decode

package
v0.0.0-...-2473a21 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Sep 16, 2024 License: MIT Imports: 7 Imported by: 0

Documentation

Index

Constants

View Source
const (
	BlockTagLatest    = "latest"
	BlockTagPending   = "pending"
	BlockTagEarliest  = "earliest"
	BlockTagFinalized = "finalized"
	BlockTagSafe      = "safe"
	// "empty" is not in the spec, it is our encoding for requests made with a nil block tag param.
	BlockTagEmpty = "empty"
)

These block tags are special strings used to reference blocks in JSON-RPC see https://ethereum.org/en/developers/docs/apis/json-rpc/#default-block

Variables

View Source
var (
	ErrInvalidEthAPIRequest               = errors.New("request is not valid for the eth api")
	ErrUncachaebleEthRequest              = fmt.Errorf("request is not cache-able, current cache-able requests are %s", CacheableEthMethods)
	ErrUncachaebleByBlockNumberEthRequest = fmt.Errorf("request is not cache-able by block number, current cache-able requests by block number are %s or by hash %s", CacheableByBlockNumberMethods, CacheableByBlockHashMethods)
	ErrUncachaebleByBlockHashEthRequest   = fmt.Errorf("request is not cache-able by block hash, current cache-able requests by block hash are  %s", CacheableByBlockHashMethods)
)

Errors that might result from decoding parts or the whole of an EVM RPC request

View Source
var BlockTagToNumberCodec = map[string]int64{
	BlockTagLatest:    -1,
	BlockTagPending:   -2,
	BlockTagEarliest:  -3,
	BlockTagFinalized: -4,
	BlockTagSafe:      -5,

	BlockTagEmpty: -6,
}

Mapping of string tag values used in the eth api to normalized int values that can be stored as the block number for the proxied request metric see https://ethereum.org/en/developers/docs/apis/json-rpc/#default-block

View Source
var CacheableByBlockHashMethods = []string{
	"eth_getBlockTransactionCountByHash",
	"eth_getUncleCountByBlockHash",
	"eth_getBlockByHash",
	"eth_getUncleByBlockHashAndIndex",
	"eth_getTransactionByBlockHashAndIndex",
}

List of evm methods that can be cached by block hash and so are useful for converting and tracking the block hash associated with any requests invoking those methods to the matching block number

View Source
var CacheableByBlockNumberMethods = []string{
	"eth_getBalance",
	"eth_getStorageAt",
	"eth_getTransactionCount",
	"eth_getBlockTransactionCountByNumber",
	"eth_getUncleCountByBlockNumber",
	"eth_getCode",
	"eth_getBlockByNumber",
	"eth_getTransactionByBlockNumberAndIndex",
	"eth_getUncleByBlockNumberAndIndex",
	"eth_call",
}

List of evm methods that can be cached by block number and so are useful for tracking the block number associated with any requests invoking those methods

View Source
var CacheableByTxHashMethods = []string{
	"eth_getTransactionReceipt",
	"eth_getTransactionByHash",
}

CacheableByTxHashMethods is a list of EVM methods which can be cached indefinitely by transaction hash. It means that for specific method and params (which includes tx hash) response will never change.

List of evm methods that can be cached and so are useful for tracking the params associated with the request to help in making caching decisions for future similar requests

View Source
var MethodNameToBlockHashParamIndex = map[string]int{
	"eth_getBlockTransactionCountByHash":    0,
	"eth_getUncleCountByBlockHash":          0,
	"eth_getBlockByHash":                    0,
	"eth_getUncleByBlockHashAndIndex":       0,
	"eth_getTransactionByBlockHashAndIndex": 0,
}

Mapping of the position of the block hash param for a given method name

View Source
var MethodNameToBlockNumberParamIndex = map[string]int{
	"eth_getBalance":                          1,
	"eth_getStorageAt":                        2,
	"eth_getTransactionCount":                 1,
	"eth_getBlockTransactionCountByNumber":    0,
	"eth_getUncleCountByBlockNumber":          0,
	"eth_getCode":                             1,
	"eth_getBlockByNumber":                    0,
	"eth_getTransactionByBlockNumberAndIndex": 0,
	"eth_getUncleByBlockNumberAndIndex":       1,
	"eth_call":                                1,
}

Mapping of the position of the block number param for a given method name

