1 // Copyright (c) 2009-2010 Satoshi Nakamoto
2 // Copyright (c) 2009-2017 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.
6 #ifndef BITCOIN_VALIDATIONINTERFACE_H
7 #define BITCOIN_VALIDATIONINTERFACE_H
9 #include <primitives/transaction.h> // CTransaction(Ref)
20 class CValidationInterface
;
21 class CValidationState
;
25 enum class MemPoolRemovalReason
;
27 // These functions dispatch to one or all registered wallets
29 /** Register a wallet to receive updates from core */
30 void RegisterValidationInterface(CValidationInterface
* pwalletIn
);
31 /** Unregister a wallet from core */
32 void UnregisterValidationInterface(CValidationInterface
* pwalletIn
);
33 /** Unregister all wallets from core */
34 void UnregisterAllValidationInterfaces();
36 * Pushes a function to callback onto the notification queue, guaranteeing any
37 * callbacks generated prior to now are finished when the function is called.
39 * Be very careful blocking on func to be called if any locks are held -
40 * validation interface clients may not be able to make progress as they often
41 * wait for things like cs_main, so blocking until func is called with cs_main
42 * will result in a deadlock (that DEBUG_LOCKORDER will miss).
44 void CallFunctionInValidationInterfaceQueue(std::function
<void ()> func
);
46 * This is a synonym for the following, which asserts certain locks are not
48 * std::promise<void> promise;
49 * CallFunctionInValidationInterfaceQueue([&promise] {
50 * promise.set_value();
52 * promise.get_future().wait();
54 void SyncWithValidationInterfaceQueue();
56 class CValidationInterface
{
59 * Notifies listeners of updated block chain tip
61 * Called on a background thread.
63 virtual void UpdatedBlockTip(const CBlockIndex
*pindexNew
, const CBlockIndex
*pindexFork
, bool fInitialDownload
) {}
65 * Notifies listeners of a transaction having been added to mempool.
67 * Called on a background thread.
69 virtual void TransactionAddedToMempool(const CTransactionRef
&ptxn
) {}
71 * Notifies listeners of a transaction leaving mempool.
73 * This only fires for transactions which leave mempool because of expiry,
74 * size limiting, reorg (changes in lock times/coinbase maturity), or
75 * replacement. This does not include any transactions which are included
76 * in BlockConnectedDisconnected either in block->vtx or in txnConflicted.
78 * Called on a background thread.
80 virtual void TransactionRemovedFromMempool(const CTransactionRef
&ptx
) {}
82 * Notifies listeners of a block being connected.
83 * Provides a vector of transactions evicted from the mempool as a result.
85 * Called on a background thread.
87 virtual void BlockConnected(const std::shared_ptr
<const CBlock
> &block
, const CBlockIndex
*pindex
, const std::vector
<CTransactionRef
> &txnConflicted
) {}
89 * Notifies listeners of a block being disconnected
91 * Called on a background thread.
93 virtual void BlockDisconnected(const std::shared_ptr
<const CBlock
> &block
) {}
95 * Notifies listeners of the new active block chain on-disk.
97 * Called on a background thread.
99 virtual void SetBestChain(const CBlockLocator
&locator
) {}
101 * Notifies listeners about an inventory item being seen on the network.
103 * Called on a background thread.
105 virtual void Inventory(const uint256
&hash
) {}
106 /** Tells listeners to broadcast their data. */
107 virtual void ResendWalletTransactions(int64_t nBestBlockTime
, CConnman
* connman
) {}
109 * Notifies listeners of a block validation result.
110 * If the provided CValidationState IsValid, the provided block
111 * is guaranteed to be the current best block at the time the
112 * callback was generated (not necessarily now)
114 virtual void BlockChecked(const CBlock
&, const CValidationState
&) {}
116 * Notifies listeners that a block which builds directly on our current tip
117 * has been received and connected to the headers tree, though not validated yet */
118 virtual void NewPoWValidBlock(const CBlockIndex
*pindex
, const std::shared_ptr
<const CBlock
>& block
) {};
119 friend void ::RegisterValidationInterface(CValidationInterface
*);
120 friend void ::UnregisterValidationInterface(CValidationInterface
*);
121 friend void ::UnregisterAllValidationInterfaces();
124 struct MainSignalsInstance
;
127 std::unique_ptr
<MainSignalsInstance
> m_internals
;
129 friend void ::RegisterValidationInterface(CValidationInterface
*);
130 friend void ::UnregisterValidationInterface(CValidationInterface
*);
131 friend void ::UnregisterAllValidationInterfaces();
132 friend void ::CallFunctionInValidationInterfaceQueue(std::function
<void ()> func
);
134 void MempoolEntryRemoved(CTransactionRef tx
, MemPoolRemovalReason reason
);
137 /** Register a CScheduler to give callbacks which should run in the background (may only be called once) */
138 void RegisterBackgroundSignalScheduler(CScheduler
& scheduler
);
139 /** Unregister a CScheduler to give callbacks which should run in the background - these callbacks will now be dropped! */
140 void UnregisterBackgroundSignalScheduler();
141 /** Call any remaining callbacks on the calling thread */
142 void FlushBackgroundCallbacks();
144 size_t CallbacksPending();
146 /** Register with mempool to call TransactionRemovedFromMempool callbacks */
147 void RegisterWithMempoolSignals(CTxMemPool
& pool
);
148 /** Unregister with mempool */
149 void UnregisterWithMempoolSignals(CTxMemPool
& pool
);
151 void UpdatedBlockTip(const CBlockIndex
*, const CBlockIndex
*, bool fInitialDownload
);
152 void TransactionAddedToMempool(const CTransactionRef
&);
153 void BlockConnected(const std::shared_ptr
<const CBlock
> &, const CBlockIndex
*pindex
, const std::shared_ptr
<const std::vector
<CTransactionRef
>> &);
154 void BlockDisconnected(const std::shared_ptr
<const CBlock
> &);
155 void SetBestChain(const CBlockLocator
&);
156 void Inventory(const uint256
&);
157 void Broadcast(int64_t nBestBlockTime
, CConnman
* connman
);
158 void BlockChecked(const CBlock
&, const CValidationState
&);
159 void NewPoWValidBlock(const CBlockIndex
*, const std::shared_ptr
<const CBlock
>&);
162 CMainSignals
& GetMainSignals();
164 #endif // BITCOIN_VALIDATIONINTERFACE_H