/* * Copyright (C) 2005-2011 Alfresco Software Limited. * * This file is part of Alfresco * * Alfresco is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Alfresco is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with Alfresco. If not, see . */ package org.alfresco.repo.solr; import java.util.List; import java.util.Map; import java.util.Set; import org.alfresco.repo.domain.node.Node; import org.alfresco.service.namespace.QName; /** * Interface for component to provide tracking data for SOLR. * * @since 4.0 */ public interface SOLRTrackingComponent { /** * Get the ACL changesets for given range parameters * * @param minAclChangeSetId minimum ACL changeset ID - (inclusive and optional) * @param fromCommitTime minimum ACL commit time - (inclusive and optional) * @param maxResults limit the results. 0 or Integer.MAX_VALUE does not limit the results * @return list of ACL changesets */ public List getAclChangeSets(Long minAclChangeSetId, Long fromCommitTime, int maxResults); /** * Get the ACLs with paging options for a specific ACL ChangeSet * * @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 ACL readers ("authorities who can read this ACL") for a given set of ACL IDs * * @param aclIds the ACL IDs * @return Returns the list of ACL readers (includes original ACL IDs) */ public List getAclsReaders(List aclIds); /** * 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 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, int maxResults); /** * Get the nodes satisfying the constraints in nodeParameters * * @param nodeParameters set of constraints for which nodes to return * @param maxResults limit the results. 0 or Integer.MAX_VALUE does not limit the results * @param callback a callback to receive the results */ public void getNodes(NodeParameters nodeParameters, NodeQueryCallback callback); /** * Returns metadata for a set of node ids * * @param nodeIds a set of nodeIds for which to return node metadata * @param maxResults limit the results. 0 or Integer.MAX_VALUE does not limit the results * @param callback a callback to receive the results */ public void getNodesMetadata(NodeMetaDataParameters nodeMetaDataParameters, MetaDataResultsFilter resultFilter, NodeMetaDataQueryCallback callback); /** * Returns the Alfresco model given by the name modelName * * @param modelName the name of the model * @return the model plus a checksum */ public AlfrescoModel getModel(QName modelName); /** * Returns a list of diffs representing differences between the current Repository models * and those passed in the models parameter. * * @param models a set of mappings of model names to checksums * @return a list of diffs between those in the repository and those passed in the models parameter */ public List getModelDiffs(Map models); /** * The interface that will be used to give query results to the calling code. */ public interface NodeQueryCallback { /** * Handle a node. * * @param node the node * @return Return true to continue processing rows or false to stop */ boolean handleNode(Node node); } /** * The interface that will be used to give query results to the calling code. */ public interface NodeMetaDataQueryCallback { /** * Handle a node. * * @param node the node meta data * @return Return true to continue processing rows or false to stop */ boolean handleNodeMetaData(NodeMetaData nodeMetaData); } /** * @return */ boolean isEnabled(); /** * @param enabled */ void setEnabled(boolean enabled); /** * Get the last transaction timestamp from the repo * @return */ public Long getMaxTxnCommitTime(); }