Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

AVM-1 No Gas Gharges for Failed Transactions #409

Open
SA124 opened this issue Aug 21, 2024 · 6 comments
Open

AVM-1 No Gas Gharges for Failed Transactions #409

SA124 opened this issue Aug 21, 2024 · 6 comments
Assignees
Labels
Source: Audit Issues discovered by audit. suzuka:safety

Comments

@SA124
Copy link

SA124 commented Aug 21, 2024

AVM-1 No Gas Gharges for Failed Transactions

Auditor: Movebit
Code: Aptos Core
Severity: Critical
Discovery Methods: Manual Review
Status: Pending
Code Location:
aptos-move/aptos-vm/src/aptos_vm.rs#1654
Descriptions:
Pre-processing checks are performed on transactions as they enter the mempool:
Screenshot 2024-08-21 at 10 47 18 AM

But the SEQUENCE_NUMBER_TOO_NEW error for transactions with sequence_number
greater than the current account.sequence_number is covered in the function. This is as
expected (because future transactions are also going into the pool pending.) But the too_new
error for transactions with sequence_number greater than the current
account.sequence_number is covered in the function. This is as expected (since future
transactions are also going into the transaction pool pending:

Screenshot 2024-08-21 at 10 47 51 AM
At this point the transaction goes to the mempool and is written to the DA. After that it will
read the transaction from DA and execute it when the code is as follows:

Screenshot 2024-08-21 at 10 48 21 AM
At this point, the transaction is still checked for the same things that are checked during
preprocessing.

Screenshot 2024-08-21 at 10 48 50 AM

In this case, the sequence_number is higher than the current sequence_number, resulting in
an error. However, the handling fee is deducted after this check is performed, so no handling
fee is deducted for the transaction. This issue can lead to DA of transactions, mempool
being dosed at 0 cost.
Suggestion:
It is suggested to refer to the design idea of aptos to do the pending processing for the
transaction whose sequence_number is larger than the current sequence_number.

@msjyryxdzzj
Copy link

We looked at the logic of the code fix in #542, and it was fixed for the same sequence_number too new, but it could still be attacked in the same way as the previous attack for a different sequence_number too new transaction.

@l-monninger
Copy link
Collaborator

@msjyryxdzzj What is your proposed attack? You cannot duplicate sequence numbers will not leave the mempool to the same node under #542?

This also became PR #722 (as it was ultimately signed). See the tests added therein for whether the issue is addressed.

@msjyryxdzzj
Copy link

Attacker sends a transaction with seq_number greater than the current seq_number
For example, if the current seq_number is 10, the attacker sends a transaction with a seq_number of 11,12,13,14... different seq_numbers to bypass the repair check.

@poetyellow
Copy link

I think the following issues still exist in the latest PR:

  1. An attacker sends transactions with sequence numbers 1, 3, and 8.
  2. Transaction 1 will execute correctly, while transactions 3 and 8 will fail without incurring any gas fees.
  3. Since transactions 3 and 8 have already been packaged and stored in Celestia, they will occupy some storage costs.
  4. The attacker can save invalid transactions in Celestia at no cost.

I have drawn a schematic diagram as follows:
企业微信截图_58c61afd-d869-44d8-9877-84e57e17f8ad

@l-monninger
Copy link
Collaborator

l-monninger commented Dec 3, 2024

@poetyellow yes, we are accepting that some transactions can enter out to the sequence number too new tolerance.

The reason we want some to enter as opposed to always simply requiring the next highest sequence number is that users should be able to have multiple transactions in flight.

When that tolerance is low, this prevents someone from running a particularly effective DOS. Your amortized cost for these transactions is $\frac{\text{Gas Fee}}{\text{Tolerance}}$. When tolerance is low, I would argue this is sufficiently sybil resistant.

Changing the gas charges requires modifications to Aptos Core execution ordering and fee statement processing which we did not want to introduce at the last. See #665 .

@poetyellow
Copy link

Got it

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Source: Audit Issues discovered by audit. suzuka:safety
Projects
None yet
Development

No branches or pull requests

5 participants