P2Pool: normalized peer list IPv4/IPv6 data

This commit is contained in:
SChernykh 2023-09-09 20:22:43 +02:00
parent 390cf0257e
commit 887611c9d8
2 changed files with 26 additions and 9 deletions

View file

@ -595,10 +595,11 @@ void P2PServer::load_peer_list()
return; return;
} }
p.m_isV6 = is_v6; p.m_isV6 = is_v6;
p.normalize();
bool already_added = false; bool already_added = false;
for (const Peer& peer : m_peerList) { for (const Peer& peer : m_peerList) {
if ((peer.m_isV6 == p.m_isV6) && (peer.m_addr == p.m_addr)) { if (peer.m_addr == p.m_addr) {
already_added = true; already_added = true;
break; break;
} }
@ -700,10 +701,13 @@ void P2PServer::update_peer_in_list(bool is_v6, const raw_ip& ip, int port)
{ {
const uint64_t cur_time = seconds_since_epoch(); const uint64_t cur_time = seconds_since_epoch();
Peer peer{ is_v6, ip, port, 0, cur_time };
peer.normalize();
MutexLock lock(m_peerListLock); MutexLock lock(m_peerListLock);
for (Peer& p : m_peerList) { for (Peer& p : m_peerList) {
if ((p.m_isV6 == is_v6) && (p.m_addr == ip)) { if (p.m_addr == peer.m_addr) {
p.m_port = port; p.m_port = port;
p.m_numFailedConnections = 0; p.m_numFailedConnections = 0;
p.m_lastSeen = cur_time; p.m_lastSeen = cur_time;
@ -711,8 +715,8 @@ void P2PServer::update_peer_in_list(bool is_v6, const raw_ip& ip, int port)
} }
} }
if (!is_banned(is_v6, ip)) { if (!is_banned(peer.m_isV6, peer.m_addr)) {
m_peerList.emplace_back(Peer{ is_v6, ip, port, 0, cur_time }); m_peerList.push_back(peer);
} }
} }
@ -742,6 +746,17 @@ void P2PServer::remove_peer_from_list(const raw_ip& ip)
} }
} }
void P2PServer::Peer::normalize()
{
if (m_isV6 && m_addr.is_ipv4_prefix()) {
m_isV6 = false;
}
else if (!m_isV6) {
// Fill in default bytes for IPv4 addresses
memcpy(m_addr.data, raw_ip::ipv4_prefix, sizeof(raw_ip::ipv4_prefix));
}
}
void P2PServer::broadcast(const PoolBlock& block, const PoolBlock* parent) void P2PServer::broadcast(const PoolBlock& block, const PoolBlock* parent)
{ {
MinerData miner_data = m_pool->miner_data(); MinerData miner_data = m_pool->miner_data();
@ -2346,14 +2361,12 @@ void P2PServer::P2PClient::on_peer_list_response(const uint8_t* buf)
} }
// Fill in default bytes for IPv4 addresses // Fill in default bytes for IPv4 addresses
memset(ip.data, 0, 10); memcpy(ip.data, raw_ip::ipv4_prefix, sizeof(raw_ip::ipv4_prefix));
ip.data[10] = 0xFF;
ip.data[11] = 0xFF;
} }
bool already_added = false; bool already_added = false;
for (Peer& p : server->m_peerList) { for (Peer& p : server->m_peerList) {
if ((p.m_isV6 == is_v6) && (p.m_addr == ip)) { if (p.m_addr == ip) {
already_added = true; already_added = true;
p.m_lastSeen = cur_time; p.m_lastSeen = cur_time;
break; break;
@ -2361,7 +2374,9 @@ void P2PServer::P2PClient::on_peer_list_response(const uint8_t* buf)
} }
if (!already_added && !server->is_banned(is_v6, ip)) { if (!already_added && !server->is_banned(is_v6, ip)) {
server->m_peerList.emplace_back(Peer{ is_v6, ip, port, 0, cur_time }); Peer p{ is_v6, ip, port, 0, cur_time };
p.normalize();
server->m_peerList.push_back(p);
} }
} }
} }

View file

@ -226,6 +226,8 @@ private:
struct Peer struct Peer
{ {
void normalize();
bool m_isV6; bool m_isV6;
raw_ip m_addr; raw_ip m_addr;
int m_port; int m_port;