/* * 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 . */ package org.alfresco.repo.domain.patch; import java.util.List; import java.util.Map; 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.cmr.repository.StoreRef; import org.alfresco.service.namespace.QName; import org.alfresco.util.Pair; import com.ibatis.sqlmap.client.event.RowHandler; /** * Additional DAO services for patches * * @author janv * @author Derek Hulley * @since 3.2 */ public interface PatchDAO { // AVM-related public long getAVMNodesCountWhereNewInStore(); public List getEmptyGUIDS(int count); public List getNullVersionLayeredDirectories(int count); public List getNullVersionLayeredFiles(int count); public long getMaxAvmNodeID(); public List getAvmNodesWithOldContentProperties(Long minNodeId, Long maxNodeId); public int updateAVMNodesNullifyAcl(List nodeIds); public int updateAVMNodesSetAcl(long aclId, List 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 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); /** * A callback handler for iterating over the string results */ public interface StringHandler { void handle(String string); } /** * Iterate over all person nodes with missing usage property (for one-off patch) * * @param storeRef the store to search in * @param handler the callback to use while iterating over the people * @return Returns the values for person node uuid */ public void getUsersWithoutUsageProp(StoreRef storeRef, StringHandler handler); // 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 selectAllAclIds(); public List selectNonDanglingAclIds(); public int deleteDanglingAces(); public int deleteAcls(List aclIds); public int deleteAclMembersForAcls(List aclIds); /** * @return Returns the names of authorities with incorrect CRC values */ public List getAuthoritiesWithNonUtf8Crcs(); /** * @return Returns the number child association rows */ public int getChildAssocCount(); /** * The results map contains: *
     * 
        
        
        
        
        
        
        
       ]]>
     * 
* @param minAssocId the minimum child assoc ID * @param maxResults the number of child associations to fetch * @return Returns child associations that need fixing */ public List> getChildAssocsForCrcFix(Long minAssocId, 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> getNodesOfTypeWithNamePattern(QName typeQName, String namePattern); /** * Migrate old Tenant attributes (if any) */ public void migrateOldAttrTenants(RowHandler rowHandler); /** * Migrate old AVM Lock attributes (if any) */ public void migrateOldAttrAVMLocks(RowHandler rowHandler); /** * Migrate old Property-Backed Bean attributes (if any) */ public void migrateOldAttrPropertyBackedBeans(RowHandler rowHandler); /** * Migrate old Chaining User Registry Synchronizer attributes (if any) */ public void migrateOldAttrChainingURS(RowHandler rowHandler); /** * Get custom global attribute names (if any) */ public List getOldAttrCustomNames(); /** * Delete all old attributes (from alf_*attribute* tables) */ public void deleteAllOldAttrs(); }