ETH Price: $3,465.35 (+1.90%)

Token

ItsABee (ABEE)
 

Overview

Max Total Supply

6,940 ABEE

Holders

744

Market

Volume (24H)

N/A

Min Price (24H)

N/A

Max Price (24H)

N/A
Balance
5 ABEE
0x07f3c8c609e68afe7ec535f1f1854b178fc7421f
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:
ItsABee

Compiler Version
v0.8.14+commit.80d49f37

Optimization Enabled:
Yes with 40 runs

Other Settings:
default evmVersion, MIT license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2022-07-20
*/

/*
 Larkin - @CodeLarkin - codelarkin.eth
 ██╗      █████╗ ██████╗ ██╗  ██╗██╗███╗   ██╗
 ██║     ██╔══██╗██╔══██╗██║ ██╔╝██║████╗  ██║
 ██║     ███████║██████╔╝█████╔╝ ██║██╔██╗ ██║
 ██║     ██╔══██║██╔══██╗██╔═██╗ ██║██║╚██╗██║
 ███████╗██║  ██║██║  ██║██║  ██╗██║██║ ╚████║
 ╚══════╝╚═╝  ╚═╝╚═╝  ╚═╝╚═╝  ╚═╝╚═╝╚═╝  ╚═══╝
*/

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.14;

// Sources flattened with hardhat v2.9.6 https://hardhat.org

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


// OpenZeppelin Contracts v4.4.1 (utils/introspection/IERC165.sol)



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


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


// OpenZeppelin Contracts (last updated v4.6.0) (interfaces/IERC2981.sol)



/**
 * @dev Interface for the NFT Royalty Standard.
 *
 * A standardized way to retrieve royalty payment information for non-fungible tokens (NFTs) to enable universal
 * support for royalty payments across all NFT marketplaces and ecosystem participants.
 *
 * _Available since v4.5._
 */
interface IERC2981 is IERC165 {
    /**
     * @dev Returns how much royalty is owed and to whom, based on a sale price that may be denominated in any unit of
     * exchange. The royalty amount is denominated and should be paid in that same unit of exchange.
     */
    function royaltyInfo(uint256 tokenId, uint256 salePrice)
        external
        view
        returns (address receiver, uint256 royaltyAmount);
}


// File erc721a/contracts/[email protected]


// ERC721A Contracts v4.0.0
// Creator: Chiru Labs



/**
 * @dev Interface of an ERC721A compliant contract.
 */
interface IERC721A {
    /**
     * The caller must own the token or be an approved operator.
     */
    error ApprovalCallerNotOwnerNorApproved();

    /**
     * The token does not exist.
     */
    error ApprovalQueryForNonexistentToken();

    /**
     * The caller cannot approve to their own address.
     */
    error ApproveToCaller();

    /**
     * The caller cannot approve to the current owner.
     */
    error ApprovalToCurrentOwner();

    /**
     * Cannot query the balance for the zero address.
     */
    error BalanceQueryForZeroAddress();

    /**
     * Cannot mint to the zero address.
     */
    error MintToZeroAddress();

    /**
     * The quantity of tokens minted must be more than zero.
     */
    error MintZeroQuantity();

    /**
     * The token does not exist.
     */
    error OwnerQueryForNonexistentToken();

    /**
     * The caller must own the token or be an approved operator.
     */
    error TransferCallerNotOwnerNorApproved();

    /**
     * The token must be owned by `from`.
     */
    error TransferFromIncorrectOwner();

    /**
     * Cannot safely transfer to a contract that does not implement the ERC721Receiver interface.
     */
    error TransferToNonERC721ReceiverImplementer();

    /**
     * Cannot transfer to the zero address.
     */
    error TransferToZeroAddress();

    /**
     * The token does not exist.
     */
    error URIQueryForNonexistentToken();

    struct TokenOwnership {
        // The address of the owner.
        address addr;
        // Keeps track of the start time of ownership with minimal overhead for tokenomics.
        uint64 startTimestamp;
        // Whether the token has been burned.
        bool burned;
    }

    /**
     * @dev Returns the total amount of tokens stored by the contract.
     *
     * Burned tokens are calculated here, use `_totalMinted()` if you want to count just minted tokens.
     */
    function totalSupply() external view returns (uint256);

    // ==============================
    //            IERC165
    // ==============================

    /**
     * @dev Returns true if this contract implements the interface defined by
     * `interfaceId`. See the corresponding
     * https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section]
     * to learn more about how these ids are created.
     *
     * This function call must use less than 30 000 gas.
     */
    function supportsInterface(bytes4 interfaceId) external view returns (bool);

    // ==============================
    //            IERC721
    // ==============================

    /**
     * @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`.
     *
     * 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;

    /**
     * @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 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 the account approved for `tokenId` token.
     *
     * Requirements:
     *
     * - `tokenId` must exist.
     */
    function getApproved(uint256 tokenId) external view returns (address operator);

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

    // ==============================
    //        IERC721Metadata
    // ==============================

    /**
     * @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 erc721a/contracts/[email protected]


// ERC721A Contracts v4.0.0
// Creator: Chiru Labs



/**
 * @dev ERC721 token receiver interface.
 */
interface ERC721A__IERC721Receiver {
    function onERC721Received(
        address operator,
        address from,
        uint256 tokenId,
        bytes calldata data
    ) external returns (bytes4);
}

/**
 * @dev Implementation of https://eips.ethereum.org/EIPS/eip-721[ERC721] Non-Fungible Token Standard, including
 * the Metadata extension. Built to optimize for lower gas during batch mints.
 *
 * Assumes serials are sequentially minted starting at _startTokenId() (defaults to 0, e.g. 0, 1, 2, 3..).
 *
 * Assumes that an owner cannot have more than 2**64 - 1 (max value of uint64) of supply.
 *
 * Assumes that the maximum token id cannot exceed 2**256 - 1 (max value of uint256).
 */
contract ERC721A is IERC721A {
    // Mask of an entry in packed address data.
    uint256 private constant BITMASK_ADDRESS_DATA_ENTRY = (1 << 64) - 1;

    // The bit position of `numberMinted` in packed address data.
    uint256 private constant BITPOS_NUMBER_MINTED = 64;

    // The bit position of `numberBurned` in packed address data.
    uint256 private constant BITPOS_NUMBER_BURNED = 128;

    // The bit position of `aux` in packed address data.
    uint256 private constant BITPOS_AUX = 192;

    // Mask of all 256 bits in packed address data except the 64 bits for `aux`.
    uint256 private constant BITMASK_AUX_COMPLEMENT = (1 << 192) - 1;

    // The bit position of `startTimestamp` in packed ownership.
    uint256 private constant BITPOS_START_TIMESTAMP = 160;

    // The bit mask of the `burned` bit in packed ownership.
    uint256 private constant BITMASK_BURNED = 1 << 224;
    
    // The bit position of the `nextInitialized` bit in packed ownership.
    uint256 private constant BITPOS_NEXT_INITIALIZED = 225;

    // The bit mask of the `nextInitialized` bit in packed ownership.
    uint256 private constant BITMASK_NEXT_INITIALIZED = 1 << 225;

    // The tokenId of the next token to be minted.
    uint256 private _currentIndex;

    // The number of tokens burned.
    uint256 private _burnCounter;

    // Token name
    string private _name;

    // Token symbol
    string private _symbol;

    // Mapping from token ID to ownership details
    // An empty struct value does not necessarily mean the token is unowned.
    // See `_packedOwnershipOf` implementation for details.
    //
    // Bits Layout:
    // - [0..159]   `addr`
    // - [160..223] `startTimestamp`
    // - [224]      `burned`
    // - [225]      `nextInitialized`
    mapping(uint256 => uint256) private _packedOwnerships;

    // Mapping owner address to address data.
    //
    // Bits Layout:
    // - [0..63]    `balance`
    // - [64..127]  `numberMinted`
    // - [128..191] `numberBurned`
    // - [192..255] `aux`
    mapping(address => uint256) private _packedAddressData;

    // 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;

    constructor(string memory name_, string memory symbol_) {
        _name = name_;
        _symbol = symbol_;
        _currentIndex = _startTokenId();
    }

    /**
     * @dev Returns the starting token ID. 
     * To change the starting token ID, please override this function.
     */
    function _startTokenId() internal view virtual returns (uint256) {
        return 0;
    }

    /**
     * @dev Returns the next token ID to be minted.
     */
    function _nextTokenId() internal view returns (uint256) {
        return _currentIndex;
    }

    /**
     * @dev Returns the total number of tokens in existence.
     * Burned tokens will reduce the count. 
     * To get the total number of tokens minted, please see `_totalMinted`.
     */
    function totalSupply() public view override returns (uint256) {
        // Counter underflow is impossible as _burnCounter cannot be incremented
        // more than `_currentIndex - _startTokenId()` times.
        unchecked {
            return _currentIndex - _burnCounter - _startTokenId();
        }
    }

    /**
     * @dev Returns the total amount of tokens minted in the contract.
     */
    function _totalMinted() internal view returns (uint256) {
        // Counter underflow is impossible as _currentIndex does not decrement,
        // and it is initialized to `_startTokenId()`
        unchecked {
            return _currentIndex - _startTokenId();
        }
    }

    /**
     * @dev Returns the total number of tokens burned.
     */
    function _totalBurned() internal view returns (uint256) {
        return _burnCounter;
    }

    /**
     * @dev See {IERC165-supportsInterface}.
     */
    function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) {
        // The interface IDs are constants representing the first 4 bytes of the XOR of
        // all function selectors in the interface. See: https://eips.ethereum.org/EIPS/eip-165
        // e.g. `bytes4(i.functionA.selector ^ i.functionB.selector ^ ...)`
        return
            interfaceId == 0x01ffc9a7 || // ERC165 interface ID for ERC165.
            interfaceId == 0x80ac58cd || // ERC165 interface ID for ERC721.
            interfaceId == 0x5b5e139f; // ERC165 interface ID for ERC721Metadata.
    }

    /**
     * @dev See {IERC721-balanceOf}.
     */
    function balanceOf(address owner) public view override returns (uint256) {
        if (owner == address(0)) revert BalanceQueryForZeroAddress();
        return _packedAddressData[owner] & BITMASK_ADDRESS_DATA_ENTRY;
    }

    /**
     * Returns the number of tokens minted by `owner`.
     */
    function _numberMinted(address owner) internal view returns (uint256) {
        return (_packedAddressData[owner] >> BITPOS_NUMBER_MINTED) & BITMASK_ADDRESS_DATA_ENTRY;
    }

    /**
     * Returns the number of tokens burned by or on behalf of `owner`.
     */
    function _numberBurned(address owner) internal view returns (uint256) {
        return (_packedAddressData[owner] >> BITPOS_NUMBER_BURNED) & BITMASK_ADDRESS_DATA_ENTRY;
    }

    /**
     * Returns the auxillary data for `owner`. (e.g. number of whitelist mint slots used).
     */
    function _getAux(address owner) internal view returns (uint64) {
        return uint64(_packedAddressData[owner] >> BITPOS_AUX);
    }

    /**
     * Sets the auxillary data for `owner`. (e.g. number of whitelist mint slots used).
     * If there are multiple variables, please pack them into a uint64.
     */
    function _setAux(address owner, uint64 aux) internal {
        uint256 packed = _packedAddressData[owner];
        uint256 auxCasted;
        assembly { // Cast aux without masking.
            auxCasted := aux
        }
        packed = (packed & BITMASK_AUX_COMPLEMENT) | (auxCasted << BITPOS_AUX);
        _packedAddressData[owner] = packed;
    }

    /**
     * Returns the packed ownership data of `tokenId`.
     */
    function _packedOwnershipOf(uint256 tokenId) private view returns (uint256) {
        uint256 curr = tokenId;

        unchecked {
            if (_startTokenId() <= curr)
                if (curr < _currentIndex) {
                    uint256 packed = _packedOwnerships[curr];
                    // If not burned.
                    if (packed & BITMASK_BURNED == 0) {
                        // Invariant:
                        // There will always be an ownership that has an address and is not burned
                        // before an ownership that does not have an address and is not burned.
                        // Hence, curr will not underflow.
                        //
                        // We can directly compare the packed value.
                        // If the address is zero, packed is zero.
                        while (packed == 0) {
                            packed = _packedOwnerships[--curr];
                        }
                        return packed;
                    }
                }
        }
        revert OwnerQueryForNonexistentToken();
    }

    /**
     * Returns the unpacked `TokenOwnership` struct from `packed`.
     */
    function _unpackedOwnership(uint256 packed) private pure returns (TokenOwnership memory ownership) {
        ownership.addr = address(uint160(packed));
        ownership.startTimestamp = uint64(packed >> BITPOS_START_TIMESTAMP);
        ownership.burned = packed & BITMASK_BURNED != 0;
    }

    /**
     * Returns the unpacked `TokenOwnership` struct at `index`.
     */
    function _ownershipAt(uint256 index) internal view returns (TokenOwnership memory) {
        return _unpackedOwnership(_packedOwnerships[index]);
    }

    /**
     * @dev Initializes the ownership slot minted at `index` for efficiency purposes.
     */
    function _initializeOwnershipAt(uint256 index) internal {
        if (_packedOwnerships[index] == 0) {
            _packedOwnerships[index] = _packedOwnershipOf(index);
        }
    }

    /**
     * Gas spent here starts off proportional to the maximum mint batch size.
     * It gradually moves to O(1) as tokens get transferred around in the collection over time.
     */
    function _ownershipOf(uint256 tokenId) internal view returns (TokenOwnership memory) {
        return _unpackedOwnership(_packedOwnershipOf(tokenId));
    }

    /**
     * @dev See {IERC721-ownerOf}.
     */
    function ownerOf(uint256 tokenId) public view override returns (address) {
        return address(uint160(_packedOwnershipOf(tokenId)));
    }

    /**
     * @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) {
        if (!_exists(tokenId)) revert URIQueryForNonexistentToken();

        string memory baseURI = _baseURI();
        return bytes(baseURI).length != 0 ? string(abi.encodePacked(baseURI, _toString(tokenId))) : '';
    }

    /**
     * @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 Casts the address to uint256 without masking.
     */
    function _addressToUint256(address value) private pure returns (uint256 result) {
        assembly {
            result := value
        }
    }

    /**
     * @dev Casts the boolean to uint256 without branching.
     */
    function _boolToUint256(bool value) private pure returns (uint256 result) {
        assembly {
            result := value
        }
    }

    /**
     * @dev See {IERC721-approve}.
     */
    function approve(address to, uint256 tokenId) public override {
        address owner = address(uint160(_packedOwnershipOf(tokenId)));
        if (to == owner) revert ApprovalToCurrentOwner();

        if (_msgSenderERC721A() != owner)
            if (!isApprovedForAll(owner, _msgSenderERC721A())) {
                revert ApprovalCallerNotOwnerNorApproved();
            }

        _tokenApprovals[tokenId] = to;
        emit Approval(owner, to, tokenId);
    }

    /**
     * @dev See {IERC721-getApproved}.
     */
    function getApproved(uint256 tokenId) public view override returns (address) {
        if (!_exists(tokenId)) revert ApprovalQueryForNonexistentToken();

        return _tokenApprovals[tokenId];
    }

