Using Gateways with MQTT Bridge
This page explains how gateways can use the MQTT bridge to communicate with OmniCore and publish telemetry events on behalf of bound devices. Before you begin, read Using the MQTT bridge for general information on using the MQTT bridge with OmniCore.
Using gateways with the MQTT bridge
After you've created and configured the gateway, connect it to OmniCore over the MQTT bridge.
Create devices if you haven't already.
Optional: Bind the devices to the gateway.
When using the MQTT bridge, you only need to bind the devices if they can't generate their own JWTs.
Optional: Subscribe to the system error topic to get feedback on whether device operations are successful or not.
Attach the devices to the gateway.
Use the gateway to relay telemetry, device state, and configuration messages on behalf of its devices. Try the end-to-end demo to learn how.
Gateway messages
After the gateway connects to OmniCore over the MQTT bridge, it can send or receive three types of messages:
Control messages: Attaches a device to the gateway, or detaches a device from the gateway. These messages are sent between the gateway and OmniCore. OmniCore accepts control messages only from gateways; if another type of device attempts to send a control message, OmniCore closes the connection.
Messages from gateways and devices: Can be relayed by the gateway on behalf of a device, or sent directly from the gateway itself.
System error messages: When the gateway is subscribed to the MQTT system error topic on behalf of the device, OmniCore sends error messages to the gateway whenever the device encounters an error.
Attaching devices to a gateway
To enable the gateway to proxy device communications with OmniCore, have the gateway publish a QoS 1 /REGISTRY_ID/{device_ID_to_attach}/attach control message over the MQTT bridge.
If you configured the gateway to authenticate devices using the devices' JWTs, the payload of the attach message must include the token in JSON format: { "authorization" : "{JWT_token}" }. Otherwise, OmniCore authenticates the device by checking its association with the gateway.
Detaching devices from the gateway
To detach a device from the gateway, have the gateway publish a QoS 1 /REGISTRY_ID/{device_ID}/detach control message over the MQTT bridge. If the device isn't attached at the time the message is sent, OmniCore ignores the detach control message and sends a PUBACK message.
Troubleshooting
To be notified when a device encounters an error, subscribe the gateway to the MQTT /REGISTRY_ID/$[gateway_ID]/errors topic using QoS level 0:
The step where the device subscribes to the errors topic is highlighted below:
Last updated