API: added PPLNS window size to pool stats

This commit is contained in:
SChernykh 2023-03-28 13:28:34 +02:00
parent 55e4ea0277
commit f6a285de87
3 changed files with 27 additions and 5 deletions

View file

@ -1251,9 +1251,13 @@ void p2pool::api_update_pool_stats()
return; return;
} }
const PoolBlock* tip = m_sideChain->chainTip();
const uint64_t bottom_height = m_sideChain->bottom_height(tip);
const uint64_t pplns_window_size = (tip && bottom_height) ? (tip->m_sidechainHeight - bottom_height + 1U) : m_sideChain->chain_window_size();
uint64_t t; uint64_t t;
const difficulty_type diff = m_sideChain->difficulty(); const difficulty_type diff = m_sideChain->difficulty();
const uint64_t height = m_sideChain->chainTip() ? m_sideChain->chainTip()->m_sidechainHeight : 0; const uint64_t height = tip ? tip->m_sidechainHeight : 0;
const uint64_t hashrate = udiv128(diff.hi, diff.lo, m_sideChain->block_time(), &t); const uint64_t hashrate = udiv128(diff.hi, diff.lo, m_sideChain->block_time(), &t);
const uint64_t miners = std::max<uint64_t>(m_sideChain->miner_count(), m_p2pServer ? m_p2pServer->peer_list_size() : 0U); const uint64_t miners = std::max<uint64_t>(m_sideChain->miner_count(), m_p2pServer ? m_p2pServer->peer_list_size() : 0U);
const difficulty_type total_hashes = m_sideChain->total_hashes(); const difficulty_type total_hashes = m_sideChain->total_hashes();
@ -1275,7 +1279,7 @@ void p2pool::api_update_pool_stats()
} }
m_api->set(p2pool_api::Category::POOL, "stats", m_api->set(p2pool_api::Category::POOL, "stats",
[hashrate, miners, &total_hashes, last_block_found_time, last_block_found_height, total_blocks_found, &pplns_weight, diff, height](log::Stream& s) [hashrate, miners, &total_hashes, last_block_found_time, last_block_found_height, total_blocks_found, &pplns_weight, pplns_window_size, diff, height](log::Stream& s)
{ {
s << "{\"pool_list\":[\"pplns\"],\"pool_statistics\":{\"hashRate\":" << hashrate s << "{\"pool_list\":[\"pplns\"],\"pool_statistics\":{\"hashRate\":" << hashrate
<< ",\"miners\":" << miners << ",\"miners\":" << miners
@ -1284,6 +1288,7 @@ void p2pool::api_update_pool_stats()
<< ",\"lastBlockFound\":" << last_block_found_height << ",\"lastBlockFound\":" << last_block_found_height
<< ",\"totalBlocksFound\":" << total_blocks_found << ",\"totalBlocksFound\":" << total_blocks_found
<< ",\"pplnsWeight\":" << pplns_weight << ",\"pplnsWeight\":" << pplns_weight
<< ",\"pplnsWindowSize\":" << pplns_window_size
<< ",\"sidechainDifficulty\":" << diff << ",\"sidechainDifficulty\":" << diff
<< ",\"sidechainHeight\":" << height << ",\"sidechainHeight\":" << height
<< "}}"; << "}}";

View file

@ -869,12 +869,12 @@ void SideChain::print_status(bool obtain_sidechain_lock) const
const PoolBlock* tip = m_chainTip; const PoolBlock* tip = m_chainTip;
std::vector<MinerShare> shares; std::vector<MinerShare> shares;
uint64_t bottom_height = 0; uint64_t bh = 0;
if (tip) { if (tip) {
get_shares(tip, shares, &bottom_height, true); get_shares(tip, shares, &bh, true);
} }
const uint64_t window_size = (tip && bottom_height) ? (tip->m_sidechainHeight - bottom_height + 1U) : m_chainWindowSize; const uint64_t window_size = (tip && bh) ? (tip->m_sidechainHeight - bh + 1U) : m_chainWindowSize;
uint64_t block_depth = 0; uint64_t block_depth = 0;
const PoolBlock* cur = tip; const PoolBlock* cur = tip;
@ -1113,6 +1113,22 @@ bool SideChain::is_mini() const
return (memcmp(m_consensusId.data(), mini_consensus_id, HASH_SIZE) == 0); return (memcmp(m_consensusId.data(), mini_consensus_id, HASH_SIZE) == 0);
} }
uint64_t SideChain::bottom_height(const PoolBlock* tip) const
{
if (!tip) {
return 0;
}
uint64_t bottom_height;
std::vector<MinerShare> shares;
if (!get_shares(tip, shares, &bottom_height, true)) {
return 0;
}
return bottom_height;
}
bool SideChain::split_reward(uint64_t reward, const std::vector<MinerShare>& shares, std::vector<uint64_t>& rewards) bool SideChain::split_reward(uint64_t reward, const std::vector<MinerShare>& shares, std::vector<uint64_t>& rewards)
{ {
const size_t num_shares = shares.size(); const size_t num_shares = shares.size();

View file

@ -75,6 +75,7 @@ public:
uint64_t last_updated() const; uint64_t last_updated() const;
bool is_default() const; bool is_default() const;
bool is_mini() const; bool is_mini() const;
uint64_t bottom_height(const PoolBlock* tip) const;
const PoolBlock* chainTip() const { return m_chainTip; } const PoolBlock* chainTip() const { return m_chainTip; }
bool precalcFinished() const { return m_precalcFinished.load(); } bool precalcFinished() const { return m_precalcFinished.load(); }