ETH Price: $3,215.27 (+5.28%)

Token

 

Overview

Max Total Supply

0

Holders

97

Market

Volume (24H)

N/A

Min Price (24H)

N/A

Max Price (24H)

N/A
Filtered by Token Holder
dracowyn.eth
Balance
7
0xd4f650da6a66C56C4C8d9b0dA904A96b12Dd721E
Loading...
Loading
Loading...
Loading
Loading...
Loading

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

Contract Source Code Verified (Exact Match)

Contract Name:
PowerBallV1

Compiler Version
v0.8.15+commit.e14f2714

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, Unlicense license

Contract Source Code (Solidity Multiple files format)

File 15 of 17: PowerBallV1.sol
// SPDX-License-Identifier: UNLICENSED

pragma solidity >=0.7.0 <0.9.0;

// import '@openzeppelin/contracts/token/ERC721/ERC721.sol';
import "./OwnableUpgradeable.sol";
import "./MerkleProof.sol";
import "./ECDSA.sol";
import "./Initializable.sol";
import "./ERC721Upgradeable.sol";
import "./ERC165Upgradeable.sol";
import "./StringsUpgradeable.sol";
import "./IERC20.sol";
import "./Base64.sol";


// import "@openzeppelin/contracts-upgradeable/interfaces/IERC2981Upgradeable.sol";
/**
 * @dev Interface for the NFT Royalty Standard
 */
interface IERC2981Upgradeable is IERC165Upgradeable {
    /**
     * @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`
     */
}

contract PowerBallV1 is Initializable, OwnableUpgradeable, ERC721Upgradeable, IERC2981Upgradeable
{
    string private baseURI = "ipfs://QmRe6FKkkgh5c78HEUth7oWMdMvRtC4Ax6L2BUqMw8pLVQ/";
    uint256 public mintFee = 0.005 ether;
    bool private mintRandomEnabled = true;
    
    uint256 public remaining = 10000;
    mapping(uint256 => uint256) public cache;
    mapping(uint256 => uint256) public cachePosition;
    mapping(address => uint256) public accountMintCount;

    uint256 public wlMintLimit = 2;
    uint256 public publicMintLimit = 10;
    uint256 public amountWithdrawn = 0;
    string public placeholderImage;

    bool public lockBaseUri = false;

    bytes32 public merkleRoot = 0x5e551ecbc4b0d0ab94638b0b80d7f29aaefff700dcb50b6a1271c4303ab5be0e;
    mapping(address => bool) public whitelistClaimed;
    bool public whitelistMintEnabled = false;

    constructor()  {}

    function initialize() public initializer  {
        __ERC721_init("Powerball V1", "PWBONE");
    }
    
    function _baseURI() internal view virtual override returns (string memory) {
        return baseURI;
    }
    
    /* Mint 'n' random tokens if random minting is enabled */
    function mintRandom(uint256 count) payable public
    {
        require(count > 0 && count <= publicMintLimit, 'Cannot mint because exceeding mint per transaction limit');
        require(mintRandomEnabled == true, 'Random minting is not enabled for this contract');
        require(msg.value >= mintFee * count, 'Eth sent does not match the mint fee');
        
        _updateUserMintCount(msg.sender, count);

        for(uint256 i=0; i < count; i++){
            uint256 tokenID = _drawRandomIndex();
            _safeMint(msg.sender, tokenID);
        }
    }
    
    function whitelistMint(uint256 _mintAmount, bytes32[] calldata _merkleProof) payable public {
        require(_mintAmount > 0 && _mintAmount <= wlMintLimit, 'Cannot mint because exceeding mint per transaction limit');
        _updateUserMintCount(msg.sender);
        // Verify whitelist requirements
        require(whitelistMintEnabled, 'The whitelist sale is not enabled!');
        require(!whitelistClaimed[msg.sender], 'Address already claimed!');
        bytes32 leaf = keccak256(abi.encodePacked(msg.sender));
        require(MerkleProof.verify(_merkleProof, merkleRoot, leaf), 'Invalid proof!');

        whitelistClaimed[msg.sender] = true;
        for(uint256 i=0; i < _mintAmount; i++){
            /* Mint the token for the provided to address */
            uint256 tokenID = _drawRandomIndex();
            _safeMint(msg.sender, tokenID);
        }
    }
    
    /* Mint a token to a specific address */
    function airDropRandomToAccounts(address[] calldata to) onlyOwner() public
    {
        for (uint i=0; i<to.length; i++) {
            uint256 tokenID = _drawRandomIndex();
            _safeMint(to[i], tokenID);
        }
    }
    
    function _drawRandomIndex() internal returns (uint256 index) {
        //RNG
        uint256 i = uint(keccak256(abi.encodePacked(block.timestamp))) % remaining;

        // if there's a cache at cache[i] then use it
        // otherwise use i itself
        index = cache[i] == 0 ? i : cache[i];

        // grab a number from the tail
        cache[i] = cache[remaining - 1] == 0 ? remaining - 1 : cache[remaining - 1];
        
        // store the position of moved token in cache to be looked up (add 1 to avoid 0, remove when recovering)
        cachePosition[cache[i]] = i + 1;
        
        remaining = remaining - 1;
    }
    
    function _drawIndex(uint256 tokenID) internal {
        // recover the index, subtract 1 from cachePosition as an additional 1 was added to avoid 0 conflict
        uint256 i = cachePosition[tokenID] == 0 ? tokenID : cachePosition[tokenID] - 1;
        
        require(i <= remaining);
        
        // grab a number from the tail
        cache[i] = cache[remaining - 1] == 0 ? remaining - 1 : cache[remaining - 1];
        
        // store the position of moved token in cache to be looked up (add 1 to avoid 0, remove when recovering)
        cachePosition[cache[i]] = i + 1;
        
        remaining = remaining - 1;
    }
    
    function _updateUserMintCount(address account) internal {
        // increment a mapping for user on how many mints they have
        uint256 count = accountMintCount[account];

        accountMintCount[account] = count + 1;
    }
    
    function _updateUserMintCount(address account, uint256 quantity) internal {
        // increment a mapping for user on how many mints they have
        uint256 count = accountMintCount[account];

        accountMintCount[account] = count + quantity;
    }
    
    function isTokenAvailable(uint256 tokenID) external view returns (bool)
    {
        return !_exists(tokenID);
    }

    function toggleRandomPublicMinting() onlyOwner() public
    {
        mintRandomEnabled = !mintRandomEnabled;
    }

    function toggleWhitelistMinting() onlyOwner() public
    {
        whitelistMintEnabled = !whitelistMintEnabled;
    }
    function changeMintFee(uint256 mintFee_) onlyOwner() public
    {
        mintFee = mintFee_;
    }

    function changePublicMintLimit(uint256 mintLimit_) onlyOwner() public
    {
        publicMintLimit = mintLimit_;
    }

    function changeWlMintLimit(uint256 mintLimit_) onlyOwner() public
    {
        wlMintLimit = mintLimit_;
    }

    function setMerkleRoot(bytes32 _merkleRoot) public onlyOwner() {
        merkleRoot = _merkleRoot;
    }

    function changePlaceholderImage(string memory placeholderImage_) onlyOwner() public
    {
        require(bytes(placeholderImage).length != 0, "Metadata has already been revealed");
        require(bytes(placeholderImage_).length != 0, "Placeholder image cannot be empty");

        placeholderImage = placeholderImage_;
    }

    /* Transfer balance of this contract to an account */
    function transferBalance(address payable to, uint256 amount) onlyOwner() public{
        if(address(this).balance != 0){
            require(address(this).balance >= amount, "Not enought Balance to Transfer");
            payable(to).transfer(amount);
            amountWithdrawn += amount;
        }
    }
    
    /* Transfer any ERC20 balance of this contract to an account */
    function transferERC20Balance(address erc20ContractAddress, address payable to, uint256 amount) onlyOwner() public{
        IERC20(erc20ContractAddress).transfer(to, amount);
    }
    
    /**
     * @dev See {IERC165-supportsInterface}.
     */
    function supportsInterface(bytes4 interfaceId) public view virtual override(ERC721Upgradeable, IERC165Upgradeable) returns (bool) {
        return
            interfaceId == type(IERC721Upgradeable).interfaceId ||
            interfaceId == type(IERC721MetadataUpgradeable).interfaceId ||
            interfaceId == type(IERC2981Upgradeable).interfaceId ||
            super.supportsInterface(interfaceId);
    }

    function isPublicMintingEnabled() external view returns (bool){
        return mintRandomEnabled;
    }
    
    /**
     * @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();

        if(bytes(placeholderImage).length > 0){
            return placeholderImage;
        }
        else{
            return bytes(__baseURI).length > 0 ? string(abi.encodePacked(__baseURI, Strings.toString(tokenId),".json")) : "";
        }

    }

    function reveal() onlyOwner() public {
        placeholderImage = "";
    }

    function changeBaseUri(string memory baseURI_) onlyOwner() public {
        require(!lockBaseUri, "Base URI is locked, it cannot be edited");

        baseURI = baseURI_;
    }

    function permanentlyLockBaseUri() onlyOwner() public {
        lockBaseUri = true;
    }

    function getMintsUsed(address account) external view returns (uint256) {
        return accountMintCount[account];
    }
    
    function version() external pure returns (string memory)
    {
        return "1.0.6";
    }

    receive() external payable {}
}

File 1 of 17: AddressUpgradeable.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.1 (utils/Address.sol)

pragma solidity ^0.8.0;

/**
 * @dev Collection of functions related to the address type
 */
library AddressUpgradeable {
    /**
     * @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;
        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");

        (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");

        (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");

        (bool success, bytes memory returndata) = target.staticcall(data);
        return verifyCallResult(success, returndata, errorMessage);
    }

    /**
     * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the
     * revert reason using the provided one.
     *
     * _Available since v4.3._
     */
    function verifyCallResult(
        bool success,
        bytes memory returndata,
        string memory errorMessage
    ) internal 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

                assembly {
                    let returndata_size := mload(returndata)
                    revert(add(32, returndata), returndata_size)
                }
            } else {
                revert(errorMessage);
            }
        }
    }
}

File 2 of 17: Base64.sol
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;

/// @title Base64
/// @author Brecht Devos - <[email protected]>
/// @notice Provides a function for encoding some bytes in base64
library Base64 {
    string internal constant TABLE =
        "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";

    function encode(bytes memory data) internal pure returns (string memory) {
        if (data.length == 0) return "";

        // load the table into memory
        string memory table = TABLE;

        // multiply by 4/3 rounded up
        uint256 encodedLen = 4 * ((data.length + 2) / 3);

        // add some extra buffer at the end required for the writing
        string memory result = new string(encodedLen + 32);

        assembly {
            // set the actual output length
            mstore(result, encodedLen)

            // prepare the lookup table
            let tablePtr := add(table, 1)

            // input ptr
            let dataPtr := data
            let endPtr := add(dataPtr, mload(data))

            // result ptr, jump over length
            let resultPtr := add(result, 32)

            // run over the input, 3 bytes at a time
            for {

            } lt(dataPtr, endPtr) {

            } {
                dataPtr := add(dataPtr, 3)

                // read 3 bytes
                let input := mload(dataPtr)

                // write 4 characters
                mstore(
                    resultPtr,
                    shl(248, mload(add(tablePtr, and(shr(18, input), 0x3F))))
                )
                resultPtr := add(resultPtr, 1)
                mstore(
                    resultPtr,
                    shl(248, mload(add(tablePtr, and(shr(12, input), 0x3F))))
                )
                resultPtr := add(resultPtr, 1)
                mstore(
                    resultPtr,
                    shl(248, mload(add(tablePtr, and(shr(6, input), 0x3F))))
                )
                resultPtr := add(resultPtr, 1)
                mstore(
                    resultPtr,
                    shl(248, mload(add(tablePtr, and(input, 0x3F))))
                )
                resultPtr := add(resultPtr, 1)
            }

            // padding with '='
            switch mod(mload(data), 3)
            case 1 {
                mstore(sub(resultPtr, 2), shl(240, 0x3d3d))
            }
            case 2 {
                mstore(sub(resultPtr, 1), shl(248, 0x3d))
            }
        }

        return result;
    }
}

File 3 of 17: ContextUpgradeable.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.1 (utils/Context.sol)

pragma solidity ^0.8.0;
import "./Initializable.sol";

/**
 * @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 ContextUpgradeable is Initializable {
    function __Context_init() internal onlyInitializing {
        __Context_init_unchained();
    }

    function __Context_init_unchained() internal onlyInitializing {
    }
    function _msgSender() internal view virtual returns (address) {
        return msg.sender;
    }

    function _msgData() internal view virtual returns (bytes calldata) {
        return msg.data;
    }
    uint256[50] private __gap;
}

File 4 of 17: ECDSA.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.1 (utils/cryptography/ECDSA.sol)

pragma solidity ^0.8.0;

import "./Strings.sol";

/**
 * @dev Elliptic Curve Digital Signature Algorithm (ECDSA) operations.
 *
 * These functions can be used to verify that a message was signed by the holder
 * of the private keys of a given address.
 */
