Split discovery topic logic into smaller functions
This commit is contained in:
37
src/main.cpp
37
src/main.cpp
@@ -347,14 +347,22 @@ void publishBattery(const String& shadeName, const uint8_t battery) {
|
|||||||
client.publish("hotdog/" + shadeName + "/battery", String(battery), true);
|
client.publish("hotdog/" + shadeName + "/battery", String(battery), true);
|
||||||
}
|
}
|
||||||
|
|
||||||
void publishDiscoveryTopics() {
|
char jsonBuffer[1024];
|
||||||
char buffer[1024];
|
|
||||||
|
|
||||||
for (size_t i = 0; i < shades.size(); i++) {
|
void addDeviceObject(JsonDocument &doc, const Shade& shade) {
|
||||||
Shade shade = shades[i];
|
String deviceID = "hotdog-" + String(shade.ID, HEX);
|
||||||
|
|
||||||
|
JsonObject device = doc["device"].to<JsonObject>();
|
||||||
|
device["name"] = shade.friendlyName;
|
||||||
|
JsonArray identifiers = device["identifiers"].to<JsonArray>();
|
||||||
|
identifiers.add(deviceID);
|
||||||
|
device["manufacturer"] = "Hunter Douglas";
|
||||||
|
// TODO: Add fields like sw_version and model
|
||||||
|
}
|
||||||
|
|
||||||
|
void publishCoverDiscoveryTopic(const Shade& shade) {
|
||||||
String objectID = String(shade.ID, HEX);
|
String objectID = String(shade.ID, HEX);
|
||||||
String entityID = "cover-" + objectID;
|
String entityID = "cover-" + objectID;
|
||||||
String deviceId = "hotdog-" + objectID;
|
|
||||||
|
|
||||||
JsonDocument doc;
|
JsonDocument doc;
|
||||||
|
|
||||||
@@ -369,15 +377,18 @@ void publishDiscoveryTopics() {
|
|||||||
doc["position_closed"] = 0;
|
doc["position_closed"] = 0;
|
||||||
doc["optimistic"] = false;
|
doc["optimistic"] = false;
|
||||||
|
|
||||||
JsonObject device = doc["device"].to<JsonObject>();
|
addDeviceObject(doc, shade);
|
||||||
device["name"] = shade.friendlyName;
|
|
||||||
JsonArray identifiers = device["identifiers"].to<JsonArray>();
|
|
||||||
identifiers.add(deviceId);
|
|
||||||
device["manufacturer"] = "Hunter Douglas";
|
|
||||||
// TODO: Add fields like sw_version and model
|
|
||||||
|
|
||||||
serializeJson(doc, buffer);
|
serializeJson(doc, jsonBuffer);
|
||||||
|
|
||||||
client.publish("homeassistant/cover/" + objectID + "/config", buffer);
|
client.publish("homeassistant/cover/" + objectID + "/config", jsonBuffer);
|
||||||
|
}
|
||||||
|
|
||||||
|
void publishDiscoveryTopics() {
|
||||||
|
for (size_t i = 0; i < shades.size(); i++) {
|
||||||
|
Shade shade = shades[i];
|
||||||
|
String objectID = String(shade.ID, HEX);
|
||||||
|
|
||||||
|
publishCoverDiscoveryTopic(shade);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Reference in New Issue
Block a user