ERC-20
Overview
Max Total Supply
100,000,000 RCS
Holders
116
Market
Onchain Market Cap
$0.00
Circulating Supply Market Cap
-
Other Info
Token Contract (WITH 9 Decimals)
Balance
878,401.549155848 RCSValue
$0.00Loading...
Loading
Loading...
Loading
Loading...
Loading
# | Exchange | Pair | Price | 24H Volume | % Volume |
---|
Contract Name:
RecursiveFi
Compiler Version
v0.8.19+commit.7dd6d404
Contract Source Code (Solidity)
/** *Submitted for verification at Etherscan.io on 2023-11-23 */ // SPDX-License-Identifier: MIT /** Website: https://www.recursiveprotocol.com Docs: https://docs.recursiveprotocol.com Telegram: https://t.me/recursiveprotocol Twitter: https://twitter.com/recursive_prtcl */ pragma solidity ^0.8.10; /** * @dev Provides information about the current execution context, including the * sender of the transaction and its data. While these are generally available * via msg.sender and msg.data, they should not be accessed in such a direct * manner, since when dealing with meta-transactions the account sending and * paying for execution may not be the actual sender (as far as an application * is concerned). * * This contract is only required for intermediate, library-like contracts. */ abstract contract Context { function _msgSender() internal view virtual returns (address) { return msg.sender; } function _msgData() internal view virtual returns (bytes calldata) { return msg.data; } } /** * @dev Contract module which provides a basic access control mechanism, where * there is an account (an owner) that can be granted exclusive access to * specific functions. * * By default, the owner account will be the one that deploys the contract. This * can later be changed with {transferOwnership}. * * This module is used through inheritance. It will make available the modifier * `onlyOwner`, which can be applied to your functions to restrict their use to * the owner. */ abstract contract Ownable is Context { address private _owner; event OwnershipTransferred( address indexed previousOwner, address indexed newOwner ); /** * @dev Initializes the contract setting the deployer as the initial owner. */ constructor() { _transferOwnership(_msgSender()); } /** * @dev Throws if called by any account other than the owner. */ modifier onlyOwner() { _checkOwner(); _; } /** * @dev Returns the address of the current owner. */ function owner() public view virtual returns (address) { return _owner; } /** * @dev Throws if the sender is not the owner. */ function _checkOwner() internal view virtual { require(owner() == _msgSender(), "Ownable: caller is not the owner"); } /** * @dev Leaves the contract without owner. It will not be possible to call * `onlyOwner` functions anymore. Can only be called by the current owner. * * NOTE: Renouncing ownership will leave the contract without an owner, * thereby removing any functionality that is only available to the owner. */ function renounceOwnership() public virtual onlyOwner { _transferOwnership(address(0)); } /** * @dev Transfers ownership of the contract to a new account (`newOwner`). * Can only be called by the current owner. */ function transferOwnership(address newOwner) public virtual onlyOwner { require( newOwner != address(0), "Ownable: new owner is the zero address" ); _transferOwnership(newOwner); } /** * @dev Transfers ownership of the contract to a new account (`newOwner`). * Internal function without access restriction. */ function _transferOwnership(address newOwner) internal virtual { address oldOwner = _owner; _owner = newOwner; emit OwnershipTransferred(oldOwner, newOwner); } } 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 pure returns (string memory); function symbol() external pure returns (string memory); function decimals() external pure 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 DOMAIN_SEPARATOR() external view returns (bytes32); function PERMIT_TYPEHASH() external pure returns (bytes32); function nonces(address owner) external view returns (uint); function permit( address owner, address spender, uint value, uint deadline, uint8 v, bytes32 r, bytes32 s ) external; function sync() external; } interface IUniswapV2Factory { event PairCreated( address indexed token0, address indexed token1, address pair, uint256 ); function feeTo() external view returns (address); function feeToSetter() external view returns (address); function getPair( address tokenA, address tokenB ) external view returns (address pair); function allPairs(uint256) external view returns (address pair); function allPairsLength() external view returns (uint256); function createPair( address tokenA, address tokenB ) external returns (address pair); function setFeeTo(address) external; function setFeeToSetter(address) external; } interface IUniswapV2Router01 { function factory() external pure returns (address); function WETH() external pure returns (address); function addLiquidity( address tokenA, address tokenB, uint256 amountADesired, uint256 amountBDesired, uint256 amountAMin, uint256 amountBMin, address to, uint256 deadline ) external returns (uint256 amountA, uint256 amountB, uint256 liquidity); function addLiquidityETH( address token, uint256 amountTokenDesired, uint256 amountTokenMin, uint256 amountETHMin, address to, uint256 deadline ) external payable returns (uint256 amountToken, uint256 amountETH, uint256 liquidity); function removeLiquidity( address tokenA, address tokenB, uint256 liquidity, uint256 amountAMin, uint256 amountBMin, address to, uint256 deadline ) external returns (uint256 amountA, uint256 amountB); function removeLiquidityETH( address token, uint256 liquidity, uint256 amountTokenMin, uint256 amountETHMin, address to, uint256 deadline ) external returns (uint256 amountToken, uint256 amountETH); function removeLiquidityWithPermit( address tokenA, address tokenB, uint256 liquidity, uint256 amountAMin, uint256 amountBMin, address to, uint256 deadline, bool approveMax, uint8 v, bytes32 r, bytes32 s ) external returns (uint256 amountA, uint256 amountB); function removeLiquidityETHWithPermit( address token, uint256 liquidity, uint256 amountTokenMin, uint256 amountETHMin, address to, uint256 deadline, bool approveMax, uint8 v, bytes32 r, bytes32 s ) external returns (uint256 amountToken, uint256 amountETH); function swapExactTokensForTokens( uint256 amountIn, uint256 amountOutMin, address[] calldata path, address to, uint256 deadline ) external returns (uint256[] memory amounts); function swapTokensForExactTokens( uint256 amountOut, uint256 amountInMax, address[] calldata path, address to, uint256 deadline ) external returns (uint256[] memory amounts); function swapExactETHForTokens( uint256 amountOutMin, address[] calldata path, address to, uint256 deadline ) external payable returns (uint256[] memory amounts); function swapExactTokensForETH( uint256 amountIn, uint256 amountOutMin, address[] calldata path, address to, uint256 deadline ) external returns (uint256[] memory amounts); function swapETHForExactTokens( uint256 amountOut, address[] calldata path, address to, uint256 deadline ) external payable returns (uint256[] memory amounts); function swapTokensForExactETH( uint256 amountOut, uint256 amountInMax, address[] calldata path, address to, uint256 deadline ) external returns (uint256[] memory amounts); function quote( uint256 amountA, uint256 reserveA, uint256 reserveB ) external pure returns (uint256 amountB); function getAmountIn( uint256 amountOut, uint256 reserveIn, uint256 reserveOut ) external pure returns (uint256 amountIn); function getAmountsOut( uint256 amountIn, address[] calldata path ) external view returns (uint256[] memory amounts); function getAmountOut( uint256 amountIn, uint256 reserveIn, uint256 reserveOut ) external pure returns (uint256 amountOut); function getAmountsIn( uint256 amountOut, address[] calldata path ) external view returns (uint256[] memory amounts); } interface IUniswapV2Router02 is IUniswapV2Router01 { function removeLiquidityETHSupportingFeeOnTransferTokens( address token, uint256 liquidity, uint256 amountTokenMin, uint256 amountETHMin, address to, uint256 deadline ) external returns (uint256 amountETH); function removeLiquidityETHWithPermitSupportingFeeOnTransferTokens( address token, uint256 liquidity, uint256 amountTokenMin, uint256 amountETHMin, address to, uint256 deadline, bool approveMax, uint8 v, bytes32 r, bytes32 s ) external returns (uint256 amountETH); function swapExactETHForTokensSupportingFeeOnTransferTokens( uint256 amountOutMin, address[] calldata path, address to, uint256 deadline ) external payable; function swapExactTokensForTokensSupportingFeeOnTransferTokens( uint256 amountIn, uint256 amountOutMin, address[] calldata path, address to, uint256 deadline ) external; function swapExactTokensForETHSupportingFeeOnTransferTokens( uint256 amountIn, uint256 amountOutMin, address[] calldata path, address to, uint256 deadline ) external; } // CAUTION // This version of SafeMath should only be used with Solidity 0.8 or later, // because it relies on the compiler's built in overflow checks. /** * @dev Wrappers over Solidity's arithmetic operations. * * NOTE: `SafeMath` is generally not needed starting with Solidity 0.8, since the compiler * now has built in overflow checking. */ library SafeMath { /** * @dev Returns the addition of two unsigned integers, with an overflow flag. * * _Available since v3.4._ */ function tryAdd( uint256 a, uint256 b ) internal pure returns (bool, uint256) { unchecked { uint256 c = a + b; if (c < a) return (false, 0); return (true, c); } } /** * @dev Returns the subtraction of two unsigned integers, with an overflow flag. * * _Available since v3.4._ */ function trySub( uint256 a, uint256 b ) internal pure returns (bool, uint256) { unchecked { if (b > a) return (false, 0); return (true, a - b); } } /** * @dev Returns the multiplication of two unsigned integers, with an overflow flag. * * _Available since v3.4._ */ function tryMul( uint256 a, uint256 b ) internal pure returns (bool, uint256) { unchecked { // Gas optimization: this is cheaper than requiring 'a' not being zero, but the // benefit is lost if 'b' is also tested. // See: https://github.com/OpenZeppelin/openzeppelin-contracts/pull/522 if (a == 0) return (true, 0); uint256 c = a * b; if (c / a != b) return (false, 0); return (true, c); } } /** * @dev Returns the division of two unsigned integers, with a division by zero flag. * * _Available since v3.4._ */ function tryDiv( uint256 a, uint256 b ) internal pure returns (bool, uint256) { unchecked { if (b == 0) return (false, 0); return (true, a / b); } } /** * @dev Returns the remainder of dividing two unsigned integers, with a division by zero flag. * * _Available since v3.4._ */ function tryMod( uint256 a, uint256 b ) internal pure returns (bool, uint256) { unchecked { if (b == 0) return (false, 0); return (true, a % b); } } /** * @dev Returns the addition of two unsigned integers, reverting on * overflow. * * Counterpart to Solidity's `+` operator. * * Requirements: * * - Addition cannot overflow. */ function add(uint256 a, uint256 b) internal pure returns (uint256) { return a + b; } /** * @dev Returns the subtraction of two unsigned integers, reverting on * overflow (when the result is negative). * * Counterpart to Solidity's `-` operator. * * Requirements: * * - Subtraction cannot overflow. */ function sub(uint256 a, uint256 b) internal pure returns (uint256) { return a - b; } /** * @dev Returns the multiplication of two unsigned integers, reverting on * overflow. * * Counterpart to Solidity's `*` operator. * * Requirements: * * - Multiplication cannot overflow. */ function mul(uint256 a, uint256 b) internal pure returns (uint256) { return a * b; } /** * @dev Returns the integer division of two unsigned integers, reverting on * division by zero. The result is rounded towards zero. * * Counterpart to Solidity's `/` operator. * * Requirements: * * - The divisor cannot be zero. */ function div(uint256 a, uint256 b) internal pure returns (uint256) { return a / b; } /** * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo), * reverting when dividing by zero. * * Counterpart to Solidity's `%` operator. This function uses a `revert` * opcode (which leaves remaining gas untouched) while Solidity uses an * invalid opcode to revert (consuming all remaining gas). * * Requirements: * * - The divisor cannot be zero. */ function mod(uint256 a, uint256 b) internal pure returns (uint256) { return a % b; } /** * @dev Returns the subtraction of two unsigned integers, reverting with custom message on * overflow (when the result is negative). * * CAUTION: This function is deprecated because it requires allocating memory for the error * message unnecessarily. For custom revert reasons use {trySub}. * * Counterpart to Solidity's `-` operator. * * Requirements: * * - Subtraction cannot overflow. */ function sub( uint256 a, uint256 b, string memory errorMessage ) internal pure returns (uint256) { unchecked { require(b <= a, errorMessage); return a - b; } } /** * @dev Returns the integer division of two unsigned integers, reverting with custom message on * division by zero. The result is rounded towards zero. * * 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) { unchecked { require(b > 0, errorMessage); return a / b; } } /** * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo), * reverting with custom message when dividing by zero. * * CAUTION: This function is deprecated because it requires allocating memory for the error * message unnecessarily. For custom revert reasons use {tryMod}. * * Counterpart to Solidity's `%` operator. This function uses a `revert` * opcode (which leaves remaining gas untouched) while Solidity uses an * invalid opcode to revert (consuming all remaining gas). * * Requirements: * * - The divisor cannot be zero. */ function mod( uint256 a, uint256 b, string memory errorMessage ) internal pure returns (uint256) { unchecked { require(b > 0, errorMessage); return a % b; } } } /** * @dev Interface of the ERC20 standard as defined in the EIP. */ interface IERC20 { /** * @dev Emitted when `value` tokens are moved from one account (`from`) to * another (`to`). * * Note that `value` may be zero. */ event Transfer(address indexed from, address indexed to, uint256 value); /** * @dev Emitted when the allowance of a `spender` for an `owner` is set by * a call to {approve}. `value` is the new allowance. */ event Approval( address indexed owner, address indexed spender, uint256 value ); /** * @dev Returns the amount of tokens in existence. */ function totalSupply() external view returns (uint256); /** * @dev Returns the amount of tokens owned by `account`. */ function balanceOf(address account) external view returns (uint256); /** * @dev Moves `amount` tokens from the caller's account to `to`. * * Returns a boolean value indicating whether the operation succeeded. * * Emits a {Transfer} event. */ function transfer(address to, uint256 amount) external returns (bool); /** * @dev Returns the remaining number of tokens that `spender` will be * allowed to spend on behalf of `owner` through {transferFrom}. This is * zero by default. * * This value changes when {approve} or {transferFrom} are called. */ function allowance( address owner, address spender ) external view returns (uint256); /** * @dev Sets `amount` as the allowance of `spender` over the caller's tokens. * * Returns a boolean value indicating whether the operation succeeded. * * IMPORTANT: Beware that changing an allowance with this method brings the risk * that someone may use both the old and the new allowance by unfortunate * transaction ordering. One possible solution to mitigate this race * condition is to first reduce the spender's allowance to 0 and set the * desired value afterwards: * https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729 * * Emits an {Approval} event. */ function approve(address spender, uint256 amount) external returns (bool); /** * @dev Moves `amount` tokens from `from` to `to` using the * allowance mechanism. `amount` is then deducted from the caller's * allowance. * * Returns a boolean value indicating whether the operation succeeded. * * Emits a {Transfer} event. */ function transferFrom( address from, address to, uint256 amount ) external returns (bool); } /** * @dev Interface for the optional metadata functions from the ERC20 standard. * * _Available since v4.1._ */ interface IERC20Metadata is IERC20 { /** * @dev Returns the name of the token. */ function name() external view returns (string memory); /** * @dev Returns the symbol of the token. */ function symbol() external view returns (string memory); /** * @dev Returns the decimals places of the token. */ function decimals() external view returns (uint8); } contract RecursiveFi is Context, IERC20, Ownable { using SafeMath for uint256; string private _name = "Recursive Finance"; string private _symbol = "RCS"; uint8 private _decimals = 9; mapping(address => uint256) _balances; mapping(address => mapping(address => uint256)) private _allowances; mapping(address => bool) public checkExcludedFromFees; mapping(address => bool) public checkWalletLimitExcept; mapping(address => bool) public checkTxLimitExcept; mapping(address => bool) public checkMarketPair; uint256 public _liquidityShares = 0; uint256 public _marketingShares = 10; uint256 public _totalTaxIfBuying = 15; uint256 public _totalTaxIfSelling = 15; uint256 public _totalDistributionShares = 10; uint256 public _buyLiquidityFees = 0; uint256 public _buyMarketingFees = 15; uint256 public _sellLiquidityFees = 0; uint256 public _sellMarketingFees = 15; uint256 private _totalSupply = 100_000_000 * 10 ** 9; uint256 public maxTxAmount = (_totalSupply * 20) / 1000; uint256 public maxWallet = (_totalSupply * 20) / 1000; uint256 public maxTaxSwap = (_totalSupply * 2) / 1000; uint256 private minTokensToSwap = _totalSupply / 100000; address payable private taxWallet = payable(0xABB4B6A246eE4621c7E08845e9Eb33fE54489518); address public immutable DEAD = 0x000000000000000000000000000000000000dEaD; IUniswapV2Router02 public uniswapV2Router; address public uniswapV2Pair; bool inSwapAndLiquify; bool public swapAndLiquifyEnabled = false; bool public swapAndLiquifyByLimitOnly = false; bool public checkWalletLimit = true; bool public tradingOpen = false; event SwapAndLiquify( uint256 tokensSwapped, uint256 ethReceived, uint256 tokensIntoLiqudity ); modifier lockTheSwap() { inSwapAndLiquify = true; _; inSwapAndLiquify = false; } constructor() { checkExcludedFromFees[owner()] = true; checkExcludedFromFees[taxWallet] = true; checkExcludedFromFees[address(this)] = true; checkWalletLimitExcept[owner()] = true; checkWalletLimitExcept[taxWallet] = true; checkWalletLimitExcept[address(this)] = true; checkTxLimitExcept[owner()] = true; checkTxLimitExcept[taxWallet] = true; checkTxLimitExcept[address(this)] = true; _balances[_msgSender()] = _totalSupply; emit Transfer(address(0), _msgSender(), _totalSupply); } function addLiquidityETH() external payable onlyOwner { uniswapV2Router = IUniswapV2Router02( 0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D ); uniswapV2Pair = IUniswapV2Factory(uniswapV2Router.factory()).createPair( address(this), uniswapV2Router.WETH() ); _approve(address(this), address(uniswapV2Router), _totalSupply); checkMarketPair[address(uniswapV2Pair)] = true; checkWalletLimitExcept[address(uniswapV2Pair)] = true; uniswapV2Router.addLiquidityETH{value: msg.value}( address(this), balanceOf(address(this)), 0, 0, owner(), block.timestamp ); } function name() public view returns (string memory) { return _name; } function symbol() public view returns (string memory) { return _symbol; } function decimals() public view returns (uint8) { return _decimals; } function totalSupply() public view override returns (uint256) { return _totalSupply; } function balanceOf(address account) public view override returns (uint256) { return _balances[account]; } function allowance( address owner, address spender ) public view override returns (uint256) { return _allowances[owner][spender]; } function approve( address spender, uint256 amount ) public override returns (bool) { _approve(_msgSender(), spender, amount); return true; } function _approve(address owner, address spender, uint256 amount) private { require(owner != address(0), "ERC20: approve from the zero address"); require(spender != address(0), "ERC20: approve to the zero address"); _allowances[owner][spender] = amount; emit Approval(owner, spender, amount); } function enableTrading() external onlyOwner { require(!tradingOpen, "trading is already open"); tradingOpen = true; swapAndLiquifyEnabled = true; } function setBuyFees( uint256 newLiquidityTax, uint256 newMarketingTax ) external onlyOwner { _buyLiquidityFees = newLiquidityTax; _buyMarketingFees = newMarketingTax; _totalTaxIfBuying = _buyLiquidityFees.add(_buyMarketingFees); require(_totalTaxIfBuying <= 10); } function setSellFees( uint256 newLiquidityTax, uint256 newMarketingTax ) external onlyOwner { _sellLiquidityFees = newLiquidityTax; _sellMarketingFees = newMarketingTax; _totalTaxIfSelling = _sellLiquidityFees.add(_sellMarketingFees); require(_totalTaxIfSelling <= 20); } function setDistributionSettings( uint256 newLiquidityShare, uint256 newMarketingShare ) external onlyOwner { _liquidityShares = newLiquidityShare; _marketingShares = newMarketingShare; _totalDistributionShares = _liquidityShares.add(_marketingShares); } function setcheckWalletLimitExcept( address holder, bool exempt ) external onlyOwner { checkWalletLimitExcept[holder] = exempt; } function setWalletLimit(uint256 newLimit) external onlyOwner { maxWallet = newLimit; } function setTaxWallet(address newAddress) external onlyOwner { taxWallet = payable(newAddress); } function min(uint256 a, uint256 b) private pure returns (uint256){ return (a>b)?b:a; } function removeLimits() external onlyOwner returns (bool) { _totalTaxIfBuying = 2; _totalTaxIfSelling = 2; _buyLiquidityFees = 0; _buyMarketingFees = 2; _sellLiquidityFees = 0; _sellMarketingFees = 2; maxWallet = ~uint256(0); maxTxAmount = ~uint256(0); return true; } function updateMaxTxAmount(uint256 maxTxAmount_) external onlyOwner { require( maxTxAmount_ >= _totalSupply / 100, "Max wallet should be more or equal to 1%" ); maxTxAmount = maxTxAmount_; } function enableDisableWalletLimit(bool newValue) external onlyOwner { checkWalletLimit = newValue; } function setSwapAndLiquifyByLimitOnly(bool newValue) public onlyOwner { swapAndLiquifyByLimitOnly = newValue; } function getCirculatingSupply() public view returns (uint256) { return _totalSupply.sub(balanceOf(DEAD)); } function swapAndLiquify(uint256 tAmount) private lockTheSwap { uint256 contractTokenBalance = balanceOf(address(this)); uint256 amountToSwap = min(tAmount, min(contractTokenBalance, maxTaxSwap)); swapTokensForEth(amountToSwap); uint256 amountETHMarketing = address(this).balance; transferToAddressETH(taxWallet, amountETHMarketing); } function swapTokensForEth(uint256 tokenAmount) private { // generate the uniswap pair path of token -> weth address[] memory path = new address[](2); path[0] = address(this); path[1] = uniswapV2Router.WETH(); _approve(address(this), address(uniswapV2Router), tokenAmount); // make the swap uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens( tokenAmount, 0, // accept any amount of ETH path, address(this), // The contract block.timestamp ); } function takeFees( address sender, address recipient, uint256 amount ) internal view returns (uint256, uint256) { uint256 feeAmount = amount; if (checkExcludedFromFees[sender]) return (amount, feeAmount); if (checkMarketPair[sender]) { feeAmount = amount.mul(_totalTaxIfBuying).div(100); } else if (checkMarketPair[recipient]) { feeAmount = amount.mul(_totalTaxIfSelling).div(100); } return (amount.sub(feeAmount), feeAmount); } function transferToAddressETH( address payable recipient, uint256 amount ) private { recipient.transfer(amount); } 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; } //to recieve ETH from uniswapV2Router when swaping receive() external payable {} function transfer( address recipient, uint256 amount ) public override returns (bool) { _transfer(_msgSender(), recipient, amount); return true; } function transferFrom( address sender, address recipient, uint256 amount ) public override returns (bool) { _transfer(sender, recipient, amount); _approve( sender, _msgSender(), _allowances[sender][_msgSender()].sub( amount, "ERC20: transfer amount exceeds allowance" ) ); return true; } function _transfer( address sender, address recipient, uint256 amount ) private returns (bool) { require(sender != address(0), "ERC20: transfer from the zero address"); require(recipient != address(0), "ERC20: transfer to the zero address"); require(amount > 0, "ERC20: transfer amount must greater than zero"); require( tradingOpen || checkExcludedFromFees[sender] || checkExcludedFromFees[recipient], "Not Enabled" ); if (inSwapAndLiquify || !swapAndLiquifyEnabled) { return _basicTransfer(sender, recipient, amount); } else { if (!checkTxLimitExcept[sender] && !checkTxLimitExcept[recipient]) { require( amount <= maxTxAmount, "Transfer amount exceeds the maxTxAmount." ); } uint256 contractTokenBalance = balanceOf(address(this)); bool overMinimumTokenBalance = contractTokenBalance >= minTokensToSwap; if ( overMinimumTokenBalance && !inSwapAndLiquify && !checkExcludedFromFees[sender] && checkMarketPair[recipient] && amount >= minTokensToSwap && swapAndLiquifyEnabled ) { if (swapAndLiquifyByLimitOnly) contractTokenBalance = minTokensToSwap; swapAndLiquify(amount); } (uint256 finalAmount, uint256 feeAmount) = takeFees( sender, recipient, amount ); address feeReceiver = feeAmount == amount ? sender : address(this); if (feeAmount > 0) { _balances[feeReceiver] = _balances[feeReceiver].add(feeAmount); emit Transfer(sender, feeReceiver, feeAmount); } _balances[sender] = _balances[sender].sub( amount, "Insufficient Balance" ); if (checkWalletLimit && !checkWalletLimitExcept[recipient]) require(balanceOf(recipient).add(finalAmount) <= maxWallet); _balances[recipient] = _balances[recipient].add(finalAmount); emit Transfer(sender, recipient, finalAmount); return true; } } }
Contract Security Audit
- No Contract Security Audit Submitted- Submit Audit Here
[{"inputs":[],"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":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"tokensSwapped","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"ethReceived","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"tokensIntoLiqudity","type":"uint256"}],"name":"SwapAndLiquify","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"},{"inputs":[],"name":"DEAD","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_buyLiquidityFees","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_buyMarketingFees","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_liquidityShares","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_marketingShares","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_sellLiquidityFees","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_sellMarketingFees","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_totalDistributionShares","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_totalTaxIfBuying","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_totalTaxIfSelling","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"addLiquidityETH","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"checkExcludedFromFees","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"checkMarketPair","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"checkTxLimitExcept","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"checkWalletLimit","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"checkWalletLimitExcept","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bool","name":"newValue","type":"bool"}],"name":"enableDisableWalletLimit","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"enableTrading","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"getCirculatingSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxTaxSwap","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxTxAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxWallet","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"removeLimits","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newLiquidityTax","type":"uint256"},{"internalType":"uint256","name":"newMarketingTax","type":"uint256"}],"name":"setBuyFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newLiquidityShare","type":"uint256"},{"internalType":"uint256","name":"newMarketingShare","type":"uint256"}],"name":"setDistributionSettings","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newLiquidityTax","type":"uint256"},{"internalType":"uint256","name":"newMarketingTax","type":"uint256"}],"name":"setSellFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"newValue","type":"bool"}],"name":"setSwapAndLiquifyByLimitOnly","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newAddress","type":"address"}],"name":"setTaxWallet","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newLimit","type":"uint256"}],"name":"setWalletLimit","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"holder","type":"address"},{"internalType":"bool","name":"exempt","type":"bool"}],"name":"setcheckWalletLimitExcept","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"swapAndLiquifyByLimitOnly","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"swapAndLiquifyEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tradingOpen","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"uniswapV2Pair","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"uniswapV2Router","outputs":[{"internalType":"contract IUniswapV2Router02","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"maxTxAmount_","type":"uint256"}],"name":"updateMaxTxAmount","outputs":[],"stateMutability":"nonpayable","type":"function"},{"stateMutability":"payable","type":"receive"}]
Contract Creation Code
60e0604052601160a0908152705265637572736976652046696e616e636560781b60c05260019062000032908262000445565b5060408051808201909152600381526252435360e81b60208201526002906200005c908262000445565b506003805460ff191660091790556000600a818155600b819055600f600c819055600d819055600e91909155818155601081905560119190915560125567016345785d8a000060138190556103e890620000b890601462000511565b620000c491906200053d565b6014556103e86013546014620000db919062000511565b620000e791906200053d565b6015556103e86013546002620000fe919062000511565b6200010a91906200053d565b601655620186a06013546200012091906200053d565b601755601880546001600160a01b03191673abb4b6a246ee4621c7e08845e9eb33fe5448951817905561dead608052601a805463ffffffff60a81b1916600160b81b1790553480156200017257600080fd5b506200017e3362000350565b600160066000620001976000546001600160a01b031690565b6001600160a01b03908116825260208083019390935260409182016000908120805495151560ff199687161790556018549091168152600690925280822080548416600190811790915530835290822080549093168117909255600790620002076000546001600160a01b031690565b6001600160a01b03908116825260208083019390935260409182016000908120805495151560ff199687161790556018549091168152600790925280822080548416600190811790915530835290822080549093168117909255600890620002776000546001600160a01b031690565b6001600160a01b03908116825260208083019390935260409182016000908120805495151560ff199687161790556018549091168152600890925280822080548416600190811790915530835290822080549093161790915560135490600490620002df3390565b6001600160a01b03168152602081019190915260400160002055336001600160a01b031660006001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef6013546040516200034291815260200190565b60405180910390a362000560565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b634e487b7160e01b600052604160045260246000fd5b600181811c90821680620003cb57607f821691505b602082108103620003ec57634e487b7160e01b600052602260045260246000fd5b50919050565b601f8211156200044057600081815260208120601f850160051c810160208610156200041b5750805b601f850160051c820191505b818110156200043c5782815560010162000427565b5050505b505050565b81516001600160401b03811115620004615762000461620003a0565b6200047981620004728454620003b6565b84620003f2565b602080601f831160018114620004b15760008415620004985750858301515b600019600386901b1c1916600185901b1785556200043c565b600085815260208120601f198616915b82811015620004e257888601518255948401946001909101908401620004c1565b5085821015620005015787850151600019600388901b60f8161c191681555b5050505050600190811b01905550565b80820281158282048414176200053757634e487b7160e01b600052601160045260246000fd5b92915050565b6000826200055b57634e487b7160e01b600052601260045260246000fd5b500490565b608051611ee662000583600039600081816102b501526109dc0152611ee66000f3fe6080604052600436106102975760003560e01c80638a8c523c1161015a578063da00097d116100c1578063f1d5f5171161007a578063f1d5f517146107d8578063f2fde38b146107f8578063f872858a14610818578063f8b45b0514610839578063fabf70631461084f578063ffb54a991461087f57600080fd5b8063da00097d14610713578063dd62ed3e14610734578063ea414b281461077a578063ed9953071461079a578063eea5b63f146107a2578063f0cd1dac146107c257600080fd5b8063a08e671f11610113578063a08e671f14610657578063a5d69d1f1461066d578063a9059cbb1461068d578063b2d8f208146106ad578063b6c3af34146106cd578063c78a789b146106e357600080fd5b80638a8c523c146105c35780638c0b5e22146105d85780638da5cb5b146105ee57806395d89b411461060c5780639e3fa323146106215780639fd8234e1461063757600080fd5b80634a74bb02116101fe57806362997f8c116101b757806362997f8c14610521578063661b6e361461053757806370a082311461054d578063715018a614610583578063751039fc1461059857806382eefb43146105ad57600080fd5b80634a74bb021461044a578063526012e81461046b57806355324fa91461049b578063565cec38146104cb57806357e6adcb146104e15780636256d1811461050157600080fd5b80632563ae83116102505780632563ae83146103a55780632b112e49146103c75780632df67109146103dc5780632f0a5fd4146103f2578063313ce5671461040857806349bd5a5e1461042a57600080fd5b806303fd2a45146102a357806306fdde03146102f4578063095ea7b3146103165780631694505e1461034657806318160ddd1461036657806323b872dd1461038557600080fd5b3661029e57005b600080fd5b3480156102af57600080fd5b506102d77f000000000000000000000000000000000000000000000000000000000000000081565b6040516001600160a01b0390911681526020015b60405180910390f35b34801561030057600080fd5b506103096108a0565b6040516102eb9190611b47565b34801561032257600080fd5b50610336610331366004611baa565b610932565b60405190151581526020016102eb565b34801561035257600080fd5b506019546102d7906001600160a01b031681565b34801561037257600080fd5b506013545b6040519081526020016102eb565b34801561039157600080fd5b506103366103a0366004611bd6565b610949565b3480156103b157600080fd5b506103c56103c0366004611c2c565b6109b4565b005b3480156103d357600080fd5b506103776109da565b3480156103e857600080fd5b5061037760105481565b3480156103fe57600080fd5b5061037760115481565b34801561041457600080fd5b5060035460405160ff90911681526020016102eb565b34801561043657600080fd5b50601a546102d7906001600160a01b031681565b34801561045657600080fd5b50601a5461033690600160a81b900460ff1681565b34801561047757600080fd5b50610336610486366004611c47565b60076020526000908152604090205460ff1681565b3480156104a757600080fd5b506103366104b6366004611c47565b60096020526000908152604090205460ff1681565b3480156104d757600080fd5b50610377600b5481565b3480156104ed57600080fd5b506103c56104fc366004611c64565b610a24565b34801561050d57600080fd5b506103c561051c366004611c99565b610a57565b34801561052d57600080fd5b5061037760165481565b34801561054357600080fd5b5061037760125481565b34801561055957600080fd5b50610377610568366004611c47565b6001600160a01b031660009081526004602052604090205490565b34801561058f57600080fd5b506103c5610ad8565b3480156105a457600080fd5b50610336610aec565b3480156105b957600080fd5b50610377600d5481565b3480156105cf57600080fd5b506103c5610b25565b3480156105e457600080fd5b5061037760145481565b3480156105fa57600080fd5b506000546001600160a01b03166102d7565b34801561061857600080fd5b50610309610ba2565b34801561062d57600080fd5b50610377600a5481565b34801561064357600080fd5b506103c5610652366004611cb2565b610bb1565b34801561066357600080fd5b50610377600e5481565b34801561067957600080fd5b506103c5610688366004611c2c565b610be3565b34801561069957600080fd5b506103366106a8366004611baa565b610c09565b3480156106b957600080fd5b506103c56106c8366004611cb2565b610c16565b3480156106d957600080fd5b50610377600f5481565b3480156106ef57600080fd5b506103366106fe366004611c47565b60086020526000908152604090205460ff1681565b34801561071f57600080fd5b50601a5461033690600160b01b900460ff1681565b34801561074057600080fd5b5061037761074f366004611cd4565b6001600160a01b03918216600090815260056020908152604080832093909416825291909152205490565b34801561078657600080fd5b506103c5610795366004611c47565b610c44565b6103c5610c6e565b3480156107ae57600080fd5b506103c56107bd366004611cb2565b610f3c565b3480156107ce57600080fd5b50610377600c5481565b3480156107e457600080fd5b506103c56107f3366004611c99565b610f5f565b34801561080457600080fd5b506103c5610813366004611c47565b610f6c565b34801561082457600080fd5b50601a5461033690600160b81b900460ff1681565b34801561084557600080fd5b5061037760155481565b34801561085b57600080fd5b5061033661086a366004611c47565b60066020526000908152604090205460ff1681565b34801561088b57600080fd5b50601a5461033690600160c01b900460ff1681565b6060600180546108af90611d0d565b80601f01602080910402602001604051908101604052809291908181526020018280546108db90611d0d565b80156109285780601f106108fd57610100808354040283529160200191610928565b820191906000526020600020905b81548152906001019060200180831161090b57829003601f168201915b5050505050905090565b600061093f338484610fe5565b5060015b92915050565b6000610956848484611109565b506109a984336109a485604051806060016040528060288152602001611e89602891396001600160a01b038a1660009081526005602090815260408083203384529091529020549190611678565b610fe5565b5060015b9392505050565b6109bc6116a4565b601a8054911515600160b81b0260ff60b81b19909216919091179055565b7f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316600090815260046020526040812054601354610a1f916116fe565b905090565b610a2c6116a4565b6001600160a01b03919091166000908152600760205260409020805460ff1916911515919091179055565b610a5f6116a4565b6064601354610a6e9190611d57565b811015610ad35760405162461bcd60e51b815260206004820152602860248201527f4d61782077616c6c65742073686f756c64206265206d6f7265206f7220657175604482015267616c20746f20312560c01b60648201526084015b60405180910390fd5b601455565b610ae06116a4565b610aea600061170a565b565b6000610af66116a4565b506002600c819055600d8190556000600f81905560108290556011556012556000196015819055601455600190565b610b2d6116a4565b601a54600160c01b900460ff1615610b875760405162461bcd60e51b815260206004820152601760248201527f74726164696e6720697320616c7265616479206f70656e0000000000000000006044820152606401610aca565b601a805463ff0000ff60a81b1916630100000160a81b179055565b6060600280546108af90611d0d565b610bb96116a4565b60118290556012819055610bcd828261175a565b600d81905560141015610bdf57600080fd5b5050565b610beb6116a4565b601a8054911515600160b01b0260ff60b01b19909216919091179055565b60006109a9338484611109565b610c1e6116a4565b600f8290556010819055610c32828261175a565b600c819055600a1015610bdf57600080fd5b610c4c6116a4565b601880546001600160a01b0319166001600160a01b0392909216919091179055565b610c766116a4565b601980546001600160a01b031916737a250d5630b4cf539739df2c5dacb4c659f2488d9081179091556040805163c45a015560e01b8152905163c45a0155916004808201926020929091908290030181865afa158015610cda573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610cfe9190611d79565b6001600160a01b031663c9c6539630601960009054906101000a90046001600160a01b03166001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610d60573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610d849190611d79565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303816000875af1158015610dd1573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610df59190611d79565b601a80546001600160a01b0319166001600160a01b03928316179055601954601354610e249230921690610fe5565b601a80546001600160a01b039081166000908152600960209081526040808320805460ff19908116600190811790925595548516845260079092529091208054909316179091556019541663f305d7193430610e95816001600160a01b031660009081526004602052604090205490565b600080610eaa6000546001600160a01b031690565b60405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c40160606040518083038185885af1158015610f12573d6000803e3d6000fd5b50505050506040513d601f19601f82011682018060405250810190610f379190611d96565b505050565b610f446116a4565b600a829055600b819055610f58828261175a565b600e555050565b610f676116a4565b601555565b610f746116a4565b6001600160a01b038116610fd95760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610aca565b610fe28161170a565b50565b6001600160a01b0383166110475760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610aca565b6001600160a01b0382166110a85760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610aca565b6001600160a01b0383811660008181526005602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b60006001600160a01b03841661116f5760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b6064820152608401610aca565b6001600160a01b0383166111d15760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b6064820152608401610aca565b600082116112375760405162461bcd60e51b815260206004820152602d60248201527f45524332303a207472616e7366657220616d6f756e74206d757374206772656160448201526c746572207468616e207a65726f60981b6064820152608401610aca565b601a54600160c01b900460ff168061126757506001600160a01b03841660009081526006602052604090205460ff165b8061128a57506001600160a01b03831660009081526006602052604090205460ff165b6112c45760405162461bcd60e51b815260206004820152600b60248201526a139bdd08115b98589b195960aa1b6044820152606401610aca565b601a54600160a01b900460ff16806112e65750601a54600160a81b900460ff16155b156112fd576112f6848484611766565b90506109ad565b6001600160a01b03841660009081526008602052604090205460ff1615801561133f57506001600160a01b03831660009081526008602052604090205460ff16155b156113a7576014548211156113a75760405162461bcd60e51b815260206004820152602860248201527f5472616e7366657220616d6f756e74206578636565647320746865206d6178546044820152673c20b6b7bab73a1760c11b6064820152608401610aca565b30600090815260046020526040902054601754811080159081906113d55750601a54600160a01b900460ff16155b80156113fa57506001600160a01b03861660009081526006602052604090205460ff16155b801561141e57506001600160a01b03851660009081526009602052604090205460ff165b801561142c57506017548410155b80156114415750601a54600160a81b900460ff165b1561146757601a54600160b01b900460ff161561145e5760175491505b6114678461184c565b6000806114758888886118be565b915091506000868214611488573061148a565b885b90508115611512576001600160a01b0381166000908152600460205260409020546114b5908361175a565b6001600160a01b0380831660008181526004602052604090819020939093559151908b16907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906115099086815260200190565b60405180910390a35b6040805180820182526014815273496e73756666696369656e742042616c616e636560601b6020808301919091526001600160a01b038c16600090815260049091529190912054611564918990611678565b6001600160a01b038a16600090815260046020526040902055601a54600160b81b900460ff1680156115af57506001600160a01b03881660009081526007602052604090205460ff16155b156115eb576015546115e0846115da8b6001600160a01b031660009081526004602052604090205490565b9061175a565b11156115eb57600080fd5b6001600160a01b03881660009081526004602052604090205461160e908461175a565b6001600160a01b03808a1660008181526004602052604090819020939093559151908b16907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906116629087815260200190565b60405180910390a36001955050505050506109ad565b6000818484111561169c5760405162461bcd60e51b8152600401610aca9190611b47565b505050900390565b6000546001600160a01b03163314610aea5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65726044820152606401610aca565b60006109ad8284611dc4565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b60006109ad8284611dd7565b6040805180820182526014815273496e73756666696369656e742042616c616e636560601b6020808301919091526001600160a01b03861660009081526004909152918220546117b7918490611678565b6001600160a01b0380861660009081526004602052604080822093909355908516815220546117e6908361175a565b6001600160a01b0380851660008181526004602052604090819020939093559151908616907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9061183a9086815260200190565b60405180910390a35060019392505050565b601a805460ff60a01b1916600160a01b1790553060009081526004602052604081205490506000611888836118838460165461198a565b61198a565b90506118938161199f565b60185447906118ab906001600160a01b031682611af9565b5050601a805460ff60a01b191690555050565b6001600160a01b0383166000908152600660205260408120548190839060ff16156118ed578392509050611982565b6001600160a01b03861660009081526009602052604090205460ff16156119355761192e6064611928600c5487611b2f90919063ffffffff16565b90611b3b565b9050611973565b6001600160a01b03851660009081526009602052604090205460ff1615611973576119706064611928600d5487611b2f90919063ffffffff16565b90505b61197d84826116fe565b925090505b935093915050565b600081831161199957826109ad565b50919050565b60408051600280825260608201835260009260208301908036833701905050905030816000815181106119d4576119d4611dea565b6001600160a01b03928316602091820292909201810191909152601954604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa158015611a2d573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611a519190611d79565b81600181518110611a6457611a64611dea565b6001600160a01b039283166020918202929092010152601954611a8a9130911684610fe5565b60195460405163791ac94760e01b81526001600160a01b039091169063791ac94790611ac3908590600090869030904290600401611e00565b600060405180830381600087803b158015611add57600080fd5b505af1158015611af1573d6000803e3d6000fd5b505050505050565b6040516001600160a01b0383169082156108fc029083906000818181858888f19350505050158015610f37573d6000803e3d6000fd5b60006109ad8284611e71565b60006109ad8284611d57565b600060208083528351808285015260005b81811015611b7457858101830151858201604001528201611b58565b506000604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b0381168114610fe257600080fd5b60008060408385031215611bbd57600080fd5b8235611bc881611b95565b946020939093013593505050565b600080600060608486031215611beb57600080fd5b8335611bf681611b95565b92506020840135611c0681611b95565b929592945050506040919091013590565b80358015158114611c2757600080fd5b919050565b600060208284031215611c3e57600080fd5b6109ad82611c17565b600060208284031215611c5957600080fd5b81356109ad81611b95565b60008060408385031215611c7757600080fd5b8235611c8281611b95565b9150611c9060208401611c17565b90509250929050565b600060208284031215611cab57600080fd5b5035919050565b60008060408385031215611cc557600080fd5b50508035926020909101359150565b60008060408385031215611ce757600080fd5b8235611cf281611b95565b91506020830135611d0281611b95565b809150509250929050565b600181811c90821680611d2157607f821691505b60208210810361199957634e487b7160e01b600052602260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b600082611d7457634e487b7160e01b600052601260045260246000fd5b500490565b600060208284031215611d8b57600080fd5b81516109ad81611b95565b600080600060608486031215611dab57600080fd5b8351925060208401519150604084015190509250925092565b8181038181111561094357610943611d41565b8082018082111561094357610943611d41565b634e487b7160e01b600052603260045260246000fd5b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b81811015611e505784516001600160a01b031683529383019391830191600101611e2b565b50506001600160a01b03969096166060850152505050608001529392505050565b808202811582820484141761094357610943611d4156fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a2646970667358221220f2b065c46f970dfdc34f065bbfeff2bfb9b7ad6258326ac7ac3e04a5f5ecae0664736f6c63430008130033
Deployed Bytecode
0x6080604052600436106102975760003560e01c80638a8c523c1161015a578063da00097d116100c1578063f1d5f5171161007a578063f1d5f517146107d8578063f2fde38b146107f8578063f872858a14610818578063f8b45b0514610839578063fabf70631461084f578063ffb54a991461087f57600080fd5b8063da00097d14610713578063dd62ed3e14610734578063ea414b281461077a578063ed9953071461079a578063eea5b63f146107a2578063f0cd1dac146107c257600080fd5b8063a08e671f11610113578063a08e671f14610657578063a5d69d1f1461066d578063a9059cbb1461068d578063b2d8f208146106ad578063b6c3af34146106cd578063c78a789b146106e357600080fd5b80638a8c523c146105c35780638c0b5e22146105d85780638da5cb5b146105ee57806395d89b411461060c5780639e3fa323146106215780639fd8234e1461063757600080fd5b80634a74bb02116101fe57806362997f8c116101b757806362997f8c14610521578063661b6e361461053757806370a082311461054d578063715018a614610583578063751039fc1461059857806382eefb43146105ad57600080fd5b80634a74bb021461044a578063526012e81461046b57806355324fa91461049b578063565cec38146104cb57806357e6adcb146104e15780636256d1811461050157600080fd5b80632563ae83116102505780632563ae83146103a55780632b112e49146103c75780632df67109146103dc5780632f0a5fd4146103f2578063313ce5671461040857806349bd5a5e1461042a57600080fd5b806303fd2a45146102a357806306fdde03146102f4578063095ea7b3146103165780631694505e1461034657806318160ddd1461036657806323b872dd1461038557600080fd5b3661029e57005b600080fd5b3480156102af57600080fd5b506102d77f000000000000000000000000000000000000000000000000000000000000dead81565b6040516001600160a01b0390911681526020015b60405180910390f35b34801561030057600080fd5b506103096108a0565b6040516102eb9190611b47565b34801561032257600080fd5b50610336610331366004611baa565b610932565b60405190151581526020016102eb565b34801561035257600080fd5b506019546102d7906001600160a01b031681565b34801561037257600080fd5b506013545b6040519081526020016102eb565b34801561039157600080fd5b506103366103a0366004611bd6565b610949565b3480156103b157600080fd5b506103c56103c0366004611c2c565b6109b4565b005b3480156103d357600080fd5b506103776109da565b3480156103e857600080fd5b5061037760105481565b3480156103fe57600080fd5b5061037760115481565b34801561041457600080fd5b5060035460405160ff90911681526020016102eb565b34801561043657600080fd5b50601a546102d7906001600160a01b031681565b34801561045657600080fd5b50601a5461033690600160a81b900460ff1681565b34801561047757600080fd5b50610336610486366004611c47565b60076020526000908152604090205460ff1681565b3480156104a757600080fd5b506103366104b6366004611c47565b60096020526000908152604090205460ff1681565b3480156104d757600080fd5b50610377600b5481565b3480156104ed57600080fd5b506103c56104fc366004611c64565b610a24565b34801561050d57600080fd5b506103c561051c366004611c99565b610a57565b34801561052d57600080fd5b5061037760165481565b34801561054357600080fd5b5061037760125481565b34801561055957600080fd5b50610377610568366004611c47565b6001600160a01b031660009081526004602052604090205490565b34801561058f57600080fd5b506103c5610ad8565b3480156105a457600080fd5b50610336610aec565b3480156105b957600080fd5b50610377600d5481565b3480156105cf57600080fd5b506103c5610b25565b3480156105e457600080fd5b5061037760145481565b3480156105fa57600080fd5b506000546001600160a01b03166102d7565b34801561061857600080fd5b50610309610ba2565b34801561062d57600080fd5b50610377600a5481565b34801561064357600080fd5b506103c5610652366004611cb2565b610bb1565b34801561066357600080fd5b50610377600e5481565b34801561067957600080fd5b506103c5610688366004611c2c565b610be3565b34801561069957600080fd5b506103366106a8366004611baa565b610c09565b3480156106b957600080fd5b506103c56106c8366004611cb2565b610c16565b3480156106d957600080fd5b50610377600f5481565b3480156106ef57600080fd5b506103366106fe366004611c47565b60086020526000908152604090205460ff1681565b34801561071f57600080fd5b50601a5461033690600160b01b900460ff1681565b34801561074057600080fd5b5061037761074f366004611cd4565b6001600160a01b03918216600090815260056020908152604080832093909416825291909152205490565b34801561078657600080fd5b506103c5610795366004611c47565b610c44565b6103c5610c6e565b3480156107ae57600080fd5b506103c56107bd366004611cb2565b610f3c565b3480156107ce57600080fd5b50610377600c5481565b3480156107e457600080fd5b506103c56107f3366004611c99565b610f5f565b34801561080457600080fd5b506103c5610813366004611c47565b610f6c565b34801561082457600080fd5b50601a5461033690600160b81b900460ff1681565b34801561084557600080fd5b5061037760155481565b34801561085b57600080fd5b5061033661086a366004611c47565b60066020526000908152604090205460ff1681565b34801561088b57600080fd5b50601a5461033690600160c01b900460ff1681565b6060600180546108af90611d0d565b80601f01602080910402602001604051908101604052809291908181526020018280546108db90611d0d565b80156109285780601f106108fd57610100808354040283529160200191610928565b820191906000526020600020905b81548152906001019060200180831161090b57829003601f168201915b5050505050905090565b600061093f338484610fe5565b5060015b92915050565b6000610956848484611109565b506109a984336109a485604051806060016040528060288152602001611e89602891396001600160a01b038a1660009081526005602090815260408083203384529091529020549190611678565b610fe5565b5060015b9392505050565b6109bc6116a4565b601a8054911515600160b81b0260ff60b81b19909216919091179055565b7f000000000000000000000000000000000000000000000000000000000000dead6001600160a01b0316600090815260046020526040812054601354610a1f916116fe565b905090565b610a2c6116a4565b6001600160a01b03919091166000908152600760205260409020805460ff1916911515919091179055565b610a5f6116a4565b6064601354610a6e9190611d57565b811015610ad35760405162461bcd60e51b815260206004820152602860248201527f4d61782077616c6c65742073686f756c64206265206d6f7265206f7220657175604482015267616c20746f20312560c01b60648201526084015b60405180910390fd5b601455565b610ae06116a4565b610aea600061170a565b565b6000610af66116a4565b506002600c819055600d8190556000600f81905560108290556011556012556000196015819055601455600190565b610b2d6116a4565b601a54600160c01b900460ff1615610b875760405162461bcd60e51b815260206004820152601760248201527f74726164696e6720697320616c7265616479206f70656e0000000000000000006044820152606401610aca565b601a805463ff0000ff60a81b1916630100000160a81b179055565b6060600280546108af90611d0d565b610bb96116a4565b60118290556012819055610bcd828261175a565b600d81905560141015610bdf57600080fd5b5050565b610beb6116a4565b601a8054911515600160b01b0260ff60b01b19909216919091179055565b60006109a9338484611109565b610c1e6116a4565b600f8290556010819055610c32828261175a565b600c819055600a1015610bdf57600080fd5b610c4c6116a4565b601880546001600160a01b0319166001600160a01b0392909216919091179055565b610c766116a4565b601980546001600160a01b031916737a250d5630b4cf539739df2c5dacb4c659f2488d9081179091556040805163c45a015560e01b8152905163c45a0155916004808201926020929091908290030181865afa158015610cda573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610cfe9190611d79565b6001600160a01b031663c9c6539630601960009054906101000a90046001600160a01b03166001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610d60573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610d849190611d79565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303816000875af1158015610dd1573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610df59190611d79565b601a80546001600160a01b0319166001600160a01b03928316179055601954601354610e249230921690610fe5565b601a80546001600160a01b039081166000908152600960209081526040808320805460ff19908116600190811790925595548516845260079092529091208054909316179091556019541663f305d7193430610e95816001600160a01b031660009081526004602052604090205490565b600080610eaa6000546001600160a01b031690565b60405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c40160606040518083038185885af1158015610f12573d6000803e3d6000fd5b50505050506040513d601f19601f82011682018060405250810190610f379190611d96565b505050565b610f446116a4565b600a829055600b819055610f58828261175a565b600e555050565b610f676116a4565b601555565b610f746116a4565b6001600160a01b038116610fd95760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610aca565b610fe28161170a565b50565b6001600160a01b0383166110475760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610aca565b6001600160a01b0382166110a85760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610aca565b6001600160a01b0383811660008181526005602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b60006001600160a01b03841661116f5760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b6064820152608401610aca565b6001600160a01b0383166111d15760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b6064820152608401610aca565b600082116112375760405162461bcd60e51b815260206004820152602d60248201527f45524332303a207472616e7366657220616d6f756e74206d757374206772656160448201526c746572207468616e207a65726f60981b6064820152608401610aca565b601a54600160c01b900460ff168061126757506001600160a01b03841660009081526006602052604090205460ff165b8061128a57506001600160a01b03831660009081526006602052604090205460ff165b6112c45760405162461bcd60e51b815260206004820152600b60248201526a139bdd08115b98589b195960aa1b6044820152606401610aca565b601a54600160a01b900460ff16806112e65750601a54600160a81b900460ff16155b156112fd576112f6848484611766565b90506109ad565b6001600160a01b03841660009081526008602052604090205460ff1615801561133f57506001600160a01b03831660009081526008602052604090205460ff16155b156113a7576014548211156113a75760405162461bcd60e51b815260206004820152602860248201527f5472616e7366657220616d6f756e74206578636565647320746865206d6178546044820152673c20b6b7bab73a1760c11b6064820152608401610aca565b30600090815260046020526040902054601754811080159081906113d55750601a54600160a01b900460ff16155b80156113fa57506001600160a01b03861660009081526006602052604090205460ff16155b801561141e57506001600160a01b03851660009081526009602052604090205460ff165b801561142c57506017548410155b80156114415750601a54600160a81b900460ff165b1561146757601a54600160b01b900460ff161561145e5760175491505b6114678461184c565b6000806114758888886118be565b915091506000868214611488573061148a565b885b90508115611512576001600160a01b0381166000908152600460205260409020546114b5908361175a565b6001600160a01b0380831660008181526004602052604090819020939093559151908b16907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906115099086815260200190565b60405180910390a35b6040805180820182526014815273496e73756666696369656e742042616c616e636560601b6020808301919091526001600160a01b038c16600090815260049091529190912054611564918990611678565b6001600160a01b038a16600090815260046020526040902055601a54600160b81b900460ff1680156115af57506001600160a01b03881660009081526007602052604090205460ff16155b156115eb576015546115e0846115da8b6001600160a01b031660009081526004602052604090205490565b9061175a565b11156115eb57600080fd5b6001600160a01b03881660009081526004602052604090205461160e908461175a565b6001600160a01b03808a1660008181526004602052604090819020939093559151908b16907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906116629087815260200190565b60405180910390a36001955050505050506109ad565b6000818484111561169c5760405162461bcd60e51b8152600401610aca9190611b47565b505050900390565b6000546001600160a01b03163314610aea5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65726044820152606401610aca565b60006109ad8284611dc4565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b60006109ad8284611dd7565b6040805180820182526014815273496e73756666696369656e742042616c616e636560601b6020808301919091526001600160a01b03861660009081526004909152918220546117b7918490611678565b6001600160a01b0380861660009081526004602052604080822093909355908516815220546117e6908361175a565b6001600160a01b0380851660008181526004602052604090819020939093559151908616907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9061183a9086815260200190565b60405180910390a35060019392505050565b601a805460ff60a01b1916600160a01b1790553060009081526004602052604081205490506000611888836118838460165461198a565b61198a565b90506118938161199f565b60185447906118ab906001600160a01b031682611af9565b5050601a805460ff60a01b191690555050565b6001600160a01b0383166000908152600660205260408120548190839060ff16156118ed578392509050611982565b6001600160a01b03861660009081526009602052604090205460ff16156119355761192e6064611928600c5487611b2f90919063ffffffff16565b90611b3b565b9050611973565b6001600160a01b03851660009081526009602052604090205460ff1615611973576119706064611928600d5487611b2f90919063ffffffff16565b90505b61197d84826116fe565b925090505b935093915050565b600081831161199957826109ad565b50919050565b60408051600280825260608201835260009260208301908036833701905050905030816000815181106119d4576119d4611dea565b6001600160a01b03928316602091820292909201810191909152601954604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa158015611a2d573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611a519190611d79565b81600181518110611a6457611a64611dea565b6001600160a01b039283166020918202929092010152601954611a8a9130911684610fe5565b60195460405163791ac94760e01b81526001600160a01b039091169063791ac94790611ac3908590600090869030904290600401611e00565b600060405180830381600087803b158015611add57600080fd5b505af1158015611af1573d6000803e3d6000fd5b505050505050565b6040516001600160a01b0383169082156108fc029083906000818181858888f19350505050158015610f37573d6000803e3d6000fd5b60006109ad8284611e71565b60006109ad8284611d57565b600060208083528351808285015260005b81811015611b7457858101830151858201604001528201611b58565b506000604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b0381168114610fe257600080fd5b60008060408385031215611bbd57600080fd5b8235611bc881611b95565b946020939093013593505050565b600080600060608486031215611beb57600080fd5b8335611bf681611b95565b92506020840135611c0681611b95565b929592945050506040919091013590565b80358015158114611c2757600080fd5b919050565b600060208284031215611c3e57600080fd5b6109ad82611c17565b600060208284031215611c5957600080fd5b81356109ad81611b95565b60008060408385031215611c7757600080fd5b8235611c8281611b95565b9150611c9060208401611c17565b90509250929050565b600060208284031215611cab57600080fd5b5035919050565b60008060408385031215611cc557600080fd5b50508035926020909101359150565b60008060408385031215611ce757600080fd5b8235611cf281611b95565b91506020830135611d0281611b95565b809150509250929050565b600181811c90821680611d2157607f821691505b60208210810361199957634e487b7160e01b600052602260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b600082611d7457634e487b7160e01b600052601260045260246000fd5b500490565b600060208284031215611d8b57600080fd5b81516109ad81611b95565b600080600060608486031215611dab57600080fd5b8351925060208401519150604084015190509250925092565b8181038181111561094357610943611d41565b8082018082111561094357610943611d41565b634e487b7160e01b600052603260045260246000fd5b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b81811015611e505784516001600160a01b031683529383019391830191600101611e2b565b50506001600160a01b03969096166060850152505050608001529392505050565b808202811582820484141761094357610943611d4156fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a2646970667358221220f2b065c46f970dfdc34f065bbfeff2bfb9b7ad6258326ac7ac3e04a5f5ecae0664736f6c63430008130033
Deployed Bytecode Sourcemap
21570:12720:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;22954:74;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;178:32:1;;;160:51;;148:2;133:18;22954:74:0;;;;;;;;24958:83;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;25646:186::-;;;;;;;;;;-1:-1:-1;25646:186:0;;;;;:::i;:::-;;:::i;:::-;;;1396:14:1;;1389:22;1371:41;;1359:2;1344:18;25646:186:0;1231:187:1;23037:41:0;;;;;;;;;;-1:-1:-1;23037:41:0;;;;-1:-1:-1;;;;;23037:41:0;;;25235:100;;;;;;;;;;-1:-1:-1;25315:12:0;;25235:100;;;1803:25:1;;;1791:2;1776:18;25235:100:0;1657:177:1;31331:446:0;;;;;;;;;;-1:-1:-1;31331:446:0;;;;;:::i;:::-;;:::i;28514:114::-;;;;;;;;;;-1:-1:-1;28514:114:0;;;;;:::i;:::-;;:::i;:::-;;28769:121;;;;;;;;;;;;;:::i;22409:37::-;;;;;;;;;;;;;;;;22455;;;;;;;;;;;;;;;;25144:83;;;;;;;;;;-1:-1:-1;25210:9:0;;25144:83;;25210:9;;;;2792:36:1;;2780:2;2765:18;25144:83:0;2650:184:1;23085:28:0;;;;;;;;;;-1:-1:-1;23085:28:0;;;;-1:-1:-1;;;;;23085:28:0;;;23150:41;;;;;;;;;;-1:-1:-1;23150:41:0;;;;-1:-1:-1;;;23150:41:0;;;;;;21963:54;;;;;;;;;;-1:-1:-1;21963:54:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;22081:47;;;;;;;;;;-1:-1:-1;22081:47:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;22179:36;;;;;;;;;;;;;;;;27382:166;;;;;;;;;;-1:-1:-1;27382:166:0;;;;;:::i;:::-;;:::i;28258:248::-;;;;;;;;;;-1:-1:-1;28258:248:0;;;;;:::i;:::-;;:::i;22727:53::-;;;;;;;;;;;;;;;;22499:38;;;;;;;;;;;;;;;;25343:119;;;;;;;;;;-1:-1:-1;25343:119:0;;;;;:::i;:::-;-1:-1:-1;;;;;25436:18:0;25409:7;25436:18;;;:9;:18;;;;;;;25343:119;2766:103;;;;;;;;;;;;;:::i;27889:361::-;;;;;;;;;;;;;:::i;22268:38::-;;;;;;;;;;;;;;;;26185:187;;;;;;;;;;;;;:::i;22605:55::-;;;;;;;;;;;;;;;;2118:87;;;;;;;;;;-1:-1:-1;2164:7:0;2191:6;-1:-1:-1;;;;;2191:6:0;2118:87;;25049;;;;;;;;;;;;;:::i;22137:35::-;;;;;;;;;;;;;;;;26718:337;;;;;;;;;;-1:-1:-1;26718:337:0;;;;;:::i;:::-;;:::i;22313:44::-;;;;;;;;;;;;;;;;28636:125;;;;;;;;;;-1:-1:-1;28636:125:0;;;;;:::i;:::-;;:::i;31131:192::-;;;;;;;;;;-1:-1:-1;31131:192:0;;;;;:::i;:::-;;:::i;26380:330::-;;;;;;;;;;-1:-1:-1;26380:330:0;;;;;:::i;:::-;;:::i;22366:36::-;;;;;;;;;;;;;;;;22024:50;;;;;;;;;;-1:-1:-1;22024:50:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;23198:45;;;;;;;;;;-1:-1:-1;23198:45:0;;;;-1:-1:-1;;;23198:45:0;;;;;;25470:168;;;;;;;;;;-1:-1:-1;25470:168:0;;;;;:::i;:::-;-1:-1:-1;;;;;25603:18:0;;;25576:7;25603:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;25470:168;27664:111;;;;;;;;;;-1:-1:-1;27664:111:0;;;;;:::i;:::-;;:::i;24190:760::-;;;:::i;27063:311::-;;;;;;;;;;-1:-1:-1;27063:311:0;;;;;:::i;:::-;;:::i;22224:37::-;;;;;;;;;;;;;;;;27556:100;;;;;;;;;;-1:-1:-1;27556:100:0;;;;;:::i;:::-;;:::i;3024:238::-;;;;;;;;;;-1:-1:-1;3024:238:0;;;;;:::i;:::-;;:::i;23250:35::-;;;;;;;;;;-1:-1:-1;23250:35:0;;;;-1:-1:-1;;;23250:35:0;;;;;;22667:53;;;;;;;;;;;;;;;;21903;;;;;;;;;;-1:-1:-1;21903:53:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;23292:31;;;;;;;;;;-1:-1:-1;23292:31:0;;;;-1:-1:-1;;;23292:31:0;;;;;;24958:83;24995:13;25028:5;25021:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;24958:83;:::o;25646:186::-;25746:4;25763:39;880:10;25786:7;25795:6;25763:8;:39::i;:::-;-1:-1:-1;25820:4:0;25646:186;;;;;:::o;31331:446::-;31463:4;31480:36;31490:6;31498:9;31509:6;31480:9;:36::i;:::-;-1:-1:-1;31527:220:0;31550:6;880:10;31598:138;31654:6;31598:138;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;31598:19:0;;;;;;:11;:19;;;;;;;;880:10;31598:33;;;;;;;;;;:37;:138::i;:::-;31527:8;:220::i;:::-;-1:-1:-1;31765:4:0;31331:446;;;;;;:::o;28514:114::-;2004:13;:11;:13::i;:::-;28593:16:::1;:27:::0;;;::::1;;-1:-1:-1::0;;;28593:27:0::1;-1:-1:-1::0;;;;28593:27:0;;::::1;::::0;;;::::1;::::0;;28514:114::o;28769:121::-;28876:4;-1:-1:-1;;;;;25436:18:0;28822:7;25436:18;;;:9;:18;;;;;;28849:12;;:33;;:16;:33::i;:::-;28842:40;;28769:121;:::o;27382:166::-;2004:13;:11;:13::i;:::-;-1:-1:-1;;;;;27501:30:0;;;::::1;;::::0;;;:22:::1;:30;::::0;;;;:39;;-1:-1:-1;;27501:39:0::1;::::0;::::1;;::::0;;;::::1;::::0;;27382:166::o;28258:248::-;2004:13;:11;:13::i;:::-;28390:3:::1;28375:12;;:18;;;;:::i;:::-;28359:12;:34;;28337:124;;;::::0;-1:-1:-1;;;28337:124:0;;5183:2:1;28337:124:0::1;::::0;::::1;5165:21:1::0;5222:2;5202:18;;;5195:30;5261:34;5241:18;;;5234:62;-1:-1:-1;;;5312:18:1;;;5305:38;5360:19;;28337:124:0::1;;;;;;;;;28472:11;:26:::0;28258:248::o;2766:103::-;2004:13;:11;:13::i;:::-;2831:30:::1;2858:1;2831:18;:30::i;:::-;2766:103::o:0;27889:361::-;27941:4;2004:13;:11;:13::i;:::-;-1:-1:-1;27978:1:0::1;27958:17;:21:::0;;;27990:18:::1;:22:::0;;;-1:-1:-1;28025:17:0::1;:21:::0;;;28057:17:::1;:21:::0;;;28091:18:::1;:22:::0;28124:18:::1;:22:::0;-1:-1:-1;;28159:9:0::1;:23:::0;;;28193:11:::1;:25:::0;-1:-1:-1;27889:361:0;:::o;26185:187::-;2004:13;:11;:13::i;:::-;26249:11:::1;::::0;-1:-1:-1;;;26249:11:0;::::1;;;26248:12;26240:48;;;::::0;-1:-1:-1;;;26240:48:0;;5592:2:1;26240:48:0::1;::::0;::::1;5574:21:1::0;5631:2;5611:18;;;5604:30;5670:25;5650:18;;;5643:53;5713:18;;26240:48:0::1;5390:347:1::0;26240:48:0::1;26299:11;:18:::0;;-1:-1:-1;;;;26328:28:0;-1:-1:-1;;;26328:28:0;;;26185:187::o;25049:87::-;25088:13;25121:7;25114:14;;;;;:::i;26718:337::-;2004:13;:11;:13::i;:::-;26844:18:::1;:36:::0;;;26891:18:::1;:36:::0;;;26961:42:::1;26865:15:::0;26912;26961:22:::1;:42::i;:::-;26940:18;:63:::0;;;27044:2:::1;-1:-1:-1::0;27022:24:0::1;27014:33;;;::::0;::::1;;26718:337:::0;;:::o;28636:125::-;2004:13;:11;:13::i;:::-;28717:25:::1;:36:::0;;;::::1;;-1:-1:-1::0;;;28717:36:0::1;-1:-1:-1::0;;;;28717:36:0;;::::1;::::0;;;::::1;::::0;;28636:125::o;31131:192::-;31234:4;31251:42;880:10;31275:9;31286:6;31251:9;:42::i;26380:330::-;2004:13;:11;:13::i;:::-;26505:17:::1;:35:::0;;;26551:17:::1;:35:::0;;;26619:40:::1;26525:15:::0;26571;26619:21:::1;:40::i;:::-;26599:17;:60:::0;;;26699:2:::1;-1:-1:-1::0;26678:23:0::1;26670:32;;;::::0;::::1;27664:111:::0;2004:13;:11;:13::i;:::-;27736:9:::1;:31:::0;;-1:-1:-1;;;;;;27736:31:0::1;-1:-1:-1::0;;;;;27736:31:0;;;::::1;::::0;;;::::1;::::0;;27664:111::o;24190:760::-;2004:13;:11;:13::i;:::-;24255:15:::1;:104:::0;;-1:-1:-1;;;;;;24255:104:0::1;24306:42;24255:104:::0;;::::1;::::0;;;24406:25:::1;::::0;;-1:-1:-1;;;24406:25:0;;;;:23:::1;::::0;:25:::1;::::0;;::::1;::::0;::::1;::::0;;;;;;;;;24306:42;24406:25:::1;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;-1:-1:-1::0;;;;;24388:55:0::1;;24466:4;24486:15;;;;;;;;;-1:-1:-1::0;;;;;24486:15:0::1;-1:-1:-1::0;;;;;24486:20:0::1;;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;24388:131;::::0;-1:-1:-1;;;;;;24388:131:0::1;::::0;;;;;;-1:-1:-1;;;;;6228:15:1;;;24388:131:0::1;::::0;::::1;6210:34:1::0;6280:15;;6260:18;;;6253:43;6145:18;;24388:131:0::1;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;24372:13;:147:::0;;-1:-1:-1;;;;;;24372:147:0::1;-1:-1:-1::0;;;;;24372:147:0;;::::1;;::::0;;24564:15:::1;::::0;24582:12:::1;::::0;24532:63:::1;::::0;24549:4:::1;::::0;24564:15:::1;::::0;24532:8:::1;:63::i;:::-;24632:13;::::0;;-1:-1:-1;;;;;24632:13:0;;::::1;24608:39;::::0;;;:15:::1;:39;::::0;;;;;;;:46;;-1:-1:-1;;24608:46:0;;::::1;24650:4;24608:46:::0;;::::1;::::0;;;24696:13;;;::::1;24665:46:::0;;:22:::1;:46:::0;;;;;;:53;;;;::::1;;::::0;;;24731:15:::1;::::0;::::1;:31;24770:9;24803:4;24823:24;24803:4:::0;-1:-1:-1;;;;;25436:18:0;25409:7;25436:18;;;:9;:18;;;;;;;25343:119;24823:24:::1;24862:1;24878::::0;24894:7:::1;2164::::0;2191:6;-1:-1:-1;;;;;2191:6:0;;2118:87;24894:7:::1;24731:211;::::0;::::1;::::0;;;-1:-1:-1;;;;;;24731:211:0;;;-1:-1:-1;;;;;6666:15:1;;;24731:211:0::1;::::0;::::1;6648:34:1::0;6698:18;;;6691:34;;;;6741:18;;;6734:34;;;;6784:18;;;6777:34;6848:15;;;6827:19;;;6820:44;24916:15:0::1;6880:19:1::0;;;6873:35;6582:19;;24731:211:0::1;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;24190:760::o:0;27063:311::-;2004:13;:11;:13::i;:::-;27205:16:::1;:36:::0;;;27252:16:::1;:36:::0;;;27328:38:::1;27224:17:::0;27271;27328:20:::1;:38::i;:::-;27301:24;:65:::0;-1:-1:-1;;27063:311:0:o;27556:100::-;2004:13;:11;:13::i;:::-;27628:9:::1;:20:::0;27556:100::o;3024:238::-;2004:13;:11;:13::i;:::-;-1:-1:-1;;;;;3127:22:0;::::1;3105:110;;;::::0;-1:-1:-1;;;3105:110:0;;7432:2:1;3105:110:0::1;::::0;::::1;7414:21:1::0;7471:2;7451:18;;;7444:30;7510:34;7490:18;;;7483:62;-1:-1:-1;;;7561:18:1;;;7554:36;7607:19;;3105:110:0::1;7230:402:1::0;3105:110:0::1;3226:28;3245:8;3226:18;:28::i;:::-;3024:238:::0;:::o;25840:337::-;-1:-1:-1;;;;;25933:19:0;;25925:68;;;;-1:-1:-1;;;25925:68:0;;7839:2:1;25925:68:0;;;7821:21:1;7878:2;7858:18;;;7851:30;7917:34;7897:18;;;7890:62;-1:-1:-1;;;7968:18:1;;;7961:34;8012:19;;25925:68:0;7637:400:1;25925:68:0;-1:-1:-1;;;;;26012:21:0;;26004:68;;;;-1:-1:-1;;;26004:68:0;;8244:2:1;26004:68:0;;;8226:21:1;8283:2;8263:18;;;8256:30;8322:34;8302:18;;;8295:62;-1:-1:-1;;;8373:18:1;;;8366:32;8415:19;;26004:68:0;8042:398:1;26004:68:0;-1:-1:-1;;;;;26085:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;26137:32;;1803:25:1;;;26137:32:0;;1776:18:1;26137:32:0;;;;;;;25840:337;;;:::o;31785:2502::-;31906:4;-1:-1:-1;;;;;31931:20:0;;31923:70;;;;-1:-1:-1;;;31923:70:0;;8647:2:1;31923:70:0;;;8629:21:1;8686:2;8666:18;;;8659:30;8725:34;8705:18;;;8698:62;-1:-1:-1;;;8776:18:1;;;8769:35;8821:19;;31923:70:0;8445:401:1;31923:70:0;-1:-1:-1;;;;;32012:23:0;;32004:71;;;;-1:-1:-1;;;32004:71:0;;9053:2:1;32004:71:0;;;9035:21:1;9092:2;9072:18;;;9065:30;9131:34;9111:18;;;9104:62;-1:-1:-1;;;9182:18:1;;;9175:33;9225:19;;32004:71:0;8851:399:1;32004:71:0;32103:1;32094:6;:10;32086:68;;;;-1:-1:-1;;;32086:68:0;;9457:2:1;32086:68:0;;;9439:21:1;9496:2;9476:18;;;9469:30;9535:34;9515:18;;;9508:62;-1:-1:-1;;;9586:18:1;;;9579:43;9639:19;;32086:68:0;9255:409:1;32086:68:0;32189:11;;-1:-1:-1;;;32189:11:0;;;;;:61;;-1:-1:-1;;;;;;32221:29:0;;;;;;:21;:29;;;;;;;;32189:61;:114;;;-1:-1:-1;;;;;;32271:32:0;;;;;;:21;:32;;;;;;;;32189:114;32167:175;;;;-1:-1:-1;;;32167:175:0;;9871:2:1;32167:175:0;;;9853:21:1;9910:2;9890:18;;;9883:30;-1:-1:-1;;;9929:18:1;;;9922:41;9980:18;;32167:175:0;9669:335:1;32167:175:0;32359:16;;-1:-1:-1;;;32359:16:0;;;;;:42;;-1:-1:-1;32380:21:0;;-1:-1:-1;;;32380:21:0;;;;32379:22;32359:42;32355:1925;;;32425:41;32440:6;32448:9;32459:6;32425:14;:41::i;:::-;32418:48;;;;32355:1925;-1:-1:-1;;;;;32504:26:0;;;;;;:18;:26;;;;;;;;32503:27;:61;;;;-1:-1:-1;;;;;;32535:29:0;;;;;;:18;:29;;;;;;;;32534:30;32503:61;32499:237;;;32625:11;;32615:6;:21;;32585:135;;;;-1:-1:-1;;;32585:135:0;;10211:2:1;32585:135:0;;;10193:21:1;10250:2;10230:18;;;10223:30;10289:34;10269:18;;;10262:62;-1:-1:-1;;;10340:18:1;;;10333:38;10388:19;;32585:135:0;10009:404:1;32585:135:0;32801:4;32752:28;25436:18;;;:9;:18;;;;;;32891:15;;32867:39;;;;;;;32945:61;;-1:-1:-1;32990:16:0;;-1:-1:-1;;;32990:16:0;;;;32989:17;32945:61;:112;;;;-1:-1:-1;;;;;;33028:29:0;;;;;;:21;:29;;;;;;;;33027:30;32945:112;:159;;;;-1:-1:-1;;;;;;33078:26:0;;;;;;:15;:26;;;;;;;;32945:159;:205;;;;;33135:15;;33125:6;:25;;32945:205;:247;;;;-1:-1:-1;33171:21:0;;-1:-1:-1;;;33171:21:0;;;;32945:247;32923:451;;;33231:25;;-1:-1:-1;;;33231:25:0;;;;33227:90;;;33302:15;;33279:38;;33227:90;33336:22;33351:6;33336:14;:22::i;:::-;33391:19;33412:17;33433:101;33460:6;33485:9;33513:6;33433:8;:101::i;:::-;33390:144;;;;33551:19;33586:6;33573:9;:19;:44;;33612:4;33573:44;;;33595:6;33573:44;33551:66;-1:-1:-1;33636:13:0;;33632:180;;-1:-1:-1;;;;;33695:22:0;;;;;;:9;:22;;;;;;:37;;33722:9;33695:26;:37::i;:::-;-1:-1:-1;;;;;33670:22:0;;;;;;;:9;:22;;;;;;;:62;;;;33756:40;;;;;;;;;;33786:9;1803:25:1;;1791:2;1776:18;;1657:177;33756:40:0;;;;;;;;33632:180;33848:102;;;;;;;;;;;-1:-1:-1;;;33848:102:0;;;;;;;;-1:-1:-1;;;;;33848:17:0;;-1:-1:-1;33848:17:0;;;:9;:17;;;;;;;;:102;;33888:6;;33848:21;:102::i;:::-;-1:-1:-1;;;;;33828:17:0;;;;;;:9;:17;;;;;:122;33971:16;;-1:-1:-1;;;33971:16:0;;;;:54;;;;-1:-1:-1;;;;;;33992:33:0;;;;;;:22;:33;;;;;;;;33991:34;33971:54;33967:136;;;34093:9;;34052:37;34077:11;34052:20;34062:9;-1:-1:-1;;;;;25436:18:0;25409:7;25436:18;;;:9;:18;;;;;;;25343:119;34052:20;:24;;:37::i;:::-;:50;;34044:59;;;;;;-1:-1:-1;;;;;34143:20:0;;;;;;:9;:20;;;;;;:37;;34168:11;34143:24;:37::i;:::-;-1:-1:-1;;;;;34120:20:0;;;;;;;:9;:20;;;;;;;:60;;;;34202:40;;;;;;;;;;34230:11;1803:25:1;;1791:2;1776:18;;1657:177;34202:40:0;;;;;;;;34264:4;34257:11;;;;;;;;;16364:240;16484:7;16545:12;16537:6;;;;16529:29;;;;-1:-1:-1;;;16529:29:0;;;;;;;;:::i;:::-;-1:-1:-1;;;16580:5:0;;;16364:240::o;2283:132::-;2164:7;2191:6;-1:-1:-1;;;;;2191:6:0;880:10;2347:23;2339:68;;;;-1:-1:-1;;;2339:68:0;;10620:2:1;2339:68:0;;;10602:21:1;;;10639:18;;;10632:30;10698:34;10678:18;;;10671:62;10750:18;;2339:68:0;10418:356:1;14466:98:0;14524:7;14551:5;14555:1;14551;:5;:::i;3422:191::-;3496:16;3515:6;;-1:-1:-1;;;;;3532:17:0;;;-1:-1:-1;;;;;;3532:17:0;;;;;;3565:40;;3515:6;;;;;;;3565:40;;3496:16;3565:40;3485:128;3422:191;:::o;14085:98::-;14143:7;14170:5;14174:1;14170;:5;:::i;30629:401::-;30793:90;;;;;;;;;;;-1:-1:-1;;;30793:90:0;;;;;;;;-1:-1:-1;;;;;30793:17:0;;30756:4;30793:17;;;:9;:17;;;;;;;:90;;30829:6;;30793:21;:90::i;:::-;-1:-1:-1;;;;;30773:17:0;;;;;;;:9;:17;;;;;;:110;;;;30917:20;;;;;;;:32;;30942:6;30917:24;:32::i;:::-;-1:-1:-1;;;;;30894:20:0;;;;;;;:9;:20;;;;;;;:55;;;;30965:35;;;;;;;;;;30993:6;1803:25:1;;1791:2;1776:18;;1657:177;30965:35:0;;;;;;;;-1:-1:-1;31018:4:0;30629:401;;;;;:::o;28898:392::-;23501:16;:23;;-1:-1:-1;;;;23501:23:0;-1:-1:-1;;;23501:23:0;;;29019:4:::1;-1:-1:-1::0;25436:18:0;;;:9;:18;;;;;;28970:55:::1;;29038:20;29061:51;29065:7;29074:37;29078:20;29100:10;;29074:3;:37::i;:::-;29061:3;:51::i;:::-;29038:74;;29125:30;29142:12;29125:16;:30::i;:::-;29252:9;::::0;29197:21:::1;::::0;29231:51:::1;::::0;-1:-1:-1;;;;;29252:9:0::1;29197:21:::0;29231:20:::1;:51::i;:::-;-1:-1:-1::0;;23547:16:0;:24;;-1:-1:-1;;;;23547:24:0;;;-1:-1:-1;;28898:392:0:o;29911:551::-;-1:-1:-1;;;;;30109:29:0;;30037:7;30109:29;;;:21;:29;;;;;;30037:7;;30086:6;;30109:29;;30105:61;;;30148:6;;-1:-1:-1;30156:9:0;-1:-1:-1;30140:26:0;;30105:61;-1:-1:-1;;;;;30183:23:0;;;;;;:15;:23;;;;;;;;30179:222;;;30235:38;30269:3;30235:29;30246:17;;30235:6;:10;;:29;;;;:::i;:::-;:33;;:38::i;:::-;30223:50;;30179:222;;;-1:-1:-1;;;;;30295:26:0;;;;;;:15;:26;;;;;;;;30291:110;;;30350:39;30385:3;30350:30;30361:18;;30350:6;:10;;:30;;;;:::i;:39::-;30338:51;;30291:110;30421:21;:6;30432:9;30421:10;:21::i;:::-;30413:41;-1:-1:-1;30444:9:0;-1:-1:-1;29911:551:0;;;;;;;:::o;27783:98::-;27840:7;27867:1;27865;:3;27864:9;;27872:1;27864:9;;;-1:-1:-1;27870:1:0;27783:98;-1:-1:-1;27783:98:0:o;29298:605::-;29448:16;;;29462:1;29448:16;;;;;;;;29424:21;;29448:16;;;;;;;;;;-1:-1:-1;29448:16:0;29424:40;;29493:4;29475;29480:1;29475:7;;;;;;;;:::i;:::-;-1:-1:-1;;;;;29475:23:0;;;:7;;;;;;;;;;:23;;;;29519:15;;:22;;;-1:-1:-1;;;29519:22:0;;;;:15;;;;;:20;;:22;;;;;29475:7;;29519:22;;;;;:15;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;29509:4;29514:1;29509:7;;;;;;;;:::i;:::-;-1:-1:-1;;;;;29509:32:0;;;:7;;;;;;;;;:32;29586:15;;29554:62;;29571:4;;29586:15;29604:11;29554:8;:62::i;:::-;29655:15;;:240;;-1:-1:-1;;;29655:240:0;;-1:-1:-1;;;;;29655:15:0;;;;:66;;:240;;29736:11;;29655:15;;29806:4;;29833;;29869:15;;29655:240;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;29353:550;29298:605;:::o;30470:151::-;30587:26;;-1:-1:-1;;;;;30587:18:0;;;:26;;;;;30606:6;;30587:26;;;;30606:6;30587:18;:26;;;;;;;;;;;;;;;;;;;14823:98;14881:7;14908:5;14912:1;14908;:5;:::i;15222:98::-;15280:7;15307:5;15311:1;15307;:5;:::i;222:548:1:-;334:4;363:2;392;381:9;374:21;424:6;418:13;467:6;462:2;451:9;447:18;440:34;492:1;502:140;516:6;513:1;510:13;502:140;;;611:14;;;607:23;;601:30;577:17;;;596:2;573:26;566:66;531:10;;502:140;;;506:3;691:1;686:2;677:6;666:9;662:22;658:31;651:42;761:2;754;750:7;745:2;737:6;733:15;729:29;718:9;714:45;710:54;702:62;;;;222:548;;;;:::o;775:131::-;-1:-1:-1;;;;;850:31:1;;840:42;;830:70;;896:1;893;886:12;911:315;979:6;987;1040:2;1028:9;1019:7;1015:23;1011:32;1008:52;;;1056:1;1053;1046:12;1008:52;1095:9;1082:23;1114:31;1139:5;1114:31;:::i;:::-;1164:5;1216:2;1201:18;;;;1188:32;;-1:-1:-1;;;911:315:1:o;1839:456::-;1916:6;1924;1932;1985:2;1973:9;1964:7;1960:23;1956:32;1953:52;;;2001:1;1998;1991:12;1953:52;2040:9;2027:23;2059:31;2084:5;2059:31;:::i;:::-;2109:5;-1:-1:-1;2166:2:1;2151:18;;2138:32;2179:33;2138:32;2179:33;:::i;:::-;1839:456;;2231:7;;-1:-1:-1;;;2285:2:1;2270:18;;;;2257:32;;1839:456::o;2300:160::-;2365:20;;2421:13;;2414:21;2404:32;;2394:60;;2450:1;2447;2440:12;2394:60;2300:160;;;:::o;2465:180::-;2521:6;2574:2;2562:9;2553:7;2549:23;2545:32;2542:52;;;2590:1;2587;2580:12;2542:52;2613:26;2629:9;2613:26;:::i;2839:247::-;2898:6;2951:2;2939:9;2930:7;2926:23;2922:32;2919:52;;;2967:1;2964;2957:12;2919:52;3006:9;2993:23;3025:31;3050:5;3025:31;:::i;3091:315::-;3156:6;3164;3217:2;3205:9;3196:7;3192:23;3188:32;3185:52;;;3233:1;3230;3223:12;3185:52;3272:9;3259:23;3291:31;3316:5;3291:31;:::i;:::-;3341:5;-1:-1:-1;3365:35:1;3396:2;3381:18;;3365:35;:::i;:::-;3355:45;;3091:315;;;;;:::o;3411:180::-;3470:6;3523:2;3511:9;3502:7;3498:23;3494:32;3491:52;;;3539:1;3536;3529:12;3491:52;-1:-1:-1;3562:23:1;;3411:180;-1:-1:-1;3411:180:1:o;3596:248::-;3664:6;3672;3725:2;3713:9;3704:7;3700:23;3696:32;3693:52;;;3741:1;3738;3731:12;3693:52;-1:-1:-1;;3764:23:1;;;3834:2;3819:18;;;3806:32;;-1:-1:-1;3596:248:1:o;3849:388::-;3917:6;3925;3978:2;3966:9;3957:7;3953:23;3949:32;3946:52;;;3994:1;3991;3984:12;3946:52;4033:9;4020:23;4052:31;4077:5;4052:31;:::i;:::-;4102:5;-1:-1:-1;4159:2:1;4144:18;;4131:32;4172:33;4131:32;4172:33;:::i;:::-;4224:7;4214:17;;;3849:388;;;;;:::o;4242:380::-;4321:1;4317:12;;;;4364;;;4385:61;;4439:4;4431:6;4427:17;4417:27;;4385:61;4492:2;4484:6;4481:14;4461:18;4458:38;4455:161;;4538:10;4533:3;4529:20;4526:1;4519:31;4573:4;4570:1;4563:15;4601:4;4598:1;4591:15;4627:127;4688:10;4683:3;4679:20;4676:1;4669:31;4719:4;4716:1;4709:15;4743:4;4740:1;4733:15;4759:217;4799:1;4825;4815:132;;4869:10;4864:3;4860:20;4857:1;4850:31;4904:4;4901:1;4894:15;4932:4;4929:1;4922:15;4815:132;-1:-1:-1;4961:9:1;;4759:217::o;5742:251::-;5812:6;5865:2;5853:9;5844:7;5840:23;5836:32;5833:52;;;5881:1;5878;5871:12;5833:52;5913:9;5907:16;5932:31;5957:5;5932:31;:::i;6919:306::-;7007:6;7015;7023;7076:2;7064:9;7055:7;7051:23;7047:32;7044:52;;;7092:1;7089;7082:12;7044:52;7121:9;7115:16;7105:26;;7171:2;7160:9;7156:18;7150:25;7140:35;;7215:2;7204:9;7200:18;7194:25;7184:35;;6919:306;;;;;:::o;10779:128::-;10846:9;;;10867:11;;;10864:37;;;10881:18;;:::i;10912:125::-;10977:9;;;10998:10;;;10995:36;;;11011:18;;:::i;11174:127::-;11235:10;11230:3;11226:20;11223:1;11216:31;11266:4;11263:1;11256:15;11290:4;11287:1;11280:15;11306:980;11568:4;11616:3;11605:9;11601:19;11647:6;11636:9;11629:25;11673:2;11711:6;11706:2;11695:9;11691:18;11684:34;11754:3;11749:2;11738:9;11734:18;11727:31;11778:6;11813;11807:13;11844:6;11836;11829:22;11882:3;11871:9;11867:19;11860:26;;11921:2;11913:6;11909:15;11895:29;;11942:1;11952:195;11966:6;11963:1;11960:13;11952:195;;;12031:13;;-1:-1:-1;;;;;12027:39:1;12015:52;;12122:15;;;;12087:12;;;;12063:1;11981:9;11952:195;;;-1:-1:-1;;;;;;;12203:32:1;;;;12198:2;12183:18;;12176:60;-1:-1:-1;;;12267:3:1;12252:19;12245:35;12164:3;11306:980;-1:-1:-1;;;11306:980:1:o;12291:168::-;12364:9;;;12395;;12412:15;;;12406:22;;12392:37;12382:71;;12433:18;;:::i
Swarm Source
ipfs://f2b065c46f970dfdc34f065bbfeff2bfb9b7ad6258326ac7ac3e04a5f5ecae06
Loading...
Loading
Loading...
Loading
[ Download: CSV Export ]
[ Download: CSV Export ]
A token is a representation of an on-chain or off-chain asset. The token page shows information such as price, total supply, holders, transfers and social links. Learn more about this page in our Knowledge Base.