[seam-commits] Seam SVN: r11131 - branches/community/Seam_2_1/src/main/org/jboss/seam/jms.

seam-commits at lists.jboss.org seam-commits at lists.jboss.org
Thu Jun 11 19:30:13 EDT 2009


Author: dan.j.allen
Date: 2009-06-11 19:30:12 -0400 (Thu, 11 Jun 2009)
New Revision: 11131

Modified:
   branches/community/Seam_2_1/src/main/org/jboss/seam/jms/ContextualMessageHandlerRequest.java
Log:
add business process support


Modified: branches/community/Seam_2_1/src/main/org/jboss/seam/jms/ContextualMessageHandlerRequest.java
===================================================================
--- branches/community/Seam_2_1/src/main/org/jboss/seam/jms/ContextualMessageHandlerRequest.java	2009-06-11 23:08:53 UTC (rev 11130)
+++ branches/community/Seam_2_1/src/main/org/jboss/seam/jms/ContextualMessageHandlerRequest.java	2009-06-11 23:30:12 UTC (rev 11131)
@@ -2,13 +2,18 @@
 
 import java.lang.reflect.ParameterizedType;
 
+import javax.jms.JMSException;
 import javax.jms.Message;
 import javax.jms.TextMessage;
 
 import org.jboss.seam.Component;
 import org.jboss.seam.async.AbstractDispatcher;
+import org.jboss.seam.bpm.BusinessProcess;
 import org.jboss.seam.contexts.Contexts;
 import org.jboss.seam.contexts.Lifecycle;
+import org.jboss.seam.core.Init;
+import org.jboss.seam.log.LogProvider;
+import org.jboss.seam.log.Logging;
 
 /**
  * <p>
@@ -26,6 +31,8 @@
  */
 public abstract class ContextualMessageHandlerRequest<T>
 {
+   private static transient final LogProvider log = Logging.getLogProvider(ContextualMessageHandlerRequest.class);
+   
    private Message message;
    private boolean setupRequired = false;
    private Object result = null;
@@ -90,6 +97,11 @@
       }
       
       Contexts.getEventContext().set(AbstractDispatcher.EXECUTING_ASYNCHRONOUS_CALL, true);
+      if (Init.instance().isJbpmInstalled())
+      {
+         setupProcessOrTask();
+      }
+      
       Class<T> delegateClass = getDelegateClass();
       if (delegateClass != null)
       {
@@ -97,6 +109,37 @@
       }
    }
    
+   private void setupProcessOrTask()
+   {
+      try
+      {
+         Long taskId = message.getLongProperty("taskId");
+         if (taskId != null)
+         {
+            BusinessProcess.instance().resumeTask(taskId);
+            return;
+         }
+      }
+      catch (JMSException e)
+      {
+         log.debug("Could not retrieve taskId from message object: " + e.getMessage());
+      }
+      
+      try
+      {
+         Long processId = message.getLongProperty("processId");
+         if (processId != null)
+         {
+            BusinessProcess.instance().resumeProcess(processId);
+            return;
+         }
+      }
+      catch (JMSException e)
+      {
+         log.debug("Could not retrieve processId from message object: " + e.getMessage());
+      }
+   }
+   
    private void cleanup()
    {
       Contexts.getEventContext().remove(AbstractDispatcher.EXECUTING_ASYNCHRONOUS_CALL);




More information about the seam-commits mailing list