Skip to content

Commit

Permalink
Fix block-related queries to use compat mode
Browse files Browse the repository at this point in the history
  • Loading branch information
romac committed Sep 24, 2024
1 parent c190d2a commit df8901e
Show file tree
Hide file tree
Showing 5 changed files with 66 additions and 4 deletions.
31 changes: 31 additions & 0 deletions rpc/src/client/transport/http.rs
Original file line number Diff line number Diff line change
Expand Up @@ -257,6 +257,24 @@ impl Client for HttpClient {
self.perform_with_dialect(request, LatestDialect).await
}

async fn block<H>(&self, height: H) -> Result<endpoint::block::Response, Error>
where
H: Into<Height> + Send,
{
perform_with_compat!(self, endpoint::block::Request::new(height.into()))
}

async fn block_by_hash(
&self,
hash: tendermint::Hash,
) -> Result<endpoint::block_by_hash::Response, Error> {
perform_with_compat!(self, endpoint::block_by_hash::Request::new(hash))
}

async fn latest_block(&self) -> Result<endpoint::block::Response, Error> {
perform_with_compat!(self, endpoint::block::Request::default())
}

async fn block_results<H>(&self, height: H) -> Result<endpoint::block_results::Response, Error>
where
H: Into<Height> + Send,
Expand All @@ -268,6 +286,19 @@ impl Client for HttpClient {
perform_with_compat!(self, endpoint::block_results::Request::default())
}

async fn block_search(
&self,
query: Query,
page: u32,
per_page: u8,
order: Order,
) -> Result<endpoint::block_search::Response, Error> {
perform_with_compat!(
self,
endpoint::block_search::Request::new(query, page, per_page, order)
)
}

async fn header<H>(&self, height: H) -> Result<endpoint::header::Response, Error>
where
H: Into<Height> + Send,
Expand Down
31 changes: 31 additions & 0 deletions rpc/src/client/transport/websocket.rs
Original file line number Diff line number Diff line change
Expand Up @@ -234,6 +234,24 @@ impl Client for WebSocketClient {
self.perform_with_dialect(request, LatestDialect).await
}

async fn block<H>(&self, height: H) -> Result<endpoint::block::Response, Error>
where
H: Into<Height> + Send,
{
perform_with_compat!(self, endpoint::block::Request::new(height.into()))
}

async fn block_by_hash(
&self,
hash: tendermint::Hash,
) -> Result<endpoint::block_by_hash::Response, Error> {
perform_with_compat!(self, endpoint::block_by_hash::Request::new(hash))
}

async fn latest_block(&self) -> Result<endpoint::block::Response, Error> {
perform_with_compat!(self, endpoint::block::Request::default())
}

async fn block_results<H>(&self, height: H) -> Result<endpoint::block_results::Response, Error>
where
H: Into<Height> + Send,
Expand All @@ -245,6 +263,19 @@ impl Client for WebSocketClient {
perform_with_compat!(self, endpoint::block_results::Request::default())
}

async fn block_search(
&self,
query: Query,
page: u32,
per_page: u8,
order: Order,
) -> Result<endpoint::block_search::Response, Error> {
perform_with_compat!(
self,
endpoint::block_search::Request::new(query, page, per_page, order)
)
}

async fn header<H>(&self, height: H) -> Result<endpoint::header::Response, Error>
where
H: Into<Height> + Send,
Expand Down
4 changes: 2 additions & 2 deletions rpc/src/endpoint/block.rs
Original file line number Diff line number Diff line change
Expand Up @@ -47,7 +47,7 @@ impl crate::SimpleRequest<dialect::v0_37::Dialect> for Request {
}

impl crate::Request<dialect::v0_38::Dialect> for Request {
type Response = Response;
type Response = self::v0_38::DialectResponse;
}

impl crate::SimpleRequest<dialect::v0_38::Dialect> for Request {
Expand All @@ -66,7 +66,7 @@ pub struct Response {

impl crate::Response for Response {}

pub mod v_038 {
pub mod v0_38 {
use std::vec::Vec;

use block::{Commit, Header};
Expand Down
2 changes: 1 addition & 1 deletion rpc/src/endpoint/block_by_hash.rs
Original file line number Diff line number Diff line change
Expand Up @@ -77,7 +77,7 @@ impl crate::Response for Response {}

pub mod v_038 {
use super::*;
use crate::endpoint::block::v_038::DialectBlock;
use crate::endpoint::block::v0_38::DialectBlock;

#[derive(Clone, Debug, Deserialize, Serialize)]
pub struct DialectResponse {
Expand Down
2 changes: 1 addition & 1 deletion rpc/src/endpoint/block_search.rs
Original file line number Diff line number Diff line change
Expand Up @@ -77,7 +77,7 @@ pub mod v0_38 {

#[derive(Clone, Debug, Deserialize, Serialize)]
pub struct DialectResponse {
pub blocks: Vec<block::v_038::DialectResponse>,
pub blocks: Vec<block::v0_38::DialectResponse>,

#[serde(with = "serializers::from_str")]
pub total_count: u32,
Expand Down

0 comments on commit df8901e

Please sign in to comment.