Token Arbibots

 

Overview

TokenID:
1488

Transfers:
-

Loading
[ Download CSV Export  ] 
Loading
Loading

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

Contract Source Code Verified (Exact Match)

Contract Name:
Arbibots

Compiler Version
v0.8.7+commit.e28d00a7

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, None license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2021-09-16
*/

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

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

 

pragma solidity ^0.8.0;

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


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

 

pragma solidity ^0.8.0;

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

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

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

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

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

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

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

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

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

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

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

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


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

 

pragma solidity ^0.8.0;

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


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

 

pragma solidity ^0.8.0;

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

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

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


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

 

pragma solidity ^0.8.0;

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

        uint256 size;
        assembly {
            size := extcodesize(account)
        }
        return size > 0;
    }

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

        (bool success, ) = recipient.call{value: amount}("");
        require(success, "Address: unable to send value, recipient may have reverted");
    }

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

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

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

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

        (bool success, bytes memory returndata) = target.call{value: value}(data);
        return verifyCallResult(success, returndata, errorMessage);
    }

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

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

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

    /**
     * @dev 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]

 

pragma solidity ^0.8.0;

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

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


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

 

pragma solidity ^0.8.0;

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

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

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

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

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


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

 

pragma solidity ^0.8.0;

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


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

 

pragma solidity ^0.8.0;







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

    // Token name
    string private _name;

    // Token symbol
    string private _symbol;

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

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

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

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

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

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

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

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

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

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

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

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

    /**
     * @dev Base URI for computing {tokenURI}. If set, the resulting URI for each
     * token will be the concatenation of the `baseURI` and the `tokenId`. Empty
     * by default, can be overriden in child contracts.
     */
    function _baseURI() internal view virtual returns (string memory) {
        return "";
    }

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

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

        _approve(to, tokenId);
    }

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

        return _tokenApprovals[tokenId];
    }

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

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

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

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

        _transfer(from, to, tokenId);
    }

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

        _beforeTokenTransfer(from, to, tokenId);

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

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

        emit Transfer(from, to, tokenId);
    }

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

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

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


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

 

pragma solidity ^0.8.0;

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

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

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


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

 

pragma solidity ^0.8.0;


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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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


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

 

pragma solidity ^0.8.0;


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


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

 

pragma solidity ^0.8.0;

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

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

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

    function _setOwner(address newOwner) private {
        address oldOwner = _owner;
        _owner = newOwner;
        emit OwnershipTransferred(oldOwner, newOwner);
    }
}


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

 

pragma solidity ^0.8.0;

/**
 * @dev Contract module that helps prevent reentrant calls to a function.
 *
 * Inheriting from `ReentrancyGuard` will make the {nonReentrant} modifier
 * available, which can be applied to functions to make sure there are no nested
 * (reentrant) calls to them.
 *
 * Note that because there is a single `nonReentrant` guard, functions marked as
 * `nonReentrant` may not call one another. This can be worked around by making
 * those functions `private`, and then adding `external` `nonReentrant` entry
 * points to them.
 *
 * TIP: If you would like to learn more about reentrancy and alternative ways
 * to protect against it, check out our blog post
 * https://blog.openzeppelin.com/reentrancy-after-istanbul/[Reentrancy After Istanbul].
 */
abstract contract ReentrancyGuard {
    // Booleans are more expensive than uint256 or any type that takes up a full
    // word because each write operation emits an extra SLOAD to first read the
    // slot's contents, replace the bits taken up by the boolean, and then write
    // back. This is the compiler's defense against contract upgrades and
    // pointer aliasing, and it cannot be disabled.

    // The values being non-zero value makes deployment a bit more expensive,
    // but in exchange the refund on every call to nonReentrant will be lower in
    // amount. Since refunds are capped to a percentage of the total
    // transaction's gas, it is best to keep them low in cases like this one, to
    // increase the likelihood of the full refund coming into effect.
    uint256 private constant _NOT_ENTERED = 1;
    uint256 private constant _ENTERED = 2;

    uint256 private _status;

    constructor() {
        _status = _NOT_ENTERED;
    }

    /**
     * @dev Prevents a contract from calling itself, directly or indirectly.
     * Calling a `nonReentrant` function from another `nonReentrant`
     * function is not supported. It is possible to prevent this from happening
     * by making the `nonReentrant` function external, and make it call a
     * `private` function that does the actual work.
     */
    modifier nonReentrant() {
        // On the first call to nonReentrant, _notEntered will be true
        require(_status != _ENTERED, "ReentrancyGuard: reentrant call");

        // Any calls to nonReentrant after this point will fail
        _status = _ENTERED;

        _;

        // By storing the original value once again, a refund is triggered (see
        // https://eips.ethereum.org/EIPS/eip-2200)
        _status = _NOT_ENTERED;
    }
}


// File base64-sol/[email protected]

 

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

    function encode(bytes memory data) internal pure returns (string memory) {
        if (data.length == 0) return '';
        
        // load the table into memory
        string memory table = TABLE;

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

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

        assembly {
            // set the actual output length
            mstore(result, encodedLen)
            
            // prepare the lookup table
            let tablePtr := add(table, 1)
            
            // input ptr
            let dataPtr := data
            let endPtr := add(dataPtr, mload(data))
            
            // result ptr, jump over length
            let resultPtr := add(result, 32)
            
            // run over the input, 3 bytes at a time
            for {} lt(dataPtr, endPtr) {}
            {
               dataPtr := add(dataPtr, 3)
               
               // read 3 bytes
               let input := mload(dataPtr)
               
               // write 4 characters
               mstore(resultPtr, shl(248, mload(add(tablePtr, and(shr(18, input), 0x3F)))))
               resultPtr := add(resultPtr, 1)
               mstore(resultPtr, shl(248, mload(add(tablePtr, and(shr(12, input), 0x3F)))))
               resultPtr := add(resultPtr, 1)
               mstore(resultPtr, shl(248, mload(add(tablePtr, and(shr( 6, input), 0x3F)))))
               resultPtr := add(resultPtr, 1)
               mstore(resultPtr, shl(248, mload(add(tablePtr, and(        input,  0x3F)))))
               resultPtr := add(resultPtr, 1)
            }
            
            // padding with '='
            switch mod(mload(data), 3)
            case 1 { mstore(sub(resultPtr, 2), shl(240, 0x3d3d)) }
            case 2 { mstore(sub(resultPtr, 1), shl(248, 0x3d)) }
        }
        
        return result;
    }
}


// File contracts/BotRenderer.sol

 

pragma solidity ^0.8.0;

contract BotRenderer {
  string[][] public palettes = [
    ['#b5eaea', '#edf6e5', '#f38ba0'],
    ['#b5c7ea', '#e5f6e8', '#f3bb8b'],
    ['#eab6b5', '#eee5f6', '#8bf3df'],
    ['#c3eab5', '#f6e9e5', '#c18bf3'],
    ['#eab5d9', '#e5e8f6', '#8bf396']
  ];

  bytes[] public bodies = [
    bytes(hex'ff00ba0001010404010111000101060301010f000101080301010d000101090301010d000101090301010d00010109030101'),
    bytes(hex'ff00ba0001010404010111000101060301010f000101080301010d000101090301010d000101090301010d00010109030101'),
    bytes(hex'ff00b90001010504010111000101050301011100010105030101110001010503010111000101050301011100010105030101'),
    bytes(hex'ff00ba000101030401011200010105030101100001010104010103030101010401010e00010103040301030401010c0001010b0401010a0001010d040101'),
    bytes(hex'ff00b9000101050301010f0002010104010103030101010402010c00010104040301040401010a0001010d040101090001010d040101090001010d040101'),
    bytes(hex'ff00ba00010103030101120001010104010101030101010401011000010103040101030401010f000101070401010f000101070401010f00010107040101'),
    bytes(hex'ff00ba0001010104010101030101010401011000010103040101020401010f00010104040101030401010e00010104040101040401010d00010104040101040401010d0001010404010104040101')
  ];

  bytes[] public heads = [
    bytes(hex'96000c010b0001010c030101090001010e030101080001010e030101080001010e030101080001010e030101080001010e030101080001010e030101080001010e030101080001010e030101080001010e03010109000e01'),
    bytes(hex'97000a010d0001010a0301010b0001010c030101090001010e030101080001010e030101080001010e030101080001010e030101080001010e030101080001010e030101090001010c0301010b0001010a0301010d000a01'),
    bytes(hex'9400100107000101100401010600010101040e03010401010600010101040e03010401010600010101040e03010401010600010101040e03010401010600010101040e03010401010600010101040e03010401010600010101040e03010401010600010101040e0301040101060001011004010107001001'),
    bytes(hex'96000c010b0001010c030101090001010e030101070001011003010105000101120301010400010112030101040001011203010104000101120301010500010110030101070001010d030201090001010b0301010c000b01'),
    bytes(hex'9400100107000101100301010600010110030101060001011003010106000101100301010600010110030101070001010e030101080001010e030101090001010c0301010a0001010c0301010b0001010a0301010d000a01')
  ];

  bytes[] public eyes = [
    bytes(hex'ff0010000201070002010d0001010104070001010104ff00'),
    bytes(hex'ff001000030105000301ff00'),
    bytes(hex'f8000101070001010e000101010001010500010101000101ff00'),
    bytes(hex'df000301050003010d000301050003010e00010107000101ff00'),
    bytes(hex'ff0011000101070001010f00010107000101ff00'),
    bytes(hex'ff00100001010100010105000101010001010e00010107000101ff00')
  ];

  bytes[] public mouths = [
    bytes(hex'ff004300010101000101010001011400010101000101'),
    bytes(hex'ff00450001011600010101000101'),
    bytes(hex'ff005c000401'),
    bytes(hex'ff00440001010200010115000201'),
    bytes(hex'ff0044000401140001010204010115000201')
  ];

  bytes[] public headgears = [
    bytes(hex'37000101080001010d0001010100010106000101010001010e000101060001011000010106000101ff00'),
    bytes(hex'240001011600010101000101150001011700010117000101ff00'),
    bytes(hex'0c000201150001010200010114000101010001010104010113000101020001011400010117000101ff00'),
    bytes(hex'68000101060001010f000101010301010400010101030101ff00'),
    bytes(hex'50000101060001010f0001010103010104000101010301010e000101020301010200010102030101ff00')
  ];

  struct BotData {
    uint palette;
    uint body;
    uint head;
    uint eyes;
    uint mouth;
    uint headgear;
  }

  mapping(uint256 => uint256) public seeds;

  function _saveSeed(uint256 tokenId) internal {
    seeds[tokenId] = uint256(keccak256(abi.encodePacked(blockhash(block.number - 1), tokenId)));
  }

  function _render(uint256 tokenId) internal view returns (string memory) {
    BotData memory data = _generateBotData(tokenId);
    string[] memory palette = palettes[data.palette];

    string memory image = string(abi.encodePacked(
      '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" shape-rendering="crispEdges" width="256" height="256">'
      '<rect width="100%" height="100%" fill="', palette[0], '" />',
      _renderRects(bodies[data.body], palette),
      _renderRects(heads[data.head], palette),
      _renderRects(eyes[data.eyes], palette),
      _renderRects(mouths[data.mouth], palette),
      _renderRects(headgears[data.headgear], palette),
      '</svg>'
    ));

    return string(abi.encodePacked(
      'data:application/json;base64,',
      Base64.encode(
        bytes(
          abi.encodePacked('{"image": "data:image/svg+xml;base64,', Base64.encode(bytes(image)), '"}')
        )
      )
    ));
  }

  function _renderRects(bytes memory data, string[] memory palette) private pure returns (string memory) {
    string[24] memory lookup = [
      '0', '1', '2', '3', '4', '5', '6', '7',
      '8', '9', '10', '11', '12', '13', '14', '15',
      '16', '17', '18', '19', '20', '21', '22', '23'
    ];

    string memory rects;
    uint256 drawIndex = 0;
    for (uint256 i = 0; i < data.length; i = i+2) {
      uint8 runLength = uint8(data[i]); // we assume runLength of any non-transparent segment cannot exceed image width (24px)
      uint8 colorIndex = uint8(data[i+1]);
      if (colorIndex != 0) { // transparent
        uint8 x = uint8(drawIndex % 24);
        uint8 y = uint8(drawIndex / 24);
        string memory color = "#000000";
        if (colorIndex > 1) {
          color = palette[colorIndex-2];
        }
        rects = string(abi.encodePacked(rects, '<rect width="', lookup[runLength], '" height="1" x="', lookup[x], '" y="', lookup[y], '" fill="', color, '" />'));
      }
      drawIndex += runLength;
    }

    return rects;
  }

  function _generateBotData(uint256 tokenId) private view returns (BotData memory) {
    uint256 seed = seeds[tokenId];
    return BotData({
      palette: seed % palettes.length,
      body: (seed/2) % bodies.length,
      head: (seed/3) % heads.length,
      eyes: (seed/4) % eyes.length,
      mouth: (seed/5) % mouths.length,
      headgear: (seed/6) % headgears.length
    });
  }
}


// File contracts/Arbibots.sol

 

pragma solidity ^0.8.0;





