2018-12-31 22:04:05 +03:00
|
|
|
//
|
2020-01-01 04:23:48 +03:00
|
|
|
// Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2020
|
2018-12-31 22:04:05 +03:00
|
|
|
//
|
|
|
|
// Distributed under the Boost Software License, Version 1.0. (See accompanying
|
|
|
|
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
|
|
|
//
|
|
|
|
#include "td/telegram/ConfigShared.h"
|
|
|
|
|
|
|
|
#include "td/telegram/td_api.h"
|
|
|
|
|
|
|
|
#include "td/utils/logging.h"
|
|
|
|
#include "td/utils/misc.h"
|
|
|
|
|
|
|
|
namespace td {
|
2018-05-17 21:08:51 +03:00
|
|
|
|
2019-01-17 23:12:31 +03:00
|
|
|
ConfigShared::ConfigShared(std::shared_ptr<KeyValueSyncInterface> config_pmc) : config_pmc_(std::move(config_pmc)) {
|
|
|
|
}
|
|
|
|
|
|
|
|
void ConfigShared::set_callback(unique_ptr<Callback> callback) {
|
|
|
|
callback_ = std::move(callback);
|
|
|
|
if (callback_ == nullptr) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2018-12-31 22:04:05 +03:00
|
|
|
for (auto key_value : config_pmc_->get_all()) {
|
|
|
|
on_option_updated(key_value.first);
|
|
|
|
}
|
|
|
|
}
|
2019-01-17 23:12:31 +03:00
|
|
|
|
2018-12-31 22:04:05 +03:00
|
|
|
void ConfigShared::set_option_boolean(Slice name, bool value) {
|
|
|
|
if (set_option(name, value ? Slice("Btrue") : Slice("Bfalse"))) {
|
|
|
|
on_option_updated(name);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void ConfigShared::set_option_empty(Slice name) {
|
|
|
|
if (set_option(name, Slice())) {
|
|
|
|
on_option_updated(name);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-09-25 00:46:16 +03:00
|
|
|
void ConfigShared::set_option_integer(Slice name, int64 value) {
|
2018-12-31 22:04:05 +03:00
|
|
|
if (set_option(name, PSLICE() << "I" << value)) {
|
|
|
|
on_option_updated(name);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void ConfigShared::set_option_string(Slice name, Slice value) {
|
|
|
|
if (set_option(name, PSLICE() << "S" << value)) {
|
|
|
|
on_option_updated(name);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-03-08 18:01:45 +03:00
|
|
|
bool ConfigShared::have_option(Slice name) const {
|
|
|
|
return config_pmc_->isset(name.str());
|
|
|
|
}
|
|
|
|
|
2018-12-31 22:04:05 +03:00
|
|
|
string ConfigShared::get_option(Slice name) const {
|
|
|
|
return config_pmc_->get(name.str());
|
|
|
|
}
|
|
|
|
|
|
|
|
std::unordered_map<string, string> ConfigShared::get_options() const {
|
|
|
|
return config_pmc_->get_all();
|
|
|
|
}
|
|
|
|
|
2018-05-03 13:18:07 +03:00
|
|
|
bool ConfigShared::get_option_boolean(Slice name, bool default_value) const {
|
2018-12-31 22:04:05 +03:00
|
|
|
auto value = get_option(name);
|
|
|
|
if (value.empty()) {
|
2018-05-03 13:18:07 +03:00
|
|
|
return default_value;
|
2018-12-31 22:04:05 +03:00
|
|
|
}
|
|
|
|
if (value == "Btrue") {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
if (value == "Bfalse") {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
LOG(ERROR) << "Found \"" << value << "\" instead of boolean option";
|
2018-05-03 13:18:07 +03:00
|
|
|
return default_value;
|
2018-12-31 22:04:05 +03:00
|
|
|
}
|
|
|
|
|
2020-09-25 00:46:16 +03:00
|
|
|
int64 ConfigShared::get_option_integer(Slice name, int64 default_value) const {
|
2018-12-31 22:04:05 +03:00
|
|
|
auto str_value = get_option(name);
|
|
|
|
if (str_value.empty()) {
|
|
|
|
return default_value;
|
|
|
|
}
|
|
|
|
if (str_value[0] != 'I') {
|
|
|
|
LOG(ERROR) << "Found \"" << str_value << "\" instead of integer option";
|
|
|
|
return default_value;
|
|
|
|
}
|
2020-09-25 00:46:16 +03:00
|
|
|
return to_integer<int64>(str_value.substr(1));
|
2018-12-31 22:04:05 +03:00
|
|
|
}
|
|
|
|
|
2018-05-17 21:08:51 +03:00
|
|
|
string ConfigShared::get_option_string(Slice name, string default_value) const {
|
|
|
|
auto str_value = get_option(name);
|
|
|
|
if (str_value.empty()) {
|
2018-06-28 02:50:46 +03:00
|
|
|
return default_value;
|
2018-05-17 21:08:51 +03:00
|
|
|
}
|
|
|
|
if (str_value[0] != 'S') {
|
|
|
|
LOG(ERROR) << "Found \"" << str_value << "\" instead of string option";
|
2018-06-28 02:50:46 +03:00
|
|
|
return default_value;
|
2018-05-17 21:08:51 +03:00
|
|
|
}
|
|
|
|
return str_value.substr(1);
|
|
|
|
}
|
|
|
|
|
2018-09-20 20:41:22 +03:00
|
|
|
tl_object_ptr<td_api::OptionValue> ConfigShared::get_option_value(Slice name) const {
|
|
|
|
return get_option_value_object(get_option(name));
|
2018-12-31 22:04:05 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
bool ConfigShared::set_option(Slice name, Slice value) {
|
|
|
|
if (value.empty()) {
|
|
|
|
return config_pmc_->erase(name.str()) != 0;
|
|
|
|
} else {
|
|
|
|
return config_pmc_->set(name.str(), value.str()) != 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
tl_object_ptr<td_api::OptionValue> ConfigShared::get_option_value_object(Slice value) {
|
|
|
|
if (value.empty()) {
|
|
|
|
return make_tl_object<td_api::optionValueEmpty>();
|
|
|
|
}
|
|
|
|
|
|
|
|
switch (value[0]) {
|
|
|
|
case 'B':
|
|
|
|
if (value == "Btrue") {
|
|
|
|
return make_tl_object<td_api::optionValueBoolean>(true);
|
|
|
|
}
|
|
|
|
if (value == "Bfalse") {
|
|
|
|
return make_tl_object<td_api::optionValueBoolean>(false);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 'I':
|
2020-09-25 00:46:16 +03:00
|
|
|
return make_tl_object<td_api::optionValueInteger>(to_integer<int64>(value.substr(1)));
|
2018-12-31 22:04:05 +03:00
|
|
|
case 'S':
|
|
|
|
return make_tl_object<td_api::optionValueString>(value.substr(1).str());
|
|
|
|
}
|
|
|
|
|
|
|
|
return make_tl_object<td_api::optionValueString>(value.str());
|
|
|
|
}
|
|
|
|
|
2018-05-22 14:09:58 +03:00
|
|
|
void ConfigShared::on_option_updated(Slice name) const {
|
2019-01-17 23:12:31 +03:00
|
|
|
if (callback_ != nullptr) {
|
|
|
|
callback_->on_option_updated(name.str(), get_option(name));
|
|
|
|
}
|
2018-12-31 22:04:05 +03:00
|
|
|
}
|
2018-05-17 21:08:51 +03:00
|
|
|
|
2018-12-31 22:04:05 +03:00
|
|
|
} // namespace td
|