mirror of https://github.com/Icinga/icinga2.git
Adjust all HTTP handlers (ex. /v1/events)
This commit is contained in:
parent
9ae1d732af
commit
1941c1da28
|
@ -12,15 +12,23 @@ using namespace icinga;
|
||||||
|
|
||||||
REGISTER_URLHANDLER("/v1/actions", ActionsHandler);
|
REGISTER_URLHANDLER("/v1/actions", ActionsHandler);
|
||||||
|
|
||||||
bool ActionsHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest& request, HttpResponse& response, const Dictionary::Ptr& params)
|
bool ActionsHandler::HandleRequest(
|
||||||
|
const ApiUser::Ptr& user,
|
||||||
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
const Url::Ptr& url,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
|
const Dictionary::Ptr& params
|
||||||
|
)
|
||||||
{
|
{
|
||||||
if (request.RequestUrl->GetPath().size() != 3)
|
namespace http = boost::beast::http;
|
||||||
|
|
||||||
|
if (url->GetPath().size() != 3)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
if (request.RequestMethod != "POST")
|
if (request.method() != http::verb::post)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
String actionName = request.RequestUrl->GetPath()[2];
|
String actionName = url->GetPath()[2];
|
||||||
|
|
||||||
ApiAction::Ptr action = ApiAction::GetByName(actionName);
|
ApiAction::Ptr action = ApiAction::GetByName(actionName);
|
||||||
|
|
||||||
|
@ -81,17 +89,15 @@ bool ActionsHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest& reques
|
||||||
}
|
}
|
||||||
|
|
||||||
int statusCode = 500;
|
int statusCode = 500;
|
||||||
String statusMessage = "No action executed successfully";
|
|
||||||
|
|
||||||
for (const Dictionary::Ptr& res : results) {
|
for (const Dictionary::Ptr& res : results) {
|
||||||
if (res->Contains("code") && res->Get("code") == 200) {
|
if (res->Contains("code") && res->Get("code") == 200) {
|
||||||
statusCode = 200;
|
statusCode = 200;
|
||||||
statusMessage = "OK";
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
response.SetStatus(statusCode, statusMessage);
|
response.result(statusCode);
|
||||||
|
|
||||||
Dictionary::Ptr result = new Dictionary({
|
Dictionary::Ptr result = new Dictionary({
|
||||||
{ "results", new Array(std::move(results)) }
|
{ "results", new Array(std::move(results)) }
|
||||||
|
|
|
@ -13,8 +13,13 @@ class ActionsHandler final : public HttpHandler
|
||||||
public:
|
public:
|
||||||
DECLARE_PTR_TYPEDEFS(ActionsHandler);
|
DECLARE_PTR_TYPEDEFS(ActionsHandler);
|
||||||
|
|
||||||
bool HandleRequest(const ApiUser::Ptr& user, HttpRequest& request,
|
bool HandleRequest(
|
||||||
HttpResponse& response, const Dictionary::Ptr& params) override;
|
const ApiUser::Ptr& user,
|
||||||
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
const Url::Ptr& url,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
|
const Dictionary::Ptr& params
|
||||||
|
) override;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -12,12 +12,20 @@ using namespace icinga;
|
||||||
|
|
||||||
REGISTER_URLHANDLER("/v1/config/files", ConfigFilesHandler);
|
REGISTER_URLHANDLER("/v1/config/files", ConfigFilesHandler);
|
||||||
|
|
||||||
bool ConfigFilesHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest& request, HttpResponse& response, const Dictionary::Ptr& params)
|
bool ConfigFilesHandler::HandleRequest(
|
||||||
|
const ApiUser::Ptr& user,
|
||||||
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
const Url::Ptr& url,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
|
const Dictionary::Ptr& params
|
||||||
|
)
|
||||||
{
|
{
|
||||||
if (request.RequestMethod != "GET")
|
namespace http = boost::beast::http;
|
||||||
|
|
||||||
|
if (request.method() != http::verb::get)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
const std::vector<String>& urlPath = request.RequestUrl->GetPath();
|
const std::vector<String>& urlPath = url->GetPath();
|
||||||
|
|
||||||
if (urlPath.size() >= 4)
|
if (urlPath.size() >= 4)
|
||||||
params->Set("package", urlPath[3]);
|
params->Set("package", urlPath[3]);
|
||||||
|
@ -30,7 +38,7 @@ bool ConfigFilesHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest& re
|
||||||
params->Set("path", boost::algorithm::join(tmpPath, "/"));
|
params->Set("path", boost::algorithm::join(tmpPath, "/"));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (request.Headers->Get("accept") == "application/json") {
|
if (request[http::field::accept] == "application/json") {
|
||||||
HttpUtility::SendJsonError(response, params, 400, "Invalid Accept header. Either remove the Accept header or set it to 'application/octet-stream'.");
|
HttpUtility::SendJsonError(response, params, 400, "Invalid Accept header. Either remove the Accept header or set it to 'application/octet-stream'.");
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -69,9 +77,10 @@ bool ConfigFilesHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest& re
|
||||||
fp.exceptions(std::ifstream::badbit);
|
fp.exceptions(std::ifstream::badbit);
|
||||||
|
|
||||||
String content((std::istreambuf_iterator<char>(fp)), std::istreambuf_iterator<char>());
|
String content((std::istreambuf_iterator<char>(fp)), std::istreambuf_iterator<char>());
|
||||||
response.SetStatus(200, "OK");
|
response.result(http::status::ok);
|
||||||
response.AddHeader("Content-Type", "application/octet-stream");
|
response.set(http::field::content_type, "application/octet-stream");
|
||||||
response.WriteBody(content.CStr(), content.GetLength());
|
response.body() = content;
|
||||||
|
response.set(http::field::content_length, response.body().size());
|
||||||
} catch (const std::exception& ex) {
|
} catch (const std::exception& ex) {
|
||||||
HttpUtility::SendJsonError(response, params, 500, "Could not read file.",
|
HttpUtility::SendJsonError(response, params, 500, "Could not read file.",
|
||||||
DiagnosticInformation(ex));
|
DiagnosticInformation(ex));
|
||||||
|
|
|
@ -13,8 +13,13 @@ class ConfigFilesHandler final : public HttpHandler
|
||||||
public:
|
public:
|
||||||
DECLARE_PTR_TYPEDEFS(ConfigFilesHandler);
|
DECLARE_PTR_TYPEDEFS(ConfigFilesHandler);
|
||||||
|
|
||||||
bool HandleRequest(const ApiUser::Ptr& user, HttpRequest& request,
|
bool HandleRequest(
|
||||||
HttpResponse& response, const Dictionary::Ptr& params) override;
|
const ApiUser::Ptr& user,
|
||||||
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
const Url::Ptr& url,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
|
const Dictionary::Ptr& params
|
||||||
|
) override;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,25 +10,41 @@ using namespace icinga;
|
||||||
|
|
||||||
REGISTER_URLHANDLER("/v1/config/packages", ConfigPackagesHandler);
|
REGISTER_URLHANDLER("/v1/config/packages", ConfigPackagesHandler);
|
||||||
|
|
||||||
bool ConfigPackagesHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest& request, HttpResponse& response, const Dictionary::Ptr& params)
|
bool ConfigPackagesHandler::HandleRequest(
|
||||||
|
const ApiUser::Ptr& user,
|
||||||
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
const Url::Ptr& url,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
|
const Dictionary::Ptr& params
|
||||||
|
)
|
||||||
{
|
{
|
||||||
if (request.RequestUrl->GetPath().size() > 4)
|
namespace http = boost::beast::http;
|
||||||
|
|
||||||
|
if (url->GetPath().size() > 4)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
if (request.RequestMethod == "GET")
|
if (request.method() == http::verb::get)
|
||||||
HandleGet(user, request, response, params);
|
HandleGet(user, request, url, response, params);
|
||||||
else if (request.RequestMethod == "POST")
|
else if (request.method() == http::verb::post)
|
||||||
HandlePost(user, request, response, params);
|
HandlePost(user, request, url, response, params);
|
||||||
else if (request.RequestMethod == "DELETE")
|
else if (request.method() == http::verb::delete_)
|
||||||
HandleDelete(user, request, response, params);
|
HandleDelete(user, request, url, response, params);
|
||||||
else
|
else
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void ConfigPackagesHandler::HandleGet(const ApiUser::Ptr& user, HttpRequest& request, HttpResponse& response, const Dictionary::Ptr& params)
|
void ConfigPackagesHandler::HandleGet(
|
||||||
|
const ApiUser::Ptr& user,
|
||||||
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
const Url::Ptr& url,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
|
const Dictionary::Ptr& params
|
||||||
|
)
|
||||||
{
|
{
|
||||||
|
namespace http = boost::beast::http;
|
||||||
|
|
||||||
FilterUtility::CheckPermission(user, "config/query");
|
FilterUtility::CheckPermission(user, "config/query");
|
||||||
|
|
||||||
std::vector<String> packages;
|
std::vector<String> packages;
|
||||||
|
@ -58,16 +74,24 @@ void ConfigPackagesHandler::HandleGet(const ApiUser::Ptr& user, HttpRequest& req
|
||||||
{ "results", new Array(std::move(results)) }
|
{ "results", new Array(std::move(results)) }
|
||||||
});
|
});
|
||||||
|
|
||||||
response.SetStatus(200, "OK");
|
response.result(http::status::ok);
|
||||||
HttpUtility::SendJsonBody(response, params, result);
|
HttpUtility::SendJsonBody(response, params, result);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ConfigPackagesHandler::HandlePost(const ApiUser::Ptr& user, HttpRequest& request, HttpResponse& response, const Dictionary::Ptr& params)
|
void ConfigPackagesHandler::HandlePost(
|
||||||
|
const ApiUser::Ptr& user,
|
||||||
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
const Url::Ptr& url,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
|
const Dictionary::Ptr& params
|
||||||
|
)
|
||||||
{
|
{
|
||||||
|
namespace http = boost::beast::http;
|
||||||
|
|
||||||
FilterUtility::CheckPermission(user, "config/modify");
|
FilterUtility::CheckPermission(user, "config/modify");
|
||||||
|
|
||||||
if (request.RequestUrl->GetPath().size() >= 4)
|
if (url->GetPath().size() >= 4)
|
||||||
params->Set("package", request.RequestUrl->GetPath()[3]);
|
params->Set("package", url->GetPath()[3]);
|
||||||
|
|
||||||
String packageName = HttpUtility::GetLastParameter(params, "package");
|
String packageName = HttpUtility::GetLastParameter(params, "package");
|
||||||
|
|
||||||
|
@ -95,16 +119,24 @@ void ConfigPackagesHandler::HandlePost(const ApiUser::Ptr& user, HttpRequest& re
|
||||||
{ "results", new Array({ result1 }) }
|
{ "results", new Array({ result1 }) }
|
||||||
});
|
});
|
||||||
|
|
||||||
response.SetStatus(200, "OK");
|
response.result(http::status::ok);
|
||||||
HttpUtility::SendJsonBody(response, params, result);
|
HttpUtility::SendJsonBody(response, params, result);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ConfigPackagesHandler::HandleDelete(const ApiUser::Ptr& user, HttpRequest& request, HttpResponse& response, const Dictionary::Ptr& params)
|
void ConfigPackagesHandler::HandleDelete(
|
||||||
|
const ApiUser::Ptr& user,
|
||||||
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
const Url::Ptr& url,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
|
const Dictionary::Ptr& params
|
||||||
|
)
|
||||||
{
|
{
|
||||||
|
namespace http = boost::beast::http;
|
||||||
|
|
||||||
FilterUtility::CheckPermission(user, "config/modify");
|
FilterUtility::CheckPermission(user, "config/modify");
|
||||||
|
|
||||||
if (request.RequestUrl->GetPath().size() >= 4)
|
if (url->GetPath().size() >= 4)
|
||||||
params->Set("package", request.RequestUrl->GetPath()[3]);
|
params->Set("package", url->GetPath()[3]);
|
||||||
|
|
||||||
String packageName = HttpUtility::GetLastParameter(params, "package");
|
String packageName = HttpUtility::GetLastParameter(params, "package");
|
||||||
|
|
||||||
|
@ -131,6 +163,6 @@ void ConfigPackagesHandler::HandleDelete(const ApiUser::Ptr& user, HttpRequest&
|
||||||
{ "results", new Array({ result1 }) }
|
{ "results", new Array({ result1 }) }
|
||||||
});
|
});
|
||||||
|
|
||||||
response.SetStatus(200, "OK");
|
response.result(http::status::ok);
|
||||||
HttpUtility::SendJsonBody(response, params, result);
|
HttpUtility::SendJsonBody(response, params, result);
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,16 +13,36 @@ class ConfigPackagesHandler final : public HttpHandler
|
||||||
public:
|
public:
|
||||||
DECLARE_PTR_TYPEDEFS(ConfigPackagesHandler);
|
DECLARE_PTR_TYPEDEFS(ConfigPackagesHandler);
|
||||||
|
|
||||||
bool HandleRequest(const ApiUser::Ptr& user, HttpRequest& request,
|
bool HandleRequest(
|
||||||
HttpResponse& response, const Dictionary::Ptr& params) override;
|
const ApiUser::Ptr& user,
|
||||||
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
const Url::Ptr& url,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
|
const Dictionary::Ptr& params
|
||||||
|
) override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void HandleGet(const ApiUser::Ptr& user, HttpRequest& request,
|
void HandleGet(
|
||||||
HttpResponse& response, const Dictionary::Ptr& params);
|
const ApiUser::Ptr& user,
|
||||||
void HandlePost(const ApiUser::Ptr& user, HttpRequest& request,
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
HttpResponse& response, const Dictionary::Ptr& params);
|
const Url::Ptr& url,
|
||||||
void HandleDelete(const ApiUser::Ptr& user, HttpRequest& request,
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
HttpResponse& response, const Dictionary::Ptr& params);
|
const Dictionary::Ptr& params
|
||||||
|
);
|
||||||
|
void HandlePost(
|
||||||
|
const ApiUser::Ptr& user,
|
||||||
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
const Url::Ptr& url,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
|
const Dictionary::Ptr& params
|
||||||
|
);
|
||||||
|
void HandleDelete(
|
||||||
|
const ApiUser::Ptr& user,
|
||||||
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
const Url::Ptr& url,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
|
const Dictionary::Ptr& params
|
||||||
|
);
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -11,32 +11,48 @@ using namespace icinga;
|
||||||
|
|
||||||
REGISTER_URLHANDLER("/v1/config/stages", ConfigStagesHandler);
|
REGISTER_URLHANDLER("/v1/config/stages", ConfigStagesHandler);
|
||||||
|
|
||||||
bool ConfigStagesHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest& request, HttpResponse& response, const Dictionary::Ptr& params)
|
bool ConfigStagesHandler::HandleRequest(
|
||||||
|
const ApiUser::Ptr& user,
|
||||||
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
const Url::Ptr& url,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
|
const Dictionary::Ptr& params
|
||||||
|
)
|
||||||
{
|
{
|
||||||
if (request.RequestUrl->GetPath().size() > 5)
|
namespace http = boost::beast::http;
|
||||||
|
|
||||||
|
if (url->GetPath().size() > 5)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
if (request.RequestMethod == "GET")
|
if (request.method() == http::verb::get)
|
||||||
HandleGet(user, request, response, params);
|
HandleGet(user, request, url, response, params);
|
||||||
else if (request.RequestMethod == "POST")
|
else if (request.method() == http::verb::post)
|
||||||
HandlePost(user, request, response, params);
|
HandlePost(user, request, url, response, params);
|
||||||
else if (request.RequestMethod == "DELETE")
|
else if (request.method() == http::verb::delete_)
|
||||||
HandleDelete(user, request, response, params);
|
HandleDelete(user, request, url, response, params);
|
||||||
else
|
else
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void ConfigStagesHandler::HandleGet(const ApiUser::Ptr& user, HttpRequest& request, HttpResponse& response, const Dictionary::Ptr& params)
|
void ConfigStagesHandler::HandleGet(
|
||||||
|
const ApiUser::Ptr& user,
|
||||||
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
const Url::Ptr& url,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
|
const Dictionary::Ptr& params
|
||||||
|
)
|
||||||
{
|
{
|
||||||
|
namespace http = boost::beast::http;
|
||||||
|
|
||||||
FilterUtility::CheckPermission(user, "config/query");
|
FilterUtility::CheckPermission(user, "config/query");
|
||||||
|
|
||||||
if (request.RequestUrl->GetPath().size() >= 4)
|
if (url->GetPath().size() >= 4)
|
||||||
params->Set("package", request.RequestUrl->GetPath()[3]);
|
params->Set("package", url->GetPath()[3]);
|
||||||
|
|
||||||
if (request.RequestUrl->GetPath().size() >= 5)
|
if (url->GetPath().size() >= 5)
|
||||||
params->Set("stage", request.RequestUrl->GetPath()[4]);
|
params->Set("stage", url->GetPath()[4]);
|
||||||
|
|
||||||
String packageName = HttpUtility::GetLastParameter(params, "package");
|
String packageName = HttpUtility::GetLastParameter(params, "package");
|
||||||
String stageName = HttpUtility::GetLastParameter(params, "stage");
|
String stageName = HttpUtility::GetLastParameter(params, "stage");
|
||||||
|
@ -64,16 +80,24 @@ void ConfigStagesHandler::HandleGet(const ApiUser::Ptr& user, HttpRequest& reque
|
||||||
{ "results", new Array(std::move(results)) }
|
{ "results", new Array(std::move(results)) }
|
||||||
});
|
});
|
||||||
|
|
||||||
response.SetStatus(200, "OK");
|
response.result(http::status::ok);
|
||||||
HttpUtility::SendJsonBody(response, params, result);
|
HttpUtility::SendJsonBody(response, params, result);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ConfigStagesHandler::HandlePost(const ApiUser::Ptr& user, HttpRequest& request, HttpResponse& response, const Dictionary::Ptr& params)
|
void ConfigStagesHandler::HandlePost(
|
||||||
|
const ApiUser::Ptr& user,
|
||||||
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
const Url::Ptr& url,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
|
const Dictionary::Ptr& params
|
||||||
|
)
|
||||||
{
|
{
|
||||||
|
namespace http = boost::beast::http;
|
||||||
|
|
||||||
FilterUtility::CheckPermission(user, "config/modify");
|
FilterUtility::CheckPermission(user, "config/modify");
|
||||||
|
|
||||||
if (request.RequestUrl->GetPath().size() >= 4)
|
if (url->GetPath().size() >= 4)
|
||||||
params->Set("package", request.RequestUrl->GetPath()[3]);
|
params->Set("package", url->GetPath()[3]);
|
||||||
|
|
||||||
String packageName = HttpUtility::GetLastParameter(params, "package");
|
String packageName = HttpUtility::GetLastParameter(params, "package");
|
||||||
|
|
||||||
|
@ -123,19 +147,27 @@ void ConfigStagesHandler::HandlePost(const ApiUser::Ptr& user, HttpRequest& requ
|
||||||
{ "results", new Array({ result1 }) }
|
{ "results", new Array({ result1 }) }
|
||||||
});
|
});
|
||||||
|
|
||||||
response.SetStatus(200, "OK");
|
response.result(http::status::ok);
|
||||||
HttpUtility::SendJsonBody(response, params, result);
|
HttpUtility::SendJsonBody(response, params, result);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ConfigStagesHandler::HandleDelete(const ApiUser::Ptr& user, HttpRequest& request, HttpResponse& response, const Dictionary::Ptr& params)
|
void ConfigStagesHandler::HandleDelete(
|
||||||
|
const ApiUser::Ptr& user,
|
||||||
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
const Url::Ptr& url,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
|
const Dictionary::Ptr& params
|
||||||
|
)
|
||||||
{
|
{
|
||||||
|
namespace http = boost::beast::http;
|
||||||
|
|
||||||
FilterUtility::CheckPermission(user, "config/modify");
|
FilterUtility::CheckPermission(user, "config/modify");
|
||||||
|
|
||||||
if (request.RequestUrl->GetPath().size() >= 4)
|
if (url->GetPath().size() >= 4)
|
||||||
params->Set("package", request.RequestUrl->GetPath()[3]);
|
params->Set("package", url->GetPath()[3]);
|
||||||
|
|
||||||
if (request.RequestUrl->GetPath().size() >= 5)
|
if (url->GetPath().size() >= 5)
|
||||||
params->Set("stage", request.RequestUrl->GetPath()[4]);
|
params->Set("stage", url->GetPath()[4]);
|
||||||
|
|
||||||
String packageName = HttpUtility::GetLastParameter(params, "package");
|
String packageName = HttpUtility::GetLastParameter(params, "package");
|
||||||
String stageName = HttpUtility::GetLastParameter(params, "stage");
|
String stageName = HttpUtility::GetLastParameter(params, "stage");
|
||||||
|
@ -165,7 +197,7 @@ void ConfigStagesHandler::HandleDelete(const ApiUser::Ptr& user, HttpRequest& re
|
||||||
{ "results", new Array({ result1 }) }
|
{ "results", new Array({ result1 }) }
|
||||||
});
|
});
|
||||||
|
|
||||||
response.SetStatus(200, "OK");
|
response.result(http::status::ok);
|
||||||
HttpUtility::SendJsonBody(response, params, result);
|
HttpUtility::SendJsonBody(response, params, result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -13,16 +13,36 @@ class ConfigStagesHandler final : public HttpHandler
|
||||||
public:
|
public:
|
||||||
DECLARE_PTR_TYPEDEFS(ConfigStagesHandler);
|
DECLARE_PTR_TYPEDEFS(ConfigStagesHandler);
|
||||||
|
|
||||||
bool HandleRequest(const ApiUser::Ptr& user, HttpRequest& request,
|
bool HandleRequest(
|
||||||
HttpResponse& response, const Dictionary::Ptr& params) override;
|
const ApiUser::Ptr& user,
|
||||||
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
const Url::Ptr& url,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
|
const Dictionary::Ptr& params
|
||||||
|
) override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void HandleGet(const ApiUser::Ptr& user, HttpRequest& request,
|
void HandleGet(
|
||||||
HttpResponse& response, const Dictionary::Ptr& params);
|
const ApiUser::Ptr& user,
|
||||||
void HandlePost(const ApiUser::Ptr& user, HttpRequest& request,
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
HttpResponse& response, const Dictionary::Ptr& params);
|
const Url::Ptr& url,
|
||||||
void HandleDelete(const ApiUser::Ptr& user, HttpRequest& request,
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
HttpResponse& response, const Dictionary::Ptr& params);
|
const Dictionary::Ptr& params
|
||||||
|
);
|
||||||
|
void HandlePost(
|
||||||
|
const ApiUser::Ptr& user,
|
||||||
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
const Url::Ptr& url,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
|
const Dictionary::Ptr& params
|
||||||
|
);
|
||||||
|
void HandleDelete(
|
||||||
|
const ApiUser::Ptr& user,
|
||||||
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
const Url::Ptr& url,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
|
const Dictionary::Ptr& params
|
||||||
|
);
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -53,17 +53,25 @@ static void EnsureFrameCleanupTimer()
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ConsoleHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest& request, HttpResponse& response, const Dictionary::Ptr& params)
|
bool ConsoleHandler::HandleRequest(
|
||||||
|
const ApiUser::Ptr& user,
|
||||||
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
const Url::Ptr& url,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
|
const Dictionary::Ptr& params
|
||||||
|
)
|
||||||
{
|
{
|
||||||
if (request.RequestUrl->GetPath().size() != 3)
|
namespace http = boost::beast::http;
|
||||||
|
|
||||||
|
if (url->GetPath().size() != 3)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
if (request.RequestMethod != "POST")
|
if (request.method() != http::verb::post)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
QueryDescription qd;
|
QueryDescription qd;
|
||||||
|
|
||||||
String methodName = request.RequestUrl->GetPath()[2];
|
String methodName = url->GetPath()[2];
|
||||||
|
|
||||||
FilterUtility::CheckPermission(user, "console");
|
FilterUtility::CheckPermission(user, "console");
|
||||||
|
|
||||||
|
@ -85,9 +93,12 @@ bool ConsoleHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest& reques
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ConsoleHandler::ExecuteScriptHelper(HttpRequest& request, HttpResponse& response,
|
bool ConsoleHandler::ExecuteScriptHelper(boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
const Dictionary::Ptr& params, const String& command, const String& session, bool sandboxed)
|
const Dictionary::Ptr& params, const String& command, const String& session, bool sandboxed)
|
||||||
{
|
{
|
||||||
|
namespace http = boost::beast::http;
|
||||||
|
|
||||||
Log(LogNotice, "Console")
|
Log(LogNotice, "Console")
|
||||||
<< "Executing expression: " << command;
|
<< "Executing expression: " << command;
|
||||||
|
|
||||||
|
@ -151,15 +162,18 @@ bool ConsoleHandler::ExecuteScriptHelper(HttpRequest& request, HttpResponse& res
|
||||||
{ "results", new Array({ resultInfo }) }
|
{ "results", new Array({ resultInfo }) }
|
||||||
});
|
});
|
||||||
|
|
||||||
response.SetStatus(200, "OK");
|
response.result(http::status::ok);
|
||||||
HttpUtility::SendJsonBody(response, params, result);
|
HttpUtility::SendJsonBody(response, params, result);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ConsoleHandler::AutocompleteScriptHelper(HttpRequest& request, HttpResponse& response,
|
bool ConsoleHandler::AutocompleteScriptHelper(boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
const Dictionary::Ptr& params, const String& command, const String& session, bool sandboxed)
|
const Dictionary::Ptr& params, const String& command, const String& session, bool sandboxed)
|
||||||
{
|
{
|
||||||
|
namespace http = boost::beast::http;
|
||||||
|
|
||||||
Log(LogInformation, "Console")
|
Log(LogInformation, "Console")
|
||||||
<< "Auto-completing expression: " << command;
|
<< "Auto-completing expression: " << command;
|
||||||
|
|
||||||
|
@ -187,7 +201,7 @@ bool ConsoleHandler::AutocompleteScriptHelper(HttpRequest& request, HttpResponse
|
||||||
{ "results", new Array({ result1 }) }
|
{ "results", new Array({ result1 }) }
|
||||||
});
|
});
|
||||||
|
|
||||||
response.SetStatus(200, "OK");
|
response.result(http::status::ok);
|
||||||
HttpUtility::SendJsonBody(response, params, result);
|
HttpUtility::SendJsonBody(response, params, result);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -22,15 +22,22 @@ class ConsoleHandler final : public HttpHandler
|
||||||
public:
|
public:
|
||||||
DECLARE_PTR_TYPEDEFS(ConsoleHandler);
|
DECLARE_PTR_TYPEDEFS(ConsoleHandler);
|
||||||
|
|
||||||
bool HandleRequest(const ApiUser::Ptr& user, HttpRequest& request,
|
bool HandleRequest(
|
||||||
HttpResponse& response, const Dictionary::Ptr& params) override;
|
const ApiUser::Ptr& user,
|
||||||
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
const Url::Ptr& url,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
|
const Dictionary::Ptr& params
|
||||||
|
) override;
|
||||||
|
|
||||||
static std::vector<String> GetAutocompletionSuggestions(const String& word, ScriptFrame& frame);
|
static std::vector<String> GetAutocompletionSuggestions(const String& word, ScriptFrame& frame);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
static bool ExecuteScriptHelper(HttpRequest& request, HttpResponse& response,
|
static bool ExecuteScriptHelper(boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
const Dictionary::Ptr& params, const String& command, const String& session, bool sandboxed);
|
const Dictionary::Ptr& params, const String& command, const String& session, bool sandboxed);
|
||||||
static bool AutocompleteScriptHelper(HttpRequest& request, HttpResponse& response,
|
static bool AutocompleteScriptHelper(boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
const Dictionary::Ptr& params, const String& command, const String& session, bool sandboxed);
|
const Dictionary::Ptr& params, const String& command, const String& session, bool sandboxed);
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
|
@ -14,15 +14,23 @@ using namespace icinga;
|
||||||
|
|
||||||
REGISTER_URLHANDLER("/v1/objects", CreateObjectHandler);
|
REGISTER_URLHANDLER("/v1/objects", CreateObjectHandler);
|
||||||
|
|
||||||
bool CreateObjectHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest& request, HttpResponse& response, const Dictionary::Ptr& params)
|
bool CreateObjectHandler::HandleRequest(
|
||||||
|
const ApiUser::Ptr& user,
|
||||||
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
const Url::Ptr& url,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
|
const Dictionary::Ptr& params
|
||||||
|
)
|
||||||
{
|
{
|
||||||
if (request.RequestUrl->GetPath().size() != 4)
|
namespace http = boost::beast::http;
|
||||||
|
|
||||||
|
if (url->GetPath().size() != 4)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
if (request.RequestMethod != "PUT")
|
if (request.method() != http::verb::put)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
Type::Ptr type = FilterUtility::TypeFromPluralName(request.RequestUrl->GetPath()[2]);
|
Type::Ptr type = FilterUtility::TypeFromPluralName(url->GetPath()[2]);
|
||||||
|
|
||||||
if (!type) {
|
if (!type) {
|
||||||
HttpUtility::SendJsonError(response, params, 400, "Invalid type specified.");
|
HttpUtility::SendJsonError(response, params, 400, "Invalid type specified.");
|
||||||
|
@ -31,7 +39,7 @@ bool CreateObjectHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest& r
|
||||||
|
|
||||||
FilterUtility::CheckPermission(user, "objects/create/" + type->GetName());
|
FilterUtility::CheckPermission(user, "objects/create/" + type->GetName());
|
||||||
|
|
||||||
String name = request.RequestUrl->GetPath()[3];
|
String name = url->GetPath()[3];
|
||||||
Array::Ptr templates = params->Get("templates");
|
Array::Ptr templates = params->Get("templates");
|
||||||
Dictionary::Ptr attrs = params->Get("attrs");
|
Dictionary::Ptr attrs = params->Get("attrs");
|
||||||
|
|
||||||
|
@ -99,7 +107,7 @@ bool CreateObjectHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest& r
|
||||||
result1->Set("code", 500);
|
result1->Set("code", 500);
|
||||||
result1->Set("status", "Object could not be created.");
|
result1->Set("status", "Object could not be created.");
|
||||||
|
|
||||||
response.SetStatus(500, "Object could not be created");
|
response.result(http::status::internal_server_error);
|
||||||
HttpUtility::SendJsonBody(response, params, result);
|
HttpUtility::SendJsonBody(response, params, result);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
@ -113,7 +121,7 @@ bool CreateObjectHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest& r
|
||||||
if (verbose)
|
if (verbose)
|
||||||
result1->Set("diagnostic_information", diagnosticInformation);
|
result1->Set("diagnostic_information", diagnosticInformation);
|
||||||
|
|
||||||
response.SetStatus(500, "Object could not be created");
|
response.result(http::status::internal_server_error);
|
||||||
HttpUtility::SendJsonBody(response, params, result);
|
HttpUtility::SendJsonBody(response, params, result);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
@ -129,7 +137,7 @@ bool CreateObjectHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest& r
|
||||||
else if (!obj && ignoreOnError)
|
else if (!obj && ignoreOnError)
|
||||||
result1->Set("status", "Object was not created but 'ignore_on_error' was set to true");
|
result1->Set("status", "Object was not created but 'ignore_on_error' was set to true");
|
||||||
|
|
||||||
response.SetStatus(200, "OK");
|
response.result(http::status::ok);
|
||||||
HttpUtility::SendJsonBody(response, params, result);
|
HttpUtility::SendJsonBody(response, params, result);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -13,8 +13,13 @@ class CreateObjectHandler final : public HttpHandler
|
||||||
public:
|
public:
|
||||||
DECLARE_PTR_TYPEDEFS(CreateObjectHandler);
|
DECLARE_PTR_TYPEDEFS(CreateObjectHandler);
|
||||||
|
|
||||||
bool HandleRequest(const ApiUser::Ptr& user, HttpRequest& request,
|
bool HandleRequest(
|
||||||
HttpResponse& response, const Dictionary::Ptr& params) override;
|
const ApiUser::Ptr& user,
|
||||||
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
const Url::Ptr& url,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
|
const Dictionary::Ptr& params
|
||||||
|
) override;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,15 +14,23 @@ using namespace icinga;
|
||||||
|
|
||||||
REGISTER_URLHANDLER("/v1/objects", DeleteObjectHandler);
|
REGISTER_URLHANDLER("/v1/objects", DeleteObjectHandler);
|
||||||
|
|
||||||
bool DeleteObjectHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest& request, HttpResponse& response, const Dictionary::Ptr& params)
|
bool DeleteObjectHandler::HandleRequest(
|
||||||
|
const ApiUser::Ptr& user,
|
||||||
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
const Url::Ptr& url,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
|
const Dictionary::Ptr& params
|
||||||
|
)
|
||||||
{
|
{
|
||||||
if (request.RequestUrl->GetPath().size() < 3 || request.RequestUrl->GetPath().size() > 4)
|
namespace http = boost::beast::http;
|
||||||
|
|
||||||
|
if (url->GetPath().size() < 3 || url->GetPath().size() > 4)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
if (request.RequestMethod != "DELETE")
|
if (request.method() != http::verb::delete_)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
Type::Ptr type = FilterUtility::TypeFromPluralName(request.RequestUrl->GetPath()[2]);
|
Type::Ptr type = FilterUtility::TypeFromPluralName(url->GetPath()[2]);
|
||||||
|
|
||||||
if (!type) {
|
if (!type) {
|
||||||
HttpUtility::SendJsonError(response, params, 400, "Invalid type specified.");
|
HttpUtility::SendJsonError(response, params, 400, "Invalid type specified.");
|
||||||
|
@ -35,10 +43,10 @@ bool DeleteObjectHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest& r
|
||||||
|
|
||||||
params->Set("type", type->GetName());
|
params->Set("type", type->GetName());
|
||||||
|
|
||||||
if (request.RequestUrl->GetPath().size() >= 4) {
|
if (url->GetPath().size() >= 4) {
|
||||||
String attr = type->GetName();
|
String attr = type->GetName();
|
||||||
boost::algorithm::to_lower(attr);
|
boost::algorithm::to_lower(attr);
|
||||||
params->Set(attr, request.RequestUrl->GetPath()[3]);
|
params->Set(attr, url->GetPath()[3]);
|
||||||
}
|
}
|
||||||
|
|
||||||
std::vector<Value> objs;
|
std::vector<Value> objs;
|
||||||
|
@ -93,9 +101,9 @@ bool DeleteObjectHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest& r
|
||||||
});
|
});
|
||||||
|
|
||||||
if (!success)
|
if (!success)
|
||||||
response.SetStatus(500, "One or more objects could not be deleted");
|
response.result(http::status::internal_server_error);
|
||||||
else
|
else
|
||||||
response.SetStatus(200, "OK");
|
response.result(http::status::ok);
|
||||||
|
|
||||||
HttpUtility::SendJsonBody(response, params, result);
|
HttpUtility::SendJsonBody(response, params, result);
|
||||||
|
|
||||||
|
|
|
@ -13,8 +13,13 @@ class DeleteObjectHandler final : public HttpHandler
|
||||||
public:
|
public:
|
||||||
DECLARE_PTR_TYPEDEFS(DeleteObjectHandler);
|
DECLARE_PTR_TYPEDEFS(DeleteObjectHandler);
|
||||||
|
|
||||||
bool HandleRequest(const ApiUser::Ptr& user, HttpRequest& request,
|
bool HandleRequest(
|
||||||
HttpResponse& response, const Dictionary::Ptr& params) override;
|
const ApiUser::Ptr& user,
|
||||||
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
const Url::Ptr& url,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
|
const Dictionary::Ptr& params
|
||||||
|
) override;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,15 +13,23 @@ using namespace icinga;
|
||||||
|
|
||||||
REGISTER_URLHANDLER("/v1/events", EventsHandler);
|
REGISTER_URLHANDLER("/v1/events", EventsHandler);
|
||||||
|
|
||||||
bool EventsHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest& request, HttpResponse& response, const Dictionary::Ptr& params)
|
bool EventsHandler::HandleRequest(
|
||||||
|
const ApiUser::Ptr& user,
|
||||||
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
const Url::Ptr& url,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
|
const Dictionary::Ptr& params
|
||||||
|
)
|
||||||
{
|
{
|
||||||
if (request.RequestUrl->GetPath().size() != 2)
|
namespace http = boost::beast::http;
|
||||||
|
|
||||||
|
if (url->GetPath().size() != 2)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
if (request.RequestMethod != "POST")
|
if (request.method() != http::verb::post)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
if (request.ProtocolVersion == HttpVersion10) {
|
if (request.version() == 10) {
|
||||||
HttpUtility::SendJsonError(response, params, 400, "HTTP/1.0 not supported for event streams.");
|
HttpUtility::SendJsonError(response, params, 400, "HTTP/1.0 not supported for event streams.");
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -67,8 +75,8 @@ bool EventsHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest& request
|
||||||
|
|
||||||
queue->AddClient(&request);
|
queue->AddClient(&request);
|
||||||
|
|
||||||
response.SetStatus(200, "OK");
|
response.result(http::status::ok);
|
||||||
response.AddHeader("Content-Type", "application/json");
|
response.set(http::field::content_type, "application/json");
|
||||||
|
|
||||||
for (;;) {
|
for (;;) {
|
||||||
Dictionary::Ptr result = queue->WaitForEvent(&request);
|
Dictionary::Ptr result = queue->WaitForEvent(&request);
|
||||||
|
|
|
@ -14,8 +14,13 @@ class EventsHandler final : public HttpHandler
|
||||||
public:
|
public:
|
||||||
DECLARE_PTR_TYPEDEFS(EventsHandler);
|
DECLARE_PTR_TYPEDEFS(EventsHandler);
|
||||||
|
|
||||||
bool HandleRequest(const ApiUser::Ptr& user, HttpRequest& request,
|
bool HandleRequest(
|
||||||
HttpResponse& response, const Dictionary::Ptr& params) override;
|
const ApiUser::Ptr& user,
|
||||||
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
const Url::Ptr& url,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
|
const Dictionary::Ptr& params
|
||||||
|
) override;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,24 +8,32 @@ using namespace icinga;
|
||||||
|
|
||||||
REGISTER_URLHANDLER("/", InfoHandler);
|
REGISTER_URLHANDLER("/", InfoHandler);
|
||||||
|
|
||||||
bool InfoHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest& request, HttpResponse& response, const Dictionary::Ptr& params)
|
bool InfoHandler::HandleRequest(
|
||||||
|
const ApiUser::Ptr& user,
|
||||||
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
const Url::Ptr& url,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
|
const Dictionary::Ptr& params
|
||||||
|
)
|
||||||
{
|
{
|
||||||
if (request.RequestUrl->GetPath().size() > 2)
|
namespace http = boost::beast::http;
|
||||||
|
|
||||||
|
if (url->GetPath().size() > 2)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
if (request.RequestMethod != "GET")
|
if (request.method() != http::verb::get)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
if (request.RequestUrl->GetPath().empty()) {
|
if (url->GetPath().empty()) {
|
||||||
response.SetStatus(302, "Found");
|
response.result(http::status::found);
|
||||||
response.AddHeader("Location", "/v1");
|
response.set(http::field::location, "/v1");
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (request.RequestUrl->GetPath()[0] != "v1" || request.RequestUrl->GetPath().size() != 1)
|
if (url->GetPath()[0] != "v1" || url->GetPath().size() != 1)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
response.SetStatus(200, "OK");
|
response.result(http::status::ok);
|
||||||
|
|
||||||
std::vector<String> permInfo;
|
std::vector<String> permInfo;
|
||||||
Array::Ptr permissions = user->GetPermissions();
|
Array::Ptr permissions = user->GetPermissions();
|
||||||
|
@ -49,7 +57,7 @@ bool InfoHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest& request,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (request.Headers->Get("accept") == "application/json") {
|
if (request[http::field::accept] == "application/json") {
|
||||||
Dictionary::Ptr result1 = new Dictionary({
|
Dictionary::Ptr result1 = new Dictionary({
|
||||||
{ "user", user->GetName() },
|
{ "user", user->GetName() },
|
||||||
{ "permissions", Array::FromVector(permInfo) },
|
{ "permissions", Array::FromVector(permInfo) },
|
||||||
|
@ -63,7 +71,7 @@ bool InfoHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest& request,
|
||||||
|
|
||||||
HttpUtility::SendJsonBody(response, params, result);
|
HttpUtility::SendJsonBody(response, params, result);
|
||||||
} else {
|
} else {
|
||||||
response.AddHeader("Content-Type", "text/html");
|
response.set(http::field::content_type, "text/html");
|
||||||
|
|
||||||
String body = "<html><head><title>Icinga 2</title></head><h1>Hello from Icinga 2 (Version: " + Application::GetAppVersion() + ")!</h1>";
|
String body = "<html><head><title>Icinga 2</title></head><h1>Hello from Icinga 2 (Version: " + Application::GetAppVersion() + ")!</h1>";
|
||||||
body += "<p>You are authenticated as <b>" + user->GetName() + "</b>. ";
|
body += "<p>You are authenticated as <b>" + user->GetName() + "</b>. ";
|
||||||
|
@ -80,7 +88,8 @@ bool InfoHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest& request,
|
||||||
body += "Your user does not have any permissions.</p>";
|
body += "Your user does not have any permissions.</p>";
|
||||||
|
|
||||||
body += R"(<p>More information about API requests is available in the <a href="https://docs.icinga.com/icinga2/latest" target="_blank">documentation</a>.</p></html>)";
|
body += R"(<p>More information about API requests is available in the <a href="https://docs.icinga.com/icinga2/latest" target="_blank">documentation</a>.</p></html>)";
|
||||||
response.WriteBody(body.CStr(), body.GetLength());
|
response.body() = body;
|
||||||
|
response.set(http::field::content_length, response.body().size());
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -13,8 +13,13 @@ class InfoHandler final : public HttpHandler
|
||||||
public:
|
public:
|
||||||
DECLARE_PTR_TYPEDEFS(InfoHandler);
|
DECLARE_PTR_TYPEDEFS(InfoHandler);
|
||||||
|
|
||||||
bool HandleRequest(const ApiUser::Ptr& user, HttpRequest& request,
|
bool HandleRequest(
|
||||||
HttpResponse& response, const Dictionary::Ptr& params) override;
|
const ApiUser::Ptr& user,
|
||||||
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
const Url::Ptr& url,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
|
const Dictionary::Ptr& params
|
||||||
|
) override;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -12,15 +12,23 @@ using namespace icinga;
|
||||||
|
|
||||||
REGISTER_URLHANDLER("/v1/objects", ModifyObjectHandler);
|
REGISTER_URLHANDLER("/v1/objects", ModifyObjectHandler);
|
||||||
|
|
||||||
bool ModifyObjectHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest& request, HttpResponse& response, const Dictionary::Ptr& params)
|
bool ModifyObjectHandler::HandleRequest(
|
||||||
|
const ApiUser::Ptr& user,
|
||||||
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
const Url::Ptr& url,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
|
const Dictionary::Ptr& params
|
||||||
|
)
|
||||||
{
|
{
|
||||||
if (request.RequestUrl->GetPath().size() < 3 || request.RequestUrl->GetPath().size() > 4)
|
namespace http = boost::beast::http;
|
||||||
|
|
||||||
|
if (url->GetPath().size() < 3 || url->GetPath().size() > 4)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
if (request.RequestMethod != "POST")
|
if (request.method() != http::verb::post)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
Type::Ptr type = FilterUtility::TypeFromPluralName(request.RequestUrl->GetPath()[2]);
|
Type::Ptr type = FilterUtility::TypeFromPluralName(url->GetPath()[2]);
|
||||||
|
|
||||||
if (!type) {
|
if (!type) {
|
||||||
HttpUtility::SendJsonError(response, params, 400, "Invalid type specified.");
|
HttpUtility::SendJsonError(response, params, 400, "Invalid type specified.");
|
||||||
|
@ -33,10 +41,10 @@ bool ModifyObjectHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest& r
|
||||||
|
|
||||||
params->Set("type", type->GetName());
|
params->Set("type", type->GetName());
|
||||||
|
|
||||||
if (request.RequestUrl->GetPath().size() >= 4) {
|
if (url->GetPath().size() >= 4) {
|
||||||
String attr = type->GetName();
|
String attr = type->GetName();
|
||||||
boost::algorithm::to_lower(attr);
|
boost::algorithm::to_lower(attr);
|
||||||
params->Set(attr, request.RequestUrl->GetPath()[3]);
|
params->Set(attr, url->GetPath()[3]);
|
||||||
}
|
}
|
||||||
|
|
||||||
std::vector<Value> objs;
|
std::vector<Value> objs;
|
||||||
|
@ -101,7 +109,7 @@ bool ModifyObjectHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest& r
|
||||||
{ "results", new Array(std::move(results)) }
|
{ "results", new Array(std::move(results)) }
|
||||||
});
|
});
|
||||||
|
|
||||||
response.SetStatus(200, "OK");
|
response.result(http::status::ok);
|
||||||
HttpUtility::SendJsonBody(response, params, result);
|
HttpUtility::SendJsonBody(response, params, result);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -13,8 +13,13 @@ class ModifyObjectHandler final : public HttpHandler
|
||||||
public:
|
public:
|
||||||
DECLARE_PTR_TYPEDEFS(ModifyObjectHandler);
|
DECLARE_PTR_TYPEDEFS(ModifyObjectHandler);
|
||||||
|
|
||||||
bool HandleRequest(const ApiUser::Ptr& user, HttpRequest& request,
|
bool HandleRequest(
|
||||||
HttpResponse& response, const Dictionary::Ptr& params) override;
|
const ApiUser::Ptr& user,
|
||||||
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
const Url::Ptr& url,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
|
const Dictionary::Ptr& params
|
||||||
|
) override;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -87,15 +87,23 @@ Dictionary::Ptr ObjectQueryHandler::SerializeObjectAttrs(const Object::Ptr& obje
|
||||||
return new Dictionary(std::move(resultAttrs));
|
return new Dictionary(std::move(resultAttrs));
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ObjectQueryHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest& request, HttpResponse& response, const Dictionary::Ptr& params)
|
bool ObjectQueryHandler::HandleRequest(
|
||||||
|
const ApiUser::Ptr& user,
|
||||||
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
const Url::Ptr& url,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
|
const Dictionary::Ptr& params
|
||||||
|
)
|
||||||
{
|
{
|
||||||
if (request.RequestUrl->GetPath().size() < 3 || request.RequestUrl->GetPath().size() > 4)
|
namespace http = boost::beast::http;
|
||||||
|
|
||||||
|
if (url->GetPath().size() < 3 || url->GetPath().size() > 4)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
if (request.RequestMethod != "GET")
|
if (request.method() != http::verb::get)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
Type::Ptr type = FilterUtility::TypeFromPluralName(request.RequestUrl->GetPath()[2]);
|
Type::Ptr type = FilterUtility::TypeFromPluralName(url->GetPath()[2]);
|
||||||
|
|
||||||
if (!type) {
|
if (!type) {
|
||||||
HttpUtility::SendJsonError(response, params, 400, "Invalid type specified.");
|
HttpUtility::SendJsonError(response, params, 400, "Invalid type specified.");
|
||||||
|
@ -136,10 +144,10 @@ bool ObjectQueryHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest& re
|
||||||
|
|
||||||
params->Set("type", type->GetName());
|
params->Set("type", type->GetName());
|
||||||
|
|
||||||
if (request.RequestUrl->GetPath().size() >= 4) {
|
if (url->GetPath().size() >= 4) {
|
||||||
String attr = type->GetName();
|
String attr = type->GetName();
|
||||||
boost::algorithm::to_lower(attr);
|
boost::algorithm::to_lower(attr);
|
||||||
params->Set(attr, request.RequestUrl->GetPath()[3]);
|
params->Set(attr, url->GetPath()[3]);
|
||||||
}
|
}
|
||||||
|
|
||||||
std::vector<Value> objs;
|
std::vector<Value> objs;
|
||||||
|
@ -265,7 +273,7 @@ bool ObjectQueryHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest& re
|
||||||
{ "results", new Array(std::move(results)) }
|
{ "results", new Array(std::move(results)) }
|
||||||
});
|
});
|
||||||
|
|
||||||
response.SetStatus(200, "OK");
|
response.result(http::status::ok);
|
||||||
HttpUtility::SendJsonBody(response, params, result);
|
HttpUtility::SendJsonBody(response, params, result);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -13,8 +13,13 @@ class ObjectQueryHandler final : public HttpHandler
|
||||||
public:
|
public:
|
||||||
DECLARE_PTR_TYPEDEFS(ObjectQueryHandler);
|
DECLARE_PTR_TYPEDEFS(ObjectQueryHandler);
|
||||||
|
|
||||||
bool HandleRequest(const ApiUser::Ptr& user, HttpRequest& request,
|
bool HandleRequest(
|
||||||
HttpResponse& response, const Dictionary::Ptr& params) override;
|
const ApiUser::Ptr& user,
|
||||||
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
const Url::Ptr& url,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
|
const Dictionary::Ptr& params
|
||||||
|
) override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
static Dictionary::Ptr SerializeObjectAttrs(const Object::Ptr& object, const String& attrPrefix,
|
static Dictionary::Ptr SerializeObjectAttrs(const Object::Ptr& object, const String& attrPrefix,
|
||||||
|
|
|
@ -68,12 +68,20 @@ public:
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
bool StatusHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest& request, HttpResponse& response, const Dictionary::Ptr& params)
|
bool StatusHandler::HandleRequest(
|
||||||
|
const ApiUser::Ptr& user,
|
||||||
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
const Url::Ptr& url,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
|
const Dictionary::Ptr& params
|
||||||
|
)
|
||||||
{
|
{
|
||||||
if (request.RequestUrl->GetPath().size() > 3)
|
namespace http = boost::beast::http;
|
||||||
|
|
||||||
|
if (url->GetPath().size() > 3)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
if (request.RequestMethod != "GET")
|
if (request.method() != http::verb::get)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
QueryDescription qd;
|
QueryDescription qd;
|
||||||
|
@ -83,8 +91,8 @@ bool StatusHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest& request
|
||||||
|
|
||||||
params->Set("type", "Status");
|
params->Set("type", "Status");
|
||||||
|
|
||||||
if (request.RequestUrl->GetPath().size() >= 3)
|
if (url->GetPath().size() >= 3)
|
||||||
params->Set("status", request.RequestUrl->GetPath()[2]);
|
params->Set("status", url->GetPath()[2]);
|
||||||
|
|
||||||
std::vector<Value> objs;
|
std::vector<Value> objs;
|
||||||
|
|
||||||
|
@ -101,7 +109,7 @@ bool StatusHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest& request
|
||||||
{ "results", new Array(std::move(objs)) }
|
{ "results", new Array(std::move(objs)) }
|
||||||
});
|
});
|
||||||
|
|
||||||
response.SetStatus(200, "OK");
|
response.result(http::status::ok);
|
||||||
HttpUtility::SendJsonBody(response, params, result);
|
HttpUtility::SendJsonBody(response, params, result);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -13,8 +13,13 @@ class StatusHandler final : public HttpHandler
|
||||||
public:
|
public:
|
||||||
DECLARE_PTR_TYPEDEFS(StatusHandler);
|
DECLARE_PTR_TYPEDEFS(StatusHandler);
|
||||||
|
|
||||||
bool HandleRequest(const ApiUser::Ptr& user, HttpRequest& request,
|
bool HandleRequest(
|
||||||
HttpResponse& response, const Dictionary::Ptr& params) override;
|
const ApiUser::Ptr& user,
|
||||||
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
const Url::Ptr& url,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
|
const Dictionary::Ptr& params
|
||||||
|
) override;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -75,15 +75,23 @@ public:
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
bool TemplateQueryHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest& request, HttpResponse& response, const Dictionary::Ptr& params)
|
bool TemplateQueryHandler::HandleRequest(
|
||||||
|
const ApiUser::Ptr& user,
|
||||||
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
const Url::Ptr& url,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
|
const Dictionary::Ptr& params
|
||||||
|
)
|
||||||
{
|
{
|
||||||
if (request.RequestUrl->GetPath().size() < 3 || request.RequestUrl->GetPath().size() > 4)
|
namespace http = boost::beast::http;
|
||||||
|
|
||||||
|
if (url->GetPath().size() < 3 || url->GetPath().size() > 4)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
if (request.RequestMethod != "GET")
|
if (request.method() != http::verb::get)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
Type::Ptr type = FilterUtility::TypeFromPluralName(request.RequestUrl->GetPath()[2]);
|
Type::Ptr type = FilterUtility::TypeFromPluralName(url->GetPath()[2]);
|
||||||
|
|
||||||
if (!type) {
|
if (!type) {
|
||||||
HttpUtility::SendJsonError(response, params, 400, "Invalid type specified.");
|
HttpUtility::SendJsonError(response, params, 400, "Invalid type specified.");
|
||||||
|
@ -97,10 +105,10 @@ bool TemplateQueryHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest&
|
||||||
|
|
||||||
params->Set("type", type->GetName());
|
params->Set("type", type->GetName());
|
||||||
|
|
||||||
if (request.RequestUrl->GetPath().size() >= 4) {
|
if (url->GetPath().size() >= 4) {
|
||||||
String attr = type->GetName();
|
String attr = type->GetName();
|
||||||
boost::algorithm::to_lower(attr);
|
boost::algorithm::to_lower(attr);
|
||||||
params->Set(attr, request.RequestUrl->GetPath()[3]);
|
params->Set(attr, url->GetPath()[3]);
|
||||||
}
|
}
|
||||||
|
|
||||||
std::vector<Value> objs;
|
std::vector<Value> objs;
|
||||||
|
@ -118,7 +126,7 @@ bool TemplateQueryHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest&
|
||||||
{ "results", new Array(std::move(objs)) }
|
{ "results", new Array(std::move(objs)) }
|
||||||
});
|
});
|
||||||
|
|
||||||
response.SetStatus(200, "OK");
|
response.result(http::status::ok);
|
||||||
HttpUtility::SendJsonBody(response, params, result);
|
HttpUtility::SendJsonBody(response, params, result);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -13,8 +13,13 @@ class TemplateQueryHandler final : public HttpHandler
|
||||||
public:
|
public:
|
||||||
DECLARE_PTR_TYPEDEFS(TemplateQueryHandler);
|
DECLARE_PTR_TYPEDEFS(TemplateQueryHandler);
|
||||||
|
|
||||||
bool HandleRequest(const ApiUser::Ptr& user, HttpRequest& request,
|
bool HandleRequest(
|
||||||
HttpResponse& response, const Dictionary::Ptr& params) override;
|
const ApiUser::Ptr& user,
|
||||||
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
const Url::Ptr& url,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
|
const Dictionary::Ptr& params
|
||||||
|
) override;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -46,12 +46,20 @@ public:
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
bool TypeQueryHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest& request, HttpResponse& response, const Dictionary::Ptr& params)
|
bool TypeQueryHandler::HandleRequest(
|
||||||
|
const ApiUser::Ptr& user,
|
||||||
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
const Url::Ptr& url,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
|
const Dictionary::Ptr& params
|
||||||
|
)
|
||||||
{
|
{
|
||||||
if (request.RequestUrl->GetPath().size() > 3)
|
namespace http = boost::beast::http;
|
||||||
|
|
||||||
|
if (url->GetPath().size() > 3)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
if (request.RequestMethod != "GET")
|
if (request.method() != http::verb::get)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
QueryDescription qd;
|
QueryDescription qd;
|
||||||
|
@ -64,8 +72,8 @@ bool TypeQueryHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest& requ
|
||||||
|
|
||||||
params->Set("type", "Type");
|
params->Set("type", "Type");
|
||||||
|
|
||||||
if (request.RequestUrl->GetPath().size() >= 3)
|
if (url->GetPath().size() >= 3)
|
||||||
params->Set("name", request.RequestUrl->GetPath()[2]);
|
params->Set("name", url->GetPath()[2]);
|
||||||
|
|
||||||
std::vector<Value> objs;
|
std::vector<Value> objs;
|
||||||
|
|
||||||
|
@ -138,7 +146,7 @@ bool TypeQueryHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest& requ
|
||||||
{ "results", new Array(std::move(results)) }
|
{ "results", new Array(std::move(results)) }
|
||||||
});
|
});
|
||||||
|
|
||||||
response.SetStatus(200, "OK");
|
response.result(http::status::ok);
|
||||||
HttpUtility::SendJsonBody(response, params, result);
|
HttpUtility::SendJsonBody(response, params, result);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -13,8 +13,13 @@ class TypeQueryHandler final : public HttpHandler
|
||||||
public:
|
public:
|
||||||
DECLARE_PTR_TYPEDEFS(TypeQueryHandler);
|
DECLARE_PTR_TYPEDEFS(TypeQueryHandler);
|
||||||
|
|
||||||
bool HandleRequest(const ApiUser::Ptr& user, HttpRequest& request,
|
bool HandleRequest(
|
||||||
HttpResponse& response, const Dictionary::Ptr& params) override;
|
const ApiUser::Ptr& user,
|
||||||
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
const Url::Ptr& url,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
|
const Dictionary::Ptr& params
|
||||||
|
) override;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -56,12 +56,20 @@ public:
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
bool VariableQueryHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest& request, HttpResponse& response, const Dictionary::Ptr& params)
|
bool VariableQueryHandler::HandleRequest(
|
||||||
|
const ApiUser::Ptr& user,
|
||||||
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
const Url::Ptr& url,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
|
const Dictionary::Ptr& params
|
||||||
|
)
|
||||||
{
|
{
|
||||||
if (request.RequestUrl->GetPath().size() > 3)
|
namespace http = boost::beast::http;
|
||||||
|
|
||||||
|
if (url->GetPath().size() > 3)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
if (request.RequestMethod != "GET")
|
if (request.method() != http::verb::get)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
QueryDescription qd;
|
QueryDescription qd;
|
||||||
|
@ -71,8 +79,8 @@ bool VariableQueryHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest&
|
||||||
|
|
||||||
params->Set("type", "Variable");
|
params->Set("type", "Variable");
|
||||||
|
|
||||||
if (request.RequestUrl->GetPath().size() >= 3)
|
if (url->GetPath().size() >= 3)
|
||||||
params->Set("variable", request.RequestUrl->GetPath()[2]);
|
params->Set("variable", url->GetPath()[2]);
|
||||||
|
|
||||||
std::vector<Value> objs;
|
std::vector<Value> objs;
|
||||||
|
|
||||||
|
@ -99,7 +107,7 @@ bool VariableQueryHandler::HandleRequest(const ApiUser::Ptr& user, HttpRequest&
|
||||||
{ "results", new Array(std::move(results)) }
|
{ "results", new Array(std::move(results)) }
|
||||||
});
|
});
|
||||||
|
|
||||||
response.SetStatus(200, "OK");
|
response.result(http::status::ok);
|
||||||
HttpUtility::SendJsonBody(response, params, result);
|
HttpUtility::SendJsonBody(response, params, result);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -13,8 +13,13 @@ class VariableQueryHandler final : public HttpHandler
|
||||||
public:
|
public:
|
||||||
DECLARE_PTR_TYPEDEFS(VariableQueryHandler);
|
DECLARE_PTR_TYPEDEFS(VariableQueryHandler);
|
||||||
|
|
||||||
bool HandleRequest(const ApiUser::Ptr& user, HttpRequest& request,
|
bool HandleRequest(
|
||||||
HttpResponse& response, const Dictionary::Ptr& params) override;
|
const ApiUser::Ptr& user,
|
||||||
|
boost::beast::http::request<boost::beast::http::string_body>& request,
|
||||||
|
const Url::Ptr& url,
|
||||||
|
boost::beast::http::response<boost::beast::http::string_body>& response,
|
||||||
|
const Dictionary::Ptr& params
|
||||||
|
) override;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue