Documentation ¶
Index ¶
Constants ¶
const ( // GenesisBaseFeeEM is the initial base fee elasticity multiplier for EIP-1559 blocks. GenesisBaseFeeEM = 2 // GenesisGasLimit is the default gas limit of the Genesis block. GenesisGasLimit uint64 = 4712388 // GenesisDifficulty is the default difficulty of the Genesis block. GenesisDifficulty uint64 = 131072 )
const ( Homestead = "homestead" Byzantium = "byzantium" Constantinople = "constantinople" Petersburg = "petersburg" Istanbul = "istanbul" London = "london" EIP150 = "EIP150" EIP158 = "EIP158" EIP155 = "EIP155" )
predefined forks
Variables ¶
var AllForksEnabled = &Forks{ Homestead: NewFork(0), EIP150: NewFork(0), EIP155: NewFork(0), EIP158: NewFork(0), Byzantium: NewFork(0), Constantinople: NewFork(0), Petersburg: NewFork(0), Istanbul: NewFork(0), London: NewFork(0), }
AllForksEnabled should contain all supported forks by current edge version
var ( // ErrBurnContractAddressMissing is the error when a contract address is not provided ErrBurnContractAddressMissing = errors.New("burn contract address missing") )
var ( // GenesisBaseFee is the initial base fee for EIP-1559 blocks. GenesisBaseFee = ethgo.Gwei(1).Uint64() )
Functions ¶
This section is empty.
Types ¶
type AddressListConfig ¶ added in v0.9.0
type Chain ¶
type Chain struct { Name string `json:"name"` Genesis *Genesis `json:"genesis"` Params *Params `json:"params"` Bootnodes []string `json:"bootnodes,omitempty"` }
Chain is the blockchain chain configuration
func ImportFromFile ¶
ImportFromFile imports a chain from a filepath
type Fork ¶
type Fork struct { Block uint64 `json:"block"` Params *ForkParams `json:"params,omitempty"` }
type ForkParams ¶ added in v1.0.0
type ForkParams struct { // MaxValidatorSetSize indicates the maximum size of validator set MaxValidatorSetSize *uint64 `json:"maxValidatorSetSize,omitempty"` // EpochSize is size of epoch EpochSize *uint64 `json:"epochSize,omitempty"` // SprintSize is size of sprint SprintSize *uint64 `json:"sprintSize,omitempty"` // BlockTime is target frequency of blocks production BlockTime *common.Duration `json:"blockTime,omitempty"` // BlockTimeDrift defines the time slot in which a new block can be created BlockTimeDrift *uint64 `json:"blockTimeDrift,omitempty"` }
ForkParams hard-coded fork params
type Forks ¶
Forks is map which contains all forks and their starting blocks from genesis
func (*Forks) At ¶
func (f *Forks) At(block uint64) ForksInTime
At returns ForksInTime instance that shows which supported forks are enabled for the block
func (*Forks) IsActive ¶ added in v1.0.0
IsActive returns true if fork defined by name exists and defined for the block
func (*Forks) RemoveFork ¶ added in v1.0.0
type ForksInTime ¶
type ForksInTime struct { Homestead, Byzantium, Constantinople, Petersburg, Istanbul, London, EIP150, EIP158, EIP155 bool }
ForksInTime should contain all supported forks by current edge version
type Genesis ¶
type Genesis struct { Nonce [8]byte `json:"nonce"` Timestamp uint64 `json:"timestamp"` ExtraData []byte `json:"extraData,omitempty"` GasLimit uint64 `json:"gasLimit"` Difficulty uint64 `json:"difficulty"` Mixhash types.Hash `json:"mixHash"` Coinbase types.Address `json:"coinbase"` Alloc map[types.Address]*GenesisAccount `json:"alloc,omitempty"` BaseFee uint64 `json:"baseFee"` BaseFeeEM uint64 `json:"baseFeeEM"` // Override StateRoot types.Hash // Only for testing Number uint64 `json:"number"` GasUsed uint64 `json:"gasUsed"` ParentHash types.Hash `json:"parentHash"` }
Genesis specifies the header fields, state of a genesis block
func (*Genesis) GenesisHeader ¶
GenesisHeader converts the initially defined genesis struct to a header
func (*Genesis) MarshalJSON ¶
MarshalJSON implements the json interface
func (*Genesis) UnmarshalJSON ¶
UnmarshalJSON implements the json interface
type GenesisAccount ¶
type GenesisAccount struct { Code []byte `json:"code,omitempty"` Storage map[types.Hash]types.Hash `json:"storage,omitempty"` Balance *big.Int `json:"balance,omitempty"` Nonce uint64 `json:"nonce,omitempty"` PrivateKey []byte `json:"secretKey,omitempty"` // for tests }
GenesisAccount is an account in the state of the genesis block.
func (*GenesisAccount) MarshalJSON ¶
func (g *GenesisAccount) MarshalJSON() ([]byte, error)
func (*GenesisAccount) UnmarshalJSON ¶
func (g *GenesisAccount) UnmarshalJSON(data []byte) error
type Params ¶
type Params struct { Forks *Forks `json:"forks"` ChainID int64 `json:"chainID"` Engine map[string]interface{} `json:"engine"` BlockGasTarget uint64 `json:"blockGasTarget"` // Access control configuration ContractDeployerAllowList *AddressListConfig `json:"contractDeployerAllowList,omitempty"` ContractDeployerBlockList *AddressListConfig `json:"contractDeployerBlockList,omitempty"` TransactionsAllowList *AddressListConfig `json:"transactionsAllowList,omitempty"` TransactionsBlockList *AddressListConfig `json:"transactionsBlockList,omitempty"` BridgeAllowList *AddressListConfig `json:"bridgeAllowList,omitempty"` BridgeBlockList *AddressListConfig `json:"bridgeBlockList,omitempty"` // Governance contract where the token will be sent to and burn in london fork BurnContract map[uint64]types.Address `json:"burnContract"` // Destination address to initialize default burn contract with BurnContractDestinationAddress types.Address `json:"burnContractDestinationAddress,omitempty"` }
Params are all the set of params for the chain
func (*Params) CalculateBurnContract ¶ added in v0.9.0
CalculateBurnContract calculates burn contract address for the given block number