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

com.versionone.apiclient.interfaces.IServices Maven / Gradle / Ivy

package com.versionone.apiclient.interfaces;

import java.io.IOException;
import java.io.Reader;
import java.util.ArrayList;
import java.util.Map;

import com.versionone.Oid;
import com.versionone.apiclient.Asset;
import com.versionone.apiclient.Query;
import com.versionone.apiclient.V1Connector;
import com.versionone.apiclient.exceptions.APIException;
import com.versionone.apiclient.exceptions.ConnectionException;
import com.versionone.apiclient.exceptions.MetaException;
import com.versionone.apiclient.exceptions.OidException;
import com.versionone.apiclient.exceptions.V1Exception;
import com.versionone.apiclient.services.QueryResult;

/**
 * Methods implemented by a class providing VersionOne services.
 */
public interface IServices {

	/**
	 * Returns the type information for an asset specified in a token.
	 * 
	 * @param token The token to process
	 * @return IAssetType Based on the token
	 * @throws MetaException if the token is invalid
	 */
	IAssetType getAssetType(String token) throws MetaException;

	/**
	 * Returns the type information for an attribute specified in a token.
	 * 
	 * @param token The token to process
	 * @return IAttributeDefinition Based on the token
	 * @throws MetaException if the token is invalid
	 */
	IAttributeDefinition getAttributeDefinition(String token) throws MetaException;

	/**
	 * Returns the type information for an operation specified in a token.
	 * 
	 * @param token The token to process
	 * @return IOperation Based on the token
	 * @throws MetaException if the token is invalid
	 */
	IOperation getOperation(String token) throws MetaException;

	/**
	 * Returns an object identifier for the specified token.
	 * 
	 * @param token The token to process
	 * @return Object Identifier
	 * @throws OidException if the token is invalid
	 */
	Oid getOid(String token) throws OidException;

	/**
	 * Executes a query and returns the results.
	 * 
	 * @param query The query to execute.
	 * @return QueryResult of the query
	 * @throws ConnectionException - if connection to VersionOne down
	 * @throws OidException - if there is problem related to Object Identifiers
	 * @throws APIException if there is a problem executing the query
	 */
	QueryResult retrieve(Query query) throws ConnectionException, APIException, OidException;

	/**
	 * Persists changes to an asset without a comment.
	 * 
	 * @param asset The asset that changed
	 * @throws ConnectionException - if connection to VersionOne down
	 * @throws APIException - if the save fails
	 */
	void save(Asset asset) throws APIException, ConnectionException;

	/**
	 * Persists changes to as asset with a comment.
	 * 
	 * @param asset The asset that changed
	 * @param comment - comment
	 * @throws ConnectionException - if connection to VersionOne down
	 * @throws APIException - if the save fails
	 */
	void save(Asset asset, String comment) throws APIException, ConnectionException;

	/**
	 * Saves multiple assets without a comment.
	 * 
	 * @param assetList An array of assets to save
	 * @throws V1Exception - if the save fails
	 */
	void save(Asset[] assetList) throws V1Exception;

	/**
	 * Determines the OID of the currently logged in user.
	 * 
	 * @return Object Identifier for current user
	 * @throws ConnectionException - if connection to VersionOne down
	 * @throws OidException - if there is problem related to Object Identifiers
	 * @throws APIException - if there is any other error
	 */
	Oid getLoggedIn() throws APIException, ConnectionException, OidException;

	/**
	 * Creates a new asset.
	 * 
	 * @param assetType The type of asset to create
	 * @param context - context under which to create the asset
	 * @return New Asset
	 * @throws V1Exception - when the create fails
	 */
	Asset createNew(IAssetType assetType, Oid context) throws V1Exception;

	/**
	 * Executes an operation.
	 * 
	 * @param op The operation to execute
	 * @param oid - OID of object on which method is executed
	 * @return Oid result of operation
	 * @throws APIException - when the operation fails
	 */
	Oid executeOperation(IOperation op, Oid oid) throws APIException;

	/**
	 * Returns the MetaModel.
	 * 
	 * @return IMetaModel
	 */
	IMetaModel getMeta();

	/**
	 * Returns the V1Connector.
	 * 
	 * @return V1Connector
	 */
	V1Connector getV1Connector();

	/**
	 * Executes a Query API query using in JSON or YAML format.
	 * 
	 * @param query The query JSON or YAML query string
	 * @return String
	 */
	String executePassThroughQuery(String query);

	/**
	 * Returns a localization value based on an attribute definition.
	 * 
	 * @param attribute An attribute definition
	 * @return String String
	 * @throws V1Exception V1Exception
	 */
	String getLocalization(IAttributeDefinition attribute) throws V1Exception;

	/**
	 * Returns a localization value based on key.
	 * 
	 * @param key String A string value of the key
	 * @return String String
	 * @throws V1Exception V1Exception
	 */
	String getLocalization(String key) throws V1Exception;

	/**
	 * Returns a Map of localized values.
	 * 
	 * @param attributes attributes
	 * @return Map Map of strings
	 * @throws ConnectionException ConnectionException
	 */
	Map getLocalization(ArrayList attributes) throws ConnectionException;

	/**
	 * Saves an attachment to the specified asset.
	 * 
	 * @param filePath Path and name of the attachment file.
	 * @param asset Asset to save the attachment to.
	 * @param attachmentName The name of the attachment.
	 * @return Oid
	 * @throws V1Exception V1Exception
	 * @throws IOException IOException
	 */
	Oid saveAttachment(String filePath, Asset asset, String attachmentName) throws V1Exception, IOException;

	/**
	 * Returns the attachment data for the specified attachment Oid.
	 * 
	 * @param attachmentOid The Oid of the attachment to return.
	 * @return Reader
	 * @throws V1Exception V1Exception
	 */
	Reader getAttachment(Oid attachmentOid) throws V1Exception;

	/**
	 * Saves an embedded image to the specified asset.
	 * 
	 * @param filePath Path and name of the embedded image file.
	 * @param asset Asset to save the embedded image to.
	 * @return Oid
	 * @throws V1Exception V1Exception
	 * @throws IOException IOException
	 */
	Oid saveEmbeddedImage(String filePath, Asset asset) throws V1Exception, IOException;

	/**
	 * Returns the embedded image data for the specified attachment Oid.
	 * 
	 * @param embeddedImageOid The Oid of the embedded image to return.
	 * @return Reader
	 * @throws V1Exception V1Exception
	 */
	Reader getEmbeddedImage(Oid embeddedImageOid) throws V1Exception;

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy