-
Notifications
You must be signed in to change notification settings - Fork 99
/
Reentrancy.sol
108 lines (93 loc) · 3.13 KB
/
Reentrancy.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
pragma solidity ^0.8.13;
import "forge-std/console.sol";
abstract contract Reentrancy {
enum State {
PRE_ATTACK,
ATTACK,
POST_ATTACK
}
State reentrancyStage;
/**
* @dev Function run the first time the callback is entered
*/
function _executeAttack() internal virtual;
/**
* @dev Function run after the attack is executed
*/
function _completeAttack() internal virtual;
/**
* @dev Function run when target contract makes external call back to attack contract
*/
function _reentrancyCallback() internal virtual {
console.log("\n>>> Execute attack");
_executeAttack();
}
/**
* @dev Handles the receipt of ERC677 token type.
*/
function onTokenTransfer(address, uint256, bytes memory) external returns (bool) {
_reentrancyCallback();
return true;
}
/**
* @dev Handles the receipt of ERC1363 token type.
*/
function onTransferReceived(address, address, uint256, bytes memory) external returns (bytes4) {
_reentrancyCallback();
return this.onTransferReceived.selector;
}
/**
* @dev Handles the receipt of a single ERC1155 token type. This function is
* called at the end of a `safeTransferFrom` after the balance has been updated.
*/
function onERC1155Received(address, address, uint256, uint256, bytes calldata) external returns (bytes4) {
_reentrancyCallback();
return this.onERC1155Received.selector;
}
/**
* @dev Handles the receipt of a multiple ERC1155 token types. This function
* is called at the end of a `safeBatchTransferFrom` after the balances have
* been updated.
*/
function onERC1155BatchReceived(address, address, uint256[] calldata, uint256[] calldata, bytes calldata)
external
returns (bytes4)
{
_reentrancyCallback();
return this.onERC1155BatchReceived.selector;
}
/**
* @dev Whenever an {IERC721} `tokenId` token is transferred to this contract via {IERC721-safeTransferFrom}
* by `operator` from `from`, this function is called.
*/
function onERC721Received(address, address, uint256, bytes calldata) external returns (bytes4) {
_reentrancyCallback();
return this.onERC721Received.selector;
}
/**
* @dev Whenever an AAVE flashloan is executed
*/
function executeOperation(address, uint256, uint256, address, bytes calldata) external returns (bool) {
_reentrancyCallback();
return true;
}
/**
* @dev Fallback function called when no other functions match the function signature
*/
fallback() external payable virtual {
_reentrancyCallback();
}
/**
* @dev Function called when native asset is sent with no calldata
*/
receive() external payable virtual {
_reentrancyCallback();
}
/**
* @dev We need to implement this function to tell contracts we support their callback interface
* @return true Always returns true
*/
function supportsInterface(bytes4) public pure returns (bool) {
return true;
}
}