    /**
     * @dev See {IERC721-setApprovalForAll}.
     */
    function setApprovalForAll(address operator, bool approved) public virtual override {
        if (operator == _msgSenderERC721A()) revert ApproveToCaller();

        _operatorApprovals[_msgSenderERC721A()][operator] = approved;
        emit ApprovalForAll(_msgSenderERC721A(), 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 {
        _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 {
        _transfer(from, to, tokenId);
        if (to.code.length != 0)
            if (!_checkContractOnERC721Received(from, to, tokenId, _data)) {
                revert TransferToNonERC721ReceiverImplementer();
            }
    }

    /**
     * @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`),
     */
    function _exists(uint256 tokenId) internal view returns (bool) {
        return
            _startTokenId() <= tokenId &&
            tokenId < _currentIndex && // If within bounds,
            _packedOwnerships[tokenId] & BITMASK_BURNED == 0; // and not burned.
    }

    /**
     * @dev Equivalent to `_safeMint(to, quantity, '')`.
     */
    function _safeMint(address to, uint256 quantity) internal {
        _safeMint(to, quantity, '');
    }

    /**
     * @dev Safely mints `quantity` tokens and transfers them to `to`.
     *
     * Requirements:
     *
     * - If `to` refers to a smart contract, it must implement
     *   {IERC721Receiver-onERC721Received}, which is called for each safe transfer.
     * - `quantity` must be greater than 0.
     *
     * Emits a {Transfer} event.
     */
    function _safeMint(
        address to,
        uint256 quantity,
        bytes memory _data
    ) internal {
        uint256 startTokenId = _currentIndex;
        if (to == address(0)) revert MintToZeroAddress();
        if (quantity == 0) revert MintZeroQuantity();

        _beforeTokenTransfers(address(0), to, startTokenId, quantity);

        // Overflows are incredibly unrealistic.
        // balance or numberMinted overflow if current value of either + quantity > 1.8e19 (2**64) - 1
        // updatedIndex overflows if _currentIndex + quantity > 1.2e77 (2**256) - 1
        unchecked {
            // Updates:
            // - `balance += quantity`.
            // - `numberMinted += quantity`.
            //
            // We can directly add to the balance and number minted.
            _packedAddressData[to] += quantity * ((1 << BITPOS_NUMBER_MINTED) | 1);

            // Updates:
            // - `address` to the owner.
            // - `startTimestamp` to the timestamp of minting.
            // - `burned` to `false`.
            // - `nextInitialized` to `quantity == 1`.
            _packedOwnerships[startTokenId] =
                _addressToUint256(to) |
                (block.timestamp << BITPOS_START_TIMESTAMP) |
                (_boolToUint256(quantity == 1) << BITPOS_NEXT_INITIALIZED);

            uint256 updatedIndex = startTokenId;
            uint256 end = updatedIndex + quantity;

            if (to.code.length != 0) {
                do {
                    emit Transfer(address(0), to, updatedIndex);
                    if (!_checkContractOnERC721Received(address(0), to, updatedIndex++, _data)) {
                        revert TransferToNonERC721ReceiverImplementer();
                    }
                } while (updatedIndex < end);
                // Reentrancy protection
                if (_currentIndex != startTokenId) revert();
            } else {
                do {
                    emit Transfer(address(0), to, updatedIndex++);
                } while (updatedIndex < end);
            }
            _currentIndex = updatedIndex;
        }
        _afterTokenTransfers(address(0), to, startTokenId, quantity);
    }

    /**
     * @dev Mints `quantity` tokens and transfers them to `to`.
     *
     * Requirements:
     *
     * - `to` cannot be the zero address.
     * - `quantity` must be greater than 0.
     *
     * Emits a {Transfer} event.
     */
    function _mint(address to, uint256 quantity) internal {
        uint256 startTokenId = _currentIndex;
        if (to == address(0)) revert MintToZeroAddress();
        if (quantity == 0) revert MintZeroQuantity();

        _beforeTokenTransfers(address(0), to, startTokenId, quantity);

        // Overflows are incredibly unrealistic.
        // balance or numberMinted overflow if current value of either + quantity > 1.8e19 (2**64) - 1
        // updatedIndex overflows if _currentIndex + quantity > 1.2e77 (2**256) - 1
        unchecked {
            // Updates:
            // - `balance += quantity`.
            // - `numberMinted += quantity`.
            //
            // We can directly add to the balance and number minted.
            _packedAddressData[to] += quantity * ((1 << BITPOS_NUMBER_MINTED) | 1);

            // Updates:
            // - `address` to the owner.
            // - `startTimestamp` to the timestamp of minting.
            // - `burned` to `false`.
            // - `nextInitialized` to `quantity == 1`.
            _packedOwnerships[startTokenId] =
                _addressToUint256(to) |
                (block.timestamp << BITPOS_START_TIMESTAMP) |
                (_boolToUint256(quantity == 1) << BITPOS_NEXT_INITIALIZED);

            uint256 updatedIndex = startTokenId;
            uint256 end = updatedIndex + quantity;

            do {
                emit Transfer(address(0), to, updatedIndex++);
            } while (updatedIndex < end);

            _currentIndex = updatedIndex;
        }
        _afterTokenTransfers(address(0), to, startTokenId, quantity);
    }

    /**
     * @dev Transfers `tokenId` from `from` to `to`.
     *
     * 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
    ) private {
        uint256 prevOwnershipPacked = _packedOwnershipOf(tokenId);

        if (address(uint160(prevOwnershipPacked)) != from) revert TransferFromIncorrectOwner();

        bool isApprovedOrOwner = (_msgSenderERC721A() == from ||
            isApprovedForAll(from, _msgSenderERC721A()) ||
            getApproved(tokenId) == _msgSenderERC721A());

        if (!isApprovedOrOwner) revert TransferCallerNotOwnerNorApproved();
        if (to == address(0)) revert TransferToZeroAddress();

        _beforeTokenTransfers(from, to, tokenId, 1);

        // Clear approvals from the previous owner.
        delete _tokenApprovals[tokenId];

        // Underflow of the sender's balance is impossible because we check for
        // ownership above and the recipient's balance can't realistically overflow.
        // Counter overflow is incredibly unrealistic as tokenId would have to be 2**256.
        unchecked {
            // We can directly increment and decrement the balances.
            --_packedAddressData[from]; // Updates: `balance -= 1`.
            ++_packedAddressData[to]; // Updates: `balance += 1`.

            // Updates:
            // - `address` to the next owner.
            // - `startTimestamp` to the timestamp of transfering.
            // - `burned` to `false`.
            // - `nextInitialized` to `true`.
            _packedOwnerships[tokenId] =
                _addressToUint256(to) |
                (block.timestamp << BITPOS_START_TIMESTAMP) |
                BITMASK_NEXT_INITIALIZED;

            // If the next slot may not have been initialized (i.e. `nextInitialized == false`) .
            if (prevOwnershipPacked & BITMASK_NEXT_INITIALIZED == 0) {
                uint256 nextTokenId = tokenId + 1;
                // If the next slot's address is zero and not burned (i.e. packed value is zero).
                if (_packedOwnerships[nextTokenId] == 0) {
                    // If the next slot is within bounds.
                    if (nextTokenId != _currentIndex) {
                        // Initialize the next slot to maintain correctness for `ownerOf(tokenId + 1)`.
                        _packedOwnerships[nextTokenId] = prevOwnershipPacked;
                    }
                }
            }
        }

        emit Transfer(from, to, tokenId);
        _afterTokenTransfers(from, to, tokenId, 1);
    }

    /**
     * @dev Equivalent to `_burn(tokenId, false)`.
     */
    function _burn(uint256 tokenId) internal virtual {
        _burn(tokenId, false);
    }

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

        address from = address(uint160(prevOwnershipPacked));

        if (approvalCheck) {
            bool isApprovedOrOwner = (_msgSenderERC721A() == from ||
                isApprovedForAll(from, _msgSenderERC721A()) ||
                getApproved(tokenId) == _msgSenderERC721A());

            if (!isApprovedOrOwner) revert TransferCallerNotOwnerNorApproved();
        }

        _beforeTokenTransfers(from, address(0), tokenId, 1);

        // Clear approvals from the previous owner.
        delete _tokenApprovals[tokenId];

        // Underflow of the sender's balance is impossible because we check for
        // ownership above and the recipient's balance can't realistically overflow.
        // Counter overflow is incredibly unrealistic as tokenId would have to be 2**256.
        unchecked {
            // Updates:
            // - `balance -= 1`.
            // - `numberBurned += 1`.
            //
            // We can directly decrement the balance, and increment the number burned.
            // This is equivalent to `packed -= 1; packed += 1 << BITPOS_NUMBER_BURNED;`.
            _packedAddressData[from] += (1 << BITPOS_NUMBER_BURNED) - 1;

            // Updates:
            // - `address` to the last owner.
            // - `startTimestamp` to the timestamp of burning.
            // - `burned` to `true`.
            // - `nextInitialized` to `true`.
            _packedOwnerships[tokenId] =
                _addressToUint256(from) |
                (block.timestamp << BITPOS_START_TIMESTAMP) |
                BITMASK_BURNED | 
                BITMASK_NEXT_INITIALIZED;

            // If the next slot may not have been initialized (i.e. `nextInitialized == false`) .
            if (prevOwnershipPacked & BITMASK_NEXT_INITIALIZED == 0) {
                uint256 nextTokenId = tokenId + 1;
                // If the next slot's address is zero and not burned (i.e. packed value is zero).
                if (_packedOwnerships[nextTokenId] == 0) {
                    // If the next slot is within bounds.
                    if (nextTokenId != _currentIndex) {
                        // Initialize the next slot to maintain correctness for `ownerOf(tokenId + 1)`.
                        _packedOwnerships[nextTokenId] = prevOwnershipPacked;
                    }
                }
            }
        }

        emit Transfer(from, address(0), tokenId);
        _afterTokenTransfers(from, address(0), tokenId, 1);

        // Overflow not possible, as _burnCounter cannot be exceed _currentIndex times.
        unchecked {
            _burnCounter++;
        }
    }

    /**
     * @dev Internal function to invoke {IERC721Receiver-onERC721Received} on a target 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 _checkContractOnERC721Received(
        address from,
        address to,
        uint256 tokenId,
        bytes memory _data
    ) private returns (bool) {
        try ERC721A__IERC721Receiver(to).onERC721Received(_msgSenderERC721A(), from, tokenId, _data) returns (
            bytes4 retval
        ) {
            return retval == ERC721A__IERC721Receiver(to).onERC721Received.selector;
        } catch (bytes memory reason) {
            if (reason.length == 0) {
                revert TransferToNonERC721ReceiverImplementer();
            } else {
                assembly {
                    revert(add(32, reason), mload(reason))
                }
            }
        }
    }

    /**
     * @dev Hook that is called before a set of serially-ordered token ids are about to be transferred. This includes minting.
     * And also called before burning one token.
     *
     * startTokenId - the first token id to be transferred
     * quantity - the amount to be transferred
     *
     * 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, `tokenId` will be burned by `from`.
     * - `from` and `to` are never both zero.
     */
    function _beforeTokenTransfers(
        address from,
        address to,
        uint256 startTokenId,
        uint256 quantity
    ) internal virtual {}

    /**
     * @dev Hook that is called after a set of serially-ordered token ids have been transferred. This includes
     * minting.
     * And also called after one token has been burned.
     *
     * startTokenId - the first token id to be transferred
     * quantity - the amount to be transferred
     *
     * Calling conditions:
     *
     * - When `from` and `to` are both non-zero, `from`'s `tokenId` has been
     * transferred to `to`.
     * - When `from` is zero, `tokenId` has been minted for `to`.
     * - When `to` is zero, `tokenId` has been burned by `from`.
     * - `from` and `to` are never both zero.
     */
    function _afterTokenTransfers(
        address from,
        address to,
        uint256 startTokenId,
        uint256 quantity
    ) internal virtual {}

    /**
     * @dev Returns the message sender (defaults to `msg.sender`).
     *
     * If you are writing GSN compatible contracts, you need to override this function.
     */
    function _msgSenderERC721A() internal view virtual returns (address) {
        return msg.sender;
    }

    /**
     * @dev Converts a `uint256` to its ASCII `string` decimal representation.
     */
    function _toString(uint256 value) internal pure returns (string memory ptr) {
        assembly {
            // The maximum value of a uint256 contains 78 digits (1 byte per digit), 
            // but we allocate 128 bytes to keep the free memory pointer 32-byte word aliged.
            // We will need 1 32-byte word to store the length, 
            // and 3 32-byte words to store a maximum of 78 digits. Total: 32 + 3 * 32 = 128.
            ptr := add(mload(0x40), 128)
            // Update the free memory pointer to allocate.
            mstore(0x40, ptr)

            // Cache the end of the memory to calculate the length later.
            let end := ptr

            // We write the string from the rightmost digit to the leftmost digit.
            // The following is essentially a do-while loop that also handles the zero case.
            // Costs a bit more than early returning for the zero case,
            // but cheaper in terms of deployment and overall runtime costs.
            for { 
                // Initialize and perform the first pass without check.
                let temp := value
                // Move the pointer 1 byte leftwards to point to an empty character slot.
                ptr := sub(ptr, 1)
                // Write the character to the pointer. 48 is the ASCII index of '0'.
                mstore8(ptr, add(48, mod(temp, 10)))
                temp := div(temp, 10)
            } temp { 
                // Keep dividing `temp` until zero.
                temp := div(temp, 10)
            } { // Body of the for loop.
                ptr := sub(ptr, 1)
                mstore8(ptr, add(48, mod(temp, 10)))
            }
            
            let length := sub(end, ptr)
            // Move the pointer 32 bytes leftwards to make room for the length.
            ptr := sub(ptr, 32)
            // Store the length.
            mstore(ptr, length)
        }
    }
}


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


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



/**
 * @dev Interface of the ERC20 standard as defined in the EIP.
 */
interface IERC20 {
    /**
     * @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);

    /**
     * @dev Returns the amount of tokens in existence.
     */
    function totalSupply() external view returns (uint256);

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

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

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

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

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


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


// OpenZeppelin Contracts v4.4.1 (utils/Context.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 Context {
    function _msgSender() internal view virtual returns (address) {
        return msg.sender;
    }

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


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


// OpenZeppelin Contracts v4.4.1 (access/Ownable.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 Ownable is Context {
    address private _owner;

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

    /**
     * @dev Initializes the contract setting the deployer as the initial owner.
     */
    constructor() {
        _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);
    }
}


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


// OpenZeppelin Contracts (last updated v4.5.0) (utils/Address.sol)



/**
 * @dev Collection of functions related to the address type
 */
library Address {
    /**
     * @dev Returns true if `account` is a contract.
     *
     * [IMPORTANT]
     * ====
     * It is unsafe to assume that an address for which this function returns
     * false is an externally-owned account (EOA) and not a contract.
     *
     * Among others, `isContract` will return false for the following
     * types of addresses:
     *
     *  - an externally-owned account
     *  - a contract in construction
     *  - an address where a contract will be created
     *  - an address where a contract lived, but was destroyed
     * ====
     *
     * [IMPORTANT]
     * ====
     * You shouldn't rely on `isContract` to protect against flash loan attacks!
     *
     * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets
     * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract
     * constructor.
     * ====
     */
    function isContract(address account) internal view returns (bool) {
        // This method relies on extcodesize/address.code.length, which returns 0
        // for contracts in construction, since the code is only stored at the end
        // of the constructor execution.

        return account.code.length > 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 Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but performing a delegate call.
     *
     * _Available since v3.4._
     */
    function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {
        return functionDelegateCall(target, data, "Address: low-level delegate call failed");
    }

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

        (bool success, bytes memory returndata) = target.delegatecall(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 @openzeppelin/contracts/utils/[email protected]


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



/**
 * @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 hardhat/[email protected]




library console {
	address constant CONSOLE_ADDRESS = address(0x000000000000000000636F6e736F6c652e6c6f67);

	function _sendLogPayload(bytes memory payload) private view {
		uint256 payloadLength = payload.length;
		address consoleAddress = CONSOLE_ADDRESS;
		assembly {
			let payloadStart := add(payload, 32)
			let r := staticcall(gas(), consoleAddress, payloadStart, payloadLength, 0, 0)
		}
	}

	function log() internal view {
		_sendLogPayload(abi.encodeWithSignature("log()"));
	}

	function logInt(int p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(int)", p0));
	}

	function logUint(uint p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint)", p0));
	}

	function logString(string memory p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string)", p0));
	}

	function logBool(bool p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool)", p0));
	}

	function logAddress(address p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address)", p0));
	}

	function logBytes(bytes memory p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes)", p0));
	}

	function logBytes1(bytes1 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes1)", p0));
	}

	function logBytes2(bytes2 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes2)", p0));
	}

	function logBytes3(bytes3 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes3)", p0));
	}

	function logBytes4(bytes4 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes4)", p0));
	}

	function logBytes5(bytes5 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes5)", p0));
	}

	function logBytes6(bytes6 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes6)", p0));
	}

	function logBytes7(bytes7 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes7)", p0));
	}

	function logBytes8(bytes8 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes8)", p0));
	}

	function logBytes9(bytes9 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes9)", p0));
	}

	function logBytes10(bytes10 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes10)", p0));
	}

	function logBytes11(bytes11 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes11)", p0));
	}

	function logBytes12(bytes12 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes12)", p0));
	}

	function logBytes13(bytes13 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes13)", p0));
	}

	function logBytes14(bytes14 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes14)", p0));
	}

	function logBytes15(bytes15 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes15)", p0));
	}

	function logBytes16(bytes16 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes16)", p0));
	}

	function logBytes17(bytes17 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes17)", p0));
	}

	function logBytes18(bytes18 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes18)", p0));
	}

	function logBytes19(bytes19 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes19)", p0));
	}

	function logBytes20(bytes20 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes20)", p0));
	}

	function logBytes21(bytes21 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes21)", p0));
	}

	function logBytes22(bytes22 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes22)", p0));
	}

	function logBytes23(bytes23 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes23)", p0));
	}

	function logBytes24(bytes24 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes24)", p0));
	}

	function logBytes25(bytes25 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes25)", p0));
	}

	function logBytes26(bytes26 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes26)", p0));
	}

	function logBytes27(bytes27 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes27)", p0));
	}

	function logBytes28(bytes28 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes28)", p0));
	}

	function logBytes29(bytes29 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes29)", p0));
	}

	function logBytes30(bytes30 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes30)", p0));
	}

	function logBytes31(bytes31 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes31)", p0));
	}

	function logBytes32(bytes32 p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bytes32)", p0));
	}

	function log(uint p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint)", p0));
	}

	function log(string memory p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string)", p0));
	}

	function log(bool p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool)", p0));
	}

	function log(address p0) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address)", p0));
	}

	function log(uint p0, uint p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint)", p0, p1));
	}

	function log(uint p0, string memory p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string)", p0, p1));
	}

	function log(uint p0, bool p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool)", p0, p1));
	}

	function log(uint p0, address p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address)", p0, p1));
	}

	function log(string memory p0, uint p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint)", p0, p1));
	}

	function log(string memory p0, string memory p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string)", p0, p1));
	}

	function log(string memory p0, bool p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool)", p0, p1));
	}

	function log(string memory p0, address p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address)", p0, p1));
	}

	function log(bool p0, uint p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint)", p0, p1));
	}

	function log(bool p0, string memory p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string)", p0, p1));
	}

	function log(bool p0, bool p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool)", p0, p1));
	}

	function log(bool p0, address p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address)", p0, p1));
	}

	function log(address p0, uint p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint)", p0, p1));
	}

	function log(address p0, string memory p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string)", p0, p1));
	}

	function log(address p0, bool p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool)", p0, p1));
	}

	function log(address p0, address p1) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address)", p0, p1));
	}

	function log(uint p0, uint p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,uint)", p0, p1, p2));
	}

	function log(uint p0, uint p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,string)", p0, p1, p2));
	}

	function log(uint p0, uint p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,bool)", p0, p1, p2));
	}

	function log(uint p0, uint p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,address)", p0, p1, p2));
	}

	function log(uint p0, string memory p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,uint)", p0, p1, p2));
	}

	function log(uint p0, string memory p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,string)", p0, p1, p2));
	}

	function log(uint p0, string memory p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,bool)", p0, p1, p2));
	}

	function log(uint p0, string memory p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,address)", p0, p1, p2));
	}

	function log(uint p0, bool p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,uint)", p0, p1, p2));
	}

	function log(uint p0, bool p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,string)", p0, p1, p2));
	}

	function log(uint p0, bool p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,bool)", p0, p1, p2));
	}

	function log(uint p0, bool p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,address)", p0, p1, p2));
	}

	function log(uint p0, address p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,uint)", p0, p1, p2));
	}

	function log(uint p0, address p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,string)", p0, p1, p2));
	}

	function log(uint p0, address p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,bool)", p0, p1, p2));
	}

	function log(uint p0, address p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,address)", p0, p1, p2));
	}

	function log(string memory p0, uint p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,uint)", p0, p1, p2));
	}

	function log(string memory p0, uint p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,string)", p0, p1, p2));
	}

	function log(string memory p0, uint p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,bool)", p0, p1, p2));
	}

	function log(string memory p0, uint p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,address)", p0, p1, p2));
	}

	function log(string memory p0, string memory p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,uint)", p0, p1, p2));
	}

	function log(string memory p0, string memory p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,string)", p0, p1, p2));
	}

	function log(string memory p0, string memory p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,bool)", p0, p1, p2));
	}

	function log(string memory p0, string memory p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,address)", p0, p1, p2));
	}

	function log(string memory p0, bool p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,uint)", p0, p1, p2));
	}

	function log(string memory p0, bool p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,string)", p0, p1, p2));
	}

	function log(string memory p0, bool p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,bool)", p0, p1, p2));
	}

	function log(string memory p0, bool p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,address)", p0, p1, p2));
	}

	function log(string memory p0, address p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,uint)", p0, p1, p2));
	}

	function log(string memory p0, address p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,string)", p0, p1, p2));
	}

	function log(string memory p0, address p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,bool)", p0, p1, p2));
	}

	function log(string memory p0, address p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,address)", p0, p1, p2));
	}

	function log(bool p0, uint p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,uint)", p0, p1, p2));
	}

	function log(bool p0, uint p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,string)", p0, p1, p2));
	}

	function log(bool p0, uint p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,bool)", p0, p1, p2));
	}

	function log(bool p0, uint p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,address)", p0, p1, p2));
	}

	function log(bool p0, string memory p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,uint)", p0, p1, p2));
	}

	function log(bool p0, string memory p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,string)", p0, p1, p2));
	}

	function log(bool p0, string memory p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,bool)", p0, p1, p2));
	}

	function log(bool p0, string memory p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,address)", p0, p1, p2));
	}

	function log(bool p0, bool p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,uint)", p0, p1, p2));
	}

	function log(bool p0, bool p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,string)", p0, p1, p2));
	}

	function log(bool p0, bool p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,bool)", p0, p1, p2));
	}

	function log(bool p0, bool p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,address)", p0, p1, p2));
	}

	function log(bool p0, address p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,uint)", p0, p1, p2));
	}

	function log(bool p0, address p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,string)", p0, p1, p2));
	}

	function log(bool p0, address p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,bool)", p0, p1, p2));
	}

	function log(bool p0, address p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,address)", p0, p1, p2));
	}

	function log(address p0, uint p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,uint)", p0, p1, p2));
	}

	function log(address p0, uint p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,string)", p0, p1, p2));
	}

	function log(address p0, uint p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,bool)", p0, p1, p2));
	}

	function log(address p0, uint p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,address)", p0, p1, p2));
	}

	function log(address p0, string memory p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,uint)", p0, p1, p2));
	}

	function log(address p0, string memory p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,string)", p0, p1, p2));
	}

	function log(address p0, string memory p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,bool)", p0, p1, p2));
	}

	function log(address p0, string memory p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,address)", p0, p1, p2));
	}

	function log(address p0, bool p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,uint)", p0, p1, p2));
	}

	function log(address p0, bool p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,string)", p0, p1, p2));
	}

	function log(address p0, bool p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,bool)", p0, p1, p2));
	}

	function log(address p0, bool p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,address)", p0, p1, p2));
	}

	function log(address p0, address p1, uint p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,uint)", p0, p1, p2));
	}

	function log(address p0, address p1, string memory p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,string)", p0, p1, p2));
	}

	function log(address p0, address p1, bool p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,bool)", p0, p1, p2));
	}

	function log(address p0, address p1, address p2) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,address)", p0, p1, p2));
	}

	function log(uint p0, uint p1, uint p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,uint,uint)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, uint p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,uint,string)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, uint p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,uint,bool)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, uint p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,uint,address)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, string memory p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,string,uint)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, string memory p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,string,string)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, string memory p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,string,bool)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, string memory p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,string,address)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, bool p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,bool,uint)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, bool p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,bool,string)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, bool p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,bool,bool)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, bool p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,bool,address)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, address p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,address,uint)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, address p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,address,string)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, address p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,address,bool)", p0, p1, p2, p3));
	}

	function log(uint p0, uint p1, address p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,uint,address,address)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, uint p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,uint,uint)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, uint p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,uint,string)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, uint p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,uint,bool)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, uint p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,uint,address)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, string memory p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,string,uint)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, string memory p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,string,string)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, string memory p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,string,bool)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, string memory p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,string,address)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, bool p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,bool,uint)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, bool p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,bool,string)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, bool p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,bool,bool)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, bool p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,bool,address)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, address p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,address,uint)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, address p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,address,string)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, address p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,address,bool)", p0, p1, p2, p3));
	}

	function log(uint p0, string memory p1, address p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,string,address,address)", p0, p1, p2, p3));
	}

	function log(uint p0, bool p1, uint p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,uint,uint)", p0, p1, p2, p3));
	}

	function log(uint p0, bool p1, uint p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,uint,string)", p0, p1, p2, p3));
	}

	function log(uint p0, bool p1, uint p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,uint,bool)", p0, p1, p2, p3));
	}

	function log(uint p0, bool p1, uint p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,uint,address)", p0, p1, p2, p3));
	}

	function log(uint p0, bool p1, string memory p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,string,uint)", p0, p1, p2, p3));
	}

	function log(uint p0, bool p1, string memory p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,string,string)", p0, p1, p2, p3));
	}

	function log(uint p0, bool p1, string memory p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,string,bool)", p0, p1, p2, p3));
	}

	function log(uint p0, bool p1, string memory p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,string,address)", p0, p1, p2, p3));
	}

	function log(uint p0, bool p1, bool p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,bool,uint)", p0, p1, p2, p3));
	}

	function log(uint p0, bool p1, bool p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,bool,string)", p0, p1, p2, p3));
	}

	function log(uint p0, bool p1, bool p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,bool,bool)", p0, p1, p2, p3));
	}

	function log(uint p0, bool p1, bool p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,bool,address)", p0, p1, p2, p3));
	}

	function log(uint p0, bool p1, address p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,address,uint)", p0, p1, p2, p3));
	}

	function log(uint p0, bool p1, address p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,address,string)", p0, p1, p2, p3));
	}

	function log(uint p0, bool p1, address p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,address,bool)", p0, p1, p2, p3));
	}

	function log(uint p0, bool p1, address p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,bool,address,address)", p0, p1, p2, p3));
	}

	function log(uint p0, address p1, uint p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,uint,uint)", p0, p1, p2, p3));
	}

	function log(uint p0, address p1, uint p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,uint,string)", p0, p1, p2, p3));
	}

	function log(uint p0, address p1, uint p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,uint,bool)", p0, p1, p2, p3));
	}

	function log(uint p0, address p1, uint p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,uint,address)", p0, p1, p2, p3));
	}

	function log(uint p0, address p1, string memory p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,string,uint)", p0, p1, p2, p3));
	}

	function log(uint p0, address p1, string memory p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,string,string)", p0, p1, p2, p3));
	}

	function log(uint p0, address p1, string memory p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,string,bool)", p0, p1, p2, p3));
	}

	function log(uint p0, address p1, string memory p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,string,address)", p0, p1, p2, p3));
	}

	function log(uint p0, address p1, bool p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,bool,uint)", p0, p1, p2, p3));
	}

	function log(uint p0, address p1, bool p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,bool,string)", p0, p1, p2, p3));
	}

	function log(uint p0, address p1, bool p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,bool,bool)", p0, p1, p2, p3));
	}

	function log(uint p0, address p1, bool p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,bool,address)", p0, p1, p2, p3));
	}

	function log(uint p0, address p1, address p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,address,uint)", p0, p1, p2, p3));
	}

	function log(uint p0, address p1, address p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,address,string)", p0, p1, p2, p3));
	}

	function log(uint p0, address p1, address p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,address,bool)", p0, p1, p2, p3));
	}

	function log(uint p0, address p1, address p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(uint,address,address,address)", p0, p1, p2, p3));
	}

	function log(string memory p0, uint p1, uint p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,uint,uint)", p0, p1, p2, p3));
	}

	function log(string memory p0, uint p1, uint p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,uint,string)", p0, p1, p2, p3));
	}

	function log(string memory p0, uint p1, uint p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,uint,bool)", p0, p1, p2, p3));
	}

	function log(string memory p0, uint p1, uint p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,uint,address)", p0, p1, p2, p3));
	}

	function log(string memory p0, uint p1, string memory p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,string,uint)", p0, p1, p2, p3));
	}

	function log(string memory p0, uint p1, string memory p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,string,string)", p0, p1, p2, p3));
	}

	function log(string memory p0, uint p1, string memory p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,string,bool)", p0, p1, p2, p3));
	}

	function log(string memory p0, uint p1, string memory p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,string,address)", p0, p1, p2, p3));
	}

	function log(string memory p0, uint p1, bool p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,bool,uint)", p0, p1, p2, p3));
	}

	function log(string memory p0, uint p1, bool p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,bool,string)", p0, p1, p2, p3));
	}

	function log(string memory p0, uint p1, bool p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,bool,bool)", p0, p1, p2, p3));
	}

	function log(string memory p0, uint p1, bool p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,bool,address)", p0, p1, p2, p3));
	}

	function log(string memory p0, uint p1, address p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,address,uint)", p0, p1, p2, p3));
	}

	function log(string memory p0, uint p1, address p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,address,string)", p0, p1, p2, p3));
	}

	function log(string memory p0, uint p1, address p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,address,bool)", p0, p1, p2, p3));
	}

	function log(string memory p0, uint p1, address p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,uint,address,address)", p0, p1, p2, p3));
	}

	function log(string memory p0, string memory p1, uint p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,uint,uint)", p0, p1, p2, p3));
	}

	function log(string memory p0, string memory p1, uint p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,uint,string)", p0, p1, p2, p3));
	}

	function log(string memory p0, string memory p1, uint p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,uint,bool)", p0, p1, p2, p3));
	}

	function log(string memory p0, string memory p1, uint p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,uint,address)", p0, p1, p2, p3));
	}

	function log(string memory p0, string memory p1, string memory p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,string,uint)", p0, p1, p2, p3));
	}

	function log(string memory p0, string memory p1, string memory p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,string,string)", p0, p1, p2, p3));
	}

	function log(string memory p0, string memory p1, string memory p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,string,bool)", p0, p1, p2, p3));
	}

	function log(string memory p0, string memory p1, string memory p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,string,address)", p0, p1, p2, p3));
	}

	function log(string memory p0, string memory p1, bool p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,bool,uint)", p0, p1, p2, p3));
	}

	function log(string memory p0, string memory p1, bool p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,bool,string)", p0, p1, p2, p3));
	}

	function log(string memory p0, string memory p1, bool p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,bool,bool)", p0, p1, p2, p3));
	}

	function log(string memory p0, string memory p1, bool p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,bool,address)", p0, p1, p2, p3));
	}

	function log(string memory p0, string memory p1, address p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,address,uint)", p0, p1, p2, p3));
	}

	function log(string memory p0, string memory p1, address p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,address,string)", p0, p1, p2, p3));
	}

	function log(string memory p0, string memory p1, address p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,address,bool)", p0, p1, p2, p3));
	}

	function log(string memory p0, string memory p1, address p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,string,address,address)", p0, p1, p2, p3));
	}

	function log(string memory p0, bool p1, uint p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,uint,uint)", p0, p1, p2, p3));
	}

	function log(string memory p0, bool p1, uint p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,uint,string)", p0, p1, p2, p3));
	}

	function log(string memory p0, bool p1, uint p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,uint,bool)", p0, p1, p2, p3));
	}

	function log(string memory p0, bool p1, uint p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,uint,address)", p0, p1, p2, p3));
	}

	function log(string memory p0, bool p1, string memory p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,string,uint)", p0, p1, p2, p3));
	}

	function log(string memory p0, bool p1, string memory p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,string,string)", p0, p1, p2, p3));
	}

	function log(string memory p0, bool p1, string memory p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,string,bool)", p0, p1, p2, p3));
	}

	function log(string memory p0, bool p1, string memory p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,string,address)", p0, p1, p2, p3));
	}

	function log(string memory p0, bool p1, bool p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,bool,uint)", p0, p1, p2, p3));
	}

	function log(string memory p0, bool p1, bool p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,bool,string)", p0, p1, p2, p3));
	}

	function log(string memory p0, bool p1, bool p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,bool,bool)", p0, p1, p2, p3));
	}

	function log(string memory p0, bool p1, bool p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,bool,address)", p0, p1, p2, p3));
	}

	function log(string memory p0, bool p1, address p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,address,uint)", p0, p1, p2, p3));
	}

	function log(string memory p0, bool p1, address p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,address,string)", p0, p1, p2, p3));
	}

	function log(string memory p0, bool p1, address p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,address,bool)", p0, p1, p2, p3));
	}

	function log(string memory p0, bool p1, address p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,bool,address,address)", p0, p1, p2, p3));
	}

	function log(string memory p0, address p1, uint p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,uint,uint)", p0, p1, p2, p3));
	}

	function log(string memory p0, address p1, uint p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,uint,string)", p0, p1, p2, p3));
	}

	function log(string memory p0, address p1, uint p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,uint,bool)", p0, p1, p2, p3));
	}

	function log(string memory p0, address p1, uint p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,uint,address)", p0, p1, p2, p3));
	}

	function log(string memory p0, address p1, string memory p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,string,uint)", p0, p1, p2, p3));
	}

	function log(string memory p0, address p1, string memory p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,string,string)", p0, p1, p2, p3));
	}

	function log(string memory p0, address p1, string memory p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,string,bool)", p0, p1, p2, p3));
	}

	function log(string memory p0, address p1, string memory p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,string,address)", p0, p1, p2, p3));
	}

	function log(string memory p0, address p1, bool p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,bool,uint)", p0, p1, p2, p3));
	}

	function log(string memory p0, address p1, bool p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,bool,string)", p0, p1, p2, p3));
	}

	function log(string memory p0, address p1, bool p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,bool,bool)", p0, p1, p2, p3));
	}

	function log(string memory p0, address p1, bool p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,bool,address)", p0, p1, p2, p3));
	}

	function log(string memory p0, address p1, address p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,address,uint)", p0, p1, p2, p3));
	}

	function log(string memory p0, address p1, address p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,address,string)", p0, p1, p2, p3));
	}

	function log(string memory p0, address p1, address p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,address,bool)", p0, p1, p2, p3));
	}

	function log(string memory p0, address p1, address p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(string,address,address,address)", p0, p1, p2, p3));
	}

	function log(bool p0, uint p1, uint p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,uint,uint)", p0, p1, p2, p3));
	}

	function log(bool p0, uint p1, uint p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,uint,string)", p0, p1, p2, p3));
	}

	function log(bool p0, uint p1, uint p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,uint,bool)", p0, p1, p2, p3));
	}

	function log(bool p0, uint p1, uint p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,uint,address)", p0, p1, p2, p3));
	}

	function log(bool p0, uint p1, string memory p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,string,uint)", p0, p1, p2, p3));
	}

	function log(bool p0, uint p1, string memory p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,string,string)", p0, p1, p2, p3));
	}

	function log(bool p0, uint p1, string memory p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,string,bool)", p0, p1, p2, p3));
	}

	function log(bool p0, uint p1, string memory p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,string,address)", p0, p1, p2, p3));
	}

	function log(bool p0, uint p1, bool p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,bool,uint)", p0, p1, p2, p3));
	}

	function log(bool p0, uint p1, bool p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,bool,string)", p0, p1, p2, p3));
	}

	function log(bool p0, uint p1, bool p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,bool,bool)", p0, p1, p2, p3));
	}

	function log(bool p0, uint p1, bool p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,bool,address)", p0, p1, p2, p3));
	}

	function log(bool p0, uint p1, address p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,address,uint)", p0, p1, p2, p3));
	}

	function log(bool p0, uint p1, address p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,address,string)", p0, p1, p2, p3));
	}

	function log(bool p0, uint p1, address p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,address,bool)", p0, p1, p2, p3));
	}

	function log(bool p0, uint p1, address p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,uint,address,address)", p0, p1, p2, p3));
	}

	function log(bool p0, string memory p1, uint p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,uint,uint)", p0, p1, p2, p3));
	}

	function log(bool p0, string memory p1, uint p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,uint,string)", p0, p1, p2, p3));
	}

	function log(bool p0, string memory p1, uint p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,uint,bool)", p0, p1, p2, p3));
	}

	function log(bool p0, string memory p1, uint p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,uint,address)", p0, p1, p2, p3));
	}

	function log(bool p0, string memory p1, string memory p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,string,uint)", p0, p1, p2, p3));
	}

	function log(bool p0, string memory p1, string memory p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,string,string)", p0, p1, p2, p3));
	}

	function log(bool p0, string memory p1, string memory p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,string,bool)", p0, p1, p2, p3));
	}

	function log(bool p0, string memory p1, string memory p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,string,address)", p0, p1, p2, p3));
	}

	function log(bool p0, string memory p1, bool p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,bool,uint)", p0, p1, p2, p3));
	}

	function log(bool p0, string memory p1, bool p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,bool,string)", p0, p1, p2, p3));
	}

	function log(bool p0, string memory p1, bool p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,bool,bool)", p0, p1, p2, p3));
	}

	function log(bool p0, string memory p1, bool p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,bool,address)", p0, p1, p2, p3));
	}

	function log(bool p0, string memory p1, address p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,address,uint)", p0, p1, p2, p3));
	}

	function log(bool p0, string memory p1, address p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,address,string)", p0, p1, p2, p3));
	}

	function log(bool p0, string memory p1, address p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,address,bool)", p0, p1, p2, p3));
	}

	function log(bool p0, string memory p1, address p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,string,address,address)", p0, p1, p2, p3));
	}

	function log(bool p0, bool p1, uint p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,uint,uint)", p0, p1, p2, p3));
	}

	function log(bool p0, bool p1, uint p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,uint,string)", p0, p1, p2, p3));
	}

	function log(bool p0, bool p1, uint p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,uint,bool)", p0, p1, p2, p3));
	}

	function log(bool p0, bool p1, uint p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,uint,address)", p0, p1, p2, p3));
	}

	function log(bool p0, bool p1, string memory p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,string,uint)", p0, p1, p2, p3));
	}

	function log(bool p0, bool p1, string memory p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,string,string)", p0, p1, p2, p3));
	}

	function log(bool p0, bool p1, string memory p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,string,bool)", p0, p1, p2, p3));
	}

	function log(bool p0, bool p1, string memory p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,string,address)", p0, p1, p2, p3));
	}

	function log(bool p0, bool p1, bool p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,bool,uint)", p0, p1, p2, p3));
	}

	function log(bool p0, bool p1, bool p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,bool,string)", p0, p1, p2, p3));
	}

	function log(bool p0, bool p1, bool p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,bool,bool)", p0, p1, p2, p3));
	}

	function log(bool p0, bool p1, bool p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,bool,address)", p0, p1, p2, p3));
	}

	function log(bool p0, bool p1, address p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,address,uint)", p0, p1, p2, p3));
	}

	function log(bool p0, bool p1, address p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,address,string)", p0, p1, p2, p3));
	}

	function log(bool p0, bool p1, address p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,address,bool)", p0, p1, p2, p3));
	}

	function log(bool p0, bool p1, address p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,bool,address,address)", p0, p1, p2, p3));
	}

	function log(bool p0, address p1, uint p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,uint,uint)", p0, p1, p2, p3));
	}

	function log(bool p0, address p1, uint p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,uint,string)", p0, p1, p2, p3));
	}

	function log(bool p0, address p1, uint p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,uint,bool)", p0, p1, p2, p3));
	}

	function log(bool p0, address p1, uint p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,uint,address)", p0, p1, p2, p3));
	}

	function log(bool p0, address p1, string memory p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,string,uint)", p0, p1, p2, p3));
	}

	function log(bool p0, address p1, string memory p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,string,string)", p0, p1, p2, p3));
	}

	function log(bool p0, address p1, string memory p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,string,bool)", p0, p1, p2, p3));
	}

	function log(bool p0, address p1, string memory p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,string,address)", p0, p1, p2, p3));
	}

	function log(bool p0, address p1, bool p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,bool,uint)", p0, p1, p2, p3));
	}

	function log(bool p0, address p1, bool p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,bool,string)", p0, p1, p2, p3));
	}

	function log(bool p0, address p1, bool p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,bool,bool)", p0, p1, p2, p3));
	}

	function log(bool p0, address p1, bool p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,bool,address)", p0, p1, p2, p3));
	}

	function log(bool p0, address p1, address p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,address,uint)", p0, p1, p2, p3));
	}

	function log(bool p0, address p1, address p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,address,string)", p0, p1, p2, p3));
	}

	function log(bool p0, address p1, address p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,address,bool)", p0, p1, p2, p3));
	}

	function log(bool p0, address p1, address p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(bool,address,address,address)", p0, p1, p2, p3));
	}

	function log(address p0, uint p1, uint p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,uint,uint)", p0, p1, p2, p3));
	}

	function log(address p0, uint p1, uint p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,uint,string)", p0, p1, p2, p3));
	}

	function log(address p0, uint p1, uint p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,uint,bool)", p0, p1, p2, p3));
	}

	function log(address p0, uint p1, uint p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,uint,address)", p0, p1, p2, p3));
	}

	function log(address p0, uint p1, string memory p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,string,uint)", p0, p1, p2, p3));
	}

	function log(address p0, uint p1, string memory p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,string,string)", p0, p1, p2, p3));
	}

	function log(address p0, uint p1, string memory p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,string,bool)", p0, p1, p2, p3));
	}

	function log(address p0, uint p1, string memory p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,string,address)", p0, p1, p2, p3));
	}

	function log(address p0, uint p1, bool p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,bool,uint)", p0, p1, p2, p3));
	}

	function log(address p0, uint p1, bool p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,bool,string)", p0, p1, p2, p3));
	}

	function log(address p0, uint p1, bool p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,bool,bool)", p0, p1, p2, p3));
	}

	function log(address p0, uint p1, bool p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,bool,address)", p0, p1, p2, p3));
	}

	function log(address p0, uint p1, address p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,address,uint)", p0, p1, p2, p3));
	}

	function log(address p0, uint p1, address p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,address,string)", p0, p1, p2, p3));
	}

	function log(address p0, uint p1, address p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,address,bool)", p0, p1, p2, p3));
	}

	function log(address p0, uint p1, address p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,uint,address,address)", p0, p1, p2, p3));
	}

	function log(address p0, string memory p1, uint p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,uint,uint)", p0, p1, p2, p3));
	}

	function log(address p0, string memory p1, uint p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,uint,string)", p0, p1, p2, p3));
	}

	function log(address p0, string memory p1, uint p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,uint,bool)", p0, p1, p2, p3));
	}

	function log(address p0, string memory p1, uint p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,uint,address)", p0, p1, p2, p3));
	}

	function log(address p0, string memory p1, string memory p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,string,uint)", p0, p1, p2, p3));
	}

	function log(address p0, string memory p1, string memory p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,string,string)", p0, p1, p2, p3));
	}

	function log(address p0, string memory p1, string memory p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,string,bool)", p0, p1, p2, p3));
	}

	function log(address p0, string memory p1, string memory p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,string,address)", p0, p1, p2, p3));
	}

	function log(address p0, string memory p1, bool p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,bool,uint)", p0, p1, p2, p3));
	}

	function log(address p0, string memory p1, bool p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,bool,string)", p0, p1, p2, p3));
	}

	function log(address p0, string memory p1, bool p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,bool,bool)", p0, p1, p2, p3));
	}

	function log(address p0, string memory p1, bool p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,bool,address)", p0, p1, p2, p3));
	}

	function log(address p0, string memory p1, address p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,address,uint)", p0, p1, p2, p3));
	}

	function log(address p0, string memory p1, address p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,address,string)", p0, p1, p2, p3));
	}

	function log(address p0, string memory p1, address p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,address,bool)", p0, p1, p2, p3));
	}

	function log(address p0, string memory p1, address p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,string,address,address)", p0, p1, p2, p3));
	}

	function log(address p0, bool p1, uint p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,uint,uint)", p0, p1, p2, p3));
	}

	function log(address p0, bool p1, uint p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,uint,string)", p0, p1, p2, p3));
	}

	function log(address p0, bool p1, uint p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,uint,bool)", p0, p1, p2, p3));
	}

	function log(address p0, bool p1, uint p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,uint,address)", p0, p1, p2, p3));
	}

	function log(address p0, bool p1, string memory p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,string,uint)", p0, p1, p2, p3));
	}

	function log(address p0, bool p1, string memory p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,string,string)", p0, p1, p2, p3));
	}

	function log(address p0, bool p1, string memory p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,string,bool)", p0, p1, p2, p3));
	}

	function log(address p0, bool p1, string memory p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,string,address)", p0, p1, p2, p3));
	}

	function log(address p0, bool p1, bool p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,bool,uint)", p0, p1, p2, p3));
	}

	function log(address p0, bool p1, bool p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,bool,string)", p0, p1, p2, p3));
	}

	function log(address p0, bool p1, bool p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,bool,bool)", p0, p1, p2, p3));
	}

	function log(address p0, bool p1, bool p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,bool,address)", p0, p1, p2, p3));
	}

	function log(address p0, bool p1, address p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,address,uint)", p0, p1, p2, p3));
	}

	function log(address p0, bool p1, address p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,address,string)", p0, p1, p2, p3));
	}

	function log(address p0, bool p1, address p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,address,bool)", p0, p1, p2, p3));
	}

	function log(address p0, bool p1, address p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,bool,address,address)", p0, p1, p2, p3));
	}

	function log(address p0, address p1, uint p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,uint,uint)", p0, p1, p2, p3));
	}

	function log(address p0, address p1, uint p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,uint,string)", p0, p1, p2, p3));
	}

	function log(address p0, address p1, uint p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,uint,bool)", p0, p1, p2, p3));
	}

	function log(address p0, address p1, uint p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,uint,address)", p0, p1, p2, p3));
	}

	function log(address p0, address p1, string memory p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,string,uint)", p0, p1, p2, p3));
	}

	function log(address p0, address p1, string memory p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,string,string)", p0, p1, p2, p3));
	}

	function log(address p0, address p1, string memory p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,string,bool)", p0, p1, p2, p3));
	}

	function log(address p0, address p1, string memory p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,string,address)", p0, p1, p2, p3));
	}

	function log(address p0, address p1, bool p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,bool,uint)", p0, p1, p2, p3));
	}

	function log(address p0, address p1, bool p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,bool,string)", p0, p1, p2, p3));
	}

	function log(address p0, address p1, bool p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,bool,bool)", p0, p1, p2, p3));
	}

	function log(address p0, address p1, bool p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,bool,address)", p0, p1, p2, p3));
	}

	function log(address p0, address p1, address p2, uint p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,address,uint)", p0, p1, p2, p3));
	}

	function log(address p0, address p1, address p2, string memory p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,address,string)", p0, p1, p2, p3));
	}

	function log(address p0, address p1, address p2, bool p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,address,bool)", p0, p1, p2, p3));
	}

	function log(address p0, address p1, address p2, address p3) internal view {
		_sendLogPayload(abi.encodeWithSignature("log(address,address,address,address)", p0, p1, p2, p3));
	}

}


// File contracts/ItsABee.sol

/*
 ██╗      █████╗ ██████╗ ██╗  ██╗██╗███╗   ██╗
 ██║     ██╔══██╗██╔══██╗██║ ██╔╝██║████╗  ██║
 ██║     ███████║██████╔╝█████╔╝ ██║██╔██╗ ██║
 ██║     ██╔══██║██╔══██╗██╔═██╗ ██║██║╚██╗██║
 ███████╗██║  ██║██║  ██║██║  ██╗██║██║ ╚████║
 ╚══════╝╚═╝  ╚═╝╚═╝  ╚═╝╚═╝  ╚═╝╚═╝╚═╝  ╚═══╝
*/


contract ItsABee is ERC721A, IERC2981, Ownable {
    using Strings for uint256;

    ///////////////////////////////////////////////////////////////////////////
    // Public constants
    ///////////////////////////////////////////////////////////////////////////
    uint256 constant public MAX_SUPPLY = 6969;
    //uint256 constant public MAX_PER_WALLET = 5;
    uint256 constant public MAX_PER_MINT = 5;
    uint256 public PRICE = 0.1 ether;
    uint256 constant MAX_TEAM_MINTS = 100;

    ///////////////////////////////////////////////////////////////////////////
    // Important Globals
    ///////////////////////////////////////////////////////////////////////////
    uint256 public publicSaleTime = 1658408400;

    uint256 private teamMintsLeft = MAX_TEAM_MINTS-1;  // contract deployer gets one
    // how many has each address minted
    mapping (address => uint256) userMinted;

    string constant public PROVENANCE = "74ff6419e8a785b48e234bd6003f0248144ba2cd4ad36b011a9b932fd0244310";
    string private baseURI = "ipfs://QmRwTjENj9wHhk4ZiqjXWG6RKuEoFmZm413djYdAEGSmu4/";
    string private transformedBaseURI = "ipfs://QmRwTjENj9wHhk4ZiqjXWG6RKuEoFmZm413djYdAEGSmu4/";



    ///////////////////////////////////////////////////////////////////////////
    // Team members and shares
    ///////////////////////////////////////////////////////////////////////////
    mapping(address => bool) private isTeam;

    address constant public LARKIN = 0xA4430c68005b1F570a111aA71E1cA7EE5246c4CD;
    address constant public MAKER  = 0x7b0B5a326Aa4d95968e88654aF9b87624383A549;

    // Team Addresses
    address[] private team = [
        0x8eC73aB96d3d89d3882F5d79fa00cE6B0f16b6C7, // makerlee & artist
        LARKIN                                    , // Larkin
        0x05ed59e9765Ce11ACb387B66f91A99E1514ee7c8, // Pixel
        0x84B8C0f4659cDCc7714468167EC5b092C2dce75A  // former partner
    ];

    // Team wallet addresses
    //                            makerlee Larkin  Pixel partner
    uint256[] private teamShares = [50,     20,     15,      15];
    uint256 constant private TOTAL_SHARES = 100;
    // For EIP-2981 (royalties)
    bytes4 private constant INTERFACE_ID_ERC2981 = 0x2a55205a;
    uint256 constant private ROYALTIES_PERCENTAGE_X10 = 49;

    mapping (address => uint256[]) public burnedBy;  // tokens burned by a user

    uint256 public MAX_TRANSFORMS = 2100;
    uint256 public TRANSFORM_PRICE = 0.01 ether;
    uint256 public numTransformed;  // so far
    mapping (uint256 => bool) public transformed;  // is each token transformed?
    // optional boost to larkin's share of 'transform' payments
    uint256 private DEV_TRANSFORM_BOOST = 10;  // this is a percentage, so 10 means 10%


    ///////////////////////////////////////////////////////////////////////////
    // Contract initialization
    ///////////////////////////////////////////////////////////////////////////
    constructor() ERC721A("ItsABee", "ABEE") {
        // Validate that the team size matches number of share buckets for mint and royalties
        uint256 teamSize = team.length;
        if (teamSize != teamShares.length) revert InvalidTeam(teamShares.length);

        // Validate that the number of teamShares match the expected for mint and royalties
        uint256 totalTeamShares;
        for (uint256 i; i < teamSize; ) {
            isTeam[team[i]] = true;
            unchecked {
                totalTeamShares += teamShares[i];
                ++i;
            }
        }
        if (totalTeamShares != TOTAL_SHARES) revert InvalidTeam(totalTeamShares);

        // mint first token ID to creator
        _safeMint(msg.sender, 1);
    }


    ///////////////////////////////////////////////////////////////////////////
    // Modifiers
    ///////////////////////////////////////////////////////////////////////////
    modifier onlyDev() {
        if (msg.sender != LARKIN) revert OnlyAllowedAddressCanDoThat(LARKIN);
        _;
    }
    modifier onlyTeam() {
        if (!isTeam[msg.sender] && msg.sender != MAKER) revert OnlyTeamCanDoThat();
        _;
    }


    ///////////////////////////////////////////////////////////////////////////
    // Contract setup
    ///////////////////////////////////////////////////////////////////////////
    // The developer can change a team member (in case of emergency - wallet lost etc)
    function setTeamMember(uint256 index, address member) external onlyDev {
        require(member != address(0), "Cannot set team member to 0");
        require(index < team.length, "Invalid team member index");

        isTeam[team[index]] = false;  // remove team member
        team[index] = member; // relace team member
        isTeam[member] = true;
    }

    // Provenance hash proves that the team didn't play favorites with assigning tokenIds
    // for rare NFTs to specific addresses with a post-mint reveal
    //function setProvenanceHash(string memory _provenanceHash) external onlyDev {
    //    provenance = _provenanceHash;
    //}

    // change price after launch
    function setPrice(uint256 newPrice) public onlyTeam {
        PRICE = newPrice;
    }
    // Base IPFS URI that points to all metadata for the collection
    // It basically points to the IPFS folder containing all metadata.
    // So, if it points to ipfs://blah/, then tokenId 69 will have
    // metadata URI ipfs://blah/69
    //
    // Update the base URI (like to reveal)
    function setBaseURI(string memory _uri) external onlyDev {
        baseURI = _uri;
    }
    // update transformed URI (like when transformed images are uploaded)
    function setTransformedBaseURI(string memory _uri) external onlyDev {
        transformedBaseURI = _uri;
    }

    // The 'image' tag in the metadat for a tokenId points to its image's IPFS URI
    function tokenURI(uint256 tokenId) public view virtual override returns (string memory) {
        if (tokenId >= _totalMinted()) revert TokenDNE(tokenId);

        string memory mBaseURI = transformed[tokenId] ? transformedBaseURI : baseURI;
        return bytes(mBaseURI).length > 0 ? string(abi.encodePacked(mBaseURI, tokenId.toString())) : "";
    }

    // when does mint start
    function setPublicSaleTime(uint256 _newTime) public onlyDev {
        publicSaleTime = _newTime;
    }

    // set transform constants
    function setMaxTransforms(uint256 _max) public onlyDev {
        MAX_TRANSFORMS = _max;
    }
    function setTransformPrice(uint256 _price) public onlyDev {
        TRANSFORM_PRICE = _price;
    }
    function setDevTransformBoost(uint256 _boostPercent) public onlyDev {
        DEV_TRANSFORM_BOOST = _boostPercent;
    }


    ///////////////////////////////////////////////////////////////////////////
    // Mint and Burn
    ///////////////////////////////////////////////////////////////////////////
    function teamMint(uint256 _amount) external onlyTeam {
        if (teamMintsLeft < _amount) revert TooManyTeamMints(_amount - teamMintsLeft);
        teamMintsLeft -= _amount;

        _safeMint(msg.sender, _amount);
    }

    function mint(uint256 _amount) external payable {
        if (msg.value != _amount * PRICE) revert WrongPayment(msg.value, _amount * PRICE);
        if (block.timestamp < publicSaleTime) revert MintClosed();
        if (_totalMinted() + _amount + teamMintsLeft > MAX_SUPPLY) revert WouldPassSupplyCap(_totalMinted() + _amount + teamMintsLeft);
        if (_amount > MAX_PER_MINT) revert OverMaxMint(_amount, MAX_PER_MINT);
        //if (_numberMinted(msg.sender) + _amount > MAX_PER_WALLET) revert WalletCanOnlyMintNMore(MAX_PER_WALLET - _numberMinted(msg.sender));

        _safeMint(msg.sender, _amount);
    }

    function burn(uint256 _tokenId) external {
        if (ownerOf(_tokenId) != msg.sender) revert OnlyTokenOwnerCanDoThat(_tokenId, ownerOf(_tokenId));

        // Keep track of all tokens this address has burned
        burnedBy[msg.sender].push(_tokenId);
        _burn(_tokenId);
    }

    function getBurnedBy(address _by) external view returns (uint256[] memory) {
        return burnedBy[_by];
    }


    ///////////////////////////////////////////////////////////////////////////
    // Withdraw funds from contract
    ///////////////////////////////////////////////////////////////////////////
    // ETH is received for mint and royalties
    function withdrawETH() public onlyTeam {
        uint256 totalETH = address(this).balance;
        if (totalETH == 0) revert EmptyWithdraw();

        uint256 teamSize = team.length;
        for (uint256 i; i < teamSize; ) {
            address payable wallet = payable(team[i]);
            // How much is this wallet owed
            uint256 payment = (totalETH * teamShares[i]) / TOTAL_SHARES;
            // Send payment
            Address.sendValue(wallet, payment);

            unchecked { ++i; }
        }
        emit ETHWithdrawn(totalETH);
    }

    // Royalties in any ERC20 are accepted
    function withdrawERC20(IERC20 _token) public onlyTeam {
        uint256 totalERC20 = _token.balanceOf(address(this));
        if (totalERC20 == 0) revert EmptyWithdraw();

        uint256 teamSize = team.length;
        for (uint256 i; i < teamSize; ) {
            // How much is this wallet owed
            uint256 payment = (totalERC20 * teamShares[i]) / TOTAL_SHARES;
            // Send payment
            _token.transfer(team[i], payment);

            unchecked { ++i; }
        }
        emit ERC20Withdrawn(address(_token), totalERC20);
    }


    ///////////////////////////////////////////////////////////////////////////
    // Royalties - ERC2981
    ///////////////////////////////////////////////////////////////////////////
    // Supports ERC2981 for royalties as well as ofc 721 and 165
    function supportsInterface(bytes4 _interfaceId) public view override(ERC721A, IERC165) returns (bool) {
        return _interfaceId == INTERFACE_ID_ERC2981 || super.supportsInterface(_interfaceId);
    }

    // NFT marketplaces will call this function to determine amount of royalties
    // to charge and who to send them to
    function royaltyInfo(uint256 _tokenId, uint256 _salePrice) public view virtual override returns (address _receiver, uint256 _royaltyAmount) {
        _receiver = address(this);
        _royaltyAmount = (_salePrice * ROYALTIES_PERCENTAGE_X10) / 1000;
    }

    // ensure this contract can receive payments (royalties)
    receive() external payable { }


    ///////////////////////////////////////////////////////////////////////////
    // Custom functions
    ///////////////////////////////////////////////////////////////////////////
    function transform(uint256 _tokenId) public payable {
        if (msg.value != TRANSFORM_PRICE) revert WrongTransformPrice(msg.value, TRANSFORM_PRICE);
        if (ownerOf(_tokenId) != msg.sender) revert OnlyTokenOwnerCanDoThat(_tokenId, ownerOf(_tokenId));
        if (transformed[_tokenId]) revert AlreadyTransformed(_tokenId);
        if (numTransformed >= MAX_TRANSFORMS) revert TransformingEnded();

        // As dev, Larkin may get a bump in payments for transforms
        if (DEV_TRANSFORM_BOOST > 0) {
            Address.sendValue(payable(LARKIN), msg.value * DEV_TRANSFORM_BOOST / 100);
        }

        numTransformed += 1;
        transformed[_tokenId] = true;
        emit Transformed(_tokenId);
    }


    ///////////////////////////////////////////////////////////////////////////
    // Errors and Events
    ///////////////////////////////////////////////////////////////////////////
    error InvalidTeam(uint256 sizeOrShares);
    error OnlyTeamCanDoThat();
    error OnlyAllowedAddressCanDoThat(address allowed);
    error WrongPayment(uint256 was, uint256 shouldBe);
    error MintClosed();
    error TooManyTeamMints(uint256 wouldBeTeamMints);
    error WouldPassSupplyCap(uint256 wouldBeSupply);
    //error WalletCanOnlyMintNMore(uint256 more);
    error OverMaxMint(uint256 over, uint256 max);
    error EmptyWithdraw();
    error TokenDNE(uint256 tokenId);
    error OnlyTokenOwnerCanDoThat(uint256 tokenId, address owner);
    error WrongTransformPrice(uint256 payed, uint256 price);
    error AlreadyTransformed(uint256 tokenId);
    error TransformingEnded();

    event ETHWithdrawn(uint256 amount);
    event ERC20Withdrawn(address erc20, uint256 amount);
    event Transformed(uint256 tokenId);
}

/*
 Larkin - @CodeLarkin - codelarkin.eth
 ██╗      █████╗ ██████╗ ██╗  ██╗██╗███╗   ██╗
 ██║     ██╔══██╗██╔══██╗██║ ██╔╝██║████╗  ██║
 ██║     ███████║██████╔╝█████╔╝ ██║██╔██╗ ██║
 ██║     ██╔══██║██╔══██╗██╔═██╗ ██║██║╚██╗██║
 ███████╗██║  ██║██║  ██║██║  ██╗██║██║ ╚████║
 ╚══════╝╚═╝  ╚═╝╚═╝  ╚═╝╚═╝  ╚═╝╚═╝╚═╝  ╚═══╝
 */

Contract Security Audit

Contract ABI

[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"AlreadyTransformed","type":"error"},{"inputs":[],"name":"ApprovalCallerNotOwnerNorApproved","type":"error"},{"inputs":[],"name":"ApprovalQueryForNonexistentToken","type":"error"},{"inputs":[],"name":"ApprovalToCurrentOwner","type":"error"},{"inputs":[],"name":"ApproveToCaller","type":"error"},{"inputs":[],"name":"BalanceQueryForZeroAddress","type":"error"},{"inputs":[],"name":"EmptyWithdraw","type":"error"},{"inputs":[{"internalType":"uint256","name":"sizeOrShares","type":"uint256"}],"name":"InvalidTeam","type":"error"},{"inputs":[],"name":"MintClosed","type":"error"},{"inputs":[],"name":"MintToZeroAddress","type":"error"},{"inputs":[],"name":"MintZeroQuantity","type":"error"},{"inputs":[{"internalType":"address","name":"allowed","type":"address"}],"name":"OnlyAllowedAddressCanDoThat","type":"error"},{"inputs":[],"name":"OnlyTeamCanDoThat","type":"error"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"},{"internalType":"address","name":"owner","type":"address"}],"name":"OnlyTokenOwnerCanDoThat","type":"error"},{"inputs":[{"internalType":"uint256","name":"over","type":"uint256"},{"internalType":"uint256","name":"max","type":"uint256"}],"name":"OverMaxMint","type":"error"},{"inputs":[],"name":"OwnerQueryForNonexistentToken","type":"error"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"TokenDNE","type":"error"},{"inputs":[{"internalType":"uint256","name":"wouldBeTeamMints","type":"uint256"}],"name":"TooManyTeamMints","type":"error"},{"inputs":[],"name":"TransferCallerNotOwnerNorApproved","type":"error"},{"inputs":[],"name":"TransferFromIncorrectOwner","type":"error"},{"inputs":[],"name":"TransferToNonERC721ReceiverImplementer","type":"error"},{"inputs":[],"name":"TransferToZeroAddress","type":"error"},{"inputs":[],"name":"TransformingEnded","type":"error"},{"inputs":[],"name":"URIQueryForNonexistentToken","type":"error"},{"inputs":[{"internalType":"uint256","name":"wouldBeSupply","type":"uint256"}],"name":"WouldPassSupplyCap","type":"error"},{"inputs":[{"internalType":"uint256","name":"was","type":"uint256"},{"internalType":"uint256","name":"shouldBe","type":"uint256"}],"name":"WrongPayment","type":"error"},{"inputs":[{"internalType":"uint256","name":"payed","type":"uint256"},{"internalType":"uint256","name":"price","type":"uint256"}],"name":"WrongTransformPrice","type":"error"},{"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":false,"internalType":"address","name":"erc20","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"ERC20Withdrawn","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"ETHWithdrawn","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"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"Transformed","type":"event"},{"inputs":[],"name":"LARKIN","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"MAKER","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"MAX_PER_MINT","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"MAX_SUPPLY","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"MAX_TRANSFORMS","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"PRICE","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"PROVENANCE","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"TRANSFORM_PRICE","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":"_tokenId","type":"uint256"}],"name":"burn","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"},{"internalType":"uint256","name":"","type":"uint256"}],"name":"burnedBy","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"getApproved","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_by","type":"address"}],"name":"getBurnedBy","outputs":[{"internalType":"uint256[]","name":"","type":"uint256[]"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"operator","type":"address"}],"name":"isApprovedForAll","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"mint","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"numTransformed","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"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":"publicSaleTime","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_tokenId","type":"uint256"},{"internalType":"uint256","name":"_salePrice","type":"uint256"}],"name":"royaltyInfo","outputs":[{"internalType":"address","name":"_receiver","type":"address"},{"internalType":"uint256","name":"_royaltyAmount","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"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":"string","name":"_uri","type":"string"}],"name":"setBaseURI","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_boostPercent","type":"uint256"}],"name":"setDevTransformBoost","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_max","type":"uint256"}],"name":"setMaxTransforms","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newPrice","type":"uint256"}],"name":"setPrice","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_newTime","type":"uint256"}],"name":"setPublicSaleTime","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"index","type":"uint256"},{"internalType":"address","name":"member","type":"address"}],"name":"setTeamMember","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_price","type":"uint256"}],"name":"setTransformPrice","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"string","name":"_uri","type":"string"}],"name":"setTransformedBaseURI","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":[{"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"teamMint","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":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"transferFrom","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_tokenId","type":"uint256"}],"name":"transform","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"transformed","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"contract IERC20","name":"_token","type":"address"}],"name":"withdrawERC20","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"withdrawETH","outputs":[],"stateMutability":"nonpayable","type":"function"},{"stateMutability":"payable","type":"receive"}]

