- Use case
- Prerequisites
- Create device
- Configure edge rule engine to push filtered data to the cloud
- Connect device to edge and post telemetry
- Create dashboard
- Next Steps
Use case
This use case demonstrates how to configure an “in-vehicle IoT monitoring system” connected to Klyff Edge platform.
The goal is to collect data from various sensors, process it locally on the Edge, and selectively push relevant data (e.g., mileage readings) to the cloud. This setup ensures efficient tracking of the remaining mileage until the next oil change.
To achieve this, we will configure the “Edge Root Rule Chain” to process sensor readings locally on the Klyff Edge platform. This setup will handle inputs from all 10 sensors and use a rule node to filter and forward only the distance readings (mileage) to the cloud.
The “in-vehicle monitoring system” includes 10 sensors:
- Distance
- Gas consumption
- Vehicle speed
- Engine temperature
- Ambient temperature
- Tire temperature
- Pressure in each tire (4x)
Klyff Edge has the following responsibilities:
- Collecting readings from all 10 sensors
- Sending only “distance” readings to the cloud
Please note that this is just a simple theoretical use case to demonstrate the capabilities of the platform. You can use this tutorial as a basis for much more complex scenarios.
Prerequisites
We assume you have completed the following guides and reviewed the articles listed below:
-
Getting Started guide.
- Rule Engine Overview article.
- Klyff Edge Getting Started article.
- Edge Rule Chain Templates guide.
Please make sure that you have Klyff PE server up and running. Additionally, Klyff Edge must be up, running and connected to the cloud.
If you have these prerequisites in place let’s go to next steps.
In other case please visit this link to provision, install and connect Edge to Server guide.
Create device
To begin, let’s create a new device named “In-vehicle monitoring system” on the Edge.
Please open Klyff Edge UI using the URL EDGE_URL.
- Log in to your Klyff Edge instance using your credentials. Navigate to the "Devices" page.
- Click on the "Add device" ("+") icon in the top right corner of the table to create a device. Then click "Add new device".
- Input the device Name, e.g., "In-vehicle monitoring system". Then click the "Add" button.
- Verify that your "In-vehicle monitoring system" device is listed in the devices table.
data:image/s3,"s3://crabby-images/c484d/c484d6daf42ff21dedeec678e667019eb8def39d" alt="Log in to your Klyff <b>Edge</b> instance using your credentials. Navigate to the "Devices" page."
data:image/s3,"s3://crabby-images/eb430/eb4302bf4ffac118e9a8505b1beb8bc591f02cb1" alt="Click on the "Add device" ("+") icon in the top right corner of the table to create a device. Then click "Add new device"."
data:image/s3,"s3://crabby-images/3d9f7/3d9f75d897612af90b2d88ac21036913a9d2a9f1" alt="Input the device Name, e.g., <b>"In-vehicle monitoring system"</b>. Then click the "Add" button."
data:image/s3,"s3://crabby-images/7f1cb/7f1cb0a8390870ce30a1b5c2175c4778f6f1005d" alt="Verify that your <b>"In-vehicle monitoring system"</b> device is listed in the devices table."
Please open Klyff using the URL SERVER_URL:
- Log in to your Klyff PE instance. Navigate to the "Devices" page.
- Verify that the "In-vehicle monitoring system" device is listed in the devices list.
data:image/s3,"s3://crabby-images/8281c/8281c683d904b7c0b19fc0f85bef60ca2c4fda0c" alt="Log in to your <b>Klyff PE</b> instance. Navigate to the "Devices" page."
data:image/s3,"s3://crabby-images/54678/546783353389336473cb0640e9c07bc6c4d44994" alt="Verify that the <b>"In-vehicle monitoring system"</b> device is listed in the devices list."
Configure edge rule engine to push filtered data to the cloud
We will update “Edge Root Rule Chain” that will be saving on the edge 10 sensor readings. In the rule chain we add rule node that transforms incoming messages and pushes to the cloud message only with distance readings. Here is the final configuration of the edge root rule chain:
In the next steps, we will create a TBEL node to filter data. The TBEL script language node will create an empty object newMsg, add a property named “distance” with the corresponding value from the “In-vehicle monitoring system”, and then send the newMsg object as a new message.
1
2
3
var newMsg = {};
newMsg.distance = msg.distance;
return { msg: newMsg, metadata: metadata, msgType: msgType };
Here are the steps to update the default Edge “Root Rule Chain” with the provided rule chain:
- Log in to your Klyff PE instance and navigate to the "Rule chains" page.
- Click on the "Edge Root Rule Chain" to enter edit mode.
- Search for the "script" node using the query "script". Drag the "Transformation" node into the rule chain.
- Enter a Name, e.g., "Transform incoming message", and paste the JavaScript code (from the snippet above) to process only the "distance" readings parameter. Click "Add" to proceed.
- Disconnect the "save time series" node from the "push to cloud" node.
- Connect "save time series" node to the "Transform incoming message" node.
- Choose "Success" from the dropdown list, and click the "Add" button.
- Connect "Transform incoming message" to the "Push to cloud" node.
- Choose "Success" from the dropdown list, then click the "Add" button to establish the connection.
- Click on the "Apply changes" icon to save your current progress.
data:image/s3,"s3://crabby-images/ceeac/ceeaca28c31dc0ff848dc35eed4593bba38db746" alt="Log in to your <b>Klyff PE</b> instance and navigate to the "Rule chains" page."
data:image/s3,"s3://crabby-images/6fc1e/6fc1e7f1abb0ad50ff619d0311505f866060c807" alt="Click on the "Edge Root Rule Chain" to enter edit mode."
data:image/s3,"s3://crabby-images/c115a/c115ab8f70c8a05a014480854a8c56be355f8f87" alt="Search for the "script" node using the query "script". Drag the "Transformation" node into the rule chain."
data:image/s3,"s3://crabby-images/ba8e2/ba8e2b289d63c41377d10e53eb1221261f3c991f" alt="Enter a Name, e.g., "Transform incoming message", and paste the <b>JavaScript code</b> (from the snippet above) to process only the "distance" readings parameter. Click "Add" to proceed."
data:image/s3,"s3://crabby-images/59562/59562adb1cde21e74bbff74d8a2df3d7cfc07fe6" alt="Disconnect the "save time series" node from the "push to cloud" node."
data:image/s3,"s3://crabby-images/7e1a8/7e1a8d384b136766beae76e88a8eeab447e5fd82" alt="Connect "save time series" node to the "Transform incoming message" node."
data:image/s3,"s3://crabby-images/30924/309245cc2a36cea1c307c08b234fb902527c1b34" alt="Choose "Success" from the dropdown list, and click the "Add" button."
data:image/s3,"s3://crabby-images/64d41/64d4112c8719f49e8d8e7aee98f28390f2776942" alt="Connect "Transform incoming message" to the "Push to cloud" node."
data:image/s3,"s3://crabby-images/593f2/593f221f36ce25688102e29219fd80b0c2e90fe7" alt="Choose "Success" from the dropdown list, then click the "Add" button to establish the connection."
data:image/s3,"s3://crabby-images/a7bbe/a7bbe3edf6f4440c66aaa28f16865e0413985cb9" alt="Click on the "Apply changes" icon to save your current progress."
Now let’s open Klyff Edge UI to see updated Root Rule Chain:
- Log in to your Klyff Edge instance and navigate to the "Devices" page.
- Open the "Edge Root Rule Chain" to verify changes.
- You should see the same rule chain nodes configuration as on the cloud.
data:image/s3,"s3://crabby-images/7e363/7e3638d88b7953566ea1b4518e6eca0e700130a3" alt="Log in to your Klyff <b>Edge</b> instance and navigate to the "Devices" page."
data:image/s3,"s3://crabby-images/06184/06184ebac03335c123f59f761345157085682bfb" alt="Open the "Edge Root Rule Chain" to verify changes."
data:image/s3,"s3://crabby-images/9aaa7/9aaa7b07cbdee906f2ad37622699b511de35f49f" alt="You should see the same rule chain nodes configuration as on the cloud."
Connect device to edge and post telemetry
To connect “In-vehicle monitoring system” to the Klyff Edge you need to get device credentials first. Klyff supports different device credentials. We recommend to use default auto-generated credentials which is access token for this guide.
Please open Klyff Edge UI using the URL: EDGE_URL.
- Open the "Devices" page.
- Select the "All" tab, then click on the row that represents the "In-vehicle monitoring system" device in the table to open its details.
- Click on the "Copy access token" (token will be copied to your clipboard).
data:image/s3,"s3://crabby-images/55349/5534965b30b02c875d90cd6f6c5987c737d1897f" alt="Open the "Devices" page."
data:image/s3,"s3://crabby-images/31bd0/31bd0fcc26aadf1f5c44650f2b1547018c3dc4f3" alt="Select the "All" tab, then click on the row that represents the <b>"In-vehicle monitoring system"</b> device in the table to open its details."
data:image/s3,"s3://crabby-images/0520c/0520c3c6dca0d512d4bfeecbdb7b26876879363d" alt="Click on the "Copy access token" (token will be copied to your clipboard)."
We will use simple commands to generate random telemetry for the device “In-vehicle monitoring system” and publish to the Klyff Edge by the MQTT protocol.
Please download following script to your local folder:
Before running the scripts, please modify mqtt-generator.py as follows:
-
Replace YOUR_ACCESS_TOKEN with the access token of the “In-vehicle monitoring system” device copied from the previous steps.
-
Replace YOUR_TB_EDGE_HOST with your Klyff Edge host address. For example, localhost.
-
Replace YOUR_TB_EDGE_MQTT_PORT with your Klyff Edge MQTT port number. For example, 11883 or 1883.
Open the terminal and install the MQTT Python library using the following command:
1
sudo pip install paho-mqtt
Navigate to the directory containing your Python script and launch the application with the following command:
1
python mqtt-generator.py
Open the Klyff Edge UI and verify that the device successfully receives telemetry:
- Open the "Devices" page in your Klyff Edge instance.
- Click on the row corresponding to the "In-vehicle monitoring system" device in the table to view its details.
- Switch to the "Latest telemetry" tab to monitor the telemetry data generated by the Python script in real-time
data:image/s3,"s3://crabby-images/9580f/9580ff4cf34bd9522e749f4d747a1cf738bb4b0a" alt="Open the "Devices" page in your Klyff <b>Edge</b> instance."
data:image/s3,"s3://crabby-images/72cb2/72cb2d171e921accef1742834b39dd4bcbc4bd00" alt="Click on the row corresponding to the <b>"In-vehicle monitoring system"</b> device in the table to view its details."
data:image/s3,"s3://crabby-images/93d97/93d97c9cd137616d7220c9a7bfba2e3920f1d78f" alt="Switch to the <b>"Latest telemetry"</b> tab to monitor the telemetry data generated by the Python script in real-time"
Open Klyff UI and verify that edge successfully pushes data to the cloud:
- Log in to your Klyff PE instance. Then navigate to the "Devices" page.
- Click on the "In-vehicle monitoring system" row to open the device details.
- Click on the "Latest telemetry" tab, to verify that "distance readings" are pushed successfully from the edge to the cloud.
data:image/s3,"s3://crabby-images/f1b60/f1b6002e499d8e433a42c56a75b4c19e8d859505" alt="Log in to your <b>Klyff PE</b> instance. Then navigate to the "Devices" page."
data:image/s3,"s3://crabby-images/cb8e5/cb8e5ae7a9234c442dc682b7df9053292548637a" alt="Click on the <b>"In-vehicle monitoring system"</b> row to open the device details."
data:image/s3,"s3://crabby-images/c96f2/c96f2e6f6145e5a7ab68760d42a294be9a3e92eb" alt="Click on the "Latest telemetry" tab, to verify that "distance readings" are pushed successfully from the edge to the cloud."
Create dashboard
In the following steps, we will create a dashboard that displays both the total miles traveled and the remaining miles until the next oil change for the vehicle.
Please open Klyff to create a new dashboard:
- Log in to your Klyff PE instance. Navigate to "Dashboards" page.
- Click on the ("+") icon, then select "Create new dashboard"
- Input the Name for the new dashboard, e.g., "Edge dashboards", then click the "Add" button.
- Click on the "Add alias" icon.
- Click on the "Add alias" button.
- Input Alias name "edge device". Select Filter type "Single entity", type "Device", and Device "In-vehicle monitoring system". Then click on the "Add" button.
- Click on the "Save" button.
- Click on the "Add new widget".
- Enter the search query "Digital gauges", then click to select the widget from the search results.
- Click on the widget shown in the screenshot, or choose another one according to your preference.
- Click on the "Save button".
- Click on the "Edit mode" button.
- Click on the "Edit widget" icon.
- Set max value to "10000".
- Switch to the "Advanced" tab, set the units to "mil", and click the "Apply" button.
- You have successfully created and configured the dashboard.
data:image/s3,"s3://crabby-images/03615/036150dc65c49dd8d9bc906ae7471ab661d85138" alt="Log in to your <b>Klyff PE</b> instance. Navigate to "Dashboards" page."
data:image/s3,"s3://crabby-images/ed9da/ed9da959e2372c3008ac0324795c629f11857e1e" alt="Click on the ("+") icon, then select "Create new dashboard""
data:image/s3,"s3://crabby-images/47bdb/47bdbf2525c8a31bdc10a266e15f95af6b647a15" alt="Input the Name for the new dashboard, e.g., "Edge dashboards", then click the "Add" button."
data:image/s3,"s3://crabby-images/a1244/a124410e46226d5ed847ba9c2cd22c68cb287cff" alt="Click on the "Add alias" icon."
data:image/s3,"s3://crabby-images/cabb5/cabb5a4eaaaf58d6014e2468d0cb6d1db532ba48" alt="Click on the "Add alias" button."
data:image/s3,"s3://crabby-images/c8cf1/c8cf1e07188e206c9f607742e2247490ef0dcc93" alt="Input Alias name "edge device". Select Filter type "Single entity", type "Device", and Device <b>"In-vehicle monitoring system"</b>. Then click on the "Add" button."
data:image/s3,"s3://crabby-images/60695/60695dd287f4fa6003ed469ae2096140c8f6d863" alt="Click on the "Save" button."
data:image/s3,"s3://crabby-images/85bd2/85bd29b8d3b455dc0c2fccb69c1f70bbc7e37637" alt="Click on the "Add new widget"."
data:image/s3,"s3://crabby-images/bae64/bae641e5b61742af862a4bb97814f843e46477ed" alt="Enter the search query "Digital gauges", then click to select the widget from the search results."
data:image/s3,"s3://crabby-images/33acf/33acf9c103845f719c56444634c5ec40ad137826" alt="Click on the widget shown in the screenshot, or choose another one according to your preference."
data:image/s3,"s3://crabby-images/8c5ce/8c5ce054aa0022eb8b37376359000f26ba202b8d" alt="Click on the "Save button"."
data:image/s3,"s3://crabby-images/9bfd7/9bfd7c7a9cf685984f2fe8cd3c4cf90e9f401c63" alt="Click on the "Edit mode" button."
data:image/s3,"s3://crabby-images/79024/79024a64f05d7f10eda1657322cb799265fbd82d" alt="Click on the "Edit widget" icon."
data:image/s3,"s3://crabby-images/d5908/d59089a8ddfcc86fea68e3c7709fa2a25ded9353" alt="Set max value to "10000"."
data:image/s3,"s3://crabby-images/d1457/d14573077b165f995ac3fbc5ce6a63d369438c82" alt="Switch to the "Advanced" tab, set the units to "mil", and click the "Apply" button."
data:image/s3,"s3://crabby-images/a8af2/a8af29add63d5a564e86be26fddff4d3afc4b68c" alt="You have successfully created and configured the dashboard."
Congratulations! You have successfully sent telemetry from the device, saved it on the edge, pushed filtered data to the cloud, and visualized it on the dashboard.
Next Steps
-
Getting started guide - Provide quick overview of main Klyff Edge features. Designed to be completed in 15-30 minutes:
-
Installation guides - Learn how to setup Klyff Edge on various available operating systems and connect to Klyff CE server.
-
Edge Rule Engine:
-
Rule Chain Templates - Learn how to use Klyff Edge Rule Chain Templates.
-
Provision Rule Chains from cloud to edge - Learn how to provision edge rule chains from cloud to edge.
-
- Security:
- gRPC over SSL/TLS - Learn how to configure gRPC over SSL/TLS for communication between edge and cloud.
-
Features:
-
Edge Status - Learn about Edge Status page on Klyff Edge.
-
Cloud Events - Learn about Cloud Events page on Klyff Edge.
-
-
Use cases:
- Data filtering and traffic reduce - This guide will show how to send to cloud from edge only filterd amount of device data:
- Roadmap - Klyff Edge roadmap.