mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-08-07 17:49:17 +00:00
Merged V3.2 to HEAD
17307: Merged DEV/BELARUS/V3.2-2009_10_19 to V3.2 17121: ETHREEOH-2999: Accessing Recent snapshots fails in a web project that is created from an already existing project 17223: ETHREEEOH-2999: (post-review changes) 17346: ETHREEOH-2824 - further perf improvement for multiple single submits (to active workflow sandboxes) from large modified list 17375: Fix ETHREEOH-1643 - WCM revert file & version history, including a few unreported WCM / UI revert file issues 17380: ETHREEOH-1643 - fix build/test fallout git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@18110 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
This commit is contained in:
@@ -567,10 +567,10 @@
|
|||||||
</property>
|
</property>
|
||||||
</bean>
|
</bean>
|
||||||
|
|
||||||
<!-- deprecated -->
|
<!-- deprecated - note: still used by Web-Client (FileDetailsBean) -->
|
||||||
<bean id="avm-revert-to-version" class="org.alfresco.repo.avm.actions.AVMRevertToVersionAction" parent = "action-executer">
|
<bean id="avm-revert-to-version" class="org.alfresco.repo.avm.actions.AVMRevertToVersionAction" parent = "action-executer">
|
||||||
<property name="avmService">
|
<property name="avmService">
|
||||||
<ref bean="AVMService"/>
|
<ref bean="AVMLockingAwareService"/>
|
||||||
</property>
|
</property>
|
||||||
<property name="publicAction">
|
<property name="publicAction">
|
||||||
<value>false</value>
|
<value>false</value>
|
||||||
@@ -590,7 +590,7 @@
|
|||||||
</property>
|
</property>
|
||||||
</bean>
|
</bean>
|
||||||
|
|
||||||
<!-- deprecated -->
|
<!-- deprecated - note: still used by Web-Client (*Deploy*) -->
|
||||||
<bean id="avm-deploy-website" class="org.alfresco.repo.avm.actions.AVMDeployWebsiteAction" parent="action-executer">
|
<bean id="avm-deploy-website" class="org.alfresco.repo.avm.actions.AVMDeployWebsiteAction" parent="action-executer">
|
||||||
|
|
||||||
<!-- Run avm-deploy-website action on the deployment queue -->
|
<!-- Run avm-deploy-website action on the deployment queue -->
|
||||||
|
@@ -34,6 +34,7 @@ import java.util.Map;
|
|||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
import java.util.SortedMap;
|
import java.util.SortedMap;
|
||||||
|
|
||||||
|
import org.alfresco.repo.avm.util.AVMUtil;
|
||||||
import org.alfresco.repo.domain.PropertyValue;
|
import org.alfresco.repo.domain.PropertyValue;
|
||||||
import org.alfresco.service.cmr.avm.AVMBadArgumentException;
|
import org.alfresco.service.cmr.avm.AVMBadArgumentException;
|
||||||
import org.alfresco.service.cmr.avm.AVMNodeDescriptor;
|
import org.alfresco.service.cmr.avm.AVMNodeDescriptor;
|
||||||
@@ -703,10 +704,11 @@ public class AVMLockingAwareService implements AVMService, ApplicationContextAwa
|
|||||||
*/
|
*/
|
||||||
public void removeNode(String parent, String name)
|
public void removeNode(String parent, String name)
|
||||||
{
|
{
|
||||||
grabLock(parent + '/' + name);
|
String path = AVMUtil.extendAVMPath(parent, name);
|
||||||
|
grabLock(path);
|
||||||
fService.removeNode(parent, name);
|
fService.removeNode(parent, name);
|
||||||
String[] storePath = parent.split(":");
|
String[] storePath = parent.split(":");
|
||||||
fService.createSnapshot(storePath[0], null, null);
|
fService.createSnapshot(storePath[0], null, "Removed "+path);
|
||||||
String webProject = getWebProject(storePath[0]);
|
String webProject = getWebProject(storePath[0]);
|
||||||
if (webProject != null)
|
if (webProject != null)
|
||||||
{
|
{
|
||||||
@@ -722,7 +724,7 @@ public class AVMLockingAwareService implements AVMService, ApplicationContextAwa
|
|||||||
grabLock(path);
|
grabLock(path);
|
||||||
fService.removeNode(path);
|
fService.removeNode(path);
|
||||||
String[] storePath = path.split(":");
|
String[] storePath = path.split(":");
|
||||||
fService.createSnapshot(storePath[0], null, null);
|
fService.createSnapshot(storePath[0], null, "Removed "+path);
|
||||||
String webProject = getWebProject(storePath[0]);
|
String webProject = getWebProject(storePath[0]);
|
||||||
if (webProject != null)
|
if (webProject != null)
|
||||||
{
|
{
|
||||||
|
@@ -1259,47 +1259,62 @@ public class AVMServiceTest extends AVMServiceTestBase
|
|||||||
try
|
try
|
||||||
{
|
{
|
||||||
setupBasicTree();
|
setupBasicTree();
|
||||||
|
|
||||||
ContentWriter writer = fService.getContentWriter("main:/a/b/c/foo");
|
ContentWriter writer = fService.getContentWriter("main:/a/b/c/foo");
|
||||||
writer.setEncoding("UTF-8");
|
writer.setEncoding("UTF-8");
|
||||||
writer.setMimetype(MimetypeMap.MIMETYPE_TEXT_PLAIN);
|
writer.setMimetype(MimetypeMap.MIMETYPE_TEXT_PLAIN);
|
||||||
writer.putContent("I am main:/a/b/c/foo V1");
|
writer.putContent("I am main:/a/b/c/foo V1");
|
||||||
fService.createSnapshot("main", "v1", null);
|
fService.createSnapshot("main", "v1", null);
|
||||||
|
|
||||||
writer = fService.getContentWriter("main:/a/b/c/foo");
|
writer = fService.getContentWriter("main:/a/b/c/foo");
|
||||||
writer.setEncoding("UTF-8");
|
writer.setEncoding("UTF-8");
|
||||||
writer.setMimetype(MimetypeMap.MIMETYPE_TEXT_PLAIN);
|
writer.setMimetype(MimetypeMap.MIMETYPE_TEXT_PLAIN);
|
||||||
writer.putContent("I am main:/a/b/c/foo V2");
|
writer.putContent("I am main:/a/b/c/foo V2");
|
||||||
fService.createSnapshot("main", "v2", null);
|
fService.createSnapshot("main", "v2", null);
|
||||||
|
|
||||||
writer = fService.getContentWriter("main:/a/b/c/foo");
|
writer = fService.getContentWriter("main:/a/b/c/foo");
|
||||||
writer.setEncoding("UTF-8");
|
writer.setEncoding("UTF-8");
|
||||||
writer.setMimetype(MimetypeMap.MIMETYPE_TEXT_PLAIN);
|
writer.setMimetype(MimetypeMap.MIMETYPE_TEXT_PLAIN);
|
||||||
writer.putContent("I am main:/a/b/c/foo V3");
|
writer.putContent("I am main:/a/b/c/foo V3");
|
||||||
fService.createSnapshot("main", "v3", null);
|
fService.createSnapshot("main", "v3", null);
|
||||||
|
|
||||||
writer = fService.getContentWriter("main:/a/b/c/foo");
|
writer = fService.getContentWriter("main:/a/b/c/foo");
|
||||||
writer.setEncoding("UTF-8");
|
writer.setEncoding("UTF-8");
|
||||||
writer.setMimetype(MimetypeMap.MIMETYPE_TEXT_PLAIN);
|
writer.setMimetype(MimetypeMap.MIMETYPE_TEXT_PLAIN);
|
||||||
writer.putContent("I am main:/a/b/c/foo V4");
|
writer.putContent("I am main:/a/b/c/foo V4");
|
||||||
fService.createSnapshot("main", "v4", null);
|
fService.createSnapshot("main", "v4", null);
|
||||||
|
|
||||||
writer = fService.getContentWriter("main:/a/b/c/foo");
|
writer = fService.getContentWriter("main:/a/b/c/foo");
|
||||||
writer.setEncoding("UTF-8");
|
writer.setEncoding("UTF-8");
|
||||||
writer.setMimetype(MimetypeMap.MIMETYPE_TEXT_PLAIN);
|
writer.setMimetype(MimetypeMap.MIMETYPE_TEXT_PLAIN);
|
||||||
writer.putContent("I am main:/a/b/c/foo V5");
|
writer.putContent("I am main:/a/b/c/foo V5");
|
||||||
fService.createSnapshot("main", "v5", null);
|
fService.createSnapshot("main", "v5", null);
|
||||||
|
|
||||||
writer = fService.getContentWriter("main:/a/b/c/foo");
|
writer = fService.getContentWriter("main:/a/b/c/foo");
|
||||||
writer.setEncoding("UTF-8");
|
writer.setEncoding("UTF-8");
|
||||||
writer.setMimetype(MimetypeMap.MIMETYPE_TEXT_PLAIN);
|
writer.setMimetype(MimetypeMap.MIMETYPE_TEXT_PLAIN);
|
||||||
writer.putContent("I am main:/a/b/c/foo HEAD");
|
writer.putContent("I am main:/a/b/c/foo HEAD");
|
||||||
|
|
||||||
StoreRef storeRef = AVMNodeConverter.ToStoreRef("main");
|
StoreRef storeRef = AVMNodeConverter.ToStoreRef("main");
|
||||||
|
|
||||||
SearchService searchService = fIndexerAndSearcher.getSearcher(storeRef, true);
|
SearchService searchService = fIndexerAndSearcher.getSearcher(storeRef, true);
|
||||||
|
|
||||||
ResultSet results = searchService.query(storeRef, "lucene", "TEXT:\"HEAD\"");
|
ResultSet results = searchService.query(storeRef, "lucene", "TEXT:\"HEAD\"");
|
||||||
assertEquals(0, results.length());
|
assertEquals(0, results.length());
|
||||||
results.close();
|
results.close();
|
||||||
|
|
||||||
results = searchService.query(storeRef, "lucene", "TEXT:\"V5\"");
|
results = searchService.query(storeRef, "lucene", "TEXT:\"V5\"");
|
||||||
assertEquals(1, results.length());
|
assertEquals(1, results.length());
|
||||||
results.close();
|
results.close();
|
||||||
|
|
||||||
|
results = searchService.query(storeRef, "lucene", "TEXT:\"V2\"");
|
||||||
|
assertEquals(0, results.length());
|
||||||
|
results.close();
|
||||||
|
|
||||||
AVMNodeDescriptor desc = fService.lookup(-1, "main:/a/b/c/foo");
|
AVMNodeDescriptor desc = fService.lookup(-1, "main:/a/b/c/foo");
|
||||||
List<AVMNodeDescriptor> history = fService.getHistory(desc, 100);
|
List<AVMNodeDescriptor> history = fService.getHistory(desc, 100);
|
||||||
AVMNodeDescriptor toRevert = history.get(3);
|
AVMNodeDescriptor toRevert = history.get(3);
|
||||||
|
|
||||||
final ActionImpl action = new ActionImpl(null, GUID.generate(), AVMRevertToVersionAction.NAME);
|
final ActionImpl action = new ActionImpl(null, GUID.generate(), AVMRevertToVersionAction.NAME);
|
||||||
action.setParameterValue(AVMRevertToVersionAction.TOREVERT, toRevert);
|
action.setParameterValue(AVMRevertToVersionAction.TOREVERT, toRevert);
|
||||||
final AVMRevertToVersionAction revert = (AVMRevertToVersionAction) fContext.getBean("avm-revert-to-version");
|
final AVMRevertToVersionAction revert = (AVMRevertToVersionAction) fContext.getBean("avm-revert-to-version");
|
||||||
@@ -1307,26 +1322,15 @@ public class AVMServiceTest extends AVMServiceTestBase
|
|||||||
{
|
{
|
||||||
public Object execute() throws Exception
|
public Object execute() throws Exception
|
||||||
{
|
{
|
||||||
|
// note: including implicit snapshot
|
||||||
revert.execute(action, AVMNodeConverter.ToNodeRef(-1, "main:/a/b/c/foo"));
|
revert.execute(action, AVMNodeConverter.ToNodeRef(-1, "main:/a/b/c/foo"));
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}
|
};
|
||||||
;
|
|
||||||
TransactionService transactionService = (TransactionService) fContext.getBean("transactionService");
|
TransactionService transactionService = (TransactionService) fContext.getBean("transactionService");
|
||||||
transactionService.getRetryingTransactionHelper().doInTransaction(new TxnWork());
|
transactionService.getRetryingTransactionHelper().doInTransaction(new TxnWork());
|
||||||
|
|
||||||
results = searchService.query(storeRef, "lucene", "TEXT:\"HEAD\"");
|
|
||||||
assertEquals(0, results.length());
|
|
||||||
results.close();
|
|
||||||
results = searchService.query(storeRef, "lucene", "TEXT:\"V5\"");
|
|
||||||
assertEquals(1, results.length());
|
|
||||||
results.close();
|
|
||||||
results = searchService.query(storeRef, "lucene", "TEXT:\"V2\"");
|
|
||||||
assertEquals(0, results.length());
|
|
||||||
results.close();
|
|
||||||
|
|
||||||
fService.createSnapshot("main", "reverted", null);
|
|
||||||
|
|
||||||
results = searchService.query(storeRef, "lucene", "TEXT:\"HEAD\"");
|
results = searchService.query(storeRef, "lucene", "TEXT:\"HEAD\"");
|
||||||
assertEquals(0, results.length());
|
assertEquals(0, results.length());
|
||||||
results.close();
|
results.close();
|
||||||
@@ -1336,7 +1340,6 @@ public class AVMServiceTest extends AVMServiceTestBase
|
|||||||
results = searchService.query(storeRef, "lucene", "TEXT:\"V2\"");
|
results = searchService.query(storeRef, "lucene", "TEXT:\"V2\"");
|
||||||
assertEquals(1, results.length());
|
assertEquals(1, results.length());
|
||||||
results.close();
|
results.close();
|
||||||
|
|
||||||
}
|
}
|
||||||
catch (Exception e)
|
catch (Exception e)
|
||||||
{
|
{
|
||||||
|
@@ -29,6 +29,7 @@ import java.util.List;
|
|||||||
import org.alfresco.repo.action.ParameterDefinitionImpl;
|
import org.alfresco.repo.action.ParameterDefinitionImpl;
|
||||||
import org.alfresco.repo.action.executer.ActionExecuterAbstractBase;
|
import org.alfresco.repo.action.executer.ActionExecuterAbstractBase;
|
||||||
import org.alfresco.repo.avm.AVMNodeConverter;
|
import org.alfresco.repo.avm.AVMNodeConverter;
|
||||||
|
import org.alfresco.repo.avm.util.AVMUtil;
|
||||||
import org.alfresco.service.cmr.action.Action;
|
import org.alfresco.service.cmr.action.Action;
|
||||||
import org.alfresco.service.cmr.action.ParameterDefinition;
|
import org.alfresco.service.cmr.action.ParameterDefinition;
|
||||||
import org.alfresco.service.cmr.avm.AVMNodeDescriptor;
|
import org.alfresco.service.cmr.avm.AVMNodeDescriptor;
|
||||||
@@ -77,9 +78,12 @@ public class AVMRevertToVersionAction extends ActionExecuterAbstractBase
|
|||||||
{
|
{
|
||||||
Pair<Integer, String> versionPath =
|
Pair<Integer, String> versionPath =
|
||||||
AVMNodeConverter.ToAVMVersionPath(actionedUponNodeRef);
|
AVMNodeConverter.ToAVMVersionPath(actionedUponNodeRef);
|
||||||
AVMNodeDescriptor toRevert =
|
AVMNodeDescriptor toRevertTo =
|
||||||
(AVMNodeDescriptor)action.getParameterValue(TOREVERT);
|
(AVMNodeDescriptor)action.getParameterValue(TOREVERT);
|
||||||
fAVMService.revert(versionPath.getSecond(), toRevert);
|
fAVMService.revert(versionPath.getSecond(), toRevertTo);
|
||||||
|
|
||||||
|
String[] storePath = AVMUtil.splitPath(versionPath.getSecond());
|
||||||
|
fAVMService.createSnapshot(storePath[0], null, "Reverted "+versionPath.getSecond()+" to version "+toRevertTo.getVersionID());
|
||||||
}
|
}
|
||||||
|
|
||||||
/* (non-Javadoc)
|
/* (non-Javadoc)
|
||||||
|
@@ -961,30 +961,28 @@ public class SandboxServiceImpl implements SandboxService
|
|||||||
|
|
||||||
List<AssetInfo> assetsToRevert = new ArrayList<AssetInfo>(assets.size());
|
List<AssetInfo> assetsToRevert = new ArrayList<AssetInfo>(assets.size());
|
||||||
|
|
||||||
List<WorkflowTask> tasks = null;
|
List<String> wfRelativePaths = WCMWorkflowUtil.getAssociatedPathsForSandbox(avmSyncService, workflowService, sbStoreId);
|
||||||
|
|
||||||
for (AssetInfo asset : assets)
|
for (AssetInfo asset : assets)
|
||||||
{
|
{
|
||||||
if (tasks == null)
|
if (! asset.getSandboxId().equals(sbStoreId))
|
||||||
{
|
{
|
||||||
tasks = WCMWorkflowUtil.getAssociatedTasksForSandbox(workflowService, WCMUtil.getSandboxStoreId(asset.getAvmPath()));
|
// belts-and-braces
|
||||||
|
logger.warn("revertListAssets: Skip assert "+asset.getPath()+" (was "+asset.getSandboxId()+", expected "+sbStoreId+")");
|
||||||
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO refactor getAssociatedTasksForNode to use AssetInfo instead of AVMNodeDescriptor
|
// check if in workflow
|
||||||
AVMNodeDescriptor node = ((AssetInfoImpl)asset).getAVMNodeDescriptor();
|
if (! wfRelativePaths.contains(asset.getPath()))
|
||||||
|
|
||||||
if (node != null)
|
|
||||||
{
|
{
|
||||||
if (WCMWorkflowUtil.getAssociatedTasksForNode(avmService, node, tasks).size() == 0)
|
assetsToRevert.add(asset);
|
||||||
{
|
|
||||||
assetsToRevert.add(asset);
|
if (VirtServerUtils.requiresUpdateNotification(asset.getAvmPath()))
|
||||||
|
{
|
||||||
if (VirtServerUtils.requiresUpdateNotification(asset.getAvmPath()))
|
// Bind the post-commit transaction listener with data required for virtualization server notification
|
||||||
{
|
UpdateSandboxTransactionListener tl = new UpdateSandboxTransactionListener(asset.getAvmPath());
|
||||||
// Bind the post-commit transaction listener with data required for virtualization server notification
|
AlfrescoTransactionSupport.bindListener(tl);
|
||||||
UpdateSandboxTransactionListener tl = new UpdateSandboxTransactionListener(asset.getAvmPath());
|
}
|
||||||
AlfrescoTransactionSupport.bindListener(tl);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -24,6 +24,7 @@
|
|||||||
*/
|
*/
|
||||||
package org.alfresco.wcm.util;
|
package org.alfresco.wcm.util;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.LinkedList;
|
import java.util.LinkedList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
@@ -36,6 +37,8 @@ import org.alfresco.service.cmr.avm.AVMNodeDescriptor;
|
|||||||
import org.alfresco.service.cmr.avm.AVMNotFoundException;
|
import org.alfresco.service.cmr.avm.AVMNotFoundException;
|
||||||
import org.alfresco.service.cmr.avm.AVMService;
|
import org.alfresco.service.cmr.avm.AVMService;
|
||||||
import org.alfresco.service.cmr.avm.LayeringDescriptor;
|
import org.alfresco.service.cmr.avm.LayeringDescriptor;
|
||||||
|
import org.alfresco.service.cmr.avmsync.AVMDifference;
|
||||||
|
import org.alfresco.service.cmr.avmsync.AVMSyncService;
|
||||||
import org.alfresco.service.cmr.dictionary.DataTypeDefinition;
|
import org.alfresco.service.cmr.dictionary.DataTypeDefinition;
|
||||||
import org.alfresco.service.cmr.repository.NodeRef;
|
import org.alfresco.service.cmr.repository.NodeRef;
|
||||||
import org.alfresco.service.cmr.workflow.WorkflowService;
|
import org.alfresco.service.cmr.workflow.WorkflowService;
|
||||||
@@ -56,7 +59,7 @@ import org.apache.commons.logging.LogFactory;
|
|||||||
public class WCMWorkflowUtil
|
public class WCMWorkflowUtil
|
||||||
{
|
{
|
||||||
private static final Log logger = LogFactory.getLog(WCMWorkflowUtil.class);
|
private static final Log logger = LogFactory.getLog(WCMWorkflowUtil.class);
|
||||||
|
|
||||||
public static NodeRef createWorkflowPackage(WorkflowService workflowService, AVMService avmService, SandboxInfo sandboxInfo)
|
public static NodeRef createWorkflowPackage(WorkflowService workflowService, AVMService avmService, SandboxInfo sandboxInfo)
|
||||||
{
|
{
|
||||||
// create package paths (layered to user sandbox area as target)
|
// create package paths (layered to user sandbox area as target)
|
||||||
@@ -81,25 +84,30 @@ public class WCMWorkflowUtil
|
|||||||
|
|
||||||
public static List<WorkflowTask> getAssociatedTasksForSandbox(WorkflowService workflowService, final String storeName)
|
public static List<WorkflowTask> getAssociatedTasksForSandbox(WorkflowService workflowService, final String storeName)
|
||||||
{
|
{
|
||||||
|
long start = System.currentTimeMillis();
|
||||||
|
|
||||||
String fromPath = WCMUtil.buildStoreRootPath(storeName);
|
String fromPath = WCMUtil.buildStoreRootPath(storeName);
|
||||||
WorkflowTaskQuery query = new WorkflowTaskQuery();
|
WorkflowTaskQuery query = new WorkflowTaskQuery();
|
||||||
|
|
||||||
HashMap<QName, Object> props = new HashMap<QName, Object>(1, 1.0f);
|
HashMap<QName, Object> props = new HashMap<QName, Object>(1, 1.0f);
|
||||||
|
|
||||||
props.put(WCMWorkflowModel.PROP_FROM_PATH, fromPath);
|
props.put(WCMWorkflowModel.PROP_FROM_PATH, fromPath);
|
||||||
query.setProcessCustomProps(props);
|
query.setProcessCustomProps(props);
|
||||||
query.setActive(true);
|
query.setActive(true);
|
||||||
|
|
||||||
List<WorkflowTask> tasks = workflowService.queryTasks(query);
|
List<WorkflowTask> tasks = workflowService.queryTasks(query);
|
||||||
|
|
||||||
if (logger.isDebugEnabled())
|
if (logger.isTraceEnabled())
|
||||||
{
|
{
|
||||||
logger.debug("found " + tasks.size() + " tasks originating user sandbox " + fromPath);
|
logger.trace("getAssociatedTasksForSandbox: "+storeName+" (found "+tasks.size()+" tasks originating user sandbox "+fromPath+") in "+(System.currentTimeMillis()-start)+" msecs");
|
||||||
}
|
}
|
||||||
|
|
||||||
return tasks;
|
return tasks;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated since 3.2
|
||||||
|
*/
|
||||||
public static List<WorkflowTask> getAssociatedTasksForNode(AVMService avmService, AVMNodeDescriptor node, List<WorkflowTask> tasks)
|
public static List<WorkflowTask> getAssociatedTasksForNode(AVMService avmService, AVMNodeDescriptor node, List<WorkflowTask> tasks)
|
||||||
{
|
{
|
||||||
List<WorkflowTask> result = new LinkedList<WorkflowTask>();
|
List<WorkflowTask> result = new LinkedList<WorkflowTask>();
|
||||||
@@ -139,10 +147,58 @@ public class WCMWorkflowUtil
|
|||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @deprecated since 3.2
|
||||||
|
*/
|
||||||
public static List<WorkflowTask> getAssociatedTasksForNode(WorkflowService workflowService, AVMService avmService, AVMNodeDescriptor node)
|
public static List<WorkflowTask> getAssociatedTasksForNode(WorkflowService workflowService, AVMService avmService, AVMNodeDescriptor node)
|
||||||
{
|
{
|
||||||
final List<WorkflowTask> tasks = WCMWorkflowUtil.getAssociatedTasksForSandbox(workflowService, WCMUtil.getSandboxStoreId(node.getPath()));
|
final List<WorkflowTask> tasks = getAssociatedTasksForSandbox(workflowService, WCMUtil.getSandboxStoreId(node.getPath()));
|
||||||
return getAssociatedTasksForNode(avmService, node, tasks);
|
return getAssociatedTasksForNode(avmService, node, tasks);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static List<String> getAssociatedPathsForSandbox(AVMSyncService avmSyncService, WorkflowService workflowService, String sandboxName)
|
||||||
|
{
|
||||||
|
long start = System.currentTimeMillis();
|
||||||
|
|
||||||
|
List<WorkflowTask> tasks = getAssociatedTasksForSandbox(workflowService, sandboxName);
|
||||||
|
List<String> storeRelativePaths = getAssociatedPathsForSandboxTasks(avmSyncService, sandboxName, tasks);
|
||||||
|
|
||||||
|
if (logger.isDebugEnabled())
|
||||||
|
{
|
||||||
|
logger.debug("getAssociatedPathsForSandbox: "+sandboxName+" (tasks="+tasks.size()+", paths="+storeRelativePaths.size()+") in "+(System.currentTimeMillis()-start)+" msecs");
|
||||||
|
}
|
||||||
|
|
||||||
|
return storeRelativePaths;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static List<String> getAssociatedPathsForSandboxTasks(AVMSyncService avmSyncService, String sandboxName, List<WorkflowTask> tasks)
|
||||||
|
{
|
||||||
|
long start = System.currentTimeMillis();
|
||||||
|
|
||||||
|
String stagingSandboxName = WCMUtil.buildStagingStoreName(WCMUtil.getWebProjectStoreId(sandboxName));
|
||||||
|
List<String> storeRelativePaths = new ArrayList<String>(tasks.size());
|
||||||
|
|
||||||
|
for (WorkflowTask task : tasks)
|
||||||
|
{
|
||||||
|
final NodeRef ref = task.path.instance.workflowPackage;
|
||||||
|
|
||||||
|
String wfPath = AVMNodeConverter.ToAVMVersionPath(ref).getSecond();
|
||||||
|
String stagingSandboxPath = WCMUtil.getCorrespondingPath(wfPath, stagingSandboxName);
|
||||||
|
|
||||||
|
List<AVMDifference> diffs = avmSyncService.compare(-1, wfPath, -1, stagingSandboxPath, null);
|
||||||
|
|
||||||
|
for (AVMDifference diff : diffs)
|
||||||
|
{
|
||||||
|
storeRelativePaths.add(WCMUtil.getStoreRelativePath(diff.getSourcePath()));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (logger.isTraceEnabled())
|
||||||
|
{
|
||||||
|
logger.trace("getAssociatedPathsForSandboxTasks: "+sandboxName+" (tasks="+tasks.size()+", paths="+storeRelativePaths.size()+") in "+(System.currentTimeMillis()-start)+" msecs");
|
||||||
|
}
|
||||||
|
|
||||||
|
return storeRelativePaths;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user