Token Richoffcrypto

 

Overview [ERC-20]

Max Total Supply:
10,000,000 ROC

Holders:
2

Transfers:
-

 
Loading
[ Download CSV Export  ] 
Loading
[ Download CSV Export  ] 
Loading

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

Contract Source Code Verified (Exact Match)

Contract Name:
Richoffcrypto

Compiler Version
v0.8.12+commit.f00d7308

Optimization Enabled:
No with 200 runs

Other Settings:
default evmVersion, MIT license
/**
 *Submitted for verification at Etherscan.io on 2022-03-29
*/

// SPDX-License-Identifier: MIT
// File: https://github.com/OpenZeppelin/openzeppelin-contracts/blob/master/contracts/utils/Context.sol


// OpenZeppelin Contracts v4.4.1 (utils/Context.sol)

pragma solidity ^0.8.0;

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

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

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


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

pragma solidity ^0.8.0;

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

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

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

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

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

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

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

// File: https://github.com/OpenZeppelin/openzeppelin-contracts/blob/master/contracts/token/ERC20/extensions/IERC20Metadata.sol


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

pragma solidity ^0.8.0;


/**
 * @dev Interface for the optional metadata functions from the ERC20 standard.
 *
 * _Available since v4.1._
 */
interface IERC20Metadata is IERC20 {
    /**
     * @dev Returns the name of the token.
     */
    function name() external view returns (string memory);

    /**
     * @dev Returns the symbol of the token.
     */
    function symbol() external view returns (string memory);

    /**
     * @dev Returns the decimals places of the token.
     */
    function decimals() external view returns (uint8);
}

// File: https://github.com/OpenZeppelin/openzeppelin-contracts/blob/master/contracts/token/ERC20/ERC20.sol


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

pragma solidity ^0.8.0;




/**
 * @dev Implementation of the {IERC20} interface.
 *
 * This implementation is agnostic to the way tokens are created. This means
 * that a supply mechanism has to be added in a derived contract using {_mint}.
 * For a generic mechanism see {ERC20PresetMinterPauser}.
 *
 * TIP: For a detailed writeup see our guide
 * https://forum.zeppelin.solutions/t/how-to-implement-erc20-supply-mechanisms/226[How
 * to implement supply mechanisms].
 *
 * We have followed general OpenZeppelin Contracts guidelines: functions revert
 * instead returning `false` on failure. This behavior is nonetheless
 * conventional and does not conflict with the expectations of ERC20
 * applications.
 *
 * Additionally, an {Approval} event is emitted on calls to {transferFrom}.
 * This allows applications to reconstruct the allowance for all accounts just
 * by listening to said events. Other implementations of the EIP may not emit
 * these events, as it isn't required by the specification.
 *
 * Finally, the non-standard {decreaseAllowance} and {increaseAllowance}
 * functions have been added to mitigate the well-known issues around setting
 * allowances. See {IERC20-approve}.
 */
contract ERC20 is Context, IERC20, IERC20Metadata {
    mapping(address => uint256) private _balances;

    mapping(address => mapping(address => uint256)) private _allowances;

    uint256 private _totalSupply;

    string private _name;
    string private _symbol;

    /**
     * @dev Sets the values for {name} and {symbol}.
     *
     * The default value of {decimals} is 18. To select a different value for
     * {decimals} you should overload it.
     *
     * All two of these values are immutable: they can only be set once during
     * construction.
     */
    constructor(string memory name_, string memory symbol_) {
        _name = name_;
        _symbol = symbol_;
    }

    /**
     * @dev Returns the name of the token.
     */
    function name() public view virtual override returns (string memory) {
        return _name;
    }

    /**
     * @dev Returns the symbol of the token, usually a shorter version of the
     * name.
     */
    function symbol() public view virtual override returns (string memory) {
        return _symbol;
    }

    /**
     * @dev Returns the number of decimals used to get its user representation.
     * For example, if `decimals` equals `2`, a balance of `505` tokens should
     * be displayed to a user as `5.05` (`505 / 10 ** 2`).
     *
     * Tokens usually opt for a value of 18, imitating the relationship between
     * Ether and Wei. This is the value {ERC20} uses, unless this function is
     * overridden;
     *
     * NOTE: This information is only used for _display_ purposes: it in
     * no way affects any of the arithmetic of the contract, including
     * {IERC20-balanceOf} and {IERC20-transfer}.
     */
    function decimals() public view virtual override returns (uint8) {
        return 18;
    }

    /**
     * @dev See {IERC20-totalSupply}.
     */
    function totalSupply() public view virtual override returns (uint256) {
        return _totalSupply;
    }

    /**
     * @dev See {IERC20-balanceOf}.
     */
    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 `sender` to `recipient`.
     *
     * 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(from != address(0), "ERC20: transfer from the zero address");
        require(to != address(0), "ERC20: transfer to the zero address");

        _beforeTokenTransfer(from, to, amount);

        uint256 fromBalance = _balances[from];
        require(fromBalance >= amount, "ERC20: transfer amount exceeds balance");
        unchecked {
            _balances[from] = fromBalance - amount;
        }
        _balances[to] += 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;
        _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;
        }
        _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: richoffcrypto.sol