library ECDSA {
    enum RecoverError {
        NoError,
        InvalidSignature,
        InvalidSignatureLength,
        InvalidSignatureS,
        InvalidSignatureV
    }

    function _throwError(RecoverError error) private pure {
        if (error == RecoverError.NoError) {
            return; // no error: do nothing
        } else if (error == RecoverError.InvalidSignature) {
            revert("ECDSA: invalid signature");
        } else if (error == RecoverError.InvalidSignatureLength) {
            revert("ECDSA: invalid signature length");
        } else if (error == RecoverError.InvalidSignatureS) {
            revert("ECDSA: invalid signature 's' value");
        } else if (error == RecoverError.InvalidSignatureV) {
            revert("ECDSA: invalid signature 'v' value");
        }
    }

    /**
     * @dev Returns the address that signed a hashed message (`hash`) with
     * `signature` or error string. This address can then be used for verification purposes.
     *
     * The `ecrecover` EVM opcode allows for malleable (non-unique) signatures:
     * this function rejects them by requiring the `s` value to be in the lower
     * half order, and the `v` value to be either 27 or 28.
     *
     * IMPORTANT: `hash` _must_ be the result of a hash operation for the
     * verification to be secure: it is possible to craft signatures that
     * recover to arbitrary addresses for non-hashed data. A safe way to ensure
     * this is by receiving a hash of the original message (which may otherwise
     * be too long), and then calling {toEthSignedMessageHash} on it.
     *
     * Documentation for signature generation:
     * - with https://web3js.readthedocs.io/en/v1.3.4/web3-eth-accounts.html#sign[Web3.js]
     * - with https://docs.ethers.io/v5/api/signer/#Signer-signMessage[ethers]
     *
     * _Available since v4.3._
     */
    function tryRecover(bytes32 hash, bytes memory signature) internal pure returns (address, RecoverError) {
        // Check the signature length
        // - case 65: r,s,v signature (standard)
        // - case 64: r,vs signature (cf https://eips.ethereum.org/EIPS/eip-2098) _Available since v4.1._
        if (signature.length == 65) {
            bytes32 r;
            bytes32 s;
            uint8 v;
            // ecrecover takes the signature parameters, and the only way to get them
            // currently is to use assembly.
            assembly {
                r := mload(add(signature, 0x20))
                s := mload(add(signature, 0x40))
                v := byte(0, mload(add(signature, 0x60)))
            }
            return tryRecover(hash, v, r, s);
        } else if (signature.length == 64) {
            bytes32 r;
            bytes32 vs;
            // ecrecover takes the signature parameters, and the only way to get them
            // currently is to use assembly.
            assembly {
                r := mload(add(signature, 0x20))
                vs := mload(add(signature, 0x40))
            }
            return tryRecover(hash, r, vs);
        } else {
            return (address(0), RecoverError.InvalidSignatureLength);
        }
    }

    /**
     * @dev Returns the address that signed a hashed message (`hash`) with
     * `signature`. This address can then be used for verification purposes.
     *
     * The `ecrecover` EVM opcode allows for malleable (non-unique) signatures:
     * this function rejects them by requiring the `s` value to be in the lower
     * half order, and the `v` value to be either 27 or 28.
     *
     * IMPORTANT: `hash` _must_ be the result of a hash operation for the
     * verification to be secure: it is possible to craft signatures that
     * recover to arbitrary addresses for non-hashed data. A safe way to ensure
     * this is by receiving a hash of the original message (which may otherwise
     * be too long), and then calling {toEthSignedMessageHash} on it.
     */
    function recover(bytes32 hash, bytes memory signature) internal pure returns (address) {
        (address recovered, RecoverError error) = tryRecover(hash, signature);
        _throwError(error);
        return recovered;
    }

    /**
     * @dev Overload of {ECDSA-tryRecover} that receives the `r` and `vs` short-signature fields separately.
     *
     * See https://eips.ethereum.org/EIPS/eip-2098[EIP-2098 short signatures]
     *
     * _Available since v4.3._
     */
    function tryRecover(
        bytes32 hash,
        bytes32 r,
        bytes32 vs
    ) internal pure returns (address, RecoverError) {
        bytes32 s;
        uint8 v;
        assembly {
            s := and(vs, 0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff)
            v := add(shr(255, vs), 27)
        }
        return tryRecover(hash, v, r, s);
    }

    /**
     * @dev Overload of {ECDSA-recover} that receives the `r and `vs` short-signature fields separately.
     *
     * _Available since v4.2._
     */
    function recover(
        bytes32 hash,
        bytes32 r,
        bytes32 vs
    ) internal pure returns (address) {
        (address recovered, RecoverError error) = tryRecover(hash, r, vs);
        _throwError(error);
        return recovered;
    }

    /**
     * @dev Overload of {ECDSA-tryRecover} that receives the `v`,
     * `r` and `s` signature fields separately.
     *
     * _Available since v4.3._
     */
    function tryRecover(
        bytes32 hash,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) internal pure returns (address, RecoverError) {
        // EIP-2 still allows signature malleability for ecrecover(). Remove this possibility and make the signature
        // unique. Appendix F in the Ethereum Yellow paper (https://ethereum.github.io/yellowpaper/paper.pdf), defines
        // the valid range for s in (301): 0 < s < secp256k1n ÷ 2 + 1, and for v in (302): v ∈ {27, 28}. Most
        // signatures from current libraries generate a unique signature with an s-value in the lower half order.
        //
        // If your library generates malleable signatures, such as s-values in the upper range, calculate a new s-value
        // with 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFEBAAEDCE6AF48A03BBFD25E8CD0364141 - s1 and flip v from 27 to 28 or
        // vice versa. If your library also generates signatures with 0/1 for v instead 27/28, add 27 to v to accept
        // these malleable signatures as well.
        if (uint256(s) > 0x7FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF5D576E7357A4501DDFE92F46681B20A0) {
            return (address(0), RecoverError.InvalidSignatureS);
        }
        if (v != 27 && v != 28) {
            return (address(0), RecoverError.InvalidSignatureV);
        }

        // If the signature is valid (and not malleable), return the signer address
        address signer = ecrecover(hash, v, r, s);
        if (signer == address(0)) {
            return (address(0), RecoverError.InvalidSignature);
        }

        return (signer, RecoverError.NoError);
    }

    /**
     * @dev Overload of {ECDSA-recover} that receives the `v`,
     * `r` and `s` signature fields separately.
     */
    function recover(
        bytes32 hash,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) internal pure returns (address) {
        (address recovered, RecoverError error) = tryRecover(hash, v, r, s);
        _throwError(error);
        return recovered;
    }

    /**
     * @dev Returns an Ethereum Signed Message, created from a `hash`. This
     * produces hash corresponding to the one signed with the
     * https://eth.wiki/json-rpc/API#eth_sign[`eth_sign`]
     * JSON-RPC method as part of EIP-191.
     *
     * See {recover}.
     */
    function toEthSignedMessageHash(bytes32 hash) internal pure returns (bytes32) {
        // 32 is the length in bytes of hash,
        // enforced by the type signature above
        return keccak256(abi.encodePacked("\x19Ethereum Signed Message:\n32", hash));
    }

    /**
     * @dev Returns an Ethereum Signed Message, created from `s`. This
     * produces hash corresponding to the one signed with the
     * https://eth.wiki/json-rpc/API#eth_sign[`eth_sign`]
     * JSON-RPC method as part of EIP-191.
     *
     * See {recover}.
     */
    function toEthSignedMessageHash(bytes memory s) internal pure returns (bytes32) {
        return keccak256(abi.encodePacked("\x19Ethereum Signed Message:\n", Strings.toString(s.length), s));
    }

    /**
     * @dev Returns an Ethereum Signed Typed Data, created from a
     * `domainSeparator` and a `structHash`. This produces hash corresponding
     * to the one signed with the
     * https://eips.ethereum.org/EIPS/eip-712[`eth_signTypedData`]
     * JSON-RPC method as part of EIP-712.
     *
     * See {recover}.
     */
    function toTypedDataHash(bytes32 domainSeparator, bytes32 structHash) internal pure returns (bytes32) {
        return keccak256(abi.encodePacked("\x19\x01", domainSeparator, structHash));
    }
}

File 5 of 17: ERC165Upgradeable.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.1 (utils/introspection/ERC165.sol)

pragma solidity ^0.8.0;

import "./IERC165Upgradeable.sol";
import "./Initializable.sol";

/**
 * @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 ERC165Upgradeable is Initializable, IERC165Upgradeable {
    function __ERC165_init() internal onlyInitializing {
        __ERC165_init_unchained();
    }

    function __ERC165_init_unchained() internal onlyInitializing {
    }
    /**
     * @dev See {IERC165-supportsInterface}.
     */
    function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {
        return interfaceId == type(IERC165Upgradeable).interfaceId;
    }
    uint256[50] private __gap;
}

File 6 of 17: ERC721Upgradeable.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.1 (token/ERC721/ERC721.sol)

pragma solidity ^0.8.0;

import "./IERC721Upgradeable.sol";
import "./IERC721ReceiverUpgradeable.sol";
import "./IERC721MetadataUpgradeable.sol";
import "./AddressUpgradeable.sol";
import "./ContextUpgradeable.sol";
import "./StringsUpgradeable.sol";
import "./ERC165Upgradeable.sol";
import "./Initializable.sol";

/**
 * @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 ERC721Upgradeable is Initializable, ContextUpgradeable, ERC165Upgradeable, IERC721Upgradeable, IERC721MetadataUpgradeable {
    using AddressUpgradeable for address;
    using StringsUpgradeable 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.
     */
    function __ERC721_init(string memory name_, string memory symbol_) internal onlyInitializing {
        __Context_init_unchained();
        __ERC165_init_unchained();
        __ERC721_init_unchained(name_, symbol_);
    }

    function __ERC721_init_unchained(string memory name_, string memory symbol_) internal onlyInitializing {
        _name = name_;
        _symbol = symbol_;
    }

    /**
     * @dev See {IERC165-supportsInterface}.
     */
    function supportsInterface(bytes4 interfaceId) public view virtual override(ERC165Upgradeable, IERC165Upgradeable) returns (bool) {
        return
            interfaceId == type(IERC721Upgradeable).interfaceId ||
            interfaceId == type(IERC721MetadataUpgradeable).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}. If set, the resulting URI for each
     * token will be the concatenation of the `baseURI` and the `tokenId`. Empty
     * by default, can be overriden in child contracts.
     */
    function _baseURI() internal view virtual returns (string memory) {
        return "";
    }

    /**
     * @dev See {IERC721-approve}.
     */
    function approve(address to, uint256 tokenId) public virtual override {
        address owner = ERC721Upgradeable.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 {
        _setApprovalForAll(_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 = ERC721Upgradeable.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 = ERC721Upgradeable.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(ERC721Upgradeable.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(ERC721Upgradeable.ownerOf(tokenId), to, tokenId);
    }

    /**
     * @dev Approve `operator` to operate on all of `owner` tokens
     *
     * Emits a {ApprovalForAll} event.
     */
    function _setApprovalForAll(
        address owner,
        address operator,
        bool approved
    ) internal virtual {
        require(owner != operator, "ERC721: approve to caller");
        _operatorApprovals[owner][operator] = approved;
        emit ApprovalForAll(owner, operator, approved);
    }

    /**
     * @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 IERC721ReceiverUpgradeable(to).onERC721Received(_msgSender(), from, tokenId, _data) returns (bytes4 retval) {
                return retval == IERC721ReceiverUpgradeable.onERC721Received.selector;
            } catch (bytes memory reason) {
                if (reason.length == 0) {
                    revert("ERC721: transfer to non ERC721Receiver implementer");
                } else {
                    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` and `to` are never both zero.
     *
     * To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks].
     */
    function _beforeTokenTransfer(
        address from,
        address to,
        uint256 tokenId
    ) internal virtual {}
    uint256[44] private __gap;
}

File 7 of 17: IERC165Upgradeable.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.1 (utils/introspection/IERC165.sol)

pragma solidity ^0.8.0;

/**
 * @dev Interface of the ERC165 standard, as defined in the
 * https://eips.ethereum.org/EIPS/eip-165[EIP].
 *
 * Implementers can declare support of contract interfaces, which can then be
 * queried by others ({ERC165Checker}).
 *
 * For an implementation, see {ERC165}.
 */
interface IERC165Upgradeable {
    /**
     * @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 8 of 17: IERC20.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.1 (token/ERC20/IERC20.sol)

pragma solidity ^0.8.0;

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

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

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

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

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

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

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

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

File 9 of 17: IERC721MetadataUpgradeable.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.1 (token/ERC721/extensions/IERC721Metadata.sol)

pragma solidity ^0.8.0;

import "./IERC721Upgradeable.sol";

/**
 * @title ERC-721 Non-Fungible Token Standard, optional metadata extension
 * @dev See https://eips.ethereum.org/EIPS/eip-721
 */
interface IERC721MetadataUpgradeable is IERC721Upgradeable {
    /**
     * @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 10 of 17: IERC721ReceiverUpgradeable.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.1 (token/ERC721/IERC721Receiver.sol)

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 IERC721ReceiverUpgradeable {
    /**
     * @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 11 of 17: IERC721Upgradeable.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.1 (token/ERC721/IERC721.sol)

pragma solidity ^0.8.0;

import "./IERC165Upgradeable.sol";

/**
 * @dev Required interface of an ERC721 compliant contract.
 */
interface IERC721Upgradeable is IERC165Upgradeable {
    /**
     * @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 12 of 17: Initializable.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.1 (proxy/utils/Initializable.sol)

pragma solidity ^0.8.0;

import "./AddressUpgradeable.sol";

/**
 * @dev This is a base contract to aid in writing upgradeable contracts, or any kind of contract that will be deployed
 * behind a proxy. Since a proxied contract can't have a constructor, it's common to move constructor logic to an
 * external initializer function, usually called `initialize`. It then becomes necessary to protect this initializer
 * function so it can only be called once. The {initializer} modifier provided by this contract will have this effect.
 *
 * TIP: To avoid leaving the proxy in an uninitialized state, the initializer function should be called as early as
 * possible by providing the encoded function call as the `_data` argument to {ERC1967Proxy-constructor}.
 *
 * CAUTION: When used with inheritance, manual care must be taken to not invoke a parent initializer twice, or to ensure
 * that all initializers are idempotent. This is not verified automatically as constructors are by Solidity.
 *
 * [CAUTION]
 * ====
 * Avoid leaving a contract uninitialized.
 *
 * An uninitialized contract can be taken over by an attacker. This applies to both a proxy and its implementation
 * contract, which may impact the proxy. To initialize the implementation contract, you can either invoke the
 * initializer manually, or you can include a constructor to automatically mark it as initialized when it is deployed:
 *
 * [.hljs-theme-light.nopadding]
 * ```
 * /// @custom:oz-upgrades-unsafe-allow constructor
 * constructor() initializer {}
 * ```
 * ====
 */
abstract contract Initializable {
    /**
     * @dev Indicates that the contract has been initialized.
     */
    bool private _initialized;

    /**
     * @dev Indicates that the contract is in the process of being initialized.
     */
    bool private _initializing;

    /**
     * @dev Modifier to protect an initializer function from being invoked twice.
     */
    modifier initializer() {
        // If the contract is initializing we ignore whether _initialized is set in order to support multiple
        // inheritance patterns, but we only do this in the context of a constructor, because in other contexts the
        // contract may have been reentered.
        require(_initializing ? _isConstructor() : !_initialized, "Initializable: contract is already initialized");

        bool isTopLevelCall = !_initializing;
        if (isTopLevelCall) {
            _initializing = true;
            _initialized = true;
        }

        _;

        if (isTopLevelCall) {
            _initializing = false;
        }
    }

    /**
     * @dev Modifier to protect an initialization function so that it can only be invoked by functions with the
     * {initializer} modifier, directly or indirectly.
     */
    modifier onlyInitializing() {
        require(_initializing, "Initializable: contract is not initializing");
        _;
    }

    function _isConstructor() private view returns (bool) {
        return !AddressUpgradeable.isContract(address(this));
    }
}

File 13 of 17: MerkleProof.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v4.5.0) (utils/cryptography/MerkleProof.sol)

pragma solidity ^0.8.0;

/**
 * @dev These functions deal with verification of Merkle Trees proofs.
 *
 * The proofs can be generated using the JavaScript library
 * https://github.com/miguelmota/merkletreejs[merkletreejs].
 * Note: the hashing algorithm should be keccak256 and pair sorting should be enabled.
 *
 * See `test/utils/cryptography/MerkleProof.test.js` for some examples.
 */
library MerkleProof {
    /**
     * @dev Returns true if a `leaf` can be proved to be a part of a Merkle tree
     * defined by `root`. For this, a `proof` must be provided, containing
     * sibling hashes on the branch from the leaf to the root of the tree. Each
     * pair of leaves and each pair of pre-images are assumed to be sorted.
     */
    function verify(
        bytes32[] memory proof,
        bytes32 root,
        bytes32 leaf
    ) internal pure returns (bool) {
        return processProof(proof, leaf) == root;
    }

    /**
     * @dev Returns the rebuilt hash obtained by traversing a Merklee tree up
     * from `leaf` using `proof`. A `proof` is valid if and only if the rebuilt
     * hash matches the root of the tree. When processing the proof, the pairs
     * of leafs & pre-images are assumed to be sorted.
     *
     * _Available since v4.4._
     */
    function processProof(bytes32[] memory proof, bytes32 leaf) internal pure returns (bytes32) {
        bytes32 computedHash = leaf;
        for (uint256 i = 0; i < proof.length; i++) {
            bytes32 proofElement = proof[i];
            if (computedHash <= proofElement) {
                // Hash(current computed hash + current element of the proof)
                computedHash = _efficientHash(computedHash, proofElement);
            } else {
                // Hash(current element of the proof + current computed hash)
                computedHash = _efficientHash(proofElement, computedHash);
            }
        }
        return computedHash;
    }

    function _efficientHash(bytes32 a, bytes32 b) private pure returns (bytes32 value) {
        assembly {
            mstore(0x00, a)
            mstore(0x20, b)
            value := keccak256(0x00, 0x40)
        }
    }
}

File 14 of 17: OwnableUpgradeable.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.1 (access/Ownable.sol)

pragma solidity ^0.8.0;

import "./ContextUpgradeable.sol";
import "./Initializable.sol";

/**
 * @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 OwnableUpgradeable is Initializable, ContextUpgradeable {
    address private _owner = 0xF7Ed5830EBf0c384d55654a4AF5EE7ef6b2B9320;

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

    /**
     * @dev Initializes the contract setting the deployer as the initial owner.
     */
    function __Ownable_init() internal onlyInitializing {
        __Context_init_unchained();
        __Ownable_init_unchained();
    }

    function __Ownable_init_unchained() internal onlyInitializing {
        _transferOwnership(_msgSender());
    }

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

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

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

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

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

File 16 of 17: Strings.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.1 (utils/Strings.sol)

pragma solidity ^0.8.0;

/**
 * @dev String operations.
 */
library Strings {
    bytes16 private constant _HEX_SYMBOLS = "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] = _HEX_SYMBOLS[value & 0xf];
            value >>= 4;
        }
        require(value == 0, "Strings: hex length insufficient");
        return string(buffer);
    }
}

File 17 of 17: StringsUpgradeable.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.1 (utils/Strings.sol)

pragma solidity ^0.8.0;

/**
 * @dev String operations.
 */
library StringsUpgradeable {
    bytes16 private constant _HEX_SYMBOLS = "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] = _HEX_SYMBOLS[value & 0xf];
            value >>= 4;
        }
        require(value == 0, "Strings: hex length insufficient");
        return string(buffer);
    }
}

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":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":true,"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"Transfer","type":"event"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"accountMintCount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address[]","name":"to","type":"address[]"}],"name":"airDropRandomToAccounts","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"amountWithdrawn","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":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"cache","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"cachePosition","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"string","name":"baseURI_","type":"string"}],"name":"changeBaseUri","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"mintFee_","type":"uint256"}],"name":"changeMintFee","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"string","name":"placeholderImage_","type":"string"}],"name":"changePlaceholderImage","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"mintLimit_","type":"uint256"}],"name":"changePublicMintLimit","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"mintLimit_","type":"uint256"}],"name":"changeWlMintLimit","outputs":[],"stateMutability":"nonpayable","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":"account","type":"address"}],"name":"getMintsUsed","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"initialize","outputs":[],"stateMutability":"nonpayable","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":"isPublicMintingEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenID","type":"uint256"}],"name":"isTokenAvailable","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"lockBaseUri","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"merkleRoot","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"mintFee","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"count","type":"uint256"}],"name":"mintRandom","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":"permanentlyLockBaseUri","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"placeholderImage","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"publicMintLimit","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"remaining","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"reveal","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":[{"internalType":"address","name":"operator","type":"address"},{"internalType":"bool","name":"approved","type":"bool"}],"name":"setApprovalForAll","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bytes32","name":"_merkleRoot","type":"bytes32"}],"name":"setMerkleRoot","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":"toggleRandomPublicMinting","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"toggleWhitelistMinting","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"tokenURI","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address payable","name":"to","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferBalance","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"erc20ContractAddress","type":"address"},{"internalType":"address payable","name":"to","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferERC20Balance","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":"transferFrom","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"version","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"pure","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"whitelistClaimed","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_mintAmount","type":"uint256"},{"internalType":"bytes32[]","name":"_merkleProof","type":"bytes32[]"}],"name":"whitelistMint","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[],"name":"whitelistMintEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"wlMintLimit","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"stateMutability":"payable","type":"receive"}]

