diff --git a/crates/iota-rust-sdk/src/types/mod.rs b/crates/iota-rust-sdk/src/types/mod.rs index 2d97d8c..eadd504 100644 --- a/crates/iota-rust-sdk/src/types/mod.rs +++ b/crates/iota-rust-sdk/src/types/mod.rs @@ -55,13 +55,13 @@ pub use object_id::ObjectId; pub(crate) use transaction::SignedTransactionWithIntentMessage; pub use transaction::{ ActiveJwk, Argument, AuthenticatorStateExpire, AuthenticatorStateUpdate, CancelledTransaction, - ChangeEpoch, Command, ConsensusCommitPrologue, ConsensusCommitPrologueV2, - ConsensusCommitPrologueV3, ConsensusDeterminedVersionAssignments, EndOfEpochTransactionKind, - GasPayment, GenesisTransaction, InputArgument, MakeMoveVector, MergeCoins, MoveCall, - ProgrammableTransaction, Publish, RandomnessStateUpdate, SignedTransaction, SplitCoins, - SystemPackage, Transaction, TransactionExpiration, TransactionKind, TransferObjects, - UnresolvedGasPayment, UnresolvedInputArgument, UnresolvedObjectReference, - UnresolvedProgrammableTransaction, UnresolvedTransaction, Upgrade, VersionAssignment, + ChangeEpoch, Command, ConsensusCommitPrologueV1, ConsensusDeterminedVersionAssignments, + EndOfEpochTransactionKind, GasPayment, GenesisTransaction, InputArgument, MakeMoveVector, + MergeCoins, MoveCall, ProgrammableTransaction, Publish, RandomnessStateUpdate, + SignedTransaction, SplitCoins, SystemPackage, Transaction, TransactionExpiration, + TransactionKind, TransferObjects, UnresolvedGasPayment, UnresolvedInputArgument, + UnresolvedObjectReference, UnresolvedProgrammableTransaction, UnresolvedTransaction, Upgrade, + VersionAssignment, }; pub use type_tag::{Identifier, StructTag, TypeParseError, TypeTag}; diff --git a/crates/iota-rust-sdk/src/types/serialization_proptests.rs b/crates/iota-rust-sdk/src/types/serialization_proptests.rs index 31c6dec..af662e9 100644 --- a/crates/iota-rust-sdk/src/types/serialization_proptests.rs +++ b/crates/iota-rust-sdk/src/types/serialization_proptests.rs @@ -155,9 +155,7 @@ serialization_test!(AuthenticatorStateExpire); serialization_test!(AuthenticatorStateUpdate); serialization_test!(ChangeEpoch); serialization_test!(Command); -serialization_test!(ConsensusCommitPrologue); -serialization_test!(ConsensusCommitPrologueV2); -serialization_test!(ConsensusCommitPrologueV3); +serialization_test!(ConsensusCommitPrologueV1); serialization_test!(CancelledTransaction); serialization_test!(ConsensusDeterminedVersionAssignments); serialization_test!(VersionAssignment); diff --git a/crates/iota-rust-sdk/src/types/transaction/mod.rs b/crates/iota-rust-sdk/src/types/transaction/mod.rs index ae88918..05f20ce 100644 --- a/crates/iota-rust-sdk/src/types/transaction/mod.rs +++ b/crates/iota-rust-sdk/src/types/transaction/mod.rs @@ -111,12 +111,8 @@ pub enum TransactionKind { /// It also doesn't require/use a gas object. /// A validator will not sign a transaction of this kind from outside. It /// only signs internally during epoch changes. - /// - /// The ChangeEpoch enumerant is now deprecated (but the ChangeEpoch struct - /// is still used by EndOfEpochTransaction below). - ChangeEpoch(ChangeEpoch), Genesis(GenesisTransaction), - ConsensusCommitPrologue(ConsensusCommitPrologue), + ConsensusCommitPrologueV1(ConsensusCommitPrologueV1), AuthenticatorStateUpdate(AuthenticatorStateUpdate), /// EndOfEpochTransaction replaces ChangeEpoch with a list of transactions @@ -124,10 +120,6 @@ pub enum TransactionKind { EndOfEpoch(Vec), RandomnessStateUpdate(RandomnessStateUpdate), - // V2 ConsensusCommitPrologue also includes the digest of the current consensus output. - ConsensusCommitPrologueV2(ConsensusCommitPrologueV2), - - ConsensusCommitPrologueV3(ConsensusCommitPrologueV3), // .. more transaction types go here } @@ -143,7 +135,6 @@ pub enum EndOfEpochTransactionKind { ChangeEpoch(ChangeEpoch), AuthenticatorStateCreate, AuthenticatorStateExpire(AuthenticatorStateExpire), - RandomnessStateCreate, DenyListStateCreate, BridgeStateCreate { chain_id: super::CheckpointDigest, @@ -214,55 +205,6 @@ pub struct ActiveJwk { pub epoch: u64, } -/// Only commit_timestamp_ms is passed to the move call currently. -/// However we include epoch and round to make sure each ConsensusCommitPrologue -/// has a unique tx digest. -#[derive(Clone, Debug, PartialEq, Eq)] -#[cfg_attr( - feature = "serde", - derive(serde_derive::Serialize, serde_derive::Deserialize) -)] -#[cfg_attr(feature = "schemars", derive(schemars::JsonSchema))] -#[cfg_attr(test, derive(test_strategy::Arbitrary))] -pub struct ConsensusCommitPrologue { - /// Epoch of the commit prologue transaction - #[cfg_attr(feature = "serde", serde(with = "crate::_serde::ReadableDisplay"))] - #[cfg_attr(feature = "schemars", schemars(with = "crate::_schemars::U64"))] - pub epoch: u64, - /// Consensus round of the commit - #[cfg_attr(feature = "serde", serde(with = "crate::_serde::ReadableDisplay"))] - #[cfg_attr(feature = "schemars", schemars(with = "crate::_schemars::U64"))] - pub round: u64, - /// Unix timestamp from consensus - #[cfg_attr(feature = "serde", serde(with = "crate::_serde::ReadableDisplay"))] - #[cfg_attr(feature = "schemars", schemars(with = "crate::_schemars::U64"))] - pub commit_timestamp_ms: CheckpointTimestamp, -} - -#[derive(Clone, Debug, PartialEq, Eq)] -#[cfg_attr( - feature = "serde", - derive(serde_derive::Serialize, serde_derive::Deserialize) -)] -#[cfg_attr(feature = "schemars", derive(schemars::JsonSchema))] -#[cfg_attr(test, derive(test_strategy::Arbitrary))] -pub struct ConsensusCommitPrologueV2 { - /// Epoch of the commit prologue transaction - #[cfg_attr(feature = "serde", serde(with = "crate::_serde::ReadableDisplay"))] - #[cfg_attr(feature = "schemars", schemars(with = "crate::_schemars::U64"))] - pub epoch: u64, - /// Consensus round of the commit - #[cfg_attr(feature = "serde", serde(with = "crate::_serde::ReadableDisplay"))] - #[cfg_attr(feature = "schemars", schemars(with = "crate::_schemars::U64"))] - pub round: u64, - /// Unix timestamp from consensus - #[cfg_attr(feature = "serde", serde(with = "crate::_serde::ReadableDisplay"))] - #[cfg_attr(feature = "schemars", schemars(with = "crate::_schemars::U64"))] - pub commit_timestamp_ms: CheckpointTimestamp, - /// Digest of consensus output - pub consensus_commit_digest: ConsensusCommitDigest, -} - #[derive(Clone, Debug, PartialEq, Eq)] #[cfg_attr( feature = "schemars", @@ -312,7 +254,7 @@ pub struct VersionAssignment { )] #[cfg_attr(feature = "schemars", derive(schemars::JsonSchema))] #[cfg_attr(test, derive(test_strategy::Arbitrary))] -pub struct ConsensusCommitPrologueV3 { +pub struct ConsensusCommitPrologueV1 { /// Epoch of the commit prologue transaction #[cfg_attr(feature = "serde", serde(with = "crate::_serde::ReadableDisplay"))] #[cfg_attr(feature = "schemars", schemars(with = "crate::_schemars::U64"))] diff --git a/crates/iota-rust-sdk/src/types/transaction/serialization.rs b/crates/iota-rust-sdk/src/types/transaction/serialization.rs index f6e9e7e..4023aa7 100644 --- a/crates/iota-rust-sdk/src/types/transaction/serialization.rs +++ b/crates/iota-rust-sdk/src/types/transaction/serialization.rs @@ -124,25 +124,21 @@ mod transaction { mod transaction_kind { use super::*; use crate::types::transaction::{ - AuthenticatorStateUpdate, ChangeEpoch, ConsensusCommitPrologue, ConsensusCommitPrologueV2, - ConsensusCommitPrologueV3, EndOfEpochTransactionKind, GenesisTransaction, - ProgrammableTransaction, RandomnessStateUpdate, TransactionKind, + AuthenticatorStateUpdate, ConsensusCommitPrologueV1, EndOfEpochTransactionKind, + GenesisTransaction, ProgrammableTransaction, RandomnessStateUpdate, TransactionKind, }; #[derive(serde_derive::Serialize)] #[serde(tag = "kind", rename_all = "snake_case")] enum ReadableTransactionKindRef<'a> { ProgrammableTransaction(&'a ProgrammableTransaction), - ChangeEpoch(&'a ChangeEpoch), Genesis(&'a GenesisTransaction), - ConsensusCommitPrologue(&'a ConsensusCommitPrologue), + ConsensusCommitPrologueV1(&'a ConsensusCommitPrologueV1), AuthenticatorStateUpdate(&'a AuthenticatorStateUpdate), EndOfEpoch { commands: &'a Vec, }, RandomnessStateUpdate(&'a RandomnessStateUpdate), - ConsensusCommitPrologueV2(&'a ConsensusCommitPrologueV2), - ConsensusCommitPrologueV3(&'a ConsensusCommitPrologueV3), } #[derive(serde_derive::Deserialize)] @@ -151,16 +147,13 @@ mod transaction_kind { #[cfg_attr(feature = "schemars", derive(schemars::JsonSchema))] enum ReadableTransactionKind { ProgrammableTransaction(ProgrammableTransaction), - ChangeEpoch(ChangeEpoch), Genesis(GenesisTransaction), - ConsensusCommitPrologue(ConsensusCommitPrologue), + ConsensusCommitPrologueV1(ConsensusCommitPrologueV1), AuthenticatorStateUpdate(AuthenticatorStateUpdate), EndOfEpoch { commands: Vec, }, RandomnessStateUpdate(RandomnessStateUpdate), - ConsensusCommitPrologueV2(ConsensusCommitPrologueV2), - ConsensusCommitPrologueV3(ConsensusCommitPrologueV3), } #[cfg(feature = "schemars")] @@ -177,26 +170,20 @@ mod transaction_kind { #[derive(serde_derive::Serialize)] enum BinaryTransactionKindRef<'a> { ProgrammableTransaction(&'a ProgrammableTransaction), - ChangeEpoch(&'a ChangeEpoch), Genesis(&'a GenesisTransaction), - ConsensusCommitPrologue(&'a ConsensusCommitPrologue), + ConsensusCommitPrologueV1(&'a ConsensusCommitPrologueV1), AuthenticatorStateUpdate(&'a AuthenticatorStateUpdate), EndOfEpoch(&'a Vec), RandomnessStateUpdate(&'a RandomnessStateUpdate), - ConsensusCommitPrologueV2(&'a ConsensusCommitPrologueV2), - ConsensusCommitPrologueV3(&'a ConsensusCommitPrologueV3), } #[derive(serde_derive::Deserialize)] enum BinaryTransactionKind { ProgrammableTransaction(ProgrammableTransaction), - ChangeEpoch(ChangeEpoch), Genesis(GenesisTransaction), - ConsensusCommitPrologue(ConsensusCommitPrologue), + ConsensusCommitPrologueV1(ConsensusCommitPrologueV1), AuthenticatorStateUpdate(AuthenticatorStateUpdate), EndOfEpoch(Vec), RandomnessStateUpdate(RandomnessStateUpdate), - ConsensusCommitPrologueV2(ConsensusCommitPrologueV2), - ConsensusCommitPrologueV3(ConsensusCommitPrologueV3), } impl Serialize for TransactionKind { @@ -209,10 +196,9 @@ mod transaction_kind { Self::ProgrammableTransaction(k) => { ReadableTransactionKindRef::ProgrammableTransaction(k) } - Self::ChangeEpoch(k) => ReadableTransactionKindRef::ChangeEpoch(k), Self::Genesis(k) => ReadableTransactionKindRef::Genesis(k), - Self::ConsensusCommitPrologue(k) => { - ReadableTransactionKindRef::ConsensusCommitPrologue(k) + Self::ConsensusCommitPrologueV1(k) => { + ReadableTransactionKindRef::ConsensusCommitPrologueV1(k) } Self::AuthenticatorStateUpdate(k) => { ReadableTransactionKindRef::AuthenticatorStateUpdate(k) @@ -223,12 +209,6 @@ mod transaction_kind { Self::RandomnessStateUpdate(k) => { ReadableTransactionKindRef::RandomnessStateUpdate(k) } - Self::ConsensusCommitPrologueV2(k) => { - ReadableTransactionKindRef::ConsensusCommitPrologueV2(k) - } - Self::ConsensusCommitPrologueV3(k) => { - ReadableTransactionKindRef::ConsensusCommitPrologueV3(k) - } }; readable.serialize(serializer) } else { @@ -236,10 +216,9 @@ mod transaction_kind { Self::ProgrammableTransaction(k) => { BinaryTransactionKindRef::ProgrammableTransaction(k) } - Self::ChangeEpoch(k) => BinaryTransactionKindRef::ChangeEpoch(k), Self::Genesis(k) => BinaryTransactionKindRef::Genesis(k), - Self::ConsensusCommitPrologue(k) => { - BinaryTransactionKindRef::ConsensusCommitPrologue(k) + Self::ConsensusCommitPrologueV1(k) => { + BinaryTransactionKindRef::ConsensusCommitPrologueV1(k) } Self::AuthenticatorStateUpdate(k) => { BinaryTransactionKindRef::AuthenticatorStateUpdate(k) @@ -248,12 +227,6 @@ mod transaction_kind { Self::RandomnessStateUpdate(k) => { BinaryTransactionKindRef::RandomnessStateUpdate(k) } - Self::ConsensusCommitPrologueV2(k) => { - BinaryTransactionKindRef::ConsensusCommitPrologueV2(k) - } - Self::ConsensusCommitPrologueV3(k) => { - BinaryTransactionKindRef::ConsensusCommitPrologueV3(k) - } }; binary.serialize(serializer) } @@ -270,10 +243,9 @@ mod transaction_kind { ReadableTransactionKind::ProgrammableTransaction(k) => { Self::ProgrammableTransaction(k) } - ReadableTransactionKind::ChangeEpoch(k) => Self::ChangeEpoch(k), ReadableTransactionKind::Genesis(k) => Self::Genesis(k), - ReadableTransactionKind::ConsensusCommitPrologue(k) => { - Self::ConsensusCommitPrologue(k) + ReadableTransactionKind::ConsensusCommitPrologueV1(k) => { + Self::ConsensusCommitPrologueV1(k) } ReadableTransactionKind::AuthenticatorStateUpdate(k) => { Self::AuthenticatorStateUpdate(k) @@ -282,22 +254,15 @@ mod transaction_kind { ReadableTransactionKind::RandomnessStateUpdate(k) => { Self::RandomnessStateUpdate(k) } - ReadableTransactionKind::ConsensusCommitPrologueV2(k) => { - Self::ConsensusCommitPrologueV2(k) - } - ReadableTransactionKind::ConsensusCommitPrologueV3(k) => { - Self::ConsensusCommitPrologueV3(k) - } }) } else { BinaryTransactionKind::deserialize(deserializer).map(|binary| match binary { BinaryTransactionKind::ProgrammableTransaction(k) => { Self::ProgrammableTransaction(k) } - BinaryTransactionKind::ChangeEpoch(k) => Self::ChangeEpoch(k), BinaryTransactionKind::Genesis(k) => Self::Genesis(k), - BinaryTransactionKind::ConsensusCommitPrologue(k) => { - Self::ConsensusCommitPrologue(k) + BinaryTransactionKind::ConsensusCommitPrologueV1(k) => { + Self::ConsensusCommitPrologueV1(k) } BinaryTransactionKind::AuthenticatorStateUpdate(k) => { Self::AuthenticatorStateUpdate(k) @@ -306,12 +271,6 @@ mod transaction_kind { BinaryTransactionKind::RandomnessStateUpdate(k) => { Self::RandomnessStateUpdate(k) } - BinaryTransactionKind::ConsensusCommitPrologueV2(k) => { - Self::ConsensusCommitPrologueV2(k) - } - BinaryTransactionKind::ConsensusCommitPrologueV3(k) => { - Self::ConsensusCommitPrologueV3(k) - } }) } } @@ -331,7 +290,6 @@ mod end_of_epoch { ChangeEpoch(&'a ChangeEpoch), AuthenticatorStateCreate, AuthenticatorStateExpire(&'a AuthenticatorStateExpire), - RandomnessStateCreate, DenyListStateCreate, BridgeStateCreate { chain_id: &'a CheckpointDigest, @@ -348,7 +306,6 @@ mod end_of_epoch { ChangeEpoch(ChangeEpoch), AuthenticatorStateCreate, AuthenticatorStateExpire(AuthenticatorStateExpire), - RandomnessStateCreate, DenyListStateCreate, BridgeStateCreate { chain_id: CheckpointDigest, @@ -364,7 +321,6 @@ mod end_of_epoch { ChangeEpoch(&'a ChangeEpoch), AuthenticatorStateCreate, AuthenticatorStateExpire(&'a AuthenticatorStateExpire), - RandomnessStateCreate, DenyListStateCreate, BridgeStateCreate { chain_id: &'a CheckpointDigest }, BridgeCommitteeInit { bridge_object_version: u64 }, @@ -375,7 +331,6 @@ mod end_of_epoch { ChangeEpoch(ChangeEpoch), AuthenticatorStateCreate, AuthenticatorStateExpire(AuthenticatorStateExpire), - RandomnessStateCreate, DenyListStateCreate, BridgeStateCreate { chain_id: CheckpointDigest }, BridgeCommitteeInit { bridge_object_version: u64 }, @@ -395,9 +350,6 @@ mod end_of_epoch { Self::AuthenticatorStateExpire(k) => { ReadableEndOfEpochTransactionKindRef::AuthenticatorStateExpire(k) } - Self::RandomnessStateCreate => { - ReadableEndOfEpochTransactionKindRef::RandomnessStateCreate - } Self::DenyListStateCreate => { ReadableEndOfEpochTransactionKindRef::DenyListStateCreate } @@ -420,9 +372,6 @@ mod end_of_epoch { Self::AuthenticatorStateExpire(k) => { BinaryEndOfEpochTransactionKindRef::AuthenticatorStateExpire(k) } - Self::RandomnessStateCreate => { - BinaryEndOfEpochTransactionKindRef::RandomnessStateCreate - } Self::DenyListStateCreate => { BinaryEndOfEpochTransactionKindRef::DenyListStateCreate } @@ -455,9 +404,6 @@ mod end_of_epoch { ReadableEndOfEpochTransactionKind::AuthenticatorStateExpire(k) => { Self::AuthenticatorStateExpire(k) } - ReadableEndOfEpochTransactionKind::RandomnessStateCreate => { - Self::RandomnessStateCreate - } ReadableEndOfEpochTransactionKind::DenyListStateCreate => { Self::DenyListStateCreate } @@ -481,9 +427,6 @@ mod end_of_epoch { BinaryEndOfEpochTransactionKind::AuthenticatorStateExpire(k) => { Self::AuthenticatorStateExpire(k) } - BinaryEndOfEpochTransactionKind::RandomnessStateCreate => { - Self::RandomnessStateCreate - } BinaryEndOfEpochTransactionKind::DenyListStateCreate => { Self::DenyListStateCreate } @@ -1325,6 +1268,7 @@ mod test { } #[test] + #[ignore = "https://github.com/iotaledger/iota/issues/3475"] fn transaction_fixtures() { const GENESIS_TRANSACTION: &str = include_str!("fixtures/genesis-transaction"); const CONSENSUS_PROLOGUE: &str = "AAMAAAAAAAAAAAIAAAAAAAAAtkjHeocBAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAIAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABAAAAAAAAAAAAAAAAAAAAAA==";