-
Notifications
You must be signed in to change notification settings - Fork 8
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
fix(wifi): do not trust platform auto reconnect routines
- Loading branch information
Showing
4 changed files
with
117 additions
and
26 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,32 @@ | ||
#ifndef AQUAMQTT_WIFI_H | ||
#define AQUAMQTT_WIFI_H | ||
|
||
#include <WiFi.h> | ||
|
||
namespace aquamqtt | ||
{ | ||
class WifiHandler | ||
{ | ||
public: | ||
WifiHandler(); | ||
|
||
virtual ~WifiHandler() = default; | ||
|
||
void setup(); | ||
|
||
void loop(); | ||
|
||
private: | ||
static void wifiCallback(WiFiEvent_t event); | ||
|
||
unsigned long mLastCheck; | ||
|
||
static bool mConnectedToWifiWithValidIpAddress; | ||
|
||
}; | ||
|
||
} // namespace aquamqtt | ||
|
||
|
||
|
||
#endif // AQUAMQTT_WIFI_H |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,71 @@ | ||
#include "handler/Wifi.h" | ||
|
||
#include "config/Configuration.h" | ||
|
||
namespace aquamqtt | ||
{ | ||
|
||
bool WifiHandler::mConnectedToWifiWithValidIpAddress = false; | ||
|
||
WifiHandler::WifiHandler() : mLastCheck(0) | ||
{ | ||
} | ||
|
||
void WifiHandler::setup() | ||
{ | ||
WiFiClass::mode(WIFI_STA); | ||
|
||
// we don't trust the auto reconnect routine, as it seems there are edge cases where it does not work | ||
WiFi.setAutoReconnect(false); | ||
|
||
// we trust the wifi callbacks to determine if we are properly connected or disconnected | ||
WiFi.onEvent(wifiCallback); | ||
|
||
// begin a single wifi session | ||
WiFi.begin(aquamqtt::config::ssid, aquamqtt::config::psk); | ||
|
||
// perform the next wifi check in config::WIFI_RECONNECT_CYCLE_S | ||
mLastCheck = millis(); | ||
} | ||
|
||
void WifiHandler::loop() | ||
{ | ||
if ((millis() - mLastCheck) >= (config::WIFI_RECONNECT_CYCLE_S * 1000)) | ||
{ | ||
mLastCheck = millis(); | ||
|
||
// we don't trust WiFi.isConnected() or WiFi.status() == WL_CONNECTED, since it is suspected to be unreliable | ||
if (!mConnectedToWifiWithValidIpAddress) | ||
{ | ||
Serial.println("[wifi] attempting reconnect"); | ||
WiFi.disconnect(); | ||
WiFi.reconnect(); | ||
} | ||
} | ||
} | ||
|
||
void WifiHandler::wifiCallback(WiFiEvent_t event) | ||
{ | ||
Serial.print("[wifi] event: "); | ||
Serial.println(WiFi.eventName(event)); | ||
|
||
switch (event) | ||
{ | ||
case ARDUINO_EVENT_WIFI_STA_DISCONNECTED: | ||
case ARDUINO_EVENT_WIFI_STA_LOST_IP: | ||
// if we lost connection or ip address, we wil enforce a reconnect within the next cycle | ||
mConnectedToWifiWithValidIpAddress = false; | ||
break; | ||
case ARDUINO_EVENT_WIFI_STA_GOT_IP: | ||
case ARDUINO_EVENT_WIFI_STA_GOT_IP6: | ||
// if we got connection and therefore a valid ip address we have a valid connection | ||
Serial.print("[wifi] ip address: "); | ||
Serial.println(WiFi.localIP().toString().c_str()); | ||
mConnectedToWifiWithValidIpAddress = true; | ||
break; | ||
default: | ||
break; | ||
} | ||
} | ||
|
||
} // namespace aquamqtt |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters