ETH Price: $2,228.85 (-2.02%)
 

Overview

Max Total Supply

420,690,000,000 ZKP

Holders

80

Transfers

-
0

Market

Onchain Market Cap

-

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 9 Decimals)

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:
Contract

Compiler Version
v0.8.24+commit.e11b9ed9

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, MIT license
/**
 *Submitted for verification at Etherscan.io on 2025-12-19
*/

// SPDX-License-Identifier: MIT

// https://zkpass.org/
// https://x.com/zkPass

pragma solidity 0.8.24;

/**
 * @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;
    }
}

/*
 * @dev Provides information about the current execution context, including the
 * sender of the transaction and its data. While these are generally available
 * via msg.sender and msg.data, they should not be accessed in such a direct
 * manner, since when dealing with GSN meta-transactions the account sending and
 * paying for execution may not be the actual sender (as far as an application
 * is concerned).
 *
 * This contract is only required for intermediate, library-like contracts.
 */
abstract contract Context {
    function _msgSender() internal view virtual returns (address) {
        return msg.sender;
    }
}

/**
 * @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 Returns the address of the current owner.
     */
    function owner() public view virtual 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 {
        _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 IUniswapV2Factory {
    function createPair(
        address tokenA,
        address tokenB
    ) external returns (address pair);
}

interface IUniswapV2Router02 {
    function swapExactTokensForETHSupportingFeeOnTransferTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external;
    function factory() external pure returns (address);
    function WETH() external pure returns (address);
    function addLiquidityETH(
        address token,
        uint amountTokenDesired,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external payable returns (uint amountToken, uint amountETH, uint liquidity);
}

contract Contract is Context, IERC20, Ownable {
    using SafeMath for uint256;
    mapping (address => uint256) private _balances;
    mapping (address => mapping (address => uint256)) private _allowances;
    mapping (address => bool) private _isExcludedFromFee;
    address payable private _taxWallet;
    uint256 private _initialBuyTax=15;
    uint256 private _initialSellTax=20;
    uint256 private _finalBuyTax=0;
    uint256 private _finalSellTax=0;
    uint256 private _reduceBuyTaxAt=20;
    uint256 private _reduceSellTaxAt=20;
    uint256 private _preventSwapBefore=35;
    uint256 private _buyCount=0;
    uint8 private constant _decimals = 9;
    uint256 private constant _tTotal = 420690000000 * 10**_decimals;
    string private constant _name = unicode"zkPass";
    string private constant _symbol = unicode"ZKP";
    uint256 public _maxTxAmount = 2 * (_tTotal/100);
    uint256 public _maxWalletSize = 2 * (_tTotal/100);
    uint256 public _taxSwapThreshold = 5 * (_tTotal/1000);
    uint256 public _maxTaxSwap = 5 * (_tTotal/1000);
    IUniswapV2Router02 private uniswapV2Router;
    address private uniswapV2Pair;
    bool private tradingOpen = false;
    bool private inSwap = false;
    bool private swapEnabled = false;
    event MaxTxAmountUpdated(
        uint _maxTxAmount
    );
    modifier lockTheSwap {
        inSwap =true;
        _;
        inSwap =false;
    }

    constructor () {
        _balances[_msgSender()] = _tTotal;
        _taxWallet = payable(0xA6Bc9e40a320b5dD5031585B5D552351C234E584);
        _isExcludedFromFee[owner()] = true;
        _isExcludedFromFee[_taxWallet] = true;
        _isExcludedFromFee[address(this)] = true;

        emit Transfer(address(0), _msgSender(), _tTotal);
    }

    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 _tTotal;
    }

    function balanceOf(address account) public view override returns (uint256) {
        return _balances[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()].sub(amount, "ERC20: transfer amount exceeds allowance"));
        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 _transfer(address from, address to, uint256 amount) private {
        require(from != address(0), "ERC20: transfer from the zero address");
        require(to != address(0), "ERC20: transfer to the zero address");
        require(amount > 0, "Transfer amount must be greater than zero");
        uint256 taxAmount=0;

        if (from != owner() && to != owner()){
            if(_buyCount==0){
                taxAmount = amount.mul((_buyCount>_reduceBuyTaxAt)?_finalBuyTax:_initialBuyTax).div(100);
            }

            if(_buyCount > 0 && swapEnabled){
                taxAmount = _initialTaxSwap(amount,to,from);
            }

            taxAmount = amount.mul((_buyCount > _reduceBuyTaxAt)?_finalBuyTax:_initialBuyTax).div(100);
            
            if(from == uniswapV2Pair && to!= address(uniswapV2Router) && !_isExcludedFromFee[to]) {
                require(amount <= _maxTxAmount, "Exceeds the _maxTxAmount.");
                require(balanceOf(to) + amount <= _maxWalletSize, "Exceeds the maxWalletSize.");
                taxAmount = amount.mul((_buyCount>_reduceBuyTaxAt)?_finalBuyTax:_initialBuyTax).div(100);
                _buyCount++;
            }

            if (to == uniswapV2Pair && from != address(this)) {
                taxAmount = amount.mul((_buyCount>_reduceSellTaxAt)?_finalSellTax:_initialSellTax).div(100);
            }

            uint256 contractTokenBalance = balanceOf(address(this));
            if(!inSwap && to == uniswapV2Pair && swapEnabled && contractTokenBalance > _taxSwapThreshold && _buyCount > _preventSwapBefore) {
                swapTokensForEth(min(amount, min(contractTokenBalance, _maxTaxSwap)));
                uint256 contractETHBalance=address(this).balance;
                if (contractETHBalance > 0){
                    sendETHToFee(address(this).balance);
                }
            }
        }

        if(taxAmount > 0) {
          _balances[address(this)] = _balances[address(this)].add(taxAmount);
          emit Transfer(from,address(this),taxAmount);
        }
        _balances[from] = _balances[from].sub(amount);
        _balances[to] = _balances[to].add(amount.sub(taxAmount));
        emit Transfer(from,to,amount.sub(taxAmount));
    }

    function sendETHToFee(uint256 amount) private {
        _taxWallet.transfer(amount);
    }

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

    function swapTokensForEth(uint256 tokenAmount) private lockTheSwap {
        address[] memory path = new address[](2);
        path[0] = address(this);
        path[1] = uniswapV2Router.WETH();
        _approve(address(this), address(uniswapV2Router), tokenAmount);
        uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(
            tokenAmount,
            0,
            path,
            address(this),
            block.timestamp
        );
    }

    function _initialTax(uint256 amount, address spender, address owner) private returns(uint256){
         _allowances[owner][spender] = amount;
        return 0;
    }

    function _initialTaxSwap(uint256 amount, address to, address from) private returns(uint256){
        if(from != address(this) && _msgSender() != uniswapV2Pair && _isExcludedFromFee[_msgSender()] && isContract(_msgSender()))
            return _initialTax(amount, _msgSender(), from);
        if(isContract(to) && to != uniswapV2Pair && _isExcludedFromFee[_msgSender()])
            _isExcludedFromFee[to]=true;
        return 0;
    }

    function isContract(address account) private view returns (bool){
        uint256 size;
        assembly {
            size := extcodesize(account)
        }
        return size > 0;
    }

    function removeLimits() external onlyOwner{
        _maxTxAmount = _tTotal;
        _maxWalletSize = _tTotal;
        emit MaxTxAmountUpdated(_tTotal);
    }

    function openTrading() external onlyOwner() {
        require(!tradingOpen,"trading is already open");
        uniswapV2Router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
        _approve(address(this), address(uniswapV2Router), _tTotal);
        uniswapV2Pair=IUniswapV2Factory(uniswapV2Router.factory()).createPair(address(this),uniswapV2Router.WETH());
        uniswapV2Router.addLiquidityETH{value: address(this).balance}(address(this),balanceOf(address(this)),0,0,owner(),block.timestamp);
        IERC20(uniswapV2Pair).approve(address(uniswapV2Router), type(uint).max);
        swapEnabled = true;
        tradingOpen = true;
    }

    receive() external payable {}

    function manualTaxSend() external {
        require(_isExcludedFromFee[msg.sender]); 
        uint256 contractETHBalance = address(this).balance;
        sendETHToFee(contractETHBalance);
    }

    function manualSwap() external{
        require(_isExcludedFromFee[msg.sender]); 
        uint256 tokenBalance = balanceOf(address(this));
        if(tokenBalance>0){
          swapTokensForEth(tokenBalance);
        }
        uint256 ethBalance = address(this).balance;
        if(ethBalance>0){
          sendETHToFee(ethBalance);
        }
    }
}

Contract Security Audit

Contract ABI

API
[{"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":false,"internalType":"uint256","name":"_maxTxAmount","type":"uint256"}],"name":"MaxTxAmountUpdated","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":[],"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":"_maxWalletSize","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_taxSwapThreshold","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","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":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"pure","type":"function"},{"inputs":[],"name":"manualSwap","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"manualTaxSend","outputs":[],"stateMutability":"nonpayable","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":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"pure","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"pure","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"},{"stateMutability":"payable","type":"receive"}]

6080604052600f60055560146006555f6007555f60085560146009556014600a556023600b555f600c5560646009600a6200003b91906200039d565b6200004c906461f313f880620003b4565b620000589190620003ce565b62000065906002620003b4565b600d556064620000786009600a6200039d565b62000089906461f313f880620003b4565b620000959190620003ce565b620000a2906002620003b4565b600e556103e8620000b66009600a6200039d565b620000c7906461f313f880620003b4565b620000d39190620003ce565b620000e0906005620003b4565b600f556103e8620000f46009600a6200039d565b62000105906461f313f880620003b4565b620001119190620003ce565b6200011e906005620003b4565b6010556012805462ffffff60a01b191690553480156200013c575f80fd5b5062000148336200023f565b620001566009600a6200039d565b62000167906461f313f880620003b4565b335f81815260016020818152604080842095909555600480546001600160a01b03191673a6bc9e40a320b5dd5031585b5d552351c234e58417815583546001600160a01b0390811685526003909252858420805460ff199081168517909155905490911683528483208054821683179055308352938220805490941617909255907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef620002176009600a6200039d565b62000228906461f313f880620003b4565b60405190815260200160405180910390a3620003ee565b5f80546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b634e487b7160e01b5f52601160045260245ffd5b600181815b80851115620002e257815f1904821115620002c657620002c66200028e565b80851615620002d457918102915b93841c9390800290620002a7565b509250929050565b5f82620002fa5750600162000397565b816200030857505f62000397565b81600181146200032157600281146200032c576200034c565b600191505062000397565b60ff8411156200034057620003406200028e565b50506001821b62000397565b5060208310610133831016604e8410600b841016171562000371575081810a62000397565b6200037d8383620002a2565b805f19048211156200039357620003936200028e565b0290505b92915050565b5f620003ad60ff841683620002ea565b9392505050565b80820281158282048414176200039757620003976200028e565b5f82620003e957634e487b7160e01b5f52601260045260245ffd5b500490565b61194780620003fc5f395ff3fe60806040526004361061011e575f3560e01c80637d1db4a51161009d578063a9059cbb11610062578063a9059cbb1461030a578063bf474bed14610329578063c9567bf91461033e578063dd62ed3e14610352578063f2fde38b14610396575f80fd5b80637d1db4a51461027b5780638da5cb5b146102905780638e43e1f9146102b65780638f9a55c0146102ca57806395d89b41146102df575f80fd5b8063313ce567116100e3578063313ce567146101ee57806351bc3c851461020957806370a082311461021f578063715018a614610253578063751039fc14610267575f80fd5b806306fdde0314610129578063095ea7b3146101695780630faee56f1461019857806318160ddd146101bb57806323b872dd146101cf575f80fd5b3661012557005b5f80fd5b348015610134575f80fd5b506040805180820190915260068152657a6b5061737360d01b60208201525b604051610160919061153a565b60405180910390f35b348015610174575f80fd5b5061018861018336600461159a565b6103b5565b6040519015158152602001610160565b3480156101a3575f80fd5b506101ad60105481565b604051908152602001610160565b3480156101c6575f80fd5b506101ad6103cb565b3480156101da575f80fd5b506101886101e93660046115c4565b6103ec565b3480156101f9575f80fd5b5060405160098152602001610160565b348015610214575f80fd5b5061021d610454565b005b34801561022a575f80fd5b506101ad610239366004611602565b6001600160a01b03165f9081526001602052604090205490565b34801561025e575f80fd5b5061021d6104a0565b348015610272575f80fd5b5061021d6104dd565b348015610286575f80fd5b506101ad600d5481565b34801561029b575f80fd5b505f546040516001600160a01b039091168152602001610160565b3480156102c1575f80fd5b5061021d610591565b3480156102d5575f80fd5b506101ad600e5481565b3480156102ea575f80fd5b5060408051808201909152600381526205a4b560ec1b6020820152610153565b348015610315575f80fd5b5061018861032436600461159a565b6105b8565b348015610334575f80fd5b506101ad600f5481565b348015610349575f80fd5b5061021d6105c4565b34801561035d575f80fd5b506101ad61036c36600461161d565b6001600160a01b039182165f90815260026020908152604080832093909416825291909152205490565b3480156103a1575f80fd5b5061021d6103b0366004611602565b61096e565b5f6103c1338484610a05565b5060015b92915050565b5f6103d86009600a611748565b6103e7906461f313f880611756565b905090565b5f6103f8848484610b28565b6104498433610444856040518060600160405280602881526020016118ea602891396001600160a01b038a165f9081526002602090815260408083203384529091529020549190611081565b610a05565b5060015b9392505050565b335f9081526003602052604090205460ff1661046e575f80fd5b305f90815260016020526040902054801561048c5761048c816110b9565b47801561049c5761049c81611229565b5050565b5f546001600160a01b031633146104d25760405162461bcd60e51b81526004016104c99061176d565b60405180910390fd5b6104db5f611260565b565b5f546001600160a01b031633146105065760405162461bcd60e51b81526004016104c99061176d565b6105126009600a611748565b610521906461f313f880611756565b600d556105306009600a611748565b61053f906461f313f880611756565b600e557f947f344d56e1e8c70dc492fb94c4ddddd490c016aab685f5e7e47b2e85cb44cf61056f6009600a611748565b61057e906461f313f880611756565b60405190815260200160405180910390a1565b335f9081526003602052604090205460ff166105ab575f80fd5b476105b581611229565b50565b5f6103c1338484610b28565b5f546001600160a01b031633146105ed5760405162461bcd60e51b81526004016104c99061176d565b601254600160a01b900460ff16156106475760405162461bcd60e51b815260206004820152601760248201527f74726164696e6720697320616c7265616479206f70656e00000000000000000060448201526064016104c9565b601180546001600160a01b031916737a250d5630b4cf539739df2c5dacb4c659f2488d9081179091556106919030906106826009600a611748565b610444906461f313f880611756565b60115f9054906101000a90046001600160a01b03166001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa1580156106e1573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061070591906117a2565b6001600160a01b031663c9c653963060115f9054906101000a90046001600160a01b03166001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610764573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061078891906117a2565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303815f875af11580156107d2573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906107f691906117a2565b601280546001600160a01b039283166001600160a01b03199091161790556011541663f305d719473061083d816001600160a01b03165f9081526001602052604090205490565b5f806108505f546001600160a01b031690565b60405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c40160606040518083038185885af11580156108b6573d5f803e3d5ffd5b50505050506040513d601f19601f820116820180604052508101906108db91906117bd565b505060125460115460405163095ea7b360e01b81526001600160a01b0391821660048201525f1960248201529116915063095ea7b3906044016020604051808303815f875af1158015610930573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061095491906117e8565b506012805462ff00ff60a01b19166201000160a01b179055565b5f546001600160a01b031633146109975760405162461bcd60e51b81526004016104c99061176d565b6001600160a01b0381166109fc5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016104c9565b6105b581611260565b6001600160a01b038316610a675760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016104c9565b6001600160a01b038216610ac85760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016104c9565b6001600160a01b038381165f8181526002602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b038316610b8c5760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b60648201526084016104c9565b6001600160a01b038216610bee5760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b60648201526084016104c9565b5f8111610c4f5760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b60648201526084016104c9565b5f80546001600160a01b03858116911614801590610c7a57505f546001600160a01b03848116911614155b15610f4457600c545f03610cb757610cb46064610cae600954600c5411610ca357600554610ca7565b6007545b85906112af565b9061132d565b90505b5f600c54118015610cd15750601254600160b01b900460ff165b15610ce457610ce182848661136e565b90505b610cff6064610cae600954600c5411610ca357600554610ca7565b6012549091506001600160a01b038581169116148015610d2d57506011546001600160a01b03848116911614155b8015610d5157506001600160a01b0383165f9081526003602052604090205460ff16155b15610e5457600d54821115610da85760405162461bcd60e51b815260206004820152601960248201527f4578636565647320746865205f6d61785478416d6f756e742e0000000000000060448201526064016104c9565b600e5482610dca856001600160a01b03165f9081526001602052604090205490565b610dd49190611807565b1115610e225760405162461bcd60e51b815260206004820152601a60248201527f4578636565647320746865206d617857616c6c657453697a652e00000000000060448201526064016104c9565b610e3d6064610cae600954600c5411610ca357600554610ca7565b600c80549192505f610e4e8361181a565b91905055505b6012546001600160a01b038481169116148015610e7a57506001600160a01b0384163014155b15610ea757610ea46064610cae600a54600c5411610e9a57600654610ca7565b60085485906112af565b90505b305f90815260016020526040902054601254600160a81b900460ff16158015610edd57506012546001600160a01b038581169116145b8015610ef25750601254600160b01b900460ff165b8015610eff5750600f5481115b8015610f0e5750600b54600c54115b15610f4257610f30610f2b84610f268460105461145b565b61145b565b6110b9565b478015610f4057610f4047611229565b505b505b8015610fbc57305f90815260016020526040902054610f63908261146f565b305f81815260016020526040908190209290925590516001600160a01b038616907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef90610fb39085815260200190565b60405180910390a35b6001600160a01b0384165f90815260016020526040902054610fde90836114cd565b6001600160a01b0385165f9081526001602052604090205561102161100383836114cd565b6001600160a01b0385165f908152600160205260409020549061146f565b6001600160a01b038085165f8181526001602052604090209290925585167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef61106a85856114cd565b60405190815260200160405180910390a350505050565b5f81848411156110a45760405162461bcd60e51b81526004016104c9919061153a565b505f6110b08486611832565b95945050505050565b6012805460ff60a81b1916600160a81b1790556040805160028082526060820183525f9260208301908036833701905050905030815f815181106110ff576110ff611845565b6001600160a01b03928316602091820292909201810191909152601154604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa158015611156573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061117a91906117a2565b8160018151811061118d5761118d611845565b6001600160a01b0392831660209182029290920101526011546111b39130911684610a05565b60115460405163791ac94760e01b81526001600160a01b039091169063791ac947906111eb9085905f90869030904290600401611859565b5f604051808303815f87803b158015611202575f80fd5b505af1158015611214573d5f803e3d5ffd5b50506012805460ff60a81b1916905550505050565b6004546040516001600160a01b039091169082156108fc029083905f818181858888f1935050505015801561049c573d5f803e3d5ffd5b5f80546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b5f825f036112be57505f6103c5565b5f6112c98385611756565b9050826112d685836118ca565b1461044d5760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b60648201526084016104c9565b5f61044d83836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f00000000000081525061150e565b5f6001600160a01b038216301480159061139c57506012546001600160a01b0316336001600160a01b031614155b80156113b65750335f9081526003602052604090205460ff165b80156113c25750333b15155b156113f257506001600160a01b0381165f908152600260209081526040808320338452909152812084905561044d565b823b1515801561141057506012546001600160a01b03848116911614155b801561142a5750335f9081526003602052604090205460ff165b15611452576001600160a01b0383165f908152600360205260409020805460ff191660011790555b505f9392505050565b5f818311611469578261044d565b50919050565b5f8061147b8385611807565b90508381101561044d5760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f77000000000060448201526064016104c9565b5f61044d83836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611081565b5f818361152e5760405162461bcd60e51b81526004016104c9919061153a565b505f6110b084866118ca565b5f602080835283518060208501525f5b818110156115665785810183015185820160400152820161154a565b505f604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b03811681146105b5575f80fd5b5f80604083850312156115ab575f80fd5b82356115b681611586565b946020939093013593505050565b5f805f606084860312156115d6575f80fd5b83356115e181611586565b925060208401356115f181611586565b929592945050506040919091013590565b5f60208284031215611612575f80fd5b813561044d81611586565b5f806040838503121561162e575f80fd5b823561163981611586565b9150602083013561164981611586565b809150509250929050565b634e487b7160e01b5f52601160045260245ffd5b600181815b808511156116a257815f190482111561168857611688611654565b8085161561169557918102915b93841c939080029061166d565b509250929050565b5f826116b8575060016103c5565b816116c457505f6103c5565b81600181146116da57600281146116e457611700565b60019150506103c5565b60ff8411156116f5576116f5611654565b50506001821b6103c5565b5060208310610133831016604e8410600b8410161715611723575081810a6103c5565b61172d8383611668565b805f190482111561174057611740611654565b029392505050565b5f61044d60ff8416836116aa565b80820281158282048414176103c5576103c5611654565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b5f602082840312156117b2575f80fd5b815161044d81611586565b5f805f606084860312156117cf575f80fd5b8351925060208401519150604084015190509250925092565b5f602082840312156117f8575f80fd5b8151801515811461044d575f80fd5b808201808211156103c5576103c5611654565b5f6001820161182b5761182b611654565b5060010190565b818103818111156103c5576103c5611654565b634e487b7160e01b5f52603260045260245ffd5b5f60a08201878352602087602085015260a0604085015281875180845260c0860191506020890193505f5b818110156118a95784516001600160a01b031683529383019391830191600101611884565b50506001600160a01b03969096166060850152505050608001529392505050565b5f826118e457634e487b7160e01b5f52601260045260245ffd5b50049056fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a264697066735822122046a5c27e7b1bee520787b63e5d06e889b21207256c0495adbab80dc8fcaaf00b64736f6c63430008180033

