Documentation ¶
Index ¶
- Constants
- func GetValidatorsWeightedAverage(validators []*ValidatorState) int
- func IsDoubleSpend(s storage.Store, tx *transaction.Transaction) bool
- type AccountState
- type Accounts
- type AppExecResult
- type AssetState
- type Assets
- type Block
- type BlockBase
- type BlockChainState
- type Blockchain
- func (bc *Blockchain) AddBlock(block *Block) error
- func (bc *Blockchain) AddHeaders(headers ...*Header) (err error)
- func (bc *Blockchain) BlockHeight() uint32
- func (bc *Blockchain) Close()
- func (bc *Blockchain) CurrentBlockHash() (hash util.Uint256)
- func (bc *Blockchain) CurrentHeaderHash() (hash util.Uint256)
- func (bc *Blockchain) FeePerByte(t *transaction.Transaction) util.Fixed8
- func (bc *Blockchain) GetAccountState(scriptHash util.Uint160) *AccountState
- func (bc *Blockchain) GetAssetState(assetID util.Uint256) *AssetState
- func (bc *Blockchain) GetBlock(hash util.Uint256) (*Block, error)
- func (bc *Blockchain) GetConfig() config.ProtocolConfiguration
- func (bc *Blockchain) GetContractState(hash util.Uint160) *ContractState
- func (bc *Blockchain) GetHeader(hash util.Uint256) (*Header, error)
- func (bc *Blockchain) GetHeaderHash(i int) (hash util.Uint256)
- func (bc *Blockchain) GetMemPool() MemPool
- func (bc *Blockchain) GetScriptHashesForVerifying(t *transaction.Transaction) ([]util.Uint160, error)
- func (bc *Blockchain) GetScriptHashesForVerifyingClaim(t *transaction.Transaction) ([]util.Uint160, error)
- func (bc *Blockchain) GetStandByValidators() (keys.PublicKeys, error)
- func (bc *Blockchain) GetStorageItem(scripthash util.Uint160, key []byte) *StorageItem
- func (bc *Blockchain) GetStorageItems(hash util.Uint160) (map[string]*StorageItem, error)
- func (bc *Blockchain) GetTestVM() (*vm.VM, storage.Store)
- func (bc *Blockchain) GetTransaction(hash util.Uint256) (*transaction.Transaction, uint32, error)
- func (bc *Blockchain) GetTransactionResults(t *transaction.Transaction) []*transaction.Result
- func (bc *Blockchain) GetUnspentCoinState(hash util.Uint256) *UnspentCoinState
- func (bc *Blockchain) GetValidators(txes ...*transaction.Transaction) ([]*keys.PublicKey, error)
- func (bc *Blockchain) HasBlock(hash util.Uint256) bool
- func (bc *Blockchain) HasTransaction(hash util.Uint256) bool
- func (bc *Blockchain) HeaderHeight() uint32
- func (bc *Blockchain) IsLowPriority(t *transaction.Transaction) bool
- func (bc *Blockchain) NetworkFee(t *transaction.Transaction) util.Fixed8
- func (bc *Blockchain) References(t *transaction.Transaction) map[transaction.Input]*transaction.Output
- func (bc *Blockchain) Run()
- func (bc *Blockchain) SystemFee(t *transaction.Transaction) util.Fixed8
- func (bc *Blockchain) VerifyBlock(block *Block) error
- func (bc *Blockchain) VerifyTx(t *transaction.Transaction, block *Block) error
- type Blockchainer
- type CoinState
- type ContractState
- type Contracts
- type Feer
- type Header
- type HeaderHashList
- func (l *HeaderHashList) Add(h ...util.Uint256)
- func (l *HeaderHashList) Get(i int) util.Uint256
- func (l *HeaderHashList) Last() util.Uint256
- func (l *HeaderHashList) Len() int
- func (l *HeaderHashList) Slice(start, end int) []util.Uint256
- func (l *HeaderHashList) Write(bw *io.BinWriter, start, n int) error
- type MemPool
- func (mp MemPool) ContainsKey(hash util.Uint256) bool
- func (mp MemPool) Count() int
- func (mp *MemPool) GetVerifiedTransactions() []*transaction.Transaction
- func (mp *MemPool) Remove(hash util.Uint256)
- func (mp *MemPool) RemoveOverCapacity()
- func (mp MemPool) TryAdd(hash util.Uint256, pItem *PoolItem) bool
- func (mp MemPool) TryGetValue(hash util.Uint256) (*transaction.Transaction, bool)
- func (mp MemPool) Verify(tx *transaction.Transaction) bool
- type NotificationEvent
- type PoolItem
- type PoolItems
- type SpentCoinState
- type SpentCoins
- type StorageContext
- type StorageItem
- type UnspentBalance
- type UnspentBalances
- type UnspentCoinState
- type UnspentCoins
- type ValidatorState
- type Validators
Constants ¶
const ( // MaxContractScriptSize is the maximum script size for a contract. MaxContractScriptSize = 1024 * 1024 // MaxContractParametersNum is the maximum number of parameters for a contract. MaxContractParametersNum = 252 // MaxContractStringLen is the maximum length for contract metadata strings. MaxContractStringLen = 252 // MaxAssetNameLen is the maximum length of asset name. MaxAssetNameLen = 1024 // MaxAssetPrecision is the maximum precision of asset. MaxAssetPrecision = 8 // BlocksPerYear is a multiplier for asset renewal. BlocksPerYear = 2000000 // DefaultAssetLifetime is the default lifetime of an asset (which differs // from assets created by register tx). DefaultAssetLifetime = 1 + BlocksPerYear )
const (
// MaxStorageKeyLen is the maximum length of a key for storage items.
MaxStorageKeyLen = 1024
)
Variables ¶
This section is empty.
Functions ¶
func GetValidatorsWeightedAverage ¶ added in v0.70.0
func GetValidatorsWeightedAverage(validators []*ValidatorState) int
GetValidatorsWeightedAverage applies weighted filter based on votes for validator and returns number of validators. Get back to it with further investigation in https://github.com/nspcc-dev/neo-go/issues/512.
func IsDoubleSpend ¶
func IsDoubleSpend(s storage.Store, tx *transaction.Transaction) bool
IsDoubleSpend verifies that the input transactions are not double spent.
Types ¶
type AccountState ¶
type AccountState struct { Version uint8 ScriptHash util.Uint160 IsFrozen bool Votes []*keys.PublicKey Balances map[util.Uint256][]UnspentBalance }
AccountState represents the state of a NEO account.
func NewAccountState ¶
func NewAccountState(scriptHash util.Uint160) *AccountState
NewAccountState returns a new AccountState object.
func (*AccountState) DecodeBinary ¶
func (s *AccountState) DecodeBinary(br *io.BinReader)
DecodeBinary decodes AccountState from the given BinReader.
func (*AccountState) EncodeBinary ¶
func (s *AccountState) EncodeBinary(bw *io.BinWriter)
EncodeBinary encodes AccountState to the given BinWriter.
func (*AccountState) GetBalanceValues ¶ added in v0.70.0
func (s *AccountState) GetBalanceValues() map[util.Uint256]util.Fixed8
GetBalanceValues sums all unspent outputs and returns a map of asset IDs to overall balances.
type Accounts ¶
type Accounts map[util.Uint160]*AccountState
Accounts is mapping between a account address and AccountState.
type AppExecResult ¶ added in v0.70.0
type AppExecResult struct { TxHash util.Uint256 Trigger byte VMState string GasConsumed util.Fixed8 Stack string // JSON Events []NotificationEvent }
AppExecResult represent the result of the script execution, gathering together all resulting notifications, state, stack and other metadata.
func (*AppExecResult) DecodeBinary ¶ added in v0.70.0
func (aer *AppExecResult) DecodeBinary(r *io.BinReader)
DecodeBinary implements the Serializable interface.
func (*AppExecResult) EncodeBinary ¶ added in v0.70.0
func (aer *AppExecResult) EncodeBinary(w *io.BinWriter)
EncodeBinary implements the Serializable interface.
type AssetState ¶
type AssetState struct { ID util.Uint256 AssetType transaction.AssetType Name string Amount util.Fixed8 Available util.Fixed8 Precision uint8 FeeMode uint8 FeeAddress util.Uint160 Owner *keys.PublicKey Admin util.Uint160 Issuer util.Uint160 Expiration uint32 IsFrozen bool }
AssetState represents the state of an NEO registered Asset.
func (*AssetState) DecodeBinary ¶
func (a *AssetState) DecodeBinary(br *io.BinReader)
DecodeBinary implements Serializable interface.
func (*AssetState) EncodeBinary ¶
func (a *AssetState) EncodeBinary(bw *io.BinWriter)
EncodeBinary implements Serializable interface.
func (*AssetState) GetName ¶
func (a *AssetState) GetName() string
GetName returns the asset name based on its type.
type Assets ¶
type Assets map[util.Uint256]*AssetState
Assets is mapping between AssetID and the AssetState.
type Block ¶
type Block struct { // The base of the block. BlockBase // Transaction list. Transactions []*transaction.Transaction `json:"tx"` // True if this block is created from trimmed data. Trimmed bool `json:"-"` }
Block represents one block in the chain.
func NewBlockFromTrimmedBytes ¶
NewBlockFromTrimmedBytes returns a new block from trimmed data. This is commonly used to create a block from stored data. Blocks created from trimmed data will have their Trimmed field set to true.
func (*Block) DecodeBinary ¶
DecodeBinary decodes the block from the given BinReader, implementing Serializable interface.
func (*Block) EncodeBinary ¶
EncodeBinary encodes the block to the given BinWriter, implementing Serializable interface.
type BlockBase ¶
type BlockBase struct { // Version of the block. Version uint32 `json:"version"` // hash of the previous block. PrevHash util.Uint256 `json:"previousblockhash"` // Root hash of a transaction list. MerkleRoot util.Uint256 `json:"merkleroot"` // The time stamp of each block must be later than previous block's time stamp. // Generally the difference of two block's time stamp is about 15 seconds and imprecision is allowed. // The height of the block must be exactly equal to the height of the previous block plus 1. Timestamp uint32 `json:"time"` // index/height of the block Index uint32 `json:"height"` // Random number also called nonce ConsensusData uint64 `json:"nonce"` // Contract address of the next miner NextConsensus util.Uint160 `json:"next_consensus"` // Script used to validate the block Script *transaction.Witness `json:"script"` // contains filtered or unexported fields }
BlockBase holds the base info of a block
func (*BlockBase) DecodeBinary ¶
DecodeBinary implements Serializable interface.
func (*BlockBase) EncodeBinary ¶
EncodeBinary implements Serializable interface
func (*BlockBase) GetHashableData ¶ added in v0.70.0
GetHashableData returns serialized hashable data of the block.
func (*BlockBase) VerificationHash ¶ added in v0.51.0
VerificationHash returns the hash of the block used to verify it.
type BlockChainState ¶ added in v0.70.0
type BlockChainState struct {
// contains filtered or unexported fields
}
BlockChainState represents Blockchain state structure with mempool.
func NewBlockChainState ¶ added in v0.70.0
func NewBlockChainState(store *storage.MemCachedStore) *BlockChainState
NewBlockChainState creates blockchain state with it's memchached store.
type Blockchain ¶
type Blockchain struct {
// contains filtered or unexported fields
}
Blockchain represents the blockchain.
func NewBlockchain ¶
func NewBlockchain(s storage.Store, cfg config.ProtocolConfiguration) (*Blockchain, error)
NewBlockchain returns a new blockchain object the will use the given Store as its underlying storage.
func (*Blockchain) AddBlock ¶
func (bc *Blockchain) AddBlock(block *Block) error
AddBlock accepts successive block for the Blockchain, verifies it and stores internally. Eventually it will be persisted to the backing storage.
func (*Blockchain) AddHeaders ¶
func (bc *Blockchain) AddHeaders(headers ...*Header) (err error)
AddHeaders processes the given headers and add them to the HeaderHashList.
func (*Blockchain) BlockHeight ¶
func (bc *Blockchain) BlockHeight() uint32
BlockHeight returns the height/index of the highest block.
func (*Blockchain) Close ¶ added in v0.70.0
func (bc *Blockchain) Close()
Close stops Blockchain's internal loop, syncs changes to persistent storage and closes it. The Blockchain is no longer functional after the call to Close.
func (*Blockchain) CurrentBlockHash ¶
func (bc *Blockchain) CurrentBlockHash() (hash util.Uint256)
CurrentBlockHash returns the highest processed block hash.
func (*Blockchain) CurrentHeaderHash ¶
func (bc *Blockchain) CurrentHeaderHash() (hash util.Uint256)
CurrentHeaderHash returns the hash of the latest known header.
func (*Blockchain) FeePerByte ¶
func (bc *Blockchain) FeePerByte(t *transaction.Transaction) util.Fixed8
FeePerByte returns network fee divided by the size of the transaction.
func (*Blockchain) GetAccountState ¶
func (bc *Blockchain) GetAccountState(scriptHash util.Uint160) *AccountState
GetAccountState returns the account state from its script hash.
func (*Blockchain) GetAssetState ¶
func (bc *Blockchain) GetAssetState(assetID util.Uint256) *AssetState
GetAssetState returns asset state from its assetID.
func (*Blockchain) GetBlock ¶
func (bc *Blockchain) GetBlock(hash util.Uint256) (*Block, error)
GetBlock returns a Block by the given hash.
func (*Blockchain) GetConfig ¶
func (bc *Blockchain) GetConfig() config.ProtocolConfiguration
GetConfig returns the config stored in the blockchain.
func (*Blockchain) GetContractState ¶ added in v0.51.0
func (bc *Blockchain) GetContractState(hash util.Uint160) *ContractState
GetContractState returns contract by its script hash.
func (*Blockchain) GetHeader ¶
func (bc *Blockchain) GetHeader(hash util.Uint256) (*Header, error)
GetHeader returns data block header identified with the given hash value.
func (*Blockchain) GetHeaderHash ¶
func (bc *Blockchain) GetHeaderHash(i int) (hash util.Uint256)
GetHeaderHash returns the hash from the headerList by its height/index.
func (*Blockchain) GetMemPool ¶
func (bc *Blockchain) GetMemPool() MemPool
GetMemPool returns the memory pool of the blockchain.
func (*Blockchain) GetScriptHashesForVerifying ¶
func (bc *Blockchain) GetScriptHashesForVerifying(t *transaction.Transaction) ([]util.Uint160, error)
GetScriptHashesForVerifying returns all the ScriptHashes of a transaction which will be use to verify whether the transaction is bonafide or not. Golang implementation of GetScriptHashesForVerifying method in C# (https://github.com/neo-project/neo/blob/master/neo/Network/P2P/Payloads/Transaction.cs#L190)
func (*Blockchain) GetScriptHashesForVerifyingClaim ¶ added in v0.51.0
func (bc *Blockchain) GetScriptHashesForVerifyingClaim(t *transaction.Transaction) ([]util.Uint160, error)
GetScriptHashesForVerifyingClaim returns all ScriptHashes of Claim transaction which has a different implementation from generic GetScriptHashesForVerifying.
func (*Blockchain) GetStandByValidators ¶ added in v0.70.0
func (bc *Blockchain) GetStandByValidators() (keys.PublicKeys, error)
GetStandByValidators returns validators from the configuration.
func (*Blockchain) GetStorageItem ¶ added in v0.51.0
func (bc *Blockchain) GetStorageItem(scripthash util.Uint160, key []byte) *StorageItem
GetStorageItem returns an item from storage.
func (*Blockchain) GetStorageItems ¶ added in v0.51.0
func (bc *Blockchain) GetStorageItems(hash util.Uint160) (map[string]*StorageItem, error)
GetStorageItems returns all storage items for a given scripthash.
func (*Blockchain) GetTestVM ¶ added in v0.61.0
func (bc *Blockchain) GetTestVM() (*vm.VM, storage.Store)
GetTestVM returns a VM and a Store setup for a test run of some sort of code.
func (*Blockchain) GetTransaction ¶
func (bc *Blockchain) GetTransaction(hash util.Uint256) (*transaction.Transaction, uint32, error)
GetTransaction returns a TX and its height by the given hash.
func (*Blockchain) GetTransactionResults ¶ added in v0.51.0
func (bc *Blockchain) GetTransactionResults(t *transaction.Transaction) []*transaction.Result
GetTransactionResults returns the transaction results aggregate by assetID. Golang of GetTransationResults method in C# (https://github.com/neo-project/neo/blob/master/neo/Network/P2P/Payloads/Transaction.cs#L207)
func (*Blockchain) GetUnspentCoinState ¶ added in v0.51.0
func (bc *Blockchain) GetUnspentCoinState(hash util.Uint256) *UnspentCoinState
GetUnspentCoinState returns unspent coin state for given tx hash.
func (*Blockchain) GetValidators ¶ added in v0.70.0
func (bc *Blockchain) GetValidators(txes ...*transaction.Transaction) ([]*keys.PublicKey, error)
GetValidators returns validators. Golang implementation of GetValidators method in C# (https://github.com/neo-project/neo/blob/c64748ecbac3baeb8045b16af0d518398a6ced24/neo/Persistence/Snapshot.cs#L182)
func (*Blockchain) HasBlock ¶
func (bc *Blockchain) HasBlock(hash util.Uint256) bool
HasBlock returns true if the blockchain contains the given block hash.
func (*Blockchain) HasTransaction ¶
func (bc *Blockchain) HasTransaction(hash util.Uint256) bool
HasTransaction returns true if the blockchain contains he given transaction hash.
func (*Blockchain) HeaderHeight ¶
func (bc *Blockchain) HeaderHeight() uint32
HeaderHeight returns the index/height of the highest header.
func (*Blockchain) IsLowPriority ¶
func (bc *Blockchain) IsLowPriority(t *transaction.Transaction) bool
IsLowPriority flags a transaction as low priority if the network fee is less than LowPriorityThreshold.
func (*Blockchain) NetworkFee ¶
func (bc *Blockchain) NetworkFee(t *transaction.Transaction) util.Fixed8
NetworkFee returns network fee.
func (*Blockchain) References ¶
func (bc *Blockchain) References(t *transaction.Transaction) map[transaction.Input]*transaction.Output
References returns a map with input coin reference (prevhash and index) as key and transaction output as value from a transaction t. @TODO: unfortunately we couldn't attach this method to the Transaction struct in the transaction package because of a import cycle problem. Perhaps we should think to re-design the code base to avoid this situation.
func (*Blockchain) SystemFee ¶
func (bc *Blockchain) SystemFee(t *transaction.Transaction) util.Fixed8
SystemFee returns system fee.
func (*Blockchain) VerifyBlock ¶ added in v0.51.0
func (bc *Blockchain) VerifyBlock(block *Block) error
VerifyBlock verifies block against its current state.
func (*Blockchain) VerifyTx ¶ added in v0.51.0
func (bc *Blockchain) VerifyTx(t *transaction.Transaction, block *Block) error
VerifyTx verifies whether a transaction is bonafide or not. Block parameter is used for easy interop access and can be omitted for transactions that are not yet added into any block. Golang implementation of Verify method in C# (https://github.com/neo-project/neo/blob/master/neo/Network/P2P/Payloads/Transaction.cs#L270).
type Blockchainer ¶
type Blockchainer interface { GetConfig() config.ProtocolConfiguration AddHeaders(...*Header) error AddBlock(*Block) error BlockHeight() uint32 Close() HeaderHeight() uint32 GetBlock(hash util.Uint256) (*Block, error) GetContractState(hash util.Uint160) *ContractState GetHeaderHash(int) util.Uint256 GetHeader(hash util.Uint256) (*Header, error) CurrentHeaderHash() util.Uint256 CurrentBlockHash() util.Uint256 HasBlock(util.Uint256) bool HasTransaction(util.Uint256) bool GetAssetState(util.Uint256) *AssetState GetAccountState(util.Uint160) *AccountState GetValidators(txes ...*transaction.Transaction) ([]*keys.PublicKey, error) GetScriptHashesForVerifying(*transaction.Transaction) ([]util.Uint160, error) GetStorageItem(scripthash util.Uint160, key []byte) *StorageItem GetStorageItems(hash util.Uint160) (map[string]*StorageItem, error) GetTestVM() (*vm.VM, storage.Store) GetTransaction(util.Uint256) (*transaction.Transaction, uint32, error) GetUnspentCoinState(util.Uint256) *UnspentCoinState References(t *transaction.Transaction) map[transaction.Input]*transaction.Output Feer // fee interface VerifyTx(*transaction.Transaction, *Block) error GetMemPool() MemPool }
Blockchainer is an interface that abstract the implementation of the blockchain.
type ContractState ¶
type ContractState struct { Script []byte ParamList []smartcontract.ParamType ReturnType smartcontract.ParamType Properties smartcontract.PropertyState Name string CodeVersion string Author string Email string Description string // contains filtered or unexported fields }
ContractState holds information about a smart contract in the NEO blockchain.
func (*ContractState) DecodeBinary ¶ added in v0.51.0
func (cs *ContractState) DecodeBinary(br *io.BinReader)
DecodeBinary implements Serializable interface.
func (*ContractState) EncodeBinary ¶ added in v0.51.0
func (cs *ContractState) EncodeBinary(bw *io.BinWriter)
EncodeBinary implements Serializable interface.
func (*ContractState) HasDynamicInvoke ¶
func (cs *ContractState) HasDynamicInvoke() bool
HasDynamicInvoke checks whether the contract has dynamic invoke property set.
func (*ContractState) HasStorage ¶
func (cs *ContractState) HasStorage() bool
HasStorage checks whether the contract has storage property set.
func (*ContractState) IsPayable ¶ added in v0.51.0
func (cs *ContractState) IsPayable() bool
IsPayable checks whether the contract has payable property set.
func (*ContractState) ScriptHash ¶ added in v0.51.0
func (cs *ContractState) ScriptHash() util.Uint160
ScriptHash returns a contract script hash.
type Contracts ¶ added in v0.51.0
type Contracts map[util.Uint160]*ContractState
Contracts is a mapping between scripthash and ContractState.
type Feer ¶
type Feer interface { NetworkFee(t *transaction.Transaction) util.Fixed8 IsLowPriority(t *transaction.Transaction) bool FeePerByte(t *transaction.Transaction) util.Fixed8 SystemFee(t *transaction.Transaction) util.Fixed8 }
Feer is an interface that abstract the implementation of the fee calculation.
type Header ¶
type Header struct { // Base of the block. BlockBase // contains filtered or unexported fields }
Header holds the head info of a block.
func (*Header) DecodeBinary ¶
DecodeBinary implements Serializable interface.
func (*Header) EncodeBinary ¶
EncodeBinary implements Serializable interface.
type HeaderHashList ¶
type HeaderHashList struct {
// contains filtered or unexported fields
}
A HeaderHashList represents a list of header hashes. This data structure in not routine safe and should be used under some kind of protection against race conditions.
func NewHeaderHashList ¶
func NewHeaderHashList(hashes ...util.Uint256) *HeaderHashList
NewHeaderHashList returns a new pointer to a HeaderHashList.
func NewHeaderHashListFromBytes ¶
func NewHeaderHashListFromBytes(b []byte) (*HeaderHashList, error)
NewHeaderHashListFromBytes returns a new hash list from the given bytes.
func (*HeaderHashList) Add ¶
func (l *HeaderHashList) Add(h ...util.Uint256)
Add appends the given hash to the list of hashes.
func (*HeaderHashList) Get ¶
func (l *HeaderHashList) Get(i int) util.Uint256
Get returns the hash by the given index.
func (*HeaderHashList) Last ¶
func (l *HeaderHashList) Last() util.Uint256
Last return the last hash in the HeaderHashList.
func (*HeaderHashList) Len ¶
func (l *HeaderHashList) Len() int
Len returns the length of the underlying hashes slice.
type MemPool ¶
type MemPool struct {
// contains filtered or unexported fields
}
MemPool stores the unconfirms transactions.
func (MemPool) ContainsKey ¶
ContainsKey checks if a transactions hash is in the MemPool.
func (*MemPool) GetVerifiedTransactions ¶
func (mp *MemPool) GetVerifiedTransactions() []*transaction.Transaction
GetVerifiedTransactions returns a slice of Input from all the transactions in the memory pool whose hash is not included in excludedHashes.
func (*MemPool) Remove ¶ added in v0.60.0
Remove removes an item from the mempool, if it exists there (and does nothing if it doesn't).
func (*MemPool) RemoveOverCapacity ¶
func (mp *MemPool) RemoveOverCapacity()
RemoveOverCapacity removes transactions with lowest fees until the total number of transactions in the MemPool is within the capacity of the MemPool.
func (MemPool) TryGetValue ¶
func (mp MemPool) TryGetValue(hash util.Uint256) (*transaction.Transaction, bool)
TryGetValue returns a transaction if it exists in the memory pool.
func (MemPool) Verify ¶
func (mp MemPool) Verify(tx *transaction.Transaction) bool
Verify verifies if the inputs of a transaction tx are already used in any other transaction in the memory pool. If yes, the transaction tx is not a valid transaction and the function return false. If no, the transaction tx is a valid transaction and the function return true.
type NotificationEvent ¶ added in v0.70.0
NotificationEvent is a tuple of scripthash that emitted the StackItem as a notification and that item itself.
func (*NotificationEvent) DecodeBinary ¶ added in v0.70.0
func (ne *NotificationEvent) DecodeBinary(r *io.BinReader)
DecodeBinary implements the Serializable interface.
func (NotificationEvent) EncodeBinary ¶ added in v0.70.0
func (ne NotificationEvent) EncodeBinary(w *io.BinWriter)
EncodeBinary implements the Serializable interface.
type PoolItem ¶
type PoolItem struct {
// contains filtered or unexported fields
}
PoolItem represents a transaction in the the Memory pool.
func NewPoolItem ¶
func NewPoolItem(t *transaction.Transaction, fee Feer) *PoolItem
NewPoolItem returns a new PoolItem.
type SpentCoinState ¶
type SpentCoinState struct {
// contains filtered or unexported fields
}
SpentCoinState represents the state of a spent coin.
func NewSpentCoinState ¶
func NewSpentCoinState(hash util.Uint256, height uint32) *SpentCoinState
NewSpentCoinState returns a new SpentCoinState object.
func (*SpentCoinState) DecodeBinary ¶
func (s *SpentCoinState) DecodeBinary(br *io.BinReader)
DecodeBinary implements Serializable interface.
func (*SpentCoinState) EncodeBinary ¶
func (s *SpentCoinState) EncodeBinary(bw *io.BinWriter)
EncodeBinary implements Serializable interface.
type SpentCoins ¶
type SpentCoins map[util.Uint256]*SpentCoinState
SpentCoins is mapping between transactions and their spent coin state.
type StorageContext ¶ added in v0.51.0
StorageContext contains storing script hash and read/write flag, it's used as a context for storage manipulation functions.
type StorageItem ¶ added in v0.51.0
StorageItem is the value to be stored with read-only flag.
func (*StorageItem) DecodeBinary ¶ added in v0.51.0
func (si *StorageItem) DecodeBinary(r *io.BinReader)
DecodeBinary implements Serializable interface.
func (*StorageItem) EncodeBinary ¶ added in v0.51.0
func (si *StorageItem) EncodeBinary(w *io.BinWriter)
EncodeBinary implements Serializable interface.
type UnspentBalance ¶ added in v0.70.0
type UnspentBalance struct { Tx util.Uint256 `json:"txid"` Index uint16 `json:"n"` Value util.Fixed8 `json:"value"` }
UnspentBalance contains input/output transactons that sum up into the account balance for the given asset.
func (*UnspentBalance) DecodeBinary ¶ added in v0.70.0
func (u *UnspentBalance) DecodeBinary(r *io.BinReader)
DecodeBinary implements io.Serializable interface.
func (UnspentBalance) EncodeBinary ¶ added in v0.70.0
func (u UnspentBalance) EncodeBinary(w *io.BinWriter)
EncodeBinary implements io.Serializable interface.
type UnspentBalances ¶ added in v0.70.0
type UnspentBalances []UnspentBalance
UnspentBalances is a slice of UnspentBalance (mostly needed to sort them).
func (UnspentBalances) Len ¶ added in v0.70.0
func (us UnspentBalances) Len() int
Len returns the length of UnspentBalances (used to sort things).
func (UnspentBalances) Less ¶ added in v0.70.0
func (us UnspentBalances) Less(i, j int) bool
Less compares two elements of UnspentBalances (used to sort things).
func (UnspentBalances) Swap ¶ added in v0.70.0
func (us UnspentBalances) Swap(i, j int)
Swap swaps two elements of UnspentBalances (used to sort things).
type UnspentCoinState ¶
type UnspentCoinState struct {
// contains filtered or unexported fields
}
UnspentCoinState hold the state of a unspent coin.
func NewUnspentCoinState ¶
func NewUnspentCoinState(n int) *UnspentCoinState
NewUnspentCoinState returns a new unspent coin state with N confirmed states.
func (*UnspentCoinState) DecodeBinary ¶
func (s *UnspentCoinState) DecodeBinary(br *io.BinReader)
DecodeBinary decodes UnspentCoinState from the given BinReader.
func (*UnspentCoinState) EncodeBinary ¶
func (s *UnspentCoinState) EncodeBinary(bw *io.BinWriter)
EncodeBinary encodes UnspentCoinState to the given BinWriter.
type UnspentCoins ¶
type UnspentCoins map[util.Uint256]*UnspentCoinState
UnspentCoins is mapping between transactions and their unspent coin state.
type ValidatorState ¶
ValidatorState holds the state of a validator.
func (*ValidatorState) DecodeBinary ¶ added in v0.70.0
func (vs *ValidatorState) DecodeBinary(reader *io.BinReader)
DecodeBinary decodes ValidatorState from the given BinReader.
func (*ValidatorState) EncodeBinary ¶ added in v0.70.0
func (vs *ValidatorState) EncodeBinary(bw *io.BinWriter)
EncodeBinary encodes ValidatorState to the given BinWriter.
func (*ValidatorState) RegisteredAndHasVotes ¶ added in v0.70.0
func (vs *ValidatorState) RegisteredAndHasVotes() bool
RegisteredAndHasVotes returns true or false whether Validator is registered and has votes.
type Validators ¶
type Validators map[*keys.PublicKey]*ValidatorState
Validators is a mapping between public keys and ValidatorState.
Source Files ¶
- account_state.go
- asset_state.go
- block.go
- block_base.go
- blockchain.go
- blockchain_state.go
- blockchainer.go
- coin_state.go
- contract_state.go
- feer.go
- header.go
- header_hash_list.go
- interop_neo.go
- interop_system.go
- interops.go
- mem_pool.go
- notification_event.go
- prometheus.go
- spent_coin_state.go
- storage_item.go
- unspent_coin_state.go
- util.go
- validator_state.go