mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-10-08 14:51:49 +00:00
130022 gjames: Merged 5.2.N-AHIND (5.2.1) to searchapi (5.2.1) 129926 ahind: SEARCH-31 SOLR 6 - Shard based on date - SOLR implementation - Support returning a date, datetime or string property to use for sharding git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/BRANCHES/DEV/5.2.N/root@130285 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
178 lines
5.4 KiB
Java
178 lines
5.4 KiB
Java
/*
|
|
* #%L
|
|
* Alfresco Repository
|
|
* %%
|
|
* Copyright (C) 2005 - 2016 Alfresco Software Limited
|
|
* %%
|
|
* This file is part of the Alfresco software.
|
|
* If the software was purchased under a paid Alfresco license, the terms of
|
|
* the paid license agreement will prevail. Otherwise, the software is
|
|
* provided under the following open source license terms:
|
|
*
|
|
* 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 <http://www.gnu.org/licenses/>.
|
|
* #L%
|
|
*/
|
|
package org.alfresco.repo.domain.solr;
|
|
|
|
import java.util.ArrayList;
|
|
import java.util.List;
|
|
import java.util.Set;
|
|
|
|
import org.alfresco.model.ContentModel;
|
|
import org.alfresco.repo.domain.qname.QNameDAO;
|
|
import org.alfresco.repo.solr.NodeParameters;
|
|
import org.alfresco.service.namespace.QName;
|
|
import org.alfresco.util.Pair;
|
|
|
|
/**
|
|
* Stores node query parameters for use in SOLR DAO queries
|
|
*
|
|
* @since 4.0
|
|
*/
|
|
public class NodeParametersEntity extends NodeParameters
|
|
{
|
|
private List<Long> includeTypeIds;
|
|
private List<Long> excludeTypeIds;
|
|
|
|
private List<Long> includeAspectIds;
|
|
private List<Long> excludeAspectIds;
|
|
|
|
private Long originalIdPropQNameId;
|
|
private Long shardPropertyQNameId;
|
|
|
|
/**
|
|
* Public constructor, but not generally useful
|
|
*/
|
|
public NodeParametersEntity(QNameDAO qnameDAO)
|
|
{
|
|
Pair<Long, QName> qnamePair = qnameDAO.getQName(ContentModel.PROP_ORIGINAL_ID);
|
|
this.setOriginalIdPropQNameId(qnamePair == null ? -1 : qnamePair.getFirst());
|
|
}
|
|
|
|
/**
|
|
* Construct from higher-level parameters
|
|
*/
|
|
public NodeParametersEntity(NodeParameters params, QNameDAO qnameDAO)
|
|
{
|
|
this(qnameDAO);
|
|
|
|
this.setFromNodeId(params.getFromNodeId());
|
|
this.setToNodeId(params.getToNodeId());
|
|
|
|
this.setFromTxnId(params.getFromTxnId());
|
|
this.setToTxnId(params.getToTxnId());
|
|
this.setTransactionIds(params.getTransactionIds());
|
|
|
|
this.setStoreIdentifier(params.getStoreIdentifier());
|
|
this.setStoreProtocol(params.getStoreProtocol());
|
|
|
|
// Translate the QNames, if provided
|
|
if (params.getIncludeNodeTypes() != null)
|
|
{
|
|
Set<Long> qnamesIds = qnameDAO.convertQNamesToIds(params.getIncludeNodeTypes(), false);
|
|
this.setIncludeTypeIds(new ArrayList<Long>(qnamesIds));
|
|
}
|
|
|
|
if (params.getExcludeNodeTypes() != null)
|
|
{
|
|
Set<Long> qnamesIds = qnameDAO.convertQNamesToIds(params.getExcludeNodeTypes(), false);
|
|
this.setExcludeTypeIds(new ArrayList<Long>(qnamesIds));
|
|
}
|
|
|
|
if (params.getExcludeAspects() != null)
|
|
{
|
|
Set<Long> qnamesIds = qnameDAO.convertQNamesToIds(params.getExcludeAspects(), false);
|
|
this.setExcludeAspectIds(new ArrayList<Long>(qnamesIds));
|
|
}
|
|
|
|
if (params.getIncludeAspects() != null)
|
|
{
|
|
Set<Long> qnamesIds = qnameDAO.convertQNamesToIds(params.getIncludeAspects(), false);
|
|
this.setIncludeAspectIds(new ArrayList<Long>(qnamesIds));
|
|
}
|
|
}
|
|
|
|
public void setOriginalIdPropQNameId(Long originalIdPropQNameId)
|
|
{
|
|
this.originalIdPropQNameId = originalIdPropQNameId;
|
|
}
|
|
|
|
public Long getOriginalIdPropQNameId()
|
|
{
|
|
return originalIdPropQNameId;
|
|
}
|
|
|
|
public boolean getStoreFilter()
|
|
{
|
|
return (getStoreProtocol() != null || getStoreIdentifier() != null);
|
|
}
|
|
|
|
public List<Long> getIncludeAspectIds()
|
|
{
|
|
return includeAspectIds;
|
|
}
|
|
|
|
public void setIncludeAspectIds(List<Long> includeAspectIds)
|
|
{
|
|
this.includeAspectIds = includeAspectIds;
|
|
}
|
|
|
|
public List<Long> getExcludeAspectIds()
|
|
{
|
|
return excludeAspectIds;
|
|
}
|
|
|
|
public void setExcludeAspectIds(List<Long> excludeAspectIds)
|
|
{
|
|
this.excludeAspectIds = excludeAspectIds;
|
|
}
|
|
|
|
public List<Long> getIncludeTypeIds()
|
|
{
|
|
return includeTypeIds;
|
|
}
|
|
|
|
public void setIncludeTypeIds(List<Long> includeTypeIds)
|
|
{
|
|
this.includeTypeIds = includeTypeIds;
|
|
}
|
|
|
|
public List<Long> getExcludeTypeIds()
|
|
{
|
|
return excludeTypeIds;
|
|
}
|
|
|
|
public void setExcludeTypeIds(List<Long> excludeTypeIds)
|
|
{
|
|
this.excludeTypeIds = excludeTypeIds;
|
|
}
|
|
|
|
public boolean isIncludeNodesTable()
|
|
{
|
|
return (getFromNodeId() != null || getToNodeId() != null || getIncludeTypeIds() != null || getExcludeTypeIds() != null || getIncludeAspectIds() != null || getExcludeAspectIds() != null);
|
|
}
|
|
|
|
public Long getShardPropertyQNameId()
|
|
{
|
|
return this.shardPropertyQNameId;
|
|
}
|
|
|
|
public void setShardPropertyQNameId(Long shardPropertyQNameId)
|
|
{
|
|
this.shardPropertyQNameId = shardPropertyQNameId;
|
|
}
|
|
|
|
|
|
}
|