Skip to content

pico-cs/mqtt-gateway

Repository files navigation

pico-cs mqtt-gateway

Go Reference Go Report Card REUSE status

mqtt-gateway connects pico-cs command stations to a MQTT broker.

Why care about a MQTT gateway

The short answer

A model railroad can be seen as a set of IoT devices and MQTT is one of the standard protocols in this space.

IoT integration

While the pico-cs firmware can be simply installed on a Raspberry Pi Pico and used as a DCC command station whether by controlling it over a serial monitor or via serial over USB or WiFi with the help of a client library (e.g. Go client). But using an IoT standard protocol like MQTT provides unprecedented opportunities in integrating pico-cs command stations into an IoT (software) infrastructure. And just to name two well known examples with MQTT support:

Why a dedicated gateway component...

...and not having an IoT protocol integrated as part of the pico firmware.

The resources on a micro controller are limited and following the KISS priciple each component should be simple and providing exactly the tasks it is designed for:

  • the pico-cs firmware implements a simple command text protocol used for the serial as well as for the WiFi TCP/IP communication
  • client libraries provide an idiomatic way in their respective programming language to communicate with the command station
  • and finally this gateway provides MQTT integration (like future components might provide integrations to additional protocols)

Precondition

  • a running MQTT broker like Mosquitto
  • the gateway executable or docker container
  • command station and model locomotive configuration files

Build

For building there are the following options available:

Local

Build

To build the pico-cs mqtt-gateway you need to have

git clone https://github.com/pico-cs/mqtt-gateway.git
cd mqtt-gateway/cmd/gateway
go build

Beside building the gateway executable for the local operating system and hardware architecture Go supports 'cross compiling' for many target OS and hardware architecture combinations (for details please consult the excellent Go documention).

Example building executable for Raspberry Pi on Raspberry Pi OS

GOOS=linux GOARCH=arm GOARM=7 go build

Run

A list of all gateway parameters can be printed via:

./gateway -h

Execute gateway with MQTT broker listening at address 10.10.10.42 (default port 1883):

./gateway -host 10.10.10.42

Execute gateway reading configurations files stored in directory /pico-cs/config

./gateway -configDir /pico-cs/config

Docker

To build and run the pico-cs mqtt-gateway as docker container you need to have

  • a running docker environment and
  • git installed

Build

git clone https://github.com/pico-cs/mqtt-gateway.git
cd mqtt-gateway
docker build --tag pico-cs/mqtt-gateway .

Run

A list of all gateway parameters can be printed via:

docker run -it pico-cs/mqtt-gateway -h

Execute container with

  • command station (pico) is connected to /dev/ttyACM0
  • MQTT broker listening at address 10.10.10.42 (default port 1883)
  • mqtt-gateway http endpoint (default 50000) should be made available on same host port 50000
  • run the container in detached mode
docker run -d --device /dev/ttyACM0 -p 50000:50000 pico-cs/mqtt-gateway -mqttHost='10.10.10.42' 

Execute container in interactive mode:

docker run -it --device /dev/ttyACM0 -p 50000:50000 pico-cs/mqtt-gateway -mqttHost='10.10.10.42' 

Configuration files

To configure the gateway's command station and loco parameters YAML files are used. The entire configuration can be stored in one file or in multiple files. During the start of the gateway the configuration directory (parameter configDir) and it's subdirectories are scanned for valid configuration files with file extension '.yaml' or '.yml'. The directory tree scan is a depth-first search and within a directory the files are visited in a lexical order. If a configuration for a device is found more than once the last one wins.

Each device needs to define a name. As the device name is part of the MQTT topic it must fullfil the following conditions:

  • consist of valid MQTT topic characters and
  • must not contain characters "/", "+" or "#"

If a device is assigned to a command station the command station acts whether as a primary or secondary. A primary command stations 'owns' the device, meaning that the command station registers for all commands of the device. A secondary command station listens and registers the events 'send' by the device and executes the correspondig commands to keep the device settings in sync with the primary command station. A device can be assigned to 0..1 primary command stations and 0..* secondary command stations.

Embedded configuration files

Beside using a configuration directory the configuration files can be embedded in the gateway executable:

  • store them in as part of the source code directory at mqtt-gateway/cmd/gateway/config and
  • build the binary

This is the prefered method using a static or default configuration. During the gateway start the embedded configuration files are scanned before the 'external' configuration files (configDir parameter), so an external device configuration would overwrite an embedded one.

MQTT topics

In MQTT a topic is a string the MQTT broker uses to determine which messages should be send to each of the connected clients. The client uses a topic to publish a message and uses topics to subscribe to messages it would like to receive from the broker. A topic can consist of more than one level - the character used to separate levels is '/'. A client might use wildcards when subscribing to topics, where '+' is the wildcard character for a dedicated level and '#' is the multi level wildcard character which can only be used as the last level of a topic. For further details about MQTT topics please see the MQTT specification.

The topic schema used by the gateway is

"<topic root>/<device type>/<device name>/<property>[/<command>]"

with

device type: cs | loco

The message payload is whether a json encoded atomic field (aka string, number, boolean) or a json encoded object.

Please see mqtt for information about the topics and message payloads used by the gateway.

Licensing

Copyright 2021-2023 Stefan Miller and pico-cs contributers. Please see our LICENSE for copyright and license information. Detailed information including third-party components and their licensing/copyright information is available via the REUSE tool.