Compare commits
No commits in common. "24fd856584f4a9cde6de6012f466785ccd7a8c25" and "f12fbafc4774b3dadbcd2ff3915dd141ff70e67c" have entirely different histories.
24fd856584
...
f12fbafc47
1 changed files with 43 additions and 111 deletions
154
src/main.cpp
154
src/main.cpp
|
@ -1,5 +1,4 @@
|
||||||
#include <Arduino.h>
|
#include <Arduino.h>
|
||||||
#include <ArduinoOTA.h>
|
|
||||||
#include <ESP8266WiFi.h>
|
#include <ESP8266WiFi.h>
|
||||||
|
|
||||||
#define RELAY 4 // GPIO4
|
#define RELAY 4 // GPIO4
|
||||||
|
@ -8,103 +7,7 @@
|
||||||
#define HTTP_HOST "google.com"
|
#define HTTP_HOST "google.com"
|
||||||
#define HTTP_PORT (80)
|
#define HTTP_PORT (80)
|
||||||
|
|
||||||
// ----- //
|
bool testHTTP() {
|
||||||
// Setup //
|
|
||||||
// ----- //
|
|
||||||
|
|
||||||
void ensureWiFiConnection();
|
|
||||||
void relayOn();
|
|
||||||
void relayOff();
|
|
||||||
|
|
||||||
void setupOTA()
|
|
||||||
{
|
|
||||||
ArduinoOTA.onStart([]() {
|
|
||||||
String type;
|
|
||||||
if(ArduinoOTA.getCommand() == U_FLASH) {
|
|
||||||
type = "sketch";
|
|
||||||
} else { // U_FS
|
|
||||||
type = "filesystem";
|
|
||||||
}
|
|
||||||
|
|
||||||
// NOTE: if updating FS this would be the place to unmount FS using FS.end()
|
|
||||||
Serial.println("Start updating " + type);
|
|
||||||
});
|
|
||||||
ArduinoOTA.onEnd([]() { Serial.println("\nEnd"); });
|
|
||||||
ArduinoOTA.onProgress(
|
|
||||||
[](unsigned int progress, unsigned int total) { Serial.printf("Progress: %u%%\r", (progress / (total / 100))); });
|
|
||||||
ArduinoOTA.onError([](ota_error_t error) {
|
|
||||||
Serial.printf("Error[%u]: ", error);
|
|
||||||
if(error == OTA_AUTH_ERROR) {
|
|
||||||
Serial.println("Auth Failed");
|
|
||||||
} else if(error == OTA_BEGIN_ERROR) {
|
|
||||||
Serial.println("Begin Failed");
|
|
||||||
} else if(error == OTA_CONNECT_ERROR) {
|
|
||||||
Serial.println("Connect Failed");
|
|
||||||
} else if(error == OTA_RECEIVE_ERROR) {
|
|
||||||
Serial.println("Receive Failed");
|
|
||||||
} else if(error == OTA_END_ERROR) {
|
|
||||||
Serial.println("End Failed");
|
|
||||||
}
|
|
||||||
});
|
|
||||||
ArduinoOTA.begin();
|
|
||||||
}
|
|
||||||
|
|
||||||
void setup()
|
|
||||||
{
|
|
||||||
Serial.begin(9600);
|
|
||||||
pinMode(LED_BUILTIN, OUTPUT);
|
|
||||||
pinMode(RELAY, OUTPUT);
|
|
||||||
relayOn();
|
|
||||||
delay(2000);
|
|
||||||
relayOff();
|
|
||||||
ensureWiFiConnection();
|
|
||||||
setupOTA();
|
|
||||||
}
|
|
||||||
|
|
||||||
// ----- //
|
|
||||||
// Relay //
|
|
||||||
// ----- //
|
|
||||||
|
|
||||||
void relayOn()
|
|
||||||
{
|
|
||||||
Serial.println("Lights on");
|
|
||||||
digitalWrite(LED_BUILTIN, HIGH);
|
|
||||||
digitalWrite(RELAY, HIGH);
|
|
||||||
}
|
|
||||||
|
|
||||||
void relayOff()
|
|
||||||
{
|
|
||||||
Serial.println("Lights off");
|
|
||||||
digitalWrite(LED_BUILTIN, LOW);
|
|
||||||
digitalWrite(RELAY, LOW);
|
|
||||||
}
|
|
||||||
|
|
||||||
// --------------- //
|
|
||||||
// Network Testing //
|
|
||||||
// --------------- //
|
|
||||||
|
|
||||||
void ensureWiFiConnection()
|
|
||||||
{
|
|
||||||
wl_status_t status = WiFi.status();
|
|
||||||
if(status == WL_CONNECTED)
|
|
||||||
return;
|
|
||||||
else {
|
|
||||||
relayOff();
|
|
||||||
Serial.print("WiFi is disconnected, now connecting");
|
|
||||||
WiFi.begin(WIFI_NAME, WIFI_PASSWORD);
|
|
||||||
while(WiFi.status() != WL_CONNECTED) {
|
|
||||||
delay(500);
|
|
||||||
Serial.print(".");
|
|
||||||
}
|
|
||||||
Serial.println();
|
|
||||||
|
|
||||||
Serial.print("Connected, IP address: ");
|
|
||||||
Serial.println(WiFi.localIP());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
bool pingHTTP()
|
|
||||||
{
|
|
||||||
WiFiClient client;
|
WiFiClient client;
|
||||||
client.setNoDelay(true);
|
client.setNoDelay(true);
|
||||||
bool available = client.connect(HTTP_HOST, HTTP_PORT);
|
bool available = client.connect(HTTP_HOST, HTTP_PORT);
|
||||||
|
@ -112,13 +15,29 @@ bool pingHTTP()
|
||||||
return available;
|
return available;
|
||||||
}
|
}
|
||||||
|
|
||||||
// ---- //
|
// Returns true if Internet works
|
||||||
// Loop //
|
bool uplinkWorks() { return testHTTP(); }
|
||||||
// ---- //
|
|
||||||
|
|
||||||
void testInternet()
|
void setup() {
|
||||||
{
|
Serial.begin(9600);
|
||||||
if(pingHTTP()) {
|
pinMode(LED_BUILTIN, OUTPUT);
|
||||||
|
pinMode(RELAY, OUTPUT);
|
||||||
|
}
|
||||||
|
|
||||||
|
void relayOn() {
|
||||||
|
Serial.println("Lights on");
|
||||||
|
digitalWrite(LED_BUILTIN, HIGH);
|
||||||
|
digitalWrite(RELAY, HIGH);
|
||||||
|
}
|
||||||
|
|
||||||
|
void relayOff() {
|
||||||
|
Serial.println("Lights off");
|
||||||
|
digitalWrite(LED_BUILTIN, LOW);
|
||||||
|
digitalWrite(RELAY, LOW);
|
||||||
|
}
|
||||||
|
|
||||||
|
void testInternet() {
|
||||||
|
if (uplinkWorks()) {
|
||||||
Serial.println("Internet is up");
|
Serial.println("Internet is up");
|
||||||
relayOn();
|
relayOn();
|
||||||
} else {
|
} else {
|
||||||
|
@ -127,12 +46,25 @@ void testInternet()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void loop()
|
void ensureWiFiConnection() {
|
||||||
{
|
wl_status_t status = WiFi.status();
|
||||||
ensureWiFiConnection();
|
if(status == WL_CONNECTED) return;
|
||||||
testInternet();
|
else {
|
||||||
for(size_t i = 0; i < 5; i++) {
|
relayOff();
|
||||||
ArduinoOTA.handle();
|
Serial.print("WiFi is disconnected, now connecting");
|
||||||
delay(1000);
|
WiFi.begin(WIFI_NAME, WIFI_PASSWORD);
|
||||||
|
while (WiFi.status() != WL_CONNECTED) {
|
||||||
|
delay(500);
|
||||||
|
Serial.print(".");
|
||||||
|
}
|
||||||
|
Serial.println();
|
||||||
|
|
||||||
|
Serial.print("Connected, IP address: ");
|
||||||
|
Serial.println(WiFi.localIP());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
void loop() {
|
||||||
|
ensureWiFiConnection();
|
||||||
|
testInternet();
|
||||||
|
delay(5000);
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue