X-Git-Url: http://git.argeo.org/?a=blobdiff_plain;f=runtime%2Forg.argeo.slc.core%2Fsrc%2Fmain%2Fjava%2Forg%2Fargeo%2Fslc%2Fcore%2Fexecution%2FAbstractExecutionModulesManager.java;fp=runtime%2Forg.argeo.slc.core%2Fsrc%2Fmain%2Fjava%2Forg%2Fargeo%2Fslc%2Fcore%2Fexecution%2FAbstractExecutionModulesManager.java;h=3b561392115a27d2e156493383e3d7121adacd36;hb=0e2ff188c2e8ffac85739cccc3925e8bd82d7be9;hp=06c05248b2f3c82ec3c25fa89c17ac719937e6d8;hpb=8696d1a70c254b338d0cac390ef7c80b5f773942;p=gpl%2Fargeo-slc.git diff --git a/runtime/org.argeo.slc.core/src/main/java/org/argeo/slc/core/execution/AbstractExecutionModulesManager.java b/runtime/org.argeo.slc.core/src/main/java/org/argeo/slc/core/execution/AbstractExecutionModulesManager.java index 06c05248b..3b5613921 100644 --- a/runtime/org.argeo.slc.core/src/main/java/org/argeo/slc/core/execution/AbstractExecutionModulesManager.java +++ b/runtime/org.argeo.slc.core/src/main/java/org/argeo/slc/core/execution/AbstractExecutionModulesManager.java @@ -17,6 +17,7 @@ package org.argeo.slc.core.execution; import java.util.ArrayList; +import java.util.Collections; import java.util.Iterator; import java.util.List; import java.util.Map; @@ -28,9 +29,10 @@ import org.argeo.slc.execution.ExecutionFlow; import org.argeo.slc.execution.ExecutionFlowDescriptorConverter; import org.argeo.slc.execution.ExecutionModulesManager; import org.argeo.slc.execution.ExecutionProcess; +import org.argeo.slc.execution.ExecutionProcessNotifier; +import org.argeo.slc.execution.ExecutionStep; import org.argeo.slc.process.RealizedFlow; import org.argeo.slc.process.SlcExecutionNotifier; -import org.argeo.slc.process.SlcExecutionStep; /** Provides the base feature of an execution module manager. */ @SuppressWarnings("deprecation") @@ -41,7 +43,10 @@ public abstract class AbstractExecutionModulesManager implements private List slcExecutionNotifiers = new ArrayList(); - private ThreadGroup processesThreadGroup = new ThreadGroup("Processes"); + private List filteredNotifiers = Collections + .synchronizedList(new ArrayList()); + + private ThreadGroup processesThreadGroup = new ThreadGroup("SLC Processes"); protected abstract ExecutionFlow findExecutionFlow(String moduleName, String moduleVersion, String flowName); @@ -79,30 +84,50 @@ public abstract class AbstractExecutionModulesManager implements // } - public void dispatchUpdateStatus(ExecutionProcess slcExecution, + public void dispatchUpdateStatus(ExecutionProcess process, String oldStatus, String newStatus) { + // generic notifiers (notified of everything) for (Iterator it = getSlcExecutionNotifiers() .iterator(); it.hasNext();) { - it.next().updateStatus(slcExecution, oldStatus, newStatus); + it.next().updateStatus(process, oldStatus, newStatus); + } + + // filtered notifiers + for (Iterator it = filteredNotifiers.iterator(); it + .hasNext();) { + FilteredNotifier filteredNotifier = it.next(); + if (filteredNotifier.receiveFrom(process)) + filteredNotifier.getNotifier().updateStatus(process, oldStatus, + newStatus); } } - public void dispatchAddStep(ExecutionProcess slcExecution, - SlcExecutionStep step) { - List steps = new ArrayList(); - steps.add(step); + public void dispatchAddSteps(ExecutionProcess process, + List steps) { for (Iterator it = getSlcExecutionNotifiers() .iterator(); it.hasNext();) { - it.next().addSteps(slcExecution, steps); + it.next().addSteps(process, steps); + } + + for (Iterator it = filteredNotifiers.iterator(); it + .hasNext();) { + FilteredNotifier filteredNotifier = it.next(); + if (filteredNotifier.receiveFrom(process)) + filteredNotifier.getNotifier().addSteps(process, steps); } } + public void registerProcessNotifier(ExecutionProcessNotifier notifier, + Map properties) { + filteredNotifiers.add(new FilteredNotifier(notifier, properties)); + } + public void setSlcExecutionNotifiers( List slcExecutionNotifiers) { this.slcExecutionNotifiers = slcExecutionNotifiers; } - public List getSlcExecutionNotifiers() { + private List getSlcExecutionNotifiers() { return slcExecutionNotifiers; } @@ -110,4 +135,45 @@ public abstract class AbstractExecutionModulesManager implements return processesThreadGroup; } + protected class FilteredNotifier { + private final ExecutionProcessNotifier notifier; + private final String processId; + + public FilteredNotifier(ExecutionProcessNotifier notifier, + Map properties) { + super(); + this.notifier = notifier; + if (properties.containsKey(SLC_PROCESS_ID)) + processId = properties.get(SLC_PROCESS_ID); + else + processId = null; + } + + /** + * Whether event from this process should be received by this listener. + */ + public Boolean receiveFrom(ExecutionProcess process) { + if (processId != null) + if (process.getUuid().equals(processId)) + return true; + else + return false; + return true; + } + + @Override + public int hashCode() { + return notifier.hashCode(); + } + + @Override + public boolean equals(Object obj) { + return notifier.equals(obj); + } + + public ExecutionProcessNotifier getNotifier() { + return notifier; + } + + } }