Wraps the uhppote-core
device API in an MQTT endpoint for use with access control systems based on the
UHPPOTE UT0311-L0x TCP/IP Wiegand access control boards.
Supported operating systems:
- Linux
- MacOS
- Windows
- RaspberryPi (ARM/ARM7/ARM6)
uhppoted-mqtt
implements an MQTT endpoint that facilitates integration of the access control function with other systems (e.g. web servers, mobile applications) where the controllers are located behind a firewall that does not allow ingress.
It also facilitates integration of access control with IoT systems based on e.g. AWS IoT, Google Cloud IoT or the IBM Watson IoT Platform.
v0.8.9 - 2024-09-06
- Added TCP/IP support.
- Updated to Go 1.23.
Executables for all the supported operating systems are packaged in the releases:
The release tarballs contain the executables for all the operating systems - OS specific tarballs with all the uhppoted components can be found in uhpppoted releases.
Installation is straightforward - download the archive and extract it to a directory of your choice. To install uhppoted-mqttd
as a system service:
cd <uhppote directory>
sudo uhppoted-mqttd daemonize
uhppoted-mqttd help
will list the available commands and associated options (documented below).
The uhppoted-mqttd
service requires the following additional files:
uhppoted.conf
uhppoted.conf
is the communal configuration file shared by all the uhppoted
project modules and is (or will
eventually be) documented in uhppoted. uhppoted-mqttd
requires:
- the MQTT section to define the configuration for the MQTT client connection and endpoint
- the devices section to resolve non-local controller IP addresses and door to controller door identities.
A sample uhppoted.conf file
is included in the uhppoted
distribution. Alternatively, a starter uhppoted.conf
file can be created by executing:
uhppoted-mqtt config > uhppoted.conf
A public Docker image is published to ghcr.io.
The image is configured to use the /usr/local/etc/uhppoted/uhppoted.conf
file for configuration information.
A sample Docker compose
configuration is provided in the docker/compose
folder.
To run the example, download and extract the compose.zip scripts and supporting files into folder of your choice and then:
cd <compose folder>
docker compose up
The MQTT server can be tested using an MQTT client, e.g. mqtt:
mqtt publish --topic 'uhppoted/gateway/requests/devices:get' \
--message '{ "message": { "request": { "request-id": "AH173635G3", \
"client-id": "QWERTY54", \
"reply-to": "uhppoted/reply", \
"nonce": 5 }}}'
The default image is configured for TCP only. To enable a TLS connection to the MQTT broker, enable it in the uhppoted.conf file on the Docker volume mapped to /usr/local/etc/uhppoted and copy the certificates and keys to the /usr/local/etc/uhppoted/mqtt folder on the Docker volume mapped to /usr/local/etc/uhppoted, e.g.
docker cp broker.pem mqttd:/usr/local/etc/uhppoted/mqtt
docker cp client.key mqttd:/usr/local/etc/uhppoted/mqtt
docker cp client.cert mqttd:/usr/local/etc/uhppoted/mqtt
To start a REST server using Docker run
:
docker pull ghcr.io/uhppoted/restd:latest
docker run --publish 8080:8080 --publish 8443:8443 --name restd --mount source=uhppoted,target=/var/uhppoted --rm ghcr.io/uhppoted/restd
The REST server can be tested using curl, e.g.:
curl -X 'GET' 'http://127.0.0.1:8080/uhppote/device' -H 'accept: application/json' | jq .
For inclusion in a Dockerfile:
FROM ghcr.io/uhppoted/restd:latest
Assuming you have Go
and make
installed:
git clone https://github.com/uhppoted/uhppoted-mqtt.git
cd uhppoted-mqtt
make build
If you prefer not to use make
:
git clone https://github.com/uhppoted/uhppoted-mqtt.git
cd uhppoted-mqtt
mkdir bin
go build -trimpath -o bin ./...
The above commands build the 'uhppoted-mqtt
executable to the bin
directory.
Dependency | Description |
---|---|
uhppote-core | Device level API implementation |
uhppoted-lib | common API for external applications |
github.com/eclipse/paho.mqtt.golang | Eclipse Paho MQTT client |
golang.org/x/sys | Support for Windows services |
golang.org/x/net | paho.mqtt.golang dependency |
github.com/gorilla/websocket | paho.mqtt.golang dependency |
Usage: uhppoted-mqtt <command> <options>
Supported commands:
help
version
config
run
daemonize
undaemonize
Defaults to run
if the command it not provided i.e. uhppoted-mqtt <options>
is equivalent to uhppoted-mqtt run <options>
.
Runs the uhppoted-mqtt
MQTT client. Intended for use as a system service that runs in the background to handle MQTT messages directed at the endpoint.
Command line:
uhppoted-mqtt [--debug] [--console] [--config <file>]
--config Sets the uhppoted.conf file to use for controller configurations.
Defaults to the communal uhppoted.conf file shared by all the uhppoted
modules.
--console Runs the MQTT endpoint as an application, logging events to the
console.
--debug Displays verbose debugging information, in particular the communications with the UHPPOTE controllers
Registers the uhppoted-mqtt
MQTT endpoint as a system service that will be started on system boot. The command creates the necessary system specific service configuration files and service manager entries.
Command line:
uhppoted-mqtt daemonize
Unregisters the uhppoted-mqtt
MQTT endpoint as a system service, but does not delete any created log or configuration files.
Command line:
uhppoted-mqtt undaemonize
uhppoted-mqtt publishes controller events to two topics:
uhppoted/gateway/events
uhppoted/gateway/events/live
The uhppoted/gateway/events
topic is an events feed that attempts to ensure that all events are published to the topic at least
once, including events that may have occurred while the service was offline. Events are retrieved in small batches so if there is a
significant backlog the event published in the feed may lag significantly behind the current event.
The uhppoted/gateway/events/live
topic is an events feed that publishes controller events as they are received. However, events
that occur while the service is offline won't be published to this topic.
The topics are configurable in uhppoted.conf:
…
mqtt.topic.root = uhppoted/gateway
mqtt.topic.events = ./events
mqtt.topic.events.live = ./events/live
…