pub enum Transaction<P = NotPruned>where
P: PotentiallyPruned,{
V1 {
prefix: TransactionPrefix,
signatures: <P as PotentiallyPruned>::RingSignatures,
},
V2 {
prefix: TransactionPrefix,
proofs: Option<<P as PotentiallyPruned>::RctProofs>,
},
}Expand description
A Monero transaction.
Variants§
V1
A version 1 transaction, used by the original Cryptonote codebase.
Fields
prefix: TransactionPrefixThe transaction’s prefix.
signatures: <P as PotentiallyPruned>::RingSignaturesThe transaction’s ring signatures.
V2
A version 2 transaction, used by the RingCT protocol.
Fields
prefix: TransactionPrefixThe transaction’s prefix.
proofs: Option<<P as PotentiallyPruned>::RctProofs>The transaction’s proofs.
Implementations§
Source§impl<P> Transaction<P>where
P: PotentiallyPruned,
impl<P> Transaction<P>where
P: PotentiallyPruned,
Sourcepub fn prefix(&self) -> &TransactionPrefix
pub fn prefix(&self) -> &TransactionPrefix
Get the TransactionPrefix of this transaction.
Sourcepub fn prefix_mut(&mut self) -> &mut TransactionPrefix
pub fn prefix_mut(&mut self) -> &mut TransactionPrefix
Get a mutable reference to the TransactionPrefix of this transaction.
Sourcepub fn write<W>(&self, w: &mut W) -> Result<(), Error>where
W: Write,
pub fn write<W>(&self, w: &mut W) -> Result<(), Error>where
W: Write,
Write the Transaction.
Some writable transactions may not be readable if they’re malformed, per Monero’s consensus rules.
Sourcepub fn read<R>(r: &mut R) -> Result<Transaction<P>, Error>where
R: Read,
pub fn read<R>(r: &mut R) -> Result<Transaction<P>, Error>where
R: Read,
Read a Transaction.
This MAY error if miscellaneous Monero conseusus rules are broken, as useful when deserializing. The result is not guaranteed to follow all Monero consensus rules or any specific set of consensus rules.
Source§impl Transaction
impl Transaction
Sourcepub const NON_MINER_SIZE_UPPER_BOUND: UpperBound<usize>
pub const NON_MINER_SIZE_UPPER_BOUND: UpperBound<usize>
The maximum size for a non-miner transaction.
Sourcepub fn prunable_hash(&self) -> Option<[u8; 32]>
pub fn prunable_hash(&self) -> Option<[u8; 32]>
The prunable hash of the transaction.
This will return None for V1 transactions which do not have a well-defined prunable hash.
Sourcepub fn signature_hash(&self) -> Option<[u8; 32]>
pub fn signature_hash(&self) -> Option<[u8; 32]>
Calculate the hash of this transaction as needed for signing it.
This returns None if the transaction is without signatures.
Sourcepub fn pruned_with_prunable(self) -> (Transaction<Pruned>, Vec<u8>)
pub fn pruned_with_prunable(self) -> (Transaction<Pruned>, Vec<u8>)
Splits this transaction into its pruned and serialized prunable part.
Source§impl Transaction<Pruned>
impl Transaction<Pruned>
Sourcepub fn hash_with_prunable_hash(
&self,
prunable_hash: [u8; 32],
) -> Option<[u8; 32]>
pub fn hash_with_prunable_hash( &self, prunable_hash: [u8; 32], ) -> Option<[u8; 32]>
Return the hash of the pruned transaction.
This requires the transaction be version 2 and the hash of the pruned data be provided. If
the proofs are RctType::Null, prunable_hash MUST equal [0; 32] for the result to be
correct.
Trait Implementations§
Source§impl<P> Clone for Transaction<P>where
P: Clone + PotentiallyPruned,
<P as PotentiallyPruned>::RingSignatures: Clone,
<P as PotentiallyPruned>::RctProofs: Clone,
impl<P> Clone for Transaction<P>where
P: Clone + PotentiallyPruned,
<P as PotentiallyPruned>::RingSignatures: Clone,
<P as PotentiallyPruned>::RctProofs: Clone,
Source§fn clone(&self) -> Transaction<P>
fn clone(&self) -> Transaction<P>
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl<P> Debug for Transaction<P>where
P: Debug + PotentiallyPruned,
<P as PotentiallyPruned>::RingSignatures: Debug,
<P as PotentiallyPruned>::RctProofs: Debug,
impl<P> Debug for Transaction<P>where
P: Debug + PotentiallyPruned,
<P as PotentiallyPruned>::RingSignatures: Debug,
<P as PotentiallyPruned>::RctProofs: Debug,
Source§impl<P> Eq for Transaction<P>where
P: Eq + PotentiallyPruned,
<P as PotentiallyPruned>::RingSignatures: Eq,
<P as PotentiallyPruned>::RctProofs: Eq,
impl<P> Eq for Transaction<P>where
P: Eq + PotentiallyPruned,
<P as PotentiallyPruned>::RingSignatures: Eq,
<P as PotentiallyPruned>::RctProofs: Eq,
#[doc(hidden)] fn assert_receiver_is_total_eq(&self)
Source§impl From<Transaction> for Transaction<Pruned>
impl From<Transaction> for Transaction<Pruned>
Source§fn from(tx: Transaction) -> Transaction<Pruned>
fn from(tx: Transaction) -> Transaction<Pruned>
Source§impl<P> PartialEq for Transaction<P>where
P: PartialEq + PotentiallyPruned,
<P as PotentiallyPruned>::RingSignatures: PartialEq,
<P as PotentiallyPruned>::RctProofs: PartialEq,
impl<P> PartialEq for Transaction<P>where
P: PartialEq + PotentiallyPruned,
<P as PotentiallyPruned>::RingSignatures: PartialEq,
<P as PotentiallyPruned>::RctProofs: PartialEq,
Source§impl SignMachine<Transaction> for TransactionSignMachine
Available on crate feature multisig only.
impl SignMachine<Transaction> for TransactionSignMachine
multisig only.Source§type Params = ()
type Params = ()
Source§type Keys = ThresholdKeys<Ed25519>
type Keys = ThresholdKeys<Ed25519>
Source§type Preprocess = TransactionPreprocess
type Preprocess = TransactionPreprocess
Source§type SignatureMachine = TransactionSignatureMachine
type SignatureMachine = TransactionSignatureMachine
Source§fn cache(self) -> CachedPreprocess
fn cache(self) -> CachedPreprocess
Source§fn from_cache(
(): (),
_: ThresholdKeys<Ed25519>,
_: CachedPreprocess,
) -> (Self, Self::Preprocess)
fn from_cache( (): (), _: ThresholdKeys<Ed25519>, _: CachedPreprocess, ) -> (Self, Self::Preprocess)
Source§fn read_preprocess<R: Read>(&self, reader: &mut R) -> Result<Self::Preprocess>
fn read_preprocess<R: Read>(&self, reader: &mut R) -> Result<Self::Preprocess>
Source§fn sign(
self,
commitments: HashMap<Participant, Self::Preprocess>,
msg: &[u8],
) -> Result<(TransactionSignatureMachine, Self::SignatureShare), FrostError>
fn sign( self, commitments: HashMap<Participant, Self::Preprocess>, msg: &[u8], ) -> Result<(TransactionSignatureMachine, Self::SignatureShare), FrostError>
Source§impl SignatureMachine<Transaction> for TransactionSignatureMachine
Available on crate feature multisig only.
impl SignatureMachine<Transaction> for TransactionSignatureMachine
multisig only.Source§fn complete(
self,
shares: HashMap<Participant, Self::SignatureShare>,
) -> Result<Transaction, FrostError>
fn complete( self, shares: HashMap<Participant, Self::SignatureShare>, ) -> Result<Transaction, FrostError>
impl<P> StructuralPartialEq for Transaction<P>where
P: PotentiallyPruned,
Auto Trait Implementations§
impl<P> Freeze for Transaction<P>where
<P as PotentiallyPruned>::RingSignatures: Freeze,
<P as PotentiallyPruned>::RctProofs: Freeze,
impl<P> RefUnwindSafe for Transaction<P>where
<P as PotentiallyPruned>::RingSignatures: RefUnwindSafe,
<P as PotentiallyPruned>::RctProofs: RefUnwindSafe,
impl<P> Send for Transaction<P>
impl<P> Sync for Transaction<P>
impl<P> Unpin for Transaction<P>
impl<P> UnwindSafe for Transaction<P>where
<P as PotentiallyPruned>::RingSignatures: UnwindSafe,
<P as PotentiallyPruned>::RctProofs: UnwindSafe,
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> FmtForward for T
impl<T> FmtForward for T
Source§fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
self to use its Binary implementation when Debug-formatted.Source§fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
self to use its Display implementation when
Debug-formatted.Source§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
self to use its LowerExp implementation when
Debug-formatted.Source§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
self to use its LowerHex implementation when
Debug-formatted.Source§fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
self to use its Octal implementation when Debug-formatted.Source§fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
self to use its Pointer implementation when
Debug-formatted.Source§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
self to use its UpperExp implementation when
Debug-formatted.Source§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
self to use its UpperHex implementation when
Debug-formatted.Source§impl<A, B> IsEqualPrivate<B, Equal> for A
impl<A, B> IsEqualPrivate<B, Equal> for A
Source§impl<A, B> IsEqualPrivate<B, Greater> for A
impl<A, B> IsEqualPrivate<B, Greater> for A
Source§impl<A, B> IsEqualPrivate<B, Less> for A
impl<A, B> IsEqualPrivate<B, Less> for A
Source§impl<A, B> IsGreaterOrEqualPrivate<B, Equal> for A
impl<A, B> IsGreaterOrEqualPrivate<B, Equal> for A
Source§impl<A, B> IsGreaterOrEqualPrivate<B, Greater> for A
impl<A, B> IsGreaterOrEqualPrivate<B, Greater> for A
Source§impl<A, B> IsGreaterOrEqualPrivate<B, Less> for A
impl<A, B> IsGreaterOrEqualPrivate<B, Less> for A
Source§impl<A, B> IsGreaterPrivate<B, Equal> for A
impl<A, B> IsGreaterPrivate<B, Equal> for A
Source§impl<A, B> IsGreaterPrivate<B, Greater> for A
impl<A, B> IsGreaterPrivate<B, Greater> for A
Source§impl<A, B> IsGreaterPrivate<B, Less> for A
impl<A, B> IsGreaterPrivate<B, Less> for A
Source§impl<A, B> IsLessOrEqualPrivate<B, Equal> for A
impl<A, B> IsLessOrEqualPrivate<B, Equal> for A
Source§impl<A, B> IsLessOrEqualPrivate<B, Greater> for A
impl<A, B> IsLessOrEqualPrivate<B, Greater> for A
Source§impl<A, B> IsLessOrEqualPrivate<B, Less> for A
impl<A, B> IsLessOrEqualPrivate<B, Less> for A
Source§impl<A, B> IsLessPrivate<B, Equal> for A
impl<A, B> IsLessPrivate<B, Equal> for A
Source§impl<A, B> IsLessPrivate<B, Greater> for A
impl<A, B> IsLessPrivate<B, Greater> for A
Source§impl<A, B> IsLessPrivate<B, Less> for A
impl<A, B> IsLessPrivate<B, Less> for A
Source§impl<A, B> IsNotEqualPrivate<B, Equal> for A
impl<A, B> IsNotEqualPrivate<B, Equal> for A
Source§impl<A, B> IsNotEqualPrivate<B, Greater> for A
impl<A, B> IsNotEqualPrivate<B, Greater> for A
Source§impl<A, B> IsNotEqualPrivate<B, Less> for A
impl<A, B> IsNotEqualPrivate<B, Less> for A
Source§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
Source§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
Source§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
self and passes that borrow into the pipe function. Read moreSource§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
self and passes that borrow into the pipe function. Read moreSource§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
Source§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R,
) -> R
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
Source§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
self, then passes self.as_ref() into the pipe function.Source§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
self, then passes self.as_mut() into the pipe
function.Source§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
self, then passes self.deref() into the pipe function.Source§impl<T> SizedTypeProperties for T
impl<T> SizedTypeProperties for T
Source§#[doc(hidden)] const SIZE: usize = _
#[doc(hidden)] const SIZE: usize = _
sized_type_properties)Source§#[doc(hidden)] const ALIGN: usize = _
#[doc(hidden)] const ALIGN: usize = _
sized_type_properties)Source§#[doc(hidden)] const IS_ZST: bool = _
#[doc(hidden)] const IS_ZST: bool = _
sized_type_properties)Source§#[doc(hidden)] const LAYOUT: Layout = _
#[doc(hidden)] const LAYOUT: Layout = _
sized_type_properties)Source§#[doc(hidden)] const MAX_SLICE_LEN: usize = _
#[doc(hidden)] const MAX_SLICE_LEN: usize = _
sized_type_properties)[Self]. Read moreSource§impl<T> Tap for T
impl<T> Tap for T
Source§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Borrow<B> of a value. Read moreSource§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
BorrowMut<B> of a value. Read moreSource§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
AsRef<R> view of a value. Read moreSource§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
AsMut<R> view of a value. Read moreSource§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Deref::Target of a value. Read moreSource§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Deref::Target of a value. Read moreSource§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
.tap() only in debug builds, and is erased in release builds.Source§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
.tap_mut() only in debug builds, and is erased in release
builds.Source§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
.tap_borrow() only in debug builds, and is erased in release
builds.Source§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
.tap_borrow_mut() only in debug builds, and is erased in release
builds.Source§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
.tap_ref() only in debug builds, and is erased in release
builds.Source§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
.tap_ref_mut() only in debug builds, and is erased in release
builds.Source§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
.tap_deref() only in debug builds, and is erased in release
builds.