Documentation ¶
Overview ¶
Copyright (C) 2019-2021, Ava Labs, Inc. All rights reserved. See the file LICENSE for licensing terms.
Index ¶
- Variables
- func BatchedParseBlock(vm Parser, blks [][]byte) ([]snowman.Block, error)
- func GetAncestors(vm Getter, blkID ids.ID, maxBlocksNum int, maxBlocksSize int, ...) ([][]byte, error)
- type BatchedChainVM
- type ChainVM
- type Getter
- type HeightIndexedChainVM
- type Parser
- type StateSummary
- type StateSyncableVM
- type TestBatchedVM
- type TestHeightIndexedVM
- type TestStateSummary
- type TestStateSyncableVM
- func (vm *TestStateSyncableVM) GetLastStateSummary() (StateSummary, error)
- func (vm *TestStateSyncableVM) GetOngoingSyncStateSummary() (StateSummary, error)
- func (vm *TestStateSyncableVM) GetStateSummary(key uint64) (StateSummary, error)
- func (vm *TestStateSyncableVM) ParseStateSummary(summaryBytes []byte) (StateSummary, error)
- func (vm *TestStateSyncableVM) StateSyncEnabled() (bool, error)
- type TestVM
- func (vm *TestVM) BuildBlock() (snowman.Block, error)
- func (vm *TestVM) Default(cant bool)
- func (vm *TestVM) GetBlock(id ids.ID) (snowman.Block, error)
- func (vm *TestVM) LastAccepted() (ids.ID, error)
- func (vm *TestVM) ParseBlock(b []byte) (snowman.Block, error)
- func (vm *TestVM) SetPreference(id ids.ID) error
Constants ¶
This section is empty.
Variables ¶
var ( ErrHeightIndexedVMNotImplemented = errors.New("vm does not implement HeightIndexedChainVM interface") ErrIndexIncomplete = errors.New("query failed because height index is incomplete") )
var ErrRemoteVMNotImplemented = errors.New("vm does not implement RemoteVM interface")
var ErrStateSyncableVMNotImplemented = errors.New("vm does not implement StateSyncableVM interface")
Functions ¶
Types ¶
type BatchedChainVM ¶
type BatchedChainVM interface { GetAncestors( blkID ids.ID, maxBlocksNum int, maxBlocksSize int, maxBlocksRetrivalTime time.Duration, ) ([][]byte, error) BatchedParseBlock(blks [][]byte) ([]snowman.Block, error) }
BatchedChainVM extends the minimal functionalities exposed by ChainVM for VMs communicating over network (gRPC in our case). This allows more efficient operations since calls over network can be duly batched
type ChainVM ¶
type ChainVM interface { common.VM Getter Parser // Attempt to create a new block from data contained in the VM. // // If the VM doesn't want to issue a new block, an error should be // returned. BuildBlock() (snowman.Block, error) // Notify the VM of the currently preferred block. // // This should always be a block that has no children known to consensus. SetPreference(ids.ID) error // LastAccepted returns the ID of the last accepted block. // // If no blocks have been accepted by consensus yet, it is assumed there is // a definitionally accepted block, the Genesis block, that will be // returned. LastAccepted() (ids.ID, error) }
ChainVM defines the required functionality of a Snowman VM.
A Snowman VM is responsible for defining the representation of state, the representation of operations on that state, the application of operations on that state, and the creation of the operations. Consensus will decide on if the operation is executed and the order operations are executed in.
For example, suppose we have a VM that tracks an increasing number that is agreed upon by the network. The state is a single number. The operation is setting the number to a new, larger value. Applying the operation will save to the database the new value. The VM can attempt to issue a new number, of larger value, at any time. Consensus will ensure the network agrees on the number at every block height.
type Getter ¶
type Getter interface { // Attempt to load a block. // // If the block does not exist, database.ErrNotFound should be returned. // // It is expected that blocks that have been successfully verified should be // returned correctly. It is also expected that blocks that have been // accepted by the consensus engine should be able to be fetched. It is not // required for blocks that have been rejected by the consensus engine to be // able to be fetched. GetBlock(ids.ID) (snowman.Block, error) }
Getter defines the functionality for fetching a block by its ID.
type HeightIndexedChainVM ¶
type HeightIndexedChainVM interface { // VerifyHeightIndex should return: // - nil if the height index is available. // - ErrHeightIndexedVMNotImplemented if the height index is not supported. // - ErrIndexIncomplete if the height index is not currently available. // - Any other non-standard error that may have occurred when verifying the // index. VerifyHeightIndex() error // GetBlockIDAtHeight returns the ID of the block that was accepted with // [height]. GetBlockIDAtHeight(height uint64) (ids.ID, error) }
HeightIndexedChainVM extends ChainVM to allow querying block IDs by height.
type Parser ¶
type Parser interface { // Attempt to create a block from a stream of bytes. // // The block should be represented by the full byte array, without extra // bytes. // // It is expected for all historical blocks to be parseable. ParseBlock([]byte) (snowman.Block, error) }
Parser defines the functionality for fetching a block by its bytes.
type StateSummary ¶
type StateSummary interface { // ID uniquely identifies this state summary, regardless of the chain state. ID() ids.ID // Height uniquely identifies this an accepted state summary. Height() uint64 // Bytes returns a byte slice than can be used to reconstruct this summary. Bytes() []byte // Accept triggers the VM to start state syncing this summary. // // The returned boolean will be [true] if the VM has started state sync or // [false] if the VM has skipped state sync. Accept() (bool, error) }
StateSummary represents all the information needed to download, verify, and rebuild its state.
type StateSyncableVM ¶
type StateSyncableVM interface { // StateSyncEnabled indicates whether the state sync is enabled for this VM. // If StateSyncableVM is not implemented, as it may happen with a wrapper // VM, StateSyncEnabled should return false, nil StateSyncEnabled() (bool, error) // GetOngoingSyncStateSummary returns an in-progress state summary if it // exists. // // The engine can then ask the network if the ongoing summary is still // supported, thus helping the VM decide whether to continue an in-progress // sync or start over. // // Returns database.ErrNotFound if there is no in-progress sync. GetOngoingSyncStateSummary() (StateSummary, error) // GetLastStateSummary returns the latest state summary. // // Returns database.ErrNotFound if no summary is available. GetLastStateSummary() (StateSummary, error) // ParseStateSummary parses a state summary out of [summaryBytes]. ParseStateSummary(summaryBytes []byte) (StateSummary, error) // GetStateSummary retrieves the state summary that was generated at height // [summaryHeight]. // // Returns database.ErrNotFound if no summary is available at // [summaryHeight]. GetStateSummary(summaryHeight uint64) (StateSummary, error) }
StateSyncableVM contains the functionality to allow VMs to sync to a given state, rather then boostrapping from genesis.
type TestBatchedVM ¶
type TestBatchedVM struct { T *testing.T CantGetAncestors bool CantBatchParseBlock bool GetAncestorsF func( blkID ids.ID, maxBlocksNum int, maxBlocksSize int, maxBlocksRetrivalTime time.Duration, ) ([][]byte, error) BatchedParseBlockF func(blks [][]byte) ([]snowman.Block, error) }
TestBatchedVM is a BatchedVM that is useful for testing.
func (*TestBatchedVM) BatchedParseBlock ¶
func (vm *TestBatchedVM) BatchedParseBlock(blks [][]byte) ([]snowman.Block, error)
func (*TestBatchedVM) Default ¶
func (vm *TestBatchedVM) Default(cant bool)
type TestHeightIndexedVM ¶
type TestHeightIndexedVM struct { T *testing.T CantVerifyHeightIndex bool CantGetBlockIDAtHeight bool VerifyHeightIndexF func() error GetBlockIDAtHeightF func(height uint64) (ids.ID, error) }
TestBatchedVM is a BatchedVM that is useful for testing.
func (*TestHeightIndexedVM) GetBlockIDAtHeight ¶
func (vm *TestHeightIndexedVM) GetBlockIDAtHeight(height uint64) (ids.ID, error)
func (*TestHeightIndexedVM) VerifyHeightIndex ¶
func (vm *TestHeightIndexedVM) VerifyHeightIndex() error
type TestStateSummary ¶
type TestStateSummary struct { IDV ids.ID HeightV uint64 BytesV []byte T *testing.T CantAccept bool AcceptF func() (bool, error) }
func (*TestStateSummary) Accept ¶
func (s *TestStateSummary) Accept() (bool, error)
func (*TestStateSummary) Bytes ¶
func (s *TestStateSummary) Bytes() []byte
func (*TestStateSummary) Height ¶
func (s *TestStateSummary) Height() uint64
func (*TestStateSummary) ID ¶
func (s *TestStateSummary) ID() ids.ID
type TestStateSyncableVM ¶
type TestStateSyncableVM struct { T *testing.T CantStateSyncEnabled, CantStateSyncGetOngoingSummary, CantGetLastStateSummary, CantParseStateSummary, CantGetStateSummary bool StateSyncEnabledF func() (bool, error) GetOngoingSyncStateSummaryF func() (StateSummary, error) GetLastStateSummaryF func() (StateSummary, error) ParseStateSummaryF func(summaryBytes []byte) (StateSummary, error) GetStateSummaryF func(uint64) (StateSummary, error) }
func (*TestStateSyncableVM) GetLastStateSummary ¶
func (vm *TestStateSyncableVM) GetLastStateSummary() (StateSummary, error)
func (*TestStateSyncableVM) GetOngoingSyncStateSummary ¶
func (vm *TestStateSyncableVM) GetOngoingSyncStateSummary() (StateSummary, error)
func (*TestStateSyncableVM) GetStateSummary ¶
func (vm *TestStateSyncableVM) GetStateSummary(key uint64) (StateSummary, error)
func (*TestStateSyncableVM) ParseStateSummary ¶
func (vm *TestStateSyncableVM) ParseStateSummary(summaryBytes []byte) (StateSummary, error)
func (*TestStateSyncableVM) StateSyncEnabled ¶
func (vm *TestStateSyncableVM) StateSyncEnabled() (bool, error)
type TestVM ¶
type TestVM struct { common.TestVM CantBuildBlock, CantParseBlock, CantGetBlock, CantSetPreference, CantLastAccepted bool BuildBlockF func() (snowman.Block, error) ParseBlockF func([]byte) (snowman.Block, error) GetBlockF func(ids.ID) (snowman.Block, error) SetPreferenceF func(ids.ID) error LastAcceptedF func() (ids.ID, error) }
TestVM is a ChainVM that is useful for testing.