2018-02-13 13:36:36 +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_PROVIDERTX_H
|
|
|
|
#define DASH_PROVIDERTX_H
|
|
|
|
|
2018-10-21 21:45:16 +02:00
|
|
|
#include "bls/bls.h"
|
2018-11-06 09:54:23 +01:00
|
|
|
#include "consensus/validation.h"
|
|
|
|
#include "primitives/transaction.h"
|
2018-02-13 13:36:36 +01:00
|
|
|
|
|
|
|
#include "netaddress.h"
|
|
|
|
#include "pubkey.h"
|
|
|
|
|
|
|
|
class CBlockIndex;
|
|
|
|
class UniValue;
|
|
|
|
|
|
|
|
class CProRegTx
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
static const uint16_t CURRENT_VERSION = 1;
|
|
|
|
|
|
|
|
public:
|
2018-11-06 09:54:23 +01:00
|
|
|
uint16_t nVersion{CURRENT_VERSION}; // message version
|
|
|
|
uint16_t nType{0}; // only 0 supported for now
|
|
|
|
uint16_t nMode{0}; // only 0 supported for now
|
2018-10-25 16:29:50 +02:00
|
|
|
COutPoint collateralOutpoint{uint256(), (uint32_t)-1}; // if hash is null, we refer to a ProRegTx output
|
2018-02-13 13:36:36 +01:00
|
|
|
CService addr;
|
|
|
|
CKeyID keyIDOwner;
|
2018-10-21 21:45:16 +02:00
|
|
|
CBLSPublicKey pubKeyOperator;
|
2018-02-13 13:36:36 +01:00
|
|
|
CKeyID keyIDVoting;
|
|
|
|
uint16_t nOperatorReward{0};
|
|
|
|
CScript scriptPayout;
|
|
|
|
uint256 inputsHash; // replay protection
|
|
|
|
std::vector<unsigned char> vchSig;
|
|
|
|
|
|
|
|
public:
|
|
|
|
ADD_SERIALIZE_METHODS;
|
|
|
|
|
|
|
|
template <typename Stream, typename Operation>
|
|
|
|
inline void SerializationOp(Stream& s, Operation ser_action)
|
|
|
|
{
|
|
|
|
READWRITE(nVersion);
|
2018-10-23 13:15:38 +02:00
|
|
|
READWRITE(nType);
|
|
|
|
READWRITE(nMode);
|
2018-10-25 16:29:50 +02:00
|
|
|
READWRITE(collateralOutpoint);
|
2018-02-13 13:36:36 +01:00
|
|
|
READWRITE(addr);
|
|
|
|
READWRITE(keyIDOwner);
|
2018-10-21 21:45:16 +02:00
|
|
|
READWRITE(pubKeyOperator);
|
2018-02-13 13:36:36 +01:00
|
|
|
READWRITE(keyIDVoting);
|
|
|
|
READWRITE(nOperatorReward);
|
2018-10-25 09:17:02 +02:00
|
|
|
READWRITE(*(CScriptBase*)(&scriptPayout));
|
2018-02-13 13:36:36 +01:00
|
|
|
READWRITE(inputsHash);
|
|
|
|
if (!(s.GetType() & SER_GETHASH)) {
|
|
|
|
READWRITE(vchSig);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-11-01 22:57:10 +01:00
|
|
|
// When signing with the collateral key, we don't sign the hash but a generated message instead
|
|
|
|
// This is needed for HW wallet support which can only sign text messages as of now
|
|
|
|
std::string MakeSignString() const;
|
|
|
|
|
2018-02-13 13:36:36 +01:00
|
|
|
std::string ToString() const;
|
|
|
|
void ToJson(UniValue& obj) const;
|
|
|
|
};
|
|
|
|
|
2018-03-12 12:14:11 +01:00
|
|
|
class CProUpServTx
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
static const uint16_t CURRENT_VERSION = 1;
|
|
|
|
|
|
|
|
public:
|
|
|
|
uint16_t nVersion{CURRENT_VERSION}; // message version
|
|
|
|
uint256 proTxHash;
|
|
|
|
CService addr;
|
|
|
|
CScript scriptOperatorPayout;
|
|
|
|
uint256 inputsHash; // replay protection
|
2018-10-21 21:45:16 +02:00
|
|
|
CBLSSignature sig;
|
2018-03-12 12:14:11 +01:00
|
|
|
|
|
|
|
public:
|
|
|
|
ADD_SERIALIZE_METHODS;
|
|
|
|
|
|
|
|
template <typename Stream, typename Operation>
|
|
|
|
inline void SerializationOp(Stream& s, Operation ser_action)
|
|
|
|
{
|
|
|
|
READWRITE(nVersion);
|
|
|
|
READWRITE(proTxHash);
|
|
|
|
READWRITE(addr);
|
|
|
|
READWRITE(*(CScriptBase*)(&scriptOperatorPayout));
|
|
|
|
READWRITE(inputsHash);
|
|
|
|
if (!(s.GetType() & SER_GETHASH)) {
|
2018-10-21 21:45:16 +02:00
|
|
|
READWRITE(sig);
|
2018-03-12 12:14:11 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public:
|
|
|
|
std::string ToString() const;
|
|
|
|
void ToJson(UniValue& obj) const;
|
|
|
|
};
|
|
|
|
|
2018-03-19 08:44:00 +01:00
|
|
|
class CProUpRegTx
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
static const uint16_t CURRENT_VERSION = 1;
|
|
|
|
|
|
|
|
public:
|
|
|
|
uint16_t nVersion{CURRENT_VERSION}; // message version
|
|
|
|
uint256 proTxHash;
|
2018-10-23 13:15:38 +02:00
|
|
|
uint16_t nMode{0}; // only 0 supported for now
|
2018-10-21 21:45:16 +02:00
|
|
|
CBLSPublicKey pubKeyOperator;
|
2018-03-19 08:44:00 +01:00
|
|
|
CKeyID keyIDVoting;
|
|
|
|
CScript scriptPayout;
|
|
|
|
uint256 inputsHash; // replay protection
|
|
|
|
std::vector<unsigned char> vchSig;
|
|
|
|
|
|
|
|
public:
|
|
|
|
ADD_SERIALIZE_METHODS;
|
|
|
|
|
|
|
|
template <typename Stream, typename Operation>
|
|
|
|
inline void SerializationOp(Stream& s, Operation ser_action)
|
|
|
|
{
|
|
|
|
READWRITE(nVersion);
|
|
|
|
READWRITE(proTxHash);
|
2018-10-23 13:15:38 +02:00
|
|
|
READWRITE(nMode);
|
2018-10-21 21:45:16 +02:00
|
|
|
READWRITE(pubKeyOperator);
|
2018-03-19 08:44:00 +01:00
|
|
|
READWRITE(keyIDVoting);
|
|
|
|
READWRITE(*(CScriptBase*)(&scriptPayout));
|
|
|
|
READWRITE(inputsHash);
|
|
|
|
if (!(s.GetType() & SER_GETHASH)) {
|
|
|
|
READWRITE(vchSig);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public:
|
|
|
|
std::string ToString() const;
|
|
|
|
void ToJson(UniValue& obj) const;
|
|
|
|
};
|
|
|
|
|
2018-03-19 12:29:59 +01:00
|
|
|
class CProUpRevTx
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
static const uint16_t CURRENT_VERSION = 1;
|
|
|
|
|
|
|
|
// these are just informational and do not have any effect on the revocation
|
|
|
|
enum {
|
|
|
|
REASON_NOT_SPECIFIED = 0,
|
|
|
|
REASON_TERMINATION_OF_SERVICE = 1,
|
|
|
|
REASON_COMPROMISED_KEYS = 2,
|
|
|
|
REASON_CHANGE_OF_KEYS = 3,
|
|
|
|
REASON_LAST = REASON_CHANGE_OF_KEYS
|
|
|
|
};
|
|
|
|
|
|
|
|
public:
|
|
|
|
uint16_t nVersion{CURRENT_VERSION}; // message version
|
|
|
|
uint256 proTxHash;
|
|
|
|
uint16_t nReason{REASON_NOT_SPECIFIED};
|
|
|
|
uint256 inputsHash; // replay protection
|
2018-10-21 21:45:16 +02:00
|
|
|
CBLSSignature sig;
|
2018-03-19 12:29:59 +01:00
|
|
|
|
|
|
|
public:
|
|
|
|
ADD_SERIALIZE_METHODS;
|
|
|
|
|
|
|
|
template <typename Stream, typename Operation>
|
|
|
|
inline void SerializationOp(Stream& s, Operation ser_action)
|
|
|
|
{
|
|
|
|
READWRITE(nVersion);
|
|
|
|
READWRITE(proTxHash);
|
|
|
|
READWRITE(nReason);
|
|
|
|
READWRITE(inputsHash);
|
|
|
|
if (!(s.GetType() & SER_GETHASH)) {
|
2018-10-21 21:45:16 +02:00
|
|
|
READWRITE(sig);
|
2018-03-19 12:29:59 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public:
|
|
|
|
std::string ToString() const;
|
|
|
|
void ToJson(UniValue& obj) const;
|
|
|
|
};
|
|
|
|
|
2018-03-19 08:44:00 +01:00
|
|
|
|
2018-02-13 13:36:36 +01:00
|
|
|
bool CheckProRegTx(const CTransaction& tx, const CBlockIndex* pindexPrev, CValidationState& state);
|
2018-03-12 12:14:11 +01:00
|
|
|
bool CheckProUpServTx(const CTransaction& tx, const CBlockIndex* pindexPrev, CValidationState& state);
|
2018-03-19 08:44:00 +01:00
|
|
|
bool CheckProUpRegTx(const CTransaction& tx, const CBlockIndex* pindexPrev, CValidationState& state);
|
2018-03-19 12:29:59 +01:00
|
|
|
bool CheckProUpRevTx(const CTransaction& tx, const CBlockIndex* pindexPrev, CValidationState& state);
|
2018-02-13 13:36:36 +01:00
|
|
|
|
2018-11-06 09:54:23 +01:00
|
|
|
#endif //DASH_PROVIDERTX_H
|