mirror of
https://github.com/dashpay/dash.git
synced 2024-12-29 05:49:11 +01:00
fc930dc0f4
3dc27a15242a22b5301904375e5880372e9b7f4d doc: Add internal interface conventions to developer notes (Russell Yanofsky) 1dca9dc4c772fa0a4ec52c4d88b7cd3d243aea7b refactor: Change createWallet, fillPSBT argument order (Russell Yanofsky) 96dfe5ced64979e51649d20555aa182defc80119 refactor: Change Chain::broadcastTransaction param order (Russell Yanofsky) 6ceb21909ce66b7b4762a855889acd46bb6b77f3 refactor: Rename Chain::Notifications methods to be consistent with other interfaces methods (Russell Yanofsky) 1c2ab1a6d29f2c6c065dae4f4a4e2ad1286311b3 refactor: Rename Node::disconnect methods (Russell Yanofsky) 77e4b0657298c715c835d8d2eb11e173852e6815 refactor: Get rid of Wallet::IsWalletFlagSet method (Russell Yanofsky) Pull request description: This PR is part of the [process separation project](https://github.com/bitcoin/bitcoin/projects/10). This PR doesn't change behavior at all, it just cleans up code in [`src/interfaces`](https://github.com/bitcoin/bitcoin/tree/master/src/interfaces) to simplify #10102, and [documents](https://github.com/ryanofsky/bitcoin/blob/pr/ipc-conv/doc/developer-notes.md#internal-interface-guidelines) coding conventions there better ACKs for top commit: hebasto: re-ACK 3dc27a15242a22b5301904375e5880372e9b7f4d, the only change since the [previous](https://github.com/bitcoin/bitcoin/pull/18278#pullrequestreview-372582146) review is rebasing. MarcoFalke: ACK 3dc27a15242a22b5301904375e5880372e9b7f4d 🕍 Tree-SHA512: 62e6a0f2488e3924e559d2074ed460b92e7a0a5d98eab492221cb20d59d04bbe32aef2a8aeba5e4ea9168cfa91acd5bc973dce6677be0180bd7a919354df53ed
378 lines
12 KiB
C++
378 lines
12 KiB
C++
// Copyright (c) 2018 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_INTERFACES_NODE_H
|
|
#define BITCOIN_INTERFACES_NODE_H
|
|
|
|
#include <amount.h> // For CAmount
|
|
#include <net.h> // For CConnman::NumConnections
|
|
#include <net_types.h> // For banmap_t
|
|
#include <netaddress.h> // For Network
|
|
#include <support/allocators/secure.h> // For SecureString
|
|
#include <uint256.h>
|
|
|
|
#include <functional>
|
|
#include <memory>
|
|
#include <stddef.h>
|
|
#include <stdint.h>
|
|
#include <string>
|
|
#include <tuple>
|
|
#include <vector>
|
|
|
|
class BanMan;
|
|
class CCoinControl;
|
|
class CDeterministicMNList;
|
|
class CFeeRate;
|
|
class CGovernanceObject;
|
|
class CNodeStats;
|
|
class Coin;
|
|
class RPCTimerInterface;
|
|
class UniValue;
|
|
class proxyType;
|
|
struct bilingual_str;
|
|
enum class SynchronizationState;
|
|
struct CNodeStateStats;
|
|
struct NodeContext;
|
|
|
|
namespace interfaces {
|
|
class Handler;
|
|
class WalletClient;
|
|
struct BlockTip;
|
|
|
|
//! Interface for the src/evo part of a dash node (dashd process).
|
|
class EVO
|
|
{
|
|
public:
|
|
virtual ~EVO() {}
|
|
virtual CDeterministicMNList getListAtChainTip() = 0;
|
|
};
|
|
|
|
//! Interface for the src/governance part of a dash node (dashd process).
|
|
class GOV
|
|
{
|
|
public:
|
|
virtual ~GOV() {}
|
|
virtual void getAllNewerThan(std::vector<CGovernanceObject> &objs, int64_t nMoreThanTime) = 0;
|
|
};
|
|
|
|
//! Interface for the src/llmq part of a dash node (dashd process).
|
|
class LLMQ
|
|
{
|
|
public:
|
|
virtual ~LLMQ() {}
|
|
virtual size_t getInstantSentLockCount() = 0;
|
|
};
|
|
|
|
//! Interface for the src/masternode part of a dash node (dashd process).
|
|
namespace Masternode
|
|
{
|
|
class Sync
|
|
{
|
|
public:
|
|
virtual ~Sync() {}
|
|
virtual bool isBlockchainSynced() = 0;
|
|
virtual bool isSynced() = 0;
|
|
virtual std::string getSyncStatus() = 0;
|
|
};
|
|
}
|
|
|
|
namespace CoinJoin {
|
|
//! Interface for the global coinjoin options in src/coinjoin
|
|
class Options
|
|
{
|
|
public:
|
|
virtual int getRounds() = 0;
|
|
virtual int getAmount() = 0;
|
|
|
|
virtual void setEnabled(bool fEnabled) = 0;
|
|
virtual void setMultiSessionEnabled(bool fEnabled) = 0;
|
|
virtual void setRounds(int nRounds) = 0;
|
|
virtual void setAmount(CAmount amount) = 0;
|
|
|
|
virtual bool isMultiSessionEnabled() = 0;
|
|
virtual bool isEnabled() = 0;
|
|
// Static helpers
|
|
virtual bool isCollateralAmount(CAmount nAmount) = 0;
|
|
virtual CAmount getMinCollateralAmount() = 0;
|
|
virtual CAmount getMaxCollateralAmount() = 0;
|
|
virtual CAmount getSmallestDenomination() = 0;
|
|
virtual bool isDenominated(CAmount nAmount) = 0;
|
|
virtual std::array<CAmount, 5> getStandardDenominations() = 0;
|
|
};
|
|
}
|
|
|
|
//! Block and header tip information
|
|
struct BlockAndHeaderTipInfo
|
|
{
|
|
int block_height;
|
|
int64_t block_time;
|
|
uint256 block_hash;
|
|
int header_height;
|
|
int64_t header_time;
|
|
double verification_progress;
|
|
};
|
|
|
|
//! Top-level interface for a dash node (dashd process).
|
|
class Node
|
|
{
|
|
public:
|
|
virtual ~Node() {}
|
|
|
|
//! Send init error.
|
|
virtual void initError(const bilingual_str& message) = 0;
|
|
|
|
//! Set command line arguments.
|
|
virtual bool parseParameters(int argc, const char* const argv[], std::string& error) = 0;
|
|
|
|
//! Set a command line argument
|
|
virtual void forceSetArg(const std::string& arg, const std::string& value) = 0;
|
|
|
|
//! Set a command line argument if it doesn't already have a value
|
|
virtual bool softSetArg(const std::string& arg, const std::string& value) = 0;
|
|
|
|
//! Set a command line boolean argument if it doesn't already have a value
|
|
virtual bool softSetBoolArg(const std::string& arg, bool value) = 0;
|
|
|
|
//! Load settings from configuration file.
|
|
virtual bool readConfigFiles(std::string& error) = 0;
|
|
|
|
//! Choose network parameters.
|
|
virtual void selectParams(const std::string& network) = 0;
|
|
|
|
//! Read and update <datadir>/settings.json file with saved settings. This
|
|
//! needs to be called after selectParams() because the settings file
|
|
//! location is network-specific.
|
|
virtual bool initSettings(std::string& error) = 0;
|
|
|
|
//! Get the (assumed) blockchain size.
|
|
virtual uint64_t getAssumedBlockchainSize() = 0;
|
|
|
|
//! Get the (assumed) chain state size.
|
|
virtual uint64_t getAssumedChainStateSize() = 0;
|
|
|
|
//! Get network name.
|
|
virtual std::string getNetwork() = 0;
|
|
|
|
//! Init logging.
|
|
virtual void initLogging() = 0;
|
|
|
|
//! Init parameter interaction.
|
|
virtual void initParameterInteraction() = 0;
|
|
|
|
//! Get warnings.
|
|
virtual std::string getWarnings() = 0;
|
|
|
|
// Get log flags.
|
|
virtual uint64_t getLogCategories() = 0;
|
|
|
|
//! Initialize app dependencies.
|
|
virtual bool baseInitialize() = 0;
|
|
|
|
//! Start node.
|
|
virtual bool appInitMain(interfaces::BlockAndHeaderTipInfo* tip_info = nullptr) = 0;
|
|
|
|
//! Stop node.
|
|
virtual void appShutdown() = 0;
|
|
|
|
//! Prepare shutdown.
|
|
virtual void appPrepareShutdown() = 0;
|
|
|
|
//! Start shutdown.
|
|
virtual void startShutdown() = 0;
|
|
|
|
//! Return whether shutdown was requested.
|
|
virtual bool shutdownRequested() = 0;
|
|
|
|
//! Setup arguments
|
|
virtual void setupServerArgs() = 0;
|
|
|
|
//! Map port.
|
|
virtual void mapPort(bool use_upnp, bool use_natpmp) = 0;
|
|
|
|
//! Get proxy.
|
|
virtual bool getProxy(Network net, proxyType& proxy_info) = 0;
|
|
|
|
//! Get number of connections.
|
|
virtual size_t getNodeCount(CConnman::NumConnections flags) = 0;
|
|
|
|
//! Get stats for connected nodes.
|
|
using NodesStats = std::vector<std::tuple<CNodeStats, bool, CNodeStateStats>>;
|
|
virtual bool getNodesStats(NodesStats& stats) = 0;
|
|
|
|
//! Get ban map entries.
|
|
virtual bool getBanned(banmap_t& banmap) = 0;
|
|
|
|
//! Ban node.
|
|
virtual bool ban(const CNetAddr& net_addr, int64_t ban_time_offset) = 0;
|
|
|
|
//! Unban node.
|
|
virtual bool unban(const CSubNet& ip) = 0;
|
|
|
|
//! Disconnect node by address.
|
|
virtual bool disconnectByAddress(const CNetAddr& net_addr) = 0;
|
|
|
|
//! Disconnect node by id.
|
|
virtual bool disconnectById(NodeId id) = 0;
|
|
|
|
//! Get total bytes recv.
|
|
virtual int64_t getTotalBytesRecv() = 0;
|
|
|
|
//! Get total bytes sent.
|
|
virtual int64_t getTotalBytesSent() = 0;
|
|
|
|
//! Get mempool size.
|
|
virtual size_t getMempoolSize() = 0;
|
|
|
|
//! Get mempool dynamic usage.
|
|
virtual size_t getMempoolDynamicUsage() = 0;
|
|
|
|
//! Get header tip height and time.
|
|
virtual bool getHeaderTip(int& height, int64_t& block_time) = 0;
|
|
|
|
//! Get num blocks.
|
|
virtual int getNumBlocks() = 0;
|
|
|
|
//! Get best block hash.
|
|
virtual uint256 getBestBlockHash() = 0;
|
|
|
|
//! Get last block time.
|
|
virtual int64_t getLastBlockTime() = 0;
|
|
|
|
//! Get last block hash.
|
|
virtual std::string getLastBlockHash() = 0;
|
|
|
|
//! Get verification progress.
|
|
virtual double getVerificationProgress() = 0;
|
|
|
|
//! Is initial block download.
|
|
virtual bool isInitialBlockDownload() = 0;
|
|
|
|
//! Get reindex.
|
|
virtual bool getReindex() = 0;
|
|
|
|
//! Get importing.
|
|
virtual bool getImporting() = 0;
|
|
|
|
//! Set network active.
|
|
virtual void setNetworkActive(bool active) = 0;
|
|
|
|
//! Get network active.
|
|
virtual bool getNetworkActive() = 0;
|
|
|
|
//! Get dust relay fee.
|
|
virtual CFeeRate getDustRelayFee() = 0;
|
|
|
|
//! Execute rpc command.
|
|
virtual UniValue executeRpc(const std::string& command, const UniValue& params, const std::string& uri) = 0;
|
|
|
|
//! List rpc commands.
|
|
virtual std::vector<std::string> listRpcCommands() = 0;
|
|
|
|
//! Set RPC timer interface if unset.
|
|
virtual void rpcSetTimerInterfaceIfUnset(RPCTimerInterface* iface) = 0;
|
|
|
|
//! Unset RPC timer interface.
|
|
virtual void rpcUnsetTimerInterface(RPCTimerInterface* iface) = 0;
|
|
|
|
//! Get unspent outputs associated with a transaction.
|
|
virtual bool getUnspentOutput(const COutPoint& output, Coin& coin) = 0;
|
|
|
|
//! Get wallet client.
|
|
virtual WalletClient& walletClient() = 0;
|
|
|
|
//! Return interface for accessing evo related handler.
|
|
virtual EVO& evo() = 0;
|
|
|
|
//! Return interface for accessing governance related handler.
|
|
virtual GOV& gov() = 0;
|
|
|
|
//! Return interface for accessing llmq related handler.
|
|
virtual LLMQ& llmq() = 0;
|
|
|
|
//! Return interface for accessing masternode related handler.
|
|
virtual Masternode::Sync& masternodeSync() = 0;
|
|
|
|
//! Return interface for accessing coinjoin related handler.
|
|
virtual CoinJoin::Options& coinJoinOptions() = 0;
|
|
|
|
//! Register handler for init messages.
|
|
using InitMessageFn = std::function<void(const std::string& message)>;
|
|
virtual std::unique_ptr<Handler> handleInitMessage(InitMessageFn fn) = 0;
|
|
|
|
//! Register handler for message box messages.
|
|
using MessageBoxFn =
|
|
std::function<bool(const bilingual_str& message, const std::string& caption, unsigned int style)>;
|
|
virtual std::unique_ptr<Handler> handleMessageBox(MessageBoxFn fn) = 0;
|
|
|
|
//! Register handler for question messages.
|
|
using QuestionFn = std::function<bool(const bilingual_str& message,
|
|
const std::string& non_interactive_message,
|
|
const std::string& caption,
|
|
unsigned int style)>;
|
|
virtual std::unique_ptr<Handler> handleQuestion(QuestionFn fn) = 0;
|
|
|
|
//! Register handler for progress messages.
|
|
using ShowProgressFn = std::function<void(const std::string& title, int progress, bool resume_possible)>;
|
|
virtual std::unique_ptr<Handler> handleShowProgress(ShowProgressFn fn) = 0;
|
|
|
|
//! Register handler for number of connections changed messages.
|
|
using NotifyNumConnectionsChangedFn = std::function<void(int new_num_connections)>;
|
|
virtual std::unique_ptr<Handler> handleNotifyNumConnectionsChanged(NotifyNumConnectionsChangedFn fn) = 0;
|
|
|
|
//! Register handler for network active messages.
|
|
using NotifyNetworkActiveChangedFn = std::function<void(bool network_active)>;
|
|
virtual std::unique_ptr<Handler> handleNotifyNetworkActiveChanged(NotifyNetworkActiveChangedFn fn) = 0;
|
|
|
|
//! Register handler for notify alert messages.
|
|
using NotifyAlertChangedFn = std::function<void()>;
|
|
virtual std::unique_ptr<Handler> handleNotifyAlertChanged(NotifyAlertChangedFn fn) = 0;
|
|
|
|
//! Register handler for ban list messages.
|
|
using BannedListChangedFn = std::function<void()>;
|
|
virtual std::unique_ptr<Handler> handleBannedListChanged(BannedListChangedFn fn) = 0;
|
|
|
|
//! Register handler for block tip messages.
|
|
using NotifyBlockTipFn =
|
|
std::function<void(bool initial_download, interfaces::BlockTip tip, double verification_progress)>;
|
|
virtual std::unique_ptr<Handler> handleNotifyBlockTip(NotifyBlockTipFn fn) = 0;
|
|
|
|
//! Register handler for chainlock messages.
|
|
using NotifyChainLockFn =
|
|
std::function<void(const std::string& bestChainLockedHash, int32_t bestChainLockedHeight)>;
|
|
virtual std::unique_ptr<Handler> handleNotifyChainLock(NotifyChainLockFn fn) = 0;
|
|
|
|
//! Register handler for header tip messages.
|
|
using NotifyHeaderTipFn =
|
|
std::function<void(bool initial_download, interfaces::BlockTip tip, double verification_progress)>;
|
|
virtual std::unique_ptr<Handler> handleNotifyHeaderTip(NotifyHeaderTipFn fn) = 0;
|
|
|
|
//! Register handler for masternode list update messages.
|
|
using NotifyMasternodeListChangedFn =
|
|
std::function<void(const CDeterministicMNList& newList)>;
|
|
virtual std::unique_ptr<Handler> handleNotifyMasternodeListChanged(NotifyMasternodeListChangedFn fn) = 0;
|
|
|
|
//! Register handler for additional data sync progress update messages.
|
|
using NotifyAdditionalDataSyncProgressChangedFn =
|
|
std::function<void(double nSyncProgress)>;
|
|
virtual std::unique_ptr<Handler> handleNotifyAdditionalDataSyncProgressChanged(NotifyAdditionalDataSyncProgressChangedFn fn) = 0;
|
|
|
|
//! Get and set internal node context. Useful for testing, but not
|
|
//! accessible across processes.
|
|
virtual NodeContext* context() { return nullptr; }
|
|
virtual void setContext(NodeContext* context) { }
|
|
};
|
|
|
|
//! Return implementation of Node interface.
|
|
std::unique_ptr<Node> MakeNode(NodeContext* context = nullptr);
|
|
|
|
//! Block tip (could be a header or not, depends on the subscribed signal).
|
|
struct BlockTip {
|
|
int block_height;
|
|
int64_t block_time;
|
|
uint256 block_hash;
|
|
};
|
|
} // namespace interfaces
|
|
|
|
#endif // BITCOIN_INTERFACES_NODE_H
|