Skip to main content

MQTTStuff

Project description

mypy and pytests Cumulative Clones PyPI Downloads

https://github.com/vroomfondel/mqttstuff/raw/main/Gemini_Generated_Image_mqttstuff_i3269fi3269fi326_250x250.png

MQTTStuff

Lightweight helper utilities for working with MQTT via Paho, with convenient wrappers for:

  • Connecting and subscribing to topics, including retained-message handling

  • Publishing one or many messages with consistent metadata and timestamps

  • Reading “last/most recent” messages with timeout-based collection and optional type conversion

  • Developer helpers for JSON pretty-printing, deep updates, and logging configuration

  • Repository: https://github.com/vroomfondel/mqttstuff

  • Package: mqttstuff

Overview

MQTTStuff provides a higher-level interface over paho-mqtt to simplify common patterns:

  • A MosquittoClientWrapper to configure, connect, subscribe, and publish with minimal boilerplate
  • A MQTTLastDataReader utility to retrieve the most recent messages for one or more topics quickly
  • A MWMqttMessage normalization data format for sending/receiving data (optional metadata) from/to IOT devices/sensors

Installation

Options:

  • From source (editable):

    • python -m venv .venv && source .venv/bin/activate
    • pip install -r requirements-dev.txt
    • pip install -e .
  • Build distributions with Hatch:

    • make pypibuild
    • Artifacts are created under dist/

Quick Start

Simple publish and subscribe using the wrapper:

from mqttstuff.mosquittomqttwrapper import MosquittoClientWrapper

client = MosquittoClientWrapper(
    host="localhost", port=1883, username="user", password="pass",
    topics=["test/topic"],
)

def on_any_message(msg, userdata):
    # msg is an instance of MWMqttMessage with convenient fields
    print(msg.topic, msg.value)

client.set_on_msg_callback(on_any_message, rettype="valuemsg")
client.connect_and_start_loop_forever()

# elsewhere or in another process
client.publish_one("test/topic", {"hello": "world"}, retain=False)

Read last retained or recent messages with a timeout:

from mqttstuff.mosquittomqttwrapper import MQTTLastDataReader

data = MQTTLastDataReader.get_most_recent_data_with_timeout(
    host="localhost", port=1883, username="user", password="pass",
    topics=["tele/+/STATE", "stat/+/STATUS"],
    retained="only",  # "yes" | "no" | "only"
    rettype="str_raw", # or "json", "valuemsg", "str", "int", "float"
)
print(data)

Notes on configuration

This repository does not provide a central config.py anymore. Pass your MQTT connection settings directly to the wrapper (see examples above) or manage configuration in your own application code.

Python Modules

Each Python module provided by this repository is documented here with a focused explanation of its purpose and usage.

Module: mqttstuff.mosquittomqttwrapper

Key classes and responsibilities:

  • MWMqttMessage (Pydantic model)

    • Normalized container for incoming/outgoing MQTT messages
    • Helpers like from_pahomsg(...) and fields for topic, qos, retain, payload, value, created_at, and optional metadata
  • MosquittoClientWrapper

    • Thin wrapper around paho.mqtt.client.Client
    • Simplifies connection setup and topic subscriptions via set_topics([...])
    • Register callbacks per-topic (add_message_callback(topic, callback, rettype=...)) or a global callback (set_on_msg_callback)
    • Publish utilities:
      • publish_one(topic, value, created_at=None, metadata=None, rettype="valuemsg", retain=False, timeout=None)
      • publish_multiple(list[MWMqttMessage], timeout=None)
    • Connection loop helpers:
      • connect_and_start_loop_forever(topics=None, timeout_connect_seconds=None)
      • wait_for_connect_and_start_loop()
    • Convenience: automatic payload conversion for int/float/str/JSON/valuemsg
  • MQTTLastDataReader

    • Static helper to retrieve the most recent messages within a configurable timeout window
    • Supports retained-only, no-retained, or mixed operation via retained parameter
    • Returns results in different representations via rettype and fallback_rettype

Example – per-topic callback with type conversion:

from mqttstuff.mosquittomqttwrapper import MosquittoClientWrapper

client = MosquittoClientWrapper(
    host="localhost", port=1883, username="user", password="pass",
    topics=["home/+/temperature"],
)

def on_temperature(msg, userdata):
    # msg.value is already a number if rettype="int"/"float"
    print("Temp:", msg.value)

client.add_message_callback("home/+/temperature", on_temperature, rettype="float")
client.connect_and_start_loop_forever()

Module: Helper

Small utilities used across the project:

  • ComplexEncoder for JSON serialization of complex types (UUID, datetimes, dict/list pretty rendering)
  • print_pretty_dict_json, get_pretty_dict_json, get_pretty_dict_json_no_sort
  • update_deep(base, u) for deep dict/list merge/update
  • get_exception_tb_as_string(exc) for converting exception tracebacks to strings
  • get_loguru_logger_info() to introspect Loguru handlers and filters

Docker

Docker image building and publishing have been removed from this repository. If you need containerization, consider creating a separate Docker setup in your own project using this package from PyPI.

Development

Helpful Makefile targets:

  • make help – list available targets with short descriptions
  • make install – create virtualenv and install development requirements
  • make venv – ensure .venv exists and dev requirements are installed
  • make tests – run pytest
  • make lint – run Black code formatter
  • make isort – fix and check import order
  • make tcheck – run mypy type checks over *.py, scripts/, and mqttstuff/
  • make commit-checks – run pre-commit hooks on all files
  • make prepare – run tests and commit-checks (useful before committing/PRs)
  • make pypibuild – build sdist and wheel with Hatch into dist/
  • make pypipush – publish built artifacts with Hatch (configure credentials first)

Testing

Tests live under tests/. Run all tests with:

pytest -q

License

This project is licensed under the LGPL where applicable/possible — see LICENSE.md. Some files/parts may be governed by other licenses and/or licensors, such as MIT | GPL | LGPL. Please also check file headers/comments.

Acknowledgments

See inline comments in the codebase for inspirations and references.

⚠️ Disclaimer

This is a development/experimental project. For production use, review security settings, customize configurations, and test thoroughly in your environment. Provided "as is" without warranty of any kind, express or implied, including but not limited to the warranties of merchantability, fitness for a particular purpose and noninfringement. In no event shall the authors or copyright holders be liable for any claim, damages or other liability, whether in an action of contract, tort or otherwise, arising from, out of or in connection with the software or the use or other dealings in the software. Use at your own risk.

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

mqttstuff-0.0.4.tar.gz (14.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mqttstuff-0.0.4-py3-none-any.whl (13.5 kB view details)

Uploaded Python 3

File details

Details for the file mqttstuff-0.0.4.tar.gz.

File metadata

  • Download URL: mqttstuff-0.0.4.tar.gz
  • Upload date:
  • Size: 14.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: Hatch/1.16.2 cpython/3.14.2 HTTPX/0.28.1

File hashes

Hashes for mqttstuff-0.0.4.tar.gz
Algorithm Hash digest
SHA256 43c564547d7fb306fa0c25b20538ad45fdac671dc3e80c7168eece6ffa87bac4
MD5 7143361525e2886f406f328df489cc6f
BLAKE2b-256 177840c1922b350ecc7aa4086d5b9ebe9a3a377b13d123a8bb27b2ed5202436d

See more details on using hashes here.

File details

Details for the file mqttstuff-0.0.4-py3-none-any.whl.

File metadata

  • Download URL: mqttstuff-0.0.4-py3-none-any.whl
  • Upload date:
  • Size: 13.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: Hatch/1.16.2 cpython/3.14.2 HTTPX/0.28.1

File hashes

Hashes for mqttstuff-0.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 8e081bdf9a0baba6610c4a35fc4c854be7bbe17ca2d340d0a4a05232510c7e38
MD5 23f414874f4bf01c9b633cc97d13e855
BLAKE2b-256 d51cd67caa83b44c19e5f06eeb3b716c3a53408cafaee01fa5ee80af6561e163

See more details on using hashes here.

Supported by

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