contract Arbibots is BotRenderer, ERC721Enumerable, ERC721Burnable, Ownable, ReentrancyGuard {
  event Mint(address indexed owner, uint256 indexed tokenId, uint256 price);
  event Redeem(address indexed owner, uint256 value);

  uint256 public constant MAX_BOTS = 2000;

  uint256 public constant TOTAL_REWARD_POOLS = 80;
  uint256[TOTAL_REWARD_POOLS] public rewardPools;
  mapping(uint256 => bool[TOTAL_REWARD_POOLS]) public redeemed;

  uint256 private _auctionStartedAt;
  uint256 private _currentRewardPool;

  constructor() ERC721("Arbibots", "BOT") {
    _auctionStartedAt = block.timestamp;
  }

  // mint related functions

  function mint() public payable nonReentrant {
    // supply and daily supply limits
    uint256 nextId = totalSupply();
    require(nextId < MAX_BOTS, "No more supply");

    // pricing and rewards
    require(msg.value >= mintPrice(), "Price not met");
    uint256 rewardRemainder = _reward(nextId, msg.value);

    // actual minting
    _saveSeed(nextId);
    _safeMint(msg.sender, nextId);
    emit Mint(msg.sender, nextId, msg.value);

    _checkAndHandleNewAuction(nextId+1);

    // owner send
    (bool success, ) = owner().call{value: rewardRemainder}(""); // remainder (50%) goes to owner
    require(success, "Transfer failed");
  }

  function mintPrice() public view returns (uint256) {
    uint256 secondsSinceAuctionStart = _secondsSinceAuctionStart();
    if (secondsSinceAuctionStart < 18000) {
      return 2 * 10**19 - (2 * 10**19 * secondsSinceAuctionStart) / 18305;
    }
    if (secondsSinceAuctionStart < 21492) {
      return 2 * 10**18 - (2 * 10**18 * secondsSinceAuctionStart) / 21600;
    }
    return 10**16; // min price is 0.01 ETH
  }

  // reward related functions

  function redeem() public nonReentrant {
    uint256 toRedeem;
    uint256 maxRewardPoolSlot = totalSupply() / (MAX_BOTS / TOTAL_REWARD_POOLS);

    uint256 owned = balanceOf(msg.sender);
    for (uint256 i = 0; i < owned; i++) {
      uint256 tokenId = tokenOfOwnerByIndex(msg.sender, i);
      uint256 rewardPoolSlotStartAt = tokenId / (MAX_BOTS / TOTAL_REWARD_POOLS);
      for (uint256 j = rewardPoolSlotStartAt; j < maxRewardPoolSlot; j++) {
        if (redeemed[tokenId][j]) {
          continue;
        }
        redeemed[tokenId][j] = true;
        toRedeem += rewardPools[j];
      }
    }

    (bool success, ) = msg.sender.call{value: toRedeem}("");
    require(success, "Transfer failed");
    emit Redeem(msg.sender, toRedeem);
  }

  function _reward(uint256 tokenId, uint256 saleAmount) private returns (uint256) {
    uint256 rewardPoolSlot = tokenId / (MAX_BOTS / TOTAL_REWARD_POOLS);
    uint256 tokensToSplitAcross = (rewardPoolSlot+1) * (MAX_BOTS / TOTAL_REWARD_POOLS); // take advantage of div flooring
    uint256 individualRewardAmount = (saleAmount / 2) / tokensToSplitAcross;
    rewardPools[rewardPoolSlot] += individualRewardAmount;

    return saleAmount - (individualRewardAmount * tokensToSplitAcross);
  }

  // view functions for redeem amounts, loops duplicated for gas
  function redeemable() public view returns (uint256) {
    uint256 toRedeem;
    uint256 maxRewardPoolSlot = totalSupply() / (MAX_BOTS / TOTAL_REWARD_POOLS);

    uint256 owned = balanceOf(msg.sender);
    for (uint256 i = 0; i < owned; i++) {
      uint256 tokenId = tokenOfOwnerByIndex(msg.sender, i);
      uint256 rewardPoolSlotStartAt = tokenId / (MAX_BOTS / TOTAL_REWARD_POOLS);
      for (uint256 j = rewardPoolSlotStartAt; j < maxRewardPoolSlot; j++) {
        if (redeemed[tokenId][j]) {
          continue;
        }
        toRedeem += rewardPools[j];
      }
    }
    return toRedeem;
  }

  function totalRewards() public view returns (uint256) {
    uint256 toRedeem;

    uint256 owned = balanceOf(msg.sender);
    for (uint256 i = 0; i < owned; i++) {
      uint256 tokenId = tokenOfOwnerByIndex(msg.sender, i);
      uint256 rewardPoolSlotStartAt = tokenId / (MAX_BOTS / TOTAL_REWARD_POOLS);
      for (uint256 j = rewardPoolSlotStartAt; j < TOTAL_REWARD_POOLS; j++) {
        if (redeemed[tokenId][j]) {
          continue;
        }
        toRedeem += rewardPools[j];
      }
    }
    return toRedeem;
  }

  // timing related functions

  function _checkAndHandleNewAuction(uint256 nextTokenId) private {
    uint256 calculatedRewardPool = nextTokenId / (MAX_BOTS / TOTAL_REWARD_POOLS);
    if (_currentRewardPool != calculatedRewardPool) {
      _currentRewardPool = calculatedRewardPool;
      _auctionStartedAt = block.timestamp;
    }
  }

  function _secondsSinceAuctionStart() private view returns (uint256) {
    return (block.timestamp - _auctionStartedAt);
  }

  // etc

  function tokenURI(uint256 tokenId) public view override returns (string memory) {
    require(_exists(tokenId), "URI query for nonexistent token");
    return _render(tokenId);
  }

  function _beforeTokenTransfer(address from, address to, uint256 tokenId) internal override(ERC721, ERC721Enumerable) {
    super._beforeTokenTransfer(from, to, tokenId);
  }

  function supportsInterface(bytes4 interfaceId) public view override(ERC721, ERC721Enumerable) returns (bool) {
    return super.supportsInterface(interfaceId);
  }
}

Contract Security Audit

Contract ABI

[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"approved","type":"address"},{"indexed":true,"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"operator","type":"address"},{"indexed":false,"internalType":"bool","name":"approved","type":"bool"}],"name":"ApprovalForAll","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"uint256","name":"tokenId","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"price","type":"uint256"}],"name":"Mint","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":"owner","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Redeem","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":true,"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"Transfer","type":"event"},{"inputs":[],"name":"MAX_BOTS","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"TOTAL_REWARD_POOLS","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"approve","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"bodies","outputs":[{"internalType":"bytes","name":"","type":"bytes"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"burn","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"eyes","outputs":[{"internalType":"bytes","name":"","type":"bytes"}],"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":"uint256","name":"","type":"uint256"}],"name":"headgears","outputs":[{"internalType":"bytes","name":"","type":"bytes"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"heads","outputs":[{"internalType":"bytes","name":"","type":"bytes"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"operator","type":"address"}],"name":"isApprovedForAll","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"mint","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[],"name":"mintPrice","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"mouths","outputs":[{"internalType":"bytes","name":"","type":"bytes"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"ownerOf","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"uint256","name":"","type":"uint256"}],"name":"palettes","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"redeem","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"redeemable","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"uint256","name":"","type":"uint256"}],"name":"redeemed","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"rewardPools","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":"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":"uint256","name":"","type":"uint256"}],"name":"seeds","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"operator","type":"address"},{"internalType":"bool","name":"approved","type":"bool"}],"name":"setApprovalForAll","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"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":"index","type":"uint256"}],"name":"tokenByIndex","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"uint256","name":"index","type":"uint256"}],"name":"tokenOfOwnerByIndex","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"tokenURI","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalRewards","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"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"}]

6007610180818152662362356561656160c81b6101a0526101209081526101c0828152662365646636653560c81b6101e05261014052610200828152660236633386261360cc1b610220526101605260809081526102a0828152662362356337656160c81b6102c0526102409081526102e083815266046ca6acc6cca760cb1b61030052610260526103208381526611b319b1311c3160c91b610340526102805260a0526103c0828152662365616236623560c81b6103e0526103609081526104008381526611b2b2b29ab31b60c91b610420526103805261044083815266119c313319b23360c91b610460526103a05260c0526104e0828152662363336561623560c81b61050052610480908152610520838152662366366539653560c81b610540526104a052610560838152662363313862663360c81b610580526104c05260e052610600828152662365616235643960c81b610620526105a09081526106408381526611b29ab29c331b60c91b610660526105c0526106c060405261068092835266119c3133199c9b60c91b6106a0526105e09290925261010091909152620001b0906000906005620007b2565b50604080516101408101909152603260e082018181528291620043d46101008401398152602001604051806060016040528060328152602001620043d4603291398152602001604051806060016040528060328152602001620042946032913981526020016040518060600160405280603e81526020016200431e603e913981526020016040518060600160405280603e81526020016200445e603e913981526020016040518060600160405280603e81526020016200412e603e913981526020016040518060800160405280604e8152602001620041ee604e913990526200029e90600190600762000810565b50604080516101208101909152605860a082018181528291620042c660c084013981526020016040518060800160405280605881526020016200416c6058913981526020016040518060a00160405280607881526020016200435c607891398152602001604051806080016040528060588152602001620044066058913981526020016040518060800160405280605881526020016200423c6058913990526200034d90600290600562000870565b506040805161010081018252601860c082019081527fff0010000201070002010d0001010104070001010104ff00000000000000000060e0830152815281518083018352600c81527fff001000030105000301ff0000000000000000000000000000000000000000006020828101919091528083019190915282518084018452601a8082527ff8000101070001010e000101010001010500010101000101ff000000000000008284015283850191909152835180850185529081527fdf000301050003010d000301050003010e00010107000101ff0000000000000081830152606083015282518084018452601481527fff0011000101070001010f00010107000101ff000000000000000000000000008183015260808301528251808401909352601c83527fff00100001010100010105000101010001010e00010107000101ff00000000009083015260a0810191909152620004b0906003906006620008c2565b506040805160e081018252601660a082019081527fff0043000101010001010100010114000101010001010000000000000000000060c0830152815281518083018352600e8082527fff004500010116000101010001010000000000000000000000000000000000006020838101919091528084019290925283518085018552600681527fff005c00040100000000000000000000000000000000000000000000000000008184015283850152835180850185529081527fff004400010102000101150002010000000000000000000000000000000000008183015260608301528251808401909352601283527fff00440004011400010102040101150002010000000000000000000000000000908301526080810191909152620005da90600490600562000870565b50604080516101008101909152602a60a082018181528291620041c460c084013981526020016040518060400160405280601a81526020017f240001011600010101000101150001011700010117000101ff0000000000000081525081526020016040518060600160405280602a815260200162004104602a913981526020016040518060400160405280601a81526020017f68000101060001010f000101010301010400010101030101ff0000000000000081525081526020016040518060600160405280602a8152602001620040da602a91399052620006c0906005908162000870565b50348015620006ce57600080fd5b50604080518082018252600881526741726269626f747360c01b6020808301918252835180850190945260038452621093d560ea1b9084015281519192916200071a9160079162000914565b5080516200073090600890602084019062000914565b5050506200074d620007476200075c60201b60201c565b62000760565b60016012554260645562000b18565b3390565b601180546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b828054828255906000526020600020908101928215620007fe579160200282015b82811115620007fe578251620007ed90839060036200099f565b5091602001919060010190620007d3565b506200080c929150620009ff565b5090565b82805482825590600052602060002090810192821562000862579160200282015b828111156200086257825180516200085191849160209091019062000914565b509160200191906001019062000831565b506200080c92915062000a20565b82805482825590600052602060002090810192821562000862579160200282015b82811115620008625782518051620008b191849160209091019062000914565b509160200191906001019062000891565b82805482825590600052602060002090810192821562000862579160200282015b828111156200086257825180516200090391849160209091019062000914565b5091602001919060010190620008e3565b828054620009229062000adb565b90600052602060002090601f01602090048101928262000946576000855562000991565b82601f106200096157805160ff191683800117855562000991565b8280016001018555821562000991579182015b828111156200099157825182559160200191906001019062000974565b506200080c92915062000a41565b828054828255906000526020600020908101928215620009f1579160200282015b82811115620009f15782518051620009e091849160209091019062000914565b5091602001919060010190620009c0565b506200080c92915062000a58565b808211156200080c57600062000a16828262000a79565b50600101620009ff565b808211156200080c57600062000a37828262000a9c565b5060010162000a20565b5b808211156200080c576000815560010162000a42565b808211156200080c57600062000a6f828262000a9c565b5060010162000a58565b508054600082559060005260206000209081019062000a99919062000a58565b50565b50805462000aaa9062000adb565b6000825580601f1062000abb575050565b601f01602090049060005260206000209081019062000a99919062000a41565b600181811c9082168062000af057607f821691505b6020821081141562000b1257634e487b7160e01b600052602260045260246000fd5b50919050565b6135b28062000b286000396000f3fe60806040526004361061020f5760003560e01c80636817c76c11610118578063a22cb465116100a0578063c87b56dd1161006f578063c87b56dd146105b7578063e985e9c5146105d7578063f0503e8014610620578063f1dc193a1461064d578063f2fde38b1461066d57600080fd5b8063a22cb46514610542578063a3053dd514610562578063b88d4fde14610582578063be040fb0146105a257600080fd5b8063873950eb116100e7578063873950eb146104b95780638da5cb5b146104d957806390f1d5dc146104f757806395d89b41146105175780639cc6e0961461052c57600080fd5b80636817c76c1461044f57806370a0823114610464578063715018a614610484578063868b4d331461049957600080fd5b80632d7ecd111161019b57806344cee73c1161016a57806344cee73c146103af57806346abf391146103cf5780634f6ccce7146103ef5780635a503f131461040f5780636352211e1461042f57600080fd5b80632d7ecd111461033a5780632f745c591461034f57806342842e0e1461036f57806342966c681461038f57600080fd5b80630e15561a116101e25780630e15561a146102c55780631249c58b146102e857806318160ddd146102f057806323068f2a1461030557806323b872dd1461031a57600080fd5b806301ffc9a71461021457806306fdde0314610249578063081812fc1461026b578063095ea7b3146102a3575b600080fd5b34801561022057600080fd5b5061023461022f366004612f1c565b61068d565b60405190151581526020015b60405180910390f35b34801561025557600080fd5b5061025e61069e565b60405161024091906132e7565b34801561027757600080fd5b5061028b610286366004612f56565b610730565b6040516001600160a01b039091168152602001610240565b3480156102af57600080fd5b506102c36102be366004612ef2565b6107ca565b005b3480156102d157600080fd5b506102da6108e0565b604051908152602001610240565b6102c36109c0565b3480156102fc57600080fd5b50600f546102da565b34801561031157600080fd5b506102da605081565b34801561032657600080fd5b506102c3610335366004612d9e565b610bc9565b34801561034657600080fd5b506102da610bfb565b34801561035b57600080fd5b506102da61036a366004612ef2565b610cf8565b34801561037b57600080fd5b506102c361038a366004612d9e565b610d8e565b34801561039b57600080fd5b506102c36103aa366004612f56565b610da9565b3480156103bb57600080fd5b5061025e6103ca366004612f56565b610e23565b3480156103db57600080fd5b506102da6103ea366004612f56565b610ecf565b3480156103fb57600080fd5b506102da61040a366004612f56565b610ee6565b34801561041b57600080fd5b5061025e61042a366004612f56565b610f79565b34801561043b57600080fd5b5061028b61044a366004612f56565b610f89565b34801561045b57600080fd5b506102da611000565b34801561047057600080fd5b506102da61047f366004612d49565b611099565b34801561049057600080fd5b506102c3611120565b3480156104a557600080fd5b5061025e6104b4366004612f56565b611186565b3480156104c557600080fd5b506102346104d4366004612f6f565b611196565b3480156104e557600080fd5b506011546001600160a01b031661028b565b34801561050357600080fd5b5061025e610512366004612f56565b6111cf565b34801561052357600080fd5b5061025e6111df565b34801561053857600080fd5b506102da6107d081565b34801561054e57600080fd5b506102c361055d366004612eb6565b6111ee565b34801561056e57600080fd5b5061025e61057d366004612f56565b6112b3565b34801561058e57600080fd5b506102c361059d366004612dda565b6112c3565b3480156105ae57600080fd5b506102c36112fb565b3480156105c357600080fd5b5061025e6105d2366004612f56565b611552565b3480156105e357600080fd5b506102346105f2366004612d6b565b6001600160a01b039182166000908152600c6020908152604080832093909416825291909152205460ff1690565b34801561062c57600080fd5b506102da61063b366004612f56565b60066020526000908152604090205481565b34801561065957600080fd5b5061025e610668366004612f6f565b6115c2565b34801561067957600080fd5b506102c3610688366004612d49565b611606565b6000610698826116ce565b92915050565b6060600780546106ad9061344e565b80601f01602080910402602001604051908101604052809291908181526020018280546106d99061344e565b80156107265780601f106106fb57610100808354040283529160200191610726565b820191906000526020600020905b81548152906001019060200180831161070957829003601f168201915b5050505050905090565b6000818152600960205260408120546001600160a01b03166107ae5760405162461bcd60e51b815260206004820152602c60248201527f4552433732313a20617070726f76656420717565727920666f72206e6f6e657860448201526b34b9ba32b73a103a37b5b2b760a11b60648201526084015b60405180910390fd5b506000908152600b60205260409020546001600160a01b031690565b60006107d582610f89565b9050806001600160a01b0316836001600160a01b031614156108435760405162461bcd60e51b815260206004820152602160248201527f4552433732313a20617070726f76616c20746f2063757272656e74206f776e656044820152603960f91b60648201526084016107a5565b336001600160a01b038216148061085f575061085f81336105f2565b6108d15760405162461bcd60e51b815260206004820152603860248201527f4552433732313a20617070726f76652063616c6c6572206973206e6f74206f7760448201527f6e6572206e6f7220617070726f76656420666f7220616c6c000000000000000060648201526084016107a5565b6108db83836116f3565b505050565b60008060006108ee33611099565b905060005b818110156109b85760006109073383610cf8565b9050600061091860506107d06133b5565b61092290836133b5565b9050805b60508110156109a2576000838152606360205260409020816050811061094e5761094e6134fa565b602081049091015460ff601f9092166101000a9004161561096e57610990565b60138160508110610981576109816134fa565b015461098d908761339d565b95505b8061099a81613489565b915050610926565b50505080806109b090613489565b9150506108f3565b509092915050565b60026012541415610a135760405162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c0060448201526064016107a5565b60026012556000610a23600f5490565b90506107d08110610a675760405162461bcd60e51b815260206004820152600e60248201526d4e6f206d6f726520737570706c7960901b60448201526064016107a5565b610a6f611000565b341015610aae5760405162461bcd60e51b815260206004820152600d60248201526c141c9a58d9481b9bdd081b595d609a1b60448201526064016107a5565b6000610aba8234611761565b9050610ac582611805565b610acf338361184b565b604051348152829033907f4c209b5fc8ad50758f13e2e1088ba56a560dff690a1c6fef26394f4c03821c4f9060200160405180910390a3610b19610b1483600161339d565b611869565b6000610b2d6011546001600160a01b031690565b6001600160a01b03168260405160006040518083038185875af1925050503d8060008114610b77576040519150601f19603f3d011682016040523d82523d6000602084013e610b7c565b606091505b5050905080610bbf5760405162461bcd60e51b815260206004820152600f60248201526e151c985b9cd9995c8819985a5b1959608a1b60448201526064016107a5565b5050600160125550565b610bd4335b82611897565b610bf05760405162461bcd60e51b81526004016107a59061334c565b6108db83838361198e565b60008080610c0c60506107d06133b5565b600f54610c1991906133b5565b90506000610c2633611099565b905060005b81811015610cef576000610c3f3383610cf8565b90506000610c5060506107d06133b5565b610c5a90836133b5565b9050805b85811015610cd95760008381526063602052604090208160508110610c8557610c856134fa565b602081049091015460ff601f9092166101000a90041615610ca557610cc7565b60138160508110610cb857610cb86134fa565b0154610cc4908861339d565b96505b80610cd181613489565b915050610c5e565b5050508080610ce790613489565b915050610c2b565b50919392505050565b6000610d0383611099565b8210610d655760405162461bcd60e51b815260206004820152602b60248201527f455243373231456e756d657261626c653a206f776e657220696e646578206f7560448201526a74206f6620626f756e647360a81b60648201526084016107a5565b506001600160a01b03919091166000908152600d60209081526040808320938352929052205490565b6108db838383604051806020016040528060008152506112c3565b610db233610bce565b610e175760405162461bcd60e51b815260206004820152603060248201527f4552433732314275726e61626c653a2063616c6c6572206973206e6f74206f7760448201526f1b995c881b9bdc88185c1c1c9bdd995960821b60648201526084016107a5565b610e2081611b39565b50565b60018181548110610e3357600080fd5b906000526020600020016000915090508054610e4e9061344e565b80601f0160208091040260200160405190810160405280929190818152602001828054610e7a9061344e565b8015610ec75780601f10610e9c57610100808354040283529160200191610ec7565b820191906000526020600020905b815481529060010190602001808311610eaa57829003601f168201915b505050505081565b60138160508110610edf57600080fd5b0154905081565b6000610ef1600f5490565b8210610f545760405162461bcd60e51b815260206004820152602c60248201527f455243373231456e756d657261626c653a20676c6f62616c20696e646578206f60448201526b7574206f6620626f756e647360a01b60648201526084016107a5565b600f8281548110610f6757610f676134fa565b90600052602060002001549050919050565b60028181548110610e3357600080fd5b6000818152600960205260408120546001600160a01b0316806106985760405162461bcd60e51b815260206004820152602960248201527f4552433732313a206f776e657220717565727920666f72206e6f6e657869737460448201526832b73a103a37b5b2b760b91b60648201526084016107a5565b60008061100b611be0565b90506146508110156110505761478161102d826801158e460913d000006133c9565b61103791906133b5565b61104a906801158e460913d000006133e8565b91505090565b6153f481101561108b5761546061106f82671bc16d674ec800006133c9565b61107991906133b5565b61104a90671bc16d674ec800006133e8565b662386f26fc1000091505090565b60006001600160a01b0382166111045760405162461bcd60e51b815260206004820152602a60248201527f4552433732313a2062616c616e636520717565727920666f7220746865207a65604482015269726f206164647265737360b01b60648201526084016107a5565b506001600160a01b03166000908152600a602052604090205490565b6011546001600160a01b0316331461117a5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064016107a5565b6111846000611bf5565b565b60058181548110610e3357600080fd5b606360205281600052604060002081605081106111b257600080fd5b602081049091015460ff601f9092166101000a9004169150829050565b60048181548110610e3357600080fd5b6060600880546106ad9061344e565b6001600160a01b0382163314156112475760405162461bcd60e51b815260206004820152601960248201527f4552433732313a20617070726f766520746f2063616c6c65720000000000000060448201526064016107a5565b336000818152600c602090815260408083206001600160a01b03871680855290835292819020805460ff191686151590811790915590519081529192917f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c31910160405180910390a35050565b60038181548110610e3357600080fd5b6112cd3383611897565b6112e95760405162461bcd60e51b81526004016107a59061334c565b6112f584848484611c47565b50505050565b6002601254141561134e5760405162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c0060448201526064016107a5565b600260125560008061136360506107d06133b5565b600f5461137091906133b5565b9050600061137d33611099565b905060005b818110156114875760006113963383610cf8565b905060006113a760506107d06133b5565b6113b190836133b5565b9050805b8581101561147157600083815260636020526040902081605081106113dc576113dc6134fa565b602081049091015460ff601f9092166101000a900416156113fc5761145f565b6000838152606360205260409020600190826050811061141e5761141e6134fa565b602091828204019190066101000a81548160ff02191690831515021790555060138160508110611450576114506134fa565b015461145c908861339d565b96505b8061146981613489565b9150506113b5565b505050808061147f90613489565b915050611382565b50604051600090339085908381818185875af1925050503d80600081146114ca576040519150601f19603f3d011682016040523d82523d6000602084013e6114cf565b606091505b50509050806115125760405162461bcd60e51b815260206004820152600f60248201526e151c985b9cd9995c8819985a5b1959608a1b60448201526064016107a5565b60405184815233907f222838db2794d11532d940e8dec38ae307ed0b63cd97c233322e221f998767a69060200160405180910390a2505060016012555050565b6000818152600960205260409020546060906001600160a01b03166115b95760405162461bcd60e51b815260206004820152601f60248201527f55524920717565727920666f72206e6f6e6578697374656e7420746f6b656e0060448201526064016107a5565b61069882611c7a565b600082815481106115d257600080fd5b9060005260206000200181815481106115ea57600080fd5b90600052602060002001600091509150508054610e4e9061344e565b6011546001600160a01b031633146116605760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064016107a5565b6001600160a01b0381166116c55760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016107a5565b610e2081611bf5565b60006001600160e01b0319821663780e9d6360e01b1480610698575061069882612198565b6000818152600b6020526040902080546001600160a01b0319166001600160a01b038416908117909155819061172882610f89565b6001600160a01b03167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92560405160405180910390a45050565b60008061177160506107d06133b5565b61177b90856133b5565b9050600061178c60506107d06133b5565b61179783600161339d565b6117a191906133c9565b90506000816117b16002876133b5565b6117bb91906133b5565b905080601384605081106117d1576117d16134fa565b0160008282546117e1919061339d565b909155506117f1905082826133c9565b6117fb90866133e8565b9695505050505050565b6118106001436133e8565b6040805191406020830152810182905260600160408051601f1981840301815291815281516020928301206000938452600690925290912055565b6118658282604051806020016040528060008152506121e8565b5050565b600061187860506107d06133b5565b61188290836133b5565b90508060655414611865576065555042606455565b6000818152600960205260408120546001600160a01b03166119105760405162461bcd60e51b815260206004820152602c60248201527f4552433732313a206f70657261746f7220717565727920666f72206e6f6e657860448201526b34b9ba32b73a103a37b5b2b760a11b60648201526084016107a5565b600061191b83610f89565b9050806001600160a01b0316846001600160a01b031614806119565750836001600160a01b031661194b84610730565b6001600160a01b0316145b8061198657506001600160a01b038082166000908152600c602090815260408083209388168352929052205460ff165b949350505050565b826001600160a01b03166119a182610f89565b6001600160a01b031614611a095760405162461bcd60e51b815260206004820152602960248201527f4552433732313a207472616e73666572206f6620746f6b656e2074686174206960448201526839903737ba1037bbb760b91b60648201526084016107a5565b6001600160a01b038216611a6b5760405162461bcd60e51b8152602060048201526024808201527f4552433732313a207472616e7366657220746f20746865207a65726f206164646044820152637265737360e01b60648201526084016107a5565b611a7683838361221b565b611a816000826116f3565b6001600160a01b0383166000908152600a60205260408120805460019290611aaa9084906133e8565b90915550506001600160a01b0382166000908152600a60205260408120805460019290611ad890849061339d565b909155505060008181526009602052604080822080546001600160a01b0319166001600160a01b0386811691821790925591518493918716917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef91a4505050565b6000611b4482610f89565b9050611b528160008461221b565b611b5d6000836116f3565b6001600160a01b0381166000908152600a60205260408120805460019290611b869084906133e8565b909155505060008281526009602052604080822080546001600160a01b0319169055518391906001600160a01b038416907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef908390a45050565b600060645442611bf091906133e8565b905090565b601180546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b611c5284848461198e565b611c5e84848484612226565b6112f55760405162461bcd60e51b81526004016107a5906132fa565b60606000611c8783612333565b9050600080826000015181548110611ca157611ca16134fa565b90600052602060002001805480602002602001604051908101604052809291908181526020016000905b82821015611d77578382906000526020600020018054611cea9061344e565b80601f0160208091040260200160405190810160405280929190818152602001828054611d169061344e565b8015611d635780601f10611d3857610100808354040283529160200191611d63565b820191906000526020600020905b815481529060010190602001808311611d4657829003601f168201915b505050505081526020019060010190611ccb565b505050509050600081600081518110611d9257611d926134fa565b6020026020010151611e4d6001856020015181548110611db457611db46134fa565b906000526020600020018054611dc99061344e565b80601f0160208091040260200160405190810160405280929190818152602001828054611df59061344e565b8015611e425780601f10611e1757610100808354040283529160200191611e42565b820191906000526020600020905b815481529060010190602001808311611e2557829003601f168201915b50505050508461243c565b611f006002866040015181548110611e6757611e676134fa565b906000526020600020018054611e7c9061344e565b80601f0160208091040260200160405190810160405280929190818152602001828054611ea89061344e565b8015611ef55780601f10611eca57610100808354040283529160200191611ef5565b820191906000526020600020905b815481529060010190602001808311611ed857829003601f168201915b50505050508561243c565b611fb36003876060015181548110611f1a57611f1a6134fa565b906000526020600020018054611f2f9061344e565b80601f0160208091040260200160405190810160405280929190818152602001828054611f5b9061344e565b8015611fa85780601f10611f7d57610100808354040283529160200191611fa8565b820191906000526020600020905b815481529060010190602001808311611f8b57829003601f168201915b50505050508661243c565b6120666004886080015181548110611fcd57611fcd6134fa565b906000526020600020018054611fe29061344e565b80601f016020809104026020016040519081016040528092919081815260200182805461200e9061344e565b801561205b5780601f106120305761010080835404028352916020019161205b565b820191906000526020600020905b81548152906001019060200180831161203e57829003601f168201915b50505050508761243c565b61211960058960a0015181548110612080576120806134fa565b9060005260206000200180546120959061344e565b80601f01602080910402602001604051908101604052809291908181526020018280546120c19061344e565b801561210e5780601f106120e35761010080835404028352916020019161210e565b820191906000526020600020905b8154815290600101906020018083116120f157829003601f168201915b50505050508861243c565b60405160200161212e96959493929190613114565b604051602081830303815290604052905061216f61214b8261282f565b60405160200161215b91906130b5565b60405160208183030381529060405261282f565b60405160200161217f919061326f565b6040516020818303038152906040529350505050919050565b60006001600160e01b031982166380ac58cd60e01b14806121c957506001600160e01b03198216635b5e139f60e01b145b8061069857506301ffc9a760e01b6001600160e01b0319831614610698565b6121f28383612997565b6121ff6000848484612226565b6108db5760405162461bcd60e51b81526004016107a5906132fa565b6108db838383612ae5565b60006001600160a01b0384163b1561232857604051630a85bd0160e11b81526001600160a01b0385169063150b7a029061226a9033908990889088906004016132b4565b602060405180830381600087803b15801561228457600080fd5b505af19250505080156122b4575060408051601f3d908101601f191682019092526122b191810190612f39565b60015b61230e573d8080156122e2576040519150601f19603f3d011682016040523d82523d6000602084013e6122e7565b606091505b5080516123065760405162461bcd60e51b81526004016107a5906132fa565b805181602001fd5b6001600160e01b031916630a85bd0160e11b149050611986565b506001949350505050565b61236c6040518060c001604052806000815260200160008152602001600081526020016000815260200160008152602001600081525090565b60008281526006602052604080822054815160c081019092529154819061239390846134a4565b81526001546020909101906123a96002856133b5565b6123b391906134a4565b81526002546020909101906123c96003856133b5565b6123d391906134a4565b81526003546020909101906123e96004856133b5565b6123f391906134a4565b81526004546020909101906124096005856133b5565b61241391906134a4565b81526005546020909101906124296006856133b5565b61243391906134a4565b90529392505050565b604080516103408101825260016103008201818152600360fc1b610320840152825282518084018452818152603160f81b6020828101919091528084019190915283518085018552828152601960f91b818301528385015283518085018552828152603360f81b8183015260608481019190915284518086018652838152600d60fa1b81840152608085015284518086018652838152603560f81b8184015260a085015284518086018652838152601b60f91b8184015260c085015284518086018652838152603760f81b8184015260e085015284518086018652838152600760fb1b8184015261010085015284518086018652928352603960f81b8383015261012084019290925283518085018552600280825261031360f41b828401526101408501919091528451808601865281815261313160f01b818401526101608501528451808601865281815261189960f11b818401526101808501528451808601865281815261313360f01b818401526101a085015284518086018652818152610c4d60f21b818401526101c08501528451808601865281815261313560f01b818401526101e08501528451808601865281815261189b60f11b818401526102008501528451808601865281815261313760f01b818401526102208501528451808601865281815261062760f31b818401526102408501528451808601865281815261313960f01b818401526102608501528451808601865281815261032360f41b818401526102808501528451808601865281815261323160f01b818401526102a08501528451808601865281815261191960f11b818401526102c08501528451808601909552845261323360f01b908401526102e0820192909252816000805b86518110156128245760008782815181106126db576126db6134fa565b016020015160f81c90506000886126f384600161339d565b81518110612703576127036134fa565b016020015160f81c905080156127ff5760006127206018866134a4565b9050600061272f6018876133b5565b6040805180820190915260078152660233030303030360cc1b6020820152909150600160ff85161115612786578a6127686002866133ff565b60ff168151811061277b5761277b6134fa565b602002602001015190505b87898660ff166018811061279c5761279c6134fa565b60200201518a8560ff16601881106127b6576127b66134fa565b60200201518b8560ff16601881106127d0576127d06134fa565b6020020151846040516020016127ea959493929190612fd9565b60405160208183030381529060405297505050505b61280c60ff83168561339d565b9350505080600261281d919061339d565b90506126be565b509095945050505050565b606081516000141561284f57505060408051602081019091526000815290565b600060405180606001604052806040815260200161353d604091399050600060038451600261287e919061339d565b61288891906133b5565b6128939060046133c9565b905060006128a282602061339d565b67ffffffffffffffff8111156128ba576128ba613510565b6040519080825280601f01601f1916602001820160405280156128e4576020820181803683370190505b509050818152600183018586518101602084015b818310156129525760039283018051603f601282901c811687015160f890811b8552600c83901c8216880151811b6001860152600683901c8216880151811b60028601529116860151901b938201939093526004016128f8565b60038951066001811461296c576002811461297d57612989565b613d3d60f01b600119830152612989565b603d60f81b6000198301525b509398975050505050505050565b6001600160a01b0382166129ed5760405162461bcd60e51b815260206004820181905260248201527f4552433732313a206d696e7420746f20746865207a65726f206164647265737360448201526064016107a5565b6000818152600960205260409020546001600160a01b031615612a525760405162461bcd60e51b815260206004820152601c60248201527f4552433732313a20746f6b656e20616c7265616479206d696e7465640000000060448201526064016107a5565b612a5e6000838361221b565b6001600160a01b0382166000908152600a60205260408120805460019290612a8790849061339d565b909155505060008181526009602052604080822080546001600160a01b0319166001600160a01b03861690811790915590518392907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef908290a45050565b6001600160a01b038316612b4057612b3b81600f80546000838152601060205260408120829055600182018355919091527f8d1108e10bcb7c27dddfc02ed9d693a074039d026cf4ea4240b40f7d581ac8020155565b612b63565b816001600160a01b0316836001600160a01b031614612b6357612b638382612b9d565b6001600160a01b038216612b7a576108db81612c3a565b826001600160a01b0316826001600160a01b0316146108db576108db8282612ce9565b60006001612baa84611099565b612bb491906133e8565b6000838152600e6020526040902054909150808214612c07576001600160a01b0384166000908152600d602090815260408083208584528252808320548484528184208190558352600e90915290208190555b506000918252600e602090815260408084208490556001600160a01b039094168352600d81528383209183525290812055565b600f54600090612c4c906001906133e8565b600083815260106020526040812054600f8054939450909284908110612c7457612c746134fa565b9060005260206000200154905080600f8381548110612c9557612c956134fa565b600091825260208083209091019290925582815260109091526040808220849055858252812055600f805480612ccd57612ccd6134e4565b6001900381819060005260206000200160009055905550505050565b6000612cf483611099565b6001600160a01b039093166000908152600d602090815260408083208684528252808320859055938252600e9052919091209190915550565b80356001600160a01b0381168114612d4457600080fd5b919050565b600060208284031215612d5b57600080fd5b612d6482612d2d565b9392505050565b60008060408385031215612d7e57600080fd5b612d8783612d2d565b9150612d9560208401612d2d565b90509250929050565b600080600060608486031215612db357600080fd5b612dbc84612d2d565b9250612dca60208501612d2d565b9150604084013590509250925092565b60008060008060808587031215612df057600080fd5b612df985612d2d565b9350612e0760208601612d2d565b925060408501359150606085013567ffffffffffffffff80821115612e2b57600080fd5b818701915087601f830112612e3f57600080fd5b813581811115612e5157612e51613510565b604051601f8201601f19908116603f01168101908382118183101715612e7957612e79613510565b816040528281528a6020848701011115612e9257600080fd5b82602086016020830137600060208483010152809550505050505092959194509250565b60008060408385031215612ec957600080fd5b612ed283612d2d565b915060208301358015158114612ee757600080fd5b809150509250929050565b60008060408385031215612f0557600080fd5b612f0e83612d2d565b946020939093013593505050565b600060208284031215612f2e57600080fd5b8135612d6481613526565b600060208284031215612f4b57600080fd5b8151612d6481613526565b600060208284031215612f6857600080fd5b5035919050565b60008060408385031215612f8257600080fd5b50508035926020909101359150565b60008151808452612fa9816020860160208601613422565b601f01601f19169290920160200192915050565b60008151612fcf818560208601613422565b9290920192915050565b60008651612feb818460208b01613422565b6c1e3932b1ba103bb4b23a341e9160991b908301908152865161301581600d840160208b01613422565b6f11103432b4b3b43a1e911891103c1e9160811b600d9290910191820152855161304681601d840160208a01613422565b6411103c9e9160d91b601d9290910191820152845161306c816022840160208901613422565b6711103334b6361e9160c11b60229290910191820152835161309581602a840160208801613422565b631110179f60e11b602a9290910191820152602e01979650505050505050565b7f7b22696d616765223a2022646174613a696d6167652f7376672b786d6c3b62618152641cd94d8d0b60da1b6020820152600082516130fb816025850160208701613422565b61227d60f01b6025939091019283015250602701919050565b7f3c73766720786d6c6e733d22687474703a2f2f7777772e77332e6f72672f323081527f30302f737667222076696577426f783d2230203020323420323422207368617060208201527f652d72656e646572696e673d2263726973704564676573222077696474683d2260408201527f32353622206865696768743d22323536223e3c726563742077696474683d223160608201527f30302522206865696768743d2231303025222066696c6c3d22000000000000006080820152600087516131e4816099850160208c01613422565b631110179f60e11b609991840191820152875161320881609d840160208c01613422565b875191019061321e81609d840160208b01613422565b865191019061323481609d840160208a01613422565b61326161324f613249609d8486010189612fbd565b87612fbd565b651e17b9bb339f60d11b815260060190565b9a9950505050505050505050565b7f646174613a6170706c69636174696f6e2f6a736f6e3b6261736536342c0000008152600082516132a781601d850160208701613422565b91909101601d0192915050565b6001600160a01b03858116825284166020820152604081018390526080606082018190526000906117fb90830184612f91565b602081526000612d646020830184612f91565b60208082526032908201527f4552433732313a207472616e7366657220746f206e6f6e20455243373231526560408201527131b2b4bb32b91034b6b83632b6b2b73a32b960711b606082015260800190565b60208082526031908201527f4552433732313a207472616e736665722063616c6c6572206973206e6f74206f6040820152701ddb995c881b9bdc88185c1c1c9bdd9959607a1b606082015260800190565b600082198211156133b0576133b06134b8565b500190565b6000826133c4576133c46134ce565b500490565b60008160001904831182151516156133e3576133e36134b8565b500290565b6000828210156133fa576133fa6134b8565b500390565b600060ff821660ff841680821015613419576134196134b8565b90039392505050565b60005b8381101561343d578181015183820152602001613425565b838111156112f55750506000910152565b600181811c9082168061346257607f821691505b6020821081141561348357634e487b7160e01b600052602260045260246000fd5b50919050565b600060001982141561349d5761349d6134b8565b5060010190565b6000826134b3576134b36134ce565b500690565b634e487b7160e01b600052601160045260246000fd5b634e487b7160e01b600052601260045260246000fd5b634e487b7160e01b600052603160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052604160045260246000fd5b6001600160e01b031981168114610e2057600080fdfe4142434445464748494a4b4c4d4e4f505152535455565758595a6162636465666768696a6b6c6d6e6f707172737475767778797a303132333435363738392b2fa26469706673582212202e442de6ed3f22c889e823fec27f7318466e00a8a5f2ac133d8a5228dfeb0c5364736f6c6343000807003350000101060001010f0001010103010104000101010301010e000101020301010200010102030101ff000c000201150001010200010114000101010001010104010113000101020001011400010117000101ff00ff00ba00010103030101120001010104010101030101010401011000010103040101030401010f000101070401010f000101070401010f0001010704010197000a010d0001010a0301010b0001010c030101090001010e030101080001010e030101080001010e030101080001010e030101080001010e030101080001010e030101090001010c0301010b0001010a0301010d000a0137000101080001010d0001010100010106000101010001010e000101060001011000010106000101ff00ff00ba0001010104010101030101010401011000010103040101020401010f00010104040101030401010e00010104040101040401010d00010104040101040401010d00010104040101040401019400100107000101100301010600010110030101060001011003010106000101100301010600010110030101070001010e030101080001010e030101090001010c0301010a0001010c0301010b0001010a0301010d000a01ff00b9000101050401011100010105030101110001010503010111000101050301011100010105030101110001010503010196000c010b0001010c030101090001010e030101080001010e030101080001010e030101080001010e030101080001010e030101080001010e030101080001010e030101080001010e030101080001010e03010109000e01ff00ba000101030401011200010105030101100001010104010103030101010401010e00010103040301030401010c0001010b0401010a0001010d0401019400100107000101100401010600010101040e03010401010600010101040e03010401010600010101040e03010401010600010101040e03010401010600010101040e03010401010600010101040e03010401010600010101040e03010401010600010101040e0301040101060001011004010107001001ff00ba0001010404010111000101060301010f000101080301010d000101090301010d000101090301010d0001010903010196000c010b0001010c030101090001010e030101070001011003010105000101120301010400010112030101040001011203010104000101120301010500010110030101070001010d030201090001010b0301010c000b01ff00b9000101050301010f0002010104010103030101010402010c00010104040301040401010a0001010d040101090001010d040101090001010d040101

