Token SpaceY Token

 

Overview [ERC-20]

Max Total Supply:
4,260,789.6 SPAY

Holders:
69

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

Compiler Version
v0.8.0+commit.c7dfd78e

Optimization Enabled:
No with 200 runs

Other Settings:
default evmVersion, MIT license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2021-03-29
*/

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

// SPDX-License-Identifier: MIT

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 `recipient`.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * Emits a {Transfer} event.
     */
    function transfer(address recipient, uint256 amount) external returns (bool);

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

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

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

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

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

// File: @openzeppelin/contracts/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) {
        this; // silence state mutability warning without generating bytecode - see https://github.com/ethereum/solidity/issues/2691
        return msg.data;
    }
}

// File: @openzeppelin/contracts/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 guidelines: functions revert instead
 * of 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 {
    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 defaut value of {decimals} is 18. To select a different value for
     * {decimals} you should overload it.
     *
     * All three 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 returns (string memory) {
        return _name;
    }

    /**
     * @dev Returns the symbol of the token, usually a shorter version of the
     * name.
     */
    function symbol() public view virtual 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
     * overloaded;
     *
     * 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 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:
     *
     * - `recipient` cannot be the zero address.
     * - the caller must have a balance of at least `amount`.
     */
    function transfer(address recipient, uint256 amount) public virtual override returns (bool) {
        _transfer(_msgSender(), recipient, 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}.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     */
    function approve(address spender, uint256 amount) public virtual override returns (bool) {
        _approve(_msgSender(), 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}.
     *
     * Requirements:
     *
     * - `sender` and `recipient` cannot be the zero address.
     * - `sender` must have a balance of at least `amount`.
     * - the caller must have allowance for ``sender``'s tokens of at least
     * `amount`.
     */
    function transferFrom(address sender, address recipient, uint256 amount) public virtual override returns (bool) {
        _transfer(sender, recipient, amount);

        uint256 currentAllowance = _allowances[sender][_msgSender()];
        require(currentAllowance >= amount, "ERC20: transfer amount exceeds allowance");
        _approve(sender, _msgSender(), currentAllowance - 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) {
        _approve(_msgSender(), spender, _allowances[_msgSender()][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) {
        uint256 currentAllowance = _allowances[_msgSender()][spender];
        require(currentAllowance >= subtractedValue, "ERC20: decreased allowance below zero");
        _approve(_msgSender(), spender, currentAllowance - subtractedValue);

        return true;
    }

    /**
     * @dev Moves tokens `amount` from `sender` to `recipient`.
     *
     * This is 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:
     *
     * - `sender` cannot be the zero address.
     * - `recipient` cannot be the zero address.
     * - `sender` must have a balance of at least `amount`.
     */
    function _transfer(address sender, address recipient, uint256 amount) internal virtual {
        require(sender != address(0), "ERC20: transfer from the zero address");
        require(recipient != address(0), "ERC20: transfer to the zero address");

        _beforeTokenTransfer(sender, recipient, amount);

        uint256 senderBalance = _balances[sender];
        require(senderBalance >= amount, "ERC20: transfer amount exceeds balance");
        _balances[sender] = senderBalance - amount;
        _balances[recipient] += amount;

        emit Transfer(sender, recipient, 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:
     *
     * - `to` 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);
    }

    /**
     * @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");
        _balances[account] = accountBalance - amount;
        _totalSupply -= amount;

        emit Transfer(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 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 to 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 { }
}

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

pragma solidity ^0.8.0;


/**
 * @dev Extension of {ERC20} that adds a cap to the supply of tokens.
 */
abstract contract ERC20Capped is ERC20 {
    uint256 immutable private _cap;

    /**
     * @dev Sets the value of the `cap`. This value is immutable, it can only be
     * set once during construction.
     */
    constructor (uint256 cap_) {
        require(cap_ > 0, "ERC20Capped: cap is 0");
        _cap = cap_;
    }

    /**
     * @dev Returns the cap on the token's total supply.
     */
    function cap() public view virtual returns (uint256) {
        return _cap;
    }

    /**
     * @dev See {ERC20-_mint}.
     */
    function _mint(address account, uint256 amount) internal virtual override {
        require(ERC20.totalSupply() + amount <= cap(), "ERC20Capped: cap exceeded");
        super._mint(account, amount);
    }
}

// File: @openzeppelin/contracts/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 {
        uint256 currentAllowance = allowance(account, _msgSender());
        require(currentAllowance >= amount, "ERC20: burn amount exceeds allowance");
        _approve(account, _msgSender(), currentAllowance - amount);
        _burn(account, amount);
    }
}

// File: @openzeppelin/contracts/security/Pausable.sol

pragma solidity ^0.8.0;


/**
 * @dev Contract module which allows children to implement an emergency stop
 * mechanism that can be triggered by an authorized account.
 *
 * This module is used through inheritance. It will make available the
 * modifiers `whenNotPaused` and `whenPaused`, which can be applied to
 * the functions of your contract. Note that they will not be pausable by
 * simply including this module, only once the modifiers are put in place.
 */
abstract contract Pausable is Context {
    /**
     * @dev Emitted when the pause is triggered by `account`.
     */
    event Paused(address account);

    /**
     * @dev Emitted when the pause is lifted by `account`.
     */
    event Unpaused(address account);

    bool private _paused;

    /**
     * @dev Initializes the contract in unpaused state.
     */
    constructor () {
        _paused = false;
    }

    /**
     * @dev Returns true if the contract is paused, and false otherwise.
     */
    function paused() public view virtual returns (bool) {
        return _paused;
    }

    /**
     * @dev Modifier to make a function callable only when the contract is not paused.
     *
     * Requirements:
     *
     * - The contract must not be paused.
     */
    modifier whenNotPaused() {
        require(!paused(), "Pausable: paused");
        _;
    }

    /**
     * @dev Modifier to make a function callable only when the contract is paused.
     *
     * Requirements:
     *
     * - The contract must be paused.
     */
    modifier whenPaused() {
        require(paused(), "Pausable: not paused");
        _;
    }

    /**
     * @dev Triggers stopped state.
     *
     * Requirements:
     *
     * - The contract must not be paused.
     */
    function _pause() internal virtual whenNotPaused {
        _paused = true;
        emit Paused(_msgSender());
    }

    /**
     * @dev Returns to normal state.
     *
     * Requirements:
     *
     * - The contract must be paused.
     */
    function _unpause() internal virtual whenPaused {
        _paused = false;
        emit Unpaused(_msgSender());
    }
}

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

pragma solidity ^0.8.0;



/**
 * @dev ERC20 token with pausable token transfers, minting and burning.
 *
 * Useful for scenarios such as preventing trades until the end of an evaluation
 * period, or having an emergency switch for freezing all token transfers in the
 * event of a large bug.
 */
abstract contract ERC20Pausable is ERC20, Pausable {
    /**
     * @dev See {ERC20-_beforeTokenTransfer}.
     *
     * Requirements:
     *
     * - the contract must not be paused.
     */
    function _beforeTokenTransfer(address from, address to, uint256 amount) internal virtual override {
        super._beforeTokenTransfer(from, to, amount);

        require(!paused(), "ERC20Pausable: token transfer while paused");
    }
}

// File: @openzeppelin/contracts/utils/introspection/IERC165.sol

pragma solidity ^0.8.0;

/**
 * @dev Interface of the ERC165 standard, as defined in the
 * https://eips.ethereum.org/EIPS/eip-165[EIP].
 *
 * Implementers can declare support of contract interfaces, which can then be
 * queried by others ({ERC165Checker}).
 *
 * For an implementation, see {ERC165}.
 */
interface IERC165 {
    /**
     * @dev Returns true if this contract implements the interface defined by
     * `interfaceId`. See the corresponding
     * https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section]
     * to learn more about how these ids are created.
     *
     * This function call must use less than 30 000 gas.
     */
    function supportsInterface(bytes4 interfaceId) external view returns (bool);
}

// File: @openzeppelin/contracts/utils/introspection/ERC165.sol

pragma solidity ^0.8.0;


/**
 * @dev Implementation of the {IERC165} interface.
 *
 * Contracts that want to implement ERC165 should inherit from this contract and override {supportsInterface} to check
 * for the additional interface id that will be supported. For example:
 *
 * ```solidity
 * function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {
 *     return interfaceId == type(MyInterface).interfaceId || super.supportsInterface(interfaceId);
 * }
 * ```
 *
 * Alternatively, {ERC165Storage} provides an easier to use but more expensive implementation.
 */
abstract contract ERC165 is IERC165 {
    /**
     * @dev See {IERC165-supportsInterface}.
     */
    function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {
        return interfaceId == type(IERC165).interfaceId;
    }
}

// File: @openzeppelin/contracts/access/AccessControl.sol

pragma solidity ^0.8.0;



/**
 * @dev External interface of AccessControl declared to support ERC165 detection.
 */
interface IAccessControl {
    function hasRole(bytes32 role, address account) external view returns (bool);
    function getRoleAdmin(bytes32 role) external view returns (bytes32);
    function grantRole(bytes32 role, address account) external;
    function revokeRole(bytes32 role, address account) external;
    function renounceRole(bytes32 role, address account) external;
}

/**
 * @dev Contract module that allows children to implement role-based access
 * control mechanisms. This is a lightweight version that doesn't allow enumerating role
 * members except through off-chain means by accessing the contract event logs. Some
 * applications may benefit from on-chain enumerability, for those cases see
 * {AccessControlEnumerable}.
 *
 * Roles are referred to by their `bytes32` identifier. These should be exposed
 * in the external API and be unique. The best way to achieve this is by
 * using `public constant` hash digests:
 *
 * ```
 * bytes32 public constant MY_ROLE = keccak256("MY_ROLE");
 * ```
 *
 * Roles can be used to represent a set of permissions. To restrict access to a
 * function call, use {hasRole}:
 *
 * ```
 * function foo() public {
 *     require(hasRole(MY_ROLE, msg.sender));
 *     ...
 * }
 * ```
 *
 * Roles can be granted and revoked dynamically via the {grantRole} and
 * {revokeRole} functions. Each role has an associated admin role, and only
 * accounts that have a role's admin role can call {grantRole} and {revokeRole}.
 *
 * By default, the admin role for all roles is `DEFAULT_ADMIN_ROLE`, which means
 * that only accounts with this role will be able to grant or revoke other
 * roles. More complex role relationships can be created by using
 * {_setRoleAdmin}.
 *
 * WARNING: The `DEFAULT_ADMIN_ROLE` is also its own admin: it has permission to
 * grant and revoke this role. Extra precautions should be taken to secure
 * accounts that have been granted it.
 */
abstract contract AccessControl is Context, IAccessControl, ERC165 {
    struct RoleData {
        mapping (address => bool) members;
        bytes32 adminRole;
    }

    mapping (bytes32 => RoleData) private _roles;

    bytes32 public constant DEFAULT_ADMIN_ROLE = 0x00;

    /**
     * @dev Emitted when `newAdminRole` is set as ``role``'s admin role, replacing `previousAdminRole`
     *
     * `DEFAULT_ADMIN_ROLE` is the starting admin for all roles, despite
     * {RoleAdminChanged} not being emitted signaling this.
     *
     * _Available since v3.1._
     */
    event RoleAdminChanged(bytes32 indexed role, bytes32 indexed previousAdminRole, bytes32 indexed newAdminRole);

    /**
     * @dev Emitted when `account` is granted `role`.
     *
     * `sender` is the account that originated the contract call, an admin role
     * bearer except when using {_setupRole}.
     */
    event RoleGranted(bytes32 indexed role, address indexed account, address indexed sender);

    /**
     * @dev Emitted when `account` is revoked `role`.
     *
     * `sender` is the account that originated the contract call:
     *   - if using `revokeRole`, it is the admin role bearer
     *   - if using `renounceRole`, it is the role bearer (i.e. `account`)
     */
    event RoleRevoked(bytes32 indexed role, address indexed account, address indexed sender);

    /**
     * @dev See {IERC165-supportsInterface}.
     */
    function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {
        return interfaceId == type(IAccessControl).interfaceId
            || super.supportsInterface(interfaceId);
    }

    /**
     * @dev Returns `true` if `account` has been granted `role`.
     */
    function hasRole(bytes32 role, address account) public view override returns (bool) {
        return _roles[role].members[account];
    }

    /**
     * @dev Returns the admin role that controls `role`. See {grantRole} and
     * {revokeRole}.
     *
     * To change a role's admin, use {_setRoleAdmin}.
     */
    function getRoleAdmin(bytes32 role) public view override returns (bytes32) {
        return _roles[role].adminRole;
    }

    /**
     * @dev Grants `role` to `account`.
     *
     * If `account` had not been already granted `role`, emits a {RoleGranted}
     * event.
     *
     * Requirements:
     *
     * - the caller must have ``role``'s admin role.
     */
    function grantRole(bytes32 role, address account) public virtual override {
        require(hasRole(getRoleAdmin(role), _msgSender()), "AccessControl: sender must be an admin to grant");

        _grantRole(role, account);
    }

    /**
     * @dev Revokes `role` from `account`.
     *
     * If `account` had been granted `role`, emits a {RoleRevoked} event.
     *
     * Requirements:
     *
     * - the caller must have ``role``'s admin role.
     */
    function revokeRole(bytes32 role, address account) public virtual override {
        require(hasRole(getRoleAdmin(role), _msgSender()), "AccessControl: sender must be an admin to revoke");

        _revokeRole(role, account);
    }

    /**
     * @dev Revokes `role` from the calling account.
     *
     * Roles are often managed via {grantRole} and {revokeRole}: this function's
     * purpose is to provide a mechanism for accounts to lose their privileges
     * if they are compromised (such as when a trusted device is misplaced).
     *
     * If the calling account had been granted `role`, emits a {RoleRevoked}
     * event.
     *
     * Requirements:
     *
     * - the caller must be `account`.
     */
    function renounceRole(bytes32 role, address account) public virtual override {
        require(account == _msgSender(), "AccessControl: can only renounce roles for self");

        _revokeRole(role, account);
    }

    /**
     * @dev Grants `role` to `account`.
     *
     * If `account` had not been already granted `role`, emits a {RoleGranted}
     * event. Note that unlike {grantRole}, this function doesn't perform any
     * checks on the calling account.
     *
     * [WARNING]
     * ====
     * This function should only be called from the constructor when setting
     * up the initial roles for the system.
     *
     * Using this function in any other way is effectively circumventing the admin
     * system imposed by {AccessControl}.
     * ====
     */
    function _setupRole(bytes32 role, address account) internal virtual {
        _grantRole(role, account);
    }

    /**
     * @dev Sets `adminRole` as ``role``'s admin role.
     *
     * Emits a {RoleAdminChanged} event.
     */
    function _setRoleAdmin(bytes32 role, bytes32 adminRole) internal virtual {
        emit RoleAdminChanged(role, getRoleAdmin(role), adminRole);
        _roles[role].adminRole = adminRole;
    }

    function _grantRole(bytes32 role, address account) private {
        if (!hasRole(role, account)) {
            _roles[role].members[account] = true;
            emit RoleGranted(role, account, _msgSender());
        }
    }

    function _revokeRole(bytes32 role, address account) private {
        if (hasRole(role, account)) {
            _roles[role].members[account] = false;
            emit RoleRevoked(role, account, _msgSender());
        }
    }
}

// File: @openzeppelin/contracts/utils/structs/EnumerableSet.sol

pragma solidity ^0.8.0;

/**
 * @dev Library for managing
 * https://en.wikipedia.org/wiki/Set_(abstract_data_type)[sets] of primitive
 * types.
 *
 * Sets have the following properties:
 *
 * - Elements are added, removed, and checked for existence in constant time
 * (O(1)).
 * - Elements are enumerated in O(n). No guarantees are made on the ordering.
 *
 * ```
 * contract Example {
 *     // Add the library methods
 *     using EnumerableSet for EnumerableSet.AddressSet;
 *
 *     // Declare a set state variable
 *     EnumerableSet.AddressSet private mySet;
 * }
 * ```
 *
 * As of v3.3.0, sets of type `bytes32` (`Bytes32Set`), `address` (`AddressSet`)
 * and `uint256` (`UintSet`) are supported.
 */
library EnumerableSet {
    // To implement this library for multiple types with as little code
    // repetition as possible, we write it in terms of a generic Set type with
    // bytes32 values.
    // The Set implementation uses private functions, and user-facing
    // implementations (such as AddressSet) are just wrappers around the
    // underlying Set.
    // This means that we can only create new EnumerableSets for types that fit
    // in bytes32.

    struct Set {
        // Storage of set values
        bytes32[] _values;

        // Position of the value in the `values` array, plus 1 because index 0
        // means a value is not in the set.
        mapping (bytes32 => uint256) _indexes;
    }

    /**
     * @dev Add a value to a set. O(1).
     *
     * Returns true if the value was added to the set, that is if it was not
     * already present.
     */
    function _add(Set storage set, bytes32 value) private returns (bool) {
        if (!_contains(set, value)) {
            set._values.push(value);
            // The value is stored at length-1, but we add 1 to all indexes
            // and use 0 as a sentinel value
            set._indexes[value] = set._values.length;
            return true;
        } else {
            return false;
        }
    }

    /**
     * @dev Removes a value from a set. O(1).
     *
     * Returns true if the value was removed from the set, that is if it was
     * present.
     */
    function _remove(Set storage set, bytes32 value) private returns (bool) {
        // We read and store the value's index to prevent multiple reads from the same storage slot
        uint256 valueIndex = set._indexes[value];

        if (valueIndex != 0) { // Equivalent to contains(set, value)
            // To delete an element from the _values array in O(1), we swap the element to delete with the last one in
            // the array, and then remove the last element (sometimes called as 'swap and pop').
            // This modifies the order of the array, as noted in {at}.

            uint256 toDeleteIndex = valueIndex - 1;
            uint256 lastIndex = set._values.length - 1;

            // When the value to delete is the last one, the swap operation is unnecessary. However, since this occurs
            // so rarely, we still do the swap anyway to avoid the gas cost of adding an 'if' statement.

            bytes32 lastvalue = set._values[lastIndex];

            // Move the last value to the index where the value to delete is
            set._values[toDeleteIndex] = lastvalue;
            // Update the index for the moved value
            set._indexes[lastvalue] = toDeleteIndex + 1; // All indexes are 1-based

            // Delete the slot where the moved value was stored
            set._values.pop();

            // Delete the index for the deleted slot
            delete set._indexes[value];

            return true;
        } else {
            return false;
        }
    }

    /**
     * @dev Returns true if the value is in the set. O(1).
     */
    function _contains(Set storage set, bytes32 value) private view returns (bool) {
        return set._indexes[value] != 0;
    }

    /**
     * @dev Returns the number of values on the set. O(1).
     */
    function _length(Set storage set) private view returns (uint256) {
        return set._values.length;
    }

   /**
    * @dev Returns the value stored at position `index` in the set. O(1).
    *
    * Note that there are no guarantees on the ordering of values inside the
    * array, and it may change when more values are added or removed.
    *
    * Requirements:
    *
    * - `index` must be strictly less than {length}.
    */
    function _at(Set storage set, uint256 index) private view returns (bytes32) {
        require(set._values.length > index, "EnumerableSet: index out of bounds");
        return set._values[index];
    }

    // Bytes32Set

    struct Bytes32Set {
        Set _inner;
    }

    /**
     * @dev Add a value to a set. O(1).
     *
     * Returns true if the value was added to the set, that is if it was not
     * already present.
     */
    function add(Bytes32Set storage set, bytes32 value) internal returns (bool) {
        return _add(set._inner, value);
    }

    /**
     * @dev Removes a value from a set. O(1).
     *
     * Returns true if the value was removed from the set, that is if it was
     * present.
     */
    function remove(Bytes32Set storage set, bytes32 value) internal returns (bool) {
        return _remove(set._inner, value);
    }

    /**
     * @dev Returns true if the value is in the set. O(1).
     */
    function contains(Bytes32Set storage set, bytes32 value) internal view returns (bool) {
        return _contains(set._inner, value);
    }

    /**
     * @dev Returns the number of values in the set. O(1).
     */
    function length(Bytes32Set storage set) internal view returns (uint256) {
        return _length(set._inner);
    }

   /**
    * @dev Returns the value stored at position `index` in the set. O(1).
    *
    * Note that there are no guarantees on the ordering of values inside the
    * array, and it may change when more values are added or removed.
    *
    * Requirements:
    *
    * - `index` must be strictly less than {length}.
    */
    function at(Bytes32Set storage set, uint256 index) internal view returns (bytes32) {
        return _at(set._inner, index);
    }

    // AddressSet

    struct AddressSet {
        Set _inner;
    }

    /**
     * @dev Add a value to a set. O(1).
     *
     * Returns true if the value was added to the set, that is if it was not
     * already present.
     */
    function add(AddressSet storage set, address value) internal returns (bool) {
        return _add(set._inner, bytes32(uint256(uint160(value))));
    }

    /**
     * @dev Removes a value from a set. O(1).
     *
     * Returns true if the value was removed from the set, that is if it was
     * present.
     */
    function remove(AddressSet storage set, address value) internal returns (bool) {
        return _remove(set._inner, bytes32(uint256(uint160(value))));
    }

    /**
     * @dev Returns true if the value is in the set. O(1).
     */
    function contains(AddressSet storage set, address value) internal view returns (bool) {
        return _contains(set._inner, bytes32(uint256(uint160(value))));
    }

    /**
     * @dev Returns the number of values in the set. O(1).
     */
    function length(AddressSet storage set) internal view returns (uint256) {
        return _length(set._inner);
    }

   /**
    * @dev Returns the value stored at position `index` in the set. O(1).
    *
    * Note that there are no guarantees on the ordering of values inside the
    * array, and it may change when more values are added or removed.
    *
    * Requirements:
    *
    * - `index` must be strictly less than {length}.
    */
    function at(AddressSet storage set, uint256 index) internal view returns (address) {
        return address(uint160(uint256(_at(set._inner, index))));
    }


    // UintSet

    struct UintSet {
        Set _inner;
    }

    /**
     * @dev Add a value to a set. O(1).
     *
     * Returns true if the value was added to the set, that is if it was not
     * already present.
     */
    function add(UintSet storage set, uint256 value) internal returns (bool) {
        return _add(set._inner, bytes32(value));
    }

    /**
     * @dev Removes a value from a set. O(1).
     *
     * Returns true if the value was removed from the set, that is if it was
     * present.
     */
    function remove(UintSet storage set, uint256 value) internal returns (bool) {
        return _remove(set._inner, bytes32(value));
    }

    /**
     * @dev Returns true if the value is in the set. O(1).
     */
    function contains(UintSet storage set, uint256 value) internal view returns (bool) {
        return _contains(set._inner, bytes32(value));
    }

    /**
     * @dev Returns the number of values on the set. O(1).
     */
    function length(UintSet storage set) internal view returns (uint256) {
        return _length(set._inner);
    }

   /**
    * @dev Returns the value stored at position `index` in the set. O(1).
    *
    * Note that there are no guarantees on the ordering of values inside the
    * array, and it may change when more values are added or removed.
    *
    * Requirements:
    *
    * - `index` must be strictly less than {length}.
    */
    function at(UintSet storage set, uint256 index) internal view returns (uint256) {
        return uint256(_at(set._inner, index));
    }
}

// File: @openzeppelin/contracts/access/AccessControlEnumerable.sol

pragma solidity ^0.8.0;



/**
 * @dev External interface of AccessControlEnumerable declared to support ERC165 detection.
 */
interface IAccessControlEnumerable {
    function getRoleMember(bytes32 role, uint256 index) external view returns (address);
    function getRoleMemberCount(bytes32 role) external view returns (uint256);
}

/**
 * @dev Extension of {AccessControl} that allows enumerating the members of each role.
 */
abstract contract AccessControlEnumerable is IAccessControlEnumerable, AccessControl {
    using EnumerableSet for EnumerableSet.AddressSet;

    mapping (bytes32 => EnumerableSet.AddressSet) private _roleMembers;

    /**
     * @dev See {IERC165-supportsInterface}.
     */
    function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {
        return interfaceId == type(IAccessControlEnumerable).interfaceId
            || super.supportsInterface(interfaceId);
    }

    /**
     * @dev Returns one of the accounts that have `role`. `index` must be a
     * value between 0 and {getRoleMemberCount}, non-inclusive.
     *
     * Role bearers are not sorted in any particular way, and their ordering may
     * change at any point.
     *
     * WARNING: When using {getRoleMember} and {getRoleMemberCount}, make sure
     * you perform all queries on the same block. See the following
     * https://forum.openzeppelin.com/t/iterating-over-elements-on-enumerableset-in-openzeppelin-contracts/2296[forum post]
     * for more information.
     */
    function getRoleMember(bytes32 role, uint256 index) public view override returns (address) {
        return _roleMembers[role].at(index);
    }

    /**
     * @dev Returns the number of accounts that have `role`. Can be used
     * together with {getRoleMember} to enumerate all bearers of a role.
     */
    function getRoleMemberCount(bytes32 role) public view override returns (uint256) {
        return _roleMembers[role].length();
    }

    /**
     * @dev Overload {grantRole} to track enumerable memberships
     */
    function grantRole(bytes32 role, address account) public virtual override {
        super.grantRole(role, account);
        _roleMembers[role].add(account);
    }

    /**
     * @dev Overload {revokeRole} to track enumerable memberships
     */
    function revokeRole(bytes32 role, address account) public virtual override {
        super.revokeRole(role, account);
        _roleMembers[role].remove(account);
    }

    /**
     * @dev Overload {renounceRole} to track enumerable memberships
     */
    function renounceRole(bytes32 role, address account) public virtual override {
        super.renounceRole(role, account);
        _roleMembers[role].remove(account);
    }

    /**
     * @dev Overload {_setupRole} to track enumerable memberships
     */
    function _setupRole(bytes32 role, address account) internal virtual override {
        super._setupRole(role, account);
        _roleMembers[role].add(account);
    }
}

// File: @openzeppelin/contracts/token/ERC20/presets/ERC20PresetMinterPauser.sol

pragma solidity ^0.8.0;






/**
 * @dev {ERC20} token, including:
 *
 *  - ability for holders to burn (destroy) their tokens
 *  - a minter role that allows for token minting (creation)
 *  - a pauser role that allows to stop all token transfers
 *
 * This contract uses {AccessControl} to lock permissioned functions using the
 * different roles - head to its documentation for details.
 *
 * The account that deploys the contract will be granted the minter and pauser
 * roles, as well as the default admin role, which will let it grant both minter
 * and pauser roles to other accounts.
 * 
 * Author: Kevin Huang
 */
contract ERC20PresetMinterPauser is Context, AccessControlEnumerable, ERC20Burnable, ERC20Pausable {
    bytes32 public constant MINTER_ROLE = keccak256("MINTER_ROLE");
    bytes32 public constant PAUSER_ROLE = keccak256("PAUSER_ROLE");

    /**
     * @dev Grants `DEFAULT_ADMIN_ROLE`, `MINTER_ROLE` and `PAUSER_ROLE` to the
     * account that deploys the contract.
     *
     * See {ERC20-constructor}.
     */
    constructor(string memory name, string memory symbol) ERC20(name, symbol) {
        _setupRole(DEFAULT_ADMIN_ROLE, _msgSender());

        _setupRole(MINTER_ROLE, _msgSender());
        _setupRole(PAUSER_ROLE, _msgSender());
    }

    /**
     * @dev Creates `amount` new tokens for `to`.
     *
     * See {ERC20-_mint}.
     *
     * Requirements:
     *
     * - the caller must have the `MINTER_ROLE`.
     */
    function mint(address to, uint256 amount) public virtual {
        require(hasRole(MINTER_ROLE, _msgSender()), "ERC20PresetMinterPauser: must have minter role to mint");
        _mint(to, amount);
    }

    /**
     * @dev Pauses all token transfers.
     *
     * See {ERC20Pausable} and {Pausable-_pause}.
     *
     * Requirements:
     *
     * - the caller must have the `PAUSER_ROLE`.
     */
    function pause() public virtual {
        require(hasRole(PAUSER_ROLE, _msgSender()), "ERC20PresetMinterPauser: must have pauser role to pause");
        _pause();
    }

    /**
     * @dev Unpauses all token transfers.
     *
     * See {ERC20Pausable} and {Pausable-_unpause}.
     *
     * Requirements:
     *
     * - the caller must have the `PAUSER_ROLE`.
     */
    function unpause() public virtual {
        require(hasRole(PAUSER_ROLE, _msgSender()), "ERC20PresetMinterPauser: must have pauser role to unpause");
        _unpause();
    }

    function _beforeTokenTransfer(address from, address to, uint256 amount) internal virtual override(ERC20, ERC20Pausable) {
        super._beforeTokenTransfer(from, to, amount);
    }
}

// File: contracts/SPAY.sol

// contracts/MyNFT.sol
pragma solidity ^0.8.0;



contract SPAY is ERC20PresetMinterPauser, ERC20Capped {

    constructor()
        ERC20PresetMinterPauser("SpaceY Token", "SPAY")
        ERC20Capped(25000000 * (10**uint256(18)))
    {}

    function _beforeTokenTransfer(
        address from,
        address to,
        uint256 amount
    ) internal virtual override(ERC20, ERC20PresetMinterPauser) {
        super._beforeTokenTransfer(from, to, amount);
    }

    function _mint(
        address account,
        uint256 amount
    ) internal virtual override(ERC20, ERC20Capped) {
        super._mint(account, 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":false,"internalType":"address","name":"account","type":"address"}],"name":"Paused","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"role","type":"bytes32"},{"indexed":true,"internalType":"bytes32","name":"previousAdminRole","type":"bytes32"},{"indexed":true,"internalType":"bytes32","name":"newAdminRole","type":"bytes32"}],"name":"RoleAdminChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"role","type":"bytes32"},{"indexed":true,"internalType":"address","name":"account","type":"address"},{"indexed":true,"internalType":"address","name":"sender","type":"address"}],"name":"RoleGranted","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"role","type":"bytes32"},{"indexed":true,"internalType":"address","name":"account","type":"address"},{"indexed":true,"internalType":"address","name":"sender","type":"address"}],"name":"RoleRevoked","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"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"account","type":"address"}],"name":"Unpaused","type":"event"},{"inputs":[],"name":"DEFAULT_ADMIN_ROLE","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"MINTER_ROLE","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"PAUSER_ROLE","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"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":[{"internalType":"address","name":"account","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"burnFrom","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"cap","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","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":"bytes32","name":"role","type":"bytes32"}],"name":"getRoleAdmin","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bytes32","name":"role","type":"bytes32"},{"internalType":"uint256","name":"index","type":"uint256"}],"name":"getRoleMember","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bytes32","name":"role","type":"bytes32"}],"name":"getRoleMemberCount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bytes32","name":"role","type":"bytes32"},{"internalType":"address","name":"account","type":"address"}],"name":"grantRole","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bytes32","name":"role","type":"bytes32"},{"internalType":"address","name":"account","type":"address"}],"name":"hasRole","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","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":"pause","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"paused","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bytes32","name":"role","type":"bytes32"},{"internalType":"address","name":"account","type":"address"}],"name":"renounceRole","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bytes32","name":"role","type":"bytes32"},{"internalType":"address","name":"account","type":"address"}],"name":"revokeRole","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bytes4","name":"interfaceId","type":"bytes4"}],"name":"supportsInterface","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"unpause","outputs":[],"stateMutability":"nonpayable","type":"function"}]

