Este contenido no está disponible en el idioma seleccionado.
Chapter 2. Decision Server Java client API for KIE containers and business assets
Red Hat Decision Manager provides a Decision Server Java client API that enables you to connect to Decision Server using REST protocol from your Java client application. You can use the Decision Server Java client API as an alternative to the Decision Server REST API to interact with your KIE containers and business assets (such as business rules, processes, and solvers) in Red Hat Decision Manager without using the Business Central user interface. This API support enables you to maintain your Red Hat Decision Manager resources more efficiently and optimize your integration and development with Red Hat Decision Manager.
With the Decision Server Java client API, you can perform the following actions also supported by the Decision Server REST API:
- Deploy or dispose KIE containers
- Retrieve and update KIE container information
- Return Decision Server status and basic information
- Retrieve and update business asset information
- Execute business assets (such as rules and processes)
Decision Server Java client API requests require the following components:
- Authentication
The Decision Server Java client API requires HTTP Basic authentication for the user role
kie-server
. To view configured user roles for your Red Hat Decision Manager distribution, navigate to~/$SERVER_HOME/standalone/configuration/application-roles.properties
and~/application-users.properties
.To add a user with the
kie-server
role, navigate to~/$SERVER_HOME/bin
and run the following command:./add-user.sh -a --user <USERNAME> --password <PASSWORD> --role kie-server
$ ./add-user.sh -a --user <USERNAME> --password <PASSWORD> --role kie-server
Copy to Clipboard Copied! Toggle word wrap Toggle overflow For more information about user roles and Red Hat Decision Manager installation options, see Planning a Red Hat Decision Manager installation.
- Project dependencies
The Decision Server Java client API requires the following dependencies on the relevant classpath of your Java project:
Copy to Clipboard Copied! Toggle word wrap Toggle overflow The
<version>
for Red Hat Decision Manager dependencies is the Maven artifact version for Red Hat Decision Manager currently used in your project (for example, 7.26.0.Final-redhat-00005).NoteInstead of specifying a Red Hat Decision Manager
<version>
for individual dependencies, consider adding the Red Hat Business Automation bill of materials (BOM) dependency to your projectpom.xml
file. The Red Hat Business Automation BOM applies to both Red Hat Decision Manager and Red Hat Process Automation Manager. When you add the BOM files, the correct versions of transitive dependencies from the provided Maven repositories are included in the project.Example BOM dependency:
Copy to Clipboard Copied! Toggle word wrap Toggle overflow For more information about the Red Hat Business Automation BOM, see What is the mapping between RHDM product and maven library version?.
- Client request configuration
All Java client requests with the Decision Server Java client API must define at least the following server communication components:
-
Credentials of the
kie-server
user -
Decision Server location, such as
http://localhost:8080/kie-server/services/rest/server
- Marshalling format for API requests and responses (JSON, JAXB, or XSTREAM)
-
A
KieServicesConfiguration
object and aKieServicesClient
object, which serve as the entry point for starting the server communication using the Java client API -
A
KieServicesFactory
object defining REST protocol and user access -
Any other client services used, such as
RuleServicesClient
,ProcessServicesClient
, orQueryServicesClient
The following are examples of basic and advanced client configurations with these components:
Basic client configuration example
Copy to Clipboard Copied! Toggle word wrap Toggle overflow Advanced client configuration example with additional client services
Copy to Clipboard Copied! Toggle word wrap Toggle overflow -
Credentials of the
2.1. Sending requests with the Decision Server Java client API Copiar enlaceEnlace copiado en el portapapeles!
The Decision Server Java client API enables you to connect to Decision Server using REST protocol from your Java client application. You can use the Decision Server Java client API as an alternative to the Decision Server REST API to interact with your KIE containers and business assets (such as business rules, processes, and solvers) in Red Hat Decision Manager without using the Business Central user interface.
Prerequisites
- Decision Server is installed and running.
-
You have
kie-server
user role access to Decision Server. - You have a Java project with Red Hat Decision Manager resources.
Procedure
In your client application, ensure that the following dependencies have been added to the relevant classpath of your Java project:
Copy to Clipboard Copied! Toggle word wrap Toggle overflow -
Download the Red Hat Decision Manager 7.5.1 Source Distribution from the Red Hat Customer Portal and navigate to
~/rhdm-7.5.1-sources/src/droolsjbpm-integration-$VERSION/kie-server-parent/kie-server-remote/kie-server-client/src/main/java/org/kie/server/client
to access the Decision Server Java clients. -
In the
~/kie/server/client
folder , identify the relevant Java client for the request you want to send, such asKieServicesClient
to access client services for KIE containers and other assets in Decision Server. In your client application, create a
.java
class for the API request. The class must contain the necessary imports, Decision Server location and user credentials, aKieServicesClient
object, and the client method to execute, such ascreateContainer
anddisposeContainer
from theKieServicesClient
client. Adjust any configuration details according to your use case.Creating and disposing a container
Copy to Clipboard Copied! Toggle word wrap Toggle overflow You define service responses using the
org.kie.server.api.model.ServiceResponse<T>
object, whereT
represents the type of returned response. TheServiceResponse
object has the following attributes:-
String message
: Returns the response message -
ResponseType type
: Returns eitherSUCCESS
orFAILURE
-
T result
: Returns the requested object
In this example, when you dispose a container, the
ServiceResponse
returns aVoid
response. When you create a container, theServiceResponse
returns aKieContainerResource
object.NoteA conversation between a client and a specific Decision Server container in a clustered environment is secured by a unique
conversationID
. TheconversationID
is transferred using theX-KIE-ConversationId
REST header. If you update the container, unset the previousconversationID
. UseKieServiesClient.completeConversation()
to unset theconversationID
for Java API.-
Run the configured
.java
class from your project directory to execute the request, and review the Decision Server response.If you enabled debug logging, Decision Server responds with a detailed response according to your configured marshalling format, such as JSON.
Example server response for a new KIE container (log):
Copy to Clipboard Copied! Toggle word wrap Toggle overflow If you encounter request errors, review the returned error code messages and adjust your Java configurations accordingly.
2.2. Supported Decision Server Java clients Copiar enlaceEnlace copiado en el portapapeles!
The following are some of the Java client services available in the org.kie.server.client
package of your Red Hat Decision Manager distribution. You can use these services to interact with related resources in Decision Server similarly to the Decision Server REST API.
-
KieServicesClient
: Used as the entry point for other Decision Server Java clients, and used to interact with KIE containers -
JobServicesClient
: Used to schedule, cancel, re-queue, and get job requests -
RuleServicesClient
: Used to send commands to the server to perform rule-related operations, such as executing rules or inserting objects into the KIE session -
SolverServicesClient
: Used to perform all Red Hat Business Optimizer operations, such as getting the solver state and the best solution, or disposing a solver
The getServicesClient
method provides access to any of these clients:
RuleServicesClient rulesClient = kieServicesClient.getServicesClient(RuleServicesClient.class);
RuleServicesClient rulesClient = kieServicesClient.getServicesClient(RuleServicesClient.class);
For the full list of available Decision Server Java clients, download the Red Hat Decision Manager 7.5.1 Source Distribution from the Red Hat Customer Portal and navigate to ~/rhdm-7.5.1-sources/src/droolsjbpm-integration-$VERSION/kie-server-parent/kie-server-remote/kie-server-client/src/main/java/org/kie/server/client
.
2.3. Example requests with the Decision Server Java client API Copiar enlaceEnlace copiado en el portapapeles!
The following are examples of Decision Server Java client API requests for basic interactions with Decision Server. For the full list of available Decision Server Java clients, download the Red Hat Decision Manager 7.5.1 Source Distribution from the Red Hat Customer Portal and navigate to ~/rhdm-7.5.1-sources/src/droolsjbpm-integration-$VERSION/kie-server-parent/kie-server-remote/kie-server-client/src/main/java/org/kie/server/client
.
- Listing Decision Server capabilities
You can use the
org.kie.server.api.model.KieServerInfo
object to identify server capabilities. TheKieServicesClient
client requires the server capability information to correctly produce service clients. You can specify the capabilities globally inKieServicesConfiguration
; otherwise they are automatically retrieved from Decision Server.Example request to return Decision Server capabilities
Copy to Clipboard Copied! Toggle word wrap Toggle overflow - Listing KIE containers in Decision Server
KIE containers are represented by the
org.kie.server.api.model.KieContainerResource
object. The list of resources is represented by theorg.kie.server.api.model.KieContainerResourceList
object.Example request to return KIE containers from Decision Server
Copy to Clipboard Copied! Toggle word wrap Toggle overflow You can optionally filter the KIE container results using an instance of the
org.kie.server.api.model.KieContainerResourceFilter
class, which is passed to theorg.kie.server.client.KieServicesClient.listContainers()
method.Example request to return KIE containers by release ID and status
Copy to Clipboard Copied! Toggle word wrap Toggle overflow - Creating and disposing KIE containers in Decision Server
You can use the
createContainer
anddisposeContainer
methods in theKieServicesClient
client to dispose and create KIE containers. In this example, when you dispose a container, theServiceResponse
returns aVoid
response. When you create a container, theServiceResponse
returns aKieContainerResource
object.Example request to dispose and re-create a KIE container
Copy to Clipboard Copied! Toggle word wrap Toggle overflow - Executing runtime commands in Decision Server
Red Hat Decision Manager supports runtime commands that you can send to Decision Server for asset-related operations, such as inserting or retracting objects in a KIE session or firing all rules. The full list of supported runtime commands is located in the
org.drools.core.command.runtime
package in your Red Hat Decision Manager instance.You can use the
org.kie.api.command.KieCommands
class to insert commands, and useorg.kie.api.KieServices.get().getCommands()
to instantiate theKieCommands
class. If you want to add multiple commands, use theBatchExecutionCommand
wrapper.Example request to insert an object and fire all rules
Copy to Clipboard Copied! Toggle word wrap Toggle overflow NoteA conversation between a client and a specific Decision Server container in a clustered environment is secured by a unique
conversationID
. TheconversationID
is transferred using theX-KIE-ConversationId
REST header. If you update the container, unset the previousconversationID
. UseKieServiesClient.completeConversation()
to unset theconversationID
for Java API.