mirror of
https://github.com/SChernykh/p2pool.git
synced 2025-01-24 11:15:57 +00:00
API: added PPLNS window size to pool stats
This commit is contained in:
parent
55e4ea0277
commit
f6a285de87
3 changed files with 27 additions and 5 deletions
|
@ -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
|
||||||
<< "}}";
|
<< "}}";
|
||||||
|
|
|
@ -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();
|
||||||
|
|
|
@ -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(); }
|
||||||
|
|
Loading…
Reference in a new issue