mirror of
				https://github.com/Alfresco/alfresco-community-repo.git
				synced 2025-10-15 15:02:20 +00:00 
			
		
		
		
	- ALF-8806 RINF 41: Lucene Removal: Fix CopyService
     - ALF-9028: RINF 41: Fix Aspect cm:copiedFrom
   - ALF-9029 RINF 49: Lucene Removal: CheckOutCheckInService API
     - ALF-9032: RINF 49: fixes to cm:workingcopy aspect
   28996: Dev branch for De-Lucene work pending patches
   29004: Evaluator runs in read-only txn
   29006: Additional PermissionCheckedCollection.create method
          - Use an existing collection's permission check data (cut-off, etc) to wrap a new collection
   29007:
          CopyService and CheckOutCheckInService refactors to remove Lucene
          
          CopyService:
          
          Removed cm:source property from cm:copiedfrom aspect and replaced with a cm:original association.
          Added CQ-based APIs to query for copies
          Added APIs to support bi-directional walking of copy association
          Fixed sundry uses of cm:copiedfrom esp. all uses related to cm:workingcopy
          
          CheckOutCheckInService:
          
          Check-out now creates a source aspect cm:checkedOut with 1:1 relationship to cm:workingcopy via cm:workingcopylink
          Removed explicit use of cm:workingcopy aspect and replaced it with calls to COCI API
          
   29083: Audit tests fail when indexing is turned off.
          Also removed a getReader() call during rule evaluation, leading to a 'sub-action' read being recorded.
   29113: NodeDAO.getNodesWithAspects supports paging
   29135: Removed unused patch queries
   29139: Basic patch (still terminates with error) to upgrade cm:copiedfrom and cm:workingcopy
   29157: Tested patch for cm:copiedfrom and cm:workingcopy aspects
git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@29159 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
		
	
		
			
				
	
	
		
			248 lines
		
	
	
		
			8.5 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
			
		
		
	
	
			248 lines
		
	
	
		
			8.5 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
| /*
 | |
|  * Copyright (C) 2005-2010 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 <http://www.gnu.org/licenses/>.
 | |
|  */
 | |
| package org.alfresco.repo.domain.patch;
 | |
| 
 | |
| import java.util.List;
 | |
| import java.util.Map;
 | |
| import java.util.Set;
 | |
| 
 | |
| import org.alfresco.repo.domain.avm.AVMNodeEntity;
 | |
| import org.alfresco.repo.domain.contentdata.ContentDataDAO;
 | |
| import org.alfresco.service.cmr.repository.ContentData;
 | |
| import org.alfresco.service.cmr.repository.NodeRef;
 | |
| import org.alfresco.service.namespace.QName;
 | |
| import org.alfresco.util.Pair;
 | |
| import org.apache.ibatis.session.ResultHandler;
 | |
| 
 | |
| /**
 | |
|  * Additional DAO services for patches
 | |
|  *
 | |
|  * @author janv
 | |
|  * @author Derek Hulley
 | |
|  * @since 3.2
 | |
|  */
 | |
| public interface PatchDAO
 | |
