Hush Full Node software. We were censored from Github, this is where all development happens now.
https://hush.is
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
79 lines
3.1 KiB
79 lines
3.1 KiB
// Copyright (c) 2018 Michael Toutonghi
|
|
// Distributed under the MIT software license, see the accompanying
|
|
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
|
|
|
/******************************************************************************
|
|
* Copyright © 2014-2019 The SuperNET Developers. *
|
|
* *
|
|
* See the AUTHORS, DEVELOPER-AGREEMENT and LICENSE files at *
|
|
* the top-level directory of this distribution for the individual copyright *
|
|
* holder information and the developer policies on copyright and licensing. *
|
|
* *
|
|
* Unless otherwise agreed in a custom licensing agreement, no part of the *
|
|
* SuperNET software, including this file may be copied, modified, propagated *
|
|
* or distributed except according to the terms contained in the LICENSE file *
|
|
* *
|
|
* Removal or modification of this copyright notice is prohibited. *
|
|
* *
|
|
******************************************************************************/
|
|
|
|
#ifndef BITCOIN_PRIMITIVES_NONCE_H
|
|
#define BITCOIN_PRIMITIVES_NONCE_H
|
|
|
|
#include "serialize.h"
|
|
#include "uint256.h"
|
|
#include "arith_uint256.h"
|
|
|
|
|
|
/** For POS blocks, the nNonce of a block header holds the entropy source for the POS contest
|
|
* in the latest VerusHash protocol
|
|
* */
|
|
class CPOSNonce : public uint256
|
|
{
|
|
public:
|
|
static bool NewPOSActive(int32_t height);
|
|
static bool NewNonceActive(int32_t height);
|
|
|
|
static arith_uint256 entropyMask;
|
|
static arith_uint256 posDiffMask;
|
|
|
|
CPOSNonce() : uint256() { }
|
|
CPOSNonce(const base_blob<256> &b) : uint256(b) { }
|
|
CPOSNonce(const std::vector<unsigned char> &vch) : uint256(vch) { }
|
|
|
|
int32_t GetPOSTarget() const
|
|
{
|
|
uint32_t nBits = 0;
|
|
|
|
for (const unsigned char *p = begin() + 3; p >= begin(); p--)
|
|
{
|
|
nBits <<= 8;
|
|
nBits += *p;
|
|
}
|
|
return nBits;
|
|
}
|
|
|
|
bool IsPOSNonce() const
|
|
{
|
|
arith_uint256 arNonce = UintToArith256(*this);
|
|
arith_uint256 tmpNonce = ((arNonce << 128) >> 128);
|
|
CVerusHashWriter hashWriter = CVerusHashWriter(SER_GETHASH, PROTOCOL_VERSION);
|
|
hashWriter << ArithToUint256(tmpNonce);
|
|
return (*this == ArithToUint256(UintToArith256(hashWriter.GetHash()) << 128 | tmpNonce));
|
|
}
|
|
|
|
void SetPOSTarget(uint32_t nBits)
|
|
{
|
|
CVerusHashWriter hashWriter = CVerusHashWriter(SER_GETHASH, PROTOCOL_VERSION);
|
|
|
|
arith_uint256 arNonce = (UintToArith256(*this) & entropyMask) | nBits;
|
|
hashWriter << ArithToUint256(arNonce);
|
|
|
|
(uint256 &)(*this) = ArithToUint256(UintToArith256(hashWriter.GetHash()) << 128 | arNonce);
|
|
}
|
|
|
|
void SetPOSEntropy(const uint256 &pastHash, uint256 txid, int32_t voutNum);
|
|
bool CheckPOSEntropy(const uint256 &pastHash, uint256 txid, int32_t voutNum);
|
|
};
|
|
|
|
#endif // BITCOIN_PRIMITIVES_NONCE_H
|
|
|