* Optimize Sun data calculation * Remove not required enum * Split config struct into different sub structs * Feature: Allow configuration of LWT QoS * Made resetreason methods static * Feature: Implement offset cache for "YieldDay" Thanks to @broth-itk for the idea! Fix: #1258 #1397 * Add Esp32-Stick-PoE-A * remove broken LilyGO_T_ETH_POE config, use device profile instead * Feature: High resolution Icon and PWA (Progressive Web App) functionality Fix: #1289 * webapp: Update dependencies * Initialize TaskScheduler * Migrate SunPosition to TaskScheduler * Migrate Datastore to TaskScheduler * Migrate MqttHandleInverterTotal to TaskSchedule * Migrate MqttHandleHass to TaskScheduler * Migrate MqttHandleDtu to TaskScheduler * Migrate MqttHandleInverter to TaskScheduler * Migrate LedSingle to TaskScheduler * Migrate NetworkSettings to TaskScheduler * Migrate InverterSettings to TaskScheduler * Migrate MessageOutput to TaskScheduler * Migrate Display_Graphic to TaskScheduler * Migrate WebApi to TaskScheduler * Split InverterSettings into multiple tasks * Calculate SunPosition only every 5 seconds * Split LedSingle into multiple tasks * Upgrade espMqttClient from 1.4.5 to 1.5.0 * Doc: Correct amount of MPP-Tracker * Added HMT-1600-4T and HMT-1800-4T to DevInfoParser Fix #1524 * Adjusted inverter names for HMS-1600/1800/2000-4T * Add channel count to description of detected inverter type (DevInfoParser) * Adjust device web api endpoint for dynamic led count * Feature: Added ability to change the brightness of the LEDs Based on the idea of @moritzlerch with several modifications like pwmTable and structure * webapp: Update dependencies * Update olikraus/U8g2 from 2.35.7 to 2.35.8 * Remove not required onWebsocketEvent * Remove code nesting * Introduce several const statements * Remove not required AsyncEventSource * Doc: Added byte specification to each command * Feature: Added basic Grid Profile parser which shows the used profile and version Other values are still outstanding. * Optimize AlarmLogParser to save memory * Add libfrozen to project to create constexpr maps * Feature: First version of GridProfile Parser which shows all values contained in the profile. * webapp: Update dependencies * Apply better variable names * Remove not required casts * Add additional compiler flags to prevent errors * Add const statement to several variables * Replace NULL by nullptr * Update bblanchon/ArduinoJson from 6.21.3 to 6.21.4 * Add const keyword to method parameters * Add const keyword to methods * Use references instead of pointers whenver possible * Adjust member variable names in MqttSettings * Adjust member variable names in NetworkSettings * webapp: Update timezone database to latest version * webapp: Beautify and unify form footers * Feature: Allow setting of an inverter limit of 0% and 0W Thanks to @madmartin in #1270 * Feature: Allow links in device profiles These links will be shown on the hardware settings page. * Doc: Added hint regarding HMS-xxxx-xT-NA inverters * Feature: Added DeviceProfile for CASmo-DTU Based on #1565 * Upgrade actions/upload-artifact from v3 to v4 * Upgrade actions/download-artifact from v3 to v4 * webapp: add app.js.gz * Gridprofileparser: Added latest known values Thanks to @stefan123t and @noone2k * webapp: Fix lint errors * Feature: Add DTU to Home Assistant Auto Discovery This is based on PR 1365 from @CFenner with several fixes and optimizations * Fix: Remove debug output as it floods the console * Fix: Gridprofileparser: Add additional error handling if profile is unknown * webapp: add app.js.gz * Fix: Offset cache for "YieldDay" did not work correctly * webapp: update dependencies * webapp: add app.js.gz * Fix: yarn.lock was outdated * Fix: yarn build error * Fix: Reset Yield day correction in combination with Zero Yield Day on Midnight lead to wrong values. * Fix: Allow negative values in GridProfileParser * Correct variable name * Fix #1579: Static IP in Ethernet mode did not work correctly * Feature: Added diagram to display This is based on the idea of @Henrik-Ingenieur and was discussed in #1504 * webapp: update dependencies * webapp: add app.js.gz --------- Co-authored-by: Thomas Basler <thomas@familie-basler.net> Co-authored-by: Pierre Kancir <pierre.kancir.emn@gmail.com>
120 lines
3.2 KiB
C++
120 lines
3.2 KiB
C++
// SPDX-License-Identifier: GPL-2.0-or-later
|
|
/*
|
|
* Copyright (C) 2022-2023 Thomas Basler and others
|
|
*/
|
|
#include "WebApi.h"
|
|
#include "Configuration.h"
|
|
#include "defaults.h"
|
|
#include <AsyncJson.h>
|
|
|
|
WebApiClass::WebApiClass()
|
|
: _server(HTTP_PORT)
|
|
{
|
|
}
|
|
|
|
void WebApiClass::init(Scheduler& scheduler)
|
|
{
|
|
_webApiConfig.init(_server);
|
|
_webApiDevice.init(_server);
|
|
_webApiDevInfo.init(_server);
|
|
_webApiDtu.init(_server);
|
|
_webApiEventlog.init(_server);
|
|
_webApiFirmware.init(_server);
|
|
_webApiGridprofile.init(_server);
|
|
_webApiInverter.init(_server);
|
|
_webApiLimit.init(_server);
|
|
_webApiMaintenance.init(_server);
|
|
_webApiMqtt.init(_server);
|
|
_webApiNetwork.init(_server);
|
|
_webApiNtp.init(_server);
|
|
_webApiPower.init(_server);
|
|
_webApiPrometheus.init(_server);
|
|
_webApiSecurity.init(_server);
|
|
_webApiSysstatus.init(_server);
|
|
_webApiWebapp.init(_server);
|
|
_webApiWsConsole.init(_server);
|
|
_webApiWsLive.init(_server);
|
|
_webApiBattery.init(_server);
|
|
_webApiPowerMeter.init(_server);
|
|
_webApiPowerLimiter.init(_server);
|
|
_webApiWsVedirectLive.init(_server);
|
|
_webApiVedirect.init(_server);
|
|
_webApiWsHuaweiLive.init(_server);
|
|
_webApiHuaweiClass.init(_server);
|
|
_webApiWsBatteryLive.init(_server);
|
|
|
|
_server.begin();
|
|
|
|
scheduler.addTask(_loopTask);
|
|
_loopTask.setCallback(std::bind(&WebApiClass::loop, this));
|
|
_loopTask.setIterations(TASK_FOREVER);
|
|
_loopTask.enable();
|
|
}
|
|
|
|
void WebApiClass::loop()
|
|
{
|
|
_webApiBattery.loop();
|
|
_webApiConfig.loop();
|
|
_webApiDevice.loop();
|
|
_webApiDevInfo.loop();
|
|
_webApiDtu.loop();
|
|
_webApiEventlog.loop();
|
|
_webApiFirmware.loop();
|
|
_webApiGridprofile.loop();
|
|
_webApiInverter.loop();
|
|
_webApiLimit.loop();
|
|
_webApiMaintenance.loop();
|
|
_webApiMqtt.loop();
|
|
_webApiNetwork.loop();
|
|
_webApiNtp.loop();
|
|
_webApiPower.loop();
|
|
_webApiPowerMeter.loop();
|
|
_webApiPowerLimiter.loop();
|
|
_webApiSecurity.loop();
|
|
_webApiSysstatus.loop();
|
|
_webApiWebapp.loop();
|
|
_webApiWsConsole.loop();
|
|
_webApiWsLive.loop();
|
|
_webApiWsVedirectLive.loop();
|
|
_webApiVedirect.loop();
|
|
_webApiWsHuaweiLive.loop();
|
|
_webApiHuaweiClass.loop();
|
|
_webApiWsBatteryLive.loop();
|
|
}
|
|
|
|
bool WebApiClass::checkCredentials(AsyncWebServerRequest* request)
|
|
{
|
|
CONFIG_T& config = Configuration.get();
|
|
if (request->authenticate(AUTH_USERNAME, config.Security.Password)) {
|
|
return true;
|
|
}
|
|
|
|
AsyncWebServerResponse* r = request->beginResponse(401);
|
|
|
|
// WebAPI should set the X-Requested-With to prevent browser internal auth dialogs
|
|
if (!request->hasHeader("X-Requested-With")) {
|
|
r->addHeader("WWW-Authenticate", "Basic realm=\"Login Required\"");
|
|
}
|
|
request->send(r);
|
|
|
|
return false;
|
|
}
|
|
|
|
bool WebApiClass::checkCredentialsReadonly(AsyncWebServerRequest* request)
|
|
{
|
|
CONFIG_T& config = Configuration.get();
|
|
if (config.Security.AllowReadonly) {
|
|
return true;
|
|
} else {
|
|
return checkCredentials(request);
|
|
}
|
|
}
|
|
|
|
void WebApiClass::sendTooManyRequests(AsyncWebServerRequest* request)
|
|
{
|
|
auto response = request->beginResponse(429, "text/plain", "Too Many Requests");
|
|
response->addHeader("Retry-After", "60");
|
|
request->send(response);
|
|
}
|
|
|
|
WebApiClass WebApi; |