-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
0da624d
commit c648beb
Showing
2 changed files
with
17 additions
and
6 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,20 +1,31 @@ | ||
# PuzzleBox CTF | ||
|
||
Do you have what it takes to unlock this devious solidity puzzle box? You will need to demonstrate your understanding of the EVM, solidity, and smart contract vulnerabilities and chain them together in an exact sequence to get inside, with challenges getting more difficult as you progress. How far can you get? | ||
Do you have what it takes to unlock this devious solidity puzzle box? You will need to demonstrate your understanding of the EVM, solidity, and smart contract vulnerabilities and chain them together in an exact sequence to get inside. How far can you get? | ||
|
||
## Setup | ||
|
||
```bash | ||
# clone this repo | ||
git clone [email protected]:merklejerk/puzzlebox-ctf.git && cd puzzlebox-ctf | ||
git clone [email protected]:dragonfly-ctf/puzzlebox-ctf.git && cd puzzlebox-ctf | ||
# install foundry | ||
forge install | ||
# check your solution | ||
# run/check your solution | ||
forge test -vvvv | ||
``` | ||
|
||
## Structure and Rules | ||
## PuzzleBox Design | ||
|
||
The core puzzlebox contracts are in [`PuzzleBox.sol`](./src/PuzzleBox.sol). The puzzlebox is deployed as a custom proxy contract, `PuzzleBoxProxy`, which delegatecalls most logic to the `PuzzleBox` logic contract. The Puzzlebox is instantiated through the `PuzzleBoxFactory`, which is in charge of setting up initial state. | ||
data:image/s3,"s3://crabby-images/5f72e/5f72e2d95c887ab99c2ef1d58e9b0de3d1451695" alt="architecture diagram" | ||
|
||
[`PuzzleBoxSolution`](./src/PuzzleBoxSolution.sol) is a contract with an incomplete `solve()` function where you should implement your solution. The [tests](./test/PuzzleBox.t.sol) will instantiate and call this contract to verify your solution. | ||
Puzzlebox instances use a familiar proxy pattern, with the main logic contract being [`PuzzleBox`](./src/PuzzleBox.sol#L41) and the proxy contract being [`PuzzleBoxProxy`](./src/PuzzleBox.sol#L5). The contract that deploys and initializes puzzleboxes is [`PuzzleBoxFactory`](./src/PuzzleBox.sol#L306). All 3 contain vital clues for defeating the challenges. | ||
|
||
[`PuzzleBoxSolution`](./src/PuzzleBoxSolution.sol) is a contract with an incomplete `solve()` function where you should implement your solution against the provided `PuzzleBox` instance. The [tests](./test/PuzzleBox.t.sol) will deploy and call this contract to verify your solution. | ||
|
||
* One important thing to note is that your `PuzzleBoxSolution` is never directly instantiated, meaning *its constructor will never be executed*. Instead, a shell contract ([`SolutionContainer`](./test/PuzzleBox.t.sol#L37)) that deploys itself using your solution's runtime bytecode will be created in its place. This confines as much business logic as possible to your solution's `solve()` function for fairness. | ||
|
||
In the contest, your solution will be scored based on how many challenges it completes, with a bonus given to more gas efficient solutions. *Only the gas you spend inside `solve()` is counted.* | ||
|
||
Beyond the contest, this is intended to be an educational resource so even partial solutions can be submitted and awarded a score! | ||
|
||
### Project Structure | ||
This project is designed to loosely emulate the evaluation environment of the contest. In the contest, everything happens in 1 transaction, and is orchestrated by a "runner" contract. The runner is in charge of deploying the puzzlebox, your solution, and calling `solve()`, atomically. In this repo, the provided test case ([`test_win`](./test/PuzzleBox.t.sol#L29)) simulates the role of the runner. |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.