pragma solidity ^0.8.7;


contract Richoffcrypto is ERC20 {
    address public admin;
    constructor() ERC20('Richoffcrypto', 'ROC') {
     _mint(msg.sender, 10000000 * 10 ** 18);
     admin = msg.sender;
     }

     function mint(address to, uint amount) external {
         require(msg.sender == admin, 'only admin');
         _mint(to, amount);
     }

     function burn(uint amount) external {
         _burn(msg.sender, amount);
     }
}

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":"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":"admin","outputs":[{"internalType":"address","name":"","type":"address"}],"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":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"burn","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":"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":"to","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"mint","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"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"}]

60806040523480156200001157600080fd5b506040518060400160405280600d81526020017f526963686f666663727970746f000000000000000000000000000000000000008152506040518060400160405280600381526020017f524f43000000000000000000000000000000000000000000000000000000000081525081600390805190602001906200009692919062000299565b508060049080519060200190620000af92919062000299565b505050620000cf336a084595161401484a0000006200011660201b60201c565b33600560006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550620004f5565b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff16141562000189576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016200018090620003aa565b60405180910390fd5b6200019d600083836200028f60201b60201c565b8060026000828254620001b1919062000405565b92505081905550806000808473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020600082825462000208919062000405565b925050819055508173ffffffffffffffffffffffffffffffffffffffff16600073ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef836040516200026f919062000473565b60405180910390a36200028b600083836200029460201b60201c565b5050565b505050565b505050565b828054620002a790620004bf565b90600052602060002090601f016020900481019282620002cb576000855562000317565b82601f10620002e657805160ff191683800117855562000317565b8280016001018555821562000317579182015b8281111562000316578251825591602001919060010190620002f9565b5b5090506200032691906200032a565b5090565b5b80821115620003455760008160009055506001016200032b565b5090565b600082825260208201905092915050565b7f45524332303a206d696e7420746f20746865207a65726f206164647265737300600082015250565b600062000392601f8362000349565b91506200039f826200035a565b602082019050919050565b60006020820190508181036000830152620003c58162000383565b9050919050565b6000819050919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b60006200041282620003cc565b91506200041f83620003cc565b9250827fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff03821115620004575762000456620003d6565b5b828201905092915050565b6200046d81620003cc565b82525050565b60006020820190506200048a600083018462000462565b92915050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052602260045260246000fd5b60006002820490506001821680620004d857607f821691505b60208210811415620004ef57620004ee62000490565b5b50919050565b61198e80620005056000396000f3fe608060405234801561001057600080fd5b50600436106100ea5760003560e01c806342966c681161008c578063a457c2d711610066578063a457c2d71461025f578063a9059cbb1461028f578063dd62ed3e146102bf578063f851a440146102ef576100ea565b806342966c68146101f557806370a082311461021157806395d89b4114610241576100ea565b806323b872dd116100c857806323b872dd1461015b578063313ce5671461018b57806339509351146101a957806340c10f19146101d9576100ea565b806306fdde03146100ef578063095ea7b31461010d57806318160ddd1461013d575b600080fd5b6100f761030d565b6040516101049190610fc1565b60405180910390f35b6101276004803603810190610122919061107c565b61039f565b60405161013491906110d7565b60405180910390f35b6101456103c2565b6040516101529190611101565b60405180910390f35b6101756004803603810190610170919061111c565b6103cc565b60405161018291906110d7565b60405180910390f35b6101936103fb565b6040516101a0919061118b565b60405180910390f35b6101c360048036038101906101be919061107c565b610404565b6040516101d091906110d7565b60405180910390f35b6101f360048036038101906101ee919061107c565b61043b565b005b61020f600480360381019061020a91906111a6565b6104d9565b005b61022b600480360381019061022691906111d3565b6104e6565b6040516102389190611101565b60405180910390f35b61024961052e565b6040516102569190610fc1565b60405180910390f35b6102796004803603810190610274919061107c565b6105c0565b60405161028691906110d7565b60405180910390f35b6102a960048036038101906102a4919061107c565b610637565b6040516102b691906110d7565b60405180910390f35b6102d960048036038101906102d49190611200565b61065a565b6040516102e69190611101565b60405180910390f35b6102f76106e1565b604051610304919061124f565b60405180910390f35b60606003805461031c90611299565b80601f016020809104026020016040519081016040528092919081815260200182805461034890611299565b80156103955780601f1061036a57610100808354040283529160200191610395565b820191906000526020600020905b81548152906001019060200180831161037857829003601f168201915b5050505050905090565b6000806103aa610707565b90506103b781858561070f565b600191505092915050565b6000600254905090565b6000806103d7610707565b90506103e48582856108da565b6103ef858585610966565b60019150509392505050565b60006012905090565b60008061040f610707565b9050610430818585610421858961065a565b61042b91906112fa565b61070f565b600191505092915050565b600560009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff16146104cb576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016104c29061139c565b60405180910390fd5b6104d58282610be7565b5050565b6104e33382610d47565b50565b60008060008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020549050919050565b60606004805461053d90611299565b80601f016020809104026020016040519081016040528092919081815260200182805461056990611299565b80156105b65780601f1061058b576101008083540402835291602001916105b6565b820191906000526020600020905b81548152906001019060200180831161059957829003601f168201915b5050505050905090565b6000806105cb610707565b905060006105d9828661065a565b90508381101561061e576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016106159061142e565b60405180910390fd5b61062b828686840361070f565b60019250505092915050565b600080610642610707565b905061064f818585610966565b600191505092915050565b6000600160008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054905092915050565b600560009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b600033905090565b600073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff16141561077f576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610776906114c0565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1614156107ef576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016107e690611552565b60405180910390fd5b80600160008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055508173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925836040516108cd9190611101565b60405180910390a3505050565b60006108e6848461065a565b90507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff81146109605781811015610952576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610949906115be565b60405180910390fd5b61095f848484840361070f565b5b50505050565b600073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614156109d6576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016109cd90611650565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff161415610a46576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610a3d906116e2565b60405180910390fd5b610a51838383610f1e565b60008060008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054905081811015610ad7576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610ace90611774565b60405180910390fd5b8181036000808673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002081905550816000808573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000206000828254610b6a91906112fa565b925050819055508273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef84604051610bce9190611101565b60405180910390a3610be1848484610f23565b50505050565b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff161415610c57576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610c4e906117e0565b60405180910390fd5b610c6360008383610f1e565b8060026000828254610c7591906112fa565b92505081905550806000808473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000206000828254610cca91906112fa565b925050819055508173ffffffffffffffffffffffffffffffffffffffff16600073ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051610d2f9190611101565b60405180910390a3610d4360008383610f23565b5050565b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff161415610db7576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610dae90611872565b60405180910390fd5b610dc382600083610f1e565b60008060008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054905081811015610e49576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610e4090611904565b60405180910390fd5b8181036000808573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055508160026000828254610ea09190611924565b92505081905550600073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef84604051610f059190611101565b60405180910390a3610f1983600084610f23565b505050565b505050565b505050565b600081519050919050565b600082825260208201905092915050565b60005b83811015610f62578082015181840152602081019050610f47565b83811115610f71576000848401525b50505050565b6000601f19601f8301169050919050565b6000610f9382610f28565b610f9d8185610f33565b9350610fad818560208601610f44565b610fb681610f77565b840191505092915050565b60006020820190508181036000830152610fdb8184610f88565b905092915050565b600080fd5b600073ffffffffffffffffffffffffffffffffffffffff82169050919050565b600061101382610fe8565b9050919050565b61102381611008565b811461102e57600080fd5b50565b6000813590506110408161101a565b92915050565b6000819050919050565b61105981611046565b811461106457600080fd5b50565b60008135905061107681611050565b92915050565b6000806040838503121561109357611092610fe3565b5b60006110a185828601611031565b92505060206110b285828601611067565b9150509250929050565b60008115159050919050565b6110d1816110bc565b82525050565b60006020820190506110ec60008301846110c8565b92915050565b6110fb81611046565b82525050565b600060208201905061111660008301846110f2565b92915050565b60008060006060848603121561113557611134610fe3565b5b600061114386828701611031565b935050602061115486828701611031565b925050604061116586828701611067565b9150509250925092565b600060ff82169050919050565b6111858161116f565b82525050565b60006020820190506111a0600083018461117c565b92915050565b6000602082840312156111bc576111bb610fe3565b5b60006111ca84828501611067565b91505092915050565b6000602082840312156111e9576111e8610fe3565b5b60006111f784828501611031565b91505092915050565b6000806040838503121561121757611216610fe3565b5b600061122585828601611031565b925050602061123685828601611031565b9150509250929050565b61124981611008565b82525050565b60006020820190506112646000830184611240565b92915050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052602260045260246000fd5b600060028204905060018216806112b157607f821691505b602082108114156112c5576112c461126a565b5b50919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b600061130582611046565b915061131083611046565b9250827fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff03821115611345576113446112cb565b5b828201905092915050565b7f6f6e6c792061646d696e00000000000000000000000000000000000000000000600082015250565b6000611386600a83610f33565b915061139182611350565b602082019050919050565b600060208201905081810360008301526113b581611379565b9050919050565b7f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f7760008201527f207a65726f000000000000000000000000000000000000000000000000000000602082015250565b6000611418602583610f33565b9150611423826113bc565b604082019050919050565b600060208201905081810360008301526114478161140b565b9050919050565b7f45524332303a20617070726f76652066726f6d20746865207a65726f2061646460008201527f7265737300000000000000000000000000000000000000000000000000000000602082015250565b60006114aa602483610f33565b91506114b58261144e565b604082019050919050565b600060208201905081810360008301526114d98161149d565b9050919050565b7f45524332303a20617070726f766520746f20746865207a65726f20616464726560008201527f7373000000000000000000000000000000000000000000000000000000000000602082015250565b600061153c602283610f33565b9150611547826114e0565b604082019050919050565b6000602082019050818103600083015261156b8161152f565b9050919050565b7f45524332303a20696e73756666696369656e7420616c6c6f77616e6365000000600082015250565b60006115a8601d83610f33565b91506115b382611572565b602082019050919050565b600060208201905081810360008301526115d78161159b565b9050919050565b7f45524332303a207472616e736665722066726f6d20746865207a65726f20616460008201527f6472657373000000000000000000000000000000000000000000000000000000602082015250565b600061163a602583610f33565b9150611645826115de565b604082019050919050565b600060208201905081810360008301526116698161162d565b9050919050565b7f45524332303a207472616e7366657220746f20746865207a65726f206164647260008201527f6573730000000000000000000000000000000000000000000000000000000000602082015250565b60006116cc602383610f33565b91506116d782611670565b604082019050919050565b600060208201905081810360008301526116fb816116bf565b9050919050565b7f45524332303a207472616e7366657220616d6f756e742065786365656473206260008201527f616c616e63650000000000000000000000000000000000000000000000000000602082015250565b600061175e602683610f33565b915061176982611702565b604082019050919050565b6000602082019050818103600083015261178d81611751565b9050919050565b7f45524332303a206d696e7420746f20746865207a65726f206164647265737300600082015250565b60006117ca601f83610f33565b91506117d582611794565b602082019050919050565b600060208201905081810360008301526117f9816117bd565b9050919050565b7f45524332303a206275726e2066726f6d20746865207a65726f2061646472657360008201527f7300000000000000000000000000000000000000000000000000000000000000602082015250565b600061185c602183610f33565b915061186782611800565b604082019050919050565b6000602082019050818103600083015261188b8161184f565b9050919050565b7f45524332303a206275726e20616d6f756e7420657863656564732062616c616e60008201527f6365000000000000000000000000000000000000000000000000000000000000602082015250565b60006118ee602283610f33565b91506118f982611892565b604082019050919050565b6000602082019050818103600083015261191d816118e1565b9050919050565b600061192f82611046565b915061193a83611046565b92508282101561194d5761194c6112cb565b5b82820390509291505056fea2646970667358221220e9c0428ade0f70a7f459da08a8ce638b846d243f82689ca036c5173030b8b9f364736f6c634300080c0033

