/damn-vulnerable-defi

My solution for DamnVulnerableDeFi's CTF

Primary LanguageSolidityMIT LicenseMIT

Solution for Damn Vulnerable Defi

Note on solutions: The exploits written optimizes for brevity and assumes that the blockchain operates on a vacuum. The exploit smart contracts does not check for authorization and can easily be frontrunned by a generalized frontrunner. That said, even if it checks for authorization, it can still be frontrunned by a sufficiently advanced generalized frontrunner that checks for internal transactions. For that reason, we might as well surrender to the MEV overlords.

A set of challenges to hack implementations of DeFi in Ethereum. Featuring flash loans, oracles, governance, NFTs, lending pools, and more!

Created by @tinchoabbate at OpenZeppelin

Play

Visit damnvulnerabledefi.xyz!

Troubleshooting

  • Some users have reported issues with specific versions of node. I have succesfully installed all dependencies, and executed all challenges, with version v12.20.0. If you're using a different version of node and are having problems during the setup, try switching to version v12.20.0.
  • Some users have reported issues with the timeout set in the package.json file for "The Rewarder" challenge. If you're having trouble executing your exploit for this challenge, try increasing the timeout.

Disclaimer

All Solidity code, practices and patterns in this repository are DAMN VULNERABLE and for educational purposes only.

DO NOT USE IN PRODUCTION.