mirror of
https://github.com/nspcc-dev/neo-go.git
synced 2025-01-22 19:43:46 +00:00
37f7363386
`Transaction`, `Block` and `Contract` are represented as
`Array`s in VM, so we must return pointers.
Revert a1f98f92
.
105 lines
4 KiB
Go
105 lines
4 KiB
Go
/*
|
|
Package blockchain provides functions to access various blockchain data.
|
|
*/
|
|
package blockchain
|
|
|
|
import (
|
|
"github.com/nspcc-dev/neo-go/pkg/interop"
|
|
"github.com/nspcc-dev/neo-go/pkg/interop/contract"
|
|
)
|
|
|
|
// Transaction represents a NEO transaction. It's similar to Transaction class
|
|
// in Neo .net framework.
|
|
type Transaction struct {
|
|
// Hash represents the hash (256 bit BE value in a 32 byte slice) of the
|
|
// given transaction (which also is its ID).
|
|
Hash interop.Hash256
|
|
// Version represents the transaction version.
|
|
Version int
|
|
// Nonce is a random number to avoid hash collision.
|
|
Nonce int
|
|
// Sender represents the sender (160 bit BE value in a 20 byte slice) of the
|
|
// given Transaction.
|
|
Sender interop.Hash160
|
|
// SysFee represents fee to be burned.
|
|
SysFee int
|
|
// NetFee represents fee to be distributed to consensus nodes.
|
|
NetFee int
|
|
// ValidUntilBlock is the maximum blockchain height exceeding which
|
|
// transaction should fail verification.
|
|
ValidUntilBlock int
|
|
// Script represents code to run in NeoVM for this transaction.
|
|
Script []byte
|
|
}
|
|
|
|
// Block represents a NEO block, it's a data structure that you can get
|
|
// block-related data from. It's similar to the Block class in the Neo .net
|
|
// framework. To use it you need to get it via GetBlock function call.
|
|
type Block struct {
|
|
// Hash represents the hash (256 bit BE value in a 32 byte slice) of the
|
|
// given block.
|
|
Hash interop.Hash256
|
|
// Version of the block.
|
|
Version int
|
|
// PrevHash represents the hash (256 bit BE value in a 32 byte slice) of the
|
|
// previous block.
|
|
PrevHash interop.Hash256
|
|
// MerkleRoot represents the root hash (256 bit BE value in a 32 byte slice)
|
|
// of a transaction list.
|
|
MerkleRoot interop.Hash256
|
|
// Timestamp represents millisecond-precision block timestamp.
|
|
Timestamp int
|
|
// Index represents the height of the block.
|
|
Index int
|
|
// NextConsensus represents contract address of the next miner (160 bit BE
|
|
// value in a 20 byte slice).
|
|
NextConsensus interop.Hash160
|
|
// TransactionsLength represents the length of block's transactions array.
|
|
TransactionsLength int
|
|
}
|
|
|
|
// GetHeight returns current block height (index of the last accepted block).
|
|
// Note that when transaction is being run as a part of new block this block is
|
|
// considered as not yet accepted (persisted) and thus you'll get an index of
|
|
// the previous (already accepted) block. This function uses
|
|
// `System.Blockchain.GetHeight` syscall.
|
|
func GetHeight() int {
|
|
return 0
|
|
}
|
|
|
|
// GetBlock returns block found by the given hash or index (with the same
|
|
// encoding as for GetHeader). This function uses `System.Blockchain.GetBlock`
|
|
// syscall.
|
|
func GetBlock(heightOrHash interface{}) *Block {
|
|
return &Block{}
|
|
}
|
|
|
|
// GetTransaction returns transaction found by the given hash (256 bit in BE
|
|
// format represented as a slice of 32 bytes). This function uses
|
|
// `System.Blockchain.GetTransaction` syscall.
|
|
func GetTransaction(hash interop.Hash256) *Transaction {
|
|
return &Transaction{}
|
|
}
|
|
|
|
// GetTransactionFromBlock returns transaction hash (256 bit in BE format
|
|
// represented as a slice of 32 bytes) from the block found by the given hash or
|
|
// index (with the same encoding as for GetHeader) by its index. This
|
|
// function uses `System.Blockchain.GetTransactionFromBlock` syscall.
|
|
func GetTransactionFromBlock(heightOrHash interface{}, index int) interop.Hash256 {
|
|
return nil
|
|
}
|
|
|
|
// GetTransactionHeight returns transaction's height (index of the block that
|
|
// includes it) by the given ID (256 bit in BE format represented as a slice of
|
|
// 32 bytes). This function uses `System.Blockchain.GetTransactionHeight` syscall.
|
|
func GetTransactionHeight(hash interop.Hash256) int {
|
|
return 0
|
|
}
|
|
|
|
// GetContract returns contract found by the given script hash (160 bit in BE
|
|
// format represented as a slice of 20 bytes). Refer to the `contract` package
|
|
// for details on how to use the returned structure. This function uses
|
|
// `System.Blockchain.GetContract` syscall.
|
|
func GetContract(scriptHash interop.Hash160) *contract.Contract {
|
|
return &contract.Contract{}
|
|
}
|