mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-06-30 18:15:39 +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);
|
|
}
|