com.versionone.apiclient.interfaces.IAttributeDefinition Maven / Gradle / Ivy
package com.versionone.apiclient.interfaces;
import com.versionone.apiclient.exceptions.APIException;
import com.versionone.apiclient.exceptions.MetaException;
import com.versionone.apiclient.exceptions.V1Exception;
import com.versionone.apiclient.filters.IFilterTerm;
/**
* Defines methods for the definition of a VersionOne attribute
*/
public interface IAttributeDefinition {
/**
* Supported attribute types
*/
public enum AttributeType {
Boolean,
Numeric,
Date,
Duration,
Text,
LongText,
LocalizerTag,
Password,
AssetType,
Relation,
Opaque,
State,
Rank,
Blob,
LongInt,
Guid,
}
/**
* Supported aggregate types
*/
public enum Aggregate
{
Sum,
Min,
Max,
Count,
And,
Or
}
/**
* Attempt to convert the value into this type
*
* @param value - value to coerce
* @return same value in this type
* @throws V1Exception - if the value cannot be converted
*/
Object coerce(Object value) throws V1Exception;
/**
* Get asset type information to this attribute
*
* @return IAssetType for this attribute
* @throws MetaException - MetaException
*/
IAssetType getAssetType() throws MetaException;
/**
* Get attribute name
*
* @return string containing name
*/
String getName();
/**
* Get attribute display name
*
* @return String
*/
String getDisplayName();
/**
* Get attribute token
*
* @return String containing token
*/
String getToken();
/**
* Get type of attribute
*
* @return AttributeType for this instance
*/
AttributeType getAttributeType();
/**
* Get base attribute information
*
* @return IAttributeDefinition for base
* @throws MetaException if there is no base
*/
IAttributeDefinition getBase() throws MetaException;
/**
* Is this attribute read-only
*
* @return true if read-only, false otherwise
*/
boolean isReadOnly();
/**
* Is this a required attribute
*
* @return true if attribute is required, false otherwise
*/
boolean isRequired();
/**
* Does this attribute support multiple values
*
* @return true if attribute supports multiple-values, false otherwise
*/
boolean isMultiValue();
/**
* Get type information for related asset if this attribute is a relation
*
* @return IAssetType for related asset
* @throws MetaException - if we cannot get the Asset Type information
*/
IAssetType getRelatedAsset() throws MetaException;
/**
* Downcast current object
*
* @param assetType IAssetType for asset defined in token
* @return Downcasted object
*/
IAttributeDefinition downcast(IAssetType assetType);
/**
* Add filter to object
*
* @param filter filter for adding
* @return object with filter
* @throws APIException if filter has incorrect statement
*/
IAttributeDefinition filter(IFilterTerm filter) throws APIException;
/**
* Join current token with new
*
* @param joined Object with token for joining
* @return new object with joined tokens
*/
IAttributeDefinition join(IAttributeDefinition joined);
/**
* Aggregate objects
*
* @param aggregate rule for Aggregating
* @return agregated object
*/
IAttributeDefinition aggregate(Aggregate aggregate);
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy