Routing was implemented

This commit is contained in:
2024-05-29 15:21:30 +02:00
parent 4dd36db312
commit 3851702254

View File

@@ -6,6 +6,7 @@ namespace App {
constexpr auto DefaultPort = 8888; constexpr auto DefaultPort = 8888;
constexpr auto DefaultHost = "0.0.0.0"; constexpr auto DefaultHost = "0.0.0.0";
constexpr auto ContentType = "application/json";
static httplib::Server *srv = nullptr; static httplib::Server *srv = nullptr;
@@ -28,15 +29,57 @@ int main(int argc, char *argv[])
App::srv = new httplib::Server(); App::srv = new httplib::Server();
App::srv->Get("/", [](const httplib::Request &, httplib::Response &res) { const std::map< std::string, noolitelib::Command > commands = {
{ "off", noolitelib::Off },
{ "decraseBrightnes", noolitelib::DecraseBrightnes },
{ "on", noolitelib::DecraseBrightnes },
{ "incraseBrightnes", noolitelib::IncreaseBrightnes },
{ "switch", noolitelib::Switch },
{ "invertBrightnes", noolitelib::InvertBrightnes },
{ "set", noolitelib::Set },
{ "callScenario", noolitelib::CallScenario },
{ "saveScenario", noolitelib::SaveScenario },
{ "unbind", noolitelib::Unbind },
{ "stopColorSelection", noolitelib::StopColorSelection },
{ "bind", noolitelib::Bind },
{ "colorSelection", noolitelib::ColorSelection },
{ "colorSwitch", noolitelib::ColorSwitch },
{ "modeSwitch", noolitelib::ModeSwitch },
{ "effectSpeed", noolitelib::EffectSpeed }
};
App::srv->Get("/noolite/:command/:channel", [&commands](const httplib::Request &req, httplib::Response &res) {
auto formatResult = [](bool successful, const std::string &text) -> std::string {
std::stringstream res;
res << "{\"" << (successful ? "result" : "error")
<< "\":\"" << (successful ? "ok" : text) << "\"";
if (successful) {
res << (",\"command\":\"" + text + "\"");
}
res << "}";
return res.str();
};
auto command = req.path_params.at("command");
if (!commands.count(command)) {
res.set_content(formatResult(false, "Command not found"), App::ContentType);
return;
}
auto channel = req.path_params.at("channel");
noolitelib::Noolite adapter; noolitelib::Noolite adapter;
if (adapter.sendCommand(0, noolitelib::Switch)) { if (adapter.sendCommand(0, noolitelib::Switch)) {
res.set_content("{\"Result\":\"Successful\"}", "application/json"); res.set_content(formatResult(true, command + " " + channel), App::ContentType);
} else { } else {
res.set_content("{\"Result\":\"Failed\"}", "application/json"); res.set_content(formatResult(false, "Device error"), App::ContentType);
} }
}); });
App::srv->set_mount_point("/var/www/static", "/static");
auto host = App::DefaultHost; auto host = App::DefaultHost;
auto port = App::DefaultPort; auto port = App::DefaultPort;
@@ -47,6 +90,8 @@ int main(int argc, char *argv[])
port = atoi(argv[2]); port = atoi(argv[2]);
} }
std::cout << "Listen on " << host << ":" << port << std::endl;
App::srv->listen(host, port); App::srv->listen(host, port);
return 0; return 0;