Browse Source

0.8.149

* fix redirect after login with newest webserver version
pull/1759/head
lumapu 4 months ago
parent
commit
eb8924a6d8
  1. 1
      src/CHANGES.md
  2. 2
      src/platformio.ini
  3. 32
      src/web/web.h

1
src/CHANGES.md

@ -3,6 +3,7 @@
## 0.8.149 - 2024-10-01 ## 0.8.149 - 2024-10-01
* fixed send power limit #1757 * fixed send power limit #1757
* merged: Fix minor typos #1758 * merged: Fix minor typos #1758
* fix redirect after login with newest webserver version
## 0.8.148 - 2024-09-30 ## 0.8.148 - 2024-09-30
* fixed send power limit #1757 * fixed send power limit #1757

2
src/platformio.ini

@ -154,7 +154,7 @@ platform = espressif32@6.7.0
board = lolin_d32 board = lolin_d32
lib_deps = lib_deps =
${env.lib_deps} ${env.lib_deps}
https://github.com/mathieucarbou/ESPAsyncWebServer#v3.2.4 https://github.com/mathieucarbou/ESPAsyncWebServer#v3.3.7
build_flags = ${env.build_flags} build_flags = ${env.build_flags}
-DSPI_HAL -DSPI_HAL
monitor_filters = monitor_filters =

32
src/web/web.h

@ -216,31 +216,36 @@ class Web {
} }
private: private:
inline void checkRedirect(AsyncWebServerRequest *request) { bool checkProtection(AsyncWebServerRequest *request) {
if ((mConfig->sys.protectionMask & PROT_MASK_INDEX) != PROT_MASK_INDEX) if(mApp->isProtected(request->client()->remoteIP().toString().c_str(), "", true)) {
if ((mConfig->sys.protectionMask & PROT_MASK_INDEX) != PROT_MASK_INDEX) {
request->redirect(F("/index")); request->redirect(F("/index"));
else if ((mConfig->sys.protectionMask & PROT_MASK_LIVE) != PROT_MASK_LIVE) return true;
} else if ((mConfig->sys.protectionMask & PROT_MASK_LIVE) != PROT_MASK_LIVE) {
request->redirect(F("/live")); request->redirect(F("/live"));
else if ((mConfig->sys.protectionMask & PROT_MASK_HISTORY) != PROT_MASK_HISTORY) return true;
} else if ((mConfig->sys.protectionMask & PROT_MASK_HISTORY) != PROT_MASK_HISTORY) {
request->redirect(F("/history")); request->redirect(F("/history"));
else if ((mConfig->sys.protectionMask & PROT_MASK_SERIAL) != PROT_MASK_SERIAL) return true;
} else if ((mConfig->sys.protectionMask & PROT_MASK_SERIAL) != PROT_MASK_SERIAL) {
request->redirect(F("/serial")); request->redirect(F("/serial"));
else if ((mConfig->sys.protectionMask & PROT_MASK_SYSTEM) != PROT_MASK_SYSTEM) return true;
} else if ((mConfig->sys.protectionMask & PROT_MASK_SYSTEM) != PROT_MASK_SYSTEM) {
request->redirect(F("/system")); request->redirect(F("/system"));
else return true;
} else {
request->redirect(F("/login")); request->redirect(F("/login"));
return true;
} }
void checkProtection(AsyncWebServerRequest *request) {
if(mApp->isProtected(request->client()->remoteIP().toString().c_str(), "", true)) {
checkRedirect(request);
return;
} }
return false;
} }
void getPage(AsyncWebServerRequest *request, uint16_t mask, const uint8_t *zippedHtml, uint32_t len) { void getPage(AsyncWebServerRequest *request, uint16_t mask, const uint8_t *zippedHtml, uint32_t len) {
if (CHECK_MASK(mConfig->sys.protectionMask, mask)) if (CHECK_MASK(mConfig->sys.protectionMask, mask))
checkProtection(request); if(checkProtection(request))
return;
AsyncWebServerResponse *response = beginResponse(request, 200, F("text/html; charset=UTF-8"), zippedHtml, len); AsyncWebServerResponse *response = beginResponse(request, 200, F("text/html; charset=UTF-8"), zippedHtml, len);
response->addHeader(F("Content-Encoding"), "gzip"); response->addHeader(F("Content-Encoding"), "gzip");
@ -337,6 +342,7 @@ class Web {
if (String(request->arg("pwd")) == String(mConfig->sys.adminPwd)) { if (String(request->arg("pwd")) == String(mConfig->sys.adminPwd)) {
mApp->unlock(request->client()->remoteIP().toString().c_str(), true); mApp->unlock(request->client()->remoteIP().toString().c_str(), true);
request->redirect("/index"); request->redirect("/index");
return;
} }
} }

Loading…
Cancel
Save