Token Astro Kid

 

Overview

TokenID:
1115

Transfers:
-

Loading
[ Download CSV Export  ] 
Loading
Loading

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

Contract Source Code Verified (Exact Match)

Contract Name:
AstroKid

Compiler Version
v0.8.7+commit.e28d00a7

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, None license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2022-02-01
*/

// SPDX-License-Identifier: MIT

// File @openzeppelin/contracts/utils/introspection/[email protected]

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/token/ERC721/[email protected]

pragma solidity ^0.8.0;

/**
 * @dev Required interface of an ERC721 compliant contract.
 */
interface IERC721 is IERC165 {
    /**
     * @dev Emitted when `tokenId` token is transferred from `from` to `to`.
     */
    event Transfer(
        address indexed from,
        address indexed to,
        uint256 indexed tokenId
    );

    /**
     * @dev Emitted when `owner` enables `approved` to manage the `tokenId` token.
     */
    event Approval(
        address indexed owner,
        address indexed approved,
        uint256 indexed tokenId
    );

    /**
     * @dev Emitted when `owner` enables or disables (`approved`) `operator` to manage all of its assets.
     */
    event ApprovalForAll(
        address indexed owner,
        address indexed operator,
        bool approved
    );

    /**
     * @dev Returns the number of tokens in ``owner``'s account.
     */
    function balanceOf(address owner) external view returns (uint256 balance);

    /**
     * @dev Returns the owner of the `tokenId` token.
     *
     * Requirements:
     *
     * - `tokenId` must exist.
     */
    function ownerOf(uint256 tokenId) external view returns (address owner);

    /**
     * @dev Safely transfers `tokenId` token from `from` to `to`, checking first that contract recipients
     * are aware of the ERC721 protocol to prevent tokens from being forever locked.
     *
     * Requirements:
     *
     * - `from` cannot be the zero address.
     * - `to` cannot be the zero address.
     * - `tokenId` token must exist and be owned by `from`.
     * - If the caller is not `from`, it must be have been allowed to move this token by either {approve} or {setApprovalForAll}.
     * - If `to` refers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called upon a safe transfer.
     *
     * Emits a {Transfer} event.
     */
    function safeTransferFrom(
        address from,
        address to,
        uint256 tokenId
    ) external;

    /**
     * @dev Transfers `tokenId` token from `from` to `to`.
     *
     * WARNING: Usage of this method is discouraged, use {safeTransferFrom} whenever possible.
     *
     * Requirements:
     *
     * - `from` cannot be the zero address.
     * - `to` cannot be the zero address.
     * - `tokenId` token must be owned by `from`.
     * - If the caller is not `from`, it must be approved to move this token by either {approve} or {setApprovalForAll}.
     *
     * Emits a {Transfer} event.
     */
    function transferFrom(
        address from,
        address to,
        uint256 tokenId
    ) external;

    /**
     * @dev Gives permission to `to` to transfer `tokenId` token to another account.
     * The approval is cleared when the token is transferred.
     *
     * Only a single account can be approved at a time, so approving the zero address clears previous approvals.
     *
     * Requirements:
     *
     * - The caller must own the token or be an approved operator.
     * - `tokenId` must exist.
     *
     * Emits an {Approval} event.
     */
    function approve(address to, uint256 tokenId) external;

    /**
     * @dev Returns the account approved for `tokenId` token.
     *
     * Requirements:
     *
     * - `tokenId` must exist.
     */
    function getApproved(uint256 tokenId)
        external
        view
        returns (address operator);

    /**
     * @dev Approve or remove `operator` as an operator for the caller.
     * Operators can call {transferFrom} or {safeTransferFrom} for any token owned by the caller.
     *
     * Requirements:
     *
     * - The `operator` cannot be the caller.
     *
     * Emits an {ApprovalForAll} event.
     */
    function setApprovalForAll(address operator, bool _approved) external;

    /**
     * @dev Returns if the `operator` is allowed to manage all of the assets of `owner`.
     *
     * See {setApprovalForAll}
     */
    function isApprovedForAll(address owner, address operator)
        external
        view
        returns (bool);

    /**
     * @dev Safely transfers `tokenId` token from `from` to `to`.
     *
     * Requirements:
     *
     * - `from` cannot be the zero address.
     * - `to` cannot be the zero address.
     * - `tokenId` token must exist and be owned by `from`.
     * - If the caller is not `from`, it must be approved to move this token by either {approve} or {setApprovalForAll}.
     * - If `to` refers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called upon a safe transfer.
     *
     * Emits a {Transfer} event.
     */
    function safeTransferFrom(
        address from,
        address to,
        uint256 tokenId,
        bytes calldata data
    ) external;
}

// File @openzeppelin/contracts/token/ERC721/[email protected]

pragma solidity ^0.8.0;

/**
 * @title ERC721 token receiver interface
 * @dev Interface for any contract that wants to support safeTransfers
 * from ERC721 asset contracts.
 */
interface IERC721Receiver {
    /**
     * @dev Whenever an {IERC721} `tokenId` token is transferred to this contract via {IERC721-safeTransferFrom}
     * by `operator` from `from`, this function is called.
     *
     * It must return its Solidity selector to confirm the token transfer.
     * If any other value is returned or the interface is not implemented by the recipient, the transfer will be reverted.
     *
     * The selector can be obtained in Solidity with `IERC721.onERC721Received.selector`.
     */
    function onERC721Received(
        address operator,
        address from,
        uint256 tokenId,
        bytes calldata data
    ) external returns (bytes4);
}

// File @openzeppelin/contracts/token/ERC721/extensions/[email protected]

pragma solidity ^0.8.0;

/**
 * @title ERC-721 Non-Fungible Token Standard, optional metadata extension
 * @dev See https://eips.ethereum.org/EIPS/eip-721
 */
interface IERC721Metadata is IERC721 {
    /**
     * @dev Returns the token collection name.
     */
    function name() external view returns (string memory);

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

    /**
     * @dev Returns the Uniform Resource Identifier (URI) for `tokenId` token.
     */
    function tokenURI(uint256 tokenId) external view returns (string memory);
}

// File @openzeppelin/contracts/utils/[email protected]

pragma solidity ^0.8.0;

/**
 * @dev Collection of functions related to the address type
 */
