Expirable Trainsaction
EIP-5081, titled "Expirable Trainsaction," proposes the introduction of a new transaction type that includes an expiration block number. The motivation behind this proposal is to address the issue of transactions with low gas prices that might not be executed immediately. Currently, there's no clean way to cancel such transactions, except for signing a new transaction with the same nonce but a higher gas fee, hoping it will preempt the original transaction. This method can be both unreliable and costly.
The proposal specifies that a new EIP-2718 transaction is introduced with a TransactionType that includes an expiration block number. If a transaction is not executed by the specified block number, it is considered expired and will not be processed.
The document also introduces a new execution state in EVM for these expirable transactions. The rationale behind this proposal is to prevent wastage of resources on transactions that are likely to fail due to changes in network conditions. The document mentions that there are no known backward compatibility issues associated with this proposal. The test cases, reference implementation, and security considerations are yet to be determined.
Video
Original
Abstract
This EIP adds a new transaction type of that includes expiration with a blocknum.
Motivation
When a user sends a transaction tx0
with a low gas price, sometimes it might not be high enough to be executed.
A common resolution is for the user to submit the transaction again with the same nonce and higher gas price.
That previous tx0
can theoretically be included in any time in the future unless a tx
with the exact same nonce is already executed.
When network is congested, gas price are high, for critical transactions user might try gas price that is much higher than an average day.
This cause the tx0
choose might be very easy to executed in the average day.
If user already uses a tx1
with different nonce or from another account to execute the intended transaction,
there is currently no clean way to cancel it,
except for signing a new tx0'
that shares the same nonce but with higher gas fee hoping that it will execute to preempt- than tx0
.
Given tx0
was already high gas price, the current way of preempting tx0
could be both unreliable and very costly.
TODO(@xinbenlv): to include in the motivation:
-
Expiring transactions are transactions that have low time preference, but can easily become invalid in the future. For example, you may want to do a swap on an AMM but you don't want to pay a very high fee for it so you set the max fee to a low number. However, your transaction will almost certainly fail if it takes longer than a couple minutes to be mined. In this scenario, you would rather fail cheaply if your transaction doesn't get included quickly.
-
Similarly, there are situations where there is a limited window of availability of some asset and if your transaction doesn't mine within that period you know with certainty that it will fail. In these cases, it would be nice to be able to express that to the system and not waste unnecessary resources just to have the transaction fail.
Specification
The key words “MUST”, “MUST NOT”, “REQUIRED”, “SHALL”, “SHALL NOT”, “SHOULD”, “SHOULD NOT”, “RECOMMENDED”, “MAY”, and “OPTIONAL” in this document are to be interpreted as described in RFC 2119.
Parameters
FORK_BLKNUM
=TBD
CHAIN_ID
=TBD
TX_TYPE
= TBD, > 0x02 (EIP-1559)
As of FORK_BLOCK_NUMBER
, a new EIP-2718 transaction is introduced with TransactionType
= TX_TYPE(TBD)
.
The intrinsic cost of the new transaction is inherited from EIP-2930, specifically 21000 + 16 * non-zero calldata bytes + 4 * zero calldata bytes + 1900 * access list storage key count + 2400 * access list address count
.
The EIP-2718 TransactionPayload
for this transaction is
rlp([chain_id, expire_by, nonce, max_priority_fee_per_gas, max_fee_per_gas, gas_limit, destination, amount, data, access_list, signature_y_parity, signature_r, signature_s])
The definition of expire_by
is a block number the latest possible block to
execute this transaction. Any block with a block number block_num > expire_by
MUST NOT execute this transaction.
The definitions of all other fields share the same meaning with EIP-1559
The signature_y_parity, signature_r, signature_s
elements of this transaction represent a secp256k1 signature over keccak256(0x02 || rlp([chain_id, expire_by, nonce, max_priority_fee_per_gas, max_fee_per_gas, gas_limit, destination, amount, data, access_list]))
.
The EIP-2718 ReceiptPayload
for this transaction is rlp([status, cumulative_transaction_gas_used, logs_bloom, logs])
.
Rationale
TODO
Backwards Compatibility
TODO
Security Considerations
-
If
current_block_num
is available, client MUST drop and stop propagating/broadcasting any transactions that has atransacton_type == TX_TYPE
ANDcurrent_block_num > expire_by
-
It is suggested but not required that a
currentBlockNum
SHOULD be made available to client. Any client doing PoW calculation on blocks expire tx or propagating such are essentially penalized for wasting of work, mitigating possible denial of service attack. -
It is suggested but not required that client SHOULD introduce a
gossip_ttl
in unit of block_num as a safe net so that it only propagate a tx ifcurrent_block_num + gossip_ttl <= expire_by
. Backward compatibility: for nodes that doesn't havecurrent_block_num
orgossip_ttl
available, they should be presume to be0
. -
It is suggested by not required that any propagating client SHOULD properly deduct the
gossip_ttl
based on the network environment it sees fit.
Copyright
Copyright and related rights waived via CC0.
Adopted by projects
Not miss a beat of EIPs' update?
Subscribe EIPs Fun to receive the latest updates of EIPs Good for Buidlers to follow up.
View all