mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-06-30 18:15:39 +00:00
- Moved setting of txn isolation level to ControlDAO - Retired patches where target schema is < 100 - Removed unreferenced patch implementations - Removed unreferenced DB scripts - Moved patch-specific queries (ACL upgrade counts) into patch-common-SqlMap.xml - Fixed count query result processing (max of nothing is NULL) leading to unboxing NPEs - All DM-modifying patches depend on DmPermissionsPatch i.e. it will normally run immediately after SQL scripts git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@21908 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
205 lines
6.9 KiB
Java
205 lines
6.9 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 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<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);
|
|
}
|
|
|
|
/**
|
|
* 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<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();
|
|
|
|
/**
|
|
* 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 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, 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(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<String> getOldAttrCustomNames();
|
|
|
|
/**
|
|
* Delete all old attributes (from alf_*attribute* tables)
|
|
*/
|
|
public void deleteAllOldAttrs();
|
|
}
|