Bitcoin Core  0.19.99
P2P Digital Currency
validationinterface.h
Go to the documentation of this file.
1 // Copyright (c) 2009-2010 Satoshi Nakamoto
2 // Copyright (c) 2009-2020 The Bitcoin Core developers
3 // Distributed under the MIT software license, see the accompanying
4 // file COPYING or http://www.opensource.org/licenses/mit-license.php.
5 
6 #ifndef BITCOIN_VALIDATIONINTERFACE_H
7 #define BITCOIN_VALIDATIONINTERFACE_H
8 
9 #include <primitives/transaction.h> // CTransaction(Ref)
10 #include <sync.h>
11 
12 #include <functional>
13 #include <memory>
14 
15 extern RecursiveMutex cs_main;
17 class CBlock;
18 class CBlockIndex;
19 struct CBlockLocator;
20 class CConnman;
22 class uint256;
23 class CScheduler;
24 
25 // These functions dispatch to one or all registered wallets
26 
33 
34 // Alternate registration functions that release a shared_ptr after the last
35 // notification is sent. These are useful for race-free cleanup, since
36 // unregistration is nonblocking and can return before the last notification is
37 // processed.
38 void RegisterSharedValidationInterface(std::shared_ptr<CValidationInterface> callbacks);
39 void UnregisterSharedValidationInterface(std::shared_ptr<CValidationInterface> callbacks);
40 
50 void CallFunctionInValidationInterfaceQueue(std::function<void ()> func);
61 
78 protected:
83  ~CValidationInterface() = default;
93  virtual void UpdatedBlockTip(const CBlockIndex *pindexNew, const CBlockIndex *pindexFork, bool fInitialDownload) {}
99  virtual void TransactionAddedToMempool(const CTransactionRef &ptxn) {}
132  virtual void TransactionRemovedFromMempool(const CTransactionRef &ptx) {}
139  virtual void BlockConnected(const std::shared_ptr<const CBlock> &block, const CBlockIndex *pindex) {}
145  virtual void BlockDisconnected(const std::shared_ptr<const CBlock> &block, const CBlockIndex* pindex) {}
162  virtual void ChainStateFlushed(const CBlockLocator &locator) {}
169  virtual void BlockChecked(const CBlock&, const BlockValidationState&) {}
173  virtual void NewPoWValidBlock(const CBlockIndex *pindex, const std::shared_ptr<const CBlock>& block) {};
174  friend void ::RegisterSharedValidationInterface(std::shared_ptr<CValidationInterface>);
175  friend void ::UnregisterValidationInterface(CValidationInterface*);
177 };
178 
179 struct MainSignalsInstance;
181 private:
182  std::unique_ptr<MainSignalsInstance> m_internals;
183 
184  friend void ::RegisterSharedValidationInterface(std::shared_ptr<CValidationInterface>);
187  friend void ::CallFunctionInValidationInterfaceQueue(std::function<void ()> func);
188 
189 public:
196 
197  size_t CallbacksPending();
198 
199 
200  void UpdatedBlockTip(const CBlockIndex *, const CBlockIndex *, bool fInitialDownload);
203  void BlockConnected(const std::shared_ptr<const CBlock> &, const CBlockIndex *pindex);
204  void BlockDisconnected(const std::shared_ptr<const CBlock> &, const CBlockIndex* pindex);
205  void ChainStateFlushed(const CBlockLocator &);
206  void BlockChecked(const CBlock&, const BlockValidationState&);
207  void NewPoWValidBlock(const CBlockIndex *, const std::shared_ptr<const CBlock>&);
208 };
209 
211 
212 #endif // BITCOIN_VALIDATIONINTERFACE_H
std::shared_ptr< const CTransaction > CTransactionRef
Definition: transaction.h:408
void UpdatedBlockTip(const CBlockIndex *, const CBlockIndex *, bool fInitialDownload)
std::unique_ptr< MainSignalsInstance > m_internals
virtual void ChainStateFlushed(const CBlockLocator &locator)
Notifies listeners of the new active block chain on-disk.
Describes a place in the block chain to another node such that if the other node doesn&#39;t have the sam...
Definition: block.h:126
virtual void BlockDisconnected(const std::shared_ptr< const CBlock > &block, const CBlockIndex *pindex)
Notifies listeners of a block being disconnected.
void BlockDisconnected(const std::shared_ptr< const CBlock > &, const CBlockIndex *pindex)
Definition: block.h:72
virtual void NewPoWValidBlock(const CBlockIndex *pindex, const std::shared_ptr< const CBlock > &block)
Notifies listeners that a block which builds directly on our current tip has been received and connec...
void UnregisterSharedValidationInterface(std::shared_ptr< CValidationInterface > callbacks)
void UnregisterBackgroundSignalScheduler()
Unregister a CScheduler to give callbacks which should run in the background - these callbacks will n...
void TransactionRemovedFromMempool(const CTransactionRef &)
virtual void BlockChecked(const CBlock &, const BlockValidationState &)
Notifies listeners of a block validation result.
Implement this to subscribe to events generated in validation.
virtual void BlockConnected(const std::shared_ptr< const CBlock > &block, const CBlockIndex *pindex)
Notifies listeners of a block being connected.
void RegisterSharedValidationInterface(std::shared_ptr< CValidationInterface > callbacks)
void RegisterValidationInterface(CValidationInterface *pwalletIn)
Register a wallet to receive updates from core.
void SyncWithValidationInterfaceQueue() LOCKS_EXCLUDED(cs_main)
This is a synonym for the following, which asserts certain locks are not held: std::promise<void> pro...
virtual void UpdatedBlockTip(const CBlockIndex *pindexNew, const CBlockIndex *pindexFork, bool fInitialDownload)
Notifies listeners when the block chain tip advances.
RecursiveMutex cs_main
Mutex to guard access to validation specific variables, such as reading or changing the chainstate...
Definition: validation.cpp:105
void CallFunctionInValidationInterfaceQueue(std::function< void()> func)
Pushes a function to callback onto the notification queue, guaranteeing any callbacks generated prior...
Definition: net.h:121
void ChainStateFlushed(const CBlockLocator &)
CMainSignals & GetMainSignals()
void RegisterBackgroundSignalScheduler(CScheduler &scheduler)
Register a CScheduler to give callbacks which should run in the background (may only be called once) ...
256-bit opaque blob.
Definition: uint256.h:120
#define LOCKS_EXCLUDED(...)
Definition: threadsafety.h:50
The block chain is a tree shaped structure starting with the genesis block at the root...
Definition: chain.h:137
void FlushBackgroundCallbacks()
Call any remaining callbacks on the calling thread.
void UnregisterAllValidationInterfaces()
Unregister all wallets from core.
virtual void TransactionRemovedFromMempool(const CTransactionRef &ptx)
Notifies listeners of a transaction leaving mempool.
virtual void TransactionAddedToMempool(const CTransactionRef &ptxn)
Notifies listeners of a transaction having been added to mempool.
void NewPoWValidBlock(const CBlockIndex *, const std::shared_ptr< const CBlock > &)
void BlockChecked(const CBlock &, const BlockValidationState &)
void UnregisterValidationInterface(CValidationInterface *pwalletIn)
Unregister a wallet from core.
void BlockConnected(const std::shared_ptr< const CBlock > &, const CBlockIndex *pindex)
void TransactionAddedToMempool(const CTransactionRef &)