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

com.versionone.apiclient.RequiredFieldValidator Maven / Gradle / Ivy

package com.versionone.apiclient;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import com.versionone.Oid;
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.filters.AndFilterTerm;
import com.versionone.apiclient.filters.FilterTerm;
import com.versionone.apiclient.filters.IFilterTerm;
import com.versionone.apiclient.interfaces.IAssetType;
import com.versionone.apiclient.interfaces.IAttributeDefinition;
import com.versionone.apiclient.interfaces.IMetaModel;
import com.versionone.apiclient.interfaces.IServices;
import com.versionone.apiclient.services.QueryResult;

public class RequiredFieldValidator {
    private final Map> requiredFields;
    private final IMetaModel metaModel;
    private final IServices services;

    public RequiredFieldValidator(IMetaModel metaModel, IServices services) {
        requiredFields = new HashMap>();
        this.metaModel = metaModel;
        this.services = services;
    }

    /**
     * Validate single Asset attribute. If attribute is not loaded, it is just considered invalid.
     *
     * @param asset 				- Asset to validate
     * @param attributeDefinition 	- Attribute definition of validated attribute
     * @return Validation result
     * @throws APIException - APIException
     * @throws OidException - OidException
     * @throws ConnectionException - ConnectionException
     */
    public boolean validate(Asset asset, IAttributeDefinition attributeDefinition) throws APIException, ConnectionException, OidException {
        getRequiredFields(asset.getAssetType());
        asset.ensureAttribute(attributeDefinition);
        Attribute attribute = asset.getAttribute(attributeDefinition);

        boolean result = attribute != null && !(isMultiValueAndUnfilled(attribute) || isSingleValueAndUnfilled(attribute));

        if (!result) {
        	result = !attribute.hasChanged() && !isAttributeUnfilledOnServer(asset, attributeDefinition);
        }
        return result;
    }

    /**
	 *	Validate all available Asset attributes.
     *	If there are required attributes that haven't been loaded, these are considered failures.
     *	In some cases, attributes could exist on server and have valid values, but it's up to user to retrieve them or ignore corresponding validation errors.
     *
     *  @param asset	- Asset to validate
     *  @return Collection of attribute definitions for attributes which values do not pass validation
     * @throws APIException - APIException
     * @throws OidException - OidException
     * @throws ConnectionException - ConnectionException
     */
    public List validate(Asset asset) throws APIException, ConnectionException, OidException {
        getRequiredFields(asset.getAssetType());
        List results = new ArrayList();
        List requiredAttributes = requiredFields.get(asset.getAssetType());

        for (IAttributeDefinition attributeDefinition : requiredAttributes) {
        	asset.ensureAttribute(attributeDefinition);
            Attribute attribute = asset.getAttribute(attributeDefinition);

            if(attribute == null || !validate(asset, attributeDefinition)) {
                results.add(attributeDefinition);
            }
        }

        return results;
    }

    /**
     * Validate collection of Assets.
     *
     * @param assets - Assets collection to check.
     * @return Validation results dictionary, each entry value key is Asset, and value is output of @seeValidate(Asset)
     * @throws APIException - APIException
     * @throws OidException - OidException
     * @throws ConnectionException - ConnectionException
     */
    public Map> validate(Asset[] assets) throws APIException, ConnectionException, OidException {
        Map> results = new HashMap>();

        for (Asset asset : assets) {
            results.put(asset, validate(asset));
        }

        return results;
    }

    /**
     * Check whether the attribute corresponding to the attributeName is required in current VersionOne server setup.
     *
     * @param assetType		- Asset type.
     * @param attributeName - Attribute name.
     * @return is specified attribute required for specified asset.
     * @throws MetaException - MetaException
     * @throws OidException  - OidException
     * @throws APIException - APIException
     * @throws ConnectionException - ConnectionException
     */
    public boolean isRequired(IAssetType assetType, String attributeName) throws ConnectionException, APIException, OidException, MetaException {
        return isRequired(assetType.getAttributeDefinition(attributeName));
    }

