/* * 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 org.alfresco.repo.domain.node.Node; /** * 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 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); /** * 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); } }