diff options
author | MarcoFalke <falke.marco@gmail.com> | 2021-08-21 13:49:16 +0200 |
---|---|---|
committer | MarcoFalke <falke.marco@gmail.com> | 2021-09-09 09:11:41 +0200 |
commit | fa5aeec80c6cdca9ca027d80dff3b397911ff2c2 (patch) | |
tree | ebf8556dc2ff667bf3929c1f2bc3a72b447fe77a /src/addrdb.cpp | |
parent | e4aa9b15b9f80a08076ad329b473fe9107d9e65e (diff) |
Move LoadAddrman from init to addrdb
Init should only concern itself with the initialization order, not the
detailed initialization logic of every module.
Also, inlining logic into a method that is ~800 lines of code, makes it
impossible to unit test on its own.
Diffstat (limited to 'src/addrdb.cpp')
-rw-r--r-- | src/addrdb.cpp | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/src/addrdb.cpp b/src/addrdb.cpp index 856f318961..fd85e717e3 100644 --- a/src/addrdb.cpp +++ b/src/addrdb.cpp @@ -18,6 +18,7 @@ #include <univalue.h> #include <util/settings.h> #include <util/system.h> +#include <util/translation.h> namespace { template <typename Stream, typename Data> @@ -187,6 +188,23 @@ bool ReadFromStream(CAddrMan& addr, CDataStream& ssPeers) return DeserializeDB(ssPeers, addr, false); } +std::optional<bilingual_str> LoadAddrman(const std::vector<bool>& asmap, const ArgsManager& args, std::unique_ptr<CAddrMan>& addrman) +{ + auto check_addrman = std::clamp<int32_t>(args.GetArg("-checkaddrman", DEFAULT_ADDRMAN_CONSISTENCY_CHECKS), 0, 1000000); + addrman = std::make_unique<CAddrMan>(asmap, /* deterministic */ false, /* consistency_check_ratio */ check_addrman); + + int64_t nStart = GetTimeMillis(); + if (ReadPeerAddresses(args, *addrman)) { + LogPrintf("Loaded %i addresses from peers.dat %dms\n", addrman->size(), GetTimeMillis() - nStart); + } else { + // Addrman can be in an inconsistent state after failure, reset it + addrman = std::make_unique<CAddrMan>(asmap, /* deterministic */ false, /* consistency_check_ratio */ check_addrman); + LogPrintf("Recreating peers.dat\n"); + DumpPeerAddresses(args, *addrman); + } + return std::nullopt; +} + void DumpAnchors(const fs::path& anchors_db_path, const std::vector<CAddress>& anchors) { LOG_TIME_SECONDS(strprintf("Flush %d outbound block-relay-only peer addresses to anchors.dat", anchors.size())); |