Skip to main content

Home Assistant Control Objects

Project description

haco Home Assistant Control Objects

haco is a to greatly simplify the process of exposing Home Assistant controls (e.g. Pull-down Lists, Number Sliders, Sensors, etc.) from a device - and handling the communication between both sides.

While the current implementation is in Python, the capability definitions for controls are designed to be shared across different languages. Support for additional languages (namely native support for Tasmota Berry) is planned.

Why MQTT?

You might wonder why we use MQTT instead of directly using Home Assistant's APIs. The reason is flexibility: using MQTT allows haco to target any device or environment that has an MQTT client, not just those that can easily make HTTP requests or run a full HA integration. This makes it ideal for lightweight embedded systems and cross-platform utility.

Why Would I Want Such a Thing?

Integrating custom hardware or scripts with Home Assistant often involves a lot of boilerplate: defining MQTT topics, crafting JSON payloads for discovery, and managing state updates. haco handles the heavy lifting, letting you define your device and its controls in clean, declarative Python.

If you're building a custom IoT device, a script to monitor your system, or just want a simpler way to bridge your code to Home Assistant, then you might find haco useful.

How it Works

haco uses MQTT to communicate with Home Assistant. It automatically generates the discovery configurations required for Home Assistant to "see" your device and its entities. All you need to do is define a Device with some Controls and start the ClientHaco.

Documentation

See Documentation

Project details


Release history Release notifications | RSS feed

This version

0.3.2

Download files

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

Source Distribution

haco-0.3.2.tar.gz (16.2 kB view details)

Uploaded Source

Built Distribution

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

haco-0.3.2-py3-none-any.whl (21.3 kB view details)

Uploaded Python 3

File details

Details for the file haco-0.3.2.tar.gz.

File metadata

  • Download URL: haco-0.3.2.tar.gz
  • Upload date:
  • Size: 16.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.7

File hashes

Hashes for haco-0.3.2.tar.gz
Algorithm Hash digest
SHA256 f0fb9bd24ed16af614aca586cd81c24d24b25c54bd7c52f2297ff043b5d78eec
MD5 2f8b7707e92a3e6e43823eb531bf1792
BLAKE2b-256 2211eba4b8c1b7505ca86e887d10fd1d720350eadb2d6bd285656215f796c989

See more details on using hashes here.

File details

Details for the file haco-0.3.2-py3-none-any.whl.

File metadata

  • Download URL: haco-0.3.2-py3-none-any.whl
  • Upload date:
  • Size: 21.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.7

File hashes

Hashes for haco-0.3.2-py3-none-any.whl
Algorithm Hash digest
SHA256 d2f6c8cf6977fd3dea5a1b73b8c214d3200172283f859308f63c9a9a99aadd9d
MD5 10c62cb5716171c6647096aaad63dee1
BLAKE2b-256 703dbd3bf1909699bf3c23534abb9ccaba4b41be0994417808cafe59af522513

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