Documentation ¶
Index ¶
- Variables
- func BlockByNumber(txn db.Transaction, number uint64) (*core.Block, error)
- func RegisterCoreTypesToEncoder()
- func StoreBlockCommitments(txn db.Transaction, blockNumber uint64, commitments *core.BlockCommitments) error
- func StoreBlockHeader(txn db.Transaction, header *core.Header) error
- type Blockchain
- func (b *Blockchain) BlockByHash(hash *felt.Felt) (*core.Block, error)
- func (b *Blockchain) BlockByNumber(number uint64) (*core.Block, error)
- func (b *Blockchain) BlockCommitmentsByNumber(blockNumber uint64) (*core.BlockCommitments, error)
- func (b *Blockchain) BlockHeaderByHash(hash *felt.Felt) (*core.Header, error)
- func (b *Blockchain) BlockHeaderByNumber(number uint64) (*core.Header, error)
- func (b *Blockchain) EventFilter(from *felt.Felt, keys [][]felt.Felt) (*EventFilter, error)
- func (b *Blockchain) Head() (*core.Block, error)
- func (b *Blockchain) HeadState() (core.StateReader, StateCloser, error)
- func (b *Blockchain) HeadsHeader() (*core.Header, error)
- func (b *Blockchain) Height() (uint64, error)
- func (b *Blockchain) L1Head() (*core.L1Head, error)
- func (b *Blockchain) Network() utils.Network
- func (b *Blockchain) Pending() (Pending, error)
- func (b *Blockchain) PendingState() (core.StateReader, StateCloser, error)
- func (b *Blockchain) Receipt(hash *felt.Felt) (*core.TransactionReceipt, *felt.Felt, uint64, error)
- func (b *Blockchain) RevertHead() error
- func (b *Blockchain) SanityCheckNewHeight(block *core.Block, stateUpdate *core.StateUpdate, ...) (*core.BlockCommitments, error)
- func (b *Blockchain) SetL1Head(update *core.L1Head) error
- func (b *Blockchain) StateAtBlockHash(blockHash *felt.Felt) (core.StateReader, StateCloser, error)
- func (b *Blockchain) StateAtBlockNumber(blockNumber uint64) (core.StateReader, StateCloser, error)
- func (b *Blockchain) StateCommitment() (*felt.Felt, error)
- func (b *Blockchain) StateUpdateByHash(hash *felt.Felt) (*core.StateUpdate, error)
- func (b *Blockchain) StateUpdateByNumber(number uint64) (*core.StateUpdate, error)
- func (b *Blockchain) Store(block *core.Block, blockCommitments *core.BlockCommitments, ...) error
- func (b *Blockchain) StorePending(pending *Pending) error
- func (b *Blockchain) SubscribeNewHeads(sink chan<- *core.Header) event.Subscription
- func (b *Blockchain) TransactionByBlockNumberAndIndex(blockNumber, index uint64) (core.Transaction, error)
- func (b *Blockchain) TransactionByHash(hash *felt.Felt) (core.Transaction, error)
- func (b *Blockchain) VerifyBlock(block *core.Block) error
- type ContinuationToken
- type EventFilter
- func (e *EventFilter) Close() error
- func (e *EventFilter) Events(cToken *ContinuationToken, chunkSize uint64) ([]*FilteredEvent, *ContinuationToken, error)
- func (e *EventFilter) SetRangeEndBlockByHash(filterRange EventFilterRange, blockHash *felt.Felt) error
- func (e *EventFilter) SetRangeEndBlockByNumber(filterRange EventFilterRange, blockNumber uint64) error
- type EventFilterRange
- type FilteredEvent
- type Pending
- type PendingState
- func (p *PendingState) Class(classHash *felt.Felt) (*core.DeclaredClass, error)
- func (p *PendingState) ContractClassHash(addr *felt.Felt) (*felt.Felt, error)
- func (p *PendingState) ContractNonce(addr *felt.Felt) (*felt.Felt, error)
- func (p *PendingState) ContractStorage(addr, key *felt.Felt) (*felt.Felt, error)
- type Reader
- type StateCloser
Constants ¶
This section is empty.
Variables ¶
var (
ErrParentDoesNotMatchHead = errors.New("block's parent hash does not match head block hash")
)
Functions ¶
func BlockByNumber ¶ added in v0.4.0
BlockByNumber retrieves a block from database by its number
func RegisterCoreTypesToEncoder ¶ added in v0.4.0
func RegisterCoreTypesToEncoder()
func StoreBlockCommitments ¶ added in v0.6.0
func StoreBlockCommitments(txn db.Transaction, blockNumber uint64, commitments *core.BlockCommitments) error
func StoreBlockHeader ¶ added in v0.4.0
func StoreBlockHeader(txn db.Transaction, header *core.Header) error
StoreBlockHeader stores the given block in the database. The db storage for blocks is maintained by two buckets as follows:
db.BlockHeaderNumbersByHash(BlockHash) -> (BlockNumber) db.BlockHeadersByNumber(BlockNumber) -> (BlockHeader)
"[]" is the db prefix to represent a bucket "()" are additional keys appended to the prefix or multiple values marshalled together "->" represents a key value pair.
Types ¶
type Blockchain ¶
type Blockchain struct {
// contains filtered or unexported fields
}
Blockchain is responsible for keeping track of all things related to the Starknet blockchain
func New ¶
func New(database db.DB, network utils.Network, log utils.SimpleLogger) *Blockchain
func (*Blockchain) BlockByHash ¶ added in v0.2.1
func (*Blockchain) BlockByNumber ¶ added in v0.2.1
func (b *Blockchain) BlockByNumber(number uint64) (*core.Block, error)
func (*Blockchain) BlockCommitmentsByNumber ¶ added in v0.6.0
func (b *Blockchain) BlockCommitmentsByNumber(blockNumber uint64) (*core.BlockCommitments, error)
func (*Blockchain) BlockHeaderByHash ¶ added in v0.2.1
func (*Blockchain) BlockHeaderByNumber ¶ added in v0.2.1
func (b *Blockchain) BlockHeaderByNumber(number uint64) (*core.Header, error)
func (*Blockchain) EventFilter ¶ added in v0.3.1
func (b *Blockchain) EventFilter(from *felt.Felt, keys [][]felt.Felt) (*EventFilter, error)
EventFilter returns an EventFilter object that is tied to a snapshot of the blockchain
func (*Blockchain) HeadState ¶ added in v0.3.0
func (b *Blockchain) HeadState() (core.StateReader, StateCloser, error)
HeadState returns a StateReader that provides a stable view to the latest state
func (*Blockchain) HeadsHeader ¶
func (b *Blockchain) HeadsHeader() (*core.Header, error)
func (*Blockchain) Height ¶
func (b *Blockchain) Height() (uint64, error)
Height returns the latest block height. If blockchain is empty nil is returned.
func (*Blockchain) Network ¶
func (b *Blockchain) Network() utils.Network
func (*Blockchain) Pending ¶ added in v0.4.0
func (b *Blockchain) Pending() (Pending, error)
Pending returns the pending block from the database
func (*Blockchain) PendingState ¶ added in v0.4.0
func (b *Blockchain) PendingState() (core.StateReader, StateCloser, error)
PendingState returns the state resulting from execution of the pending block
func (*Blockchain) Receipt ¶ added in v0.2.1
func (b *Blockchain) Receipt(hash *felt.Felt) (*core.TransactionReceipt, *felt.Felt, uint64, error)
Receipt gets the transaction receipt for a given transaction hash.
func (*Blockchain) RevertHead ¶ added in v0.4.0
func (b *Blockchain) RevertHead() error
RevertHead reverts the head block
func (*Blockchain) SanityCheckNewHeight ¶
func (b *Blockchain) SanityCheckNewHeight(block *core.Block, stateUpdate *core.StateUpdate, newClasses map[felt.Felt]core.Class, ) (*core.BlockCommitments, error)
SanityCheckNewHeight checks integrity of a block and resulting state update
func (*Blockchain) SetL1Head ¶ added in v0.4.0
func (b *Blockchain) SetL1Head(update *core.L1Head) error
func (*Blockchain) StateAtBlockHash ¶ added in v0.3.0
func (b *Blockchain) StateAtBlockHash(blockHash *felt.Felt) (core.StateReader, StateCloser, error)
StateAtBlockHash returns a StateReader that provides a stable view to the state at the given block hash
func (*Blockchain) StateAtBlockNumber ¶ added in v0.3.0
func (b *Blockchain) StateAtBlockNumber(blockNumber uint64) (core.StateReader, StateCloser, error)
StateAtBlockNumber returns a StateReader that provides a stable view to the state at the given block number
func (*Blockchain) StateCommitment ¶
func (b *Blockchain) StateCommitment() (*felt.Felt, error)
StateCommitment returns the latest block state commitment. If blockchain is empty zero felt is returned.
func (*Blockchain) StateUpdateByHash ¶ added in v0.2.1
func (b *Blockchain) StateUpdateByHash(hash *felt.Felt) (*core.StateUpdate, error)
func (*Blockchain) StateUpdateByNumber ¶ added in v0.2.1
func (b *Blockchain) StateUpdateByNumber(number uint64) (*core.StateUpdate, error)
func (*Blockchain) Store ¶
func (b *Blockchain) Store(block *core.Block, blockCommitments *core.BlockCommitments, stateUpdate *core.StateUpdate, newClasses map[felt.Felt]core.Class, ) error
Store takes a block and state update and performs sanity checks before putting in the database.
func (*Blockchain) StorePending ¶ added in v0.4.0
func (b *Blockchain) StorePending(pending *Pending) error
StorePending stores a pending block given that it is for the next height
func (*Blockchain) SubscribeNewHeads ¶ added in v0.5.0
func (b *Blockchain) SubscribeNewHeads(sink chan<- *core.Header) event.Subscription
func (*Blockchain) TransactionByBlockNumberAndIndex ¶ added in v0.2.1
func (b *Blockchain) TransactionByBlockNumberAndIndex(blockNumber, index uint64) (core.Transaction, error)
TransactionByBlockNumberAndIndex gets the transaction for a given block number and index.
func (*Blockchain) TransactionByHash ¶ added in v0.2.1
func (b *Blockchain) TransactionByHash(hash *felt.Felt) (core.Transaction, error)
TransactionByHash gets the transaction for a given hash.
func (*Blockchain) VerifyBlock ¶
func (b *Blockchain) VerifyBlock(block *core.Block) error
VerifyBlock assumes the block has already been sanity-checked.
type ContinuationToken ¶ added in v0.3.1
type ContinuationToken struct {
// contains filtered or unexported fields
}
func (*ContinuationToken) FromString ¶ added in v0.3.1
func (c *ContinuationToken) FromString(str string) error
func (*ContinuationToken) String ¶ added in v0.3.1
func (c *ContinuationToken) String() string
type EventFilter ¶ added in v0.3.1
type EventFilter struct {
// contains filtered or unexported fields
}
func (*EventFilter) Close ¶ added in v0.3.1
func (e *EventFilter) Close() error
Close closes the underlying database transaction that provides the blockchain snapshot
func (*EventFilter) Events ¶ added in v0.3.1
func (e *EventFilter) Events(cToken *ContinuationToken, chunkSize uint64) ([]*FilteredEvent, *ContinuationToken, error)
func (*EventFilter) SetRangeEndBlockByHash ¶ added in v0.3.1
func (e *EventFilter) SetRangeEndBlockByHash(filterRange EventFilterRange, blockHash *felt.Felt) error
SetRangeEndBlockByHash sets an end of the block range by block hash
func (*EventFilter) SetRangeEndBlockByNumber ¶ added in v0.3.1
func (e *EventFilter) SetRangeEndBlockByNumber(filterRange EventFilterRange, blockNumber uint64) error
SetRangeEndBlockByNumber sets an end of the block range by block number
type EventFilterRange ¶ added in v0.3.1
type EventFilterRange uint
const ( EventFilterFrom EventFilterRange = iota EventFilterTo )
type FilteredEvent ¶ added in v0.3.1
type PendingState ¶ added in v0.4.0
type PendingState struct {
// contains filtered or unexported fields
}
func NewPendingState ¶ added in v0.4.0
func NewPendingState(pending Pending, head core.StateReader) *PendingState
func (*PendingState) Class ¶ added in v0.4.0
func (p *PendingState) Class(classHash *felt.Felt) (*core.DeclaredClass, error)
func (*PendingState) ContractClassHash ¶ added in v0.4.0
func (*PendingState) ContractNonce ¶ added in v0.4.0
func (*PendingState) ContractStorage ¶ added in v0.4.0
type Reader ¶
type Reader interface { Height() (height uint64, err error) Head() (head *core.Block, err error) L1Head() (*core.L1Head, error) BlockByNumber(number uint64) (block *core.Block, err error) BlockByHash(hash *felt.Felt) (block *core.Block, err error) HeadsHeader() (header *core.Header, err error) BlockHeaderByNumber(number uint64) (header *core.Header, err error) BlockHeaderByHash(hash *felt.Felt) (header *core.Header, err error) TransactionByHash(hash *felt.Felt) (transaction core.Transaction, err error) TransactionByBlockNumberAndIndex(blockNumber, index uint64) (transaction core.Transaction, err error) Receipt(hash *felt.Felt) (receipt *core.TransactionReceipt, blockHash *felt.Felt, blockNumber uint64, err error) StateUpdateByNumber(number uint64) (update *core.StateUpdate, err error) StateUpdateByHash(hash *felt.Felt) (update *core.StateUpdate, err error) HeadState() (core.StateReader, StateCloser, error) StateAtBlockHash(blockHash *felt.Felt) (core.StateReader, StateCloser, error) StateAtBlockNumber(blockNumber uint64) (core.StateReader, StateCloser, error) PendingState() (core.StateReader, StateCloser, error) EventFilter(from *felt.Felt, keys [][]felt.Felt) (*EventFilter, error) Pending() (Pending, error) }
type StateCloser ¶ added in v0.3.0
type StateCloser = func() error