#include ESP8266React::ESP8266React(AsyncWebServer* server, FS* fs) : _securitySettingsService(server, fs), _wifiSettingsService(server, fs, &_securitySettingsService), _apSettingsService(server, fs, &_securitySettingsService), _ntpSettingsService(server, fs, &_securitySettingsService), _otaSettingsService(server, fs, &_securitySettingsService), _restartService(server, &_securitySettingsService), _authenticationService(server, &_securitySettingsService), _wifiScanner(server, &_securitySettingsService), _wifiStatus(server, &_securitySettingsService), _ntpStatus(server, &_securitySettingsService), _apStatus(server, &_securitySettingsService), _systemStatus(server, &_securitySettingsService) { // Serve static resources from /www/ server->serveStatic("/js/", SPIFFS, "/www/js/"); server->serveStatic("/css/", SPIFFS, "/www/css/"); server->serveStatic("/fonts/", SPIFFS, "/www/fonts/"); server->serveStatic("/app/", SPIFFS, "/www/app/"); server->serveStatic("/favicon.ico", SPIFFS, "/www/favicon.ico"); // Serving all other get requests with "/www/index.htm" // OPTIONS get a straight up 200 response server->onNotFound([](AsyncWebServerRequest* request) { if (request->method() == HTTP_GET) { request->send(SPIFFS, "/www/index.html"); } else if (request->method() == HTTP_OPTIONS) { request->send(200); } else { request->send(404); } }); // Disable CORS if required #if defined(ENABLE_CORS) DefaultHeaders::Instance().addHeader("Access-Control-Allow-Origin", CORS_ORIGIN); DefaultHeaders::Instance().addHeader("Access-Control-Allow-Headers", "Accept, Content-Type, Authorization"); DefaultHeaders::Instance().addHeader("Access-Control-Allow-Credentials", "true"); #endif } void ESP8266React::begin() { _securitySettingsService.begin(); _wifiSettingsService.begin(); _apSettingsService.begin(); _ntpSettingsService.begin(); _otaSettingsService.begin(); } void ESP8266React::loop() { _wifiSettingsService.loop(); _apSettingsService.loop(); _ntpSettingsService.loop(); _otaSettingsService.loop(); }