Stand with Ukraine flag
Try it now Pricing
Professional Edition
Documentation > Integrations > Azure Service Bus
Getting Started
Devices Library Guides Installation Architecture API FAQ
On this page

Azure Service Bus Integration

Doc info icon
ThingsBoard PE Feature

Only Professional Edition supports Platform Integrations feature.
Use ThingsBoard Cloud or install your own platform instance.

Overview

Azure Service Bus Integration allows to stream data from Azure Service bus to ThingsBoard and converts device payloads to the ThingsBoard format.

image

Configure Azure Service Bus

To create ThingsBoard Service Bus integration you will need two things created in Azure portal: topic and subscription to the topic. You will also need to find and save connection string for your Servise Bus namespace, you will need it later.

You can сreate an Uplink converter in the Data converters section or directly in the integration. Uplink is necessary in order to convert the incoming data from the device into the required format for displaying them in ThingsBoard. Click on the “plus” and on “Create new converter”. To view the events, enable Debug. In the function decoder field, specify a script to parse and transform data.

Doc info icon

The Debug mode is very useful for development and troubleshooting. However, having it on all the time can significantly increase the disk space used by the database since all the debug data is stored there.
Therefore, starting from version 3.9, ThingsBoard stores all integrations debug events for the first 15 minutes. After that, only failure events are retained. These settings can be combined or completely disabled.

Let’s review sample uplink message from Service Bus topic:

1
2
3
4
5
6
7
{
   "devName": "Sensor A1",
   "msg": {
      "temp": 23,
      "humidity": 40
   }
}

One can use either TBEL (ThingsBoard expression language) or JavaScript to develop user defined functions. We recommend utilizing TBEL as it’s execution in ThingsBoard is much more efficient compared to JS.

You can use the following code, copy it to the decoder function section:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
/** Decoder **/

// decode payload to string
var data = decodeToJson(payload);
var deviceName = data.devName;
var deviceType = 'thermostat';

var result = {
    deviceName: deviceName,
    deviceType: deviceType,
    telemetry: {
        temperature: data.msg.temp,
        humidity: data.msg.humidity
    }
};

/** Helper functions 'decodeToString' and 'decodeToJson' are already built-in **/
return result;

image

You can use the following code, copy it to the decoder function section:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
/** Decoder **/

// decode payload to string
var data = decodeToJson(payload);
var deviceName = data.devName;
var deviceType = 'thermostat';

var result = {
    deviceName: deviceName,
    deviceType: deviceType,
    telemetry: {
        temperature: data.msg.temp,
        humidity: data.msg.humidity
    }
};

function decodeToString(payload) {
    return String.fromCharCode.apply(String, payload);
}

function decodeToJson(payload) {
    var str = decodeToString(payload);
    var data = JSON.parse(str);
    return data;
}

return result;

image

Create Integration in Thingsboard

Now that we have a topic created in Azure Portal and an Uplink converter created, it is possible to create an integration.

1) Go to Integrations center section -> Integrations page and click “plus” button to create new integration. Name it Azure Service Bus Integration, select type Azure Service Bus. Click “Next”;

image

2) At this step, you can select a previously created or create a new upnlink converter right in this window. Select the previously created Service Bus Uplink Converter. Click “Next”;

image

3) At the step of adding a downlink converter, you can also select a previously created or create a new downlink converter. But for now, leave the “Downlink data converter” field empty. Click “Skip”;

image

4) Fill in connection string for your Service Bus namespace, topic and subscription names;

image

5) [Optional] Click on Check connection button to check connection to your Service Bus topic. Click Add button to create the integration.

image

Test it up!

To send a test message, use the additional functionality of Azure Service bus, Service Bus Explorer.

Sign-in to Azure portal and select your namespace. Choose topic to uplink. On the left blade select ‘Service Bus Explorer’ tab. Click on ‘Send message’, choose type of payload according to uplink converter and send test message.

