Documentation ¶
Overview ¶
Package chaindata: Functions related to Block Serial ID feature.
BlockHashToSerialID is the name of the db bucket used to house the mapping of block hash to serial id. SerialIDToPrevBlock is the name of the db bucket used to house the mapping of block serial id to hash and previous serial id.
| bucket | Key | Value | | ------------------------------ | ---------- | --------------- | | SerialIDToPrevBlock | serialID | {hash; prev_id} | | BlockHashToSerialID | block_hash | serialID |
Copyright (c) 2015-2016 The btcsuite developers Copyright (c) 2020 The JaxNetwork developers Use of this source code is governed by an ISC license that can be found in the LICENSE file. nolint: gomnd
Copyright (c) 2020 The JaxNetwork developers Use of this source code is governed by an ISC license that can be found in the LICENSE file.
Index ¶
- Constants
- Variables
- func BTCCoinbaseScript(nextBlockHeight int64, extraNonce, beaconHash []byte) ([]byte, error)
- func BtcCalcBlockSubsidy(height int32, chainParams *chaincfg.Params) int64
- func BuildMerkleTreeStore(transactions []*jaxutil.Tx, witness bool) []*chainhash.Hash
- func CalcShardBlockSubsidy(shards, bits, k uint32) int64
- func CheckBlockSanity(block *jaxutil.Block, chainParams *chaincfg.Params, ...) error
- func CheckBlockSanityWF(block *jaxutil.Block, chainParams *chaincfg.Params, ...) error
- func CheckBlockScripts(block *jaxutil.Block, utxoView *UtxoViewpoint, ...) error
- func CheckProofOfWork(block *jaxutil.Block, chainCfg *chaincfg.Params) error
- func CheckSerializedHeight(coinbaseTx *jaxutil.Tx, wantHeight int32) error
- func CheckTransactionInputs(tx *jaxutil.Tx, txHeight int32, utxoView *UtxoViewpoint, ...) (int64, error)
- func CheckTransactionSanity(tx *jaxutil.Tx) error
- func CollectTxHashes(transactions []*jaxutil.Tx, witness bool) []chainhash.Hash
- func CountP2SHSigOps(tx *jaxutil.Tx, isCoinBaseTx bool, utxoView *UtxoViewpoint) (int, error)
- func CountSigOps(tx *jaxutil.Tx) int
- func CountSpentOutputs(block *jaxutil.Block) int
- func CreateBitcoinCoinbaseTx(value, fee int64, nextHeight int32, addr jaxutil.Address, beaconHash []byte, ...) (*jaxutil.Tx, error)
- func CreateCoinbaseTx(value int64, nextHeight int32, shardID uint32, addr jaxutil.Address) (*jaxutil.Tx, error)
- func CreateJaxCoinbaseTx(value, fee int64, height int32, shardID uint32, addr jaxutil.Address, ...) (*jaxutil.Tx, error)
- func CreateJaxCoinbaseTxWithBurn(value, fee int64, height int32, shardID uint32, addr jaxutil.Address, ...) (*jaxutil.Tx, error)
- func DBFetchAllEADAddresses(dbTx database.Tx) (map[string]*wire.EADAddresses, error)
- func DBFetchBlockByNode(dbTx database.Tx, node blocknodes.IBlockNode) (*jaxutil.Block, error)
- func DBFetchBlockHashBySerialID(dbTx database.Tx, serialID int64) (*chainhash.Hash, int64, error)
- func DBFetchBlockSerialID(dbTx database.Tx, hash *chainhash.Hash) (int64, int64, error)
- func DBFetchEADAddresses(dbTx database.Tx, ownerPK string) (*wire.EADAddresses, error)
- func DBFetchHeightByHash(dbTx database.Tx, hash *chainhash.Hash) (int32, error)
- func DBFetchOrCreateVersion(dbTx database.Tx, key []byte, defaultVersion uint32) (uint32, error)
- func DBFetchUtxoEntries(dbTx database.Tx, limit int) (map[wire.OutPoint]*UtxoEntry, error)
- func DBGetBlocksMMRRoots(dbTx database.Tx) (map[chainhash.Hash]chainhash.Hash, error)
- func DBGetMMRRootForBlock(dbTx database.Tx, blockHash *chainhash.Hash) (chainhash.Hash, error)
- func DBGetShardGenesisInfo(dbTx database.Tx) (map[uint32]ShardInfo, uint32)
- func DBPutBestState(dbTx database.Tx, snapshot *BestState, workSum *big.Int) error
- func DBPutBlockHashToSerialID(dbTx database.Tx, hash chainhash.Hash, serialID int64) error
- func DBPutBlockIndex(dbTx database.Tx, hash *chainhash.Hash, height int32) error
- func DBPutEADAddresses(dbTx database.Tx, updateSet map[string]*wire.EADAddresses) error
- func DBPutHashToSerialIDWithPrev(dbTx database.Tx, hash chainhash.Hash, serialID, prevSerialID int64) error
- func DBPutMMRRoot(dbTx database.Tx, mmrRoot, blockHash chainhash.Hash) error
- func DBPutSerialIDsList(dbTx database.Tx, serialIDs []int64) error
- func DBPutSpendJournalEntry(dbTx database.Tx, blockHash *chainhash.Hash, stxos []SpentTxOut) error
- func DBPutUtxoView(dbTx database.Tx, view *UtxoViewpoint) error
- func DBPutVersion(dbTx database.Tx, key []byte, version uint32) error
- func DBRemoveBlockIndex(dbTx database.Tx, hash *chainhash.Hash, height int32) error
- func DBRemoveSpendJournalEntry(dbTx database.Tx, blockHash *chainhash.Hash) error
- func DBStoreBlock(dbTx database.Tx, block *jaxutil.Block) error
- func DBStoreBlockNode(dbTx database.Tx, node blocknodes.IBlockNode) error
- func DBStoreLastShardInfo(dbTx database.Tx, shardID uint32) error
- func DBStoreShardGenesisInfo(dbTx database.Tx, shardID uint32, blockHeight int32, blockHash *chainhash.Hash, ...) error
- func DeserializeBlockRow(blockRow []byte) (wire.BlockHeader, blocknodes.BlockStatus, int64, error)
- func DisableLog()
- func ExtractCoinbaseHeight(coinbaseTx *jaxutil.Tx) (int32, error)
- func ExtractWitnessCommitment(tx *jaxutil.Tx) ([]byte, bool)
- func GetBlockWeight(blk *jaxutil.Block) int64
- func GetSigOpCost(tx *jaxutil.Tx, isCoinBaseTx bool, utxoView *UtxoViewpoint, bip16, segWit bool) (int, error)
- func GetTransactionWeight(tx *jaxutil.Tx) int64
- func IsCoinBase(tx *jaxutil.Tx) bool
- func IsCoinBaseTx(msgTx *wire.MsgTx) bool
- func IsDeserializeErr(err error) bool
- func IsFinalizedTransaction(tx *jaxutil.Tx, blockHeight int32, blockTime time.Time) bool
- func IsNotInMainChainErr(err error) bool
- func MigrateBlockIndex(db database.DB) error
- func SequenceLockActive(sequenceLock *SequenceLock, blockHeight int32, medianTimePast time.Time) bool
- func ShouldHaveSerializedBlockHeight(header wire.BlockHeader) bool
- func StandardCoinbaseScript(nextBlockHeight int32, shardID uint32, extraNonce uint64) ([]byte, error)
- func UpgradeUtxoSetToV2(db database.DB, interrupt <-chan struct{}) error
- func UseLogger(logger zerolog.Logger)
- func ValidMoneyBackAfterExpiration(tx *jaxutil.Tx, view *UtxoViewpoint) bool
- func ValidateBTCCoinbase(aux *wire.BTCBlockAux) (rewardBurned bool, err error)
- func ValidateBeaconCoinbase(aux *wire.BeaconHeader, coinbase *wire.MsgTx, expectedReward int64) (bool, error)
- func ValidateShardCoinbase(shardHeader *wire.ShardHeader, shardCoinbaseTx *wire.MsgTx, ...) error
- func ValidateSwapTxStructure(tx *wire.MsgTx, missedUTXO int) error
- func ValidateTransactionScripts(tx *jaxutil.Tx, utxoView *UtxoViewpoint, flags txscript.ScriptFlags, ...) error
- func ValidateVoteK(header wire.BlockHeader) error
- func ValidateWitnessCommitment(blk *jaxutil.Block) error
- type AssertError
- type BTCBlockGen
- type BeaconBlockGenerator
- func (c *BeaconBlockGenerator) CalcBlockSubsidy(height int32, difficulty uint32, header wire.BlockHeader) int64
- func (c *BeaconBlockGenerator) NewBlockHeader(version wire.BVersion, height int32, ...) (wire.BlockHeader, error)
- func (c *BeaconBlockGenerator) ValidateJaxAuxRules(block *wire.MsgBlock, height int32) error
- type BeaconBlockProvider
- type BehaviorFlags
- type BestChainBlockRecord
- type BestChainState
- type BestState
- type BlockTemplate
- type BtcGen
- type ChainBlockGenerator
- type DeploymentError
- type ErrDeserialize
- type ErrNotInMainChain
- type ErrorCode
- type MedianTimeSource
- type RuleError
- type SequenceLock
- type SerialIDBlockMeta
- type ShardBlockGenerator
- func (c *ShardBlockGenerator) CalcBlockSubsidy(height int32, difficulty uint32, header wire.BlockHeader) int64
- func (c *ShardBlockGenerator) NewBlockHeader(_ wire.BVersion, height int32, ...) (wire.BlockHeader, error)
- func (c *ShardBlockGenerator) ValidateJaxAuxRules(block *wire.MsgBlock, height int32) error
- func (c *ShardBlockGenerator) ValidateMergeMiningData(header wire.BlockHeader) error
- type ShardInfo
- type SpentTxOut
- type StateProvider
- type UtxoEntry
- type UtxoViewpoint
- func (view *UtxoViewpoint) AddTxOut(tx *jaxutil.Tx, txOutIdx uint32, blockHeight int32)
- func (view *UtxoViewpoint) AddTxOuts(tx *jaxutil.Tx, blockHeight int32)
- func (view *UtxoViewpoint) BestHash() *chainhash.Hash
- func (view *UtxoViewpoint) Commit()
- func (view *UtxoViewpoint) ConnectTransaction(tx *jaxutil.Tx, blockHeight int32, stxos *[]SpentTxOut) error
- func (view *UtxoViewpoint) ConnectTransactions(block *jaxutil.Block, stxos *[]SpentTxOut) error
- func (view *UtxoViewpoint) DisconnectTransactions(db database.DB, block *jaxutil.Block, prevHash chainhash.Hash, ...) error
- func (view *UtxoViewpoint) EADAddressesSet() map[string]*wire.EADAddresses
- func (view *UtxoViewpoint) Entries() map[wire.OutPoint]*UtxoEntry
- func (view *UtxoViewpoint) FetchInputUtxos(db database.DB, block *jaxutil.Block) error
- func (view *UtxoViewpoint) FetchUtxos(db database.DB, outpoints map[wire.OutPoint]struct{}) error
- func (view *UtxoViewpoint) FetchUtxosMain(db database.DB, outpoints map[wire.OutPoint]struct{}) error
- func (view *UtxoViewpoint) LookupEntry(outpoint wire.OutPoint) *UtxoEntry
- func (view *UtxoViewpoint) RemoveEntry(outpoint wire.OutPoint)
- func (view *UtxoViewpoint) SetBestHash(hash *chainhash.Hash)
Constants ¶
const ( // LatestUtxoSetBucketVersion is the current version of the utxo set // bucket that is used to track all unspent outputs. LatestUtxoSetBucketVersion = 2 // LatestSpendJournalBucketVersion is the current version of the spend // journal bucket that is used to track all spent transactions for use // in reorgs. LatestSpendJournalBucketVersion = 1 )
const ( // CoinbaseWitnessDataLen is the required length of the only element within // the coinbase's witness data if the coinbase transaction contains a // witness commitment. CoinbaseWitnessDataLen = 32 // CoinbaseWitnessPkScriptLength is the length of the public key script // containing an OP_RETURN, the WitnessMagicBytes, and the witness // commitment itself. In order to be a valid candidate for the output // containing the witness commitment CoinbaseWitnessPkScriptLength = 38 )
const ( // MaxTimeOffsetSeconds is the maximum number of seconds a block time // is allowed to be ahead of the current time. This is currently 2 // hours. MaxTimeOffsetSeconds = 2 * 60 * 60 // MinCoinbaseScriptLen is the minimum length a coinbase script can be. MinCoinbaseScriptLen = 2 // MaxCoinbaseScriptLen is the maximum length a coinbase script can be. MaxCoinbaseScriptLen = 100 )
const ( // MaxBlockWeight defines the maximum block weight, where "block // weight" is interpreted as defined in BIP0141. A block's weight is // calculated as the sum of the of bytes in the existing transactions // and header, plus the weight of each byte within a transaction. The // weight of a "base" byte is 4, while the weight of a witness byte is // 1. As a result, for a block to be valid, the BlockWeight MUST be // less than, or equal to MaxBlockWeight. MaxBlockWeight = 4000000 // MaxBlockBaseSize is the maximum number of bytes within a block // which can be allocated to non-witness data. MaxBlockBaseSize = 1000000 // MaxBlockSigOpsCost is the maximum number of signature operations // allowed for a block. It is calculated via a weighted algorithm which // weights segregated witness sig ops lower than regular sig ops. MaxBlockSigOpsCost = 80000 // WitnessScaleFactor determines the level of "discount" witness data // receives compared to "base" data. A scale factor of 4, denotes that // witness data is 1/4 as cheap as regular non-witness data. WitnessScaleFactor = 4 // MinTxOutputWeight is the minimum possible weight for a transaction // output. MinTxOutputWeight = WitnessScaleFactor * wire.MinTxOutPayload // MaxOutputsPerBlock is the maximum number of transaction outputs there // can be in a block of max weight size. MaxOutputsPerBlock = MaxBlockWeight / MinTxOutputWeight )
const CoinbaseFlags = "/P2SH/jaxnetd/"
CoinbaseFlags is added to the coinbase script of a generated block and is used to monitor BIP16 support as well as blocks that are generated via jaxnetd.
const JaxnetScriptSigMarker = "6a61786e6574" // "jaxnet" in hex
Variables ¶
var ( // BlockIndexBucketName is the name of the db bucket used to house to the // block headers and contextual information. BlockIndexBucketName = []byte("blockheaderidx") // HashIndexBucketName is the name of the db bucket used to house to the // [block Hash] -> [block height] index. HashIndexBucketName = []byte("hashidx") // HeightIndexBucketName is the name of the db bucket used to house to the // [block height] -> [block Hash] index. HeightIndexBucketName = []byte("heightidx") // ChainStateKeyName is the name of the db key used to store the best // chain state. ChainStateKeyName = []byte("chainstate") // MMRRootsToHashBucketName is unordered storage of mmr root and // corresponding last block hash for this root. // [mmr root hash] -> [block Hash] MMRRootsToHashBucketName = []byte("mmr_root_to_hash") // HashToMMRRootBucketName is unordered storage of block hash and // corresponding mmr root for this block. // [mmr root hash] -> [block Hash] // [block Hash] -> [mmr root hash] HashToMMRRootBucketName = []byte("hash_to_mmr_root") // BlockHashToSerialID is the name of the db bucket used to house the // [block Hash] -> [serial id] index. BlockHashToSerialID = []byte("hash_to_serialid") // SerialIDToPrevBlock is the name of the db bucket used to house the // block serial id to hash and previous serial id. // [serial id] -> [block Hash; previous serial id] SerialIDToPrevBlock = []byte("serialid_to_prev_block") // SpendJournalVersionKeyName is the name of the db key used to store // the version of the spend journal currently in the database. SpendJournalVersionKeyName = []byte("spendjournalversion") // SpendJournalBucketName is the name of the db bucket used to house // transactions outputs that are spent in each block. SpendJournalBucketName = []byte("spendjournal") // UtxoSetVersionKeyName is the name of the db key used to store the // version of the utxo set currently in the database. UtxoSetVersionKeyName = []byte("utxosetversion") // UtxoSetBucketName is the name of the db bucket used to house the // unspent transaction output set. UtxoSetBucketName = []byte("utxosetv2") // EADAddressesBucketNameV2 is the name of the db bucket used to house the // net addresses of Exchange Agents. EADAddressesBucketNameV2 = []byte("ead_addresses_v2") // BestChainSerialIDsBucketName - is the name of the db bucket used to house the // list of serialIDs of the blocks in the best chain. Values are written to it on node shutdown. // Bucket is used for quick catch-up launch BestChainSerialIDsBucketName = []byte("bestchain_serialids") ShardCreationsBucketName = []byte("shard_creations") )
var JaxnetScriptSigMarkerBytes = []byte{0x6a, 0x61, 0x78, 0x6e, 0x65, 0x74}
var WitnessMagicBytes = []byte{ txscript.OP_RETURN, txscript.OP_DATA_36, 0xaa, 0x21, 0xa9, 0xed, }
WitnessMagicBytes is the prefix marker within the public key script of a coinbase output to indicate that this output holds the witness commitment for a block.
Functions ¶
func BTCCoinbaseScript ¶ added in v0.4.0
BTCCoinbaseScript returns a standard script suitable for use as the signature script of the coinbase transaction of a new block. In particular, it starts with the block height that is required by version 2 blocks and adds the extra nonce as well as additional coinbase flags.
func BtcCalcBlockSubsidy ¶ added in v0.4.0
BtcCalcBlockSubsidy returns the subsidy amount a block at the provided height should have. This is mainly used for determining how much the coinbase for newly generated blocks awards as well as validating the coinbase for blocks has the expected value.
The subsidy is halved every SubsidyReductionInterval blocks. Mathematically this is: btcBaseSubsidy / 2^(height/SubsidyReductionInterval)
At the target block generation rate for the main network, this is approximately every 4 years. nolint: gomnd
func BuildMerkleTreeStore ¶
BuildMerkleTreeStore creates a merkle tree from a slice of transactions, stores it using a linear array, and returns a slice of the backing array. A linear array was chosen as opposed to an actual tree structure since it uses about half as much memory. The following describes a merkle tree and how it is stored in a linear array.
A merkle tree is a tree in which every non-leaf node is the Hash of its children nodes. A diagram depicting how this works for bitcoin transactions where h(x) is a double sha256 follows:
root = h1234 = h(h12 + h34) / \ h12 = h(h1 + h2) h34 = h(h3 + h4) / \ / \ h1 = h(tx1) h2 = h(tx2) h3 = h(tx3) h4 = h(tx4)
The above stored as a linear array is as follows:
[h1 h2 h3 h4 h12 h34 root]
As the above shows, the merkle root is always the last element in the array.
The number of inputs is not always a power of two which results in a balanced tree structure as above. In that case, parent nodes with no children are also zero and parent nodes with only a single left node are calculated by concatenating the left node with itself before hashing. Since this function uses nodes that are pointers to the hashes, empty nodes will be nil.
The additional bool parameter indicates if we are generating the merkle tree using witness transaction id's rather than regular transaction id's. This also presents an additional case wherein the wtxid of the coinbase transaction is the zeroHash.
func CalcShardBlockSubsidy ¶ added in v0.4.0
CalcShardBlockSubsidy returns reward for shard block. - height is block height; - shards is a number of shards that were mined by a miner at the time; - bits is current target; - k is inflation-fix-coefficient.
func CheckBlockSanity ¶
func CheckBlockSanity(block *jaxutil.Block, chainParams *chaincfg.Params, timeSource MedianTimeSource) error
CheckBlockSanity performs some preliminary checks on a block to ensure it is sane before continuing with block processing. These checks are context free.
func CheckBlockSanityWF ¶
func CheckBlockSanityWF(block *jaxutil.Block, chainParams *chaincfg.Params, timeSource MedianTimeSource, flags BehaviorFlags) error
CheckBlockSanityWF performs some preliminary checks on a block to ensure it is sane before continuing with block processing. These checks are context free.
The flags do not modify the behavior of this function directly, however they are needed to pass along to checkBlockHeaderSanity.
func CheckBlockScripts ¶
func CheckBlockScripts(block *jaxutil.Block, utxoView *UtxoViewpoint, scriptFlags txscript.ScriptFlags, sigCache *txscript.SigCache, hashCache *txscript.HashCache) error
CheckBlockScripts executes and validates the scripts for all transactions in the passed block using multiple goroutines.
func CheckProofOfWork ¶
CheckProofOfWork ensures the block header bits which indicate the target difficulty is in min/max range and that the block Hash is less than the target difficulty as claimed.
func CheckSerializedHeight ¶
CheckSerializedHeight checks if the signature script in the passed transaction starts with the serialized block height of wantHeight.
func CheckTransactionInputs ¶
func CheckTransactionInputs(tx *jaxutil.Tx, txHeight int32, utxoView *UtxoViewpoint, chainParams *chaincfg.Params) (int64, error)
CheckTransactionInputs performs a series of checks on the inputs to a transaction to ensure they are valid. An example of some of the checks include verifying all inputs exist, ensuring the coinbase seasoning requirements are met, detecting double spends, validating all values and fees are in the legal range and the total output amount doesn't exceed the input amount, and verifying the signatures to prove the spender was the owner of the bitcoins and therefore allowed to spend them. As it checks the inputs, it also calculates the total fees for the transaction and returns that value.
NOTE: The transaction MUST have already been sanity checked with the CheckTransactionSanity function prior to calling this function.
func CheckTransactionSanity ¶
CheckTransactionSanity performs some preliminary checks on a transaction to ensure it is sane. These checks are context free.
func CollectTxHashes ¶ added in v0.4.2
func CountP2SHSigOps ¶
CountP2SHSigOps returns the number of signature operations for all input transactions which are of the pay-to-script-Hash type. This uses the precise, signature operation counting mechanism from the script engine which requires access to the input transaction scripts.
func CountSigOps ¶
CountSigOps returns the number of signature operations for all transaction input and output scripts in the provided transaction. This uses the quicker, but imprecise, signature operation counting mechanism from txscript.
func CountSpentOutputs ¶
CountSpentOutputs returns the number of utxos the passed block spends.
func CreateBitcoinCoinbaseTx ¶ added in v0.4.0
func CreateCoinbaseTx ¶ added in v0.4.0
func CreateCoinbaseTx(value int64, nextHeight int32, shardID uint32, addr jaxutil.Address) (*jaxutil.Tx, error)
CreateCoinbaseTx returns a coinbase transaction paying an appropriate subsidy based on the passed block height to the provided address. When the address is nil, the coinbase transaction will instead be redeemable by anyone.
See the comment for NewBlockTemplate for more information about why the nil address handling is useful.
func CreateJaxCoinbaseTx ¶ added in v0.4.0
func CreateJaxCoinbaseTxWithBurn ¶ added in v0.4.2
func DBFetchAllEADAddresses ¶
DBFetchAllEADAddresses ...
func DBFetchBlockByNode ¶
func DBFetchBlockByNode(dbTx database.Tx, node blocknodes.IBlockNode) (*jaxutil.Block, error)
DBFetchBlockByNode uses an existing database transaction to retrieve the raw block for the provided node, deserialize it, and return a jaxutil.Block with the height set.
func DBFetchBlockSerialID ¶
func DBFetchEADAddresses ¶
DBFetchEADAddresses ...
func DBFetchHeightByHash ¶
DBFetchHeightByHash uses an existing database transaction to retrieve the height for the provided Hash from the index.
func DBFetchOrCreateVersion ¶
DBFetchOrCreateVersion uses an existing database transaction to attempt to fetch the provided key from the metadata bucket as a version and in the case it doesn't exist, it adds the entry with the provided default version and returns that. This is useful during upgrades to automatically handle loading and adding version keys as necessary.
func DBFetchUtxoEntries ¶
func DBGetBlocksMMRRoots ¶ added in v0.4.3
func DBGetMMRRootForBlock ¶ added in v0.4.2
func DBGetShardGenesisInfo ¶ added in v0.4.3
func DBPutBestState ¶
DBPutBestState uses an existing database transaction to update the best chain state with the given parameters.
func DBPutBlockHashToSerialID ¶ added in v0.4.2
func DBPutBlockIndex ¶
DBPutBlockIndex uses an existing database transaction to update or add the block index entries for the Hash to height and height to Hash mappings for the provided values.
func DBPutEADAddresses ¶
DBPutEADAddresses ...
func DBPutHashToSerialIDWithPrev ¶ added in v0.4.2
func DBPutHashToSerialIDWithPrev(dbTx database.Tx, hash chainhash.Hash, serialID, prevSerialID int64) error
DBPutHashToSerialIDWithPrev stores block hash with corresponding serialID and serialID of prev_block.
| bucket | Key | Value | | ------------------------------ | ---------- | --------------- | | SerialIDToPrevBlock | serialID | {hash; prev_block_id} |
func DBPutMMRRoot ¶ added in v0.4.2
func DBPutSerialIDsList ¶ added in v0.4.3
func DBPutSpendJournalEntry ¶
DBPutSpendJournalEntry uses an existing database transaction to update the spend journal entry for the given block Hash using the provided slice of spent txouts. The spent txouts slice must contain an entry for every txout the transactions in the block spend in the order they are spent.
func DBPutUtxoView ¶
func DBPutUtxoView(dbTx database.Tx, view *UtxoViewpoint) error
DBPutUtxoView uses an existing database transaction to update the utxo set in the database based on the provided utxo view contents and state. In particular, only the entries that have been marked as modified are written to the database.
func DBPutVersion ¶
DBPutVersion uses an existing database transaction to update the provided key in the metadata bucket to the given version. It is primarily used to track versions on entities such as buckets.
func DBRemoveBlockIndex ¶
DBRemoveBlockIndex uses an existing database transaction remove block index entries from the Hash to height and height to Hash mappings for the provided values.
func DBRemoveSpendJournalEntry ¶
DBRemoveSpendJournalEntry uses an existing database transaction to remove the spend journal entry for the passed block Hash.
func DBStoreBlock ¶
DBStoreBlock stores the provided block in the database if it is not already there. The full block data is written to ffldb.
func DBStoreBlockNode ¶
func DBStoreBlockNode(dbTx database.Tx, node blocknodes.IBlockNode) error
DBStoreBlockNode stores the block header and validation status to the block index bucket. This overwrites the current entry if there exists one.
func DBStoreLastShardInfo ¶ added in v0.4.3
func DBStoreShardGenesisInfo ¶ added in v0.4.3
func DeserializeBlockRow ¶
func DeserializeBlockRow(blockRow []byte) (wire.BlockHeader, blocknodes.BlockStatus, int64, error)
DeserializeBlockRow parses a value in the block index bucket into a block header and block status bitfield.
func DisableLog ¶
func DisableLog()
DisableLog disables all library log output. Logging output is disabled by default until UseLogger is called.
func ExtractCoinbaseHeight ¶
ExtractCoinbaseHeight attempts to extract the height of the block from the scriptSig of a coinbase transaction. Coinbase heights are only present in blocks of version 2 or later. This was added as part of BIP0034.
func ExtractWitnessCommitment ¶
ExtractWitnessCommitment attempts to locate, and return the witness commitment for a block. The witness commitment is of the form: SHA256(witness root || witness nonce). The function additionally returns a boolean indicating if the witness root was located within any of the txOut's in the passed transaction. The witness commitment is stored as the data push for an OP_RETURN with special magic bytes to aide in location.
func GetBlockWeight ¶
GetBlockWeight computes the value of the weight metric for a given block. Currently the weight metric is simply the sum of the block's serialized size without any witness data scaled proportionally by the WitnessScaleFactor, and the block's serialized size including any witness data.
func GetSigOpCost ¶
func GetSigOpCost(tx *jaxutil.Tx, isCoinBaseTx bool, utxoView *UtxoViewpoint, bip16, segWit bool) (int, error)
GetSigOpCost returns the unified sig op cost for the passed transaction respecting current active soft-forks which modified sig op cost counting. The unified sig op cost for a transaction is computed as the sum of: the legacy sig op count scaled according to the WitnessScaleFactor, the sig op count for all p2sh inputs scaled by the WitnessScaleFactor, and finally the unscaled sig op count for any inputs spending witness programs. nolint: nilerr
func GetTransactionWeight ¶
GetTransactionWeight computes the value of the weight metric for a given transaction. Currently the weight metric is simply the sum of the transactions's serialized size without any witness data scaled proportionally by the WitnessScaleFactor, and the transaction's serialized size including any witness data.
func IsCoinBase ¶
IsCoinBase determines whether or not a transaction is a coinbase. A coinbase is a special transaction created by miners that has no inputs. This is represented in the block chain by a transaction with a single input that has a previous output transaction index set to the maximum value along with a zero Hash.
This function only differs from IsCoinBaseTx in that it works with a higher level util transaction as opposed to a raw wire transaction.
func IsCoinBaseTx ¶
IsCoinBaseTx determines whether or not a transaction is a coinbase. A coinbase is a special transaction created by miners that has no inputs. This is represented in the block chain by a transaction with a single input that has a previous output transaction index set to the maximum value along with a zero Hash.
This function only differs from IsCoinBase in that it works with a raw wire transaction as opposed to a higher level util transaction.
func IsDeserializeErr ¶
IsDeserializeErr returns whether or not the passed error is an ErrDeserialize error.
func IsFinalizedTransaction ¶
IsFinalizedTransaction determines whether or not a transaction is finalized.
func IsNotInMainChainErr ¶
IsNotInMainChainErr returns whether or not the passed error is an ErrNotInMainChain error.
func MigrateBlockIndex ¶
MigrateBlockIndex migrates all block entries from the v1 block index bucket to the v2 bucket. The v1 bucket stores all block entries keyed by block Hash, whereas the v2 bucket stores the exact same values, but keyed instead by block height + Hash.
func SequenceLockActive ¶
func SequenceLockActive(sequenceLock *SequenceLock, blockHeight int32, medianTimePast time.Time) bool
SequenceLockActive determines if a transaction's sequence locks have been met, meaning that all the inputs of a given transaction have reached a height or time sufficient for their relative lock-time maturity.
func ShouldHaveSerializedBlockHeight ¶
func ShouldHaveSerializedBlockHeight(header wire.BlockHeader) bool
ShouldHaveSerializedBlockHeight determines if a block should have a serialized block height embedded within the scriptSig of its coinbase transaction. Judgement is based on the block version in the block header. Blocks with version 2 and above satisfy this criteria. See BIP0034 for further information.
func StandardCoinbaseScript ¶ added in v0.4.0
func StandardCoinbaseScript(nextBlockHeight int32, shardID uint32, extraNonce uint64) ([]byte, error)
StandardCoinbaseScript returns a standard script suitable for use as the signature script of the coinbase transaction of a new block. In particular, it starts with the block height that is required by version 2 blocks and adds the extra nonce as well as additional coinbase flags.
func UpgradeUtxoSetToV2 ¶
UpgradeUtxoSetToV2 migrates the utxo set entries from version 1 to 2 in batches. It is guaranteed to updated if this returns without failure.
func ValidMoneyBackAfterExpiration ¶
func ValidMoneyBackAfterExpiration(tx *jaxutil.Tx, view *UtxoViewpoint) bool
func ValidateBTCCoinbase ¶ added in v0.4.0
func ValidateBTCCoinbase(aux *wire.BTCBlockAux) (rewardBurned bool, err error)
nolint: gomnd
func ValidateBeaconCoinbase ¶ added in v0.4.0
func ValidateBeaconCoinbase(aux *wire.BeaconHeader, coinbase *wire.MsgTx, expectedReward int64) (bool, error)
nolint: gomnd
func ValidateShardCoinbase ¶ added in v0.4.0
func ValidateSwapTxStructure ¶
ValidateSwapTxStructure validates formats of the cross shard swap tx. wire.TxVerCrossShardSwap transaction is a special tx for atomic swap between chains. It can contain only TWO or FOUR inputs and TWO or FOUR outputs. TxIn and TxOut are strictly associated with each other by index. One pair corresponds to the current chain. The second is for another, unknown chain.
| # | --- []TxIn ----- | --- | --- []TxOut ----- | # | | - | ---------------- | --- | ----------------- | - | | 0 | TxIn_0 ∈ Shard_X | --> | TxOut_0 ∈ Shard_X | 0 | | 1 | TxIn_1 ∈ Shard_X | --> | TxOut_1 ∈ Shard_X | 1 | | 2 | TxIn_2 ∈ Shard_Y | --> | TxOut_2 ∈ Shard_Y | 2 | | 3 | TxIn_3 ∈ Shard_Y | --> | TxOut_3 ∈ Shard_Y | 3 |
The order is not deterministic.
func ValidateTransactionScripts ¶
func ValidateTransactionScripts(tx *jaxutil.Tx, utxoView *UtxoViewpoint, flags txscript.ScriptFlags, sigCache *txscript.SigCache, hashCache *txscript.HashCache) error
ValidateTransactionScripts validates the scripts for the passed transaction using multiple goroutines.
func ValidateVoteK ¶ added in v0.4.0
func ValidateVoteK(header wire.BlockHeader) error
func ValidateWitnessCommitment ¶
ValidateWitnessCommitment validates the witness commitment (if any) found within the coinbase transaction of the passed block.
Types ¶
type AssertError ¶
type AssertError string
AssertError identifies an error that indicates an internal code consistency issue and should be treated as a critical and unrecoverable error.
func (AssertError) Error ¶
func (e AssertError) Error() string
Error returns the assertion error as a human-readable string and satisfies the error interface.
type BTCBlockGen ¶ added in v0.4.0
func (*BTCBlockGen) NewBlockTemplate ¶ added in v0.4.0
func (bg *BTCBlockGen) NewBlockTemplate(burnRewardFlag int, beaconHash chainhash.Hash) (wire.BTCBlockAux, bool, error)
nolint: gomnd
type BeaconBlockGenerator ¶ added in v0.4.0
type BeaconBlockGenerator struct {
// contains filtered or unexported fields
}
func NewBeaconBlockGen ¶ added in v0.4.0
func NewBeaconBlockGen(stateInfo StateProvider, powParams chaincfg.PowParams) *BeaconBlockGenerator
func (*BeaconBlockGenerator) CalcBlockSubsidy ¶ added in v0.4.0
func (c *BeaconBlockGenerator) CalcBlockSubsidy(height int32, difficulty uint32, header wire.BlockHeader) int64
CalcBlockSubsidy returns the subsidy amount a block at the provided height should have. This is mainly used for determining how much the coinbase for newly generated blocks awards as well as validating the coinbase for blocks has the expected value.
| Year | First Block | Last block | Formula based on block number | First Block reward | Last block reward | |------|-------------|------------|---------------------------------------|--------------------|-------------------| | 1 | 1 | 49152 | `340-10*([(x-1+3*2^10)/(3*2^11])` | 340 | 260 | | 2 | 49153 | 98304 | `260-5*([(x-49153+3*2^10)/(3*2^11])` | 260 | 220 | | 3 | 98305 | 147456 | `220-15*([(x-98305+3*2^10)/(3*2^11])` | 220 | 100 | | 4 | 147457 | 196608 | `100-5*([(x-147157+3*2^10)/(3*2^11])` | 100 | 60 | | 5 | 196609 | 245760 | `60-5*([(x-196609+3*2^10)/(3*2^11])` | 60 | 20 | | 6+ | 245761 | | 20 | 20 | |
func (*BeaconBlockGenerator) NewBlockHeader ¶ added in v0.4.0
func (*BeaconBlockGenerator) ValidateJaxAuxRules ¶ added in v0.4.0
func (c *BeaconBlockGenerator) ValidateJaxAuxRules(block *wire.MsgBlock, height int32) error
type BeaconBlockProvider ¶ added in v0.4.0
type BehaviorFlags ¶
type BehaviorFlags uint32
BehaviorFlags is a bitmask defining tweaks to the normal behavior when performing chain processing and consensus rules checks.
const ( // BFFastAdd may be set to indicate that several checks can be avoided // for the block since it is already known to fit into the chain due to // already proving it correct links into the chain up to a known // checkpoint. This is primarily used for headers-first mode. BFFastAdd BehaviorFlags = 1 << iota // BFNoPoWCheck may be set to indicate the proof of work check which // ensures a block hashes to a value less than the required target will // not be performed. BFNoPoWCheck // BFNone is a convenience value to specifically indicate no flags. BFNone BehaviorFlags = 0 )
type BestChainBlockRecord ¶ added in v0.4.3
type BestChainBlockRecord struct { SerialID int64 `json:"serial_id"` Hash *chainhash.Hash `json:"hash"` }
func DBGetBestChainSerialIDs ¶ added in v0.4.3
func DBGetBestChainSerialIDs(dbTx database.Tx) ([]BestChainBlockRecord, error)
type BestChainState ¶
type BestChainState struct { Hash chainhash.Hash MMRRoot chainhash.Hash LastSerialID int64 TotalTxns uint64 // contains filtered or unexported fields }
BestChainState represents the data to be stored the database for the current best chain state.
func DeserializeBestChainState ¶
func DeserializeBestChainState(serializedData []byte) (BestChainState, error)
DeserializeBestChainState deserializes the passed serialized best chain state. This is data stored in the chain state bucket and is updated after every block is connected or disconnected form the main chain. block.
type BestState ¶
type BestState struct { Hash chainhash.Hash // The hash of the block. Height int32 // The height of the block. Bits uint32 // The difficulty bits of the block. K uint32 // The K coefficient. Shards uint32 // The last known number of Shards. BlockSize uint64 // The size of the block. BlockWeight uint64 // The weight of the block. NumTxns uint64 // The number of txns in the block. TotalTxns uint64 // The total number of txns in the chain. MedianTime time.Time // Median time as per CalcPastMedianTime. LastSerialID int64 CurrentMMRRoot chainhash.Hash // Actual root of the MMR Tree. ChainWeight *big.Int }
BestState houses information about the current best block and other info related to the state of the main chain as it exists from the point of view of the current best block.
The BestSnapshot method can be used to obtain access to this information in a concurrent safe manner and the data will not be changed out from under the caller when chain state changes occur as the function name implies. However, the returned snapshot must be treated as immutable since it is shared by all callers.
func NewBestState ¶
func NewBestState(node blocknodes.IBlockNode, actualMMRRoot chainhash.Hash, blockSize, blockWeight uint64, chainWeight *big.Int, numTxns, totalTxns uint64, medianTime time.Time, lastSerialID int64) *BestState
NewBestState returns a new best stats instance for the given parameters.
type BlockTemplate ¶ added in v0.4.0
type BlockTemplate struct { // Block is a block that is ready to be solved by miners. Thus, it is // completely valid with the exception of satisfying the proof-of-work // requirement. Block *wire.MsgBlock // Fees contains the amount of fees each transaction in the generated // template pays in base units. Since the first transaction is the // coinbase, the first entry (offset 0) will contain the negative of the // sum of the fees of all other transactions. Fees []int64 // SigOpCosts contains the number of signature operations each // transaction in the generated template performs. SigOpCosts []int64 // Height is the height at which the block template connects to the main // chain. Height int32 // ValidPayAddress indicates whether or not the template coinbase pays // to an address or is redeemable by anyone. See the documentation on // NewBlockTemplate for details on which this can be useful to generate // templates without a coinbase payment address. ValidPayAddress bool // WitnessCommitment is a commitment to the witness data (if any) // within the block. This field will only be populted once segregated // witness has been activated, and the block contains a transaction // which has witness data. WitnessCommitment []byte }
BlockTemplate houses a block that has yet to be solved along with additional details about the fees and the number of signature operations for each transaction in the block.
type ChainBlockGenerator ¶ added in v0.4.0
type ChainBlockGenerator interface { NewBlockHeader(version wire.BVersion, height int32, blocksMMRRoot chainhash.Hash, prevBlock chainhash.Hash, merkleRootHash chainhash.Hash, timestamp time.Time, bits uint32, prevWeight *big.Int, nonce uint32, burnReward int) (wire.BlockHeader, error) ValidateJaxAuxRules(block *wire.MsgBlock, height int32) error CalcBlockSubsidy(height int32, difficulty uint32, header wire.BlockHeader) int64 }
type DeploymentError ¶
type DeploymentError uint32
DeploymentError identifies an error that indicates a deployment ID was specified that does not exist.
func (DeploymentError) Error ¶
func (e DeploymentError) Error() string
Error returns the assertion error as a human-readable string and satisfies the error interface.
type ErrDeserialize ¶
type ErrDeserialize string
ErrDeserialize signifies that a problem was encountered when deserializing data.
func (ErrDeserialize) Error ¶
func (e ErrDeserialize) Error() string
Error implements the error interface.
type ErrNotInMainChain ¶
type ErrNotInMainChain string
ErrNotInMainChain signifies that a block Hash or height that is not in the main chain was requested.
func (ErrNotInMainChain) Error ¶
func (e ErrNotInMainChain) Error() string
Error implements the error interface.
type ErrorCode ¶
type ErrorCode int
ErrorCode identifies a kind of error.
const ( // ErrDuplicateBlock indicates a block with the same Hash already // exists. ErrDuplicateBlock ErrorCode = iota // ErrBlockTooBig indicates the serialized block size exceeds the // maximum allowed size. ErrBlockTooBig // ErrBlockWeightTooHigh indicates that the block's computed weight // metric exceeds the maximum allowed value. ErrBlockWeightTooHigh // ErrBlockVersionTooOld indicates the block version is too old and is // no longer accepted since the majority of the network has upgraded // to a newer version. ErrBlockVersionTooOld // ErrInvalidTime indicates the time in the passed block has a precision // that is more than one second. The chain consensus rules require // timestamps to have a maximum precision of one second. ErrInvalidTime // ErrTimeTooOld indicates the time is either before the median time of // the last several blocks per the chain consensus rules or prior to the // most recent checkpoint. ErrTimeTooOld // ErrTimeTooNew indicates the time is too far in the future as compared // the current time. ErrTimeTooNew // ErrDifficultyTooLow indicates the difficulty for the block is lower // than the difficulty required by the most recent checkpoint. ErrDifficultyTooLow // ErrUnexpectedDifficulty indicates specified bits do not align with // the expected value either because it doesn't match the calculated // valued based on difficulty regarted rules or it is out of the valid // range. ErrUnexpectedDifficulty // ErrHighHash indicates the block does not Hash to a value which is // lower than the required target difficultly. ErrHighHash // ErrBadMerkleRoot indicates the calculated merkle root does not match // the expected value. ErrBadMerkleRoot // ErrBadCheckpoint indicates a block that is expected to be at a // checkpoint height does not match the expected one. ErrBadCheckpoint // ErrForkTooOld indicates a block is attempting to fork the block chain // before the most recent checkpoint. ErrForkTooOld // ErrCheckpointTimeTooOld indicates a block has a timestamp before the // most recent checkpoint. ErrCheckpointTimeTooOld // ErrNoTransactions indicates the block does not have a least one // transaction. A valid block must have at least the coinbase // transaction. ErrNoTransactions // ErrNoTxInputs indicates a transaction does not have any inputs. A // valid transaction must have at least one input. ErrNoTxInputs // ErrNoTxOutputs indicates a transaction does not have any outputs. A // valid transaction must have at least one output. ErrNoTxOutputs // ErrTxTooBig indicates a transaction exceeds the maximum allowed size // when serialized. ErrTxTooBig // ErrBadTxOutValue indicates an output value for a transaction is // invalid in some way such as being out of range. ErrBadTxOutValue // ErrDuplicateTxInputs indicates a transaction references the same // input more than once. ErrDuplicateTxInputs // ErrBadTxInput indicates a transaction input is invalid in some way // such as referencing a previous transaction outpoint which is out of // range or not referencing one at all. ErrBadTxInput // ErrMissingTxOut indicates a transaction output referenced by an input // either does not exist or has already been spent. ErrMissingTxOut // ErrUnfinalizedTx indicates a transaction has not been finalized. // A valid block may only contain finalized transactions. ErrUnfinalizedTx // ErrDuplicateTx indicates a block contains an identical transaction // (or at least two transactions which Hash to the same value). A // valid block may only contain unique transactions. ErrDuplicateTx // ErrOverwriteTx indicates a block contains a transaction that has // the same Hash as a previous transaction which has not been fully // spent. ErrOverwriteTx // ErrImmatureSpend indicates a transaction is attempting to spend a // coinbase that has not yet reached the required maturity. ErrImmatureSpend // ErrSpendTooHigh indicates a transaction is attempting to spend more // value than the sum of all of its inputs. ErrSpendTooHigh // ErrBadFees indicates the total fees for a block are invalid due to // exceeding the maximum possible value. ErrBadFees // ErrTooManySigOps indicates the total number of signature operations // for a transaction or block exceed the maximum allowed limits. ErrTooManySigOps // ErrFirstTxNotCoinbase indicates the first transaction in a block // is not a coinbase transaction. ErrFirstTxNotCoinbase // ErrMultipleCoinbases indicates a block contains more than one // coinbase transaction. ErrMultipleCoinbases // ErrBadCoinbaseScriptLen indicates the length of the signature script // for a coinbase transaction is not within the valid range. ErrBadCoinbaseScriptLen // ErrBadCoinbaseValue indicates the amount of a coinbase value does // not match the expected value of the subsidy plus the sum of all fees. ErrBadCoinbaseValue // ErrMissingCoinbaseHeight indicates the coinbase transaction for a // block does not start with the serialized block block height as // required for version 2 and higher blocks. ErrMissingCoinbaseHeight // ErrBadCoinbaseHeight indicates the serialized block height in the // coinbase transaction for version 2 and higher blocks does not match // the expected value. ErrBadCoinbaseHeight // ErrScriptMalformed indicates a transaction script is malformed in // some way. For example, it might be longer than the maximum allowed // length or fail to parse. ErrScriptMalformed // ErrScriptValidation indicates the result of executing transaction // script failed. The error covers any failure when executing scripts // such signature verification failures and execution past the end of // the stack. ErrScriptValidation // ErrUnexpectedWitness indicates that a block includes transactions // with witness data, but doesn't also have a witness commitment within // the coinbase transaction. ErrUnexpectedWitness // ErrInvalidWitnessCommitment indicates that a block's witness // commitment is not well formed. ErrInvalidWitnessCommitment // ErrWitnessCommitmentMismatch indicates that the witness commitment // included in the block's coinbase transaction doesn't match the // manually computed witness commitment. ErrWitnessCommitmentMismatch // ErrPreviousBlockUnknown indicates that the previous block is not known. ErrPreviousBlockUnknown // ErrInvalidAncestorBlock indicates that an ancestor of this block has // already failed validation. ErrInvalidAncestorBlock // ErrPrevBlockNotBest indicates that the block's previous block is not the // current chain tip. This is not a block validation rule, but is required // for block proposals submitted via getblocktemplate RPC. ErrPrevBlockNotBest // ErrInvalidShardSwapInOuts indicates that tx content not match // with ShardsSwapTx requirements. ErrInvalidShardSwapInOuts // ErrHashSortingRuleNotMatch indicates that block hash not match // with hash sorting mask for current chain ErrHashSortingRuleNotMatch // ErrUnexpectedKValue indicates specified K value do not align with // the expected value either because it doesn't match the calculated // valued based on protocol rules or it is out of the valid ErrUnexpectedKValue ErrInvalidJaxHeaderAux ErrUnexpectedShardsValue ErrInvalidBlockHeightValue ErrInvalidChainWeightValue )
These constants are used to identify a specific RuleError.
type MedianTimeSource ¶
type MedianTimeSource interface { // AdjustedTime returns the current time adjusted by the median time // offset as calculated from the time samples added by AddTimeSample. AdjustedTime() time.Time // AddTimeSample adds a time sample that is used when determining the // median time of the added samples. AddTimeSample(id string, timeVal time.Time) // Offset returns the number of seconds to adjust the local clock based // upon the median of the time samples added by AddTimeData. Offset() time.Duration }
MedianTimeSource provides a mechanism to add several time samples which are used to determine a median time which is then used as an offset to the local clock.
func NewMedianTime ¶
func NewMedianTime() MedianTimeSource
NewMedianTime returns a new instance of concurrency-safe implementation of the MedianTimeSource interface. The returned implementation contains the rules necessary for proper time handling in the chain consensus rules and expects the time samples to be added from the timestamp field of the version message received from remote peers that successfully connect and negotiate.
type RuleError ¶
type RuleError struct { ErrorCode ErrorCode // Describes the kind of error Description string // Human readable description of the issue }
RuleError identifies a rule violation. It is used to indicate that processing of a block or transaction failed due to one of the many validation rules. The caller can use type assertions to determine if a failure was specifically due to a rule violation and access the ErrorCode field to ascertain the specific reason for the rule violation.
func NewRuleError ¶
NewRuleError creates an RuleError given a set of arguments.
type SequenceLock ¶
SequenceLock represents the converted relative lock-time in seconds, and absolute block-height for a transaction input's relative lock-times. According to SequenceLock, after the referenced input has been confirmed within a block, a transaction spending that input can be included into a block either after 'seconds' (according to past median time), or once the 'BlockHeight' has been reached.
type SerialIDBlockMeta ¶ added in v0.4.2
func DBFetchAllBlocksHashBySerialID ¶ added in v0.4.2
type ShardBlockGenerator ¶ added in v0.4.0
type ShardBlockGenerator struct {
// contains filtered or unexported fields
}
func NewShardBlockGen ¶ added in v0.4.0
func NewShardBlockGen(ctx chainctx.IChainCtx, beacon BeaconBlockProvider) *ShardBlockGenerator
func (*ShardBlockGenerator) CalcBlockSubsidy ¶ added in v0.4.0
func (c *ShardBlockGenerator) CalcBlockSubsidy(height int32, difficulty uint32, header wire.BlockHeader) int64
nolint: revive
func (*ShardBlockGenerator) NewBlockHeader ¶ added in v0.4.0
func (*ShardBlockGenerator) ValidateJaxAuxRules ¶ added in v0.4.0
func (c *ShardBlockGenerator) ValidateJaxAuxRules(block *wire.MsgBlock, height int32) error
nolint: forcetypeassert
func (*ShardBlockGenerator) ValidateMergeMiningData ¶ added in v0.4.0
func (c *ShardBlockGenerator) ValidateMergeMiningData(header wire.BlockHeader) error
type ShardInfo ¶ added in v0.4.3
type ShardInfo struct { // ID of the shard chain. ID uint32 // ExpansionHeight chain height of beacon block // when expansion has happened for this shard. ExpansionHeight int32 // ExpansionHash hash of beacon block // when expansion has happened for this shard. ExpansionHash chainhash.Hash // ExpansionHeight serial id of beacon block // when expansion has happened for this shard. SerialID int64 }
type SpentTxOut ¶
type SpentTxOut struct { // Amount is the amount of the output. Amount int64 // PkScipt is the the public key script for the output. PkScript []byte // Height is the height of the the block containing the creating tx. Height int32 // Denotes if the creating tx is a coinbase. IsCoinBase bool }
SpentTxOut contains a spent transaction output and potentially additional contextual information such as whether or not it was contained in a coinbase transaction, the version of the transaction it was contained in, and which block height the containing transaction was included in. As described in the comments above, the additional contextual information will only be valid when this spent txout is spending the last unspent output of the containing transaction.
func DBFetchSpendJournalEntry ¶
DBFetchSpendJournalEntry fetches the spend journal entry for the passed block and deserializes it into a slice of spent txout entries.
NOTE: Legacy entries will not have the coinbase flag or height set unless it was the final output spend in the containing transaction. It is up to the caller to handle this properly by looking the information up in the utxo set.
type StateProvider ¶ added in v0.4.0
type UtxoEntry ¶
type UtxoEntry struct {
// contains filtered or unexported fields
}
UtxoEntry houses details about an individual transaction output in a utxo view such as whether or not it was contained in a coinbase tx, the height of the block that contains the tx, whether or not it is spent, its public key script, and how much it pays.
func DBFetchUtxoEntry ¶
DBFetchUtxoEntry uses an existing database transaction to fetch the specified transaction output from the utxo set.
When there is no entry for the provided output, nil will be returned for both the entry and the error.
func DeserializeUtxoEntry ¶ added in v0.4.0
DeserializeUtxoEntry decodes a utxo entry from the passed serialized byte slice into a new UtxoEntry using a format that is suitable for long-term storage. The format is described in detail above. nolint: gomnd
func (*UtxoEntry) BlockHeight ¶
BlockHeight returns the height of the block containing the output.
func (*UtxoEntry) IsCoinBase ¶
IsCoinBase returns whether or not the output was contained in a coinbase transaction.
func (*UtxoEntry) IsSpent ¶
IsSpent returns whether or not the output has been spent based upon the current state of the unspent transaction output view it was obtained from.
type UtxoViewpoint ¶
type UtxoViewpoint struct {
// contains filtered or unexported fields
}
UtxoViewpoint represents a view into the set of unspent transaction outputs from a specific point of view in the chain. For example, it could be for the end of the main chain, some point in the history of the main chain, or down a side chain.
The unspent outputs are needed by other transactions for things such as script validation and double spend prevention.
func NewUtxoViewpoint ¶
func NewUtxoViewpoint(beacon bool) *UtxoViewpoint
NewUtxoViewpoint returns a new empty unspent transaction output view.
func (*UtxoViewpoint) AddTxOut ¶
func (view *UtxoViewpoint) AddTxOut(tx *jaxutil.Tx, txOutIdx uint32, blockHeight int32)
AddTxOut adds the specified output of the passed transaction to the view if it exists and is not provably unspendable. When the view already has an entry for the output, it will be marked unspent. All fields will be updated for existing entries since it's possible it has changed during a reorg.
func (*UtxoViewpoint) AddTxOuts ¶
func (view *UtxoViewpoint) AddTxOuts(tx *jaxutil.Tx, blockHeight int32)
AddTxOuts adds all outputs in the passed transaction which are not provably unspendable to the view. When the view already has entries for any of the outputs, they are simply marked unspent. All fields will be updated for existing entries since it's possible it has changed during a reorg.
func (*UtxoViewpoint) BestHash ¶
func (view *UtxoViewpoint) BestHash() *chainhash.Hash
BestHash returns the Hash of the best block in the chain the view currently respresents.
func (*UtxoViewpoint) Commit ¶
func (view *UtxoViewpoint) Commit()
Commit prunes all entries marked modified that are now fully spent and marks all entries as unmodified.
func (*UtxoViewpoint) ConnectTransaction ¶
func (view *UtxoViewpoint) ConnectTransaction(tx *jaxutil.Tx, blockHeight int32, stxos *[]SpentTxOut) error
ConnectTransaction updates the view by adding all new utxos created by the passed transaction and marking all utxos that the transactions spend as spent. In addition, when the 'stxos' argument is not nil, it will be updated to append an entry for each spent txout. An error will be returned if the view does not contain the required utxos.
func (*UtxoViewpoint) ConnectTransactions ¶
func (view *UtxoViewpoint) ConnectTransactions(block *jaxutil.Block, stxos *[]SpentTxOut) error
ConnectTransactions updates the view by adding all new utxos created by all of the transactions in the passed block, marking all utxos the transactions spend as spent, and setting the best Hash for the view to the passed block. In addition, when the 'stxos' argument is not nil, it will be updated to append an entry for each spent txout.
func (*UtxoViewpoint) DisconnectTransactions ¶
func (view *UtxoViewpoint) DisconnectTransactions(db database.DB, block *jaxutil.Block, prevHash chainhash.Hash, stxos []SpentTxOut) error
DisconnectTransactions updates the view by removing all of the transactions created by the passed block, restoring all utxos the transactions spent by using the provided spent txo information, and setting the best Hash for the view to the block before the passed block.
func (*UtxoViewpoint) EADAddressesSet ¶
func (view *UtxoViewpoint) EADAddressesSet() map[string]*wire.EADAddresses
func (*UtxoViewpoint) Entries ¶
func (view *UtxoViewpoint) Entries() map[wire.OutPoint]*UtxoEntry
Entries returns the underlying map that stores of all the utxo entries.
func (*UtxoViewpoint) FetchInputUtxos ¶
FetchInputUtxos loads the unspent transaction outputs for the inputs referenced by the transactions in the given block into the view from the database as needed. In particular, referenced entries that are earlier in the block are added to the view and entries that are already in the view are not modified.
func (*UtxoViewpoint) FetchUtxos ¶
FetchUtxos loads the unspent transaction outputs for the provided set of outputs into the view from the database as needed unless they already exist in the view in which case they are ignored.
func (*UtxoViewpoint) FetchUtxosMain ¶
func (view *UtxoViewpoint) FetchUtxosMain(db database.DB, outpoints map[wire.OutPoint]struct{}) error
FetchUtxosMain fetches unspent transaction output data about the provided set of outpoints from the point of view of the end of the main chain at the time of the call.
Upon completion of this function, the view will contain an entry for each requested outpoint. Spent outputs, or those which otherwise don't exist, will result in a nil entry in the view.
func (*UtxoViewpoint) LookupEntry ¶
func (view *UtxoViewpoint) LookupEntry(outpoint wire.OutPoint) *UtxoEntry
LookupEntry returns information about a given transaction output according to the current state of the view. It will return nil if the passed output does not exist in the view or is otherwise not available such as when it has been disconnected during a reorg.
func (*UtxoViewpoint) RemoveEntry ¶
func (view *UtxoViewpoint) RemoveEntry(outpoint wire.OutPoint)
RemoveEntry removes the given transaction output from the current state of the view. It will have no effect if the passed output does not exist in the view.
func (*UtxoViewpoint) SetBestHash ¶
func (view *UtxoViewpoint) SetBestHash(hash *chainhash.Hash)
SetBestHash sets the Hash of the best block in the chain the view currently respresents.