OpenDTU-old/src/WebApi.cpp
2024-01-05 22:04:54 +01:00

132 lines
3.6 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);
}
void WebApiClass::writeConfig(JsonVariant& retMsg, const WebApiError code, const String& message)
{
if (!Configuration.write()) {
retMsg["message"] = "Write failed!";
retMsg["code"] = WebApiError::GenericWriteFailed;
} else {
retMsg["type"] = "success";
retMsg["message"] = message;
retMsg["code"] = code;
}
}
WebApiClass WebApi;