_section: Transactions @ _subsection: Types @ _heading: UnsignedTransaction @ An unsigned transaction represents a transaction that has not been signed and its values are flexible as long as they are not ambiguous. _property: unsignedTransaction.to => string<[Address](address)> The address this transaction is to. _property: unsignedTransaction.nonce => number The nonce of this transaction. _property: unsignedTransaction.gasLimit => [[BigNumberish]] The gas limit for this transaction. _property: unsignedTransaction.gasPrice => [[BigNumberish]] The gas price for this transaction. _property: unsignedTransaction.maxFeePerGas => [[BigNumberish]] The maximum fee per unit of gas for this transaction. _property: unsignedTransaction.maxPriorityFeePerGas => [[BigNumberish]] The maximum priority fee per unit of gas for this transaction. _property: unsignedTransaction.data => [[BytesLike]] The data for this transaction. _property: unsignedTransaction.value => [[BigNumberish]] The value (in wei) for this transaction. _property: unsignedTransaction.chainId => number The chain ID for this transaction. If the chain ID is 0 or null, then [[link-eip-155]] is disabled and legacy signing is used, unless overridden in a signature. _heading: Transaction @ A generic object to represent a transaction. _property: transaction.hash => string<[[DataHexString]]<32>> The transaction hash, which can be used as an identifier for //transaction//. This is the keccak256 of the serialized RLP encoded representation of //transaction//. _property: transaction.to => string<[Address](address)> The address //transaction// is to. _property: transaction.from => string<[Address](address)> The address //transaction// is from. _property: transaction.nonce => number The nonce for //transaction//. Each transaction sent to the network from an account includes this, which ensures the order and non-replayability of a transaction. This must be equal to the current number of transactions ever sent to the network by the **from** address. _property: transaction.gasLimit => [[BigNumber]] The gas limit for //transaction//. An account must have enough ether to cover the gas (at the specified **gasPrice**). Any unused gas is refunded at the end of the transaction, and if there is insufficient gas to complete execution, the effects of the transaction are reverted, but the gas is **fully consumed** and an out-of-gas error occurs. _property: transaction.gasPrice => null | [[BigNumber]] The price (in wei) per unit of gas for //transaction//. For [[link-eip-1559]] transactions, this will be null. _property: transaction.maxFeePerGas => [[BigNumber]] The maximum price (in wei) per unit of gas for //transaction//. For transactions that are not [[link-eip-1559]] transactions, this will be null. _property: transaction.maxPriorityFeePerGas => [[BigNumber]] The priority fee price (in wei) per unit of gas for //transaction//. For transactions that are not [[link-eip-1559]] transactions, this will be null. _property: transaction.data => [[BytesLike]] The data for //transaction//. In a contract this is the call data. _property: transaction.value => [[BigNumber]] The value (in wei) for //transaction//. _property: transaction.chainId => number The chain ID for //transaction//. This is used as part of [[link-eip-155]] to prevent replay attacks on different networks. For example, if a transaction was made on ropsten with an account also used on homestead, it would be possible for a transaction signed on ropsten to be executed on homestead, which is likely unintended. There are situations where replay may be desired, however these are very rare and it is almost always recommended to specify the chain ID. _property: transaction.r => string<[[DataHexString]]<32>> The r portion of the elliptic curve signatures for //transaction//. This is more accurately, the x coordinate of the point r (from which the y can be computed, along with v). _property: transaction.s => string<[[DataHexString]]<32>> The s portion of the elliptic curve signatures for //transaction//. _property: transaction.v => number The v portion of the elliptic curve signatures for //transaction//. This is used to refine which of the two possible points a given x-coordinate can have, and in [[link-eip-155]] is additionally used to encode the chain ID into the serialized transaction. _subsection: Functions @ _property: ethers.utils.accessListify(anAcceslistish) => [[providers-AccessList]] @ @SRC Normalizes the [[providers-AccessListish]] //anAccessListish// into an [[providers-AccessList]]. This is useful for other utility functions which wish to remain flexible as to the input parameter for access lists, such as when creating a [[Signer]] which needs to manipulate a possibly typed transaction envelope. _property: ethers.utils.parseTransaction(aBytesLike) => [[Transaction]] @ @SRC Parses the transaction properties from a serialized transaction. _property: ethers.utils.serializeTransaction(tx [ , signature ]) => string<[[DataHexString]]> @ @SRC Computes the serialized //transaction//, optionally serialized with the a //signature//. If //signature// is not present, the unsigned serialized transaction is returned, which can be used to compute the hash necessary to sign. This function uses [[link-eip-155]] if a chainId is provided, otherwise legacy serialization is used. It is **highly** recommended to always specify a //chainId//. If //signature// includes a chain ID (explicitly or implicitly by using an [[link-eip-155]] ``v`` or ``_vs``) it will be used to compute the chain ID. If there is a mismatch between the chain ID of //transaction// and //signature// an error is thrown.