Struct TransactionSigned
pub struct TransactionSigned {
pub hash: OnceLock<FixedBytes<32>>,
pub signature: PrimitiveSignature,
pub transaction: Transaction,
}
Expand description
Signed transaction.
Fields§
§hash: OnceLock<FixedBytes<32>>
Transaction hash
signature: PrimitiveSignature
The transaction signature values
transaction: Transaction
Raw transaction info
Implementations§
§impl TransactionSigned
impl TransactionSigned
pub fn new(
transaction: Transaction,
signature: PrimitiveSignature,
hash: FixedBytes<32>,
) -> TransactionSigned
pub fn new( transaction: Transaction, signature: PrimitiveSignature, hash: FixedBytes<32>, ) -> TransactionSigned
Creates a new signed transaction from the given parts.
pub fn new_unhashed(
transaction: Transaction,
signature: PrimitiveSignature,
) -> TransactionSigned
pub fn new_unhashed( transaction: Transaction, signature: PrimitiveSignature, ) -> TransactionSigned
Creates a new signed transaction from the given transaction and signature without the hash.
Note: this only calculates the hash on the first TransactionSigned::hash
call.
pub const fn transaction(&self) -> &Transaction
pub const fn transaction(&self) -> &Transaction
Transaction
pub fn try_into_pooled(self) -> Result<PooledTransaction, TransactionSigned>
pub fn try_into_pooled(self) -> Result<PooledTransaction, TransactionSigned>
Tries to convert a TransactionSigned
into a PooledTransaction
.
This function used as a helper to convert from a decoded p2p broadcast message to
PooledTransaction
. Since EIP4844 variants are disallowed to be broadcasted on
p2p, return an err if tx
is Transaction::Eip4844
.
pub fn try_into_pooled_eip4844(
self,
sidecar: BlobTransactionSidecar,
) -> Result<PooledTransaction, TransactionSigned>
pub fn try_into_pooled_eip4844( self, sidecar: BlobTransactionSidecar, ) -> Result<PooledTransaction, TransactionSigned>
Converts from an EIP-4844 RecoveredTx
to a
PooledTransactionsElementEcRecovered
with the given sidecar.
Returns an Err
containing the original TransactionSigned
if the transaction is not
EIP-4844.
pub fn hash(&self) -> FixedBytes<32>
pub fn hash(&self) -> FixedBytes<32>
Transaction hash. Used to identify transaction.
pub fn recover_signers<'a, T>(txes: T, num_txes: usize) -> Option<Vec<Address>>where
T: IntoParallelIterator<Item = &'a TransactionSigned> + IntoIterator<Item = &'a TransactionSigned> + Send,
pub fn recover_signers<'a, T>(txes: T, num_txes: usize) -> Option<Vec<Address>>where
T: IntoParallelIterator<Item = &'a TransactionSigned> + IntoIterator<Item = &'a TransactionSigned> + Send,
Recovers a list of signers from a transaction list iterator.
Returns None
, if some transaction’s signature is invalid, see also
Self::recover_signer
.
pub fn recover_signers_unchecked<'a, T>(
txes: T,
num_txes: usize,
) -> Option<Vec<Address>>where
T: IntoParallelIterator<Item = &'a TransactionSigned> + IntoIterator<Item = &'a TransactionSigned>,
pub fn recover_signers_unchecked<'a, T>(
txes: T,
num_txes: usize,
) -> Option<Vec<Address>>where
T: IntoParallelIterator<Item = &'a TransactionSigned> + IntoIterator<Item = &'a TransactionSigned>,
Recovers a list of signers from a transaction list iterator without ensuring that the
signature has a low s
value.
Returns None
, if some transaction’s signature is invalid, see also
Self::recover_signer_unchecked
.
pub const fn with_signer(self, signer: Address) -> RecoveredTx
pub const fn with_signer(self, signer: Address) -> RecoveredTx
Returns the RecoveredTx
transaction with the given sender.
pub fn into_ecrecovered(self) -> Option<RecoveredTx>
pub fn into_ecrecovered(self) -> Option<RecoveredTx>
Consumes the type, recover signer and return RecoveredTx
Returns None
if the transaction’s signature is invalid, see also Self::recover_signer
.
pub fn into_ecrecovered_unchecked(self) -> Option<RecoveredTx>
pub fn into_ecrecovered_unchecked(self) -> Option<RecoveredTx>
Consumes the type, recover signer and return RecoveredTx
without
ensuring that the signature has a low s
value (EIP-2).
Returns None
if the transaction’s signature is invalid, see also
Self::recover_signer_unchecked
.
pub fn try_into_ecrecovered_unchecked(
self,
) -> Result<RecoveredTx, TransactionSigned>
pub fn try_into_ecrecovered_unchecked( self, ) -> Result<RecoveredTx, TransactionSigned>
Tries to recover signer and return RecoveredTx
. without ensuring that
the signature has a low s
value (EIP-2).
Returns Err(Self)
if the transaction’s signature is invalid, see also
Self::recover_signer_unchecked
.
pub fn recalculate_hash(&self) -> FixedBytes<32>
pub fn recalculate_hash(&self) -> FixedBytes<32>
Calculate transaction hash, eip2728 transaction does not contain rlp header and start with tx type.
pub fn into_parts(self) -> (Transaction, PrimitiveSignature, FixedBytes<32>)
pub fn into_parts(self) -> (Transaction, PrimitiveSignature, FixedBytes<32>)
Splits the transaction into parts.
Methods from Deref<Target = Transaction>§
pub fn signature_hash(&self) -> FixedBytes<32>
pub fn signature_hash(&self) -> FixedBytes<32>
Heavy operation that return signature hash over rlp encoded transaction. It is only for signature signing or signer recovery.
pub fn blob_gas_used(&self) -> Option<u64>
pub fn blob_gas_used(&self) -> Option<u64>
Returns the blob gas used for all blobs of the EIP-4844 transaction if it is an EIP-4844 transaction.
This is the number of blobs times the
DATA_GAS_PER_BLOB
a single blob consumes.
pub fn effective_tip_per_gas(&self, base_fee: Option<u64>) -> Option<u128>
pub fn effective_tip_per_gas(&self, base_fee: Option<u64>) -> Option<u128>
Returns the effective miner gas tip cap (gasTipCap
) for the given base fee:
min(maxFeePerGas - baseFee, maxPriorityFeePerGas)
If the base fee is None
, the max_priority_fee_per_gas
, or gas price for non-EIP1559
transactions is returned.
Returns None
if the basefee is higher than the Transaction::max_fee_per_gas
.
pub fn encode_for_signing(&self, out: &mut dyn BufMut)
pub fn encode_for_signing(&self, out: &mut dyn BufMut)
This encodes the transaction without the signature, and is only suitable for creating a hash intended for signing.
pub fn eip2718_encode(
&self,
signature: &PrimitiveSignature,
out: &mut dyn BufMut,
)
pub fn eip2718_encode( &self, signature: &PrimitiveSignature, out: &mut dyn BufMut, )
Produces EIP-2718 encoding of the transaction
pub fn is_eip2930(&self) -> bool
pub fn is_eip2930(&self) -> bool
Returns true if the transaction is an EIP-2930 transaction.
pub fn is_eip1559(&self) -> bool
pub fn is_eip1559(&self) -> bool
Returns true if the transaction is an EIP-1559 transaction.
pub fn is_eip4844(&self) -> bool
pub fn is_eip4844(&self) -> bool
Returns true if the transaction is an EIP-4844 transaction.
pub fn is_eip7702(&self) -> bool
pub fn is_eip7702(&self) -> bool
Returns true if the transaction is an EIP-7702 transaction.
pub fn as_legacy(&self) -> Option<&TxLegacy>
pub fn as_legacy(&self) -> Option<&TxLegacy>
Returns the [TxLegacy
] variant if the transaction is a legacy transaction.
pub fn as_eip2930(&self) -> Option<&TxEip2930>
pub fn as_eip2930(&self) -> Option<&TxEip2930>
Returns the [TxEip2930
] variant if the transaction is an EIP-2930 transaction.
pub fn as_eip1559(&self) -> Option<&TxEip1559>
pub fn as_eip1559(&self) -> Option<&TxEip1559>
Returns the [TxEip1559
] variant if the transaction is an EIP-1559 transaction.
pub fn as_eip4844(&self) -> Option<&TxEip4844>
pub fn as_eip4844(&self) -> Option<&TxEip4844>
Returns the [TxEip4844
] variant if the transaction is an EIP-4844 transaction.
pub fn as_eip7702(&self) -> Option<&TxEip7702>
pub fn as_eip7702(&self) -> Option<&TxEip7702>
Returns the [TxEip7702
] variant if the transaction is an EIP-7702 transaction.
Trait Implementations§
§impl<'a> Arbitrary<'a> for TransactionSigned
Available on crate feature arbitrary
only.
impl<'a> Arbitrary<'a> for TransactionSigned
arbitrary
only.§fn arbitrary(u: &mut Unstructured<'a>) -> Result<TransactionSigned, Error>
fn arbitrary(u: &mut Unstructured<'a>) -> Result<TransactionSigned, Error>
Self
from the given unstructured data. Read more§fn arbitrary_take_rest(u: Unstructured<'a>) -> Result<Self, Error>
fn arbitrary_take_rest(u: Unstructured<'a>) -> Result<Self, Error>
Self
from the entirety of the given
unstructured data. Read more§fn size_hint(depth: usize) -> (usize, Option<usize>)
fn size_hint(depth: usize) -> (usize, Option<usize>)
Unstructured
this type
needs to construct itself. Read more§fn try_size_hint(
depth: usize,
) -> Result<(usize, Option<usize>), MaxRecursionReached>
fn try_size_hint( depth: usize, ) -> Result<(usize, Option<usize>), MaxRecursionReached>
Unstructured
this type
needs to construct itself. Read more§impl AsRef<Transaction> for TransactionSigned
impl AsRef<Transaction> for TransactionSigned
§fn as_ref(&self) -> &Transaction
fn as_ref(&self) -> &Transaction
§impl AsRef<TransactionSigned> for TransactionSigned
impl AsRef<TransactionSigned> for TransactionSigned
§fn as_ref(&self) -> &TransactionSigned
fn as_ref(&self) -> &TransactionSigned
§impl Clone for TransactionSigned
impl Clone for TransactionSigned
§fn clone(&self) -> TransactionSigned
fn clone(&self) -> TransactionSigned
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read more§impl Compact for TransactionSigned
Available on crate feature reth-codec
only.
impl Compact for TransactionSigned
reth-codec
only.§fn to_compact<B>(&self, buf: &mut B) -> usize
fn to_compact<B>(&self, buf: &mut B) -> usize
§fn from_compact(buf: &[u8], _len: usize) -> (TransactionSigned, &[u8])
fn from_compact(buf: &[u8], _len: usize) -> (TransactionSigned, &[u8])
buf
with its internal cursor
advanced (eg..advance(len)
). Read more§fn specialized_to_compact<B>(&self, buf: &mut B) -> usize
fn specialized_to_compact<B>(&self, buf: &mut B) -> usize
§fn specialized_from_compact(buf: &[u8], len: usize) -> (Self, &[u8])
fn specialized_from_compact(buf: &[u8], len: usize) -> (Self, &[u8])
Source§impl Compress for TransactionSigned
impl Compress for TransactionSigned
Source§type Compressed = Vec<u8>
type Compressed = Vec<u8>
Source§fn compress_to_buf<B>(self, buf: &mut B)
fn compress_to_buf<B>(self, buf: &mut B)
Source§fn uncompressable_ref(&self) -> Option<&[u8]>
fn uncompressable_ref(&self) -> Option<&[u8]>
Some(self.as_ref())
Source§fn compress(self) -> Self::Compressed
fn compress(self) -> Self::Compressed
§impl Debug for TransactionSigned
impl Debug for TransactionSigned
§impl Decodable for TransactionSigned
impl Decodable for TransactionSigned
§fn decode(buf: &mut &[u8]) -> Result<TransactionSigned, Error>
fn decode(buf: &mut &[u8]) -> Result<TransactionSigned, Error>
This Decodable
implementation only supports decoding rlp encoded transactions as it’s used
by p2p.
The p2p encoding format always includes an RLP header, although the type RLP header depends on whether or not the transaction is a legacy transaction.
If the transaction is a legacy transaction, it is just encoded as a RLP list:
rlp(tx-data)
.
If the transaction is a typed transaction, it is encoded as a RLP string:
rlp(tx-type || rlp(tx-data))
This can be used for decoding all signed transactions in p2p BlockBodies
responses.
This cannot be used for decoding EIP-4844 transactions in p2p PooledTransactions
, since
the EIP-4844 variant of TransactionSigned
does not include the blob sidecar.
For a method suitable for decoding pooled transactions, see PooledTransaction
.
CAUTION: Due to a quirk in [Header::decode
], this method will succeed even if a typed
transaction is encoded in this format, and does not start with a RLP header:
tx-type || rlp(tx-data)
.
This is because [Header::decode
] does not advance the buffer, and returns a length-1
string header if the first byte is less than 0xf7
.
§impl Decodable2718 for TransactionSigned
impl Decodable2718 for TransactionSigned
§fn typed_decode(
ty: u8,
buf: &mut &[u8],
) -> Result<TransactionSigned, Eip2718Error>
fn typed_decode( ty: u8, buf: &mut &[u8], ) -> Result<TransactionSigned, Eip2718Error>
§fn fallback_decode(buf: &mut &[u8]) -> Result<TransactionSigned, Eip2718Error>
fn fallback_decode(buf: &mut &[u8]) -> Result<TransactionSigned, Eip2718Error>
§fn extract_type_byte(buf: &mut &[u8]) -> Option<u8>
fn extract_type_byte(buf: &mut &[u8]) -> Option<u8>
§fn decode_2718(buf: &mut &[u8]) -> Result<Self, Eip2718Error>
fn decode_2718(buf: &mut &[u8]) -> Result<Self, Eip2718Error>
Source§impl Decompress for TransactionSigned
impl Decompress for TransactionSigned
Source§fn decompress(value: &[u8]) -> Result<TransactionSigned, DatabaseError>
fn decompress(value: &[u8]) -> Result<TransactionSigned, DatabaseError>
Source§fn decompress_owned(value: Vec<u8>) -> Result<Self, DatabaseError>
fn decompress_owned(value: Vec<u8>) -> Result<Self, DatabaseError>
§impl Default for TransactionSigned
impl Default for TransactionSigned
§fn default() -> TransactionSigned
fn default() -> TransactionSigned
§impl Deref for TransactionSigned
impl Deref for TransactionSigned
§type Target = Transaction
type Target = Transaction
§fn deref(&self) -> &<TransactionSigned as Deref>::Target
fn deref(&self) -> &<TransactionSigned as Deref>::Target
§impl<'de> Deserialize<'de> for TransactionSigned
impl<'de> Deserialize<'de> for TransactionSigned
§fn deserialize<__D>(
__deserializer: __D,
) -> Result<TransactionSigned, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(
__deserializer: __D,
) -> Result<TransactionSigned, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
§impl<'de> DeserializeAs<'de, TransactionSigned> for TransactionSigned<'de>
impl<'de> DeserializeAs<'de, TransactionSigned> for TransactionSigned<'de>
§fn deserialize_as<D>(
deserializer: D,
) -> Result<TransactionSigned, <D as Deserializer<'de>>::Error>where
D: Deserializer<'de>,
fn deserialize_as<D>(
deserializer: D,
) -> Result<TransactionSigned, <D as Deserializer<'de>>::Error>where
D: Deserializer<'de>,
§impl Encodable for TransactionSigned
impl Encodable for TransactionSigned
§fn encode(&self, out: &mut dyn BufMut)
fn encode(&self, out: &mut dyn BufMut)
This encodes the transaction with the signature, and an rlp header.
For legacy transactions, it encodes the transaction data:
rlp(tx-data)
For EIP-2718 typed transactions, it encodes the transaction type followed by the rlp of the
transaction:
rlp(tx-type || rlp(tx-data))
§impl Encodable2718 for TransactionSigned
impl Encodable2718 for TransactionSigned
§fn encode_2718_len(&self) -> usize
fn encode_2718_len(&self) -> usize
§fn encode_2718(&self, out: &mut dyn BufMut)
fn encode_2718(&self, out: &mut dyn BufMut)
§fn trie_hash(&self) -> FixedBytes<32>
fn trie_hash(&self) -> FixedBytes<32>
§fn encoded_2718(&self) -> Vec<u8> ⓘ
fn encoded_2718(&self) -> Vec<u8> ⓘ
§fn network_len(&self) -> usize
fn network_len(&self) -> usize
§fn network_encode(&self, out: &mut dyn BufMut)
fn network_encode(&self, out: &mut dyn BufMut)
§impl FillTxEnv for TransactionSigned
impl FillTxEnv for TransactionSigned
§impl FillTxEnv for TransactionSigned
impl FillTxEnv for TransactionSigned
§impl<'a> From<&'a TransactionSigned> for TransactionSigned<'a>
impl<'a> From<&'a TransactionSigned> for TransactionSigned<'a>
§fn from(value: &'a TransactionSigned) -> TransactionSigned<'a>
fn from(value: &'a TransactionSigned) -> TransactionSigned<'a>
§impl From<PooledTransaction> for TransactionSigned
impl From<PooledTransaction> for TransactionSigned
§fn from(tx: PooledTransaction) -> TransactionSigned
fn from(tx: PooledTransaction) -> TransactionSigned
§impl From<RecoveredTx<PooledTransaction>> for TransactionSigned
impl From<RecoveredTx<PooledTransaction>> for TransactionSigned
§fn from(recovered: RecoveredTx<PooledTransaction>) -> TransactionSigned
fn from(recovered: RecoveredTx<PooledTransaction>) -> TransactionSigned
§impl From<RecoveredTx> for TransactionSigned
impl From<RecoveredTx> for TransactionSigned
§fn from(recovered: RecoveredTx) -> TransactionSigned
fn from(recovered: RecoveredTx) -> TransactionSigned
§impl From<Signed<Transaction>> for TransactionSigned
impl From<Signed<Transaction>> for TransactionSigned
§fn from(value: Signed<Transaction>) -> TransactionSigned
fn from(value: Signed<Transaction>) -> TransactionSigned
§impl From<Signed<TxEip1559>> for TransactionSigned
impl From<Signed<TxEip1559>> for TransactionSigned
§fn from(value: Signed<TxEip1559>) -> TransactionSigned
fn from(value: Signed<TxEip1559>) -> TransactionSigned
§impl From<Signed<TxEip2930>> for TransactionSigned
impl From<Signed<TxEip2930>> for TransactionSigned
§fn from(value: Signed<TxEip2930>) -> TransactionSigned
fn from(value: Signed<TxEip2930>) -> TransactionSigned
§impl From<Signed<TxEip4844>> for TransactionSigned
impl From<Signed<TxEip4844>> for TransactionSigned
§fn from(value: Signed<TxEip4844>) -> TransactionSigned
fn from(value: Signed<TxEip4844>) -> TransactionSigned
§impl From<Signed<TxEip4844WithSidecar>> for TransactionSigned
impl From<Signed<TxEip4844WithSidecar>> for TransactionSigned
§fn from(value: Signed<TxEip4844WithSidecar>) -> TransactionSigned
fn from(value: Signed<TxEip4844WithSidecar>) -> TransactionSigned
§impl From<Signed<TxEip7702>> for TransactionSigned
impl From<Signed<TxEip7702>> for TransactionSigned
§fn from(value: Signed<TxEip7702>) -> TransactionSigned
fn from(value: Signed<TxEip7702>) -> TransactionSigned
§impl From<Signed<TxLegacy>> for TransactionSigned
impl From<Signed<TxLegacy>> for TransactionSigned
§fn from(value: Signed<TxLegacy>) -> TransactionSigned
fn from(value: Signed<TxLegacy>) -> TransactionSigned
§impl From<Signed<TypedTransaction>> for TransactionSigned
impl From<Signed<TypedTransaction>> for TransactionSigned
§fn from(value: Signed<TypedTransaction>) -> TransactionSigned
fn from(value: Signed<TypedTransaction>) -> TransactionSigned
§impl<'a> From<TransactionSigned<'a>> for TransactionSigned
impl<'a> From<TransactionSigned<'a>> for TransactionSigned
§fn from(value: TransactionSigned<'a>) -> TransactionSigned
fn from(value: TransactionSigned<'a>) -> TransactionSigned
§impl From<TransactionSigned> for Signed<Transaction>
impl From<TransactionSigned> for Signed<Transaction>
§fn from(value: TransactionSigned) -> Signed<Transaction>
fn from(value: TransactionSigned) -> Signed<Transaction>
§impl Hash for TransactionSigned
impl Hash for TransactionSigned
§impl InMemorySize for TransactionSigned
impl InMemorySize for TransactionSigned
§fn size(&self) -> usize
fn size(&self) -> usize
Calculate a heuristic for the in-memory size of the TransactionSigned
.
§impl PartialEq for TransactionSigned
impl PartialEq for TransactionSigned
§impl SerdeBincodeCompat for TransactionSigned
impl SerdeBincodeCompat for TransactionSigned
§type BincodeRepr<'a> = TransactionSigned<'a>
type BincodeRepr<'a> = TransactionSigned<'a>
§impl Serialize for TransactionSigned
impl Serialize for TransactionSigned
§fn serialize<__S>(
&self,
__serializer: __S,
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
__S: Serializer,
fn serialize<__S>(
&self,
__serializer: __S,
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
__S: Serializer,
§impl SerializeAs<TransactionSigned> for TransactionSigned<'_>
impl SerializeAs<TransactionSigned> for TransactionSigned<'_>
§fn serialize_as<S>(
source: &TransactionSigned,
serializer: S,
) -> Result<<S as Serializer>::Ok, <S as Serializer>::Error>where
S: Serializer,
fn serialize_as<S>(
source: &TransactionSigned,
serializer: S,
) -> Result<<S as Serializer>::Ok, <S as Serializer>::Error>where
S: Serializer,
§impl SignedTransaction for TransactionSigned
impl SignedTransaction for TransactionSigned
§fn tx_hash(&self) -> &FixedBytes<32>
fn tx_hash(&self) -> &FixedBytes<32>
§fn signature(&self) -> &PrimitiveSignature
fn signature(&self) -> &PrimitiveSignature
§fn recover_signer(&self) -> Option<Address>
fn recover_signer(&self) -> Option<Address>
§fn recover_signer_unchecked_with_buf(
&self,
buf: &mut Vec<u8>,
) -> Option<Address>
fn recover_signer_unchecked_with_buf( &self, buf: &mut Vec<u8>, ) -> Option<Address>
Self::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.§fn is_broadcastable_in_full(&self) -> bool
fn is_broadcastable_in_full(&self) -> bool
§fn recover_signer_unchecked(&self) -> Option<Address>
fn recover_signer_unchecked(&self) -> Option<Address>
s
value. Read more§fn recalculate_hash(&self) -> FixedBytes<32>
fn recalculate_hash(&self) -> FixedBytes<32>
§impl Transaction for TransactionSigned
impl Transaction for TransactionSigned
§fn max_fee_per_gas(&self) -> u128
fn max_fee_per_gas(&self) -> u128
§fn max_priority_fee_per_gas(&self) -> Option<u128>
fn max_priority_fee_per_gas(&self) -> Option<u128>
§fn max_fee_per_blob_gas(&self) -> Option<u128>
fn max_fee_per_blob_gas(&self) -> Option<u128>
§fn priority_fee_or_price(&self) -> u128
fn priority_fee_or_price(&self) -> u128
§fn effective_gas_price(&self, base_fee: Option<u64>) -> u128
fn effective_gas_price(&self, base_fee: Option<u64>) -> u128
§fn is_dynamic_fee(&self) -> bool
fn is_dynamic_fee(&self) -> bool
true
if the transaction supports dynamic fees.§fn is_create(&self) -> bool
fn is_create(&self) -> bool
kind
as it copies the 21-byte
TxKind
for this simple check. A proper implementation shouldn’t allocate.§fn access_list(&self) -> Option<&AccessList>
fn access_list(&self) -> Option<&AccessList>
access_list
for the particular transaction type. Returns None
for
older transaction types.§fn blob_versioned_hashes(&self) -> Option<&[FixedBytes<32>]>
fn blob_versioned_hashes(&self) -> Option<&[FixedBytes<32>]>
None
.SignedAuthorization
list of the transaction. Read more§fn effective_tip_per_gas(&self, base_fee: u64) -> Option<u128>
fn effective_tip_per_gas(&self, base_fee: u64) -> Option<u128>
§fn to(&self) -> Option<Address>
fn to(&self) -> Option<Address>
§fn blob_gas_used(&self) -> Option<u64>
fn blob_gas_used(&self) -> Option<u64>
§impl TryFrom<TransactionSigned> for PooledTransaction
impl TryFrom<TransactionSigned> for PooledTransaction
§type Error = TransactionConversionError
type Error = TransactionConversionError
§fn try_from(
tx: TransactionSigned,
) -> Result<PooledTransaction, <PooledTransaction as TryFrom<TransactionSigned>>::Error>
fn try_from( tx: TransactionSigned, ) -> Result<PooledTransaction, <PooledTransaction as TryFrom<TransactionSigned>>::Error>
§impl TryFrom<WithOtherFields<Transaction<AnyTxEnvelope>>> for TransactionSigned
impl TryFrom<WithOtherFields<Transaction<AnyTxEnvelope>>> for TransactionSigned
§type Error = ConversionError
type Error = ConversionError
§fn try_from(
tx: WithOtherFields<Transaction<AnyTxEnvelope>>,
) -> Result<TransactionSigned, <TransactionSigned as TryFrom<WithOtherFields<Transaction<AnyTxEnvelope>>>>::Error>
fn try_from( tx: WithOtherFields<Transaction<AnyTxEnvelope>>, ) -> Result<TransactionSigned, <TransactionSigned as TryFrom<WithOtherFields<Transaction<AnyTxEnvelope>>>>::Error>
§impl Typed2718 for TransactionSigned
impl Typed2718 for TransactionSigned
§fn is_eip2930(&self) -> bool
fn is_eip2930(&self) -> bool
§fn is_eip1559(&self) -> bool
fn is_eip1559(&self) -> bool
§fn is_eip4844(&self) -> bool
fn is_eip4844(&self) -> bool
§fn is_eip7702(&self) -> bool
fn is_eip7702(&self) -> bool
impl Eq for TransactionSigned
Auto Trait Implementations§
impl !Freeze for TransactionSigned
impl RefUnwindSafe for TransactionSigned
impl Send for TransactionSigned
impl Sync for TransactionSigned
impl Unpin for TransactionSigned
impl UnwindSafe for TransactionSigned
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,
§impl<T> Conv for T
impl<T> Conv for T
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.§impl<T> FmtForward for T
impl<T> FmtForward for T
§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.§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.§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.§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.§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.§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.§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.§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.§fn fmt_list(self) -> FmtList<Self>where
&'a Self: for<'a> IntoIterator,
fn fmt_list(self) -> FmtList<Self>where
&'a Self: for<'a> IntoIterator,
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
Source§fn in_current_span(self) -> Instrumented<Self> ⓘ
fn in_current_span(self) -> Instrumented<Self> ⓘ
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more§impl<T> Paint for Twhere
T: ?Sized,
impl<T> Paint for Twhere
T: ?Sized,
§fn fg(&self, value: Color) -> Painted<&T>
fn fg(&self, value: Color) -> Painted<&T>
Returns a styled value derived from self
with the foreground set to
value
.
This method should be used rarely. Instead, prefer to use color-specific
builder methods like red()
and
green()
, which have the same functionality but are
pithier.
§Example
Set foreground color to white using fg()
:
use yansi::{Paint, Color};
painted.fg(Color::White);
Set foreground color to white using white()
.
use yansi::Paint;
painted.white();
§fn bright_black(&self) -> Painted<&T>
fn bright_black(&self) -> Painted<&T>
§fn bright_red(&self) -> Painted<&T>
fn bright_red(&self) -> Painted<&T>
§fn bright_green(&self) -> Painted<&T>
fn bright_green(&self) -> Painted<&T>
§fn bright_yellow(&self) -> Painted<&T>
fn bright_yellow(&self) -> Painted<&T>
§fn bright_blue(&self) -> Painted<&T>
fn bright_blue(&self) -> Painted<&T>
§fn bright_magenta(&self) -> Painted<&T>
fn bright_magenta(&self) -> Painted<&T>
§fn bright_cyan(&self) -> Painted<&T>
fn bright_cyan(&self) -> Painted<&T>
§fn bright_white(&self) -> Painted<&T>
fn bright_white(&self) -> Painted<&T>
§fn bg(&self, value: Color) -> Painted<&T>
fn bg(&self, value: Color) -> Painted<&T>
Returns a styled value derived from self
with the background set to
value
.
This method should be used rarely. Instead, prefer to use color-specific
builder methods like on_red()
and
on_green()
, which have the same functionality but
are pithier.
§Example
Set background color to red using fg()
:
use yansi::{Paint, Color};
painted.bg(Color::Red);
Set background color to red using on_red()
.
use yansi::Paint;
painted.on_red();
§fn on_primary(&self) -> Painted<&T>
fn on_primary(&self) -> Painted<&T>
§fn on_magenta(&self) -> Painted<&T>
fn on_magenta(&self) -> Painted<&T>
§fn on_bright_black(&self) -> Painted<&T>
fn on_bright_black(&self) -> Painted<&T>
§fn on_bright_red(&self) -> Painted<&T>
fn on_bright_red(&self) -> Painted<&T>
§fn on_bright_green(&self) -> Painted<&T>
fn on_bright_green(&self) -> Painted<&T>
§fn on_bright_yellow(&self) -> Painted<&T>
fn on_bright_yellow(&self) -> Painted<&T>
§fn on_bright_blue(&self) -> Painted<&T>
fn on_bright_blue(&self) -> Painted<&T>
§fn on_bright_magenta(&self) -> Painted<&T>
fn on_bright_magenta(&self) -> Painted<&T>
§fn on_bright_cyan(&self) -> Painted<&T>
fn on_bright_cyan(&self) -> Painted<&T>
§fn on_bright_white(&self) -> Painted<&T>
fn on_bright_white(&self) -> Painted<&T>
§fn attr(&self, value: Attribute) -> Painted<&T>
fn attr(&self, value: Attribute) -> Painted<&T>
Enables the styling [Attribute
] value
.
This method should be used rarely. Instead, prefer to use
attribute-specific builder methods like bold()
and
underline()
, which have the same functionality
but are pithier.
§Example
Make text bold using attr()
:
use yansi::{Paint, Attribute};
painted.attr(Attribute::Bold);
Make text bold using using bold()
.
use yansi::Paint;
painted.bold();
§fn rapid_blink(&self) -> Painted<&T>
fn rapid_blink(&self) -> Painted<&T>
§fn quirk(&self, value: Quirk) -> Painted<&T>
fn quirk(&self, value: Quirk) -> Painted<&T>
Enables the yansi
[Quirk
] value
.
This method should be used rarely. Instead, prefer to use quirk-specific
builder methods like mask()
and
wrap()
, which have the same functionality but are
pithier.
§Example
Enable wrapping using .quirk()
:
use yansi::{Paint, Quirk};
painted.quirk(Quirk::Wrap);
Enable wrapping using wrap()
.
use yansi::Paint;
painted.wrap();
§fn clear(&self) -> Painted<&T>
👎Deprecated since 1.0.1: renamed to resetting()
due to conflicts with Vec::clear()
.
The clear()
method will be removed in a future release.
fn clear(&self) -> Painted<&T>
resetting()
due to conflicts with Vec::clear()
.
The clear()
method will be removed in a future release.§fn whenever(&self, value: Condition) -> Painted<&T>
fn whenever(&self, value: Condition) -> Painted<&T>
Conditionally enable styling based on whether the [Condition
] value
applies. Replaces any previous condition.
See the crate level docs for more details.
§Example
Enable styling painted
only when both stdout
and stderr
are TTYs:
use yansi::{Paint, Condition};
painted.red().on_yellow().whenever(Condition::STDOUTERR_ARE_TTY);
§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
§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 more§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 more§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
§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
§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.§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.§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.§impl<T> Pointable for T
impl<T> Pointable for T
§impl<T> PolicyExt for Twhere
T: ?Sized,
impl<T> PolicyExt for Twhere
T: ?Sized,
§impl<T> SignedTransactionIntoRecoveredExt for Twhere
T: SignedTransaction,
impl<T> SignedTransactionIntoRecoveredExt for Twhere
T: SignedTransaction,
§fn try_ecrecovered(&self) -> Option<RecoveredTx<Self>>
fn try_ecrecovered(&self) -> Option<RecoveredTx<Self>>
RecoveredTx
by cloning the type.§fn try_into_ecrecovered(self) -> Result<RecoveredTx<Self>, Self>
fn try_into_ecrecovered(self) -> Result<RecoveredTx<Self>, Self>
RecoveredTx
. Read more§fn into_ecrecovered_unchecked(self) -> Option<RecoveredTx<Self>>
fn into_ecrecovered_unchecked(self) -> Option<RecoveredTx<Self>>
RecoveredTx
without
ensuring that the signature has a low s
value (EIP-2). Read more§fn with_signer(self, signer: Address) -> RecoveredTx<Self>
fn with_signer(self, signer: Address) -> RecoveredTx<Self>
RecoveredTx
transaction with the given sender.§impl<T> Tap for T
impl<T> Tap for T
§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 more§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 more§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 more§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 more§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 more§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 more§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.§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.§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.§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.§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.§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.§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.§impl<T> TryConv for T
impl<T> TryConv for T
§impl<T> WithSubscriber for T
impl<T> WithSubscriber for T
§fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self> ⓘwhere
S: Into<Dispatch>,
fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self> ⓘwhere
S: Into<Dispatch>,
§fn with_current_subscriber(self) -> WithDispatch<Self> ⓘ
fn with_current_subscriber(self) -> WithDispatch<Self> ⓘ
Source§impl<T> WithSubscriber for T
impl<T> WithSubscriber for T
Source§fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self> ⓘwhere
S: Into<Dispatch>,
fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self> ⓘwhere
S: Into<Dispatch>,
Source§fn with_current_subscriber(self) -> WithDispatch<Self> ⓘ
fn with_current_subscriber(self) -> WithDispatch<Self> ⓘ
impl<A> ArbInterop for A
impl<T> DeserializeOwned for Twhere
T: for<'de> Deserialize<'de>,
impl<T> Eip2718Envelope for Twhere
T: Decodable2718 + Encodable2718,
impl<T> ErasedDestructor for Twhere
T: 'static,
impl<T> FullSignedTx for T
impl<T> FullTransaction for Twhere
T: Transaction + MaybeCompact,
impl<T> MaybeCompact for Twhere
T: Compact,
impl<T> MaybeDebug for Twhere
T: Debug,
impl<T> MaybeSend for Twhere
T: Send,
impl<T> MaybeSendSync for T
impl<T> MaybeSerde for Twhere
T: Serialize + for<'de> Deserialize<'de>,
impl<T> MaybeSerdeBincodeCompat for Twhere
T: SerdeBincodeCompat,
impl<T> NippyJarHeader for T
impl<T> RpcObject for Twhere
T: RpcParam + RpcReturn,
impl<T> RpcParam for T
impl<T> RpcReturn for T
impl<T> Transaction for Twhere
T: Send + Sync + Unpin + Clone + Debug + Eq + PartialEq + Hash + Transaction + InMemorySize + MaybeSerde,
impl<T> Value for T
Layout§
Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...)
attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.
Size: 336 bytes