2021-08-31 08:22:36 -04:00
|
|
|
// Copyright (c) 2021 The Bitcoin Core developers
|
|
|
|
// Distributed under the MIT software license, see the accompanying
|
|
|
|
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
|
|
|
|
|
|
|
#ifndef BITCOIN_NETGROUP_H
|
|
|
|
#define BITCOIN_NETGROUP_H
|
|
|
|
|
2021-09-01 07:12:52 -04:00
|
|
|
#include <netaddress.h>
|
2021-09-01 11:34:23 -04:00
|
|
|
#include <uint256.h>
|
2021-09-01 07:12:52 -04:00
|
|
|
|
2021-08-31 13:40:18 -04:00
|
|
|
#include <vector>
|
|
|
|
|
2021-08-31 08:22:36 -04:00
|
|
|
/**
|
|
|
|
* Netgroup manager
|
|
|
|
*/
|
2021-08-31 13:40:18 -04:00
|
|
|
class NetGroupManager {
|
|
|
|
public:
|
|
|
|
explicit NetGroupManager(std::vector<bool> asmap)
|
|
|
|
: m_asmap{std::move(asmap)}
|
|
|
|
{}
|
|
|
|
|
2021-09-01 11:34:23 -04:00
|
|
|
/** Get a checksum identifying the asmap being used. */
|
|
|
|
uint256 GetAsmapChecksum() const;
|
|
|
|
|
2021-09-01 10:55:32 -04:00
|
|
|
/**
|
|
|
|
* Get the canonical identifier of the network group for address.
|
|
|
|
*
|
|
|
|
* The groups are assigned in a way where it should be costly for an attacker to
|
|
|
|
* obtain addresses with many different group identifiers, even if it is cheap
|
|
|
|
* to obtain addresses with the same identifier.
|
|
|
|
*
|
|
|
|
* @note No two connections will be attempted to addresses with the same network
|
|
|
|
* group.
|
|
|
|
*/
|
2021-09-01 07:12:52 -04:00
|
|
|
std::vector<unsigned char> GetGroup(const CNetAddr& address) const;
|
|
|
|
|
2021-09-01 10:55:32 -04:00
|
|
|
/**
|
|
|
|
* Get the autonomous system on the BGP path to address.
|
|
|
|
*
|
|
|
|
* The ip->AS mapping depends on how asmap is constructed.
|
|
|
|
*/
|
2021-09-01 07:12:52 -04:00
|
|
|
uint32_t GetMappedAS(const CNetAddr& address) const;
|
|
|
|
|
2021-08-31 13:40:18 -04:00
|
|
|
private:
|
|
|
|
/** Compressed IP->ASN mapping, loaded from a file when a node starts.
|
|
|
|
*
|
|
|
|
* This mapping is then used for bucketing nodes in Addrman and for
|
|
|
|
* ensuring we connect to a diverse set of peers in Connman. The map is
|
|
|
|
* empty if no file was provided.
|
|
|
|
*
|
|
|
|
* If asmap is provided, nodes will be bucketed by AS they belong to, in
|
|
|
|
* order to make impossible for a node to connect to several nodes hosted
|
|
|
|
* in a single AS. This is done in response to Erebus attack, but also to
|
|
|
|
* generally diversify the connections every node creates, especially
|
|
|
|
* useful when a large fraction of nodes operate under a couple of cloud
|
|
|
|
* providers.
|
|
|
|
*
|
|
|
|
* If a new asmap is provided, the existing addrman records are
|
|
|
|
* re-bucketed.
|
|
|
|
*
|
|
|
|
* This is initialized in the constructor, const, and therefore is
|
|
|
|
* thread-safe. */
|
|
|
|
const std::vector<bool> m_asmap;
|
|
|
|
};
|
2021-08-31 08:22:36 -04:00
|
|
|
|
|
|
|
#endif // BITCOIN_NETGROUP_H
|