package gov.nist.registry.ws.sq;
import gov.nist.registry.common2.exception.MetadataException;
import gov.nist.registry.common2.exception.MetadataValidationException;
import gov.nist.registry.common2.exception.XDSRegistryOutOfResourcesException;
import gov.nist.registry.common2.exception.XdsException;
import gov.nist.registry.common2.exception.XdsInternalException;
import gov.nist.registry.common2.registry.Metadata;
import gov.nist.registry.common2.registry.MetadataSupport;
import gov.nist.registry.common2.registry.storedquery.StoredQuerySupport;
import java.util.ArrayList;
import java.util.List;
import org.openhealthtools.openxds.log.LoggerException;
/**
Generic implementation of GetAssociations Stored Query. This class knows how to parse a
* GetAssociations Stored Query request producing a collection of instance variables describing
* the request. A sub-class must provide the runImplementation() method that uses the pre-parsed
* information about the stored query and queries a metadata database.
* @author bill
*
*/
abstract public class GetRelatedDocuments extends StoredQuery {
/**
* Method required in subclasses (implementation specific class) to define specific
* linkage to local database
* @return matching metadata
* @throws MetadataException
* @throws XdsException
* @throws LoggerException
*/
abstract protected Metadata runImplementation() throws MetadataException, XdsException, LoggerException;
/**
* Basic constructor
* @param sqs
* @throws MetadataValidationException
*/
public GetRelatedDocuments(StoredQuerySupport sqs) {
super(sqs);
}
void validateParameters() throws MetadataValidationException {
// param name, required?, multiple?, is string?, same size as, alternative
sqs.validate_parm("$XDSDocumentEntryUniqueId", true, false, true, null, "$XDSDocumentEntryEntryUUID");
sqs.validate_parm("$XDSDocumentEntryEntryUUID", true, false, true, null, "$XDSDocumentEntryUniqueId");
sqs.validate_parm("$AssociationTypes", true, true, true, null, (String[])null);
sqs.validate_parm("$XDSDocumentEntryType", false, true, true, null, (String[])null);
if (sqs.has_validation_errors)
throw new MetadataValidationException("Metadata Validation error present");
}
protected String uid;
protected String uuid;
protected List<String> assoc_types;
protected List<String> object_type;
void parseParameters() throws XdsInternalException, XdsException, LoggerException {
uid = sqs.params.getStringParm("$XDSDocumentEntryUniqueId");
uuid = sqs.params.getStringParm("$XDSDocumentEntryEntryUUID");
assoc_types = sqs.params.getListParm("$AssociationTypes");
object_type = sqs.params.getListParm("$XDSDocumentEntryType");
// the default value of object_type is stable documents
if (object_type == null) {
object_type = new ArrayList<String>();
object_type.add(MetadataSupport.XDSDocumentEntry_objectType_stable_uuid);
}
}
/**
* Implementation of Stored Query specific logic including parsing and validating parameters.
* @throws XdsInternalException
* @throws XdsException
* @throws LoggerException
* @throws XDSRegistryOutOfResourcesException
*/
public Metadata runSpecific() throws XdsException, LoggerException {
validateParameters();
parseParameters();
if (uuid == null && uid == null)
throw new XdsInternalException("GetRelatedDocuments Stored Query");
return runImplementation();
}
}