mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-02-04 10:07:27 -05:00
00e9b97f37
The fs.* files are already part of the libbitcoin_util library. With the introduction of the fs_helpers.* it makes sense to move fs.* into the util/ directory as well.
60 lines
1.8 KiB
C++
60 lines
1.8 KiB
C++
// Copyright (c) 2017-2022 The Bitcoin Core developers
|
|
// Distributed under the MIT software license, see the accompanying
|
|
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
|
|
|
#ifndef BITCOIN_RPC_BLOCKCHAIN_H
|
|
#define BITCOIN_RPC_BLOCKCHAIN_H
|
|
|
|
#include <consensus/amount.h>
|
|
#include <core_io.h>
|
|
#include <streams.h>
|
|
#include <sync.h>
|
|
#include <util/fs.h>
|
|
#include <validation.h>
|
|
|
|
#include <any>
|
|
#include <stdint.h>
|
|
#include <vector>
|
|
|
|
class CBlock;
|
|
class CBlockIndex;
|
|
class Chainstate;
|
|
class UniValue;
|
|
namespace node {
|
|
struct NodeContext;
|
|
} // namespace node
|
|
|
|
static constexpr int NUM_GETBLOCKSTATS_PERCENTILES = 5;
|
|
|
|
/**
|
|
* Get the difficulty of the net wrt to the given block index.
|
|
*
|
|
* @return A floating point number that is a multiple of the main net minimum
|
|
* difficulty (4295032833 hashes).
|
|
*/
|
|
double GetDifficulty(const CBlockIndex* blockindex);
|
|
|
|
/** Callback for when block tip changed. */
|
|
void RPCNotifyBlockChange(const CBlockIndex*);
|
|
|
|
/** Block description to JSON */
|
|
UniValue blockToJSON(node::BlockManager& blockman, const CBlock& block, const CBlockIndex* tip, const CBlockIndex* blockindex, TxVerbosity verbosity) LOCKS_EXCLUDED(cs_main);
|
|
|
|
/** Block header to JSON */
|
|
UniValue blockheaderToJSON(const CBlockIndex* tip, const CBlockIndex* blockindex) LOCKS_EXCLUDED(cs_main);
|
|
|
|
/** Used by getblockstats to get feerates at different percentiles by weight */
|
|
void CalculatePercentilesByWeight(CAmount result[NUM_GETBLOCKSTATS_PERCENTILES], std::vector<std::pair<CAmount, int64_t>>& scores, int64_t total_weight);
|
|
|
|
/**
|
|
* Helper to create UTXO snapshots given a chainstate and a file handle.
|
|
* @return a UniValue map containing metadata about the snapshot.
|
|
*/
|
|
UniValue CreateUTXOSnapshot(
|
|
node::NodeContext& node,
|
|
Chainstate& chainstate,
|
|
AutoFile& afile,
|
|
const fs::path& path,
|
|
const fs::path& tmppath);
|
|
|
|
#endif // BITCOIN_RPC_BLOCKCHAIN_H
|