Rule Engine is an easy to use framework for building event based workflows. There are 3 main components:
ThingsBoard Rule Engine is a highly customizable framework for complex event processing. Here are some common use cases that one can configure via ThingsBoard Rule Chains:
Let’s assume your device is using DHT22 sensor to collect and push temperature to the ThingsBoard. DHT22 sensor can measure temperature from -40°C to +80°C.
In this tutorial we will configure ThingsBoard Rule Engine to store all temperature within -40 to 80°C range and log all other readings to the system log.
In Thingsboard UI go to Rule Chains section and open Root Rule Chain.
Drag and Drop Script Filter rule node to the chain. Node configuration window will be opened. We will use this script for data validation:
If temperature property not defined or temperature is valid - script will return True, otherwise it will return False. If script returns True incoming message will be routed to the next nodes that are connected with True relation.
No we want that all telemetry requests pass through this validation script. We need to remove existing Post Telemetry relation between Message Type Switch node and Save Telemetry node:
And connect Message Type Switch node with Script Filter node using Post Telemetry relation:
Next we need to connect Script Filter node with Save Telemetry node using True relation. So all valid telemetry will be saved:
Also we will connect Script Filter node with Log Other node using False relation. So all not valid telemetry will be logged in the system log:
Press Save button to apply changes.
For validating results we will need to create Device and submit telemetry to the Thingsboard. So go in Devices section and create new Device:
For posting device telemetry we will use Rest API. For this we will need to copy device access token from the device Thermostat Home.
Lets post temperature = 99. We will see that telemetry was not added in Device Latest Telemetry section:
*you need to replace $ACCESS_TOKEN with actual device token
Lets post temperature = 24. We will see that telemetry was saved successfully.
You can use the next links for learning more about Thingsboard Rule Engine:
Installation guides - Learn how to setup ThingsBoard on various available operating systems.
Connect your device - Learn how to connect devices based on your connectivity technology or solution.
Data visualization - These guides contain instructions how to configure complex ThingsBoard dashboards
Data processing & actions - Learn how to use ThingsBoard Rule Engine.
IoT Data analytics - Learn how to use rule engine to perform basic analytics tasks.
Hardware samples - Learn how to connect various hardware platforms to ThingsBoard.
Advanced features - Learn about advanced ThingsBoard features