Skip to content

Commit

Permalink
Allow disabling of ICS31 Cross Chain Queries (#4041)
Browse files Browse the repository at this point in the history
* Add configuration to disable relaying of ICS31 Cross Chain Queries

* Update and add a test for ICS31 Cross Chain Queries

* Add changelog entry

* Add 'allow_ccq' config to example config with documentation

* Add allow_ccq() method to ChainConfig
  • Loading branch information
ljoss17 authored Jun 21, 2024
1 parent b9b6663 commit 7e3f11e
Show file tree
Hide file tree
Showing 9 changed files with 71 additions and 15 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
- Add a new per-chain configuration `allow_ccq` to enable or disable
relaying of ICS31 Cross Chain Query packets.
([\#4040](https://github.com/informalsystems/hermes/issues/4040))
7 changes: 7 additions & 0 deletions config.toml
Original file line number Diff line number Diff line change
Expand Up @@ -453,6 +453,13 @@ memo_prefix = ''
# Default: No filter
# excluded_sequences = {}

# Enable or disable relaying of ICS31 Cross Chain Query packets.
# If this configuration is set to false, Hermes will skip ICS31
# Cross Chain Query packets.
#
# Default: true
# allow_ccq = true

[[chains]]
id = 'ibc-1'
rpc_addr = 'http://127.0.0.1:26557'
Expand Down
1 change: 1 addition & 0 deletions crates/relayer-cli/src/chain_registry.rs
Original file line number Diff line number Diff line change
Expand Up @@ -169,6 +169,7 @@ where
compat_mode: None,
clear_interval: None,
excluded_sequences: ExcludedSequences::new(BTreeMap::new()),
allow_ccq: true,
}))
}

Expand Down
3 changes: 3 additions & 0 deletions crates/relayer/src/chain/cosmos/config.rs
Original file line number Diff line number Diff line change
Expand Up @@ -149,6 +149,9 @@ pub struct CosmosSdkConfig {
pub clear_interval: Option<u64>,
#[serde(default)]
pub excluded_sequences: ExcludedSequences,

#[serde(default = "default::allow_ccq")]
pub allow_ccq: bool,
}

impl CosmosSdkConfig {
Expand Down
10 changes: 10 additions & 0 deletions crates/relayer/src/config.rs
Original file line number Diff line number Diff line change
Expand Up @@ -246,6 +246,10 @@ pub mod default {
pub fn ics20_max_receiver_size() -> Ics20FieldSizeLimit {
Ics20FieldSizeLimit::new(true, Byte::from_bytes(2048))
}

pub fn allow_ccq() -> bool {
true
}
}

#[derive(Clone, Debug, Default, Deserialize, Serialize)]
Expand Down Expand Up @@ -725,6 +729,12 @@ impl ChainConfig {
.unwrap_or_else(|| Cow::Owned(Vec::new())),
}
}

pub fn allow_ccq(&self) -> bool {
match self {
Self::CosmosSdk(config) => config.allow_ccq,
}
}
}

// /!\ Update me when adding a new chain type!
Expand Down
28 changes: 18 additions & 10 deletions crates/relayer/src/worker.rs
Original file line number Diff line number Diff line change
Expand Up @@ -209,16 +209,24 @@ pub fn spawn_worker_tasks<ChainA: ChainHandle, ChainB: ChainHandle>(
}

Object::CrossChainQuery(cross_chain_query) => {
let (cmd_tx, cmd_rx) = crossbeam_channel::unbounded();
let cross_chain_query_task = cross_chain_query::spawn_cross_chain_query_worker(
chains.a.clone(),
chains.b,
cmd_rx,
cross_chain_query.clone(),
);
task_handles.push(cross_chain_query_task);

(Some(cmd_tx), None)
if config
.chains
.iter()
.any(|chain| chain.id() == &cross_chain_query.dst_chain_id && chain.allow_ccq())
{
let (cmd_tx, cmd_rx) = crossbeam_channel::unbounded();
let cross_chain_query_task = cross_chain_query::spawn_cross_chain_query_worker(
chains.a.clone(),
chains.b,
cmd_rx,
cross_chain_query.clone(),
);
task_handles.push(cross_chain_query_task);

(Some(cmd_tx), None)
} else {
(None, None)
}
}
};

Expand Down
31 changes: 27 additions & 4 deletions tools/integration-test/src/tests/interchain_security/icq.rs
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@
//! The test then waits for a Cross-chain Query to be pending and
//! then processed.
use ibc_relayer::config::ChainConfig;
use ibc_test_framework::chain::cli::host_zone::register_host_zone;
use ibc_test_framework::chain::config::{
set_crisis_denom, set_mint_mint_denom, set_staking_bond_denom, set_staking_max_entries,
Expand All @@ -27,10 +28,17 @@ use ibc_test_framework::util::random::random_u128_range;

#[test]
fn test_ics31_cross_chain_queries() -> Result<(), Error> {
run_binary_interchain_security_channel_test(&InterchainSecurityIcqTest)
run_binary_interchain_security_channel_test(&InterchainSecurityIcqTest { allow_ccq: true })
}

struct InterchainSecurityIcqTest;
#[test]
fn test_disable_ics31_cross_chain_queries() -> Result<(), Error> {
run_binary_interchain_security_channel_test(&InterchainSecurityIcqTest { allow_ccq: false })
}

struct InterchainSecurityIcqTest {
pub allow_ccq: bool,
}

impl TestOverrides for InterchainSecurityIcqTest {
fn modify_genesis_file(&self, genesis: &mut serde_json::Value) -> Result<(), Error> {
Expand Down Expand Up @@ -81,6 +89,14 @@ impl TestOverrides for InterchainSecurityIcqTest {
config.mode.channels.enabled = true;

update_relayer_config_for_consumer_chain(config);

for chain in config.chains.iter_mut() {
match chain {
ChainConfig::CosmosSdk(chain_config) => {
chain_config.allow_ccq = self.allow_ccq;
}
}
}
}
}

Expand Down Expand Up @@ -175,10 +191,17 @@ impl BinaryChannelTest for InterchainSecurityIcqTest {
.assert_pending_cross_chain_query()?;

// After there is a pending cross chain query, wait for it to be processed
chains
let processed_ccqs = chains
.node_b
.chain_driver()
.assert_processed_cross_chain_query()?;
.assert_processed_cross_chain_query();

if self.allow_ccq {
assert!(processed_ccqs.is_ok());
} else {
assert!(processed_ccqs.is_err());
}

Ok(())
}
}
2 changes: 1 addition & 1 deletion tools/test-framework/src/chain/ext/crosschainquery.rs
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ use crate::types::tagged::MonoTagged;
If you encounter retry error, verify the value of `stride_epoch`in
the `stride_epoch` configuration in Stride's `genesis.toml` file.
*/
const WAIT_CROSS_CHAIN_QUERY_ATTEMPTS: u16 = 100;
const WAIT_CROSS_CHAIN_QUERY_ATTEMPTS: u16 = 30;

pub trait CrossChainQueryMethodsExt<Chain> {
fn assert_pending_cross_chain_query(&self) -> Result<(), Error>;
Expand Down
1 change: 1 addition & 0 deletions tools/test-framework/src/types/single/node.rs
Original file line number Diff line number Diff line change
Expand Up @@ -200,6 +200,7 @@ impl FullNode {
compat_mode,
clear_interval: None,
excluded_sequences: ExcludedSequences::new(BTreeMap::new()),
allow_ccq: true,
}))
}

Expand Down

0 comments on commit 7e3f11e

Please sign in to comment.