image

Example of payload:

1
2
3
4
5
6
7
{
    "devName": "Sensor A1",
    "msg": {
        "temp": 23,
        "humidity": 40
    }
}

To check if the message has arrived at Service Bus integration open the ‘Events’ tab of integration.

image


Received data can be viewed in the Uplink converter. In the ‘In’ and ‘Out’ blocks of the ‘Events’ tab:

After you sent uplink message a new device was created. You should receive a notification about it. To view notification click on the bell icon in the upper right corner of the screen. The notification will contain link to created device. Go to this device.

image

Here you will see information about the new device. As well as the telemetry which we sent to the device.

image

Learn more about notifications and how to configure them here.

To send messages to device you need to configure downlink settings, such as downlink converter and information about Service Bus topic that will receive mesages. Create topic for downlink messaging in Azure portal. (We advise also to create subscription to the topic so that you can check messages later in Azure portal).

Now, create downlink converter (You need to do same steps like when was creating Uplink but choose Downlink and specify another function).

You can use our example of downlink converter or write your own according to your configuration:

1
2
3
4
5
6
7
8
9
10
11
12
13
// Encode downlink data from incoming Rule Engine message
// msg - JSON message payload downlink message json
// msgType - type of message, for ex. 'ATTRIBUTES_UPDATED', 'POST_TELEMETRY_REQUEST', etc.
// Result object with encoded downlink payload
var result = {
    contentType: "JSON",
    data: JSON.stringify(msg),
    metadata: {
        deviceId: 'Sensor A1'
    }
};

return result;

image

You can use our example of downlink converter or write your own according to your configuration:

1
2
3
4
5
6
7
8
9
10
11
12
// Encode downlink data from incoming Rule Engine message
// msg - JSON message payload downlink message json
// Result object with encoded downlink payload
var result = {
    contentType: "JSON",
    data: JSON.stringify(msg),
    metadata: {
        deviceId: 'Sensor A1'
    }
};

return result;

image

Doc info icon

NOTE
If you used another name of device (not Sensor A1) you have to specify in the Downlink converter your device name for deviceId field

Go to integration and specify created downlink converter. Then open Advanced settings to specify Downlink topic and Downlink connection string for your Service Bus namespace (copy connection string from uplink settings if you use the same namespace for downlink).

image


Ok, downlink converter ready, integration ready. Let’s test integration with help of downlink node.

After test uplink message was sent integration has created the device inside Thingsboard. Let`s check with which Rule Chain it is connected. For this go to Entities -> Devices page in Thingsboard menu and find the device with the name that we have used in the uplink. Find and navigate to the device profile used by the device.

image

Find the name of rule chain that device profile uses.

image

Go to the Rule chains page. In ‘Search nodes’ field type ‘downlink’ and choose in the menu ‘integration downlink’ node and drag it to the canvas. In pop-up you need to specify the name of rule node and choose your integration.

image

Then we need to tap on a right grey circle of ‘message type switch’ rule node and drag this circle to left side of ‘integration downlink’ node, here choose ‘Post attribute’ and ‘Attributes update’, tap “Add” link and save Rule chain.

image

Let’s go to ‘Entities’ -> ‘Devices’ page and choose our device. Switch to Attributes tab. In ‘Entity attributes scope’ list choose Shared attributes. Tap on ‘plus’ to create a new attribute. Specify in pop-up the key name of attribute, type of value and some value and tap ‘Add’.

image

Go to the Integrations page to check the result of downlink.

image

As you can see we have an event that downlink message was successfully generated by Integration and was sent to Azure Service Bus.

To check it in Azure Service Bus you need to go to Azure Portal, choose topic you have used for downlink and subscription to the topic. Select Receive mode, then click on Receive messages. In pop-up click ‘Receive’ button.

image


image

Conclusion

That’s it! Good luck in configuring of you IoT devices and dashboards!

Next steps