More Info
Private Name Tags
ContractCreator
TokenTracker
Latest 25 from a total of 25 transactions
Transaction Hash |
Method
|
Block
|
From
|
To
|
|||||
---|---|---|---|---|---|---|---|---|---|
Approve | 16631716 | 592 days ago | IN | 0 ETH | 0.00148939 | ||||
Approve | 16611757 | 594 days ago | IN | 0 ETH | 0.00070436 | ||||
Approve | 16609961 | 595 days ago | IN | 0 ETH | 0.000687 | ||||
Approve | 16607495 | 595 days ago | IN | 0 ETH | 0.0008222 | ||||
Approve | 16607371 | 595 days ago | IN | 0 ETH | 0.00081074 | ||||
Approve | 16604820 | 595 days ago | IN | 0 ETH | 0.00078823 | ||||
Approve | 16602036 | 596 days ago | IN | 0 ETH | 0.00061249 | ||||
Approve | 16588538 | 598 days ago | IN | 0 ETH | 0.00174511 | ||||
Approve | 16588502 | 598 days ago | IN | 0 ETH | 0.00202732 | ||||
Approve | 16586923 | 598 days ago | IN | 0 ETH | 0.0020595 | ||||
Approve | 16574372 | 600 days ago | IN | 0 ETH | 0.00118762 | ||||
Approve | 16566783 | 601 days ago | IN | 0 ETH | 0.00080218 | ||||
Approve | 16556054 | 602 days ago | IN | 0 ETH | 0.00111341 | ||||
Approve | 16549164 | 603 days ago | IN | 0 ETH | 0.00155082 | ||||
Approve | 16548826 | 603 days ago | IN | 0 ETH | 0.00144294 | ||||
Approve | 16548451 | 603 days ago | IN | 0 ETH | 0.00111142 | ||||
Approve | 16548444 | 603 days ago | IN | 0 ETH | 0.00115442 | ||||
Approve | 16548396 | 603 days ago | IN | 0 ETH | 0.0009612 | ||||
Approve | 16548358 | 603 days ago | IN | 0 ETH | 0.00106627 | ||||
Approve | 16548325 | 603 days ago | IN | 0 ETH | 0.00111439 | ||||
Approve | 16540857 | 604 days ago | IN | 0 ETH | 0.00072953 | ||||
Approve | 16538304 | 605 days ago | IN | 0 ETH | 0.00196223 | ||||
Approve | 16535921 | 605 days ago | IN | 0 ETH | 0.00132511 | ||||
Approve | 16534698 | 605 days ago | IN | 0 ETH | 0.00093597 | ||||
Approve | 16531130 | 606 days ago | IN | 0 ETH | 0.00083692 |
Latest 1 internal transaction
Advanced mode:
Parent Transaction Hash | Block | From | To | |||
---|---|---|---|---|---|---|
16530513 | 606 days ago | Contract Creation | 0 ETH |
Loading...
Loading
Contract Name:
Collateral
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 "./PoolToken.sol"; import "./CStorage.sol"; import "./CSetter.sol"; import "./interfaces/IBorrowable.sol"; import "./interfaces/ICollateral.sol"; import "./interfaces/IFactory.sol"; import "./interfaces/ITarotSolidlyPriceOracleV2.sol"; import "./interfaces/ITarotCallee.sol"; import "./interfaces/IUniswapV2Pair.sol"; import "./libraries/UQ112x112.sol"; import "./libraries/Math.sol"; contract Collateral is ICollateral, PoolToken, CStorage, CSetter { using UQ112x112 for uint224; constructor() public {} /*** Collateralization Model ***/ // returns the prices of borrowable0's and borrowable1's underlyings with collateral's underlying as denom function getPrices() public returns (uint256 price0, uint256 price1) { uint224 twapPrice112x112; { (uint112 _twapReserve0, uint112 _twapReserve1, ) = ITarotSolidlyPriceOracleV2(tarotPriceOracle).getResult(underlying); twapPrice112x112 = UQ112x112.encode(_twapReserve1).uqdiv(_twapReserve0); } (uint112 reserve0, uint112 reserve1, ) = IUniswapV2Pair(underlying).getReserves(); uint256 collateralTotalSupply = IUniswapV2Pair(underlying).totalSupply(); uint224 currentPrice112x112 = UQ112x112.encode(reserve1).uqdiv(reserve0); uint256 adjustmentSquared = uint256(twapPrice112x112).mul(2**32).div(currentPrice112x112); uint256 adjustment = Math.sqrt(adjustmentSquared.mul(2**32)); uint256 currentBorrowable0Price = uint256(collateralTotalSupply).mul(1e18).div(reserve0 * 2); uint256 currentBorrowable1Price = uint256(collateralTotalSupply).mul(1e18).div(reserve1 * 2); price0 = currentBorrowable0Price.mul(adjustment).div(2**32); price1 = currentBorrowable1Price.mul(2**32).div(adjustment); /* * Price calculation errors may happen in some edge pairs where * reserve0 / reserve1 is close to 2**112 or 1/2**112 * We're going to prevent users from using pairs at risk from the UI */ require(price0 > 100, "Tarot: PRICE_CALCULATION_ERROR"); require(price1 > 100, "Tarot: PRICE_CALCULATION_ERROR"); } // returns liquidity in collateral's underlying function _calculateLiquidity( uint256 amountCollateral, uint256 amount0, uint256 amount1 ) internal returns (uint256 liquidity, uint256 shortfall) { uint256 _safetyMarginSqrt = safetyMarginSqrt; (uint256 price0, uint256 price1) = getPrices(); uint256 a = amount0.mul(price0).div(1e18); uint256 b = amount1.mul(price1).div(1e18); if (a < b) (a, b) = (b, a); a = a.mul(_safetyMarginSqrt).div(1e18); b = b.mul(1e18).div(_safetyMarginSqrt); uint256 collateralNeeded = a.add(b).mul(liquidationPenalty()).div(1e18); if (amountCollateral >= collateralNeeded) { return (amountCollateral - collateralNeeded, 0); } else { return (0, collateralNeeded - amountCollateral); } } /*** ERC20 ***/ function _transfer( address from, address to, uint256 value ) internal { require(tokensUnlocked(from, value), "Tarot: INSUFFICIENT_LIQUIDITY"); super._transfer(from, to, value); } function tokensUnlocked(address from, uint256 value) public returns (bool) { uint256 _balance = balanceOf[from]; if (value > _balance) return false; uint256 finalBalance = _balance - value; uint256 amountCollateral = finalBalance.mul(exchangeRate()).div(1e18); uint256 amount0 = IBorrowable(borrowable0).borrowBalance(from); uint256 amount1 = IBorrowable(borrowable1).borrowBalance(from); (, uint256 shortfall) = _calculateLiquidity(amountCollateral, amount0, amount1); return shortfall == 0; } /*** Collateral ***/ function accountLiquidityAmounts( address borrower, uint256 amount0, uint256 amount1 ) public returns (uint256 liquidity, uint256 shortfall) { if (amount0 == uint256(-1)) amount0 = IBorrowable(borrowable0).borrowBalance(borrower); if (amount1 == uint256(-1)) amount1 = IBorrowable(borrowable1).borrowBalance(borrower); uint256 amountCollateral = balanceOf[borrower].mul(exchangeRate()).div(1e18); return _calculateLiquidity(amountCollateral, amount0, amount1); } function accountLiquidity(address borrower) public returns (uint256 liquidity, uint256 shortfall) { return accountLiquidityAmounts(borrower, uint256(-1), uint256(-1)); } function canBorrow( address borrower, address borrowable, uint256 accountBorrows ) public returns (bool) { address _borrowable0 = borrowable0; address _borrowable1 = borrowable1; require( borrowable == _borrowable0 || borrowable == _borrowable1, "Tarot: INVALID_BORROWABLE" ); uint256 amount0 = borrowable == _borrowable0 ? accountBorrows : uint256(-1); uint256 amount1 = borrowable == _borrowable1 ? accountBorrows : uint256(-1); (, uint256 shortfall) = accountLiquidityAmounts(borrower, amount0, amount1); return shortfall == 0; } // this function must be called from borrowable0 or borrowable1 function seize( address liquidator, address borrower, uint256 repayAmount ) external returns (uint256 seizeTokens) { require( msg.sender == borrowable0 || msg.sender == borrowable1, "Tarot: UNAUTHORIZED" ); (, uint256 shortfall) = accountLiquidity(borrower); require(shortfall > 0, "Tarot: INSUFFICIENT_SHORTFALL"); uint256 price; if (msg.sender == borrowable0) (price, ) = getPrices(); else (, price) = getPrices(); uint256 collateralEquivalent = repayAmount.mul(price).div(exchangeRate()); seizeTokens = collateralEquivalent .mul(liquidationIncentive) .div(1e18); balanceOf[borrower] = balanceOf[borrower].sub( seizeTokens, "Tarot: LIQUIDATING_TOO_MUCH" ); balanceOf[liquidator] = balanceOf[liquidator].add(seizeTokens); emit Transfer(borrower, liquidator, seizeTokens); if (liquidationFee > 0) { uint256 seizeFee = collateralEquivalent.mul(liquidationFee).div(1e18); address reservesManager = IFactory(factory).reservesManager(); balanceOf[borrower] = balanceOf[borrower].sub(seizeFee, "Tarot: LIQUIDATING_TOO_MUCH"); balanceOf[reservesManager] = balanceOf[reservesManager].add(seizeFee); emit Transfer(borrower, reservesManager, seizeFee); } } // this low-level function should be called from another contract function flashRedeem( address redeemer, uint256 redeemAmount, bytes calldata data ) external nonReentrant update { require(redeemAmount <= totalBalance, "Tarot: INSUFFICIENT_CASH"); // optimistically transfer funds _safeTransfer(redeemer, redeemAmount); if (data.length > 0) ITarotCallee(redeemer).tarotRedeem(msg.sender, redeemAmount, data); uint256 redeemTokens = balanceOf[address(this)]; uint256 declaredRedeemTokens = redeemAmount.mul(1e18).div(exchangeRate()).add(1); // rounded up require( redeemTokens >= declaredRedeemTokens, "Tarot: INSUFFICIENT_REDEEM_TOKENS" ); _burn(address(this), redeemTokens); emit Redeem(msg.sender, redeemer, redeemAmount, redeemTokens); } }
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 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(); } }
pragma solidity =0.5.16; contract CStorage { address public borrowable0; address public borrowable1; address public tarotPriceOracle; uint public safetyMarginSqrt = 1.41421356e18; //safetyMargin: 200% uint public liquidationIncentive = 1.04e18; //104% uint public liquidationFee = 0.02e18; //2% function liquidationPenalty() public view returns (uint) { return liquidationIncentive + liquidationFee; } }
pragma solidity =0.5.16; import "./CStorage.sol"; import "./PoolToken.sol"; import "./interfaces/IFactory.sol"; import "./interfaces/ITarotSolidlyPriceOracleV2.sol"; contract CSetter is PoolToken, CStorage { uint256 public constant SAFETY_MARGIN_SQRT_MIN = 1.00e18; //safetyMargin: 100% uint256 public constant SAFETY_MARGIN_SQRT_MAX = 1.58113884e18; //safetyMargin: 250% uint256 public constant LIQUIDATION_INCENTIVE_MIN = 1.00e18; //100% uint256 public constant LIQUIDATION_INCENTIVE_MAX = 1.10e18; //110% uint256 public constant LIQUIDATION_FEE_MAX = 0.05e18; //5% event NewSafetyMargin(uint256 newSafetyMarginSqrt); event NewLiquidationIncentive(uint256 newLiquidationIncentive); event NewLiquidationFee(uint256 newLiquidationFee); // called once by the factory at the time of deployment function _initialize( string calldata _name, string calldata _symbol, address _underlying, address _borrowable0, address _borrowable1 ) external { require(msg.sender == factory, "Tarot: UNAUTHORIZED"); // sufficient check _setName(_name, _symbol); underlying = _underlying; borrowable0 = _borrowable0; borrowable1 = _borrowable1; tarotPriceOracle = IFactory(factory).tarotPriceOracle(); } function _setSafetyMarginSqrt(uint256 newSafetyMarginSqrt) external nonReentrant { _checkSetting( newSafetyMarginSqrt, SAFETY_MARGIN_SQRT_MIN, SAFETY_MARGIN_SQRT_MAX ); safetyMarginSqrt = newSafetyMarginSqrt; emit NewSafetyMargin(newSafetyMarginSqrt); } function _setLiquidationIncentive(uint256 newLiquidationIncentive) external nonReentrant { _checkSetting( newLiquidationIncentive, LIQUIDATION_INCENTIVE_MIN, LIQUIDATION_INCENTIVE_MAX ); liquidationIncentive = newLiquidationIncentive; emit NewLiquidationIncentive(newLiquidationIncentive); } function _setLiquidationFee(uint256 newLiquidationFee) external nonReentrant { _checkSetting( newLiquidationFee, 0, LIQUIDATION_FEE_MAX ); liquidationFee = newLiquidationFee; emit NewLiquidationFee(newLiquidationFee); } function _checkSetting( uint256 parameter, uint256 min, uint256 max ) internal view { _checkAdmin(); require(parameter >= min, "Tarot: INVALID_SETTING"); require(parameter <= max, "Tarot: INVALID_SETTING"); } function _checkAdmin() internal view { require(msg.sender == IFactory(factory).admin(), "Tarot: UNAUTHORIZED"); } }
pragma solidity >=0.5.0; interface IBorrowable { /*** 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 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; /*** Borrowable ***/ event BorrowApproval( address indexed owner, address indexed spender, uint256 value ); event Borrow( address indexed sender, address indexed borrower, address indexed receiver, uint256 borrowAmount, uint256 repayAmount, uint256 accountBorrowsPrior, uint256 accountBorrows, uint256 totalBorrows ); event Liquidate( address indexed sender, address indexed borrower, address indexed liquidator, uint256 seizeTokens, uint256 repayAmount, uint256 accountBorrowsPrior, uint256 accountBorrows, uint256 totalBorrows ); function BORROW_FEE() external pure returns (uint256); function collateral() external view returns (address); function reserveFactor() external view returns (uint256); function exchangeRateLast() external view returns (uint256); function borrowIndex() external view returns (uint256); function totalBorrows() external view returns (uint256); function borrowAllowance(address owner, address spender) external view returns (uint256); function borrowBalance(address borrower) external view returns (uint256); function borrowTracker() external view returns (address); function BORROW_PERMIT_TYPEHASH() external pure returns (bytes32); function borrowApprove(address spender, uint256 value) external returns (bool); function borrowPermit( address owner, address spender, uint256 value, uint256 deadline, uint8 v, bytes32 r, bytes32 s ) external; function borrow( address borrower, address receiver, uint256 borrowAmount, bytes calldata data ) external; function liquidate(address borrower, address liquidator) external returns (uint256 seizeTokens); function trackBorrow(address borrower) external; /*** Borrowable Interest Rate Model ***/ event AccrueInterest( uint256 interestAccumulated, uint256 borrowIndex, uint256 totalBorrows ); event CalculateKink(uint256 kinkRate); event CalculateBorrowRate(uint256 borrowRate); function KINK_BORROW_RATE_MAX() external pure returns (uint256); function KINK_BORROW_RATE_MIN() external pure returns (uint256); function KINK_MULTIPLIER() external pure returns (uint256); function borrowRate() external view returns (uint256); function kinkBorrowRate() external view returns (uint256); function kinkUtilizationRate() external view returns (uint256); function adjustSpeed() external view returns (uint256); function rateUpdateTimestamp() external view returns (uint32); function accrualTimestamp() external view returns (uint32); function accrueInterest() external; /*** Borrowable Setter ***/ event NewReserveFactor(uint256 newReserveFactor); event NewKinkUtilizationRate(uint256 newKinkUtilizationRate); event NewAdjustSpeed(uint256 newAdjustSpeed); event NewBorrowTracker(address newBorrowTracker); function RESERVE_FACTOR_MAX() external pure returns (uint256); function KINK_UR_MIN() external pure returns (uint256); function KINK_UR_MAX() external pure returns (uint256); function ADJUST_SPEED_MIN() external pure returns (uint256); function ADJUST_SPEED_MAX() external pure returns (uint256); function _initialize( string calldata _name, string calldata _symbol, address _underlying, address _collateral ) external; function _setReserveFactor(uint256 newReserveFactor) external; function _setKinkUtilizationRate(uint256 newKinkUtilizationRate) external; function _setAdjustSpeed(uint256 newAdjustSpeed) external; function _setBorrowTracker(address newBorrowTracker) external; }
pragma solidity >=0.5.0; interface ICollateral { /*** 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 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; /*** Collateral ***/ function borrowable0() external view returns (address); function borrowable1() external view returns (address); function tarotPriceOracle() external view returns (address); function safetyMarginSqrt() external view returns (uint256); function liquidationIncentive() external view returns (uint256); function liquidationFee() external view returns (uint256); function liquidationPenalty() external view returns (uint256); function getPrices() external returns (uint256 price0, uint256 price1); function tokensUnlocked(address from, uint256 value) external returns (bool); function accountLiquidityAmounts( address account, uint256 amount0, uint256 amount1 ) external returns (uint256 liquidity, uint256 shortfall); function accountLiquidity(address account) external returns (uint256 liquidity, uint256 shortfall); function canBorrow( address account, address borrowable, uint256 accountBorrows ) external returns (bool); function seize( address liquidator, address borrower, uint256 repayAmount ) external returns (uint256 seizeTokens); function flashRedeem( address redeemer, uint256 redeemAmount, bytes calldata data ) external; /*** Collateral Setter ***/ event NewSafetyMargin(uint256 newSafetyMarginSqrt); event NewLiquidationIncentive(uint256 newLiquidationIncentive); event NewLiquidationFee(uint256 newLiquidationFee); function SAFETY_MARGIN_SQRT_MIN() external pure returns (uint256); function SAFETY_MARGIN_SQRT_MAX() external pure returns (uint256); function LIQUIDATION_INCENTIVE_MIN() external pure returns (uint256); function LIQUIDATION_INCENTIVE_MAX() external pure returns (uint256); function LIQUIDATION_FEE_MAX() external pure returns (uint256); function _initialize( string calldata _name, string calldata _symbol, address _underlying, address _borrowable0, address _borrowable1 ) external; function _setSafetyMarginSqrt(uint256 newSafetyMarginSqrt) external; function _setLiquidationIncentive(uint256 newLiquidationIncentive) external; function _setLiquidationFee(uint256 newLiquidationFee) external; }
pragma solidity >=0.5.0; interface IFactory { event LendingPoolInitialized(address indexed uniswapV2Pair, address indexed token0, address indexed token1, address collateral, address borrowable0, address borrowable1, uint lendingPoolId); event NewPendingAdmin(address oldPendingAdmin, address newPendingAdmin); event NewAdmin(address oldAdmin, address newAdmin); event NewReservesPendingAdmin(address oldReservesPendingAdmin, address newReservesPendingAdmin); event NewReservesAdmin(address oldReservesAdmin, address newReservesAdmin); event NewReservesManager(address oldReservesManager, address newReservesManager); function admin() external view returns (address); function pendingAdmin() external view returns (address); function reservesAdmin() external view returns (address); function reservesPendingAdmin() external view returns (address); function reservesManager() external view returns (address); function getLendingPool(address uniswapV2Pair) external view returns ( bool initialized, uint24 lendingPoolId, address collateral, address borrowable0, address borrowable1 ); function allLendingPools(uint) external view returns (address uniswapV2Pair); function allLendingPoolsLength() external view returns (uint); function bDeployer() external view returns (address); function cDeployer() external view returns (address); function tarotPriceOracle() external view returns (address); function createCollateral(address uniswapV2Pair) external returns (address collateral); function createBorrowable0(address uniswapV2Pair) external returns (address borrowable0); function createBorrowable1(address uniswapV2Pair) external returns (address borrowable1); function initializeLendingPool(address uniswapV2Pair) external; function _setPendingAdmin(address newPendingAdmin) external; function _acceptAdmin() external; function _setReservesPendingAdmin(address newPendingAdmin) external; function _acceptReservesAdmin() external; function _setReservesManager(address newReservesManager) external; }
pragma solidity >=0.5; interface ITarotSolidlyPriceOracleV2 { function MIN_T() external pure returns (uint32); function getResult(address pair) external returns (uint112 reserve0, uint112 reserve1, uint32 T); }
pragma solidity >=0.5.0; interface ITarotCallee { function tarotBorrow( address sender, address borrower, uint256 borrowAmount, bytes calldata data ) external; function tarotRedeem( address sender, uint256 redeemAmount, bytes calldata data ) external; }
pragma solidity >=0.5.0; interface IUniswapV2Pair { event Approval(address indexed owner, address indexed spender, uint value); event Transfer(address indexed from, address indexed to, uint 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 (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 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 (uint); }
pragma solidity =0.5.16; // a library for handling binary fixed point numbers (https://en.wikipedia.org/wiki/Q_(number_format)) // src: https://github.com/Uniswap/uniswap-v2-core/blob/master/contracts/libraries/UQ112x112.sol // range: [0, 2**112 - 1] // resolution: 1 / 2**112 library UQ112x112 { uint224 constant Q112 = 2**112; // encode a uint112 as a UQ112x112 function encode(uint112 y) internal pure returns (uint224 z) { z = uint224(y) * Q112; // never overflows } // divide a UQ112x112 by a uint112, returning a UQ112x112 function uqdiv(uint224 x, uint112 y) internal pure returns (uint224 z) { z = x / uint224(y); } }
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(uint x, uint y) internal pure returns (uint z) { z = x < y ? x : y; } // babylonian method (https://en.wikipedia.org/wiki/Methods_of_computing_square_roots#Babylonian_method) function sqrt(uint y) internal pure returns (uint z) { if (y > 3) { z = y; uint 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 IERC20 { event Approval(address indexed owner, address indexed spender, uint value); event Transfer(address indexed from, address indexed to, uint 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 (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); }
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 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":[],"payable":false,"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"sender","type":"address"},{"indexed":true,"internalType":"address","name":"minter","type":"address"},{"indexed":false,"internalType":"uint256","name":"mintAmount","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"mintTokens","type":"uint256"}],"name":"Mint","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"newLiquidationFee","type":"uint256"}],"name":"NewLiquidationFee","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"newLiquidationIncentive","type":"uint256"}],"name":"NewLiquidationIncentive","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"newSafetyMarginSqrt","type":"uint256"}],"name":"NewSafetyMargin","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"sender","type":"address"},{"indexed":true,"internalType":"address","name":"redeemer","type":"address"},{"indexed":false,"internalType":"uint256","name":"redeemAmount","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"redeemTokens","type":"uint256"}],"name":"Redeem","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"totalBalance","type":"uint256"}],"name":"Sync","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"constant":true,"inputs":[],"name":"DOMAIN_SEPARATOR","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"LIQUIDATION_FEE_MAX","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"LIQUIDATION_INCENTIVE_MAX","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"LIQUIDATION_INCENTIVE_MIN","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"MINIMUM_LIQUIDITY","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"PERMIT_TYPEHASH","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"SAFETY_MARGIN_SQRT_MAX","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"SAFETY_MARGIN_SQRT_MIN","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"string","name":"_name","type":"string"},{"internalType":"string","name":"_symbol","type":"string"},{"internalType":"address","name":"_underlying","type":"address"},{"internalType":"address","name":"_borrowable0","type":"address"},{"internalType":"address","name":"_borrowable1","type":"address"}],"name":"_initialize","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[],"name":"_setFactory","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"uint256","name":"newLiquidationFee","type":"uint256"}],"name":"_setLiquidationFee","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"uint256","name":"newLiquidationIncentive","type":"uint256"}],"name":"_setLiquidationIncentive","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"uint256","name":"newSafetyMarginSqrt","type":"uint256"}],"name":"_setSafetyMarginSqrt","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"borrower","type":"address"}],"name":"accountLiquidity","outputs":[{"internalType":"uint256","name":"liquidity","type":"uint256"},{"internalType":"uint256","name":"shortfall","type":"uint256"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"borrower","type":"address"},{"internalType":"uint256","name":"amount0","type":"uint256"},{"internalType":"uint256","name":"amount1","type":"uint256"}],"name":"accountLiquidityAmounts","outputs":[{"internalType":"uint256","name":"liquidity","type":"uint256"},{"internalType":"uint256","name":"shortfall","type":"uint256"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"internalType":"address","name":"","type":"address"},{"internalType":"address","name":"","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"borrowable0","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"borrowable1","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"borrower","type":"address"},{"internalType":"address","name":"borrowable","type":"address"},{"internalType":"uint256","name":"accountBorrows","type":"uint256"}],"name":"canBorrow","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[],"name":"exchangeRate","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"factory","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"redeemer","type":"address"},{"internalType":"uint256","name":"redeemAmount","type":"uint256"},{"internalType":"bytes","name":"data","type":"bytes"}],"name":"flashRedeem","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[],"name":"getPrices","outputs":[{"internalType":"uint256","name":"price0","type":"uint256"},{"internalType":"uint256","name":"price1","type":"uint256"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"liquidationFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"liquidationIncentive","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"liquidationPenalty","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"minter","type":"address"}],"name":"mint","outputs":[{"internalType":"uint256","name":"mintTokens","type":"uint256"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"nonces","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"},{"internalType":"uint256","name":"deadline","type":"uint256"},{"internalType":"uint8","name":"v","type":"uint8"},{"internalType":"bytes32","name":"r","type":"bytes32"},{"internalType":"bytes32","name":"s","type":"bytes32"}],"name":"permit","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"redeemer","type":"address"}],"name":"redeem","outputs":[{"internalType":"uint256","name":"redeemAmount","type":"uint256"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"safetyMarginSqrt","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"liquidator","type":"address"},{"internalType":"address","name":"borrower","type":"address"},{"internalType":"uint256","name":"repayAmount","type":"uint256"}],"name":"seize","outputs":[{"internalType":"uint256","name":"seizeTokens","type":"uint256"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"to","type":"address"}],"name":"skim","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[],"name":"sync","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"tarotPriceOracle","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"}],"name":"tokensUnlocked","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"totalBalance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"underlying","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"}]
Contract Creation Code
60806040526002805460ff19908116601217909155600b805490911660011790556713a04bbd70573000600e55670e6ed27d66680000600f5566470de4df82000060105534801561004f57600080fd5b506131308061005f6000396000f3fe608060405234801561001057600080fd5b506004361061028a5760003560e01c806370a082311161015c578063ba9a7a56116100ce578063c548e3c511610087578063c548e3c51461073d578063d490e7e014610816578063d505accf1461081e578063daf888181461086f578063dd62ed3e14610877578063fff6cae9146108a55761028a565b8063ba9a7a56146106e2578063bb6ff386146106ea578063bc25cf7714610707578063bc9bd12a1461034c578063bd9a548b1461072d578063c45a0155146107355761028a565b80639aac2c53116101205780639aac2c5314610632578063a36a363014610668578063a9059cbb14610670578063ad7a672f1461069c578063afc8276c146106a4578063b2a02ff1146106ac5761028a565b806370a08231146105b05780637ecebe00146105d65780638c765e94146105fc57806395a2251f1461060457806395d89b411461062a5761028a565b806333fabfd1116102005780634fd42e17116101b95780634fd42e17146104c85780635a0f03c6146104e55780636a627842146105245780636e01be101461054a5780636f13cb83146105765780636f307dc3146105a85761028a565b806333fabfd11461049857806334fb08a8146104a0578063356c571f146104a85780633644e515146104b05780633ba0b9a9146104b85780634a5d316c146104c05761028a565b80631ef63a79116102525780631ef63a79146103f357806323b872dd1461041057806323f5589a146104465780632fa5ae1b1461044e57806330adf81f14610472578063313ce5671461047a5761028a565b806306fdde031461028f578063095ea7b31461030c5780630fb60fef1461034c57806318160ddd1461036657806319f3400d1461036e575b600080fd5b6102976108ad565b6040805160208082528351818301528351919283929083019185019080838360005b838110156102d15781810151838201526020016102b9565b50505050905090810190601f1680156102fe5780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b6103386004803603604081101561032257600080fd5b506001600160a01b03813516906020013561093b565b604080519115158252519081900360200190f35b610354610952565b60408051918252519081900360200190f35b61035461095e565b6103f16004803603606081101561038457600080fd5b6001600160a01b0382351691602081013591810190606081016040820135600160201b8111156103b357600080fd5b8201836020820111156103c557600080fd5b803590602001918460018302840111600160201b831117156103e657600080fd5b509092509050610964565b005b6103f16004803603602081101561040957600080fd5b5035610bbb565b6103386004803603606081101561042657600080fd5b506001600160a01b03813581169160208101359091169060400135610c6a565b610354610d39565b610456610d44565b604080516001600160a01b039092168252519081900360200190f35b610354610d58565b610482610d7c565b6040805160ff9092168252519081900360200190f35b610354610d85565b610456610d90565b610354610d9f565b610354610da5565b610354610dab565b6103f1610dfa565b6103f1600480360360208110156104de57600080fd5b5035610e6c565b61050b600480360360208110156104fb57600080fd5b50356001600160a01b0316610f23565b6040805192835260208301919091528051918290030190f35b6103546004803603602081101561053a57600080fd5b50356001600160a01b0316610f3c565b6103386004803603604081101561056057600080fd5b506001600160a01b03813516906020013561113a565b61050b6004803603606081101561058c57600080fd5b506001600160a01b0381351690602081013590604001356112c6565b610456611434565b610354600480360360208110156105c657600080fd5b50356001600160a01b0316611443565b610354600480360360208110156105ec57600080fd5b50356001600160a01b0316611455565b610354611467565b6103546004803603602081101561061a57600080fd5b50356001600160a01b031661146d565b610297611606565b6103386004803603606081101561064857600080fd5b506001600160a01b03813581169160208101359091169060400135611660565b610354611749565b6103386004803603604081101561068657600080fd5b506001600160a01b03813516906020013561174f565b61035461175c565b610354611762565b610354600480360360608110156106c257600080fd5b506001600160a01b0381358116916020810135909116906040013561176e565b610354611b3a565b6103f16004803603602081101561070057600080fd5b5035611b40565b6103f16004803603602081101561071d57600080fd5b50356001600160a01b0316611bf7565b61050b611cf1565b610456612045565b6103f1600480360360a081101561075357600080fd5b810190602081018135600160201b81111561076d57600080fd5b82018360208201111561077f57600080fd5b803590602001918460018302840111600160201b831117156107a057600080fd5b919390929091602081019035600160201b8111156107bd57600080fd5b8201836020820111156107cf57600080fd5b803590602001918460018302840111600160201b831117156107f057600080fd5b91935091506001600160a01b038135811691602081013582169160409091013516612054565b6103546121f5565b6103f1600480360360e081101561083457600080fd5b506001600160a01b03813581169160208101359091169060408101359060608101359060ff6080820135169060a08101359060c00135612201565b610456612245565b6103546004803603604081101561088d57600080fd5b506001600160a01b0381358116916020013516612254565b6103f1612271565b6000805460408051602060026001851615610100026000190190941693909304601f810184900484028201840190925281815292918301828280156109335780601f1061090857610100808354040283529160200191610933565b820191906000526020600020905b81548152906001019060200180831161091657829003601f168201915b505050505081565b60006109483384846122dc565b5060015b92915050565b670de0b6b3a764000081565b60035481565b600b5460ff166109ae576040805162461bcd60e51b815260206004820152601060248201526f15185c9bdd0e8814915153951154915160821b604482015290519081900360640190fd5b600b805460ff19169055600a54831115610a0a576040805162461bcd60e51b81526020600482015260186024820152770a8c2e4dee87440929ca6aa8c8c9286928a9ca8be8682a6960431b604482015290519081900360640190fd5b610a14848461233e565b8015610aba57604051636b4d4dc160e01b8152336004820181815260248301869052606060448401908152606484018590526001600160a01b03881693636b4d4dc193928892889288929190608401848480828437600081840152601f19601f82011690508083019250505095505050505050600060405180830381600087803b158015610aa157600080fd5b505af1158015610ab5573d6000803e3d6000fd5b505050505b3060009081526004602052604081205490610b0b6001610aff610adb610dab565b610af389670de0b6b3a764000063ffffffff6124d016565b9063ffffffff61253016565b9063ffffffff61257216565b905080821015610b4c5760405162461bcd60e51b81526004018080602001828103825260218152602001806130486021913960400191505060405180910390fd5b610b5630836125cc565b604080518681526020810184905281516001600160a01b0389169233927f3f693fff038bb8a046aa76d9516190ac7444f7d69cf952c4cbdc086fdef2d6fc929081900390910190a35050610ba8612657565b5050600b805460ff191660011790555050565b600b5460ff16610c05576040805162461bcd60e51b815260206004820152601060248201526f15185c9bdd0e8814915153951154915160821b604482015290519081900360640190fd5b600b805460ff19169055610c2281600066b1a2bc2ec50000612707565b60108190556040805182815290517f21e5451a492a87031e8324e7e1e2ba821fdec0c40972393c9f74dd38bd88a6af9181900360200190a150600b805460ff19166001179055565b6001600160a01b038316600090815260056020908152604080832033845290915281205460001914610d2457604080518082018252601b81527f5461726f743a205452414e534645525f4e4f545f414c4c4f57454400000000006020808301919091526001600160a01b0387166000908152600582528381203382529091529190912054610cff91849063ffffffff6127b016565b6001600160a01b03851660009081526005602090815260408083203384529091529020555b610d2f848484612847565b5060019392505050565b601054600f54015b90565b600b5461010090046001600160a01b031681565b7f6e71edae12b1b97f4d1f60370fef10105fa2faae0126114a169c64845d6126c981565b60025460ff1681565b66b1a2bc2ec5000081565b600d546001600160a01b031681565b600e5481565b60065481565b600354600a5460009190811580610dc0575080155b15610dd757670de0b6b3a764000092505050610d41565b610df382610af383670de0b6b3a764000063ffffffff6124d016565b9250505090565b6009546001600160a01b031615610e58576040805162461bcd60e51b815260206004820152601a60248201527f5461726f743a20464143544f52595f414c52454144595f534554000000000000604482015290519081900360640190fd5b600980546001600160a01b03191633179055565b600b5460ff16610eb6576040805162461bcd60e51b815260206004820152601060248201526f15185c9bdd0e8814915153951154915160821b604482015290519081900360640190fd5b600b805460ff19169055610edb81670de0b6b3a7640000670f43fc2c04ee0000612707565b600f8190556040805182815290517f8a9bb9067f9ecb13a322b548e6df3dd1bd10a54698834dac43ed8f0e765bf94d9181900360200190a150600b805460ff19166001179055565b600080610f3383600019806112c6565b91509150915091565b600b5460009060ff16610f89576040805162461bcd60e51b815260206004820152601060248201526f15185c9bdd0e8814915153951154915160821b604482015290519081900360640190fd5b600b805460ff19169055600854604080516370a0823160e01b815230600482015290516000926001600160a01b0316916370a08231916024808301926020929190829003018186803b158015610fde57600080fd5b505afa158015610ff2573d6000803e3d6000fd5b505050506040513d602081101561100857600080fd5b5051600a5490915060009061102490839063ffffffff6128ad16565b9050611049611031610dab565b610af383670de0b6b3a764000063ffffffff6124d016565b92506003546000141561107757611068836103e863ffffffff6128ad16565b925061107760006103e86128ef565b600083116110cc576040805162461bcd60e51b815260206004820152601760248201527f5461726f743a204d494e545f414d4f554e545f5a45524f000000000000000000604482015290519081900360640190fd5b6110d684846128ef565b604080518281526020810185905281516001600160a01b0387169233927f2f00e3cdd69a77be7ed215ec7b2a36784dd158f921fca79ac29deffa353fe6ee929081900390910190a35050611128612657565b600b805460ff19166001179055919050565b6001600160a01b0382166000908152600460205260408120548083111561116557600091505061094c565b828103600061118e670de0b6b3a7640000610af3611181610dab565b859063ffffffff6124d016565b90506000600b60019054906101000a90046001600160a01b03166001600160a01b0316634d73e9ba886040518263ffffffff1660e01b815260040180826001600160a01b03166001600160a01b0316815260200191505060206040518083038186803b1580156111fd57600080fd5b505afa158015611211573d6000803e3d6000fd5b505050506040513d602081101561122757600080fd5b5051600c54604080516326b9f4dd60e11b81526001600160a01b038b8116600483015291519394506000939190921691634d73e9ba916024808301926020929190829003018186803b15801561127c57600080fd5b505afa158015611290573d6000803e3d6000fd5b505050506040513d60208110156112a657600080fd5b5051905060006112b7848484612974565b159a9950505050505050505050565b60008060001984141561135557600b54604080516326b9f4dd60e11b81526001600160a01b038881166004830152915161010090930490911691634d73e9ba91602480820192602092909190829003018186803b15801561132657600080fd5b505afa15801561133a573d6000803e3d6000fd5b505050506040513d602081101561135057600080fd5b505193505b6000198314156113db57600c54604080516326b9f4dd60e11b81526001600160a01b03888116600483015291519190921691634d73e9ba916024808301926020929190829003018186803b1580156113ac57600080fd5b505afa1580156113c0573d6000803e3d6000fd5b505050506040513d60208110156113d657600080fd5b505192505b6000611419670de0b6b3a7640000610af36113f4610dab565b6001600160a01b038a166000908152600460205260409020549063ffffffff6124d016565b9050611426818686612974565b92509250505b935093915050565b6008546001600160a01b031681565b60046020526000908152604090205481565b60076020526000908152604090205481565b600f5481565b600b5460009060ff166114ba576040805162461bcd60e51b815260206004820152601060248201526f15185c9bdd0e8814915153951154915160821b604482015290519081900360640190fd5b600b805460ff19169055306000908152600460205260409020546114f8670de0b6b3a7640000610af36114eb610dab565b849063ffffffff6124d016565b91506000821161154f576040805162461bcd60e51b815260206004820152601960248201527f5461726f743a2052454445454d5f414d4f554e545f5a45524f00000000000000604482015290519081900360640190fd5b600a548211156115a1576040805162461bcd60e51b81526020600482015260186024820152770a8c2e4dee87440929ca6aa8c8c9286928a9ca8be8682a6960431b604482015290519081900360640190fd5b6115ab30826125cc565b6115b5838361233e565b604080518381526020810183905281516001600160a01b0386169233927f3f693fff038bb8a046aa76d9516190ac7444f7d69cf952c4cbdc086fdef2d6fc929081900390910190a350611128612657565b60018054604080516020600284861615610100026000190190941693909304601f810184900484028201840190925281815292918301828280156109335780601f1061090857610100808354040283529160200191610933565b600b54600c546000916001600160a01b03610100909104811691811690851682148061169d5750806001600160a01b0316856001600160a01b0316145b6116ee576040805162461bcd60e51b815260206004820152601960248201527f5461726f743a20494e56414c49445f424f52524f5741424c4500000000000000604482015290519081900360640190fd5b6000826001600160a01b0316866001600160a01b03161461171157600019611713565b845b90506000826001600160a01b0316876001600160a01b0316146117385760001961173a565b855b905060006112b78984846112c6565b60105481565b6000610948338484612847565b600a5481565b670f43fc2c04ee000081565b600b5460009061010090046001600160a01b03163314806117995750600c546001600160a01b031633145b6117e0576040805162461bcd60e51b815260206004820152601360248201527215185c9bdd0e8815539055551213d492569151606a1b604482015290519081900360640190fd5b60006117eb84610f23565b91505060008111611843576040805162461bcd60e51b815260206004820152601d60248201527f5461726f743a20494e53554646494349454e545f53484f525446414c4c000000604482015290519081900360640190fd5b600b5460009061010090046001600160a01b031633141561186e57611866611cf1565b50905061187a565b611876611cf1565b9150505b6000611897611887610dab565b610af3878563ffffffff6124d016565b90506118ba670de0b6b3a7640000610af3600f54846124d090919063ffffffff16565b935061192b846040518060400160405280601b81526020017f5461726f743a204c49515549444154494e475f544f4f5f4d5543480000000000815250600460008a6001600160a01b03166001600160a01b03168152602001908152602001600020546127b09092919063ffffffff16565b6001600160a01b038088166000908152600460205260408082209390935590891681522054611960908563ffffffff61257216565b6001600160a01b0380891660008181526004602090815260409182902094909455805188815290519193928a16926000805160206130dc83398151915292918290030190a360105415611b305760006119d0670de0b6b3a7640000610af3601054856124d090919063ffffffff16565b90506000600960009054906101000a90046001600160a01b03166001600160a01b031663345ef9416040518163ffffffff1660e01b815260040160206040518083038186803b158015611a2257600080fd5b505afa158015611a36573d6000803e3d6000fd5b505050506040513d6020811015611a4c57600080fd5b5051604080518082018252601b81527f5461726f743a204c49515549444154494e475f544f4f5f4d55434800000000006020828101919091526001600160a01b038c16600090815260049091529190912054919250611ab39190849063ffffffff6127b016565b6001600160a01b03808a166000908152600460205260408082209390935590831681522054611ae8908363ffffffff61257216565b6001600160a01b0380831660008181526004602090815260409182902094909455805186815290519193928c16926000805160206130dc83398151915292918290030190a350505b5050509392505050565b6103e881565b600b5460ff16611b8a576040805162461bcd60e51b815260206004820152601060248201526f15185c9bdd0e8814915153951154915160821b604482015290519081900360640190fd5b600b805460ff19169055611baf81670de0b6b3a76400006715f15565d2c5f000612707565b600e8190556040805182815290517fdff9a61839be6f6ce5ea77311cc351786a39a9f337c507ff35e7b358fd39c0439181900360200190a150600b805460ff19166001179055565b600b5460ff16611c41576040805162461bcd60e51b815260206004820152601060248201526f15185c9bdd0e8814915153951154915160821b604482015290519081900360640190fd5b600b805460ff19169055600a54600854604080516370a0823160e01b81523060048201529051611ce1938593611cdc9391926001600160a01b03909116916370a08231916024808301926020929190829003018186803b158015611ca457600080fd5b505afa158015611cb8573d6000803e3d6000fd5b505050506040513d6020811015611cce57600080fd5b50519063ffffffff6128ad16565b61233e565b50600b805460ff19166001179055565b600d546008546040805163022351bf60e51b81526001600160a01b03928316600482015290516000938493849384938493929092169163446a37e09160248082019260609290919082900301818787803b158015611d4e57600080fd5b505af1158015611d62573d6000803e3d6000fd5b505050506040513d6060811015611d7857600080fd5b5080516020909101519092509050611da882611d9383612a76565b6001600160e01b03169063ffffffff612a8816565b92505050600080600860009054906101000a90046001600160a01b03166001600160a01b0316630902f1ac6040518163ffffffff1660e01b815260040160606040518083038186803b158015611dfd57600080fd5b505afa158015611e11573d6000803e3d6000fd5b505050506040513d6060811015611e2757600080fd5b508051602091820151600854604080516318160ddd60e01b815290519396509194506000936001600160a01b03909116926318160ddd926004808201939291829003018186803b158015611e7a57600080fd5b505afa158015611e8e573d6000803e3d6000fd5b505050506040513d6020811015611ea457600080fd5b505190506000611eb784611d9385612a76565b90506000611ee06001600160e01b0380841690610af3908916600160201b63ffffffff6124d016565b90506000611f00611efb83600160201b63ffffffff6124d016565b612aad565b90506000611f2c6001600160701b036002890216610af387670de0b6b3a764000063ffffffff6124d016565b90506000611f586001600160701b036002890216610af388670de0b6b3a764000063ffffffff6124d016565b9050611f72600160201b610af3848663ffffffff6124d016565b9a50611f8c83610af383600160201b63ffffffff6124d016565b995060648b11611fe3576040805162461bcd60e51b815260206004820152601e60248201527f5461726f743a2050524943455f43414c43554c4154494f4e5f4552524f520000604482015290519081900360640190fd5b60648a11612038576040805162461bcd60e51b815260206004820152601e60248201527f5461726f743a2050524943455f43414c43554c4154494f4e5f4552524f520000604482015290519081900360640190fd5b5050505050505050509091565b6009546001600160a01b031681565b6009546001600160a01b031633146120a9576040805162461bcd60e51b815260206004820152601360248201527215185c9bdd0e8815539055551213d492569151606a1b604482015290519081900360640190fd5b61211c87878080601f01602080910402602001604051908101604052809392919081815260200183838082843760009201919091525050604080516020601f8b018190048102820181019092528981529250899150889081908401838280828437600092019190915250612aff92505050565b600880546001600160a01b03199081166001600160a01b0386811691909117909255600b8054610100600160a81b03191661010086851602179055600c80549091168383161790556009546040805163069f611560e31b8152905191909216916334fb08a8916004808301926020929190829003018186803b1580156121a157600080fd5b505afa1580156121b5573d6000803e3d6000fd5b505050506040513d60208110156121cb57600080fd5b5051600d80546001600160a01b0319166001600160a01b0390921691909117905550505050505050565b6715f15565d2c5f00081565b612231878787878787877f6e71edae12b1b97f4d1f60370fef10105fa2faae0126114a169c64845d6126c9612bc7565b61223c8787876122dc565b50505050505050565b600c546001600160a01b031681565b600560209081526000928352604080842090915290825290205481565b600b5460ff166122bb576040805162461bcd60e51b815260206004820152601060248201526f15185c9bdd0e8814915153951154915160821b604482015290519081900360640190fd5b600b805460ff191690556122cd612657565b600b805460ff19166001179055565b6001600160a01b03808416600081815260056020908152604080832094871680845294825291829020859055815185815291517f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259281900390910190a3505050565b600854604080518082018252601981527f7472616e7366657228616464726573732c75696e74323536290000000000000060209182015281516001600160a01b0386811660248301526044808301879052845180840390910181526064909201845291810180516001600160e01b031663a9059cbb60e01b1781529251815160009560609594169382918083835b602083106123eb5780518252601f1990920191602091820191016123cc565b6001836020036101000a0380198251168184511680821785525050505050509050019150506000604051808303816000865af19150503d806000811461244d576040519150601f19603f3d011682016040523d82523d6000602084013e612452565b606091505b5091509150818015612480575080511580612480575080806020019051602081101561247d57600080fd5b50515b6124ca576040805162461bcd60e51b815260206004820152601660248201527515185c9bdd0e881514905394d1915497d1905253115160521b604482015290519081900360640190fd5b50505050565b6000826124df5750600061094c565b828202828482816124ec57fe5b04146125295760405162461bcd60e51b81526004018080602001828103825260218152602001806130bb6021913960400191505060405180910390fd5b9392505050565b600061252983836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250612d9c565b600082820183811015612529576040805162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015290519081900360640190fd5b6001600160a01b0382166000908152600460205260409020546125f5908263ffffffff6128ad16565b6001600160a01b038316600090815260046020526040902055600354612621908263ffffffff6128ad16565b6003556040805182815290516000916001600160a01b038516916000805160206130dc8339815191529181900360200190a35050565b600854604080516370a0823160e01b815230600482015290516001600160a01b03909216916370a0823191602480820192602092909190829003018186803b1580156126a257600080fd5b505afa1580156126b6573d6000803e3d6000fd5b505050506040513d60208110156126cc57600080fd5b5051600a81905560408051918252517f8a0df8ef054fae2c3d2d19a7b322e864870cc9fd3cb07fb9526309c596244bf49181900360200190a1565b61270f612e01565b8183101561275d576040805162461bcd60e51b81526020600482015260166024820152755461726f743a20494e56414c49445f53455454494e4760501b604482015290519081900360640190fd5b808311156127ab576040805162461bcd60e51b81526020600482015260166024820152755461726f743a20494e56414c49445f53455454494e4760501b604482015290519081900360640190fd5b505050565b6000818484111561283f5760405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b838110156128045781810151838201526020016127ec565b50505050905090810190601f1680156128315780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b505050900390565b612851838261113a565b6128a2576040805162461bcd60e51b815260206004820152601d60248201527f5461726f743a20494e53554646494349454e545f4c4951554944495459000000604482015290519081900360640190fd5b6127ab838383612ecf565b600061252983836040518060400160405280601f81526020017f536166654d6174683a207375627472616374696f6e20756e646572666c6f77008152506127b0565b600354612902908263ffffffff61257216565b6003556001600160a01b03821660009081526004602052604090205461292e908263ffffffff61257216565b6001600160a01b03831660008181526004602090815260408083209490945583518581529351929391926000805160206130dc8339815191529281900390910190a35050565b600e5460009081908180612986611cf1565b909250905060006129a9670de0b6b3a7640000610af38a8663ffffffff6124d016565b905060006129c9670de0b6b3a7640000610af38a8663ffffffff6124d016565b9050808210156129d557905b6129f1670de0b6b3a7640000610af3848863ffffffff6124d016565b9150612a0f85610af383670de0b6b3a764000063ffffffff6124d016565b90506000612a46670de0b6b3a7640000610af3612a2a610d39565b612a3a878763ffffffff61257216565b9063ffffffff6124d016565b9050808b10612a62578a0396506000955061142c945050505050565b600097508a9003955061142c945050505050565b6001600160701b0316600160701b0290565b60006001600160701b0382166001600160e01b03841681612aa557fe5b049392505050565b60006003821115612af0575080600160028204015b81811015612aea57809150600281828581612ad957fe5b040181612ae257fe5b049050612ac2565b50612afa565b8115612afa575060015b919050565b8151612b12906000906020850190612faf565b508051612b26906001906020840190612faf565b5060405146908060526130698239604080519182900360520182208651602097880120838301835260018452603160f81b93880193909352815180880191909152808201929092527fc89efdaa54c0f20c7adf612882df0950f5a951637e0307cdcb4c672f298b8bc6606083015260808201939093523060a0808301919091528351808303909101815260c090910190925250805192019190912060065550565b42851015612c0d576040805162461bcd60e51b815260206004820152600e60248201526d15185c9bdd0e881156141254915160921b604482015290519081900360640190fd5b6006546001600160a01b03808a1660008181526007602090815260408083208054600180820190925582518085018a905280840196909652958e166060860152608085018d905260a085019590955260c08085018c90528151808603909101815260e08501825280519083012061190160f01b6101008601526101028501969096526101228085019690965280518085039096018652610142840180825286519683019690962095839052610162840180825286905260ff8a166101828501526101a284018990526101c28401889052519193926101e280820193601f1981019281900390910190855afa158015612d09573d6000803e3d6000fd5b5050604051601f1901519150506001600160a01b03811615801590612d3f5750896001600160a01b0316816001600160a01b0316145b612d90576040805162461bcd60e51b815260206004820152601860248201527f5461726f743a20494e56414c49445f5349474e41545552450000000000000000604482015290519081900360640190fd5b50505050505050505050565b60008183612deb5760405162461bcd60e51b81526020600482018181528351602484015283519092839260449091019190850190808383600083156128045781810151838201526020016127ec565b506000838581612df757fe5b0495945050505050565b600960009054906101000a90046001600160a01b03166001600160a01b031663f851a4406040518163ffffffff1660e01b815260040160206040518083038186803b158015612e4f57600080fd5b505afa158015612e63573d6000803e3d6000fd5b505050506040513d6020811015612e7957600080fd5b50516001600160a01b03163314612ecd576040805162461bcd60e51b815260206004820152601360248201527215185c9bdd0e8815539055551213d492569151606a1b604482015290519081900360640190fd5b565b604080518082018252601881527f5461726f743a205452414e534645525f544f4f5f4849474800000000000000006020808301919091526001600160a01b038616600090815260049091529190912054612f3091839063ffffffff6127b016565b6001600160a01b038085166000908152600460205260408082209390935590841681522054612f65908263ffffffff61257216565b6001600160a01b0380841660008181526004602090815260409182902094909455805185815290519193928716926000805160206130dc83398151915292918290030190a3505050565b828054600181600116156101000203166002900490600052602060002090601f016020900481019282601f10612ff057805160ff191683800117855561301d565b8280016001018555821561301d579182015b8281111561301d578251825591602001919060010190613002565b5061302992915061302d565b5090565b610d4191905b80821115613029576000815560010161303356fe5461726f743a20494e53554646494349454e545f52454445454d5f544f4b454e53454950373132446f6d61696e28737472696e67206e616d652c737472696e672076657273696f6e2c75696e7432353620636861696e49642c6164647265737320766572696679696e67436f6e747261637429536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f77ddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3efa265627a7a72315820eeda8b323717ce03ef70f651a53a7a2673d856ab3cae7524b966cbf7a0ae388e64736f6c63430005100032
Deployed Bytecode
0x608060405234801561001057600080fd5b506004361061028a5760003560e01c806370a082311161015c578063ba9a7a56116100ce578063c548e3c511610087578063c548e3c51461073d578063d490e7e014610816578063d505accf1461081e578063daf888181461086f578063dd62ed3e14610877578063fff6cae9146108a55761028a565b8063ba9a7a56146106e2578063bb6ff386146106ea578063bc25cf7714610707578063bc9bd12a1461034c578063bd9a548b1461072d578063c45a0155146107355761028a565b80639aac2c53116101205780639aac2c5314610632578063a36a363014610668578063a9059cbb14610670578063ad7a672f1461069c578063afc8276c146106a4578063b2a02ff1146106ac5761028a565b806370a08231146105b05780637ecebe00146105d65780638c765e94146105fc57806395a2251f1461060457806395d89b411461062a5761028a565b806333fabfd1116102005780634fd42e17116101b95780634fd42e17146104c85780635a0f03c6146104e55780636a627842146105245780636e01be101461054a5780636f13cb83146105765780636f307dc3146105a85761028a565b806333fabfd11461049857806334fb08a8146104a0578063356c571f146104a85780633644e515146104b05780633ba0b9a9146104b85780634a5d316c146104c05761028a565b80631ef63a79116102525780631ef63a79146103f357806323b872dd1461041057806323f5589a146104465780632fa5ae1b1461044e57806330adf81f14610472578063313ce5671461047a5761028a565b806306fdde031461028f578063095ea7b31461030c5780630fb60fef1461034c57806318160ddd1461036657806319f3400d1461036e575b600080fd5b6102976108ad565b6040805160208082528351818301528351919283929083019185019080838360005b838110156102d15781810151838201526020016102b9565b50505050905090810190601f1680156102fe5780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b6103386004803603604081101561032257600080fd5b506001600160a01b03813516906020013561093b565b604080519115158252519081900360200190f35b610354610952565b60408051918252519081900360200190f35b61035461095e565b6103f16004803603606081101561038457600080fd5b6001600160a01b0382351691602081013591810190606081016040820135600160201b8111156103b357600080fd5b8201836020820111156103c557600080fd5b803590602001918460018302840111600160201b831117156103e657600080fd5b509092509050610964565b005b6103f16004803603602081101561040957600080fd5b5035610bbb565b6103386004803603606081101561042657600080fd5b506001600160a01b03813581169160208101359091169060400135610c6a565b610354610d39565b610456610d44565b604080516001600160a01b039092168252519081900360200190f35b610354610d58565b610482610d7c565b6040805160ff9092168252519081900360200190f35b610354610d85565b610456610d90565b610354610d9f565b610354610da5565b610354610dab565b6103f1610dfa565b6103f1600480360360208110156104de57600080fd5b5035610e6c565b61050b600480360360208110156104fb57600080fd5b50356001600160a01b0316610f23565b6040805192835260208301919091528051918290030190f35b6103546004803603602081101561053a57600080fd5b50356001600160a01b0316610f3c565b6103386004803603604081101561056057600080fd5b506001600160a01b03813516906020013561113a565b61050b6004803603606081101561058c57600080fd5b506001600160a01b0381351690602081013590604001356112c6565b610456611434565b610354600480360360208110156105c657600080fd5b50356001600160a01b0316611443565b610354600480360360208110156105ec57600080fd5b50356001600160a01b0316611455565b610354611467565b6103546004803603602081101561061a57600080fd5b50356001600160a01b031661146d565b610297611606565b6103386004803603606081101561064857600080fd5b506001600160a01b03813581169160208101359091169060400135611660565b610354611749565b6103386004803603604081101561068657600080fd5b506001600160a01b03813516906020013561174f565b61035461175c565b610354611762565b610354600480360360608110156106c257600080fd5b506001600160a01b0381358116916020810135909116906040013561176e565b610354611b3a565b6103f16004803603602081101561070057600080fd5b5035611b40565b6103f16004803603602081101561071d57600080fd5b50356001600160a01b0316611bf7565b61050b611cf1565b610456612045565b6103f1600480360360a081101561075357600080fd5b810190602081018135600160201b81111561076d57600080fd5b82018360208201111561077f57600080fd5b803590602001918460018302840111600160201b831117156107a057600080fd5b919390929091602081019035600160201b8111156107bd57600080fd5b8201836020820111156107cf57600080fd5b803590602001918460018302840111600160201b831117156107f057600080fd5b91935091506001600160a01b038135811691602081013582169160409091013516612054565b6103546121f5565b6103f1600480360360e081101561083457600080fd5b506001600160a01b03813581169160208101359091169060408101359060608101359060ff6080820135169060a08101359060c00135612201565b610456612245565b6103546004803603604081101561088d57600080fd5b506001600160a01b0381358116916020013516612254565b6103f1612271565b6000805460408051602060026001851615610100026000190190941693909304601f810184900484028201840190925281815292918301828280156109335780601f1061090857610100808354040283529160200191610933565b820191906000526020600020905b81548152906001019060200180831161091657829003601f168201915b505050505081565b60006109483384846122dc565b5060015b92915050565b670de0b6b3a764000081565b60035481565b600b5460ff166109ae576040805162461bcd60e51b815260206004820152601060248201526f15185c9bdd0e8814915153951154915160821b604482015290519081900360640190fd5b600b805460ff19169055600a54831115610a0a576040805162461bcd60e51b81526020600482015260186024820152770a8c2e4dee87440929ca6aa8c8c9286928a9ca8be8682a6960431b604482015290519081900360640190fd5b610a14848461233e565b8015610aba57604051636b4d4dc160e01b8152336004820181815260248301869052606060448401908152606484018590526001600160a01b03881693636b4d4dc193928892889288929190608401848480828437600081840152601f19601f82011690508083019250505095505050505050600060405180830381600087803b158015610aa157600080fd5b505af1158015610ab5573d6000803e3d6000fd5b505050505b3060009081526004602052604081205490610b0b6001610aff610adb610dab565b610af389670de0b6b3a764000063ffffffff6124d016565b9063ffffffff61253016565b9063ffffffff61257216565b905080821015610b4c5760405162461bcd60e51b81526004018080602001828103825260218152602001806130486021913960400191505060405180910390fd5b610b5630836125cc565b604080518681526020810184905281516001600160a01b0389169233927f3f693fff038bb8a046aa76d9516190ac7444f7d69cf952c4cbdc086fdef2d6fc929081900390910190a35050610ba8612657565b5050600b805460ff191660011790555050565b600b5460ff16610c05576040805162461bcd60e51b815260206004820152601060248201526f15185c9bdd0e8814915153951154915160821b604482015290519081900360640190fd5b600b805460ff19169055610c2281600066b1a2bc2ec50000612707565b60108190556040805182815290517f21e5451a492a87031e8324e7e1e2ba821fdec0c40972393c9f74dd38bd88a6af9181900360200190a150600b805460ff19166001179055565b6001600160a01b038316600090815260056020908152604080832033845290915281205460001914610d2457604080518082018252601b81527f5461726f743a205452414e534645525f4e4f545f414c4c4f57454400000000006020808301919091526001600160a01b0387166000908152600582528381203382529091529190912054610cff91849063ffffffff6127b016565b6001600160a01b03851660009081526005602090815260408083203384529091529020555b610d2f848484612847565b5060019392505050565b601054600f54015b90565b600b5461010090046001600160a01b031681565b7f6e71edae12b1b97f4d1f60370fef10105fa2faae0126114a169c64845d6126c981565b60025460ff1681565b66b1a2bc2ec5000081565b600d546001600160a01b031681565b600e5481565b60065481565b600354600a5460009190811580610dc0575080155b15610dd757670de0b6b3a764000092505050610d41565b610df382610af383670de0b6b3a764000063ffffffff6124d016565b9250505090565b6009546001600160a01b031615610e58576040805162461bcd60e51b815260206004820152601a60248201527f5461726f743a20464143544f52595f414c52454144595f534554000000000000604482015290519081900360640190fd5b600980546001600160a01b03191633179055565b600b5460ff16610eb6576040805162461bcd60e51b815260206004820152601060248201526f15185c9bdd0e8814915153951154915160821b604482015290519081900360640190fd5b600b805460ff19169055610edb81670de0b6b3a7640000670f43fc2c04ee0000612707565b600f8190556040805182815290517f8a9bb9067f9ecb13a322b548e6df3dd1bd10a54698834dac43ed8f0e765bf94d9181900360200190a150600b805460ff19166001179055565b600080610f3383600019806112c6565b91509150915091565b600b5460009060ff16610f89576040805162461bcd60e51b815260206004820152601060248201526f15185c9bdd0e8814915153951154915160821b604482015290519081900360640190fd5b600b805460ff19169055600854604080516370a0823160e01b815230600482015290516000926001600160a01b0316916370a08231916024808301926020929190829003018186803b158015610fde57600080fd5b505afa158015610ff2573d6000803e3d6000fd5b505050506040513d602081101561100857600080fd5b5051600a5490915060009061102490839063ffffffff6128ad16565b9050611049611031610dab565b610af383670de0b6b3a764000063ffffffff6124d016565b92506003546000141561107757611068836103e863ffffffff6128ad16565b925061107760006103e86128ef565b600083116110cc576040805162461bcd60e51b815260206004820152601760248201527f5461726f743a204d494e545f414d4f554e545f5a45524f000000000000000000604482015290519081900360640190fd5b6110d684846128ef565b604080518281526020810185905281516001600160a01b0387169233927f2f00e3cdd69a77be7ed215ec7b2a36784dd158f921fca79ac29deffa353fe6ee929081900390910190a35050611128612657565b600b805460ff19166001179055919050565b6001600160a01b0382166000908152600460205260408120548083111561116557600091505061094c565b828103600061118e670de0b6b3a7640000610af3611181610dab565b859063ffffffff6124d016565b90506000600b60019054906101000a90046001600160a01b03166001600160a01b0316634d73e9ba886040518263ffffffff1660e01b815260040180826001600160a01b03166001600160a01b0316815260200191505060206040518083038186803b1580156111fd57600080fd5b505afa158015611211573d6000803e3d6000fd5b505050506040513d602081101561122757600080fd5b5051600c54604080516326b9f4dd60e11b81526001600160a01b038b8116600483015291519394506000939190921691634d73e9ba916024808301926020929190829003018186803b15801561127c57600080fd5b505afa158015611290573d6000803e3d6000fd5b505050506040513d60208110156112a657600080fd5b5051905060006112b7848484612974565b159a9950505050505050505050565b60008060001984141561135557600b54604080516326b9f4dd60e11b81526001600160a01b038881166004830152915161010090930490911691634d73e9ba91602480820192602092909190829003018186803b15801561132657600080fd5b505afa15801561133a573d6000803e3d6000fd5b505050506040513d602081101561135057600080fd5b505193505b6000198314156113db57600c54604080516326b9f4dd60e11b81526001600160a01b03888116600483015291519190921691634d73e9ba916024808301926020929190829003018186803b1580156113ac57600080fd5b505afa1580156113c0573d6000803e3d6000fd5b505050506040513d60208110156113d657600080fd5b505192505b6000611419670de0b6b3a7640000610af36113f4610dab565b6001600160a01b038a166000908152600460205260409020549063ffffffff6124d016565b9050611426818686612974565b92509250505b935093915050565b6008546001600160a01b031681565b60046020526000908152604090205481565b60076020526000908152604090205481565b600f5481565b600b5460009060ff166114ba576040805162461bcd60e51b815260206004820152601060248201526f15185c9bdd0e8814915153951154915160821b604482015290519081900360640190fd5b600b805460ff19169055306000908152600460205260409020546114f8670de0b6b3a7640000610af36114eb610dab565b849063ffffffff6124d016565b91506000821161154f576040805162461bcd60e51b815260206004820152601960248201527f5461726f743a2052454445454d5f414d4f554e545f5a45524f00000000000000604482015290519081900360640190fd5b600a548211156115a1576040805162461bcd60e51b81526020600482015260186024820152770a8c2e4dee87440929ca6aa8c8c9286928a9ca8be8682a6960431b604482015290519081900360640190fd5b6115ab30826125cc565b6115b5838361233e565b604080518381526020810183905281516001600160a01b0386169233927f3f693fff038bb8a046aa76d9516190ac7444f7d69cf952c4cbdc086fdef2d6fc929081900390910190a350611128612657565b60018054604080516020600284861615610100026000190190941693909304601f810184900484028201840190925281815292918301828280156109335780601f1061090857610100808354040283529160200191610933565b600b54600c546000916001600160a01b03610100909104811691811690851682148061169d5750806001600160a01b0316856001600160a01b0316145b6116ee576040805162461bcd60e51b815260206004820152601960248201527f5461726f743a20494e56414c49445f424f52524f5741424c4500000000000000604482015290519081900360640190fd5b6000826001600160a01b0316866001600160a01b03161461171157600019611713565b845b90506000826001600160a01b0316876001600160a01b0316146117385760001961173a565b855b905060006112b78984846112c6565b60105481565b6000610948338484612847565b600a5481565b670f43fc2c04ee000081565b600b5460009061010090046001600160a01b03163314806117995750600c546001600160a01b031633145b6117e0576040805162461bcd60e51b815260206004820152601360248201527215185c9bdd0e8815539055551213d492569151606a1b604482015290519081900360640190fd5b60006117eb84610f23565b91505060008111611843576040805162461bcd60e51b815260206004820152601d60248201527f5461726f743a20494e53554646494349454e545f53484f525446414c4c000000604482015290519081900360640190fd5b600b5460009061010090046001600160a01b031633141561186e57611866611cf1565b50905061187a565b611876611cf1565b9150505b6000611897611887610dab565b610af3878563ffffffff6124d016565b90506118ba670de0b6b3a7640000610af3600f54846124d090919063ffffffff16565b935061192b846040518060400160405280601b81526020017f5461726f743a204c49515549444154494e475f544f4f5f4d5543480000000000815250600460008a6001600160a01b03166001600160a01b03168152602001908152602001600020546127b09092919063ffffffff16565b6001600160a01b038088166000908152600460205260408082209390935590891681522054611960908563ffffffff61257216565b6001600160a01b0380891660008181526004602090815260409182902094909455805188815290519193928a16926000805160206130dc83398151915292918290030190a360105415611b305760006119d0670de0b6b3a7640000610af3601054856124d090919063ffffffff16565b90506000600960009054906101000a90046001600160a01b03166001600160a01b031663345ef9416040518163ffffffff1660e01b815260040160206040518083038186803b158015611a2257600080fd5b505afa158015611a36573d6000803e3d6000fd5b505050506040513d6020811015611a4c57600080fd5b5051604080518082018252601b81527f5461726f743a204c49515549444154494e475f544f4f5f4d55434800000000006020828101919091526001600160a01b038c16600090815260049091529190912054919250611ab39190849063ffffffff6127b016565b6001600160a01b03808a166000908152600460205260408082209390935590831681522054611ae8908363ffffffff61257216565b6001600160a01b0380831660008181526004602090815260409182902094909455805186815290519193928c16926000805160206130dc83398151915292918290030190a350505b5050509392505050565b6103e881565b600b5460ff16611b8a576040805162461bcd60e51b815260206004820152601060248201526f15185c9bdd0e8814915153951154915160821b604482015290519081900360640190fd5b600b805460ff19169055611baf81670de0b6b3a76400006715f15565d2c5f000612707565b600e8190556040805182815290517fdff9a61839be6f6ce5ea77311cc351786a39a9f337c507ff35e7b358fd39c0439181900360200190a150600b805460ff19166001179055565b600b5460ff16611c41576040805162461bcd60e51b815260206004820152601060248201526f15185c9bdd0e8814915153951154915160821b604482015290519081900360640190fd5b600b805460ff19169055600a54600854604080516370a0823160e01b81523060048201529051611ce1938593611cdc9391926001600160a01b03909116916370a08231916024808301926020929190829003018186803b158015611ca457600080fd5b505afa158015611cb8573d6000803e3d6000fd5b505050506040513d6020811015611cce57600080fd5b50519063ffffffff6128ad16565b61233e565b50600b805460ff19166001179055565b600d546008546040805163022351bf60e51b81526001600160a01b03928316600482015290516000938493849384938493929092169163446a37e09160248082019260609290919082900301818787803b158015611d4e57600080fd5b505af1158015611d62573d6000803e3d6000fd5b505050506040513d6060811015611d7857600080fd5b5080516020909101519092509050611da882611d9383612a76565b6001600160e01b03169063ffffffff612a8816565b92505050600080600860009054906101000a90046001600160a01b03166001600160a01b0316630902f1ac6040518163ffffffff1660e01b815260040160606040518083038186803b158015611dfd57600080fd5b505afa158015611e11573d6000803e3d6000fd5b505050506040513d6060811015611e2757600080fd5b508051602091820151600854604080516318160ddd60e01b815290519396509194506000936001600160a01b03909116926318160ddd926004808201939291829003018186803b158015611e7a57600080fd5b505afa158015611e8e573d6000803e3d6000fd5b505050506040513d6020811015611ea457600080fd5b505190506000611eb784611d9385612a76565b90506000611ee06001600160e01b0380841690610af3908916600160201b63ffffffff6124d016565b90506000611f00611efb83600160201b63ffffffff6124d016565b612aad565b90506000611f2c6001600160701b036002890216610af387670de0b6b3a764000063ffffffff6124d016565b90506000611f586001600160701b036002890216610af388670de0b6b3a764000063ffffffff6124d016565b9050611f72600160201b610af3848663ffffffff6124d016565b9a50611f8c83610af383600160201b63ffffffff6124d016565b995060648b11611fe3576040805162461bcd60e51b815260206004820152601e60248201527f5461726f743a2050524943455f43414c43554c4154494f4e5f4552524f520000604482015290519081900360640190fd5b60648a11612038576040805162461bcd60e51b815260206004820152601e60248201527f5461726f743a2050524943455f43414c43554c4154494f4e5f4552524f520000604482015290519081900360640190fd5b5050505050505050509091565b6009546001600160a01b031681565b6009546001600160a01b031633146120a9576040805162461bcd60e51b815260206004820152601360248201527215185c9bdd0e8815539055551213d492569151606a1b604482015290519081900360640190fd5b61211c87878080601f01602080910402602001604051908101604052809392919081815260200183838082843760009201919091525050604080516020601f8b018190048102820181019092528981529250899150889081908401838280828437600092019190915250612aff92505050565b600880546001600160a01b03199081166001600160a01b0386811691909117909255600b8054610100600160a81b03191661010086851602179055600c80549091168383161790556009546040805163069f611560e31b8152905191909216916334fb08a8916004808301926020929190829003018186803b1580156121a157600080fd5b505afa1580156121b5573d6000803e3d6000fd5b505050506040513d60208110156121cb57600080fd5b5051600d80546001600160a01b0319166001600160a01b0390921691909117905550505050505050565b6715f15565d2c5f00081565b612231878787878787877f6e71edae12b1b97f4d1f60370fef10105fa2faae0126114a169c64845d6126c9612bc7565b61223c8787876122dc565b50505050505050565b600c546001600160a01b031681565b600560209081526000928352604080842090915290825290205481565b600b5460ff166122bb576040805162461bcd60e51b815260206004820152601060248201526f15185c9bdd0e8814915153951154915160821b604482015290519081900360640190fd5b600b805460ff191690556122cd612657565b600b805460ff19166001179055565b6001600160a01b03808416600081815260056020908152604080832094871680845294825291829020859055815185815291517f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259281900390910190a3505050565b600854604080518082018252601981527f7472616e7366657228616464726573732c75696e74323536290000000000000060209182015281516001600160a01b0386811660248301526044808301879052845180840390910181526064909201845291810180516001600160e01b031663a9059cbb60e01b1781529251815160009560609594169382918083835b602083106123eb5780518252601f1990920191602091820191016123cc565b6001836020036101000a0380198251168184511680821785525050505050509050019150506000604051808303816000865af19150503d806000811461244d576040519150601f19603f3d011682016040523d82523d6000602084013e612452565b606091505b5091509150818015612480575080511580612480575080806020019051602081101561247d57600080fd5b50515b6124ca576040805162461bcd60e51b815260206004820152601660248201527515185c9bdd0e881514905394d1915497d1905253115160521b604482015290519081900360640190fd5b50505050565b6000826124df5750600061094c565b828202828482816124ec57fe5b04146125295760405162461bcd60e51b81526004018080602001828103825260218152602001806130bb6021913960400191505060405180910390fd5b9392505050565b600061252983836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250612d9c565b600082820183811015612529576040805162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015290519081900360640190fd5b6001600160a01b0382166000908152600460205260409020546125f5908263ffffffff6128ad16565b6001600160a01b038316600090815260046020526040902055600354612621908263ffffffff6128ad16565b6003556040805182815290516000916001600160a01b038516916000805160206130dc8339815191529181900360200190a35050565b600854604080516370a0823160e01b815230600482015290516001600160a01b03909216916370a0823191602480820192602092909190829003018186803b1580156126a257600080fd5b505afa1580156126b6573d6000803e3d6000fd5b505050506040513d60208110156126cc57600080fd5b5051600a81905560408051918252517f8a0df8ef054fae2c3d2d19a7b322e864870cc9fd3cb07fb9526309c596244bf49181900360200190a1565b61270f612e01565b8183101561275d576040805162461bcd60e51b81526020600482015260166024820152755461726f743a20494e56414c49445f53455454494e4760501b604482015290519081900360640190fd5b808311156127ab576040805162461bcd60e51b81526020600482015260166024820152755461726f743a20494e56414c49445f53455454494e4760501b604482015290519081900360640190fd5b505050565b6000818484111561283f5760405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b838110156128045781810151838201526020016127ec565b50505050905090810190601f1680156128315780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b505050900390565b612851838261113a565b6128a2576040805162461bcd60e51b815260206004820152601d60248201527f5461726f743a20494e53554646494349454e545f4c4951554944495459000000604482015290519081900360640190fd5b6127ab838383612ecf565b600061252983836040518060400160405280601f81526020017f536166654d6174683a207375627472616374696f6e20756e646572666c6f77008152506127b0565b600354612902908263ffffffff61257216565b6003556001600160a01b03821660009081526004602052604090205461292e908263ffffffff61257216565b6001600160a01b03831660008181526004602090815260408083209490945583518581529351929391926000805160206130dc8339815191529281900390910190a35050565b600e5460009081908180612986611cf1565b909250905060006129a9670de0b6b3a7640000610af38a8663ffffffff6124d016565b905060006129c9670de0b6b3a7640000610af38a8663ffffffff6124d016565b9050808210156129d557905b6129f1670de0b6b3a7640000610af3848863ffffffff6124d016565b9150612a0f85610af383670de0b6b3a764000063ffffffff6124d016565b90506000612a46670de0b6b3a7640000610af3612a2a610d39565b612a3a878763ffffffff61257216565b9063ffffffff6124d016565b9050808b10612a62578a0396506000955061142c945050505050565b600097508a9003955061142c945050505050565b6001600160701b0316600160701b0290565b60006001600160701b0382166001600160e01b03841681612aa557fe5b049392505050565b60006003821115612af0575080600160028204015b81811015612aea57809150600281828581612ad957fe5b040181612ae257fe5b049050612ac2565b50612afa565b8115612afa575060015b919050565b8151612b12906000906020850190612faf565b508051612b26906001906020840190612faf565b5060405146908060526130698239604080519182900360520182208651602097880120838301835260018452603160f81b93880193909352815180880191909152808201929092527fc89efdaa54c0f20c7adf612882df0950f5a951637e0307cdcb4c672f298b8bc6606083015260808201939093523060a0808301919091528351808303909101815260c090910190925250805192019190912060065550565b42851015612c0d576040805162461bcd60e51b815260206004820152600e60248201526d15185c9bdd0e881156141254915160921b604482015290519081900360640190fd5b6006546001600160a01b03808a1660008181526007602090815260408083208054600180820190925582518085018a905280840196909652958e166060860152608085018d905260a085019590955260c08085018c90528151808603909101815260e08501825280519083012061190160f01b6101008601526101028501969096526101228085019690965280518085039096018652610142840180825286519683019690962095839052610162840180825286905260ff8a166101828501526101a284018990526101c28401889052519193926101e280820193601f1981019281900390910190855afa158015612d09573d6000803e3d6000fd5b5050604051601f1901519150506001600160a01b03811615801590612d3f5750896001600160a01b0316816001600160a01b0316145b612d90576040805162461bcd60e51b815260206004820152601860248201527f5461726f743a20494e56414c49445f5349474e41545552450000000000000000604482015290519081900360640190fd5b50505050505050505050565b60008183612deb5760405162461bcd60e51b81526020600482018181528351602484015283519092839260449091019190850190808383600083156128045781810151838201526020016127ec565b506000838581612df757fe5b0495945050505050565b600960009054906101000a90046001600160a01b03166001600160a01b031663f851a4406040518163ffffffff1660e01b815260040160206040518083038186803b158015612e4f57600080fd5b505afa158015612e63573d6000803e3d6000fd5b505050506040513d6020811015612e7957600080fd5b50516001600160a01b03163314612ecd576040805162461bcd60e51b815260206004820152601360248201527215185c9bdd0e8815539055551213d492569151606a1b604482015290519081900360640190fd5b565b604080518082018252601881527f5461726f743a205452414e534645525f544f4f5f4849474800000000000000006020808301919091526001600160a01b038616600090815260049091529190912054612f3091839063ffffffff6127b016565b6001600160a01b038085166000908152600460205260408082209390935590841681522054612f65908263ffffffff61257216565b6001600160a01b0380841660008181526004602090815260409182902094909455805185815290519193928716926000805160206130dc83398151915292918290030190a3505050565b828054600181600116156101000203166002900490600052602060002090601f016020900481019282601f10612ff057805160ff191683800117855561301d565b8280016001018555821561301d579182015b8281111561301d578251825591602001919060010190613002565b5061302992915061302d565b5090565b610d4191905b80821115613029576000815560010161303356fe5461726f743a20494e53554646494349454e545f52454445454d5f544f4b454e53454950373132446f6d61696e28737472696e67206e616d652c737472696e672076657273696f6e2c75696e7432353620636861696e49642c6164647265737320766572696679696e67436f6e747261637429536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f77ddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3efa265627a7a72315820eeda8b323717ce03ef70f651a53a7a2673d856ab3cae7524b966cbf7a0ae388e64736f6c63430005100032
Loading...
Loading
Loading...
Loading
Multichain Portfolio | 27 Chains
Chain | Token | Portfolio % | Price | Amount | Value |
---|
Loading...
Loading
[ Download: CSV Export ]
[ 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.