mirror of
https://github.com/esphome/esphome.git
synced 2025-02-03 03:30:54 +00:00
765e641d08
* Expose right webserver port using mDNS. 80 is the default value but can be changed in the config file. Add a new define for the port. Signed-off-by: Richard Weinberger <richard@nod.at> * Expose prometheus service via mDNS That way prometheus auto discovery features can find us. Signed-off-by: Richard Weinberger <richard@nod.at>
103 lines
2.7 KiB
C++
103 lines
2.7 KiB
C++
#include "esphome/core/util.h"
|
|
#include "esphome/core/defines.h"
|
|
#include "esphome/core/application.h"
|
|
#include "esphome/core/version.h"
|
|
#include "esphome/core/log.h"
|
|
|
|
#ifdef USE_WIFI
|
|
#include "esphome/components/wifi/wifi_component.h"
|
|
#endif
|
|
|
|
#ifdef USE_API
|
|
#include "esphome/components/api/api_server.h"
|
|
#endif
|
|
|
|
#ifdef USE_ETHERNET
|
|
#include "esphome/components/ethernet/ethernet_component.h"
|
|
#endif
|
|
|
|
#ifdef ARDUINO_ARCH_ESP32
|
|
#include <ESPmDNS.h>
|
|
#endif
|
|
#ifdef ARDUINO_ARCH_ESP8266
|
|
#include <ESP8266mDNS.h>
|
|
#endif
|
|
|
|
namespace esphome {
|
|
|
|
bool network_is_connected() {
|
|
#ifdef USE_ETHERNET
|
|
if (ethernet::global_eth_component != nullptr && ethernet::global_eth_component->is_connected())
|
|
return true;
|
|
#endif
|
|
|
|
#ifdef USE_WIFI
|
|
if (wifi::global_wifi_component != nullptr)
|
|
return wifi::global_wifi_component->is_connected();
|
|
#endif
|
|
|
|
return false;
|
|
}
|
|
|
|
#ifdef ARDUINO_ARCH_ESP8266
|
|
bool mdns_setup;
|
|
#endif
|
|
|
|
#ifndef WEBSERVER_PORT
|
|
static const uint8_t WEBSERVER_PORT = 80;
|
|
#endif
|
|
|
|
#ifdef ARDUINO_ARCH_ESP8266
|
|
void network_setup_mdns(IPAddress address, int interface) {
|
|
// Latest arduino framework breaks mDNS for AP interface
|
|
// see https://github.com/esp8266/Arduino/issues/6114
|
|
if (interface == 1)
|
|
return;
|
|
MDNS.begin(App.get_name().c_str(), address);
|
|
mdns_setup = true;
|
|
#endif
|
|
#ifdef ARDUINO_ARCH_ESP32
|
|
void network_setup_mdns() {
|
|
MDNS.begin(App.get_name().c_str());
|
|
#endif
|
|
#ifdef USE_API
|
|
if (api::global_api_server != nullptr) {
|
|
MDNS.addService("esphomelib", "tcp", api::global_api_server->get_port());
|
|
// DNS-SD (!=mDNS !) requires at least one TXT record for service discovery - let's add version
|
|
MDNS.addServiceTxt("esphomelib", "tcp", "version", ESPHOME_VERSION);
|
|
MDNS.addServiceTxt("esphomelib", "tcp", "address", network_get_address().c_str());
|
|
MDNS.addServiceTxt("esphomelib", "tcp", "mac", get_mac_address().c_str());
|
|
} else {
|
|
#endif
|
|
// Publish "http" service if not using native API nor the webserver component
|
|
// This is just to have *some* mDNS service so that .local resolution works
|
|
MDNS.addService("http", "tcp", WEBSERVER_PORT);
|
|
MDNS.addServiceTxt("http", "tcp", "version", ESPHOME_VERSION);
|
|
#ifdef USE_API
|
|
}
|
|
#endif
|
|
#ifdef USE_PROMETHEUS
|
|
MDNS.addService("prometheus-http", "tcp", WEBSERVER_PORT);
|
|
#endif
|
|
}
|
|
void network_tick_mdns() {
|
|
#ifdef ARDUINO_ARCH_ESP8266
|
|
if (mdns_setup)
|
|
MDNS.update();
|
|
#endif
|
|
}
|
|
|
|
std::string network_get_address() {
|
|
#ifdef USE_ETHERNET
|
|
if (ethernet::global_eth_component != nullptr)
|
|
return ethernet::global_eth_component->get_use_address();
|
|
#endif
|
|
#ifdef USE_WIFI
|
|
if (wifi::global_wifi_component != nullptr)
|
|
return wifi::global_wifi_component->get_use_address();
|
|
#endif
|
|
return "";
|
|
}
|
|
|
|
} // namespace esphome
|