All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.camunda.bpm.application.impl.JakartaEjbProcessApplication Maven / Gradle / Ivy

/*
 * Copyright Camunda Services GmbH and/or licensed to Camunda Services GmbH
 * under one or more contributor license agreements. See the NOTICE file
 * distributed with this work for additional information regarding copyright
 * ownership. Camunda licenses this file to you under the Apache License,
 * Version 2.0; you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package org.camunda.bpm.application.impl;

import jakarta.ejb.SessionContext;
import javax.naming.InitialContext;
import javax.naming.NamingException;
import org.camunda.bpm.application.ProcessApplicationInterface;
import org.camunda.bpm.application.ProcessApplicationReference;
import org.camunda.bpm.engine.ManagementService;
import org.camunda.bpm.engine.delegate.JavaDelegate;
import org.camunda.bpm.engine.impl.ProcessEngineLogger;

/**
 * 

Common base class for writing Jakarta Enterprise Bean 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 {@link ProcessApplicationReference} held by the process engine.

* *

Usage

*

In order to add a custom EJB process application to your application, extend this class and configure * it as follows:

*
 * {@literal @}ProcessApplication("my process application")
 * {@literal @}Singleton
 * {@literal @}Startup
 * {@literal @}ConcurrencyManagement(ConcurrencyManagementType.BEAN)
 * {@literal @}TransactionAttribute(TransactionAttributeType.REQUIRED)
 * public class DefaultEjbProcessApplication extends JakartaEjbProcessApplication {
 *
 *   {@literal @}PostConstruct
 *   public void deploy() {
 *     super.deploy();
 *   }
 *
 *   {@literal @}PreDestroy
 *   public void undeploy() {
 *     super.undeploy();
 *   }
 * }
 * 
*

(the same Metadata can of course be provided using an XML-based ejb-jar.xml * deployment descriptor

* *

Invocation Semantics

*

This 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 {@link JavaDelegate} implementation, the process engine * will call the {@link JakartaEjbProcessApplication JakartaEjbProcessApplication's} * {@link #execute(java.util.concurrent.Callable)} Method and from that method invoke * the {@link JavaDelegate}. This makes sure that *

    *
  • the call is intercepted by the EJB container and "enters" the process application legally.
  • *
  • the {@link JavaDelegate} may take advantage of the {@link JakartaEjbProcessApplication}'s invocation context * and resolve resources from the component's Environment (such as a java:comp/BeanManager). *
*

* * *
 *                        Big pile of EJB interceptors
 *                                     |
 *                                     |  +--------------------+
 *                                     |  |Process Application |
 *                       invoke        v  |                    |
 *      ProcessEngine ----------------OOOOO--> Java Delegate   |
 *                                        |                    |
 *                                        |                    |
 *                                        +--------------------+
 *
 * 
* *

Process Application Reference

*

When the process application registers with a process engine * (see {@link 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. The {@link JakartaEjbProcessApplication} takes advantage * of the EJB Container's naming context and passes a reference containing the JakartaEjbProcessApplication'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.

* */ public class JakartaEjbProcessApplication extends AbstractEjbProcessApplication { private static ProcessApplicationLogger LOG = ProcessEngineLogger.PROCESS_APPLICATION_LOGGER; private JakartaEjbProcessApplicationReference ejbProcessApplicationReference; @Override protected ProcessApplicationInterface lookupSelfReference() { try { InitialContext ic = new InitialContext(); SessionContext sctxLookup = (SessionContext) ic.lookup(EJB_CONTEXT_PATH); return sctxLookup.getBusinessObject(getBusinessInterface()); } catch (NamingException e) { throw LOG.ejbPaCannotLookupSelfReference(e); } } @Override protected void ensureEjbProcessApplicationReferenceInitialized() { if (ejbProcessApplicationReference == null) { ejbProcessApplicationReference = new JakartaEjbProcessApplicationReference(selfReference, getName()); } } @Override protected ProcessApplicationReference getEjbProcessApplicationReference() { return ejbProcessApplicationReference; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy