Skip to main content

CREATING AN MQTT CONNECTION

The MQTT connector requires access to a MQTT broker.

Note

To use the MQTT connector, refer to the guide here.
Alternatively, if you want to connect directly to an Actility MQTT broker, follow the instructions here.

Creating a Connection from the UI

You must have deployed a MQTT server prior to configuring a MQTT Connector instance. The MQTT server must be accessible from your ThingPark Enterprise server, and you need to know the path of MQTT topics you want to publish to (uplinks) or subscribe (downlinks).

You also need to know the parameters that are required to perform this task. To learn more, click Parameters required for connecting to a MQTT application below in this topic.

  1. Click Applications -> Create -> View More Applications Type.

img

Then, a new page will open. Select the connection type: MQTT

img

Note

The application creation form is the same for a JSON enriched document as for a JSON legacy document.

  1. Fill in the form as in the example below.

img

Note

Parameters marked with * are mandatory.

The Certificate and the Private Key are required for both SSL and WSS protocols. This does not apply to TCP.

  1. Click Create.
  • A notification appears on the upper right side of your screen to confirm that the application has been created. img
  1. After creating the application, you will be redirected to the application details.

img

Collecting Expected Information

Parameters required

UI FieldDescription
Application NameName of the application that you want to register (Editable).
Uplink Topic PatternDefines a pattern of topic for the Uplink.
Downlink Topic PatternDefines a pattern of topic for the Downlink.
Host NameThe hostname/IP and port of your MQTT server. For example, "myhostname.com:8883".
ProtocolProtocol to be used for your connection with your MQTT server. Choose among SSL, WSS and TCP.
UsernameThe username to access your MQTT server.
PasswordThe password to access your MQTT server.
Certificate
  • The client certificate file (X.509 with .crt format only) used to connect to your MQTT server. Only required when you are using double factor authentication (login/password and client interface).
  • This parameter does not apply to TCP protocol.