library Address {
    /**
     * @dev Returns true if `account` is a contract.
     *
     * [IMPORTANT]
     * ====
     * It is unsafe to assume that an address for which this function returns
     * false is an externally-owned account (EOA) and not a contract.
     *
     * Among others, `isContract` will return false for the following
     * types of addresses:
     *
     *  - an externally-owned account
     *  - a contract in construction
     *  - an address where a contract will be created
     *  - an address where a contract lived, but was destroyed
     * ====
     */
    function isContract(address account) internal view returns (bool) {
        // This method relies on extcodesize, which returns 0 for contracts in
        // construction, since the code is only stored at the end of the
        // constructor execution.

        uint256 size;
        // solhint-disable-next-line no-inline-assembly
        assembly {
            size := extcodesize(account)
        }
        return size > 0;
    }

    /**
     * @dev Replacement for Solidity's `transfer`: sends `amount` wei to
     * `recipient`, forwarding all available gas and reverting on errors.
     *
     * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost
     * of certain opcodes, possibly making contracts go over the 2300 gas limit
     * imposed by `transfer`, making them unable to receive funds via
     * `transfer`. {sendValue} removes this limitation.
     *
     * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].
     *
     * IMPORTANT: because control is transferred to `recipient`, care must be
     * taken to not create reentrancy vulnerabilities. Consider using
     * {ReentrancyGuard} or the
     * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].
     */
    function sendValue(address payable recipient, uint256 amount) internal {
        require(
            address(this).balance >= amount,
            "Address: insufficient balance"
        );

        // solhint-disable-next-line avoid-low-level-calls, avoid-call-value
        (bool success, ) = recipient.call{value: amount}("");
        require(
            success,
            "Address: unable to send value, recipient may have reverted"
        );
    }

    /**
     * @dev Performs a Solidity function call using a low level `call`. A
     * plain`call` is an unsafe replacement for a function call: use this
     * function instead.
     *
     * If `target` reverts with a revert reason, it is bubbled up by this
     * function (like regular Solidity function calls).
     *
     * Returns the raw returned data. To convert to the expected return value,
     * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].
     *
     * Requirements:
     *
     * - `target` must be a contract.
     * - calling `target` with `data` must not revert.
     *
     * _Available since v3.1._
     */
    function functionCall(address target, bytes memory data)
        internal
        returns (bytes memory)
    {
        return functionCall(target, data, "Address: low-level call failed");
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with
     * `errorMessage` as a fallback revert reason when `target` reverts.
     *
     * _Available since v3.1._
     */
    function functionCall(
        address target,
        bytes memory data,
        string memory errorMessage
    ) internal returns (bytes memory) {
        return functionCallWithValue(target, data, 0, errorMessage);
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but also transferring `value` wei to `target`.
     *
     * Requirements:
     *
     * - the calling contract must have an ETH balance of at least `value`.
     * - the called Solidity function must be `payable`.
     *
     * _Available since v3.1._
     */
    function functionCallWithValue(
        address target,
        bytes memory data,
        uint256 value
    ) internal returns (bytes memory) {
        return
            functionCallWithValue(
                target,
                data,
                value,
                "Address: low-level call with value failed"
            );
    }

    /**
     * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but
     * with `errorMessage` as a fallback revert reason when `target` reverts.
     *
     * _Available since v3.1._
     */
    function functionCallWithValue(
        address target,
        bytes memory data,
        uint256 value,
        string memory errorMessage
    ) internal returns (bytes memory) {
        require(
            address(this).balance >= value,
            "Address: insufficient balance for call"
        );
        require(isContract(target), "Address: call to non-contract");

        // solhint-disable-next-line avoid-low-level-calls
        (bool success, bytes memory returndata) = target.call{value: value}(
            data
        );
        return _verifyCallResult(success, returndata, errorMessage);
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but performing a static call.
     *
     * _Available since v3.3._
     */
    function functionStaticCall(address target, bytes memory data)
        internal
        view
        returns (bytes memory)
    {
        return
            functionStaticCall(
                target,
                data,
                "Address: low-level static call failed"
            );
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],
     * but performing a static call.
     *
     * _Available since v3.3._
     */
    function functionStaticCall(
        address target,
        bytes memory data,
        string memory errorMessage
    ) internal view returns (bytes memory) {
        require(isContract(target), "Address: static call to non-contract");

        // solhint-disable-next-line avoid-low-level-calls
        (bool success, bytes memory returndata) = target.staticcall(data);
        return _verifyCallResult(success, returndata, errorMessage);
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but performing a delegate call.
     *
     * _Available since v3.4._
     */
    function functionDelegateCall(address target, bytes memory data)
        internal
        returns (bytes memory)
    {
        return
            functionDelegateCall(
                target,
                data,
                "Address: low-level delegate call failed"
            );
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],
     * but performing a delegate call.
     *
     * _Available since v3.4._
     */
    function functionDelegateCall(
        address target,
        bytes memory data,
        string memory errorMessage
    ) internal returns (bytes memory) {
        require(isContract(target), "Address: delegate call to non-contract");

        // solhint-disable-next-line avoid-low-level-calls
        (bool success, bytes memory returndata) = target.delegatecall(data);
        return _verifyCallResult(success, returndata, errorMessage);
    }

    function _verifyCallResult(
        bool success,
        bytes memory returndata,
        string memory errorMessage
    ) private pure returns (bytes memory) {
        if (success) {
            return returndata;
        } else {
            // Look for revert reason and bubble it up if present
            if (returndata.length > 0) {
                // The easiest way to bubble the revert reason is using memory via assembly

                // solhint-disable-next-line no-inline-assembly
                assembly {
                    let returndata_size := mload(returndata)
                    revert(add(32, returndata), returndata_size)
                }
            } else {
                revert(errorMessage);
            }
        }
    }
}

// File @openzeppelin/contracts/utils/[email protected]

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/utils/[email protected]

pragma solidity ^0.8.0;

/**
 * @dev String operations.
 */
library Strings {
    bytes16 private constant alphabet = "0123456789abcdef";

    /**
     * @dev Converts a `uint256` to its ASCII `string` decimal representation.
     */
    function toString(uint256 value) internal pure returns (string memory) {
        // Inspired by OraclizeAPI's implementation - MIT licence
        // https://github.com/oraclize/ethereum-api/blob/b42146b063c7d6ee1358846c198246239e9360e8/oraclizeAPI_0.4.25.sol

        if (value == 0) {
            return "0";
        }
        uint256 temp = value;
        uint256 digits;
        while (temp != 0) {
            digits++;
            temp /= 10;
        }
        bytes memory buffer = new bytes(digits);
        while (value != 0) {
            digits -= 1;
            buffer[digits] = bytes1(uint8(48 + uint256(value % 10)));
            value /= 10;
        }
        return string(buffer);
    }

    /**
     * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation.
     */
    function toHexString(uint256 value) internal pure returns (string memory) {
        if (value == 0) {
            return "0x00";
        }
        uint256 temp = value;
        uint256 length = 0;
        while (temp != 0) {
            length++;
            temp >>= 8;
        }
        return toHexString(value, length);
    }

    /**
     * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation with fixed length.
     */
    function toHexString(uint256 value, uint256 length)
        internal
        pure
        returns (string memory)
    {
        bytes memory buffer = new bytes(2 * length + 2);
        buffer[0] = "0";
        buffer[1] = "x";
        for (uint256 i = 2 * length + 1; i > 1; --i) {
            buffer[i] = alphabet[value & 0xf];
            value >>= 4;
        }
        require(value == 0, "Strings: hex length insufficient");
        return string(buffer);
    }
}

// File @openzeppelin/contracts/utils/introspection/[email protected]

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/token/ERC721/[email protected]

pragma solidity ^0.8.0;

/**
 * @dev Implementation of https://eips.ethereum.org/EIPS/eip-721[ERC721] Non-Fungible Token Standard, including
 * the Metadata extension, but not including the Enumerable extension, which is available separately as
 * {ERC721Enumerable}.
 */
contract ERC721 is Context, ERC165, IERC721, IERC721Metadata {
    using Address for address;
    using Strings for uint256;

    // Token name
    string private _name;

    // Token symbol
    string private _symbol;

    // Mapping from token ID to owner address
    mapping(uint256 => address) private _owners;

    // Mapping owner address to token count
    mapping(address => uint256) private _balances;

    // Mapping from token ID to approved address
    mapping(uint256 => address) private _tokenApprovals;

    // Mapping from owner to operator approvals
    mapping(address => mapping(address => bool)) private _operatorApprovals;

    /**
     * @dev Initializes the contract by setting a `name` and a `symbol` to the token collection.
     */
    constructor(string memory name_, string memory symbol_) {
        _name = name_;
        _symbol = symbol_;
    }

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

    /**
     * @dev See {IERC721-balanceOf}.
     */
    function balanceOf(address owner)
        public
        view
        virtual
        override
        returns (uint256)
    {
        require(
            owner != address(0),
            "ERC721: balance query for the zero address"
        );
        return _balances[owner];
    }

    /**
     * @dev See {IERC721-ownerOf}.
     */
    function ownerOf(uint256 tokenId)
        public
        view
        virtual
        override
        returns (address)
    {
        address owner = _owners[tokenId];
        require(
            owner != address(0),
            "ERC721: owner query for nonexistent token"
        );
        return owner;
    }

    /**
     * @dev See {IERC721Metadata-name}.
     */
    function name() public view virtual override returns (string memory) {
        return _name;
    }

    /**
     * @dev See {IERC721Metadata-symbol}.
     */
    function symbol() public view virtual override returns (string memory) {
        return _symbol;
    }

    /**
     * @dev See {IERC721Metadata-tokenURI}.
     */
    function tokenURI(uint256 tokenId)
        public
        view
        virtual
        override
        returns (string memory)
    {
        require(
            _exists(tokenId),
            "ERC721Metadata: URI query for nonexistent token"
        );

        string memory baseURI = _baseURI();
        return
            bytes(baseURI).length > 0
                ? string(abi.encodePacked(baseURI, tokenId.toString()))
                : "";
    }

    /**
     * @dev Base URI for computing {tokenURI}. Empty by default, can be overriden
     * in child contracts.
     */
    function _baseURI() internal view virtual returns (string memory) {
        return "";
    }

    function _baseExtension() internal view virtual returns (string memory) {
        return "";
    }

    /**
     * @dev See {IERC721-approve}.
     */
    function approve(address to, uint256 tokenId) public virtual override {
        address owner = ERC721.ownerOf(tokenId);
        require(to != owner, "ERC721: approval to current owner");

        require(
            _msgSender() == owner || isApprovedForAll(owner, _msgSender()),
            "ERC721: approve caller is not owner nor approved for all"
        );

        _approve(to, tokenId);
    }

    /**
     * @dev See {IERC721-getApproved}.
     */
    function getApproved(uint256 tokenId)
        public
        view
        virtual
        override
        returns (address)
    {
        require(
            _exists(tokenId),
            "ERC721: approved query for nonexistent token"
        );

        return _tokenApprovals[tokenId];
    }

    /**
     * @dev See {IERC721-setApprovalForAll}.
     */
    function setApprovalForAll(address operator, bool approved)
        public
        virtual
        override
    {
        require(operator != _msgSender(), "ERC721: approve to caller");

        _operatorApprovals[_msgSender()][operator] = approved;
        emit ApprovalForAll(_msgSender(), operator, approved);
    }

    /**
     * @dev See {IERC721-isApprovedForAll}.
     */
    function isApprovedForAll(address owner, address operator)
        public
        view
        virtual
        override
        returns (bool)
    {
        return _operatorApprovals[owner][operator];
    }

    /**
     * @dev See {IERC721-transferFrom}.
     */
    function transferFrom(
        address from,
        address to,
        uint256 tokenId
    ) public virtual override {
        //solhint-disable-next-line max-line-length
        require(
            _isApprovedOrOwner(_msgSender(), tokenId),
            "ERC721: transfer caller is not owner nor approved"
        );

        _transfer(from, to, tokenId);
    }

    /**
     * @dev See {IERC721-safeTransferFrom}.
     */
    function safeTransferFrom(
        address from,
        address to,
        uint256 tokenId
    ) public virtual override {
        safeTransferFrom(from, to, tokenId, "");
    }

    /**
     * @dev See {IERC721-safeTransferFrom}.
     */
    function safeTransferFrom(
        address from,
        address to,
        uint256 tokenId,
        bytes memory _data
    ) public virtual override {
        require(
            _isApprovedOrOwner(_msgSender(), tokenId),
            "ERC721: transfer caller is not owner nor approved"
        );
        _safeTransfer(from, to, tokenId, _data);
    }

    /**
     * @dev Safely transfers `tokenId` token from `from` to `to`, checking first that contract recipients
     * are aware of the ERC721 protocol to prevent tokens from being forever locked.
     *
     * `_data` is additional data, it has no specified format and it is sent in call to `to`.
     *
     * This internal function is equivalent to {safeTransferFrom}, and can be used to e.g.
     * implement alternative mechanisms to perform token transfer, such as signature-based.
     *
     * Requirements:
     *
     * - `from` cannot be the zero address.
     * - `to` cannot be the zero address.
     * - `tokenId` token must exist and be owned by `from`.
     * - If `to` refers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called upon a safe transfer.
     *
     * Emits a {Transfer} event.
     */
    function _safeTransfer(
        address from,
        address to,
        uint256 tokenId,
        bytes memory _data
    ) internal virtual {
        _transfer(from, to, tokenId);
        require(
            _checkOnERC721Received(from, to, tokenId, _data),
            "ERC721: transfer to non ERC721Receiver implementer"
        );
    }

    /**
     * @dev Returns whether `tokenId` exists.
     *
     * Tokens can be managed by their owner or approved accounts via {approve} or {setApprovalForAll}.
     *
     * Tokens start existing when they are minted (`_mint`),
     * and stop existing when they are burned (`_burn`).
     */
    function _exists(uint256 tokenId) internal view virtual returns (bool) {
        return _owners[tokenId] != address(0);
    }

    /**
     * @dev Returns whether `spender` is allowed to manage `tokenId`.
     *
     * Requirements:
     *
     * - `tokenId` must exist.
     */
    function _isApprovedOrOwner(address spender, uint256 tokenId)
        internal
        view
        virtual
        returns (bool)
    {
        require(
            _exists(tokenId),
            "ERC721: operator query for nonexistent token"
        );
        address owner = ERC721.ownerOf(tokenId);
        return (spender == owner ||
            getApproved(tokenId) == spender ||
            isApprovedForAll(owner, spender));
    }

    /**
     * @dev Safely mints `tokenId` and transfers it to `to`.
     *
     * Requirements:
     *
     * - `tokenId` must not exist.
     * - If `to` refers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called upon a safe transfer.
     *
     * Emits a {Transfer} event.
     */
    function _safeMint(address to, uint256 tokenId) internal virtual {
        _safeMint(to, tokenId, "");
    }

    /**
     * @dev Same as {xref-ERC721-_safeMint-address-uint256-}[`_safeMint`], with an additional `data` parameter which is
     * forwarded in {IERC721Receiver-onERC721Received} to contract recipients.
     */
    function _safeMint(
        address to,
        uint256 tokenId,
        bytes memory _data
    ) internal virtual {
        _mint(to, tokenId);
        require(
            _checkOnERC721Received(address(0), to, tokenId, _data),
            "ERC721: transfer to non ERC721Receiver implementer"
        );
    }

    /**
     * @dev Mints `tokenId` and transfers it to `to`.
     *
     * WARNING: Usage of this method is discouraged, use {_safeMint} whenever possible
     *
     * Requirements:
     *
     * - `tokenId` must not exist.
     * - `to` cannot be the zero address.
     *
     * Emits a {Transfer} event.
     */
    function _mint(address to, uint256 tokenId) internal virtual {
        require(to != address(0), "ERC721: mint to the zero address");
        require(!_exists(tokenId), "ERC721: token already minted");

        _beforeTokenTransfer(address(0), to, tokenId);

        _balances[to] += 1;
        _owners[tokenId] = to;

        emit Transfer(address(0), to, tokenId);
    }

    /**
     * @dev Destroys `tokenId`.
     * The approval is cleared when the token is burned.
     *
     * Requirements:
     *
     * - `tokenId` must exist.
     *
     * Emits a {Transfer} event.
     */
    function _burn(uint256 tokenId) internal virtual {
        address owner = ERC721.ownerOf(tokenId);

        _beforeTokenTransfer(owner, address(0), tokenId);

        // Clear approvals
        _approve(address(0), tokenId);

        _balances[owner] -= 1;
        delete _owners[tokenId];

        emit Transfer(owner, address(0), tokenId);
    }

    /**
     * @dev Transfers `tokenId` from `from` to `to`.
     *  As opposed to {transferFrom}, this imposes no restrictions on msg.sender.
     *
     * Requirements:
     *
     * - `to` cannot be the zero address.
     * - `tokenId` token must be owned by `from`.
     *
     * Emits a {Transfer} event.
     */
    function _transfer(
        address from,
        address to,
        uint256 tokenId
    ) internal virtual {
        require(
            ERC721.ownerOf(tokenId) == from,
            "ERC721: transfer of token that is not own"
        );
        require(to != address(0), "ERC721: transfer to the zero address");

        _beforeTokenTransfer(from, to, tokenId);

        // Clear approvals from the previous owner
        _approve(address(0), tokenId);

        _balances[from] -= 1;
        _balances[to] += 1;
        _owners[tokenId] = to;

        emit Transfer(from, to, tokenId);
    }

    /**
     * @dev Approve `to` to operate on `tokenId`
     *
     * Emits a {Approval} event.
     */
    function _approve(address to, uint256 tokenId) internal virtual {
        _tokenApprovals[tokenId] = to;
        emit Approval(ERC721.ownerOf(tokenId), to, tokenId);
    }

    /**
     * @dev Internal function to invoke {IERC721Receiver-onERC721Received} on a target address.
     * The call is not executed if the target address is not a contract.
     *
     * @param from address representing the previous owner of the given token ID
     * @param to target address that will receive the tokens
     * @param tokenId uint256 ID of the token to be transferred
     * @param _data bytes optional data to send along with the call
     * @return bool whether the call correctly returned the expected magic value
     */
    function _checkOnERC721Received(
        address from,
        address to,
        uint256 tokenId,
        bytes memory _data
    ) private returns (bool) {
        if (to.isContract()) {
            try
                IERC721Receiver(to).onERC721Received(
                    _msgSender(),
                    from,
                    tokenId,
                    _data
                )
            returns (bytes4 retval) {
                return retval == IERC721Receiver(to).onERC721Received.selector;
            } catch (bytes memory reason) {
                if (reason.length == 0) {
                    revert(
                        "ERC721: transfer to non ERC721Receiver implementer"
                    );
                } else {
                    // solhint-disable-next-line no-inline-assembly
                    assembly {
                        revert(add(32, reason), mload(reason))
                    }
                }
            }
        } else {
            return true;
        }
    }

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

// File @openzeppelin/contracts/token/ERC721/extensions/[email protected]

pragma solidity ^0.8.0;

/**
 * @title ERC-721 Non-Fungible Token Standard, optional enumeration extension
 * @dev See https://eips.ethereum.org/EIPS/eip-721
 */
interface IERC721Enumerable is IERC721 {
    /**
     * @dev Returns the total amount of tokens stored by the contract.
     */
    function totalSupply() external view returns (uint256);

    /**
     * @dev Returns a token ID owned by `owner` at a given `index` of its token list.
     * Use along with {balanceOf} to enumerate all of ``owner``'s tokens.
     */
    function tokenOfOwnerByIndex(address owner, uint256 index)
        external
        view
        returns (uint256 tokenId);

    /**
     * @dev Returns a token ID at a given `index` of all the tokens stored by the contract.
     * Use along with {totalSupply} to enumerate all tokens.
     */
    function tokenByIndex(uint256 index) external view returns (uint256);
}

// File @openzeppelin/contracts/token/ERC721/extensions/[email protected]

pragma solidity ^0.8.0;

/**
 * @dev This implements an optional extension of {ERC721} defined in the EIP that adds
 * enumerability of all the token ids in the contract as well as all token ids owned by each
 * account.
 */
abstract contract ERC721Enumerable is ERC721, IERC721Enumerable {
    // Mapping from owner to list of owned token IDs
    mapping(address => mapping(uint256 => uint256)) private _ownedTokens;

    // Mapping from token ID to index of the owner tokens list
    mapping(uint256 => uint256) private _ownedTokensIndex;

    // Array with all token ids, used for enumeration
    uint256[] private _allTokens;

    // Mapping from token id to position in the allTokens array
    mapping(uint256 => uint256) private _allTokensIndex;

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

    /**
     * @dev See {IERC721Enumerable-tokenOfOwnerByIndex}.
     */
    function tokenOfOwnerByIndex(address owner, uint256 index)
        public
        view
        virtual
        override
        returns (uint256)
    {
        require(
            index < ERC721.balanceOf(owner),
            "ERC721Enumerable: owner index out of bounds"
        );
        return _ownedTokens[owner][index];
    }

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

    /**
     * @dev See {IERC721Enumerable-tokenByIndex}.
     */
    function tokenByIndex(uint256 index)
        public
        view
        virtual
        override
        returns (uint256)
    {
        require(
            index < ERC721Enumerable.totalSupply(),
            "ERC721Enumerable: global index out of bounds"
        );
        return _allTokens[index];
    }

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

        if (from == address(0)) {
            _addTokenToAllTokensEnumeration(tokenId);
        } else if (from != to) {
            _removeTokenFromOwnerEnumeration(from, tokenId);
        }
        if (to == address(0)) {
            _removeTokenFromAllTokensEnumeration(tokenId);
        } else if (to != from) {
            _addTokenToOwnerEnumeration(to, tokenId);
        }
    }

    /**
     * @dev Private function to add a token to this extension's ownership-tracking data structures.
     * @param to address representing the new owner of the given token ID
     * @param tokenId uint256 ID of the token to be added to the tokens list of the given address
     */
    function _addTokenToOwnerEnumeration(address to, uint256 tokenId) private {
        uint256 length = ERC721.balanceOf(to);
        _ownedTokens[to][length] = tokenId;
        _ownedTokensIndex[tokenId] = length;
    }

    /**
     * @dev Private function to add a token to this extension's token tracking data structures.
     * @param tokenId uint256 ID of the token to be added to the tokens list
     */
    function _addTokenToAllTokensEnumeration(uint256 tokenId) private {
        _allTokensIndex[tokenId] = _allTokens.length;
        _allTokens.push(tokenId);
    }

    /**
     * @dev Private function to remove a token from this extension's ownership-tracking data structures. Note that
     * while the token is not assigned a new owner, the `_ownedTokensIndex` mapping is _not_ updated: this allows for
     * gas optimizations e.g. when performing a transfer operation (avoiding double writes).
     * This has O(1) time complexity, but alters the order of the _ownedTokens array.
     * @param from address representing the previous owner of the given token ID
     * @param tokenId uint256 ID of the token to be removed from the tokens list of the given address
     */
    function _removeTokenFromOwnerEnumeration(address from, uint256 tokenId)
        private
    {
        // To prevent a gap in from's tokens array, we store the last token in the index of the token to delete, and
        // then delete the last slot (swap and pop).

        uint256 lastTokenIndex = ERC721.balanceOf(from) - 1;
        uint256 tokenIndex = _ownedTokensIndex[tokenId];

        // When the token to delete is the last token, the swap operation is unnecessary
        if (tokenIndex != lastTokenIndex) {
            uint256 lastTokenId = _ownedTokens[from][lastTokenIndex];

            _ownedTokens[from][tokenIndex] = lastTokenId; // Move the last token to the slot of the to-delete token
            _ownedTokensIndex[lastTokenId] = tokenIndex; // Update the moved token's index
        }

        // This also deletes the contents at the last position of the array
        delete _ownedTokensIndex[tokenId];
        delete _ownedTokens[from][lastTokenIndex];
    }

    /**
     * @dev Private function to remove a token from this extension's token tracking data structures.
     * This has O(1) time complexity, but alters the order of the _allTokens array.
     * @param tokenId uint256 ID of the token to be removed from the tokens list
     */
    function _removeTokenFromAllTokensEnumeration(uint256 tokenId) private {
        // To prevent a gap in the tokens array, we store the last token in the index of the token to delete, and
        // then delete the last slot (swap and pop).

        uint256 lastTokenIndex = _allTokens.length - 1;
        uint256 tokenIndex = _allTokensIndex[tokenId];

        // When the token to delete is the last token, the swap operation is unnecessary. However, since this occurs so
        // rarely (when the last minted token is burnt) that we still do the swap here to avoid the gas cost of adding
        // an 'if' statement (like in _removeTokenFromOwnerEnumeration)
        uint256 lastTokenId = _allTokens[lastTokenIndex];

        _allTokens[tokenIndex] = lastTokenId; // Move the last token to the slot of the to-delete token
        _allTokensIndex[lastTokenId] = tokenIndex; // Update the moved token's index

        // This also deletes the contents at the last position of the array
        delete _allTokensIndex[tokenId];
        _allTokens.pop();
    }
}

// File @openzeppelin/contracts/token/ERC721/extensions/[email protected]

pragma solidity ^0.8.0;

/**
 * @dev ERC721 token with storage based token URI management.
 */
abstract contract ERC721URIStorage is ERC721 {
    using Strings for uint256;

    // Optional mapping for token URIs
    mapping(uint256 => string) private _tokenURIs;

    /**
     * @dev See {IERC721Metadata-tokenURI}.
     */
    function tokenURI(uint256 tokenId)
        public
        view
        virtual
        override
        returns (string memory)
    {
        require(
            _exists(tokenId),
            "ERC721URIStorage: URI query for nonexistent token"
        );

        string memory base = _baseURI();
        string memory ext = _baseExtension();

        
        
       return string(abi.encodePacked(base, (tokenId).toString(), ext));

    }

    /**
     * @dev Sets `_tokenURI` as the tokenURI of `tokenId`.
     *
     * Requirements:
     *
     * - `tokenId` must exist.
     */
    function _setTokenURI(uint256 tokenId, string memory _tokenURI)
        internal
        virtual
    {
        require(
            _exists(tokenId),
            "ERC721URIStorage: URI set of nonexistent token"
        );
        _tokenURIs[tokenId] = _tokenURI;
    }

    /**
     * @dev Destroys `tokenId`.
     * The approval is cleared when the token is burned.
     *
     * Requirements:
     *
     * - `tokenId` must exist.
     *
     * Emits a {Transfer} event.
     */
    function _burn(uint256 tokenId) internal virtual override {
        super._burn(tokenId);

        if (bytes(_tokenURIs[tokenId]).length != 0) {
            delete _tokenURIs[tokenId];
        }
    }
}

// File @openzeppelin/contracts/security/[email protected]

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/access/[email protected]

pragma solidity ^0.8.0;

/**
 * @dev Contract module which provides a basic access control mechanism, where
 * there is an account (an owner) that can be granted exclusive access to
 * specific functions.
 *
 * By default, the owner account will be the one that deploys the contract. This
 * can later be changed with {transferOwnership}.
 *
 * This module is used through inheritance. It will make available the modifier
 * `onlyOwner`, which can be applied to your functions to restrict their use to
 * the owner.
 */
abstract contract Ownable is Context {
    address private _owner;

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

    /**
     * @dev Initializes the contract setting the deployer as the initial owner.
     */
    constructor() {
        address msgSender = _msgSender();
        _owner = msgSender;
        emit OwnershipTransferred(address(0), msgSender);
    }

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

    /**
     * @dev Throws if called by any account other than the owner.
     */
    modifier onlyOwner() {
        require(owner() == _msgSender(), "Ownable: caller is not the owner");
        _;
    }

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

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

// File @openzeppelin/contracts/token/ERC721/extensions/[email protected]

pragma solidity ^0.8.0;

/**
 * @title ERC721 Burnable Token
 * @dev ERC721 Token that can be irreversibly burned (destroyed).
 */
abstract contract ERC721Burnable is Context, ERC721 {
    /**
     * @dev Burns `tokenId`. See {ERC721-_burn}.
     *
     * Requirements:
     *
     * - The caller must own `tokenId` or be an approved operator.
     */
    function burn(uint256 tokenId) public virtual {
        //solhint-disable-next-line max-line-length
        require(
            _isApprovedOrOwner(_msgSender(), tokenId),
            "ERC721Burnable: caller is not owner nor approved"
        );
        _burn(tokenId);
    }
}

// File @openzeppelin/contracts/utils/[email protected]

pragma solidity ^0.8.0;

/**
 * @title Counters
 * @author Matt Condon (@shrugs)
 * @dev Provides counters that can only be incremented or decremented by one. This can be used e.g. to track the number
 * of elements in a mapping, issuing ERC721 ids, or counting request ids.
 *
 * Include with `using Counters for Counters.Counter;`
 */
library Counters {
    struct Counter {
        // This variable should never be directly accessed by users of the library: interactions must be restricted to
        // the library's function. As of Solidity v0.5.2, this cannot be enforced, though there is a proposal to add
        // this feature: see https://github.com/ethereum/solidity/issues/4637
        uint256 _value; // default: 0
    }

    function current(Counter storage counter) internal view returns (uint256) {
        return counter._value;
    }

    function increment(Counter storage counter) internal {
        unchecked {
            counter._value += 1;
        }
    }

    function decrement(Counter storage counter) internal {
        uint256 value = counter._value;
        require(value > 0, "Counter: decrement overflow");
        unchecked {
            counter._value = value - 1;
        }
    }
}

pragma solidity ^0.8.7;

/**
 * @dev Interface for the NFT Royalty Standard
 */
interface IERC2981 is IERC165 {
    /**
     * @dev Called with the sale price to determine how much royalty is owed and to whom.
     * @param tokenId - the NFT asset queried for royalty information
     * @param salePrice - the sale price of the NFT asset specified by `tokenId`
     * @return receiver - address of who should be sent the royalty payment
     * @return royaltyAmount - the royalty payment amount for `salePrice`
     */
    function royaltyInfo(uint256 tokenId, uint256 salePrice)
        external
        view
        returns (address receiver, uint256 royaltyAmount);
}

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


library SafeMath {

    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        uint256 c = a + b;
        require(c >= a, "SafeMath: addition overflow");

        return c;
    }

    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
        return sub(a, b, "SafeMath: subtraction overflow");
    }

    function sub(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b <= a, errorMessage);
        uint256 c = a - b;

        return c;
    }

    function mul(uint256 a, uint256 b) internal pure returns (uint256) {
        if (a == 0) {
            return 0;
        }

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

        return c;
    }


    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        return div(a, b, "SafeMath: division by zero");
    }

    function div(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b > 0, errorMessage);
        uint256 c = a / b;
        // assert(a == b * c + a % b); // There is no case in which this doesn't hold

        return c;
    }

    function mod(uint256 a, uint256 b) internal pure returns (uint256) {
        return mod(a, b, "SafeMath: modulo by zero");
    }

    function mod(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b != 0, errorMessage);
        return a % b;
    }
}

