diff options
| author | Per Larsson <[email protected]> | 2021-09-28 15:09:15 +0200 |
|---|---|---|
| committer | Per Larsson <[email protected]> | 2021-09-28 15:09:15 +0200 |
| commit | 141317786f9d59e95da8316ce40cf30e4dfd7b53 (patch) | |
| tree | 3c863384c6ca68a30e82989994408c5f40159273 /zenserver/admin | |
| parent | Removed using the bucket name to detect binary cache records and store conten... (diff) | |
| parent | apply: Re-enabled environment variable setup for child processes (diff) | |
| download | zen-141317786f9d59e95da8316ce40cf30e4dfd7b53.tar.xz zen-141317786f9d59e95da8316ce40cf30e4dfd7b53.zip | |
Merge branch 'main' of https://github.com/EpicGames/zen
Diffstat (limited to 'zenserver/admin')
| -rw-r--r-- | zenserver/admin/admin.cpp | 44 | ||||
| -rw-r--r-- | zenserver/admin/admin.h | 10 |
2 files changed, 49 insertions, 5 deletions
diff --git a/zenserver/admin/admin.cpp b/zenserver/admin/admin.cpp new file mode 100644 index 000000000..07211cbeb --- /dev/null +++ b/zenserver/admin/admin.cpp @@ -0,0 +1,44 @@ +// Copyright Epic Games, Inc. All Rights Reserved. + +#pragma once + +#include "admin.h" + +#include <zencore/compactbinarybuilder.h> + +namespace zen { + +HttpAdminService::HttpAdminService() +{ + m_Router.RegisterRoute( + "hello", + [this](HttpRouterRequest& Req) { Req.ServerRequest().WriteResponse(HttpResponseCode::OK); }, + HttpVerb::kGet); + + m_Router.RegisterRoute( + "health", + [this](HttpRouterRequest& Req) { + CbObjectWriter Obj; + Obj.AddBool("ok", true); + Req.ServerRequest().WriteResponse(HttpResponseCode::OK, Obj.Save()); + }, + HttpVerb::kGet); +} + +HttpAdminService::~HttpAdminService() +{ +} + +const char* +HttpAdminService::BaseUri() const +{ + return "/admin/"; +} + +void +HttpAdminService::HandleRequest(zen::HttpServerRequest& Request) +{ + m_Router.HandleRequest(Request); +} + +} // namespace zen diff --git a/zenserver/admin/admin.h b/zenserver/admin/admin.h index 3554b1005..6257f0998 100644 --- a/zenserver/admin/admin.h +++ b/zenserver/admin/admin.h @@ -9,14 +9,14 @@ namespace zen { class HttpAdminService : public zen::HttpService { public: - HttpAdminService() = default; - ~HttpAdminService() = default; + HttpAdminService(); + ~HttpAdminService(); - virtual const char* BaseUri() const override { return "/admin/"; } - - virtual void HandleRequest(zen::HttpServerRequest& Request) override { ZEN_UNUSED(Request); } + virtual const char* BaseUri() const override; + virtual void HandleRequest(zen::HttpServerRequest& Request) override; private: + HttpRequestRouter m_Router; }; } // namespace zen |