Copyright (C) 2018-2025 The Open Library Foundation.
This software is distributed under the terms of the Apache License, Version 2.0. See the file "LICENSE" for more information.
- Docker deployment
- Publish docker image
- Manual Build and Run
- Camunda Module Dependencies
- Workflow Project Structure
- Camunda APIs
- Kafka Message Broker
- Issue Tracker
cd ..
git clone https://github.com/TAMULib/mod-workflow.git
cd mod-workflow
mvn clean install
cd mod-camunda
docker build -t folio/mod-camunda .
docker run -d -p 8081:8081 folio/mod-camunda
docker login [docker repo]
docker build -t [docker repo]/folio/mod-camunda:[version] .
docker push [docker repo]/folio/mod-camunda:[version]
The mod-camunda project may also be built and run directly on a local machine.
There are external services that are still needed and it is recommended that a remote OKAPI and a remote Kafka are used.
This example describes the local build and run process using an already configured local Postgresql server with already configured remote OKAPI, remote Kafka servers, and a remote (or local) mod-workflow.
This example uses environment variables to configure the mod-camunda service, however these configurations may be directly applied to the application.yml.
DB_USERNAME=folio \
DB_PASSWORD=folio \
DB_PORT=5432 \
SERVER_PORT=9000 \
OKAPI_URL=http://remote_okapi:9130 \
SPRING_JPA_HIBERNATE_DDLAUTO="update" \
CAMUNDA_BPM_DATABASE_SCHEMAUPDATE=true \
TENANT_INITIALIZEDEFAULTENANT=true \
TENANT_RECREATEDEFAULTTENANT=true \
SPRING_MAIL_PROPERTIES_MAIL_SMTP_SSL_CHECKSERVERIDENTITY=false \
TENANT_DEFAULTTENANT=diku \
KAFKA_HOST=https://remote_kafka \
KAFKA_PORT=9092 \
APPLICATION_KAFKA_LISTENER_EVENTS_TOPIC_PATTERN='folio.(.*\.)?camunda_local.events' \
APPLICATION_KAFKA_LISTENER_EVENTS_GROUPID=folio-mod-camunda_local-events-group \
mvn clean spring-boot:runThe above example explicitly defines the Postgresql database settings.
The SPRING_JPA_HIBERNATE_DDLAUTO, CAMUNDA_BPM_DATABASE_SCHEMAUPDATE, TENANT_INITIALIZEDEFAULTENANT, and TENANT_RECREATEDEFAULTTENANT environment variables are defined this way so that the database is deleted and re-created on each run. If this is not desired, then they should be set to false.
Note that the SPRING_JPA_HIBERNATE_DDLAUTO could be set to None, but update is still safe when preserving the database between runs.
The SPRING_MAIL_PROPERTIES_MAIL_SMTP_SSL_CHECKSERVERIDENTITY is only needed on a local machine because there might not be a valid mail server certificate for the local machine.
This probably should not be set to false on a production system.
The TENANT_DEFAULTTENANT is added to show that the tenant can be changed, but the default of diku is likely fine.
The APPLICATION_KAFKA_LISTENER_EVENTS_TOPIC_PATTERN and APPLICATION_KAFKA_LISTENER_EVENTS_GROUPID are provided to separate the normal Kafka messages from the local instance.
This helps ensure isolation between different systems.
It is recommended to use a unique topic pattern and group id for each local instance (as in for each developer machine running this locally).
The OKAPI_URL, KAFKA_HOST, and KAFKA_PORT are standard server configuration variables for the remote systems.
The values assigned to these are for example purposes and likely will not work without being changed to a proper address.
The SERVER_PORT is provided because the mod-workflow might be run on the same local machine.
They both default to port 8081 and that could be changed to something like 9000 to prevent conflicts.
The OKAPI_URL may be changed to point directly to a local mod-workflow to bypass OKAPI.
This can help make development easier in certain situations.
In such a case, this could be set to the local mod-workflow instance, such as OKAPI_URL=http://localhost:9001.
This module depends on spring-module-core and brings in Camunda BPM to enable workflow capabilities. Camunda is an open-source BPM platform that is embedded in this module. The pom.xml described these versions and dependencies.
camunda-bpm-spring-boot-starter- Adds the Camunda engine.
- https://docs.camunda.org/manual/develop/user-guide/spring-boot-integration/
- https://github.com/camunda/camunda-bpm-spring-boot-starter
- The Camunda engine requires a database schema to be configured on startup.
- Details on the process engine database schema configuration can be found in the spring boot integration configuration.
camunda-bpm-spring-boot-starter-webapp- Enables Web Applications such as Camunda Cockpit and Tasklist.
- https://docs.camunda.org/manual/develop/user-guide/spring-boot-integration/webapps/
camunda-bpm-spring-boot-starter-rest- Enables the Camunda REST API.
- https://docs.camunda.org/manual/develop/user-guide/spring-boot-integration/rest-api/
- https://docs.camunda.org/manual/latest/reference/rest/
- The Camunda REST API uses Jersey so we use spring boot's common application properties to configure the path to be /camunda in the application.yml file.
spring.jersey.application-path=camunda
Business Process Models and Decision Models are built using the Camunda Modeler which implements BPMN 2.0 and DMN 1.1 specifications.
The UI module ui-workflow provides a way to facilitate building, activating, and running individual workflows.
Any Java code that is executed in the context of a process is usually written in a Java Delegate.
These classes are stored in src/main/java/org/folio/rest/camunda/delegate.
- Start
mod-camundaeither through the Docker interface or through the manualmvn clean spring-boot:runcommand. - Navigate to the Camunda Portal, such as
https://localhost:9000/ui/welcome/default/#/welcomefor a local execution. - Log in as admin user:
admin, password:admin(which can be changed using environment variables or by tweaking theapplication.ymlfile).
The module descriptor template describes the available end points provided by mod-camunda.
This template is used to build the module descriptor when building the package or starting the local server.
This end point described by this template can be found via appropriate FOLIO interfaces, such what Stripes UI may provide.
The following are example end points:
- Process/Decision Deployment
- https://docs.camunda.org/manual/latest/reference/rest/deployment/
GET/camunda/deployment/camunda/deployment/{id}
POST/camunda/deployment/create
DELETE/camunda/deployment/{id}
- Process Definition
- https://docs.camunda.org/manual/latest/reference/rest/process-definition/
GET/camunda/process-definition/camunda/process-definition/{id}
POST/camunda/process-definition/{id}/start/camunda/process-definition/key/{key}/tenant-id/{tenant-id}/start
- Decision Definition
- https://docs.camunda.org/manual/latest/reference/rest/decision-definition/
GET/camunda/decision-definition/camunda/decision-definition/{id}
- Tasks
- https://docs.camunda.org/manual/latest/reference/rest/task/
GET/camunda/task/camunda/task/{id}
POST/camunda/task/{id}/claim/camunda/task/{id}/unclaim/camunda/task/{id}/complete
- Message Events
- https://docs.camunda.org/manual/latest/reference/rest/message/
POST/camunda/message
The message broker being used is the standard FOLIO message broker called Apache Kafka, which is called Kafka for brevity.
The trigger entity from mod-workflow is used to select which request-response events from Okapi are to be published to the ${ENV:folio}.workflow.events topic that mod-camunda can subscribe to. In order to create the Triggers we have to provide the correct permissions to the diku_admin. The vagrant will create an example trigger for when a user is created.
The most notable environment variables for deployment are described in the Module Descriptor template.
The following is a summary of many of them.
| Name | Default value | Description |
|---|---|---|
| CAMUNDA_BPM_ADMINUSER_EMAIL | admin@localhost |
The e-mail address of the Camunda administration user. |
| CAMUNDA_BPM_ADMINUSER_ID | admin | The account name of the Camunda administration user. |
| CAMUNDA_BPM_ADMINUSER_PASSWORD | admin | The password of the Camunda administration user. |
| CAMUNDA_BPM_DATABASE_SCHEMAUPDATE | true | If Camunda should auto-update the BPM database schema (may result in dropping existing data). |
| CAMUNDA_BPM_METRICS | false | Enable or disable Camunda metrics by default. |
| DB_CHARSET | UTF-8 | Database charset. |
| DB_DATABASE | okapi_modules | Postgres database name. |
| DB_HOST | postgres | Postgres host name. |
| DB_MAXPOOLSIZE | 5 | Database max pool size. |
| DB_PASSWORD | folio_admin | Postgres user password (be sure to change this). |
| DB_PORT | 5432 | Postgres port. |
| DB_QUERYTIMEOUT | 60000 | Database query timeout. |
| DB_USERNAME | folio_admin | Postgres user name. |
| JAVA_OPTIONS | -XX:MaxRAMPercentage=75.0 |
Java options. |
| KAFKA_HOST | kafka | Kafka broker host name. |
| KAFKA_PORT | 9092 | Kafka broker port. |
| KAFKA_SECURITY_PROTOCOL | PLAINTEXT | Kafka security protocol used to communicate with brokers (SSL or PLAINTEXT). |
| KAFKA_SSL_KEYSTORE_LOCATION | - | The location of the Kafka key store file. This is optional for client and can be used for two-way authentication for client. |
| KAFKA_SSL_KEYSTORE_PASSWORD | - | The store password for the Kafka key store file. This is optional for client and only needed if ssl.keystore.location is configured. |
| KAFKA_SSL_TRUSTSTORE_LOCATION | - | The location of the Kafka trust store file. |
| KAFKA_SSL_TRUSTSTORE_PASSWORD | - | The password for the Kafka trust store file. If a password is not set, trust store file configured will still be used, but integrity checking is disabled. |
| OKAPI_URL | http://okapi:9130 |
OKAPI URL used to login system user, required (can be used to point directly to mod-workflow). |
| OKAPI_AUTH_ACCESSCOOKIENAME | folioAccessToken |
The OKAPI cookie name for the Access token; This is generally never changed. |
| OKAPI_AUTH_REFRESHCOOKIENAME | folioRefreshToken |
The OKAPI cookie name for the Refresh token; This is generally never changed. |
| OKAPI_AUTH_TOKENHEADERNAME | x-okapi-token |
The OKAPI header token name; This is generally never changed. |
| SERVER_PORT | 8081 | The port the mod-camunda service listens on. |
| SERVER_SERVLET_CONTEXTPATH | / |
The context path, or base path, to host at. |
| SPRING_FLYWAY_ENABLED | false | Database migration support via Spring Flyway. |
| SPRING_JPA_HIBERNATE_DDLAUTO | update | Auto-configure database on startup. |
| TENANT_DEFAULTTENANT | diku | The name of the default tenant to use. |
| TENANT_FORCETENANT | false | Forcibly add or overwrite the tenant name using the default tenant. |
| TENANT_INITIALIZEDEFAULTENANT | true | Perform initial auto-creation of tenant in the database (schema, tables, etc..). |
| TENANT_RECREATEDEFAULTTENANT | false | When TENANT_INITIALIZEDEFAULTTENANT is true and the database already exists, then drop and re-create the database on start. |
The permissions provided by this module are described in the Module Descriptor under permissionSets.
The permissions defined here are specific to this module and are usually not directly applied to any specific user. Instead, permissions available for assignment to users (or accounts) are found in the ui-workflow Module Permission Sets. These ui-workflow permissions are automatically exposed via the appropriate Stripes UI administration interface.
See project FOLIO and the FOLIO issue tracker.