diff --git a/src/masternode/masternode-utils.cpp b/src/masternode/masternode-utils.cpp index e72d730b4..1c10385ed 100644 --- a/src/masternode/masternode-utils.cpp +++ b/src/masternode/masternode-utils.cpp @@ -27,6 +27,17 @@ void CMasternodeUtils::ProcessMasternodeConnections(CConnman& connman) privateSendClient.GetMixingMasternodesInfo(vecDmns); #endif // ENABLE_WALLET + // Don't disconnect masternode connections when we have less then the desired amount of outbound nodes + int nonMasternodeCount = 0; + connman.ForEachNode(CConnman::AllNodes, [&](CNode* pnode) { + if (!pnode->fInbound && !pnode->fFeeler && !pnode->m_manual_connection && !pnode->fMasternode) { + nonMasternodeCount++; + } + }); + if (nonMasternodeCount < connman.GetMaxOutboundNodeCount()) { + return; + } + connman.ForEachNode(CConnman::AllNodes, [&](CNode* pnode) { if (pnode->fMasternode && !connman.IsMasternodeQuorumNode(pnode)) { #ifdef ENABLE_WALLET diff --git a/src/net.cpp b/src/net.cpp index 03aee7625..9e82a2a45 100644 --- a/src/net.cpp +++ b/src/net.cpp @@ -2924,6 +2924,11 @@ size_t CConnman::GetNodeCount(NumConnections flags) return nNum; } +size_t CConnman::GetMaxOutboundNodeCount() +{ + return nMaxOutbound; +} + void CConnman::GetNodeStats(std::vector& vstats) { vstats.clear(); diff --git a/src/net.h b/src/net.h index 3a405d0f7..f4d687903 100644 --- a/src/net.h +++ b/src/net.h @@ -407,6 +407,7 @@ public: bool IsMasternodeQuorumNode(const CNode* pnode); size_t GetNodeCount(NumConnections num); + size_t GetMaxOutboundNodeCount(); void GetNodeStats(std::vector& vstats); bool DisconnectNode(const std::string& node); bool DisconnectNode(NodeId id);