Transactions
Token Transfers
Tokens
Internal Transactions
Coin Balance History
Logs
Code
Read Contract
Write Contract
- Contract name:
- MilkyYachtClub
- Optimization enabled
- true
- Compiler version
- v0.8.7+commit.e28d00a7
- Optimization runs
- 200
- EVM Version
- default
- Verified at
- 2022-04-06T16:46:29.654639Z
Contract source code
//SPDX-License-Identifier: MIT pragma solidity ^0.8.5; library SafeMath { function add(uint256 a, uint256 b) internal pure returns (uint256) { uint256 c = a + b; require(c >= a, "SafeMath: addition overflow"); return c; } function sub(uint256 a, uint256 b) internal pure returns (uint256) { return sub(a, b, "SafeMath: subtraction overflow"); } function sub(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) { require(b <= a, errorMessage); uint256 c = a - b; return c; } function mul(uint256 a, uint256 b) internal pure returns (uint256) { if (a == 0) { return 0; } uint256 c = a * b; require(c / a == b, "SafeMath: multiplication overflow"); return c; } function div(uint256 a, uint256 b) internal pure returns (uint256) { return div(a, b, "SafeMath: division by zero"); } function div(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) { // 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; } } /** * BEP20 standard interface. */ interface IBEP20 { function totalSupply() external view returns (uint256); function decimals() external view returns (uint8); function symbol() external view returns (string memory); function name() external view returns (string memory); function getOwner() external view returns (address); function balanceOf(address account) external view returns (uint256); function transfer(address recipient, uint256 amount) external returns (bool); function allowance(address _owner, address spender) external view returns (uint256); function approve(address spender, uint256 amount) external returns (bool); function transferFrom(address sender, address recipient, uint256 amount) external returns (bool); event Transfer(address indexed from, address indexed to, uint256 value); event Approval(address indexed owner, address indexed spender, uint256 value); } /** * Allows for contract ownership along with multi-address authorization */ abstract contract Auth { address internal owner; mapping (address => bool) internal authorizations; constructor(address _owner) { owner = _owner; authorizations[_owner] = true; } /** * Function modifier to require caller to be contract owner */ modifier onlyOwner() { require(isOwner(msg.sender), "!OWNER"); _; } /** * Function modifier to require caller to be authorized */ modifier authorized() { require(isAuthorized(msg.sender), "!AUTHORIZED"); _; } /** * Authorize address. Owner only */ function authorize(address adr) public onlyOwner { authorizations[adr] = true; } /** * Remove address' authorization. Owner only */ function unauthorize(address adr) public onlyOwner { authorizations[adr] = false; } /** * Check if address is owner */ function isOwner(address account) public view returns (bool) { return account == owner; } /** * Return address' authorization status */ function isAuthorized(address adr) public view returns (bool) { return authorizations[adr]; } /** * Transfer ownership to new address. Caller must be owner. Leaves old owner authorized */ function transferOwnership(address payable adr) public onlyOwner { owner = adr; authorizations[adr] = true; emit OwnershipTransferred(adr); } event OwnershipTransferred(address owner); } interface IDEXFactory { function createPair(address tokenA, address tokenB) external returns (address pair); } interface IDEXRouter { function factory() external pure returns (address); function WETH() external pure returns (address); function addLiquidity( address tokenA, address tokenB, uint amountADesired, uint amountBDesired, uint amountAMin, uint amountBMin, address to, uint deadline ) external returns (uint amountA, uint amountB, uint liquidity); function addLiquidityETH( address token, uint amountTokenDesired, uint amountTokenMin, uint amountETHMin, address to, uint deadline ) external payable returns (uint amountToken, uint amountETH, uint liquidity); function swapExactTokensForTokensSupportingFeeOnTransferTokens( uint amountIn, uint amountOutMin, address[] calldata path, address to, uint deadline ) external; function swapExactETHForTokensSupportingFeeOnTransferTokens( uint amountOutMin, address[] calldata path, address to, uint deadline ) external payable; function swapExactTokensForETHSupportingFeeOnTransferTokens( uint amountIn, uint amountOutMin, address[] calldata path, address to, uint deadline ) external; } contract MilkyYachtClub is IBEP20, Auth { using SafeMath for uint256; address WCRO = 0xAE83571000aF4499798d1e3b0fA0070EB3A3E3F9; address DEAD = 0x000000000000000000000000000000000000dEaD; address ZERO = 0x0000000000000000000000000000000000000000; string constant _name = "MilkyYachtClub"; string constant _symbol = "MILKYYACHTCLUB"; uint8 constant _decimals = 9; uint256 _totalSupply = 1000000000 * (10 ** _decimals); uint256 public _maxTxAmount = (_totalSupply * 3) / 100; //1% max tx uint256 public _maxWalletSize = (_totalSupply * 3) / 100; //1% max wallet mapping (address => uint256) _balances; mapping (address => mapping (address => uint256)) _allowances; mapping (address => bool) isFeeExempt; mapping (address => bool) isTxLimitExempt; uint256 liquidityFee = 2; uint256 teamFee =2; uint256 marketingFee = 8; uint256 totalFee = 12; uint256 feeDenominator = 100; address private marketingFeeReceiver = 0xeb1B15f6F66e13D61A0e7f6175675e7C35aA5c4b; address private teamFeeReceiver = 0x075b37ac0F001871c36000A934db6349B86574A4; IDEXRouter public router; address public pair; uint256 public launchedAt; bool public swapEnabled = true; uint256 public swapThreshold = _totalSupply / 1000 * 3; // 0.3% bool inSwap; modifier swapping() { inSwap = true; _; inSwap = false; } constructor () Auth(msg.sender) { router = IDEXRouter(0x9D2E30C2FB648BeE307EDBaFDb461b09DF79516C); pair = IDEXFactory(router.factory()).createPair(WCRO, address(this)); _allowances[address(this)][address(router)] = type(uint256).max; address _owner = owner; isFeeExempt[_owner] = true; isTxLimitExempt[_owner] = true; _balances[_owner] = _totalSupply; emit Transfer(address(0), _owner, _totalSupply); } receive() external payable { } function totalSupply() external view override returns (uint256) { return _totalSupply; } function decimals() external pure override returns (uint8) { return _decimals; } function symbol() external pure override returns (string memory) { return _symbol; } function name() external pure override returns (string memory) { return _name; } function getOwner() external view override returns (address) { return owner; } function balanceOf(address account) public view override returns (uint256) { return _balances[account]; } function allowance(address holder, address spender) external view override returns (uint256) { return _allowances[holder][spender]; } function approve(address spender, uint256 amount) public override returns (bool) { _allowances[msg.sender][spender] = amount; emit Approval(msg.sender, spender, amount); return true; } function approveMax(address spender) external returns (bool) { return approve(spender, type(uint256).max); } function transfer(address recipient, uint256 amount) external override returns (bool) { return _transferFrom(msg.sender, recipient, amount); } function transferFrom(address sender, address recipient, uint256 amount) external override returns (bool) { if(_allowances[sender][msg.sender] != type(uint256).max){ _allowances[sender][msg.sender] = _allowances[sender][msg.sender].sub(amount, "Insufficient Allowance"); } return _transferFrom(sender, recipient, amount); } function _transferFrom(address sender, address recipient, uint256 amount) internal returns (bool) { if(inSwap){ return _basicTransfer(sender, recipient, amount); } checkTxLimit(sender, amount); if (recipient != pair && recipient != DEAD) { require(isTxLimitExempt[recipient] || _balances[recipient] + amount <= _maxWalletSize, "Transfer amount exceeds the bag size."); } if(shouldSwapBack()){ swapBack(); } if(!launched() && recipient == pair){ require(_balances[sender] > 0); launch(); } _balances[sender] = _balances[sender].sub(amount, "Insufficient Balance"); uint256 amountReceived = shouldTakeFee(sender) ? takeFee(sender, recipient, amount) : amount; _balances[recipient] = _balances[recipient].add(amountReceived); emit Transfer(sender, recipient, amountReceived); return true; } function _basicTransfer(address sender, address recipient, uint256 amount) internal returns (bool) { _balances[sender] = _balances[sender].sub(amount, "Insufficient Balance"); _balances[recipient] = _balances[recipient].add(amount); emit Transfer(sender, recipient, amount); return true; } function checkTxLimit(address sender, uint256 amount) internal view { require(amount <= _maxTxAmount || isTxLimitExempt[sender], "TX Limit Exceeded"); } function shouldTakeFee(address sender) internal view returns (bool) { return !isFeeExempt[sender]; } function getTotalFee(bool selling) public view returns (uint256) { if(launchedAt + 1 >= block.number){ return feeDenominator.sub(1); } if(selling) { return totalFee.add(1); } return totalFee; } function takeFee(address sender, address receiver, uint256 amount) internal returns (uint256) { uint256 feeAmount = amount.mul(getTotalFee(receiver == pair)).div(feeDenominator); _balances[address(this)] = _balances[address(this)].add(feeAmount); emit Transfer(sender, address(this), feeAmount); return amount.sub(feeAmount); } function shouldSwapBack() internal view returns (bool) { return msg.sender != pair && !inSwap && swapEnabled && _balances[address(this)] >= swapThreshold; } function swapBack() internal swapping { uint256 contractTokenBalance = balanceOf(address(this)); uint256 amountToLiquify = contractTokenBalance.mul(liquidityFee).div(totalFee).div(2); uint256 amountToSwap = contractTokenBalance.sub(amountToLiquify); address[] memory path = new address[](2); path[0] = address(this); path[1] = WCRO; uint256 balanceBefore = address(this).balance; router.swapExactTokensForETHSupportingFeeOnTransferTokens( amountToSwap, 0, path, address(this), block.timestamp ); uint256 amountBNB = address(this).balance.sub(balanceBefore); uint256 totalBNBFee = totalFee.sub(liquidityFee.div(2)); uint256 amountBNBLiquidity = amountBNB.mul(liquidityFee).div(totalBNBFee).div(2); uint256 amountBNBdevelopment = amountBNB.mul(teamFee).div(totalBNBFee); uint256 amountBNBMarketing = amountBNB.mul(marketingFee).div(totalBNBFee); (bool MarketingSuccess, /* bytes memory data */) = payable(marketingFeeReceiver).call{value: amountBNBMarketing, gas: 30000}(""); require(MarketingSuccess, "receiver rejected ETH transfer"); (bool developmentSuccess, /* bytes memory data */) = payable(teamFeeReceiver).call{value: amountBNBdevelopment, gas: 30000}(""); require(developmentSuccess, "receiver rejected ETH transfer"); if(amountToLiquify > 0){ router.addLiquidityETH{value: amountBNBLiquidity}( address(this), amountToLiquify, 0, 0, marketingFeeReceiver, block.timestamp ); emit AutoLiquify(amountBNBLiquidity, amountToLiquify); } } function buyTokens(uint256 amount, address to) internal swapping { address[] memory path = new address[](2); path[0] = WCRO; path[1] = address(this); router.swapExactETHForTokensSupportingFeeOnTransferTokens{value: amount}( 0, path, to, block.timestamp ); } function launched() internal view returns (bool) { return launchedAt != 0; } function launch() internal { launchedAt = block.number; } function setTxLimit(uint256 amount) external authorized { require(amount >= _totalSupply / 1000); _maxTxAmount = amount; } function setMaxWallet(uint256 amount) external onlyOwner() { require(amount >= _totalSupply / 1000 ); _maxWalletSize = amount; } function setIsFeeExempt(address holder, bool exempt) external authorized { isFeeExempt[holder] = exempt; } function setIsTxLimitExempt(address holder, bool exempt) external authorized { isTxLimitExempt[holder] = exempt; } function setFees(uint256 _liquidityFee, uint256 _teamFee, uint256 _marketingFee, uint256 _feeDenominator) external authorized { liquidityFee = _liquidityFee; teamFee = _teamFee; marketingFee = _marketingFee; totalFee = _liquidityFee.add(_teamFee).add(_marketingFee); feeDenominator = _feeDenominator; } function setFeeReceiver(address _marketingFeeReceiver, address _teamFeeReceiver) external authorized { marketingFeeReceiver = _marketingFeeReceiver; teamFeeReceiver = _teamFeeReceiver; } function setSwapBackSettings(bool _enabled, uint256 _amount) external authorized { swapEnabled = _enabled; swapThreshold = _amount; } function manualSend() external authorized { uint256 contractETHBalance = address(this).balance; payable(marketingFeeReceiver).transfer(contractETHBalance); } function transferForeignToken(address _token) public authorized { require(_token != address(this), "Can't let you take all native token"); uint256 _contractBalance = IBEP20(_token).balanceOf(address(this)); payable(marketingFeeReceiver).transfer(_contractBalance); } function getCirculatingSupply() public view returns (uint256) { return _totalSupply.sub(balanceOf(DEAD)).sub(balanceOf(ZERO)); } function getLiquidityBacking(uint256 accuracy) public view returns (uint256) { return accuracy.mul(balanceOf(pair).mul(2)).div(getCirculatingSupply()); } function isOverLiquified(uint256 target, uint256 accuracy) public view returns (bool) { return getLiquidityBacking(accuracy) > target; } event AutoLiquify(uint256 amountBNB, uint256 amountBOG); }
Contract ABI
[{"type":"constructor","stateMutability":"nonpayable","inputs":[]},{"type":"event","name":"Approval","inputs":[{"type":"address","name":"owner","internalType":"address","indexed":true},{"type":"address","name":"spender","internalType":"address","indexed":true},{"type":"uint256","name":"value","internalType":"uint256","indexed":false}],"anonymous":false},{"type":"event","name":"AutoLiquify","inputs":[{"type":"uint256","name":"amountBNB","internalType":"uint256","indexed":false},{"type":"uint256","name":"amountBOG","internalType":"uint256","indexed":false}],"anonymous":false},{"type":"event","name":"OwnershipTransferred","inputs":[{"type":"address","name":"owner","internalType":"address","indexed":false}],"anonymous":false},{"type":"event","name":"Transfer","inputs":[{"type":"address","name":"from","internalType":"address","indexed":true},{"type":"address","name":"to","internalType":"address","indexed":true},{"type":"uint256","name":"value","internalType":"uint256","indexed":false}],"anonymous":false},{"type":"function","stateMutability":"view","outputs":[{"type":"uint256","name":"","internalType":"uint256"}],"name":"_maxTxAmount","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"uint256","name":"","internalType":"uint256"}],"name":"_maxWalletSize","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"uint256","name":"","internalType":"uint256"}],"name":"allowance","inputs":[{"type":"address","name":"holder","internalType":"address"},{"type":"address","name":"spender","internalType":"address"}]},{"type":"function","stateMutability":"nonpayable","outputs":[{"type":"bool","name":"","internalType":"bool"}],"name":"approve","inputs":[{"type":"address","name":"spender","internalType":"address"},{"type":"uint256","name":"amount","internalType":"uint256"}]},{"type":"function","stateMutability":"nonpayable","outputs":[{"type":"bool","name":"","internalType":"bool"}],"name":"approveMax","inputs":[{"type":"address","name":"spender","internalType":"address"}]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"authorize","inputs":[{"type":"address","name":"adr","internalType":"address"}]},{"type":"function","stateMutability":"view","outputs":[{"type":"uint256","name":"","internalType":"uint256"}],"name":"balanceOf","inputs":[{"type":"address","name":"account","internalType":"address"}]},{"type":"function","stateMutability":"pure","outputs":[{"type":"uint8","name":"","internalType":"uint8"}],"name":"decimals","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"uint256","name":"","internalType":"uint256"}],"name":"getCirculatingSupply","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"uint256","name":"","internalType":"uint256"}],"name":"getLiquidityBacking","inputs":[{"type":"uint256","name":"accuracy","internalType":"uint256"}]},{"type":"function","stateMutability":"view","outputs":[{"type":"address","name":"","internalType":"address"}],"name":"getOwner","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"uint256","name":"","internalType":"uint256"}],"name":"getTotalFee","inputs":[{"type":"bool","name":"selling","internalType":"bool"}]},{"type":"function","stateMutability":"view","outputs":[{"type":"bool","name":"","internalType":"bool"}],"name":"isAuthorized","inputs":[{"type":"address","name":"adr","internalType":"address"}]},{"type":"function","stateMutability":"view","outputs":[{"type":"bool","name":"","internalType":"bool"}],"name":"isOverLiquified","inputs":[{"type":"uint256","name":"target","internalType":"uint256"},{"type":"uint256","name":"accuracy","internalType":"uint256"}]},{"type":"function","stateMutability":"view","outputs":[{"type":"bool","name":"","internalType":"bool"}],"name":"isOwner","inputs":[{"type":"address","name":"account","internalType":"address"}]},{"type":"function","stateMutability":"view","outputs":[{"type":"uint256","name":"","internalType":"uint256"}],"name":"launchedAt","inputs":[]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"manualSend","inputs":[]},{"type":"function","stateMutability":"pure","outputs":[{"type":"string","name":"","internalType":"string"}],"name":"name","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"address","name":"","internalType":"address"}],"name":"pair","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"address","name":"","internalType":"contract IDEXRouter"}],"name":"router","inputs":[]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"setFeeReceiver","inputs":[{"type":"address","name":"_marketingFeeReceiver","internalType":"address"},{"type":"address","name":"_teamFeeReceiver","internalType":"address"}]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"setFees","inputs":[{"type":"uint256","name":"_liquidityFee","internalType":"uint256"},{"type":"uint256","name":"_teamFee","internalType":"uint256"},{"type":"uint256","name":"_marketingFee","internalType":"uint256"},{"type":"uint256","name":"_feeDenominator","internalType":"uint256"}]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"setIsFeeExempt","inputs":[{"type":"address","name":"holder","internalType":"address"},{"type":"bool","name":"exempt","internalType":"bool"}]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"setIsTxLimitExempt","inputs":[{"type":"address","name":"holder","internalType":"address"},{"type":"bool","name":"exempt","internalType":"bool"}]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"setMaxWallet","inputs":[{"type":"uint256","name":"amount","internalType":"uint256"}]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"setSwapBackSettings","inputs":[{"type":"bool","name":"_enabled","internalType":"bool"},{"type":"uint256","name":"_amount","internalType":"uint256"}]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"setTxLimit","inputs":[{"type":"uint256","name":"amount","internalType":"uint256"}]},{"type":"function","stateMutability":"view","outputs":[{"type":"bool","name":"","internalType":"bool"}],"name":"swapEnabled","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"uint256","name":"","internalType":"uint256"}],"name":"swapThreshold","inputs":[]},{"type":"function","stateMutability":"pure","outputs":[{"type":"string","name":"","internalType":"string"}],"name":"symbol","inputs":[]},{"type":"function","stateMutability":"view","outputs":[{"type":"uint256","name":"","internalType":"uint256"}],"name":"totalSupply","inputs":[]},{"type":"function","stateMutability":"nonpayable","outputs":[{"type":"bool","name":"","internalType":"bool"}],"name":"transfer","inputs":[{"type":"address","name":"recipient","internalType":"address"},{"type":"uint256","name":"amount","internalType":"uint256"}]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"transferForeignToken","inputs":[{"type":"address","name":"_token","internalType":"address"}]},{"type":"function","stateMutability":"nonpayable","outputs":[{"type":"bool","name":"","internalType":"bool"}],"name":"transferFrom","inputs":[{"type":"address","name":"sender","internalType":"address"},{"type":"address","name":"recipient","internalType":"address"},{"type":"uint256","name":"amount","internalType":"uint256"}]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"transferOwnership","inputs":[{"type":"address","name":"adr","internalType":"address payable"}]},{"type":"function","stateMutability":"nonpayable","outputs":[],"name":"unauthorize","inputs":[{"type":"address","name":"adr","internalType":"address"}]},{"type":"receive","stateMutability":"payable"}]
Deployed ByteCode
0x6080604052600436106102135760003560e01c80638f9a55c011610118578063df20fd49116100a0578063f2fde38b1161006f578063f2fde38b14610670578063f429389014610690578063f84ba65d146106a5578063f887ea40146106c5578063fe9fbb80146106e557600080fd5b8063df20fd49146105f0578063e66db25e14610610578063f0b37c0414610630578063f1f3bca31461065057600080fd5b8063b6a5d7de116100e7578063b6a5d7de14610534578063bf56b37114610554578063d51ed1c81461056a578063dc93cf701461058a578063dd62ed3e146105aa57600080fd5b80638f9a55c0146104a757806395d89b41146104bd578063a8aa1b31146104f4578063a9059cbb1461051457600080fd5b8063571ac8b01161019b5780636ddd17131161016a5780636ddd1713146103ef5780636fcba3771461040957806370a08231146104295780637d1db4a51461045f578063893d20e81461047557600080fd5b8063571ac8b01461036d5780635c85974f1461038d5780635d0044ca146103af578063658d4b7f146103cf57600080fd5b806318160ddd116101e257806318160ddd146102d857806323b872dd146102ed5780632b112e491461030d5780632f54bf6e14610322578063313ce5671461035157600080fd5b80630445b6671461021f57806306fdde0314610248578063095ea7b3146102885780631161ae39146102b857600080fd5b3661021a57005b600080fd5b34801561022b57600080fd5b5061023560175481565b6040519081526020015b60405180910390f35b34801561025457600080fd5b5060408051808201909152600e81526d26b4b635bcacb0b1b43a21b63ab160911b60208201525b60405161023f9190611b02565b34801561029457600080fd5b506102a86102a33660046119eb565b610705565b604051901515815260200161023f565b3480156102c457600080fd5b506102a86102d3366004611a80565b610772565b3480156102e457600080fd5b50600554610235565b3480156102f957600080fd5b506102a8610308366004611975565b610786565b34801561031957600080fd5b50610235610848565b34801561032e57600080fd5b506102a861033d36600461191f565b6000546001600160a01b0391821691161490565b34801561035d57600080fd5b506040516009815260200161023f565b34801561037957600080fd5b506102a861038836600461191f565b61089a565b34801561039957600080fd5b506103ad6103a8366004611a4e565b6108a8565b005b3480156103bb57600080fd5b506103ad6103ca366004611a4e565b6108f7565b3480156103db57600080fd5b506103ad6103ea3660046119b6565b610942565b3480156103fb57600080fd5b506016546102a89060ff1681565b34801561041557600080fd5b506103ad610424366004611ad0565b610992565b34801561043557600080fd5b5061023561044436600461191f565b6001600160a01b031660009081526008602052604090205490565b34801561046b57600080fd5b5061023560065481565b34801561048157600080fd5b506000546001600160a01b03165b6040516001600160a01b03909116815260200161023f565b3480156104b357600080fd5b5061023560075481565b3480156104c957600080fd5b5060408051808201909152600e81526d26a4a625acaca0a1a42a21a62aa160911b602082015261027b565b34801561050057600080fd5b5060145461048f906001600160a01b031681565b34801561052057600080fd5b506102a861052f3660046119eb565b6109e5565b34801561054057600080fd5b506103ad61054f36600461191f565b6109f2565b34801561056057600080fd5b5061023560155481565b34801561057657600080fd5b50610235610585366004611a4e565b610a43565b34801561059657600080fd5b506103ad6105a536600461191f565b610a87565b3480156105b657600080fd5b506102356105c536600461193c565b6001600160a01b03918216600090815260096020908152604080832093909416825291909152205490565b3480156105fc57600080fd5b506103ad61060b366004611a32565b610bcb565b34801561061c57600080fd5b506103ad61062b36600461193c565b610c07565b34801561063c57600080fd5b506103ad61064b36600461191f565b610c5a565b34801561065c57600080fd5b5061023561066b366004611a17565b610ca5565b34801561067c57600080fd5b506103ad61068b36600461191f565b610ce6565b34801561069c57600080fd5b506103ad610d7c565b3480156106b157600080fd5b506103ad6106c03660046119b6565b610ddf565b3480156106d157600080fd5b5060135461048f906001600160a01b031681565b3480156106f157600080fd5b506102a861070036600461191f565b610e2f565b3360008181526009602090815260408083206001600160a01b038716808552925280832085905551919290917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925906107609086815260200190565b60405180910390a35060015b92915050565b60008261077e83610a43565b119392505050565b6001600160a01b038316600090815260096020908152604080832033845290915281205460001914610833576040805180820182526016815275496e73756666696369656e7420416c6c6f77616e636560501b6020808301919091526001600160a01b038716600090815260098252838120338252909152919091205461080e918490610e4d565b6001600160a01b03851660009081526009602090815260408083203384529091529020555b61083e848484610e87565b90505b9392505050565b6004546001600160a01b0316600090815260086020526040812054610895906003546001600160a01b031660009081526008602052604090205461088f9060055490611109565b90611109565b905090565b600061076c82600019610705565b6108b133610e2f565b6108d65760405162461bcd60e51b81526004016108cd90611b77565b60405180910390fd5b6103e86005546108e69190611c25565b8110156108f257600080fd5b600655565b6000546001600160a01b031633146109215760405162461bcd60e51b81526004016108cd90611b57565b6103e86005546109319190611c25565b81101561093d57600080fd5b600755565b61094b33610e2f565b6109675760405162461bcd60e51b81526004016108cd90611b77565b6001600160a01b03919091166000908152600a60205260409020805460ff1916911515919091179055565b61099b33610e2f565b6109b75760405162461bcd60e51b81526004016108cd90611b77565b600c849055600d839055600e8290556109da826109d4868661114b565b9061114b565b600f55601055505050565b6000610841338484610e87565b6000546001600160a01b03163314610a1c5760405162461bcd60e51b81526004016108cd90611b57565b6001600160a01b03166000908152600160208190526040909120805460ff19169091179055565b600061076c610a50610848565b6014546001600160a01b0316600090815260086020526040902054610a8190610a7a9060026111aa565b85906111aa565b90611229565b610a9033610e2f565b610aac5760405162461bcd60e51b81526004016108cd90611b77565b6001600160a01b038116301415610b115760405162461bcd60e51b815260206004820152602360248201527f43616e2774206c657420796f752074616b6520616c6c206e617469766520746f60448201526235b2b760e91b60648201526084016108cd565b6040516370a0823160e01b81523060048201526000906001600160a01b038316906370a082319060240160206040518083038186803b158015610b5357600080fd5b505afa158015610b67573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610b8b9190611a67565b6011546040519192506001600160a01b03169082156108fc029083906000818181858888f19350505050158015610bc6573d6000803e3d6000fd5b505050565b610bd433610e2f565b610bf05760405162461bcd60e51b81526004016108cd90611b77565b6016805460ff191692151592909217909155601755565b610c1033610e2f565b610c2c5760405162461bcd60e51b81526004016108cd90611b77565b601180546001600160a01b039384166001600160a01b03199182161790915560128054929093169116179055565b6000546001600160a01b03163314610c845760405162461bcd60e51b81526004016108cd90611b57565b6001600160a01b03166000908152600160205260409020805460ff19169055565b6000436015546001610cb79190611c0d565b10610cca5760105461076c906001611109565b8115610cde57600f5461076c90600161114b565b5050600f5490565b6000546001600160a01b03163314610d105760405162461bcd60e51b81526004016108cd90611b57565b600080546001600160a01b0319166001600160a01b038316908117825580825260016020818152604093849020805460ff191690921790915591519081527f04dba622d284ed0014ee4b9a6a68386be1a4c08a4913ae272de89199cc686163910160405180910390a150565b610d8533610e2f565b610da15760405162461bcd60e51b81526004016108cd90611b77565b60115460405147916001600160a01b03169082156108fc029083906000818181858888f19350505050158015610ddb573d6000803e3d6000fd5b5050565b610de833610e2f565b610e045760405162461bcd60e51b81526004016108cd90611b77565b6001600160a01b03919091166000908152600b60205260409020805460ff1916911515919091179055565b6001600160a01b031660009081526001602052604090205460ff1690565b60008184841115610e715760405162461bcd60e51b81526004016108cd9190611b02565b506000610e7e8486611c66565b95945050505050565b60185460009060ff1615610ea757610ea084848461126b565b9050610841565b610eb18483611351565b6014546001600160a01b03848116911614801590610edd57506003546001600160a01b03848116911614155b15610f88576001600160a01b0383166000908152600b602052604090205460ff1680610f2e57506007546001600160a01b038416600090815260086020526040902054610f2b908490611c0d565b11155b610f885760405162461bcd60e51b815260206004820152602560248201527f5472616e7366657220616d6f756e74206578636565647320746865206261672060448201526439b4bd329760d91b60648201526084016108cd565b610f906113ba565b15610f9d57610f9d611409565b601554158015610fba57506014546001600160a01b038481169116145b15610fea576001600160a01b038416600090815260086020526040902054610fe157600080fd5b610fea43601555565b6040805180820182526014815273496e73756666696369656e742042616c616e636560601b6020808301919091526001600160a01b03871660009081526008909152919091205461103c918490610e4d565b6001600160a01b038516600090815260086020908152604080832093909355600a90529081205460ff1615611071578261107c565b61107c85858561182a565b6001600160a01b0385166000908152600860205260409020549091506110a2908261114b565b6001600160a01b0380861660008181526008602052604090819020939093559151908716907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906110f69085815260200190565b60405180910390a3506001949350505050565b600061084183836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250610e4d565b6000806111588385611c0d565b9050838110156108415760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f77000000000060448201526064016108cd565b6000826111b95750600061076c565b60006111c58385611c47565b9050826111d28583611c25565b146108415760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b60648201526084016108cd565b600061084183836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f0000000000008152506118dc565b6040805180820182526014815273496e73756666696369656e742042616c616e636560601b6020808301919091526001600160a01b03861660009081526008909152918220546112bc918490610e4d565b6001600160a01b0380861660009081526008602052604080822093909355908516815220546112eb908361114b565b6001600160a01b0380851660008181526008602052604090819020939093559151908616907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9061133f9086815260200190565b60405180910390a35060019392505050565b6006548111158061137a57506001600160a01b0382166000908152600b602052604090205460ff165b610ddb5760405162461bcd60e51b8152602060048201526011602482015270151608131a5b5a5d08115e18d959591959607a1b60448201526064016108cd565b6014546000906001600160a01b031633148015906113db575060185460ff16155b80156113e9575060165460ff165b801561089557505060175430600090815260086020526040902054101590565b6018805460ff19166001179055306000908152600860205260408120549050600061144a6002610a81600f54610a81600c54876111aa90919063ffffffff16565b905060006114588383611109565b6040805160028082526060820183529293506000929091602083019080368337019050509050308160008151811061149257611492611c93565b6001600160a01b0392831660209182029290920101526002548251911690829060019081106114c3576114c3611c93565b6001600160a01b03928316602091820292909201015260135460405163791ac94760e01b81524792919091169063791ac9479061150d908690600090879030904290600401611b9c565b600060405180830381600087803b15801561152757600080fd5b505af115801561153b573d6000803e3d6000fd5b505050506000611554824761110990919063ffffffff16565b9050600061157a6115716002600c5461122990919063ffffffff16565b600f5490611109565b9050600061159c6002610a8184610a81600c54886111aa90919063ffffffff16565b905060006115b983610a81600d54876111aa90919063ffffffff16565b905060006115d684610a81600e54886111aa90919063ffffffff16565b6011546040519192506000916001600160a01b039091169061753090849084818181858888f193505050503d806000811461162d576040519150601f19603f3d011682016040523d82523d6000602084013e611632565b606091505b50509050806116835760405162461bcd60e51b815260206004820152601e60248201527f72656365697665722072656a656374656420455448207472616e73666572000060448201526064016108cd565b6012546040516000916001600160a01b03169061753090869084818181858888f193505050503d80600081146116d5576040519150601f19603f3d011682016040523d82523d6000602084013e6116da565b606091505b505090508061172b5760405162461bcd60e51b815260206004820152601e60248201527f72656365697665722072656a656374656420455448207472616e73666572000060448201526064016108cd565b8a156118125760135460115460405163f305d71960e01b8152306004820152602481018e905260006044820181905260648201526001600160a01b0391821660848201524260a482015291169063f305d71990879060c4016060604051808303818588803b15801561179c57600080fd5b505af11580156117b0573d6000803e3d6000fd5b50505050506040513d601f19601f820116820180604052508101906117d59190611aa2565b505060408051878152602081018e90527f424db2872186fa7e7afa7a5e902ed3b49a2ef19c2f5431e672462495dd6b450692500160405180910390a15b50506018805460ff1916905550505050505050505050565b601054601454600091829161185c9190610a8190611855906001600160a01b03898116911614610ca5565b86906111aa565b30600090815260086020526040902054909150611879908261114b565b30600081815260086020526040908190209290925590516001600160a01b038716907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906118ca9085815260200190565b60405180910390a3610e7e8382611109565b600081836118fd5760405162461bcd60e51b81526004016108cd9190611b02565b506000610e7e8486611c25565b8035801515811461191a57600080fd5b919050565b60006020828403121561193157600080fd5b813561084181611ca9565b6000806040838503121561194f57600080fd5b823561195a81611ca9565b9150602083013561196a81611ca9565b809150509250929050565b60008060006060848603121561198a57600080fd5b833561199581611ca9565b925060208401356119a581611ca9565b929592945050506040919091013590565b600080604083850312156119c957600080fd5b82356119d481611ca9565b91506119e26020840161190a565b90509250929050565b600080604083850312156119fe57600080fd5b8235611a0981611ca9565b946020939093013593505050565b600060208284031215611a2957600080fd5b6108418261190a565b60008060408385031215611a4557600080fd5b611a098361190a565b600060208284031215611a6057600080fd5b5035919050565b600060208284031215611a7957600080fd5b5051919050565b60008060408385031215611a9357600080fd5b50508035926020909101359150565b600080600060608486031215611ab757600080fd5b8351925060208401519150604084015190509250925092565b60008060008060808587031215611ae657600080fd5b5050823594602084013594506040840135936060013592509050565b600060208083528351808285015260005b81811015611b2f57858101830151858201604001528201611b13565b81811115611b41576000604083870101525b50601f01601f1916929092016040019392505050565b60208082526006908201526510a7aba722a960d11b604082015260600190565b6020808252600b908201526a085055551213d49256915160aa1b604082015260600190565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b81811015611bec5784516001600160a01b031683529383019391830191600101611bc7565b50506001600160a01b03969096166060850152505050608001529392505050565b60008219821115611c2057611c20611c7d565b500190565b600082611c4257634e487b7160e01b600052601260045260246000fd5b500490565b6000816000190483118215151615611c6157611c61611c7d565b500290565b600082821015611c7857611c78611c7d565b500390565b634e487b7160e01b600052601160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b6001600160a01b0381168114611cbe57600080fd5b5056fea264697066735822122087b768fe3c917cdc9f8a5a0871391839709589166035d2cb3a4e3958319ca27064736f6c63430008070033