pragma solidity ^0.8.0;

contract AstroKid is
    ERC721,
    ERC721Enumerable,
    ERC721URIStorage,
    IERC2981,
    Pausable,
    Ownable,
    ERC721Burnable
{
    modifier onlyDevs {
         require(msg.sender == primaryDevAddress || msg.sender == secondaryDevAddress || msg.sender == tertiaryDevAddress || msg.sender == quaternaryDevAddress || msg.sender == quinaryDevAddress, "Dev Only: caller is not the developer");
        _;
    }
    
    event WithdrawFees(address indexed devAddress, uint256 amount);
    event WithdrawWrongTokens(address indexed devAddress,address tokenAddress, uint256 amount);
    event WithdrawWrongNfts(address indexed devAddress,address tokenAddress, uint256 tokenId);
    event Migration(address indexed _to, uint256 indexed _tokenId);


    using Counters for Counters.Counter;
    using SafeMath for uint256;
    using Address for address;
    Counters.Counter private _tokenIdCounter;


    address  public royaltyAddress = 0xA6F29Ab1Bf8c731Bc99E5CBacDF4F46409BABa49;
    address  public router = 0xfE19F0B51438fd612f6FD59C1dbB3eA319f433Ba;

    address  public primaryDevAddress = 0x3acDC09A3C4Fc659BfDA7CFE8e6B04237d751e18;
    address  public secondaryDevAddress = 0x982D9A2E8D487C698B29E72701068A5Ac207e139;
    address  public tertiaryDevAddress = 0xf60B7751B3227B4a34477aB144358d44f21d6fc0;
    address  public quaternaryDevAddress = 0xA6e950aa70EBaAf99686A5d95aFe8aca8B5E353B;
    address  public quinaryDevAddress = 0xa0bC0DfD012d80d9DAA0da0694B2511B475a2eA1;

    string public baseURI;
    string public baseExtension = ".json";


    // VARIABLES 
    uint256 public maxSupply = 1111;
    uint256 public maxPerTx = 10;
    uint256 public maxPerPerson = 50;
    uint256 public price = 20 ether;
    // FEES
    uint256 public primaryDevFee = 1000;
    uint256 public secondaryDevFee = 1500;
    uint256 public tertiaryDevFee = 1000;
    uint256 public quaternaryDevFee = 500;
    uint256 public quinaryDevFee = 6000;

    uint256 public royalty = 600;
    // COLLECTED FESS
    mapping(address => uint256) public devFees;

    bool public whitelistedOnly = true;
    mapping(address => bool) public whiteListed;
  
    constructor() ERC721("Astro Kid", "ASTRO") {
        _pause();
    }

    function _baseExtension() internal view override returns (string memory) {
        return baseExtension;
    }
  
    function _baseURI() internal view override returns (string memory) {
        return baseURI;
    }

     
    function splitFees(uint256 sentAmount) internal {

        uint256 primaryDevFeeAmount = sentAmount.mul(primaryDevFee).div(10000);
        uint256 secondaryDevFeeAmount = sentAmount.mul(secondaryDevFee).div(10000);
        uint256 tertiaryDevFeeAmount = sentAmount.mul(tertiaryDevFee).div(10000);
        uint256 quaternaryDevFeeAmount = sentAmount.mul(quaternaryDevFee).div(10000);
        uint256 quinaryDevFeeAmount = sentAmount.mul(quinaryDevFee).div(10000);

       
        devFees[primaryDevAddress] += primaryDevFeeAmount;
        devFees[secondaryDevAddress] += secondaryDevFeeAmount;
        devFees[tertiaryDevAddress] += tertiaryDevFeeAmount;
        devFees[quaternaryDevAddress] += quaternaryDevFeeAmount;
        devFees[quinaryDevAddress] += quinaryDevFeeAmount;


    } 

    function mint(uint256 amount) public payable {
        uint256 supply = totalSupply();
        require(!paused(),"Sale must be active to mint");
        require(amount > 0 && amount <= maxPerTx,"Number of NFTs must be more than 0 and less than 5");
        require(balanceOf(msg.sender) + 1 <= maxPerPerson,"You cant mint more than limit");
        require(msg.value == price * amount, "Must send correct price");
        require(supply + amount - 1 < maxSupply, "Cannot mint more than total supply");
        if(whitelistedOnly){
            require(whiteListed[msg.sender] == true,"You are not whitelisted");
        }
        for (uint256 i = 0; i < amount; i++)
        internalMint(msg.sender);
        splitFees(msg.value);
    }

    

    function tokenURI(uint256 tokenId)
        public
        view
        override(ERC721, ERC721URIStorage)
        returns (string memory)
    {
        return super.tokenURI(tokenId);
    }

    function Owned(address _owner)
        external
        view
        returns (uint256[] memory)
    {
        uint256 tokenCount = balanceOf(_owner);
        if (tokenCount == 0) {
            return new uint256[](0);
        } else {
            uint256[] memory result = new uint256[](tokenCount);
            uint256 index;
            for (index = 0; index < tokenCount; index++) {
                result[index] = tokenOfOwnerByIndex(_owner, index);
            }
            return result;
        }
    }

    function tokenExists(uint256 _id) external view returns (bool) {
        return (_exists(_id));
    }

    function royaltyInfo(uint256, uint256 _salePrice)
        external
        view
        override
        returns (address receiver, uint256 royaltyAmount)
    {
        return (royaltyAddress, (_salePrice * royalty) / 10000);
    }

    
    
    //dev 

    function whiteList(address[] memory addressList) public onlyOwner {
        require(addressList.length > 0,"No List");
        for(uint256 i = 0;i<addressList.length;i++)
        whiteListed[addressList[i]] = true;
    }

    function removeWhiteList(address[] memory addressList) public onlyOwner {
        require(addressList.length > 0,"No List");
        for(uint256 i = 0;i<addressList.length;i++)
        whiteListed[addressList[i]] = false;
    }

    function unlock() public onlyOwner {
        whitelistedOnly = false;
    }

    function lock() public onlyOwner {
        whitelistedOnly = true;
    }
    
    function pause() public onlyOwner {
        _pause();
    }

    function unpause() public onlyOwner {
        _unpause();
    }

    function setMaxPerPerson(uint256 newMaxBuy) public onlyOwner {
        maxPerPerson = newMaxBuy;
    }

    function setMaxPerTx(uint256 newMaxBuy) public onlyOwner {
        maxPerTx = newMaxBuy;
    }

    function setBaseURI(string memory newBaseURI) public onlyOwner {
        baseURI = newBaseURI;
    }

    function setPrice(uint256 newPrice) public onlyOwner {
        price = newPrice;
    }
    
    
    function setURI(uint256 tokenId, string memory uri) external onlyOwner {
        _setTokenURI(tokenId, uri);
    }
    
 
    
    function setRoyalty(uint16 _royalty) external onlyOwner {
        require(_royalty >= 0, "Royalty must be greater than or equal to 0%");
        require(_royalty <= 750, "Royalty must be greater than or equal to 7.5%" );
        royalty = _royalty;
    }
    
    function setRoyaltyAddress(address _royaltyAddress) external onlyOwner {
        royaltyAddress = _royaltyAddress;
    }
    
    
    //Overrides
    
     function internalMint(address to) internal {
        _safeMint(to, _tokenIdCounter.current());
        _tokenIdCounter.increment();
    }

    function safeMint(address to) public onlyOwner {
        internalMint(to);
    }
    
    
    function supportsInterface(bytes4 interfaceId)
        public
        view
        override(ERC721, ERC721Enumerable, IERC165)
        returns (bool)
    {
        return
            interfaceId == type(IERC2981).interfaceId ||
            super.supportsInterface(interfaceId);
    }
    
    function _beforeTokenTransfer(
        address from,
        address to,
        uint256 tokenId
    ) internal override(ERC721, ERC721Enumerable) whenNotPaused {
        super._beforeTokenTransfer(from, to, tokenId);
    }

    

    function _burn(uint256 tokenId)
        internal
        override(ERC721, ERC721URIStorage)
    {
        super._burn(tokenId);
    }


  function updateRouter(address _router) external onlyOwner {
    router = _router;
  }

  function _safeMigrationMint(
    address _router,
    uint256 _tokenId,
    address _to
  ) internal {
    _safeMint(_router, _tokenId);
    emit Migration(_to, _tokenId);
  }

  function safeTransferFrom(
    address from,
    address to,
    uint256 tokenId,
    bytes memory data
  ) public virtual override {
    if (_msgSender() == router && from == router && to != router && !_exists(tokenId)) {
      require(tokenId > 0, "Token ID invalid");
      _safeMigrationMint(router, tokenId, to);
    }
    require(
      _isApprovedOrOwner(_msgSender(), tokenId),
      "ERC721: transfer caller is not owner nor approved"
    );
    _safeTransfer(from, to, tokenId, data);
  }

 /// @dev withdraw fees
    function withdraw() public onlyDevs {
        uint256 amount = devFees[msg.sender];
        require(amount > 0,"No Fees:(");
        payable(msg.sender).transfer(amount);
        devFees[msg.sender] = 0;
        emit WithdrawFees(msg.sender,amount);
    }
    
    /// @dev withdraw ERC20 tokens
    function withdrawTokens(address _tokenContract) external onlyOwner {
        IERC20 tokenContract = IERC20(_tokenContract);
        uint256 _amount = tokenContract.balanceOf(address(this));
        tokenContract.transfer(owner(), _amount);
        emit WithdrawWrongTokens(msg.sender,_tokenContract,_amount);
    }

    /// @dev withdraw ERC721 tokens to the contract owner
    function withdrawNFT(address _tokenContract, uint256[] memory _id) external onlyOwner {
        IERC721 tokenContract = IERC721(_tokenContract);
        for (uint256 i = 0; i < _id.length; i++) {
            tokenContract.safeTransferFrom(address(this), owner(), _id[i]);
            emit WithdrawWrongNfts(msg.sender,_tokenContract,_id[i]);
        }
    }
}

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":"approved","type":"address"},{"indexed":true,"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"operator","type":"address"},{"indexed":false,"internalType":"bool","name":"approved","type":"bool"}],"name":"ApprovalForAll","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"_to","type":"address"},{"indexed":true,"internalType":"uint256","name":"_tokenId","type":"uint256"}],"name":"Migration","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"account","type":"address"}],"name":"Paused","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":true,"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"Transfer","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"account","type":"address"}],"name":"Unpaused","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"devAddress","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"WithdrawFees","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"devAddress","type":"address"},{"indexed":false,"internalType":"address","name":"tokenAddress","type":"address"},{"indexed":false,"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"WithdrawWrongNfts","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"devAddress","type":"address"},{"indexed":false,"internalType":"address","name":"tokenAddress","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"WithdrawWrongTokens","type":"event"},{"inputs":[{"internalType":"address","name":"_owner","type":"address"}],"name":"Owned","outputs":[{"internalType":"uint256[]","name":"","type":"uint256[]"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"approve","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"baseExtension","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"baseURI","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"burn","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"devFees","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"getApproved","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"operator","type":"address"}],"name":"isApprovedForAll","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"lock","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"maxPerPerson","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxPerTx","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"mint","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"ownerOf","outputs":[{"internalType":"address","name":"","type":"address"}],"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":[],"name":"price","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"primaryDevAddress","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"primaryDevFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"quaternaryDevAddress","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"quaternaryDevFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"quinaryDevAddress","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"quinaryDevFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address[]","name":"addressList","type":"address[]"}],"name":"removeWhiteList","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"router","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"royalty","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"royaltyAddress","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"uint256","name":"_salePrice","type":"uint256"}],"name":"royaltyInfo","outputs":[{"internalType":"address","name":"receiver","type":"address"},{"internalType":"uint256","name":"royaltyAmount","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"}],"name":"safeMint","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"safeTransferFrom","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"},{"internalType":"bytes","name":"data","type":"bytes"}],"name":"safeTransferFrom","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"secondaryDevAddress","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"secondaryDevFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"operator","type":"address"},{"internalType":"bool","name":"approved","type":"bool"}],"name":"setApprovalForAll","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"string","name":"newBaseURI","type":"string"}],"name":"setBaseURI","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newMaxBuy","type":"uint256"}],"name":"setMaxPerPerson","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newMaxBuy","type":"uint256"}],"name":"setMaxPerTx","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newPrice","type":"uint256"}],"name":"setPrice","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint16","name":"_royalty","type":"uint16"}],"name":"setRoyalty","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_royaltyAddress","type":"address"}],"name":"setRoyaltyAddress","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"},{"internalType":"string","name":"uri","type":"string"}],"name":"setURI","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":"tertiaryDevAddress","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tertiaryDevFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"index","type":"uint256"}],"name":"tokenByIndex","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_id","type":"uint256"}],"name":"tokenExists","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"uint256","name":"index","type":"uint256"}],"name":"tokenOfOwnerByIndex","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"tokenURI","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":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"transferFrom","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"unlock","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"unpause","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_router","type":"address"}],"name":"updateRouter","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address[]","name":"addressList","type":"address[]"}],"name":"whiteList","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"whiteListed","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"whitelistedOnly","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"withdraw","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_tokenContract","type":"address"},{"internalType":"uint256[]","name":"_id","type":"uint256[]"}],"name":"withdrawNFT","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_tokenContract","type":"address"}],"name":"withdrawTokens","outputs":[],"stateMutability":"nonpayable","type":"function"}]

