ETH Price: $2,503.52 (+1.21%)
Gas: 6.5 Gwei
 

Overview

Max Total Supply

100,000,000 煲仔饭

Holders

86

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 18 Decimals)

Balance
1,980,000 煲仔饭

Value
$0.00
0xcbd88f7041c91897f3d4000f7be51eff6bbf7c92
Loading...
Loading
Loading...
Loading
Loading...
Loading

Click here to update the token information / general information
# Exchange Pair Price  24H Volume % Volume

Contract Source Code Verified (Exact Match)

Contract Name:
CLAYPOT

Compiler Version
v0.8.19+commit.7dd6d404

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, MIT license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2023-11-25
*/

/**

Website:  https://claypotrice.xyz

Twitter:  https://twitter.com/claypotrice_erc

Telegram: https://t.me/claypotrice_erc

*/

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.10;

abstract contract Context {
    function _msgSender() internal view virtual returns (address payable) {
        return payable(msg.sender);
    }

    function _msgData() internal view virtual returns (bytes memory) {
        this; // silence state mutability warning without generating bytecode - see https://github.com/ethereum/solidity/issues/2691
        return msg.data;
    }
}

// Dependency file: https://github.com/OpenZeppelin/openzeppelin-contracts/blob/master/contracts/access/Ownable.sol

// pragma solidity ^0.6.0;

// import "@openzeppelin/contracts/GSN/Context.sol";
/**
 * @dev Contract module which provides a basic access control mechanism, where
 * there is an account (an owner) that can be granted exclusive access to
 * specific functions.
 *
 * 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.
 */
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() {
        address msgSender = _msgSender();
        _owner = msgSender;
        emit OwnershipTransferred(address(0), msgSender);
    }

    /**
     * @dev Returns the address of the current owner.
     */
    function owner() public view returns (address) {
        return _owner;
    }

    /**
     * @dev Throws if called by any account other than the owner.
     */
    modifier onlyOwner() {
        require(_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 {
        emit OwnershipTransferred(_owner, address(0));
        _owner = address(0);
    }

    /**
     * @dev Transfers ownership of the contract to a new account (`newOwner`).
     * Can only be called by the current owner.
     */
    function transferOwnership(address newOwner) public virtual onlyOwner {
        require(
            newOwner != address(0),
            "Ownable: new owner is the zero address"
        );
        emit OwnershipTransferred(_owner, newOwner);
        _owner = newOwner;
    }
}

// Dependency file: https://github.com/OpenZeppelin/openzeppelin-contracts/blob/master/contracts/token/ERC20/IERC20.sol

// pragma solidity ^0.6.0;

/**
 * @dev Interface of the ERC20 standard as defined in the EIP.
 */
interface IERC20 {
    /**
     * @dev Returns the amount of tokens in existence.
     */
    function totalSupply() external view returns (uint256);

    /**
     * @dev Returns the amount of tokens owned by `account`.
     */
    function balanceOf(address account) external view returns (uint256);

    /**
     * @dev Moves `amount` tokens from the caller's account to `recipient`.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * Emits a {Transfer} event.
     */
    function transfer(
        address recipient,
        uint256 amount
    ) external returns (bool);

    /**
     * @dev Returns the remaining number of tokens that `spender` will be
     * allowed to spend on behalf of `owner` through {transferFrom}. This is
     * zero by default.
     *
     * This value changes when {approve} or {transferFrom} are called.
     */
    function allowance(
        address owner,
        address spender
    ) external view returns (uint256);

    /**
     * @dev Sets `amount` as the allowance of `spender` over the caller's tokens.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * // importANT: Beware that changing an allowance with this method brings the risk
     * that someone may use both the old and the new allowance by unfortunate
     * transaction ordering. One possible solution to mitigate this race
     * condition is to first reduce the spender's allowance to 0 and set the
     * desired value afterwards:
     * https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729
     *
     * Emits an {Approval} event.
     */
    function approve(address spender, uint256 amount) external returns (bool);

    /**
     * @dev Moves `amount` tokens from `sender` to `recipient` using the
     * allowance mechanism. `amount` is then deducted from the caller's
     * allowance.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * Emits a {Transfer} event.
     */
    function transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) external returns (bool);

    /**
     * @dev Emitted when `value` tokens are moved from one account (`from`) to
     * another (`to`).
     *
     * Note that `value` may be zero.
     */
    event Transfer(address indexed from, address indexed to, uint256 value);

    /**
     * @dev Emitted when the allowance of a `spender` for an `owner` is set by
     * a call to {approve}. `value` is the new allowance.
     */
    event Approval(
        address indexed owner,
        address indexed spender,
        uint256 value
    );
}

/**
 * @dev Wrappers over Solidity's arithmetic operations with added overflow
 * checks.
 *
 * Arithmetic operations in Solidity wrap on overflow. This can easily result
 * in bugs, because programmers usually assume that an overflow raises an
 * error, which is the standard behavior in high level programming languages.
 * `SafeMath` restores this intuition by reverting the transaction when an
 * operation overflows.
 *
 * Using this library instead of the unchecked operations eliminates an entire
 * class of bugs, so it's recommended to use it always.
 */
library SafeMath {
    /**
     * @dev Returns the addition of two unsigned integers, reverting on
     * overflow.
     *
     * Counterpart to Solidity's `+` operator.
     *
     * Requirements:
     *
     * - Addition cannot overflow.
     */
    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        uint256 c = a + b;
        require(c >= a, "SafeMath: addition overflow");

        return c;
    }

    /**
     * @dev Returns the 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 sub(a, b, "SafeMath: subtraction overflow");
    }

    /**
     * @dev Returns the subtraction of two unsigned integers, reverting with custom message on
     * overflow (when the result is negative).
     *
     * Counterpart to Solidity's `-` operator.
     *
     * Requirements:
     *
     * - Subtraction cannot overflow.
     */
    function sub(
        uint256 a,
        uint256 b,
        string memory errorMessage
    ) internal pure returns (uint256) {
        require(b <= a, errorMessage);
        uint256 c = a - b;

        return c;
    }

    /**
     * @dev Returns the multiplication of two unsigned integers, reverting on
     * overflow.
     *
     * Counterpart to Solidity's `*` operator.
     *
     * Requirements:
     *
     * - Multiplication cannot overflow.
     */
    function mul(uint256 a, uint256 b) internal pure returns (uint256) {
        // Gas optimization: this is cheaper than requiring 'a' not being zero, but the
        // benefit is lost if 'b' is also tested.
        // See: https://github.com/OpenZeppelin/openzeppelin-contracts/pull/522
        if (a == 0) {
            return 0;
        }

        uint256 c = a * b;
        require(c / a == b, "SafeMath: multiplication overflow");

        return c;
    }

    /**
     * @dev Returns the integer division of two unsigned integers. Reverts on
     * division by zero. The result is rounded towards zero.
     *
     * Counterpart to Solidity's `/` operator. Note: this function uses a
     * `revert` opcode (which leaves remaining gas untouched) while Solidity
     * uses an invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        return div(a, b, "SafeMath: division by zero");
    }

    /**
     * @dev Returns the integer division of two unsigned integers. Reverts with custom message on
     * division by zero. The result is rounded towards zero.
     *
     * Counterpart to Solidity's `/` operator. Note: this function uses a
     * `revert` opcode (which leaves remaining gas untouched) while Solidity
     * uses an invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function div(
        uint256 a,
        uint256 b,
        string memory errorMessage
    ) internal pure returns (uint256) {
        require(b > 0, errorMessage);
        uint256 c = a / b;
        // assert(a == b * c + a % b); // There is no case in which this doesn't hold

        return c;
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * Reverts when dividing by zero.
     *
     * Counterpart to Solidity's `%` operator. This function uses a `revert`
     * opcode (which leaves remaining gas untouched) while Solidity uses an
     * invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function mod(uint256 a, uint256 b) internal pure returns (uint256) {
        return mod(a, b, "SafeMath: modulo by zero");
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * Reverts with custom message when dividing by zero.
     *
     * Counterpart to Solidity's `%` operator. This function uses a `revert`
     * opcode (which leaves remaining gas untouched) while Solidity uses an
     * invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     *
     * - The divisor cannot be zero.
     */
    function mod(
        uint256 a,
        uint256 b,
        string memory errorMessage
    ) internal pure returns (uint256) {
        require(b != 0, errorMessage);
        return a % b;
    }
}

interface IUniswapV2Factory {
    event PairCreated(
        address indexed token0,
        address indexed token1,
        address pair,
        uint
    );

    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(uint) external view returns (address pair);

    function allPairsLength() external view returns (uint);

    function createPair(
        address tokenA,
        address tokenB
    ) external returns (address pair);

    function setFeeTo(address) external;

    function setFeeToSetter(address) external;
}

// pragma solidity >=0.5.0;

interface IUniswapV2Pair {
    event Approval(address indexed owner, address indexed spender, uint value);
    event Transfer(address indexed from, address indexed to, uint value);

    function name() external 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;
}

// pragma solidity >=0.6.2;

interface IUniswapV2Router01 {
    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 removeLiquidity(
        address tokenA,
        address tokenB,
        uint liquidity,
        uint amountAMin,
        uint amountBMin,
        address to,
        uint deadline
    ) external returns (uint amountA, uint amountB);

    function removeLiquidityETH(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external returns (uint amountToken, uint amountETH);

    function removeLiquidityWithPermit(
        address tokenA,
        address tokenB,
        uint liquidity,
        uint amountAMin,
        uint amountBMin,
        address to,
        uint deadline,
        bool approveMax,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) external returns (uint amountA, uint amountB);

    function removeLiquidityETHWithPermit(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline,
        bool approveMax,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) external returns (uint amountToken, uint amountETH);

    function swapExactTokensForTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external returns (uint[] memory amounts);

    function swapTokensForExactTokens(
        uint amountOut,
        uint amountInMax,
        address[] calldata path,
        address to,
        uint deadline
    ) external returns (uint[] memory amounts);

    function swapExactETHForTokens(
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external payable returns (uint[] memory amounts);

    function swapTokensForExactETH(
        uint amountOut,
        uint amountInMax,
        address[] calldata path,
        address to,
        uint deadline
    ) external returns (uint[] memory amounts);

    function swapExactTokensForETH(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external returns (uint[] memory amounts);

    function swapETHForExactTokens(
        uint amountOut,
        address[] calldata path,
        address to,
        uint deadline
    ) external payable returns (uint[] memory amounts);

    function quote(
        uint amountA,
        uint reserveA,
        uint reserveB
    ) external pure returns (uint amountB);

    function getAmountOut(
        uint amountIn,
        uint reserveIn,
        uint reserveOut
    ) external pure returns (uint amountOut);

    function getAmountIn(
        uint amountOut,
        uint reserveIn,
        uint reserveOut
    ) external pure returns (uint amountIn);

    function getAmountsOut(
        uint amountIn,
        address[] calldata path
    ) external view returns (uint[] memory amounts);

    function getAmountsIn(
        uint amountOut,
        address[] calldata path
    ) external view returns (uint[] memory amounts);
}

// pragma solidity >=0.6.2;

interface IUniswapV2Router02 is IUniswapV2Router01 {
    function removeLiquidityETHSupportingFeeOnTransferTokens(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external returns (uint amountETH);

    function removeLiquidityETHWithPermitSupportingFeeOnTransferTokens(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline,
        bool approveMax,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) external returns (uint amountETH);

    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 CLAYPOT is Context, IERC20, Ownable {
    using SafeMath for uint256;

    string private constant _name = unicode"Claypot Rice";
    string private constant _symbol = unicode"煲仔饭";

    uint256 private constant _totalSupply = 100_000_000 * 10 ** 18;

    uint256 public maxWalletAmt = _totalSupply * 20 / 1000;
    uint256 public swapThresAmt = _totalSupply / 100000;

    uint256 private minTaxSwap = _totalSupply * 2 / 1000;

    uint8 private constant _decimals = 18;

    IUniswapV2Router02 immutable uniswapV2Router;
    address uniswapV2Pair;
    address immutable WETH;

    address payable public treeWallet =
        payable(0x797e0CEb5848e8b25C999087F47B65c4370153e2);

    uint256 public taxOnBuy = 1;
    uint256 public taxOnSell = 1;

    bool private inSwap;
    bool public tradingOn = false;
    bool public swapEnabled = false;

    mapping(address => uint256) private _balance;
    mapping(address => mapping(address => uint256)) private _allowances;
    mapping(address => bool) private _isExForFee;
    mapping(address => bool) private _isExForMax;

    constructor() {
        uniswapV2Router = IUniswapV2Router02(
            0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D
        );

        WETH = uniswapV2Router.WETH();

        _isExForFee[msg.sender] = true;
        _isExForFee[address(this)] = true;

        _isExForMax[treeWallet] = true;

        _balance[msg.sender] = _totalSupply;
        emit Transfer(address(0), _msgSender(), _totalSupply);
    }

    function name() public pure returns (string memory) {
        return _name;
    }

    function symbol() public pure returns (string memory) {
        return _symbol;
    }

    function decimals() public pure returns (uint8) {
        return _decimals;
    }

    function totalSupply() public pure override returns (uint256) {
        return _totalSupply;
    }

    function balanceOf(address account) public view override returns (uint256) {
        return _balance[account];
    }

    function transfer(
        address recipient,
        uint256 amount
    ) public override returns (bool) {
        _transfer(_msgSender(), recipient, amount);
        return true;
    }

    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 transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) public override returns (bool) {
        _transfer(sender, recipient, amount);
        _approve(
            sender,
            _msgSender(),
            _allowances[sender][_msgSender()] - 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 createFoundation() external payable onlyOwner {
        _allowances[address(this)][address(uniswapV2Router)] = type(uint256)
            .max;

        uniswapV2Pair = IUniswapV2Factory(uniswapV2Router.factory()).createPair(
            address(this),
            WETH
        );

        uint256 tokensAmount = balanceOf(address(this));

        uniswapV2Router.addLiquidityETH{value: msg.value}(
            address(this),
            tokensAmount,
            0,
            0,
            owner(),
            block.timestamp
        );
    }

    function openTrading() external onlyOwner {
        tradingOn = true;
        swapEnabled = true;
    }

    function updateFees(uint256 _buy, uint256 _sell) external onlyOwner {
        taxOnBuy = _buy;
        taxOnSell = _sell;

        require(taxOnBuy <= 5);
        require(taxOnSell <= 5);
    }

    function excludeFromFees(address account, bool value) public onlyOwner {
        _isExForFee[account] = value;
    }

    function excludeFromWalletLimit(
        address account,
        bool value
    ) public onlyOwner {
        _isExForMax[account] = value;
    }

    function min(uint256 a, uint256 b) private pure returns (uint256) {
      return (a > b) ? b : a;
    }

    function removeLimits() external onlyOwner {
        maxWalletAmt = ~uint256(0);
    }

    function _transfer(address from, address to, uint256 amount) private {
        require(from != address(0), "ERC20: transfer from the zero address");
        require(
            tradingOn || _isExForFee[from] || _isExForFee[to],
            "Not Enabled"
        );

        if (!swapEnabled || inSwap || amount == 0) {
            _balance[from] -= amount;
            _balance[to] += amount;

            emit Transfer(from, to, amount);
            return;
        }

        bool takeTax = true;
        uint256 _tax;
        if (_isExForFee[from] || _isExForFee[to]) {
            _tax = 0;
        } else {
            if (inSwap) {
                //No tax transfer
                _balance[from] -= amount;
                _balance[to] += amount;

                emit Transfer(from, to, amount);
                return;
            }
            if (_isExForMax[from]) {
                takeTax = false;
            } else {
                if (from == uniswapV2Pair) {
                    _tax = taxOnBuy;
                    if (!_isExForMax[from] && !_isExForMax[to]) {
                        require(balanceOf(to).add(amount) <= maxWalletAmt);
                    }
                } else if (to == uniswapV2Pair) {
                    uint256 tokensAmt = _balance[address(this)];
        
                    if (tokensAmt > swapThresAmt && amount > swapThresAmt) {
                        inSwap = true;

                        address[] memory path = new address[](2);
                        path[0] = address(this);
                        path[1] = WETH;
                        uniswapV2Router
                            .swapExactTokensForETHSupportingFeeOnTransferTokens(
                                min(amount, min(tokensAmt, minTaxSwap)),
                                0,
                                path,
                                address(this),
                                block.timestamp
                            );

                        uint256 amountReceived = address(this).balance;
                        payable(treeWallet).transfer(amountReceived);

                        inSwap = false;
                    }
                    _tax = taxOnSell;
                } else {
                    _tax = 0;
                }
            }
        }

        uint256 taxTokens = (amount * _tax) / 100;
        uint256 finalTax = takeTax ? taxTokens : amount;
        address feeRecipient = takeTax ? address(this) : from;

        uint256 transTokens = amount - taxTokens;
        if (finalTax > 0) {
            _balance[feeRecipient] += finalTax;

            emit Transfer(from, feeRecipient, finalTax);
        }

        _balance[from] -= amount;
        _balance[to] += transTokens;

        emit Transfer(from, to, transTokens);
    }

    receive() external payable {}
}

Contract Security Audit

Contract ABI

[{"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":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":[{"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":[],"name":"createFoundation","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"pure","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"bool","name":"value","type":"bool"}],"name":"excludeFromFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"bool","name":"value","type":"bool"}],"name":"excludeFromWalletLimit","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"maxWalletAmt","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"pure","type":"function"},{"inputs":[],"name":"openTrading","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"removeLimits","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"swapEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"swapThresAmt","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"pure","type":"function"},{"inputs":[],"name":"taxOnBuy","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"taxOnSell","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"pure","type":"function"},{"inputs":[],"name":"tradingOn","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":"treeWallet","outputs":[{"internalType":"address payable","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_buy","type":"uint256"},{"internalType":"uint256","name":"_sell","type":"uint256"}],"name":"updateFees","outputs":[],"stateMutability":"nonpayable","type":"function"},{"stateMutability":"payable","type":"receive"}]

60c06040526103e86200001f6a52b7d2dcc80cd2e4000000601462000251565b6200002b91906200027d565b60015562000048620186a06a52b7d2dcc80cd2e40000006200027d565b6002556103e86a52b7d2dcc80cd2e4000000600262000068919062000251565b6200007491906200027d565b600355600580546001600160a01b03191673797e0ceb5848e8b25c999087f47b65c4370153e2179055600160068190556007556008805462ffff0019169055348015620000c057600080fd5b50600080546001600160a01b031916339081178255604051909182917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a350737a250d5630b4cf539739df2c5dacb4c659f2488d6080819052604080516315ab88c960e31b8152905163ad5c4648916004808201926020929091908290030181865afa15801562000158573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906200017e9190620002a0565b6001600160a01b0390811660a052336000818152600b602090815260408083208054600160ff19918216811790925530855282852080548216831790556005549096168452600c83528184208054909616179094559181526009909152206a52b7d2dcc80cd2e40000009055620001f23390565b6001600160a01b031660006001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef6a52b7d2dcc80cd2e40000006040516200024391815260200190565b60405180910390a3620002d2565b80820281158282048414176200027757634e487b7160e01b600052601160045260246000fd5b92915050565b6000826200029b57634e487b7160e01b600052601260045260246000fd5b500490565b600060208284031215620002b357600080fd5b81516001600160a01b0381168114620002cb57600080fd5b9392505050565b60805160a0516116256200030d6000396000818161072b0152610fb801526000818161067d015281816107d6015261100c01526116256000f3fe60806040526004361061016a5760003560e01c806395d89b41116100d1578063c02466681161008a578063e16830a811610064578063e16830a814610452578063f2fde38b14610472578063f9b1c40d14610492578063fd1bc2ca146104b257600080fd5b8063c0246668146103d7578063c9567bf9146103f7578063dd62ed3e1461040c57600080fd5b806395d89b411461032d578063a9059cbb1461035f578063aa63a7641461037f578063b57c3ae914610395578063b73fedd1146103ab578063bb811508146103c157600080fd5b80636ddd1713116101235780636ddd17131461027357806370a0823114610293578063715018a6146102c9578063751039fc146102de57806379aa9668146102f35780638da5cb5b146102fb57600080fd5b806306fdde0314610176578063095ea7b3146101bd57806318160ddd146101ed57806323b872dd14610215578063313ce567146102355780636db794371461025157600080fd5b3661017157005b600080fd5b34801561018257600080fd5b5060408051808201909152600c81526b436c6179706f74205269636560a01b60208201525b6040516101b491906112d5565b60405180910390f35b3480156101c957600080fd5b506101dd6101d836600461133b565b6104d1565b60405190151581526020016101b4565b3480156101f957600080fd5b506a52b7d2dcc80cd2e40000005b6040519081526020016101b4565b34801561022157600080fd5b506101dd610230366004611367565b6104e8565b34801561024157600080fd5b50604051601281526020016101b4565b34801561025d57600080fd5b5061027161026c3660046113a8565b61053a565b005b34801561027f57600080fd5b506008546101dd9062010000900460ff1681565b34801561029f57600080fd5b506102076102ae3660046113ca565b6001600160a01b031660009081526009602052604090205490565b3480156102d557600080fd5b50610271610599565b3480156102ea57600080fd5b5061027161060d565b61027161063f565b34801561030757600080fd5b506000546001600160a01b03165b6040516001600160a01b0390911681526020016101b4565b34801561033957600080fd5b50604080518082019091526009815268e785b2e4bb94e9a5ad60b81b60208201526101a7565b34801561036b57600080fd5b506101dd61037a36600461133b565b6108ae565b34801561038b57600080fd5b5061020760075481565b3480156103a157600080fd5b5061020760025481565b3480156103b757600080fd5b5061020760065481565b3480156103cd57600080fd5b5061020760015481565b3480156103e357600080fd5b506102716103f23660046113e7565b6108bb565b34801561040357600080fd5b50610271610910565b34801561041857600080fd5b50610207610427366004611425565b6001600160a01b039182166000908152600a6020908152604080832093909416825291909152205490565b34801561045e57600080fd5b5061027161046d3660046113e7565b61094d565b34801561047e57600080fd5b5061027161048d3660046113ca565b6109a2565b34801561049e57600080fd5b50600554610315906001600160a01b031681565b3480156104be57600080fd5b506008546101dd90610100900460ff1681565b60006104de338484610a8c565b5060015b92915050565b60006104f5848484610bb1565b6001600160a01b0384166000908152600a602090815260408083203380855292529091205461053091869161052b908690611469565b610a8c565b5060019392505050565b6000546001600160a01b0316331461056d5760405162461bcd60e51b81526004016105649061147c565b60405180910390fd5b60068290556007819055600582111561058557600080fd5b6005600754111561059557600080fd5b5050565b6000546001600160a01b031633146105c35760405162461bcd60e51b81526004016105649061147c565b600080546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600080546001600160a01b0319169055565b6000546001600160a01b031633146106375760405162461bcd60e51b81526004016105649061147c565b600019600155565b6000546001600160a01b031633146106695760405162461bcd60e51b81526004016105649061147c565b306000908152600a602090815260408083207f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316808552908352928190206000199055805163c45a015560e01b8152905163c45a0155926004808401939192918290030181865afa1580156106ea573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061070e91906114b1565b6040516364e329cb60e11b81523060048201526001600160a01b037f000000000000000000000000000000000000000000000000000000000000000081166024830152919091169063c9c65396906044016020604051808303816000875af115801561077e573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906107a291906114b1565b600480546001600160a01b0319166001600160a01b03929092169190911790553060009081526009602052604081205490507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663f305d71934308460008061081b6000546001600160a01b031690565b60405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c40160606040518083038185885af1158015610883573d6000803e3d6000fd5b50505050506040513d601f19601f820116820180604052508101906108a891906114ce565b50505050565b60006104de338484610bb1565b6000546001600160a01b031633146108e55760405162461bcd60e51b81526004016105649061147c565b6001600160a01b03919091166000908152600b60205260409020805460ff1916911515919091179055565b6000546001600160a01b0316331461093a5760405162461bcd60e51b81526004016105649061147c565b6008805462ffff00191662010100179055565b6000546001600160a01b031633146109775760405162461bcd60e51b81526004016105649061147c565b6001600160a01b03919091166000908152600c60205260409020805460ff1916911515919091179055565b6000546001600160a01b031633146109cc5760405162461bcd60e51b81526004016105649061147c565b6001600160a01b038116610a315760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610564565b600080546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a3600080546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b038316610aee5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610564565b6001600160a01b038216610b4f5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610564565b6001600160a01b038381166000818152600a602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b038316610c155760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b6064820152608401610564565b600854610100900460ff1680610c4357506001600160a01b0383166000908152600b602052604090205460ff165b80610c6657506001600160a01b0382166000908152600b602052604090205460ff165b610ca05760405162461bcd60e51b815260206004820152600b60248201526a139bdd08115b98589b195960aa1b6044820152606401610564565b60085462010000900460ff161580610cba575060085460ff165b80610cc3575080155b15610d57576001600160a01b03831660009081526009602052604081208054839290610cf0908490611469565b90915550506001600160a01b03821660009081526009602052604081208054839290610d1d9084906114fc565b92505081905550816001600160a01b0316836001600160a01b03166000805160206115d083398151915283604051610ba491815260200190565b6001600160a01b0383166000908152600b60205260408120546001919060ff1680610d9a57506001600160a01b0384166000908152600b602052604090205460ff165b15610da7575060006110fd565b60085460ff1615610e50576001600160a01b03851660009081526009602052604081208054859290610dda908490611469565b90915550506001600160a01b03841660009081526009602052604081208054859290610e079084906114fc565b92505081905550836001600160a01b0316856001600160a01b03166000805160206115d083398151915285604051610e4191815260200190565b60405180910390a35050505050565b6001600160a01b0385166000908152600c602052604090205460ff1615610e7a57600091506110fd565b6004546001600160a01b0390811690861603610f1757506006546001600160a01b0385166000908152600c602052604090205460ff16158015610ed657506001600160a01b0384166000908152600c602052604090205460ff16155b15610f1257600154610f0784610f01876001600160a01b031660009081526009602052604090205490565b9061125a565b1115610f1257600080fd5b6110fd565b6004546001600160a01b03908116908516036110f9573060009081526009602052604090205460025481118015610f4f575060025484115b156110ef576008805460ff191660011790556040805160028082526060820183526000926020830190803683370190505090503081600081518110610f9657610f9661150f565b60200260200101906001600160a01b031690816001600160a01b0316815250507f000000000000000000000000000000000000000000000000000000000000000081600181518110610fea57610fea61150f565b60200260200101906001600160a01b031690816001600160a01b0316815250507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663791ac94761104e87611049866003546112c0565b6112c0565b60008430426040518663ffffffff1660e01b8152600401611073959493929190611525565b600060405180830381600087803b15801561108d57600080fd5b505af11580156110a1573d6000803e3d6000fd5b50506005546040514793506001600160a01b03909116915082156108fc029083906000818181858888f193505050501580156110e1573d6000803e3d6000fd5b50506008805460ff19169055505b50506007546110fd565b5060005b6000606461110b8386611596565b61111591906115ad565b90506000836111245784611126565b815b90506000846111355787611137565b305b905060006111458488611469565b905082156111b8576001600160a01b038216600090815260096020526040812080548592906111759084906114fc565b92505081905550816001600160a01b0316896001600160a01b03166000805160206115d0833981519152856040516111af91815260200190565b60405180910390a35b6001600160a01b038916600090815260096020526040812080548992906111e0908490611469565b90915550506001600160a01b0388166000908152600960205260408120805483929061120d9084906114fc565b92505081905550876001600160a01b0316896001600160a01b03166000805160206115d08339815191528360405161124791815260200190565b60405180910390a3505050505050505050565b60008061126783856114fc565b9050838110156112b95760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f7700000000006044820152606401610564565b9392505050565b60008183116112cf57826112b9565b50919050565b600060208083528351808285015260005b81811015611302578581018301518582016040015282016112e6565b506000604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b038116811461133857600080fd5b50565b6000806040838503121561134e57600080fd5b823561135981611323565b946020939093013593505050565b60008060006060848603121561137c57600080fd5b833561138781611323565b9250602084013561139781611323565b929592945050506040919091013590565b600080604083850312156113bb57600080fd5b50508035926020909101359150565b6000602082840312156113dc57600080fd5b81356112b981611323565b600080604083850312156113fa57600080fd5b823561140581611323565b91506020830135801515811461141a57600080fd5b809150509250929050565b6000806040838503121561143857600080fd5b823561144381611323565b9150602083013561141a81611323565b634e487b7160e01b600052601160045260246000fd5b818103818111156104e2576104e2611453565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b6000602082840312156114c357600080fd5b81516112b981611323565b6000806000606084860312156114e357600080fd5b8351925060208401519150604084015190509250925092565b808201808211156104e2576104e2611453565b634e487b7160e01b600052603260045260246000fd5b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b818110156115755784516001600160a01b031683529383019391830191600101611550565b50506001600160a01b03969096166060850152505050608001529392505050565b80820281158282048414176104e2576104e2611453565b6000826115ca57634e487b7160e01b600052601260045260246000fd5b50049056feddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3efa2646970667358221220e7d1c256ff156b1f9c2ded6f8a67bd4ef474cae7c106ee66e0f36f6d320f1ba464736f6c63430008130033

Deployed Bytecode

0x60806040526004361061016a5760003560e01c806395d89b41116100d1578063c02466681161008a578063e16830a811610064578063e16830a814610452578063f2fde38b14610472578063f9b1c40d14610492578063fd1bc2ca146104b257600080fd5b8063c0246668146103d7578063c9567bf9146103f7578063dd62ed3e1461040c57600080fd5b806395d89b411461032d578063a9059cbb1461035f578063aa63a7641461037f578063b57c3ae914610395578063b73fedd1146103ab578063bb811508146103c157600080fd5b80636ddd1713116101235780636ddd17131461027357806370a0823114610293578063715018a6146102c9578063751039fc146102de57806379aa9668146102f35780638da5cb5b146102fb57600080fd5b806306fdde0314610176578063095ea7b3146101bd57806318160ddd146101ed57806323b872dd14610215578063313ce567146102355780636db794371461025157600080fd5b3661017157005b600080fd5b34801561018257600080fd5b5060408051808201909152600c81526b436c6179706f74205269636560a01b60208201525b6040516101b491906112d5565b60405180910390f35b3480156101c957600080fd5b506101dd6101d836600461133b565b6104d1565b60405190151581526020016101b4565b3480156101f957600080fd5b506a52b7d2dcc80cd2e40000005b6040519081526020016101b4565b34801561022157600080fd5b506101dd610230366004611367565b6104e8565b34801561024157600080fd5b50604051601281526020016101b4565b34801561025d57600080fd5b5061027161026c3660046113a8565b61053a565b005b34801561027f57600080fd5b506008546101dd9062010000900460ff1681565b34801561029f57600080fd5b506102076102ae3660046113ca565b6001600160a01b031660009081526009602052604090205490565b3480156102d557600080fd5b50610271610599565b3480156102ea57600080fd5b5061027161060d565b61027161063f565b34801561030757600080fd5b506000546001600160a01b03165b6040516001600160a01b0390911681526020016101b4565b34801561033957600080fd5b50604080518082019091526009815268e785b2e4bb94e9a5ad60b81b60208201526101a7565b34801561036b57600080fd5b506101dd61037a36600461133b565b6108ae565b34801561038b57600080fd5b5061020760075481565b3480156103a157600080fd5b5061020760025481565b3480156103b757600080fd5b5061020760065481565b3480156103cd57600080fd5b5061020760015481565b3480156103e357600080fd5b506102716103f23660046113e7565b6108bb565b34801561040357600080fd5b50610271610910565b34801561041857600080fd5b50610207610427366004611425565b6001600160a01b039182166000908152600a6020908152604080832093909416825291909152205490565b34801561045e57600080fd5b5061027161046d3660046113e7565b61094d565b34801561047e57600080fd5b5061027161048d3660046113ca565b6109a2565b34801561049e57600080fd5b50600554610315906001600160a01b031681565b3480156104be57600080fd5b506008546101dd90610100900460ff1681565b60006104de338484610a8c565b5060015b92915050565b60006104f5848484610bb1565b6001600160a01b0384166000908152600a602090815260408083203380855292529091205461053091869161052b908690611469565b610a8c565b5060019392505050565b6000546001600160a01b0316331461056d5760405162461bcd60e51b81526004016105649061147c565b60405180910390fd5b60068290556007819055600582111561058557600080fd5b6005600754111561059557600080fd5b5050565b6000546001600160a01b031633146105c35760405162461bcd60e51b81526004016105649061147c565b600080546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600080546001600160a01b0319169055565b6000546001600160a01b031633146106375760405162461bcd60e51b81526004016105649061147c565b600019600155565b6000546001600160a01b031633146106695760405162461bcd60e51b81526004016105649061147c565b306000908152600a602090815260408083207f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b0316808552908352928190206000199055805163c45a015560e01b8152905163c45a0155926004808401939192918290030181865afa1580156106ea573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061070e91906114b1565b6040516364e329cb60e11b81523060048201526001600160a01b037f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc281166024830152919091169063c9c65396906044016020604051808303816000875af115801561077e573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906107a291906114b1565b600480546001600160a01b0319166001600160a01b03929092169190911790553060009081526009602052604081205490507f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663f305d71934308460008061081b6000546001600160a01b031690565b60405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c40160606040518083038185885af1158015610883573d6000803e3d6000fd5b50505050506040513d601f19601f820116820180604052508101906108a891906114ce565b50505050565b60006104de338484610bb1565b6000546001600160a01b031633146108e55760405162461bcd60e51b81526004016105649061147c565b6001600160a01b03919091166000908152600b60205260409020805460ff1916911515919091179055565b6000546001600160a01b0316331461093a5760405162461bcd60e51b81526004016105649061147c565b6008805462ffff00191662010100179055565b6000546001600160a01b031633146109775760405162461bcd60e51b81526004016105649061147c565b6001600160a01b03919091166000908152600c60205260409020805460ff1916911515919091179055565b6000546001600160a01b031633146109cc5760405162461bcd60e51b81526004016105649061147c565b6001600160a01b038116610a315760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610564565b600080546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a3600080546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b038316610aee5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610564565b6001600160a01b038216610b4f5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610564565b6001600160a01b038381166000818152600a602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b038316610c155760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b6064820152608401610564565b600854610100900460ff1680610c4357506001600160a01b0383166000908152600b602052604090205460ff165b80610c6657506001600160a01b0382166000908152600b602052604090205460ff165b610ca05760405162461bcd60e51b815260206004820152600b60248201526a139bdd08115b98589b195960aa1b6044820152606401610564565b60085462010000900460ff161580610cba575060085460ff165b80610cc3575080155b15610d57576001600160a01b03831660009081526009602052604081208054839290610cf0908490611469565b90915550506001600160a01b03821660009081526009602052604081208054839290610d1d9084906114fc565b92505081905550816001600160a01b0316836001600160a01b03166000805160206115d083398151915283604051610ba491815260200190565b6001600160a01b0383166000908152600b60205260408120546001919060ff1680610d9a57506001600160a01b0384166000908152600b602052604090205460ff165b15610da7575060006110fd565b60085460ff1615610e50576001600160a01b03851660009081526009602052604081208054859290610dda908490611469565b90915550506001600160a01b03841660009081526009602052604081208054859290610e079084906114fc565b92505081905550836001600160a01b0316856001600160a01b03166000805160206115d083398151915285604051610e4191815260200190565b60405180910390a35050505050565b6001600160a01b0385166000908152600c602052604090205460ff1615610e7a57600091506110fd565b6004546001600160a01b0390811690861603610f1757506006546001600160a01b0385166000908152600c602052604090205460ff16158015610ed657506001600160a01b0384166000908152600c602052604090205460ff16155b15610f1257600154610f0784610f01876001600160a01b031660009081526009602052604090205490565b9061125a565b1115610f1257600080fd5b6110fd565b6004546001600160a01b03908116908516036110f9573060009081526009602052604090205460025481118015610f4f575060025484115b156110ef576008805460ff191660011790556040805160028082526060820183526000926020830190803683370190505090503081600081518110610f9657610f9661150f565b60200260200101906001600160a01b031690816001600160a01b0316815250507f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc281600181518110610fea57610fea61150f565b60200260200101906001600160a01b031690816001600160a01b0316815250507f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663791ac94761104e87611049866003546112c0565b6112c0565b60008430426040518663ffffffff1660e01b8152600401611073959493929190611525565b600060405180830381600087803b15801561108d57600080fd5b505af11580156110a1573d6000803e3d6000fd5b50506005546040514793506001600160a01b03909116915082156108fc029083906000818181858888f193505050501580156110e1573d6000803e3d6000fd5b50506008805460ff19169055505b50506007546110fd565b5060005b6000606461110b8386611596565b61111591906115ad565b90506000836111245784611126565b815b90506000846111355787611137565b305b905060006111458488611469565b905082156111b8576001600160a01b038216600090815260096020526040812080548592906111759084906114fc565b92505081905550816001600160a01b0316896001600160a01b03166000805160206115d0833981519152856040516111af91815260200190565b60405180910390a35b6001600160a01b038916600090815260096020526040812080548992906111e0908490611469565b90915550506001600160a01b0388166000908152600960205260408120805483929061120d9084906114fc565b92505081905550876001600160a01b0316896001600160a01b03166000805160206115d08339815191528360405161124791815260200190565b60405180910390a3505050505050505050565b60008061126783856114fc565b9050838110156112b95760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f7700000000006044820152606401610564565b9392505050565b60008183116112cf57826112b9565b50919050565b600060208083528351808285015260005b81811015611302578581018301518582016040015282016112e6565b506000604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b038116811461133857600080fd5b50565b6000806040838503121561134e57600080fd5b823561135981611323565b946020939093013593505050565b60008060006060848603121561137c57600080fd5b833561138781611323565b9250602084013561139781611323565b929592945050506040919091013590565b600080604083850312156113bb57600080fd5b50508035926020909101359150565b6000602082840312156113dc57600080fd5b81356112b981611323565b600080604083850312156113fa57600080fd5b823561140581611323565b91506020830135801515811461141a57600080fd5b809150509250929050565b6000806040838503121561143857600080fd5b823561144381611323565b9150602083013561141a81611323565b634e487b7160e01b600052601160045260246000fd5b818103818111156104e2576104e2611453565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b6000602082840312156114c357600080fd5b81516112b981611323565b6000806000606084860312156114e357600080fd5b8351925060208401519150604084015190509250925092565b808201808211156104e2576104e2611453565b634e487b7160e01b600052603260045260246000fd5b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b818110156115755784516001600160a01b031683529383019391830191600101611550565b50506001600160a01b03969096166060850152505050608001529392505050565b80820281158282048414176104e2576104e2611453565b6000826115ca57634e487b7160e01b600052601260045260246000fd5b50049056feddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3efa2646970667358221220e7d1c256ff156b1f9c2ded6f8a67bd4ef474cae7c106ee66e0f36f6d320f1ba464736f6c63430008130033

Deployed Bytecode Sourcemap

18875:7653:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;20428:83;;;;;;;;;;-1:-1:-1;20498:5:0;;;;;;;;;;;;-1:-1:-1;;;20498:5:0;;;;20428:83;;;;;;;:::i;:::-;;;;;;;;21315:186;;;;;;;;;;-1:-1:-1;21315:186:0;;;;;:::i;:::-;;:::i;:::-;;;1188:14:1;;1181:22;1163:41;;1151:2;1136:18;21315:186:0;1023:187:1;20705:100:0;;;;;;;;;;-1:-1:-1;19123:22:0;20705:100;;;1361:25:1;;;1349:2;1334:18;20705:100:0;1215:177:1;21509:350:0;;;;;;;;;;-1:-1:-1;21509:350:0;;;;;:::i;:::-;;:::i;20614:83::-;;;;;;;;;;-1:-1:-1;20614:83:0;;19371:2;2000:36:1;;1988:2;1973:18;20614:83:0;1858:184:1;22906:199:0;;;;;;;;;;-1:-1:-1;22906:199:0;;;;;:::i;:::-;;:::i;:::-;;19730:31;;;;;;;;;;-1:-1:-1;19730:31:0;;;;;;;;;;;20813:118;;;;;;;;;;-1:-1:-1;20813:118:0;;;;;:::i;:::-;-1:-1:-1;;;;;20906:17:0;20879:7;20906:17;;;:8;:17;;;;;;;20813:118;2466:148;;;;;;;;;;;;;:::i;23510:88::-;;;;;;;;;;;;;:::i;22210:574::-;;;:::i;1824:79::-;;;;;;;;;;-1:-1:-1;1862:7:0;1889:6;-1:-1:-1;;;;;1889:6:0;1824:79;;;-1:-1:-1;;;;;2716:32:1;;;2698:51;;2686:2;2671:18;1824:79:0;2552:203:1;20519:87:0;;;;;;;;;;-1:-1:-1;20591:7:0;;;;;;;;;;;;-1:-1:-1;;;20591:7:0;;;;20519:87;;20939:192;;;;;;;;;;-1:-1:-1;20939:192:0;;;;;:::i;:::-;;:::i;19631:28::-;;;;;;;;;;;;;;;;19215:51;;;;;;;;;;;;;;;;19597:27;;;;;;;;;;;;;;;;19154:54;;;;;;;;;;;;;;;;23113:118;;;;;;;;;;-1:-1:-1;23113:118:0;;;;;:::i;:::-;;:::i;22792:106::-;;;;;;;;;;;;;:::i;21139:168::-;;;;;;;;;;-1:-1:-1;21139:168:0;;;;;:::i;:::-;-1:-1:-1;;;;;21272:18:0;;;21245:7;21272:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;21139:168;23239:150;;;;;;;;;;-1:-1:-1;23239:150:0;;;;;:::i;:::-;;:::i;2769:281::-;;;;;;;;;;-1:-1:-1;2769:281:0;;;;;:::i;:::-;;:::i;19492:96::-;;;;;;;;;;-1:-1:-1;19492:96:0;;;;-1:-1:-1;;;;;19492:96:0;;;19694:29;;;;;;;;;;-1:-1:-1;19694:29:0;;;;;;;;;;;21315:186;21415:4;21432:39;331:10;21455:7;21464:6;21432:8;:39::i;:::-;-1:-1:-1;21489:4:0;21315:186;;;;;:::o;21509:350::-;21641:4;21658:36;21668:6;21676:9;21687:6;21658:9;:36::i;:::-;-1:-1:-1;;;;;21776:19:0;;;;;;:11;:19;;;;;;;;331:10;21776:33;;;;;;;;;21705:124;;21728:6;;21776:42;;21812:6;;21776:42;:::i;:::-;21705:8;:124::i;:::-;-1:-1:-1;21847:4:0;21509:350;;;;;:::o;22906:199::-;2036:6;;-1:-1:-1;;;;;2036:6:0;331:10;2036:22;2028:67;;;;-1:-1:-1;;;2028:67:0;;;;;;;:::i;:::-;;;;;;;;;22985:8:::1;:15:::0;;;23011:9:::1;:17:::0;;;23061:1:::1;23049:13:::0;::::1;;23041:22;;;::::0;::::1;;23095:1;23082:9;;:14;;23074:23;;;::::0;::::1;;22906:199:::0;;:::o;2466:148::-;2036:6;;-1:-1:-1;;;;;2036:6:0;331:10;2036:22;2028:67;;;;-1:-1:-1;;;2028:67:0;;;;;;;:::i;:::-;2573:1:::1;2557:6:::0;;2536:40:::1;::::0;-1:-1:-1;;;;;2557:6:0;;::::1;::::0;2536:40:::1;::::0;2573:1;;2536:40:::1;2604:1;2587:19:::0;;-1:-1:-1;;;;;;2587:19:0::1;::::0;;2466:148::o;23510:88::-;2036:6;;-1:-1:-1;;;;;2036:6:0;331:10;2036:22;2028:67;;;;-1:-1:-1;;;2028:67:0;;;;;;;:::i;:::-;-1:-1:-1;;23564:12:0::1;:26:::0;23510:88::o;22210:574::-;2036:6;;-1:-1:-1;;;;;2036:6:0;331:10;2036:22;2028:67;;;;-1:-1:-1;;;2028:67:0;;;;;;;:::i;:::-;22296:4:::1;22276:26;::::0;;;:11:::1;:26;::::0;;;;;;;22311:15:::1;-1:-1:-1::0;;;;;22276:52:0::1;::::0;;;;;;;;;;-1:-1:-1;;22276:86:0;;22409:25;;-1:-1:-1;;;22409:25:0;;;;:23:::1;::::0;:25:::1;::::0;;::::1;::::0;22276:26;;22409:25;;;;;;22276:52;22409:25:::1;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;22391:113;::::0;-1:-1:-1;;;22391:113:0;;22469:4:::1;22391:113;::::0;::::1;4892:34:1::0;-1:-1:-1;;;;;22489:4:0::1;4962:15:1::0;;4942:18;;;4935:43;22391:55:0;;;::::1;::::0;::::1;::::0;4827:18:1;;22391:113:0::1;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;22375:13;:129:::0;;-1:-1:-1;;;;;;22375:129:0::1;-1:-1:-1::0;;;;;22375:129:0;;;::::1;::::0;;;::::1;::::0;;22558:4:::1;-1:-1:-1::0;20906:17:0;;;:8;:17;;;;;;22517:47:::1;;22577:15;-1:-1:-1::0;;;;;22577:31:0::1;;22616:9;22649:4;22669:12;22696:1;22712::::0;22728:7:::1;1862::::0;1889:6;-1:-1:-1;;;;;1889:6:0;;1824:79;22728:7:::1;22577:199;::::0;::::1;::::0;;;-1:-1:-1;;;;;;22577:199:0;;;-1:-1:-1;;;;;5348:15:1;;;22577:199:0::1;::::0;::::1;5330:34:1::0;5380:18;;;5373:34;;;;5423:18;;;5416:34;;;;5466:18;;;5459:34;5530:15;;;5509:19;;;5502:44;22750:15:0::1;5562:19:1::0;;;5555:35;5264:19;;22577:199:0::1;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;22265:519;22210:574::o:0;20939:192::-;21042:4;21059:42;331:10;21083:9;21094:6;21059:9;:42::i;23113:118::-;2036:6;;-1:-1:-1;;;;;2036:6:0;331:10;2036:22;2028:67;;;;-1:-1:-1;;;2028:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;23195:20:0;;;::::1;;::::0;;;:11:::1;:20;::::0;;;;:28;;-1:-1:-1;;23195:28:0::1;::::0;::::1;;::::0;;;::::1;::::0;;23113:118::o;22792:106::-;2036:6;;-1:-1:-1;;;;;2036:6:0;331:10;2036:22;2028:67;;;;-1:-1:-1;;;2028:67:0;;;;;;;:::i;:::-;22845:9:::1;:16:::0;;-1:-1:-1;;22872:18:0;;;;;22792:106::o;23239:150::-;2036:6;;-1:-1:-1;;;;;2036:6:0;331:10;2036:22;2028:67;;;;-1:-1:-1;;;2028:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;23353:20:0;;;::::1;;::::0;;;:11:::1;:20;::::0;;;;:28;;-1:-1:-1;;23353:28:0::1;::::0;::::1;;::::0;;;::::1;::::0;;23239:150::o;2769:281::-;2036:6;;-1:-1:-1;;;;;2036:6:0;331:10;2036:22;2028:67;;;;-1:-1:-1;;;2028:67:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;2872:22:0;::::1;2850:110;;;::::0;-1:-1:-1;;;2850:110:0;;6114:2:1;2850:110:0::1;::::0;::::1;6096:21:1::0;6153:2;6133:18;;;6126:30;6192:34;6172:18;;;6165:62;-1:-1:-1;;;6243:18:1;;;6236:36;6289:19;;2850:110:0::1;5912:402:1::0;2850:110:0::1;2997:6;::::0;;2976:38:::1;::::0;-1:-1:-1;;;;;2976:38:0;;::::1;::::0;2997:6;::::1;::::0;2976:38:::1;::::0;::::1;3025:6;:17:::0;;-1:-1:-1;;;;;;3025:17:0::1;-1:-1:-1::0;;;;;3025:17:0;;;::::1;::::0;;;::::1;::::0;;2769:281::o;21867:335::-;-1:-1:-1;;;;;21960:19:0;;21952:68;;;;-1:-1:-1;;;21952:68:0;;6521:2:1;21952:68:0;;;6503:21:1;6560:2;6540:18;;;6533:30;6599:34;6579:18;;;6572:62;-1:-1:-1;;;6650:18:1;;;6643:34;6694:19;;21952:68:0;6319:400:1;21952:68:0;-1:-1:-1;;;;;22039:21:0;;22031:68;;;;-1:-1:-1;;;22031:68:0;;6926:2:1;22031:68:0;;;6908:21:1;6965:2;6945:18;;;6938:30;7004:34;6984:18;;;6977:62;-1:-1:-1;;;7055:18:1;;;7048:32;7097:19;;22031:68:0;6724:398:1;22031:68:0;-1:-1:-1;;;;;22110:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;22162:32;;1361:25:1;;;22162:32:0;;1334:18:1;22162:32:0;;;;;;;;21867:335;;;:::o;23606:2882::-;-1:-1:-1;;;;;23694:18:0;;23686:68;;;;-1:-1:-1;;;23686:68:0;;7329:2:1;23686:68:0;;;7311:21:1;7368:2;7348:18;;;7341:30;7407:34;7387:18;;;7380:62;-1:-1:-1;;;7458:18:1;;;7451:35;7503:19;;23686:68:0;7127:401:1;23686:68:0;23787:9;;;;;;;;:30;;-1:-1:-1;;;;;;23800:17:0;;;;;;:11;:17;;;;;;;;23787:30;:49;;;-1:-1:-1;;;;;;23821:15:0;;;;;;:11;:15;;;;;;;;23787:49;23765:110;;;;-1:-1:-1;;;23765:110:0;;7735:2:1;23765:110:0;;;7717:21:1;7774:2;7754:18;;;7747:30;-1:-1:-1;;;7793:18:1;;;7786:41;7844:18;;23765:110:0;7533:335:1;23765:110:0;23893:11;;;;;;;23892:12;;:22;;-1:-1:-1;23908:6:0;;;;23892:22;:37;;;-1:-1:-1;23918:11:0;;23892:37;23888:200;;;-1:-1:-1;;;;;23946:14:0;;;;;;:8;:14;;;;;:24;;23964:6;;23946:14;:24;;23964:6;;23946:24;:::i;:::-;;;;-1:-1:-1;;;;;;;23985:12:0;;;;;;:8;:12;;;;;:22;;24001:6;;23985:12;:22;;24001:6;;23985:22;:::i;:::-;;;;;;;;24044:2;-1:-1:-1;;;;;24029:26:0;24038:4;-1:-1:-1;;;;;24029:26:0;-1:-1:-1;;;;;;;;;;;24048:6:0;24029:26;;;;1361:25:1;;1349:2;1334:18;;1215:177;23888:200:0;-1:-1:-1;;;;;24157:17:0;;24100:12;24157:17;;;:11;:17;;;;;;24115:4;;24100:12;24157:17;;;:36;;-1:-1:-1;;;;;;24178:15:0;;;;;;:11;:15;;;;;;;;24157:36;24153:1826;;;-1:-1:-1;24217:1:0;24153:1826;;;24255:6;;;;24251:224;;;-1:-1:-1;;;;;24317:14:0;;;;;;:8;:14;;;;;:24;;24335:6;;24317:14;:24;;24335:6;;24317:24;:::i;:::-;;;;-1:-1:-1;;;;;;;24360:12:0;;;;;;:8;:12;;;;;:22;;24376:6;;24360:12;:22;;24376:6;;24360:22;:::i;:::-;;;;;;;;24423:2;-1:-1:-1;;;;;24408:26:0;24417:4;-1:-1:-1;;;;;24408:26:0;-1:-1:-1;;;;;;;;;;;24427:6:0;24408:26;;;;1361:25:1;;1349:2;1334:18;;1215:177;24408:26:0;;;;;;;;24453:7;;23606:2882;;;:::o;24251:224::-;-1:-1:-1;;;;;24493:17:0;;;;;;:11;:17;;;;;;;;24489:1479;;;24541:5;24531:15;;24489:1479;;;24599:13;;-1:-1:-1;;;;;24599:13:0;;;24591:21;;;;24587:1366;;-1:-1:-1;24644:8:0;;-1:-1:-1;;;;;24680:17:0;;;;;;:11;:17;;;;;;;;24679:18;:38;;;;-1:-1:-1;;;;;;24702:15:0;;;;;;:11;:15;;;;;;;;24701:16;24679:38;24675:145;;;24783:12;;24754:25;24772:6;24754:13;24764:2;-1:-1:-1;;;;;20906:17:0;20879:7;20906:17;;;:8;:17;;;;;;;20813:118;24754:13;:17;;:25::i;:::-;:41;;24746:50;;;;;;24587:1366;;;24855:13;;-1:-1:-1;;;;;24855:13:0;;;24849:19;;;;24845:1108;;24930:4;24893:17;24913:23;;;:8;:23;;;;;;24985:12;;24973:24;;:49;;;;;25010:12;;25001:6;:21;24973:49;24969:869;;;25051:6;:13;;-1:-1:-1;;25051:13:0;25060:4;25051:13;;;25117:16;;;25131:1;25117:16;;;;;;;;-1:-1:-1;;25117:16:0;;;;;;;;;;-1:-1:-1;25117:16:0;25093:40;;25178:4;25160;25165:1;25160:7;;;;;;;;:::i;:::-;;;;;;:23;-1:-1:-1;;;;;25160:23:0;;;-1:-1:-1;;;;;25160:23:0;;;;;25220:4;25210;25215:1;25210:7;;;;;;;;:::i;:::-;;;;;;:14;-1:-1:-1;;;;;25210:14:0;;;-1:-1:-1;;;;;25210:14:0;;;;;25251:15;-1:-1:-1;;;;;25251:96:0;;25382:39;25386:6;25394:26;25398:9;25409:10;;25394:3;:26::i;:::-;25382:3;:39::i;:::-;25456:1;25492:4;25539;25579:15;25251:374;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;25735:10:0;;25727:44;;25679:21;;-1:-1:-1;;;;;;25735:10:0;;;;-1:-1:-1;25727:44:0;;;;;25679:21;;25654:22;25727:44;25654:22;25727:44;25679:21;25735:10;25727:44;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;25800:6:0;:14;;-1:-1:-1;;25800:14:0;;;-1:-1:-1;24969:869:0;-1:-1:-1;;25867:9:0;;24845:1108;;;-1:-1:-1;25932:1:0;24845:1108;25991:17;26029:3;26012:13;26021:4;26012:6;:13;:::i;:::-;26011:21;;;;:::i;:::-;25991:41;;26043:16;26062:7;:28;;26084:6;26062:28;;;26072:9;26062:28;26043:47;;26101:20;26124:7;:30;;26150:4;26124:30;;;26142:4;26124:30;26101:53;-1:-1:-1;26167:19:0;26189:18;26198:9;26189:6;:18;:::i;:::-;26167:40;-1:-1:-1;26222:12:0;;26218:139;;-1:-1:-1;;;;;26251:22:0;;;;;;:8;:22;;;;;:34;;26277:8;;26251:22;:34;;26277:8;;26251:34;:::i;:::-;;;;;;;;26322:12;-1:-1:-1;;;;;26307:38:0;26316:4;-1:-1:-1;;;;;26307:38:0;-1:-1:-1;;;;;;;;;;;26336:8:0;26307:38;;;;1361:25:1;;1349:2;1334:18;;1215:177;26307:38:0;;;;;;;;26218:139;-1:-1:-1;;;;;26369:14:0;;;;;;:8;:14;;;;;:24;;26387:6;;26369:14;:24;;26387:6;;26369:24;:::i;:::-;;;;-1:-1:-1;;;;;;;26404:12:0;;;;;;:8;:12;;;;;:27;;26420:11;;26404:12;:27;;26420:11;;26404:27;:::i;:::-;;;;;;;;26464:2;-1:-1:-1;;;;;26449:31:0;26458:4;-1:-1:-1;;;;;26449:31:0;-1:-1:-1;;;;;;;;;;;26468:11:0;26449:31;;;;1361:25:1;;1349:2;1334:18;;1215:177;26449:31:0;;;;;;;;23675:2813;;;;;;23606:2882;;;:::o;6884:181::-;6942:7;;6974:5;6978:1;6974;:5;:::i;:::-;6962:17;;7003:1;6998;:6;;6990:46;;;;-1:-1:-1;;;6990:46:0;;9849:2:1;6990:46:0;;;9831:21:1;9888:2;9868:18;;;9861:30;9927:29;9907:18;;;9900:57;9974:18;;6990:46:0;9647:351:1;6990:46:0;7056:1;6884:181;-1:-1:-1;;;6884:181:0:o;23397:105::-;23454:7;23484:1;23480;:5;23479:15;;23493:1;23479:15;;;-1:-1:-1;23489:1:0;23472:22;-1:-1:-1;23397:105:0:o;14:548:1:-;126:4;155:2;184;173:9;166:21;216:6;210:13;259:6;254:2;243:9;239:18;232:34;284:1;294:140;308:6;305:1;302:13;294:140;;;403:14;;;399:23;;393:30;369:17;;;388:2;365:26;358:66;323:10;;294:140;;;298:3;483:1;478:2;469:6;458:9;454:22;450:31;443:42;553:2;546;542:7;537:2;529:6;525:15;521:29;510:9;506:45;502:54;494:62;;;;14:548;;;;:::o;567:131::-;-1:-1:-1;;;;;642:31:1;;632:42;;622:70;;688:1;685;678:12;622:70;567:131;:::o;703:315::-;771:6;779;832:2;820:9;811:7;807:23;803:32;800:52;;;848:1;845;838:12;800:52;887:9;874:23;906:31;931:5;906:31;:::i;:::-;956:5;1008:2;993:18;;;;980:32;;-1:-1:-1;;;703:315:1:o;1397:456::-;1474:6;1482;1490;1543:2;1531:9;1522:7;1518:23;1514:32;1511:52;;;1559:1;1556;1549:12;1511:52;1598:9;1585:23;1617:31;1642:5;1617:31;:::i;:::-;1667:5;-1:-1:-1;1724:2:1;1709:18;;1696:32;1737:33;1696:32;1737:33;:::i;:::-;1397:456;;1789:7;;-1:-1:-1;;;1843:2:1;1828:18;;;;1815:32;;1397:456::o;2047:248::-;2115:6;2123;2176:2;2164:9;2155:7;2151:23;2147:32;2144:52;;;2192:1;2189;2182:12;2144:52;-1:-1:-1;;2215:23:1;;;2285:2;2270:18;;;2257:32;;-1:-1:-1;2047:248:1:o;2300:247::-;2359:6;2412:2;2400:9;2391:7;2387:23;2383:32;2380:52;;;2428:1;2425;2418:12;2380:52;2467:9;2454:23;2486:31;2511:5;2486:31;:::i;2760:416::-;2825:6;2833;2886:2;2874:9;2865:7;2861:23;2857:32;2854:52;;;2902:1;2899;2892:12;2854:52;2941:9;2928:23;2960:31;2985:5;2960:31;:::i;:::-;3010:5;-1:-1:-1;3067:2:1;3052:18;;3039:32;3109:15;;3102:23;3090:36;;3080:64;;3140:1;3137;3130:12;3080:64;3163:7;3153:17;;;2760:416;;;;;:::o;3181:388::-;3249:6;3257;3310:2;3298:9;3289:7;3285:23;3281:32;3278:52;;;3326:1;3323;3316:12;3278:52;3365:9;3352:23;3384:31;3409:5;3384:31;:::i;:::-;3434:5;-1:-1:-1;3491:2:1;3476:18;;3463:32;3504:33;3463:32;3504:33;:::i;3798:127::-;3859:10;3854:3;3850:20;3847:1;3840:31;3890:4;3887:1;3880:15;3914:4;3911:1;3904:15;3930:128;3997:9;;;4018:11;;;4015:37;;;4032:18;;:::i;4063:356::-;4265:2;4247:21;;;4284:18;;;4277:30;4343:34;4338:2;4323:18;;4316:62;4410:2;4395:18;;4063:356::o;4424:251::-;4494:6;4547:2;4535:9;4526:7;4522:23;4518:32;4515:52;;;4563:1;4560;4553:12;4515:52;4595:9;4589:16;4614:31;4639:5;4614:31;:::i;5601:306::-;5689:6;5697;5705;5758:2;5746:9;5737:7;5733:23;5729:32;5726:52;;;5774:1;5771;5764:12;5726:52;5803:9;5797:16;5787:26;;5853:2;5842:9;5838:18;5832:25;5822:35;;5897:2;5886:9;5882:18;5876:25;5866:35;;5601:306;;;;;:::o;7873:125::-;7938:9;;;7959:10;;;7956:36;;;7972:18;;:::i;8135:127::-;8196:10;8191:3;8187:20;8184:1;8177:31;8227:4;8224:1;8217:15;8251:4;8248:1;8241:15;8267:980;8529:4;8577:3;8566:9;8562:19;8608:6;8597:9;8590:25;8634:2;8672:6;8667:2;8656:9;8652:18;8645:34;8715:3;8710:2;8699:9;8695:18;8688:31;8739:6;8774;8768:13;8805:6;8797;8790:22;8843:3;8832:9;8828:19;8821:26;;8882:2;8874:6;8870:15;8856:29;;8903:1;8913:195;8927:6;8924:1;8921:13;8913:195;;;8992:13;;-1:-1:-1;;;;;8988:39:1;8976:52;;9083:15;;;;9048:12;;;;9024:1;8942:9;8913:195;;;-1:-1:-1;;;;;;;9164:32:1;;;;9159:2;9144:18;;9137:60;-1:-1:-1;;;9228:3:1;9213:19;9206:35;9125:3;8267:980;-1:-1:-1;;;8267:980:1:o;9252:168::-;9325:9;;;9356;;9373:15;;;9367:22;;9353:37;9343:71;;9394:18;;:::i;9425:217::-;9465:1;9491;9481:132;;9535:10;9530:3;9526:20;9523:1;9516:31;9570:4;9567:1;9560:15;9598:4;9595:1;9588:15;9481:132;-1:-1:-1;9627:9:1;;9425:217::o

Swarm Source

ipfs://e7d1c256ff156b1f9c2ded6f8a67bd4ef474cae7c106ee66e0f36f6d320f1ba4
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.