lokinet/llarp/config/config.hpp

320 lines
8.6 KiB
C++
Raw Normal View History

#pragma once
#include "definition.hpp"
#include "ini.hpp"
#include <llarp/bootstrap.hpp>
#include <llarp/constants/files.hpp>
#include <llarp/crypto/types.hpp>
#include <llarp/dns/srv_data.hpp>
#include <llarp/net/ip_address.hpp>
#include <llarp/net/ip_range_map.hpp>
#include <llarp/net/net.hpp>
#include <llarp/net/net_int.hpp>
#include <llarp/net/traffic_policy.hpp>
#include <llarp/router_contact.hpp>
#include <llarp/service/address.hpp>
#include <llarp/service/auth.hpp>
#include <llarp/util/fs.hpp>
#include <llarp/util/logging.hpp>
#include <llarp/util/str.hpp>
2023-10-19 21:59:57 +00:00
#include <oxenmq/address.h>
2023-10-19 21:59:57 +00:00
#include <chrono>
#include <cstdlib>
#include <functional>
#include <optional>
#include <string>
#include <unordered_set>
#include <utility>
#include <vector>
namespace llarp
{
2023-11-03 13:40:14 +00:00
using SectionValues = llarp::ConfigParser::SectionValues;
using ConfigMap = llarp::ConfigParser::ConfigMap;
2019-07-06 13:46:21 +00:00
inline static constexpr uint16_t DEFAULT_LISTEN_PORT{1090};
2020-03-31 15:25:29 +00:00
// TODO: don't use these maps. they're sloppy and difficult to follow
/// Small struct to gather all parameters needed for config generation to reduce the number of
/// parameters that need to be passed around.
struct ConfigGenParameters
{
ConfigGenParameters() = default;
virtual ~ConfigGenParameters() = default;
ConfigGenParameters(const ConfigGenParameters&) = delete;
ConfigGenParameters(ConfigGenParameters&&) = delete;
2023-11-03 13:40:14 +00:00
bool is_relay = false;
fs::path default_data_dir;
/// get network platform (virtual for unit test mocks)
virtual const llarp::net::Platform*
Net_ptr() const = 0;
};
struct RouterConfig
{
2023-11-03 13:40:14 +00:00
size_t min_connected_routers = 0;
size_t max_connected_routers = 0;
2023-11-03 13:40:14 +00:00
std::string net_id;
2023-11-03 13:40:14 +00:00
fs::path data_dir;
2019-07-01 23:55:02 +00:00
2023-11-03 13:40:14 +00:00
bool block_bogons = false;
2019-08-26 23:29:17 +00:00
2023-11-03 13:40:14 +00:00
int worker_threads = -1;
int net_threads = -1;
2023-11-03 13:40:14 +00:00
size_t job_que_size = 0;
2019-11-25 21:30:34 +00:00
2023-11-03 13:40:14 +00:00
std::string rc_file;
std::string enckey_file;
std::string idkey_file;
std::string transkey_file;
2023-11-03 13:40:14 +00:00
bool is_relay = false;
/// deprecated
2023-11-03 13:40:14 +00:00
std::optional<net::ipaddr_t> public_ip;
/// deprecated
2023-11-03 13:40:14 +00:00
std::optional<net::port_t> public_port;
2020-05-26 17:03:21 +00:00
void
2023-11-03 13:40:14 +00:00
define_config_options(ConfigDefinition& conf, const ConfigGenParameters& params);
};
/// config for path hop selection
struct PeerSelectionConfig
{
/// in our hops what netmask will we use for unique ips for hops
/// i.e. 32 for every hop unique ip, 24 unique /24 per hop, etc
///
2023-11-03 13:40:14 +00:00
int unique_hop_netmask;
/// set of countrys to exclude from path building (2 char country code)
2023-11-03 13:40:14 +00:00
std::unordered_set<std::string> exclude_countries;
void
2023-11-03 13:40:14 +00:00
define_config_options(ConfigDefinition& conf, const ConfigGenParameters& params);
/// return true if this set of router contacts is acceptable against this config
bool
2023-11-03 13:40:14 +00:00
check_rcs(const std::set<RemoteRC>& hops) const;
};
struct NetworkConfig
{
2023-11-03 13:40:14 +00:00
std::optional<bool> enable_profiling;
bool save_profiles;
std::set<RouterID> strict_connect;
std::string if_name;
IPRange if_addr;
2023-11-03 13:40:14 +00:00
std::optional<fs::path> keyfile;
std::string endpoint_type;
bool is_reachable = false;
std::optional<int> hops;
std::optional<int> paths;
bool allow_exit = false;
std::set<RouterID> snode_blacklist;
net::IPRangeMap<service::Address> exit_map;
net::IPRangeMap<std::string> ons_exit_map;
2023-11-03 13:40:14 +00:00
std::unordered_map<service::Address, service::AuthInfo> exit_auths;
std::unordered_map<std::string, service::AuthInfo> ons_exit_auths;
2023-11-03 13:40:14 +00:00
std::unordered_map<huint128_t, service::Address> map_addrs;
2023-11-03 13:40:14 +00:00
service::AuthType auth_type = service::AuthType::NONE;
service::AuthFileType auth_file_type = service::AuthFileType::HASHES;
std::optional<std::string> auth_url;
std::optional<std::string> auth_method;
std::unordered_set<service::Address> auth_whitelist;
std::unordered_set<std::string> auth_static_tokens;
std::set<fs::path> auth_files;
2020-06-02 21:10:42 +00:00
2023-11-03 13:40:14 +00:00
std::vector<llarp::dns::SRVData> srv_records;
2023-11-03 13:40:14 +00:00
std::optional<huint128_t> base_ipv6_addr;
2023-11-03 13:40:14 +00:00
std::set<IPRange> owned_ranges;
std::optional<net::TrafficPolicy> traffic_policy;
2021-04-14 15:07:06 +00:00
2023-11-03 13:40:14 +00:00
std::optional<llarp_time_t> path_alignment_timeout;
2023-11-03 13:40:14 +00:00
std::optional<fs::path> addr_map_persist_file;
2023-11-03 13:40:14 +00:00
bool enable_route_poker;
bool blackhole_routes;
void
2023-11-03 13:40:14 +00:00
define_config_options(ConfigDefinition& conf, const ConfigGenParameters& params);
};
struct DnsConfig
{
2023-11-03 13:40:14 +00:00
bool raw;
std::vector<SockAddr> bind_addr;
std::vector<SockAddr> upstream_dns;
std::vector<fs::path> hostfiles;
std::optional<SockAddr> query_bind;
2023-11-03 13:40:14 +00:00
std::unordered_multimap<std::string, std::string> extra_opts;
void
2023-11-03 13:40:14 +00:00
define_config_options(ConfigDefinition& conf, const ConfigGenParameters& params);
};
struct LinksConfig
{
2023-11-03 13:40:14 +00:00
std::optional<net::ipaddr_t> public_addr;
std::optional<net::port_t> public_port;
std::optional<oxen::quic::Address> addr;
bool using_new_api = false;
void
2023-11-03 13:40:14 +00:00
define_config_options(ConfigDefinition& conf, const ConfigGenParameters& params);
};
struct ConnectConfig
{
std::vector<fs::path> routers;
void
2023-11-03 13:40:14 +00:00
define_config_options(ConfigDefinition& conf, const ConfigGenParameters& params);
};
2023-10-23 22:58:58 +00:00
// TODO: remove oxenmq from this header
struct ApiConfig
{
2023-11-03 13:40:14 +00:00
bool enable_rpc_server = false;
std::vector<oxenmq::address> rpc_bind_addrs;
void
2023-11-03 13:40:14 +00:00
define_config_options(ConfigDefinition& conf, const ConfigGenParameters& params);
};
struct LokidConfig
{
2023-11-03 13:40:14 +00:00
fs::path id_keyfile;
oxenmq::address rpc_addr;
void
2023-11-03 13:40:14 +00:00
define_config_options(ConfigDefinition& conf, const ConfigGenParameters& params);
};
struct BootstrapConfig
{
std::vector<fs::path> files;
BootstrapList routers;
bool seednode;
2023-11-03 13:40:14 +00:00
void
2023-11-03 13:40:14 +00:00
define_config_options(ConfigDefinition& conf, const ConfigGenParameters& params);
};
struct LoggingConfig
{
2023-11-03 13:40:14 +00:00
log::Type type = log::Type::Print;
log::Level level = log::Level::off;
std::string file;
2020-03-30 16:25:02 +00:00
void
2023-11-03 13:40:14 +00:00
define_config_options(ConfigDefinition& conf, const ConfigGenParameters& params);
2020-03-30 16:25:02 +00:00
};
struct Config
{
explicit Config(std::optional<fs::path> datadir = std::nullopt);
virtual ~Config() = default;
/// create generation params (virtual for unit test mock)
virtual std::unique_ptr<ConfigGenParameters>
2023-11-03 13:40:14 +00:00
make_gen_params() const;
RouterConfig router;
NetworkConfig network;
PeerSelectionConfig paths;
ConnectConfig connect;
DnsConfig dns;
2019-08-07 16:33:29 +00:00
LinksConfig links;
ApiConfig api;
LokidConfig lokid;
BootstrapConfig bootstrap;
LoggingConfig logging;
// Initialize config definition
void
2023-11-03 13:40:14 +00:00
init_config(ConfigDefinition& conf, const ConfigGenParameters& params);
/// Insert config entries for backwards-compatibility (e.g. so that the config system will
/// tolerate old values that are no longer accepted)
///
/// @param conf is the config to modify
void
2023-11-03 13:40:14 +00:00
add_backcompat_opts(ConfigDefinition& conf);
// Load a config from the given file if the config file is not provided LoadDefault is called
bool
2023-11-03 13:40:14 +00:00
load(std::optional<fs::path> fname = std::nullopt, bool isRelay = false);
// Load a config from a string of ini, same effects as Config::Load
bool
2023-11-03 13:40:14 +00:00
load_string(std::string_view ini, bool isRelay = false);
std::string
2023-11-03 13:40:14 +00:00
generate_client_config_base();
std::string
2023-11-03 13:40:14 +00:00
generate_router_config_base();
void
2023-11-03 13:40:14 +00:00
save();
void
2023-11-03 13:40:14 +00:00
override(std::string section, std::string key, std::string value);
2019-07-06 13:46:21 +00:00
void
2023-11-03 13:40:14 +00:00
add_default(std::string section, std::string key, std::string value);
2021-04-01 11:13:39 +00:00
/// create a config with the default parameters for an embedded lokinet
static std::shared_ptr<Config>
2023-11-03 13:40:14 +00:00
make_embedded_config();
2021-04-01 11:13:39 +00:00
private:
/// Load (initialize) a default config.
///
/// This delegates to the ConfigDefinition to generate a default config,
/// as though an empty config were specified.
///
/// If using Config without the intention of loading from file (or string), this is necessary
/// in order to obtain sane defaults.
///
/// @param isRelay determines whether the config will reflect that of a relay or client
/// @param dataDir is a path representing a directory to be used as the data dir
/// @return true on success, false otherwise
bool
2023-11-03 13:40:14 +00:00
load_default_config(bool isRelay);
2020-08-27 12:43:53 +00:00
2022-06-27 17:14:03 +00:00
bool
2023-11-03 13:40:14 +00:00
load_config_data(
2022-06-27 17:14:03 +00:00
std::string_view ini, std::optional<fs::path> fname = std::nullopt, bool isRelay = false);
2020-08-27 12:43:53 +00:00
void
2023-11-03 13:40:14 +00:00
load_overrides(ConfigDefinition& conf) const;
2020-08-27 12:43:53 +00:00
2023-11-03 13:40:14 +00:00
std::vector<std::array<std::string, 3>> additional;
ConfigParser parser;
const fs::path data_dir;
};
void
2023-11-03 13:40:14 +00:00
ensure_config(fs::path dataDir, fs::path confFile, bool overwrite, bool asRouter);
} // namespace llarp