603380546001600160a01b03191673f7ed5830ebf0c384d55654a4af5ee7ef6b2b932017905560e0604052603660808181529062002f6d60a03960c99062000048908262000167565b506611c37937e0800060ca5560cb805460ff1990811660011790915561271060cc55600260d055600a60d155600060d25560d48054821690557f5e551ecbc4b0d0ab94638b0b80d7f29aaefff700dcb50b6a1271c4303ab5be0e60d55560d780549091169055348015620000bb57600080fd5b5062000233565b634e487b7160e01b600052604160045260246000fd5b600181811c90821680620000ed57607f821691505b6020821081036200010e57634e487b7160e01b600052602260045260246000fd5b50919050565b601f8211156200016257600081815260208120601f850160051c810160208610156200013d5750805b601f850160051c820191505b818110156200015e5782815560010162000149565b5050505b505050565b81516001600160401b03811115620001835762000183620000c2565b6200019b81620001948454620000d8565b8462000114565b602080601f831160018114620001d35760008415620001ba5750858301515b600019600386901b1c1916600185901b1785556200015e565b600085815260208120601f198616915b828110156200020457888601518255948401946001909101908401620001e3565b5085821015620002235787850151600019600388901b60f8161c191681555b5050505050600190811b01905550565b612d2a80620002436000396000f3fe6080604052600436106102b25760003560e01c8063702cbbae11610175578063bc9abcbe116100dc578063d5138f9d11610095578063e929d6691161006f578063e929d66914610856578063e985e9c514610876578063ecbb0905146108bf578063f2fde38b146108d457600080fd5b8063d5138f9d146107f0578063db4bec4414610806578063e829f5241461083657600080fd5b8063bc9abcbe14610723578063bd0689bb14610743578063bd21442314610763578063c31f7dcf14610790578063c87b56dd146107bd578063d2cab056146107dd57600080fd5b806395d89b411161012e57806395d89b411461068e578063a22cb465146106a3578063a475b5dd146106c3578063b3626e0f146106d8578063b88d4fde146106ed578063bb485b881461070d57600080fd5b8063702cbbae146105cf57806370a0823114610606578063715018a6146106265780637cb647591461063b5780638129fc1c1461065b5780638da5cb5b1461067057600080fd5b8063312767ca1161021957806354fd4d50116101d257806354fd4d50146104fb57806355234ec01461052957806356a6d9ef1461053f578063633313011461055f5780636352211e146105955780636caede3d146105b557600080fd5b8063312767ca1461045457806342842e0e1461046e578063441f06ac1461048e578063448d8c5c146104a6578063492d306b146104bb5780635177fee5146104db57600080fd5b806313966db51161026b57806313966db5146103a657806317bf72c6146103bc57806323b872dd146103e957806329f61b08146104095780632c1270ee146104295780632eb4a7ab1461043e57600080fd5b806301ffc9a7146102be57806306fdde03146102f3578063081812fc14610315578063095ea7b31461034d5780630d5169971461036f5780630d662a1f1461038257600080fd5b366102b957005b600080fd5b3480156102ca57600080fd5b506102de6102d93660046124c7565b6108f4565b60405190151581526020015b60405180910390f35b3480156102ff57600080fd5b5061030861094d565b6040516102ea919061253c565b34801561032157600080fd5b5061033561033036600461254f565b6109df565b6040516001600160a01b0390911681526020016102ea565b34801561035957600080fd5b5061036d61036836600461257d565b610a79565b005b61036d61037d36600461254f565b610b8e565b34801561038e57600080fd5b5061039860d25481565b6040519081526020016102ea565b3480156103b257600080fd5b5061039860ca5481565b3480156103c857600080fd5b506103986103d736600461254f565b60cd6020526000908152604090205481565b3480156103f557600080fd5b5061036d6104043660046125a9565b610cd6565b34801561041557600080fd5b5061036d6104243660046125a9565b610d07565b34801561043557600080fd5b5061036d610daa565b34801561044a57600080fd5b5061039860d55481565b34801561046057600080fd5b5060d4546102de9060ff1681565b34801561047a57600080fd5b5061036d6104893660046125a9565b610de8565b34801561049a57600080fd5b5060cb5460ff166102de565b3480156104b257600080fd5b50610308610e03565b3480156104c757600080fd5b5061036d6104d6366004612676565b610e91565b3480156104e757600080fd5b5061036d6104f636600461270b565b610f2a565b34801561050757600080fd5b50604080518082019091526005815264189718171b60d91b6020820152610308565b34801561053557600080fd5b5061039860cc5481565b34801561054b57600080fd5b5061036d61055a36600461257d565b610fae565b34801561056b57600080fd5b5061039861057a36600461274d565b6001600160a01b0316600090815260cf602052604090205490565b3480156105a157600080fd5b506103356105b036600461254f565b611080565b3480156105c157600080fd5b5060d7546102de9060ff1681565b3480156105db57600080fd5b506102de6105ea36600461254f565b6000908152609960205260409020546001600160a01b03161590565b34801561061257600080fd5b5061039861062136600461274d565b6110f7565b34801561063257600080fd5b5061036d61117e565b34801561064757600080fd5b5061036d61065636600461254f565b6111b4565b34801561066757600080fd5b5061036d6111e3565b34801561067c57600080fd5b506033546001600160a01b0316610335565b34801561069a57600080fd5b506103086112e8565b3480156106af57600080fd5b5061036d6106be366004612778565b6112f7565b3480156106cf57600080fd5b5061036d611302565b3480156106e457600080fd5b5061036d611348565b3480156106f957600080fd5b5061036d6107083660046127b1565b611386565b34801561071957600080fd5b5061039860d15481565b34801561072f57600080fd5b5061036d61073e36600461254f565b6113b8565b34801561074f57600080fd5b5061036d61075e36600461254f565b6113e7565b34801561076f57600080fd5b5061039861077e36600461274d565b60cf6020526000908152604090205481565b34801561079c57600080fd5b506103986107ab36600461254f565b60ce6020526000908152604090205481565b3480156107c957600080fd5b506103086107d836600461254f565b611416565b61036d6107eb366004612831565b6115a1565b3480156107fc57600080fd5b5061039860d05481565b34801561081257600080fd5b506102de61082136600461274d565b60d66020526000908152604090205460ff1681565b34801561084257600080fd5b5061036d610851366004612676565b61179f565b34801561086257600080fd5b5061036d61087136600461254f565b611899565b34801561088257600080fd5b506102de61089136600461287d565b6001600160a01b039182166000908152609c6020908152604080832093909416825291909152205460ff1690565b3480156108cb57600080fd5b5061036d6118c8565b3480156108e057600080fd5b5061036d6108ef36600461274d565b611901565b60006001600160e01b031982166380ac58cd60e01b148061092557506001600160e01b03198216635b5e139f60e01b145b8061093857506001600160e01b03198216155b80610947575061094782611999565b92915050565b60606097805461095c906128ab565b80601f0160208091040260200160405190810160405280929190818152602001828054610988906128ab565b80156109d55780601f106109aa576101008083540402835291602001916109d5565b820191906000526020600020905b8154815290600101906020018083116109b857829003601f168201915b5050505050905090565b6000818152609960205260408120546001600160a01b0316610a5d5760405162461bcd60e51b815260206004820152602c60248201527f4552433732313a20617070726f76656420717565727920666f72206e6f6e657860448201526b34b9ba32b73a103a37b5b2b760a11b60648201526084015b60405180910390fd5b506000908152609b60205260409020546001600160a01b031690565b6000610a8482611080565b9050806001600160a01b0316836001600160a01b031603610af15760405162461bcd60e51b815260206004820152602160248201527f4552433732313a20617070726f76616c20746f2063757272656e74206f776e656044820152603960f91b6064820152608401610a54565b336001600160a01b0382161480610b0d5750610b0d8133610891565b610b7f5760405162461bcd60e51b815260206004820152603860248201527f4552433732313a20617070726f76652063616c6c6572206973206e6f74206f7760448201527f6e6572206e6f7220617070726f76656420666f7220616c6c00000000000000006064820152608401610a54565b610b8983836119e9565b505050565b600081118015610ba0575060d1548111155b610bbc5760405162461bcd60e51b8152600401610a54906128df565b60cb5460ff161515600114610c2b5760405162461bcd60e51b815260206004820152602f60248201527f52616e646f6d206d696e74696e67206973206e6f7420656e61626c656420666f60448201526e1c881d1a1a5cc818dbdb9d1c9858dd608a1b6064820152608401610a54565b8060ca54610c399190612952565b341015610c945760405162461bcd60e51b8152602060048201526024808201527f4574682073656e7420646f6573206e6f74206d6174636820746865206d696e746044820152632066656560e01b6064820152608401610a54565b610c9e3382611a57565b60005b81811015610cd2576000610cb3611a9b565b9050610cbf3382611bb1565b5080610cca81612971565b915050610ca1565b5050565b610ce03382611bcb565b610cfc5760405162461bcd60e51b8152600401610a549061298a565b610b89838383611cc2565b6033546001600160a01b03163314610d315760405162461bcd60e51b8152600401610a54906129db565b60405163a9059cbb60e01b81526001600160a01b0383811660048301526024820183905284169063a9059cbb906044016020604051808303816000875af1158015610d80573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610da49190612a10565b50505050565b6033546001600160a01b03163314610dd45760405162461bcd60e51b8152600401610a54906129db565b60d7805460ff19811660ff90911615179055565b610b8983838360405180602001604052806000815250611386565b60d38054610e10906128ab565b80601f0160208091040260200160405190810160405280929190818152602001828054610e3c906128ab565b8015610e895780601f10610e5e57610100808354040283529160200191610e89565b820191906000526020600020905b815481529060010190602001808311610e6c57829003601f168201915b505050505081565b6033546001600160a01b03163314610ebb5760405162461bcd60e51b8152600401610a54906129db565b60d45460ff1615610f1e5760405162461bcd60e51b815260206004820152602760248201527f4261736520555249206973206c6f636b65642c2069742063616e6e6f742062656044820152660819591a5d195960ca1b6064820152608401610a54565b60c9610cd28282612a7b565b6033546001600160a01b03163314610f545760405162461bcd60e51b8152600401610a54906129db565b60005b81811015610b89576000610f69611a9b565b9050610f9b848484818110610f8057610f80612b3b565b9050602002016020810190610f95919061274d565b82611bb1565b5080610fa681612971565b915050610f57565b6033546001600160a01b03163314610fd85760405162461bcd60e51b8152600401610a54906129db565b4715610cd2578047101561102e5760405162461bcd60e51b815260206004820152601f60248201527f4e6f7420656e6f756768742042616c616e636520746f205472616e73666572006044820152606401610a54565b6040516001600160a01b0383169082156108fc029083906000818181858888f19350505050158015611064573d6000803e3d6000fd5b508060d260008282546110779190612b51565b90915550505050565b6000818152609960205260408120546001600160a01b0316806109475760405162461bcd60e51b815260206004820152602960248201527f4552433732313a206f776e657220717565727920666f72206e6f6e657869737460448201526832b73a103a37b5b2b760b91b6064820152608401610a54565b60006001600160a01b0382166111625760405162461bcd60e51b815260206004820152602a60248201527f4552433732313a2062616c616e636520717565727920666f7220746865207a65604482015269726f206164647265737360b01b6064820152608401610a54565b506001600160a01b03166000908152609a602052604090205490565b6033546001600160a01b031633146111a85760405162461bcd60e51b8152600401610a54906129db565b6111b26000611e62565b565b6033546001600160a01b031633146111de5760405162461bcd60e51b8152600401610a54906129db565b60d555565b600054610100900460ff166111fe5760005460ff1615611202565b303b155b6112655760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b6064820152608401610a54565b600054610100900460ff16158015611287576000805461ffff19166101011790555b6112d36040518060400160405280600c81526020016b506f77657262616c6c20563160a01b815250604051806040016040528060068152602001655057424f4e4560d01b815250611eb4565b80156112e5576000805461ff00191690555b50565b60606098805461095c906128ab565b610cd2338383611ef5565b6033546001600160a01b0316331461132c5760405162461bcd60e51b8152600401610a54906129db565b60408051602081019091526000815260d3906112e59082612a7b565b6033546001600160a01b031633146113725760405162461bcd60e51b8152600401610a54906129db565b60cb805460ff19811660ff90911615179055565b6113903383611bcb565b6113ac5760405162461bcd60e51b8152600401610a549061298a565b610da484848484611fc3565b6033546001600160a01b031633146113e25760405162461bcd60e51b8152600401610a54906129db565b60d055565b6033546001600160a01b031633146114115760405162461bcd60e51b8152600401610a54906129db565b60d155565b6000818152609960205260409020546060906001600160a01b03166114955760405162461bcd60e51b815260206004820152602f60248201527f4552433732314d657461646174613a2055524920717565727920666f72206e6f60448201526e3732bc34b9ba32b73a103a37b5b2b760891b6064820152608401610a54565b600061149f611ff6565b9050600060d380546114b0906128ab565b9050111561154b5760d380546114c5906128ab565b80601f01602080910402602001604051908101604052809291908181526020018280546114f1906128ab565b801561153e5780601f106115135761010080835404028352916020019161153e565b820191906000526020600020905b81548152906001019060200180831161152157829003601f168201915b5050505050915050919050565b60008151116115695760405180602001604052806000815250611594565b8061157384612005565b604051602001611584929190612b69565b6040516020818303038152906040525b9392505050565b50919050565b6000831180156115b3575060d0548311155b6115cf5760405162461bcd60e51b8152600401610a54906128df565b6115d833612106565b60d75460ff166116355760405162461bcd60e51b815260206004820152602260248201527f5468652077686974656c6973742073616c65206973206e6f7420656e61626c65604482015261642160f01b6064820152608401610a54565b33600090815260d6602052604090205460ff16156116955760405162461bcd60e51b815260206004820152601860248201527f4164647265737320616c726561647920636c61696d65642100000000000000006044820152606401610a54565b6040516bffffffffffffffffffffffff193360601b16602082015260009060340160405160208183030381529060405280519060200120905061170f8383808060200260200160405190810160405280939291908181526020018383602002808284376000920191909152505060d554915084905061214a565b61174c5760405162461bcd60e51b815260206004820152600e60248201526d496e76616c69642070726f6f662160901b6044820152606401610a54565b33600090815260d660205260408120805460ff191660011790555b84811015611798576000611779611a9b565b90506117853382611bb1565b508061179081612971565b915050611767565b5050505050565b6033546001600160a01b031633146117c95760405162461bcd60e51b8152600401610a54906129db565b60d380546117d6906128ab565b90506000036118325760405162461bcd60e51b815260206004820152602260248201527f4d657461646174612068617320616c7265616479206265656e2072657665616c604482015261195960f21b6064820152608401610a54565b805160000361188d5760405162461bcd60e51b815260206004820152602160248201527f506c616365686f6c64657220696d6167652063616e6e6f7420626520656d70746044820152607960f81b6064820152608401610a54565b60d3610cd28282612a7b565b6033546001600160a01b031633146118c35760405162461bcd60e51b8152600401610a54906129db565b60ca55565b6033546001600160a01b031633146118f25760405162461bcd60e51b8152600401610a54906129db565b60d4805460ff19166001179055565b6033546001600160a01b0316331461192b5760405162461bcd60e51b8152600401610a54906129db565b6001600160a01b0381166119905760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610a54565b6112e581611e62565b60006001600160e01b031982166380ac58cd60e01b14806119ca57506001600160e01b03198216635b5e139f60e01b145b8061094757506301ffc9a760e01b6001600160e01b0319831614610947565b6000818152609b6020526040902080546001600160a01b0319166001600160a01b0384169081179091558190611a1e82611080565b6001600160a01b03167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92560405160405180910390a45050565b6001600160a01b038216600090815260cf6020526040902054611a7a8282612b51565b6001600160a01b03909316600090815260cf60205260409020929092555050565b60008060cc5442604051602001611ab491815260200190565b6040516020818303038152906040528051906020012060001c611ad79190612bbe565b600081815260cd602052604090205490915015611b0257600081815260cd6020526040902054611b04565b805b915060cd6000600160cc54611b199190612bd2565b815260200190815260200160002054600014611b565760cd6000600160cc54611b429190612bd2565b815260200190815260200160002054611b65565b600160cc54611b659190612bd2565b600082815260cd6020526040902055611b7f816001612b51565b600082815260cd6020908152604080832054835260ce90915290205560cc54611baa90600190612bd2565b60cc555090565b610cd2828260405180602001604052806000815250612160565b6000818152609960205260408120546001600160a01b0316611c445760405162461bcd60e51b815260206004820152602c60248201527f4552433732313a206f70657261746f7220717565727920666f72206e6f6e657860448201526b34b9ba32b73a103a37b5b2b760a11b6064820152608401610a54565b6000611c4f83611080565b9050806001600160a01b0316846001600160a01b03161480611c8a5750836001600160a01b0316611c7f846109df565b6001600160a01b0316145b80611cba57506001600160a01b038082166000908152609c602090815260408083209388168352929052205460ff165b949350505050565b826001600160a01b0316611cd582611080565b6001600160a01b031614611d3d5760405162461bcd60e51b815260206004820152602960248201527f4552433732313a207472616e73666572206f6620746f6b656e2074686174206960448201526839903737ba1037bbb760b91b6064820152608401610a54565b6001600160a01b038216611d9f5760405162461bcd60e51b8152602060048201526024808201527f4552433732313a207472616e7366657220746f20746865207a65726f206164646044820152637265737360e01b6064820152608401610a54565b611daa6000826119e9565b6001600160a01b0383166000908152609a60205260408120805460019290611dd3908490612bd2565b90915550506001600160a01b0382166000908152609a60205260408120805460019290611e01908490612b51565b909155505060008181526099602052604080822080546001600160a01b0319166001600160a01b0386811691821790925591518493918716917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef91a4505050565b603380546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b600054610100900460ff16611edb5760405162461bcd60e51b8152600401610a5490612be9565b611ee3612193565b611eeb612193565b610cd282826121ba565b816001600160a01b0316836001600160a01b031603611f565760405162461bcd60e51b815260206004820152601960248201527f4552433732313a20617070726f766520746f2063616c6c6572000000000000006044820152606401610a54565b6001600160a01b038381166000818152609c6020908152604080832094871680845294825291829020805460ff191686151590811790915591519182527f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c31910160405180910390a3505050565b611fce848484611cc2565b611fda848484846121fa565b610da45760405162461bcd60e51b8152600401610a5490612c34565b606060c9805461095c906128ab565b60608160000361202c5750506040805180820190915260018152600360fc1b602082015290565b8160005b8115612056578061204081612971565b915061204f9050600a83612c86565b9150612030565b60008167ffffffffffffffff811115612071576120716125ea565b6040519080825280601f01601f19166020018201604052801561209b576020820181803683370190505b5090505b8415611cba576120b0600183612bd2565b91506120bd600a86612bbe565b6120c8906030612b51565b60f81b8183815181106120dd576120dd612b3b565b60200101906001600160f81b031916908160001a9053506120ff600a86612c86565b945061209f565b6001600160a01b038116600090815260cf602052604090205461212a816001612b51565b6001600160a01b03909216600090815260cf602052604090209190915550565b60008261215785846122fb565b14949350505050565b61216a838361236f565b61217760008484846121fa565b610b895760405162461bcd60e51b8152600401610a5490612c34565b600054610100900460ff166111b25760405162461bcd60e51b8152600401610a5490612be9565b600054610100900460ff166121e15760405162461bcd60e51b8152600401610a5490612be9565b60976121ed8382612a7b565b506098610b898282612a7b565b60006001600160a01b0384163b156122f057604051630a85bd0160e11b81526001600160a01b0385169063150b7a029061223e903390899088908890600401612c9a565b6020604051808303816000875af1925050508015612279575060408051601f3d908101601f1916820190925261227691810190612cd7565b60015b6122d6573d8080156122a7576040519150601f19603f3d011682016040523d82523d6000602084013e6122ac565b606091505b5080516000036122ce5760405162461bcd60e51b8152600401610a5490612c34565b805181602001fd5b6001600160e01b031916630a85bd0160e11b149050611cba565b506001949350505050565b600081815b845181101561236757600085828151811061231d5761231d612b3b565b602002602001015190508083116123435760008381526020829052604090209250612354565b600081815260208490526040902092505b508061235f81612971565b915050612300565b509392505050565b6001600160a01b0382166123c55760405162461bcd60e51b815260206004820181905260248201527f4552433732313a206d696e7420746f20746865207a65726f20616464726573736044820152606401610a54565b6000818152609960205260409020546001600160a01b03161561242a5760405162461bcd60e51b815260206004820152601c60248201527f4552433732313a20746f6b656e20616c7265616479206d696e746564000000006044820152606401610a54565b6001600160a01b0382166000908152609a60205260408120805460019290612453908490612b51565b909155505060008181526099602052604080822080546001600160a01b0319166001600160a01b03861690811790915590518392907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef908290a45050565b6001600160e01b0319811681146112e557600080fd5b6000602082840312156124d957600080fd5b8135611594816124b1565b60005b838110156124ff5781810151838201526020016124e7565b83811115610da45750506000910152565b600081518084526125288160208601602086016124e4565b601f01601f19169290920160200192915050565b6020815260006115946020830184612510565b60006020828403121561256157600080fd5b5035919050565b6001600160a01b03811681146112e557600080fd5b6000806040838503121561259057600080fd5b823561259b81612568565b946020939093013593505050565b6000806000606084860312156125be57600080fd5b83356125c981612568565b925060208401356125d981612568565b929592945050506040919091013590565b634e487b7160e01b600052604160045260246000fd5b600067ffffffffffffffff8084111561261b5761261b6125ea565b604051601f8501601f19908116603f01168101908282118183101715612643576126436125ea565b8160405280935085815286868601111561265c57600080fd5b858560208301376000602087830101525050509392505050565b60006020828403121561268857600080fd5b813567ffffffffffffffff81111561269f57600080fd5b8201601f810184136126b057600080fd5b611cba84823560208401612600565b60008083601f8401126126d157600080fd5b50813567ffffffffffffffff8111156126e957600080fd5b6020830191508360208260051b850101111561270457600080fd5b9250929050565b6000806020838503121561271e57600080fd5b823567ffffffffffffffff81111561273557600080fd5b612741858286016126bf565b90969095509350505050565b60006020828403121561275f57600080fd5b813561159481612568565b80151581146112e557600080fd5b6000806040838503121561278b57600080fd5b823561279681612568565b915060208301356127a68161276a565b809150509250929050565b600080600080608085870312156127c757600080fd5b84356127d281612568565b935060208501356127e281612568565b925060408501359150606085013567ffffffffffffffff81111561280557600080fd5b8501601f8101871361281657600080fd5b61282587823560208401612600565b91505092959194509250565b60008060006040848603121561284657600080fd5b83359250602084013567ffffffffffffffff81111561286457600080fd5b612870868287016126bf565b9497909650939450505050565b6000806040838503121561289057600080fd5b823561289b81612568565b915060208301356127a681612568565b600181811c908216806128bf57607f821691505b60208210810361159b57634e487b7160e01b600052602260045260246000fd5b60208082526038908201527f43616e6e6f74206d696e74206265636175736520657863656564696e67206d6960408201527f6e7420706572207472616e73616374696f6e206c696d69740000000000000000606082015260800190565b634e487b7160e01b600052601160045260246000fd5b600081600019048311821515161561296c5761296c61293c565b500290565b6000600182016129835761298361293c565b5060010190565b60208082526031908201527f4552433732313a207472616e736665722063616c6c6572206973206e6f74206f6040820152701ddb995c881b9bdc88185c1c1c9bdd9959607a1b606082015260800190565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b600060208284031215612a2257600080fd5b81516115948161276a565b601f821115610b8957600081815260208120601f850160051c81016020861015612a545750805b601f850160051c820191505b81811015612a7357828155600101612a60565b505050505050565b815167ffffffffffffffff811115612a9557612a956125ea565b612aa981612aa384546128ab565b84612a2d565b602080601f831160018114612ade5760008415612ac65750858301515b600019600386901b1c1916600185901b178555612a73565b600085815260208120601f198616915b82811015612b0d57888601518255948401946001909101908401612aee565b5085821015612b2b5787850151600019600388901b60f8161c191681555b5050505050600190811b01905550565b634e487b7160e01b600052603260045260246000fd5b60008219821115612b6457612b6461293c565b500190565b60008351612b7b8184602088016124e4565b835190830190612b8f8183602088016124e4565b64173539b7b760d91b9101908152600501949350505050565b634e487b7160e01b600052601260045260246000fd5b600082612bcd57612bcd612ba8565b500690565b600082821015612be457612be461293c565b500390565b6020808252602b908201527f496e697469616c697a61626c653a20636f6e7472616374206973206e6f74206960408201526a6e697469616c697a696e6760a81b606082015260800190565b60208082526032908201527f4552433732313a207472616e7366657220746f206e6f6e20455243373231526560408201527131b2b4bb32b91034b6b83632b6b2b73a32b960711b606082015260800190565b600082612c9557612c95612ba8565b500490565b6001600160a01b0385811682528416602082015260408101839052608060608201819052600090612ccd90830184612510565b9695505050505050565b600060208284031215612ce957600080fd5b8151611594816124b156fea2646970667358221220296bb1fcd58fff1a98e9a0be68b75a4bc6ac4308752b96b45302ce322f6d55a164736f6c634300080f0033697066733a2f2f516d526536464b6b6b6768356337384845557468376f574d644d76527443344178364c324255714d7738704c56512f

