Skip to content

MarcBresson/HA-MQTT-library

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

16 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

HA MQTT discovery

This library handles devices and entities to enable auto-discovery of MQTT devices in Home Assistant. It works with EspMQTTClient from https://registry.platformio.org/libraries/plapointe6/EspMQTTClient.

API

TOC

Device

Constructor

HAMqttDevice(String device_name, (optional) EspMQTTClient& client);

Construct the device object. Managing or sending availability will only work if Client provided.

Parameters

  • device_name The name of your device. It should not contains accentuated letters.
  • client The MQTT client object.

Example

EspMQTTClient client(
  WIFI_SSID,
  WIFI_PASSWORD,
  MQTT_IP,
  MQTT_USERNAME,
  MQTT_PASSWORD
);

void addConfig(const String &key, const String &value);

Custom config variables

void addConfig(const String &key, const String &value);

Add a custom config key value pair that will be used when sending the config payload to MQTT. See available device config here: https://www.home-assistant.io/integrations/sensor.mqtt/#device. Device configs are common whatever entity type (sensor, switch, button, fan etc.) you are setting up.

Parameters

  • key name of the config option.
  • value value of the config option.

Example

device.addConfig("sw_version", "0.0.1");
device.addConfig("manufacturer", "Marc Bresson");

Manage availability

void manageAvailability(uint16_t keepAliveSecond);

will send an available payload every n seconds.

Parameters

  • keepAliveSecond number of seconds to wait before sending a new available message.

Example

void loop() {
    client.loop();

    // wait 60 seconds between availability message.
    device.manageAvailability(60);
}

Other methods

Their documentations are available in the header file.

String getConfigPayload();
String getName();
String getIdentifier();
String getAvailabilityTopic();
EspMQTTClient* getClient();
void sendAvailable();
void setClient(EspMQTTClient& client);

Entity

Constructor

HAMqttEntity();
HAMqttEntity(HAMqttDevice& device, String name, Component component);

Construct the entity object. Any interaction with topics or mqtt client requires device's Client to be provided.

Parameters

  • device The device object.
  • name The entity name.
  • component What component this entity is, e.g. HAMqttEntity::SENSOR. Available components are: ALARM_CONTROL_PANEL, BINARY_SENSOR, BUTTON, CAMERA, COVER, DEVICE_TRACKER, DEVICE_TRIGGER, FAN, HUMIDIFIER, HVAC, LIGHT, LOCK, SIREN, SENSOR, SWITCH, VACUUM. If you don't see yours in this list, create an issue on my github https://github.com/MarcBresson/HA-MQTT.

Example

HAMqttEntity entityEnergy(device, "Grid Energy", HAMqttEntity::SENSOR);

Add command topic

void addCommandTopic();

Add topic where home assistant will publish commands for the entity. (see more https://www.home-assistant.io/integrations/button.mqtt/#command_topic).

Example

entitySwitch.addCommandTopic();

Add state topic

void addStateTopic();

Add topic where this entity will report its state to home assistant. . (see more https://www.home-assistant.io/integrations/switch.mqtt/#state_topic).

Example

entityEnergy.addStateTopic();

Custom config variables

void addConfig(const String &key, const String &value);

Add a custom config key value pair that will be used when sending the config payload to MQTT. See available config for mqtt sensors here: https://www.home-assistant.io/integrations/sensor.mqtt/#configuration-variables

Parameters

  • key name of the config option.
  • value value of the config option.

Example

entityEnergy.addConfig("device_class", "energy");
entityEnergy.addConfig("state_class", "total_increasing");
entityEnergy.addConfig("unit_of_measurement", "Wh");

Get state topic

void getStateTopic();

get entity state topic. If relative is false, will construct the topic with the base topic prepended. Otherwise, it will prepend "~" that HA automatically interprets with the base topic.

Parameters

  • relative whether to include "~" or full base topic.

Example

client.publish(entityEnergy.getStateTopic(), String(energyCount));

Other methods

Their documentations are available in the header file.

String getName();
String getIdentifier();
String getBaseTopic();
String getAvailabilityTopic(bool relative = false);
String getDiscoveryTopic(bool relative = false);
String getCommandTopic(bool relative = false);
String getConfigPayload();
void sendAvailable();
void setDevice(HAMqttDevice& device);
void setName(String name);
void setComponent(Component component);
void init();
EspMQTTClient* getClient();

Examples

About

handler for MQTT auto discovery in HA

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages