Skip to main content

MQTT client supporting Home Assistant MQTT entity auto-discovery

Project description

MQTT Entity helper library for Home Assistant

Workflow Status codecov

A Python helper library to manage Home Assistant entities over MQTT.

Updated for device based MQTT discovery.

Features:

  • MQTT client based on paho-mqtt
    • Retrieve MQTT service info from the Home Assistant Supervisor
  • Manage MQTT discovery info (adding/removing entities)
  • MQTTDevice class to manage devices
    • Availability management
    • Manage entities per device
  • Home Assistant Entities modelled as attrs classes:
    • Read-only: Sensor, BinarySensor
    • Read & write: Select, Switch, Number, Text, Light
    • MQTT device events
  • Asyncio based
  • Helpers for Home Assistant add-ons (optional)
    • Add-on configuration modeled as attrs classes
      • Load from environment variables, HA's options.yaml or options.json
      • Load MQTT connection settings from the Supervisor
    • Enable add-on logging (incl colors & debug by config)

Why?

This MQTT code was included in several of my home Assistant addons (SMA-EM / Sunsynk). It is easier to update a single library & add new features, like discovery removal.

Alternatives options (not based on asyncio)

Credits

@Ivan-L contributed some of the writable entities to the Sunsynk addon project

Release

Semantic versioning is used for release.

To create a new release, include a commit with a :dolphin: emoji as a prefix in the commit message. This will trigger a release on the master branch.

# Patch
git commit -m ":dolphin: Release 0.0.x"

# Minor
git commit -m ":rocket: Release 0.x.0"

Development

To run the tests, you need to have Python 3.12+ installed.

The --mqtt connects to a live Home Assistant instance using the MQTT broker.

uv run pytest --mqtt

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

mqtt_entity-1.1.2.tar.gz (16.8 kB view details)

Uploaded Source

Built Distribution

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

mqtt_entity-1.1.2-py3-none-any.whl (19.9 kB view details)

Uploaded Python 3

File details

Details for the file mqtt_entity-1.1.2.tar.gz.

File metadata

  • Download URL: mqtt_entity-1.1.2.tar.gz
  • Upload date:
  • Size: 16.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.10.2 {"installer":{"name":"uv","version":"0.10.2","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for mqtt_entity-1.1.2.tar.gz
Algorithm Hash digest
SHA256 47b8be590bfd29b3aa32fcfd6f3d2f069033d1793ca652c860f14ee8c9f49eb2
MD5 eb5c96a9ba09edb1c6f647bb1cbe0af0
BLAKE2b-256 259a0ab00c28e19bb59c4f8c5dc65aef46c6bc8496d1efeb2a2745259a0f18f8

See more details on using hashes here.

File details

Details for the file mqtt_entity-1.1.2-py3-none-any.whl.

File metadata

  • Download URL: mqtt_entity-1.1.2-py3-none-any.whl
  • Upload date:
  • Size: 19.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.10.2 {"installer":{"name":"uv","version":"0.10.2","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for mqtt_entity-1.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 336a0abc45eaf2eef97f893bb1f1fc5ba7e81b416093109f8ee94c1046533a4c
MD5 23b993a79ae2956001b4f393cbce7197
BLAKE2b-256 e0539bb9a357fe6593bf8dd94fb93fe885709a8c4d7282c0cd75abec7c96f933

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