Routing was implemented
This commit is contained in:
51
main.cpp
51
main.cpp
@@ -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;
|
||||||
|
|||||||
Reference in New Issue
Block a user