Changes for page ThingsBoard
Last modified by Dilisi S on 2025/04/02 02:09
Summary
-
Page properties (1 modified, 0 added, 0 removed)
Details
- Page properties
-
- Content
-
... ... @@ -329,10 +329,72 @@ 329 329 [[image:data-converter-list-showing-uplink-dc.png]] 330 330 331 331 332 +== 3.2 Downlink == 332 332 333 333 335 +On the **Data converters** page, click on the ‘**+**’ button, and then click on the **Create new converter** from the dropdown menu. 334 334 335 335 338 +[[image:create-new-converter-menu.png||width="500"]] 339 + 340 + 341 + 342 +The **Add data converter** window will appear. Name it ‘**MQTT Downlink Converter NB/CB**’ and select the Type as **Downlink**. 343 + 344 +Click on the **TBEL** button if not selected it by default. Now copy and paste the following encoder function written in **TBEL (ThingsBoard Expression Language)** in to the **code editor**. This encoder function is compatible for both NB and CB series devices. 345 + 346 + 347 +{{code language="JavaScript"}} 348 +// Encode downlink data from incoming Rule Engine message 349 + 350 +// msg - JSON message payload downlink message json 351 +// msgType - type of message, for ex. 'ATTRIBUTES_UPDATED', 'POST_TELEMETRY_REQUEST', etc. 352 +// metadata - list of key-value pairs with additional data about the message 353 +// integrationMetadata - list of key-value pairs with additional data defined in Integration executing this converter 354 + 355 +/** Encoder **/ 356 + 357 +var data = {}; 358 + 359 +// Process data from incoming message and metadata 360 + 361 +data.tempFreq = msg.temperatureUploadFrequency; 362 +data.humFreq = msg.humidityUploadFrequency; 363 + 364 +data.devSerialNumber = metadata['ss_serialNumber']; 365 + 366 +// Result object with encoded downlink payload 367 +var result = { 368 + 369 + // downlink data content type: JSON, TEXT or BINARY (base64 format) 370 + contentType: "JSON", 371 + 372 + // downlink data 373 + data: JSON.stringify(data), 374 + 375 + // Optional metadata object presented in key/value format 376 + metadata: { 377 + topic: metadata['deviceType']+'/'+metadata['deviceName']+'/upload' 378 + } 379 + 380 +}; 381 + 382 +return result; 383 +{{/code}} 384 + 385 + 386 +Click on the **Add** button. 387 + 388 + 389 +[[image:add-downlink-data-converter.png||height="529" width="500"]] 390 + 391 + 392 +You should see that the newly added **MQTT Downlink** Converter NB/CB is listed on the **Data Converters** page. 393 + 394 + 395 +[[image:data-converters-list.png]] 396 + 397 + 336 336 = 4. Add Integration = 337 337 338 338 ... ... @@ -520,7 +520,8 @@ 520 520 521 521 First simulate a few messages using MQTT. This time, we have added the 'humidity' field to the payload. Eg: 522 522 523 -{{code language="none"}}mosquitto_pub -d -q 1 -h 011731f7928xxxxx.s1.eu.hivemq.cloud -p 8883 -t "v1/devices/me/telemetry" -u "xxxxx" -P "xxxxx" -m '{"IMEI": "S31B-NB", "temperature": 22, "humidity":80}'{{/code}} 585 +{{code language="none"}}mosquitto_pub -d -q 1 -h 011731f7928xxxxx.s1.eu.hivemq.cloud -p 8883 -t "v1/devices/me/telemetry" -u "xxxxx" -P "xxxxx" -m '{"IMEI": "S31B-NB", "temperature": 22, "humidity":80}' 586 +{{/code}} 524 524 525 525 526 526 In **ThingsBoard**, from the left navigation menu, click **Dashboards**. Then, click the **+** button and select **Create new dashboard** from the dropdown menu.