/* * Copyright (C) 2005-2014 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.domain.patch; import java.util.List; import java.util.Set; import org.alfresco.service.cmr.repository.NodeRef; import org.alfresco.service.namespace.QName; import org.alfresco.util.Pair; /** * Additional DAO services for patches * * @author janv * @author Derek Hulley * @since 3.2 */ public interface PatchDAO { // DM-related public long getMaxAdmNodeID(); /** * Update all alf_content_data mimetype references. * * @param oldMimetypeId the ID to search for * @param newMimetypeId the ID to change to * @return the number of rows affected */ public int updateContentMimetypeIds(Long oldMimetypeId, Long newMimetypeId); /** * Query for a list of nodes that have a given type and share the same name pattern (SQL LIKE syntax) * * @param typeQName the node type * @param namePattern the SQL LIKE pattern * @return Returns the node ID and node name */ public List> getNodesOfTypeWithNamePattern(QName typeQName, String namePattern); /** * @param qnames the qnames to search for * @return Returns a count of the number of nodes that have either of the aspects */ public long getCountNodesWithAspects(Set qnames); /** * Find all the nodes ids with the given type * @param typeQNameId - the id of the type qname * @param minNodeId - min node id in the result set - inclusive * @param maxNodeId - max node id in the result set - exclusive * @return IDs of the nodes */ public List getNodesByTypeQNameId(Long typeQNameId, Long minNodeId, Long maxNodeId); /** * Find all the nodes ids with the given type uri * @param uriId - the id of the type qname uri * @param minNodeId - min node id in the result set - inclusive * @param maxNodeId - max node id in the result set - exclusive * @return IDs of the nodes */ public List getNodesByTypeUriId(Long uriId, Long minNodeId, Long maxNodeId); /** * Find all the nodes ids with the given aspect * @param aspectQNameId - the id of the aspect qname * @param minNodeId - min node id in the result set - inclusive * @param maxNodeId - max node id in the result set - exclusive * @return IDs of the nodes */ public List getNodesByAspectQNameId(Long aspectQNameId, Long minNodeId, Long maxNodeId); /** * Find all the nodes ids with the given content property set with the given mimetype * @param mimetypeId - the id of the content data mimetype * @param minNodeId - min node id in the result set - inclusive * @param maxNodeId - max node id in the result set - exclusive * @return IDs of the nodes */ public List getNodesByContentPropertyMimetypeId(Long mimetypeId, Long minNodeId, Long maxNodeId); /** * Gets the total number of nodes which match the given Type QName. * * @param typeQName the qname to search for * @return count of nodes that match the typeQName */ public long getCountNodesWithTypId(QName typeQName); /** * Finds folders of the shared surf-config (for all tenants): *
    *
  • company_home/sites/surf-config/components
  • *
  • company_home/sites/surf-config/pages
  • *
  • company_home/sites/surf-config/pages/user
  • *
  • company_home/sites/surf-config/pages/user{userId}
  • *
* @param minNodeId - min node id in the result set - inclusive * @param maxNodeId - max node id in the result set - exclusive * @return list of children nodeRefs */ public List getChildrenOfTheSharedSurfConfigFolder(Long minNodeId, Long maxNodeId); }