mirror of
https://github.com/esphome/esphome.git
synced 2025-10-18 09:43:47 +01:00
simplify
This commit is contained in:
@@ -45,24 +45,7 @@ static const char *const TAG = "mdns";
|
|||||||
#define USE_WEBSERVER_PORT 80 // NOLINT
|
#define USE_WEBSERVER_PORT 80 // NOLINT
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Define all constant strings using the macro
|
// Define constant strings for values (PROGMEM on ESP8266, regular flash on others)
|
||||||
MDNS_STATIC_CONST_CHAR(SERVICE_ESPHOMELIB, "_esphomelib");
|
|
||||||
MDNS_STATIC_CONST_CHAR(SERVICE_TCP, "_tcp");
|
|
||||||
MDNS_STATIC_CONST_CHAR(SERVICE_PROMETHEUS, "_prometheus-http");
|
|
||||||
MDNS_STATIC_CONST_CHAR(SERVICE_HTTP, "_http");
|
|
||||||
|
|
||||||
MDNS_STATIC_CONST_CHAR(TXT_FRIENDLY_NAME, "friendly_name");
|
|
||||||
MDNS_STATIC_CONST_CHAR(TXT_VERSION, "version");
|
|
||||||
MDNS_STATIC_CONST_CHAR(TXT_MAC, "mac");
|
|
||||||
MDNS_STATIC_CONST_CHAR(TXT_PLATFORM, "platform");
|
|
||||||
MDNS_STATIC_CONST_CHAR(TXT_BOARD, "board");
|
|
||||||
MDNS_STATIC_CONST_CHAR(TXT_NETWORK, "network");
|
|
||||||
MDNS_STATIC_CONST_CHAR(TXT_API_ENCRYPTION, "api_encryption");
|
|
||||||
MDNS_STATIC_CONST_CHAR(TXT_API_ENCRYPTION_SUPPORTED, "api_encryption_supported");
|
|
||||||
MDNS_STATIC_CONST_CHAR(TXT_PROJECT_NAME, "project_name");
|
|
||||||
MDNS_STATIC_CONST_CHAR(TXT_PROJECT_VERSION, "project_version");
|
|
||||||
MDNS_STATIC_CONST_CHAR(TXT_PACKAGE_IMPORT_URL, "package_import_url");
|
|
||||||
|
|
||||||
MDNS_STATIC_CONST_CHAR(PLATFORM_ESP8266, "ESP8266");
|
MDNS_STATIC_CONST_CHAR(PLATFORM_ESP8266, "ESP8266");
|
||||||
MDNS_STATIC_CONST_CHAR(PLATFORM_ESP32, "ESP32");
|
MDNS_STATIC_CONST_CHAR(PLATFORM_ESP32, "ESP32");
|
||||||
MDNS_STATIC_CONST_CHAR(PLATFORM_RP2040, "RP2040");
|
MDNS_STATIC_CONST_CHAR(PLATFORM_RP2040, "RP2040");
|
||||||
@@ -80,8 +63,8 @@ void MDNSComponent::compile_records_() {
|
|||||||
#ifdef USE_API
|
#ifdef USE_API
|
||||||
if (api::global_api_server != nullptr) {
|
if (api::global_api_server != nullptr) {
|
||||||
auto &service = this->services_.emplace_next();
|
auto &service = this->services_.emplace_next();
|
||||||
service.service_type = MDNS_STR(SERVICE_ESPHOMELIB);
|
service.service_type = "_esphomelib";
|
||||||
service.proto = MDNS_STR(SERVICE_TCP);
|
service.proto = "_tcp";
|
||||||
service.port = api::global_api_server->get_port();
|
service.port = api::global_api_server->get_port();
|
||||||
|
|
||||||
const std::string &friendly_name = App.get_friendly_name();
|
const std::string &friendly_name = App.get_friendly_name();
|
||||||
@@ -112,62 +95,62 @@ void MDNSComponent::compile_records_() {
|
|||||||
txt_records.reserve(txt_count);
|
txt_records.reserve(txt_count);
|
||||||
|
|
||||||
if (!friendly_name_empty) {
|
if (!friendly_name_empty) {
|
||||||
txt_records.push_back({MDNS_STR(TXT_FRIENDLY_NAME), friendly_name});
|
txt_records.push_back({"friendly_name", friendly_name});
|
||||||
}
|
}
|
||||||
txt_records.push_back({MDNS_STR(TXT_VERSION), ESPHOME_VERSION});
|
txt_records.push_back({"version", ESPHOME_VERSION});
|
||||||
txt_records.push_back({MDNS_STR(TXT_MAC), get_mac_address()});
|
txt_records.push_back({"mac", get_mac_address()});
|
||||||
|
|
||||||
#ifdef USE_ESP8266
|
#ifdef USE_ESP8266
|
||||||
txt_records.push_back({MDNS_STR(TXT_PLATFORM), MDNS_STR(PLATFORM_ESP8266)});
|
txt_records.push_back({"platform", MDNS_STR(PLATFORM_ESP8266)});
|
||||||
#elif defined(USE_ESP32)
|
#elif defined(USE_ESP32)
|
||||||
txt_records.push_back({MDNS_STR(TXT_PLATFORM), MDNS_STR(PLATFORM_ESP32)});
|
txt_records.push_back({"platform", MDNS_STR(PLATFORM_ESP32)});
|
||||||
#elif defined(USE_RP2040)
|
#elif defined(USE_RP2040)
|
||||||
txt_records.push_back({MDNS_STR(TXT_PLATFORM), MDNS_STR(PLATFORM_RP2040)});
|
txt_records.push_back({"platform", MDNS_STR(PLATFORM_RP2040)});
|
||||||
#elif defined(USE_LIBRETINY)
|
#elif defined(USE_LIBRETINY)
|
||||||
txt_records.emplace_back(MDNSTXTRecord{"platform", lt_cpu_get_model_name()});
|
txt_records.emplace_back(MDNSTXTRecord{"platform", lt_cpu_get_model_name()});
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
txt_records.push_back({MDNS_STR(TXT_BOARD), ESPHOME_BOARD});
|
txt_records.push_back({"board", ESPHOME_BOARD});
|
||||||
|
|
||||||
#if defined(USE_WIFI)
|
#if defined(USE_WIFI)
|
||||||
txt_records.push_back({MDNS_STR(TXT_NETWORK), MDNS_STR(NETWORK_WIFI)});
|
txt_records.push_back({"network", MDNS_STR(NETWORK_WIFI)});
|
||||||
#elif defined(USE_ETHERNET)
|
#elif defined(USE_ETHERNET)
|
||||||
txt_records.push_back({MDNS_STR(TXT_NETWORK), MDNS_STR(NETWORK_ETHERNET)});
|
txt_records.push_back({"network", MDNS_STR(NETWORK_ETHERNET)});
|
||||||
#elif defined(USE_OPENTHREAD)
|
#elif defined(USE_OPENTHREAD)
|
||||||
txt_records.push_back({MDNS_STR(TXT_NETWORK), MDNS_STR(NETWORK_THREAD)});
|
txt_records.push_back({"network", MDNS_STR(NETWORK_THREAD)});
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef USE_API_NOISE
|
#ifdef USE_API_NOISE
|
||||||
MDNS_STATIC_CONST_CHAR(NOISE_ENCRYPTION, "Noise_NNpsk0_25519_ChaChaPoly_SHA256");
|
MDNS_STATIC_CONST_CHAR(NOISE_ENCRYPTION, "Noise_NNpsk0_25519_ChaChaPoly_SHA256");
|
||||||
if (api::global_api_server->get_noise_ctx()->has_psk()) {
|
if (api::global_api_server->get_noise_ctx()->has_psk()) {
|
||||||
txt_records.push_back({MDNS_STR(TXT_API_ENCRYPTION), MDNS_STR(NOISE_ENCRYPTION)});
|
txt_records.push_back({"api_encryption", MDNS_STR(NOISE_ENCRYPTION)});
|
||||||
} else {
|
} else {
|
||||||
txt_records.push_back({MDNS_STR(TXT_API_ENCRYPTION_SUPPORTED), MDNS_STR(NOISE_ENCRYPTION)});
|
txt_records.push_back({"api_encryption_supported", MDNS_STR(NOISE_ENCRYPTION)});
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef ESPHOME_PROJECT_NAME
|
#ifdef ESPHOME_PROJECT_NAME
|
||||||
txt_records.push_back({MDNS_STR(TXT_PROJECT_NAME), ESPHOME_PROJECT_NAME});
|
txt_records.push_back({"project_name", ESPHOME_PROJECT_NAME});
|
||||||
txt_records.push_back({MDNS_STR(TXT_PROJECT_VERSION), ESPHOME_PROJECT_VERSION});
|
txt_records.push_back({"project_version", ESPHOME_PROJECT_VERSION});
|
||||||
#endif // ESPHOME_PROJECT_NAME
|
#endif // ESPHOME_PROJECT_NAME
|
||||||
|
|
||||||
#ifdef USE_DASHBOARD_IMPORT
|
#ifdef USE_DASHBOARD_IMPORT
|
||||||
txt_records.push_back({MDNS_STR(TXT_PACKAGE_IMPORT_URL), dashboard_import::get_package_import_url()});
|
txt_records.push_back({"package_import_url", dashboard_import::get_package_import_url()});
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
#endif // USE_API
|
#endif // USE_API
|
||||||
|
|
||||||
#ifdef USE_PROMETHEUS
|
#ifdef USE_PROMETHEUS
|
||||||
auto &prom_service = this->services_.emplace_next();
|
auto &prom_service = this->services_.emplace_next();
|
||||||
prom_service.service_type = MDNS_STR(SERVICE_PROMETHEUS);
|
prom_service.service_type = "_prometheus-http";
|
||||||
prom_service.proto = MDNS_STR(SERVICE_TCP);
|
prom_service.proto = "_tcp";
|
||||||
prom_service.port = USE_WEBSERVER_PORT;
|
prom_service.port = USE_WEBSERVER_PORT;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef USE_WEBSERVER
|
#ifdef USE_WEBSERVER
|
||||||
auto &web_service = this->services_.emplace_next();
|
auto &web_service = this->services_.emplace_next();
|
||||||
web_service.service_type = MDNS_STR(SERVICE_HTTP);
|
web_service.service_type = "_http";
|
||||||
web_service.proto = MDNS_STR(SERVICE_TCP);
|
web_service.proto = "_tcp";
|
||||||
web_service.port = USE_WEBSERVER_PORT;
|
web_service.port = USE_WEBSERVER_PORT;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@@ -20,10 +20,10 @@ struct MDNSTXTRecord {
|
|||||||
struct MDNSService {
|
struct MDNSService {
|
||||||
// service name _including_ underscore character prefix
|
// service name _including_ underscore character prefix
|
||||||
// as defined in RFC6763 Section 7
|
// as defined in RFC6763 Section 7
|
||||||
std::string service_type;
|
const char *service_type;
|
||||||
// second label indicating protocol _including_ underscore character prefix
|
// second label indicating protocol _including_ underscore character prefix
|
||||||
// as defined in RFC6763 Section 7, like "_tcp" or "_udp"
|
// as defined in RFC6763 Section 7, like "_tcp" or "_udp"
|
||||||
std::string proto;
|
const char *proto;
|
||||||
TemplatableValue<uint16_t> port;
|
TemplatableValue<uint16_t> port;
|
||||||
std::vector<MDNSTXTRecord> txt_records;
|
std::vector<MDNSTXTRecord> txt_records;
|
||||||
};
|
};
|
||||||
|
@@ -21,11 +21,11 @@ void MDNSComponent::setup() {
|
|||||||
// part of the wire protocol to have an underscore, and for example ESP-IDF
|
// part of the wire protocol to have an underscore, and for example ESP-IDF
|
||||||
// expects the underscore to be there, the ESP8266 implementation always adds
|
// expects the underscore to be there, the ESP8266 implementation always adds
|
||||||
// the underscore itself.
|
// the underscore itself.
|
||||||
auto *proto = service.proto.c_str();
|
auto *proto = service.proto;
|
||||||
while (*proto == '_') {
|
while (*proto == '_') {
|
||||||
proto++;
|
proto++;
|
||||||
}
|
}
|
||||||
auto *service_type = service.service_type.c_str();
|
auto *service_type = service.service_type;
|
||||||
while (*service_type == '_') {
|
while (*service_type == '_') {
|
||||||
service_type++;
|
service_type++;
|
||||||
}
|
}
|
||||||
|
@@ -21,11 +21,11 @@ void MDNSComponent::setup() {
|
|||||||
// part of the wire protocol to have an underscore, and for example ESP-IDF
|
// part of the wire protocol to have an underscore, and for example ESP-IDF
|
||||||
// expects the underscore to be there, the ESP8266 implementation always adds
|
// expects the underscore to be there, the ESP8266 implementation always adds
|
||||||
// the underscore itself.
|
// the underscore itself.
|
||||||
auto *proto = service.proto.c_str();
|
auto *proto = service.proto;
|
||||||
while (*proto == '_') {
|
while (*proto == '_') {
|
||||||
proto++;
|
proto++;
|
||||||
}
|
}
|
||||||
auto *service_type = service.service_type.c_str();
|
auto *service_type = service.service_type;
|
||||||
while (*service_type == '_') {
|
while (*service_type == '_') {
|
||||||
service_type++;
|
service_type++;
|
||||||
}
|
}
|
||||||
|
@@ -21,11 +21,11 @@ void MDNSComponent::setup() {
|
|||||||
// part of the wire protocol to have an underscore, and for example ESP-IDF
|
// part of the wire protocol to have an underscore, and for example ESP-IDF
|
||||||
// expects the underscore to be there, the ESP8266 implementation always adds
|
// expects the underscore to be there, the ESP8266 implementation always adds
|
||||||
// the underscore itself.
|
// the underscore itself.
|
||||||
auto *proto = service.proto.c_str();
|
auto *proto = service.proto;
|
||||||
while (*proto == '_') {
|
while (*proto == '_') {
|
||||||
proto++;
|
proto++;
|
||||||
}
|
}
|
||||||
auto *service_type = service.service_type.c_str();
|
auto *service_type = service.service_type;
|
||||||
while (*service_type == '_') {
|
while (*service_type == '_') {
|
||||||
service_type++;
|
service_type++;
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user