mirror of
https://github.com/SChernykh/p2pool.git
synced 2025-01-08 19:59:30 +00:00
P2PServer: request blocks coming from BLOCK_NOTIFY
This commit is contained in:
parent
8d9f16c387
commit
2f5b0db786
2 changed files with 37 additions and 0 deletions
|
@ -1044,6 +1044,11 @@ int P2PServer::deserialize_block(const uint8_t* buf, uint32_t size, bool compact
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const PoolBlock* P2PServer::find_block(const hash& id) const
|
||||||
|
{
|
||||||
|
return m_pool->side_chain().find_block(id);
|
||||||
|
}
|
||||||
|
|
||||||
void P2PServer::on_timer()
|
void P2PServer::on_timer()
|
||||||
{
|
{
|
||||||
if (m_pool->stopped()) {
|
if (m_pool->stopped()) {
|
||||||
|
@ -2308,6 +2313,36 @@ void P2PServer::P2PClient::on_block_notify(const uint8_t* buf)
|
||||||
memcpy(id.h, buf, HASH_SIZE);
|
memcpy(id.h, buf, HASH_SIZE);
|
||||||
|
|
||||||
m_broadcastedHashes[m_broadcastedHashesIndex++ % array_size(&P2PClient::m_broadcastedHashes)] = id;
|
m_broadcastedHashes[m_broadcastedHashesIndex++ % array_size(&P2PClient::m_broadcastedHashes)] = id;
|
||||||
|
|
||||||
|
P2PServer* server = static_cast<P2PServer*>(m_owner);
|
||||||
|
|
||||||
|
// If we don't know about this block, request it from this peer. The peer can do it to speed up our initial sync, for example.
|
||||||
|
if (!server->find_block(id)) {
|
||||||
|
LOGINFO(5, "Received an unknown block " << id << " in BLOCK_NOTIFY");
|
||||||
|
|
||||||
|
const bool result = server->send(this,
|
||||||
|
[&id, this](uint8_t* buf, size_t buf_size) -> size_t
|
||||||
|
{
|
||||||
|
LOGINFO(5, "sending BLOCK_REQUEST for id = " << id << " to " << static_cast<char*>(m_addrString));
|
||||||
|
|
||||||
|
if (buf_size < 1 + HASH_SIZE) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
uint8_t* p = buf;
|
||||||
|
|
||||||
|
*(p++) = static_cast<uint8_t>(MessageId::BLOCK_REQUEST);
|
||||||
|
|
||||||
|
memcpy(p, id.h, HASH_SIZE);
|
||||||
|
p += HASH_SIZE;
|
||||||
|
|
||||||
|
return p - buf;
|
||||||
|
});
|
||||||
|
|
||||||
|
if (result) {
|
||||||
|
m_blockPendingRequests.push_back(id);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool P2PServer::P2PClient::handle_incoming_block_async(const PoolBlock* block, uint64_t max_time_delta)
|
bool P2PServer::P2PClient::handle_incoming_block_async(const PoolBlock* block, uint64_t max_time_delta)
|
||||||
|
|
|
@ -175,6 +175,8 @@ public:
|
||||||
int deserialize_block(const uint8_t* buf, uint32_t size, bool compact, uint64_t received_timestamp);
|
int deserialize_block(const uint8_t* buf, uint32_t size, bool compact, uint64_t received_timestamp);
|
||||||
const PoolBlock* get_block() const { return m_block; }
|
const PoolBlock* get_block() const { return m_block; }
|
||||||
|
|
||||||
|
const PoolBlock* find_block(const hash& id) const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
const char* get_category() const override { return "P2PServer "; }
|
const char* get_category() const override { return "P2PServer "; }
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue