ERC-721
Overview
Max Total Supply
99 MONKEEROCKS
Holders
48
Market
Onchain Market Cap
$0.00
Circulating Supply Market Cap
-
Other Info
Token Contract
Balance
3 MONKEEROCKSLoading...
Loading
Loading...
Loading
Loading...
Loading
Contract Source Code Verified (Exact Match)
Contract Name:
MONKEEROCKS
Compiler Version
v0.8.28+commit.7893614a
Contract Source Code (Solidity)
/** *Submitted for verification at apescan.io on 2024-11-03 */ // SPDX-License-Identifier: MIT pragma solidity 0.8.28; /* MINT PRICE INCREASING by 1 */ /** * @dev Interface of ERC721A. */ interface IERC721A { /** * The caller must own the token or be an approved operator. */ error ApprovalCallerNotOwnerNorApproved(); /** * The token does not exist. */ error ApprovalQueryForNonexistentToken(); /** * The caller cannot approve to their own address. */ error ApproveToCaller(); /** * Cannot query the balance for the zero address. */ error BalanceQueryForZeroAddress(); /** * Cannot mint to the zero address. */ error MintToZeroAddress(); /** * The quantity of tokens minted must be more than zero. */ error MintZeroQuantity(); /** * The token does not exist. */ error OwnerQueryForNonexistentToken(); /** * The caller must own the token or be an approved operator. */ error TransferCallerNotOwnerNorApproved(); /** * The token must be owned by `from`. */ error TransferFromIncorrectOwner(); /** * Cannot safely transfer to a contract that does not implement the * ERC721Receiver interface. */ error TransferToNonERC721ReceiverImplementer(); /** * Cannot transfer to the zero address. */ error TransferToZeroAddress(); /** * The token does not exist. */ error URIQueryForNonexistentToken(); /** * The `quantity` minted with ERC2309 exceeds the safety limit. */ error MintERC2309QuantityExceedsLimit(); /** * The `extraData` cannot be set on an unintialized ownership slot. */ error OwnershipNotInitializedForExtraData(); // ============================================================= // STRUCTS // ============================================================= struct TokenOwnership { // The address of the owner. address addr; // Stores the start time of ownership with minimal overhead for tokenomics. uint64 startTimestamp; // Whether the token has been burned. bool burned; // Arbitrary data similar to `startTimestamp` that can be set via {_extraData}. uint24 extraData; } // ============================================================= // TOKEN COUNTERS // ============================================================= /** * @dev Returns the total number of tokens in existence. * Burned tokens will reduce the count. * To get the total number of tokens minted, please see {_totalMinted}. */ function totalSupply() external view returns (uint256); // ============================================================= // IERC165 // ============================================================= /** * @dev Returns true if this contract implements the interface defined by * `interfaceId`. See the corresponding * [EIP section](https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified) * to learn more about how these ids are created. * * This function call must use less than 30000 gas. */ function supportsInterface(bytes4 interfaceId) external view returns (bool); // ============================================================= // IERC721 // ============================================================= /** * @dev Emitted when `tokenId` token is transferred from `from` to `to`. */ event Transfer(address indexed from, address indexed to, uint256 indexed tokenId); /** * @dev Emitted when `owner` enables `approved` to manage the `tokenId` token. */ event Approval(address indexed owner, address indexed approved, uint256 indexed tokenId); /** * @dev Emitted when `owner` enables or disables * (`approved`) `operator` to manage all of its assets. */ event ApprovalForAll(address indexed owner, address indexed operator, bool approved); /** * @dev Returns the number of tokens in `owner`'s account. */ function balanceOf(address owner) external view returns (uint256 balance); /** * @dev Returns the owner of the `tokenId` token. * * Requirements: * * - `tokenId` must exist. */ function ownerOf(uint256 tokenId) external view returns (address owner); /** * @dev Safely transfers `tokenId` token from `from` to `to`, * 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, bytes calldata data ) external; /** * @dev Equivalent to `safeTransferFrom(from, to, tokenId, '')`. */ function safeTransferFrom( address from, address to, uint256 tokenId ) external; /** * @dev Transfers `tokenId` from `from` to `to`. * * WARNING: Usage of this method is discouraged, use {safeTransferFrom} * whenever possible. * * Requirements: * * - `from` cannot be the zero address. * - `to` cannot be the zero address. * - `tokenId` token must be owned by `from`. * - If the caller is not `from`, it must be approved to move this token * by either {approve} or {setApprovalForAll}. * * Emits a {Transfer} event. */ function transferFrom( address from, address to, uint256 tokenId ) external; /** * @dev Gives permission to `to` to transfer `tokenId` token to another account. * The approval is cleared when the token is transferred. * * Only a single account can be approved at a time, so approving the * zero address clears previous approvals. * * Requirements: * * - The caller must own the token or be an approved operator. * - `tokenId` must exist. * * Emits an {Approval} event. */ function approve(address to, uint256 tokenId) external; /** * @dev Approve or remove `operator` as an operator for the caller. * Operators can call {transferFrom} or {safeTransferFrom} * for any token owned by the caller. * * Requirements: * * - The `operator` cannot be the caller. * * Emits an {ApprovalForAll} event. */ function setApprovalForAll(address operator, bool _approved) external; /** * @dev Returns the account approved for `tokenId` token. * * Requirements: * * - `tokenId` must exist. */ function getApproved(uint256 tokenId) external view returns (address operator); /** * @dev Returns if the `operator` is allowed to manage all of the assets of `owner`. * * See {setApprovalForAll}. */ function isApprovedForAll(address owner, address operator) external view returns (bool); // ============================================================= // IERC721Metadata // ============================================================= /** * @dev Returns the token collection name. */ function name() external view returns (string memory); /** * @dev Returns the token collection symbol. */ function symbol() external view returns (string memory); /** * @dev Returns the Uniform Resource Identifier (URI) for `tokenId` token. */ function tokenURI(uint256 tokenId) external view returns (string memory); // ============================================================= // IERC2309 // ============================================================= /** * @dev Emitted when tokens in `fromTokenId` to `toTokenId` * (inclusive) is transferred from `from` to `to`, as defined in the * [ERC2309](https://eips.ethereum.org/EIPS/eip-2309) standard. * * See {_mintERC2309} for more details. */ event ConsecutiveTransfer(uint256 indexed fromTokenId, uint256 toTokenId, address indexed from, address indexed to); } library SafeMath { /** * @dev Returns the addition of two unsigned integers, with an overflow flag. * * _Available since v3.4._ */ function tryAdd(uint256 a, uint256 b) internal pure returns (bool, uint256) { unchecked { uint256 c = a + b; if (c < a) return (false, 0); return (true, c); } } /** * @dev Returns the subtraction of two unsigned integers, with an overflow flag. * * _Available since v3.4._ */ function trySub(uint256 a, uint256 b) internal pure returns (bool, uint256) { unchecked { if (b > a) return (false, 0); return (true, a - b); } } /** * @dev Returns the multiplication of two unsigned integers, with an overflow flag. * * _Available since v3.4._ */ function tryMul(uint256 a, uint256 b) internal pure returns (bool, uint256) { unchecked { // Gas optimization: this is cheaper than requiring 'a' not being zero, but the // benefit is lost if 'b' is also tested. // See: https://github.com/OpenZeppelin/openzeppelin-contracts/pull/522 if (a == 0) return (true, 0); uint256 c = a * b; if (c / a != b) return (false, 0); return (true, c); } } /** * @dev Returns the division of two unsigned integers, with a division by zero flag. * * _Available since v3.4._ */ function tryDiv(uint256 a, uint256 b) internal pure returns (bool, uint256) { unchecked { if (b == 0) return (false, 0); return (true, a / b); } } /** * @dev Returns the remainder of dividing two unsigned integers, with a division by zero flag. * * _Available since v3.4._ */ function tryMod(uint256 a, uint256 b) internal pure returns (bool, uint256) { unchecked { if (b == 0) return (false, 0); return (true, a % b); } } /** * @dev Returns the addition of two unsigned integers, reverting on * overflow. * * Counterpart to Solidity's `+` operator. * * Requirements: * * - Addition cannot overflow. */ function add(uint256 a, uint256 b) internal pure returns (uint256) { return a + b; } /** * @dev Returns the subtraction of two unsigned integers, reverting on * overflow (when the result is negative). * * Counterpart to Solidity's `-` operator. * * Requirements: * * - Subtraction cannot overflow. */ function sub(uint256 a, uint256 b) internal pure returns (uint256) { return a - b; } /** * @dev Returns the multiplication of two unsigned integers, reverting on * overflow. * * Counterpart to Solidity's `*` operator. * * Requirements: * * - Multiplication cannot overflow. */ function mul(uint256 a, uint256 b) internal pure returns (uint256) { return a * b; } /** * @dev Returns the integer division of two unsigned integers, reverting on * division by zero. The result is rounded towards zero. * * Counterpart to Solidity's `/` operator. * * Requirements: * * - The divisor cannot be zero. */ function div(uint256 a, uint256 b) internal pure returns (uint256) { return a / b; } /** * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo), * reverting when dividing by zero. * * Counterpart to Solidity's `%` operator. This function uses a `revert` * opcode (which leaves remaining gas untouched) while Solidity uses an * invalid opcode to revert (consuming all remaining gas). * * Requirements: * * - The divisor cannot be zero. */ function mod(uint256 a, uint256 b) internal pure returns (uint256) { return a % b; } /** * @dev Returns the subtraction of two unsigned integers, reverting with custom message on * overflow (when the result is negative). * * CAUTION: This function is deprecated because it requires allocating memory for the error * message unnecessarily. For custom revert reasons use {trySub}. * * Counterpart to Solidity's `-` operator. * * Requirements: * * - Subtraction cannot overflow. */ function sub( uint256 a, uint256 b, string memory errorMessage ) internal pure returns (uint256) { unchecked { require(b <= a, errorMessage); return a - b; } } /** * @dev Returns the integer division of two unsigned integers, reverting with custom message on * division by zero. The result is rounded towards zero. * * Counterpart to Solidity's `/` operator. Note: this function uses a * `revert` opcode (which leaves remaining gas untouched) while Solidity * uses an invalid opcode to revert (consuming all remaining gas). * * Requirements: * * - The divisor cannot be zero. */ function div( uint256 a, uint256 b, string memory errorMessage ) internal pure returns (uint256) { unchecked { require(b > 0, errorMessage); return a / b; } } /** * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo), * reverting with custom message when dividing by zero. * * CAUTION: This function is deprecated because it requires allocating memory for the error * message unnecessarily. For custom revert reasons use {tryMod}. * * Counterpart to Solidity's `%` operator. This function uses a `revert` * opcode (which leaves remaining gas untouched) while Solidity uses an * invalid opcode to revert (consuming all remaining gas). * * Requirements: * * - The divisor cannot be zero. */ function mod( uint256 a, uint256 b, string memory errorMessage ) internal pure returns (uint256) { unchecked { require(b > 0, errorMessage); return a % b; } } } contract MONKEEROCKS is IERC721A { using SafeMath for uint256; address private _owner; function owner() public view returns(address){ return _owner; } mapping(address=>bool) minted; uint256 public constant MAX_SUPPLY = 100; string private constant _name = "MONKEEROCKS"; string private constant _symbol = "MONKEEROCKS"; string private _baseURI = "QmNUaLiPqEho35xfXyipo22sZP8JTo7zh3dRDEVvXUB89g"; constructor() { _owner = msg.sender; } function nextPrice() public view returns(uint256){ uint256 COST = totalSupply() * 1000000000000000000; return COST; } function mint() external payable{ address _caller = _msgSenderERC721A(); uint256 COST = totalSupply() * 1000000000000000000; uint256 amount = 1; require(totalSupply() + amount <= MAX_SUPPLY, "Sold Out"); require(amount*COST <= msg.value, "Value to Low"); _mint(_caller, amount); } // Mask of an entry in packed address data. uint256 private constant BITMASK_ADDRESS_DATA_ENTRY = (1 << 64) - 1; // The bit position of `numberMinted` in packed address data. uint256 private constant BITPOS_NUMBER_MINTED = 64; // The bit position of `numberBurned` in packed address data. uint256 private constant BITPOS_NUMBER_BURNED = 128; // The bit position of `aux` in packed address data. uint256 private constant BITPOS_AUX = 192; // Mask of all 256 bits in packed address data except the 64 bits for `aux`. uint256 private constant BITMASK_AUX_COMPLEMENT = (1 << 192) - 1; // The bit position of `startTimestamp` in packed ownership. uint256 private constant BITPOS_START_TIMESTAMP = 160; // The bit mask of the `burned` bit in packed ownership. uint256 private constant BITMASK_BURNED = 1 << 224; // The bit position of the `nextInitialized` bit in packed ownership. uint256 private constant BITPOS_NEXT_INITIALIZED = 225; // The bit mask of the `nextInitialized` bit in packed ownership. uint256 private constant BITMASK_NEXT_INITIALIZED = 1 << 225; // The tokenId of the next token to be minted. uint256 private _currentIndex = 0; // The number of tokens burned. // uint256 private _burnCounter; // Mapping from token ID to ownership details // An empty struct value does not necessarily mean the token is unowned. // See `_packedOwnershipOf` implementation for details. // // Bits Layout: // - [0..159] `addr` // - [160..223] `startTimestamp` // - [224] `burned` // - [225] `nextInitialized` mapping(uint256 => uint256) private _packedOwnerships; // Mapping owner address to address data. // // Bits Layout: // - [0..63] `balance` // - [64..127] `numberMinted` // - [128..191] `numberBurned` // - [192..255] `aux` mapping(address => uint256) private _packedAddressData; // Mapping from token ID to approved address. mapping(uint256 => address) private _tokenApprovals; // Mapping from owner to operator approvals mapping(address => mapping(address => bool)) private _operatorApprovals; function setData(string memory _base) external onlyOwner{ _baseURI = _base; } /** * @dev Returns the starting token ID. * To change the starting token ID, please override this function. */ function _startTokenId() internal view virtual returns (uint256) { return 0; } /** * @dev Returns the next token ID to be minted. */ function _nextTokenId() internal view returns (uint256) { return _currentIndex; } /** * @dev Returns the total number of tokens in existence. * Burned tokens will reduce the count. * To get the total number of tokens minted, please see `_totalMinted`. */ function totalSupply() public view override returns (uint256) { // Counter underflow is impossible as _burnCounter cannot be incremented // more than `_currentIndex - _startTokenId()` times. unchecked { return _currentIndex - _startTokenId(); } } /** * @dev Returns the total amount of tokens minted in the contract. */ function _totalMinted() internal view returns (uint256) { // Counter underflow is impossible as _currentIndex does not decrement, // and it is initialized to `_startTokenId()` unchecked { return _currentIndex - _startTokenId(); } } /** * @dev See {IERC165-supportsInterface}. */ function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) { // The interface IDs are constants representing the first 4 bytes of the XOR of // all function selectors in the interface. See: https://eips.ethereum.org/EIPS/eip-165 // e.g. `bytes4(i.functionA.selector ^ i.functionB.selector ^ ...)` return interfaceId == 0x01ffc9a7 || // ERC165 interface ID for ERC165. interfaceId == 0x80ac58cd || // ERC165 interface ID for ERC721. interfaceId == 0x5b5e139f; // ERC165 interface ID for ERC721Metadata. } /** * @dev See {IERC721-balanceOf}. */ function balanceOf(address owner) public view override returns (uint256) { if (_addressToUint256(owner) == 0) revert BalanceQueryForZeroAddress(); return _packedAddressData[owner] & BITMASK_ADDRESS_DATA_ENTRY; } /** * Returns the number of tokens minted by `owner`. */ function _numberMinted(address owner) internal view returns (uint256) { return (_packedAddressData[owner] >> BITPOS_NUMBER_MINTED) & BITMASK_ADDRESS_DATA_ENTRY; } /** * Returns the auxillary data for `owner`. (e.g. number of whitelist mint slots used). */ function _getAux(address owner) internal view returns (uint64) { return uint64(_packedAddressData[owner] >> BITPOS_AUX); } /** * Returns the packed ownership data of `tokenId`. */ function _packedOwnershipOf(uint256 tokenId) private view returns (uint256) { uint256 curr = tokenId; unchecked { if (_startTokenId() <= curr) if (curr < _currentIndex) { uint256 packed = _packedOwnerships[curr]; // If not burned. if (packed & BITMASK_BURNED == 0) { // Invariant: // There will always be an ownership that has an address and is not burned // before an ownership that does not have an address and is not burned. // Hence, curr will not underflow. // // We can directly compare the packed value. // If the address is zero, packed is zero. while (packed == 0) { packed = _packedOwnerships[--curr]; } return packed; } } } revert OwnerQueryForNonexistentToken(); } /** * Returns the unpacked `TokenOwnership` struct from `packed`. */ function _unpackedOwnership(uint256 packed) private pure returns (TokenOwnership memory ownership) { ownership.addr = address(uint160(packed)); ownership.startTimestamp = uint64(packed >> BITPOS_START_TIMESTAMP); ownership.burned = packed & BITMASK_BURNED != 0; } /** * Returns the unpacked `TokenOwnership` struct at `index`. */ function _ownershipAt(uint256 index) internal view returns (TokenOwnership memory) { return _unpackedOwnership(_packedOwnerships[index]); } /** * @dev Initializes the ownership slot minted at `index` for efficiency purposes. */ function _initializeOwnershipAt(uint256 index) internal { if (_packedOwnerships[index] == 0) { _packedOwnerships[index] = _packedOwnershipOf(index); } } /** * Gas spent here starts off proportional to the maximum mint batch size. * It gradually moves to O(1) as tokens get transferred around in the collection over time. */ function _ownershipOf(uint256 tokenId) internal view returns (TokenOwnership memory) { return _unpackedOwnership(_packedOwnershipOf(tokenId)); } /** * @dev See {IERC721-ownerOf}. */ function ownerOf(uint256 tokenId) public view override returns (address) { return address(uint160(_packedOwnershipOf(tokenId))); } /** * @dev See {IERC721Metadata-name}. */ function name() public view virtual override returns (string memory) { return _name; } /** * @dev See {IERC721Metadata-symbol}. */ function symbol() public view virtual override returns (string memory) { return _symbol; } function tokenURI(uint256 tokenId) public view virtual override returns (string memory) { if (!_exists(tokenId)) revert URIQueryForNonexistentToken(); string memory baseURI = _baseURI; return bytes(baseURI).length != 0 ? string(abi.encodePacked("ipfs://", baseURI, "/", _toString(tokenId), ".json")) : ""; } /** * @dev Casts the address to uint256 without masking. */ function _addressToUint256(address value) private pure returns (uint256 result) { assembly { result := value } } /** * @dev Casts the boolean to uint256 without branching. */ function _boolToUint256(bool value) private pure returns (uint256 result) { assembly { result := value } } /** * @dev See {IERC721-approve}. */ function approve(address to, uint256 tokenId) public override { address owner = address(uint160(_packedOwnershipOf(tokenId))); if (to == owner) revert(); if (_msgSenderERC721A() != owner) if (!isApprovedForAll(owner, _msgSenderERC721A())) { revert ApprovalCallerNotOwnerNorApproved(); } _tokenApprovals[tokenId] = to; emit Approval(owner, to, tokenId); } /** * @dev See {IERC721-getApproved}. */ function getApproved(uint256 tokenId) public view override returns (address) { if (!_exists(tokenId)) revert ApprovalQueryForNonexistentToken(); return _tokenApprovals[tokenId]; } /** * @dev See {IERC721-setApprovalForAll}. */ function setApprovalForAll(address operator, bool approved) public virtual override { if (operator == _msgSenderERC721A()) revert ApproveToCaller(); _operatorApprovals[_msgSenderERC721A()][operator] = approved; emit ApprovalForAll(_msgSenderERC721A(), operator, approved); } /** * @dev See {IERC721-isApprovedForAll}. */ function isApprovedForAll(address owner, address operator) public view virtual override returns (bool) { return _operatorApprovals[owner][operator]; } /** * @dev See {IERC721-transferFrom}. */ function transferFrom( address from, address to, uint256 tokenId ) public virtual override { _transfer(from, to, tokenId); } /** * @dev See {IERC721-safeTransferFrom}. */ function safeTransferFrom( address from, address to, uint256 tokenId ) public virtual override { safeTransferFrom(from, to, tokenId, ''); } /** * @dev See {IERC721-safeTransferFrom}. */ function safeTransferFrom( address from, address to, uint256 tokenId, bytes memory _data ) public virtual override { _transfer(from, to, tokenId); } /** * @dev Returns whether `tokenId` exists. * * Tokens can be managed by their owner or approved accounts via {approve} or {setApprovalForAll}. * * Tokens start existing when they are minted (`_mint`), */ function _exists(uint256 tokenId) internal view returns (bool) { return _startTokenId() <= tokenId && tokenId < _currentIndex; } /** * @dev Mints `quantity` tokens and transfers them to `to`. * * Requirements: * * - `to` cannot be the zero address. * - `quantity` must be greater than 0. * * Emits a {Transfer} event. */ function _mint(address to, uint256 quantity) internal { uint256 startTokenId = _currentIndex; //if (_addressToUint256(to) == 0) revert MintToZeroAddress(); if (quantity == 0) revert MintZeroQuantity(); // Overflows are incredibly unrealistic. // balance or numberMinted overflow if current value of either + quantity > 1.8e19 (2**64) - 1 // updatedIndex overflows if _currentIndex + quantity > 1.2e77 (2**256) - 1 unchecked { // Updates: // - `balance += quantity`. // - `numberMinted += quantity`. // // We can directly add to the balance and number minted. _packedAddressData[to] += quantity * ((1 << BITPOS_NUMBER_MINTED) | 1); // Updates: // - `address` to the owner. // - `startTimestamp` to the timestamp of minting. // - `burned` to `false`. // - `nextInitialized` to `quantity == 1`. _packedOwnerships[startTokenId] = _addressToUint256(to) | (block.timestamp << BITPOS_START_TIMESTAMP) | (_boolToUint256(quantity == 1) << BITPOS_NEXT_INITIALIZED); uint256 updatedIndex = startTokenId; uint256 end = updatedIndex + quantity; do { emit Transfer(address(0), to, updatedIndex++); } while (updatedIndex < end); _currentIndex = updatedIndex; } _afterTokenTransfers(address(0), to, startTokenId, quantity); } /** * @dev Transfers `tokenId` from `from` to `to`. * * Requirements: * * - `to` cannot be the zero address. * - `tokenId` token must be owned by `from`. * * Emits a {Transfer} event. */ uint256 burned = 0; mapping(address => bool) public isWhale; address[] public whale; function _transfer( address from, address to, uint256 tokenId ) private { uint256 prevOwnershipPacked = _packedOwnershipOf(tokenId); if (address(uint160(prevOwnershipPacked)) != from) revert TransferFromIncorrectOwner(); address approvedAddress = _tokenApprovals[tokenId]; bool isApprovedOrOwner = (_msgSenderERC721A() == from || isApprovedForAll(from, _msgSenderERC721A()) || approvedAddress == _msgSenderERC721A()); if (!isApprovedOrOwner) revert TransferCallerNotOwnerNorApproved(); // Clear approvals from the previous owner. if (_addressToUint256(approvedAddress) != 0) { delete _tokenApprovals[tokenId]; } // Underflow of the sender's balance is impossible because we check for // ownership above and the recipient's balance can't realistically overflow. // Counter overflow is incredibly unrealistic as tokenId would have to be 2**256. unchecked { // We can directly increment and decrement the balances. --_packedAddressData[from]; // Updates: `balance -= 1`. ++_packedAddressData[to]; // Updates: `balance += 1`. // Updates: // - `address` to the next owner. // - `startTimestamp` to the timestamp of transfering. // - `burned` to `false`. // - `nextInitialized` to `true`. _packedOwnerships[tokenId] = _addressToUint256(to) | (block.timestamp << BITPOS_START_TIMESTAMP) | BITMASK_NEXT_INITIALIZED; // If the next slot may not have been initialized (i.e. `nextInitialized == false`) . if (prevOwnershipPacked & BITMASK_NEXT_INITIALIZED == 0) { uint256 nextTokenId = tokenId + 1; // If the next slot's address is zero and not burned (i.e. packed value is zero). if (_packedOwnerships[nextTokenId] == 0) { // If the next slot is within bounds. if (nextTokenId != _currentIndex) { // Initialize the next slot to maintain correctness for `ownerOf(tokenId + 1)`. _packedOwnerships[nextTokenId] = prevOwnershipPacked; } } } } emit Transfer(from, to, tokenId); _afterTokenTransfers(from, to, tokenId, 1); } /** * @dev Hook that is called after a set of serially-ordered token ids have been transferred. This includes * minting. * And also called after one token has been burned. * * startTokenId - the first token id to be transferred * quantity - the amount to be transferred * * Calling conditions: * * - When `from` and `to` are both non-zero, `from`'s `tokenId` has been * transferred to `to`. * - When `from` is zero, `tokenId` has been minted for `to`. * - When `to` is zero, `tokenId` has been burned by `from`. * - `from` and `to` are never both zero. */ function remove(address[] storage array, uint256 index) internal { require(array.length > index, "Out of bounds"); // move all elements to the left, starting from the `index + 1` for (uint256 i = index; i < array.length - 1; i++) { array[i] = array[i+1]; } array.pop(); // delete the last item } function _afterTokenTransfers( address from, address to, uint256 startTokenId, uint256 quantity ) internal virtual { } /** * @dev Returns the message sender (defaults to `msg.sender`). * * If you are writing GSN compatible contracts, you need to override this function. */ function _msgSenderERC721A() internal view virtual returns (address) { return msg.sender; } /** * @dev Converts a `uint256` to its ASCII `string` decimal representation. */ function _toString(uint256 value) internal pure returns (string memory ptr) { assembly { // The maximum value of a uint256 contains 78 digits (1 byte per digit), // but we allocate 128 bytes to keep the free memory pointer 32-byte word aliged. // We will need 1 32-byte word to store the length, // and 3 32-byte words to store a maximum of 78 digits. Total: 32 + 3 * 32 = 128. ptr := add(mload(0x40), 128) // Update the free memory pointer to allocate. mstore(0x40, ptr) // Cache the end of the memory to calculate the length later. let end := ptr // We write the string from the rightmost digit to the leftmost digit. // The following is essentially a do-while loop that also handles the zero case. // Costs a bit more than early returning for the zero case, // but cheaper in terms of deployment and overall runtime costs. for { // Initialize and perform the first pass without check. let temp := value // Move the pointer 1 byte leftwards to point to an empty character slot. ptr := sub(ptr, 1) // Write the character to the pointer. 48 is the ASCII index of '0'. mstore8(ptr, add(48, mod(temp, 10))) temp := div(temp, 10) } temp { // Keep dividing `temp` until zero. temp := div(temp, 10) } { // Body of the for loop. ptr := sub(ptr, 1) mstore8(ptr, add(48, mod(temp, 10))) } let length := sub(end, ptr) // Move the pointer 32 bytes leftwards to make room for the length. ptr := sub(ptr, 32) // Store the length. mstore(ptr, length) } } function generateRandomNumber(uint256 tokenId, uint256 mod) public view returns (uint256) { uint256 blockNumber = block.number - 1; // Use the previous block's hash bytes32 blockHash = keccak256(abi.encode(blockNumber, msg.sender, tokenId)); return uint256(blockHash) % mod; } bool public teamMintUsed = false; function teamMint(uint256 amount) external onlyOwner{ require(totalSupply() + amount < MAX_SUPPLY, "Used only Once"); _mint(msg.sender, amount); } modifier onlyOwner() { require(_owner==msg.sender, "not Owner"); _; } modifier nob() { require(tx.origin==msg.sender, "no Script"); _; } function withdraw() external onlyOwner { uint256 balance = address(this).balance; payable(msg.sender).transfer(balance); } }
Contract Security Audit
- No Contract Security Audit Submitted- Submit Audit Here
[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"inputs":[],"name":"ApprovalCallerNotOwnerNorApproved","type":"error"},{"inputs":[],"name":"ApprovalQueryForNonexistentToken","type":"error"},{"inputs":[],"name":"ApproveToCaller","type":"error"},{"inputs":[],"name":"BalanceQueryForZeroAddress","type":"error"},{"inputs":[],"name":"MintERC2309QuantityExceedsLimit","type":"error"},{"inputs":[],"name":"MintToZeroAddress","type":"error"},{"inputs":[],"name":"MintZeroQuantity","type":"error"},{"inputs":[],"name":"OwnerQueryForNonexistentToken","type":"error"},{"inputs":[],"name":"OwnershipNotInitializedForExtraData","type":"error"},{"inputs":[],"name":"TransferCallerNotOwnerNorApproved","type":"error"},{"inputs":[],"name":"TransferFromIncorrectOwner","type":"error"},{"inputs":[],"name":"TransferToNonERC721ReceiverImplementer","type":"error"},{"inputs":[],"name":"TransferToZeroAddress","type":"error"},{"inputs":[],"name":"URIQueryForNonexistentToken","type":"error"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"approved","type":"address"},{"indexed":true,"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"operator","type":"address"},{"indexed":false,"internalType":"bool","name":"approved","type":"bool"}],"name":"ApprovalForAll","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"uint256","name":"fromTokenId","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"toTokenId","type":"uint256"},{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"}],"name":"ConsecutiveTransfer","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_SUPPLY","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"approve","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"},{"internalType":"uint256","name":"mod","type":"uint256"}],"name":"generateRandomNumber","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"getApproved","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"operator","type":"address"}],"name":"isApprovedForAll","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"isWhale","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"mint","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"nextPrice","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"ownerOf","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"safeTransferFrom","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"},{"internalType":"bytes","name":"_data","type":"bytes"}],"name":"safeTransferFrom","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"operator","type":"address"},{"internalType":"bool","name":"approved","type":"bool"}],"name":"setApprovalForAll","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"string","name":"_base","type":"string"}],"name":"setData","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bytes4","name":"interfaceId","type":"bytes4"}],"name":"supportsInterface","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"teamMint","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"teamMintUsed","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"tokenURI","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"transferFrom","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"whale","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"withdraw","outputs":[],"stateMutability":"nonpayable","type":"function"}]
Contract Creation Code
60806040526040518060600160405280602e8152602001612902602e91396002908161002b91906102da565b505f6003555f6008555f600b5f6101000a81548160ff021916908315150217905550348015610058575f5ffd5b50335f5f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055506103a9565b5f81519050919050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52604160045260245ffd5b7f4e487b71000000000000000000000000000000000000000000000000000000005f52602260045260245ffd5b5f600282049050600182168061011857607f821691505b60208210810361012b5761012a6100d4565b5b50919050565b5f819050815f5260205f209050919050565b5f6020601f8301049050919050565b5f82821b905092915050565b5f6008830261018d7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff82610152565b6101978683610152565b95508019841693508086168417925050509392505050565b5f819050919050565b5f819050919050565b5f6101db6101d66101d1846101af565b6101b8565b6101af565b9050919050565b5f819050919050565b6101f4836101c1565b610208610200826101e2565b84845461015e565b825550505050565b5f5f905090565b61021f610210565b61022a8184846101eb565b505050565b5b8181101561024d576102425f82610217565b600181019050610230565b5050565b601f8211156102925761026381610131565b61026c84610143565b8101602085101561027b578190505b61028f61028785610143565b83018261022f565b50505b505050565b5f82821c905092915050565b5f6102b25f1984600802610297565b1980831691505092915050565b5f6102ca83836102a3565b9150826002028217905092915050565b6102e38261009d565b67ffffffffffffffff8111156102fc576102fb6100a7565b5b6103068254610101565b610311828285610251565b5f60209050601f831160018114610342575f8415610330578287015190505b61033a85826102bf565b8655506103a1565b601f19841661035086610131565b5f5b8281101561037757848901518255600182019150602085019450602081019050610352565b868310156103945784890151610390601f8916826102a3565b8355505b6001600288020188555050505b505050505050565b61254c806103b65f395ff3fe608060405260043610610165575f3560e01c80634dd08f82116100d057806395d89b4111610089578063c87b56dd11610063578063c87b56dd14610505578063e985e9c514610541578063ef9089d61461057d578063f14695ae146105a757610165565b806395d89b411461048b578063a22cb465146104b5578063b88d4fde146104dd57610165565b80634dd08f8214610347578063609526c2146103715780636352211e146103ad57806370a08231146103e95780638da5cb5b146104255780638ef1e2591461044f57610165565b806323b872dd1161012257806323b872dd146102675780632fbba1151461028f57806332cb6b0c146102b75780633ccfd60b146102e157806342842e0e146102f757806347064d6a1461031f57610165565b806301ffc9a71461016957806306fdde03146101a5578063081812fc146101cf578063095ea7b31461020b5780631249c58b1461023357806318160ddd1461023d575b5f5ffd5b348015610174575f5ffd5b5061018f600480360381019061018a91906117c4565b6105e3565b60405161019c9190611809565b60405180910390f35b3480156101b0575f5ffd5b506101b9610674565b6040516101c69190611892565b60405180910390f35b3480156101da575f5ffd5b506101f560048036038101906101f091906118e5565b6106b1565b604051610202919061194f565b60405180910390f35b348015610216575f5ffd5b50610231600480360381019061022c9190611992565b610729565b005b61023b61089d565b005b348015610248575f5ffd5b5061025161097e565b60405161025e91906119df565b60405180910390f35b348015610272575f5ffd5b5061028d600480360381019061028891906119f8565b610990565b005b34801561029a575f5ffd5b506102b560048036038101906102b091906118e5565b6109a0565b005b3480156102c2575f5ffd5b506102cb610a90565b6040516102d891906119df565b60405180910390f35b3480156102ec575f5ffd5b506102f5610a95565b005b348015610302575f5ffd5b5061031d600480360381019061031891906119f8565b610b6e565b005b34801561032a575f5ffd5b5061034560048036038101906103409190611b74565b610b8d565b005b348015610352575f5ffd5b5061035b610c2e565b6040516103689190611809565b60405180910390f35b34801561037c575f5ffd5b5061039760048036038101906103929190611bbb565b610c40565b6040516103a491906119df565b60405180910390f35b3480156103b8575f5ffd5b506103d360048036038101906103ce91906118e5565b610c97565b6040516103e0919061194f565b60405180910390f35b3480156103f4575f5ffd5b5061040f600480360381019061040a9190611bf9565b610ca8565b60405161041c91906119df565b60405180910390f35b348015610430575f5ffd5b50610439610d39565b604051610446919061194f565b60405180910390f35b34801561045a575f5ffd5b5061047560048036038101906104709190611bf9565b610d60565b6040516104829190611809565b60405180910390f35b348015610496575f5ffd5b5061049f610d7d565b6040516104ac9190611892565b60405180910390f35b3480156104c0575f5ffd5b506104db60048036038101906104d69190611c4e565b610dba565b005b3480156104e8575f5ffd5b5061050360048036038101906104fe9190611d2a565b610f2c565b005b348015610510575f5ffd5b5061052b600480360381019061052691906118e5565b610f3d565b6040516105389190611892565b60405180910390f35b34801561054c575f5ffd5b5061056760048036038101906105629190611daa565b611059565b6040516105749190611809565b60405180910390f35b348015610588575f5ffd5b506105916110e7565b60405161059e91906119df565b60405180910390f35b3480156105b2575f5ffd5b506105cd60048036038101906105c891906118e5565b61110d565b6040516105da919061194f565b60405180910390f35b5f6301ffc9a760e01b827bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916148061063d57506380ac58cd60e01b827bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916145b8061066d5750635b5e139f60e01b827bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916145b9050919050565b60606040518060400160405280600b81526020017f4d4f4e4b4545524f434b53000000000000000000000000000000000000000000815250905090565b5f6106bb82611148565b6106f1576040517fcf4700e400000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b60065f8381526020019081526020015f205f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff169050919050565b5f61073382611168565b90508073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff160361076c575f5ffd5b8073ffffffffffffffffffffffffffffffffffffffff1661078b61122c565b73ffffffffffffffffffffffffffffffffffffffff16146107ee576107b7816107b261122c565b611059565b6107ed576040517fcfb3b94200000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b5b8260065f8481526020019081526020015f205f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550818373ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92560405160405180910390a4505050565b5f6108a661122c565b90505f670de0b6b3a76400006108ba61097e565b6108c49190611e15565b90505f600190506064816108d661097e565b6108e09190611e56565b1115610921576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161091890611ed3565b60405180910390fd5b34828261092e9190611e15565b111561096f576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161096690611f3b565b60405180910390fd5b6109798382611233565b505050565b5f610987611388565b60035403905090565b61099b83838361138f565b505050565b3373ffffffffffffffffffffffffffffffffffffffff165f5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610a2e576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610a2590611fa3565b60405180910390fd5b606481610a3961097e565b610a439190611e56565b10610a83576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610a7a9061200b565b60405180910390fd5b610a8d3382611233565b50565b606481565b3373ffffffffffffffffffffffffffffffffffffffff165f5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610b23576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610b1a90611fa3565b60405180910390fd5b5f4790503373ffffffffffffffffffffffffffffffffffffffff166108fc8290811502906040515f60405180830381858888f19350505050158015610b6a573d5f5f3e3d5ffd5b5050565b610b8883838360405180602001604052805f815250610f2c565b505050565b3373ffffffffffffffffffffffffffffffffffffffff165f5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610c1b576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610c1290611fa3565b60405180910390fd5b8060029081610c2a9190612226565b5050565b600b5f9054906101000a900460ff1681565b5f5f600143610c4f91906122f5565b90505f813386604051602001610c6793929190612328565b60405160208183030381529060405280519060200120905083815f1c610c8d919061238a565b9250505092915050565b5f610ca182611168565b9050919050565b5f5f610cb3836116ec565b03610cea576040517f8f4eb60400000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b67ffffffffffffffff60055f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054169050919050565b5f5f5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b6009602052805f5260405f205f915054906101000a900460ff1681565b60606040518060400160405280600b81526020017f4d4f4e4b4545524f434b53000000000000000000000000000000000000000000815250905090565b610dc261122c565b73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1603610e26576040517fb06307db00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b8060075f610e3261122c565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f6101000a81548160ff0219169083151502179055508173ffffffffffffffffffffffffffffffffffffffff16610edb61122c565b73ffffffffffffffffffffffffffffffffffffffff167f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c3183604051610f209190611809565b60405180910390a35050565b610f3784848461138f565b50505050565b6060610f4882611148565b610f7e576040517fa14c4b5000000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b5f60028054610f8c90612056565b80601f0160208091040260200160405190810160405280929190818152602001828054610fb890612056565b80156110035780601f10610fda57610100808354040283529160200191611003565b820191905f5260205f20905b815481529060010190602001808311610fe657829003601f168201915b505050505090505f8151036110265760405180602001604052805f815250611051565b80611030846116f5565b6040516020016110419291906124d2565b6040516020818303038152906040525b915050919050565b5f60075f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16905092915050565b5f5f670de0b6b3a76400006110fa61097e565b6111049190611e15565b90508091505090565b600a818154811061111c575f80fd5b905f5260205f20015f915054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b5f81611152611388565b11158015611161575060035482105b9050919050565b5f5f82905080611176611388565b116111f5576003548110156111f4575f60045f8381526020019081526020015f205490505f7c01000000000000000000000000000000000000000000000000000000008216036111f2575b5f81036111e85760045f836001900393508381526020019081526020015f205490506111c1565b8092505050611227565b505b5b6040517fdf2d9b4200000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b919050565b5f33905090565b5f60035490505f8203611272576040517fb562e8dd00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b600160406001901b17820260055f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f828254019250508190555060e16112d46001841461174f565b901b60a042901b6112e4856116ec565b171760045f8381526020019081526020015f20819055505f8190505f83820190505b818060010192508573ffffffffffffffffffffffffffffffffffffffff165f73ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60405160405180910390a4808210611306578160038190555050506113835f848385611758565b505050565b5f5f905090565b5f61139982611168565b90508373ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff1614611400576040517fa114810000000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b5f60065f8481526020019081526020015f205f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1690505f8573ffffffffffffffffffffffffffffffffffffffff1661145461122c565b73ffffffffffffffffffffffffffffffffffffffff16148061148357506114828661147d61122c565b611059565b5b806114c0575061149161122c565b73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff16145b9050806114f9576040517f59c896be00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b5f611503836116ec565b1461153c5760065f8581526020019081526020015f205f6101000a81549073ffffffffffffffffffffffffffffffffffffffff02191690555b60055f8773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8154600190039190508190555060055f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8154600101919050819055507c020000000000000000000000000000000000000000000000000000000060a042901b6115fd876116ec565b171760045f8681526020019081526020015f20819055505f7c020000000000000000000000000000000000000000000000000000000084160361167c575f6001850190505f60045f8381526020019081526020015f20540361167a576003548114611679578360045f8381526020019081526020015f20819055505b5b505b838573ffffffffffffffffffffffffffffffffffffffff168773ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60405160405180910390a46116e48686866001611758565b505050505050565b5f819050919050565b60606080604051019050806040528082600183039250600a81066030018353600a810490505b801561173b57600183039250600a81066030018353600a8104905061171b565b508181036020830392508083525050919050565b5f819050919050565b50505050565b5f604051905090565b5f5ffd5b5f5ffd5b5f7fffffffff0000000000000000000000000000000000000000000000000000000082169050919050565b6117a38161176f565b81146117ad575f5ffd5b50565b5f813590506117be8161179a565b92915050565b5f602082840312156117d9576117d8611767565b5b5f6117e6848285016117b0565b91505092915050565b5f8115159050919050565b611803816117ef565b82525050565b5f60208201905061181c5f8301846117fa565b92915050565b5f81519050919050565b5f82825260208201905092915050565b8281835e5f83830152505050565b5f601f19601f8301169050919050565b5f61186482611822565b61186e818561182c565b935061187e81856020860161183c565b6118878161184a565b840191505092915050565b5f6020820190508181035f8301526118aa818461185a565b905092915050565b5f819050919050565b6118c4816118b2565b81146118ce575f5ffd5b50565b5f813590506118df816118bb565b92915050565b5f602082840312156118fa576118f9611767565b5b5f611907848285016118d1565b91505092915050565b5f73ffffffffffffffffffffffffffffffffffffffff82169050919050565b5f61193982611910565b9050919050565b6119498161192f565b82525050565b5f6020820190506119625f830184611940565b92915050565b6119718161192f565b811461197b575f5ffd5b50565b5f8135905061198c81611968565b92915050565b5f5f604083850312156119a8576119a7611767565b5b5f6119b58582860161197e565b92505060206119c6858286016118d1565b9150509250929050565b6119d9816118b2565b82525050565b5f6020820190506119f25f8301846119d0565b92915050565b5f5f5f60608486031215611a0f57611a0e611767565b5b5f611a1c8682870161197e565b9350506020611a2d8682870161197e565b9250506040611a3e868287016118d1565b9150509250925092565b5f5ffd5b5f5ffd5b7f4e487b71000000000000000000000000000000000000000000000000000000005f52604160045260245ffd5b611a868261184a565b810181811067ffffffffffffffff82111715611aa557611aa4611a50565b5b80604052505050565b5f611ab761175e565b9050611ac38282611a7d565b919050565b5f67ffffffffffffffff821115611ae257611ae1611a50565b5b611aeb8261184a565b9050602081019050919050565b828183375f83830152505050565b5f611b18611b1384611ac8565b611aae565b905082815260208101848484011115611b3457611b33611a4c565b5b611b3f848285611af8565b509392505050565b5f82601f830112611b5b57611b5a611a48565b5b8135611b6b848260208601611b06565b91505092915050565b5f60208284031215611b8957611b88611767565b5b5f82013567ffffffffffffffff811115611ba657611ba561176b565b5b611bb284828501611b47565b91505092915050565b5f5f60408385031215611bd157611bd0611767565b5b5f611bde858286016118d1565b9250506020611bef858286016118d1565b9150509250929050565b5f60208284031215611c0e57611c0d611767565b5b5f611c1b8482850161197e565b91505092915050565b611c2d816117ef565b8114611c37575f5ffd5b50565b5f81359050611c4881611c24565b92915050565b5f5f60408385031215611c6457611c63611767565b5b5f611c718582860161197e565b9250506020611c8285828601611c3a565b9150509250929050565b5f67ffffffffffffffff821115611ca657611ca5611a50565b5b611caf8261184a565b9050602081019050919050565b5f611cce611cc984611c8c565b611aae565b905082815260208101848484011115611cea57611ce9611a4c565b5b611cf5848285611af8565b509392505050565b5f82601f830112611d1157611d10611a48565b5b8135611d21848260208601611cbc565b91505092915050565b5f5f5f5f60808587031215611d4257611d41611767565b5b5f611d4f8782880161197e565b9450506020611d608782880161197e565b9350506040611d71878288016118d1565b925050606085013567ffffffffffffffff811115611d9257611d9161176b565b5b611d9e87828801611cfd565b91505092959194509250565b5f5f60408385031215611dc057611dbf611767565b5b5f611dcd8582860161197e565b9250506020611dde8582860161197e565b9150509250929050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601160045260245ffd5b5f611e1f826118b2565b9150611e2a836118b2565b9250828202611e38816118b2565b91508282048414831517611e4f57611e4e611de8565b5b5092915050565b5f611e60826118b2565b9150611e6b836118b2565b9250828201905080821115611e8357611e82611de8565b5b92915050565b7f536f6c64204f75740000000000000000000000000000000000000000000000005f82015250565b5f611ebd60088361182c565b9150611ec882611e89565b602082019050919050565b5f6020820190508181035f830152611eea81611eb1565b9050919050565b7f56616c756520746f204c6f7700000000000000000000000000000000000000005f82015250565b5f611f25600c8361182c565b9150611f3082611ef1565b602082019050919050565b5f6020820190508181035f830152611f5281611f19565b9050919050565b7f6e6f74204f776e657200000000000000000000000000000000000000000000005f82015250565b5f611f8d60098361182c565b9150611f9882611f59565b602082019050919050565b5f6020820190508181035f830152611fba81611f81565b9050919050565b7f55736564206f6e6c79204f6e63650000000000000000000000000000000000005f82015250565b5f611ff5600e8361182c565b915061200082611fc1565b602082019050919050565b5f6020820190508181035f83015261202281611fe9565b9050919050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52602260045260245ffd5b5f600282049050600182168061206d57607f821691505b6020821081036120805761207f612029565b5b50919050565b5f819050815f5260205f209050919050565b5f6020601f8301049050919050565b5f82821b905092915050565b5f600883026120e27fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff826120a7565b6120ec86836120a7565b95508019841693508086168417925050509392505050565b5f819050919050565b5f61212761212261211d846118b2565b612104565b6118b2565b9050919050565b5f819050919050565b6121408361210d565b61215461214c8261212e565b8484546120b3565b825550505050565b5f5f905090565b61216b61215c565b612176818484612137565b505050565b5b818110156121995761218e5f82612163565b60018101905061217c565b5050565b601f8211156121de576121af81612086565b6121b884612098565b810160208510156121c7578190505b6121db6121d385612098565b83018261217b565b50505b505050565b5f82821c905092915050565b5f6121fe5f19846008026121e3565b1980831691505092915050565b5f61221683836121ef565b9150826002028217905092915050565b61222f82611822565b67ffffffffffffffff81111561224857612247611a50565b5b6122528254612056565b61225d82828561219d565b5f60209050601f83116001811461228e575f841561227c578287015190505b612286858261220b565b8655506122ed565b601f19841661229c86612086565b5f5b828110156122c35784890151825560018201915060208501945060208101905061229e565b868310156122e057848901516122dc601f8916826121ef565b8355505b6001600288020188555050505b505050505050565b5f6122ff826118b2565b915061230a836118b2565b925082820390508181111561232257612321611de8565b5b92915050565b5f60608201905061233b5f8301866119d0565b6123486020830185611940565b61235560408301846119d0565b949350505050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601260045260245ffd5b5f612394826118b2565b915061239f836118b2565b9250826123af576123ae61235d565b5b828206905092915050565b5f81905092915050565b7f697066733a2f2f000000000000000000000000000000000000000000000000005f82015250565b5f6123f86007836123ba565b9150612403826123c4565b600782019050919050565b5f61241882611822565b61242281856123ba565b935061243281856020860161183c565b80840191505092915050565b7f2f000000000000000000000000000000000000000000000000000000000000005f82015250565b5f6124726001836123ba565b915061247d8261243e565b600182019050919050565b7f2e6a736f6e0000000000000000000000000000000000000000000000000000005f82015250565b5f6124bc6005836123ba565b91506124c782612488565b600582019050919050565b5f6124dc826123ec565b91506124e8828561240e565b91506124f382612466565b91506124ff828461240e565b915061250a826124b0565b9150819050939250505056fea26469706673582212203cd746104ca32d5dfd88a4c1e8654556a0dee56b959fd731df76e45d7c80459064736f6c634300081c0033516d4e55614c69507145686f33357866587969706f3232735a50384a546f377a6833645244455676585542383967
Deployed Bytecode
0x608060405260043610610165575f3560e01c80634dd08f82116100d057806395d89b4111610089578063c87b56dd11610063578063c87b56dd14610505578063e985e9c514610541578063ef9089d61461057d578063f14695ae146105a757610165565b806395d89b411461048b578063a22cb465146104b5578063b88d4fde146104dd57610165565b80634dd08f8214610347578063609526c2146103715780636352211e146103ad57806370a08231146103e95780638da5cb5b146104255780638ef1e2591461044f57610165565b806323b872dd1161012257806323b872dd146102675780632fbba1151461028f57806332cb6b0c146102b75780633ccfd60b146102e157806342842e0e146102f757806347064d6a1461031f57610165565b806301ffc9a71461016957806306fdde03146101a5578063081812fc146101cf578063095ea7b31461020b5780631249c58b1461023357806318160ddd1461023d575b5f5ffd5b348015610174575f5ffd5b5061018f600480360381019061018a91906117c4565b6105e3565b60405161019c9190611809565b60405180910390f35b3480156101b0575f5ffd5b506101b9610674565b6040516101c69190611892565b60405180910390f35b3480156101da575f5ffd5b506101f560048036038101906101f091906118e5565b6106b1565b604051610202919061194f565b60405180910390f35b348015610216575f5ffd5b50610231600480360381019061022c9190611992565b610729565b005b61023b61089d565b005b348015610248575f5ffd5b5061025161097e565b60405161025e91906119df565b60405180910390f35b348015610272575f5ffd5b5061028d600480360381019061028891906119f8565b610990565b005b34801561029a575f5ffd5b506102b560048036038101906102b091906118e5565b6109a0565b005b3480156102c2575f5ffd5b506102cb610a90565b6040516102d891906119df565b60405180910390f35b3480156102ec575f5ffd5b506102f5610a95565b005b348015610302575f5ffd5b5061031d600480360381019061031891906119f8565b610b6e565b005b34801561032a575f5ffd5b5061034560048036038101906103409190611b74565b610b8d565b005b348015610352575f5ffd5b5061035b610c2e565b6040516103689190611809565b60405180910390f35b34801561037c575f5ffd5b5061039760048036038101906103929190611bbb565b610c40565b6040516103a491906119df565b60405180910390f35b3480156103b8575f5ffd5b506103d360048036038101906103ce91906118e5565b610c97565b6040516103e0919061194f565b60405180910390f35b3480156103f4575f5ffd5b5061040f600480360381019061040a9190611bf9565b610ca8565b60405161041c91906119df565b60405180910390f35b348015610430575f5ffd5b50610439610d39565b604051610446919061194f565b60405180910390f35b34801561045a575f5ffd5b5061047560048036038101906104709190611bf9565b610d60565b6040516104829190611809565b60405180910390f35b348015610496575f5ffd5b5061049f610d7d565b6040516104ac9190611892565b60405180910390f35b3480156104c0575f5ffd5b506104db60048036038101906104d69190611c4e565b610dba565b005b3480156104e8575f5ffd5b5061050360048036038101906104fe9190611d2a565b610f2c565b005b348015610510575f5ffd5b5061052b600480360381019061052691906118e5565b610f3d565b6040516105389190611892565b60405180910390f35b34801561054c575f5ffd5b5061056760048036038101906105629190611daa565b611059565b6040516105749190611809565b60405180910390f35b348015610588575f5ffd5b506105916110e7565b60405161059e91906119df565b60405180910390f35b3480156105b2575f5ffd5b506105cd60048036038101906105c891906118e5565b61110d565b6040516105da919061194f565b60405180910390f35b5f6301ffc9a760e01b827bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916148061063d57506380ac58cd60e01b827bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916145b8061066d5750635b5e139f60e01b827bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916145b9050919050565b60606040518060400160405280600b81526020017f4d4f4e4b4545524f434b53000000000000000000000000000000000000000000815250905090565b5f6106bb82611148565b6106f1576040517fcf4700e400000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b60065f8381526020019081526020015f205f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff169050919050565b5f61073382611168565b90508073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff160361076c575f5ffd5b8073ffffffffffffffffffffffffffffffffffffffff1661078b61122c565b73ffffffffffffffffffffffffffffffffffffffff16146107ee576107b7816107b261122c565b611059565b6107ed576040517fcfb3b94200000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b5b8260065f8481526020019081526020015f205f6101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550818373ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92560405160405180910390a4505050565b5f6108a661122c565b90505f670de0b6b3a76400006108ba61097e565b6108c49190611e15565b90505f600190506064816108d661097e565b6108e09190611e56565b1115610921576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161091890611ed3565b60405180910390fd5b34828261092e9190611e15565b111561096f576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161096690611f3b565b60405180910390fd5b6109798382611233565b505050565b5f610987611388565b60035403905090565b61099b83838361138f565b505050565b3373ffffffffffffffffffffffffffffffffffffffff165f5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610a2e576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610a2590611fa3565b60405180910390fd5b606481610a3961097e565b610a439190611e56565b10610a83576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610a7a9061200b565b60405180910390fd5b610a8d3382611233565b50565b606481565b3373ffffffffffffffffffffffffffffffffffffffff165f5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610b23576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610b1a90611fa3565b60405180910390fd5b5f4790503373ffffffffffffffffffffffffffffffffffffffff166108fc8290811502906040515f60405180830381858888f19350505050158015610b6a573d5f5f3e3d5ffd5b5050565b610b8883838360405180602001604052805f815250610f2c565b505050565b3373ffffffffffffffffffffffffffffffffffffffff165f5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614610c1b576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610c1290611fa3565b60405180910390fd5b8060029081610c2a9190612226565b5050565b600b5f9054906101000a900460ff1681565b5f5f600143610c4f91906122f5565b90505f813386604051602001610c6793929190612328565b60405160208183030381529060405280519060200120905083815f1c610c8d919061238a565b9250505092915050565b5f610ca182611168565b9050919050565b5f5f610cb3836116ec565b03610cea576040517f8f4eb60400000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b67ffffffffffffffff60055f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f2054169050919050565b5f5f5f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b6009602052805f5260405f205f915054906101000a900460ff1681565b60606040518060400160405280600b81526020017f4d4f4e4b4545524f434b53000000000000000000000000000000000000000000815250905090565b610dc261122c565b73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1603610e26576040517fb06307db00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b8060075f610e3261122c565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f6101000a81548160ff0219169083151502179055508173ffffffffffffffffffffffffffffffffffffffff16610edb61122c565b73ffffffffffffffffffffffffffffffffffffffff167f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c3183604051610f209190611809565b60405180910390a35050565b610f3784848461138f565b50505050565b6060610f4882611148565b610f7e576040517fa14c4b5000000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b5f60028054610f8c90612056565b80601f0160208091040260200160405190810160405280929190818152602001828054610fb890612056565b80156110035780601f10610fda57610100808354040283529160200191611003565b820191905f5260205f20905b815481529060010190602001808311610fe657829003601f168201915b505050505090505f8151036110265760405180602001604052805f815250611051565b80611030846116f5565b6040516020016110419291906124d2565b6040516020818303038152906040525b915050919050565b5f60075f8473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f9054906101000a900460ff16905092915050565b5f5f670de0b6b3a76400006110fa61097e565b6111049190611e15565b90508091505090565b600a818154811061111c575f80fd5b905f5260205f20015f915054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b5f81611152611388565b11158015611161575060035482105b9050919050565b5f5f82905080611176611388565b116111f5576003548110156111f4575f60045f8381526020019081526020015f205490505f7c01000000000000000000000000000000000000000000000000000000008216036111f2575b5f81036111e85760045f836001900393508381526020019081526020015f205490506111c1565b8092505050611227565b505b5b6040517fdf2d9b4200000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b919050565b5f33905090565b5f60035490505f8203611272576040517fb562e8dd00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b600160406001901b17820260055f8573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f828254019250508190555060e16112d46001841461174f565b901b60a042901b6112e4856116ec565b171760045f8381526020019081526020015f20819055505f8190505f83820190505b818060010192508573ffffffffffffffffffffffffffffffffffffffff165f73ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60405160405180910390a4808210611306578160038190555050506113835f848385611758565b505050565b5f5f905090565b5f61139982611168565b90508373ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff1614611400576040517fa114810000000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b5f60065f8481526020019081526020015f205f9054906101000a900473ffffffffffffffffffffffffffffffffffffffff1690505f8573ffffffffffffffffffffffffffffffffffffffff1661145461122c565b73ffffffffffffffffffffffffffffffffffffffff16148061148357506114828661147d61122c565b611059565b5b806114c0575061149161122c565b73ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff16145b9050806114f9576040517f59c896be00000000000000000000000000000000000000000000000000000000815260040160405180910390fd5b5f611503836116ec565b1461153c5760065f8581526020019081526020015f205f6101000a81549073ffffffffffffffffffffffffffffffffffffffff02191690555b60055f8773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8154600190039190508190555060055f8673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020015f205f8154600101919050819055507c020000000000000000000000000000000000000000000000000000000060a042901b6115fd876116ec565b171760045f8681526020019081526020015f20819055505f7c020000000000000000000000000000000000000000000000000000000084160361167c575f6001850190505f60045f8381526020019081526020015f20540361167a576003548114611679578360045f8381526020019081526020015f20819055505b5b505b838573ffffffffffffffffffffffffffffffffffffffff168773ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60405160405180910390a46116e48686866001611758565b505050505050565b5f819050919050565b60606080604051019050806040528082600183039250600a81066030018353600a810490505b801561173b57600183039250600a81066030018353600a8104905061171b565b508181036020830392508083525050919050565b5f819050919050565b50505050565b5f604051905090565b5f5ffd5b5f5ffd5b5f7fffffffff0000000000000000000000000000000000000000000000000000000082169050919050565b6117a38161176f565b81146117ad575f5ffd5b50565b5f813590506117be8161179a565b92915050565b5f602082840312156117d9576117d8611767565b5b5f6117e6848285016117b0565b91505092915050565b5f8115159050919050565b611803816117ef565b82525050565b5f60208201905061181c5f8301846117fa565b92915050565b5f81519050919050565b5f82825260208201905092915050565b8281835e5f83830152505050565b5f601f19601f8301169050919050565b5f61186482611822565b61186e818561182c565b935061187e81856020860161183c565b6118878161184a565b840191505092915050565b5f6020820190508181035f8301526118aa818461185a565b905092915050565b5f819050919050565b6118c4816118b2565b81146118ce575f5ffd5b50565b5f813590506118df816118bb565b92915050565b5f602082840312156118fa576118f9611767565b5b5f611907848285016118d1565b91505092915050565b5f73ffffffffffffffffffffffffffffffffffffffff82169050919050565b5f61193982611910565b9050919050565b6119498161192f565b82525050565b5f6020820190506119625f830184611940565b92915050565b6119718161192f565b811461197b575f5ffd5b50565b5f8135905061198c81611968565b92915050565b5f5f604083850312156119a8576119a7611767565b5b5f6119b58582860161197e565b92505060206119c6858286016118d1565b9150509250929050565b6119d9816118b2565b82525050565b5f6020820190506119f25f8301846119d0565b92915050565b5f5f5f60608486031215611a0f57611a0e611767565b5b5f611a1c8682870161197e565b9350506020611a2d8682870161197e565b9250506040611a3e868287016118d1565b9150509250925092565b5f5ffd5b5f5ffd5b7f4e487b71000000000000000000000000000000000000000000000000000000005f52604160045260245ffd5b611a868261184a565b810181811067ffffffffffffffff82111715611aa557611aa4611a50565b5b80604052505050565b5f611ab761175e565b9050611ac38282611a7d565b919050565b5f67ffffffffffffffff821115611ae257611ae1611a50565b5b611aeb8261184a565b9050602081019050919050565b828183375f83830152505050565b5f611b18611b1384611ac8565b611aae565b905082815260208101848484011115611b3457611b33611a4c565b5b611b3f848285611af8565b509392505050565b5f82601f830112611b5b57611b5a611a48565b5b8135611b6b848260208601611b06565b91505092915050565b5f60208284031215611b8957611b88611767565b5b5f82013567ffffffffffffffff811115611ba657611ba561176b565b5b611bb284828501611b47565b91505092915050565b5f5f60408385031215611bd157611bd0611767565b5b5f611bde858286016118d1565b9250506020611bef858286016118d1565b9150509250929050565b5f60208284031215611c0e57611c0d611767565b5b5f611c1b8482850161197e565b91505092915050565b611c2d816117ef565b8114611c37575f5ffd5b50565b5f81359050611c4881611c24565b92915050565b5f5f60408385031215611c6457611c63611767565b5b5f611c718582860161197e565b9250506020611c8285828601611c3a565b9150509250929050565b5f67ffffffffffffffff821115611ca657611ca5611a50565b5b611caf8261184a565b9050602081019050919050565b5f611cce611cc984611c8c565b611aae565b905082815260208101848484011115611cea57611ce9611a4c565b5b611cf5848285611af8565b509392505050565b5f82601f830112611d1157611d10611a48565b5b8135611d21848260208601611cbc565b91505092915050565b5f5f5f5f60808587031215611d4257611d41611767565b5b5f611d4f8782880161197e565b9450506020611d608782880161197e565b9350506040611d71878288016118d1565b925050606085013567ffffffffffffffff811115611d9257611d9161176b565b5b611d9e87828801611cfd565b91505092959194509250565b5f5f60408385031215611dc057611dbf611767565b5b5f611dcd8582860161197e565b9250506020611dde8582860161197e565b9150509250929050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601160045260245ffd5b5f611e1f826118b2565b9150611e2a836118b2565b9250828202611e38816118b2565b91508282048414831517611e4f57611e4e611de8565b5b5092915050565b5f611e60826118b2565b9150611e6b836118b2565b9250828201905080821115611e8357611e82611de8565b5b92915050565b7f536f6c64204f75740000000000000000000000000000000000000000000000005f82015250565b5f611ebd60088361182c565b9150611ec882611e89565b602082019050919050565b5f6020820190508181035f830152611eea81611eb1565b9050919050565b7f56616c756520746f204c6f7700000000000000000000000000000000000000005f82015250565b5f611f25600c8361182c565b9150611f3082611ef1565b602082019050919050565b5f6020820190508181035f830152611f5281611f19565b9050919050565b7f6e6f74204f776e657200000000000000000000000000000000000000000000005f82015250565b5f611f8d60098361182c565b9150611f9882611f59565b602082019050919050565b5f6020820190508181035f830152611fba81611f81565b9050919050565b7f55736564206f6e6c79204f6e63650000000000000000000000000000000000005f82015250565b5f611ff5600e8361182c565b915061200082611fc1565b602082019050919050565b5f6020820190508181035f83015261202281611fe9565b9050919050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52602260045260245ffd5b5f600282049050600182168061206d57607f821691505b6020821081036120805761207f612029565b5b50919050565b5f819050815f5260205f209050919050565b5f6020601f8301049050919050565b5f82821b905092915050565b5f600883026120e27fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff826120a7565b6120ec86836120a7565b95508019841693508086168417925050509392505050565b5f819050919050565b5f61212761212261211d846118b2565b612104565b6118b2565b9050919050565b5f819050919050565b6121408361210d565b61215461214c8261212e565b8484546120b3565b825550505050565b5f5f905090565b61216b61215c565b612176818484612137565b505050565b5b818110156121995761218e5f82612163565b60018101905061217c565b5050565b601f8211156121de576121af81612086565b6121b884612098565b810160208510156121c7578190505b6121db6121d385612098565b83018261217b565b50505b505050565b5f82821c905092915050565b5f6121fe5f19846008026121e3565b1980831691505092915050565b5f61221683836121ef565b9150826002028217905092915050565b61222f82611822565b67ffffffffffffffff81111561224857612247611a50565b5b6122528254612056565b61225d82828561219d565b5f60209050601f83116001811461228e575f841561227c578287015190505b612286858261220b565b8655506122ed565b601f19841661229c86612086565b5f5b828110156122c35784890151825560018201915060208501945060208101905061229e565b868310156122e057848901516122dc601f8916826121ef565b8355505b6001600288020188555050505b505050505050565b5f6122ff826118b2565b915061230a836118b2565b925082820390508181111561232257612321611de8565b5b92915050565b5f60608201905061233b5f8301866119d0565b6123486020830185611940565b61235560408301846119d0565b949350505050565b7f4e487b71000000000000000000000000000000000000000000000000000000005f52601260045260245ffd5b5f612394826118b2565b915061239f836118b2565b9250826123af576123ae61235d565b5b828206905092915050565b5f81905092915050565b7f697066733a2f2f000000000000000000000000000000000000000000000000005f82015250565b5f6123f86007836123ba565b9150612403826123c4565b600782019050919050565b5f61241882611822565b61242281856123ba565b935061243281856020860161183c565b80840191505092915050565b7f2f000000000000000000000000000000000000000000000000000000000000005f82015250565b5f6124726001836123ba565b915061247d8261243e565b600182019050919050565b7f2e6a736f6e0000000000000000000000000000000000000000000000000000005f82015250565b5f6124bc6005836123ba565b91506124c782612488565b600582019050919050565b5f6124dc826123ec565b91506124e8828561240e565b91506124f382612466565b91506124ff828461240e565b915061250a826124b0565b9150819050939250505056fea26469706673582212203cd746104ca32d5dfd88a4c1e8654556a0dee56b959fd731df76e45d7c80459064736f6c634300081c0033
Deployed Bytecode Sourcemap
15573:21897:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;20316:615;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;24523:100;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;26190:204;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;25673:451;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;16245:343;;;:::i;:::-;;19559:300;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;27076:190;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;36946:169;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;15799:40;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;37322:145;;;;;;;;;;;;;:::i;:::-;;27337:205;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;18848:91;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;36907:32;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;36591:308;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;24312:144;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;20995:234;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;15678:77;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;30405:39;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;24692:104;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;26466:308;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;27613:227;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;24810:339;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;26845:164;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;16097:140;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;30451:22;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;20316:615;20401:4;20716:10;20701:25;;:11;:25;;;;:102;;;;20793:10;20778:25;;:11;:25;;;;20701:102;:179;;;;20870:10;20855:25;;:11;:25;;;;20701:179;20681:199;;20316:615;;;:::o;24523:100::-;24577:13;24610:5;;;;;;;;;;;;;;;;;24603:12;;24523:100;:::o;26190:204::-;26258:7;26283:16;26291:7;26283;:16::i;:::-;26278:64;;26308:34;;;;;;;;;;;;;;26278:64;26362:15;:24;26378:7;26362:24;;;;;;;;;;;;;;;;;;;;;26355:31;;26190:204;;;:::o;25673:451::-;25746:13;25778:27;25797:7;25778:18;:27::i;:::-;25746:61;;25828:5;25822:11;;:2;:11;;;25818:25;;25835:8;;;25818:25;25883:5;25860:28;;:19;:17;:19::i;:::-;:28;;;25856:175;;25908:44;25925:5;25932:19;:17;:19::i;:::-;25908:16;:44::i;:::-;25903:128;;25980:35;;;;;;;;;;;;;;25903:128;25856:175;26070:2;26043:15;:24;26059:7;26043:24;;;;;;;;;;;;:29;;;;;;;;;;;;;;;;;;26108:7;26104:2;26088:28;;26097:5;26088:28;;;;;;;;;;;;25735:389;25673:451;;:::o;16245:343::-;16288:15;16306:19;:17;:19::i;:::-;16288:37;;16336:12;16367:19;16351:13;:11;:13::i;:::-;:35;;;;:::i;:::-;16336:50;;16397:14;16414:1;16397:18;;15836:3;16452:6;16436:13;:11;:13::i;:::-;:22;;;;:::i;:::-;:36;;16428:57;;;;;;;;;;;;:::i;:::-;;;;;;;;;16519:9;16511:4;16504:6;:11;;;;:::i;:::-;:24;;16496:49;;;;;;;;;;;;:::i;:::-;;;;;;;;;16558:22;16564:7;16573:6;16558:5;:22::i;:::-;16277:311;;;16245:343::o;19559:300::-;19612:7;19825:15;:13;:15::i;:::-;19809:13;;:31;19802:38;;19559:300;:::o;27076:190::-;27230:28;27240:4;27246:2;27250:7;27230:9;:28::i;:::-;27076:190;;;:::o;36946:169::-;37172:10;37164:18;;:6;;;;;;;;;;;:18;;;37156:40;;;;;;;;;;;;:::i;:::-;;;;;;;;;15836:3:::1;37033:6;37017:13;:11;:13::i;:::-;:22;;;;:::i;:::-;:35;37009:62;;;;;;;;;;;;:::i;:::-;;;;;;;;;37082:25;37088:10;37100:6;37082:5;:25::i;:::-;36946:169:::0;:::o;15799:40::-;15836:3;15799:40;:::o;37322:145::-;37172:10;37164:18;;:6;;;;;;;;;;;:18;;;37156:40;;;;;;;;;;;;:::i;:::-;;;;;;;;;37372:15:::1;37390:21;37372:39;;37430:10;37422:28;;:37;37451:7;37422:37;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;37361:106;37322:145::o:0;27337:205::-;27495:39;27512:4;27518:2;27522:7;27495:39;;;;;;;;;;;;:16;:39::i;:::-;27337:205;;;:::o;18848:91::-;37172:10;37164:18;;:6;;;;;;;;;;;:18;;;37156:40;;;;;;;;;;;;:::i;:::-;;;;;;;;;18926:5:::1;18915:8;:16;;;;;;:::i;:::-;;18848:91:::0;:::o;36907:32::-;;;;;;;;;;;;;:::o;36591:308::-;36672:7;36692:19;36729:1;36714:12;:16;;;;:::i;:::-;36692:38;;36774:17;36815:11;36828:10;36840:7;36804:44;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;36794:55;;;;;;36774:75;;36888:3;36875:9;36867:18;;:24;;;;:::i;:::-;36860:31;;;;36591:308;;;;:::o;24312:144::-;24376:7;24419:27;24438:7;24419:18;:27::i;:::-;24396:52;;24312:144;;;:::o;20995:234::-;21059:7;21111:1;21083:24;21101:5;21083:17;:24::i;:::-;:29;21079:70;;21121:28;;;;;;;;;;;;;;21079:70;16699:13;21167:18;:25;21186:5;21167:25;;;;;;;;;;;;;;;;:54;21160:61;;20995:234;;;:::o;15678:77::-;15715:7;15741:6;;;;;;;;;;;15734:13;;15678:77;:::o;30405:39::-;;;;;;;;;;;;;;;;;;;;;;:::o;24692:104::-;24748:13;24781:7;;;;;;;;;;;;;;;;;24774:14;;24692:104;:::o;26466:308::-;26577:19;:17;:19::i;:::-;26565:31;;:8;:31;;;26561:61;;26605:17;;;;;;;;;;;;;;26561:61;26687:8;26635:18;:39;26654:19;:17;:19::i;:::-;26635:39;;;;;;;;;;;;;;;:49;26675:8;26635:49;;;;;;;;;;;;;;;;:60;;;;;;;;;;;;;;;;;;26747:8;26711:55;;26726:19;:17;:19::i;:::-;26711:55;;;26757:8;26711:55;;;;;;:::i;:::-;;;;;;;;26466:308;;:::o;27613:227::-;27804:28;27814:4;27820:2;27824:7;27804:9;:28::i;:::-;27613:227;;;;:::o;24810:339::-;24883:13;24914:16;24922:7;24914;:16::i;:::-;24909:59;;24939:29;;;;;;;;;;;;;;24909:59;24979:21;25003:8;24979:32;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;25054:1;25035:7;25029:21;:26;:112;;;;;;;;;;;;;;;;;25093:7;25107:18;25117:7;25107:9;:18::i;:::-;25065:70;;;;;;;;;:::i;:::-;;;;;;;;;;;;;25029:112;25022:119;;;24810:339;;;:::o;26845:164::-;26942:4;26966:18;:25;26985:5;26966:25;;;;;;;;;;;;;;;:35;26992:8;26966:35;;;;;;;;;;;;;;;;;;;;;;;;;26959:42;;26845:164;;;;:::o;16097:140::-;16138:7;16157:12;16188:19;16172:13;:11;:13::i;:::-;:35;;;;:::i;:::-;16157:50;;16225:4;16218:11;;;16097:140;:::o;30451:22::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::o;28095:168::-;28152:4;28208:7;28189:15;:13;:15::i;:::-;:26;;:66;;;;;28242:13;;28232:7;:23;28189:66;28169:86;;28095:168;;;:::o;21827:1129::-;21894:7;21914:12;21929:7;21914:22;;21997:4;21978:15;:13;:15::i;:::-;:23;21974:915;;22031:13;;22024:4;:20;22020:869;;;22069:14;22086:17;:23;22104:4;22086:23;;;;;;;;;;;;22069:40;;22202:1;17469:8;22175:6;:23;:28;22171:699;;22694:113;22711:1;22701:6;:11;22694:113;;22754:17;:25;22772:6;;;;;;;22754:25;;;;;;;;;;;;22745:34;;22694:113;;;22840:6;22833:13;;;;;;22171:699;22046:843;22020:869;21974:915;22917:31;;;;;;;;;;;;;;21827:1129;;;;:::o;34490:105::-;34550:7;34577:10;34570:17;;34490:105;:::o;28528:1596::-;28593:20;28616:13;;28593:36;;28727:1;28715:8;:13;28711:44;;28737:18;;;;;;;;;;;;;;28711:44;29300:1;16836:2;29271:1;:25;;29270:31;29258:8;:44;29232:18;:22;29251:2;29232:22;;;;;;;;;;;;;;;;:70;;;;;;;;;;;17612:3;29701:29;29728:1;29716:8;:13;29701:14;:29::i;:::-;:56;;17353:3;29638:15;:41;;29596:21;29614:2;29596:17;:21::i;:::-;:84;:162;29545:17;:31;29563:12;29545:31;;;;;;;;;;;:213;;;;29775:20;29798:12;29775:35;;29825:11;29854:8;29839:12;:23;29825:37;;29879:111;29931:14;;;;;;29927:2;29906:40;;29923:1;29906:40;;;;;;;;;;;;29985:3;29970:12;:18;29879:111;;30022:12;30006:13;:28;;;;29009:1037;;30056:60;30085:1;30089:2;30093:12;30107:8;30056:20;:60::i;:::-;28582:1542;28528:1596;;:::o;19082:92::-;19138:7;19165:1;19158:8;;19082:92;:::o;30480:2561::-;30621:27;30651;30670:7;30651:18;:27::i;:::-;30621:57;;30736:4;30695:45;;30711:19;30695:45;;;30691:86;;30749:28;;;;;;;;;;;;;;30691:86;30790:23;30816:15;:24;30832:7;30816:24;;;;;;;;;;;;;;;;;;;;;30790:50;;30853:22;30902:4;30879:27;;:19;:17;:19::i;:::-;:27;;;:91;;;;30927:43;30944:4;30950:19;:17;:19::i;:::-;30927:16;:43::i;:::-;30879:91;:150;;;;31010:19;:17;:19::i;:::-;30991:38;;:15;:38;;;30879:150;30853:177;;31048:17;31043:66;;31074:35;;;;;;;;;;;;;;31043:66;31219:1;31181:34;31199:15;31181:17;:34::i;:::-;:39;31177:103;;31244:15;:24;31260:7;31244:24;;;;;;;;;;;;31237:31;;;;;;;;;;;31177:103;31647:18;:24;31666:4;31647:24;;;;;;;;;;;;;;;;31645:26;;;;;;;;;;;;31716:18;:22;31735:2;31716:22;;;;;;;;;;;;;;;;31714:24;;;;;;;;;;;17747:8;17353:3;32097:15;:41;;32055:21;32073:2;32055:17;:21::i;:::-;:84;:128;32009:17;:26;32027:7;32009:26;;;;;;;;;;;:174;;;;32353:1;17747:8;32303:19;:46;:51;32299:626;;32375:19;32407:1;32397:7;:11;32375:33;;32564:1;32530:17;:30;32548:11;32530:30;;;;;;;;;;;;:35;32526:384;;32668:13;;32653:11;:28;32649:242;;32848:19;32815:17;:30;32833:11;32815:30;;;;;;;;;;;:52;;;;32649:242;32526:384;32356:569;32299:626;32972:7;32968:2;32953:27;;32962:4;32953:27;;;;;;;;;;;;32991:42;33012:4;33018:2;33022:7;33031:1;32991:20;:42::i;:::-;30604:2437;;;30480:2561;;;:::o;25234:148::-;25298:14;25359:5;25349:15;;25234:148;;;:::o;34701:1882::-;34758:17;35179:3;35172:4;35166:11;35162:21;35155:28;;35266:3;35260:4;35253:17;35366:3;35802:5;35934:1;35929:3;35925:11;35918:18;;36073:2;36067:4;36063:13;36059:2;36055:22;36050:3;36042:36;36115:2;36109:4;36105:13;36097:21;;35699:661;36131:4;35699:661;;;36299:1;36294:3;36290:11;36283:18;;36343:2;36337:4;36333:13;36329:2;36325:22;36320:3;36312:36;36216:2;36210:4;36206:13;36198:21;;35699:661;;;35703:427;36392:3;36387;36383:13;36501:2;36496:3;36492:12;36485:19;;36558:6;36553:3;36546:19;34797:1779;;34701:1882;;;:::o;25469:142::-;25527:14;25588:5;25578:15;;25469:142;;;:::o;34072:213::-;;;;;:::o;7:75:1:-;40:6;73:2;67:9;57:19;;7:75;:::o;88:117::-;197:1;194;187:12;211:117;320:1;317;310:12;334:149;370:7;410:66;403:5;399:78;388:89;;334:149;;;:::o;489:120::-;561:23;578:5;561:23;:::i;:::-;554:5;551:34;541:62;;599:1;596;589:12;541:62;489:120;:::o;615:137::-;660:5;698:6;685:20;676:29;;714:32;740:5;714:32;:::i;:::-;615:137;;;;:::o;758:327::-;816:6;865:2;853:9;844:7;840:23;836:32;833:119;;;871:79;;:::i;:::-;833:119;991:1;1016:52;1060:7;1051:6;1040:9;1036:22;1016:52;:::i;:::-;1006:62;;962:116;758:327;;;;:::o;1091:90::-;1125:7;1168:5;1161:13;1154:21;1143:32;;1091:90;;;:::o;1187:109::-;1268:21;1283:5;1268:21;:::i;:::-;1263:3;1256:34;1187:109;;:::o;1302:210::-;1389:4;1427:2;1416:9;1412:18;1404:26;;1440:65;1502:1;1491:9;1487:17;1478:6;1440:65;:::i;:::-;1302:210;;;;:::o;1518:99::-;1570:6;1604:5;1598:12;1588:22;;1518:99;;;:::o;1623:169::-;1707:11;1741:6;1736:3;1729:19;1781:4;1776:3;1772:14;1757:29;;1623:169;;;;:::o;1798:139::-;1887:6;1882:3;1877;1871:23;1928:1;1919:6;1914:3;1910:16;1903:27;1798:139;;;:::o;1943:102::-;1984:6;2035:2;2031:7;2026:2;2019:5;2015:14;2011:28;2001:38;;1943:102;;;:::o;2051:377::-;2139:3;2167:39;2200:5;2167:39;:::i;:::-;2222:71;2286:6;2281:3;2222:71;:::i;:::-;2215:78;;2302:65;2360:6;2355:3;2348:4;2341:5;2337:16;2302:65;:::i;:::-;2392:29;2414:6;2392:29;:::i;:::-;2387:3;2383:39;2376:46;;2143:285;2051:377;;;;:::o;2434:313::-;2547:4;2585:2;2574:9;2570:18;2562:26;;2634:9;2628:4;2624:20;2620:1;2609:9;2605:17;2598:47;2662:78;2735:4;2726:6;2662:78;:::i;:::-;2654:86;;2434:313;;;;:::o;2753:77::-;2790:7;2819:5;2808:16;;2753:77;;;:::o;2836:122::-;2909:24;2927:5;2909:24;:::i;:::-;2902:5;2899:35;2889:63;;2948:1;2945;2938:12;2889:63;2836:122;:::o;2964:139::-;3010:5;3048:6;3035:20;3026:29;;3064:33;3091:5;3064:33;:::i;:::-;2964:139;;;;:::o;3109:329::-;3168:6;3217:2;3205:9;3196:7;3192:23;3188:32;3185:119;;;3223:79;;:::i;:::-;3185:119;3343:1;3368:53;3413:7;3404:6;3393:9;3389:22;3368:53;:::i;:::-;3358:63;;3314:117;3109:329;;;;:::o;3444:126::-;3481:7;3521:42;3514:5;3510:54;3499:65;;3444:126;;;:::o;3576:96::-;3613:7;3642:24;3660:5;3642:24;:::i;:::-;3631:35;;3576:96;;;:::o;3678:118::-;3765:24;3783:5;3765:24;:::i;:::-;3760:3;3753:37;3678:118;;:::o;3802:222::-;3895:4;3933:2;3922:9;3918:18;3910:26;;3946:71;4014:1;4003:9;3999:17;3990:6;3946:71;:::i;:::-;3802:222;;;;:::o;4030:122::-;4103:24;4121:5;4103:24;:::i;:::-;4096:5;4093:35;4083:63;;4142:1;4139;4132:12;4083:63;4030:122;:::o;4158:139::-;4204:5;4242:6;4229:20;4220:29;;4258:33;4285:5;4258:33;:::i;:::-;4158:139;;;;:::o;4303:474::-;4371:6;4379;4428:2;4416:9;4407:7;4403:23;4399:32;4396:119;;;4434:79;;:::i;:::-;4396:119;4554:1;4579:53;4624:7;4615:6;4604:9;4600:22;4579:53;:::i;:::-;4569:63;;4525:117;4681:2;4707:53;4752:7;4743:6;4732:9;4728:22;4707:53;:::i;:::-;4697:63;;4652:118;4303:474;;;;;:::o;4783:118::-;4870:24;4888:5;4870:24;:::i;:::-;4865:3;4858:37;4783:118;;:::o;4907:222::-;5000:4;5038:2;5027:9;5023:18;5015:26;;5051:71;5119:1;5108:9;5104:17;5095:6;5051:71;:::i;:::-;4907:222;;;;:::o;5135:619::-;5212:6;5220;5228;5277:2;5265:9;5256:7;5252:23;5248:32;5245:119;;;5283:79;;:::i;:::-;5245:119;5403:1;5428:53;5473:7;5464:6;5453:9;5449:22;5428:53;:::i;:::-;5418:63;;5374:117;5530:2;5556:53;5601:7;5592:6;5581:9;5577:22;5556:53;:::i;:::-;5546:63;;5501:118;5658:2;5684:53;5729:7;5720:6;5709:9;5705:22;5684:53;:::i;:::-;5674:63;;5629:118;5135:619;;;;;:::o;5760:117::-;5869:1;5866;5859:12;5883:117;5992:1;5989;5982:12;6006:180;6054:77;6051:1;6044:88;6151:4;6148:1;6141:15;6175:4;6172:1;6165:15;6192:281;6275:27;6297:4;6275:27;:::i;:::-;6267:6;6263:40;6405:6;6393:10;6390:22;6369:18;6357:10;6354:34;6351:62;6348:88;;;6416:18;;:::i;:::-;6348:88;6456:10;6452:2;6445:22;6235:238;6192:281;;:::o;6479:129::-;6513:6;6540:20;;:::i;:::-;6530:30;;6569:33;6597:4;6589:6;6569:33;:::i;:::-;6479:129;;;:::o;6614:308::-;6676:4;6766:18;6758:6;6755:30;6752:56;;;6788:18;;:::i;:::-;6752:56;6826:29;6848:6;6826:29;:::i;:::-;6818:37;;6910:4;6904;6900:15;6892:23;;6614:308;;;:::o;6928:148::-;7026:6;7021:3;7016;7003:30;7067:1;7058:6;7053:3;7049:16;7042:27;6928:148;;;:::o;7082:425::-;7160:5;7185:66;7201:49;7243:6;7201:49;:::i;:::-;7185:66;:::i;:::-;7176:75;;7274:6;7267:5;7260:21;7312:4;7305:5;7301:16;7350:3;7341:6;7336:3;7332:16;7329:25;7326:112;;;7357:79;;:::i;:::-;7326:112;7447:54;7494:6;7489:3;7484;7447:54;:::i;:::-;7166:341;7082:425;;;;;:::o;7527:340::-;7583:5;7632:3;7625:4;7617:6;7613:17;7609:27;7599:122;;7640:79;;:::i;:::-;7599:122;7757:6;7744:20;7782:79;7857:3;7849:6;7842:4;7834:6;7830:17;7782:79;:::i;:::-;7773:88;;7589:278;7527:340;;;;:::o;7873:509::-;7942:6;7991:2;7979:9;7970:7;7966:23;7962:32;7959:119;;;7997:79;;:::i;:::-;7959:119;8145:1;8134:9;8130:17;8117:31;8175:18;8167:6;8164:30;8161:117;;;8197:79;;:::i;:::-;8161:117;8302:63;8357:7;8348:6;8337:9;8333:22;8302:63;:::i;:::-;8292:73;;8088:287;7873:509;;;;:::o;8388:474::-;8456:6;8464;8513:2;8501:9;8492:7;8488:23;8484:32;8481:119;;;8519:79;;:::i;:::-;8481:119;8639:1;8664:53;8709:7;8700:6;8689:9;8685:22;8664:53;:::i;:::-;8654:63;;8610:117;8766:2;8792:53;8837:7;8828:6;8817:9;8813:22;8792:53;:::i;:::-;8782:63;;8737:118;8388:474;;;;;:::o;8868:329::-;8927:6;8976:2;8964:9;8955:7;8951:23;8947:32;8944:119;;;8982:79;;:::i;:::-;8944:119;9102:1;9127:53;9172:7;9163:6;9152:9;9148:22;9127:53;:::i;:::-;9117:63;;9073:117;8868:329;;;;:::o;9203:116::-;9273:21;9288:5;9273:21;:::i;:::-;9266:5;9263:32;9253:60;;9309:1;9306;9299:12;9253:60;9203:116;:::o;9325:133::-;9368:5;9406:6;9393:20;9384:29;;9422:30;9446:5;9422:30;:::i;:::-;9325:133;;;;:::o;9464:468::-;9529:6;9537;9586:2;9574:9;9565:7;9561:23;9557:32;9554:119;;;9592:79;;:::i;:::-;9554:119;9712:1;9737:53;9782:7;9773:6;9762:9;9758:22;9737:53;:::i;:::-;9727:63;;9683:117;9839:2;9865:50;9907:7;9898:6;9887:9;9883:22;9865:50;:::i;:::-;9855:60;;9810:115;9464:468;;;;;:::o;9938:307::-;9999:4;10089:18;10081:6;10078:30;10075:56;;;10111:18;;:::i;:::-;10075:56;10149:29;10171:6;10149:29;:::i;:::-;10141:37;;10233:4;10227;10223:15;10215:23;;9938:307;;;:::o;10251:423::-;10328:5;10353:65;10369:48;10410:6;10369:48;:::i;:::-;10353:65;:::i;:::-;10344:74;;10441:6;10434:5;10427:21;10479:4;10472:5;10468:16;10517:3;10508:6;10503:3;10499:16;10496:25;10493:112;;;10524:79;;:::i;:::-;10493:112;10614:54;10661:6;10656:3;10651;10614:54;:::i;:::-;10334:340;10251:423;;;;;:::o;10693:338::-;10748:5;10797:3;10790:4;10782:6;10778:17;10774:27;10764:122;;10805:79;;:::i;:::-;10764:122;10922:6;10909:20;10947:78;11021:3;11013:6;11006:4;10998:6;10994:17;10947:78;:::i;:::-;10938:87;;10754:277;10693:338;;;;:::o;11037:943::-;11132:6;11140;11148;11156;11205:3;11193:9;11184:7;11180:23;11176:33;11173:120;;;11212:79;;:::i;:::-;11173:120;11332:1;11357:53;11402:7;11393:6;11382:9;11378:22;11357:53;:::i;:::-;11347:63;;11303:117;11459:2;11485:53;11530:7;11521:6;11510:9;11506:22;11485:53;:::i;:::-;11475:63;;11430:118;11587:2;11613:53;11658:7;11649:6;11638:9;11634:22;11613:53;:::i;:::-;11603:63;;11558:118;11743:2;11732:9;11728:18;11715:32;11774:18;11766:6;11763:30;11760:117;;;11796:79;;:::i;:::-;11760:117;11901:62;11955:7;11946:6;11935:9;11931:22;11901:62;:::i;:::-;11891:72;;11686:287;11037:943;;;;;;;:::o;11986:474::-;12054:6;12062;12111:2;12099:9;12090:7;12086:23;12082:32;12079:119;;;12117:79;;:::i;:::-;12079:119;12237:1;12262:53;12307:7;12298:6;12287:9;12283:22;12262:53;:::i;:::-;12252:63;;12208:117;12364:2;12390:53;12435:7;12426:6;12415:9;12411:22;12390:53;:::i;:::-;12380:63;;12335:118;11986:474;;;;;:::o;12466:180::-;12514:77;12511:1;12504:88;12611:4;12608:1;12601:15;12635:4;12632:1;12625:15;12652:410;12692:7;12715:20;12733:1;12715:20;:::i;:::-;12710:25;;12749:20;12767:1;12749:20;:::i;:::-;12744:25;;12804:1;12801;12797:9;12826:30;12844:11;12826:30;:::i;:::-;12815:41;;13005:1;12996:7;12992:15;12989:1;12986:22;12966:1;12959:9;12939:83;12916:139;;13035:18;;:::i;:::-;12916:139;12700:362;12652:410;;;;:::o;13068:191::-;13108:3;13127:20;13145:1;13127:20;:::i;:::-;13122:25;;13161:20;13179:1;13161:20;:::i;:::-;13156:25;;13204:1;13201;13197:9;13190:16;;13225:3;13222:1;13219:10;13216:36;;;13232:18;;:::i;:::-;13216:36;13068:191;;;;:::o;13265:158::-;13405:10;13401:1;13393:6;13389:14;13382:34;13265:158;:::o;13429:365::-;13571:3;13592:66;13656:1;13651:3;13592:66;:::i;:::-;13585:73;;13667:93;13756:3;13667:93;:::i;:::-;13785:2;13780:3;13776:12;13769:19;;13429:365;;;:::o;13800:419::-;13966:4;14004:2;13993:9;13989:18;13981:26;;14053:9;14047:4;14043:20;14039:1;14028:9;14024:17;14017:47;14081:131;14207:4;14081:131;:::i;:::-;14073:139;;13800:419;;;:::o;14225:162::-;14365:14;14361:1;14353:6;14349:14;14342:38;14225:162;:::o;14393:366::-;14535:3;14556:67;14620:2;14615:3;14556:67;:::i;:::-;14549:74;;14632:93;14721:3;14632:93;:::i;:::-;14750:2;14745:3;14741:12;14734:19;;14393:366;;;:::o;14765:419::-;14931:4;14969:2;14958:9;14954:18;14946:26;;15018:9;15012:4;15008:20;15004:1;14993:9;14989:17;14982:47;15046:131;15172:4;15046:131;:::i;:::-;15038:139;;14765:419;;;:::o;15190:159::-;15330:11;15326:1;15318:6;15314:14;15307:35;15190:159;:::o;15355:365::-;15497:3;15518:66;15582:1;15577:3;15518:66;:::i;:::-;15511:73;;15593:93;15682:3;15593:93;:::i;:::-;15711:2;15706:3;15702:12;15695:19;;15355:365;;;:::o;15726:419::-;15892:4;15930:2;15919:9;15915:18;15907:26;;15979:9;15973:4;15969:20;15965:1;15954:9;15950:17;15943:47;16007:131;16133:4;16007:131;:::i;:::-;15999:139;;15726:419;;;:::o;16151:164::-;16291:16;16287:1;16279:6;16275:14;16268:40;16151:164;:::o;16321:366::-;16463:3;16484:67;16548:2;16543:3;16484:67;:::i;:::-;16477:74;;16560:93;16649:3;16560:93;:::i;:::-;16678:2;16673:3;16669:12;16662:19;;16321:366;;;:::o;16693:419::-;16859:4;16897:2;16886:9;16882:18;16874:26;;16946:9;16940:4;16936:20;16932:1;16921:9;16917:17;16910:47;16974:131;17100:4;16974:131;:::i;:::-;16966:139;;16693:419;;;:::o;17118:180::-;17166:77;17163:1;17156:88;17263:4;17260:1;17253:15;17287:4;17284:1;17277:15;17304:320;17348:6;17385:1;17379:4;17375:12;17365:22;;17432:1;17426:4;17422:12;17453:18;17443:81;;17509:4;17501:6;17497:17;17487:27;;17443:81;17571:2;17563:6;17560:14;17540:18;17537:38;17534:84;;17590:18;;:::i;:::-;17534:84;17355:269;17304:320;;;:::o;17630:141::-;17679:4;17702:3;17694:11;;17725:3;17722:1;17715:14;17759:4;17756:1;17746:18;17738:26;;17630:141;;;:::o;17777:93::-;17814:6;17861:2;17856;17849:5;17845:14;17841:23;17831:33;;17777:93;;;:::o;17876:107::-;17920:8;17970:5;17964:4;17960:16;17939:37;;17876:107;;;;:::o;17989:393::-;18058:6;18108:1;18096:10;18092:18;18131:97;18161:66;18150:9;18131:97;:::i;:::-;18249:39;18279:8;18268:9;18249:39;:::i;:::-;18237:51;;18321:4;18317:9;18310:5;18306:21;18297:30;;18370:4;18360:8;18356:19;18349:5;18346:30;18336:40;;18065:317;;17989:393;;;;;:::o;18388:60::-;18416:3;18437:5;18430:12;;18388:60;;;:::o;18454:142::-;18504:9;18537:53;18555:34;18564:24;18582:5;18564:24;:::i;:::-;18555:34;:::i;:::-;18537:53;:::i;:::-;18524:66;;18454:142;;;:::o;18602:75::-;18645:3;18666:5;18659:12;;18602:75;;;:::o;18683:269::-;18793:39;18824:7;18793:39;:::i;:::-;18854:91;18903:41;18927:16;18903:41;:::i;:::-;18895:6;18888:4;18882:11;18854:91;:::i;:::-;18848:4;18841:105;18759:193;18683:269;;;:::o;18958:73::-;19003:3;19024:1;19017:8;;18958:73;:::o;19037:189::-;19114:32;;:::i;:::-;19155:65;19213:6;19205;19199:4;19155:65;:::i;:::-;19090:136;19037:189;;:::o;19232:186::-;19292:120;19309:3;19302:5;19299:14;19292:120;;;19363:39;19400:1;19393:5;19363:39;:::i;:::-;19336:1;19329:5;19325:13;19316:22;;19292:120;;;19232:186;;:::o;19424:543::-;19525:2;19520:3;19517:11;19514:446;;;19559:38;19591:5;19559:38;:::i;:::-;19643:29;19661:10;19643:29;:::i;:::-;19633:8;19629:44;19826:2;19814:10;19811:18;19808:49;;;19847:8;19832:23;;19808:49;19870:80;19926:22;19944:3;19926:22;:::i;:::-;19916:8;19912:37;19899:11;19870:80;:::i;:::-;19529:431;;19514:446;19424:543;;;:::o;19973:117::-;20027:8;20077:5;20071:4;20067:16;20046:37;;19973:117;;;;:::o;20096:169::-;20140:6;20173:51;20221:1;20217:6;20209:5;20206:1;20202:13;20173:51;:::i;:::-;20169:56;20254:4;20248;20244:15;20234:25;;20147:118;20096:169;;;;:::o;20270:295::-;20346:4;20492:29;20517:3;20511:4;20492:29;:::i;:::-;20484:37;;20554:3;20551:1;20547:11;20541:4;20538:21;20530:29;;20270:295;;;;:::o;20570:1395::-;20687:37;20720:3;20687:37;:::i;:::-;20789:18;20781:6;20778:30;20775:56;;;20811:18;;:::i;:::-;20775:56;20855:38;20887:4;20881:11;20855:38;:::i;:::-;20940:67;21000:6;20992;20986:4;20940:67;:::i;:::-;21034:1;21058:4;21045:17;;21090:2;21082:6;21079:14;21107:1;21102:618;;;;21764:1;21781:6;21778:77;;;21830:9;21825:3;21821:19;21815:26;21806:35;;21778:77;21881:67;21941:6;21934:5;21881:67;:::i;:::-;21875:4;21868:81;21737:222;21072:887;;21102:618;21154:4;21150:9;21142:6;21138:22;21188:37;21220:4;21188:37;:::i;:::-;21247:1;21261:208;21275:7;21272:1;21269:14;21261:208;;;21354:9;21349:3;21345:19;21339:26;21331:6;21324:42;21405:1;21397:6;21393:14;21383:24;;21452:2;21441:9;21437:18;21424:31;;21298:4;21295:1;21291:12;21286:17;;21261:208;;;21497:6;21488:7;21485:19;21482:179;;;21555:9;21550:3;21546:19;21540:26;21598:48;21640:4;21632:6;21628:17;21617:9;21598:48;:::i;:::-;21590:6;21583:64;21505:156;21482:179;21707:1;21703;21695:6;21691:14;21687:22;21681:4;21674:36;21109:611;;;21072:887;;20662:1303;;;20570:1395;;:::o;21971:194::-;22011:4;22031:20;22049:1;22031:20;:::i;:::-;22026:25;;22065:20;22083:1;22065:20;:::i;:::-;22060:25;;22109:1;22106;22102:9;22094:17;;22133:1;22127:4;22124:11;22121:37;;;22138:18;;:::i;:::-;22121:37;21971:194;;;;:::o;22171:442::-;22320:4;22358:2;22347:9;22343:18;22335:26;;22371:71;22439:1;22428:9;22424:17;22415:6;22371:71;:::i;:::-;22452:72;22520:2;22509:9;22505:18;22496:6;22452:72;:::i;:::-;22534;22602:2;22591:9;22587:18;22578:6;22534:72;:::i;:::-;22171:442;;;;;;:::o;22619:180::-;22667:77;22664:1;22657:88;22764:4;22761:1;22754:15;22788:4;22785:1;22778:15;22805:176;22837:1;22854:20;22872:1;22854:20;:::i;:::-;22849:25;;22888:20;22906:1;22888:20;:::i;:::-;22883:25;;22927:1;22917:35;;22932:18;;:::i;:::-;22917:35;22973:1;22970;22966:9;22961:14;;22805:176;;;;:::o;22987:148::-;23089:11;23126:3;23111:18;;22987:148;;;;:::o;23141:161::-;23281:9;23277:1;23269:6;23265:14;23258:33;23141:161;:::o;23312:416::-;23472:3;23497:84;23579:1;23574:3;23497:84;:::i;:::-;23490:91;;23594:93;23683:3;23594:93;:::i;:::-;23716:1;23711:3;23707:11;23700:18;;23312:416;;;:::o;23738:410::-;23844:3;23876:39;23909:5;23876:39;:::i;:::-;23935:89;24017:6;24012:3;23935:89;:::i;:::-;23928:96;;24037:65;24095:6;24090:3;24083:4;24076:5;24072:16;24037:65;:::i;:::-;24131:6;24126:3;24122:16;24115:23;;23848:300;23738:410;;;;:::o;24158:159::-;24302:3;24298:1;24290:6;24286:14;24279:27;24158:159;:::o;24327:416::-;24487:3;24512:84;24594:1;24589:3;24512:84;:::i;:::-;24505:91;;24609:93;24698:3;24609:93;:::i;:::-;24731:1;24726:3;24722:11;24715:18;;24327:416;;;:::o;24753:163::-;24897:7;24893:1;24885:6;24881:14;24874:31;24753:163;:::o;24926:416::-;25086:3;25111:84;25193:1;25188:3;25111:84;:::i;:::-;25104:91;;25208:93;25297:3;25208:93;:::i;:::-;25330:1;25325:3;25321:11;25314:18;;24926:416;;;:::o;25352:1261::-;25835:3;25861:148;26005:3;25861:148;:::i;:::-;25854:155;;26030:95;26121:3;26112:6;26030:95;:::i;:::-;26023:102;;26146:148;26290:3;26146:148;:::i;:::-;26139:155;;26315:95;26406:3;26397:6;26315:95;:::i;:::-;26308:102;;26431:148;26575:3;26431:148;:::i;:::-;26424:155;;26600:3;26593:10;;25352:1261;;;;;:::o
Swarm Source
ipfs://3cd746104ca32d5dfd88a4c1e8654556a0dee56b959fd731df76e45d7c804590
[ Download: CSV Export ]
[ Download: CSV Export ]
A token is a representation of an on-chain or off-chain asset. The token page shows information such as price, total supply, holders, transfers and social links. Learn more about this page in our Knowledge Base.