| {
 | |
|     // AVM-related
 | |
|     
 | |
|     public long getAVMNodesCountWhereNewInStore();
 | |
|     
 | |
|     public List<AVMNodeEntity> getEmptyGUIDS(int count);
 | |
|     
 | |
|     public List<AVMNodeEntity> getNullVersionLayeredDirectories(int count);
 | |
|     
 | |
|     public List<AVMNodeEntity> getNullVersionLayeredFiles(int count);
 | |
|     
 | |
|     public long getMaxAvmNodeID();
 | |
|     
 | |
|     public List<Long> getAvmNodesWithOldContentProperties(Long minNodeId, Long maxNodeId);
 | |
|     
 | |
|     public int updateAVMNodesNullifyAcl(List<Long> nodeIds);
 | |
|     
 | |
|     public int updateAVMNodesSetAcl(long aclId, List<Long> nodeIds);
 | |
|     
 | |
|     // DM-related
 | |
|     
 | |
|     public long getMaxAdmNodeID();
 | |
|     
 | |
|     /**
 | |
|      * Migrates DM content properties from the old V3.1 format (String-based {@link ContentData#toString()})
 | |
|      * to the new V3.2 format (ID based storage using {@link ContentDataDAO}).
 | |
|      * 
 | |
|      * @param minNodeId         the inclusive node ID to limit the updates to
 | |
|      * @param maxNodeId         the exclusive node ID to limit the updates to
 | |
|      */
 | |
|     public void updateAdmV31ContentProperties(Long minNodeId, Long maxNodeId);
 | |
|     
 | |
|     /**
 | |
|      * Update all <b>alf_content_data</b> 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);
 | |
|     
 | |
|     /**
 | |
|      * A callback handler for iterating over the string results
 | |
|      */
 | |
|     public interface StringHandler
 | |
|     {
 | |
|         void handle(String string);
 | |
|     }
 | |
|     
 | |
|     /**
 | |
|      * Add a <b>cm:sizeCurrent</b> property to person nodes that don't have it.
 | |
|      */
 | |
|     public int addSizeCurrentProp();
 | |
|     
 | |
|     // ACL-related
 | |
|     
 | |
|     /**
 | |
|      * Get the max acl id
 | |
|      * 
 | |
|      * @return - max acl id
 | |
|      */
 | |
|     public long getMaxAclId();
 | |
|     
 | |
|     /**
 | |
|      * How many DM nodes are there?
 | |
|      * 
 | |
|      * @return - the count
 | |
|      */
 | |
|     public long getDmNodeCount();
 | |
|     
 | |
|     /**
 | |
|      * How many DM nodes are three with new ACls (to track patch progress)
 | |
|      * 
 | |
|      * @param above
 | |
|      * @return - the count
 | |
|      */
 | |
|     public long getDmNodeCountWithNewACLs(Long above);
 | |
|     
 | |
|     public List<Long> selectAllAclIds();
 | |
|     
 | |
|     public List<Long> selectNonDanglingAclIds();
 | |
|     
 | |
|     public int deleteDanglingAces();
 | |
|     
 | |
|     public int deleteAcls(List<Long> aclIds);
 | |
|     
 | |
|     public int deleteAclMembersForAcls(List<Long> aclIds);
 | |
|     
 | |
|     /**
 | |
|      * @return      Returns the names of authorities with incorrect CRC values
 | |
|      */
 | |
|     public List<String> getAuthoritiesWithNonUtf8Crcs();
 | |
|     
 | |
|     /**
 | |
|      * @return                      Returns the number child association rows
 | |
|      */
 | |
|     public int getChildAssocCount();
 | |
|     
 | |
|     /**
 | |
|      * 
 | |
|      * @return                      Returns the maximum child assoc ID or <tt>0</tt> if there are none
 | |
|      */
 | |
|     Long getMaxChildAssocId();
 | |
|     
 | |
|     /**
 | |
|      * The results map contains:
 | |
|      * <pre>
 | |
|      * <![CDATA[
 | |
|         <result property="id" column="id" jdbcType="BIGINT" javaType="java.lang.Long"/>
 | |
|         <result property="typeQNameId" column="type_qname_id" jdbcType="BIGINT" javaType="java.lang.Long"/>
 | |
|         <result property="qnameNamespaceId" column="qname_ns_id" jdbcType="BIGINT" javaType="java.lang.Long"/>
 | |
|         <result property="qnameLocalName" column="qname_localname" jdbcType="VARCHAR" javaType="java.lang.String"/>
 | |
|         <result property="childNodeNameCrc" column="child_node_name_crc" jdbcType="BIGINT" javaType="java.lang.Long"/>
 | |
|         <result property="qnameCrc" column="qname_crc" jdbcType="BIGINT" javaType="java.lang.Long"/>
 | |
|         <result property="childNodeUuid" column="child_node_uuid" jdbcType="VARCHAR" javaType="java.lang.String"/>
 | |
|         <result property="childNodeName" column="child_node_name" jdbcType="VARCHAR" javaType="java.lang.String"/>
 | |
|        ]]>
 | |
|      * </pre>
 | |
|      * @param minAssocId            the minimum child assoc ID
 | |
|      * @param stopAtAssocId         the child assoc ID to stop at i.e. once this ID has been reached,
 | |
|      *                              pull back no results
 | |
|      * @param rangeMultiplier       the ration of IDs to actual rows (how many IDs to select to get a row)
 | |
|      * @param maxIdRange            the largest ID range to use for selects.  Normally, the ID range should be
 | |
|      *                              allowed to grow in accordance with the general distribution of rows, but
 | |
|      *                              if memory problems are encountered, then the range will need to be set down.
 | |
|      * @param maxResults            the number of child associations to fetch
 | |
|      * @return                      Returns child associations <b>that need fixing</b>
 | |
|      */
 | |
|     public List<Map<String, Object>> getChildAssocsForCrcFix(
 | |
|             Long minAssocId,
 | |
|             Long stopAtAssocId,
 | |
|             long rangeMultiplier,
 | |
|             long maxIdRange,
 | |
|             int maxResults);
 | |
|     
 | |
|     public int updateChildAssocCrc(Long assocId, Long childNodeNameCrc, Long qnameCrc);
 | |
|     
 | |
|     /**
 | |
|      * 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<Pair<NodeRef, String>> getNodesOfTypeWithNamePattern(QName typeQName, String namePattern);
 | |
|     
 | |
|     /**
 | |
|      * Migrate old Tenant attributes (if any)
 | |
|      */
 | |
|     public void migrateOldAttrTenants(ResultHandler resultHandler);
 | |
|     
 | |
|     /**
 | |
|      * Migrate old AVM Lock attributes (if any)
 | |
|      */
 | |
|     public void migrateOldAttrAVMLocks(ResultHandler resultHandler);
 | |
|     
 | |
|     /**
 | |
|      * Migrate old Property-Backed Bean attributes (if any)
 | |
|      */
 | |
|     public void migrateOldAttrPropertyBackedBeans(ResultHandler resultHandler);
 | |
|     
 | |
|     /**
 | |
|      * Migrate old Chaining User Registry Synchronizer attributes (if any)
 | |
|      */
 | |
|     public void migrateOldAttrChainingURS(ResultHandler resultHandler);
 | |
|     
 | |
|     /**
 | |
|      * Drop old attribute alf_*attribute* tables
 | |
|      */
 | |
|     public void migrateOldAttrDropTables();
 | |
|     
 | |
|     /**
 | |
|      * Get custom global attribute names (if any)
 | |
|      */
 | |
|     public List<String> getOldAttrCustomNames();
 | |
|     
 | |
|     /**
 | |
|      * Get shared acls with inheritance issues
 | |
|      */
 | |
|     public List<Map<String, Object>> getSharedAclsThatDoNotInheritCorrectlyFromThePrimaryParent();
 | |
|     
 | |
|     /**
 | |
|      * Get defining acls with inheritance issues
 | |
|      */
 | |
|     public List<Map<String, Object>> getDefiningAclsThatDoNotInheritCorrectlyFromThePrimaryParent();
 | |
|     
 | |
|     /**
 | |
|      * Get acls that do not inherit from the primary parent.
 | |
|      */
 | |
|     public List<Map<String, Object>> getAclsThatInheritFromNonPrimaryParent();
 | |
|     
 | |
|     /**
 | |
|      * Get acls that inherit with inheritance unset
 | |
|      */
 | |
|     public List<Map<String, Object>> getAclsThatInheritWithInheritanceUnset();
 | |
|     
 | |
|     /**
 | |
|      * Get shared acls that do not inherit correctly from the defining acl
 | |
|      */
 | |
|     public List<Map<String, Object>> getSharedAclsThatDoNotInheritCorrectlyFromTheirDefiningAcl();
 | |
|     
 | |
|     /**
 | |
|      * @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<QName> qnames);
 | |
| }
 |