Skip to main content

Async MQTT broker and client, with optional MoaT-KV support

Project description

MoaT-MQTT is an open source MQTT 3.1.1 client and broker implementation. It is a fork of hbmqtt with support for anyio and MoaT-KV.

MoaT-MQTT provides a straightforward API based on coroutines, making it easy to write highly concurrent applications.

Deprecation Notice

MoaT-MQTT will be retired because by now, broker support for MQTT 5 is nearly universal.

The designated replacement is mqttproto.

Features

MoaT-MQTT implements the full set of MQTT 3.1.1 protocol specifications and provides the following features:

  • Support for QoS 0, QoS 1 and QoS 2 messages flows

  • Client auto-reconnection

  • Authentication via password file (more methods can be added through a plugin system)

  • Basic $SYS topics

  • TCP and websocket support

  • SSL support over TCP and websocket

  • Plugin system

  • Optional: Storage of retained messages in MoaT-KV

Build status

TODO.

Project status

TODO.

Getting started

MoaT-MQTT is available on Pypi and can installed simply using pip :

$ pip install moat-mqtt

Documentation is available on Read the Docs.

Bug reports, patches and suggestions welcome! Just open an issue.

'Join the chat at https://gitter.im/beerfactory/moat-mqtt'

Moat-MQTT? DistMQTT? MoaT-KV? Whatever?

MoaT-MQTT is a Python package that includes a stand-alone MQTT server, as well as basic client scripts. It is based on hbmqtt and was previously named “DistMQTT”.

MoaT-KV is a distributed key-value storage system. It uses the MoaT-MQTT client library as its connector to an MQTT server, preferably Mosquitto or some other low-latency broker. It was previously named “DistKV”.

A MoaT-MQTT server can hook into MoaT-KV so that some messages are persisted, translated (i.e. store msgpack messages encoding True and False, instead of the strings “on” and “off” (or “ON” and “OFF” or “1” and “0” or …)), filtered (e.g. the client can only modify existing messages but not add any), et al..

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

moat_mqtt-0.42.3.tar.gz (55.2 kB view details)

Uploaded Source

Built Distribution

moat_mqtt-0.42.3-py3-none-any.whl (35.6 kB view details)

Uploaded Python 3

File details

Details for the file moat_mqtt-0.42.3.tar.gz.

File metadata

  • Download URL: moat_mqtt-0.42.3.tar.gz
  • Upload date:
  • Size: 55.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.2

File hashes

Hashes for moat_mqtt-0.42.3.tar.gz
Algorithm Hash digest
SHA256 c2949db4742b7e69155efc88337b7d8dbde38f1c311b1ece1876bcc45efa059c
MD5 242919fd2d8d60a41172739983ed7c06
BLAKE2b-256 f53500b81d0a569dd1f164adec7cda8b154a5e07191d7729ffd048de47e38c6c

See more details on using hashes here.

File details

Details for the file moat_mqtt-0.42.3-py3-none-any.whl.

File metadata

  • Download URL: moat_mqtt-0.42.3-py3-none-any.whl
  • Upload date:
  • Size: 35.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.2

File hashes

Hashes for moat_mqtt-0.42.3-py3-none-any.whl
Algorithm Hash digest
SHA256 5eafcd5e4eedc2d711925fce4b8b5763b773e2514be41c260c895e687df80ce8
MD5 a8cb08b9056d6e6725927cbcc2e75836
BLAKE2b-256 d5259ef9b7dbdbeb743a48211c8d61b14fcd2aaa6002ad50c73a8a923c721982

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page