Private Key
  • The client Private Key file (PKCS#8 format only) used to connect to your MQTT server. Only required when you are using double factor authentication (login/password and client interface).
  • This parameter does not apply to TCP protocol.
DescriptionAny useful information related to the application.
QoSQuality of Service (QoS) is an agreement between the message sender and receiver that defines the level of delivery guarantee for a specific message.

Creating a Connection With API

MQTT over TLS v1.2 connection is the recommended protocol to use with MQTT Brokers. You need to create a MQTT Connector instance (Connection) before you can associate it to device(s). The creation of a Connection establishes a link from ThingPark IoT Flow to the MQTT Broker. The link can be used to publish Uplink and related metadata information for any device associated to this instance of MQTT Connector, but will also publish messages that may have been redirected from other Connectors.

To do this, you need to use the following endpoints:

  • POST/connections for creation
  • PUT/connections for modification
  • DELETE/connections for deletion
Note

When you want to update a configuration property on a Connection, you must provide all configuration properties again.

Example of the creation of a Connection.

POST /connections

    {
"connectorId": "actility-mqtt-iot",
"name": "Actility MQTT (SSL) Connection",
"configuration": {
"description": "MQTT (SSL) connection example",
"uplinkTopicPattern": "mqtt/things/{DevEUI}/uplink",
"downlinkTopicPattern": "mqtt/things/{DevEUI}/downlink",
"hostName": "91.134.250.109:8883",
"protocol": "SSL",
"username": "mycompany",
"password": "bar",
"certificate": "-----BEGIN CERTIFICATE-----...-----END CERTIFICATE-----",
"privateKey": "-----BEGIN RSA PRIVATE KEY-----...-----END RSA PRIVATE KEY-----",
"qos": 1
}
}

The following table lists the expected results of the properties when applied.

PropertyExpected results
connectorIdMust be set to actility-mqtt-iot for AWS IoT cloud platform.
configuration/uplinkTopicPatternDefines a pattern of topic for the Uplink. Could contain JSONPath expression, check Topic Pattern Expression for examples.
configuration/downlinkTopicPatternDefines a pattern of topic for the Downlink. Could contain JSONPath expression, check Topic Pattern Expression for examples.
configuration/hostNameHostname/IP and port of your MQTT Broker.
configuration/protocolProtocol to be used for the connection with your MQTT server, possible values are 'SSL' (MQTT over SSL), 'WSS' (MQTT over secure Web Sockets) or 'TCP' (MQTT over TCP without encryption).
configuration/usernameLogin to access your MQTT Broker.
configuration/trustedCaCertficateContents of the client CA certificate file (X.509 with .crt format only) used to connect to your MQTT server. Only required when your+ client certificate is not self-sign).
configuration/certificateContents of the client certificate file (X.509 with .crt format only) used to connect to your MQTT server. Only required when you are using double factor authentication (login/password + client certificate).
configuration/privateKeyContents of the client private key file (PKCS#8 format only) used to connect to your MQTT server. Only required when you are using double factor authentication (login/password + client certificate).
configuration/connectionTimeoutMax time needed for establishing a connection. (Default=5000ms, max=30000ms)
configuration/actionTimeoutMax time available for each action like publishing a message or subscribe to a topic. (Default=1000ms, max = 10000ms)
Important note

All properties are not present in this example. You can check the rest of these properties in the common parameters section.

Limitations

MQTT Broker Compatibility with org.eclipse.paho.client.mqttv3 (v1.2.5)

Most modern brokers are backward compatible and accept MQTT 3.1.1 clients without issue.

BrokerSupported MQTT VersionsCompatible with Paho v1.2.5 (3.1.1)Notes
Mosquitto3.1, 3.1.1, 5.0✅ YesConnection established in 3.1.1 mode (no MQTT 5 features).
EMQX3.1, 3.1.1, 5.0✅ YesBackward compatible with 3.1.1 clients.
HiveMQ3.1, 3.1.1, 5.0✅ YesFull compatibility; MQTT 5 features unavailable with this client.
VerneMQ3.1, 3.1.1, 5.0✅ YesBroker auto-negotiates 3.1.1 when connecting.
RabbitMQ3.1, 3.1.1✅ YesMQTT 5 not supported by RabbitMQ (as of current versions).
AWS IoT Core3.1.1✅ YesOnly supports 3.1.1; fully compatible.
Azure IoT Hub3.1.1✅ YesMQTT 5 not yet supported.
Google Cloud IoT Core3.1.1✅ YesWorks with MQTT 3.1.1 clients.

How to test the MQTT Connection

  1. Download and install a MQTT client, for example MQTT Explorer or MQTT.fx.

  2. Create a new connection and connect to the MQTT Broker using your configuration:

img img

  1. Select the Subscribe tab, fill the uplink topic you want to monitor (that is, mqtt/things/+/uplink) and click Subscribe.

img

You should see incoming uplinks (published by your IoT Flow MQTT connector) in the right part of the screen.

In order to test the processing of subscribed topic messages by the MQTT connector, you need to properly format the message. LoRaWAN Commands targeted to a given DevEUI look like this:

mosquitto_pub \
-h $BROKER_PUBLIC \
-p $TLS_PUBLIC_LISTENER \
-u $SUPER_USERNAME \
-P $SUPER_PASSWORD \
-t "mqtt/things/A81758FFFE04F27E/downlink" \
-m '{
"DevEUI_downlink": {
"Time": "2022-06-08T15:50:00.882+02:00",
"DevEUI": "A81758FFFE04F27E",
"FPort": "8",
"payload_hex": "9e1c4852512000220020e3831071",
"Confirmed": "1",
"FlushDownlinkQueue": "1"
}
}'

Any other JSON message will be accepted and processed by the forwarding rules configured in the MQTT connector (forwarding rules do not apply to Commands). Messages not properly JSON-formatted will be ignored.

Troubleshooting

MQTT Broker timeouts

If your MQTT Broker is really far from the Actility platform, the network latency can cause the MQTT connection to timeout. These two parameters may need to be tuned accordingly :

ParameterDescriptionDefault
configuration/connectionTimeoutMax time allowed for establishing a connection.Default=5s, max=10s
configuration/actionTimeoutMax time available for each action, e.g. publishing a message or subscribe to a topic.Default=1s, max = 10s