Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

getting started with spring java guide #3897

Merged
merged 25 commits into from
Jun 18, 2024
Merged
Show file tree
Hide file tree
Changes from 24 commits
Commits
Show all changes
25 commits
Select commit Hold shift + click to select a range
a8c3ffc
document prereqs
christinaausley Jun 5, 2024
ebd043d
create a spring project
christinaausley Jun 5, 2024
b133b98
create a new BPMN diagram
christinaausley Jun 5, 2024
56edb75
implement service task
christinaausley Jun 6, 2024
b5696ef
deploy
christinaausley Jun 6, 2024
8c03c20
Update docs/guides/getting-started-java-spring.md
christinaausley Jun 7, 2024
8daf45f
Update docs/guides/getting-started-java-spring.md
christinaausley Jun 7, 2024
61712b5
Update docs/guides/getting-started-java-spring.md
christinaausley Jun 7, 2024
841bfb1
style(formatting): resolve amaras comments
christinaausley Jun 10, 2024
36502c5
Update docs/guides/getting-started-java-spring.md
christinaausley Jun 11, 2024
1a7a81d
Update docs/guides/getting-started-java-spring.md
christinaausley Jun 11, 2024
b497bcb
Update docs/guides/getting-started-java-spring.md
christinaausley Jun 11, 2024
5fa3c0d
Update docs/guides/getting-started-java-spring.md
christinaausley Jun 11, 2024
733e907
Update docs/guides/getting-started-java-spring.md
christinaausley Jun 11, 2024
f863a97
Update docs/guides/getting-started-java-spring.md
christinaausley Jun 11, 2024
40fa152
Update docs/guides/getting-started-java-spring.md
christinaausley Jun 11, 2024
1eff780
Update docs/guides/getting-started-java-spring.md
christinaausley Jun 11, 2024
ea33850
Update docs/guides/getting-started-java-spring.md
christinaausley Jun 11, 2024
3fdbd16
Update docs/guides/getting-started-java-spring.md
christinaausley Jun 11, 2024
c416a75
Update docs/guides/getting-started-java-spring.md
christinaausley Jun 11, 2024
96b2166
resolve initial comments from steve
christinaausley Jun 11, 2024
e511023
adjust steps for code
christinaausley Jun 11, 2024
72ee1e5
backport and add to sidebar
christinaausley Jun 11, 2024
89e570d
Merge branch 'main' into getting-started-spring-java
christinaausley Jun 11, 2024
63d3b18
resolve steve's comments
christinaausley Jun 12, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
249 changes: 249 additions & 0 deletions docs/guides/getting-started-java-spring.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,249 @@
---
id: getting-started-java-spring
title: Getting started as a Java developer using Spring
sidebar_label: Getting started as a Java developer using Spring
description: "Use Spring Boot and the Spring Zeebe SDK to interact with your local Self-Managed Camunda 8 installation."
keywords: [java, spring, spring zeebe, getting started, user guide, tutorial]
---

<span class="badge badge--beginner">Beginner</span>
<span class="badge badge--medium">1 hour</span>

In this guide, we'll step through using Spring Boot and the [Spring Zeebe SDK](/apis-tools/spring-zeebe-sdk/getting-started.md) with Desktop Modeler to interact with your local Self-Managed Camunda 8 installation.

By the end of this tutorial, you'll be able to use Spring and Java code with Zeebe to:

- Deploy a process model.
- Initiate a process instance.
- Handle a service task.

For example, in this guide we will outline a BPMN model to receive a payment request, prepare a transaction, charge a credit card, and execute a payment:

![example BPMN model to receive a payment request, prepare a transaction, charge a credit card, and execute a payment](./img/prepare-transaction-example.png)

:::note
This tutorial is not intended for production purposes.
:::

## Prerequisites

Before getting started, ensure you:

