mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-08-07 17:49:17 +00:00
15897: Merged V3.1 to V3.2 14485: (RECORD ONLY) ETHREEOH-1937 14915: (RECORD ONLY) Fix for ETHREEOH-2011: chaining-authentication-context.xml.sample 14954: (RECORD ONLY) Fix merge error 14966: (RECORD ONLY) Merged V2.2 to V3.1 14131: *RECORD ONLY* 14605: Merged HEAD to V2.2 (workaround for ETWOTWO-1137) 14368: Fix for ETHREEOH-1936 14607: Fixed NPE in TextMiningContentTransformer: Lead-up to fix for ETWOTWO-1174 14992: (RECORD ONLY) Updated svn:mergeinfo for V2.1-A 15080: Applied suggested fix for ETHREEOH-2252: Emailed content created in wrong space 15131: Merged V2.1-A to V3.1 (ETHREEOH-2270) 13465: Fix for ADB-161 ACT 7870 - added 'xsd' to mimetype map. 15134: Merged V2.2 to V3.1 14332: (RECORD-ONLY) 14717: (RECORD-ONLY) 14745: (RECORD-ONLY) 14746: Fixed error relating to detection and clean-up of duplicate child associations 14759: Missed check-in: Set transactionService for post-transaction duplicate child assoc cleanup 14761: (RECORD-ONLY) 14885: (RECORD-ONLY) 14893: (RECORD-ONLY) 14903: (RECORD-ONLY) 15204: Fixed ETHREEOH-2303: FixNameCrcValuesPatch throws ConstraintViolationException during upgrade ... 15214: Fixed ETHREEOH-1861: Offline synchronization updates file content without any changes 15271: Applied patch fix: Imported users don't conform to case-sensitivity switch 15352: ETHREEOH-2322 15361: ETHREEOH-1112 15369: ETHREEOH-2448 15419: ETHREEOH-2479 15431: ETHREEOH-2520 and ETHREEOH-2521 15587: (RECORD ONLY) Moved Enterprise-only scripts to correct location 15616: Fix ETHREEOH-2581 - WCM layered folder - can't submit deleted file 15675: WCM fixes (ETHREEOH-2110 & ETHREEOH-2645) 15836: Check for null username in ContentUsage service getUserUsage() method 15840: (RECORD ONLY) Merged V3.2 to V3.1 14760: Fix for ALFCOM-586 - trims and ignores leading/trailing whitespace before validation in JSF client forms. 15841: Fixes for ETHREEOH-2702 and ETHREEOH-2687 15860: (RECORD ONLY) Added Oracle and MS SQL Server config 15891: Removed unused compiler directive ___________________________________________________________________ Modified: svn:mergeinfo Merged /alfresco/BRANCHES/DEV/BELARUS/ETHREEOH-2221:r14753 Merged /alfresco/BRANCHES/V2.1-A: lots Merged /alfresco/BRANCHES/V2.2:r14131,14332,14605,14607,14717,14745-14746,14759,14761,14885,14893,14903 Merged /alfresco/BRANCHES/V3.1:r14485,14915,14954,14966,14992,15080,15131,15134,15204,15214,15271,15352,15361,15369,15419,15431,15587,15616,15675,15818,15836,15840-15841,15860,15891 Merged /alfresco/BRANCHES/V3.2:r15897 git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@16886 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
285 lines
11 KiB
Java
285 lines
11 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.web.bean.clipboard;
|
|
|
|
import java.util.Map;
|
|
|
|
import javax.faces.context.FacesContext;
|
|
import javax.transaction.UserTransaction;
|
|
|
|
import org.alfresco.model.WCMAppModel;
|
|
import org.alfresco.repo.avm.AVMNodeConverter;
|
|
import org.alfresco.service.cmr.avm.AVMExistsException;
|
|
import org.alfresco.service.cmr.avm.AVMNodeDescriptor;
|
|
import org.alfresco.service.cmr.avm.AVMService;
|
|
import org.alfresco.service.cmr.model.FileExistsException;
|
|
import org.alfresco.service.cmr.repository.CrossRepositoryCopyService;
|
|
import org.alfresco.service.cmr.repository.NodeRef;
|
|
import org.alfresco.service.cmr.repository.StoreRef;
|
|
import org.alfresco.web.app.Application;
|
|
import org.alfresco.web.app.servlet.FacesHelper;
|
|
import org.alfresco.web.bean.NavigationBean;
|
|
import org.alfresco.web.bean.repository.Repository;
|
|
import org.alfresco.web.bean.wcm.AVMBrowseBean;
|
|
|
|
/**
|
|
* Class representing an 'avm' store protocol clipboard item
|
|
*
|
|
* @author Kevin Roast
|
|
*/
|
|
public class AVMClipboardItem extends AbstractClipboardItem
|
|
{
|
|
private static final long serialVersionUID = 2550867083821268131L;
|
|
|
|
private static final String AVM_PASTE_VIEW_ID = "/jsp/wcm/browse-sandbox.jsp";
|
|
private static final String WORKSPACE_PASTE_VIEW_ID = "/jsp/browse/browse.jsp";
|
|
|
|
/**
|
|
* @param ref
|
|
* @param mode
|
|
*/
|
|
public AVMClipboardItem(NodeRef ref, ClipboardStatus mode)
|
|
{
|
|
super(ref, mode);
|
|
}
|
|
|
|
/**
|
|
* @see org.alfresco.web.bean.clipboard.ClipboardItem#supportsLink()
|
|
*/
|
|
public boolean supportsLink()
|
|
{
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* @see org.alfresco.web.bean.clipboard.ClipboardItem#canCopyToViewId(java.lang.String)
|
|
*/
|
|
public boolean canCopyToViewId(String viewId)
|
|
{
|
|
return (AVM_PASTE_VIEW_ID.equals(viewId) || WORKSPACE_PASTE_VIEW_ID.equals(viewId));
|
|
}
|
|
|
|
/**
|
|
* @see org.alfresco.web.bean.clipboard.ClipboardItem#canMoveToViewId(java.lang.String)
|
|
*/
|
|
public boolean canMoveToViewId(String viewId)
|
|
{
|
|
return (AVM_PASTE_VIEW_ID.equals(viewId));
|
|
}
|
|
|
|
/**
|
|
* @see org.alfresco.web.bean.clipboard.ClipboardItem#paste(javax.faces.context.FacesContext, java.lang.String, int)
|
|
*/
|
|
public boolean paste(FacesContext fc, String viewId, int action) throws Throwable
|
|
{
|
|
if (AVM_PASTE_VIEW_ID.equals(viewId))
|
|
{
|
|
AVMBrowseBean avmBrowseBean = (AVMBrowseBean)FacesHelper.getManagedBean(fc, AVMBrowseBean.BEAN_NAME);
|
|
|
|
String destPath = avmBrowseBean.getCurrentPath();
|
|
NodeRef destRef = AVMNodeConverter.ToNodeRef(-1, destPath);
|
|
String sourcePath = AVMNodeConverter.ToAVMVersionPath(getNodeRef()).getSecond();
|
|
|
|
//FileFolderService fileFolderService = getServiceRegistry().getFileFolderService();
|
|
|
|
// initial name to attempt the copy of the item with
|
|
String name = getName();
|
|
|
|
boolean operationComplete = false;
|
|
while (operationComplete == false)
|
|
{
|
|
UserTransaction tx = null;
|
|
try
|
|
{
|
|
// attempt each copy/paste in its own transaction
|
|
tx = Repository.getUserTransaction(fc);
|
|
tx.begin();
|
|
if (getMode() == ClipboardStatus.COPY)
|
|
{
|
|
// COPY operation
|
|
if (logger.isDebugEnabled())
|
|
logger.debug("Attempting to copy node path: " + sourcePath + " into path: " + destPath);
|
|
|
|
// copy the avm path
|
|
// first check that we are not attempting to copy a duplicate into the same parent
|
|
if (AVMNodeConverter.ExtendAVMPath(destPath, name).equals(sourcePath))
|
|
{
|
|
// manually change the name if this occurs
|
|
String copyOf = Application.getMessage(fc, MSG_COPY_OF);
|
|
name = copyOf + ' ' + name;
|
|
}
|
|
/*fileFolderService.copy(
|
|
getNodeRef(),
|
|
destRef,
|
|
name);*/
|
|
getAvmService().copy(-1, sourcePath, destPath, name);
|
|
|
|
// ETHREEOH-2110
|
|
AVMNodeDescriptor desc = getAvmService().lookup(-1, destPath + "/" + name);
|
|
recursiveFormCheck(desc);
|
|
|
|
// if we get here without an exception, the clipboard copy operation was successful
|
|
operationComplete = true;
|
|
}
|
|
else
|
|
{
|
|
// MOVE operation
|
|
if (logger.isDebugEnabled())
|
|
logger.debug("Attempting to move node path: " + sourcePath + " into path: " + destRef);
|
|
|
|
// move the avm path
|
|
/*fileFolderService.move(
|
|
getNodeRef(),
|
|
destRef,
|
|
name);*/
|
|
getAvmService().rename(AVMNodeConverter.SplitBase(sourcePath)[0], getName(),
|
|
destPath, name);
|
|
|
|
// if we get here without an exception, the clipboard move operation was successful
|
|
operationComplete = true;
|
|
}
|
|
}
|
|
catch (FileExistsException fileExistsErr)
|
|
{
|
|
if (getMode() != ClipboardStatus.COPY)
|
|
{
|
|
// we should not rename an item when it is being moved - so exit
|
|
throw fileExistsErr;
|
|
}
|
|
}
|
|
catch (AVMExistsException avmExistsErr)
|
|
{
|
|
if (getMode() != ClipboardStatus.COPY)
|
|
{
|
|
// we should not rename an item when it is being moved - so exit
|
|
throw avmExistsErr;
|
|
}
|
|
}
|
|
catch (Throwable e)
|
|
{
|
|
// some other type of exception occured - rollback and exit
|
|
throw e;
|
|
}
|
|
finally
|
|
{
|
|
// rollback if the operation didn't complete
|
|
if (operationComplete == false)
|
|
{
|
|
try { if (tx != null) {tx.rollback();} } catch (Exception tex) {}
|
|
String copyOf = Application.getMessage(fc, MSG_COPY_OF);
|
|
name = copyOf + ' ' + name;
|
|
}
|
|
else
|
|
{
|
|
// commit the transaction
|
|
tx.commit();
|
|
}
|
|
}
|
|
}
|
|
return operationComplete;
|
|
}
|
|
else if (WORKSPACE_PASTE_VIEW_ID.equals(viewId))
|
|
{
|
|
NavigationBean navigator = (NavigationBean)FacesHelper.getManagedBean(fc, NavigationBean.BEAN_NAME);
|
|
NodeRef destRef = new NodeRef(Repository.getStoreRef(), navigator.getCurrentNodeId());
|
|
|
|
CrossRepositoryCopyService crossRepoCopyService = getServiceRegistry().getCrossRepositoryCopyService();
|
|
|
|
// initial name to attempt the copy of the item with
|
|
String name = getName();
|
|
|
|
boolean operationComplete = false;
|
|
while (operationComplete == false)
|
|
{
|
|
UserTransaction tx = null;
|
|
try
|
|
{
|
|
// attempt each copy/paste in its own transaction
|
|
tx = Repository.getUserTransaction(fc);
|
|
tx.begin();
|
|
if (getMode() == ClipboardStatus.COPY)
|
|
{
|
|
// COPY operation
|
|
if (logger.isDebugEnabled())
|
|
logger.debug("Attempting to copy node: " + getNodeRef() + " into node ID: " + destRef.toString());
|
|
|
|
// inter-store copy operation
|
|
crossRepoCopyService.copy(getNodeRef(), destRef, name);
|
|
|
|
if (destRef.getStoreRef().getProtocol().equals(StoreRef.PROTOCOL_AVM))
|
|
{
|
|
// ETHREEOH-2110
|
|
String destPath = AVMNodeConverter.ToAVMVersionPath(destRef).getSecond();
|
|
AVMNodeDescriptor desc = getAvmService().lookup(-1, destPath + "/" + name);
|
|
recursiveFormCheck(desc);
|
|
}
|
|
|
|
// if we get here without an exception, the clipboard copy operation was successful
|
|
operationComplete = true;
|
|
}
|
|
else
|
|
{
|
|
// this should not occur as the canMoveToViewId() will return false
|
|
throw new Exception("Move operation not supported between stores.");
|
|
}
|
|
}
|
|
catch (FileExistsException fileExistsErr)
|
|
{
|
|
if (getMode() != ClipboardStatus.COPY)
|
|
{
|
|
// we should not rename an item when it is being moved - so exit
|
|
throw fileExistsErr;
|
|
}
|
|
}
|
|
catch (Throwable e)
|
|
{
|
|
// some other type of exception occured - rollback and exit
|
|
throw e;
|
|
}
|
|
finally
|
|
{
|
|
// rollback if the operation didn't complete
|
|
if (operationComplete == false)
|
|
{
|
|
try { if (tx != null) {tx.rollback();} } catch (Exception tex) {}
|
|
String copyOf = Application.getMessage(fc, MSG_COPY_OF);
|
|
name = copyOf + ' ' + name;
|
|
}
|
|
else
|
|
{
|
|
// commit the transaction
|
|
tx.commit();
|
|
}
|
|
}
|
|
}
|
|
return operationComplete;
|
|
}
|
|
else
|
|
{
|
|
return false;
|
|
}
|
|
}
|
|
}
|