608060405267016345785d8a00006009556362d94dd0600a556200002660016064620006f1565b600b556040518060600160405280603681526020016200301d6036913980516200005991600d91602090910190620005b0565b506040518060600160405280603681526020016200301d6036913980516200008a91600e91602090910190620005b0565b5060408051608081018252738ec73ab96d3d89d3882f5d79fa00ce6b0f16b6c7815273a4430c68005b1f570a111aa71e1ca7ee5246c4cd60208201527305ed59e9765ce11acb387b66f91a99e1514ee7c8918101919091527384b8c0f4659cdcc7714468167ec5b092c2dce75a60608201526200010c9060109060046200063f565b50604080516080810182526032815260146020820152600f91810182905260608101919091526200014290601190600462000697565b50610834601355662386f26fc10000601455600a6017553480156200016657600080fd5b5060408051808201825260078152664974734142656560c81b6020808301918252835180850190945260048452634142454560e01b908401528151919291620001b291600291620005b0565b508051620001c8906003906020840190620005b0565b50506000805550620001da33620002d7565b60105460115481146200020c576011546040516369754ba960e11b815260048101919091526024015b60405180910390fd5b6000805b828110156200029b576001600f60006010848154811062000235576200023562000717565b6000918252602080832091909101546001600160a01b031683528201929092526040019020805460ff1916911515919091179055601180548290811062000280576200028062000717565b90600052602060002001548201915080600101905062000210565b5060648114620002c2576040516369754ba960e11b81526004810182905260240162000203565b620002cf33600162000329565b505062000817565b600880546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6200034b8282604051806020016040528060008152506200034f60201b60201c565b5050565b6000546001600160a01b0384166200037957604051622e076360e81b815260040160405180910390fd5b826000036200039b5760405163b562e8dd60e01b815260040160405180910390fd5b6001600160a01b03841660008181526005602090815260408083208054680100000000000000018902019055848352600490915290204260a01b86176001861460e11b1790558190818501903b1562000467575b60405182906001600160a01b0388169060009060008051602062003053833981519152908290a460018201916200042c90600090889087620004bc565b6200044a576040516368d2bf6b60e11b815260040160405180910390fd5b808210620003ef5782600054146200046157600080fd5b6200049c565b5b6040516001830192906001600160a01b0388169060009060008051602062003053833981519152908290a480821062000468575b506000908155620004b6908583866001600160e01b038516565b50505050565b604051630a85bd0160e11b81526000906001600160a01b0385169063150b7a0290620004f39033908990889088906004016200072d565b6020604051808303816000875af192505050801562000531575060408051601f3d908101601f191682019092526200052e91810190620007a8565b60015b62000593573d80801562000562576040519150601f19603f3d011682016040523d82523d6000602084013e62000567565b606091505b5080516000036200058b576040516368d2bf6b60e11b815260040160405180910390fd5b805181602001fd5b6001600160e01b031916630a85bd0160e11b149050949350505050565b828054620005be90620007db565b90600052602060002090601f016020900481019282620005e257600085556200062d565b82601f10620005fd57805160ff19168380011785556200062d565b828001600101855582156200062d579182015b828111156200062d57825182559160200191906001019062000610565b506200063b929150620006da565b5090565b8280548282559060005260206000209081019282156200062d579160200282015b828111156200062d57825182546001600160a01b0319166001600160a01b0390911617825560209092019160019091019062000660565b8280548282559060005260206000209081019282156200062d579160200282015b828111156200062d578251829060ff16905591602001919060010190620006b8565b5b808211156200063b5760008155600101620006db565b6000828210156200071257634e487b7160e01b600052601160045260246000fd5b500390565b634e487b7160e01b600052603260045260246000fd5b600060018060a01b038087168352602081871681850152856040850152608060608501528451915081608085015260005b828110156200077c5785810182015185820160a0015281016200075e565b828111156200078f57600060a084870101525b5050601f01601f19169190910160a00195945050505050565b600060208284031215620007bb57600080fd5b81516001600160e01b031981168114620007d457600080fd5b9392505050565b600181811c90821680620007f057607f821691505b6020821081036200081157634e487b7160e01b600052602260045260246000fd5b50919050565b6127f680620008276000396000f3fe6080604052600436106102365760003560e01c8063715018a61161012f578063a153ab5e116100b1578063a153ab5e14610658578063a22cb4651461066e578063b88d4fde1461068e578063c87b56dd146106ae578063d9cd2453146106ce578063e086e5ec146106ee578063e979806a14610703578063e985e9c514610723578063eb9047bb1461076c578063f2fde38b1461077f578063f4f3b2001461079f578063ff3ff182146107bf57600080fd5b8063715018a61461051e578063743262961461053357806377201fe4146105535780637cc4207a1461057357806380f28af3146105955780638a27034f146105b55780638d859f3e146105e55780638da5cb5b146105fb57806391b7f5ed1461061057806395d89b4114610630578063a0712d681461064557600080fd5b806323b872dd116101b857806323b872dd146103b85780632a55205a146103d85780632fbba1151461040657806332cb6b0c1461042657806335d532c91461043c57806342842e0e1461046957806342966c681461048957806355f804b3146104a95780636352211e146104c95780636373a6b1146104e957806370a08231146104fe57600080fd5b806301ffc9a71461024257806306fdde0314610277578063081812fc14610299578063095ea7b3146102c657806309d42b30146102e857806311b7e5e71461030b578063170c9c5f1461032b57806317eaf7121461034157806318160ddd146103695780632094e84d146103825780632344be0a146103a257600080fd5b3661023d57005b600080fd5b34801561024e57600080fd5b5061026261025d366004612182565b6107d5565b60405190151581526020015b60405180910390f35b34801561028357600080fd5b5061028c610800565b60405161026e91906121f7565b3480156102a557600080fd5b506102b96102b436600461220a565b610892565b60405161026e9190612223565b3480156102d257600080fd5b506102e66102e136600461224c565b6108d6565b005b3480156102f457600080fd5b506102fd600581565b60405190815260200161026e565b34801561031757600080fd5b506102e661032636600461220a565b6109a8565b34801561033757600080fd5b506102fd60155481565b34801561034d57600080fd5b506102b9737b0b5a326aa4d95968e88654af9b87624383a54981565b34801561037557600080fd5b50600154600054036102fd565b34801561038e57600080fd5b506102fd61039d36600461224c565b6109f4565b3480156103ae57600080fd5b506102fd600a5481565b3480156103c457600080fd5b506102e66103d3366004612278565b610a25565b3480156103e457600080fd5b506103f86103f33660046122b9565b610a35565b60405161026e9291906122db565b34801561041257600080fd5b506102e661042136600461220a565b610a59565b34801561043257600080fd5b506102fd611b3981565b34801561044857600080fd5b5061045c6104573660046122f4565b610b03565b60405161026e9190612311565b34801561047557600080fd5b506102e6610484366004612278565b610b6f565b34801561049557600080fd5b506102e66104a436600461220a565b610b8a565b3480156104b557600080fd5b506102e66104c43660046123e0565b610c02565b3480156104d557600080fd5b506102b96104e436600461220a565b610c57565b3480156104f557600080fd5b5061028c610c62565b34801561050a57600080fd5b506102fd6105193660046122f4565b610c7e565b34801561052a57600080fd5b506102e6610ccc565b34801561053f57600080fd5b506102e661054e36600461220a565b610d07565b34801561055f57600080fd5b506102e661056e36600461220a565b610d4a565b34801561057f57600080fd5b506102b960008051602061278183398151915281565b3480156105a157600080fd5b506102e66105b036600461220a565b610d8d565b3480156105c157600080fd5b506102626105d036600461220a565b60166020526000908152604090205460ff1681565b3480156105f157600080fd5b506102fd60095481565b34801561060757600080fd5b506102b9610dd0565b34801561061c57600080fd5b506102e661062b36600461220a565b610ddf565b34801561063c57600080fd5b5061028c610e36565b6102e661065336600461220a565b610e45565b34801561066457600080fd5b506102fd60135481565b34801561067a57600080fd5b506102e6610689366004612436565b610f49565b34801561069a57600080fd5b506102e66106a936600461246f565b610fde565b3480156106ba57600080fd5b5061028c6106c936600461220a565b611028565b3480156106da57600080fd5b506102e66106e93660046123e0565b611150565b3480156106fa57600080fd5b506102e66111a1565b34801561070f57600080fd5b506102e661071e3660046124ee565b6112d6565b34801561072f57600080fd5b5061026261073e366004612513565b6001600160a01b03918216600090815260076020908152604080832093909416825291909152205460ff1690565b6102e661077a36600461220a565b61145e565b34801561078b57600080fd5b506102e661079a3660046122f4565b6115ad565b3480156107ab57600080fd5b506102e66107ba3660046122f4565b61164a565b3480156107cb57600080fd5b506102fd60145481565b60006001600160e01b0319821663152a902d60e11b14806107fa57506107fa8261185c565b92915050565b60606002805461080f90612541565b80601f016020809104026020016040519081016040528092919081815260200182805461083b90612541565b80156108885780601f1061085d57610100808354040283529160200191610888565b820191906000526020600020905b81548152906001019060200180831161086b57829003601f168201915b5050505050905090565b600061089d826118aa565b6108ba576040516333d1c03960e21b815260040160405180910390fd5b506000908152600660205260409020546001600160a01b031690565b60006108e1826118d1565b9050806001600160a01b0316836001600160a01b0316036109155760405163250fdee360e21b815260040160405180910390fd5b336001600160a01b0382161461094c5761092f813361073e565b61094c576040516367d9dca160e11b815260040160405180910390fd5b60008281526006602052604080822080546001600160a01b0319166001600160a01b0387811691821790925591518593918516917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591a4505050565b33600080516020612781833981519152146109ef57600080516020612781833981519152604051631022f85d60e11b81526004016109e69190612223565b60405180910390fd5b600a55565b60126020528160005260406000208181548110610a1057600080fd5b90600052602060002001600091509150505481565b610a30838383611938565b505050565b3060006103e8610a46603185612591565b610a5091906125c6565b90509250929050565b336000908152600f602052604090205460ff16158015610a8d575033737b0b5a326aa4d95968e88654af9b87624383a54914155b15610aab57604051634f88b4f560e11b815260040160405180910390fd5b80600b541015610ade57600b54610ac290826125da565b6040516310df17a560e01b81526004016109e691815260200190565b80600b6000828254610af091906125da565b90915550610b0090503382611acd565b50565b6001600160a01b038116600090815260126020908152604091829020805483518184028101840190945280845260609392830182828015610b6357602002820191906000526020600020905b815481526020019060010190808311610b4f575b50505050509050919050565b610a3083838360405180602001604052806000815250610fde565b33610b9482610c57565b6001600160a01b031614610bd75780610bac82610c57565b6040516326a5d68f60e11b815260048101929092526001600160a01b031660248201526044016109e6565b33600090815260126020908152604082208054600181018255908352912001819055610b0081611ae7565b3360008051602061278183398151915214610c4057600080516020612781833981519152604051631022f85d60e11b81526004016109e69190612223565b8051610c5390600d9060208401906120d3565b5050565b60006107fa826118d1565b6040518060600160405280604081526020016127416040913981565b60006001600160a01b038216610ca7576040516323d3ad8160e21b815260040160405180910390fd5b506001600160a01b03166000908152600560205260409020546001600160401b031690565b33610cd5610dd0565b6001600160a01b031614610cfb5760405162461bcd60e51b81526004016109e6906125f1565b610d056000611af2565b565b3360008051602061278183398151915214610d4557600080516020612781833981519152604051631022f85d60e11b81526004016109e69190612223565b601755565b3360008051602061278183398151915214610d8857600080516020612781833981519152604051631022f85d60e11b81526004016109e69190612223565b601355565b3360008051602061278183398151915214610dcb57600080516020612781833981519152604051631022f85d60e11b81526004016109e69190612223565b601455565b6008546001600160a01b031690565b336000908152600f602052604090205460ff16158015610e13575033737b0b5a326aa4d95968e88654af9b87624383a54914155b15610e3157604051634f88b4f560e11b815260040160405180910390fd5b600955565b60606003805461080f90612541565b600954610e529082612591565b3414610e89573460095482610e679190612591565b604051630374cb4760e21b8152600481019290925260248201526044016109e6565b600a54421015610eac5760405163589ed34b60e01b815260040160405180910390fd5b611b39600b5482610ebc60005490565b610ec69190612626565b610ed09190612626565b1115610f1357600b5481610ee360005490565b610eed9190612626565b610ef79190612626565b604051630c540f2160e01b81526004016109e691815260200190565b6005811115610f3f57604051633eda2f4160e11b815260048101829052600560248201526044016109e6565b610b003382611acd565b336001600160a01b03831603610f725760405163b06307db60e01b815260040160405180910390fd5b3360008181526007602090815260408083206001600160a01b03871680855290835292819020805460ff191686151590811790915590519081529192917f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c31910160405180910390a35050565b610fe9848484611938565b6001600160a01b0383163b156110225761100584848484611b44565b611022576040516368d2bf6b60e11b815260040160405180910390fd5b50505050565b606061103360005490565b821061105557604051631e39122160e11b8152600481018390526024016109e6565b60008281526016602052604081205460ff1661107257600d611075565b600e5b805461108090612541565b80601f01602080910402602001604051908101604052809291908181526020018280546110ac90612541565b80156110f95780601f106110ce576101008083540402835291602001916110f9565b820191906000526020600020905b8154815290600101906020018083116110dc57829003601f168201915b50505050509050600081511161111e5760405180602001604052806000815250611149565b8061112884611c30565b60405160200161113992919061263e565b6040516020818303038152906040525b9392505050565b336000805160206127818339815191521461118e57600080516020612781833981519152604051631022f85d60e11b81526004016109e69190612223565b8051610c5390600e9060208401906120d3565b336000908152600f602052604090205460ff161580156111d5575033737b0b5a326aa4d95968e88654af9b87624383a54914155b156111f357604051634f88b4f560e11b815260040160405180910390fd5b476000819003611216576040516308ae8bb160e41b815260040160405180910390fd5b60105460005b8181101561129e576000601082815481106112395761123961266d565b6000918252602082200154601180546001600160a01b039092169350606491859081106112685761126861266d565b90600052602060002001548661127e9190612591565b61128891906125c6565b90506112948282611d30565b505060010161121c565b506040518281527f043f607a14d3b4f0a11a0b2e192bbfcd894298ba5abf22553be6081406db28aa9060200160405180910390a15050565b336000805160206127818339815191521461131457600080516020612781833981519152604051631022f85d60e11b81526004016109e69190612223565b6001600160a01b0381166113685760405162461bcd60e51b815260206004820152601b60248201527a043616e6e6f7420736574207465616d206d656d62657220746f203602c1b60448201526064016109e6565b60105482106113b55760405162461bcd60e51b8152602060048201526019602482015278092dcecc2d8d2c840e8cac2da40dacadac4cae440d2dcc8caf603b1b60448201526064016109e6565b6000600f6000601085815481106113ce576113ce61266d565b6000918252602080832091909101546001600160a01b031683528201929092526040019020805460ff191691151591909117905560108054829190849081106114195761141961266d565b600091825260208083209190910180546001600160a01b0319166001600160a01b03948516179055929091168152600f90915260409020805460ff1916600117905550565b601454341461148d57601454604051637998543b60e01b815234600482015260248101919091526044016109e6565b3361149782610c57565b6001600160a01b0316146114af5780610bac82610c57565b60008181526016602052604090205460ff16156114e25760405163d39ab56360e01b8152600481018290526024016109e6565b60135460155410611506576040516332d2dafb60e11b815260040160405180910390fd5b6017541561153f5761153f6000805160206127818339815191526064601754346115309190612591565b61153a91906125c6565b611d30565b6001601560008282546115529190612626565b909155505060008181526016602052604090819020805460ff19166001179055517f51dba42a71b99e344e4141f74c8d409d50613b760cbe5360262c20260c39b428906115a29083815260200190565b60405180910390a150565b336115b6610dd0565b6001600160a01b0316146115dc5760405162461bcd60e51b81526004016109e6906125f1565b6001600160a01b0381166116415760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016109e6565b610b0081611af2565b336000908152600f602052604090205460ff1615801561167e575033737b0b5a326aa4d95968e88654af9b87624383a54914155b1561169c57604051634f88b4f560e11b815260040160405180910390fd5b6040516370a0823160e01b81526000906001600160a01b038316906370a08231906116cb903090600401612223565b602060405180830381865afa1580156116e8573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061170c9190612683565b90508060000361172f576040516308ae8bb160e41b815260040160405180910390fd5b60105460005b8181101561181d5760006064601183815481106117545761175461266d565b90600052602060002001548561176a9190612591565b61177491906125c6565b9050846001600160a01b031663a9059cbb601084815481106117985761179861266d565b6000918252602090912001546040516001600160e01b031960e084901b1681526117d0916001600160a01b03169085906004016122db565b6020604051808303816000875af11580156117ef573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611813919061269c565b5050600101611735565b507f7e2c99819371db0a6fc6f4269fe872496e44f502df19ba3eae594b7a15987460838360405161184f9291906122db565b60405180910390a1505050565b60006301ffc9a760e01b6001600160e01b03198316148061188d57506380ac58cd60e01b6001600160e01b03198316145b806107fa5750506001600160e01b031916635b5e139f60e01b1490565b60008054821080156107fa575050600090815260046020526040902054600160e01b161590565b60008160005481101561191f5760008181526004602052604081205490600160e01b8216900361191d575b806000036111495750600019016000818152600460205260409020546118fc565b505b604051636f96cda160e11b815260040160405180910390fd5b6000611943826118d1565b9050836001600160a01b0316816001600160a01b0316146119765760405162a1148160e81b815260040160405180910390fd5b6000336001600160a01b03861614806119945750611994853361073e565b806119af5750336119a484610892565b6001600160a01b0316145b9050806119cf57604051632ce44b5f60e11b815260040160405180910390fd5b6001600160a01b0384166119f657604051633a954ecd60e21b815260040160405180910390fd5b600083815260066020908152604080832080546001600160a01b03191690556001600160a01b038881168452600583528184208054600019019055871683528083208054600101905585835260049091528120600160e11b4260a01b8717811790915583169003611a9757600183016000818152600460205260408120549003611a95576000548114611a955760008181526004602052604090208390555b505b82846001600160a01b0316866001600160a01b03166000805160206127a183398151915260405160405180910390a45050505050565b610c53828260405180602001604052806000815250611e46565b610b00816000611f96565b600880546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b604051630a85bd0160e11b81526000906001600160a01b0385169063150b7a0290611b799033908990889088906004016126b9565b6020604051808303816000875af1925050508015611bb4575060408051601f3d908101601f19168201909252611bb1918101906126f6565b60015b611c12573d808015611be2576040519150601f19603f3d011682016040523d82523d6000602084013e611be7565b606091505b508051600003611c0a576040516368d2bf6b60e11b815260040160405180910390fd5b805181602001fd5b6001600160e01b031916630a85bd0160e11b1490505b949350505050565b606081600003611c575750506040805180820190915260018152600360fc1b602082015290565b8160005b8115611c815780611c6b81612713565b9150611c7a9050600a836125c6565b9150611c5b565b6000816001600160401b03811115611c9b57611c9b612355565b6040519080825280601f01601f191660200182016040528015611cc5576020820181803683370190505b5090505b8415611c2857611cda6001836125da565b9150611ce7600a8661272c565b611cf2906030612626565b60f81b818381518110611d0757611d0761266d565b60200101906001600160f81b031916908160001a905350611d29600a866125c6565b9450611cc9565b80471015611d805760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a20696e73756666696369656e742062616c616e636500000060448201526064016109e6565b6000826001600160a01b03168260405160006040518083038185875af1925050503d8060008114611dcd576040519150601f19603f3d011682016040523d82523d6000602084013e611dd2565b606091505b5050905080610a305760405162461bcd60e51b815260206004820152603a60248201527f416464726573733a20756e61626c6520746f2073656e642076616c75652c20726044820152791958da5c1a595b9d081b585e481a185d99481c995d995c9d195960321b60648201526084016109e6565b6000546001600160a01b038416611e6f57604051622e076360e81b815260040160405180910390fd5b82600003611e905760405163b562e8dd60e01b815260040160405180910390fd5b6001600160a01b03841660008181526005602090815260408083208054680100000000000000018902019055848352600490915290204260a01b86176001861460e11b1790558190818501903b15611f53575b60405182906001600160a01b038816906000906000805160206127a1833981519152908290a4611f1c6000878480600101955087611b44565b611f39576040516368d2bf6b60e11b815260040160405180910390fd5b808210611ee3578260005414611f4e57600080fd5b611f86565b5b6040516001830192906001600160a01b038816906000906000805160206127a1833981519152908290a4808210611f54575b5060009081556110229085838684565b6000611fa1836118d1565b9050808215612005576000336001600160a01b0383161480611fc85750611fc8823361073e565b80611fe3575033611fd886610892565b6001600160a01b0316145b90508061200357604051632ce44b5f60e11b815260040160405180910390fd5b505b600084815260066020908152604080832080546001600160a01b03191690556001600160a01b03841683526005825280832080546001600160801b0301905586835260049091528120600360e01b4260a01b8417179055600160e11b8316900361209f5760018401600081815260046020526040812054900361209d57600054811461209d5760008181526004602052604090208390555b505b60405184906000906001600160a01b038416906000805160206127a1833981519152908390a4505060018054810190555050565b8280546120df90612541565b90600052602060002090601f0160209004810192826121015760008555612147565b82601f1061211a57805160ff1916838001178555612147565b82800160010185558215612147579182015b8281111561214757825182559160200191906001019061212c565b50612153929150612157565b5090565b5b808211156121535760008155600101612158565b6001600160e01b031981168114610b0057600080fd5b60006020828403121561219457600080fd5b81356111498161216c565b60005b838110156121ba5781810151838201526020016121a2565b838111156110225750506000910152565b600081518084526121e381602086016020860161219f565b601f01601f19169290920160200192915050565b60208152600061114960208301846121cb565b60006020828403121561221c57600080fd5b5035919050565b6001600160a01b0391909116815260200190565b6001600160a01b0381168114610b0057600080fd5b6000806040838503121561225f57600080fd5b823561226a81612237565b946020939093013593505050565b60008060006060848603121561228d57600080fd5b833561229881612237565b925060208401356122a881612237565b929592945050506040919091013590565b600080604083850312156122cc57600080fd5b50508035926020909101359150565b6001600160a01b03929092168252602082015260400190565b60006020828403121561230657600080fd5b813561114981612237565b6020808252825182820181905260009190848201906040850190845b818110156123495783518352928401929184019160010161232d565b50909695505050505050565b634e487b7160e01b600052604160045260246000fd5b60006001600160401b038084111561238557612385612355565b604051601f8501601f19908116603f011681019082821181831017156123ad576123ad612355565b816040528093508581528686860111156123c657600080fd5b858560208301376000602087830101525050509392505050565b6000602082840312156123f257600080fd5b81356001600160401b0381111561240857600080fd5b8201601f8101841361241957600080fd5b611c288482356020840161236b565b8015158114610b0057600080fd5b6000806040838503121561244957600080fd5b823561245481612237565b9150602083013561246481612428565b809150509250929050565b6000806000806080858703121561248557600080fd5b843561249081612237565b935060208501356124a081612237565b92506040850135915060608501356001600160401b038111156124c257600080fd5b8501601f810187136124d357600080fd5b6124e28782356020840161236b565b91505092959194509250565b6000806040838503121561250157600080fd5b82359150602083013561246481612237565b6000806040838503121561252657600080fd5b823561253181612237565b9150602083013561246481612237565b600181811c9082168061255557607f821691505b60208210810361257557634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052601160045260246000fd5b60008160001904831182151516156125ab576125ab61257b565b500290565b634e487b7160e01b600052601260045260246000fd5b6000826125d5576125d56125b0565b500490565b6000828210156125ec576125ec61257b565b500390565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b600082198211156126395761263961257b565b500190565b6000835161265081846020880161219f565b83519083019061266481836020880161219f565b01949350505050565b634e487b7160e01b600052603260045260246000fd5b60006020828403121561269557600080fd5b5051919050565b6000602082840312156126ae57600080fd5b815161114981612428565b6001600160a01b03858116825284166020820152604081018390526080606082018190526000906126ec908301846121cb565b9695505050505050565b60006020828403121561270857600080fd5b81516111498161216c565b6000600182016127255761272561257b565b5060010190565b60008261273b5761273b6125b0565b50069056fe37346666363431396538613738356234386532333462643630303366303234383134346261326364346164333662303131613962393332666430323434333130000000000000000000000000a4430c68005b1f570a111aa71e1ca7ee5246c4cdddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3efa26469706673582212204ea52b8e407f8a89d0bc96022d49046f8de2cf0100846e7237f603f69e9f239d64736f6c634300080e0033697066733a2f2f516d5277546a454e6a397748686b345a69716a58574736524b75456f466d5a6d343133646a5964414547536d75342fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef

Deployed Bytecode

0x6080604052600436106102365760003560e01c8063715018a61161012f578063a153ab5e116100b1578063a153ab5e14610658578063a22cb4651461066e578063b88d4fde1461068e578063c87b56dd146106ae578063d9cd2453146106ce578063e086e5ec146106ee578063e979806a14610703578063e985e9c514610723578063eb9047bb1461076c578063f2fde38b1461077f578063f4f3b2001461079f578063ff3ff182146107bf57600080fd5b8063715018a61461051e578063743262961461053357806377201fe4146105535780637cc4207a1461057357806380f28af3146105955780638a27034f146105b55780638d859f3e146105e55780638da5cb5b146105fb57806391b7f5ed1461061057806395d89b4114610630578063a0712d681461064557600080fd5b806323b872dd116101b857806323b872dd146103b85780632a55205a146103d85780632fbba1151461040657806332cb6b0c1461042657806335d532c91461043c57806342842e0e1461046957806342966c681461048957806355f804b3146104a95780636352211e146104c95780636373a6b1146104e957806370a08231146104fe57600080fd5b806301ffc9a71461024257806306fdde0314610277578063081812fc14610299578063095ea7b3146102c657806309d42b30146102e857806311b7e5e71461030b578063170c9c5f1461032b57806317eaf7121461034157806318160ddd146103695780632094e84d146103825780632344be0a146103a257600080fd5b3661023d57005b600080fd5b34801561024e57600080fd5b5061026261025d366004612182565b6107d5565b60405190151581526020015b60405180910390f35b34801561028357600080fd5b5061028c610800565b60405161026e91906121f7565b3480156102a557600080fd5b506102b96102b436600461220a565b610892565b60405161026e9190612223565b3480156102d257600080fd5b506102e66102e136600461224c565b6108d6565b005b3480156102f457600080fd5b506102fd600581565b60405190815260200161026e565b34801561031757600080fd5b506102e661032636600461220a565b6109a8565b34801561033757600080fd5b506102fd60155481565b34801561034d57600080fd5b506102b9737b0b5a326aa4d95968e88654af9b87624383a54981565b34801561037557600080fd5b50600154600054036102fd565b34801561038e57600080fd5b506102fd61039d36600461224c565b6109f4565b3480156103ae57600080fd5b506102fd600a5481565b3480156103c457600080fd5b506102e66103d3366004612278565b610a25565b3480156103e457600080fd5b506103f86103f33660046122b9565b610a35565b60405161026e9291906122db565b34801561041257600080fd5b506102e661042136600461220a565b610a59565b34801561043257600080fd5b506102fd611b3981565b34801561044857600080fd5b5061045c6104573660046122f4565b610b03565b60405161026e9190612311565b34801561047557600080fd5b506102e6610484366004612278565b610b6f565b34801561049557600080fd5b506102e66104a436600461220a565b610b8a565b3480156104b557600080fd5b506102e66104c43660046123e0565b610c02565b3480156104d557600080fd5b506102b96104e436600461220a565b610c57565b3480156104f557600080fd5b5061028c610c62565b34801561050a57600080fd5b506102fd6105193660046122f4565b610c7e565b34801561052a57600080fd5b506102e6610ccc565b34801561053f57600080fd5b506102e661054e36600461220a565b610d07565b34801561055f57600080fd5b506102e661056e36600461220a565b610d4a565b34801561057f57600080fd5b506102b960008051602061278183398151915281565b3480156105a157600080fd5b506102e66105b036600461220a565b610d8d565b3480156105c157600080fd5b506102626105d036600461220a565b60166020526000908152604090205460ff1681565b3480156105f157600080fd5b506102fd60095481565b34801561060757600080fd5b506102b9610dd0565b34801561061c57600080fd5b506102e661062b36600461220a565b610ddf565b34801561063c57600080fd5b5061028c610e36565b6102e661065336600461220a565b610e45565b34801561066457600080fd5b506102fd60135481565b34801561067a57600080fd5b506102e6610689366004612436565b610f49565b34801561069a57600080fd5b506102e66106a936600461246f565b610fde565b3480156106ba57600080fd5b5061028c6106c936600461220a565b611028565b3480156106da57600080fd5b506102e66106e93660046123e0565b611150565b3480156106fa57600080fd5b506102e66111a1565b34801561070f57600080fd5b506102e661071e3660046124ee565b6112d6565b34801561072f57600080fd5b5061026261073e366004612513565b6001600160a01b03918216600090815260076020908152604080832093909416825291909152205460ff1690565b6102e661077a36600461220a565b61145e565b34801561078b57600080fd5b506102e661079a3660046122f4565b6115ad565b3480156107ab57600080fd5b506102e66107ba3660046122f4565b61164a565b3480156107cb57600080fd5b506102fd60145481565b60006001600160e01b0319821663152a902d60e11b14806107fa57506107fa8261185c565b92915050565b60606002805461080f90612541565b80601f016020809104026020016040519081016040528092919081815260200182805461083b90612541565b80156108885780601f1061085d57610100808354040283529160200191610888565b820191906000526020600020905b81548152906001019060200180831161086b57829003601f168201915b5050505050905090565b600061089d826118aa565b6108ba576040516333d1c03960e21b815260040160405180910390fd5b506000908152600660205260409020546001600160a01b031690565b60006108e1826118d1565b9050806001600160a01b0316836001600160a01b0316036109155760405163250fdee360e21b815260040160405180910390fd5b336001600160a01b0382161461094c5761092f813361073e565b61094c576040516367d9dca160e11b815260040160405180910390fd5b60008281526006602052604080822080546001600160a01b0319166001600160a01b0387811691821790925591518593918516917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591a4505050565b33600080516020612781833981519152146109ef57600080516020612781833981519152604051631022f85d60e11b81526004016109e69190612223565b60405180910390fd5b600a55565b60126020528160005260406000208181548110610a1057600080fd5b90600052602060002001600091509150505481565b610a30838383611938565b505050565b3060006103e8610a46603185612591565b610a5091906125c6565b90509250929050565b336000908152600f602052604090205460ff16158015610a8d575033737b0b5a326aa4d95968e88654af9b87624383a54914155b15610aab57604051634f88b4f560e11b815260040160405180910390fd5b80600b541015610ade57600b54610ac290826125da565b6040516310df17a560e01b81526004016109e691815260200190565b80600b6000828254610af091906125da565b90915550610b0090503382611acd565b50565b6001600160a01b038116600090815260126020908152604091829020805483518184028101840190945280845260609392830182828015610b6357602002820191906000526020600020905b815481526020019060010190808311610b4f575b50505050509050919050565b610a3083838360405180602001604052806000815250610fde565b33610b9482610c57565b6001600160a01b031614610bd75780610bac82610c57565b6040516326a5d68f60e11b815260048101929092526001600160a01b031660248201526044016109e6565b33600090815260126020908152604082208054600181018255908352912001819055610b0081611ae7565b3360008051602061278183398151915214610c4057600080516020612781833981519152604051631022f85d60e11b81526004016109e69190612223565b8051610c5390600d9060208401906120d3565b5050565b60006107fa826118d1565b6040518060600160405280604081526020016127416040913981565b60006001600160a01b038216610ca7576040516323d3ad8160e21b815260040160405180910390fd5b506001600160a01b03166000908152600560205260409020546001600160401b031690565b33610cd5610dd0565b6001600160a01b031614610cfb5760405162461bcd60e51b81526004016109e6906125f1565b610d056000611af2565b565b3360008051602061278183398151915214610d4557600080516020612781833981519152604051631022f85d60e11b81526004016109e69190612223565b601755565b3360008051602061278183398151915214610d8857600080516020612781833981519152604051631022f85d60e11b81526004016109e69190612223565b601355565b3360008051602061278183398151915214610dcb57600080516020612781833981519152604051631022f85d60e11b81526004016109e69190612223565b601455565b6008546001600160a01b031690565b336000908152600f602052604090205460ff16158015610e13575033737b0b5a326aa4d95968e88654af9b87624383a54914155b15610e3157604051634f88b4f560e11b815260040160405180910390fd5b600955565b60606003805461080f90612541565b600954610e529082612591565b3414610e89573460095482610e679190612591565b604051630374cb4760e21b8152600481019290925260248201526044016109e6565b600a54421015610eac5760405163589ed34b60e01b815260040160405180910390fd5b611b39600b5482610ebc60005490565b610ec69190612626565b610ed09190612626565b1115610f1357600b5481610ee360005490565b610eed9190612626565b610ef79190612626565b604051630c540f2160e01b81526004016109e691815260200190565b6005811115610f3f57604051633eda2f4160e11b815260048101829052600560248201526044016109e6565b610b003382611acd565b336001600160a01b03831603610f725760405163b06307db60e01b815260040160405180910390fd5b3360008181526007602090815260408083206001600160a01b03871680855290835292819020805460ff191686151590811790915590519081529192917f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c31910160405180910390a35050565b610fe9848484611938565b6001600160a01b0383163b156110225761100584848484611b44565b611022576040516368d2bf6b60e11b815260040160405180910390fd5b50505050565b606061103360005490565b821061105557604051631e39122160e11b8152600481018390526024016109e6565b60008281526016602052604081205460ff1661107257600d611075565b600e5b805461108090612541565b80601f01602080910402602001604051908101604052809291908181526020018280546110ac90612541565b80156110f95780601f106110ce576101008083540402835291602001916110f9565b820191906000526020600020905b8154815290600101906020018083116110dc57829003601f168201915b50505050509050600081511161111e5760405180602001604052806000815250611149565b8061112884611c30565b60405160200161113992919061263e565b6040516020818303038152906040525b9392505050565b336000805160206127818339815191521461118e57600080516020612781833981519152604051631022f85d60e11b81526004016109e69190612223565b8051610c5390600e9060208401906120d3565b336000908152600f602052604090205460ff161580156111d5575033737b0b5a326aa4d95968e88654af9b87624383a54914155b156111f357604051634f88b4f560e11b815260040160405180910390fd5b476000819003611216576040516308ae8bb160e41b815260040160405180910390fd5b60105460005b8181101561129e576000601082815481106112395761123961266d565b6000918252602082200154601180546001600160a01b039092169350606491859081106112685761126861266d565b90600052602060002001548661127e9190612591565b61128891906125c6565b90506112948282611d30565b505060010161121c565b506040518281527f043f607a14d3b4f0a11a0b2e192bbfcd894298ba5abf22553be6081406db28aa9060200160405180910390a15050565b336000805160206127818339815191521461131457600080516020612781833981519152604051631022f85d60e11b81526004016109e69190612223565b6001600160a01b0381166113685760405162461bcd60e51b815260206004820152601b60248201527a043616e6e6f7420736574207465616d206d656d62657220746f203602c1b60448201526064016109e6565b60105482106113b55760405162461bcd60e51b8152602060048201526019602482015278092dcecc2d8d2c840e8cac2da40dacadac4cae440d2dcc8caf603b1b60448201526064016109e6565b6000600f6000601085815481106113ce576113ce61266d565b6000918252602080832091909101546001600160a01b031683528201929092526040019020805460ff191691151591909117905560108054829190849081106114195761141961266d565b600091825260208083209190910180546001600160a01b0319166001600160a01b03948516179055929091168152600f90915260409020805460ff1916600117905550565b601454341461148d57601454604051637998543b60e01b815234600482015260248101919091526044016109e6565b3361149782610c57565b6001600160a01b0316146114af5780610bac82610c57565b60008181526016602052604090205460ff16156114e25760405163d39ab56360e01b8152600481018290526024016109e6565b60135460155410611506576040516332d2dafb60e11b815260040160405180910390fd5b6017541561153f5761153f6000805160206127818339815191526064601754346115309190612591565b61153a91906125c6565b611d30565b6001601560008282546115529190612626565b909155505060008181526016602052604090819020805460ff19166001179055517f51dba42a71b99e344e4141f74c8d409d50613b760cbe5360262c20260c39b428906115a29083815260200190565b60405180910390a150565b336115b6610dd0565b6001600160a01b0316146115dc5760405162461bcd60e51b81526004016109e6906125f1565b6001600160a01b0381166116415760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016109e6565b610b0081611af2565b336000908152600f602052604090205460ff1615801561167e575033737b0b5a326aa4d95968e88654af9b87624383a54914155b1561169c57604051634f88b4f560e11b815260040160405180910390fd5b6040516370a0823160e01b81526000906001600160a01b038316906370a08231906116cb903090600401612223565b602060405180830381865afa1580156116e8573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061170c9190612683565b90508060000361172f576040516308ae8bb160e41b815260040160405180910390fd5b60105460005b8181101561181d5760006064601183815481106117545761175461266d565b90600052602060002001548561176a9190612591565b61177491906125c6565b9050846001600160a01b031663a9059cbb601084815481106117985761179861266d565b6000918252602090912001546040516001600160e01b031960e084901b1681526117d0916001600160a01b03169085906004016122db565b6020604051808303816000875af11580156117ef573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190611813919061269c565b5050600101611735565b507f7e2c99819371db0a6fc6f4269fe872496e44f502df19ba3eae594b7a15987460838360405161184f9291906122db565b60405180910390a1505050565b60006301ffc9a760e01b6001600160e01b03198316148061188d57506380ac58cd60e01b6001600160e01b03198316145b806107fa5750506001600160e01b031916635b5e139f60e01b1490565b60008054821080156107fa575050600090815260046020526040902054600160e01b161590565b60008160005481101561191f5760008181526004602052604081205490600160e01b8216900361191d575b806000036111495750600019016000818152600460205260409020546118fc565b505b604051636f96cda160e11b815260040160405180910390fd5b6000611943826118d1565b9050836001600160a01b0316816001600160a01b0316146119765760405162a1148160e81b815260040160405180910390fd5b6000336001600160a01b03861614806119945750611994853361073e565b806119af5750336119a484610892565b6001600160a01b0316145b9050806119cf57604051632ce44b5f60e11b815260040160405180910390fd5b6001600160a01b0384166119f657604051633a954ecd60e21b815260040160405180910390fd5b600083815260066020908152604080832080546001600160a01b03191690556001600160a01b038881168452600583528184208054600019019055871683528083208054600101905585835260049091528120600160e11b4260a01b8717811790915583169003611a9757600183016000818152600460205260408120549003611a95576000548114611a955760008181526004602052604090208390555b505b82846001600160a01b0316866001600160a01b03166000805160206127a183398151915260405160405180910390a45050505050565b610c53828260405180602001604052806000815250611e46565b610b00816000611f96565b600880546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b604051630a85bd0160e11b81526000906001600160a01b0385169063150b7a0290611b799033908990889088906004016126b9565b6020604051808303816000875af1925050508015611bb4575060408051601f3d908101601f19168201909252611bb1918101906126f6565b60015b611c12573d808015611be2576040519150601f19603f3d011682016040523d82523d6000602084013e611be7565b606091505b508051600003611c0a576040516368d2bf6b60e11b815260040160405180910390fd5b805181602001fd5b6001600160e01b031916630a85bd0160e11b1490505b949350505050565b606081600003611c575750506040805180820190915260018152600360fc1b602082015290565b8160005b8115611c815780611c6b81612713565b9150611c7a9050600a836125c6565b9150611c5b565b6000816001600160401b03811115611c9b57611c9b612355565b6040519080825280601f01601f191660200182016040528015611cc5576020820181803683370190505b5090505b8415611c2857611cda6001836125da565b9150611ce7600a8661272c565b611cf2906030612626565b60f81b818381518110611d0757611d0761266d565b60200101906001600160f81b031916908160001a905350611d29600a866125c6565b9450611cc9565b80471015611d805760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a20696e73756666696369656e742062616c616e636500000060448201526064016109e6565b6000826001600160a01b03168260405160006040518083038185875af1925050503d8060008114611dcd576040519150601f19603f3d011682016040523d82523d6000602084013e611dd2565b606091505b5050905080610a305760405162461bcd60e51b815260206004820152603a60248201527f416464726573733a20756e61626c6520746f2073656e642076616c75652c20726044820152791958da5c1a595b9d081b585e481a185d99481c995d995c9d195960321b60648201526084016109e6565b6000546001600160a01b038416611e6f57604051622e076360e81b815260040160405180910390fd5b82600003611e905760405163b562e8dd60e01b815260040160405180910390fd5b6001600160a01b03841660008181526005602090815260408083208054680100000000000000018902019055848352600490915290204260a01b86176001861460e11b1790558190818501903b15611f53575b60405182906001600160a01b038816906000906000805160206127a1833981519152908290a4611f1c6000878480600101955087611b44565b611f39576040516368d2bf6b60e11b815260040160405180910390fd5b808210611ee3578260005414611f4e57600080fd5b611f86565b5b6040516001830192906001600160a01b038816906000906000805160206127a1833981519152908290a4808210611f54575b5060009081556110229085838684565b6000611fa1836118d1565b9050808215612005576000336001600160a01b0383161480611fc85750611fc8823361073e565b80611fe3575033611fd886610892565b6001600160a01b0316145b90508061200357604051632ce44b5f60e11b815260040160405180910390fd5b505b600084815260066020908152604080832080546001600160a01b03191690556001600160a01b03841683526005825280832080546001600160801b0301905586835260049091528120600360e01b4260a01b8417179055600160e11b8316900361209f5760018401600081815260046020526040812054900361209d57600054811461209d5760008181526004602052604090208390555b505b60405184906000906001600160a01b038416906000805160206127a1833981519152908390a4505060018054810190555050565b8280546120df90612541565b90600052602060002090601f0160209004810192826121015760008555612147565b82601f1061211a57805160ff1916838001178555612147565b82800160010185558215612147579182015b8281111561214757825182559160200191906001019061212c565b50612153929150612157565b5090565b5b808211156121535760008155600101612158565b6001600160e01b031981168114610b0057600080fd5b60006020828403121561219457600080fd5b81356111498161216c565b60005b838110156121ba5781810151838201526020016121a2565b838111156110225750506000910152565b600081518084526121e381602086016020860161219f565b601f01601f19169290920160200192915050565b60208152600061114960208301846121cb565b60006020828403121561221c57600080fd5b5035919050565b6001600160a01b0391909116815260200190565b6001600160a01b0381168114610b0057600080fd5b6000806040838503121561225f57600080fd5b823561226a81612237565b946020939093013593505050565b60008060006060848603121561228d57600080fd5b833561229881612237565b925060208401356122a881612237565b929592945050506040919091013590565b600080604083850312156122cc57600080fd5b50508035926020909101359150565b6001600160a01b03929092168252602082015260400190565b60006020828403121561230657600080fd5b813561114981612237565b6020808252825182820181905260009190848201906040850190845b818110156123495783518352928401929184019160010161232d565b50909695505050505050565b634e487b7160e01b600052604160045260246000fd5b60006001600160401b038084111561238557612385612355565b604051601f8501601f19908116603f011681019082821181831017156123ad576123ad612355565b816040528093508581528686860111156123c657600080fd5b858560208301376000602087830101525050509392505050565b6000602082840312156123f257600080fd5b81356001600160401b0381111561240857600080fd5b8201601f8101841361241957600080fd5b611c288482356020840161236b565b8015158114610b0057600080fd5b6000806040838503121561244957600080fd5b823561245481612237565b9150602083013561246481612428565b809150509250929050565b6000806000806080858703121561248557600080fd5b843561249081612237565b935060208501356124a081612237565b92506040850135915060608501356001600160401b038111156124c257600080fd5b8501601f810187136124d357600080fd5b6124e28782356020840161236b565b91505092959194509250565b6000806040838503121561250157600080fd5b82359150602083013561246481612237565b6000806040838503121561252657600080fd5b823561253181612237565b9150602083013561246481612237565b600181811c9082168061255557607f821691505b60208210810361257557634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052601160045260246000fd5b60008160001904831182151516156125ab576125ab61257b565b500290565b634e487b7160e01b600052601260045260246000fd5b6000826125d5576125d56125b0565b500490565b6000828210156125ec576125ec61257b565b500390565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b600082198211156126395761263961257b565b500190565b6000835161265081846020880161219f565b83519083019061266481836020880161219f565b01949350505050565b634e487b7160e01b600052603260045260246000fd5b60006020828403121561269557600080fd5b5051919050565b6000602082840312156126ae57600080fd5b815161114981612428565b6001600160a01b03858116825284166020820152604081018390526080606082018190526000906126ec908301846121cb565b9695505050505050565b60006020828403121561270857600080fd5b81516111498161216c565b6000600182016127255761272561257b565b5060010190565b60008261273b5761273b6125b0565b50069056fe37346666363431396538613738356234386532333462643630303366303234383134346261326364346164333662303131613962393332666430323434333130000000000000000000000000a4430c68005b1f570a111aa71e1ca7ee5246c4cdddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3efa26469706673582212204ea52b8e407f8a89d0bc96022d49046f8de2cf0100846e7237f603f69e9f239d64736f6c634300080e0033

