2c722d03ce
* rpc, evm: grpc tests * address validation * update rpc * test cleanup * additional tests
269 lines
9.3 KiB
Protocol Buffer
269 lines
9.3 KiB
Protocol Buffer
syntax = "proto3";
|
|
package ethermint.evm.v1alpha1;
|
|
|
|
import "gogoproto/gogo.proto";
|
|
import "google/api/annotations.proto";
|
|
import "ethermint/evm/v1alpha1/evm.proto";
|
|
|
|
option go_package = "github.com/cosmos/ethermint/x/evm/types";
|
|
|
|
// Query defines the gRPC querier service.
|
|
service Query {
|
|
// Account queries an Ethereum account.
|
|
rpc Account(QueryAccountRequest) returns (QueryAccountResponse) {
|
|
option (google.api.http).get = "/ethermint/evm/v1alpha1/account/{address}";
|
|
}
|
|
|
|
// Account queries an Ethereum account's Cosmos Address.
|
|
rpc CosmosAccount(QueryCosmosAccountRequest) returns (QueryCosmosAccountResponse) {
|
|
option (google.api.http).get = "/ethermint/evm/v1alpha1/cosmos_account/{address}";
|
|
}
|
|
|
|
// Balance queries the balance of a the EVM denomination for a single
|
|
// EthAccount.
|
|
rpc Balance(QueryBalanceRequest) returns (QueryBalanceResponse) {
|
|
option (google.api.http).get = "/ethermint/evm/v1alpha1/balances/{address}";
|
|
}
|
|
|
|
// Storage queries the balance of all coins for a single account.
|
|
rpc Storage(QueryStorageRequest) returns (QueryStorageResponse) {
|
|
option (google.api.http).get = "/ethermint/evm/v1alpha1/storage/{address}/{key}";
|
|
}
|
|
|
|
// Code queries the balance of all coins for a single account.
|
|
rpc Code(QueryCodeRequest) returns (QueryCodeResponse) {
|
|
option (google.api.http).get = "/ethermint/evm/v1alpha1/codes/{address}";
|
|
}
|
|
|
|
// TxLogs queries ethereum logs from a transaction.
|
|
rpc TxLogs(QueryTxLogsRequest) returns (QueryTxLogsResponse) {
|
|
option (google.api.http).get = "/ethermint/evm/v1alpha1/tx_logs/{hash}";
|
|
}
|
|
|
|
// TxReceipt queries a receipt by a transaction hash.
|
|
rpc TxReceipt(QueryTxReceiptRequest) returns (QueryTxReceiptResponse) {
|
|
option (google.api.http).get = "/ethermint/evm/v1alpha1/tx_receipt/{hash}";
|
|
}
|
|
|
|
// TxReceiptsByBlockHeight queries tx receipts by a block height.
|
|
rpc TxReceiptsByBlockHeight(QueryTxReceiptsByBlockHeightRequest) returns (QueryTxReceiptsByBlockHeightResponse) {
|
|
option (google.api.http).get = "/ethermint/evm/v1alpha1/tx_receipts_block";
|
|
}
|
|
|
|
// TxReceiptsByBlockHash queries tx receipts by a block hash.
|
|
rpc TxReceiptsByBlockHash(QueryTxReceiptsByBlockHashRequest) returns (QueryTxReceiptsByBlockHashResponse) {
|
|
option (google.api.http).get = "/ethermint/evm/v1alpha1/tx_receipts_block_hash/{hash}";
|
|
}
|
|
|
|
// BlockLogs queries all the ethereum logs for a given block hash.
|
|
rpc BlockLogs(QueryBlockLogsRequest) returns (QueryBlockLogsResponse) {
|
|
option (google.api.http).get = "/ethermint/evm/v1alpha1/block_logs/{hash}";
|
|
}
|
|
|
|
// BlockBloom queries the block bloom filter bytes at a given height.
|
|
rpc BlockBloom(QueryBlockBloomRequest) returns (QueryBlockBloomResponse) {
|
|
option (google.api.http).get = "/ethermint/evm/v1alpha1/block_bloom";
|
|
}
|
|
|
|
// Params queries the parameters of x/evm module.
|
|
rpc Params(QueryParamsRequest) returns (QueryParamsResponse) {
|
|
option (google.api.http).get = "/ethermint/evm/v1alpha1/params";
|
|
}
|
|
|
|
// StaticCall queries the static call value of x/evm module.
|
|
rpc StaticCall(QueryStaticCallRequest) returns (QueryStaticCallResponse) {
|
|
option (google.api.http).get = "/ethermint/evm/v1alpha1/static_call";
|
|
}
|
|
}
|
|
|
|
// QueryAccountRequest is the request type for the Query/Account RPC method.
|
|
message QueryAccountRequest {
|
|
option (gogoproto.equal) = false;
|
|
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.
|
|
string balance = 1;
|
|
// code_hash is the code bytes from the EOA.
|
|
bytes code_hash = 2;
|
|
// nonce is the account's sequence number.
|
|
uint64 nonce = 3;
|
|
}
|
|
|
|
// QueryCosmosAccountRequest is the request type for the Query/CosmosAccount RPC method.
|
|
message QueryCosmosAccountRequest {
|
|
option (gogoproto.equal) = false;
|
|
option (gogoproto.goproto_getters) = false;
|
|
|
|
// address is the ethereum hex address to query the account for.
|
|
string address = 1;
|
|
}
|
|
|
|
// QueryCosmosAccountResponse is the response type for the Query/CosmosAccount RPC method.
|
|
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;
|
|
// account_number is the account numbert
|
|
uint64 account_number = 3;
|
|
}
|
|
|
|
// QueryBalanceRequest is the request type for the Query/Balance RPC method.
|
|
message QueryBalanceRequest {
|
|
option (gogoproto.equal) = false;
|
|
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.
|
|
string balance = 1;
|
|
}
|
|
|
|
// QueryStorageRequest is the request type for the Query/Storage RPC method.
|
|
message QueryStorageRequest {
|
|
option (gogoproto.equal) = false;
|
|
option (gogoproto.goproto_getters) = false;
|
|
|
|
/// address is the ethereum hex address to query the storage state for.
|
|
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 {
|
|
// key defines the storage state value hash associated with the given key.
|
|
string value = 1;
|
|
}
|
|
|
|
// QueryCodeRequest is the request type for the Query/Code RPC method.
|
|
message QueryCodeRequest {
|
|
option (gogoproto.equal) = false;
|
|
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 {
|
|
option (gogoproto.equal) = false;
|
|
option (gogoproto.goproto_getters) = false;
|
|
|
|
// hash is the ethereum transaction hex hash to query the logs for.
|
|
string hash = 1;
|
|
}
|
|
|
|
// QueryTxLogs is the response type for the Query/TxLogs RPC method.
|
|
message QueryTxLogsResponse {
|
|
// logs represents the ethereum logs generated from the given transaction.
|
|
repeated Log logs = 1;
|
|
}
|
|
|
|
// QueryTxReceiptRequest is the request type for the Query/TxReceipt RPC method.
|
|
message QueryTxReceiptRequest {
|
|
option (gogoproto.equal) = false;
|
|
option (gogoproto.goproto_getters) = false;
|
|
|
|
// hash is the ethereum transaction hex hash to query the receipt for.
|
|
string hash = 1;
|
|
}
|
|
|
|
// QueryTxReceiptResponse is the response type for the Query/TxReceipt RPC method.
|
|
message QueryTxReceiptResponse {
|
|
// receipt represents the ethereum receipt for the given transaction.
|
|
TxReceipt receipt = 1;
|
|
}
|
|
|
|
// QueryTxReceiptsByBlockHeightRequest is the request type for the Query/TxReceiptsByBlockHeight RPC method.
|
|
message QueryTxReceiptsByBlockHeightRequest {
|
|
}
|
|
|
|
// QueryTxReceiptsByBlockHeightResponse is the response type for the Query/TxReceiptsByBlockHeight RPC method.
|
|
message QueryTxReceiptsByBlockHeightResponse {
|
|
// tx receipts list for the block
|
|
repeated TxReceipt receipts = 1;
|
|
}
|
|
|
|
// QueryTxReceiptsByBlockHashRequest is the request type for the Query/TxReceiptsByBlockHash RPC method.
|
|
message QueryTxReceiptsByBlockHashRequest {
|
|
option (gogoproto.equal) = false;
|
|
option (gogoproto.goproto_getters) = false;
|
|
|
|
// hash is the ethereum transaction hex hash to query the receipt for.
|
|
string hash = 1;
|
|
}
|
|
|
|
// QueryTxReceiptsByBlockHashResponse is the response type for the Query/TxReceiptsByBlockHash RPC method.
|
|
message QueryTxReceiptsByBlockHashResponse {
|
|
// tx receipts list for the block
|
|
repeated TxReceipt receipts = 1;
|
|
}
|
|
|
|
// QueryBlockLogsRequest is the request type for the Query/BlockLogs RPC method.
|
|
message QueryBlockLogsRequest {
|
|
option (gogoproto.equal) = false;
|
|
option (gogoproto.goproto_getters) = false;
|
|
|
|
// hash is the block hash to query the logs for.
|
|
string hash = 1;
|
|
}
|
|
|
|
// QueryTxLogs is the response type for the Query/BlockLogs RPC method.
|
|
message QueryBlockLogsResponse {
|
|
// logs represents the ethereum logs generated at the given block hash.
|
|
repeated TransactionLogs tx_logs = 1 [(gogoproto.nullable) = false];
|
|
}
|
|
|
|
// QueryBlockBloomRequest is the request type for the Query/BlockBloom RPC
|
|
// method.
|
|
message QueryBlockBloomRequest { }
|
|
|
|
// QueryBlockBloomResponse is the response type for the Query/BlockBloom RPC
|
|
// method.
|
|
message QueryBlockBloomResponse {
|
|
// bloom represents bloom filter for the given block hash.
|
|
bytes bloom = 1;
|
|
}
|
|
|
|
// 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.
|
|
Params params = 1 [(gogoproto.nullable) = false];
|
|
}
|
|
|
|
// QueryStaticCallRequest defines static call request
|
|
message QueryStaticCallRequest {
|
|
// address is the ethereum contract hex address to for static call.
|
|
string address = 1;
|
|
// static call input generated from abi
|
|
bytes input = 2;
|
|
}
|
|
|
|
// // QueryStaticCallRequest defines static call response
|
|
message QueryStaticCallResponse {
|
|
bytes data = 1;
|
|
}
|