Use Constants and Methods
Introduction
Now that you've mastered the basics of creating a ruleset and calling it via its API, let's move on and add constants and predefined methods to sophisticate rulesets and speed up development.
Constants are placeholders with a fixed value that you can use throughout a ruleset. They are comparable to const
in JavaScript.
Methods are predefined functionalities that execute a task or calculate a value. You can incorporate them into your ruleset, and they are comparable to JavaScript methods like filter()
and map()
. Because methods are predefined, they save you time in developing rulesets and make them more robust.
Rulecube has many methods ready to use for you and grouped them into these classes or categories:
Global
Methods such as:
AGE()
,ROUND()
,TODAY(
)
Finance
Methods such as calculating future values, annuities, etc.
HTTP
Methods for getting or posting data over the web
Mail
Methods for sending emails
MongoDB
Methods for interacting with a MongoDB database
PDF
Methods for generating PDF files
SQL
Methods for interacting with a SQL database
Statistics
Methods such as calculating standard deviation, variance, generating numbers from a normal distribution, etc.
Workflow
Methods for working with workflow and its state
System
Methods like creating alerts and entities on the fly, halting or restarting an execution, getting meta data of the current ruleset, etc.
Array
These are extensions for the Javascript Array. Methods like
sum()
,groupBy()
,orderBy()
, and many more.
Date
These are extensions for the Javascript Date. Methods like
addMonths()
,diff()
,isSameDay()
, and many more.
You may not know every category yet, but that's fine and will change as you work with Rulecube. In this guide, you'll focus on the Global category, which contain methods that might remind you of Excel functions.
You can use any method right away in your rulesets, and by the end of this tutorial, you'll know how to:
Use constants in rulesets.
Use methods in rulesets.
Apply multiple rules in a ruleset.
Use constants and methods
So far, your ruleset contained one rule, but rulesets can have multiple rules to distribute functionality logically. And each rule in a ruleset can use all the input and other ruleset components you defined. Furthermore, the output of each rule is combined in a joint output of the ruleset.
Let's create a new ruleset that calculates travel insurance costs to see how multiple rules, methods, and constants work. The ruleset will calculate the insurance costs based on travel days, risk, and extra costs based on days and the number of electronic devices someone wants to insure. To cover this, the ruleset will have these inputs:
StartDate
EndDate
RiskCategory
NumberOfItems
And these rules and corresponding output:
InsuranceCosts
ElectronicDeviceCosts
The rest of the necessary information will follow as you develop the ruleset.
Task: Create a new ruleset
Create a new ruleset named
Travel insurance calculator
Create these inputs:
NameTypeStartDate
date
EndDate
date
NumberOfItems
number
RiskCategory
enum
RiskCategory
is an enum, this is a special type of string, which can only be one of a given possible values. To complete this step enter this comma-separated list in the "Possible values" field:Normal, Medium, High.
This will also display the input as a dropdown in the Sandbox instead of a textbox.
This table defines how we're going to eventually calculate the total cost based on the RiskCategory
.
Normal
0.35
Medium
0.45
High
0.55
Task: Define constants
You're going to use the costs per day in a rule to calculate the insurance costs, and one way to do this is to hardcode the cost in your rule expression. Something like:
This is one possible way of coding values, but it's much better to use constants for this purpose because you only have to define them once and can use them anywhere.
Another advantage is that the value can be easily found and changed under Constants and you won't need to go through all your rules to find and replace it.
Click the + sign behind Constants from the left menu. ↳ The Constant details page opens.
In the Name field, enter
CostsPerItemPerDay
.In the Constant type list, select
Simple
.In the Value field, enter
0.25
.
CostsPerItemPerDay
applies to electronic devices such as smartphones with a value larger than 100 euros.
Task: Apply methods and use constants
You're all set now to add the rules. In the rules, you're going to use these methods:
DAYDIFF
- to calculate the number of days between the start and end date of the travel insurance.ROUND
- to round up the costs.
Create a rule named
NumberOfDays
Uncheck the checkbox under "Output" - as we do not want to include this in our output
Add the following expression:
Add a rule named
ElectronicDeviceCosts
Add the following expression:
Note how we use another rule (
NumberOfDays
), an input (NumberOfItems
) and a constant (CostsPerItemPerDay
) in our expression.
Save the ruleset and try out your ruleset with different input values.
Task: Create a Constant Table and use it in a rule
To calculate the insurance costs, we could create an additional 3 constants for each risk category (NormalRiskCostsPerDay
, MediumRiskCostsPerDay
and HighRiskCostsPerDay
) and use conditional logic in a rule to calculate it:
However, as you can see, this is quite complex, repetitive and tedious. But don't worry - there is a better approach to this that can simplify this to a single line rule!
Let's first create a new Constant named
RiskCostsPerDay
Change its Constant type from Simple to Table
You should now see an empty table like this:
Let's fill this table with some values.
Click on the first cell and enter
Normal
Press Tab to go to the value cell
Enter
0.35
in the value cellPress
Enter
to create another rowNow repeat the previous steps to end up with a table that looks like this:
Now that we've created our table, let's use it in a rule.
Create a rule named
InsuranceCosts
Add the following expression:
Explanation
RiskCostsPerDay.get()
is a method that will get a value from the constant table by Key. For example,RiskCostsPerDay.get("Normal")
would return0.35
. We're passing in theRiskCategory
input variable instead, which is either "Normal", "Medium" or "High" as that's how we've defined its Possible values.
Save the ruleset and try it out with different input values.
The result of your ruleset should look something like this:
Extra: explore Rulecube's predefined methods
You've only seen the tip of the methods iceberg yet. To see what methods are available and explore their possibilities, follow these steps:
Open up the sections in the menu and explore the available methods.
Recap
You now know how to use methods and constants in rulesets. And how to define multiple rules in a ruleset. Your rulesets are already getting pretty advanced, and you only need to take a few more steps before you create fully working rulesets.
What's next?
Rulecube also lets you develop your own methods, called functions, that can save you a lot of repeating work and make your rules more manageable. As you'll learn in the next tutorial.