    /**
     * Check whether the provided attribute is required in current VersionOne server setup.
     *
     * @param definition - Attribute definition.
     * @return is specified attribute definition required.
     * @throws MetaException - MetaException
     * @throws OidException - OidException
     * @throws APIException - APIException
     * @throws ConnectionException - ConnectionException
     */
    public boolean isRequired(IAttributeDefinition definition) throws ConnectionException, APIException, OidException, MetaException {
        getRequiredFields(definition.getAssetType());
        return isRequiredField(definition.getAssetType(), definition.getName());
    }

    /**
     * Get required fields for asset type.
     *
     * @param assetType - Asset type.
     * @throws OidException
     * @throws APIException
     * @throws ConnectionException
     */
    private void getRequiredFields(IAssetType assetType) throws ConnectionException, APIException, OidException {
        if (!requiredFields.containsKey(assetType)) {
            List requiredFieldsForType = loadRequiredFields(assetType);
            requiredFields.put(assetType, requiredFieldsForType);
        }
    }

    /**
     * Load required fields attribute definitions for provided Asset type.
     * 
     * @param assetType - Asset type.
     * @return Collection of attribute definitions for required fields.
     * @throws OidException
     * @throws APIException
     * @throws ConnectionException
     */
    private List loadRequiredFields(IAssetType assetType) throws ConnectionException, APIException, OidException {
        List requiredFieldsForType = new ArrayList();

        IAssetType attributeDefinitionAssetType = metaModel.getAssetType("AttributeDefinition");
        IAttributeDefinition nameAttributeDef = attributeDefinitionAssetType.getAttributeDefinition("Name");
        IAttributeDefinition assetNameAttributeDef =
            attributeDefinitionAssetType.getAttributeDefinition("Asset.AssetTypesMeAndDown.Name");

        Query query = new Query(attributeDefinitionAssetType);
        query.getSelection().add(nameAttributeDef);
        FilterTerm assetTypeTerm = new FilterTerm(assetNameAttributeDef);
        assetTypeTerm.equal(assetType.getToken());
        query.setFilter(new AndFilterTerm(new IFilterTerm[] { assetTypeTerm }));

        QueryResult result = services.retrieve(query);

        for (Asset asset : result.getAssets()) {
        	Attribute attr = asset.getAttribute(nameAttributeDef);
        	if (attr == null) {
        		continue;
        	}
            String name = (String)attr.getValue();
            if (isRequiredField(assetType, name)) {
                IAttributeDefinition definition = assetType.getAttributeDefinition(name);
                requiredFieldsForType.add(definition);
            }
        }

        return requiredFieldsForType;
    }

    private boolean isRequiredField(IAssetType assetType, String name) {
        IAttributeDefinition def = assetType.getAttributeDefinition(name);
        return def.isRequired() && !def.isReadOnly();
    }

    private boolean isSingleValueAndUnfilled(Attribute attribute) throws APIException {
        return !attribute.getDefinition().isMultiValue() &&
                ((attribute.getValue() instanceof Oid && ((Oid)attribute.getValue()).isNull()) ||
                 attribute.getValue() == null);
    }

    private boolean isMultiValueAndUnfilled(Attribute attribute) {
        return (attribute.getDefinition().isMultiValue() && attribute.getValues().length < 1);
    }

    private boolean isAttributeUnfilledOnServer(Asset asset, IAttributeDefinition attributeDefinition) {
    	if (asset.getOid() == Oid.Null) {
    		return true;
    	}
        Query query = new Query(asset.getOid());
        query.getSelection().add(attributeDefinition);
        QueryResult result = null;
    	try {
    		result = services.retrieve(query);
		} catch (Exception e) {
			//do nothing
		}

		if(result != null) {
			Attribute attr = result.getAssets()[0].getAttribute(attributeDefinition);
			try {
				return isSingleValueAndUnfilled(attr) && isMultiValueAndUnfilled(attr);
			} catch (APIException e) {
				// do nothing
			}
		}

		return true; // there is no data on the server.
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy