2020-05-17 20:30:16 +00:00
|
|
|
/*
|
|
|
|
Package blockchain provides functions to access various blockchain data.
|
|
|
|
*/
|
2018-08-21 10:57:48 +00:00
|
|
|
package blockchain
|
|
|
|
|
|
|
|
import (
|
2020-03-03 14:21:42 +00:00
|
|
|
"github.com/nspcc-dev/neo-go/pkg/interop/account"
|
|
|
|
"github.com/nspcc-dev/neo-go/pkg/interop/asset"
|
|
|
|
"github.com/nspcc-dev/neo-go/pkg/interop/block"
|
|
|
|
"github.com/nspcc-dev/neo-go/pkg/interop/contract"
|
|
|
|
"github.com/nspcc-dev/neo-go/pkg/interop/header"
|
|
|
|
"github.com/nspcc-dev/neo-go/pkg/interop/transaction"
|
2018-08-21 10:57:48 +00:00
|
|
|
)
|
|
|
|
|
2020-05-17 20:30:16 +00:00
|
|
|
// 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
|
|
|
|
// `Neo.Blockchain.GetHeight` syscall.
|
2018-08-21 10:57:48 +00:00
|
|
|
func GetHeight() int {
|
|
|
|
return 0
|
|
|
|
}
|
|
|
|
|
2020-05-17 20:30:16 +00:00
|
|
|
// GetHeader returns header found by the given hash (256 bit hash in BE format
|
|
|
|
// represented as a slice of 32 bytes) or index (integer). Refer to the `header`
|
|
|
|
// package for possible uses of returned structure. This function uses
|
|
|
|
// `Neo.Blockchain.GetHeader` syscall.
|
2018-08-21 10:57:48 +00:00
|
|
|
func GetHeader(heightOrHash interface{}) header.Header {
|
|
|
|
return header.Header{}
|
|
|
|
}
|
|
|
|
|
2020-05-17 20:30:16 +00:00
|
|
|
// GetBlock returns block found by the given hash or index (with the same
|
|
|
|
// encoding as for GetHeader). Refer to the `block` package for possible uses
|
|
|
|
// of returned structure. This function uses `Neo.Blockchain.GetBlock` syscall.
|
2018-08-21 10:57:48 +00:00
|
|
|
func GetBlock(heightOrHash interface{}) block.Block {
|
|
|
|
return block.Block{}
|
|
|
|
}
|
|
|
|
|
2020-05-17 20:30:16 +00:00
|
|
|
// GetTransaction returns transaction found by the given (256 bit in BE format
|
|
|
|
// represented as a slice of 32 bytes). Refer to the `transaction` package for
|
|
|
|
// possible uses of returned structure. This function uses
|
|
|
|
// `Neo.Blockchain.GetTransaction` syscall.
|
2018-08-21 10:57:48 +00:00
|
|
|
func GetTransaction(hash []byte) transaction.Transaction {
|
|
|
|
return transaction.Transaction{}
|
|
|
|
}
|
|
|
|
|
2020-05-17 20:30:16 +00:00
|
|
|
// 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
|
|
|
|
// `Neo.Blockchain.GetContract` syscall.
|
2018-08-21 10:57:48 +00:00
|
|
|
func GetContract(scriptHash []byte) contract.Contract {
|
|
|
|
return contract.Contract{}
|
|
|
|
}
|
|
|
|
|
2020-05-17 20:30:16 +00:00
|
|
|
// GetAccount returns account found by the given script hash (160 bit in BE
|
|
|
|
// format represented as a slice of 20 bytes). Refer to the `account` package
|
|
|
|
// for details on how to use the returned structure. This function uses
|
|
|
|
// `Neo.Blockchain.GetAccount` syscall.
|
2018-08-21 10:57:48 +00:00
|
|
|
func GetAccount(scriptHash []byte) account.Account {
|
|
|
|
return account.Account{}
|
|
|
|
}
|
|
|
|
|
2020-05-17 20:30:16 +00:00
|
|
|
// GetValidators returns a slice of current validators public keys represented
|
|
|
|
// as a compressed serialized byte slice (33 bytes long). This function uses
|
|
|
|
// `Neo.Blockchain.GetValidators` syscall.
|
2018-08-21 10:57:48 +00:00
|
|
|
func GetValidators() [][]byte {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2020-05-17 20:30:16 +00:00
|
|
|
// GetAsset returns asset found by the given asset ID (256 bit in BE format
|
|
|
|
// represented as a slice of 32 bytes). Refer to the `asset` package for
|
|
|
|
// possible uses of returned structure. This function uses
|
|
|
|
// `Neo.Blockchain.GetAsset` syscall.
|
2018-08-21 10:57:48 +00:00
|
|
|
func GetAsset(assetID []byte) asset.Asset {
|
|
|
|
return asset.Asset{}
|
|
|
|
}
|