2024-04-15 18:28:30 +00:00
|
|
|
#ifndef MAINWEBSERVER_H
|
|
|
|
#define MAINWEBSERVER_H
|
2023-06-13 19:11:23 +00:00
|
|
|
|
|
|
|
#include "Arduino.h"
|
|
|
|
#include "stdlib_noniso.h"
|
|
|
|
#include "WiFi.h"
|
|
|
|
#include "AsyncTCP.h"
|
|
|
|
#include "Update.h"
|
|
|
|
#include "esp_int_wdt.h"
|
|
|
|
#include "esp_task_wdt.h"
|
|
|
|
#include "ESPAsyncWebServer.h"
|
|
|
|
#include "SPIFFS.h"
|
|
|
|
#include "hardware.h"
|
2023-06-13 21:05:43 +00:00
|
|
|
#include "settings.h"
|
2023-06-13 19:11:23 +00:00
|
|
|
|
|
|
|
class MainWebServerClass{
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
|
|
|
void begin(AsyncWebServer *server, const char* username = "", const char* password = ""){
|
|
|
|
_server = server;
|
|
|
|
|
|
|
|
if(strlen(username) > 0){
|
|
|
|
_authRequired = true;
|
|
|
|
_username = username;
|
|
|
|
_password = password;
|
|
|
|
}else{
|
|
|
|
_authRequired = false;
|
|
|
|
_username = "";
|
|
|
|
_password = "";
|
|
|
|
}
|
|
|
|
|
|
|
|
_server->on("/", HTTP_GET, [&](AsyncWebServerRequest *request){
|
|
|
|
if(_authRequired){
|
|
|
|
if(!request->authenticate(_username.c_str(), _password.c_str())){
|
|
|
|
return request->requestAuthentication();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-04-15 18:28:30 +00:00
|
|
|
request->send(SPIFFS, "/index.html", String(), false);
|
2023-06-13 19:11:23 +00:00
|
|
|
});
|
|
|
|
|
2024-04-13 15:16:27 +00:00
|
|
|
_server->on("/version", HTTP_GET, [&](AsyncWebServerRequest *request){
|
|
|
|
if(_authRequired){
|
|
|
|
if(!request->authenticate(_username.c_str(), _password.c_str())){
|
|
|
|
return request->requestAuthentication();
|
|
|
|
}
|
|
|
|
}
|
2024-04-15 18:28:30 +00:00
|
|
|
request->send(200, "application/json", "{\"version\":\"3.2.5\"}");
|
2024-04-13 15:16:27 +00:00
|
|
|
});
|
|
|
|
|
2023-06-13 19:11:23 +00:00
|
|
|
_server->onNotFound([&](AsyncWebServerRequest *request){
|
2023-06-13 21:05:43 +00:00
|
|
|
if(_authRequired){
|
|
|
|
if(!request->authenticate(_username.c_str(), _password.c_str())){
|
|
|
|
return request->requestAuthentication();
|
|
|
|
}
|
|
|
|
}
|
2023-06-13 19:11:23 +00:00
|
|
|
request->send(200, "application/json", "{\"msg\":\"The content you are looking for was not found\"}");
|
|
|
|
});
|
|
|
|
|
2024-04-13 21:59:25 +00:00
|
|
|
_server->on("/gpio", HTTP_POST, [&] (AsyncWebServerRequest *request) {
|
2023-06-13 21:05:43 +00:00
|
|
|
String paramOutput;
|
|
|
|
String paramState;
|
|
|
|
|
|
|
|
if(_authRequired){
|
|
|
|
if(!request->authenticate(_username.c_str(), _password.c_str())){
|
|
|
|
return request->requestAuthentication();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// GET input1 value on <ESP_IP>/gpio?output=<paramOutput>&state=<paramState>
|
|
|
|
if (request->hasParam("output") && request->hasParam("state")) {
|
|
|
|
paramOutput = request->getParam("output")->value();
|
|
|
|
paramState = request->getParam("state")->value();
|
|
|
|
|
|
|
|
#ifdef RELAY1
|
|
|
|
if (paramOutput == "relay1") {
|
|
|
|
if (paramState == String(0)){
|
|
|
|
unlockDoor(false);
|
|
|
|
AsyncWebServerResponse *response = request->beginResponse(200, "application/json", "{\"msg\":\"Door Unlocked.\"}");
|
|
|
|
request->send(response);
|
|
|
|
}
|
|
|
|
else if (paramState == String(1)) {
|
2023-12-27 21:42:02 +00:00
|
|
|
lockDoor(false);
|
2023-06-13 21:05:43 +00:00
|
|
|
AsyncWebServerResponse *response = request->beginResponse(200, "application/json", "{\"msg\":\"Door Locked.\"}");
|
|
|
|
request->send(response);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
AsyncWebServerResponse *response = request->beginResponse(200, "application/json", "{\"msg\":\"Incorect state provide 0 to unlock and 1 to lock.\"}");
|
|
|
|
request->send(response);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "{\"msg\":\"Error with request, incorrect GPIO pin number.\"}");
|
|
|
|
request->send(response);
|
|
|
|
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
#ifdef RELAY1
|
|
|
|
_server->on("/state/relay1", HTTP_GET, [&] (AsyncWebServerRequest *request) {
|
|
|
|
if(_authRequired){
|
|
|
|
if(!request->authenticate(_username.c_str(), _password.c_str())){
|
|
|
|
return request->requestAuthentication();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
AsyncWebServerResponse *response = request->beginResponse(200, "application/json", "{\"state\":\""+stateDoor()+"\"}");
|
|
|
|
request->send(response);
|
|
|
|
});
|
|
|
|
#endif
|
|
|
|
|
2024-04-15 19:07:26 +00:00
|
|
|
_server->on("/settings/DoorDisabled", HTTP_GET, [&] (AsyncWebServerRequest *request) {
|
2023-06-13 21:05:43 +00:00
|
|
|
if(_authRequired){
|
|
|
|
if(!request->authenticate(_username.c_str(), _password.c_str())){
|
|
|
|
return request->requestAuthentication();
|
|
|
|
}
|
|
|
|
}
|
2023-12-28 09:14:36 +00:00
|
|
|
AsyncWebServerResponse *response = request->beginResponse(200, "application/json", "{\"value\":\""+String(settings.getDoorDisabled())+"\"}");
|
2023-06-13 21:05:43 +00:00
|
|
|
request->send(response);
|
|
|
|
});
|
|
|
|
|
2024-04-15 19:07:26 +00:00
|
|
|
_server->on("/settings/DoorDisabled", HTTP_POST, [&] (AsyncWebServerRequest *request) {
|
2023-06-13 21:05:43 +00:00
|
|
|
String value;
|
|
|
|
|
|
|
|
if(_authRequired){
|
|
|
|
if(!request->authenticate(_username.c_str(), _password.c_str())){
|
|
|
|
return request->requestAuthentication();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (request->hasParam("value")) {
|
|
|
|
value = request->getParam("value")->value();
|
|
|
|
if (value == "0") {
|
|
|
|
settings.setDisableDoor(0);
|
|
|
|
AsyncWebServerResponse *response = request->beginResponse(200, "application/json", "{\"msg\":\"value set to 0\"}");
|
|
|
|
request->send(response);
|
|
|
|
}
|
|
|
|
else if (value =="1") {
|
|
|
|
settings.setDisableDoor(1);
|
|
|
|
AsyncWebServerResponse *response = request->beginResponse(200, "application/json", "{\"msg\":\"value set to 1\"}");
|
|
|
|
request->send(response);
|
|
|
|
|
|
|
|
} else {
|
|
|
|
AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "{\"msg\":\"value should be 0 or 1\"}");
|
|
|
|
request->send(response);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "{\"msg\":\"Missing 'value' param.\"}");
|
|
|
|
request->send(response);
|
|
|
|
}
|
|
|
|
});
|
2024-04-13 21:51:35 +00:00
|
|
|
|
|
|
|
|
2024-04-15 19:07:26 +00:00
|
|
|
_server->on("/settings/tinanceCreds", HTTP_GET, [&] (AsyncWebServerRequest *request) {
|
2024-04-13 21:51:35 +00:00
|
|
|
if(_authRequired){
|
|
|
|
if(!request->authenticate(_username.c_str(), _password.c_str())){
|
|
|
|
return request->requestAuthentication();
|
|
|
|
}
|
|
|
|
}
|
2024-04-15 18:28:30 +00:00
|
|
|
AsyncWebServerResponse *response = request->beginResponse(200, "application/json", "{\"identifier\":\""+settings.tinance2ReaderIdentifier+"\", \"key\":\""+settings.tinance2ReaderKey+"\"}");
|
2024-04-13 21:51:35 +00:00
|
|
|
request->send(response);
|
|
|
|
});
|
|
|
|
|
2024-04-15 19:07:26 +00:00
|
|
|
_server->on("/settings/tinanceCreds", HTTP_POST, [&] (AsyncWebServerRequest *request) {
|
2024-04-13 21:51:35 +00:00
|
|
|
if(_authRequired){
|
|
|
|
if(!request->authenticate(_username.c_str(), _password.c_str())){
|
|
|
|
return request->requestAuthentication();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if(request->hasParam("identifier", true)) {} //This is important, otherwise the sketch will crash if there is no body
|
|
|
|
else {
|
|
|
|
AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "{\"msg\":\"No identifier\"}");
|
|
|
|
request->send(response);
|
|
|
|
}
|
|
|
|
String identifier = String(request->arg("identifier"));
|
|
|
|
|
|
|
|
if(request->hasParam("key", true)) {} //This is important, otherwise the sketch will crash if there is no body
|
|
|
|
else {
|
|
|
|
AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "{\"msg\":\"No key\"}");
|
|
|
|
request->send(response);
|
|
|
|
}
|
|
|
|
String key = String(request->arg("key"));
|
|
|
|
|
2024-04-15 18:28:30 +00:00
|
|
|
settings.tinance2ReaderIdentifier = identifier;
|
|
|
|
settings.tinance2ReaderKey = key;
|
|
|
|
|
|
|
|
settings.saveSetting("t2", "ri", settings.tinance2ReaderIdentifier, "string");
|
|
|
|
settings.saveSetting("t2", "rk", settings.tinance2ReaderKey, "string");
|
|
|
|
|
2024-04-13 21:51:35 +00:00
|
|
|
|
|
|
|
AsyncWebServerResponse *response = request->beginResponse(200, "application/json", "{\"msg\":\"Tinance credentials updated\"}");
|
|
|
|
request->send(response);
|
|
|
|
|
|
|
|
});
|
2024-04-15 18:28:30 +00:00
|
|
|
|
|
|
|
|
2024-04-15 19:07:26 +00:00
|
|
|
_server->on("/settings/tinanceurl", HTTP_POST, [&] (AsyncWebServerRequest *request) {
|
2024-04-15 18:28:30 +00:00
|
|
|
if(_authRequired){
|
|
|
|
if(!request->authenticate(_username.c_str(), _password.c_str())){
|
|
|
|
return request->requestAuthentication();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if(request->hasParam("url", true)) {} //This is important, otherwise the sketch will crash if there is no body
|
|
|
|
else {
|
|
|
|
AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "{\"msg\":\"No url\"}");
|
|
|
|
request->send(response);
|
|
|
|
}
|
|
|
|
String url = String(request->arg("url"));
|
|
|
|
|
2024-04-15 19:07:26 +00:00
|
|
|
settings.tinance2_url = url;
|
|
|
|
settings.saveSetting("t2", "rooturl", settings.tinance2_url, "string");
|
2024-04-15 18:28:30 +00:00
|
|
|
|
|
|
|
AsyncWebServerResponse *response = request->beginResponse(200, "application/json", "{\"msg\":\"Tinance URL updated\"}");
|
|
|
|
request->send(response);
|
|
|
|
|
|
|
|
});
|
|
|
|
|
2024-04-15 19:07:26 +00:00
|
|
|
_server->on("/settings/tinanceurl", HTTP_GET, [&] (AsyncWebServerRequest *request) {
|
|
|
|
if(_authRequired){
|
|
|
|
if(!request->authenticate(_username.c_str(), _password.c_str())){
|
|
|
|
return request->requestAuthentication();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
AsyncWebServerResponse *response = request->beginResponse(200, "application/json", "{\"value\":\""+settings.tinance2_url+"\"}");
|
|
|
|
request->send(response);
|
|
|
|
});
|
|
|
|
|
2024-04-15 18:28:30 +00:00
|
|
|
|
|
|
|
_server->on("/settings/validatecardurl", HTTP_GET, [&] (AsyncWebServerRequest *request) {
|
|
|
|
if(_authRequired){
|
|
|
|
if(!request->authenticate(_username.c_str(), _password.c_str())){
|
|
|
|
return request->requestAuthentication();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
AsyncWebServerResponse *response = request->beginResponse(200, "application/json", "{\"value\":\""+settings.tinance2_url_validatecard+"\"}");
|
|
|
|
request->send(response);
|
|
|
|
});
|
|
|
|
|
|
|
|
|
2024-04-15 19:07:26 +00:00
|
|
|
_server->on("/settings/readerinfourl", HTTP_GET, [&] (AsyncWebServerRequest *request) {
|
|
|
|
if(_authRequired){
|
|
|
|
if(!request->authenticate(_username.c_str(), _password.c_str())){
|
|
|
|
return request->requestAuthentication();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
AsyncWebServerResponse *response = request->beginResponse(200, "application/json", "{\"value\":\""+settings.tinance2_url_readerinfo+"\"}");
|
|
|
|
request->send(response);
|
|
|
|
});
|
|
|
|
|
|
|
|
_server->on("/settings/aclsurl", HTTP_GET, [&] (AsyncWebServerRequest *request) {
|
|
|
|
if(_authRequired){
|
|
|
|
if(!request->authenticate(_username.c_str(), _password.c_str())){
|
|
|
|
return request->requestAuthentication();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
AsyncWebServerResponse *response = request->beginResponse(200, "application/json", "{\"value\":\""+settings.tinance2_url_acls+"\"}");
|
|
|
|
request->send(response);
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
_server->on("/settings/logurl", HTTP_GET, [&] (AsyncWebServerRequest *request) {
|
|
|
|
if(_authRequired){
|
|
|
|
if(!request->authenticate(_username.c_str(), _password.c_str())){
|
|
|
|
return request->requestAuthentication();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
AsyncWebServerResponse *response = request->beginResponse(200, "application/json", "{\"value\":\""+settings.tinance2_url_log+"\"}");
|
|
|
|
request->send(response);
|
|
|
|
});
|
|
|
|
|
|
|
|
_server->on("/settings/webhooklockenabled", HTTP_GET, [&] (AsyncWebServerRequest *request) {
|
|
|
|
if(_authRequired){
|
|
|
|
if(!request->authenticate(_username.c_str(), _password.c_str())){
|
|
|
|
return request->requestAuthentication();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
AsyncWebServerResponse *response = request->beginResponse(200, "application/json", "{\"value\":\""+String(settings.webhookLockEnabled)+"\"}");
|
|
|
|
request->send(response);
|
|
|
|
});
|
|
|
|
|
|
|
|
_server->on("/settings/webhooklockenabled", HTTP_POST, [&] (AsyncWebServerRequest *request) {
|
|
|
|
String value;
|
|
|
|
|
|
|
|
if(_authRequired){
|
|
|
|
if(!request->authenticate(_username.c_str(), _password.c_str())){
|
|
|
|
return request->requestAuthentication();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (request->hasParam("value")) {
|
|
|
|
value = request->getParam("value")->value();
|
|
|
|
if (value == "0") {
|
|
|
|
settings.webhookLockEnabled = 0;
|
|
|
|
settings.saveSetting("wh", "lockena", String(settings.webhookLockEnabled), "bool");
|
|
|
|
AsyncWebServerResponse *response = request->beginResponse(200, "application/json", "{\"msg\":\"value set to 0\"}");
|
|
|
|
request->send(response);
|
|
|
|
}
|
|
|
|
else if (value =="1") {
|
|
|
|
settings.webhookLockEnabled = 1;
|
|
|
|
settings.saveSetting("wh", "lockena", String(settings.webhookLockEnabled), "bool");
|
|
|
|
AsyncWebServerResponse *response = request->beginResponse(200, "application/json", "{\"msg\":\"value set to 1\"}");
|
|
|
|
request->send(response);
|
|
|
|
|
|
|
|
} else {
|
|
|
|
AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "{\"msg\":\"value should be 0 or 1\"}");
|
|
|
|
request->send(response);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "{\"msg\":\"Missing 'value' param.\"}");
|
|
|
|
request->send(response);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
_server->on("/settings/webhooklockhook", HTTP_GET, [&] (AsyncWebServerRequest *request) {
|
|
|
|
if(_authRequired){
|
|
|
|
if(!request->authenticate(_username.c_str(), _password.c_str())){
|
|
|
|
return request->requestAuthentication();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
AsyncWebServerResponse *response = request->beginResponse(200, "application/json", "{\"value\":\""+settings.webhookLockHook+"\"}");
|
|
|
|
request->send(response);
|
|
|
|
});
|
|
|
|
|
|
|
|
_server->on("/settings/webhooklockhook", HTTP_POST, [&] (AsyncWebServerRequest *request) {
|
|
|
|
String value;
|
|
|
|
|
|
|
|
if(_authRequired){
|
|
|
|
if(!request->authenticate(_username.c_str(), _password.c_str())){
|
|
|
|
return request->requestAuthentication();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (request->hasParam("value")) {
|
|
|
|
value = request->getParam("value")->value();
|
|
|
|
settings.webhookLockHook = value;
|
|
|
|
settings.saveSetting("wh", "lockurl", settings.webhookLockHook, "string");
|
|
|
|
AsyncWebServerResponse *response = request->beginResponse(200, "application/json", "{\"msg\":\"value set to "+value+"\"}");
|
|
|
|
request->send(response);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "{\"msg\":\"Missing 'value' param.\"}");
|
|
|
|
request->send(response);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
_server->on("/settings/webhookunlockenabled", HTTP_GET, [&] (AsyncWebServerRequest *request) {
|
|
|
|
if(_authRequired){
|
|
|
|
if(!request->authenticate(_username.c_str(), _password.c_str())){
|
|
|
|
return request->requestAuthentication();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
AsyncWebServerResponse *response = request->beginResponse(200, "application/json", "{\"value\":\""+String(settings.webhookUnlockEnabled)+"\"}");
|
|
|
|
request->send(response);
|
|
|
|
});
|
|
|
|
|
|
|
|
_server->on("/settings/webhookunlockenabled", HTTP_POST, [&] (AsyncWebServerRequest *request) {
|
|
|
|
String value;
|
|
|
|
|
|
|
|
if(_authRequired){
|
|
|
|
if(!request->authenticate(_username.c_str(), _password.c_str())){
|
|
|
|
return request->requestAuthentication();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (request->hasParam("value")) {
|
|
|
|
value = request->getParam("value")->value();
|
|
|
|
if (value == "0") {
|
|
|
|
settings.webhookUnlockEnabled = 0;
|
|
|
|
settings.saveSetting("wh", "unlockena", String(settings.webhookUnlockEnabled), "bool");
|
|
|
|
AsyncWebServerResponse *response = request->beginResponse(200, "application/json", "{\"msg\":\"value set to 0\"}");
|
|
|
|
request->send(response);
|
|
|
|
}
|
|
|
|
else if (value =="1") {
|
|
|
|
settings.webhookUnlockEnabled = 1;
|
|
|
|
settings.saveSetting("wh", "unlockena", String(settings.webhookUnlockEnabled), "bool");
|
|
|
|
AsyncWebServerResponse *response = request->beginResponse(200, "application/json", "{\"msg\":\"value set to 1\"}");
|
|
|
|
request->send(response);
|
|
|
|
|
|
|
|
} else {
|
|
|
|
AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "{\"msg\":\"value should be 0 or 1\"}");
|
|
|
|
request->send(response);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "{\"msg\":\"Missing 'value' param.\"}");
|
|
|
|
request->send(response);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
_server->on("/settings/webhookunlockhook", HTTP_GET, [&] (AsyncWebServerRequest *request) {
|
|
|
|
if(_authRequired){
|
|
|
|
if(!request->authenticate(_username.c_str(), _password.c_str())){
|
|
|
|
return request->requestAuthentication();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
AsyncWebServerResponse *response = request->beginResponse(200, "application/json", "{\"value\":\""+settings.webhookUnlockHook+"\"}");
|
|
|
|
request->send(response);
|
|
|
|
});
|
|
|
|
|
|
|
|
_server->on("/settings/webhookunlockhook", HTTP_POST, [&] (AsyncWebServerRequest *request) {
|
|
|
|
String value;
|
|
|
|
|
|
|
|
if(_authRequired){
|
|
|
|
if(!request->authenticate(_username.c_str(), _password.c_str())){
|
|
|
|
return request->requestAuthentication();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (request->hasParam("value")) {
|
|
|
|
value = request->getParam("value")->value();
|
|
|
|
settings.webhookUnlockHook = value;
|
|
|
|
settings.saveSetting("wh", "unlockurl", settings.webhookUnlockHook, "string");
|
|
|
|
AsyncWebServerResponse *response = request->beginResponse(200, "application/json", "{\"msg\":\"value set to "+value+"\"}");
|
|
|
|
request->send(response);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "{\"msg\":\"Missing 'value' param.\"}");
|
|
|
|
request->send(response);
|
|
|
|
}
|
|
|
|
});
|
2024-04-15 18:28:30 +00:00
|
|
|
|
2023-06-13 19:11:23 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// deprecated, keeping for backward compatibility
|
|
|
|
void loop() {
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
AsyncWebServer *_server;
|
|
|
|
String _username = "";
|
|
|
|
String _password = "";
|
|
|
|
bool _authRequired = false;
|
|
|
|
};
|
|
|
|
|
|
|
|
MainWebServerClass MainWebServer;
|
|
|
|
#endif
|