2021-01-07 21:45:32 +00:00
|
|
|
syntax = "proto3";
|
2021-08-17 15:30:35 +00:00
|
|
|
package ethermint.evm.v1;
|
2021-01-07 21:45:32 +00:00
|
|
|
|
2021-05-31 14:54:59 +00:00
|
|
|
import "cosmos/base/query/v1beta1/pagination.proto";
|
2021-08-17 15:30:35 +00:00
|
|
|
import "ethermint/evm/v1/evm.proto";
|
|
|
|
import "ethermint/evm/v1/tx.proto";
|
2022-11-30 17:00:19 +00:00
|
|
|
import "gogoproto/gogo.proto";
|
|
|
|
import "google/api/annotations.proto";
|
2021-11-09 18:38:22 +00:00
|
|
|
import "google/protobuf/timestamp.proto";
|
2021-01-07 21:45:32 +00:00
|
|
|
|
2022-06-19 09:43:41 +00:00
|
|
|
option go_package = "github.com/evmos/ethermint/x/evm/types";
|
2021-01-07 21:45:32 +00:00
|
|
|
|
|
|
|
// Query defines the gRPC querier service.
|
|
|
|
service Query {
|
|
|
|
// Account queries an Ethereum account.
|
|
|
|
rpc Account(QueryAccountRequest) returns (QueryAccountResponse) {
|
2021-08-17 15:30:35 +00:00
|
|
|
option (google.api.http).get = "/ethermint/evm/v1/account/{address}";
|
2021-01-07 21:45:32 +00:00
|
|
|
}
|
|
|
|
|
2021-06-22 10:14:40 +00:00
|
|
|
// CosmosAccount queries an Ethereum account's Cosmos Address.
|
2022-10-20 20:43:19 +00:00
|
|
|
rpc CosmosAccount(QueryCosmosAccountRequest) returns (QueryCosmosAccountResponse) {
|
2021-10-07 11:02:31 +00:00
|
|
|
option (google.api.http).get = "/ethermint/evm/v1/cosmos_account/{address}";
|
2021-04-18 15:54:18 +00:00
|
|
|
}
|
|
|
|
|
2021-07-30 11:40:17 +00:00
|
|
|
// ValidatorAccount queries an Ethereum account's from a validator consensus
|
|
|
|
// Address.
|
2022-10-20 20:43:19 +00:00
|
|
|
rpc ValidatorAccount(QueryValidatorAccountRequest) returns (QueryValidatorAccountResponse) {
|
|
|
|
option (google.api.http).get = "/ethermint/evm/v1/validator_account/{cons_address}";
|
2021-06-22 10:14:40 +00:00
|
|
|
}
|
|
|
|
|
2021-01-07 21:45:32 +00:00
|
|
|
// Balance queries the balance of a the EVM denomination for a single
|
|
|
|
// EthAccount.
|
|
|
|
rpc Balance(QueryBalanceRequest) returns (QueryBalanceResponse) {
|
2021-08-17 15:30:35 +00:00
|
|
|
option (google.api.http).get = "/ethermint/evm/v1/balances/{address}";
|
2021-01-07 21:45:32 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Storage queries the balance of all coins for a single account.
|
|
|
|
rpc Storage(QueryStorageRequest) returns (QueryStorageResponse) {
|
2021-10-07 11:02:31 +00:00
|
|
|
option (google.api.http).get = "/ethermint/evm/v1/storage/{address}/{key}";
|
2021-01-07 21:45:32 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Code queries the balance of all coins for a single account.
|
|
|
|
rpc Code(QueryCodeRequest) returns (QueryCodeResponse) {
|
2021-08-17 15:30:35 +00:00
|
|
|
option (google.api.http).get = "/ethermint/evm/v1/codes/{address}";
|
2021-01-07 21:45:32 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Params queries the parameters of x/evm module.
|
|
|
|
rpc Params(QueryParamsRequest) returns (QueryParamsResponse) {
|
2021-08-17 15:30:35 +00:00
|
|
|
option (google.api.http).get = "/ethermint/evm/v1/params";
|
2021-01-07 21:45:32 +00:00
|
|
|
}
|
2021-10-07 11:02:31 +00:00
|
|
|
|
2021-07-09 09:04:46 +00:00
|
|
|
// EthCall implements the `eth_call` rpc api
|
|
|
|
rpc EthCall(EthCallRequest) returns (MsgEthereumTxResponse) {
|
2021-08-17 15:30:35 +00:00
|
|
|
option (google.api.http).get = "/ethermint/evm/v1/eth_call";
|
2021-07-09 09:04:46 +00:00
|
|
|
}
|
2021-07-19 15:19:23 +00:00
|
|
|
|
|
|
|
// EstimateGas implements the `eth_estimateGas` rpc api
|
|
|
|
rpc EstimateGas(EthCallRequest) returns (EstimateGasResponse) {
|
2021-08-17 15:30:35 +00:00
|
|
|
option (google.api.http).get = "/ethermint/evm/v1/estimate_gas";
|
2021-07-19 15:19:23 +00:00
|
|
|
}
|
2021-09-04 20:33:06 +00:00
|
|
|
|
|
|
|
// TraceTx implements the `debug_traceTransaction` rpc api
|
|
|
|
rpc TraceTx(QueryTraceTxRequest) returns (QueryTraceTxResponse) {
|
|
|
|
option (google.api.http).get = "/ethermint/evm/v1/trace_tx";
|
|
|
|
}
|
2021-11-09 18:38:22 +00:00
|
|
|
|
|
|
|
// TraceBlock implements the `debug_traceBlockByNumber` and `debug_traceBlockByHash` rpc api
|
|
|
|
rpc TraceBlock(QueryTraceBlockRequest) returns (QueryTraceBlockResponse) {
|
|
|
|
option (google.api.http).get = "/ethermint/evm/v1/trace_block";
|
|
|
|
}
|
2022-04-30 16:11:28 +00:00
|
|
|
|
|
|
|
// BaseFee queries the base fee of the parent block of the current block,
|
|
|
|
// it's similar to feemarket module's method, but also checks london hardfork status.
|
|
|
|
rpc BaseFee(QueryBaseFeeRequest) returns (QueryBaseFeeResponse) {
|
|
|
|
option (google.api.http).get = "/ethermint/evm/v1/base_fee";
|
|
|
|
}
|
2021-01-07 21:45:32 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// QueryAccountRequest is the request type for the Query/Account RPC method.
|
|
|
|
message QueryAccountRequest {
|
2022-11-30 17:00:19 +00:00
|
|
|
option (gogoproto.equal) = false;
|
2021-01-07 21:45:32 +00:00
|
|
|
option (gogoproto.goproto_getters) = false;
|
|
|
|
|
|
|
|
// address is the ethereum hex address to query the account for.
|
|
|
|
string address = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
// QueryAccountResponse is the response type for the Query/Account RPC method.
|
|
|
|
message QueryAccountResponse {
|
|
|
|
// balance is the balance of the EVM denomination.
|
2021-07-02 09:29:47 +00:00
|
|
|
string balance = 1;
|
2022-11-30 17:00:19 +00:00
|
|
|
// code_hash is the hex-formatted code bytes from the EOA.
|
2021-06-08 17:10:29 +00:00
|
|
|
string code_hash = 2;
|
2021-01-07 21:45:32 +00:00
|
|
|
// nonce is the account's sequence number.
|
|
|
|
uint64 nonce = 3;
|
|
|
|
}
|
|
|
|
|
2021-07-30 11:40:17 +00:00
|
|
|
// QueryCosmosAccountRequest is the request type for the Query/CosmosAccount RPC
|
|
|
|
// method.
|
2021-04-18 15:54:18 +00:00
|
|
|
message QueryCosmosAccountRequest {
|
2022-11-30 17:00:19 +00:00
|
|
|
option (gogoproto.equal) = false;
|
2021-04-18 15:54:18 +00:00
|
|
|
option (gogoproto.goproto_getters) = false;
|
|
|
|
|
|
|
|
// address is the ethereum hex address to query the account for.
|
|
|
|
string address = 1;
|
|
|
|
}
|
|
|
|
|
2021-07-30 11:40:17 +00:00
|
|
|
// QueryCosmosAccountResponse is the response type for the Query/CosmosAccount
|
|
|
|
// RPC method.
|
2021-04-18 15:54:18 +00:00
|
|
|
message QueryCosmosAccountResponse {
|
|
|
|
// cosmos_address is the cosmos address of the account.
|
|
|
|
string cosmos_address = 1;
|
|
|
|
// sequence is the account's sequence number.
|
|
|
|
uint64 sequence = 2;
|
2022-11-30 17:00:19 +00:00
|
|
|
// account_number is the account number
|
2021-04-18 15:54:18 +00:00
|
|
|
uint64 account_number = 3;
|
|
|
|
}
|
|
|
|
|
2021-07-30 11:40:17 +00:00
|
|
|
// QueryValidatorAccountRequest is the request type for the
|
|
|
|
// Query/ValidatorAccount RPC method.
|
2021-06-22 10:14:40 +00:00
|
|
|
message QueryValidatorAccountRequest {
|
2022-11-30 17:00:19 +00:00
|
|
|
option (gogoproto.equal) = false;
|
2021-06-22 10:14:40 +00:00
|
|
|
option (gogoproto.goproto_getters) = false;
|
|
|
|
|
|
|
|
// cons_address is the validator cons address to query the account for.
|
|
|
|
string cons_address = 1;
|
|
|
|
}
|
|
|
|
|
2021-07-30 11:40:17 +00:00
|
|
|
// QueryValidatorAccountResponse is the response type for the
|
|
|
|
// Query/ValidatorAccount RPC method.
|
2021-06-22 10:14:40 +00:00
|
|
|
message QueryValidatorAccountResponse {
|
|
|
|
// account_address is the cosmos address of the account in bech32 format.
|
|
|
|
string account_address = 1;
|
|
|
|
// sequence is the account's sequence number.
|
|
|
|
uint64 sequence = 2;
|
|
|
|
// account_number is the account number
|
|
|
|
uint64 account_number = 3;
|
|
|
|
}
|
|
|
|
|
2021-01-07 21:45:32 +00:00
|
|
|
// QueryBalanceRequest is the request type for the Query/Balance RPC method.
|
|
|
|
message QueryBalanceRequest {
|
2022-11-30 17:00:19 +00:00
|
|
|
option (gogoproto.equal) = false;
|
2021-01-07 21:45:32 +00:00
|
|
|
option (gogoproto.goproto_getters) = false;
|
|
|
|
|
|
|
|
// address is the ethereum hex address to query the balance for.
|
|
|
|
string address = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
// QueryBalanceResponse is the response type for the Query/Balance RPC method.
|
|
|
|
message QueryBalanceResponse {
|
|
|
|
// balance is the balance of the EVM denomination.
|
2021-07-02 09:29:47 +00:00
|
|
|
string balance = 1;
|
2021-01-07 21:45:32 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// QueryStorageRequest is the request type for the Query/Storage RPC method.
|
|
|
|
message QueryStorageRequest {
|
2022-11-30 17:00:19 +00:00
|
|
|
option (gogoproto.equal) = false;
|
2021-01-07 21:45:32 +00:00
|
|
|
option (gogoproto.goproto_getters) = false;
|
|
|
|
|
2022-11-30 17:00:19 +00:00
|
|
|
// address is the ethereum hex address to query the storage state for.
|
2021-01-07 21:45:32 +00:00
|
|
|
string address = 1;
|
|
|
|
|
|
|
|
// key defines the key of the storage state
|
|
|
|
string key = 2;
|
|
|
|
}
|
|
|
|
|
|
|
|
// QueryStorageResponse is the response type for the Query/Storage RPC
|
|
|
|
// method.
|
|
|
|
message QueryStorageResponse {
|
2022-11-30 17:00:19 +00:00
|
|
|
// value defines the storage state value hash associated with the given key.
|
2021-01-07 21:45:32 +00:00
|
|
|
string value = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
// QueryCodeRequest is the request type for the Query/Code RPC method.
|
|
|
|
message QueryCodeRequest {
|
2022-11-30 17:00:19 +00:00
|
|
|
option (gogoproto.equal) = false;
|
2021-01-07 21:45:32 +00:00
|
|
|
option (gogoproto.goproto_getters) = false;
|
|
|
|
|
|
|
|
// address is the ethereum hex address to query the code for.
|
|
|
|
string address = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
// QueryCodeResponse is the response type for the Query/Code RPC
|
|
|
|
// method.
|
|
|
|
message QueryCodeResponse {
|
|
|
|
// code represents the code bytes from an ethereum address.
|
|
|
|
bytes code = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
// QueryTxLogsRequest is the request type for the Query/TxLogs RPC method.
|
|
|
|
message QueryTxLogsRequest {
|
2022-11-30 17:00:19 +00:00
|
|
|
option (gogoproto.equal) = false;
|
2021-01-07 21:45:32 +00:00
|
|
|
option (gogoproto.goproto_getters) = false;
|
|
|
|
|
|
|
|
// hash is the ethereum transaction hex hash to query the logs for.
|
|
|
|
string hash = 1;
|
2021-09-09 14:26:30 +00:00
|
|
|
// pagination defines an optional pagination for the request.
|
|
|
|
cosmos.base.query.v1beta1.PageRequest pagination = 2;
|
2021-01-07 21:45:32 +00:00
|
|
|
}
|
|
|
|
|
2022-11-30 17:00:19 +00:00
|
|
|
// QueryTxLogsResponse is the response type for the Query/TxLogs RPC method.
|
2021-01-07 21:45:32 +00:00
|
|
|
message QueryTxLogsResponse {
|
|
|
|
// logs represents the ethereum logs generated from the given transaction.
|
|
|
|
repeated Log logs = 1;
|
2021-09-09 14:26:30 +00:00
|
|
|
// pagination defines the pagination in the response.
|
|
|
|
cosmos.base.query.v1beta1.PageResponse pagination = 2;
|
2021-01-07 21:45:32 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// QueryParamsRequest defines the request type for querying x/evm parameters.
|
|
|
|
message QueryParamsRequest {}
|
|
|
|
|
|
|
|
// QueryParamsResponse defines the response type for querying x/evm parameters.
|
|
|
|
message QueryParamsResponse {
|
|
|
|
// params define the evm module parameters.
|
2022-10-20 20:43:19 +00:00
|
|
|
Params params = 1 [(gogoproto.nullable) = false];
|
2021-01-07 21:45:32 +00:00
|
|
|
}
|
2021-04-18 15:54:18 +00:00
|
|
|
|
2021-07-09 09:04:46 +00:00
|
|
|
// EthCallRequest defines EthCall request
|
|
|
|
message EthCallRequest {
|
2022-11-30 17:00:19 +00:00
|
|
|
// args uses the same json format as the json rpc api.
|
2021-07-09 09:04:46 +00:00
|
|
|
bytes args = 1;
|
2022-11-30 17:00:19 +00:00
|
|
|
// gas_cap defines the default gas cap to be used
|
2021-07-19 15:19:23 +00:00
|
|
|
uint64 gas_cap = 2;
|
2022-11-30 17:00:19 +00:00
|
|
|
// proposer_address of the requested block in hex format
|
2022-10-21 23:58:29 +00:00
|
|
|
bytes proposer_address = 3 [(gogoproto.casttype) = "github.com/cosmos/cosmos-sdk/types.ConsAddress"];
|
2022-11-30 17:00:19 +00:00
|
|
|
// chain_id is the eip155 chain id parsed from the requested block header
|
|
|
|
int64 chain_id = 4;
|
2021-07-19 15:19:23 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// EstimateGasResponse defines EstimateGas response
|
|
|
|
message EstimateGasResponse {
|
2022-11-30 17:00:19 +00:00
|
|
|
// gas returns the estimated gas
|
2021-07-19 15:19:23 +00:00
|
|
|
uint64 gas = 1;
|
2021-07-09 09:04:46 +00:00
|
|
|
}
|
2021-09-04 20:33:06 +00:00
|
|
|
|
|
|
|
// QueryTraceTxRequest defines TraceTx request
|
|
|
|
message QueryTraceTxRequest {
|
2022-11-30 17:00:19 +00:00
|
|
|
// msg is the MsgEthereumTx for the requested transaction
|
2021-09-04 20:33:06 +00:00
|
|
|
MsgEthereumTx msg = 1;
|
2022-04-16 17:31:30 +00:00
|
|
|
// tx_index is not necessary anymore
|
|
|
|
reserved 2;
|
|
|
|
reserved "tx_index";
|
2022-11-30 17:00:19 +00:00
|
|
|
// trace_config holds extra parameters to trace functions.
|
2021-09-04 20:33:06 +00:00
|
|
|
TraceConfig trace_config = 3;
|
2022-11-30 17:00:19 +00:00
|
|
|
// predecessors is an array of transactions included in the same block
|
2021-11-09 18:38:22 +00:00
|
|
|
// need to be replayed first to get correct context for tracing.
|
|
|
|
repeated MsgEthereumTx predecessors = 4;
|
2022-11-30 17:00:19 +00:00
|
|
|
// block_number of requested transaction
|
2021-11-09 18:38:22 +00:00
|
|
|
int64 block_number = 5;
|
2022-11-30 17:00:19 +00:00
|
|
|
// block_hash of requested transaction
|
2021-11-09 18:38:22 +00:00
|
|
|
string block_hash = 6;
|
2022-11-30 17:00:19 +00:00
|
|
|
// block_time of requested transaction
|
2021-11-09 18:38:22 +00:00
|
|
|
google.protobuf.Timestamp block_time = 7 [(gogoproto.nullable) = false, (gogoproto.stdtime) = true];
|
2022-11-30 17:00:19 +00:00
|
|
|
// proposer_address is the proposer of the requested block
|
2022-10-21 23:58:29 +00:00
|
|
|
bytes proposer_address = 8 [(gogoproto.casttype) = "github.com/cosmos/cosmos-sdk/types.ConsAddress"];
|
2022-11-30 17:00:19 +00:00
|
|
|
// chain_id is the the eip155 chain id parsed from the requested block header
|
|
|
|
int64 chain_id = 9;
|
2021-09-04 20:33:06 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// QueryTraceTxResponse defines TraceTx response
|
|
|
|
message QueryTraceTxResponse {
|
2022-11-30 17:00:19 +00:00
|
|
|
// data is the response serialized in bytes
|
2021-09-04 20:33:06 +00:00
|
|
|
bytes data = 1;
|
2021-09-15 09:45:03 +00:00
|
|
|
}
|
2021-11-09 18:38:22 +00:00
|
|
|
|
|
|
|
// QueryTraceBlockRequest defines TraceTx request
|
|
|
|
message QueryTraceBlockRequest {
|
2022-11-30 17:00:19 +00:00
|
|
|
// txs is an array of messages in the block
|
2021-11-09 18:38:22 +00:00
|
|
|
repeated MsgEthereumTx txs = 1;
|
2022-11-30 17:00:19 +00:00
|
|
|
// trace_config holds extra parameters to trace functions.
|
2021-11-09 18:38:22 +00:00
|
|
|
TraceConfig trace_config = 3;
|
2022-11-30 17:00:19 +00:00
|
|
|
// block_number of the traced block
|
2021-11-09 18:38:22 +00:00
|
|
|
int64 block_number = 5;
|
2022-11-30 17:00:19 +00:00
|
|
|
// block_hash (hex) of the traced block
|
2021-11-09 18:38:22 +00:00
|
|
|
string block_hash = 6;
|
2022-11-30 17:00:19 +00:00
|
|
|
// block_time of the traced block
|
2021-11-09 18:38:22 +00:00
|
|
|
google.protobuf.Timestamp block_time = 7 [(gogoproto.nullable) = false, (gogoproto.stdtime) = true];
|
2022-11-30 17:00:19 +00:00
|
|
|
// proposer_address is the address of the requested block
|
2022-10-21 23:58:29 +00:00
|
|
|
bytes proposer_address = 8 [(gogoproto.casttype) = "github.com/cosmos/cosmos-sdk/types.ConsAddress"];
|
2022-11-30 17:00:19 +00:00
|
|
|
// chain_id is the eip155 chain id parsed from the requested block header
|
|
|
|
int64 chain_id = 9;
|
2021-11-09 18:38:22 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// QueryTraceBlockResponse defines TraceBlock response
|
|
|
|
message QueryTraceBlockResponse {
|
2022-11-30 17:00:19 +00:00
|
|
|
// data is the response serialized in bytes
|
2021-11-09 18:38:22 +00:00
|
|
|
bytes data = 1;
|
|
|
|
}
|
|
|
|
|
2022-04-30 16:11:28 +00:00
|
|
|
// QueryBaseFeeRequest defines the request type for querying the EIP1559 base
|
|
|
|
// fee.
|
|
|
|
message QueryBaseFeeRequest {}
|
|
|
|
|
2022-11-30 17:00:19 +00:00
|
|
|
// QueryBaseFeeResponse returns the EIP1559 base fee.
|
2022-04-30 16:11:28 +00:00
|
|
|
message QueryBaseFeeResponse {
|
2022-11-30 17:00:19 +00:00
|
|
|
// base_fee is the EIP1559 base fee
|
2022-10-20 20:43:19 +00:00
|
|
|
string base_fee = 1 [(gogoproto.customtype) = "github.com/cosmos/cosmos-sdk/types.Int"];
|
2022-04-30 16:11:28 +00:00
|
|
|
}
|