mirror of
https://github.com/esphome/esphome.git
synced 2025-10-14 15:53:48 +01:00
Merge branch 'mdns_esp32_cleanup' into integration
This commit is contained in:
@@ -9,24 +9,23 @@
|
|||||||
#include <pgmspace.h>
|
#include <pgmspace.h>
|
||||||
// Macro to define strings in PROGMEM on ESP8266, regular memory on other platforms
|
// Macro to define strings in PROGMEM on ESP8266, regular memory on other platforms
|
||||||
#define MDNS_STATIC_CONST_CHAR(name, value) static const char name[] PROGMEM = value
|
#define MDNS_STATIC_CONST_CHAR(name, value) static const char name[] PROGMEM = value
|
||||||
// Helper to get string from PROGMEM - returns a temporary std::string
|
#define MDNS_STR(name) (reinterpret_cast<const MDNSString *>(name))
|
||||||
|
// Helper to convert PROGMEM string to std::string for TemplatableValue
|
||||||
// Only define this function if we have services that will use it
|
// Only define this function if we have services that will use it
|
||||||
#if defined(USE_API) || defined(USE_PROMETHEUS) || defined(USE_WEBSERVER) || defined(USE_MDNS_EXTRA_SERVICES)
|
#if defined(USE_API) || defined(USE_PROMETHEUS) || defined(USE_WEBSERVER) || defined(USE_MDNS_EXTRA_SERVICES)
|
||||||
static std::string mdns_string_p(const char *src) {
|
static std::string mdns_str_value(PGM_P str) {
|
||||||
char buf[64];
|
char buf[64];
|
||||||
strncpy_P(buf, src, sizeof(buf) - 1);
|
strncpy_P(buf, str, sizeof(buf) - 1);
|
||||||
buf[sizeof(buf) - 1] = '\0';
|
buf[sizeof(buf) - 1] = '\0';
|
||||||
return std::string(buf);
|
return std::string(buf);
|
||||||
}
|
}
|
||||||
#define MDNS_STR(name) mdns_string_p(name)
|
#define MDNS_STR_VALUE(name) mdns_str_value(name)
|
||||||
#else
|
|
||||||
// If no services are configured, we still need the fallback service but it uses string literals
|
|
||||||
#define MDNS_STR(name) std::string(name)
|
|
||||||
#endif
|
#endif
|
||||||
#else
|
#else
|
||||||
// On non-ESP8266 platforms, use regular const char*
|
// On non-ESP8266 platforms, use regular const char*
|
||||||
#define MDNS_STATIC_CONST_CHAR(name, value) static constexpr const char *name = value
|
#define MDNS_STATIC_CONST_CHAR(name, value) static constexpr const char name[] = value
|
||||||
#define MDNS_STR(name) name
|
#define MDNS_STR(name) (reinterpret_cast<const MDNSString *>(name))
|
||||||
|
#define MDNS_STR_VALUE(name) std::string(name)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef USE_API
|
#ifdef USE_API
|
||||||
@@ -45,7 +44,24 @@ static const char *const TAG = "mdns";
|
|||||||
#define USE_WEBSERVER_PORT 80 // NOLINT
|
#define USE_WEBSERVER_PORT 80 // NOLINT
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Define constant strings for values (PROGMEM on ESP8266, static pointers on others)
|
// Define all constant strings using the macro
|
||||||
|
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");
|
||||||
@@ -63,8 +79,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 = "_esphomelib";
|
service.service_type = MDNS_STR(SERVICE_ESPHOMELIB);
|
||||||
service.proto = "_tcp";
|
service.proto = MDNS_STR(SERVICE_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();
|
||||||
@@ -95,62 +111,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({"friendly_name", friendly_name});
|
txt_records.push_back({MDNS_STR(TXT_FRIENDLY_NAME), friendly_name});
|
||||||
}
|
}
|
||||||
txt_records.push_back({"version", ESPHOME_VERSION});
|
txt_records.push_back({MDNS_STR(TXT_VERSION), ESPHOME_VERSION});
|
||||||
txt_records.push_back({"mac", get_mac_address()});
|
txt_records.push_back({MDNS_STR(TXT_MAC), get_mac_address()});
|
||||||
|
|
||||||
#ifdef USE_ESP8266
|
#ifdef USE_ESP8266
|
||||||
txt_records.push_back({"platform", MDNS_STR(PLATFORM_ESP8266)});
|
txt_records.push_back({MDNS_STR(TXT_PLATFORM), MDNS_STR_VALUE(PLATFORM_ESP8266)});
|
||||||
#elif defined(USE_ESP32)
|
#elif defined(USE_ESP32)
|
||||||
txt_records.push_back({"platform", MDNS_STR(PLATFORM_ESP32)});
|
txt_records.push_back({MDNS_STR(TXT_PLATFORM), MDNS_STR_VALUE(PLATFORM_ESP32)});
|
||||||
#elif defined(USE_RP2040)
|
#elif defined(USE_RP2040)
|
||||||
txt_records.push_back({"platform", MDNS_STR(PLATFORM_RP2040)});
|
txt_records.push_back({MDNS_STR(TXT_PLATFORM), MDNS_STR_VALUE(PLATFORM_RP2040)});
|
||||||
#elif defined(USE_LIBRETINY)
|
#elif defined(USE_LIBRETINY)
|
||||||
txt_records.emplace_back(MDNSTXTRecord{"platform", lt_cpu_get_model_name()});
|
txt_records.push_back({MDNS_STR(TXT_PLATFORM), lt_cpu_get_model_name()});
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
txt_records.push_back({"board", ESPHOME_BOARD});
|
txt_records.push_back({MDNS_STR(TXT_BOARD), ESPHOME_BOARD});
|
||||||
|
|
||||||
#if defined(USE_WIFI)
|
#if defined(USE_WIFI)
|
||||||
txt_records.push_back({"network", MDNS_STR(NETWORK_WIFI)});
|
txt_records.push_back({MDNS_STR(TXT_NETWORK), MDNS_STR_VALUE(NETWORK_WIFI)});
|
||||||
#elif defined(USE_ETHERNET)
|
#elif defined(USE_ETHERNET)
|
||||||
txt_records.push_back({"network", MDNS_STR(NETWORK_ETHERNET)});
|
txt_records.push_back({MDNS_STR(TXT_NETWORK), MDNS_STR_VALUE(NETWORK_ETHERNET)});
|
||||||
#elif defined(USE_OPENTHREAD)
|
#elif defined(USE_OPENTHREAD)
|
||||||
txt_records.push_back({"network", MDNS_STR(NETWORK_THREAD)});
|
txt_records.push_back({MDNS_STR(TXT_NETWORK), MDNS_STR_VALUE(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({"api_encryption", MDNS_STR(NOISE_ENCRYPTION)});
|
txt_records.push_back({MDNS_STR(TXT_API_ENCRYPTION), MDNS_STR_VALUE(NOISE_ENCRYPTION)});
|
||||||
} else {
|
} else {
|
||||||
txt_records.push_back({"api_encryption_supported", MDNS_STR(NOISE_ENCRYPTION)});
|
txt_records.push_back({MDNS_STR(TXT_API_ENCRYPTION_SUPPORTED), MDNS_STR_VALUE(NOISE_ENCRYPTION)});
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef ESPHOME_PROJECT_NAME
|
#ifdef ESPHOME_PROJECT_NAME
|
||||||
txt_records.push_back({"project_name", ESPHOME_PROJECT_NAME});
|
txt_records.push_back({MDNS_STR(TXT_PROJECT_NAME), ESPHOME_PROJECT_NAME});
|
||||||
txt_records.push_back({"project_version", ESPHOME_PROJECT_VERSION});
|
txt_records.push_back({MDNS_STR(TXT_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({"package_import_url", dashboard_import::get_package_import_url()});
|
txt_records.push_back({MDNS_STR(TXT_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 = "_prometheus-http";
|
prom_service.service_type = MDNS_STR(SERVICE_PROMETHEUS);
|
||||||
prom_service.proto = "_tcp";
|
prom_service.proto = MDNS_STR(SERVICE_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 = "_http";
|
web_service.service_type = MDNS_STR(SERVICE_HTTP);
|
||||||
web_service.proto = "_tcp";
|
web_service.proto = MDNS_STR(SERVICE_TCP);
|
||||||
web_service.port = USE_WEBSERVER_PORT;
|
web_service.port = USE_WEBSERVER_PORT;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@@ -158,10 +174,10 @@ void MDNSComponent::compile_records_() {
|
|||||||
// Publish "http" service if not using native API or any other services
|
// Publish "http" service if not using native API or any other services
|
||||||
// This is just to have *some* mDNS service so that .local resolution works
|
// This is just to have *some* mDNS service so that .local resolution works
|
||||||
auto &fallback_service = this->services_.emplace_next();
|
auto &fallback_service = this->services_.emplace_next();
|
||||||
fallback_service.service_type = "_http";
|
fallback_service.service_type = MDNS_STR(SERVICE_HTTP);
|
||||||
fallback_service.proto = "_tcp";
|
fallback_service.proto = MDNS_STR(SERVICE_TCP);
|
||||||
fallback_service.port = USE_WEBSERVER_PORT;
|
fallback_service.port = USE_WEBSERVER_PORT;
|
||||||
fallback_service.txt_records.emplace_back(MDNSTXTRecord{"version", ESPHOME_VERSION});
|
fallback_service.txt_records.push_back({MDNS_STR(TXT_VERSION), ESPHOME_VERSION});
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -173,10 +189,10 @@ void MDNSComponent::dump_config() {
|
|||||||
#if ESPHOME_LOG_LEVEL >= ESPHOME_LOG_LEVEL_VERBOSE
|
#if ESPHOME_LOG_LEVEL >= ESPHOME_LOG_LEVEL_VERBOSE
|
||||||
ESP_LOGV(TAG, " Services:");
|
ESP_LOGV(TAG, " Services:");
|
||||||
for (const auto &service : this->services_) {
|
for (const auto &service : this->services_) {
|
||||||
ESP_LOGV(TAG, " - %s, %s, %d", service.service_type, service.proto,
|
ESP_LOGV(TAG, " - %s, %s, %d", MDNS_STR_ARG(service.service_type), MDNS_STR_ARG(service.proto),
|
||||||
const_cast<TemplatableValue<uint16_t> &>(service.port).value());
|
const_cast<TemplatableValue<uint16_t> &>(service.port).value());
|
||||||
for (const auto &record : service.txt_records) {
|
for (const auto &record : service.txt_records) {
|
||||||
ESP_LOGV(TAG, " TXT: %s = %s", record.key,
|
ESP_LOGV(TAG, " TXT: %s = %s", MDNS_STR_ARG(record.key),
|
||||||
const_cast<TemplatableValue<std::string> &>(record.value).value().c_str());
|
const_cast<TemplatableValue<std::string> &>(record.value).value().c_str());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -9,21 +9,31 @@
|
|||||||
namespace esphome {
|
namespace esphome {
|
||||||
namespace mdns {
|
namespace mdns {
|
||||||
|
|
||||||
|
// Helper struct that identifies strings that may be stored in flash storage (similar to LogString)
|
||||||
|
struct MDNSString;
|
||||||
|
|
||||||
|
#ifdef USE_ESP8266
|
||||||
|
#include <pgmspace.h>
|
||||||
|
#define MDNS_STR_ARG(s) ((PGM_P) (s))
|
||||||
|
#else
|
||||||
|
#define MDNS_STR_ARG(s) (reinterpret_cast<const char *>(s))
|
||||||
|
#endif
|
||||||
|
|
||||||
// Service count is calculated at compile time by Python codegen
|
// Service count is calculated at compile time by Python codegen
|
||||||
// MDNS_SERVICE_COUNT will always be defined
|
// MDNS_SERVICE_COUNT will always be defined
|
||||||
|
|
||||||
struct MDNSTXTRecord {
|
struct MDNSTXTRecord {
|
||||||
const char *key;
|
const MDNSString *key;
|
||||||
TemplatableValue<std::string> value;
|
TemplatableValue<std::string> value;
|
||||||
};
|
};
|
||||||
|
|
||||||
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
|
||||||
const char *service_type;
|
const MDNSString *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"
|
||||||
const char *proto;
|
const MDNSString *proto;
|
||||||
TemplatableValue<uint16_t> port;
|
TemplatableValue<uint16_t> port;
|
||||||
std::vector<MDNSTXTRecord> txt_records;
|
std::vector<MDNSTXTRecord> txt_records;
|
||||||
};
|
};
|
||||||
|
@@ -30,21 +30,22 @@ void MDNSComponent::setup() {
|
|||||||
for (const auto &record : service.txt_records) {
|
for (const auto &record : service.txt_records) {
|
||||||
mdns_txt_item_t it{};
|
mdns_txt_item_t it{};
|
||||||
// key is a compile-time string literal in flash, no need to strdup
|
// key is a compile-time string literal in flash, no need to strdup
|
||||||
it.key = record.key;
|
it.key = MDNS_STR_ARG(record.key);
|
||||||
// value is a temporary from TemplatableValue, must strdup to keep it alive
|
// value is a temporary from TemplatableValue, must strdup to keep it alive
|
||||||
it.value = strdup(const_cast<TemplatableValue<std::string> &>(record.value).value().c_str());
|
it.value = strdup(const_cast<TemplatableValue<std::string> &>(record.value).value().c_str());
|
||||||
txt_records.push_back(it);
|
txt_records.push_back(it);
|
||||||
}
|
}
|
||||||
uint16_t port = const_cast<TemplatableValue<uint16_t> &>(service.port).value();
|
uint16_t port = const_cast<TemplatableValue<uint16_t> &>(service.port).value();
|
||||||
err = mdns_service_add(nullptr, service.service_type, service.proto, port, txt_records.data(), txt_records.size());
|
err = mdns_service_add(nullptr, MDNS_STR_ARG(service.service_type), MDNS_STR_ARG(service.proto), port,
|
||||||
|
txt_records.data(), txt_records.size());
|
||||||
|
|
||||||
// free records
|
// free records
|
||||||
for (const auto &it : txt_records) {
|
for (const auto &it : txt_records) {
|
||||||
free((void *) it.value); // NOLINT(cppcoreguidelines-owning-memory,cppcoreguidelines-pro-type-cstyle-cast)
|
free((void *) it.value); // NOLINT(cppcoreguidelines-no-malloc)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (err != ESP_OK) {
|
if (err != ESP_OK) {
|
||||||
ESP_LOGW(TAG, "Failed to register service %s: %s", service.service_type, esp_err_to_name(err));
|
ESP_LOGW(TAG, "Failed to register service %s: %s", MDNS_STR_ARG(service.service_type), esp_err_to_name(err));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -21,18 +21,18 @@ 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;
|
auto *proto = MDNS_STR_ARG(service.proto);
|
||||||
while (*proto == '_') {
|
while (progmem_read_byte((const uint8_t *) proto) == '_') {
|
||||||
proto++;
|
proto++;
|
||||||
}
|
}
|
||||||
auto *service_type = service.service_type;
|
auto *service_type = MDNS_STR_ARG(service.service_type);
|
||||||
while (*service_type == '_') {
|
while (progmem_read_byte((const uint8_t *) service_type) == '_') {
|
||||||
service_type++;
|
service_type++;
|
||||||
}
|
}
|
||||||
uint16_t port = const_cast<TemplatableValue<uint16_t> &>(service.port).value();
|
uint16_t port = const_cast<TemplatableValue<uint16_t> &>(service.port).value();
|
||||||
MDNS.addService(service_type, proto, port);
|
MDNS.addService(FPSTR(service_type), FPSTR(proto), port);
|
||||||
for (const auto &record : service.txt_records) {
|
for (const auto &record : service.txt_records) {
|
||||||
MDNS.addServiceTxt(service_type, proto, record.key,
|
MDNS.addServiceTxt(FPSTR(service_type), FPSTR(proto), FPSTR(MDNS_STR_ARG(record.key)),
|
||||||
const_cast<TemplatableValue<std::string> &>(record.value).value().c_str());
|
const_cast<TemplatableValue<std::string> &>(record.value).value().c_str());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -21,18 +21,18 @@ 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;
|
auto *proto = MDNS_STR_ARG(service.proto);
|
||||||
while (*proto == '_') {
|
while (*proto == '_') {
|
||||||
proto++;
|
proto++;
|
||||||
}
|
}
|
||||||
auto *service_type = service.service_type;
|
auto *service_type = MDNS_STR_ARG(service.service_type);
|
||||||
while (*service_type == '_') {
|
while (*service_type == '_') {
|
||||||
service_type++;
|
service_type++;
|
||||||
}
|
}
|
||||||
uint16_t port_ = const_cast<TemplatableValue<uint16_t> &>(service.port).value();
|
uint16_t port_ = const_cast<TemplatableValue<uint16_t> &>(service.port).value();
|
||||||
MDNS.addService(service_type, proto, port_);
|
MDNS.addService(service_type, proto, port_);
|
||||||
for (const auto &record : service.txt_records) {
|
for (const auto &record : service.txt_records) {
|
||||||
MDNS.addServiceTxt(service_type, proto, record.key,
|
MDNS.addServiceTxt(service_type, proto, MDNS_STR_ARG(record.key),
|
||||||
const_cast<TemplatableValue<std::string> &>(record.value).value().c_str());
|
const_cast<TemplatableValue<std::string> &>(record.value).value().c_str());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -21,18 +21,18 @@ 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;
|
auto *proto = MDNS_STR_ARG(service.proto);
|
||||||
while (*proto == '_') {
|
while (*proto == '_') {
|
||||||
proto++;
|
proto++;
|
||||||
}
|
}
|
||||||
auto *service_type = service.service_type;
|
auto *service_type = MDNS_STR_ARG(service.service_type);
|
||||||
while (*service_type == '_') {
|
while (*service_type == '_') {
|
||||||
service_type++;
|
service_type++;
|
||||||
}
|
}
|
||||||
uint16_t port = const_cast<TemplatableValue<uint16_t> &>(service.port).value();
|
uint16_t port = const_cast<TemplatableValue<uint16_t> &>(service.port).value();
|
||||||
MDNS.addService(service_type, proto, port);
|
MDNS.addService(service_type, proto, port);
|
||||||
for (const auto &record : service.txt_records) {
|
for (const auto &record : service.txt_records) {
|
||||||
MDNS.addServiceTxt(service_type, proto, record.key,
|
MDNS.addServiceTxt(service_type, proto, MDNS_STR_ARG(record.key),
|
||||||
const_cast<TemplatableValue<std::string> &>(record.value).value().c_str());
|
const_cast<TemplatableValue<std::string> &>(record.value).value().c_str());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -155,7 +155,7 @@ void OpenThreadSrpComponent::setup() {
|
|||||||
|
|
||||||
// Set service name
|
// Set service name
|
||||||
char *string = otSrpClientBuffersGetServiceEntryServiceNameString(entry, &size);
|
char *string = otSrpClientBuffersGetServiceEntryServiceNameString(entry, &size);
|
||||||
std::string full_service = service.service_type + "." + service.proto;
|
std::string full_service = std::string(MDNS_STR_ARG(service.service_type)) + "." + MDNS_STR_ARG(service.proto);
|
||||||
if (full_service.size() > size) {
|
if (full_service.size() > size) {
|
||||||
ESP_LOGW(TAG, "Service name too long: %s", full_service.c_str());
|
ESP_LOGW(TAG, "Service name too long: %s", full_service.c_str());
|
||||||
continue;
|
continue;
|
||||||
@@ -181,7 +181,7 @@ void OpenThreadSrpComponent::setup() {
|
|||||||
for (size_t i = 0; i < service.txt_records.size(); i++) {
|
for (size_t i = 0; i < service.txt_records.size(); i++) {
|
||||||
const auto &txt = service.txt_records[i];
|
const auto &txt = service.txt_records[i];
|
||||||
auto value = const_cast<TemplatableValue<std::string> &>(txt.value).value();
|
auto value = const_cast<TemplatableValue<std::string> &>(txt.value).value();
|
||||||
txt_entries[i].mKey = txt.key; // Compile-time string literal in flash
|
txt_entries[i].mKey = MDNS_STR_ARG(txt.key);
|
||||||
txt_entries[i].mValue = reinterpret_cast<const uint8_t *>(strdup(value.c_str()));
|
txt_entries[i].mValue = reinterpret_cast<const uint8_t *>(strdup(value.c_str()));
|
||||||
txt_entries[i].mValueLength = value.size();
|
txt_entries[i].mValueLength = value.size();
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user