All Downloads are FREE. Search and download functionalities are using the official Maven repository.

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