Address Contract Partially Verified
Address
0x6467e807dB1E71B9Ef04E0E3aFb962E4B0900B2B
Balance
0 ETH
Nonce
1
Code Size
2138 bytes
Creator
0x446aD06C...63c7 at tx 0x08dc14dc...0a4531
Indexed Transactions
0
Contract Bytecode
2138 bytes
0x6080604052600436106100695760003560e01c806382dfc5f71161004357806382dfc5f714610131578063b11569f514610162578063d95393eb1461017757610070565b806301e33667146100725780631b9a91a4146100b5578063560706da146100ee57610070565b3661007057005b005b34801561007e57600080fd5b506100706004803603606081101561009557600080fd5b506001600160a01b0381358116916020810135909116906040013561018c565b3480156100c157600080fd5b50610070600480360360408110156100d857600080fd5b506001600160a01b03813516906020013561028d565b3480156100fa57600080fd5b506100706004803603606081101561011157600080fd5b506001600160a01b03813581169160208101359091169060400135610390565b34801561013d57600080fd5b506101466103f9565b604080516001600160a01b039092168252519081900360200190f35b34801561016e57600080fd5b50610146610411565b34801561018357600080fd5b50610146610429565b3373a74e9791d7d66c6a14b2c571bda0f2a1f6d64e06146101e1576040805162461bcd60e51b815260206004820152600a60248201526927b7363c9020b236b4b760b11b604482015290519081900360640190fd5b8061027457604080517f70a0823100000000000000000000000000000000000000000000000000000000815230600482015290516001600160a01b038516916370a08231916024808301926020929190829003018186803b15801561024557600080fd5b505afa158015610259573d6000803e3d6000fd5b505050506040513d602081101561026f57600080fd5b505190505b6102886001600160a01b0384168383610441565b505050565b3373a74e9791d7d66c6a14b2c571bda0f2a1f6d64e06146102e2576040805162461bcd60e51b815260206004820152600a60248201526927b7363c9020b236b4b760b11b604482015290519081900360640190fd5b806102ea5750475b6040516000906001600160a01b0384169083908381818185875af1925050503d8060008114610335576040519150601f19603f3d011682016040523d82523d6000602084013e61033a565b606091505b5050905080610288576040805162461bcd60e51b815260206004820152600f60248201527f4574682073656e64206661696c65640000000000000000000000000000000000604482015290519081900360640190fd5b3373a74e9791d7d66c6a14b2c571bda0f2a1f6d64e06146103e5576040805162461bcd60e51b815260206004820152600a60248201526927b7363c9020b236b4b760b11b604482015290519081900360640190fd5b6102886001600160a01b03841683836104ac565b73c02aaa39b223fe8d0a0e5c4f27ead9083c756cc281565b73a74e9791d7d66c6a14b2c571bda0f2a1f6d64e0681565b736b175474e89094c44da98b954eedeac495271d0f81565b604080516001600160a01b038416602482015260448082018490528251808303909101815260649091019091526020810180516001600160e01b03167fa9059cbb0000000000000000000000000000000000000000000000000000000017905261028890849061054f565b604080516001600160a01b038416602482015260006044808301919091528251808303909101815260649091019091526020810180516001600160e01b031663095ea7b360e01b17905261050190849061054f565b604080516001600160a01b038416602482015260448082018490528251808303909101815260649091019091526020810180516001600160e01b031663095ea7b360e01b1790526102889084905b60006105a4826040518060400160405280602081526020017f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564815250856001600160a01b03166106009092919063ffffffff16565b805190915015610288578080602001905160208110156105c357600080fd5b50516102885760405162461bcd60e51b815260040180806020018281038252602a8152602001806107fb602a913960400191505060405180910390fd5b606061060f8484600085610617565b949350505050565b6060610622856107c1565b610673576040805162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e7472616374000000604482015290519081900360640190fd5b600080866001600160a01b031685876040518082805190602001908083835b602083106106b15780518252601f199092019160209182019101610692565b6001836020036101000a03801982511681845116808217855250505050505090500191505060006040518083038185875af1925050503d8060008114610713576040519150601f19603f3d011682016040523d82523d6000602084013e610718565b606091505b5091509150811561072c57915061060f9050565b80511561073c5780518082602001fd5b8360405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b8381101561078657818101518382015260200161076e565b50505050905090810190601f1680156107b35780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b6000813f7fc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a47081811480159061060f57505015159291505056fe5361666545524332303a204552433230206f7065726174696f6e20646964206e6f742073756363656564a264697066735822122035667c31aefb202f3f62ff1ea1e1e21e721f2faae051d2e4a45c93d542c124fd64736f6c63430007060033
Verified Source Code Partial Match
Compiler: v0.7.6+commit.7338295f
EVM: istanbul
Optimization: Yes (1000 runs)
FeeReceiver.sol 329 lines
// SPDX-License-Identifier: MIT
pragma solidity =0.7.6;
interface IERC20 {
function totalSupply() external view returns (uint256 supply);
function balanceOf(address _owner) external view returns (uint256 balance);
function transfer(address _to, uint256 _value) external returns (bool success);
function transferFrom(
address _from,
address _to,
uint256 _value
) external returns (bool success);
function approve(address _spender, uint256 _value) external returns (bool success);
function allowance(address _owner, address _spender) external view returns (uint256 remaining);
function decimals() external view returns (uint256 digits);
event Approval(address indexed _owner, address indexed _spender, uint256 _value);
}
library Address {
function isContract(address account) internal view returns (bool) {
// According to EIP-1052, 0x0 is the value returned for not-yet created accounts
// and 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470 is returned
// for accounts without code, i.e. `keccak256('')`
bytes32 codehash;
bytes32 accountHash = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470;
// solhint-disable-next-line no-inline-assembly
assembly {
codehash := extcodehash(account)
}
return (codehash != accountHash && codehash != 0x0);
}
function sendValue(address payable recipient, uint256 amount) internal {
require(address(this).balance >= amount, "Address: insufficient balance");
// solhint-disable-next-line avoid-low-level-calls, avoid-call-value
(bool success, ) = recipient.call{value: amount}("");
require(success, "Address: unable to send value, recipient may have reverted");
}
function functionCall(address target, bytes memory data) internal returns (bytes memory) {
return functionCall(target, data, "Address: low-level call failed");
}
function functionCall(
address target,
bytes memory data,
string memory errorMessage
) internal returns (bytes memory) {
return _functionCallWithValue(target, data, 0, errorMessage);
}
function functionCallWithValue(
address target,
bytes memory data,
uint256 value
) internal returns (bytes memory) {
return
functionCallWithValue(target, data, value, "Address: low-level call with value failed");
}
function functionCallWithValue(
address target,
bytes memory data,
uint256 value,
string memory errorMessage
) internal returns (bytes memory) {
require(address(this).balance >= value, "Address: insufficient balance for call");
return _functionCallWithValue(target, data, value, errorMessage);
}
function _functionCallWithValue(
address target,
bytes memory data,
uint256 weiValue,
string memory errorMessage
) private returns (bytes memory) {
require(isContract(target), "Address: call to non-contract");
// solhint-disable-next-line avoid-low-level-calls
(bool success, bytes memory returndata) = target.call{value: weiValue}(data);
if (success) {
return returndata;
} else {
// Look for revert reason and bubble it up if present
if (returndata.length > 0) {
// The easiest way to bubble the revert reason is using memory via assembly
// solhint-disable-next-line no-inline-assembly
assembly {
let returndata_size := mload(returndata)
revert(add(32, returndata), returndata_size)
}
} else {
revert(errorMessage);
}
}
}
}
library SafeMath {
function add(uint256 a, uint256 b) internal pure returns (uint256) {
uint256 c = a + b;
require(c >= a, "SafeMath: addition overflow");
return c;
}
function sub(uint256 a, uint256 b) internal pure returns (uint256) {
return sub(a, b, "SafeMath: subtraction overflow");
}
function sub(
uint256 a,
uint256 b,
string memory errorMessage
) internal pure returns (uint256) {
require(b <= a, errorMessage);
uint256 c = a - b;
return c;
}
function mul(uint256 a, uint256 b) internal pure returns (uint256) {
// Gas optimization: this is cheaper than requiring 'a' not being zero, but the
// benefit is lost if 'b' is also tested.
// See: https://github.com/OpenZeppelin/openzeppelin-contracts/pull/522
if (a == 0) {
return 0;
}
uint256 c = a * b;
require(c / a == b, "SafeMath: multiplication overflow");
return c;
}
function div(uint256 a, uint256 b) internal pure returns (uint256) {
return div(a, b, "SafeMath: division by zero");
}
function div(
uint256 a,
uint256 b,
string memory errorMessage
) internal pure returns (uint256) {
require(b > 0, errorMessage);
uint256 c = a / b;
// assert(a == b * c + a % b); // There is no case in which this doesn't hold
return c;
}
function mod(uint256 a, uint256 b) internal pure returns (uint256) {
return mod(a, b, "SafeMath: modulo by zero");
}
function mod(
uint256 a,
uint256 b,
string memory errorMessage
) internal pure returns (uint256) {
require(b != 0, errorMessage);
return a % b;
}
}
library SafeERC20 {
using SafeMath for uint256;
using Address for address;
function safeTransfer(
IERC20 token,
address to,
uint256 value
) internal {
_callOptionalReturn(token, abi.encodeWithSelector(token.transfer.selector, to, value));
}
function safeTransferFrom(
IERC20 token,
address from,
address to,
uint256 value
) internal {
_callOptionalReturn(
token,
abi.encodeWithSelector(token.transferFrom.selector, from, to, value)
);
}
/// @dev Edited so it always first approves 0 and then the value, because of non standard tokens
function safeApprove(
IERC20 token,
address spender,
uint256 value
) internal {
_callOptionalReturn(token, abi.encodeWithSelector(token.approve.selector, spender, 0));
_callOptionalReturn(token, abi.encodeWithSelector(token.approve.selector, spender, value));
}
function safeIncreaseAllowance(
IERC20 token,
address spender,
uint256 value
) internal {
uint256 newAllowance = token.allowance(address(this), spender).add(value);
_callOptionalReturn(
token,
abi.encodeWithSelector(token.approve.selector, spender, newAllowance)
);
}
function safeDecreaseAllowance(
IERC20 token,
address spender,
uint256 value
) internal {
uint256 newAllowance = token.allowance(address(this), spender).sub(
value,
"SafeERC20: decreased allowance below zero"
);
_callOptionalReturn(
token,
abi.encodeWithSelector(token.approve.selector, spender, newAllowance)
);
}
function _callOptionalReturn(IERC20 token, bytes memory data) private {
bytes memory returndata = address(token).functionCall(
data,
"SafeERC20: low-level call failed"
);
if (returndata.length > 0) {
// Return data is optional
// solhint-disable-next-line max-line-length
require(abi.decode(returndata, (bool)), "SafeERC20: ERC20 operation did not succeed");
}
}
}
contract FeeReceiver {
using SafeERC20 for IERC20;
address public constant DAI_ADDR = 0x6B175474E89094C44Da98b954EedeAC495271d0F;
address public constant WETH_ADDR = 0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2;
address public constant ADMIN_ADDR = 0xA74e9791D7D66c6a14B2C571BdA0F2A1f6D64E06;
modifier onlyAdmin {
require(msg.sender == ADMIN_ADDR, "Only Admin");
_;
}
/// @dev Approves bot refill as it needs to pull funds for gas feeds from this addr
constructor() {
address botRefill = 0xCD73a63f2cb03d1a11c5C009B0fB2b5c9C430754;
IERC20(DAI_ADDR).approve(botRefill, type(uint256).max);
IERC20(WETH_ADDR).approve(botRefill, type(uint256).max);
}
/// @notice Withdraws ERC20 tokens from the contract
/// @param _tokenAddr ERC20 token address
/// @param _to Address where the tokens will be sent
/// @param _amount Amount of tokens to be sent, if 0 it takes the whole balance
function withdrawToken(address _tokenAddr, address _to, uint256 _amount) public onlyAdmin {
if (_amount == 0) {
_amount = IERC20(_tokenAddr).balanceOf(address(this));
}
IERC20(_tokenAddr).safeTransfer(_to, _amount);
}
/// @notice Withdraws Ether from the contract
/// @param _to Address where Eth will be sent
/// @param _amount Amount of Eth to be sent, if 0 it takes the whole balance
function withdrawEth(address payable _to, uint256 _amount) public onlyAdmin {
if (_amount == 0) {
_amount = address(this).balance;
}
(bool success, ) = _to.call{value: _amount}("");
require(success, "Eth send failed");
}
/// @notice Gives ERC20 token approval from this contract to an address
/// @dev This is needed if we change the BotRefill contract which needs to pull funds
/// @param _tokenAddr ERC20 token address
/// @param _to Address of the address to approve
/// @param _amount Amount to approve
function approveAddress(address _tokenAddr, address _to, uint256 _amount) public onlyAdmin {
IERC20(_tokenAddr).safeApprove(_to, _amount);
}
// solhint-disable-next-line no-empty-blocks
receive() external payable {}
fallback() external payable {}
}
Read Contract
ADMIN_ADDR 0xb11569f5 → address
DAI_ADDR 0xd95393eb → address
WETH_ADDR 0x82dfc5f7 → address
Write Contract 3 functions
These functions modify contract state and require a wallet transaction to execute.
approveAddress 0x560706da
address _tokenAddr
address _to
uint256 _amount
withdrawEth 0x1b9a91a4
address _to
uint256 _amount
withdrawToken 0x01e33667
address _tokenAddr
address _to
uint256 _amount
Token Balances (9)
View Transfers →Recent Transactions
No transactions found for this address