package org.argeo.slc.core.execution; import java.util.ArrayList; import java.util.List; import java.util.Map; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; import org.argeo.slc.execution.ExecutionContext; import org.argeo.slc.execution.ExecutionFlow; import org.argeo.slc.execution.ExecutionFlowDescriptorConverter; import org.argeo.slc.execution.ExecutionModulesListener; import org.argeo.slc.execution.ExecutionModulesManager; import org.argeo.slc.process.RealizedFlow; import org.argeo.slc.process.SlcExecution; import org.argeo.slc.process.SlcExecutionNotifier; public abstract class AbstractExecutionModulesManager implements ExecutionModulesManager { private final static Log log = LogFactory .getLog(AbstractExecutionModulesManager.class); private List slcExecutionNotifiers = new ArrayList(); private List executionModulesListeners = new ArrayList(); private ThreadGroup processesThreadGroup = new ThreadGroup("Processes"); protected abstract ExecutionFlow findExecutionFlow(String moduleName, String moduleVersion, String flowName); protected abstract ExecutionContext findExecutionContext(String moduleName, String moduleVersion); protected abstract ExecutionFlowDescriptorConverter getExecutionFlowDescriptorConverter( String moduleName, String moduleVersion); public void process(SlcExecution slcExecution) { new ProcessThread(this, slcExecution).start(); } public void execute(RealizedFlow realizedFlow) { if (log.isTraceEnabled()) log.trace("Executing " + realizedFlow); String moduleName = realizedFlow.getModuleName(); String moduleVersion = realizedFlow.getModuleVersion(); Map variablesToAdd = getExecutionFlowDescriptorConverter( moduleName, moduleVersion).convertValues( realizedFlow.getFlowDescriptor()); ExecutionContext executionContext = findExecutionContext(moduleName, moduleVersion); for (String key : variablesToAdd.keySet()) executionContext.setVariable(key, variablesToAdd.get(key)); ExecutionFlow flow = findExecutionFlow(moduleName, moduleVersion, realizedFlow.getFlowDescriptor().getName()); // // Actually runs the flow, IN THIS THREAD // flow.run(); // // // } public void setSlcExecutionNotifiers( List slcExecutionNotifiers) { this.slcExecutionNotifiers = slcExecutionNotifiers; } public List getSlcExecutionNotifiers() { return slcExecutionNotifiers; } public ThreadGroup getProcessesThreadGroup() { return processesThreadGroup; } public List getExecutionModulesListeners() { return executionModulesListeners; } public void setExecutionModulesListeners( List executionModulesListeners) { this.executionModulesListeners = executionModulesListeners; } }