2021-04-17 10:00:07 +00:00
<!-- This file is auto - generated. Please do not modify it yourself. -->
# Protobuf Documentation
< a name = "top" > < / a >
## Table of Contents
2021-08-17 15:30:35 +00:00
- [ethermint/crypto/v1/ethsecp256k1/keys.proto ](#ethermint/crypto/v1/ethsecp256k1/keys.proto )
- [PrivKey ](#ethermint.crypto.v1.ethsecp256k1.PrivKey )
- [PubKey ](#ethermint.crypto.v1.ethsecp256k1.PubKey )
2021-04-17 10:00:07 +00:00
2021-08-17 15:30:35 +00:00
- [ethermint/evm/v1/evm.proto ](#ethermint/evm/v1/evm.proto )
- [AccessTuple ](#ethermint.evm.v1.AccessTuple )
- [ChainConfig ](#ethermint.evm.v1.ChainConfig )
- [Log ](#ethermint.evm.v1.Log )
- [Params ](#ethermint.evm.v1.Params )
- [State ](#ethermint.evm.v1.State )
2021-09-04 20:33:06 +00:00
- [TraceConfig ](#ethermint.evm.v1.TraceConfig )
2021-08-17 15:30:35 +00:00
- [TransactionLogs ](#ethermint.evm.v1.TransactionLogs )
- [TxResult ](#ethermint.evm.v1.TxResult )
2021-04-17 10:00:07 +00:00
2021-08-17 15:30:35 +00:00
- [ethermint/evm/v1/genesis.proto ](#ethermint/evm/v1/genesis.proto )
- [GenesisAccount ](#ethermint.evm.v1.GenesisAccount )
- [GenesisState ](#ethermint.evm.v1.GenesisState )
2021-04-17 10:00:07 +00:00
2021-08-17 15:30:35 +00:00
- [ethermint/evm/v1/tx.proto ](#ethermint/evm/v1/tx.proto )
- [AccessListTx ](#ethermint.evm.v1.AccessListTx )
- [DynamicFeeTx ](#ethermint.evm.v1.DynamicFeeTx )
- [ExtensionOptionsEthereumTx ](#ethermint.evm.v1.ExtensionOptionsEthereumTx )
- [LegacyTx ](#ethermint.evm.v1.LegacyTx )
- [MsgEthereumTx ](#ethermint.evm.v1.MsgEthereumTx )
- [MsgEthereumTxResponse ](#ethermint.evm.v1.MsgEthereumTxResponse )
2021-07-09 09:04:46 +00:00
2021-08-17 15:30:35 +00:00
- [Msg ](#ethermint.evm.v1.Msg )
2021-07-09 09:04:46 +00:00
2021-08-17 15:30:35 +00:00
- [ethermint/evm/v1/query.proto ](#ethermint/evm/v1/query.proto )
- [EstimateGasResponse ](#ethermint.evm.v1.EstimateGasResponse )
- [EthCallRequest ](#ethermint.evm.v1.EthCallRequest )
- [QueryAccountRequest ](#ethermint.evm.v1.QueryAccountRequest )
- [QueryAccountResponse ](#ethermint.evm.v1.QueryAccountResponse )
- [QueryBalanceRequest ](#ethermint.evm.v1.QueryBalanceRequest )
- [QueryBalanceResponse ](#ethermint.evm.v1.QueryBalanceResponse )
- [QueryCodeRequest ](#ethermint.evm.v1.QueryCodeRequest )
- [QueryCodeResponse ](#ethermint.evm.v1.QueryCodeResponse )
- [QueryCosmosAccountRequest ](#ethermint.evm.v1.QueryCosmosAccountRequest )
- [QueryCosmosAccountResponse ](#ethermint.evm.v1.QueryCosmosAccountResponse )
- [QueryParamsRequest ](#ethermint.evm.v1.QueryParamsRequest )
- [QueryParamsResponse ](#ethermint.evm.v1.QueryParamsResponse )
- [QueryStaticCallResponse ](#ethermint.evm.v1.QueryStaticCallResponse )
- [QueryStorageRequest ](#ethermint.evm.v1.QueryStorageRequest )
- [QueryStorageResponse ](#ethermint.evm.v1.QueryStorageResponse )
2021-09-04 20:33:06 +00:00
- [QueryTraceTxRequest ](#ethermint.evm.v1.QueryTraceTxRequest )
- [QueryTraceTxResponse ](#ethermint.evm.v1.QueryTraceTxResponse )
2021-08-17 15:30:35 +00:00
- [QueryTxLogsRequest ](#ethermint.evm.v1.QueryTxLogsRequest )
- [QueryTxLogsResponse ](#ethermint.evm.v1.QueryTxLogsResponse )
- [QueryValidatorAccountRequest ](#ethermint.evm.v1.QueryValidatorAccountRequest )
- [QueryValidatorAccountResponse ](#ethermint.evm.v1.QueryValidatorAccountResponse )
2021-04-17 10:00:07 +00:00
2021-08-17 15:30:35 +00:00
- [Query ](#ethermint.evm.v1.Query )
2021-04-17 10:00:07 +00:00
2021-08-26 10:08:11 +00:00
- [ethermint/feemarket/v1/feemarket.proto ](#ethermint/feemarket/v1/feemarket.proto )
- [Params ](#ethermint.feemarket.v1.Params )
- [ethermint/feemarket/v1/genesis.proto ](#ethermint/feemarket/v1/genesis.proto )
- [GenesisState ](#ethermint.feemarket.v1.GenesisState )
- [ethermint/feemarket/v1/query.proto ](#ethermint/feemarket/v1/query.proto )
- [QueryBaseFeeRequest ](#ethermint.feemarket.v1.QueryBaseFeeRequest )
- [QueryBaseFeeResponse ](#ethermint.feemarket.v1.QueryBaseFeeResponse )
- [QueryBlockGasRequest ](#ethermint.feemarket.v1.QueryBlockGasRequest )
- [QueryBlockGasResponse ](#ethermint.feemarket.v1.QueryBlockGasResponse )
- [QueryParamsRequest ](#ethermint.feemarket.v1.QueryParamsRequest )
- [QueryParamsResponse ](#ethermint.feemarket.v1.QueryParamsResponse )
- [Query ](#ethermint.feemarket.v1.Query )
2021-08-17 15:30:35 +00:00
- [ethermint/types/v1/account.proto ](#ethermint/types/v1/account.proto )
- [EthAccount ](#ethermint.types.v1.EthAccount )
2021-08-25 14:45:51 +00:00
- [ethermint/types/v1/web3.proto ](#ethermint/types/v1/web3.proto )
2021-08-17 15:30:35 +00:00
- [ExtensionOptionsWeb3Tx ](#ethermint.types.v1.ExtensionOptionsWeb3Tx )
2021-04-17 10:00:07 +00:00
- [Scalar Value Types ](#scalar-value-types )
2021-08-17 15:30:35 +00:00
< a name = "ethermint/crypto/v1/ethsecp256k1/keys.proto" > < / a >
2021-04-17 10:00:07 +00:00
< p align = "right" > < a href = "#top" > Top< / a > < / p >
2021-08-17 15:30:35 +00:00
## ethermint/crypto/v1/ethsecp256k1/keys.proto
2021-04-17 10:00:07 +00:00
2021-08-17 15:30:35 +00:00
< a name = "ethermint.crypto.v1.ethsecp256k1.PrivKey" > < / a >
2021-04-17 10:00:07 +00:00
### PrivKey
PrivKey defines a type alias for an ecdsa.PrivateKey that implements
Tendermint's PrivateKey interface.
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
| `key` | [bytes ](#bytes ) | | |
2021-08-17 15:30:35 +00:00
< a name = "ethermint.crypto.v1.ethsecp256k1.PubKey" > < / a >
2021-04-17 10:00:07 +00:00
### PubKey
PubKey defines a type alias for an ecdsa.PublicKey that implements
Tendermint's PubKey interface. It represents the 33-byte compressed public
key format.
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
| `key` | [bytes ](#bytes ) | | |
<!-- end messages -->
<!-- end enums -->
<!-- end HasExtensions -->
<!-- end services -->
2021-08-17 15:30:35 +00:00
< a name = "ethermint/evm/v1/evm.proto" > < / a >
2021-04-17 10:00:07 +00:00
< p align = "right" > < a href = "#top" > Top< / a > < / p >
2021-08-17 15:30:35 +00:00
## ethermint/evm/v1/evm.proto
2021-04-17 10:00:07 +00:00
2021-08-17 15:30:35 +00:00
< a name = "ethermint.evm.v1.AccessTuple" > < / a >
2021-05-10 16:34:00 +00:00
### AccessTuple
AccessTuple is the element type of an access list.
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
| `address` | [string ](#string ) | | hex formatted ethereum address |
| `storage_keys` | [string ](#string ) | repeated | hex formatted hashes of the storage keys |
2021-08-17 15:30:35 +00:00
< a name = "ethermint.evm.v1.ChainConfig" > < / a >
2021-04-17 10:00:07 +00:00
### ChainConfig
2021-07-14 09:13:55 +00:00
ChainConfig defines the Ethereum ChainConfig parameters using *sdk.Int values
instead of *big.Int.
2021-04-17 10:00:07 +00:00
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
2021-07-14 09:13:55 +00:00
| `homestead_block` | [string ](#string ) | | Homestead switch block (nil no fork, 0 = already homestead) |
| `dao_fork_block` | [string ](#string ) | | TheDAO hard-fork switch block (nil no fork) |
2021-04-17 10:00:07 +00:00
| `dao_fork_support` | [bool ](#bool ) | | Whether the nodes supports or opposes the DAO hard-fork |
2021-07-14 09:13:55 +00:00
| `eip150_block` | [string ](#string ) | | EIP150 implements the Gas price changes (https://github.com/ethereum/EIPs/issues/150) EIP150 HF block (nil no fork) |
2021-04-17 10:00:07 +00:00
| `eip150_hash` | [string ](#string ) | | EIP150 HF hash (needed for header only clients as only gas pricing changed) |
| `eip155_block` | [string ](#string ) | | EIP155Block HF block |
| `eip158_block` | [string ](#string ) | | EIP158 HF block |
2021-07-14 09:13:55 +00:00
| `byzantium_block` | [string ](#string ) | | Byzantium switch block (nil no fork, 0 = already on byzantium) |
| `constantinople_block` | [string ](#string ) | | Constantinople switch block (nil no fork, 0 = already activated) |
| `petersburg_block` | [string ](#string ) | | Petersburg switch block (nil same as Constantinople) |
| `istanbul_block` | [string ](#string ) | | Istanbul switch block (nil no fork, 0 = already on istanbul) |
| `muir_glacier_block` | [string ](#string ) | | Eip-2384 (bomb delay) switch block (nil no fork, 0 = already activated) |
| `berlin_block` | [string ](#string ) | | Berlin switch block (nil = no fork, 0 = already on berlin) |
| `catalyst_block` | [string ](#string ) | | Catalyst switch block (nil = no fork, 0 = already on catalyst) |
2021-08-25 14:45:51 +00:00
| `london_block` | [string ](#string ) | | London switch block (nil = no fork, 0 = already on london) |
2021-04-17 10:00:07 +00:00
2021-08-17 15:30:35 +00:00
< a name = "ethermint.evm.v1.Log" > < / a >
2021-04-17 10:00:07 +00:00
### Log
Log represents an protobuf compatible Ethereum Log that defines a contract
log event. These events are generated by the LOG opcode and stored/indexed by
the node.
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
| `address` | [string ](#string ) | | address of the contract that generated the event |
| `topics` | [string ](#string ) | repeated | list of topics provided by the contract. |
| `data` | [bytes ](#bytes ) | | supplied by the contract, usually ABI-encoded |
| `block_number` | [uint64 ](#uint64 ) | | block in which the transaction was included |
| `tx_hash` | [string ](#string ) | | hash of the transaction |
| `tx_index` | [uint64 ](#uint64 ) | | index of the transaction in the block |
| `block_hash` | [string ](#string ) | | hash of the block in which the transaction was included |
| `index` | [uint64 ](#uint64 ) | | index of the log in the block |
| `removed` | [bool ](#bool ) | | The Removed field is true if this log was reverted due to a chain reorganisation. You must pay attention to this field if you receive logs through a filter query. |
2021-08-17 15:30:35 +00:00
< a name = "ethermint.evm.v1.Params" > < / a >
2021-04-17 10:00:07 +00:00
### Params
Params defines the EVM module parameters
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
2021-07-14 09:13:55 +00:00
| `evm_denom` | [string ](#string ) | | evm denom represents the token denomination used to run the EVM state transitions. |
| `enable_create` | [bool ](#bool ) | | enable create toggles state transitions that use the vm.Create function |
| `enable_call` | [bool ](#bool ) | | enable call toggles state transitions that use the vm.Call function |
| `extra_eips` | [int64 ](#int64 ) | repeated | extra eips defines the additional EIPs for the vm.Config |
2021-08-17 15:30:35 +00:00
| `chain_config` | [ChainConfig ](#ethermint.evm.v1.ChainConfig ) | | chain config defines the EVM chain configuration parameters |
2021-04-17 10:00:07 +00:00
2021-08-17 15:30:35 +00:00
< a name = "ethermint.evm.v1.State" > < / a >
2021-04-17 10:00:07 +00:00
### State
State represents a single Storage key value pair item.
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
| `key` | [string ](#string ) | | |
| `value` | [string ](#string ) | | |
2021-09-04 20:33:06 +00:00
< a name = "ethermint.evm.v1.TraceConfig" > < / a >
### TraceConfig
TraceConfig holds extra parameters to trace functions.
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
| `tracer` | [string ](#string ) | | custom javascript tracer |
| `timeout` | [string ](#string ) | | overrides the default timeout of 5 seconds for JavaScript-based tracing calls |
| `reexec` | [uint64 ](#uint64 ) | | number of blocks the tracer is willing to go back |
2021-09-15 13:50:52 +00:00
| `disable_memory` | [bool ](#bool ) | | disable memory capture |
| `disable_stack` | [bool ](#bool ) | | disable stack capture |
| `disable_storage` | [bool ](#bool ) | | disable storage capture |
| `disable_return_data` | [bool ](#bool ) | | disable return data capture |
| `debug` | [bool ](#bool ) | | print output during capture end |
| `limit` | [int32 ](#int32 ) | | maximum length of output, but zero means unlimited |
| `overrides` | [ChainConfig ](#ethermint.evm.v1.ChainConfig ) | | Chain overrides, can be used to execute a trace using future fork rules |
2021-09-04 20:33:06 +00:00
2021-08-17 15:30:35 +00:00
< a name = "ethermint.evm.v1.TransactionLogs" > < / a >
2021-04-17 10:00:07 +00:00
### TransactionLogs
TransactionLogs define the logs generated from a transaction execution
with a given hash. It it used for import/export data as transactions are not
persisted on blockchain state after an upgrade.
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
| `hash` | [string ](#string ) | | |
2021-08-17 15:30:35 +00:00
| `logs` | [Log ](#ethermint.evm.v1.Log ) | repeated | |
2021-04-17 10:00:07 +00:00
2021-05-10 16:34:00 +00:00
2021-08-17 15:30:35 +00:00
< a name = "ethermint.evm.v1.TxResult" > < / a >
2021-05-10 16:34:00 +00:00
### TxResult
TxResult stores results of Tx execution.
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
| `contract_address` | [string ](#string ) | | contract_address contains the ethereum address of the created contract (if any). If the state transition is an evm.Call, the contract address will be empty. |
| `bloom` | [bytes ](#bytes ) | | bloom represents the bloom filter bytes |
2021-08-17 15:30:35 +00:00
| `tx_logs` | [TransactionLogs ](#ethermint.evm.v1.TransactionLogs ) | | tx_logs contains the transaction hash and the proto-compatible ethereum logs. |
2021-05-10 16:34:00 +00:00
| `ret` | [bytes ](#bytes ) | | ret defines the bytes from the execution. |
| `reverted` | [bool ](#bool ) | | reverted flag is set to true when the call has been reverted |
| `gas_used` | [uint64 ](#uint64 ) | | gas_used notes the amount of gas consumed while execution |
2021-04-17 10:00:07 +00:00
<!-- end messages -->
<!-- end enums -->
<!-- end HasExtensions -->
<!-- end services -->
2021-08-17 15:30:35 +00:00
< a name = "ethermint/evm/v1/genesis.proto" > < / a >
2021-04-17 10:00:07 +00:00
< p align = "right" > < a href = "#top" > Top< / a > < / p >
2021-08-17 15:30:35 +00:00
## ethermint/evm/v1/genesis.proto
2021-04-17 10:00:07 +00:00
2021-08-17 15:30:35 +00:00
< a name = "ethermint.evm.v1.GenesisAccount" > < / a >
2021-04-17 10:00:07 +00:00
### GenesisAccount
GenesisAccount defines an account to be initialized in the genesis state.
Its main difference between with Geth's GenesisAccount is that it uses a
custom storage type and that it doesn't contain the private key field.
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
| `address` | [string ](#string ) | | address defines an ethereum hex formated address of an account |
| `code` | [string ](#string ) | | code defines the hex bytes of the account code. |
2021-08-17 15:30:35 +00:00
| `storage` | [State ](#ethermint.evm.v1.State ) | repeated | storage defines the set of state key values for the account. |
2021-04-17 10:00:07 +00:00
2021-08-17 15:30:35 +00:00
< a name = "ethermint.evm.v1.GenesisState" > < / a >
2021-04-17 10:00:07 +00:00
### GenesisState
GenesisState defines the evm module's genesis state.
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
2021-08-17 15:30:35 +00:00
| `accounts` | [GenesisAccount ](#ethermint.evm.v1.GenesisAccount ) | repeated | accounts is an array containing the ethereum genesis accounts. |
| `params` | [Params ](#ethermint.evm.v1.Params ) | | params defines all the paramaters of the module. |
2021-04-17 10:00:07 +00:00
<!-- end messages -->
<!-- end enums -->
<!-- end HasExtensions -->
<!-- end services -->
2021-08-17 15:30:35 +00:00
< a name = "ethermint/evm/v1/tx.proto" > < / a >
2021-07-09 09:04:46 +00:00
< p align = "right" > < a href = "#top" > Top< / a > < / p >
2021-08-17 15:30:35 +00:00
## ethermint/evm/v1/tx.proto
2021-07-09 09:04:46 +00:00
2021-08-17 15:30:35 +00:00
< a name = "ethermint.evm.v1.AccessListTx" > < / a >
2021-07-09 09:04:46 +00:00
### AccessListTx
AccessListTx is the data of EIP-2930 access list transactions.
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
| `chain_id` | [string ](#string ) | | destination EVM chain ID |
| `nonce` | [uint64 ](#uint64 ) | | nonce corresponds to the account nonce (transaction sequence). |
| `gas_price` | [string ](#string ) | | gas price defines the value for each gas unit |
| `gas` | [uint64 ](#uint64 ) | | gas defines the gas limit defined for the transaction. |
| `to` | [string ](#string ) | | hex formatted address of the recipient |
| `value` | [string ](#string ) | | value defines the unsigned integer value of the transaction amount. |
| `data` | [bytes ](#bytes ) | | input defines the data payload bytes of the transaction. |
2021-08-17 15:30:35 +00:00
| `accesses` | [AccessTuple ](#ethermint.evm.v1.AccessTuple ) | repeated | |
2021-07-09 09:04:46 +00:00
| `v` | [bytes ](#bytes ) | | v defines the signature value |
| `r` | [bytes ](#bytes ) | | r defines the signature value |
| `s` | [bytes ](#bytes ) | | s define the signature value |
2021-08-17 15:30:35 +00:00
< a name = "ethermint.evm.v1.DynamicFeeTx" > < / a >
2021-07-30 11:40:17 +00:00
### DynamicFeeTx
DynamicFeeTx is the data of EIP-1559 dinamic fee transactions.
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
| `chain_id` | [string ](#string ) | | destination EVM chain ID |
| `nonce` | [uint64 ](#uint64 ) | | nonce corresponds to the account nonce (transaction sequence). |
| `gas_tip_cap` | [string ](#string ) | | gas tip cap defines the max value for the gas tip |
| `gas_fee_cap` | [string ](#string ) | | gas fee cap defines the max value for the gas fee |
| `gas` | [uint64 ](#uint64 ) | | gas defines the gas limit defined for the transaction. |
| `to` | [string ](#string ) | | hex formatted address of the recipient |
| `value` | [string ](#string ) | | value defines the the transaction amount. |
| `data` | [bytes ](#bytes ) | | input defines the data payload bytes of the transaction. |
2021-08-17 15:30:35 +00:00
| `accesses` | [AccessTuple ](#ethermint.evm.v1.AccessTuple ) | repeated | |
2021-07-30 11:40:17 +00:00
| `v` | [bytes ](#bytes ) | | v defines the signature value |
| `r` | [bytes ](#bytes ) | | r defines the signature value |
| `s` | [bytes ](#bytes ) | | s define the signature value |
2021-08-17 15:30:35 +00:00
< a name = "ethermint.evm.v1.ExtensionOptionsEthereumTx" > < / a >
2021-07-09 09:04:46 +00:00
### ExtensionOptionsEthereumTx
2021-08-17 15:30:35 +00:00
< a name = "ethermint.evm.v1.LegacyTx" > < / a >
2021-07-09 09:04:46 +00:00
### LegacyTx
LegacyTx is the transaction data of regular Ethereum transactions.
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
| `nonce` | [uint64 ](#uint64 ) | | nonce corresponds to the account nonce (transaction sequence). |
| `gas_price` | [string ](#string ) | | gas price defines the value for each gas unit |
| `gas` | [uint64 ](#uint64 ) | | gas defines the gas limit defined for the transaction. |
| `to` | [string ](#string ) | | hex formatted address of the recipient |
| `value` | [string ](#string ) | | value defines the unsigned integer value of the transaction amount. |
| `data` | [bytes ](#bytes ) | | input defines the data payload bytes of the transaction. |
| `v` | [bytes ](#bytes ) | | v defines the signature value |
| `r` | [bytes ](#bytes ) | | r defines the signature value |
| `s` | [bytes ](#bytes ) | | s define the signature value |
2021-08-17 15:30:35 +00:00
< a name = "ethermint.evm.v1.MsgEthereumTx" > < / a >
2021-07-09 09:04:46 +00:00
### MsgEthereumTx
MsgEthereumTx encapsulates an Ethereum transaction as an SDK message.
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
| `data` | [google.protobuf.Any ](#google.protobuf.Any ) | | inner transaction data
caches |
| `size` | [double ](#double ) | | encoded storage size of the transaction |
| `hash` | [string ](#string ) | | transaction hash in hex format |
| `from` | [string ](#string ) | | ethereum signer address in hex format. This address value is checked against the address derived from the signature (V, R, S) using the secp256k1 elliptic curve |
2021-08-17 15:30:35 +00:00
< a name = "ethermint.evm.v1.MsgEthereumTxResponse" > < / a >
2021-07-09 09:04:46 +00:00
### MsgEthereumTxResponse
MsgEthereumTxResponse defines the Msg/EthereumTx response type.
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
| `hash` | [string ](#string ) | | ethereum transaction hash in hex format. This hash differs from the Tendermint sha256 hash of the transaction bytes. See https://github.com/tendermint/tendermint/issues/6539 for reference |
2021-08-17 15:30:35 +00:00
| `logs` | [Log ](#ethermint.evm.v1.Log ) | repeated | logs contains the transaction hash and the proto-compatible ethereum logs. |
2021-07-09 09:04:46 +00:00
| `ret` | [bytes ](#bytes ) | | returned data from evm function (result or data supplied with revert opcode) |
2021-07-15 06:01:05 +00:00
| `vm_error` | [string ](#string ) | | vm error is the error returned by vm execution |
2021-07-09 09:04:46 +00:00
| `gas_used` | [uint64 ](#uint64 ) | | gas consumed by the transaction |
<!-- end messages -->
<!-- end enums -->
<!-- end HasExtensions -->
2021-08-17 15:30:35 +00:00
< a name = "ethermint.evm.v1.Msg" > < / a >
2021-07-09 09:04:46 +00:00
### Msg
Msg defines the evm Msg service.
| Method Name | Request Type | Response Type | Description | HTTP Verb | Endpoint |
| ----------- | ------------ | ------------- | ------------| ------- | -------- |
2021-08-17 15:30:35 +00:00
| `EthereumTx` | [MsgEthereumTx ](#ethermint.evm.v1.MsgEthereumTx ) | [MsgEthereumTxResponse ](#ethermint.evm.v1.MsgEthereumTxResponse ) | EthereumTx defines a method submitting Ethereum transactions. | |
2021-07-09 09:04:46 +00:00
<!-- end services -->
2021-08-17 15:30:35 +00:00
< a name = "ethermint/evm/v1/query.proto" > < / a >
2021-04-17 10:00:07 +00:00
< p align = "right" > < a href = "#top" > Top< / a > < / p >
2021-08-17 15:30:35 +00:00
## ethermint/evm/v1/query.proto
2021-04-17 10:00:07 +00:00
2021-08-17 15:30:35 +00:00
< a name = "ethermint.evm.v1.EstimateGasResponse" > < / a >
2021-07-19 15:19:23 +00:00
### EstimateGasResponse
EstimateGasResponse defines EstimateGas response
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
| `gas` | [uint64 ](#uint64 ) | | the estimated gas |
2021-08-17 15:30:35 +00:00
< a name = "ethermint.evm.v1.EthCallRequest" > < / a >
2021-07-09 09:04:46 +00:00
### EthCallRequest
EthCallRequest defines EthCall request
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
| `args` | [bytes ](#bytes ) | | same json format as the json rpc api. |
2021-07-19 15:19:23 +00:00
| `gas_cap` | [uint64 ](#uint64 ) | | the default gas cap to be used |
2021-07-09 09:04:46 +00:00
2021-08-17 15:30:35 +00:00
< a name = "ethermint.evm.v1.QueryAccountRequest" > < / a >
2021-04-17 10:00:07 +00:00
### QueryAccountRequest
QueryAccountRequest is the request type for the Query/Account RPC method.
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
| `address` | [string ](#string ) | | address is the ethereum hex address to query the account for. |
2021-08-17 15:30:35 +00:00
< a name = "ethermint.evm.v1.QueryAccountResponse" > < / a >
2021-04-17 10:00:07 +00:00
### QueryAccountResponse
QueryAccountResponse is the response type for the Query/Account RPC method.
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
2021-07-02 09:29:47 +00:00
| `balance` | [string ](#string ) | | balance is the balance of the EVM denomination. |
2021-06-08 17:10:29 +00:00
| `code_hash` | [string ](#string ) | | code hash is the hex-formatted code bytes from the EOA. |
2021-04-17 10:00:07 +00:00
| `nonce` | [uint64 ](#uint64 ) | | nonce is the account's sequence number. |
2021-08-17 15:30:35 +00:00
< a name = "ethermint.evm.v1.QueryBalanceRequest" > < / a >
2021-04-17 10:00:07 +00:00
### QueryBalanceRequest
QueryBalanceRequest is the request type for the Query/Balance RPC method.
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
| `address` | [string ](#string ) | | address is the ethereum hex address to query the balance for. |
2021-08-17 15:30:35 +00:00
< a name = "ethermint.evm.v1.QueryBalanceResponse" > < / a >
2021-04-17 10:00:07 +00:00
### QueryBalanceResponse
QueryBalanceResponse is the response type for the Query/Balance RPC method.
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
2021-07-02 09:29:47 +00:00
| `balance` | [string ](#string ) | | balance is the balance of the EVM denomination. |
2021-04-17 10:00:07 +00:00
2021-08-17 15:30:35 +00:00
< a name = "ethermint.evm.v1.QueryCodeRequest" > < / a >
2021-04-17 10:00:07 +00:00
### QueryCodeRequest
QueryCodeRequest is the request type for the Query/Code RPC method.
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
| `address` | [string ](#string ) | | address is the ethereum hex address to query the code for. |
2021-08-17 15:30:35 +00:00
< a name = "ethermint.evm.v1.QueryCodeResponse" > < / a >
2021-04-17 10:00:07 +00:00
### QueryCodeResponse
QueryCodeResponse is the response type for the Query/Code RPC
method.
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
| `code` | [bytes ](#bytes ) | | code represents the code bytes from an ethereum address. |
2021-08-17 15:30:35 +00:00
< a name = "ethermint.evm.v1.QueryCosmosAccountRequest" > < / a >
2021-05-10 16:34:00 +00:00
### QueryCosmosAccountRequest
2021-07-30 11:40:17 +00:00
QueryCosmosAccountRequest is the request type for the Query/CosmosAccount RPC
method.
2021-05-10 16:34:00 +00:00
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
| `address` | [string ](#string ) | | address is the ethereum hex address to query the account for. |
2021-08-17 15:30:35 +00:00
< a name = "ethermint.evm.v1.QueryCosmosAccountResponse" > < / a >
2021-05-10 16:34:00 +00:00
### QueryCosmosAccountResponse
2021-07-30 11:40:17 +00:00
QueryCosmosAccountResponse is the response type for the Query/CosmosAccount
RPC method.
2021-05-10 16:34:00 +00:00
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
| `cosmos_address` | [string ](#string ) | | cosmos_address is the cosmos address of the account. |
| `sequence` | [uint64 ](#uint64 ) | | sequence is the account's sequence number. |
| `account_number` | [uint64 ](#uint64 ) | | account_number is the account numbert |
2021-08-17 15:30:35 +00:00
< a name = "ethermint.evm.v1.QueryParamsRequest" > < / a >
2021-04-17 10:00:07 +00:00
### QueryParamsRequest
QueryParamsRequest defines the request type for querying x/evm parameters.
2021-08-17 15:30:35 +00:00
< a name = "ethermint.evm.v1.QueryParamsResponse" > < / a >
2021-04-17 10:00:07 +00:00
### QueryParamsResponse
QueryParamsResponse defines the response type for querying x/evm parameters.
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
2021-08-17 15:30:35 +00:00
| `params` | [Params ](#ethermint.evm.v1.Params ) | | params define the evm module parameters. |
2021-04-17 10:00:07 +00:00
2021-08-17 15:30:35 +00:00
< a name = "ethermint.evm.v1.QueryStaticCallResponse" > < / a >
2021-05-10 16:34:00 +00:00
### QueryStaticCallResponse
QueryStaticCallRequest defines static call response
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
| `data` | [bytes ](#bytes ) | | |
2021-08-17 15:30:35 +00:00
< a name = "ethermint.evm.v1.QueryStorageRequest" > < / a >
2021-04-17 10:00:07 +00:00
### QueryStorageRequest
QueryStorageRequest is the request type for the Query/Storage RPC method.
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
| `address` | [string ](#string ) | | address is the ethereum hex address to query the storage state for. |
| `key` | [string ](#string ) | | key defines the key of the storage state |
2021-08-17 15:30:35 +00:00
< a name = "ethermint.evm.v1.QueryStorageResponse" > < / a >
2021-04-17 10:00:07 +00:00
### QueryStorageResponse
QueryStorageResponse is the response type for the Query/Storage RPC
method.
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
| `value` | [string ](#string ) | | key defines the storage state value hash associated with the given key. |
2021-09-04 20:33:06 +00:00
< a name = "ethermint.evm.v1.QueryTraceTxRequest" > < / a >
### QueryTraceTxRequest
QueryTraceTxRequest defines TraceTx request
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
| `msg` | [MsgEthereumTx ](#ethermint.evm.v1.MsgEthereumTx ) | | msgEthereumTx for the requested transaction |
2021-09-15 08:46:01 +00:00
| `tx_index` | [uint64 ](#uint64 ) | | transaction index |
2021-09-04 20:33:06 +00:00
| `trace_config` | [TraceConfig ](#ethermint.evm.v1.TraceConfig ) | | TraceConfig holds extra parameters to trace functions. |
< a name = "ethermint.evm.v1.QueryTraceTxResponse" > < / a >
### QueryTraceTxResponse
QueryTraceTxResponse defines TraceTx response
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
| `data` | [bytes ](#bytes ) | | response serialized in bytes |
2021-08-17 15:30:35 +00:00
< a name = "ethermint.evm.v1.QueryTxLogsRequest" > < / a >
2021-04-17 10:00:07 +00:00
### QueryTxLogsRequest
QueryTxLogsRequest is the request type for the Query/TxLogs RPC method.
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
| `hash` | [string ](#string ) | | hash is the ethereum transaction hex hash to query the logs for. |
2021-09-09 14:26:30 +00:00
| `pagination` | [cosmos.base.query.v1beta1.PageRequest ](#cosmos.base.query.v1beta1.PageRequest ) | | pagination defines an optional pagination for the request. |
2021-04-17 10:00:07 +00:00
2021-08-17 15:30:35 +00:00
< a name = "ethermint.evm.v1.QueryTxLogsResponse" > < / a >
2021-04-17 10:00:07 +00:00
### QueryTxLogsResponse
QueryTxLogs is the response type for the Query/TxLogs RPC method.
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
2021-08-17 15:30:35 +00:00
| `logs` | [Log ](#ethermint.evm.v1.Log ) | repeated | logs represents the ethereum logs generated from the given transaction. |
2021-09-09 14:26:30 +00:00
| `pagination` | [cosmos.base.query.v1beta1.PageResponse ](#cosmos.base.query.v1beta1.PageResponse ) | | pagination defines the pagination in the response. |
2021-04-17 10:00:07 +00:00
2021-06-22 10:14:40 +00:00
2021-08-17 15:30:35 +00:00
< a name = "ethermint.evm.v1.QueryValidatorAccountRequest" > < / a >
2021-06-22 10:14:40 +00:00
### QueryValidatorAccountRequest
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
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
| `cons_address` | [string ](#string ) | | cons_address is the validator cons address to query the account for. |
2021-08-17 15:30:35 +00:00
< a name = "ethermint.evm.v1.QueryValidatorAccountResponse" > < / a >
2021-06-22 10:14:40 +00:00
### QueryValidatorAccountResponse
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
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
| `account_address` | [string ](#string ) | | account_address is the cosmos address of the account in bech32 format. |
| `sequence` | [uint64 ](#uint64 ) | | sequence is the account's sequence number. |
| `account_number` | [uint64 ](#uint64 ) | | account_number is the account number |
2021-05-10 16:34:00 +00:00
<!-- end messages -->
2021-04-17 10:00:07 +00:00
2021-05-10 16:34:00 +00:00
<!-- end enums -->
2021-04-17 10:00:07 +00:00
2021-05-10 16:34:00 +00:00
<!-- end HasExtensions -->
2021-08-17 15:30:35 +00:00
< a name = "ethermint.evm.v1.Query" > < / a >
2021-05-10 16:34:00 +00:00
### Query
Query defines the gRPC querier service.
| Method Name | Request Type | Response Type | Description | HTTP Verb | Endpoint |
| ----------- | ------------ | ------------- | ------------| ------- | -------- |
2021-08-17 15:30:35 +00:00
| `Account` | [QueryAccountRequest ](#ethermint.evm.v1.QueryAccountRequest ) | [QueryAccountResponse ](#ethermint.evm.v1.QueryAccountResponse ) | Account queries an Ethereum account. | GET|/ethermint/evm/v1/account/{address}|
| `CosmosAccount` | [QueryCosmosAccountRequest ](#ethermint.evm.v1.QueryCosmosAccountRequest ) | [QueryCosmosAccountResponse ](#ethermint.evm.v1.QueryCosmosAccountResponse ) | CosmosAccount queries an Ethereum account's Cosmos Address. | GET|/ethermint/evm/v1/cosmos_account/{address}|
| `ValidatorAccount` | [QueryValidatorAccountRequest ](#ethermint.evm.v1.QueryValidatorAccountRequest ) | [QueryValidatorAccountResponse ](#ethermint.evm.v1.QueryValidatorAccountResponse ) | ValidatorAccount queries an Ethereum account's from a validator consensus Address. | GET|/ethermint/evm/v1/validator_account/{cons_address}|
| `Balance` | [QueryBalanceRequest ](#ethermint.evm.v1.QueryBalanceRequest ) | [QueryBalanceResponse ](#ethermint.evm.v1.QueryBalanceResponse ) | Balance queries the balance of a the EVM denomination for a single EthAccount. | GET|/ethermint/evm/v1/balances/{address}|
| `Storage` | [QueryStorageRequest ](#ethermint.evm.v1.QueryStorageRequest ) | [QueryStorageResponse ](#ethermint.evm.v1.QueryStorageResponse ) | Storage queries the balance of all coins for a single account. | GET|/ethermint/evm/v1/storage/{address}/{key}|
| `Code` | [QueryCodeRequest ](#ethermint.evm.v1.QueryCodeRequest ) | [QueryCodeResponse ](#ethermint.evm.v1.QueryCodeResponse ) | Code queries the balance of all coins for a single account. | GET|/ethermint/evm/v1/codes/{address}|
| `Params` | [QueryParamsRequest ](#ethermint.evm.v1.QueryParamsRequest ) | [QueryParamsResponse ](#ethermint.evm.v1.QueryParamsResponse ) | Params queries the parameters of x/evm module. | GET|/ethermint/evm/v1/params|
| `EthCall` | [EthCallRequest ](#ethermint.evm.v1.EthCallRequest ) | [MsgEthereumTxResponse ](#ethermint.evm.v1.MsgEthereumTxResponse ) | EthCall implements the `eth_call` rpc api | GET|/ethermint/evm/v1/eth_call|
| `EstimateGas` | [EthCallRequest ](#ethermint.evm.v1.EthCallRequest ) | [EstimateGasResponse ](#ethermint.evm.v1.EstimateGasResponse ) | EstimateGas implements the `eth_estimateGas` rpc api | GET|/ethermint/evm/v1/estimate_gas|
2021-09-04 20:33:06 +00:00
| `TraceTx` | [QueryTraceTxRequest ](#ethermint.evm.v1.QueryTraceTxRequest ) | [QueryTraceTxResponse ](#ethermint.evm.v1.QueryTraceTxResponse ) | TraceTx implements the `debug_traceTransaction` rpc api | GET|/ethermint/evm/v1/trace_tx|
2021-04-17 10:00:07 +00:00
<!-- end services -->
2021-08-26 10:08:11 +00:00
< a name = "ethermint/feemarket/v1/feemarket.proto" > < / a >
< p align = "right" > < a href = "#top" > Top< / a > < / p >
## ethermint/feemarket/v1/feemarket.proto
< a name = "ethermint.feemarket.v1.Params" > < / a >
### Params
Params defines the EVM module parameters
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
| `no_base_fee` | [bool ](#bool ) | | no base fee forces the EIP-1559 base fee to 0 (needed for 0 price calls) |
| `base_fee_change_denominator` | [uint32 ](#uint32 ) | | base fee change denominator bounds the amount the base fee can change between blocks. |
| `elasticity_multiplier` | [uint32 ](#uint32 ) | | elasticity multiplier bounds the maximum gas limit an EIP-1559 block may have. |
| `initial_base_fee` | [int64 ](#int64 ) | | initial base fee for EIP-1559 blocks. |
| `enable_height` | [int64 ](#int64 ) | | height at which the base fee calculation is enabled. |
<!-- end messages -->
<!-- end enums -->
<!-- end HasExtensions -->
<!-- end services -->
< a name = "ethermint/feemarket/v1/genesis.proto" > < / a >
< p align = "right" > < a href = "#top" > Top< / a > < / p >
## ethermint/feemarket/v1/genesis.proto
< a name = "ethermint.feemarket.v1.GenesisState" > < / a >
### GenesisState
GenesisState defines the feemarket module's genesis state.
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
| `params` | [Params ](#ethermint.feemarket.v1.Params ) | | params defines all the paramaters of the module. |
| `base_fee` | [string ](#string ) | | base fee is the exported value from previous software version. Zero by default. |
| `block_gas` | [uint64 ](#uint64 ) | | block gas is the amount of gas used on the last block before the upgrade. Zero by default. |
<!-- end messages -->
<!-- end enums -->
<!-- end HasExtensions -->
<!-- end services -->
< a name = "ethermint/feemarket/v1/query.proto" > < / a >
< p align = "right" > < a href = "#top" > Top< / a > < / p >
## ethermint/feemarket/v1/query.proto
< a name = "ethermint.feemarket.v1.QueryBaseFeeRequest" > < / a >
### QueryBaseFeeRequest
QueryBaseFeeRequest defines the request type for querying the EIP1559 base
fee.
< a name = "ethermint.feemarket.v1.QueryBaseFeeResponse" > < / a >
### QueryBaseFeeResponse
BaseFeeResponse returns the EIP1559 base fee.
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
| `base_fee` | [string ](#string ) | | |
< a name = "ethermint.feemarket.v1.QueryBlockGasRequest" > < / a >
### QueryBlockGasRequest
QueryBlockGasRequest defines the request type for querying the EIP1559 base
fee.
< a name = "ethermint.feemarket.v1.QueryBlockGasResponse" > < / a >
### QueryBlockGasResponse
QueryBlockGasResponse returns block gas used for a given height.
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
| `gas` | [int64 ](#int64 ) | | |
< a name = "ethermint.feemarket.v1.QueryParamsRequest" > < / a >
### QueryParamsRequest
QueryParamsRequest defines the request type for querying x/evm parameters.
< a name = "ethermint.feemarket.v1.QueryParamsResponse" > < / a >
### QueryParamsResponse
QueryParamsResponse defines the response type for querying x/evm parameters.
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
| `params` | [Params ](#ethermint.feemarket.v1.Params ) | | params define the evm module parameters. |
<!-- end messages -->
<!-- end enums -->
<!-- end HasExtensions -->
< a name = "ethermint.feemarket.v1.Query" > < / a >
### Query
Query defines the gRPC querier service.
| Method Name | Request Type | Response Type | Description | HTTP Verb | Endpoint |
| ----------- | ------------ | ------------- | ------------| ------- | -------- |
| `Params` | [QueryParamsRequest ](#ethermint.feemarket.v1.QueryParamsRequest ) | [QueryParamsResponse ](#ethermint.feemarket.v1.QueryParamsResponse ) | Params queries the parameters of x/feemarket module. | GET|/feemarket/evm/v1/params|
| `BaseFee` | [QueryBaseFeeRequest ](#ethermint.feemarket.v1.QueryBaseFeeRequest ) | [QueryBaseFeeResponse ](#ethermint.feemarket.v1.QueryBaseFeeResponse ) | BaseFee queries the base fee of the parent block of the current block. | GET|/feemarket/evm/v1/base_fee|
| `BlockGas` | [QueryBlockGasRequest ](#ethermint.feemarket.v1.QueryBlockGasRequest ) | [QueryBlockGasResponse ](#ethermint.feemarket.v1.QueryBlockGasResponse ) | BlockGas queries the gas used at a given block height | GET|/feemarket/evm/v1/block_gas|
<!-- end services -->
2021-08-17 15:30:35 +00:00
< a name = "ethermint/types/v1/account.proto" > < / a >
2021-04-17 10:00:07 +00:00
< p align = "right" > < a href = "#top" > Top< / a > < / p >
2021-08-17 15:30:35 +00:00
## ethermint/types/v1/account.proto
2021-04-17 10:00:07 +00:00
2021-08-17 15:30:35 +00:00
< a name = "ethermint.types.v1.EthAccount" > < / a >
2021-04-17 10:00:07 +00:00
### EthAccount
EthAccount implements the authtypes.AccountI interface and embeds an
authtypes.BaseAccount type. It is compatible with the auth AccountKeeper.
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
| `base_account` | [cosmos.auth.v1beta1.BaseAccount ](#cosmos.auth.v1beta1.BaseAccount ) | | |
2021-06-29 17:02:21 +00:00
| `code_hash` | [string ](#string ) | | |
2021-04-17 10:00:07 +00:00
2021-08-17 15:30:35 +00:00
<!-- end messages -->
<!-- end enums -->
<!-- end HasExtensions -->
<!-- end services -->
2021-08-25 14:45:51 +00:00
< a name = "ethermint/types/v1/web3.proto" > < / a >
2021-08-17 15:30:35 +00:00
< p align = "right" > < a href = "#top" > Top< / a > < / p >
2021-08-25 14:45:51 +00:00
## ethermint/types/v1/web3.proto
2021-08-17 15:30:35 +00:00
< a name = "ethermint.types.v1.ExtensionOptionsWeb3Tx" > < / a >
### ExtensionOptionsWeb3Tx
| Field | Type | Label | Description |
| ----- | ---- | ----- | ----------- |
2021-08-25 14:45:51 +00:00
| `typed_data_chain_id` | [uint64 ](#uint64 ) | | typed data chain id used only in EIP712 Domain and should match Ethereum network ID in a Web3 provider (e.g. Metamask). |
| `fee_payer` | [string ](#string ) | | fee payer is an account address for the fee payer. It will be validated during EIP712 signature checking. |
| `fee_payer_sig` | [bytes ](#bytes ) | | fee payer sig is a signature data from the fee paying account, allows to perform fee delegation when using EIP712 Domain. |
2021-08-17 15:30:35 +00:00
2021-04-17 10:00:07 +00:00
<!-- end messages -->
<!-- end enums -->
<!-- end HasExtensions -->
<!-- end services -->
## Scalar Value Types
| .proto Type | Notes | C++ | Java | Python | Go | C# | PHP | Ruby |
| ----------- | ----- | --- | ---- | ------ | -- | -- | --- | ---- |
| < a name = "double" / > double | | double | double | float | float64 | double | float | Float |
| < a name = "float" / > float | | float | float | float | float32 | float | float | Float |
| < a name = "int32" / > int32 | Uses variable-length encoding. Inefficient for encoding negative numbers – if your field is likely to have negative values, use sint32 instead. | int32 | int | int | int32 | int | integer | Bignum or Fixnum (as required) |
| < a name = "int64" / > int64 | Uses variable-length encoding. Inefficient for encoding negative numbers – if your field is likely to have negative values, use sint64 instead. | int64 | long | int/long | int64 | long | integer/string | Bignum |
| < a name = "uint32" / > uint32 | Uses variable-length encoding. | uint32 | int | int/long | uint32 | uint | integer | Bignum or Fixnum (as required) |
| < a name = "uint64" / > uint64 | Uses variable-length encoding. | uint64 | long | int/long | uint64 | ulong | integer/string | Bignum or Fixnum (as required) |
| < a name = "sint32" / > sint32 | Uses variable-length encoding. Signed int value. These more efficiently encode negative numbers than regular int32s. | int32 | int | int | int32 | int | integer | Bignum or Fixnum (as required) |
| < a name = "sint64" / > sint64 | Uses variable-length encoding. Signed int value. These more efficiently encode negative numbers than regular int64s. | int64 | long | int/long | int64 | long | integer/string | Bignum |
| < a name = "fixed32" / > fixed32 | Always four bytes. More efficient than uint32 if values are often greater than 2^28. | uint32 | int | int | uint32 | uint | integer | Bignum or Fixnum (as required) |
| < a name = "fixed64" / > fixed64 | Always eight bytes. More efficient than uint64 if values are often greater than 2^56. | uint64 | long | int/long | uint64 | ulong | integer/string | Bignum |
| < a name = "sfixed32" / > sfixed32 | Always four bytes. | int32 | int | int | int32 | int | integer | Bignum or Fixnum (as required) |
| < a name = "sfixed64" / > sfixed64 | Always eight bytes. | int64 | long | int/long | int64 | long | integer/string | Bignum |
| < a name = "bool" / > bool | | bool | boolean | boolean | bool | bool | boolean | TrueClass/FalseClass |
| < a name = "string" / > string | A string must always contain UTF-8 encoded or 7-bit ASCII text. | string | String | str/unicode | string | string | string | String (UTF-8) |
| < a name = "bytes" / > bytes | May contain any arbitrary sequence of bytes. | string | ByteString | str | []byte | ByteString | string | String (ASCII-8BIT) |