Documentation ¶
Index ¶
- Constants
- Variables
- func CanTransfer(db vm.StateDB, fromHash common.Address, balance *uint256.Int) bool
- func ExecuteContract(ctx context.Context, sm protocol.StateManager, ...) ([]byte, *action.Receipt, error)
- func MakeTransfer(db vm.StateDB, fromHash, toHash common.Address, amount *uint256.Int)
- func ReadContractStorage(ctx context.Context, sm protocol.StateManager, contract address.Address, ...) ([]byte, error)
- func SimulateExecution(ctx context.Context, sm protocol.StateManager, caller address.Address, ...) ([]byte, *action.Receipt, error)
- func WithHelperCtx(ctx context.Context, hctx HelperContext) context.Context
- type Contract
- type DepositGasWithSGD
- type GetBlockHash
- type GetBlockTime
- type HelperContext
- type Params
- type SGDRegistry
- type StateDBAdapter
- func (stateDB *StateDBAdapter) AddAddressToAccessList(addr common.Address)
- func (stateDB *StateDBAdapter) AddBalance(evmAddr common.Address, a256 *uint256.Int)
- func (stateDB *StateDBAdapter) AddLog(evmLog *types.Log)
- func (stateDB *StateDBAdapter) AddPreimage(hash common.Hash, preimage []byte)
- func (stateDB *StateDBAdapter) AddRefund(gas uint64)
- func (stateDB *StateDBAdapter) AddSlotToAccessList(addr common.Address, slot common.Hash)
- func (stateDB *StateDBAdapter) AddressInAccessList(addr common.Address) bool
- func (stateDB *StateDBAdapter) CommitContracts() error
- func (stateDB *StateDBAdapter) CreateAccount(evmAddr common.Address)
- func (stateDB *StateDBAdapter) Empty(evmAddr common.Address) bool
- func (stateDB *StateDBAdapter) Error() error
- func (stateDB *StateDBAdapter) Exist(evmAddr common.Address) bool
- func (stateDB *StateDBAdapter) ForEachStorage(addr common.Address, cb func(common.Hash, common.Hash) bool) error
- func (stateDB *StateDBAdapter) GetBalance(evmAddr common.Address) *uint256.Int
- func (stateDB *StateDBAdapter) GetCode(evmAddr common.Address) []byte
- func (stateDB *StateDBAdapter) GetCodeHash(evmAddr common.Address) common.Hash
- func (stateDB *StateDBAdapter) GetCodeSize(evmAddr common.Address) int
- func (stateDB *StateDBAdapter) GetCommittedState(evmAddr common.Address, k common.Hash) common.Hash
- func (stateDB *StateDBAdapter) GetNonce(evmAddr common.Address) uint64
- func (stateDB *StateDBAdapter) GetRefund() uint64
- func (stateDB *StateDBAdapter) GetState(evmAddr common.Address, k common.Hash) common.Hash
- func (stateDB *StateDBAdapter) GetTransientState(addr common.Address, key common.Hash) common.Hash
- func (stateDB *StateDBAdapter) HasSelfDestructed(evmAddr common.Address) bool
- func (stateDB *StateDBAdapter) IsNewAccount(evmAddr common.Address) bool
- func (stateDB *StateDBAdapter) Logs() []*action.Log
- func (stateDB *StateDBAdapter) Prepare(rules params.Rules, sender, coinbase common.Address, dst *common.Address, ...)
- func (stateDB *StateDBAdapter) RevertToSnapshot(snapshot int)
- func (stateDB *StateDBAdapter) SelfDestruct(evmAddr common.Address)
- func (stateDB *StateDBAdapter) Selfdestruct6780(evmAddr common.Address)
- func (stateDB *StateDBAdapter) SetCode(evmAddr common.Address, code []byte)
- func (stateDB *StateDBAdapter) SetNonce(evmAddr common.Address, nonce uint64)
- func (stateDB *StateDBAdapter) SetState(evmAddr common.Address, k, v common.Hash)
- func (stateDB *StateDBAdapter) SetTransientState(addr common.Address, key, value common.Hash)
- func (stateDB *StateDBAdapter) SlotInAccessList(addr common.Address, slot common.Hash) (addressOk bool, slotOk bool)
- func (stateDB *StateDBAdapter) Snapshot() int
- func (stateDB *StateDBAdapter) SubBalance(evmAddr common.Address, a256 *uint256.Int)
- func (stateDB *StateDBAdapter) SubRefund(gas uint64)
- func (stateDB *StateDBAdapter) TransactionLogs() []*action.TransactionLog
- type StateDBAdapterOption
- func AsyncContractTrieOption() StateDBAdapterOption
- func DisableSortCachedContractsOption() StateDBAdapterOption
- func FixRevertSnapshotOption() StateDBAdapterOption
- func FixSnapshotOrderOption() StateDBAdapterOption
- func LegacyNonceAccountOption() StateDBAdapterOption
- func ManualCorrectGasRefundOption() StateDBAdapterOption
- func NotFixTopicCopyBugOption() StateDBAdapterOption
- func PanicUnrecoverableErrorOption() StateDBAdapterOption
- func RevertLogOption() StateDBAdapterOption
- func SuicideTxLogMismatchPanicOption() StateDBAdapterOption
- func UseConfirmedNonceOption() StateDBAdapterOption
- func WithContext(ctx context.Context) StateDBAdapterOption
- func ZeroNonceForFreshAccountOption() StateDBAdapterOption
Constants ¶
const ( // CodeKVNameSpace is the bucket name for code CodeKVNameSpace = "Code" // ContractKVNameSpace is the bucket name for contract data storage ContractKVNameSpace = "Contract" // PreimageKVNameSpace is the bucket name for preimage data storage PreimageKVNameSpace = "Preimage" )
Variables ¶
var ( // ErrInconsistentNonce is the error that the nonce is different from executor's nonce ErrInconsistentNonce = errors.New("Nonce is not identical to executor nonce") )
Functions ¶
func CanTransfer ¶
CanTransfer checks whether the from account has enough balance
func ExecuteContract ¶
func ExecuteContract( ctx context.Context, sm protocol.StateManager, execution *action.EvmTransaction, readOnly bool, ) ([]byte, *action.Receipt, error)
ExecuteContract processes a transfer which contains a contract
func MakeTransfer ¶
MakeTransfer transfers account
func ReadContractStorage ¶
func ReadContractStorage( ctx context.Context, sm protocol.StateManager, contract address.Address, key []byte, ) ([]byte, error)
ReadContractStorage reads contract's storage
func SimulateExecution ¶
func SimulateExecution( ctx context.Context, sm protocol.StateManager, caller address.Address, ex *action.Execution, ) ([]byte, *action.Receipt, error)
SimulateExecution simulates the execution in evm
func WithHelperCtx ¶
func WithHelperCtx(ctx context.Context, hctx HelperContext) context.Context
WithHelperCtx returns a new context with helper context
Types ¶
type Contract ¶
type Contract interface { GetCommittedState(hash.Hash256) ([]byte, error) GetState(hash.Hash256) ([]byte, error) SetState(hash.Hash256, []byte) error GetCode() ([]byte, error) SetCode(hash.Hash256, []byte) SelfState() *state.Account Commit() error LoadRoot() error Iterator() (trie.Iterator, error) Snapshot() Contract }
Contract is a special type of account with code and storage trie.
type DepositGasWithSGD ¶ added in v2.0.6
type DepositGasWithSGD func(context.Context, protocol.StateManager, address.Address, *big.Int, *big.Int) (*action.TransactionLog, error)
DepositGasWithSGD deposits gas with Sharing of Gas-fee with DApps
type GetBlockHash ¶
GetBlockHash gets block hash by height
type GetBlockTime ¶
GetBlockTime gets block time by height
type HelperContext ¶
type HelperContext struct { GetBlockHash GetBlockHash GetBlockTime GetBlockTime DepositGasFunc DepositGasWithSGD // TODO: sgd should be moved into depositGasFunc Sgd SGDRegistry }
HelperContext is the context for EVM helper
type Params ¶
type Params struct {
// contains filtered or unexported fields
}
Params is the context and parameters
type SGDRegistry ¶ added in v2.0.6
type SGDRegistry interface {
CheckContract(context.Context, string, uint64) (address.Address, uint64, bool, error)
}
SGDRegistry is the interface for handling Sharing of Gas-fee with DApps
type StateDBAdapter ¶
type StateDBAdapter struct {
// contains filtered or unexported fields
}
StateDBAdapter represents the state db adapter for evm to access iotx blockchain
func NewStateDBAdapter ¶
func NewStateDBAdapter( sm protocol.StateManager, blockHeight uint64, executionHash hash.Hash256, opts ...StateDBAdapterOption, ) (*StateDBAdapter, error)
NewStateDBAdapter creates a new state db with iotex blockchain
func (*StateDBAdapter) AddAddressToAccessList ¶
func (stateDB *StateDBAdapter) AddAddressToAccessList(addr common.Address)
AddAddressToAccessList adds the given address to the access list. This operation is safe to perform even if the feature/fork is not active yet
func (*StateDBAdapter) AddBalance ¶
func (stateDB *StateDBAdapter) AddBalance(evmAddr common.Address, a256 *uint256.Int)
AddBalance adds balance to account
func (*StateDBAdapter) AddLog ¶
func (stateDB *StateDBAdapter) AddLog(evmLog *types.Log)
AddLog adds log whose transaction amount is larger than 0
func (*StateDBAdapter) AddPreimage ¶
func (stateDB *StateDBAdapter) AddPreimage(hash common.Hash, preimage []byte)
AddPreimage adds the preimage of a hash
func (*StateDBAdapter) AddRefund ¶
func (stateDB *StateDBAdapter) AddRefund(gas uint64)
AddRefund adds refund
func (*StateDBAdapter) AddSlotToAccessList ¶
func (stateDB *StateDBAdapter) AddSlotToAccessList(addr common.Address, slot common.Hash)
AddSlotToAccessList adds the given (address,slot) to the access list. This operation is safe to perform even if the feature/fork is not active yet
func (*StateDBAdapter) AddressInAccessList ¶
func (stateDB *StateDBAdapter) AddressInAccessList(addr common.Address) bool
AddressInAccessList returns true if the given address is in the access list
func (*StateDBAdapter) CommitContracts ¶
func (stateDB *StateDBAdapter) CommitContracts() error
CommitContracts commits contract code to db and update pending contract account changes to trie
func (*StateDBAdapter) CreateAccount ¶
func (stateDB *StateDBAdapter) CreateAccount(evmAddr common.Address)
CreateAccount creates an account in iotx blockchain
func (*StateDBAdapter) Empty ¶
func (stateDB *StateDBAdapter) Empty(evmAddr common.Address) bool
Empty returns true if the the contract is empty
func (*StateDBAdapter) Error ¶
func (stateDB *StateDBAdapter) Error() error
Error returns the first stored error during evm contract execution
func (*StateDBAdapter) Exist ¶
func (stateDB *StateDBAdapter) Exist(evmAddr common.Address) bool
Exist checks the existence of an address
func (*StateDBAdapter) ForEachStorage ¶
func (stateDB *StateDBAdapter) ForEachStorage(addr common.Address, cb func(common.Hash, common.Hash) bool) error
ForEachStorage loops each storage
func (*StateDBAdapter) GetBalance ¶
func (stateDB *StateDBAdapter) GetBalance(evmAddr common.Address) *uint256.Int
GetBalance gets the balance of account
func (*StateDBAdapter) GetCode ¶
func (stateDB *StateDBAdapter) GetCode(evmAddr common.Address) []byte
GetCode returns contract's code
func (*StateDBAdapter) GetCodeHash ¶
func (stateDB *StateDBAdapter) GetCodeHash(evmAddr common.Address) common.Hash
GetCodeHash returns contract's code hash
func (*StateDBAdapter) GetCodeSize ¶
func (stateDB *StateDBAdapter) GetCodeSize(evmAddr common.Address) int
GetCodeSize gets the code size saved in hash
func (*StateDBAdapter) GetCommittedState ¶
GetCommittedState gets committed state
func (*StateDBAdapter) GetNonce ¶
func (stateDB *StateDBAdapter) GetNonce(evmAddr common.Address) uint64
GetNonce gets the nonce of account
func (*StateDBAdapter) GetRefund ¶
func (stateDB *StateDBAdapter) GetRefund() uint64
GetRefund gets refund
func (*StateDBAdapter) GetTransientState ¶
GetTransientState gets transient storage for a given account.
func (*StateDBAdapter) HasSelfDestructed ¶
func (stateDB *StateDBAdapter) HasSelfDestructed(evmAddr common.Address) bool
HasSelfDestructed returns whether the contract has been killed
func (*StateDBAdapter) IsNewAccount ¶
func (stateDB *StateDBAdapter) IsNewAccount(evmAddr common.Address) bool
IsNewAccount returns true if this is a new account
func (*StateDBAdapter) Logs ¶
func (stateDB *StateDBAdapter) Logs() []*action.Log
Logs returns the logs
func (*StateDBAdapter) Prepare ¶
func (stateDB *StateDBAdapter) Prepare(rules params.Rules, sender, coinbase common.Address, dst *common.Address, precompiles []common.Address, list types.AccessList)
Prepare handles the preparatory steps for executing a state transition with. This method must be invoked before state transition.
Berlin fork: - Add sender to access list (2929) - Add destination to access list (2929) - Add precompiles to access list (2929) - Add the contents of the optional tx access list (2930)
Potential EIPs: - Reset access list (Berlin) - Add coinbase to access list (EIP-3651) - Reset transient storage (EIP-1153)
func (*StateDBAdapter) RevertToSnapshot ¶
func (stateDB *StateDBAdapter) RevertToSnapshot(snapshot int)
RevertToSnapshot reverts the state factory to the state at a given snapshot
func (*StateDBAdapter) SelfDestruct ¶
func (stateDB *StateDBAdapter) SelfDestruct(evmAddr common.Address)
SelfDestruct kills the contract
func (*StateDBAdapter) Selfdestruct6780 ¶
func (stateDB *StateDBAdapter) Selfdestruct6780(evmAddr common.Address)
Selfdestruct6780 implements EIP-6780
func (*StateDBAdapter) SetCode ¶
func (stateDB *StateDBAdapter) SetCode(evmAddr common.Address, code []byte)
SetCode sets contract's code
func (*StateDBAdapter) SetNonce ¶
func (stateDB *StateDBAdapter) SetNonce(evmAddr common.Address, nonce uint64)
SetNonce sets the nonce of account
func (*StateDBAdapter) SetState ¶
func (stateDB *StateDBAdapter) SetState(evmAddr common.Address, k, v common.Hash)
SetState sets state
func (*StateDBAdapter) SetTransientState ¶
func (stateDB *StateDBAdapter) SetTransientState(addr common.Address, key, value common.Hash)
SetTransientState sets transient storage for a given account
func (*StateDBAdapter) SlotInAccessList ¶
func (stateDB *StateDBAdapter) SlotInAccessList(addr common.Address, slot common.Hash) (addressOk bool, slotOk bool)
SlotInAccessList returns true if the given (address, slot)-tuple is in the access list
func (*StateDBAdapter) Snapshot ¶
func (stateDB *StateDBAdapter) Snapshot() int
Snapshot returns the snapshot id
func (*StateDBAdapter) SubBalance ¶
func (stateDB *StateDBAdapter) SubBalance(evmAddr common.Address, a256 *uint256.Int)
SubBalance subtracts balance from account
func (*StateDBAdapter) SubRefund ¶
func (stateDB *StateDBAdapter) SubRefund(gas uint64)
SubRefund subtracts refund
func (*StateDBAdapter) TransactionLogs ¶
func (stateDB *StateDBAdapter) TransactionLogs() []*action.TransactionLog
TransactionLogs returns the transaction logs
type StateDBAdapterOption ¶
type StateDBAdapterOption func(*StateDBAdapter) error
StateDBAdapterOption set StateDBAdapter construction param
func AsyncContractTrieOption ¶
func AsyncContractTrieOption() StateDBAdapterOption
AsyncContractTrieOption set asyncContractTrie as true
func DisableSortCachedContractsOption ¶
func DisableSortCachedContractsOption() StateDBAdapterOption
DisableSortCachedContractsOption set disable sort cached contracts as true
func FixRevertSnapshotOption ¶ added in v2.0.7
func FixRevertSnapshotOption() StateDBAdapterOption
FixRevertSnapshotOption set fixRevertSnapshot as true
func FixSnapshotOrderOption ¶
func FixSnapshotOrderOption() StateDBAdapterOption
FixSnapshotOrderOption set fixSnapshotOrder as true
func LegacyNonceAccountOption ¶
func LegacyNonceAccountOption() StateDBAdapterOption
LegacyNonceAccountOption set legacyNonceAccount as true
func ManualCorrectGasRefundOption ¶
func ManualCorrectGasRefundOption() StateDBAdapterOption
ManualCorrectGasRefundOption set manualCorrectGasRefund as true
func NotFixTopicCopyBugOption ¶
func NotFixTopicCopyBugOption() StateDBAdapterOption
NotFixTopicCopyBugOption set notFixTopicCopyBug as true
func PanicUnrecoverableErrorOption ¶
func PanicUnrecoverableErrorOption() StateDBAdapterOption
PanicUnrecoverableErrorOption set panicUnrecoverableError as true
func RevertLogOption ¶
func RevertLogOption() StateDBAdapterOption
RevertLogOption set revertLog as true
func SuicideTxLogMismatchPanicOption ¶
func SuicideTxLogMismatchPanicOption() StateDBAdapterOption
SuicideTxLogMismatchPanicOption set suicideTxLogMismatchPanic as true
func UseConfirmedNonceOption ¶
func UseConfirmedNonceOption() StateDBAdapterOption
UseConfirmedNonceOption set usePendingNonce as true
func WithContext ¶ added in v2.1.1
func WithContext(ctx context.Context) StateDBAdapterOption
func ZeroNonceForFreshAccountOption ¶
func ZeroNonceForFreshAccountOption() StateDBAdapterOption
ZeroNonceForFreshAccountOption set zeroNonceForFreshAccount as true