mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-06-30 18:15:39 +00:00
Fallout: 1. Policy handling for 'onCopy' has been changed to 'getCopyCallback' 2. All existing policy usage was refactored to control behaviour more closely 3. The default child association behaviour has changed: 3.1 Types and aspects control their own child association behaviour 3.2 cm:folder recurses into primary children, but merely copies the secondary association 3.3 cm:rule recurses into primary children 3.4 unless behaviour is defined for a child association, there is no recursion or copying 4. Node association behavior has changed 4.1 There is no copying of node associations. Each type and aspect must handle this by recording nodes and fixing up the required associations in the onCopyComplete. 4.2 If there is a requirement, this can be added to the callback later See 'org.alfresco.repo.copy.AbstractCopyBehaviourCallback' and derived classes for examples. Areas to test with particular attention: 1. Normal copy behaviour 2. Copy of documents with discussions 3. Check-in check-out 4. Check-in, check-out of documents where a discussion was added to working copy 5. Copies of documents with thumbnails 6. Copies of documents with rules 7. Copying of hierarchies that contain rules to copy to another location within the hierarchy 8. Copying into folders where named children already exist git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@13915 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
166 lines
5.1 KiB
Java
166 lines
5.1 KiB
Java
/*
|
|
* Copyright (C) 2005-2009 Alfresco Software Limited.
|
|
*
|
|
* This program is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU General Public License
|
|
* as published by the Free Software Foundation; either version 2
|
|
* of the License, or (at your option) any later version.
|
|
|
|
* This program 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 General Public License for more details.
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
* As a special exception to the terms and conditions of version 2.0 of
|
|
* the GPL, you may redistribute this Program in connection with Free/Libre
|
|
* and Open Source Software ("FLOSS") applications as described in Alfresco's
|
|
* FLOSS exception. You should have recieved a copy of the text describing
|
|
* the FLOSS exception, and it is also available here:
|
|
* http://www.alfresco.com/legal/licensing"
|
|
*/
|
|
package org.alfresco.repo.copy;
|
|
|
|
import java.io.Serializable;
|
|
import java.util.Map;
|
|
import java.util.Set;
|
|
|
|
import org.alfresco.service.cmr.repository.NodeRef;
|
|
import org.alfresco.service.namespace.QName;
|
|
|
|
/**
|
|
* Simple Java bean that contains the details of a copy process underway.
|
|
*
|
|
* @see CopyServicePolicies
|
|
*
|
|
* @author Derek Hulley
|
|
* @since 3.2
|
|
*/
|
|
public class CopyDetails
|
|
{
|
|
private final NodeRef sourceNodeRef;
|
|
private final QName sourceNodeTypeQName;
|
|
private final Set<QName> sourceNodeAspectQNames;
|
|
private final Map<QName, Serializable> sourceNodeProperties;
|
|
private final NodeRef targetParentNodeRef;
|
|
private final NodeRef targetNodeRef;
|
|
private final boolean targetNodeIsNew;
|
|
private final QName assocTypeQName;
|
|
private final QName assocQName;
|
|
|
|
public CopyDetails(
|
|
NodeRef sourceNodeRef,
|
|
QName sourceNodeTypeQName,
|
|
Set<QName> sourceNodeAspectQNames,
|
|
Map<QName, Serializable> sourceNodeProperties,
|
|
NodeRef targetParentNodeRef,
|
|
NodeRef targetNodeRef,
|
|
boolean targetNodeIsNew,
|
|
QName assocTypeQName,
|
|
QName assocQName)
|
|
{
|
|
this.sourceNodeRef = sourceNodeRef;
|
|
this.sourceNodeTypeQName = sourceNodeTypeQName;
|
|
this.sourceNodeAspectQNames = sourceNodeAspectQNames;
|
|
this.sourceNodeProperties = sourceNodeProperties;
|
|
this.targetParentNodeRef = targetParentNodeRef;
|
|
this.targetNodeRef = targetNodeRef;
|
|
this.targetNodeIsNew = targetNodeIsNew;
|
|
this.assocTypeQName = assocTypeQName;
|
|
this.assocQName = assocQName;
|
|
}
|
|
|
|
@Override
|
|
public String toString()
|
|
{
|
|
StringBuilder sb = new StringBuilder(512);
|
|
sb.append("CopyDetails")
|
|
.append(" [source=").append(sourceNodeRef)
|
|
.append(", targetParent=").append(targetParentNodeRef)
|
|
.append(", targetNode=").append(targetNodeRef)
|
|
.append(", targetNodeIsNew=").append(targetNodeIsNew)
|
|
.append(", assocTypeQName=").append(assocTypeQName)
|
|
.append(", assocQName=").append(assocQName)
|
|
.append("]");
|
|
return sb.toString();
|
|
}
|
|
|
|
/**
|
|
* Get the source node
|
|
*/
|
|
public final NodeRef getSourceNodeRef()
|
|
{
|
|
return sourceNodeRef;
|
|
}
|
|
|
|
/**
|
|
* Get the type of the source node
|
|
*/
|
|
public final QName getSourceNodeTypeQName()
|
|
{
|
|
return this.sourceNodeTypeQName;
|
|
}
|
|
|
|
/**
|
|
* Get the aspects associated with the source node
|
|
*/
|
|
public final Set<QName> getSourceNodeAspectQNames()
|
|
{
|
|
return sourceNodeAspectQNames;
|
|
}
|
|
|
|
/**
|
|
* Get the properties associated with the source node
|
|
*/
|
|
public final Map<QName, Serializable> getSourceNodeProperties()
|
|
{
|
|
return sourceNodeProperties;
|
|
}
|
|
|
|
/**
|
|
* Get the node under which the new/existing copy will be placed
|
|
*/
|
|
public final NodeRef getTargetParentNodeRef()
|
|
{
|
|
return targetParentNodeRef;
|
|
}
|
|
|
|
/**
|
|
* Get the node to which the copy will occur. The node may not
|
|
* <i>yet</i> exist.
|
|
*/
|
|
public final NodeRef getTargetNodeRef()
|
|
{
|
|
return targetNodeRef;
|
|
}
|
|
|
|
/**
|
|
* Determine if the {@link #getTargetNodeRef() target node} was newly-created
|
|
* for the copy or if it pre-existed.
|
|
*
|
|
* @return <tt>true</tt> if the node was created by the copy
|
|
*/
|
|
public final boolean isTargetNodeIsNew()
|
|
{
|
|
return targetNodeIsNew;
|
|
}
|
|
|
|
/**
|
|
* Get the new association type qualified name
|
|
*/
|
|
public final QName getAssocTypeQName()
|
|
{
|
|
return assocTypeQName;
|
|
}
|
|
|
|
/**
|
|
* Get the association path qualified name
|
|
*/
|
|
public final QName getAssocQName()
|
|
{
|
|
return assocQName;
|
|
}
|
|
} |