Feature Tip: Add private address tag to any address under My Name Tag !
ERC-721
Overview
Max Total Supply
12 MOODY
Holders
1
Market
Volume (24H)
N/A
Min Price (24H)
N/A
Max Price (24H)
N/A
Other Info
Token Contract
Balance
12 MOODYLoading...
Loading
Loading...
Loading
Loading...
Loading
# | Exchange | Pair | Price | 24H Volume | % Volume |
---|
Contract Name:
MoodyMushrooms
Compiler Version
v0.7.0+commit.9e61f92b
Contract Source Code (Solidity Multiple files format)
// SPDX-License-Identifier: MIT // File: contracts/MoodyMushrooms.sol pragma solidity ^0.7.0; import "./ERC721.sol"; import "./Ownable.sol"; import "./PaymentSplitter.sol"; import "./Whitelist.sol"; import "./Counters.sol"; /** * @title MoodyMushrooms contract * @dev Extends ERC721 Non-Fungible Token Standard basic implementation */ contract MoodyMushrooms is ERC721, Ownable, PaymentSplitter, Whitelist{ using SafeMath for uint256; string public MM_PROVENANCE = ""; uint256 public startingIndexBlock; uint256 public startingIndex; uint256 public constant mushroomMintPrice = 50000000000000000; //0.05 ETH uint256 public constant whitelistMintPrice = 40000000000000000; //0.04 ETH uint public constant maxMushroomPurchase = 3; uint256 public MAX_MUSHROOM_SUPPLY; bool public saleIsActive = false; bool public presaleIsActive = false; uint256 public REVEAL_TIMESTAMP; using Counters for Counters.Counter; Counters.Counter private _tokenSupply; struct Account { uint mintedNFTs; } mapping(address => Account) public accounts; IERC721Enumerable public GigaGardenPass; constructor(string memory name, string memory symbol, uint256 maxNftSupply, uint256 saleStart, address[] memory addrs, uint256[] memory shares_, address[] memory wl_addrs) ERC721(name, symbol) PaymentSplitter(addrs,shares_) Whitelist(wl_addrs){ MAX_MUSHROOM_SUPPLY = maxNftSupply; REVEAL_TIMESTAMP = saleStart; GigaGardenPass = IERC721Enumerable(0x812701d9bA747c01F9B94655De6fd4f089D76cB5); } /** * Set some Moody Mushrooms aside for giveaways and promotions */ function reserveMushrooms() public onlyOwner { uint supply = _tokenSupply.current()+1; uint i; for (i = 0; i < 12; i++) { _safeMint(msg.sender, supply + i); } } /** * DM ImEmmy in Discord that you're standing right behind him */ function setRevealTimestamp(uint256 revealTimeStamp) public onlyOwner { REVEAL_TIMESTAMP = revealTimeStamp; } /* * Set provenance once it's calculated */ function setProvenanceHash(string memory provenanceHash) public onlyOwner { MM_PROVENANCE = provenanceHash; } function setBaseURI(string memory baseURI) public onlyOwner { _setBaseURI(baseURI); } function setPassAddress(address contractAddr) public onlyOwner { GigaGardenPass = IERC721Enumerable(contractAddr); } function hasPass(address _address) public view returns(bool) { if(GigaGardenPass.balanceOf(_address)>0) return true; return false; } /* * Pause sale if active, make active if paused */ function flipSaleState() public onlyOwner { presaleIsActive = false; saleIsActive = !saleIsActive; } /* * Pause presale if active, make active if paused */ function flipPreSaleState() public onlyOwner { saleIsActive = false; presaleIsActive = !presaleIsActive; } /** * Mints Self Rising Flowers */ function mintMushroom(uint numberOfTokens) public payable { require(saleIsActive || presaleIsActive, "Sale must be active to mint Moody Mushrooms"); if(presaleIsActive && !saleIsActive){ require(hasPass(msg.sender) || isWhitelisted(msg.sender),"Must be Whitelisted to mint before Jan 15, 2022 11:00:00 PM GMT"); require(_tokenSupply.current().add(numberOfTokens) <= MAX_MUSHROOM_SUPPLY, "Purchase would exceed max supply of Moody Mushrooms"); } require(numberOfTokens <= maxMushroomPurchase, "Can only mint 3 Moody Mushrooms at a time"); require((numberOfTokens.add(accounts[msg.sender].mintedNFTs)) <= maxMushroomPurchase, "Sorry purchase would exceed 3 mints per wallet"); require(_tokenSupply.current().add(numberOfTokens) <= MAX_MUSHROOM_SUPPLY, "Purchase would exceed max supply of Moody Mushrooms"); if(hasPass(msg.sender)) require(whitelistMintPrice.mul(numberOfTokens) <= msg.value, "Ether value sent is not correct"); else require(mushroomMintPrice.mul(numberOfTokens) <= msg.value, "Ether value sent is not correct"); require(!isContract(msg.sender), "Contracts can't mint"); for(uint i = 0; i < numberOfTokens; i++) { if (_tokenSupply.current() <= MAX_MUSHROOM_SUPPLY) { accounts[msg.sender].mintedNFTs++; _tokenSupply.increment(); _safeMint(msg.sender, _tokenSupply.current()); } } // If we haven't set the starting index and this is either 1) the last saleable token or 2) the first token to be sold after // the end of pre-sale, set the starting index block if (startingIndexBlock == 0 && (_tokenSupply.current() == MAX_MUSHROOM_SUPPLY || block.timestamp >= REVEAL_TIMESTAMP)) { startingIndexBlock = block.number; } } /* * Replacement for ERC721Enumerable totalSupply() to save gas */ function tokensMinted() public view returns (uint256) { return _tokenSupply.current(); } /** * Set the starting index for the collection */ function setStartingIndex() public { require(startingIndex == 0, "Starting index is already set"); require(startingIndexBlock != 0, "Starting index block must be set"); startingIndex = uint(blockhash(startingIndexBlock)) % MAX_MUSHROOM_SUPPLY; // Just a sanity case in the worst case if this function is called late (EVM only stores last 256 block hashes) if (block.number.sub(startingIndexBlock) > 255) { startingIndex = uint(blockhash(block.number - 1)) % MAX_MUSHROOM_SUPPLY; } // Prevent default sequence if (startingIndex == 0) { startingIndex = startingIndex.add(1); } } /** * Set the starting index block for the collection, essentially unblocking * setting starting index */ function emergencySetStartingIndexBlock() public onlyOwner { require(startingIndex == 0, "Starting index is already set"); startingIndexBlock = block.number; } function isContract(address account) internal view returns (bool) { // This method relies on extcodesize, which returns 0 for contracts in // construction, since the code is only stored at the end of the // constructor execution. uint256 size; assembly { size := extcodesize(account) } return size > 0; } }
// SPDX-License-Identifier: MIT // File: @openzeppelin/contracts/utils/Address.sol pragma solidity >=0.6.2 <0.8.0; /** * @dev Collection of functions related to the address type */ library Address { /** * @dev Returns true if `account` is a contract. * * [IMPORTANT] * ==== * It is unsafe to assume that an address for which this function returns * false is an externally-owned account (EOA) and not a contract. * * Among others, `isContract` will return false for the following * types of addresses: * * - an externally-owned account * - a contract in construction * - an address where a contract will be created * - an address where a contract lived, but was destroyed * ==== */ function isContract(address account) internal view returns (bool) { // This method relies on extcodesize, which returns 0 for contracts in // construction, since the code is only stored at the end of the // constructor execution. uint256 size; // solhint-disable-next-line no-inline-assembly assembly { size := extcodesize(account) } return size > 0; } /** * @dev Replacement for Solidity's `transfer`: sends `amount` wei to * `recipient`, forwarding all available gas and reverting on errors. * * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost * of certain opcodes, possibly making contracts go over the 2300 gas limit * imposed by `transfer`, making them unable to receive funds via * `transfer`. {sendValue} removes this limitation. * * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more]. * * IMPORTANT: because control is transferred to `recipient`, care must be * taken to not create reentrancy vulnerabilities. Consider using * {ReentrancyGuard} or the * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern]. */ function sendValue(address payable recipient, uint256 amount) internal { require(address(this).balance >= amount, "Address: insufficient balance"); // solhint-disable-next-line avoid-low-level-calls, avoid-call-value (bool success, ) = recipient.call{ value: amount }(""); require(success, "Address: unable to send value, recipient may have reverted"); } /** * @dev Performs a Solidity function call using a low level `call`. A * plain`call` is an unsafe replacement for a function call: use this * function instead. * * If `target` reverts with a revert reason, it is bubbled up by this * function (like regular Solidity function calls). * * Returns the raw returned data. To convert to the expected return value, * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`]. * * Requirements: * * - `target` must be a contract. * - calling `target` with `data` must not revert. * * _Available since v3.1._ */ function functionCall(address target, bytes memory data) internal returns (bytes memory) { return functionCall(target, data, "Address: low-level call failed"); } /** * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with * `errorMessage` as a fallback revert reason when `target` reverts. * * _Available since v3.1._ */ function functionCall(address target, bytes memory data, string memory errorMessage) internal returns (bytes memory) { return functionCallWithValue(target, data, 0, errorMessage); } /** * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], * but also transferring `value` wei to `target`. * * Requirements: * * - the calling contract must have an ETH balance of at least `value`. * - the called Solidity function must be `payable`. * * _Available since v3.1._ */ function functionCallWithValue(address target, bytes memory data, uint256 value) internal returns (bytes memory) { return functionCallWithValue(target, data, value, "Address: low-level call with value failed"); } /** * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but * with `errorMessage` as a fallback revert reason when `target` reverts. * * _Available since v3.1._ */ function functionCallWithValue(address target, bytes memory data, uint256 value, string memory errorMessage) internal returns (bytes memory) { require(address(this).balance >= value, "Address: insufficient balance for call"); require(isContract(target), "Address: call to non-contract"); // solhint-disable-next-line avoid-low-level-calls (bool success, bytes memory returndata) = target.call{ value: value }(data); return _verifyCallResult(success, returndata, errorMessage); } /** * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], * but performing a static call. * * _Available since v3.3._ */ function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) { return functionStaticCall(target, data, "Address: low-level static call failed"); } /** * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`], * but performing a static call. * * _Available since v3.3._ */ function functionStaticCall(address target, bytes memory data, string memory errorMessage) internal view returns (bytes memory) { require(isContract(target), "Address: static call to non-contract"); // solhint-disable-next-line avoid-low-level-calls (bool success, bytes memory returndata) = target.staticcall(data); return _verifyCallResult(success, returndata, errorMessage); } /** * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], * but performing a delegate call. * * _Available since v3.4._ */ function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) { return functionDelegateCall(target, data, "Address: low-level delegate call failed"); } /** * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`], * but performing a delegate call. * * _Available since v3.4._ */ function functionDelegateCall(address target, bytes memory data, string memory errorMessage) internal returns (bytes memory) { require(isContract(target), "Address: delegate call to non-contract"); // solhint-disable-next-line avoid-low-level-calls (bool success, bytes memory returndata) = target.delegatecall(data); return _verifyCallResult(success, returndata, errorMessage); } function _verifyCallResult(bool success, bytes memory returndata, string memory errorMessage) private pure returns(bytes memory) { if (success) { return returndata; } else { // Look for revert reason and bubble it up if present if (returndata.length > 0) { // The easiest way to bubble the revert reason is using memory via assembly // solhint-disable-next-line no-inline-assembly assembly { let returndata_size := mload(returndata) revert(add(32, returndata), returndata_size) } } else { revert(errorMessage); } } } }
// SPDX-License-Identifier: MIT // File: @openzeppelin/contracts/utils/Context.sol pragma solidity >=0.6.0 <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 GSN 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 payable) { return msg.sender; } function _msgData() internal view virtual returns (bytes memory) { this; // silence state mutability warning without generating bytecode - see https://github.com/ethereum/solidity/issues/2691 return msg.data; } }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts v4.4.1 (utils/Counters.sol) pragma solidity ^0.7.0; import "./SafeMath.sol"; /** * @title Counters * @author Matt Condon (@shrugs) * @dev Provides counters that can only be incremented, decremented or reset. This can be used e.g. to track the number * of elements in a mapping, issuing ERC721 ids, or counting request ids. * * Include with `using Counters for Counters.Counter;` */ library Counters { using SafeMath for uint256; struct Counter { // This variable should never be directly accessed by users of the library: interactions must be restricted to // the library's function. As of Solidity v0.5.2, this cannot be enforced, though there is a proposal to add // this feature: see https://github.com/ethereum/solidity/issues/4637 uint256 _value; // default: 0 } function current(Counter storage counter) internal view returns (uint256) { return counter._value; } function increment(Counter storage counter) internal { counter._value = counter._value.add(1); } function decrement(Counter storage counter) internal { uint256 value = counter._value; counter._value = counter._value.sub(1); } function reset(Counter storage counter) internal { counter._value = 0; } }
// SPDX-License-Identifier: MIT // File: @openzeppelin/contracts/utils/EnumerableMap.sol pragma solidity >=0.6.0 <0.8.0; /** * @dev Library for managing an enumerable variant of Solidity's * https://solidity.readthedocs.io/en/latest/types.html#mapping-types[`mapping`] * type. * * Maps have the following properties: * * - Entries are added, removed, and checked for existence in constant time * (O(1)). * - Entries are enumerated in O(n). No guarantees are made on the ordering. * * ``` * contract Example { * // Add the library methods * using EnumerableMap for EnumerableMap.UintToAddressMap; * * // Declare a set state variable * EnumerableMap.UintToAddressMap private myMap; * } * ``` * * As of v3.0.0, only maps of type `uint256 -> address` (`UintToAddressMap`) are * supported. */ library EnumerableMap { // To implement this library for multiple types with as little code // repetition as possible, we write it in terms of a generic Map type with // bytes32 keys and values. // The Map implementation uses private functions, and user-facing // implementations (such as Uint256ToAddressMap) are just wrappers around // the underlying Map. // This means that we can only create new EnumerableMaps for types that fit // in bytes32. struct MapEntry { bytes32 _key; bytes32 _value; } struct Map { // Storage of map keys and values MapEntry[] _entries; // Position of the entry defined by a key in the `entries` array, plus 1 // because index 0 means a key is not in the map. mapping (bytes32 => uint256) _indexes; } /** * @dev Adds a key-value pair to a map, or updates the value for an existing * key. O(1). * * Returns true if the key was added to the map, that is if it was not * already present. */ function _set(Map storage map, bytes32 key, bytes32 value) private returns (bool) { // We read and store the key's index to prevent multiple reads from the same storage slot uint256 keyIndex = map._indexes[key]; if (keyIndex == 0) { // Equivalent to !contains(map, key) map._entries.push(MapEntry({ _key: key, _value: value })); // The entry is stored at length-1, but we add 1 to all indexes // and use 0 as a sentinel value map._indexes[key] = map._entries.length; return true; } else { map._entries[keyIndex - 1]._value = value; return false; } } /** * @dev Removes a key-value pair from a map. O(1). * * Returns true if the key was removed from the map, that is if it was present. */ function _remove(Map storage map, bytes32 key) private returns (bool) { // We read and store the key's index to prevent multiple reads from the same storage slot uint256 keyIndex = map._indexes[key]; if (keyIndex != 0) { // Equivalent to contains(map, key) // To delete a key-value pair from the _entries array in O(1), we swap the entry to delete with the last one // in the array, and then remove the last entry (sometimes called as 'swap and pop'). // This modifies the order of the array, as noted in {at}. uint256 toDeleteIndex = keyIndex - 1; uint256 lastIndex = map._entries.length - 1; // When the entry to delete is the last one, the swap operation is unnecessary. However, since this occurs // so rarely, we still do the swap anyway to avoid the gas cost of adding an 'if' statement. MapEntry storage lastEntry = map._entries[lastIndex]; // Move the last entry to the index where the entry to delete is map._entries[toDeleteIndex] = lastEntry; // Update the index for the moved entry map._indexes[lastEntry._key] = toDeleteIndex + 1; // All indexes are 1-based // Delete the slot where the moved entry was stored map._entries.pop(); // Delete the index for the deleted slot delete map._indexes[key]; return true; } else { return false; } } /** * @dev Returns true if the key is in the map. O(1). */ function _contains(Map storage map, bytes32 key) private view returns (bool) { return map._indexes[key] != 0; } /** * @dev Returns the number of key-value pairs in the map. O(1). */ function _length(Map storage map) private view returns (uint256) { return map._entries.length; } /** * @dev Returns the key-value pair stored at position `index` in the map. O(1). * * Note that there are no guarantees on the ordering of entries inside the * array, and it may change when more entries are added or removed. * * Requirements: * * - `index` must be strictly less than {length}. */ function _at(Map storage map, uint256 index) private view returns (bytes32, bytes32) { require(map._entries.length > index, "EnumerableMap: index out of bounds"); MapEntry storage entry = map._entries[index]; return (entry._key, entry._value); } /** * @dev Tries to returns the value associated with `key`. O(1). * Does not revert if `key` is not in the map. */ function _tryGet(Map storage map, bytes32 key) private view returns (bool, bytes32) { uint256 keyIndex = map._indexes[key]; if (keyIndex == 0) return (false, 0); // Equivalent to contains(map, key) return (true, map._entries[keyIndex - 1]._value); // All indexes are 1-based } /** * @dev Returns the value associated with `key`. O(1). * * Requirements: * * - `key` must be in the map. */ function _get(Map storage map, bytes32 key) private view returns (bytes32) { uint256 keyIndex = map._indexes[key]; require(keyIndex != 0, "EnumerableMap: nonexistent key"); // Equivalent to contains(map, key) return map._entries[keyIndex - 1]._value; // All indexes are 1-based } /** * @dev Same as {_get}, with a custom error message when `key` is not in the map. * * CAUTION: This function is deprecated because it requires allocating memory for the error * message unnecessarily. For custom revert reasons use {_tryGet}. */ function _get(Map storage map, bytes32 key, string memory errorMessage) private view returns (bytes32) { uint256 keyIndex = map._indexes[key]; require(keyIndex != 0, errorMessage); // Equivalent to contains(map, key) return map._entries[keyIndex - 1]._value; // All indexes are 1-based } // UintToAddressMap struct UintToAddressMap { Map _inner; } /** * @dev Adds a key-value pair to a map, or updates the value for an existing * key. O(1). * * Returns true if the key was added to the map, that is if it was not * already present. */ function set(UintToAddressMap storage map, uint256 key, address value) internal returns (bool) { return _set(map._inner, bytes32(key), bytes32(uint256(uint160(value)))); } /** * @dev Removes a value from a set. O(1). * * Returns true if the key was removed from the map, that is if it was present. */ function remove(UintToAddressMap storage map, uint256 key) internal returns (bool) { return _remove(map._inner, bytes32(key)); } /** * @dev Returns true if the key is in the map. O(1). */ function contains(UintToAddressMap storage map, uint256 key) internal view returns (bool) { return _contains(map._inner, bytes32(key)); } /** * @dev Returns the number of elements in the map. O(1). */ function length(UintToAddressMap storage map) internal view returns (uint256) { return _length(map._inner); } /** * @dev Returns the element stored at position `index` in the set. O(1). * Note that there are no guarantees on the ordering of values inside the * array, and it may change when more values are added or removed. * * Requirements: * * - `index` must be strictly less than {length}. */ function at(UintToAddressMap storage map, uint256 index) internal view returns (uint256, address) { (bytes32 key, bytes32 value) = _at(map._inner, index); return (uint256(key), address(uint160(uint256(value)))); } /** * @dev Tries to returns the value associated with `key`. O(1). * Does not revert if `key` is not in the map. * * _Available since v3.4._ */ function tryGet(UintToAddressMap storage map, uint256 key) internal view returns (bool, address) { (bool success, bytes32 value) = _tryGet(map._inner, bytes32(key)); return (success, address(uint160(uint256(value)))); } /** * @dev Returns the value associated with `key`. O(1). * * Requirements: * * - `key` must be in the map. */ function get(UintToAddressMap storage map, uint256 key) internal view returns (address) { return address(uint160(uint256(_get(map._inner, bytes32(key))))); } /** * @dev Same as {get}, with a custom error message when `key` is not in the map. * * CAUTION: This function is deprecated because it requires allocating memory for the error * message unnecessarily. For custom revert reasons use {tryGet}. */ function get(UintToAddressMap storage map, uint256 key, string memory errorMessage) internal view returns (address) { return address(uint160(uint256(_get(map._inner, bytes32(key), errorMessage)))); } }
// SPDX-License-Identifier: MIT // File: @openzeppelin/contracts/utils/EnumerableSet.sol pragma solidity >=0.6.0 <0.8.0; /** * @dev Library for managing * https://en.wikipedia.org/wiki/Set_(abstract_data_type)[sets] of primitive * types. * * Sets have the following properties: * * - Elements are added, removed, and checked for existence in constant time * (O(1)). * - Elements are enumerated in O(n). No guarantees are made on the ordering. * * ``` * contract Example { * // Add the library methods * using EnumerableSet for EnumerableSet.AddressSet; * * // Declare a set state variable * EnumerableSet.AddressSet private mySet; * } * ``` * * As of v3.3.0, sets of type `bytes32` (`Bytes32Set`), `address` (`AddressSet`) * and `uint256` (`UintSet`) are supported. */ library EnumerableSet { // To implement this library for multiple types with as little code // repetition as possible, we write it in terms of a generic Set type with // bytes32 values. // The Set implementation uses private functions, and user-facing // implementations (such as AddressSet) are just wrappers around the // underlying Set. // This means that we can only create new EnumerableSets for types that fit // in bytes32. struct Set { // Storage of set values bytes32[] _values; // Position of the value in the `values` array, plus 1 because index 0 // means a value is not in the set. mapping (bytes32 => uint256) _indexes; } /** * @dev Add a value to a set. O(1). * * Returns true if the value was added to the set, that is if it was not * already present. */ function _add(Set storage set, bytes32 value) private returns (bool) { if (!_contains(set, value)) { set._values.push(value); // The value is stored at length-1, but we add 1 to all indexes // and use 0 as a sentinel value set._indexes[value] = set._values.length; return true; } else { return false; } } /** * @dev Removes a value from a set. O(1). * * Returns true if the value was removed from the set, that is if it was * present. */ function _remove(Set storage set, bytes32 value) private returns (bool) { // We read and store the value's index to prevent multiple reads from the same storage slot uint256 valueIndex = set._indexes[value]; if (valueIndex != 0) { // Equivalent to contains(set, value) // To delete an element from the _values array in O(1), we swap the element to delete with the last one in // the array, and then remove the last element (sometimes called as 'swap and pop'). // This modifies the order of the array, as noted in {at}. uint256 toDeleteIndex = valueIndex - 1; uint256 lastIndex = set._values.length - 1; // When the value to delete is the last one, the swap operation is unnecessary. However, since this occurs // so rarely, we still do the swap anyway to avoid the gas cost of adding an 'if' statement. bytes32 lastvalue = set._values[lastIndex]; // Move the last value to the index where the value to delete is set._values[toDeleteIndex] = lastvalue; // Update the index for the moved value set._indexes[lastvalue] = toDeleteIndex + 1; // All indexes are 1-based // Delete the slot where the moved value was stored set._values.pop(); // Delete the index for the deleted slot delete set._indexes[value]; return true; } else { return false; } } /** * @dev Returns true if the value is in the set. O(1). */ function _contains(Set storage set, bytes32 value) private view returns (bool) { return set._indexes[value] != 0; } /** * @dev Returns the number of values on the set. O(1). */ function _length(Set storage set) private view returns (uint256) { return set._values.length; } /** * @dev Returns the value stored at position `index` in the set. O(1). * * Note that there are no guarantees on the ordering of values inside the * array, and it may change when more values are added or removed. * * Requirements: * * - `index` must be strictly less than {length}. */ function _at(Set storage set, uint256 index) private view returns (bytes32) { require(set._values.length > index, "EnumerableSet: index out of bounds"); return set._values[index]; } // Bytes32Set struct Bytes32Set { Set _inner; } /** * @dev Add a value to a set. O(1). * * Returns true if the value was added to the set, that is if it was not * already present. */ function add(Bytes32Set storage set, bytes32 value) internal returns (bool) { return _add(set._inner, value); } /** * @dev Removes a value from a set. O(1). * * Returns true if the value was removed from the set, that is if it was * present. */ function remove(Bytes32Set storage set, bytes32 value) internal returns (bool) { return _remove(set._inner, value); } /** * @dev Returns true if the value is in the set. O(1). */ function contains(Bytes32Set storage set, bytes32 value) internal view returns (bool) { return _contains(set._inner, value); } /** * @dev Returns the number of values in the set. O(1). */ function length(Bytes32Set storage set) internal view returns (uint256) { return _length(set._inner); } /** * @dev Returns the value stored at position `index` in the set. O(1). * * Note that there are no guarantees on the ordering of values inside the * array, and it may change when more values are added or removed. * * Requirements: * * - `index` must be strictly less than {length}. */ function at(Bytes32Set storage set, uint256 index) internal view returns (bytes32) { return _at(set._inner, index); } // AddressSet struct AddressSet { Set _inner; } /** * @dev Add a value to a set. O(1). * * Returns true if the value was added to the set, that is if it was not * already present. */ function add(AddressSet storage set, address value) internal returns (bool) { return _add(set._inner, bytes32(uint256(uint160(value)))); } /** * @dev Removes a value from a set. O(1). * * Returns true if the value was removed from the set, that is if it was * present. */ function remove(AddressSet storage set, address value) internal returns (bool) { return _remove(set._inner, bytes32(uint256(uint160(value)))); } /** * @dev Returns true if the value is in the set. O(1). */ function contains(AddressSet storage set, address value) internal view returns (bool) { return _contains(set._inner, bytes32(uint256(uint160(value)))); } /** * @dev Returns the number of values in the set. O(1). */ function length(AddressSet storage set) internal view returns (uint256) { return _length(set._inner); } /** * @dev Returns the value stored at position `index` in the set. O(1). * * Note that there are no guarantees on the ordering of values inside the * array, and it may change when more values are added or removed. * * Requirements: * * - `index` must be strictly less than {length}. */ function at(AddressSet storage set, uint256 index) internal view returns (address) { return address(uint160(uint256(_at(set._inner, index)))); } // UintSet struct UintSet { Set _inner; } /** * @dev Add a value to a set. O(1). * * Returns true if the value was added to the set, that is if it was not * already present. */ function add(UintSet storage set, uint256 value) internal returns (bool) { return _add(set._inner, bytes32(value)); } /** * @dev Removes a value from a set. O(1). * * Returns true if the value was removed from the set, that is if it was * present. */ function remove(UintSet storage set, uint256 value) internal returns (bool) { return _remove(set._inner, bytes32(value)); } /** * @dev Returns true if the value is in the set. O(1). */ function contains(UintSet storage set, uint256 value) internal view returns (bool) { return _contains(set._inner, bytes32(value)); } /** * @dev Returns the number of values on the set. O(1). */ function length(UintSet storage set) internal view returns (uint256) { return _length(set._inner); } /** * @dev Returns the value stored at position `index` in the set. O(1). * * Note that there are no guarantees on the ordering of values inside the * array, and it may change when more values are added or removed. * * Requirements: * * - `index` must be strictly less than {length}. */ function at(UintSet storage set, uint256 index) internal view returns (uint256) { return uint256(_at(set._inner, index)); } }
// SPDX-License-Identifier: MIT // File: @openzeppelin/contracts/introspection/ERC165.sol pragma solidity >=0.6.0 <0.8.0; import "./IERC165.sol"; /** * @dev Implementation of the {IERC165} interface. * * Contracts may inherit from this and call {_registerInterface} to declare * their support of an interface. */ abstract contract ERC165 is IERC165 { /* * bytes4(keccak256('supportsInterface(bytes4)')) == 0x01ffc9a7 */ bytes4 private constant _INTERFACE_ID_ERC165 = 0x01ffc9a7; /** * @dev Mapping of interface ids to whether or not it's supported. */ mapping(bytes4 => bool) private _supportedInterfaces; constructor () internal { // Derived contracts need only register support for their own interfaces, // we register support for ERC165 itself here _registerInterface(_INTERFACE_ID_ERC165); } /** * @dev See {IERC165-supportsInterface}. * * Time complexity O(1), guaranteed to always use less than 30 000 gas. */ function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) { return _supportedInterfaces[interfaceId]; } /** * @dev Registers the contract as an implementer of the interface defined by * `interfaceId`. Support of the actual ERC165 interface is automatic and * registering its interface id is not required. * * See {IERC165-supportsInterface}. * * Requirements: * * - `interfaceId` cannot be the ERC165 invalid interface (`0xffffffff`). */ function _registerInterface(bytes4 interfaceId) internal virtual { require(interfaceId != 0xffffffff, "ERC165: invalid interface id"); _supportedInterfaces[interfaceId] = true; } }
// SPDX-License-Identifier: MIT // File: @openzeppelin/contracts/token/ERC721/ERC721.sol pragma solidity >=0.6.0 <0.8.0; import "./Context.sol"; import "./ERC165.sol"; import "./IERC721.sol"; import "./IERC721Metadata.sol"; import "./IERC721Enumerable.sol"; import "./IERC721Receiver.sol"; import "./SafeMath.sol"; import "./Address.sol"; import "./EnumerableSet.sol"; import "./EnumerableMap.sol"; import "./Strings.sol"; /** * @title ERC721 Non-Fungible Token Standard basic implementation * @dev see https://eips.ethereum.org/EIPS/eip-721 */ contract ERC721 is Context, ERC165, IERC721, IERC721Metadata, IERC721Enumerable { using SafeMath for uint256; using Address for address; using EnumerableSet for EnumerableSet.UintSet; using EnumerableMap for EnumerableMap.UintToAddressMap; using Strings for uint256; // Equals to `bytes4(keccak256("onERC721Received(address,address,uint256,bytes)"))` // which can be also obtained as `IERC721Receiver(0).onERC721Received.selector` bytes4 private constant _ERC721_RECEIVED = 0x150b7a02; // Mapping from holder address to their (enumerable) set of owned tokens mapping (address => EnumerableSet.UintSet) private _holderTokens; // Enumerable mapping from token ids to their owners EnumerableMap.UintToAddressMap private _tokenOwners; // Mapping from token ID to approved address mapping (uint256 => address) private _tokenApprovals; // Mapping from owner to operator approvals mapping (address => mapping (address => bool)) private _operatorApprovals; // Token name string private _name; // Token symbol string private _symbol; // Optional mapping for token URIs mapping (uint256 => string) private _tokenURIs; // Base URI string private _baseURI; /* * bytes4(keccak256('balanceOf(address)')) == 0x70a08231 * bytes4(keccak256('ownerOf(uint256)')) == 0x6352211e * bytes4(keccak256('approve(address,uint256)')) == 0x095ea7b3 * bytes4(keccak256('getApproved(uint256)')) == 0x081812fc * bytes4(keccak256('setApprovalForAll(address,bool)')) == 0xa22cb465 * bytes4(keccak256('isApprovedForAll(address,address)')) == 0xe985e9c5 * bytes4(keccak256('transferFrom(address,address,uint256)')) == 0x23b872dd * bytes4(keccak256('safeTransferFrom(address,address,uint256)')) == 0x42842e0e * bytes4(keccak256('safeTransferFrom(address,address,uint256,bytes)')) == 0xb88d4fde * * => 0x70a08231 ^ 0x6352211e ^ 0x095ea7b3 ^ 0x081812fc ^ * 0xa22cb465 ^ 0xe985e9c5 ^ 0x23b872dd ^ 0x42842e0e ^ 0xb88d4fde == 0x80ac58cd */ bytes4 private constant _INTERFACE_ID_ERC721 = 0x80ac58cd; /* * bytes4(keccak256('name()')) == 0x06fdde03 * bytes4(keccak256('symbol()')) == 0x95d89b41 * bytes4(keccak256('tokenURI(uint256)')) == 0xc87b56dd * * => 0x06fdde03 ^ 0x95d89b41 ^ 0xc87b56dd == 0x5b5e139f */ bytes4 private constant _INTERFACE_ID_ERC721_METADATA = 0x5b5e139f; /* * bytes4(keccak256('totalSupply()')) == 0x18160ddd * bytes4(keccak256('tokenOfOwnerByIndex(address,uint256)')) == 0x2f745c59 * bytes4(keccak256('tokenByIndex(uint256)')) == 0x4f6ccce7 * * => 0x18160ddd ^ 0x2f745c59 ^ 0x4f6ccce7 == 0x780e9d63 */ bytes4 private constant _INTERFACE_ID_ERC721_ENUMERABLE = 0x780e9d63; /** * @dev Initializes the contract by setting a `name` and a `symbol` to the token collection. */ constructor (string memory name_, string memory symbol_) public { _name = name_; _symbol = symbol_; // register the supported interfaces to conform to ERC721 via ERC165 _registerInterface(_INTERFACE_ID_ERC721); _registerInterface(_INTERFACE_ID_ERC721_METADATA); _registerInterface(_INTERFACE_ID_ERC721_ENUMERABLE); } /** * @dev See {IERC721-balanceOf}. */ function balanceOf(address owner) public view virtual override returns (uint256) { require(owner != address(0), "ERC721: balance query for the zero address"); return _holderTokens[owner].length(); } /** * @dev See {IERC721-ownerOf}. */ function ownerOf(uint256 tokenId) public view virtual override returns (address) { return _tokenOwners.get(tokenId, "ERC721: owner query for nonexistent token"); } /** * @dev See {IERC721Metadata-name}. */ function name() public view virtual override returns (string memory) { return _name; } /** * @dev See {IERC721Metadata-symbol}. */ function symbol() public view virtual override returns (string memory) { return _symbol; } /** * @dev See {IERC721Metadata-tokenURI}. */ function tokenURI(uint256 tokenId) public view virtual override returns (string memory) { require(_exists(tokenId), "ERC721Metadata: URI query for nonexistent token"); string memory _tokenURI = _tokenURIs[tokenId]; string memory base = baseURI(); // If there is no base URI, return the token URI. if (bytes(base).length == 0) { return _tokenURI; } // If both are set, concatenate the baseURI and tokenURI (via abi.encodePacked). if (bytes(_tokenURI).length > 0) { return string(abi.encodePacked(base, _tokenURI)); } // If there is a baseURI but no tokenURI, concatenate the tokenID to the baseURI. return string(abi.encodePacked(base, tokenId.toString())); } /** * @dev Returns the base URI set via {_setBaseURI}. This will be * automatically added as a prefix in {tokenURI} to each token's URI, or * to the token ID if no specific URI is set for that token ID. */ function baseURI() public view virtual returns (string memory) { return _baseURI; } /** * @dev See {IERC721Enumerable-tokenOfOwnerByIndex}. */ function tokenOfOwnerByIndex(address owner, uint256 index) public view virtual override returns (uint256) { return _holderTokens[owner].at(index); } /** * @dev See {IERC721Enumerable-totalSupply}. */ function totalSupply() public view virtual override returns (uint256) { // _tokenOwners are indexed by tokenIds, so .length() returns the number of tokenIds return _tokenOwners.length(); } /** * @dev See {IERC721Enumerable-tokenByIndex}. */ function tokenByIndex(uint256 index) public view virtual override returns (uint256) { (uint256 tokenId, ) = _tokenOwners.at(index); return tokenId; } /** * @dev See {IERC721-approve}. */ function approve(address to, uint256 tokenId) public virtual override { address owner = ERC721.ownerOf(tokenId); require(to != owner, "ERC721: approval to current owner"); require(_msgSender() == owner || ERC721.isApprovedForAll(owner, _msgSender()), "ERC721: approve caller is not owner nor approved for all" ); _approve(to, tokenId); } /** * @dev See {IERC721-getApproved}. */ function getApproved(uint256 tokenId) public view virtual override returns (address) { require(_exists(tokenId), "ERC721: approved query for nonexistent token"); return _tokenApprovals[tokenId]; } /** * @dev See {IERC721-setApprovalForAll}. */ function setApprovalForAll(address operator, bool approved) public virtual override { require(operator != _msgSender(), "ERC721: approve to caller"); _operatorApprovals[_msgSender()][operator] = approved; emit ApprovalForAll(_msgSender(), operator, approved); } /** * @dev See {IERC721-isApprovedForAll}. */ function isApprovedForAll(address owner, address operator) public view virtual override returns (bool) { return _operatorApprovals[owner][operator]; } /** * @dev See {IERC721-transferFrom}. */ function transferFrom(address from, address to, uint256 tokenId) public virtual override { //solhint-disable-next-line max-line-length require(_isApprovedOrOwner(_msgSender(), tokenId), "ERC721: transfer caller is not owner nor approved"); _transfer(from, to, tokenId); } /** * @dev See {IERC721-safeTransferFrom}. */ function safeTransferFrom(address from, address to, uint256 tokenId) public virtual override { safeTransferFrom(from, to, tokenId, ""); } /** * @dev See {IERC721-safeTransferFrom}. */ function safeTransferFrom(address from, address to, uint256 tokenId, bytes memory _data) public virtual override { require(_isApprovedOrOwner(_msgSender(), tokenId), "ERC721: transfer caller is not owner nor approved"); _safeTransfer(from, to, tokenId, _data); } /** * @dev Safely transfers `tokenId` token from `from` to `to`, checking first that contract recipients * are aware of the ERC721 protocol to prevent tokens from being forever locked. * * `_data` is additional data, it has no specified format and it is sent in call to `to`. * * This internal function is equivalent to {safeTransferFrom}, and can be used to e.g. * implement alternative mechanisms to perform token transfer, such as signature-based. * * Requirements: * * - `from` cannot be the zero address. * - `to` cannot be the zero address. * - `tokenId` token must exist and be owned by `from`. * - If `to` refers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called upon a safe transfer. * * Emits a {Transfer} event. */ function _safeTransfer(address from, address to, uint256 tokenId, bytes memory _data) internal virtual { _transfer(from, to, tokenId); require(_checkOnERC721Received(from, to, tokenId, _data), "ERC721: transfer to non ERC721Receiver implementer"); } /** * @dev Returns whether `tokenId` exists. * * Tokens can be managed by their owner or approved accounts via {approve} or {setApprovalForAll}. * * Tokens start existing when they are minted (`_mint`), * and stop existing when they are burned (`_burn`). */ function _exists(uint256 tokenId) internal view virtual returns (bool) { return _tokenOwners.contains(tokenId); } /** * @dev Returns whether `spender` is allowed to manage `tokenId`. * * Requirements: * * - `tokenId` must exist. */ function _isApprovedOrOwner(address spender, uint256 tokenId) internal view virtual returns (bool) { require(_exists(tokenId), "ERC721: operator query for nonexistent token"); address owner = ERC721.ownerOf(tokenId); return (spender == owner || getApproved(tokenId) == spender || ERC721.isApprovedForAll(owner, spender)); } /** * @dev Safely mints `tokenId` and transfers it to `to`. * * Requirements: d* * - `tokenId` must not exist. * - If `to` refers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called upon a safe transfer. * * Emits a {Transfer} event. */ function _safeMint(address to, uint256 tokenId) internal virtual { _safeMint(to, tokenId, ""); } /** * @dev Same as {xref-ERC721-_safeMint-address-uint256-}[`_safeMint`], with an additional `data` parameter which is * forwarded in {IERC721Receiver-onERC721Received} to contract recipients. */ function _safeMint(address to, uint256 tokenId, bytes memory _data) internal virtual { _mint(to, tokenId); require(_checkOnERC721Received(address(0), to, tokenId, _data), "ERC721: transfer to non ERC721Receiver implementer"); } /** * @dev Mints `tokenId` and transfers it to `to`. * * WARNING: Usage of this method is discouraged, use {_safeMint} whenever possible * * Requirements: * * - `tokenId` must not exist. * - `to` cannot be the zero address. * * Emits a {Transfer} event. */ function _mint(address to, uint256 tokenId) internal virtual { require(to != address(0), "ERC721: mint to the zero address"); require(!_exists(tokenId), "ERC721: token already minted"); _beforeTokenTransfer(address(0), to, tokenId); _holderTokens[to].add(tokenId); _tokenOwners.set(tokenId, to); emit Transfer(address(0), to, tokenId); } /** * @dev Destroys `tokenId`. * The approval is cleared when the token is burned. * * Requirements: * * - `tokenId` must exist. * * Emits a {Transfer} event. */ function _burn(uint256 tokenId) internal virtual { address owner = ERC721.ownerOf(tokenId); // internal owner _beforeTokenTransfer(owner, address(0), tokenId); // Clear approvals _approve(address(0), tokenId); // Clear metadata (if any) if (bytes(_tokenURIs[tokenId]).length != 0) { delete _tokenURIs[tokenId]; } _holderTokens[owner].remove(tokenId); _tokenOwners.remove(tokenId); emit Transfer(owner, address(0), tokenId); } /** * @dev Transfers `tokenId` from `from` to `to`. * As opposed to {transferFrom}, this imposes no restrictions on msg.sender. * * Requirements: * * - `to` cannot be the zero address. * - `tokenId` token must be owned by `from`. * * Emits a {Transfer} event. */ function _transfer(address from, address to, uint256 tokenId) internal virtual { require(ERC721.ownerOf(tokenId) == from, "ERC721: transfer of token that is not own"); // internal owner require(to != address(0), "ERC721: transfer to the zero address"); _beforeTokenTransfer(from, to, tokenId); // Clear approvals from the previous owner _approve(address(0), tokenId); _holderTokens[from].remove(tokenId); _holderTokens[to].add(tokenId); _tokenOwners.set(tokenId, to); emit Transfer(from, to, tokenId); } /** * @dev Sets `_tokenURI` as the tokenURI of `tokenId`. * * Requirements: * * - `tokenId` must exist. */ function _setTokenURI(uint256 tokenId, string memory _tokenURI) internal virtual { require(_exists(tokenId), "ERC721Metadata: URI set of nonexistent token"); _tokenURIs[tokenId] = _tokenURI; } /** * @dev Internal function to set the base URI for all token IDs. It is * automatically added as a prefix to the value returned in {tokenURI}, * or to the token ID if {tokenURI} is empty. */ function _setBaseURI(string memory baseURI_) internal virtual { _baseURI = baseURI_; } /** * @dev Internal function to invoke {IERC721Receiver-onERC721Received} on a target address. * The call is not executed if the target address is not a contract. * * @param from address representing the previous owner of the given token ID * @param to target address that will receive the tokens * @param tokenId uint256 ID of the token to be transferred * @param _data bytes optional data to send along with the call * @return bool whether the call correctly returned the expected magic value */ function _checkOnERC721Received(address from, address to, uint256 tokenId, bytes memory _data) private returns (bool) { if (!to.isContract()) { return true; } bytes memory returndata = to.functionCall(abi.encodeWithSelector( IERC721Receiver(to).onERC721Received.selector, _msgSender(), from, tokenId, _data ), "ERC721: transfer to non ERC721Receiver implementer"); bytes4 retval = abi.decode(returndata, (bytes4)); return (retval == _ERC721_RECEIVED); } /** * @dev Approve `to` to operate on `tokenId` * * Emits an {Approval} event. */ function _approve(address to, uint256 tokenId) internal virtual { _tokenApprovals[tokenId] = to; emit Approval(ERC721.ownerOf(tokenId), to, tokenId); // internal owner } /** * @dev Hook that is called before any token transfer. This includes minting * and burning. * * Calling conditions: * * - When `from` and `to` are both non-zero, ``from``'s `tokenId` will be * transferred to `to`. * - When `from` is zero, `tokenId` will be minted for `to`. * - When `to` is zero, ``from``'s `tokenId` will be burned. * - `from` cannot be the zero address. * - `to` cannot be the zero address. * * To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks]. */ function _beforeTokenTransfer(address from, address to, uint256 tokenId) internal virtual { } }
// SPDX-License-Identifier: MIT // File: @openzeppelin/contracts/introspection/IERC165.sol pragma solidity >=0.6.0 <0.8.0; /** * @dev Interface of the ERC165 standard, as defined in the * https://eips.ethereum.org/EIPS/eip-165[EIP]. * * Implementers can declare support of contract interfaces, which can then be * queried by others ({ERC165Checker}). * * For an implementation, see {ERC165}. */ interface IERC165 { /** * @dev Returns true if this contract implements the interface defined by * `interfaceId`. See the corresponding * https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section] * to learn more about how these ids are created. * * This function call must use less than 30 000 gas. */ function supportsInterface(bytes4 interfaceId) external view returns (bool); }
// SPDX-License-Identifier: MIT // File: @openzeppelin/contracts/token/ERC721/IERC721.sol pragma solidity >=0.6.2 <0.8.0; import "./IERC165.sol"; /** * @dev Required interface of an ERC721 compliant contract. */ interface IERC721 is IERC165 { /** * @dev Emitted when `tokenId` token is transferred from `from` to `to`. */ event Transfer(address indexed from, address indexed to, uint256 indexed tokenId); /** * @dev Emitted when `owner` enables `approved` to manage the `tokenId` token. */ event Approval(address indexed owner, address indexed approved, uint256 indexed tokenId); /** * @dev Emitted when `owner` enables or disables (`approved`) `operator` to manage all of its assets. */ event ApprovalForAll(address indexed owner, address indexed operator, bool approved); /** * @dev Returns the number of tokens in ``owner``'s account. */ function balanceOf(address owner) external view returns (uint256 balance); /** * @dev Returns the owner of the `tokenId` token. * * Requirements: * * - `tokenId` must exist. */ function ownerOf(uint256 tokenId) external view returns (address owner); /** * @dev Safely transfers `tokenId` token from `from` to `to`, checking first that contract recipients * are aware of the ERC721 protocol to prevent tokens from being forever locked. * * Requirements: * * - `from` cannot be the zero address. * - `to` cannot be the zero address. * - `tokenId` token must exist and be owned by `from`. * - If the caller is not `from`, it must be have been allowed to move this token by either {approve} or {setApprovalForAll}. * - If `to` refers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called upon a safe transfer. * * Emits a {Transfer} event. */ function safeTransferFrom(address from, address to, uint256 tokenId) external; /** * @dev Transfers `tokenId` token from `from` to `to`. * * WARNING: Usage of this method is discouraged, use {safeTransferFrom} whenever possible. * * Requirements: * * - `from` cannot be the zero address. * - `to` cannot be the zero address. * - `tokenId` token must be owned by `from`. * - If the caller is not `from`, it must be approved to move this token by either {approve} or {setApprovalForAll}. * * Emits a {Transfer} event. */ function transferFrom(address from, address to, uint256 tokenId) external; /** * @dev Gives permission to `to` to transfer `tokenId` token to another account. * The approval is cleared when the token is transferred. * * Only a single account can be approved at a time, so approving the zero address clears previous approvals. * * Requirements: * * - The caller must own the token or be an approved operator. * - `tokenId` must exist. * * Emits an {Approval} event. */ function approve(address to, uint256 tokenId) external; /** * @dev Returns the account approved for `tokenId` token. * * Requirements: * * - `tokenId` must exist. */ function getApproved(uint256 tokenId) external view returns (address operator); /** * @dev Approve or remove `operator` as an operator for the caller. * Operators can call {transferFrom} or {safeTransferFrom} for any token owned by the caller. * * Requirements: * * - The `operator` cannot be the caller. * * Emits an {ApprovalForAll} event. */ function setApprovalForAll(address operator, bool _approved) external; /** * @dev Returns if the `operator` is allowed to manage all of the assets of `owner`. * * See {setApprovalForAll} */ function isApprovedForAll(address owner, address operator) external view returns (bool); /** * @dev Safely transfers `tokenId` token from `from` to `to`. * * Requirements: * * - `from` cannot be the zero address. * - `to` cannot be the zero address. * - `tokenId` token must exist and be owned by `from`. * - If the caller is not `from`, it must be approved to move this token by either {approve} or {setApprovalForAll}. * - If `to` refers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called upon a safe transfer. * * Emits a {Transfer} event. */ function safeTransferFrom(address from, address to, uint256 tokenId, bytes calldata data) external; }
// SPDX-License-Identifier: MIT // File: @openzeppelin/contracts/token/ERC721/IERC721Enumerable.sol pragma solidity >=0.6.2 <0.8.0; import "./IERC721.sol"; /** * @title ERC-721 Non-Fungible Token Standard, optional enumeration extension * @dev See https://eips.ethereum.org/EIPS/eip-721 */ interface IERC721Enumerable is IERC721 { /** * @dev Returns the total amount of tokens stored by the contract. */ function totalSupply() external view returns (uint256); /** * @dev Returns a token ID owned by `owner` at a given `index` of its token list. * Use along with {balanceOf} to enumerate all of ``owner``'s tokens. */ function tokenOfOwnerByIndex(address owner, uint256 index) external view returns (uint256 tokenId); /** * @dev Returns a token ID at a given `index` of all the tokens stored by the contract. * Use along with {totalSupply} to enumerate all tokens. */ function tokenByIndex(uint256 index) external view returns (uint256); }
// SPDX-License-Identifier: MIT // File: @openzeppelin/contracts/token/ERC721/IERC721Metadata.sol pragma solidity >=0.6.2 <0.8.0; import "./IERC721.sol"; /** * @title ERC-721 Non-Fungible Token Standard, optional metadata extension * @dev See https://eips.ethereum.org/EIPS/eip-721 */ interface IERC721Metadata is IERC721 { /** * @dev Returns the token collection name. */ function name() external view returns (string memory); /** * @dev Returns the token collection symbol. */ function symbol() external view returns (string memory); /** * @dev Returns the Uniform Resource Identifier (URI) for `tokenId` token. */ function tokenURI(uint256 tokenId) external view returns (string memory); }
// SPDX-License-Identifier: MIT // File: @openzeppelin/contracts/token/ERC721/IERC721Receiver.sol pragma solidity >=0.6.0 <0.8.0; /** * @title ERC721 token receiver interface * @dev Interface for any contract that wants to support safeTransfers * from ERC721 asset contracts. */ interface IERC721Receiver { /** * @dev Whenever an {IERC721} `tokenId` token is transferred to this contract via {IERC721-safeTransferFrom} * by `operator` from `from`, this function is called. * * It must return its Solidity selector to confirm the token transfer. * If any other value is returned or the interface is not implemented by the recipient, the transfer will be reverted. * * The selector can be obtained in Solidity with `IERC721.onERC721Received.selector`. */ function onERC721Received(address operator, address from, uint256 tokenId, bytes calldata data) external returns (bytes4); }
// SPDX-License-Identifier: MIT pragma solidity >=0.6.0 <0.9.0; contract Migrations { address public owner = msg.sender; uint public last_completed_migration; modifier restricted() { require( msg.sender == owner, "This function is restricted to the contract's owner" ); _; } function setCompleted(uint completed) public restricted { last_completed_migration = completed; } }
// SPDX-License-Identifier: MIT // File: @openzeppelin/contracts/access/Ownable.sol pragma solidity >=0.6.0 <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 () internal { address msgSender = _msgSender(); _owner = msgSender; emit OwnershipTransferred(address(0), msgSender); } /** * @dev Returns the address of the current owner. */ function owner() public view virtual returns (address) { return _owner; } /** * @dev Throws if called by any account other than the owner. */ modifier onlyOwner() { require(owner() == _msgSender(), "Ownable: caller is not the owner"); _; } /** * @dev Leaves the contract without owner. It will not be possible to call * `onlyOwner` functions anymore. Can only be called by the current owner. * * NOTE: Renouncing ownership will leave the contract without an owner, * thereby removing any functionality that is only available to the owner. */ function renounceOwnership() public virtual onlyOwner { emit OwnershipTransferred(_owner, address(0)); _owner = 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"); emit OwnershipTransferred(_owner, newOwner); _owner = newOwner; } }
// SPDX-License-Identifier: MIT pragma solidity ^0.7.0; import "./Address.sol"; import "./Context.sol"; /** * @title PaymentSplitter * @dev This contract allows to split Ether payments among a group of accounts. The sender does not need to be aware * that the Ether will be split in this way, since it is handled transparently by the contract. * * The split can be in equal parts or in any other arbitrary proportion. The way this is specified is by assigning each * account to a number of shares. Of all the Ether that this contract receives, each account will then be able to claim * an amount proportional to the percentage of total shares they were assigned. * * `PaymentSplitter` follows a _pull payment_ model. This means that payments are not automatically forwarded to the * accounts but kept in this contract, and the actual transfer is triggered as a separate step by calling the {release} * function. */ contract PaymentSplitter is Context { event PayeeAdded(address account, uint256 shares); event PaymentReleased(address to, uint256 amount); event PaymentReceived(address from, uint256 amount); uint256 private _totalShares; uint256 private _totalReleased; mapping(address => uint256) private _shares; mapping(address => uint256) private _released; address[] private _payees; /** * @dev Creates an instance of `PaymentSplitter` where each account in `payees` is assigned the number of shares at * the matching position in the `shares` array. * * All addresses in `payees` must be non-zero. Both arrays must have the same non-zero length, and there must be no * duplicates in `payees`. */ constructor(address[] memory payees, uint256[] memory shares_) payable { require(payees.length == shares_.length, "PaymentSplitter: payees and shares length mismatch"); require(payees.length > 0, "PaymentSplitter: no payees"); for (uint256 i = 0; i < payees.length; i++) { _addPayee(payees[i], shares_[i]); } } /** * @dev The Ether received will be logged with {PaymentReceived} events. Note that these events are not fully * reliable: it's possible for a contract to receive Ether without triggering this function. This only affects the * reliability of the events, and not the actual splitting of Ether. * * To learn more about this see the Solidity documentation for * https://solidity.readthedocs.io/en/latest/contracts.html#fallback-function[fallback * functions]. */ receive() external payable virtual { emit PaymentReceived(_msgSender(), msg.value); } /** * @dev Getter for the total shares held by payees. */ function totalShares() public view returns (uint256) { return _totalShares; } /** * @dev Getter for the total amount of Ether already released. */ function totalReleased() public view returns (uint256) { return _totalReleased; } /** * @dev Getter for the amount of shares held by an account. */ function shares(address account) public view returns (uint256) { return _shares[account]; } /** * @dev Getter for the amount of Ether already released to a payee. */ function released(address account) public view returns (uint256) { return _released[account]; } /** * @dev Getter for the address of the payee number `index`. */ function payee(uint256 index) public view returns (address) { return _payees[index]; } /** * @dev Triggers a transfer to `account` of the amount of Ether they are owed, according to their percentage of the * total shares and their previous withdrawals. */ function release(address payable account) public virtual { require(_shares[account] > 0, "PaymentSplitter: account has no shares"); uint256 totalReceived = address(this).balance + _totalReleased; uint256 payment = (totalReceived * _shares[account]) / _totalShares - _released[account]; require(payment != 0, "PaymentSplitter: account is not due payment"); _released[account] = _released[account] + payment; _totalReleased = _totalReleased + payment; Address.sendValue(account, payment); emit PaymentReleased(account, payment); } /** * @dev Add a new payee to the contract. * @param account The address of the payee to add. * @param shares_ The number of shares owned by the payee. */ function _addPayee(address account, uint256 shares_) private { require(account != address(0), "PaymentSplitter: account is the zero address"); require(shares_ > 0, "PaymentSplitter: shares are 0"); require(_shares[account] == 0, "PaymentSplitter: account already has shares"); _payees.push(account); _shares[account] = shares_; _totalShares = _totalShares + shares_; emit PayeeAdded(account, shares_); } }
// SPDX-License-Identifier: MIT // File: @openzeppelin/contracts/math/SafeMath.sol pragma solidity >=0.6.0 <0.8.0; /** * @dev Wrappers over Solidity's arithmetic operations with added overflow * checks. * * Arithmetic operations in Solidity wrap on overflow. This can easily result * in bugs, because programmers usually assume that an overflow raises an * error, which is the standard behavior in high level programming languages. * `SafeMath` restores this intuition by reverting the transaction when an * operation overflows. * * Using this library instead of the unchecked operations eliminates an entire * class of bugs, so it's recommended to use it always. */ library SafeMath { /** * @dev Returns the addition of two unsigned integers, with an overflow flag. * * _Available since v3.4._ */ function tryAdd(uint256 a, uint256 b) internal pure returns (bool, uint256) { uint256 c = a + b; if (c < a) return (false, 0); return (true, c); } /** * @dev Returns the substraction of two unsigned integers, with an overflow flag. * * _Available since v3.4._ */ function trySub(uint256 a, uint256 b) internal pure returns (bool, uint256) { if (b > a) return (false, 0); return (true, a - b); } /** * @dev Returns the multiplication of two unsigned integers, with an overflow flag. * * _Available since v3.4._ */ function tryMul(uint256 a, uint256 b) internal pure returns (bool, uint256) { // Gas optimization: this is cheaper than requiring 'a' not being zero, but the // benefit is lost if 'b' is also tested. // See: https://github.com/OpenZeppelin/openzeppelin-contracts/pull/522 if (a == 0) return (true, 0); uint256 c = a * b; if (c / a != b) return (false, 0); return (true, c); } /** * @dev Returns the division of two unsigned integers, with a division by zero flag. * * _Available since v3.4._ */ function tryDiv(uint256 a, uint256 b) internal pure returns (bool, uint256) { if (b == 0) return (false, 0); return (true, a / b); } /** * @dev Returns the remainder of dividing two unsigned integers, with a division by zero flag. * * _Available since v3.4._ */ function tryMod(uint256 a, uint256 b) internal pure returns (bool, uint256) { if (b == 0) return (false, 0); return (true, a % b); } /** * @dev Returns the addition of two unsigned integers, reverting on * overflow. * * Counterpart to Solidity's `+` operator. * * Requirements: * * - Addition cannot overflow. */ function add(uint256 a, uint256 b) internal pure returns (uint256) { uint256 c = a + b; require(c >= a, "SafeMath: addition overflow"); return c; } /** * @dev Returns the subtraction of two unsigned integers, reverting on * overflow (when the result is negative). * * Counterpart to Solidity's `-` operator. * * Requirements: * * - Subtraction cannot overflow. */ function sub(uint256 a, uint256 b) internal pure returns (uint256) { require(b <= a, "SafeMath: subtraction overflow"); return a - b; } /** * @dev Returns the multiplication of two unsigned integers, reverting on * overflow. * * Counterpart to Solidity's `*` operator. * * Requirements: * * - Multiplication cannot overflow. */ function mul(uint256 a, uint256 b) internal pure returns (uint256) { if (a == 0) return 0; uint256 c = a * b; require(c / a == b, "SafeMath: multiplication overflow"); return c; } /** * @dev Returns the integer division of two unsigned integers, reverting on * division by zero. The result is rounded towards zero. * * Counterpart to Solidity's `/` operator. Note: this function uses a * `revert` opcode (which leaves remaining gas untouched) while Solidity * uses an invalid opcode to revert (consuming all remaining gas). * * Requirements: * * - The divisor cannot be zero. */ function div(uint256 a, uint256 b) internal pure returns (uint256) { require(b > 0, "SafeMath: division by zero"); return a / b; } /** * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo), * reverting when dividing by zero. * * Counterpart to Solidity's `%` operator. This function uses a `revert` * opcode (which leaves remaining gas untouched) while Solidity uses an * invalid opcode to revert (consuming all remaining gas). * * Requirements: * * - The divisor cannot be zero. */ function mod(uint256 a, uint256 b) internal pure returns (uint256) { require(b > 0, "SafeMath: modulo by zero"); return a % b; } /** * @dev Returns the subtraction of two unsigned integers, reverting with custom message on * overflow (when the result is negative). * * CAUTION: This function is deprecated because it requires allocating memory for the error * message unnecessarily. For custom revert reasons use {trySub}. * * Counterpart to Solidity's `-` operator. * * Requirements: * * - Subtraction cannot overflow. */ function sub(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) { require(b <= a, errorMessage); return a - b; } /** * @dev Returns the integer division of two unsigned integers, reverting with custom message on * division by zero. The result is rounded towards zero. * * CAUTION: This function is deprecated because it requires allocating memory for the error * message unnecessarily. For custom revert reasons use {tryDiv}. * * Counterpart to Solidity's `/` operator. Note: this function uses a * `revert` opcode (which leaves remaining gas untouched) while Solidity * uses an invalid opcode to revert (consuming all remaining gas). * * Requirements: * * - The divisor cannot be zero. */ function div(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) { require(b > 0, errorMessage); return a / b; } /** * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo), * reverting with custom message when dividing by zero. * * CAUTION: This function is deprecated because it requires allocating memory for the error * message unnecessarily. For custom revert reasons use {tryMod}. * * Counterpart to Solidity's `%` operator. This function uses a `revert` * opcode (which leaves remaining gas untouched) while Solidity uses an * invalid opcode to revert (consuming all remaining gas). * * Requirements: * * - The divisor cannot be zero. */ function mod(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) { require(b > 0, errorMessage); return a % b; } }
// SPDX-License-Identifier: MIT // File: @openzeppelin/contracts/utils/Strings.sol pragma solidity >=0.6.0 <0.8.0; /** * @dev String operations. */ library Strings { /** * @dev Converts a `uint256` to its ASCII `string` representation. */ function toString(uint256 value) internal pure returns (string memory) { // Inspired by OraclizeAPI's implementation - MIT licence // https://github.com/oraclize/ethereum-api/blob/b42146b063c7d6ee1358846c198246239e9360e8/oraclizeAPI_0.4.25.sol if (value == 0) { return "0"; } uint256 temp = value; uint256 digits; while (temp != 0) { digits++; temp /= 10; } bytes memory buffer = new bytes(digits); uint256 index = digits - 1; temp = value; while (temp != 0) { buffer[index--] = bytes1(uint8(48 + temp % 10)); temp /= 10; } return string(buffer); } }
pragma solidity ^0.7.0; import "./Ownable.sol"; contract Whitelist is Ownable { mapping(address => bool) whitelist; event AddedToWhitelist(address indexed account); event RemovedFromWhitelist(address indexed account); modifier onlyWhitelisted() { require(isWhitelisted(msg.sender)); _; } /// constructor called at deploy time constructor(address[] memory wl_addrs) { //wlcount = wl_addrs.length; for (uint i = 0; i < wl_addrs.length; i++) { // loop over wl_addrs and update set of whitelisted accounts address _address = wl_addrs[i]; whitelist[_address] = true; } } function add(address _address) public onlyOwner { whitelist[_address] = true; emit AddedToWhitelist(_address); } function remove(address _address) public onlyOwner { whitelist[_address] = false; emit RemovedFromWhitelist(_address); } function isWhitelisted(address _address) public view returns(bool) { return whitelist[_address]; } }
Contract Security Audit
- No Contract Security Audit Submitted- Submit Audit Here
[{"inputs":[{"internalType":"string","name":"name","type":"string"},{"internalType":"string","name":"symbol","type":"string"},{"internalType":"uint256","name":"maxNftSupply","type":"uint256"},{"internalType":"uint256","name":"saleStart","type":"uint256"},{"internalType":"address[]","name":"addrs","type":"address[]"},{"internalType":"uint256[]","name":"shares_","type":"uint256[]"},{"internalType":"address[]","name":"wl_addrs","type":"address[]"}],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"account","type":"address"}],"name":"AddedToWhitelist","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"approved","type":"address"},{"indexed":true,"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"operator","type":"address"},{"indexed":false,"internalType":"bool","name":"approved","type":"bool"}],"name":"ApprovalForAll","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"account","type":"address"},{"indexed":false,"internalType":"uint256","name":"shares","type":"uint256"}],"name":"PayeeAdded","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"from","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"PaymentReceived","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"PaymentReleased","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"account","type":"address"}],"name":"RemovedFromWhitelist","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":"GigaGardenPass","outputs":[{"internalType":"contract IERC721Enumerable","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"MAX_MUSHROOM_SUPPLY","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"MM_PROVENANCE","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"REVEAL_TIMESTAMP","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"accounts","outputs":[{"internalType":"uint256","name":"mintedNFTs","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_address","type":"address"}],"name":"add","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"approve","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"baseURI","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"emergencySetStartingIndexBlock","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"flipPreSaleState","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"flipSaleState","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"getApproved","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_address","type":"address"}],"name":"hasPass","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":"address","name":"_address","type":"address"}],"name":"isWhitelisted","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxMushroomPurchase","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"numberOfTokens","type":"uint256"}],"name":"mintMushroom","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[],"name":"mushroomMintPrice","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":[{"internalType":"uint256","name":"index","type":"uint256"}],"name":"payee","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"presaleIsActive","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address payable","name":"account","type":"address"}],"name":"release","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"released","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_address","type":"address"}],"name":"remove","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"reserveMushrooms","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"safeTransferFrom","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"},{"internalType":"bytes","name":"_data","type":"bytes"}],"name":"safeTransferFrom","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"saleIsActive","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"operator","type":"address"},{"internalType":"bool","name":"approved","type":"bool"}],"name":"setApprovalForAll","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"string","name":"baseURI","type":"string"}],"name":"setBaseURI","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"contractAddr","type":"address"}],"name":"setPassAddress","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"string","name":"provenanceHash","type":"string"}],"name":"setProvenanceHash","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"revealTimeStamp","type":"uint256"}],"name":"setRevealTimestamp","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"setStartingIndex","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"shares","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"startingIndex","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"startingIndexBlock","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bytes4","name":"interfaceId","type":"bytes4"}],"name":"supportsInterface","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"index","type":"uint256"}],"name":"tokenByIndex","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"uint256","name":"index","type":"uint256"}],"name":"tokenOfOwnerByIndex","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"tokenURI","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tokensMinted","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalReleased","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalShares","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"transferFrom","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"whitelistMintPrice","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"stateMutability":"payable","type":"receive"}]
Contract Creation Code
60a06040819052600060808190526200001b91601191620007f1565b506015805461ffff191690553480156200003457600080fd5b506040516200423838038062004238833981810160405260e08110156200005a57600080fd5b81019080805160405193929190846401000000008211156200007b57600080fd5b9083019060208201858111156200009157600080fd5b8251640100000000811182820188101715620000ac57600080fd5b82525081516020918201929091019080838360005b83811015620000db578181015183820152602001620000c1565b50505050905090810190601f168015620001095780820380516001836020036101000a031916815260200191505b50604052602001805160405193929190846401000000008211156200012d57600080fd5b9083019060208201858111156200014357600080fd5b82516401000000008111828201881017156200015e57600080fd5b82525081516020918201929091019080838360005b838110156200018d57818101518382015260200162000173565b50505050905090810190601f168015620001bb5780820380516001836020036101000a031916815260200191505b50604081815260208301519083015160609093018051919593949293929184640100000000821115620001ed57600080fd5b9083019060208201858111156200020357600080fd5b82518660208202830111640100000000821117156200022157600080fd5b82525081516020918201928201910280838360005b838110156200025057818101518382015260200162000236565b50505050905001604052602001805160405193929190846401000000008211156200027a57600080fd5b9083019060208201858111156200029057600080fd5b8251866020820283011164010000000082111715620002ae57600080fd5b82525081516020918201928201910280838360005b83811015620002dd578181015183820152602001620002c3565b50505050905001604052602001805160405193929190846401000000008211156200030757600080fd5b9083019060208201858111156200031d57600080fd5b82518660208202830111640100000000821117156200033b57600080fd5b82525081516020918201928201910280838360005b838110156200036a57818101518382015260200162000350565b505050509050016040525050508083838989620003946301ffc9a760e01b620005d460201b60201c565b8151620003a9906006906020850190620007f1565b508051620003bf906007906020840190620007f1565b50620003d26380ac58cd60e01b620005d4565b620003e4635b5e139f60e01b620005d4565b620003f663780e9d6360e01b620005d4565b50600090506200040562000659565b600a80546001600160a01b0319166001600160a01b038316908117909155604051919250906000907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a3508051825114620004955760405162461bcd60e51b8152600401808060200182810382526032815260200180620041db6032913960400191505060405180910390fd5b6000825111620004ec576040805162461bcd60e51b815260206004820152601a60248201527f5061796d656e7453706c69747465723a206e6f20706179656573000000000000604482015290519081900360640190fd5b60005b82518110156200053c57620005338382815181106200050a57fe5b60200260200101518383815181106200051f57fe5b60200260200101516200065d60201b60201c565b600101620004ef565b50505060005b8151811015620005985760008282815181106200055b57fe5b6020908102919091018101516001600160a01b03166000908152601090915260409020805460ff1916600190811790915591909101905062000542565b505050601493909355506016555050601980546001600160a01b03191673812701d9ba747c01f9b94655de6fd4f089d76cb5179055506200088d565b6001600160e01b0319808216141562000634576040805162461bcd60e51b815260206004820152601c60248201527f4552433136353a20696e76616c696420696e7465726661636520696400000000604482015290519081900360640190fd5b6001600160e01b0319166000908152602081905260409020805460ff19166001179055565b3390565b6001600160a01b038216620006a45760405162461bcd60e51b815260040180806020018281038252602c815260200180620041af602c913960400191505060405180910390fd5b60008111620006fa576040805162461bcd60e51b815260206004820152601d60248201527f5061796d656e7453706c69747465723a20736861726573206172652030000000604482015290519081900360640190fd5b6001600160a01b0382166000908152600d602052604090205415620007515760405162461bcd60e51b815260040180806020018281038252602b8152602001806200420d602b913960400191505060405180910390fd5b600f8054600181019091557f8d1108e10bcb7c27dddfc02ed9d693a074039d026cf4ea4240b40f7d581ac8020180546001600160a01b0319166001600160a01b0384169081179091556000818152600d6020908152604091829020849055600b8054850190558151928352820183905280517f40c340f65e17194d14ddddb073d3c9f888e3cb52b5aae0c6c7706b4fbc905fac9281900390910190a15050565b828054600181600116156101000203166002900490600052602060002090601f016020900481019282601f106200083457805160ff191683800117855562000864565b8280016001018555821562000864579182015b828111156200086457825182559160200191906001019062000847565b506200087292915062000876565b5090565b5b8082111562000872576000815560010162000877565b613912806200089d6000396000f3fe60806040526004361061034e5760003560e01c80636de9f32b116101bb578063b88d4fde116100f7578063e36d649811610095578063eb8d24441161006f578063eb8d244414610d34578063ef3f4a3c14610d49578063f032554914610d5e578063f2fde38b14610d735761039e565b8063e36d649814610ccf578063e985e9c514610ce4578063e986655014610d1f5761039e565b8063cb774d47116100d1578063cb774d4714610c5d578063ce7c2ac214610c72578063d9f80c3e14610ca5578063e33b7de314610cba5761039e565b8063b88d4fde14610b4b578063c6ff7eb914610c1e578063c87b56dd14610c335761039e565b80638da5cb5b116101645780639852595c1161013e5780639852595c14610aab578063a22cb46514610ade578063a625567114610b19578063a6eeaede14610b365761039e565b80638da5cb5b14610a4e578063937cde2014610a6357806395d89b4114610a965761039e565b80637d17fcbe116101955780637d17fcbe146109dc578063865f7724146109f15780638b83209b14610a245761039e565b80636de9f32b1461097f57806370a0823114610994578063715018a6146109c75761039e565b806329092d0e1161028a5780633af32abf1161023357806355f804b31161020d57806355f804b31461085a5780635e5c06e21461090d5780636352211e146109405780636c0360eb1461096a5761039e565b80633af32abf146107ba57806342842e0e146107ed5780634f6ccce7146108305761039e565b806334918dfd1161026457806334918dfd1461077b57806335c6aaf8146107905780633a98ef39146107a55761039e565b806329092d0e146106fa5780632f745c591461072d57806330f72cd4146107665761039e565b80630a3b0a4f116102f757806318e20a38116102d157806318e20a381461065a578063191655871461066f5780631c136e7c146106a257806323b872dd146106b75761039e565b80630a3b0a4f1461055f578063109695231461059257806318160ddd146106455761039e565b806306fdde031161032857806306fdde0314610456578063081812fc146104e0578063095ea7b3146105265761039e565b8063018a2c37146103a357806301ffc9a7146103cf57806305cefdea1461042f5761039e565b3661039e577f6ef95f06320e7a25a04a175ca677b7052bdd97131872c2192525a629f51be77061037c610da6565b604080516001600160a01b0390921682523460208301528051918290030190a1005b600080fd5b3480156103af57600080fd5b506103cd600480360360208110156103c657600080fd5b5035610daa565b005b3480156103db57600080fd5b5061041b600480360360208110156103f257600080fd5b50357fffffffff0000000000000000000000000000000000000000000000000000000016610e11565b604080519115158252519081900360200190f35b34801561043b57600080fd5b50610444610e4c565b60408051918252519081900360200190f35b34801561046257600080fd5b5061046b610e57565b6040805160208082528351818301528351919283929083019185019080838360005b838110156104a557818101518382015260200161048d565b50505050905090810190601f1680156104d25780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b3480156104ec57600080fd5b5061050a6004803603602081101561050357600080fd5b5035610eed565b604080516001600160a01b039092168252519081900360200190f35b34801561053257600080fd5b506103cd6004803603604081101561054957600080fd5b506001600160a01b038135169060200135610f4f565b34801561056b57600080fd5b506103cd6004803603602081101561058257600080fd5b50356001600160a01b031661102a565b34801561059e57600080fd5b506103cd600480360360208110156105b557600080fd5b8101906020810181356401000000008111156105d057600080fd5b8201836020820111156105e257600080fd5b8035906020019184600183028401116401000000008311171561060457600080fd5b91908080601f0160208091040260200160405190810160405280939291908181526020018383808284376000920191909152509295506110d8945050505050565b34801561065157600080fd5b50610444611151565b34801561066657600080fd5b50610444611162565b34801561067b57600080fd5b506103cd6004803603602081101561069257600080fd5b50356001600160a01b0316611168565b3480156106ae57600080fd5b5061050a6112b1565b3480156106c357600080fd5b506103cd600480360360608110156106da57600080fd5b506001600160a01b038135811691602081013590911690604001356112c0565b34801561070657600080fd5b506103cd6004803603602081101561071d57600080fd5b50356001600160a01b0316611317565b34801561073957600080fd5b506104446004803603604081101561075057600080fd5b506001600160a01b0381351690602001356113c2565b34801561077257600080fd5b5061041b6113ed565b34801561078757600080fd5b506103cd6113fb565b34801561079c57600080fd5b50610444611472565b3480156107b157600080fd5b5061044461147d565b3480156107c657600080fd5b5061041b600480360360208110156107dd57600080fd5b50356001600160a01b0316611483565b3480156107f957600080fd5b506103cd6004803603606081101561081057600080fd5b506001600160a01b038135811691602081013590911690604001356114a1565b34801561083c57600080fd5b506104446004803603602081101561085357600080fd5b50356114bc565b34801561086657600080fd5b506103cd6004803603602081101561087d57600080fd5b81019060208101813564010000000081111561089857600080fd5b8201836020820111156108aa57600080fd5b803590602001918460018302840111640100000000831117156108cc57600080fd5b91908080601f0160208091040260200160405190810160405280939291908181526020018383808284376000920191909152509295506114d2945050505050565b34801561091957600080fd5b506104446004803603602081101561093057600080fd5b50356001600160a01b0316611540565b34801561094c57600080fd5b5061050a6004803603602081101561096357600080fd5b5035611552565b34801561097657600080fd5b5061046b61157a565b34801561098b57600080fd5b506104446115db565b3480156109a057600080fd5b50610444600480360360208110156109b757600080fd5b50356001600160a01b03166115e7565b3480156109d357600080fd5b506103cd61164f565b3480156109e857600080fd5b506103cd611708565b3480156109fd57600080fd5b506103cd60048036036020811015610a1457600080fd5b50356001600160a01b03166117c5565b348015610a3057600080fd5b5061050a60048036036020811015610a4757600080fd5b5035611856565b348015610a5a57600080fd5b5061050a611880565b348015610a6f57600080fd5b5061041b60048036036020811015610a8657600080fd5b50356001600160a01b031661188f565b348015610aa257600080fd5b5061046b611939565b348015610ab757600080fd5b5061044460048036036020811015610ace57600080fd5b50356001600160a01b031661199a565b348015610aea57600080fd5b506103cd60048036036040811015610b0157600080fd5b506001600160a01b03813516906020013515156119b5565b6103cd60048036036020811015610b2f57600080fd5b5035611aba565b348015610b4257600080fd5b5061046b611e7f565b348015610b5757600080fd5b506103cd60048036036080811015610b6e57600080fd5b6001600160a01b03823581169260208101359091169160408201359190810190608081016060820135640100000000811115610ba957600080fd5b820183602082011115610bbb57600080fd5b80359060200191846001830284011164010000000083111715610bdd57600080fd5b91908080601f016020809104026020016040519081016040528093929190818152602001838380828437600092019190915250929550611f0d945050505050565b348015610c2a57600080fd5b50610444611f6b565b348015610c3f57600080fd5b5061046b60048036036020811015610c5657600080fd5b5035611f71565b348015610c6957600080fd5b506104446121f4565b348015610c7e57600080fd5b5061044460048036036020811015610c9557600080fd5b50356001600160a01b03166121fa565b348015610cb157600080fd5b506103cd612215565b348015610cc657600080fd5b506104446122a8565b348015610cdb57600080fd5b506104446122ae565b348015610cf057600080fd5b5061041b60048036036040811015610d0757600080fd5b506001600160a01b03813581169160200135166122b4565b348015610d2b57600080fd5b506103cd6122e2565b348015610d4057600080fd5b5061041b6123e4565b348015610d5557600080fd5b506104446123ed565b348015610d6a57600080fd5b506103cd6123f2565b348015610d7f57600080fd5b506103cd60048036036020811015610d9657600080fd5b50356001600160a01b0316612474565b3390565b610db2610da6565b6001600160a01b0316610dc3611880565b6001600160a01b031614610e0c576040805162461bcd60e51b815260206004820181905260248201526000805160206137d4833981519152604482015290519081900360640190fd5b601655565b7fffffffff00000000000000000000000000000000000000000000000000000000811660009081526020819052604090205460ff165b919050565b66b1a2bc2ec5000081565b60068054604080516020601f6002600019610100600188161502019095169490940493840181900481028201810190925282815260609390929091830182828015610ee35780601f10610eb857610100808354040283529160200191610ee3565b820191906000526020600020905b815481529060010190602001808311610ec657829003601f168201915b5050505050905090565b6000610ef882612584565b610f335760405162461bcd60e51b815260040180806020018281038252602c8152602001806137a8602c913960400191505060405180910390fd5b506000908152600460205260409020546001600160a01b031690565b6000610f5a82611552565b9050806001600160a01b0316836001600160a01b03161415610fad5760405162461bcd60e51b815260040180806020018281038252602181526020018061384c6021913960400191505060405180910390fd5b806001600160a01b0316610fbf610da6565b6001600160a01b03161480610fe05750610fe081610fdb610da6565b6122b4565b61101b5760405162461bcd60e51b81526004018080602001828103825260388152602001806136b16038913960400191505060405180910390fd5b6110258383612591565b505050565b611032610da6565b6001600160a01b0316611043611880565b6001600160a01b03161461108c576040805162461bcd60e51b815260206004820181905260248201526000805160206137d4833981519152604482015290519081900360640190fd5b6001600160a01b038116600081815260106020526040808220805460ff19166001179055517fa850ae9193f515cbae8d35e8925bd2be26627fc91bce650b8652ed254e9cab039190a250565b6110e0610da6565b6001600160a01b03166110f1611880565b6001600160a01b03161461113a576040805162461bcd60e51b815260206004820181905260248201526000805160206137d4833981519152604482015290519081900360640190fd5b805161114d90601190602084019061343c565b5050565b600061115d600261260c565b905090565b60165481565b6001600160a01b0381166000908152600d60205260409020546111bc5760405162461bcd60e51b81526004018080602001828103825260268152602001806135d66026913960400191505060405180910390fd5b600c546001600160a01b0382166000908152600e6020908152604080832054600b54600d9093529083205447909401939091908402816111f857fe5b04039050806112385760405162461bcd60e51b815260040180806020018281038252602b815260200180613686602b913960400191505060405180910390fd5b6001600160a01b0383166000908152600e60205260409020805482019055600c8054820190556112688382612617565b604080516001600160a01b03851681526020810183905281517fdf20fd1e76bc69d672e4814fafb2c449bba3a5369d8359adf9e05e6fde87b056929181900390910190a1505050565b6019546001600160a01b031681565b6112d16112cb610da6565b826126fc565b61130c5760405162461bcd60e51b81526004018080602001828103825260318152602001806138ac6031913960400191505060405180910390fd5b6110258383836127a0565b61131f610da6565b6001600160a01b0316611330611880565b6001600160a01b031614611379576040805162461bcd60e51b815260206004820181905260248201526000805160206137d4833981519152604482015290519081900360640190fd5b6001600160a01b038116600081815260106020526040808220805460ff19169055517fcdd2e9b91a56913d370075169cefa1602ba36be5301664f752192bb1709df7579190a250565b6001600160a01b03821660009081526001602052604081206113e490836128ec565b90505b92915050565b601554610100900460ff1681565b611403610da6565b6001600160a01b0316611414611880565b6001600160a01b03161461145d576040805162461bcd60e51b815260206004820181905260248201526000805160206137d4833981519152604482015290519081900360640190fd5b6015805461ffff19811660ff90911615179055565b668e1bc9bf04000081565b600b5490565b6001600160a01b031660009081526010602052604090205460ff1690565b61102583838360405180602001604052806000815250611f0d565b6000806114ca6002846128f8565b509392505050565b6114da610da6565b6001600160a01b03166114eb611880565b6001600160a01b031614611534576040805162461bcd60e51b815260206004820181905260248201526000805160206137d4833981519152604482015290519081900360640190fd5b61153d81612914565b50565b60186020526000908152604090205481565b60006113e7826040518060600160405280602981526020016137136029913960029190612927565b60098054604080516020601f6002600019610100600188161502019095169490940493840181900481028201810190925282815260609390929091830182828015610ee35780601f10610eb857610100808354040283529160200191610ee3565b600061115d601761293e565b60006001600160a01b03821661162e5760405162461bcd60e51b815260040180806020018281038252602a8152602001806136e9602a913960400191505060405180910390fd5b6001600160a01b03821660009081526001602052604090206113e79061260c565b611657610da6565b6001600160a01b0316611668611880565b6001600160a01b0316146116b1576040805162461bcd60e51b815260206004820181905260248201526000805160206137d4833981519152604482015290519081900360640190fd5b600a546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600a805473ffffffffffffffffffffffffffffffffffffffff19169055565b611710610da6565b6001600160a01b0316611721611880565b6001600160a01b03161461176a576040805162461bcd60e51b815260206004820181905260248201526000805160206137d4833981519152604482015290519081900360640190fd5b601354156117bf576040805162461bcd60e51b815260206004820152601d60248201527f5374617274696e6720696e64657820697320616c726561647920736574000000604482015290519081900360640190fd5b43601255565b6117cd610da6565b6001600160a01b03166117de611880565b6001600160a01b031614611827576040805162461bcd60e51b815260206004820181905260248201526000805160206137d4833981519152604482015290519081900360640190fd5b6019805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0392909216919091179055565b6000600f828154811061186557fe5b6000918252602090912001546001600160a01b031692915050565b600a546001600160a01b031690565b601954604080517f70a082310000000000000000000000000000000000000000000000000000000081526001600160a01b0384811660048301529151600093849316916370a08231916024808301926020929190829003018186803b1580156118f757600080fd5b505afa15801561190b573d6000803e3d6000fd5b505050506040513d602081101561192157600080fd5b5051111561193157506001610e47565b506000919050565b60078054604080516020601f6002600019610100600188161502019095169490940493840181900481028201810190925282815260609390929091830182828015610ee35780601f10610eb857610100808354040283529160200191610ee3565b6001600160a01b03166000908152600e602052604090205490565b6119bd610da6565b6001600160a01b0316826001600160a01b03161415611a23576040805162461bcd60e51b815260206004820152601960248201527f4552433732313a20617070726f766520746f2063616c6c657200000000000000604482015290519081900360640190fd5b8060056000611a30610da6565b6001600160a01b03908116825260208083019390935260409182016000908120918716808252919093529120805460ff191692151592909217909155611a74610da6565b6001600160a01b03167f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c318360405180821515815260200191505060405180910390a35050565b60155460ff1680611ad25750601554610100900460ff165b611b0d5760405162461bcd60e51b815260040180806020018281038252602b81526020018061357d602b913960400191505060405180910390fd5b601554610100900460ff168015611b27575060155460ff16155b15611bd357611b353361188f565b80611b445750611b4433611483565b611b7f5760405162461bcd60e51b815260040180806020018281038252603f81526020018061386d603f913960400191505060405180910390fd5b601454611b9682611b90601761293e565b90612942565b1115611bd35760405162461bcd60e51b81526004018080602001828103825260338152602001806134f26033913960400191505060405180910390fd5b6003811115611c135760405162461bcd60e51b815260040180806020018281038252602981526020018061373c6029913960400191505060405180910390fd5b33600090815260186020526040902054600390611c31908390612942565b1115611c6e5760405162461bcd60e51b815260040180806020018281038252602e8152602001806135a8602e913960400191505060405180910390fd5b601454611c7f82611b90601761293e565b1115611cbc5760405162461bcd60e51b81526004018080602001828103825260338152602001806134f26033913960400191505060405180910390fd5b611cc53361188f565b15611d345734611cdc668e1bc9bf0400008361299c565b1115611d2f576040805162461bcd60e51b815260206004820152601f60248201527f45746865722076616c75652073656e74206973206e6f7420636f727265637400604482015290519081900360640190fd5b611d99565b34611d4666b1a2bc2ec500008361299c565b1115611d99576040805162461bcd60e51b815260206004820152601f60248201527f45746865722076616c75652073656e74206973206e6f7420636f727265637400604482015290519081900360640190fd5b611da2336129f5565b15611df4576040805162461bcd60e51b815260206004820152601460248201527f436f6e7472616374732063616e2774206d696e74000000000000000000000000604482015290519081900360640190fd5b60005b81811015611e4c57601454611e0c601761293e565b11611e445733600090815260186020526040902080546001019055611e3160176129fb565b611e4433611e3f601761293e565b612a0c565b600101611df7565b50601254158015611e735750601454611e65601761293e565b1480611e7357506016544210155b1561153d574360125550565b6011805460408051602060026001851615610100026000190190941693909304601f81018490048402820184019092528181529291830182828015611f055780601f10611eda57610100808354040283529160200191611f05565b820191906000526020600020905b815481529060010190602001808311611ee857829003601f168201915b505050505081565b611f1e611f18610da6565b836126fc565b611f595760405162461bcd60e51b81526004018080602001828103825260318152602001806138ac6031913960400191505060405180910390fd5b611f6584848484612a26565b50505050565b60145481565b6060611f7c82612584565b611fb75760405162461bcd60e51b815260040180806020018281038252602f81526020018061381d602f913960400191505060405180910390fd5b60008281526008602090815260409182902080548351601f600260001961010060018616150201909316929092049182018490048402810184019094528084526060939283018282801561204c5780601f106120215761010080835404028352916020019161204c565b820191906000526020600020905b81548152906001019060200180831161202f57829003601f168201915b50505050509050606061205d61157a565b905080516000141561207157509050610e47565b8151156121325780826040516020018083805190602001908083835b602083106120ac5780518252601f19909201916020918201910161208d565b51815160209384036101000a600019018019909216911617905285519190930192850191508083835b602083106120f45780518252601f1990920191602091820191016120d5565b6001836020036101000a0380198251168184511680821785525050505050509050019250505060405160208183030381529060405292505050610e47565b8061213c85612a78565b6040516020018083805190602001908083835b6020831061216e5780518252601f19909201916020918201910161214f565b51815160209384036101000a600019018019909216911617905285519190930192850191508083835b602083106121b65780518252601f199092019160209182019101612197565b6001836020036101000a0380198251168184511680821785525050505050509050019250505060405160208183030381529060405292505050919050565b60135481565b6001600160a01b03166000908152600d602052604090205490565b61221d610da6565b6001600160a01b031661222e611880565b6001600160a01b031614612277576040805162461bcd60e51b815260206004820181905260248201526000805160206137d4833981519152604482015290519081900360640190fd5b6000612283601761293e565b600101905060005b600c81101561114d576122a033828401612a0c565b60010161228b565b600c5490565b60125481565b6001600160a01b03918216600090815260056020908152604080832093909416825291909152205460ff1690565b60135415612337576040805162461bcd60e51b815260206004820152601d60248201527f5374617274696e6720696e64657820697320616c726561647920736574000000604482015290519081900360640190fd5b60125461238b576040805162461bcd60e51b815260206004820181905260248201527f5374617274696e6720696e64657820626c6f636b206d75737420626520736574604482015290519081900360640190fd5b601454601254408161239957fe5b0660135560125460ff906123ae904390612b87565b11156123c957601454600019430140816123c457fe5b066013555b6013546123e2576013546123de906001612942565b6013555b565b60155460ff1681565b600381565b6123fa610da6565b6001600160a01b031661240b611880565b6001600160a01b031614612454576040805162461bcd60e51b815260206004820181905260248201526000805160206137d4833981519152604482015290519081900360640190fd5b6015805461010060ff19821681900460ff16150261ffff19909116179055565b61247c610da6565b6001600160a01b031661248d611880565b6001600160a01b0316146124d6576040805162461bcd60e51b815260206004820181905260248201526000805160206137d4833981519152604482015290519081900360640190fd5b6001600160a01b03811661251b5760405162461bcd60e51b81526004018080602001828103825260268152602001806135576026913960400191505060405180910390fd5b600a546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600a805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0392909216919091179055565b60006113e7600283612be4565b6000818152600460205260409020805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b03841690811790915581906125d382611552565b6001600160a01b03167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92560405160405180910390a45050565b60006113e78261293e565b8047101561266c576040805162461bcd60e51b815260206004820152601d60248201527f416464726573733a20696e73756666696369656e742062616c616e6365000000604482015290519081900360640190fd5b6040516000906001600160a01b0384169083908381818185875af1925050503d80600081146126b7576040519150601f19603f3d011682016040523d82523d6000602084013e6126bc565b606091505b50509050806110255760405162461bcd60e51b815260040180806020018281038252603a815260200180613620603a913960400191505060405180910390fd5b600061270782612584565b6127425760405162461bcd60e51b815260040180806020018281038252602c81526020018061365a602c913960400191505060405180910390fd5b600061274d83611552565b9050806001600160a01b0316846001600160a01b031614806127885750836001600160a01b031661277d84610eed565b6001600160a01b0316145b80612798575061279881856122b4565b949350505050565b826001600160a01b03166127b382611552565b6001600160a01b0316146127f85760405162461bcd60e51b81526004018080602001828103825260298152602001806137f46029913960400191505060405180910390fd5b6001600160a01b03821661283d5760405162461bcd60e51b81526004018080602001828103825260248152602001806135fc6024913960400191505060405180910390fd5b612848838383611025565b612853600082612591565b6001600160a01b03831660009081526001602052604090206128759082612bf0565b506001600160a01b03821660009081526001602052604090206128989082612bfc565b506128a560028284612c08565b5080826001600160a01b0316846001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60405160405180910390a4505050565b60006113e48383612c1e565b60008080806129078686612c82565b9097909650945050505050565b805161114d90600990602084019061343c565b6000612934848484612cfd565b90505b9392505050565b5490565b6000828201838110156113e4576040805162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015290519081900360640190fd5b6000826129ab575060006113e7565b828202828482816129b857fe5b04146113e45760405162461bcd60e51b81526004018080602001828103825260218152602001806137876021913960400191505060405180910390fd5b3b151590565b8054612a08906001612942565b9055565b61114d828260405180602001604052806000815250612dc7565b612a318484846127a0565b612a3d84848484612e19565b611f655760405162461bcd60e51b81526004018080602001828103825260328152602001806135256032913960400191505060405180910390fd5b606081612ab9575060408051808201909152600181527f30000000000000000000000000000000000000000000000000000000000000006020820152610e47565b8160005b8115612ad157600101600a82049150612abd565b60608167ffffffffffffffff81118015612aea57600080fd5b506040519080825280601f01601f191660200182016040528015612b15576020820181803683370190505b50859350905060001982015b8315612b7e57600a840660300160f81b82828060019003935081518110612b4457fe5b60200101907effffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916908160001a905350600a84049350612b21565b50949350505050565b600082821115612bde576040805162461bcd60e51b815260206004820152601e60248201527f536166654d6174683a207375627472616374696f6e206f766572666c6f770000604482015290519081900360640190fd5b50900390565b60006113e48383612fc3565b60006113e48383612fdb565b60006113e483836130a1565b600061293484846001600160a01b0385166130eb565b81546000908210612c605760405162461bcd60e51b81526004018080602001828103825260228152602001806134d06022913960400191505060405180910390fd5b826000018281548110612c6f57fe5b9060005260206000200154905092915050565b815460009081908310612cc65760405162461bcd60e51b81526004018080602001828103825260228152602001806137656022913960400191505060405180910390fd5b6000846000018481548110612cd757fe5b906000526020600020906002020190508060000154816001015492509250509250929050565b60008281526001840160205260408120548281612d985760405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b83811015612d5d578181015183820152602001612d45565b50505050905090810190601f168015612d8a5780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b50846000016001820381548110612dab57fe5b9060005260206000209060020201600101549150509392505050565b612dd18383613182565b612dde6000848484612e19565b6110255760405162461bcd60e51b81526004018080602001828103825260328152602001806135256032913960400191505060405180910390fd5b6000612e2d846001600160a01b03166129f5565b612e3957506001612798565b6060612f71630a85bd0160e11b612e4e610da6565b88878760405160240180856001600160a01b03168152602001846001600160a01b0316815260200183815260200180602001828103825283818151815260200191508051906020019080838360005b83811015612eb5578181015183820152602001612e9d565b50505050905090810190601f168015612ee25780820380516001836020036101000a031916815260200191505b5095505050505050604051602081830303815290604052907bffffffffffffffffffffffffffffffffffffffffffffffffffffffff19166020820180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff8381831617835250505050604051806060016040528060328152602001613525603291396001600160a01b03881691906132b0565b90506000818060200190516020811015612f8a57600080fd5b50517fffffffff0000000000000000000000000000000000000000000000000000000016630a85bd0160e11b1492505050949350505050565b60009081526001919091016020526040902054151590565b60008181526001830160205260408120548015613097578354600019808301919081019060009087908390811061300e57fe5b906000526020600020015490508087600001848154811061302b57fe5b60009182526020808320909101929092558281526001898101909252604090209084019055865487908061305b57fe5b600190038181906000526020600020016000905590558660010160008781526020019081526020016000206000905560019450505050506113e7565b60009150506113e7565b60006130ad8383612fc3565b6130e3575081546001818101845560008481526020808220909301849055845484825282860190935260409020919091556113e7565b5060006113e7565b600082815260018401602052604081205480613150575050604080518082018252838152602080820184815286546001818101895560008981528481209551600290930290950191825591519082015586548684528188019092529290912055612937565b8285600001600183038154811061316357fe5b9060005260206000209060020201600101819055506000915050612937565b6001600160a01b0382166131dd576040805162461bcd60e51b815260206004820181905260248201527f4552433732313a206d696e7420746f20746865207a65726f2061646472657373604482015290519081900360640190fd5b6131e681612584565b15613238576040805162461bcd60e51b815260206004820152601c60248201527f4552433732313a20746f6b656e20616c7265616479206d696e74656400000000604482015290519081900360640190fd5b61324460008383611025565b6001600160a01b03821660009081526001602052604090206132669082612bfc565b5061327360028284612c08565b5060405181906001600160a01b038416906000907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef908290a45050565b60606129348484600085856132c4856129f5565b613315576040805162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e7472616374000000604482015290519081900360640190fd5b60006060866001600160a01b031685876040518082805190602001908083835b602083106133545780518252601f199092019160209182019101613335565b6001836020036101000a03801982511681845116808217855250505050505090500191505060006040518083038185875af1925050503d80600081146133b6576040519150601f19603f3d011682016040523d82523d6000602084013e6133bb565b606091505b50915091506133cb8282866133d6565b979650505050505050565b606083156133e5575081612937565b8251156133f55782518084602001fd5b60405162461bcd60e51b8152602060048201818152845160248401528451859391928392604401919085019080838360008315612d5d578181015183820152602001612d45565b828054600181600116156101000203166002900490600052602060002090601f016020900481019282601f1061347d57805160ff19168380011785556134aa565b828001600101855582156134aa579182015b828111156134aa57825182559160200191906001019061348f565b506134b69291506134ba565b5090565b5b808211156134b657600081556001016134bb56fe456e756d657261626c655365743a20696e646578206f7574206f6620626f756e6473507572636861736520776f756c6420657863656564206d617820737570706c79206f66204d6f6f6479204d757368726f6f6d734552433732313a207472616e7366657220746f206e6f6e20455243373231526563656976657220696d706c656d656e7465724f776e61626c653a206e6577206f776e657220697320746865207a65726f206164647265737353616c65206d7573742062652061637469766520746f206d696e74204d6f6f6479204d757368726f6f6d73536f72727920707572636861736520776f756c64206578636565642033206d696e7473207065722077616c6c65745061796d656e7453706c69747465723a206163636f756e7420686173206e6f207368617265734552433732313a207472616e7366657220746f20746865207a65726f2061646472657373416464726573733a20756e61626c6520746f2073656e642076616c75652c20726563697069656e74206d617920686176652072657665727465644552433732313a206f70657261746f7220717565727920666f72206e6f6e6578697374656e7420746f6b656e5061796d656e7453706c69747465723a206163636f756e74206973206e6f7420647565207061796d656e744552433732313a20617070726f76652063616c6c6572206973206e6f74206f776e6572206e6f7220617070726f76656420666f7220616c6c4552433732313a2062616c616e636520717565727920666f7220746865207a65726f20616464726573734552433732313a206f776e657220717565727920666f72206e6f6e6578697374656e7420746f6b656e43616e206f6e6c79206d696e742033204d6f6f6479204d757368726f6f6d7320617420612074696d65456e756d657261626c654d61703a20696e646578206f7574206f6620626f756e6473536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f774552433732313a20617070726f76656420717565727920666f72206e6f6e6578697374656e7420746f6b656e4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65724552433732313a207472616e73666572206f6620746f6b656e2074686174206973206e6f74206f776e4552433732314d657461646174613a2055524920717565727920666f72206e6f6e6578697374656e7420746f6b656e4552433732313a20617070726f76616c20746f2063757272656e74206f776e65724d7573742062652057686974656c697374656420746f206d696e74206265666f7265204a616e2031352c20323032322031313a30303a303020504d20474d544552433732313a207472616e736665722063616c6c6572206973206e6f74206f776e6572206e6f7220617070726f766564a2646970667358221220563cc61c3d2d49cf35d60cc0f52adb9c9e9a2568682c2013f5b9d2c1e49f7b7a64736f6c634300070000335061796d656e7453706c69747465723a206163636f756e7420697320746865207a65726f20616464726573735061796d656e7453706c69747465723a2070617965657320616e6420736861726573206c656e677468206d69736d617463685061796d656e7453706c69747465723a206163636f756e7420616c7265616479206861732073686172657300000000000000000000000000000000000000000000000000000000000000e0000000000000000000000000000000000000000000000000000000000000012000000000000000000000000000000000000000000000000000000000000001f40000000000000000000000000000000000000000000000000000000061e351f0000000000000000000000000000000000000000000000000000000000000016000000000000000000000000000000000000000000000000000000000000001c00000000000000000000000000000000000000000000000000000000000000220000000000000000000000000000000000000000000000000000000000000000f4d6f6f6479204d757368726f6f6d73000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000054d4f4f44590000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000002000000000000000000000000dcabf4fb1d7594eacb014d48e3674857f806f4b200000000000000000000000056cc222791c8e0d048b6dd42a7d3ef273afe55b20000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000003200000000000000000000000000000000000000000000000000000000000000320000000000000000000000000000000000000000000000000000000000000026000000000000000000000000dcabf4fb1d7594eacb014d48e3674857f806f4b200000000000000000000000056cc222791c8e0d048b6dd42a7d3ef273afe55b20000000000000000000000006d3b7a9df256b8f1e643b9fb8908a26b55ca99e2000000000000000000000000449afe8e487b2c3297ea0833a1dc3f83af82d91e000000000000000000000000319d3a318f6a99c9b7bcb54a45a61f5c5a3ca31a0000000000000000000000000b49e6a16565344faf35501d79e7420e94b5308d000000000000000000000000c5a933661815633047451ee7ee72b12fab1aff50000000000000000000000000fda3513b35e1890182d61e1d140ba636108d234900000000000000000000000042e41bc9cfc1dc24aad993b65c2ba7597a33c1c90000000000000000000000002ca27dfd517e96764295adc935c8e2e26ab4197b000000000000000000000000d614bebb77393923e8f7d9690b3dbce12f412ff40000000000000000000000008462e8ba9bd29e0ea5cb7989055dde36d6b4948e0000000000000000000000008a46cecd738800123b9049cf4602575b36b22c0a0000000000000000000000009499b6da11777a6993e717a86f3f6f12eceb3d32000000000000000000000000c6b7c8bae695be4eee069d393521bf2fade76b3a00000000000000000000000071f01e7236eef0a9072d38bc4c6b3c42f32e6b1d000000000000000000000000ef07fa176957435b53aa2df0ff0e06cf0694ca31000000000000000000000000211ef050b4165eb1f4a3ac7747e4844fce0fd3b50000000000000000000000008e9fcaba9ea23ada7631247e1404196f5eb590c900000000000000000000000009b7ee62b2bdd4c8c36f9bbabf746abe8d1dd5bc00000000000000000000000013b46618ce640d79780f3471a77b03478de9501d000000000000000000000000b11ce08416c61303ab6b6d81b91eae93dd33a5eb000000000000000000000000e92819cd3586c5675734e4e3dce8396f535c29bb0000000000000000000000008c831f68bbeb3f1c733f1ff30fef47e389b18033000000000000000000000000f831f66e2521420b1529dc60a54b0cb125ecb33c00000000000000000000000065dabfe189e7d6bd5de97ee1a88d3cbeb319a9e3000000000000000000000000385e029c3360a170057867db5d5eb5860eab45220000000000000000000000006939e42c497547b8b88f115408b10888442d14460000000000000000000000004d7c2d52365daad36ff689d482f0e8f576291fca000000000000000000000000ef4c773fb8562fb11290f0f01f6c83040965e66e000000000000000000000000741e50151a7ed552944b15f91ec26d3df85c824f000000000000000000000000b88db7ecf70c9827529953668dc4c7bfa600ae87000000000000000000000000f08091b21e457d6eae65ad96e2757827489d9fd40000000000000000000000001a7d7d11227f66ca03666932f0b4c57a86d2ed9200000000000000000000000035584e81e5d012047d4a66eaed098abf2adf5ebd0000000000000000000000006db7ad23a5759e8bc9eccf6ed7fe24322c90b033000000000000000000000000fc327e782c823e9e1ebd62c537fef51a89852d36000000000000000000000000a78d2dfc4b5e8638284516dc946378094f996933
Deployed Bytecode
0x60806040526004361061034e5760003560e01c80636de9f32b116101bb578063b88d4fde116100f7578063e36d649811610095578063eb8d24441161006f578063eb8d244414610d34578063ef3f4a3c14610d49578063f032554914610d5e578063f2fde38b14610d735761039e565b8063e36d649814610ccf578063e985e9c514610ce4578063e986655014610d1f5761039e565b8063cb774d47116100d1578063cb774d4714610c5d578063ce7c2ac214610c72578063d9f80c3e14610ca5578063e33b7de314610cba5761039e565b8063b88d4fde14610b4b578063c6ff7eb914610c1e578063c87b56dd14610c335761039e565b80638da5cb5b116101645780639852595c1161013e5780639852595c14610aab578063a22cb46514610ade578063a625567114610b19578063a6eeaede14610b365761039e565b80638da5cb5b14610a4e578063937cde2014610a6357806395d89b4114610a965761039e565b80637d17fcbe116101955780637d17fcbe146109dc578063865f7724146109f15780638b83209b14610a245761039e565b80636de9f32b1461097f57806370a0823114610994578063715018a6146109c75761039e565b806329092d0e1161028a5780633af32abf1161023357806355f804b31161020d57806355f804b31461085a5780635e5c06e21461090d5780636352211e146109405780636c0360eb1461096a5761039e565b80633af32abf146107ba57806342842e0e146107ed5780634f6ccce7146108305761039e565b806334918dfd1161026457806334918dfd1461077b57806335c6aaf8146107905780633a98ef39146107a55761039e565b806329092d0e146106fa5780632f745c591461072d57806330f72cd4146107665761039e565b80630a3b0a4f116102f757806318e20a38116102d157806318e20a381461065a578063191655871461066f5780631c136e7c146106a257806323b872dd146106b75761039e565b80630a3b0a4f1461055f578063109695231461059257806318160ddd146106455761039e565b806306fdde031161032857806306fdde0314610456578063081812fc146104e0578063095ea7b3146105265761039e565b8063018a2c37146103a357806301ffc9a7146103cf57806305cefdea1461042f5761039e565b3661039e577f6ef95f06320e7a25a04a175ca677b7052bdd97131872c2192525a629f51be77061037c610da6565b604080516001600160a01b0390921682523460208301528051918290030190a1005b600080fd5b3480156103af57600080fd5b506103cd600480360360208110156103c657600080fd5b5035610daa565b005b3480156103db57600080fd5b5061041b600480360360208110156103f257600080fd5b50357fffffffff0000000000000000000000000000000000000000000000000000000016610e11565b604080519115158252519081900360200190f35b34801561043b57600080fd5b50610444610e4c565b60408051918252519081900360200190f35b34801561046257600080fd5b5061046b610e57565b6040805160208082528351818301528351919283929083019185019080838360005b838110156104a557818101518382015260200161048d565b50505050905090810190601f1680156104d25780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b3480156104ec57600080fd5b5061050a6004803603602081101561050357600080fd5b5035610eed565b604080516001600160a01b039092168252519081900360200190f35b34801561053257600080fd5b506103cd6004803603604081101561054957600080fd5b506001600160a01b038135169060200135610f4f565b34801561056b57600080fd5b506103cd6004803603602081101561058257600080fd5b50356001600160a01b031661102a565b34801561059e57600080fd5b506103cd600480360360208110156105b557600080fd5b8101906020810181356401000000008111156105d057600080fd5b8201836020820111156105e257600080fd5b8035906020019184600183028401116401000000008311171561060457600080fd5b91908080601f0160208091040260200160405190810160405280939291908181526020018383808284376000920191909152509295506110d8945050505050565b34801561065157600080fd5b50610444611151565b34801561066657600080fd5b50610444611162565b34801561067b57600080fd5b506103cd6004803603602081101561069257600080fd5b50356001600160a01b0316611168565b3480156106ae57600080fd5b5061050a6112b1565b3480156106c357600080fd5b506103cd600480360360608110156106da57600080fd5b506001600160a01b038135811691602081013590911690604001356112c0565b34801561070657600080fd5b506103cd6004803603602081101561071d57600080fd5b50356001600160a01b0316611317565b34801561073957600080fd5b506104446004803603604081101561075057600080fd5b506001600160a01b0381351690602001356113c2565b34801561077257600080fd5b5061041b6113ed565b34801561078757600080fd5b506103cd6113fb565b34801561079c57600080fd5b50610444611472565b3480156107b157600080fd5b5061044461147d565b3480156107c657600080fd5b5061041b600480360360208110156107dd57600080fd5b50356001600160a01b0316611483565b3480156107f957600080fd5b506103cd6004803603606081101561081057600080fd5b506001600160a01b038135811691602081013590911690604001356114a1565b34801561083c57600080fd5b506104446004803603602081101561085357600080fd5b50356114bc565b34801561086657600080fd5b506103cd6004803603602081101561087d57600080fd5b81019060208101813564010000000081111561089857600080fd5b8201836020820111156108aa57600080fd5b803590602001918460018302840111640100000000831117156108cc57600080fd5b91908080601f0160208091040260200160405190810160405280939291908181526020018383808284376000920191909152509295506114d2945050505050565b34801561091957600080fd5b506104446004803603602081101561093057600080fd5b50356001600160a01b0316611540565b34801561094c57600080fd5b5061050a6004803603602081101561096357600080fd5b5035611552565b34801561097657600080fd5b5061046b61157a565b34801561098b57600080fd5b506104446115db565b3480156109a057600080fd5b50610444600480360360208110156109b757600080fd5b50356001600160a01b03166115e7565b3480156109d357600080fd5b506103cd61164f565b3480156109e857600080fd5b506103cd611708565b3480156109fd57600080fd5b506103cd60048036036020811015610a1457600080fd5b50356001600160a01b03166117c5565b348015610a3057600080fd5b5061050a60048036036020811015610a4757600080fd5b5035611856565b348015610a5a57600080fd5b5061050a611880565b348015610a6f57600080fd5b5061041b60048036036020811015610a8657600080fd5b50356001600160a01b031661188f565b348015610aa257600080fd5b5061046b611939565b348015610ab757600080fd5b5061044460048036036020811015610ace57600080fd5b50356001600160a01b031661199a565b348015610aea57600080fd5b506103cd60048036036040811015610b0157600080fd5b506001600160a01b03813516906020013515156119b5565b6103cd60048036036020811015610b2f57600080fd5b5035611aba565b348015610b4257600080fd5b5061046b611e7f565b348015610b5757600080fd5b506103cd60048036036080811015610b6e57600080fd5b6001600160a01b03823581169260208101359091169160408201359190810190608081016060820135640100000000811115610ba957600080fd5b820183602082011115610bbb57600080fd5b80359060200191846001830284011164010000000083111715610bdd57600080fd5b91908080601f016020809104026020016040519081016040528093929190818152602001838380828437600092019190915250929550611f0d945050505050565b348015610c2a57600080fd5b50610444611f6b565b348015610c3f57600080fd5b5061046b60048036036020811015610c5657600080fd5b5035611f71565b348015610c6957600080fd5b506104446121f4565b348015610c7e57600080fd5b5061044460048036036020811015610c9557600080fd5b50356001600160a01b03166121fa565b348015610cb157600080fd5b506103cd612215565b348015610cc657600080fd5b506104446122a8565b348015610cdb57600080fd5b506104446122ae565b348015610cf057600080fd5b5061041b60048036036040811015610d0757600080fd5b506001600160a01b03813581169160200135166122b4565b348015610d2b57600080fd5b506103cd6122e2565b348015610d4057600080fd5b5061041b6123e4565b348015610d5557600080fd5b506104446123ed565b348015610d6a57600080fd5b506103cd6123f2565b348015610d7f57600080fd5b506103cd60048036036020811015610d9657600080fd5b50356001600160a01b0316612474565b3390565b610db2610da6565b6001600160a01b0316610dc3611880565b6001600160a01b031614610e0c576040805162461bcd60e51b815260206004820181905260248201526000805160206137d4833981519152604482015290519081900360640190fd5b601655565b7fffffffff00000000000000000000000000000000000000000000000000000000811660009081526020819052604090205460ff165b919050565b66b1a2bc2ec5000081565b60068054604080516020601f6002600019610100600188161502019095169490940493840181900481028201810190925282815260609390929091830182828015610ee35780601f10610eb857610100808354040283529160200191610ee3565b820191906000526020600020905b815481529060010190602001808311610ec657829003601f168201915b5050505050905090565b6000610ef882612584565b610f335760405162461bcd60e51b815260040180806020018281038252602c8152602001806137a8602c913960400191505060405180910390fd5b506000908152600460205260409020546001600160a01b031690565b6000610f5a82611552565b9050806001600160a01b0316836001600160a01b03161415610fad5760405162461bcd60e51b815260040180806020018281038252602181526020018061384c6021913960400191505060405180910390fd5b806001600160a01b0316610fbf610da6565b6001600160a01b03161480610fe05750610fe081610fdb610da6565b6122b4565b61101b5760405162461bcd60e51b81526004018080602001828103825260388152602001806136b16038913960400191505060405180910390fd5b6110258383612591565b505050565b611032610da6565b6001600160a01b0316611043611880565b6001600160a01b03161461108c576040805162461bcd60e51b815260206004820181905260248201526000805160206137d4833981519152604482015290519081900360640190fd5b6001600160a01b038116600081815260106020526040808220805460ff19166001179055517fa850ae9193f515cbae8d35e8925bd2be26627fc91bce650b8652ed254e9cab039190a250565b6110e0610da6565b6001600160a01b03166110f1611880565b6001600160a01b03161461113a576040805162461bcd60e51b815260206004820181905260248201526000805160206137d4833981519152604482015290519081900360640190fd5b805161114d90601190602084019061343c565b5050565b600061115d600261260c565b905090565b60165481565b6001600160a01b0381166000908152600d60205260409020546111bc5760405162461bcd60e51b81526004018080602001828103825260268152602001806135d66026913960400191505060405180910390fd5b600c546001600160a01b0382166000908152600e6020908152604080832054600b54600d9093529083205447909401939091908402816111f857fe5b04039050806112385760405162461bcd60e51b815260040180806020018281038252602b815260200180613686602b913960400191505060405180910390fd5b6001600160a01b0383166000908152600e60205260409020805482019055600c8054820190556112688382612617565b604080516001600160a01b03851681526020810183905281517fdf20fd1e76bc69d672e4814fafb2c449bba3a5369d8359adf9e05e6fde87b056929181900390910190a1505050565b6019546001600160a01b031681565b6112d16112cb610da6565b826126fc565b61130c5760405162461bcd60e51b81526004018080602001828103825260318152602001806138ac6031913960400191505060405180910390fd5b6110258383836127a0565b61131f610da6565b6001600160a01b0316611330611880565b6001600160a01b031614611379576040805162461bcd60e51b815260206004820181905260248201526000805160206137d4833981519152604482015290519081900360640190fd5b6001600160a01b038116600081815260106020526040808220805460ff19169055517fcdd2e9b91a56913d370075169cefa1602ba36be5301664f752192bb1709df7579190a250565b6001600160a01b03821660009081526001602052604081206113e490836128ec565b90505b92915050565b601554610100900460ff1681565b611403610da6565b6001600160a01b0316611414611880565b6001600160a01b03161461145d576040805162461bcd60e51b815260206004820181905260248201526000805160206137d4833981519152604482015290519081900360640190fd5b6015805461ffff19811660ff90911615179055565b668e1bc9bf04000081565b600b5490565b6001600160a01b031660009081526010602052604090205460ff1690565b61102583838360405180602001604052806000815250611f0d565b6000806114ca6002846128f8565b509392505050565b6114da610da6565b6001600160a01b03166114eb611880565b6001600160a01b031614611534576040805162461bcd60e51b815260206004820181905260248201526000805160206137d4833981519152604482015290519081900360640190fd5b61153d81612914565b50565b60186020526000908152604090205481565b60006113e7826040518060600160405280602981526020016137136029913960029190612927565b60098054604080516020601f6002600019610100600188161502019095169490940493840181900481028201810190925282815260609390929091830182828015610ee35780601f10610eb857610100808354040283529160200191610ee3565b600061115d601761293e565b60006001600160a01b03821661162e5760405162461bcd60e51b815260040180806020018281038252602a8152602001806136e9602a913960400191505060405180910390fd5b6001600160a01b03821660009081526001602052604090206113e79061260c565b611657610da6565b6001600160a01b0316611668611880565b6001600160a01b0316146116b1576040805162461bcd60e51b815260206004820181905260248201526000805160206137d4833981519152604482015290519081900360640190fd5b600a546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600a805473ffffffffffffffffffffffffffffffffffffffff19169055565b611710610da6565b6001600160a01b0316611721611880565b6001600160a01b03161461176a576040805162461bcd60e51b815260206004820181905260248201526000805160206137d4833981519152604482015290519081900360640190fd5b601354156117bf576040805162461bcd60e51b815260206004820152601d60248201527f5374617274696e6720696e64657820697320616c726561647920736574000000604482015290519081900360640190fd5b43601255565b6117cd610da6565b6001600160a01b03166117de611880565b6001600160a01b031614611827576040805162461bcd60e51b815260206004820181905260248201526000805160206137d4833981519152604482015290519081900360640190fd5b6019805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0392909216919091179055565b6000600f828154811061186557fe5b6000918252602090912001546001600160a01b031692915050565b600a546001600160a01b031690565b601954604080517f70a082310000000000000000000000000000000000000000000000000000000081526001600160a01b0384811660048301529151600093849316916370a08231916024808301926020929190829003018186803b1580156118f757600080fd5b505afa15801561190b573d6000803e3d6000fd5b505050506040513d602081101561192157600080fd5b5051111561193157506001610e47565b506000919050565b60078054604080516020601f6002600019610100600188161502019095169490940493840181900481028201810190925282815260609390929091830182828015610ee35780601f10610eb857610100808354040283529160200191610ee3565b6001600160a01b03166000908152600e602052604090205490565b6119bd610da6565b6001600160a01b0316826001600160a01b03161415611a23576040805162461bcd60e51b815260206004820152601960248201527f4552433732313a20617070726f766520746f2063616c6c657200000000000000604482015290519081900360640190fd5b8060056000611a30610da6565b6001600160a01b03908116825260208083019390935260409182016000908120918716808252919093529120805460ff191692151592909217909155611a74610da6565b6001600160a01b03167f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c318360405180821515815260200191505060405180910390a35050565b60155460ff1680611ad25750601554610100900460ff165b611b0d5760405162461bcd60e51b815260040180806020018281038252602b81526020018061357d602b913960400191505060405180910390fd5b601554610100900460ff168015611b27575060155460ff16155b15611bd357611b353361188f565b80611b445750611b4433611483565b611b7f5760405162461bcd60e51b815260040180806020018281038252603f81526020018061386d603f913960400191505060405180910390fd5b601454611b9682611b90601761293e565b90612942565b1115611bd35760405162461bcd60e51b81526004018080602001828103825260338152602001806134f26033913960400191505060405180910390fd5b6003811115611c135760405162461bcd60e51b815260040180806020018281038252602981526020018061373c6029913960400191505060405180910390fd5b33600090815260186020526040902054600390611c31908390612942565b1115611c6e5760405162461bcd60e51b815260040180806020018281038252602e8152602001806135a8602e913960400191505060405180910390fd5b601454611c7f82611b90601761293e565b1115611cbc5760405162461bcd60e51b81526004018080602001828103825260338152602001806134f26033913960400191505060405180910390fd5b611cc53361188f565b15611d345734611cdc668e1bc9bf0400008361299c565b1115611d2f576040805162461bcd60e51b815260206004820152601f60248201527f45746865722076616c75652073656e74206973206e6f7420636f727265637400604482015290519081900360640190fd5b611d99565b34611d4666b1a2bc2ec500008361299c565b1115611d99576040805162461bcd60e51b815260206004820152601f60248201527f45746865722076616c75652073656e74206973206e6f7420636f727265637400604482015290519081900360640190fd5b611da2336129f5565b15611df4576040805162461bcd60e51b815260206004820152601460248201527f436f6e7472616374732063616e2774206d696e74000000000000000000000000604482015290519081900360640190fd5b60005b81811015611e4c57601454611e0c601761293e565b11611e445733600090815260186020526040902080546001019055611e3160176129fb565b611e4433611e3f601761293e565b612a0c565b600101611df7565b50601254158015611e735750601454611e65601761293e565b1480611e7357506016544210155b1561153d574360125550565b6011805460408051602060026001851615610100026000190190941693909304601f81018490048402820184019092528181529291830182828015611f055780601f10611eda57610100808354040283529160200191611f05565b820191906000526020600020905b815481529060010190602001808311611ee857829003601f168201915b505050505081565b611f1e611f18610da6565b836126fc565b611f595760405162461bcd60e51b81526004018080602001828103825260318152602001806138ac6031913960400191505060405180910390fd5b611f6584848484612a26565b50505050565b60145481565b6060611f7c82612584565b611fb75760405162461bcd60e51b815260040180806020018281038252602f81526020018061381d602f913960400191505060405180910390fd5b60008281526008602090815260409182902080548351601f600260001961010060018616150201909316929092049182018490048402810184019094528084526060939283018282801561204c5780601f106120215761010080835404028352916020019161204c565b820191906000526020600020905b81548152906001019060200180831161202f57829003601f168201915b50505050509050606061205d61157a565b905080516000141561207157509050610e47565b8151156121325780826040516020018083805190602001908083835b602083106120ac5780518252601f19909201916020918201910161208d565b51815160209384036101000a600019018019909216911617905285519190930192850191508083835b602083106120f45780518252601f1990920191602091820191016120d5565b6001836020036101000a0380198251168184511680821785525050505050509050019250505060405160208183030381529060405292505050610e47565b8061213c85612a78565b6040516020018083805190602001908083835b6020831061216e5780518252601f19909201916020918201910161214f565b51815160209384036101000a600019018019909216911617905285519190930192850191508083835b602083106121b65780518252601f199092019160209182019101612197565b6001836020036101000a0380198251168184511680821785525050505050509050019250505060405160208183030381529060405292505050919050565b60135481565b6001600160a01b03166000908152600d602052604090205490565b61221d610da6565b6001600160a01b031661222e611880565b6001600160a01b031614612277576040805162461bcd60e51b815260206004820181905260248201526000805160206137d4833981519152604482015290519081900360640190fd5b6000612283601761293e565b600101905060005b600c81101561114d576122a033828401612a0c565b60010161228b565b600c5490565b60125481565b6001600160a01b03918216600090815260056020908152604080832093909416825291909152205460ff1690565b60135415612337576040805162461bcd60e51b815260206004820152601d60248201527f5374617274696e6720696e64657820697320616c726561647920736574000000604482015290519081900360640190fd5b60125461238b576040805162461bcd60e51b815260206004820181905260248201527f5374617274696e6720696e64657820626c6f636b206d75737420626520736574604482015290519081900360640190fd5b601454601254408161239957fe5b0660135560125460ff906123ae904390612b87565b11156123c957601454600019430140816123c457fe5b066013555b6013546123e2576013546123de906001612942565b6013555b565b60155460ff1681565b600381565b6123fa610da6565b6001600160a01b031661240b611880565b6001600160a01b031614612454576040805162461bcd60e51b815260206004820181905260248201526000805160206137d4833981519152604482015290519081900360640190fd5b6015805461010060ff19821681900460ff16150261ffff19909116179055565b61247c610da6565b6001600160a01b031661248d611880565b6001600160a01b0316146124d6576040805162461bcd60e51b815260206004820181905260248201526000805160206137d4833981519152604482015290519081900360640190fd5b6001600160a01b03811661251b5760405162461bcd60e51b81526004018080602001828103825260268152602001806135576026913960400191505060405180910390fd5b600a546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600a805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b0392909216919091179055565b60006113e7600283612be4565b6000818152600460205260409020805473ffffffffffffffffffffffffffffffffffffffff19166001600160a01b03841690811790915581906125d382611552565b6001600160a01b03167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92560405160405180910390a45050565b60006113e78261293e565b8047101561266c576040805162461bcd60e51b815260206004820152601d60248201527f416464726573733a20696e73756666696369656e742062616c616e6365000000604482015290519081900360640190fd5b6040516000906001600160a01b0384169083908381818185875af1925050503d80600081146126b7576040519150601f19603f3d011682016040523d82523d6000602084013e6126bc565b606091505b50509050806110255760405162461bcd60e51b815260040180806020018281038252603a815260200180613620603a913960400191505060405180910390fd5b600061270782612584565b6127425760405162461bcd60e51b815260040180806020018281038252602c81526020018061365a602c913960400191505060405180910390fd5b600061274d83611552565b9050806001600160a01b0316846001600160a01b031614806127885750836001600160a01b031661277d84610eed565b6001600160a01b0316145b80612798575061279881856122b4565b949350505050565b826001600160a01b03166127b382611552565b6001600160a01b0316146127f85760405162461bcd60e51b81526004018080602001828103825260298152602001806137f46029913960400191505060405180910390fd5b6001600160a01b03821661283d5760405162461bcd60e51b81526004018080602001828103825260248152602001806135fc6024913960400191505060405180910390fd5b612848838383611025565b612853600082612591565b6001600160a01b03831660009081526001602052604090206128759082612bf0565b506001600160a01b03821660009081526001602052604090206128989082612bfc565b506128a560028284612c08565b5080826001600160a01b0316846001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60405160405180910390a4505050565b60006113e48383612c1e565b60008080806129078686612c82565b9097909650945050505050565b805161114d90600990602084019061343c565b6000612934848484612cfd565b90505b9392505050565b5490565b6000828201838110156113e4576040805162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015290519081900360640190fd5b6000826129ab575060006113e7565b828202828482816129b857fe5b04146113e45760405162461bcd60e51b81526004018080602001828103825260218152602001806137876021913960400191505060405180910390fd5b3b151590565b8054612a08906001612942565b9055565b61114d828260405180602001604052806000815250612dc7565b612a318484846127a0565b612a3d84848484612e19565b611f655760405162461bcd60e51b81526004018080602001828103825260328152602001806135256032913960400191505060405180910390fd5b606081612ab9575060408051808201909152600181527f30000000000000000000000000000000000000000000000000000000000000006020820152610e47565b8160005b8115612ad157600101600a82049150612abd565b60608167ffffffffffffffff81118015612aea57600080fd5b506040519080825280601f01601f191660200182016040528015612b15576020820181803683370190505b50859350905060001982015b8315612b7e57600a840660300160f81b82828060019003935081518110612b4457fe5b60200101907effffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916908160001a905350600a84049350612b21565b50949350505050565b600082821115612bde576040805162461bcd60e51b815260206004820152601e60248201527f536166654d6174683a207375627472616374696f6e206f766572666c6f770000604482015290519081900360640190fd5b50900390565b60006113e48383612fc3565b60006113e48383612fdb565b60006113e483836130a1565b600061293484846001600160a01b0385166130eb565b81546000908210612c605760405162461bcd60e51b81526004018080602001828103825260228152602001806134d06022913960400191505060405180910390fd5b826000018281548110612c6f57fe5b9060005260206000200154905092915050565b815460009081908310612cc65760405162461bcd60e51b81526004018080602001828103825260228152602001806137656022913960400191505060405180910390fd5b6000846000018481548110612cd757fe5b906000526020600020906002020190508060000154816001015492509250509250929050565b60008281526001840160205260408120548281612d985760405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b83811015612d5d578181015183820152602001612d45565b50505050905090810190601f168015612d8a5780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b50846000016001820381548110612dab57fe5b9060005260206000209060020201600101549150509392505050565b612dd18383613182565b612dde6000848484612e19565b6110255760405162461bcd60e51b81526004018080602001828103825260328152602001806135256032913960400191505060405180910390fd5b6000612e2d846001600160a01b03166129f5565b612e3957506001612798565b6060612f71630a85bd0160e11b612e4e610da6565b88878760405160240180856001600160a01b03168152602001846001600160a01b0316815260200183815260200180602001828103825283818151815260200191508051906020019080838360005b83811015612eb5578181015183820152602001612e9d565b50505050905090810190601f168015612ee25780820380516001836020036101000a031916815260200191505b5095505050505050604051602081830303815290604052907bffffffffffffffffffffffffffffffffffffffffffffffffffffffff19166020820180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff8381831617835250505050604051806060016040528060328152602001613525603291396001600160a01b03881691906132b0565b90506000818060200190516020811015612f8a57600080fd5b50517fffffffff0000000000000000000000000000000000000000000000000000000016630a85bd0160e11b1492505050949350505050565b60009081526001919091016020526040902054151590565b60008181526001830160205260408120548015613097578354600019808301919081019060009087908390811061300e57fe5b906000526020600020015490508087600001848154811061302b57fe5b60009182526020808320909101929092558281526001898101909252604090209084019055865487908061305b57fe5b600190038181906000526020600020016000905590558660010160008781526020019081526020016000206000905560019450505050506113e7565b60009150506113e7565b60006130ad8383612fc3565b6130e3575081546001818101845560008481526020808220909301849055845484825282860190935260409020919091556113e7565b5060006113e7565b600082815260018401602052604081205480613150575050604080518082018252838152602080820184815286546001818101895560008981528481209551600290930290950191825591519082015586548684528188019092529290912055612937565b8285600001600183038154811061316357fe5b9060005260206000209060020201600101819055506000915050612937565b6001600160a01b0382166131dd576040805162461bcd60e51b815260206004820181905260248201527f4552433732313a206d696e7420746f20746865207a65726f2061646472657373604482015290519081900360640190fd5b6131e681612584565b15613238576040805162461bcd60e51b815260206004820152601c60248201527f4552433732313a20746f6b656e20616c7265616479206d696e74656400000000604482015290519081900360640190fd5b61324460008383611025565b6001600160a01b03821660009081526001602052604090206132669082612bfc565b5061327360028284612c08565b5060405181906001600160a01b038416906000907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef908290a45050565b60606129348484600085856132c4856129f5565b613315576040805162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e7472616374000000604482015290519081900360640190fd5b60006060866001600160a01b031685876040518082805190602001908083835b602083106133545780518252601f199092019160209182019101613335565b6001836020036101000a03801982511681845116808217855250505050505090500191505060006040518083038185875af1925050503d80600081146133b6576040519150601f19603f3d011682016040523d82523d6000602084013e6133bb565b606091505b50915091506133cb8282866133d6565b979650505050505050565b606083156133e5575081612937565b8251156133f55782518084602001fd5b60405162461bcd60e51b8152602060048201818152845160248401528451859391928392604401919085019080838360008315612d5d578181015183820152602001612d45565b828054600181600116156101000203166002900490600052602060002090601f016020900481019282601f1061347d57805160ff19168380011785556134aa565b828001600101855582156134aa579182015b828111156134aa57825182559160200191906001019061348f565b506134b69291506134ba565b5090565b5b808211156134b657600081556001016134bb56fe456e756d657261626c655365743a20696e646578206f7574206f6620626f756e6473507572636861736520776f756c6420657863656564206d617820737570706c79206f66204d6f6f6479204d757368726f6f6d734552433732313a207472616e7366657220746f206e6f6e20455243373231526563656976657220696d706c656d656e7465724f776e61626c653a206e6577206f776e657220697320746865207a65726f206164647265737353616c65206d7573742062652061637469766520746f206d696e74204d6f6f6479204d757368726f6f6d73536f72727920707572636861736520776f756c64206578636565642033206d696e7473207065722077616c6c65745061796d656e7453706c69747465723a206163636f756e7420686173206e6f207368617265734552433732313a207472616e7366657220746f20746865207a65726f2061646472657373416464726573733a20756e61626c6520746f2073656e642076616c75652c20726563697069656e74206d617920686176652072657665727465644552433732313a206f70657261746f7220717565727920666f72206e6f6e6578697374656e7420746f6b656e5061796d656e7453706c69747465723a206163636f756e74206973206e6f7420647565207061796d656e744552433732313a20617070726f76652063616c6c6572206973206e6f74206f776e6572206e6f7220617070726f76656420666f7220616c6c4552433732313a2062616c616e636520717565727920666f7220746865207a65726f20616464726573734552433732313a206f776e657220717565727920666f72206e6f6e6578697374656e7420746f6b656e43616e206f6e6c79206d696e742033204d6f6f6479204d757368726f6f6d7320617420612074696d65456e756d657261626c654d61703a20696e646578206f7574206f6620626f756e6473536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f774552433732313a20617070726f76656420717565727920666f72206e6f6e6578697374656e7420746f6b656e4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65724552433732313a207472616e73666572206f6620746f6b656e2074686174206973206e6f74206f776e4552433732314d657461646174613a2055524920717565727920666f72206e6f6e6578697374656e7420746f6b656e4552433732313a20617070726f76616c20746f2063757272656e74206f776e65724d7573742062652057686974656c697374656420746f206d696e74206265666f7265204a616e2031352c20323032322031313a30303a303020504d20474d544552433732313a207472616e736665722063616c6c6572206973206e6f74206f776e6572206e6f7220617070726f766564a2646970667358221220563cc61c3d2d49cf35d60cc0f52adb9c9e9a2568682c2013f5b9d2c1e49f7b7a64736f6c63430007000033
Constructor Arguments (ABI-Encoded and is the last bytes of the Contract Creation Code above)
00000000000000000000000000000000000000000000000000000000000000e0000000000000000000000000000000000000000000000000000000000000012000000000000000000000000000000000000000000000000000000000000001f40000000000000000000000000000000000000000000000000000000061e351f0000000000000000000000000000000000000000000000000000000000000016000000000000000000000000000000000000000000000000000000000000001c00000000000000000000000000000000000000000000000000000000000000220000000000000000000000000000000000000000000000000000000000000000f4d6f6f6479204d757368726f6f6d73000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000054d4f4f44590000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000002000000000000000000000000dcabf4fb1d7594eacb014d48e3674857f806f4b200000000000000000000000056cc222791c8e0d048b6dd42a7d3ef273afe55b20000000000000000000000000000000000000000000000000000000000000002000000000000000000000000000000000000000000000000000000000000003200000000000000000000000000000000000000000000000000000000000000320000000000000000000000000000000000000000000000000000000000000026000000000000000000000000dcabf4fb1d7594eacb014d48e3674857f806f4b200000000000000000000000056cc222791c8e0d048b6dd42a7d3ef273afe55b20000000000000000000000006d3b7a9df256b8f1e643b9fb8908a26b55ca99e2000000000000000000000000449afe8e487b2c3297ea0833a1dc3f83af82d91e000000000000000000000000319d3a318f6a99c9b7bcb54a45a61f5c5a3ca31a0000000000000000000000000b49e6a16565344faf35501d79e7420e94b5308d000000000000000000000000c5a933661815633047451ee7ee72b12fab1aff50000000000000000000000000fda3513b35e1890182d61e1d140ba636108d234900000000000000000000000042e41bc9cfc1dc24aad993b65c2ba7597a33c1c90000000000000000000000002ca27dfd517e96764295adc935c8e2e26ab4197b000000000000000000000000d614bebb77393923e8f7d9690b3dbce12f412ff40000000000000000000000008462e8ba9bd29e0ea5cb7989055dde36d6b4948e0000000000000000000000008a46cecd738800123b9049cf4602575b36b22c0a0000000000000000000000009499b6da11777a6993e717a86f3f6f12eceb3d32000000000000000000000000c6b7c8bae695be4eee069d393521bf2fade76b3a00000000000000000000000071f01e7236eef0a9072d38bc4c6b3c42f32e6b1d000000000000000000000000ef07fa176957435b53aa2df0ff0e06cf0694ca31000000000000000000000000211ef050b4165eb1f4a3ac7747e4844fce0fd3b50000000000000000000000008e9fcaba9ea23ada7631247e1404196f5eb590c900000000000000000000000009b7ee62b2bdd4c8c36f9bbabf746abe8d1dd5bc00000000000000000000000013b46618ce640d79780f3471a77b03478de9501d000000000000000000000000b11ce08416c61303ab6b6d81b91eae93dd33a5eb000000000000000000000000e92819cd3586c5675734e4e3dce8396f535c29bb0000000000000000000000008c831f68bbeb3f1c733f1ff30fef47e389b18033000000000000000000000000f831f66e2521420b1529dc60a54b0cb125ecb33c00000000000000000000000065dabfe189e7d6bd5de97ee1a88d3cbeb319a9e3000000000000000000000000385e029c3360a170057867db5d5eb5860eab45220000000000000000000000006939e42c497547b8b88f115408b10888442d14460000000000000000000000004d7c2d52365daad36ff689d482f0e8f576291fca000000000000000000000000ef4c773fb8562fb11290f0f01f6c83040965e66e000000000000000000000000741e50151a7ed552944b15f91ec26d3df85c824f000000000000000000000000b88db7ecf70c9827529953668dc4c7bfa600ae87000000000000000000000000f08091b21e457d6eae65ad96e2757827489d9fd40000000000000000000000001a7d7d11227f66ca03666932f0b4c57a86d2ed9200000000000000000000000035584e81e5d012047d4a66eaed098abf2adf5ebd0000000000000000000000006db7ad23a5759e8bc9eccf6ed7fe24322c90b033000000000000000000000000fc327e782c823e9e1ebd62c537fef51a89852d36000000000000000000000000a78d2dfc4b5e8638284516dc946378094f996933
-----Decoded View---------------
Arg [0] : name (string): Moody Mushrooms
Arg [1] : symbol (string): MOODY
Arg [2] : maxNftSupply (uint256): 500
Arg [3] : saleStart (uint256): 1642287600
Arg [4] : addrs (address[]): 0xDcABf4Fb1D7594eaCB014d48e3674857f806f4b2,0x56cC222791C8E0D048b6dD42a7D3ef273afe55B2
Arg [5] : shares_ (uint256[]): 50,50
Arg [6] : wl_addrs (address[]): 0xDcABf4Fb1D7594eaCB014d48e3674857f806f4b2,0x56cC222791C8E0D048b6dD42a7D3ef273afe55B2,0x6D3b7a9dF256b8f1E643B9FB8908a26B55CA99e2,0x449afE8e487B2c3297eA0833a1dC3f83Af82D91e,0x319D3A318F6A99C9b7bcB54A45a61f5c5a3Ca31a,0x0B49e6a16565344Faf35501D79e7420E94b5308d,0xC5A933661815633047451eE7ee72b12fAb1Aff50,0xfda3513b35e1890182d61E1D140BA636108D2349,0x42e41Bc9cfC1Dc24AAD993b65c2BA7597a33C1C9,0x2Ca27dfD517E96764295adC935c8E2E26ab4197B,0xd614bebB77393923E8f7d9690b3DbCe12F412FF4,0x8462e8BA9Bd29e0EA5Cb7989055DdE36D6b4948E,0x8a46cEcd738800123b9049cF4602575B36B22C0A,0x9499B6dA11777A6993e717a86f3F6F12EcEb3d32,0xC6b7c8BAe695be4eee069D393521BF2FAde76b3a,0x71F01e7236EEF0A9072D38Bc4c6b3c42F32e6b1d,0xef07FA176957435b53aa2DF0Ff0E06cF0694CA31,0x211Ef050b4165Eb1F4a3AC7747e4844fCE0Fd3B5,0x8E9FCabA9EA23ADa7631247E1404196F5eB590c9,0x09B7Ee62b2BdD4c8C36F9bbabf746aBe8d1dD5Bc,0x13B46618CE640D79780F3471a77B03478DE9501d,0xB11Ce08416C61303aB6B6D81B91eae93Dd33A5EB,0xe92819cd3586C5675734E4e3DcE8396f535c29bB,0x8c831F68bbeb3F1C733f1FF30fef47e389b18033,0xF831f66E2521420B1529dc60a54B0CB125ecb33C,0x65dABfe189e7d6Bd5dE97EE1a88d3cBEb319a9E3,0x385e029C3360A170057867db5D5Eb5860Eab4522,0x6939E42C497547B8b88F115408b10888442D1446,0x4D7C2D52365dAaD36ff689D482f0E8f576291fca,0xEF4c773Fb8562FB11290f0F01f6c83040965e66E,0x741e50151a7ed552944b15F91ec26D3DF85C824f,0xB88DB7ecF70c9827529953668DC4C7BFA600AE87,0xf08091B21e457d6EaE65aD96e2757827489D9fd4,0x1A7d7D11227f66cA03666932F0b4C57A86D2eD92,0x35584e81e5d012047d4A66eaeD098aBF2adF5eBD,0x6DB7Ad23a5759E8BC9eCcf6Ed7fE24322C90B033,0xFc327E782c823E9E1EbD62C537feF51A89852d36,0xa78D2dFc4B5E8638284516dc946378094F996933
-----Encoded View---------------
56 Constructor Arguments found :
Arg [0] : 00000000000000000000000000000000000000000000000000000000000000e0
Arg [1] : 0000000000000000000000000000000000000000000000000000000000000120
Arg [2] : 00000000000000000000000000000000000000000000000000000000000001f4
Arg [3] : 0000000000000000000000000000000000000000000000000000000061e351f0
Arg [4] : 0000000000000000000000000000000000000000000000000000000000000160
Arg [5] : 00000000000000000000000000000000000000000000000000000000000001c0
Arg [6] : 0000000000000000000000000000000000000000000000000000000000000220
Arg [7] : 000000000000000000000000000000000000000000000000000000000000000f
Arg [8] : 4d6f6f6479204d757368726f6f6d730000000000000000000000000000000000
Arg [9] : 0000000000000000000000000000000000000000000000000000000000000005
Arg [10] : 4d4f4f4459000000000000000000000000000000000000000000000000000000
Arg [11] : 0000000000000000000000000000000000000000000000000000000000000002
Arg [12] : 000000000000000000000000dcabf4fb1d7594eacb014d48e3674857f806f4b2
Arg [13] : 00000000000000000000000056cc222791c8e0d048b6dd42a7d3ef273afe55b2
Arg [14] : 0000000000000000000000000000000000000000000000000000000000000002
Arg [15] : 0000000000000000000000000000000000000000000000000000000000000032
Arg [16] : 0000000000000000000000000000000000000000000000000000000000000032
Arg [17] : 0000000000000000000000000000000000000000000000000000000000000026
Arg [18] : 000000000000000000000000dcabf4fb1d7594eacb014d48e3674857f806f4b2
Arg [19] : 00000000000000000000000056cc222791c8e0d048b6dd42a7d3ef273afe55b2
Arg [20] : 0000000000000000000000006d3b7a9df256b8f1e643b9fb8908a26b55ca99e2
Arg [21] : 000000000000000000000000449afe8e487b2c3297ea0833a1dc3f83af82d91e
Arg [22] : 000000000000000000000000319d3a318f6a99c9b7bcb54a45a61f5c5a3ca31a
Arg [23] : 0000000000000000000000000b49e6a16565344faf35501d79e7420e94b5308d
Arg [24] : 000000000000000000000000c5a933661815633047451ee7ee72b12fab1aff50
Arg [25] : 000000000000000000000000fda3513b35e1890182d61e1d140ba636108d2349
Arg [26] : 00000000000000000000000042e41bc9cfc1dc24aad993b65c2ba7597a33c1c9
Arg [27] : 0000000000000000000000002ca27dfd517e96764295adc935c8e2e26ab4197b
Arg [28] : 000000000000000000000000d614bebb77393923e8f7d9690b3dbce12f412ff4
Arg [29] : 0000000000000000000000008462e8ba9bd29e0ea5cb7989055dde36d6b4948e
Arg [30] : 0000000000000000000000008a46cecd738800123b9049cf4602575b36b22c0a
Arg [31] : 0000000000000000000000009499b6da11777a6993e717a86f3f6f12eceb3d32
Arg [32] : 000000000000000000000000c6b7c8bae695be4eee069d393521bf2fade76b3a
Arg [33] : 00000000000000000000000071f01e7236eef0a9072d38bc4c6b3c42f32e6b1d
Arg [34] : 000000000000000000000000ef07fa176957435b53aa2df0ff0e06cf0694ca31
Arg [35] : 000000000000000000000000211ef050b4165eb1f4a3ac7747e4844fce0fd3b5
Arg [36] : 0000000000000000000000008e9fcaba9ea23ada7631247e1404196f5eb590c9
Arg [37] : 00000000000000000000000009b7ee62b2bdd4c8c36f9bbabf746abe8d1dd5bc
Arg [38] : 00000000000000000000000013b46618ce640d79780f3471a77b03478de9501d
Arg [39] : 000000000000000000000000b11ce08416c61303ab6b6d81b91eae93dd33a5eb
Arg [40] : 000000000000000000000000e92819cd3586c5675734e4e3dce8396f535c29bb
Arg [41] : 0000000000000000000000008c831f68bbeb3f1c733f1ff30fef47e389b18033
Arg [42] : 000000000000000000000000f831f66e2521420b1529dc60a54b0cb125ecb33c
Arg [43] : 00000000000000000000000065dabfe189e7d6bd5de97ee1a88d3cbeb319a9e3
Arg [44] : 000000000000000000000000385e029c3360a170057867db5d5eb5860eab4522
Arg [45] : 0000000000000000000000006939e42c497547b8b88f115408b10888442d1446
Arg [46] : 0000000000000000000000004d7c2d52365daad36ff689d482f0e8f576291fca
Arg [47] : 000000000000000000000000ef4c773fb8562fb11290f0f01f6c83040965e66e
Arg [48] : 000000000000000000000000741e50151a7ed552944b15f91ec26d3df85c824f
Arg [49] : 000000000000000000000000b88db7ecf70c9827529953668dc4c7bfa600ae87
Arg [50] : 000000000000000000000000f08091b21e457d6eae65ad96e2757827489d9fd4
Arg [51] : 0000000000000000000000001a7d7d11227f66ca03666932f0b4c57a86d2ed92
Arg [52] : 00000000000000000000000035584e81e5d012047d4a66eaed098abf2adf5ebd
Arg [53] : 0000000000000000000000006db7ad23a5759e8bc9eccf6ed7fe24322c90b033
Arg [54] : 000000000000000000000000fc327e782c823e9e1ebd62c537fef51a89852d36
Arg [55] : 000000000000000000000000a78d2dfc4b5e8638284516dc946378094f996933
Deployed Bytecode Sourcemap
358:6523:13:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;2668:40:15;2684:12;:10;:12::i;:::-;2668:40;;;-1:-1:-1;;;;;2668:40:15;;;;;2698:9;2668:40;;;;;;;;;;;;;358:6523:13;;;;;2055:123;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;2055:123:13;;:::i;:::-;;1062:150:3;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;1062:150:3;;;;:::i;:::-;;;;;;;;;;;;;;;;;;590:61:13;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;4622:100:4;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;7408:221;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;7408:221:4;;:::i;:::-;;;;-1:-1:-1;;;;;7408:221:4;;;;;;;;;;;;;;6938:404;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;6938:404:4;;;;;;;;:::i;707:135:18:-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;707:135:18;-1:-1:-1;;;;;707:135:18;;:::i;2251:123:13:-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;2251:123:13;;-1:-1:-1;2251:123:13;;-1:-1:-1;;;;;2251:123:13:i;6416:211:4:-;;;;;;;;;;;;;:::i;934:31:13:-;;;;;;;;;;;;;:::i;3874:613:15:-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;3874:613:15;-1:-1:-1;;;;;3874:613:15;;:::i;1173:39:13:-;;;;;;;;;;;;;:::i;8298:305:4:-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;8298:305:4;;;;;;;;;;;;;;;;;:::i;850:143:18:-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;850:143:18;-1:-1:-1;;;;;850:143:18;;:::i;6178:162:4:-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;6178:162:4;;;;;;;;:::i;890:35:13:-;;;;;;;;;;;;;:::i;2866:123::-;;;;;;;;;;;;;:::i;671:62::-;;;;;;;;;;;;;:::i;2799:91:15:-;;;;;;;;;;;;;:::i;1001:112:18:-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;1001:112:18;-1:-1:-1;;;;;1001:112:18;;:::i;8674:151:4:-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;8674:151:4;;;;;;;;;;;;;;;;;:::i;6704:172::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;6704:172:4;;:::i;2382:99:13:-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;2382:99:13;;-1:-1:-1;2382:99:13;;-1:-1:-1;;;;;2382:99:13:i;1121:43::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;1121:43:13;-1:-1:-1;;;;;1121:43:13;;:::i;4378:177:4:-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;4378:177:4;;:::i;5997:97::-;;;;;;;;;;;;;:::i;5280:100:13:-;;;;;;;;;;;;;:::i;4095:221:4:-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;4095:221:4;-1:-1:-1;;;;;4095:221:4;;:::i;1822:148:14:-;;;;;;;;;;;;;:::i;6289:192:13:-;;;;;;;;;;;;;:::i;2489:130::-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;2489:130:13;-1:-1:-1;;;;;2489:130:13;;:::i;3574:100:15:-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;3574:100:15;;:::i;1171:87:14:-;;;;;;;;;;;;;:::i;2625:168:13:-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;2625:168:13;-1:-1:-1;;;;;2625:168:13;;:::i;4791:104:4:-;;;;;;;;;;;;;:::i;3374:109:15:-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;3374:109:15;-1:-1:-1;;;;;3374:109:15;;:::i;7701:295:4:-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;7701:295:4;;;;;;;;;;:::i;3252:1938:13:-;;;;;;;;;;;;;;;;-1:-1:-1;3252:1938:13;;:::i;470:32::-;;;;;;;;;;;;;:::i;8896:285:4:-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;8896:285:4;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;8896:285:4;;-1:-1:-1;8896:285:4;;-1:-1:-1;;;;;8896:285:4:i;806:34:13:-;;;;;;;;;;;;;:::i;4966:792:4:-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;4966:792:4;;:::i;553:28:13:-;;;;;;;;;;;;;:::i;3170:105:15:-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;3170:105:15;-1:-1:-1;;;;;3170:105:15;;:::i;1740:222:13:-;;;;;;;;;;;;;:::i;2984:95:15:-;;;;;;;;;;;;;:::i;511:33:13:-;;;;;;;;;;;;;:::i;8067:164:4:-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;8067:164:4;;;;;;;;;;:::i;5454:698:13:-;;;;;;;;;;;;;:::i;849:32::-;;;;;;;;;;;;;:::i;753:44::-;;;;;;;;;;;;;:::i;3067:129::-;;;;;;;;;;;;;:::i;2125:244:14:-;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;2125:244:14;-1:-1:-1;;;;;2125:244:14;;:::i;669:106:1:-;757:10;669:106;:::o;2055:123:13:-;1402:12:14;:10;:12::i;:::-;-1:-1:-1;;;;;1391:23:14;:7;:5;:7::i;:::-;-1:-1:-1;;;;;1391:23:14;;1383:68;;;;;-1:-1:-1;;;1383:68:14;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;1383:68:14;;;;;;;;;;;;;;;2136:16:13::1;:34:::0;2055:123::o;1062:150:3:-;1171:33;;;1147:4;1171:33;;;;;;;;;;;;;1062:150;;;;:::o;590:61:13:-;634:17;590:61;:::o;4622:100:4:-;4709:5;4702:12;;;;;;;;-1:-1:-1;;4702:12:4;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4676:13;;4702:12;;4709:5;;4702:12;;4709:5;4702:12;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4622:100;:::o;7408:221::-;7484:7;7512:16;7520:7;7512;:16::i;:::-;7504:73;;;;-1:-1:-1;;;7504:73:4;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;7597:24:4;;;;:15;:24;;;;;;-1:-1:-1;;;;;7597:24:4;;7408:221::o;6938:404::-;7019:13;7035:23;7050:7;7035:14;:23::i;:::-;7019:39;;7083:5;-1:-1:-1;;;;;7077:11:4;:2;-1:-1:-1;;;;;7077:11:4;;;7069:57;;;;-1:-1:-1;;;7069:57:4;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;7163:5;-1:-1:-1;;;;;7147:21:4;:12;:10;:12::i;:::-;-1:-1:-1;;;;;7147:21:4;;:69;;;;7172:44;7196:5;7203:12;:10;:12::i;:::-;7172:23;:44::i;:::-;7139:161;;;;-1:-1:-1;;;7139:161:4;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;7313:21;7322:2;7326:7;7313:8;:21::i;:::-;6938:404;;;:::o;707:135:18:-;1402:12:14;:10;:12::i;:::-;-1:-1:-1;;;;;1391:23:14;:7;:5;:7::i;:::-;-1:-1:-1;;;;;1391:23:14;;1383:68;;;;;-1:-1:-1;;;1383:68:14;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;1383:68:14;;;;;;;;;;;;;;;-1:-1:-1;;;;;766:19:18;::::1;;::::0;;;:9:::1;:19;::::0;;;;;:26;;-1:-1:-1;;766:26:18::1;788:4;766:26;::::0;;808;::::1;::::0;766:19;808:26:::1;707:135:::0;:::o;2251:123:13:-;1402:12:14;:10;:12::i;:::-;-1:-1:-1;;;;;1391:23:14;:7;:5;:7::i;:::-;-1:-1:-1;;;;;1391:23:14;;1383:68;;;;;-1:-1:-1;;;1383:68:14;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;1383:68:14;;;;;;;;;;;;;;;2336:30:13;;::::1;::::0;:13:::1;::::0;:30:::1;::::0;::::1;::::0;::::1;:::i;:::-;;2251:123:::0;:::o;6416:211:4:-;6477:7;6598:21;:12;:19;:21::i;:::-;6591:28;;6416:211;:::o;934:31:13:-;;;;:::o;3874:613:15:-;-1:-1:-1;;;;;3950:16:15;;3969:1;3950:16;;;:7;:16;;;;;;3942:71;;;;-1:-1:-1;;;3942:71:15;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4074:14;;-1:-1:-1;;;;;4169:18:15;;4026:21;4169:18;;;:9;:18;;;;;;;;;4154:12;;4134:7;:16;;;;;;;4050:21;:38;;;;4169:18;;4154:12;4118:32;;4154:12;4117:49;;;;;:70;;-1:-1:-1;4208:12:15;4200:68;;;;-1:-1:-1;;;4200:68:15;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;4302:18:15;;;;;;:9;:18;;;;;;;:28;;4281:49;;4358:14;;;:24;;4341:41;;4395:35;4312:7;4323;4395:17;:35::i;:::-;4446:33;;;-1:-1:-1;;;;;4446:33:15;;;;;;;;;;;;;;;;;;;;;;;3874:613;;;:::o;1173:39:13:-;;;-1:-1:-1;;;;;1173:39:13;;:::o;8298:305:4:-;8459:41;8478:12;:10;:12::i;:::-;8492:7;8459:18;:41::i;:::-;8451:103;;;;-1:-1:-1;;;8451:103:4;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8567:28;8577:4;8583:2;8587:7;8567:9;:28::i;850:143:18:-;1402:12:14;:10;:12::i;:::-;-1:-1:-1;;;;;1391:23:14;:7;:5;:7::i;:::-;-1:-1:-1;;;;;1391:23:14;;1383:68;;;;;-1:-1:-1;;;1383:68:14;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;1383:68:14;;;;;;;;;;;;;;;-1:-1:-1;;;;;912:19:18;::::1;934:5;912:19:::0;;;:9:::1;:19;::::0;;;;;:27;;-1:-1:-1;;912:27:18::1;::::0;;955:30;::::1;::::0;934:5;955:30:::1;850:143:::0;:::o;6178:162:4:-;-1:-1:-1;;;;;6302:20:4;;6275:7;6302:20;;;:13;:20;;;;;:30;;6326:5;6302:23;:30::i;:::-;6295:37;;6178:162;;;;;:::o;890:35:13:-;;;;;;;;;:::o;2866:123::-;1402:12:14;:10;:12::i;:::-;-1:-1:-1;;;;;1391:23:14;:7;:5;:7::i;:::-;-1:-1:-1;;;;;1391:23:14;;1383:68;;;;;-1:-1:-1;;;1383:68:14;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;1383:68:14;;;;;;;;;;;;;;;2919:15:13::1;:23:::0;;-1:-1:-1;;2953:28:13;;2919:23:::1;2969:12:::0;;;2968:13:::1;2953:28;::::0;;2866:123::o;671:62::-;716:17;671:62;:::o;2799:91:15:-;2870:12;;2799:91;:::o;1001:112:18:-;-1:-1:-1;;;;;1086:19:18;1062:4;1086:19;;;:9;:19;;;;;;;;;1001:112::o;8674:151:4:-;8778:39;8795:4;8801:2;8805:7;8778:39;;;;;;;;;;;;:16;:39::i;6704:172::-;6779:7;;6821:22;:12;6837:5;6821:15;:22::i;:::-;-1:-1:-1;6799:44:4;6704:172;-1:-1:-1;;;6704:172:4:o;2382:99:13:-;1402:12:14;:10;:12::i;:::-;-1:-1:-1;;;;;1391:23:14;:7;:5;:7::i;:::-;-1:-1:-1;;;;;1391:23:14;;1383:68;;;;;-1:-1:-1;;;1383:68:14;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;1383:68:14;;;;;;;;;;;;;;;2453:20:13::1;2465:7;2453:11;:20::i;:::-;2382:99:::0;:::o;1121:43::-;;;;;;;;;;;;;:::o;4378:177:4:-;4450:7;4477:70;4494:7;4477:70;;;;;;;;;;;;;;;;;:12;;:70;:16;:70::i;5997:97::-;6078:8;6071:15;;;;;;;;-1:-1:-1;;6071:15:4;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6045:13;;6071:15;;6078:8;;6071:15;;6078:8;6071:15;;;;;;;;;;;;;;;;;;;;;;;;5280:100:13;5325:7;5350:22;:12;:20;:22::i;4095:221:4:-;4167:7;-1:-1:-1;;;;;4195:19:4;;4187:74;;;;-1:-1:-1;;;4187:74:4;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;4279:20:4;;;;;;:13;:20;;;;;:29;;:27;:29::i;1822:148:14:-;1402:12;:10;:12::i;:::-;-1:-1:-1;;;;;1391:23:14;:7;:5;:7::i;:::-;-1:-1:-1;;;;;1391:23:14;;1383:68;;;;;-1:-1:-1;;;1383:68:14;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;1383:68:14;;;;;;;;;;;;;;;1913:6:::1;::::0;1892:40:::1;::::0;1929:1:::1;::::0;-1:-1:-1;;;;;1913:6:14::1;::::0;1892:40:::1;::::0;1929:1;;1892:40:::1;1943:6;:19:::0;;-1:-1:-1;;1943:19:14::1;::::0;;1822:148::o;6289:192:13:-;1402:12:14;:10;:12::i;:::-;-1:-1:-1;;;;;1391:23:14;:7;:5;:7::i;:::-;-1:-1:-1;;;;;1391:23:14;;1383:68;;;;;-1:-1:-1;;;1383:68:14;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;1383:68:14;;;;;;;;;;;;;;;6367:13:13::1;::::0;:18;6359:60:::1;;;::::0;;-1:-1:-1;;;6359:60:13;;::::1;;::::0;::::1;::::0;::::1;::::0;;;;::::1;::::0;;;;;;;;;;;;;::::1;;6461:12;6440:18;:33:::0;6289:192::o;2489:130::-;1402:12:14;:10;:12::i;:::-;-1:-1:-1;;;;;1391:23:14;:7;:5;:7::i;:::-;-1:-1:-1;;;;;1391:23:14;;1383:68;;;;;-1:-1:-1;;;1383:68:14;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;1383:68:14;;;;;;;;;;;;;;;2563:14:13::1;:48:::0;;-1:-1:-1;;2563:48:13::1;-1:-1:-1::0;;;;;2563:48:13;;;::::1;::::0;;;::::1;::::0;;2489:130::o;3574:100:15:-;3625:7;3652;3660:5;3652:14;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;3652:14:15;;3574:100;-1:-1:-1;;3574:100:15:o;1171:87:14:-;1244:6;;-1:-1:-1;;;;;1244:6:14;1171:87;:::o;2625:168:13:-;2700:14;;:34;;;;;;-1:-1:-1;;;;;2700:34:13;;;;;;;;;2680:4;;;;2700:14;;:24;;:34;;;;;;;;;;;;;;:14;:34;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;2700:34:13;:36;2697:65;;;-1:-1:-1;2758:4:13;2751:11;;2697:65;-1:-1:-1;2780:5:13;2625:168;;;:::o;4791:104:4:-;4880:7;4873:14;;;;;;;;-1:-1:-1;;4873:14:4;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4847:13;;4873:14;;4880:7;;4873:14;;4880:7;4873:14;;;;;;;;;;;;;;;;;;;;;;;;3374:109:15;-1:-1:-1;;;;;3457:18:15;3430:7;3457:18;;;:9;:18;;;;;;;3374:109::o;7701:295:4:-;7816:12;:10;:12::i;:::-;-1:-1:-1;;;;;7804:24:4;:8;-1:-1:-1;;;;;7804:24:4;;;7796:62;;;;;-1:-1:-1;;;7796:62:4;;;;;;;;;;;;;;;;;;;;;;;;;;;;7916:8;7871:18;:32;7890:12;:10;:12::i;:::-;-1:-1:-1;;;;;7871:32:4;;;;;;;;;;;;;;;;;-1:-1:-1;7871:32:4;;;:42;;;;;;;;;;;;:53;;-1:-1:-1;;7871:53:4;;;;;;;;;;;7955:12;:10;:12::i;:::-;-1:-1:-1;;;;;7940:48:4;;7979:8;7940:48;;;;;;;;;;;;;;;;;;;;7701:295;;:::o;3252:1938:13:-;3329:12;;;;;:31;;-1:-1:-1;3345:15:13;;;;;;;3329:31;3321:87;;;;-1:-1:-1;;;3321:87:13;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;3422:15;;;;;;;:32;;;;-1:-1:-1;3442:12:13;;;;3441:13;3422:32;3419:330;;;3478:19;3486:10;3478:7;:19::i;:::-;:48;;;;3501:25;3515:10;3501:13;:25::i;:::-;3470:123;;;;-1:-1:-1;;;3470:123:13;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;3662:19;;3616:42;3643:14;3616:22;:12;:20;:22::i;:::-;:26;;:42::i;:::-;:65;;3608:129;;;;-1:-1:-1;;;3608:129:13;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;796:1;3767:14;:37;;3759:91;;;;-1:-1:-1;;;3759:91:13;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;3898:10;3889:20;;;;:8;:20;;;;;:31;796:1;;3870:51;;:14;;:18;:51::i;:::-;3869:76;;3861:135;;;;-1:-1:-1;;;3861:135:13;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4061:19;;4015:42;4042:14;4015:22;:12;:20;:22::i;:42::-;:65;;4007:129;;;;-1:-1:-1;;;4007:129:13;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4160:19;4168:10;4160:7;:19::i;:::-;4157:255;;;4244:9;4202:38;716:17;4225:14;4202:22;:38::i;:::-;:51;;4194:95;;;;;-1:-1:-1;;;4194:95:13;;;;;;;;;;;;;;;;;;;;;;;;;;;;4157:255;;;4367:9;4326:37;634:17;4348:14;4326:21;:37::i;:::-;:50;;4318:94;;;;;-1:-1:-1;;;4318:94:13;;;;;;;;;;;;;;;;;;;;;;;;;;;;4434:22;4445:10;4434;:22::i;:::-;4433:23;4425:56;;;;;-1:-1:-1;;;4425:56:13;;;;;;;;;;;;;;;;;;;;;;;;;;;;4506:6;4502:293;4522:14;4518:1;:18;4502:293;;;4588:19;;4562:22;:12;:20;:22::i;:::-;:45;4558:226;;4637:10;4628:20;;;;:8;:20;;;;;:33;;;;;;4680:24;:12;:22;:24::i;:::-;4723:45;4733:10;4745:22;:12;:20;:22::i;:::-;4723:9;:45::i;:::-;4538:3;;4502:293;;;-1:-1:-1;5007:18:13;;:23;:113;;;;;5061:19;;5035:22;:12;:20;:22::i;:::-;:45;:84;;;;5103:16;;5084:15;:35;;5035:84;5003:179;;;5158:12;5137:18;:33;3252:1938;:::o;470:32::-;;;;;;;;;;;;;;;-1:-1:-1;;470:32:13;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::o;8896:285:4:-;9028:41;9047:12;:10;:12::i;:::-;9061:7;9028:18;:41::i;:::-;9020:103;;;;-1:-1:-1;;;9020:103:4;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;9134:39;9148:4;9154:2;9158:7;9167:5;9134:13;:39::i;:::-;8896:285;;;;:::o;806:34:13:-;;;;:::o;4966:792:4:-;5039:13;5073:16;5081:7;5073;:16::i;:::-;5065:76;;;;-1:-1:-1;;;5065:76:4;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;5180:19;;;;:10;:19;;;;;;;;;5154:45;;;;;;-1:-1:-1;;5154:45:4;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:23;;:45;;;5180:19;5154:45;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;5210:18;5231:9;:7;:9::i;:::-;5210:30;;5322:4;5316:18;5338:1;5316:23;5312:72;;;-1:-1:-1;5363:9:4;-1:-1:-1;5356:16:4;;5312:72;5488:23;;:27;5484:108;;5563:4;5569:9;5546:33;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;5546:33:4;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;5546:33:4;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;5546:33:4;;;;;;;;;;;;;-1:-1:-1;;5546:33:4;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;5532:48;;;;;;5484:108;5724:4;5730:18;:7;:16;:18::i;:::-;5707:42;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;5707:42:4;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;5707:42:4;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;5707:42:4;;;;;;;;;;;;;-1:-1:-1;;5707:42:4;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;5693:57;;;;4966:792;;;:::o;553:28:13:-;;;;:::o;3170:105:15:-;-1:-1:-1;;;;;3251:16:15;3224:7;3251:16;;;:7;:16;;;;;;;3170:105::o;1740:222:13:-;1402:12:14;:10;:12::i;:::-;-1:-1:-1;;;;;1391:23:14;:7;:5;:7::i;:::-;-1:-1:-1;;;;;1391:23:14;;1383:68;;;;;-1:-1:-1;;;1383:68:14;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;1383:68:14;;;;;;;;;;;;;;;1804:11:13::1;1818:22;:12;:20;:22::i;:::-;1841:1;1818:24;1804:38;;1853:6;1870:85;1886:2;1882:1;:6;1870:85;;;1910:33;1920:10;1941:1;1932:6;:10;1910:9;:33::i;:::-;1890:3;;1870:85;;2984:95:15::0;3057:14;;2984:95;:::o;511:33:13:-;;;;:::o;8067:164:4:-;-1:-1:-1;;;;;8188:25:4;;;8164:4;8188:25;;;:18;:25;;;;;;;;:35;;;;;;;;;;;;;;;8067:164::o;5454:698:13:-;5508:13;;:18;5500:60;;;;;-1:-1:-1;;;5500:60:13;;;;;;;;;;;;;;;;;;;;;;;;;;;;5579:18;;5571:68;;;;;-1:-1:-1;;;5571:68:13;;;;;;;;;;;;;;;;;;;;;;;;;;;;;5714:19;;5691:18;;5681:29;5714:19;5676:57;;;;;5660:13;:73;5886:18;;5908:3;;5869:36;;:12;;:16;:36::i;:::-;:42;5865:146;;;5980:19;;-1:-1:-1;;5959:12:13;:16;5949:27;5980:19;5944:55;;;;;5928:13;:71;5865:146;6062:13;;6058:87;;6113:13;;:20;;6131:1;6113:17;:20::i;:::-;6097:13;:36;6058:87;5454:698::o;849:32::-;;;;;;:::o;753:44::-;796:1;753:44;:::o;3067:129::-;1402:12:14;:10;:12::i;:::-;-1:-1:-1;;;;;1391:23:14;:7;:5;:7::i;:::-;-1:-1:-1;;;;;1391:23:14;;1383:68;;;;;-1:-1:-1;;;1383:68:14;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;1383:68:14;;;;;;;;;;;;;;;3123:12:13::1;:20:::0;;::::1;-1:-1:-1::0;;3123:20:13;::::1;3173:15:::0;;::::1;3123:20;3173:15;3172:16;3154:34;-1:-1:-1::0;;3154:34:13;;;::::1;::::0;;3067:129::o;2125:244:14:-;1402:12;:10;:12::i;:::-;-1:-1:-1;;;;;1391:23:14;:7;:5;:7::i;:::-;-1:-1:-1;;;;;1391:23:14;;1383:68;;;;;-1:-1:-1;;;1383:68:14;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;1383:68:14;;;;;;;;;;;;;;;-1:-1:-1;;;;;2214:22:14;::::1;2206:73;;;;-1:-1:-1::0;;;2206:73:14::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;2316:6;::::0;2295:38:::1;::::0;-1:-1:-1;;;;;2295:38:14;;::::1;::::0;2316:6:::1;::::0;2295:38:::1;::::0;2316:6:::1;::::0;2295:38:::1;2344:6;:17:::0;;-1:-1:-1;;2344:17:14::1;-1:-1:-1::0;;;;;2344:17:14;;;::::1;::::0;;;::::1;::::0;;2125:244::o;10648:127:4:-;10713:4;10737:30;:12;10759:7;10737:21;:30::i;16666:192::-;16741:24;;;;:15;:24;;;;;:29;;-1:-1:-1;;16741:29:4;-1:-1:-1;;;;;16741:29:4;;;;;;;;:24;;16795:23;16741:24;16795:14;:23::i;:::-;-1:-1:-1;;;;;16786:46:4;;;;;;;;;;;16666:192;;:::o;8098:123:5:-;8167:7;8194:19;8202:3;8194:7;:19::i;2164:397:0:-;2279:6;2254:21;:31;;2246:73;;;;;-1:-1:-1;;;2246:73:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;2429:35;;2411:12;;-1:-1:-1;;;;;2429:14:0;;;2452:6;;2411:12;2429:35;2411:12;2429:35;2452:6;2429:14;:35;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;2410:54;;;2483:7;2475:78;;;;-1:-1:-1;;;2475:78:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;10942:355:4;11035:4;11060:16;11068:7;11060;:16::i;:::-;11052:73;;;;-1:-1:-1;;;11052:73:4;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;11136:13;11152:23;11167:7;11152:14;:23::i;:::-;11136:39;;11205:5;-1:-1:-1;;;;;11194:16:4;:7;-1:-1:-1;;;;;11194:16:4;;:51;;;;11238:7;-1:-1:-1;;;;;11214:31:4;:20;11226:7;11214:11;:20::i;:::-;-1:-1:-1;;;;;11214:31:4;;11194:51;:94;;;;11249:39;11273:5;11280:7;11249:23;:39::i;:::-;11186:103;10942:355;-1:-1:-1;;;;10942:355:4:o;14078:599::-;14203:4;-1:-1:-1;;;;;14176:31:4;:23;14191:7;14176:14;:23::i;:::-;-1:-1:-1;;;;;14176:31:4;;14168:85;;;;-1:-1:-1;;;14168:85:4;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;14290:16:4;;14282:65;;;;-1:-1:-1;;;14282:65:4;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;14360:39;14381:4;14387:2;14391:7;14360:20;:39::i;:::-;14464:29;14481:1;14485:7;14464:8;:29::i;:::-;-1:-1:-1;;;;;14506:19:4;;;;;;:13;:19;;;;;:35;;14533:7;14506:26;:35::i;:::-;-1:-1:-1;;;;;;14552:17:4;;;;;;:13;:17;;;;;:30;;14574:7;14552:21;:30::i;:::-;-1:-1:-1;14595:29:4;:12;14612:7;14621:2;14595:16;:29::i;:::-;;14661:7;14657:2;-1:-1:-1;;;;;14642:27:4;14651:4;-1:-1:-1;;;;;14642:27:4;;;;;;;;;;;14078:599;;;:::o;9605:137:6:-;9676:7;9711:22;9715:3;9727:5;9711:3;:22::i;8560:236:5:-;8640:7;;;;8700:22;8704:3;8716:5;8700:3;:22::i;:::-;8669:53;;;;-1:-1:-1;8560:236:5;-1:-1:-1;;;;;8560:236:5:o;15278:100:4:-;15351:19;;;;:8;;:19;;;;;:::i;9846:213:5:-;9953:7;10004:44;10009:3;10029;10035:12;10004:4;:44::i;:::-;9996:53;-1:-1:-1;9846:213:5;;;;;;:::o;909:114:2:-;1001:14;;909:114::o;2830:179:16:-;2888:7;2920:5;;;2944:6;;;;2936:46;;;;;-1:-1:-1;;;2936:46:16;;;;;;;;;;;;;;;;;;;;;;;;;;;3709:220;3767:7;3791:6;3787:20;;-1:-1:-1;3806:1:16;3799:8;;3787:20;3830:5;;;3834:1;3830;:5;:1;3854:5;;;;;:10;3846:56;;;;-1:-1:-1;;;3846:56:16;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6487:391:13;6812:20;6862:8;;;6487:391::o;1031:120:2:-;1112:14;;:21;;1131:1;1112:18;:21::i;:::-;1095:38;;1031:120::o;11640:110:4:-;11716:26;11726:2;11730:7;11716:26;;;;;;;;;;;;:9;:26::i;10063:272::-;10177:28;10187:4;10193:2;10197:7;10177:9;:28::i;:::-;10224:48;10247:4;10253:2;10257:7;10266:5;10224:22;:48::i;:::-;10216:111;;;;-1:-1:-1;;;10216:111:4;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;277:746:17;333:13;554:10;550:53;;-1:-1:-1;581:10:17;;;;;;;;;;;;;;;;;;;550:53;628:5;613:12;669:78;676:9;;669:78;;702:8;;733:2;725:10;;;;669:78;;;757:19;789:6;779:17;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;779:17:17;-1:-1:-1;851:5:17;;-1:-1:-1;757:39:17;-1:-1:-1;;;823:10:17;;867:117;874:9;;867:117;;943:2;936:4;:9;931:2;:14;918:29;;900:6;907:7;;;;;;;900:15;;;;;;;;;;;:47;;;;;;;;;;-1:-1:-1;970:2:17;962:10;;;;867:117;;;-1:-1:-1;1008:6:17;277:746;-1:-1:-1;;;;277:746:17:o;3292:158:16:-;3350:7;3383:1;3378;:6;;3370:49;;;;;-1:-1:-1;;;3370:49:16;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;3437:5:16;;;3292:158::o;7859:151:5:-;7943:4;7967:35;7977:3;7997;7967:9;:35::i;8692:137:6:-;8762:4;8786:35;8794:3;8814:5;8786:7;:35::i;8385:131::-;8452:4;8476:32;8481:3;8501:5;8476:4;:32::i;7282:185:5:-;7371:4;7395:64;7400:3;7420;-1:-1:-1;;;;;7434:23:5;;7395:4;:64::i;4643:204:6:-;4738:18;;4710:7;;4738:26;-1:-1:-1;4730:73:6;;;;-1:-1:-1;;;4730:73:6;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4821:3;:11;;4833:5;4821:18;;;;;;;;;;;;;;;;4814:25;;4643:204;;;;:::o;5142:279:5:-;5246:19;;5209:7;;;;5246:27;-1:-1:-1;5238:74:5;;;;-1:-1:-1;;;5238:74:5;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;5325:22;5350:3;:12;;5363:5;5350:19;;;;;;;;;;;;;;;;;;5325:44;;5388:5;:10;;;5400:5;:12;;;5380:33;;;;;5142:279;;;;;:::o;6639:319::-;6733:7;6772:17;;;:12;;;:17;;;;;;6823:12;6808:13;6800:36;;;;-1:-1:-1;;;6800:36:5;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;6890:3;:12;;6914:1;6903:8;:12;6890:26;;;;;;;;;;;;;;;;;;:33;;;6883:40;;;6639:319;;;;;:::o;11977:250:4:-;12073:18;12079:2;12083:7;12073:5;:18::i;:::-;12110:54;12141:1;12145:2;12149:7;12158:5;12110:22;:54::i;:::-;12102:117;;;;-1:-1:-1;;;12102:117:4;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;15943:604;16064:4;16091:15;:2;-1:-1:-1;;;;;16091:13:4;;:15::i;:::-;16086:60;;-1:-1:-1;16130:4:4;16123:11;;16086:60;16156:23;16182:252;-1:-1:-1;;;16295:12:4;:10;:12::i;:::-;16322:4;16341:7;16363:5;16198:181;;;;;;-1:-1:-1;;;;;16198:181:4;;;;;;-1:-1:-1;;;;;16198:181:4;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;16182:252;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;16182:15:4;;;:252;:15;:252::i;:::-;16156:278;;16445:13;16472:10;16461:32;;;;;;;;;;;;;;;-1:-1:-1;16461:32:4;16512:26;;-1:-1:-1;;;16512:26:4;;-1:-1:-1;;;15943:604:4;;;;;;:::o;4457:125:5:-;4528:4;4552:17;;;:12;;;;;:17;;;;;;:22;;;4457:125::o;2345:1544:6:-;2411:4;2550:19;;;:12;;;:19;;;;;;2586:15;;2582:1300;;3021:18;;-1:-1:-1;;2972:14:6;;;;3021:22;;;;2948:21;;3021:3;;:22;;3308;;;;;;;;;;;;;;3288:42;;3454:9;3425:3;:11;;3437:13;3425:26;;;;;;;;;;;;;;;;;;;:38;;;;3531:23;;;3573:1;3531:12;;;:23;;;;;;3557:17;;;3531:43;;3683:17;;3531:3;;3683:17;;;;;;;;;;;;;;;;;;;;;;3778:3;:12;;:19;3791:5;3778:19;;;;;;;;;;;3771:26;;;3821:4;3814:11;;;;;;;;2582:1300;3865:5;3858:12;;;;;1755:414;1818:4;1840:21;1850:3;1855:5;1840:9;:21::i;:::-;1835:327;;-1:-1:-1;1878:23:6;;;;;;;;:11;:23;;;;;;;;;;;;;2061:18;;2039:19;;;:12;;;:19;;;;;;:40;;;;2094:11;;1835:327;-1:-1:-1;2145:5:6;2138:12;;1957:692:5;2033:4;2168:17;;;:12;;;:17;;;;;;2202:13;2198:444;;-1:-1:-1;;2287:38:5;;;;;;;;;;;;;;;;;;2269:57;;;;;;;;:12;:57;;;;;;;;;;;;;;;;;;;;;;;;2484:19;;2464:17;;;:12;;;:17;;;;;;;:39;2518:11;;2198:444;2598:5;2562:3;:12;;2586:1;2575:8;:12;2562:26;;;;;;;;;;;;;;;;;;:33;;:41;;;;2625:5;2618:12;;;;;12563:404:4;-1:-1:-1;;;;;12643:16:4;;12635:61;;;;;-1:-1:-1;;;12635:61:4;;;;;;;;;;;;;;;;;;;;;;;;;;;;;12716:16;12724:7;12716;:16::i;:::-;12715:17;12707:58;;;;;-1:-1:-1;;;12707:58:4;;;;;;;;;;;;;;;;;;;;;;;;;;;;12778:45;12807:1;12811:2;12815:7;12778:20;:45::i;:::-;-1:-1:-1;;;;;12836:17:4;;;;;;:13;:17;;;;;:30;;12858:7;12836:21;:30::i;:::-;-1:-1:-1;12879:29:4;:12;12896:7;12905:2;12879:16;:29::i;:::-;-1:-1:-1;12926:33:4;;12951:7;;-1:-1:-1;;;;;12926:33:4;;;12943:1;;12926:33;;12943:1;;12926:33;12563:404;;:::o;3725:195:0:-;3828:12;3860:52;3882:6;3890:4;3896:1;3899:12;3828;5029:18;5040:6;5029:10;:18::i;:::-;5021:60;;;;;-1:-1:-1;;;5021:60:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;5155:12;5169:23;5196:6;-1:-1:-1;;;;;5196:11:0;5216:5;5224:4;5196:33;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;5196:33:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;5154:75;;;;5247:52;5265:7;5274:10;5286:12;5247:17;:52::i;:::-;5240:59;4777:530;-1:-1:-1;;;;;;;4777:530:0:o;7317:742::-;7432:12;7461:7;7457:595;;;-1:-1:-1;7492:10:0;7485:17;;7457:595;7606:17;;:21;7602:439;;7869:10;7863:17;7930:15;7917:10;7913:2;7909:19;7902:44;7817:148;8005:20;;-1:-1:-1;;;8005:20:0;;;;;;;;;;;;;;;;;8012:12;;8005:20;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;:::o;:::-;;;;;;;;;;;;;;
Swarm Source
ipfs://563cc61c3d2d49cf35d60cc0f52adb9c9e9a2568682c2013f5b9d2c1e49f7b7a
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.