ERC-721
Overview
Max Total Supply
3,358 Pee
Holders
508
Market
Volume (24H)
N/A
Min Price (24H)
N/A
Max Price (24H)
N/A
Other Info
Token Contract
Balance
3 PeeLoading...
Loading
Loading...
Loading
Loading...
Loading
# | Exchange | Pair | Price | 24H Volume | % Volume |
---|
Contract Name:
Pee
Compiler Version
v0.8.9+commit.e5eed63a
Contract Source Code (Solidity Multiple files format)
// SPDX-License-Identifier: MIT pragma solidity >=0.8.9 <0.9.0; import './ERC721AQueryable.sol'; import './Ownable.sol'; import './MerkleProof.sol'; import './ReentrancyGuard.sol'; import './Strings.sol'; interface IERC20 { function totalSupply() external view returns (uint256); function balanceOf(address account) external view returns (uint256); function transfer(address recipient, uint256 amount) external returns (bool); function allowance(address owner, address spender) external view returns (uint256); function approve(address spender, uint256 amount) external returns (bool); function transferFrom(address sender, address recipient, uint256 amount) external returns (bool); function mint(address to, uint256 amount) external returns (bool); function burn(uint256 amount) external returns (bool); event Transfer(address indexed from, address indexed to, uint256 value); event Approval(address indexed owner, address indexed spender, uint256 value); } contract Pee is ERC721AQueryable, Ownable, ReentrancyGuard { using Strings for uint256; bytes32 public merkleRoot; mapping(address => bool) public whitelistClaimed; mapping(address => uint256)public mintedAmount; mapping(address =>bool)public isfree; mapping(uint256=>bool)public isClaim; IERC20 public PeeCoinContract; address public Peeaddress; bool public holderClaim_state = false; uint public maxPerFree = 1; uint public whitelistPerFree = 3; string public uriPrefix = ''; string public uriSuffix = '.json'; string public hiddenMetadataUri; uint public totalFreeMinted = 0; uint256 public cost; uint256 public maxSupply; uint256 public maxMintAmountPerTx; bool public paused = true; bool public whitelistMintEnabled = false; bool public revealed = false; constructor( string memory _tokenName, string memory _tokenSymbol, uint256 _cost, uint256 _maxSupply, uint256 _maxMintAmountPerTx, string memory _hiddenMetadataUri ) ERC721A(_tokenName, _tokenSymbol) { setCost(_cost); maxSupply = _maxSupply; Peeaddress = address(this); setMaxMintAmountPerTx(_maxMintAmountPerTx); setHiddenMetadataUri(_hiddenMetadataUri); } function whitelistMint(uint256 _mintAmount, bytes32[] calldata _merkleProof) public payable { require(_mintAmount > 0 && _mintAmount <= maxMintAmountPerTx, 'Invalid mint amount!'); require(totalSupply() + _mintAmount <= maxSupply, 'Max supply exceeded!'); require(msg.value >= cost * _mintAmount - cost*whitelistPerFree, 'Insufficient funds!'); require(whitelistMintEnabled, 'The whitelist sale is not enabled!'); require(!whitelistClaimed[_msgSender()], 'Address already claimed!'); bytes32 leaf = keccak256(abi.encodePacked(_msgSender())); require(_msgSender()==tx.origin,'The minter is another contract'); require(MerkleProof.verify(_merkleProof, merkleRoot, leaf), 'Invalid proof!'); require(mintedAmount[_msgSender()]<20,'Maximum number of wallets is 20'); require(mintedAmount[_msgSender()]+_mintAmount<=20,'Maximum number of wallets is 20'); totalFreeMinted += whitelistPerFree; whitelistClaimed[_msgSender()] = true; isfree[_msgSender()]=true; mintedAmount[_msgSender()] +=_mintAmount; _safeMint(_msgSender(), _mintAmount); } function setPeecoinaddress(address Peeadd_) public onlyOwner { PeeCoinContract = IERC20(Peeadd_); } function holderClaim(uint256[] memory tokenIds) external { require(holderClaim_state, 'Activity redemption has not yet started'); uint256 claimAmount = 5000*10**18; uint256 tokenCount = tokenIds.length; address sender = msg.sender; for (uint256 i = 0; i < tokenCount; i++) { uint256 tokenId = tokenIds[i]; require(ownerOf(tokenId) == sender, "You don't own this token"); if (!isClaim[tokenId]) { isClaim[tokenId] = true; PeeCoinContract.transfer(sender, claimAmount); } } } function setholderClaimstate(bool _state)public onlyOwner{ holderClaim_state=_state; } function mint(uint256 _mintAmount) public payable { require(_mintAmount > 0 && _mintAmount <= maxMintAmountPerTx, 'Invalid mint amount!'); require(totalSupply() + _mintAmount <= maxSupply, 'Max supply exceeded!'); require(!paused, 'The contract is paused!'); require(_msgSender()==tx.origin,'The minter is another contract'); require(mintedAmount[_msgSender()]+_mintAmount<=20,'Maximum number of wallets is 20'); if (!isfree[_msgSender()]) { require(msg.value >= (_mintAmount * cost) - cost*maxPerFree, 'Insufficient funds!'); totalFreeMinted += maxPerFree; mintedAmount[_msgSender()] += _mintAmount; isfree[_msgSender()] = true; } else { require(msg.value >= (_mintAmount * cost), 'Insufficient funds!'); mintedAmount[_msgSender()] += _mintAmount; } _safeMint(_msgSender(), _mintAmount); } function mintForAddress(uint256 _mintAmount, address _receiver) public onlyOwner { require(_mintAmount > 0 && _mintAmount <= maxMintAmountPerTx, 'Invalid mint amount!'); require(totalSupply() + _mintAmount <= maxSupply, 'Max supply exceeded!'); _safeMint(_receiver, _mintAmount); } function _startTokenId() internal view virtual override returns (uint256) { return 1; } function tokenURI(uint256 _tokenId) public view virtual override returns (string memory) { require(_exists(_tokenId), 'ERC721Metadata: URI query for nonexistent token'); if (revealed == false) { return hiddenMetadataUri; } string memory currentBaseURI = _baseURI(); return bytes(currentBaseURI).length > 0 ? string(abi.encodePacked(currentBaseURI, _tokenId.toString(), uriSuffix)) : ''; } function setRevealed(bool _state) public onlyOwner { revealed = _state; } function setCost(uint256 _cost) public onlyOwner { cost = _cost; } function setMaxPerFree(uint freenum_)public onlyOwner{ maxPerFree = freenum_; } function setWhitelistPerFree(uint freenum)public onlyOwner{ whitelistPerFree = freenum; } function setMaxMintAmountPerTx(uint256 _maxMintAmountPerTx) public onlyOwner { maxMintAmountPerTx = _maxMintAmountPerTx; } function setHiddenMetadataUri(string memory _hiddenMetadataUri) public onlyOwner { hiddenMetadataUri = _hiddenMetadataUri; } function setUriPrefix(string memory _uriPrefix) public onlyOwner { uriPrefix = _uriPrefix; } function setUriSuffix(string memory _uriSuffix) public onlyOwner { uriSuffix = _uriSuffix; } function setPaused(bool _state) public onlyOwner { paused = _state; } function setMerkleRoot(bytes32 _merkleRoot) public onlyOwner { merkleRoot = _merkleRoot; } function setWhitelistMintEnabled(bool _state) public onlyOwner { whitelistMintEnabled = _state; } function withdraw() public onlyOwner nonReentrant { (bool os, ) = payable(owner()).call{value: address(this).balance}(''); require(os); } function withdrawPeetoken(uint Amount_) public onlyOwner { PeeCoinContract.transfer(owner(), Amount_); } function _baseURI() internal view virtual override returns (string memory) { return uriPrefix; } }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts v4.4.1 (utils/Context.sol) pragma solidity ^0.8.0; /** * @dev Provides information about the current execution context, including the * sender of the transaction and its data. While these are generally available * via msg.sender and msg.data, they should not be accessed in such a direct * manner, since when dealing with meta-transactions the account sending and * paying for execution may not be the actual sender (as far as an application * is concerned). * * This contract is only required for intermediate, library-like contracts. */ abstract contract Context { function _msgSender() internal view virtual returns (address) { return msg.sender; } function _msgData() internal view virtual returns (bytes calldata) { return msg.data; } }
// SPDX-License-Identifier: MIT // ERC721A Contracts v4.2.3 // Creator: Chiru Labs pragma solidity ^0.8.4; import './IERC721A.sol'; /** * @dev Interface of ERC721 token receiver. */ interface ERC721A__IERC721Receiver { function onERC721Received( address operator, address from, uint256 tokenId, bytes calldata data ) external returns (bytes4); } /** * @title ERC721A * * @dev Implementation of the [ERC721](https://eips.ethereum.org/EIPS/eip-721) * Non-Fungible Token Standard, including the Metadata extension. * Optimized for lower gas during batch mints. * * Token IDs are minted in sequential order (e.g. 0, 1, 2, 3, ...) * starting from `_startTokenId()`. * * Assumptions: * * - An owner cannot have more than 2**64 - 1 (max value of uint64) of supply. * - The maximum token ID cannot exceed 2**256 - 1 (max value of uint256). */ contract ERC721A is IERC721A { // Bypass for a `--via-ir` bug (https://github.com/chiru-labs/ERC721A/pull/364). struct TokenApprovalRef { address value; } // ============================================================= // CONSTANTS // ============================================================= // 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 bit position of `extraData` in packed ownership. uint256 private constant _BITPOS_EXTRA_DATA = 232; // Mask of all 256 bits in a packed ownership except the 24 bits for `extraData`. uint256 private constant _BITMASK_EXTRA_DATA_COMPLEMENT = (1 << 232) - 1; // The mask of the lower 160 bits for addresses. uint256 private constant _BITMASK_ADDRESS = (1 << 160) - 1; // The maximum `quantity` that can be minted with {_mintERC2309}. // This limit is to prevent overflows on the address data entries. // For a limit of 5000, a total of 3.689e15 calls to {_mintERC2309} // is required to cause an overflow, which is unrealistic. uint256 private constant _MAX_MINT_ERC2309_QUANTITY_LIMIT = 5000; // The `Transfer` event signature is given by: // `keccak256(bytes("Transfer(address,address,uint256)"))`. bytes32 private constant _TRANSFER_EVENT_SIGNATURE = 0xddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef; // ============================================================= // STORAGE // ============================================================= // The next token ID to be minted. uint256 private _currentIndex; // The number of tokens burned. uint256 private _burnCounter; // Token name string private _name; // Token symbol string private _symbol; // Mapping from token ID to ownership details // An empty struct value does not necessarily mean the token is unowned. // See {_packedOwnershipOf} implementation for details. // // Bits Layout: // - [0..159] `addr` // - [160..223] `startTimestamp` // - [224] `burned` // - [225] `nextInitialized` // - [232..255] `extraData` 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 => TokenApprovalRef) private _tokenApprovals; // Mapping from owner to operator approvals mapping(address => mapping(address => bool)) private _operatorApprovals; // ============================================================= // CONSTRUCTOR // ============================================================= constructor(string memory name_, string memory symbol_) { _name = name_; _symbol = symbol_; _currentIndex = _startTokenId(); } // ============================================================= // TOKEN COUNTING OPERATIONS // ============================================================= /** * @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 virtual 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 virtual override returns (uint256) { // Counter underflow is impossible as _burnCounter cannot be incremented // more than `_currentIndex - _startTokenId()` times. unchecked { return _currentIndex - _burnCounter - _startTokenId(); } } /** * @dev Returns the total amount of tokens minted in the contract. */ function _totalMinted() internal view virtual returns (uint256) { // Counter underflow is impossible as `_currentIndex` does not decrement, // and it is initialized to `_startTokenId()`. unchecked { return _currentIndex - _startTokenId(); } } /** * @dev Returns the total number of tokens burned. */ function _totalBurned() internal view virtual returns (uint256) { return _burnCounter; } // ============================================================= // ADDRESS DATA OPERATIONS // ============================================================= /** * @dev Returns the number of tokens in `owner`'s account. */ function balanceOf(address owner) public view virtual override returns (uint256) { if (owner == address(0)) _revert(BalanceQueryForZeroAddress.selector); return _packedAddressData[owner] & _BITMASK_ADDRESS_DATA_ENTRY; } /** * Returns the number of tokens minted by `owner`. */ function _numberMinted(address owner) internal view returns (uint256) { return (_packedAddressData[owner] >> _BITPOS_NUMBER_MINTED) & _BITMASK_ADDRESS_DATA_ENTRY; } /** * Returns the number of tokens burned by or on behalf of `owner`. */ function _numberBurned(address owner) internal view returns (uint256) { return (_packedAddressData[owner] >> _BITPOS_NUMBER_BURNED) & _BITMASK_ADDRESS_DATA_ENTRY; } /** * Returns the auxiliary data for `owner`. (e.g. number of whitelist mint slots used). */ function _getAux(address owner) internal view returns (uint64) { return uint64(_packedAddressData[owner] >> _BITPOS_AUX); } /** * Sets the auxiliary data for `owner`. (e.g. number of whitelist mint slots used). * If there are multiple variables, please pack them into a uint64. */ function _setAux(address owner, uint64 aux) internal virtual { uint256 packed = _packedAddressData[owner]; uint256 auxCasted; // Cast `aux` with assembly to avoid redundant masking. assembly { auxCasted := aux } packed = (packed & _BITMASK_AUX_COMPLEMENT) | (auxCasted << _BITPOS_AUX); _packedAddressData[owner] = packed; } // ============================================================= // 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) 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: [ERC165](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. } // ============================================================= // IERC721Metadata // ============================================================= /** * @dev Returns the token collection name. */ function name() public view virtual override returns (string memory) { return _name; } /** * @dev Returns the token collection symbol. */ function symbol() public view virtual override returns (string memory) { return _symbol; } /** * @dev Returns the Uniform Resource Identifier (URI) for `tokenId` token. */ function tokenURI(uint256 tokenId) public view virtual override returns (string memory) { if (!_exists(tokenId)) _revert(URIQueryForNonexistentToken.selector); string memory baseURI = _baseURI(); return bytes(baseURI).length != 0 ? string(abi.encodePacked(baseURI, _toString(tokenId))) : ''; } /** * @dev Base URI for computing {tokenURI}. If set, the resulting URI for each * token will be the concatenation of the `baseURI` and the `tokenId`. Empty * by default, it can be overridden in child contracts. */ function _baseURI() internal view virtual returns (string memory) { return ''; } // ============================================================= // OWNERSHIPS OPERATIONS // ============================================================= /** * @dev Returns the owner of the `tokenId` token. * * Requirements: * * - `tokenId` must exist. */ function ownerOf(uint256 tokenId) public view virtual override returns (address) { return address(uint160(_packedOwnershipOf(tokenId))); } /** * @dev Gas spent here starts off proportional to the maximum mint batch size. * It gradually moves to O(1) as tokens get transferred around over time. */ function _ownershipOf(uint256 tokenId) internal view virtual returns (TokenOwnership memory) { return _unpackedOwnership(_packedOwnershipOf(tokenId)); } /** * @dev Returns the unpacked `TokenOwnership` struct at `index`. */ function _ownershipAt(uint256 index) internal view virtual returns (TokenOwnership memory) { return _unpackedOwnership(_packedOwnerships[index]); } /** * @dev Returns whether the ownership slot at `index` is initialized. * An uninitialized slot does not necessarily mean that the slot has no owner. */ function _ownershipIsInitialized(uint256 index) internal view virtual returns (bool) { return _packedOwnerships[index] != 0; } /** * @dev Initializes the ownership slot minted at `index` for efficiency purposes. */ function _initializeOwnershipAt(uint256 index) internal virtual { if (_packedOwnerships[index] == 0) { _packedOwnerships[index] = _packedOwnershipOf(index); } } /** * Returns the packed ownership data of `tokenId`. */ function _packedOwnershipOf(uint256 tokenId) private view returns (uint256 packed) { if (_startTokenId() <= tokenId) { packed = _packedOwnerships[tokenId]; // If the data at the starting slot does not exist, start the scan. if (packed == 0) { if (tokenId >= _currentIndex) _revert(OwnerQueryForNonexistentToken.selector); // Invariant: // There will always be an initialized ownership slot // (i.e. `ownership.addr != address(0) && ownership.burned == false`) // before an unintialized ownership slot // (i.e. `ownership.addr == address(0) && ownership.burned == false`) // Hence, `tokenId` will not underflow. // // We can directly compare the packed value. // If the address is zero, packed will be zero. for (;;) { unchecked { packed = _packedOwnerships[--tokenId]; } if (packed == 0) continue; if (packed & _BITMASK_BURNED == 0) return packed; // Otherwise, the token is burned, and we must revert. // This handles the case of batch burned tokens, where only the burned bit // of the starting slot is set, and remaining slots are left uninitialized. _revert(OwnerQueryForNonexistentToken.selector); } } // Otherwise, the data exists and we can skip the scan. // This is possible because we have already achieved the target condition. // This saves 2143 gas on transfers of initialized tokens. // If the token is not burned, return `packed`. Otherwise, revert. if (packed & _BITMASK_BURNED == 0) return packed; } _revert(OwnerQueryForNonexistentToken.selector); } /** * @dev 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; ownership.extraData = uint24(packed >> _BITPOS_EXTRA_DATA); } /** * @dev Packs ownership data into a single uint256. */ function _packOwnershipData(address owner, uint256 flags) private view returns (uint256 result) { assembly { // Mask `owner` to the lower 160 bits, in case the upper bits somehow aren't clean. owner := and(owner, _BITMASK_ADDRESS) // `owner | (block.timestamp << _BITPOS_START_TIMESTAMP) | flags`. result := or(owner, or(shl(_BITPOS_START_TIMESTAMP, timestamp()), flags)) } } /** * @dev Returns the `nextInitialized` flag set if `quantity` equals 1. */ function _nextInitializedFlag(uint256 quantity) private pure returns (uint256 result) { // For branchless setting of the `nextInitialized` flag. assembly { // `(quantity == 1) << _BITPOS_NEXT_INITIALIZED`. result := shl(_BITPOS_NEXT_INITIALIZED, eq(quantity, 1)) } } // ============================================================= // APPROVAL OPERATIONS // ============================================================= /** * @dev Gives permission to `to` to transfer `tokenId` token to another account. See {ERC721A-_approve}. * * Requirements: * * - The caller must own the token or be an approved operator. */ function approve(address to, uint256 tokenId) public payable virtual override { _approve(to, tokenId, true); } /** * @dev Returns the account approved for `tokenId` token. * * Requirements: * * - `tokenId` must exist. */ function getApproved(uint256 tokenId) public view virtual override returns (address) { if (!_exists(tokenId)) _revert(ApprovalQueryForNonexistentToken.selector); return _tokenApprovals[tokenId].value; } /** * @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) public virtual override { _operatorApprovals[_msgSenderERC721A()][operator] = approved; emit ApprovalForAll(_msgSenderERC721A(), operator, approved); } /** * @dev Returns if the `operator` is allowed to manage all of the assets of `owner`. * * See {setApprovalForAll}. */ function isApprovedForAll(address owner, address operator) public view virtual override returns (bool) { return _operatorApprovals[owner][operator]; } /** * @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. See {_mint}. */ function _exists(uint256 tokenId) internal view virtual returns (bool result) { if (_startTokenId() <= tokenId) { if (tokenId < _currentIndex) { uint256 packed; while ((packed = _packedOwnerships[tokenId]) == 0) --tokenId; result = packed & _BITMASK_BURNED == 0; } } } /** * @dev Returns whether `msgSender` is equal to `approvedAddress` or `owner`. */ function _isSenderApprovedOrOwner( address approvedAddress, address owner, address msgSender ) private pure returns (bool result) { assembly { // Mask `owner` to the lower 160 bits, in case the upper bits somehow aren't clean. owner := and(owner, _BITMASK_ADDRESS) // Mask `msgSender` to the lower 160 bits, in case the upper bits somehow aren't clean. msgSender := and(msgSender, _BITMASK_ADDRESS) // `msgSender == owner || msgSender == approvedAddress`. result := or(eq(msgSender, owner), eq(msgSender, approvedAddress)) } } /** * @dev Returns the storage slot and value for the approved address of `tokenId`. */ function _getApprovedSlotAndAddress(uint256 tokenId) private view returns (uint256 approvedAddressSlot, address approvedAddress) { TokenApprovalRef storage tokenApproval = _tokenApprovals[tokenId]; // The following is equivalent to `approvedAddress = _tokenApprovals[tokenId].value`. assembly { approvedAddressSlot := tokenApproval.slot approvedAddress := sload(approvedAddressSlot) } } // ============================================================= // TRANSFER OPERATIONS // ============================================================= /** * @dev Transfers `tokenId` from `from` to `to`. * * 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 ) public payable virtual override { uint256 prevOwnershipPacked = _packedOwnershipOf(tokenId); // Mask `from` to the lower 160 bits, in case the upper bits somehow aren't clean. from = address(uint160(uint256(uint160(from)) & _BITMASK_ADDRESS)); if (address(uint160(prevOwnershipPacked)) != from) _revert(TransferFromIncorrectOwner.selector); (uint256 approvedAddressSlot, address approvedAddress) = _getApprovedSlotAndAddress(tokenId); // The nested ifs save around 20+ gas over a compound boolean condition. if (!_isSenderApprovedOrOwner(approvedAddress, from, _msgSenderERC721A())) if (!isApprovedForAll(from, _msgSenderERC721A())) _revert(TransferCallerNotOwnerNorApproved.selector); _beforeTokenTransfers(from, to, tokenId, 1); // Clear approvals from the previous owner. assembly { if approvedAddress { // This is equivalent to `delete _tokenApprovals[tokenId]`. sstore(approvedAddressSlot, 0) } } // 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] = _packOwnershipData( to, _BITMASK_NEXT_INITIALIZED | _nextExtraData(from, to, prevOwnershipPacked) ); // 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; } } } } // Mask `to` to the lower 160 bits, in case the upper bits somehow aren't clean. uint256 toMasked = uint256(uint160(to)) & _BITMASK_ADDRESS; assembly { // Emit the `Transfer` event. log4( 0, // Start of data (0, since no data). 0, // End of data (0, since no data). _TRANSFER_EVENT_SIGNATURE, // Signature. from, // `from`. toMasked, // `to`. tokenId // `tokenId`. ) } if (toMasked == 0) _revert(TransferToZeroAddress.selector); _afterTokenTransfers(from, to, tokenId, 1); } /** * @dev Equivalent to `safeTransferFrom(from, to, tokenId, '')`. */ function safeTransferFrom( address from, address to, uint256 tokenId ) public payable virtual override { safeTransferFrom(from, to, tokenId, ''); } /** * @dev Safely transfers `tokenId` token from `from` to `to`. * * Requirements: * * - `from` cannot be the zero address. * - `to` cannot be the zero address. * - `tokenId` token must exist and be owned by `from`. * - If the caller is not `from`, it must be approved to move this token * by either {approve} or {setApprovalForAll}. * - If `to` refers to a smart contract, it must implement * {IERC721Receiver-onERC721Received}, which is called upon a safe transfer. * * Emits a {Transfer} event. */ function safeTransferFrom( address from, address to, uint256 tokenId, bytes memory _data ) public payable virtual override { transferFrom(from, to, tokenId); if (to.code.length != 0) if (!_checkContractOnERC721Received(from, to, tokenId, _data)) { _revert(TransferToNonERC721ReceiverImplementer.selector); } } /** * @dev Hook that is called before a set of serially-ordered token IDs * are about to be transferred. This includes minting. * And also called before burning one token. * * `startTokenId` - the first token ID to be transferred. * `quantity` - the amount to be transferred. * * Calling conditions: * * - When `from` and `to` are both non-zero, `from`'s `tokenId` will be * transferred to `to`. * - When `from` is zero, `tokenId` will be minted for `to`. * - When `to` is zero, `tokenId` will be burned by `from`. * - `from` and `to` are never both zero. */ function _beforeTokenTransfers( address from, address to, uint256 startTokenId, uint256 quantity ) internal virtual {} /** * @dev Hook that is called after a set of serially-ordered token IDs * have been transferred. This includes minting. * And also called after one token has been burned. * * `startTokenId` - the first token ID to be transferred. * `quantity` - the amount to be transferred. * * Calling conditions: * * - When `from` and `to` are both non-zero, `from`'s `tokenId` has been * transferred to `to`. * - When `from` is zero, `tokenId` has been minted for `to`. * - When `to` is zero, `tokenId` has been burned by `from`. * - `from` and `to` are never both zero. */ function _afterTokenTransfers( address from, address to, uint256 startTokenId, uint256 quantity ) internal virtual {} /** * @dev Private function to invoke {IERC721Receiver-onERC721Received} on a target contract. * * `from` - Previous owner of the given token ID. * `to` - Target address that will receive the token. * `tokenId` - Token ID to be transferred. * `_data` - Optional data to send along with the call. * * Returns whether the call correctly returned the expected magic value. */ function _checkContractOnERC721Received( address from, address to, uint256 tokenId, bytes memory _data ) private returns (bool) { try ERC721A__IERC721Receiver(to).onERC721Received(_msgSenderERC721A(), from, tokenId, _data) returns ( bytes4 retval ) { return retval == ERC721A__IERC721Receiver(to).onERC721Received.selector; } catch (bytes memory reason) { if (reason.length == 0) { _revert(TransferToNonERC721ReceiverImplementer.selector); } assembly { revert(add(32, reason), mload(reason)) } } } // ============================================================= // MINT OPERATIONS // ============================================================= /** * @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 for each mint. */ function _mint(address to, uint256 quantity) internal virtual { uint256 startTokenId = _currentIndex; if (quantity == 0) _revert(MintZeroQuantity.selector); _beforeTokenTransfers(address(0), to, startTokenId, quantity); // Overflows are incredibly unrealistic. // `balance` and `numberMinted` have a maximum limit of 2**64. // `tokenId` has a maximum limit of 2**256. unchecked { // Updates: // - `address` to the owner. // - `startTimestamp` to the timestamp of minting. // - `burned` to `false`. // - `nextInitialized` to `quantity == 1`. _packedOwnerships[startTokenId] = _packOwnershipData( to, _nextInitializedFlag(quantity) | _nextExtraData(address(0), to, 0) ); // Updates: // - `balance += quantity`. // - `numberMinted += quantity`. // // We can directly add to the `balance` and `numberMinted`. _packedAddressData[to] += quantity * ((1 << _BITPOS_NUMBER_MINTED) | 1); // Mask `to` to the lower 160 bits, in case the upper bits somehow aren't clean. uint256 toMasked = uint256(uint160(to)) & _BITMASK_ADDRESS; if (toMasked == 0) _revert(MintToZeroAddress.selector); uint256 end = startTokenId + quantity; uint256 tokenId = startTokenId; do { assembly { // Emit the `Transfer` event. log4( 0, // Start of data (0, since no data). 0, // End of data (0, since no data). _TRANSFER_EVENT_SIGNATURE, // Signature. 0, // `address(0)`. toMasked, // `to`. tokenId // `tokenId`. ) } // The `!=` check ensures that large values of `quantity` // that overflows uint256 will make the loop run out of gas. } while (++tokenId != end); _currentIndex = end; } _afterTokenTransfers(address(0), to, startTokenId, quantity); } /** * @dev Mints `quantity` tokens and transfers them to `to`. * * This function is intended for efficient minting only during contract creation. * * It emits only one {ConsecutiveTransfer} as defined in * [ERC2309](https://eips.ethereum.org/EIPS/eip-2309), * instead of a sequence of {Transfer} event(s). * * Calling this function outside of contract creation WILL make your contract * non-compliant with the ERC721 standard. * For full ERC721 compliance, substituting ERC721 {Transfer} event(s) with the ERC2309 * {ConsecutiveTransfer} event is only permissible during contract creation. * * Requirements: * * - `to` cannot be the zero address. * - `quantity` must be greater than 0. * * Emits a {ConsecutiveTransfer} event. */ function _mintERC2309(address to, uint256 quantity) internal virtual { uint256 startTokenId = _currentIndex; if (to == address(0)) _revert(MintToZeroAddress.selector); if (quantity == 0) _revert(MintZeroQuantity.selector); if (quantity > _MAX_MINT_ERC2309_QUANTITY_LIMIT) _revert(MintERC2309QuantityExceedsLimit.selector); _beforeTokenTransfers(address(0), to, startTokenId, quantity); // Overflows are unrealistic due to the above check for `quantity` to be below the limit. unchecked { // Updates: // - `balance += quantity`. // - `numberMinted += quantity`. // // We can directly add to the `balance` and `numberMinted`. _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] = _packOwnershipData( to, _nextInitializedFlag(quantity) | _nextExtraData(address(0), to, 0) ); emit ConsecutiveTransfer(startTokenId, startTokenId + quantity - 1, address(0), to); _currentIndex = startTokenId + quantity; } _afterTokenTransfers(address(0), to, startTokenId, quantity); } /** * @dev Safely mints `quantity` tokens and transfers them to `to`. * * Requirements: * * - If `to` refers to a smart contract, it must implement * {IERC721Receiver-onERC721Received}, which is called for each safe transfer. * - `quantity` must be greater than 0. * * See {_mint}. * * Emits a {Transfer} event for each mint. */ function _safeMint( address to, uint256 quantity, bytes memory _data ) internal virtual { _mint(to, quantity); unchecked { if (to.code.length != 0) { uint256 end = _currentIndex; uint256 index = end - quantity; do { if (!_checkContractOnERC721Received(address(0), to, index++, _data)) { _revert(TransferToNonERC721ReceiverImplementer.selector); } } while (index < end); // Reentrancy protection. if (_currentIndex != end) _revert(bytes4(0)); } } } /** * @dev Equivalent to `_safeMint(to, quantity, '')`. */ function _safeMint(address to, uint256 quantity) internal virtual { _safeMint(to, quantity, ''); } // ============================================================= // APPROVAL OPERATIONS // ============================================================= /** * @dev Equivalent to `_approve(to, tokenId, false)`. */ function _approve(address to, uint256 tokenId) internal virtual { _approve(to, tokenId, false); } /** * @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: * * - `tokenId` must exist. * * Emits an {Approval} event. */ function _approve( address to, uint256 tokenId, bool approvalCheck ) internal virtual { address owner = ownerOf(tokenId); if (approvalCheck && _msgSenderERC721A() != owner) if (!isApprovedForAll(owner, _msgSenderERC721A())) { _revert(ApprovalCallerNotOwnerNorApproved.selector); } _tokenApprovals[tokenId].value = to; emit Approval(owner, to, tokenId); } // ============================================================= // BURN OPERATIONS // ============================================================= /** * @dev Equivalent to `_burn(tokenId, false)`. */ function _burn(uint256 tokenId) internal virtual { _burn(tokenId, false); } /** * @dev Destroys `tokenId`. * The approval is cleared when the token is burned. * * Requirements: * * - `tokenId` must exist. * * Emits a {Transfer} event. */ function _burn(uint256 tokenId, bool approvalCheck) internal virtual { uint256 prevOwnershipPacked = _packedOwnershipOf(tokenId); address from = address(uint160(prevOwnershipPacked)); (uint256 approvedAddressSlot, address approvedAddress) = _getApprovedSlotAndAddress(tokenId); if (approvalCheck) { // The nested ifs save around 20+ gas over a compound boolean condition. if (!_isSenderApprovedOrOwner(approvedAddress, from, _msgSenderERC721A())) if (!isApprovedForAll(from, _msgSenderERC721A())) _revert(TransferCallerNotOwnerNorApproved.selector); } _beforeTokenTransfers(from, address(0), tokenId, 1); // Clear approvals from the previous owner. assembly { if approvedAddress { // This is equivalent to `delete _tokenApprovals[tokenId]`. sstore(approvedAddressSlot, 0) } } // Underflow of the sender's balance is impossible because we check for // ownership above and the recipient's balance can't realistically overflow. // Counter overflow is incredibly unrealistic as `tokenId` would have to be 2**256. unchecked { // Updates: // - `balance -= 1`. // - `numberBurned += 1`. // // We can directly decrement the balance, and increment the number burned. // This is equivalent to `packed -= 1; packed += 1 << _BITPOS_NUMBER_BURNED;`. _packedAddressData[from] += (1 << _BITPOS_NUMBER_BURNED) - 1; // Updates: // - `address` to the last owner. // - `startTimestamp` to the timestamp of burning. // - `burned` to `true`. // - `nextInitialized` to `true`. _packedOwnerships[tokenId] = _packOwnershipData( from, (_BITMASK_BURNED | _BITMASK_NEXT_INITIALIZED) | _nextExtraData(from, address(0), prevOwnershipPacked) ); // If the next slot may not have been initialized (i.e. `nextInitialized == false`) . if (prevOwnershipPacked & _BITMASK_NEXT_INITIALIZED == 0) { uint256 nextTokenId = tokenId + 1; // If the next slot's address is zero and not burned (i.e. packed value is zero). if (_packedOwnerships[nextTokenId] == 0) { // If the next slot is within bounds. if (nextTokenId != _currentIndex) { // Initialize the next slot to maintain correctness for `ownerOf(tokenId + 1)`. _packedOwnerships[nextTokenId] = prevOwnershipPacked; } } } } emit Transfer(from, address(0), tokenId); _afterTokenTransfers(from, address(0), tokenId, 1); // Overflow not possible, as _burnCounter cannot be exceed _currentIndex times. unchecked { _burnCounter++; } } // ============================================================= // EXTRA DATA OPERATIONS // ============================================================= /** * @dev Directly sets the extra data for the ownership data `index`. */ function _setExtraDataAt(uint256 index, uint24 extraData) internal virtual { uint256 packed = _packedOwnerships[index]; if (packed == 0) _revert(OwnershipNotInitializedForExtraData.selector); uint256 extraDataCasted; // Cast `extraData` with assembly to avoid redundant masking. assembly { extraDataCasted := extraData } packed = (packed & _BITMASK_EXTRA_DATA_COMPLEMENT) | (extraDataCasted << _BITPOS_EXTRA_DATA); _packedOwnerships[index] = packed; } /** * @dev Called during each token transfer to set the 24bit `extraData` field. * Intended to be overridden by the cosumer contract. * * `previousExtraData` - the value of `extraData` before transfer. * * Calling conditions: * * - When `from` and `to` are both non-zero, `from`'s `tokenId` will be * transferred to `to`. * - When `from` is zero, `tokenId` will be minted for `to`. * - When `to` is zero, `tokenId` will be burned by `from`. * - `from` and `to` are never both zero. */ function _extraData( address from, address to, uint24 previousExtraData ) internal view virtual returns (uint24) {} /** * @dev Returns the next extra data for the packed ownership data. * The returned result is shifted into position. */ function _nextExtraData( address from, address to, uint256 prevOwnershipPacked ) private view returns (uint256) { uint24 extraData = uint24(prevOwnershipPacked >> _BITPOS_EXTRA_DATA); return uint256(_extraData(from, to, extraData)) << _BITPOS_EXTRA_DATA; } // ============================================================= // OTHER OPERATIONS // ============================================================= /** * @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 virtual returns (string memory str) { assembly { // The maximum value of a uint256 contains 78 digits (1 byte per digit), but // we allocate 0xa0 bytes to keep the free memory pointer 32-byte word aligned. // We will need 1 word for the trailing zeros padding, 1 word for the length, // and 3 words for a maximum of 78 digits. Total: 5 * 0x20 = 0xa0. let m := add(mload(0x40), 0xa0) // Update the free memory pointer to allocate. mstore(0x40, m) // Assign the `str` to the end. str := sub(m, 0x20) // Zeroize the slot after the string. mstore(str, 0) // Cache the end of the memory to calculate the length later. let end := str // We write the string from rightmost digit to leftmost digit. // The following is essentially a do-while loop that also handles the zero case. // prettier-ignore for { let temp := value } 1 {} { str := sub(str, 1) // Write the character to the pointer. // The ASCII index of the '0' character is 48. mstore8(str, add(48, mod(temp, 10))) // Keep dividing `temp` until zero. temp := div(temp, 10) // prettier-ignore if iszero(temp) { break } } let length := sub(end, str) // Move the pointer 32 bytes leftwards to make room for the length. str := sub(str, 0x20) // Store the length. mstore(str, length) } } /** * @dev For more efficient reverts. */ function _revert(bytes4 errorSelector) internal pure { assembly { mstore(0x00, errorSelector) revert(0x00, 0x04) } } }
// SPDX-License-Identifier: MIT // ERC721A Contracts v4.2.3 // Creator: Chiru Labs pragma solidity ^0.8.4; import './IERC721AQueryable.sol'; import './ERC721A.sol'; /** * @title ERC721AQueryable. * * @dev ERC721A subclass with convenience query functions. */ abstract contract ERC721AQueryable is ERC721A, IERC721AQueryable { /** * @dev Returns the `TokenOwnership` struct at `tokenId` without reverting. * * If the `tokenId` is out of bounds: * * - `addr = address(0)` * - `startTimestamp = 0` * - `burned = false` * - `extraData = 0` * * If the `tokenId` is burned: * * - `addr = <Address of owner before token was burned>` * - `startTimestamp = <Timestamp when token was burned>` * - `burned = true` * - `extraData = <Extra data when token was burned>` * * Otherwise: * * - `addr = <Address of owner>` * - `startTimestamp = <Timestamp of start of ownership>` * - `burned = false` * - `extraData = <Extra data at start of ownership>` */ function explicitOwnershipOf(uint256 tokenId) public view virtual override returns (TokenOwnership memory ownership) { unchecked { if (tokenId >= _startTokenId()) { if (tokenId < _nextTokenId()) { // If the `tokenId` is within bounds, // scan backwards for the initialized ownership slot. while (!_ownershipIsInitialized(tokenId)) --tokenId; return _ownershipAt(tokenId); } } } } /** * @dev Returns an array of `TokenOwnership` structs at `tokenIds` in order. * See {ERC721AQueryable-explicitOwnershipOf} */ function explicitOwnershipsOf(uint256[] calldata tokenIds) external view virtual override returns (TokenOwnership[] memory) { TokenOwnership[] memory ownerships; uint256 i = tokenIds.length; assembly { // Grab the free memory pointer. ownerships := mload(0x40) // Store the length. mstore(ownerships, i) // Allocate one word for the length, // `tokenIds.length` words for the pointers. i := shl(5, i) // Multiply `i` by 32. mstore(0x40, add(add(ownerships, 0x20), i)) } while (i != 0) { uint256 tokenId; assembly { i := sub(i, 0x20) tokenId := calldataload(add(tokenIds.offset, i)) } TokenOwnership memory ownership = explicitOwnershipOf(tokenId); assembly { // Store the pointer of `ownership` in the `ownerships` array. mstore(add(add(ownerships, 0x20), i), ownership) } } return ownerships; } /** * @dev Returns an array of token IDs owned by `owner`, * in the range [`start`, `stop`) * (i.e. `start <= tokenId < stop`). * * This function allows for tokens to be queried if the collection * grows too big for a single call of {ERC721AQueryable-tokensOfOwner}. * * Requirements: * * - `start < stop` */ function tokensOfOwnerIn( address owner, uint256 start, uint256 stop ) external view virtual override returns (uint256[] memory) { return _tokensOfOwnerIn(owner, start, stop); } /** * @dev Returns an array of token IDs owned by `owner`. * * This function scans the ownership mapping and is O(`totalSupply`) in complexity. * It is meant to be called off-chain. * * See {ERC721AQueryable-tokensOfOwnerIn} for splitting the scan into * multiple smaller scans if the collection is large enough to cause * an out-of-gas error (10K collections should be fine). */ function tokensOfOwner(address owner) external view virtual override returns (uint256[] memory) { uint256 start = _startTokenId(); uint256 stop = _nextTokenId(); uint256[] memory tokenIds; if (start != stop) tokenIds = _tokensOfOwnerIn(owner, start, stop); return tokenIds; } /** * @dev Helper function for returning an array of token IDs owned by `owner`. * * Note that this function is optimized for smaller bytecode size over runtime gas, * since it is meant to be called off-chain. */ function _tokensOfOwnerIn( address owner, uint256 start, uint256 stop ) private view returns (uint256[] memory) { unchecked { if (start >= stop) _revert(InvalidQueryRange.selector); // Set `start = max(start, _startTokenId())`. if (start < _startTokenId()) { start = _startTokenId(); } uint256 stopLimit = _nextTokenId(); // Set `stop = min(stop, stopLimit)`. if (stop >= stopLimit) { stop = stopLimit; } uint256[] memory tokenIds; uint256 tokenIdsMaxLength = balanceOf(owner); bool startLtStop = start < stop; assembly { // Set `tokenIdsMaxLength` to zero if `start` is less than `stop`. tokenIdsMaxLength := mul(tokenIdsMaxLength, startLtStop) } if (tokenIdsMaxLength != 0) { // Set `tokenIdsMaxLength = min(balanceOf(owner), stop - start)`, // to cater for cases where `balanceOf(owner)` is too big. if (stop - start <= tokenIdsMaxLength) { tokenIdsMaxLength = stop - start; } assembly { // Grab the free memory pointer. tokenIds := mload(0x40) // Allocate one word for the length, and `tokenIdsMaxLength` words // for the data. `shl(5, x)` is equivalent to `mul(32, x)`. mstore(0x40, add(tokenIds, shl(5, add(tokenIdsMaxLength, 1)))) } // We need to call `explicitOwnershipOf(start)`, // because the slot at `start` may not be initialized. TokenOwnership memory ownership = explicitOwnershipOf(start); address currOwnershipAddr; // If the starting slot exists (i.e. not burned), // initialize `currOwnershipAddr`. // `ownership.address` will not be zero, // as `start` is clamped to the valid token ID range. if (!ownership.burned) { currOwnershipAddr = ownership.addr; } uint256 tokenIdsIdx; // Use a do-while, which is slightly more efficient for this case, // as the array will at least contain one element. do { ownership = _ownershipAt(start); assembly { switch mload(add(ownership, 0x40)) // if `ownership.burned == false`. case 0 { // if `ownership.addr != address(0)`. // The `addr` already has it's upper 96 bits clearned, // since it is written to memory with regular Solidity. if mload(ownership) { currOwnershipAddr := mload(ownership) } // if `currOwnershipAddr == owner`. // The `shl(96, x)` is to make the comparison agnostic to any // dirty upper 96 bits in `owner`. if iszero(shl(96, xor(currOwnershipAddr, owner))) { tokenIdsIdx := add(tokenIdsIdx, 1) mstore(add(tokenIds, shl(5, tokenIdsIdx)), start) } } // Otherwise, reset `currOwnershipAddr`. // This handles the case of batch burned tokens // (burned bit of first slot set, remaining slots left uninitialized). default { currOwnershipAddr := 0 } start := add(start, 1) } } while (!(start == stop || tokenIdsIdx == tokenIdsMaxLength)); // Store the length of the array. assembly { mstore(tokenIds, tokenIdsIdx) } } return tokenIds; } } }
// SPDX-License-Identifier: MIT // ERC721A Contracts v4.2.3 // Creator: Chiru Labs pragma solidity ^0.8.4; /** * @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(); /** * 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 payable; /** * @dev Equivalent to `safeTransferFrom(from, to, tokenId, '')`. */ function safeTransferFrom( address from, address to, uint256 tokenId ) external payable; /** * @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 payable; /** * @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 payable; /** * @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); }
// SPDX-License-Identifier: MIT // ERC721A Contracts v4.2.3 // Creator: Chiru Labs pragma solidity ^0.8.4; import './IERC721A.sol'; /** * @dev Interface of ERC721AQueryable. */ interface IERC721AQueryable is IERC721A { /** * Invalid query range (`start` >= `stop`). */ error InvalidQueryRange(); /** * @dev Returns the `TokenOwnership` struct at `tokenId` without reverting. * * If the `tokenId` is out of bounds: * * - `addr = address(0)` * - `startTimestamp = 0` * - `burned = false` * - `extraData = 0` * * If the `tokenId` is burned: * * - `addr = <Address of owner before token was burned>` * - `startTimestamp = <Timestamp when token was burned>` * - `burned = true` * - `extraData = <Extra data when token was burned>` * * Otherwise: * * - `addr = <Address of owner>` * - `startTimestamp = <Timestamp of start of ownership>` * - `burned = false` * - `extraData = <Extra data at start of ownership>` */ function explicitOwnershipOf(uint256 tokenId) external view returns (TokenOwnership memory); /** * @dev Returns an array of `TokenOwnership` structs at `tokenIds` in order. * See {ERC721AQueryable-explicitOwnershipOf} */ function explicitOwnershipsOf(uint256[] memory tokenIds) external view returns (TokenOwnership[] memory); /** * @dev Returns an array of token IDs owned by `owner`, * in the range [`start`, `stop`) * (i.e. `start <= tokenId < stop`). * * This function allows for tokens to be queried if the collection * grows too big for a single call of {ERC721AQueryable-tokensOfOwner}. * * Requirements: * * - `start < stop` */ function tokensOfOwnerIn( address owner, uint256 start, uint256 stop ) external view returns (uint256[] memory); /** * @dev Returns an array of token IDs owned by `owner`. * * This function scans the ownership mapping and is O(`totalSupply`) in complexity. * It is meant to be called off-chain. * * See {ERC721AQueryable-tokensOfOwnerIn} for splitting the scan into * multiple smaller scans if the collection is large enough to cause * an out-of-gas error (10K collections should be fine). */ function tokensOfOwner(address owner) external view returns (uint256[] memory); }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts (last updated v4.8.0) (utils/math/Math.sol) pragma solidity ^0.8.0; /** * @dev Standard math utilities missing in the Solidity language. */ library Math { enum Rounding { Down, // Toward negative infinity Up, // Toward infinity Zero // Toward zero } /** * @dev Returns the largest of two numbers. */ function max(uint256 a, uint256 b) internal pure returns (uint256) { return a > b ? a : b; } /** * @dev Returns the smallest of two numbers. */ function min(uint256 a, uint256 b) internal pure returns (uint256) { return a < b ? a : b; } /** * @dev Returns the average of two numbers. The result is rounded towards * zero. */ function average(uint256 a, uint256 b) internal pure returns (uint256) { // (a + b) / 2 can overflow. return (a & b) + (a ^ b) / 2; } /** * @dev Returns the ceiling of the division of two numbers. * * This differs from standard division with `/` in that it rounds up instead * of rounding down. */ function ceilDiv(uint256 a, uint256 b) internal pure returns (uint256) { // (a + b - 1) / b can overflow on addition, so we distribute. return a == 0 ? 0 : (a - 1) / b + 1; } /** * @notice Calculates floor(x * y / denominator) with full precision. Throws if result overflows a uint256 or denominator == 0 * @dev Original credit to Remco Bloemen under MIT license (https://xn--2-umb.com/21/muldiv) * with further edits by Uniswap Labs also under MIT license. */ function mulDiv( uint256 x, uint256 y, uint256 denominator ) internal pure returns (uint256 result) { unchecked { // 512-bit multiply [prod1 prod0] = x * y. Compute the product mod 2^256 and mod 2^256 - 1, then use // use the Chinese Remainder Theorem to reconstruct the 512 bit result. The result is stored in two 256 // variables such that product = prod1 * 2^256 + prod0. uint256 prod0; // Least significant 256 bits of the product uint256 prod1; // Most significant 256 bits of the product assembly { let mm := mulmod(x, y, not(0)) prod0 := mul(x, y) prod1 := sub(sub(mm, prod0), lt(mm, prod0)) } // Handle non-overflow cases, 256 by 256 division. if (prod1 == 0) { return prod0 / denominator; } // Make sure the result is less than 2^256. Also prevents denominator == 0. require(denominator > prod1); /////////////////////////////////////////////// // 512 by 256 division. /////////////////////////////////////////////// // Make division exact by subtracting the remainder from [prod1 prod0]. uint256 remainder; assembly { // Compute remainder using mulmod. remainder := mulmod(x, y, denominator) // Subtract 256 bit number from 512 bit number. prod1 := sub(prod1, gt(remainder, prod0)) prod0 := sub(prod0, remainder) } // Factor powers of two out of denominator and compute largest power of two divisor of denominator. Always >= 1. // See https://cs.stackexchange.com/q/138556/92363. // Does not overflow because the denominator cannot be zero at this stage in the function. uint256 twos = denominator & (~denominator + 1); assembly { // Divide denominator by twos. denominator := div(denominator, twos) // Divide [prod1 prod0] by twos. prod0 := div(prod0, twos) // Flip twos such that it is 2^256 / twos. If twos is zero, then it becomes one. twos := add(div(sub(0, twos), twos), 1) } // Shift in bits from prod1 into prod0. prod0 |= prod1 * twos; // Invert denominator mod 2^256. Now that denominator is an odd number, it has an inverse modulo 2^256 such // that denominator * inv = 1 mod 2^256. Compute the inverse by starting with a seed that is correct for // four bits. That is, denominator * inv = 1 mod 2^4. uint256 inverse = (3 * denominator) ^ 2; // Use the Newton-Raphson iteration to improve the precision. Thanks to Hensel's lifting lemma, this also works // in modular arithmetic, doubling the correct bits in each step. inverse *= 2 - denominator * inverse; // inverse mod 2^8 inverse *= 2 - denominator * inverse; // inverse mod 2^16 inverse *= 2 - denominator * inverse; // inverse mod 2^32 inverse *= 2 - denominator * inverse; // inverse mod 2^64 inverse *= 2 - denominator * inverse; // inverse mod 2^128 inverse *= 2 - denominator * inverse; // inverse mod 2^256 // Because the division is now exact we can divide by multiplying with the modular inverse of denominator. // This will give us the correct result modulo 2^256. Since the preconditions guarantee that the outcome is // less than 2^256, this is the final result. We don't need to compute the high bits of the result and prod1 // is no longer required. result = prod0 * inverse; return result; } } /** * @notice Calculates x * y / denominator with full precision, following the selected rounding direction. */ function mulDiv( uint256 x, uint256 y, uint256 denominator, Rounding rounding ) internal pure returns (uint256) { uint256 result = mulDiv(x, y, denominator); if (rounding == Rounding.Up && mulmod(x, y, denominator) > 0) { result += 1; } return result; } /** * @dev Returns the square root of a number. If the number is not a perfect square, the value is rounded down. * * Inspired by Henry S. Warren, Jr.'s "Hacker's Delight" (Chapter 11). */ function sqrt(uint256 a) internal pure returns (uint256) { if (a == 0) { return 0; } // For our first guess, we get the biggest power of 2 which is smaller than the square root of the target. // // We know that the "msb" (most significant bit) of our target number `a` is a power of 2 such that we have // `msb(a) <= a < 2*msb(a)`. This value can be written `msb(a)=2**k` with `k=log2(a)`. // // This can be rewritten `2**log2(a) <= a < 2**(log2(a) + 1)` // → `sqrt(2**k) <= sqrt(a) < sqrt(2**(k+1))` // → `2**(k/2) <= sqrt(a) < 2**((k+1)/2) <= 2**(k/2 + 1)` // // Consequently, `2**(log2(a) / 2)` is a good first approximation of `sqrt(a)` with at least 1 correct bit. uint256 result = 1 << (log2(a) >> 1); // At this point `result` is an estimation with one bit of precision. We know the true value is a uint128, // since it is the square root of a uint256. Newton's method converges quadratically (precision doubles at // every iteration). We thus need at most 7 iteration to turn our partial result with one bit of precision // into the expected uint128 result. unchecked { result = (result + a / result) >> 1; result = (result + a / result) >> 1; result = (result + a / result) >> 1; result = (result + a / result) >> 1; result = (result + a / result) >> 1; result = (result + a / result) >> 1; result = (result + a / result) >> 1; return min(result, a / result); } } /** * @notice Calculates sqrt(a), following the selected rounding direction. */ function sqrt(uint256 a, Rounding rounding) internal pure returns (uint256) { unchecked { uint256 result = sqrt(a); return result + (rounding == Rounding.Up && result * result < a ? 1 : 0); } } /** * @dev Return the log in base 2, rounded down, of a positive value. * Returns 0 if given 0. */ function log2(uint256 value) internal pure returns (uint256) { uint256 result = 0; unchecked { if (value >> 128 > 0) { value >>= 128; result += 128; } if (value >> 64 > 0) { value >>= 64; result += 64; } if (value >> 32 > 0) { value >>= 32; result += 32; } if (value >> 16 > 0) { value >>= 16; result += 16; } if (value >> 8 > 0) { value >>= 8; result += 8; } if (value >> 4 > 0) { value >>= 4; result += 4; } if (value >> 2 > 0) { value >>= 2; result += 2; } if (value >> 1 > 0) { result += 1; } } return result; } /** * @dev Return the log in base 2, following the selected rounding direction, of a positive value. * Returns 0 if given 0. */ function log2(uint256 value, Rounding rounding) internal pure returns (uint256) { unchecked { uint256 result = log2(value); return result + (rounding == Rounding.Up && 1 << result < value ? 1 : 0); } } /** * @dev Return the log in base 10, rounded down, of a positive value. * Returns 0 if given 0. */ function log10(uint256 value) internal pure returns (uint256) { uint256 result = 0; unchecked { if (value >= 10**64) { value /= 10**64; result += 64; } if (value >= 10**32) { value /= 10**32; result += 32; } if (value >= 10**16) { value /= 10**16; result += 16; } if (value >= 10**8) { value /= 10**8; result += 8; } if (value >= 10**4) { value /= 10**4; result += 4; } if (value >= 10**2) { value /= 10**2; result += 2; } if (value >= 10**1) { result += 1; } } return result; } /** * @dev Return the log in base 10, following the selected rounding direction, of a positive value. * Returns 0 if given 0. */ function log10(uint256 value, Rounding rounding) internal pure returns (uint256) { unchecked { uint256 result = log10(value); return result + (rounding == Rounding.Up && 10**result < value ? 1 : 0); } } /** * @dev Return the log in base 256, rounded down, of a positive value. * Returns 0 if given 0. * * Adding one to the result gives the number of pairs of hex symbols needed to represent `value` as a hex string. */ function log256(uint256 value) internal pure returns (uint256) { uint256 result = 0; unchecked { if (value >> 128 > 0) { value >>= 128; result += 16; } if (value >> 64 > 0) { value >>= 64; result += 8; } if (value >> 32 > 0) { value >>= 32; result += 4; } if (value >> 16 > 0) { value >>= 16; result += 2; } if (value >> 8 > 0) { result += 1; } } return result; } /** * @dev Return the log in base 10, following the selected rounding direction, of a positive value. * Returns 0 if given 0. */ function log256(uint256 value, Rounding rounding) internal pure returns (uint256) { unchecked { uint256 result = log256(value); return result + (rounding == Rounding.Up && 1 << (result * 8) < value ? 1 : 0); } } }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts (last updated v4.8.0) (utils/cryptography/MerkleProof.sol) pragma solidity ^0.8.0; /** * @dev These functions deal with verification of Merkle Tree proofs. * * The tree and the proofs can be generated using our * https://github.com/OpenZeppelin/merkle-tree[JavaScript library]. * You will find a quickstart guide in the readme. * * WARNING: You should avoid using leaf values that are 64 bytes long prior to * hashing, or use a hash function other than keccak256 for hashing leaves. * This is because the concatenation of a sorted pair of internal nodes in * the merkle tree could be reinterpreted as a leaf value. * OpenZeppelin's JavaScript library generates merkle trees that are safe * against this attack out of the box. */ library MerkleProof { /** * @dev Returns true if a `leaf` can be proved to be a part of a Merkle tree * defined by `root`. For this, a `proof` must be provided, containing * sibling hashes on the branch from the leaf to the root of the tree. Each * pair of leaves and each pair of pre-images are assumed to be sorted. */ function verify( bytes32[] memory proof, bytes32 root, bytes32 leaf ) internal pure returns (bool) { return processProof(proof, leaf) == root; } /** * @dev Calldata version of {verify} * * _Available since v4.7._ */ function verifyCalldata( bytes32[] calldata proof, bytes32 root, bytes32 leaf ) internal pure returns (bool) { return processProofCalldata(proof, leaf) == root; } /** * @dev Returns the rebuilt hash obtained by traversing a Merkle tree up * from `leaf` using `proof`. A `proof` is valid if and only if the rebuilt * hash matches the root of the tree. When processing the proof, the pairs * of leafs & pre-images are assumed to be sorted. * * _Available since v4.4._ */ function processProof(bytes32[] memory proof, bytes32 leaf) internal pure returns (bytes32) { bytes32 computedHash = leaf; for (uint256 i = 0; i < proof.length; i++) { computedHash = _hashPair(computedHash, proof[i]); } return computedHash; } /** * @dev Calldata version of {processProof} * * _Available since v4.7._ */ function processProofCalldata(bytes32[] calldata proof, bytes32 leaf) internal pure returns (bytes32) { bytes32 computedHash = leaf; for (uint256 i = 0; i < proof.length; i++) { computedHash = _hashPair(computedHash, proof[i]); } return computedHash; } /** * @dev Returns true if the `leaves` can be simultaneously proven to be a part of a merkle tree defined by * `root`, according to `proof` and `proofFlags` as described in {processMultiProof}. * * CAUTION: Not all merkle trees admit multiproofs. See {processMultiProof} for details. * * _Available since v4.7._ */ function multiProofVerify( bytes32[] memory proof, bool[] memory proofFlags, bytes32 root, bytes32[] memory leaves ) internal pure returns (bool) { return processMultiProof(proof, proofFlags, leaves) == root; } /** * @dev Calldata version of {multiProofVerify} * * CAUTION: Not all merkle trees admit multiproofs. See {processMultiProof} for details. * * _Available since v4.7._ */ function multiProofVerifyCalldata( bytes32[] calldata proof, bool[] calldata proofFlags, bytes32 root, bytes32[] memory leaves ) internal pure returns (bool) { return processMultiProofCalldata(proof, proofFlags, leaves) == root; } /** * @dev Returns the root of a tree reconstructed from `leaves` and sibling nodes in `proof`. The reconstruction * proceeds by incrementally reconstructing all inner nodes by combining a leaf/inner node with either another * leaf/inner node or a proof sibling node, depending on whether each `proofFlags` item is true or false * respectively. * * CAUTION: Not all merkle trees admit multiproofs. To use multiproofs, it is sufficient to ensure that: 1) the tree * is complete (but not necessarily perfect), 2) the leaves to be proven are in the opposite order they are in the * tree (i.e., as seen from right to left starting at the deepest layer and continuing at the next layer). * * _Available since v4.7._ */ function processMultiProof( bytes32[] memory proof, bool[] memory proofFlags, bytes32[] memory leaves ) internal pure returns (bytes32 merkleRoot) { // This function rebuild the root hash by traversing the tree up from the leaves. The root is rebuilt by // consuming and producing values on a queue. The queue starts with the `leaves` array, then goes onto the // `hashes` array. At the end of the process, the last hash in the `hashes` array should contain the root of // the merkle tree. uint256 leavesLen = leaves.length; uint256 totalHashes = proofFlags.length; // Check proof validity. require(leavesLen + proof.length - 1 == totalHashes, "MerkleProof: invalid multiproof"); // The xxxPos values are "pointers" to the next value to consume in each array. All accesses are done using // `xxx[xxxPos++]`, which return the current value and increment the pointer, thus mimicking a queue's "pop". bytes32[] memory hashes = new bytes32[](totalHashes); uint256 leafPos = 0; uint256 hashPos = 0; uint256 proofPos = 0; // At each step, we compute the next hash using two values: // - a value from the "main queue". If not all leaves have been consumed, we get the next leaf, otherwise we // get the next hash. // - depending on the flag, either another value for the "main queue" (merging branches) or an element from the // `proof` array. for (uint256 i = 0; i < totalHashes; i++) { bytes32 a = leafPos < leavesLen ? leaves[leafPos++] : hashes[hashPos++]; bytes32 b = proofFlags[i] ? leafPos < leavesLen ? leaves[leafPos++] : hashes[hashPos++] : proof[proofPos++]; hashes[i] = _hashPair(a, b); } if (totalHashes > 0) { return hashes[totalHashes - 1]; } else if (leavesLen > 0) { return leaves[0]; } else { return proof[0]; } } /** * @dev Calldata version of {processMultiProof}. * * CAUTION: Not all merkle trees admit multiproofs. See {processMultiProof} for details. * * _Available since v4.7._ */ function processMultiProofCalldata( bytes32[] calldata proof, bool[] calldata proofFlags, bytes32[] memory leaves ) internal pure returns (bytes32 merkleRoot) { // This function rebuild the root hash by traversing the tree up from the leaves. The root is rebuilt by // consuming and producing values on a queue. The queue starts with the `leaves` array, then goes onto the // `hashes` array. At the end of the process, the last hash in the `hashes` array should contain the root of // the merkle tree. uint256 leavesLen = leaves.length; uint256 totalHashes = proofFlags.length; // Check proof validity. require(leavesLen + proof.length - 1 == totalHashes, "MerkleProof: invalid multiproof"); // The xxxPos values are "pointers" to the next value to consume in each array. All accesses are done using // `xxx[xxxPos++]`, which return the current value and increment the pointer, thus mimicking a queue's "pop". bytes32[] memory hashes = new bytes32[](totalHashes); uint256 leafPos = 0; uint256 hashPos = 0; uint256 proofPos = 0; // At each step, we compute the next hash using two values: // - a value from the "main queue". If not all leaves have been consumed, we get the next leaf, otherwise we // get the next hash. // - depending on the flag, either another value for the "main queue" (merging branches) or an element from the // `proof` array. for (uint256 i = 0; i < totalHashes; i++) { bytes32 a = leafPos < leavesLen ? leaves[leafPos++] : hashes[hashPos++]; bytes32 b = proofFlags[i] ? leafPos < leavesLen ? leaves[leafPos++] : hashes[hashPos++] : proof[proofPos++]; hashes[i] = _hashPair(a, b); } if (totalHashes > 0) { return hashes[totalHashes - 1]; } else if (leavesLen > 0) { return leaves[0]; } else { return proof[0]; } } function _hashPair(bytes32 a, bytes32 b) private pure returns (bytes32) { return a < b ? _efficientHash(a, b) : _efficientHash(b, a); } function _efficientHash(bytes32 a, bytes32 b) private pure returns (bytes32 value) { /// @solidity memory-safe-assembly assembly { mstore(0x00, a) mstore(0x20, b) value := keccak256(0x00, 0x40) } } }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts (last updated v4.7.0) (access/Ownable.sol) pragma solidity ^0.8.0; import "./Context.sol"; /** * @dev Contract module which provides a basic access control mechanism, where * there is an account (an owner) that can be granted exclusive access to * specific functions. * * By default, the owner account will be the one that deploys the contract. This * can later be changed with {transferOwnership}. * * This module is used through inheritance. It will make available the modifier * `onlyOwner`, which can be applied to your functions to restrict their use to * the owner. */ abstract contract Ownable is Context { address private _owner; event OwnershipTransferred(address indexed previousOwner, address indexed newOwner); /** * @dev Initializes the contract setting the deployer as the initial owner. */ constructor() { _transferOwnership(_msgSender()); } /** * @dev Throws if called by any account other than the owner. */ modifier onlyOwner() { _checkOwner(); _; } /** * @dev Returns the address of the current owner. */ function owner() public view virtual returns (address) { return _owner; } /** * @dev Throws if the sender is not the owner. */ function _checkOwner() internal view virtual { require(owner() == _msgSender(), "Ownable: caller is not the owner"); } /** * @dev Leaves the contract without owner. It will not be possible to call * `onlyOwner` functions anymore. Can only be called by the current owner. * * NOTE: Renouncing ownership will leave the contract without an owner, * thereby removing any functionality that is only available to the owner. */ function renounceOwnership() public virtual onlyOwner { _transferOwnership(address(0)); } /** * @dev Transfers ownership of the contract to a new account (`newOwner`). * Can only be called by the current owner. */ function transferOwnership(address newOwner) public virtual onlyOwner { require(newOwner != address(0), "Ownable: new owner is the zero address"); _transferOwnership(newOwner); } /** * @dev Transfers ownership of the contract to a new account (`newOwner`). * Internal function without access restriction. */ function _transferOwnership(address newOwner) internal virtual { address oldOwner = _owner; _owner = newOwner; emit OwnershipTransferred(oldOwner, newOwner); } }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts (last updated v4.8.0) (security/ReentrancyGuard.sol) pragma solidity ^0.8.0; /** * @dev Contract module that helps prevent reentrant calls to a function. * * Inheriting from `ReentrancyGuard` will make the {nonReentrant} modifier * available, which can be applied to functions to make sure there are no nested * (reentrant) calls to them. * * Note that because there is a single `nonReentrant` guard, functions marked as * `nonReentrant` may not call one another. This can be worked around by making * those functions `private`, and then adding `external` `nonReentrant` entry * points to them. * * TIP: If you would like to learn more about reentrancy and alternative ways * to protect against it, check out our blog post * https://blog.openzeppelin.com/reentrancy-after-istanbul/[Reentrancy After Istanbul]. */ abstract contract ReentrancyGuard { // Booleans are more expensive than uint256 or any type that takes up a full // word because each write operation emits an extra SLOAD to first read the // slot's contents, replace the bits taken up by the boolean, and then write // back. This is the compiler's defense against contract upgrades and // pointer aliasing, and it cannot be disabled. // The values being non-zero value makes deployment a bit more expensive, // but in exchange the refund on every call to nonReentrant will be lower in // amount. Since refunds are capped to a percentage of the total // transaction's gas, it is best to keep them low in cases like this one, to // increase the likelihood of the full refund coming into effect. uint256 private constant _NOT_ENTERED = 1; uint256 private constant _ENTERED = 2; uint256 private _status; constructor() { _status = _NOT_ENTERED; } /** * @dev Prevents a contract from calling itself, directly or indirectly. * Calling a `nonReentrant` function from another `nonReentrant` * function is not supported. It is possible to prevent this from happening * by making the `nonReentrant` function external, and making it call a * `private` function that does the actual work. */ modifier nonReentrant() { _nonReentrantBefore(); _; _nonReentrantAfter(); } function _nonReentrantBefore() private { // On the first call to nonReentrant, _status will be _NOT_ENTERED require(_status != _ENTERED, "ReentrancyGuard: reentrant call"); // Any calls to nonReentrant after this point will fail _status = _ENTERED; } function _nonReentrantAfter() private { // By storing the original value once again, a refund is triggered (see // https://eips.ethereum.org/EIPS/eip-2200) _status = _NOT_ENTERED; } }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts (last updated v4.8.0) (utils/Strings.sol) pragma solidity ^0.8.0; import "./Math.sol"; /** * @dev String operations. */ library Strings { bytes16 private constant _SYMBOLS = "0123456789abcdef"; uint8 private constant _ADDRESS_LENGTH = 20; /** * @dev Converts a `uint256` to its ASCII `string` decimal representation. */ function toString(uint256 value) internal pure returns (string memory) { unchecked { uint256 length = Math.log10(value) + 1; string memory buffer = new string(length); uint256 ptr; /// @solidity memory-safe-assembly assembly { ptr := add(buffer, add(32, length)) } while (true) { ptr--; /// @solidity memory-safe-assembly assembly { mstore8(ptr, byte(mod(value, 10), _SYMBOLS)) } value /= 10; if (value == 0) break; } return buffer; } } /** * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation. */ function toHexString(uint256 value) internal pure returns (string memory) { unchecked { return toHexString(value, Math.log256(value) + 1); } } /** * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation with fixed length. */ function toHexString(uint256 value, uint256 length) internal pure returns (string memory) { bytes memory buffer = new bytes(2 * length + 2); buffer[0] = "0"; buffer[1] = "x"; for (uint256 i = 2 * length + 1; i > 1; --i) { buffer[i] = _SYMBOLS[value & 0xf]; value >>= 4; } require(value == 0, "Strings: hex length insufficient"); return string(buffer); } /** * @dev Converts an `address` with fixed length of 20 bytes to its not checksummed ASCII `string` hexadecimal representation. */ function toHexString(address addr) internal pure returns (string memory) { return toHexString(uint256(uint160(addr)), _ADDRESS_LENGTH); } }
Contract Security Audit
- No Contract Security Audit Submitted- Submit Audit Here
[{"inputs":[{"internalType":"string","name":"_tokenName","type":"string"},{"internalType":"string","name":"_tokenSymbol","type":"string"},{"internalType":"uint256","name":"_cost","type":"uint256"},{"internalType":"uint256","name":"_maxSupply","type":"uint256"},{"internalType":"uint256","name":"_maxMintAmountPerTx","type":"uint256"},{"internalType":"string","name":"_hiddenMetadataUri","type":"string"}],"stateMutability":"nonpayable","type":"constructor"},{"inputs":[],"name":"ApprovalCallerNotOwnerNorApproved","type":"error"},{"inputs":[],"name":"ApprovalQueryForNonexistentToken","type":"error"},{"inputs":[],"name":"BalanceQueryForZeroAddress","type":"error"},{"inputs":[],"name":"InvalidQueryRange","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":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":true,"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"Transfer","type":"event"},{"inputs":[],"name":"PeeCoinContract","outputs":[{"internalType":"contract IERC20","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"Peeaddress","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"approve","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"cost","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"explicitOwnershipOf","outputs":[{"components":[{"internalType":"address","name":"addr","type":"address"},{"internalType":"uint64","name":"startTimestamp","type":"uint64"},{"internalType":"bool","name":"burned","type":"bool"},{"internalType":"uint24","name":"extraData","type":"uint24"}],"internalType":"struct IERC721A.TokenOwnership","name":"ownership","type":"tuple"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256[]","name":"tokenIds","type":"uint256[]"}],"name":"explicitOwnershipsOf","outputs":[{"components":[{"internalType":"address","name":"addr","type":"address"},{"internalType":"uint64","name":"startTimestamp","type":"uint64"},{"internalType":"bool","name":"burned","type":"bool"},{"internalType":"uint24","name":"extraData","type":"uint24"}],"internalType":"struct IERC721A.TokenOwnership[]","name":"","type":"tuple[]"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"getApproved","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"hiddenMetadataUri","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256[]","name":"tokenIds","type":"uint256[]"}],"name":"holderClaim","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"holderClaim_state","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"operator","type":"address"}],"name":"isApprovedForAll","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"isClaim","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"isfree","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxMintAmountPerTx","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxPerFree","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"merkleRoot","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_mintAmount","type":"uint256"}],"name":"mint","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_mintAmount","type":"uint256"},{"internalType":"address","name":"_receiver","type":"address"}],"name":"mintForAddress","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"mintedAmount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"ownerOf","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"paused","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"revealed","outputs":[{"internalType":"bool","name":"","type":"bool"}],"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":"payable","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":"payable","type":"function"},{"inputs":[{"internalType":"address","name":"operator","type":"address"},{"internalType":"bool","name":"approved","type":"bool"}],"name":"setApprovalForAll","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_cost","type":"uint256"}],"name":"setCost","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"string","name":"_hiddenMetadataUri","type":"string"}],"name":"setHiddenMetadataUri","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_maxMintAmountPerTx","type":"uint256"}],"name":"setMaxMintAmountPerTx","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"freenum_","type":"uint256"}],"name":"setMaxPerFree","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bytes32","name":"_merkleRoot","type":"bytes32"}],"name":"setMerkleRoot","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"_state","type":"bool"}],"name":"setPaused","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"Peeadd_","type":"address"}],"name":"setPeecoinaddress","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"_state","type":"bool"}],"name":"setRevealed","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"string","name":"_uriPrefix","type":"string"}],"name":"setUriPrefix","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"string","name":"_uriSuffix","type":"string"}],"name":"setUriSuffix","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"_state","type":"bool"}],"name":"setWhitelistMintEnabled","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"freenum","type":"uint256"}],"name":"setWhitelistPerFree","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bool","name":"_state","type":"bool"}],"name":"setholderClaimstate","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":"_tokenId","type":"uint256"}],"name":"tokenURI","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"}],"name":"tokensOfOwner","outputs":[{"internalType":"uint256[]","name":"","type":"uint256[]"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"uint256","name":"start","type":"uint256"},{"internalType":"uint256","name":"stop","type":"uint256"}],"name":"tokensOfOwnerIn","outputs":[{"internalType":"uint256[]","name":"","type":"uint256[]"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalFreeMinted","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"transferFrom","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"uriPrefix","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"uriSuffix","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"whitelistClaimed","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_mintAmount","type":"uint256"},{"internalType":"bytes32[]","name":"_merkleProof","type":"bytes32[]"}],"name":"whitelistMint","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[],"name":"whitelistMintEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"whitelistPerFree","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"withdraw","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"Amount_","type":"uint256"}],"name":"withdrawPeetoken","outputs":[],"stateMutability":"nonpayable","type":"function"}]
Contract Creation Code
6010805460ff60a01b191690556001601155600360125560a0604081905260006080819052620000329160139162000225565b5060408051808201909152600580825264173539b7b760d91b6020909201918252620000619160149162000225565b506000601655601a805462ffffff191660011790553480156200008357600080fd5b506040516200333638038062003336833981016040819052620000a69162000398565b855186908690620000bf90600290602085019062000225565b508051620000d590600390602084019062000225565b5050600160005550620000e83362000131565b6001600955620000f88462000183565b6018839055601080546001600160a01b031916301790556200011a8262000192565b6200012581620001a1565b50505050505062000482565b600880546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6200018d620001c4565b601755565b6200019c620001c4565b601955565b620001ab620001c4565b8051620001c090601590602084019062000225565b5050565b6008546001600160a01b03163314620002235760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015260640160405180910390fd5b565b828054620002339062000445565b90600052602060002090601f016020900481019282620002575760008555620002a2565b82601f106200027257805160ff1916838001178555620002a2565b82800160010185558215620002a2579182015b82811115620002a257825182559160200191906001019062000285565b50620002b0929150620002b4565b5090565b5b80821115620002b05760008155600101620002b5565b634e487b7160e01b600052604160045260246000fd5b600082601f830112620002f357600080fd5b81516001600160401b0380821115620003105762000310620002cb565b604051601f8301601f19908116603f011681019082821181831017156200033b576200033b620002cb565b816040528381526020925086838588010111156200035857600080fd5b600091505b838210156200037c57858201830151818301840152908201906200035d565b838211156200038e5760008385830101525b9695505050505050565b60008060008060008060c08789031215620003b257600080fd5b86516001600160401b0380821115620003ca57600080fd5b620003d88a838b01620002e1565b97506020890151915080821115620003ef57600080fd5b620003fd8a838b01620002e1565b965060408901519550606089015194506080890151935060a08901519150808211156200042957600080fd5b506200043889828a01620002e1565b9150509295509295509295565b600181811c908216806200045a57607f821691505b602082108114156200047c57634e487b7160e01b600052602260045260246000fd5b50919050565b612ea480620004926000396000f3fe6080604052600436106103975760003560e01c80637cb64759116101dc578063c7c39ffc11610102578063e0a80853116100a0578063efbd73f41161006f578063efbd73f414610a7a578063f1a631ec14610a9a578063f2fde38b14610abb578063fbbf8cc314610adb57600080fd5b8063e0a80853146109d1578063e945971c146109f1578063e985e9c514610a11578063ef29948914610a5a57600080fd5b8063d5abeb01116100dc578063d5abeb0114610955578063dad7b5c91461096b578063db4bec4414610981578063dc8c3270146109b157600080fd5b8063c7c39ffc1461090c578063c87b56dd14610922578063d2cab0561461094257600080fd5b806399a2557a1161017a578063b071401b11610149578063b071401b1461088c578063b767a098146108ac578063b88d4fde146108cc578063c23dc68f146108df57600080fd5b806399a2557a14610824578063a0712d6814610844578063a22cb46514610857578063a45ba8e71461087757600080fd5b80638da5cb5b116101b65780638da5cb5b146107bb57806394354fd0146107d957806395d89b41146107ef57806398dfe50b1461080457600080fd5b80637cb647591461074e5780637ec4a6591461076e5780638462151c1461078e57600080fd5b80634fdd43cb116102c15780635c975abb1161025f5780636caede3d1161022e5780636caede3d146106ca57806370a08231146106e9578063715018a614610709578063745308e71461071e57600080fd5b80635c975abb1461065b57806362b99ad4146106755780636352211e1461068a57806364febc38146106aa57600080fd5b80635503a0e81161029b5780635503a0e8146105d957806357a2e24b146105ee57806359236f3a1461060e5780635bbb21771461062e57600080fd5b80634fdd43cb146105795780635183022714610599578063542d878b146105b957600080fd5b806316c38b3c116103395780633c4ed0ad116103085780633c4ed0ad1461051b5780633ccfd60b1461053157806342842e0e1461054657806344a0d68a1461055957600080fd5b806316c38b3c146104b457806318160ddd146104d457806323b872dd146104f25780632eb4a7ab1461050557600080fd5b8063081812fc11610375578063081812fc14610423578063095ea7b31461045b57806313faede61461047057806316ba10e01461049457600080fd5b806301ffc9a71461039c57806306fdde03146103d157806307cfa41b146103f3575b600080fd5b3480156103a857600080fd5b506103bc6103b73660046125bf565b610b08565b60405190151581526020015b60405180910390f35b3480156103dd57600080fd5b506103e6610b5a565b6040516103c89190612634565b3480156103ff57600080fd5b506103bc61040e366004612647565b600e6020526000908152604090205460ff1681565b34801561042f57600080fd5b5061044361043e366004612647565b610bec565b6040516001600160a01b0390911681526020016103c8565b61046e610469366004612677565b610c27565b005b34801561047c57600080fd5b5061048660175481565b6040519081526020016103c8565b3480156104a057600080fd5b5061046e6104af366004612740565b610c37565b3480156104c057600080fd5b5061046e6104cf366004612797565b610c52565b3480156104e057600080fd5b50610486600154600054036000190190565b61046e6105003660046127b4565b610c6d565b34801561051157600080fd5b50610486600a5481565b34801561052757600080fd5b5061048660125481565b34801561053d57600080fd5b5061046e610dc8565b61046e6105543660046127b4565b610e56565b34801561056557600080fd5b5061046e610574366004612647565b610e76565b34801561058557600080fd5b5061046e610594366004612740565b610e83565b3480156105a557600080fd5b50601a546103bc9062010000900460ff1681565b3480156105c557600080fd5b5061046e6105d4366004612647565b610e9e565b3480156105e557600080fd5b506103e6610eab565b3480156105fa57600080fd5b50600f54610443906001600160a01b031681565b34801561061a57600080fd5b5061046e6106293660046127f0565b610f39565b34801561063a57600080fd5b5061064e610649366004612857565b610f63565b6040516103c891906128d6565b34801561066757600080fd5b50601a546103bc9060ff1681565b34801561068157600080fd5b506103e6610faf565b34801561069657600080fd5b506104436106a5366004612647565b610fbc565b3480156106b657600080fd5b5061046e6106c5366004612918565b610fc7565b3480156106d657600080fd5b50601a546103bc90610100900460ff1681565b3480156106f557600080fd5b506104866107043660046127f0565b6111a8565b34801561071557600080fd5b5061046e6111ee565b34801561072a57600080fd5b506103bc6107393660046127f0565b600d6020526000908152604090205460ff1681565b34801561075a57600080fd5b5061046e610769366004612647565b611200565b34801561077a57600080fd5b5061046e610789366004612740565b61120d565b34801561079a57600080fd5b506107ae6107a93660046127f0565b611228565b6040516103c891906129be565b3480156107c757600080fd5b506008546001600160a01b0316610443565b3480156107e557600080fd5b5061048660195481565b3480156107fb57600080fd5b506103e661124f565b34801561081057600080fd5b5061046e61081f366004612797565b61125e565b34801561083057600080fd5b506107ae61083f3660046129f6565b611284565b61046e610852366004612647565b611291565b34801561086357600080fd5b5061046e610872366004612a29565b6114f1565b34801561088357600080fd5b506103e661155d565b34801561089857600080fd5b5061046e6108a7366004612647565b61156a565b3480156108b857600080fd5b5061046e6108c7366004612797565b611577565b61046e6108da366004612a60565b611599565b3480156108eb57600080fd5b506108ff6108fa366004612647565b6115da565b6040516103c89190612adc565b34801561091857600080fd5b5061048660115481565b34801561092e57600080fd5b506103e661093d366004612647565b61163e565b61046e610950366004612aea565b6117ae565b34801561096157600080fd5b5061048660185481565b34801561097757600080fd5b5061048660165481565b34801561098d57600080fd5b506103bc61099c3660046127f0565b600b6020526000908152604090205460ff1681565b3480156109bd57600080fd5b5061046e6109cc366004612647565b611b07565b3480156109dd57600080fd5b5061046e6109ec366004612797565b611bb2565b3480156109fd57600080fd5b5061046e610a0c366004612647565b611bd6565b348015610a1d57600080fd5b506103bc610a2c366004612b36565b6001600160a01b03918216600090815260076020908152604080832093909416825291909152205460ff1690565b348015610a6657600080fd5b50601054610443906001600160a01b031681565b348015610a8657600080fd5b5061046e610a95366004612b69565b611be3565b348015610aa657600080fd5b506010546103bc90600160a01b900460ff1681565b348015610ac757600080fd5b5061046e610ad63660046127f0565b611c60565b348015610ae757600080fd5b50610486610af63660046127f0565b600c6020526000908152604090205481565b60006301ffc9a760e01b6001600160e01b031983161480610b3957506380ac58cd60e01b6001600160e01b03198316145b80610b545750635b5e139f60e01b6001600160e01b03198316145b92915050565b606060028054610b6990612b8c565b80601f0160208091040260200160405190810160405280929190818152602001828054610b9590612b8c565b8015610be25780601f10610bb757610100808354040283529160200191610be2565b820191906000526020600020905b815481529060010190602001808311610bc557829003601f168201915b5050505050905090565b6000610bf782611cd6565b610c0b57610c0b6333d1c03960e21b611d1f565b506000908152600660205260409020546001600160a01b031690565b610c3382826001611d29565b5050565b610c3f611dcc565b8051610c33906014906020840190612510565b610c5a611dcc565b601a805460ff1916911515919091179055565b6000610c7882611e26565b6001600160a01b039485169490915081168414610c9e57610c9e62a1148160e81b611d1f565b60008281526006602052604090208054338082146001600160a01b03881690911417610ce257610cce8633610a2c565b610ce257610ce2632ce44b5f60e11b611d1f565b8015610ced57600082555b6001600160a01b038681166000908152600560205260408082208054600019019055918716808252919020805460010190554260a01b17600160e11b17600085815260046020526040902055600160e11b8316610d785760018401600081815260046020526040902054610d76576000548114610d765760008181526004602052604090208490555b505b6001600160a01b0385168481887fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef600080a480610dbf57610dbf633a954ecd60e21b611d1f565b50505050505050565b610dd0611dcc565b610dd8611ec2565b6000610dec6008546001600160a01b031690565b6001600160a01b03164760405160006040518083038185875af1925050503d8060008114610e36576040519150601f19603f3d011682016040523d82523d6000602084013e610e3b565b606091505b5050905080610e4957600080fd5b50610e546001600955565b565b610e7183838360405180602001604052806000815250611599565b505050565b610e7e611dcc565b601755565b610e8b611dcc565b8051610c33906015906020840190612510565b610ea6611dcc565b601255565b60148054610eb890612b8c565b80601f0160208091040260200160405190810160405280929190818152602001828054610ee490612b8c565b8015610f315780601f10610f0657610100808354040283529160200191610f31565b820191906000526020600020905b815481529060010190602001808311610f1457829003601f168201915b505050505081565b610f41611dcc565b600f80546001600160a01b0319166001600160a01b0392909216919091179055565b60408051828152600583901b8082016020019092526060915b8015610fa757601f1980820191860101356000610f98826115da565b8484016020015250610f7c9050565b509392505050565b60138054610eb890612b8c565b6000610b5482611e26565b601054600160a01b900460ff166110355760405162461bcd60e51b815260206004820152602760248201527f416374697669747920726564656d7074696f6e20686173206e6f7420796574206044820152661cdd185c9d195960ca1b60648201526084015b60405180910390fd5b805169010f0cf064dd59200000903360005b828110156111a157600085828151811061106357611063612bc7565b60200260200101519050826001600160a01b031661108082610fbc565b6001600160a01b0316146110d65760405162461bcd60e51b815260206004820152601860248201527f596f7520646f6e2774206f776e207468697320746f6b656e0000000000000000604482015260640161102c565b6000818152600e602052604090205460ff1661118e576000818152600e602052604090819020805460ff19166001179055600f54905163a9059cbb60e01b81526001600160a01b038581166004830152602482018890529091169063a9059cbb90604401602060405180830381600087803b15801561115457600080fd5b505af1158015611168573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061118c9190612bdd565b505b508061119981612c10565b915050611047565b5050505050565b60006001600160a01b0382166111c8576111c86323d3ad8160e21b611d1f565b506001600160a01b031660009081526005602052604090205467ffffffffffffffff1690565b6111f6611dcc565b610e546000611f1c565b611208611dcc565b600a55565b611215611dcc565b8051610c33906013906020840190612510565b6000546060906001908282821461124757611244858484611f6e565b90505b949350505050565b606060038054610b6990612b8c565b611266611dcc565b60108054911515600160a01b0260ff60a01b19909216919091179055565b6060611247848484611f6e565b6000811180156112a357506019548111155b6112bf5760405162461bcd60e51b815260040161102c90612c2b565b601854816112d4600154600054036000190190565b6112de9190612c59565b11156112fc5760405162461bcd60e51b815260040161102c90612c71565b601a5460ff161561134f5760405162461bcd60e51b815260206004820152601760248201527f54686520636f6e74726163742069732070617573656421000000000000000000604482015260640161102c565b33321461139e5760405162461bcd60e51b815260206004820152601e60248201527f546865206d696e74657220697320616e6f7468657220636f6e74726163740000604482015260640161102c565b336000908152600c60205260409020546014906113bc908390612c59565b11156113da5760405162461bcd60e51b815260040161102c90612c9f565b336000908152600d602052604090205460ff16611493576011546017546114019190612cd6565b60175461140e9083612cd6565b6114189190612cf5565b3410156114375760405162461bcd60e51b815260040161102c90612d0c565b6011546016600082825461144b9190612c59565b9091555050336000908152600c60205260408120805483929061146f908490612c59565b9091555050336000908152600d60205260409020805460ff191660011790556114e4565b6017546114a09082612cd6565b3410156114bf5760405162461bcd60e51b815260040161102c90612d0c565b336000908152600c6020526040812080548392906114de908490612c59565b90915550505b6114ee338261206d565b50565b3360008181526007602090815260408083206001600160a01b03871680855290835292819020805460ff191686151590811790915590519081529192917f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c31910160405180910390a35050565b60158054610eb890612b8c565b611572611dcc565b601955565b61157f611dcc565b601a80549115156101000261ff0019909216919091179055565b6115a4848484610c6d565b6001600160a01b0383163b156115d4576115c084848484612087565b6115d4576115d46368d2bf6b60e11b611d1f565b50505050565b6040805160808101825260008082526020820181905291810182905260608101919091526001821061163957600054821015611639575b6000828152600460205260409020546116305760001990910190611611565b610b5482612175565b919050565b606061164982611cd6565b6116ad5760405162461bcd60e51b815260206004820152602f60248201527f4552433732314d657461646174613a2055524920717565727920666f72206e6f60448201526e3732bc34b9ba32b73a103a37b5b2b760891b606482015260840161102c565b601a5462010000900460ff1661174f57601580546116ca90612b8c565b80601f01602080910402602001604051908101604052809291908181526020018280546116f690612b8c565b80156117435780601f1061171857610100808354040283529160200191611743565b820191906000526020600020905b81548152906001019060200180831161172657829003601f168201915b50505050509050919050565b60006117596121f4565b9050600081511161177957604051806020016040528060008152506117a7565b8061178384612203565b601460405160200161179793929190612d39565b6040516020818303038152906040525b9392505050565b6000831180156117c057506019548311155b6117dc5760405162461bcd60e51b815260040161102c90612c2b565b601854836117f1600154600054036000190190565b6117fb9190612c59565b11156118195760405162461bcd60e51b815260040161102c90612c71565b6012546017546118299190612cd6565b836017546118379190612cd6565b6118419190612cf5565b3410156118605760405162461bcd60e51b815260040161102c90612d0c565b601a54610100900460ff166118c25760405162461bcd60e51b815260206004820152602260248201527f5468652077686974656c6973742073616c65206973206e6f7420656e61626c65604482015261642160f01b606482015260840161102c565b336000908152600b602052604090205460ff16156119225760405162461bcd60e51b815260206004820152601860248201527f4164647265737320616c726561647920636c61696d6564210000000000000000604482015260640161102c565b6040516bffffffffffffffffffffffff193360601b16602082015260009060340160408051808303601f19018152919052805160209091012090503332146119ac5760405162461bcd60e51b815260206004820152601e60248201527f546865206d696e74657220697320616e6f7468657220636f6e74726163740000604482015260640161102c565b6119ed83838080602002602001604051908101604052809392919081815260200183836020028082843760009201919091525050600a549150849050612298565b611a2a5760405162461bcd60e51b815260206004820152600e60248201526d496e76616c69642070726f6f662160901b604482015260640161102c565b336000908152600c6020526040902054601411611a595760405162461bcd60e51b815260040161102c90612c9f565b336000908152600c6020526040902054601490611a77908690612c59565b1115611a955760405162461bcd60e51b815260040161102c90612c9f565b60125460166000828254611aa99190612c59565b9091555050336000908152600b602090815260408083208054600160ff199182168117909255600d845282852080549091169091179055600c90915281208054869290611af7908490612c59565b909155506115d49050338561206d565b611b0f611dcc565b600f546001600160a01b031663a9059cbb611b326008546001600160a01b031690565b6040516001600160e01b031960e084901b1681526001600160a01b03909116600482015260248101849052604401602060405180830381600087803b158015611b7a57600080fd5b505af1158015611b8e573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610c339190612bdd565b611bba611dcc565b601a8054911515620100000262ff000019909216919091179055565b611bde611dcc565b601155565b611beb611dcc565b600082118015611bfd57506019548211155b611c195760405162461bcd60e51b815260040161102c90612c2b565b60185482611c2e600154600054036000190190565b611c389190612c59565b1115611c565760405162461bcd60e51b815260040161102c90612c71565b610c33818361206d565b611c68611dcc565b6001600160a01b038116611ccd5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b606482015260840161102c565b6114ee81611f1c565b600081600111611639576000548210156116395760005b5060008281526004602052604090205480611d1257611d0b83612dfd565b9250611ced565b600160e01b161592915050565b8060005260046000fd5b6000611d3483610fbc565b9050818015611d4c5750336001600160a01b03821614155b15611d6f57611d5b8133610a2c565b611d6f57611d6f6367d9dca160e11b611d1f565b60008381526006602052604080822080546001600160a01b0319166001600160a01b0388811691821790925591518693918516917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591a450505050565b6008546001600160a01b03163314610e545760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015260640161102c565b600081600111611eb2575060008181526004602052604090205480611ea2576000548210611e5e57611e5e636f96cda160e11b611d1f565b5b506000190160008181526004602052604090205480611e7d57611e5f565b600160e01b8116611e8d57919050565b611e9d636f96cda160e11b611d1f565b611e5f565b600160e01b8116611eb257919050565b611639636f96cda160e11b611d1f565b60026009541415611f155760405162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c00604482015260640161102c565b6002600955565b600880546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6060818310611f8757611f87631960ccad60e11b611d1f565b6001831015611f9557600192505b600054808310611fa3578092505b60606000611fb0876111a8565b85871090810291508115612061578187870311611fcd5786860391505b60405192506001820160051b83016040526000611fe9886115da565b905060008160400151611ffa575080515b60005b6120068a612175565b925060408301516000811461201e5760009250612043565b83511561202a57835192505b8b831860601b612043576001820191508a8260051b8801525b5060018a019950888a148061205757508481145b15611ffd57855250505b50909695505050505050565b610c338282604051806020016040528060008152506122ae565b604051630a85bd0160e11b81526000906001600160a01b0385169063150b7a02906120bc903390899088908890600401612e14565b602060405180830381600087803b1580156120d657600080fd5b505af1925050508015612106575060408051601f3d908101601f1916820190925261210391810190612e51565b60015b612158573d808015612134576040519150601f19603f3d011682016040523d82523d6000602084013e612139565b606091505b508051612150576121506368d2bf6b60e11b611d1f565b805181602001fd5b6001600160e01b031916630a85bd0160e11b149050949350505050565b604080516080810182526000808252602082018190529181018290526060810191909152600082815260046020526040902054610b5490604080516080810182526001600160a01b038316815260a083901c67ffffffffffffffff166020820152600160e01b831615159181019190915260e89190911c606082015290565b606060138054610b6990612b8c565b6060600061221083612310565b600101905060008167ffffffffffffffff811115612230576122306126a1565b6040519080825280601f01601f19166020018201604052801561225a576020820181803683370190505b5090508181016020015b600019016f181899199a1a9b1b9c1cb0b131b232b360811b600a86061a8153600a850494508461229357610fa7565b612264565b6000826122a585846123e8565b14949350505050565b6122b8838361242d565b6001600160a01b0383163b15610e71576000548281035b6122e26000868380600101945086612087565b6122f6576122f66368d2bf6b60e11b611d1f565b8181106122cf5781600054146111a1576111a16000611d1f565b60008072184f03e93ff9f4daa797ed6e38ed64bf6a1f0160401b831061234f5772184f03e93ff9f4daa797ed6e38ed64bf6a1f0160401b830492506040015b6d04ee2d6d415b85acef8100000000831061237b576d04ee2d6d415b85acef8100000000830492506020015b662386f26fc10000831061239957662386f26fc10000830492506010015b6305f5e10083106123b1576305f5e100830492506008015b61271083106123c557612710830492506004015b606483106123d7576064830492506002015b600a8310610b545760010192915050565b600081815b8451811015610fa7576124198286838151811061240c5761240c612bc7565b60200260200101516124e4565b91508061242581612c10565b9150506123ed565b600054816124455761244563b562e8dd60e01b611d1f565b60008181526004602090815260408083206001600160a01b0387164260a01b6001881460e11b17811790915580845260059092529091208054680100000000000000018502019055806124a1576124a1622e076360e81b611d1f565b818301825b808360007fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef600080a4600101808214156124a6575060005550505050565b60008183106125005760008281526020849052604090206117a7565b5060009182526020526040902090565b82805461251c90612b8c565b90600052602060002090601f01602090048101928261253e5760008555612584565b82601f1061255757805160ff1916838001178555612584565b82800160010185558215612584579182015b82811115612584578251825591602001919060010190612569565b50612590929150612594565b5090565b5b808211156125905760008155600101612595565b6001600160e01b0319811681146114ee57600080fd5b6000602082840312156125d157600080fd5b81356117a7816125a9565b60005b838110156125f75781810151838201526020016125df565b838111156115d45750506000910152565b600081518084526126208160208601602086016125dc565b601f01601f19169290920160200192915050565b6020815260006117a76020830184612608565b60006020828403121561265957600080fd5b5035919050565b80356001600160a01b038116811461163957600080fd5b6000806040838503121561268a57600080fd5b61269383612660565b946020939093013593505050565b634e487b7160e01b600052604160045260246000fd5b604051601f8201601f1916810167ffffffffffffffff811182821017156126e0576126e06126a1565b604052919050565b600067ffffffffffffffff831115612702576127026126a1565b612715601f8401601f19166020016126b7565b905082815283838301111561272957600080fd5b828260208301376000602084830101529392505050565b60006020828403121561275257600080fd5b813567ffffffffffffffff81111561276957600080fd5b8201601f8101841361277a57600080fd5b611247848235602084016126e8565b80151581146114ee57600080fd5b6000602082840312156127a957600080fd5b81356117a781612789565b6000806000606084860312156127c957600080fd5b6127d284612660565b92506127e060208501612660565b9150604084013590509250925092565b60006020828403121561280257600080fd5b6117a782612660565b60008083601f84011261281d57600080fd5b50813567ffffffffffffffff81111561283557600080fd5b6020830191508360208260051b850101111561285057600080fd5b9250929050565b6000806020838503121561286a57600080fd5b823567ffffffffffffffff81111561288157600080fd5b61288d8582860161280b565b90969095509350505050565b80516001600160a01b0316825260208082015167ffffffffffffffff169083015260408082015115159083015260609081015162ffffff16910152565b6020808252825182820181905260009190848201906040850190845b8181101561206157612905838551612899565b92840192608092909201916001016128f2565b6000602080838503121561292b57600080fd5b823567ffffffffffffffff8082111561294357600080fd5b818501915085601f83011261295757600080fd5b813581811115612969576129696126a1565b8060051b915061297a8483016126b7565b818152918301840191848101908884111561299457600080fd5b938501935b838510156129b257843582529385019390850190612999565b98975050505050505050565b6020808252825182820181905260009190848201906040850190845b81811015612061578351835292840192918401916001016129da565b600080600060608486031215612a0b57600080fd5b612a1484612660565b95602085013595506040909401359392505050565b60008060408385031215612a3c57600080fd5b612a4583612660565b91506020830135612a5581612789565b809150509250929050565b60008060008060808587031215612a7657600080fd5b612a7f85612660565b9350612a8d60208601612660565b925060408501359150606085013567ffffffffffffffff811115612ab057600080fd5b8501601f81018713612ac157600080fd5b612ad0878235602084016126e8565b91505092959194509250565b60808101610b548284612899565b600080600060408486031215612aff57600080fd5b83359250602084013567ffffffffffffffff811115612b1d57600080fd5b612b298682870161280b565b9497909650939450505050565b60008060408385031215612b4957600080fd5b612b5283612660565b9150612b6060208401612660565b90509250929050565b60008060408385031215612b7c57600080fd5b82359150612b6060208401612660565b600181811c90821680612ba057607f821691505b60208210811415612bc157634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052603260045260246000fd5b600060208284031215612bef57600080fd5b81516117a781612789565b634e487b7160e01b600052601160045260246000fd5b6000600019821415612c2457612c24612bfa565b5060010190565b602080825260149082015273496e76616c6964206d696e7420616d6f756e742160601b604082015260600190565b60008219821115612c6c57612c6c612bfa565b500190565b6020808252601490820152734d617820737570706c792065786365656465642160601b604082015260600190565b6020808252601f908201527f4d6178696d756d206e756d626572206f662077616c6c65747320697320323000604082015260600190565b6000816000190483118215151615612cf057612cf0612bfa565b500290565b600082821015612d0757612d07612bfa565b500390565b602080825260139082015272496e73756666696369656e742066756e64732160681b604082015260600190565b600084516020612d4c8285838a016125dc565b855191840191612d5f8184848a016125dc565b8554920191600090600181811c9080831680612d7c57607f831692505b858310811415612d9a57634e487b7160e01b85526022600452602485fd5b808015612dae5760018114612dbf57612dec565b60ff19851688528388019550612dec565b60008b81526020902060005b85811015612de45781548a820152908401908801612dcb565b505083880195505b50939b9a5050505050505050505050565b600081612e0c57612e0c612bfa565b506000190190565b6001600160a01b0385811682528416602082015260408101839052608060608201819052600090612e4790830184612608565b9695505050505050565b600060208284031215612e6357600080fd5b81516117a7816125a956fea26469706673582212208618e0c8a68ec3a577d22999e1ffbfc6f6012574f509b5a2aa394f662957318764736f6c6343000809003300000000000000000000000000000000000000000000000000000000000000c00000000000000000000000000000000000000000000000000000000000000100000000000000000000000000000000000000000000000000006a94d74f4300000000000000000000000000000000000000000000000000000000000000001e6100000000000000000000000000000000000000000000000000000000000000140000000000000000000000000000000000000000000000000000000000000140000000000000000000000000000000000000000000000000000000000000000750656520506565000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000003506565000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000022727000000000000000000000000000000000000000000000000000000000000
Deployed Bytecode
0x6080604052600436106103975760003560e01c80637cb64759116101dc578063c7c39ffc11610102578063e0a80853116100a0578063efbd73f41161006f578063efbd73f414610a7a578063f1a631ec14610a9a578063f2fde38b14610abb578063fbbf8cc314610adb57600080fd5b8063e0a80853146109d1578063e945971c146109f1578063e985e9c514610a11578063ef29948914610a5a57600080fd5b8063d5abeb01116100dc578063d5abeb0114610955578063dad7b5c91461096b578063db4bec4414610981578063dc8c3270146109b157600080fd5b8063c7c39ffc1461090c578063c87b56dd14610922578063d2cab0561461094257600080fd5b806399a2557a1161017a578063b071401b11610149578063b071401b1461088c578063b767a098146108ac578063b88d4fde146108cc578063c23dc68f146108df57600080fd5b806399a2557a14610824578063a0712d6814610844578063a22cb46514610857578063a45ba8e71461087757600080fd5b80638da5cb5b116101b65780638da5cb5b146107bb57806394354fd0146107d957806395d89b41146107ef57806398dfe50b1461080457600080fd5b80637cb647591461074e5780637ec4a6591461076e5780638462151c1461078e57600080fd5b80634fdd43cb116102c15780635c975abb1161025f5780636caede3d1161022e5780636caede3d146106ca57806370a08231146106e9578063715018a614610709578063745308e71461071e57600080fd5b80635c975abb1461065b57806362b99ad4146106755780636352211e1461068a57806364febc38146106aa57600080fd5b80635503a0e81161029b5780635503a0e8146105d957806357a2e24b146105ee57806359236f3a1461060e5780635bbb21771461062e57600080fd5b80634fdd43cb146105795780635183022714610599578063542d878b146105b957600080fd5b806316c38b3c116103395780633c4ed0ad116103085780633c4ed0ad1461051b5780633ccfd60b1461053157806342842e0e1461054657806344a0d68a1461055957600080fd5b806316c38b3c146104b457806318160ddd146104d457806323b872dd146104f25780632eb4a7ab1461050557600080fd5b8063081812fc11610375578063081812fc14610423578063095ea7b31461045b57806313faede61461047057806316ba10e01461049457600080fd5b806301ffc9a71461039c57806306fdde03146103d157806307cfa41b146103f3575b600080fd5b3480156103a857600080fd5b506103bc6103b73660046125bf565b610b08565b60405190151581526020015b60405180910390f35b3480156103dd57600080fd5b506103e6610b5a565b6040516103c89190612634565b3480156103ff57600080fd5b506103bc61040e366004612647565b600e6020526000908152604090205460ff1681565b34801561042f57600080fd5b5061044361043e366004612647565b610bec565b6040516001600160a01b0390911681526020016103c8565b61046e610469366004612677565b610c27565b005b34801561047c57600080fd5b5061048660175481565b6040519081526020016103c8565b3480156104a057600080fd5b5061046e6104af366004612740565b610c37565b3480156104c057600080fd5b5061046e6104cf366004612797565b610c52565b3480156104e057600080fd5b50610486600154600054036000190190565b61046e6105003660046127b4565b610c6d565b34801561051157600080fd5b50610486600a5481565b34801561052757600080fd5b5061048660125481565b34801561053d57600080fd5b5061046e610dc8565b61046e6105543660046127b4565b610e56565b34801561056557600080fd5b5061046e610574366004612647565b610e76565b34801561058557600080fd5b5061046e610594366004612740565b610e83565b3480156105a557600080fd5b50601a546103bc9062010000900460ff1681565b3480156105c557600080fd5b5061046e6105d4366004612647565b610e9e565b3480156105e557600080fd5b506103e6610eab565b3480156105fa57600080fd5b50600f54610443906001600160a01b031681565b34801561061a57600080fd5b5061046e6106293660046127f0565b610f39565b34801561063a57600080fd5b5061064e610649366004612857565b610f63565b6040516103c891906128d6565b34801561066757600080fd5b50601a546103bc9060ff1681565b34801561068157600080fd5b506103e6610faf565b34801561069657600080fd5b506104436106a5366004612647565b610fbc565b3480156106b657600080fd5b5061046e6106c5366004612918565b610fc7565b3480156106d657600080fd5b50601a546103bc90610100900460ff1681565b3480156106f557600080fd5b506104866107043660046127f0565b6111a8565b34801561071557600080fd5b5061046e6111ee565b34801561072a57600080fd5b506103bc6107393660046127f0565b600d6020526000908152604090205460ff1681565b34801561075a57600080fd5b5061046e610769366004612647565b611200565b34801561077a57600080fd5b5061046e610789366004612740565b61120d565b34801561079a57600080fd5b506107ae6107a93660046127f0565b611228565b6040516103c891906129be565b3480156107c757600080fd5b506008546001600160a01b0316610443565b3480156107e557600080fd5b5061048660195481565b3480156107fb57600080fd5b506103e661124f565b34801561081057600080fd5b5061046e61081f366004612797565b61125e565b34801561083057600080fd5b506107ae61083f3660046129f6565b611284565b61046e610852366004612647565b611291565b34801561086357600080fd5b5061046e610872366004612a29565b6114f1565b34801561088357600080fd5b506103e661155d565b34801561089857600080fd5b5061046e6108a7366004612647565b61156a565b3480156108b857600080fd5b5061046e6108c7366004612797565b611577565b61046e6108da366004612a60565b611599565b3480156108eb57600080fd5b506108ff6108fa366004612647565b6115da565b6040516103c89190612adc565b34801561091857600080fd5b5061048660115481565b34801561092e57600080fd5b506103e661093d366004612647565b61163e565b61046e610950366004612aea565b6117ae565b34801561096157600080fd5b5061048660185481565b34801561097757600080fd5b5061048660165481565b34801561098d57600080fd5b506103bc61099c3660046127f0565b600b6020526000908152604090205460ff1681565b3480156109bd57600080fd5b5061046e6109cc366004612647565b611b07565b3480156109dd57600080fd5b5061046e6109ec366004612797565b611bb2565b3480156109fd57600080fd5b5061046e610a0c366004612647565b611bd6565b348015610a1d57600080fd5b506103bc610a2c366004612b36565b6001600160a01b03918216600090815260076020908152604080832093909416825291909152205460ff1690565b348015610a6657600080fd5b50601054610443906001600160a01b031681565b348015610a8657600080fd5b5061046e610a95366004612b69565b611be3565b348015610aa657600080fd5b506010546103bc90600160a01b900460ff1681565b348015610ac757600080fd5b5061046e610ad63660046127f0565b611c60565b348015610ae757600080fd5b50610486610af63660046127f0565b600c6020526000908152604090205481565b60006301ffc9a760e01b6001600160e01b031983161480610b3957506380ac58cd60e01b6001600160e01b03198316145b80610b545750635b5e139f60e01b6001600160e01b03198316145b92915050565b606060028054610b6990612b8c565b80601f0160208091040260200160405190810160405280929190818152602001828054610b9590612b8c565b8015610be25780601f10610bb757610100808354040283529160200191610be2565b820191906000526020600020905b815481529060010190602001808311610bc557829003601f168201915b5050505050905090565b6000610bf782611cd6565b610c0b57610c0b6333d1c03960e21b611d1f565b506000908152600660205260409020546001600160a01b031690565b610c3382826001611d29565b5050565b610c3f611dcc565b8051610c33906014906020840190612510565b610c5a611dcc565b601a805460ff1916911515919091179055565b6000610c7882611e26565b6001600160a01b039485169490915081168414610c9e57610c9e62a1148160e81b611d1f565b60008281526006602052604090208054338082146001600160a01b03881690911417610ce257610cce8633610a2c565b610ce257610ce2632ce44b5f60e11b611d1f565b8015610ced57600082555b6001600160a01b038681166000908152600560205260408082208054600019019055918716808252919020805460010190554260a01b17600160e11b17600085815260046020526040902055600160e11b8316610d785760018401600081815260046020526040902054610d76576000548114610d765760008181526004602052604090208490555b505b6001600160a01b0385168481887fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef600080a480610dbf57610dbf633a954ecd60e21b611d1f565b50505050505050565b610dd0611dcc565b610dd8611ec2565b6000610dec6008546001600160a01b031690565b6001600160a01b03164760405160006040518083038185875af1925050503d8060008114610e36576040519150601f19603f3d011682016040523d82523d6000602084013e610e3b565b606091505b5050905080610e4957600080fd5b50610e546001600955565b565b610e7183838360405180602001604052806000815250611599565b505050565b610e7e611dcc565b601755565b610e8b611dcc565b8051610c33906015906020840190612510565b610ea6611dcc565b601255565b60148054610eb890612b8c565b80601f0160208091040260200160405190810160405280929190818152602001828054610ee490612b8c565b8015610f315780601f10610f0657610100808354040283529160200191610f31565b820191906000526020600020905b815481529060010190602001808311610f1457829003601f168201915b505050505081565b610f41611dcc565b600f80546001600160a01b0319166001600160a01b0392909216919091179055565b60408051828152600583901b8082016020019092526060915b8015610fa757601f1980820191860101356000610f98826115da565b8484016020015250610f7c9050565b509392505050565b60138054610eb890612b8c565b6000610b5482611e26565b601054600160a01b900460ff166110355760405162461bcd60e51b815260206004820152602760248201527f416374697669747920726564656d7074696f6e20686173206e6f7420796574206044820152661cdd185c9d195960ca1b60648201526084015b60405180910390fd5b805169010f0cf064dd59200000903360005b828110156111a157600085828151811061106357611063612bc7565b60200260200101519050826001600160a01b031661108082610fbc565b6001600160a01b0316146110d65760405162461bcd60e51b815260206004820152601860248201527f596f7520646f6e2774206f776e207468697320746f6b656e0000000000000000604482015260640161102c565b6000818152600e602052604090205460ff1661118e576000818152600e602052604090819020805460ff19166001179055600f54905163a9059cbb60e01b81526001600160a01b038581166004830152602482018890529091169063a9059cbb90604401602060405180830381600087803b15801561115457600080fd5b505af1158015611168573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061118c9190612bdd565b505b508061119981612c10565b915050611047565b5050505050565b60006001600160a01b0382166111c8576111c86323d3ad8160e21b611d1f565b506001600160a01b031660009081526005602052604090205467ffffffffffffffff1690565b6111f6611dcc565b610e546000611f1c565b611208611dcc565b600a55565b611215611dcc565b8051610c33906013906020840190612510565b6000546060906001908282821461124757611244858484611f6e565b90505b949350505050565b606060038054610b6990612b8c565b611266611dcc565b60108054911515600160a01b0260ff60a01b19909216919091179055565b6060611247848484611f6e565b6000811180156112a357506019548111155b6112bf5760405162461bcd60e51b815260040161102c90612c2b565b601854816112d4600154600054036000190190565b6112de9190612c59565b11156112fc5760405162461bcd60e51b815260040161102c90612c71565b601a5460ff161561134f5760405162461bcd60e51b815260206004820152601760248201527f54686520636f6e74726163742069732070617573656421000000000000000000604482015260640161102c565b33321461139e5760405162461bcd60e51b815260206004820152601e60248201527f546865206d696e74657220697320616e6f7468657220636f6e74726163740000604482015260640161102c565b336000908152600c60205260409020546014906113bc908390612c59565b11156113da5760405162461bcd60e51b815260040161102c90612c9f565b336000908152600d602052604090205460ff16611493576011546017546114019190612cd6565b60175461140e9083612cd6565b6114189190612cf5565b3410156114375760405162461bcd60e51b815260040161102c90612d0c565b6011546016600082825461144b9190612c59565b9091555050336000908152600c60205260408120805483929061146f908490612c59565b9091555050336000908152600d60205260409020805460ff191660011790556114e4565b6017546114a09082612cd6565b3410156114bf5760405162461bcd60e51b815260040161102c90612d0c565b336000908152600c6020526040812080548392906114de908490612c59565b90915550505b6114ee338261206d565b50565b3360008181526007602090815260408083206001600160a01b03871680855290835292819020805460ff191686151590811790915590519081529192917f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c31910160405180910390a35050565b60158054610eb890612b8c565b611572611dcc565b601955565b61157f611dcc565b601a80549115156101000261ff0019909216919091179055565b6115a4848484610c6d565b6001600160a01b0383163b156115d4576115c084848484612087565b6115d4576115d46368d2bf6b60e11b611d1f565b50505050565b6040805160808101825260008082526020820181905291810182905260608101919091526001821061163957600054821015611639575b6000828152600460205260409020546116305760001990910190611611565b610b5482612175565b919050565b606061164982611cd6565b6116ad5760405162461bcd60e51b815260206004820152602f60248201527f4552433732314d657461646174613a2055524920717565727920666f72206e6f60448201526e3732bc34b9ba32b73a103a37b5b2b760891b606482015260840161102c565b601a5462010000900460ff1661174f57601580546116ca90612b8c565b80601f01602080910402602001604051908101604052809291908181526020018280546116f690612b8c565b80156117435780601f1061171857610100808354040283529160200191611743565b820191906000526020600020905b81548152906001019060200180831161172657829003601f168201915b50505050509050919050565b60006117596121f4565b9050600081511161177957604051806020016040528060008152506117a7565b8061178384612203565b601460405160200161179793929190612d39565b6040516020818303038152906040525b9392505050565b6000831180156117c057506019548311155b6117dc5760405162461bcd60e51b815260040161102c90612c2b565b601854836117f1600154600054036000190190565b6117fb9190612c59565b11156118195760405162461bcd60e51b815260040161102c90612c71565b6012546017546118299190612cd6565b836017546118379190612cd6565b6118419190612cf5565b3410156118605760405162461bcd60e51b815260040161102c90612d0c565b601a54610100900460ff166118c25760405162461bcd60e51b815260206004820152602260248201527f5468652077686974656c6973742073616c65206973206e6f7420656e61626c65604482015261642160f01b606482015260840161102c565b336000908152600b602052604090205460ff16156119225760405162461bcd60e51b815260206004820152601860248201527f4164647265737320616c726561647920636c61696d6564210000000000000000604482015260640161102c565b6040516bffffffffffffffffffffffff193360601b16602082015260009060340160408051808303601f19018152919052805160209091012090503332146119ac5760405162461bcd60e51b815260206004820152601e60248201527f546865206d696e74657220697320616e6f7468657220636f6e74726163740000604482015260640161102c565b6119ed83838080602002602001604051908101604052809392919081815260200183836020028082843760009201919091525050600a549150849050612298565b611a2a5760405162461bcd60e51b815260206004820152600e60248201526d496e76616c69642070726f6f662160901b604482015260640161102c565b336000908152600c6020526040902054601411611a595760405162461bcd60e51b815260040161102c90612c9f565b336000908152600c6020526040902054601490611a77908690612c59565b1115611a955760405162461bcd60e51b815260040161102c90612c9f565b60125460166000828254611aa99190612c59565b9091555050336000908152600b602090815260408083208054600160ff199182168117909255600d845282852080549091169091179055600c90915281208054869290611af7908490612c59565b909155506115d49050338561206d565b611b0f611dcc565b600f546001600160a01b031663a9059cbb611b326008546001600160a01b031690565b6040516001600160e01b031960e084901b1681526001600160a01b03909116600482015260248101849052604401602060405180830381600087803b158015611b7a57600080fd5b505af1158015611b8e573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610c339190612bdd565b611bba611dcc565b601a8054911515620100000262ff000019909216919091179055565b611bde611dcc565b601155565b611beb611dcc565b600082118015611bfd57506019548211155b611c195760405162461bcd60e51b815260040161102c90612c2b565b60185482611c2e600154600054036000190190565b611c389190612c59565b1115611c565760405162461bcd60e51b815260040161102c90612c71565b610c33818361206d565b611c68611dcc565b6001600160a01b038116611ccd5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b606482015260840161102c565b6114ee81611f1c565b600081600111611639576000548210156116395760005b5060008281526004602052604090205480611d1257611d0b83612dfd565b9250611ced565b600160e01b161592915050565b8060005260046000fd5b6000611d3483610fbc565b9050818015611d4c5750336001600160a01b03821614155b15611d6f57611d5b8133610a2c565b611d6f57611d6f6367d9dca160e11b611d1f565b60008381526006602052604080822080546001600160a01b0319166001600160a01b0388811691821790925591518693918516917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591a450505050565b6008546001600160a01b03163314610e545760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604482015260640161102c565b600081600111611eb2575060008181526004602052604090205480611ea2576000548210611e5e57611e5e636f96cda160e11b611d1f565b5b506000190160008181526004602052604090205480611e7d57611e5f565b600160e01b8116611e8d57919050565b611e9d636f96cda160e11b611d1f565b611e5f565b600160e01b8116611eb257919050565b611639636f96cda160e11b611d1f565b60026009541415611f155760405162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c00604482015260640161102c565b6002600955565b600880546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b6060818310611f8757611f87631960ccad60e11b611d1f565b6001831015611f9557600192505b600054808310611fa3578092505b60606000611fb0876111a8565b85871090810291508115612061578187870311611fcd5786860391505b60405192506001820160051b83016040526000611fe9886115da565b905060008160400151611ffa575080515b60005b6120068a612175565b925060408301516000811461201e5760009250612043565b83511561202a57835192505b8b831860601b612043576001820191508a8260051b8801525b5060018a019950888a148061205757508481145b15611ffd57855250505b50909695505050505050565b610c338282604051806020016040528060008152506122ae565b604051630a85bd0160e11b81526000906001600160a01b0385169063150b7a02906120bc903390899088908890600401612e14565b602060405180830381600087803b1580156120d657600080fd5b505af1925050508015612106575060408051601f3d908101601f1916820190925261210391810190612e51565b60015b612158573d808015612134576040519150601f19603f3d011682016040523d82523d6000602084013e612139565b606091505b508051612150576121506368d2bf6b60e11b611d1f565b805181602001fd5b6001600160e01b031916630a85bd0160e11b149050949350505050565b604080516080810182526000808252602082018190529181018290526060810191909152600082815260046020526040902054610b5490604080516080810182526001600160a01b038316815260a083901c67ffffffffffffffff166020820152600160e01b831615159181019190915260e89190911c606082015290565b606060138054610b6990612b8c565b6060600061221083612310565b600101905060008167ffffffffffffffff811115612230576122306126a1565b6040519080825280601f01601f19166020018201604052801561225a576020820181803683370190505b5090508181016020015b600019016f181899199a1a9b1b9c1cb0b131b232b360811b600a86061a8153600a850494508461229357610fa7565b612264565b6000826122a585846123e8565b14949350505050565b6122b8838361242d565b6001600160a01b0383163b15610e71576000548281035b6122e26000868380600101945086612087565b6122f6576122f66368d2bf6b60e11b611d1f565b8181106122cf5781600054146111a1576111a16000611d1f565b60008072184f03e93ff9f4daa797ed6e38ed64bf6a1f0160401b831061234f5772184f03e93ff9f4daa797ed6e38ed64bf6a1f0160401b830492506040015b6d04ee2d6d415b85acef8100000000831061237b576d04ee2d6d415b85acef8100000000830492506020015b662386f26fc10000831061239957662386f26fc10000830492506010015b6305f5e10083106123b1576305f5e100830492506008015b61271083106123c557612710830492506004015b606483106123d7576064830492506002015b600a8310610b545760010192915050565b600081815b8451811015610fa7576124198286838151811061240c5761240c612bc7565b60200260200101516124e4565b91508061242581612c10565b9150506123ed565b600054816124455761244563b562e8dd60e01b611d1f565b60008181526004602090815260408083206001600160a01b0387164260a01b6001881460e11b17811790915580845260059092529091208054680100000000000000018502019055806124a1576124a1622e076360e81b611d1f565b818301825b808360007fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef600080a4600101808214156124a6575060005550505050565b60008183106125005760008281526020849052604090206117a7565b5060009182526020526040902090565b82805461251c90612b8c565b90600052602060002090601f01602090048101928261253e5760008555612584565b82601f1061255757805160ff1916838001178555612584565b82800160010185558215612584579182015b82811115612584578251825591602001919060010190612569565b50612590929150612594565b5090565b5b808211156125905760008155600101612595565b6001600160e01b0319811681146114ee57600080fd5b6000602082840312156125d157600080fd5b81356117a7816125a9565b60005b838110156125f75781810151838201526020016125df565b838111156115d45750506000910152565b600081518084526126208160208601602086016125dc565b601f01601f19169290920160200192915050565b6020815260006117a76020830184612608565b60006020828403121561265957600080fd5b5035919050565b80356001600160a01b038116811461163957600080fd5b6000806040838503121561268a57600080fd5b61269383612660565b946020939093013593505050565b634e487b7160e01b600052604160045260246000fd5b604051601f8201601f1916810167ffffffffffffffff811182821017156126e0576126e06126a1565b604052919050565b600067ffffffffffffffff831115612702576127026126a1565b612715601f8401601f19166020016126b7565b905082815283838301111561272957600080fd5b828260208301376000602084830101529392505050565b60006020828403121561275257600080fd5b813567ffffffffffffffff81111561276957600080fd5b8201601f8101841361277a57600080fd5b611247848235602084016126e8565b80151581146114ee57600080fd5b6000602082840312156127a957600080fd5b81356117a781612789565b6000806000606084860312156127c957600080fd5b6127d284612660565b92506127e060208501612660565b9150604084013590509250925092565b60006020828403121561280257600080fd5b6117a782612660565b60008083601f84011261281d57600080fd5b50813567ffffffffffffffff81111561283557600080fd5b6020830191508360208260051b850101111561285057600080fd5b9250929050565b6000806020838503121561286a57600080fd5b823567ffffffffffffffff81111561288157600080fd5b61288d8582860161280b565b90969095509350505050565b80516001600160a01b0316825260208082015167ffffffffffffffff169083015260408082015115159083015260609081015162ffffff16910152565b6020808252825182820181905260009190848201906040850190845b8181101561206157612905838551612899565b92840192608092909201916001016128f2565b6000602080838503121561292b57600080fd5b823567ffffffffffffffff8082111561294357600080fd5b818501915085601f83011261295757600080fd5b813581811115612969576129696126a1565b8060051b915061297a8483016126b7565b818152918301840191848101908884111561299457600080fd5b938501935b838510156129b257843582529385019390850190612999565b98975050505050505050565b6020808252825182820181905260009190848201906040850190845b81811015612061578351835292840192918401916001016129da565b600080600060608486031215612a0b57600080fd5b612a1484612660565b95602085013595506040909401359392505050565b60008060408385031215612a3c57600080fd5b612a4583612660565b91506020830135612a5581612789565b809150509250929050565b60008060008060808587031215612a7657600080fd5b612a7f85612660565b9350612a8d60208601612660565b925060408501359150606085013567ffffffffffffffff811115612ab057600080fd5b8501601f81018713612ac157600080fd5b612ad0878235602084016126e8565b91505092959194509250565b60808101610b548284612899565b600080600060408486031215612aff57600080fd5b83359250602084013567ffffffffffffffff811115612b1d57600080fd5b612b298682870161280b565b9497909650939450505050565b60008060408385031215612b4957600080fd5b612b5283612660565b9150612b6060208401612660565b90509250929050565b60008060408385031215612b7c57600080fd5b82359150612b6060208401612660565b600181811c90821680612ba057607f821691505b60208210811415612bc157634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052603260045260246000fd5b600060208284031215612bef57600080fd5b81516117a781612789565b634e487b7160e01b600052601160045260246000fd5b6000600019821415612c2457612c24612bfa565b5060010190565b602080825260149082015273496e76616c6964206d696e7420616d6f756e742160601b604082015260600190565b60008219821115612c6c57612c6c612bfa565b500190565b6020808252601490820152734d617820737570706c792065786365656465642160601b604082015260600190565b6020808252601f908201527f4d6178696d756d206e756d626572206f662077616c6c65747320697320323000604082015260600190565b6000816000190483118215151615612cf057612cf0612bfa565b500290565b600082821015612d0757612d07612bfa565b500390565b602080825260139082015272496e73756666696369656e742066756e64732160681b604082015260600190565b600084516020612d4c8285838a016125dc565b855191840191612d5f8184848a016125dc565b8554920191600090600181811c9080831680612d7c57607f831692505b858310811415612d9a57634e487b7160e01b85526022600452602485fd5b808015612dae5760018114612dbf57612dec565b60ff19851688528388019550612dec565b60008b81526020902060005b85811015612de45781548a820152908401908801612dcb565b505083880195505b50939b9a5050505050505050505050565b600081612e0c57612e0c612bfa565b506000190190565b6001600160a01b0385811682528416602082015260408101839052608060608201819052600090612e4790830184612608565b9695505050505050565b600060208284031215612e6357600080fd5b81516117a7816125a956fea26469706673582212208618e0c8a68ec3a577d22999e1ffbfc6f6012574f509b5a2aa394f662957318764736f6c63430008090033
Constructor Arguments (ABI-Encoded and is the last bytes of the Contract Creation Code above)
00000000000000000000000000000000000000000000000000000000000000c00000000000000000000000000000000000000000000000000000000000000100000000000000000000000000000000000000000000000000006a94d74f4300000000000000000000000000000000000000000000000000000000000000001e6100000000000000000000000000000000000000000000000000000000000000140000000000000000000000000000000000000000000000000000000000000140000000000000000000000000000000000000000000000000000000000000000750656520506565000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000003506565000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000022727000000000000000000000000000000000000000000000000000000000000
-----Decoded View---------------
Arg [0] : _tokenName (string): Pee Pee
Arg [1] : _tokenSymbol (string): Pee
Arg [2] : _cost (uint256): 30000000000000000
Arg [3] : _maxSupply (uint256): 7777
Arg [4] : _maxMintAmountPerTx (uint256): 20
Arg [5] : _hiddenMetadataUri (string): ''
-----Encoded View---------------
12 Constructor Arguments found :
Arg [0] : 00000000000000000000000000000000000000000000000000000000000000c0
Arg [1] : 0000000000000000000000000000000000000000000000000000000000000100
Arg [2] : 000000000000000000000000000000000000000000000000006a94d74f430000
Arg [3] : 0000000000000000000000000000000000000000000000000000000000001e61
Arg [4] : 0000000000000000000000000000000000000000000000000000000000000014
Arg [5] : 0000000000000000000000000000000000000000000000000000000000000140
Arg [6] : 0000000000000000000000000000000000000000000000000000000000000007
Arg [7] : 5065652050656500000000000000000000000000000000000000000000000000
Arg [8] : 0000000000000000000000000000000000000000000000000000000000000003
Arg [9] : 5065650000000000000000000000000000000000000000000000000000000000
Arg [10] : 0000000000000000000000000000000000000000000000000000000000000002
Arg [11] : 2727000000000000000000000000000000000000000000000000000000000000
Deployed Bytecode Sourcemap
1033:6469:8:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;9164:630:1;;;;;;;;;;-1:-1:-1;9164:630:1;;;;;:::i;:::-;;:::i;:::-;;;565:14:11;;558:22;540:41;;528:2;513:18;9164:630:1;;;;;;;;10048:98;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;1306:36:8:-;;;;;;;;;;-1:-1:-1;1306:36:8;;;;;:::i;:::-;;;;;;;;;;;;;;;;16911:223:1;;;;;;;;;;-1:-1:-1;16911:223:1;;;;;:::i;:::-;;:::i;:::-;;;-1:-1:-1;;;;;1692:32:11;;;1674:51;;1662:2;1647:18;16911:223:1;1528:203:11;16639:122:1;;;;;;:::i;:::-;;:::i;:::-;;1668:19:8;;;;;;;;;;;;;;;;;;;2319:25:11;;;2307:2;2292:18;1668:19:8;2173:177:11;6707:100:8;;;;;;;;;;-1:-1:-1;6707:100:8;;;;;:::i;:::-;;:::i;6813:77::-;;;;;;;;;;-1:-1:-1;6813:77:8;;;;;:::i;:::-;;:::i;5894:317:1:-;;;;;;;;;;;;5498:1:8;6164:12:1;5955:7;6148:13;:28;-1:-1:-1;;6148:46:1;;5894:317;20546:3447;;;;;;:::i;:::-;;:::i;1131:25:8:-;;;;;;;;;;;;;;;;1486:34;;;;;;;;;;;;;;;;7111:156;;;;;;;;;;;;;:::i;24084:187:1:-;;;;;;:::i;:::-;;:::i;6055:74:8:-;;;;;;;;;;-1:-1:-1;6055:74:8;;;;;:::i;:::-;;:::i;6463:132::-;;;;;;;;;;-1:-1:-1;6463:132:8;;;;;:::i;:::-;;:::i;1836:28::-;;;;;;;;;;-1:-1:-1;1836:28:8;;;;;;;;;;;6226:97;;;;;;;;;;-1:-1:-1;6226:97:8;;;;;:::i;:::-;;:::i;1558:33::-;;;;;;;;;;;;;:::i;1347:29::-;;;;;;;;;;-1:-1:-1;1347:29:8;;;;-1:-1:-1;;;;;1347:29:8;;;3420:109;;;;;;;;;;-1:-1:-1;3420:109:8;;;;;:::i;:::-;;:::i;1801:1131:2:-;;;;;;;;;;-1:-1:-1;1801:1131:2;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;1761:25:8:-;;;;;;;;;;-1:-1:-1;1761:25:8;;;;;;;;1525:28;;;;;;;;;;;;;:::i;11409:150:1:-;;;;;;;;;;-1:-1:-1;11409:150:1;;;;;:::i;:::-;;:::i;3534:566:8:-;;;;;;;;;;-1:-1:-1;3534:566:8;;;;;:::i;:::-;;:::i;1791:40::-;;;;;;;;;;-1:-1:-1;1791:40:8;;;;;;;;;;;7045:239:1;;;;;;;;;;-1:-1:-1;7045:239:1;;;;;:::i;:::-;;:::i;1824:101:7:-;;;;;;;;;;;;;:::i;1265:36:8:-;;;;;;;;;;-1:-1:-1;1265:36:8;;;;;:::i;:::-;;;;;;;;;;;;;;;;6896:98;;;;;;;;;;-1:-1:-1;6896:98:8;;;;;:::i;:::-;;:::i;6601:100::-;;;;;;;;;;-1:-1:-1;6601:100:8;;;;;:::i;:::-;;:::i;3958:319:2:-;;;;;;;;;;-1:-1:-1;3958:319:2;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;1194:85:7:-;;;;;;;;;;-1:-1:-1;1266:6:7;;-1:-1:-1;;;;;1266:6:7;1194:85;;1721:33:8;;;;;;;;;;;;;;;;10217:102:1;;;;;;;;;;;;;:::i;4104:94:8:-;;;;;;;;;;-1:-1:-1;4104:94:8;;;;;:::i;:::-;;:::i;3306:217:2:-;;;;;;;;;;-1:-1:-1;3306:217:2;;;;;:::i;:::-;;:::i;4205:890:8:-;;;;;;:::i;:::-;;:::i;17461:231:1:-;;;;;;;;;;-1:-1:-1;17461:231:1;;;;;:::i;:::-;;:::i;1596:31:8:-;;;;;;;;;;;;;:::i;6327:130::-;;;;;;;;;;-1:-1:-1;6327:130:8;;;;;:::i;:::-;;:::i;7000:105::-;;;;;;;;;;-1:-1:-1;7000:105:8;;;;;:::i;:::-;;:::i;24852:405:1:-;;;;;;:::i;:::-;;:::i;1069:579:2:-;;;;;;;;;;-1:-1:-1;1069:579:2;;;;;:::i;:::-;;:::i;:::-;;;;;;;:::i;1453:28:8:-;;;;;;;;;;;;;;;;5513:449;;;;;;;;;;-1:-1:-1;5513:449:8;;;;;:::i;:::-;;:::i;2303:1111::-;;;;;;:::i;:::-;;:::i;1692:24::-;;;;;;;;;;;;;;;;1632:31;;;;;;;;;;;;;;;;1161:48;;;;;;;;;;-1:-1:-1;1161:48:8;;;;;:::i;:::-;;;;;;;;;;;;;;;;7275:114;;;;;;;;;;-1:-1:-1;7275:114:8;;;;;:::i;:::-;;:::i;5968:81::-;;;;;;;;;;-1:-1:-1;5968:81:8;;;;;:::i;:::-;;:::i;6135:87::-;;;;;;;;;;-1:-1:-1;6135:87:8;;;;;:::i;:::-;;:::i;17842:162:1:-;;;;;;;;;;-1:-1:-1;17842:162:1;;;;;:::i;:::-;-1:-1:-1;;;;;17962:25:1;;;17939:4;17962:25;;;:18;:25;;;;;;;;:35;;;;;;;;;;;;;;;17842:162;1381:25:8;;;;;;;;;;-1:-1:-1;1381:25:8;;;;-1:-1:-1;;;;;1381:25:8;;;5105:299;;;;;;;;;;-1:-1:-1;5105:299:8;;;;;:::i;:::-;;:::i;1411:37::-;;;;;;;;;;-1:-1:-1;1411:37:8;;;;-1:-1:-1;;;1411:37:8;;;;;;2074:198:7;;;;;;;;;;-1:-1:-1;2074:198:7;;;;;:::i;:::-;;:::i;1214:46:8:-;;;;;;;;;;-1:-1:-1;1214:46:8;;;;;:::i;:::-;;;;;;;;;;;;;;9164:630:1;9249:4;-1:-1:-1;;;;;;;;;9567:25:1;;;;:101;;-1:-1:-1;;;;;;;;;;9643:25:1;;;9567:101;:177;;;-1:-1:-1;;;;;;;;;;9719:25:1;;;9567:177;9548:196;9164:630;-1:-1:-1;;9164:630:1:o;10048:98::-;10102:13;10134:5;10127:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;10048:98;:::o;16911:223::-;16987:7;17011:16;17019:7;17011;:16::i;:::-;17006:73;;17029:50;-1:-1:-1;;;17029:7:1;:50::i;:::-;-1:-1:-1;17097:24:1;;;;:15;:24;;;;;:30;-1:-1:-1;;;;;17097:30:1;;16911:223::o;16639:122::-;16727:27;16736:2;16740:7;16749:4;16727:8;:27::i;:::-;16639:122;;:::o;6707:100:8:-;1087:13:7;:11;:13::i;:::-;6779:22:8;;::::1;::::0;:9:::1;::::0;:22:::1;::::0;::::1;::::0;::::1;:::i;6813:77::-:0;1087:13:7;:11;:13::i;:::-;6869:6:8::1;:15:::0;;-1:-1:-1;;6869:15:8::1;::::0;::::1;;::::0;;;::::1;::::0;;6813:77::o;20546:3447:1:-;20683:27;20713;20732:7;20713:18;:27::i;:::-;-1:-1:-1;;;;;20865:22:1;;;;20683:57;;-1:-1:-1;20923:45:1;;;;20919:95;;20970:44;-1:-1:-1;;;20970:7:1;:44::i;:::-;21026:27;19679:24;;;:15;:24;;;;;19903:26;;41487:10;19316:30;;;-1:-1:-1;;;;;19013:28:1;;19294:20;;;19291:56;21209:188;;21301:43;21318:4;41487:10;17842:162;:::i;21301:43::-;21296:101;;21346:51;-1:-1:-1;;;21346:7:1;:51::i;:::-;21540:15;21537:157;;;21678:1;21657:19;21650:30;21537:157;-1:-1:-1;;;;;22066:24:1;;;;;;;:18;:24;;;;;;22064:26;;-1:-1:-1;;22064:26:1;;;22134:22;;;;;;;;;22132:24;;-1:-1:-1;22132:24:1;;;15767:11;15742:23;15738:41;15725:63;-1:-1:-1;;;15725:63:1;22420:26;;;;:17;:26;;;;;:172;-1:-1:-1;;;22709:47:1;;22705:617;;22813:1;22803:11;;22781:19;22934:30;;;:17;:30;;;;;;22930:378;;23070:13;;23055:11;:28;23051:239;;23215:30;;;;:17;:30;;;;;:52;;;23051:239;22763:559;22705:617;-1:-1:-1;;;;;23450:20:1;;23821:7;23450:20;23753:4;23696:25;23431:16;;23564:292;23879:13;23875:58;;23894:39;-1:-1:-1;;;23894:7:1;:39::i;:::-;20673:3320;;;;20546:3447;;;:::o;7111:156:8:-;1087:13:7;:11;:13::i;:::-;2261:21:9::1;:19;:21::i;:::-;7173:7:8::2;7194;1266:6:7::0;;-1:-1:-1;;;;;1266:6:7;;1194:85;7194:7:8::2;-1:-1:-1::0;;;;;7186:21:8::2;7215;7186:55;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;7172:69;;;7256:2;7248:11;;;::::0;::::2;;7161:106;2303:20:9::1;1716:1:::0;2809:7;:22;2629:209;2303:20:::1;7111:156:8:o:0;24084:187:1:-;24225:39;24242:4;24248:2;24252:7;24225:39;;;;;;;;;;;;:16;:39::i;:::-;24084:187;;;:::o;6055:74:8:-;1087:13:7;:11;:13::i;:::-;6111:4:8::1;:12:::0;6055:74::o;6463:132::-;1087:13:7;:11;:13::i;:::-;6551:38:8;;::::1;::::0;:17:::1;::::0;:38:::1;::::0;::::1;::::0;::::1;:::i;6226:97::-:0;1087:13:7;:11;:13::i;:::-;6291:16:8::1;:26:::0;6226:97::o;1558:33::-;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::o;3420:109::-;1087:13:7;:11;:13::i;:::-;3490:15:8::1;:33:::0;;-1:-1:-1;;;;;;3490:33:8::1;-1:-1:-1::0;;;;;3490:33:8;;;::::1;::::0;;;::::1;::::0;;3420:109::o;1801:1131:2:-;2148:4;2142:11;;2199:21;;;2348:1;2344:9;;;2402:29;;;2422:4;2402:29;2389:43;;;1940:23;;2451:448;2458:6;;2451:448;;-1:-1:-1;;2541:12:2;;;;2594:23;;;2581:37;2480:15;2679:28;2581:37;2679:19;:28::i;:::-;2834:29;;;2854:4;2834:29;2827:48;-1:-1:-1;2451:448:2;;-1:-1:-1;2451:448:2;;-1:-1:-1;2915:10:2;1801:1131;-1:-1:-1;;;1801:1131:2:o;1525:28:8:-;;;;;;;:::i;11409:150:1:-;11481:7;11523:27;11542:7;11523:18;:27::i;3534:566:8:-;3606:17;;-1:-1:-1;;;3606:17:8;;;;3598:69;;;;-1:-1:-1;;;3598:69:8;;12026:2:11;3598:69:8;;;12008:21:11;12065:2;12045:18;;;12038:30;12104:34;12084:18;;;12077:62;-1:-1:-1;;;12155:18:11;;;12148:37;12202:19;;3598:69:8;;;;;;;;;3735:15;;3696:11;;3774:10;3674:19;3791:306;3815:10;3811:1;:14;3791:306;;;3843:15;3861:8;3870:1;3861:11;;;;;;;;:::i;:::-;;;;;;;3843:29;;3911:6;-1:-1:-1;;;;;3891:26:8;:16;3899:7;3891;:16::i;:::-;-1:-1:-1;;;;;3891:26:8;;3883:63;;;;-1:-1:-1;;;3883:63:8;;12566:2:11;3883:63:8;;;12548:21:11;12605:2;12585:18;;;12578:30;12644:26;12624:18;;;12617:54;12688:18;;3883:63:8;12364:348:11;3883:63:8;3962:16;;;;:7;:16;;;;;;;;3957:133;;3995:16;;;;:7;:16;;;;;;;:23;;-1:-1:-1;;3995:23:8;4014:4;3995:23;;;4033:15;;:45;;-1:-1:-1;;;4033:45:8;;-1:-1:-1;;;;;12909:32:11;;;4033:45:8;;;12891:51:11;12958:18;;;12951:34;;;4033:15:8;;;;:24;;12864:18:11;;4033:45:8;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;3957:133;-1:-1:-1;3827:3:8;;;;:::i;:::-;;;;3791:306;;;;3591:509;;;3534:566;:::o;7045:239:1:-;7117:7;-1:-1:-1;;;;;7140:19:1;;7136:69;;7161:44;-1:-1:-1;;;7161:7:1;:44::i;:::-;-1:-1:-1;;;;;;7222:25:1;;;;;:18;:25;;;;;;1360:13;7222:55;;7045:239::o;1824:101:7:-;1087:13;:11;:13::i;:::-;1888:30:::1;1915:1;1888:18;:30::i;6896:98:8:-:0;1087:13:7;:11;:13::i;:::-;6964:10:8::1;:24:::0;6896:98::o;6601:100::-;1087:13:7;:11;:13::i;:::-;6673:22:8;;::::1;::::0;:9:::1;::::0;:22:::1;::::0;::::1;::::0;::::1;:::i;3958:319:2:-:0;4064:13;5671::1;4036:16:2;;5498:1:8;;4036:16:2;4183:13;;;4179:66;;4209:36;4226:5;4233;4240:4;4209:16;:36::i;:::-;4198:47;;4179:66;4262:8;3958:319;-1:-1:-1;;;;3958:319:2:o;10217:102:1:-;10273:13;10305:7;10298:14;;;;;:::i;4104:94:8:-;1087:13:7;:11;:13::i;:::-;4168:17:8::1;:24:::0;;;::::1;;-1:-1:-1::0;;;4168:24:8::1;-1:-1:-1::0;;;;4168:24:8;;::::1;::::0;;;::::1;::::0;;4104:94::o;3306:217:2:-;3445:16;3480:36;3497:5;3504;3511:4;3480:16;:36::i;4205:890:8:-;4284:1;4270:11;:15;:52;;;;;4304:18;;4289:11;:33;;4270:52;4262:85;;;;-1:-1:-1;;;4262:85:8;;;;;;;:::i;:::-;4393:9;;4378:11;4362:13;5498:1;6164:12:1;5955:7;6148:13;:28;-1:-1:-1;;6148:46:1;;5894:317;4362:13:8;:27;;;;:::i;:::-;:40;;4354:73;;;;-1:-1:-1;;;4354:73:8;;;;;;;:::i;:::-;4443:6;;;;4442:7;4434:43;;;;-1:-1:-1;;;4434:43:8;;14551:2:11;4434:43:8;;;14533:21:11;14590:2;14570:18;;;14563:30;14629:25;14609:18;;;14602:53;14672:18;;4434:43:8;14349:347:11;4434:43:8;41487:10:1;4506:9:8;4492:23;4484:65;;;;-1:-1:-1;;;4484:65:8;;14903:2:11;4484:65:8;;;14885:21:11;14942:2;14922:18;;;14915:30;14981:32;14961:18;;;14954:60;15031:18;;4484:65:8;14701:354:11;4484:65:8;41487:10:1;4564:26:8;;;;:12;:26;;;;;;4604:2;;4564:38;;4591:11;;4564:38;:::i;:::-;:42;;4556:85;;;;-1:-1:-1;;;4556:85:8;;;;;;;:::i;:::-;41487:10:1;4653:20:8;;;;:6;:20;;;;;;;;4648:401;;4735:10;;4730:4;;:15;;;;:::i;:::-;4722:4;;4708:18;;:11;:18;:::i;:::-;4707:38;;;;:::i;:::-;4694:9;:51;;4686:83;;;;-1:-1:-1;;;4686:83:8;;;;;;;:::i;:::-;4799:10;;4780:15;;:29;;;;;;;:::i;:::-;;;;-1:-1:-1;;41487:10:1;4820:26:8;;;;:12;:26;;;;;:41;;4850:11;;4820:26;:41;;4850:11;;4820:41;:::i;:::-;;;;-1:-1:-1;;41487:10:1;4872:20:8;;;;:6;:20;;;;;:27;;-1:-1:-1;;4872:27:8;4895:4;4872:27;;;4648:401;;;4960:4;;4946:18;;:11;:18;:::i;:::-;4932:9;:33;;4924:65;;;;-1:-1:-1;;;4924:65:8;;;;;;;:::i;:::-;41487:10:1;5000:26:8;;;;:12;:26;;;;;:41;;5030:11;;5000:26;:41;;5030:11;;5000:41;:::i;:::-;;;;-1:-1:-1;;4648:401:8;5055:36;41487:10:1;5079:11:8;5055:9;:36::i;:::-;4205:890;:::o;17461:231:1:-;41487:10;17555:39;;;;:18;:39;;;;;;;;-1:-1:-1;;;;;17555:49:1;;;;;;;;;;;;:60;;-1:-1:-1;;17555:60:1;;;;;;;;;;17630:55;;540:41:11;;;17555:49:1;;41487:10;17630:55;;513:18:11;17630:55:1;;;;;;;17461:231;;:::o;1596:31:8:-;;;;;;;:::i;6327:130::-;1087:13:7;:11;:13::i;:::-;6411:18:8::1;:40:::0;6327:130::o;7000:105::-;1087:13:7;:11;:13::i;:::-;7070:20:8::1;:29:::0;;;::::1;;;;-1:-1:-1::0;;7070:29:8;;::::1;::::0;;;::::1;::::0;;7000:105::o;24852:405:1:-;25021:31;25034:4;25040:2;25044:7;25021:12;:31::i;:::-;-1:-1:-1;;;;;25066:14:1;;;:19;25062:189;;25104:56;25135:4;25141:2;25145:7;25154:5;25104:30;:56::i;:::-;25099:152;;25180:56;-1:-1:-1;;;25180:7:1;:56::i;:::-;24852:405;;;;:::o;1069:579:2:-;-1:-1:-1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;5498:1:8;1268:7:2;:26;1264:368;;5645:7:1;5671:13;1318:7:2;:24;1314:304;;;1498:51;12414:4:1;12437:24;;;:17;:24;;;;;;1498:51:2;;-1:-1:-1;;1540:9:2;;;;1498:51;;;1578:21;1591:7;1578:12;:21::i;1314:304::-;1069:579;;;:::o;5513:449:8:-;5587:13;5617:17;5625:8;5617:7;:17::i;:::-;5609:77;;;;-1:-1:-1;;;5609:77:8;;16273:2:11;5609:77:8;;;16255:21:11;16312:2;16292:18;;;16285:30;16351:34;16331:18;;;16324:62;-1:-1:-1;;;16402:18:11;;;16395:45;16457:19;;5609:77:8;16071:411:11;5609:77:8;5699:8;;;;;;;5695:64;;5734:17;5727:24;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;5513:449;;;:::o;5695:64::-;5771:28;5802:10;:8;:10::i;:::-;5771:41;;5857:1;5832:14;5826:28;:32;:130;;;;;;;;;;;;;;;;;5894:14;5910:19;:8;:17;:19::i;:::-;5931:9;5877:64;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;5826:130;5819:137;5513:449;-1:-1:-1;;;5513:449:8:o;2303:1111::-;2424:1;2410:11;:15;:52;;;;;2444:18;;2429:11;:33;;2410:52;2402:85;;;;-1:-1:-1;;;2402:85:8;;;;;;;:::i;:::-;2533:9;;2518:11;2502:13;5498:1;6164:12:1;5955:7;6148:13;:28;-1:-1:-1;;6148:46:1;;5894:317;2502:13:8;:27;;;;:::i;:::-;:40;;2494:73;;;;-1:-1:-1;;;2494:73:8;;;;;;;:::i;:::-;2621:16;;2616:4;;:21;;;;:::i;:::-;2602:11;2595:4;;:18;;;;:::i;:::-;:42;;;;:::i;:::-;2582:9;:55;;2574:87;;;;-1:-1:-1;;;2574:87:8;;;;;;;:::i;:::-;2676:20;;;;;;;2668:67;;;;-1:-1:-1;;;2668:67:8;;18347:2:11;2668:67:8;;;18329:21:11;18386:2;18366:18;;;18359:30;18425:34;18405:18;;;18398:62;-1:-1:-1;;;18476:18:11;;;18469:32;18518:19;;2668:67:8;18145:398:11;2668:67:8;41487:10:1;2751:30:8;;;;:16;:30;;;;;;;;2750:31;2742:68;;;;-1:-1:-1;;;2742:68:8;;18750:2:11;2742:68:8;;;18732:21:11;18789:2;18769:18;;;18762:30;18828:26;18808:18;;;18801:54;18872:18;;2742:68:8;18548:348:11;2742:68:8;2842:30;;-1:-1:-1;;41487:10:1;19050:2:11;19046:15;19042:53;2842:30:8;;;19030:66:11;2817:12:8;;19112::11;;2842:30:8;;;;;;-1:-1:-1;;2842:30:8;;;;;;2832:41;;2842:30;2832:41;;;;;-1:-1:-1;41487:10:1;2902:9:8;2888:23;2880:65;;;;-1:-1:-1;;;2880:65:8;;14903:2:11;2880:65:8;;;14885:21:11;14942:2;14922:18;;;14915:30;14981:32;14961:18;;;14954:60;15031:18;;2880:65:8;14701:354:11;2880:65:8;2960:50;2979:12;;2960:50;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;2993:10:8;;;-1:-1:-1;3005:4:8;;-1:-1:-1;2960:18:8;:50::i;:::-;2952:77;;;;-1:-1:-1;;;2952:77:8;;19337:2:11;2952:77:8;;;19319:21:11;19376:2;19356:18;;;19349:30;-1:-1:-1;;;19395:18:11;;;19388:44;19449:18;;2952:77:8;19135:338:11;2952:77:8;41487:10:1;3044:26:8;;;;:12;:26;;;;;;3071:2;-1:-1:-1;3036:72:8;;;;-1:-1:-1;;;3036:72:8;;;;;;;:::i;:::-;41487:10:1;3123:26:8;;;;:12;:26;;;;;;3163:2;;3123:38;;3150:11;;3123:38;:::i;:::-;:42;;3115:85;;;;-1:-1:-1;;;3115:85:8;;;;;;;:::i;:::-;3226:16;;3207:15;;:35;;;;;;;:::i;:::-;;;;-1:-1:-1;;41487:10:1;3249:30:8;;;;:16;:30;;;;;;;;:37;;3282:4;-1:-1:-1;;3249:37:8;;;;;;;;3293:6;:20;;;;;:25;;;;;;;;;;3325:12;:26;;;;;:40;;3354:11;;3249:30;3325:40;;3354:11;;3325:40;:::i;:::-;;;;-1:-1:-1;3372:36:8;;-1:-1:-1;41487:10:1;3396:11:8;3372:9;:36::i;7275:114::-;1087:13:7;:11;:13::i;:::-;7339:15:8::1;::::0;-1:-1:-1;;;;;7339:15:8::1;:24;7364:7;1266:6:7::0;;-1:-1:-1;;;;;1266:6:7;;1194:85;7364:7:8::1;7339:42;::::0;-1:-1:-1;;;;;;7339:42:8::1;::::0;;;;;;-1:-1:-1;;;;;12909:32:11;;;7339:42:8::1;::::0;::::1;12891:51:11::0;12958:18;;;12951:34;;;12864:18;;7339:42:8::1;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;5968:81::-:0;1087:13:7;:11;:13::i;:::-;6026:8:8::1;:17:::0;;;::::1;;::::0;::::1;-1:-1:-1::0;;6026:17:8;;::::1;::::0;;;::::1;::::0;;5968:81::o;6135:87::-;1087:13:7;:11;:13::i;:::-;6195:10:8::1;:21:::0;6135:87::o;5105:299::-;1087:13:7;:11;:13::i;:::-;5215:1:8::1;5201:11;:15;:52;;;;;5235:18;;5220:11;:33;;5201:52;5193:85;;;;-1:-1:-1::0;;;5193:85:8::1;;;;;;;:::i;:::-;5324:9;;5309:11;5293:13;5498:1:::0;6164:12:1;5955:7;6148:13;:28;-1:-1:-1;;6148:46:1;;5894:317;5293:13:8::1;:27;;;;:::i;:::-;:40;;5285:73;;;;-1:-1:-1::0;;;5285:73:8::1;;;;;;;:::i;:::-;5365:33;5375:9;5386:11;5365:9;:33::i;2074:198:7:-:0;1087:13;:11;:13::i;:::-;-1:-1:-1;;;;;2162:22:7;::::1;2154:73;;;::::0;-1:-1:-1;;;2154:73:7;;19680:2:11;2154:73:7::1;::::0;::::1;19662:21:11::0;19719:2;19699:18;;;19692:30;19758:34;19738:18;;;19731:62;-1:-1:-1;;;19809:18:11;;;19802:36;19855:19;;2154:73:7::1;19478:402:11::0;2154:73:7::1;2237:28;2256:8;2237:18;:28::i;18253:360:1:-:0;18318:11;18364:7;5498:1:8;18345:26:1;18341:266;;18401:13;;18391:7;:23;18387:210;;;18434:14;18466:60;-1:-1:-1;18483:26:1;;;;:17;:26;;;;;;18473:42;18466:60;;18517:9;;;:::i;:::-;;;18466:60;;;-1:-1:-1;;;18553:24:1;:29;;18253:360;-1:-1:-1;;18253:360:1:o;43371:160::-;43470:13;43464:4;43457:27;43510:4;43504;43497:18;35019:460;35143:13;35159:16;35167:7;35159;:16::i;:::-;35143:32;;35190:13;:45;;;;-1:-1:-1;41487:10:1;-1:-1:-1;;;;;35207:28:1;;;;35190:45;35186:198;;;35254:44;35271:5;41487:10;17842:162;:::i;35254:44::-;35249:135;;35318:51;-1:-1:-1;;;35318:7:1;:51::i;:::-;35394:24;;;;:15;:24;;;;;;:35;;-1:-1:-1;;;;;;35394:35:1;-1:-1:-1;;;;;35394:35:1;;;;;;;;;35444:28;;35394:24;;35444:28;;;;;;;35133:346;35019:460;;;:::o;1352:130:7:-;1266:6;;-1:-1:-1;;;;;1266:6:7;41487:10:1;1415:23:7;1407:68;;;;-1:-1:-1;;;1407:68:7;;20228:2:11;1407:68:7;;;20210:21:11;;;20247:18;;;20240:30;20306:34;20286:18;;;20279:62;20358:18;;1407:68:7;20026:356:11;12850:1978:1;12917:14;12966:7;5498:1:8;12947:26:1;12943:1822;;-1:-1:-1;12998:26:1;;;;:17;:26;;;;;;13122:11;13118:1270;;13168:13;;13157:7;:24;13153:77;;13183:47;-1:-1:-1;;;13183:7:1;:47::i;:::-;13777:597;-1:-1:-1;;;13871:9:1;13853:28;;;;:17;:28;;;;;;13929:11;13925:25;;13777:597;;13925:25;-1:-1:-1;;;13976:24:1;;13972:48;;12850:1978;;;:::o;13972:48::-;14308:47;-1:-1:-1;;;14308:7:1;:47::i;:::-;13777:597;;13118:1270;-1:-1:-1;;;14710:24:1;;14706:48;;12850:1978;;;:::o;14706:48::-;14774:47;-1:-1:-1;;;14774:7:1;:47::i;2336:287:9:-;1759:1;2468:7;;:19;;2460:63;;;;-1:-1:-1;;;2460:63:9;;20589:2:11;2460:63:9;;;20571:21:11;20628:2;20608:18;;;20601:30;20667:33;20647:18;;;20640:61;20718:18;;2460:63:9;20387:355:11;2460:63:9;1759:1;2598:7;:18;2336:287::o;2426:187:7:-;2518:6;;;-1:-1:-1;;;;;2534:17:7;;;-1:-1:-1;;;;;;2534:17:7;;;;;;;2566:40;;2518:6;;;2534:17;2518:6;;2566:40;;2499:16;;2566:40;2489:124;2426:187;:::o;4525:4263:2:-;4647:16;4712:4;4703:5;:13;4699:54;;4718:35;-1:-1:-1;;;4718:7:2;:35::i;:::-;5498:1:8;4829:5:2;:23;4825:85;;;5498:1:8;4872:23:2;;4825:85;4923:17;5671:13:1;5025:17:2;;;5021:72;;5069:9;5062:16;;5021:72;5106:25;5145;5173:16;5183:5;5173:9;:16::i;:::-;5222:12;;;5379:35;;;;-1:-1:-1;5445:22:2;;5441:3302;;5664:17;5655:5;5648:4;:12;:33;5644:112;;5732:5;5725:4;:12;5705:32;;5644:112;5875:4;5869:11;5857:23;;6125:1;6106:17;6102:25;6099:1;6095:33;6085:8;6081:48;6075:4;6068:62;6301:31;6335:26;6355:5;6335:19;:26::i;:::-;6301:60;;6379:25;6671:9;:16;;;6666:98;;-1:-1:-1;6731:14:2;;6666:98;6781:19;6968:1616;7005:19;7018:5;7005:12;:19::i;:::-;6993:31;;7109:4;7098:9;7094:20;7088:27;7204:1;7199:893;;;;8408:1;8387:22;;7081:1354;;7199:893;7478:9;7472:16;7469:121;;;7550:9;7544:16;7523:37;;7469:121;7877:5;7858:17;7854:29;7850:2;7846:38;7836:230;;7952:1;7939:11;7935:19;7920:34;;8030:5;8015:11;8012:1;8008:19;7998:8;7994:34;7987:49;7836:230;7081:1354;8480:1;8473:5;8469:13;8460:22;;8541:4;8532:5;:13;:49;;;;8564:17;8549:11;:32;8532:49;8530:52;6968:1616;;8682:29;;-1:-1:-1;;5441:3302:2;-1:-1:-1;8763:8:2;;4525:4263;-1:-1:-1;;;;;;4525:4263:2:o;34129:110:1:-;34205:27;34215:2;34219:8;34205:27;;;;;;;;;;;;:9;:27::i;27283:673::-;27461:88;;-1:-1:-1;;;27461:88:1;;27441:4;;-1:-1:-1;;;;;27461:45:1;;;;;:88;;41487:10;;27528:4;;27534:7;;27543:5;;27461:88;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;27461:88:1;;;;;;;;-1:-1:-1;;27461:88:1;;;;;;;;;;;;:::i;:::-;;;27457:493;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;27739:13:1;;27735:113;;27777:56;-1:-1:-1;;;27777:7:1;:56::i;:::-;27918:6;27912:13;27903:6;27899:2;27895:15;27888:38;27457:493;-1:-1:-1;;;;;;27617:64:1;-1:-1:-1;;;27617:64:1;;-1:-1:-1;27283:673:1;;;;;;:::o;11997:159::-;-1:-1:-1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;12124:24:1;;;;:17;:24;;;;;;12105:44;;-1:-1:-1;;;;;;;;;;;;;15031:41:1;;;;2004:3;15116:33;;;15082:68;;-1:-1:-1;;;15082:68:1;-1:-1:-1;;;15179:24:1;;:29;;-1:-1:-1;;;15160:48:1;;;;2513:3;15247:28;;;;-1:-1:-1;;;15218:58:1;-1:-1:-1;14922:361:1;7395:104:8;7455:13;7484:9;7477:16;;;;;:::i;410:696:10:-;466:13;515:14;532:17;543:5;532:10;:17::i;:::-;552:1;532:21;515:38;;567:20;601:6;590:18;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;590:18:10;-1:-1:-1;567:41:10;-1:-1:-1;728:28:10;;;744:2;728:28;783:280;-1:-1:-1;;814:5:10;-1:-1:-1;;;948:2:10;937:14;;932:30;814:5;919:44;1007:2;998:11;;;-1:-1:-1;1031:10:10;1027:21;;1043:5;;1027:21;783:280;;1156:184:6;1277:4;1329;1300:25;1313:5;1320:4;1300:12;:25::i;:::-;:33;;1156:184;-1:-1:-1;;;;1156:184:6:o;33362:688:1:-;33488:19;33494:2;33498:8;33488:5;:19::i;:::-;-1:-1:-1;;;;;33546:14:1;;;:19;33542:492;;33585:11;33599:13;33646:14;;;33678:238;33708:62;33747:1;33751:2;33755:7;;;;;;33764:5;33708:30;:62::i;:::-;33703:174;;33798:56;-1:-1:-1;;;33798:7:1;:56::i;:::-;33911:3;33903:5;:11;33678:238;;33996:3;33979:13;;:20;33975:44;;34001:18;34016:1;34001:7;:18::i;9889:890:5:-;9942:7;;-1:-1:-1;;;10017:15:5;;10013:99;;-1:-1:-1;;;10052:15:5;;;-1:-1:-1;10095:2:5;10085:12;10013:99;10138:6;10129:5;:15;10125:99;;10173:6;10164:15;;;-1:-1:-1;10207:2:5;10197:12;10125:99;10250:6;10241:5;:15;10237:99;;10285:6;10276:15;;;-1:-1:-1;10319:2:5;10309:12;10237:99;10362:5;10353;:14;10349:96;;10396:5;10387:14;;;-1:-1:-1;10429:1:5;10419:11;10349:96;10471:5;10462;:14;10458:96;;10505:5;10496:14;;;-1:-1:-1;10538:1:5;10528:11;10458:96;10580:5;10571;:14;10567:96;;10614:5;10605:14;;;-1:-1:-1;10647:1:5;10637:11;10567:96;10689:5;10680;:14;10676:64;;10724:1;10714:11;10766:6;9889:890;-1:-1:-1;;9889:890:5:o;1994:290:6:-;2077:7;2119:4;2077:7;2133:116;2157:5;:12;2153:1;:16;2133:116;;;2205:33;2215:12;2229:5;2235:1;2229:8;;;;;;;;:::i;:::-;;;;;;;2205:9;:33::i;:::-;2190:48;-1:-1:-1;2171:3:6;;;;:::i;:::-;;;;2133:116;;28402:2251:1;28474:20;28497:13;28524;28520:53;;28539:34;-1:-1:-1;;;28539:7:1;:34::i;:::-;29073:31;;;;:17;:31;;;;;;;;-1:-1:-1;;;;;15595:28:1;;15767:11;15742:23;15738:41;16200:1;16187:15;;16161:24;16157:46;15735:52;15725:63;;29073:170;;;29454:22;;;:18;:22;;;;;;:71;;29492:32;29480:45;;29454:71;;;15595:28;29706:54;;29725:35;-1:-1:-1;;;29725:7:1;:35::i;:::-;29789:23;;;:12;29871:662;30281:7;30238:8;30194:1;30129:25;30067:1;30003;29973:351;30515:9;;:16;;;;29871:662;;-1:-1:-1;30547:13:1;:19;-1:-1:-1;24084:187:1;;;:::o;8879:147:6:-;8942:7;8972:1;8968;:5;:51;;9100:13;9191:15;;;9226:4;9219:15;;;9272:4;9256:21;;8968:51;;;-1:-1:-1;9100:13:6;9191:15;;;9226:4;9219:15;9272:4;9256:21;;;8879:147::o;-1:-1:-1:-;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;:::o;:::-;;;;;;;;;;;;;;;14:131:11;-1:-1:-1;;;;;;88:32:11;;78:43;;68:71;;135:1;132;125:12;150:245;208:6;261:2;249:9;240:7;236:23;232:32;229:52;;;277:1;274;267:12;229:52;316:9;303:23;335:30;359:5;335:30;:::i;592:258::-;664:1;674:113;688:6;685:1;682:13;674:113;;;764:11;;;758:18;745:11;;;738:39;710:2;703:10;674:113;;;805:6;802:1;799:13;796:48;;;-1:-1:-1;;840:1:11;822:16;;815:27;592:258::o;855:::-;897:3;935:5;929:12;962:6;957:3;950:19;978:63;1034:6;1027:4;1022:3;1018:14;1011:4;1004:5;1000:16;978:63;:::i;:::-;1095:2;1074:15;-1:-1:-1;;1070:29:11;1061:39;;;;1102:4;1057:50;;855:258;-1:-1:-1;;855:258:11:o;1118:220::-;1267:2;1256:9;1249:21;1230:4;1287:45;1328:2;1317:9;1313:18;1305:6;1287:45;:::i;1343:180::-;1402:6;1455:2;1443:9;1434:7;1430:23;1426:32;1423:52;;;1471:1;1468;1461:12;1423:52;-1:-1:-1;1494:23:11;;1343:180;-1:-1:-1;1343:180:11:o;1736:173::-;1804:20;;-1:-1:-1;;;;;1853:31:11;;1843:42;;1833:70;;1899:1;1896;1889:12;1914:254;1982:6;1990;2043:2;2031:9;2022:7;2018:23;2014:32;2011:52;;;2059:1;2056;2049:12;2011:52;2082:29;2101:9;2082:29;:::i;:::-;2072:39;2158:2;2143:18;;;;2130:32;;-1:-1:-1;;;1914:254:11:o;2355:127::-;2416:10;2411:3;2407:20;2404:1;2397:31;2447:4;2444:1;2437:15;2471:4;2468:1;2461:15;2487:275;2558:2;2552:9;2623:2;2604:13;;-1:-1:-1;;2600:27:11;2588:40;;2658:18;2643:34;;2679:22;;;2640:62;2637:88;;;2705:18;;:::i;:::-;2741:2;2734:22;2487:275;;-1:-1:-1;2487:275:11:o;2767:407::-;2832:5;2866:18;2858:6;2855:30;2852:56;;;2888:18;;:::i;:::-;2926:57;2971:2;2950:15;;-1:-1:-1;;2946:29:11;2977:4;2942:40;2926:57;:::i;:::-;2917:66;;3006:6;2999:5;2992:21;3046:3;3037:6;3032:3;3028:16;3025:25;3022:45;;;3063:1;3060;3053:12;3022:45;3112:6;3107:3;3100:4;3093:5;3089:16;3076:43;3166:1;3159:4;3150:6;3143:5;3139:18;3135:29;3128:40;2767:407;;;;;:::o;3179:451::-;3248:6;3301:2;3289:9;3280:7;3276:23;3272:32;3269:52;;;3317:1;3314;3307:12;3269:52;3357:9;3344:23;3390:18;3382:6;3379:30;3376:50;;;3422:1;3419;3412:12;3376:50;3445:22;;3498:4;3490:13;;3486:27;-1:-1:-1;3476:55:11;;3527:1;3524;3517:12;3476:55;3550:74;3616:7;3611:2;3598:16;3593:2;3589;3585:11;3550:74;:::i;3635:118::-;3721:5;3714:13;3707:21;3700:5;3697:32;3687:60;;3743:1;3740;3733:12;3758:241;3814:6;3867:2;3855:9;3846:7;3842:23;3838:32;3835:52;;;3883:1;3880;3873:12;3835:52;3922:9;3909:23;3941:28;3963:5;3941:28;:::i;4004:328::-;4081:6;4089;4097;4150:2;4138:9;4129:7;4125:23;4121:32;4118:52;;;4166:1;4163;4156:12;4118:52;4189:29;4208:9;4189:29;:::i;:::-;4179:39;;4237:38;4271:2;4260:9;4256:18;4237:38;:::i;:::-;4227:48;;4322:2;4311:9;4307:18;4294:32;4284:42;;4004:328;;;;;:::o;4742:186::-;4801:6;4854:2;4842:9;4833:7;4829:23;4825:32;4822:52;;;4870:1;4867;4860:12;4822:52;4893:29;4912:9;4893:29;:::i;4933:367::-;4996:8;5006:6;5060:3;5053:4;5045:6;5041:17;5037:27;5027:55;;5078:1;5075;5068:12;5027:55;-1:-1:-1;5101:20:11;;5144:18;5133:30;;5130:50;;;5176:1;5173;5166:12;5130:50;5213:4;5205:6;5201:17;5189:29;;5273:3;5266:4;5256:6;5253:1;5249:14;5241:6;5237:27;5233:38;5230:47;5227:67;;;5290:1;5287;5280:12;5227:67;4933:367;;;;;:::o;5305:437::-;5391:6;5399;5452:2;5440:9;5431:7;5427:23;5423:32;5420:52;;;5468:1;5465;5458:12;5420:52;5508:9;5495:23;5541:18;5533:6;5530:30;5527:50;;;5573:1;5570;5563:12;5527:50;5612:70;5674:7;5665:6;5654:9;5650:22;5612:70;:::i;:::-;5701:8;;5586:96;;-1:-1:-1;5305:437:11;-1:-1:-1;;;;5305:437:11:o;5747:349::-;5831:12;;-1:-1:-1;;;;;5827:38:11;5815:51;;5919:4;5908:16;;;5902:23;5927:18;5898:48;5882:14;;;5875:72;6010:4;5999:16;;;5993:23;5986:31;5979:39;5963:14;;;5956:63;6072:4;6061:16;;;6055:23;6080:8;6051:38;6035:14;;6028:62;5747:349::o;6101:724::-;6336:2;6388:21;;;6458:13;;6361:18;;;6480:22;;;6307:4;;6336:2;6559:15;;;;6533:2;6518:18;;;6307:4;6602:197;6616:6;6613:1;6610:13;6602:197;;;6665:52;6713:3;6704:6;6698:13;6665:52;:::i;:::-;6774:15;;;;6746:4;6737:14;;;;;6638:1;6631:9;6602:197;;6830:946;6914:6;6945:2;6988;6976:9;6967:7;6963:23;6959:32;6956:52;;;7004:1;7001;6994:12;6956:52;7044:9;7031:23;7073:18;7114:2;7106:6;7103:14;7100:34;;;7130:1;7127;7120:12;7100:34;7168:6;7157:9;7153:22;7143:32;;7213:7;7206:4;7202:2;7198:13;7194:27;7184:55;;7235:1;7232;7225:12;7184:55;7271:2;7258:16;7293:2;7289;7286:10;7283:36;;;7299:18;;:::i;:::-;7345:2;7342:1;7338:10;7328:20;;7368:28;7392:2;7388;7384:11;7368:28;:::i;:::-;7430:15;;;7500:11;;;7496:20;;;7461:12;;;;7528:19;;;7525:39;;;7560:1;7557;7550:12;7525:39;7584:11;;;;7604:142;7620:6;7615:3;7612:15;7604:142;;;7686:17;;7674:30;;7637:12;;;;7724;;;;7604:142;;;7765:5;6830:946;-1:-1:-1;;;;;;;;6830:946:11:o;7966:632::-;8137:2;8189:21;;;8259:13;;8162:18;;;8281:22;;;8108:4;;8137:2;8360:15;;;;8334:2;8319:18;;;8108:4;8403:169;8417:6;8414:1;8411:13;8403:169;;;8478:13;;8466:26;;8547:15;;;;8512:12;;;;8439:1;8432:9;8403:169;;8603:322;8680:6;8688;8696;8749:2;8737:9;8728:7;8724:23;8720:32;8717:52;;;8765:1;8762;8755:12;8717:52;8788:29;8807:9;8788:29;:::i;:::-;8778:39;8864:2;8849:18;;8836:32;;-1:-1:-1;8915:2:11;8900:18;;;8887:32;;8603:322;-1:-1:-1;;;8603:322:11:o;8930:315::-;8995:6;9003;9056:2;9044:9;9035:7;9031:23;9027:32;9024:52;;;9072:1;9069;9062:12;9024:52;9095:29;9114:9;9095:29;:::i;:::-;9085:39;;9174:2;9163:9;9159:18;9146:32;9187:28;9209:5;9187:28;:::i;:::-;9234:5;9224:15;;;8930:315;;;;;:::o;9250:667::-;9345:6;9353;9361;9369;9422:3;9410:9;9401:7;9397:23;9393:33;9390:53;;;9439:1;9436;9429:12;9390:53;9462:29;9481:9;9462:29;:::i;:::-;9452:39;;9510:38;9544:2;9533:9;9529:18;9510:38;:::i;:::-;9500:48;;9595:2;9584:9;9580:18;9567:32;9557:42;;9650:2;9639:9;9635:18;9622:32;9677:18;9669:6;9666:30;9663:50;;;9709:1;9706;9699:12;9663:50;9732:22;;9785:4;9777:13;;9773:27;-1:-1:-1;9763:55:11;;9814:1;9811;9804:12;9763:55;9837:74;9903:7;9898:2;9885:16;9880:2;9876;9872:11;9837:74;:::i;:::-;9827:84;;;9250:667;;;;;;;:::o;9922:268::-;10120:3;10105:19;;10133:51;10109:9;10166:6;10133:51;:::i;10195:505::-;10290:6;10298;10306;10359:2;10347:9;10338:7;10334:23;10330:32;10327:52;;;10375:1;10372;10365:12;10327:52;10411:9;10398:23;10388:33;;10472:2;10461:9;10457:18;10444:32;10499:18;10491:6;10488:30;10485:50;;;10531:1;10528;10521:12;10485:50;10570:70;10632:7;10623:6;10612:9;10608:22;10570:70;:::i;:::-;10195:505;;10659:8;;-1:-1:-1;10544:96:11;;-1:-1:-1;;;;10195:505:11:o;10705:260::-;10773:6;10781;10834:2;10822:9;10813:7;10809:23;10805:32;10802:52;;;10850:1;10847;10840:12;10802:52;10873:29;10892:9;10873:29;:::i;:::-;10863:39;;10921:38;10955:2;10944:9;10940:18;10921:38;:::i;:::-;10911:48;;10705:260;;;;;:::o;10970:254::-;11038:6;11046;11099:2;11087:9;11078:7;11074:23;11070:32;11067:52;;;11115:1;11112;11105:12;11067:52;11151:9;11138:23;11128:33;;11180:38;11214:2;11203:9;11199:18;11180:38;:::i;11229:380::-;11308:1;11304:12;;;;11351;;;11372:61;;11426:4;11418:6;11414:17;11404:27;;11372:61;11479:2;11471:6;11468:14;11448:18;11445:38;11442:161;;;11525:10;11520:3;11516:20;11513:1;11506:31;11560:4;11557:1;11550:15;11588:4;11585:1;11578:15;11442:161;;11229:380;;;:::o;12232:127::-;12293:10;12288:3;12284:20;12281:1;12274:31;12324:4;12321:1;12314:15;12348:4;12345:1;12338:15;12996:245;13063:6;13116:2;13104:9;13095:7;13091:23;13087:32;13084:52;;;13132:1;13129;13122:12;13084:52;13164:9;13158:16;13183:28;13205:5;13183:28;:::i;13246:127::-;13307:10;13302:3;13298:20;13295:1;13288:31;13338:4;13335:1;13328:15;13362:4;13359:1;13352:15;13378:135;13417:3;-1:-1:-1;;13438:17:11;;13435:43;;;13458:18;;:::i;:::-;-1:-1:-1;13505:1:11;13494:13;;13378:135::o;13518:344::-;13720:2;13702:21;;;13759:2;13739:18;;;13732:30;-1:-1:-1;;;13793:2:11;13778:18;;13771:50;13853:2;13838:18;;13518:344::o;13867:128::-;13907:3;13938:1;13934:6;13931:1;13928:13;13925:39;;;13944:18;;:::i;:::-;-1:-1:-1;13980:9:11;;13867:128::o;14000:344::-;14202:2;14184:21;;;14241:2;14221:18;;;14214:30;-1:-1:-1;;;14275:2:11;14260:18;;14253:50;14335:2;14320:18;;14000:344::o;15060:355::-;15262:2;15244:21;;;15301:2;15281:18;;;15274:30;15340:33;15335:2;15320:18;;15313:61;15406:2;15391:18;;15060:355::o;15420:168::-;15460:7;15526:1;15522;15518:6;15514:14;15511:1;15508:21;15503:1;15496:9;15489:17;15485:45;15482:71;;;15533:18;;:::i;:::-;-1:-1:-1;15573:9:11;;15420:168::o;15593:125::-;15633:4;15661:1;15658;15655:8;15652:34;;;15666:18;;:::i;:::-;-1:-1:-1;15703:9:11;;15593:125::o;15723:343::-;15925:2;15907:21;;;15964:2;15944:18;;;15937:30;-1:-1:-1;;;15998:2:11;15983:18;;15976:49;16057:2;16042:18;;15723:343::o;16613:1527::-;16837:3;16875:6;16869:13;16901:4;16914:51;16958:6;16953:3;16948:2;16940:6;16936:15;16914:51;:::i;:::-;17028:13;;16987:16;;;;17050:55;17028:13;16987:16;17072:15;;;17050:55;:::i;:::-;17194:13;;17127:20;;;17167:1;;17254;17276:18;;;;17329;;;;17356:93;;17434:4;17424:8;17420:19;17408:31;;17356:93;17497:2;17487:8;17484:16;17464:18;17461:40;17458:167;;;-1:-1:-1;;;17524:33:11;;17580:4;17577:1;17570:15;17610:4;17531:3;17598:17;17458:167;17641:18;17668:110;;;;17792:1;17787:328;;;;17634:481;;17668:110;-1:-1:-1;;17703:24:11;;17689:39;;17748:20;;;;-1:-1:-1;17668:110:11;;17787:328;16560:1;16553:14;;;16597:4;16584:18;;17882:1;17896:169;17910:8;17907:1;17904:15;17896:169;;;17992:14;;17977:13;;;17970:37;18035:16;;;;17927:10;;17896:169;;;17900:3;;18096:8;18089:5;18085:20;18078:27;;17634:481;-1:-1:-1;18131:3:11;;16613:1527;-1:-1:-1;;;;;;;;;;;16613:1527:11:o;19885:136::-;19924:3;19952:5;19942:39;;19961:18;;:::i;:::-;-1:-1:-1;;;19997:18:11;;19885:136::o;20747:489::-;-1:-1:-1;;;;;21016:15:11;;;20998:34;;21068:15;;21063:2;21048:18;;21041:43;21115:2;21100:18;;21093:34;;;21163:3;21158:2;21143:18;;21136:31;;;20941:4;;21184:46;;21210:19;;21202:6;21184:46;:::i;:::-;21176:54;20747:489;-1:-1:-1;;;;;;20747:489:11:o;21241:249::-;21310:6;21363:2;21351:9;21342:7;21338:23;21334:32;21331:52;;;21379:1;21376;21369:12;21331:52;21411:9;21405:16;21430:30;21454:5;21430:30;:::i
Swarm Source
ipfs://8618e0c8a68ec3a577d22999e1ffbfc6f6012574f509b5a2aa394f6629573187
Loading...
Loading
Loading...
Loading
[ Download: CSV Export ]
[ Download: CSV Export ]
A token is a representation of an on-chain or off-chain asset. The token page shows information such as price, total supply, holders, transfers and social links. Learn more about this page in our Knowledge Base.