Skip to content

coinspect/solana-assign-test

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

7 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

The Vulnerability

Read the Unveiling Transaction Simulation Challenges blog post to understand the vulnerability and see a step-by-step attack reproduction.

Setup

  • Install Node.js version 18
    • If you are using nvm (recommended) running nvm use will automatically choose the right node version for you.
  • Install Yarn v1
  • Run yarn setup to install dependencies and run any required post-install scripts
    • Warning: Do not use the yarn / yarn install command directly. Use yarn setup instead. The normal install command will skip required post-install scripts, leaving your development environment in an invalid state.
  • yarn start to run

Attacker's smart contract deployment

  1. Using Solana Playground is the simplest way to deploy
  2. If connecting it to mainnet-beta fails (it happens), an easy alternative is creating an Alchemy account and launching a Solana mainnet node, then add custom endpoint to the settings
  3. The IDE will create you an authority account for deploying the contract
  4. It needs ~1.4SOL to do a first deploy (you get 0.4SOL back), so keep that in mind and make the transfer
  5. Paste take-over.ts
  6. Build & Deploy
  7. Take your contract's address (program ID) and update the exploit code accordingly

Exploit setup

  1. Set up accounts for attacker and victim
  2. Add public key for victim to assign-test.js
  3. Add private key for attacker to assign-test.js

Attack execution

  1. Open browser with Wallet extension and navigate to http://localhost:9011/
  2. Select the victim's wallet from accounts
  3. [On DApp] click connect
  4. [On DApp] click STAGE #1
  • Now funds are transfered to victim. And victim's account is now owned by attacker's ProgramID A3mayAzsbd4H1YFnLBbafAMxbygXYx56Dq2jKupWczM9
  • You can take TXID and check on explorer
  • You can put the victim's account on explorer, and see that it's owned by the attacker's contract, not System Program
  1. Select the attacker's wallet from accounts
  2. [On DApp] click STAGE #2
  • Call to attacker's contract drains the victim's wallet into the attacker's account
  • You can take TXID and check on explorer

Disclaimer

This repository contains a proof-of-concept (PoC) that demonstrates and reproduces a Solana transaction simulation bypass bug that previously affected certain Solana wallets. This content is provided for educational and research purposes only. The authors and contributors of this repository are not responsible for any misuse of the provided information or code.

Responsible Use

This PoC is intended for:

  • Security researchers
  • Solana wallet developers
  • Individuals interested in understanding blockchain vulnerabilities

Responsibly Reported

  • This vulnerability has been responsibly reported to all affected vendors.
  • All affected vendors have patched this vulnerability.
  • The code in this repository is not intended for malicious use.

Without Coinspect's responsible disclosure and work with vendors to remediate this vulnerability, the code in this repository could have been used to:

  1. Take over a victim's Solana account
  2. Transfer funds without proper authorization

Contact Information

For any questions, concerns, or issues in the codebase, please open an issue in this repository.

About

Proof-of-concept exploit for the Solana transaction simulation bypass.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published