// 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 signers; std::vector 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& members, bool checkSigs) const; bool VerifyNull() const; bool VerifySizes(const Consensus::LLMQParams& params) const; void ToJson(UniValue& obj) const; public: ADD_SERIALIZE_METHODS template 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() || !quorumVvecHash.IsNull() || membersSig.IsValid() || quorumSig.IsValid()) { return false; } return true; } }; 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 inline void SerializationOp(Stream& s, Operation ser_action) { READWRITE(nVersion); READWRITE(nHeight); READWRITE(commitment); } }; bool CheckLLMQCommitment(const CTransaction& tx, const CBlockIndex* pindexPrev, CValidationState& state); } #endif //DASH_QUORUMS_COMMITMENT_H