// Copyright (c) 2014-2023 The Dash Core developers // Distributed under the MIT software license, see the accompanying // file COPYING or http://www.opensource.org/licenses/mit-license.php. #include #include #ifdef ENABLE_WALLET #include #endif // ENABLE_WALLET #include #include #include #include #include #include #include #include #include #include #include CDSNotificationInterface::CDSNotificationInterface(CConnman& _connman, CMasternodeSync& _mn_sync, const std::unique_ptr& _dmnman, CGovernanceManager& _govman, const std::unique_ptr& _llmq_ctx ) : connman(_connman), m_mn_sync(_mn_sync), dmnman(_dmnman), govman(_govman), llmq_ctx(_llmq_ctx) {} void CDSNotificationInterface::InitializeCurrentBlockTip() { SynchronousUpdatedBlockTip(::ChainActive().Tip(), nullptr, ::ChainstateActive().IsInitialBlockDownload()); UpdatedBlockTip(::ChainActive().Tip(), nullptr, ::ChainstateActive().IsInitialBlockDownload()); } void CDSNotificationInterface::AcceptedBlockHeader(const CBlockIndex *pindexNew) { llmq_ctx->clhandler->AcceptedBlockHeader(pindexNew); m_mn_sync.AcceptedBlockHeader(pindexNew); } void CDSNotificationInterface::NotifyHeaderTip(const CBlockIndex *pindexNew, bool fInitialDownload) { m_mn_sync.NotifyHeaderTip(pindexNew, fInitialDownload); } void CDSNotificationInterface::SynchronousUpdatedBlockTip(const CBlockIndex *pindexNew, const CBlockIndex *pindexFork, bool fInitialDownload) { if (pindexNew == pindexFork) // blocks were disconnected without any new ones return; dmnman->UpdatedBlockTip(pindexNew); } void CDSNotificationInterface::UpdatedBlockTip(const CBlockIndex *pindexNew, const CBlockIndex *pindexFork, bool fInitialDownload) { if (pindexNew == pindexFork) // blocks were disconnected without any new ones return; m_mn_sync.UpdatedBlockTip(pindexNew, fInitialDownload); // Update global DIP0001 activation status fDIP0001ActiveAtTip = pindexNew->nHeight >= Params().GetConsensus().DIP0001Height; if (fInitialDownload) return; CCoinJoin::UpdatedBlockTip(pindexNew, *llmq_ctx->clhandler, m_mn_sync); #ifdef ENABLE_WALLET for (auto& pair : coinJoinClientManagers) { pair.second->UpdatedBlockTip(pindexNew); } #endif // ENABLE_WALLET llmq_ctx->isman->UpdatedBlockTip(pindexNew); llmq_ctx->clhandler->UpdatedBlockTip(); llmq_ctx->qman->UpdatedBlockTip(pindexNew, fInitialDownload); llmq_ctx->qdkgsman->UpdatedBlockTip(pindexNew, fInitialDownload); if (!fDisableGovernance) govman.UpdatedBlockTip(pindexNew, connman); } void CDSNotificationInterface::TransactionAddedToMempool(const CTransactionRef& ptx, int64_t nAcceptTime) { llmq_ctx->isman->TransactionAddedToMempool(ptx); llmq_ctx->clhandler->TransactionAddedToMempool(ptx, nAcceptTime); CCoinJoin::TransactionAddedToMempool(ptx); } void CDSNotificationInterface::TransactionRemovedFromMempool(const CTransactionRef& ptx, MemPoolRemovalReason reason) { llmq_ctx->isman->TransactionRemovedFromMempool(ptx); } void CDSNotificationInterface::BlockConnected(const std::shared_ptr& pblock, const CBlockIndex* pindex) { // TODO: Temporarily ensure that mempool removals are notified before // connected transactions. This shouldn't matter, but the abandoned // state of transactions in our wallet is currently cleared when we // receive another notification and there is a race condition where // notification of a connected conflict might cause an outside process // to abandon a transaction and then have it inadvertently cleared by // the notification that the conflicted transaction was evicted. llmq_ctx->isman->BlockConnected(pblock, pindex); llmq_ctx->clhandler->BlockConnected(pblock, pindex); CCoinJoin::BlockConnected(pblock, pindex); } void CDSNotificationInterface::BlockDisconnected(const std::shared_ptr& pblock, const CBlockIndex* pindexDisconnected) { llmq_ctx->isman->BlockDisconnected(pblock, pindexDisconnected); llmq_ctx->clhandler->BlockDisconnected(pblock, pindexDisconnected); CCoinJoin::BlockDisconnected(pblock, pindexDisconnected); } void CDSNotificationInterface::NotifyMasternodeListChanged(bool undo, const CDeterministicMNList& oldMNList, const CDeterministicMNListDiff& diff, CConnman& connman) { CMNAuth::NotifyMasternodeListChanged(undo, oldMNList, diff, connman); govman.UpdateCachesAndClean(); } void CDSNotificationInterface::NotifyChainLock(const CBlockIndex* pindex, const std::shared_ptr& clsig) { llmq_ctx->isman->NotifyChainLock(pindex); CCoinJoin::NotifyChainLock(pindex, *llmq_ctx->clhandler, m_mn_sync); }