From a99c025826d5da67cffe2c08459739f543154331 Mon Sep 17 00:00:00 2001 From: grillo Date: Fri, 15 Apr 2022 16:00:08 -0300 Subject: [PATCH] server: refactor the code to use the RoutineService Template from the fkd --- src/server.cpp | 96 ++++++++++++++++++++++++++++++++++++-------------- 1 file changed, 70 insertions(+), 26 deletions(-) diff --git a/src/server.cpp b/src/server.cpp index b103bcc..ab81f7b 100644 --- a/src/server.cpp +++ b/src/server.cpp @@ -1,11 +1,76 @@ #include "message-buffer.hpp" #include "utils.hpp" #include +#include #include #include #include #include +class ServerdService : public RoutineService { + const char* m_host; + int m_port; + + httplib::Server m_svr; + MessagesBuffer m_buffer; + +public: + explicit ServerdService(const char* host, const int port) + : RoutineService { "serverd" } + , m_host { host } + , m_port { port } + , m_buffer { 10 } + { + } + + const DBusHandler::Path m_requestPath { + "zfkd.dbus.serverd", + "/zfkd/dbus/serverd", + "zfkd.dbus.serverd", + "request" + }; + + void setup() override + { + + m_svr.Post("/", [&](const httplib::Request& req, httplib::Response& res) { + nlohmann::json receivedJson; + receivedJson = nlohmann::json::parse(req.body); + + int id = receivedJson["equipe"]; + nlohmann::json payload = receivedJson["payload"]; + + m_buffer.write(id, payload); + utils::saveJson(receivedJson, std::to_string(id)); + + res.set_content("received message", "text/plain"); + }); + + m_svr.set_error_handler([](const httplib::Request&, httplib::Response& res) { + std::string error = "Error:" + std::to_string(res.status); + res.set_content(error, "text/plain"); + }); + + m_svr.set_exception_handler([](const httplib::Request& req, httplib::Response& res, std::exception& e) { + std::cout << e.what() << std::endl; + res.set_content("exception raised", "text/plain"); + }); + + DBusHandler::registerMethod(m_requestPath, [&](nlohmann::json req) { + return m_buffer.getCurrMessage(); + }); + } + + void routine() override + { + m_svr.listen(m_host, m_port); + } + + void destroy() override + { + } +}; + auto main(int argc, char* argv[]) -> int { const char* host; @@ -21,31 +86,10 @@ auto main(int argc, char* argv[]) -> int throw std::invalid_argument("invalid number of arguments"); } - httplib::Server svr; - MessagesBuffer buffer(10); - - svr.Post("/", [&buffer](const httplib::Request& req, httplib::Response& res) { - nlohmann::json receivedJson; - receivedJson = nlohmann::json::parse(req.body); - - int id = receivedJson["equipe"]; - nlohmann::json payload = receivedJson["payload"]; - - buffer.write(id, payload); - utils::saveJson(receivedJson, std::to_string(id)); - - res.set_content("received message", "text/plain"); - }); - - svr.set_error_handler([](const httplib::Request&, httplib::Response& res) { - std::string error = "Error:" + std::to_string(res.status); - res.set_content(error, "text/plain"); - }); - - svr.set_exception_handler([](const httplib::Request& req, httplib::Response& res, std::exception& e) { - std::cout << e.what() << std::endl; - res.set_content("exception raised", "text/plain"); - }); + Daemon serverd { "serverd.json" }; + ServerdService serverdService { host, port }; + serverd.deploy { serverdService }; + serverd.run(); - svr.listen(host, port); + return 0; }