#[derive(Clone, PartialEq, ::prost::Message)]
pub struct Request {
#[prost(
oneof = "request::Value",
tags = "1, 2, 3, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17"
)]
pub value: ::core::option::Option<request::Value>,
}
pub mod request {
#[derive(Clone, PartialEq, ::prost::Oneof)]
pub enum Value {
#[prost(message, tag = "1")]
Echo(super::RequestEcho),
#[prost(message, tag = "2")]
Flush(super::RequestFlush),
#[prost(message, tag = "3")]
Info(super::RequestInfo),
#[prost(message, tag = "5")]
InitChain(super::RequestInitChain),
#[prost(message, tag = "6")]
Query(super::RequestQuery),
#[prost(message, tag = "7")]
BeginBlock(super::RequestBeginBlock),
#[prost(message, tag = "8")]
CheckTx(super::RequestCheckTx),
#[prost(message, tag = "9")]
DeliverTx(super::RequestDeliverTx),
#[prost(message, tag = "10")]
EndBlock(super::RequestEndBlock),
#[prost(message, tag = "11")]
Commit(super::RequestCommit),
#[prost(message, tag = "12")]
ListSnapshots(super::RequestListSnapshots),
#[prost(message, tag = "13")]
OfferSnapshot(super::RequestOfferSnapshot),
#[prost(message, tag = "14")]
LoadSnapshotChunk(super::RequestLoadSnapshotChunk),
#[prost(message, tag = "15")]
ApplySnapshotChunk(super::RequestApplySnapshotChunk),
#[prost(message, tag = "16")]
PrepareProposal(super::RequestPrepareProposal),
#[prost(message, tag = "17")]
ProcessProposal(super::RequestProcessProposal),
}
}
impl ::prost::Name for Request {
const NAME: &'static str = "Request";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.Request".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.Request".into()
}
}
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct RequestEcho {
#[prost(string, tag = "1")]
pub message: ::prost::alloc::string::String,
}
impl ::prost::Name for RequestEcho {
const NAME: &'static str = "RequestEcho";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.RequestEcho".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.RequestEcho".into()
}
}
#[derive(Clone, Copy, PartialEq, ::prost::Message)]
pub struct RequestFlush {}
impl ::prost::Name for RequestFlush {
const NAME: &'static str = "RequestFlush";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.RequestFlush".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.RequestFlush".into()
}
}
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct RequestInfo {
#[prost(string, tag = "1")]
pub version: ::prost::alloc::string::String,
#[prost(uint64, tag = "2")]
pub block_version: u64,
#[prost(uint64, tag = "3")]
pub p2p_version: u64,
#[prost(string, tag = "4")]
pub abci_version: ::prost::alloc::string::String,
}
impl ::prost::Name for RequestInfo {
const NAME: &'static str = "RequestInfo";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.RequestInfo".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.RequestInfo".into()
}
}
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct RequestInitChain {
#[prost(message, optional, tag = "1")]
pub time: ::core::option::Option<::pbjson_types::Timestamp>,
#[prost(string, tag = "2")]
pub chain_id: ::prost::alloc::string::String,
#[prost(message, optional, tag = "3")]
pub consensus_params: ::core::option::Option<super::types::ConsensusParams>,
#[prost(message, repeated, tag = "4")]
pub validators: ::prost::alloc::vec::Vec<ValidatorUpdate>,
#[prost(bytes = "vec", tag = "5")]
pub app_state_bytes: ::prost::alloc::vec::Vec<u8>,
#[prost(int64, tag = "6")]
pub initial_height: i64,
}
impl ::prost::Name for RequestInitChain {
const NAME: &'static str = "RequestInitChain";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.RequestInitChain".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.RequestInitChain".into()
}
}
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct RequestQuery {
#[prost(bytes = "vec", tag = "1")]
pub data: ::prost::alloc::vec::Vec<u8>,
#[prost(string, tag = "2")]
pub path: ::prost::alloc::string::String,
#[prost(int64, tag = "3")]
pub height: i64,
#[prost(bool, tag = "4")]
pub prove: bool,
}
impl ::prost::Name for RequestQuery {
const NAME: &'static str = "RequestQuery";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.RequestQuery".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.RequestQuery".into()
}
}
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct RequestBeginBlock {
#[prost(bytes = "vec", tag = "1")]
pub hash: ::prost::alloc::vec::Vec<u8>,
#[prost(message, optional, tag = "2")]
pub header: ::core::option::Option<super::types::Header>,
#[prost(message, optional, tag = "3")]
pub last_commit_info: ::core::option::Option<CommitInfo>,
#[prost(message, repeated, tag = "4")]
pub byzantine_validators: ::prost::alloc::vec::Vec<Misbehavior>,
}
impl ::prost::Name for RequestBeginBlock {
const NAME: &'static str = "RequestBeginBlock";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.RequestBeginBlock".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.RequestBeginBlock".into()
}
}
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct RequestCheckTx {
#[prost(bytes = "vec", tag = "1")]
pub tx: ::prost::alloc::vec::Vec<u8>,
#[prost(enumeration = "CheckTxType", tag = "2")]
pub r#type: i32,
}
impl ::prost::Name for RequestCheckTx {
const NAME: &'static str = "RequestCheckTx";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.RequestCheckTx".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.RequestCheckTx".into()
}
}
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct RequestDeliverTx {
#[prost(bytes = "vec", tag = "1")]
pub tx: ::prost::alloc::vec::Vec<u8>,
}
impl ::prost::Name for RequestDeliverTx {
const NAME: &'static str = "RequestDeliverTx";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.RequestDeliverTx".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.RequestDeliverTx".into()
}
}
#[derive(Clone, Copy, PartialEq, ::prost::Message)]
pub struct RequestEndBlock {
#[prost(int64, tag = "1")]
pub height: i64,
}
impl ::prost::Name for RequestEndBlock {
const NAME: &'static str = "RequestEndBlock";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.RequestEndBlock".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.RequestEndBlock".into()
}
}
#[derive(Clone, Copy, PartialEq, ::prost::Message)]
pub struct RequestCommit {}
impl ::prost::Name for RequestCommit {
const NAME: &'static str = "RequestCommit";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.RequestCommit".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.RequestCommit".into()
}
}
#[derive(Clone, Copy, PartialEq, ::prost::Message)]
pub struct RequestListSnapshots {}
impl ::prost::Name for RequestListSnapshots {
const NAME: &'static str = "RequestListSnapshots";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.RequestListSnapshots".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.RequestListSnapshots".into()
}
}
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct RequestOfferSnapshot {
#[prost(message, optional, tag = "1")]
pub snapshot: ::core::option::Option<Snapshot>,
#[prost(bytes = "vec", tag = "2")]
pub app_hash: ::prost::alloc::vec::Vec<u8>,
}
impl ::prost::Name for RequestOfferSnapshot {
const NAME: &'static str = "RequestOfferSnapshot";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.RequestOfferSnapshot".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.RequestOfferSnapshot".into()
}
}
#[derive(Clone, Copy, PartialEq, ::prost::Message)]
pub struct RequestLoadSnapshotChunk {
#[prost(uint64, tag = "1")]
pub height: u64,
#[prost(uint32, tag = "2")]
pub format: u32,
#[prost(uint32, tag = "3")]
pub chunk: u32,
}
impl ::prost::Name for RequestLoadSnapshotChunk {
const NAME: &'static str = "RequestLoadSnapshotChunk";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.RequestLoadSnapshotChunk".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.RequestLoadSnapshotChunk".into()
}
}
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct RequestApplySnapshotChunk {
#[prost(uint32, tag = "1")]
pub index: u32,
#[prost(bytes = "vec", tag = "2")]
pub chunk: ::prost::alloc::vec::Vec<u8>,
#[prost(string, tag = "3")]
pub sender: ::prost::alloc::string::String,
}
impl ::prost::Name for RequestApplySnapshotChunk {
const NAME: &'static str = "RequestApplySnapshotChunk";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.RequestApplySnapshotChunk".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.RequestApplySnapshotChunk".into()
}
}
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct RequestPrepareProposal {
#[prost(int64, tag = "1")]
pub max_tx_bytes: i64,
#[prost(bytes = "vec", repeated, tag = "2")]
pub txs: ::prost::alloc::vec::Vec<::prost::alloc::vec::Vec<u8>>,
#[prost(message, optional, tag = "3")]
pub local_last_commit: ::core::option::Option<ExtendedCommitInfo>,
#[prost(message, repeated, tag = "4")]
pub misbehavior: ::prost::alloc::vec::Vec<Misbehavior>,
#[prost(int64, tag = "5")]
pub height: i64,
#[prost(message, optional, tag = "6")]
pub time: ::core::option::Option<::pbjson_types::Timestamp>,
#[prost(bytes = "vec", tag = "7")]
pub next_validators_hash: ::prost::alloc::vec::Vec<u8>,
#[prost(bytes = "vec", tag = "8")]
pub proposer_address: ::prost::alloc::vec::Vec<u8>,
}
impl ::prost::Name for RequestPrepareProposal {
const NAME: &'static str = "RequestPrepareProposal";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.RequestPrepareProposal".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.RequestPrepareProposal".into()
}
}
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct RequestProcessProposal {
#[prost(bytes = "vec", repeated, tag = "1")]
pub txs: ::prost::alloc::vec::Vec<::prost::alloc::vec::Vec<u8>>,
#[prost(message, optional, tag = "2")]
pub proposed_last_commit: ::core::option::Option<CommitInfo>,
#[prost(message, repeated, tag = "3")]
pub misbehavior: ::prost::alloc::vec::Vec<Misbehavior>,
#[prost(bytes = "vec", tag = "4")]
pub hash: ::prost::alloc::vec::Vec<u8>,
#[prost(int64, tag = "5")]
pub height: i64,
#[prost(message, optional, tag = "6")]
pub time: ::core::option::Option<::pbjson_types::Timestamp>,
#[prost(bytes = "vec", tag = "7")]
pub next_validators_hash: ::prost::alloc::vec::Vec<u8>,
#[prost(bytes = "vec", tag = "8")]
pub proposer_address: ::prost::alloc::vec::Vec<u8>,
}
impl ::prost::Name for RequestProcessProposal {
const NAME: &'static str = "RequestProcessProposal";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.RequestProcessProposal".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.RequestProcessProposal".into()
}
}
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct Response {
#[prost(
oneof = "response::Value",
tags = "1, 2, 3, 4, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18"
)]
pub value: ::core::option::Option<response::Value>,
}
pub mod response {
#[derive(Clone, PartialEq, ::prost::Oneof)]
pub enum Value {
#[prost(message, tag = "1")]
Exception(super::ResponseException),
#[prost(message, tag = "2")]
Echo(super::ResponseEcho),
#[prost(message, tag = "3")]
Flush(super::ResponseFlush),
#[prost(message, tag = "4")]
Info(super::ResponseInfo),
#[prost(message, tag = "6")]
InitChain(super::ResponseInitChain),
#[prost(message, tag = "7")]
Query(super::ResponseQuery),
#[prost(message, tag = "8")]
BeginBlock(super::ResponseBeginBlock),
#[prost(message, tag = "9")]
CheckTx(super::ResponseCheckTx),
#[prost(message, tag = "10")]
DeliverTx(super::ResponseDeliverTx),
#[prost(message, tag = "11")]
EndBlock(super::ResponseEndBlock),
#[prost(message, tag = "12")]
Commit(super::ResponseCommit),
#[prost(message, tag = "13")]
ListSnapshots(super::ResponseListSnapshots),
#[prost(message, tag = "14")]
OfferSnapshot(super::ResponseOfferSnapshot),
#[prost(message, tag = "15")]
LoadSnapshotChunk(super::ResponseLoadSnapshotChunk),
#[prost(message, tag = "16")]
ApplySnapshotChunk(super::ResponseApplySnapshotChunk),
#[prost(message, tag = "17")]
PrepareProposal(super::ResponsePrepareProposal),
#[prost(message, tag = "18")]
ProcessProposal(super::ResponseProcessProposal),
}
}
impl ::prost::Name for Response {
const NAME: &'static str = "Response";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.Response".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.Response".into()
}
}
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct ResponseException {
#[prost(string, tag = "1")]
pub error: ::prost::alloc::string::String,
}
impl ::prost::Name for ResponseException {
const NAME: &'static str = "ResponseException";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.ResponseException".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.ResponseException".into()
}
}
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct ResponseEcho {
#[prost(string, tag = "1")]
pub message: ::prost::alloc::string::String,
}
impl ::prost::Name for ResponseEcho {
const NAME: &'static str = "ResponseEcho";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.ResponseEcho".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.ResponseEcho".into()
}
}
#[derive(Clone, Copy, PartialEq, ::prost::Message)]
pub struct ResponseFlush {}
impl ::prost::Name for ResponseFlush {
const NAME: &'static str = "ResponseFlush";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.ResponseFlush".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.ResponseFlush".into()
}
}
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct ResponseInfo {
#[prost(string, tag = "1")]
pub data: ::prost::alloc::string::String,
#[prost(string, tag = "2")]
pub version: ::prost::alloc::string::String,
#[prost(uint64, tag = "3")]
pub app_version: u64,
#[prost(int64, tag = "4")]
pub last_block_height: i64,
#[prost(bytes = "vec", tag = "5")]
pub last_block_app_hash: ::prost::alloc::vec::Vec<u8>,
}
impl ::prost::Name for ResponseInfo {
const NAME: &'static str = "ResponseInfo";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.ResponseInfo".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.ResponseInfo".into()
}
}
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct ResponseInitChain {
#[prost(message, optional, tag = "1")]
pub consensus_params: ::core::option::Option<super::types::ConsensusParams>,
#[prost(message, repeated, tag = "2")]
pub validators: ::prost::alloc::vec::Vec<ValidatorUpdate>,
#[prost(bytes = "vec", tag = "3")]
pub app_hash: ::prost::alloc::vec::Vec<u8>,
}
impl ::prost::Name for ResponseInitChain {
const NAME: &'static str = "ResponseInitChain";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.ResponseInitChain".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.ResponseInitChain".into()
}
}
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct ResponseQuery {
#[prost(uint32, tag = "1")]
pub code: u32,
#[prost(string, tag = "3")]
pub log: ::prost::alloc::string::String,
#[prost(string, tag = "4")]
pub info: ::prost::alloc::string::String,
#[prost(int64, tag = "5")]
pub index: i64,
#[prost(bytes = "vec", tag = "6")]
pub key: ::prost::alloc::vec::Vec<u8>,
#[prost(bytes = "vec", tag = "7")]
pub value: ::prost::alloc::vec::Vec<u8>,
#[prost(message, optional, tag = "8")]
pub proof_ops: ::core::option::Option<super::crypto::ProofOps>,
#[prost(int64, tag = "9")]
pub height: i64,
#[prost(string, tag = "10")]
pub codespace: ::prost::alloc::string::String,
}
impl ::prost::Name for ResponseQuery {
const NAME: &'static str = "ResponseQuery";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.ResponseQuery".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.ResponseQuery".into()
}
}
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct ResponseBeginBlock {
#[prost(message, repeated, tag = "1")]
pub events: ::prost::alloc::vec::Vec<Event>,
}
impl ::prost::Name for ResponseBeginBlock {
const NAME: &'static str = "ResponseBeginBlock";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.ResponseBeginBlock".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.ResponseBeginBlock".into()
}
}
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct ResponseCheckTx {
#[prost(uint32, tag = "1")]
pub code: u32,
#[prost(bytes = "vec", tag = "2")]
pub data: ::prost::alloc::vec::Vec<u8>,
#[prost(string, tag = "3")]
pub log: ::prost::alloc::string::String,
#[prost(string, tag = "4")]
pub info: ::prost::alloc::string::String,
#[prost(int64, tag = "5")]
pub gas_wanted: i64,
#[prost(int64, tag = "6")]
pub gas_used: i64,
#[prost(message, repeated, tag = "7")]
pub events: ::prost::alloc::vec::Vec<Event>,
#[prost(string, tag = "8")]
pub codespace: ::prost::alloc::string::String,
#[prost(string, tag = "9")]
pub sender: ::prost::alloc::string::String,
#[prost(int64, tag = "10")]
pub priority: i64,
#[prost(string, tag = "11")]
pub mempool_error: ::prost::alloc::string::String,
}
impl ::prost::Name for ResponseCheckTx {
const NAME: &'static str = "ResponseCheckTx";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.ResponseCheckTx".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.ResponseCheckTx".into()
}
}
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct ResponseDeliverTx {
#[prost(uint32, tag = "1")]
pub code: u32,
#[prost(bytes = "vec", tag = "2")]
pub data: ::prost::alloc::vec::Vec<u8>,
#[prost(string, tag = "3")]
pub log: ::prost::alloc::string::String,
#[prost(string, tag = "4")]
pub info: ::prost::alloc::string::String,
#[prost(int64, tag = "5")]
pub gas_wanted: i64,
#[prost(int64, tag = "6")]
pub gas_used: i64,
#[prost(message, repeated, tag = "7")]
pub events: ::prost::alloc::vec::Vec<Event>,
#[prost(string, tag = "8")]
pub codespace: ::prost::alloc::string::String,
}
impl ::prost::Name for ResponseDeliverTx {
const NAME: &'static str = "ResponseDeliverTx";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.ResponseDeliverTx".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.ResponseDeliverTx".into()
}
}
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct ResponseEndBlock {
#[prost(message, repeated, tag = "1")]
pub validator_updates: ::prost::alloc::vec::Vec<ValidatorUpdate>,
#[prost(message, optional, tag = "2")]
pub consensus_param_updates: ::core::option::Option<super::types::ConsensusParams>,
#[prost(message, repeated, tag = "3")]
pub events: ::prost::alloc::vec::Vec<Event>,
}
impl ::prost::Name for ResponseEndBlock {
const NAME: &'static str = "ResponseEndBlock";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.ResponseEndBlock".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.ResponseEndBlock".into()
}
}
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct ResponseCommit {
#[prost(bytes = "vec", tag = "2")]
pub data: ::prost::alloc::vec::Vec<u8>,
#[prost(int64, tag = "3")]
pub retain_height: i64,
}
impl ::prost::Name for ResponseCommit {
const NAME: &'static str = "ResponseCommit";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.ResponseCommit".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.ResponseCommit".into()
}
}
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct ResponseListSnapshots {
#[prost(message, repeated, tag = "1")]
pub snapshots: ::prost::alloc::vec::Vec<Snapshot>,
}
impl ::prost::Name for ResponseListSnapshots {
const NAME: &'static str = "ResponseListSnapshots";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.ResponseListSnapshots".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.ResponseListSnapshots".into()
}
}
#[derive(Clone, Copy, PartialEq, ::prost::Message)]
pub struct ResponseOfferSnapshot {
#[prost(enumeration = "response_offer_snapshot::Result", tag = "1")]
pub result: i32,
}
pub mod response_offer_snapshot {
#[derive(
Clone,
Copy,
Debug,
PartialEq,
Eq,
Hash,
PartialOrd,
Ord,
::prost::Enumeration
)]
#[repr(i32)]
pub enum Result {
Unknown = 0,
Accept = 1,
Abort = 2,
Reject = 3,
RejectFormat = 4,
RejectSender = 5,
}
impl Result {
pub fn as_str_name(&self) -> &'static str {
match self {
Self::Unknown => "UNKNOWN",
Self::Accept => "ACCEPT",
Self::Abort => "ABORT",
Self::Reject => "REJECT",
Self::RejectFormat => "REJECT_FORMAT",
Self::RejectSender => "REJECT_SENDER",
}
}
pub fn from_str_name(value: &str) -> ::core::option::Option<Self> {
match value {
"UNKNOWN" => Some(Self::Unknown),
"ACCEPT" => Some(Self::Accept),
"ABORT" => Some(Self::Abort),
"REJECT" => Some(Self::Reject),
"REJECT_FORMAT" => Some(Self::RejectFormat),
"REJECT_SENDER" => Some(Self::RejectSender),
_ => None,
}
}
}
}
impl ::prost::Name for ResponseOfferSnapshot {
const NAME: &'static str = "ResponseOfferSnapshot";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.ResponseOfferSnapshot".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.ResponseOfferSnapshot".into()
}
}
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct ResponseLoadSnapshotChunk {
#[prost(bytes = "vec", tag = "1")]
pub chunk: ::prost::alloc::vec::Vec<u8>,
}
impl ::prost::Name for ResponseLoadSnapshotChunk {
const NAME: &'static str = "ResponseLoadSnapshotChunk";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.ResponseLoadSnapshotChunk".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.ResponseLoadSnapshotChunk".into()
}
}
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct ResponseApplySnapshotChunk {
#[prost(enumeration = "response_apply_snapshot_chunk::Result", tag = "1")]
pub result: i32,
#[prost(uint32, repeated, tag = "2")]
pub refetch_chunks: ::prost::alloc::vec::Vec<u32>,
#[prost(string, repeated, tag = "3")]
pub reject_senders: ::prost::alloc::vec::Vec<::prost::alloc::string::String>,
}
pub mod response_apply_snapshot_chunk {
#[derive(
Clone,
Copy,
Debug,
PartialEq,
Eq,
Hash,
PartialOrd,
Ord,
::prost::Enumeration
)]
#[repr(i32)]
pub enum Result {
Unknown = 0,
Accept = 1,
Abort = 2,
Retry = 3,
RetrySnapshot = 4,
RejectSnapshot = 5,
}
impl Result {
pub fn as_str_name(&self) -> &'static str {
match self {
Self::Unknown => "UNKNOWN",
Self::Accept => "ACCEPT",
Self::Abort => "ABORT",
Self::Retry => "RETRY",
Self::RetrySnapshot => "RETRY_SNAPSHOT",
Self::RejectSnapshot => "REJECT_SNAPSHOT",
}
}
pub fn from_str_name(value: &str) -> ::core::option::Option<Self> {
match value {
"UNKNOWN" => Some(Self::Unknown),
"ACCEPT" => Some(Self::Accept),
"ABORT" => Some(Self::Abort),
"RETRY" => Some(Self::Retry),
"RETRY_SNAPSHOT" => Some(Self::RetrySnapshot),
"REJECT_SNAPSHOT" => Some(Self::RejectSnapshot),
_ => None,
}
}
}
}
impl ::prost::Name for ResponseApplySnapshotChunk {
const NAME: &'static str = "ResponseApplySnapshotChunk";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.ResponseApplySnapshotChunk".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.ResponseApplySnapshotChunk".into()
}
}
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct ResponsePrepareProposal {
#[prost(bytes = "vec", repeated, tag = "1")]
pub txs: ::prost::alloc::vec::Vec<::prost::alloc::vec::Vec<u8>>,
}
impl ::prost::Name for ResponsePrepareProposal {
const NAME: &'static str = "ResponsePrepareProposal";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.ResponsePrepareProposal".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.ResponsePrepareProposal".into()
}
}
#[derive(Clone, Copy, PartialEq, ::prost::Message)]
pub struct ResponseProcessProposal {
#[prost(enumeration = "response_process_proposal::ProposalStatus", tag = "1")]
pub status: i32,
}
pub mod response_process_proposal {
#[derive(
Clone,
Copy,
Debug,
PartialEq,
Eq,
Hash,
PartialOrd,
Ord,
::prost::Enumeration
)]
#[repr(i32)]
pub enum ProposalStatus {
Unknown = 0,
Accept = 1,
Reject = 2,
}
impl ProposalStatus {
pub fn as_str_name(&self) -> &'static str {
match self {
Self::Unknown => "UNKNOWN",
Self::Accept => "ACCEPT",
Self::Reject => "REJECT",
}
}
pub fn from_str_name(value: &str) -> ::core::option::Option<Self> {
match value {
"UNKNOWN" => Some(Self::Unknown),
"ACCEPT" => Some(Self::Accept),
"REJECT" => Some(Self::Reject),
_ => None,
}
}
}
}
impl ::prost::Name for ResponseProcessProposal {
const NAME: &'static str = "ResponseProcessProposal";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.ResponseProcessProposal".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.ResponseProcessProposal".into()
}
}
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct CommitInfo {
#[prost(int32, tag = "1")]
pub round: i32,
#[prost(message, repeated, tag = "2")]
pub votes: ::prost::alloc::vec::Vec<VoteInfo>,
}
impl ::prost::Name for CommitInfo {
const NAME: &'static str = "CommitInfo";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.CommitInfo".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.CommitInfo".into()
}
}
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct ExtendedCommitInfo {
#[prost(int32, tag = "1")]
pub round: i32,
#[prost(message, repeated, tag = "2")]
pub votes: ::prost::alloc::vec::Vec<ExtendedVoteInfo>,
}
impl ::prost::Name for ExtendedCommitInfo {
const NAME: &'static str = "ExtendedCommitInfo";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.ExtendedCommitInfo".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.ExtendedCommitInfo".into()
}
}
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct Event {
#[prost(string, tag = "1")]
pub r#type: ::prost::alloc::string::String,
#[prost(message, repeated, tag = "2")]
pub attributes: ::prost::alloc::vec::Vec<EventAttribute>,
}
impl ::prost::Name for Event {
const NAME: &'static str = "Event";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.Event".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.Event".into()
}
}
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct EventAttribute {
#[prost(string, tag = "1")]
pub key: ::prost::alloc::string::String,
#[prost(string, tag = "2")]
pub value: ::prost::alloc::string::String,
#[prost(bool, tag = "3")]
pub index: bool,
}
impl ::prost::Name for EventAttribute {
const NAME: &'static str = "EventAttribute";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.EventAttribute".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.EventAttribute".into()
}
}
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct TxResult {
#[prost(int64, tag = "1")]
pub height: i64,
#[prost(uint32, tag = "2")]
pub index: u32,
#[prost(bytes = "vec", tag = "3")]
pub tx: ::prost::alloc::vec::Vec<u8>,
#[prost(message, optional, tag = "4")]
pub result: ::core::option::Option<ResponseDeliverTx>,
}
impl ::prost::Name for TxResult {
const NAME: &'static str = "TxResult";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.TxResult".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.TxResult".into()
}
}
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct Validator {
#[prost(bytes = "vec", tag = "1")]
pub address: ::prost::alloc::vec::Vec<u8>,
#[prost(int64, tag = "3")]
pub power: i64,
}
impl ::prost::Name for Validator {
const NAME: &'static str = "Validator";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.Validator".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.Validator".into()
}
}
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct ValidatorUpdate {
#[prost(message, optional, tag = "1")]
pub pub_key: ::core::option::Option<super::crypto::PublicKey>,
#[prost(int64, tag = "2")]
pub power: i64,
}
impl ::prost::Name for ValidatorUpdate {
const NAME: &'static str = "ValidatorUpdate";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.ValidatorUpdate".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.ValidatorUpdate".into()
}
}
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct VoteInfo {
#[prost(message, optional, tag = "1")]
pub validator: ::core::option::Option<Validator>,
#[prost(bool, tag = "2")]
pub signed_last_block: bool,
}
impl ::prost::Name for VoteInfo {
const NAME: &'static str = "VoteInfo";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.VoteInfo".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.VoteInfo".into()
}
}
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct ExtendedVoteInfo {
#[prost(message, optional, tag = "1")]
pub validator: ::core::option::Option<Validator>,
#[prost(bool, tag = "2")]
pub signed_last_block: bool,
#[prost(bytes = "vec", tag = "3")]
pub vote_extension: ::prost::alloc::vec::Vec<u8>,
}
impl ::prost::Name for ExtendedVoteInfo {
const NAME: &'static str = "ExtendedVoteInfo";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.ExtendedVoteInfo".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.ExtendedVoteInfo".into()
}
}
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct Misbehavior {
#[prost(enumeration = "MisbehaviorType", tag = "1")]
pub r#type: i32,
#[prost(message, optional, tag = "2")]
pub validator: ::core::option::Option<Validator>,
#[prost(int64, tag = "3")]
pub height: i64,
#[prost(message, optional, tag = "4")]
pub time: ::core::option::Option<::pbjson_types::Timestamp>,
#[prost(int64, tag = "5")]
pub total_voting_power: i64,
}
impl ::prost::Name for Misbehavior {
const NAME: &'static str = "Misbehavior";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.Misbehavior".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.Misbehavior".into()
}
}
#[derive(Clone, PartialEq, ::prost::Message)]
pub struct Snapshot {
#[prost(uint64, tag = "1")]
pub height: u64,
#[prost(uint32, tag = "2")]
pub format: u32,
#[prost(uint32, tag = "3")]
pub chunks: u32,
#[prost(bytes = "vec", tag = "4")]
pub hash: ::prost::alloc::vec::Vec<u8>,
#[prost(bytes = "vec", tag = "5")]
pub metadata: ::prost::alloc::vec::Vec<u8>,
}
impl ::prost::Name for Snapshot {
const NAME: &'static str = "Snapshot";
const PACKAGE: &'static str = "tendermint.abci";
fn full_name() -> ::prost::alloc::string::String {
"tendermint.abci.Snapshot".into()
}
fn type_url() -> ::prost::alloc::string::String {
"/tendermint.abci.Snapshot".into()
}
}
#[derive(Clone, Copy, Debug, PartialEq, Eq, Hash, PartialOrd, Ord, ::prost::Enumeration)]
#[repr(i32)]
pub enum CheckTxType {
New = 0,
Recheck = 1,
}
impl CheckTxType {
pub fn as_str_name(&self) -> &'static str {
match self {
Self::New => "NEW",
Self::Recheck => "RECHECK",
}
}
pub fn from_str_name(value: &str) -> ::core::option::Option<Self> {
match value {
"NEW" => Some(Self::New),
"RECHECK" => Some(Self::Recheck),
_ => None,
}
}
}
#[derive(Clone, Copy, Debug, PartialEq, Eq, Hash, PartialOrd, Ord, ::prost::Enumeration)]
#[repr(i32)]
pub enum MisbehaviorType {
Unknown = 0,
DuplicateVote = 1,
LightClientAttack = 2,
}
impl MisbehaviorType {
pub fn as_str_name(&self) -> &'static str {
match self {
Self::Unknown => "UNKNOWN",
Self::DuplicateVote => "DUPLICATE_VOTE",
Self::LightClientAttack => "LIGHT_CLIENT_ATTACK",
}
}
pub fn from_str_name(value: &str) -> ::core::option::Option<Self> {
match value {
"UNKNOWN" => Some(Self::Unknown),
"DUPLICATE_VOTE" => Some(Self::DuplicateVote),
"LIGHT_CLIENT_ATTACK" => Some(Self::LightClientAttack),
_ => None,
}
}
}
#[cfg(feature = "rpc")]
pub mod abci_application_client {
#![allow(
unused_variables,
dead_code,
missing_docs,
clippy::wildcard_imports,
clippy::let_unit_value,
)]
use tonic::codegen::*;
use tonic::codegen::http::Uri;
#[derive(Debug, Clone)]
pub struct AbciApplicationClient<T> {
inner: tonic::client::Grpc<T>,
}
impl AbciApplicationClient<tonic::transport::Channel> {
pub async fn connect<D>(dst: D) -> Result<Self, tonic::transport::Error>
where
D: TryInto<tonic::transport::Endpoint>,
D::Error: Into<StdError>,
{
let conn = tonic::transport::Endpoint::new(dst)?.connect().await?;
Ok(Self::new(conn))
}
}
impl<T> AbciApplicationClient<T>
where
T: tonic::client::GrpcService<tonic::body::BoxBody>,
T::Error: Into<StdError>,
T::ResponseBody: Body<Data = Bytes> + std::marker::Send + 'static,
<T::ResponseBody as Body>::Error: Into<StdError> + std::marker::Send,
{
pub fn new(inner: T) -> Self {
let inner = tonic::client::Grpc::new(inner);
Self { inner }
}
pub fn with_origin(inner: T, origin: Uri) -> Self {
let inner = tonic::client::Grpc::with_origin(inner, origin);
Self { inner }
}
pub fn with_interceptor<F>(
inner: T,
interceptor: F,
) -> AbciApplicationClient<InterceptedService<T, F>>
where
F: tonic::service::Interceptor,
T::ResponseBody: Default,
T: tonic::codegen::Service<
http::Request<tonic::body::BoxBody>,
Response = http::Response<
<T as tonic::client::GrpcService<tonic::body::BoxBody>>::ResponseBody,
>,
>,
<T as tonic::codegen::Service<
http::Request<tonic::body::BoxBody>,
>>::Error: Into<StdError> + std::marker::Send + std::marker::Sync,
{
AbciApplicationClient::new(InterceptedService::new(inner, interceptor))
}
#[must_use]
pub fn send_compressed(mut self, encoding: CompressionEncoding) -> Self {
self.inner = self.inner.send_compressed(encoding);
self
}
#[must_use]
pub fn accept_compressed(mut self, encoding: CompressionEncoding) -> Self {
self.inner = self.inner.accept_compressed(encoding);
self
}
#[must_use]
pub fn max_decoding_message_size(mut self, limit: usize) -> Self {
self.inner = self.inner.max_decoding_message_size(limit);
self
}
#[must_use]
pub fn max_encoding_message_size(mut self, limit: usize) -> Self {
self.inner = self.inner.max_encoding_message_size(limit);
self
}
pub async fn echo(
&mut self,
request: impl tonic::IntoRequest<super::RequestEcho>,
) -> std::result::Result<tonic::Response<super::ResponseEcho>, tonic::Status> {
self.inner
.ready()
.await
.map_err(|e| {
tonic::Status::unknown(
format!("Service was not ready: {}", e.into()),
)
})?;
let codec = tonic::codec::ProstCodec::default();
let path = http::uri::PathAndQuery::from_static(
"/tendermint.abci.ABCIApplication/Echo",
);
let mut req = request.into_request();
req.extensions_mut()
.insert(GrpcMethod::new("tendermint.abci.ABCIApplication", "Echo"));
self.inner.unary(req, path, codec).await
}
pub async fn flush(
&mut self,
request: impl tonic::IntoRequest<super::RequestFlush>,
) -> std::result::Result<tonic::Response<super::ResponseFlush>, tonic::Status> {
self.inner
.ready()
.await
.map_err(|e| {
tonic::Status::unknown(
format!("Service was not ready: {}", e.into()),
)
})?;
let codec = tonic::codec::ProstCodec::default();
let path = http::uri::PathAndQuery::from_static(
"/tendermint.abci.ABCIApplication/Flush",
);
let mut req = request.into_request();
req.extensions_mut()
.insert(GrpcMethod::new("tendermint.abci.ABCIApplication", "Flush"));
self.inner.unary(req, path, codec).await
}
pub async fn info(
&mut self,
request: impl tonic::IntoRequest<super::RequestInfo>,
) -> std::result::Result<tonic::Response<super::ResponseInfo>, tonic::Status> {
self.inner
.ready()
.await
.map_err(|e| {
tonic::Status::unknown(
format!("Service was not ready: {}", e.into()),
)
})?;
let codec = tonic::codec::ProstCodec::default();
let path = http::uri::PathAndQuery::from_static(
"/tendermint.abci.ABCIApplication/Info",
);
let mut req = request.into_request();
req.extensions_mut()
.insert(GrpcMethod::new("tendermint.abci.ABCIApplication", "Info"));
self.inner.unary(req, path, codec).await
}
pub async fn deliver_tx(
&mut self,
request: impl tonic::IntoRequest<super::RequestDeliverTx>,
) -> std::result::Result<
tonic::Response<super::ResponseDeliverTx>,
tonic::Status,
> {
self.inner
.ready()
.await
.map_err(|e| {
tonic::Status::unknown(
format!("Service was not ready: {}", e.into()),
)
})?;
let codec = tonic::codec::ProstCodec::default();
let path = http::uri::PathAndQuery::from_static(
"/tendermint.abci.ABCIApplication/DeliverTx",
);
let mut req = request.into_request();
req.extensions_mut()
.insert(GrpcMethod::new("tendermint.abci.ABCIApplication", "DeliverTx"));
self.inner.unary(req, path, codec).await
}
pub async fn check_tx(
&mut self,
request: impl tonic::IntoRequest<super::RequestCheckTx>,
) -> std::result::Result<
tonic::Response<super::ResponseCheckTx>,
tonic::Status,
> {
self.inner
.ready()
.await
.map_err(|e| {
tonic::Status::unknown(
format!("Service was not ready: {}", e.into()),
)
})?;
let codec = tonic::codec::ProstCodec::default();
let path = http::uri::PathAndQuery::from_static(
"/tendermint.abci.ABCIApplication/CheckTx",
);
let mut req = request.into_request();
req.extensions_mut()
.insert(GrpcMethod::new("tendermint.abci.ABCIApplication", "CheckTx"));
self.inner.unary(req, path, codec).await
}
pub async fn query(
&mut self,
request: impl tonic::IntoRequest<super::RequestQuery>,
) -> std::result::Result<tonic::Response<super::ResponseQuery>, tonic::Status> {
self.inner
.ready()
.await
.map_err(|e| {
tonic::Status::unknown(
format!("Service was not ready: {}", e.into()),
)
})?;
let codec = tonic::codec::ProstCodec::default();
let path = http::uri::PathAndQuery::from_static(
"/tendermint.abci.ABCIApplication/Query",
);
let mut req = request.into_request();
req.extensions_mut()
.insert(GrpcMethod::new("tendermint.abci.ABCIApplication", "Query"));
self.inner.unary(req, path, codec).await
}
pub async fn commit(
&mut self,
request: impl tonic::IntoRequest<super::RequestCommit>,
) -> std::result::Result<tonic::Response<super::ResponseCommit>, tonic::Status> {
self.inner
.ready()
.await
.map_err(|e| {
tonic::Status::unknown(
format!("Service was not ready: {}", e.into()),
)
})?;
let codec = tonic::codec::ProstCodec::default();
let path = http::uri::PathAndQuery::from_static(
"/tendermint.abci.ABCIApplication/Commit",
);
let mut req = request.into_request();
req.extensions_mut()
.insert(GrpcMethod::new("tendermint.abci.ABCIApplication", "Commit"));
self.inner.unary(req, path, codec).await
}
pub async fn init_chain(
&mut self,
request: impl tonic::IntoRequest<super::RequestInitChain>,
) -> std::result::Result<
tonic::Response<super::ResponseInitChain>,
tonic::Status,
> {
self.inner
.ready()
.await
.map_err(|e| {
tonic::Status::unknown(
format!("Service was not ready: {}", e.into()),
)
})?;
let codec = tonic::codec::ProstCodec::default();
let path = http::uri::PathAndQuery::from_static(
"/tendermint.abci.ABCIApplication/InitChain",
);
let mut req = request.into_request();
req.extensions_mut()
.insert(GrpcMethod::new("tendermint.abci.ABCIApplication", "InitChain"));
self.inner.unary(req, path, codec).await
}
pub async fn begin_block(
&mut self,
request: impl tonic::IntoRequest<super::RequestBeginBlock>,
) -> std::result::Result<
tonic::Response<super::ResponseBeginBlock>,
tonic::Status,
> {
self.inner
.ready()
.await
.map_err(|e| {
tonic::Status::unknown(
format!("Service was not ready: {}", e.into()),
)
})?;
let codec = tonic::codec::ProstCodec::default();
let path = http::uri::PathAndQuery::from_static(
"/tendermint.abci.ABCIApplication/BeginBlock",
);
let mut req = request.into_request();
req.extensions_mut()
.insert(
GrpcMethod::new("tendermint.abci.ABCIApplication", "BeginBlock"),
);
self.inner.unary(req, path, codec).await
}
pub async fn end_block(
&mut self,
request: impl tonic::IntoRequest<super::RequestEndBlock>,
) -> std::result::Result<
tonic::Response<super::ResponseEndBlock>,
tonic::Status,
> {
self.inner
.ready()
.await
.map_err(|e| {
tonic::Status::unknown(
format!("Service was not ready: {}", e.into()),
)
})?;
let codec = tonic::codec::ProstCodec::default();
let path = http::uri::PathAndQuery::from_static(
"/tendermint.abci.ABCIApplication/EndBlock",
);
let mut req = request.into_request();
req.extensions_mut()
.insert(GrpcMethod::new("tendermint.abci.ABCIApplication", "EndBlock"));
self.inner.unary(req, path, codec).await
}
pub async fn list_snapshots(
&mut self,
request: impl tonic::IntoRequest<super::RequestListSnapshots>,
) -> std::result::Result<
tonic::Response<super::ResponseListSnapshots>,
tonic::Status,
> {
self.inner
.ready()
.await
.map_err(|e| {
tonic::Status::unknown(
format!("Service was not ready: {}", e.into()),
)
})?;
let codec = tonic::codec::ProstCodec::default();
let path = http::uri::PathAndQuery::from_static(
"/tendermint.abci.ABCIApplication/ListSnapshots",
);
let mut req = request.into_request();
req.extensions_mut()
.insert(
GrpcMethod::new("tendermint.abci.ABCIApplication", "ListSnapshots"),
);
self.inner.unary(req, path, codec).await
}
pub async fn offer_snapshot(
&mut self,
request: impl tonic::IntoRequest<super::RequestOfferSnapshot>,
) -> std::result::Result<
tonic::Response<super::ResponseOfferSnapshot>,
tonic::Status,
> {
self.inner
.ready()
.await
.map_err(|e| {
tonic::Status::unknown(
format!("Service was not ready: {}", e.into()),
)
})?;
let codec = tonic::codec::ProstCodec::default();
let path = http::uri::PathAndQuery::from_static(
"/tendermint.abci.ABCIApplication/OfferSnapshot",
);
let mut req = request.into_request();
req.extensions_mut()
.insert(
GrpcMethod::new("tendermint.abci.ABCIApplication", "OfferSnapshot"),
);
self.inner.unary(req, path, codec).await
}
pub async fn load_snapshot_chunk(
&mut self,
request: impl tonic::IntoRequest<super::RequestLoadSnapshotChunk>,
) -> std::result::Result<
tonic::Response<super::ResponseLoadSnapshotChunk>,
tonic::Status,
> {
self.inner
.ready()
.await
.map_err(|e| {
tonic::Status::unknown(
format!("Service was not ready: {}", e.into()),
)
})?;
let codec = tonic::codec::ProstCodec::default();
let path = http::uri::PathAndQuery::from_static(
"/tendermint.abci.ABCIApplication/LoadSnapshotChunk",
);
let mut req = request.into_request();
req.extensions_mut()
.insert(
GrpcMethod::new(
"tendermint.abci.ABCIApplication",
"LoadSnapshotChunk",
),
);
self.inner.unary(req, path, codec).await
}
pub async fn apply_snapshot_chunk(
&mut self,
request: impl tonic::IntoRequest<super::RequestApplySnapshotChunk>,
) -> std::result::Result<
tonic::Response<super::ResponseApplySnapshotChunk>,
tonic::Status,
> {
self.inner
.ready()
.await
.map_err(|e| {
tonic::Status::unknown(
format!("Service was not ready: {}", e.into()),
)
})?;
let codec = tonic::codec::ProstCodec::default();
let path = http::uri::PathAndQuery::from_static(
"/tendermint.abci.ABCIApplication/ApplySnapshotChunk",
);
let mut req = request.into_request();
req.extensions_mut()
.insert(
GrpcMethod::new(
"tendermint.abci.ABCIApplication",
"ApplySnapshotChunk",
),
);
self.inner.unary(req, path, codec).await
}
pub async fn prepare_proposal(
&mut self,
request: impl tonic::IntoRequest<super::RequestPrepareProposal>,
) -> std::result::Result<
tonic::Response<super::ResponsePrepareProposal>,
tonic::Status,
> {
self.inner
.ready()
.await
.map_err(|e| {
tonic::Status::unknown(
format!("Service was not ready: {}", e.into()),
)
})?;
let codec = tonic::codec::ProstCodec::default();
let path = http::uri::PathAndQuery::from_static(
"/tendermint.abci.ABCIApplication/PrepareProposal",
);
let mut req = request.into_request();
req.extensions_mut()
.insert(
GrpcMethod::new("tendermint.abci.ABCIApplication", "PrepareProposal"),
);
self.inner.unary(req, path, codec).await
}
pub async fn process_proposal(
&mut self,
request: impl tonic::IntoRequest<super::RequestProcessProposal>,
) -> std::result::Result<
tonic::Response<super::ResponseProcessProposal>,
tonic::Status,
> {
self.inner
.ready()
.await
.map_err(|e| {
tonic::Status::unknown(
format!("Service was not ready: {}", e.into()),
)
})?;
let codec = tonic::codec::ProstCodec::default();
let path = http::uri::PathAndQuery::from_static(
"/tendermint.abci.ABCIApplication/ProcessProposal",
);
let mut req = request.into_request();
req.extensions_mut()
.insert(
GrpcMethod::new("tendermint.abci.ABCIApplication", "ProcessProposal"),
);
self.inner.unary(req, path, codec).await
}
}
}
#[cfg(feature = "rpc")]
pub mod abci_application_server {
#![allow(
unused_variables,
dead_code,
missing_docs,
clippy::wildcard_imports,
clippy::let_unit_value,
)]
use tonic::codegen::*;
#[async_trait]
pub trait AbciApplication: std::marker::Send + std::marker::Sync + 'static {
async fn echo(
&self,
request: tonic::Request<super::RequestEcho>,
) -> std::result::Result<tonic::Response<super::ResponseEcho>, tonic::Status>;
async fn flush(
&self,
request: tonic::Request<super::RequestFlush>,
) -> std::result::Result<tonic::Response<super::ResponseFlush>, tonic::Status>;
async fn info(
&self,
request: tonic::Request<super::RequestInfo>,
) -> std::result::Result<tonic::Response<super::ResponseInfo>, tonic::Status>;
async fn deliver_tx(
&self,
request: tonic::Request<super::RequestDeliverTx>,
) -> std::result::Result<
tonic::Response<super::ResponseDeliverTx>,
tonic::Status,
>;
async fn check_tx(
&self,
request: tonic::Request<super::RequestCheckTx>,
) -> std::result::Result<tonic::Response<super::ResponseCheckTx>, tonic::Status>;
async fn query(
&self,
request: tonic::Request<super::RequestQuery>,
) -> std::result::Result<tonic::Response<super::ResponseQuery>, tonic::Status>;
async fn commit(
&self,
request: tonic::Request<super::RequestCommit>,
) -> std::result::Result<tonic::Response<super::ResponseCommit>, tonic::Status>;
async fn init_chain(
&self,
request: tonic::Request<super::RequestInitChain>,
) -> std::result::Result<
tonic::Response<super::ResponseInitChain>,
tonic::Status,
>;
async fn begin_block(
&self,
request: tonic::Request<super::RequestBeginBlock>,
) -> std::result::Result<
tonic::Response<super::ResponseBeginBlock>,
tonic::Status,
>;
async fn end_block(
&self,
request: tonic::Request<super::RequestEndBlock>,
) -> std::result::Result<
tonic::Response<super::ResponseEndBlock>,
tonic::Status,
>;
async fn list_snapshots(
&self,
request: tonic::Request<super::RequestListSnapshots>,
) -> std::result::Result<
tonic::Response<super::ResponseListSnapshots>,
tonic::Status,
>;
async fn offer_snapshot(
&self,
request: tonic::Request<super::RequestOfferSnapshot>,
) -> std::result::Result<
tonic::Response<super::ResponseOfferSnapshot>,
tonic::Status,
>;
async fn load_snapshot_chunk(
&self,
request: tonic::Request<super::RequestLoadSnapshotChunk>,
) -> std::result::Result<
tonic::Response<super::ResponseLoadSnapshotChunk>,
tonic::Status,
>;
async fn apply_snapshot_chunk(
&self,
request: tonic::Request<super::RequestApplySnapshotChunk>,
) -> std::result::Result<
tonic::Response<super::ResponseApplySnapshotChunk>,
tonic::Status,
>;
async fn prepare_proposal(
&self,
request: tonic::Request<super::RequestPrepareProposal>,
) -> std::result::Result<
tonic::Response<super::ResponsePrepareProposal>,
tonic::Status,
>;
async fn process_proposal(
&self,
request: tonic::Request<super::RequestProcessProposal>,
) -> std::result::Result<
tonic::Response<super::ResponseProcessProposal>,
tonic::Status,
>;
}
#[derive(Debug)]
pub struct AbciApplicationServer<T> {
inner: Arc<T>,
accept_compression_encodings: EnabledCompressionEncodings,
send_compression_encodings: EnabledCompressionEncodings,
max_decoding_message_size: Option<usize>,
max_encoding_message_size: Option<usize>,
}
impl<T> AbciApplicationServer<T> {
pub fn new(inner: T) -> Self {
Self::from_arc(Arc::new(inner))
}
pub fn from_arc(inner: Arc<T>) -> Self {
Self {
inner,
accept_compression_encodings: Default::default(),
send_compression_encodings: Default::default(),
max_decoding_message_size: None,
max_encoding_message_size: None,
}
}
pub fn with_interceptor<F>(
inner: T,
interceptor: F,
) -> InterceptedService<Self, F>
where
F: tonic::service::Interceptor,
{
InterceptedService::new(Self::new(inner), interceptor)
}
#[must_use]
pub fn accept_compressed(mut self, encoding: CompressionEncoding) -> Self {
self.accept_compression_encodings.enable(encoding);
self
}
#[must_use]
pub fn send_compressed(mut self, encoding: CompressionEncoding) -> Self {
self.send_compression_encodings.enable(encoding);
self
}
#[must_use]
pub fn max_decoding_message_size(mut self, limit: usize) -> Self {
self.max_decoding_message_size = Some(limit);
self
}
#[must_use]
pub fn max_encoding_message_size(mut self, limit: usize) -> Self {
self.max_encoding_message_size = Some(limit);
self
}
}
impl<T, B> tonic::codegen::Service<http::Request<B>> for AbciApplicationServer<T>
where
T: AbciApplication,
B: Body + std::marker::Send + 'static,
B::Error: Into<StdError> + std::marker::Send + 'static,
{
type Response = http::Response<tonic::body::BoxBody>;
type Error = std::convert::Infallible;
type Future = BoxFuture<Self::Response, Self::Error>;
fn poll_ready(
&mut self,
_cx: &mut Context<'_>,
) -> Poll<std::result::Result<(), Self::Error>> {
Poll::Ready(Ok(()))
}
fn call(&mut self, req: http::Request<B>) -> Self::Future {
match req.uri().path() {
"/tendermint.abci.ABCIApplication/Echo" => {
#[allow(non_camel_case_types)]
struct EchoSvc<T: AbciApplication>(pub Arc<T>);
impl<
T: AbciApplication,
> tonic::server::UnaryService<super::RequestEcho> for EchoSvc<T> {
type Response = super::ResponseEcho;
type Future = BoxFuture<
tonic::Response<Self::Response>,
tonic::Status,
>;
fn call(
&mut self,
request: tonic::Request<super::RequestEcho>,
) -> Self::Future {
let inner = Arc::clone(&self.0);
let fut = async move {
<T as AbciApplication>::echo(&inner, request).await
};
Box::pin(fut)
}
}
let accept_compression_encodings = self.accept_compression_encodings;
let send_compression_encodings = self.send_compression_encodings;
let max_decoding_message_size = self.max_decoding_message_size;
let max_encoding_message_size = self.max_encoding_message_size;
let inner = self.inner.clone();
let fut = async move {
let method = EchoSvc(inner);
let codec = tonic::codec::ProstCodec::default();
let mut grpc = tonic::server::Grpc::new(codec)
.apply_compression_config(
accept_compression_encodings,
send_compression_encodings,
)
.apply_max_message_size_config(
max_decoding_message_size,
max_encoding_message_size,
);
let res = grpc.unary(method, req).await;
Ok(res)
};
Box::pin(fut)
}
"/tendermint.abci.ABCIApplication/Flush" => {
#[allow(non_camel_case_types)]
struct FlushSvc<T: AbciApplication>(pub Arc<T>);
impl<
T: AbciApplication,
> tonic::server::UnaryService<super::RequestFlush> for FlushSvc<T> {
type Response = super::ResponseFlush;
type Future = BoxFuture<
tonic::Response<Self::Response>,
tonic::Status,
>;
fn call(
&mut self,
request: tonic::Request<super::RequestFlush>,
) -> Self::Future {
let inner = Arc::clone(&self.0);
let fut = async move {
<T as AbciApplication>::flush(&inner, request).await
};
Box::pin(fut)
}
}
let accept_compression_encodings = self.accept_compression_encodings;
let send_compression_encodings = self.send_compression_encodings;
let max_decoding_message_size = self.max_decoding_message_size;
let max_encoding_message_size = self.max_encoding_message_size;
let inner = self.inner.clone();
let fut = async move {
let method = FlushSvc(inner);
let codec = tonic::codec::ProstCodec::default();
let mut grpc = tonic::server::Grpc::new(codec)
.apply_compression_config(
accept_compression_encodings,
send_compression_encodings,
)
.apply_max_message_size_config(
max_decoding_message_size,
max_encoding_message_size,
);
let res = grpc.unary(method, req).await;
Ok(res)
};
Box::pin(fut)
}
"/tendermint.abci.ABCIApplication/Info" => {
#[allow(non_camel_case_types)]
struct InfoSvc<T: AbciApplication>(pub Arc<T>);
impl<
T: AbciApplication,
> tonic::server::UnaryService<super::RequestInfo> for InfoSvc<T> {
type Response = super::ResponseInfo;
type Future = BoxFuture<
tonic::Response<Self::Response>,
tonic::Status,
>;
fn call(
&mut self,
request: tonic::Request<super::RequestInfo>,
) -> Self::Future {
let inner = Arc::clone(&self.0);
let fut = async move {
<T as AbciApplication>::info(&inner, request).await
};
Box::pin(fut)
}
}
let accept_compression_encodings = self.accept_compression_encodings;
let send_compression_encodings = self.send_compression_encodings;
let max_decoding_message_size = self.max_decoding_message_size;
let max_encoding_message_size = self.max_encoding_message_size;
let inner = self.inner.clone();
let fut = async move {
let method = InfoSvc(inner);
let codec = tonic::codec::ProstCodec::default();
let mut grpc = tonic::server::Grpc::new(codec)
.apply_compression_config(
accept_compression_encodings,
send_compression_encodings,
)
.apply_max_message_size_config(
max_decoding_message_size,
max_encoding_message_size,
);
let res = grpc.unary(method, req).await;
Ok(res)
};
Box::pin(fut)
}
"/tendermint.abci.ABCIApplication/DeliverTx" => {
#[allow(non_camel_case_types)]
struct DeliverTxSvc<T: AbciApplication>(pub Arc<T>);
impl<
T: AbciApplication,
> tonic::server::UnaryService<super::RequestDeliverTx>
for DeliverTxSvc<T> {
type Response = super::ResponseDeliverTx;
type Future = BoxFuture<
tonic::Response<Self::Response>,
tonic::Status,
>;
fn call(
&mut self,
request: tonic::Request<super::RequestDeliverTx>,
) -> Self::Future {
let inner = Arc::clone(&self.0);
let fut = async move {
<T as AbciApplication>::deliver_tx(&inner, request).await
};
Box::pin(fut)
}
}
let accept_compression_encodings = self.accept_compression_encodings;
let send_compression_encodings = self.send_compression_encodings;
let max_decoding_message_size = self.max_decoding_message_size;
let max_encoding_message_size = self.max_encoding_message_size;
let inner = self.inner.clone();
let fut = async move {
let method = DeliverTxSvc(inner);
let codec = tonic::codec::ProstCodec::default();
let mut grpc = tonic::server::Grpc::new(codec)
.apply_compression_config(
accept_compression_encodings,
send_compression_encodings,
)
.apply_max_message_size_config(
max_decoding_message_size,
max_encoding_message_size,
);
let res = grpc.unary(method, req).await;
Ok(res)
};
Box::pin(fut)
}
"/tendermint.abci.ABCIApplication/CheckTx" => {
#[allow(non_camel_case_types)]
struct CheckTxSvc<T: AbciApplication>(pub Arc<T>);
impl<
T: AbciApplication,
> tonic::server::UnaryService<super::RequestCheckTx>
for CheckTxSvc<T> {
type Response = super::ResponseCheckTx;
type Future = BoxFuture<
tonic::Response<Self::Response>,
tonic::Status,
>;
fn call(
&mut self,
request: tonic::Request<super::RequestCheckTx>,
) -> Self::Future {
let inner = Arc::clone(&self.0);
let fut = async move {
<T as AbciApplication>::check_tx(&inner, request).await
};
Box::pin(fut)
}
}
let accept_compression_encodings = self.accept_compression_encodings;
let send_compression_encodings = self.send_compression_encodings;
let max_decoding_message_size = self.max_decoding_message_size;
let max_encoding_message_size = self.max_encoding_message_size;
let inner = self.inner.clone();
let fut = async move {
let method = CheckTxSvc(inner);
let codec = tonic::codec::ProstCodec::default();
let mut grpc = tonic::server::Grpc::new(codec)
.apply_compression_config(
accept_compression_encodings,
send_compression_encodings,
)
.apply_max_message_size_config(
max_decoding_message_size,
max_encoding_message_size,
);
let res = grpc.unary(method, req).await;
Ok(res)
};
Box::pin(fut)
}
"/tendermint.abci.ABCIApplication/Query" => {
#[allow(non_camel_case_types)]
struct QuerySvc<T: AbciApplication>(pub Arc<T>);
impl<
T: AbciApplication,
> tonic::server::UnaryService<super::RequestQuery> for QuerySvc<T> {
type Response = super::ResponseQuery;
type Future = BoxFuture<
tonic::Response<Self::Response>,
tonic::Status,
>;
fn call(
&mut self,
request: tonic::Request<super::RequestQuery>,
) -> Self::Future {
let inner = Arc::clone(&self.0);
let fut = async move {
<T as AbciApplication>::query(&inner, request).await
};
Box::pin(fut)
}
}
let accept_compression_encodings = self.accept_compression_encodings;
let send_compression_encodings = self.send_compression_encodings;
let max_decoding_message_size = self.max_decoding_message_size;
let max_encoding_message_size = self.max_encoding_message_size;
let inner = self.inner.clone();
let fut = async move {
let method = QuerySvc(inner);
let codec = tonic::codec::ProstCodec::default();
let mut grpc = tonic::server::Grpc::new(codec)
.apply_compression_config(
accept_compression_encodings,
send_compression_encodings,
)
.apply_max_message_size_config(
max_decoding_message_size,
max_encoding_message_size,
);
let res = grpc.unary(method, req).await;
Ok(res)
};
Box::pin(fut)
}
"/tendermint.abci.ABCIApplication/Commit" => {
#[allow(non_camel_case_types)]
struct CommitSvc<T: AbciApplication>(pub Arc<T>);
impl<
T: AbciApplication,
> tonic::server::UnaryService<super::RequestCommit>
for CommitSvc<T> {
type Response = super::ResponseCommit;
type Future = BoxFuture<
tonic::Response<Self::Response>,
tonic::Status,
>;
fn call(
&mut self,
request: tonic::Request<super::RequestCommit>,
) -> Self::Future {
let inner = Arc::clone(&self.0);
let fut = async move {
<T as AbciApplication>::commit(&inner, request).await
};
Box::pin(fut)
}
}
let accept_compression_encodings = self.accept_compression_encodings;
let send_compression_encodings = self.send_compression_encodings;
let max_decoding_message_size = self.max_decoding_message_size;
let max_encoding_message_size = self.max_encoding_message_size;
let inner = self.inner.clone();
let fut = async move {
let method = CommitSvc(inner);
let codec = tonic::codec::ProstCodec::default();
let mut grpc = tonic::server::Grpc::new(codec)
.apply_compression_config(
accept_compression_encodings,
send_compression_encodings,
)
.apply_max_message_size_config(
max_decoding_message_size,
max_encoding_message_size,
);
let res = grpc.unary(method, req).await;
Ok(res)
};
Box::pin(fut)
}
"/tendermint.abci.ABCIApplication/InitChain" => {
#[allow(non_camel_case_types)]
struct InitChainSvc<T: AbciApplication>(pub Arc<T>);
impl<
T: AbciApplication,
> tonic::server::UnaryService<super::RequestInitChain>
for InitChainSvc<T> {
type Response = super::ResponseInitChain;
type Future = BoxFuture<
tonic::Response<Self::Response>,
tonic::Status,
>;
fn call(
&mut self,
request: tonic::Request<super::RequestInitChain>,
) -> Self::Future {
let inner = Arc::clone(&self.0);
let fut = async move {
<T as AbciApplication>::init_chain(&inner, request).await
};
Box::pin(fut)
}
}
let accept_compression_encodings = self.accept_compression_encodings;
let send_compression_encodings = self.send_compression_encodings;
let max_decoding_message_size = self.max_decoding_message_size;
let max_encoding_message_size = self.max_encoding_message_size;
let inner = self.inner.clone();
let fut = async move {
let method = InitChainSvc(inner);
let codec = tonic::codec::ProstCodec::default();
let mut grpc = tonic::server::Grpc::new(codec)
.apply_compression_config(
accept_compression_encodings,
send_compression_encodings,
)
.apply_max_message_size_config(
max_decoding_message_size,
max_encoding_message_size,
);
let res = grpc.unary(method, req).await;
Ok(res)
};
Box::pin(fut)
}
"/tendermint.abci.ABCIApplication/BeginBlock" => {
#[allow(non_camel_case_types)]
struct BeginBlockSvc<T: AbciApplication>(pub Arc<T>);
impl<
T: AbciApplication,
> tonic::server::UnaryService<super::RequestBeginBlock>
for BeginBlockSvc<T> {
type Response = super::ResponseBeginBlock;
type Future = BoxFuture<
tonic::Response<Self::Response>,
tonic::Status,
>;
fn call(
&mut self,
request: tonic::Request<super::RequestBeginBlock>,
) -> Self::Future {
let inner = Arc::clone(&self.0);
let fut = async move {
<T as AbciApplication>::begin_block(&inner, request).await
};
Box::pin(fut)
}
}
let accept_compression_encodings = self.accept_compression_encodings;
let send_compression_encodings = self.send_compression_encodings;
let max_decoding_message_size = self.max_decoding_message_size;
let max_encoding_message_size = self.max_encoding_message_size;
let inner = self.inner.clone();
let fut = async move {
let method = BeginBlockSvc(inner);
let codec = tonic::codec::ProstCodec::default();
let mut grpc = tonic::server::Grpc::new(codec)
.apply_compression_config(
accept_compression_encodings,
send_compression_encodings,
)
.apply_max_message_size_config(
max_decoding_message_size,
max_encoding_message_size,
);
let res = grpc.unary(method, req).await;
Ok(res)
};
Box::pin(fut)
}
"/tendermint.abci.ABCIApplication/EndBlock" => {
#[allow(non_camel_case_types)]
struct EndBlockSvc<T: AbciApplication>(pub Arc<T>);
impl<
T: AbciApplication,
> tonic::server::UnaryService<super::RequestEndBlock>
for EndBlockSvc<T> {
type Response = super::ResponseEndBlock;
type Future = BoxFuture<
tonic::Response<Self::Response>,
tonic::Status,
>;
fn call(
&mut self,
request: tonic::Request<super::RequestEndBlock>,
) -> Self::Future {
let inner = Arc::clone(&self.0);
let fut = async move {
<T as AbciApplication>::end_block(&inner, request).await
};
Box::pin(fut)
}
}
let accept_compression_encodings = self.accept_compression_encodings;
let send_compression_encodings = self.send_compression_encodings;
let max_decoding_message_size = self.max_decoding_message_size;
let max_encoding_message_size = self.max_encoding_message_size;
let inner = self.inner.clone();
let fut = async move {
let method = EndBlockSvc(inner);
let codec = tonic::codec::ProstCodec::default();
let mut grpc = tonic::server::Grpc::new(codec)
.apply_compression_config(
accept_compression_encodings,
send_compression_encodings,
)
.apply_max_message_size_config(
max_decoding_message_size,
max_encoding_message_size,
);
let res = grpc.unary(method, req).await;
Ok(res)
};
Box::pin(fut)
}
"/tendermint.abci.ABCIApplication/ListSnapshots" => {
#[allow(non_camel_case_types)]
struct ListSnapshotsSvc<T: AbciApplication>(pub Arc<T>);
impl<
T: AbciApplication,
> tonic::server::UnaryService<super::RequestListSnapshots>
for ListSnapshotsSvc<T> {
type Response = super::ResponseListSnapshots;
type Future = BoxFuture<
tonic::Response<Self::Response>,
tonic::Status,
>;
fn call(
&mut self,
request: tonic::Request<super::RequestListSnapshots>,
) -> Self::Future {
let inner = Arc::clone(&self.0);
let fut = async move {
<T as AbciApplication>::list_snapshots(&inner, request)
.await
};
Box::pin(fut)
}
}
let accept_compression_encodings = self.accept_compression_encodings;
let send_compression_encodings = self.send_compression_encodings;
let max_decoding_message_size = self.max_decoding_message_size;
let max_encoding_message_size = self.max_encoding_message_size;
let inner = self.inner.clone();
let fut = async move {
let method = ListSnapshotsSvc(inner);
let codec = tonic::codec::ProstCodec::default();
let mut grpc = tonic::server::Grpc::new(codec)
.apply_compression_config(
accept_compression_encodings,
send_compression_encodings,
)
.apply_max_message_size_config(
max_decoding_message_size,
max_encoding_message_size,
);
let res = grpc.unary(method, req).await;
Ok(res)
};
Box::pin(fut)
}
"/tendermint.abci.ABCIApplication/OfferSnapshot" => {
#[allow(non_camel_case_types)]
struct OfferSnapshotSvc<T: AbciApplication>(pub Arc<T>);
impl<
T: AbciApplication,
> tonic::server::UnaryService<super::RequestOfferSnapshot>
for OfferSnapshotSvc<T> {
type Response = super::ResponseOfferSnapshot;
type Future = BoxFuture<
tonic::Response<Self::Response>,
tonic::Status,
>;
fn call(
&mut self,
request: tonic::Request<super::RequestOfferSnapshot>,
) -> Self::Future {
let inner = Arc::clone(&self.0);
let fut = async move {
<T as AbciApplication>::offer_snapshot(&inner, request)
.await
};
Box::pin(fut)
}
}
let accept_compression_encodings = self.accept_compression_encodings;
let send_compression_encodings = self.send_compression_encodings;
let max_decoding_message_size = self.max_decoding_message_size;
let max_encoding_message_size = self.max_encoding_message_size;
let inner = self.inner.clone();
let fut = async move {
let method = OfferSnapshotSvc(inner);
let codec = tonic::codec::ProstCodec::default();
let mut grpc = tonic::server::Grpc::new(codec)
.apply_compression_config(
accept_compression_encodings,
send_compression_encodings,
)
.apply_max_message_size_config(
max_decoding_message_size,
max_encoding_message_size,
);
let res = grpc.unary(method, req).await;
Ok(res)
};
Box::pin(fut)
}
"/tendermint.abci.ABCIApplication/LoadSnapshotChunk" => {
#[allow(non_camel_case_types)]
struct LoadSnapshotChunkSvc<T: AbciApplication>(pub Arc<T>);
impl<
T: AbciApplication,
> tonic::server::UnaryService<super::RequestLoadSnapshotChunk>
for LoadSnapshotChunkSvc<T> {
type Response = super::ResponseLoadSnapshotChunk;
type Future = BoxFuture<
tonic::Response<Self::Response>,
tonic::Status,
>;
fn call(
&mut self,
request: tonic::Request<super::RequestLoadSnapshotChunk>,
) -> Self::Future {
let inner = Arc::clone(&self.0);
let fut = async move {
<T as AbciApplication>::load_snapshot_chunk(&inner, request)
.await
};
Box::pin(fut)
}
}
let accept_compression_encodings = self.accept_compression_encodings;
let send_compression_encodings = self.send_compression_encodings;
let max_decoding_message_size = self.max_decoding_message_size;
let max_encoding_message_size = self.max_encoding_message_size;
let inner = self.inner.clone();
let fut = async move {
let method = LoadSnapshotChunkSvc(inner);
let codec = tonic::codec::ProstCodec::default();
let mut grpc = tonic::server::Grpc::new(codec)
.apply_compression_config(
accept_compression_encodings,
send_compression_encodings,
)
.apply_max_message_size_config(
max_decoding_message_size,
max_encoding_message_size,
);
let res = grpc.unary(method, req).await;
Ok(res)
};
Box::pin(fut)
}
"/tendermint.abci.ABCIApplication/ApplySnapshotChunk" => {
#[allow(non_camel_case_types)]
struct ApplySnapshotChunkSvc<T: AbciApplication>(pub Arc<T>);
impl<
T: AbciApplication,
> tonic::server::UnaryService<super::RequestApplySnapshotChunk>
for ApplySnapshotChunkSvc<T> {
type Response = super::ResponseApplySnapshotChunk;
type Future = BoxFuture<
tonic::Response<Self::Response>,
tonic::Status,
>;
fn call(
&mut self,
request: tonic::Request<super::RequestApplySnapshotChunk>,
) -> Self::Future {
let inner = Arc::clone(&self.0);
let fut = async move {
<T as AbciApplication>::apply_snapshot_chunk(
&inner,
request,
)
.await
};
Box::pin(fut)
}
}
let accept_compression_encodings = self.accept_compression_encodings;
let send_compression_encodings = self.send_compression_encodings;
let max_decoding_message_size = self.max_decoding_message_size;
let max_encoding_message_size = self.max_encoding_message_size;
let inner = self.inner.clone();
let fut = async move {
let method = ApplySnapshotChunkSvc(inner);
let codec = tonic::codec::ProstCodec::default();
let mut grpc = tonic::server::Grpc::new(codec)
.apply_compression_config(
accept_compression_encodings,
send_compression_encodings,
)
.apply_max_message_size_config(
max_decoding_message_size,
max_encoding_message_size,
);
let res = grpc.unary(method, req).await;
Ok(res)
};
Box::pin(fut)
}
"/tendermint.abci.ABCIApplication/PrepareProposal" => {
#[allow(non_camel_case_types)]
struct PrepareProposalSvc<T: AbciApplication>(pub Arc<T>);
impl<
T: AbciApplication,
> tonic::server::UnaryService<super::RequestPrepareProposal>
for PrepareProposalSvc<T> {
type Response = super::ResponsePrepareProposal;
type Future = BoxFuture<
tonic::Response<Self::Response>,
tonic::Status,
>;
fn call(
&mut self,
request: tonic::Request<super::RequestPrepareProposal>,
) -> Self::Future {
let inner = Arc::clone(&self.0);
let fut = async move {
<T as AbciApplication>::prepare_proposal(&inner, request)
.await
};
Box::pin(fut)
}
}
let accept_compression_encodings = self.accept_compression_encodings;
let send_compression_encodings = self.send_compression_encodings;
let max_decoding_message_size = self.max_decoding_message_size;
let max_encoding_message_size = self.max_encoding_message_size;
let inner = self.inner.clone();
let fut = async move {
let method = PrepareProposalSvc(inner);
let codec = tonic::codec::ProstCodec::default();
let mut grpc = tonic::server::Grpc::new(codec)
.apply_compression_config(
accept_compression_encodings,
send_compression_encodings,
)
.apply_max_message_size_config(
max_decoding_message_size,
max_encoding_message_size,
);
let res = grpc.unary(method, req).await;
Ok(res)
};
Box::pin(fut)
}
"/tendermint.abci.ABCIApplication/ProcessProposal" => {
#[allow(non_camel_case_types)]
struct ProcessProposalSvc<T: AbciApplication>(pub Arc<T>);
impl<
T: AbciApplication,
> tonic::server::UnaryService<super::RequestProcessProposal>
for ProcessProposalSvc<T> {
type Response = super::ResponseProcessProposal;
type Future = BoxFuture<
tonic::Response<Self::Response>,
tonic::Status,
>;
fn call(
&mut self,
request: tonic::Request<super::RequestProcessProposal>,
) -> Self::Future {
let inner = Arc::clone(&self.0);
let fut = async move {
<T as AbciApplication>::process_proposal(&inner, request)
.await
};
Box::pin(fut)
}
}
let accept_compression_encodings = self.accept_compression_encodings;
let send_compression_encodings = self.send_compression_encodings;
let max_decoding_message_size = self.max_decoding_message_size;
let max_encoding_message_size = self.max_encoding_message_size;
let inner = self.inner.clone();
let fut = async move {
let method = ProcessProposalSvc(inner);
let codec = tonic::codec::ProstCodec::default();
let mut grpc = tonic::server::Grpc::new(codec)
.apply_compression_config(
accept_compression_encodings,
send_compression_encodings,
)
.apply_max_message_size_config(
max_decoding_message_size,
max_encoding_message_size,
);
let res = grpc.unary(method, req).await;
Ok(res)
};
Box::pin(fut)
}
_ => {
Box::pin(async move {
let mut response = http::Response::new(empty_body());
let headers = response.headers_mut();
headers
.insert(
tonic::Status::GRPC_STATUS,
(tonic::Code::Unimplemented as i32).into(),
);
headers
.insert(
http::header::CONTENT_TYPE,
tonic::metadata::GRPC_CONTENT_TYPE,
);
Ok(response)
})
}
}
}
}
impl<T> Clone for AbciApplicationServer<T> {
fn clone(&self) -> Self {
let inner = self.inner.clone();
Self {
inner,
accept_compression_encodings: self.accept_compression_encodings,
send_compression_encodings: self.send_compression_encodings,
max_decoding_message_size: self.max_decoding_message_size,
max_encoding_message_size: self.max_encoding_message_size,
}
}
}
pub const SERVICE_NAME: &str = "tendermint.abci.ABCIApplication";
impl<T> tonic::server::NamedService for AbciApplicationServer<T> {
const NAME: &'static str = SERVICE_NAME;
}
}