Trait SignedTransaction

pub trait SignedTransaction:
    Send
    + Sync
    + Unpin
    + Clone
    + Debug
    + PartialEq
    + Eq
    + Hash
    + Encodable
    + Decodable
    + Encodable2718
    + Decodable2718
    + Transaction
    + MaybeSerde
    + InMemorySize
    + SignerRecoverable {
    // Required methods
    fn tx_hash(&self) -> &FixedBytes<32>;
    fn recover_signer_unchecked_with_buf(
        &self,
        buf: &mut Vec<u8>,
    ) -> Result<Address, RecoveryError>;

    // Provided methods
    fn is_broadcastable_in_full(&self) -> bool { ... }
    fn try_recover(&self) -> Result<Address, RecoveryError> { ... }
    fn try_recover_unchecked(&self) -> Result<Address, RecoveryError> { ... }
    fn recalculate_hash(&self) -> FixedBytes<32> { ... }
    fn try_clone_into_recovered(&self) -> Result<Recovered<Self>, RecoveryError> { ... }
    fn try_into_recovered(self) -> Result<Recovered<Self>, Self> { ... }
    fn into_recovered_unchecked(self) -> Result<Recovered<Self>, RecoveryError> { ... }
    fn with_signer(self, signer: Address) -> Recovered<Self> { ... }
    fn with_signer_ref(&self, signer: Address) -> Recovered<&Self> { ... }
}
Expand description

A signed transaction.

Required Methods§

fn tx_hash(&self) -> &FixedBytes<32>

Returns reference to transaction hash.

fn recover_signer_unchecked_with_buf( &self, buf: &mut Vec<u8>, ) -> Result<Address, RecoveryError>

Same as [SignerRecoverable::recover_signer_unchecked] but receives a buffer to operate on. This is used during batch recovery to avoid allocating a new buffer for each transaction.

Provided Methods§

fn is_broadcastable_in_full(&self) -> bool

Returns whether this transaction type can be broadcasted as full transaction over the network.

Some transactions are not broadcastable as objects and only allowed to be broadcasted as hashes, e.g. because they missing context (e.g. blob sidecar).

fn try_recover(&self) -> Result<Address, RecoveryError>

Recover signer from signature and hash.

Returns an error if the transaction’s signature is invalid.

fn try_recover_unchecked(&self) -> Result<Address, RecoveryError>

Recover signer from signature and hash without ensuring that the signature has a low s value.

Returns an error if the transaction’s signature is invalid.

fn recalculate_hash(&self) -> FixedBytes<32>

Calculate transaction hash, eip2728 transaction does not contain rlp header and start with tx type.

fn try_clone_into_recovered(&self) -> Result<Recovered<Self>, RecoveryError>

Tries to recover signer and return Recovered by cloning the type.

fn try_into_recovered(self) -> Result<Recovered<Self>, Self>

Tries to recover signer and return Recovered.

Returns Err(Self) if the transaction’s signature is invalid, see also [SignerRecoverable::recover_signer].

fn into_recovered_unchecked(self) -> Result<Recovered<Self>, RecoveryError>

👎Deprecated: Use try_into_recovered_unchecked instead

Consumes the type, recover signer and return Recovered without ensuring that the signature has a low s value (EIP-2).

Returns RecoveryError if the transaction’s signature is invalid.

fn with_signer(self, signer: Address) -> Recovered<Self>

Returns the Recovered transaction with the given sender.

Note: assumes the given signer is the signer of this transaction.

fn with_signer_ref(&self, signer: Address) -> Recovered<&Self>

Returns the Recovered transaction with the given signer, using a reference to self.

Note: assumes the given signer is the signer of this transaction.

Dyn Compatibility§

This trait is not dyn compatible.

In older versions of Rust, dyn compatibility was called "object safety", so this trait is not object safe.

Implementations on Foreign Types§

§

impl SignedTransaction for OpPooledTransaction

§

fn tx_hash(&self) -> &FixedBytes<32>

§

fn recover_signer_unchecked_with_buf( &self, buf: &mut Vec<u8>, ) -> Result<Address, RecoveryError>

§

impl SignedTransaction for OpTxEnvelope

§

fn tx_hash(&self) -> &FixedBytes<32>

§

fn recover_signer_unchecked_with_buf( &self, buf: &mut Vec<u8>, ) -> Result<Address, RecoveryError>

§

impl SignedTransaction for SeismicTxEnvelope

§

fn tx_hash(&self) -> &FixedBytes<32>

§

fn recover_signer_unchecked_with_buf( &self, buf: &mut Vec<u8>, ) -> Result<Address, RecoveryError>

§

impl<'a, T> SignedTransaction for &'a T
where T: 'a + SignedTransaction + ?Sized, &'a T: Send + Sync + Unpin + Clone + Debug + PartialEq + Eq + Hash + Encodable + Decodable + Encodable2718 + Decodable2718 + Transaction + MaybeSerde + InMemorySize + SignerRecoverable,

§

fn tx_hash(&self) -> &FixedBytes<32>

§

fn is_broadcastable_in_full(&self) -> bool

§

fn try_recover(&self) -> Result<Address, RecoveryError>

§

fn try_recover_unchecked(&self) -> Result<Address, RecoveryError>

§

fn recover_signer_unchecked_with_buf( &self, buf: &mut Vec<u8>, ) -> Result<Address, RecoveryError>

§

fn recalculate_hash(&self) -> FixedBytes<32>

§

impl<T> SignedTransaction for Arc<T>
where T: SignedTransaction + ?Sized, Arc<T>: Send + Sync + Unpin + Clone + Debug + PartialEq + Eq + Hash + Encodable + Decodable + Encodable2718 + Decodable2718 + Transaction + MaybeSerde + InMemorySize + SignerRecoverable,

§

fn tx_hash(&self) -> &FixedBytes<32>

§

fn is_broadcastable_in_full(&self) -> bool

§

fn try_recover(&self) -> Result<Address, RecoveryError>

§

fn try_recover_unchecked(&self) -> Result<Address, RecoveryError>

§

fn recover_signer_unchecked_with_buf( &self, buf: &mut Vec<u8>, ) -> Result<Address, RecoveryError>

§

fn recalculate_hash(&self) -> FixedBytes<32>

§

impl<T> SignedTransaction for EthereumTxEnvelope<T>
where T: RlpEcdsaEncodableTx + SignableTransaction<Signature> + Unpin, EthereumTxEnvelope<T>: Clone + PartialEq + Eq + Decodable + Decodable2718 + MaybeSerde + InMemorySize,

§

fn tx_hash(&self) -> &FixedBytes<32>

§

fn recover_signer_unchecked_with_buf( &self, buf: &mut Vec<u8>, ) -> Result<Address, RecoveryError>

Implementors§

§

impl<B, T> SignedTransaction for Extended<B, T>
where B: SignedTransaction + IsTyped2718, T: SignedTransaction,