Deployed ByteCode Sourcemap

55497:5317:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;60646:165;;;;;;;;;;-1:-1:-1;60646:165:0;;;;;:::i;:::-;;:::i;:::-;;;10511:14:1;;10504:22;10486:41;;10474:2;10459:18;60646:165:0;;;;;;;;21725:100;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;23284:221::-;;;;;;;;;;-1:-1:-1;23284:221:0;;;;;:::i;:::-;;:::i;:::-;;;-1:-1:-1;;;;;9809:32:1;;;9791:51;;9779:2;9764:18;23284:221:0;9645:203:1;22807:411:0;;;;;;;;;;-1:-1:-1;22807:411:0;;;;;:::i;:::-;;:::i;:::-;;59242:537;;;;;;;;;;;;;:::i;:::-;;;20087:25:1;;;20075:2;20060:18;59242:537:0;19941:177:1;56150:661:0;;;:::i;35478:113::-;;;;;;;;;;-1:-1:-1;35566:10:0;:17;35478:113;;55776:47;;;;;;;;;;;;55821:2;55776:47;;24174:339;;;;;;;;;;-1:-1:-1;24174:339:0;;;;;:::i;:::-;;:::i;58620:616::-;;;;;;;;;;;;;:::i;35146:256::-;;;;;;;;;;-1:-1:-1;35146:256:0;;;;;:::i;:::-;;:::i;24584:185::-;;;;;;;;;;-1:-1:-1;24584:185:0;;;;;:::i;:::-;;:::i;41450:245::-;;;;;;;;;;-1:-1:-1;41450:245:0;;;;;:::i;:::-;;:::i;49383:990::-;;;;;;;;;;-1:-1:-1;49383:990:0;;;;;:::i;:::-;;:::i;55828:46::-;;;;;;;;;;-1:-1:-1;55828:46:0;;;;;:::i;:::-;;:::i;35668:233::-;;;;;;;;;;-1:-1:-1;35668:233:0;;;;;:::i;:::-;;:::i;50380:1067::-;;;;;;;;;;-1:-1:-1;50380:1067:0;;;;;:::i;:::-;;:::i;21419:239::-;;;;;;;;;;-1:-1:-1;21419:239:0;;;;;:::i;:::-;;:::i;56817:427::-;;;;;;;;;;;;;:::i;21149:208::-;;;;;;;;;;-1:-1:-1;21149:208:0;;;;;:::i;:::-;;:::i;43358:94::-;;;;;;;;;;;;;:::i;52153:483::-;;;;;;;;;;-1:-1:-1;52153:483:0;;;;;:::i;:::-;;:::i;55879:60::-;;;;;;;;;;-1:-1:-1;55879:60:0;;;;;:::i;:::-;;:::i;42707:87::-;;;;;;;;;;-1:-1:-1;42780:6:0;;-1:-1:-1;;;;;42780:6:0;42707:87;;51874:272;;;;;;;;;;-1:-1:-1;51874:272:0;;;;;:::i;:::-;;:::i;21894:104::-;;;;;;;;;;;;;:::i;55730:39::-;;;;;;;;;;;;55765:4;55730:39;;23577:295;;;;;;;;;;-1:-1:-1;23577:295:0;;;;;:::i;:::-;;:::i;51454:413::-;;;;;;;;;;-1:-1:-1;51454:413:0;;;;;:::i;:::-;;:::i;24840:328::-;;;;;;;;;;-1:-1:-1;24840:328:0;;;;;:::i;:::-;;:::i;57283:764::-;;;;;;;;;;;;;:::i;60276:183::-;;;;;;;;;;-1:-1:-1;60276:183:0;;;;;:::i;:::-;;:::i;23943:164::-;;;;;;;;;;-1:-1:-1;23943:164:0;;;;;:::i;:::-;-1:-1:-1;;;;;24064:25:0;;;24040:4;24064:25;;;:18;:25;;;;;;;;:35;;;;;;;;;;;;;;;23943:164;52774:40;;;;;;;;;;-1:-1:-1;52774:40:0;;;;;:::i;:::-;;;;;;;;;;;;;;49142:234;;;;;;;;;;-1:-1:-1;49142:234:0;;;;;:::i;:::-;;:::i;43607:192::-;;;;;;;;;;-1:-1:-1;43607:192:0;;;;;:::i;:::-;;:::i;60646:165::-;60749:4;60769:36;60793:11;60769:23;:36::i;:::-;60762:43;60646:165;-1:-1:-1;;60646:165:0:o;21725:100::-;21779:13;21812:5;21805:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;21725:100;:::o;23284:221::-;23360:7;26767:16;;;:7;:16;;;;;;-1:-1:-1;;;;;26767:16:0;23380:73;;;;-1:-1:-1;;;23380:73:0;;16264:2:1;23380:73:0;;;16246:21:1;16303:2;16283:18;;;16276:30;16342:34;16322:18;;;16315:62;-1:-1:-1;;;16393:18:1;;;16386:42;16445:19;;23380:73:0;;;;;;;;;-1:-1:-1;23473:24:0;;;;:15;:24;;;;;;-1:-1:-1;;;;;23473:24:0;;23284:221::o;22807:411::-;22888:13;22904:23;22919:7;22904:14;:23::i;:::-;22888:39;;22952:5;-1:-1:-1;;;;;22946:11:0;:2;-1:-1:-1;;;;;22946:11:0;;;22938:57;;;;-1:-1:-1;;;22938:57:0;;17790:2:1;22938:57:0;;;17772:21:1;17829:2;17809:18;;;17802:30;17868:34;17848:18;;;17841:62;-1:-1:-1;;;17919:18:1;;;17912:31;17960:19;;22938:57:0;17588:397:1;22938:57:0;16259:10;-1:-1:-1;;;;;23030:21:0;;;;:62;;-1:-1:-1;23055:37:0;23072:5;16259:10;23943:164;:::i;23055:37::-;23008:168;;;;-1:-1:-1;;;23008:168:0;;14657:2:1;23008:168:0;;;14639:21:1;14696:2;14676:18;;;14669:30;14735:34;14715:18;;;14708:62;14806:26;14786:18;;;14779:54;14850:19;;23008:168:0;14455:420:1;23008:168:0;23189:21;23198:2;23202:7;23189:8;:21::i;:::-;22877:341;22807:411;;:::o;59242:537::-;59287:7;59303:16;59328:13;59344:21;59354:10;59344:9;:21::i;:::-;59328:37;;59377:9;59372:380;59396:5;59392:1;:9;59372:380;;;59417:15;59435:34;59455:10;59467:1;59435:19;:34::i;:::-;59417:52;-1:-1:-1;59478:29:0;59521;55821:2;55765:4;59521:29;:::i;:::-;59510:41;;:7;:41;:::i;:::-;59478:73;-1:-1:-1;59478:73:0;59560:185;55821:2;59600:1;:22;59560:185;;;59644:17;;;;:8;:17;;;;;59662:1;59644:20;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;59640:59;;;59679:8;;59640:59;59721:11;59733:1;59721:14;;;;;;;:::i;:::-;;;59709:26;;;;:::i;:::-;;;59560:185;59624:3;;;;:::i;:::-;;;;59560:185;;;;59408:344;;59403:3;;;;;:::i;:::-;;;;59372:380;;;-1:-1:-1;59765:8:0;;59242:537;-1:-1:-1;;59242:537:0:o;56150:661::-;45743:1;46339:7;;:19;;46331:63;;;;-1:-1:-1;;;46331:63:0;;19366:2:1;46331:63:0;;;19348:21:1;19405:2;19385:18;;;19378:30;19444:33;19424:18;;;19417:61;19495:18;;46331:63:0;19164:355:1;46331:63:0;45743:1;46472:7;:18;56240:14:::1;56257:13;35566:10:::0;:17;;35478:113;56257:13:::1;56240:30;;55765:4;56285:6;:17;56277:44;;;::::0;-1:-1:-1;;;56277:44:0;;19023:2:1;56277:44:0::1;::::0;::::1;19005:21:1::0;19062:2;19042:18;;;19035:30;-1:-1:-1;;;19081:18:1;;;19074:44;19135:18;;56277:44:0::1;18821:338:1::0;56277:44:0::1;56379:11;:9;:11::i;:::-;56366:9;:24;;56358:50;;;::::0;-1:-1:-1;;;56358:50:0;;17038:2:1;56358:50:0::1;::::0;::::1;17020:21:1::0;17077:2;17057:18;;;17050:30;-1:-1:-1;;;17096:18:1;;;17089:43;17149:18;;56358:50:0::1;16836:337:1::0;56358:50:0::1;56415:23;56441:26;56449:6;56457:9;56441:7;:26::i;:::-;56415:52;;56499:17;56509:6;56499:9;:17::i;:::-;56523:29;56533:10;56545:6;56523:9;:29::i;:::-;56564:35;::::0;56589:9:::1;20087:25:1::0;;56581:6:0;;56569:10:::1;::::0;56564:35:::1;::::0;20075:2:1;20060:18;56564:35:0::1;;;;;;;56608;56634:8;:6:::0;56641:1:::1;56634:8;:::i;:::-;56608:25;:35::i;:::-;56672:12;56690:7;42780:6:::0;;-1:-1:-1;;;;;42780:6:0;;42707:87;56690:7:::1;-1:-1:-1::0;;;;;56690:12:0::1;56710:15;56690:40;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;56671:59;;;56778:7;56770:35;;;::::0;-1:-1:-1;;;56770:35:0;;12784:2:1;56770:35:0::1;::::0;::::1;12766:21:1::0;12823:2;12803:18;;;12796:30;-1:-1:-1;;;12842:18:1;;;12835:45;12897:18;;56770:35:0::1;12582:339:1::0;56770:35:0::1;-1:-1:-1::0;;45699:1:0;46651:7;:22;-1:-1:-1;56150:661:0:o;24174:339::-;24369:41;16259:10;24388:12;24402:7;24369:18;:41::i;:::-;24361:103;;;;-1:-1:-1;;;24361:103:0;;;;;;;:::i;:::-;24477:28;24487:4;24493:2;24497:7;24477:9;:28::i;58620:616::-;58663:7;;;58747:29;55821:2;55765:4;58747:29;:::i;:::-;35566:10;:17;58730:47;;;;:::i;:::-;58702:75;;58786:13;58802:21;58812:10;58802:9;:21::i;:::-;58786:37;;58835:9;58830:379;58854:5;58850:1;:9;58830:379;;;58875:15;58893:34;58913:10;58925:1;58893:19;:34::i;:::-;58875:52;-1:-1:-1;58936:29:0;58979;55821:2;55765:4;58979:29;:::i;:::-;58968:41;;:7;:41;:::i;:::-;58936:73;-1:-1:-1;58936:73:0;59018:184;59062:17;59058:1;:21;59018:184;;;59101:17;;;;:8;:17;;;;;59119:1;59101:20;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;59097:59;;;59136:8;;59097:59;59178:11;59190:1;59178:14;;;;;;;:::i;:::-;;;59166:26;;;;:::i;:::-;;;59018:184;59081:3;;;;:::i;:::-;;;;59018:184;;;;58866:343;;58861:3;;;;;:::i;:::-;;;;58830:379;;;-1:-1:-1;59222:8:0;;58620:616;-1:-1:-1;;;58620:616:0:o;35146:256::-;35243:7;35279:23;35296:5;35279:16;:23::i;:::-;35271:5;:31;35263:87;;;;-1:-1:-1;;;35263:87:0;;11546:2:1;35263:87:0;;;11528:21:1;11585:2;11565:18;;;11558:30;11624:34;11604:18;;;11597:62;-1:-1:-1;;;11675:18:1;;;11668:41;11726:19;;35263:87:0;11344:407:1;35263:87:0;-1:-1:-1;;;;;;35368:19:0;;;;;;;;:12;:19;;;;;;;;:26;;;;;;;;;35146:256::o;24584:185::-;24722:39;24739:4;24745:2;24749:7;24722:39;;;;;;;;;;;;:16;:39::i;41450:245::-;41568:41;16259:10;41587:12;16179:98;41568:41;41560:102;;;;-1:-1:-1;;;41560:102:0;;19726:2:1;41560:102:0;;;19708:21:1;19765:2;19745:18;;;19738:30;19804:34;19784:18;;;19777:62;-1:-1:-1;;;19855:18:1;;;19848:46;19911:19;;41560:102:0;19524:412:1;41560:102:0;41673:14;41679:7;41673:5;:14::i;:::-;41450:245;:::o;49383:990::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::o;55828:46::-;;;;;;;;;;;;;;;-1:-1:-1;55828:46:0;:::o;35668:233::-;35743:7;35779:30;35566:10;:17;;35478:113;35779:30;35771:5;:38;35763:95;;;;-1:-1:-1;;;35763:95:0;;18610:2:1;35763:95:0;;;18592:21:1;18649:2;18629:18;;;18622:30;18688:34;18668:18;;;18661:62;-1:-1:-1;;;18739:18:1;;;18732:42;18791:19;;35763:95:0;18408:408:1;35763:95:0;35876:10;35887:5;35876:17;;;;;;;;:::i;:::-;;;;;;;;;35869:24;;35668:233;;;:::o;50380:1067::-;;;;;;;;;;;;21419:239;21491:7;21527:16;;;:7;:16;;;;;;-1:-1:-1;;;;;21527:16:0;21562:19;21554:73;;;;-1:-1:-1;;;21554:73:0;;15493:2:1;21554:73:0;;;15475:21:1;15532:2;15512:18;;;15505:30;15571:34;15551:18;;;15544:62;-1:-1:-1;;;15622:18:1;;;15615:39;15671:19;;21554:73:0;15291:405:1;56817:427:0;56859:7;56875:32;56910:27;:25;:27::i;:::-;56875:62;;56975:5;56948:24;:32;56944:122;;;57053:5;57012:37;57025:24;57012:10;:37;:::i;:::-;57011:47;;;;:::i;:::-;56998:60;;:10;:60;:::i;:::-;56991:67;;;56817:427;:::o;56944:122::-;57103:5;57076:24;:32;57072:122;;;57181:5;57140:37;57153:24;57140:10;:37;:::i;:::-;57139:47;;;;:::i;:::-;57126:60;;:10;:60;:::i;57072:122::-;57207:6;57200:13;;;56817:427;:::o;21149:208::-;21221:7;-1:-1:-1;;;;;21249:19:0;;21241:74;;;;-1:-1:-1;;;21241:74:0;;15082:2:1;21241:74:0;;;15064:21:1;15121:2;15101:18;;;15094:30;15160:34;15140:18;;;15133:62;-1:-1:-1;;;15211:18:1;;;15204:40;15261:19;;21241:74:0;14880:406:1;21241:74:0;-1:-1:-1;;;;;;21333:16:0;;;;;:9;:16;;;;;;;21149:208::o;43358:94::-;42780:6;;-1:-1:-1;;;;;42780:6:0;16259:10;42927:23;42919:68;;;;-1:-1:-1;;;42919:68:0;;16677:2:1;42919:68:0;;;16659:21:1;;;16696:18;;;16689:30;16755:34;16735:18;;;16728:62;16807:18;;42919:68:0;16475:356:1;42919:68:0;43423:21:::1;43441:1;43423:9;:21::i;:::-;43358:94::o:0;52153:483::-;;;;;;;;;;;;55879:60;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;55879:60:0;;-1:-1:-1;55879:60:0:o;51874:272::-;;;;;;;;;;;;21894:104;21950:13;21983:7;21976:14;;;;;:::i;23577:295::-;-1:-1:-1;;;;;23680:24:0;;16259:10;23680:24;;23672:62;;;;-1:-1:-1;;;23672:62:0;;13890:2:1;23672:62:0;;;13872:21:1;13929:2;13909:18;;;13902:30;13968:27;13948:18;;;13941:55;14013:18;;23672:62:0;13688:349:1;23672:62:0;16259:10;23747:32;;;;:18;:32;;;;;;;;-1:-1:-1;;;;;23747:42:0;;;;;;;;;;;;:53;;-1:-1:-1;;23747:53:0;;;;;;;;;;23816:48;;10486:41:1;;;23747:42:0;;16259:10;23816:48;;10459:18:1;23816:48:0;;;;;;;23577:295;;:::o;51454:413::-;;;;;;;;;;;;24840:328;25015:41;16259:10;25048:7;25015:18;:41::i;:::-;25007:103;;;;-1:-1:-1;;;25007:103:0;;;;;;;:::i;:::-;25121:39;25135:4;25141:2;25145:7;25154:5;25121:13;:39::i;:::-;24840:328;;;;:::o;57283:764::-;45743:1;46339:7;;:19;;46331:63;;;;-1:-1:-1;;;46331:63:0;;19366:2:1;46331:63:0;;;19348:21:1;19405:2;19385:18;;;19378:30;19444:33;19424:18;;;19417:61;19495:18;;46331:63:0;19164:355:1;46331:63:0;45743:1;46472:7;:18;57328:16:::1;::::0;57396:29:::1;55821:2;55765:4;57396:29;:::i;:::-;35566:10:::0;:17;57379:47:::1;;;;:::i;:::-;57351:75;;57435:13;57451:21;57461:10;57451:9;:21::i;:::-;57435:37;;57484:9;57479:417;57503:5;57499:1;:9;57479:417;;;57524:15;57542:34;57562:10;57574:1;57542:19;:34::i;:::-;57524:52:::0;-1:-1:-1;57585:29:0::1;57628;55821:2;55765:4;57628:29;:::i;:::-;57617:41;::::0;:7;:41:::1;:::i;:::-;57585:73:::0;-1:-1:-1;57585:73:0;57667:222:::1;57711:17;57707:1;:21;57667:222;;;57750:17;::::0;;;:8:::1;:17;::::0;;;;57768:1;57750:20:::1;::::0;::::1;;;;;:::i;:::-;;::::0;::::1;::::0;;::::1;::::0;::::1;::::0;;;;::::1;;::::0;::::1;;57746:59;;;57785:8;;57746:59;57815:17;::::0;;;:8:::1;:17;::::0;;;;57838:4:::1;::::0;57833:1;57815:20:::1;::::0;::::1;;;;;:::i;:::-;;;;;;;;;;:27;;;;;;;;;;;;;;;;;;57865:11;57877:1;57865:14;;;;;;;:::i;:::-;;::::0;57853:26:::1;::::0;;::::1;:::i;:::-;;;57667:222;57730:3:::0;::::1;::::0;::::1;:::i;:::-;;;;57667:222;;;;57515:381;;57510:3;;;;;:::i;:::-;;;;57479:417;;;-1:-1:-1::0;57923:36:0::1;::::0;57905:12:::1;::::0;57923:10:::1;::::0;57946:8;;57905:12;57923:36;57905:12;57923:36;57946:8;57923:10;:36:::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;57904:55;;;57974:7;57966:35;;;::::0;-1:-1:-1;;;57966:35:0;;12784:2:1;57966:35:0::1;::::0;::::1;12766:21:1::0;12823:2;12803:18;;;12796:30;-1:-1:-1;;;12842:18:1;;;12835:45;12897:18;;57966:35:0::1;12582:339:1::0;57966:35:0::1;58013:28;::::0;20087:25:1;;;58020:10:0::1;::::0;58013:28:::1;::::0;20075:2:1;20060:18;58013:28:0::1;;;;;;;-1:-1:-1::0;;45699:1:0;46651:7;:22;-1:-1:-1;;57283:764:0:o;60276:183::-;26743:4;26767:16;;;:7;:16;;;;;;60341:13;;-1:-1:-1;;;;;26767:16:0;60363:60;;;;-1:-1:-1;;;60363:60:0;;11186:2:1;60363:60:0;;;11168:21:1;11225:2;11205:18;;;11198:30;11264:33;11244:18;;;11237:61;11315:18;;60363:60:0;10984:355:1;60363:60:0;60437:16;60445:7;60437;:16::i;49142:234::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;43607:192::-;42780:6;;-1:-1:-1;;;;;42780:6:0;16259:10;42927:23;42919:68;;;;-1:-1:-1;;;42919:68:0;;16677:2:1;42919:68:0;;;16659:21:1;;;16696:18;;;16689:30;16755:34;16735:18;;;16728:62;16807:18;;42919:68:0;16475:356:1;42919:68:0;-1:-1:-1;;;;;43696:22:0;::::1;43688:73;;;::::0;-1:-1:-1;;;43688:73:0;;12377:2:1;43688:73:0::1;::::0;::::1;12359:21:1::0;12416:2;12396:18;;;12389:30;12455:34;12435:18;;;12428:62;-1:-1:-1;;;12506:18:1;;;12499:36;12552:19;;43688:73:0::1;12175:402:1::0;43688:73:0::1;43772:19;43782:8;43772:9;:19::i;34838:224::-:0;34940:4;-1:-1:-1;;;;;;34964:50:0;;-1:-1:-1;;;34964:50:0;;:90;;;35018:36;35042:11;35018:23;:36::i;30660:174::-;30735:24;;;;:15;:24;;;;;:29;;-1:-1:-1;;;;;;30735:29:0;-1:-1:-1;;;;;30735:29:0;;;;;;;;:24;;30789:23;30735:24;30789:14;:23::i;:::-;-1:-1:-1;;;;;30780:46:0;;;;;;;;;;;30660:174;;:::o;58053:495::-;58124:7;;58176:29;55821:2;55765:4;58176:29;:::i;:::-;58165:41;;:7;:41;:::i;:::-;58140:66;-1:-1:-1;58213:27:0;58265:29;55821:2;55765:4;58265:29;:::i;:::-;58244:16;:14;58259:1;58244:16;:::i;:::-;58243:52;;;;:::i;:::-;58213:82;-1:-1:-1;58336:30:0;58213:82;58370:14;58383:1;58370:10;:14;:::i;:::-;58369:38;;;;:::i;:::-;58336:71;;58445:22;58414:11;58426:14;58414:27;;;;;;;:::i;:::-;;;:53;;;;;;;:::i;:::-;;;;-1:-1:-1;58497:44:0;;-1:-1:-1;58522:19:0;58497:22;:44;:::i;:::-;58483:59;;:10;:59;:::i;:::-;58476:66;58053:495;-1:-1:-1;;;;;;58053:495:0:o;52821:149::-;52935:16;52950:1;52935:12;:16;:::i;:::-;52908:54;;;52925:27;;52908:54;;;4410:19:1;4445:12;;4438:28;;;4482:12;;52908:54:0;;;-1:-1:-1;;52908:54:0;;;;;;;;;52898:65;;52908:54;52898:65;;;;52890:74;52873:14;;;:5;:14;;;;;;:91;52821:149::o;27662:110::-;27738:26;27748:2;27752:7;27738:26;;;;;;;;;;;;:9;:26::i;:::-;27662:110;;:::o;59818:309::-;59889:28;59935:29;55821:2;55765:4;59935:29;:::i;:::-;59920:45;;:11;:45;:::i;:::-;59889:76;;59998:20;59976:18;;:42;59972:150;;60029:18;:41;-1:-1:-1;60099:15:0;60079:17;:35;59818:309::o;26972:348::-;27065:4;26767:16;;;:7;:16;;;;;;-1:-1:-1;;;;;26767:16:0;27082:73;;;;-1:-1:-1;;;27082:73:0;;14244:2:1;27082:73:0;;;14226:21:1;14283:2;14263:18;;;14256:30;14322:34;14302:18;;;14295:62;-1:-1:-1;;;14373:18:1;;;14366:42;14425:19;;27082:73:0;14042:408:1;27082:73:0;27166:13;27182:23;27197:7;27182:14;:23::i;:::-;27166:39;;27235:5;-1:-1:-1;;;;;27224:16:0;:7;-1:-1:-1;;;;;27224:16:0;;:51;;;;27268:7;-1:-1:-1;;;;;27244:31:0;:20;27256:7;27244:11;:20::i;:::-;-1:-1:-1;;;;;27244:31:0;;27224:51;:87;;;-1:-1:-1;;;;;;24064:25:0;;;24040:4;24064:25;;;:18;:25;;;;;;;;:35;;;;;;;;;;;;27279:32;27216:96;26972:348;-1:-1:-1;;;;26972:348:0:o;29964:578::-;30123:4;-1:-1:-1;;;;;30096:31:0;:23;30111:7;30096:14;:23::i;:::-;-1:-1:-1;;;;;30096:31:0;;30088:85;;;;-1:-1:-1;;;30088:85:0;;17380:2:1;30088:85:0;;;17362:21:1;17419:2;17399:18;;;17392:30;17458:34;17438:18;;;17431:62;-1:-1:-1;;;17509:18:1;;;17502:39;17558:19;;30088:85:0;17178:405:1;30088:85:0;-1:-1:-1;;;;;30192:16:0;;30184:65;;;;-1:-1:-1;;;30184:65:0;;13485:2:1;30184:65:0;;;13467:21:1;13524:2;13504:18;;;13497:30;13563:34;13543:18;;;13536:62;-1:-1:-1;;;13614:18:1;;;13607:34;13658:19;;30184:65:0;13283:400:1;30184:65:0;30262:39;30283:4;30289:2;30293:7;30262:20;:39::i;:::-;30366:29;30383:1;30387:7;30366:8;:29::i;:::-;-1:-1:-1;;;;;30408:15:0;;;;;;:9;:15;;;;;:20;;30427:1;;30408:15;:20;;30427:1;;30408:20;:::i;:::-;;;;-1:-1:-1;;;;;;;30439:13:0;;;;;;:9;:13;;;;;:18;;30456:1;;30439:13;:18;;30456:1;;30439:18;:::i;:::-;;;;-1:-1:-1;;30468:16:0;;;;:7;:16;;;;;;:21;;-1:-1:-1;;;;;;30468:21:0;-1:-1:-1;;;;;30468:21:0;;;;;;;;;30507:27;;30468:16;;30507:27;;;;;;;29964:578;;;:::o;29267:360::-;29327:13;29343:23;29358:7;29343:14;:23::i;:::-;29327:39;;29379:48;29400:5;29415:1;29419:7;29379:20;:48::i;:::-;29468:29;29485:1;29489:7;29468:8;:29::i;:::-;-1:-1:-1;;;;;29510:16:0;;;;;;:9;:16;;;;;:21;;29530:1;;29510:16;:21;;29530:1;;29510:21;:::i;:::-;;;;-1:-1:-1;;29549:16:0;;;;:7;:16;;;;;;29542:23;;-1:-1:-1;;;;;;29542:23:0;;;29583:36;29557:7;;29549:16;-1:-1:-1;;;;;29583:36:0;;;;;29549:16;;29583:36;29316:311;29267:360;:::o;60133:125::-;60192:7;60234:17;;60216:15;:35;;;;:::i;:::-;60208:44;;60133:125;:::o;43807:173::-;43882:6;;;-1:-1:-1;;;;;43899:17:0;;;-1:-1:-1;;;;;;43899:17:0;;;;;;;43932:40;;43882:6;;;43899:17;43882:6;;43932:40;;43863:16;;43932:40;43852:128;43807:173;:::o;26050:315::-;26207:28;26217:4;26223:2;26227:7;26207:9;:28::i;:::-;26254:48;26277:4;26283:2;26287:7;26296:5;26254:22;:48::i;:::-;26246:111;;;;-1:-1:-1;;;26246:111:0;;;;;;;:::i;52976:960::-;53033:13;53055:19;53077:25;53094:7;53077:16;:25::i;:::-;53055:47;;53109:23;53135:8;53144:4;:12;;;53135:22;;;;;;;;:::i;:::-;;;;;;;;53109:48;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;53166:19;53387:7;53395:1;53387:10;;;;;;;;:::i;:::-;;;;;;;53414:40;53427:6;53434:4;:9;;;53427:17;;;;;;;;:::i;:::-;;;;;;;;53414:40;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;53446:7;53414:12;:40::i;:::-;53463:39;53476:5;53482:4;:9;;;53476:16;;;;;;;;:::i;:::-;;;;;;;;53463:39;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;53494:7;53463:12;:39::i;:::-;53511:38;53524:4;53529;:9;;;53524:15;;;;;;;;:::i;:::-;;;;;;;;53511:38;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;53541:7;53511:12;:38::i;:::-;53558:41;53571:6;53578:4;:10;;;53571:18;;;;;;;;:::i;:::-;;;;;;;;53558:41;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;53591:7;53558:12;:41::i;:::-;53608:47;53621:9;53631:4;:13;;;53621:24;;;;;;;;:::i;:::-;;;;;;;;53608:47;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;53647:7;53608:12;:47::i;:::-;53195:484;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;53166:514;;53768:154;53868:27;53888:5;53868:13;:27::i;:::-;53810:92;;;;;;;;:::i;:::-;;;;;;;;;;;;;53768:13;:154::i;:::-;53703:226;;;;;;;;:::i;:::-;;;;;;;;;;;;;53689:241;;;;;52976:960;;;:::o;20780:305::-;20882:4;-1:-1:-1;;;;;;20919:40:0;;-1:-1:-1;;;20919:40:0;;:105;;-1:-1:-1;;;;;;;20976:48:0;;-1:-1:-1;;;20976:48:0;20919:105;:158;;;-1:-1:-1;;;;;;;;;;19386:40:0;;;21041:36;19277:157;27999:321;28129:18;28135:2;28139:7;28129:5;:18::i;:::-;28180:54;28211:1;28215:2;28219:7;28228:5;28180:22;:54::i;:::-;28158:154;;;;-1:-1:-1;;;28158:154:0;;;;;;;:::i;60465:175::-;60589:45;60616:4;60622:2;60626:7;60589:26;:45::i;31399:799::-;31554:4;-1:-1:-1;;;;;31575:13:0;;8537:20;8585:8;31571:620;;31611:72;;-1:-1:-1;;;31611:72:0;;-1:-1:-1;;;;;31611:36:0;;;;;:72;;16259:10;;31662:4;;31668:7;;31677:5;;31611:72;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;31611:72:0;;;;;;;;-1:-1:-1;;31611:72:0;;;;;;;;;;;;:::i;:::-;;;31607:529;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;31853:13:0;;31849:272;;31896:60;;-1:-1:-1;;;31896:60:0;;;;;;;:::i;31849:272::-;32071:6;32065:13;32056:6;32052:2;32048:15;32041:38;31607:529;-1:-1:-1;;;;;;31734:51:0;-1:-1:-1;;;31734:51:0;;-1:-1:-1;31727:58:0;;31571:620;-1:-1:-1;32175:4:0;31399:799;;;;;;:::o;55021:393::-;55086:14;-1:-1:-1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;55086:14:0;55109:12;55124:14;;;:5;:14;;;;;;;55152:256;;;;;;;;55185:15;;55152:256;;55178:22;;55124:14;55178:22;:::i;:::-;55152:256;;55226:6;:13;55152:256;;;;;55216:6;55221:1;55216:4;:6;:::i;:::-;55215:24;;;;:::i;:::-;55152:256;;55265:5;:12;55152:256;;;;;55255:6;55260:1;55255:4;:6;:::i;:::-;55254:23;;;;:::i;:::-;55152:256;;55303:4;:11;55152:256;;;;;55293:6;55298:1;55293:4;:6;:::i;:::-;55292:22;;;;:::i;:::-;55152:256;;55341:6;:13;55152:256;;;;;55331:6;55336:1;55331:4;:6;:::i;:::-;55330:24;;;;:::i;:::-;55152:256;;55384:9;:16;55152:256;;;;;55374:6;55379:1;55374:4;:6;:::i;:::-;55373:27;;;;:::i;:::-;55152:256;;55145:263;55021:393;-1:-1:-1;;;55021:393:0:o;53942:1073::-;54052:189;;;;;;;;;;;;;;;-1:-1:-1;;;54052:189:0;;;;;;;;;;;;;;;;-1:-1:-1;;;54052:189:0;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;54052:189:0;;;;;;;;;;;;;;;;;;-1:-1:-1;;;54052:189:0;;;;54030:13;54052:189;;;;;;;;;;;;;;;;;-1:-1:-1;;;54052:189:0;;;;;;;;;;;;;;;;;;-1:-1:-1;;;54052:189:0;;;;;;;;;;;;;;;;;;-1:-1:-1;;;54052:189:0;;;;;;;;;;;;;;;;;;-1:-1:-1;;;54052:189:0;;;;;;;;;;;;;;;;;;-1:-1:-1;;;54052:189:0;;;;;;;;;;;;;;;;;;-1:-1:-1;;;54052:189:0;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;54052:189:0;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;54052:189:0;;;;;;;;;;;;;;;;;;-1:-1:-1;;;54052:189:0;;;;;;;;;;;;;;;;;;-1:-1:-1;;;54052:189:0;;;;;;;;;;;;;;;;;;-1:-1:-1;;;54052:189:0;;;;;;;;;;;;;;;;;;-1:-1:-1;;;54052:189:0;;;;;;;;;;;;;;;;;;-1:-1:-1;;;54052:189:0;;;;;;;;;;;;;;;;;;-1:-1:-1;;;54052:189:0;;;;;;;;;;;;;;;;;;-1:-1:-1;;;54052:189:0;;;;;;;;;;;;;;;;;;-1:-1:-1;;;54052:189:0;;;;;;;;;;;;;;;;;;-1:-1:-1;;;54052:189:0;;;;;;;;;;;;;;;;;;-1:-1:-1;;;54052:189:0;;;;;;;;;;;;;;;;;;-1:-1:-1;;;54052:189:0;;;;-1:-1:-1;;;54052:189:0;;;;;;;;;;;-1:-1:-1;;;54052:189:0;;;;-1:-1:-1;;;54052:189:0;;;;54030:13;54052:24;;54304:685;54328:4;:11;54324:1;:15;54304:685;;;54359:15;54383:4;54388:1;54383:7;;;;;;;;:::i;:::-;;;;;;;;-1:-1:-1;54487:16:0;54512:4;54517:3;:1;54519;54517:3;:::i;:::-;54512:9;;;;;;;;:::i;:::-;;;;;;;;-1:-1:-1;54535:15:0;;54531:420;;54578:7;54594:14;54606:2;54594:9;:14;:::i;:::-;54578:31;-1:-1:-1;54620:7:0;54636:14;54648:2;54636:9;:14;:::i;:::-;54662:31;;;;;;;;;;;;-1:-1:-1;;;54662:31:0;;;;54620;;-1:-1:-1;54721:1:0;54708:14;;;;54704:74;;;54745:7;54753:12;54764:1;54753:10;:12;:::i;:::-;54745:21;;;;;;;;;;:::i;:::-;;;;;;;54737:29;;54704:74;54820:5;54844:6;54851:9;54844:17;;;;;;;;;:::i;:::-;;;;;54883:6;54890:1;54883:9;;;;;;;;;:::i;:::-;;;;;54903:6;54910:1;54903:9;;;;;;;;;:::i;:::-;;;;;54926:5;54803:137;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;54788:153;;54552:399;;;54531:420;54959:22;;;;;;:::i;:::-;;;54350:639;;54345:1;54347;54345:3;;;;:::i;:::-;54341:7;;54304:685;;;-1:-1:-1;55004:5:0;;53942:1073;-1:-1:-1;;;;;53942:1073:0:o;47001:2037::-;47059:13;47089:4;:11;47104:1;47089:16;47085:31;;;-1:-1:-1;;47107:9:0;;;;;;;;;-1:-1:-1;47107:9:0;;;47001:2037::o;47085:31::-;47176:19;47198:5;;;;;;;;;;;;;;;;;47176:27;;47255:18;47301:1;47282:4;:11;47296:1;47282:15;;;;:::i;:::-;47281:21;;;;:::i;:::-;47276:27;;:1;:27;:::i;:::-;47255:48;-1:-1:-1;47386:20:0;47420:15;47255:48;47433:2;47420:15;:::i;:::-;47409:27;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;47409:27:0;;47386:50;;47533:10;47525:6;47518:26;47640:1;47633:5;47629:13;47711:4;47762;47756:11;47747:7;47743:25;47870:2;47862:6;47858:15;47955:810;47974:6;47965:7;47962:19;47955:810;;;48040:1;48027:15;;;48121:14;;48274:4;48262:2;48258:14;;;48254:25;;48240:40;;48234:47;48229:3;48225:57;;;48207:76;;48402:2;48398:14;;;48394:25;;48380:40;;48374:47;48365:57;;48328:1;48313:17;;48347:76;48543:1;48538:14;;;48534:25;;48520:40;;48514:47;48505:57;;48453:17;;;48487:76;48674:25;;48660:40;;48654:47;48645:57;;48593:17;;;48627:76;;;;48733:17;;47955:810;;;48850:1;48843:4;48837:11;48833:19;48871:1;48866:54;;;;48939:1;48934:52;;;;48826:160;;48866:54;-1:-1:-1;;;;;48882:17:0;;48875:43;48866:54;;48934:52;-1:-1:-1;;;;;48950:17:0;;48943:41;48826:160;-1:-1:-1;49024:6:0;;47001:2037;-1:-1:-1;;;;;;;;47001:2037:0:o;28656:382::-;-1:-1:-1;;;;;28736:16:0;;28728:61;;;;-1:-1:-1;;;28728:61:0;;15903:2:1;28728:61:0;;;15885:21:1;;;15922:18;;;15915:30;15981:34;15961:18;;;15954:62;16033:18;;28728:61:0;15701:356:1;28728:61:0;26743:4;26767:16;;;:7;:16;;;;;;-1:-1:-1;;;;;26767:16:0;:30;28800:58;;;;-1:-1:-1;;;28800:58:0;;13128:2:1;28800:58:0;;;13110:21:1;13167:2;13147:18;;;13140:30;13206;13186:18;;;13179:58;13254:18;;28800:58:0;12926:352:1;28800:58:0;28871:45;28900:1;28904:2;28908:7;28871:20;:45::i;:::-;-1:-1:-1;;;;;28929:13:0;;;;;;:9;:13;;;;;:18;;28946:1;;28929:13;:18;;28946:1;;28929:18;:::i;:::-;;;;-1:-1:-1;;28958:16:0;;;;:7;:16;;;;;;:21;;-1:-1:-1;;;;;;28958:21:0;-1:-1:-1;;;;;28958:21:0;;;;;;;;28997:33;;28958:16;;;28997:33;;28958:16;;28997:33;28656:382;;:::o;36514:589::-;-1:-1:-1;;;;;36720:18:0;;36716:187;;36755:40;36787:7;37930:10;:17;;37903:24;;;;:15;:24;;;;;:44;;;37958:24;;;;;;;;;;;;37826:164;36755:40;36716:187;;;36825:2;-1:-1:-1;;;;;36817:10:0;:4;-1:-1:-1;;;;;36817:10:0;;36813:90;;36844:47;36877:4;36883:7;36844:32;:47::i;:::-;-1:-1:-1;;;;;36917:16:0;;36913:183;;36950:45;36987:7;36950:36;:45::i;36913:183::-;37023:4;-1:-1:-1;;;;;37017:10:0;:2;-1:-1:-1;;;;;37017:10:0;;37013:83;;37044:40;37072:2;37076:7;37044:27;:40::i;38617:988::-;38883:22;38933:1;38908:22;38925:4;38908:16;:22::i;:::-;:26;;;;:::i;:::-;38945:18;38966:26;;;:17;:26;;;;;;38883:51;;-1:-1:-1;39099:28:0;;;39095:328;;-1:-1:-1;;;;;39166:18:0;;39144:19;39166:18;;;:12;:18;;;;;;;;:34;;;;;;;;;39217:30;;;;;;:44;;;39334:30;;:17;:30;;;;;:43;;;39095:328;-1:-1:-1;39519:26:0;;;;:17;:26;;;;;;;;39512:33;;;-1:-1:-1;;;;;39563:18:0;;;;;:12;:18;;;;;:34;;;;;;;39556:41;38617:988::o;39900:1079::-;40178:10;:17;40153:22;;40178:21;;40198:1;;40178:21;:::i;:::-;40210:18;40231:24;;;:15;:24;;;;;;40604:10;:26;;40153:46;;-1:-1:-1;40231:24:0;;40153:46;;40604:26;;;;;;:::i;:::-;;;;;;;;;40582:48;;40668:11;40643:10;40654;40643:22;;;;;;;;:::i;:::-;;;;;;;;;;;;:36;;;;40748:28;;;:15;:28;;;;;;;:41;;;40920:24;;;;;40913:31;40955:10;:16;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;39971:1008;;;39900:1079;:::o;37404:221::-;37489:14;37506:20;37523:2;37506:16;:20::i;:::-;-1:-1:-1;;;;;37537:16:0;;;;;;;:12;:16;;;;;;;;:24;;;;;;;;:34;;;37582:26;;;:17;:26;;;;;;:35;;;;-1:-1:-1;37404:221:0:o;14:173:1:-;82:20;;-1:-1:-1;;;;;131:31:1;;121:42;;111:70;;177:1;174;167:12;111:70;14:173;;;:::o;192:186::-;251:6;304:2;292:9;283:7;279:23;275:32;272:52;;;320:1;317;310:12;272:52;343:29;362:9;343:29;:::i;:::-;333:39;192:186;-1:-1:-1;;;192:186:1:o;383:260::-;451:6;459;512:2;500:9;491:7;487:23;483:32;480:52;;;528:1;525;518:12;480:52;551:29;570:9;551:29;:::i;:::-;541:39;;599:38;633:2;622:9;618:18;599:38;:::i;:::-;589:48;;383:260;;;;;:::o;648:328::-;725:6;733;741;794:2;782:9;773:7;769:23;765:32;762:52;;;810:1;807;800:12;762:52;833:29;852:9;833:29;:::i;:::-;823:39;;881:38;915:2;904:9;900:18;881:38;:::i;:::-;871:48;;966:2;955:9;951:18;938:32;928:42;;648:328;;;;;:::o;981:1138::-;1076:6;1084;1092;1100;1153:3;1141:9;1132:7;1128:23;1124:33;1121:53;;;1170:1;1167;1160:12;1121:53;1193:29;1212:9;1193:29;:::i;:::-;1183:39;;1241:38;1275:2;1264:9;1260:18;1241:38;:::i;:::-;1231:48;;1326:2;1315:9;1311:18;1298:32;1288:42;;1381:2;1370:9;1366:18;1353:32;1404:18;1445:2;1437:6;1434:14;1431:34;;;1461:1;1458;1451:12;1431:34;1499:6;1488:9;1484:22;1474:32;;1544:7;1537:4;1533:2;1529:13;1525:27;1515:55;;1566:1;1563;1556:12;1515:55;1602:2;1589:16;1624:2;1620;1617:10;1614:36;;;1630:18;;:::i;:::-;1705:2;1699:9;1673:2;1759:13;;-1:-1:-1;;1755:22:1;;;1779:2;1751:31;1747:40;1735:53;;;1803:18;;;1823:22;;;1800:46;1797:72;;;1849:18;;:::i;:::-;1889:10;1885:2;1878:22;1924:2;1916:6;1909:18;1964:7;1959:2;1954;1950;1946:11;1942:20;1939:33;1936:53;;;1985:1;1982;1975:12;1936:53;2041:2;2036;2032;2028:11;2023:2;2015:6;2011:15;1998:46;2086:1;2081:2;2076;2068:6;2064:15;2060:24;2053:35;2107:6;2097:16;;;;;;;981:1138;;;;;;;:::o;2124:347::-;2189:6;2197;2250:2;2238:9;2229:7;2225:23;2221:32;2218:52;;;2266:1;2263;2256:12;2218:52;2289:29;2308:9;2289:29;:::i;:::-;2279:39;;2368:2;2357:9;2353:18;2340:32;2415:5;2408:13;2401:21;2394:5;2391:32;2381:60;;2437:1;2434;2427:12;2381:60;2460:5;2450:15;;;2124:347;;;;;:::o;2476:254::-;2544:6;2552;2605:2;2593:9;2584:7;2580:23;2576:32;2573:52;;;2621:1;2618;2611:12;2573:52;2644:29;2663:9;2644:29;:::i;:::-;2634:39;2720:2;2705:18;;;;2692:32;;-1:-1:-1;;;2476:254:1:o;2735:245::-;2793:6;2846:2;2834:9;2825:7;2821:23;2817:32;2814:52;;;2862:1;2859;2852:12;2814:52;2901:9;2888:23;2920:30;2944:5;2920:30;:::i;2985:249::-;3054:6;3107:2;3095:9;3086:7;3082:23;3078:32;3075:52;;;3123:1;3120;3113:12;3075:52;3155:9;3149:16;3174:30;3198:5;3174:30;:::i;3239:180::-;3298:6;3351:2;3339:9;3330:7;3326:23;3322:32;3319:52;;;3367:1;3364;3357:12;3319:52;-1:-1:-1;3390:23:1;;3239:180;-1:-1:-1;3239:180:1:o;3424:248::-;3492:6;3500;3553:2;3541:9;3532:7;3528:23;3524:32;3521:52;;;3569:1;3566;3559:12;3521:52;-1:-1:-1;;3592:23:1;;;3662:2;3647:18;;;3634:32;;-1:-1:-1;3424:248:1:o;3677:257::-;3718:3;3756:5;3750:12;3783:6;3778:3;3771:19;3799:63;3855:6;3848:4;3843:3;3839:14;3832:4;3825:5;3821:16;3799:63;:::i;:::-;3916:2;3895:15;-1:-1:-1;;3891:29:1;3882:39;;;;3923:4;3878:50;;3677:257;-1:-1:-1;;3677:257:1:o;3939:185::-;3981:3;4019:5;4013:12;4034:52;4079:6;4074:3;4067:4;4060:5;4056:16;4034:52;:::i;:::-;4102:16;;;;;3939:185;-1:-1:-1;;3939:185:1:o;4505:1892::-;5333:3;5371:6;5365:13;5387:53;5433:6;5428:3;5421:4;5413:6;5409:17;5387:53;:::i;:::-;-1:-1:-1;;;5462:16:1;;;5487:53;;;5565:13;;5587:66;5565:13;5639:2;5628:14;;5621:4;5609:17;;5587:66;:::i;:::-;-1:-1:-1;;;5716:2:1;5672:20;;;;5708:11;;;5701:65;5791:13;;5813:63;5791:13;5862:2;5854:11;;5847:4;5835:17;;5813:63;:::i;:::-;-1:-1:-1;;;5936:2:1;5895:17;;;;5928:11;;;5921:43;5989:13;;6011:63;5989:13;6060:2;6052:11;;6045:4;6033:17;;6011:63;:::i;:::-;-1:-1:-1;;;6134:2:1;6093:17;;;;6126:11;;;6119:49;6193:13;;6215:63;6193:13;6264:2;6256:11;;6249:4;6237:17;;6215:63;:::i;:::-;-1:-1:-1;;;6338:2:1;6297:17;;;;6330:11;;;6323:41;6388:2;6380:11;;4505:1892;-1:-1:-1;;;;;;;4505:1892:1:o;6402:685::-;6765:66;6760:3;6753:79;-1:-1:-1;;;6857:2:1;6852:3;6848:12;6841:29;6735:3;6899:6;6893:13;6915:60;6968:6;6963:2;6958:3;6954:12;6949:2;6941:6;6937:15;6915:60;:::i;:::-;-1:-1:-1;;;7034:2:1;6994:16;;;;7026:11;;;7019:35;-1:-1:-1;7078:2:1;7070:11;;6402:685;-1:-1:-1;6402:685:1:o;7092:1885::-;7796:66;7791:3;7784:79;7893:66;7888:2;7883:3;7879:12;7872:88;7990:66;7985:2;7980:3;7976:12;7969:88;8087:66;8082:2;8077:3;8073:12;8066:88;8185:66;8179:3;8174;8170:13;8163:89;7766:3;8281:6;8275:13;8297:61;8351:6;8345:3;8340;8336:13;8331:2;8323:6;8319:15;8297:61;:::i;:::-;-1:-1:-1;;;8417:3:1;8377:16;;;8409:12;;;8402:42;8469:13;;8491:62;8469:13;8538:3;8530:12;;8525:2;8513:15;;8491:62;:::i;:::-;8614:13;;8572:17;;;8636:62;8614:13;8683:3;8675:12;;8670:2;8658:15;;8636:62;:::i;:::-;8759:13;;8717:17;;;8781:62;8759:13;8828:3;8820:12;;8815:2;8803:15;;8781:62;:::i;:::-;8859:112;8889:81;8915:54;8964:3;8953:8;8949:2;8945:17;8941:27;8933:6;8915:54;:::i;:::-;8907:6;8889:81;:::i;:::-;-1:-1:-1;;;4194:21:1;;4240:1;4231:11;;4129:119;8859:112;8852:119;7092:1885;-1:-1:-1;;;;;;;;;;7092:1885:1:o;8982:448::-;9244:31;9239:3;9232:44;9214:3;9305:6;9299:13;9321:62;9376:6;9371:2;9366:3;9362:12;9355:4;9347:6;9343:17;9321:62;:::i;:::-;9403:16;;;;9421:2;9399:25;;8982:448;-1:-1:-1;;8982:448:1:o;9853:488::-;-1:-1:-1;;;;;10122:15:1;;;10104:34;;10174:15;;10169:2;10154:18;;10147:43;10221:2;10206:18;;10199:34;;;10269:3;10264:2;10249:18;;10242:31;;;10047:4;;10290:45;;10315:19;;10307:6;10290:45;:::i;10538:217::-;10685:2;10674:9;10667:21;10648:4;10705:44;10745:2;10734:9;10730:18;10722:6;10705:44;:::i;11756:414::-;11958:2;11940:21;;;11997:2;11977:18;;;11970:30;12036:34;12031:2;12016:18;;12009:62;-1:-1:-1;;;12102:2:1;12087:18;;12080:48;12160:3;12145:19;;11756:414::o;17990:413::-;18192:2;18174:21;;;18231:2;18211:18;;;18204:30;18270:34;18265:2;18250:18;;18243:62;-1:-1:-1;;;18336:2:1;18321:18;;18314:47;18393:3;18378:19;;17990:413::o;20123:128::-;20163:3;20194:1;20190:6;20187:1;20184:13;20181:39;;;20200:18;;:::i;:::-;-1:-1:-1;20236:9:1;;20123:128::o;20256:120::-;20296:1;20322;20312:35;;20327:18;;:::i;:::-;-1:-1:-1;20361:9:1;;20256:120::o;20381:168::-;20421:7;20487:1;20483;20479:6;20475:14;20472:1;20469:21;20464:1;20457:9;20450:17;20446:45;20443:71;;;20494:18;;:::i;:::-;-1:-1:-1;20534:9:1;;20381:168::o;20554:125::-;20594:4;20622:1;20619;20616:8;20613:34;;;20627:18;;:::i;:::-;-1:-1:-1;20664:9:1;;20554:125::o;20684:195::-;20722:4;20759;20756:1;20752:12;20791:4;20788:1;20784:12;20816:3;20811;20808:12;20805:38;;;20823:18;;:::i;:::-;20860:13;;;20684:195;-1:-1:-1;;;20684:195:1:o;20884:258::-;20956:1;20966:113;20980:6;20977:1;20974:13;20966:113;;;21056:11;;;21050:18;21037:11;;;21030:39;21002:2;20995:10;20966:113;;;21097:6;21094:1;21091:13;21088:48;;;-1:-1:-1;;21132:1:1;21114:16;;21107:27;20884:258::o;21147:380::-;21226:1;21222:12;;;;21269;;;21290:61;;21344:4;21336:6;21332:17;21322:27;;21290:61;21397:2;21389:6;21386:14;21366:18;21363:38;21360:161;;;21443:10;21438:3;21434:20;21431:1;21424:31;21478:4;21475:1;21468:15;21506:4;21503:1;21496:15;21360:161;;21147:380;;;:::o;21532:135::-;21571:3;-1:-1:-1;;21592:17:1;;21589:43;;;21612:18;;:::i;:::-;-1:-1:-1;21659:1:1;21648:13;;21532:135::o;21672:112::-;21704:1;21730;21720:35;;21735:18;;:::i;:::-;-1:-1:-1;21769:9:1;;21672:112::o;21789:127::-;21850:10;21845:3;21841:20;21838:1;21831:31;21881:4;21878:1;21871:15;21905:4;21902:1;21895:15;21921:127;21982:10;21977:3;21973:20;21970:1;21963:31;22013:4;22010:1;22003:15;22037:4;22034:1;22027:15;22053:127;22114:10;22109:3;22105:20;22102:1;22095:31;22145:4;22142:1;22135:15;22169:4;22166:1;22159:15;22185:127;22246:10;22241:3;22237:20;22234:1;22227:31;22277:4;22274:1;22267:15;22301:4;22298:1;22291:15;22317:127;22378:10;22373:3;22369:20;22366:1;22359:31;22409:4;22406:1;22399:15;22433:4;22430:1;22423:15;22449:131;-1:-1:-1;;;;;;22523:32:1;;22513:43;;22503:71;;22570:1;22567;22560:12

Metadata Hash

ipfs://2e442de6ed3f22c889e823fec27f7318466e00a8a5f2ac133d8a5228dfeb0c53
Loading