In order to eventually switch to a single JSON library, most of the libjsoncpp usage is dropped in favor of rjson. Unfortunately, one usage still remains: test/utils/test_repl utility heavily depends on the *exact textual* format of its output JSON files, so replacing a library results in all tests failing because of differences in formatting. It is possible to force rjson to print its documents in the exact matching format, but that's left for later, since the issue is not critical. It would be nice though if our test suite compared JSON documents with a real JSON parser, since there are more differences - e.g. libjsoncpp keeps children of the object sorted, while rapidjson uses an unordered data structure. This change should cause no change in semantics, it strives just to replace all usage of libjsoncpp with rjson.
121 lines
3.6 KiB
C++
121 lines
3.6 KiB
C++
/*
|
|
* Copyright (C) 2015 ScyllaDB
|
|
*/
|
|
|
|
/*
|
|
* This file is part of Scylla.
|
|
*
|
|
* Scylla is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU Affero General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* Scylla is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with Scylla. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#pragma once
|
|
#include <seastar/core/sstring.hh>
|
|
#include <boost/lexical_cast.hpp>
|
|
#include "exceptions/exceptions.hh"
|
|
#include "utils/rjson.hh"
|
|
#include "seastarx.hh"
|
|
|
|
class schema;
|
|
|
|
class caching_options {
|
|
// For Origin, the default value for the row is "NONE". However, since our
|
|
// row_cache will cache both keys and rows, we will default to ALL.
|
|
//
|
|
// FIXME: We don't yet make any changes to our caching policies based on
|
|
// this (and maybe we shouldn't)
|
|
static constexpr auto default_key = "ALL";
|
|
static constexpr auto default_row = "ALL";
|
|
|
|
sstring _key_cache;
|
|
sstring _row_cache;
|
|
bool _enabled = true;
|
|
caching_options(sstring k, sstring r, bool enabled)
|
|
: _key_cache(k), _row_cache(r), _enabled(enabled)
|
|
{
|
|
if ((k != "ALL") && (k != "NONE")) {
|
|
throw exceptions::configuration_exception("Invalid key value: " + k);
|
|
}
|
|
|
|
if ((r == "ALL") || (r == "NONE")) {
|
|
return;
|
|
} else {
|
|
try {
|
|
boost::lexical_cast<unsigned long>(r);
|
|
} catch (boost::bad_lexical_cast& e) {
|
|
throw exceptions::configuration_exception("Invalid key value: " + r);
|
|
}
|
|
}
|
|
}
|
|
|
|
friend class schema;
|
|
caching_options() : _key_cache(default_key), _row_cache(default_row) {}
|
|
public:
|
|
|
|
bool enabled() const {
|
|
return _enabled;
|
|
}
|
|
|
|
std::map<sstring, sstring> to_map() const {
|
|
std::map<sstring, sstring> res = {{ "keys", _key_cache },
|
|
{ "rows_per_partition", _row_cache }};
|
|
if (!_enabled) {
|
|
res.insert({"enabled", "false"});
|
|
}
|
|
return res;
|
|
}
|
|
|
|
sstring to_sstring() const {
|
|
return rjson::print(rjson::from_string_map(to_map()));
|
|
}
|
|
|
|
static caching_options get_disabled_caching_options() {
|
|
return caching_options("NONE", "NONE", false);
|
|
}
|
|
|
|
template<typename Map>
|
|
static caching_options from_map(const Map & map) {
|
|
sstring k = default_key;
|
|
sstring r = default_row;
|
|
bool e = true;
|
|
|
|
for (auto& p : map) {
|
|
if (p.first == "keys") {
|
|
k = p.second;
|
|
} else if (p.first == "rows_per_partition") {
|
|
r = p.second;
|
|
} else if (p.first == "enabled") {
|
|
e = p.second == "true";
|
|
} else {
|
|
throw exceptions::configuration_exception(format("Invalid caching option: {}", p.first));
|
|
}
|
|
}
|
|
return caching_options(k, r, e);
|
|
}
|
|
|
|
static caching_options from_sstring(const sstring& str) {
|
|
return from_map(rjson::parse_to_map<std::map<sstring, sstring>>(str));
|
|
}
|
|
|
|
bool operator==(const caching_options& other) const {
|
|
return _key_cache == other._key_cache && _row_cache == other._row_cache
|
|
&& _enabled == other._enabled;
|
|
}
|
|
bool operator!=(const caching_options& other) const {
|
|
return !(*this == other);
|
|
}
|
|
};
|
|
|
|
|
|
|