pub enum TransactionSpendingCondition {
    Singlesig(SinglesigSpendingCondition),
    Multisig(MultisigSpendingCondition),
}

Variants§

Implementations§

source§

impl TransactionSpendingCondition

source

pub fn new_singlesig_p2pkh( pubkey: Secp256k1PublicKey ) -> Option<TransactionSpendingCondition>

source

pub fn new_singlesig_p2wpkh( pubkey: Secp256k1PublicKey ) -> Option<TransactionSpendingCondition>

source

pub fn new_multisig_p2sh( num_sigs: u16, pubkeys: Vec<Secp256k1PublicKey> ) -> Option<TransactionSpendingCondition>

source

pub fn new_multisig_p2wsh( num_sigs: u16, pubkeys: Vec<Secp256k1PublicKey> ) -> Option<TransactionSpendingCondition>

source

pub fn new_initial_sighash() -> TransactionSpendingCondition

When committing to the fact that a transaction is sponsored, the origin doesn’t know anything else. Instead, it commits to this sentinel value as its sponsor. It is intractable to calculate a private key that could generate this.

source

pub fn num_signatures(&self) -> u16

source

pub fn signatures_required(&self) -> u16

source

pub fn nonce(&self) -> u64

source

pub fn tx_fee(&self) -> u64

source

pub fn set_nonce(&mut self, n: u64)

source

pub fn set_tx_fee(&mut self, tx_fee: u64)

source

pub fn get_tx_fee(&self) -> u64

source

pub fn address_mainnet(&self) -> StacksAddress

Get the mainnet account address of the spending condition

source

pub fn address_testnet(&self) -> StacksAddress

Get the mainnet account address of the spending condition

source

pub fn clear(&mut self)

Clear fee rate, nonces, signatures, and public keys

source

pub fn make_sighash_presign( cur_sighash: &Txid, cond_code: &TransactionAuthFlags, tx_fee: u64, nonce: u64 ) -> Txid

source

pub fn make_sighash_postsign( cur_sighash: &Txid, pubkey: &Secp256k1PublicKey, sig: &MessageSignature ) -> Txid

source

pub fn next_signature( cur_sighash: &Txid, cond_code: &TransactionAuthFlags, tx_fee: u64, nonce: u64, privk: &Secp256k1PrivateKey ) -> Result<(MessageSignature, Txid), Error>

Linear-complexity signing algorithm – we sign a rolling hash over all data committed to by the previous signer (instead of naively re-serializing the transaction each time), as well as over new data provided by this key (excluding its own public key or signature, which are authenticated by the spending condition’s key hash). Calculates and returns the next signature and sighash, which the subsequent private key must sign.

source

pub fn next_verification( cur_sighash: &Txid, cond_code: &TransactionAuthFlags, tx_fee: u64, nonce: u64, key_encoding: &TransactionPublicKeyEncoding, sig: &MessageSignature ) -> Result<(Secp256k1PublicKey, Txid), Error>

Linear-complexity verifying algorithm – we verify a rolling hash over all data committed to by order of signers (instead of re-serializing the tranasction each time). Calculates the next sighash and public key, which the next verifier must verify. Used by StacksTransaction::verify*

source

pub fn verify( &self, initial_sighash: &Txid, cond_code: &TransactionAuthFlags ) -> Result<Txid, Error>

Verify all signatures

Trait Implementations§

source§

impl Clone for TransactionSpendingCondition

source§

fn clone(&self) -> TransactionSpendingCondition

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for TransactionSpendingCondition

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
source§

impl<'de> Deserialize<'de> for TransactionSpendingCondition

source§

fn deserialize<__D>( __deserializer: __D ) -> Result<TransactionSpendingCondition, <__D as Deserializer<'de>>::Error>where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
source§

impl PartialEq for TransactionSpendingCondition

source§

fn eq(&self, other: &TransactionSpendingCondition) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl Serialize for TransactionSpendingCondition

source§

fn serialize<__S>( &self, __serializer: __S ) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
source§

impl StacksMessageCodec for TransactionSpendingCondition

source§

fn consensus_serialize<W>(&self, fd: &mut W) -> Result<(), Error>where W: Write,

serialize implementors should never error unless there is an underlying failure in writing to the fd
source§

fn consensus_deserialize<R>( fd: &mut R ) -> Result<TransactionSpendingCondition, Error>where R: Read,

§

fn serialize_to_vec(&self) -> Vec<u8> where Self: Sized,

Convenience for serialization to a vec. this function unwraps any underlying serialization error
source§

impl StructuralPartialEq for TransactionSpendingCondition

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
source§

impl<T, U> Into<U> for Twhere U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> Same for T

§

type Output = T

Should always be Self
source§

impl<T> ToOwned for Twhere T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for Twhere U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<V, T> VZip<V> for Twhere V: MultiLane<T>,

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more
source§

impl<T> DeserializeOwned for Twhere T: for<'de> Deserialize<'de>,