mirror of
https://github.com/SChernykh/p2pool.git
synced 2025-01-24 19:25:51 +00:00
P2Pool: normalized peer list IPv4/IPv6 data
This commit is contained in:
parent
390cf0257e
commit
887611c9d8
2 changed files with 26 additions and 9 deletions
|
@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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;
|
||||||
|
|
Loading…
Reference in a new issue