From 70e0ebed53788ee56b754dfec01e4c87395a993a Mon Sep 17 00:00:00 2001 From: Matthew Frost Date: Tue, 13 Jun 2023 22:18:44 +0200 Subject: [PATCH 1/3] move stuff --- include/aclwebserver.h | 189 ++++++++++++++++++++++++++++++++++++++++ include/hardware.h | 6 ++ include/main.h | 6 -- include/mainwebserver.h | 43 +++++++++ src/main.cpp | 161 +--------------------------------- 5 files changed, 242 insertions(+), 163 deletions(-) create mode 100644 include/aclwebserver.h diff --git a/include/aclwebserver.h b/include/aclwebserver.h new file mode 100644 index 0000000..8115295 --- /dev/null +++ b/include/aclwebserver.h @@ -0,0 +1,189 @@ +#ifndef aclwebserver_h +#define aclwebserver_h + +#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 "hardware.h" +#include +#include + + + +class ACLWebServerClass{ + + 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->onNotFound([&](AsyncWebServerRequest *request){ + request->send(200, "application/json", "{\"msg\":\"The content you are looking for was not found\"}"); + }); + + _server->on("/users", HTTP_GET, handleListUsers); + + + _server->on("/users/create", HTTP_POST, handleCreateUser); + _server->on("/users/update", HTTP_POST, handleUpdateUser); + _server->on("/users/remove", HTTP_POST, handleRemoveUser); + + } + + // deprecated, keeping for backward compatibility + void loop() { + } + + private: + AsyncWebServer *_server; + String _username = ""; + String _password = ""; + bool _authRequired = false; + + static String outputState(int output){ + if(digitalRead(output)){ + return "checked"; + } + else { + return ""; + } + } + + // Handler for the '/users' endpoint to list all users + void handleListUsers(AsyncWebServerRequest* request) { + + if(_authRequired){ + if(!request->authenticate(_username.c_str(), _password.c_str())){ + return request->requestAuthentication(); + } + } + // Create a JSON array to store the users + StaticJsonDocument<512> jsonDoc; + JsonArray usersArray = jsonDoc.to(); + + // Retrieve the ACL data using the getter function + const User* aclData = acl.getACL(); + + // Iterate over each user in the ACL and add it to the JSON array + for (int i = 0; i < acl.getACLSize(); i++) { + JsonObject user = usersArray.createNestedObject(); + user["cardId"] = aclData[i].cardId; + user["desc"] = aclData[i].desc; + } + + // Convert the JSON array to a string + String response; + serializeJson(usersArray, response); + + // Set the response content type to JSON + request->send(200, "application/json", response); + } + + + + void handleCreateUser(AsyncWebServerRequest* request) { + if(_authRequired){ + if(!request->authenticate(_username.c_str(), _password.c_str())){ + return request->requestAuthentication(); + } + } + + if(request->hasParam("cardId", true)) {} //This is important, otherwise the sketch will crash if there is no body + else { + AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "{\"msg\":\"No cardId\"}"); + request->send(response); + } + + if(request->hasParam("desc", true)) {} //This is important, otherwise the sketch will crash if there is no body + else { + AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "{\"msg\":\"No desc\"}"); + request->send(response); + } + + String cardId = String(request->arg("cardId")); + String desc = String(request->arg("desc")); + + if (acl.validateAccess(String(cardId))) { + AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "{\"msg\":\"Duplicate ACL\"}"); + request->send(response); + } else { + acl.addUser(cardId, desc); + acl.saveToEEPROM(); + request->send(201); // Create + } + + } + + // Handler for the '/users/update' endpoint to remove a user + void handleUpdateUser(AsyncWebServerRequest* request) { + if(_authRequired){ + if(!request->authenticate(_username.c_str(), _password.c_str())){ + return request->requestAuthentication(); + } + } + + if(request->hasParam("cardId", true)) {} //This is important, otherwise the sketch will crash if there is no body + else { + AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "{\"msg\":\"No cardId\"}"); + request->send(response); + } + + if(request->hasParam("newCardId", true)) {} //This is important, otherwise the sketch will crash if there is no body + else { + AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "\"msg\":\"No newCardId\"}"); + request->send(response); + } + + if(request->hasParam("desc", true)) {} //This is important, otherwise the sketch will crash if there is no body + else { + AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "{\"msg\":\"No desc\"}"); + request->send(response); + } + String cardId = String(request->arg("cardId")); + String newCardId = String(request->arg("newCardId")); + String desc = String(request->arg("desc")); + acl.updateUser(cardId, newCardId, desc); + acl.saveToEEPROM(); + request->send(201); // Created + } + + // Handler for the '/users/remove' endpoint to remove a user + void handleRemoveUser(AsyncWebServerRequest* request) { + if(_authRequired){ + if(!request->authenticate(_username.c_str(), _password.c_str())){ + return request->requestAuthentication(); + } + } + + if(request->hasParam("cardId", true)) {} //This is important, otherwise the sketch will crash if there is no body + else { + AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "{\"msg\":\"No cardId\"}"); + request->send(response); + } + String cardId = String(request->arg("cardId")); + acl.removeUser(cardId); + acl.saveToEEPROM(); + request->send(201); // Created + } + + + +}; + +ACLWebServerClass ACLWebServer; +#endif diff --git a/include/hardware.h b/include/hardware.h index e9db3f5..a43c332 100644 --- a/include/hardware.h +++ b/include/hardware.h @@ -34,4 +34,10 @@ void lockDoor(); void toggleDoor(); String stateDoor(); + + #ifdef LOCAL_ACL + #include "ACL.h" + ACL acl = { + }; + #endif #endif diff --git a/include/main.h b/include/main.h index 792de14..aa79d35 100644 --- a/include/main.h +++ b/include/main.h @@ -6,12 +6,6 @@ #include "secrets.h" #include "settings.h" - #ifdef LOCAL_ACL - #include "ACL.h" - ACL acl = { - }; - #endif - #ifdef WIFI #include "WiFi.h" #endif diff --git a/include/mainwebserver.h b/include/mainwebserver.h index 2e4b91b..5318479 100644 --- a/include/mainwebserver.h +++ b/include/mainwebserver.h @@ -43,6 +43,49 @@ class MainWebServerClass{ request->send(200, "application/json", "{\"msg\":\"The content you are looking for was not found\"}"); }); + _server->on("/gpio", HTTP_GET, [&] (AsyncWebServerRequest *request) { + String paramOutput; + String paramState; + + if(_authRequired){ + if(!request->authenticate(_username.c_str(), _password.c_str())){ + return request->requestAuthentication(); + } + } + + // GET input1 value on /gpio?output=&state= + 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)) { + lockDoor(); + 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); + + } + }); + + } // deprecated, keeping for backward compatibility diff --git a/src/main.cpp b/src/main.cpp index 17385b1..1e3013c 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -97,117 +97,6 @@ void WiFiGotIP(WiFiEvent_t event, WiFiEventInfo_t info){ #ifdef WEB_SERVER - -#ifdef LOCAL_ACL - #ifdef LOCAL_ACL_API - // Handler for the '/users' endpoint to list all users - void handleListUsers(AsyncWebServerRequest* request) { - - if(!request->authenticate(http_username, http_password)) - return request->requestAuthentication(); - // Create a JSON array to store the users - StaticJsonDocument<512> jsonDoc; - JsonArray usersArray = jsonDoc.to(); - - // Retrieve the ACL data using the getter function - const User* aclData = acl.getACL(); - - // Iterate over each user in the ACL and add it to the JSON array - for (int i = 0; i < acl.getACLSize(); i++) { - JsonObject user = usersArray.createNestedObject(); - user["cardId"] = aclData[i].cardId; - user["desc"] = aclData[i].desc; - } - - // Convert the JSON array to a string - String response; - serializeJson(usersArray, response); - - // Set the response content type to JSON - request->send(200, "application/json", response); - } - - - - void handleCreateUser(AsyncWebServerRequest* request) { - if(!request->authenticate(http_username, http_password)) - return request->requestAuthentication(); - - if(request->hasParam("cardId", true)) {} //This is important, otherwise the sketch will crash if there is no body - else { - AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "{\"msg\":\"No cardId\"}"); - request->send(response); - } - - if(request->hasParam("desc", true)) {} //This is important, otherwise the sketch will crash if there is no body - else { - AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "{\"msg\":\"No desc\"}"); - request->send(response); - } - - String cardId = String(request->arg("cardId")); - String desc = String(request->arg("desc")); - - if (acl.validateAccess(String(cardId))) { - AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "{\"msg\":\"Duplicate ACL\"}"); - request->send(response); - } else { - acl.addUser(cardId, desc); - acl.saveToEEPROM(); - request->send(201); // Create - } - - } - - // Handler for the '/users/update' endpoint to remove a user - void handleUpdateUser(AsyncWebServerRequest* request) { - if(!request->authenticate(http_username, http_password)) - return request->requestAuthentication(); - - if(request->hasParam("cardId", true)) {} //This is important, otherwise the sketch will crash if there is no body - else { - AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "{\"msg\":\"No cardId\"}"); - request->send(response); - } - - if(request->hasParam("newCardId", true)) {} //This is important, otherwise the sketch will crash if there is no body - else { - AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "\"msg\":\"No newCardId\"}"); - request->send(response); - } - - if(request->hasParam("desc", true)) {} //This is important, otherwise the sketch will crash if there is no body - else { - AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "{\"msg\":\"No desc\"}"); - request->send(response); - } - String cardId = String(request->arg("cardId")); - String newCardId = String(request->arg("newCardId")); - String desc = String(request->arg("desc")); - acl.updateUser(cardId, newCardId, desc); - acl.saveToEEPROM(); - request->send(201); // Created - } - - // Handler for the '/users/remove' endpoint to remove a user - void handleRemoveUser(AsyncWebServerRequest* request) { - if(!request->authenticate(http_username, http_password)) - return request->requestAuthentication(); - - if(request->hasParam("cardId", true)) {} //This is important, otherwise the sketch will crash if there is no body - else { - AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "{\"msg\":\"No cardId\"}"); - request->send(response); - } - String cardId = String(request->arg("cardId")); - acl.removeUser(cardId); - acl.saveToEEPROM(); - request->send(201); // Created - } - #endif - #endif - - #endif void handleInterrupt(int bitValue) { @@ -361,56 +250,14 @@ void setup() { - - // Send a GET request to /gpio?output=&state= - server.on("/gpio", HTTP_GET, [] (AsyncWebServerRequest *request) { - String paramOutput; - String paramState; - - if(!request->authenticate(http_username, http_password)) - return request->requestAuthentication(); - - // GET input1 value on /gpio?output=&state= - 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)) { - lockDoor(); - 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); - - } - }); - - MainWebServer.begin(&server, http_username, http_password); + #ifdef WEB_SERVER + MainWebServer.begin(&server, http_username, http_password); + #endif #ifdef LOCAL_ACL #ifdef LOCAL_ACL_API - server.on("/users", HTTP_GET, handleListUsers); - server.on("/users/create", HTTP_POST, handleCreateUser); - server.on("/users/update", HTTP_POST, handleUpdateUser); - server.on("/users/remove", HTTP_POST, handleRemoveUser); + #endif #endif -- 2.30.2 From 2c1c126dc254f075292159ac4841a0f763992f32 Mon Sep 17 00:00:00 2001 From: Matthew Frost Date: Tue, 13 Jun 2023 22:47:52 +0200 Subject: [PATCH 2/3] webserver basic restructure --- include/aclwebserver.h | 235 ++++++++++++++++++---------------------- include/hardware.h | 5 - include/main.h | 11 +- include/mainwebserver.h | 41 +++++++ src/main.cpp | 67 +----------- 5 files changed, 161 insertions(+), 198 deletions(-) diff --git a/include/aclwebserver.h b/include/aclwebserver.h index 8115295..84a0da1 100644 --- a/include/aclwebserver.h +++ b/include/aclwebserver.h @@ -32,18 +32,117 @@ class ACLWebServerClass{ _password = ""; } - _server->onNotFound([&](AsyncWebServerRequest *request){ - request->send(200, "application/json", "{\"msg\":\"The content you are looking for was not found\"}"); + _server->on("/users", HTTP_GET, [&](AsyncWebServerRequest *request){ + + if(_authRequired){ + if(!request->authenticate(_username.c_str(), _password.c_str())){ + return request->requestAuthentication(); + } + } + // Create a JSON array to store the users + StaticJsonDocument<512> jsonDoc; + JsonArray usersArray = jsonDoc.to(); + + // Retrieve the ACL data using the getter function + const User* aclData = acl.getACL(); + + // Iterate over each user in the ACL and add it to the JSON array + for (int i = 0; i < acl.getACLSize(); i++) { + JsonObject user = usersArray.createNestedObject(); + user["cardId"] = aclData[i].cardId; + user["desc"] = aclData[i].desc; + } + + // Convert the JSON array to a string + String response; + serializeJson(usersArray, response); + + // Set the response content type to JSON + request->send(200, "application/json", response); }); - _server->on("/users", HTTP_GET, handleListUsers); + _server->on("/users/create", HTTP_POST, [&](AsyncWebServerRequest *request){ + if(_authRequired){ + if(!request->authenticate(_username.c_str(), _password.c_str())){ + return request->requestAuthentication(); + } + } + + if(request->hasParam("cardId", true)) {} //This is important, otherwise the sketch will crash if there is no body + else { + AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "{\"msg\":\"No cardId\"}"); + request->send(response); + } - - _server->on("/users/create", HTTP_POST, handleCreateUser); - _server->on("/users/update", HTTP_POST, handleUpdateUser); - _server->on("/users/remove", HTTP_POST, handleRemoveUser); + if(request->hasParam("desc", true)) {} //This is important, otherwise the sketch will crash if there is no body + else { + AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "{\"msg\":\"No desc\"}"); + request->send(response); + } - } + String cardId = String(request->arg("cardId")); + String desc = String(request->arg("desc")); + + if (acl.validateAccess(String(cardId))) { + AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "{\"msg\":\"Duplicate ACL\"}"); + request->send(response); + } else { + acl.addUser(cardId, desc); + acl.saveToEEPROM(); + request->send(201); // Create + } + }); + + _server->on("/users/update", HTTP_POST, [&](AsyncWebServerRequest *request){ + if(_authRequired){ + if(!request->authenticate(_username.c_str(), _password.c_str())){ + return request->requestAuthentication(); + } + } + + if(request->hasParam("cardId", true)) {} //This is important, otherwise the sketch will crash if there is no body + else { + AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "{\"msg\":\"No cardId\"}"); + request->send(response); + } + + if(request->hasParam("newCardId", true)) {} //This is important, otherwise the sketch will crash if there is no body + else { + AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "\"msg\":\"No newCardId\"}"); + request->send(response); + } + + if(request->hasParam("desc", true)) {} //This is important, otherwise the sketch will crash if there is no body + else { + AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "{\"msg\":\"No desc\"}"); + request->send(response); + } + String cardId = String(request->arg("cardId")); + String newCardId = String(request->arg("newCardId")); + String desc = String(request->arg("desc")); + acl.updateUser(cardId, newCardId, desc); + acl.saveToEEPROM(); + request->send(201); // Created + }); + + _server->on("/users/remove", HTTP_POST, [&](AsyncWebServerRequest *request){ + if(_authRequired){ + if(!request->authenticate(_username.c_str(), _password.c_str())){ + return request->requestAuthentication(); + } + } + + if(request->hasParam("cardId", true)) {} //This is important, otherwise the sketch will crash if there is no body + else { + AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "{\"msg\":\"No cardId\"}"); + request->send(response); + } + String cardId = String(request->arg("cardId")); + acl.removeUser(cardId); + acl.saveToEEPROM(); + request->send(201); // Created + }); + } // deprecated, keeping for backward compatibility void loop() { @@ -63,126 +162,6 @@ class ACLWebServerClass{ return ""; } } - - // Handler for the '/users' endpoint to list all users - void handleListUsers(AsyncWebServerRequest* request) { - - if(_authRequired){ - if(!request->authenticate(_username.c_str(), _password.c_str())){ - return request->requestAuthentication(); - } - } - // Create a JSON array to store the users - StaticJsonDocument<512> jsonDoc; - JsonArray usersArray = jsonDoc.to(); - - // Retrieve the ACL data using the getter function - const User* aclData = acl.getACL(); - - // Iterate over each user in the ACL and add it to the JSON array - for (int i = 0; i < acl.getACLSize(); i++) { - JsonObject user = usersArray.createNestedObject(); - user["cardId"] = aclData[i].cardId; - user["desc"] = aclData[i].desc; - } - - // Convert the JSON array to a string - String response; - serializeJson(usersArray, response); - - // Set the response content type to JSON - request->send(200, "application/json", response); - } - - - - void handleCreateUser(AsyncWebServerRequest* request) { - if(_authRequired){ - if(!request->authenticate(_username.c_str(), _password.c_str())){ - return request->requestAuthentication(); - } - } - - if(request->hasParam("cardId", true)) {} //This is important, otherwise the sketch will crash if there is no body - else { - AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "{\"msg\":\"No cardId\"}"); - request->send(response); - } - - if(request->hasParam("desc", true)) {} //This is important, otherwise the sketch will crash if there is no body - else { - AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "{\"msg\":\"No desc\"}"); - request->send(response); - } - - String cardId = String(request->arg("cardId")); - String desc = String(request->arg("desc")); - - if (acl.validateAccess(String(cardId))) { - AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "{\"msg\":\"Duplicate ACL\"}"); - request->send(response); - } else { - acl.addUser(cardId, desc); - acl.saveToEEPROM(); - request->send(201); // Create - } - - } - - // Handler for the '/users/update' endpoint to remove a user - void handleUpdateUser(AsyncWebServerRequest* request) { - if(_authRequired){ - if(!request->authenticate(_username.c_str(), _password.c_str())){ - return request->requestAuthentication(); - } - } - - if(request->hasParam("cardId", true)) {} //This is important, otherwise the sketch will crash if there is no body - else { - AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "{\"msg\":\"No cardId\"}"); - request->send(response); - } - - if(request->hasParam("newCardId", true)) {} //This is important, otherwise the sketch will crash if there is no body - else { - AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "\"msg\":\"No newCardId\"}"); - request->send(response); - } - - if(request->hasParam("desc", true)) {} //This is important, otherwise the sketch will crash if there is no body - else { - AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "{\"msg\":\"No desc\"}"); - request->send(response); - } - String cardId = String(request->arg("cardId")); - String newCardId = String(request->arg("newCardId")); - String desc = String(request->arg("desc")); - acl.updateUser(cardId, newCardId, desc); - acl.saveToEEPROM(); - request->send(201); // Created - } - - // Handler for the '/users/remove' endpoint to remove a user - void handleRemoveUser(AsyncWebServerRequest* request) { - if(_authRequired){ - if(!request->authenticate(_username.c_str(), _password.c_str())){ - return request->requestAuthentication(); - } - } - - if(request->hasParam("cardId", true)) {} //This is important, otherwise the sketch will crash if there is no body - else { - AsyncWebServerResponse *response = request->beginResponse(400, "application/json", "{\"msg\":\"No cardId\"}"); - request->send(response); - } - String cardId = String(request->arg("cardId")); - acl.removeUser(cardId); - acl.saveToEEPROM(); - request->send(201); // Created - } - - - }; ACLWebServerClass ACLWebServer; diff --git a/include/hardware.h b/include/hardware.h index a43c332..d75f029 100644 --- a/include/hardware.h +++ b/include/hardware.h @@ -35,9 +35,4 @@ void toggleDoor(); String stateDoor(); - #ifdef LOCAL_ACL - #include "ACL.h" - ACL acl = { - }; - #endif #endif diff --git a/include/main.h b/include/main.h index aa79d35..ac78e03 100644 --- a/include/main.h +++ b/include/main.h @@ -6,6 +6,8 @@ #include "secrets.h" #include "settings.h" + Settings settings; + #ifdef WIFI #include "WiFi.h" #endif @@ -24,7 +26,14 @@ #endif #include "mainwebserver.h" - + #ifdef LOCAL_ACL + #include "acl.h" + ACL acl = { + }; + #ifdef LOCAL_ACL_API + #include "aclwebserver.h" + #endif + #endif #endif #ifdef BUZZER diff --git a/include/mainwebserver.h b/include/mainwebserver.h index 5318479..66a23a3 100644 --- a/include/mainwebserver.h +++ b/include/mainwebserver.h @@ -85,7 +85,48 @@ class MainWebServerClass{ } }); + #ifdef RELAY1 + _server->on("/state/relay1", HTTP_GET, [] (AsyncWebServerRequest *request) { + if(!request->authenticate(http_username, http_password)) + return request->requestAuthentication(); + AsyncWebServerResponse *response = request->beginResponse(200, "application/json", "{\"state\":\""+stateDoor()+"\"}"); + request->send(response); + }); + #endif + _server->on("/settings/get/DoorDisabled", HTTP_GET, [] (AsyncWebServerRequest *request) { + AsyncWebServerResponse *response = request->beginResponse(200, "application/json", "{\"value\":\""+String(settings.DoorDisabled())+"\"}"); + request->send(response); + }); + + _server->on("/settings/set/DoorDisabled", HTTP_GET, [] (AsyncWebServerRequest *request) { + String value; + + if(!request->authenticate(http_username, http_password)) + 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); + } + }); } // deprecated, keeping for backward compatibility diff --git a/src/main.cpp b/src/main.cpp index 1e3013c..2928bec 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -7,7 +7,6 @@ const unsigned long displayDelay = 1000; // Delay in milliseconds after which th const unsigned long wifiRebootTimeout = 20000; // Delay before reboot after disconnect unsigned int bitCount = 0; // Variable to keep track of the bit count unsigned int maxReaderWaitTime = 9000; // Variable to timeout reader after too long of no data. -Settings settings; AsyncWebServer server(80); #ifdef WIFI @@ -136,7 +135,6 @@ void setup() { acl.loadFromEEPROM(); #endif - settings.loadFromEEPROM(); // Initialize SPIFFS @@ -192,75 +190,16 @@ void setup() { #ifdef BUZZER pinMode(ALARM_PIN, OUTPUT); - // Do not set to low or it will constantly beep. - digitalWrite(ALARM_PIN, HIGH); + digitalWrite(ALARM_PIN, HIGH); // Do not set to low or it will constantly beep. #endif #ifdef WEB_SERVER - // Route for root / web page - - - #ifdef RELAY1 - server.on("/state/relay1", HTTP_GET, [] (AsyncWebServerRequest *request) { - if(!request->authenticate(http_username, http_password)) - return request->requestAuthentication(); - AsyncWebServerResponse *response = request->beginResponse(200, "application/json", "{\"state\":\""+stateDoor()+"\"}"); - request->send(response); - }); - #endif - - server.on("/settings/get/DoorDisabled", HTTP_GET, [] (AsyncWebServerRequest *request) { - AsyncWebServerResponse *response = request->beginResponse(200, "application/json", "{\"value\":\""+String(settings.DoorDisabled())+"\"}"); - request->send(response); - }); - - - - // Send a GET request to /gpio?output=&state= - server.on("/settings/set/DoorDisabled", HTTP_GET, [] (AsyncWebServerRequest *request) { - String value; - - if(!request->authenticate(http_username, http_password)) - 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); - } - - }); - - - - - #ifdef WEB_SERVER - MainWebServer.begin(&server, http_username, http_password); - #endif - - + MainWebServer.begin(&server, http_username, http_password); #ifdef LOCAL_ACL #ifdef LOCAL_ACL_API - + ACLWebServer.begin(&server, http_username, http_password); #endif #endif - server.begin(); #endif -- 2.30.2 From 40b249778e85386bd455d33c09ad8d21be63ac85 Mon Sep 17 00:00:00 2001 From: Matthew Frost Date: Tue, 13 Jun 2023 22:54:27 +0200 Subject: [PATCH 3/3] webserver --- include/mainwebserver.h | 33 +++++++++++++++++++++++++-------- 1 file changed, 25 insertions(+), 8 deletions(-) diff --git a/include/mainwebserver.h b/include/mainwebserver.h index 66a23a3..a1cfa21 100644 --- a/include/mainwebserver.h +++ b/include/mainwebserver.h @@ -11,6 +11,7 @@ #include "ESPAsyncWebServer.h" #include "SPIFFS.h" #include "hardware.h" +#include "settings.h" class MainWebServerClass{ @@ -40,6 +41,11 @@ class MainWebServerClass{ }); _server->onNotFound([&](AsyncWebServerRequest *request){ + if(_authRequired){ + if(!request->authenticate(_username.c_str(), _password.c_str())){ + return request->requestAuthentication(); + } + } request->send(200, "application/json", "{\"msg\":\"The content you are looking for was not found\"}"); }); @@ -86,25 +92,36 @@ class MainWebServerClass{ }); #ifdef RELAY1 - _server->on("/state/relay1", HTTP_GET, [] (AsyncWebServerRequest *request) { - if(!request->authenticate(http_username, http_password)) - return request->requestAuthentication(); + _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 - _server->on("/settings/get/DoorDisabled", HTTP_GET, [] (AsyncWebServerRequest *request) { + _server->on("/settings/get/DoorDisabled", 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.DoorDisabled())+"\"}"); request->send(response); }); - _server->on("/settings/set/DoorDisabled", HTTP_GET, [] (AsyncWebServerRequest *request) { + _server->on("/settings/set/DoorDisabled", HTTP_GET, [&] (AsyncWebServerRequest *request) { String value; - if(!request->authenticate(http_username, http_password)) - return request->requestAuthentication(); - + 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") { -- 2.30.2