Bitcoin Core 28.99.0
P2P Digital Currency
node.h
Go to the documentation of this file.
1// Copyright (c) 2018-2022 The Bitcoin Core developers
2// Distributed under the MIT software license, see the accompanying
3// file COPYING or http://www.opensource.org/licenses/mit-license.php.
4
5#ifndef BITCOIN_INTERFACES_NODE_H
6#define BITCOIN_INTERFACES_NODE_H
7
8#include <common/settings.h>
9#include <consensus/amount.h> // For CAmount
10#include <logging.h> // For BCLog::CategoryMask
11#include <net.h> // For NodeId
12#include <net_types.h> // For banmap_t
13#include <netaddress.h> // For Network
14#include <netbase.h> // For ConnectionDirection
15#include <support/allocators/secure.h> // For SecureString
16#include <util/translation.h>
17
18#include <functional>
19#include <memory>
20#include <stddef.h>
21#include <stdint.h>
22#include <string>
23#include <tuple>
24#include <vector>
25
26class BanMan;
27class CFeeRate;
28class CNodeStats;
29class Coin;
31class UniValue;
32class Proxy;
33enum class SynchronizationState;
34struct CNodeStateStats;
35struct bilingual_str;
36namespace node {
37enum class TransactionError;
38struct NodeContext;
39} // namespace node
40namespace wallet {
41class CCoinControl;
42} // namespace wallet
43
44namespace interfaces {
45class Handler;
46class WalletLoader;
47struct BlockTip;
48
51{
53 int64_t block_time;
55 int64_t header_time;
57};
58
61{
62public:
63 virtual ~ExternalSigner() = default;
64
66 virtual std::string getName() = 0;
67};
68
70class Node
71{
72public:
73 virtual ~Node() = default;
74
76 virtual void initLogging() = 0;
77
79 virtual void initParameterInteraction() = 0;
80
83
85 virtual int getExitStatus() = 0;
86
87 // Get log flags.
89
91 virtual bool baseInitialize() = 0;
92
94 virtual bool appInitMain(interfaces::BlockAndHeaderTipInfo* tip_info = nullptr) = 0;
95
97 virtual void appShutdown() = 0;
98
100 virtual void startShutdown() = 0;
101
103 virtual bool shutdownRequested() = 0;
104
107 virtual bool isSettingIgnored(const std::string& name) = 0;
108
110 virtual common::SettingsValue getPersistentSetting(const std::string& name) = 0;
111
113 virtual void updateRwSetting(const std::string& name, const common::SettingsValue& value) = 0;
114
117 virtual void forceSetting(const std::string& name, const common::SettingsValue& value) = 0;
118
121 virtual void resetSettings() = 0;
122
124 virtual void mapPort(bool use_pcp) = 0;
125
127 virtual bool getProxy(Network net, Proxy& proxy_info) = 0;
128
131
133 using NodesStats = std::vector<std::tuple<CNodeStats, bool, CNodeStateStats>>;
134 virtual bool getNodesStats(NodesStats& stats) = 0;
135
137 virtual bool getBanned(banmap_t& banmap) = 0;
138
140 virtual bool ban(const CNetAddr& net_addr, int64_t ban_time_offset) = 0;
141
143 virtual bool unban(const CSubNet& ip) = 0;
144
146 virtual bool disconnectByAddress(const CNetAddr& net_addr) = 0;
147
149 virtual bool disconnectById(NodeId id) = 0;
150
152 virtual std::vector<std::unique_ptr<ExternalSigner>> listExternalSigners() = 0;
153
155 virtual int64_t getTotalBytesRecv() = 0;
156
158 virtual int64_t getTotalBytesSent() = 0;
159
161 virtual size_t getMempoolSize() = 0;
162
164 virtual size_t getMempoolDynamicUsage() = 0;
165
167 virtual size_t getMempoolMaxUsage() = 0;
168
170 virtual bool getHeaderTip(int& height, int64_t& block_time) = 0;
171
173 virtual int getNumBlocks() = 0;
174
176 virtual std::map<CNetAddr, LocalServiceInfo> getNetLocalAddresses() = 0;
177
180
182 virtual int64_t getLastBlockTime() = 0;
183
185 virtual double getVerificationProgress() = 0;
186
188 virtual bool isInitialBlockDownload() = 0;
189
191 virtual bool isLoadingBlocks() = 0;
192
194 virtual void setNetworkActive(bool active) = 0;
195
197 virtual bool getNetworkActive() = 0;
198
201
203 virtual UniValue executeRpc(const std::string& command, const UniValue& params, const std::string& uri) = 0;
204
206 virtual std::vector<std::string> listRpcCommands() = 0;
207
210
213
215 virtual std::optional<Coin> getUnspentOutput(const COutPoint& output) = 0;
216
218 virtual node::TransactionError broadcastTransaction(CTransactionRef tx, CAmount max_tx_fee, std::string& err_string) = 0;
219
222
224 using InitMessageFn = std::function<void(const std::string& message)>;
225 virtual std::unique_ptr<Handler> handleInitMessage(InitMessageFn fn) = 0;
226
229 std::function<bool(const bilingual_str& message, const std::string& caption, unsigned int style)>;
230 virtual std::unique_ptr<Handler> handleMessageBox(MessageBoxFn fn) = 0;
231
233 using QuestionFn = std::function<bool(const bilingual_str& message,
234 const std::string& non_interactive_message,
235 const std::string& caption,
236 unsigned int style)>;
237 virtual std::unique_ptr<Handler> handleQuestion(QuestionFn fn) = 0;
238
240 using ShowProgressFn = std::function<void(const std::string& title, int progress, bool resume_possible)>;
241 virtual std::unique_ptr<Handler> handleShowProgress(ShowProgressFn fn) = 0;
242
244 using InitWalletFn = std::function<void()>;
245 virtual std::unique_ptr<Handler> handleInitWallet(InitWalletFn fn) = 0;
246
248 using NotifyNumConnectionsChangedFn = std::function<void(int new_num_connections)>;
249 virtual std::unique_ptr<Handler> handleNotifyNumConnectionsChanged(NotifyNumConnectionsChangedFn fn) = 0;
250
252 using NotifyNetworkActiveChangedFn = std::function<void(bool network_active)>;
253 virtual std::unique_ptr<Handler> handleNotifyNetworkActiveChanged(NotifyNetworkActiveChangedFn fn) = 0;
254
256 using NotifyAlertChangedFn = std::function<void()>;
257 virtual std::unique_ptr<Handler> handleNotifyAlertChanged(NotifyAlertChangedFn fn) = 0;
258
260 using BannedListChangedFn = std::function<void()>;
261 virtual std::unique_ptr<Handler> handleBannedListChanged(BannedListChangedFn fn) = 0;
262
265 std::function<void(SynchronizationState, interfaces::BlockTip tip, double verification_progress)>;
266 virtual std::unique_ptr<Handler> handleNotifyBlockTip(NotifyBlockTipFn fn) = 0;
267
270 std::function<void(SynchronizationState, interfaces::BlockTip tip, bool presync)>;
271 virtual std::unique_ptr<Handler> handleNotifyHeaderTip(NotifyHeaderTipFn fn) = 0;
272
275 virtual node::NodeContext* context() { return nullptr; }
277};
278
280std::unique_ptr<Node> MakeNode(node::NodeContext& context);
281
283struct BlockTip {
285 int64_t block_time;
287};
288
289} // namespace interfaces
290
291#endif // BITCOIN_INTERFACES_NODE_H
int64_t CAmount
Amount in satoshis (Can be negative)
Definition: amount.h:12
int flags
Definition: bitcoin-tx.cpp:536
const auto command
Definition: banman.h:59
Fee rate in satoshis per kilovirtualbyte: CAmount / kvB.
Definition: feerate.h:33
Network address.
Definition: netaddress.h:112
An outpoint - a combination of a transaction hash and an index n into its vout.
Definition: transaction.h:29
A UTXO entry.
Definition: coins.h:33
Definition: netbase.h:59
RPC timer "driver".
Definition: server.h:52
External signer interface used by the GUI.
Definition: node.h:61
virtual std::string getName()=0
Get signer display name.
virtual ~ExternalSigner()=default
Top-level interface for a bitcoin node (bitcoind process).
Definition: node.h:71
virtual void rpcSetTimerInterfaceIfUnset(RPCTimerInterface *iface)=0
Set RPC timer interface if unset.
std::function< void()> BannedListChangedFn
Register handler for ban list messages.
Definition: node.h:260
virtual void updateRwSetting(const std::string &name, const common::SettingsValue &value)=0
Update a setting in <datadir>/settings.json.
virtual std::map< CNetAddr, LocalServiceInfo > getNetLocalAddresses()=0
Get network local addresses.
virtual std::optional< Coin > getUnspentOutput(const COutPoint &output)=0
Get unspent output associated with a transaction.
virtual common::SettingsValue getPersistentSetting(const std::string &name)=0
Return setting value from <datadir>/settings.json or bitcoin.conf.
virtual bool disconnectById(NodeId id)=0
Disconnect node by id.
virtual bool baseInitialize()=0
Initialize app dependencies.
std::function< void(SynchronizationState, interfaces::BlockTip tip, bool presync)> NotifyHeaderTipFn
Register handler for header tip messages.
Definition: node.h:270
virtual std::unique_ptr< Handler > handleInitMessage(InitMessageFn fn)=0
virtual bool ban(const CNetAddr &net_addr, int64_t ban_time_offset)=0
Ban node.
std::function< void(bool network_active)> NotifyNetworkActiveChangedFn
Register handler for network active messages.
Definition: node.h:252
virtual std::unique_ptr< Handler > handleShowProgress(ShowProgressFn fn)=0
virtual void setNetworkActive(bool active)=0
Set network active.
virtual bilingual_str getWarnings()=0
Get warnings.
virtual size_t getMempoolMaxUsage()=0
Get mempool maximum memory usage.
virtual std::vector< std::string > listRpcCommands()=0
List rpc commands.
virtual void appShutdown()=0
Stop node.
virtual node::TransactionError broadcastTransaction(CTransactionRef tx, CAmount max_tx_fee, std::string &err_string)=0
Broadcast transaction.
std::function< void(const std::string &message)> InitMessageFn
Register handler for init messages.
Definition: node.h:224
std::function< bool(const bilingual_str &message, const std::string &non_interactive_message, const std::string &caption, unsigned int style)> QuestionFn
Register handler for question messages.
Definition: node.h:236
std::function< bool(const bilingual_str &message, const std::string &caption, unsigned int style)> MessageBoxFn
Register handler for message box messages.
Definition: node.h:229
virtual std::unique_ptr< Handler > handleNotifyBlockTip(NotifyBlockTipFn fn)=0
virtual void resetSettings()=0
Clear all settings in <datadir>/settings.json and store a backup of previous settings in <datadir>/se...
virtual void rpcUnsetTimerInterface(RPCTimerInterface *iface)=0
Unset RPC timer interface.
virtual void mapPort(bool use_pcp)=0
Map port.
std::function< void()> InitWalletFn
Register handler for wallet loader constructed messages.
Definition: node.h:244
virtual std::unique_ptr< Handler > handleNotifyAlertChanged(NotifyAlertChangedFn fn)=0
virtual std::unique_ptr< Handler > handleNotifyHeaderTip(NotifyHeaderTipFn fn)=0
virtual std::unique_ptr< Handler > handleMessageBox(MessageBoxFn fn)=0
std::vector< std::tuple< CNodeStats, bool, CNodeStateStats > > NodesStats
Get stats for connected nodes.
Definition: node.h:133
virtual UniValue executeRpc(const std::string &command, const UniValue &params, const std::string &uri)=0
Execute rpc command.
virtual bool isSettingIgnored(const std::string &name)=0
Return whether a particular setting in <datadir>/settings.json is or would be ignored because it is a...
virtual void initParameterInteraction()=0
Init parameter interaction.
virtual void startShutdown()=0
Start shutdown.
std::function< void()> NotifyAlertChangedFn
Register handler for notify alert messages.
Definition: node.h:256
virtual int64_t getLastBlockTime()=0
Get last block time.
virtual bool getBanned(banmap_t &banmap)=0
Get ban map entries.
virtual std::unique_ptr< Handler > handleInitWallet(InitWalletFn fn)=0
virtual BCLog::CategoryMask getLogCategories()=0
virtual size_t getMempoolSize()=0
Get mempool size.
virtual bool getNetworkActive()=0
Get network active.
virtual bool unban(const CSubNet &ip)=0
Unban node.
virtual bool isLoadingBlocks()=0
Is loading blocks.
virtual bool appInitMain(interfaces::BlockAndHeaderTipInfo *tip_info=nullptr)=0
Start node.
virtual std::unique_ptr< Handler > handleQuestion(QuestionFn fn)=0
virtual size_t getNodeCount(ConnectionDirection flags)=0
Get number of connections.
virtual void forceSetting(const std::string &name, const common::SettingsValue &value)=0
Force a setting value to be applied, overriding any other configuration source, but not being persist...
virtual double getVerificationProgress()=0
Get verification progress.
virtual bool getHeaderTip(int &height, int64_t &block_time)=0
Get header tip height and time.
virtual uint256 getBestBlockHash()=0
Get best block hash.
virtual bool disconnectByAddress(const CNetAddr &net_addr)=0
Disconnect node by address.
virtual int64_t getTotalBytesRecv()=0
Get total bytes recv.
virtual std::unique_ptr< Handler > handleBannedListChanged(BannedListChangedFn fn)=0
std::function< void(const std::string &title, int progress, bool resume_possible)> ShowProgressFn
Register handler for progress messages.
Definition: node.h:240
virtual WalletLoader & walletLoader()=0
Get wallet loader.
virtual void initLogging()=0
Init logging.
virtual std::unique_ptr< Handler > handleNotifyNetworkActiveChanged(NotifyNetworkActiveChangedFn fn)=0
virtual int64_t getTotalBytesSent()=0
Get total bytes sent.
virtual ~Node()=default
virtual node::NodeContext * context()
Get and set internal node context.
Definition: node.h:275
virtual size_t getMempoolDynamicUsage()=0
Get mempool dynamic usage.
virtual bool getProxy(Network net, Proxy &proxy_info)=0
Get proxy.
virtual int getNumBlocks()=0
Get num blocks.
virtual bool shutdownRequested()=0
Return whether shutdown was requested.
virtual bool getNodesStats(NodesStats &stats)=0
virtual bool isInitialBlockDownload()=0
Is initial block download.
std::function< void(int new_num_connections)> NotifyNumConnectionsChangedFn
Register handler for number of connections changed messages.
Definition: node.h:248
virtual std::unique_ptr< Handler > handleNotifyNumConnectionsChanged(NotifyNumConnectionsChangedFn fn)=0
virtual int getExitStatus()=0
Get exit status.
virtual CFeeRate getDustRelayFee()=0
Get dust relay fee.
virtual void setContext(node::NodeContext *context)
Definition: node.h:276
std::function< void(SynchronizationState, interfaces::BlockTip tip, double verification_progress)> NotifyBlockTipFn
Register handler for block tip messages.
Definition: node.h:265
virtual std::vector< std::unique_ptr< ExternalSigner > > listExternalSigners()=0
Return list of external signers (attached devices which can sign transactions).
Wallet chain client that in addition to having chain client methods for starting up,...
Definition: wallet.h:328
256-bit opaque blob.
Definition: uint256.h:190
static CService ip(uint32_t i)
uint64_t CategoryMask
Definition: logging.h:40
std::unique_ptr< Node > MakeNode(node::NodeContext &context)
Return implementation of Node interface.
Definition: interfaces.cpp:998
Definition: messages.h:20
TransactionError
Definition: types.h:20
int64_t NodeId
Definition: net.h:97
std::map< CSubNet, CBanEntry > banmap_t
Definition: net_types.h:41
Network
A network type.
Definition: netaddress.h:32
ConnectionDirection
Definition: netbase.h:33
std::shared_ptr< const CTransaction > CTransactionRef
Definition: transaction.h:423
const char * name
Definition: rest.cpp:49
Bilingual messages:
Definition: translation.h:21
Block and header tip information.
Definition: node.h:51
Block tip (could be a header or not, depends on the subscribed signal).
Definition: node.h:283
uint256 block_hash
Definition: node.h:286
int64_t block_time
Definition: node.h:285
NodeContext struct containing references to chain state and connection state.
Definition: context.h:56
SynchronizationState
Current sync state passed to tip changed callbacks.
Definition: validation.h:85