From 7287613e76e7a8358c888ef9e5f821f7506fe5db Mon Sep 17 00:00:00 2001 From: Richard Janis Goldschmidt Date: Thu, 3 Oct 2024 19:14:48 +0200 Subject: [PATCH] chore(proto, core)!: remove Action suffix from all action types --- crates/astria-bridge-contracts/src/lib.rs | 2 +- .../helpers/test_bridge_withdrawer.rs | 6 +- .../astria-cli/src/sequencer/bridge_lock.rs | 4 +- .../src/sequencer/init_bridge_account.rs | 4 +- .../src/sequencer/sudo/fee_asset.rs | 6 +- .../src/sequencer/sudo/ibc_relayer.rs | 6 +- .../src/sequencer/sudo/sudo_address_change.rs | 4 +- crates/astria-cli/src/sequencer/transfer.rs | 4 +- crates/astria-composer/src/collectors/geth.rs | 6 +- crates/astria-composer/src/collectors/grpc.rs | 4 +- .../astria-composer/src/executor/builder.rs | 4 +- .../src/executor/bundle_factory/mod.rs | 21 +- .../src/executor/bundle_factory/tests.rs | 8 +- crates/astria-composer/src/executor/mod.rs | 14 +- crates/astria-composer/src/executor/tests.rs | 14 +- crates/astria-composer/src/test_utils.rs | 12 +- .../astria.protocol.transactions.v1alpha1.rs | 136 +-- ...ia.protocol.transactions.v1alpha1.serde.rs | 451 +++++----- crates/astria-core/src/protocol/test_utils.rs | 4 +- .../protocol/transaction/v1alpha1/action.rs | 776 ++++++++---------- .../transaction/v1alpha1/action_group/mod.rs | 66 +- .../v1alpha1/action_group/tests.rs | 54 +- .../src/protocol/transaction/v1alpha1/mod.rs | 6 +- .../src/sequencerblock/v1alpha1/block.rs | 2 +- .../astria-sequencer-client/src/tests/http.rs | 4 +- .../astria-sequencer/src/accounts/action.rs | 10 +- crates/astria-sequencer/src/app/test_utils.rs | 4 +- .../src/app/tests_app/mempool.rs | 22 +- .../astria-sequencer/src/app/tests_app/mod.rs | 24 +- .../src/app/tests_block_fees.rs | 22 +- .../src/app/tests_breaking_changes.rs | 52 +- .../src/app/tests_execute_transaction.rs | 94 +-- .../astria-sequencer/src/authority/action.rs | 50 +- .../src/bridge/bridge_lock_action.rs | 10 +- .../src/bridge/bridge_sudo_change_action.rs | 8 +- .../src/bridge/bridge_unlock_action.rs | 18 +- .../src/bridge/init_bridge_account_action.rs | 4 +- .../astria-sequencer/src/fee_asset_change.rs | 8 +- .../src/ibc/ibc_relayer_change.rs | 10 +- .../src/proposal/commitment.rs | 12 +- .../astria-sequencer/src/sequence/action.rs | 4 +- .../astria-sequencer/src/service/consensus.rs | 4 +- .../src/transaction/checks.rs | 16 +- .../transactions/v1alpha1/types.proto | 68 +- 44 files changed, 983 insertions(+), 1075 deletions(-) diff --git a/crates/astria-bridge-contracts/src/lib.rs b/crates/astria-bridge-contracts/src/lib.rs index f6cb8b7b8f..454f3df0a2 100644 --- a/crates/astria-bridge-contracts/src/lib.rs +++ b/crates/astria-bridge-contracts/src/lib.rs @@ -464,7 +464,7 @@ where let to = parse_destination_chain_as_address(&event) .map_err(GetWithdrawalActionsError::destination_chain_as_address)?; - let action = astria_core::protocol::transaction::v1alpha1::action::BridgeUnlockAction { + let action = astria_core::protocol::transaction::v1alpha1::action::BridgeUnlock { to, amount, rollup_block_number, diff --git a/crates/astria-bridge-withdrawer/tests/blackbox/helpers/test_bridge_withdrawer.rs b/crates/astria-bridge-withdrawer/tests/blackbox/helpers/test_bridge_withdrawer.rs index 7048b4cf2f..18006aaf34 100644 --- a/crates/astria-bridge-withdrawer/tests/blackbox/helpers/test_bridge_withdrawer.rs +++ b/crates/astria-bridge-withdrawer/tests/blackbox/helpers/test_bridge_withdrawer.rs @@ -22,7 +22,7 @@ use astria_core::{ memos::v1alpha1::Ics20WithdrawalFromRollup, transaction::v1alpha1::{ action::{ - BridgeUnlockAction, + BridgeUnlock, Ics20Withdrawal, }, Action, @@ -435,7 +435,7 @@ pub fn make_native_bridge_unlock_action(receipt: &TransactionReceipt) -> Action let rollup_transaction_hash = receipt.transaction_hash.encode_hex(); let event_index = receipt.logs[0].log_index.unwrap().encode_hex(); - let inner = BridgeUnlockAction { + let inner = BridgeUnlock { to: default_sequencer_address(), amount: 1_000_000u128, rollup_block_number: receipt.block_number.unwrap().as_u64(), @@ -485,7 +485,7 @@ pub fn make_erc20_bridge_unlock_action(receipt: &TransactionReceipt) -> Action { // use the second event because the erc20 transfer also emits an event let event_index = receipt.logs[1].log_index.unwrap().encode_hex(); - let inner = BridgeUnlockAction { + let inner = BridgeUnlock { to: default_sequencer_address(), amount: 1_000_000u128, rollup_block_number: receipt.block_number.unwrap().as_u64(), diff --git a/crates/astria-cli/src/sequencer/bridge_lock.rs b/crates/astria-cli/src/sequencer/bridge_lock.rs index baeabbc717..4c07db8040 100644 --- a/crates/astria-cli/src/sequencer/bridge_lock.rs +++ b/crates/astria-cli/src/sequencer/bridge_lock.rs @@ -4,7 +4,7 @@ use astria_core::{ Address, }, protocol::transaction::v1alpha1::{ - action::BridgeLockAction, + action::BridgeLock, Action, }, }; @@ -62,7 +62,7 @@ impl Command { self.sequencer_chain_id.clone(), &self.prefix, self.private_key.as_str(), - Action::BridgeLock(BridgeLockAction { + Action::BridgeLock(BridgeLock { to: self.to_address, asset: self.asset.clone(), amount: self.amount, diff --git a/crates/astria-cli/src/sequencer/init_bridge_account.rs b/crates/astria-cli/src/sequencer/init_bridge_account.rs index 1e411457eb..9149909ecb 100644 --- a/crates/astria-cli/src/sequencer/init_bridge_account.rs +++ b/crates/astria-cli/src/sequencer/init_bridge_account.rs @@ -1,7 +1,7 @@ use astria_core::{ primitive::v1::asset, protocol::transaction::v1alpha1::{ - action::InitBridgeAccountAction, + action::InitBridgeAccount, Action, }, }; @@ -57,7 +57,7 @@ impl Command { self.sequencer_chain_id.clone(), &self.prefix, self.private_key.as_str(), - Action::InitBridgeAccount(InitBridgeAccountAction { + Action::InitBridgeAccount(InitBridgeAccount { rollup_id, asset: self.asset.clone(), fee_asset: self.fee_asset.clone(), diff --git a/crates/astria-cli/src/sequencer/sudo/fee_asset.rs b/crates/astria-cli/src/sequencer/sudo/fee_asset.rs index 181c833cda..f1ac0a750a 100644 --- a/crates/astria-cli/src/sequencer/sudo/fee_asset.rs +++ b/crates/astria-cli/src/sequencer/sudo/fee_asset.rs @@ -1,7 +1,7 @@ use astria_core::{ primitive::v1::asset, protocol::transaction::v1alpha1::{ - action::FeeAssetChangeAction, + action::FeeAssetChange, Action, }, }; @@ -50,7 +50,7 @@ impl Add { args.sequencer_chain_id.clone(), &args.prefix, args.private_key.as_str(), - Action::FeeAssetChange(FeeAssetChangeAction::Addition(args.asset.clone())), + Action::FeeAssetChange(FeeAssetChange::Addition(args.asset.clone())), ) .await .wrap_err("failed to submit FeeAssetChangeAction::Addition transaction")?; @@ -75,7 +75,7 @@ impl Remove { args.sequencer_chain_id.clone(), &args.prefix, args.private_key.as_str(), - Action::FeeAssetChange(FeeAssetChangeAction::Removal(args.asset.clone())), + Action::FeeAssetChange(FeeAssetChange::Removal(args.asset.clone())), ) .await .wrap_err("failed to submit FeeAssetChangeAction::Removal transaction")?; diff --git a/crates/astria-cli/src/sequencer/sudo/ibc_relayer.rs b/crates/astria-cli/src/sequencer/sudo/ibc_relayer.rs index f8c190b157..8ec116cc79 100644 --- a/crates/astria-cli/src/sequencer/sudo/ibc_relayer.rs +++ b/crates/astria-cli/src/sequencer/sudo/ibc_relayer.rs @@ -1,7 +1,7 @@ use astria_core::{ primitive::v1::Address, protocol::transaction::v1alpha1::{ - action::IbcRelayerChangeAction, + action::IbcRelayerChange, Action, }, }; @@ -47,7 +47,7 @@ impl Add { args.sequencer_chain_id.clone(), &args.prefix, args.private_key.as_str(), - Action::IbcRelayerChange(IbcRelayerChangeAction::Addition(args.address)), + Action::IbcRelayerChange(IbcRelayerChange::Addition(args.address)), ) .await .wrap_err("failed to submit IbcRelayerChangeAction::Addition transaction")?; @@ -72,7 +72,7 @@ impl Remove { args.sequencer_chain_id.clone(), &args.prefix, args.private_key.as_str(), - Action::IbcRelayerChange(IbcRelayerChangeAction::Removal(args.address)), + Action::IbcRelayerChange(IbcRelayerChange::Removal(args.address)), ) .await .wrap_err("failed to submit IbcRelayerChangeAction::Removal transaction")?; diff --git a/crates/astria-cli/src/sequencer/sudo/sudo_address_change.rs b/crates/astria-cli/src/sequencer/sudo/sudo_address_change.rs index f93277440e..ecfcf2b823 100644 --- a/crates/astria-cli/src/sequencer/sudo/sudo_address_change.rs +++ b/crates/astria-cli/src/sequencer/sudo/sudo_address_change.rs @@ -1,7 +1,7 @@ use astria_core::{ primitive::v1::Address, protocol::transaction::v1alpha1::{ - action::SudoAddressChangeAction, + action::SudoAddressChange, Action, }, }; @@ -49,7 +49,7 @@ impl Command { self.sequencer_chain_id.clone(), &self.prefix, self.private_key.as_str(), - Action::SudoAddressChange(SudoAddressChangeAction { + Action::SudoAddressChange(SudoAddressChange { new_address: self.address, }), ) diff --git a/crates/astria-cli/src/sequencer/transfer.rs b/crates/astria-cli/src/sequencer/transfer.rs index 648156cd3e..7903d04fcf 100644 --- a/crates/astria-cli/src/sequencer/transfer.rs +++ b/crates/astria-cli/src/sequencer/transfer.rs @@ -4,7 +4,7 @@ use astria_core::{ Address, }, protocol::transaction::v1alpha1::{ - action::TransferAction, + action::Transfer, Action, }, }; @@ -61,7 +61,7 @@ impl Command { self.sequencer_chain_id.clone(), &self.prefix, self.private_key.as_str(), - Action::Transfer(TransferAction { + Action::Transfer(Transfer { to: self.to_address, amount: self.amount, asset: self.asset.clone(), diff --git a/crates/astria-composer/src/collectors/geth.rs b/crates/astria-composer/src/collectors/geth.rs index c2e4e4601a..3e0c190ee9 100644 --- a/crates/astria-composer/src/collectors/geth.rs +++ b/crates/astria-composer/src/collectors/geth.rs @@ -20,7 +20,7 @@ use astria_core::{ asset, RollupId, }, - protocol::transaction::v1alpha1::action::SequenceAction, + protocol::transaction::v1alpha1::action::Sequence, }; use astria_eyre::eyre::{ self, @@ -194,7 +194,7 @@ impl Geth { if let Some(tx) = tx_res { let tx_hash = tx.hash; let data = tx.rlp().to_vec(); - let seq_action = SequenceAction { + let seq_action = Sequence { rollup_id, data: data.into(), fee_asset: fee_asset.clone(), @@ -234,7 +234,7 @@ impl Geth { #[instrument(skip_all)] async fn forward_geth_tx( executor_handle: &Handle, - seq_action: SequenceAction, + seq_action: Sequence, tx_hash: ethers::types::H256, txs_dropped_counter: &Counter, ) -> eyre::Result<()> { diff --git a/crates/astria-composer/src/collectors/grpc.rs b/crates/astria-composer/src/collectors/grpc.rs index 091cca23b2..ca378960f6 100644 --- a/crates/astria-composer/src/collectors/grpc.rs +++ b/crates/astria-composer/src/collectors/grpc.rs @@ -12,7 +12,7 @@ use astria_core::{ asset, RollupId, }, - protocol::transaction::v1alpha1::action::SequenceAction, + protocol::transaction::v1alpha1::action::Sequence, }; use tokio::sync::mpsc::error::SendTimeoutError; use tonic::{ @@ -62,7 +62,7 @@ impl GrpcCollectorService for Grpc { return Err(Status::invalid_argument("invalid rollup id")); }; - let sequence_action = SequenceAction { + let sequence_action = Sequence { rollup_id, data: submit_rollup_tx_request.data, fee_asset: self.fee_asset.clone(), diff --git a/crates/astria-composer/src/executor/builder.rs b/crates/astria-composer/src/executor/builder.rs index 7234600f05..b84ef794d6 100644 --- a/crates/astria-composer/src/executor/builder.rs +++ b/crates/astria-composer/src/executor/builder.rs @@ -7,7 +7,7 @@ use std::{ use astria_core::{ crypto::SigningKey, primitive::v1::Address, - protocol::transaction::v1alpha1::action::SequenceAction, + protocol::transaction::v1alpha1::action::Sequence, }; use astria_eyre::eyre::{ self, @@ -63,7 +63,7 @@ impl Builder { .wrap_err("failed constructing a sequencer address from private key")?; let (serialized_rollup_transaction_tx, serialized_rollup_transaction_rx) = - tokio::sync::mpsc::channel::(256); + tokio::sync::mpsc::channel::(256); Ok(( super::Executor { diff --git a/crates/astria-composer/src/executor/bundle_factory/mod.rs b/crates/astria-composer/src/executor/bundle_factory/mod.rs index f4fb47eaaa..b32938f6bf 100644 --- a/crates/astria-composer/src/executor/bundle_factory/mod.rs +++ b/crates/astria-composer/src/executor/bundle_factory/mod.rs @@ -11,7 +11,7 @@ use std::{ use astria_core::{ primitive::v1::RollupId, protocol::transaction::v1alpha1::{ - action::SequenceAction, + action::Sequence, Action, UnsignedTransaction, }, @@ -29,9 +29,9 @@ mod tests; #[derive(Debug, thiserror::Error)] enum SizedBundleError { #[error("bundle does not have enough space left for the given sequence action")] - NotEnoughSpace(SequenceAction), + NotEnoughSpace(Sequence), #[error("sequence action is larger than the max bundle size")] - SequenceActionTooLarge(SequenceAction), + SequenceActionTooLarge(Sequence), } pub(super) struct SizedBundleReport<'a>(pub(super) &'a SizedBundle); @@ -100,7 +100,7 @@ impl SizedBundle { /// # Errors /// - `seq_action` is beyond the max size allowed for the entire bundle /// - `seq_action` does not fit in the remaining space in the bundle - fn try_push(&mut self, seq_action: SequenceAction) -> Result<(), SizedBundleError> { + fn try_push(&mut self, seq_action: Sequence) -> Result<(), SizedBundleError> { let seq_action_size = encoded_len(&seq_action); if seq_action_size > self.max_size { @@ -162,7 +162,7 @@ pub(super) struct FinishedQueueFull { curr_bundle_size: usize, finished_queue_capacity: usize, sequence_action_size: usize, - seq_action: SequenceAction, + seq_action: Sequence, } impl From for BundleFactoryError { @@ -196,10 +196,7 @@ impl BundleFactory { /// Buffer `seq_action` into the current bundle. If the bundle won't fit `seq_action`, flush /// `curr_bundle` into the `finished` queue and start a new bundle, unless the `finished` queue /// is at capacity. - pub(super) fn try_push( - &mut self, - seq_action: SequenceAction, - ) -> Result<(), BundleFactoryError> { + pub(super) fn try_push(&mut self, seq_action: Sequence) -> Result<(), BundleFactoryError> { let seq_action = with_ibc_prefixed(seq_action); let seq_action_size = encoded_len(&seq_action); @@ -289,14 +286,14 @@ impl<'a> NextFinishedBundle<'a> { } } -fn with_ibc_prefixed(action: SequenceAction) -> SequenceAction { - SequenceAction { +fn with_ibc_prefixed(action: Sequence) -> Sequence { + Sequence { fee_asset: action.fee_asset.to_ibc_prefixed().into(), ..action } } -fn encoded_len(action: &SequenceAction) -> usize { +fn encoded_len(action: &Sequence) -> usize { use prost::Message as _; action.to_raw().encoded_len() } diff --git a/crates/astria-composer/src/executor/bundle_factory/tests.rs b/crates/astria-composer/src/executor/bundle_factory/tests.rs index 762934782e..31c6e2de8b 100644 --- a/crates/astria-composer/src/executor/bundle_factory/tests.rs +++ b/crates/astria-composer/src/executor/bundle_factory/tests.rs @@ -3,7 +3,7 @@ use astria_core::{ RollupId, ROLLUP_ID_LEN, }, - protocol::transaction::v1alpha1::action::SequenceAction, + protocol::transaction::v1alpha1::action::Sequence, }; mod sized_bundle { @@ -203,7 +203,7 @@ mod bundle_factory { // try to push a third bundle that wouldn't fit in `curr_bundle`, forcing the factory to // flush it into `finished` this shouldn't work since the `finished` queue's // capacity is 1. - let seq_action1 = SequenceAction { + let seq_action1 = Sequence { rollup_id: RollupId::new([1; ROLLUP_ID_LEN]), ..sequence_action_of_max_size(200) }; @@ -256,7 +256,7 @@ mod bundle_factory { // push another sequence action that is <100 bytes total to force the current bundle to // flush - let seq_action1 = SequenceAction { + let seq_action1 = Sequence { rollup_id: RollupId::new([1; ROLLUP_ID_LEN]), ..sequence_action_of_max_size(200) }; @@ -290,7 +290,7 @@ mod bundle_factory { let seq_action0 = sequence_action_of_max_size(200); bundle_factory.try_push(seq_action0.clone()).unwrap(); - let seq_action1 = SequenceAction { + let seq_action1 = Sequence { rollup_id: RollupId::new([1; ROLLUP_ID_LEN]), ..sequence_action_of_max_size(200) }; diff --git a/crates/astria-composer/src/executor/mod.rs b/crates/astria-composer/src/executor/mod.rs index 26260cbfaa..f1512d43b7 100644 --- a/crates/astria-composer/src/executor/mod.rs +++ b/crates/astria-composer/src/executor/mod.rs @@ -15,7 +15,7 @@ use astria_core::{ protocol::{ abci::AbciErrorCode, transaction::v1alpha1::{ - action::SequenceAction, + action::Sequence, SignedTransaction, }, }, @@ -120,7 +120,7 @@ pub(super) struct Executor { // The status of this executor status: watch::Sender, // Channel for receiving `SequenceAction`s to be bundled. - serialized_rollup_transactions: mpsc::Receiver, + serialized_rollup_transactions: mpsc::Receiver, // The client for submitting wrapped and signed pending eth transactions to the astria // sequencer. sequencer_client: sequencer_client::HttpClient, @@ -143,11 +143,11 @@ pub(super) struct Executor { #[derive(Clone)] pub(super) struct Handle { - serialized_rollup_transactions_tx: mpsc::Sender, + serialized_rollup_transactions_tx: mpsc::Sender, } impl Handle { - fn new(serialized_rollup_transactions_tx: mpsc::Sender) -> Self { + fn new(serialized_rollup_transactions_tx: mpsc::Sender) -> Self { Self { serialized_rollup_transactions_tx, } @@ -156,9 +156,9 @@ impl Handle { #[instrument(skip_all, err)] pub(super) async fn send_timeout( &self, - sequence_action: SequenceAction, + sequence_action: Sequence, timeout: Duration, - ) -> Result<(), SendTimeoutError> { + ) -> Result<(), SendTimeoutError> { self.serialized_rollup_transactions_tx .send_timeout(sequence_action, timeout) .await @@ -446,7 +446,7 @@ impl Executor { /// Pushes sequence action into current bundle, warning and dropping on failure. #[instrument(skip_all)] - fn bundle_seq_action(&self, seq_action: SequenceAction, bundle_factory: &mut BundleFactory) { + fn bundle_seq_action(&self, seq_action: Sequence, bundle_factory: &mut BundleFactory) { let rollup_id = seq_action.rollup_id; if let Err(e) = bundle_factory.try_push(seq_action) { diff --git a/crates/astria-composer/src/executor/tests.rs b/crates/astria-composer/src/executor/tests.rs index bf0f8d9ee9..5abb7c6ff7 100644 --- a/crates/astria-composer/src/executor/tests.rs +++ b/crates/astria-composer/src/executor/tests.rs @@ -18,7 +18,7 @@ use astria_core::{ RollupId, ROLLUP_ID_LEN, }, - protocol::transaction::v1alpha1::action::SequenceAction, + protocol::transaction::v1alpha1::action::Sequence, }; use astria_eyre::eyre; use prost::{ @@ -111,8 +111,8 @@ static TELEMETRY: LazyLock<()> = LazyLock::new(|| { } }); -fn sequence_action() -> SequenceAction { - SequenceAction { +fn sequence_action() -> Sequence { + Sequence { rollup_id: RollupId::new([0; ROLLUP_ID_LEN]), data: Bytes::new(), fee_asset: "nria".parse().unwrap(), @@ -354,7 +354,7 @@ async fn full_bundle() { // order to make space for the second let seq0 = sequence_action_of_max_size(cfg.max_bytes_per_bundle); - let seq1 = SequenceAction { + let seq1 = Sequence { rollup_id: RollupId::new([1; ROLLUP_ID_LEN]), ..sequence_action_of_max_size(cfg.max_bytes_per_bundle) }; @@ -443,7 +443,7 @@ async fn bundle_triggered_by_block_timer() { // send two sequence actions to the executor, both small enough to fit in a single bundle // without filling it - let seq0 = SequenceAction { + let seq0 = Sequence { data: vec![0u8; cfg.max_bytes_per_bundle / 4].into(), ..sequence_action() }; @@ -530,12 +530,12 @@ async fn two_seq_actions_single_bundle() { // send two sequence actions to the executor, both small enough to fit in a single bundle // without filling it - let seq0 = SequenceAction { + let seq0 = Sequence { data: vec![0u8; cfg.max_bytes_per_bundle / 4].into(), ..sequence_action() }; - let seq1 = SequenceAction { + let seq1 = Sequence { rollup_id: RollupId::new([1; ROLLUP_ID_LEN]), data: vec![1u8; cfg.max_bytes_per_bundle / 4].into(), ..sequence_action() diff --git a/crates/astria-composer/src/test_utils.rs b/crates/astria-composer/src/test_utils.rs index 0759b81666..54b9a551dc 100644 --- a/crates/astria-composer/src/test_utils.rs +++ b/crates/astria-composer/src/test_utils.rs @@ -4,17 +4,17 @@ use astria_core::{ RollupId, ROLLUP_ID_LEN, }, - protocol::transaction::v1alpha1::action::SequenceAction, + protocol::transaction::v1alpha1::action::Sequence, Protobuf as _, }; -fn encoded_len(action: &SequenceAction) -> usize { +fn encoded_len(action: &Sequence) -> usize { use prost::Message as _; action.to_raw().encoded_len() } -pub(crate) fn sequence_action_with_n_bytes(n: usize) -> SequenceAction { - SequenceAction { +pub(crate) fn sequence_action_with_n_bytes(n: usize) -> Sequence { + Sequence { rollup_id: RollupId::new([0; ROLLUP_ID_LEN]), data: vec![0; n].into(), fee_asset: "nria" @@ -25,11 +25,11 @@ pub(crate) fn sequence_action_with_n_bytes(n: usize) -> SequenceAction { } } -pub(crate) fn empty_sequence_action() -> SequenceAction { +pub(crate) fn empty_sequence_action() -> Sequence { sequence_action_with_n_bytes(0) } -pub(crate) fn sequence_action_of_max_size(max: usize) -> SequenceAction { +pub(crate) fn sequence_action_of_max_size(max: usize) -> Sequence { // an action where the data part is exactly max bytes long let big_action = sequence_action_with_n_bytes(max); // the number of bytes past max diff --git a/crates/astria-core/src/generated/astria.protocol.transactions.v1alpha1.rs b/crates/astria-core/src/generated/astria.protocol.transactions.v1alpha1.rs index 5d8a18974d..6bf30e40cb 100644 --- a/crates/astria-core/src/generated/astria.protocol.transactions.v1alpha1.rs +++ b/crates/astria-core/src/generated/astria.protocol.transactions.v1alpha1.rs @@ -70,38 +70,38 @@ pub mod action { pub enum Value { /// Core protocol actions are defined on 1-10 #[prost(message, tag = "1")] - TransferAction(super::TransferAction), + Transfer(super::Transfer), #[prost(message, tag = "2")] - SequenceAction(super::SequenceAction), + Sequence(super::Sequence), /// Bridge actions are defined on 11-20 #[prost(message, tag = "11")] - InitBridgeAccountAction(super::InitBridgeAccountAction), + InitBridgeAccount(super::InitBridgeAccount), #[prost(message, tag = "12")] - BridgeLockAction(super::BridgeLockAction), + BridgeLock(super::BridgeLock), #[prost(message, tag = "13")] - BridgeUnlockAction(super::BridgeUnlockAction), + BridgeUnlock(super::BridgeUnlock), #[prost(message, tag = "14")] - BridgeSudoChangeAction(super::BridgeSudoChangeAction), + BridgeSudoChange(super::BridgeSudoChange), /// IBC user actions are defined on 21-30 #[prost(message, tag = "21")] - IbcAction(::penumbra_proto::core::component::ibc::v1::IbcRelay), + Ibc(::penumbra_proto::core::component::ibc::v1::IbcRelay), #[prost(message, tag = "22")] Ics20Withdrawal(super::Ics20Withdrawal), /// POA sudo actions are defined on 50-60 #[prost(message, tag = "50")] - SudoAddressChangeAction(super::SudoAddressChangeAction), + SudoAddressChange(super::SudoAddressChange), #[prost(message, tag = "51")] - ValidatorUpdateAction( + ValidatorUpdate( crate::generated::astria_vendored::tendermint::abci::ValidatorUpdate, ), #[prost(message, tag = "52")] - IbcRelayerChangeAction(super::IbcRelayerChangeAction), + IbcRelayerChange(super::IbcRelayerChange), #[prost(message, tag = "53")] - FeeAssetChangeAction(super::FeeAssetChangeAction), + FeeAssetChange(super::FeeAssetChange), #[prost(message, tag = "55")] - FeeChangeAction(super::FeeChangeAction), + FeeChange(super::FeeChange), #[prost(message, tag = "56")] - IbcSudoChangeAction(super::IbcSudoChangeAction), + IbcSudoChange(super::IbcSudoChange), } } impl ::prost::Name for Action { @@ -117,7 +117,7 @@ impl ::prost::Name for Action { /// be considered invalid by the sequencer. #[allow(clippy::derive_partial_eq_without_eq)] #[derive(Clone, PartialEq, ::prost::Message)] -pub struct TransferAction { +pub struct Transfer { #[prost(message, optional, tag = "1")] pub to: ::core::option::Option, #[prost(message, optional, tag = "2")] @@ -129,21 +129,21 @@ pub struct TransferAction { #[prost(string, tag = "4")] pub fee_asset: ::prost::alloc::string::String, } -impl ::prost::Name for TransferAction { - const NAME: &'static str = "TransferAction"; +impl ::prost::Name for Transfer { + const NAME: &'static str = "Transfer"; const PACKAGE: &'static str = "astria.protocol.transactions.v1alpha1"; fn full_name() -> ::prost::alloc::string::String { ::prost::alloc::format!("astria.protocol.transactions.v1alpha1.{}", Self::NAME) } } -/// `SequenceAction` represents a transaction destined for another +/// `Sequence` represents a transaction destined for another /// chain, ordered by the sequencer. /// /// It contains the rollup ID of the destination chain, and the /// opaque transaction data. #[allow(clippy::derive_partial_eq_without_eq)] #[derive(Clone, PartialEq, ::prost::Message)] -pub struct SequenceAction { +pub struct Sequence { #[prost(message, optional, tag = "1")] pub rollup_id: ::core::option::Option, #[prost(bytes = "bytes", tag = "2")] @@ -152,26 +152,26 @@ pub struct SequenceAction { #[prost(string, tag = "3")] pub fee_asset: ::prost::alloc::string::String, } -impl ::prost::Name for SequenceAction { - const NAME: &'static str = "SequenceAction"; +impl ::prost::Name for Sequence { + const NAME: &'static str = "Sequence"; const PACKAGE: &'static str = "astria.protocol.transactions.v1alpha1"; fn full_name() -> ::prost::alloc::string::String { ::prost::alloc::format!("astria.protocol.transactions.v1alpha1.{}", Self::NAME) } } -/// / `SudoAddressChangeAction` represents a transaction that changes +/// / `SudoAddressChange` represents a transaction that changes /// / the sudo address of the chain, which is the address authorized to /// / make validator update actions. /// / /// / It contains the new sudo address. #[allow(clippy::derive_partial_eq_without_eq)] #[derive(Clone, PartialEq, ::prost::Message)] -pub struct SudoAddressChangeAction { +pub struct SudoAddressChange { #[prost(message, optional, tag = "1")] pub new_address: ::core::option::Option, } -impl ::prost::Name for SudoAddressChangeAction { - const NAME: &'static str = "SudoAddressChangeAction"; +impl ::prost::Name for SudoAddressChange { + const NAME: &'static str = "SudoAddressChange"; const PACKAGE: &'static str = "astria.protocol.transactions.v1alpha1"; fn full_name() -> ::prost::alloc::string::String { ::prost::alloc::format!("astria.protocol.transactions.v1alpha1.{}", Self::NAME) @@ -252,17 +252,17 @@ impl ::prost::Name for IbcHeight { ::prost::alloc::format!("astria.protocol.transactions.v1alpha1.{}", Self::NAME) } } -/// `IbcRelayerChangeAction` represents a transaction that adds +/// `IbcRelayerChange` represents a transaction that adds /// or removes an IBC relayer address. /// The bytes contained in each variant are the address to add or remove. #[allow(clippy::derive_partial_eq_without_eq)] #[derive(Clone, PartialEq, ::prost::Message)] -pub struct IbcRelayerChangeAction { - #[prost(oneof = "ibc_relayer_change_action::Value", tags = "1, 2")] - pub value: ::core::option::Option, +pub struct IbcRelayerChange { + #[prost(oneof = "ibc_relayer_change::Value", tags = "1, 2")] + pub value: ::core::option::Option, } -/// Nested message and enum types in `IbcRelayerChangeAction`. -pub mod ibc_relayer_change_action { +/// Nested message and enum types in `IbcRelayerChange`. +pub mod ibc_relayer_change { #[allow(clippy::derive_partial_eq_without_eq)] #[derive(Clone, PartialEq, ::prost::Oneof)] pub enum Value { @@ -272,23 +272,23 @@ pub mod ibc_relayer_change_action { Removal(super::super::super::super::primitive::v1::Address), } } -impl ::prost::Name for IbcRelayerChangeAction { - const NAME: &'static str = "IbcRelayerChangeAction"; +impl ::prost::Name for IbcRelayerChange { + const NAME: &'static str = "IbcRelayerChange"; const PACKAGE: &'static str = "astria.protocol.transactions.v1alpha1"; fn full_name() -> ::prost::alloc::string::String { ::prost::alloc::format!("astria.protocol.transactions.v1alpha1.{}", Self::NAME) } } -/// `FeeAssetChangeAction` represents a transaction that adds +/// `FeeAssetChange` represents a transaction that adds /// or removes an asset for fee payments. #[allow(clippy::derive_partial_eq_without_eq)] #[derive(Clone, PartialEq, ::prost::Message)] -pub struct FeeAssetChangeAction { - #[prost(oneof = "fee_asset_change_action::Value", tags = "1, 2")] - pub value: ::core::option::Option, +pub struct FeeAssetChange { + #[prost(oneof = "fee_asset_change::Value", tags = "1, 2")] + pub value: ::core::option::Option, } -/// Nested message and enum types in `FeeAssetChangeAction`. -pub mod fee_asset_change_action { +/// Nested message and enum types in `FeeAssetChange`. +pub mod fee_asset_change { #[allow(clippy::derive_partial_eq_without_eq)] #[derive(Clone, PartialEq, ::prost::Oneof)] pub enum Value { @@ -298,22 +298,22 @@ pub mod fee_asset_change_action { Removal(::prost::alloc::string::String), } } -impl ::prost::Name for FeeAssetChangeAction { - const NAME: &'static str = "FeeAssetChangeAction"; +impl ::prost::Name for FeeAssetChange { + const NAME: &'static str = "FeeAssetChange"; const PACKAGE: &'static str = "astria.protocol.transactions.v1alpha1"; fn full_name() -> ::prost::alloc::string::String { ::prost::alloc::format!("astria.protocol.transactions.v1alpha1.{}", Self::NAME) } } -/// `InitBridgeAccountAction` represents a transaction that initializes +/// `InitBridgeAccount` represents a transaction that initializes /// a bridge account for the given rollup on the chain. /// /// The sender of the transaction is used as the owner of the bridge account /// and is the only actor authorized to transfer out of this account via -/// a `TransferAction`. +/// a `Transfer`. #[allow(clippy::derive_partial_eq_without_eq)] #[derive(Clone, PartialEq, ::prost::Message)] -pub struct InitBridgeAccountAction { +pub struct InitBridgeAccount { /// the rollup ID to register with the bridge account (the tx sender) #[prost(message, optional, tag = "1")] pub rollup_id: ::core::option::Option, @@ -337,21 +337,21 @@ pub struct InitBridgeAccountAction { super::super::super::primitive::v1::Address, >, } -impl ::prost::Name for InitBridgeAccountAction { - const NAME: &'static str = "InitBridgeAccountAction"; +impl ::prost::Name for InitBridgeAccount { + const NAME: &'static str = "InitBridgeAccount"; const PACKAGE: &'static str = "astria.protocol.transactions.v1alpha1"; fn full_name() -> ::prost::alloc::string::String { ::prost::alloc::format!("astria.protocol.transactions.v1alpha1.{}", Self::NAME) } } -/// `BridgeLockAction` represents a transaction that transfers +/// `BridgeLock` represents a transaction that transfers /// funds from a sequencer account to a bridge account. /// -/// It's the same as a `TransferAction` but with the added +/// It's the same as a `Transfer` but with the added /// `destination_chain_address` field. #[allow(clippy::derive_partial_eq_without_eq)] #[derive(Clone, PartialEq, ::prost::Message)] -pub struct BridgeLockAction { +pub struct BridgeLock { /// the address of the bridge account to transfer to #[prost(message, optional, tag = "1")] pub to: ::core::option::Option, @@ -369,21 +369,21 @@ pub struct BridgeLockAction { #[prost(string, tag = "5")] pub destination_chain_address: ::prost::alloc::string::String, } -impl ::prost::Name for BridgeLockAction { - const NAME: &'static str = "BridgeLockAction"; +impl ::prost::Name for BridgeLock { + const NAME: &'static str = "BridgeLock"; const PACKAGE: &'static str = "astria.protocol.transactions.v1alpha1"; fn full_name() -> ::prost::alloc::string::String { ::prost::alloc::format!("astria.protocol.transactions.v1alpha1.{}", Self::NAME) } } -/// `BridgeUnlockAction` represents a transaction that transfers +/// `BridgeUnlock` represents a transaction that transfers /// funds from a bridge account to a sequencer account. /// -/// It's the same as a `TransferAction` but without the `asset` field +/// It's the same as a `Transfer` but without the `asset` field /// and with the `memo` field. #[allow(clippy::derive_partial_eq_without_eq)] #[derive(Clone, PartialEq, ::prost::Message)] -pub struct BridgeUnlockAction { +pub struct BridgeUnlock { /// the to withdraw funds to #[prost(message, optional, tag = "1")] pub to: ::core::option::Option, @@ -416,8 +416,8 @@ pub struct BridgeUnlockAction { #[prost(string, tag = "7")] pub rollup_withdrawal_event_id: ::prost::alloc::string::String, } -impl ::prost::Name for BridgeUnlockAction { - const NAME: &'static str = "BridgeUnlockAction"; +impl ::prost::Name for BridgeUnlock { + const NAME: &'static str = "BridgeUnlock"; const PACKAGE: &'static str = "astria.protocol.transactions.v1alpha1"; fn full_name() -> ::prost::alloc::string::String { ::prost::alloc::format!("astria.protocol.transactions.v1alpha1.{}", Self::NAME) @@ -425,7 +425,7 @@ impl ::prost::Name for BridgeUnlockAction { } #[allow(clippy::derive_partial_eq_without_eq)] #[derive(Clone, PartialEq, ::prost::Message)] -pub struct BridgeSudoChangeAction { +pub struct BridgeSudoChange { /// the address of the bridge account to change the sudo or withdrawer addresses for #[prost(message, optional, tag = "1")] pub bridge_address: ::core::option::Option< @@ -445,8 +445,8 @@ pub struct BridgeSudoChangeAction { #[prost(string, tag = "4")] pub fee_asset: ::prost::alloc::string::String, } -impl ::prost::Name for BridgeSudoChangeAction { - const NAME: &'static str = "BridgeSudoChangeAction"; +impl ::prost::Name for BridgeSudoChange { + const NAME: &'static str = "BridgeSudoChange"; const PACKAGE: &'static str = "astria.protocol.transactions.v1alpha1"; fn full_name() -> ::prost::alloc::string::String { ::prost::alloc::format!("astria.protocol.transactions.v1alpha1.{}", Self::NAME) @@ -454,14 +454,14 @@ impl ::prost::Name for BridgeSudoChangeAction { } #[allow(clippy::derive_partial_eq_without_eq)] #[derive(Clone, PartialEq, ::prost::Message)] -pub struct FeeChangeAction { +pub struct FeeChange { /// note that the proto number ranges are doubled from that of `Action`. /// this to accomodate both `base_fee` and `byte_cost_multiplier` for each action. - #[prost(oneof = "fee_change_action::Value", tags = "1, 2, 3, 20, 21, 22, 40")] - pub value: ::core::option::Option, + #[prost(oneof = "fee_change::Value", tags = "1, 2, 3, 20, 21, 22, 40")] + pub value: ::core::option::Option, } -/// Nested message and enum types in `FeeChangeAction`. -pub mod fee_change_action { +/// Nested message and enum types in `FeeChange`. +pub mod fee_change { /// note that the proto number ranges are doubled from that of `Action`. /// this to accomodate both `base_fee` and `byte_cost_multiplier` for each action. #[allow(clippy::derive_partial_eq_without_eq)] @@ -486,8 +486,8 @@ pub mod fee_change_action { Ics20WithdrawalBaseFee(super::super::super::super::primitive::v1::Uint128), } } -impl ::prost::Name for FeeChangeAction { - const NAME: &'static str = "FeeChangeAction"; +impl ::prost::Name for FeeChange { + const NAME: &'static str = "FeeChange"; const PACKAGE: &'static str = "astria.protocol.transactions.v1alpha1"; fn full_name() -> ::prost::alloc::string::String { ::prost::alloc::format!("astria.protocol.transactions.v1alpha1.{}", Self::NAME) @@ -495,12 +495,12 @@ impl ::prost::Name for FeeChangeAction { } #[allow(clippy::derive_partial_eq_without_eq)] #[derive(Clone, PartialEq, ::prost::Message)] -pub struct IbcSudoChangeAction { +pub struct IbcSudoChange { #[prost(message, optional, tag = "1")] pub new_address: ::core::option::Option, } -impl ::prost::Name for IbcSudoChangeAction { - const NAME: &'static str = "IbcSudoChangeAction"; +impl ::prost::Name for IbcSudoChange { + const NAME: &'static str = "IbcSudoChange"; const PACKAGE: &'static str = "astria.protocol.transactions.v1alpha1"; fn full_name() -> ::prost::alloc::string::String { ::prost::alloc::format!("astria.protocol.transactions.v1alpha1.{}", Self::NAME) diff --git a/crates/astria-core/src/generated/astria.protocol.transactions.v1alpha1.serde.rs b/crates/astria-core/src/generated/astria.protocol.transactions.v1alpha1.serde.rs index 92cfc727e0..ea905cf97e 100644 --- a/crates/astria-core/src/generated/astria.protocol.transactions.v1alpha1.serde.rs +++ b/crates/astria-core/src/generated/astria.protocol.transactions.v1alpha1.serde.rs @@ -12,47 +12,47 @@ impl serde::Serialize for Action { let mut struct_ser = serializer.serialize_struct("astria.protocol.transactions.v1alpha1.Action", len)?; if let Some(v) = self.value.as_ref() { match v { - action::Value::TransferAction(v) => { - struct_ser.serialize_field("transferAction", v)?; + action::Value::Transfer(v) => { + struct_ser.serialize_field("transfer", v)?; } - action::Value::SequenceAction(v) => { - struct_ser.serialize_field("sequenceAction", v)?; + action::Value::Sequence(v) => { + struct_ser.serialize_field("sequence", v)?; } - action::Value::InitBridgeAccountAction(v) => { - struct_ser.serialize_field("initBridgeAccountAction", v)?; + action::Value::InitBridgeAccount(v) => { + struct_ser.serialize_field("initBridgeAccount", v)?; } - action::Value::BridgeLockAction(v) => { - struct_ser.serialize_field("bridgeLockAction", v)?; + action::Value::BridgeLock(v) => { + struct_ser.serialize_field("bridgeLock", v)?; } - action::Value::BridgeUnlockAction(v) => { - struct_ser.serialize_field("bridgeUnlockAction", v)?; + action::Value::BridgeUnlock(v) => { + struct_ser.serialize_field("bridgeUnlock", v)?; } - action::Value::BridgeSudoChangeAction(v) => { - struct_ser.serialize_field("bridgeSudoChangeAction", v)?; + action::Value::BridgeSudoChange(v) => { + struct_ser.serialize_field("bridgeSudoChange", v)?; } - action::Value::IbcAction(v) => { - struct_ser.serialize_field("ibcAction", v)?; + action::Value::Ibc(v) => { + struct_ser.serialize_field("ibc", v)?; } action::Value::Ics20Withdrawal(v) => { struct_ser.serialize_field("ics20Withdrawal", v)?; } - action::Value::SudoAddressChangeAction(v) => { - struct_ser.serialize_field("sudoAddressChangeAction", v)?; + action::Value::SudoAddressChange(v) => { + struct_ser.serialize_field("sudoAddressChange", v)?; } - action::Value::ValidatorUpdateAction(v) => { - struct_ser.serialize_field("validatorUpdateAction", v)?; + action::Value::ValidatorUpdate(v) => { + struct_ser.serialize_field("validatorUpdate", v)?; } - action::Value::IbcRelayerChangeAction(v) => { - struct_ser.serialize_field("ibcRelayerChangeAction", v)?; + action::Value::IbcRelayerChange(v) => { + struct_ser.serialize_field("ibcRelayerChange", v)?; } - action::Value::FeeAssetChangeAction(v) => { - struct_ser.serialize_field("feeAssetChangeAction", v)?; + action::Value::FeeAssetChange(v) => { + struct_ser.serialize_field("feeAssetChange", v)?; } - action::Value::FeeChangeAction(v) => { - struct_ser.serialize_field("feeChangeAction", v)?; + action::Value::FeeChange(v) => { + struct_ser.serialize_field("feeChange", v)?; } - action::Value::IbcSudoChangeAction(v) => { - struct_ser.serialize_field("ibcSudoChangeAction", v)?; + action::Value::IbcSudoChange(v) => { + struct_ser.serialize_field("ibcSudoChange", v)?; } } } @@ -66,52 +66,49 @@ impl<'de> serde::Deserialize<'de> for Action { D: serde::Deserializer<'de>, { const FIELDS: &[&str] = &[ - "transfer_action", - "transferAction", - "sequence_action", - "sequenceAction", - "init_bridge_account_action", - "initBridgeAccountAction", - "bridge_lock_action", - "bridgeLockAction", - "bridge_unlock_action", - "bridgeUnlockAction", - "bridge_sudo_change_action", - "bridgeSudoChangeAction", - "ibc_action", - "ibcAction", + "transfer", + "sequence", + "init_bridge_account", + "initBridgeAccount", + "bridge_lock", + "bridgeLock", + "bridge_unlock", + "bridgeUnlock", + "bridge_sudo_change", + "bridgeSudoChange", + "ibc", "ics20_withdrawal", "ics20Withdrawal", - "sudo_address_change_action", - "sudoAddressChangeAction", - "validator_update_action", - "validatorUpdateAction", - "ibc_relayer_change_action", - "ibcRelayerChangeAction", - "fee_asset_change_action", - "feeAssetChangeAction", - "fee_change_action", - "feeChangeAction", - "ibc_sudo_change_action", - "ibcSudoChangeAction", + "sudo_address_change", + "sudoAddressChange", + "validator_update", + "validatorUpdate", + "ibc_relayer_change", + "ibcRelayerChange", + "fee_asset_change", + "feeAssetChange", + "fee_change", + "feeChange", + "ibc_sudo_change", + "ibcSudoChange", ]; #[allow(clippy::enum_variant_names)] enum GeneratedField { - TransferAction, - SequenceAction, - InitBridgeAccountAction, - BridgeLockAction, - BridgeUnlockAction, - BridgeSudoChangeAction, - IbcAction, + Transfer, + Sequence, + InitBridgeAccount, + BridgeLock, + BridgeUnlock, + BridgeSudoChange, + Ibc, Ics20Withdrawal, - SudoAddressChangeAction, - ValidatorUpdateAction, - IbcRelayerChangeAction, - FeeAssetChangeAction, - FeeChangeAction, - IbcSudoChangeAction, + SudoAddressChange, + ValidatorUpdate, + IbcRelayerChange, + FeeAssetChange, + FeeChange, + IbcSudoChange, } impl<'de> serde::Deserialize<'de> for GeneratedField { fn deserialize(deserializer: D) -> std::result::Result @@ -133,20 +130,20 @@ impl<'de> serde::Deserialize<'de> for Action { E: serde::de::Error, { match value { - "transferAction" | "transfer_action" => Ok(GeneratedField::TransferAction), - "sequenceAction" | "sequence_action" => Ok(GeneratedField::SequenceAction), - "initBridgeAccountAction" | "init_bridge_account_action" => Ok(GeneratedField::InitBridgeAccountAction), - "bridgeLockAction" | "bridge_lock_action" => Ok(GeneratedField::BridgeLockAction), - "bridgeUnlockAction" | "bridge_unlock_action" => Ok(GeneratedField::BridgeUnlockAction), - "bridgeSudoChangeAction" | "bridge_sudo_change_action" => Ok(GeneratedField::BridgeSudoChangeAction), - "ibcAction" | "ibc_action" => Ok(GeneratedField::IbcAction), + "transfer" => Ok(GeneratedField::Transfer), + "sequence" => Ok(GeneratedField::Sequence), + "initBridgeAccount" | "init_bridge_account" => Ok(GeneratedField::InitBridgeAccount), + "bridgeLock" | "bridge_lock" => Ok(GeneratedField::BridgeLock), + "bridgeUnlock" | "bridge_unlock" => Ok(GeneratedField::BridgeUnlock), + "bridgeSudoChange" | "bridge_sudo_change" => Ok(GeneratedField::BridgeSudoChange), + "ibc" => Ok(GeneratedField::Ibc), "ics20Withdrawal" | "ics20_withdrawal" => Ok(GeneratedField::Ics20Withdrawal), - "sudoAddressChangeAction" | "sudo_address_change_action" => Ok(GeneratedField::SudoAddressChangeAction), - "validatorUpdateAction" | "validator_update_action" => Ok(GeneratedField::ValidatorUpdateAction), - "ibcRelayerChangeAction" | "ibc_relayer_change_action" => Ok(GeneratedField::IbcRelayerChangeAction), - "feeAssetChangeAction" | "fee_asset_change_action" => Ok(GeneratedField::FeeAssetChangeAction), - "feeChangeAction" | "fee_change_action" => Ok(GeneratedField::FeeChangeAction), - "ibcSudoChangeAction" | "ibc_sudo_change_action" => Ok(GeneratedField::IbcSudoChangeAction), + "sudoAddressChange" | "sudo_address_change" => Ok(GeneratedField::SudoAddressChange), + "validatorUpdate" | "validator_update" => Ok(GeneratedField::ValidatorUpdate), + "ibcRelayerChange" | "ibc_relayer_change" => Ok(GeneratedField::IbcRelayerChange), + "feeAssetChange" | "fee_asset_change" => Ok(GeneratedField::FeeAssetChange), + "feeChange" | "fee_change" => Ok(GeneratedField::FeeChange), + "ibcSudoChange" | "ibc_sudo_change" => Ok(GeneratedField::IbcSudoChange), _ => Err(serde::de::Error::unknown_field(value, FIELDS)), } } @@ -169,53 +166,53 @@ impl<'de> serde::Deserialize<'de> for Action { let mut value__ = None; while let Some(k) = map_.next_key()? { match k { - GeneratedField::TransferAction => { + GeneratedField::Transfer => { if value__.is_some() { - return Err(serde::de::Error::duplicate_field("transferAction")); + return Err(serde::de::Error::duplicate_field("transfer")); } - value__ = map_.next_value::<::std::option::Option<_>>()?.map(action::Value::TransferAction) + value__ = map_.next_value::<::std::option::Option<_>>()?.map(action::Value::Transfer) ; } - GeneratedField::SequenceAction => { + GeneratedField::Sequence => { if value__.is_some() { - return Err(serde::de::Error::duplicate_field("sequenceAction")); + return Err(serde::de::Error::duplicate_field("sequence")); } - value__ = map_.next_value::<::std::option::Option<_>>()?.map(action::Value::SequenceAction) + value__ = map_.next_value::<::std::option::Option<_>>()?.map(action::Value::Sequence) ; } - GeneratedField::InitBridgeAccountAction => { + GeneratedField::InitBridgeAccount => { if value__.is_some() { - return Err(serde::de::Error::duplicate_field("initBridgeAccountAction")); + return Err(serde::de::Error::duplicate_field("initBridgeAccount")); } - value__ = map_.next_value::<::std::option::Option<_>>()?.map(action::Value::InitBridgeAccountAction) + value__ = map_.next_value::<::std::option::Option<_>>()?.map(action::Value::InitBridgeAccount) ; } - GeneratedField::BridgeLockAction => { + GeneratedField::BridgeLock => { if value__.is_some() { - return Err(serde::de::Error::duplicate_field("bridgeLockAction")); + return Err(serde::de::Error::duplicate_field("bridgeLock")); } - value__ = map_.next_value::<::std::option::Option<_>>()?.map(action::Value::BridgeLockAction) + value__ = map_.next_value::<::std::option::Option<_>>()?.map(action::Value::BridgeLock) ; } - GeneratedField::BridgeUnlockAction => { + GeneratedField::BridgeUnlock => { if value__.is_some() { - return Err(serde::de::Error::duplicate_field("bridgeUnlockAction")); + return Err(serde::de::Error::duplicate_field("bridgeUnlock")); } - value__ = map_.next_value::<::std::option::Option<_>>()?.map(action::Value::BridgeUnlockAction) + value__ = map_.next_value::<::std::option::Option<_>>()?.map(action::Value::BridgeUnlock) ; } - GeneratedField::BridgeSudoChangeAction => { + GeneratedField::BridgeSudoChange => { if value__.is_some() { - return Err(serde::de::Error::duplicate_field("bridgeSudoChangeAction")); + return Err(serde::de::Error::duplicate_field("bridgeSudoChange")); } - value__ = map_.next_value::<::std::option::Option<_>>()?.map(action::Value::BridgeSudoChangeAction) + value__ = map_.next_value::<::std::option::Option<_>>()?.map(action::Value::BridgeSudoChange) ; } - GeneratedField::IbcAction => { + GeneratedField::Ibc => { if value__.is_some() { - return Err(serde::de::Error::duplicate_field("ibcAction")); + return Err(serde::de::Error::duplicate_field("ibc")); } - value__ = map_.next_value::<::std::option::Option<_>>()?.map(action::Value::IbcAction) + value__ = map_.next_value::<::std::option::Option<_>>()?.map(action::Value::Ibc) ; } GeneratedField::Ics20Withdrawal => { @@ -225,46 +222,46 @@ impl<'de> serde::Deserialize<'de> for Action { value__ = map_.next_value::<::std::option::Option<_>>()?.map(action::Value::Ics20Withdrawal) ; } - GeneratedField::SudoAddressChangeAction => { + GeneratedField::SudoAddressChange => { if value__.is_some() { - return Err(serde::de::Error::duplicate_field("sudoAddressChangeAction")); + return Err(serde::de::Error::duplicate_field("sudoAddressChange")); } - value__ = map_.next_value::<::std::option::Option<_>>()?.map(action::Value::SudoAddressChangeAction) + value__ = map_.next_value::<::std::option::Option<_>>()?.map(action::Value::SudoAddressChange) ; } - GeneratedField::ValidatorUpdateAction => { + GeneratedField::ValidatorUpdate => { if value__.is_some() { - return Err(serde::de::Error::duplicate_field("validatorUpdateAction")); + return Err(serde::de::Error::duplicate_field("validatorUpdate")); } - value__ = map_.next_value::<::std::option::Option<_>>()?.map(action::Value::ValidatorUpdateAction) + value__ = map_.next_value::<::std::option::Option<_>>()?.map(action::Value::ValidatorUpdate) ; } - GeneratedField::IbcRelayerChangeAction => { + GeneratedField::IbcRelayerChange => { if value__.is_some() { - return Err(serde::de::Error::duplicate_field("ibcRelayerChangeAction")); + return Err(serde::de::Error::duplicate_field("ibcRelayerChange")); } - value__ = map_.next_value::<::std::option::Option<_>>()?.map(action::Value::IbcRelayerChangeAction) + value__ = map_.next_value::<::std::option::Option<_>>()?.map(action::Value::IbcRelayerChange) ; } - GeneratedField::FeeAssetChangeAction => { + GeneratedField::FeeAssetChange => { if value__.is_some() { - return Err(serde::de::Error::duplicate_field("feeAssetChangeAction")); + return Err(serde::de::Error::duplicate_field("feeAssetChange")); } - value__ = map_.next_value::<::std::option::Option<_>>()?.map(action::Value::FeeAssetChangeAction) + value__ = map_.next_value::<::std::option::Option<_>>()?.map(action::Value::FeeAssetChange) ; } - GeneratedField::FeeChangeAction => { + GeneratedField::FeeChange => { if value__.is_some() { - return Err(serde::de::Error::duplicate_field("feeChangeAction")); + return Err(serde::de::Error::duplicate_field("feeChange")); } - value__ = map_.next_value::<::std::option::Option<_>>()?.map(action::Value::FeeChangeAction) + value__ = map_.next_value::<::std::option::Option<_>>()?.map(action::Value::FeeChange) ; } - GeneratedField::IbcSudoChangeAction => { + GeneratedField::IbcSudoChange => { if value__.is_some() { - return Err(serde::de::Error::duplicate_field("ibcSudoChangeAction")); + return Err(serde::de::Error::duplicate_field("ibcSudoChange")); } - value__ = map_.next_value::<::std::option::Option<_>>()?.map(action::Value::IbcSudoChangeAction) + value__ = map_.next_value::<::std::option::Option<_>>()?.map(action::Value::IbcSudoChange) ; } } @@ -277,7 +274,7 @@ impl<'de> serde::Deserialize<'de> for Action { deserializer.deserialize_struct("astria.protocol.transactions.v1alpha1.Action", FIELDS, GeneratedVisitor) } } -impl serde::Serialize for BridgeLockAction { +impl serde::Serialize for BridgeLock { #[allow(deprecated)] fn serialize(&self, serializer: S) -> std::result::Result where @@ -300,7 +297,7 @@ impl serde::Serialize for BridgeLockAction { if !self.destination_chain_address.is_empty() { len += 1; } - let mut struct_ser = serializer.serialize_struct("astria.protocol.transactions.v1alpha1.BridgeLockAction", len)?; + let mut struct_ser = serializer.serialize_struct("astria.protocol.transactions.v1alpha1.BridgeLock", len)?; if let Some(v) = self.to.as_ref() { struct_ser.serialize_field("to", v)?; } @@ -319,7 +316,7 @@ impl serde::Serialize for BridgeLockAction { struct_ser.end() } } -impl<'de> serde::Deserialize<'de> for BridgeLockAction { +impl<'de> serde::Deserialize<'de> for BridgeLock { #[allow(deprecated)] fn deserialize(deserializer: D) -> std::result::Result where @@ -377,13 +374,13 @@ impl<'de> serde::Deserialize<'de> for BridgeLockAction { } struct GeneratedVisitor; impl<'de> serde::de::Visitor<'de> for GeneratedVisitor { - type Value = BridgeLockAction; + type Value = BridgeLock; fn expecting(&self, formatter: &mut std::fmt::Formatter<'_>) -> std::fmt::Result { - formatter.write_str("struct astria.protocol.transactions.v1alpha1.BridgeLockAction") + formatter.write_str("struct astria.protocol.transactions.v1alpha1.BridgeLock") } - fn visit_map(self, mut map_: V) -> std::result::Result + fn visit_map(self, mut map_: V) -> std::result::Result where V: serde::de::MapAccess<'de>, { @@ -426,7 +423,7 @@ impl<'de> serde::Deserialize<'de> for BridgeLockAction { } } } - Ok(BridgeLockAction { + Ok(BridgeLock { to: to__, amount: amount__, asset: asset__.unwrap_or_default(), @@ -435,10 +432,10 @@ impl<'de> serde::Deserialize<'de> for BridgeLockAction { }) } } - deserializer.deserialize_struct("astria.protocol.transactions.v1alpha1.BridgeLockAction", FIELDS, GeneratedVisitor) + deserializer.deserialize_struct("astria.protocol.transactions.v1alpha1.BridgeLock", FIELDS, GeneratedVisitor) } } -impl serde::Serialize for BridgeSudoChangeAction { +impl serde::Serialize for BridgeSudoChange { #[allow(deprecated)] fn serialize(&self, serializer: S) -> std::result::Result where @@ -458,7 +455,7 @@ impl serde::Serialize for BridgeSudoChangeAction { if !self.fee_asset.is_empty() { len += 1; } - let mut struct_ser = serializer.serialize_struct("astria.protocol.transactions.v1alpha1.BridgeSudoChangeAction", len)?; + let mut struct_ser = serializer.serialize_struct("astria.protocol.transactions.v1alpha1.BridgeSudoChange", len)?; if let Some(v) = self.bridge_address.as_ref() { struct_ser.serialize_field("bridgeAddress", v)?; } @@ -474,7 +471,7 @@ impl serde::Serialize for BridgeSudoChangeAction { struct_ser.end() } } -impl<'de> serde::Deserialize<'de> for BridgeSudoChangeAction { +impl<'de> serde::Deserialize<'de> for BridgeSudoChange { #[allow(deprecated)] fn deserialize(deserializer: D) -> std::result::Result where @@ -531,13 +528,13 @@ impl<'de> serde::Deserialize<'de> for BridgeSudoChangeAction { } struct GeneratedVisitor; impl<'de> serde::de::Visitor<'de> for GeneratedVisitor { - type Value = BridgeSudoChangeAction; + type Value = BridgeSudoChange; fn expecting(&self, formatter: &mut std::fmt::Formatter<'_>) -> std::fmt::Result { - formatter.write_str("struct astria.protocol.transactions.v1alpha1.BridgeSudoChangeAction") + formatter.write_str("struct astria.protocol.transactions.v1alpha1.BridgeSudoChange") } - fn visit_map(self, mut map_: V) -> std::result::Result + fn visit_map(self, mut map_: V) -> std::result::Result where V: serde::de::MapAccess<'de>, { @@ -573,7 +570,7 @@ impl<'de> serde::Deserialize<'de> for BridgeSudoChangeAction { } } } - Ok(BridgeSudoChangeAction { + Ok(BridgeSudoChange { bridge_address: bridge_address__, new_sudo_address: new_sudo_address__, new_withdrawer_address: new_withdrawer_address__, @@ -581,10 +578,10 @@ impl<'de> serde::Deserialize<'de> for BridgeSudoChangeAction { }) } } - deserializer.deserialize_struct("astria.protocol.transactions.v1alpha1.BridgeSudoChangeAction", FIELDS, GeneratedVisitor) + deserializer.deserialize_struct("astria.protocol.transactions.v1alpha1.BridgeSudoChange", FIELDS, GeneratedVisitor) } } -impl serde::Serialize for BridgeUnlockAction { +impl serde::Serialize for BridgeUnlock { #[allow(deprecated)] fn serialize(&self, serializer: S) -> std::result::Result where @@ -613,7 +610,7 @@ impl serde::Serialize for BridgeUnlockAction { if !self.rollup_withdrawal_event_id.is_empty() { len += 1; } - let mut struct_ser = serializer.serialize_struct("astria.protocol.transactions.v1alpha1.BridgeUnlockAction", len)?; + let mut struct_ser = serializer.serialize_struct("astria.protocol.transactions.v1alpha1.BridgeUnlock", len)?; if let Some(v) = self.to.as_ref() { struct_ser.serialize_field("to", v)?; } @@ -639,7 +636,7 @@ impl serde::Serialize for BridgeUnlockAction { struct_ser.end() } } -impl<'de> serde::Deserialize<'de> for BridgeUnlockAction { +impl<'de> serde::Deserialize<'de> for BridgeUnlock { #[allow(deprecated)] fn deserialize(deserializer: D) -> std::result::Result where @@ -705,13 +702,13 @@ impl<'de> serde::Deserialize<'de> for BridgeUnlockAction { } struct GeneratedVisitor; impl<'de> serde::de::Visitor<'de> for GeneratedVisitor { - type Value = BridgeUnlockAction; + type Value = BridgeUnlock; fn expecting(&self, formatter: &mut std::fmt::Formatter<'_>) -> std::fmt::Result { - formatter.write_str("struct astria.protocol.transactions.v1alpha1.BridgeUnlockAction") + formatter.write_str("struct astria.protocol.transactions.v1alpha1.BridgeUnlock") } - fn visit_map(self, mut map_: V) -> std::result::Result + fn visit_map(self, mut map_: V) -> std::result::Result where V: serde::de::MapAccess<'de>, { @@ -770,7 +767,7 @@ impl<'de> serde::Deserialize<'de> for BridgeUnlockAction { } } } - Ok(BridgeUnlockAction { + Ok(BridgeUnlock { to: to__, amount: amount__, fee_asset: fee_asset__.unwrap_or_default(), @@ -781,10 +778,10 @@ impl<'de> serde::Deserialize<'de> for BridgeUnlockAction { }) } } - deserializer.deserialize_struct("astria.protocol.transactions.v1alpha1.BridgeUnlockAction", FIELDS, GeneratedVisitor) + deserializer.deserialize_struct("astria.protocol.transactions.v1alpha1.BridgeUnlock", FIELDS, GeneratedVisitor) } } -impl serde::Serialize for FeeAssetChangeAction { +impl serde::Serialize for FeeAssetChange { #[allow(deprecated)] fn serialize(&self, serializer: S) -> std::result::Result where @@ -795,13 +792,13 @@ impl serde::Serialize for FeeAssetChangeAction { if self.value.is_some() { len += 1; } - let mut struct_ser = serializer.serialize_struct("astria.protocol.transactions.v1alpha1.FeeAssetChangeAction", len)?; + let mut struct_ser = serializer.serialize_struct("astria.protocol.transactions.v1alpha1.FeeAssetChange", len)?; if let Some(v) = self.value.as_ref() { match v { - fee_asset_change_action::Value::Addition(v) => { + fee_asset_change::Value::Addition(v) => { struct_ser.serialize_field("addition", v)?; } - fee_asset_change_action::Value::Removal(v) => { + fee_asset_change::Value::Removal(v) => { struct_ser.serialize_field("removal", v)?; } } @@ -809,7 +806,7 @@ impl serde::Serialize for FeeAssetChangeAction { struct_ser.end() } } -impl<'de> serde::Deserialize<'de> for FeeAssetChangeAction { +impl<'de> serde::Deserialize<'de> for FeeAssetChange { #[allow(deprecated)] fn deserialize(deserializer: D) -> std::result::Result where @@ -856,13 +853,13 @@ impl<'de> serde::Deserialize<'de> for FeeAssetChangeAction { } struct GeneratedVisitor; impl<'de> serde::de::Visitor<'de> for GeneratedVisitor { - type Value = FeeAssetChangeAction; + type Value = FeeAssetChange; fn expecting(&self, formatter: &mut std::fmt::Formatter<'_>) -> std::fmt::Result { - formatter.write_str("struct astria.protocol.transactions.v1alpha1.FeeAssetChangeAction") + formatter.write_str("struct astria.protocol.transactions.v1alpha1.FeeAssetChange") } - fn visit_map(self, mut map_: V) -> std::result::Result + fn visit_map(self, mut map_: V) -> std::result::Result where V: serde::de::MapAccess<'de>, { @@ -873,25 +870,25 @@ impl<'de> serde::Deserialize<'de> for FeeAssetChangeAction { if value__.is_some() { return Err(serde::de::Error::duplicate_field("addition")); } - value__ = map_.next_value::<::std::option::Option<_>>()?.map(fee_asset_change_action::Value::Addition); + value__ = map_.next_value::<::std::option::Option<_>>()?.map(fee_asset_change::Value::Addition); } GeneratedField::Removal => { if value__.is_some() { return Err(serde::de::Error::duplicate_field("removal")); } - value__ = map_.next_value::<::std::option::Option<_>>()?.map(fee_asset_change_action::Value::Removal); + value__ = map_.next_value::<::std::option::Option<_>>()?.map(fee_asset_change::Value::Removal); } } } - Ok(FeeAssetChangeAction { + Ok(FeeAssetChange { value: value__, }) } } - deserializer.deserialize_struct("astria.protocol.transactions.v1alpha1.FeeAssetChangeAction", FIELDS, GeneratedVisitor) + deserializer.deserialize_struct("astria.protocol.transactions.v1alpha1.FeeAssetChange", FIELDS, GeneratedVisitor) } } -impl serde::Serialize for FeeChangeAction { +impl serde::Serialize for FeeChange { #[allow(deprecated)] fn serialize(&self, serializer: S) -> std::result::Result where @@ -902,28 +899,28 @@ impl serde::Serialize for FeeChangeAction { if self.value.is_some() { len += 1; } - let mut struct_ser = serializer.serialize_struct("astria.protocol.transactions.v1alpha1.FeeChangeAction", len)?; + let mut struct_ser = serializer.serialize_struct("astria.protocol.transactions.v1alpha1.FeeChange", len)?; if let Some(v) = self.value.as_ref() { match v { - fee_change_action::Value::TransferBaseFee(v) => { + fee_change::Value::TransferBaseFee(v) => { struct_ser.serialize_field("transferBaseFee", v)?; } - fee_change_action::Value::SequenceBaseFee(v) => { + fee_change::Value::SequenceBaseFee(v) => { struct_ser.serialize_field("sequenceBaseFee", v)?; } - fee_change_action::Value::SequenceByteCostMultiplier(v) => { + fee_change::Value::SequenceByteCostMultiplier(v) => { struct_ser.serialize_field("sequenceByteCostMultiplier", v)?; } - fee_change_action::Value::InitBridgeAccountBaseFee(v) => { + fee_change::Value::InitBridgeAccountBaseFee(v) => { struct_ser.serialize_field("initBridgeAccountBaseFee", v)?; } - fee_change_action::Value::BridgeLockByteCostMultiplier(v) => { + fee_change::Value::BridgeLockByteCostMultiplier(v) => { struct_ser.serialize_field("bridgeLockByteCostMultiplier", v)?; } - fee_change_action::Value::BridgeSudoChangeBaseFee(v) => { + fee_change::Value::BridgeSudoChangeBaseFee(v) => { struct_ser.serialize_field("bridgeSudoChangeBaseFee", v)?; } - fee_change_action::Value::Ics20WithdrawalBaseFee(v) => { + fee_change::Value::Ics20WithdrawalBaseFee(v) => { struct_ser.serialize_field("ics20WithdrawalBaseFee", v)?; } } @@ -931,7 +928,7 @@ impl serde::Serialize for FeeChangeAction { struct_ser.end() } } -impl<'de> serde::Deserialize<'de> for FeeChangeAction { +impl<'de> serde::Deserialize<'de> for FeeChange { #[allow(deprecated)] fn deserialize(deserializer: D) -> std::result::Result where @@ -1000,13 +997,13 @@ impl<'de> serde::Deserialize<'de> for FeeChangeAction { } struct GeneratedVisitor; impl<'de> serde::de::Visitor<'de> for GeneratedVisitor { - type Value = FeeChangeAction; + type Value = FeeChange; fn expecting(&self, formatter: &mut std::fmt::Formatter<'_>) -> std::fmt::Result { - formatter.write_str("struct astria.protocol.transactions.v1alpha1.FeeChangeAction") + formatter.write_str("struct astria.protocol.transactions.v1alpha1.FeeChange") } - fn visit_map(self, mut map_: V) -> std::result::Result + fn visit_map(self, mut map_: V) -> std::result::Result where V: serde::de::MapAccess<'de>, { @@ -1017,59 +1014,59 @@ impl<'de> serde::Deserialize<'de> for FeeChangeAction { if value__.is_some() { return Err(serde::de::Error::duplicate_field("transferBaseFee")); } - value__ = map_.next_value::<::std::option::Option<_>>()?.map(fee_change_action::Value::TransferBaseFee) + value__ = map_.next_value::<::std::option::Option<_>>()?.map(fee_change::Value::TransferBaseFee) ; } GeneratedField::SequenceBaseFee => { if value__.is_some() { return Err(serde::de::Error::duplicate_field("sequenceBaseFee")); } - value__ = map_.next_value::<::std::option::Option<_>>()?.map(fee_change_action::Value::SequenceBaseFee) + value__ = map_.next_value::<::std::option::Option<_>>()?.map(fee_change::Value::SequenceBaseFee) ; } GeneratedField::SequenceByteCostMultiplier => { if value__.is_some() { return Err(serde::de::Error::duplicate_field("sequenceByteCostMultiplier")); } - value__ = map_.next_value::<::std::option::Option<_>>()?.map(fee_change_action::Value::SequenceByteCostMultiplier) + value__ = map_.next_value::<::std::option::Option<_>>()?.map(fee_change::Value::SequenceByteCostMultiplier) ; } GeneratedField::InitBridgeAccountBaseFee => { if value__.is_some() { return Err(serde::de::Error::duplicate_field("initBridgeAccountBaseFee")); } - value__ = map_.next_value::<::std::option::Option<_>>()?.map(fee_change_action::Value::InitBridgeAccountBaseFee) + value__ = map_.next_value::<::std::option::Option<_>>()?.map(fee_change::Value::InitBridgeAccountBaseFee) ; } GeneratedField::BridgeLockByteCostMultiplier => { if value__.is_some() { return Err(serde::de::Error::duplicate_field("bridgeLockByteCostMultiplier")); } - value__ = map_.next_value::<::std::option::Option<_>>()?.map(fee_change_action::Value::BridgeLockByteCostMultiplier) + value__ = map_.next_value::<::std::option::Option<_>>()?.map(fee_change::Value::BridgeLockByteCostMultiplier) ; } GeneratedField::BridgeSudoChangeBaseFee => { if value__.is_some() { return Err(serde::de::Error::duplicate_field("bridgeSudoChangeBaseFee")); } - value__ = map_.next_value::<::std::option::Option<_>>()?.map(fee_change_action::Value::BridgeSudoChangeBaseFee) + value__ = map_.next_value::<::std::option::Option<_>>()?.map(fee_change::Value::BridgeSudoChangeBaseFee) ; } GeneratedField::Ics20WithdrawalBaseFee => { if value__.is_some() { return Err(serde::de::Error::duplicate_field("ics20WithdrawalBaseFee")); } - value__ = map_.next_value::<::std::option::Option<_>>()?.map(fee_change_action::Value::Ics20WithdrawalBaseFee) + value__ = map_.next_value::<::std::option::Option<_>>()?.map(fee_change::Value::Ics20WithdrawalBaseFee) ; } } } - Ok(FeeChangeAction { + Ok(FeeChange { value: value__, }) } } - deserializer.deserialize_struct("astria.protocol.transactions.v1alpha1.FeeChangeAction", FIELDS, GeneratedVisitor) + deserializer.deserialize_struct("astria.protocol.transactions.v1alpha1.FeeChange", FIELDS, GeneratedVisitor) } } impl serde::Serialize for IbcHeight { @@ -1188,7 +1185,7 @@ impl<'de> serde::Deserialize<'de> for IbcHeight { deserializer.deserialize_struct("astria.protocol.transactions.v1alpha1.IbcHeight", FIELDS, GeneratedVisitor) } } -impl serde::Serialize for IbcRelayerChangeAction { +impl serde::Serialize for IbcRelayerChange { #[allow(deprecated)] fn serialize(&self, serializer: S) -> std::result::Result where @@ -1199,13 +1196,13 @@ impl serde::Serialize for IbcRelayerChangeAction { if self.value.is_some() { len += 1; } - let mut struct_ser = serializer.serialize_struct("astria.protocol.transactions.v1alpha1.IbcRelayerChangeAction", len)?; + let mut struct_ser = serializer.serialize_struct("astria.protocol.transactions.v1alpha1.IbcRelayerChange", len)?; if let Some(v) = self.value.as_ref() { match v { - ibc_relayer_change_action::Value::Addition(v) => { + ibc_relayer_change::Value::Addition(v) => { struct_ser.serialize_field("addition", v)?; } - ibc_relayer_change_action::Value::Removal(v) => { + ibc_relayer_change::Value::Removal(v) => { struct_ser.serialize_field("removal", v)?; } } @@ -1213,7 +1210,7 @@ impl serde::Serialize for IbcRelayerChangeAction { struct_ser.end() } } -impl<'de> serde::Deserialize<'de> for IbcRelayerChangeAction { +impl<'de> serde::Deserialize<'de> for IbcRelayerChange { #[allow(deprecated)] fn deserialize(deserializer: D) -> std::result::Result where @@ -1260,13 +1257,13 @@ impl<'de> serde::Deserialize<'de> for IbcRelayerChangeAction { } struct GeneratedVisitor; impl<'de> serde::de::Visitor<'de> for GeneratedVisitor { - type Value = IbcRelayerChangeAction; + type Value = IbcRelayerChange; fn expecting(&self, formatter: &mut std::fmt::Formatter<'_>) -> std::fmt::Result { - formatter.write_str("struct astria.protocol.transactions.v1alpha1.IbcRelayerChangeAction") + formatter.write_str("struct astria.protocol.transactions.v1alpha1.IbcRelayerChange") } - fn visit_map(self, mut map_: V) -> std::result::Result + fn visit_map(self, mut map_: V) -> std::result::Result where V: serde::de::MapAccess<'de>, { @@ -1277,27 +1274,27 @@ impl<'de> serde::Deserialize<'de> for IbcRelayerChangeAction { if value__.is_some() { return Err(serde::de::Error::duplicate_field("addition")); } - value__ = map_.next_value::<::std::option::Option<_>>()?.map(ibc_relayer_change_action::Value::Addition) + value__ = map_.next_value::<::std::option::Option<_>>()?.map(ibc_relayer_change::Value::Addition) ; } GeneratedField::Removal => { if value__.is_some() { return Err(serde::de::Error::duplicate_field("removal")); } - value__ = map_.next_value::<::std::option::Option<_>>()?.map(ibc_relayer_change_action::Value::Removal) + value__ = map_.next_value::<::std::option::Option<_>>()?.map(ibc_relayer_change::Value::Removal) ; } } } - Ok(IbcRelayerChangeAction { + Ok(IbcRelayerChange { value: value__, }) } } - deserializer.deserialize_struct("astria.protocol.transactions.v1alpha1.IbcRelayerChangeAction", FIELDS, GeneratedVisitor) + deserializer.deserialize_struct("astria.protocol.transactions.v1alpha1.IbcRelayerChange", FIELDS, GeneratedVisitor) } } -impl serde::Serialize for IbcSudoChangeAction { +impl serde::Serialize for IbcSudoChange { #[allow(deprecated)] fn serialize(&self, serializer: S) -> std::result::Result where @@ -1308,14 +1305,14 @@ impl serde::Serialize for IbcSudoChangeAction { if self.new_address.is_some() { len += 1; } - let mut struct_ser = serializer.serialize_struct("astria.protocol.transactions.v1alpha1.IbcSudoChangeAction", len)?; + let mut struct_ser = serializer.serialize_struct("astria.protocol.transactions.v1alpha1.IbcSudoChange", len)?; if let Some(v) = self.new_address.as_ref() { struct_ser.serialize_field("newAddress", v)?; } struct_ser.end() } } -impl<'de> serde::Deserialize<'de> for IbcSudoChangeAction { +impl<'de> serde::Deserialize<'de> for IbcSudoChange { #[allow(deprecated)] fn deserialize(deserializer: D) -> std::result::Result where @@ -1360,13 +1357,13 @@ impl<'de> serde::Deserialize<'de> for IbcSudoChangeAction { } struct GeneratedVisitor; impl<'de> serde::de::Visitor<'de> for GeneratedVisitor { - type Value = IbcSudoChangeAction; + type Value = IbcSudoChange; fn expecting(&self, formatter: &mut std::fmt::Formatter<'_>) -> std::fmt::Result { - formatter.write_str("struct astria.protocol.transactions.v1alpha1.IbcSudoChangeAction") + formatter.write_str("struct astria.protocol.transactions.v1alpha1.IbcSudoChange") } - fn visit_map(self, mut map_: V) -> std::result::Result + fn visit_map(self, mut map_: V) -> std::result::Result where V: serde::de::MapAccess<'de>, { @@ -1381,12 +1378,12 @@ impl<'de> serde::Deserialize<'de> for IbcSudoChangeAction { } } } - Ok(IbcSudoChangeAction { + Ok(IbcSudoChange { new_address: new_address__, }) } } - deserializer.deserialize_struct("astria.protocol.transactions.v1alpha1.IbcSudoChangeAction", FIELDS, GeneratedVisitor) + deserializer.deserialize_struct("astria.protocol.transactions.v1alpha1.IbcSudoChange", FIELDS, GeneratedVisitor) } } impl serde::Serialize for Ics20Withdrawal { @@ -1661,7 +1658,7 @@ impl<'de> serde::Deserialize<'de> for Ics20Withdrawal { deserializer.deserialize_struct("astria.protocol.transactions.v1alpha1.Ics20Withdrawal", FIELDS, GeneratedVisitor) } } -impl serde::Serialize for InitBridgeAccountAction { +impl serde::Serialize for InitBridgeAccount { #[allow(deprecated)] fn serialize(&self, serializer: S) -> std::result::Result where @@ -1684,7 +1681,7 @@ impl serde::Serialize for InitBridgeAccountAction { if self.withdrawer_address.is_some() { len += 1; } - let mut struct_ser = serializer.serialize_struct("astria.protocol.transactions.v1alpha1.InitBridgeAccountAction", len)?; + let mut struct_ser = serializer.serialize_struct("astria.protocol.transactions.v1alpha1.InitBridgeAccount", len)?; if let Some(v) = self.rollup_id.as_ref() { struct_ser.serialize_field("rollupId", v)?; } @@ -1703,7 +1700,7 @@ impl serde::Serialize for InitBridgeAccountAction { struct_ser.end() } } -impl<'de> serde::Deserialize<'de> for InitBridgeAccountAction { +impl<'de> serde::Deserialize<'de> for InitBridgeAccount { #[allow(deprecated)] fn deserialize(deserializer: D) -> std::result::Result where @@ -1763,13 +1760,13 @@ impl<'de> serde::Deserialize<'de> for InitBridgeAccountAction { } struct GeneratedVisitor; impl<'de> serde::de::Visitor<'de> for GeneratedVisitor { - type Value = InitBridgeAccountAction; + type Value = InitBridgeAccount; fn expecting(&self, formatter: &mut std::fmt::Formatter<'_>) -> std::fmt::Result { - formatter.write_str("struct astria.protocol.transactions.v1alpha1.InitBridgeAccountAction") + formatter.write_str("struct astria.protocol.transactions.v1alpha1.InitBridgeAccount") } - fn visit_map(self, mut map_: V) -> std::result::Result + fn visit_map(self, mut map_: V) -> std::result::Result where V: serde::de::MapAccess<'de>, { @@ -1812,7 +1809,7 @@ impl<'de> serde::Deserialize<'de> for InitBridgeAccountAction { } } } - Ok(InitBridgeAccountAction { + Ok(InitBridgeAccount { rollup_id: rollup_id__, asset: asset__.unwrap_or_default(), fee_asset: fee_asset__.unwrap_or_default(), @@ -1821,10 +1818,10 @@ impl<'de> serde::Deserialize<'de> for InitBridgeAccountAction { }) } } - deserializer.deserialize_struct("astria.protocol.transactions.v1alpha1.InitBridgeAccountAction", FIELDS, GeneratedVisitor) + deserializer.deserialize_struct("astria.protocol.transactions.v1alpha1.InitBridgeAccount", FIELDS, GeneratedVisitor) } } -impl serde::Serialize for SequenceAction { +impl serde::Serialize for Sequence { #[allow(deprecated)] fn serialize(&self, serializer: S) -> std::result::Result where @@ -1841,7 +1838,7 @@ impl serde::Serialize for SequenceAction { if !self.fee_asset.is_empty() { len += 1; } - let mut struct_ser = serializer.serialize_struct("astria.protocol.transactions.v1alpha1.SequenceAction", len)?; + let mut struct_ser = serializer.serialize_struct("astria.protocol.transactions.v1alpha1.Sequence", len)?; if let Some(v) = self.rollup_id.as_ref() { struct_ser.serialize_field("rollupId", v)?; } @@ -1855,7 +1852,7 @@ impl serde::Serialize for SequenceAction { struct_ser.end() } } -impl<'de> serde::Deserialize<'de> for SequenceAction { +impl<'de> serde::Deserialize<'de> for Sequence { #[allow(deprecated)] fn deserialize(deserializer: D) -> std::result::Result where @@ -1907,13 +1904,13 @@ impl<'de> serde::Deserialize<'de> for SequenceAction { } struct GeneratedVisitor; impl<'de> serde::de::Visitor<'de> for GeneratedVisitor { - type Value = SequenceAction; + type Value = Sequence; fn expecting(&self, formatter: &mut std::fmt::Formatter<'_>) -> std::fmt::Result { - formatter.write_str("struct astria.protocol.transactions.v1alpha1.SequenceAction") + formatter.write_str("struct astria.protocol.transactions.v1alpha1.Sequence") } - fn visit_map(self, mut map_: V) -> std::result::Result + fn visit_map(self, mut map_: V) -> std::result::Result where V: serde::de::MapAccess<'de>, { @@ -1944,14 +1941,14 @@ impl<'de> serde::Deserialize<'de> for SequenceAction { } } } - Ok(SequenceAction { + Ok(Sequence { rollup_id: rollup_id__, data: data__.unwrap_or_default(), fee_asset: fee_asset__.unwrap_or_default(), }) } } - deserializer.deserialize_struct("astria.protocol.transactions.v1alpha1.SequenceAction", FIELDS, GeneratedVisitor) + deserializer.deserialize_struct("astria.protocol.transactions.v1alpha1.Sequence", FIELDS, GeneratedVisitor) } } impl serde::Serialize for SignedTransaction { @@ -2086,7 +2083,7 @@ impl<'de> serde::Deserialize<'de> for SignedTransaction { deserializer.deserialize_struct("astria.protocol.transactions.v1alpha1.SignedTransaction", FIELDS, GeneratedVisitor) } } -impl serde::Serialize for SudoAddressChangeAction { +impl serde::Serialize for SudoAddressChange { #[allow(deprecated)] fn serialize(&self, serializer: S) -> std::result::Result where @@ -2097,14 +2094,14 @@ impl serde::Serialize for SudoAddressChangeAction { if self.new_address.is_some() { len += 1; } - let mut struct_ser = serializer.serialize_struct("astria.protocol.transactions.v1alpha1.SudoAddressChangeAction", len)?; + let mut struct_ser = serializer.serialize_struct("astria.protocol.transactions.v1alpha1.SudoAddressChange", len)?; if let Some(v) = self.new_address.as_ref() { struct_ser.serialize_field("newAddress", v)?; } struct_ser.end() } } -impl<'de> serde::Deserialize<'de> for SudoAddressChangeAction { +impl<'de> serde::Deserialize<'de> for SudoAddressChange { #[allow(deprecated)] fn deserialize(deserializer: D) -> std::result::Result where @@ -2149,13 +2146,13 @@ impl<'de> serde::Deserialize<'de> for SudoAddressChangeAction { } struct GeneratedVisitor; impl<'de> serde::de::Visitor<'de> for GeneratedVisitor { - type Value = SudoAddressChangeAction; + type Value = SudoAddressChange; fn expecting(&self, formatter: &mut std::fmt::Formatter<'_>) -> std::fmt::Result { - formatter.write_str("struct astria.protocol.transactions.v1alpha1.SudoAddressChangeAction") + formatter.write_str("struct astria.protocol.transactions.v1alpha1.SudoAddressChange") } - fn visit_map(self, mut map_: V) -> std::result::Result + fn visit_map(self, mut map_: V) -> std::result::Result where V: serde::de::MapAccess<'de>, { @@ -2170,12 +2167,12 @@ impl<'de> serde::Deserialize<'de> for SudoAddressChangeAction { } } } - Ok(SudoAddressChangeAction { + Ok(SudoAddressChange { new_address: new_address__, }) } } - deserializer.deserialize_struct("astria.protocol.transactions.v1alpha1.SudoAddressChangeAction", FIELDS, GeneratedVisitor) + deserializer.deserialize_struct("astria.protocol.transactions.v1alpha1.SudoAddressChange", FIELDS, GeneratedVisitor) } } impl serde::Serialize for TransactionFee { @@ -2508,7 +2505,7 @@ impl<'de> serde::Deserialize<'de> for TransactionParams { deserializer.deserialize_struct("astria.protocol.transactions.v1alpha1.TransactionParams", FIELDS, GeneratedVisitor) } } -impl serde::Serialize for TransferAction { +impl serde::Serialize for Transfer { #[allow(deprecated)] fn serialize(&self, serializer: S) -> std::result::Result where @@ -2528,7 +2525,7 @@ impl serde::Serialize for TransferAction { if !self.fee_asset.is_empty() { len += 1; } - let mut struct_ser = serializer.serialize_struct("astria.protocol.transactions.v1alpha1.TransferAction", len)?; + let mut struct_ser = serializer.serialize_struct("astria.protocol.transactions.v1alpha1.Transfer", len)?; if let Some(v) = self.to.as_ref() { struct_ser.serialize_field("to", v)?; } @@ -2544,7 +2541,7 @@ impl serde::Serialize for TransferAction { struct_ser.end() } } -impl<'de> serde::Deserialize<'de> for TransferAction { +impl<'de> serde::Deserialize<'de> for Transfer { #[allow(deprecated)] fn deserialize(deserializer: D) -> std::result::Result where @@ -2598,13 +2595,13 @@ impl<'de> serde::Deserialize<'de> for TransferAction { } struct GeneratedVisitor; impl<'de> serde::de::Visitor<'de> for GeneratedVisitor { - type Value = TransferAction; + type Value = Transfer; fn expecting(&self, formatter: &mut std::fmt::Formatter<'_>) -> std::fmt::Result { - formatter.write_str("struct astria.protocol.transactions.v1alpha1.TransferAction") + formatter.write_str("struct astria.protocol.transactions.v1alpha1.Transfer") } - fn visit_map(self, mut map_: V) -> std::result::Result + fn visit_map(self, mut map_: V) -> std::result::Result where V: serde::de::MapAccess<'de>, { @@ -2640,7 +2637,7 @@ impl<'de> serde::Deserialize<'de> for TransferAction { } } } - Ok(TransferAction { + Ok(Transfer { to: to__, amount: amount__, asset: asset__.unwrap_or_default(), @@ -2648,7 +2645,7 @@ impl<'de> serde::Deserialize<'de> for TransferAction { }) } } - deserializer.deserialize_struct("astria.protocol.transactions.v1alpha1.TransferAction", FIELDS, GeneratedVisitor) + deserializer.deserialize_struct("astria.protocol.transactions.v1alpha1.Transfer", FIELDS, GeneratedVisitor) } } impl serde::Serialize for UnsignedTransaction { diff --git a/crates/astria-core/src/protocol/test_utils.rs b/crates/astria-core/src/protocol/test_utils.rs index c1edc8e92f..6b389039bf 100644 --- a/crates/astria-core/src/protocol/test_utils.rs +++ b/crates/astria-core/src/protocol/test_utils.rs @@ -7,7 +7,7 @@ use prost::Message as _; use super::{ group_sequence_actions_in_signed_transaction_transactions_by_rollup_id, - transaction::v1alpha1::action::SequenceAction, + transaction::v1alpha1::action::Sequence, }; use crate::{ crypto::SigningKey, @@ -93,7 +93,7 @@ impl ConfigureSequencerBlock { let actions: Vec = sequence_data .into_iter() .map(|(rollup_id, data)| { - SequenceAction { + Sequence { rollup_id, data: data.into(), fee_asset: "nria".parse().unwrap(), diff --git a/crates/astria-core/src/protocol/transaction/v1alpha1/action.rs b/crates/astria-core/src/protocol/transaction/v1alpha1/action.rs index 5a4ef5d88b..4482a6ac85 100644 --- a/crates/astria-core/src/protocol/transaction/v1alpha1/action.rs +++ b/crates/astria-core/src/protocol/transaction/v1alpha1/action.rs @@ -30,20 +30,20 @@ use crate::{ serde(into = "raw::Action", try_from = "raw::Action") )] pub enum Action { - Sequence(SequenceAction), - Transfer(TransferAction), + Sequence(Sequence), + Transfer(Transfer), ValidatorUpdate(ValidatorUpdate), - SudoAddressChange(SudoAddressChangeAction), + SudoAddressChange(SudoAddressChange), Ibc(IbcRelay), - IbcSudoChange(IbcSudoChangeAction), + IbcSudoChange(IbcSudoChange), Ics20Withdrawal(Ics20Withdrawal), - IbcRelayerChange(IbcRelayerChangeAction), - FeeAssetChange(FeeAssetChangeAction), - InitBridgeAccount(InitBridgeAccountAction), - BridgeLock(BridgeLockAction), - BridgeUnlock(BridgeUnlockAction), - BridgeSudoChange(BridgeSudoChangeAction), - FeeChange(FeeChangeAction), + IbcRelayerChange(IbcRelayerChange), + FeeAssetChange(FeeAssetChange), + InitBridgeAccount(InitBridgeAccount), + BridgeLock(BridgeLock), + BridgeUnlock(BridgeUnlock), + BridgeSudoChange(BridgeSudoChange), + FeeChange(FeeChange), } impl Protobuf for Action { @@ -54,22 +54,20 @@ impl Protobuf for Action { fn to_raw(&self) -> Self::Raw { use raw::action::Value; let kind = match self { - Action::Sequence(act) => Value::SequenceAction(act.to_raw()), - Action::Transfer(act) => Value::TransferAction(act.to_raw()), - Action::ValidatorUpdate(act) => Value::ValidatorUpdateAction(act.to_raw()), - Action::SudoAddressChange(act) => { - Value::SudoAddressChangeAction(act.clone().into_raw()) - } - Action::Ibc(act) => Value::IbcAction(act.clone().into()), - Action::IbcSudoChange(act) => Value::IbcSudoChangeAction(act.clone().into_raw()), + Action::Sequence(act) => Value::Sequence(act.to_raw()), + Action::Transfer(act) => Value::Transfer(act.to_raw()), + Action::ValidatorUpdate(act) => Value::ValidatorUpdate(act.to_raw()), + Action::SudoAddressChange(act) => Value::SudoAddressChange(act.clone().into_raw()), + Action::Ibc(act) => Value::Ibc(act.clone().into()), + Action::IbcSudoChange(act) => Value::IbcSudoChange(act.clone().into_raw()), Action::Ics20Withdrawal(act) => Value::Ics20Withdrawal(act.to_raw()), - Action::IbcRelayerChange(act) => Value::IbcRelayerChangeAction(act.to_raw()), - Action::FeeAssetChange(act) => Value::FeeAssetChangeAction(act.to_raw()), - Action::InitBridgeAccount(act) => Value::InitBridgeAccountAction(act.to_raw()), - Action::BridgeLock(act) => Value::BridgeLockAction(act.to_raw()), - Action::BridgeUnlock(act) => Value::BridgeUnlockAction(act.to_raw()), - Action::BridgeSudoChange(act) => Value::BridgeSudoChangeAction(act.to_raw()), - Action::FeeChange(act) => Value::FeeChangeAction(act.to_raw()), + Action::IbcRelayerChange(act) => Value::IbcRelayerChange(act.to_raw()), + Action::FeeAssetChange(act) => Value::FeeAssetChange(act.to_raw()), + Action::InitBridgeAccount(act) => Value::InitBridgeAccount(act.to_raw()), + Action::BridgeLock(act) => Value::BridgeLock(act.to_raw()), + Action::BridgeUnlock(act) => Value::BridgeUnlock(act.to_raw()), + Action::BridgeSudoChange(act) => Value::BridgeSudoChange(act.to_raw()), + Action::FeeChange(act) => Value::FeeChange(act.to_raw()), }; raw::Action { value: Some(kind), @@ -101,53 +99,49 @@ impl Protobuf for Action { return Err(ActionError::unset()); }; let action = match action { - Value::SequenceAction(act) => { - Self::Sequence(SequenceAction::try_from_raw(act).map_err(ActionError::sequence)?) + Value::Sequence(act) => { + Self::Sequence(Sequence::try_from_raw(act).map_err(ActionError::sequence)?) } - Value::TransferAction(act) => { - Self::Transfer(TransferAction::try_from_raw(act).map_err(ActionError::transfer)?) + Value::Transfer(act) => { + Self::Transfer(Transfer::try_from_raw(act).map_err(ActionError::transfer)?) } - Value::ValidatorUpdateAction(act) => Self::ValidatorUpdate( + Value::ValidatorUpdate(act) => Self::ValidatorUpdate( ValidatorUpdate::try_from_raw(act).map_err(ActionError::validator_update)?, ), - Value::SudoAddressChangeAction(act) => Self::SudoAddressChange( - SudoAddressChangeAction::try_from_raw(act) - .map_err(ActionError::sudo_address_change)?, + Value::SudoAddressChange(act) => Self::SudoAddressChange( + SudoAddressChange::try_from_raw(act).map_err(ActionError::sudo_address_change)?, ), - Value::IbcSudoChangeAction(act) => Self::IbcSudoChange( - IbcSudoChangeAction::try_from_raw(act).map_err(ActionError::ibc_sudo_change)?, + Value::IbcSudoChange(act) => Self::IbcSudoChange( + IbcSudoChange::try_from_raw(act).map_err(ActionError::ibc_sudo_change)?, ), - Value::IbcAction(act) => { + Value::Ibc(act) => { Self::Ibc(IbcRelay::try_from(act).map_err(|e| ActionError::ibc(e.into()))?) } Value::Ics20Withdrawal(act) => Self::Ics20Withdrawal( Ics20Withdrawal::try_from_raw(act).map_err(ActionError::ics20_withdrawal)?, ), - Value::IbcRelayerChangeAction(act) => Self::IbcRelayerChange( - IbcRelayerChangeAction::try_from_raw_ref(&act) + Value::IbcRelayerChange(act) => Self::IbcRelayerChange( + IbcRelayerChange::try_from_raw_ref(&act) .map_err(ActionError::ibc_relayer_change)?, ), - Value::FeeAssetChangeAction(act) => Self::FeeAssetChange( - FeeAssetChangeAction::try_from_raw_ref(&act) - .map_err(ActionError::fee_asset_change)?, - ), - Value::InitBridgeAccountAction(act) => Self::InitBridgeAccount( - InitBridgeAccountAction::try_from_raw(act) - .map_err(ActionError::init_bridge_account)?, - ), - Value::BridgeLockAction(act) => Self::BridgeLock( - BridgeLockAction::try_from_raw(act).map_err(ActionError::bridge_lock)?, + Value::FeeAssetChange(act) => Self::FeeAssetChange( + FeeAssetChange::try_from_raw_ref(&act).map_err(ActionError::fee_asset_change)?, ), - Value::BridgeUnlockAction(act) => Self::BridgeUnlock( - BridgeUnlockAction::try_from_raw(act).map_err(ActionError::bridge_unlock)?, + Value::InitBridgeAccount(act) => Self::InitBridgeAccount( + InitBridgeAccount::try_from_raw(act).map_err(ActionError::init_bridge_account)?, ), - Value::BridgeSudoChangeAction(act) => Self::BridgeSudoChange( - BridgeSudoChangeAction::try_from_raw(act) - .map_err(ActionError::bridge_sudo_change)?, + Value::BridgeLock(act) => { + Self::BridgeLock(BridgeLock::try_from_raw(act).map_err(ActionError::bridge_lock)?) + } + Value::BridgeUnlock(act) => Self::BridgeUnlock( + BridgeUnlock::try_from_raw(act).map_err(ActionError::bridge_unlock)?, ), - Value::FeeChangeAction(act) => Self::FeeChange( - FeeChangeAction::try_from_raw_ref(&act).map_err(ActionError::fee_change)?, + Value::BridgeSudoChange(act) => Self::BridgeSudoChange( + BridgeSudoChange::try_from_raw(act).map_err(ActionError::bridge_sudo_change)?, ), + Value::FeeChange(act) => { + Self::FeeChange(FeeChange::try_from_raw_ref(&act).map_err(ActionError::fee_change)?) + } }; Ok(action) } @@ -156,7 +150,7 @@ impl Protobuf for Action { // TODO: add unit tests for these methods (https://github.com/astriaorg/astria/issues/1593) impl Action { #[must_use] - pub fn as_sequence(&self) -> Option<&SequenceAction> { + pub fn as_sequence(&self) -> Option<&Sequence> { let Self::Sequence(sequence_action) = self else { return None; }; @@ -164,7 +158,7 @@ impl Action { } #[must_use] - pub fn as_transfer(&self) -> Option<&TransferAction> { + pub fn as_transfer(&self) -> Option<&Transfer> { let Self::Transfer(transfer_action) = self else { return None; }; @@ -180,26 +174,26 @@ impl Action { } } -impl From for Action { - fn from(value: SequenceAction) -> Self { +impl From for Action { + fn from(value: Sequence) -> Self { Self::Sequence(value) } } -impl From for Action { - fn from(value: TransferAction) -> Self { +impl From for Action { + fn from(value: Transfer) -> Self { Self::Transfer(value) } } -impl From for Action { - fn from(value: SudoAddressChangeAction) -> Self { +impl From for Action { + fn from(value: SudoAddressChange) -> Self { Self::SudoAddressChange(value) } } -impl From for Action { - fn from(value: IbcSudoChangeAction) -> Self { +impl From for Action { + fn from(value: IbcSudoChange) -> Self { Self::IbcSudoChange(value) } } @@ -216,44 +210,44 @@ impl From for Action { } } -impl From for Action { - fn from(value: IbcRelayerChangeAction) -> Self { +impl From for Action { + fn from(value: IbcRelayerChange) -> Self { Self::IbcRelayerChange(value) } } -impl From for Action { - fn from(value: FeeAssetChangeAction) -> Self { +impl From for Action { + fn from(value: FeeAssetChange) -> Self { Self::FeeAssetChange(value) } } -impl From for Action { - fn from(value: InitBridgeAccountAction) -> Self { +impl From for Action { + fn from(value: InitBridgeAccount) -> Self { Self::InitBridgeAccount(value) } } -impl From for Action { - fn from(value: BridgeLockAction) -> Self { +impl From for Action { + fn from(value: BridgeLock) -> Self { Self::BridgeLock(value) } } -impl From for Action { - fn from(value: BridgeUnlockAction) -> Self { +impl From for Action { + fn from(value: BridgeUnlock) -> Self { Self::BridgeUnlock(value) } } -impl From for Action { - fn from(value: BridgeSudoChangeAction) -> Self { +impl From for Action { + fn from(value: BridgeSudoChange) -> Self { Self::BridgeSudoChange(value) } } -impl From for Action { - fn from(value: FeeChangeAction) -> Self { +impl From for Action { + fn from(value: FeeChange) -> Self { Self::FeeChange(value) } } @@ -299,10 +293,6 @@ impl ActionName for Action { } } -#[expect( - clippy::module_name_repetitions, - reason = "for parity with the Protobuf spec" -)] #[derive(Debug, thiserror::Error)] #[error(transparent)] pub struct ActionError(ActionErrorKind); @@ -312,11 +302,11 @@ impl ActionError { Self(ActionErrorKind::Unset) } - fn sequence(inner: SequenceActionError) -> Self { + fn sequence(inner: SequenceError) -> Self { Self(ActionErrorKind::Sequence(inner)) } - fn transfer(inner: TransferActionError) -> Self { + fn transfer(inner: TransferError) -> Self { Self(ActionErrorKind::Transfer(inner)) } @@ -324,11 +314,11 @@ impl ActionError { Self(ActionErrorKind::ValidatorUpdate(inner)) } - fn sudo_address_change(inner: SudoAddressChangeActionError) -> Self { + fn sudo_address_change(inner: SudoAddressChangeError) -> Self { Self(ActionErrorKind::SudoAddressChange(inner)) } - fn ibc_sudo_change(inner: IbcSudoChangeActionError) -> Self { + fn ibc_sudo_change(inner: IbcSudoChangeError) -> Self { Self(ActionErrorKind::IbcSudoChange(inner)) } @@ -340,31 +330,31 @@ impl ActionError { Self(ActionErrorKind::Ics20Withdrawal(inner)) } - fn ibc_relayer_change(inner: IbcRelayerChangeActionError) -> Self { + fn ibc_relayer_change(inner: IbcRelayerChangeError) -> Self { Self(ActionErrorKind::IbcRelayerChange(inner)) } - fn fee_asset_change(inner: FeeAssetChangeActionError) -> Self { + fn fee_asset_change(inner: FeeAssetChangeError) -> Self { Self(ActionErrorKind::FeeAssetChange(inner)) } - fn init_bridge_account(inner: InitBridgeAccountActionError) -> Self { + fn init_bridge_account(inner: InitBridgeAccountError) -> Self { Self(ActionErrorKind::InitBridgeAccount(inner)) } - fn bridge_lock(inner: BridgeLockActionError) -> Self { + fn bridge_lock(inner: BridgeLockError) -> Self { Self(ActionErrorKind::BridgeLock(inner)) } - fn bridge_unlock(inner: BridgeUnlockActionError) -> Self { + fn bridge_unlock(inner: BridgeUnlockError) -> Self { Self(ActionErrorKind::BridgeUnlock(inner)) } - fn bridge_sudo_change(inner: BridgeSudoChangeActionError) -> Self { + fn bridge_sudo_change(inner: BridgeSudoChangeError) -> Self { Self(ActionErrorKind::BridgeSudoChange(inner)) } - fn fee_change(inner: FeeChangeActionError) -> Self { + fn fee_change(inner: FeeChangeError) -> Self { Self(ActionErrorKind::FeeChange(inner)) } } @@ -374,55 +364,55 @@ enum ActionErrorKind { #[error("required action value was not set")] Unset, #[error("sequence action was not valid")] - Sequence(#[source] SequenceActionError), + Sequence(#[source] SequenceError), #[error("transfer action was not valid")] - Transfer(#[source] TransferActionError), + Transfer(#[source] TransferError), #[error("validator update action was not valid")] ValidatorUpdate(#[source] ValidatorUpdateError), #[error("sudo address change action was not valid")] - SudoAddressChange(#[source] SudoAddressChangeActionError), + SudoAddressChange(#[source] SudoAddressChangeError), #[error("ibc sudo address change action was not valid")] - IbcSudoChange(#[source] IbcSudoChangeActionError), + IbcSudoChange(#[source] IbcSudoChangeError), #[error("ibc action was not valid")] Ibc(#[source] Box), #[error("ics20 withdrawal action was not valid")] Ics20Withdrawal(#[source] Ics20WithdrawalError), #[error("ibc relayer change action was not valid")] - IbcRelayerChange(#[source] IbcRelayerChangeActionError), + IbcRelayerChange(#[source] IbcRelayerChangeError), #[error("fee asset change action was not valid")] - FeeAssetChange(#[source] FeeAssetChangeActionError), + FeeAssetChange(#[source] FeeAssetChangeError), #[error("init bridge account action was not valid")] - InitBridgeAccount(#[source] InitBridgeAccountActionError), + InitBridgeAccount(#[source] InitBridgeAccountError), #[error("bridge lock action was not valid")] - BridgeLock(#[source] BridgeLockActionError), + BridgeLock(#[source] BridgeLockError), #[error("bridge unlock action was not valid")] - BridgeUnlock(#[source] BridgeUnlockActionError), + BridgeUnlock(#[source] BridgeUnlockError), #[error("bridge sudo change action was not valid")] - BridgeSudoChange(#[source] BridgeSudoChangeActionError), + BridgeSudoChange(#[source] BridgeSudoChangeError), #[error("fee change action was not valid")] - FeeChange(#[source] FeeChangeActionError), + FeeChange(#[source] FeeChangeError), } #[derive(Debug, thiserror::Error)] #[error(transparent)] -pub struct SequenceActionError(SequenceActionErrorKind); +pub struct SequenceError(SequenceErrorKind); -impl SequenceActionError { +impl SequenceError { fn field_not_set(field: &'static str) -> Self { - Self(SequenceActionErrorKind::FieldNotSet(field)) + Self(SequenceErrorKind::FieldNotSet(field)) } fn rollup_id_length(inner: IncorrectRollupIdLength) -> Self { - Self(SequenceActionErrorKind::RollupIdLength(inner)) + Self(SequenceErrorKind::RollupIdLength(inner)) } fn fee_asset(inner: asset::ParseDenomError) -> Self { - Self(SequenceActionErrorKind::FeeAsset(inner)) + Self(SequenceErrorKind::FeeAsset(inner)) } } #[derive(Debug, thiserror::Error)] -enum SequenceActionErrorKind { +enum SequenceErrorKind { #[error("the expected field in the raw source type was not set: `{0}`")] FieldNotSet(&'static str), #[error("`rollup_id` field did not contain a valid rollup ID")] @@ -432,29 +422,25 @@ enum SequenceActionErrorKind { } #[derive(Clone, Debug)] -#[expect( - clippy::module_name_repetitions, - reason = "for parity with the Protobuf spec" -)] -pub struct SequenceAction { +pub struct Sequence { pub rollup_id: RollupId, pub data: Bytes, /// asset to use for fee payment. pub fee_asset: asset::Denom, } -impl Protobuf for SequenceAction { - type Error = SequenceActionError; - type Raw = raw::SequenceAction; +impl Protobuf for Sequence { + type Error = SequenceError; + type Raw = raw::Sequence; #[must_use] - fn to_raw(&self) -> raw::SequenceAction { + fn to_raw(&self) -> raw::Sequence { let Self { rollup_id, data, fee_asset, } = self; - raw::SequenceAction { + raw::Sequence { rollup_id: Some(rollup_id.to_raw()), data: data.clone(), fee_asset: fee_asset.to_string(), @@ -466,17 +452,17 @@ impl Protobuf for SequenceAction { /// # Errors /// Returns `SequenceActionError` if the `proto.rollup_id` field was not 32 bytes. fn try_from_raw_ref(raw: &Self::Raw) -> Result { - let raw::SequenceAction { + let raw::Sequence { rollup_id, data, fee_asset, } = raw; let Some(rollup_id) = rollup_id else { - return Err(SequenceActionError::field_not_set("rollup_id")); + return Err(SequenceError::field_not_set("rollup_id")); }; let rollup_id = - RollupId::try_from_raw(rollup_id).map_err(SequenceActionError::rollup_id_length)?; - let fee_asset = fee_asset.parse().map_err(SequenceActionError::fee_asset)?; + RollupId::try_from_raw(rollup_id).map_err(SequenceError::rollup_id_length)?; + let fee_asset = fee_asset.parse().map_err(SequenceError::fee_asset)?; let data = data.clone(); Ok(Self { rollup_id, @@ -487,11 +473,7 @@ impl Protobuf for SequenceAction { } #[derive(Clone, Debug)] -#[expect( - clippy::module_name_repetitions, - reason = "for parity with the Protobuf spec" -)] -pub struct TransferAction { +pub struct Transfer { pub to: Address, pub amount: u128, /// asset to be transferred. @@ -500,19 +482,19 @@ pub struct TransferAction { pub fee_asset: asset::Denom, } -impl Protobuf for TransferAction { - type Error = TransferActionError; - type Raw = raw::TransferAction; +impl Protobuf for Transfer { + type Error = TransferError; + type Raw = raw::Transfer; #[must_use] - fn to_raw(&self) -> raw::TransferAction { + fn to_raw(&self) -> raw::Transfer { let Self { to, amount, asset, fee_asset, } = self; - raw::TransferAction { + raw::Transfer { to: Some(to.to_raw()), amount: Some((*amount).into()), asset: asset.to_string(), @@ -526,19 +508,19 @@ impl Protobuf for TransferAction { /// Returns `TransferActionError` if the raw action's `to` address did not have the expected /// length. fn try_from_raw_ref(raw: &Self::Raw) -> Result { - let raw::TransferAction { + let raw::Transfer { to, amount, asset, fee_asset, } = raw; let Some(to) = to else { - return Err(TransferActionError::field_not_set("to")); + return Err(TransferError::field_not_set("to")); }; - let to = Address::try_from_raw(to).map_err(TransferActionError::address)?; + let to = Address::try_from_raw(to).map_err(TransferError::address)?; let amount = amount.map_or(0, Into::into); - let asset = asset.parse().map_err(TransferActionError::asset)?; - let fee_asset = fee_asset.parse().map_err(TransferActionError::fee_asset)?; + let asset = asset.parse().map_err(TransferError::asset)?; + let fee_asset = fee_asset.parse().map_err(TransferError::fee_asset)?; Ok(Self { to, @@ -551,9 +533,9 @@ impl Protobuf for TransferAction { #[derive(Debug, thiserror::Error)] #[error(transparent)] -pub struct TransferActionError(TransferActionErrorKind); +pub struct TransferError(TransferActionErrorKind); -impl TransferActionError { +impl TransferError { fn field_not_set(field: &'static str) -> Self { Self(TransferActionErrorKind::FieldNotSet(field)) } @@ -736,52 +718,48 @@ impl TryFrom raw::SudoAddressChangeAction { + fn into_raw(self) -> raw::SudoAddressChange { let Self { new_address, } = self; - raw::SudoAddressChangeAction { + raw::SudoAddressChange { new_address: Some(new_address.into_raw()), } } #[must_use] - fn to_raw(&self) -> raw::SudoAddressChangeAction { + fn to_raw(&self) -> raw::SudoAddressChange { let Self { new_address, } = self; - raw::SudoAddressChangeAction { + raw::SudoAddressChange { new_address: Some(new_address.to_raw()), } } - /// Convert from a reference to a raw, unchecked protobuf [`raw::SudoAddressChangeAction`]. + /// Convert from a reference to a raw, unchecked protobuf [`raw::SudoAddressChange`]. /// /// # Errors /// /// Returns an error if the raw action's `new_address` did not have the expected /// length. - fn try_from_raw_ref(proto: &Self::Raw) -> Result { - let raw::SudoAddressChangeAction { + fn try_from_raw_ref(proto: &Self::Raw) -> Result { + let raw::SudoAddressChange { new_address, } = proto; let Some(new_address) = new_address else { - return Err(SudoAddressChangeActionError::field_not_set("new_address")); + return Err(SudoAddressChangeError::field_not_set("new_address")); }; let new_address = - Address::try_from_raw(new_address).map_err(SudoAddressChangeActionError::address)?; + Address::try_from_raw(new_address).map_err(SudoAddressChangeError::address)?; Ok(Self { new_address, }) @@ -790,22 +768,22 @@ impl Protobuf for SudoAddressChangeAction { #[derive(Debug, thiserror::Error)] #[error(transparent)] -pub struct SudoAddressChangeActionError(SudoAddressChangeActionErrorKind); +pub struct SudoAddressChangeError(SudoAddressChangeErrorKind); -impl SudoAddressChangeActionError { +impl SudoAddressChangeError { fn field_not_set(field: &'static str) -> Self { - Self(SudoAddressChangeActionErrorKind::FieldNotSet(field)) + Self(SudoAddressChangeErrorKind::FieldNotSet(field)) } fn address(source: AddressError) -> Self { - Self(SudoAddressChangeActionErrorKind::Address { + Self(SudoAddressChangeErrorKind::Address { source, }) } } #[derive(Debug, thiserror::Error)] -enum SudoAddressChangeActionErrorKind { +enum SudoAddressChangeErrorKind { #[error("the expected field in the raw source type was not set: `{0}`")] FieldNotSet(&'static str), #[error("`new_address` field did not contain a valid address")] @@ -813,27 +791,23 @@ enum SudoAddressChangeActionErrorKind { } #[derive(Debug, Clone)] -#[expect( - clippy::module_name_repetitions, - reason = "for parity with the Protobuf spec" -)] -pub struct IbcSudoChangeAction { +pub struct IbcSudoChange { pub new_address: Address, } -impl Protobuf for IbcSudoChangeAction { - type Error = IbcSudoChangeActionError; - type Raw = raw::IbcSudoChangeAction; +impl Protobuf for IbcSudoChange { + type Error = IbcSudoChangeError; + type Raw = raw::IbcSudoChange; - fn into_raw(self) -> raw::IbcSudoChangeAction { - raw::IbcSudoChangeAction { + fn into_raw(self) -> raw::IbcSudoChange { + raw::IbcSudoChange { new_address: Some(self.new_address.into_raw()), } } #[must_use] - fn to_raw(&self) -> raw::IbcSudoChangeAction { - raw::IbcSudoChangeAction { + fn to_raw(&self) -> raw::IbcSudoChange { + raw::IbcSudoChange { new_address: Some(self.new_address.to_raw()), } } @@ -844,15 +818,15 @@ impl Protobuf for IbcSudoChangeAction { /// /// Returns an error if the raw action's `new_address` did not have the expected /// length or if the field was not set. - fn try_from_raw_ref(proto: &Self::Raw) -> Result { - let raw::IbcSudoChangeAction { + fn try_from_raw_ref(proto: &Self::Raw) -> Result { + let raw::IbcSudoChange { new_address, } = proto; let Some(new_address) = new_address else { - return Err(IbcSudoChangeActionError::field_not_set("new_address")); + return Err(IbcSudoChangeError::field_not_set("new_address")); }; let new_address = - Address::try_from_raw(new_address).map_err(IbcSudoChangeActionError::address)?; + Address::try_from_raw(new_address).map_err(IbcSudoChangeError::address)?; Ok(Self { new_address, }) @@ -861,22 +835,22 @@ impl Protobuf for IbcSudoChangeAction { #[derive(Debug, thiserror::Error)] #[error(transparent)] -pub struct IbcSudoChangeActionError(IbcSudoChangeActionErrorKind); +pub struct IbcSudoChangeError(IbcSudoChangeErrorKind); -impl IbcSudoChangeActionError { +impl IbcSudoChangeError { fn field_not_set(field: &'static str) -> Self { - Self(IbcSudoChangeActionErrorKind::FieldNotSet(field)) + Self(IbcSudoChangeErrorKind::FieldNotSet(field)) } fn address(source: AddressError) -> Self { - Self(IbcSudoChangeActionErrorKind::Address { + Self(IbcSudoChangeErrorKind::Address { source, }) } } #[derive(Debug, thiserror::Error)] -enum IbcSudoChangeActionErrorKind { +enum IbcSudoChangeErrorKind { #[error("the expected field in the raw source type was not set: `{0}`")] FieldNotSet(&'static str), #[error("`new_sudo` field did not contain a valid address")] @@ -1217,32 +1191,24 @@ enum Ics20WithdrawalErrorKind { InvalidDenom { source: asset::ParseDenomError }, } -#[expect( - clippy::module_name_repetitions, - reason = "for parity with the Protobuf spec" -)] #[derive(Debug, Clone)] -pub enum IbcRelayerChangeAction { +pub enum IbcRelayerChange { Addition(Address), Removal(Address), } -impl Protobuf for IbcRelayerChangeAction { - type Error = IbcRelayerChangeActionError; - type Raw = raw::IbcRelayerChangeAction; +impl Protobuf for IbcRelayerChange { + type Error = IbcRelayerChangeError; + type Raw = raw::IbcRelayerChange; #[must_use] - fn to_raw(&self) -> raw::IbcRelayerChangeAction { + fn to_raw(&self) -> raw::IbcRelayerChange { match self { - IbcRelayerChangeAction::Addition(address) => raw::IbcRelayerChangeAction { - value: Some(raw::ibc_relayer_change_action::Value::Addition( - address.to_raw(), - )), + IbcRelayerChange::Addition(address) => raw::IbcRelayerChange { + value: Some(raw::ibc_relayer_change::Value::Addition(address.to_raw())), }, - IbcRelayerChangeAction::Removal(address) => raw::IbcRelayerChangeAction { - value: Some(raw::ibc_relayer_change_action::Value::Removal( - address.to_raw(), - )), + IbcRelayerChange::Removal(address) => raw::IbcRelayerChange { + value: Some(raw::ibc_relayer_change::Value::Removal(address.to_raw())), }, } } @@ -1252,81 +1218,71 @@ impl Protobuf for IbcRelayerChangeAction { /// # Errors /// /// - if the `address` field is invalid - fn try_from_raw_ref( - raw: &raw::IbcRelayerChangeAction, - ) -> Result { + fn try_from_raw_ref(raw: &raw::IbcRelayerChange) -> Result { match raw { - raw::IbcRelayerChangeAction { - value: Some(raw::ibc_relayer_change_action::Value::Addition(address)), + raw::IbcRelayerChange { + value: Some(raw::ibc_relayer_change::Value::Addition(address)), } => { let address = - Address::try_from_raw(address).map_err(IbcRelayerChangeActionError::address)?; - Ok(IbcRelayerChangeAction::Addition(address)) + Address::try_from_raw(address).map_err(IbcRelayerChangeError::address)?; + Ok(IbcRelayerChange::Addition(address)) } - raw::IbcRelayerChangeAction { - value: Some(raw::ibc_relayer_change_action::Value::Removal(address)), + raw::IbcRelayerChange { + value: Some(raw::ibc_relayer_change::Value::Removal(address)), } => { let address = - Address::try_from_raw(address).map_err(IbcRelayerChangeActionError::address)?; - Ok(IbcRelayerChangeAction::Removal(address)) + Address::try_from_raw(address).map_err(IbcRelayerChangeError::address)?; + Ok(IbcRelayerChange::Removal(address)) } - _ => Err(IbcRelayerChangeActionError::missing_address()), + _ => Err(IbcRelayerChangeError::missing_address()), } } } #[derive(Debug, thiserror::Error)] #[error(transparent)] -pub struct IbcRelayerChangeActionError(IbcRelayerChangeActionErrorKind); +pub struct IbcRelayerChangeError(IbcRelayerChangeErrorKind); -impl IbcRelayerChangeActionError { +impl IbcRelayerChangeError { #[must_use] fn address(source: AddressError) -> Self { - Self(IbcRelayerChangeActionErrorKind::Address { + Self(IbcRelayerChangeErrorKind::Address { source, }) } #[must_use] fn missing_address() -> Self { - Self(IbcRelayerChangeActionErrorKind::MissingAddress) + Self(IbcRelayerChangeErrorKind::MissingAddress) } } #[derive(Debug, thiserror::Error)] -enum IbcRelayerChangeActionErrorKind { +enum IbcRelayerChangeErrorKind { #[error("the `address` was invalid")] Address { source: AddressError }, #[error("the `address` was not set")] MissingAddress, } -#[expect( - clippy::module_name_repetitions, - reason = "for parity with the Protobuf spec" -)] #[derive(Debug, Clone)] -pub enum FeeAssetChangeAction { +pub enum FeeAssetChange { Addition(asset::Denom), Removal(asset::Denom), } -impl Protobuf for FeeAssetChangeAction { - type Error = FeeAssetChangeActionError; - type Raw = raw::FeeAssetChangeAction; +impl Protobuf for FeeAssetChange { + type Error = FeeAssetChangeError; + type Raw = raw::FeeAssetChange; #[must_use] - fn to_raw(&self) -> raw::FeeAssetChangeAction { + fn to_raw(&self) -> raw::FeeAssetChange { match self { - FeeAssetChangeAction::Addition(asset) => raw::FeeAssetChangeAction { - value: Some(raw::fee_asset_change_action::Value::Addition( - asset.to_string(), - )), + FeeAssetChange::Addition(asset) => raw::FeeAssetChange { + value: Some(raw::fee_asset_change::Value::Addition(asset.to_string())), }, - FeeAssetChangeAction::Removal(asset) => raw::FeeAssetChangeAction { - value: Some(raw::fee_asset_change_action::Value::Removal( - asset.to_string(), - )), + FeeAssetChange::Removal(asset) => raw::FeeAssetChange { + value: Some(raw::fee_asset_change::Value::Removal(asset.to_string())), }, } } @@ -1336,61 +1292,51 @@ impl Protobuf for FeeAssetChangeAction { /// # Errors /// /// - if the `asset` field is invalid - fn try_from_raw_ref( - raw: &raw::FeeAssetChangeAction, - ) -> Result { + fn try_from_raw_ref(raw: &raw::FeeAssetChange) -> Result { match raw { - raw::FeeAssetChangeAction { - value: Some(raw::fee_asset_change_action::Value::Addition(asset)), + raw::FeeAssetChange { + value: Some(raw::fee_asset_change::Value::Addition(asset)), } => { - let asset = asset - .parse() - .map_err(FeeAssetChangeActionError::invalid_asset)?; - Ok(FeeAssetChangeAction::Addition(asset)) + let asset = asset.parse().map_err(FeeAssetChangeError::invalid_asset)?; + Ok(FeeAssetChange::Addition(asset)) } - raw::FeeAssetChangeAction { - value: Some(raw::fee_asset_change_action::Value::Removal(asset)), + raw::FeeAssetChange { + value: Some(raw::fee_asset_change::Value::Removal(asset)), } => { - let asset = asset - .parse() - .map_err(FeeAssetChangeActionError::invalid_asset)?; - Ok(FeeAssetChangeAction::Removal(asset)) + let asset = asset.parse().map_err(FeeAssetChangeError::invalid_asset)?; + Ok(FeeAssetChange::Removal(asset)) } - _ => Err(FeeAssetChangeActionError::missing_asset()), + _ => Err(FeeAssetChangeError::missing_asset()), } } } #[derive(Debug, thiserror::Error)] #[error(transparent)] -pub struct FeeAssetChangeActionError(FeeAssetChangeActionErrorKind); +pub struct FeeAssetChangeError(FeeAssetChangeErrorKind); -impl FeeAssetChangeActionError { +impl FeeAssetChangeError { #[must_use] fn invalid_asset(err: asset::ParseDenomError) -> Self { - Self(FeeAssetChangeActionErrorKind::InvalidAsset(err)) + Self(FeeAssetChangeErrorKind::InvalidAsset(err)) } #[must_use] fn missing_asset() -> Self { - Self(FeeAssetChangeActionErrorKind::MissingAsset) + Self(FeeAssetChangeErrorKind::MissingAsset) } } #[derive(Debug, thiserror::Error)] -enum FeeAssetChangeActionErrorKind { +enum FeeAssetChangeErrorKind { #[error("the `asset` field was invalid")] InvalidAsset(#[source] asset::ParseDenomError), #[error("the `asset` field was not set")] MissingAsset, } -#[expect( - clippy::module_name_repetitions, - reason = "for parity with the Protobuf spec" -)] #[derive(Debug, Clone)] -pub struct InitBridgeAccountAction { +pub struct InitBridgeAccount { // the rollup ID to register for the sender of this action pub rollup_id: RollupId, // the assets accepted by the bridge account @@ -1406,13 +1352,13 @@ pub struct InitBridgeAccountAction { pub withdrawer_address: Option
, } -impl Protobuf for InitBridgeAccountAction { - type Error = InitBridgeAccountActionError; - type Raw = raw::InitBridgeAccountAction; +impl Protobuf for InitBridgeAccount { + type Error = InitBridgeAccountError; + type Raw = raw::InitBridgeAccount; #[must_use] - fn into_raw(self) -> raw::InitBridgeAccountAction { - raw::InitBridgeAccountAction { + fn into_raw(self) -> raw::InitBridgeAccount { + raw::InitBridgeAccount { rollup_id: Some(self.rollup_id.to_raw()), asset: self.asset.to_string(), fee_asset: self.fee_asset.to_string(), @@ -1422,8 +1368,8 @@ impl Protobuf for InitBridgeAccountAction { } #[must_use] - fn to_raw(&self) -> raw::InitBridgeAccountAction { - raw::InitBridgeAccountAction { + fn to_raw(&self) -> raw::InitBridgeAccount { + raw::InitBridgeAccount { rollup_id: Some(self.rollup_id.to_raw()), asset: self.asset.to_string(), fee_asset: self.fee_asset.to_string(), @@ -1440,34 +1386,32 @@ impl Protobuf for InitBridgeAccountAction { /// - if the `rollup_id` field is invalid /// - if the `sudo_address` field is invalid /// - if the `withdrawer_address` field is invalid - fn try_from_raw( - proto: raw::InitBridgeAccountAction, - ) -> Result { + fn try_from_raw(proto: raw::InitBridgeAccount) -> Result { let Some(rollup_id) = proto.rollup_id else { - return Err(InitBridgeAccountActionError::field_not_set("rollup_id")); + return Err(InitBridgeAccountError::field_not_set("rollup_id")); }; let rollup_id = RollupId::try_from_raw(&rollup_id) - .map_err(InitBridgeAccountActionError::invalid_rollup_id)?; + .map_err(InitBridgeAccountError::invalid_rollup_id)?; let asset = proto .asset .parse() - .map_err(InitBridgeAccountActionError::invalid_asset)?; + .map_err(InitBridgeAccountError::invalid_asset)?; let fee_asset = proto .fee_asset .parse() - .map_err(InitBridgeAccountActionError::invalid_fee_asset)?; + .map_err(InitBridgeAccountError::invalid_fee_asset)?; let sudo_address = proto .sudo_address .as_ref() .map(Address::try_from_raw) .transpose() - .map_err(InitBridgeAccountActionError::invalid_sudo_address)?; + .map_err(InitBridgeAccountError::invalid_sudo_address)?; let withdrawer_address = proto .withdrawer_address .as_ref() .map(Address::try_from_raw) .transpose() - .map_err(InitBridgeAccountActionError::invalid_withdrawer_address)?; + .map_err(InitBridgeAccountError::invalid_withdrawer_address)?; Ok(Self { rollup_id, @@ -1486,51 +1430,49 @@ impl Protobuf for InitBridgeAccountAction { /// - if the `rollup_id` field is invalid /// - if the `sudo_address` field is invalid /// - if the `withdrawer_address` field is invalid - fn try_from_raw_ref(proto: &Self::Raw) -> Result { + fn try_from_raw_ref(proto: &Self::Raw) -> Result { Self::try_from_raw(proto.clone()) } } #[derive(Debug, thiserror::Error)] #[error(transparent)] -pub struct InitBridgeAccountActionError(InitBridgeAccountActionErrorKind); +pub struct InitBridgeAccountError(InitBridgeAccountErrorKind); -impl InitBridgeAccountActionError { +impl InitBridgeAccountError { #[must_use] fn field_not_set(field: &'static str) -> Self { - Self(InitBridgeAccountActionErrorKind::FieldNotSet(field)) + Self(InitBridgeAccountErrorKind::FieldNotSet(field)) } #[must_use] fn invalid_rollup_id(err: IncorrectRollupIdLength) -> Self { - Self(InitBridgeAccountActionErrorKind::InvalidRollupId(err)) + Self(InitBridgeAccountErrorKind::InvalidRollupId(err)) } #[must_use] fn invalid_asset(err: asset::ParseDenomError) -> Self { - Self(InitBridgeAccountActionErrorKind::InvalidAsset(err)) + Self(InitBridgeAccountErrorKind::InvalidAsset(err)) } #[must_use] fn invalid_fee_asset(err: asset::ParseDenomError) -> Self { - Self(InitBridgeAccountActionErrorKind::InvalidFeeAsset(err)) + Self(InitBridgeAccountErrorKind::InvalidFeeAsset(err)) } #[must_use] fn invalid_sudo_address(err: AddressError) -> Self { - Self(InitBridgeAccountActionErrorKind::InvalidSudoAddress(err)) + Self(InitBridgeAccountErrorKind::InvalidSudoAddress(err)) } #[must_use] fn invalid_withdrawer_address(err: AddressError) -> Self { - Self(InitBridgeAccountActionErrorKind::InvalidWithdrawerAddress( - err, - )) + Self(InitBridgeAccountErrorKind::InvalidWithdrawerAddress(err)) } } #[derive(Debug, thiserror::Error)] -enum InitBridgeAccountActionErrorKind { +enum InitBridgeAccountErrorKind { #[error("the expected field in the raw source type was not set: `{0}`")] FieldNotSet(&'static str), #[error("the `rollup_id` field was invalid")] @@ -1545,12 +1487,8 @@ enum InitBridgeAccountActionErrorKind { InvalidWithdrawerAddress(#[source] AddressError), } -#[expect( - clippy::module_name_repetitions, - reason = "for parity with the Protobuf spec" -)] #[derive(Debug, Clone)] -pub struct BridgeLockAction { +pub struct BridgeLock { pub to: Address, pub amount: u128, // asset to be transferred. @@ -1561,13 +1499,13 @@ pub struct BridgeLockAction { pub destination_chain_address: String, } -impl Protobuf for BridgeLockAction { - type Error = BridgeLockActionError; - type Raw = raw::BridgeLockAction; +impl Protobuf for BridgeLock { + type Error = BridgeLockError; + type Raw = raw::BridgeLock; #[must_use] - fn into_raw(self) -> raw::BridgeLockAction { - raw::BridgeLockAction { + fn into_raw(self) -> raw::BridgeLock { + raw::BridgeLock { to: Some(self.to.to_raw()), amount: Some(self.amount.into()), asset: self.asset.to_string(), @@ -1577,8 +1515,8 @@ impl Protobuf for BridgeLockAction { } #[must_use] - fn to_raw(&self) -> raw::BridgeLockAction { - raw::BridgeLockAction { + fn to_raw(&self) -> raw::BridgeLock { + raw::BridgeLock { to: Some(self.to.to_raw()), amount: Some(self.amount.into()), asset: self.asset.to_string(), @@ -1595,22 +1533,20 @@ impl Protobuf for BridgeLockAction { /// - if the `to` field is invalid /// - if the `asset` field is invalid /// - if the `fee_asset` field is invalid - fn try_from_raw(proto: raw::BridgeLockAction) -> Result { + fn try_from_raw(proto: raw::BridgeLock) -> Result { let Some(to) = proto.to else { - return Err(BridgeLockActionError::field_not_set("to")); + return Err(BridgeLockError::field_not_set("to")); }; - let to = Address::try_from_raw(&to).map_err(BridgeLockActionError::address)?; - let amount = proto - .amount - .ok_or(BridgeLockActionError::missing_amount())?; + let to = Address::try_from_raw(&to).map_err(BridgeLockError::address)?; + let amount = proto.amount.ok_or(BridgeLockError::missing_amount())?; let asset = proto .asset .parse() - .map_err(BridgeLockActionError::invalid_asset)?; + .map_err(BridgeLockError::invalid_asset)?; let fee_asset = proto .fee_asset .parse() - .map_err(BridgeLockActionError::invalid_fee_asset)?; + .map_err(BridgeLockError::invalid_fee_asset)?; Ok(Self { to, amount: amount.into(), @@ -1628,46 +1564,46 @@ impl Protobuf for BridgeLockAction { /// - if the `to` field is invalid /// - if the `asset` field is invalid /// - if the `fee_asset` field is invalid - fn try_from_raw_ref(proto: &raw::BridgeLockAction) -> Result { + fn try_from_raw_ref(proto: &raw::BridgeLock) -> Result { Self::try_from_raw(proto.clone()) } } #[derive(Debug, thiserror::Error)] #[error(transparent)] -pub struct BridgeLockActionError(BridgeLockActionErrorKind); +pub struct BridgeLockError(BridgeLockErrorKind); -impl BridgeLockActionError { +impl BridgeLockError { #[must_use] fn field_not_set(field: &'static str) -> Self { - Self(BridgeLockActionErrorKind::FieldNotSet(field)) + Self(BridgeLockErrorKind::FieldNotSet(field)) } #[must_use] fn address(source: AddressError) -> Self { - Self(BridgeLockActionErrorKind::Address { + Self(BridgeLockErrorKind::Address { source, }) } #[must_use] fn missing_amount() -> Self { - Self(BridgeLockActionErrorKind::MissingAmount) + Self(BridgeLockErrorKind::MissingAmount) } #[must_use] fn invalid_asset(err: asset::ParseDenomError) -> Self { - Self(BridgeLockActionErrorKind::InvalidAsset(err)) + Self(BridgeLockErrorKind::InvalidAsset(err)) } #[must_use] fn invalid_fee_asset(err: asset::ParseDenomError) -> Self { - Self(BridgeLockActionErrorKind::InvalidFeeAsset(err)) + Self(BridgeLockErrorKind::InvalidFeeAsset(err)) } } #[derive(Debug, thiserror::Error)] -enum BridgeLockActionErrorKind { +enum BridgeLockErrorKind { #[error("the expected field in the raw source type was not set: `{0}`")] FieldNotSet(&'static str), #[error("the `to` field was invalid")] @@ -1680,12 +1616,8 @@ enum BridgeLockActionErrorKind { InvalidFeeAsset(#[source] asset::ParseDenomError), } -#[expect( - clippy::module_name_repetitions, - reason = "for parity with the Protobuf spec" -)] #[derive(Debug, Clone, PartialEq, Eq)] -pub struct BridgeUnlockAction { +pub struct BridgeUnlock { pub to: Address, pub amount: u128, // asset to use for fee payment. @@ -1700,13 +1632,13 @@ pub struct BridgeUnlockAction { pub rollup_withdrawal_event_id: String, } -impl Protobuf for BridgeUnlockAction { - type Error = BridgeUnlockActionError; - type Raw = raw::BridgeUnlockAction; +impl Protobuf for BridgeUnlock { + type Error = BridgeUnlockError; + type Raw = raw::BridgeUnlock; #[must_use] - fn into_raw(self) -> raw::BridgeUnlockAction { - raw::BridgeUnlockAction { + fn into_raw(self) -> raw::BridgeUnlock { + raw::BridgeUnlock { to: Some(self.to.into_raw()), amount: Some(self.amount.into()), fee_asset: self.fee_asset.to_string(), @@ -1718,8 +1650,8 @@ impl Protobuf for BridgeUnlockAction { } #[must_use] - fn to_raw(&self) -> raw::BridgeUnlockAction { - raw::BridgeUnlockAction { + fn to_raw(&self) -> raw::BridgeUnlock { + raw::BridgeUnlock { to: Some(self.to.to_raw()), amount: Some(self.amount.into()), fee_asset: self.fee_asset.to_string(), @@ -1739,8 +1671,8 @@ impl Protobuf for BridgeUnlockAction { /// - if the `amount` field is invalid /// - if the `fee_asset` field is invalid /// - if the `from` field is invalid - fn try_from_raw(proto: raw::BridgeUnlockAction) -> Result { - let raw::BridgeUnlockAction { + fn try_from_raw(proto: raw::BridgeUnlock) -> Result { + let raw::BridgeUnlock { to, amount, fee_asset, @@ -1750,18 +1682,14 @@ impl Protobuf for BridgeUnlockAction { rollup_withdrawal_event_id, } = proto; let to = to - .ok_or_else(|| BridgeUnlockActionError::field_not_set("to")) - .and_then(|to| Address::try_from_raw(&to).map_err(BridgeUnlockActionError::address))?; - let amount = amount.ok_or_else(|| BridgeUnlockActionError::field_not_set("amount"))?; - let fee_asset = fee_asset - .parse() - .map_err(BridgeUnlockActionError::fee_asset)?; + .ok_or_else(|| BridgeUnlockError::field_not_set("to")) + .and_then(|to| Address::try_from_raw(&to).map_err(BridgeUnlockError::address))?; + let amount = amount.ok_or_else(|| BridgeUnlockError::field_not_set("amount"))?; + let fee_asset = fee_asset.parse().map_err(BridgeUnlockError::fee_asset)?; let bridge_address = bridge_address - .ok_or_else(|| BridgeUnlockActionError::field_not_set("bridge_address")) - .and_then(|to| { - Address::try_from_raw(&to).map_err(BridgeUnlockActionError::bridge_address) - })?; + .ok_or_else(|| BridgeUnlockError::field_not_set("bridge_address")) + .and_then(|to| Address::try_from_raw(&to).map_err(BridgeUnlockError::bridge_address))?; Ok(Self { to, amount: amount.into(), @@ -1782,45 +1710,45 @@ impl Protobuf for BridgeUnlockAction { /// - if the `amount` field is invalid /// - if the `fee_asset` field is invalid /// - if the `from` field is invalid - fn try_from_raw_ref(proto: &raw::BridgeUnlockAction) -> Result { + fn try_from_raw_ref(proto: &raw::BridgeUnlock) -> Result { Self::try_from_raw(proto.clone()) } } #[derive(Debug, thiserror::Error)] #[error(transparent)] -pub struct BridgeUnlockActionError(BridgeUnlockActionErrorKind); +pub struct BridgeUnlockError(BridgeUnlockErrorKind); -impl BridgeUnlockActionError { +impl BridgeUnlockError { #[must_use] fn field_not_set(field: &'static str) -> Self { - Self(BridgeUnlockActionErrorKind::FieldNotSet(field)) + Self(BridgeUnlockErrorKind::FieldNotSet(field)) } #[must_use] fn address(source: AddressError) -> Self { - Self(BridgeUnlockActionErrorKind::Address { + Self(BridgeUnlockErrorKind::Address { source, }) } #[must_use] fn fee_asset(source: asset::ParseDenomError) -> Self { - Self(BridgeUnlockActionErrorKind::FeeAsset { + Self(BridgeUnlockErrorKind::FeeAsset { source, }) } #[must_use] fn bridge_address(source: AddressError) -> Self { - Self(BridgeUnlockActionErrorKind::BridgeAddress { + Self(BridgeUnlockErrorKind::BridgeAddress { source, }) } } #[derive(Debug, thiserror::Error)] -enum BridgeUnlockActionErrorKind { +enum BridgeUnlockErrorKind { #[error("the expected field in the raw source type was not set: `{0}`")] FieldNotSet(&'static str), #[error("the `to` field was invalid")] @@ -1831,25 +1759,21 @@ enum BridgeUnlockActionErrorKind { BridgeAddress { source: AddressError }, } -#[expect( - clippy::module_name_repetitions, - reason = "for parity with the Protobuf spec" -)] #[derive(Debug, Clone)] -pub struct BridgeSudoChangeAction { +pub struct BridgeSudoChange { pub bridge_address: Address, pub new_sudo_address: Option
, pub new_withdrawer_address: Option
, pub fee_asset: asset::Denom, } -impl Protobuf for BridgeSudoChangeAction { - type Error = BridgeSudoChangeActionError; - type Raw = raw::BridgeSudoChangeAction; +impl Protobuf for BridgeSudoChange { + type Error = BridgeSudoChangeError; + type Raw = raw::BridgeSudoChange; #[must_use] - fn into_raw(self) -> raw::BridgeSudoChangeAction { - raw::BridgeSudoChangeAction { + fn into_raw(self) -> raw::BridgeSudoChange { + raw::BridgeSudoChange { bridge_address: Some(self.bridge_address.to_raw()), new_sudo_address: self.new_sudo_address.map(Address::into_raw), new_withdrawer_address: self.new_withdrawer_address.map(Address::into_raw), @@ -1858,8 +1782,8 @@ impl Protobuf for BridgeSudoChangeAction { } #[must_use] - fn to_raw(&self) -> raw::BridgeSudoChangeAction { - raw::BridgeSudoChangeAction { + fn to_raw(&self) -> raw::BridgeSudoChange { + raw::BridgeSudoChange { bridge_address: Some(self.bridge_address.to_raw()), new_sudo_address: self.new_sudo_address.as_ref().map(Address::to_raw), new_withdrawer_address: self.new_withdrawer_address.as_ref().map(Address::to_raw), @@ -1876,30 +1800,28 @@ impl Protobuf for BridgeSudoChangeAction { /// - if the `new_sudo_address` field is invalid /// - if the `new_withdrawer_address` field is invalid /// - if the `fee_asset` field is invalid - fn try_from_raw( - proto: raw::BridgeSudoChangeAction, - ) -> Result { + fn try_from_raw(proto: raw::BridgeSudoChange) -> Result { let Some(bridge_address) = proto.bridge_address else { - return Err(BridgeSudoChangeActionError::field_not_set("bridge_address")); + return Err(BridgeSudoChangeError::field_not_set("bridge_address")); }; let bridge_address = Address::try_from_raw(&bridge_address) - .map_err(BridgeSudoChangeActionError::invalid_bridge_address)?; + .map_err(BridgeSudoChangeError::invalid_bridge_address)?; let new_sudo_address = proto .new_sudo_address .as_ref() .map(Address::try_from_raw) .transpose() - .map_err(BridgeSudoChangeActionError::invalid_new_sudo_address)?; + .map_err(BridgeSudoChangeError::invalid_new_sudo_address)?; let new_withdrawer_address = proto .new_withdrawer_address .as_ref() .map(Address::try_from_raw) .transpose() - .map_err(BridgeSudoChangeActionError::invalid_new_withdrawer_address)?; + .map_err(BridgeSudoChangeError::invalid_new_withdrawer_address)?; let fee_asset = proto .fee_asset .parse() - .map_err(BridgeSudoChangeActionError::invalid_fee_asset)?; + .map_err(BridgeSudoChangeError::invalid_fee_asset)?; Ok(Self { bridge_address, @@ -1918,46 +1840,44 @@ impl Protobuf for BridgeSudoChangeAction { /// - if the `new_sudo_address` field is invalid /// - if the `new_withdrawer_address` field is invalid /// - if the `fee_asset` field is invalid - fn try_from_raw_ref( - proto: &raw::BridgeSudoChangeAction, - ) -> Result { + fn try_from_raw_ref(proto: &raw::BridgeSudoChange) -> Result { Self::try_from_raw(proto.clone()) } } #[derive(Debug, thiserror::Error)] #[error(transparent)] -pub struct BridgeSudoChangeActionError(BridgeSudoChangeActionErrorKind); +pub struct BridgeSudoChangeError(BridgeSudoChangeErrorKind); -impl BridgeSudoChangeActionError { +impl BridgeSudoChangeError { #[must_use] fn field_not_set(field: &'static str) -> Self { - Self(BridgeSudoChangeActionErrorKind::FieldNotSet(field)) + Self(BridgeSudoChangeErrorKind::FieldNotSet(field)) } #[must_use] fn invalid_bridge_address(err: AddressError) -> Self { - Self(BridgeSudoChangeActionErrorKind::InvalidBridgeAddress(err)) + Self(BridgeSudoChangeErrorKind::InvalidBridgeAddress(err)) } #[must_use] fn invalid_new_sudo_address(err: AddressError) -> Self { - Self(BridgeSudoChangeActionErrorKind::InvalidNewSudoAddress(err)) + Self(BridgeSudoChangeErrorKind::InvalidNewSudoAddress(err)) } #[must_use] fn invalid_new_withdrawer_address(err: AddressError) -> Self { - Self(BridgeSudoChangeActionErrorKind::InvalidNewWithdrawerAddress(err)) + Self(BridgeSudoChangeErrorKind::InvalidNewWithdrawerAddress(err)) } #[must_use] fn invalid_fee_asset(err: asset::ParseDenomError) -> Self { - Self(BridgeSudoChangeActionErrorKind::InvalidFeeAsset(err)) + Self(BridgeSudoChangeErrorKind::InvalidFeeAsset(err)) } } #[derive(Debug, thiserror::Error)] -enum BridgeSudoChangeActionErrorKind { +enum BridgeSudoChangeErrorKind { #[error("the expected field in the raw source type was not set: `{0}`")] FieldNotSet(&'static str), #[error("the `bridge_address` field was invalid")] @@ -1971,7 +1891,7 @@ enum BridgeSudoChangeActionErrorKind { } #[derive(Debug, Clone)] -pub enum FeeChange { +pub enum FeeChangeKind { TransferBaseFee, SequenceBaseFee, SequenceByteCostMultiplier, @@ -1981,46 +1901,40 @@ pub enum FeeChange { Ics20WithdrawalBaseFee, } -#[expect( - clippy::module_name_repetitions, - reason = "for parity with the Protobuf spec" -)] #[derive(Debug, Clone)] -pub struct FeeChangeAction { - pub fee_change: FeeChange, +pub struct FeeChange { + pub fee_change: FeeChangeKind, pub new_value: u128, } -impl Protobuf for FeeChangeAction { - type Error = FeeChangeActionError; - type Raw = raw::FeeChangeAction; +impl Protobuf for FeeChange { + type Error = FeeChangeError; + type Raw = raw::FeeChange; #[must_use] - fn to_raw(&self) -> raw::FeeChangeAction { - raw::FeeChangeAction { + fn to_raw(&self) -> raw::FeeChange { + raw::FeeChange { value: Some(match self.fee_change { - FeeChange::TransferBaseFee => { - raw::fee_change_action::Value::TransferBaseFee(self.new_value.into()) + FeeChangeKind::TransferBaseFee => { + raw::fee_change::Value::TransferBaseFee(self.new_value.into()) } - FeeChange::SequenceBaseFee => { - raw::fee_change_action::Value::SequenceBaseFee(self.new_value.into()) + FeeChangeKind::SequenceBaseFee => { + raw::fee_change::Value::SequenceBaseFee(self.new_value.into()) } - FeeChange::SequenceByteCostMultiplier => { - raw::fee_change_action::Value::SequenceByteCostMultiplier(self.new_value.into()) + FeeChangeKind::SequenceByteCostMultiplier => { + raw::fee_change::Value::SequenceByteCostMultiplier(self.new_value.into()) } - FeeChange::InitBridgeAccountBaseFee => { - raw::fee_change_action::Value::InitBridgeAccountBaseFee(self.new_value.into()) + FeeChangeKind::InitBridgeAccountBaseFee => { + raw::fee_change::Value::InitBridgeAccountBaseFee(self.new_value.into()) } - FeeChange::BridgeLockByteCostMultiplier => { - raw::fee_change_action::Value::BridgeLockByteCostMultiplier( - self.new_value.into(), - ) + FeeChangeKind::BridgeLockByteCostMultiplier => { + raw::fee_change::Value::BridgeLockByteCostMultiplier(self.new_value.into()) } - FeeChange::BridgeSudoChangeBaseFee => { - raw::fee_change_action::Value::BridgeSudoChangeBaseFee(self.new_value.into()) + FeeChangeKind::BridgeSudoChangeBaseFee => { + raw::fee_change::Value::BridgeSudoChangeBaseFee(self.new_value.into()) } - FeeChange::Ics20WithdrawalBaseFee => { - raw::fee_change_action::Value::Ics20WithdrawalBaseFee(self.new_value.into()) + FeeChangeKind::Ics20WithdrawalBaseFee => { + raw::fee_change::Value::Ics20WithdrawalBaseFee(self.new_value.into()) } }), } @@ -2032,30 +1946,30 @@ impl Protobuf for FeeChangeAction { /// /// - if the fee change `value` field is missing /// - if the `new_value` field is missing - fn try_from_raw_ref(proto: &raw::FeeChangeAction) -> Result { + fn try_from_raw_ref(proto: &raw::FeeChange) -> Result { let (fee_change, new_value) = match proto.value { - Some(raw::fee_change_action::Value::TransferBaseFee(new_value)) => { - (FeeChange::TransferBaseFee, new_value) + Some(raw::fee_change::Value::TransferBaseFee(new_value)) => { + (FeeChangeKind::TransferBaseFee, new_value) } - Some(raw::fee_change_action::Value::SequenceBaseFee(new_value)) => { - (FeeChange::SequenceBaseFee, new_value) + Some(raw::fee_change::Value::SequenceBaseFee(new_value)) => { + (FeeChangeKind::SequenceBaseFee, new_value) } - Some(raw::fee_change_action::Value::SequenceByteCostMultiplier(new_value)) => { - (FeeChange::SequenceByteCostMultiplier, new_value) + Some(raw::fee_change::Value::SequenceByteCostMultiplier(new_value)) => { + (FeeChangeKind::SequenceByteCostMultiplier, new_value) } - Some(raw::fee_change_action::Value::InitBridgeAccountBaseFee(new_value)) => { - (FeeChange::InitBridgeAccountBaseFee, new_value) + Some(raw::fee_change::Value::InitBridgeAccountBaseFee(new_value)) => { + (FeeChangeKind::InitBridgeAccountBaseFee, new_value) } - Some(raw::fee_change_action::Value::BridgeLockByteCostMultiplier(new_value)) => { - (FeeChange::BridgeLockByteCostMultiplier, new_value) + Some(raw::fee_change::Value::BridgeLockByteCostMultiplier(new_value)) => { + (FeeChangeKind::BridgeLockByteCostMultiplier, new_value) } - Some(raw::fee_change_action::Value::BridgeSudoChangeBaseFee(new_value)) => { - (FeeChange::BridgeSudoChangeBaseFee, new_value) + Some(raw::fee_change::Value::BridgeSudoChangeBaseFee(new_value)) => { + (FeeChangeKind::BridgeSudoChangeBaseFee, new_value) } - Some(raw::fee_change_action::Value::Ics20WithdrawalBaseFee(new_value)) => { - (FeeChange::Ics20WithdrawalBaseFee, new_value) + Some(raw::fee_change::Value::Ics20WithdrawalBaseFee(new_value)) => { + (FeeChangeKind::Ics20WithdrawalBaseFee, new_value) } - None => return Err(FeeChangeActionError::missing_value_to_change()), + None => return Err(FeeChangeError::missing_value_to_change()), }; Ok(Self { @@ -2067,16 +1981,16 @@ impl Protobuf for FeeChangeAction { #[derive(Debug, thiserror::Error)] #[error(transparent)] -pub struct FeeChangeActionError(FeeChangeActionErrorKind); +pub struct FeeChangeError(FeeChangeErrorKind); -impl FeeChangeActionError { +impl FeeChangeError { fn missing_value_to_change() -> Self { - Self(FeeChangeActionErrorKind::MissingValueToChange) + Self(FeeChangeErrorKind::MissingValueToChange) } } #[derive(Debug, thiserror::Error)] -enum FeeChangeActionErrorKind { +enum FeeChangeErrorKind { #[error("the value which to change was missing")] MissingValueToChange, } diff --git a/crates/astria-core/src/protocol/transaction/v1alpha1/action_group/mod.rs b/crates/astria-core/src/protocol/transaction/v1alpha1/action_group/mod.rs index fe526a1452..0de397d874 100644 --- a/crates/astria-core/src/protocol/transaction/v1alpha1/action_group/mod.rs +++ b/crates/astria-core/src/protocol/transaction/v1alpha1/action_group/mod.rs @@ -11,18 +11,18 @@ use penumbra_ibc::IbcRelay; use super::{ action::{ ActionName, - BridgeLockAction, - BridgeSudoChangeAction, - BridgeUnlockAction, - FeeAssetChangeAction, - FeeChangeAction, - IbcRelayerChangeAction, - IbcSudoChangeAction, + BridgeLock, + BridgeSudoChange, + BridgeUnlock, + FeeAssetChange, + FeeChangeKind, + IbcRelayerChange, + IbcSudoChange, Ics20Withdrawal, - InitBridgeAccountAction, - SequenceAction, - SudoAddressChangeAction, - TransferAction, + InitBridgeAccount, + Sequence, + SudoAddressChange, + Transfer, ValidatorUpdate, }, Action, @@ -43,39 +43,39 @@ macro_rules! impl_belong_to_group { } impl_belong_to_group!( - (SequenceAction, ActionGroup::BundleableGeneral), - (TransferAction, ActionGroup::BundleableGeneral), + (Sequence, ActionGroup::BundleableGeneral), + (Transfer, ActionGroup::BundleableGeneral), (ValidatorUpdate, ActionGroup::BundleableGeneral), - (SudoAddressChangeAction, ActionGroup::UnbundleableSudo), - (IbcRelayerChangeAction, ActionGroup::BundleableSudo), + (SudoAddressChange, ActionGroup::UnbundleableSudo), + (IbcRelayerChange, ActionGroup::BundleableSudo), (Ics20Withdrawal, ActionGroup::BundleableGeneral), - (InitBridgeAccountAction, ActionGroup::UnbundleableGeneral), - (BridgeLockAction, ActionGroup::BundleableGeneral), - (BridgeUnlockAction, ActionGroup::BundleableGeneral), - (BridgeSudoChangeAction, ActionGroup::UnbundleableGeneral), - (FeeChangeAction, ActionGroup::BundleableSudo), - (FeeAssetChangeAction, ActionGroup::BundleableSudo), + (InitBridgeAccount, ActionGroup::UnbundleableGeneral), + (BridgeLock, ActionGroup::BundleableGeneral), + (BridgeUnlock, ActionGroup::BundleableGeneral), + (BridgeSudoChange, ActionGroup::UnbundleableGeneral), + (FeeChangeKind, ActionGroup::BundleableSudo), + (FeeAssetChange, ActionGroup::BundleableSudo), (IbcRelay, ActionGroup::BundleableGeneral), - (IbcSudoChangeAction, ActionGroup::UnbundleableSudo), + (IbcSudoChange, ActionGroup::UnbundleableSudo), ); impl Action { const fn group(&self) -> ActionGroup { match self { - Action::Sequence(_) => SequenceAction::GROUP, - Action::Transfer(_) => TransferAction::GROUP, + Action::Sequence(_) => Sequence::GROUP, + Action::Transfer(_) => Transfer::GROUP, Action::ValidatorUpdate(_) => ValidatorUpdate::GROUP, - Action::SudoAddressChange(_) => SudoAddressChangeAction::GROUP, - Action::IbcRelayerChange(_) => IbcRelayerChangeAction::GROUP, + Action::SudoAddressChange(_) => SudoAddressChange::GROUP, + Action::IbcRelayerChange(_) => IbcRelayerChange::GROUP, Action::Ics20Withdrawal(_) => Ics20Withdrawal::GROUP, - Action::InitBridgeAccount(_) => InitBridgeAccountAction::GROUP, - Action::BridgeLock(_) => BridgeLockAction::GROUP, - Action::BridgeUnlock(_) => BridgeUnlockAction::GROUP, - Action::BridgeSudoChange(_) => BridgeSudoChangeAction::GROUP, - Action::FeeChange(_) => FeeChangeAction::GROUP, - Action::FeeAssetChange(_) => FeeAssetChangeAction::GROUP, + Action::InitBridgeAccount(_) => InitBridgeAccount::GROUP, + Action::BridgeLock(_) => BridgeLock::GROUP, + Action::BridgeUnlock(_) => BridgeUnlock::GROUP, + Action::BridgeSudoChange(_) => BridgeSudoChange::GROUP, + Action::FeeChange(_) => FeeChangeKind::GROUP, + Action::FeeAssetChange(_) => FeeAssetChange::GROUP, Action::Ibc(_) => IbcRelay::GROUP, - Action::IbcSudoChange(_) => IbcSudoChangeAction::GROUP, + Action::IbcSudoChange(_) => IbcSudoChange::GROUP, } } } diff --git a/crates/astria-core/src/protocol/transaction/v1alpha1/action_group/tests.rs b/crates/astria-core/src/protocol/transaction/v1alpha1/action_group/tests.rs index 71169c6a67..d4679f381a 100644 --- a/crates/astria-core/src/protocol/transaction/v1alpha1/action_group/tests.rs +++ b/crates/astria-core/src/protocol/transaction/v1alpha1/action_group/tests.rs @@ -10,19 +10,19 @@ use crate::{ protocol::transaction::v1alpha1::{ action::{ Action, - BridgeLockAction, - BridgeSudoChangeAction, - BridgeUnlockAction, - FeeAssetChangeAction, + BridgeLock, + BridgeSudoChange, + BridgeUnlock, + FeeAssetChange, FeeChange, - FeeChangeAction, - IbcRelayerChangeAction, - IbcSudoChangeAction, + FeeChangeKind, + IbcRelayerChange, + IbcSudoChange, Ics20Withdrawal, - InitBridgeAccountAction, - SequenceAction, - SudoAddressChangeAction, - TransferAction, + InitBridgeAccount, + Sequence, + SudoAddressChange, + Transfer, ValidatorUpdate, }, action_group::{ @@ -44,25 +44,25 @@ fn try_from_list_of_actions_bundleable_general() { let asset: Denom = "nria".parse().unwrap(); let actions = vec![ - Action::Sequence(SequenceAction { + Action::Sequence(Sequence { rollup_id: RollupId::from([8; 32]), data: vec![].into(), fee_asset: asset.clone(), }), - Action::Transfer(TransferAction { + Action::Transfer(Transfer { to: address, amount: 100, asset: asset.clone(), fee_asset: asset.clone(), }), - Action::BridgeLock(BridgeLockAction { + Action::BridgeLock(BridgeLock { to: address, amount: 100, asset: asset.clone(), fee_asset: asset.clone(), destination_chain_address: String::new(), }), - Action::BridgeUnlock(BridgeUnlockAction { + Action::BridgeUnlock(BridgeUnlock { to: address, amount: 100, fee_asset: asset.clone(), @@ -106,12 +106,12 @@ fn from_list_of_actions_bundleable_sudo() { let asset: Denom = "nria".parse().unwrap(); let actions = vec![ - Action::FeeChange(FeeChangeAction { - fee_change: FeeChange::TransferBaseFee, + Action::FeeChange(FeeChange { + fee_change: FeeChangeKind::TransferBaseFee, new_value: 100, }), - Action::FeeAssetChange(FeeAssetChangeAction::Addition(asset)), - Action::IbcRelayerChange(IbcRelayerChangeAction::Addition(address)), + Action::FeeAssetChange(FeeAssetChange::Addition(asset)), + Action::IbcRelayerChange(IbcRelayerChange::Addition(address)), ]; assert!(matches!( @@ -128,7 +128,7 @@ fn from_list_of_actions_unbundleable_sudo() { .try_build() .unwrap(); - let actions = vec![Action::SudoAddressChange(SudoAddressChangeAction { + let actions = vec![Action::SudoAddressChange(SudoAddressChange { new_address: address, })]; @@ -137,7 +137,7 @@ fn from_list_of_actions_unbundleable_sudo() { ActionGroup::UnbundleableSudo )); - let actions = vec![Action::IbcSudoChange(IbcSudoChangeAction { + let actions = vec![Action::IbcSudoChange(IbcSudoChange { new_address: address, })]; @@ -147,10 +147,10 @@ fn from_list_of_actions_unbundleable_sudo() { )); let actions = vec![ - Action::SudoAddressChange(SudoAddressChangeAction { + Action::SudoAddressChange(SudoAddressChange { new_address: address, }), - Action::SudoAddressChange(SudoAddressChangeAction { + Action::SudoAddressChange(SudoAddressChange { new_address: address, }), ]; @@ -172,7 +172,7 @@ fn from_list_of_actions_unbundleable_general() { let asset: Denom = "nria".parse().unwrap(); - let init_bridge_account_action = InitBridgeAccountAction { + let init_bridge_account_action = InitBridgeAccount { rollup_id: RollupId::from([8; 32]), asset: asset.clone(), fee_asset: asset.clone(), @@ -180,7 +180,7 @@ fn from_list_of_actions_unbundleable_general() { withdrawer_address: Some(address), }; - let sudo_bridge_address_change_action = BridgeSudoChangeAction { + let sudo_bridge_address_change_action = BridgeSudoChange { new_sudo_address: Some(address), bridge_address: address, new_withdrawer_address: Some(address), @@ -223,12 +223,12 @@ fn from_list_of_actions_mixed() { let asset: Denom = "nria".parse().unwrap(); let actions = vec![ - Action::Sequence(SequenceAction { + Action::Sequence(Sequence { rollup_id: RollupId::from([8; 32]), data: vec![].into(), fee_asset: asset.clone(), }), - Action::SudoAddressChange(SudoAddressChangeAction { + Action::SudoAddressChange(SudoAddressChange { new_address: address, }), ]; diff --git a/crates/astria-core/src/protocol/transaction/v1alpha1/mod.rs b/crates/astria-core/src/protocol/transaction/v1alpha1/mod.rs index 457c357c7b..025a4bceb6 100644 --- a/crates/astria-core/src/protocol/transaction/v1alpha1/mod.rs +++ b/crates/astria-core/src/protocol/transaction/v1alpha1/mod.rs @@ -570,7 +570,7 @@ mod tests { use super::*; use crate::{ primitive::v1::Address, - protocol::transaction::v1alpha1::action::TransferAction, + protocol::transaction::v1alpha1::action::Transfer, }; const ASTRIA_ADDRESS_PREFIX: &str = "astria"; @@ -592,7 +592,7 @@ mod tests { 227, 96, 127, 152, 22, 47, 146, 10, ]); - let transfer = TransferAction { + let transfer = Transfer { to: Address::builder() .array([0; 20]) .prefix(ASTRIA_ADDRESS_PREFIX) @@ -627,7 +627,7 @@ mod tests { 178, 63, 69, 238, 27, 96, 95, 213, 135, 120, 87, 106, 196, ]); - let transfer = TransferAction { + let transfer = Transfer { to: Address::builder() .array([0; 20]) .prefix(ASTRIA_ADDRESS_PREFIX) diff --git a/crates/astria-core/src/sequencerblock/v1alpha1/block.rs b/crates/astria-core/src/sequencerblock/v1alpha1/block.rs index bd8a1a4dc8..46fa1eab99 100644 --- a/crates/astria-core/src/sequencerblock/v1alpha1/block.rs +++ b/crates/astria-core/src/sequencerblock/v1alpha1/block.rs @@ -797,7 +797,7 @@ impl SequencerBlock { .map_err(SequencerBlockError::raw_signed_transaction_conversion)?; for action in signed_tx.into_unsigned().into_actions() { // XXX: The fee asset is dropped. We shjould explain why that's ok. - if let action::Action::Sequence(action::SequenceAction { + if let action::Action::Sequence(action::Sequence { rollup_id, data, fee_asset: _, diff --git a/crates/astria-sequencer-client/src/tests/http.rs b/crates/astria-sequencer-client/src/tests/http.rs index c23f14b1d1..a1223b9e75 100644 --- a/crates/astria-sequencer-client/src/tests/http.rs +++ b/crates/astria-sequencer-client/src/tests/http.rs @@ -5,7 +5,7 @@ use astria_core::{ generated::protocol::asset::v1alpha1::AllowedFeeAssetsResponse, primitive::v1::Address, protocol::transaction::v1alpha1::{ - action::TransferAction, + action::Transfer, SignedTransaction, UnsignedTransaction, }, @@ -148,7 +148,7 @@ fn create_signed_transaction() -> SignedTransaction { let alice_key = SigningKey::from(alice_secret_bytes); let actions = vec![ - TransferAction { + Transfer { to: bob_address(), amount: 333_333, asset: "nria".parse().unwrap(), diff --git a/crates/astria-sequencer/src/accounts/action.rs b/crates/astria-sequencer/src/accounts/action.rs index b02a77c1de..b248bc3624 100644 --- a/crates/astria-sequencer/src/accounts/action.rs +++ b/crates/astria-sequencer/src/accounts/action.rs @@ -1,5 +1,5 @@ use astria_core::{ - protocol::transaction::v1alpha1::action::TransferAction, + protocol::transaction::v1alpha1::action::Transfer, Protobuf as _, }; use astria_eyre::eyre::{ @@ -30,7 +30,7 @@ use crate::{ }; #[async_trait::async_trait] -impl ActionHandler for TransferAction { +impl ActionHandler for Transfer { async fn check_stateless(&self) -> Result<()> { Ok(()) } @@ -58,7 +58,7 @@ impl ActionHandler for TransferAction { } pub(crate) async fn execute_transfer( - action: &TransferAction, + action: &Transfer, from: &TAddress, mut state: S, ) -> Result<()> @@ -71,7 +71,7 @@ where .await .wrap_err("failed to get transfer base fee")?; state - .get_and_increase_block_fees(&action.fee_asset, fee, TransferAction::full_name()) + .get_and_increase_block_fees(&action.fee_asset, fee, Transfer::full_name()) .await .wrap_err("failed to add to block fees")?; @@ -114,7 +114,7 @@ where } pub(crate) async fn check_transfer( - action: &TransferAction, + action: &Transfer, from: &TAddress, state: &S, ) -> Result<()> diff --git a/crates/astria-sequencer/src/app/test_utils.rs b/crates/astria-sequencer/src/app/test_utils.rs index 38dc2816c9..edaf468e97 100644 --- a/crates/astria-sequencer/src/app/test_utils.rs +++ b/crates/astria-sequencer/src/app/test_utils.rs @@ -20,7 +20,7 @@ use astria_core::{ }, transaction::v1alpha1::{ action::{ - SequenceAction, + Sequence, ValidatorUpdate, }, SignedTransaction, @@ -302,7 +302,7 @@ impl MockTxBuilder { pub(crate) fn build(self) -> Arc { let tx = UnsignedTransaction::builder() .actions(vec![ - SequenceAction { + Sequence { rollup_id: RollupId::from_unhashed_bytes("rollup-id"), data: Bytes::from_static(&[0x99]), fee_asset: denom_0(), diff --git a/crates/astria-sequencer/src/app/tests_app/mempool.rs b/crates/astria-sequencer/src/app/tests_app/mempool.rs index a147e643e0..42e16f9c8f 100644 --- a/crates/astria-sequencer/src/app/tests_app/mempool.rs +++ b/crates/astria-sequencer/src/app/tests_app/mempool.rs @@ -6,8 +6,8 @@ use astria_core::{ transaction::v1alpha1::{ action::{ FeeChange, - FeeChangeAction, - TransferAction, + FeeChangeKind, + Transfer, }, UnsignedTransaction, }, @@ -50,8 +50,8 @@ async fn trigger_cleaning() { // create tx which will cause mempool cleaning flag to be set let tx_trigger = UnsignedTransaction::builder() .actions(vec![ - FeeChangeAction { - fee_change: FeeChange::TransferBaseFee, + FeeChange { + fee_change: FeeChangeKind::TransferBaseFee, new_value: 10, } .into(), @@ -146,8 +146,8 @@ async fn do_not_trigger_cleaning() { // (wrong sudo signer) let tx_fail = UnsignedTransaction::builder() .actions(vec![ - FeeChangeAction { - fee_change: FeeChange::TransferBaseFee, + FeeChange { + fee_change: FeeChangeKind::TransferBaseFee, new_value: 10, } .into(), @@ -217,7 +217,7 @@ async fn maintenance_recosting_promotes() { // having insufficient funds (transaction will be recosted to enable) let tx_fail_recost_funds = UnsignedTransaction::builder() .actions(vec![ - TransferAction { + Transfer { to: astria_address_from_hex_string(CAROL_ADDRESS), amount: 1u128, asset: nria().into(), @@ -247,8 +247,8 @@ async fn maintenance_recosting_promotes() { // create tx which will enable recost tx to pass let tx_recost = UnsignedTransaction::builder() .actions(vec![ - FeeChangeAction { - fee_change: FeeChange::TransferBaseFee, + FeeChange { + fee_change: FeeChangeKind::TransferBaseFee, new_value: 10, // originally 12 } .into(), @@ -386,7 +386,7 @@ async fn maintenance_funds_added_promotes() { // having no funds (will be sent transfer to then enable) let tx_fail_transfer_funds = UnsignedTransaction::builder() .actions(vec![ - TransferAction { + Transfer { to: astria_address_from_hex_string(BOB_ADDRESS), amount: 10u128, asset: nria().into(), @@ -416,7 +416,7 @@ async fn maintenance_funds_added_promotes() { // create tx which will enable no funds to pass let tx_fund = UnsignedTransaction::builder() .actions(vec![ - TransferAction { + Transfer { to: astria_address_from_hex_string(CAROL_ADDRESS), amount: 22u128, asset: nria().into(), diff --git a/crates/astria-sequencer/src/app/tests_app/mod.rs b/crates/astria-sequencer/src/app/tests_app/mod.rs index 6e5ddea619..a7bba14858 100644 --- a/crates/astria-sequencer/src/app/tests_app/mod.rs +++ b/crates/astria-sequencer/src/app/tests_app/mod.rs @@ -12,9 +12,9 @@ use astria_core::{ genesis::v1alpha1::Account, transaction::v1alpha1::{ action::{ - BridgeLockAction, - SequenceAction, - TransferAction, + BridgeLock, + Sequence, + Transfer, }, UnsignedTransaction, }, @@ -232,7 +232,7 @@ async fn app_transfer_block_fees_to_sudo() { let amount = 333_333; let tx = UnsignedTransaction::builder() .actions(vec![ - TransferAction { + Transfer { to: bob_address, amount, asset: nria().into(), @@ -325,14 +325,14 @@ async fn app_create_sequencer_block_with_sequenced_data_and_deposits() { app.commit(storage.clone()).await; let amount = 100; - let lock_action = BridgeLockAction { + let lock_action = BridgeLock { to: bridge_address, amount, asset: nria().into(), fee_asset: nria().into(), destination_chain_address: "nootwashere".to_string(), }; - let sequence_action = SequenceAction { + let sequence_action = Sequence { rollup_id, data: Bytes::from_static(b"hello world"), fee_asset: nria().into(), @@ -417,14 +417,14 @@ async fn app_execution_results_match_proposal_vs_after_proposal() { app.commit(storage.clone()).await; let amount = 100; - let lock_action = BridgeLockAction { + let lock_action = BridgeLock { to: bridge_address, amount, asset: nria().into(), fee_asset: nria().into(), destination_chain_address: "nootwashere".to_string(), }; - let sequence_action = SequenceAction { + let sequence_action = Sequence { rollup_id, data: Bytes::from_static(b"hello world"), fee_asset: nria().into(), @@ -567,7 +567,7 @@ async fn app_prepare_proposal_cometbft_max_bytes_overflow_ok() { let alice = get_alice_signing_key(); let tx_pass = UnsignedTransaction::builder() .actions(vec![ - SequenceAction { + Sequence { rollup_id: RollupId::from([1u8; 32]), data: Bytes::copy_from_slice(&[1u8; 100_000]), fee_asset: nria().into(), @@ -581,7 +581,7 @@ async fn app_prepare_proposal_cometbft_max_bytes_overflow_ok() { let tx_overflow = UnsignedTransaction::builder() .actions(vec![ - SequenceAction { + Sequence { rollup_id: RollupId::from([1u8; 32]), data: Bytes::copy_from_slice(&[1u8; 100_000]), fee_asset: nria().into(), @@ -657,7 +657,7 @@ async fn app_prepare_proposal_sequencer_max_bytes_overflow_ok() { let alice = get_alice_signing_key(); let tx_pass = UnsignedTransaction::builder() .actions(vec![ - SequenceAction { + Sequence { rollup_id: RollupId::from([1u8; 32]), data: Bytes::copy_from_slice(&[1u8; 200_000]), fee_asset: nria().into(), @@ -670,7 +670,7 @@ async fn app_prepare_proposal_sequencer_max_bytes_overflow_ok() { .into_signed(&alice); let tx_overflow = UnsignedTransaction::builder() .actions(vec![ - SequenceAction { + Sequence { rollup_id: RollupId::from([1u8; 32]), data: Bytes::copy_from_slice(&[1u8; 100_000]), fee_asset: nria().into(), diff --git a/crates/astria-sequencer/src/app/tests_block_fees.rs b/crates/astria-sequencer/src/app/tests_block_fees.rs index 6937f481ba..31cc3e371d 100644 --- a/crates/astria-sequencer/src/app/tests_block_fees.rs +++ b/crates/astria-sequencer/src/app/tests_block_fees.rs @@ -4,11 +4,11 @@ use astria_core::{ primitive::v1::RollupId, protocol::transaction::v1alpha1::{ action::{ - BridgeLockAction, - BridgeSudoChangeAction, - InitBridgeAccountAction, - SequenceAction, - TransferAction, + BridgeLock, + BridgeSudoChange, + InitBridgeAccount, + Sequence, + Transfer, }, UnsignedTransaction, }, @@ -54,7 +54,7 @@ async fn transaction_execution_records_fee_event() { let value = 333_333; let tx = UnsignedTransaction::builder() .actions(vec![ - TransferAction { + Transfer { to: bob_address, amount: value, asset: nria().into(), @@ -101,7 +101,7 @@ async fn ensure_correct_block_fees_transfer() { let alice = get_alice_signing_key(); let bob_address = astria_address_from_hex_string(BOB_ADDRESS); let actions = vec![ - TransferAction { + Transfer { to: bob_address, amount: 1000, asset: nria().into(), @@ -143,7 +143,7 @@ async fn ensure_correct_block_fees_sequence() { let data = b"hello world".to_vec(); let actions = vec![ - SequenceAction { + Sequence { rollup_id: RollupId::from_unhashed_bytes(b"testchainid"), data: data.clone().into(), fee_asset: nria().into(), @@ -184,7 +184,7 @@ async fn ensure_correct_block_fees_init_bridge_acct() { let alice = get_alice_signing_key(); let actions = vec![ - InitBridgeAccountAction { + InitBridgeAccount { rollup_id: RollupId::from_unhashed_bytes(b"testchainid"), asset: nria().into(), fee_asset: nria().into(), @@ -240,7 +240,7 @@ async fn ensure_correct_block_fees_bridge_lock() { app.apply(state_tx); let actions = vec![ - BridgeLockAction { + BridgeLock { to: bridge_address, amount: 1, asset: nria().into(), @@ -305,7 +305,7 @@ async fn ensure_correct_block_fees_bridge_sudo_change() { app.apply(state_tx); let actions = vec![ - BridgeSudoChangeAction { + BridgeSudoChange { bridge_address, new_sudo_address: None, new_withdrawer_address: None, diff --git a/crates/astria-sequencer/src/app/tests_breaking_changes.rs b/crates/astria-sequencer/src/app/tests_breaking_changes.rs index d992372f84..ea16e84813 100644 --- a/crates/astria-sequencer/src/app/tests_breaking_changes.rs +++ b/crates/astria-sequencer/src/app/tests_breaking_changes.rs @@ -20,13 +20,13 @@ use astria_core::{ genesis::v1alpha1::Account, transaction::v1alpha1::{ action::{ - BridgeLockAction, - BridgeSudoChangeAction, - BridgeUnlockAction, - IbcRelayerChangeAction, - IbcSudoChangeAction, - SequenceAction, - TransferAction, + BridgeLock, + BridgeSudoChange, + BridgeUnlock, + IbcRelayerChange, + IbcSudoChange, + Sequence, + Transfer, ValidatorUpdate, }, Action, @@ -101,14 +101,14 @@ async fn app_finalize_block_snapshot() { app.commit(storage.clone()).await; let amount = 100; - let lock_action = BridgeLockAction { + let lock_action = BridgeLock { to: bridge_address, amount, asset: nria().into(), fee_asset: nria().into(), destination_chain_address: "nootwashere".to_string(), }; - let sequence_action = SequenceAction { + let sequence_action = Sequence { rollup_id, data: Bytes::from_static(b"hello world"), fee_asset: nria().into(), @@ -165,9 +165,9 @@ async fn app_finalize_block_snapshot() { #[tokio::test] async fn app_execute_transaction_with_every_action_snapshot() { use astria_core::protocol::transaction::v1alpha1::action::{ - FeeAssetChangeAction, - InitBridgeAccountAction, - SudoAddressChangeAction, + FeeAssetChange, + InitBridgeAccount, + SudoAddressChange, }; let alice = get_alice_signing_key(); @@ -204,14 +204,14 @@ async fn app_execute_transaction_with_every_action_snapshot() { let tx_bundleable_general = UnsignedTransaction::builder() .actions(vec![ - TransferAction { + Transfer { to: bob_address, amount: 333_333, asset: nria().into(), fee_asset: nria().into(), } .into(), - SequenceAction { + Sequence { rollup_id: RollupId::from_unhashed_bytes(b"testchainid"), data: Bytes::from_static(b"hello world"), fee_asset: nria().into(), @@ -225,12 +225,12 @@ async fn app_execute_transaction_with_every_action_snapshot() { let tx_bundleable_sudo = UnsignedTransaction::builder() .actions(vec![ - IbcRelayerChangeAction::Addition(bob_address).into(), - IbcRelayerChangeAction::Addition(carol_address).into(), - IbcRelayerChangeAction::Removal(bob_address).into(), - FeeAssetChangeAction::Addition("test-0".parse().unwrap()).into(), - FeeAssetChangeAction::Addition("test-1".parse().unwrap()).into(), - FeeAssetChangeAction::Removal("test-0".parse().unwrap()).into(), + IbcRelayerChange::Addition(bob_address).into(), + IbcRelayerChange::Addition(carol_address).into(), + IbcRelayerChange::Removal(bob_address).into(), + FeeAssetChange::Addition("test-0".parse().unwrap()).into(), + FeeAssetChange::Addition("test-1".parse().unwrap()).into(), + FeeAssetChange::Removal("test-0".parse().unwrap()).into(), ]) .nonce(1) .chain_id("test") @@ -239,7 +239,7 @@ async fn app_execute_transaction_with_every_action_snapshot() { let tx_sudo_ibc = UnsignedTransaction::builder() .actions(vec![ - IbcSudoChangeAction { + IbcSudoChange { new_address: bob_address, } .into(), @@ -251,7 +251,7 @@ async fn app_execute_transaction_with_every_action_snapshot() { let tx_sudo = UnsignedTransaction::builder() .actions(vec![ - SudoAddressChangeAction { + SudoAddressChange { new_address: bob_address, } .into(), @@ -279,7 +279,7 @@ async fn app_execute_transaction_with_every_action_snapshot() { let tx = UnsignedTransaction::builder() .actions(vec![ - InitBridgeAccountAction { + InitBridgeAccount { rollup_id, asset: nria().into(), fee_asset: nria().into(), @@ -296,7 +296,7 @@ async fn app_execute_transaction_with_every_action_snapshot() { let tx_bridge_bundleable = UnsignedTransaction::builder() .actions(vec![ - BridgeLockAction { + BridgeLock { to: bridge_address, amount: 100, asset: nria().into(), @@ -304,7 +304,7 @@ async fn app_execute_transaction_with_every_action_snapshot() { destination_chain_address: "nootwashere".to_string(), } .into(), - BridgeUnlockAction { + BridgeUnlock { to: bob_address, amount: 10, fee_asset: nria().into(), @@ -325,7 +325,7 @@ async fn app_execute_transaction_with_every_action_snapshot() { let tx_bridge = UnsignedTransaction::builder() .actions(vec![ - BridgeSudoChangeAction { + BridgeSudoChange { bridge_address, new_sudo_address: Some(bob_address), new_withdrawer_address: Some(bob_address), diff --git a/crates/astria-sequencer/src/app/tests_execute_transaction.rs b/crates/astria-sequencer/src/app/tests_execute_transaction.rs index 7baf724a11..2c64d35fe6 100644 --- a/crates/astria-sequencer/src/app/tests_execute_transaction.rs +++ b/crates/astria-sequencer/src/app/tests_execute_transaction.rs @@ -10,13 +10,13 @@ use astria_core::{ genesis::v1alpha1::GenesisAppState, transaction::v1alpha1::{ action::{ - BridgeLockAction, - BridgeUnlockAction, - IbcRelayerChangeAction, - IbcSudoChangeAction, - SequenceAction, - SudoAddressChangeAction, - TransferAction, + BridgeLock, + BridgeUnlock, + IbcRelayerChange, + IbcSudoChange, + Sequence, + SudoAddressChange, + Transfer, ValidatorUpdate, }, Action, @@ -105,7 +105,7 @@ async fn app_execute_transaction_transfer() { let value = 333_333; let tx = UnsignedTransaction::builder() .actions(vec![ - TransferAction { + Transfer { to: bob_address, amount: value, asset: crate::test_utils::nria().into(), @@ -163,7 +163,7 @@ async fn app_execute_transaction_transfer_not_native_token() { let bob_address = astria_address_from_hex_string(BOB_ADDRESS); let tx = UnsignedTransaction::builder() .actions(vec![ - TransferAction { + Transfer { to: bob_address, amount: value, asset: test_asset(), @@ -229,7 +229,7 @@ async fn app_execute_transaction_transfer_balance_too_low_for_fee() { // 0-value transfer; only fee is deducted from sender let tx = UnsignedTransaction::builder() .actions(vec![ - TransferAction { + Transfer { to: bob, amount: 0, asset: nria().into(), @@ -270,7 +270,7 @@ async fn app_execute_transaction_sequence() { let tx = UnsignedTransaction::builder() .actions(vec![ - SequenceAction { + Sequence { rollup_id: RollupId::from_unhashed_bytes(b"testchainid"), data, fee_asset: nria().into(), @@ -306,7 +306,7 @@ async fn app_execute_transaction_invalid_fee_asset() { let tx = UnsignedTransaction::builder() .actions(vec![ - SequenceAction { + Sequence { rollup_id: RollupId::from_unhashed_bytes(b"testchainid"), data, fee_asset: test_asset(), @@ -362,9 +362,9 @@ async fn app_execute_transaction_ibc_relayer_change_addition() { let mut app = initialize_app(Some(genesis_state()), vec![]).await; let tx = UnsignedTransaction::builder() - .actions(vec![Action::IbcRelayerChange( - IbcRelayerChangeAction::Addition(alice_address), - )]) + .actions(vec![Action::IbcRelayerChange(IbcRelayerChange::Addition( + alice_address, + ))]) .chain_id("test") .try_build() .unwrap(); @@ -393,7 +393,7 @@ async fn app_execute_transaction_ibc_relayer_change_deletion() { let mut app = initialize_app(Some(genesis_state), vec![]).await; let tx = UnsignedTransaction::builder() - .actions(vec![IbcRelayerChangeAction::Removal(alice_address).into()]) + .actions(vec![IbcRelayerChange::Removal(alice_address).into()]) .chain_id("test") .try_build() .unwrap(); @@ -423,7 +423,7 @@ async fn app_execute_transaction_ibc_relayer_change_invalid() { let mut app = initialize_app(Some(genesis_state), vec![]).await; let tx = UnsignedTransaction::builder() - .actions(vec![IbcRelayerChangeAction::Removal(alice_address).into()]) + .actions(vec![IbcRelayerChange::Removal(alice_address).into()]) .chain_id("test") .try_build() .unwrap(); @@ -441,7 +441,7 @@ async fn app_execute_transaction_sudo_address_change() { let new_address = astria_address_from_hex_string(BOB_ADDRESS); let tx = UnsignedTransaction::builder() - .actions(vec![Action::SudoAddressChange(SudoAddressChangeAction { + .actions(vec![Action::SudoAddressChange(SudoAddressChange { new_address, })]) .chain_id("test") @@ -479,7 +479,7 @@ async fn app_execute_transaction_sudo_address_change_error() { .unwrap(); let mut app = initialize_app(Some(genesis_state), vec![]).await; let tx = UnsignedTransaction::builder() - .actions(vec![Action::SudoAddressChange(SudoAddressChangeAction { + .actions(vec![Action::SudoAddressChange(SudoAddressChange { new_address: alice_address, })]) .chain_id("test") @@ -498,7 +498,7 @@ async fn app_execute_transaction_sudo_address_change_error() { #[tokio::test] async fn app_execute_transaction_fee_asset_change_addition() { - use astria_core::protocol::transaction::v1alpha1::action::FeeAssetChangeAction; + use astria_core::protocol::transaction::v1alpha1::action::FeeAssetChange; let alice = get_alice_signing_key(); let alice_address = astria_address(&alice.address_bytes()); @@ -506,9 +506,9 @@ async fn app_execute_transaction_fee_asset_change_addition() { let mut app = initialize_app(Some(genesis_state()), vec![]).await; let tx = UnsignedTransaction::builder() - .actions(vec![Action::FeeAssetChange( - FeeAssetChangeAction::Addition(test_asset()), - )]) + .actions(vec![Action::FeeAssetChange(FeeAssetChange::Addition( + test_asset(), + ))]) .chain_id("test") .try_build() .unwrap(); @@ -525,7 +525,7 @@ async fn app_execute_transaction_fee_asset_change_addition() { #[tokio::test] async fn app_execute_transaction_fee_asset_change_removal() { - use astria_core::protocol::transaction::v1alpha1::action::FeeAssetChangeAction; + use astria_core::protocol::transaction::v1alpha1::action::FeeAssetChange; let alice = get_alice_signing_key(); let alice_address = astria_address(&alice.address_bytes()); @@ -540,7 +540,7 @@ async fn app_execute_transaction_fee_asset_change_removal() { let mut app = initialize_app(Some(genesis_state), vec![]).await; let tx = UnsignedTransaction::builder() - .actions(vec![Action::FeeAssetChange(FeeAssetChangeAction::Removal( + .actions(vec![Action::FeeAssetChange(FeeAssetChange::Removal( test_asset(), ))]) .chain_id("test") @@ -559,14 +559,14 @@ async fn app_execute_transaction_fee_asset_change_removal() { #[tokio::test] async fn app_execute_transaction_fee_asset_change_invalid() { - use astria_core::protocol::transaction::v1alpha1::action::FeeAssetChangeAction; + use astria_core::protocol::transaction::v1alpha1::action::FeeAssetChange; let alice = get_alice_signing_key(); let mut app = initialize_app(Some(genesis_state()), vec![]).await; let tx = UnsignedTransaction::builder() - .actions(vec![Action::FeeAssetChange(FeeAssetChangeAction::Removal( + .actions(vec![Action::FeeAssetChange(FeeAssetChange::Removal( nria().into(), ))]) .chain_id("test") @@ -585,7 +585,7 @@ async fn app_execute_transaction_fee_asset_change_invalid() { #[tokio::test] async fn app_execute_transaction_init_bridge_account_ok() { - use astria_core::protocol::transaction::v1alpha1::action::InitBridgeAccountAction; + use astria_core::protocol::transaction::v1alpha1::action::InitBridgeAccount; let alice = get_alice_signing_key(); let alice_address = astria_address(&alice.address_bytes()); @@ -597,7 +597,7 @@ async fn app_execute_transaction_init_bridge_account_ok() { app.apply(state_tx); let rollup_id = RollupId::from_unhashed_bytes(b"testchainid"); - let action = InitBridgeAccountAction { + let action = InitBridgeAccount { rollup_id, asset: nria().into(), fee_asset: nria().into(), @@ -649,13 +649,13 @@ async fn app_execute_transaction_init_bridge_account_ok() { #[tokio::test] async fn app_execute_transaction_init_bridge_account_account_already_registered() { - use astria_core::protocol::transaction::v1alpha1::action::InitBridgeAccountAction; + use astria_core::protocol::transaction::v1alpha1::action::InitBridgeAccount; let alice = get_alice_signing_key(); let mut app = initialize_app(None, vec![]).await; let rollup_id = RollupId::from_unhashed_bytes(b"testchainid"); - let action = InitBridgeAccountAction { + let action = InitBridgeAccount { rollup_id, asset: nria().into(), fee_asset: nria().into(), @@ -671,7 +671,7 @@ async fn app_execute_transaction_init_bridge_account_account_already_registered( let signed_tx = Arc::new(tx.into_signed(&alice)); app.execute_transaction(signed_tx).await.unwrap(); - let action = InitBridgeAccountAction { + let action = InitBridgeAccount { rollup_id, asset: nria().into(), fee_asset: nria().into(), @@ -709,7 +709,7 @@ async fn app_execute_transaction_bridge_lock_action_ok() { app.apply(state_tx); let amount = 100; - let action = BridgeLockAction { + let action = BridgeLock { to: bridge_address, amount, asset: nria().into(), @@ -781,7 +781,7 @@ async fn app_execute_transaction_bridge_lock_action_ok() { #[tokio::test] async fn app_execute_transaction_bridge_lock_action_invalid_for_eoa() { - use astria_core::protocol::transaction::v1alpha1::action::BridgeLockAction; + use astria_core::protocol::transaction::v1alpha1::action::BridgeLock; let alice = get_alice_signing_key(); let mut app = initialize_app(None, vec![]).await; @@ -790,7 +790,7 @@ async fn app_execute_transaction_bridge_lock_action_invalid_for_eoa() { let bridge_address = astria_address(&[99; 20]); let amount = 100; - let action = BridgeLockAction { + let action = BridgeLock { to: bridge_address, amount, asset: nria().into(), @@ -819,7 +819,7 @@ async fn app_execute_transaction_invalid_nonce() { let tx = UnsignedTransaction::builder() .actions(vec![ - SequenceAction { + Sequence { rollup_id: RollupId::from_unhashed_bytes(b"testchainid"), data, fee_asset: nria().into(), @@ -868,7 +868,7 @@ async fn app_execute_transaction_invalid_chain_id() { let data = Bytes::from_static(b"hello world"); let tx = UnsignedTransaction::builder() .actions(vec![ - SequenceAction { + Sequence { rollup_id: RollupId::from_unhashed_bytes(b"testchainid"), data, fee_asset: nria().into(), @@ -925,7 +925,7 @@ async fn app_stateful_check_fails_insufficient_total_balance() { // transfer just enough to cover single sequence fee with data let signed_tx = UnsignedTransaction::builder() .actions(vec![ - TransferAction { + Transfer { to: keypair_address, amount: fee, asset: nria().into(), @@ -942,13 +942,13 @@ async fn app_stateful_check_fails_insufficient_total_balance() { // build double transfer exceeding balance let signed_tx_fail = UnsignedTransaction::builder() .actions(vec![ - SequenceAction { + Sequence { rollup_id: RollupId::from_unhashed_bytes(b"testchainid"), data: data.clone(), fee_asset: nria().into(), } .into(), - SequenceAction { + Sequence { rollup_id: RollupId::from_unhashed_bytes(b"testchainid"), data: data.clone(), fee_asset: nria().into(), @@ -971,7 +971,7 @@ async fn app_stateful_check_fails_insufficient_total_balance() { // build single transfer to see passes let signed_tx_pass = UnsignedTransaction::builder() .actions(vec![ - SequenceAction { + Sequence { rollup_id: RollupId::from_unhashed_bytes(b"testchainid"), data, fee_asset: nria().into(), @@ -1023,7 +1023,7 @@ async fn app_execute_transaction_bridge_lock_unlock_action_ok() { app.apply(state_tx); let amount = 100; - let action = BridgeLockAction { + let action = BridgeLock { to: bridge_address, amount, asset: nria().into(), @@ -1045,7 +1045,7 @@ async fn app_execute_transaction_bridge_lock_unlock_action_ok() { ); // see can unlock through bridge unlock - let action = BridgeUnlockAction { + let action = BridgeUnlock { to: alice_address, amount, fee_asset: nria().into(), @@ -1095,7 +1095,7 @@ async fn app_execute_transaction_action_index_correctly_increments() { app.apply(state_tx); let amount = 100; - let action = BridgeLockAction { + let action = BridgeLock { to: bridge_address, amount, asset: nria().into(), @@ -1144,7 +1144,7 @@ async fn transaction_execution_records_deposit_event() { .put_bridge_account_ibc_asset(&bob_address, nria()) .unwrap(); - let action = BridgeLockAction { + let action = BridgeLock { to: bob_address, amount: 1, asset: nria().into(), @@ -1187,7 +1187,7 @@ async fn app_execute_transaction_ibc_sudo_change() { let new_address = astria_address_from_hex_string(BOB_ADDRESS); let tx = UnsignedTransaction::builder() - .actions(vec![Action::IbcSudoChange(IbcSudoChangeAction { + .actions(vec![Action::IbcSudoChange(IbcSudoChange { new_address, })]) .chain_id("test") @@ -1222,7 +1222,7 @@ async fn app_execute_transaction_ibc_sudo_change_error() { let mut app = initialize_app(Some(genesis_state), vec![]).await; let tx = UnsignedTransaction::builder() - .actions(vec![Action::IbcSudoChange(IbcSudoChangeAction { + .actions(vec![Action::IbcSudoChange(IbcSudoChange { new_address: alice_address, })]) .chain_id("test") diff --git a/crates/astria-sequencer/src/authority/action.rs b/crates/astria-sequencer/src/authority/action.rs index ac044f601d..8386c748c6 100644 --- a/crates/astria-sequencer/src/authority/action.rs +++ b/crates/astria-sequencer/src/authority/action.rs @@ -1,8 +1,8 @@ use astria_core::protocol::transaction::v1alpha1::action::{ FeeChange, - FeeChangeAction, - IbcSudoChangeAction, - SudoAddressChangeAction, + FeeChangeKind, + IbcSudoChange, + SudoAddressChange, ValidatorUpdate, }; use astria_eyre::eyre::{ @@ -77,7 +77,7 @@ impl ActionHandler for ValidatorUpdate { } #[async_trait::async_trait] -impl ActionHandler for SudoAddressChangeAction { +impl ActionHandler for SudoAddressChange { async fn check_stateless(&self) -> Result<()> { Ok(()) } @@ -107,7 +107,7 @@ impl ActionHandler for SudoAddressChangeAction { } #[async_trait::async_trait] -impl ActionHandler for FeeChangeAction { +impl ActionHandler for FeeChange { async fn check_stateless(&self) -> Result<()> { Ok(()) } @@ -127,25 +127,25 @@ impl ActionHandler for FeeChangeAction { ensure!(sudo_address == from, "signer is not the sudo key"); match self.fee_change { - FeeChange::TransferBaseFee => state + FeeChangeKind::TransferBaseFee => state .put_transfer_base_fee(self.new_value) .wrap_err("failed to put transfer base fee"), - FeeChange::SequenceBaseFee => state + FeeChangeKind::SequenceBaseFee => state .put_sequence_action_base_fee(self.new_value) .wrap_err("failed to put sequence action base fee"), - FeeChange::SequenceByteCostMultiplier => state + FeeChangeKind::SequenceByteCostMultiplier => state .put_sequence_action_byte_cost_multiplier(self.new_value) .wrap_err("failed to put sequence action byte cost multiplier"), - FeeChange::InitBridgeAccountBaseFee => state + FeeChangeKind::InitBridgeAccountBaseFee => state .put_init_bridge_account_base_fee(self.new_value) .wrap_err("failed to put init bridge account base fee"), - FeeChange::BridgeLockByteCostMultiplier => state + FeeChangeKind::BridgeLockByteCostMultiplier => state .put_bridge_lock_byte_cost_multiplier(self.new_value) .wrap_err("failed to put bridge lock byte cost multiplier"), - FeeChange::BridgeSudoChangeBaseFee => state + FeeChangeKind::BridgeSudoChangeBaseFee => state .put_bridge_sudo_change_base_fee(self.new_value) .wrap_err("failed to put bridge sudo change base fee"), - FeeChange::Ics20WithdrawalBaseFee => state + FeeChangeKind::Ics20WithdrawalBaseFee => state .put_ics20_withdrawal_base_fee(self.new_value) .wrap_err("failed to put ics20 withdrawal base fee"), } @@ -153,7 +153,7 @@ impl ActionHandler for FeeChangeAction { } #[async_trait::async_trait] -impl ActionHandler for IbcSudoChangeAction { +impl ActionHandler for IbcSudoChange { async fn check_stateless(&self) -> Result<()> { Ok(()) } @@ -213,8 +213,8 @@ mod tests { state.put_transfer_base_fee(transfer_fee).unwrap(); - let fee_change = FeeChangeAction { - fee_change: FeeChange::TransferBaseFee, + let fee_change = FeeChange { + fee_change: FeeChangeKind::TransferBaseFee, new_value: 10, }; @@ -226,8 +226,8 @@ mod tests { .put_sequence_action_base_fee(sequence_base_fee) .unwrap(); - let fee_change = FeeChangeAction { - fee_change: FeeChange::SequenceBaseFee, + let fee_change = FeeChange { + fee_change: FeeChangeKind::SequenceBaseFee, new_value: 3, }; @@ -239,8 +239,8 @@ mod tests { .put_sequence_action_byte_cost_multiplier(sequence_byte_cost_multiplier) .unwrap(); - let fee_change = FeeChangeAction { - fee_change: FeeChange::SequenceByteCostMultiplier, + let fee_change = FeeChange { + fee_change: FeeChangeKind::SequenceByteCostMultiplier, new_value: 4, }; @@ -258,8 +258,8 @@ mod tests { .put_init_bridge_account_base_fee(init_bridge_account_base_fee) .unwrap(); - let fee_change = FeeChangeAction { - fee_change: FeeChange::InitBridgeAccountBaseFee, + let fee_change = FeeChange { + fee_change: FeeChangeKind::InitBridgeAccountBaseFee, new_value: 2, }; @@ -271,8 +271,8 @@ mod tests { .put_bridge_lock_byte_cost_multiplier(bridge_lock_byte_cost_multiplier) .unwrap(); - let fee_change = FeeChangeAction { - fee_change: FeeChange::BridgeLockByteCostMultiplier, + let fee_change = FeeChange { + fee_change: FeeChangeKind::BridgeLockByteCostMultiplier, new_value: 2, }; @@ -287,8 +287,8 @@ mod tests { .put_ics20_withdrawal_base_fee(ics20_withdrawal_base_fee) .unwrap(); - let fee_change = FeeChangeAction { - fee_change: FeeChange::Ics20WithdrawalBaseFee, + let fee_change = FeeChange { + fee_change: FeeChangeKind::Ics20WithdrawalBaseFee, new_value: 2, }; diff --git a/crates/astria-sequencer/src/bridge/bridge_lock_action.rs b/crates/astria-sequencer/src/bridge/bridge_lock_action.rs index 20f8764380..f5270901ed 100644 --- a/crates/astria-sequencer/src/bridge/bridge_lock_action.rs +++ b/crates/astria-sequencer/src/bridge/bridge_lock_action.rs @@ -1,7 +1,7 @@ use astria_core::{ protocol::transaction::v1alpha1::action::{ - BridgeLockAction, - TransferAction, + BridgeLock, + Transfer, }, sequencerblock::v1alpha1::block::Deposit, Protobuf as _, @@ -39,7 +39,7 @@ use crate::{ const DEPOSIT_BASE_FEE: u128 = 16; #[async_trait::async_trait] -impl ActionHandler for BridgeLockAction { +impl ActionHandler for BridgeLock { async fn check_stateless(&self) -> Result<()> { Ok(()) } @@ -107,7 +107,7 @@ impl ActionHandler for BridgeLockAction { .saturating_add(transfer_fee); ensure!(from_balance >= fee, "insufficient funds for fee payment"); - let transfer_action = TransferAction { + let transfer_action = Transfer { to: self.to, asset: self.asset.clone(), amount: self.amount, @@ -215,7 +215,7 @@ mod tests { let bridge_address = astria_address(&[1; 20]); let asset = test_asset(); - let bridge_lock = BridgeLockAction { + let bridge_lock = BridgeLock { to: bridge_address, asset: asset.clone(), amount: 100, diff --git a/crates/astria-sequencer/src/bridge/bridge_sudo_change_action.rs b/crates/astria-sequencer/src/bridge/bridge_sudo_change_action.rs index 4d626ce690..68ff190ad9 100644 --- a/crates/astria-sequencer/src/bridge/bridge_sudo_change_action.rs +++ b/crates/astria-sequencer/src/bridge/bridge_sudo_change_action.rs @@ -1,5 +1,5 @@ use astria_core::{ - protocol::transaction::v1alpha1::action::BridgeSudoChangeAction, + protocol::transaction::v1alpha1::action::BridgeSudoChange, Protobuf as _, }; use astria_eyre::eyre::{ @@ -25,7 +25,7 @@ use crate::{ transaction::StateReadExt as _, }; #[async_trait::async_trait] -impl ActionHandler for BridgeSudoChangeAction { +impl ActionHandler for BridgeSudoChange { async fn check_stateless(&self) -> Result<()> { Ok(()) } @@ -152,7 +152,7 @@ mod tests { .put_bridge_account_sudo_address(&bridge_address, sudo_address) .unwrap(); - let action = BridgeSudoChangeAction { + let action = BridgeSudoChange { bridge_address, new_sudo_address: None, new_withdrawer_address: None, @@ -199,7 +199,7 @@ mod tests { .put_account_balance(&bridge_address, &fee_asset, 10) .unwrap(); - let action = BridgeSudoChangeAction { + let action = BridgeSudoChange { bridge_address, new_sudo_address: Some(new_sudo_address), new_withdrawer_address: Some(new_withdrawer_address), diff --git a/crates/astria-sequencer/src/bridge/bridge_unlock_action.rs b/crates/astria-sequencer/src/bridge/bridge_unlock_action.rs index 787000f9a3..1661f9692a 100644 --- a/crates/astria-sequencer/src/bridge/bridge_unlock_action.rs +++ b/crates/astria-sequencer/src/bridge/bridge_unlock_action.rs @@ -1,6 +1,6 @@ use astria_core::protocol::transaction::v1alpha1::action::{ - BridgeUnlockAction, - TransferAction, + BridgeUnlock, + Transfer, }; use astria_eyre::eyre::{ bail, @@ -25,7 +25,7 @@ use crate::{ }; #[async_trait::async_trait] -impl ActionHandler for BridgeUnlockAction { +impl ActionHandler for BridgeUnlock { // TODO(https://github.com/astriaorg/astria/issues/1430): move checks to the `BridgeUnlock` parsing. async fn check_stateless(&self) -> Result<()> { ensure!(self.amount > 0, "amount must be greater than zero",); @@ -78,7 +78,7 @@ impl ActionHandler for BridgeUnlockAction { "unauthorized to unlock bridge account", ); - let transfer_action = TransferAction { + let transfer_action = Transfer { to: self.to, asset: asset.into(), amount: self.amount, @@ -108,7 +108,7 @@ mod tests { RollupId, TransactionId, }, - protocol::transaction::v1alpha1::action::BridgeUnlockAction, + protocol::transaction::v1alpha1::action::BridgeUnlock, }; use cnidarium::StateDelta; @@ -155,7 +155,7 @@ mod tests { .put_bridge_account_ibc_asset(&bridge_address, &asset) .unwrap(); - let bridge_unlock = BridgeUnlockAction { + let bridge_unlock = BridgeUnlock { to: to_address, amount: transfer_amount, fee_asset: asset.clone(), @@ -198,7 +198,7 @@ mod tests { .put_bridge_account_ibc_asset(&bridge_address, &asset) .unwrap(); - let bridge_unlock = BridgeUnlockAction { + let bridge_unlock = BridgeUnlock { to: to_address, amount: transfer_amount, fee_asset: asset, @@ -252,7 +252,7 @@ mod tests { .put_account_balance(&bridge_address, &asset, 3 * transfer_amount) .unwrap(); - let bridge_unlock_first = BridgeUnlockAction { + let bridge_unlock_first = BridgeUnlock { to: to_address, amount: transfer_amount, fee_asset: asset.clone(), @@ -261,7 +261,7 @@ mod tests { rollup_block_number: 1, rollup_withdrawal_event_id: "a-rollup-defined-hash".to_string(), }; - let bridge_unlock_second = BridgeUnlockAction { + let bridge_unlock_second = BridgeUnlock { rollup_block_number: 10, ..bridge_unlock_first.clone() }; diff --git a/crates/astria-sequencer/src/bridge/init_bridge_account_action.rs b/crates/astria-sequencer/src/bridge/init_bridge_account_action.rs index 0cf23d6773..9f4138289b 100644 --- a/crates/astria-sequencer/src/bridge/init_bridge_account_action.rs +++ b/crates/astria-sequencer/src/bridge/init_bridge_account_action.rs @@ -1,6 +1,6 @@ use astria_core::{ primitive::v1::Address, - protocol::transaction::v1alpha1::action::InitBridgeAccountAction, + protocol::transaction::v1alpha1::action::InitBridgeAccount, Protobuf as _, }; use astria_eyre::eyre::{ @@ -30,7 +30,7 @@ use crate::{ }; #[async_trait::async_trait] -impl ActionHandler for InitBridgeAccountAction { +impl ActionHandler for InitBridgeAccount { async fn check_stateless(&self) -> Result<()> { Ok(()) } diff --git a/crates/astria-sequencer/src/fee_asset_change.rs b/crates/astria-sequencer/src/fee_asset_change.rs index 326d5472eb..f12cc9dd93 100644 --- a/crates/astria-sequencer/src/fee_asset_change.rs +++ b/crates/astria-sequencer/src/fee_asset_change.rs @@ -1,4 +1,4 @@ -use astria_core::protocol::transaction::v1alpha1::action::FeeAssetChangeAction; +use astria_core::protocol::transaction::v1alpha1::action::FeeAssetChange; use astria_eyre::eyre::{ bail, ensure, @@ -19,7 +19,7 @@ use crate::{ }; #[async_trait] -impl ActionHandler for FeeAssetChangeAction { +impl ActionHandler for FeeAssetChange { async fn check_stateless(&self) -> Result<()> { Ok(()) } @@ -38,12 +38,12 @@ impl ActionHandler for FeeAssetChangeAction { "unauthorized address for fee asset change" ); match self { - FeeAssetChangeAction::Addition(asset) => { + FeeAssetChange::Addition(asset) => { state .put_allowed_fee_asset(asset) .context("failed to write allowed fee asset to state")?; } - FeeAssetChangeAction::Removal(asset) => { + FeeAssetChange::Removal(asset) => { state.delete_allowed_fee_asset(asset); if state diff --git a/crates/astria-sequencer/src/ibc/ibc_relayer_change.rs b/crates/astria-sequencer/src/ibc/ibc_relayer_change.rs index 24491b9b5c..17b513a57c 100644 --- a/crates/astria-sequencer/src/ibc/ibc_relayer_change.rs +++ b/crates/astria-sequencer/src/ibc/ibc_relayer_change.rs @@ -1,4 +1,4 @@ -use astria_core::protocol::transaction::v1alpha1::action::IbcRelayerChangeAction; +use astria_core::protocol::transaction::v1alpha1::action::IbcRelayerChange; use astria_eyre::eyre::{ ensure, Result, @@ -18,7 +18,7 @@ use crate::{ }; #[async_trait] -impl ActionHandler for IbcRelayerChangeAction { +impl ActionHandler for IbcRelayerChange { async fn check_stateless(&self) -> Result<()> { Ok(()) } @@ -29,7 +29,7 @@ impl ActionHandler for IbcRelayerChangeAction { .expect("transaction source must be present in state when executing an action") .address_bytes(); match self { - IbcRelayerChangeAction::Addition(addr) | IbcRelayerChangeAction::Removal(addr) => { + IbcRelayerChange::Addition(addr) | IbcRelayerChange::Removal(addr) => { state.ensure_base_prefix(addr).await.wrap_err( "failed check for base prefix of provided address to be added/removed", )?; @@ -46,12 +46,12 @@ impl ActionHandler for IbcRelayerChangeAction { ); match self { - IbcRelayerChangeAction::Addition(address) => { + IbcRelayerChange::Addition(address) => { state .put_ibc_relayer_address(address) .wrap_err("failed to put IBC relayer address")?; } - IbcRelayerChangeAction::Removal(address) => { + IbcRelayerChange::Removal(address) => { state.delete_ibc_relayer_address(address); } } diff --git a/crates/astria-sequencer/src/proposal/commitment.rs b/crates/astria-sequencer/src/proposal/commitment.rs index 627cb1998f..dd113080d8 100644 --- a/crates/astria-sequencer/src/proposal/commitment.rs +++ b/crates/astria-sequencer/src/proposal/commitment.rs @@ -95,8 +95,8 @@ mod tests { crypto::SigningKey, protocol::transaction::v1alpha1::{ action::{ - SequenceAction, - TransferAction, + Sequence, + Transfer, }, UnsignedTransaction, }, @@ -107,12 +107,12 @@ mod tests { #[test] fn generate_rollup_datas_commitment_should_ignore_transfers() { - let sequence_action = SequenceAction { + let sequence_action = Sequence { rollup_id: RollupId::from_unhashed_bytes(b"testchainid"), data: Bytes::from_static(b"hello world"), fee_asset: crate::test_utils::nria().into(), }; - let transfer_action = TransferAction { + let transfer_action = Transfer { to: crate::test_utils::astria_address(&[0u8; 20]), amount: 1, asset: crate::test_utils::nria().into(), @@ -158,12 +158,12 @@ mod tests { // this test will only break in the case of a breaking change to the commitment scheme, // thus if this test needs to be updated, we should cut a new release. - let sequence_action = SequenceAction { + let sequence_action = Sequence { rollup_id: RollupId::from_unhashed_bytes(b"testchainid"), data: b"helloworld".to_vec().into(), fee_asset: crate::test_utils::nria().into(), }; - let transfer_action = TransferAction { + let transfer_action = Transfer { to: crate::test_utils::astria_address(&[0u8; 20]), amount: 1, asset: crate::test_utils::nria().into(), diff --git a/crates/astria-sequencer/src/sequence/action.rs b/crates/astria-sequencer/src/sequence/action.rs index cee7e3710e..dffbdeff61 100644 --- a/crates/astria-sequencer/src/sequence/action.rs +++ b/crates/astria-sequencer/src/sequence/action.rs @@ -1,5 +1,5 @@ use astria_core::{ - protocol::transaction::v1alpha1::action::SequenceAction, + protocol::transaction::v1alpha1::action::Sequence, Protobuf as _, }; use astria_eyre::eyre::{ @@ -25,7 +25,7 @@ use crate::{ }; #[async_trait::async_trait] -impl ActionHandler for SequenceAction { +impl ActionHandler for Sequence { async fn check_stateless(&self) -> Result<()> { // TODO: do we want to place a maximum on the size of the data? // https://github.com/astriaorg/astria/issues/222 diff --git a/crates/astria-sequencer/src/service/consensus.rs b/crates/astria-sequencer/src/service/consensus.rs index 95597fbd7c..9dafcef7c0 100644 --- a/crates/astria-sequencer/src/service/consensus.rs +++ b/crates/astria-sequencer/src/service/consensus.rs @@ -210,7 +210,7 @@ mod tests { }, primitive::v1::RollupId, protocol::transaction::v1alpha1::{ - action::SequenceAction, + action::Sequence, UnsignedTransaction, }, }; @@ -238,7 +238,7 @@ mod tests { fn make_unsigned_tx() -> UnsignedTransaction { UnsignedTransaction::builder() .actions(vec![ - SequenceAction { + Sequence { rollup_id: RollupId::from_unhashed_bytes(b"testchainid"), data: Bytes::from_static(b"hello world"), fee_asset: crate::test_utils::nria().into(), diff --git a/crates/astria-sequencer/src/transaction/checks.rs b/crates/astria-sequencer/src/transaction/checks.rs index 07858213ea..ad7759ff22 100644 --- a/crates/astria-sequencer/src/transaction/checks.rs +++ b/crates/astria-sequencer/src/transaction/checks.rs @@ -9,7 +9,7 @@ use astria_core::{ protocol::transaction::v1alpha1::{ action::{ Action, - BridgeLockAction, + BridgeLock, }, SignedTransaction, UnsignedTransaction, @@ -268,7 +268,7 @@ fn ics20_withdrawal_updates_fees( } fn bridge_lock_update_fees( - act: &BridgeLockAction, + act: &BridgeLock, fees_by_asset: &mut HashMap, transfer_fee: u128, bridge_lock_byte_cost_multiplier: u128, @@ -317,8 +317,8 @@ mod tests { ADDRESS_LEN, }, protocol::transaction::v1alpha1::action::{ - SequenceAction, - TransferAction, + Sequence, + Transfer, }, }; use bytes::Bytes; @@ -392,13 +392,13 @@ mod tests { .unwrap(); let actions = vec![ - Action::Transfer(TransferAction { + Action::Transfer(Transfer { asset: other_asset.clone(), amount, fee_asset: crate::test_utils::nria().into(), to: state_tx.try_base_prefixed(&[0; ADDRESS_LEN]).await.unwrap(), }), - Action::Sequence(SequenceAction { + Action::Sequence(Sequence { rollup_id: RollupId::from_unhashed_bytes([0; 32]), data, fee_asset: crate::test_utils::nria().into(), @@ -459,13 +459,13 @@ mod tests { .unwrap(); let actions = vec![ - Action::Transfer(TransferAction { + Action::Transfer(Transfer { asset: other_asset.clone(), amount, fee_asset: crate::test_utils::nria().into(), to: state_tx.try_base_prefixed(&[0; ADDRESS_LEN]).await.unwrap(), }), - Action::Sequence(SequenceAction { + Action::Sequence(Sequence { rollup_id: RollupId::from_unhashed_bytes([0; 32]), data, fee_asset: crate::test_utils::nria().into(), diff --git a/proto/protocolapis/astria/protocol/transactions/v1alpha1/types.proto b/proto/protocolapis/astria/protocol/transactions/v1alpha1/types.proto index 8bd9665303..80d9c992b5 100644 --- a/proto/protocolapis/astria/protocol/transactions/v1alpha1/types.proto +++ b/proto/protocolapis/astria/protocol/transactions/v1alpha1/types.proto @@ -35,26 +35,26 @@ message TransactionParams { message Action { oneof value { // Core protocol actions are defined on 1-10 - TransferAction transfer_action = 1; - SequenceAction sequence_action = 2; + Transfer transfer = 1; + Sequence sequence = 2; // Bridge actions are defined on 11-20 - InitBridgeAccountAction init_bridge_account_action = 11; - BridgeLockAction bridge_lock_action = 12; - BridgeUnlockAction bridge_unlock_action = 13; - BridgeSudoChangeAction bridge_sudo_change_action = 14; + InitBridgeAccount init_bridge_account = 11; + BridgeLock bridge_lock = 12; + BridgeUnlock bridge_unlock = 13; + BridgeSudoChange bridge_sudo_change = 14; // IBC user actions are defined on 21-30 - astria_vendored.penumbra.core.component.ibc.v1.IbcRelay ibc_action = 21; + astria_vendored.penumbra.core.component.ibc.v1.IbcRelay ibc = 21; Ics20Withdrawal ics20_withdrawal = 22; // POA sudo actions are defined on 50-60 - SudoAddressChangeAction sudo_address_change_action = 50; - astria_vendored.tendermint.abci.ValidatorUpdate validator_update_action = 51; - IbcRelayerChangeAction ibc_relayer_change_action = 52; - FeeAssetChangeAction fee_asset_change_action = 53; - FeeChangeAction fee_change_action = 55; - IbcSudoChangeAction ibc_sudo_change_action = 56; + SudoAddressChange sudo_address_change = 50; + astria_vendored.tendermint.abci.ValidatorUpdate validator_update = 51; + IbcRelayerChange ibc_relayer_change = 52; + FeeAssetChange fee_asset_change = 53; + FeeChange fee_change = 55; + IbcSudoChange ibc_sudo_change = 56; } reserved 3 to 10; reserved 15 to 20; @@ -70,7 +70,7 @@ message Action { // // Note: all values must be set (ie. not `None`), otherwise it will // be considered invalid by the sequencer. -message TransferAction { +message Transfer { astria.primitive.v1.Address to = 1; astria.primitive.v1.Uint128 amount = 2; // the asset to be transferred @@ -79,24 +79,24 @@ message TransferAction { string fee_asset = 4; } -// `SequenceAction` represents a transaction destined for another +// `Sequence` represents a transaction destined for another // chain, ordered by the sequencer. // // It contains the rollup ID of the destination chain, and the // opaque transaction data. -message SequenceAction { +message Sequence { astria.primitive.v1.RollupId rollup_id = 1; bytes data = 2; // the asset used to pay the transaction fee string fee_asset = 3; } -/// `SudoAddressChangeAction` represents a transaction that changes +/// `SudoAddressChange` represents a transaction that changes /// the sudo address of the chain, which is the address authorized to /// make validator update actions. /// /// It contains the new sudo address. -message SudoAddressChangeAction { +message SudoAddressChange { astria.primitive.v1.Address new_address = 1; } @@ -143,32 +143,32 @@ message IbcHeight { uint64 revision_height = 2; } -// `IbcRelayerChangeAction` represents a transaction that adds +// `IbcRelayerChange` represents a transaction that adds // or removes an IBC relayer address. // The bytes contained in each variant are the address to add or remove. -message IbcRelayerChangeAction { +message IbcRelayerChange { oneof value { astria.primitive.v1.Address addition = 1; astria.primitive.v1.Address removal = 2; } } -// `FeeAssetChangeAction` represents a transaction that adds +// `FeeAssetChange` represents a transaction that adds // or removes an asset for fee payments. -message FeeAssetChangeAction { +message FeeAssetChange { oneof value { string addition = 1; string removal = 2; } } -// `InitBridgeAccountAction` represents a transaction that initializes +// `InitBridgeAccount` represents a transaction that initializes // a bridge account for the given rollup on the chain. // // The sender of the transaction is used as the owner of the bridge account // and is the only actor authorized to transfer out of this account via -// a `TransferAction`. -message InitBridgeAccountAction { +// a `Transfer`. +message InitBridgeAccount { // the rollup ID to register with the bridge account (the tx sender) astria.primitive.v1.RollupId rollup_id = 1; // the asset ID accepted as an incoming transfer by the bridge account @@ -184,12 +184,12 @@ message InitBridgeAccountAction { astria.primitive.v1.Address withdrawer_address = 5; } -// `BridgeLockAction` represents a transaction that transfers +// `BridgeLock` represents a transaction that transfers // funds from a sequencer account to a bridge account. // -// It's the same as a `TransferAction` but with the added +// It's the same as a `Transfer` but with the added // `destination_chain_address` field. -message BridgeLockAction { +message BridgeLock { // the address of the bridge account to transfer to astria.primitive.v1.Address to = 1; // the amount to transfer @@ -203,12 +203,12 @@ message BridgeLockAction { string destination_chain_address = 5; } -// `BridgeUnlockAction` represents a transaction that transfers +// `BridgeUnlock` represents a transaction that transfers // funds from a bridge account to a sequencer account. // -// It's the same as a `TransferAction` but without the `asset` field +// It's the same as a `Transfer` but without the `asset` field // and with the `memo` field. -message BridgeUnlockAction { +message BridgeUnlock { // the to withdraw funds to astria.primitive.v1.Address to = 1; // the amount to transfer @@ -233,7 +233,7 @@ message BridgeUnlockAction { string rollup_withdrawal_event_id = 7; } -message BridgeSudoChangeAction { +message BridgeSudoChange { // the address of the bridge account to change the sudo or withdrawer addresses for astria.primitive.v1.Address bridge_address = 1; // the new sudo address; unchanged if unset @@ -244,7 +244,7 @@ message BridgeSudoChangeAction { string fee_asset = 4; } -message FeeChangeAction { +message FeeChange { // note that the proto number ranges are doubled from that of `Action`. // this to accomodate both `base_fee` and `byte_cost_multiplier` for each action. oneof value { @@ -263,7 +263,7 @@ message FeeChangeAction { } } -message IbcSudoChangeAction { +message IbcSudoChange { astria.primitive.v1.Address new_address = 1; }