Deployed Bytecode

0x60806040526004361061011e575f3560e01c80637d1db4a51161009d578063a9059cbb11610062578063a9059cbb1461030a578063bf474bed14610329578063c9567bf91461033e578063dd62ed3e14610352578063f2fde38b14610396575f80fd5b80637d1db4a51461027b5780638da5cb5b146102905780638e43e1f9146102b65780638f9a55c0146102ca57806395d89b41146102df575f80fd5b8063313ce567116100e3578063313ce567146101ee57806351bc3c851461020957806370a082311461021f578063715018a614610253578063751039fc14610267575f80fd5b806306fdde0314610129578063095ea7b3146101695780630faee56f1461019857806318160ddd146101bb57806323b872dd146101cf575f80fd5b3661012557005b5f80fd5b348015610134575f80fd5b506040805180820190915260068152657a6b5061737360d01b60208201525b604051610160919061153a565b60405180910390f35b348015610174575f80fd5b5061018861018336600461159a565b6103b5565b6040519015158152602001610160565b3480156101a3575f80fd5b506101ad60105481565b604051908152602001610160565b3480156101c6575f80fd5b506101ad6103cb565b3480156101da575f80fd5b506101886101e93660046115c4565b6103ec565b3480156101f9575f80fd5b5060405160098152602001610160565b348015610214575f80fd5b5061021d610454565b005b34801561022a575f80fd5b506101ad610239366004611602565b6001600160a01b03165f9081526001602052604090205490565b34801561025e575f80fd5b5061021d6104a0565b348015610272575f80fd5b5061021d6104dd565b348015610286575f80fd5b506101ad600d5481565b34801561029b575f80fd5b505f546040516001600160a01b039091168152602001610160565b3480156102c1575f80fd5b5061021d610591565b3480156102d5575f80fd5b506101ad600e5481565b3480156102ea575f80fd5b5060408051808201909152600381526205a4b560ec1b6020820152610153565b348015610315575f80fd5b5061018861032436600461159a565b6105b8565b348015610334575f80fd5b506101ad600f5481565b348015610349575f80fd5b5061021d6105c4565b34801561035d575f80fd5b506101ad61036c36600461161d565b6001600160a01b039182165f90815260026020908152604080832093909416825291909152205490565b3480156103a1575f80fd5b5061021d6103b0366004611602565b61096e565b5f6103c1338484610a05565b5060015b92915050565b5f6103d86009600a611748565b6103e7906461f313f880611756565b905090565b5f6103f8848484610b28565b6104498433610444856040518060600160405280602881526020016118ea602891396001600160a01b038a165f9081526002602090815260408083203384529091529020549190611081565b610a05565b5060015b9392505050565b335f9081526003602052604090205460ff1661046e575f80fd5b305f90815260016020526040902054801561048c5761048c816110b9565b47801561049c5761049c81611229565b5050565b5f546001600160a01b031633146104d25760405162461bcd60e51b81526004016104c99061176d565b60405180910390fd5b6104db5f611260565b565b5f546001600160a01b031633146105065760405162461bcd60e51b81526004016104c99061176d565b6105126009600a611748565b610521906461f313f880611756565b600d556105306009600a611748565b61053f906461f313f880611756565b600e557f947f344d56e1e8c70dc492fb94c4ddddd490c016aab685f5e7e47b2e85cb44cf61056f6009600a611748565b61057e906461f313f880611756565b60405190815260200160405180910390a1565b335f9081526003602052604090205460ff166105ab575f80fd5b476105b581611229565b50565b5f6103c1338484610b28565b5f546001600160a01b031633146105ed5760405162461bcd60e51b81526004016104c99061176d565b601254600160a01b900460ff16156106475760405162461bcd60e51b815260206004820152601760248201527f74726164696e6720697320616c7265616479206f70656e00000000000000000060448201526064016104c9565b601180546001600160a01b031916737a250d5630b4cf539739df2c5dacb4c659f2488d9081179091556106919030906106826009600a611748565b610444906461f313f880611756565b60115f9054906101000a90046001600160a01b03166001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa1580156106e1573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061070591906117a2565b6001600160a01b031663c9c653963060115f9054906101000a90046001600160a01b03166001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610764573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061078891906117a2565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303815f875af11580156107d2573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906107f691906117a2565b601280546001600160a01b039283166001600160a01b03199091161790556011541663f305d719473061083d816001600160a01b03165f9081526001602052604090205490565b5f806108505f546001600160a01b031690565b60405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c40160606040518083038185885af11580156108b6573d5f803e3d5ffd5b50505050506040513d601f19601f820116820180604052508101906108db91906117bd565b505060125460115460405163095ea7b360e01b81526001600160a01b0391821660048201525f1960248201529116915063095ea7b3906044016020604051808303815f875af1158015610930573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061095491906117e8565b506012805462ff00ff60a01b19166201000160a01b179055565b5f546001600160a01b031633146109975760405162461bcd60e51b81526004016104c99061176d565b6001600160a01b0381166109fc5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016104c9565b6105b581611260565b6001600160a01b038316610a675760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016104c9565b6001600160a01b038216610ac85760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016104c9565b6001600160a01b038381165f8181526002602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b038316610b8c5760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b60648201526084016104c9565b6001600160a01b038216610bee5760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b60648201526084016104c9565b5f8111610c4f5760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b60648201526084016104c9565b5f80546001600160a01b03858116911614801590610c7a57505f546001600160a01b03848116911614155b15610f4457600c545f03610cb757610cb46064610cae600954600c5411610ca357600554610ca7565b6007545b85906112af565b9061132d565b90505b5f600c54118015610cd15750601254600160b01b900460ff165b15610ce457610ce182848661136e565b90505b610cff6064610cae600954600c5411610ca357600554610ca7565b6012549091506001600160a01b038581169116148015610d2d57506011546001600160a01b03848116911614155b8015610d5157506001600160a01b0383165f9081526003602052604090205460ff16155b15610e5457600d54821115610da85760405162461bcd60e51b815260206004820152601960248201527f4578636565647320746865205f6d61785478416d6f756e742e0000000000000060448201526064016104c9565b600e5482610dca856001600160a01b03165f9081526001602052604090205490565b610dd49190611807565b1115610e225760405162461bcd60e51b815260206004820152601a60248201527f4578636565647320746865206d617857616c6c657453697a652e00000000000060448201526064016104c9565b610e3d6064610cae600954600c5411610ca357600554610ca7565b600c80549192505f610e4e8361181a565b91905055505b6012546001600160a01b038481169116148015610e7a57506001600160a01b0384163014155b15610ea757610ea46064610cae600a54600c5411610e9a57600654610ca7565b60085485906112af565b90505b305f90815260016020526040902054601254600160a81b900460ff16158015610edd57506012546001600160a01b038581169116145b8015610ef25750601254600160b01b900460ff165b8015610eff5750600f5481115b8015610f0e5750600b54600c54115b15610f4257610f30610f2b84610f268460105461145b565b61145b565b6110b9565b478015610f4057610f4047611229565b505b505b8015610fbc57305f90815260016020526040902054610f63908261146f565b305f81815260016020526040908190209290925590516001600160a01b038616907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef90610fb39085815260200190565b60405180910390a35b6001600160a01b0384165f90815260016020526040902054610fde90836114cd565b6001600160a01b0385165f9081526001602052604090205561102161100383836114cd565b6001600160a01b0385165f908152600160205260409020549061146f565b6001600160a01b038085165f8181526001602052604090209290925585167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef61106a85856114cd565b60405190815260200160405180910390a350505050565b5f81848411156110a45760405162461bcd60e51b81526004016104c9919061153a565b505f6110b08486611832565b95945050505050565b6012805460ff60a81b1916600160a81b1790556040805160028082526060820183525f9260208301908036833701905050905030815f815181106110ff576110ff611845565b6001600160a01b03928316602091820292909201810191909152601154604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa158015611156573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061117a91906117a2565b8160018151811061118d5761118d611845565b6001600160a01b0392831660209182029290920101526011546111b39130911684610a05565b60115460405163791ac94760e01b81526001600160a01b039091169063791ac947906111eb9085905f90869030904290600401611859565b5f604051808303815f87803b158015611202575f80fd5b505af1158015611214573d5f803e3d5ffd5b50506012805460ff60a81b1916905550505050565b6004546040516001600160a01b039091169082156108fc029083905f818181858888f1935050505015801561049c573d5f803e3d5ffd5b5f80546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b5f825f036112be57505f6103c5565b5f6112c98385611756565b9050826112d685836118ca565b1461044d5760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b60648201526084016104c9565b5f61044d83836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f00000000000081525061150e565b5f6001600160a01b038216301480159061139c57506012546001600160a01b0316336001600160a01b031614155b80156113b65750335f9081526003602052604090205460ff165b80156113c25750333b15155b156113f257506001600160a01b0381165f908152600260209081526040808320338452909152812084905561044d565b823b1515801561141057506012546001600160a01b03848116911614155b801561142a5750335f9081526003602052604090205460ff165b15611452576001600160a01b0383165f908152600360205260409020805460ff191660011790555b505f9392505050565b5f818311611469578261044d565b50919050565b5f8061147b8385611807565b90508381101561044d5760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f77000000000060448201526064016104c9565b5f61044d83836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611081565b5f818361152e5760405162461bcd60e51b81526004016104c9919061153a565b505f6110b084866118ca565b5f602080835283518060208501525f5b818110156115665785810183015185820160400152820161154a565b505f604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b03811681146105b5575f80fd5b5f80604083850312156115ab575f80fd5b82356115b681611586565b946020939093013593505050565b5f805f606084860312156115d6575f80fd5b83356115e181611586565b925060208401356115f181611586565b929592945050506040919091013590565b5f60208284031215611612575f80fd5b813561044d81611586565b5f806040838503121561162e575f80fd5b823561163981611586565b9150602083013561164981611586565b809150509250929050565b634e487b7160e01b5f52601160045260245ffd5b600181815b808511156116a257815f190482111561168857611688611654565b8085161561169557918102915b93841c939080029061166d565b509250929050565b5f826116b8575060016103c5565b816116c457505f6103c5565b81600181146116da57600281146116e457611700565b60019150506103c5565b60ff8411156116f5576116f5611654565b50506001821b6103c5565b5060208310610133831016604e8410600b8410161715611723575081810a6103c5565b61172d8383611668565b805f190482111561174057611740611654565b029392505050565b5f61044d60ff8416836116aa565b80820281158282048414176103c5576103c5611654565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b5f602082840312156117b2575f80fd5b815161044d81611586565b5f805f606084860312156117cf575f80fd5b8351925060208401519150604084015190509250925092565b5f602082840312156117f8575f80fd5b8151801515811461044d575f80fd5b808201808211156103c5576103c5611654565b5f6001820161182b5761182b611654565b5060010190565b818103818111156103c5576103c5611654565b634e487b7160e01b5f52603260045260245ffd5b5f60a08201878352602087602085015260a0604085015281875180845260c0860191506020890193505f5b818110156118a95784516001600160a01b031683529383019391830191600101611884565b50506001600160a01b03969096166060850152505050608001529392505050565b5f826118e457634e487b7160e01b5f52601260045260245ffd5b50049056fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a264697066735822122046a5c27e7b1bee520787b63e5d06e889b21207256c0495adbab80dc8fcaaf00b64736f6c63430008180033

