Quickstart
The quickest way to try out GoRules.
Access GoRules BRMS
GoRules BRMS can be accessed by two different methods:
- Through GoRules BRMS Cloud Demo - Quickest way
- Through Self-hosted instance
If you already have your environment set-up feel free to skip this section.
BRMS Cloud is not intended to be used in a product environments. It is used for evaluation purposes only.
Once you are ready, a developer should follow deployment instructions.
Signing up
Process of getting started with Cloud BRMS is simple and straight forward.
- Go to GoRules Cloud And Sign Up
- Follow the instructions to log in
- Create your organisation and open it
Create a project
Projects are workspaces for your organisation. They enable you to achieve better decoupling between teams. Each team can manage their own projects and have ownership of their work.
Log in to GoRules. You should land on the dashboard which contains a list of projects.
Create a project by clicking on the Create project button and filling in the details.
 
You can now open the newly created project to access the documents and other project related resources.
Create a decision
Decisions are graph based structures which allow you to compose multiple nodes.
From the documents, create a decision and name it Shipping decision.
 
Double-click on the decision document to open it.
Connect the graph
Let's build a simple graph which uses required nodes (input and output) and a decision table.
Drag the components from the right side and connect edges until you create a graph like the one below.
 
Edit the decision table
Decision tables allow you to create a set of conditions in a spreadsheet format. They consist of inputs and outputs. Both inputs and outputs consist of two data points:
- Label - Helps you describe what the field is supposed to represent
- Field - Selector that utilises ZEN expressions
Add fields and rows to create a decision table with the same structure as below:
 
The reference operator ($) is also used in the table. Passing it as a first argument in contains function allows us to check if one of the groups which customer belongs to is called "premium". Meaning that "premium" customers will receive free shipping!
The purpose of the last row is to have a default value in case no other rows match.
Save and publish the changes by clicking the Save and publish button.
Simulate
You can simulate a decision even when the content is unsaved. This allows you to experiment and test
before saving the changes.
Click on Open simulator button from the decision to show the panel on the right.
The panel consists of request and response. In the request write the following JSON:
{
  "customer": {
    "country": "US",
    "groups": ["premium", "early-bird"]
  },
  "cart": {
    "weight": 10
  }
} 
The decision correctly matches the provided input, and this premium customer will enjoy their free-cost shipping./
Evaluate using the API
Once you have designed and tested your decision in the simulator, you'll likely want to integrate it with your application. GoRules provides a REST API that allows you to evaluate decisions programmatically.
Copy decision URL
- In your project, right click on the document name (e.g. Shipping)
- From the dropdown menu, select Copy Link.
- This will copy the decision URL that you'll need for the API call.
Example:
https://[your-brms-url]/api/projects/{projectId}/evaluate/{documentPath} 
Get the project token
When evaluating a decision using GoRules Agent, each Agent has it's own dedicated Project token.
- Navigate to your project.
- Go to Settings > Security from the side menu.
- Copy the project token
 
Make an HTTP request
Using a tool like Postman or any API client:
- 
Create a new POST request to: https://[your-brms-url]/api/projects/{projectId}/evaluate/{documentPath}Replace {projectId}with your actual project ID and{documentPath}with the document path you copied earlier.
- 
Add the header: X-Access-Token: [your-project-token]
- 
Set the request body to JSON with the following structure: { "context": { "customer": { "country": "US", "groups": ["premium", "early-bird"] }, "cart": { "weight": 10 } }, "trace": false }The traceparameter is optional (default: false) and can be set totrueif you want detailed execution information.
- 
Send the request and you should receive a response similar to: { "performance": "85.421μs", "result": { "shipping": { "fee": 30 } } }
Updated 8 months ago
