2018-11-23 15:42:09 +01:00
|
|
|
// Copyright (c) 2018 The Dash Core developers
|
|
|
|
// Distributed under the MIT software license, see the accompanying
|
|
|
|
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
|
|
|
|
|
|
|
#ifndef DASH_QUORUMS_UTILS_H
|
|
|
|
#define DASH_QUORUMS_UTILS_H
|
|
|
|
|
|
|
|
#include "consensus/params.h"
|
2019-01-15 15:35:26 +01:00
|
|
|
#include "net.h"
|
2018-11-23 15:42:09 +01:00
|
|
|
|
|
|
|
#include "evo/deterministicmns.h"
|
|
|
|
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
namespace llmq
|
|
|
|
{
|
|
|
|
|
|
|
|
class CLLMQUtils
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
// includes members which failed DKG
|
|
|
|
static std::vector<CDeterministicMNCPtr> GetAllQuorumMembers(Consensus::LLMQType llmqType, const uint256& blockHash);
|
|
|
|
|
|
|
|
static uint256 BuildCommitmentHash(uint8_t llmqType, const uint256& blockHash, const std::vector<bool>& validMembers, const CBLSPublicKey& pubKey, const uint256& vvecHash);
|
2019-01-15 15:35:26 +01:00
|
|
|
static uint256 BuildSignHash(Consensus::LLMQType llmqType, const uint256& quorumHash, const uint256& id, const uint256& msgHash);
|
|
|
|
|
|
|
|
// works for sig shares and recovered sigs
|
|
|
|
template<typename T>
|
|
|
|
static uint256 BuildSignHash(const T& s)
|
|
|
|
{
|
|
|
|
return BuildSignHash((Consensus::LLMQType)s.llmqType, s.quorumHash, s.id, s.msgHash);
|
|
|
|
}
|
2018-05-24 16:14:55 +02:00
|
|
|
|
|
|
|
static std::set<CService> GetQuorumConnections(Consensus::LLMQType llmqType, const uint256& blockHash, const uint256& forMember);
|
|
|
|
static std::set<size_t> CalcDeterministicWatchConnections(Consensus::LLMQType llmqType, const uint256& blockHash, size_t memberCount, size_t connectionCount);
|
2019-01-15 15:35:26 +01:00
|
|
|
|
|
|
|
static bool IsQuorumActive(Consensus::LLMQType llmqType, const uint256& quorumHash);
|
|
|
|
|
|
|
|
template<typename NodesContainer, typename Continue, typename Callback>
|
|
|
|
static void IterateNodesRandom(NodesContainer& nodeStates, Continue&& cont, Callback&& callback, FastRandomContext& rnd)
|
|
|
|
{
|
|
|
|
std::vector<typename NodesContainer::iterator> rndNodes;
|
|
|
|
rndNodes.reserve(nodeStates.size());
|
|
|
|
for (auto it = nodeStates.begin(); it != nodeStates.end(); ++it) {
|
|
|
|
rndNodes.emplace_back(it);
|
|
|
|
}
|
|
|
|
if (rndNodes.empty()) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
std::random_shuffle(rndNodes.begin(), rndNodes.end(), rnd);
|
|
|
|
|
|
|
|
size_t idx = 0;
|
|
|
|
while (!rndNodes.empty() && cont()) {
|
|
|
|
auto nodeId = rndNodes[idx]->first;
|
|
|
|
auto& ns = rndNodes[idx]->second;
|
|
|
|
|
|
|
|
if (callback(nodeId, ns)) {
|
|
|
|
idx = (idx + 1) % rndNodes.size();
|
|
|
|
} else {
|
|
|
|
rndNodes.erase(rndNodes.begin() + idx);
|
|
|
|
if (rndNodes.empty()) {
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
idx %= rndNodes.size();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2018-11-23 15:42:09 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif//DASH_QUORUMS_UTILS_H
|