Class EjbProcessApplication
- java.lang.Object
- 
- org.camunda.bpm.application.AbstractProcessApplication
- 
- org.camunda.bpm.application.impl.EjbProcessApplication
 
 
- 
- All Implemented Interfaces:
- ProcessApplicationInterface
 - Direct Known Subclasses:
- DefaultEjbProcessApplication
 
 public class EjbProcessApplication extends AbstractProcessApplication Common base class for writing EJB process applications. An EJB Process Application exposes itself as a Session Bean Component inside the EJB container. This determines the invocation semantics when invoking code from the process application and the nature of the ProcessApplicationReferenceheld by the process engine.UsageIn order to add a custom EJB process application to your application, extend this class and configure it as follows: @ProcessApplication("my process application") @Singleton @Startup @ConcurrencyManagement(ConcurrencyManagementType.BEAN) @TransactionAttribute(TransactionAttributeType.REQUIRED) public class DefaultEjbProcessApplication extends EjbProcessApplication { @PostConstruct public void deploy() { super.deploy(); } @PreDestroy public void undeploy() { super.undeploy(); } }(the same Metadata can of course be provided using an XML-based ejb-jar.xmldeployment descriptorInvocation SemanticsThis allows the process engine as well as other applications to invoke this EJB Process Application and get EJB invocation semantics for the invocation. For example, if your process application provides a JavaDelegateimplementation, the process engine will call theEjbProcessApplication'sexecute(java.util.concurrent.Callable)Method and from that method invoke theJavaDelegate. This makes sure that- the call is intercepted by the EJB container and "enters" the process application legally.
- the JavaDelegatemay take advantage of theEjbProcessApplication's invocation context and resolve resources from the component's Environment (such as ajava:comp/BeanManager).
 Big pile of EJB interceptors | | +--------------------+ | |Process Application | invoke v | | ProcessEngine ----------------OOOOO--> Java Delegate | | | | | +--------------------+Process Application ReferenceWhen the process application registers with a process engine (see ManagementService.registerProcessApplication(String, ProcessApplicationReference), the process application passes a reference to itself to the process engine. This reference allows the process engine to reference the process application. TheEjbProcessApplicationtakes advantage of the Ejb Containers naming context and passes a reference containing the EJBProcessApplication's Component Name to the process engine. Whenever the process engine needs access to process application, the actual component instance is looked up and invoked.- Author:
- Daniel Meyer
 
- 
- 
Field SummaryFields Modifier and Type Field Description protected static StringEJB_CONTEXT_PATHprotected static StringJAVA_APP_APP_NAME_PATHprotected static StringMODULE_NAME_PATH- 
Fields inherited from class org.camunda.bpm.application.AbstractProcessApplicationdefaultDeployToEngineName, isDeployed, processApplicationBeanElResolver, processApplicationElResolver, processApplicationScriptEnvironment, variableSerializers
 
- 
 - 
Constructor SummaryConstructors Constructor Description EjbProcessApplication()
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description protected StringautodetectProcessApplicationName()Override this method to autodetect an application name in case theProcessApplicationannotation was used but without parameter.protected voidensureInitialized()<T> Texecute(Callable<T> callable)The default implementation simply modifies the ContextClassLoaderprotected Class<? extends ProcessApplicationInterface>getBusinessInterface()allows subclasses to provide a custom business interfaceProcessApplicationReferencegetReference()Returns a globally sharable reference to this process application.protected StringlookupEeApplicationName()determine the ee application name based on information obtained from JNDI.protected ProcessApplicationInterfacelookupSelfReference()lookup a proxy object representing the invoked business view of this component.- 
Methods inherited from class org.camunda.bpm.application.AbstractProcessApplicationcreateDeployment, deploy, execute, getBeanElResolver, getDefaultDeployToEngineName, getElResolver, getEnvironmentScripts, getExecutionListener, getName, getProcessApplicationClassloader, getProcessApplicationScriptEnvironment, getProperties, getRawObject, getScriptEngineForName, getTaskListener, getVariableSerializers, initProcessApplicationElResolver, setDefaultDeployToEngineName, setVariableSerializers, undeploy
 
- 
 
- 
- 
- 
Method Detail- 
getReferencepublic ProcessApplicationReference getReference() Description copied from interface:ProcessApplicationInterfaceReturns a globally sharable reference to this process application. This reference may be safely passed to the process engine. And other applications. - Returns:
- a globally sharable reference to this process application.
 
 - 
autodetectProcessApplicationNameprotected String autodetectProcessApplicationName() Description copied from class:AbstractProcessApplicationOverride this method to autodetect an application name in case theProcessApplicationannotation was used but without parameter.- Specified by:
- autodetectProcessApplicationNamein class- AbstractProcessApplication
 
 - 
getBusinessInterfaceprotected Class<? extends ProcessApplicationInterface> getBusinessInterface() allows subclasses to provide a custom business interface
 - 
executepublic <T> T execute(Callable<T> callable) throws ProcessApplicationExecutionException Description copied from interface:ProcessApplicationInterfaceThe default implementation simply modifies the ContextClassLoader- Specified by:
- executein interface- ProcessApplicationInterface
- Overrides:
- executein class- AbstractProcessApplication
- Parameters:
- callable- to be executed "within" the context of this process application.
- Returns:
- the result of the callback
- Throws:
- ProcessApplicationExecutionException
 
 - 
ensureInitializedprotected void ensureInitialized() 
 - 
lookupSelfReferenceprotected ProcessApplicationInterface lookupSelfReference() lookup a proxy object representing the invoked business view of this component.
 - 
lookupEeApplicationNameprotected String lookupEeApplicationName() determine the ee application name based on information obtained from JNDI.
 
- 
 
-