Initial HASS autodiscovery support
This commit is contained in:
@@ -76,6 +76,7 @@ void NukiWrapper::update()
|
||||
if (_nukiLock.pairNuki() == Nuki::PairingResult::Success) {
|
||||
Serial.println(F("Nuki paired"));
|
||||
_paired = true;
|
||||
setupHASS();
|
||||
}
|
||||
else
|
||||
{
|
||||
@@ -321,3 +322,23 @@ void NukiWrapper::readAdvancedConfig()
|
||||
_nukiAdvancedConfigValid = result == Nuki::CmdResult::Success;
|
||||
Serial.println(result);
|
||||
}
|
||||
|
||||
void NukiWrapper::setupHASS()
|
||||
{
|
||||
if(!_nukiConfigValid) // only ask for config once to save battery life
|
||||
{
|
||||
Nuki::CmdResult result = _nukiLock.requestConfig(&_nukiConfig);
|
||||
_nukiConfigValid = result == Nuki::CmdResult::Success;
|
||||
}
|
||||
if (_nukiConfigValid)
|
||||
{
|
||||
String baseTopic = _preferences->getString(preference_mqtt_lock_path);
|
||||
char uidString[20];
|
||||
itoa(_nukiConfig.nukiId, uidString, 16);
|
||||
_network->publishHASSConfig(baseTopic.c_str(),(char*)_nukiConfig.name,uidString,"lock","unlock","unlatch","locked","unlocked");
|
||||
}
|
||||
else
|
||||
{
|
||||
Serial.println(F("Unable to setup HASS. Invalid config received."));
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user