2022-05-19 17:39:34 +02:00
2022-05-09 07:30:28 +02:00
2022-05-19 17:39:34 +02:00
2022-05-19 17:39:34 +02:00
2022-05-19 17:39:34 +02:00
2022-05-02 07:45:12 +02:00
2022-05-09 07:30:28 +02:00

Camunda DDD and Clean Architecture

An example to show how you could use clean architecture and DDD elements with Camunda.

🚀Features

The BPMN process is a tiny process just to demonstrate the architecture.

🛫Start the process

With the following POST request you could start the process:

curl --request POST \
  --url http://localhost:8080/loan/agreement/1 \
  --header 'Content-Type: application/json' \
  --data '
  "customerNumber": "A-11",
  "name": "Tester",
  "mailAddress": "tester@web.io",
  "amount": 1100
}'

Using the admin user (username: admin and password: pw) you could log in to the Camunda Cockpit.

🏗Architecture

The following sections contain some small aspects explaining the advantages of Domain-driven Design (DDD) and clean architecture.

DDD-Clean-Architecture

DDD

Using Domain-driven Design you focus on you core business domain and the domain logic. With this fact in mind you build your complex design around your domain. Keeping your domain as close to the real business as possible you need collaborate constantly with your business experts.

Beside that the focus in immutability and building object that know all about their invariants helps you to structure your code. Such DDD Elements can be found in our domain-primitives library.

Structuring your code functional and brining more context to your object with, e.g. Value Object does not only help you to keep your code expressive, it also helps keeping it close to you business as your BPMN model.

Clean

Using clean architecture as architecture style combines perfectly with Domain-driven Design because we completely focus on our domain, as shown in the image by placing it in the center.

Flexibility around your domain (switching from Camunda 7 to Camunda 8) is the main focus I want to show you in this little example.

The main advantage is the independence of any framework. Due to this fact the architecture allows (and by using the Dependency Inversion Principle), compared to the conventional layer-architecture, exchange for example you Camunda Framework. So you could migrate to Camunda 8 without even touching your business code.

The origin of clean architecture.

🙏🏼Credits

Thanks to Matthias Eschhold for the passionate discussion around DDD and clean architecture.

📨Contact

If you have any questions or ideas feel free to contact me or create an issue.

Description
An example to show how you could use clean architecture and DDD elements with Camunda.
Readme 48 MiB
Languages
Java 99.8%
Dockerfile 0.2%