nscapi::settings_proxy::string_list nscapi::settings_proxy::get_keys(std::string path) { nscapi::settings_proxy::string_list ret; Plugin::SettingsRequestMessage request; nscapi::protobuf::functions::create_simple_header(request.mutable_header()); Plugin::SettingsRequestMessage::Request *payload = request.add_payload(); payload->set_plugin_id(plugin_id_); Plugin::SettingsRequestMessage::Request::Query *item = payload->mutable_query(); item->mutable_node()->set_path(path); item->set_type(Plugin::Common_DataType_LIST); item->set_recursive(false); std::string response_string; core_->settings_query(request.SerializeAsString(), response_string); Plugin::SettingsResponseMessage response; response.ParseFromString(response_string); if (response.payload_size() != 1 || !response.payload(0).has_query()) { return ret; } const ::Plugin::Common_AnyDataType value = response.payload(0).query().value(); for (int i=0;i<value.list_data_size();++i) { ret.push_back(value.list_data(i)); } return ret; }
void settings_controller::get_key(Mongoose::Request &request, boost::smatch &what, Mongoose::StreamResponse &response) { if (!session->is_loggedin("settings", request, response)) return; if (!validate_arguments(2, what, response)) { return; } std::string path = what.str(1); std::string key = what.str(2); if (!session->can("settings.get", request, response)) return; Plugin::SettingsRequestMessage rm; Plugin::SettingsRequestMessage::Request *payload = rm.add_payload(); payload->mutable_query()->mutable_node()->set_path(path); payload->mutable_query()->mutable_node()->set_key(key); payload->mutable_query()->set_recursive(false); payload->set_plugin_id(plugin_id); std::string str_response; core->settings_query(rm.SerializeAsString(), str_response); Plugin::SettingsResponseMessage pb_response; pb_response.ParseFromString(str_response); json_spirit::Object node; BOOST_FOREACH(const Plugin::SettingsResponseMessage::Response r, pb_response.payload()) { if (!r.has_query()) { response.setCode(HTTP_NOT_FOUND); response.append("Key not found: " + path + "/" + key); return; } const Plugin::SettingsResponseMessage::Response::Query &i = r.query(); node["path"] = i.node().path(); node["key"] = i.node().key(); if (i.value().has_string_data()) { node["value"] = i.value().string_data(); } else if (i.value().has_int_data()) { node["value"] = i.value().int_data(); } else if (i.value().has_bool_data()) { node["value"] = i.value().bool_data(); } } response.append(json_spirit::write(node)); }
int nscapi::settings_proxy::get_int(std::string path, std::string key, int def) { Plugin::SettingsRequestMessage request; nscapi::protobuf::functions::create_simple_header(request.mutable_header()); Plugin::SettingsRequestMessage::Request *payload = request.add_payload(); payload->set_plugin_id(plugin_id_); Plugin::SettingsRequestMessage::Request::Query *item = payload->mutable_query(); item->mutable_node()->set_key(key); item->mutable_node()->set_path(path); item->set_type(Plugin::Common_DataType_INT); item->set_recursive(false); item->mutable_default_value()->set_int_data(def); std::string response_string; core_->settings_query(request.SerializeAsString(), response_string); Plugin::SettingsResponseMessage response; response.ParseFromString(response_string); if (response.payload_size() != 1 || !response.payload(0).has_query()) { return def; } return response.payload(0).query().value().int_data(); }
void settings_controller::get_section(Mongoose::Request &request, boost::smatch &what, Mongoose::StreamResponse &response) { if (!session->is_loggedin("settings.list", request, response)) return; if (!validate_arguments(1, what, response)) { return; } std::string path = what.str(1); Plugin::SettingsRequestMessage rm; Plugin::SettingsRequestMessage::Request *payload = rm.add_payload(); payload->mutable_query()->mutable_node()->set_path(path); payload->mutable_query()->set_recursive(false); payload->set_plugin_id(plugin_id); payload = rm.add_payload(); payload->mutable_query()->mutable_node()->set_path(path); payload->mutable_query()->set_recursive(true); payload->set_plugin_id(plugin_id); std::string str_response; core->settings_query(rm.SerializeAsString(), str_response); Plugin::SettingsResponseMessage pb_response; pb_response.ParseFromString(str_response); json_spirit::Object node; node["path"] = path; if (pb_response.payload_size() != 2) { response.setCode(HTTP_SERVER_ERROR); response.append("Failed to fetch keys"); return; } const Plugin::SettingsResponseMessage::Response rKeys = pb_response.payload(0); if (!rKeys.has_query()) { response.setCode(HTTP_NOT_FOUND); response.append("Key not found: " + path); return; } json_spirit::Array keys; BOOST_FOREACH(const std::string &s, rKeys.query().value().list_data()) { keys.push_back(s); } node["keys"] = keys; const Plugin::SettingsResponseMessage::Response rPath = pb_response.payload(1); if (!rPath.has_query()) { response.setCode(HTTP_NOT_FOUND); response.append("Key not found: " + path); return; } json_spirit::Array paths; BOOST_FOREACH(const std::string &s, rPath.query().value().list_data()) { paths.push_back(s); } node["paths"] = paths; response.append(json_spirit::write(node)); }