Skip to content
This repository has been archived by the owner on Jan 22, 2025. It is now read-only.

[experimental] Decoding and then re-compiling a transaction invalidates existing signatures #2362

Closed
mcintyre94 opened this issue Mar 22, 2024 · 4 comments · Fixed by #2387
Closed
Assignees
Labels
bug Something isn't working released

Comments

@mcintyre94
Copy link
Contributor

Overview

If we have a transaction that has been partially signed, and we decode it using the new web3js and then call compileMessage, the existing signature may not be compatible with the newly compiled message. This is because of the new more deterministic account ordering used in the experimental web3js

Steps to reproduce

Codesandbox: https://codesandbox.io/p/devbox/web3js-account-ordering-xmxrxm (node index.mjs)

This repro creates and signs a transaction with the legacy web3js. It then decodes + recompiles the transaction message using the new web3js, and verifies the signature before and after

Description of bug

  • If we decode a transaction with an existing accounts array then I think we need to keep it the same, to ensure the compiled message.

Suggested fix:

  • Add a field to the Transaction model eg orderedAccounts
  • There should be no way exposed to set that field, it should only be used when we decode an existing transaction. Also probably only set it if there are existing signatures
  • If we do anything that already invalidates signatures (like adding an instruction), we should also strip this field
  • When we compile the message, if this field is set then we should use it instead of our deterministic account ordering
Copy link
Contributor

github-actions bot commented Apr 3, 2024

🎉 This issue has been resolved in version 1.91.4 🎉

The release is available on:

Your semantic-release bot 📦🚀

@mcintyre94 mcintyre94 reopened this Apr 3, 2024
@mcintyre94
Copy link
Contributor Author

^ Nope

@mcintyre94
Copy link
Contributor Author

Okay now this is closed!

Copy link
Contributor

Because there has been no activity on this issue for 7 days since it was closed, it has been automatically locked. Please open a new issue if it requires a follow up.

@github-actions github-actions bot locked as resolved and limited conversation to collaborators Jun 11, 2024
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.