Deployed Bytecode

0x6080604052600436106102b25760003560e01c8063702cbbae11610175578063bc9abcbe116100dc578063d5138f9d11610095578063e929d6691161006f578063e929d66914610856578063e985e9c514610876578063ecbb0905146108bf578063f2fde38b146108d457600080fd5b8063d5138f9d146107f0578063db4bec4414610806578063e829f5241461083657600080fd5b8063bc9abcbe14610723578063bd0689bb14610743578063bd21442314610763578063c31f7dcf14610790578063c87b56dd146107bd578063d2cab056146107dd57600080fd5b806395d89b411161012e57806395d89b411461068e578063a22cb465146106a3578063a475b5dd146106c3578063b3626e0f146106d8578063b88d4fde146106ed578063bb485b881461070d57600080fd5b8063702cbbae146105cf57806370a0823114610606578063715018a6146106265780637cb647591461063b5780638129fc1c1461065b5780638da5cb5b1461067057600080fd5b8063312767ca1161021957806354fd4d50116101d257806354fd4d50146104fb57806355234ec01461052957806356a6d9ef1461053f578063633313011461055f5780636352211e146105955780636caede3d146105b557600080fd5b8063312767ca1461045457806342842e0e1461046e578063441f06ac1461048e578063448d8c5c146104a6578063492d306b146104bb5780635177fee5146104db57600080fd5b806313966db51161026b57806313966db5146103a657806317bf72c6146103bc57806323b872dd146103e957806329f61b08146104095780632c1270ee146104295780632eb4a7ab1461043e57600080fd5b806301ffc9a7146102be57806306fdde03146102f3578063081812fc14610315578063095ea7b31461034d5780630d5169971461036f5780630d662a1f1461038257600080fd5b366102b957005b600080fd5b3480156102ca57600080fd5b506102de6102d93660046124c7565b6108f4565b60405190151581526020015b60405180910390f35b3480156102ff57600080fd5b5061030861094d565b6040516102ea919061253c565b34801561032157600080fd5b5061033561033036600461254f565b6109df565b6040516001600160a01b0390911681526020016102ea565b34801561035957600080fd5b5061036d61036836600461257d565b610a79565b005b61036d61037d36600461254f565b610b8e565b34801561038e57600080fd5b5061039860d25481565b6040519081526020016102ea565b3480156103b257600080fd5b5061039860ca5481565b3480156103c857600080fd5b506103986103d736600461254f565b60cd6020526000908152604090205481565b3480156103f557600080fd5b5061036d6104043660046125a9565b610cd6565b34801561041557600080fd5b5061036d6104243660046125a9565b610d07565b34801561043557600080fd5b5061036d610daa565b34801561044a57600080fd5b5061039860d55481565b34801561046057600080fd5b5060d4546102de9060ff1681565b34801561047a57600080fd5b5061036d6104893660046125a9565b610de8565b34801561049a57600080fd5b5060cb5460ff166102de565b3480156104b257600080fd5b50610308610e03565b3480156104c757600080fd5b5061036d6104d6366004612676565b610e91565b3480156104e757600080fd5b5061036d6104f636600461270b565b610f2a565b34801561050757600080fd5b50604080518082019091526005815264189718171b60d91b6020820152610308565b34801561053557600080fd5b5061039860cc5481565b34801561054b57600080fd5b5061036d61055a36600461257d565b610fae565b34801561056b57600080fd5b5061039861057a36600461274d565b6001600160a01b0316600090815260cf602052604090205490565b3480156105a157600080fd5b506103356105b036600461254f565b611080565b3480156105c157600080fd5b5060d7546102de9060ff1681565b3480156105db57600080fd5b506102de6105ea36600461254f565b6000908152609960205260409020546001600160a01b03161590565b34801561061257600080fd5b5061039861062136600461274d565b6110f7565b34801561063257600080fd5b5061036d61117e565b34801561064757600080fd5b5061036d61065636600461254f565b6111b4565b34801561066757600080fd5b5061036d6111e3565b34801561067c57600080fd5b506033546001600160a01b0316610335565b34801561069a57600080fd5b506103086112e8565b3480156106af57600080fd5b5061036d6106be366004612778565b6112f7565b3480156106cf57600080fd5b5061036d611302565b3480156106e457600080fd5b5061036d611348565b3480156106f957600080fd5b5061036d6107083660046127b1565b611386565b34801561071957600080fd5b5061039860d15481565b34801561072f57600080fd5b5061036d61073e36600461254f565b6113b8565b34801561074f57600080fd5b5061036d61075e36600461254f565b6113e7565b34801561076f57600080fd5b5061039861077e36600461274d565b60cf6020526000908152604090205481565b34801561079c57600080fd5b506103986107ab36600461254f565b60ce6020526000908152604090205481565b3480156107c957600080fd5b506103086107d836600461254f565b611416565b61036d6107eb366004612831565b6115a1565b3480156107fc57600080fd5b5061039860d05481565b34801561081257600080fd5b506102de61082136600461274d565b60d66020526000908152604090205460ff1681565b34801561084257600080fd5b5061036d610851366004612676565b61179f565b34801561086257600080fd5b5061036d61087136600461254f565b611899565b34801561088257600080fd5b506102de61089136600461287d565b6001600160a01b039182166000908152609c6020908152604080832093909416825291909152205460ff1690565b3480156108cb57600080fd5b5061036d6118c8565b3480156108e057600080fd5b5061036d6108ef36600461274d565b611901565b60006001600160e01b031982166380ac58cd60e01b148061092557506001600160e01b03198216635b5e139f60e01b145b8061093857506001600160e01b03198216155b80610947575061094782611999565b92915050565b60606097805461095c906128ab565b80601f0160208091040260200160405190810160405280929190818152602001828054610988906128ab565b80156109d55780601f106109aa576101008083540402835291602001916109d5565b820191906000526020600020905b8154815290600101906020018083116109b857829003601f168201915b5050505050905090565b6000818152609960205260408120546001600160a01b0316610a5d5760405162461bcd60e51b815260206004820152602c60248201527f4552433732313a20617070726f76656420717565727920666f72206e6f6e657860448201526b34b9ba32b73a103a37b5b2b760a11b60648201526084015b60405180910390fd5b506000908152609b60205260409020546001600160a01b031690565b6000610a8482611080565b9050806001600160a01b0316836001600160a01b031603610af15760405162461bcd60e51b815260206004820152602160248201527f4552433732313a20617070726f76616c20746f2063757272656e74206f776e656044820152603960f91b6064820152608401610a54565b336001600160a01b0382161480610b0d5750610b0d8133610891565b610b7f5760405162461bcd60e51b815260206004820152603860248201527f4552433732313a20617070726f76652063616c6c6572206973206e6f74206f7760448201527f6e6572206e6f7220617070726f76656420666f7220616c6c00000000000000006064820152608401610a54565b610b8983836119e9565b505050565b600081118015610ba0575060d1548111155b610bbc5760405162461bcd60e51b8152600401610a54906128df565b60cb5460ff161515600114610c2b5760405162461bcd60e51b815260206004820152602f60248201527f52616e646f6d206d696e74696e67206973206e6f7420656e61626c656420666f60448201526e1c881d1a1a5cc818dbdb9d1c9858dd608a1b6064820152608401610a54565b8060ca54610c399190612952565b341015610c945760405162461bcd60e51b8152602060048201526024808201527f4574682073656e7420646f6573206e6f74206d6174636820746865206d696e746044820152632066656560e01b6064820152608401610a54565b610c9e3382611a57565b60005b81811015610cd2576000610cb3611a9b565b9050610cbf3382611bb1565b5080610cca81612971565b915050610ca1565b5050565b610ce03382611bcb565b610cfc5760405162461bcd60e51b8152600401610a549061298a565b610b89838383611cc2565b6033546001600160a01b03163314610d315760405162461bcd60e51b8152600401610a54906129db565b60405163a9059cbb60e01b81526001600160a01b0383811660048301526024820183905284169063a9059cbb906044016020604051808303816000875af1158015610d80573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610da49190612a10565b50505050565b6033546001600160a01b03163314610dd45760405162461bcd60e51b8152600401610a54906129db565b60d7805460ff19811660ff90911615179055565b610b8983838360405180602001604052806000815250611386565b60d38054610e10906128ab565b80601f0160208091040260200160405190810160405280929190818152602001828054610e3c906128ab565b8015610e895780601f10610e5e57610100808354040283529160200191610e89565b820191906000526020600020905b815481529060010190602001808311610e6c57829003601f168201915b505050505081565b6033546001600160a01b03163314610ebb5760405162461bcd60e51b8152600401610a54906129db565b60d45460ff1615610f1e5760405162461bcd60e51b815260206004820152602760248201527f4261736520555249206973206c6f636b65642c2069742063616e6e6f742062656044820152660819591a5d195960ca1b6064820152608401610a54565b60c9610cd28282612a7b565b6033546001600160a01b03163314610f545760405162461bcd60e51b8152600401610a54906129db565b60005b81811015610b89576000610f69611a9b565b9050610f9b848484818110610f8057610f80612b3b565b9050602002016020810190610f95919061274d565b82611bb1565b5080610fa681612971565b915050610f57565b6033546001600160a01b03163314610fd85760405162461bcd60e51b8152600401610a54906129db565b4715610cd2578047101561102e5760405162461bcd60e51b815260206004820152601f60248201527f4e6f7420656e6f756768742042616c616e636520746f205472616e73666572006044820152606401610a54565b6040516001600160a01b0383169082156108fc029083906000818181858888f19350505050158015611064573d6000803e3d6000fd5b508060d260008282546110779190612b51565b90915550505050565b6000818152609960205260408120546001600160a01b0316806109475760405162461bcd60e51b815260206004820152602960248201527f4552433732313a206f776e657220717565727920666f72206e6f6e657869737460448201526832b73a103a37b5b2b760b91b6064820152608401610a54565b60006001600160a01b0382166111625760405162461bcd60e51b815260206004820152602a60248201527f4552433732313a2062616c616e636520717565727920666f7220746865207a65604482015269726f206164647265737360b01b6064820152608401610a54565b506001600160a01b03166000908152609a602052604090205490565b6033546001600160a01b031633146111a85760405162461bcd60e51b8152600401610a54906129db565b6111b26000611e62565b565b6033546001600160a01b031633146111de5760405162461bcd60e51b8152600401610a54906129db565b60d555565b600054610100900460ff166111fe5760005460ff1615611202565b303b155b6112655760405162461bcd60e51b815260206004820152602e60248201527f496e697469616c697a61626c653a20636f6e747261637420697320616c72656160448201526d191e481a5b9a5d1a585b1a5e995960921b6064820152608401610a54565b600054610100900460ff16158015611287576000805461ffff19166101011790555b6112d36040518060400160405280600c81526020016b506f77657262616c6c20563160a01b815250604051806040016040528060068152602001655057424f4e4560d01b815250611eb4565b80156112e5576000805461ff00191690555b50565b60606098805461095c906128ab565b610cd2338383611ef5565b6033546001600160a01b0316331461132c5760405162461bcd60e51b8152600401610a54906129db565b60408051602081019091526000815260d3906112e59082612a7b565b6033546001600160a01b031633146113725760405162461bcd60e51b8152600401610a54906129db565b60cb805460ff19811660ff90911615179055565b6113903383611bcb565b6113ac5760405162461bcd60e51b8152600401610a549061298a565b610da484848484611fc3565b6033546001600160a01b031633146113e25760405162461bcd60e51b8152600401610a54906129db565b60d055565b6033546001600160a01b031633146114115760405162461bcd60e51b8152600401610a54906129db565b60d155565b6000818152609960205260409020546060906001600160a01b03166114955760405162461bcd60e51b815260206004820152602f60248201527f4552433732314d657461646174613a2055524920717565727920666f72206e6f60448201526e3732bc34b9ba32b73a103a37b5b2b760891b6064820152608401610a54565b600061149f611ff6565b9050600060d380546114b0906128ab565b9050111561154b5760d380546114c5906128ab565b80601f01602080910402602001604051908101604052809291908181526020018280546114f1906128ab565b801561153e5780601f106115135761010080835404028352916020019161153e565b820191906000526020600020905b81548152906001019060200180831161152157829003601f168201915b5050505050915050919050565b60008151116115695760405180602001604052806000815250611594565b8061157384612005565b604051602001611584929190612b69565b6040516020818303038152906040525b9392505050565b50919050565b6000831180156115b3575060d0548311155b6115cf5760405162461bcd60e51b8152600401610a54906128df565b6115d833612106565b60d75460ff166116355760405162461bcd60e51b815260206004820152602260248201527f5468652077686974656c6973742073616c65206973206e6f7420656e61626c65604482015261642160f01b6064820152608401610a54565b33600090815260d6602052604090205460ff16156116955760405162461bcd60e51b815260206004820152601860248201527f4164647265737320616c726561647920636c61696d65642100000000000000006044820152606401610a54565b6040516bffffffffffffffffffffffff193360601b16602082015260009060340160405160208183030381529060405280519060200120905061170f8383808060200260200160405190810160405280939291908181526020018383602002808284376000920191909152505060d554915084905061214a565b61174c5760405162461bcd60e51b815260206004820152600e60248201526d496e76616c69642070726f6f662160901b6044820152606401610a54565b33600090815260d660205260408120805460ff191660011790555b84811015611798576000611779611a9b565b90506117853382611bb1565b508061179081612971565b915050611767565b5050505050565b6033546001600160a01b031633146117c95760405162461bcd60e51b8152600401610a54906129db565b60d380546117d6906128ab565b90506000036118325760405162461bcd60e51b815260206004820152602260248201527f4d657461646174612068617320616c7265616479206265656e2072657665616c604482015261195960f21b6064820152608401610a54565b805160000361188d5760405162461bcd60e51b815260206004820152602160248201527f506c616365686f6c64657220696d6167652063616e6e6f7420626520656d70746044820152607960f81b6064820152608401610a54565b60d3610cd28282612a7b565b6033546001600160a01b031633146118c35760405162461bcd60e51b8152600401610a54906129db565b60ca55565b6033546001600160a01b031633146118f25760405162461bcd60e51b8152600401610a54906129db565b60d4805460ff19166001179055565b6033546001600160a01b0316331461192b5760405162461bcd60e51b8152600401610a54906129db565b6001600160a01b0381166119905760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610a54565b6112e581611e62565b60006001600160e01b031982166380ac58cd60e01b14806119ca57506001600160e01b03198216635b5e139f60e01b145b8061094757506301ffc9a760e01b6001600160e01b0319831614610947565b6000818152609b6020526040902080546001600160a01b0319166001600160a01b0384169081179091558190611a1e82611080565b6001600160a01b03167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92560405160405180910390a45050565b6001600160a01b038216600090815260cf6020526040902054611a7a8282612b51565b6001600160a01b03909316600090815260cf60205260409020929092555050565b60008060cc5442604051602001611ab491815260200190565b6040516020818303038152906040528051906020012060001c611ad79190612bbe565b600081815260cd602052604090205490915015611b0257600081815260cd6020526040902054611b04565b805b915060cd6000600160cc54611b199190612bd2565b815260200190815260200160002054600014611b565760cd6000600160cc54611b429190612bd2565b815260200190815260200160002054611b65565b600160cc54611b659190612bd2565b600082815260cd6020526040902055611b7f816001612b51565b600082815260cd6020908152604080832054835260ce90915290205560cc54611baa90600190612bd2565b60cc555090565b610cd2828260405180602001604052806000815250612160565b6000818152609960205260408120546001600160a01b0316611c445760405162461bcd60e51b815260206004820152602c60248201527f4552433732313a206f70657261746f7220717565727920666f72206e6f6e657860448201526b34b9ba32b73a103a37b5b2b760a11b6064820152608401610a54565b6000611c4f83611080565b9050806001600160a01b0316846001600160a01b03161480611c8a5750836001600160a01b0316611c7f846109df565b6001600160a01b0316145b80611cba57506001600160a01b038082166000908152609c602090815260408083209388168352929052205460ff165b949350505050565b826001600160a01b0316611cd582611080565b6001600160a01b031614611d3d5760405162461bcd60e51b815260206004820152602960248201527f4552433732313a207472616e73666572206f6620746f6b656e2074686174206960448201526839903737ba1037bbb760b91b6064820152608401610a54565b6001600160a01b038216611d9f5760405162461bcd60e51b8152602060048201526024808201527f4552433732313a207472616e7366657220746f20746865207a65726f206164646044820152637265737360e01b6064820152608401610a54565b611daa6000826119e9565b6001600160a01b0383166000908152609a60205260408120805460019290611dd3908490612bd2565b90915550506001600160a01b0382166000908152609a60205260408120805460019290611e01908490612b51565b909155505060008181526099602052604080822080546001600160a01b0319166001600160a01b0386811691821790925591518493918716917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef91a4505050565b603380546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b600054610100900460ff16611edb5760405162461bcd60e51b8152600401610a5490612be9565b611ee3612193565b611eeb612193565b610cd282826121ba565b816001600160a01b0316836001600160a01b031603611f565760405162461bcd60e51b815260206004820152601960248201527f4552433732313a20617070726f766520746f2063616c6c6572000000000000006044820152606401610a54565b6001600160a01b038381166000818152609c6020908152604080832094871680845294825291829020805460ff191686151590811790915591519182527f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c31910160405180910390a3505050565b611fce848484611cc2565b611fda848484846121fa565b610da45760405162461bcd60e51b8152600401610a5490612c34565b606060c9805461095c906128ab565b60608160000361202c5750506040805180820190915260018152600360fc1b602082015290565b8160005b8115612056578061204081612971565b915061204f9050600a83612c86565b9150612030565b60008167ffffffffffffffff811115612071576120716125ea565b6040519080825280601f01601f19166020018201604052801561209b576020820181803683370190505b5090505b8415611cba576120b0600183612bd2565b91506120bd600a86612bbe565b6120c8906030612b51565b60f81b8183815181106120dd576120dd612b3b565b60200101906001600160f81b031916908160001a9053506120ff600a86612c86565b945061209f565b6001600160a01b038116600090815260cf602052604090205461212a816001612b51565b6001600160a01b03909216600090815260cf602052604090209190915550565b60008261215785846122fb565b14949350505050565b61216a838361236f565b61217760008484846121fa565b610b895760405162461bcd60e51b8152600401610a5490612c34565b600054610100900460ff166111b25760405162461bcd60e51b8152600401610a5490612be9565b600054610100900460ff166121e15760405162461bcd60e51b8152600401610a5490612be9565b60976121ed8382612a7b565b506098610b898282612a7b565b60006001600160a01b0384163b156122f057604051630a85bd0160e11b81526001600160a01b0385169063150b7a029061223e903390899088908890600401612c9a565b6020604051808303816000875af1925050508015612279575060408051601f3d908101601f1916820190925261227691810190612cd7565b60015b6122d6573d8080156122a7576040519150601f19603f3d011682016040523d82523d6000602084013e6122ac565b606091505b5080516000036122ce5760405162461bcd60e51b8152600401610a5490612c34565b805181602001fd5b6001600160e01b031916630a85bd0160e11b149050611cba565b506001949350505050565b600081815b845181101561236757600085828151811061231d5761231d612b3b565b602002602001015190508083116123435760008381526020829052604090209250612354565b600081815260208490526040902092505b508061235f81612971565b915050612300565b509392505050565b6001600160a01b0382166123c55760405162461bcd60e51b815260206004820181905260248201527f4552433732313a206d696e7420746f20746865207a65726f20616464726573736044820152606401610a54565b6000818152609960205260409020546001600160a01b03161561242a5760405162461bcd60e51b815260206004820152601c60248201527f4552433732313a20746f6b656e20616c7265616479206d696e746564000000006044820152606401610a54565b6001600160a01b0382166000908152609a60205260408120805460019290612453908490612b51565b909155505060008181526099602052604080822080546001600160a01b0319166001600160a01b03861690811790915590518392907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef908290a45050565b6001600160e01b0319811681146112e557600080fd5b6000602082840312156124d957600080fd5b8135611594816124b1565b60005b838110156124ff5781810151838201526020016124e7565b83811115610da45750506000910152565b600081518084526125288160208601602086016124e4565b601f01601f19169290920160200192915050565b6020815260006115946020830184612510565b60006020828403121561256157600080fd5b5035919050565b6001600160a01b03811681146112e557600080fd5b6000806040838503121561259057600080fd5b823561259b81612568565b946020939093013593505050565b6000806000606084860312156125be57600080fd5b83356125c981612568565b925060208401356125d981612568565b929592945050506040919091013590565b634e487b7160e01b600052604160045260246000fd5b600067ffffffffffffffff8084111561261b5761261b6125ea565b604051601f8501601f19908116603f01168101908282118183101715612643576126436125ea565b8160405280935085815286868601111561265c57600080fd5b858560208301376000602087830101525050509392505050565b60006020828403121561268857600080fd5b813567ffffffffffffffff81111561269f57600080fd5b8201601f810184136126b057600080fd5b611cba84823560208401612600565b60008083601f8401126126d157600080fd5b50813567ffffffffffffffff8111156126e957600080fd5b6020830191508360208260051b850101111561270457600080fd5b9250929050565b6000806020838503121561271e57600080fd5b823567ffffffffffffffff81111561273557600080fd5b612741858286016126bf565b90969095509350505050565b60006020828403121561275f57600080fd5b813561159481612568565b80151581146112e557600080fd5b6000806040838503121561278b57600080fd5b823561279681612568565b915060208301356127a68161276a565b809150509250929050565b600080600080608085870312156127c757600080fd5b84356127d281612568565b935060208501356127e281612568565b925060408501359150606085013567ffffffffffffffff81111561280557600080fd5b8501601f8101871361281657600080fd5b61282587823560208401612600565b91505092959194509250565b60008060006040848603121561284657600080fd5b83359250602084013567ffffffffffffffff81111561286457600080fd5b612870868287016126bf565b9497909650939450505050565b6000806040838503121561289057600080fd5b823561289b81612568565b915060208301356127a681612568565b600181811c908216806128bf57607f821691505b60208210810361159b57634e487b7160e01b600052602260045260246000fd5b60208082526038908201527f43616e6e6f74206d696e74206265636175736520657863656564696e67206d6960408201527f6e7420706572207472616e73616374696f6e206c696d69740000000000000000606082015260800190565b634e487b7160e01b600052601160045260246000fd5b600081600019048311821515161561296c5761296c61293c565b500290565b6000600182016129835761298361293c565b5060010190565b60208082526031908201527f4552433732313a207472616e736665722063616c6c6572206973206e6f74206f6040820152701ddb995c881b9bdc88185c1c1c9bdd9959607a1b606082015260800190565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b600060208284031215612a2257600080fd5b81516115948161276a565b601f821115610b8957600081815260208120601f850160051c81016020861015612a545750805b601f850160051c820191505b81811015612a7357828155600101612a60565b505050505050565b815167ffffffffffffffff811115612a9557612a956125ea565b612aa981612aa384546128ab565b84612a2d565b602080601f831160018114612ade5760008415612ac65750858301515b600019600386901b1c1916600185901b178555612a73565b600085815260208120601f198616915b82811015612b0d57888601518255948401946001909101908401612aee565b5085821015612b2b5787850151600019600388901b60f8161c191681555b5050505050600190811b01905550565b634e487b7160e01b600052603260045260246000fd5b60008219821115612b6457612b6461293c565b500190565b60008351612b7b8184602088016124e4565b835190830190612b8f8183602088016124e4565b64173539b7b760d91b9101908152600501949350505050565b634e487b7160e01b600052601260045260246000fd5b600082612bcd57612bcd612ba8565b500690565b600082821015612be457612be461293c565b500390565b6020808252602b908201527f496e697469616c697a61626c653a20636f6e7472616374206973206e6f74206960408201526a6e697469616c697a696e6760a81b606082015260800190565b60208082526032908201527f4552433732313a207472616e7366657220746f206e6f6e20455243373231526560408201527131b2b4bb32b91034b6b83632b6b2b73a32b960711b606082015260800190565b600082612c9557612c95612ba8565b500490565b6001600160a01b0385811682528416602082015260408101839052608060608201819052600090612ccd90830184612510565b9695505050505050565b600060208284031215612ce957600080fd5b8151611594816124b156fea2646970667358221220296bb1fcd58fff1a98e9a0be68b75a4bc6ac4308752b96b45302ce322f6d55a164736f6c634300080f0033

