2018-11-23 15:42:09 +01:00
|
|
|
// 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);
|
|
|
|
}
|
|
|
|
|
2018-11-27 08:04:08 +01:00
|
|
|
bool Verify(const std::vector<CDeterministicMNCPtr>& members, bool checkSigs) const;
|
|
|
|
bool VerifyNull() const;
|
2018-11-23 15:42:09 +01:00
|
|
|
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() ||
|
2018-11-27 08:04:08 +01:00
|
|
|
!quorumVvecHash.IsNull() ||
|
2018-11-23 15:42:09 +01:00
|
|
|
membersSig.IsValid() ||
|
|
|
|
quorumSig.IsValid()) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2018-11-27 08:04:08 +01:00
|
|
|
class CFinalCommitmentTxPayload
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
static const uint16_t CURRENT_VERSION = 1;
|
|
|
|
|
|
|
|
public:
|
|
|
|
uint16_t nVersion{CURRENT_VERSION};
|
|
|
|
uint32_t nHeight{(uint32_t)-1};
|
|
|
|
CFinalCommitment commitment;
|
|
|
|
|
|
|
|
public:
|
|
|
|
ADD_SERIALIZE_METHODS
|
|
|
|
|
|
|
|
template<typename Stream, typename Operation>
|
|
|
|
inline void SerializationOp(Stream& s, Operation ser_action)
|
|
|
|
{
|
|
|
|
READWRITE(nVersion);
|
|
|
|
READWRITE(nHeight);
|
|
|
|
READWRITE(commitment);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
bool CheckLLMQCommitment(const CTransaction& tx, const CBlockIndex* pindexPrev, CValidationState& state);
|
|
|
|
|
2018-11-23 15:42:09 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
#endif //DASH_QUORUMS_COMMITMENT_H
|