Deployed ByteCode Sourcemap

17754:434:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6898:100;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;9249:201;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;8018:108;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;10030:295;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;7860:93;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;10734:238;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;17954:140;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;18103:82;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;8189:127;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;7117:104;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;11475:436;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;8522:193;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;8778:151;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;17793:20;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;6898:100;6952:13;6985:5;6978:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6898:100;:::o;9249:201::-;9332:4;9349:13;9365:12;:10;:12::i;:::-;9349:28;;9388:32;9397:5;9404:7;9413:6;9388:8;:32::i;:::-;9438:4;9431:11;;;9249:201;;;;:::o;8018:108::-;8079:7;8106:12;;8099:19;;8018:108;:::o;10030:295::-;10161:4;10178:15;10196:12;:10;:12::i;:::-;10178:30;;10219:38;10235:4;10241:7;10250:6;10219:15;:38::i;:::-;10268:27;10278:4;10284:2;10288:6;10268:9;:27::i;:::-;10313:4;10306:11;;;10030:295;;;;;:::o;7860:93::-;7918:5;7943:2;7936:9;;7860:93;:::o;10734:238::-;10822:4;10839:13;10855:12;:10;:12::i;:::-;10839:28;;10878:64;10887:5;10894:7;10931:10;10903:25;10913:5;10920:7;10903:9;:25::i;:::-;:38;;;;:::i;:::-;10878:8;:64::i;:::-;10960:4;10953:11;;;10734:238;;;;:::o;17954:140::-;18036:5;;;;;;;;;;;18022:19;;:10;:19;;;18014:42;;;;;;;;;;;;:::i;:::-;;;;;;;;;18068:17;18074:2;18078:6;18068:5;:17::i;:::-;17954:140;;:::o;18103:82::-;18151:25;18157:10;18169:6;18151:5;:25::i;:::-;18103:82;:::o;8189:127::-;8263:7;8290:9;:18;8300:7;8290:18;;;;;;;;;;;;;;;;8283:25;;8189:127;;;:::o;7117:104::-;7173:13;7206:7;7199:14;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;7117:104;:::o;11475:436::-;11568:4;11585:13;11601:12;:10;:12::i;:::-;11585:28;;11624:24;11651:25;11661:5;11668:7;11651:9;:25::i;:::-;11624:52;;11715:15;11695:16;:35;;11687:85;;;;;;;;;;;;:::i;:::-;;;;;;;;;11808:60;11817:5;11824:7;11852:15;11833:16;:34;11808:8;:60::i;:::-;11899:4;11892:11;;;;11475:436;;;;:::o;8522:193::-;8601:4;8618:13;8634:12;:10;:12::i;:::-;8618:28;;8657;8667:5;8674:2;8678:6;8657:9;:28::i;:::-;8703:4;8696:11;;;8522:193;;;;:::o;8778:151::-;8867:7;8894:11;:18;8906:5;8894:18;;;;;;;;;;;;;;;:27;8913:7;8894:27;;;;;;;;;;;;;;;;8887:34;;8778:151;;;;:::o;17793:20::-;;;;;;;;;;;;;:::o;765:98::-;818:7;845:10;838:17;;765:98;:::o;15109:380::-;15262:1;15245:19;;:5;:19;;;;15237:68;;;;;;;;;;;;:::i;:::-;;;;;;;;;15343:1;15324:21;;:7;:21;;;;15316:68;;;;;;;;;;;;:::i;:::-;;;;;;;;;15427:6;15397:11;:18;15409:5;15397:18;;;;;;;;;;;;;;;:27;15416:7;15397:27;;;;;;;;;;;;;;;:36;;;;15465:7;15449:32;;15458:5;15449:32;;;15474:6;15449:32;;;;;;:::i;:::-;;;;;;;;15109:380;;;:::o;15780:453::-;15915:24;15942:25;15952:5;15959:7;15942:9;:25::i;:::-;15915:52;;16002:17;15982:16;:37;15978:248;;16064:6;16044:16;:26;;16036:68;;;;;;;;;;;;:::i;:::-;;;;;;;;;16148:51;16157:5;16164:7;16192:6;16173:16;:25;16148:8;:51::i;:::-;15978:248;15904:329;15780:453;;;:::o;12390:671::-;12537:1;12521:18;;:4;:18;;;;12513:68;;;;;;;;;;;;:::i;:::-;;;;;;;;;12614:1;12600:16;;:2;:16;;;;12592:64;;;;;;;;;;;;:::i;:::-;;;;;;;;;12669:38;12690:4;12696:2;12700:6;12669:20;:38::i;:::-;12720:19;12742:9;:15;12752:4;12742:15;;;;;;;;;;;;;;;;12720:37;;12791:6;12776:11;:21;;12768:72;;;;;;;;;;;;:::i;:::-;;;;;;;;;12908:6;12894:11;:20;12876:9;:15;12886:4;12876:15;;;;;;;;;;;;;;;:38;;;;12953:6;12936:9;:13;12946:2;12936:13;;;;;;;;;;;;;;;;:23;;;;;;;:::i;:::-;;;;;;;;12992:2;12977:26;;12986:4;12977:26;;;12996:6;12977:26;;;;;;:::i;:::-;;;;;;;;13016:37;13036:4;13042:2;13046:6;13016:19;:37::i;:::-;12502:559;12390:671;;;:::o;13348:399::-;13451:1;13432:21;;:7;:21;;;;13424:65;;;;;;;;;;;;:::i;:::-;;;;;;;;;13502:49;13531:1;13535:7;13544:6;13502:20;:49::i;:::-;13580:6;13564:12;;:22;;;;;;;:::i;:::-;;;;;;;;13619:6;13597:9;:18;13607:7;13597:18;;;;;;;;;;;;;;;;:28;;;;;;;:::i;:::-;;;;;;;;13662:7;13641:37;;13658:1;13641:37;;;13671:6;13641:37;;;;;;:::i;:::-;;;;;;;;13691:48;13719:1;13723:7;13732:6;13691:19;:48::i;:::-;13348:399;;:::o;14080:591::-;14183:1;14164:21;;:7;:21;;;;14156:67;;;;;;;;;;;;:::i;:::-;;;;;;;;;14236:49;14257:7;14274:1;14278:6;14236:20;:49::i;:::-;14298:22;14323:9;:18;14333:7;14323:18;;;;;;;;;;;;;;;;14298:43;;14378:6;14360:14;:24;;14352:71;;;;;;;;;;;;:::i;:::-;;;;;;;;;14497:6;14480:14;:23;14459:9;:18;14469:7;14459:18;;;;;;;;;;;;;;;:44;;;;14541:6;14525:12;;:22;;;;;;;:::i;:::-;;;;;;;;14591:1;14565:37;;14574:7;14565:37;;;14595:6;14565:37;;;;;;:::i;:::-;;;;;;;;14615:48;14635:7;14652:1;14656:6;14615:19;:48::i;:::-;14145:526;14080:591;;:::o;16833:125::-;;;;:::o;17562:124::-;;;;:::o;7:99:1:-;59:6;93:5;87:12;77:22;;7:99;;;:::o;112:169::-;196:11;230:6;225:3;218:19;270:4;265:3;261:14;246:29;;112:169;;;;:::o;287:307::-;355:1;365:113;379:6;376:1;373:13;365:113;;;464:1;459:3;455:11;449:18;445:1;440:3;436:11;429:39;401:2;398:1;394:10;389:15;;365:113;;;496:6;493:1;490:13;487:101;;;576:1;567:6;562:3;558:16;551:27;487:101;336:258;287:307;;;:::o;600:102::-;641:6;692:2;688:7;683:2;676:5;672:14;668:28;658:38;;600:102;;;:::o;708:364::-;796:3;824:39;857:5;824:39;:::i;:::-;879:71;943:6;938:3;879:71;:::i;:::-;872:78;;959:52;1004:6;999:3;992:4;985:5;981:16;959:52;:::i;:::-;1036:29;1058:6;1036:29;:::i;:::-;1031:3;1027:39;1020:46;;800:272;708:364;;;;:::o;1078:313::-;1191:4;1229:2;1218:9;1214:18;1206:26;;1278:9;1272:4;1268:20;1264:1;1253:9;1249:17;1242:47;1306:78;1379:4;1370:6;1306:78;:::i;:::-;1298:86;;1078:313;;;;:::o;1478:117::-;1587:1;1584;1577:12;1724:126;1761:7;1801:42;1794:5;1790:54;1779:65;;1724:126;;;:::o;1856:96::-;1893:7;1922:24;1940:5;1922:24;:::i;:::-;1911:35;;1856:96;;;:::o;1958:122::-;2031:24;2049:5;2031:24;:::i;:::-;2024:5;2021:35;2011:63;;2070:1;2067;2060:12;2011:63;1958:122;:::o;2086:139::-;2132:5;2170:6;2157:20;2148:29;;2186:33;2213:5;2186:33;:::i;:::-;2086:139;;;;:::o;2231:77::-;2268:7;2297:5;2286:16;;2231:77;;;:::o;2314:122::-;2387:24;2405:5;2387:24;:::i;:::-;2380:5;2377:35;2367:63;;2426:1;2423;2416:12;2367:63;2314:122;:::o;2442:139::-;2488:5;2526:6;2513:20;2504:29;;2542:33;2569:5;2542:33;:::i;:::-;2442:139;;;;:::o;2587:474::-;2655:6;2663;2712:2;2700:9;2691:7;2687:23;2683:32;2680:119;;;2718:79;;:::i;:::-;2680:119;2838:1;2863:53;2908:7;2899:6;2888:9;2884:22;2863:53;:::i;:::-;2853:63;;2809:117;2965:2;2991:53;3036:7;3027:6;3016:9;3012:22;2991:53;:::i;:::-;2981:63;;2936:118;2587:474;;;;;:::o;3067:90::-;3101:7;3144:5;3137:13;3130:21;3119:32;;3067:90;;;:::o;3163:109::-;3244:21;3259:5;3244:21;:::i;:::-;3239:3;3232:34;3163:109;;:::o;3278:210::-;3365:4;3403:2;3392:9;3388:18;3380:26;;3416:65;3478:1;3467:9;3463:17;3454:6;3416:65;:::i;:::-;3278:210;;;;:::o;3494:118::-;3581:24;3599:5;3581:24;:::i;:::-;3576:3;3569:37;3494:118;;:::o;3618:222::-;3711:4;3749:2;3738:9;3734:18;3726:26;;3762:71;3830:1;3819:9;3815:17;3806:6;3762:71;:::i;:::-;3618:222;;;;:::o;3846:619::-;3923:6;3931;3939;3988:2;3976:9;3967:7;3963:23;3959:32;3956:119;;;3994:79;;:::i;:::-;3956:119;4114:1;4139:53;4184:7;4175:6;4164:9;4160:22;4139:53;:::i;:::-;4129:63;;4085:117;4241:2;4267:53;4312:7;4303:6;4292:9;4288:22;4267:53;:::i;:::-;4257:63;;4212:118;4369:2;4395:53;4440:7;4431:6;4420:9;4416:22;4395:53;:::i;:::-;4385:63;;4340:118;3846:619;;;;;:::o;4471:86::-;4506:7;4546:4;4539:5;4535:16;4524:27;;4471:86;;;:::o;4563:112::-;4646:22;4662:5;4646:22;:::i;:::-;4641:3;4634:35;4563:112;;:::o;4681:214::-;4770:4;4808:2;4797:9;4793:18;4785:26;;4821:67;4885:1;4874:9;4870:17;4861:6;4821:67;:::i;:::-;4681:214;;;;:::o;4901:329::-;4960:6;5009:2;4997:9;4988:7;4984:23;4980:32;4977:119;;;5015:79;;:::i;:::-;4977:119;5135:1;5160:53;5205:7;5196:6;5185:9;5181:22;5160:53;:::i;:::-;5150:63;;5106:117;4901:329;;;;:::o;5236:::-;5295:6;5344:2;5332:9;5323:7;5319:23;5315:32;5312:119;;;5350:79;;:::i;:::-;5312:119;5470:1;5495:53;5540:7;5531:6;5520:9;5516:22;5495:53;:::i;:::-;5485:63;;5441:117;5236:329;;;;:::o;5571:474::-;5639:6;5647;5696:2;5684:9;5675:7;5671:23;5667:32;5664:119;;;5702:79;;:::i;:::-;5664:119;5822:1;5847:53;5892:7;5883:6;5872:9;5868:22;5847:53;:::i;:::-;5837:63;;5793:117;5949:2;5975:53;6020:7;6011:6;6000:9;5996:22;5975:53;:::i;:::-;5965:63;;5920:118;5571:474;;;;;:::o;6051:118::-;6138:24;6156:5;6138:24;:::i;:::-;6133:3;6126:37;6051:118;;:::o;6175:222::-;6268:4;6306:2;6295:9;6291:18;6283:26;;6319:71;6387:1;6376:9;6372:17;6363:6;6319:71;:::i;:::-;6175:222;;;;:::o;6403:180::-;6451:77;6448:1;6441:88;6548:4;6545:1;6538:15;6572:4;6569:1;6562:15;6589:320;6633:6;6670:1;6664:4;6660:12;6650:22;;6717:1;6711:4;6707:12;6738:18;6728:81;;6794:4;6786:6;6782:17;6772:27;;6728:81;6856:2;6848:6;6845:14;6825:18;6822:38;6819:84;;;6875:18;;:::i;:::-;6819:84;6640:269;6589:320;;;:::o;6915:180::-;6963:77;6960:1;6953:88;7060:4;7057:1;7050:15;7084:4;7081:1;7074:15;7101:305;7141:3;7160:20;7178:1;7160:20;:::i;:::-;7155:25;;7194:20;7212:1;7194:20;:::i;:::-;7189:25;;7348:1;7280:66;7276:74;7273:1;7270:81;7267:107;;;7354:18;;:::i;:::-;7267:107;7398:1;7395;7391:9;7384:16;;7101:305;;;;:::o;7412:160::-;7552:12;7548:1;7540:6;7536:14;7529:36;7412:160;:::o;7578:366::-;7720:3;7741:67;7805:2;7800:3;7741:67;:::i;:::-;7734:74;;7817:93;7906:3;7817:93;:::i;:::-;7935:2;7930:3;7926:12;7919:19;;7578:366;;;:::o;7950:419::-;8116:4;8154:2;8143:9;8139:18;8131:26;;8203:9;8197:4;8193:20;8189:1;8178:9;8174:17;8167:47;8231:131;8357:4;8231:131;:::i;:::-;8223:139;;7950:419;;;:::o;8375:224::-;8515:34;8511:1;8503:6;8499:14;8492:58;8584:7;8579:2;8571:6;8567:15;8560:32;8375:224;:::o;8605:366::-;8747:3;8768:67;8832:2;8827:3;8768:67;:::i;:::-;8761:74;;8844:93;8933:3;8844:93;:::i;:::-;8962:2;8957:3;8953:12;8946:19;;8605:366;;;:::o;8977:419::-;9143:4;9181:2;9170:9;9166:18;9158:26;;9230:9;9224:4;9220:20;9216:1;9205:9;9201:17;9194:47;9258:131;9384:4;9258:131;:::i;:::-;9250:139;;8977:419;;;:::o;9402:223::-;9542:34;9538:1;9530:6;9526:14;9519:58;9611:6;9606:2;9598:6;9594:15;9587:31;9402:223;:::o;9631:366::-;9773:3;9794:67;9858:2;9853:3;9794:67;:::i;:::-;9787:74;;9870:93;9959:3;9870:93;:::i;:::-;9988:2;9983:3;9979:12;9972:19;;9631:366;;;:::o;10003:419::-;10169:4;10207:2;10196:9;10192:18;10184:26;;10256:9;10250:4;10246:20;10242:1;10231:9;10227:17;10220:47;10284:131;10410:4;10284:131;:::i;:::-;10276:139;;10003:419;;;:::o;10428:221::-;10568:34;10564:1;10556:6;10552:14;10545:58;10637:4;10632:2;10624:6;10620:15;10613:29;10428:221;:::o;10655:366::-;10797:3;10818:67;10882:2;10877:3;10818:67;:::i;:::-;10811:74;;10894:93;10983:3;10894:93;:::i;:::-;11012:2;11007:3;11003:12;10996:19;;10655:366;;;:::o;11027:419::-;11193:4;11231:2;11220:9;11216:18;11208:26;;11280:9;11274:4;11270:20;11266:1;11255:9;11251:17;11244:47;11308:131;11434:4;11308:131;:::i;:::-;11300:139;;11027:419;;;:::o;11452:179::-;11592:31;11588:1;11580:6;11576:14;11569:55;11452:179;:::o;11637:366::-;11779:3;11800:67;11864:2;11859:3;11800:67;:::i;:::-;11793:74;;11876:93;11965:3;11876:93;:::i;:::-;11994:2;11989:3;11985:12;11978:19;;11637:366;;;:::o;12009:419::-;12175:4;12213:2;12202:9;12198:18;12190:26;;12262:9;12256:4;12252:20;12248:1;12237:9;12233:17;12226:47;12290:131;12416:4;12290:131;:::i;:::-;12282:139;;12009:419;;;:::o;12434:224::-;12574:34;12570:1;12562:6;12558:14;12551:58;12643:7;12638:2;12630:6;12626:15;12619:32;12434:224;:::o;12664:366::-;12806:3;12827:67;12891:2;12886:3;12827:67;:::i;:::-;12820:74;;12903:93;12992:3;12903:93;:::i;:::-;13021:2;13016:3;13012:12;13005:19;;12664:366;;;:::o;13036:419::-;13202:4;13240:2;13229:9;13225:18;13217:26;;13289:9;13283:4;13279:20;13275:1;13264:9;13260:17;13253:47;13317:131;13443:4;13317:131;:::i;:::-;13309:139;;13036:419;;;:::o;13461:222::-;13601:34;13597:1;13589:6;13585:14;13578:58;13670:5;13665:2;13657:6;13653:15;13646:30;13461:222;:::o;13689:366::-;13831:3;13852:67;13916:2;13911:3;13852:67;:::i;:::-;13845:74;;13928:93;14017:3;13928:93;:::i;:::-;14046:2;14041:3;14037:12;14030:19;;13689:366;;;:::o;14061:419::-;14227:4;14265:2;14254:9;14250:18;14242:26;;14314:9;14308:4;14304:20;14300:1;14289:9;14285:17;14278:47;14342:131;14468:4;14342:131;:::i;:::-;14334:139;;14061:419;;;:::o;14486:225::-;14626:34;14622:1;14614:6;14610:14;14603:58;14695:8;14690:2;14682:6;14678:15;14671:33;14486:225;:::o;14717:366::-;14859:3;14880:67;14944:2;14939:3;14880:67;:::i;:::-;14873:74;;14956:93;15045:3;14956:93;:::i;:::-;15074:2;15069:3;15065:12;15058:19;;14717:366;;;:::o;15089:419::-;15255:4;15293:2;15282:9;15278:18;15270:26;;15342:9;15336:4;15332:20;15328:1;15317:9;15313:17;15306:47;15370:131;15496:4;15370:131;:::i;:::-;15362:139;;15089:419;;;:::o;15514:181::-;15654:33;15650:1;15642:6;15638:14;15631:57;15514:181;:::o;15701:366::-;15843:3;15864:67;15928:2;15923:3;15864:67;:::i;:::-;15857:74;;15940:93;16029:3;15940:93;:::i;:::-;16058:2;16053:3;16049:12;16042:19;;15701:366;;;:::o;16073:419::-;16239:4;16277:2;16266:9;16262:18;16254:26;;16326:9;16320:4;16316:20;16312:1;16301:9;16297:17;16290:47;16354:131;16480:4;16354:131;:::i;:::-;16346:139;;16073:419;;;:::o;16498:220::-;16638:34;16634:1;16626:6;16622:14;16615:58;16707:3;16702:2;16694:6;16690:15;16683:28;16498:220;:::o;16724:366::-;16866:3;16887:67;16951:2;16946:3;16887:67;:::i;:::-;16880:74;;16963:93;17052:3;16963:93;:::i;:::-;17081:2;17076:3;17072:12;17065:19;;16724:366;;;:::o;17096:419::-;17262:4;17300:2;17289:9;17285:18;17277:26;;17349:9;17343:4;17339:20;17335:1;17324:9;17320:17;17313:47;17377:131;17503:4;17377:131;:::i;:::-;17369:139;;17096:419;;;:::o;17521:221::-;17661:34;17657:1;17649:6;17645:14;17638:58;17730:4;17725:2;17717:6;17713:15;17706:29;17521:221;:::o;17748:366::-;17890:3;17911:67;17975:2;17970:3;17911:67;:::i;:::-;17904:74;;17987:93;18076:3;17987:93;:::i;:::-;18105:2;18100:3;18096:12;18089:19;;17748:366;;;:::o;18120:419::-;18286:4;18324:2;18313:9;18309:18;18301:26;;18373:9;18367:4;18363:20;18359:1;18348:9;18344:17;18337:47;18401:131;18527:4;18401:131;:::i;:::-;18393:139;;18120:419;;;:::o;18545:191::-;18585:4;18605:20;18623:1;18605:20;:::i;:::-;18600:25;;18639:20;18657:1;18639:20;:::i;:::-;18634:25;;18678:1;18675;18672:8;18669:34;;;18683:18;;:::i;:::-;18669:34;18728:1;18725;18721:9;18713:17;;18545:191;;;;:::o

Swarm Source

ipfs://e9c0428ade0f70a7f459da08a8ce638b846d243f82689ca036c5173030b8b9f3

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.