mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-07-24 17:32:48 +00:00
This is an action to undo a list of changes made in a user sandbox, relative to
the staging sandbox. Turns out yesterday's revert action isn't quite what is wanted for this use case. git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/BRANCHES/WCM-DEV2/root@4366 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
This commit is contained in:
@@ -439,6 +439,21 @@ public class AVMServiceImpl implements AVMService
|
||||
fAVMRepository.uncover(dirPath, name);
|
||||
}
|
||||
|
||||
/**
|
||||
* Make name in dirPath transparent to what was underneath it. That is, this
|
||||
* removes the offending node from its layered directory parent's direct ownership.
|
||||
* @param dirPath The path to the layered directory.
|
||||
* @param name The name of the item to flatten.
|
||||
*/
|
||||
public void flatten(String dirPath, String name)
|
||||
{
|
||||
if (dirPath == null || name == null)
|
||||
{
|
||||
throw new AVMBadArgumentException("Illegal null argument.");
|
||||
}
|
||||
fAVMRepository.flatten(dirPath, name);
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the Latest Version ID for an AVMStore.
|
||||
* @param repName The name of the AVMStore.
|
||||
|
@@ -34,6 +34,7 @@ import org.alfresco.model.ContentModel;
|
||||
import org.alfresco.model.WCMModel;
|
||||
import org.alfresco.repo.action.ActionImpl;
|
||||
import org.alfresco.repo.avm.actions.AVMRevertListAction;
|
||||
import org.alfresco.repo.avm.actions.AVMUndoSandboxListAction;
|
||||
import org.alfresco.repo.avm.actions.SimpleAVMPromoteAction;
|
||||
import org.alfresco.repo.avm.actions.SimpleAVMSubmitAction;
|
||||
import org.alfresco.repo.avm.util.BulkLoader;
|
||||
@@ -282,6 +283,53 @@ public class AVMServiceTest extends AVMServiceTestBase
|
||||
fail();
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Test the undo list action.
|
||||
*/
|
||||
public void testUndoListAction()
|
||||
{
|
||||
try
|
||||
{
|
||||
setupBasicTree();
|
||||
fService.createAVMStore("area");
|
||||
fService.createLayeredDirectory("main:/a", "area:/", "a");
|
||||
fService.getFileOutputStream("area:/a/b/c/foo").close();
|
||||
List<AVMDifference> diffs = fSyncService.compare(-1, "area:/a", -1, "main:/a");
|
||||
assertEquals(1, diffs.size());
|
||||
fSyncService.update(diffs, false, false, false, false, null, null);
|
||||
fService.getFileOutputStream("area:/a/b/c/bar").close();
|
||||
diffs = fSyncService.compare(-1, "area:/a", -1, "main:/a");
|
||||
assertEquals(1, diffs.size());
|
||||
final ActionImpl action = new ActionImpl(null,
|
||||
GUID.generate(),
|
||||
AVMUndoSandboxListAction.NAME);
|
||||
VersionPathStuffer stuffer = new VersionPathStuffer();
|
||||
stuffer.add(-1, "area:/a/b/c/bar");
|
||||
String nodeList = stuffer.toString();
|
||||
action.setParameterValue(AVMUndoSandboxListAction.PARAM_NODE_LIST, nodeList);
|
||||
final AVMUndoSandboxListAction revert = (AVMUndoSandboxListAction)fContext.getBean("avm-undo-list");
|
||||
class TxnWork implements TransactionUtil.TransactionWork<Object>
|
||||
{
|
||||
public Object doWork() throws Exception
|
||||
{
|
||||
revert.execute(action, null);
|
||||
return null;
|
||||
}
|
||||
};
|
||||
TransactionUtil.executeInUserTransaction((TransactionService)fContext.getBean("transactionComponent"),
|
||||
new TxnWork());
|
||||
diffs = fSyncService.compare(-1, "area:/a", -1, "main:/a");
|
||||
assertEquals(0, diffs.size());
|
||||
System.out.println(recursiveList("area", -1, true));
|
||||
System.out.println(recursiveList("main", -1, true));
|
||||
}
|
||||
catch (Exception e)
|
||||
{
|
||||
e.printStackTrace();
|
||||
fail();
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Test the promote action.
|
||||
|
@@ -0,0 +1,87 @@
|
||||
/**
|
||||
*
|
||||
*/
|
||||
package org.alfresco.repo.avm.actions;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
import org.alfresco.repo.action.ParameterDefinitionImpl;
|
||||
import org.alfresco.repo.action.executer.ActionExecuterAbstractBase;
|
||||
import org.alfresco.repo.avm.AVMNodeConverter;
|
||||
import org.alfresco.repo.avm.util.VersionPathUnstuffer;
|
||||
import org.alfresco.service.cmr.action.Action;
|
||||
import org.alfresco.service.cmr.action.ParameterDefinition;
|
||||
import org.alfresco.service.cmr.avm.AVMNodeDescriptor;
|
||||
import org.alfresco.service.cmr.avm.AVMService;
|
||||
import org.alfresco.service.cmr.avmsync.AVMSyncService;
|
||||
import org.alfresco.service.cmr.dictionary.DataTypeDefinition;
|
||||
import org.alfresco.service.cmr.repository.NodeRef;
|
||||
import org.alfresco.util.Pair;
|
||||
import org.apache.log4j.Logger;
|
||||
|
||||
/**
|
||||
* Undos a list of changed nodes in a user sandbox. The set of nodes to undo is
|
||||
* passed in as a packed string (Obtained by VersionPathStuffer).
|
||||
* The actionedUponNodeRef is a dummy and can be null.
|
||||
* @author britt
|
||||
*/
|
||||
public class AVMUndoSandboxListAction extends ActionExecuterAbstractBase
|
||||
{
|
||||
private static Logger fgLogger = Logger.getLogger(AVMUndoSandboxListAction.class);
|
||||
|
||||
public static final String NAME = "avm-undo-list";
|
||||
// The encoded list of nodes.
|
||||
public static final String PARAM_NODE_LIST = "node-list";
|
||||
|
||||
/**
|
||||
* The AVM Service reference.
|
||||
*/
|
||||
private AVMService fAVMService;
|
||||
|
||||
public void setAvmService(AVMService service)
|
||||
{
|
||||
fAVMService = service;
|
||||
}
|
||||
|
||||
/* (non-Javadoc)
|
||||
* @see org.alfresco.repo.action.executer.ActionExecuterAbstractBase#executeImpl(org.alfresco.service.cmr.action.Action, org.alfresco.service.cmr.repository.NodeRef)
|
||||
*/
|
||||
@Override
|
||||
protected void executeImpl(Action action, NodeRef actionedUponNodeRef)
|
||||
{
|
||||
String packedNodes = (String)action.getParameterValue(PARAM_NODE_LIST);
|
||||
VersionPathUnstuffer unstuffer = new VersionPathUnstuffer(packedNodes);
|
||||
List<Pair<Integer, String>> versionPaths = unstuffer.getVersionPaths();
|
||||
for (Pair<Integer, String> item : versionPaths)
|
||||
{
|
||||
AVMNodeDescriptor desc = fAVMService.lookup(-1, item.getSecond(), true);
|
||||
if (desc == null)
|
||||
{
|
||||
continue;
|
||||
}
|
||||
String [] parentChild = AVMNodeConverter.SplitBase(item.getSecond());
|
||||
if (parentChild.length != 2)
|
||||
{
|
||||
continue;
|
||||
}
|
||||
AVMNodeDescriptor parent = fAVMService.lookup(-1, parentChild[0], true);
|
||||
if (parent.isLayeredDirectory())
|
||||
{
|
||||
fAVMService.flatten(parentChild[0], parentChild[1]);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/* (non-Javadoc)
|
||||
* @see org.alfresco.repo.action.ParameterizedItemAbstractBase#addParameterDefinitions(java.util.List)
|
||||
*/
|
||||
@Override
|
||||
protected void addParameterDefinitions(List<ParameterDefinition> paramList)
|
||||
{
|
||||
paramList.add(
|
||||
new ParameterDefinitionImpl(PARAM_NODE_LIST,
|
||||
DataTypeDefinition.TEXT,
|
||||
true,
|
||||
getParamDisplayLabel(PARAM_NODE_LIST)));
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user