Introduction to Fluent Rules
Authors:
Ankit Mehta, Cille Schliebitz, Anita Gu
Changed on:
4 Feb 2025
Overview
Workflow Framework Rules are written using Java and contain a specific structure and metadata for describing and validating the Rule. In this lesson, you will learn how to write Rules by adding customised business logic.
Key points
- OMX Workflow - Understand the Workflow Engine (previously 'Rubix Orchestration Engine'), Workflow Design Patterns, Workflow Builder
- Workflow Framework - Understand the Workflow Framework, Events, and Triggers.
Basic steps to create a Rule Class
Rules, which are written in Java, contain specific structure and metadata for describing and validating the Rule. The steps below should be used to write a Rule:
- Write a Java class that implements the com.fluentretail.rubix.v2.rule.Rule Interface.
- Implement the 'run' method which receives the current event context as a parameter.
- Define the Rule metadata via the @RuleInfo annotation .
- Define additional Rule metadata via the @EventAttributes and @Param* annotations.
💡 Let's take a look at an example of a Rule.
data:image/s3,"s3://crabby-images/83c3d/83c3db0a584a0edc89b860770a2e7763542ec3e6" alt="No alt provided"
Rule Interface and Actions for Rules
Rule Interface
For a Java class to be defined, as a Rule, it must implement the com.fluentretail.rubix.v2.rule.Rule interface which defines a class as a Rubix compatible executable Rule. The com.fluentretail.rubix.v2.rule.Rule provides access to the GraphQL API Client.
The Rule interface declares a run method that takes in a Context. To learn more read Rule Development Guidelines & Recommended Practices and the Write your first custom Rule using the Fluent Rules SDK (Hello World) guide.
Context parameter provides access to :
- Orchestrateable Entity e.g. context.getEntity()
- API Client e.g. context.api()
- Source Event e.g. context.getEvent()
- Rule Parameters e.g. context.getProp()
Available Actions for Rules
Rules have Actions as an output. These Actions are provided by the Rubix SDK, and handled in a very specific way by the Workflow engine. Actions are not immediately executed synchronously within the Rule's run method. They are simply queued, and executed at the end of the execution context.
context.action().<ActionName> method returns the ActionFactory which provides the supported output actions for a rule.
There are four possible Actions available to your Rules, examples for each Action are provided in the next section:
- SendEventAction: SendEventAction produces an event, however that event could be for flow control, notification of other workflows, or future-dated events.
- WebhookAction: provides an integration ability, whereby data can be sent to an external endpoint.
- MutateAction: provides an action that mutates data (create or update an entity) within the Fluent Platform
- LogAction: provides the ability to add a custom Orchestration Audit Event
To learn more read Rule Actions.
Examples of Rule Actions
Flow control
data:image/s3,"s3://crabby-images/a517d/a517dbfcbe26ba5688c8931eede74b6b176b31ad" alt="No alt provided"
Notify another workflow
data:image/s3,"s3://crabby-images/3d539/3d539b2f573071af3397f4885173f2f8d3e0227a" alt="No alt provided"
Notify another retailer
data:image/s3,"s3://crabby-images/083e5/083e57007e1e887c0163c3074f92fb56b43a0062" alt="No alt provided"
Future-dated/Scheduled
data:image/s3,"s3://crabby-images/f49dd/f49dd7aec2853fbcc63102b4f9bcb20b39973722" alt="No alt provided"
Mutate action
data:image/s3,"s3://crabby-images/a6edd/a6edd861d43a5402029695ddae088ef05f94e0e4" alt="No alt provided"
Webhook action
data:image/s3,"s3://crabby-images/33f70/33f70e90b8f071e220878758536689a65f7f5df3" alt="No alt provided"
Log action
data:image/s3,"s3://crabby-images/9c638/9c63815b599509c0a910cae03d5300e2d7543103" alt="No alt provided"
To learn more read Rule Actions, Designing Rules, and Event Context.
Rule Annotations
In this lesson, you will learn about Rule Annotations and different types of Annotations.
Annotations are used to provide additional information. It can be viewed as a tag that represents metadata like Rule class details, params, event attributes, etc.
RuleInfo Annotation
Describes the metadata for the Rule. It is important to annotate the Rule as accurately as possible.
The information in the Rule Info is used in the following ways:
- To validate the Rule for Workflow Execution.
- To provide data to display in the Workflow Builder and Rule Library.
The Rule Info includes the following properties:
- name - this is the Rule name.
- description - this is a parameterised string used to describe the behaviour of the Rule, as well as indicate what and how the Rule Parameters are used.
- accepts - this is a list of EventInfo Annotations to describe the acceptable entity types
- produces - this uses an EventInfo Annotation to describe the Event that the rule outputs
- exceptions - this is a list of RuleExecutionException classes that this rule might throw( Exception Management)
Note: The description property is also used by the Modeller to display form fields for Parameter values. It is important that all parameters defined for the rule via the @Param<Type> annotations are reflected in the description. To learn more read Rule Info Annotation.
An Example is given below:
data:image/s3,"s3://crabby-images/6b654/6b654285b24c24cf808c98ac54c6acc15b04edb2" alt="No alt provided"
EventInfo Annotation
The EventInfo Annotation describes the Event-specific metadata applicable to either the incoming event (Rule Info accepts property) or the outgoing action event (Rule Info produces property).
The Event Info includes the following properties:
- eventName - the Name of the Event produced by this Rule.
- entityType - the Entity Type of the Events accepted by this Rule, or the Entity Type of the Event produced by this Rule.
- entitySubType - the Sub Type of the Entity of the Event produced by this Rule.
- status - the Status of the Entity of the Event produced by this Rule.
If the Event produced by the Rule should inherit the parent event context, you can set the produces RuleInfo property to the following, and the Rubix Engine will automatically inherit the parent event values at runtime
An Example is given below:
data:image/s3,"s3://crabby-images/5cc6b/5cc6b11f55a6faf181ba06f65f922becffb63526" alt="No alt provided"
Event Attributes and Rule Parameters
Declaring Event Attributes Required by the Rule:
The Event Attribute type is used to provide configuration guidance to the Workflow, which is used to drive User Actions on the front end. When using a complex event attribute type such as a JSON object, it is helpful to provide a meaningful name for that type to the workflow configurators and frontend developers. Event Attributes are also considered "optional" in that the Rule should validate and handle it if they are not present
The EventAttribute Annotation declares the Event Attributes the Rule requires from the Event.
It contains 2 properties:
- name - the Name of the Event Attribute.
- type - the Type of the Event Attribute.
An example :
@EventAttribute(name = "EventAttribute1", type = "STRING")
Declaring Rule Parameters Required by the Rule
Parameters are not Event Attributes. Parameters are the configuration of a specific Rule instance within a Ruleset.
For example, the SendEvent Rule contains a string parameter named eventName, which is set during the configuration of the Rule within a Ruleset within a Workflow.
The ParamString annotation:
The ParamString Annotation defines a Parameter for the Rule of type String.
It contains 3 properties:
- name - The name of the Parameter. It is a required field
- description - The description of the Parameters. It is a required field
- defaultValue - This is the default value of the Parameter. It is an optional field
An example :
@ParamString(name = "ParamString1", description = "Parameter String 1", defaultValue = "PS1")
To learn more read Rules SDK - Event Attributes and Rule Parameters.
An Example is given below:
data:image/s3,"s3://crabby-images/46a3c/46a3c44ff3c641cf4a1ea23ff32526991a380fca" alt="No alt provided"
💡 Let's see an example which illustrates annotations.
data:image/s3,"s3://crabby-images/b13e9/b13e97b71602f4a75eb00bb17de42ac52d73aac4" alt="No alt provided"
- Name - The name of the rule how it appears in the editor. *A combination of the accountId, plugin namespace and rule name will fully qualify a rule in the workflow. For example: TESTACCOUNT.base.ForwardIfOrderAttributeExists
- Description - The description is how the Rule appears in the editor. Placeholders (like *"{" + PROP_EVENT_NAME + "}") represent parameters and are substituted with form fields in the editor. Every defined parameter must appear in the description and every placeholder in the description must have a corresponding @Param defined.
- Accepts - For this example we're restricting the Rule to apply only to Order actions. Accepts is an array, so we could add additional Entity types by adding more. If we are not using accepts then it means the rule will work on any orchestrateable entity. @EventInfo annotations. Accepts is used to validate workflows when they are updated and also to filter the Rule list in the editor.
- Produces - The rule produces an event which is defined in the produces section. Since the event name is defined via a parameter the eventName is defined as "{" + PROP_EVENT_NAME + "}". The entity type/subtype/status defaults to the same value as the current event.
- Event attributes - The list of attributes which this rule expects to be present in the incoming event attributes. The event attribute annotations of all rules within a ruleset define the interface contract of the ruleset.
- ParamString - This annotation is used for Rule parameters. For example if the Rule takes 2 string parameters, one for attribute name and other for the outgoing event name. Parameterising allows the Rule to be re-usable in different ways.
- Slf4j - The @Slf4j annotation enables the logging which is currently visible only to Fluent SRE team, but in the future will be available to partners as well
Run Method
The run method is the entry point of the Rule. This is the method where you write the functionality of your Rule. It also provides an instance of the current context into the method to write your rule logic in there.
Below you will find five stages (or phases) that we recommend for you to consider in your run method.
- Validation stage
- Retrieve data/query stage
- Write conditional logic stage
- Build action data stage
- Produce action stage
⚠️ You will learn about each run method stage with an example in the following section.
Below is an example of a run method configured with the required stages:
data:image/s3,"s3://crabby-images/9485a/9485a7f48292c561ed3c737228d2c89741bc3c15" alt="No alt provided"
To learn more read The run Method.