- Can access your preferred code editor or IDE.
- Have Java [installed locally](https://www.java.com/en/download/). Currently, the Spring Initializr supports Java versions 17, 21, and 22.
- Have [Docker Desktop](https://www.docker.com/products/docker-desktop/) installed locally.
- Install [Desktop Modeler](https://camunda.com/download/modeler/).
christinaausley marked this conversation as resolved.
Show resolved Hide resolved

## Step 1: Install Camunda 8 Self-Managed

If you haven't already, follow [this guide](/self-managed/setup/deploy/local/docker-compose.md) to install Camunda 8 Self-Managed locally via Docker Compose:

1. Use the `docker-compose.yaml` file in [this repository](https://github.com/camunda/camunda-platform).
2. Clone this repo and run `docker compose up -d` in your terminal to start your environment.

To confirm Camunda 8 Self-Managed is installed, click into Docker Desktop. Here, you will see the `camunda-platform` container. Alternatively, navigate to the different components and log in with the username `demo` and password `demo`. For example, Operate can be accessed at [http://localhost:8081](http://localhost:8081) (as noted under **Port(s)** in the Docker container). Find additional guidance in the repository [README](https://github.com/camunda/camunda-platform?tab=readme-ov-file#using-docker-compose).

## Step 2: Create a new Spring Boot project

Next, create a new Spring Boot project:

1. Go to [https://start.spring.io/](https://start.spring.io/) to get started.
2. Under **Project**, select **Maven**. Under **Language**, select **Java**. Under **Spring Boot**, select the latest non-SNAPSHOT version (currently 3.3.0).
3. Under **Project Metadata**, configure the following:
1. **Group**: `io.camunda.demo`
2. **Artifact**: `process_payments`
3. **Name**: `Process payments`
4. **Description**: `Process payments with Camunda`
5. **Package name**: `io.camunda.demo.process_payments`
6. **Packaging**: `Jar`
7. **Java**: Select the Java version you have installed.
christinaausley marked this conversation as resolved.
Show resolved Hide resolved
8. For this tutorial, we will not install any dependencies.
4. Click **Generate**.
5. Download the project, extract the `.zip` file, and add the contents to your desired location.
6. Open this project in your preferred code editor.
7. Run `mvn spring-boot:run` in your terminal to confirm your Spring project builds.
8. (Optional) Run `git init` if you'd like to commit milestones along the way, and add a `.gitignore` file containing `target/` to ignore build artifacts.

## Step 3: Create a new BPMN diagram

Next, we'll create a BPMN diagram to represent the transaction model shown at the beginning of this guide:

1. Open Desktop Modeler.
2. Click **Create a new diagram** in Camunda 8, and name your diagram `Process payments` with an id of `process-payments`.
3. Add a start event, and name it `Payment request received`.
4. Append a task named `Prepare transaction`.
5. Click the wrench-shaped change type context menu icon to change the type of task to a script task, and configure the following properties:
1. **Implementation**: `FEEL expression`
2. **Script/Result variable**: `totalWithTax`
3. **Script/FEEL expression**: `total * 1.1` (this represents the tax applied to the transaction.)
6. Append a task named `Charge credit card`.
7. Click on the task and click the wrench-shaped icon to change the type of task to a service task. In the properties panel, change the **Task definition/Type** to `charge-credit-card`.
8. Append an end event named `Payment executed`.
9. Save this BPMN file to your Spring project in `src/main/resources`, and name it `process-payments.bpmn`.

## Step 4: Deploy your process

To deploy your process, take the following steps:

1. Open Desktop Modeler and click the rocket icon in the bottom left corner.
2. Change the **Deployment name** to `process-payments`, and ensure the **Target** is `Camunda 8 Self-Managed`.
3. Change the **Cluster endpoint** to `http://localhost:26500/`, with no authentication.
4. Click **Deploy**.

When you open Operate at http://localhost:8081/, you should now note the process deployed to your local Self-Managed setup.

## Step 5: Run your process from Modeler

To run your process, take the following steps:

1. From Desktop Modeler, click the "play" icon (next to the rocket icon to deploy) in the bottom left corner.
2. In **Variables**, insert the JSON object `{"total": 100}`.
3. Click **Start**.

From Operate, you should now notice a process instance running. You'll notice the process instance is waiting at **Charge credit card**, because we'll need to configure a job worker.

## Step 6: Implement a service task

To implement a service task, take the following steps:

### Configure Spring Boot Starter

See our documentation on [adding the Spring Zeebe SDK to your project](/apis-tools/spring-zeebe-sdk/getting-started.md#add-the-spring-zeebe-sdk-to-your-project) for more details, also described below:

1. Copy the following code snippet into the `pom.xml` file of your Spring project, below properties and above dependencies:

```
<repositories>
<repository>
<releases>
<enabled>true</enabled>
</releases>
<snapshots>
<enabled>false</enabled>
</snapshots>
<id>identity</id>
<name>Camunda Identity</name>
<url>https://artifacts.camunda.com/artifactory/camunda-identity/</url>
</repository>
</repositories>
```

2. Add the following dependency to your `pom.xml` file:

```
<dependency>
<groupId>io.camunda</groupId>
<artifactId>spring-boot-starter-camunda-sdk</artifactId>
<version>8.5.0</version>
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

(no changes)

Ah, cool -- we are telling them to use 8.5.0, which definitely does not include the upcoming configuration changes I mentioned in Slack. (I think 8.5.2 might be where they are introduced.)

I will still follow up with updates to this version, and the configuration properties associated with it, though I can do that in a separate PR after this is merged.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Let me know if I can assist with any changes!

</dependency>
```

### Configure the Zeebe client

Open your `src/main/resources/application.properties` file, and paste the following snippet to connect to the Self-Managed Zeebe broker:

```
zeebe.client.broker.grpcAddress=http://127.0.0.1:26500
zeebe.client.broker.restAddress=http://127.0.0.1:8080
zeebe.client.security.plaintext=true
```

### Create a worker

1. In `src/main/java/io/camunda/demo/process_payments/`, create a file called `ChargeCreditCardWorker.java`.
2. In the file created above, paste the following dependencies and package `package io.camunda.demo.process_payments`:

```java
package io.camunda.demo.process_payments;

import java.util.Map;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;

import io.camunda.zeebe.spring.client.annotation.JobWorker;
import io.camunda.zeebe.spring.client.annotation.Variable;
```

3. Next, we can decorate our class with `@Component` and instantiate a logger. Additionally, we will add a method and decorate the `chargeCreditCard` method with `@JobWorker`, and specify a `@Variable(name = "totalWithTax") Double totalWithTax` argument into the `chargeCreditCard` method we'll implement:
christinaausley marked this conversation as resolved.
Show resolved Hide resolved

```java
@Component
public class ChargeCreditCardWorker {

// Instantiate a logger
private final static Logger LOG = LoggerFactory.getLogger(ChargeCreditCardWorker.class);

// Add the following method, and decorate `chargeCreditCard` with `@JobWorker`
@JobWorker(type = "charge-credit-card")

// Specify a `@Variable(name = "totalWithTax") Double totalWithTax` argument into the `chargeCreditCard` method
public Map<String, Double> chargeCreditCard(@Variable(name = "totalWithTax") Double totalWithTax) {

// Implement the method
LOG.info("charging credit card: {}", totalWithTax);

return Map.of("amountCharged", totalWithTax);
pepopowitz marked this conversation as resolved.
Show resolved Hide resolved
}
}
christinaausley marked this conversation as resolved.
Show resolved Hide resolved
```

:::note
To check your work, visit our [sample repository](https://github.com/camunda/camunda-8-get-started-spring/blob/main/src/main/java/io/camunda/demo/process_payments/ChargeCreditCardWorker.java) with the completed code.
:::

In your terminal, run `mvn spring-boot:run`, where you should see the `charging credit card` output. In Operate, refresh if needed, and note the payment has executed.

## Step 7: Start a process instance

christinaausley marked this conversation as resolved.
Show resolved Hide resolved
To start a process instance programmatically, take the following steps:

1. In `ProcessPaymentsApplication.java`, instantiate a static logger and declare `zeebeClient` with the `@Autowired` annotation. To convert the application to a `CommandLineRunner`, add `implements CommandLineRunner` to the class declaration `public class ProcessPaymentsApplication implements CommandLineRunner`.
christinaausley marked this conversation as resolved.
Show resolved Hide resolved

```java
@SpringBootApplication
@Deployment(resources = "classpath:process-payments.bpmn")
public class ProcessPaymentsApplication implements CommandLineRunner {

christinaausley marked this conversation as resolved.
Show resolved Hide resolved
private static final Logger LOG = LoggerFactory.getLogger(ProcessPaymentsApplication.class);

@Autowired
private ZeebeClient zeebeClient;

public static void main(String[] args) {
SpringApplication.run(ProcessPaymentsApplication.class, args);
}
}
```

2. Implement an overriding `run` method:
christinaausley marked this conversation as resolved.
Show resolved Hide resolved

```java
@Override
public void run(final String... args) {
var processDefinitionKey = "process-payments";
var event = zeebeClient.newCreateInstanceCommand()
.bpmnProcessId(processDefinitionKey)
.latestVersion()
.variables(Map.of("total", 100))
.send()
.join();
LOG.info(String.format("started a process: %d", event.getProcessInstanceKey()));
}
christinaausley marked this conversation as resolved.
Show resolved Hide resolved
```

:::note
To check your work, visit our [sample repository](https://github.com/camunda/camunda-8-get-started-spring/blob/main/src/main/java/io/camunda/demo/process_payments/ProcessPaymentsApplication.java) with the completed code.
:::

Re-run the application in your terminal with `mvn spring-boot:run` to see the process run, and note the instance history in Operate.

## Step 8: Deploy the process

To deploy your process, take the following steps:

1. Decorate the `ProcessPaymentsApplication` class with `@Deployment(resources = "classpath:process-payments.bpmn")` in `ProcessPaymentsApplication.java`:
2. In Desktop Modeler, change the tax amount calculated to `total * 1.2` under **FEEL expression** and save your changes.

Re-run the application in your terminal with `mvn spring-boot:run` to see the process run. In Operate, note the new version `2` when filtering process instances, and the tax amount has increased for the most recent process instance.
Binary file added docs/guides/img/prepare-transaction-example.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
1 change: 1 addition & 0 deletions sidebars.js
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ module.exports = {
"guides/orchestrate-human-tasks",
"guides/orchestrate-apis",
"guides/orchestrate-microservices",
"guides/getting-started-java-spring",
],
},
{
Expand Down
Loading
Loading