|
|
@ -2,12 +2,18 @@ |
|
|
|
|
|
|
|
WiFiStatus::WiFiStatus(AsyncWebServer *server) : _server(server) { |
|
|
|
_server->on(WIFI_STATUS_SERVICE_PATH, HTTP_GET, std::bind(&WiFiStatus::wifiStatus, this, std::placeholders::_1)); |
|
|
|
|
|
|
|
#if defined(ESP8266)
|
|
|
|
_onStationModeConnectedHandler = WiFi.onStationModeConnected(onStationModeConnected); |
|
|
|
_onStationModeDisconnectedHandler = WiFi.onStationModeDisconnected(onStationModeDisconnected); |
|
|
|
_onStationModeGotIPHandler = WiFi.onStationModeGotIP(onStationModeGotIP); |
|
|
|
#elif defined(ESP_PLATFORM)
|
|
|
|
WiFi.onEvent(onStationModeConnected, WiFiEvent_t::SYSTEM_EVENT_STA_CONNECTED); |
|
|
|
WiFi.onEvent(onStationModeDisconnected, WiFiEvent_t::SYSTEM_EVENT_STA_DISCONNECTED); |
|
|
|
WiFi.onEvent(onStationModeGotIP, WiFiEvent_t::SYSTEM_EVENT_STA_GOT_IP); |
|
|
|
#endif
|
|
|
|
} |
|
|
|
|
|
|
|
#if defined(ESP8266)
|
|
|
|
void WiFiStatus::onStationModeConnected(const WiFiEventStationModeConnected& event) { |
|
|
|
Serial.print("WiFi Connected. SSID="); |
|
|
|
Serial.println(event.ssid); |
|
|
@ -24,6 +30,23 @@ void WiFiStatus::onStationModeGotIP(const WiFiEventStationModeGotIP& event) { |
|
|
|
Serial.print(", hostName="); |
|
|
|
Serial.println(WiFi.hostname()); |
|
|
|
} |
|
|
|
#elif defined(ESP_PLATFORM)
|
|
|
|
void WiFiStatus::onStationModeConnected(WiFiEvent_t event, WiFiEventInfo_t info) { |
|
|
|
Serial.print("WiFi Connected."); |
|
|
|
} |
|
|
|
|
|
|
|
void WiFiStatus::onStationModeDisconnected(WiFiEvent_t event, WiFiEventInfo_t info) { |
|
|
|
Serial.print("WiFi Disconnected. Reason code="); |
|
|
|
Serial.println(info.disconnected.reason); |
|
|
|
} |
|
|
|
|
|
|
|
void WiFiStatus::onStationModeGotIP(WiFiEvent_t event, WiFiEventInfo_t info) { |
|
|
|
Serial.print("WiFi Got IP. localIP="); |
|
|
|
Serial.print(WiFi.localIP().toString()); |
|
|
|
Serial.print(", hostName="); |
|
|
|
Serial.println(WiFi.getHostname()); |
|
|
|
} |
|
|
|
#endif
|
|
|
|
|
|
|
|
void WiFiStatus::wifiStatus(AsyncWebServerRequest *request) { |
|
|
|
AsyncJsonResponse * response = new AsyncJsonResponse(); |
|
|
@ -40,10 +63,10 @@ void WiFiStatus::wifiStatus(AsyncWebServerRequest *request) { |
|
|
|
root["gateway_ip"] = WiFi.gatewayIP().toString(); |
|
|
|
IPAddress dnsIP1 = WiFi.dnsIP(0); |
|
|
|
IPAddress dnsIP2 = WiFi.dnsIP(1); |
|
|
|
if (dnsIP1 != 0U){ |
|
|
|
if (dnsIP1 != INADDR_NONE){ |
|
|
|
root["dns_ip_1"] = dnsIP1.toString(); |
|
|
|
} |
|
|
|
if (dnsIP2 != 0U){ |
|
|
|
if (dnsIP2 != INADDR_NONE){ |
|
|
|
root["dns_ip_2"] = dnsIP2.toString(); |
|
|
|
} |
|
|
|
} |
|
|
|