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);
|
||||
}
|
||||
|
||||
void publishDiscoveryTopics() {
|
||||
char buffer[1024];
|
||||
char jsonBuffer[1024];
|
||||
|
||||
for (size_t i = 0; i < shades.size(); i++) {
|
||||
Shade shade = shades[i];
|
||||
void addDeviceObject(JsonDocument &doc, const Shade& shade) {
|
||||
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 entityID = "cover-" + objectID;
|
||||
String deviceId = "hotdog-" + objectID;
|
||||
|
||||
JsonDocument doc;
|
||||
|
||||
@@ -369,15 +377,18 @@ void publishDiscoveryTopics() {
|
||||
doc["position_closed"] = 0;
|
||||
doc["optimistic"] = false;
|
||||
|
||||
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
|
||||
addDeviceObject(doc, shade);
|
||||
|
||||
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