60a06040523480156200001157600080fd5b506012600a62000022919062000603565b63017d784062000033919062000740565b6040518060400160405280600c81526020017f53706163655920546f6b656e00000000000000000000000000000000000000008152506040518060400160405280600481526020017f535041590000000000000000000000000000000000000000000000000000000081525081818160059080519060200190620000b992919062000483565b508060069080519060200190620000d292919062000483565b5050506000600760006101000a81548160ff021916908315150217905550620001146000801b62000108620001ed60201b60201c565b620001f560201b60201c565b620001557f9f2df0fed2c77648de5860a4cc508cd0818c85b8b8a1ab4ceeef8d981c8956a662000149620001ed60201b60201c565b620001f560201b60201c565b620001967f65d7a28e3265b37a6474929f336521b332c1681b933f6cb9f3376673440d862a6200018a620001ed60201b60201c565b620001f560201b60201c565b505060008111620001de576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401620001d59062000575565b60405180910390fd5b8060808181525050506200084c565b600033905090565b6200020c82826200023d60201b62000f4c1760201c565b6200023881600160008581526020019081526020016000206200025360201b62000f5a1790919060201c565b505050565b6200024f82826200028b60201b60201c565b5050565b600062000283836000018373ffffffffffffffffffffffffffffffffffffffff1660001b6200037c60201b60201c565b905092915050565b6200029d8282620003f660201b60201c565b6200037857600160008084815260200190815260200160002060000160008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff0219169083151502179055506200031d620001ed60201b60201c565b73ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff16837f2f8788117e7eff1d82e926ec794901d17c78024a50270940304540a733656f0d60405160405180910390a45b5050565b60006200039083836200046060201b60201c565b620003eb578260000182908060018154018082558091505060019003906000526020600020016000909190919091505582600001805490508360010160008481526020019081526020016000208190555060019050620003f0565b600090505b92915050565b600080600084815260200190815260200160002060000160008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16905092915050565b600080836001016000848152602001908152602001600020541415905092915050565b8280546200049190620007ab565b90600052602060002090601f016020900481019282620004b5576000855562000501565b82601f10620004d057805160ff191683800117855562000501565b8280016001018555821562000501579182015b8281111562000500578251825591602001919060010190620004e3565b5b50905062000510919062000514565b5090565b5b808211156200052f57600081600090555060010162000515565b5090565b60006200054260158362000597565b91507f45524332304361707065643a20636170206973203000000000000000000000006000830152602082019050919050565b60006020820190508181036000830152620005908162000533565b9050919050565b600082825260208201905092915050565b6000808291508390505b6001851115620005fa57808604811115620005d257620005d1620007e1565b5b6001851615620005e25780820291505b8081029050620005f2856200083f565b9450620005b2565b94509492505050565b60006200061082620007a1565b91506200061d83620007a1565b92506200064c7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff848462000654565b905092915050565b60008262000666576001905062000739565b8162000676576000905062000739565b81600181146200068f57600281146200069a57620006d0565b600191505062000739565b60ff841115620006af57620006ae620007e1565b5b8360020a915084821115620006c957620006c8620007e1565b5b5062000739565b5060208310610133831016604e8410600b84101617156200070a5782820a905083811115620007045762000703620007e1565b5b62000739565b620007198484846001620005a8565b92509050818404811115620007335762000732620007e1565b5b81810290505b9392505050565b60006200074d82620007a1565b91506200075a83620007a1565b9250817fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff0483118215151615620007965762000795620007e1565b5b828202905092915050565b6000819050919050565b60006002820490506001821680620007c457607f821691505b60208210811415620007db57620007da62000810565b5b50919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052602260045260246000fd5b60008160011c9050919050565b60805161314662000868600039600061087301526131466000f3fe608060405234801561001057600080fd5b50600436106101cf5760003560e01c80635c975abb11610104578063a217fddf116100a2578063d539139311610071578063d539139314610556578063d547741f14610574578063dd62ed3e14610590578063e63ab1e9146105c0576101cf565b8063a217fddf146104a8578063a457c2d7146104c6578063a9059cbb146104f6578063ca15c87314610526576101cf565b80638456cb59116100de5780638456cb59146104205780639010d07c1461042a57806391d148541461045a57806395d89b411461048a576101cf565b80635c975abb146103b657806370a08231146103d457806379cc679014610404576101cf565b8063313ce56711610171578063395093511161014b57806339509351146103445780633f4ba83a1461037457806340c10f191461037e57806342966c681461039a576101cf565b8063313ce567146102ec578063355274ea1461030a57806336568abe14610328576101cf565b806318160ddd116101ad57806318160ddd1461025257806323b872dd14610270578063248a9ca3146102a05780632f2ff15d146102d0576101cf565b806301ffc9a7146101d457806306fdde0314610204578063095ea7b314610222575b600080fd5b6101ee60048036038101906101e99190612244565b6105de565b6040516101fb9190612b61565b60405180910390f35b61020c610658565b6040516102199190612b97565b60405180910390f35b61023c60048036038101906102379190612167565b6106ea565b6040516102499190612b61565b60405180910390f35b61025a610708565b6040516102679190612e79565b60405180910390f35b61028a60048036038101906102859190612118565b610712565b6040516102979190612b61565b60405180910390f35b6102ba60048036038101906102b591906121a3565b610813565b6040516102c79190612b7c565b60405180910390f35b6102ea60048036038101906102e591906121cc565b610832565b005b6102f4610866565b6040516103019190612e94565b60405180910390f35b61031261086f565b60405161031f9190612e79565b60405180910390f35b610342600480360381019061033d91906121cc565b610897565b005b61035e60048036038101906103599190612167565b6108cb565b60405161036b9190612b61565b60405180910390f35b61037c610977565b005b61039860048036038101906103939190612167565b6109f1565b005b6103b460048036038101906103af919061226d565b610a6f565b005b6103be610a83565b6040516103cb9190612b61565b60405180910390f35b6103ee60048036038101906103e991906120b3565b610a9a565b6040516103fb9190612e79565b60405180910390f35b61041e60048036038101906104199190612167565b610ae3565b005b610428610b67565b005b610444600480360381019061043f9190612208565b610be1565b6040516104519190612b46565b60405180910390f35b610474600480360381019061046f91906121cc565b610c10565b6040516104819190612b61565b60405180910390f35b610492610c7a565b60405161049f9190612b97565b60405180910390f35b6104b0610d0c565b6040516104bd9190612b7c565b60405180910390f35b6104e060048036038101906104db9190612167565b610d13565b6040516104ed9190612b61565b60405180910390f35b610510600480360381019061050b9190612167565b610e07565b60405161051d9190612b61565b60405180910390f35b610540600480360381019061053b91906121a3565b610e25565b60405161054d9190612e79565b60405180910390f35b61055e610e49565b60405161056b9190612b7c565b60405180910390f35b61058e600480360381019061058991906121cc565b610e6d565b005b6105aa60048036038101906105a591906120dc565b610ea1565b6040516105b79190612e79565b60405180910390f35b6105c8610f28565b6040516105d59190612b7c565b60405180910390f35b60007f5a05180f000000000000000000000000000000000000000000000000000000007bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916827bffffffffffffffffffffffffffffffffffffffffffffffffffffffff19161480610651575061065082610f8a565b5b9050919050565b60606005805461066790613013565b80601f016020809104026020016040519081016040528092919081815260200182805461069390613013565b80156106e05780601f106106b5576101008083540402835291602001916106e0565b820191906000526020600020905b8154815290600101906020018083116106c357829003601f168201915b5050505050905090565b60006106fe6106f7611004565b848461100c565b6001905092915050565b6000600454905090565b600061071f8484846111d7565b6000600360008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020600061076a611004565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020549050828110156107ea576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016107e190612cf9565b60405180910390fd5b610807856107f6611004565b85846108029190612f21565b61100c565b60019150509392505050565b6000806000838152602001908152602001600020600101549050919050565b61083c8282611459565b6108618160016000858152602001908152602001600020610f5a90919063ffffffff16565b505050565b60006012905090565b60007f0000000000000000000000000000000000000000000000000000000000000000905090565b6108a182826114bf565b6108c6816001600085815260200190815260200160002061154290919063ffffffff16565b505050565b600061096d6108d8611004565b8484600360006108e6611004565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008873ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020546109689190612ecb565b61100c565b6001905092915050565b6109a87f65d7a28e3265b37a6474929f336521b332c1681b933f6cb9f3376673440d862a6109a3611004565b610c10565b6109e7576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016109de90612c59565b60405180910390fd5b6109ef611572565b565b610a227f9f2df0fed2c77648de5860a4cc508cd0818c85b8b8a1ab4ceeef8d981c8956a6610a1d611004565b610c10565b610a61576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610a5890612d19565b60405180910390fd5b610a6b8282611614565b5050565b610a80610a7a611004565b82611622565b50565b6000600760009054906101000a900460ff16905090565b6000600260008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020549050919050565b6000610af683610af1611004565b610ea1565b905081811015610b3b576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610b3290612d39565b60405180910390fd5b610b5883610b47611004565b8484610b539190612f21565b61100c565b610b628383611622565b505050565b610b987f65d7a28e3265b37a6474929f336521b332c1681b933f6cb9f3376673440d862a610b93611004565b610c10565b610bd7576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610bce90612dd9565b60405180910390fd5b610bdf6117f8565b565b6000610c08826001600086815260200190815260200160002061189b90919063ffffffff16565b905092915050565b600080600084815260200190815260200160002060000160008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16905092915050565b606060068054610c8990613013565b80601f0160208091040260200160405190810160405280929190818152602001828054610cb590613013565b8015610d025780601f10610cd757610100808354040283529160200191610d02565b820191906000526020600020905b815481529060010190602001808311610ce557829003601f168201915b5050505050905090565b6000801b81565b60008060036000610d22611004565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054905082811015610ddf576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610dd690612df9565b60405180910390fd5b610dfc610dea611004565b858584610df79190612f21565b61100c565b600191505092915050565b6000610e1b610e14611004565b84846111d7565b6001905092915050565b6000610e42600160008481526020019081526020016000206118b5565b9050919050565b7f9f2df0fed2c77648de5860a4cc508cd0818c85b8b8a1ab4ceeef8d981c8956a681565b610e7782826118ca565b610e9c816001600085815260200190815260200160002061154290919063ffffffff16565b505050565b6000600360008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054905092915050565b7f65d7a28e3265b37a6474929f336521b332c1681b933f6cb9f3376673440d862a81565b610f568282611930565b5050565b6000610f82836000018373ffffffffffffffffffffffffffffffffffffffff1660001b611a10565b905092915050565b60007f7965db0b000000000000000000000000000000000000000000000000000000007bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916827bffffffffffffffffffffffffffffffffffffffffffffffffffffffff19161480610ffd5750610ffc82611a80565b5b9050919050565b600033905090565b600073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff16141561107c576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161107390612db9565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1614156110ec576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016110e390612c79565b60405180910390fd5b80600360008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055508173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925836040516111ca9190612e79565b60405180910390a3505050565b600073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff161415611247576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161123e90612d79565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1614156112b7576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016112ae90612bd9565b60405180910390fd5b6112c2838383611aea565b6000600260008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054905081811015611349576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161134090612c99565b60405180910390fd5b81816113559190612f21565b600260008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000208190555081600260008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008282546113e79190612ecb565b925050819055508273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8460405161144b9190612e79565b60405180910390a350505050565b61147261146583610813565b61146d611004565b610c10565b6114b1576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016114a890612bf9565b60405180910390fd5b6114bb8282611930565b5050565b6114c7611004565b73ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff1614611534576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161152b90612e19565b60405180910390fd5b61153e8282611afa565b5050565b600061156a836000018373ffffffffffffffffffffffffffffffffffffffff1660001b611bdb565b905092915050565b61157a610a83565b6115b9576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016115b090612c19565b60405180910390fd5b6000600760006101000a81548160ff0219169083151502179055507f5db9ee0a495bf2e6ff9c91a7834c1ba4fdd244a5e8aa4e537bd38aeae4b073aa6115fd611004565b60405161160a9190612b46565b60405180910390a1565b61161e8282611d65565b5050565b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff161415611692576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161168990612d59565b60405180910390fd5b61169e82600083611aea565b6000600260008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054905081811015611725576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161171c90612c39565b60405180910390fd5b81816117319190612f21565b600260008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000208190555081600460008282546117869190612f21565b92505081905550600073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef846040516117eb9190612e79565b60405180910390a3505050565b611800610a83565b15611840576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161183790612cd9565b60405180910390fd5b6001600760006101000a81548160ff0219169083151502179055507f62e78cea01bee320cd4e420270b5ea74000d11b0c9f74754ebdbfc544b05a258611884611004565b6040516118919190612b46565b60405180910390a1565b60006118aa8360000183611dcf565b60001c905092915050565b60006118c382600001611e69565b9050919050565b6118e36118d683610813565b6118de611004565b610c10565b611922576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161191990612cb9565b60405180910390fd5b61192c8282611afa565b5050565b61193a8282610c10565b611a0c57600160008084815260200190815260200160002060000160008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff0219169083151502179055506119b1611004565b73ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff16837f2f8788117e7eff1d82e926ec794901d17c78024a50270940304540a733656f0d60405160405180910390a45b5050565b6000611a1c8383611e7a565b611a75578260000182908060018154018082558091505060019003906000526020600020016000909190919091505582600001805490508360010160008481526020019081526020016000208190555060019050611a7a565b600090505b92915050565b60007f01ffc9a7000000000000000000000000000000000000000000000000000000007bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916827bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916149050919050565b611af5838383611e9d565b505050565b611b048282610c10565b15611bd757600080600084815260200190815260200160002060000160008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff021916908315150217905550611b7c611004565b73ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff16837ff6391f5c32d9c69d2a47ea670b442974b53935d1edc7fd64eb21e047a839171b60405160405180910390a45b5050565b60008083600101600084815260200190815260200160002054905060008114611d59576000600182611c0d9190612f21565b9050600060018660000180549050611c259190612f21565b90506000866000018281548110611c65577f4e487b7100000000000000000000000000000000000000000000000000000000600052603260045260246000fd5b9060005260206000200154905080876000018481548110611caf577f4e487b7100000000000000000000000000000000000000000000000000000000600052603260045260246000fd5b9060005260206000200181905550600183611cca9190612ecb565b8760010160008381526020019081526020016000208190555086600001805480611d1d577f4e487b7100000000000000000000000000000000000000000000000000000000600052603160045260246000fd5b60019003818190600052602060002001600090559055866001016000878152602001908152602001600020600090556001945050505050611d5f565b60009150505b92915050565b611d6d61086f565b81611d76610708565b611d809190612ecb565b1115611dc1576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611db890612d99565b60405180910390fd5b611dcb8282611ead565b5050565b600081836000018054905011611e1a576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611e1190612bb9565b60405180910390fd5b826000018281548110611e56577f4e487b7100000000000000000000000000000000000000000000000000000000600052603260045260246000fd5b9060005260206000200154905092915050565b600081600001805490509050919050565b600080836001016000848152602001908152602001600020541415905092915050565b611ea8838383612002565b505050565b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff161415611f1d576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611f1490612e39565b60405180910390fd5b611f2960008383611aea565b8060046000828254611f3b9190612ecb565b9250508190555080600260008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000206000828254611f919190612ecb565b925050819055508173ffffffffffffffffffffffffffffffffffffffff16600073ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051611ff69190612e79565b60405180910390a35050565b61200d83838361205a565b612015610a83565b15612055576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161204c90612e59565b60405180910390fd5b505050565b505050565b60008135905061206e816130b4565b92915050565b600081359050612083816130cb565b92915050565b600081359050612098816130e2565b92915050565b6000813590506120ad816130f9565b92915050565b6000602082840312156120c557600080fd5b60006120d38482850161205f565b91505092915050565b600080604083850312156120ef57600080fd5b60006120fd8582860161205f565b925050602061210e8582860161205f565b9150509250929050565b60008060006060848603121561212d57600080fd5b600061213b8682870161205f565b935050602061214c8682870161205f565b925050604061215d8682870161209e565b9150509250925092565b6000806040838503121561217a57600080fd5b60006121888582860161205f565b92505060206121998582860161209e565b9150509250929050565b6000602082840312156121b557600080fd5b60006121c384828501612074565b91505092915050565b600080604083850312156121df57600080fd5b60006121ed85828601612074565b92505060206121fe8582860161205f565b9150509250929050565b6000806040838503121561221b57600080fd5b600061222985828601612074565b925050602061223a8582860161209e565b9150509250929050565b60006020828403121561225657600080fd5b600061226484828501612089565b91505092915050565b60006020828403121561227f57600080fd5b600061228d8482850161209e565b91505092915050565b61229f81612f55565b82525050565b6122ae81612f67565b82525050565b6122bd81612f73565b82525050565b60006122ce82612eaf565b6122d88185612eba565b93506122e8818560208601612fe0565b6122f1816130a3565b840191505092915050565b6000612309602283612eba565b91507f456e756d657261626c655365743a20696e646578206f7574206f6620626f756e60008301527f64730000000000000000000000000000000000000000000000000000000000006020830152604082019050919050565b600061236f602383612eba565b91507f45524332303a207472616e7366657220746f20746865207a65726f206164647260008301527f65737300000000000000000000000000000000000000000000000000000000006020830152604082019050919050565b60006123d5602f83612eba565b91507f416363657373436f6e74726f6c3a2073656e646572206d75737420626520616e60008301527f2061646d696e20746f206772616e7400000000000000000000000000000000006020830152604082019050919050565b600061243b601483612eba565b91507f5061757361626c653a206e6f74207061757365640000000000000000000000006000830152602082019050919050565b600061247b602283612eba565b91507f45524332303a206275726e20616d6f756e7420657863656564732062616c616e60008301527f63650000000000000000000000000000000000000000000000000000000000006020830152604082019050919050565b60006124e1603983612eba565b91507f45524332305072657365744d696e7465725061757365723a206d75737420686160008301527f76652070617573657220726f6c6520746f20756e7061757365000000000000006020830152604082019050919050565b6000612547602283612eba565b91507f45524332303a20617070726f766520746f20746865207a65726f20616464726560008301527f73730000000000000000000000000000000000000000000000000000000000006020830152604082019050919050565b60006125ad602683612eba565b91507f45524332303a207472616e7366657220616d6f756e742065786365656473206260008301527f616c616e636500000000000000000000000000000000000000000000000000006020830152604082019050919050565b6000612613603083612eba565b91507f416363657373436f6e74726f6c3a2073656e646572206d75737420626520616e60008301527f2061646d696e20746f207265766f6b65000000000000000000000000000000006020830152604082019050919050565b6000612679601083612eba565b91507f5061757361626c653a20706175736564000000000000000000000000000000006000830152602082019050919050565b60006126b9602883612eba565b91507f45524332303a207472616e7366657220616d6f756e742065786365656473206160008301527f6c6c6f77616e63650000000000000000000000000000000000000000000000006020830152604082019050919050565b600061271f603683612eba565b91507f45524332305072657365744d696e7465725061757365723a206d75737420686160008301527f7665206d696e74657220726f6c6520746f206d696e74000000000000000000006020830152604082019050919050565b6000612785602483612eba565b91507f45524332303a206275726e20616d6f756e74206578636565647320616c6c6f7760008301527f616e6365000000000000000000000000000000000000000000000000000000006020830152604082019050919050565b60006127eb602183612eba565b91507f45524332303a206275726e2066726f6d20746865207a65726f2061646472657360008301527f73000000000000000000000000000000000000000000000000000000000000006020830152604082019050919050565b6000612851602583612eba565b91507f45524332303a207472616e736665722066726f6d20746865207a65726f20616460008301527f64726573730000000000000000000000000000000000000000000000000000006020830152604082019050919050565b60006128b7601983612eba565b91507f45524332304361707065643a20636170206578636565646564000000000000006000830152602082019050919050565b60006128f7602483612eba565b91507f45524332303a20617070726f76652066726f6d20746865207a65726f2061646460008301527f72657373000000000000000000000000000000000000000000000000000000006020830152604082019050919050565b600061295d603783612eba565b91507f45524332305072657365744d696e7465725061757365723a206d75737420686160008301527f76652070617573657220726f6c6520746f2070617573650000000000000000006020830152604082019050919050565b60006129c3602583612eba565b91507f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f7760008301527f207a65726f0000000000000000000000000000000000000000000000000000006020830152604082019050919050565b6000612a29602f83612eba565b91507f416363657373436f6e74726f6c3a2063616e206f6e6c792072656e6f756e636560008301527f20726f6c657320666f722073656c6600000000000000000000000000000000006020830152604082019050919050565b6000612a8f601f83612eba565b91507f45524332303a206d696e7420746f20746865207a65726f2061646472657373006000830152602082019050919050565b6000612acf602a83612eba565b91507f45524332305061757361626c653a20746f6b656e207472616e7366657220776860008301527f696c6520706175736564000000000000000000000000000000000000000000006020830152604082019050919050565b612b3181612fc9565b82525050565b612b4081612fd3565b82525050565b6000602082019050612b5b6000830184612296565b92915050565b6000602082019050612b7660008301846122a5565b92915050565b6000602082019050612b9160008301846122b4565b92915050565b60006020820190508181036000830152612bb181846122c3565b905092915050565b60006020820190508181036000830152612bd2816122fc565b9050919050565b60006020820190508181036000830152612bf281612362565b9050919050565b60006020820190508181036000830152612c12816123c8565b9050919050565b60006020820190508181036000830152612c328161242e565b9050919050565b60006020820190508181036000830152612c528161246e565b9050919050565b60006020820190508181036000830152612c72816124d4565b9050919050565b60006020820190508181036000830152612c928161253a565b9050919050565b60006020820190508181036000830152612cb2816125a0565b9050919050565b60006020820190508181036000830152612cd281612606565b9050919050565b60006020820190508181036000830152612cf28161266c565b9050919050565b60006020820190508181036000830152612d12816126ac565b9050919050565b60006020820190508181036000830152612d3281612712565b9050919050565b60006020820190508181036000830152612d5281612778565b9050919050565b60006020820190508181036000830152612d72816127de565b9050919050565b60006020820190508181036000830152612d9281612844565b9050919050565b60006020820190508181036000830152612db2816128aa565b9050919050565b60006020820190508181036000830152612dd2816128ea565b9050919050565b60006020820190508181036000830152612df281612950565b9050919050565b60006020820190508181036000830152612e12816129b6565b9050919050565b60006020820190508181036000830152612e3281612a1c565b9050919050565b60006020820190508181036000830152612e5281612a82565b9050919050565b60006020820190508181036000830152612e7281612ac2565b9050919050565b6000602082019050612e8e6000830184612b28565b92915050565b6000602082019050612ea96000830184612b37565b92915050565b600081519050919050565b600082825260208201905092915050565b6000612ed682612fc9565b9150612ee183612fc9565b9250827fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff03821115612f1657612f15613045565b5b828201905092915050565b6000612f2c82612fc9565b9150612f3783612fc9565b925082821015612f4a57612f49613045565b5b828203905092915050565b6000612f6082612fa9565b9050919050565b60008115159050919050565b6000819050919050565b60007fffffffff0000000000000000000000000000000000000000000000000000000082169050919050565b600073ffffffffffffffffffffffffffffffffffffffff82169050919050565b6000819050919050565b600060ff82169050919050565b60005b83811015612ffe578082015181840152602081019050612fe3565b8381111561300d576000848401525b50505050565b6000600282049050600182168061302b57607f821691505b6020821081141561303f5761303e613074565b5b50919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052602260045260246000fd5b6000601f19601f8301169050919050565b6130bd81612f55565b81146130c857600080fd5b50565b6130d481612f73565b81146130df57600080fd5b50565b6130eb81612f7d565b81146130f657600080fd5b50565b61310281612fc9565b811461310d57600080fd5b5056fea26469706673582212203949702d57c950a296ef6e12c42bf64424e9eec14da401981990c398d05705ee64736f6c63430008000033

