From 9e5f0894e2c6c657f6096e30c3debe8074279bfe Mon Sep 17 00:00:00 2001 From: Trevor Porter Date: Tue, 31 Oct 2023 17:22:53 +0000 Subject: [PATCH 1/3] fix lag --- rust/chains/hyperlane-cosmos/src/mailbox.rs | 60 ++++++------------- .../hyperlane-cosmos/src/providers/grpc.rs | 38 +++--------- 2 files changed, 26 insertions(+), 72 deletions(-) diff --git a/rust/chains/hyperlane-cosmos/src/mailbox.rs b/rust/chains/hyperlane-cosmos/src/mailbox.rs index 5aedb4d63d..5cb052bd9a 100644 --- a/rust/chains/hyperlane-cosmos/src/mailbox.rs +++ b/rust/chains/hyperlane-cosmos/src/mailbox.rs @@ -80,22 +80,8 @@ impl Debug for CosmosMailbox { impl Mailbox for CosmosMailbox { #[instrument(level = "debug", err, ret, skip(self))] async fn count(&self, lag: Option) -> ChainResult { - let payload = mailbox::NonceRequest { - nonce: general::EmptyStruct {}, - }; - - let data = self - .provider - .wasm_query(GeneralMailboxQuery { mailbox: payload }, lag) - .await; - - if let Err(e) = data { - warn!("error: {:?}", e); - return Ok(0); - } - - let response: mailbox::NonceResponse = serde_json::from_slice(&data?)?; - Ok(response.nonce) + let block_height = self.get_block_height_for_lag(lag).await?; + self.nonce_at_block(block_height).await } #[instrument(level = "debug", err, ret, skip(self))] @@ -281,30 +267,31 @@ impl CosmosMailboxIndexer { } } - #[instrument(level = "debug", err, ret, skip(self))] - async fn count(&self, lag: Option) -> ChainResult { - let payload = mailbox::NonceRequest { - nonce: general::EmptyStruct {}, + /// Given a lag, returns the block height at the moment. + /// If the lag is None, a block height of None is given, indicating that the + /// tip directly can be used. + async fn get_block_height_for_lag(&self, lag: Option) -> ChainResult> { + let block_height = match lag { + Some(lag) => { + let tip = self.indexer.latest_block_height().await?; + let block_height = tip as u64 - lag; + Some(block_height) + } + None => None, }; - let data = self - .provider - .wasm_query(GeneralMailboxQuery { mailbox: payload }, lag) - .await?; - let response: mailbox::NonceResponse = serde_json::from_slice(&data)?; - - Ok(response.nonce) + Ok(block_height) } #[instrument(level = "debug", err, ret, skip(self))] - async fn nonce(&self, lag: Option) -> ChainResult { + async fn nonce_at_block(&self, block_height: Option) -> ChainResult { let payload = mailbox::NonceRequest { nonce: general::EmptyStruct {}, }; let data = self .provider - .wasm_query(GeneralMailboxQuery { mailbox: payload }, lag) + .wasm_query(GeneralMailboxQuery { mailbox: payload }, block_height) .await?; let response: mailbox::NonceResponse = serde_json::from_slice(&data)?; @@ -350,28 +337,19 @@ impl Indexer for CosmosMailboxIndexer { #[async_trait] impl SequenceIndexer for CosmosMailboxIndexer { async fn sequence_and_tip(&self) -> ChainResult<(Option, u32)> { - // TODO: implement when cosmos scraper support is implemented let tip = self.indexer.latest_block_height().await?; - let sequence = match NonZeroU64::new(tip as u64) { - None => None, - Some(n) => Some(self.nonce(Some(n)).await?), - }; - - Ok((sequence, tip)) + // No sequence for message deliveries. + Ok((None, tip)) } } #[async_trait] impl SequenceIndexer for CosmosMailboxIndexer { async fn sequence_and_tip(&self) -> ChainResult<(Option, u32)> { - // TODO: implement when cosmos scraper support is implemented let tip = self.indexer.latest_block_height().await?; - let sequence = match NonZeroU64::new(tip as u64) { - None => None, - Some(n) => Some(self.nonce(Some(n)).await?), - }; + let sequence = self.nonce_at_block(Some(tip)).await?; Ok((sequence, tip)) } diff --git a/rust/chains/hyperlane-cosmos/src/providers/grpc.rs b/rust/chains/hyperlane-cosmos/src/providers/grpc.rs index 2925a93443..d50c28b3bc 100644 --- a/rust/chains/hyperlane-cosmos/src/providers/grpc.rs +++ b/rust/chains/hyperlane-cosmos/src/providers/grpc.rs @@ -42,7 +42,7 @@ pub trait WasmProvider: Send + Sync { async fn wasm_query( &self, payload: T, - maybe_lag: Option, + block_height: Option, ) -> ChainResult>; /// query to specific contract address @@ -50,7 +50,7 @@ pub trait WasmProvider: Send + Sync { &self, to: String, payload: T, - maybe_lag: Option, + block_height: Option, ) -> ChainResult>; /// query account info @@ -133,41 +133,21 @@ impl WasmProvider for WasmGrpcProvider { Ok(height as u64) } - async fn wasm_query(&self, payload: T, maybe_lag: Option) -> ChainResult> + async fn wasm_query(&self, payload: T, block_height: Option) -> ChainResult> where T: Serialize + Send + Sync, { let mut client = WasmQueryClient::connect(self.get_conn_url()?).await?; - let mut request = tonic::Request::new(QuerySmartContractStateRequest { - address: self.get_contract_addr()?, - query_data: serde_json::to_string(&payload)?.as_bytes().to_vec(), - }); - - if let Some(lag) = maybe_lag { - let height = self.latest_block_height().await?; - let height = height.saturating_sub(lag.get()); - - request - .metadata_mut() - .insert("x-cosmos-block-height", height.into()); - } - - let response = client - .smart_contract_state(request) + self.wasm_query_to(self.get_contract_addr()?, payload, block_height) .await - .map_err(ChainCommunicationError::from_other)? - .into_inner(); - - // TODO: handle query to specific block number - Ok(response.data) } async fn wasm_query_to( &self, to: String, payload: T, - maybe_lag: Option, + block_height: Option, ) -> ChainResult> where T: Serialize + Send + Sync, @@ -178,13 +158,10 @@ impl WasmProvider for WasmGrpcProvider { query_data: serde_json::to_string(&payload)?.as_bytes().to_vec(), }); - if let Some(lag) = maybe_lag { - let height = self.latest_block_height().await?; - let height = height.saturating_sub(lag.get()); - + if let Some(block_height) = block_height { request .metadata_mut() - .insert("x-cosmos-block-height", height.into()); + .insert("x-cosmos-block-height", block_height.into()); } let response = client @@ -193,7 +170,6 @@ impl WasmProvider for WasmGrpcProvider { .map_err(ChainCommunicationError::from_other)? .into_inner(); - // TODO: handle query to specific block number Ok(response.data) } From d11b6e6e2002e015f14c249d8f70a9bbbb51decf Mon Sep 17 00:00:00 2001 From: Trevor Porter Date: Tue, 31 Oct 2023 17:51:07 +0000 Subject: [PATCH 2/3] Fix lag issue --- rust/chains/hyperlane-cosmos/src/lib.rs | 1 + rust/chains/hyperlane-cosmos/src/mailbox.rs | 70 +++++++------------ .../hyperlane-cosmos/src/merkle_tree_hook.rs | 13 +++- .../hyperlane-cosmos/src/providers/grpc.rs | 3 - rust/chains/hyperlane-cosmos/src/utils.rs | 23 ++++++ 5 files changed, 61 insertions(+), 49 deletions(-) create mode 100644 rust/chains/hyperlane-cosmos/src/utils.rs diff --git a/rust/chains/hyperlane-cosmos/src/lib.rs b/rust/chains/hyperlane-cosmos/src/lib.rs index ce1a211558..0480f72f5a 100644 --- a/rust/chains/hyperlane-cosmos/src/lib.rs +++ b/rust/chains/hyperlane-cosmos/src/lib.rs @@ -17,6 +17,7 @@ mod providers; mod routing_ism; mod signers; mod trait_builder; +mod utils; mod validator_announce; pub use self::{ diff --git a/rust/chains/hyperlane-cosmos/src/mailbox.rs b/rust/chains/hyperlane-cosmos/src/mailbox.rs index 0bc3d8ccc8..690c2375cb 100644 --- a/rust/chains/hyperlane-cosmos/src/mailbox.rs +++ b/rust/chains/hyperlane-cosmos/src/mailbox.rs @@ -11,7 +11,7 @@ use crate::payloads::mailbox::{ use crate::payloads::{general, mailbox}; use crate::rpc::{CosmosWasmIndexer, WasmIndexer}; use crate::CosmosProvider; -use crate::{signers::Signer, verify, ConnectionConf}; +use crate::{signers::Signer, utils::get_block_height_for_lag, verify, ConnectionConf}; use async_trait::async_trait; use cosmrs::proto::cosmos::base::abci::v1beta1::TxResponse; @@ -40,8 +40,7 @@ impl CosmosMailbox { /// Create a reference to a mailbox at a specific Ethereum address on some /// chain pub fn new(conf: ConnectionConf, locator: ContractLocator, signer: Signer) -> Self { - let provider: WasmGrpcProvider = - WasmGrpcProvider::new(conf.clone(), locator.clone(), signer.clone()); + let provider = WasmGrpcProvider::new(conf.clone(), locator.clone(), signer.clone()); Self { _conf: conf, @@ -80,7 +79,7 @@ impl Debug for CosmosMailbox { impl Mailbox for CosmosMailbox { #[instrument(level = "debug", err, ret, skip(self))] async fn count(&self, lag: Option) -> ChainResult { - let block_height = self.get_block_height_for_lag(lag).await?; + let block_height = get_block_height_for_lag(&self.provider, lag).await?; self.nonce_at_block(block_height).await } @@ -208,11 +207,29 @@ impl Mailbox for CosmosMailbox { } } +impl CosmosMailbox { + #[instrument(level = "debug", err, ret, skip(self))] + async fn nonce_at_block(&self, block_height: Option) -> ChainResult { + let payload = mailbox::NonceRequest { + nonce: general::EmptyStruct {}, + }; + + let data = self + .provider + .wasm_query(GeneralMailboxQuery { mailbox: payload }, block_height) + .await?; + + let response: mailbox::NonceResponse = serde_json::from_slice(&data)?; + + Ok(response.nonce) + } +} + /// Struct that retrieves event data for a Cosmos Mailbox contract #[derive(Debug)] pub struct CosmosMailboxIndexer { + mailbox: CosmosMailbox, indexer: Box, - provider: Box, } impl CosmosMailboxIndexer { @@ -224,13 +241,12 @@ impl CosmosMailboxIndexer { signer: Signer, event_type: String, ) -> Self { - let indexer: CosmosWasmIndexer = - CosmosWasmIndexer::new(conf.clone(), locator.clone(), event_type.clone()); - let provider: WasmGrpcProvider = WasmGrpcProvider::new(conf, locator, signer); + let mailbox = CosmosMailbox::new(conf.clone(), locator.clone(), signer.clone()); + let indexer: CosmosWasmIndexer = CosmosWasmIndexer::new(conf, locator, event_type); Self { + mailbox, indexer: Box::new(indexer), - provider: Box::new(provider), } } @@ -266,38 +282,6 @@ impl CosmosMailboxIndexer { None } } - - /// Given a lag, returns the block height at the moment. - /// If the lag is None, a block height of None is given, indicating that the - /// tip directly can be used. - async fn get_block_height_for_lag(&self, lag: Option) -> ChainResult> { - let block_height = match lag { - Some(lag) => { - let tip = self.indexer.latest_block_height().await?; - let block_height = tip as u64 - lag; - Some(block_height) - } - None => None, - }; - - Ok(block_height) - } - - #[instrument(level = "debug", err, ret, skip(self))] - async fn nonce_at_block(&self, block_height: Option) -> ChainResult { - let payload = mailbox::NonceRequest { - nonce: general::EmptyStruct {}, - }; - - let data = self - .provider - .wasm_query(GeneralMailboxQuery { mailbox: payload }, block_height) - .await?; - - let response: mailbox::NonceResponse = serde_json::from_slice(&data)?; - - Ok(response.nonce) - } } #[async_trait] @@ -349,8 +333,8 @@ impl SequenceIndexer for CosmosMailboxIndexer { async fn sequence_and_tip(&self) -> ChainResult<(Option, u32)> { let tip = self.indexer.latest_block_height().await?; - let sequence = self.nonce_at_block(Some(tip)).await?; + let sequence = self.mailbox.nonce_at_block(Some(tip.into())).await?; - Ok((sequence, tip)) + Ok((Some(sequence), tip)) } } diff --git a/rust/chains/hyperlane-cosmos/src/merkle_tree_hook.rs b/rust/chains/hyperlane-cosmos/src/merkle_tree_hook.rs index 2eb3f8d446..d6374b65fb 100644 --- a/rust/chains/hyperlane-cosmos/src/merkle_tree_hook.rs +++ b/rust/chains/hyperlane-cosmos/src/merkle_tree_hook.rs @@ -17,6 +17,7 @@ use crate::{ merkle_tree_hook, }, rpc::{CosmosWasmIndexer, WasmIndexer}, + utils::get_block_height_for_lag, ConnectionConf, CosmosProvider, Signer, }; @@ -75,13 +76,15 @@ impl MerkleTreeHook for CosmosMerkleTreeHook { tree: general::EmptyStruct {}, }; + let block_height = get_block_height_for_lag(&self.provider, lag).await?; + let data = self .provider .wasm_query( merkle_tree_hook::MerkleTreeGenericRequest { merkle_hook: payload, }, - lag, + block_height, ) .await?; let response: merkle_tree_hook::MerkleTreeResponse = serde_json::from_slice(&data)?; @@ -108,13 +111,15 @@ impl MerkleTreeHook for CosmosMerkleTreeHook { count: general::EmptyStruct {}, }; + let block_height = get_block_height_for_lag(&self.provider, lag).await?; + let data = self .provider .wasm_query( merkle_tree_hook::MerkleTreeGenericRequest { merkle_hook: payload, }, - lag, + block_height, ) .await?; let response: merkle_tree_hook::MerkleTreeCountResponse = serde_json::from_slice(&data)?; @@ -128,13 +133,15 @@ impl MerkleTreeHook for CosmosMerkleTreeHook { check_point: general::EmptyStruct {}, }; + let block_height = get_block_height_for_lag(&self.provider, lag).await?; + let data = self .provider .wasm_query( merkle_tree_hook::MerkleTreeGenericRequest { merkle_hook: payload, }, - lag, + block_height, ) .await?; let response: merkle_tree_hook::CheckPointResponse = serde_json::from_slice(&data)?; diff --git a/rust/chains/hyperlane-cosmos/src/providers/grpc.rs b/rust/chains/hyperlane-cosmos/src/providers/grpc.rs index d50c28b3bc..027294a935 100644 --- a/rust/chains/hyperlane-cosmos/src/providers/grpc.rs +++ b/rust/chains/hyperlane-cosmos/src/providers/grpc.rs @@ -24,7 +24,6 @@ use hyperlane_core::{ ChainCommunicationError, ChainResult, ContractLocator, HyperlaneDomain, H256, U256, }; use serde::Serialize; -use std::num::NonZeroU64; use crate::verify; use crate::{signers::Signer, ConnectionConf}; @@ -137,8 +136,6 @@ impl WasmProvider for WasmGrpcProvider { where T: Serialize + Send + Sync, { - let mut client = WasmQueryClient::connect(self.get_conn_url()?).await?; - self.wasm_query_to(self.get_contract_addr()?, payload, block_height) .await } diff --git a/rust/chains/hyperlane-cosmos/src/utils.rs b/rust/chains/hyperlane-cosmos/src/utils.rs new file mode 100644 index 0000000000..22abd23585 --- /dev/null +++ b/rust/chains/hyperlane-cosmos/src/utils.rs @@ -0,0 +1,23 @@ +use std::num::NonZeroU64; + +use crate::grpc::{WasmGrpcProvider, WasmProvider}; +use hyperlane_core::ChainResult; + +/// Given a lag, returns the block height at the moment. +/// If the lag is None, a block height of None is given, indicating that the +/// tip directly can be used. +pub(crate) async fn get_block_height_for_lag( + provider: &WasmGrpcProvider, + lag: Option, +) -> ChainResult> { + let block_height = match lag { + Some(lag) => { + let tip = provider.latest_block_height().await?; + let block_height = tip as u64 - lag.get(); + Some(block_height) + } + None => None, + }; + + Ok(block_height) +} From 5dd03a8df2b8d59c87ea0e2abe9450f896c418c5 Mon Sep 17 00:00:00 2001 From: Trevor Porter Date: Tue, 31 Oct 2023 18:07:24 +0000 Subject: [PATCH 3/3] fix clippy --- rust/chains/hyperlane-cosmos/src/utils.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/rust/chains/hyperlane-cosmos/src/utils.rs b/rust/chains/hyperlane-cosmos/src/utils.rs index 22abd23585..86dc4de736 100644 --- a/rust/chains/hyperlane-cosmos/src/utils.rs +++ b/rust/chains/hyperlane-cosmos/src/utils.rs @@ -13,7 +13,7 @@ pub(crate) async fn get_block_height_for_lag( let block_height = match lag { Some(lag) => { let tip = provider.latest_block_height().await?; - let block_height = tip as u64 - lag.get(); + let block_height = tip - lag.get(); Some(block_height) } None => None,