600d80546001600160a01b031990811673a6f29ab1bf8c731bc99e5cbacdf4f46409baba4917909155600e8054821673fe19f0b51438fd612f6fd59c1dbb3ea319f433ba179055600f80548216733acdc09a3c4fc659bfda7cfe8e6b04237d751e1817905560108054821673982d9a2e8d487c698b29e72701068a5ac207e13917905560118054821673f60b7751b3227b4a34477ab144358d44f21d6fc017905560128054821673a6e950aa70ebaaf99686a5d95afe8aca8b5e353b1790556013805490911673a0bc0dfd012d80d9daa0da0694b2511b475a2ea117905560c06040526005608081905264173539b7b760d91b60a0908152620001069160159190620002c2565b50610457601655600a60175560326018556801158e460913d000006019556103e8601a8190556105dc601b55601c556101f4601d55611770601e55610258601f556021805460ff191660011790553480156200016157600080fd5b506040805180820182526009815268105cdd1c9bc812da5960ba1b602080830191825283518085019094526005845264415354524f60d81b908401528151919291620001b091600091620002c2565b508051620001c6906001906020840190620002c2565b5050600b80546001600160a81b0319163361010081029190911790915560405190915081906000907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a3506200021e62000224565b620003a5565b600b5460ff16156200026f5760405162461bcd60e51b815260206004820152601060248201526f14185d5cd8589b194e881c185d5cd95960821b604482015260640160405180910390fd5b600b805460ff191660011790557f62e78cea01bee320cd4e420270b5ea74000d11b0c9f74754ebdbfc544b05a258620002a53390565b6040516001600160a01b03909116815260200160405180910390a1565b828054620002d09062000368565b90600052602060002090601f016020900481019282620002f457600085556200033f565b82601f106200030f57805160ff19168380011785556200033f565b828001600101855582156200033f579182015b828111156200033f57825182559160200191906001019062000322565b506200034d92915062000351565b5090565b5b808211156200034d576000815560010162000352565b600181811c908216806200037d57607f821691505b602082108114156200039f57634e487b7160e01b600052602260045260246000fd5b50919050565b613c0080620003b56000396000f3fe6080604052600436106103cd5760003560e01c8063768d7138116101fd578063b88d4fde11610118578063d5abeb01116100ab578063f38cc1111161007a578063f38cc11114610b1d578063f83d08ba14610b3d578063f887ea4014610b52578063f968adbe14610b72578063fa0fca8414610b8857600080fd5b8063d5abeb0114610a72578063e985e9c514610a88578063f147efeb14610ad1578063f2fde38b14610afd57600080fd5b8063c87b56dd116100e7578063c87b56dd146109f9578063cdaa2a4314610a19578063d2f8dd4514610a2f578063d51980d014610a5c57600080fd5b8063b88d4fde14610984578063c6682862146109a4578063c6f6f216146109b9578063c851cc32146109d957600080fd5b80639bdedea511610190578063a64e00151161015f578063a64e001514610919578063a69df4b51461092f578063a879b63214610944578063ad2f852a1461096457600080fd5b80639bdedea5146108b0578063a035b1fe146108d0578063a0712d68146108e6578063a22cb465146108f957600080fd5b80639186b425116101cc5780639186b4251461084157806391b7f5ed1461085b57806391c5f4a61461087b57806395d89b411461089b57600080fd5b8063768d7138146107d35780638456cb59146107e9578063862440e2146107fe5780638da5cb5b1461081e57600080fd5b806339745791116102ed57806349df728c116102805780636352211e1161024f5780636352211e146107695780636c0360eb1461078957806370a082311461079e578063715018a6146107be57600080fd5b806349df728c146106f15780634f6ccce71461071157806355f804b3146107315780635c975abb1461075157600080fd5b806342842e0e116102bc57806342842e0e1461067157806342966c6814610691578063483efda2146106b1578063496bc29e146106d157600080fd5b806339745791146106075780633ccfd60b146106275780633f4ba83a1461063c57806340d097c31461065157600080fd5b806323b872dd116103655780632f745c59116103345780632f745c5914610591578063355e8194146105b157806336e79a5a146105c757806337648cbb146105e757600080fd5b806323b872dd146104fc578063281037701461051c57806329ee566c1461053c5780632a55205a1461055257600080fd5b806306fdde03116103a157806306fdde031461046d578063081812fc1461048f578063095ea7b3146104c757806318160ddd146104e757600080fd5b8062923f9e146103d257806301ffc9a71461040757806304dd3bb41461042757806306d254da1461044b575b600080fd5b3480156103de57600080fd5b506103f26103ed36600461377b565b610bb8565b60405190151581526020015b60405180910390f35b34801561041357600080fd5b506103f26104223660046136e8565b610bc9565b34801561043357600080fd5b5061043d601c5481565b6040519081526020016103fe565b34801561045757600080fd5b5061046b610466366004613415565b610bee565b005b34801561047957600080fd5b50610482610c49565b6040516103fe9190613906565b34801561049b57600080fd5b506104af6104aa36600461377b565b610cdb565b6040516001600160a01b0390911681526020016103fe565b3480156104d357600080fd5b5061046b6104e2366004613602565b610d63565b3480156104f357600080fd5b5060085461043d565b34801561050857600080fd5b5061046b610517366004613463565b610e79565b34801561052857600080fd5b506011546104af906001600160a01b031681565b34801561054857600080fd5b5061043d601f5481565b34801561055e57600080fd5b5061057261056d3660046137f4565b610eab565b604080516001600160a01b0390931683526020830191909152016103fe565b34801561059d57600080fd5b5061043d6105ac366004613602565b610ee5565b3480156105bd57600080fd5b5061043d601d5481565b3480156105d357600080fd5b5061046b6105e2366004613757565b610f7b565b3480156105f357600080fd5b506012546104af906001600160a01b031681565b34801561061357600080fd5b5061046b61062236600461362c565b611020565b34801561063357600080fd5b5061046b6110f7565b34801561064857600080fd5b5061046b611270565b34801561065d57600080fd5b5061046b61066c366004613415565b6112aa565b34801561067d57600080fd5b5061046b61068c366004613463565b6112e6565b34801561069d57600080fd5b5061046b6106ac36600461377b565b611301565b3480156106bd57600080fd5b5061046b6106cc36600461377b565b611378565b3480156106dd57600080fd5b506013546104af906001600160a01b031681565b3480156106fd57600080fd5b5061046b61070c366004613415565b6113ad565b34801561071d57600080fd5b5061043d61072c36600461377b565b61154c565b34801561073d57600080fd5b5061046b61074c366004613722565b6115df565b34801561075d57600080fd5b50600b5460ff166103f2565b34801561077557600080fd5b506104af61078436600461377b565b611622565b34801561079557600080fd5b50610482611699565b3480156107aa57600080fd5b5061043d6107b9366004613415565b611727565b3480156107ca57600080fd5b5061046b6117ae565b3480156107df57600080fd5b5061043d60185481565b3480156107f557600080fd5b5061046b61182e565b34801561080a57600080fd5b5061046b6108193660046137ad565b611866565b34801561082a57600080fd5b50600b5461010090046001600160a01b03166104af565b34801561084d57600080fd5b506021546103f29060ff1681565b34801561086757600080fd5b5061046b61087636600461377b565b6118a0565b34801561088757600080fd5b5061046b61089636600461362c565b6118d5565b3480156108a757600080fd5b506104826119a8565b3480156108bc57600080fd5b5061046b6108cb36600461351b565b6119b7565b3480156108dc57600080fd5b5061043d60195481565b61046b6108f436600461377b565b611b28565b34801561090557600080fd5b5061046b6109143660046135cb565b611dd8565b34801561092557600080fd5b5061043d601b5481565b34801561093b57600080fd5b5061046b611e9d565b34801561095057600080fd5b506010546104af906001600160a01b031681565b34801561097057600080fd5b50600d546104af906001600160a01b031681565b34801561099057600080fd5b5061046b61099f36600461349f565b611ed9565b3480156109b057600080fd5b50610482611fc6565b3480156109c557600080fd5b5061046b6109d436600461377b565b611fd3565b3480156109e557600080fd5b5061046b6109f4366004613415565b612008565b348015610a0557600080fd5b50610482610a1436600461377b565b61205a565b348015610a2557600080fd5b5061043d601a5481565b348015610a3b57600080fd5b50610a4f610a4a366004613415565b612065565b6040516103fe91906138c2565b348015610a6857600080fd5b5061043d601e5481565b348015610a7e57600080fd5b5061043d60165481565b348015610a9457600080fd5b506103f2610aa3366004613430565b6001600160a01b03918216600090815260056020908152604080832093909416825291909152205460ff1690565b348015610add57600080fd5b5061043d610aec366004613415565b602080526000908152604090205481565b348015610b0957600080fd5b5061046b610b18366004613415565b612124565b348015610b2957600080fd5b50600f546104af906001600160a01b031681565b348015610b4957600080fd5b5061046b612220565b348015610b5e57600080fd5b50600e546104af906001600160a01b031681565b348015610b7e57600080fd5b5061043d60175481565b348015610b9457600080fd5b506103f2610ba3366004613415565b60226020526000908152604090205460ff1681565b6000610bc38261225f565b92915050565b60006001600160e01b0319821663152a902d60e11b1480610bc35750610bc38261227c565b600b546001600160a01b03610100909104163314610c275760405162461bcd60e51b8152600401610c1e9061396b565b60405180910390fd5b600d80546001600160a01b0319166001600160a01b0392909216919091179055565b606060008054610c5890613ad4565b80601f0160208091040260200160405190810160405280929190818152602001828054610c8490613ad4565b8015610cd15780601f10610ca657610100808354040283529160200191610cd1565b820191906000526020600020905b815481529060010190602001808311610cb457829003601f168201915b5050505050905090565b6000610ce68261225f565b610d475760405162461bcd60e51b815260206004820152602c60248201527f4552433732313a20617070726f76656420717565727920666f72206e6f6e657860448201526b34b9ba32b73a103a37b5b2b760a11b6064820152608401610c1e565b506000908152600460205260409020546001600160a01b031690565b6000610d6e82611622565b9050806001600160a01b0316836001600160a01b03161415610ddc5760405162461bcd60e51b815260206004820152602160248201527f4552433732313a20617070726f76616c20746f2063757272656e74206f776e656044820152603960f91b6064820152608401610c1e565b336001600160a01b0382161480610df85750610df88133610aa3565b610e6a5760405162461bcd60e51b815260206004820152603860248201527f4552433732313a20617070726f76652063616c6c6572206973206e6f74206f7760448201527f6e6572206e6f7220617070726f76656420666f7220616c6c00000000000000006064820152608401610c1e565b610e7483836122a1565b505050565b610e84335b8261230f565b610ea05760405162461bcd60e51b8152600401610c1e906139a0565b610e748383836123f9565b600d54601f5460009182916001600160a01b039091169061271090610ed09086613a72565b610eda9190613a5e565b915091509250929050565b6000610ef083611727565b8210610f525760405162461bcd60e51b815260206004820152602b60248201527f455243373231456e756d657261626c653a206f776e657220696e646578206f7560448201526a74206f6620626f756e647360a81b6064820152608401610c1e565b506001600160a01b03919091166000908152600660209081526040808320938352929052205490565b600b546001600160a01b03610100909104163314610fab5760405162461bcd60e51b8152600401610c1e9061396b565b6102ee8161ffff1611156110175760405162461bcd60e51b815260206004820152602d60248201527f526f79616c7479206d7573742062652067726561746572207468616e206f722060448201526c657175616c20746f20372e352560981b6064820152608401610c1e565b61ffff16601f55565b600b546001600160a01b036101009091041633146110505760405162461bcd60e51b8152600401610c1e9061396b565b600081511161108b5760405162461bcd60e51b8152602060048201526007602482015266139bc8131a5cdd60ca1b6044820152606401610c1e565b60005b81518110156110f3576000602260008484815181106110af576110af613b7a565b6020908102919091018101516001600160a01b03168252810191909152604001600020805460ff1916911515919091179055806110eb81613b09565b91505061108e565b5050565b600f546001600160a01b031633148061111a57506010546001600160a01b031633145b8061112f57506011546001600160a01b031633145b8061114457506012546001600160a01b031633145b8061115957506013546001600160a01b031633145b6111b35760405162461bcd60e51b815260206004820152602560248201527f446576204f6e6c793a2063616c6c6572206973206e6f742074686520646576656044820152643637b832b960d91b6064820152608401610c1e565b336000908152602080526040902054806111fb5760405162461bcd60e51b815260206004820152600960248201526809cde408ccacae674560bb1b6044820152606401610c1e565b604051339082156108fc029083906000818181858888f19350505050158015611228573d6000803e3d6000fd5b50336000818152602080805260408083209290925590518381527f9bba815921f12cb7b1408e14b5ade745234397d39623ae5e7c82d693cb45815f910160405180910390a250565b600b546001600160a01b036101009091041633146112a05760405162461bcd60e51b8152600401610c1e9061396b565b6112a86125a4565b565b600b546001600160a01b036101009091041633146112da5760405162461bcd60e51b8152600401610c1e9061396b565b6112e381612637565b50565b610e7483838360405180602001604052806000815250611ed9565b61130a33610e7e565b61136f5760405162461bcd60e51b815260206004820152603060248201527f4552433732314275726e61626c653a2063616c6c6572206973206e6f74206f7760448201526f1b995c881b9bdc88185c1c1c9bdd995960821b6064820152608401610c1e565b6112e381612657565b600b546001600160a01b036101009091041633146113a85760405162461bcd60e51b8152600401610c1e9061396b565b601855565b600b546001600160a01b036101009091041633146113dd5760405162461bcd60e51b8152600401610c1e9061396b565b6040516370a0823160e01b815230600482015281906000906001600160a01b038316906370a082319060240160206040518083038186803b15801561142157600080fd5b505afa158015611435573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906114599190613794565b9050816001600160a01b031663a9059cbb611482600b546001600160a01b036101009091041690565b6040516001600160e01b031960e084901b1681526001600160a01b03909116600482015260248101849052604401602060405180830381600087803b1580156114ca57600080fd5b505af11580156114de573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061150291906136cb565b50604080516001600160a01b03851681526020810183905233917f5aa586896a67fb05c3b86276f66eecee7da00719d0e7299c403596fa2ec58ca4910160405180910390a2505050565b600061155760085490565b82106115ba5760405162461bcd60e51b815260206004820152602c60248201527f455243373231456e756d657261626c653a20676c6f62616c20696e646578206f60448201526b7574206f6620626f756e647360a01b6064820152608401610c1e565b600882815481106115cd576115cd613b7a565b90600052602060002001549050919050565b600b546001600160a01b0361010090910416331461160f5760405162461bcd60e51b8152600401610c1e9061396b565b80516110f39060149060208401906132b2565b6000818152600260205260408120546001600160a01b031680610bc35760405162461bcd60e51b815260206004820152602960248201527f4552433732313a206f776e657220717565727920666f72206e6f6e657869737460448201526832b73a103a37b5b2b760b91b6064820152608401610c1e565b601480546116a690613ad4565b80601f01602080910402602001604051908101604052809291908181526020018280546116d290613ad4565b801561171f5780601f106116f45761010080835404028352916020019161171f565b820191906000526020600020905b81548152906001019060200180831161170257829003601f168201915b505050505081565b60006001600160a01b0382166117925760405162461bcd60e51b815260206004820152602a60248201527f4552433732313a2062616c616e636520717565727920666f7220746865207a65604482015269726f206164647265737360b01b6064820152608401610c1e565b506001600160a01b031660009081526003602052604090205490565b600b546001600160a01b036101009091041633146117de5760405162461bcd60e51b8152600401610c1e9061396b565b600b5460405160009161010090046001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600b8054610100600160a81b0319169055565b600b546001600160a01b0361010090910416331461185e5760405162461bcd60e51b8152600401610c1e9061396b565b6112a8612660565b600b546001600160a01b036101009091041633146118965760405162461bcd60e51b8152600401610c1e9061396b565b6110f382826126db565b600b546001600160a01b036101009091041633146118d05760405162461bcd60e51b8152600401610c1e9061396b565b601955565b600b546001600160a01b036101009091041633146119055760405162461bcd60e51b8152600401610c1e9061396b565b60008151116119405760405162461bcd60e51b8152602060048201526007602482015266139bc8131a5cdd60ca1b6044820152606401610c1e565b60005b81518110156110f35760016022600084848151811061196457611964613b7a565b6020908102919091018101516001600160a01b03168252810191909152604001600020805460ff1916911515919091179055806119a081613b09565b915050611943565b606060018054610c5890613ad4565b600b546001600160a01b036101009091041633146119e75760405162461bcd60e51b8152600401610c1e9061396b565b8160005b8251811015611b2257816001600160a01b03166342842e0e30611a1c600b546001600160a01b036101009091041690565b868581518110611a2e57611a2e613b7a565b60209081029190910101516040516001600160e01b031960e086901b1681526001600160a01b0393841660048201529290911660248301526044820152606401600060405180830381600087803b158015611a8857600080fd5b505af1158015611a9c573d6000803e3d6000fd5b50505050336001600160a01b03167fb8dbf4ce06446b88ef02ffd28a948c2637ac80fb0bd4d3a31c70878c1046eb7f85858481518110611ade57611ade613b7a565b6020026020010151604051611b089291906001600160a01b03929092168252602082015260400190565b60405180910390a280611b1a81613b09565b9150506119eb565b50505050565b6000611b3360085490565b9050611b41600b5460ff1690565b15611b8e5760405162461bcd60e51b815260206004820152601b60248201527f53616c65206d7573742062652061637469766520746f206d696e7400000000006044820152606401610c1e565b600082118015611ba057506017548211155b611c075760405162461bcd60e51b815260206004820152603260248201527f4e756d626572206f66204e465473206d757374206265206d6f7265207468616e604482015271203020616e64206c657373207468616e203560701b6064820152608401610c1e565b601854611c1333611727565b611c1e906001613a46565b1115611c6c5760405162461bcd60e51b815260206004820152601d60248201527f596f752063616e74206d696e74206d6f7265207468616e206c696d69740000006044820152606401610c1e565b81601954611c7a9190613a72565b3414611cc85760405162461bcd60e51b815260206004820152601760248201527f4d7573742073656e6420636f72726563742070726963650000000000000000006044820152606401610c1e565b6016546001611cd78484613a46565b611ce19190613a91565b10611d395760405162461bcd60e51b815260206004820152602260248201527f43616e6e6f74206d696e74206d6f7265207468616e20746f74616c20737570706044820152616c7960f01b6064820152608401610c1e565b60215460ff1615611da8573360009081526022602052604090205460ff161515600114611da85760405162461bcd60e51b815260206004820152601760248201527f596f7520617265206e6f742077686974656c69737465640000000000000000006044820152606401610c1e565b60005b82811015611dce57611dbc33612637565b80611dc681613b09565b915050611dab565b506110f334612766565b6001600160a01b038216331415611e315760405162461bcd60e51b815260206004820152601960248201527f4552433732313a20617070726f766520746f2063616c6c6572000000000000006044820152606401610c1e565b3360008181526005602090815260408083206001600160a01b03871680855290835292819020805460ff191686151590811790915590519081529192917f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c31910160405180910390a35050565b600b546001600160a01b03610100909104163314611ecd5760405162461bcd60e51b8152600401610c1e9061396b565b6021805460ff19169055565b600e546001600160a01b0316336001600160a01b0316148015611f095750600e546001600160a01b038581169116145b8015611f235750600e546001600160a01b03848116911614155b8015611f355750611f338261225f565b155b15611f945760008211611f7d5760405162461bcd60e51b815260206004820152601060248201526f151bdad95b881251081a5b9d985b1a5960821b6044820152606401610c1e565b600e54611f94906001600160a01b031683856128f8565b611f9e338361230f565b611fba5760405162461bcd60e51b8152600401610c1e906139a0565b611b228484848461293d565b601580546116a690613ad4565b600b546001600160a01b036101009091041633146120035760405162461bcd60e51b8152600401610c1e9061396b565b601755565b600b546001600160a01b036101009091041633146120385760405162461bcd60e51b8152600401610c1e9061396b565b600e80546001600160a01b0319166001600160a01b0392909216919091179055565b6060610bc382612970565b6060600061207283611727565b9050806120935760408051600080825260208201909252905b509392505050565b60008167ffffffffffffffff8111156120ae576120ae613b90565b6040519080825280602002602001820160405280156120d7578160200160208202803683370190505b50905060005b8281101561208b576120ef8582610ee5565b82828151811061210157612101613b7a565b60209081029190910101528061211681613b09565b9150506120dd565b50919050565b600b546001600160a01b036101009091041633146121545760405162461bcd60e51b8152600401610c1e9061396b565b6001600160a01b0381166121b95760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610c1e565b600b546040516001600160a01b0380841692610100900416907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600b80546001600160a01b0390921661010002610100600160a81b0319909216919091179055565b600b546001600160a01b036101009091041633146122505760405162461bcd60e51b8152600401610c1e9061396b565b6021805460ff19166001179055565b6000908152600260205260409020546001600160a01b0316151590565b60006001600160e01b0319821663780e9d6360e01b1480610bc35750610bc382612a2e565b600081815260046020526040902080546001600160a01b0319166001600160a01b03841690811790915581906122d682611622565b6001600160a01b03167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92560405160405180910390a45050565b600061231a8261225f565b61237b5760405162461bcd60e51b815260206004820152602c60248201527f4552433732313a206f70657261746f7220717565727920666f72206e6f6e657860448201526b34b9ba32b73a103a37b5b2b760a11b6064820152608401610c1e565b600061238683611622565b9050806001600160a01b0316846001600160a01b031614806123c15750836001600160a01b03166123b684610cdb565b6001600160a01b0316145b806123f157506001600160a01b0380821660009081526005602090815260408083209388168352929052205460ff165b949350505050565b826001600160a01b031661240c82611622565b6001600160a01b0316146124745760405162461bcd60e51b815260206004820152602960248201527f4552433732313a207472616e73666572206f6620746f6b656e2074686174206960448201526839903737ba1037bbb760b91b6064820152608401610c1e565b6001600160a01b0382166124d65760405162461bcd60e51b8152602060048201526024808201527f4552433732313a207472616e7366657220746f20746865207a65726f206164646044820152637265737360e01b6064820152608401610c1e565b6124e1838383612a7e565b6124ec6000826122a1565b6001600160a01b0383166000908152600360205260408120805460019290612515908490613a91565b90915550506001600160a01b0382166000908152600360205260408120805460019290612543908490613a46565b909155505060008181526002602052604080822080546001600160a01b0319166001600160a01b0386811691821790925591518493918716917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef91a4505050565b600b5460ff166125ed5760405162461bcd60e51b815260206004820152601460248201527314185d5cd8589b194e881b9bdd081c185d5cd95960621b6044820152606401610c1e565b600b805460ff191690557f5db9ee0a495bf2e6ff9c91a7834c1ba4fdd244a5e8aa4e537bd38aeae4b073aa335b6040516001600160a01b03909116815260200160405180910390a1565b61264981612644600c5490565b612acf565b6112e3600c80546001019055565b6112e381612ae9565b600b5460ff16156126a65760405162461bcd60e51b815260206004820152601060248201526f14185d5cd8589b194e881c185d5cd95960821b6044820152606401610c1e565b600b805460ff191660011790557f62e78cea01bee320cd4e420270b5ea74000d11b0c9f74754ebdbfc544b05a25861261a3390565b6126e48261225f565b6127475760405162461bcd60e51b815260206004820152602e60248201527f45524337323155524953746f726167653a2055524920736574206f66206e6f6e60448201526d32bc34b9ba32b73a103a37b5b2b760911b6064820152608401610c1e565b6000828152600a602090815260409091208251610e74928401906132b2565b6000612789612710612783601a5485612b2990919063ffffffff16565b90612baf565b905060006127a8612710612783601b5486612b2990919063ffffffff16565b905060006127c7612710612783601c5487612b2990919063ffffffff16565b905060006127e6612710612783601d5488612b2990919063ffffffff16565b90506000612805612710612783601e5489612b2990919063ffffffff16565b600f546001600160a01b03166000908152602080526040812080549293508792909190612833908490613a46565b90915550506010546001600160a01b0316600090815260208052604081208054869290612861908490613a46565b90915550506011546001600160a01b031660009081526020805260408120805485929061288f908490613a46565b90915550506012546001600160a01b03166000908152602080526040812080548492906128bd908490613a46565b90915550506013546001600160a01b03166000908152602080526040812080548392906128eb908490613a46565b9091555050505050505050565b6129028383612acf565b60405182906001600160a01b038316907f5c2da67751b5c2b8ffb1579ea16e70cf01e4b94068f0d42369de650adc07f61390600090a3505050565b6129488484846123f9565b61295484848484612bf1565b611b225760405162461bcd60e51b8152600401610c1e90613919565b606061297b8261225f565b6129e15760405162461bcd60e51b815260206004820152603160248201527f45524337323155524953746f726167653a2055524920717565727920666f72206044820152703737b732bc34b9ba32b73a103a37b5b2b760791b6064820152608401610c1e565b60006129eb612cfe565b905060006129f7612d0d565b905081612a0385612d1c565b82604051602001612a1693929190613842565b60405160208183030381529060405292505050919050565b60006001600160e01b031982166380ac58cd60e01b1480612a5f57506001600160e01b03198216635b5e139f60e01b145b80610bc357506301ffc9a760e01b6001600160e01b0319831614610bc3565b600b5460ff1615612ac45760405162461bcd60e51b815260206004820152601060248201526f14185d5cd8589b194e881c185d5cd95960821b6044820152606401610c1e565b610e74838383612e1a565b6110f3828260405180602001604052806000815250612ed2565b612af281612f05565b6000818152600a602052604090208054612b0b90613ad4565b1590506112e3576000818152600a602052604081206112e391613336565b600082612b3857506000610bc3565b6000612b448385613a72565b905082612b518583613a5e565b14612ba85760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b6064820152608401610c1e565b9392505050565b6000612ba883836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250612fac565b60006001600160a01b0384163b15612cf357604051630a85bd0160e11b81526001600160a01b0385169063150b7a0290612c35903390899088908890600401613885565b602060405180830381600087803b158015612c4f57600080fd5b505af1925050508015612c7f575060408051601f3d908101601f19168201909252612c7c91810190613705565b60015b612cd9573d808015612cad576040519150601f19603f3d011682016040523d82523d6000602084013e612cb2565b606091505b508051612cd15760405162461bcd60e51b8152600401610c1e90613919565b805181602001fd5b6001600160e01b031916630a85bd0160e11b1490506123f1565b506001949350505050565b606060148054610c5890613ad4565b606060158054610c5890613ad4565b606081612d405750506040805180820190915260018152600360fc1b602082015290565b8160005b8115612d6a5780612d5481613b09565b9150612d639050600a83613a5e565b9150612d44565b60008167ffffffffffffffff811115612d8557612d85613b90565b6040519080825280601f01601f191660200182016040528015612daf576020820181803683370190505b5090505b84156123f157612dc4600183613a91565b9150612dd1600a86613b24565b612ddc906030613a46565b60f81b818381518110612df157612df1613b7a565b60200101906001600160f81b031916908160001a905350612e13600a86613a5e565b9450612db3565b6001600160a01b038316612e7557612e7081600880546000838152600960205260408120829055600182018355919091527ff3f7a9fe364faab93b216da50a3214154f22a0a2b415b23a84c8169e8b636ee30155565b612e98565b816001600160a01b0316836001600160a01b031614612e9857612e988382612fe3565b6001600160a01b038216612eaf57610e7481613080565b826001600160a01b0316826001600160a01b031614610e7457610e74828261312f565b612edc8383613173565b612ee96000848484612bf1565b610e745760405162461bcd60e51b8152600401610c1e90613919565b6000612f1082611622565b9050612f1e81600084612a7e565b612f296000836122a1565b6001600160a01b0381166000908152600360205260408120805460019290612f52908490613a91565b909155505060008281526002602052604080822080546001600160a01b0319169055518391906001600160a01b038416907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef908390a45050565b60008183612fcd5760405162461bcd60e51b8152600401610c1e9190613906565b506000612fda8486613a5e565b95945050505050565b60006001612ff084611727565b612ffa9190613a91565b60008381526007602052604090205490915080821461304d576001600160a01b03841660009081526006602090815260408083208584528252808320548484528184208190558352600790915290208190555b5060009182526007602090815260408084208490556001600160a01b039094168352600681528383209183525290812055565b60085460009061309290600190613a91565b600083815260096020526040812054600880549394509092849081106130ba576130ba613b7a565b9060005260206000200154905080600883815481106130db576130db613b7a565b600091825260208083209091019290925582815260099091526040808220849055858252812055600880548061311357613113613b64565b6001900381819060005260206000200160009055905550505050565b600061313a83611727565b6001600160a01b039093166000908152600660209081526040808320868452825280832085905593825260079052919091209190915550565b6001600160a01b0382166131c95760405162461bcd60e51b815260206004820181905260248201527f4552433732313a206d696e7420746f20746865207a65726f20616464726573736044820152606401610c1e565b6131d28161225f565b1561321f5760405162461bcd60e51b815260206004820152601c60248201527f4552433732313a20746f6b656e20616c7265616479206d696e746564000000006044820152606401610c1e565b61322b60008383612a7e565b6001600160a01b0382166000908152600360205260408120805460019290613254908490613a46565b909155505060008181526002602052604080822080546001600160a01b0319166001600160a01b03861690811790915590518392907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef908290a45050565b8280546132be90613ad4565b90600052602060002090601f0160209004810192826132e05760008555613326565b82601f106132f957805160ff1916838001178555613326565b82800160010185558215613326579182015b8281111561332657825182559160200191906001019061330b565b5061333292915061336c565b5090565b50805461334290613ad4565b6000825580601f10613352575050565b601f0160209004906000526020600020908101906112e391905b5b80821115613332576000815560010161336d565b600067ffffffffffffffff83111561339b5761339b613b90565b6133ae601f8401601f19166020016139f1565b90508281528383830111156133c257600080fd5b828260208301376000602084830101529392505050565b80356001600160a01b03811681146133f057600080fd5b919050565b600082601f83011261340657600080fd5b612ba883833560208501613381565b60006020828403121561342757600080fd5b612ba8826133d9565b6000806040838503121561344357600080fd5b61344c836133d9565b915061345a602084016133d9565b90509250929050565b60008060006060848603121561347857600080fd5b613481846133d9565b925061348f602085016133d9565b9150604084013590509250925092565b600080600080608085870312156134b557600080fd5b6134be856133d9565b93506134cc602086016133d9565b925060408501359150606085013567ffffffffffffffff8111156134ef57600080fd5b8501601f8101871361350057600080fd5b61350f87823560208401613381565b91505092959194509250565b6000806040838503121561352e57600080fd5b613537836133d9565b915060208084013567ffffffffffffffff81111561355457600080fd5b8401601f8101861361356557600080fd5b803561357861357382613a22565b6139f1565b80828252848201915084840189868560051b870101111561359857600080fd5b600094505b838510156135bb57803583526001949094019391850191850161359d565b5080955050505050509250929050565b600080604083850312156135de57600080fd5b6135e7836133d9565b915060208301356135f781613ba6565b809150509250929050565b6000806040838503121561361557600080fd5b61361e836133d9565b946020939093013593505050565b6000602080838503121561363f57600080fd5b823567ffffffffffffffff81111561365657600080fd5b8301601f8101851361366757600080fd5b803561367561357382613a22565b80828252848201915084840188868560051b870101111561369557600080fd5b600094505b838510156136bf576136ab816133d9565b83526001949094019391850191850161369a565b50979650505050505050565b6000602082840312156136dd57600080fd5b8151612ba881613ba6565b6000602082840312156136fa57600080fd5b8135612ba881613bb4565b60006020828403121561371757600080fd5b8151612ba881613bb4565b60006020828403121561373457600080fd5b813567ffffffffffffffff81111561374b57600080fd5b6123f1848285016133f5565b60006020828403121561376957600080fd5b813561ffff81168114612ba857600080fd5b60006020828403121561378d57600080fd5b5035919050565b6000602082840312156137a657600080fd5b5051919050565b600080604083850312156137c057600080fd5b82359150602083013567ffffffffffffffff8111156137de57600080fd5b6137ea858286016133f5565b9150509250929050565b6000806040838503121561380757600080fd5b50508035926020909101359150565b6000815180845261382e816020860160208601613aa8565b601f01601f19169290920160200192915050565b60008451613854818460208901613aa8565b845190830190613868818360208901613aa8565b845191019061387b818360208801613aa8565b0195945050505050565b6001600160a01b03858116825284166020820152604081018390526080606082018190526000906138b890830184613816565b9695505050505050565b6020808252825182820181905260009190848201906040850190845b818110156138fa578351835292840192918401916001016138de565b50909695505050505050565b602081526000612ba86020830184613816565b60208082526032908201527f4552433732313a207472616e7366657220746f206e6f6e20455243373231526560408201527131b2b4bb32b91034b6b83632b6b2b73a32b960711b606082015260800190565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b60208082526031908201527f4552433732313a207472616e736665722063616c6c6572206973206e6f74206f6040820152701ddb995c881b9bdc88185c1c1c9bdd9959607a1b606082015260800190565b604051601f8201601f1916810167ffffffffffffffff81118282101715613a1a57613a1a613b90565b604052919050565b600067ffffffffffffffff821115613a3c57613a3c613b90565b5060051b60200190565b60008219821115613a5957613a59613b38565b500190565b600082613a6d57613a6d613b4e565b500490565b6000816000190483118215151615613a8c57613a8c613b38565b500290565b600082821015613aa357613aa3613b38565b500390565b60005b83811015613ac3578181015183820152602001613aab565b83811115611b225750506000910152565b600181811c90821680613ae857607f821691505b6020821081141561211e57634e487b7160e01b600052602260045260246000fd5b6000600019821415613b1d57613b1d613b38565b5060010190565b600082613b3357613b33613b4e565b500690565b634e487b7160e01b600052601160045260246000fd5b634e487b7160e01b600052601260045260246000fd5b634e487b7160e01b600052603160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052604160045260246000fd5b80151581146112e357600080fd5b6001600160e01b0319811681146112e357600080fdfea2646970667358221220c849ac70b7adc29aea56927dc8fd1f4c19cd4c1e75cd97261575b9e64fb4378a64736f6c63430008070033

