Skip to content

Go MQTT endpoint for the UHPPOTE UT0311 TCP/IP access controller boards

License

Notifications You must be signed in to change notification settings

Andre1Becker/uhppoted-mqtt

 
 

Repository files navigation

build

uhppoted-mqtt

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
  • ARM7 (e.g. RaspberryPi)

Raison d'être

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.

Release Notes

Current Release

v0.8.7 - 2023-12-01

  1. set-door-passcodes command to set supervisor passcodes for a door.
  2. Published received events to the live events topic.
  3. Renamed master branch to main in line with current development practice.
  4. Replaced nil event pointer in get-status with zero value.
  5. Fixed double events in events::Listen (cf. uhppoted#15)
  6. Reworked events feed to poll for unretrieved events.

Installation

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

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

Building from source

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.

Building from source

Dependencies

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

uhppoted-mqtt

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>.

run

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

daemonize

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

undaemonize

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

Notes

Events

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
…

About

Go MQTT endpoint for the UHPPOTE UT0311 TCP/IP access controller boards

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Go 80.0%
  • Makefile 19.6%
  • Dockerfile 0.4%