Skip to content

elbowz/ha-homie

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

46 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Issues GPL License Homie HA LinkedIn

HA Homie

Homie integration for Home Assistant

Autodiscover and/or manual Homie devices configuration


About The Project

This HomeAssistant integration is born (and maybe will dead) as University project. The project was started from the old, abandoned and closed issue Compatibility with Home Assistant MQTT Discovery.

Getting Started

Installation

Download the zip from Code/Download ZIP and uncompress the homie folder in the HA custom_components directory:

cd YOUR_HA_CONFIG_DIRECTORY		# same place as configuration.yaml
mkdir -p custom_components/homie
unzip ha-homie-master.zip 
mv ha-homie-master/homie custom_components
rm ha-homie-master.zip

Alternatively, you can install the current GitHub master version by cloning and copying:

mkdir SOME_LOCAL_WORKSPACE
cd SOME_LOCAL_WORKSPACE
git clone https://github.com/elbowz/ha-homie.git
mkdir -p YOUR_HASS_CONFIG_DIRECTORY/custom_components
cp -r ha-homie/homie YOUR_HASS_CONFIG_DIRECTORY/custom_components

Restart Home assistant

tip: if you have some Homie devices in your network, you should already see the discovery tile in home assistant, that advice to configure this integration

Configuration

Go to the Integrations menu in the Home Assistant Configuration UI and add Homie from there.

Alternatively, add homie: to <config>/configuration.yaml.

note: you can use yaml configuration or UI configuration, but remember that the UI options overwrite the yaml config.

homie:
  base_topic: +
  qos: 2
  discovery: true

The Homie base discovery topic is +/+/$homie. You can restrict using the base_topic option.

eg. base_topic = root => the discovery topic become: root/+/$homie

Manual Configuration

With discovery: true all the recognised devices properties (and related attributes) are added in HA as entities. But you also can add them manually and set preferred attributes by configuration.yaml as platform. You can use it with or without discovery activated.

The supported platfrom are:

  • Switch
  • Binary sensor
  • Sensor
  • Number

configuration.yaml switch example:

switch:
  - platform: homie
    name: Led light
    icon: mdi:lightbulb-variant-outline
    #enabled_by_default: true # default
    #qos: 1 # default
    property:
      device: device-id
      node: node-id
      name: property-id
    #property_topic: device-id/node-id/property-id # alternative to "property"
    #optimistic: false # default
    device_class: outlet

tip: enable discovery and take base_topic from HA entity attributes. There will find also stored other device information (eg. stats, IP, etc...)

Shared config options between platform

name: name displayed
icon: icon
unique_id: id # use if you know
enabled_by_default: true # default
qos: 1 # default
property:
  device: device-id
  node: node-id
  name: property-id
property_topic: device-id/node-id/property-id # alternative to "property"
key default description
property_topic none alternative to property key. Allow a plenty of topic format
(eg. root/device-id/node-id/property-id, device-id/node-id/property-id, /device-id/node-id/property-id)
enabled_by_default true don't display in HA Dashboard but still in entities registry
unique_id none the unique key used internally by HA to store entity information

Switch

optimistic: false # default
device_class: # see https://www.home-assistant.io/integrations/switch/#device-class

Sensor

unit_of_measurement: C
device_class: # see https://www.home-assistant.io/integrations/sensor/#device-class

Binary sensor

off_delay: 6 # second delay to off
device_class: # see https://www.home-assistant.io/integrations/binary_sensor/#device-class

Number

min: 2.0
max: 10.0
step: 1.0
optimistic: false # default
mode: auto/slider/box
unit_of_measurement: s

Integration development

For didactic purpose (or who is interested) here can see information/documentation about the Homie custom component development model.

Class Diagram

class diagram

Activity Diagram

class diagram

💖 Support the project

I open-source almost everything I can. If you are using this project and are happy with it, please consider one of these ways to support the project (and me):

  • Giving proper credit when you use it, linking back to it :D
  • Starring 🌟 and sharing the project 🚀
  • Submit PRs, bug reports and feature requests
  • Paypal Make one-time donations via PayPal. I'll probably buy a 🍺

Thanks! ❤️

License

Distributed under the GPL License. See LICENSE for more information.

Credits