Deployed ByteCode Sourcemap

44973:604:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;39770:227;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;5847:91;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;7987:169;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;6940:108;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;8638:422;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;25928:123;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;41141:165;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;6791:84;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;15193:83;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;41664:174;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;9469:215;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;44511:178;;;:::i;:::-;;43702:205;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;16035:91;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;17855:86;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;7111:127;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;16445:332;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;44121:172;;;:::i;:::-;;40596:145;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;25600:139;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;6057:95;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;24056:49;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;10187:377;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;7451:175;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;40915:134;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;42944:62;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;41399:170;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;7689:151;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;43013:62;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;39770:227;39855:4;39894:42;39879:57;;;:11;:57;;;;:110;;;;39953:36;39977:11;39953:23;:36::i;:::-;39879:110;39872:117;;39770:227;;;:::o;5847:91::-;5892:13;5925:5;5918:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;5847:91;:::o;7987:169::-;8070:4;8087:39;8096:12;:10;:12::i;:::-;8110:7;8119:6;8087:8;:39::i;:::-;8144:4;8137:11;;7987:169;;;;:::o;6940:108::-;7001:7;7028:12;;7021:19;;6940:108;:::o;8638:422::-;8744:4;8761:36;8771:6;8779:9;8790:6;8761:9;:36::i;:::-;8810:24;8837:11;:19;8849:6;8837:19;;;;;;;;;;;;;;;:33;8857:12;:10;:12::i;:::-;8837:33;;;;;;;;;;;;;;;;8810:60;;8909:6;8889:16;:26;;8881:79;;;;;;;;;;;;:::i;:::-;;;;;;;;;8971:57;8980:6;8988:12;:10;:12::i;:::-;9021:6;9002:16;:25;;;;:::i;:::-;8971:8;:57::i;:::-;9048:4;9041:11;;;8638:422;;;;;:::o;25928:123::-;25994:7;26021:6;:12;26028:4;26021:12;;;;;;;;;;;:22;;;26014:29;;25928:123;;;:::o;41141:165::-;41226:30;41242:4;41248:7;41226:15;:30::i;:::-;41267:31;41290:7;41267:12;:18;41280:4;41267:18;;;;;;;;;;;:22;;:31;;;;:::i;:::-;;41141:165;;:::o;6791:84::-;6840:5;6865:2;6858:9;;6791:84;:::o;15193:83::-;15237:7;15264:4;15257:11;;15193:83;:::o;41664:174::-;41752:33;41771:4;41777:7;41752:18;:33::i;:::-;41796:34;41822:7;41796:12;:18;41809:4;41796:18;;;;;;;;;;;:25;;:34;;;;:::i;:::-;;41664:174;;:::o;9469:215::-;9557:4;9574:80;9583:12;:10;:12::i;:::-;9597:7;9643:10;9606:11;:25;9618:12;:10;:12::i;:::-;9606:25;;;;;;;;;;;;;;;:34;9632:7;9606:34;;;;;;;;;;;;;;;;:47;;;;:::i;:::-;9574:8;:80::i;:::-;9672:4;9665:11;;9469:215;;;;:::o;44511:178::-;44564:34;43051:24;44585:12;:10;:12::i;:::-;44564:7;:34::i;:::-;44556:104;;;;;;;;;;;;:::i;:::-;;;;;;;;;44671:10;:8;:10::i;:::-;44511:178::o;43702:205::-;43778:34;42982:24;43799:12;:10;:12::i;:::-;43778:7;:34::i;:::-;43770:101;;;;;;;;;;;;:::i;:::-;;;;;;;;;43882:17;43888:2;43892:6;43882:5;:17::i;:::-;43702:205;;:::o;16035:91::-;16091:27;16097:12;:10;:12::i;:::-;16111:6;16091:5;:27::i;:::-;16035:91;:::o;17855:86::-;17902:4;17926:7;;;;;;;;;;;17919:14;;17855:86;:::o;7111:127::-;7185:7;7212:9;:18;7222:7;7212:18;;;;;;;;;;;;;;;;7205:25;;7111:127;;;:::o;16445:332::-;16522:24;16549:32;16559:7;16568:12;:10;:12::i;:::-;16549:9;:32::i;:::-;16522:59;;16620:6;16600:16;:26;;16592:75;;;;;;;;;;;;:::i;:::-;;;;;;;;;16678:58;16687:7;16696:12;:10;:12::i;:::-;16729:6;16710:16;:25;;;;:::i;:::-;16678:8;:58::i;:::-;16747:22;16753:7;16762:6;16747:5;:22::i;:::-;16445:332;;;:::o;44121:172::-;44172:34;43051:24;44193:12;:10;:12::i;:::-;44172:7;:34::i;:::-;44164:102;;;;;;;;;;;;:::i;:::-;;;;;;;;;44277:8;:6;:8::i;:::-;44121:172::o;40596:145::-;40678:7;40705:28;40727:5;40705:12;:18;40718:4;40705:18;;;;;;;;;;;:21;;:28;;;;:::i;:::-;40698:35;;40596:145;;;;:::o;25600:139::-;25678:4;25702:6;:12;25709:4;25702:12;;;;;;;;;;;:20;;:29;25723:7;25702:29;;;;;;;;;;;;;;;;;;;;;;;;;25695:36;;25600:139;;;;:::o;6057:95::-;6104:13;6137:7;6130:14;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6057:95;:::o;24056:49::-;24101:4;24056:49;;;:::o;10187:377::-;10280:4;10297:24;10324:11;:25;10336:12;:10;:12::i;:::-;10324:25;;;;;;;;;;;;;;;:34;10350:7;10324:34;;;;;;;;;;;;;;;;10297:61;;10397:15;10377:16;:35;;10369:85;;;;;;;;;;;;:::i;:::-;;;;;;;;;10465:67;10474:12;:10;:12::i;:::-;10488:7;10516:15;10497:16;:34;;;;:::i;:::-;10465:8;:67::i;:::-;10552:4;10545:11;;;10187:377;;;;:::o;7451:175::-;7537:4;7554:42;7564:12;:10;:12::i;:::-;7578:9;7589:6;7554:9;:42::i;:::-;7614:4;7607:11;;7451:175;;;;:::o;40915:134::-;40987:7;41014:27;:12;:18;41027:4;41014:18;;;;;;;;;;;:25;:27::i;:::-;41007:34;;40915:134;;;:::o;42944:62::-;42982:24;42944:62;:::o;41399:170::-;41485:31;41502:4;41508:7;41485:16;:31::i;:::-;41527:34;41553:7;41527:12;:18;41540:4;41527:18;;;;;;;;;;;:25;;:34;;;;:::i;:::-;;41399:170;;:::o;7689:151::-;7778:7;7805:11;:18;7817:5;7805:18;;;;;;;;;;;;;;;:27;7824:7;7805:27;;;;;;;;;;;;;;;;7798:34;;7689:151;;;;:::o;43013:62::-;43051:24;43013:62;:::o;28333:112::-;28412:25;28423:4;28429:7;28412:10;:25::i;:::-;28333:112;;:::o;35908:152::-;35978:4;36002:50;36007:3;:10;;36043:5;36027:23;;36019:32;;36002:4;:50::i;:::-;35995:57;;35908:152;;;;:::o;25291:217::-;25376:4;25415:32;25400:47;;;:11;:47;;;;:100;;;;25464:36;25488:11;25464:23;:36::i;:::-;25400:100;25393:107;;25291:217;;;:::o;3454:98::-;3507:7;3534:10;3527:17;;3454:98;:::o;13543:346::-;13662:1;13645:19;;:5;:19;;;;13637:68;;;;;;;;;;;;:::i;:::-;;;;;;;;;13743:1;13724:21;;:7;:21;;;;13716:68;;;;;;;;;;;;:::i;:::-;;;;;;;;;13827:6;13797:11;:18;13809:5;13797:18;;;;;;;;;;;;;;;:27;13816:7;13797:27;;;;;;;;;;;;;;;:36;;;;13865:7;13849:32;;13858:5;13849:32;;;13874:6;13849:32;;;;;;:::i;:::-;;;;;;;;13543:346;;;:::o;11054:604::-;11178:1;11160:20;;:6;:20;;;;11152:70;;;;;;;;;;;;:::i;:::-;;;;;;;;;11262:1;11241:23;;:9;:23;;;;11233:71;;;;;;;;;;;;:::i;:::-;;;;;;;;;11317:47;11338:6;11346:9;11357:6;11317:20;:47::i;:::-;11377:21;11401:9;:17;11411:6;11401:17;;;;;;;;;;;;;;;;11377:41;;11454:6;11437:13;:23;;11429:74;;;;;;;;;;;;:::i;:::-;;;;;;;;;11550:6;11534:13;:22;;;;:::i;:::-;11514:9;:17;11524:6;11514:17;;;;;;;;;;;;;;;:42;;;;11591:6;11567:9;:20;11577:9;11567:20;;;;;;;;;;;;;;;;:30;;;;;;;:::i;:::-;;;;;;;;11632:9;11615:35;;11624:6;11615:35;;;11643:6;11615:35;;;;;;:::i;:::-;;;;;;;;11054:604;;;;:::o;26313:232::-;26406:41;26414:18;26427:4;26414:12;:18::i;:::-;26434:12;:10;:12::i;:::-;26406:7;:41::i;:::-;26398:101;;;;;;;;;;;;:::i;:::-;;;;;;;;;26512:25;26523:4;26529:7;26512:10;:25::i;:::-;26313:232;;:::o;27532:218::-;27639:12;:10;:12::i;:::-;27628:23;;:7;:23;;;27620:83;;;;;;;;;;;;:::i;:::-;;;;;;;;;27716:26;27728:4;27734:7;27716:11;:26::i;:::-;27532:218;;:::o;36236:158::-;36309:4;36333:53;36341:3;:10;;36377:5;36361:23;;36353:32;;36333:7;:53::i;:::-;36326:60;;36236:158;;;;:::o;18914:120::-;18458:8;:6;:8::i;:::-;18450:41;;;;;;;;;;;;:::i;:::-;;;;;;;;;18983:5:::1;18973:7;;:15;;;;;;;;;;;;;;;;;;19004:22;19013:12;:10;:12::i;:::-;19004:22;;;;;;:::i;:::-;;;;;;;;18914:120::o:0;45408:166::-;45538:28;45550:7;45559:6;45538:11;:28::i;:::-;45408:166;;:::o;12611:494::-;12714:1;12695:21;;:7;:21;;;;12687:67;;;;;;;;;;;;:::i;:::-;;;;;;;;;12767:49;12788:7;12805:1;12809:6;12767:20;:49::i;:::-;12829:22;12854:9;:18;12864:7;12854:18;;;;;;;;;;;;;;;;12829:43;;12909:6;12891:14;:24;;12883:71;;;;;;;;;;;;:::i;:::-;;;;;;;;;13003:6;12986:14;:23;;;;:::i;:::-;12965:9;:18;12975:7;12965:18;;;;;;;;;;;;;;;:44;;;;13036:6;13020:12;;:22;;;;;;;:::i;:::-;;;;;;;;13086:1;13060:37;;13069:7;13060:37;;;13090:6;13060:37;;;;;;:::i;:::-;;;;;;;;12611:494;;;:::o;18655:118::-;18181:8;:6;:8::i;:::-;18180:9;18172:38;;;;;;;;;;;;:::i;:::-;;;;;;;;;18725:4:::1;18715:7;;:14;;;;;;;;;;;;;;;;;;18745:20;18752:12;:10;:12::i;:::-;18745:20;;;;;;:::i;:::-;;;;;;;;18655:118::o:0;37194:158::-;37268:7;37319:22;37323:3;:10;;37335:5;37319:3;:22::i;:::-;37311:31;;37288:56;;37194:158;;;;:::o;36733:117::-;36796:7;36823:19;36831:3;:10;;36823:7;:19::i;:::-;36816:26;;36733:117;;;:::o;26790:235::-;26884:41;26892:18;26905:4;26892:12;:18::i;:::-;26912:12;:10;:12::i;:::-;26884:7;:41::i;:::-;26876:102;;;;;;;;;;;;:::i;:::-;;;;;;;;;26991:26;27003:4;27009:7;26991:11;:26::i;:::-;26790:235;;:::o;28780:229::-;28855:22;28863:4;28869:7;28855;:22::i;:::-;28850:152;;28926:4;28894:6;:12;28901:4;28894:12;;;;;;;;;;;:20;;:29;28915:7;28894:29;;;;;;;;;;;;;;;;:36;;;;;;;;;;;;;;;;;;28977:12;:10;:12::i;:::-;28950:40;;28968:7;28950:40;;28962:4;28950:40;;;;;;;;;;28850:152;28780:229;;:::o;30972:414::-;31035:4;31057:21;31067:3;31072:5;31057:9;:21::i;:::-;31052:327;;31095:3;:11;;31112:5;31095:23;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;31278:3;:11;;:18;;;;31256:3;:12;;:19;31269:5;31256:19;;;;;;;;;;;:40;;;;31318:4;31311:11;;;;31052:327;31362:5;31355:12;;30972:414;;;;;:::o;21514:157::-;21599:4;21638:25;21623:40;;;:11;:40;;;;21616:47;;21514:157;;;:::o;45173:227::-;45348:44;45375:4;45381:2;45385:6;45348:26;:44::i;:::-;45173:227;;;:::o;29017:230::-;29092:22;29100:4;29106:7;29092;:22::i;:::-;29088:152;;;29163:5;29131:6;:12;29138:4;29131:12;;;;;;;;;;;:20;;:29;29152:7;29131:29;;;;;;;;;;;;;;;;:37;;;;;;;;;;;;;;;;;;29215:12;:10;:12::i;:::-;29188:40;;29206:7;29188:40;;29200:4;29188:40;;;;;;;;;;29088:152;29017:230;;:::o;31562:1544::-;31628:4;31746:18;31767:3;:12;;:19;31780:5;31767:19;;;;;;;;;;;;31746:40;;31817:1;31803:10;:15;31799:1300;;32165:21;32202:1;32189:10;:14;;;;:::i;:::-;32165:38;;32218:17;32259:1;32238:3;:11;;:18;;;;:22;;;;:::i;:::-;32218:42;;32505:17;32525:3;:11;;32537:9;32525:22;;;;;;;;;;;;;;;;;;;;;;;;32505:42;;32671:9;32642:3;:11;;32654:13;32642:26;;;;;;;;;;;;;;;;;;;;;;;:38;;;;32790:1;32774:13;:17;;;;:::i;:::-;32748:3;:12;;:23;32761:9;32748:23;;;;;;;;;;;:43;;;;32900:3;:11;;:17;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;32995:3;:12;;:19;33008:5;32995:19;;;;;;;;;;;32988:26;;;33038:4;33031:11;;;;;;;;31799:1300;33082:5;33075:12;;;31562:1544;;;;;:::o;15334:207::-;15459:5;:3;:5::i;:::-;15449:6;15427:19;:17;:19::i;:::-;:28;;;;:::i;:::-;:37;;15419:75;;;;;;;;;;;;:::i;:::-;;;;;;;;;15505:28;15517:7;15526:6;15505:11;:28::i;:::-;15334:207;;:::o;33860:204::-;33927:7;33976:5;33955:3;:11;;:18;;;;:26;33947:73;;;;;;;;;;;;:::i;:::-;;;;;;;;;34038:3;:11;;34050:5;34038:18;;;;;;;;;;;;;;;;;;;;;;;;34031:25;;33860:204;;;;:::o;33407:109::-;33463:7;33490:3;:11;;:18;;;;33483:25;;33407:109;;;:::o;33192:129::-;33265:4;33312:1;33289:3;:12;;:19;33302:5;33289:19;;;;;;;;;;;;:24;;33282:31;;33192:129;;;;:::o;44697:183::-;44828:44;44855:4;44861:2;44865:6;44828:26;:44::i;:::-;44697:183;;;:::o;11940:338::-;12043:1;12024:21;;:7;:21;;;;12016:65;;;;;;;;;;;;:::i;:::-;;;;;;;;;12094:49;12123:1;12127:7;12136:6;12094:20;:49::i;:::-;12172:6;12156:12;;:22;;;;;;;:::i;:::-;;;;;;;;12211:6;12189:9;:18;12199:7;12189:18;;;;;;;;;;;;;;;;:28;;;;;;;:::i;:::-;;;;;;;;12254:7;12233:37;;12250:1;12233:37;;;12263:6;12233:37;;;;;;:::i;:::-;;;;;;;;11940:338;;:::o;19630:238::-;19739:44;19766:4;19772:2;19776:6;19739:26;:44::i;:::-;19805:8;:6;:8::i;:::-;19804:9;19796:64;;;;;;;;;;;;:::i;:::-;;;;;;;;;19630:238;;;:::o;14492:92::-;;;;:::o;7:139:1:-;;91:6;78:20;69:29;;107:33;134:5;107:33;:::i;:::-;59:87;;;;:::o;152:139::-;;236:6;223:20;214:29;;252:33;279:5;252:33;:::i;:::-;204:87;;;;:::o;297:137::-;;380:6;367:20;358:29;;396:32;422:5;396:32;:::i;:::-;348:86;;;;:::o;440:139::-;;524:6;511:20;502:29;;540:33;567:5;540:33;:::i;:::-;492:87;;;;:::o;585:262::-;;693:2;681:9;672:7;668:23;664:32;661:2;;;709:1;706;699:12;661:2;752:1;777:53;822:7;813:6;802:9;798:22;777:53;:::i;:::-;767:63;;723:117;651:196;;;;:::o;853:407::-;;;978:2;966:9;957:7;953:23;949:32;946:2;;;994:1;991;984:12;946:2;1037:1;1062:53;1107:7;1098:6;1087:9;1083:22;1062:53;:::i;:::-;1052:63;;1008:117;1164:2;1190:53;1235:7;1226:6;1215:9;1211:22;1190:53;:::i;:::-;1180:63;;1135:118;936:324;;;;;:::o;1266:552::-;;;;1408:2;1396:9;1387:7;1383:23;1379:32;1376:2;;;1424:1;1421;1414:12;1376:2;1467:1;1492:53;1537:7;1528:6;1517:9;1513:22;1492:53;:::i;:::-;1482:63;;1438:117;1594:2;1620:53;1665:7;1656:6;1645:9;1641:22;1620:53;:::i;:::-;1610:63;;1565:118;1722:2;1748:53;1793:7;1784:6;1773:9;1769:22;1748:53;:::i;:::-;1738:63;;1693:118;1366:452;;;;;:::o;1824:407::-;;;1949:2;1937:9;1928:7;1924:23;1920:32;1917:2;;;1965:1;1962;1955:12;1917:2;2008:1;2033:53;2078:7;2069:6;2058:9;2054:22;2033:53;:::i;:::-;2023:63;;1979:117;2135:2;2161:53;2206:7;2197:6;2186:9;2182:22;2161:53;:::i;:::-;2151:63;;2106:118;1907:324;;;;;:::o;2237:262::-;;2345:2;2333:9;2324:7;2320:23;2316:32;2313:2;;;2361:1;2358;2351:12;2313:2;2404:1;2429:53;2474:7;2465:6;2454:9;2450:22;2429:53;:::i;:::-;2419:63;;2375:117;2303:196;;;;:::o;2505:407::-;;;2630:2;2618:9;2609:7;2605:23;2601:32;2598:2;;;2646:1;2643;2636:12;2598:2;2689:1;2714:53;2759:7;2750:6;2739:9;2735:22;2714:53;:::i;:::-;2704:63;;2660:117;2816:2;2842:53;2887:7;2878:6;2867:9;2863:22;2842:53;:::i;:::-;2832:63;;2787:118;2588:324;;;;;:::o;2918:407::-;;;3043:2;3031:9;3022:7;3018:23;3014:32;3011:2;;;3059:1;3056;3049:12;3011:2;3102:1;3127:53;3172:7;3163:6;3152:9;3148:22;3127:53;:::i;:::-;3117:63;;3073:117;3229:2;3255:53;3300:7;3291:6;3280:9;3276:22;3255:53;:::i;:::-;3245:63;;3200:118;3001:324;;;;;:::o;3331:260::-;;3438:2;3426:9;3417:7;3413:23;3409:32;3406:2;;;3454:1;3451;3444:12;3406:2;3497:1;3522:52;3566:7;3557:6;3546:9;3542:22;3522:52;:::i;:::-;3512:62;;3468:116;3396:195;;;;:::o;3597:262::-;;3705:2;3693:9;3684:7;3680:23;3676:32;3673:2;;;3721:1;3718;3711:12;3673:2;3764:1;3789:53;3834:7;3825:6;3814:9;3810:22;3789:53;:::i;:::-;3779:63;;3735:117;3663:196;;;;:::o;3865:118::-;3952:24;3970:5;3952:24;:::i;:::-;3947:3;3940:37;3930:53;;:::o;3989:109::-;4070:21;4085:5;4070:21;:::i;:::-;4065:3;4058:34;4048:50;;:::o;4104:118::-;4191:24;4209:5;4191:24;:::i;:::-;4186:3;4179:37;4169:53;;:::o;4228:364::-;;4344:39;4377:5;4344:39;:::i;:::-;4399:71;4463:6;4458:3;4399:71;:::i;:::-;4392:78;;4479:52;4524:6;4519:3;4512:4;4505:5;4501:16;4479:52;:::i;:::-;4556:29;4578:6;4556:29;:::i;:::-;4551:3;4547:39;4540:46;;4320:272;;;;;:::o;4598:366::-;;4761:67;4825:2;4820:3;4761:67;:::i;:::-;4754:74;;4858:34;4854:1;4849:3;4845:11;4838:55;4924:4;4919:2;4914:3;4910:12;4903:26;4955:2;4950:3;4946:12;4939:19;;4744:220;;;:::o;4970:367::-;;5133:67;5197:2;5192:3;5133:67;:::i;:::-;5126:74;;5230:34;5226:1;5221:3;5217:11;5210:55;5296:5;5291:2;5286:3;5282:12;5275:27;5328:2;5323:3;5319:12;5312:19;;5116:221;;;:::o;5343:379::-;;5506:67;5570:2;5565:3;5506:67;:::i;:::-;5499:74;;5603:34;5599:1;5594:3;5590:11;5583:55;5669:17;5664:2;5659:3;5655:12;5648:39;5713:2;5708:3;5704:12;5697:19;;5489:233;;;:::o;5728:318::-;;5891:67;5955:2;5950:3;5891:67;:::i;:::-;5884:74;;5988:22;5984:1;5979:3;5975:11;5968:43;6037:2;6032:3;6028:12;6021:19;;5874:172;;;:::o;6052:366::-;;6215:67;6279:2;6274:3;6215:67;:::i;:::-;6208:74;;6312:34;6308:1;6303:3;6299:11;6292:55;6378:4;6373:2;6368:3;6364:12;6357:26;6409:2;6404:3;6400:12;6393:19;;6198:220;;;:::o;6424:389::-;;6587:67;6651:2;6646:3;6587:67;:::i;:::-;6580:74;;6684:34;6680:1;6675:3;6671:11;6664:55;6750:27;6745:2;6740:3;6736:12;6729:49;6804:2;6799:3;6795:12;6788:19;;6570:243;;;:::o;6819:366::-;;6982:67;7046:2;7041:3;6982:67;:::i;:::-;6975:74;;7079:34;7075:1;7070:3;7066:11;7059:55;7145:4;7140:2;7135:3;7131:12;7124:26;7176:2;7171:3;7167:12;7160:19;;6965:220;;;:::o;7191:370::-;;7354:67;7418:2;7413:3;7354:67;:::i;:::-;7347:74;;7451:34;7447:1;7442:3;7438:11;7431:55;7517:8;7512:2;7507:3;7503:12;7496:30;7552:2;7547:3;7543:12;7536:19;;7337:224;;;:::o;7567:380::-;;7730:67;7794:2;7789:3;7730:67;:::i;:::-;7723:74;;7827:34;7823:1;7818:3;7814:11;7807:55;7893:18;7888:2;7883:3;7879:12;7872:40;7938:2;7933:3;7929:12;7922:19;;7713:234;;;:::o;7953:314::-;;8116:67;8180:2;8175:3;8116:67;:::i;:::-;8109:74;;8213:18;8209:1;8204:3;8200:11;8193:39;8258:2;8253:3;8249:12;8242:19;;8099:168;;;:::o;8273:372::-;;8436:67;8500:2;8495:3;8436:67;:::i;:::-;8429:74;;8533:34;8529:1;8524:3;8520:11;8513:55;8599:10;8594:2;8589:3;8585:12;8578:32;8636:2;8631:3;8627:12;8620:19;;8419:226;;;:::o;8651:386::-;;8814:67;8878:2;8873:3;8814:67;:::i;:::-;8807:74;;8911:34;8907:1;8902:3;8898:11;8891:55;8977:24;8972:2;8967:3;8963:12;8956:46;9028:2;9023:3;9019:12;9012:19;;8797:240;;;:::o;9043:368::-;;9206:67;9270:2;9265:3;9206:67;:::i;:::-;9199:74;;9303:34;9299:1;9294:3;9290:11;9283:55;9369:6;9364:2;9359:3;9355:12;9348:28;9402:2;9397:3;9393:12;9386:19;;9189:222;;;:::o;9417:365::-;;9580:67;9644:2;9639:3;9580:67;:::i;:::-;9573:74;;9677:34;9673:1;9668:3;9664:11;9657:55;9743:3;9738:2;9733:3;9729:12;9722:25;9773:2;9768:3;9764:12;9757:19;;9563:219;;;:::o;9788:369::-;;9951:67;10015:2;10010:3;9951:67;:::i;:::-;9944:74;;10048:34;10044:1;10039:3;10035:11;10028:55;10114:7;10109:2;10104:3;10100:12;10093:29;10148:2;10143:3;10139:12;10132:19;;9934:223;;;:::o;10163:323::-;;10326:67;10390:2;10385:3;10326:67;:::i;:::-;10319:74;;10423:27;10419:1;10414:3;10410:11;10403:48;10477:2;10472:3;10468:12;10461:19;;10309:177;;;:::o;10492:368::-;;10655:67;10719:2;10714:3;10655:67;:::i;:::-;10648:74;;10752:34;10748:1;10743:3;10739:11;10732:55;10818:6;10813:2;10808:3;10804:12;10797:28;10851:2;10846:3;10842:12;10835:19;;10638:222;;;:::o;10866:387::-;;11029:67;11093:2;11088:3;11029:67;:::i;:::-;11022:74;;11126:34;11122:1;11117:3;11113:11;11106:55;11192:25;11187:2;11182:3;11178:12;11171:47;11244:2;11239:3;11235:12;11228:19;;11012:241;;;:::o;11259:369::-;;11422:67;11486:2;11481:3;11422:67;:::i;:::-;11415:74;;11519:34;11515:1;11510:3;11506:11;11499:55;11585:7;11580:2;11575:3;11571:12;11564:29;11619:2;11614:3;11610:12;11603:19;;11405:223;;;:::o;11634:379::-;;11797:67;11861:2;11856:3;11797:67;:::i;:::-;11790:74;;11894:34;11890:1;11885:3;11881:11;11874:55;11960:17;11955:2;11950:3;11946:12;11939:39;12004:2;11999:3;11995:12;11988:19;;11780:233;;;:::o;12019:329::-;;12182:67;12246:2;12241:3;12182:67;:::i;:::-;12175:74;;12279:33;12275:1;12270:3;12266:11;12259:54;12339:2;12334:3;12330:12;12323:19;;12165:183;;;:::o;12354:374::-;;12517:67;12581:2;12576:3;12517:67;:::i;:::-;12510:74;;12614:34;12610:1;12605:3;12601:11;12594:55;12680:12;12675:2;12670:3;12666:12;12659:34;12719:2;12714:3;12710:12;12703:19;;12500:228;;;:::o;12734:118::-;12821:24;12839:5;12821:24;:::i;:::-;12816:3;12809:37;12799:53;;:::o;12858:112::-;12941:22;12957:5;12941:22;:::i;:::-;12936:3;12929:35;12919:51;;:::o;12976:222::-;;13107:2;13096:9;13092:18;13084:26;;13120:71;13188:1;13177:9;13173:17;13164:6;13120:71;:::i;:::-;13074:124;;;;:::o;13204:210::-;;13329:2;13318:9;13314:18;13306:26;;13342:65;13404:1;13393:9;13389:17;13380:6;13342:65;:::i;:::-;13296:118;;;;:::o;13420:222::-;;13551:2;13540:9;13536:18;13528:26;;13564:71;13632:1;13621:9;13617:17;13608:6;13564:71;:::i;:::-;13518:124;;;;:::o;13648:313::-;;13799:2;13788:9;13784:18;13776:26;;13848:9;13842:4;13838:20;13834:1;13823:9;13819:17;13812:47;13876:78;13949:4;13940:6;13876:78;:::i;:::-;13868:86;;13766:195;;;;:::o;13967:419::-;;14171:2;14160:9;14156:18;14148:26;;14220:9;14214:4;14210:20;14206:1;14195:9;14191:17;14184:47;14248:131;14374:4;14248:131;:::i;:::-;14240:139;;14138:248;;;:::o;14392:419::-;;14596:2;14585:9;14581:18;14573:26;;14645:9;14639:4;14635:20;14631:1;14620:9;14616:17;14609:47;14673:131;14799:4;14673:131;:::i;:::-;14665:139;;14563:248;;;:::o;14817:419::-;;15021:2;15010:9;15006:18;14998:26;;15070:9;15064:4;15060:20;15056:1;15045:9;15041:17;15034:47;15098:131;15224:4;15098:131;:::i;:::-;15090:139;;14988:248;;;:::o;15242:419::-;;15446:2;15435:9;15431:18;15423:26;;15495:9;15489:4;15485:20;15481:1;15470:9;15466:17;15459:47;15523:131;15649:4;15523:131;:::i;:::-;15515:139;;15413:248;;;:::o;15667:419::-;;15871:2;15860:9;15856:18;15848:26;;15920:9;15914:4;15910:20;15906:1;15895:9;15891:17;15884:47;15948:131;16074:4;15948:131;:::i;:::-;15940:139;;15838:248;;;:::o;16092:419::-;;16296:2;16285:9;16281:18;16273:26;;16345:9;16339:4;16335:20;16331:1;16320:9;16316:17;16309:47;16373:131;16499:4;16373:131;:::i;:::-;16365:139;;16263:248;;;:::o;16517:419::-;;16721:2;16710:9;16706:18;16698:26;;16770:9;16764:4;16760:20;16756:1;16745:9;16741:17;16734:47;16798:131;16924:4;16798:131;:::i;:::-;16790:139;;16688:248;;;:::o;16942:419::-;;17146:2;17135:9;17131:18;17123:26;;17195:9;17189:4;17185:20;17181:1;17170:9;17166:17;17159:47;17223:131;17349:4;17223:131;:::i;:::-;17215:139;;17113:248;;;:::o;17367:419::-;;17571:2;17560:9;17556:18;17548:26;;17620:9;17614:4;17610:20;17606:1;17595:9;17591:17;17584:47;17648:131;17774:4;17648:131;:::i;:::-;17640:139;;17538:248;;;:::o;17792:419::-;;17996:2;17985:9;17981:18;17973:26;;18045:9;18039:4;18035:20;18031:1;18020:9;18016:17;18009:47;18073:131;18199:4;18073:131;:::i;:::-;18065:139;;17963:248;;;:::o;18217:419::-;;18421:2;18410:9;18406:18;18398:26;;18470:9;18464:4;18460:20;18456:1;18445:9;18441:17;18434:47;18498:131;18624:4;18498:131;:::i;:::-;18490:139;;18388:248;;;:::o;18642:419::-;;18846:2;18835:9;18831:18;18823:26;;18895:9;18889:4;18885:20;18881:1;18870:9;18866:17;18859:47;18923:131;19049:4;18923:131;:::i;:::-;18915:139;;18813:248;;;:::o;19067:419::-;;19271:2;19260:9;19256:18;19248:26;;19320:9;19314:4;19310:20;19306:1;19295:9;19291:17;19284:47;19348:131;19474:4;19348:131;:::i;:::-;19340:139;;19238:248;;;:::o;19492:419::-;;19696:2;19685:9;19681:18;19673:26;;19745:9;19739:4;19735:20;19731:1;19720:9;19716:17;19709:47;19773:131;19899:4;19773:131;:::i;:::-;19765:139;;19663:248;;;:::o;19917:419::-;;20121:2;20110:9;20106:18;20098:26;;20170:9;20164:4;20160:20;20156:1;20145:9;20141:17;20134:47;20198:131;20324:4;20198:131;:::i;:::-;20190:139;;20088:248;;;:::o;20342:419::-;;20546:2;20535:9;20531:18;20523:26;;20595:9;20589:4;20585:20;20581:1;20570:9;20566:17;20559:47;20623:131;20749:4;20623:131;:::i;:::-;20615:139;;20513:248;;;:::o;20767:419::-;;20971:2;20960:9;20956:18;20948:26;;21020:9;21014:4;21010:20;21006:1;20995:9;20991:17;20984:47;21048:131;21174:4;21048:131;:::i;:::-;21040:139;;20938:248;;;:::o;21192:419::-;;21396:2;21385:9;21381:18;21373:26;;21445:9;21439:4;21435:20;21431:1;21420:9;21416:17;21409:47;21473:131;21599:4;21473:131;:::i;:::-;21465:139;;21363:248;;;:::o;21617:419::-;;21821:2;21810:9;21806:18;21798:26;;21870:9;21864:4;21860:20;21856:1;21845:9;21841:17;21834:47;21898:131;22024:4;21898:131;:::i;:::-;21890:139;;21788:248;;;:::o;22042:419::-;;22246:2;22235:9;22231:18;22223:26;;22295:9;22289:4;22285:20;22281:1;22270:9;22266:17;22259:47;22323:131;22449:4;22323:131;:::i;:::-;22315:139;;22213:248;;;:::o;22467:419::-;;22671:2;22660:9;22656:18;22648:26;;22720:9;22714:4;22710:20;22706:1;22695:9;22691:17;22684:47;22748:131;22874:4;22748:131;:::i;:::-;22740:139;;22638:248;;;:::o;22892:419::-;;23096:2;23085:9;23081:18;23073:26;;23145:9;23139:4;23135:20;23131:1;23120:9;23116:17;23109:47;23173:131;23299:4;23173:131;:::i;:::-;23165:139;;23063:248;;;:::o;23317:222::-;;23448:2;23437:9;23433:18;23425:26;;23461:71;23529:1;23518:9;23514:17;23505:6;23461:71;:::i;:::-;23415:124;;;;:::o;23545:214::-;;23672:2;23661:9;23657:18;23649:26;;23685:67;23749:1;23738:9;23734:17;23725:6;23685:67;:::i;:::-;23639:120;;;;:::o;23765:99::-;;23851:5;23845:12;23835:22;;23824:40;;;:::o;23870:169::-;;23988:6;23983:3;23976:19;24028:4;24023:3;24019:14;24004:29;;23966:73;;;;:::o;24045:305::-;;24104:20;24122:1;24104:20;:::i;:::-;24099:25;;24138:20;24156:1;24138:20;:::i;:::-;24133:25;;24292:1;24224:66;24220:74;24217:1;24214:81;24211:2;;;24298:18;;:::i;:::-;24211:2;24342:1;24339;24335:9;24328:16;;24089:261;;;;:::o;24356:191::-;;24416:20;24434:1;24416:20;:::i;:::-;24411:25;;24450:20;24468:1;24450:20;:::i;:::-;24445:25;;24489:1;24486;24483:8;24480:2;;;24494:18;;:::i;:::-;24480:2;24539:1;24536;24532:9;24524:17;;24401:146;;;;:::o;24553:96::-;;24619:24;24637:5;24619:24;:::i;:::-;24608:35;;24598:51;;;:::o;24655:90::-;;24732:5;24725:13;24718:21;24707:32;;24697:48;;;:::o;24751:77::-;;24817:5;24806:16;;24796:32;;;:::o;24834:149::-;;24910:66;24903:5;24899:78;24888:89;;24878:105;;;:::o;24989:126::-;;25066:42;25059:5;25055:54;25044:65;;25034:81;;;:::o;25121:77::-;;25187:5;25176:16;;25166:32;;;:::o;25204:86::-;;25279:4;25272:5;25268:16;25257:27;;25247:43;;;:::o;25296:307::-;25364:1;25374:113;25388:6;25385:1;25382:13;25374:113;;;25473:1;25468:3;25464:11;25458:18;25454:1;25449:3;25445:11;25438:39;25410:2;25407:1;25403:10;25398:15;;25374:113;;;25505:6;25502:1;25499:13;25496:2;;;25585:1;25576:6;25571:3;25567:16;25560:27;25496:2;25345:258;;;;:::o;25609:320::-;;25690:1;25684:4;25680:12;25670:22;;25737:1;25731:4;25727:12;25758:18;25748:2;;25814:4;25806:6;25802:17;25792:27;;25748:2;25876;25868:6;25865:14;25845:18;25842:38;25839:2;;;25895:18;;:::i;:::-;25839:2;25660:269;;;;:::o;25935:180::-;25983:77;25980:1;25973:88;26080:4;26077:1;26070:15;26104:4;26101:1;26094:15;26121:180;26169:77;26166:1;26159:88;26266:4;26263:1;26256:15;26290:4;26287:1;26280:15;26307:102;;26399:2;26395:7;26390:2;26383:5;26379:14;26375:28;26365:38;;26355:54;;;:::o;26415:122::-;26488:24;26506:5;26488:24;:::i;:::-;26481:5;26478:35;26468:2;;26527:1;26524;26517:12;26468:2;26458:79;:::o;26543:122::-;26616:24;26634:5;26616:24;:::i;:::-;26609:5;26606:35;26596:2;;26655:1;26652;26645:12;26596:2;26586:79;:::o;26671:120::-;26743:23;26760:5;26743:23;:::i;:::-;26736:5;26733:34;26723:2;;26781:1;26778;26771:12;26723:2;26713:78;:::o;26797:122::-;26870:24;26888:5;26870:24;:::i;:::-;26863:5;26860:35;26850:2;;26909:1;26906;26899:12;26850:2;26840:79;:::o

Swarm Source

ipfs://3949702d57c950a296ef6e12c42bf64424e9eec14da401981990c398d05705ee

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.