import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
-import org.argeo.slc.core.runtime.AbstractAgent;
+import org.argeo.slc.msg.MsgConstants;
import org.argeo.slc.msg.event.SlcEvent;
import org.argeo.slc.msg.event.SlcEventPublisher;
+import org.argeo.slc.msg.process.SlcExecutionStatusRequest;
+import org.argeo.slc.process.SlcExecution;
import org.argeo.slc.runtime.SlcAgentDescriptor;
import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.annotation.After;
@Aspect
public class EventPublisherAspect {
+ public final static String EVT_AGENT_REGISTERED = "agentRegistered";
+ public final static String EVT_AGENT_UNREGISTERED = "agentUnregistered";
+ public final static String EVT_NEW_SLC_EXECUTION = "newSlcExecution";
+ public final static String EVT_UPDATE_SLC_EXECUTION_STATUS = "updateSlcExecutionStatus";
+
private final static Log log = LogFactory
.getLog(EventPublisherAspect.class);
@After("execution(void org.argeo.slc.services.runtime.AgentService.register(..))")
public void registerAgent(JoinPoint jp) throws Throwable {
SlcAgentDescriptor agentDescriptor = (SlcAgentDescriptor) jp.getArgs()[0];
- SlcEvent event = new SlcEvent("agentRegistered");
- event.getHeaders().put(AbstractAgent.PROPERTY_SLC_AGENT_ID,
+ SlcEvent event = new SlcEvent(EVT_AGENT_REGISTERED);
+ event.getHeaders().put(MsgConstants.PROPERTY_SLC_AGENT_ID,
agentDescriptor.getUuid());
publishEvent(event);
}
@After("execution(void org.argeo.slc.services.runtime.AgentService.unregister(..))")
public void unregisterAgent(JoinPoint jp) throws Throwable {
SlcAgentDescriptor agentDescriptor = (SlcAgentDescriptor) jp.getArgs()[0];
- SlcEvent event = new SlcEvent("agentUnregistered");
- event.getHeaders().put(AbstractAgent.PROPERTY_SLC_AGENT_ID,
+ SlcEvent event = new SlcEvent(EVT_AGENT_UNREGISTERED);
+ event.getHeaders().put(MsgConstants.PROPERTY_SLC_AGENT_ID,
agentDescriptor.getUuid());
publishEvent(event);
}
+ @After("execution(void org.argeo.slc.services.process.SlcExecutionService.newExecution(..))")
+ public void newSlcExecution(JoinPoint jp) throws Throwable {
+ SlcExecution slcExecution = (SlcExecution) jp.getArgs()[0];
+ SlcEvent event = new SlcEvent(EVT_NEW_SLC_EXECUTION);
+ event.getHeaders().put(MsgConstants.PROPERTY_SLC_EXECUTION_ID,
+ slcExecution.getUuid());
+ publishEvent(event);
+ }
+
+ @After("execution(void org.argeo.slc.services.process.SlcExecutionService.updateStatus(..))")
+ public void updateSlcExecutionStatus(JoinPoint jp) throws Throwable {
+ SlcExecutionStatusRequest msg = (SlcExecutionStatusRequest) jp
+ .getArgs()[0];
+ SlcEvent event = new SlcEvent(EVT_UPDATE_SLC_EXECUTION_STATUS);
+ event.getHeaders().put(MsgConstants.PROPERTY_SLC_EXECUTION_ID,
+ msg.getSlcExecutionUuid());
+ event.getHeaders().put(MsgConstants.PROPERTY_SLC_EXECUTION_STATUS,
+ msg.getNewStatus());
+ publishEvent(event);
+ }
+
public void setEventPublishers(List<SlcEventPublisher> eventPublishers) {
this.eventPublishers = eventPublishers;
}
--- /dev/null
+package org.argeo.slc.web.mvc.process;\r
+\r
+import javax.servlet.http.HttpServletRequest;\r
+import javax.servlet.http.HttpServletResponse;\r
+import javax.xml.transform.stream.StreamSource;\r
+\r
+import org.argeo.slc.msg.MsgConstants;\r
+import org.argeo.slc.process.SlcExecution;\r
+import org.argeo.slc.runtime.SlcAgent;\r
+import org.argeo.slc.runtime.SlcAgentFactory;\r
+import org.argeo.slc.web.mvc.AbstractServiceController;\r
+import org.springframework.oxm.Unmarshaller;\r
+import org.springframework.web.servlet.ModelAndView;\r
+\r
+/** Send a new SlcExecution. */\r
+public class NewSlcExecutionController extends AbstractServiceController {\r
+ private SlcAgentFactory agentFactory;\r
+ private Unmarshaller unmarshaller;\r
+\r
+ @Override\r
+ protected void handleServiceRequest(HttpServletRequest request,\r
+ HttpServletResponse response, ModelAndView modelAndView)\r
+ throws Exception {\r
+\r
+ String agentId = request\r
+ .getParameter(MsgConstants.PROPERTY_SLC_AGENT_ID);\r
+\r
+ StreamSource source = new StreamSource(request.getInputStream());\r
+ SlcExecution slcExecution = (SlcExecution) unmarshaller\r
+ .unmarshal(source);\r
+\r
+ SlcAgent agent = agentFactory.getAgent(agentId);\r
+ agent.runSlcExecution(slcExecution);\r
+ }\r
+\r
+ public void setUnmarshaller(Unmarshaller unmarshaller) {\r
+ this.unmarshaller = unmarshaller;\r
+ }\r
+\r
+ public void setAgentFactory(SlcAgentFactory agentFactory) {\r
+ this.agentFactory = agentFactory;\r
+ }\r
+\r
+}\r
import org.argeo.slc.execution.ExecutionModule;
import org.argeo.slc.execution.ExecutionModuleDescriptor;
import org.argeo.slc.msg.ExecutionAnswer;
+import org.argeo.slc.msg.MsgConstants;
import org.argeo.slc.msg.ReferenceList;
import org.argeo.slc.process.SlcExecution;
import org.argeo.slc.runtime.SlcAgent;
public Message postProcessMessage(Message messageToSend)
throws JMSException {
messageToSend.setStringProperty(PROPERTY_QUERY, query);
- messageToSend.setStringProperty(AbstractAgent.PROPERTY_SLC_AGENT_ID,
+ messageToSend.setStringProperty(MsgConstants.PROPERTY_SLC_AGENT_ID,
agentDescriptor.getUuid());
messageToSend.setJMSCorrelationID(correlationId);
return messageToSend;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.argeo.slc.SlcException;
-import org.argeo.slc.core.runtime.AbstractAgent;
import org.argeo.slc.execution.ExecutionModuleDescriptor;
import org.argeo.slc.msg.ExecutionAnswer;
+import org.argeo.slc.msg.MsgConstants;
import org.argeo.slc.process.SlcExecution;
import org.argeo.slc.runtime.SlcAgent;
import org.argeo.slc.runtime.SlcAgentDescriptor;
msg = session.createTextMessage();
else
msg = toMessage(body, session);
- msg.setStringProperty(AbstractAgent.PROPERTY_SLC_AGENT_ID, agentUuid);
+ msg.setStringProperty(MsgConstants.PROPERTY_SLC_AGENT_ID, agentUuid);
msg.setStringProperty(JmsAgent.PROPERTY_QUERY, query);
msg.setJMSCorrelationID(correlationId);
setArguments(msg);
import javax.jms.MessageListener;
import org.argeo.slc.SlcException;
-import org.argeo.slc.core.runtime.AbstractAgent;
+import org.argeo.slc.msg.MsgConstants;
import org.argeo.slc.msg.MsgHandler;
import org.argeo.slc.process.SlcExecution;
import org.argeo.slc.runtime.SlcAgent;
public void onMessage(final Message message) {
try {
String agentId = message
- .getStringProperty(AbstractAgent.PROPERTY_SLC_AGENT_ID);
+ .getStringProperty(MsgConstants.PROPERTY_SLC_AGENT_ID);
final SlcAgent agent = agentFactory.getAgent(agentId);
final SlcExecution slcExecution = (SlcExecution) messageConverter
.fromMessage(message);
// private final static Log log = LogFactory.getLog(AbstractAgent.class);
private ExecutionModulesManager modulesManager;
- public final static String PROPERTY_SLC_AGENT_ID = "slc_agentId";
-
public void runSlcExecution(final SlcExecution slcExecution) {
modulesManager.process(slcExecution);
}
--- /dev/null
+package org.argeo.slc.msg;
+
+public class MsgConstants {
+
+ public final static String PROPERTY_SLC_AGENT_ID = "slc_agentId";
+ public final static String PROPERTY_SLC_EXECUTION_ID = "slc_executionId";
+ public final static String PROPERTY_SLC_EXECUTION_STATUS = "slc_executionStatus";
+
+ /** Force singleton */
+ private MsgConstants() {
+
+ }
+}
<constructor-arg ref="slcExecutionDao" />
</bean>
+ <bean name="/newSlcExecution.service"
+ class="org.argeo.slc.web.mvc.process.NewSlcExecutionController">
+ <property name="agentFactory" ref="agentFactory" />
+ <property name="unmarshaller" ref="slcDefault.castor.marshaller" />
+ </bean>
+
<bean name="/getExecutionDescriptor.service" class="org.argeo.slc.web.mvc.execution.GetModuleDescriptor">
<property name="agentFactory" ref="agentFactory" />
</bean>