More Info
Private Name Tags
ContractCreator
View more zero value Internal Transactions in Advanced View mode
Advanced mode:
Loading...
Loading
Similar Match Source Code This contract matches the deployed Bytecode of the Source Code for Contract 0x1cbB7B61...98Cc2b9B5 The constructor portion of the code might be different and could alter the actual behaviour of the contract
Contract Name:
VesperBridgeStrategy
Compiler Version
v0.6.12+commit.27d51765
Contract Source Code (Solidity Standard Json-Input format)
// SPDX-License-Identifier: MIT pragma solidity 0.6.12; import "@openzeppelin/contracts/math/SafeMath.sol"; import "@openzeppelin/contracts/token/ERC20/IERC20.sol"; import "@openzeppelin/contracts/token/ERC20/SafeERC20.sol"; import "../interfaces/vesper/IController.sol"; import "./Strategy.sol"; import "../interfaces/bloq/ISwapManager.sol"; import "../interfaces/vesper/IVesperPoolV5.sol"; import "../interfaces/vesper/IStrategyV4.sol"; import "../interfaces/vesper/IPoolRewardsV4.sol"; /// @title This strategy will deposit collateral token in Vesper V5(and up) and earn interest. contract VesperBridgeStrategy is Strategy { using SafeERC20 for IERC20; using SafeMath for uint256; string public constant NAME = "VesperBridgeStrategy"; string public constant VERSION = "2.1.0"; address public constant VSP = 0x1b40183EFB4Dd766f11bDa7A7c3AD8982e998421; IVesperPoolV5 internal immutable vToken; constructor( address _controller, address _pool, address _receiptToken ) public Strategy(_controller, _pool, _receiptToken) { vToken = IVesperPoolV5(_receiptToken); } /** * @notice Migrate tokens from pool to this address * @dev Any working VesperV5 strategy has vTokens in strategy contract. * @dev There can be scenarios when pool already has vTokens and new * strategy will have to move those tokens from pool to self address. * @dev Only valid pool strategy is allowed to move tokens from pool. */ function _migrateIn() internal override { require(controller.isPool(pool), "not-a-valid-pool"); require(controller.strategy(pool) == address(this), "not-a-valid-strategy"); IERC20(vToken).safeTransferFrom(pool, address(this), vToken.balanceOf(pool)); } /** * @notice Migrate tokens out to pool. * @dev There can be scenarios when we want to use new strategy without * calling withdrawAll(). We can achieve this by moving tokens in pool * and new strategy will take care from there. * @dev Pause this strategy and move tokens out. */ function _migrateOut() internal override { require(controller.isPool(pool), "not-a-valid-pool"); _pause(); IERC20(vToken).safeTransfer(pool, vToken.balanceOf(address(this))); } /// @notice Vesper pools are using this function so it should exist in all strategies. //solhint-disable-next-line no-empty-blocks function beforeWithdraw() external override onlyPool {} /** * @dev Claim VSP rewards and convert to collateral. * Transfer all collateral from pool to here. * Deposit all collateral from this contract into Vesper V5(and up) pool */ function rebalance() external override onlyKeeper { _claimReward(); uint256 _collateralInPool = collateralToken.balanceOf(pool); if (_collateralInPool > 0) { collateralToken.safeTransferFrom(pool, address(this), _collateralInPool); } // There may be some collateral already here due to rewards, hence reading balance again. uint256 _collateralHere = collateralToken.balanceOf(address(this)); if (_collateralHere > 0) { vToken.deposit(_collateralHere); } } /** * @notice Returns interest earned since last rebalance. */ function interestEarned() public view override returns (uint256 collateralEarned) { // Pool rewardToken can change over time so we don't store it in contract address _poolRewards = vToken.poolRewards(); if (_poolRewards != address(0)) { (address[] memory _rewardTokens, uint256[] memory _claimableRewards) = IPoolRewardsV4(_poolRewards).claimable(address(this)); // if there's any reward earned we add that to collateralEarned if (_claimableRewards[0] > 0 && _rewardTokens[0] == VSP) { (, collateralEarned, ) = swapManager.bestOutputFixedInput( VSP, address(collateralToken), _claimableRewards[0] ); } } address[] memory _strategies = vToken.getStrategies(); uint256 _len = _strategies.length; uint256 _unrealizedGain; for (uint256 i = 0; i < _len; i++) { uint256 _totalValue = IStrategyV4(_strategies[i]).totalValue(); uint256 _debt = vToken.totalDebtOf(_strategies[i]); if (_totalValue > _debt) { _unrealizedGain = _unrealizedGain.add(_totalValue.sub(_debt)); } } if (_unrealizedGain > 0) { // collateralEarned = rewards + unrealizedGain proportional to v2 share in v5 collateralEarned = collateralEarned.add( _unrealizedGain.mul(vToken.balanceOf(address(this))).div(vToken.totalSupply()) ); } } /// @notice Returns true if strategy can be upgraded. /// @dev If there are no vTokens in strategy then it is upgradable function isUpgradable() external view override returns (bool) { return vToken.balanceOf(address(this)) == 0; } /// @notice This method is deprecated and will be removed from Strategies in next release function isReservedToken(address _token) public view override returns (bool) { address _poolRewards = vToken.poolRewards(); return _token == address(vToken) || (_poolRewards != address(0) && IPoolRewardsV4(_poolRewards).isRewardToken(_token)); } function _approveToken(uint256 _amount) internal override { collateralToken.safeApprove(pool, _amount); collateralToken.safeApprove(address(vToken), _amount); for (uint256 i = 0; i < swapManager.N_DEX(); i++) { IERC20(VSP).safeApprove(address(swapManager.ROUTERS(i)), _amount); } } /** * @dev Converts rewardToken from V5(and up) Pool to collateralToken */ function _claimReward() internal override { address _poolRewards = vToken.poolRewards(); if (_poolRewards != address(0)) { IPoolRewardsV4(_poolRewards).claimReward(address(this)); uint256 _vspAmount = IERC20(VSP).balanceOf(address(this)); if (_vspAmount > 0) { _safeSwap(VSP, address(collateralToken), _vspAmount); } } } /** * @notice Total collateral locked in VesperV5. * @return Return value will be in collateralToken defined decimal. */ function totalLocked() public view override returns (uint256) { uint256 _totalVTokens = vToken.balanceOf(pool).add(vToken.balanceOf(address(this))); return _convertToCollateral(_totalVTokens); } /// @dev _deposit function is only being used via parent contract. Rebalance is not using it. function _deposit(uint256 _amount) internal virtual override { collateralToken.safeTransferFrom(pool, address(this), _amount); vToken.deposit(_amount); } function _withdraw(uint256 _amount) internal override { _safeWithdraw(_convertToShares(_amount)); collateralToken.safeTransfer(pool, collateralToken.balanceOf(address(this))); } /** * @dev V5(and up) Pools may withdraw a partial amount of requested shares. * This can cause V2 pool to burn more shares than actual collateral withdrawn. * Hence the check to verify correct withdrawal. */ function _safeWithdraw(uint256 _shares) internal { if (_shares > 0) { uint256 _sharesBefore = vToken.balanceOf(address(this)); // WhitelistedWithdraw is deprecated in V4 vToken.withdraw(_shares); require( vToken.balanceOf(address(this)) == _sharesBefore.sub(_shares), "Not enough shares withdrawn" ); } } function _withdrawAll() internal override { _safeWithdraw(vToken.balanceOf(address(this))); _claimReward(); collateralToken.safeTransfer(pool, collateralToken.balanceOf(address(this))); } /// @dev V5(and up) pools uses pricePerShare for all internal calculations, hence using pricePerShare here. function _convertToCollateral(uint256 _vTokenAmount) internal view returns (uint256) { return _vTokenAmount.mul(vToken.pricePerShare()).div(1e18); } /// @dev V5(and up) pools uses pricePerShare for all internal calculations, hence using pricePerShare here. function _convertToShares(uint256 _collateralAmount) internal view returns (uint256) { uint256 _pricePerShare = vToken.pricePerShare(); uint256 _shares = _collateralAmount.mul(1e18).div(_pricePerShare); return _collateralAmount > (_shares.mul(_pricePerShare).div(1e18)) ? _shares + 1 : _shares; } /// @dev This strategy will not collect any fee as fee will be levied by V5(and up) pool and strategies //solhint-disable-next-line no-empty-blocks function _updatePendingFee() internal override {} }
// SPDX-License-Identifier: MIT pragma solidity >=0.6.0 <0.8.0; import "../utils/Context.sol";
// SPDX-License-Identifier: MIT pragma solidity >=0.6.0 <0.8.0; /** * @dev Wrappers over Solidity's arithmetic operations with added overflow * checks. * * Arithmetic operations in Solidity wrap on overflow. This can easily result * in bugs, because programmers usually assume that an overflow raises an * error, which is the standard behavior in high level programming languages. * `SafeMath` restores this intuition by reverting the transaction when an * operation overflows. * * Using this library instead of the unchecked operations eliminates an entire * class of bugs, so it's recommended to use it always. */ library SafeMath { /** * @dev Returns the addition of two unsigned integers, with an overflow flag. * * _Available since v3.4._ */ function tryAdd(uint256 a, uint256 b) internal pure returns (bool, uint256) { uint256 c = a + b; if (c < a) return (false, 0); return (true, c); } /** * @dev Returns the substraction of two unsigned integers, with an overflow flag. * * _Available since v3.4._ */ function trySub(uint256 a, uint256 b) internal pure returns (bool, uint256) { if (b > a) return (false, 0); return (true, a - b); } /** * @dev Returns the multiplication of two unsigned integers, with an overflow flag. * * _Available since v3.4._ */ function tryMul(uint256 a, uint256 b) internal pure returns (bool, 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 (true, 0); uint256 c = a * b; if (c / a != b) return (false, 0); return (true, c); } /** * @dev Returns the division of two unsigned integers, with a division by zero flag. * * _Available since v3.4._ */ function tryDiv(uint256 a, uint256 b) internal pure returns (bool, uint256) { if (b == 0) return (false, 0); return (true, a / b); } /** * @dev Returns the remainder of dividing two unsigned integers, with a division by zero flag. * * _Available since v3.4._ */ function tryMod(uint256 a, uint256 b) internal pure returns (bool, uint256) { if (b == 0) return (false, 0); return (true, a % b); } /** * @dev Returns the addition of two unsigned integers, reverting on * overflow. * * Counterpart to Solidity's `+` operator. * * Requirements: * * - Addition cannot overflow. */ function add(uint256 a, uint256 b) internal pure returns (uint256) { uint256 c = a + b; require(c >= a, "SafeMath: addition overflow"); return c; } /** * @dev Returns the subtraction of two unsigned integers, reverting on * overflow (when the result is negative). * * Counterpart to Solidity's `-` operator. * * Requirements: * * - Subtraction cannot overflow. */ function sub(uint256 a, uint256 b) internal pure returns (uint256) { require(b <= a, "SafeMath: subtraction overflow"); return a - b; } /** * @dev Returns the multiplication of two unsigned integers, reverting on * overflow. * * Counterpart to Solidity's `*` operator. * * Requirements: * * - Multiplication cannot overflow. */ function mul(uint256 a, uint256 b) internal pure returns (uint256) { if (a == 0) return 0; uint256 c = a * b; require(c / a == b, "SafeMath: multiplication overflow"); return c; } /** * @dev Returns the integer division of two unsigned integers, reverting on * division by zero. The result is rounded towards zero. * * Counterpart to Solidity's `/` operator. Note: this function uses a * `revert` opcode (which leaves remaining gas untouched) while Solidity * uses an invalid opcode to revert (consuming all remaining gas). * * Requirements: * * - The divisor cannot be zero. */ function div(uint256 a, uint256 b) internal pure returns (uint256) { require(b > 0, "SafeMath: division by zero"); return a / b; } /** * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo), * reverting when dividing by zero. * * Counterpart to Solidity's `%` operator. This function uses a `revert` * opcode (which leaves remaining gas untouched) while Solidity uses an * invalid opcode to revert (consuming all remaining gas). * * Requirements: * * - The divisor cannot be zero. */ function mod(uint256 a, uint256 b) internal pure returns (uint256) { require(b > 0, "SafeMath: modulo by zero"); return a % b; } /** * @dev Returns the subtraction of two unsigned integers, reverting with custom message on * overflow (when the result is negative). * * CAUTION: This function is deprecated because it requires allocating memory for the error * message unnecessarily. For custom revert reasons use {trySub}. * * Counterpart to Solidity's `-` operator. * * Requirements: * * - Subtraction cannot overflow. */ function sub(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) { require(b <= a, errorMessage); return a - b; } /** * @dev Returns the integer division of two unsigned integers, reverting with custom message on * division by zero. The result is rounded towards zero. * * CAUTION: This function is deprecated because it requires allocating memory for the error * message unnecessarily. For custom revert reasons use {tryDiv}. * * Counterpart to Solidity's `/` operator. Note: this function uses a * `revert` opcode (which leaves remaining gas untouched) while Solidity * uses an invalid opcode to revert (consuming all remaining gas). * * Requirements: * * - The divisor cannot be zero. */ function div(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) { require(b > 0, errorMessage); return a / b; } /** * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo), * reverting with custom message when dividing by zero. * * CAUTION: This function is deprecated because it requires allocating memory for the error * message unnecessarily. For custom revert reasons use {tryMod}. * * Counterpart to Solidity's `%` operator. This function uses a `revert` * opcode (which leaves remaining gas untouched) while Solidity uses an * invalid opcode to revert (consuming all remaining gas). * * Requirements: * * - The divisor cannot be zero. */ function mod(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) { require(b > 0, errorMessage); return a % b; } }
// SPDX-License-Identifier: MIT pragma solidity >=0.6.0 <0.8.0; /** * @dev Interface of the ERC20 standard as defined in the EIP. */ interface IERC20 { /** * @dev Returns the amount of tokens in existence. */ function totalSupply() external view returns (uint256); /** * @dev Returns the amount of tokens owned by `account`. */ function balanceOf(address account) external view returns (uint256); /** * @dev Moves `amount` tokens from the caller's account to `recipient`. * * Returns a boolean value indicating whether the operation succeeded. * * Emits a {Transfer} event. */ function transfer(address recipient, uint256 amount) external returns (bool); /** * @dev Returns the remaining number of tokens that `spender` will be * allowed to spend on behalf of `owner` through {transferFrom}. This is * zero by default. * * This value changes when {approve} or {transferFrom} are called. */ function allowance(address owner, address spender) external view returns (uint256); /** * @dev Sets `amount` as the allowance of `spender` over the caller's tokens. * * Returns a boolean value indicating whether the operation succeeded. * * IMPORTANT: Beware that changing an allowance with this method brings the risk * that someone may use both the old and the new allowance by unfortunate * transaction ordering. One possible solution to mitigate this race * condition is to first reduce the spender's allowance to 0 and set the * desired value afterwards: * https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729 * * Emits an {Approval} event. */ function approve(address spender, uint256 amount) external returns (bool); /** * @dev Moves `amount` tokens from `sender` to `recipient` using the * allowance mechanism. `amount` is then deducted from the caller's * allowance. * * Returns a boolean value indicating whether the operation succeeded. * * Emits a {Transfer} event. */ function transferFrom(address sender, address recipient, uint256 amount) external returns (bool); /** * @dev Emitted when `value` tokens are moved from one account (`from`) to * another (`to`). * * Note that `value` may be zero. */ event Transfer(address indexed from, address indexed to, uint256 value); /** * @dev Emitted when the allowance of a `spender` for an `owner` is set by * a call to {approve}. `value` is the new allowance. */ event Approval(address indexed owner, address indexed spender, uint256 value); }
// SPDX-License-Identifier: MIT pragma solidity >=0.6.0 <0.8.0; import "./IERC20.sol"; import "../../math/SafeMath.sol"; import "../../utils/Address.sol"; /** * @title SafeERC20 * @dev Wrappers around ERC20 operations that throw on failure (when the token * contract returns false). Tokens that return no value (and instead revert or * throw on failure) are also supported, non-reverting calls are assumed to be * successful. * To use this library you can add a `using SafeERC20 for IERC20;` statement to your contract, * which allows you to call the safe operations as `token.safeTransfer(...)`, etc. */ 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 Deprecated. This function has issues similar to the ones found in * {IERC20-approve}, and its usage is discouraged. * * Whenever possible, use {safeIncreaseAllowance} and * {safeDecreaseAllowance} instead. */ function safeApprove(IERC20 token, address spender, uint256 value) internal { // safeApprove should only be called when setting an initial allowance, // or when resetting it to zero. To increase and decrease it, use // 'safeIncreaseAllowance' and 'safeDecreaseAllowance' // solhint-disable-next-line max-line-length require((value == 0) || (token.allowance(address(this), spender) == 0), "SafeERC20: approve from non-zero to non-zero allowance" ); _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)); } /** * @dev Imitates a Solidity high-level call (i.e. a regular function call to a contract), relaxing the requirement * on the return value: the return value is optional (but if data is returned, it must not be false). * @param token The token targeted by the call. * @param data The call data (encoded using abi.encode or one of its variants). */ function _callOptionalReturn(IERC20 token, bytes memory data) private { // We need to perform a low level call here, to bypass Solidity's return data size checking mechanism, since // we're implementing it ourselves. We use {Address.functionCall} to perform this call, which verifies that // the target address contains contract code and also asserts for success in the low-level call. 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"); } } }
// SPDX-License-Identifier: MIT pragma solidity >=0.6.2 <0.8.0; /** * @dev Collection of functions related to the address type */ library Address { /** * @dev Returns true if `account` is a contract. * * [IMPORTANT] * ==== * It is unsafe to assume that an address for which this function returns * false is an externally-owned account (EOA) and not a contract. * * Among others, `isContract` will return false for the following * types of addresses: * * - an externally-owned account * - a contract in construction * - an address where a contract will be created * - an address where a contract lived, but was destroyed * ==== */ function isContract(address account) internal view returns (bool) { // This method relies on extcodesize, which returns 0 for contracts in // construction, since the code is only stored at the end of the // constructor execution. uint256 size; // solhint-disable-next-line no-inline-assembly assembly { size := extcodesize(account) } return size > 0; } /** * @dev Replacement for Solidity's `transfer`: sends `amount` wei to * `recipient`, forwarding all available gas and reverting on errors. * * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost * of certain opcodes, possibly making contracts go over the 2300 gas limit * imposed by `transfer`, making them unable to receive funds via * `transfer`. {sendValue} removes this limitation. * * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more]. * * IMPORTANT: because control is transferred to `recipient`, care must be * taken to not create reentrancy vulnerabilities. Consider using * {ReentrancyGuard} or the * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern]. */ 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"); } /** * @dev Performs a Solidity function call using a low level `call`. A * plain`call` is an unsafe replacement for a function call: use this * function instead. * * If `target` reverts with a revert reason, it is bubbled up by this * function (like regular Solidity function calls). * * Returns the raw returned data. To convert to the expected return value, * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`]. * * Requirements: * * - `target` must be a contract. * - calling `target` with `data` must not revert. * * _Available since v3.1._ */ function functionCall(address target, bytes memory data) internal returns (bytes memory) { return functionCall(target, data, "Address: low-level call failed"); } /** * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with * `errorMessage` as a fallback revert reason when `target` reverts. * * _Available since v3.1._ */ function functionCall(address target, bytes memory data, string memory errorMessage) internal returns (bytes memory) { return functionCallWithValue(target, data, 0, errorMessage); } /** * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], * but also transferring `value` wei to `target`. * * Requirements: * * - the calling contract must have an ETH balance of at least `value`. * - the called Solidity function must be `payable`. * * _Available since v3.1._ */ 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"); } /** * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but * with `errorMessage` as a fallback revert reason when `target` reverts. * * _Available since v3.1._ */ 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"); require(isContract(target), "Address: call to non-contract"); // solhint-disable-next-line avoid-low-level-calls (bool success, bytes memory returndata) = target.call{ value: value }(data); return _verifyCallResult(success, returndata, errorMessage); } /** * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], * but performing a static call. * * _Available since v3.3._ */ function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) { return functionStaticCall(target, data, "Address: low-level static call failed"); } /** * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`], * but performing a static call. * * _Available since v3.3._ */ function functionStaticCall(address target, bytes memory data, string memory errorMessage) internal view returns (bytes memory) { require(isContract(target), "Address: static call to non-contract"); // solhint-disable-next-line avoid-low-level-calls (bool success, bytes memory returndata) = target.staticcall(data); return _verifyCallResult(success, returndata, errorMessage); } /** * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], * but performing a delegate call. * * _Available since v3.4._ */ function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) { return functionDelegateCall(target, data, "Address: low-level delegate call failed"); } /** * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`], * but performing a delegate call. * * _Available since v3.4._ */ function functionDelegateCall(address target, bytes memory data, string memory errorMessage) internal returns (bytes memory) { require(isContract(target), "Address: delegate call to non-contract"); // solhint-disable-next-line avoid-low-level-calls (bool success, bytes memory returndata) = target.delegatecall(data); return _verifyCallResult(success, returndata, errorMessage); } function _verifyCallResult(bool success, bytes memory returndata, string memory errorMessage) private pure returns(bytes memory) { 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); } } } }
// SPDX-License-Identifier: MIT pragma solidity >=0.6.0 <0.8.0; /* * @dev Provides information about the current execution context, including the * sender of the transaction and its data. While these are generally available * via msg.sender and msg.data, they should not be accessed in such a direct * manner, since when dealing with GSN meta-transactions the account sending and * paying for execution may not be the actual sender (as far as an application * is concerned). * * This contract is only required for intermediate, library-like contracts. */ abstract contract Context { function _msgSender() internal view virtual returns (address payable) { return msg.sender; } function _msgData() internal view virtual returns (bytes memory) { this; // silence state mutability warning without generating bytecode - see https://github.com/ethereum/solidity/issues/2691 return msg.data; } }
// SPDX-License-Identifier: MIT pragma solidity 0.6.12; import "@openzeppelin/contracts/GSN/Context.sol"; /** * @dev Contract module which allows children to implement an emergency stop * mechanism that can be triggered by an authorized account. * */ contract Pausable is Context { event Paused(address account); event Shutdown(address account); event Unpaused(address account); event Open(address account); bool public paused; bool public stopEverything; modifier whenNotPaused() { require(!paused, "Pausable: paused"); _; } modifier whenPaused() { require(paused, "Pausable: not paused"); _; } modifier whenNotShutdown() { require(!stopEverything, "Pausable: shutdown"); _; } modifier whenShutdown() { require(stopEverything, "Pausable: not shutdown"); _; } /// @dev Pause contract operations, if contract is not paused. function _pause() internal virtual whenNotPaused { paused = true; emit Paused(_msgSender()); } /// @dev Unpause contract operations, allow only if contract is paused and not shutdown. function _unpause() internal virtual whenPaused whenNotShutdown { paused = false; emit Unpaused(_msgSender()); } /// @dev Shutdown contract operations, if not already shutdown. function _shutdown() internal virtual whenNotShutdown { stopEverything = true; paused = true; emit Shutdown(_msgSender()); } /// @dev Open contract operations, if contract is in shutdown state function _open() internal virtual whenShutdown { stopEverything = false; emit Open(_msgSender()); } }
// SPDX-License-Identifier: MIT pragma solidity 0.6.12; import "../uniswap/IUniswapV2Router02.sol"; /* solhint-disable func-name-mixedcase */ interface ISwapManager { event OracleCreated(address indexed _sender, address indexed _newOracle, uint256 _period); function N_DEX() external view returns (uint256); function ROUTERS(uint256 i) external view returns (IUniswapV2Router02); function bestOutputFixedInput( address _from, address _to, uint256 _amountIn ) external view returns ( address[] memory path, uint256 amountOut, uint256 rIdx ); function bestPathFixedInput( address _from, address _to, uint256 _amountIn, uint256 _i ) external view returns (address[] memory path, uint256 amountOut); function bestInputFixedOutput( address _from, address _to, uint256 _amountOut ) external view returns ( address[] memory path, uint256 amountIn, uint256 rIdx ); function bestPathFixedOutput( address _from, address _to, uint256 _amountOut, uint256 _i ) external view returns (address[] memory path, uint256 amountIn); function safeGetAmountsOut( uint256 _amountIn, address[] memory _path, uint256 _i ) external view returns (uint256[] memory result); function unsafeGetAmountsOut( uint256 _amountIn, address[] memory _path, uint256 _i ) external view returns (uint256[] memory result); function safeGetAmountsIn( uint256 _amountOut, address[] memory _path, uint256 _i ) external view returns (uint256[] memory result); function unsafeGetAmountsIn( uint256 _amountOut, address[] memory _path, uint256 _i ) external view returns (uint256[] memory result); function comparePathsFixedInput( address[] memory pathA, address[] memory pathB, uint256 _amountIn, uint256 _i ) external view returns (address[] memory path, uint256 amountOut); function comparePathsFixedOutput( address[] memory pathA, address[] memory pathB, uint256 _amountOut, uint256 _i ) external view returns (address[] memory path, uint256 amountIn); function ours(address a) external view returns (bool); function oracleCount() external view returns (uint256); function oracleAt(uint256 idx) external view returns (address); function getOracle( address _tokenA, address _tokenB, uint256 _period, uint256 _i ) external view returns (address); function createOrUpdateOracle( address _tokenA, address _tokenB, uint256 _period, uint256 _i ) external returns (address oracleAddr); function consultForFree( address _from, address _to, uint256 _amountIn, uint256 _period, uint256 _i ) external view returns (uint256 amountOut, uint256 lastUpdatedAt); /// get the data we want and pay the gas to update function consult( address _from, address _to, uint256 _amountIn, uint256 _period, uint256 _i ) external returns ( uint256 amountOut, uint256 lastUpdatedAt, bool updated ); function updateOracles() external returns (uint256 updated, uint256 expected); function updateOracles(address[] memory _oracleAddrs) external returns (uint256 updated, uint256 expected); }
// SPDX-License-Identifier: MIT pragma solidity 0.6.12; interface IUniswapV2Router01 { function factory() external pure returns (address); function swapExactTokensForTokens( uint256 amountIn, uint256 amountOutMin, address[] calldata path, address to, uint256 deadline ) external returns (uint256[] memory amounts); function swapTokensForExactTokens( uint256 amountOut, uint256 amountInMax, address[] calldata path, address to, uint256 deadline ) external returns (uint256[] memory amounts); function swapExactETHForTokens( uint256 amountOutMin, address[] calldata path, address to, uint256 deadline ) external payable returns (uint256[] memory amounts); function swapTokensForExactETH( uint256 amountOut, uint256 amountInMax, address[] calldata path, address to, uint256 deadline ) external returns (uint256[] memory amounts); function swapExactTokensForETH( uint256 amountIn, uint256 amountOutMin, address[] calldata path, address to, uint256 deadline ) external returns (uint256[] memory amounts); function swapETHForExactTokens( uint256 amountOut, address[] calldata path, address to, uint256 deadline ) external payable returns (uint256[] memory amounts); function quote( uint256 amountA, uint256 reserveA, uint256 reserveB ) external pure returns (uint256 amountB); function getAmountOut( uint256 amountIn, uint256 reserveIn, uint256 reserveOut ) external pure returns (uint256 amountOut); function getAmountIn( uint256 amountOut, uint256 reserveIn, uint256 reserveOut ) external pure returns (uint256 amountIn); function getAmountsOut(uint256 amountIn, address[] calldata path) external view returns (uint256[] memory amounts); function getAmountsIn(uint256 amountOut, address[] calldata path) external view returns (uint256[] memory amounts); }
// SPDX-License-Identifier: MIT pragma solidity 0.6.12; import "./IUniswapV2Router01.sol"; interface IUniswapV2Router02 is IUniswapV2Router01 { function swapExactTokensForTokensSupportingFeeOnTransferTokens( uint256 amountIn, uint256 amountOutMin, address[] calldata path, address to, uint256 deadline ) external; function swapExactETHForTokensSupportingFeeOnTransferTokens( uint256 amountOutMin, address[] calldata path, address to, uint256 deadline ) external payable; function swapExactTokensForETHSupportingFeeOnTransferTokens( uint256 amountIn, uint256 amountOutMin, address[] calldata path, address to, uint256 deadline ) external; }
// SPDX-License-Identifier: MIT pragma solidity 0.6.12; interface IController { function aaveReferralCode() external view returns (uint16); function feeCollector(address) external view returns (address); function founderFee() external view returns (uint256); function founderVault() external view returns (address); function interestFee(address) external view returns (uint256); function isPool(address) external view returns (bool); function pools() external view returns (address); function strategy(address) external view returns (address); function rebalanceFriction(address) external view returns (uint256); function poolRewards(address) external view returns (address); function treasuryPool() external view returns (address); function uniswapRouter() external view returns (address); function withdrawFee(address) external view returns (uint256); }
// SPDX-License-Identifier: MIT pragma solidity 0.6.12; interface IPoolRewardsV4 { /// Emitted after reward added event RewardAdded(address indexed rewardToken, uint256 reward, uint256 rewardDuration); /// Emitted whenever any user claim rewards event RewardPaid(address indexed user, address indexed rewardToken, uint256 reward); /// Emitted after adding new rewards token into rewardTokens array event RewardTokenAdded(address indexed rewardToken, address[] existingRewardTokens); function claimReward(address) external; function notifyRewardAmount( address _rewardToken, uint256 _rewardAmount, uint256 _rewardDuration ) external; function notifyRewardAmount( address[] memory _rewardTokens, uint256[] memory _rewardAmounts, uint256[] memory _rewardDurations ) external; function updateReward(address) external; function claimable(address _account) external view returns (address[] memory _rewardTokens, uint256[] memory _claimableAmounts); function isRewardToken(address _token) external view returns (bool); function lastTimeRewardApplicable(address _rewardToken) external view returns (uint256); function rewardForDuration() external view returns (address[] memory _rewardTokens, uint256[] memory _rewardForDuration); function rewardPerToken() external view returns (address[] memory _rewardTokens, uint256[] memory _rewardPerTokenRate); function rewardTokens() external view returns (address[] memory); }
// SPDX-License-Identifier: MIT pragma solidity 0.6.12; interface IStrategy { function rebalance() external; function deposit(uint256 amount) external; function beforeWithdraw() external; function withdraw(uint256 amount) external; function withdrawAll() external; function isUpgradable() external view returns (bool); function isReservedToken(address _token) external view returns (bool); function token() external view returns (address); function pool() external view returns (address); function totalLocked() external view returns (uint256); //Lifecycle functions function pause() external; function unpause() external; }
// SPDX-License-Identifier: MIT pragma solidity 0.6.12; interface IStrategyV4 { function rebalance() external; function sweepERC20(address _fromToken) external; function withdraw(uint256 _amount) external; function feeCollector() external view returns (address); function isReservedToken(address _token) external view returns (bool); function keepers() external view returns (address); function migrate(address _newStrategy) external; function pool() external view returns (address); function token() external view returns (address); function totalValue() external view returns (uint256); function totalValueCurrent() external returns (uint256); }
// SPDX-License-Identifier: MIT pragma solidity 0.6.12; import "@openzeppelin/contracts/token/ERC20/IERC20.sol"; interface IVesperPool is IERC20 { function approveToken() external; function deposit() external payable; function deposit(uint256) external; function multiTransfer(uint256[] memory) external returns (bool); function permit( address, address, uint256, uint256, uint8, bytes32, bytes32 ) external; function rebalance() external; function resetApproval() external; function sweepErc20(address) external; function withdraw(uint256) external; function withdrawETH(uint256) external; function withdrawByStrategy(uint256) external; function feeCollector() external view returns (address); function getPricePerShare() external view returns (uint256); function token() external view returns (address); function tokensHere() external view returns (uint256); function totalValue() external view returns (uint256); function withdrawFee() external view returns (uint256); }
// SPDX-License-Identifier: MIT pragma solidity 0.6.12; import "@openzeppelin/contracts/token/ERC20/IERC20.sol"; interface IVesperPoolV5 is IERC20 { function calculateUniversalFee(uint256 _profit) external view returns (uint256 _fee); function deposit() external payable; function deposit(uint256 _share) external; function getStrategies() external view returns (address[] memory); function governor() external view returns (address); function keepers() external view returns (address[] memory); function isKeeper(address _address) external view returns (bool); function withdraw(uint256 _amount) external; function withdrawETH(uint256 _amount) external; function pricePerShare() external view returns (uint256); function poolRewards() external view returns (address); function strategy(address _strategy) external view returns ( bool _active, uint256 _interestFee, // Obsolete uint256 _debtRate, // Obsolete uint256 _lastRebalance, uint256 _totalDebt, uint256 _totalLoss, uint256 _totalProfit, uint256 _debtRatio, uint256 _externalDepositFee ); function token() external view returns (address); function tokensHere() external view returns (uint256); function totalDebtOf(address _strategy) external view returns (uint256); function totalValue() external view returns (uint256); }
// SPDX-License-Identifier: MIT pragma solidity 0.6.12; import "@openzeppelin/contracts/math/SafeMath.sol"; import "@openzeppelin/contracts/token/ERC20/IERC20.sol"; import "@openzeppelin/contracts/token/ERC20/SafeERC20.sol"; import "../Pausable.sol"; import "../interfaces/bloq/ISwapManager.sol"; import "../interfaces/vesper/IController.sol"; import "../interfaces/vesper/IStrategy.sol"; import "../interfaces/vesper/IVesperPool.sol"; abstract contract Strategy is IStrategy, Pausable { using SafeERC20 for IERC20; using SafeMath for uint256; // solhint-disable-next-line ISwapManager public swapManager = ISwapManager(0xe382d9f2394A359B01006faa8A1864b8a60d2710); IController public immutable controller; IERC20 public immutable collateralToken; address public immutable receiptToken; address public immutable override pool; address[] public keepers; mapping(address => bool) public isKeeper; address internal constant ETH = 0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE; address internal constant WETH = 0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2; uint256 internal constant MAX_UINT_VALUE = type(uint256).max; event UpdatedSwapManager(address indexed previousSwapManager, address indexed newSwapManager); constructor( address _controller, address _pool, address _receiptToken ) public { require(_controller != address(0), "controller-address-is-zero"); require(IController(_controller).isPool(_pool), "not-a-valid-pool"); controller = IController(_controller); pool = _pool; collateralToken = IERC20(IVesperPool(_pool).token()); receiptToken = _receiptToken; keepers.push(_msgSender()); isKeeper[_msgSender()] = true; } modifier onlyAuthorized() { require( _msgSender() == address(controller) || _msgSender() == pool, "caller-is-not-authorized" ); _; } modifier onlyController() { require(_msgSender() == address(controller), "caller-is-not-the-controller"); _; } modifier onlyKeeper() { require(isKeeper[_msgSender()], "caller-is-not-keeper"); _; } modifier onlyPool() { require(_msgSender() == pool, "caller-is-not-the-pool"); _; } function pause() external override onlyController { _pause(); } function unpause() external override onlyController { _unpause(); } /// @dev Approve all required tokens function approveToken() external onlyController { _approveToken(0); _approveToken(MAX_UINT_VALUE); } /// @dev Reset approval of all required tokens function resetApproval() external onlyController { _approveToken(0); } /** * @notice Add given address in keepers list. * @param _keeperAddress keeper address to add. */ function addKeeper(address _keeperAddress) external onlyController { require(!isKeeper[_keeperAddress], "already-keeper"); keepers.push(_keeperAddress); isKeeper[_keeperAddress] = true; } /** * @notice Remove given address from keepers list. * @param _keeperAddress keeper address to remove. */ function removeKeeper(address _keeperAddress) external onlyController { require(isKeeper[_keeperAddress], "!keeper"); uint256 _len = keepers.length; for (uint8 i; i < _len; ++i) { if (keepers[i] == _keeperAddress) { delete isKeeper[_keeperAddress]; keepers[i] = keepers[_len - 1]; keepers.pop(); break; } } } /** * @notice Update swap manager address * @param _swapManager swap manager address */ function updateSwapManager(address _swapManager) external onlyController { require(_swapManager != address(0), "sm-address-is-zero"); require(_swapManager != address(swapManager), "sm-is-same"); emit UpdatedSwapManager(address(swapManager), _swapManager); swapManager = ISwapManager(_swapManager); } /** * @dev Deposit collateral token into lending pool. * @param _amount Amount of collateral token */ function deposit(uint256 _amount) public override onlyKeeper { _updatePendingFee(); _deposit(_amount); } /** * @notice Deposit all collateral token from pool to other lending pool. * Anyone can call it except when paused. */ function depositAll() external virtual onlyKeeper { deposit(collateralToken.balanceOf(pool)); } /** * @dev Withdraw collateral token from lending pool. * @param _amount Amount of collateral token */ function withdraw(uint256 _amount) external override onlyAuthorized { _updatePendingFee(); _withdraw(_amount); } /** * @dev Withdraw all collateral. No rebalance earning. * Controller only function, called when migrating strategy. */ function withdrawAll() external override onlyController { _withdrawAll(); } /** * @dev sweep given token to vesper pool * @param _fromToken token address to sweep */ function sweepErc20(address _fromToken) external onlyKeeper { require(!isReservedToken(_fromToken), "not-allowed-to-sweep"); if (_fromToken == ETH) { Address.sendValue(payable(pool), address(this).balance); } else { uint256 _amount = IERC20(_fromToken).balanceOf(address(this)); IERC20(_fromToken).safeTransfer(pool, _amount); } } /// @dev Returns true if strategy can be upgraded. function isUpgradable() external view virtual override returns (bool) { return totalLocked() == 0; } /// @dev Returns address of token correspond to collateral token function token() external view override returns (address) { return receiptToken; } /// @dev Convert from 18 decimals to token defined decimals. Default no conversion. function convertFrom18(uint256 amount) public pure virtual returns (uint256) { return amount; } /// @dev report the interest earned since last rebalance function interestEarned() external view virtual returns (uint256); /// @dev Check whether given token is reserved or not. Reserved tokens are not allowed to sweep. function isReservedToken(address _token) public view virtual override returns (bool); /// @dev Returns total collateral locked here function totalLocked() public view virtual override returns (uint256); /// @dev For moving between versions of similar strategies function migrateIn() external onlyController { _migrateIn(); } /// @dev For moving between versions of similar strategies function migrateOut() external onlyController { _migrateOut(); } /** * @notice Handle earned interest fee * @dev Earned interest fee will go to the fee collector. We want fee to be in form of Vesper * pool tokens not in collateral tokens so we will deposit fee in Vesper pool and send vTokens * to fee collector. * @param _fee Earned interest fee in collateral token. */ function _handleFee(uint256 _fee) internal virtual { if (_fee != 0) { IVesperPool(pool).deposit(_fee); uint256 _feeInVTokens = IERC20(pool).balanceOf(address(this)); IERC20(pool).safeTransfer(controller.feeCollector(pool), _feeInVTokens); } } /** * @notice Safe swap via Uniswap * @dev There are many scenarios when token swap via Uniswap can fail, so this * method will wrap Uniswap call in a 'try catch' to make it fail safe. * @param _from address of from token * @param _to address of to token * @param _amount Amount to be swapped */ function _safeSwap( address _from, address _to, uint256 _amount ) internal { (address[] memory _path, uint256 amountOut, uint256 rIdx) = swapManager.bestOutputFixedInput(_from, _to, _amount); if (amountOut != 0) { swapManager.ROUTERS(rIdx).swapExactTokensForTokens( _amount, 1, _path, address(this), block.timestamp + 30 ); } } function _deposit(uint256 _amount) internal virtual; function _withdraw(uint256 _amount) internal virtual; function _approveToken(uint256 _amount) internal virtual; function _updatePendingFee() internal virtual; function _withdrawAll() internal virtual; function _migrateIn() internal virtual; function _migrateOut() internal virtual; function _claimReward() internal virtual; }
{ "evmVersion": "istanbul", "libraries": {}, "metadata": { "bytecodeHash": "ipfs", "useLiteralContent": true }, "optimizer": { "enabled": true, "runs": 200 }, "remappings": [], "outputSelection": { "*": { "*": [ "evm.bytecode", "evm.deployedBytecode", "devdoc", "userdoc", "metadata", "abi" ] } } }
Contract Security Audit
- No Contract Security Audit Submitted- Submit Audit Here
Contract ABI
API[{"inputs":[{"internalType":"address","name":"_controller","type":"address"},{"internalType":"address","name":"_pool","type":"address"},{"internalType":"address","name":"_receiptToken","type":"address"}],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"account","type":"address"}],"name":"Open","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"account","type":"address"}],"name":"Paused","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"account","type":"address"}],"name":"Shutdown","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"account","type":"address"}],"name":"Unpaused","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousSwapManager","type":"address"},{"indexed":true,"internalType":"address","name":"newSwapManager","type":"address"}],"name":"UpdatedSwapManager","type":"event"},{"inputs":[],"name":"NAME","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"VERSION","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"VSP","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_keeperAddress","type":"address"}],"name":"addKeeper","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"approveToken","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"beforeWithdraw","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"collateralToken","outputs":[{"internalType":"contract IERC20","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"controller","outputs":[{"internalType":"contract IController","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"convertFrom18","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"pure","type":"function"},{"inputs":[{"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"deposit","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"depositAll","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"interestEarned","outputs":[{"internalType":"uint256","name":"collateralEarned","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"isKeeper","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_token","type":"address"}],"name":"isReservedToken","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"isUpgradable","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"keepers","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"migrateIn","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"migrateOut","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"pause","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"paused","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"pool","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"rebalance","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"receiptToken","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_keeperAddress","type":"address"}],"name":"removeKeeper","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"resetApproval","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"stopEverything","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"swapManager","outputs":[{"internalType":"contract ISwapManager","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_fromToken","type":"address"}],"name":"sweepErc20","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"token","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalLocked","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"unpause","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_swapManager","type":"address"}],"name":"updateSwapManager","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"withdraw","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"withdrawAll","outputs":[],"stateMutability":"nonpayable","type":"function"}]
Deployed Bytecode
0x608060405234801561001057600080fd5b50600436106102065760003560e01c80637d7c2a1c1161011a578063b6b55f25116100ad578063ec78e8321161007c578063ec78e8321461049f578063f77c4791146104a7578063fb589de2146104af578063fc0c546a146104cc578063ffa1ad74146104d457610206565b8063b6b55f2514610437578063ba9de0e914610454578063d9fe3eae14610471578063de5f62681461049757610206565b8063a3f4df7e116100e9578063a3f4df7e146103a2578063b000c3281461041f578063b2016bd414610427578063b3fc176c1461042f57610206565b80637d7c2a1c146103825780638456cb591461038a578063853828b61461039257806399b71d5c1461039a57610206565b8063419f77531161019d5780635479d9401161016c5780635479d9401461033c57806356891412146103445780635c975abb1461034c5780636ba42aaa14610354578063709d039d1461037a57610206565b8063419f7753146102cc578063440d7248146102d45780634938649a1461030e5780634c36fad71461031657610206565b806335faf389116101d957806335faf3891461027c578063374261ab146102845780633f4ba83a1461029e5780634032b72b146102a657610206565b806314ae9f2e1461020b57806316f0115b146102335780632e1a7d4d14610257578063330b8b7114610274575b600080fd5b6102316004803603602081101561022157600080fd5b50356001600160a01b03166104dc565b005b61023b6106bc565b604080516001600160a01b039092168252519081900360200190f35b6102316004803603602081101561026d57600080fd5b50356106e0565b6102316107c4565b61023b61084b565b61028c610863565b60408051918252519081900360200190f35b61023161106e565b610231600480360360208110156102bc57600080fd5b50356001600160a01b03166110f1565b61023161122f565b6102fa600480360360208110156102ea57600080fd5b50356001600160a01b03166112b5565b604080519115158252519081900360200190f35b6102fa611409565b6102316004803603602081101561032c57600080fd5b50356001600160a01b0316611417565b6102fa6115a1565b61028c611642565b6102fa6117af565b6102fa6004803603602081101561036a57600080fd5b50356001600160a01b03166117b8565b61023b6117cd565b6102316117e2565b610231611a99565b610231611b1c565b610231611b9f565b6103aa611c2f565b6040805160208082528351818301528351919283929083019185019080838360005b838110156103e45781810151838201526020016103cc565b50505050905090810190601f1680156104115780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b610231611c5f565b61023b611ce2565b610231611d06565b6102316004803603602081101561044d57600080fd5b5035611d89565b61023b6004803603602081101561046a57600080fd5b5035611e0b565b6102316004803603602081101561048757600080fd5b50356001600160a01b0316611e32565b610231611ffa565b61023b61212c565b61023b612150565b61028c600480360360208110156104c557600080fd5b5035612174565b61023b612177565b6103aa61219b565b7f000000000000000000000000a4f1671d3aee73c05b552d57f2d16d3cfcbd02176001600160a01b031661050e6121bc565b6001600160a01b031614610557576040805162461bcd60e51b815260206004820152601c6024820152600080516020613cb7833981519152604482015290519081900360640190fd5b6001600160a01b03811660009081526002602052604090205460ff166105ae576040805162461bcd60e51b815260206004820152600760248201526610b5b2b2b832b960c91b604482015290519081900360640190fd5b60015460005b818160ff1610156106b757826001600160a01b031660018260ff16815481106105d957fe5b6000918252602090912001546001600160a01b031614156106af576001600160a01b0383166000908152600260205260409020805460ff1916905560018054600019840190811061062657fe5b600091825260209091200154600180546001600160a01b039092169160ff841690811061064f57fe5b9060005260206000200160006101000a8154816001600160a01b0302191690836001600160a01b03160217905550600180548061068857fe5b600082815260209020810160001990810180546001600160a01b03191690550190556106b7565b6001016105b4565b505050565b7f000000000000000000000000103cc17c2b1586e5cd9bad308690bcd0bbe54d5e81565b7f000000000000000000000000a4f1671d3aee73c05b552d57f2d16d3cfcbd02176001600160a01b03166107126121bc565b6001600160a01b0316148061075f57507f000000000000000000000000103cc17c2b1586e5cd9bad308690bcd0bbe54d5e6001600160a01b03166107546121bc565b6001600160a01b0316145b6107b0576040805162461bcd60e51b815260206004820152601860248201527f63616c6c65722d69732d6e6f742d617574686f72697a65640000000000000000604482015290519081900360640190fd5b6107b8610849565b6107c1816121c0565b50565b7f000000000000000000000000a4f1671d3aee73c05b552d57f2d16d3cfcbd02176001600160a01b03166107f66121bc565b6001600160a01b03161461083f576040805162461bcd60e51b815260206004820152601c6024820152600080516020613cb7833981519152604482015290519081900360640190fd5b61084960006122bf565b565b731b40183efb4dd766f11bda7a7c3ad8982e99842181565b6000807f000000000000000000000000951397286e4b78ae5827502ed494d7902d3cca8c6001600160a01b0316638bc6beb26040518163ffffffff1660e01b815260040160206040518083038186803b1580156108bf57600080fd5b505afa1580156108d3573d6000803e3d6000fd5b505050506040513d60208110156108e957600080fd5b505190506001600160a01b03811615610c9557606080826001600160a01b031663402914f5306040518263ffffffff1660e01b815260040180826001600160a01b0316815260200191505060006040518083038186803b15801561094c57600080fd5b505afa158015610960573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604090815281101561098957600080fd5b8101908080516040519392919084600160201b8211156109a857600080fd5b9083019060208201858111156109bd57600080fd5b82518660208202830111600160201b821117156109d957600080fd5b82525081516020918201928201910280838360005b83811015610a065781810151838201526020016109ee565b5050505090500160405260200180516040519392919084600160201b821115610a2e57600080fd5b908301906020820185811115610a4357600080fd5b82518660208202830111600160201b82111715610a5f57600080fd5b82525081516020918201928201910280838360005b83811015610a8c578181015183820152602001610a74565b5050505090500160405250505091509150600081600081518110610aac57fe5b6020026020010151118015610afa5750731b40183efb4dd766f11bda7a7c3ad8982e9984216001600160a01b031682600081518110610ae757fe5b60200260200101516001600160a01b0316145b15610c9257600060029054906101000a90046001600160a01b03166001600160a01b031663e8f983c8731b40183efb4dd766f11bda7a7c3ad8982e9984217f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc284600081518110610b6657fe5b60200260200101516040518463ffffffff1660e01b815260040180846001600160a01b03168152602001836001600160a01b03168152602001828152602001935050505060006040518083038186803b158015610bc257600080fd5b505afa158015610bd6573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f191682016040526060811015610bff57600080fd5b8101908080516040519392919084600160201b821115610c1e57600080fd5b908301906020820185811115610c3357600080fd5b82518660208202830111600160201b82111715610c4f57600080fd5b82525081516020918201928201910280838360005b83811015610c7c578181015183820152602001610c64565b5050505091909101604052506020015196505050505b50505b60607f000000000000000000000000951397286e4b78ae5827502ed494d7902d3cca8c6001600160a01b031663b49a60bb6040518163ffffffff1660e01b815260040160006040518083038186803b158015610cf057600080fd5b505afa158015610d04573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f191682016040526020811015610d2d57600080fd5b8101908080516040519392919084600160201b821115610d4c57600080fd5b908301906020820185811115610d6157600080fd5b82518660208202830111600160201b82111715610d7d57600080fd5b82525081516020918201928201910280838360005b83811015610daa578181015183820152602001610d92565b505050509190910160405250508251929350600091508190505b82811015610f27576000848281518110610dda57fe5b60200260200101516001600160a01b031663d4c3eea06040518163ffffffff1660e01b815260040160206040518083038186803b158015610e1a57600080fd5b505afa158015610e2e573d6000803e3d6000fd5b505050506040513d6020811015610e4457600080fd5b505185519091506000906001600160a01b037f000000000000000000000000951397286e4b78ae5827502ed494d7902d3cca8c1690639f2b283390889086908110610e8b57fe5b60200260200101516040518263ffffffff1660e01b815260040180826001600160a01b0316815260200191505060206040518083038186803b158015610ed057600080fd5b505afa158015610ee4573d6000803e3d6000fd5b505050506040513d6020811015610efa57600080fd5b5051905080821115610f1d57610f1a610f13838361248e565b85906124f0565b93505b5050600101610dc4565b5080156110675761106461105d7f000000000000000000000000951397286e4b78ae5827502ed494d7902d3cca8c6001600160a01b03166318160ddd6040518163ffffffff1660e01b815260040160206040518083038186803b158015610f8d57600080fd5b505afa158015610fa1573d6000803e3d6000fd5b505050506040513d6020811015610fb757600080fd5b5051604080516370a0823160e01b81523060048201529051611057916001600160a01b037f000000000000000000000000951397286e4b78ae5827502ed494d7902d3cca8c16916370a0823191602480820192602092909190829003018186803b15801561102457600080fd5b505afa158015611038573d6000803e3d6000fd5b505050506040513d602081101561104e57600080fd5b5051859061254a565b906125a3565b86906124f0565b94505b5050505090565b7f000000000000000000000000a4f1671d3aee73c05b552d57f2d16d3cfcbd02176001600160a01b03166110a06121bc565b6001600160a01b0316146110e9576040805162461bcd60e51b815260206004820152601c6024820152600080516020613cb7833981519152604482015290519081900360640190fd5b61084961260a565b7f000000000000000000000000a4f1671d3aee73c05b552d57f2d16d3cfcbd02176001600160a01b03166111236121bc565b6001600160a01b03161461116c576040805162461bcd60e51b815260206004820152601c6024820152600080516020613cb7833981519152604482015290519081900360640190fd5b6001600160a01b03811660009081526002602052604090205460ff16156111cb576040805162461bcd60e51b815260206004820152600e60248201526d30b63932b0b23c96b5b2b2b832b960911b604482015290519081900360640190fd5b6001805480820182557fb10e2d527612073b26eecdfd717e6a320cf44b4afac2b0732d9fcbe2b7fa0cf60180546001600160a01b039093166001600160a01b031990931683179055600091825260026020526040909120805460ff19169091179055565b7f000000000000000000000000103cc17c2b1586e5cd9bad308690bcd0bbe54d5e6001600160a01b03166112616121bc565b6001600160a01b031614610849576040805162461bcd60e51b815260206004820152601660248201527518d85b1b195c8b5a5ccb5b9bdd0b5d1a194b5c1bdbdb60521b604482015290519081900360640190fd5b6000807f000000000000000000000000951397286e4b78ae5827502ed494d7902d3cca8c6001600160a01b0316638bc6beb26040518163ffffffff1660e01b815260040160206040518083038186803b15801561131157600080fd5b505afa158015611325573d6000803e3d6000fd5b505050506040513d602081101561133b57600080fd5b505190507f000000000000000000000000951397286e4b78ae5827502ed494d7902d3cca8c6001600160a01b03908116908416148061140257506001600160a01b038116158015906114025750806001600160a01b031663b5fd73f8846040518263ffffffff1660e01b815260040180826001600160a01b0316815260200191505060206040518083038186803b1580156113d557600080fd5b505afa1580156113e9573d6000803e3d6000fd5b505050506040513d60208110156113ff57600080fd5b50515b9392505050565b600054610100900460ff1681565b7f000000000000000000000000a4f1671d3aee73c05b552d57f2d16d3cfcbd02176001600160a01b03166114496121bc565b6001600160a01b031614611492576040805162461bcd60e51b815260206004820152601c6024820152600080516020613cb7833981519152604482015290519081900360640190fd5b6001600160a01b0381166114e2576040805162461bcd60e51b8152602060048201526012602482015271736d2d616464726573732d69732d7a65726f60701b604482015290519081900360640190fd5b6000546001600160a01b0382811662010000909204161415611538576040805162461bcd60e51b815260206004820152600a602482015269736d2d69732d73616d6560b01b604482015290519081900360640190fd5b600080546040516001600160a01b03808516936201000090930416917f2d19927e7cac08ceb98b38898a4fdff6da6a27295b9a2d62fe250408ebe044e191a3600080546001600160a01b03909216620100000262010000600160b01b0319909216919091179055565b60007f000000000000000000000000951397286e4b78ae5827502ed494d7902d3cca8c6001600160a01b03166370a08231306040518263ffffffff1660e01b815260040180826001600160a01b0316815260200191505060206040518083038186803b15801561161057600080fd5b505afa158015611624573d6000803e3d6000fd5b505050506040513d602081101561163a57600080fd5b505115905090565b60008061179e7f000000000000000000000000951397286e4b78ae5827502ed494d7902d3cca8c6001600160a01b03166370a08231306040518263ffffffff1660e01b815260040180826001600160a01b0316815260200191505060206040518083038186803b1580156116b557600080fd5b505afa1580156116c9573d6000803e3d6000fd5b505050506040513d60208110156116df57600080fd5b5051604080516370a0823160e01b81526001600160a01b037f000000000000000000000000103cc17c2b1586e5cd9bad308690bcd0bbe54d5e8116600483015291517f000000000000000000000000951397286e4b78ae5827502ed494d7902d3cca8c909216916370a0823191602480820192602092909190829003018186803b15801561176c57600080fd5b505afa158015611780573d6000803e3d6000fd5b505050506040513d602081101561179657600080fd5b5051906124f0565b90506117a9816126fa565b91505090565b60005460ff1681565b60026020526000908152604090205460ff1681565b6000546201000090046001600160a01b031681565b600260006117ee6121bc565b6001600160a01b0316815260208101919091526040016000205460ff16611853576040805162461bcd60e51b815260206004820152601460248201527331b0b63632b916b4b996b737ba16b5b2b2b832b960611b604482015290519081900360640190fd5b61185b612764565b60007f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc26001600160a01b03166370a082317f000000000000000000000000103cc17c2b1586e5cd9bad308690bcd0bbe54d5e6040518263ffffffff1660e01b815260040180826001600160a01b0316815260200191505060206040518083038186803b1580156118ea57600080fd5b505afa1580156118fe573d6000803e3d6000fd5b505050506040513d602081101561191457600080fd5b505190508015611973576119736001600160a01b037f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc2167f000000000000000000000000103cc17c2b1586e5cd9bad308690bcd0bbe54d5e3084612923565b60007f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc26001600160a01b03166370a08231306040518263ffffffff1660e01b815260040180826001600160a01b0316815260200191505060206040518083038186803b1580156119e257600080fd5b505afa1580156119f6573d6000803e3d6000fd5b505050506040513d6020811015611a0c57600080fd5b505190508015611a95577f000000000000000000000000951397286e4b78ae5827502ed494d7902d3cca8c6001600160a01b031663b6b55f25826040518263ffffffff1660e01b815260040180828152602001915050600060405180830381600087803b158015611a7c57600080fd5b505af1158015611a90573d6000803e3d6000fd5b505050505b5050565b7f000000000000000000000000a4f1671d3aee73c05b552d57f2d16d3cfcbd02176001600160a01b0316611acb6121bc565b6001600160a01b031614611b14576040805162461bcd60e51b815260206004820152601c6024820152600080516020613cb7833981519152604482015290519081900360640190fd5b610849612983565b7f000000000000000000000000a4f1671d3aee73c05b552d57f2d16d3cfcbd02176001600160a01b0316611b4e6121bc565b6001600160a01b031614611b97576040805162461bcd60e51b815260206004820152601c6024820152600080516020613cb7833981519152604482015290519081900360640190fd5b610849612a04565b7f000000000000000000000000a4f1671d3aee73c05b552d57f2d16d3cfcbd02176001600160a01b0316611bd16121bc565b6001600160a01b031614611c1a576040805162461bcd60e51b815260206004820152601c6024820152600080516020613cb7833981519152604482015290519081900360640190fd5b611c2460006122bf565b6108496000196122bf565b60405180604001604052806014815260200173566573706572427269646765537472617465677960601b81525081565b7f000000000000000000000000a4f1671d3aee73c05b552d57f2d16d3cfcbd02176001600160a01b0316611c916121bc565b6001600160a01b031614611cda576040805162461bcd60e51b815260206004820152601c6024820152600080516020613cb7833981519152604482015290519081900360640190fd5b610849612b3e565b7f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc281565b7f000000000000000000000000a4f1671d3aee73c05b552d57f2d16d3cfcbd02176001600160a01b0316611d386121bc565b6001600160a01b031614611d81576040805162461bcd60e51b815260206004820152601c6024820152600080516020613cb7833981519152604482015290519081900360640190fd5b610849612e60565b60026000611d956121bc565b6001600160a01b0316815260208101919091526040016000205460ff16611dfa576040805162461bcd60e51b815260206004820152601460248201527331b0b63632b916b4b996b737ba16b5b2b2b832b960611b604482015290519081900360640190fd5b611e02610849565b6107c181613053565b60018181548110611e1857fe5b6000918252602090912001546001600160a01b0316905081565b60026000611e3e6121bc565b6001600160a01b0316815260208101919091526040016000205460ff16611ea3576040805162461bcd60e51b815260206004820152601460248201527331b0b63632b916b4b996b737ba16b5b2b2b832b960611b604482015290519081900360640190fd5b611eac816112b5565b15611ef5576040805162461bcd60e51b815260206004820152601460248201527306e6f742d616c6c6f7765642d746f2d73776565760641b604482015290519081900360640190fd5b6001600160a01b03811673eeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee1415611f4957611f447f000000000000000000000000103cc17c2b1586e5cd9bad308690bcd0bbe54d5e47613129565b6107c1565b6000816001600160a01b03166370a08231306040518263ffffffff1660e01b815260040180826001600160a01b0316815260200191505060206040518083038186803b158015611f9857600080fd5b505afa158015611fac573d6000803e3d6000fd5b505050506040513d6020811015611fc257600080fd5b50519050611a956001600160a01b0383167f000000000000000000000000103cc17c2b1586e5cd9bad308690bcd0bbe54d5e8361320e565b600260006120066121bc565b6001600160a01b0316815260208101919091526040016000205460ff1661206b576040805162461bcd60e51b815260206004820152601460248201527331b0b63632b916b4b996b737ba16b5b2b2b832b960611b604482015290519081900360640190fd5b6108497f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc26001600160a01b03166370a082317f000000000000000000000000103cc17c2b1586e5cd9bad308690bcd0bbe54d5e6040518263ffffffff1660e01b815260040180826001600160a01b0316815260200191505060206040518083038186803b1580156120fb57600080fd5b505afa15801561210f573d6000803e3d6000fd5b505050506040513d602081101561212557600080fd5b5051611d89565b7f000000000000000000000000951397286e4b78ae5827502ed494d7902d3cca8c81565b7f000000000000000000000000a4f1671d3aee73c05b552d57f2d16d3cfcbd021781565b90565b7f000000000000000000000000951397286e4b78ae5827502ed494d7902d3cca8c90565b604051806040016040528060058152602001640322e312e360dc1b81525081565b3390565b6121d16121cc82613260565b613333565b6107c17f000000000000000000000000103cc17c2b1586e5cd9bad308690bcd0bbe54d5e7f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc26001600160a01b03166370a08231306040518263ffffffff1660e01b815260040180826001600160a01b0316815260200191505060206040518083038186803b15801561226257600080fd5b505afa158015612276573d6000803e3d6000fd5b505050506040513d602081101561228c57600080fd5b50516001600160a01b037f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc216919061320e565b6123136001600160a01b037f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc2167f000000000000000000000000103cc17c2b1586e5cd9bad308690bcd0bbe54d5e8361354f565b6123676001600160a01b037f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc2167f000000000000000000000000951397286e4b78ae5827502ed494d7902d3cca8c8361354f565b60005b600060029054906101000a90046001600160a01b03166001600160a01b031663c2fba6676040518163ffffffff1660e01b815260040160206040518083038186803b1580156123b857600080fd5b505afa1580156123cc573d6000803e3d6000fd5b505050506040513d60208110156123e257600080fd5b5051811015611a955760005460408051636e74a6f760e01b8152600481018490529051612486926201000090046001600160a01b031691636e74a6f7916024808301926020929190829003018186803b15801561243e57600080fd5b505afa158015612452573d6000803e3d6000fd5b505050506040513d602081101561246857600080fd5b5051731b40183efb4dd766f11bda7a7c3ad8982e998421908461354f565b60010161236a565b6000828211156124e5576040805162461bcd60e51b815260206004820152601e60248201527f536166654d6174683a207375627472616374696f6e206f766572666c6f770000604482015290519081900360640190fd5b508082035b92915050565b600082820183811015611402576040805162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015290519081900360640190fd5b600082612559575060006124ea565b8282028284828161256657fe5b04146114025760405162461bcd60e51b8152600401808060200182810382526021815260200180613c6c6021913960400191505060405180910390fd5b60008082116125f9576040805162461bcd60e51b815260206004820152601a60248201527f536166654d6174683a206469766973696f6e206279207a65726f000000000000604482015290519081900360640190fd5b81838161260257fe5b049392505050565b60005460ff16612658576040805162461bcd60e51b815260206004820152601460248201527314185d5cd8589b194e881b9bdd081c185d5cd95960621b604482015290519081900360640190fd5b600054610100900460ff16156126aa576040805162461bcd60e51b81526020600482015260126024820152712830bab9b0b136329d1039b43aba3237bbb760711b604482015290519081900360640190fd5b6000805460ff191690557f5db9ee0a495bf2e6ff9c91a7834c1ba4fdd244a5e8aa4e537bd38aeae4b073aa6126dd6121bc565b604080516001600160a01b039092168252519081900360200190a1565b60006124ea670de0b6b3a76400006110577f000000000000000000000000951397286e4b78ae5827502ed494d7902d3cca8c6001600160a01b03166399530b066040518163ffffffff1660e01b815260040160206040518083038186803b15801561102457600080fd5b60007f000000000000000000000000951397286e4b78ae5827502ed494d7902d3cca8c6001600160a01b0316638bc6beb26040518163ffffffff1660e01b815260040160206040518083038186803b1580156127bf57600080fd5b505afa1580156127d3573d6000803e3d6000fd5b505050506040513d60208110156127e957600080fd5b505190506001600160a01b038116156107c1576040805163d279c19160e01b815230600482015290516001600160a01b0383169163d279c19191602480830192600092919082900301818387803b15801561284357600080fd5b505af1158015612857573d6000803e3d6000fd5b5050604080516370a0823160e01b8152306004820152905160009350731b40183efb4dd766f11bda7a7c3ad8982e99842192506370a0823191602480820192602092909190829003018186803b1580156128b057600080fd5b505afa1580156128c4573d6000803e3d6000fd5b505050506040513d60208110156128da57600080fd5b505190508015611a9557611a95731b40183efb4dd766f11bda7a7c3ad8982e9984217f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc283613662565b604080516001600160a01b0380861660248301528416604482015260648082018490528251808303909101815260849091019091526020810180516001600160e01b03166323b872dd60e01b17905261297d9085906139b0565b50505050565b60005460ff16156129ce576040805162461bcd60e51b815260206004820152601060248201526f14185d5cd8589b194e881c185d5cd95960821b604482015290519081900360640190fd5b6000805460ff191660011790557f62e78cea01bee320cd4e420270b5ea74000d11b0c9f74754ebdbfc544b05a2586126dd6121bc565b612aa57f000000000000000000000000951397286e4b78ae5827502ed494d7902d3cca8c6001600160a01b03166370a08231306040518263ffffffff1660e01b815260040180826001600160a01b0316815260200191505060206040518083038186803b158015612a7457600080fd5b505afa158015612a88573d6000803e3d6000fd5b505050506040513d6020811015612a9e57600080fd5b5051613333565b612aad612764565b6108497f000000000000000000000000103cc17c2b1586e5cd9bad308690bcd0bbe54d5e7f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc26001600160a01b03166370a08231306040518263ffffffff1660e01b815260040180826001600160a01b0316815260200191505060206040518083038186803b15801561226257600080fd5b7f000000000000000000000000a4f1671d3aee73c05b552d57f2d16d3cfcbd02176001600160a01b0316635b16ebb77f000000000000000000000000103cc17c2b1586e5cd9bad308690bcd0bbe54d5e6040518263ffffffff1660e01b815260040180826001600160a01b0316815260200191505060206040518083038186803b158015612bcb57600080fd5b505afa158015612bdf573d6000803e3d6000fd5b505050506040513d6020811015612bf557600080fd5b5051612c3b576040805162461bcd60e51b815260206004820152601060248201526f1b9bdd0b584b5d985b1a590b5c1bdbdb60821b604482015290519081900360640190fd5b306001600160a01b03167f000000000000000000000000a4f1671d3aee73c05b552d57f2d16d3cfcbd02176001600160a01b031663228bfd9f7f000000000000000000000000103cc17c2b1586e5cd9bad308690bcd0bbe54d5e6040518263ffffffff1660e01b815260040180826001600160a01b0316815260200191505060206040518083038186803b158015612cd257600080fd5b505afa158015612ce6573d6000803e3d6000fd5b505050506040513d6020811015612cfc57600080fd5b50516001600160a01b031614612d50576040805162461bcd60e51b81526020600482015260146024820152736e6f742d612d76616c69642d737472617465677960601b604482015290519081900360640190fd5b6108497f000000000000000000000000103cc17c2b1586e5cd9bad308690bcd0bbe54d5e307f000000000000000000000000951397286e4b78ae5827502ed494d7902d3cca8c6001600160a01b03166370a082317f000000000000000000000000103cc17c2b1586e5cd9bad308690bcd0bbe54d5e6040518263ffffffff1660e01b815260040180826001600160a01b0316815260200191505060206040518083038186803b158015612e0257600080fd5b505afa158015612e16573d6000803e3d6000fd5b505050506040513d6020811015612e2c57600080fd5b50516001600160a01b037f000000000000000000000000951397286e4b78ae5827502ed494d7902d3cca8c16929190612923565b7f000000000000000000000000a4f1671d3aee73c05b552d57f2d16d3cfcbd02176001600160a01b0316635b16ebb77f000000000000000000000000103cc17c2b1586e5cd9bad308690bcd0bbe54d5e6040518263ffffffff1660e01b815260040180826001600160a01b0316815260200191505060206040518083038186803b158015612eed57600080fd5b505afa158015612f01573d6000803e3d6000fd5b505050506040513d6020811015612f1757600080fd5b5051612f5d576040805162461bcd60e51b815260206004820152601060248201526f1b9bdd0b584b5d985b1a590b5c1bdbdb60821b604482015290519081900360640190fd5b612f65612983565b6108497f000000000000000000000000103cc17c2b1586e5cd9bad308690bcd0bbe54d5e7f000000000000000000000000951397286e4b78ae5827502ed494d7902d3cca8c6001600160a01b03166370a08231306040518263ffffffff1660e01b815260040180826001600160a01b0316815260200191505060206040518083038186803b158015612ff657600080fd5b505afa15801561300a573d6000803e3d6000fd5b505050506040513d602081101561302057600080fd5b50516001600160a01b037f000000000000000000000000951397286e4b78ae5827502ed494d7902d3cca8c16919061320e565b6130a86001600160a01b037f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc2167f000000000000000000000000103cc17c2b1586e5cd9bad308690bcd0bbe54d5e3084612923565b7f000000000000000000000000951397286e4b78ae5827502ed494d7902d3cca8c6001600160a01b031663b6b55f25826040518263ffffffff1660e01b815260040180828152602001915050600060405180830381600087803b15801561310e57600080fd5b505af1158015613122573d6000803e3d6000fd5b5050505050565b8047101561317e576040805162461bcd60e51b815260206004820152601d60248201527f416464726573733a20696e73756666696369656e742062616c616e6365000000604482015290519081900360640190fd5b6040516000906001600160a01b0384169083908381818185875af1925050503d80600081146131c9576040519150601f19603f3d011682016040523d82523d6000602084013e6131ce565b606091505b50509050806106b75760405162461bcd60e51b815260040180806020018281038252603a815260200180613c32603a913960400191505060405180910390fd5b604080516001600160a01b038416602482015260448082018490528251808303909101815260649091019091526020810180516001600160e01b031663a9059cbb60e01b1790526106b79084906139b0565b6000807f000000000000000000000000951397286e4b78ae5827502ed494d7902d3cca8c6001600160a01b03166399530b066040518163ffffffff1660e01b815260040160206040518083038186803b1580156132bc57600080fd5b505afa1580156132d0573d6000803e3d6000fd5b505050506040513d60208110156132e657600080fd5b5051905060006133028261105786670de0b6b3a764000061254a565b905061331a670de0b6b3a7640000611057838561254a565b8411613326578061332b565b806001015b949350505050565b80156107c15760007f000000000000000000000000951397286e4b78ae5827502ed494d7902d3cca8c6001600160a01b03166370a08231306040518263ffffffff1660e01b815260040180826001600160a01b0316815260200191505060206040518083038186803b1580156133a857600080fd5b505afa1580156133bc573d6000803e3d6000fd5b505050506040513d60208110156133d257600080fd5b505160408051632e1a7d4d60e01b81526004810185905290519192506001600160a01b037f000000000000000000000000951397286e4b78ae5827502ed494d7902d3cca8c1691632e1a7d4d9160248082019260009290919082900301818387803b15801561344057600080fd5b505af1158015613454573d6000803e3d6000fd5b5050505061346b828261248e90919063ffffffff16565b604080516370a0823160e01b815230600482015290516001600160a01b037f000000000000000000000000951397286e4b78ae5827502ed494d7902d3cca8c16916370a08231916024808301926020929190829003018186803b1580156134d157600080fd5b505afa1580156134e5573d6000803e3d6000fd5b505050506040513d60208110156134fb57600080fd5b505114611a95576040805162461bcd60e51b815260206004820152601b60248201527f4e6f7420656e6f756768207368617265732077697468647261776e0000000000604482015290519081900360640190fd5b8015806135d5575060408051636eb1769f60e11b81523060048201526001600160a01b03848116602483015291519185169163dd62ed3e91604480820192602092909190829003018186803b1580156135a757600080fd5b505afa1580156135bb573d6000803e3d6000fd5b505050506040513d60208110156135d157600080fd5b5051155b6136105760405162461bcd60e51b8152600401808060200182810382526036815260200180613cd76036913960400191505060405180910390fd5b604080516001600160a01b038416602482015260448082018490528251808303909101815260649091019091526020810180516001600160e01b031663095ea7b360e01b1790526106b79084906139b0565b6000805460408051631d1f307960e31b81526001600160a01b038781166004830152868116602483015260448201869052915160609493849362010000909104169163e8f983c89160648083019286929190829003018186803b1580156136c857600080fd5b505afa1580156136dc573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052606081101561370557600080fd5b8101908080516040519392919084600160201b82111561372457600080fd5b90830190602082018581111561373957600080fd5b82518660208202830111600160201b8211171561375557600080fd5b82525081516020918201928201910280838360005b8381101561378257818101518382015260200161376a565b5050505091909101604090815260208301519201519497509095509293505083159150611a90905057600060029054906101000a90046001600160a01b03166001600160a01b0316636e74a6f7826040518263ffffffff1660e01b81526004018082815260200191505060206040518083038186803b15801561380457600080fd5b505afa158015613818573d6000803e3d6000fd5b505050506040513d602081101561382e57600080fd5b50516040516338ed173960e01b8152600481018681526001602483018190523060648401819052601e42016084850181905260a060448601908152895160a487015289516001600160a01b03909716966338ed1739968c968c9594939092909160c401906020878101910280838360005b838110156138b757818101518382015260200161389f565b505050509050019650505050505050600060405180830381600087803b1580156138e057600080fd5b505af11580156138f4573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052602081101561391d57600080fd5b8101908080516040519392919084600160201b82111561393c57600080fd5b90830190602082018581111561395157600080fd5b82518660208202830111600160201b8211171561396d57600080fd5b82525081516020918201928201910280838360005b8381101561399a578181015183820152602001613982565b5050505090500160405250505050505050505050565b6060613a05826040518060400160405280602081526020017f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564815250856001600160a01b0316613a619092919063ffffffff16565b8051909150156106b757808060200190516020811015613a2457600080fd5b50516106b75760405162461bcd60e51b815260040180806020018281038252602a815260200180613c8d602a913960400191505060405180910390fd5b606061332b848460008585613a7585613b87565b613ac6576040805162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e7472616374000000604482015290519081900360640190fd5b60006060866001600160a01b031685876040518082805190602001908083835b60208310613b055780518252601f199092019160209182019101613ae6565b6001836020036101000a03801982511681845116808217855250505050505090500191505060006040518083038185875af1925050503d8060008114613b67576040519150601f19603f3d011682016040523d82523d6000602084013e613b6c565b606091505b5091509150613b7c828286613b8d565b979650505050505050565b3b151590565b60608315613b9c575081611402565b825115613bac5782518084602001fd5b8160405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b83811015613bf6578181015183820152602001613bde565b50505050905090810190601f168015613c235780820380516001836020036101000a031916815260200191505b509250505060405180910390fdfe416464726573733a20756e61626c6520746f2073656e642076616c75652c20726563697069656e74206d61792068617665207265766572746564536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f775361666545524332303a204552433230206f7065726174696f6e20646964206e6f74207375636365656463616c6c65722d69732d6e6f742d7468652d636f6e74726f6c6c6572000000005361666545524332303a20617070726f76652066726f6d206e6f6e2d7a65726f20746f206e6f6e2d7a65726f20616c6c6f77616e6365a264697066735822122003bdb694cb1ee083025e8916dad8ec034a2af906d2848cf0161120bd1e62ca3d64736f6c634300060c0033
Loading...
Loading
Loading...
Loading
Multichain Portfolio | 35 Chains
Chain | Token | Portfolio % | Price | Amount | Value |
---|
Loading...
Loading
Loading...
Loading
Loading...
Loading
[ Download: CSV Export ]
A contract address hosts a smart contract, which is a set of code stored on the blockchain that runs when predetermined conditions are met. Learn more about addresses in our Knowledge Base.