Skip to content

Latest commit

 

History

History
144 lines (105 loc) · 5.04 KB

File metadata and controls

144 lines (105 loc) · 5.04 KB

Camunda Engine OpenAPI REST Client Java and Spring Boot

Compatible with: Camunda Platform 7

This community extension is a convenience wrapper around the generated Java client from the Camunda Platform 7.x OpenAPI spec.

Example application

An example application using this community extension in a Spring Boot context can be found here: https://github.com/berndruecker/camunda-platform-remote-spring-boot-example

Using the client

The camunda endpoint in the ApiClient is by default http://localhost:8080/engine-rest, if you use a diffrent path then set it through setBasePath method of the ApiClient.

Plain Java

In a plain Java project you can simply add this dependency (please make sure to use the latest version as there were a couple of important bug fixes lately):

    <dependency>
      <groupId>org.camunda.community</groupId>
      <artifactId>camunda-engine-rest-client-openapi-java</artifactId>
      <version>7.20.0</version>
    </dependency>

Now you can use the ApiClient and various generated artifacts, for example:

 public static void main(String[] args) throws ApiException {
    ApiClient client = new ApiClient();
    client.setBasePath("http://localhost:8080/engine-rest");

    new DeploymentApi(client).createDeployment(
            null,
            null,
            true,
            true,
            "benchmark",
            null,
            new File(App.class.getClassLoader().getResource(bpmnXmlPath).getFile())
    );
    System.out.println("DEPLOYED");

    new ProcessDefinitionApi(client).startProcessInstanceByKey(
            processId,
            new StartProcessInstanceDto()
                    .variables(Collections.singletonMap("json", new VariableValueDto().value("test").type("string"))));

    System.out.println("STARTED");
  }

Spring Boot Starter

For convenience, there is also a Spring Boot Starter, that

  • Wires the ApiClient and provide all API's
  • Autodeploys all BPMN, DMN and form resources it finds on the classpath during startup.

Add this dependency:

    <dependency>
      <groupId>org.camunda.community</groupId>
      <artifactId>camunda-engine-rest-client-openapi-springboot</artifactId>
      <version>7.20.0</version>
    </dependency>

You can configure the Camunda endpoint via your application.properties and initialize the client been like this:

camunda.bpm.client.base-url: http://localhost:8080/engine-rest

And then simply inject the API, for example:

@RestController
public class ExampleRestEndpoint {

    @Autowired
    private ProcessDefinitionApi processDefinitionApi;

    @PutMapping("/start")
    public ResponseEntity<String> startProcess(ServerWebExchange exchange) throws ApiException {
        // ...

        // start process instance
        ProcessInstanceWithVariablesDto processInstance = processDefinitionApi.startProcessInstanceByKey(
                ProcessConstants.PROCESS_KEY,
                new StartProcessInstanceDto().variables(variables));
        // ...

Auto Deployment

You can auto-deploy resources from your project, like BPMN processes. As default, all .bpmn, .dmn, and .form files are picked up and deployed. The pattern for resource files can be configured:

camunda.autoDeploy.bpmnResources: 'classpath*:**/*.bpmn'
camunda.autoDeploy.dmnResources: 'classpath*:**/*.dmn'
camunda.autoDeploy.formResources: 'classpath*:**/*.form'

You can disable auto deployment (which is enabled by default):

camunda.autoDeploy.enabled: false

If you want to disable service start failure if it fails during deployment of the resource (which is enabled by default):

camunda.autoDeploy.failStartupOnError: false

Spring Boot OpenAPI + External Task Bundle

Most often you might also want to use the OpenAPI, but also leverage the Camunda External Task Client as Spring Boot Starter. To do so you can simply add this convenience library which bundles both:

    <dependency>
      <groupId>org.camunda.community</groupId>
      <artifactId>camunda-engine-rest-client-complete-springboot-starter</artifactId>
      <version>7.20.0</version>
    </dependency>

Now you further simply add workers, for example:

@Configuration
@ExternalTaskSubscription("check-number")
public class ExampleCheckNumberWorker implements ExternalTaskHandler {

    private final static Logger LOGGER = Logger.getLogger(ExampleCheckNumberWorker.class.getName());

    @Override
    public void execute(ExternalTask externalTask, ExternalTaskService externalTaskService) {
      // ...
      externalTaskService.complete(externalTask);
    }