package org.alfresco.repo.domain.solr; import java.util.List; import org.alfresco.repo.domain.node.Node; import org.alfresco.repo.solr.Acl; import org.alfresco.repo.solr.AclChangeSet; import org.alfresco.repo.solr.NodeParameters; import org.alfresco.repo.solr.Transaction; /** * DAO support for SOLR web scripts. * * @since 4.0 */ public interface SOLRDAO { /** * Get the ACL changesets summary (rollup count) with paging options * * @param minAclChangeSetId minimum ACL changeset ID - (inclusive and optional) * @param fromCommitTime minimum ACL commit time - (inclusive and optional) * @param maxAclChangeSetId maximum ACL changeset ID - (exclusive and optional) * @param toCommitTime maximum ACL commit time - (exclusive and optional) * @param maxResults limit the results (must be greater than zero and less than MAX) * @return list of ACL changesets (no details) */ public List getAclChangeSets(Long minAclChangeSetId, Long fromCommitTime, Long maxAclChangeSetId, Long toCommitTime, int maxResults); /** * Get the ACLs (no rollup count) for the given ACL ChangeSets * * @param aclChangeSetIds the ACL ChangeSet IDs * @param minAclId the minimum ACL ID - (inclusive and optional). * @param maxResults the maximum number of results (must be greater than zero and less than MAX) * @return list of ACLs */ public List getAcls(List aclChangeSetIds, Long minAclId, int maxResults); /** * Get the transactions from either minTxnId or fromCommitTime, optionally limited to maxResults * * @param minTxnId greater than or equal to minTxnId * @param fromCommitTime greater than or equal to transaction commit time * @param maxTxnId less than maxTxnId * @param toCommitTime less than toCommitTime * @param maxResults limit the results. 0 or Integer.MAX_VALUE does not limit the results * @return list of transactions */ public List getTransactions(Long minTxnId, Long fromCommitTime, Long maxTxnId, Long toCommitTime, int maxResults); /** * Get the nodes satisfying the constraints in nodeParameters * * @param nodeParameters set of constraints for which nodes to return * @return list of matching nodes */ public List getNodes(NodeParameters nodeParameters); }