93 lines
2.5 KiB
C
93 lines
2.5 KiB
C
|
// Copyright (c) 2018 The Dash Core developers
|
||
|
// Distributed under the MIT/X11 software license, see the accompanying
|
||
|
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
||
|
|
||
|
#ifndef DASH_QUORUMS_COMMITMENT_H
|
||
|
#define DASH_QUORUMS_COMMITMENT_H
|
||
|
|
||
|
#include "consensus/params.h"
|
||
|
|
||
|
#include "evo/deterministicmns.h"
|
||
|
|
||
|
#include "bls/bls.h"
|
||
|
|
||
|
namespace llmq
|
||
|
{
|
||
|
|
||
|
// This message is an aggregation of all received premature commitments and only valid if
|
||
|
// enough (>=threshold) premature commitments were aggregated
|
||
|
// This is mined on-chain as part of TRANSACTION_QUORUM_COMMITMENT
|
||
|
class CFinalCommitment
|
||
|
{
|
||
|
public:
|
||
|
static const uint16_t CURRENT_VERSION = 1;
|
||
|
|
||
|
public:
|
||
|
uint16_t nVersion{CURRENT_VERSION};
|
||
|
uint8_t llmqType{Consensus::LLMQ_NONE};
|
||
|
uint256 quorumHash;
|
||
|
std::vector<bool> signers;
|
||
|
std::vector<bool> validMembers;
|
||
|
|
||
|
CBLSPublicKey quorumPublicKey;
|
||
|
uint256 quorumVvecHash;
|
||
|
|
||
|
CBLSSignature quorumSig; // recovered threshold sig of blockHash+validMembers+pubKeyHash+vvecHash
|
||
|
CBLSSignature membersSig; // aggregated member sig of blockHash+validMembers+pubKeyHash+vvecHash
|
||
|
|
||
|
public:
|
||
|
CFinalCommitment() {}
|
||
|
CFinalCommitment(const Consensus::LLMQParams& params, const uint256& _quorumHash);
|
||
|
|
||
|
int CountSigners() const
|
||
|
{
|
||
|
return (int)std::count(signers.begin(), signers.end(), true);
|
||
|
}
|
||
|
int CountValidMembers() const
|
||
|
{
|
||
|
return (int)std::count(validMembers.begin(), validMembers.end(), true);
|
||
|
}
|
||
|
|
||
|
bool Verify(const std::vector<CDeterministicMNCPtr>& members) const;
|
||
|
bool VerifyNull(int nHeight) const;
|
||
|
bool VerifySizes(const Consensus::LLMQParams& params) const;
|
||
|
|
||
|
void ToJson(UniValue& obj) const;
|
||
|
|
||
|
public:
|
||
|
ADD_SERIALIZE_METHODS
|
||
|
|
||
|
template<typename Stream, typename Operation>
|
||
|
inline void SerializationOp(Stream& s, Operation ser_action)
|
||
|
{
|
||
|
READWRITE(nVersion);
|
||
|
READWRITE(llmqType);
|
||
|
READWRITE(quorumHash);
|
||
|
READWRITE(DYNBITSET(signers));
|
||
|
READWRITE(DYNBITSET(validMembers));
|
||
|
READWRITE(quorumPublicKey);
|
||
|
READWRITE(quorumVvecHash);
|
||
|
READWRITE(quorumSig);
|
||
|
READWRITE(membersSig);
|
||
|
}
|
||
|
|
||
|
public:
|
||
|
bool IsNull() const
|
||
|
{
|
||
|
if (std::count(signers.begin(), signers.end(), true) ||
|
||
|
std::count(validMembers.begin(), validMembers.end(), true)) {
|
||
|
return false;
|
||
|
}
|
||
|
if (quorumPublicKey.IsValid() ||
|
||
|
membersSig.IsValid() ||
|
||
|
quorumSig.IsValid()) {
|
||
|
return false;
|
||
|
}
|
||
|
return true;
|
||
|
}
|
||
|
};
|
||
|
|
||
|
}
|
||
|
|
||
|
#endif //DASH_QUORUMS_COMMITMENT_H
|