Contract Overview
Balance:
0 FTM
FTM Value:
$0.00
My Name Tag:
Not Available, login to update
Txn Hash | Method |
Block
|
From
|
To
|
Value | [Txn Fee] | |||
---|---|---|---|---|---|---|---|---|---|
0x59754c655596e48d3642f614b0df534f2c3f885fbbec04b4be58f7c19f31a404 | Create Vault Tok... | 45947438 | 207 days 7 hrs ago | Tarot: Deployer | IN | 0x51d49f3731a9591d6eb4fe79523f20ae5e560ba7 | 0 FTM | 0.015845956325 | |
0xcc475a6fd1d028004625fe4ecfe8ab65cce5b36d60dffe035572c832a769cdae | Create Vault Tok... | 45947434 | 207 days 7 hrs ago | Tarot: Deployer | IN | 0x51d49f3731a9591d6eb4fe79523f20ae5e560ba7 | 0 FTM | 0.015847826247 | |
0x31452f28b530afe410a8611bfc32e05cc3bbc042aa41965075788225752c9055 | Create Vault Tok... | 45947430 | 207 days 7 hrs ago | Tarot: Deployer | IN | 0x51d49f3731a9591d6eb4fe79523f20ae5e560ba7 | 0 FTM | 0.015847744441 | |
0x3bfdd4230846aef1cb2281a433f6c025ecc5b25f8d0792fee384fd02fbcee6e8 | Create Vault Tok... | 45947426 | 207 days 7 hrs ago | Tarot: Deployer | IN | 0x51d49f3731a9591d6eb4fe79523f20ae5e560ba7 | 0 FTM | 0.015842748811 | |
0x52ebdeb79abea5083f38c4fefc856def6a062087e5e02bcf25310627080bbda9 | Create Vault Tok... | 45947424 | 207 days 7 hrs ago | Tarot: Deployer | IN | 0x51d49f3731a9591d6eb4fe79523f20ae5e560ba7 | 0 FTM | 0.015858029029 | |
0xf6ca4957ae149e4a6ed026eed8d48b5b7bec7c84404a14d67507bfbf4766d338 | Create Vault Tok... | 45947420 | 207 days 7 hrs ago | Tarot: Deployer | IN | 0x51d49f3731a9591d6eb4fe79523f20ae5e560ba7 | 0 FTM | 0.015879766907 | |
0x2c27d626ee11b84bff67802571ea4fe8c4cbf979729a958c68a9757d0ec27470 | Create Vault Tok... | 45947414 | 207 days 7 hrs ago | Tarot: Deployer | IN | 0x51d49f3731a9591d6eb4fe79523f20ae5e560ba7 | 0 FTM | 0.015882922408 | |
0x8afa8e969a423729d1e68e565db734c5eaa06408ed6d8dd55e499cb66894b80e | Create Vault Tok... | 45947405 | 207 days 7 hrs ago | Tarot: Deployer | IN | 0x51d49f3731a9591d6eb4fe79523f20ae5e560ba7 | 0 FTM | 0.01586467895 | |
0x5d6c77e04719b5d7d70af41d07dea4f770db745037e293b49d50620d9977361e | Create Vault Tok... | 45947401 | 207 days 7 hrs ago | Tarot: Deployer | IN | 0x51d49f3731a9591d6eb4fe79523f20ae5e560ba7 | 0 FTM | 0.015878609891 | |
0x3a8432b32a63868abbaa122cb9ee615b8cafa21fc05e4b64891d3e64a73054b1 | Create Vault Tok... | 45947397 | 207 days 7 hrs ago | Tarot: Deployer | IN | 0x51d49f3731a9591d6eb4fe79523f20ae5e560ba7 | 0 FTM | 0.016107196816 | |
0x200b309e681aee978faabc4d80a85891f2182a88fdf1afc7b0ea083a55387e92 | Create Vault Tok... | 45947393 | 207 days 7 hrs ago | Tarot: Deployer | IN | 0x51d49f3731a9591d6eb4fe79523f20ae5e560ba7 | 0 FTM | 0.015879591603 | |
0xc74230a08ff054b7eee60859102d45d64d20ed503dd683b74f16b503b9e8e8f9 | Create Vault Tok... | 45947386 | 207 days 7 hrs ago | Tarot: Deployer | IN | 0x51d49f3731a9591d6eb4fe79523f20ae5e560ba7 | 0 FTM | 0.030459499998 | |
0xe7330093e0335d2b24942a0b0c77788b194801e05a906dc28337ec045cc5ed58 | Create Vault Tok... | 45947383 | 207 days 7 hrs ago | Tarot: Deployer | IN | 0x51d49f3731a9591d6eb4fe79523f20ae5e560ba7 | 0 FTM | 0.045964203997 | |
0x22cac410327984f993be133a7788e78bb86e53c3c8d814908d1f82a5ed51040a | 0x60806040 | 45316376 | 216 days 9 hrs ago | Tarot: Deployer | IN | Create: SpiritV2VaultTokenFactory | 0 FTM | 0.005617537423 |
[ Download CSV Export ]
Latest 14 internal transactions
[ Download CSV Export ]
Contract Name:
SpiritV2VaultTokenFactory
Compiler Version
v0.5.16+commit.9c3226ce
Optimization Enabled:
Yes with 200 runs
Other Settings:
default evmVersion
Contract Source Code (Solidity Standard Json-Input format)
pragma solidity =0.5.16; import "@openzeppelin/contracts/ownership/Ownable.sol"; import "./SpiritV2VaultToken.sol"; import "./interfaces/ISpiritV2VaultTokenFactory.sol"; contract SpiritV2VaultTokenFactory is Ownable, ISpiritV2VaultTokenFactory { address public optiSwap; address public router; address public gaugeVaultProxy; address public pairFactory; address public rewardsToken; mapping(address => address) public getVaultToken; address[] public allVaultTokens; constructor( address _optiSwap, address _router, address _gaugeVaultProxy, address _pairFactory, address _rewardsToken ) public { optiSwap = _optiSwap; router = _router; gaugeVaultProxy = _gaugeVaultProxy; pairFactory = _pairFactory; rewardsToken = _rewardsToken; } function allVaultTokensLength() external view returns (uint256) { return allVaultTokens.length; } function createVaultToken(address _underlying) external returns (address vaultToken) { require( getVaultToken[_underlying] == address(0), "VaultTokenFactory: POOL_EXISTS" ); require(!ISpiritV2BaseV1Pair(_underlying).stable(), "VaultTokenFactory: IS_STABLE"); bytes memory bytecode = type(SpiritV2VaultToken).creationCode; assembly { vaultToken := create2(0, add(bytecode, 32), mload(bytecode), _underlying) } SpiritV2VaultToken(vaultToken)._initialize( _underlying, optiSwap, router, gaugeVaultProxy, pairFactory, rewardsToken ); getVaultToken[_underlying] = vaultToken; allVaultTokens.push(vaultToken); emit VaultTokenCreated(_underlying, vaultToken, allVaultTokens.length); } }
pragma solidity ^0.5.0; import "../GSN/Context.sol"; /** * @dev Contract module which provides a basic access control mechanism, where * there is an account (an owner) that can be granted exclusive access to * specific functions. * * This module is used through inheritance. It will make available the modifier * `onlyOwner`, which can be applied to your functions to restrict their use to * the owner. */ contract Ownable is Context { address private _owner; event OwnershipTransferred(address indexed previousOwner, address indexed newOwner); /** * @dev Initializes the contract setting the deployer as the initial owner. */ constructor () internal { address msgSender = _msgSender(); _owner = msgSender; emit OwnershipTransferred(address(0), msgSender); } /** * @dev Returns the address of the current owner. */ function owner() public view returns (address) { return _owner; } /** * @dev Throws if called by any account other than the owner. */ modifier onlyOwner() { require(isOwner(), "Ownable: caller is not the owner"); _; } /** * @dev Returns true if the caller is the current owner. */ function isOwner() public view returns (bool) { return _msgSender() == _owner; } /** * @dev Leaves the contract without owner. It will not be possible to call * `onlyOwner` functions anymore. Can only be called by the current owner. * * NOTE: Renouncing ownership will leave the contract without an owner, * thereby removing any functionality that is only available to the owner. */ function renounceOwnership() public onlyOwner { emit OwnershipTransferred(_owner, address(0)); _owner = address(0); } /** * @dev Transfers ownership of the contract to a new account (`newOwner`). * Can only be called by the current owner. */ function transferOwnership(address newOwner) public onlyOwner { _transferOwnership(newOwner); } /** * @dev Transfers ownership of the contract to a new account (`newOwner`). */ function _transferOwnership(address newOwner) internal { require(newOwner != address(0), "Ownable: new owner is the zero address"); emit OwnershipTransferred(_owner, newOwner); _owner = newOwner; } }
pragma solidity =0.5.16; import "@openzeppelin/contracts/ownership/Ownable.sol"; import "./PoolToken.sol"; import "./interfaces/IGaugeVaultProxy.sol"; import "./interfaces/IGaugeVaultProxyAdmin.sol"; import "./interfaces/IOptiSwap.sol"; import "./interfaces/IBaseV1Router01.sol"; import "./interfaces/ISpiritV2BaseV1Pair.sol"; import "./interfaces/ISpiritV2VaultToken.sol"; import "./interfaces/IUniswapV2Pair.sol"; import "./interfaces/IERC20.sol"; import "./libraries/SafeToken.sol"; import "./libraries/Math.sol"; interface OptiSwapPair { function swap(uint amount0Out, uint amount1Out, address to, bytes calldata data) external; } contract SpiritV2VaultToken is ISpiritV2VaultToken, PoolToken { using SafeToken for address; bool public constant isVaultToken = true; bool public constant stable = false; address public optiSwap; address public router; address public gaugeVaultProxy; address public pairFactory; address public rewardsToken; address public WETH; address public token0; address public token1; uint256 public constant MIN_REINVEST_BOUNTY = 0.001e18; uint256 public constant MAX_REINVEST_BOUNTY = 0.01e18; uint256 public REINVEST_BOUNTY = MAX_REINVEST_BOUNTY; event Reinvest(address indexed caller, uint256 reward, uint256 bounty); event UpdateReinvestBounty(uint256 _newReinvestBounty); function _initialize( address _underlying, address _optiSwap, address _router, address _gaugeVaultProxy, address _pairFactory, address _rewardsToken ) external { require(factory == address(0), "VaultToken: FACTORY_ALREADY_SET"); // sufficient check factory = msg.sender; _setName("Tarot Vault Token", "vTAROT"); underlying = _underlying; optiSwap = _optiSwap; gaugeVaultProxy = _gaugeVaultProxy; address gaugeVaultProxyAdmin = IGaugeVaultProxy(gaugeVaultProxy).admin(); require(gaugeVaultProxyAdmin != address(0), "VaultToken: NO_GVP_ADMIN"); require(IGaugeVaultProxyAdmin(gaugeVaultProxyAdmin).getGauge(underlying) != address(0), "VaultToken: NO_GAUGE"); router = _router; pairFactory = _pairFactory; WETH = IBaseV1Router01(_router).wftm(); (token0, token1) = ISpiritV2BaseV1Pair(_underlying).tokens(); rewardsToken = _rewardsToken; } function updateReinvestBounty(uint256 _newReinvestBounty) external onlyFactoryOwner { require(_newReinvestBounty >= MIN_REINVEST_BOUNTY && _newReinvestBounty <= MAX_REINVEST_BOUNTY, "VaultToken: INVLD_REINVEST_BOUNTY"); REINVEST_BOUNTY = _newReinvestBounty; emit UpdateReinvestBounty(_newReinvestBounty); } /*** PoolToken Overrides ***/ function _update() internal { IGaugeVaultProxyAdmin gvpAdmin = IGaugeVaultProxyAdmin(IGaugeVaultProxy(gaugeVaultProxy).admin()); uint256 _totalBalance = gvpAdmin.gaugeBalanceOf(address(this)); totalBalance = _totalBalance; emit Sync(_totalBalance); } // this low-level function should be called from another contract function mint(address minter) external nonReentrant update returns (uint256 mintTokens) { uint256 mintAmount = underlying.myBalance(); IGaugeVaultProxyAdmin gvpAdmin = IGaugeVaultProxyAdmin(IGaugeVaultProxy(gaugeVaultProxy).admin()); // handle pools with deposit fees by checking balance before and after deposit uint256 _totalBalanceBefore = gvpAdmin.gaugeBalanceOf(address(this)); underlying.safeApprove(address(gvpAdmin), 0); underlying.safeApprove(address(gvpAdmin), mintAmount); gvpAdmin.depositInGauge(mintAmount); uint256 _totalBalanceAfter = gvpAdmin.gaugeBalanceOf(address(this)); mintTokens = _totalBalanceAfter.sub(_totalBalanceBefore).mul(1e18).div(exchangeRate()); if (totalSupply == 0) { // permanently lock the first MINIMUM_LIQUIDITY tokens mintTokens = mintTokens.sub(MINIMUM_LIQUIDITY); _mint(address(0), MINIMUM_LIQUIDITY); } require(mintTokens > 0, "VaultToken: MINT_AMOUNT_ZERO"); _mint(minter, mintTokens); emit Mint(msg.sender, minter, mintAmount, mintTokens); } // this low-level function should be called from another contract function redeem(address redeemer) external nonReentrant update returns (uint256 redeemAmount) { uint256 redeemTokens = balanceOf[address(this)]; redeemAmount = redeemTokens.mul(exchangeRate()).div(1e18); require(redeemAmount > 0, "VaultToken: REDEEM_AMOUNT_ZERO"); require(redeemAmount <= totalBalance, "VaultToken: INSUFFICIENT_CASH"); _burn(address(this), redeemTokens); IGaugeVaultProxyAdmin gvpAdmin = IGaugeVaultProxyAdmin(IGaugeVaultProxy(gaugeVaultProxy).admin()); gvpAdmin.withdrawFromGauge(redeemAmount); _safeTransfer(redeemer, redeemAmount); emit Redeem(msg.sender, redeemer, redeemAmount, redeemTokens); } /*** Reinvest ***/ function _optimalDepositA( uint256 _amountA, uint256 _reserveA ) internal view returns (uint256) { uint256 pairFee = ISpiritV2BaseV1Pair(underlying).fee(); uint256 swapFee = uint256(1000000).div(pairFee); uint256 swapFeeFactor = uint256(1000000).sub(swapFee); uint256 a = uint256(1000000).add(swapFeeFactor).mul(_reserveA); uint256 b = _amountA.mul(1000000).mul(_reserveA).mul(4).mul(swapFeeFactor); uint256 c = Math.sqrt(a.mul(a).add(b)); uint256 d = uint256(2).mul(swapFeeFactor); return c.sub(a).div(d); } function approveRouter(address token, uint256 amount) internal { if (IERC20(token).allowance(address(this), router) >= amount) return; token.safeApprove(address(router), uint256(-1)); } function swapExactTokensForTokens( address tokenIn, address tokenOut, uint256 amount ) internal { approveRouter(tokenIn, amount); IBaseV1Router01(router).swapExactTokensForTokensSimple(amount, 0, tokenIn, tokenOut, false, address(this), block.timestamp); } function addLiquidity( address tokenA, address tokenB, uint256 amountA, uint256 amountB ) internal returns (uint256 liquidity) { approveRouter(tokenA, amountA); approveRouter(tokenB, amountB); (, , liquidity) = IBaseV1Router01(router).addLiquidity(tokenA, tokenB, false, amountA, amountB, 0, 0, address(this), block.timestamp); } function swapTokensForBestAmountOut( IOptiSwap _optiSwap, address tokenIn, address tokenOut, uint256 amountIn ) internal returns (uint256 amountOut) { if (tokenIn == tokenOut) { return amountIn; } address pair; (pair, amountOut) = _optiSwap.getBestAmountOut(amountIn, tokenIn, tokenOut); require(pair != address(0), "NO_PAIR"); tokenIn.safeTransfer(pair, amountIn); if (tokenIn < tokenOut) { OptiSwapPair(pair).swap(0, amountOut, address(this), new bytes(0)); } else { OptiSwapPair(pair).swap(amountOut, 0, address(this), new bytes(0)); } } function optiSwapExactTokensForTokens( address tokenIn, address tokenOut, uint256 amountIn ) internal returns (uint256 amountOut) { if (tokenIn == tokenOut) { return amountIn; } IOptiSwap _optiSwap = IOptiSwap(optiSwap); address nextHop = _optiSwap.getBridgeToken(tokenIn); if (nextHop == tokenOut) { return swapTokensForBestAmountOut(_optiSwap, tokenIn, tokenOut, amountIn); } address waypoint = _optiSwap.getBridgeToken(tokenOut); if (tokenIn == waypoint) { return swapTokensForBestAmountOut(_optiSwap, tokenIn, tokenOut, amountIn); } uint256 hopAmountOut; if (nextHop != tokenIn) { hopAmountOut = swapTokensForBestAmountOut(_optiSwap, tokenIn, nextHop, amountIn); } else { hopAmountOut = amountIn; } if (nextHop == waypoint) { return swapTokensForBestAmountOut(_optiSwap, nextHop, tokenOut, hopAmountOut); } else if (waypoint == tokenOut) { return optiSwapExactTokensForTokens(nextHop, tokenOut, hopAmountOut); } else { uint256 waypointAmountOut = optiSwapExactTokensForTokens(nextHop, waypoint, hopAmountOut); return swapTokensForBestAmountOut(_optiSwap, waypoint, tokenOut, waypointAmountOut); } } function _getReward() internal returns (uint256 amount) { IGaugeVaultProxyAdmin gvpAdmin = IGaugeVaultProxyAdmin(IGaugeVaultProxy(gaugeVaultProxy).admin()); gvpAdmin.claimGaugeReward(); return rewardsToken.myBalance(); } function getReward() external nonReentrant returns (uint256) { require(msg.sender == tx.origin); return _getReward(); } function reinvest() external nonReentrant update { require(msg.sender == tx.origin); // 1. Withdraw all the rewards. uint256 reward = _getReward(); if (reward == 0) return; // 2. Send the reward bounty to the caller. uint256 bounty = reward.mul(REINVEST_BOUNTY) / 1e18; rewardsToken.safeTransfer(msg.sender, bounty); // 3. Convert all the remaining rewards to token0 or token1. address tokenA; address tokenB; if (token0 == rewardsToken || token1 == rewardsToken) { (tokenA, tokenB) = token0 == rewardsToken ? (token0, token1) : (token1, token0); } else { if (token1 == WETH) { (tokenA, tokenB) = (token1, token0); } else { (tokenA, tokenB) = (token0, token1); } optiSwapExactTokensForTokens(rewardsToken, tokenA, reward.sub(bounty)); } // 4. Convert tokenA to LP Token underlyings. uint256 totalAmountA = tokenA.myBalance(); assert(totalAmountA > 0); (uint256 r0, uint256 r1, ) = IUniswapV2Pair(underlying).getReserves(); uint256 reserveA = tokenA == token0 ? r0 : r1; uint256 swapAmount = _optimalDepositA(totalAmountA, reserveA); swapExactTokensForTokens(tokenA, tokenB, swapAmount); uint256 liquidity = addLiquidity(tokenA, tokenB, totalAmountA.sub(swapAmount), tokenB.myBalance()); // 5. Stake the LP Tokens. IGaugeVaultProxyAdmin gvpAdmin = IGaugeVaultProxyAdmin(IGaugeVaultProxy(gaugeVaultProxy).admin()); underlying.safeApprove(address(gvpAdmin), 0); underlying.safeApprove(address(gvpAdmin), liquidity); gvpAdmin.depositInGauge(liquidity); emit Reinvest(msg.sender, reward, bounty); } function adminRescueTokens(address _to, address[] calldata _tokens) external onlyFactoryOwner nonReentrant { require(_to != address(0), "VaultToken: INVLD_TO"); for (uint256 i = 0; i < _tokens.length; i++) { address token = _tokens[i]; require(token != underlying, "VaultToken: IS_UNDERLYING"); require(token != rewardsToken, "VaultToken: IS_REWARDS_TOKEN"); require(token != token0, "VaultToken: IS_TOKEN_0"); require(token != token1, "VaultToken: IS_TOKEN_1"); uint256 tokenBalance = token.myBalance(); if (tokenBalance > 0) { token.safeTransfer(_to, tokenBalance); } } } /*** Mirrored From uniswapV2Pair ***/ function getReserves() external view returns ( uint112 reserve0, uint112 reserve1, uint32 blockTimestampLast ) { (uint _reserve0, uint _reserve1, uint _blockTimestampLast) = IUniswapV2Pair(underlying).getReserves(); reserve0 = safe112(_reserve0); reserve1 = safe112(_reserve1); blockTimestampLast = uint32(_blockTimestampLast % 2**32); // if no token has been minted yet mirror uniswap getReserves if (totalSupply == 0) return (reserve0, reserve1, blockTimestampLast); // else, return the underlying reserves of this contract uint256 _totalBalance = totalBalance; uint256 _totalSupply = IUniswapV2Pair(underlying).totalSupply(); reserve0 = safe112(_totalBalance.mul(reserve0).div(_totalSupply)); reserve1 = safe112(_totalBalance.mul(reserve1).div(_totalSupply)); require(reserve0 > 100 && reserve1 > 100, "VaultToken: INSUFFICIENT_RESERVES"); } /*** Mirrored from BaseV1Pair ***/ function observationLength() external view returns (uint) { return ISpiritV2BaseV1Pair(underlying).observationLength(); } function observations(uint index) external view returns ( uint timestamp, uint reserve0Cumulative, uint reserve1Cumulative ) { return ISpiritV2BaseV1Pair(underlying).observations(index); } function currentCumulativePrices() external view returns ( uint reserve0Cumulative, uint reserve1Cumulative, uint timestamp ) { return ISpiritV2BaseV1Pair(underlying).currentCumulativePrices(); } /*** Utilities ***/ function safe112(uint256 n) internal pure returns (uint112) { require(n < 2**112, "VaultToken: SAFE112"); return uint112(n); } function getBlockTimestamp() public view returns (uint32) { return uint32(block.timestamp % 2**32); } /*** Modifiers ***/ modifier onlyFactoryOwner() { require(Ownable(factory).owner() == msg.sender, "NOT_AUTHORIZED"); _; } }
pragma solidity >=0.5.0; interface ISpiritV2VaultTokenFactory { event VaultTokenCreated( address indexed pool, address vaultToken, uint256 vaultTokenIndex ); function optiSwap() external view returns (address); function router() external view returns (address); function gaugeVaultProxy() external view returns (address); function pairFactory() external view returns (address); function rewardsToken() external view returns (address); function getVaultToken(address) external view returns (address); function allVaultTokens(uint256) external view returns (address); function allVaultTokensLength() external view returns (uint256); function createVaultToken(address _underlying) external returns (address vaultToken); }
pragma solidity ^0.5.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. */ contract Context { // Empty internal constructor, to prevent people from mistakenly deploying // an instance of this contract, which should be used via inheritance. constructor () internal { } // solhint-disable-previous-line no-empty-blocks function _msgSender() internal view returns (address payable) { return msg.sender; } function _msgData() internal view returns (bytes memory) { this; // silence state mutability warning without generating bytecode - see https://github.com/ethereum/solidity/issues/2691 return msg.data; } }
pragma solidity =0.5.16; import "./TarotERC20.sol"; import "./interfaces/IERC20.sol"; import "./interfaces/IPoolToken.sol"; import "./libraries/SafeMath.sol"; contract PoolToken is IPoolToken, TarotERC20 { uint256 internal constant initialExchangeRate = 1e18; address public underlying; address public factory; uint256 public totalBalance; uint256 public constant MINIMUM_LIQUIDITY = 1000; event Mint( address indexed sender, address indexed minter, uint256 mintAmount, uint256 mintTokens ); event Redeem( address indexed sender, address indexed redeemer, uint256 redeemAmount, uint256 redeemTokens ); event Sync(uint256 totalBalance); /*** Initialize ***/ // called once by the factory function _setFactory() external { require(factory == address(0), "Tarot: FACTORY_ALREADY_SET"); factory = msg.sender; } /*** PoolToken ***/ function _update() internal { totalBalance = IERC20(underlying).balanceOf(address(this)); emit Sync(totalBalance); } function exchangeRate() public view returns (uint256) { uint256 _totalSupply = totalSupply; // gas savings uint256 _totalBalance = totalBalance; // gas savings if (_totalSupply == 0 || _totalBalance == 0) return initialExchangeRate; return _totalBalance.mul(1e18).div(_totalSupply); } // this low-level function should be called from another contract function mint(address minter) external nonReentrant update returns (uint256 mintTokens) { uint256 balance = IERC20(underlying).balanceOf(address(this)); uint256 mintAmount = balance.sub(totalBalance); mintTokens = mintAmount.mul(1e18).div(exchangeRate()); if (totalSupply == 0) { // permanently lock the first MINIMUM_LIQUIDITY tokens mintTokens = mintTokens.sub(MINIMUM_LIQUIDITY); _mint(address(0), MINIMUM_LIQUIDITY); } require(mintTokens > 0, "Tarot: MINT_AMOUNT_ZERO"); _mint(minter, mintTokens); emit Mint(msg.sender, minter, mintAmount, mintTokens); } // this low-level function should be called from another contract function redeem(address redeemer) external nonReentrant update returns (uint256 redeemAmount) { uint256 redeemTokens = balanceOf[address(this)]; redeemAmount = redeemTokens.mul(exchangeRate()).div(1e18); require(redeemAmount > 0, "Tarot: REDEEM_AMOUNT_ZERO"); require(redeemAmount <= totalBalance, "Tarot: INSUFFICIENT_CASH"); _burn(address(this), redeemTokens); _safeTransfer(redeemer, redeemAmount); emit Redeem(msg.sender, redeemer, redeemAmount, redeemTokens); } // force real balance to match totalBalance function skim(address to) external nonReentrant { _safeTransfer( to, IERC20(underlying).balanceOf(address(this)).sub(totalBalance) ); } // force totalBalance to match real balance function sync() external nonReentrant update {} /*** Utilities ***/ // same safe transfer function used by UniSwapV2 (with fixed underlying) bytes4 private constant SELECTOR = bytes4(keccak256(bytes("transfer(address,uint256)"))); function _safeTransfer(address to, uint256 amount) internal { (bool success, bytes memory data) = underlying.call( abi.encodeWithSelector(SELECTOR, to, amount) ); require( success && (data.length == 0 || abi.decode(data, (bool))), "Tarot: TRANSFER_FAILED" ); } // prevents a contract from calling itself, directly or indirectly. bool internal _notEntered = true; modifier nonReentrant() { require(_notEntered, "Tarot: REENTERED"); _notEntered = false; _; _notEntered = true; } // update totalBalance with current balance modifier update() { _; _update(); } }
// SPDX-License-Identifier: MIT pragma solidity >=0.5.0; interface IGaugeVaultProxy { function admin() external view returns (address); }
// SPDX-License-Identifier: MIT pragma solidity >=0.5.0; interface IGaugeVaultProxyAdmin { function getGauge(address underlying) external view returns (address); function gaugeBalanceOf(address _vaultToken) external view returns (uint256); function depositInGauge(uint256 _amount) external; function withdrawFromGauge(uint256 _amount) external; function claimGaugeReward() external; }
// SPDX-License-Identifier: MIT pragma solidity >=0.5.0; interface IOptiSwap { function weth() external view returns (address); function bridgeFromTokens(uint256 index) external view returns (address token); function bridgeFromTokensLength() external view returns (uint256); function getBridgeToken(address _token) external view returns (address bridgeToken); function addBridgeToken(address _token, address _bridgeToken) external; function getDexInfo(uint256 index) external view returns (address dex, address handler); function dexListLength() external view returns (uint256); function indexOfDex(address _dex) external view returns (uint256); function getDexEnabled(address _dex) external view returns (bool); function addDex(address _dex, address _handler) external; function removeDex(address _dex) external; function getBestAmountOut( uint256 _amountIn, address _tokenIn, address _tokenOut ) external view returns (address pair, uint256 amountOut); }
pragma solidity >=0.5.0; interface IBaseV1Router01 { function wftm() external pure returns (address); function addLiquidity( address tokenA, address tokenB, bool stable, uint256 amountADesired, uint256 amountBDesired, uint256 amountAMin, uint256 amountBMin, address to, uint256 deadline ) external returns (uint amountA, uint amountB, uint liquidity); function swapExactTokensForTokensSimple( uint256 amountIn, uint256 amountOutMin, address tokenFrom, address tokenTo, bool stable, address to, uint256 deadline ) external returns (uint[] memory amounts); }
pragma solidity >=0.5.0; interface ISpiritV2BaseV1Pair { event Approval(address indexed owner, address indexed spender, uint value); event Transfer(address indexed from, address indexed to, uint value); function stable() external view returns (bool); function totalSupply() external view returns (uint); function balanceOf(address owner) external view returns (uint); function allowance(address owner, address spender) external view returns (uint); function approve(address spender, uint value) external returns (bool); function transfer(address to, uint value) external returns (bool); function transferFrom(address from, address to, uint value) external returns (bool); function fee() external view returns (uint); function token0() external view returns (address); function token1() external view returns (address); function tokens() external view returns (address, address); function getReserves() external view returns (uint112 reserve0, uint112 reserve1, uint32 blockTimestampLast); function observationLength() external view returns (uint); function observations(uint) external view returns ( uint timestamp, uint reserve0Cumulative, uint reserve1Cumulative ); function currentCumulativePrices() external view returns ( uint reserve0Cumulative, uint reserve1Cumulative, uint timestamp ); }
pragma solidity >=0.5.0; interface ISpiritV2VaultToken { /*** Tarot ERC20 ***/ event Transfer(address indexed from, address indexed to, uint256 value); event Approval(address indexed owner, address indexed spender, uint256 value); function name() external pure returns (string memory); function symbol() external pure returns (string memory); function decimals() external pure returns (uint8); function totalSupply() external view returns (uint256); function balanceOf(address owner) external view returns (uint256); function allowance(address owner, address spender) external view returns (uint256); function approve(address spender, uint256 value) external returns (bool); function transfer(address to, uint256 value) external returns (bool); function transferFrom( address from, address to, uint256 value ) external returns (bool); function DOMAIN_SEPARATOR() external view returns (bytes32); function PERMIT_TYPEHASH() external pure returns (bytes32); function nonces(address owner) external view returns (uint256); function permit( address owner, address spender, uint256 value, uint256 deadline, uint8 v, bytes32 r, bytes32 s ) external; /*** Pool Token ***/ event Mint(address indexed sender, address indexed minter, uint256 mintAmount, uint256 mintTokens); event Redeem(address indexed sender, address indexed redeemer, uint256 redeemAmount, uint256 redeemTokens); event Sync(uint256 totalBalance); function underlying() external view returns (address); function factory() external view returns (address); function totalBalance() external view returns (uint256); function MINIMUM_LIQUIDITY() external pure returns (uint256); function exchangeRate() external view returns (uint256); function mint(address minter) external returns (uint256 mintTokens); function redeem(address redeemer) external returns (uint256 redeemAmount); function skim(address to) external; function sync() external; function _setFactory() external; /*** VaultToken ***/ event Reinvest(address indexed caller, uint256 reward, uint256 bounty); function isVaultToken() external pure returns (bool); function stable() external pure returns (bool); function optiSwap() external view returns (address); function router() external view returns (address); function gaugeVaultProxy() external view returns (address); function pairFactory() external view returns (address); function rewardsToken() external view returns (address); function WETH() external view returns (address); function token0() external view returns (address); function token1() external view returns (address); function REINVEST_BOUNTY() external view returns (uint256); function updateReinvestBounty(uint256 _newReinvestBounty) external; function getReserves() external view returns ( uint112 reserve0, uint112 reserve1, uint32 blockTimestampLast ); function observationLength() external view returns (uint); function observations(uint index) external view returns ( uint timestamp, uint reserve0Cumulative, uint reserve1Cumulative ); function currentCumulativePrices() external view returns ( uint reserve0Cumulative, uint reserve1Cumulative, uint timestamp ); function _initialize( address _underlying, address _optiSwap, address _router, address _gaugeVaultProxy, address _pairFactory, address _rewardsToken ) external; function reinvest() external; function getReward() external returns (uint256); function getBlockTimestamp() external view returns (uint32); function adminRescueTokens(address _to, address[] calldata _tokens) external; }
pragma solidity >=0.5.0; interface IUniswapV2Pair { event Approval( address indexed owner, address indexed spender, uint256 value ); event Transfer(address indexed from, address indexed to, uint256 value); function totalSupply() external view returns (uint256); function balanceOf(address owner) external view returns (uint256); function allowance(address owner, address spender) external view returns (uint256); function approve(address spender, uint256 value) external returns (bool); function transfer(address to, uint256 value) external returns (bool); function transferFrom( address from, address to, uint256 value ) external returns (bool); function token0() external view returns (address); function token1() external view returns (address); function getReserves() external view returns ( uint112 reserve0, uint112 reserve1, uint32 blockTimestampLast ); function price0CumulativeLast() external view returns (uint256); function price1CumulativeLast() external view returns (uint256); }
pragma solidity >=0.5.0; interface IERC20 { event Approval( address indexed owner, address indexed spender, uint256 value ); event Transfer(address indexed from, address indexed to, uint256 value); function name() external view returns (string memory); function symbol() external view returns (string memory); function decimals() external view returns (uint8); function totalSupply() external view returns (uint256); function balanceOf(address owner) external view returns (uint256); function allowance(address owner, address spender) external view returns (uint256); function approve(address spender, uint256 value) external returns (bool); function transfer(address to, uint256 value) external returns (bool); function transferFrom( address from, address to, uint256 value ) external returns (bool); }
pragma solidity 0.5.16; interface ERC20Interface { function balanceOf(address user) external view returns (uint256); } library SafeToken { function myBalance(address token) internal view returns (uint256) { return ERC20Interface(token).balanceOf(address(this)); } function balanceOf(address token, address user) internal view returns (uint256) { return ERC20Interface(token).balanceOf(user); } function safeApprove( address token, address to, uint256 value ) internal { // bytes4(keccak256(bytes('approve(address,uint256)'))); (bool success, bytes memory data) = token.call( abi.encodeWithSelector(0x095ea7b3, to, value) ); require( success && (data.length == 0 || abi.decode(data, (bool))), "!safeApprove" ); } function safeTransfer( address token, address to, uint256 value ) internal { // bytes4(keccak256(bytes('transfer(address,uint256)'))); (bool success, bytes memory data) = token.call( abi.encodeWithSelector(0xa9059cbb, to, value) ); require( success && (data.length == 0 || abi.decode(data, (bool))), "!safeTransfer" ); } function safeTransferFrom( address token, address from, address to, uint256 value ) internal { // bytes4(keccak256(bytes('transferFrom(address,address,uint256)'))); (bool success, bytes memory data) = token.call( abi.encodeWithSelector(0x23b872dd, from, to, value) ); require( success && (data.length == 0 || abi.decode(data, (bool))), "!safeTransferFrom" ); } function safeTransferETH(address to, uint256 value) internal { (bool success, ) = to.call.value(value)(new bytes(0)); require(success, "!safeTransferETH"); } }
pragma solidity =0.5.16; // a library for performing various math operations // forked from: https://github.com/Uniswap/uniswap-v2-core/blob/master/contracts/libraries/Math.sol library Math { function min(uint256 x, uint256 y) internal pure returns (uint256 z) { z = x < y ? x : y; } // babylonian method (https://en.wikipedia.org/wiki/Methods_of_computing_square_roots#Babylonian_method) function sqrt(uint256 y) internal pure returns (uint256 z) { if (y > 3) { z = y; uint256 x = y / 2 + 1; while (x < z) { z = x; x = (y / x + x) / 2; } } else if (y != 0) { z = 1; } } }
pragma solidity =0.5.16; import "./libraries/SafeMath.sol"; // This contract is basically UniswapV2ERC20 with small modifications // src: https://github.com/Uniswap/uniswap-v2-core/blob/master/contracts/UniswapV2ERC20.sol contract TarotERC20 { using SafeMath for uint256; string public name; string public symbol; uint8 public decimals = 18; uint256 public totalSupply; mapping(address => uint256) public balanceOf; mapping(address => mapping(address => uint256)) public allowance; bytes32 public DOMAIN_SEPARATOR; mapping(address => uint256) public nonces; event Transfer(address indexed from, address indexed to, uint256 value); event Approval( address indexed owner, address indexed spender, uint256 value ); constructor() public {} function _setName(string memory _name, string memory _symbol) internal { name = _name; symbol = _symbol; uint256 chainId; assembly { chainId := chainid } DOMAIN_SEPARATOR = keccak256( abi.encode( keccak256( "EIP712Domain(string name,string version,uint256 chainId,address verifyingContract)" ), keccak256(bytes(_name)), keccak256(bytes("1")), chainId, address(this) ) ); } function _mint(address to, uint256 value) internal { totalSupply = totalSupply.add(value); balanceOf[to] = balanceOf[to].add(value); emit Transfer(address(0), to, value); } function _burn(address from, uint256 value) internal { balanceOf[from] = balanceOf[from].sub(value); totalSupply = totalSupply.sub(value); emit Transfer(from, address(0), value); } function _approve( address owner, address spender, uint256 value ) private { allowance[owner][spender] = value; emit Approval(owner, spender, value); } function _transfer( address from, address to, uint256 value ) internal { balanceOf[from] = balanceOf[from].sub( value, "Tarot: TRANSFER_TOO_HIGH" ); balanceOf[to] = balanceOf[to].add(value); emit Transfer(from, to, value); } function approve(address spender, uint256 value) external returns (bool) { _approve(msg.sender, spender, value); return true; } function transfer(address to, uint256 value) external returns (bool) { _transfer(msg.sender, to, value); return true; } function transferFrom( address from, address to, uint256 value ) external returns (bool) { if (allowance[from][msg.sender] != uint256(-1)) { allowance[from][msg.sender] = allowance[from][msg.sender].sub( value, "Tarot: TRANSFER_NOT_ALLOWED" ); } _transfer(from, to, value); return true; } function _checkSignature( address owner, address spender, uint256 value, uint256 deadline, uint8 v, bytes32 r, bytes32 s, bytes32 typehash ) internal { require(deadline >= block.timestamp, "Tarot: EXPIRED"); bytes32 digest = keccak256( abi.encodePacked( "\x19\x01", DOMAIN_SEPARATOR, keccak256( abi.encode( typehash, owner, spender, value, nonces[owner]++, deadline ) ) ) ); address recoveredAddress = ecrecover(digest, v, r, s); require( recoveredAddress != address(0) && recoveredAddress == owner, "Tarot: INVALID_SIGNATURE" ); } // keccak256("Permit(address owner,address spender,uint256 value,uint256 nonce,uint256 deadline)"); bytes32 public constant PERMIT_TYPEHASH = 0x6e71edae12b1b97f4d1f60370fef10105fa2faae0126114a169c64845d6126c9; function permit( address owner, address spender, uint256 value, uint256 deadline, uint8 v, bytes32 r, bytes32 s ) external { _checkSignature( owner, spender, value, deadline, v, r, s, PERMIT_TYPEHASH ); _approve(owner, spender, value); } }
pragma solidity >=0.5.0; interface IPoolToken { /*** Tarot ERC20 ***/ event Transfer(address indexed from, address indexed to, uint256 value); event Approval( address indexed owner, address indexed spender, uint256 value ); function name() external pure returns (string memory); function symbol() external pure returns (string memory); function decimals() external pure returns (uint8); function totalSupply() external view returns (uint256); function balanceOf(address owner) external view returns (uint256); function allowance(address owner, address spender) external view returns (uint256); function approve(address spender, uint256 value) external returns (bool); function transfer(address to, uint256 value) external returns (bool); function transferFrom( address from, address to, uint256 value ) external returns (bool); function DOMAIN_SEPARATOR() external view returns (bytes32); function PERMIT_TYPEHASH() external pure returns (bytes32); function nonces(address owner) external view returns (uint256); function permit( address owner, address spender, uint256 value, uint256 deadline, uint8 v, bytes32 r, bytes32 s ) external; /*** Pool Token ***/ event Mint( address indexed sender, address indexed minter, uint256 mintAmount, uint256 mintTokens ); event Redeem( address indexed sender, address indexed redeemer, uint256 redeemAmount, uint256 redeemTokens ); event Sync(uint256 totalBalance); function underlying() external view returns (address); function factory() external view returns (address); function totalBalance() external view returns (uint256); function MINIMUM_LIQUIDITY() external pure returns (uint256); function exchangeRate() external view returns (uint256); function mint(address minter) external returns (uint256 mintTokens); function redeem(address redeemer) external returns (uint256 redeemAmount); function skim(address to) external; function sync() external; function _setFactory() external; }
pragma solidity =0.5.16; // From https://github.com/OpenZeppelin/openzeppelin-contracts/blob/master/contracts/math/Math.sol // Subject to the MIT license. /** * @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, 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 addition of two unsigned integers, reverting with custom message on overflow. * * Counterpart to Solidity's `+` operator. * * Requirements: * - Addition cannot overflow. */ function add( uint256 a, uint256 b, string memory errorMessage ) internal pure returns (uint256) { uint256 c = a + b; require(c >= a, errorMessage); return c; } /** * @dev Returns the subtraction of two unsigned integers, reverting on underflow (when the result is negative). * * Counterpart to Solidity's `-` operator. * * Requirements: * - Subtraction cannot underflow. */ function sub(uint256 a, uint256 b) internal pure returns (uint256) { return sub(a, b, "SafeMath: subtraction underflow"); } /** * @dev Returns the subtraction of two unsigned integers, reverting with custom message on underflow (when the result is negative). * * Counterpart to Solidity's `-` operator. * * Requirements: * - Subtraction cannot underflow. */ function sub( uint256 a, uint256 b, string memory errorMessage ) internal pure returns (uint256) { require(b <= a, errorMessage); uint256 c = a - b; return c; } /** * @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) { // 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; } /** * @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, string memory errorMessage ) 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, errorMessage); return c; } /** * @dev Returns the integer division of two unsigned integers. * Reverts 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) { return div(a, b, "SafeMath: division by zero"); } /** * @dev Returns the integer division of two unsigned integers. * Reverts with custom message 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, string memory errorMessage ) internal pure returns (uint256) { // Solidity only automatically asserts when dividing by 0 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; } /** * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo), * Reverts 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) { return mod(a, b, "SafeMath: modulo by zero"); } /** * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo), * Reverts with custom message 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, string memory errorMessage ) internal pure returns (uint256) { require(b != 0, errorMessage); return a % b; } }
{ "optimizer": { "enabled": true, "runs": 200 }, "outputSelection": { "*": { "*": [ "evm.bytecode", "evm.deployedBytecode", "devdoc", "userdoc", "metadata", "abi" ] } }, "libraries": {} }
Contract Security Audit
- No Contract Security Audit Submitted- Submit Audit Here
[{"inputs":[{"internalType":"address","name":"_optiSwap","type":"address"},{"internalType":"address","name":"_router","type":"address"},{"internalType":"address","name":"_gaugeVaultProxy","type":"address"},{"internalType":"address","name":"_pairFactory","type":"address"},{"internalType":"address","name":"_rewardsToken","type":"address"}],"payable":false,"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"pool","type":"address"},{"indexed":false,"internalType":"address","name":"vaultToken","type":"address"},{"indexed":false,"internalType":"uint256","name":"vaultTokenIndex","type":"uint256"}],"name":"VaultTokenCreated","type":"event"},{"constant":true,"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"allVaultTokens","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"allVaultTokensLength","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"_underlying","type":"address"}],"name":"createVaultToken","outputs":[{"internalType":"address","name":"vaultToken","type":"address"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"gaugeVaultProxy","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"getVaultToken","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"isOwner","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"optiSwap","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"pairFactory","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[],"name":"renounceOwnership","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"rewardsToken","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"router","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"}]
Contract Creation Code
608060405234801561001057600080fd5b506040516146d13803806146d1833981810160405260a081101561003357600080fd5b5080516020820151604083015160608401516080909401519293919290919060006100656001600160e01b0361011116565b600080546001600160a01b0319166001600160a01b0383169081178255604051929350917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a350600180546001600160a01b03199081166001600160a01b03978816179091556002805482169587169590951790945560038054851693861693909317909255600480548416918516919091179055600580549092169216919091179055610115565b3390565b6145ad806101246000396000f3fe608060405234801561001057600080fd5b50600436106100cf5760003560e01c80638f32d59b1161008c578063d1af0c7d11610066578063d1af0c7d146101b1578063e14f870d146101b9578063f2fde38b146101c1578063f887ea40146101e7576100cf565b80638f32d59b146101525780639dc6108f1461016e578063a9a1e13814610194576100cf565b806329e15d0b146100d457806360c2affa146100ee578063715018a614610112578063857696091461011c5780638a9a19c2146101245780638da5cb5b1461014a575b600080fd5b6100dc6101ef565b60408051918252519081900360200190f35b6100f66101f5565b604080516001600160a01b039092168252519081900360200190f35b61011a610204565b005b6100f66102a7565b6100f66004803603602081101561013a57600080fd5b50356001600160a01b03166102b6565b6100f6610557565b61015a610566565b604080519115158252519081900360200190f35b6100f66004803603602081101561018457600080fd5b50356001600160a01b031661058a565b6100f6600480360360208110156101aa57600080fd5b50356105a5565b6100f66105cc565b6100f66105db565b61011a600480360360208110156101d757600080fd5b50356001600160a01b03166105ea565b6100f661064f565b60075490565b6001546001600160a01b031681565b61020c610566565b61025d576040805162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015290519081900360640190fd5b600080546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600080546001600160a01b0319169055565b6003546001600160a01b031681565b6001600160a01b0381811660009081526006602052604081205490911615610325576040805162461bcd60e51b815260206004820152601e60248201527f5661756c74546f6b656e466163746f72793a20504f4f4c5f4558495354530000604482015290519081900360640190fd5b816001600160a01b03166322be3de16040518163ffffffff1660e01b815260040160206040518083038186803b15801561035e57600080fd5b505afa158015610372573d6000803e3d6000fd5b505050506040513d602081101561038857600080fd5b5051156103dc576040805162461bcd60e51b815260206004820152601c60248201527f5661756c74546f6b656e466163746f72793a2049535f535441424c4500000000604482015290519081900360640190fd5b6060604051806020016103ee90610702565b6020820181038252601f19601f820116604052509050828151602083016000f56001546002546003546004805460055460408051631f6e3c3960e31b81526001600160a01b038c8116958201959095529684166024880152948316604487015292821660648601528116608485015290811660a4840152905192945084169163fb71e1c89160c48082019260009290919082900301818387803b15801561049457600080fd5b505af11580156104a8573d6000803e3d6000fd5b5050506001600160a01b03808516600081815260066020908152604080832080549589166001600160a01b0319968716811790915560078054600181018255948190527fa66cc928b5edb82af9bd49922954155ab7b0942694bea4ce44661d9a8736c68890940180549096168117909555915482519485529084015280519193507f68750cb824b88919ca0bc2d5e95520467a0a0007128b0b04772b5f06e8dda660928290030190a250919050565b6000546001600160a01b031690565b600080546001600160a01b031661057b61065e565b6001600160a01b031614905090565b6006602052600090815260409020546001600160a01b031681565b600781815481106105b257fe5b6000918252602090912001546001600160a01b0316905081565b6005546001600160a01b031681565b6004546001600160a01b031681565b6105f2610566565b610643576040805162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015290519081900360640190fd5b61064c81610662565b50565b6002546001600160a01b031681565b3390565b6001600160a01b0381166106a75760405162461bcd60e51b81526004018080602001828103825260268152602001806145536026913960400191505060405180910390fd5b600080546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a3600080546001600160a01b0319166001600160a01b0392909216919091179055565b613e43806107108339019056fe60806040526002805460ff19908116601217909155600b80549091166001179055662386f26fc10000601355613e098061003a6000396000f3fe608060405234801561001057600080fd5b506004361061028a5760003560e01c8063796b89b91161015c578063c45a0155116100ce578063e14f870d11610087578063e14f870d14610722578063ebeb31db1461072a578063f887ea4014610732578063fb71e1c81461073a578063fdb5a03e14610788578063fff6cae9146107905761028a565b8063c45a015514610683578063c8c4ff8c1461068b578063d1af0c7d14610693578063d21220a71461069b578063d505accf146106a3578063dd62ed3e146106f45761028a565b806396fa4c111161012057806396fa4c1114610611578063a9059cbb14610619578063ad5c464814610645578063ad7a672f1461064d578063ba9a7a5614610655578063bc25cf771461065d5761028a565b8063796b89b9146105945780637ecebe00146105b557806385769609146105db57806395a2251f146105e357806395d89b41146106095761028a565b8063313ce5671161020057806360c2affa116101b957806360c2affa146105285780636a627842146105305780636c2a3bc5146105565780636ee272271461055e5780636f307dc31461056657806370a082311461056e5761028a565b8063313ce567146104cd5780633644e515146104eb5780633ba0b9a9146104f35780633d18b912146104fb57806346fb738b146105035780634a5d316c146105205761028a565b80631df8c717116102525780631df8c717146103c257806322be3de1146103e857806323b872dd146103f0578063252c09d71461042657806329a105221461044357806330adf81f146104c55761028a565b806306fdde031461028f5780630902f1ac1461030c578063095ea7b3146103445780630dfe16811461038457806318160ddd146103a8575b600080fd5b610297610798565b6040805160208082528351818301528351919283929083019185019080838360005b838110156102d15781810151838201526020016102b9565b50505050905090810190601f1680156102fe5780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b610314610826565b604080516001600160701b03948516815292909316602083015263ffffffff168183015290519081900360600190f35b6103706004803603604081101561035a57600080fd5b506001600160a01b038135169060200135610a35565b604080519115158252519081900360200190f35b61038c610a4c565b604080516001600160a01b039092168252519081900360200190f35b6103b0610a5b565b60408051918252519081900360200190f35b6103ca610a61565b60408051938452602084019290925282820152519081900360600190f35b610370610af7565b6103706004803603606081101561040657600080fd5b506001600160a01b03813581169160208101359091169060400135610afc565b6103ca6004803603602081101561043c57600080fd5b5035610bcc565b6104c36004803603604081101561045957600080fd5b6001600160a01b03823516919081019060408101602082013564010000000081111561048457600080fd5b82018360208201111561049657600080fd5b803590602001918460208302840111640100000000831117156104b857600080fd5b509092509050610c63565b005b6103b0610fbf565b6104d5610fe3565b6040805160ff9092168252519081900360200190f35b6103b0610fec565b6103b0610ff2565b6103b0611042565b6104c36004803603602081101561051957600080fd5b50356110bf565b6104c361120f565b61038c611281565b6103b06004803603602081101561054657600080fd5b50356001600160a01b0316611295565b6103b0611634565b61037061163a565b61038c61163f565b6103b06004803603602081101561058457600080fd5b50356001600160a01b031661164e565b61059c611660565b6040805163ffffffff9092168252519081900360200190f35b6103b0600480360360208110156105cb57600080fd5b50356001600160a01b031661166a565b61038c61167c565b6103b0600480360360208110156105f957600080fd5b50356001600160a01b031661168b565b6102976118ff565b6103b0611959565b6103706004803603604081101561062f57600080fd5b506001600160a01b038135169060200135611964565b61038c611971565b6103b0611980565b6103b0611986565b6104c36004803603602081101561067357600080fd5b50356001600160a01b031661198c565b61038c611a86565b6103b0611a95565b61038c611aa0565b61038c611aaf565b6104c3600480360360e08110156106b957600080fd5b506001600160a01b03813581169160208101359091169060408101359060608101359060ff6080820135169060a08101359060c00135611abe565b6103b06004803603604081101561070a57600080fd5b506001600160a01b0381358116916020013516611b02565b61038c611b1f565b6103b0611b2e565b61038c611ba4565b6104c3600480360360c081101561075057600080fd5b506001600160a01b038135811691602081013582169160408201358116916060810135821691608082013581169160a0013516611bb3565b6104c3611fac565b6104c36123fc565b6000805460408051602060026001851615610100026000190190941693909304601f8101849004840282018401909252818152929183018282801561081e5780601f106107f35761010080835404028352916020019161081e565b820191906000526020600020905b81548152906001019060200180831161080157829003601f168201915b505050505081565b600080600080600080600860009054906101000a90046001600160a01b03166001600160a01b0316630902f1ac6040518163ffffffff1660e01b815260040160606040518083038186803b15801561087d57600080fd5b505afa158015610891573d6000803e3d6000fd5b505050506040513d60608110156108a757600080fd5b50805160208201516040909201516001600160701b0391821695509116925063ffffffff1690506108d783612458565b95506108e282612458565b945064010000000081069350600354600014156109025750610a30915050565b600a54600854604080516318160ddd60e01b815290516000926001600160a01b0316916318160ddd916004808301926020929190829003018186803b15801561094a57600080fd5b505afa15801561095e573d6000803e3d6000fd5b505050506040513d602081101561097457600080fd5b505190506109a96109a482610998856001600160701b038d1663ffffffff6124b016565b9063ffffffff61250916565b612458565b97506109cb6109a482610998856001600160701b038c1663ffffffff6124b016565b96506064886001600160701b03161180156109ef57506064876001600160701b0316115b610a2a5760405162461bcd60e51b8152600401808060200182810382526021815260200180613db46021913960400191505060405180910390fd5b50505050505b909192565b6000610a4233848461254b565b5060015b92915050565b6011546001600160a01b031681565b60035481565b6000806000600860009054906101000a90046001600160a01b03166001600160a01b0316631df8c7176040518163ffffffff1660e01b815260040160606040518083038186803b158015610ab457600080fd5b505afa158015610ac8573d6000803e3d6000fd5b505050506040513d6060811015610ade57600080fd5b5080516020820151604090920151909591945092509050565b600081565b6001600160a01b038316600090815260056020908152604080832033845290915281205460001914610bb657604080518082018252601b81527f5461726f743a205452414e534645525f4e4f545f414c4c4f57454400000000006020808301919091526001600160a01b0387166000908152600582528381203382529091529190912054610b9191849063ffffffff6125ad16565b6001600160a01b03851660009081526005602090815260408083203384529091529020555b610bc1848484612644565b5060015b9392505050565b6008546040805163252c09d760e01b8152600481018490529051600092839283926001600160a01b039092169163252c09d791602480820192606092909190829003018186803b158015610c1f57600080fd5b505afa158015610c33573d6000803e3d6000fd5b505050506040513d6060811015610c4957600080fd5b508051602082015160409092015190969195509350915050565b60095460408051638da5cb5b60e01b8152905133926001600160a01b031691638da5cb5b916004808301926020929190829003018186803b158015610ca757600080fd5b505afa158015610cbb573d6000803e3d6000fd5b505050506040513d6020811015610cd157600080fd5b50516001600160a01b031614610d1f576040805162461bcd60e51b815260206004820152600e60248201526d1393d517d055551213d49256915160921b604482015290519081900360640190fd5b600b5460ff16610d69576040805162461bcd60e51b815260206004820152601060248201526f15185c9bdd0e8814915153951154915160821b604482015290519081900360640190fd5b600b805460ff191690556001600160a01b038316610dc5576040805162461bcd60e51b81526020600482015260146024820152735661756c74546f6b656e3a20494e564c445f544f60601b604482015290519081900360640190fd5b60005b81811015610fac576000838383818110610dde57fe5b6008546001600160a01b036020909202939093013581169350919091168214159050610e51576040805162461bcd60e51b815260206004820152601960248201527f5661756c74546f6b656e3a2049535f554e4445524c59494e4700000000000000604482015290519081900360640190fd5b600f546001600160a01b0382811691161415610eb4576040805162461bcd60e51b815260206004820152601c60248201527f5661756c74546f6b656e3a2049535f524557415244535f544f4b454e00000000604482015290519081900360640190fd5b6011546001600160a01b0382811691161415610f10576040805162461bcd60e51b815260206004820152601660248201527505661756c74546f6b656e3a2049535f544f4b454e5f360541b604482015290519081900360640190fd5b6012546001600160a01b0382811691161415610f6c576040805162461bcd60e51b81526020600482015260166024820152755661756c74546f6b656e3a2049535f544f4b454e5f3160501b604482015290519081900360640190fd5b6000610f80826001600160a01b0316612736565b90508015610fa257610fa26001600160a01b038316878363ffffffff6127b216565b5050600101610dc8565b5050600b805460ff191660011790555050565b7f6e71edae12b1b97f4d1f60370fef10105fa2faae0126114a169c64845d6126c981565b60025460ff1681565b60065481565b600354600a5460009190811580611007575080155b1561101e57670de0b6b3a76400009250505061103f565b61103a8261099883670de0b6b3a764000063ffffffff6124b016565b925050505b90565b600b5460009060ff1661108f576040805162461bcd60e51b815260206004820152601060248201526f15185c9bdd0e8814915153951154915160821b604482015290519081900360640190fd5b600b805460ff191690553332146110a557600080fd5b6110ad61290c565b9050600b805460ff1916600117905590565b60095460408051638da5cb5b60e01b8152905133926001600160a01b031691638da5cb5b916004808301926020929190829003018186803b15801561110357600080fd5b505afa158015611117573d6000803e3d6000fd5b505050506040513d602081101561112d57600080fd5b50516001600160a01b03161461117b576040805162461bcd60e51b815260206004820152600e60248201526d1393d517d055551213d49256915160921b604482015290519081900360640190fd5b66038d7ea4c6800081101580156111995750662386f26fc100008111155b6111d45760405162461bcd60e51b8152600401808060200182810382526021815260200180613d936021913960400191505060405180910390fd5b60138190556040805182815290517ffa1e13889c5c5294758f01f045a83de15feca61a17e6281f4d11a5110085d9329181900360200190a150565b6009546001600160a01b03161561126d576040805162461bcd60e51b815260206004820152601a60248201527f5461726f743a20464143544f52595f414c52454144595f534554000000000000604482015290519081900360640190fd5b600980546001600160a01b03191633179055565b600b5461010090046001600160a01b031681565b600b5460009060ff166112e2576040805162461bcd60e51b815260206004820152601060248201526f15185c9bdd0e8814915153951154915160821b604482015290519081900360640190fd5b600b805460ff19169055600854600090611304906001600160a01b0316612736565b90506000600d60009054906101000a90046001600160a01b03166001600160a01b031663f851a4406040518163ffffffff1660e01b815260040160206040518083038186803b15801561135657600080fd5b505afa15801561136a573d6000803e3d6000fd5b505050506040513d602081101561138057600080fd5b5051604080516310f1c4ad60e11b815230600482015290519192506000916001600160a01b038416916321e3895a916024808301926020929190829003018186803b1580156113ce57600080fd5b505afa1580156113e2573d6000803e3d6000fd5b505050506040513d60208110156113f857600080fd5b505160085490915061141b906001600160a01b031683600063ffffffff612a0216565b600854611438906001600160a01b0316838563ffffffff612a0216565b816001600160a01b031663af9312ab846040518263ffffffff1660e01b815260040180828152602001915050600060405180830381600087803b15801561147e57600080fd5b505af1158015611492573d6000803e3d6000fd5b5050604080516310f1c4ad60e11b81523060048201529051600093506001600160a01b03861692506321e3895a91602480820192602092909190829003018186803b1580156114e057600080fd5b505afa1580156114f4573d6000803e3d6000fd5b505050506040513d602081101561150a57600080fd5b50519050611541611519610ff2565b610998670de0b6b3a7640000611535858763ffffffff612b5416565b9063ffffffff6124b016565b94506003546000141561156f57611560856103e863ffffffff612b5416565b945061156f60006103e8612b96565b600085116115c4576040805162461bcd60e51b815260206004820152601c60248201527f5661756c74546f6b656e3a204d494e545f414d4f554e545f5a45524f00000000604482015290519081900360640190fd5b6115ce8686612b96565b604080518581526020810187905281516001600160a01b0389169233927f2f00e3cdd69a77be7ed215ec7b2a36784dd158f921fca79ac29deffa353fe6ee929081900390910190a350505050611622612c2d565b600b805460ff19166001179055919050565b60135481565b600181565b6008546001600160a01b031681565b60046020526000908152604090205481565b63ffffffff421690565b60076020526000908152604090205481565b600d546001600160a01b031681565b600b5460009060ff166116d8576040805162461bcd60e51b815260206004820152601060248201526f15185c9bdd0e8814915153951154915160821b604482015290519081900360640190fd5b600b805460ff1916905530600090815260046020526040902054611716670de0b6b3a7640000610998611709610ff2565b849063ffffffff6124b016565b91506000821161176d576040805162461bcd60e51b815260206004820152601e60248201527f5661756c74546f6b656e3a2052454445454d5f414d4f554e545f5a45524f0000604482015290519081900360640190fd5b600a548211156117c4576040805162461bcd60e51b815260206004820152601d60248201527f5661756c74546f6b656e3a20494e53554646494349454e545f43415348000000604482015290519081900360640190fd5b6117ce3082612d56565b600d54604080516303e1469160e61b815290516000926001600160a01b03169163f851a440916004808301926020929190829003018186803b15801561181357600080fd5b505afa158015611827573d6000803e3d6000fd5b505050506040513d602081101561183d57600080fd5b5051604080516309e019bd60e41b81526004810186905290519192506001600160a01b03831691639e019bd09160248082019260009290919082900301818387803b15801561188b57600080fd5b505af115801561189f573d6000803e3d6000fd5b505050506118ad8484612df3565b604080518481526020810184905281516001600160a01b0387169233927f3f693fff038bb8a046aa76d9516190ac7444f7d69cf952c4cbdc086fdef2d6fc929081900390910190a35050611622612c2d565b60018054604080516020600284861615610100026000190190941693909304601f8101849004840282018401909252818152929183018282801561081e5780601f106107f35761010080835404028352916020019161081e565b66038d7ea4c6800081565b6000610a42338484612644565b6010546001600160a01b031681565b600a5481565b6103e881565b600b5460ff166119d6576040805162461bcd60e51b815260206004820152601060248201526f15185c9bdd0e8814915153951154915160821b604482015290519081900360640190fd5b600b805460ff19169055600a54600854604080516370a0823160e01b81523060048201529051611a76938593611a719391926001600160a01b03909116916370a08231916024808301926020929190829003018186803b158015611a3957600080fd5b505afa158015611a4d573d6000803e3d6000fd5b505050506040513d6020811015611a6357600080fd5b50519063ffffffff612b5416565b612df3565b50600b805460ff19166001179055565b6009546001600160a01b031681565b662386f26fc1000081565b600f546001600160a01b031681565b6012546001600160a01b031681565b611aee878787878787877f6e71edae12b1b97f4d1f60370fef10105fa2faae0126114a169c64845d6126c9612f85565b611af987878761254b565b50505050505050565b600560209081526000928352604080842090915290825290205481565b600e546001600160a01b031681565b6008546040805163ebeb31db60e01b815290516000926001600160a01b03169163ebeb31db916004808301926020929190829003018186803b158015611b7357600080fd5b505afa158015611b87573d6000803e3d6000fd5b505050506040513d6020811015611b9d57600080fd5b5051905090565b600c546001600160a01b031681565b6009546001600160a01b031615611c11576040805162461bcd60e51b815260206004820152601f60248201527f5661756c74546f6b656e3a20464143544f52595f414c52454144595f53455400604482015290519081900360640190fd5b600980546001600160a01b0319163317905560408051808201825260118152702a30b937ba102b30bab63a102a37b5b2b760791b602080830191909152825180840190935260068352651d95105493d560d21b90830152611c719161315a565b600880546001600160a01b03199081166001600160a01b0389811691909117909255600b8054610100600160a81b03191661010089851602179055600d80549091168583161790819055604080516303e1469160e61b81529051600093929092169163f851a44091600480820192602092909190829003018186803b158015611cf957600080fd5b505afa158015611d0d573d6000803e3d6000fd5b505050506040513d6020811015611d2357600080fd5b505190506001600160a01b038116611d82576040805162461bcd60e51b815260206004820152601860248201527f5661756c74546f6b656e3a204e4f5f4756505f41444d494e0000000000000000604482015290519081900360640190fd5b6008546040805163b1c6f0e960e01b81526001600160a01b039283166004820152905160009284169163b1c6f0e9916024808301926020929190829003018186803b158015611dd057600080fd5b505afa158015611de4573d6000803e3d6000fd5b505050506040513d6020811015611dfa57600080fd5b50516001600160a01b03161415611e4f576040805162461bcd60e51b81526020600482015260146024820152735661756c74546f6b656e3a204e4f5f474155474560601b604482015290519081900360640190fd5b600c80546001600160a01b038088166001600160a01b03199283168117909355600e80549187169190921617905560408051637a7a2da360e11b8152905163f4f45b4691600480820192602092909190829003018186803b158015611eb357600080fd5b505afa158015611ec7573d6000803e3d6000fd5b505050506040513d6020811015611edd57600080fd5b5051601080546001600160a01b0319166001600160a01b0392831617905560408051634eb1c24560e11b81528151928a1692639d63848a92600480840193919291829003018186803b158015611f3257600080fd5b505afa158015611f46573d6000803e3d6000fd5b505050506040513d6040811015611f5c57600080fd5b508051602090910151601280546001600160a01b03199081166001600160a01b039384161790915560118054821693831693909317909255600f8054909216931692909217909155505050505050565b600b5460ff16611ff6576040805162461bcd60e51b815260206004820152601060248201526f15185c9bdd0e8814915153951154915160821b604482015290519081900360640190fd5b600b805460ff1916905533321461200c57600080fd5b600061201661290c565b90508061202357506123e5565b6000670de0b6b3a7640000612043601354846124b090919063ffffffff16565b8161204a57fe5b600f54919004915061206c906001600160a01b0316338363ffffffff6127b216565b600f5460115460009182916001600160a01b03908116911614806120a05750600f546012546001600160a01b039081169116145b156120f357600f546011546001600160a01b039081169116146120d5576012546011546001600160a01b0391821691166120e9565b6011546012546001600160a01b0391821691165b9092509050612164565b6010546012546001600160a01b03908116911614156121265750506012546011546001600160a01b03918216911661213c565b50506011546012546001600160a01b0391821691165b600f54612162906001600160a01b03168361215d878763ffffffff612b5416565b613222565b505b6000612178836001600160a01b0316612736565b90506000811161218457fe5b600080600860009054906101000a90046001600160a01b03166001600160a01b0316630902f1ac6040518163ffffffff1660e01b815260040160606040518083038186803b1580156121d557600080fd5b505afa1580156121e9573d6000803e3d6000fd5b505050506040513d60608110156121ff57600080fd5b5080516020909101516011546001600160701b039283169450911691506000906001600160a01b038781169116146122375781612239565b825b905060006122478583613452565b905061225487878361359d565b6000612282888861226b898663ffffffff612b5416565b61227d8b6001600160a01b0316612736565b6136ea565b90506000600d60009054906101000a90046001600160a01b03166001600160a01b031663f851a4406040518163ffffffff1660e01b815260040160206040518083038186803b1580156122d457600080fd5b505afa1580156122e8573d6000803e3d6000fd5b505050506040513d60208110156122fe57600080fd5b5051600854909150612321906001600160a01b031682600063ffffffff612a0216565b60085461233e906001600160a01b0316828463ffffffff612a0216565b806001600160a01b031663af9312ab836040518263ffffffff1660e01b815260040180828152602001915050600060405180830381600087803b15801561238457600080fd5b505af1158015612398573d6000803e3d6000fd5b5050604080518e8152602081018e905281513394507fc003f45bc224d116b6d079100d4ab57a5b9633244c47a5a92a176c5b79a85f2893509081900390910190a250505050505050505050505b6123ed612c2d565b600b805460ff19166001179055565b600b5460ff16612446576040805162461bcd60e51b815260206004820152601060248201526f15185c9bdd0e8814915153951154915160821b604482015290519081900360640190fd5b600b805460ff191690556123ed612c2d565b6000600160701b82106124a8576040805162461bcd60e51b81526020600482015260136024820152722b30bab63a2a37b5b2b71d1029a0a32298989960691b604482015290519081900360640190fd5b50805b919050565b6000826124bf57506000610a46565b828202828482816124cc57fe5b0414610bc55760405162461bcd60e51b8152600401808060200182810382526021815260200180613d726021913960400191505060405180910390fd5b6000610bc583836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f0000000000008152506137c2565b6001600160a01b03808416600081815260056020908152604080832094871680845294825291829020859055815185815291517f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259281900390910190a3505050565b6000818484111561263c5760405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b838110156126015781810151838201526020016125e9565b50505050905090810190601f16801561262e5780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b505050900390565b604080518082018252601881527f5461726f743a205452414e534645525f544f4f5f4849474800000000000000006020808301919091526001600160a01b0386166000908152600490915291909120546126a591839063ffffffff6125ad16565b6001600160a01b0380851660009081526004602052604080822093909355908416815220546126da908263ffffffff61382716565b6001600160a01b0380841660008181526004602090815260409182902094909455805185815290519193928716927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef92918290030190a3505050565b604080516370a0823160e01b815230600482015290516000916001600160a01b038416916370a0823191602480820192602092909190829003018186803b15801561278057600080fd5b505afa158015612794573d6000803e3d6000fd5b505050506040513d60208110156127aa57600080fd5b505192915050565b604080516001600160a01b038481166024830152604480830185905283518084039091018152606490920183526020820180516001600160e01b031663a9059cbb60e01b178152925182516000946060949389169392918291908083835b6020831061282f5780518252601f199092019160209182019101612810565b6001836020036101000a0380198251168184511680821785525050505050509050019150506000604051808303816000865af19150503d8060008114612891576040519150601f19603f3d011682016040523d82523d6000602084013e612896565b606091505b50915091508180156128c45750805115806128c457508080602001905160208110156128c157600080fd5b50515b612905576040805162461bcd60e51b815260206004820152600d60248201526c10b9b0b332aa3930b739b332b960991b604482015290519081900360640190fd5b5050505050565b600080600d60009054906101000a90046001600160a01b03166001600160a01b031663f851a4406040518163ffffffff1660e01b815260040160206040518083038186803b15801561295d57600080fd5b505afa158015612971573d6000803e3d6000fd5b505050506040513d602081101561298757600080fd5b5051604080516304bf582960e11b815290519192506001600160a01b0383169163097eb0529160048082019260009290919082900301818387803b1580156129ce57600080fd5b505af11580156129e2573d6000803e3d6000fd5b5050600f546129fc92506001600160a01b03169050612736565b91505090565b604080516001600160a01b038481166024830152604480830185905283518084039091018152606490920183526020820180516001600160e01b031663095ea7b360e01b178152925182516000946060949389169392918291908083835b60208310612a7f5780518252601f199092019160209182019101612a60565b6001836020036101000a0380198251168184511680821785525050505050509050019150506000604051808303816000865af19150503d8060008114612ae1576040519150601f19603f3d011682016040523d82523d6000602084013e612ae6565b606091505b5091509150818015612b14575080511580612b145750808060200190516020811015612b1157600080fd5b50515b612905576040805162461bcd60e51b815260206004820152600c60248201526b2173616665417070726f766560a01b604482015290519081900360640190fd5b6000610bc583836040518060400160405280601f81526020017f536166654d6174683a207375627472616374696f6e20756e646572666c6f77008152506125ad565b600354612ba9908263ffffffff61382716565b6003556001600160a01b038216600090815260046020526040902054612bd5908263ffffffff61382716565b6001600160a01b03831660008181526004602090815260408083209490945583518581529351929391927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9281900390910190a35050565b600d54604080516303e1469160e61b815290516000926001600160a01b03169163f851a440916004808301926020929190829003018186803b158015612c7257600080fd5b505afa158015612c86573d6000803e3d6000fd5b505050506040513d6020811015612c9c57600080fd5b5051604080516310f1c4ad60e11b815230600482015290519192506000916001600160a01b038416916321e3895a916024808301926020929190829003018186803b158015612cea57600080fd5b505afa158015612cfe573d6000803e3d6000fd5b505050506040513d6020811015612d1457600080fd5b5051600a8190556040805182815290519192507f8a0df8ef054fae2c3d2d19a7b322e864870cc9fd3cb07fb9526309c596244bf4919081900360200190a15050565b6001600160a01b038216600090815260046020526040902054612d7f908263ffffffff612b5416565b6001600160a01b038316600090815260046020526040902055600354612dab908263ffffffff612b5416565b6003556040805182815290516000916001600160a01b038516917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9181900360200190a35050565b600854604080518082018252601981527f7472616e7366657228616464726573732c75696e74323536290000000000000060209182015281516001600160a01b0386811660248301526044808301879052845180840390910181526064909201845291810180516001600160e01b031663a9059cbb60e01b1781529251815160009560609594169382918083835b60208310612ea05780518252601f199092019160209182019101612e81565b6001836020036101000a0380198251168184511680821785525050505050509050019150506000604051808303816000865af19150503d8060008114612f02576040519150601f19603f3d011682016040523d82523d6000602084013e612f07565b606091505b5091509150818015612f35575080511580612f355750808060200190516020811015612f3257600080fd5b50515b612f7f576040805162461bcd60e51b815260206004820152601660248201527515185c9bdd0e881514905394d1915497d1905253115160521b604482015290519081900360640190fd5b50505050565b42851015612fcb576040805162461bcd60e51b815260206004820152600e60248201526d15185c9bdd0e881156141254915160921b604482015290519081900360640190fd5b6006546001600160a01b03808a1660008181526007602090815260408083208054600180820190925582518085018a905280840196909652958e166060860152608085018d905260a085019590955260c08085018c90528151808603909101815260e08501825280519083012061190160f01b6101008601526101028501969096526101228085019690965280518085039096018652610142840180825286519683019690962095839052610162840180825286905260ff8a166101828501526101a284018990526101c28401889052519193926101e280820193601f1981019281900390910190855afa1580156130c7573d6000803e3d6000fd5b5050604051601f1901519150506001600160a01b038116158015906130fd5750896001600160a01b0316816001600160a01b0316145b61314e576040805162461bcd60e51b815260206004820152601860248201527f5461726f743a20494e56414c49445f5349474e41545552450000000000000000604482015290519081900360640190fd5b50505050505050505050565b815161316d906000906020850190613c87565b508051613181906001906020840190613c87565b506040514690806052613d208239604080519182900360520182208651602097880120838301835260018452603160f81b93880193909352815180880191909152808201929092527fc89efdaa54c0f20c7adf612882df0950f5a951637e0307cdcb4c672f298b8bc6606083015260808201939093523060a0808301919091528351808303909101815260c090910190925250805192019190912060065550565b6000826001600160a01b0316846001600160a01b03161415613245575080610bc5565b600b546040805163711f958560e11b81526001600160a01b038781166004830152915161010090930490911691600091839163e23f2b0a91602480820192602092909190829003018186803b15801561329d57600080fd5b505afa1580156132b1573d6000803e3d6000fd5b505050506040513d60208110156132c757600080fd5b505190506001600160a01b0380821690861614156132f4576132eb82878787613881565b92505050610bc5565b6000826001600160a01b031663e23f2b0a876040518263ffffffff1660e01b815260040180826001600160a01b03166001600160a01b0316815260200191505060206040518083038186803b15801561334c57600080fd5b505afa158015613360573d6000803e3d6000fd5b505050506040513d602081101561337657600080fd5b505190506001600160a01b0387811690821614156133a45761339a83888888613881565b9350505050610bc5565b6000876001600160a01b0316836001600160a01b0316146133d2576133cb84898589613881565b90506133d5565b50845b816001600160a01b0316836001600160a01b03161415613406576133fb84848984613881565b945050505050610bc5565b866001600160a01b0316826001600160a01b0316141561342b576133fb838883613222565b6000613438848484613222565b905061344685848a84613881565b95505050505050610bc5565b600080600860009054906101000a90046001600160a01b03166001600160a01b031663ddca3f436040518163ffffffff1660e01b815260040160206040518083038186803b1580156134a357600080fd5b505afa1580156134b7573d6000803e3d6000fd5b505050506040513d60208110156134cd57600080fd5b5051905060006134e6620f42408363ffffffff61250916565b905060006134fd620f42408363ffffffff612b5416565b9050600061351886611535620f42408563ffffffff61382716565b90506000613538836115356004818b818e620f424063ffffffff6124b016565b9050600061356461355f83613553868063ffffffff6124b016565b9063ffffffff61382716565b613b87565b9050600061357960028663ffffffff6124b016565b905061358f81610998848763ffffffff612b5416565b9a9950505050505050505050565b6135a78382613bd8565b600c54604080516313dcfc5960e01b8152600481018490526000602482018190526001600160a01b0387811660448401528681166064840152608483018290523060a48401524260c4840152925192909316926313dcfc599260e48084019382900301818387803b15801561361b57600080fd5b505af115801561362f573d6000803e3d6000fd5b505050506040513d6000823e601f3d908101601f19168201604052602081101561365857600080fd5b810190808051604051939291908464010000000082111561367857600080fd5b90830190602082018581111561368d57600080fd5b82518660208202830111640100000000821117156136aa57600080fd5b82525081516020918201928201910280838360005b838110156136d75781810151838201526020016136bf565b5050505090500160405250505050505050565b60006136f68584613bd8565b6137008483613bd8565b600c5460408051635a47ddc360e01b81526001600160a01b0388811660048301528781166024830152600060448301819052606483018890526084830187905260a4830181905260c483018190523060e4840152426101048401529251931692635a47ddc39261012480840193606093929083900390910190829087803b15801561378a57600080fd5b505af115801561379e573d6000803e3d6000fd5b505050506040513d60608110156137b457600080fd5b506040015195945050505050565b600081836138115760405162461bcd60e51b81526020600482018181528351602484015283519092839260449091019190850190808383600083156126015781810151838201526020016125e9565b50600083858161381d57fe5b0495945050505050565b600082820183811015610bc5576040805162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015290519081900360640190fd5b6000826001600160a01b0316846001600160a01b031614156138a4575080613b7f565b60408051630820681160e11b8152600481018490526001600160a01b0386811660248301528581166044830152825160009391891692631040d022926064808301939192829003018186803b1580156138fc57600080fd5b505afa158015613910573d6000803e3d6000fd5b505050506040513d604081101561392657600080fd5b508051602090910151925090506001600160a01b038116613978576040805162461bcd60e51b81526020600482015260076024820152662727afa820a4a960c91b604482015290519081900360640190fd5b6139926001600160a01b038616828563ffffffff6127b216565b836001600160a01b0316856001600160a01b03161015613a9657604080516000808252602082019283905263022c0d9f60e01b835260248201818152604483018690523060648401819052608060848501908152845160a486018190526001600160a01b0388169663022c0d9f968a9590939092909160c48501918083838b5b83811015613a2a578181015183820152602001613a12565b50505050905090810190601f168015613a575780820380516001836020036101000a031916815260200191505b5095505050505050600060405180830381600087803b158015613a7957600080fd5b505af1158015613a8d573d6000803e3d6000fd5b50505050613b7d565b604080516000808252602082019283905263022c0d9f60e01b835260248201858152604483018290523060648401819052608060848501908152845160a486018190526001600160a01b0388169663022c0d9f968a969590939092909160c48501918083838a5b83811015613b15578181015183820152602001613afd565b50505050905090810190601f168015613b425780820380516001836020036101000a031916815260200191505b5095505050505050600060405180830381600087803b158015613b6457600080fd5b505af1158015613b78573d6000803e3d6000fd5b505050505b505b949350505050565b60006003821115613bca575080600160028204015b81811015613bc457809150600281828581613bb357fe5b040181613bbc57fe5b049050613b9c565b506124ab565b81156124ab57506001919050565b600c5460408051636eb1769f60e11b81523060048201526001600160a01b0392831660248201529051839285169163dd62ed3e916044808301926020929190829003018186803b158015613c2b57600080fd5b505afa158015613c3f573d6000803e3d6000fd5b505050506040513d6020811015613c5557600080fd5b505110613c6157613c83565b600c54613c83906001600160a01b03848116911660001963ffffffff612a0216565b5050565b828054600181600116156101000203166002900490600052602060002090601f016020900481019282601f10613cc857805160ff1916838001178555613cf5565b82800160010185558215613cf5579182015b82811115613cf5578251825591602001919060010190613cda565b50613d01929150613d05565b5090565b61103f91905b80821115613d015760008155600101613d0b56fe454950373132446f6d61696e28737472696e67206e616d652c737472696e672076657273696f6e2c75696e7432353620636861696e49642c6164647265737320766572696679696e67436f6e747261637429536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f775661756c74546f6b656e3a20494e564c445f5245494e564553545f424f554e54595661756c74546f6b656e3a20494e53554646494349454e545f5245534552564553a265627a7a72315820bcb7f6adbae2f64dc22621dffac38547b548419b42e374ab156388d51f3d45f764736f6c634300051000324f776e61626c653a206e6577206f776e657220697320746865207a65726f2061646472657373a265627a7a723158202e22f3a0d49edd74ba6a4253a872c431dc89765a8f3cbba1735feefb718d6fae64736f6c63430005100032000000000000000000000000d04f1a8182d5670e42ba9ee0ce9ffc71e6d1fc1800000000000000000000000009855b4ef0b9df961ed097ef50172be3e6f13665000000000000000000000000cf8660e267d44cc804ddbee6b1ce44f9ed5648890000000000000000000000009d3591719038752db0c8beee2040ffcc3b2c6b9c0000000000000000000000005cc61a78f164885776aa610fb0fe1257df78e59b
Constructor Arguments (ABI-Encoded and is the last bytes of the Contract Creation Code above)
000000000000000000000000d04f1a8182d5670e42ba9ee0ce9ffc71e6d1fc1800000000000000000000000009855b4ef0b9df961ed097ef50172be3e6f13665000000000000000000000000cf8660e267d44cc804ddbee6b1ce44f9ed5648890000000000000000000000009d3591719038752db0c8beee2040ffcc3b2c6b9c0000000000000000000000005cc61a78f164885776aa610fb0fe1257df78e59b
-----Decoded View---------------
Arg [0] : _optiSwap (address): 0xd04f1a8182d5670e42ba9ee0ce9ffc71e6d1fc18
Arg [1] : _router (address): 0x09855b4ef0b9df961ed097ef50172be3e6f13665
Arg [2] : _gaugeVaultProxy (address): 0xcf8660e267d44cc804ddbee6b1ce44f9ed564889
Arg [3] : _pairFactory (address): 0x9d3591719038752db0c8beee2040ffcc3b2c6b9c
Arg [4] : _rewardsToken (address): 0x5cc61a78f164885776aa610fb0fe1257df78e59b
-----Encoded View---------------
5 Constructor Arguments found :
Arg [0] : 000000000000000000000000d04f1a8182d5670e42ba9ee0ce9ffc71e6d1fc18
Arg [1] : 00000000000000000000000009855b4ef0b9df961ed097ef50172be3e6f13665
Arg [2] : 000000000000000000000000cf8660e267d44cc804ddbee6b1ce44f9ed564889
Arg [3] : 0000000000000000000000009d3591719038752db0c8beee2040ffcc3b2c6b9c
Arg [4] : 0000000000000000000000005cc61a78f164885776aa610fb0fe1257df78e59b
Age | Block | Fee Address | BC Fee Address | Voting Power | Jailed | Incoming |
---|
Validator ID :
0 FTM
Amount Staked
0
Amount Delegated
0
Staking Total
0
Staking Start Epoch
0
Staking Start Time
0
Proof of Importance
0
Origination Score
0
Validation Score
0
Active
0
Online
0
Downtime
0 s
Address | Amount | claimed Rewards | Created On Epoch | Created On |
---|
Make sure to use the "Vote Down" button for any spammy posts, and the "Vote Up" for interesting conversations.