Deployed Bytecode Sourcemap

1033:8472:14:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;7764:418;;;;;;;;;;-1:-1:-1;7764:418:14;;;;;:::i;:::-;;:::i;:::-;;;565:14:17;;558:22;540:41;;528:2;513:18;7764:418:14;;;;;;;;3009:100:5;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;4579:221::-;;;;;;;;;;-1:-1:-1;4579:221:5;;;;;:::i;:::-;;:::i;:::-;;;-1:-1:-1;;;;;1692:32:17;;;1674:51;;1662:2;1647:18;4579:221:5;1528:203:17;4091:422:5;;;;;;;;;;-1:-1:-1;4091:422:5;;;;;:::i;:::-;;:::i;:::-;;2245:576:14;;;;;;:::i;:::-;;:::i;1600:34::-;;;;;;;;;;;;;;;;;;;2338:25:17;;;2326:2;2311:18;1600:34:14;2192:177:17;1227:36:14;;;;;;;;;;;;;;;;1359:40;;;;;;;;;;-1:-1:-1;1359:40:14;;;;;:::i;:::-;;;;;;;;;;;;;;5329:339:5;;;;;;;;;;-1:-1:-1;5329:339:5;;;;;:::i;:::-;;:::i;7506:182:14:-;;;;;;;;;;-1:-1:-1;7506:182:14;;;;;:::i;:::-;;:::i;6111:121::-;;;;;;;;;;;;;:::i;1720:94::-;;;;;;;;;;;;;;;;1680:31;;;;;;;;;;-1:-1:-1;1680:31:14;;;;;;;;5739:185:5;;;;;;;;;;-1:-1:-1;5739:185:5;;;;;:::i;:::-;;:::i;8190:105:14:-;;;;;;;;;;-1:-1:-1;8270:17:14;;;;8190:105;;1641:30;;;;;;;;;;;;;:::i;8950:180::-;;;;;;;;;;-1:-1:-1;8950:180:14;;;;;:::i;:::-;;:::i;3775:234::-;;;;;;;;;;-1:-1:-1;3775:234:14;;;;;:::i;:::-;;:::i;9370:95::-;;;;;;;;;;-1:-1:-1;9443:14:14;;;;;;;;;;;;-1:-1:-1;;;9443:14:14;;;;9370:95;;1320:32;;;;;;;;;;;;;;;;7113:312;;;;;;;;;;-1:-1:-1;7113:312:14;;;;;:::i;:::-;;:::i;9236:122::-;;;;;;;;;;-1:-1:-1;9236:122:14;;;;;:::i;:::-;-1:-1:-1;;;;;9325:25:14;9298:7;9325:25;;;:16;:25;;;;;;;9236:122;2703:239:5;;;;;;;;;;-1:-1:-1;2703:239:5;;;;;:::i;:::-;;:::i;1876:40:14:-;;;;;;;;;;-1:-1:-1;1876:40:14;;;;;;;;5857:120;;;;;;;;;;-1:-1:-1;5857:120:14;;;;;:::i;:::-;5923:4;7922:16:5;;;:7;:16;;;;;;-1:-1:-1;;;;;7922:16:5;:30;;5857:120:14;2433:208:5;;;;;;;;;;-1:-1:-1;2433:208:5;;;;;:::i;:::-;;:::i;2028:103:13:-;;;;;;;;;;;;;:::i;6600:106:14:-;;;;;;;;;;-1:-1:-1;6600:106:14;;;;;:::i;:::-;;:::i;1950:100::-;;;;;;;;;;;;;:::i;1377:87:13:-;;;;;;;;;;-1:-1:-1;1450:6:13;;-1:-1:-1;;;;;1450:6:13;1377:87;;3178:104:5;;;;;;;;;;;;;:::i;4872:155::-;;;;;;;;;;-1:-1:-1;4872:155:5;;;;;:::i;:::-;;:::i;8865:77:14:-;;;;;;;;;;;;;:::i;5985:118::-;;;;;;;;;;;;;:::i;5995:328:5:-;;;;;;;;;;-1:-1:-1;5995:328:5;;;;;:::i;:::-;;:::i;1558:35:14:-;;;;;;;;;;;;;;;;6478:114;;;;;;;;;;-1:-1:-1;6478:114:14;;;;;:::i;:::-;;:::i;6348:122::-;;;;;;;;;;-1:-1:-1;6348:122:14;;;;;:::i;:::-;;:::i;1461:51::-;;;;;;;;;;-1:-1:-1;1461:51:14;;;;;:::i;:::-;;;;;;;;;;;;;;1406:48;;;;;;;;;;-1:-1:-1;1406:48:14;;;;;:::i;:::-;;;;;;;;;;;;;;8370:487;;;;;;;;;;-1:-1:-1;8370:487:14;;;;;:::i;:::-;;:::i;2833:884::-;;;;;;:::i;:::-;;:::i;1521:30::-;;;;;;;;;;;;;;;;1821:48;;;;;;;;;;-1:-1:-1;1821:48:14;;;;;:::i;:::-;;;;;;;;;;;;;;;;6714:332;;;;;;;;;;-1:-1:-1;6714:332:14;;;;;:::i;:::-;;:::i;6238:102::-;;;;;;;;;;-1:-1:-1;6238:102:14;;;;;:::i;:::-;;:::i;5098:164:5:-;;;;;;;;;;-1:-1:-1;5098:164:5;;;;;:::i;:::-;-1:-1:-1;;;;;5219:25:5;;;5195:4;5219:25;;;:18;:25;;;;;;;;:35;;;;;;;;;;;;;;;5098:164;9138:90:14;;;;;;;;;;;;;:::i;2286:201:13:-;;;;;;;;;;-1:-1:-1;2286:201:13;;;;;:::i;:::-;;:::i;7764:418:14:-;7888:4;-1:-1:-1;;;;;;7925:51:14;;-1:-1:-1;;;7925:51:14;;:127;;-1:-1:-1;;;;;;;7993:59:14;;-1:-1:-1;;;7993:59:14;7925:127;:196;;;-1:-1:-1;;;;;;;8069:52:14;;;7925:196;:249;;;;8138:36;8162:11;8138:23;:36::i;:::-;7905:269;7764:418;-1:-1:-1;;7764:418:14:o;3009:100:5:-;3063:13;3096:5;3089:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;3009:100;:::o;4579:221::-;4655:7;7922:16;;;:7;:16;;;;;;-1:-1:-1;;;;;7922:16:5;4675:73;;;;-1:-1:-1;;;4675:73:5;;9090:2:17;4675:73:5;;;9072:21:17;9129:2;9109:18;;;9102:30;9168:34;9148:18;;;9141:62;-1:-1:-1;;;9219:18:17;;;9212:42;9271:19;;4675:73:5;;;;;;;;;-1:-1:-1;4768:24:5;;;;:15;:24;;;;;;-1:-1:-1;;;;;4768:24:5;;4579:221::o;4091:422::-;4172:13;4188:34;4214:7;4188:25;:34::i;:::-;4172:50;;4247:5;-1:-1:-1;;;;;4241:11:5;:2;-1:-1:-1;;;;;4241:11:5;;4233:57;;;;-1:-1:-1;;;4233:57:5;;9503:2:17;4233:57:5;;;9485:21:17;9542:2;9522:18;;;9515:30;9581:34;9561:18;;;9554:62;-1:-1:-1;;;9632:18:17;;;9625:31;9673:19;;4233:57:5;9301:397:17;4233:57:5;976:10:2;-1:-1:-1;;;;;4325:21:5;;;;:62;;-1:-1:-1;4350:37:5;4367:5;976:10:2;5098:164:5;:::i;4350:37::-;4303:168;;;;-1:-1:-1;;;4303:168:5;;9905:2:17;4303:168:5;;;9887:21:17;9944:2;9924:18;;;9917:30;9983:34;9963:18;;;9956:62;10054:26;10034:18;;;10027:54;10098:19;;4303:168:5;9703:420:17;4303:168:5;4484:21;4493:2;4497:7;4484:8;:21::i;:::-;4161:352;4091:422;;:::o;2245:576:14:-;2327:1;2319:5;:9;:37;;;;;2341:15;;2332:5;:24;;2319:37;2311:106;;;;-1:-1:-1;;;2311:106:14;;;;;;;:::i;:::-;2436:17;;;;:25;;:17;:25;2428:85;;;;-1:-1:-1;;;2428:85:14;;10755:2:17;2428:85:14;;;10737:21:17;10794:2;10774:18;;;10767:30;10833:34;10813:18;;;10806:62;-1:-1:-1;;;10884:18:17;;;10877:45;10939:19;;2428:85:14;10553:411:17;2428:85:14;2555:5;2545:7;;:15;;;;:::i;:::-;2532:9;:28;;2524:77;;;;-1:-1:-1;;;2524:77:14;;11476:2:17;2524:77:14;;;11458:21:17;11515:2;11495:18;;;11488:30;11554:34;11534:18;;;11527:62;-1:-1:-1;;;11605:18:17;;;11598:34;11649:19;;2524:77:14;11274:400:17;2524:77:14;2622:39;2643:10;2655:5;2622:20;:39::i;:::-;2678:9;2674:140;2695:5;2691:1;:9;2674:140;;;2721:15;2739:18;:16;:18::i;:::-;2721:36;;2772:30;2782:10;2794:7;2772:9;:30::i;:::-;-1:-1:-1;2702:3:14;;;;:::i;:::-;;;;2674:140;;;;2245:576;:::o;5329:339:5:-;5524:41;976:10:2;5557:7:5;5524:18;:41::i;:::-;5516:103;;;;-1:-1:-1;;;5516:103:5;;;;;;;:::i;:::-;5632:28;5642:4;5648:2;5652:7;5632:9;:28::i;7506:182:14:-;1450:6:13;;-1:-1:-1;;;;;1450:6:13;976:10:2;1597:23:13;1589:68;;;;-1:-1:-1;;;1589:68:13;;;;;;;:::i;:::-;7631:49:14::1;::::0;-1:-1:-1;;;7631:49:14;;-1:-1:-1;;;;;12798:32:17;;;7631:49:14::1;::::0;::::1;12780:51:17::0;12847:18;;;12840:34;;;7631:37:14;::::1;::::0;::::1;::::0;12753:18:17;;7631:49:14::1;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;7506:182:::0;;;:::o;6111:121::-;1450:6:13;;-1:-1:-1;;;;;1450:6:13;976:10:2;1597:23:13;1589:68;;;;-1:-1:-1;;;1589:68:13;;;;;;;:::i;:::-;6204:20:14::1;::::0;;-1:-1:-1;;6180:44:14;::::1;6204:20;::::0;;::::1;6203:21;6180:44;::::0;;6111:121::o;5739:185:5:-;5877:39;5894:4;5900:2;5904:7;5877:39;;;;;;;;;;;;:16;:39::i;1641:30:14:-;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::o;8950:180::-;1450:6:13;;-1:-1:-1;;;;;1450:6:13;976:10:2;1597:23:13;1589:68;;;;-1:-1:-1;;;1589:68:13;;;;;;;:::i;:::-;9036:11:14::1;::::0;::::1;;9035:12;9027:64;;;::::0;-1:-1:-1;;;9027:64:14;;13337:2:17;9027:64:14::1;::::0;::::1;13319:21:17::0;13376:2;13356:18;;;13349:30;13415:34;13395:18;;;13388:62;-1:-1:-1;;;13466:18:17;;;13459:37;13513:19;;9027:64:14::1;13135:403:17::0;9027:64:14::1;9104:7;:18;9114:8:::0;9104:7;:18:::1;:::i;3775:234::-:0;1450:6:13;;-1:-1:-1;;;;;1450:6:13;976:10:2;1597:23:13;1589:68;;;;-1:-1:-1;;;1589:68:13;;;;;;;:::i;:::-;3871:6:14::1;3866:136;3881:11:::0;;::::1;3866:136;;;3914:15;3932:18;:16;:18::i;:::-;3914:36;;3965:25;3975:2;;3978:1;3975:5;;;;;;;:::i;:::-;;;;;;;;;;;;;;:::i;:::-;3982:7;3965:9;:25::i;:::-;-1:-1:-1::0;3894:3:14;::::1;::::0;::::1;:::i;:::-;;;;3866:136;;7113:312:::0;1450:6:13;;-1:-1:-1;;;;;1450:6:13;976:10:2;1597:23:13;1589:68;;;;-1:-1:-1;;;1589:68:13;;;;;;;:::i;:::-;7206:21:14::1;:26:::0;7203:215:::1;;7281:6;7256:21;:31;;7248:75;;;::::0;-1:-1:-1;;;7248:75:14;;16081:2:17;7248:75:14::1;::::0;::::1;16063:21:17::0;16120:2;16100:18;;;16093:30;16159:33;16139:18;;;16132:61;16210:18;;7248:75:14::1;15879:355:17::0;7248:75:14::1;7338:28;::::0;-1:-1:-1;;;;;7338:20:14;::::1;::::0;:28;::::1;;;::::0;7359:6;;7338:28:::1;::::0;;;7359:6;7338:20;:28;::::1;;;;;;;;;;;;;::::0;::::1;;;;;;7400:6;7381:15;;:25;;;;;;;:::i;:::-;::::0;;;-1:-1:-1;;7113:312:14;;:::o;2703:239:5:-;2775:7;2811:16;;;:7;:16;;;;;;-1:-1:-1;;;;;2811:16:5;;2838:73;;;;-1:-1:-1;;;2838:73:5;;16574:2:17;2838:73:5;;;16556:21:17;16613:2;16593:18;;;16586:30;16652:34;16632:18;;;16625:62;-1:-1:-1;;;16703:18:17;;;16696:39;16752:19;;2838:73:5;16372:405:17;2433:208:5;2505:7;-1:-1:-1;;;;;2533:19:5;;2525:74;;;;-1:-1:-1;;;2525:74:5;;16984:2:17;2525:74:5;;;16966:21:17;17023:2;17003:18;;;16996:30;17062:34;17042:18;;;17035:62;-1:-1:-1;;;17113:18:17;;;17106:40;17163:19;;2525:74:5;16782:406:17;2525:74:5;-1:-1:-1;;;;;;2617:16:5;;;;;:9;:16;;;;;;;2433:208::o;2028:103:13:-;1450:6;;-1:-1:-1;;;;;1450:6:13;976:10:2;1597:23:13;1589:68;;;;-1:-1:-1;;;1589:68:13;;;;;;;:::i;:::-;2093:30:::1;2120:1;2093:18;:30::i;:::-;2028:103::o:0;6600:106:14:-;1450:6:13;;-1:-1:-1;;;;;1450:6:13;976:10:2;1597:23:13;1589:68;;;;-1:-1:-1;;;1589:68:13;;;;;;;:::i;:::-;6674:10:14::1;:24:::0;6600:106::o;1950:100::-;2389:13:11;;;;;;;:48;;2425:12;;;;2424:13;2389:48;;;3192:4;1131:20:0;1179:8;2405:16:11;2381:107;;;;-1:-1:-1;;;2381:107:11;;17395:2:17;2381:107:11;;;17377:21:17;17434:2;17414:18;;;17407:30;17473:34;17453:18;;;17446:62;-1:-1:-1;;;17524:18:17;;;17517:44;17578:19;;2381:107:11;17193:410:17;2381:107:11;2501:19;2524:13;;;;;;2523:14;2548:101;;;;2583:13;:20;;-1:-1:-1;;2618:19:11;;;;;2548:101;2003:39:14::1;;;;;;;;;;;;;;-1:-1:-1::0;;;2003:39:14::1;;::::0;::::1;;;;;;;;;;;;;-1:-1:-1::0;;;2003:39:14::1;;::::0;:13:::1;:39::i;:::-;2679:14:11::0;2675:68;;;2726:5;2710:21;;-1:-1:-1;;2710:21:11;;;2675:68;2096:654;1950:100:14:o;3178:104:5:-;3234:13;3267:7;3260:14;;;;;:::i;4872:155::-;4967:52;976:10:2;5000:8:5;5010;4967:18;:52::i;8865:77:14:-;1450:6:13;;-1:-1:-1;;;;;1450:6:13;976:10:2;1597:23:13;1589:68;;;;-1:-1:-1;;;1589:68:13;;;;;;;:::i;:::-;8913:21:14::1;::::0;;::::1;::::0;::::1;::::0;;;-1:-1:-1;8913:21:14;;:16:::1;::::0;:21:::1;::::0;:16;:21:::1;:::i;5985:118::-:0;1450:6:13;;-1:-1:-1;;;;;1450:6:13;976:10:2;1597:23:13;1589:68;;;;-1:-1:-1;;;1589:68:13;;;;;;;:::i;:::-;6078:17:14::1;::::0;;-1:-1:-1;;6057:38:14;::::1;6078:17;::::0;;::::1;6077:18;6057:38;::::0;;5985:118::o;5995:328:5:-;6170:41;976:10:2;6203:7:5;6170:18;:41::i;:::-;6162:103;;;;-1:-1:-1;;;6162:103:5;;;;;;;:::i;:::-;6276:39;6290:4;6296:2;6300:7;6309:5;6276:13;:39::i;6478:114:14:-;1450:6:13;;-1:-1:-1;;;;;1450:6:13;976:10:2;1597:23:13;1589:68;;;;-1:-1:-1;;;1589:68:13;;;;;;;:::i;:::-;6560:11:14::1;:24:::0;6478:114::o;6348:122::-;1450:6:13;;-1:-1:-1;;;;;1450:6:13;976:10:2;1597:23:13;1589:68;;;;-1:-1:-1;;;1589:68:13;;;;;;;:::i;:::-;6434:15:14::1;:28:::0;6348:122::o;8370:487::-;7898:4:5;7922:16;;;:7;:16;;;;;;8443:13:14;;-1:-1:-1;;;;;7922:16:5;8469:76:14;;;;-1:-1:-1;;;8469:76:14;;17810:2:17;8469:76:14;;;17792:21:17;17849:2;17829:18;;;17822:30;17888:34;17868:18;;;17861:62;-1:-1:-1;;;17939:18:17;;;17932:45;17994:19;;8469:76:14;17608:411:17;8469:76:14;8558:23;8584:10;:8;:10::i;:::-;8558:36;;8643:1;8616:16;8610:30;;;;;:::i;:::-;;;:34;8607:241;;;8667:16;8660:23;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8370:487;;;:::o;8607:241::-;8757:1;8737:9;8731:23;:27;:105;;;;;;;;;;;;;;;;;8785:9;8796:25;8813:7;8796:16;:25::i;:::-;8768:62;;;;;;;;;:::i;:::-;;;;;;;;;;;;;8731:105;8724:112;8370:487;-1:-1:-1;;;8370:487:14:o;8607:241::-;8458:399;8370:487;;;:::o;2833:884::-;2958:1;2944:11;:15;:45;;;;;2978:11;;2963;:26;;2944:45;2936:114;;;;-1:-1:-1;;;2936:114:14;;;;;;;:::i;:::-;3061:32;3082:10;3061:20;:32::i;:::-;3154:20;;;;3146:67;;;;-1:-1:-1;;;3146:67:14;;18868:2:17;3146:67:14;;;18850:21:17;18907:2;18887:18;;;18880:30;18946:34;18926:18;;;18919:62;-1:-1:-1;;;18997:18:17;;;18990:32;19039:19;;3146:67:14;18666:398:17;3146:67:14;3250:10;3233:28;;;;:16;:28;;;;;;;;3232:29;3224:66;;;;-1:-1:-1;;;3224:66:14;;19271:2:17;3224:66:14;;;19253:21:17;19310:2;19290:18;;;19283:30;19349:26;19329:18;;;19322:54;19393:18;;3224:66:14;19069:348:17;3224:66:14;3326:28;;-1:-1:-1;;3343:10:14;19571:2:17;19567:15;19563:53;3326:28:14;;;19551:66:17;3301:12:14;;19633::17;;3326:28:14;;;;;;;;;;;;3316:39;;;;;;3301:54;;3374:50;3393:12;;3374:50;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;3407:10:14;;;-1:-1:-1;3419:4:14;;-1:-1:-1;3374:18:14;:50::i;:::-;3366:77;;;;-1:-1:-1;;;3366:77:14;;19858:2:17;3366:77:14;;;19840:21:17;19897:2;19877:18;;;19870:30;-1:-1:-1;;;19916:18:17;;;19909:44;19970:18;;3366:77:14;19656:338:17;3366:77:14;3473:10;3456:28;;;;:16;:28;;;;;:35;;-1:-1:-1;;3456:35:14;3487:4;3456:35;;;3502:208;3523:11;3519:1;:15;3502:208;;;3617:15;3635:18;:16;:18::i;:::-;3617:36;;3668:30;3678:10;3690:7;3668:9;:30::i;:::-;-1:-1:-1;3536:3:14;;;;:::i;:::-;;;;3502:208;;;;2925:792;2833:884;;;:::o;6714:332::-;1450:6:13;;-1:-1:-1;;;;;1450:6:13;976:10:2;1597:23:13;1589:68;;;;-1:-1:-1;;;1589:68:13;;;;;;;:::i;:::-;6828:16:14::1;6822:30;;;;;:::i;:::-;;;6856:1;6822:35:::0;6814:82:::1;;;::::0;-1:-1:-1;;;6814:82:14;;20201:2:17;6814:82:14::1;::::0;::::1;20183:21:17::0;20240:2;20220:18;;;20213:30;20279:34;20259:18;;;20252:62;-1:-1:-1;;;20330:18:17;;;20323:32;20372:19;;6814:82:14::1;19999:398:17::0;6814:82:14::1;6921:17;6915:31;6950:1;6915:36:::0;6907:82:::1;;;::::0;-1:-1:-1;;;6907:82:14;;20604:2:17;6907:82:14::1;::::0;::::1;20586:21:17::0;20643:2;20623:18;;;20616:30;20682:34;20662:18;;;20655:62;-1:-1:-1;;;20733:18:17;;;20726:31;20774:19;;6907:82:14::1;20402:397:17::0;6907:82:14::1;7002:16;:36;7021:17:::0;7002:16;:36:::1;:::i;6238:102::-:0;1450:6:13;;-1:-1:-1;;;;;1450:6:13;976:10:2;1597:23:13;1589:68;;;;-1:-1:-1;;;1589:68:13;;;;;;;:::i;:::-;6314:7:14::1;:18:::0;6238:102::o;9138:90::-;1450:6:13;;-1:-1:-1;;;;;1450:6:13;976:10:2;1597:23:13;1589:68;;;;-1:-1:-1;;;1589:68:13;;;;;;;:::i;:::-;9202:11:14::1;:18:::0;;-1:-1:-1;;9202:18:14::1;9216:4;9202:18;::::0;;9138:90::o;2286:201:13:-;1450:6;;-1:-1:-1;;;;;1450:6:13;976:10:2;1597:23:13;1589:68;;;;-1:-1:-1;;;1589:68:13;;;;;;;:::i;:::-;-1:-1:-1;;;;;2375:22:13;::::1;2367:73;;;::::0;-1:-1:-1;;;2367:73:13;;21006:2:17;2367:73:13::1;::::0;::::1;20988:21:17::0;21045:2;21025:18;;;21018:30;21084:34;21064:18;;;21057:62;-1:-1:-1;;;21135:18:17;;;21128:36;21181:19;;2367:73:13::1;20804:402:17::0;2367:73:13::1;2451:28;2470:8;2451:18;:28::i;2020:349:5:-:0;2144:4;-1:-1:-1;;;;;;2181:51:5;;-1:-1:-1;;;2181:51:5;;:127;;-1:-1:-1;;;;;;;2249:59:5;;-1:-1:-1;;;2249:59:5;2181:127;:180;;;-1:-1:-1;;;;;;;;;;1220:51:4;;;2325:36:5;1111:168:4;11848:185:5;11923:24;;;;:15;:24;;;;;:29;;-1:-1:-1;;;;;;11923:29:5;-1:-1:-1;;;;;11923:29:5;;;;;;;;:24;;11977:34;11923:24;11977:25;:34::i;:::-;-1:-1:-1;;;;;11968:57:5;;;;;;;;;;;11848:185;;:::o;5585:260:14:-;-1:-1:-1;;;;;5755:25:14;;5739:13;5755:25;;;:16;:25;;;;;;5821:16;5829:8;5755:25;5821:16;:::i;:::-;-1:-1:-1;;;;;5793:25:14;;;;;;;:16;:25;;;;;:44;;;;-1:-1:-1;;5585:260:14:o;4021:648::-;4067:13;4108:9;4173;;4152:15;4135:33;;;;;;21340:19:17;;21384:2;21375:12;;21211:182;4135:33:14;;;;;;;;;;;;;4125:44;;;;;;4120:50;;:62;;;;:::i;:::-;4293:8;;;;:5;:8;;;;;;4108:74;;-1:-1:-1;4293:13:14;:28;;4313:8;;;;:5;:8;;;;;;4293:28;;;4309:1;4293:28;4285:36;;4385:5;:20;4403:1;4391:9;;:13;;;;:::i;:::-;4385:20;;;;;;;;;;;;4409:1;4385:25;:64;;4429:5;:20;4447:1;4435:9;;:13;;;;:::i;:::-;4429:20;;;;;;;;;;;;4385:64;;;4425:1;4413:9;;:13;;;;:::i;:::-;4374:8;;;;:5;:8;;;;;:75;4610:5;4380:1;4614;4610:5;:::i;:::-;4584:23;4598:8;;;:5;:8;;;;;;;;;4584:23;;:13;:23;;;;;:31;4648:9;;:13;;4660:1;;4648:13;:::i;:::-;4636:9;:25;-1:-1:-1;4021:648:14;:::o;8828:110:5:-;8904:26;8914:2;8918:7;8904:26;;;;;;;;;;;;:9;:26::i;8127:359::-;8220:4;7922:16;;;:7;:16;;;;;;-1:-1:-1;;;;;7922:16:5;8237:73;;;;-1:-1:-1;;;8237:73:5;;21979:2:17;8237:73:5;;;21961:21:17;22018:2;21998:18;;;21991:30;22057:34;22037:18;;;22030:62;-1:-1:-1;;;22108:18:17;;;22101:42;22160:19;;8237:73:5;21777:408:17;8237:73:5;8321:13;8337:34;8363:7;8337:25;:34::i;:::-;8321:50;;8401:5;-1:-1:-1;;;;;8390:16:5;:7;-1:-1:-1;;;;;8390:16:5;;:51;;;;8434:7;-1:-1:-1;;;;;8410:31:5;:20;8422:7;8410:11;:20::i;:::-;-1:-1:-1;;;;;8410:31:5;;8390:51;:87;;;-1:-1:-1;;;;;;5219:25:5;;;5195:4;5219:25;;;:18;:25;;;;;;;;:35;;;;;;;;;;;;8445:32;8382:96;8127:359;-1:-1:-1;;;;8127:359:5:o;11141:589::-;11311:4;-1:-1:-1;;;;;11273:42:5;:34;11299:7;11273:25;:34::i;:::-;-1:-1:-1;;;;;11273:42:5;;11265:96;;;;-1:-1:-1;;;11265:96:5;;22392:2:17;11265:96:5;;;22374:21:17;22431:2;22411:18;;;22404:30;22470:34;22450:18;;;22443:62;-1:-1:-1;;;22521:18:17;;;22514:39;22570:19;;11265:96:5;22190:405:17;11265:96:5;-1:-1:-1;;;;;11380:16:5;;11372:65;;;;-1:-1:-1;;;11372:65:5;;22802:2:17;11372:65:5;;;22784:21:17;22841:2;22821:18;;;22814:30;22880:34;22860:18;;;22853:62;-1:-1:-1;;;22931:18:17;;;22924:34;22975:19;;11372:65:5;22600:400:17;11372:65:5;11554:29;11571:1;11575:7;11554:8;:29::i;:::-;-1:-1:-1;;;;;11596:15:5;;;;;;:9;:15;;;;;:20;;11615:1;;11596:15;:20;;11615:1;;11596:20;:::i;:::-;;;;-1:-1:-1;;;;;;;11627:13:5;;;;;;:9;:13;;;;;:18;;11644:1;;11627:13;:18;;11644:1;;11627:18;:::i;:::-;;;;-1:-1:-1;;11656:16:5;;;;:7;:16;;;;;;:21;;-1:-1:-1;;;;;;11656:21:5;-1:-1:-1;;;;;11656:21:5;;;;;;;;;11695:27;;11656:16;;11695:27;;;;;;;11141:589;;;:::o;2647:191:13:-;2740:6;;;-1:-1:-1;;;;;2757:17:13;;;-1:-1:-1;;;;;;2757:17:13;;;;;;;2790:40;;2740:6;;;2757:17;2740:6;;2790:40;;2721:16;;2790:40;2710:128;2647:191;:::o;1553:224:5:-;2992:13:11;;;;;;;2984:69;;;;-1:-1:-1;;;2984:69:11;;;;;;;:::i;:::-;1657:26:5::1;:24;:26::i;:::-;1694:25;:23;:25::i;:::-;1730:39;1754:5;1761:7;1730:23;:39::i;12175:315::-:0;12330:8;-1:-1:-1;;;;;12321:17:5;:5;-1:-1:-1;;;;;12321:17:5;;12313:55;;;;-1:-1:-1;;;12313:55:5;;23619:2:17;12313:55:5;;;23601:21:17;23658:2;23638:18;;;23631:30;23697:27;23677:18;;;23670:55;23742:18;;12313:55:5;23417:349:17;12313:55:5;-1:-1:-1;;;;;12379:25:5;;;;;;;:18;:25;;;;;;;;:35;;;;;;;;;;;;;:46;;-1:-1:-1;;12379:46:5;;;;;;;;;;12441:41;;540::17;;;12441::5;;513:18:17;12441:41:5;;;;;;;12175:315;;;:::o;7205:::-;7362:28;7372:4;7378:2;7382:7;7362:9;:28::i;:::-;7409:48;7432:4;7438:2;7442:7;7451:5;7409:22;:48::i;:::-;7401:111;;;;-1:-1:-1;;;7401:111:5;;;;;;;:::i;2062:108:14:-;2122:13;2155:7;2148:14;;;;;:::i;342:723:15:-;398:13;619:5;628:1;619:10;615:53;;-1:-1:-1;;646:10:15;;;;;;;;;;;;-1:-1:-1;;;646:10:15;;;;;342:723::o;615:53::-;693:5;678:12;734:78;741:9;;734:78;;767:8;;;;:::i;:::-;;-1:-1:-1;790:10:15;;-1:-1:-1;798:2:15;790:10;;:::i;:::-;;;734:78;;;822:19;854:6;844:17;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;844:17:15;;822:39;;872:154;879:10;;872:154;;906:11;916:1;906:11;;:::i;:::-;;-1:-1:-1;975:10:15;983:2;975:5;:10;:::i;:::-;962:24;;:2;:24;:::i;:::-;949:39;;932:6;939;932:14;;;;;;;;:::i;:::-;;;;:56;-1:-1:-1;;;;;932:56:15;;;;;;;;-1:-1:-1;1003:11:15;1012:2;1003:11;;:::i;:::-;;;872:154;;5338:235:14;-1:-1:-1;;;;;5490:25:14;;5474:13;5490:25;;;:16;:25;;;;;;5556:9;5490:25;5564:1;5556:9;:::i;:::-;-1:-1:-1;;;;;5528:25:14;;;;;;;:16;:25;;;;;:37;;;;-1:-1:-1;5338:235:14:o;883:190:12:-;1008:4;1061;1032:25;1045:5;1052:4;1032:12;:25::i;:::-;:33;;883:190;-1:-1:-1;;;;883:190:12:o;9165:321:5:-;9295:18;9301:2;9305:7;9295:5;:18::i;:::-;9346:54;9377:1;9381:2;9385:7;9394:5;9346:22;:54::i;:::-;9324:154;;;;-1:-1:-1;;;9324:154:5;;;;;;;:::i;820:70:2:-;2992:13:11;;;;;;;2984:69;;;;-1:-1:-1;;;2984:69:11;;;;;;;:::i;1785:163:5:-;2992:13:11;;;;;;;2984:69;;;;-1:-1:-1;;;2984:69:11;;;;;;;:::i;:::-;1899:5:5::1;:13;1907:5:::0;1899;:13:::1;:::i;:::-;-1:-1:-1::0;1923:7:5::1;:17;1933:7:::0;1923;:17:::1;:::i;13055:821::-:0;13210:4;-1:-1:-1;;;;;13231:13:5;;1131:20:0;1179:8;13227:642:5;;13267:83;;-1:-1:-1;;;13267:83:5;;-1:-1:-1;;;;;13267:47:5;;;;;:83;;976:10:2;;13329:4:5;;13335:7;;13344:5;;13267:83;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;-1:-1:-1;13267:83:5;;;;;;;;-1:-1:-1;;13267:83:5;;;;;;;;;;;;:::i;:::-;;;13263:551;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;13531:6;:13;13548:1;13531:18;13527:272;;13574:60;;-1:-1:-1;;;13574:60:5;;;;;;;:::i;13527:272::-;13749:6;13743:13;13734:6;13730:2;13726:15;13719:38;13263:551;-1:-1:-1;;;;;;13401:62:5;-1:-1:-1;;;13401:62:5;;-1:-1:-1;13394:69:5;;13227:642;-1:-1:-1;13853:4:5;13055:821;;;;;;:::o;1435:675:12:-;1518:7;1561:4;1518:7;1576:497;1600:5;:12;1596:1;:16;1576:497;;;1634:20;1657:5;1663:1;1657:8;;;;;;;;:::i;:::-;;;;;;;1634:31;;1700:12;1684;:28;1680:382;;2186:13;2236:15;;;2272:4;2265:15;;;2319:4;2303:21;;1812:57;;1680:382;;;2186:13;2236:15;;;2272:4;2265:15;;;2319:4;2303:21;;1989:57;;1680:382;-1:-1:-1;1614:3:12;;;;:::i;:::-;;;;1576:497;;;-1:-1:-1;2090:12:12;1435:675;-1:-1:-1;;;1435:675:12:o;9822:382:5:-;-1:-1:-1;;;;;9902:16:5;;9894:61;;;;-1:-1:-1;;;9894:61:5;;25265:2:17;9894:61:5;;;25247:21:17;;;25284:18;;;25277:30;25343:34;25323:18;;;25316:62;25395:18;;9894:61:5;25063:356:17;9894:61:5;7898:4;7922:16;;;:7;:16;;;;;;-1:-1:-1;;;;;7922:16:5;:30;9966:58;;;;-1:-1:-1;;;9966:58:5;;25626:2:17;9966:58:5;;;25608:21:17;25665:2;25645:18;;;25638:30;25704;25684:18;;;25677:58;25752:18;;9966:58:5;25424:352:17;9966:58:5;-1:-1:-1;;;;;10095:13:5;;;;;;:9;:13;;;;;:18;;10112:1;;10095:13;:18;;10112:1;;10095:18;:::i;:::-;;;;-1:-1:-1;;10124:16:5;;;;:7;:16;;;;;;:21;;-1:-1:-1;;;;;;10124:21:5;-1:-1:-1;;;;;10124:21:5;;;;;;;;10163:33;;10124:16;;;10163:33;;10124:16;;10163:33;9822:382;;:::o;14:131:17:-;-1:-1:-1;;;;;;88:32:17;;78:43;;68:71;;135:1;132;125:12;150:245;208:6;261:2;249:9;240:7;236:23;232:32;229:52;;;277:1;274;267:12;229:52;316:9;303:23;335:30;359:5;335:30;:::i;592:258::-;664:1;674:113;688:6;685:1;682:13;674:113;;;764:11;;;758:18;745:11;;;738:39;710:2;703:10;674:113;;;805:6;802:1;799:13;796:48;;;-1:-1:-1;;840:1:17;822:16;;815:27;592:258::o;855:::-;897:3;935:5;929:12;962:6;957:3;950:19;978:63;1034:6;1027:4;1022:3;1018:14;1011:4;1004:5;1000:16;978:63;:::i;:::-;1095:2;1074:15;-1:-1:-1;;1070:29:17;1061:39;;;;1102:4;1057:50;;855:258;-1:-1:-1;;855:258:17:o;1118:220::-;1267:2;1256:9;1249:21;1230:4;1287:45;1328:2;1317:9;1313:18;1305:6;1287:45;:::i;1343:180::-;1402:6;1455:2;1443:9;1434:7;1430:23;1426:32;1423:52;;;1471:1;1468;1461:12;1423:52;-1:-1:-1;1494:23:17;;1343:180;-1:-1:-1;1343:180:17:o;1736:131::-;-1:-1:-1;;;;;1811:31:17;;1801:42;;1791:70;;1857:1;1854;1847:12;1872:315;1940:6;1948;2001:2;1989:9;1980:7;1976:23;1972:32;1969:52;;;2017:1;2014;2007:12;1969:52;2056:9;2043:23;2075:31;2100:5;2075:31;:::i;:::-;2125:5;2177:2;2162:18;;;;2149:32;;-1:-1:-1;;;1872:315:17:o;2374:456::-;2451:6;2459;2467;2520:2;2508:9;2499:7;2495:23;2491:32;2488:52;;;2536:1;2533;2526:12;2488:52;2575:9;2562:23;2594:31;2619:5;2594:31;:::i;:::-;2644:5;-1:-1:-1;2701:2:17;2686:18;;2673:32;2714:33;2673:32;2714:33;:::i;:::-;2374:456;;2766:7;;-1:-1:-1;;;2820:2:17;2805:18;;;;2792:32;;2374:456::o;3486:127::-;3547:10;3542:3;3538:20;3535:1;3528:31;3578:4;3575:1;3568:15;3602:4;3599:1;3592:15;3618:632;3683:5;3713:18;3754:2;3746:6;3743:14;3740:40;;;3760:18;;:::i;:::-;3835:2;3829:9;3803:2;3889:15;;-1:-1:-1;;3885:24:17;;;3911:2;3881:33;3877:42;3865:55;;;3935:18;;;3955:22;;;3932:46;3929:72;;;3981:18;;:::i;:::-;4021:10;4017:2;4010:22;4050:6;4041:15;;4080:6;4072;4065:22;4120:3;4111:6;4106:3;4102:16;4099:25;4096:45;;;4137:1;4134;4127:12;4096:45;4187:6;4182:3;4175:4;4167:6;4163:17;4150:44;4242:1;4235:4;4226:6;4218;4214:19;4210:30;4203:41;;;;3618:632;;;;;:::o;4255:451::-;4324:6;4377:2;4365:9;4356:7;4352:23;4348:32;4345:52;;;4393:1;4390;4383:12;4345:52;4433:9;4420:23;4466:18;4458:6;4455:30;4452:50;;;4498:1;4495;4488:12;4452:50;4521:22;;4574:4;4566:13;;4562:27;-1:-1:-1;4552:55:17;;4603:1;4600;4593:12;4552:55;4626:74;4692:7;4687:2;4674:16;4669:2;4665;4661:11;4626:74;:::i;4711:367::-;4774:8;4784:6;4838:3;4831:4;4823:6;4819:17;4815:27;4805:55;;4856:1;4853;4846:12;4805:55;-1:-1:-1;4879:20:17;;4922:18;4911:30;;4908:50;;;4954:1;4951;4944:12;4908:50;4991:4;4983:6;4979:17;4967:29;;5051:3;5044:4;5034:6;5031:1;5027:14;5019:6;5015:27;5011:38;5008:47;5005:67;;;5068:1;5065;5058:12;5005:67;4711:367;;;;;:::o;5083:437::-;5169:6;5177;5230:2;5218:9;5209:7;5205:23;5201:32;5198:52;;;5246:1;5243;5236:12;5198:52;5286:9;5273:23;5319:18;5311:6;5308:30;5305:50;;;5351:1;5348;5341:12;5305:50;5390:70;5452:7;5443:6;5432:9;5428:22;5390:70;:::i;:::-;5479:8;;5364:96;;-1:-1:-1;5083:437:17;-1:-1:-1;;;;5083:437:17:o;5853:247::-;5912:6;5965:2;5953:9;5944:7;5940:23;5936:32;5933:52;;;5981:1;5978;5971:12;5933:52;6020:9;6007:23;6039:31;6064:5;6039:31;:::i;6290:118::-;6376:5;6369:13;6362:21;6355:5;6352:32;6342:60;;6398:1;6395;6388:12;6413:382;6478:6;6486;6539:2;6527:9;6518:7;6514:23;6510:32;6507:52;;;6555:1;6552;6545:12;6507:52;6594:9;6581:23;6613:31;6638:5;6613:31;:::i;:::-;6663:5;-1:-1:-1;6720:2:17;6705:18;;6692:32;6733:30;6692:32;6733:30;:::i;:::-;6782:7;6772:17;;;6413:382;;;;;:::o;6800:795::-;6895:6;6903;6911;6919;6972:3;6960:9;6951:7;6947:23;6943:33;6940:53;;;6989:1;6986;6979:12;6940:53;7028:9;7015:23;7047:31;7072:5;7047:31;:::i;:::-;7097:5;-1:-1:-1;7154:2:17;7139:18;;7126:32;7167:33;7126:32;7167:33;:::i;:::-;7219:7;-1:-1:-1;7273:2:17;7258:18;;7245:32;;-1:-1:-1;7328:2:17;7313:18;;7300:32;7355:18;7344:30;;7341:50;;;7387:1;7384;7377:12;7341:50;7410:22;;7463:4;7455:13;;7451:27;-1:-1:-1;7441:55:17;;7492:1;7489;7482:12;7441:55;7515:74;7581:7;7576:2;7563:16;7558:2;7554;7550:11;7515:74;:::i;:::-;7505:84;;;6800:795;;;;;;;:::o;7600:505::-;7695:6;7703;7711;7764:2;7752:9;7743:7;7739:23;7735:32;7732:52;;;7780:1;7777;7770:12;7732:52;7816:9;7803:23;7793:33;;7877:2;7866:9;7862:18;7849:32;7904:18;7896:6;7893:30;7890:50;;;7936:1;7933;7926:12;7890:50;7975:70;8037:7;8028:6;8017:9;8013:22;7975:70;:::i;:::-;7600:505;;8064:8;;-1:-1:-1;7949:96:17;;-1:-1:-1;;;;7600:505:17:o;8110:388::-;8178:6;8186;8239:2;8227:9;8218:7;8214:23;8210:32;8207:52;;;8255:1;8252;8245:12;8207:52;8294:9;8281:23;8313:31;8338:5;8313:31;:::i;:::-;8363:5;-1:-1:-1;8420:2:17;8405:18;;8392:32;8433:33;8392:32;8433:33;:::i;8503:380::-;8582:1;8578:12;;;;8625;;;8646:61;;8700:4;8692:6;8688:17;8678:27;;8646:61;8753:2;8745:6;8742:14;8722:18;8719:38;8716:161;;8799:10;8794:3;8790:20;8787:1;8780:31;8834:4;8831:1;8824:15;8862:4;8859:1;8852:15;10128:420;10330:2;10312:21;;;10369:2;10349:18;;;10342:30;10408:34;10403:2;10388:18;;10381:62;10479:26;10474:2;10459:18;;10452:54;10538:3;10523:19;;10128:420::o;10969:127::-;11030:10;11025:3;11021:20;11018:1;11011:31;11061:4;11058:1;11051:15;11085:4;11082:1;11075:15;11101:168;11141:7;11207:1;11203;11199:6;11195:14;11192:1;11189:21;11184:1;11177:9;11170:17;11166:45;11163:71;;;11214:18;;:::i;:::-;-1:-1:-1;11254:9:17;;11101:168::o;11679:135::-;11718:3;11739:17;;;11736:43;;11759:18;;:::i;:::-;-1:-1:-1;11806:1:17;11795:13;;11679:135::o;11819:413::-;12021:2;12003:21;;;12060:2;12040:18;;;12033:30;12099:34;12094:2;12079:18;;12072:62;-1:-1:-1;;;12165:2:17;12150:18;;12143:47;12222:3;12207:19;;11819:413::o;12237:356::-;12439:2;12421:21;;;12458:18;;;12451:30;12517:34;12512:2;12497:18;;12490:62;12584:2;12569:18;;12237:356::o;12885:245::-;12952:6;13005:2;12993:9;12984:7;12980:23;12976:32;12973:52;;;13021:1;13018;13011:12;12973:52;13053:9;13047:16;13072:28;13094:5;13072:28;:::i;13669:545::-;13771:2;13766:3;13763:11;13760:448;;;13807:1;13832:5;13828:2;13821:17;13877:4;13873:2;13863:19;13947:2;13935:10;13931:19;13928:1;13924:27;13918:4;13914:38;13983:4;13971:10;13968:20;13965:47;;;-1:-1:-1;14006:4:17;13965:47;14061:2;14056:3;14052:12;14049:1;14045:20;14039:4;14035:31;14025:41;;14116:82;14134:2;14127:5;14124:13;14116:82;;;14179:17;;;14160:1;14149:13;14116:82;;;14120:3;;;13669:545;;;:::o;14390:1352::-;14516:3;14510:10;14543:18;14535:6;14532:30;14529:56;;;14565:18;;:::i;:::-;14594:97;14684:6;14644:38;14676:4;14670:11;14644:38;:::i;:::-;14638:4;14594:97;:::i;:::-;14746:4;;14810:2;14799:14;;14827:1;14822:663;;;;15529:1;15546:6;15543:89;;;-1:-1:-1;15598:19:17;;;15592:26;15543:89;-1:-1:-1;;14347:1:17;14343:11;;;14339:24;14335:29;14325:40;14371:1;14367:11;;;14322:57;15645:81;;14792:944;;14822:663;13616:1;13609:14;;;13653:4;13640:18;;-1:-1:-1;;14858:20:17;;;14976:236;14990:7;14987:1;14984:14;14976:236;;;15079:19;;;15073:26;15058:42;;15171:27;;;;15139:1;15127:14;;;;15006:19;;14976:236;;;14980:3;15240:6;15231:7;15228:19;15225:201;;;15301:19;;;15295:26;-1:-1:-1;;15384:1:17;15380:14;;;15396:3;15376:24;15372:37;15368:42;15353:58;15338:74;;15225:201;-1:-1:-1;;;;;15472:1:17;15456:14;;;15452:22;15439:36;;-1:-1:-1;14390:1352:17:o;15747:127::-;15808:10;15803:3;15799:20;15796:1;15789:31;15839:4;15836:1;15829:15;15863:4;15860:1;15853:15;16239:128;16279:3;16310:1;16306:6;16303:1;16300:13;16297:39;;;16316:18;;:::i;:::-;-1:-1:-1;16352:9:17;;16239:128::o;18024:637::-;18304:3;18342:6;18336:13;18358:53;18404:6;18399:3;18392:4;18384:6;18380:17;18358:53;:::i;:::-;18474:13;;18433:16;;;;18496:57;18474:13;18433:16;18530:4;18518:17;;18496:57;:::i;:::-;-1:-1:-1;;;18575:20:17;;18604:22;;;18653:1;18642:13;;18024:637;-1:-1:-1;;;;18024:637:17:o;21398:127::-;21459:10;21454:3;21450:20;21447:1;21440:31;21490:4;21487:1;21480:15;21514:4;21511:1;21504:15;21530:112;21562:1;21588;21578:35;;21593:18;;:::i;:::-;-1:-1:-1;21627:9:17;;21530:112::o;21647:125::-;21687:4;21715:1;21712;21709:8;21706:34;;;21720:18;;:::i;:::-;-1:-1:-1;21757:9:17;;21647:125::o;23005:407::-;23207:2;23189:21;;;23246:2;23226:18;;;23219:30;23285:34;23280:2;23265:18;;23258:62;-1:-1:-1;;;23351:2:17;23336:18;;23329:41;23402:3;23387:19;;23005:407::o;23771:414::-;23973:2;23955:21;;;24012:2;23992:18;;;23985:30;24051:34;24046:2;24031:18;;24024:62;-1:-1:-1;;;24117:2:17;24102:18;;24095:48;24175:3;24160:19;;23771:414::o;24190:120::-;24230:1;24256;24246:35;;24261:18;;:::i;:::-;-1:-1:-1;24295:9:17;;24190:120::o;24315:489::-;-1:-1:-1;;;;;24584:15:17;;;24566:34;;24636:15;;24631:2;24616:18;;24609:43;24683:2;24668:18;;24661:34;;;24731:3;24726:2;24711:18;;24704:31;;;24509:4;;24752:46;;24778:19;;24770:6;24752:46;:::i;:::-;24744:54;24315:489;-1:-1:-1;;;;;;24315:489:17:o;24809:249::-;24878:6;24931:2;24919:9;24910:7;24906:23;24902:32;24899:52;;;24947:1;24944;24937:12;24899:52;24979:9;24973:16;24998:30;25022:5;24998:30;:::i

Swarm Source

ipfs://296bb1fcd58fff1a98e9a0be68b75a4bc6ac4308752b96b45302ce322f6d55a1
Loading...
Loading
Loading...
Loading
[ Download: CSV Export  ]
[ Download: CSV Export  ]

A token is a representation of an on-chain or off-chain asset. The token page shows information such as price, total supply, holders, transfers and social links. Learn more about this page in our Knowledge Base.