Documentation ¶
Index ¶
- Constants
- Variables
- func GetNumericBlockNumber(number BlockNumber, e *Eth) (uint64, error)
- func NewInternalError(msg string) *internalError
- func NewInvalidParamsError(msg string) *invalidParamsError
- func NewInvalidRequestError(msg string) *invalidRequestError
- func NewMethodNotFoundError(method string) *methodNotFoundError
- func NewSubscriptionNotFoundError(method string) *subscriptionNotFoundError
- type BlockNumber
- type BlockNumberOrHash
- type Config
- type ContentResponse
- type Debug
- type Dispatcher
- type Error
- type ErrorResponse
- type Eth
- func (e *Eth) BlockNumber() (interface{}, error)
- func (e *Eth) Call(arg *txnArgs, filter BlockNumberOrHash) (interface{}, error)
- func (e *Eth) ChainId() (interface{}, error)
- func (e *Eth) EstimateGas(arg *txnArgs, rawNum *BlockNumber) (interface{}, error)
- func (e *Eth) GasPrice() (interface{}, error)
- func (e *Eth) GetBalance(address types.Address, filter BlockNumberOrHash) (interface{}, error)
- func (e *Eth) GetBlockByHash(hash types.Hash, fullTx bool) (interface{}, error)
- func (e *Eth) GetBlockByNumber(number BlockNumber, fullTx bool) (interface{}, error)
- func (e *Eth) GetBlockTransactionCountByNumber(number BlockNumber) (interface{}, error)
- func (e *Eth) GetCode(address types.Address, filter BlockNumberOrHash) (interface{}, error)
- func (e *Eth) GetFilterChanges(id string) (interface{}, error)
- func (e *Eth) GetFilterLogs(id string) (interface{}, error)
- func (e *Eth) GetLogs(query *LogQuery) (interface{}, error)
- func (e *Eth) GetStorageAt(address types.Address, index types.Hash, filter BlockNumberOrHash) (interface{}, error)
- func (e *Eth) GetTransactionByHash(hash types.Hash) (interface{}, error)
- func (e *Eth) GetTransactionCount(address types.Address, filter BlockNumberOrHash) (interface{}, error)
- func (e *Eth) GetTransactionReceipt(hash types.Hash) (interface{}, error)
- func (e *Eth) NewBlockFilter() (interface{}, error)
- func (e *Eth) NewFilter(filter *LogQuery) (interface{}, error)
- func (e *Eth) SendRawTransaction(input string) (interface{}, error)
- func (e *Eth) SendTransaction(arg *txnArgs) (interface{}, error)
- func (e *Eth) Syncing() (interface{}, error)
- func (e *Eth) UninstallFilter(id string) (bool, error)
- func (e *Eth) Unsubscribe(id string) (bool, error)
- type ExecutionResult
- type FilterManager
- func (f *FilterManager) Close()
- func (f *FilterManager) Exists(id string) bool
- func (f *FilterManager) GetFilterChanges(id string) (string, error)
- func (f *FilterManager) GetLogFilterFromID(filterID string) (*logFilter, error)
- func (f *FilterManager) GetLogs(query *LogQuery) ([]*Log, error)
- func (f *FilterManager) NewBlockFilter(ws wsConn) string
- func (f *FilterManager) NewLogFilter(logQuery *LogQuery, ws wsConn) string
- func (f *FilterManager) RemoveFilterByWs(ws wsConn)
- func (f *FilterManager) Run()
- func (f *FilterManager) Uninstall(id string) bool
- type InspectResponse
- type JSONRPC
- type JSONRPCStore
- type Log
- type LogQuery
- type Net
- type ObjectError
- type Request
- type Response
- type StatusResponse
- type StructLogRes
- type SuccessResponse
- type TxPool
- type Web3
Constants ¶
const ( PendingBlockFlag = "pending" LatestBlockFlag = "latest" EarliestBlockFlag = "earliest" )
const ( PendingBlockNumber = BlockNumber(-3) LatestBlockNumber = BlockNumber(-2) EarliestBlockNumber = BlockNumber(-1) )
const ( // DefaultJSONRPCBatchRequestLimit maximum length allowed for json_rpc batch requests DefaultJSONRPCBatchRequestLimit uint64 = 1 // DefaultJSONRPCBlockRangeLimit maximum block range allowed for json_rpc // requests with fromBlock/toBlock values (e.g. eth_getLogs) DefaultJSONRPCBlockRangeLimit uint64 = 100 )
const (
// The index in heap which is indicating the element is not in the heap
NoIndexInHeap = -1
)
Variables ¶
var ( ErrTransactionNotSeal = errors.New("transaction not sealed") ErrGenesisNotTracable = errors.New("genesis is not traceable") ErrTransactionNotFoundInBlock = errors.New("transaction not found in block") )
var ( ErrInsufficientFunds = errors.New("insufficient funds for execution") ErrGasCapOverflow = errors.New("unable to apply transaction for the highest gas limit") )
var ( ErrFilterDoesNotExists = errors.New("filter does not exists") ErrWSFilterDoesNotSupportGetChanges = errors.New("web socket Filter doesn't support to return a batch of the changes") ErrCastingFilterToLogFilter = errors.New("casting filter object to logFilter error") ErrBlockNotFound = errors.New("block not found") ErrIncorrectBlockRange = errors.New("incorrect range") ErrBlockRangeTooHigh = errors.New("block range too high") ErrPendingBlockNumber = errors.New("pending block number is not supported") ErrNoWSConnection = errors.New("no websocket connection") )
var (
ErrStateNotFound = errors.New("given root and slot not found in storage")
)
Functions ¶
func GetNumericBlockNumber ¶
func GetNumericBlockNumber(number BlockNumber, e *Eth) (uint64, error)
func NewInternalError ¶
func NewInternalError(msg string) *internalError
func NewInvalidParamsError ¶
func NewInvalidParamsError(msg string) *invalidParamsError
func NewInvalidRequestError ¶
func NewInvalidRequestError(msg string) *invalidRequestError
func NewMethodNotFoundError ¶
func NewMethodNotFoundError(method string) *methodNotFoundError
func NewSubscriptionNotFoundError ¶
func NewSubscriptionNotFoundError(method string) *subscriptionNotFoundError
Types ¶
type BlockNumber ¶
type BlockNumber int64
func CreateBlockNumberPointer ¶ added in v0.5.3
func CreateBlockNumberPointer(str string) (*BlockNumber, error)
func StringToBlockNumber ¶ added in v0.5.3
func StringToBlockNumber(str string) (BlockNumber, error)
func (*BlockNumber) UnmarshalJSON ¶
func (b *BlockNumber) UnmarshalJSON(buffer []byte) error
UnmarshalJSON automatically decodes the user input for the block number, when a JSON RPC method is called
type BlockNumberOrHash ¶
type BlockNumberOrHash struct { BlockNumber *BlockNumber `json:"blockNumber,omitempty"` BlockHash *types.Hash `json:"blockHash,omitempty"` }
func (*BlockNumberOrHash) UnmarshalJSON ¶
func (bnh *BlockNumberOrHash) UnmarshalJSON(data []byte) error
UnmarshalJSON will try to extract the filter's data. Here are the possible input formats :
1 - "latest", "pending" or "earliest" - self-explaining keywords 2 - "0x2" - block number #2 (EIP-1898 backward compatible) 3 - {blockNumber: "0x2"} - EIP-1898 compliant block number #2 4 - {blockHash: "0xe0e..."} - EIP-1898 compliant block hash 0xe0e...
type ContentResponse ¶
type Dispatcher ¶
type Dispatcher struct {
// contains filtered or unexported fields
}
Dispatcher handles all json rpc requests by delegating the execution flow to the corresponding service
func (*Dispatcher) HandleWs ¶
func (d *Dispatcher) HandleWs(reqBody []byte, conn wsConn) ([]byte, error)
func (*Dispatcher) RemoveFilterByWs ¶ added in v1.1.3
func (d *Dispatcher) RemoveFilterByWs(conn wsConn)
type ErrorResponse ¶
type ErrorResponse struct { JSONRPC string `json:"jsonrpc"` ID interface{} `json:"id,omitempty"` Error *ObjectError `json:"error"` }
ErrorResponse is a jsonrpc error response
func (*ErrorResponse) Bytes ¶
func (e *ErrorResponse) Bytes() ([]byte, error)
Bytes return the serialized response
func (*ErrorResponse) Data ¶
func (e *ErrorResponse) Data() json.RawMessage
Data returns ObjectError
func (*ErrorResponse) GetID ¶
func (e *ErrorResponse) GetID() interface{}
GetID returns error response id
type Eth ¶
type Eth struct {
// contains filtered or unexported fields
}
Eth is the eth jsonrpc endpoint
func (*Eth) BlockNumber ¶
BlockNumber returns current block number
func (*Eth) Call ¶
func (e *Eth) Call(arg *txnArgs, filter BlockNumberOrHash) (interface{}, error)
Call executes a smart contract call using the transaction object data
func (*Eth) EstimateGas ¶
func (e *Eth) EstimateGas(arg *txnArgs, rawNum *BlockNumber) (interface{}, error)
EstimateGas estimates the gas needed to execute a transaction
func (*Eth) GetBalance ¶
func (e *Eth) GetBalance(address types.Address, filter BlockNumberOrHash) (interface{}, error)
GetBalance returns the account's balance at the referenced block.
func (*Eth) GetBlockByHash ¶
GetBlockByHash returns information about a block by hash
func (*Eth) GetBlockByNumber ¶
func (e *Eth) GetBlockByNumber(number BlockNumber, fullTx bool) (interface{}, error)
GetBlockByNumber returns information about a block by block number
func (*Eth) GetBlockTransactionCountByNumber ¶
func (e *Eth) GetBlockTransactionCountByNumber(number BlockNumber) (interface{}, error)
func (*Eth) GetCode ¶
func (e *Eth) GetCode(address types.Address, filter BlockNumberOrHash) (interface{}, error)
GetCode returns account code at given block number
func (*Eth) GetFilterChanges ¶
GetFilterChanges is a polling method for a filter, which returns an array of logs which occurred since last poll. WebSocket polling log filter changes would not be accepted anymore.
func (*Eth) GetFilterLogs ¶ added in v0.5.3
GetFilterLogs returns an array of logs for the specified filter
func (*Eth) GetStorageAt ¶
func (e *Eth) GetStorageAt( address types.Address, index types.Hash, filter BlockNumberOrHash, ) (interface{}, error)
GetStorageAt returns the contract storage at the index position
func (*Eth) GetTransactionByHash ¶
GetTransactionByHash returns a transaction by its hash. If the transaction is still pending -> return the txn with some fields omitted If the transaction is sealed into a block -> return the whole txn with all fields
func (*Eth) GetTransactionCount ¶
func (e *Eth) GetTransactionCount(address types.Address, filter BlockNumberOrHash) (interface{}, error)
GetTransactionCount returns account nonce
func (*Eth) GetTransactionReceipt ¶
GetTransactionReceipt returns a transaction receipt by his hash
func (*Eth) NewBlockFilter ¶
NewBlockFilter creates a filter in the node, to notify when a new block arrives
func (*Eth) NewFilter ¶
NewFilter creates a filter object, based on filter options, to notify when the state changes (logs).
func (*Eth) SendRawTransaction ¶
SendRawTransaction sends a raw transaction
func (*Eth) SendTransaction ¶
Reject eth_sendTransaction json-rpc call as we don't support wallet management
func (*Eth) UninstallFilter ¶
UninstallFilter uninstalls a filter with given ID
type ExecutionResult ¶ added in v1.1.4
type ExecutionResult struct { Gas uint64 `json:"gas"` Failed bool `json:"failed"` ReturnValue string `json:"returnValue"` StructLogs []StructLogRes `json:"structLogs"` }
ExecutionResult groups all structured logs emitted by the EVM while replaying a transaction in debug mode as well as transaction execution status, the amount of gas used and the return value
type FilterManager ¶
type FilterManager struct { sync.RWMutex // provide basic r/w lock // contains filtered or unexported fields }
FilterManager manages all running filters
func NewFilterManager ¶
func NewFilterManager(logger hclog.Logger, store filterManagerStore, blockRangeLimit uint64) *FilterManager
func (*FilterManager) Close ¶
func (f *FilterManager) Close()
Close closed closeCh so that terminate worker
func (*FilterManager) Exists ¶
func (f *FilterManager) Exists(id string) bool
Exists checks the filter with given ID exists
func (*FilterManager) GetFilterChanges ¶
func (f *FilterManager) GetFilterChanges(id string) (string, error)
GetFilterChanges returns the updates of the filter with given ID in string, and refreshes the timeout on the filter
func (*FilterManager) GetLogFilterFromID ¶ added in v0.5.3
func (f *FilterManager) GetLogFilterFromID(filterID string) (*logFilter, error)
GetLogFilterFromID return log filter for given filterID
func (*FilterManager) GetLogs ¶ added in v0.5.3
func (f *FilterManager) GetLogs(query *LogQuery) ([]*Log, error)
GetLogs return array of logs for given query
func (*FilterManager) NewBlockFilter ¶
func (f *FilterManager) NewBlockFilter(ws wsConn) string
NewBlockFilter adds new BlockFilter
func (*FilterManager) NewLogFilter ¶
func (f *FilterManager) NewLogFilter(logQuery *LogQuery, ws wsConn) string
NewLogFilter adds new LogFilter
func (*FilterManager) RemoveFilterByWs ¶ added in v1.1.3
func (f *FilterManager) RemoveFilterByWs(ws wsConn)
RemoveFilterByWs removes the filter with given WS [Thread safe]
func (*FilterManager) Run ¶
func (f *FilterManager) Run()
Run starts worker process to handle events
func (*FilterManager) Uninstall ¶
func (f *FilterManager) Uninstall(id string) bool
Uninstall removes the filter with given ID from list
type InspectResponse ¶
type JSONRPC ¶
type JSONRPC struct {
// contains filtered or unexported fields
}
JSONRPC is an API backend
func NewJSONRPC ¶
NewJSONRPC returns the JSONRPC http server
type JSONRPCStore ¶
type JSONRPCStore interface {
// contains filtered or unexported methods
}
JSONRPCStore defines all the methods required by all the JSON RPC endpoints
type Log ¶
type Log struct { Address types.Address `json:"address"` Topics []types.Hash `json:"topics"` Data argBytes `json:"data"` BlockNumber argUint64 `json:"blockNumber"` TxHash types.Hash `json:"transactionHash"` TxIndex argUint64 `json:"transactionIndex"` BlockHash types.Hash `json:"blockHash"` LogIndex argUint64 `json:"logIndex"` Removed bool `json:"removed"` }
type LogQuery ¶
type LogQuery struct { BlockHash *types.Hash FromBlock BlockNumber ToBlock BlockNumber Addresses []types.Address Topics [][]types.Hash }
LogQuery is a query to filter logs
func (*LogQuery) UnmarshalJSON ¶
UnmarshalJSON decodes a json object
type Net ¶
type Net struct {
// contains filtered or unexported fields
}
Net is the net jsonrpc endpoint
func (*Net) Listening ¶
Listening returns true if client is actively listening for network connections
type ObjectError ¶
type ObjectError struct { Code int `json:"code"` Message string `json:"message"` Data interface{} `json:"data,omitempty"` }
ObjectError is a jsonrpc error
type Request ¶
type Request struct { ID interface{} `json:"id"` Method string `json:"method"` Params json.RawMessage `json:"params,omitempty"` }
Request is a jsonrpc request
type Response ¶
type Response interface { GetID() interface{} Data() json.RawMessage Bytes() ([]byte, error) }
Response is a jsonrpc response interface
func NewRPCErrorResponse ¶
NewRPCErrorResponse is used to create a custom error response
type StatusResponse ¶
type StructLogRes ¶ added in v1.1.4
type StructLogRes struct { Pc uint64 `json:"pc"` Op string `json:"op"` Gas uint64 `json:"gas"` GasCost uint64 `json:"gasCost"` Depth int `json:"depth"` Error string `json:"error,omitempty"` Stack *[]string `json:"stack,omitempty"` Memory *[]string `json:"memory,omitempty"` Storage *map[string]string `json:"storage,omitempty"` }
StructLogRes stores a structured log emitted by the EVM while replaying a transaction in debug mode
type SuccessResponse ¶
type SuccessResponse struct { JSONRPC string `json:"jsonrpc"` ID interface{} `json:"id"` Result json.RawMessage `json:"result"` Error *ObjectError `json:"error,omitempty"` }
SuccessResponse is a jsonrpc success response
func (*SuccessResponse) Bytes ¶
func (s *SuccessResponse) Bytes() ([]byte, error)
Bytes return the serialized response
func (*SuccessResponse) Data ¶
func (s *SuccessResponse) Data() json.RawMessage
Data returns the result
func (*SuccessResponse) GetID ¶
func (s *SuccessResponse) GetID() interface{}
GetID returns success response id
type TxPool ¶
type TxPool struct {
// contains filtered or unexported fields
}
TxPool is the txpool jsonrpc endpoint
func (*TxPool) Content ¶
Create response for txpool_content request. See https://geth.ethereum.org/docs/rpc/ns-txpool#txpool_content.
func (*TxPool) Inspect ¶
Create response for txpool_inspect request. See https://geth.ethereum.org/docs/rpc/ns-txpool#txpool_inspect.
func (*TxPool) Status ¶
Create response for txpool_status request. See https://geth.ethereum.org/docs/rpc/ns-txpool#txpool_status.
type Web3 ¶
type Web3 struct{}
Web3 is the web3 jsonrpc endpoint
func (*Web3) ClientVersion ¶
ClientVersion returns the version of the web3 client (web3_clientVersion)