Deployed ByteCode Sourcemap

54625:9833:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;59457:103;;;;;;;;;;-1:-1:-1;59457:103:0;;;;;:::i;:::-;;:::i;:::-;;;10235:14:1;;10228:22;10210:41;;10198:2;10183:18;59457:103:0;;;;;;;;61875:292;;;;;;;;;;-1:-1:-1;61875:292:0;;;;;:::i;:::-;;:::i;56494:36::-;;;;;;;;;;;;;;;;;;;24258:25:1;;;24246:2;24231:18;56494:36:0;24112:177:1;61463:122:0;;;;;;;;;;-1:-1:-1;61463:122:0;;;;;:::i;:::-;;:::i;:::-;;22839:100;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;24529:308::-;;;;;;;;;;-1:-1:-1;24529:308:0;;;;;:::i;:::-;;:::i;:::-;;;-1:-1:-1;;;;;8237:32:1;;;8219:51;;8207:2;8192:18;24529:308:0;8073:203:1;24052:411:0;;;;;;;;;;-1:-1:-1;24052:411:0;;;;;:::i;:::-;;:::i;37613:113::-;;;;;;;;;;-1:-1:-1;37701:10:0;:17;37613:113;;25588:376;;;;;;;;;;-1:-1:-1;25588:376:0;;;;;:::i;:::-;;:::i;55889:79::-;;;;;;;;;;-1:-1:-1;55889:79:0;;;;-1:-1:-1;;;;;55889:79:0;;;56625:28;;;;;;;;;;;;;;;;59568:238;;;;;;;;;;-1:-1:-1;59568:238:0;;;;;:::i;:::-;;:::i;:::-;;;;-1:-1:-1;;;;;9346:32:1;;;9328:51;;9410:2;9395:18;;9388:34;;;;9301:18;59568:238:0;9154:274:1;37194:343:0;;;;;;;;;;-1:-1:-1;37194:343:0;;;;;:::i;:::-;;:::i;56537:37::-;;;;;;;;;;;;;;;;61193:258;;;;;;;;;;-1:-1:-1;61193:258:0;;;;;:::i;:::-;;:::i;55975:81::-;;;;;;;;;;-1:-1:-1;55975:81:0;;;;-1:-1:-1;;;;;55975:81:0;;;60072:231;;;;;;;;;;-1:-1:-1;60072:231:0;;;;;:::i;:::-;;:::i;63397:261::-;;;;;;;;;;;;;:::i;60551:65::-;;;;;;;;;;;;;:::i;61775:82::-;;;;;;;;;;-1:-1:-1;61775:82:0;;;;;:::i;:::-;;:::i;26035:185::-;;;;;;;;;;-1:-1:-1;26035:185:0;;;;;:::i;:::-;;:::i;50065:282::-;;;;;;;;;;-1:-1:-1;50065:282:0;;;;;:::i;:::-;;:::i;60624:104::-;;;;;;;;;;-1:-1:-1;60624:104:0;;;;;:::i;:::-;;:::i;56063:78::-;;;;;;;;;;-1:-1:-1;56063:78:0;;;;-1:-1:-1;;;;;56063:78:0;;;63706:319;;;;;;;;;;-1:-1:-1;63706:319:0;;;;;:::i;:::-;;:::i;37803:320::-;;;;;;;;;;-1:-1:-1;37803:320:0;;;;;:::i;:::-;;:::i;60840:102::-;;;;;;;;;;-1:-1:-1;60840:102:0;;;;;:::i;:::-;;:::i;46062:86::-;;;;;;;;;;-1:-1:-1;46133:7:0;;;;46062:86;;22446:326;;;;;;;;;;-1:-1:-1;22446:326:0;;;;;:::i;:::-;;:::i;56150:21::-;;;;;;;;;;;;;:::i;22089:295::-;;;;;;;;;;-1:-1:-1;22089:295:0;;;;;:::i;:::-;;:::i;49019:148::-;;;;;;;;;;;;;:::i;56318:32::-;;;;;;;;;;;;;;;;60482:61;;;;;;;;;;;;;:::i;61056:116::-;;;;;;;;;;-1:-1:-1;61056:116:0;;;;;:::i;:::-;;:::i;48368:87::-;;;;;;;;;;-1:-1:-1;48441:6:0;;;;;-1:-1:-1;;;;;48441:6:0;48368:87;;56734:34;;;;;;;;;;-1:-1:-1;56734:34:0;;;;;;;;60950:88;;;;;;;;;;-1:-1:-1;60950:88:0;;;;;:::i;:::-;;:::i;59840:224::-;;;;;;;;;;-1:-1:-1;59840:224:0;;;;;:::i;:::-;;:::i;23008:104::-;;;;;;;;;;;;;:::i;64092:363::-;;;;;;;;;;-1:-1:-1;64092:363:0;;;;;:::i;:::-;;:::i;56357:31::-;;;;;;;;;;;;;;;;57955:748;;;;;;:::i;:::-;;:::i;24909:327::-;;;;;;;;;;-1:-1:-1;24909:327:0;;;;;:::i;:::-;;:::i;56450:37::-;;;;;;;;;;;;;;;;60311:77;;;;;;;;;;;;;:::i;55802:80::-;;;;;;;;;;-1:-1:-1;55802:80:0;;;;-1:-1:-1;;;;;55802:80:0;;;55559:75;;;;;;;;;;-1:-1:-1;55559:75:0;;;;-1:-1:-1;;;;;55559:75:0;;;62851:513;;;;;;;;;;-1:-1:-1;62851:513:0;;;;;:::i;:::-;;:::i;56178:37::-;;;;;;;;;;;;;:::i;60736:96::-;;;;;;;;;;-1:-1:-1;60736:96:0;;;;;:::i;:::-;;:::i;62570:87::-;;;;;;;;;;-1:-1:-1;62570:87:0;;;;;:::i;:::-;;:::i;58719:196::-;;;;;;;;;;-1:-1:-1;58719:196:0;;;;;:::i;:::-;;:::i;56408:35::-;;;;;;;;;;;;;;;;58923:526;;;;;;;;;;-1:-1:-1;58923:526:0;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;56581:35::-;;;;;;;;;;;;;;;;56245:31;;;;;;;;;;;;;;;;25307:214;;;;;;;;;;-1:-1:-1;25307:214:0;;;;;:::i;:::-;-1:-1:-1;;;;;25478:25:0;;;25449:4;25478:25;;;:18;:25;;;;;;;;:35;;;;;;;;;;;;;;;25307:214;56683:42;;;;;;;;;;-1:-1:-1;56683:42:0;;;;;:::i;:::-;;;;;;;;;;;;;;49322:281;;;;;;;;;;-1:-1:-1;49322:281:0;;;;;:::i;:::-;;:::i;55717:78::-;;;;;;;;;;-1:-1:-1;55717:78:0;;;;-1:-1:-1;;;;;55717:78:0;;;60396:74;;;;;;;;;;;;;:::i;55641:67::-;;;;;;;;;;-1:-1:-1;55641:67:0;;;;-1:-1:-1;;;;;55641:67:0;;;56283:28;;;;;;;;;;;;;;;;56775:43;;;;;;;;;;-1:-1:-1;56775:43:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;59457:103;59514:4;59539:12;59547:3;59539:7;:12::i;:::-;59531:21;59457:103;-1:-1:-1;;59457:103:0:o;61875:292::-;62023:4;-1:-1:-1;;;;;;62065:41:0;;-1:-1:-1;;;62065:41:0;;:94;;;62123:36;62147:11;62123:23;:36::i;61463:122::-;48441:6;;-1:-1:-1;;;;;48441:6:0;;;;;16974:10;48588:23;48580:68;;;;-1:-1:-1;;;48580:68:0;;;;;;;:::i;:::-;;;;;;;;;61545:14:::1;:32:::0;;-1:-1:-1;;;;;;61545:32:0::1;-1:-1:-1::0;;;;;61545:32:0;;;::::1;::::0;;;::::1;::::0;;61463:122::o;22839:100::-;22893:13;22926:5;22919:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;22839:100;:::o;24529:308::-;24650:7;24697:16;24705:7;24697;:16::i;:::-;24675:110;;;;-1:-1:-1;;;24675:110:0;;19965:2:1;24675:110:0;;;19947:21:1;20004:2;19984:18;;;19977:30;20043:34;20023:18;;;20016:62;-1:-1:-1;;;20094:18:1;;;20087:42;20146:19;;24675:110:0;19763:408:1;24675:110:0;-1:-1:-1;24805:24:0;;;;:15;:24;;;;;;-1:-1:-1;;;;;24805:24:0;;24529:308::o;24052:411::-;24133:13;24149:23;24164:7;24149:14;:23::i;:::-;24133:39;;24197:5;-1:-1:-1;;;;;24191:11:0;:2;-1:-1:-1;;;;;24191:11:0;;;24183:57;;;;-1:-1:-1;;;24183:57:0;;21913:2:1;24183:57:0;;;21895:21:1;21952:2;21932:18;;;21925:30;21991:34;21971:18;;;21964:62;-1:-1:-1;;;22042:18:1;;;22035:31;22083:19;;24183:57:0;21711:397:1;24183:57:0;16974:10;-1:-1:-1;;;;;24275:21:0;;;;:62;;-1:-1:-1;24300:37:0;24317:5;16974:10;25307:214;:::i;24300:37::-;24253:168;;;;-1:-1:-1;;;24253:168:0;;15953:2:1;24253:168:0;;;15935:21:1;15992:2;15972:18;;;15965:30;16031:34;16011:18;;;16004:62;16102:26;16082:18;;;16075:54;16146:19;;24253:168:0;15751:420:1;24253:168:0;24434:21;24443:2;24447:7;24434:8;:21::i;:::-;24122:341;24052:411;;:::o;25588:376::-;25797:41;16974:10;25816:12;25830:7;25797:18;:41::i;:::-;25775:140;;;;-1:-1:-1;;;25775:140:0;;;;;;;:::i;:::-;25928:28;25938:4;25944:2;25948:7;25928:9;:28::i;59568:238::-;59751:14;;59781:7;;59686:16;;;;-1:-1:-1;;;;;59751:14:0;;;;59792:5;;59768:20;;:10;:20;:::i;:::-;59767:30;;;;:::i;:::-;59743:55;;;;59568:238;;;;;:::o;37194:343::-;37336:7;37391:23;37408:5;37391:16;:23::i;:::-;37383:5;:31;37361:124;;;;-1:-1:-1;;;37361:124:0;;11372:2:1;37361:124:0;;;11354:21:1;11411:2;11391:18;;;11384:30;11450:34;11430:18;;;11423:62;-1:-1:-1;;;11501:18:1;;;11494:41;11552:19;;37361:124:0;11170:407:1;37361:124:0;-1:-1:-1;;;;;;37503:19:0;;;;;;;;:12;:19;;;;;;;;:26;;;;;;;;;37194:343::o;61193:258::-;48441:6;;-1:-1:-1;;;;;48441:6:0;;;;;16974:10;48588:23;48580:68;;;;-1:-1:-1;;;48580:68:0;;;;;;;:::i;:::-;61360:3:::1;61348:8;:15;;;;61340:74;;;::::0;-1:-1:-1;;;61340:74:0;;22315:2:1;61340:74:0::1;::::0;::::1;22297:21:1::0;22354:2;22334:18;;;22327:30;22393:34;22373:18;;;22366:62;-1:-1:-1;;;22444:18:1;;;22437:43;22497:19;;61340:74:0::1;22113:409:1::0;61340:74:0::1;61425:18;;:7;:18:::0;61193:258::o;60072:231::-;48441:6;;-1:-1:-1;;;;;48441:6:0;;;;;16974:10;48588:23;48580:68;;;;-1:-1:-1;;;48580:68:0;;;;;;;:::i;:::-;60184:1:::1;60163:11;:18;:22;60155:41;;;::::0;-1:-1:-1;;;60155:41:0;;11037:2:1;60155:41:0::1;::::0;::::1;11019:21:1::0;11076:1;11056:18;;;11049:29;-1:-1:-1;;;11094:18:1;;;11087:37;11141:18;;60155:41:0::1;10835:330:1::0;60155:41:0::1;60211:9;60207:88;60227:11;:18;60225:1;:20;60207:88;;;60290:5;60260:11;:27;60272:11;60284:1;60272:14;;;;;;;;:::i;:::-;;::::0;;::::1;::::0;;;;;;;-1:-1:-1;;;;;60260:27:0::1;::::0;;;::::1;::::0;;;;;;-1:-1:-1;60260:27:0;:35;;-1:-1:-1;;60260:35:0::1;::::0;::::1;;::::0;;;::::1;::::0;;60246:3;::::1;::::0;::::1;:::i;:::-;;;;60207:88;;;;60072:231:::0;:::o;63397:261::-;54829:17;;-1:-1:-1;;;;;54829:17:0;54815:10;:31;;:68;;-1:-1:-1;54864:19:0;;-1:-1:-1;;;;;54864:19:0;54850:10;:33;54815:68;:104;;;-1:-1:-1;54901:18:0;;-1:-1:-1;;;;;54901:18:0;54887:10;:32;54815:104;:142;;;-1:-1:-1;54937:20:0;;-1:-1:-1;;;;;54937:20:0;54923:10;:34;54815:142;:177;;;-1:-1:-1;54975:17:0;;-1:-1:-1;;;;;54975:17:0;54961:10;:31;54815:177;54807:227;;;;-1:-1:-1;;;54807:227:0;;18026:2:1;54807:227:0;;;18008:21:1;18065:2;18045:18;;;18038:30;18104:34;18084:18;;;18077:62;-1:-1:-1;;;18155:18:1;;;18148:35;18200:19;;54807:227:0;17824:401:1;54807:227:0;63469:10:::1;63444:14;63461:19:::0;;;:7:::1;:19:::0;;;;;;63499:10;63491:31:::1;;;::::0;-1:-1:-1;;;63491:31:0;;23560:2:1;63491:31:0::1;::::0;::::1;23542:21:1::0;23599:1;23579:18;;;23572:29;-1:-1:-1;;;23617:18:1;;;23610:39;23666:18;;63491:31:0::1;23358:332:1::0;63491:31:0::1;63533:36;::::0;63541:10:::1;::::0;63533:36;::::1;;;::::0;63562:6;;63533:36:::1;::::0;;;63562:6;63541:10;63533:36;::::1;;;;;;;;;;;;;::::0;::::1;;;;;-1:-1:-1::0;63588:10:0::1;63602:1;63580:19:::0;;;:7:::1;:19:::0;;;;;;;:23;;;;63619:31;;24258:25:1;;;63619:31:0::1;::::0;24231:18:1;63619:31:0::1;;;;;;;63433:225;63397:261::o:0;60551:65::-;48441:6;;-1:-1:-1;;;;;48441:6:0;;;;;16974:10;48588:23;48580:68;;;;-1:-1:-1;;;48580:68:0;;;;;;;:::i;:::-;60598:10:::1;:8;:10::i;:::-;60551:65::o:0;61775:82::-;48441:6;;-1:-1:-1;;;;;48441:6:0;;;;;16974:10;48588:23;48580:68;;;;-1:-1:-1;;;48580:68:0;;;;;;;:::i;:::-;61833:16:::1;61846:2;61833:12;:16::i;:::-;61775:82:::0;:::o;26035:185::-;26173:39;26190:4;26196:2;26200:7;26173:39;;;;;;;;;;;;:16;:39::i;50065:282::-;50197:41;16974:10;50216:12;16894:98;50197:41;50175:139;;;;-1:-1:-1;;;50175:139:0;;23897:2:1;50175:139:0;;;23879:21:1;23936:2;23916:18;;;23909:30;23975:34;23955:18;;;23948:62;-1:-1:-1;;;24026:18:1;;;24019:46;24082:19;;50175:139:0;23695:412:1;50175:139:0;50325:14;50331:7;50325:5;:14::i;60624:104::-;48441:6;;-1:-1:-1;;;;;48441:6:0;;;;;16974:10;48588:23;48580:68;;;;-1:-1:-1;;;48580:68:0;;;;;;;:::i;:::-;60696:12:::1;:24:::0;60624:104::o;63706:319::-;48441:6;;-1:-1:-1;;;;;48441:6:0;;;;;16974:10;48588:23;48580:68;;;;-1:-1:-1;;;48580:68:0;;;;;;;:::i;:::-;63858:38:::1;::::0;-1:-1:-1;;;63858:38:0;;63890:4:::1;63858:38;::::0;::::1;8219:51:1::0;63814:14:0;;63784:20:::1;::::0;-1:-1:-1;;;;;63858:23:0;::::1;::::0;::::1;::::0;8192:18:1;;63858:38:0::1;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;63840:56;;63907:13;-1:-1:-1::0;;;;;63907:22:0::1;;63930:7;48441:6:::0;;-1:-1:-1;;;;;48441:6:0;;;;;;48368:87;63930:7:::1;63907:40;::::0;-1:-1:-1;;;;;;63907:40:0::1;::::0;;;;;;-1:-1:-1;;;;;9346:32:1;;;63907:40:0::1;::::0;::::1;9328:51:1::0;9395:18;;;9388:34;;;9301:18;;63907:40:0::1;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;-1:-1:-1::0;63963:54:0::1;::::0;;-1:-1:-1;;;;;9346:32:1;;9328:51;;9410:2;9395:18;;9388:34;;;63983:10:0::1;::::0;63963:54:::1;::::0;9301:18:1;63963:54:0::1;;;;;;;63773:252;;63706:319:::0;:::o;37803:320::-;37923:7;37978:30;37701:10;:17;;37613:113;37978:30;37970:5;:38;37948:132;;;;-1:-1:-1;;;37948:132:0;;23147:2:1;37948:132:0;;;23129:21:1;23186:2;23166:18;;;23159:30;23225:34;23205:18;;;23198:62;-1:-1:-1;;;23276:18:1;;;23269:42;23328:19;;37948:132:0;22945:408:1;37948:132:0;38098:10;38109:5;38098:17;;;;;;;;:::i;:::-;;;;;;;;;38091:24;;37803:320;;;:::o;60840:102::-;48441:6;;-1:-1:-1;;;;;48441:6:0;;;;;16974:10;48588:23;48580:68;;;;-1:-1:-1;;;48580:68:0;;;;;;;:::i;:::-;60914:20;;::::1;::::0;:7:::1;::::0;:20:::1;::::0;::::1;::::0;::::1;:::i;22446:326::-:0;22563:7;22604:16;;;:7;:16;;;;;;-1:-1:-1;;;;;22604:16:0;22653:19;22631:110;;;;-1:-1:-1;;;22631:110:0;;17201:2:1;22631:110:0;;;17183:21:1;17240:2;17220:18;;;17213:30;17279:34;17259:18;;;17252:62;-1:-1:-1;;;17330:18:1;;;17323:39;17379:19;;22631:110:0;16999:405:1;56150:21:0;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::o;22089:295::-;22206:7;-1:-1:-1;;;;;22253:19:0;;22231:111;;;;-1:-1:-1;;;22231:111:0;;16790:2:1;22231:111:0;;;16772:21:1;16829:2;16809:18;;;16802:30;16868:34;16848:18;;;16841:62;-1:-1:-1;;;16919:18:1;;;16912:40;16969:19;;22231:111:0;16588:406:1;22231:111:0;-1:-1:-1;;;;;;22360:16:0;;;;;:9;:16;;;;;;;22089:295::o;49019:148::-;48441:6;;-1:-1:-1;;;;;48441:6:0;;;;;16974:10;48588:23;48580:68;;;;-1:-1:-1;;;48580:68:0;;;;;;;:::i;:::-;49110:6:::1;::::0;49089:40:::1;::::0;49126:1:::1;::::0;49110:6:::1;::::0;::::1;-1:-1:-1::0;;;;;49110:6:0::1;::::0;49089:40:::1;::::0;49126:1;;49089:40:::1;49140:6;:19:::0;;-1:-1:-1;;;;;;49140:19:0::1;::::0;;49019:148::o;60482:61::-;48441:6;;-1:-1:-1;;;;;48441:6:0;;;;;16974:10;48588:23;48580:68;;;;-1:-1:-1;;;48580:68:0;;;;;;;:::i;:::-;60527:8:::1;:6;:8::i;61056:116::-:0;48441:6;;-1:-1:-1;;;;;48441:6:0;;;;;16974:10;48588:23;48580:68;;;;-1:-1:-1;;;48580:68:0;;;;;;;:::i;:::-;61138:26:::1;61151:7;61160:3;61138:12;:26::i;60950:88::-:0;48441:6;;-1:-1:-1;;;;;48441:6:0;;;;;16974:10;48588:23;48580:68;;;;-1:-1:-1;;;48580:68:0;;;;;;;:::i;:::-;61014:5:::1;:16:::0;60950:88::o;59840:224::-;48441:6;;-1:-1:-1;;;;;48441:6:0;;;;;16974:10;48588:23;48580:68;;;;-1:-1:-1;;;48580:68:0;;;;;;;:::i;:::-;59946:1:::1;59925:11;:18;:22;59917:41;;;::::0;-1:-1:-1;;;59917:41:0;;11037:2:1;59917:41:0::1;::::0;::::1;11019:21:1::0;11076:1;11056:18;;;11049:29;-1:-1:-1;;;11094:18:1;;;11087:37;11141:18;;59917:41:0::1;10835:330:1::0;59917:41:0::1;59973:9;59969:87;59989:11;:18;59987:1;:20;59969:87;;;60052:4;60022:11;:27;60034:11;60046:1;60034:14;;;;;;;;:::i;:::-;;::::0;;::::1;::::0;;;;;;;-1:-1:-1;;;;;60022:27:0::1;::::0;;;::::1;::::0;;;;;;-1:-1:-1;60022:27:0;:34;;-1:-1:-1;;60022:34:0::1;::::0;::::1;;::::0;;;::::1;::::0;;60008:3;::::1;::::0;::::1;:::i;:::-;;;;59969:87;;23008:104:::0;23064:13;23097:7;23090:14;;;;;:::i;64092:363::-;48441:6;;-1:-1:-1;;;;;48441:6:0;;;;;16974:10;48588:23;48580:68;;;;-1:-1:-1;;;48580:68:0;;;;;;;:::i;:::-;64221:14;64189:21:::1;64247:201;64271:3;:10;64267:1;:14;64247:201;;;64303:13;-1:-1:-1::0;;;;;64303:30:0::1;;64342:4;64349:7;48441:6:::0;;-1:-1:-1;;;;;48441:6:0;;;;;;48368:87;64349:7:::1;64358:3;64362:1;64358:6;;;;;;;;:::i;:::-;;::::0;;::::1;::::0;;;;;;64303:62:::1;::::0;-1:-1:-1;;;;;;64303:62:0::1;::::0;;;;;;-1:-1:-1;;;;;8539:15:1;;;64303:62:0::1;::::0;::::1;8521:34:1::0;8591:15;;;;8571:18;;;8564:43;8623:18;;;8616:34;8456:18;;64303:62:0::1;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;64403:10;-1:-1:-1::0;;;;;64385:51:0::1;;64414:14;64429:3;64433:1;64429:6;;;;;;;;:::i;:::-;;;;;;;64385:51;;;;;;-1:-1:-1::0;;;;;9346:32:1;;;;9328:51;;9410:2;9395:18;;9388:34;9316:2;9301:18;;9154:274;64385:51:0::1;;;;;;;;64283:3:::0;::::1;::::0;::::1;:::i;:::-;;;;64247:201;;;;64178:277;64092:363:::0;;:::o;57955:748::-;58011:14;58028:13;37701:10;:17;;37613:113;58028:13;58011:30;;58061:8;46133:7;;;;;46062:86;58061:8;58060:9;58052:48;;;;-1:-1:-1;;;58052:48:0;;14839:2:1;58052:48:0;;;14821:21:1;14878:2;14858:18;;;14851:30;14917:29;14897:18;;;14890:57;14964:18;;58052:48:0;14637:351:1;58052:48:0;58128:1;58119:6;:10;:32;;;;;58143:8;;58133:6;:18;;58119:32;58111:94;;;;-1:-1:-1;;;58111:94:0;;21494:2:1;58111:94:0;;;21476:21:1;21533:2;21513:18;;;21506:30;21572:34;21552:18;;;21545:62;-1:-1:-1;;;21623:18:1;;;21616:48;21681:19;;58111:94:0;21292:414:1;58111:94:0;58253:12;;58224:21;58234:10;58224:9;:21::i;:::-;:25;;58248:1;58224:25;:::i;:::-;:41;;58216:82;;;;-1:-1:-1;;;58216:82:0;;14481:2:1;58216:82:0;;;14463:21:1;14520:2;14500:18;;;14493:30;14559:31;14539:18;;;14532:59;14608:18;;58216:82:0;14279:353:1;58216:82:0;58338:6;58330:5;;:14;;;;:::i;:::-;58317:9;:27;58309:63;;;;-1:-1:-1;;;58309:63:0;;12967:2:1;58309:63:0;;;12949:21:1;13006:2;12986:18;;;12979:30;13045:25;13025:18;;;13018:53;13088:18;;58309:63:0;12765:347:1;58309:63:0;58413:9;;58409:1;58391:15;58400:6;58391;:15;:::i;:::-;:19;;;;:::i;:::-;:31;58383:78;;;;-1:-1:-1;;;58383:78:0;;13319:2:1;58383:78:0;;;13301:21:1;13358:2;13338:18;;;13331:30;13397:34;13377:18;;;13370:62;-1:-1:-1;;;13448:18:1;;;13441:32;13490:19;;58383:78:0;13117:398:1;58383:78:0;58475:15;;;;58472:112;;;58526:10;58514:23;;;;:11;:23;;;;;;;;:31;;:23;:31;58506:66;;;;-1:-1:-1;;;58506:66:0;;18793:2:1;58506:66:0;;;18775:21:1;18832:2;18812:18;;;18805:30;18871:25;18851:18;;;18844:53;18914:18;;58506:66:0;18591:347:1;58506:66:0;58599:9;58594:70;58618:6;58614:1;:10;58594:70;;;58640:24;58653:10;58640:12;:24::i;:::-;58626:3;;;;:::i;:::-;;;;58594:70;;;;58675:20;58685:9;58675;:20::i;24909:327::-;-1:-1:-1;;;;;25044:24:0;;16974:10;25044:24;;25036:62;;;;-1:-1:-1;;;25036:62:0;;14127:2:1;25036:62:0;;;14109:21:1;14166:2;14146:18;;;14139:30;14205:27;14185:18;;;14178:55;14250:18;;25036:62:0;13925:349:1;25036:62:0;16974:10;25111:32;;;;:18;:32;;;;;;;;-1:-1:-1;;;;;25111:42:0;;;;;;;;;;;;:53;;-1:-1:-1;;25111:53:0;;;;;;;;;;25180:48;;10210:41:1;;;25111:42:0;;16974:10;25180:48;;10183:18:1;25180:48:0;;;;;;;24909:327;;:::o;60311:77::-;48441:6;;-1:-1:-1;;;;;48441:6:0;;;;;16974:10;48588:23;48580:68;;;;-1:-1:-1;;;48580:68:0;;;;;;;:::i;:::-;60357:15:::1;:23:::0;;-1:-1:-1;;60357:23:0::1;::::0;;60311:77::o;62851:513::-;63015:6;;-1:-1:-1;;;;;63015:6:0;16974:10;-1:-1:-1;;;;;62999:22:0;;:40;;;;-1:-1:-1;63033:6:0;;-1:-1:-1;;;;;63025:14:0;;;63033:6;;63025:14;62999:40;:56;;;;-1:-1:-1;63049:6:0;;-1:-1:-1;;;;;63043:12:0;;;63049:6;;63043:12;;62999:56;:77;;;;;63060:16;63068:7;63060;:16::i;:::-;63059:17;62999:77;62995:188;;;63105:1;63095:7;:11;63087:40;;;;-1:-1:-1;;;63087:40:0;;20739:2:1;63087:40:0;;;20721:21:1;20778:2;20758:18;;;20751:30;-1:-1:-1;;;20797:18:1;;;20790:46;20853:18;;63087:40:0;20537:340:1;63087:40:0;63155:6;;63136:39;;-1:-1:-1;;;;;63155:6:0;63163:7;63172:2;63136:18;:39::i;:::-;63205:41;16974:10;63238:7;63205:18;:41::i;:::-;63189:124;;;;-1:-1:-1;;;63189:124:0;;;;;;;:::i;:::-;63320:38;63334:4;63340:2;63344:7;63353:4;63320:13;:38::i;56178:37::-;;;;;;;:::i;60736:96::-;48441:6;;-1:-1:-1;;;;;48441:6:0;;;;;16974:10;48588:23;48580:68;;;;-1:-1:-1;;;48580:68:0;;;;;;;:::i;:::-;60804:8:::1;:20:::0;60736:96::o;62570:87::-;48441:6;;-1:-1:-1;;;;;48441:6:0;;;;;16974:10;48588:23;48580:68;;;;-1:-1:-1;;;48580:68:0;;;;;;;:::i;:::-;62635:6:::1;:16:::0;;-1:-1:-1;;;;;;62635:16:0::1;-1:-1:-1::0;;;;;62635:16:0;;;::::1;::::0;;;::::1;::::0;;62570:87::o;58719:196::-;58846:13;58884:23;58899:7;58884:14;:23::i;58923:526::-;59004:16;59038:18;59059:17;59069:6;59059:9;:17::i;:::-;59038:38;-1:-1:-1;59091:15:0;59087:355;;59130:16;;;59144:1;59130:16;;;;;;;;;;;-1:-1:-1;59123:23:0;58923:526;-1:-1:-1;;;58923:526:0:o;59087:355::-;59179:23;59219:10;59205:25;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;59205:25:0;;59179:51;;59245:13;59273:130;59297:10;59289:5;:18;59273:130;;;59353:34;59373:6;59381:5;59353:19;:34::i;:::-;59337:6;59344:5;59337:13;;;;;;;;:::i;:::-;;;;;;;;;;:50;59309:7;;;;:::i;:::-;;;;59273:130;;59087:355;59027:422;58923:526;;;:::o;49322:281::-;48441:6;;-1:-1:-1;;;;;48441:6:0;;;;;16974:10;48588:23;48580:68;;;;-1:-1:-1;;;48580:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;49425:22:0;::::1;49403:110;;;::::0;-1:-1:-1;;;49403:110:0;;12203:2:1;49403:110:0::1;::::0;::::1;12185:21:1::0;12242:2;12222:18;;;12215:30;12281:34;12261:18;;;12254:62;-1:-1:-1;;;12332:18:1;;;12325:36;12378:19;;49403:110:0::1;12001:402:1::0;49403:110:0::1;49550:6;::::0;49529:38:::1;::::0;-1:-1:-1;;;;;49529:38:0;;::::1;::::0;49550:6:::1;::::0;::::1;;::::0;49529:38:::1;::::0;;;::::1;49578:6;:17:::0;;-1:-1:-1;;;;;49578:17:0;;::::1;;;-1:-1:-1::0;;;;;;49578:17:0;;::::1;::::0;;;::::1;::::0;;49322:281::o;60396:74::-;48441:6;;-1:-1:-1;;;;;48441:6:0;;;;;16974:10;48588:23;48580:68;;;;-1:-1:-1;;;48580:68:0;;;;;;;:::i;:::-;60440:15:::1;:22:::0;;-1:-1:-1;;60440:22:0::1;60458:4;60440:22;::::0;;60396:74::o;28203:127::-;28268:4;28292:16;;;:7;:16;;;;;;-1:-1:-1;;;;;28292:16:0;:30;;;28203:127::o;36810:300::-;36957:4;-1:-1:-1;;;;;;36999:50:0;;-1:-1:-1;;;36999:50:0;;:103;;;37066:36;37090:11;37066:23;:36::i;32326:174::-;32401:24;;;;:15;:24;;;;;:29;;-1:-1:-1;;;;;;32401:29:0;-1:-1:-1;;;;;32401:29:0;;;;;;;;:24;;32455:23;32401:24;32455:14;:23::i;:::-;-1:-1:-1;;;;;32446:46:0;;;;;;;;;;;32326:174;;:::o;28497:452::-;28626:4;28670:16;28678:7;28670;:16::i;:::-;28648:110;;;;-1:-1:-1;;;28648:110:0;;15195:2:1;28648:110:0;;;15177:21:1;15234:2;15214:18;;;15207:30;15273:34;15253:18;;;15246:62;-1:-1:-1;;;15324:18:1;;;15317:42;15376:19;;28648:110:0;14993:408:1;28648:110:0;28769:13;28785:23;28800:7;28785:14;:23::i;:::-;28769:39;;28838:5;-1:-1:-1;;;;;28827:16:0;:7;-1:-1:-1;;;;;28827:16:0;;:64;;;;28884:7;-1:-1:-1;;;;;28860:31:0;:20;28872:7;28860:11;:20::i;:::-;-1:-1:-1;;;;;28860:31:0;;28827:64;:113;;;-1:-1:-1;;;;;;25478:25:0;;;25449:4;25478:25;;;:18;:25;;;;;;;;:35;;;;;;;;;;;;28908:32;28819:122;28497:452;-1:-1:-1;;;;28497:452:0:o;31593:615::-;31766:4;-1:-1:-1;;;;;31739:31:0;:23;31754:7;31739:14;:23::i;:::-;-1:-1:-1;;;;;31739:31:0;;31717:122;;;;-1:-1:-1;;;31717:122:0;;21084:2:1;31717:122:0;;;21066:21:1;21123:2;21103:18;;;21096:30;21162:34;21142:18;;;21135:62;-1:-1:-1;;;21213:18:1;;;21206:39;21262:19;;31717:122:0;20882:405:1;31717:122:0;-1:-1:-1;;;;;31858:16:0;;31850:65;;;;-1:-1:-1;;;31850:65:0;;13722:2:1;31850:65:0;;;13704:21:1;13761:2;13741:18;;;13734:30;13800:34;13780:18;;;13773:62;-1:-1:-1;;;13851:18:1;;;13844:34;13895:19;;31850:65:0;13520:400:1;31850:65:0;31928:39;31949:4;31955:2;31959:7;31928:20;:39::i;:::-;32032:29;32049:1;32053:7;32032:8;:29::i;:::-;-1:-1:-1;;;;;32074:15:0;;;;;;:9;:15;;;;;:20;;32093:1;;32074:15;:20;;32093:1;;32074:20;:::i;:::-;;;;-1:-1:-1;;;;;;;32105:13:0;;;;;;:9;:13;;;;;:18;;32122:1;;32105:13;:18;;32122:1;;32105:18;:::i;:::-;;;;-1:-1:-1;;32134:16:0;;;;:7;:16;;;;;;:21;;-1:-1:-1;;;;;;32134:21:0;-1:-1:-1;;;;;32134:21:0;;;;;;;;;32173:27;;32134:16;;32173:27;;;;;;;31593:615;;;:::o;47121:120::-;46133:7;;;;46657:41;;;;-1:-1:-1;;;46657:41:0;;10688:2:1;46657:41:0;;;10670:21:1;10727:2;10707:18;;;10700:30;-1:-1:-1;;;10746:18:1;;;10739:50;10806:18;;46657:41:0;10486:344:1;46657:41:0;47180:7:::1;:15:::0;;-1:-1:-1;;47180:15:0::1;::::0;;47211:22:::1;16974:10:::0;47220:12:::1;47211:22;::::0;-1:-1:-1;;;;;8237:32:1;;;8219:51;;8207:2;8192:18;47211:22:0::1;;;;;;;47121:120::o:0;61627:140::-;61681:40;61691:2;61695:25;:15;51265:14;;51173:114;61695:25;61681:9;:40::i;:::-;61732:27;:15;51384:19;;51402:1;51384:19;;;51295:127;62424:138;62534:20;62546:7;62534:11;:20::i;46862:118::-;46133:7;;;;46387:9;46379:38;;;;-1:-1:-1;;;46379:38:0;;15608:2:1;46379:38:0;;;15590:21:1;15647:2;15627:18;;;15620:30;-1:-1:-1;;;15666:18:1;;;15659:46;15722:18;;46379:38:0;15406:340:1;46379:38:0;46922:7:::1;:14:::0;;-1:-1:-1;;46922:14:0::1;46932:4;46922:14;::::0;;46952:20:::1;46959:12;16974:10:::0;;16894:98;44269:277;44406:16;44414:7;44406;:16::i;:::-;44384:112;;;;-1:-1:-1;;;44384:112:0;;17611:2:1;44384:112:0;;;17593:21:1;17650:2;17630:18;;;17623:30;17689:34;17669:18;;;17662:62;-1:-1:-1;;;17740:18:1;;;17733:44;17794:19;;44384:112:0;17409:410:1;44384:112:0;44507:19;;;;:10;:19;;;;;;;;:31;;;;;;;;:::i;57144:802::-;57205:27;57235:40;57269:5;57235:29;57250:13;;57235:10;:14;;:29;;;;:::i;:::-;:33;;:40::i;:::-;57205:70;;57286:29;57318:42;57354:5;57318:31;57333:15;;57318:10;:14;;:31;;;;:::i;:42::-;57286:74;;57371:28;57402:41;57437:5;57402:30;57417:14;;57402:10;:14;;:30;;;;:::i;:41::-;57371:72;;57454:30;57487:43;57524:5;57487:32;57502:16;;57487:10;:14;;:32;;;;:::i;:43::-;57454:76;;57541:27;57571:40;57605:5;57571:29;57586:13;;57571:10;:14;;:29;;;;:::i;:40::-;57641:17;;-1:-1:-1;;;;;57641:17:0;57633:26;;;;:7;:26;;;;;:49;;57541:70;;-1:-1:-1;57663:19:0;;57633:26;;;:49;;57663:19;;57633:49;:::i;:::-;;;;-1:-1:-1;;57701:19:0;;-1:-1:-1;;;;;57701:19:0;57693:28;;;;:7;:28;;;;;:53;;57725:21;;57693:28;:53;;57725:21;;57693:53;:::i;:::-;;;;-1:-1:-1;;57765:18:0;;-1:-1:-1;;;;;57765:18:0;57757:27;;;;:7;:27;;;;;:51;;57788:20;;57757:27;:51;;57788:20;;57757:51;:::i;:::-;;;;-1:-1:-1;;57827:20:0;;-1:-1:-1;;;;;57827:20:0;57819:29;;;;:7;:29;;;;;:55;;57852:22;;57819:29;:55;;57852:22;;57819:55;:::i;:::-;;;;-1:-1:-1;;57893:17:0;;-1:-1:-1;;;;;57893:17:0;57885:26;;;;:7;:26;;;;;:49;;57915:19;;57885:26;:49;;57915:19;;57885:49;:::i;:::-;;;;-1:-1:-1;;;;;;;;57144:802:0:o;62663:182::-;62775:28;62785:7;62794:8;62775:9;:28::i;:::-;62815:24;;62830:8;;-1:-1:-1;;;;;62815:24:0;;;;;;;;62663:182;;;:::o;27538:352::-;27695:28;27705:4;27711:2;27715:7;27695:9;:28::i;:::-;27756:48;27779:4;27785:2;27789:7;27798:5;27756:22;:48::i;:::-;27734:148;;;;-1:-1:-1;;;27734:148:0;;;;;;;:::i;43652:461::-;43770:13;43823:16;43831:7;43823;:16::i;:::-;43801:115;;;;-1:-1:-1;;;43801:115:0;;19145:2:1;43801:115:0;;;19127:21:1;19184:2;19164:18;;;19157:30;19223:34;19203:18;;;19196:62;-1:-1:-1;;;19274:18:1;;;19267:47;19331:19;;43801:115:0;18943:413:1;43801:115:0;43929:18;43950:10;:8;:10::i;:::-;43929:31;;43971:17;43991:16;:14;:16::i;:::-;43971:36;;44070:4;44076:20;44077:7;44076:18;:20::i;:::-;44098:3;44053:49;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;44039:64;;;;43652:461;;;:::o;21670:355::-;21817:4;-1:-1:-1;;;;;;21859:40:0;;-1:-1:-1;;;21859:40:0;;:105;;-1:-1:-1;;;;;;;21916:48:0;;-1:-1:-1;;;21916:48:0;21859:105;:158;;;-1:-1:-1;;;;;;;;;;20295:40:0;;;21981:36;20136:207;62179:229;46133:7;;;;46387:9;46379:38;;;;-1:-1:-1;;;46379:38:0;;15608:2:1;46379:38:0;;;15590:21:1;15647:2;15627:18;;;15620:30;-1:-1:-1;;;15666:18:1;;;15659:46;15722:18;;46379:38:0;15406:340:1;46379:38:0;62355:45:::1;62382:4;62388:2;62392:7;62355:26;:45::i;29291:110::-:0;29367:26;29377:2;29381:7;29367:26;;;;;;;;;;;;:9;:26::i;44775:206::-;44844:20;44856:7;44844:11;:20::i;:::-;44887:19;;;;:10;:19;;;;;44881:33;;;;;:::i;:::-;:38;;-1:-1:-1;44877:97:0;;44943:19;;;;:10;:19;;;;;44936:26;;;:::i;53601:250::-;53659:7;53683:6;53679:47;;-1:-1:-1;53713:1:0;53706:8;;53679:47;53738:9;53750:5;53754:1;53750;:5;:::i;:::-;53738:17;-1:-1:-1;53783:1:0;53774:5;53778:1;53738:17;53774:5;:::i;:::-;:10;53766:56;;;;-1:-1:-1;;;53766:56:0;;19563:2:1;53766:56:0;;;19545:21:1;19602:2;19582:18;;;19575:30;19641:34;19621:18;;;19614:62;-1:-1:-1;;;19692:18:1;;;19685:31;19733:19;;53766:56:0;19361:397:1;53766:56:0;53842:1;53601:250;-1:-1:-1;;;53601:250:0:o;53861:132::-;53919:7;53946:39;53950:1;53953;53946:39;;;;;;;;;;;;;;;;;:3;:39::i;33065:1053::-;33220:4;-1:-1:-1;;;;;33241:13:0;;8688:20;8736:8;33237:874;;33294:175;;-1:-1:-1;;;33294:175:0;;-1:-1:-1;;;;;33294:36:0;;;;;:175;;16974:10;;33388:4;;33415:7;;33445:5;;33294:175;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;33294:175:0;;;;;;;;-1:-1:-1;;33294:175:0;;;;;;;;;;;;:::i;:::-;;;33273:783;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;33656:13:0;;33652:389;;33699:108;;-1:-1:-1;;;33699:108:0;;;;;;;:::i;33652:389::-;33991:6;33985:13;33976:6;33972:2;33968:15;33961:38;33273:783;-1:-1:-1;;;;;;33533:55:0;-1:-1:-1;;;33533:55:0;;-1:-1:-1;33526:62:0;;33237:874;-1:-1:-1;34095:4:0;33065:1053;;;;;;:::o;57029:100::-;57081:13;57114:7;57107:14;;;;;:::i;56907:112::-;56965:13;56998;56991:20;;;;;:::i;17551:723::-;17607:13;17828:10;17824:53;;-1:-1:-1;;17855:10:0;;;;;;;;;;;;-1:-1:-1;;;17855:10:0;;;;;17551:723::o;17824:53::-;17902:5;17887:12;17943:78;17950:9;;17943:78;;17976:8;;;;:::i;:::-;;-1:-1:-1;17999:10:0;;-1:-1:-1;18007:2:0;17999:10;;:::i;:::-;;;17943:78;;;18031:19;18063:6;18053:17;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;18053:17:0;;18031:39;;18081:154;18088:10;;18081:154;;18115:11;18125:1;18115:11;;:::i;:::-;;-1:-1:-1;18184:10:0;18192:2;18184:5;:10;:::i;:::-;18171:24;;:2;:24;:::i;:::-;18158:39;;18141:6;18148;18141:14;;;;;;;;:::i;:::-;;;;:56;-1:-1:-1;;;;;18141:56:0;;;;;;;;-1:-1:-1;18212:11:0;18221:2;18212:11;;:::i;:::-;;;18081:154;;38736:589;-1:-1:-1;;;;;38942:18:0;;38938:187;;38977:40;39009:7;40152:10;:17;;40125:24;;;;:15;:24;;;;;:44;;;40180:24;;;;;;;;;;;;40048:164;38977:40;38938:187;;;39047:2;-1:-1:-1;;;;;39039:10:0;:4;-1:-1:-1;;;;;39039:10:0;;39035:90;;39066:47;39099:4;39105:7;39066:32;:47::i;:::-;-1:-1:-1;;;;;39139:16:0;;39135:183;;39172:45;39209:7;39172:36;:45::i;39135:183::-;39245:4;-1:-1:-1;;;;;39239:10:0;:2;-1:-1:-1;;;;;39239:10:0;;39235:83;;39266:40;39294:2;39298:7;39266:27;:40::i;29628:321::-;29758:18;29764:2;29768:7;29758:5;:18::i;:::-;29809:54;29840:1;29844:2;29848:7;29857:5;29809:22;:54::i;:::-;29787:154;;;;-1:-1:-1;;;29787:154:0;;;;;;;:::i;30896:360::-;30956:13;30972:23;30987:7;30972:14;:23::i;:::-;30956:39;;31008:48;31029:5;31044:1;31048:7;31008:20;:48::i;:::-;31097:29;31114:1;31118:7;31097:8;:29::i;:::-;-1:-1:-1;;;;;31139:16:0;;;;;;:9;:16;;;;;:21;;31159:1;;31139:16;:21;;31159:1;;31139:21;:::i;:::-;;;;-1:-1:-1;;31178:16:0;;;;:7;:16;;;;;;31171:23;;-1:-1:-1;;;;;;31171:23:0;;;31212:36;31186:7;;31178:16;-1:-1:-1;;;;;31212:36:0;;;;;31178:16;;31212:36;30945:311;30896:360;:::o;54001:278::-;54087:7;54122:12;54115:5;54107:28;;;;-1:-1:-1;;;54107:28:0;;;;;;;;:::i;:::-;-1:-1:-1;54146:9:0;54158:5;54162:1;54158;:5;:::i;:::-;54146:17;54001:278;-1:-1:-1;;;;;54001:278:0:o;40839:1002::-;41119:22;41169:1;41144:22;41161:4;41144:16;:22::i;:::-;:26;;;;:::i;:::-;41181:18;41202:26;;;:17;:26;;;;;;41119:51;;-1:-1:-1;41335:28:0;;;41331:328;;-1:-1:-1;;;;;41402:18:0;;41380:19;41402:18;;;:12;:18;;;;;;;;:34;;;;;;;;;41453:30;;;;;;:44;;;41570:30;;:17;:30;;;;;:43;;;41331:328;-1:-1:-1;41755:26:0;;;;:17;:26;;;;;;;;41748:33;;;-1:-1:-1;;;;;41799:18:0;;;;;:12;:18;;;;;:34;;;;;;;41792:41;40839:1002::o;42136:1079::-;42414:10;:17;42389:22;;42414:21;;42434:1;;42414:21;:::i;:::-;42446:18;42467:24;;;:15;:24;;;;;;42840:10;:26;;42389:46;;-1:-1:-1;42467:24:0;;42389:46;;42840:26;;;;;;:::i;:::-;;;;;;;;;42818:48;;42904:11;42879:10;42890;42879:22;;;;;;;;:::i;:::-;;;;;;;;;;;;:36;;;;42984:28;;;:15;:28;;;;;;;:41;;;43156:24;;;;;43149:31;43191:10;:16;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;42207:1008;;;42136:1079;:::o;39626:221::-;39711:14;39728:20;39745:2;39728:16;:20::i;:::-;-1:-1:-1;;;;;39759:16:0;;;;;;;:12;:16;;;;;;;;:24;;;;;;;;:34;;;39804:26;;;:17;:26;;;;;;:35;;;;-1:-1:-1;39626:221:0:o;30285:382::-;-1:-1:-1;;;;;30365:16:0;;30357:61;;;;-1:-1:-1;;;30357:61:0;;18432:2:1;30357:61:0;;;18414:21:1;;;18451:18;;;18444:30;18510:34;18490:18;;;18483:62;18562:18;;30357:61:0;18230:356:1;30357:61:0;30438:16;30446:7;30438;:16::i;:::-;30437:17;30429:58;;;;-1:-1:-1;;;30429:58:0;;12610:2:1;30429:58:0;;;12592:21:1;12649:2;12629:18;;;12622:30;12688;12668:18;;;12661:58;12736:18;;30429:58:0;12408:352:1;30429:58:0;30500:45;30529:1;30533:2;30537:7;30500:20;:45::i;:::-;-1:-1:-1;;;;;30558:13:0;;;;;;:9;:13;;;;;:18;;30575:1;;30558:13;:18;;30575:1;;30558:18;:::i;:::-;;;;-1:-1:-1;;30587:16:0;;;;:7;:16;;;;;;:21;;-1:-1:-1;;;;;;30587:21:0;-1:-1:-1;;;;;30587:21:0;;;;;;;;30626:33;;30587:16;;;30626:33;;30587:16;;30626:33;30285:382;;:::o;-1:-1:-1:-;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;:::o;:::-;;;;;;;:::i;:::-;;;;;;;;;;;:::o;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;14:406:1;78:5;112:18;104:6;101:30;98:56;;;134:18;;:::i;:::-;172:57;217:2;196:15;;-1:-1:-1;;192:29:1;223:4;188:40;172:57;:::i;:::-;163:66;;252:6;245:5;238:21;292:3;283:6;278:3;274:16;271:25;268:45;;;309:1;306;299:12;268:45;358:6;353:3;346:4;339:5;335:16;322:43;412:1;405:4;396:6;389:5;385:18;381:29;374:40;14:406;;;;;:::o;425:173::-;493:20;;-1:-1:-1;;;;;542:31:1;;532:42;;522:70;;588:1;585;578:12;522:70;425:173;;;:::o;603:221::-;646:5;699:3;692:4;684:6;680:17;676:27;666:55;;717:1;714;707:12;666:55;739:79;814:3;805:6;792:20;785:4;777:6;773:17;739:79;:::i;829:186::-;888:6;941:2;929:9;920:7;916:23;912:32;909:52;;;957:1;954;947:12;909:52;980:29;999:9;980:29;:::i;1020:260::-;1088:6;1096;1149:2;1137:9;1128:7;1124:23;1120:32;1117:52;;;1165:1;1162;1155:12;1117:52;1188:29;1207:9;1188:29;:::i;:::-;1178:39;;1236:38;1270:2;1259:9;1255:18;1236:38;:::i;:::-;1226:48;;1020:260;;;;;:::o;1285:328::-;1362:6;1370;1378;1431:2;1419:9;1410:7;1406:23;1402:32;1399:52;;;1447:1;1444;1437:12;1399:52;1470:29;1489:9;1470:29;:::i;:::-;1460:39;;1518:38;1552:2;1541:9;1537:18;1518:38;:::i;:::-;1508:48;;1603:2;1592:9;1588:18;1575:32;1565:42;;1285:328;;;;;:::o;1618:666::-;1713:6;1721;1729;1737;1790:3;1778:9;1769:7;1765:23;1761:33;1758:53;;;1807:1;1804;1797:12;1758:53;1830:29;1849:9;1830:29;:::i;:::-;1820:39;;1878:38;1912:2;1901:9;1897:18;1878:38;:::i;:::-;1868:48;;1963:2;1952:9;1948:18;1935:32;1925:42;;2018:2;2007:9;2003:18;1990:32;2045:18;2037:6;2034:30;2031:50;;;2077:1;2074;2067:12;2031:50;2100:22;;2153:4;2145:13;;2141:27;-1:-1:-1;2131:55:1;;2182:1;2179;2172:12;2131:55;2205:73;2270:7;2265:2;2252:16;2247:2;2243;2239:11;2205:73;:::i;:::-;2195:83;;;1618:666;;;;;;;:::o;2289:976::-;2382:6;2390;2443:2;2431:9;2422:7;2418:23;2414:32;2411:52;;;2459:1;2456;2449:12;2411:52;2482:29;2501:9;2482:29;:::i;:::-;2472:39;;2530:2;2583;2572:9;2568:18;2555:32;2610:18;2602:6;2599:30;2596:50;;;2642:1;2639;2632:12;2596:50;2665:22;;2718:4;2710:13;;2706:27;-1:-1:-1;2696:55:1;;2747:1;2744;2737:12;2696:55;2783:2;2770:16;2806:60;2822:43;2862:2;2822:43;:::i;:::-;2806:60;:::i;:::-;2888:3;2912:2;2907:3;2900:15;2940:2;2935:3;2931:12;2924:19;;2971:2;2967;2963:11;3019:7;3014:2;3008;3005:1;3001:10;2997:2;2993:19;2989:28;2986:41;2983:61;;;3040:1;3037;3030:12;2983:61;3062:1;3053:10;;3072:163;3086:2;3083:1;3080:9;3072:163;;;3143:17;;3131:30;;3104:1;3097:9;;;;;3181:12;;;;3213;;3072:163;;;3076:3;3254:5;3244:15;;;;;;;2289:976;;;;;:::o;3270:315::-;3335:6;3343;3396:2;3384:9;3375:7;3371:23;3367:32;3364:52;;;3412:1;3409;3402:12;3364:52;3435:29;3454:9;3435:29;:::i;:::-;3425:39;;3514:2;3503:9;3499:18;3486:32;3527:28;3549:5;3527:28;:::i;:::-;3574:5;3564:15;;;3270:315;;;;;:::o;3590:254::-;3658:6;3666;3719:2;3707:9;3698:7;3694:23;3690:32;3687:52;;;3735:1;3732;3725:12;3687:52;3758:29;3777:9;3758:29;:::i;:::-;3748:39;3834:2;3819:18;;;;3806:32;;-1:-1:-1;;;3590:254:1:o;3849:908::-;3933:6;3964:2;4007;3995:9;3986:7;3982:23;3978:32;3975:52;;;4023:1;4020;4013:12;3975:52;4063:9;4050:23;4096:18;4088:6;4085:30;4082:50;;;4128:1;4125;4118:12;4082:50;4151:22;;4204:4;4196:13;;4192:27;-1:-1:-1;4182:55:1;;4233:1;4230;4223:12;4182:55;4269:2;4256:16;4292:60;4308:43;4348:2;4308:43;:::i;4292:60::-;4374:3;4398:2;4393:3;4386:15;4426:2;4421:3;4417:12;4410:19;;4457:2;4453;4449:11;4505:7;4500:2;4494;4491:1;4487:10;4483:2;4479:19;4475:28;4472:41;4469:61;;;4526:1;4523;4516:12;4469:61;4548:1;4539:10;;4558:169;4572:2;4569:1;4566:9;4558:169;;;4629:23;4648:3;4629:23;:::i;:::-;4617:36;;4590:1;4583:9;;;;;4673:12;;;;4705;;4558:169;;;-1:-1:-1;4746:5:1;3849:908;-1:-1:-1;;;;;;;3849:908:1:o;4762:245::-;4829:6;4882:2;4870:9;4861:7;4857:23;4853:32;4850:52;;;4898:1;4895;4888:12;4850:52;4930:9;4924:16;4949:28;4971:5;4949:28;:::i;5012:245::-;5070:6;5123:2;5111:9;5102:7;5098:23;5094:32;5091:52;;;5139:1;5136;5129:12;5091:52;5178:9;5165:23;5197:30;5221:5;5197:30;:::i;5262:249::-;5331:6;5384:2;5372:9;5363:7;5359:23;5355:32;5352:52;;;5400:1;5397;5390:12;5352:52;5432:9;5426:16;5451:30;5475:5;5451:30;:::i;5516:322::-;5585:6;5638:2;5626:9;5617:7;5613:23;5609:32;5606:52;;;5654:1;5651;5644:12;5606:52;5694:9;5681:23;5727:18;5719:6;5716:30;5713:50;;;5759:1;5756;5749:12;5713:50;5782;5824:7;5815:6;5804:9;5800:22;5782:50;:::i;5843:272::-;5901:6;5954:2;5942:9;5933:7;5929:23;5925:32;5922:52;;;5970:1;5967;5960:12;5922:52;6009:9;5996:23;6059:6;6052:5;6048:18;6041:5;6038:29;6028:57;;6081:1;6078;6071:12;6120:180;6179:6;6232:2;6220:9;6211:7;6207:23;6203:32;6200:52;;;6248:1;6245;6238:12;6200:52;-1:-1:-1;6271:23:1;;6120:180;-1:-1:-1;6120:180:1:o;6305:184::-;6375:6;6428:2;6416:9;6407:7;6403:23;6399:32;6396:52;;;6444:1;6441;6434:12;6396:52;-1:-1:-1;6467:16:1;;6305:184;-1:-1:-1;6305:184:1:o;6494:390::-;6572:6;6580;6633:2;6621:9;6612:7;6608:23;6604:32;6601:52;;;6649:1;6646;6639:12;6601:52;6685:9;6672:23;6662:33;;6746:2;6735:9;6731:18;6718:32;6773:18;6765:6;6762:30;6759:50;;;6805:1;6802;6795:12;6759:50;6828;6870:7;6861:6;6850:9;6846:22;6828:50;:::i;:::-;6818:60;;;6494:390;;;;;:::o;6889:248::-;6957:6;6965;7018:2;7006:9;6997:7;6993:23;6989:32;6986:52;;;7034:1;7031;7024:12;6986:52;-1:-1:-1;;7057:23:1;;;7127:2;7112:18;;;7099:32;;-1:-1:-1;6889:248:1:o;7142:257::-;7183:3;7221:5;7215:12;7248:6;7243:3;7236:19;7264:63;7320:6;7313:4;7308:3;7304:14;7297:4;7290:5;7286:16;7264:63;:::i;:::-;7381:2;7360:15;-1:-1:-1;;7356:29:1;7347:39;;;;7388:4;7343:50;;7142:257;-1:-1:-1;;7142:257:1:o;7404:664::-;7631:3;7669:6;7663:13;7685:53;7731:6;7726:3;7719:4;7711:6;7707:17;7685:53;:::i;:::-;7801:13;;7760:16;;;;7823:57;7801:13;7760:16;7857:4;7845:17;;7823:57;:::i;:::-;7947:13;;7902:20;;;7969:57;7947:13;7902:20;8003:4;7991:17;;7969:57;:::i;:::-;8042:20;;7404:664;-1:-1:-1;;;;;7404:664:1:o;8661:488::-;-1:-1:-1;;;;;8930:15:1;;;8912:34;;8982:15;;8977:2;8962:18;;8955:43;9029:2;9014:18;;9007:34;;;9077:3;9072:2;9057:18;;9050:31;;;8855:4;;9098:45;;9123:19;;9115:6;9098:45;:::i;:::-;9090:53;8661:488;-1:-1:-1;;;;;;8661:488:1:o;9433:632::-;9604:2;9656:21;;;9726:13;;9629:18;;;9748:22;;;9575:4;;9604:2;9827:15;;;;9801:2;9786:18;;;9575:4;9870:169;9884:6;9881:1;9878:13;9870:169;;;9945:13;;9933:26;;10014:15;;;;9979:12;;;;9906:1;9899:9;9870:169;;;-1:-1:-1;10056:3:1;;9433:632;-1:-1:-1;;;;;;9433:632:1:o;10262:219::-;10411:2;10400:9;10393:21;10374:4;10431:44;10471:2;10460:9;10456:18;10448:6;10431:44;:::i;11582:414::-;11784:2;11766:21;;;11823:2;11803:18;;;11796:30;11862:34;11857:2;11842:18;;11835:62;-1:-1:-1;;;11928:2:1;11913:18;;11906:48;11986:3;11971:19;;11582:414::o;20176:356::-;20378:2;20360:21;;;20397:18;;;20390:30;20456:34;20451:2;20436:18;;20429:62;20523:2;20508:18;;20176:356::o;22527:413::-;22729:2;22711:21;;;22768:2;22748:18;;;22741:30;22807:34;22802:2;22787:18;;22780:62;-1:-1:-1;;;22873:2:1;22858:18;;22851:47;22930:3;22915:19;;22527:413::o;24294:275::-;24365:2;24359:9;24430:2;24411:13;;-1:-1:-1;;24407:27:1;24395:40;;24465:18;24450:34;;24486:22;;;24447:62;24444:88;;;24512:18;;:::i;:::-;24548:2;24541:22;24294:275;;-1:-1:-1;24294:275:1:o;24574:183::-;24634:4;24667:18;24659:6;24656:30;24653:56;;;24689:18;;:::i;:::-;-1:-1:-1;24734:1:1;24730:14;24746:4;24726:25;;24574:183::o;24762:128::-;24802:3;24833:1;24829:6;24826:1;24823:13;24820:39;;;24839:18;;:::i;:::-;-1:-1:-1;24875:9:1;;24762:128::o;24895:120::-;24935:1;24961;24951:35;;24966:18;;:::i;:::-;-1:-1:-1;25000:9:1;;24895:120::o;25020:168::-;25060:7;25126:1;25122;25118:6;25114:14;25111:1;25108:21;25103:1;25096:9;25089:17;25085:45;25082:71;;;25133:18;;:::i;:::-;-1:-1:-1;25173:9:1;;25020:168::o;25193:125::-;25233:4;25261:1;25258;25255:8;25252:34;;;25266:18;;:::i;:::-;-1:-1:-1;25303:9:1;;25193:125::o;25323:258::-;25395:1;25405:113;25419:6;25416:1;25413:13;25405:113;;;25495:11;;;25489:18;25476:11;;;25469:39;25441:2;25434:10;25405:113;;;25536:6;25533:1;25530:13;25527:48;;;-1:-1:-1;;25571:1:1;25553:16;;25546:27;25323:258::o;25586:380::-;25665:1;25661:12;;;;25708;;;25729:61;;25783:4;25775:6;25771:17;25761:27;;25729:61;25836:2;25828:6;25825:14;25805:18;25802:38;25799:161;;;25882:10;25877:3;25873:20;25870:1;25863:31;25917:4;25914:1;25907:15;25945:4;25942:1;25935:15;25971:135;26010:3;-1:-1:-1;;26031:17:1;;26028:43;;;26051:18;;:::i;:::-;-1:-1:-1;26098:1:1;26087:13;;25971:135::o;26111:112::-;26143:1;26169;26159:35;;26174:18;;:::i;:::-;-1:-1:-1;26208:9:1;;26111:112::o;26228:127::-;26289:10;26284:3;26280:20;26277:1;26270:31;26320:4;26317:1;26310:15;26344:4;26341:1;26334:15;26360:127;26421:10;26416:3;26412:20;26409:1;26402:31;26452:4;26449:1;26442:15;26476:4;26473:1;26466:15;26492:127;26553:10;26548:3;26544:20;26541:1;26534:31;26584:4;26581:1;26574:15;26608:4;26605:1;26598:15;26624:127;26685:10;26680:3;26676:20;26673:1;26666:31;26716:4;26713:1;26706:15;26740:4;26737:1;26730:15;26756:127;26817:10;26812:3;26808:20;26805:1;26798:31;26848:4;26845:1;26838:15;26872:4;26869:1;26862:15;26888:118;26974:5;26967:13;26960:21;26953:5;26950:32;26940:60;;26996:1;26993;26986:12;27011:131;-1:-1:-1;;;;;;27085:32:1;;27075:43;;27065:71;;27132:1;27129;27122:12

Swarm Source

ipfs://c849ac70b7adc29aea56927dc8fd1f4c19cd4c1e75cd97261575b9e64fb4378a
Loading