mirror of https://github.com/arendst/Tasmota.git
Merge pull request #16323 from rogg/fix-local-mdns
Use Wifi.hostByName() for ESP8266
This commit is contained in:
commit
b502b84189
|
@ -817,14 +817,16 @@ void wifiKeepAlive(void) {
|
||||||
#endif // ESP8266
|
#endif // ESP8266
|
||||||
|
|
||||||
bool WifiHostByName(const char* aHostname, IPAddress& aResult) {
|
bool WifiHostByName(const char* aHostname, IPAddress& aResult) {
|
||||||
|
#ifdef ESP8266
|
||||||
|
if (WiFi.hostByName(aHostname, aResult, Settings->dns_timeout)) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
#else
|
||||||
// DnsClient can't do one-shot mDNS queries so use WiFi.hostByName() for *.local
|
// DnsClient can't do one-shot mDNS queries so use WiFi.hostByName() for *.local
|
||||||
size_t hostname_len = strlen(aHostname);
|
size_t hostname_len = strlen(aHostname);
|
||||||
if (strstr_P(aHostname, PSTR(".local")) == &aHostname[hostname_len] - 6) {
|
if (strstr_P(aHostname, PSTR(".local")) == &aHostname[hostname_len] - 6) {
|
||||||
if (WiFi.hostByName(aHostname, aResult)) {
|
if (WiFi.hostByName(aHostname, aResult)) {
|
||||||
// Host name resolved
|
return true;
|
||||||
if (0xFFFFFFFF != (uint32_t)aResult) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// Use this instead of WiFi.hostByName or connect(host_name,.. to block less if DNS server is not found
|
// Use this instead of WiFi.hostByName or connect(host_name,.. to block less if DNS server is not found
|
||||||
|
@ -834,6 +836,7 @@ bool WifiHostByName(const char* aHostname, IPAddress& aResult) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
AddLog(LOG_LEVEL_DEBUG, PSTR("DNS: Unable to resolve '%s'"), aHostname);
|
AddLog(LOG_LEVEL_DEBUG, PSTR("DNS: Unable to resolve '%s'"), aHostname);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue