1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137
#![doc = include_str!("../README.md")]
#![doc(
html_logo_url = "https://raw.githubusercontent.com/alloy-rs/core/main/assets/alloy.jpg",
html_favicon_url = "https://raw.githubusercontent.com/alloy-rs/core/main/assets/favicon.ico"
)]
#![cfg_attr(not(test), warn(unused_crate_dependencies))]
#![cfg_attr(docsrs, feature(doc_cfg, doc_auto_cfg))]
use alloy_consensus::TxReceipt;
use alloy_eips::eip2718::{Eip2718Envelope, Eip2718Error};
use alloy_json_rpc::RpcObject;
use alloy_primitives::{Address, TxHash, U256};
use core::fmt::{Debug, Display};
mod transaction;
pub use transaction::{
BuildResult, NetworkWallet, TransactionBuilder, TransactionBuilderError, TxSigner,
TxSignerSync, UnbuiltTransactionError,
};
mod ethereum;
pub use ethereum::{Ethereum, EthereumWallet};
mod any;
pub use any::AnyNetwork;
pub use alloy_eips::eip2718;
/// A receipt response.
///
/// This is distinct from [`TxReceipt`], since this is for JSON-RPC receipts.
///
/// [`TxReceipt`]: alloy_consensus::TxReceipt
pub trait ReceiptResponse {
/// Address of the created contract, or `None` if the transaction was not a deployment.
fn contract_address(&self) -> Option<Address>;
/// Status of the transaction.
///
/// ## Note
///
/// Caution must be taken when using this method for deep-historical
/// receipts, as it may not accurately reflect the status of the
/// transaction. The transaction status is not knowable from the receipt
/// for transactions before [EIP-658].
///
/// This can be handled using [`TxReceipt::status_or_post_state`].
///
/// [EIP-658]: https://eips.ethereum.org/EIPS/eip-658
/// [`TxReceipt::status_or_post_state`]: alloy_consensus::TxReceipt::status_or_post_state
fn status(&self) -> bool;
}
/// Transaction Response
///
/// This is distinct from [`Transaction`], since this is a JSON-RPC response.
///
/// [`Transaction`]: alloy_consensus::Transaction
pub trait TransactionResponse {
/// Hash of the transaction
#[doc(alias = "transaction_hash")]
fn tx_hash(&self) -> TxHash;
/// Sender of the transaction
fn from(&self) -> Address;
/// Recipient of the transaction
fn to(&self) -> Option<Address>;
/// Transferred value
fn value(&self) -> U256;
/// Gas limit
fn gas(&self) -> u128;
}
/// Captures type info for network-specific RPC requests/responses.
///
/// Networks are only containers for types, so it is recommended to use ZSTs for their definition.
// todo: block responses are ethereum only, so we need to include this in here too, or make `Block`
// generic over tx/header type
pub trait Network: Debug + Clone + Copy + Sized + Send + Sync + 'static {
// -- Consensus types --
/// The network transaction type enum.
///
/// This should be a simple `#[repr(u8)]` enum, and as such has strict type
/// bounds for better use in error messages, assertions etc.
#[doc(alias = "TransactionType")]
type TxType: Into<u8>
+ PartialEq
+ Eq
+ TryFrom<u8, Error = Eip2718Error>
+ Debug
+ Display
+ Clone
+ Copy
+ Send
+ Sync
+ 'static;
/// The network transaction envelope type.
#[doc(alias = "TransactionEnvelope")]
type TxEnvelope: Eip2718Envelope + Debug;
/// An enum over the various transaction types.
#[doc(alias = "UnsignedTransaction")]
type UnsignedTx: From<Self::TxEnvelope>;
/// The network receipt envelope type.
#[doc(alias = "TransactionReceiptEnvelope", alias = "TxReceiptEnvelope")]
type ReceiptEnvelope: Eip2718Envelope + TxReceipt;
/// The network header type.
type Header;
// -- JSON RPC types --
/// The JSON body of a transaction request.
#[doc(alias = "TxRequest")]
type TransactionRequest: RpcObject
+ TransactionBuilder<Self>
+ Debug
+ From<Self::TxEnvelope>
+ From<Self::UnsignedTx>;
/// The JSON body of a transaction response.
#[doc(alias = "TxResponse")]
type TransactionResponse: RpcObject + TransactionResponse;
/// The JSON body of a transaction receipt.
#[doc(alias = "TransactionReceiptResponse", alias = "TxReceiptResponse")]
type ReceiptResponse: RpcObject + ReceiptResponse;
/// The JSON body of a header response.
type HeaderResponse: RpcObject;
}