summaryrefslogtreecommitdiff
path: root/server/src/api_core.cpp
diff options
context:
space:
mode:
authorGluzskiy Alexandr <sss@sss.chaoslab.ru>2015-08-23 13:51:45 +0300
committerGluzskiy Alexandr <sss@sss.chaoslab.ru>2015-08-23 13:51:45 +0300
commit9dcd333d8f7ac35cadffd03325a0f72933a0dcc7 (patch)
tree608536f2616e410cf1b69f1424b784f5d297d818 /server/src/api_core.cpp
parentc77cb85e69a830d3b41ba1d55fdc7ff69d330491 (diff)
server:
started first downloader module implementation added api to get core settings downloads_dir in config
Diffstat (limited to 'server/src/api_core.cpp')
-rw-r--r--server/src/api_core.cpp35
1 files changed, 29 insertions, 6 deletions
diff --git a/server/src/api_core.cpp b/server/src/api_core.cpp
index 66df614..b407928 100644
--- a/server/src/api_core.cpp
+++ b/server/src/api_core.cpp
@@ -30,7 +30,6 @@ extern runtime_config_s runtime_config;
bool core_api::metadata_set(module_base *m, const std::string &setting_name, const std::vector<char> &data)
{
- //TODO: respect per module metadata modules definition
//print data
/* std::cout<<"printing data in core set api:\n";
for(auto i = data.begin(), end = data.end(); i != end; ++i)
@@ -44,27 +43,51 @@ bool core_api::metadata_set(module_base *m, const std::string &setting_name, con
bool core_api::metadata_get(module_base *m, const std::string &setting_name, std::vector<char> &data)
{
- //TODO
runtime_config.default_metadata_storage->get(m->get_module_info().name, setting_name, data);
return true;
}
bool core_api::metadata_remove(module_base *m, const std::string &setting_name)
{
- //TODO
runtime_config.default_metadata_storage->remove(m->get_module_info().name, setting_name);
return true;
}
std::map<std::string, std::string> core_api::get_module_settings(module_base *m)
{
- //TODO:
std::map<std::string, std::string> settings;
std::string module = "modules.";
module += m->get_module_info().name;
- for(auto i = runtime_config.config_file.get_child(module).begin(), end = runtime_config.config_file.get_child(module).end(); i != end; ++i)
+ try{
+ for(auto i : runtime_config.config_file.get_child(module))
{
- settings[i->first] = i->second.get_value<std::string>("");
+ settings[i.first] = i.second.get_value<std::string>("");
+ }
+ }
+ catch(...)
+ {
+ //TODO:
}
return settings;
}
+
+
+std::map<std::string, std::string> core_api::get_core_settings()
+{
+ std::map<std::string, std::string> settings_;
+ try{
+ for(auto it : runtime_config.config_file.get_child("server")) //load server node
+ {
+ std::string val = it.second.get_value<std::string>("empty_value"); //TODO: something better here. we need to avoid subtrees and empty vars
+ if(val == "" || val == "empty_value")
+ continue;
+
+ settings_[it.first] = it.second.get_value<std::string>("");
+ }
+ }
+ catch(...)
+ {
+ //TODO:
+ }
+ return settings_;
+}