mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-10-08 14:51:49 +00:00
125605 rmunteanu: Merged 5.1.1 (5.1.1) to 5.1.N (5.1.2) 125498 slanglois: MNT-16155 Update source headers - remove svn:eol-style property on Java and JSP source files git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/BRANCHES/DEV/5.2.N/root@125783 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
129 lines
3.7 KiB
Java
129 lines
3.7 KiB
Java
package org.alfresco.filesys.repo.rules;
|
|
|
|
import java.util.regex.Matcher;
|
|
import java.util.regex.Pattern;
|
|
|
|
import org.alfresco.filesys.repo.rules.ScenarioInstance.Ranking;
|
|
import org.alfresco.filesys.repo.rules.operations.CloseFileOperation;
|
|
import org.alfresco.filesys.repo.rules.operations.DeleteFileOperation;
|
|
import org.apache.commons.logging.Log;
|
|
import org.apache.commons.logging.LogFactory;
|
|
|
|
/**
|
|
* The DeleteOnClose rename shuffle is a delete on close of a file resulting in a file being deleted followed by a
|
|
* rename or a create
|
|
*
|
|
* First case of this is Mac Mountain Lion Preview application.
|
|
* and then a new copy of the file put into place.
|
|
*
|
|
* a) DeleteOnClose fileA
|
|
* b) Close fileA
|
|
* c) Rename whatever fileA
|
|
*
|
|
* Second case First case of this is Mac Drag and drop.
|
|
* and then a new copy of the file put into place.
|
|
*
|
|
* a) Delete fileA
|
|
* b) Close fileA
|
|
* c) Create fileA
|
|
*
|
|
* Third case Gedit.
|
|
*
|
|
* a) Delete fileA
|
|
* b) Rename .goutputstream fileA
|
|
*
|
|
*/
|
|
public class ScenarioDeleteRenameOrCreate implements Scenario
|
|
{
|
|
private static Log logger = LogFactory.getLog(ScenarioDeleteRenameOrCreate.class);
|
|
|
|
/**
|
|
* The regex pattern of a close that will trigger a new instance of
|
|
* the scenario.
|
|
*/
|
|
private Pattern pattern;
|
|
private String strPattern;
|
|
|
|
private long timeout = 30000;
|
|
|
|
@Override
|
|
public ScenarioInstance createInstance(final EvaluatorContext ctx, Operation operation)
|
|
{
|
|
/**
|
|
* This scenario is triggered by a rename of a file matching
|
|
* the pattern
|
|
*/
|
|
if(operation instanceof CloseFileOperation)
|
|
{
|
|
CloseFileOperation c = (CloseFileOperation)operation;
|
|
|
|
Matcher m = pattern.matcher(c.getName());
|
|
if(m.matches() && c.getNetworkFile().hasDeleteOnClose())
|
|
{
|
|
if(logger.isDebugEnabled())
|
|
{
|
|
logger.debug("New Scenario ScenarioDeleteRenameOrCreate strPattern:" + pattern);
|
|
}
|
|
ScenarioDeleteRenameOrCreateInstance instance = new ScenarioDeleteRenameOrCreateInstance();
|
|
instance.setTimeout(timeout);
|
|
instance.setRanking(ranking);
|
|
return instance;
|
|
}
|
|
}
|
|
|
|
if(operation instanceof DeleteFileOperation)
|
|
{
|
|
DeleteFileOperation c = (DeleteFileOperation)operation;
|
|
|
|
Matcher m = pattern.matcher(c.getName());
|
|
if(m.matches())
|
|
{
|
|
if(logger.isDebugEnabled())
|
|
{
|
|
logger.debug("New Scenario ScenarioDeleteRenameOrCreate strPattern:" + pattern);
|
|
}
|
|
ScenarioDeleteRenameOrCreateInstance instance = new ScenarioDeleteRenameOrCreateInstance();
|
|
instance.setTimeout(timeout);
|
|
instance.setRanking(ranking);
|
|
return instance;
|
|
}
|
|
}
|
|
|
|
// No not interested.
|
|
return null;
|
|
}
|
|
|
|
public void setTimeout(long timeout)
|
|
{
|
|
this.timeout = timeout;
|
|
}
|
|
|
|
public long getTimeout()
|
|
{
|
|
return timeout;
|
|
}
|
|
|
|
public void setPattern(String pattern)
|
|
{
|
|
this.pattern = Pattern.compile(pattern, Pattern.CASE_INSENSITIVE);
|
|
this.strPattern = pattern;
|
|
}
|
|
|
|
public String getPattern()
|
|
{
|
|
return strPattern;
|
|
}
|
|
|
|
private Ranking ranking = Ranking.HIGH;
|
|
|
|
public void setRanking(Ranking ranking)
|
|
{
|
|
this.ranking = ranking;
|
|
}
|
|
|
|
public Ranking getRanking()
|
|
{
|
|
return ranking;
|
|
}
|
|
}
|