This series adds the implementation for teh Failure detector API. After this patch the following APIs will be supported: /failure_detector/endpoints /failure_detector/count/endpoint/up /failure_detector/count/endpoint/down /failure_detector/phi POST:/failure_detector/phi /failure_detector/simple_states /failure_detector/endpoints/states Signed-off-by: Amnon Heiman <amnon@cloudius-systems.com>
59 lines
2.0 KiB
C++
59 lines
2.0 KiB
C++
/*
|
|
* Copyright 2015 Cloudius Systems
|
|
*/
|
|
|
|
#include "failure_detector.hh"
|
|
#include "api/api-doc/failure_detector.json.hh"
|
|
#include "gms/failure_detector.hh"
|
|
namespace api {
|
|
|
|
namespace fd = httpd::failure_detector_json;
|
|
|
|
void set_failure_detector(http_context& ctx, routes& r) {
|
|
fd::get_all_endpoint_states.set(r, [](std::unique_ptr<request> req) {
|
|
return gms::get_all_endpoint_states().then([](const sstring& str) {
|
|
return make_ready_future<json::json_return_type>(str);
|
|
});
|
|
});
|
|
|
|
fd::get_up_endpoint_count.set(r, [](std::unique_ptr<request> req) {
|
|
return gms::get_up_endpoint_count().then([](int res) {
|
|
return make_ready_future<json::json_return_type>(res);
|
|
});
|
|
});
|
|
|
|
fd::get_down_endpoint_count.set(r, [](std::unique_ptr<request> req) {
|
|
return gms::get_down_endpoint_count().then([](int res) {
|
|
return make_ready_future<json::json_return_type>(res);
|
|
});
|
|
});
|
|
|
|
fd::get_phi_convict_threshold.set(r, [] (std::unique_ptr<request> req) {
|
|
return gms::get_phi_convict_threshold().then([](double res) {
|
|
return make_ready_future<json::json_return_type>(res);
|
|
});
|
|
});
|
|
|
|
fd::get_simple_states.set(r, [] (std::unique_ptr<request> req) {
|
|
return gms::get_simple_states().then([](const std::map<sstring, sstring>& map) {
|
|
return make_ready_future<json::json_return_type>(map_to_key_value<fd::mapper>(map));
|
|
});
|
|
});
|
|
|
|
fd::set_phi_convict_threshold.set(r, [](std::unique_ptr<request> req) {
|
|
double phi = atof(req->get_query_param("phi").c_str());
|
|
return gms::set_phi_convict_threshold(phi).then([]() {
|
|
return make_ready_future<json::json_return_type>("");
|
|
});
|
|
});
|
|
|
|
fd::get_endpoint_state.set(r, [](std::unique_ptr<request> req) {
|
|
return gms::get_endpoint_state(req->param["addr"]).then([](const sstring& state) {
|
|
return make_ready_future<json::json_return_type>(state);
|
|
});
|
|
});
|
|
}
|
|
|
|
}
|
|
|