💡 Make the notion that it is the early alpha of MQTT client MicroPython SDK special for controllers. So we appreciate any help in improving this project and getting it growing.
ThingsBoard is an open-source IoT platform for data collection, processing, visualization, and device management. This project is a MicroPython library that provides convenient client SDK for Device API using MicroPython.
SDK supports:
- Provided all supported feature of umqtt library
- Unencrypted and encrypted (TLS v1.2) connection
- QoS 0 and 1 (MQTT only)
- Automatic reconnect
- Device MQTT API provided by ThingsBoard
- Firmware updates
- Device Claiming are not supported yet
The Device MQTT API are based on uMQTT library.
For now library support only local install (not from package manager relates to MicroPython)
Client initialization and telemetry publishing
from tb_device_mqtt import TBDeviceMqttClient
telemetry = {"temperature": 41.9, "enabled": False, "currentFirmwareVersion": "v1.2.2"}
client = TBDeviceMqttClient("127.0.0.1", "A1_TEST_TOKEN")
# Connect to ThingsBoard
client.connect()
# Sending telemetry without checking the delivery status
client.send_telemetry(telemetry)
# Sending telemetry and checking the delivery status (QoS = 1 by default)
result = client.send_telemetry(telemetry)
# Disconnect from ThingsBoard
client.disconnect()
TBDeviceMqttClient provides access to Device MQTT APIs of ThingsBoard platform. It allows to publish telemetry and attribute updates, subscribe to attribute changes, send and receive RPC commands, etc. Use TBHTTPClient for the Device HTTP API.
import time
from tb_device_mqtt import TBDeviceMqttClient
def on_attributes_change(client, result, exception):
if exception is not None:
print("Exception: " + str(exception))
else:
print(result)
client = TBDeviceMqttClient("127.0.0.1", "A1_TEST_TOKEN")
client.connect()
client.subscribe_to_attribute("uploadFrequency", on_attributes_change)
client.subscribe_to_all_attributes(on_attributes_change)
while True:
client.wait_for_msg()
time.sleep(1)
import logging
from tb_device_mqtt import TBDeviceMqttClient
import time
telemetry_with_ts = {"ts": int(round(time.time() * 1000)), "values": {"temperature": 42.1, "humidity": 70}}
client = TBDeviceMqttClient("127.0.0.1", "A1_TEST_TOKEN")
client.connect()
results = []
result = True
for i in range(0, 100):
results.append(client.send_telemetry(telemetry_with_ts))
print("Result " + str(result))
client.disconnect()
import logging
import time
from tb_device_mqtt import TBDeviceMqttClient
def on_attributes_change(client,result, exception:
if exception is not None:
print("Exception: " + str(exception))
else:
print(result)
client = TBDeviceMqttClient("127.0.0.1", "A1_TEST_TOKEN")
client.connect()
client.request_attributes(["configuration","targetFirmwareVersion"], callback=on_attributes_change)
while True:
time.sleep(1)
import psutil
import time
import logging
from tb_device_mqtt import TBDeviceMqttClient
# dependently of request method we send different data back
def on_server_side_rpc_request(client, request_id, request_body):
print(request_id, request_body)
if request_body["method"] == "getCPULoad":
client.send_rpc_reply(request_id, {"CPU percent": psutil.cpu_percent()})
elif request_body["method"] == "getMemoryUsage":
client.send_rpc_reply(request_id, {"Memory": psutil.virtual_memory().percent})
client = TBDeviceMqttClient("127.0.0.1", "A1_TEST_TOKEN")
client.set_server_side_rpc_request_handler(on_server_side_rpc_request)
client.connect()
while True:
time.sleep(1)
ProvisionManager - class created to have ability to provision device to ThingsBoard, using device provisioning feature Provisioning devices
First, you need to set up and configure the ProvisionManager
, which allows you to provision a device on the ThingsBoard server via MQTT. Below are the steps for using this class.
from tb_device_mqtt import TBDeviceMqttClient, ProvisionManager
THINGSBOARD_HOST = "YOUR_THINGSBOARD_HOST"
THINGSBOARD_PORT = 1883
PROVISION_DEVICE_KEY = "YOUR_PROVISION_DEVICE_KEY"
PROVISION_DEVICE_SECRET = "YOUR_PROVISION_DEVICE_SECRET"
DEVICE_NAME = "MyDevice"
provision_manager = ProvisionManager(THINGSBOARD_HOST, THINGSBOARD_PORT)
credentials = provision_manager.provision_device(
provision_device_key=PROVISION_DEVICE_KEY,
provision_device_secret=PROVISION_DEVICE_SECRET,
device_name=DEVICE_NAME
)
if not credentials:
print("Provisioning failed!")
raise SystemExit("Exiting: Provisioning unsuccessful.")
print(f"Provisioning successful! Credentials: {credentials}")
access_token = credentials.get("credentialsValue")
if not access_token:
print("No access token found in credentials!")
raise SystemExit("Exiting: Access token missing.")
client_id = f"{DEVICE_NAME}_client"
mqtt_client = TBDeviceMqttClient(host=THINGSBOARD_HOST, port=THINGSBOARD_PORT, access_token=access_token)
try:
mqtt_client.connect()
print(f"Connected to ThingsBoard server at {THINGSBOARD_HOST}:{THINGSBOARD_PORT}")
TELEMETRY_DATA = {
"temperature": 22.5,
"humidity": 60
}
mqtt_client.send_telemetry(TELEMETRY_DATA)
print(f"Telemetry sent: {TELEMETRY_DATA}")
except Exception as e:
print(f"An error occurred: {e}")
finally:
if mqtt_client.connect():
mqtt_client.disconnect()
print("Disconnected from ThingsBoard server.")
else:
print("Client was not connected; no need to disconnect.")
Claim device is a function designed to handle the device claiming feature in ThingsBoard. It enables sending device claiming requests to the ThingsBoard MQTT broker, allowing dynamic assignment of devices to users or customers.
from tb_device_mqtt import TBDeviceMqttClient
THINGSBOARD_HOST = "YOUR_THINGSBOARD_HOST"
THINGSBOARD_PORT = 1883
DEVICE_TOKEN = "YOUR_DEVICE_TOKEN"
DURATION_MS = 30000
SECRET_KEY = "YOUR_SECRET_KEY"
client = TBDeviceMqttClient(THINGSBOARD_HOST, THINGSBOARD_PORT, DEVICE_TOKEN)
try:
client.connect()
client.claim_device(SECRET_KEY, DURATION_MS)
print(f"Claim request sent with secretKey: {SECRET_KEY} and durationMs: {DURATION_MS}")
except Exception as e:
print(f"An error occurred: {e}")
finally:
if client.connected:
client.disconnect()
print("Disconnected from ThingsBoard.")
There are more examples for both device and gateway in corresponding folders.
This project is released under Apache 2.0 License.