View Source
var NoHistoryMethods = []string{
	"web3_clientVersion",
	"web3_sha3",
	"net_version",
	"net_listening",
	"net_peerCount",
	"eth_protocolVersion",
	"eth_syncing",
	"eth_coinbase",
	"eth_chainId",
	"eth_mining",
	"eth_hashrate",
	"eth_gasPrice",
	"eth_accounts",
	"eth_blockNumber",
	"eth_sign",
	"eth_signTransaction",
	"eth_sendTransaction",
	"eth_sendRawTransaction",
}

NoHistoryMethods is a list of JSON-RPC methods that rely only on the present state of the chain. They can always be safely routed to an up-to-date pruning cluster.

View Source
var OtherCacheableMethods = []string{
	"web3_clientVersion",
	"web3_sha3",
	"net_version",
	"net_listening",
	"net_peerCount",
	"eth_protocolVersion",
	"eth_syncing",
	"eth_coinbase",
	"eth_mining",
	"eth_hashrate",
	"eth_gasPrice",
	"eth_accounts",
	"eth_blockNumber",
	"eth_getTransactionByHash",
	"eth_getTransactionReceipt",
	"eth_getCompilers",
	"eth_getFilterChanges",
	"eth_getFilterLogs",
	"eth_getLogs",
	"eth_getWork",
}

List of evm methods that can be cached independent of block number (i.e. by block or transaction hash, filter id, or time period) TODO: break these out into separate list for methods that can be cached using the same key type

View Source
var StaticMethods = []string{
	"eth_chainId",
	"net_version",
}

StaticMethods is a list of static EVM methods which can be cached indefinitely, response will never change.

Functions

func IsMethodStatic

func IsMethodStatic(method string) bool

IsMethodStatic checks if method is static. In this context static means that response will never change and can be cached indefinitely.

func MethodHasBlockHashParam

func MethodHasBlockHashParam(method string) bool

MethodHasBlockHashParam returns true when the method expects a block hash in the request parameters.

func MethodHasBlockNumberParam

func MethodHasBlockNumberParam(method string) bool

MethodHasBlockNumberParam returns true when the method expects a block number in the request parameters.

func MethodHasTxHashParam

func MethodHasTxHashParam(method string) bool

MethodHasTxHashParam checks if method is cacheable by tx hash.

func MethodRequiresNoHistory

func MethodRequiresNoHistory(method string) bool

MethodRequiresNoHistory returns true when the JSON-RPC method always functions correctly when sent to the latest block. This is useful for determining if a request can be routed to a pruning cluster.

func ParseBlockNumberFromParams

func ParseBlockNumberFromParams(methodName string, params []interface{}) (int64, error)

Generic method to parse the block number from a set of params errors if method does not have a block number in the param, or the param has an unexpected value block tags are encoded to an int64 according to the BlockTagToNumberCodec map.

Types

type EVMBlockGetter

type EVMBlockGetter interface {
	// HeaderByHash returns ethereum block header by hash
	HeaderByHash(ctx context.Context, hash common.Hash) (*ethctypes.Header, error)
}

EVMBlockGetter defines an interface which can be implemented by any client capable of getting ethereum block header by hash

type EVMRPCRequestEnvelope

type EVMRPCRequestEnvelope struct {
	// version of the RPC spec being used
	// https://www.jsonrpc.org/specification
	JSONRPCVersion string `json:"jsonrpc"`
	// ID is a unique id set by the client to match responses to requests
	// it is often an int, but strings are also valid. bools also return valid responses.
	ID     interface{}
	Method string
	Params []interface{}
}

EVMRPCRequest wraps expected values present in a request to the RPC endpoint for an EVM node API https://ethereum.org/en/developers/docs/apis/json-rpc/

func DecodeEVMRPCRequest

func DecodeEVMRPCRequest(body []byte) (*EVMRPCRequestEnvelope, error)

DecodeEVMRPCRequest attempts to decode the provided bytes into an EVMRPCRequestEnvelope for use by the service to extract request details and create an enriched request metric, returning the decoded request and error (if any)

func DecodeEVMRPCRequestList

func DecodeEVMRPCRequestList(body []byte) ([]*EVMRPCRequestEnvelope, error)

DecodeEVMRPCRequest attempts to decode raw bytes to a list of EVMRPCRequestEnvelopes

func (*EVMRPCRequestEnvelope) ExtractBlockNumberFromEVMRPCRequest

func (r *EVMRPCRequestEnvelope) ExtractBlockNumberFromEVMRPCRequest(ctx context.Context, blockGetter EVMBlockGetter) (int64, error)

ExtractBlockNumberFromEVMRPCRequest attempts to extract the block number associated with a request if - the request is a valid evm rpc request - the method for the request supports specifying a block number - the provided block number is a valid tag or number

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL