#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