Skip to content

Commit

Permalink
fix: add frozen client check for create_client handler (#1063)
Browse files Browse the repository at this point in the history
* fix: add frozen client check for create_client handler

* imp: merge assert checks for test
  • Loading branch information
Farhad-Shabani authored Jan 26, 2024
1 parent f8828f7 commit 752536c
Show file tree
Hide file tree
Showing 3 changed files with 51 additions and 5 deletions.
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
- [ibc-client-tendermint-types] Ease frozen Height check in the tendermint
`ClientState` protobuf deserialization
([\#1061](https://github.com/cosmos/ibc-rs/issues/1061))
`ClientState` protobuf deserialization, and consequently include frozen client
check for client creation path.
([\#1061](https://github.com/cosmos/ibc-rs/issues/1061)),
([\#1063](https://github.com/cosmos/ibc-rs/pull/1063))
17 changes: 14 additions & 3 deletions ibc-core/ics02-client/src/handler/create_client.rs
Original file line number Diff line number Diff line change
@@ -1,6 +1,8 @@
//! Protocol logic specific to processing ICS2 messages of type `MsgCreateClient`.
use ibc_core_client_context::client_state::{ClientStateCommon, ClientStateExecution};
use ibc_core_client_context::client_state::{
ClientStateCommon, ClientStateExecution, ClientStateValidation,
};
use ibc_core_client_types::error::ClientError;
use ibc_core_client_types::events::CreateClient;
use ibc_core_client_types::msgs::MsgCreateClient;
Expand All @@ -26,10 +28,19 @@ where

let client_state = ctx.decode_client_state(client_state)?;

client_state.verify_consensus_state(consensus_state)?;

let client_id = client_state.client_type().build_client_id(id_counter);

let status = client_state.status(ctx.get_client_validation_context(), &client_id)?;

if status.is_frozen() {
return Err(ClientError::ClientFrozen {
description: "the client is frozen".to_string(),
}
.into());
};

client_state.verify_consensus_state(consensus_state)?;

if ctx.client_state(&client_id).is_ok() {
return Err(ClientError::ClientStateAlreadyExists { client_id }.into());
};
Expand Down
33 changes: 33 additions & 0 deletions ibc-testkit/tests/core/ics02_client/create_client.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,9 +2,11 @@ use ibc::clients::tendermint::types::{
client_type as tm_client_type, ConsensusState as TmConsensusState,
};
use ibc::core::client::context::client_state::ClientStateCommon;
use ibc::core::client::types::error::ClientError;
use ibc::core::client::types::msgs::{ClientMsg, MsgCreateClient};
use ibc::core::client::types::Height;
use ibc::core::entrypoint::{execute, validate};
use ibc::core::handler::types::error::ContextError;
use ibc::core::handler::types::msgs::MsgEnvelope;
use ibc::core::host::ValidationContext;
use ibc_testkit::fixtures::clients::tendermint::{
Expand Down Expand Up @@ -86,3 +88,34 @@ fn test_tm_create_client_ok() {
assert_eq!(expected_client_state.client_type(), client_type);
assert_eq!(ctx.client_state(&client_id).unwrap(), expected_client_state);
}

#[test]
fn test_invalid_frozen_tm_client_creation() {
let signer = dummy_account_id();

let ctx = MockContext::default();

let router = MockRouter::new_with_transfer();

let tm_header = dummy_tendermint_header();

let tm_client_state = dummy_tm_client_state_from_header(tm_header.clone())
.inner()
.clone()
.with_frozen_height(Height::min(0));

let msg = MsgCreateClient::new(
tm_client_state.into(),
TmConsensusState::from(tm_header).into(),
signer,
);

let msg_envelope = MsgEnvelope::from(ClientMsg::from(msg.clone()));

let res = validate(&ctx, &router, msg_envelope.clone());

assert!(matches!(
res,
Err(ContextError::ClientError(ClientError::ClientFrozen { .. }))
))
}

0 comments on commit 752536c

Please sign in to comment.