2017-02-21 00:05:15 +01:00
|
|
|
## About
|
|
|
|
This application demonstrates the usage of the emCute (MQTT-SN) module in RIOT.
|
|
|
|
|
|
|
|
## Setup
|
2019-09-14 15:47:10 +02:00
|
|
|
For using this example, two prerequisites have to be fulfilled:
|
2017-02-21 00:05:15 +01:00
|
|
|
|
|
|
|
1. You need a running MQTT broker that supports MQTT-SN or a running MQTT-SN
|
|
|
|
gateway that is connected to a running MQTT broker
|
|
|
|
2. Your RIOT node needs to be able to speak to that broker/gateway
|
|
|
|
|
|
|
|
|
|
|
|
### Setting up a broker
|
|
|
|
In general, any MQTT-SN capable broker or broker/gateway setup will do.
|
|
|
|
Following a quick instruction on how-to setup the Mosquitto Real Simple Message
|
|
|
|
Broker:
|
|
|
|
|
2020-03-04 13:28:23 +01:00
|
|
|
1. Get the RSMB here: https://github.com/eclipse/mosquitto.rsmb
|
2017-02-21 00:05:15 +01:00
|
|
|
```
|
|
|
|
git clone https://github.com/eclipse/mosquitto.rsmb.git
|
|
|
|
```
|
|
|
|
|
|
|
|
2. Go into the source folder and build the RSMB
|
|
|
|
```
|
|
|
|
cd mosquitto.rsmb/rsmb/src
|
|
|
|
make
|
|
|
|
```
|
|
|
|
|
|
|
|
3. Create a config file. In this case we run the RSMB as MQTT and MQTT-SN
|
|
|
|
capable broker, using port 1885 for MQTT-SN and 1886 for MQTT and enabling
|
|
|
|
IPv6, so save the following to `config.conf`:
|
|
|
|
```
|
|
|
|
# add some debug output
|
|
|
|
trace_output protocol
|
|
|
|
|
|
|
|
# listen for MQTT-SN traffic on UDP port 1885
|
|
|
|
listener 1885 INADDR_ANY mqtts
|
|
|
|
ipv6 true
|
|
|
|
|
|
|
|
# listen to MQTT connections on tcp port 1886
|
|
|
|
listener 1886 INADDR_ANY
|
|
|
|
ipv6 true
|
|
|
|
```
|
|
|
|
|
|
|
|
4. Start the broker:
|
|
|
|
```
|
|
|
|
./broker_mqtts config.conf
|
|
|
|
```
|
|
|
|
|
|
|
|
You can refer to
|
|
|
|
https://rawgit.com/MichalFoksa/rsmb/master/rsmb/doc/gettingstarted.htm for more
|
|
|
|
configuration options.
|
|
|
|
|
|
|
|
|
|
|
|
### Setting up RIOT `native`
|
|
|
|
When running this example under native, we must configure some global addresses,
|
|
|
|
as the RSMB doesn't seems to be able to handle link-local addresses. So for a
|
|
|
|
single RIOT native instance, we can do the following:
|
|
|
|
|
2017-05-10 10:51:22 +02:00
|
|
|
1. Setup `tap` and `tapbr` devices using RIOT's `tapsetup` script:
|
2017-02-21 00:05:15 +01:00
|
|
|
```
|
2019-07-23 13:31:33 +02:00
|
|
|
sudo ./RIOTDIR/dist/tools/tapsetup/tapsetup
|
2017-02-21 00:05:15 +01:00
|
|
|
```
|
|
|
|
|
2017-05-10 10:51:22 +02:00
|
|
|
2. Assign a site-global prefix to the `tapbr0` interface (the name could be
|
2017-02-21 00:05:15 +01:00
|
|
|
different on OSX etc):
|
|
|
|
```
|
|
|
|
sudo ip a a fec0:affe::1/64 dev tapbr0
|
|
|
|
```
|
|
|
|
|
2019-05-07 15:11:22 +02:00
|
|
|
3. Assign a site-global address with the same prefix within the RIOT `native`
|
|
|
|
instance (open first with `BOARD=native make term`):
|
2017-02-21 00:05:15 +01:00
|
|
|
```
|
|
|
|
ifconfig 5 add fec0:affe::99
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
## Usage
|
|
|
|
This example maps all available MQTT-SN functions to shell commands. Simply type
|
|
|
|
`help` to see the available commands. The most important steps are explained
|
|
|
|
below:
|
|
|
|
|
|
|
|
- To connect to a broker, use the `con` command:
|
|
|
|
```
|
|
|
|
con fec0:affe::1 1885
|
|
|
|
```
|
|
|
|
|
|
|
|
- To subscribe to a topic, run `sub` with the topic name as parameter, e.g.
|
|
|
|
```
|
|
|
|
sub hello/world
|
|
|
|
```
|
|
|
|
|
|
|
|
- For publishing, use the `pub` command:
|
|
|
|
```
|
|
|
|
pub hello/world "One more beer, please."
|
|
|
|
```
|
|
|
|
|
|
|
|
That's it, happy publishing!
|
2019-06-26 12:03:01 +02:00
|
|
|
|
|
|
|
|
|
|
|
## FAQ
|
|
|
|
|
|
|
|
### I can't connect multiple RIOT nodes to a broker, what can I do?
|
|
|
|
Each node that connects to the broker must have a unique node ID string set. Per
|
2019-08-02 09:30:11 +02:00
|
|
|
default, this example sets this statically ID to `gertrud`. If you want to
|
2019-06-26 12:03:01 +02:00
|
|
|
connect more than one node to the broker, you need to set a custom ID for each
|
|
|
|
node during compile time. Simply use the `EMCUTE_ID` environment variable for
|
|
|
|
this, e.g. build with `EMCUTE_ID=horst make all`.
|
2020-07-10 14:21:47 +02:00
|
|
|
|
|
|
|
### I see incoming messages in RSMB, but no outgoing message seems to arrive?
|
|
|
|
The UDP socket handling for IPv6 based endpoints in the `Mosquitto.rsmb`
|
|
|
|
implementation is buggy when it comes to handling link local addresses,
|
|
|
|
as the implementation does not remember the interface on which data comes in,
|
|
|
|
hindering it from sending out any responses.
|
|
|
|
|
|
|
|
Workaround: either use global IPv6 addresses or [ULAs](https://tools.ietf.org/html/rfc4193).
|
|
|
|
|
|
|
|
### I have a problem with reusing topics, what could it be?
|
|
|
|
It also seems that the `Mosquitto.rsmb` implementation has a bug when it comes
|
|
|
|
to subscribing to topics: if a topic name was formerly registered and the same
|
|
|
|
topic name is later used for issuing a subscription request, the gateway will
|
|
|
|
assign a new topic ID to the same topic name, so publish messages to the
|
|
|
|
initially assigned topic ID will not be seen by that subscription.
|