Deployed Bytecode Sourcemap

122188:12665:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;132189:205;;;;;;;;;;-1:-1:-1;132189:205:0;;;;;:::i;:::-;;:::i;:::-;;;565:14:1;;558:22;540:41;;528:2;513:18;132189:205:0;;;;;;;;20740:100;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;22808:204::-;;;;;;;;;;-1:-1:-1;22808:204:0;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;22268:474::-;;;;;;;;;;-1:-1:-1;22268:474:0;;;;;:::i;:::-;;:::i;:::-;;122562:40;;;;;;;;;;;;122601:1;122562:40;;;;;2338:25:1;;;2326:2;2311:18;122562:40:0;2192:177:1;128532:104:0;;;;;;;;;;-1:-1:-1;128532:104:0;;;;;:::i;:::-;;:::i;124702:29::-;;;;;;;;;;;;;;;;123734:75;;;;;;;;;;;;123767:42;123734:75;;14781:315;;;;;;;;;;-1:-1:-1;15047:12:0;;14834:7;15031:13;:28;14781:315;;124526:46;;;;;;;;;;-1:-1:-1;124526:46:0;;;;;:::i;:::-;;:::i;122882:42::-;;;;;;;;;;;;;;;;23694:170;;;;;;;;;;-1:-1:-1;23694:170:0;;;;;:::i;:::-;;:::i;132526:258::-;;;;;;;;;;-1:-1:-1;132526:258:0;;;;;:::i;:::-;;:::i;:::-;;;;;;;;:::i;129200:227::-;;;;;;;;;;-1:-1:-1;129200:227:0;;;;;:::i;:::-;;:::i;122463:41::-;;;;;;;;;;;;122500:4;122463:41;;130362:114;;;;;;;;;;-1:-1:-1;130362:114:0;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;23935:185::-;;;;;;;;;;-1:-1:-1;23935:185:0;;;;;:::i;:::-;;:::i;130063:291::-;;;;;;;;;;-1:-1:-1;130063:291:0;;;;;:::i;:::-;;:::i;127763:90::-;;;;;;;;;;-1:-1:-1;127763:90:0;;;;;:::i;:::-;;:::i;20529:144::-;;;;;;;;;;-1:-1:-1;20529:144:0;;;;;:::i;:::-;;:::i;123108:102::-;;;;;;;;;;;;;:::i;16406:224::-;;;;;;;;;;-1:-1:-1;16406:224:0;;;;;:::i;:::-;;:::i;46439:103::-;;;;;;;;;;;;;:::i;128884:122::-;;;;;;;;;;-1:-1:-1;128884:122:0;;;;;:::i;:::-;;:::i;128676:95::-;;;;;;;;;;-1:-1:-1;128676:95:0;;;;;:::i;:::-;;:::i;123652:75::-;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;123652:75:0;;128777:101;;;;;;;;;;-1:-1:-1;128777:101:0;;;;;:::i;:::-;;:::i;124749:44::-;;;;;;;;;;-1:-1:-1;124749:44:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;122609:32;;;;;;;;;;;;;;;;45788:87;;;;;;;;;;;;;:::i;127372:::-;;;;;;;;;;-1:-1:-1;127372:87:0;;;;;:::i;:::-;;:::i;20909:104::-;;;;;;;;;;;;;:::i;129435:620::-;;;;;;:::i;:::-;;:::i;124609:36::-;;;;;;;;;;;;;;;;23084:308;;;;;;;;;;-1:-1:-1;23084:308:0;;;;;:::i;:::-;;:::i;24191:396::-;;;;;;;;;;-1:-1:-1;24191:396:0;;;;;:::i;:::-;;:::i;128138:357::-;;;;;;;;;;-1:-1:-1;128138:357:0;;;;;:::i;:::-;;:::i;127934:112::-;;;;;;;;;;-1:-1:-1;127934:112:0;;;;;:::i;:::-;;:::i;130732:572::-;;;;;;;;;;;;;:::i;126669:366::-;;;;;;;;;;-1:-1:-1;126669:366:0;;;;;:::i;:::-;;:::i;23463:164::-;;;;;;;;;;-1:-1:-1;23463:164:0;;;;;:::i;:::-;-1:-1:-1;;;;;23584:25:0;;;23560:4;23584:25;;;:18;:25;;;;;;;;:35;;;;;;;;;;;;;;;23463:164;133081:732;;;;;;:::i;:::-;;:::i;46697:201::-;;;;;;;;;;-1:-1:-1;46697:201:0;;;;;:::i;:::-;;:::i;131356:567::-;;;;;;;;;;-1:-1:-1;131356:567:0;;;;;:::i;:::-;;:::i;124652:43::-;;;;;;;;;;;;;;;;132189:205;132285:4;-1:-1:-1;;;;;;132309:36:0;;-1:-1:-1;;;132309:36:0;;:77;;;132349:37;132373:12;132349:23;:37::i;:::-;132302:84;132189:205;-1:-1:-1;;132189:205:0:o;20740:100::-;20794:13;20827:5;20820:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;20740:100;:::o;22808:204::-;22876:7;22901:16;22909:7;22901;:16::i;:::-;22896:64;;22926:34;;-1:-1:-1;;;22926:34:0;;;;;;;;;;;22896:64;-1:-1:-1;22980:24:0;;;;:15;:24;;;;;;-1:-1:-1;;;;;22980:24:0;;22808:204::o;22268:474::-;22341:13;22373:27;22392:7;22373:18;:27::i;:::-;22341:61;;22423:5;-1:-1:-1;;;;;22417:11:0;:2;-1:-1:-1;;;;;22417:11:0;;22413:48;;22437:24;;-1:-1:-1;;;22437:24:0;;;;;;;;;;;22413:48;38911:10;-1:-1:-1;;;;;22478:28:0;;;22474:175;;22526:44;22543:5;38911:10;23463:164;:::i;22526:44::-;22521:128;;22598:35;;-1:-1:-1;;;22598:35:0;;;;;;;;;;;22521:128;22661:24;;;;:15;:24;;;;;;:29;;-1:-1:-1;;;;;;22661:29:0;-1:-1:-1;;;;;22661:29:0;;;;;;;;;22706:28;;22661:24;;22706:28;;;;;;;22330:412;22268:474;;:::o;128532:104::-;126171:10;-1:-1:-1;;;;;;;;;;;126171:20:0;126167:68;;-1:-1:-1;;;;;;;;;;;126200:35:0;;-1:-1:-1;;;126200:35:0;;;;;;;;:::i;:::-;;;;;;;;126167:68;128603:14:::1;:25:::0;128532:104::o;124526:46::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::o;23694:170::-;23828:28;23838:4;23844:2;23848:7;23828:9;:28::i;:::-;23694:170;;;:::o;132526:258::-;132697:4;132623:17;132772:4;132731:37;124515:2;132731:10;:37;:::i;:::-;132730:46;;;;:::i;:::-;132713:63;;132526:258;;;;;:::o;129200:227::-;126304:10;126297:18;;;;:6;:18;;;;;;;;126296:19;:42;;;;-1:-1:-1;126319:10:0;123767:42;126319:19;;126296:42;126292:74;;;126347:19;;-1:-1:-1;;;126347:19:0;;;;;;;;;;;126292:74;129284:7:::1;129268:13;;:23;129264:77;;;129327:13;::::0;129317:23:::1;::::0;:7;:23:::1;:::i;:::-;129300:41;;-1:-1:-1::0;;;129300:41:0::1;;;;;;2338:25:1::0;;2326:2;2311:18;;2192:177;129264:77:0::1;129369:7;129352:13;;:24;;;;;;;:::i;:::-;::::0;;;-1:-1:-1;129389:30:0::1;::::0;-1:-1:-1;129399:10:0::1;129411:7:::0;129389:9:::1;:30::i;:::-;129200:227:::0;:::o;130362:114::-;-1:-1:-1;;;;;130455:13:0;;;;;;:8;:13;;;;;;;;;130448:20;;;;;;;;;;;;;;;;;130419:16;;130448:20;;;130455:13;130448:20;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;130362:114;;;:::o;23935:185::-;24073:39;24090:4;24096:2;24100:7;24073:39;;;;;;;;;;;;:16;:39::i;130063:291::-;130140:10;130119:17;130127:8;130119:7;:17::i;:::-;-1:-1:-1;;;;;130119:31:0;;130115:96;;130183:8;130193:17;130201:8;130193:7;:17::i;:::-;130159:52;;-1:-1:-1;;;130159:52:0;;;;;9022:25:1;;;;-1:-1:-1;;;;;9083:32:1;9063:18;;;9056:60;8995:18;;130159:52:0;8848:274:1;130115:96:0;130294:10;130285:20;;;;:8;:20;;;;;;;:35;;;;;;;;;;;;;;;;130331:15;130311:8;130331:5;:15::i;127763:90::-;126171:10;-1:-1:-1;;;;;;;;;;;126171:20:0;126167:68;;-1:-1:-1;;;;;;;;;;;126200:35:0;;-1:-1:-1;;;126200:35:0;;;;;;;;:::i;126167:68::-;127831:14;;::::1;::::0;:7:::1;::::0;:14:::1;::::0;::::1;::::0;::::1;:::i;:::-;;127763:90:::0;:::o;20529:144::-;20593:7;20636:27;20655:7;20636:18;:27::i;123108:102::-;;;;;;;;;;;;;;;;;;;:::o;16406:224::-;16470:7;-1:-1:-1;;;;;16494:19:0;;16490:60;;16522:28;;-1:-1:-1;;;16522:28:0;;;;;;;;;;;16490:60;-1:-1:-1;;;;;;16568:25:0;;;;;:18;:25;;;;;;-1:-1:-1;;;;;16568:54:0;;16406:224::o;46439:103::-;38911:10;46008:7;:5;:7::i;:::-;-1:-1:-1;;;;;46008:23:0;;46000:68;;;;-1:-1:-1;;;46000:68:0;;;;;;;:::i;:::-;46504:30:::1;46531:1;46504:18;:30::i;:::-;46439:103::o:0;128884:122::-;126171:10;-1:-1:-1;;;;;;;;;;;126171:20:0;126167:68;;-1:-1:-1;;;;;;;;;;;126200:35:0;;-1:-1:-1;;;126200:35:0;;;;;;;;:::i;126167:68::-;128963:19:::1;:35:::0;128884:122::o;128676:95::-;126171:10;-1:-1:-1;;;;;;;;;;;126171:20:0;126167:68;;-1:-1:-1;;;;;;;;;;;126200:35:0;;-1:-1:-1;;;126200:35:0;;;;;;;;:::i;126167:68::-;128742:14:::1;:21:::0;128676:95::o;128777:101::-;126171:10;-1:-1:-1;;;;;;;;;;;126171:20:0;126167:68;;-1:-1:-1;;;;;;;;;;;126200:35:0;;-1:-1:-1;;;126200:35:0;;;;;;;;:::i;126167:68::-;128846:15:::1;:24:::0;128777:101::o;45788:87::-;45861:6;;-1:-1:-1;;;;;45861:6:0;;45788:87::o;127372:::-;126304:10;126297:18;;;;:6;:18;;;;;;;;126296:19;:42;;;;-1:-1:-1;126319:10:0;123767:42;126319:19;;126296:42;126292:74;;;126347:19;;-1:-1:-1;;;126347:19:0;;;;;;;;;;;126292:74;127435:5:::1;:16:::0;127372:87::o;20909:104::-;20965:13;20998:7;20991:14;;;;;:::i;129435:620::-;129521:5;;129511:15;;:7;:15;:::i;:::-;129498:9;:28;129494:81;;129548:9;129569:5;;129559:7;:15;;;;:::i;:::-;129535:40;;-1:-1:-1;;;129535:40:0;;;;;9662:25:1;;;;9703:18;;;9696:34;9635:18;;129535:40:0;9488:248:1;129494:81:0;129608:14;;129590:15;:32;129586:57;;;129631:12;;-1:-1:-1;;;129631:12:0;;;;;;;;;;;129586:57;122500:4;129685:13;;129675:7;129658:14;15241:7;15429:13;;15194:285;129658:14;:24;;;;:::i;:::-;:40;;;;:::i;:::-;:53;129654:126;;;129766:13;;129756:7;129739:14;15241:7;15429:13;;15194:285;129739:14;:24;;;;:::i;:::-;:40;;;;:::i;:::-;129720:60;;-1:-1:-1;;;129720:60:0;;;;;;2338:25:1;;2326:2;2311:18;;2192:177;129654:126:0;122601:1;129795:7;:22;129791:69;;;129826:34;;-1:-1:-1;;;129826:34:0;;;;;9662:25:1;;;122601:1:0;9703:18:1;;;9696:34;9635:18;;129826:34:0;9488:248:1;129791:69:0;130017:30;130027:10;130039:7;130017:9;:30::i;23084:308::-;38911:10;-1:-1:-1;;;;;23183:31:0;;;23179:61;;23223:17;;-1:-1:-1;;;23223:17:0;;;;;;;;;;;23179:61;38911:10;23253:39;;;;:18;:39;;;;;;;;-1:-1:-1;;;;;23253:49:0;;;;;;;;;;;;:60;;-1:-1:-1;;23253:60:0;;;;;;;;;;23329:55;;540:41:1;;;23253:49:0;;38911:10;23329:55;;513:18:1;23329:55:0;;;;;;;23084:308;;:::o;24191:396::-;24358:28;24368:4;24374:2;24378:7;24358:9;:28::i;:::-;-1:-1:-1;;;;;24401:14:0;;;:19;24397:183;;24440:56;24471:4;24477:2;24481:7;24490:5;24440:30;:56::i;:::-;24435:145;;24524:40;;-1:-1:-1;;;24524:40:0;;;;;;;;;;;24435:145;24191:396;;;;:::o;128138:357::-;128211:13;128252:14;15241:7;15429:13;;15194:285;128252:14;128241:7;:25;128237:55;;128275:17;;-1:-1:-1;;;128275:17:0;;;;;2338:25:1;;;2311:18;;128275:17:0;2192:177:1;128237:55:0;128305:22;128330:20;;;:11;:20;;;;;;;;:51;;128374:7;128330:51;;;128353:18;128330:51;128305:76;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;128424:1;128405:8;128399:22;:26;:88;;;;;;;;;;;;;;;;;128452:8;128462:18;:7;:16;:18::i;:::-;128435:46;;;;;;;;;:::i;:::-;;;;;;;;;;;;;128399:88;128392:95;128138:357;-1:-1:-1;;;128138:357:0:o;127934:112::-;126171:10;-1:-1:-1;;;;;;;;;;;126171:20:0;126167:68;;-1:-1:-1;;;;;;;;;;;126200:35:0;;-1:-1:-1;;;126200:35:0;;;;;;;;:::i;126167:68::-;128013:25;;::::1;::::0;:18:::1;::::0;:25:::1;::::0;::::1;::::0;::::1;:::i;130732:572::-:0;126304:10;126297:18;;;;:6;:18;;;;;;;;126296:19;:42;;;;-1:-1:-1;126319:10:0;123767:42;126319:19;;126296:42;126292:74;;;126347:19;;-1:-1:-1;;;126347:19:0;;;;;;;;;;;126292:74;130801:21:::1;130782:16;130837:13:::0;;;130833:41:::1;;130859:15;;-1:-1:-1::0;;;130859:15:0::1;;;;;;;;;;;130833:41;130906:4;:11:::0;130887:16:::1;130928:331;130948:8;130944:1;:12;130928:331;;;130975:22;131008:4;131013:1;131008:7;;;;;;;;:::i;:::-;;::::0;;;::::1;::::0;;::::1;::::0;131106:10:::1;:13:::0;;-1:-1:-1;;;;;131008:7:0;;::::1;::::0;-1:-1:-1;124356:3:0::1;::::0;131117:1;;131106:13;::::1;;;;;:::i;:::-;;;;;;;;;131095:8;:24;;;;:::i;:::-;131094:41;;;;:::i;:::-;131076:59;;131179:34;131197:6;131205:7;131179:17;:34::i;:::-;-1:-1:-1::0;;131242:3:0::1;;130928:331;;;-1:-1:-1::0;131274:22:0::1;::::0;2338:25:1;;;131274:22:0::1;::::0;2326:2:1;2311:18;131274:22:0::1;;;;;;;130771:533;;130732:572::o:0;126669:366::-;126171:10;-1:-1:-1;;;;;;;;;;;126171:20:0;126167:68;;-1:-1:-1;;;;;;;;;;;126200:35:0;;-1:-1:-1;;;126200:35:0;;;;;;;;:::i;126167:68::-;-1:-1:-1;;;;;126759:20:0;::::1;126751:60;;;::::0;-1:-1:-1;;;126751:60:0;;10683:2:1;126751:60:0::1;::::0;::::1;10665:21:1::0;10722:2;10702:18;;;10695:30;-1:-1:-1;;;10741:18:1;;;10734:57;10808:18;;126751:60:0::1;10481:351:1::0;126751:60:0::1;126838:4;:11:::0;126830:19;::::1;126822:57;;;::::0;-1:-1:-1;;;126822:57:0;;11039:2:1;126822:57:0::1;::::0;::::1;11021:21:1::0;11078:2;11058:18;;;11051:30;-1:-1:-1;;;11097:18:1;;;11090:55;11162:18;;126822:57:0::1;10837:349:1::0;126822:57:0::1;126914:5;126892:6;:19;126899:4;126904:5;126899:11;;;;;;;;:::i;:::-;;::::0;;;::::1;::::0;;;;;;::::1;::::0;-1:-1:-1;;;;;126899:11:0::1;126892:19:::0;;;::::1;::::0;;;;;;;;:27;;-1:-1:-1;;126892:27:0::1;::::0;::::1;;::::0;;;::::1;::::0;;126953:4:::1;:11:::0;;126967:6;;126953:4;126958:5;;126953:11;::::1;;;;;:::i;:::-;;::::0;;;::::1;::::0;;;;;;::::1;:20:::0;;-1:-1:-1;;;;;;126953:20:0::1;-1:-1:-1::0;;;;;126953:20:0;;::::1;;::::0;;127006:14;;;::::1;::::0;;:6:::1;:14:::0;;;;;;:21;;-1:-1:-1;;127006:21:0::1;-1:-1:-1::0;127006:21:0::1;::::0;;-1:-1:-1;126669:366:0:o;133081:732::-;133161:15;;133148:9;:28;133144:88;;133216:15;;133185:47;;-1:-1:-1;;;133185:47:0;;133205:9;133185:47;;;9662:25:1;9703:18;;;9696:34;;;;9635:18;;133185:47:0;9488:248:1;133144:88:0;133268:10;133247:17;133255:8;133247:7;:17::i;:::-;-1:-1:-1;;;;;133247:31:0;;133243:96;;133311:8;133321:17;133329:8;133321:7;:17::i;133243:96::-;133354:21;;;;:11;:21;;;;;;;;133350:62;;;133384:28;;-1:-1:-1;;;133384:28:0;;;;;2338:25:1;;;2311:18;;133384:28:0;2192:177:1;133350:62:0;133445:14;;133427;;:32;133423:64;;133468:19;;-1:-1:-1;;;133468:19:0;;;;;;;;;;;133423:64;133573:19;;:23;133569:129;;133613:73;-1:-1:-1;;;;;;;;;;;133682:3:0;133660:19;;133648:9;:31;;;;:::i;:::-;:37;;;;:::i;:::-;133613:17;:73::i;:::-;133728:1;133710:14;;:19;;;;;;;:::i;:::-;;;;-1:-1:-1;;133740:21:0;;;;:11;:21;;;;;;;:28;;-1:-1:-1;;133740:28:0;133764:4;133740:28;;;133784:21;;;;;133752:8;2338:25:1;;2326:2;2311:18;;2192:177;133784:21:0;;;;;;;;133081:732;:::o;46697:201::-;38911:10;46008:7;:5;:7::i;:::-;-1:-1:-1;;;;;46008:23:0;;46000:68;;;;-1:-1:-1;;;46000:68:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;46786:22:0;::::1;46778:73;;;::::0;-1:-1:-1;;;46778:73:0;;11393:2:1;46778:73:0::1;::::0;::::1;11375:21:1::0;11432:2;11412:18;;;11405:30;11471:34;11451:18;;;11444:62;-1:-1:-1;;;11522:18:1;;;11515:36;11568:19;;46778:73:0::1;11191:402:1::0;46778:73:0::1;46862:28;46881:8;46862:18;:28::i;131356:567::-:0;126304:10;126297:18;;;;:6;:18;;;;;;;;126296:19;:42;;;;-1:-1:-1;126319:10:0;123767:42;126319:19;;126296:42;126292:74;;;126347:19;;-1:-1:-1;;;126347:19:0;;;;;;;;;;;126292:74;131442:31:::1;::::0;-1:-1:-1;;;131442:31:0;;131421:18:::1;::::0;-1:-1:-1;;;;;131442:16:0;::::1;::::0;::::1;::::0;:31:::1;::::0;131467:4:::1;::::0;131442:31:::1;;;:::i;:::-;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;131421:52;;131488:10;131502:1;131488:15:::0;131484:43:::1;;131512:15;;-1:-1:-1::0;;;131512:15:0::1;;;;;;;;;;;131484:43;131559:4;:11:::0;131540:16:::1;131581:276;131601:8;131597:1;:12;131581:276;;;131673:15;124356:3;131705:10;131716:1;131705:13;;;;;;;;:::i;:::-;;;;;;;;;131692:10;:26;;;;:::i;:::-;131691:43;;;;:::i;:::-;131673:61;;131778:6;-1:-1:-1::0;;;;;131778:15:0::1;;131794:4;131799:1;131794:7;;;;;;;;:::i;:::-;;::::0;;;::::1;::::0;;;::::1;::::0;131778:33:::1;::::0;-1:-1:-1;;;;;;131778:33:0::1;::::0;;;;;;::::1;::::0;-1:-1:-1;;;;;131794:7:0::1;::::0;131803;;131778:33:::1;;;:::i;:::-;;;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;-1:-1:-1::0;;131840:3:0::1;;131581:276;;;;131872:43;131895:6;131904:10;131872:43;;;;;;;:::i;:::-;;;;;;;;131410:513;;131356:567:::0;:::o;15727:615::-;15812:4;-1:-1:-1;;;;;;;;;16112:25:0;;;;:102;;-1:-1:-1;;;;;;;;;;16189:25:0;;;16112:102;:179;;;-1:-1:-1;;;;;;;;16266:25:0;-1:-1:-1;;;16266:25:0;;15727:615::o;24842:273::-;24899:4;24989:13;;24979:7;:23;24936:152;;;;-1:-1:-1;;25040:26:0;;;;:17;:26;;;;;;-1:-1:-1;;;25040:43:0;:48;;24842:273::o;18044:1129::-;18111:7;18146;18248:13;;18241:4;:20;18237:869;;;18286:14;18303:23;;;:17;:23;;;;;;;-1:-1:-1;;;18392:23:0;;:28;;18388:699;;18911:113;18918:6;18928:1;18918:11;18911:113;;-1:-1:-1;;;18989:6:0;18971:25;;;;:17;:25;;;;;;18911:113;;18388:699;18263:843;18237:869;19134:31;;-1:-1:-1;;;19134:31:0;;;;;;;;;;;30081:2515;30196:27;30226;30245:7;30226:18;:27::i;:::-;30196:57;;30311:4;-1:-1:-1;;;;;30270:45:0;30286:19;-1:-1:-1;;;;;30270:45:0;;30266:86;;30324:28;;-1:-1:-1;;;30324:28:0;;;;;;;;;;;30266:86;30365:22;38911:10;-1:-1:-1;;;;;30391:27:0;;;;:87;;-1:-1:-1;30435:43:0;30452:4;38911:10;23463:164;:::i;30435:43::-;30391:147;;;-1:-1:-1;38911:10:0;30495:20;30507:7;30495:11;:20::i;:::-;-1:-1:-1;;;;;30495:43:0;;30391:147;30365:174;;30557:17;30552:66;;30583:35;;-1:-1:-1;;;30583:35:0;;;;;;;;;;;30552:66;-1:-1:-1;;;;;30633:16:0;;30629:52;;30658:23;;-1:-1:-1;;;30658:23:0;;;;;;;;;;;30629:52;30810:24;;;;:15;:24;;;;;;;;30803:31;;-1:-1:-1;;;;;;30803:31:0;;;-1:-1:-1;;;;;31202:24:0;;;;;:18;:24;;;;;31200:26;;-1:-1:-1;;31200:26:0;;;31271:22;;;;;;;31269:24;;-1:-1:-1;31269:24:0;;;31564:26;;;:17;:26;;;;;-1:-1:-1;;;31652:15:0;12399:3;31652:41;31610:84;;:128;;31564:174;;;31858:46;;:51;;31854:626;;31962:1;31952:11;;31930:19;32085:30;;;:17;:30;;;;;;:35;;32081:384;;32223:13;;32208:11;:28;32204:242;;32370:30;;;;:17;:30;;;;;:52;;;32204:242;31911:569;31854:626;32527:7;32523:2;-1:-1:-1;;;;;32508:27:0;32517:4;-1:-1:-1;;;;;32508:27:0;-1:-1:-1;;;;;;;;;;;32508:27:0;;;;;;;;;30185:2411;;30081:2515;;;:::o;25199:104::-;25268:27;25278:2;25282:8;25268:27;;;;;;;;;;;;:9;:27::i;32674:89::-;32734:21;32740:7;32749:5;32734;:21::i;47058:191::-;47151:6;;;-1:-1:-1;;;;;47168:17:0;;;-1:-1:-1;;;;;;47168:17:0;;;;;;;47201:40;;47151:6;;;47168:17;47151:6;;47201:40;;47132:16;;47201:40;47121:128;47058:191;:::o;36293:716::-;36477:88;;-1:-1:-1;;;36477:88:0;;36456:4;;-1:-1:-1;;;;;36477:45:0;;;;;:88;;38911:10;;36544:4;;36550:7;;36559:5;;36477:88;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;-1:-1:-1;36477:88:0;;;;;;;;-1:-1:-1;;36477:88:0;;;;;;;;;;;;:::i;:::-;;;36473:529;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;36760:6;:13;36777:1;36760:18;36756:235;;36806:40;;-1:-1:-1;;;36806:40:0;;;;;;;;;;;36756:235;36949:6;36943:13;36934:6;36930:2;36926:15;36919:38;36473:529;-1:-1:-1;;;;;;36636:64:0;-1:-1:-1;;;36636:64:0;;-1:-1:-1;36473:529:0;36293:716;;;;;;:::o;56094:723::-;56150:13;56371:5;56380:1;56371:10;56367:53;;-1:-1:-1;;56398:10:0;;;;;;;;;;;;-1:-1:-1;;;56398:10:0;;;;;56094:723::o;56367:53::-;56445:5;56430:12;56486:78;56493:9;;56486:78;;56519:8;;;;:::i;:::-;;-1:-1:-1;56542:10:0;;-1:-1:-1;56550:2:0;56542:10;;:::i;:::-;;;56486:78;;;56574:19;56606:6;-1:-1:-1;;;;;56596:17:0;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;56596:17:0;;56574:39;;56624:154;56631:10;;56624:154;;56658:11;56668:1;56658:11;;:::i;:::-;;-1:-1:-1;56727:10:0;56735:2;56727:5;:10;:::i;:::-;56714:24;;:2;:24;:::i;:::-;56701:39;;56684:6;56691;56684:14;;;;;;;;:::i;:::-;;;;:56;-1:-1:-1;;;;;56684:56:0;;;;;;;;-1:-1:-1;56755:11:0;56764:2;56755:11;;:::i;:::-;;;56624:154;;49735:317;49850:6;49825:21;:31;;49817:73;;;;-1:-1:-1;;;49817:73:0;;13244:2:1;49817:73:0;;;13226:21:1;13283:2;13263:18;;;13256:30;13322:31;13302:18;;;13295:59;13371:18;;49817:73:0;13042:353:1;49817:73:0;49904:12;49922:9;-1:-1:-1;;;;;49922:14:0;49944:6;49922:33;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;49903:52;;;49974:7;49966:78;;;;-1:-1:-1;;;49966:78:0;;13812:2:1;49966:78:0;;;13794:21:1;13851:2;13831:18;;;13824:30;13890:34;13870:18;;;13863:62;-1:-1:-1;;;13941:18:1;;;13934:56;14007:19;;49966:78:0;13610:422:1;25676:2236:0;25799:20;25822:13;-1:-1:-1;;;;;25850:16:0;;25846:48;;25875:19;;-1:-1:-1;;;25875:19:0;;;;;;;;;;;25846:48;25909:8;25921:1;25909:13;25905:44;;25931:18;;-1:-1:-1;;;25931:18:0;;;;;;;;;;;25905:44;-1:-1:-1;;;;;26498:22:0;;;;;;:18;:22;;;;11882:2;26498:22;;;:70;;26536:31;26524:44;;26498:70;;;26811:31;;;:17;:31;;;;;26904:15;12399:3;26904:41;26862:84;;-1:-1:-1;26982:13:0;;12662:3;26967:56;26862:162;26811:213;;:31;;27105:23;;;;27149:14;:19;27145:635;;27189:313;27220:38;;27245:12;;-1:-1:-1;;;;;27220:38:0;;;27237:1;;-1:-1:-1;;;;;;;;;;;27220:38:0;27237:1;;27220:38;27286:69;27325:1;27329:2;27333:14;;;;;;27349:5;27286:30;:69::i;:::-;27281:174;;27391:40;;-1:-1:-1;;;27391:40:0;;;;;;;;;;;27281:174;27497:3;27482:12;:18;27189:313;;27583:12;27566:13;;:29;27562:43;;27597:8;;;27562:43;27145:635;;;27646:119;27677:40;;27702:14;;;;;-1:-1:-1;;;;;27677:40:0;;;27694:1;;-1:-1:-1;;;;;;;;;;;27677:40:0;27694:1;;27677:40;27760:3;27745:12;:18;27646:119;;27145:635;-1:-1:-1;27794:13:0;:28;;;27844:60;;27877:2;27881:12;27895:8;27844:60;:::i;32992:2809::-;33072:27;33102;33121:7;33102:18;:27::i;:::-;33072:57;-1:-1:-1;33072:57:0;33207:311;;;;33241:22;38911:10;-1:-1:-1;;;;;33267:27:0;;;;:91;;-1:-1:-1;33315:43:0;33332:4;38911:10;23463:164;:::i;33315:43::-;33267:155;;;-1:-1:-1;38911:10:0;33379:20;33391:7;33379:11;:20::i;:::-;-1:-1:-1;;;;;33379:43:0;;33267:155;33241:182;;33445:17;33440:66;;33471:35;;-1:-1:-1;;;33471:35:0;;;;;;;;;;;33440:66;33226:292;33207:311;33654:24;;;;:15;:24;;;;;;;;33647:31;;-1:-1:-1;;;;;;33647:31:0;;;-1:-1:-1;;;;;34267:24:0;;;;:18;:24;;;;;:59;;-1:-1:-1;;;;;34267:59:0;;;34564:26;;;:17;:26;;;;;-1:-1:-1;;;34654:15:0;12399:3;34654:41;34610:86;;:165;34564:211;;-1:-1:-1;;;34895:46:0;;:51;;34891:626;;34999:1;34989:11;;34967:19;35122:30;;;:17;:30;;;;;;:35;;35118:384;;35260:13;;35245:11;:28;35241:242;;35407:30;;;;:17;:30;;;;;:52;;;35241:242;34948:569;34891:626;35545:35;;35572:7;;35568:1;;-1:-1:-1;;;;;35545:35:0;;;-1:-1:-1;;;;;;;;;;;35545:35:0;35568:1;;35545:35;-1:-1:-1;;35768:12:0;:14;;;;;;-1:-1:-1;;32992:2809:0:o;-1:-1:-1:-;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;:::o;:::-;;;;;;;;;;;;;;;14:131:1;-1:-1:-1;;;;;;88:32:1;;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:1;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:1;1061:39;;;;1102:4;1057:50;;855:258;-1:-1:-1;;855:258:1: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:1;;1343:180;-1:-1:-1;1343:180:1:o;1528:203::-;-1:-1:-1;;;;;1692:32:1;;;;1674:51;;1662:2;1647:18;;1528:203::o;1736:131::-;-1:-1:-1;;;;;1811:31:1;;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:1: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:1;2686:18;;2673:32;2714:33;2673:32;2714:33;:::i;:::-;2374:456;;2766:7;;-1:-1:-1;;;2820:2:1;2805:18;;;;2792:32;;2374:456::o;2835:248::-;2903:6;2911;2964:2;2952:9;2943:7;2939:23;2935:32;2932:52;;;2980:1;2977;2970:12;2932:52;-1:-1:-1;;3003:23:1;;;3073:2;3058:18;;;3045:32;;-1:-1:-1;2835:248:1:o;3088:274::-;-1:-1:-1;;;;;3280:32:1;;;;3262:51;;3344:2;3329:18;;3322:34;3250:2;3235:18;;3088:274::o;3367:247::-;3426:6;3479:2;3467:9;3458:7;3454:23;3450:32;3447:52;;;3495:1;3492;3485:12;3447:52;3534:9;3521:23;3553:31;3578:5;3553:31;:::i;3619:632::-;3790:2;3842:21;;;3912:13;;3815:18;;;3934:22;;;3761:4;;3790:2;4013:15;;;;3987:2;3972:18;;;3761:4;4056:169;4070:6;4067:1;4064:13;4056:169;;;4131:13;;4119:26;;4200:15;;;;4165:12;;;;4092:1;4085:9;4056:169;;;-1:-1:-1;4242:3:1;;3619:632;-1:-1:-1;;;;;;3619:632:1:o;4256:127::-;4317:10;4312:3;4308:20;4305:1;4298:31;4348:4;4345:1;4338:15;4372:4;4369:1;4362:15;4388:632;4453:5;-1:-1:-1;;;;;4524:2:1;4516:6;4513:14;4510:40;;;4530:18;;:::i;:::-;4605:2;4599:9;4573:2;4659:15;;-1:-1:-1;;4655:24:1;;;4681:2;4651:33;4647:42;4635:55;;;4705:18;;;4725:22;;;4702:46;4699:72;;;4751:18;;:::i;:::-;4791:10;4787:2;4780:22;4820:6;4811:15;;4850:6;4842;4835:22;4890:3;4881:6;4876:3;4872:16;4869:25;4866:45;;;4907:1;4904;4897:12;4866:45;4957:6;4952:3;4945:4;4937:6;4933:17;4920:44;5012:1;5005:4;4996:6;4988;4984:19;4980:30;4973:41;;;;4388:632;;;;;:::o;5025:451::-;5094:6;5147:2;5135:9;5126:7;5122:23;5118:32;5115:52;;;5163:1;5160;5153:12;5115:52;5203:9;5190:23;-1:-1:-1;;;;;5228:6:1;5225:30;5222:50;;;5268:1;5265;5258:12;5222:50;5291:22;;5344:4;5336:13;;5332:27;-1:-1:-1;5322:55:1;;5373:1;5370;5363:12;5322:55;5396:74;5462:7;5457:2;5444:16;5439:2;5435;5431:11;5396:74;:::i;5481:118::-;5567:5;5560:13;5553:21;5546:5;5543:32;5533:60;;5589:1;5586;5579:12;5604:382;5669:6;5677;5730:2;5718:9;5709:7;5705:23;5701:32;5698:52;;;5746:1;5743;5736:12;5698:52;5785:9;5772:23;5804:31;5829:5;5804:31;:::i;:::-;5854:5;-1:-1:-1;5911:2:1;5896:18;;5883:32;5924:30;5883:32;5924:30;:::i;:::-;5973:7;5963:17;;;5604:382;;;;;:::o;5991:795::-;6086:6;6094;6102;6110;6163:3;6151:9;6142:7;6138:23;6134:33;6131:53;;;6180:1;6177;6170:12;6131:53;6219:9;6206:23;6238:31;6263:5;6238:31;:::i;:::-;6288:5;-1:-1:-1;6345:2:1;6330:18;;6317:32;6358:33;6317:32;6358:33;:::i;:::-;6410:7;-1:-1:-1;6464:2:1;6449:18;;6436:32;;-1:-1:-1;6519:2:1;6504:18;;6491:32;-1:-1:-1;;;;;6535:30:1;;6532:50;;;6578:1;6575;6568:12;6532:50;6601:22;;6654:4;6646:13;;6642:27;-1:-1:-1;6632:55:1;;6683:1;6680;6673:12;6632:55;6706:74;6772:7;6767:2;6754:16;6749:2;6745;6741:11;6706:74;:::i;:::-;6696:84;;;5991:795;;;;;;;:::o;6791:315::-;6859:6;6867;6920:2;6908:9;6899:7;6895:23;6891:32;6888:52;;;6936:1;6933;6926:12;6888:52;6972:9;6959:23;6949:33;;7032:2;7021:9;7017:18;7004:32;7045:31;7070:5;7045:31;:::i;7111:388::-;7179:6;7187;7240:2;7228:9;7219:7;7215:23;7211:32;7208:52;;;7256:1;7253;7246:12;7208:52;7295:9;7282:23;7314:31;7339:5;7314:31;:::i;:::-;7364:5;-1:-1:-1;7421:2:1;7406:18;;7393:32;7434:33;7393:32;7434:33;:::i;7771:380::-;7850:1;7846:12;;;;7893;;;7914:61;;7968:4;7960:6;7956:17;7946:27;;7914:61;8021:2;8013:6;8010:14;7990:18;7987:38;7984:161;;8067:10;8062:3;8058:20;8055:1;8048:31;8102:4;8099:1;8092:15;8130:4;8127:1;8120:15;7984:161;;7771:380;;;:::o;8156:127::-;8217:10;8212:3;8208:20;8205:1;8198:31;8248:4;8245:1;8238:15;8272:4;8269:1;8262:15;8288:168;8328:7;8394:1;8390;8386:6;8382:14;8379:1;8376:21;8371:1;8364:9;8357:17;8353:45;8350:71;;;8401:18;;:::i;:::-;-1:-1:-1;8441:9:1;;8288:168::o;8461:127::-;8522:10;8517:3;8513:20;8510:1;8503:31;8553:4;8550:1;8543:15;8577:4;8574:1;8567:15;8593:120;8633:1;8659;8649:35;;8664:18;;:::i;:::-;-1:-1:-1;8698:9:1;;8593:120::o;8718:125::-;8758:4;8786:1;8783;8780:8;8777:34;;;8791:18;;:::i;:::-;-1:-1:-1;8828:9:1;;8718:125::o;9127:356::-;9329:2;9311:21;;;9348:18;;;9341:30;9407:34;9402:2;9387:18;;9380:62;9474:2;9459:18;;9127:356::o;9741:128::-;9781:3;9812:1;9808:6;9805:1;9802:13;9799:39;;;9818:18;;:::i;:::-;-1:-1:-1;9854:9:1;;9741:128::o;9874:470::-;10053:3;10091:6;10085:13;10107:53;10153:6;10148:3;10141:4;10133:6;10129:17;10107:53;:::i;:::-;10223:13;;10182:16;;;;10245:57;10223:13;10182:16;10279:4;10267:17;;10245:57;:::i;:::-;10318:20;;9874:470;-1:-1:-1;;;;9874:470:1:o;10349:127::-;10410:10;10405:3;10401:20;10398:1;10391:31;10441:4;10438:1;10431:15;10465:4;10462:1;10455:15;11598:184;11668:6;11721:2;11709:9;11700:7;11696:23;11692:32;11689:52;;;11737:1;11734;11727:12;11689:52;-1:-1:-1;11760:16:1;;11598:184;-1:-1:-1;11598:184:1:o;11787:245::-;11854:6;11907:2;11895:9;11886:7;11882:23;11878:32;11875:52;;;11923:1;11920;11913:12;11875:52;11955:9;11949:16;11974:28;11996:5;11974:28;:::i;12037:489::-;-1:-1:-1;;;;;12306:15:1;;;12288:34;;12358:15;;12353:2;12338:18;;12331:43;12405:2;12390:18;;12383:34;;;12453:3;12448:2;12433:18;;12426:31;;;12231:4;;12474:46;;12500:19;;12492:6;12474:46;:::i;:::-;12466:54;12037:489;-1:-1:-1;;;;;;12037:489:1:o;12531:249::-;12600:6;12653:2;12641:9;12632:7;12628:23;12624:32;12621:52;;;12669:1;12666;12659:12;12621:52;12701:9;12695:16;12720:30;12744:5;12720:30;:::i;12785:135::-;12824:3;12845:17;;;12842:43;;12865:18;;:::i;:::-;-1:-1:-1;12912:1:1;12901:13;;12785:135::o;12925:112::-;12957:1;12983;12973:35;;12988:18;;:::i;:::-;-1:-1:-1;13022:9:1;;12925:112::o

Swarm Source

ipfs://4ea52b8e407f8a89d0bc96022d49046f8de2cf0100846e7237f603f69e9f239d
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.