Compare commits
7 Commits
94448fc0fe
...
441a32154d
Author | SHA1 | Date |
---|---|---|
gilex-dev | 441a32154d | |
gilex-dev | dd55af6d9c | |
gilex-dev | 782fe8cf04 | |
gilex-dev | 900a1d9af2 | |
gilex-dev | 8c9de56fab | |
gilex-dev | e47bc6c4ab | |
gilex-dev | 5a73ef97dd |
|
@ -14,7 +14,5 @@ board = esp12e
|
||||||
framework = arduino
|
framework = arduino
|
||||||
upload_speed = 921600
|
upload_speed = 921600
|
||||||
monitor_speed = 74880
|
monitor_speed = 74880
|
||||||
lib_deps =
|
lib_deps =
|
||||||
ropg/ezTime@^0.8.3
|
ropg/ezTime@^0.8.3
|
||||||
paulstoffregen/OneWire@^2.3.7
|
|
||||||
milesburton/DallasTemperature@^3.11.0
|
|
||||||
|
|
97
src/html.cpp
97
src/html.cpp
|
@ -2,24 +2,7 @@
|
||||||
#include <Arduino.h>
|
#include <Arduino.h>
|
||||||
|
|
||||||
void reload_home() {
|
void reload_home() {
|
||||||
char time_current[3][3] = {"", "", ""};
|
sprintf(home_html, "<!DOCTYPE html>\
|
||||||
if (myTime.hour() < 10) {
|
|
||||||
sprintf(time_current[0], "0%d", myTime.hour());
|
|
||||||
} else {
|
|
||||||
sprintf(time_current[0], "%d", myTime.hour());
|
|
||||||
}
|
|
||||||
if (myTime.minute() < 10) {
|
|
||||||
sprintf(time_current[1], "0%d", myTime.minute());
|
|
||||||
} else {
|
|
||||||
sprintf(time_current[1], "%d", myTime.minute());
|
|
||||||
}
|
|
||||||
if (myTime.second() < 10) {
|
|
||||||
sprintf(time_current[2], "0%d", myTime.second());
|
|
||||||
} else {
|
|
||||||
sprintf(time_current[2], "%d", myTime.second());
|
|
||||||
}
|
|
||||||
|
|
||||||
sprintf(home_html, "<!DOCTYPE html>\
|
|
||||||
<html lang='de'>\
|
<html lang='de'>\
|
||||||
<head>\
|
<head>\
|
||||||
<meta charset='UTF-8'>\
|
<meta charset='UTF-8'>\
|
||||||
|
@ -79,7 +62,7 @@ void reload_home() {
|
||||||
<body>\
|
<body>\
|
||||||
<div class='wrapper_main'>\
|
<div class='wrapper_main'>\
|
||||||
<h1>Übersicht</h1>\
|
<h1>Übersicht</h1>\
|
||||||
<h2>Uhrzeit: <span>%s:%s:%s</span></h2>\
|
<h2>Uhrzeit: <span>%02d:%02d:%02d</span></h2>\
|
||||||
<div class='wrapper_form'>\
|
<div class='wrapper_form'>\
|
||||||
<div>\
|
<div>\
|
||||||
<span>Ventil 1: </span>\
|
<span>Ventil 1: </span>\
|
||||||
|
@ -120,12 +103,12 @@ void reload_home() {
|
||||||
</div>\
|
</div>\
|
||||||
</body>\
|
</body>\
|
||||||
</html>",
|
</html>",
|
||||||
time_current[0], time_current[1], time_current[2], stat[0], stat[1],
|
myTime.hour(), myTime.minute(), myTime.second(), stat[0], stat[1],
|
||||||
stat[2], stat[3], stat[4], stat[5], stat[6], stat[7]);
|
stat[2], stat[3], stat[4], stat[5], stat[6], stat[7]);
|
||||||
}
|
}
|
||||||
|
|
||||||
void reload_settings() {
|
void reload_settings() {
|
||||||
sprintf(settings_html, "<tr>\
|
sprintf(settings_html, "<tr>\
|
||||||
<td>1</td>\
|
<td>1</td>\
|
||||||
<td>%s:%s</td>\
|
<td>%s:%s</td>\
|
||||||
<td>%s:%s</td>\
|
<td>%s:%s</td>\
|
||||||
|
@ -187,42 +170,42 @@ void reload_settings() {
|
||||||
</div>\
|
</div>\
|
||||||
</body>\
|
</body>\
|
||||||
</html>",
|
</html>",
|
||||||
time_all[0][0], time_all[1][0], time_all[2][0], time_all[3][0],
|
time_all[0][0], time_all[1][0], time_all[2][0], time_all[3][0],
|
||||||
time_all[4][0], time_all[5][0], time_all[6][0], time_all[7][0],
|
time_all[4][0], time_all[5][0], time_all[6][0], time_all[7][0],
|
||||||
time_all[0][1], time_all[1][1], time_all[2][1], time_all[3][1],
|
time_all[0][1], time_all[1][1], time_all[2][1], time_all[3][1],
|
||||||
time_all[4][1], time_all[5][1], time_all[6][1], time_all[7][1],
|
time_all[4][1], time_all[5][1], time_all[6][1], time_all[7][1],
|
||||||
time_all[0][2], time_all[1][2], time_all[2][2], time_all[3][2],
|
time_all[0][2], time_all[1][2], time_all[2][2], time_all[3][2],
|
||||||
time_all[4][2], time_all[5][2], time_all[6][2], time_all[7][2],
|
time_all[4][2], time_all[5][2], time_all[6][2], time_all[7][2],
|
||||||
time_all[0][3], time_all[1][3], time_all[2][3], time_all[3][3],
|
time_all[0][3], time_all[1][3], time_all[2][3], time_all[3][3],
|
||||||
time_all[4][3], time_all[5][3], time_all[6][3], time_all[7][3],
|
time_all[4][3], time_all[5][3], time_all[6][3], time_all[7][3],
|
||||||
time_all[0][4], time_all[1][4], time_all[2][4], time_all[3][4],
|
time_all[0][4], time_all[1][4], time_all[2][4], time_all[3][4],
|
||||||
time_all[4][4], time_all[5][4], time_all[6][4], time_all[7][4],
|
time_all[4][4], time_all[5][4], time_all[6][4], time_all[7][4],
|
||||||
time_all[0][5], time_all[1][5], time_all[2][5], time_all[3][5],
|
time_all[0][5], time_all[1][5], time_all[2][5], time_all[3][5],
|
||||||
time_all[4][5], time_all[5][5], time_all[6][5], time_all[7][5],
|
time_all[4][5], time_all[5][5], time_all[6][5], time_all[7][5],
|
||||||
time_all[0][6], time_all[1][6], time_all[2][6], time_all[3][6],
|
time_all[0][6], time_all[1][6], time_all[2][6], time_all[3][6],
|
||||||
time_all[4][6], time_all[5][6], time_all[6][6], time_all[7][6],
|
time_all[4][6], time_all[5][6], time_all[6][6], time_all[7][6],
|
||||||
time_all[0][7], time_all[1][7], time_all[2][7], time_all[3][7],
|
time_all[0][7], time_all[1][7], time_all[2][7], time_all[3][7],
|
||||||
time_all[4][7], time_all[5][7], time_all[6][7], time_all[7][7]);
|
time_all[4][7], time_all[5][7], time_all[6][7], time_all[7][7]);
|
||||||
}
|
}
|
||||||
|
|
||||||
void handleToggle() {
|
void handleToggle() {
|
||||||
int i = server.arg("number")
|
int i = server.arg("number")
|
||||||
.toInt(); // converts GET argument to int and does stuff xD
|
.toInt(); // converts GET argument to int and does stuff xD
|
||||||
override[i] = !override[i];
|
override[i] = !override[i];
|
||||||
debugln(F("---------------------------"));
|
debugln(F("---------------------------"));
|
||||||
debug(F("[RECIVED] for: "));
|
debug(F("[RECIVED] for: "));
|
||||||
debugln(i);
|
debugln(i);
|
||||||
digitalWrite(pins[i], !digitalRead(pins[i]));
|
digitalWrite(pins[i], !digitalRead(pins[i]));
|
||||||
if (digitalRead(pins[i]) == LOW) {
|
if (digitalRead(pins[i]) == LOW) {
|
||||||
sprintf(stat[i], "AN");
|
sprintf(stat[i], "AN");
|
||||||
} else {
|
} else {
|
||||||
sprintf(stat[i], "AUS");
|
sprintf(stat[i], "AUS");
|
||||||
}
|
}
|
||||||
debug(F("Status: "));
|
debug(F("Status: "));
|
||||||
debugln(stat[i]);
|
debugln(stat[i]);
|
||||||
reload_home();
|
reload_home();
|
||||||
server.sendHeader(F("Location"), F("/"), true);
|
server.sendHeader(F("Location"), F("/"), true);
|
||||||
server.send(302, F("text/html"), home_html);
|
server.send(302, F("text/html"), home_html);
|
||||||
debugln(override[i]);
|
debugln(override[i]);
|
||||||
debugln(F("---------------------------"));
|
debugln(F("---------------------------"));
|
||||||
}
|
}
|
||||||
|
|
610
src/main.cpp
610
src/main.cpp
|
@ -1,305 +1,305 @@
|
||||||
const char SSID[] = "";
|
const char SSID[] = "";
|
||||||
const char PASSWORD[] = "";
|
const char PASSWORD[] = "";
|
||||||
|
|
||||||
const char version[] = " 0.8";
|
const char version[] = " 0.8";
|
||||||
#include "globalvars.h"
|
#include "globalvars.h"
|
||||||
#include <Arduino.h>
|
#include <Arduino.h>
|
||||||
#include <EEPROM.h>
|
#include <EEPROM.h>
|
||||||
#include <ESP8266WebServer.h>
|
#include <ESP8266WebServer.h>
|
||||||
#include <ESP8266WiFi.h>
|
#include <ESP8266WiFi.h>
|
||||||
#include <ezTime.h>
|
#include <ezTime.h>
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
|
|
||||||
ESP8266WebServer server;
|
ESP8266WebServer server;
|
||||||
IPAddress staticIP(192, 168, 2, 5); // static IP address
|
IPAddress staticIP(192, 168, 2, 5); // static IP address
|
||||||
IPAddress gateway(192, 168, 2, 1); // Router's IP address
|
IPAddress gateway(192, 168, 2, 1); // Router's IP address
|
||||||
IPAddress subnet(255, 255, 255, 0);
|
IPAddress subnet(255, 255, 255, 0);
|
||||||
IPAddress dns(192, 168, 2, 1);
|
IPAddress dns(192, 168, 2, 1);
|
||||||
Timezone myTime;
|
Timezone myTime;
|
||||||
|
|
||||||
char time_all[8][8][3] = {
|
char time_all[8][8][3] = {
|
||||||
{}, {}, {}, {},
|
{}, {}, {}, {},
|
||||||
{}, {}, {}, {}}; // 3D array for load_EEPROM() and handleTime()
|
{}, {}, {}, {}}; // 3D array for load_EEPROM() and handleTime()
|
||||||
const unsigned int pins[8] = {5, 4, 14, 12,
|
const unsigned int pins[8] = {5, 4, 14, 12,
|
||||||
13, 10, 9}; // TODO: only 7 of 8 pins defined
|
13, 10, 9}; // TODO: only 7 of 8 pins defined
|
||||||
int r = 0;
|
int r = 0;
|
||||||
|
|
||||||
char stat[8][4] = {"AUS", "AUS", "AUS", "AUS",
|
char stat[8][4] = {"AUS", "AUS", "AUS", "AUS",
|
||||||
"AUS", "AUS", "AUS", "AUS"}; // text on button
|
"AUS", "AUS", "AUS", "AUS"}; // text on button
|
||||||
char t_stat[8][4] = {"", "", "", "",
|
char t_stat[8][4] = {"", "", "", "",
|
||||||
"", "", "", ""}; // for "status of timer changed"
|
"", "", "", ""}; // for "status of timer changed"
|
||||||
bool override[8] = {false, false, false, false,
|
bool override[8] = {false, false, false, false,
|
||||||
false, false, false, false}; // for manual override
|
false, false, false, false}; // for manual override
|
||||||
|
|
||||||
char home_html[3000]; // be careful when changing these values (might cause
|
char home_html[3000]; // be careful when changing these values (might cause
|
||||||
// overflow)!
|
// overflow)!
|
||||||
char settings_html[2014];
|
char settings_html[2014];
|
||||||
const char settings_html_pre[] PROGMEM = {"<!DOCTYPE html>\
|
const char settings_html_pre[] PROGMEM = {"<!DOCTYPE html>\
|
||||||
<html lang='de'>\
|
<html lang='de'>\
|
||||||
<head>\
|
<head>\
|
||||||
<meta charset='UTF-8'>\
|
<meta charset='UTF-8'>\
|
||||||
<meta http-equiv='X-UA-Compatible' content='IE=edge'>\
|
<meta http-equiv='X-UA-Compatible' content='IE=edge'>\
|
||||||
<meta name='viewport' content='width=device-width, initial-scale=1.0'>\
|
<meta name='viewport' content='width=device-width, initial-scale=1.0'>\
|
||||||
<title>Einstellungen</title>\
|
<title>Einstellungen</title>\
|
||||||
<style>\
|
<style>\
|
||||||
* {\
|
* {\
|
||||||
font-family: Arial, Helvetica, sans-serif;\
|
font-family: Arial, Helvetica, sans-serif;\
|
||||||
font-size: 26px;\
|
font-size: 26px;\
|
||||||
user-select: none;\
|
user-select: none;\
|
||||||
text-decoration: none;\
|
text-decoration: none;\
|
||||||
}\
|
}\
|
||||||
a {\
|
a {\
|
||||||
color: black;\
|
color: black;\
|
||||||
}\
|
}\
|
||||||
.wrapper_main {\
|
.wrapper_main {\
|
||||||
margin: 0 auto;\
|
margin: 0 auto;\
|
||||||
max-width: fit-content;\
|
max-width: fit-content;\
|
||||||
max-width: -moz-fit-content;\
|
max-width: -moz-fit-content;\
|
||||||
text-align: center;\
|
text-align: center;\
|
||||||
background-color: rgb(214, 214, 214);\
|
background-color: rgb(214, 214, 214);\
|
||||||
padding: 1px 8px 8px 8px;\
|
padding: 1px 8px 8px 8px;\
|
||||||
border-radius: 4px;\
|
border-radius: 4px;\
|
||||||
}\
|
}\
|
||||||
#rule, [type='time'] {\
|
#rule, [type='time'] {\
|
||||||
height: 36px;\
|
height: 36px;\
|
||||||
border: none;\
|
border: none;\
|
||||||
padding: 0 4px;\
|
padding: 0 4px;\
|
||||||
margin: 4px 0;\
|
margin: 4px 0;\
|
||||||
background-color: white;\
|
background-color: white;\
|
||||||
width: fit-content;\
|
width: fit-content;\
|
||||||
width: -moz-fit-content;\
|
width: -moz-fit-content;\
|
||||||
border-radius: 4px;\
|
border-radius: 4px;\
|
||||||
}\
|
}\
|
||||||
.animated_a, [type='submit']{\
|
.animated_a, [type='submit']{\
|
||||||
background-color: rgb(135, 252, 119);\
|
background-color: rgb(135, 252, 119);\
|
||||||
border: none;\
|
border: none;\
|
||||||
border-radius: 4px;\
|
border-radius: 4px;\
|
||||||
box-shadow: rgb(25, 167, 49) 0 4px;\
|
box-shadow: rgb(25, 167, 49) 0 4px;\
|
||||||
position: relative;\
|
position: relative;\
|
||||||
margin: 8px 0;\
|
margin: 8px 0;\
|
||||||
padding: 2px 8px;\
|
padding: 2px 8px;\
|
||||||
}\
|
}\
|
||||||
[type='submit'] {\
|
[type='submit'] {\
|
||||||
position: relative;\
|
position: relative;\
|
||||||
top: -2px;\
|
top: -2px;\
|
||||||
display: inline-block;\
|
display: inline-block;\
|
||||||
}\
|
}\
|
||||||
.animated_a {\
|
.animated_a {\
|
||||||
text-decoration: none;\
|
text-decoration: none;\
|
||||||
display: inline-block;\
|
display: inline-block;\
|
||||||
margin: 8px 0;\
|
margin: 8px 0;\
|
||||||
padding-top: 4px;\
|
padding-top: 4px;\
|
||||||
height: 28px;\
|
height: 28px;\
|
||||||
}\
|
}\
|
||||||
.wrapper_table {\
|
.wrapper_table {\
|
||||||
overflow: auto;\
|
overflow: auto;\
|
||||||
}\
|
}\
|
||||||
table {\
|
table {\
|
||||||
margin: 8px auto;\
|
margin: 8px auto;\
|
||||||
}\
|
}\
|
||||||
table, th, td {\
|
table, th, td {\
|
||||||
border: 1px solid black;\
|
border: 1px solid black;\
|
||||||
border-collapse: collapse;\
|
border-collapse: collapse;\
|
||||||
user-select: text;\
|
user-select: text;\
|
||||||
padding: 0 8px;\
|
padding: 0 8px;\
|
||||||
}\
|
}\
|
||||||
.animated_a, [type='submit']{\
|
.animated_a, [type='submit']{\
|
||||||
cursor: pointer;\
|
cursor: pointer;\
|
||||||
}\
|
}\
|
||||||
.animated_a:active {\
|
.animated_a:active {\
|
||||||
box-shadow: rgb(25, 167, 49) 0 2px;\
|
box-shadow: rgb(25, 167, 49) 0 2px;\
|
||||||
top: 2px;\
|
top: 2px;\
|
||||||
}\
|
}\
|
||||||
[type='submit']:active {\
|
[type='submit']:active {\
|
||||||
box-shadow: rgb(25, 167, 49) 0 2px;\
|
box-shadow: rgb(25, 167, 49) 0 2px;\
|
||||||
top: 0px;\
|
top: 0px;\
|
||||||
}\
|
}\
|
||||||
*:focus {\
|
*:focus {\
|
||||||
outline: none;\
|
outline: none;\
|
||||||
}\
|
}\
|
||||||
</style>\
|
</style>\
|
||||||
</head>\
|
</head>\
|
||||||
<body>\
|
<body>\
|
||||||
<div class='wrapper_main'>\
|
<div class='wrapper_main'>\
|
||||||
<form action='settings' method='POST'>\
|
<form action='settings' method='POST'>\
|
||||||
<select name='rule' id='rule' required>\
|
<select name='rule' id='rule' required>\
|
||||||
<option value='' selected disabled>Ventiel Nr.</option>\
|
<option value='' selected disabled>Ventiel Nr.</option>\
|
||||||
<option value='0'>1</option>\
|
<option value='0'>1</option>\
|
||||||
<option value='1'>2</option>\
|
<option value='1'>2</option>\
|
||||||
<option value='2'>3</option>\
|
<option value='2'>3</option>\
|
||||||
<option value='3'>4</option>\
|
<option value='3'>4</option>\
|
||||||
<option value='4'>5</option>\
|
<option value='4'>5</option>\
|
||||||
<option value='5'>6</option>\
|
<option value='5'>6</option>\
|
||||||
<option value='6'>7</option>\
|
<option value='6'>7</option>\
|
||||||
<option value='7' disabled>8</option>\
|
<option value='7' disabled>8</option>\
|
||||||
</select>\
|
</select>\
|
||||||
<br>\
|
<br>\
|
||||||
<input type='time' name='time_o'>\
|
<input type='time' name='time_o'>\
|
||||||
- <input type='time' name='time_f'>\
|
- <input type='time' name='time_f'>\
|
||||||
<br>\
|
<br>\
|
||||||
<input type='time' name='time_o_1'>\
|
<input type='time' name='time_o_1'>\
|
||||||
- <input type='time' name='time_f_1'>\
|
- <input type='time' name='time_f_1'>\
|
||||||
<br>\
|
<br>\
|
||||||
<input type='submit'>\
|
<input type='submit'>\
|
||||||
</form>\
|
</form>\
|
||||||
<div class='wrapper_table'>\
|
<div class='wrapper_table'>\
|
||||||
<table>\
|
<table>\
|
||||||
<tr>\
|
<tr>\
|
||||||
<th style='background-color: gray;'></th>\
|
<th style='background-color: gray;'></th>\
|
||||||
<th>von:</th>\
|
<th>von:</th>\
|
||||||
<th>bis:</th>\
|
<th>bis:</th>\
|
||||||
<th>von:</th>\
|
<th>von:</th>\
|
||||||
<th>bis:</th>\
|
<th>bis:</th>\
|
||||||
</tr>"};
|
</tr>"};
|
||||||
void reload_home();
|
void reload_home();
|
||||||
void reload_settings();
|
void reload_settings();
|
||||||
void handleToggle();
|
void handleToggle();
|
||||||
|
|
||||||
void load_EEPROM() {
|
void load_EEPROM() {
|
||||||
unsigned int EEPROM_Addr = 0;
|
unsigned int EEPROM_Addr = 0;
|
||||||
for (unsigned int i0 = 0; i0 < 8; i0++) {
|
for (unsigned int i0 = 0; i0 < 8; i0++) {
|
||||||
for (unsigned int i = 0; i < 8; i++) {
|
for (unsigned int i = 0; i < 8; i++) {
|
||||||
if (EEPROM.read(EEPROM_Addr) < 10) {
|
sprintf(time_all[i0][i], "%02d", EEPROM.read(EEPROM_Addr));
|
||||||
sprintf(time_all[i0][i], "0%d", EEPROM.read(EEPROM_Addr));
|
EEPROM_Addr += 4;
|
||||||
} else {
|
yield();
|
||||||
sprintf(time_all[i0][i], "%d", EEPROM.read(EEPROM_Addr));
|
}
|
||||||
}
|
}
|
||||||
EEPROM_Addr += 4;
|
}
|
||||||
yield();
|
|
||||||
}
|
void handleHome() {
|
||||||
}
|
reload_home();
|
||||||
}
|
server.send(200, "text/html", home_html);
|
||||||
|
debugln(ESP.getFreeHeap(), DEC);
|
||||||
void handleHome() {
|
}
|
||||||
reload_home();
|
|
||||||
server.send(200, "text/html", home_html);
|
void handleSettings() {
|
||||||
debugln(ESP.getFreeHeap(), DEC);
|
reload_settings();
|
||||||
}
|
server.setContentLength(strlen(settings_html_pre) + strlen(settings_html));
|
||||||
|
server.send(200, "text/html", settings_html_pre);
|
||||||
void handleSettings() {
|
server.sendContent(settings_html);
|
||||||
reload_settings();
|
debugln(ESP.getFreeHeap(), DEC);
|
||||||
server.setContentLength(strlen(settings_html_pre) + strlen(settings_html));
|
}
|
||||||
server.send(200, "text/html", settings_html_pre);
|
|
||||||
server.sendContent(settings_html);
|
void handleTime() {
|
||||||
debugln(ESP.getFreeHeap(), DEC);
|
const char args[4][9] = {"time_o", "time_f", "time_o_1", "time_f_1"};
|
||||||
}
|
|
||||||
|
for (unsigned int arg = 0; arg < 4; arg++) {
|
||||||
void handleTime() {
|
if (server.arg(args[arg]) != "") {
|
||||||
const char args[4][9] = {"time_o", "time_f", "time_o_1", "time_f_1"};
|
char buff_h[2][2] = {server.arg(args[arg])[0],
|
||||||
|
server.arg(args[arg])[1]};
|
||||||
for (unsigned int arg = 0; arg < 4; arg++) {
|
char buff_m[2][2] = {server.arg(args[arg])[3],
|
||||||
if (server.arg(args[arg]) != "") {
|
server.arg(args[arg])[4]};
|
||||||
char buff_h[2][2] = {server.arg(args[arg])[0], server.arg(args[arg])[1]};
|
sprintf(time_all[arg * 2][server.arg("rule").toInt()], "%s%s",
|
||||||
char buff_m[2][2] = {server.arg(args[arg])[3], server.arg(args[arg])[4]};
|
buff_h[0], buff_h[1]);
|
||||||
sprintf(time_all[arg * 2][server.arg("rule").toInt()], "%s", buff_h);
|
sprintf(time_all[arg * 2 + 1][server.arg("rule").toInt()], "%s%s",
|
||||||
sprintf(time_all[arg * 2 + 1][server.arg("rule").toInt()], "%s", buff_m);
|
buff_m[0], buff_m[1]);
|
||||||
|
|
||||||
EEPROM.put(server.arg("rule").toInt() * 4 + arg * 64,
|
EEPROM.put(server.arg("rule").toInt() * 4 + arg * 64,
|
||||||
atoi(time_all[arg * 2][server.arg("rule").toInt()]));
|
atoi(time_all[arg * 2][server.arg("rule").toInt()]));
|
||||||
EEPROM.commit();
|
EEPROM.commit();
|
||||||
EEPROM.put(server.arg("rule").toInt() * 4 + arg * 64 + 32,
|
EEPROM.put(server.arg("rule").toInt() * 4 + arg * 64 + 32,
|
||||||
atoi(time_all[arg * 2 + 1][server.arg("rule").toInt()]));
|
atoi(time_all[arg * 2 + 1][server.arg("rule").toInt()]));
|
||||||
EEPROM.commit();
|
EEPROM.commit();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
reload_settings();
|
reload_settings();
|
||||||
server.setContentLength(strlen(settings_html_pre) + strlen(settings_html));
|
server.setContentLength(strlen(settings_html_pre) + strlen(settings_html));
|
||||||
server.send(301, "text/html", settings_html_pre);
|
server.send(301, "text/html", settings_html_pre);
|
||||||
server.sendContent(settings_html);
|
server.sendContent(settings_html);
|
||||||
}
|
}
|
||||||
|
|
||||||
void timer() {
|
void timer() {
|
||||||
if (((myTime.hour() * 60 + myTime.minute() >=
|
if (((myTime.hour() * 60 + myTime.minute() >=
|
||||||
atoi(time_all[0][r]) * 60 + atoi(time_all[1][r])) and
|
atoi(time_all[0][r]) * 60 + atoi(time_all[1][r])) and
|
||||||
(myTime.hour() * 60 + myTime.minute() <
|
(myTime.hour() * 60 + myTime.minute() <
|
||||||
atoi(time_all[2][r]) * 60 + atoi(time_all[3][r]))) or
|
atoi(time_all[2][r]) * 60 + atoi(time_all[3][r]))) or
|
||||||
((myTime.hour() * 60 + myTime.minute() >=
|
((myTime.hour() * 60 + myTime.minute() >=
|
||||||
atoi(time_all[4][r]) * 60 + atoi(time_all[5][r])) and
|
atoi(time_all[4][r]) * 60 + atoi(time_all[5][r])) and
|
||||||
(myTime.hour() * 60 + myTime.minute() <
|
(myTime.hour() * 60 + myTime.minute() <
|
||||||
atoi(time_all[6][r]) * 60 + atoi(time_all[7][r])))) {
|
atoi(time_all[6][r]) * 60 + atoi(time_all[7][r])))) {
|
||||||
if ((override[r]) and (strcmp(t_stat[r], "off") == 0)) {
|
if ((override[r]) and (strcmp(t_stat[r], "off") == 0)) {
|
||||||
override[r] = false;
|
override[r] = false;
|
||||||
debugln(F("debug#1"));
|
debugln(F("debug#1"));
|
||||||
}
|
}
|
||||||
sprintf(t_stat[r], "on");
|
sprintf(t_stat[r], "on");
|
||||||
if (!override[r]) {
|
if (!override[r]) {
|
||||||
digitalWrite(pins[r], LOW);
|
digitalWrite(pins[r], LOW);
|
||||||
if (strcmp(stat[r], "AUS") == 0) {
|
if (strcmp(stat[r], "AUS") == 0) {
|
||||||
debug(r);
|
debug(r);
|
||||||
debugln(F(" is on"));
|
debugln(F(" is on"));
|
||||||
sprintf(stat[r], "AN");
|
sprintf(stat[r], "AN");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if ((override[r]) and (strcmp(t_stat[r], "on") == 0)) {
|
if ((override[r]) and (strcmp(t_stat[r], "on") == 0)) {
|
||||||
override[r] = false;
|
override[r] = false;
|
||||||
}
|
}
|
||||||
sprintf(t_stat[r], "off");
|
sprintf(t_stat[r], "off");
|
||||||
if (!override[r]) {
|
if (!override[r]) {
|
||||||
digitalWrite(pins[r], HIGH);
|
digitalWrite(pins[r], HIGH);
|
||||||
if (strcmp(stat[r], "AN") == 0) {
|
if (strcmp(stat[r], "AN") == 0) {
|
||||||
debug(r);
|
debug(r);
|
||||||
debugln(F(" is off"));
|
debugln(F(" is off"));
|
||||||
sprintf(stat[r], "AUS");
|
sprintf(stat[r], "AUS");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void setup() {
|
void setup() {
|
||||||
int p = 0;
|
int p = 0;
|
||||||
while (p <= 7) {
|
while (p <= 7) {
|
||||||
pinMode(pins[p], OUTPUT);
|
pinMode(pins[p], OUTPUT);
|
||||||
digitalWrite(pins[p], HIGH);
|
digitalWrite(pins[p], HIGH);
|
||||||
p++;
|
p++;
|
||||||
}
|
}
|
||||||
Serial.begin(74880);
|
Serial.begin(74880);
|
||||||
EEPROM.begin(256); // 4 bits for EEPROM, address 0-255, value 0-255
|
EEPROM.begin(256); // 4 bits for EEPROM, address 0-255, value 0-255
|
||||||
debug(F("\nver."));
|
debug(F("\nver."));
|
||||||
debugln(version);
|
debugln(version);
|
||||||
debugln(F("check for updates at "
|
debugln(F("check for updates at "
|
||||||
"https://somepi.ddns.net/gitea/gilex-dev/ESP8266-IOT-timer/\n"));
|
"https://somepi.ddns.net/gitea/gilex-dev/ESP8266-IOT-timer/\n"));
|
||||||
load_EEPROM();
|
load_EEPROM();
|
||||||
// WLAN-config
|
// WLAN-config
|
||||||
// ---------------------------------------------------------------------------------------------------------------------
|
// ---------------------------------------------------------------------------------------------------------------------
|
||||||
WiFi.mode(WIFI_STA);
|
WiFi.mode(WIFI_STA);
|
||||||
WiFi.config(staticIP, gateway, subnet, dns);
|
WiFi.config(staticIP, gateway, subnet, dns);
|
||||||
WiFi.hostname("ESP8266 IOT development");
|
WiFi.hostname("ESP8266 IOT development");
|
||||||
WiFi.begin(SSID, PASSWORD);
|
WiFi.begin(SSID, PASSWORD);
|
||||||
|
|
||||||
Serial.println(F("Connecting ..."));
|
Serial.println(F("Connecting ..."));
|
||||||
while (WiFi.status() != WL_CONNECTED) {
|
while (WiFi.status() != WL_CONNECTED) {
|
||||||
delay(250);
|
delay(250);
|
||||||
Serial.print('.');
|
Serial.print('.');
|
||||||
}
|
}
|
||||||
Serial.print(F("\nConnected to "));
|
Serial.print(F("\nConnected to "));
|
||||||
Serial.println(WiFi.SSID());
|
Serial.println(WiFi.SSID());
|
||||||
Serial.print(F("IP address:\t"));
|
Serial.print(F("IP address:\t"));
|
||||||
Serial.println(WiFi.localIP());
|
Serial.println(WiFi.localIP());
|
||||||
//----------------------------------------------------------------------------------------------------------------------------------
|
//----------------------------------------------------------------------------------------------------------------------------------
|
||||||
myTime.setLocation("de");
|
myTime.setLocation("de");
|
||||||
waitForSync();
|
waitForSync();
|
||||||
|
|
||||||
debug(F("Local time: "));
|
debug(F("Local time: "));
|
||||||
debugln(myTime.dateTime("H:i:s"));
|
debugln(myTime.dateTime("H:i:s"));
|
||||||
setInterval();
|
setInterval();
|
||||||
server.on("/", HTTP_GET, handleHome);
|
server.on("/", HTTP_GET, handleHome);
|
||||||
server.on("/settings", HTTP_GET, handleSettings);
|
server.on("/settings", HTTP_GET, handleSettings);
|
||||||
server.on("/settings", HTTP_POST, handleTime);
|
server.on("/settings", HTTP_POST, handleTime);
|
||||||
server.on("/toggle", HTTP_GET, handleToggle);
|
server.on("/toggle", HTTP_GET, handleToggle);
|
||||||
server.on("/version", HTTP_GET,
|
server.on("/version", HTTP_GET,
|
||||||
[] { server.send(200, "text/html", version); });
|
[] { server.send(200, "text/html", version); });
|
||||||
server.begin();
|
server.begin();
|
||||||
debugln(F("Webserver started"));
|
debugln(F("Webserver started"));
|
||||||
}
|
}
|
||||||
|
|
||||||
void loop() {
|
void loop() {
|
||||||
server.handleClient();
|
server.handleClient();
|
||||||
timer();
|
timer();
|
||||||
r++;
|
r++;
|
||||||
if (r == 7) {
|
if (r == 7) {
|
||||||
r = 0;
|
r = 0;
|
||||||
}
|
}
|
||||||
yield();
|
yield();
|
||||||
delay(50);
|
delay(50);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue