Documentation ¶
Index ¶
- Constants
- Variables
- func CreateAllowListFunctions(precompileAddr common.Address) []*contract.StatefulPrecompileFunction
- func CreateAllowListPrecompile(precompileAddr common.Address) contract.StatefulPrecompiledContract
- func PackModifyAllowList(address common.Address, role Role) ([]byte, error)
- func PackReadAllowList(address common.Address) ([]byte, error)
- func PackReadAllowListOutput(roleNumber *big.Int) ([]byte, error)
- func PackRoleSetEvent(role Role, account common.Address, caller common.Address, oldRole Role) ([]common.Hash, []byte, error)
- func SetAllowListRole(stateDB contract.StateDB, precompileAddr, address common.Address, role Role)
- func UnpackModifyAllowListInput(input []byte, r Role, useStrictMode bool) (common.Address, error)
- func UnpackReadAllowListInput(input []byte, useStrictMode bool) (common.Address, error)
- type AllowListConfig
- type Role
- func (r Role) Big() *big.Int
- func (r Role) Bytes() []byte
- func (r Role) CanModify(from, target Role) bool
- func (r Role) GetSetterFunctionName() (string, error)
- func (r Role) Hash() common.Hash
- func (r Role) IsAdmin() bool
- func (r Role) IsEnabled() bool
- func (r Role) IsNoRole() bool
- func (r Role) String() string
Constants ¶
const ( ModifyAllowListGasCost = contract.WriteGasCostPerSlot ReadAllowListGasCost = contract.ReadGasCostPerSlot )
const ( // AllowListEventGasCost is the gas cost of a call to the AllowList contract's event. // It is the base gas cost + the gas cost of the topics (signature, role, account, caller) // and the gas cost of the non-indexed data (oldRole). AllowListEventGasCost = contract.LogGas + contract.LogTopicGas*4 + contract.LogDataGas*common.HashLength )
Variables ¶
var ( // Error returned when an invalid write is attempted ErrCannotModifyAllowList = errors.New("cannot modify allow list") // AllowListRawABI contains the raw ABI of AllowList library interface. //go:embed allowlist.abi AllowListRawABI string AllowListABI = contract.ParseABI(AllowListRawABI) )
var ( NoRole = Role(common.BigToHash(common.Big0)) EnabledRole = Role(common.BigToHash(common.Big1)) AdminRole = Role(common.BigToHash(common.Big2)) ManagerRole = Role(common.BigToHash(common.Big3)) ErrInvalidRole = errors.New("invalid role") )
1. NoRole - this is equivalent to common.Hash{} and deletes the key from the DB when set 2. EnabledRole - allowed to call the precompile 3. Admin - allowed to both modify the allowlist and call the precompile 4. Manager - allowed to add and remove only enabled addresses and also call the precompile. (only after Durango)
var ErrCannotAddManagersBeforeDurango = fmt.Errorf("cannot add managers before Durango")
Functions ¶
func CreateAllowListFunctions ¶
func CreateAllowListFunctions(precompileAddr common.Address) []*contract.StatefulPrecompileFunction
func CreateAllowListPrecompile ¶
func CreateAllowListPrecompile(precompileAddr common.Address) contract.StatefulPrecompiledContract
CreateAllowListPrecompile returns a StatefulPrecompiledContract with R/W control of an allow list at [precompileAddr]
func PackModifyAllowList ¶
func PackReadAllowList ¶
PackReadAllowList packs [address] into the input data to the read allow list function
func PackReadAllowListOutput ¶ added in v0.5.11
func PackRoleSetEvent ¶ added in v0.5.11
func PackRoleSetEvent(role Role, account common.Address, caller common.Address, oldRole Role) ([]common.Hash, []byte, error)
PackRoleSetEvent packs the event into the appropriate arguments for RoleSet. It returns topic hashes and the encoded non-indexed data.
func SetAllowListRole ¶
SetAllowListRole sets the permissions of [address] to [role] for the precompile at [precompileAddr]. assumes [role] has already been verified as valid.
func UnpackModifyAllowListInput ¶ added in v0.5.11
Types ¶
type AllowListConfig ¶
type AllowListConfig struct { AdminAddresses []common.Address `json:"adminAddresses,omitempty"` // initial admin addresses ManagerAddresses []common.Address `json:"managerAddresses,omitempty"` // initial manager addresses EnabledAddresses []common.Address `json:"enabledAddresses,omitempty"` // initial enabled addresses }
AllowListConfig specifies the initial set of addresses with Admin or Enabled roles.
func (*AllowListConfig) Configure ¶
func (c *AllowListConfig) Configure(chainConfig precompileconfig.ChainConfig, precompileAddr common.Address, state contract.StateDB, blockContext contract.ConfigurationBlockContext) error
Configure initializes the address space of [precompileAddr] by initializing the role of each of the addresses in [AllowListAdmins].
func (*AllowListConfig) Equal ¶
func (c *AllowListConfig) Equal(other *AllowListConfig) bool
Equal returns true iff [other] has the same admins in the same order in its allow list.
func (*AllowListConfig) Verify ¶
func (c *AllowListConfig) Verify(chainConfig precompileconfig.ChainConfig, upgrade precompileconfig.Upgrade) error
Verify returns an error if there is an overlapping address between admin and enabled roles
type Role ¶
Enum constants for valid Role
func GetAllowListStatus ¶
func GetAllowListStatus(state contract.StateDB, precompileAddr common.Address, address common.Address) Role
GetAllowListStatus returns the allow list role of [address] for the precompile at [precompileAddr]
func UnpackRoleSetEventData ¶ added in v0.5.11
UnpackRoleSetEventData attempts to unpack non-indexed [dataBytes].
func (Role) GetSetterFunctionName ¶ added in v0.5.11
func (Role) IsAdmin ¶
IsAdmin returns true if [r] indicates the permission to modify the allow list.
func (Role) IsEnabled ¶
IsEnabled returns true if [r] indicates that it has permission to access the resource.