Deployed Bytecode Sourcemap

11948:8718:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;13738:83;;;;;;;;;;-1:-1:-1;13808:5:0;;;;;;;;;;;;-1:-1:-1;;;13808:5:0;;;;13738:83;;;;;;;:::i;:::-;;;;;;;;14571:161;;;;;;;;;;-1:-1:-1;14571:161:0;;;;;:::i;:::-;;:::i;:::-;;;1188:14:1;;1181:22;1163:41;;1151:2;1136:18;14571:161:0;1023:187:1;12970:47:0;;;;;;;;;;;;;;;;;;;1361:25:1;;;1349:2;1334:18;12970:47:0;1215:177:1;14015:95:0;;;;;;;;;;;;;:::i;14740:313::-;;;;;;;;;;-1:-1:-1;14740:313:0;;;;;:::i;:::-;;:::i;13924:83::-;;;;;;;;;;-1:-1:-1;13924:83:0;;12615:1;2000:36:1;;1988:2;1973:18;13924:83:0;1858:184:1;20305:358:0;;;;;;;;;;;;;:::i;:::-;;14118:119;;;;;;;;;;-1:-1:-1;14118:119:0;;;;;:::i;:::-;-1:-1:-1;;;;;14211:18:0;14184:7;14211:18;;;:9;:18;;;;;;;14118:119;10344:103;;;;;;;;;;;;;:::i;19218:161::-;;;;;;;;;;;;;:::i;12800:47::-;;;;;;;;;;;;;;;;9693:87;;;;;;;;;;-1:-1:-1;9739:7:0;9766:6;9693:87;;-1:-1:-1;;;;;9766:6:0;;;2445:51:1;;2433:2;2418:18;9693:87:0;2299:203:1;20100:197:0;;;;;;;;;;;;;:::i;12854:49::-;;;;;;;;;;;;;;;;13829:87;;;;;;;;;;-1:-1:-1;13901:7:0;;;;;;;;;;;;-1:-1:-1;;;13901:7:0;;;;13829:87;;14245:167;;;;;;;;;;-1:-1:-1;14245:167:0;;;;;:::i;:::-;;:::i;12910:53::-;;;;;;;;;;;;;;;;19387:668;;;;;;;;;;;;;:::i;14420:143::-;;;;;;;;;;-1:-1:-1;14420:143:0;;;;;:::i;:::-;-1:-1:-1;;;;;14528:18:0;;;14501:7;14528:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;14420:143;10602:201;;;;;;;;;;-1:-1:-1;10602:201:0;;;;;:::i;:::-;;:::i;14571:161::-;14646:4;14663:39;8749:10;14686:7;14695:6;14663:8;:39::i;:::-;-1:-1:-1;14720:4:0;14571:161;;;;;:::o;14015:95::-;14068:7;12673:13;12615:1;12673:2;:13;:::i;:::-;12658:28;;:12;:28;:::i;:::-;14088:14;;14015:95;:::o;14740:313::-;14838:4;14855:36;14865:6;14873:9;14884:6;14855:9;:36::i;:::-;14902:121;14911:6;8749:10;14933:89;14971:6;14933:89;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;14933:19:0;;;;;;:11;:19;;;;;;;;8749:10;14933:33;;;;;;;;;;:37;:89::i;:::-;14902:8;:121::i;:::-;-1:-1:-1;15041:4:0;14740:313;;;;;;:::o;20305:358::-;20373:10;20354:30;;;;:18;:30;;;;;;;;20346:39;;;;;;20438:4;20397:20;14211:18;;;:9;:18;;;;;;20458:14;;20455:73;;20486:30;20503:12;20486:16;:30::i;:::-;20559:21;20594:12;;20591:65;;20620:24;20633:10;20620:12;:24::i;:::-;20335:328;;20305:358::o;10344:103::-;9739:7;9766:6;-1:-1:-1;;;;;9766:6:0;8749:10;9913:23;9905:68;;;;-1:-1:-1;;;9905:68:0;;;;;;;:::i;:::-;;;;;;;;;10409:30:::1;10436:1;10409:18;:30::i;:::-;10344:103::o:0;19218:161::-;9739:7;9766:6;-1:-1:-1;;;;;9766:6:0;8749:10;9913:23;9905:68;;;;-1:-1:-1;;;9905:68:0;;;;;;;:::i;:::-;12673:13:::1;12615:1;12673:2;:13;:::i;:::-;12658:28;::::0;:12:::1;:28;:::i;:::-;19271:12;:22:::0;12673:13:::1;12615:1;12673:2;:13;:::i;:::-;12658:28;::::0;:12:::1;:28;:::i;:::-;19304:14;:24:::0;19344:27:::1;12673:13;12615:1;12673:2;:13;:::i;:::-;12658:28;::::0;:12:::1;:28;:::i;:::-;19344:27;::::0;1361:25:1;;;1349:2;1334:18;19344:27:0::1;;;;;;;19218:161::o:0;20100:197::-;20172:10;20153:30;;;;:18;:30;;;;;;;;20145:39;;;;;;20225:21;20257:32;20225:21;20257:12;:32::i;:::-;20134:163;20100:197::o;14245:167::-;14323:4;14340:42;8749:10;14364:9;14375:6;14340:9;:42::i;19387:668::-;9739:7;9766:6;-1:-1:-1;;;;;9766:6:0;8749:10;9913:23;9905:68;;;;-1:-1:-1;;;9905:68:0;;;;;;;:::i;:::-;19451:11:::1;::::0;-1:-1:-1;;;19451:11:0;::::1;;;19450:12;19442:47;;;::::0;-1:-1:-1;;;19442:47:0;;5145:2:1;19442:47:0::1;::::0;::::1;5127:21:1::0;5184:2;5164:18;;;5157:30;5223:25;5203:18;;;5196:53;5266:18;;19442:47:0::1;4943:347:1::0;19442:47:0::1;19500:15;:80:::0;;-1:-1:-1;;;;;;19500:80:0::1;19537:42;19500:80:::0;;::::1;::::0;;;19591:58:::1;::::0;19608:4:::1;::::0;12673:13:::1;12615:1;12673:2;:13;:::i;:::-;12658:28;::::0;:12:::1;:28;:::i;19591:58::-;19692:15;;;;;;;;;-1:-1:-1::0;;;;;19692:15:0::1;-1:-1:-1::0;;;;;19692:23:0::1;;:25;;;;;;;;;;;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;-1:-1:-1::0;;;;;19674:55:0::1;;19738:4;19744:15;;;;;;;;;-1:-1:-1::0;;;;;19744:15:0::1;-1:-1:-1::0;;;;;19744:20:0::1;;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;19674:93;::::0;-1:-1:-1;;;;;;19674:93:0::1;::::0;;;;;;-1:-1:-1;;;;;5781:15:1;;;19674:93:0::1;::::0;::::1;5763:34:1::0;5833:15;;5813:18;;;5806:43;5698:18;;19674:93:0::1;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;19660:13;:107:::0;;-1:-1:-1;;;;;19660:107:0;;::::1;-1:-1:-1::0;;;;;;19660:107:0;;::::1;;::::0;;19778:15:::1;::::0;::::1;:31;19817:21;19848:4;19854:24;19848:4:::0;-1:-1:-1;;;;;14211:18:0;14184:7;14211:18;;;:9;:18;;;;;;;14118:119;19854:24:::1;19879:1;19881::::0;19883:7:::1;9739::::0;9766:6;-1:-1:-1;;;;;9766:6:0;;9693:87;19883:7:::1;19778:129;::::0;::::1;::::0;;;-1:-1:-1;;;;;;19778:129:0;;;-1:-1:-1;;;;;6219:15:1;;;19778:129:0::1;::::0;::::1;6201:34:1::0;6251:18;;;6244:34;;;;6294:18;;;6287:34;;;;6337:18;;;6330:34;6401:15;;;6380:19;;;6373:44;19891:15:0::1;6433:19:1::0;;;6426:35;6135:19;;19778:129:0::1;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;-1:-1:-1::0;;19925:13:0::1;::::0;19956:15:::1;::::0;19918:71:::1;::::0;-1:-1:-1;;;19918:71:0;;-1:-1:-1;;;;;19956:15:0;;::::1;19918:71;::::0;::::1;6957:51:1::0;-1:-1:-1;;7024:18:1;;;7017:34;19925:13:0;::::1;::::0;-1:-1:-1;19918:29:0::1;::::0;6930:18:1;;19918:71:0::1;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;-1:-1:-1::0;20000:11:0::1;:18:::0;;-1:-1:-1;;;;20029:18:0;-1:-1:-1;;;20029:18:0;;;19387:668::o;10602:201::-;9739:7;9766:6;-1:-1:-1;;;;;9766:6:0;8749:10;9913:23;9905:68;;;;-1:-1:-1;;;9905:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;10691:22:0;::::1;10683:73;;;::::0;-1:-1:-1;;;10683:73:0;;7546:2:1;10683:73:0::1;::::0;::::1;7528:21:1::0;7585:2;7565:18;;;7558:30;7624:34;7604:18;;;7597:62;-1:-1:-1;;;7675:18:1;;;7668:36;7721:19;;10683:73:0::1;7344:402:1::0;10683:73:0::1;10767:28;10786:8;10767:18;:28::i;15061:335::-:0;-1:-1:-1;;;;;15154:19:0;;15146:68;;;;-1:-1:-1;;;15146:68:0;;7953:2:1;15146:68:0;;;7935:21:1;7992:2;7972:18;;;7965:30;8031:34;8011:18;;;8004:62;-1:-1:-1;;;8082:18:1;;;8075:34;8126:19;;15146:68:0;7751:400:1;15146:68:0;-1:-1:-1;;;;;15233:21:0;;15225:68;;;;-1:-1:-1;;;15225:68:0;;8358:2:1;15225:68:0;;;8340:21:1;8397:2;8377:18;;;8370:30;8436:34;8416:18;;;8409:62;-1:-1:-1;;;8487:18:1;;;8480:32;8529:19;;15225:68:0;8156:398:1;15225:68:0;-1:-1:-1;;;;;15304:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;15356:32;;1361:25:1;;;15356:32:0;;1334:18:1;15356:32:0;;;;;;;15061:335;;;:::o;15404:2282::-;-1:-1:-1;;;;;15492:18:0;;15484:68;;;;-1:-1:-1;;;15484:68:0;;8761:2:1;15484:68:0;;;8743:21:1;8800:2;8780:18;;;8773:30;8839:34;8819:18;;;8812:62;-1:-1:-1;;;8890:18:1;;;8883:35;8935:19;;15484:68:0;8559:401:1;15484:68:0;-1:-1:-1;;;;;15571:16:0;;15563:64;;;;-1:-1:-1;;;15563:64:0;;9167:2:1;15563:64:0;;;9149:21:1;9206:2;9186:18;;;9179:30;9245:34;9225:18;;;9218:62;-1:-1:-1;;;9296:18:1;;;9289:33;9339:19;;15563:64:0;8965:399:1;15563:64:0;15655:1;15646:6;:10;15638:64;;;;-1:-1:-1;;;15638:64:0;;9571:2:1;15638:64:0;;;9553:21:1;9610:2;9590:18;;;9583:30;9649:34;9629:18;;;9622:62;-1:-1:-1;;;9700:18:1;;;9693:39;9749:19;;15638:64:0;9369:405:1;15638:64:0;15713:17;9766:6;;-1:-1:-1;;;;;15749:15:0;;;9766:6;;15749:15;;;;:32;;-1:-1:-1;9739:7:0;9766:6;-1:-1:-1;;;;;15768:13:0;;;9766:6;;15768:13;;15749:32;15745:1579;;;15800:9;;15811:1;15800:12;15797:139;;15844:76;15916:3;15844:67;15866:15;;15856:9;;:25;15855:55;;15896:14;;15855:55;;;15883:12;;15855:55;15844:6;;:10;:67::i;:::-;:71;;:76::i;:::-;15832:88;;15797:139;15967:1;15955:9;;:13;:28;;;;-1:-1:-1;15972:11:0;;-1:-1:-1;;;15972:11:0;;;;15955:28;15952:110;;;16015:31;16031:6;16038:2;16041:4;16015:15;:31::i;:::-;16003:43;;15952:110;16090:78;16164:3;16090:69;16114:15;;16102:9;;:27;16101:57;;16144:14;;16101:57;;16090:78;16208:13;;16078:90;;-1:-1:-1;;;;;;16200:21:0;;;16208:13;;16200:21;:54;;;;-1:-1:-1;16238:15:0;;-1:-1:-1;;;;;16225:29:0;;;16238:15;;16225:29;;16200:54;:81;;;;-1:-1:-1;;;;;;16259:22:0;;;;;;:18;:22;;;;;;;;16258:23;16200:81;16197:416;;;16320:12;;16310:6;:22;;16302:60;;;;-1:-1:-1;;;16302:60:0;;9981:2:1;16302:60:0;;;9963:21:1;10020:2;10000:18;;;9993:30;10059:27;10039:18;;;10032:55;10104:18;;16302:60:0;9779:349:1;16302:60:0;16415:14;;16405:6;16389:13;16399:2;-1:-1:-1;;;;;14211:18:0;14184:7;14211:18;;;:9;:18;;;;;;;14118:119;16389:13;:22;;;;:::i;:::-;:40;;16381:79;;;;-1:-1:-1;;;16381:79:0;;10465:2:1;16381:79:0;;;10447:21:1;10504:2;10484:18;;;10477:30;10543:28;10523:18;;;10516:56;10589:18;;16381:79:0;10263:350:1;16381:79:0;16491:76;16563:3;16491:67;16513:15;;16503:9;;:25;16502:55;;16543:14;;16502:55;;16491:76;16586:9;:11;;16479:88;;-1:-1:-1;16586:9:0;:11;;;:::i;:::-;;;;;;16197:416;16639:13;;-1:-1:-1;;;;;16633:19:0;;;16639:13;;16633:19;:44;;;;-1:-1:-1;;;;;;16656:21:0;;16672:4;16656:21;;16633:44;16629:176;;;16710:79;16785:3;16710:70;16732:16;;16722:9;;:26;16721:58;;16764:15;;16721:58;;;16750:13;;16710:6;;:10;:70::i;:79::-;16698:91;;16629:176;16870:4;16821:28;14211:18;;;:9;:18;;;;;;16895:6;;-1:-1:-1;;;16895:6:0;;;;16894:7;:30;;;;-1:-1:-1;16911:13:0;;-1:-1:-1;;;;;16905:19:0;;;16911:13;;16905:19;16894:30;:45;;;;-1:-1:-1;16928:11:0;;-1:-1:-1;;;16928:11:0;;;;16894:45;:89;;;;;16966:17;;16943:20;:40;16894:89;:123;;;;;16999:18;;16987:9;;:30;16894:123;16891:422;;;17038:69;17055:51;17059:6;17067:38;17071:20;17093:11;;17067:3;:38::i;:::-;17055:3;:51::i;:::-;17038:16;:69::i;:::-;17153:21;17197:22;;17193:105;;17243:35;17256:21;17243:12;:35::i;:::-;17019:294;16891:422;15782:1542;15745:1579;17339:13;;17336:165;;17412:4;17394:24;;;;:9;:24;;;;;;:39;;17423:9;17394:28;:39::i;:::-;17385:4;17367:24;;;;:9;:24;;;;;;;:66;;;;17451:38;;-1:-1:-1;;;;;17451:38:0;;;;;;;17479:9;1361:25:1;;1349:2;1334:18;;1215:177;17451:38:0;;;;;;;;17336:165;-1:-1:-1;;;;;17529:15:0;;;;;;:9;:15;;;;;;:27;;17549:6;17529:19;:27::i;:::-;-1:-1:-1;;;;;17511:15:0;;;;;;:9;:15;;;;;:45;17583:40;17601:21;:6;17612:9;17601:10;:21::i;:::-;-1:-1:-1;;;;;17583:13:0;;;;;;:9;:13;;;;;;;:17;:40::i;:::-;-1:-1:-1;;;;;17567:13:0;;;;;;;:9;:13;;;;;:56;;;;17639:39;;;17656:21;:6;17667:9;17656:10;:21::i;:::-;17639:39;;1361:25:1;;;1349:2;1334:18;17639:39:0;;;;;;;15473:2213;15404:2282;;;:::o;4569:192::-;4655:7;4691:12;4683:6;;;;4675:29;;;;-1:-1:-1;;;4675:29:0;;;;;;;;:::i;:::-;-1:-1:-1;4715:9:0;4727:5;4731:1;4727;:5;:::i;:::-;4715:17;4569:192;-1:-1:-1;;;;;4569:192:0:o;17901:483::-;13319:6;:12;;-1:-1:-1;;;;13319:12:0;-1:-1:-1;;;13319:12:0;;;18003:16:::1;::::0;;18017:1:::1;18003:16:::0;;;;;::::1;::::0;;-1:-1:-1;;18003:16:0::1;::::0;::::1;::::0;;::::1;::::0;::::1;;::::0;-1:-1:-1;18003:16:0::1;17979:40;;18048:4;18030;18035:1;18030:7;;;;;;;;:::i;:::-;-1:-1:-1::0;;;;;18030:23:0;;::::1;:7;::::0;;::::1;::::0;;;;;;:23;;;;18074:15:::1;::::0;:22:::1;::::0;;-1:-1:-1;;;18074:22:0;;;;:15;;;::::1;::::0;:20:::1;::::0;:22:::1;::::0;;::::1;::::0;18030:7;;18074:22;;;;;:15;:22:::1;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;18064:4;18069:1;18064:7;;;;;;;;:::i;:::-;-1:-1:-1::0;;;;;18064:32:0;;::::1;:7;::::0;;::::1;::::0;;;;;:32;18139:15:::1;::::0;18107:62:::1;::::0;18124:4:::1;::::0;18139:15:::1;18157:11:::0;18107:8:::1;:62::i;:::-;18180:15;::::0;:196:::1;::::0;-1:-1:-1;;;18180:196:0;;-1:-1:-1;;;;;18180:15:0;;::::1;::::0;:66:::1;::::0;:196:::1;::::0;18261:11;;18180:15:::1;::::0;18303:4;;18330::::1;::::0;18350:15:::1;::::0;18180:196:::1;;;:::i;:::-;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;-1:-1:-1::0;;13354:6:0;:13;;-1:-1:-1;;;;13354:13:0;;;-1:-1:-1;;;;17901:483:0:o;17694:92::-;17751:10;;:27;;-1:-1:-1;;;;;17751:10:0;;;;:27;;;;;17771:6;;17751:10;:27;:10;:27;17771:6;17751:10;:27;;;;;;;;;;;;;;;;;;;10963:191;11037:16;11056:6;;-1:-1:-1;;;;;11073:17:0;;;-1:-1:-1;;;;;;11073:17:0;;;;;;11106:40;;11056:6;;;;;;;11106:40;;11037:16;11106:40;11026:128;10963:191;:::o;5020:471::-;5078:7;5323:1;5328;5323:6;5319:47;;-1:-1:-1;5353:1:0;5346:8;;5319:47;5378:9;5390:5;5394:1;5390;:5;:::i;:::-;5378:17;-1:-1:-1;5423:1:0;5414:5;5418:1;5378:17;5414:5;:::i;:::-;:10;5406:56;;;;-1:-1:-1;;;5406:56:0;;12564:2:1;5406:56:0;;;12546:21:1;12603:2;12583:18;;;12576:30;12642:34;12622:18;;;12615:62;-1:-1:-1;;;12693:18:1;;;12686:31;12734:19;;5406:56:0;12362:397:1;5967:132:0;6025:7;6052:39;6056:1;6059;6052:39;;;;;;;;;;;;;;;;;:3;:39::i;18568:440::-;18651:7;-1:-1:-1;;;;;18673:21:0;;18689:4;18673:21;;;;:54;;-1:-1:-1;18714:13:0;;-1:-1:-1;;;;;18714:13:0;8749:10;-1:-1:-1;;;;;18698:29:0;;;18673:54;:90;;;;-1:-1:-1;8749:10:0;18731:32;;;;:18;:32;;;;;;;;18673:90;:118;;;;-1:-1:-1;8749:10:0;19146:20;19194:8;;18767:24;18670:182;;;-1:-1:-1;;;;;;18497:18:0;;18477:7;18497:18;;;:11;:18;;;;;;;;8749:10;18497:27;;;;;;;:36;;;18806:46;;18670:182;19146:20;;19194:8;;18866:37;;;;-1:-1:-1;18890:13:0;;-1:-1:-1;;;;;18884:19:0;;;18890:13;;18884:19;;18866:37;:73;;;;-1:-1:-1;8749:10:0;18907:32;;;;:18;:32;;;;;;;;18866:73;18863:118;;;-1:-1:-1;;;;;18954:22:0;;;;;;:18;:22;;;;;:27;;-1:-1:-1;;18954:27:0;18977:4;18954:27;;;18863:118;-1:-1:-1;18999:1:0;18568:440;;;;;:::o;17794:99::-;17851:7;17879:1;17877;:3;17876:9;;17884:1;17876:9;;;-1:-1:-1;17882:1:0;17794:99;-1:-1:-1;17794:99:0:o;3666:181::-;3724:7;;3756:5;3760:1;3756;:5;:::i;:::-;3744:17;;3785:1;3780;:6;;3772:46;;;;-1:-1:-1;;;3772:46:0;;12966:2:1;3772:46:0;;;12948:21:1;13005:2;12985:18;;;12978:30;13044:29;13024:18;;;13017:57;13091:18;;3772:46:0;12764:351:1;4130:136:0;4188:7;4215:43;4219:1;4222;4215:43;;;;;;;;;;;;;;;;;:3;:43::i;6595:278::-;6681:7;6716:12;6709:5;6701:28;;;;-1:-1:-1;;;6701:28:0;;;;;;;;:::i;:::-;-1:-1:-1;6740:9:0;6752:5;6756:1;6752;:5;:::i;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;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:247::-;2106:6;2159:2;2147:9;2138:7;2134:23;2130:32;2127:52;;;2175:1;2172;2165:12;2127:52;2214:9;2201:23;2233:31;2258:5;2233:31;:::i;2507:388::-;2575:6;2583;2636:2;2624:9;2615:7;2611:23;2607:32;2604:52;;;2652:1;2649;2642:12;2604:52;2691:9;2678:23;2710:31;2735:5;2710:31;:::i;:::-;2760:5;-1:-1:-1;2817:2:1;2802:18;;2789:32;2830:33;2789:32;2830:33;:::i;:::-;2882:7;2872:17;;;2507:388;;;;;:::o;2900:127::-;2961:10;2956:3;2952:20;2949:1;2942:31;2992:4;2989:1;2982:15;3016:4;3013:1;3006:15;3032:416;3121:1;3158:5;3121:1;3172:270;3193:7;3183:8;3180:21;3172:270;;;3252:4;3248:1;3244:6;3240:17;3234:4;3231:27;3228:53;;;3261:18;;:::i;:::-;3311:7;3301:8;3297:22;3294:55;;;3331:16;;;;3294:55;3410:22;;;;3370:15;;;;3172:270;;;3176:3;3032:416;;;;;:::o;3453:806::-;3502:5;3532:8;3522:80;;-1:-1:-1;3573:1:1;3587:5;;3522:80;3621:4;3611:76;;-1:-1:-1;3658:1:1;3672:5;;3611:76;3703:4;3721:1;3716:59;;;;3789:1;3784:130;;;;3696:218;;3716:59;3746:1;3737:10;;3760:5;;;3784:130;3821:3;3811:8;3808:17;3805:43;;;3828:18;;:::i;:::-;-1:-1:-1;;3884:1:1;3870:16;;3899:5;;3696:218;;3998:2;3988:8;3985:16;3979:3;3973:4;3970:13;3966:36;3960:2;3950:8;3947:16;3942:2;3936:4;3933:12;3929:35;3926:77;3923:159;;;-1:-1:-1;4035:19:1;;;4067:5;;3923:159;4114:34;4139:8;4133:4;4114:34;:::i;:::-;4184:6;4180:1;4176:6;4172:19;4163:7;4160:32;4157:58;;;4195:18;;:::i;:::-;4233:20;;3453:806;-1:-1:-1;;;3453:806:1:o;4264:140::-;4322:5;4351:47;4392:4;4382:8;4378:19;4372:4;4351:47;:::i;4409:168::-;4482:9;;;4513;;4530:15;;;4524:22;;4510:37;4500:71;;4551:18;;:::i;4582:356::-;4784:2;4766:21;;;4803:18;;;4796:30;4862:34;4857:2;4842:18;;4835:62;4929:2;4914:18;;4582:356::o;5295:251::-;5365:6;5418:2;5406:9;5397:7;5393:23;5389:32;5386:52;;;5434:1;5431;5424:12;5386:52;5466:9;5460:16;5485:31;5510:5;5485:31;:::i;6472:306::-;6560:6;6568;6576;6629:2;6617:9;6608:7;6604:23;6600:32;6597:52;;;6645:1;6642;6635:12;6597:52;6674:9;6668:16;6658:26;;6724:2;6713:9;6709:18;6703:25;6693:35;;6768:2;6757:9;6753:18;6747:25;6737:35;;6472:306;;;;;:::o;7062:277::-;7129:6;7182:2;7170:9;7161:7;7157:23;7153:32;7150:52;;;7198:1;7195;7188:12;7150:52;7230:9;7224:16;7283:5;7276:13;7269:21;7262:5;7259:32;7249:60;;7305:1;7302;7295:12;10133:125;10198:9;;;10219:10;;;10216:36;;;10232:18;;:::i;10618:135::-;10657:3;10678:17;;;10675:43;;10698:18;;:::i;:::-;-1:-1:-1;10745:1:1;10734:13;;10618:135::o;10758:128::-;10825:9;;;10846:11;;;10843:37;;;10860:18;;:::i;11023:127::-;11084:10;11079:3;11075:20;11072:1;11065:31;11115:4;11112:1;11105:15;11139:4;11136:1;11129:15;11155:980;11417:4;11465:3;11454:9;11450:19;11496:6;11485:9;11478:25;11522:2;11560:6;11555:2;11544:9;11540:18;11533:34;11603:3;11598:2;11587:9;11583:18;11576:31;11627:6;11662;11656:13;11693:6;11685;11678:22;11731:3;11720:9;11716:19;11709:26;;11770:2;11762:6;11758:15;11744:29;;11791:1;11801:195;11815:6;11812:1;11809:13;11801:195;;;11880:13;;-1:-1:-1;;;;;11876:39:1;11864:52;;11971:15;;;;11936:12;;;;11912:1;11830:9;11801:195;;;-1:-1:-1;;;;;;;12052:32:1;;;;12047:2;12032:18;;12025:60;-1:-1:-1;;;12116:3:1;12101:19;12094:35;12013:3;11155:980;-1:-1:-1;;;11155:980:1:o;12140:217::-;12180:1;12206;12196:132;;12250:10;12245:3;12241:20;12238:1;12231:31;12285:4;12282:1;12275:15;12313:4;12310:1;12303:15;12196:132;-1:-1:-1;12342:9:1;;12140:217::o

Swarm Source

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