🪄 Formats HttpEndpoint
This commit is contained in:
@@ -12,7 +12,7 @@
|
||||
|
||||
template <class T>
|
||||
class HttpEndpoint {
|
||||
protected:
|
||||
protected:
|
||||
JsonStateReader<T> _stateReader;
|
||||
JsonStateUpdater<T> _stateUpdater;
|
||||
StatefulService<T> *_statefulService;
|
||||
@@ -22,13 +22,10 @@ class HttpEndpoint {
|
||||
PsychicHttpServer *_server;
|
||||
const char *_servicePath;
|
||||
|
||||
public:
|
||||
HttpEndpoint(JsonStateReader<T> stateReader,
|
||||
JsonStateUpdater<T> stateUpdater,
|
||||
StatefulService<T> *statefulService, PsychicHttpServer *server,
|
||||
const char *servicePath, SecurityManager *securityManager,
|
||||
AuthenticationPredicate authenticationPredicate =
|
||||
AuthenticationPredicates::IS_ADMIN)
|
||||
public:
|
||||
HttpEndpoint(JsonStateReader<T> stateReader, JsonStateUpdater<T> stateUpdater, StatefulService<T> *statefulService,
|
||||
PsychicHttpServer *server, const char *servicePath, SecurityManager *securityManager,
|
||||
AuthenticationPredicate authenticationPredicate = AuthenticationPredicates::IS_ADMIN)
|
||||
: _stateReader(stateReader),
|
||||
_stateUpdater(stateUpdater),
|
||||
_statefulService(statefulService),
|
||||
@@ -41,19 +38,16 @@ class HttpEndpoint {
|
||||
void begin() {
|
||||
// OPTIONS (for CORS preflight)
|
||||
#ifdef ENABLE_CORS
|
||||
_server->on(
|
||||
_servicePath, HTTP_OPTIONS,
|
||||
_securityManager->wrapRequest(
|
||||
[this](PsychicRequest *request) { return request->reply(200); },
|
||||
AuthenticationPredicates::IS_AUTHENTICATED));
|
||||
_server->on(_servicePath, HTTP_OPTIONS,
|
||||
_securityManager->wrapRequest([this](PsychicRequest *request) { return request->reply(200); },
|
||||
AuthenticationPredicates::IS_AUTHENTICATED));
|
||||
#endif
|
||||
|
||||
// GET
|
||||
_server->on(_servicePath, HTTP_GET,
|
||||
_securityManager->wrapRequest(
|
||||
[this](PsychicRequest *request) {
|
||||
PsychicJsonResponse response =
|
||||
PsychicJsonResponse(request, false);
|
||||
PsychicJsonResponse response = PsychicJsonResponse(request, false);
|
||||
JsonObject jsonObject = response.getRoot();
|
||||
_statefulService->read(jsonObject, _stateReader);
|
||||
return response.send();
|
||||
@@ -62,36 +56,32 @@ class HttpEndpoint {
|
||||
ESP_LOGV("HttpEndpoint", "Registered GET endpoint: %s", _servicePath);
|
||||
|
||||
// POST
|
||||
_server->on(
|
||||
_servicePath, HTTP_POST,
|
||||
_securityManager->wrapCallback(
|
||||
[this](PsychicRequest *request, JsonVariant &json) {
|
||||
if (!json.is<JsonObject>()) {
|
||||
return request->reply(400);
|
||||
}
|
||||
_server->on(_servicePath, HTTP_POST,
|
||||
_securityManager->wrapCallback(
|
||||
[this](PsychicRequest *request, JsonVariant &json) {
|
||||
if (!json.is<JsonObject>()) {
|
||||
return request->reply(400);
|
||||
}
|
||||
|
||||
JsonObject jsonObject = json.as<JsonObject>();
|
||||
StateUpdateResult outcome =
|
||||
_statefulService->updateWithoutPropagation(
|
||||
jsonObject, _stateUpdater);
|
||||
JsonObject jsonObject = json.as<JsonObject>();
|
||||
StateUpdateResult outcome =
|
||||
_statefulService->updateWithoutPropagation(jsonObject, _stateUpdater);
|
||||
|
||||
if (outcome == StateUpdateResult::ERROR) {
|
||||
return request->reply(400);
|
||||
} else if ((outcome == StateUpdateResult::CHANGED)) {
|
||||
// persist the changes to the FS
|
||||
_statefulService->callUpdateHandlers(
|
||||
HTTP_ENDPOINT_ORIGIN_ID);
|
||||
}
|
||||
if (outcome == StateUpdateResult::ERROR) {
|
||||
return request->reply(400);
|
||||
} else if ((outcome == StateUpdateResult::CHANGED)) {
|
||||
// persist the changes to the FS
|
||||
_statefulService->callUpdateHandlers(HTTP_ENDPOINT_ORIGIN_ID);
|
||||
}
|
||||
|
||||
PsychicJsonResponse response =
|
||||
PsychicJsonResponse(request, false);
|
||||
jsonObject = response.getRoot();
|
||||
PsychicJsonResponse response = PsychicJsonResponse(request, false);
|
||||
jsonObject = response.getRoot();
|
||||
|
||||
_statefulService->read(jsonObject, _stateReader);
|
||||
_statefulService->read(jsonObject, _stateReader);
|
||||
|
||||
return response.send();
|
||||
},
|
||||
_authenticationPredicate));
|
||||
return response.send();
|
||||
},
|
||||
_authenticationPredicate));
|
||||
|
||||
ESP_LOGV("HttpEndpoint", "Registered POST endpoint: %s", _servicePath);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user