Chapter 5. Red Hat Process Automation Manager Spring Boot configuration
After you create your Spring Boot project, you can configure several components to customize your application.
5.1. Configuring REST endpoints for Spring Boot applications Copy linkLink copied to clipboard!
After you create your Spring Boot project, you can configure the host, port, and path for the REST endpoint for your Spring Boot application.
Prerequisites
- You have a ZIP file that you created using the business application website.
Procedure
-
Extract the Spring Boot project ZIP file and navigate to the
<BUSINESS-APPLICATION>/<BUSINESS-APPLICATION>-service/src/main/resourcesfolder, where<BUSINESS-APPLICATION>is the name of your Spring Boot project. -
Open the
application.propertiesfile in a text editor. Configure the host, port, and path for the REST endpoints, where
<ADDRESS>is the server address and<PORT>is the server port:server.address=<ADDRESS> server.port=<PORT> cxf.path=/rest
server.address=<ADDRESS> server.port=<PORT> cxf.path=/restCopy to Clipboard Copied! Toggle word wrap Toggle overflow The following example adds the REST endpoint to the address
localhoston port8090.server.address=localhost server.port=8090 cxf.path=/rest
server.address=localhost server.port=8090 cxf.path=/restCopy to Clipboard Copied! Toggle word wrap Toggle overflow
5.2. Configuring the KIE Server identity Copy linkLink copied to clipboard!
After you create your Spring Boot project, you can configure KIE Server so that it can be easily identified.
Prerequisites
- You have a Spring Boot business application ZIP file that you created using the business application website.
Procedure
-
Extract the Spring Boot project ZIP file and navigate to the
<BUSINESS-APPLICATION>/<BUSINESS-APPLICATION>-service/src/main/resourcesfolder, where<BUSINESS-APPLICATION>is the name of your Spring Boot project. -
Open the
application.propertiesfile in a text editor. Configure the KIE Server parameters as shown in the following example:
kieserver.serverId=<BUSINESS-APPLICATION>-service kieserver.serverName=<BUSINESS-APPLICATION>-service kieserver.location=http://localhost:8090/rest/server kieserver.controllers=http://localhost:8080/business-central/rest/controller
kieserver.serverId=<BUSINESS-APPLICATION>-service kieserver.serverName=<BUSINESS-APPLICATION>-service kieserver.location=http://localhost:8090/rest/server kieserver.controllers=http://localhost:8080/business-central/rest/controllerCopy to Clipboard Copied! Toggle word wrap Toggle overflow The following table describes the KIE Server parameters that you can configure in your business project:
Expand Table 5.1. kieserver parameters Parameter Values Description kieserver.serverIdstring
The ID used to identify the business application when connecting to the Process Automation Manager controller.
kieserver.serverNamestring
The name used to identify the business application when it connects to the Process Automation Manager controller. Can be the same string used for the
kieserver.serverIdparameter.kieserver.locationURL
Used by other components that use the REST API to identify the location of this server. Do not use the location as defined by
server.addressandserver.port.kieserver.controllersURLs
A comma-separated list of controller URLs.
5.3. Integrating Apache Kafka with your Red Hat Process Automation Manager Spring Boot project Copy linkLink copied to clipboard!
Apache Kafka is a distributed data streaming platform that can publish, subscribe to, store, and process streams of records in real time. It is designed to handle data streams from multiple sources and deliver them to multiple consumers. Apache Kafka is an alternative to a traditional enterprise messaging system.
You can integrate Apache Kafka with your Red Hat Process Automation Manager Spring Boot project.
Prerequisites
- You have an existing Red Hat Process Automation Manager Spring Boot project.
Procedure
-
In your Spring Boot project directory, open the
business-application-service/src/main/resources/application.propertiesfile. Add the
kieserver.kafka.enabledsystem property with valuetrue:kieserver.kafka.enabled=true
kieserver.kafka.enabled=trueCopy to Clipboard Copied! Toggle word wrap Toggle overflow
Additional resources
5.4. Configuring KIE Server components to start at runtime Copy linkLink copied to clipboard!
If you selected Business Automation when you created your Spring Boot business application, you can specify which KIE Server components must start at runtime.
Prerequisites
- You have a Spring Boot business application ZIP file that you created using the business application website.
Procedure
-
Extract the Spring Boot project ZIP file and navigate to the
<BUSINESS-APPLICATION>/<BUSINESS-APPLICATION>-service/src/main/resourcesfolder, where<BUSINESS-APPLICATION>is the name of your Spring Boot project. -
Open the
application.propertiesfile in a text editor. To set a component to start at runtime, set the value of the component to
true.The following table lists the components that you can set to start at runtime:
Expand Table 5.2. kieserver capabilities parameters Parameter Values Description kieserver.drools.enabledtrue, falseEnables or disables the Decision Manager component.
kieserver.dmn.enabledtrue, falseEnables or disables the Decision Model and Notation (DMN) component.
kieserver.jbpm.enabledtrue, falseEnables or disables the Red Hat Process Automation Manager component.
kieserver.jbpmui.enabledtrue, falseEnables or disables the Red Hat Process Automation Manager UI component.
kieserver.casemgmt.enabledtrue, falseEnables or disables the case management component.
5.5. Configuring your Spring Boot application for asynchronous execution Copy linkLink copied to clipboard!
After you create your Spring Boot project, you can use the jbpm.executor parameters to enable asynchronous execution.
Prerequisites
- You have a Spring Boot business application ZIP file that you created using the business application website.
Procedure
-
Extract the Spring Boot project ZIP file and navigate to the
<BUSINESS-APPLICATION>/<BUSINESS-APPLICATION>-service/src/main/resourcesfolder, where<BUSINESS-APPLICATION>is the name of your Spring Boot project. -
Open the
application.propertiesfile in a text editor. To enable asynchronous execution, set the value of the
jbpm.executor.enabledparameter totrue, uncomment the otherjbpm.executorparameters, and change the values as required, as shown in the following example:jbpm.executor.enabled=true jbpm.executor.retries=5 jbpm.executor.interval=0 jbpm.executor.threadPoolSize=1 jbpm.executor.timeUnit=SECONDS
jbpm.executor.enabled=true jbpm.executor.retries=5 jbpm.executor.interval=0 jbpm.executor.threadPoolSize=1 jbpm.executor.timeUnit=SECONDSCopy to Clipboard Copied! Toggle word wrap Toggle overflow The following table describes the executor parameters that you can configure in your business project:
Expand Table 5.3. Executor parameters Parameter Values Description jbpm.executor.enabledtrue, falseDisables or enables the executor component.
jbpm.executor.retriesinteger
Specifies the number of retries if errors occur while a job is running.
jbpm.executor.intervalinteger
Specifies the length of time that the executor uses to synchronize with the database. The unit of time is specified by the
jbpm.executor.timeUnitparameter. Disabled by default (value0).jbpm.executor.threadPoolSizeinteger
Specifies the thread pool size.
jbpm.executor.timeUnitstring
Specifies the time unit used to calculate the interval that the executor uses to synchronize with the database. The value must be a valid constant of
java.util.concurrent.TimeUnit. The default value isSECONDS.
5.6. Configuring the business application for a cluster using Quartz Copy linkLink copied to clipboard!
If you plan to run your application in a cluster, you must configure the Quartz timer service.
Prerequisites
- You have a ZIP file that you created using the business application website, that you want to use in a cluster.
Procedure
Create the
quartz.propertiesfile and add the following content:Copy to Clipboard Copied! Toggle word wrap Toggle overflow NoteData source names in the Quartz configuration file refer to Spring beans. The connection provider must be set to
org.jbpm.springboot.quartz.SpringConnectionProviderto enable integration with Spring-based data sources.To enable the Quartz clustered timers and set the path of the
quartz.propertiesfile that you created in the previous step, include the following properties in the<BUSINESS-APPLICATION>/<BUSINESS-APPLICATION>-service/src/main/resourcesapplication.propertiesfile, where<BUSINESS-APPLICATION>is the name of your Spring Boot project.jbpm.quartz.enabled=true jbpm.quartz.configuration=quartz.properties
jbpm.quartz.enabled=true jbpm.quartz.configuration=quartz.propertiesCopy to Clipboard Copied! Toggle word wrap Toggle overflow Create a managed and an unmanaged data source by adding the following content to the
<BUSINESS-APPLICATION>/<BUSINESS-APPLICATION>-service/src/main/resources/application.propertiesfile:Copy to Clipboard Copied! Toggle word wrap Toggle overflow In the preceding example, replace
<QUARTZ_TABLES_H2>with the name of a Quartz H2 database schema script. The last three lines of the preceding configuration initialize the database schema.
By default, Quartz requires two data sources:
- Managed data source to participate in the transaction of the decision engine or process engine
- Unmanaged data source to look up timers to trigger without any transaction handling
Red Hat Process Automation Manager business applications assume that the Quartz database (schema) will be co-located with Red Hat Process Automation Manager tables and therefore produce data sources used for transactional operations for Quartz.
The other (non transactional) data source must be configured but it should point to the same database as the main data source.
5.7. Configuring business application user group providers Copy linkLink copied to clipboard!
With Red Hat Process Automation Manager, you can manage human-centric activities. To provide integration with user and group repositories, you can use two KIE API entry points:
-
UserGroupCallback: Responsible for verifying whether a user or group exists and for collecting groups for a specific user -
UserInfo: Responsible for collecting additional information about users and groups, for example email addresses and preferred language
You can configure both of these components by providing alternative code, either code provided out of the box or custom developed code.
For the UserGroupCallback component, retain the default implementation because it is based on the security context of the application. For this reason, it does not matter which backend store is used for authentication and authorisation (for example, RH-SSO). It will be automatically used as a source of information for collecting user and group information.
The UserInfo component is a separate component because it collects more advanced information.
Prerequisites
- You have a ZIP file that you created using the business application website and that contains a business automation project.
Procedure
To provide an alternative implementation of
UserGroupCallback, add the following code to the Application class or a separate class annotated with@Configuration:@Bean(name = "userGroupCallback") public UserGroupCallback userGroupCallback(IdentityProvider identityProvider) throws IOException { return new MyCustomUserGroupCallback(identityProvider); }@Bean(name = "userGroupCallback") public UserGroupCallback userGroupCallback(IdentityProvider identityProvider) throws IOException { return new MyCustomUserGroupCallback(identityProvider); }Copy to Clipboard Copied! Toggle word wrap Toggle overflow To provide an alternative implementation of
UserInfo, add the following code to the Application class or a separate class annotated with@Configuration:@Bean(name = "userInfo") public UserInfo userInfo() throws IOException { return new MyCustomUserInfo(); }@Bean(name = "userInfo") public UserInfo userInfo() throws IOException { return new MyCustomUserInfo(); }Copy to Clipboard Copied! Toggle word wrap Toggle overflow
5.8. Configuring a Spring Boot project with a MySQL or PostgreSQL database Copy linkLink copied to clipboard!
Red Hat Process Automation Manager business applications are generated with the default H2 database. You can change the database type to MySQL or PostgreSQL.
Prerequisites
- You have a Spring Boot application file that you created using the business applications website.
Procedure
-
Extract the Spring Boot project ZIP file and navigate to the
<BUSINESS-APPLICATION>/<BUSINESS-APPLICATION>-service/src/main/resourcesfolder, where<BUSINESS-APPLICATION>is the name of your Spring Boot project. -
Open the
application.propertiesfile in a text editor. Configure your Spring Boot project to use a MySQL or PostgreSQL, complete one of the following set of steps:
To configure your business application to use a MySQL database, locate the following parameters in the
application.propertiesfile and change the values as shown:Copy to Clipboard Copied! Toggle word wrap Toggle overflow To configure your business application to use a PostgreSQL database, locate the following parameters in the
application.propertiesfile and change the values as shown:Copy to Clipboard Copied! Toggle word wrap Toggle overflow NoteTo create a PostgreSQL schema that uses the
byteacolumn type instead of theoidcolumn type, set the value of theorg.kie.persistence.postgresql.useByteaproperty totrue:org.kie.persistence.postgresql.useBytea=true
org.kie.persistence.postgresql.useBytea=trueCopy to Clipboard Copied! Toggle word wrap Toggle overflow
-
Save the
application.propertiesfile.
5.9. Configuring business applications for JPA Copy linkLink copied to clipboard!
The Java Persistence API (JPA) is a standard technology that enables you to map objects to relational databases. You must configure JPA for your Red Hat Process Automation Manager business application.
Prerequisites
- You have a ZIP file that you created using the business applications website.
Procedure
-
Extract the
<BUSINESS-APPLICATION>.zipfile and navigate to the<BUSINESS-APPLICATION>/<BUSINESS-APPLICATION>-service/src/main/resourcesfolder, where<BUSINESS-APPLICATION>is the name of your Spring Boot project. -
Open the
application.propertiesfile in a text editor. Locate the following parameters in the
application.propertiesfile and verify that they have the values shown:spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.H2Dialect spring.jpa.properties.hibernate.show_sql=false spring.jpa.properties.hibernate.hbm2ddl.auto=update spring.jpa.hibernate.naming.physical-strategy=org.hibernate.boot.model.naming.PhysicalNamingStrategyStandardImpl
spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.H2Dialect spring.jpa.properties.hibernate.show_sql=false spring.jpa.properties.hibernate.hbm2ddl.auto=update spring.jpa.hibernate.naming.physical-strategy=org.hibernate.boot.model.naming.PhysicalNamingStrategyStandardImplCopy to Clipboard Copied! Toggle word wrap Toggle overflow If your business application has business automation capabilities, you can add entities to the entity manager factory by adding a comma-separated list of packages:
spring.jpa.properties.entity-scan-packages=org.jbpm.springboot.samples.entities
spring.jpa.properties.entity-scan-packages=org.jbpm.springboot.samples.entitiesCopy to Clipboard Copied! Toggle word wrap Toggle overflow Business applications with business automation capabilities create an entity manager factory based on the
persistence.xmlfile that comes with Red Hat Process Automation Manager. All entities found in theorg.jbpm.springboot.samples.entitiespackage are automatically added to the entity manager factory and used the same as any other JPA entity in the application.
Additional resources
For more information about configuring JPA, see the Spring Boot Reference Guide.
5.10. Configuring pluggable variable persistence Copy linkLink copied to clipboard!
You can provide an arbitrary entity manager for configured process variable persistence in your Red Hat Process Automation Manager Spring Boot application. To do this, add named beans during the object marshalling strategy resolution. This enables you to configure a second entity manager factory based on a second data source qualifier. Note that this configuration will not interfere with the primary data source.
Prerequisites
- You have an existing Red Hat Process Automation Manager Spring Boot project.
Procedure
Add a customized entity manager JavaBean to your java class. The following example shows an entity manager Java Bean called
auditEntityManagerfor a Java Persistence API (JPA) data source:Copy to Clipboard Copied! Toggle word wrap Toggle overflow The
auditEntityManagerbecomes an implicit context parameter when the parameters are resolved during MVFLEX Expression Language (MVEL) evaluation.Add the following marshalling stragegy to the
kie-deployment-descriptor.xmlfile:Copy to Clipboard Copied! Toggle word wrap Toggle overflow
Additional resources
- For more information about persistence, see the "Persisting process variables in a separate database schema in Red Hat Process Automation Manager" section in Managing and monitoring KIE Server.
5.11. Enabling Swagger documentation Copy linkLink copied to clipboard!
You can enable Swagger-based documentation for all endpoints available in the service project of your Red Hat Process Automation Manager business application.
Prerequisites
- You have a Spring Boot application ZIP file that you created using the business applications website.
Procedure
-
Extract the
<BUSINESS-APPLICATION>.zipfile and navigate to the<BUSINESS-APPLICATION>/<BUSINESS-APPLICATION>-servicefolder, where<BUSINESS-APPLICATION>is the name of your Spring Boot project. -
Open the service project
pom.xmlfile in a text editor. Add the following dependencies to the service project
pom.xmlfile and save the file.Copy to Clipboard Copied! Toggle word wrap Toggle overflow To enable the Swagger UI (optional), add the following dependency to the
pom.xmlfile and save the file.<dependency> <groupId>org.webjars</groupId> <artifactId>swagger-ui</artifactId> <version>2.2.10</version> </dependency>
<dependency> <groupId>org.webjars</groupId> <artifactId>swagger-ui</artifactId> <version>2.2.10</version> </dependency>Copy to Clipboard Copied! Toggle word wrap Toggle overflow -
Open the
<BUSINESS-APPLICATION>/<BUSINESS-APPLICATION>-service/src/main/resources/application.propertiesfile in a text editor. Add the following line to the
application.propertiesfile to enable Swagger support:kieserver.swagger.enabled=true
kieserver.swagger.enabled=trueCopy to Clipboard Copied! Toggle word wrap Toggle overflow
After you start the business application, you can view the Swagger document at http://localhost:8090/rest/swagger.json. The complete set of endpoints is available at http://localhost:8090/rest/api-docs?url=http://localhost:8090/rest/swagger.json.