/* * Wifi and OTA related stuff */ #include #include #include #include #include WiFiManager WifiManager; WiFiClientSecure net; //BearSSL::WiFiClientSecure net; unsigned long ota_lastcheck = 0; // // If the WifiManager configuration portal is called, we can do stuff // //void WifiManagerCallback(WiFiManager *myWiFiManager) { // PRINTLN_SERIAL("Entered AP config mode"); //} void wifi_associate() { char apname[80]; settings.name.toCharArray(apname, 80); WifiManager.setConfigPortalTimeout(300); // If no configuration is done in 5 mins, exit/restart quietly if (WifiManager.autoConnect(apname)) { // @@@FIXME@@@ we should really set a PSK for the AP (but in my brief testing it crashed the ESP, so what's up with that) settings.ip = WiFi.localIP().toString(); PRINTLN_SERIAL("Wifi IP: " + settings.ip); //wificlient.setFingerprint(WTR_SHA1); net.setInsecure(); // Do not check fingerprint net.setTimeout(15000); // 15 Seconds PRINT_SERIAL("Setting time using SNTP"); configTime(-5 * 3600, 0, "pool.ntp.org", "time.nist.gov"); now = time(nullptr); while (now < 1510592825) { delay(500); APPEND_SERIAL("."); now = time(nullptr); } APPENDLN_SERIAL(" done!"); struct tm timeinfo; gmtime_r(&now, &timeinfo); PRINT_SERIAL("Current time: "); APPENDLN_SERIAL(asctime(&timeinfo)); } } void wifi_setup() { // WifiManager.setAPCallback(WifiManagerCallback); // Enable WifiManager callback to clear the cache wifi_associate(); } void wifi_loop() { if(WiFi.status() != WL_CONNECTED) { PRINTLN_SERIAL("Wifi disconnected, trying to reconnect"); wifi_associate(); } // OTA routine to be run once every X seconds unsigned long ota_check = millis()/1000; if((ota_lastcheck == 0) || ((ota_check - ota_lastcheck) > OTA_UPDATE_INTERVAL)) { PRINTLN_SERIAL("Checking for OTA update"); /* // Check for firmware upgrades t_httpUpdate_return ret = ESPhttpUpdate.update(wificlient, WTR_SERVER, WTR_SRVPORT, "/fw/", nodeversion); switch(ret) { case HTTP_UPDATE_FAILED: // HTTP 403, 404 Serial.printf("Firmware upgrade available, but update failed (%d): %s", ESPhttpUpdate.getLastError(), ESPhttpUpdate.getLastErrorString().c_str()); break; case HTTP_UPDATE_NO_UPDATES: // HTTP 304 Serial.println("No firmware upgrade available"); break; case HTTP_UPDATE_OK: // HTTP 200 Serial.println("Firmware upgrade available, upgraded ok."); // may not called we reboot the ESP break; } */ ota_lastcheck = ota_check; } }