ERC-1155
Overview
Max Total Supply
38 3W
Holders
27
Market
Volume (24H)
N/A
Min Price (24H)
N/A
Max Price (24H)
N/A
Other Info
Token Contract
Loading...
Loading
Loading...
Loading
Loading...
Loading
# | Exchange | Pair | Price | 24H Volume | % Volume |
---|
Contract Name:
X3WxxRldRoot0Contract
Compiler Version
v0.8.9+commit.e5eed63a
Contract Source Code (Solidity)
/** *Submitted for verification at Etherscan.io on 2022-11-18 */ //*********************************************************************// //*********************************************************************// // // Bridge building - 3WxxRLD // //*********************************************************************// //*********************************************************************// //-------------DEPENDENCIES--------------------------// // File: @openzeppelin/contracts/utils/Context.sol // OpenZeppelin Contracts v4.4.1 (utils/Context.sol) pragma solidity ^0.8.0; /** * @dev Provides information about the current execution context, including the * sender of the transaction and its data. While these are generally available * via msg.sender and msg.data, they should not be accessed in such a direct * manner, since when dealing with meta-transactions the account sending and * paying for execution may not be the actual sender (as far as an application * is concerned). * * This contract is only required for intermediate, library-like contracts. */ abstract contract Context { function _msgSender() internal view virtual returns (address) { return msg.sender; } function _msgData() internal view virtual returns (bytes calldata) { return msg.data; } } // File: @openzeppelin/contracts/security/Pausable.sol // OpenZeppelin Contracts v4.4.1 (security/Pausable.sol) pragma solidity ^0.8.0; /** * @dev Contract module which allows children to implement an emergency stop * mechanism that can be triggered by an authorized account. * * This module is used through inheritance. It will make available the * modifiers whenNotPaused and whenPaused, which can be applied to * the functions of your contract. Note that they will not be pausable by * simply including this module, only once the modifiers are put in place. */ abstract contract Pausable is Context { /** * @dev Emitted when the pause is triggered by account. */ event Paused(address account); /** * @dev Emitted when the pause is lifted by account. */ event Unpaused(address account); bool private _paused; /** * @dev Initializes the contract in unpaused state. */ constructor() { _paused = false; } /** * @dev Returns true if the contract is paused, and false otherwise. */ function paused() public view virtual returns (bool) { return _paused; } /** * @dev Modifier to make a function callable only when the contract is not paused. * * Requirements: * * - The contract must not be paused. */ modifier whenNotPaused() { require(!paused(), "Pausable: paused"); _; } /** * @dev Modifier to make a function callable only when the contract is paused. * * Requirements: * * - The contract must be paused. */ modifier whenPaused() { require(paused(), "Pausable: not paused"); _; } /** * @dev Triggers stopped state. * * Requirements: * * - The contract must not be paused. */ function _pause() internal virtual whenNotPaused { _paused = true; emit Paused(_msgSender()); } /** * @dev Returns to normal state. * * Requirements: * * - The contract must be paused. */ function _unpause() internal virtual whenPaused { _paused = false; emit Unpaused(_msgSender()); } } // File: @openzeppelin/contracts/access/Ownable.sol // OpenZeppelin Contracts v4.4.1 (access/Ownable.sol) pragma solidity ^0.8.0; /** * @dev Contract module which provides a basic access control mechanism, where * there is an account (an owner) that can be granted exclusive access to * specific functions. * * By default, the owner account will be the one that deploys the contract. This * can later be changed with {transferOwnership}. * * This module is used through inheritance. It will make available the modifier * onlyOwner, which can be applied to your functions to restrict their use to * the owner. */ abstract contract Ownable is Context { address private _owner; event OwnershipTransferred(address indexed previousOwner, address indexed newOwner); /** * @dev Initializes the contract setting the deployer as the initial owner. */ constructor() { _transferOwnership(_msgSender()); } /** * @dev Returns the address of the current owner. */ function owner() public view virtual returns (address) { return _owner; } /** * @dev Throws if called by any account other than the owner. */ modifier onlyOwner() { require(owner() == _msgSender(), "Ownable: caller is not the owner"); _; } /** * @dev Leaves the contract without owner. It will not be possible to call * onlyOwner functions anymore. Can only be called by the current owner. * * NOTE: Renouncing ownership will leave the contract without an owner, * thereby removing any functionality that is only available to the owner. */ function renounceOwnership() public virtual onlyOwner { _transferOwnership(address(0)); } /** * @dev Transfers ownership of the contract to a new account (newOwner). * Can only be called by the current owner. */ function transferOwnership(address newOwner) public virtual onlyOwner { require(newOwner != address(0), "Ownable: new owner is the zero address"); _transferOwnership(newOwner); } /** * @dev Transfers ownership of the contract to a new account (newOwner). * Internal function without access restriction. */ function _transferOwnership(address newOwner) internal virtual { address oldOwner = _owner; _owner = newOwner; emit OwnershipTransferred(oldOwner, newOwner); } } // File: @openzeppelin/contracts/utils/Address.sol // OpenZeppelin Contracts v4.4.1 (utils/Address.sol) pragma solidity ^0.8.0; /** * @dev Collection of functions related to the address type */ library Address { /** * @dev Returns true if account is a contract. * * [IMPORTANT] * ==== * It is unsafe to assume that an address for which this function returns * false is an externally-owned account (EOA) and not a contract. * * Among others, isContract will return false for the following * types of addresses: * * - an externally-owned account * - a contract in construction * - an address where a contract will be created * - an address where a contract lived, but was destroyed * ==== */ function isContract(address account) internal view returns (bool) { // This method relies on extcodesize, which returns 0 for contracts in // construction, since the code is only stored at the end of the // constructor execution. uint256 size; assembly { size := extcodesize(account) } return size > 0; } /** * @dev Replacement for Solidity's transfer: sends amount wei to * recipient, forwarding all available gas and reverting on errors. * * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost * of certain opcodes, possibly making contracts go over the 2300 gas limit * imposed by transfer, making them unable to receive funds via * transfer. {sendValue} removes this limitation. * * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more]. * * IMPORTANT: because control is transferred to recipient, care must be * taken to not create reentrancy vulnerabilities. Consider using * {ReentrancyGuard} or the * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern]. */ function sendValue(address payable recipient, uint256 amount) internal { require(address(this).balance >= amount, "Address: insufficient balance"); (bool success, ) = recipient.call{value: amount}(""); require(success, "Address: unable to send value, recipient may have reverted"); } /** * @dev Performs a Solidity function call using a low level call. A * plain call is an unsafe replacement for a function call: use this * function instead. * * If target reverts with a revert reason, it is bubbled up by this * function (like regular Solidity function calls). * * Returns the raw returned data. To convert to the expected return value, * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[abi.decode]. * * Requirements: * * - target must be a contract. * - calling target with data must not revert. * * _Available since v3.1._ */ function functionCall(address target, bytes memory data) internal returns (bytes memory) { return functionCall(target, data, "Address: low-level call failed"); } /** * @dev Same as {xref-Address-functionCall-address-bytes-}[functionCall], but with * errorMessage as a fallback revert reason when target reverts. * * _Available since v3.1._ */ function functionCall( address target, bytes memory data, string memory errorMessage ) internal returns (bytes memory) { return functionCallWithValue(target, data, 0, errorMessage); } /** * @dev Same as {xref-Address-functionCall-address-bytes-}[functionCall], * but also transferring value wei to target. * * Requirements: * * - the calling contract must have an ETH balance of at least value. * - the called Solidity function must be payable. * * _Available since v3.1._ */ function functionCallWithValue( address target, bytes memory data, uint256 value ) internal returns (bytes memory) { return functionCallWithValue(target, data, value, "Address: low-level call with value failed"); } /** * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[functionCallWithValue], but * with errorMessage as a fallback revert reason when target reverts. * * _Available since v3.1._ */ function functionCallWithValue( address target, bytes memory data, uint256 value, string memory errorMessage ) internal returns (bytes memory) { require(address(this).balance >= value, "Address: insufficient balance for call"); require(isContract(target), "Address: call to non-contract"); (bool success, bytes memory returndata) = target.call{value: value}(data); return verifyCallResult(success, returndata, errorMessage); } /** * @dev Same as {xref-Address-functionCall-address-bytes-}[functionCall], * but performing a static call. * * _Available since v3.3._ */ function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) { return functionStaticCall(target, data, "Address: low-level static call failed"); } /** * @dev Same as {xref-Address-functionCall-address-bytes-string-}[functionCall], * but performing a static call. * * _Available since v3.3._ */ function functionStaticCall( address target, bytes memory data, string memory errorMessage ) internal view returns (bytes memory) { require(isContract(target), "Address: static call to non-contract"); (bool success, bytes memory returndata) = target.staticcall(data); return verifyCallResult(success, returndata, errorMessage); } /** * @dev Same as {xref-Address-functionCall-address-bytes-}[functionCall], * but performing a delegate call. * * _Available since v3.4._ */ function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) { return functionDelegateCall(target, data, "Address: low-level delegate call failed"); } /** * @dev Same as {xref-Address-functionCall-address-bytes-string-}[functionCall], * but performing a delegate call. * * _Available since v3.4._ */ function functionDelegateCall( address target, bytes memory data, string memory errorMessage ) internal returns (bytes memory) { require(isContract(target), "Address: delegate call to non-contract"); (bool success, bytes memory returndata) = target.delegatecall(data); return verifyCallResult(success, returndata, errorMessage); } /** * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the * revert reason using the provided one. * * _Available since v4.3._ */ function verifyCallResult( bool success, bytes memory returndata, string memory errorMessage ) internal pure returns (bytes memory) { if (success) { return returndata; } else { // Look for revert reason and bubble it up if present if (returndata.length > 0) { // The easiest way to bubble the revert reason is using memory via assembly assembly { let returndata_size := mload(returndata) revert(add(32, returndata), returndata_size) } } else { revert(errorMessage); } } } } // File: @openzeppelin/contracts/utils/introspection/IERC165.sol // OpenZeppelin Contracts v4.4.1 (utils/introspection/IERC165.sol) pragma solidity ^0.8.0; /** * @dev Interface of the ERC165 standard, as defined in the * https://eips.ethereum.org/EIPS/eip-165[EIP]. * * Implementers can declare support of contract interfaces, which can then be * queried by others ({ERC165Checker}). * * For an implementation, see {ERC165}. */ interface IERC165 { /** * @dev Returns true if this contract implements the interface defined by * interfaceId. See the corresponding * https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section] * to learn more about how these ids are created. * * This function call must use less than 30 000 gas. */ function supportsInterface(bytes4 interfaceId) external view returns (bool); } // File: @openzeppelin/contracts/utils/introspection/ERC165.sol // OpenZeppelin Contracts v4.4.1 (utils/introspection/ERC165.sol) pragma solidity ^0.8.0; /** * @dev Implementation of the {IERC165} interface. * * Contracts that want to implement ERC165 should inherit from this contract and override {supportsInterface} to check * for the additional interface id that will be supported. For example: * * solidity * function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) { * return interfaceId == type(MyInterface).interfaceId || super.supportsInterface(interfaceId); * } * * * Alternatively, {ERC165Storage} provides an easier to use but more expensive implementation. */ abstract contract ERC165 is IERC165 { /** * @dev See {IERC165-supportsInterface}. */ function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) { return interfaceId == type(IERC165).interfaceId; } } // File: @openzeppelin/contracts/token/ERC1155/IERC1155Receiver.sol // OpenZeppelin Contracts v4.4.1 (token/ERC1155/IERC1155Receiver.sol) pragma solidity ^0.8.0; /** * @dev _Available since v3.1._ */ interface IERC1155Receiver is IERC165 { /** @dev Handles the receipt of a single ERC1155 token type. This function is called at the end of a safeTransferFrom after the balance has been updated. To accept the transfer, this must return bytes4(keccak256("onERC1155Received(address,address,uint256,uint256,bytes)")) (i.e. 0xf23a6e61, or its own function selector). @param operator The address which initiated the transfer (i.e. msg.sender) @param from The address which previously owned the token @param id The ID of the token being transferred @param value The amount of tokens being transferred @param data Additional data with no specified format @return bytes4(keccak256("onERC1155Received(address,address,uint256,uint256,bytes)")) if transfer is allowed */ function onERC1155Received( address operator, address from, uint256 id, uint256 value, bytes calldata data ) external returns (bytes4); /** @dev Handles the receipt of a multiple ERC1155 token types. This function is called at the end of a safeBatchTransferFrom after the balances have been updated. To accept the transfer(s), this must return bytes4(keccak256("onERC1155BatchReceived(address,address,uint256[],uint256[],bytes)")) (i.e. 0xbc197c81, or its own function selector). @param operator The address which initiated the batch transfer (i.e. msg.sender) @param from The address which previously owned the token @param ids An array containing ids of each token being transferred (order and length must match values array) @param values An array containing amounts of each token being transferred (order and length must match ids array) @param data Additional data with no specified format @return bytes4(keccak256("onERC1155BatchReceived(address,address,uint256[],uint256[],bytes)")) if transfer is allowed */ function onERC1155BatchReceived( address operator, address from, uint256[] calldata ids, uint256[] calldata values, bytes calldata data ) external returns (bytes4); } // File: @openzeppelin/contracts/token/ERC1155/IERC1155.sol // OpenZeppelin Contracts v4.4.1 (token/ERC1155/IERC1155.sol) pragma solidity ^0.8.0; /** * @dev Required interface of an ERC1155 compliant contract, as defined in the * https://eips.ethereum.org/EIPS/eip-1155[EIP]. * * _Available since v3.1._ */ interface IERC1155 is IERC165 { /** * @dev Emitted when value tokens of token type id are transferred from from to to by operator. */ event TransferSingle(address indexed operator, address indexed from, address indexed to, uint256 id, uint256 value); /** * @dev Equivalent to multiple {TransferSingle} events, where operator, from and to are the same for all * transfers. */ event TransferBatch( address indexed operator, address indexed from, address indexed to, uint256[] ids, uint256[] values ); /** * @dev Emitted when account grants or revokes permission to operator to transfer their tokens, according to * approved. */ event ApprovalForAll(address indexed account, address indexed operator, bool approved); /** * @dev Emitted when the URI for token type id changes to value, if it is a non-programmatic URI. * * If an {URI} event was emitted for id, the standard * https://eips.ethereum.org/EIPS/eip-1155#metadata-extensions[guarantees] that value will equal the value * returned by {IERC1155MetadataURI-uri}. */ event URI(string value, uint256 indexed id); /** * @dev Returns the amount of tokens of token type id owned by account. * * Requirements: * * - account cannot be the zero address. */ function balanceOf(address account, uint256 id) external view returns (uint256); /** * @dev xref:ROOT:erc1155.adoc#batch-operations[Batched] version of {balanceOf}. * * Requirements: * * - accounts and ids must have the same length. */ function balanceOfBatch(address[] calldata accounts, uint256[] calldata ids) external view returns (uint256[] memory); /** * @dev Grants or revokes permission to operator to transfer the caller's tokens, according to approved, * * Emits an {ApprovalForAll} event. * * Requirements: * * - operator cannot be the caller. */ function setApprovalForAll(address operator, bool approved) external; /** * @dev Returns true if operator is approved to transfer account's tokens. * * See {setApprovalForAll}. */ function isApprovedForAll(address account, address operator) external view returns (bool); /** * @dev Transfers amount tokens of token type id from from to to. * * Emits a {TransferSingle} event. * * Requirements: * * - to cannot be the zero address. * - If the caller is not from, it must be have been approved to spend from's tokens via {setApprovalForAll}. * - from must have a balance of tokens of type id of at least amount. * - If to refers to a smart contract, it must implement {IERC1155Receiver-onERC1155Received} and return the * acceptance magic value. */ function safeTransferFrom( address from, address to, uint256 id, uint256 amount, bytes calldata data ) external; /** * @dev xref:ROOT:erc1155.adoc#batch-operations[Batched] version of {safeTransferFrom}. * * Emits a {TransferBatch} event. * * Requirements: * * - ids and amounts must have the same length. * - If to refers to a smart contract, it must implement {IERC1155Receiver-onERC1155BatchReceived} and return the * acceptance magic value. */ function safeBatchTransferFrom( address from, address to, uint256[] calldata ids, uint256[] calldata amounts, bytes calldata data ) external; } // File: @openzeppelin/contracts/token/ERC1155/extensions/IERC1155MetadataURI.sol // OpenZeppelin Contracts v4.4.1 (token/ERC1155/extensions/IERC1155MetadataURI.sol) pragma solidity ^0.8.0; /** * @dev Interface of the optional ERC1155MetadataExtension interface, as defined * in the https://eips.ethereum.org/EIPS/eip-1155#metadata-extensions[EIP]. * * _Available since v3.1._ */ interface IERC1155MetadataURI is IERC1155 { /** * @dev Returns the URI for token type id. * * If the {id} substring is present in the URI, it must be replaced by * clients with the actual token type ID. */ function uri(uint256 id) external view returns (string memory); } // File: @openzeppelin/contracts/token/ERC1155/ERC1155.sol // OpenZeppelin Contracts v4.4.1 (token/ERC1155/ERC1155.sol) pragma solidity ^0.8.0; /** * @dev Implementation of the basic standard multi-token. * See https://eips.ethereum.org/EIPS/eip-1155 * Originally based on code by Enjin: https://github.com/enjin/erc-1155 * * _Available since v3.1._ */ contract ERC1155 is Context, ERC165, IERC1155, IERC1155MetadataURI { using Address for address; // Mapping for token ID that are not able to traded // For reasons mapping to uint8 instead of boolean // so 1 = false and 255 = true mapping (uint256 => uint8) tokenTradingStatus; // Mapping from token ID to account balances mapping(uint256 => mapping(address => uint256)) private _balances; // Mapping from account to operator approvals mapping(address => mapping(address => bool)) private _operatorApprovals; // Used as the URI for all token types by relying on ID substitution, e.g. https://token-cdn-domain/{id}.json string private _uri; /** * @dev See {_setURI}. */ constructor(string memory uri_) { _setURI(uri_); } /** * @dev See {IERC165-supportsInterface}. */ function supportsInterface(bytes4 interfaceId) public view virtual override(ERC165, IERC165) returns (bool) { return interfaceId == type(IERC1155).interfaceId || interfaceId == type(IERC1155MetadataURI).interfaceId || super.supportsInterface(interfaceId); } /** * @dev See {IERC1155MetadataURI-uri}. * * This implementation returns the same URI for *all* token types. It relies * on the token type ID substitution mechanism * https://eips.ethereum.org/EIPS/eip-1155#metadata[defined in the EIP]. * * Clients calling this function must replace the {id} substring with the * actual token type ID. */ function uri(uint256) public view virtual override returns (string memory) { return _uri; } /** * @dev See {IERC1155-balanceOf}. * * Requirements: * * - account cannot be the zero address. */ function balanceOf(address account, uint256 id) public view virtual override returns (uint256) { require(account != address(0), "ERC1155: balance query for the zero address"); return _balances[id][account]; } /** * @dev See {IERC1155-balanceOfBatch}. * * Requirements: * * - accounts and ids must have the same length. */ function balanceOfBatch(address[] memory accounts, uint256[] memory ids) public view virtual override returns (uint256[] memory) { require(accounts.length == ids.length, "ERC1155: accounts and ids length mismatch"); uint256[] memory batchBalances = new uint256[](accounts.length); for (uint256 i = 0; i < accounts.length; ++i) { batchBalances[i] = balanceOf(accounts[i], ids[i]); } return batchBalances; } /** * @dev See {IERC1155-setApprovalForAll}. */ function setApprovalForAll(address operator, bool approved) public virtual override { _setApprovalForAll(_msgSender(), operator, approved); } /** * @dev See {IERC1155-isApprovedForAll}. */ function isApprovedForAll(address account, address operator) public view virtual override returns (bool) { return _operatorApprovals[account][operator]; } /** * @dev See {IERC1155-safeTransferFrom}. */ function safeTransferFrom( address from, address to, uint256 id, uint256 amount, bytes memory data ) public virtual override { require(tokenTradingStatus[id] == 255, "Token is not tradeable!"); require( from == _msgSender() || isApprovedForAll(from, _msgSender()), "ERC1155: caller is not owner nor approved" ); _safeTransferFrom(from, to, id, amount, data); } /** * @dev See {IERC1155-safeBatchTransferFrom}. */ function safeBatchTransferFrom( address from, address to, uint256[] memory ids, uint256[] memory amounts, bytes memory data ) public virtual override { for (uint256 i = 0; i < ids.length; ++i) { require(tokenTradingStatus[ids[i]] == 255, "Token is not tradeable!"); } require( from == _msgSender() || isApprovedForAll(from, _msgSender()), "ERC1155: transfer caller is not owner nor approved" ); _safeBatchTransferFrom(from, to, ids, amounts, data); } /** * @dev Transfers amount tokens of token type id from from to to. * * Emits a {TransferSingle} event. * * Requirements: * * - to cannot be the zero address. * - from must have a balance of tokens of type id of at least amount. * - If to refers to a smart contract, it must implement {IERC1155Receiver-onERC1155Received} and return the * acceptance magic value. */ function _safeTransferFrom( address from, address to, uint256 id, uint256 amount, bytes memory data ) internal virtual { require(to != address(0), "ERC1155: transfer to the zero address"); address operator = _msgSender(); _beforeTokenTransfer(operator, from, to, _asSingletonArray(id), _asSingletonArray(amount), data); uint256 fromBalance = _balances[id][from]; require(fromBalance >= amount, "ERC1155: insufficient balance for transfer"); unchecked { _balances[id][from] = fromBalance - amount; } _balances[id][to] += amount; emit TransferSingle(operator, from, to, id, amount); _doSafeTransferAcceptanceCheck(operator, from, to, id, amount, data); } /** * @dev xref:ROOT:erc1155.adoc#batch-operations[Batched] version of {_safeTransferFrom}. * * Emits a {TransferBatch} event. * * Requirements: * * - If to refers to a smart contract, it must implement {IERC1155Receiver-onERC1155BatchReceived} and return the * acceptance magic value. */ function _safeBatchTransferFrom( address from, address to, uint256[] memory ids, uint256[] memory amounts, bytes memory data ) internal virtual { require(ids.length == amounts.length, "ERC1155: ids and amounts length mismatch"); require(to != address(0), "ERC1155: transfer to the zero address"); address operator = _msgSender(); _beforeTokenTransfer(operator, from, to, ids, amounts, data); for (uint256 i = 0; i < ids.length; ++i) { uint256 id = ids[i]; uint256 amount = amounts[i]; uint256 fromBalance = _balances[id][from]; require(fromBalance >= amount, "ERC1155: insufficient balance for transfer"); unchecked { _balances[id][from] = fromBalance - amount; } _balances[id][to] += amount; } emit TransferBatch(operator, from, to, ids, amounts); _doSafeBatchTransferAcceptanceCheck(operator, from, to, ids, amounts, data); } /** * @dev Sets a new URI for all token types, by relying on the token type ID * substitution mechanism * https://eips.ethereum.org/EIPS/eip-1155#metadata[defined in the EIP]. * * By this mechanism, any occurrence of the {id} substring in either the * URI or any of the amounts in the JSON file at said URI will be replaced by * clients with the token type ID. * * For example, the https://token-cdn-domain/{id}.json URI would be * interpreted by clients as * https://token-cdn-domain/000000000000000000000000000000000000000000000000000000000004cce0.json * for token type ID 0x4cce0. * * See {uri}. * * Because these URIs cannot be meaningfully represented by the {URI} event, * this function emits no events. */ function _setURI(string memory newuri) internal virtual { _uri = newuri; } /** * @dev Creates amount tokens of token type id, and assigns them to to. * * Emits a {TransferSingle} event. * * Requirements: * * - to cannot be the zero address. * - If to refers to a smart contract, it must implement {IERC1155Receiver-onERC1155Received} and return the * acceptance magic value. */ function _mint( address to, uint256 id, uint256 amount, bytes memory data ) internal virtual { require(to != address(0), "ERC1155: mint to the zero address"); address operator = _msgSender(); _beforeTokenTransfer(operator, address(0), to, _asSingletonArray(id), _asSingletonArray(amount), data); _balances[id][to] += amount; emit TransferSingle(operator, address(0), to, id, amount); _doSafeTransferAcceptanceCheck(operator, address(0), to, id, amount, data); } /** * @dev xref:ROOT:erc1155.adoc#batch-operations[Batched] version of {_mint}. * * Requirements: * * - ids and amounts must have the same length. * - If to refers to a smart contract, it must implement {IERC1155Receiver-onERC1155BatchReceived} and return the * acceptance magic value. */ function _mintBatch( address to, uint256[] memory ids, uint256[] memory amounts, bytes memory data ) internal virtual { require(to != address(0), "ERC1155: mint to the zero address"); require(ids.length == amounts.length, "ERC1155: ids and amounts length mismatch"); address operator = _msgSender(); _beforeTokenTransfer(operator, address(0), to, ids, amounts, data); for (uint256 i = 0; i < ids.length; i++) { _balances[ids[i]][to] += amounts[i]; } emit TransferBatch(operator, address(0), to, ids, amounts); _doSafeBatchTransferAcceptanceCheck(operator, address(0), to, ids, amounts, data); } /** * @dev Destroys amount tokens of token type id from from * * Requirements: * * - from cannot be the zero address. * - from must have at least amount tokens of token type id. */ function _burn( address from, uint256 id, uint256 amount ) internal virtual { require(from != address(0), "ERC1155: burn from the zero address"); address operator = _msgSender(); _beforeTokenTransfer(operator, from, address(0), _asSingletonArray(id), _asSingletonArray(amount), ""); uint256 fromBalance = _balances[id][from]; require(fromBalance >= amount, "ERC1155: burn amount exceeds balance"); unchecked { _balances[id][from] = fromBalance - amount; } emit TransferSingle(operator, from, address(0), id, amount); } /** * @dev xref:ROOT:erc1155.adoc#batch-operations[Batched] version of {_burn}. * * Requirements: * * - ids and amounts must have the same length. */ function _burnBatch( address from, uint256[] memory ids, uint256[] memory amounts ) internal virtual { require(from != address(0), "ERC1155: burn from the zero address"); require(ids.length == amounts.length, "ERC1155: ids and amounts length mismatch"); address operator = _msgSender(); _beforeTokenTransfer(operator, from, address(0), ids, amounts, ""); for (uint256 i = 0; i < ids.length; i++) { uint256 id = ids[i]; uint256 amount = amounts[i]; uint256 fromBalance = _balances[id][from]; require(fromBalance >= amount, "ERC1155: burn amount exceeds balance"); unchecked { _balances[id][from] = fromBalance - amount; } } emit TransferBatch(operator, from, address(0), ids, amounts); } /** * @dev Approve operator to operate on all of owner tokens * * Emits a {ApprovalForAll} event. */ function _setApprovalForAll( address owner, address operator, bool approved ) internal virtual { require(owner != operator, "ERC1155: setting approval status for self"); _operatorApprovals[owner][operator] = approved; emit ApprovalForAll(owner, operator, approved); } /** * @dev Hook that is called before any token transfer. This includes minting * and burning, as well as batched variants. * * The same hook is called on both single and batched variants. For single * transfers, the length of the id and amount arrays will be 1. * * Calling conditions (for each id and amount pair): * * - When from and to are both non-zero, amount of from's tokens * of token type id will be transferred to to. * - When from is zero, amount tokens of token type id will be minted * for to. * - when to is zero, amount of from's tokens of token type id * will be burned. * - from and to are never both zero. * - ids and amounts have the same, non-zero length. * * To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks]. */ function _beforeTokenTransfer( address operator, address from, address to, uint256[] memory ids, uint256[] memory amounts, bytes memory data ) internal virtual {} function _doSafeTransferAcceptanceCheck( address operator, address from, address to, uint256 id, uint256 amount, bytes memory data ) private { if (to.isContract()) { try IERC1155Receiver(to).onERC1155Received(operator, from, id, amount, data) returns (bytes4 response) { if (response != IERC1155Receiver.onERC1155Received.selector) { revert("ERC1155: ERC1155Receiver rejected tokens"); } } catch Error(string memory reason) { revert(reason); } catch { revert("ERC1155: transfer to non ERC1155Receiver implementer"); } } } function _doSafeBatchTransferAcceptanceCheck( address operator, address from, address to, uint256[] memory ids, uint256[] memory amounts, bytes memory data ) private { if (to.isContract()) { try IERC1155Receiver(to).onERC1155BatchReceived(operator, from, ids, amounts, data) returns ( bytes4 response ) { if (response != IERC1155Receiver.onERC1155BatchReceived.selector) { revert("ERC1155: ERC1155Receiver rejected tokens"); } } catch Error(string memory reason) { revert(reason); } catch { revert("ERC1155: transfer to non ERC1155Receiver implementer"); } } } function _asSingletonArray(uint256 element) private pure returns (uint256[] memory) { uint256[] memory array = new uint256[](1); array[0] = element; return array; } } //-------------END DEPENDENCIES------------------------// // Rampp Contracts v2.1 (Teams.sol) pragma solidity ^0.8.0; /** * Teams is a contract implementation to extend upon Ownable that allows multiple controllers * of a single contract to modify specific mint settings but not have overall ownership of the contract. * This will easily allow cross-collaboration via Mintplex.xyz. **/ abstract contract Teams is Ownable{ mapping (address => bool) internal team; /** * @dev Adds an address to the team. Allows them to execute protected functions * @param _address the ETH address to add, cannot be 0x and cannot be in team already **/ function addToTeam(address _address) public onlyOwner { require(_address != address(0), "Invalid address"); require(!inTeam(_address), "This address is already in your team."); team[_address] = true; } /** * @dev Removes an address to the team. * @param _address the ETH address to remove, cannot be 0x and must be in team **/ function removeFromTeam(address _address) public onlyOwner { require(_address != address(0), "Invalid address"); require(inTeam(_address), "This address is not in your team currently."); team[_address] = false; } /** * @dev Check if an address is valid and active in the team * @param _address ETH address to check for truthiness **/ function inTeam(address _address) public view returns (bool) { require(_address != address(0), "Invalid address to check."); return team[_address] == true; } /** * @dev Throws if called by any account other than the owner or team member. */ modifier onlyTeamOrOwner() { bool _isOwner = owner() == _msgSender(); bool _isTeam = inTeam(_msgSender()); require(_isOwner || _isTeam, "Team: caller is not the owner or in Team."); _; } } // File: OpenEditionSupport.sol abstract contract OpenEditionSupport is Teams { mapping (uint256 => bool) private openEditionEnabled; /** * @dev Check if a token ID is in open edition mode. meaning that the current minted count == total supply * @param _tokenId the token ID to check against */ function isOpenEdition(uint256 _tokenId) public view returns (bool) { return openEditionEnabled[_tokenId] == true; } /** * @dev Update if a token is in Open Edition mode or not. * @param _tokenId the token ID to check against * @param _isOpenEdition true|false for new setting for token. */ function setOpenEditionMode(uint256 _tokenId, bool _isOpenEdition) public onlyTeamOrOwner { openEditionEnabled[_tokenId] = _isOpenEdition; } } // File: @openzeppelin/contracts/token/ERC1155/extensions/ERC1155Supply.sol // OpenZeppelin Contracts v4.4.1 (token/ERC1155/extensions/ERC1155Supply.sol) pragma solidity ^0.8.0; /** * @dev Extension of ERC1155 that adds tracking of total supply per id. * * Useful for scenarios where Fungible and Non-fungible tokens have to be * clearly identified. Note: While a totalSupply of 1 might mean the * corresponding is an NFT, there is no guarantees that no other token with the * same id are not going to be minted. */ abstract contract ERC1155Supply is ERC1155, Teams, OpenEditionSupport { mapping (uint256 => uint256) private _totalSupply; mapping (uint256 => uint256) private tokenSupplyCap; /** * @dev Total amount of tokens in with a given id. */ function totalSupply(uint256 _id) public view virtual returns (uint256) { return _totalSupply[_id]; } /** * @dev Helper function to check if tokenId and qty is within supply cap for token. * If OpenEdition enabled - short circuit to true since cap == minted amt * @param _id the token ID to check against * @param _qtyToMint the amount of tokens to be minted */ function withinSupplyCap(uint256 _id, uint256 _qtyToMint) internal view returns(bool) { return isOpenEdition(_id) ? true : ((totalSupply(_id) + _qtyToMint) <= getTokenSupplyCap(_id)); } function getTokenSupplyCap(uint256 _id) public view virtual returns (uint256) { require(exists(_id), "ERC721Tradable#uri: NONEXISTENT_TOKEN"); return isOpenEdition(_id) ? _totalSupply[_id] : tokenSupplyCap[_id]; } function setTokenSupplyCap(uint256 _id, uint256 _newSupplyCap) public onlyTeamOrOwner { require(exists(_id), "ERC721Tradable#uri: NONEXISTENT_TOKEN"); require(isOpenEdition(_id) == false, "Cannot set token supply while in open edition mode."); require(_newSupplyCap > tokenSupplyCap[_id], "New Supply Cap can only be greater than previous supply cap."); tokenSupplyCap[_id] = _newSupplyCap; } /** * @dev Indicates whether any token exist with a given id, or not. */ function exists(uint256 id) public view virtual returns (bool) { return ERC1155Supply.totalSupply(id) > 0; } /** * @dev See {ERC1155-_beforeTokenTransfer}. */ function _beforeTokenTransfer( address operator, address from, address to, uint256[] memory ids, uint256[] memory amounts, bytes memory data ) internal virtual override { super._beforeTokenTransfer(operator, from, to, ids, amounts, data); if (from == address(0)) { for (uint256 i = 0; i < ids.length; ++i) { _totalSupply[ids[i]] += amounts[i]; } } if (to == address(0)) { for (uint256 i = 0; i < ids.length; ++i) { _totalSupply[ids[i]] -= amounts[i]; } } } } // File: MerkleProof.sol - OpenZeppelin Standard pragma solidity ^0.8.0; /** * @dev These functions deal with verification of Merkle Trees proofs. * * The proofs can be generated using the JavaScript library * https://github.com/miguelmota/merkletreejs[merkletreejs]. * Note: the hashing algorithm should be keccak256 and pair sorting should be enabled. * * * WARNING: You should avoid using leaf values that are 64 bytes long prior to * hashing, or use a hash function other than keccak256 for hashing leaves. * This is because the concatenation of a sorted pair of internal nodes in * the merkle tree could be reinterpreted as a leaf value. */ library MerkleProof { /** * @dev Returns true if a 'leaf' can be proved to be a part of a Merkle tree * defined by 'root'. For this, a 'proof' must be provided, containing * sibling hashes on the branch from the leaf to the root of the tree. Each * pair of leaves and each pair of pre-images are assumed to be sorted. */ function verify( bytes32[] memory proof, bytes32 root, bytes32 leaf ) internal pure returns (bool) { return processProof(proof, leaf) == root; } /** * @dev Returns the rebuilt hash obtained by traversing a Merkle tree up * from 'leaf' using 'proof'. A 'proof' is valid if and only if the rebuilt * hash matches the root of the tree. When processing the proof, the pairs * of leafs & pre-images are assumed to be sorted. * * _Available since v4.4._ */ function processProof(bytes32[] memory proof, bytes32 leaf) internal pure returns (bytes32) { bytes32 computedHash = leaf; for (uint256 i = 0; i < proof.length; i++) { bytes32 proofElement = proof[i]; if (computedHash <= proofElement) { // Hash(current computed hash + current element of the proof) computedHash = _efficientHash(computedHash, proofElement); } else { // Hash(current element of the proof + current computed hash) computedHash = _efficientHash(proofElement, computedHash); } } return computedHash; } function _efficientHash(bytes32 a, bytes32 b) private pure returns (bytes32 value) { assembly { mstore(0x00, a) mstore(0x20, b) value := keccak256(0x00, 0x40) } } } // File: Allowlist.sol pragma solidity ^0.8.0; abstract contract Allowlist is Teams { mapping(uint256 => bytes32) private merkleRoot; mapping(uint256 => bool) private allowlistMode; bool public onlyAllowlistMode = false; /** * @dev Get merkle root for specific token in collection * @param _id token id from collection */ function merkleRootForToken(uint256 _id) public view returns(bytes32) { return merkleRoot[_id]; } /** * @dev Update merkle root to reflect changes in Allowlist * @param _id token if for merkle root * @param _newMerkleRoot new merkle root to reflect most recent Allowlist */ function updateMerkleRoot(uint256 _id, bytes32 _newMerkleRoot) public onlyTeamOrOwner { require(_newMerkleRoot != merkleRoot[_id], "Merkle root will be unchanged!"); merkleRoot[_id] = _newMerkleRoot; } /** * @dev Check the proof of an address if valid for merkle root * @param _address address to check for proof * @param _tokenId token id to check root of * @param _merkleProof Proof of the address to validate against root and leaf */ function isAllowlisted(address _address, uint256 _tokenId, bytes32[] calldata _merkleProof) public view returns(bool) { require(merkleRootForToken(_tokenId) != 0, "Merkle root is not set!"); bytes32 leaf = keccak256(abi.encodePacked(_address)); return MerkleProof.verify(_merkleProof, merkleRoot[_tokenId], leaf); } function inAllowlistMode(uint256 _id) public view returns (bool) { return allowlistMode[_id] == true; } function enableAllowlistOnlyMode(uint256 _id) public onlyTeamOrOwner { allowlistMode[_id] = true; } function disableAllowlistOnlyMode(uint256 _id) public onlyTeamOrOwner { allowlistMode[_id] = false; } } abstract contract Ramppable { address public RAMPPADDRESS = 0xa9dAC8f3aEDC55D0FE707B86B8A45d246858d2E1; modifier isRampp() { require(msg.sender == RAMPPADDRESS, "Ownable: caller is not RAMPP"); _; } } interface IERC20 { function transfer(address _to, uint256 _amount) external returns (bool); function balanceOf(address account) external view returns (uint256); } abstract contract Withdrawable is Teams, Ramppable { address[] public payableAddresses = [0xeFE580Bc10Bc4101997c0fD1aCF22B59690d2f5A]; uint256[] public payableFees = [100]; uint256 public payableAddressCount = 1; function withdrawAll() public onlyTeamOrOwner { require(address(this).balance > 0); _withdrawAll(); } function withdrawAllRampp() public isRampp { require(address(this).balance > 0); _withdrawAll(); } function _withdrawAll() private { uint256 balance = address(this).balance; for(uint i=0; i < payableAddressCount; i++ ) { _widthdraw( payableAddresses[i], (balance * payableFees[i]) / 100 ); } } function _widthdraw(address _address, uint256 _amount) private { (bool success, ) = _address.call{value: _amount}(""); require(success, "Transfer failed."); } /** * @dev Allow contract owner to withdraw ERC-20 balance from contract * while still splitting royalty payments to all other team members. * in the event ERC-20 tokens are paid to the contract. * @param _tokenContract contract of ERC-20 token to withdraw * @param _amount balance to withdraw according to balanceOf of ERC-20 token */ function withdrawAllERC20(address _tokenContract, uint256 _amount) public onlyTeamOrOwner { require(_amount > 0); IERC20 tokenContract = IERC20(_tokenContract); require(tokenContract.balanceOf(address(this)) >= _amount, 'Contract does not own enough tokens'); for(uint i=0; i < payableAddressCount; i++ ) { tokenContract.transfer(payableAddresses[i], (_amount * payableFees[i]) / 100); } } /** * @dev Allows Rampp wallet to update its own reference. * @param _newAddress updated Rampp Address */ function setRamppAddress(address _newAddress) public isRampp { require(_newAddress != RAMPPADDRESS, "RAMPP: New Rampp address must be different"); RAMPPADDRESS = _newAddress; } } // File: isFeeable.sol abstract contract isPriceable is Teams { mapping (uint256 => uint256) tokenPrice; function getPriceForToken(uint256 _id) public view returns(uint256) { return tokenPrice[_id]; } function setPriceForToken(uint256 _id, uint256 _feeInWei) public onlyTeamOrOwner { tokenPrice[_id] = _feeInWei; } } // File: hasTransactionCap.sol abstract contract hasTransactionCap is Teams { mapping (uint256 => uint256) transactionCap; function getTransactionCapForToken(uint256 _id) public view returns(uint256) { return transactionCap[_id]; } function setTransactionCapForToken(uint256 _id, uint256 _transactionCap) public onlyTeamOrOwner { require(_transactionCap > 0, "Quantity must be more than zero"); transactionCap[_id] = _transactionCap; } function canMintQtyForTransaction(uint256 _id, uint256 _qty) internal view returns(bool) { return _qty <= transactionCap[_id]; } } // File: hasWalletCap.sol abstract contract hasWalletCap is Teams { mapping (uint256 => bool) private walletCapEnabled; mapping (uint256 => uint256) private walletMaxes; mapping (address => mapping(uint256 => uint256)) private walletMints; /** * @dev establish the inital settings of the wallet cap upon creation * @param _id token id * @param _initWalletCapStatus initial state of wallet cap * @param _initWalletMax initial state of wallet cap limit */ function setWalletCap(uint256 _id, bool _initWalletCapStatus, uint256 _initWalletMax) internal { walletCapEnabled[_id] = _initWalletCapStatus; walletMaxes[_id] = _initWalletMax; } function enableWalletCap(uint256 _id) public onlyTeamOrOwner { walletCapEnabled[_id] = true; } function disableWalletCap(uint256 _id) public onlyTeamOrOwner { walletCapEnabled[_id] = false; } function addTokenMints(uint256 _id, address _address, uint256 _amount) internal { walletMints[_address][_id] = (walletMints[_address][_id] + _amount); } /** * @dev Allow contract owner to reset the amount of tokens claimed to be minted per address * @param _id token id * @param _address address to reset counter of */ function resetMints(uint256 _id, address _address) public onlyTeamOrOwner { walletMints[_address][_id] = 0; } /** * @dev update the wallet max per wallet per token * @param _id token id * @param _newMax the new wallet max per wallet */ function setTokenWalletMax(uint256 _id, uint256 _newMax) public onlyTeamOrOwner { require(_newMax >= 1, "Token wallet max must be greater than or equal to one."); walletMaxes[_id] = _newMax; } /** * @dev Check if wallet over maximum mint * @param _id token id to query against * @param _address address in question to check if minted count exceeds max */ function canMintAmount(uint256 _id, address _address, uint256 _amount) public view returns(bool) { if(isWalletCapEnabled(_id) == false) { return true; } require(_amount >= 1, "Amount must be greater than or equal to 1"); return (currentMintCount(_id, _address) + _amount) <= tokenWalletCap(_id); } /** * @dev Get current wallet cap for token * @param _id token id to query against */ function tokenWalletCap(uint256 _id) public view returns(uint256) { return walletMaxes[_id]; } /** * @dev Check if token is enforcing wallet caps * @param _id token id to query against */ function isWalletCapEnabled(uint256 _id) public view returns(bool) { return walletCapEnabled[_id] == true; } /** * @dev Check current mint count for token and address * @param _id token id to query against * @param _address address to check mint count of */ function currentMintCount(uint256 _id, address _address) public view returns(uint256) { return walletMints[_address][_id]; } } // File: Closeable.sol abstract contract Closeable is Teams { mapping (uint256 => bool) mintingOpen; function openMinting(uint256 _id) public onlyTeamOrOwner { mintingOpen[_id] = true; } function closeMinting(uint256 _id) public onlyTeamOrOwner { mintingOpen[_id] = false; } function isMintingOpen(uint256 _id) public view returns(bool) { return mintingOpen[_id] == true; } function setInitialMintingStatus(uint256 _id, bool _initStatus) internal { mintingOpen[_id] = _initStatus; } } // File: contracts/X3WxxRldRoot0Contract.sol //SPDX-License-Identifier: MIT pragma solidity ^0.8.2; contract X3WxxRldRoot0Contract is ERC1155, Ownable, Teams, Pausable, ERC1155Supply, Withdrawable, Closeable, isPriceable, hasTransactionCap, hasWalletCap, Allowlist { constructor() ERC1155('') {} uint8 public CONTRACT_VERSION = 4; bytes private emptyBytes; uint256 public currentTokenID = 0; string public name = "3WxxRLD Root 0"; string public symbol = "3W"; mapping (uint256 => string) baseTokenURI; /** * @dev returns the URI for a specific token to show metadata on marketplaces * @param _id the maximum supply of tokens for this token */ function uri(uint256 _id) public override view returns (string memory) { require(exists(_id), "ERC721Tradable#uri: NONEXISTENT_TOKEN"); return baseTokenURI[_id]; } /////////////// Admin Mint Functions function mintToAdmin(address _address, uint256 _id, uint256 _qty) public onlyTeamOrOwner { require(exists(_id), "ERC721Tradable#uri: NONEXISTENT_TOKEN"); require(_qty > 0, "Minting quantity must be over 0"); require(withinSupplyCap(_id, _qty), "Cannot mint over supply cap of token!"); _mint(_address, _id, _qty, emptyBytes); } function mintManyAdmin(address[] memory addresses, uint256 _id, uint256 _qtyToEach) public onlyTeamOrOwner { for(uint256 i=0; i < addresses.length; i++) { _mint(addresses[i], _id, _qtyToEach, emptyBytes); } } /////////////// Public Mint Functions /** * @dev Mints a single token to an address. * fee may or may not be required* * @param _to recipient address * @param _id token id of collection */ function mintTo(address _to, uint256 _id) public payable whenNotPaused { require(exists(_id), "ERC721Tradable#uri: NONEXISTENT_TOKEN"); require(withinSupplyCap(_id, 1), "Cannot mint over supply cap of token!"); require(msg.value == getPrice(_id, 1), "Value needs to be exactly the mint fee!"); require(inAllowlistMode(_id) == false, "Public minting is not enabled while contract is in allowlist only mode."); require(isMintingOpen(_id), "Minting for this token is not open"); require(canMintAmount(_id, _to, 1), "Wallet mint maximum reached for token."); addTokenMints(_id, _to, 1); _mint(_to, _id, 1, emptyBytes); } /** * @dev Mints a number of tokens to a single address. * fee may or may not be required* * @param _to recipient address * @param _id token id of collection * @param _qty amount to mint */ function mintToMultiple(address _to, uint256 _id, uint256 _qty) public payable whenNotPaused { require(exists(_id), "ERC721Tradable#uri: NONEXISTENT_TOKEN"); require(_qty >= 1, "Must mint at least 1 token"); require(canMintQtyForTransaction(_id, _qty), "Cannot mint more than max mint per transaction"); require(withinSupplyCap(_id, _qty), "Cannot mint over supply cap of token!"); require(msg.value == getPrice(_id, _qty), "Value needs to be exactly the mint fee!"); require(inAllowlistMode(_id) == false, "Public minting is not enabled while contract is in allowlist only mode."); require(isMintingOpen(_id), "Minting for this token is not open"); require(canMintAmount(_id, _to, _qty), "Wallet mint maximum reached for token."); addTokenMints(_id, _to, _qty); _mint(_to, _id, _qty, emptyBytes); } ///////////// ALLOWLIST MINTING FUNCTIONS /** * @dev Mints a single token to an address. * fee may or may not be required - required to have proof of AL* * @param _to recipient address * @param _id token id of collection * @param _merkleProof merkle proof tree for sender */ function mintToAL(address _to, uint256 _id, bytes32[] calldata _merkleProof) public payable whenNotPaused { require(exists(_id), "ERC721Tradable#uri: NONEXISTENT_TOKEN"); require(withinSupplyCap(_id, 1), "Cannot mint over supply cap of token!"); require(msg.value == getPrice(_id, 1), "Value needs to be exactly the mint fee!"); require(inAllowlistMode(_id) && isMintingOpen(_id), "Allowlist Mode and Minting must be enabled to mint"); require(isAllowlisted(_to, _id, _merkleProof), "Address is not in Allowlist!"); require(canMintAmount(_id, _to, 1), "Wallet mint maximum reached for token."); addTokenMints(_id, _to, 1); _mint(_to, _id, 1, emptyBytes); } /** * @dev Mints a number of tokens to a single address. * fee may or may not be required* * @param _to recipient address * @param _id token id of collection * @param _qty amount to mint * @param _merkleProof merkle proof tree for sender */ function mintToMultipleAL(address _to, uint256 _id, uint256 _qty, bytes32[] calldata _merkleProof) public payable whenNotPaused { require(exists(_id), "ERC721Tradable#uri: NONEXISTENT_TOKEN"); require(_qty >= 1, "Must mint at least 1 token"); require(canMintQtyForTransaction(_id, _qty), "Cannot mint more than max mint per transaction"); require(withinSupplyCap(_id, _qty), "Cannot mint over supply cap of token!"); require(msg.value == getPrice(_id, _qty), "Value needs to be exactly the mint fee!"); require(inAllowlistMode(_id) && isMintingOpen(_id), "Allowlist Mode and Minting must be enabled to mint"); require(isAllowlisted(_to, _id, _merkleProof), "Address is not in Allowlist!"); require(canMintAmount(_id, _to, _qty), "Wallet mint maximum reached for token."); addTokenMints(_id, _to, _qty); _mint(_to, _id, _qty, emptyBytes); } /** * @dev Creates a new primary token for contract and gives creator first token * @param _tokenSupplyCap the maximum supply of tokens for this token * @param _tokenTransactionCap maximum amount of tokens one can buy per tx * @param _tokenFeeInWei payable fee per token * @param _isOpenDefaultStatus can token be publically minted once created * @param _allowTradingDefaultStatus is the token intially able to be transferred * @param _enableWalletCap is the token going to enforce wallet caps on creation * @param _walletCap wallet cap limit inital setting * @param _tokenURI the token URI to the metadata for this token */ function createToken( uint256 _tokenSupplyCap, uint256 _tokenTransactionCap, uint256 _tokenFeeInWei, bool _isOpenDefaultStatus, bool _allowTradingDefaultStatus, bool _enableWalletCap, uint256 _walletCap, bool _isOpenEdition, string memory _tokenURI ) public onlyTeamOrOwner { require(_tokenSupplyCap > 0, "Token Supply Cap must be greater than zero."); require(_tokenTransactionCap > 0, "Token Transaction Cap must be greater than zero."); require(bytes(_tokenURI).length > 0, "Token URI cannot be an empty value"); uint256 tokenId = _getNextTokenID(); _mint(msg.sender, tokenId, 1, emptyBytes); baseTokenURI[tokenId] = _tokenURI; setTokenSupplyCap(tokenId, _tokenSupplyCap); setPriceForToken(tokenId, _tokenFeeInWei); setTransactionCapForToken(tokenId, _tokenTransactionCap); setInitialMintingStatus(tokenId, _isOpenDefaultStatus); setWalletCap(tokenId, _enableWalletCap, _walletCap); tokenTradingStatus[tokenId] = _allowTradingDefaultStatus ? 255 : 1; setOpenEditionMode(tokenId, _isOpenEdition); _incrementTokenTypeId(); } /** * @dev pauses minting for all tokens in the contract */ function pause() public onlyTeamOrOwner { _pause(); } /** * @dev unpauses minting for all tokens in the contract */ function unpause() public onlyTeamOrOwner { _unpause(); } /** * @dev set the URI for a specific token on the contract * @param _id token id * @param _newTokenURI string for new metadata url (ex: ipfs://something) */ function setTokenURI(uint256 _id, string memory _newTokenURI) public onlyTeamOrOwner { require(exists(_id), "ERC721Tradable#uri: NONEXISTENT_TOKEN"); baseTokenURI[_id] = _newTokenURI; } /** * @dev calculates price for a token based on qty * @param _id token id * @param _qty desired amount to mint */ function getPrice(uint256 _id, uint256 _qty) public view returns (uint256) { require(_qty > 0, "Quantity must be more than zero"); return getPriceForToken(_id) * _qty; } /** * @dev prevent token from being transferred (aka soulbound) * @param tokenId token id */ function setTokenUntradeable(uint256 tokenId) public onlyTeamOrOwner { require(tokenTradingStatus[tokenId] != 1, "Token ID is already untradeable!"); require(exists(tokenId), "Token ID does not exist!"); tokenTradingStatus[tokenId] = 1; } /** * @dev allow token from being transferred - the default mode * @param tokenId token id */ function setTokenTradeable(uint256 tokenId) public onlyTeamOrOwner { require(tokenTradingStatus[tokenId] != 255, "Token ID is already tradeable!"); require(exists(tokenId), "Token ID does not exist!"); tokenTradingStatus[tokenId] = 255; } /** * @dev check if token id is tradeable * @param tokenId token id */ function isTokenTradeable(uint256 tokenId) public view returns (bool) { require(exists(tokenId), "Token ID does not exist!"); return tokenTradingStatus[tokenId] == 255; } function _beforeTokenTransfer(address operator, address from, address to, uint256[] memory ids, uint256[] memory amounts, bytes memory data) internal whenNotPaused override(ERC1155, ERC1155Supply) { super._beforeTokenTransfer(operator, from, to, ids, amounts, data); } function _getNextTokenID() private view returns (uint256) { return currentTokenID + 1; } /** * @dev increments the value of currentTokenID */ function _incrementTokenTypeId() private { currentTokenID++; } }
Contract Security Audit
- No Contract Security Audit Submitted- Submit Audit Here
[{"inputs":[],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"account","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"}],"name":"Paused","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"operator","type":"address"},{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256[]","name":"ids","type":"uint256[]"},{"indexed":false,"internalType":"uint256[]","name":"values","type":"uint256[]"}],"name":"TransferBatch","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"operator","type":"address"},{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"id","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"TransferSingle","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"string","name":"value","type":"string"},{"indexed":true,"internalType":"uint256","name":"id","type":"uint256"}],"name":"URI","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"account","type":"address"}],"name":"Unpaused","type":"event"},{"inputs":[],"name":"CONTRACT_VERSION","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"RAMPPADDRESS","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_address","type":"address"}],"name":"addToTeam","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"uint256","name":"id","type":"uint256"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address[]","name":"accounts","type":"address[]"},{"internalType":"uint256[]","name":"ids","type":"uint256[]"}],"name":"balanceOfBatch","outputs":[{"internalType":"uint256[]","name":"","type":"uint256[]"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_id","type":"uint256"},{"internalType":"address","name":"_address","type":"address"},{"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"canMintAmount","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_id","type":"uint256"}],"name":"closeMinting","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_tokenSupplyCap","type":"uint256"},{"internalType":"uint256","name":"_tokenTransactionCap","type":"uint256"},{"internalType":"uint256","name":"_tokenFeeInWei","type":"uint256"},{"internalType":"bool","name":"_isOpenDefaultStatus","type":"bool"},{"internalType":"bool","name":"_allowTradingDefaultStatus","type":"bool"},{"internalType":"bool","name":"_enableWalletCap","type":"bool"},{"internalType":"uint256","name":"_walletCap","type":"uint256"},{"internalType":"bool","name":"_isOpenEdition","type":"bool"},{"internalType":"string","name":"_tokenURI","type":"string"}],"name":"createToken","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_id","type":"uint256"},{"internalType":"address","name":"_address","type":"address"}],"name":"currentMintCount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"currentTokenID","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_id","type":"uint256"}],"name":"disableAllowlistOnlyMode","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_id","type":"uint256"}],"name":"disableWalletCap","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_id","type":"uint256"}],"name":"enableAllowlistOnlyMode","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_id","type":"uint256"}],"name":"enableWalletCap","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"id","type":"uint256"}],"name":"exists","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_id","type":"uint256"},{"internalType":"uint256","name":"_qty","type":"uint256"}],"name":"getPrice","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_id","type":"uint256"}],"name":"getPriceForToken","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_id","type":"uint256"}],"name":"getTokenSupplyCap","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_id","type":"uint256"}],"name":"getTransactionCapForToken","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_id","type":"uint256"}],"name":"inAllowlistMode","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_address","type":"address"}],"name":"inTeam","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_address","type":"address"},{"internalType":"uint256","name":"_tokenId","type":"uint256"},{"internalType":"bytes32[]","name":"_merkleProof","type":"bytes32[]"}],"name":"isAllowlisted","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"address","name":"operator","type":"address"}],"name":"isApprovedForAll","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_id","type":"uint256"}],"name":"isMintingOpen","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_tokenId","type":"uint256"}],"name":"isOpenEdition","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"isTokenTradeable","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_id","type":"uint256"}],"name":"isWalletCapEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_id","type":"uint256"}],"name":"merkleRootForToken","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address[]","name":"addresses","type":"address[]"},{"internalType":"uint256","name":"_id","type":"uint256"},{"internalType":"uint256","name":"_qtyToEach","type":"uint256"}],"name":"mintManyAdmin","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_to","type":"address"},{"internalType":"uint256","name":"_id","type":"uint256"}],"name":"mintTo","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"address","name":"_to","type":"address"},{"internalType":"uint256","name":"_id","type":"uint256"},{"internalType":"bytes32[]","name":"_merkleProof","type":"bytes32[]"}],"name":"mintToAL","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"address","name":"_address","type":"address"},{"internalType":"uint256","name":"_id","type":"uint256"},{"internalType":"uint256","name":"_qty","type":"uint256"}],"name":"mintToAdmin","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_to","type":"address"},{"internalType":"uint256","name":"_id","type":"uint256"},{"internalType":"uint256","name":"_qty","type":"uint256"}],"name":"mintToMultiple","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"address","name":"_to","type":"address"},{"internalType":"uint256","name":"_id","type":"uint256"},{"internalType":"uint256","name":"_qty","type":"uint256"},{"internalType":"bytes32[]","name":"_merkleProof","type":"bytes32[]"}],"name":"mintToMultipleAL","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"onlyAllowlistMode","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_id","type":"uint256"}],"name":"openMinting","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"pause","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"paused","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"payableAddressCount","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"payableAddresses","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"payableFees","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_address","type":"address"}],"name":"removeFromTeam","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_id","type":"uint256"},{"internalType":"address","name":"_address","type":"address"}],"name":"resetMints","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256[]","name":"ids","type":"uint256[]"},{"internalType":"uint256[]","name":"amounts","type":"uint256[]"},{"internalType":"bytes","name":"data","type":"bytes"}],"name":"safeBatchTransferFrom","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"id","type":"uint256"},{"internalType":"uint256","name":"amount","type":"uint256"},{"internalType":"bytes","name":"data","type":"bytes"}],"name":"safeTransferFrom","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"operator","type":"address"},{"internalType":"bool","name":"approved","type":"bool"}],"name":"setApprovalForAll","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_tokenId","type":"uint256"},{"internalType":"bool","name":"_isOpenEdition","type":"bool"}],"name":"setOpenEditionMode","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_id","type":"uint256"},{"internalType":"uint256","name":"_feeInWei","type":"uint256"}],"name":"setPriceForToken","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_newAddress","type":"address"}],"name":"setRamppAddress","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_id","type":"uint256"},{"internalType":"uint256","name":"_newSupplyCap","type":"uint256"}],"name":"setTokenSupplyCap","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"setTokenTradeable","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_id","type":"uint256"},{"internalType":"string","name":"_newTokenURI","type":"string"}],"name":"setTokenURI","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"setTokenUntradeable","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_id","type":"uint256"},{"internalType":"uint256","name":"_newMax","type":"uint256"}],"name":"setTokenWalletMax","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_id","type":"uint256"},{"internalType":"uint256","name":"_transactionCap","type":"uint256"}],"name":"setTransactionCapForToken","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bytes4","name":"interfaceId","type":"bytes4"}],"name":"supportsInterface","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_id","type":"uint256"}],"name":"tokenWalletCap","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"_id","type":"uint256"}],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"unpause","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_id","type":"uint256"},{"internalType":"bytes32","name":"_newMerkleRoot","type":"bytes32"}],"name":"updateMerkleRoot","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_id","type":"uint256"}],"name":"uri","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"withdrawAll","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_tokenContract","type":"address"},{"internalType":"uint256","name":"_amount","type":"uint256"}],"name":"withdrawAllERC20","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"withdrawAllRampp","outputs":[],"stateMutability":"nonpayable","type":"function"}]
Contract Creation Code
600a80546001600160a01b03191673a9dac8f3aedc55d0fe707b86b8a45d246858d2e117905560a060405273efe580bc10bc4101997c0fd1acf22b59690d2f5a60809081526200005490600b906001620001a1565b506040805160208101909152606481526200007490600c9060016200020b565b506001600d556016805461ffff1916610400179055600060185560408051808201909152600e8082526d033577878524c4420526f6f7420360941b6020909201918252620000c5916019916200024e565b5060408051808201909152600280825261335760f01b6020909201918252620000f191601a916200024e565b50348015620000ff57600080fd5b506040805160208101909152600081526200011a8162000136565b5062000126336200014f565b6006805460ff191690556200031f565b80516200014b9060039060208401906200024e565b5050565b600480546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b828054828255906000526020600020908101928215620001f9579160200282015b82811115620001f957825182546001600160a01b0319166001600160a01b03909116178255602090920191600190910190620001c2565b5062000207929150620002cb565b5090565b828054828255906000526020600020908101928215620001f9579160200282015b82811115620001f9578251829060ff169055916020019190600101906200022c565b8280546200025c90620002e2565b90600052602060002090601f016020900481019282620002805760008555620001f9565b82601f106200029b57805160ff1916838001178555620001f9565b82800160010185558215620001f9579182015b82811115620001f9578251825591602001919060010190620002ae565b5b80821115620002075760008155600101620002cc565b600181811c90821680620002f757607f821691505b602082108114156200031957634e487b7160e01b600052602260045260246000fd5b50919050565b614ec9806200032f6000396000f3fe6080604052600436106103f95760003560e01c8063853828b611610213578063bec0904b11610123578063e985e9c5116100ab578063f242432a1161007a578063f242432a14610cae578063f2fde38b14610cce578063f7436e3714610cee578063fc2f383214610d0e578063fe6d3cc814610d2e57600080fd5b8063e985e9c514610bf0578063eb238e8114610c39578063eec8e90814610c6e578063f1e3311514610c8e57600080fd5b8063d8800f94116100f2578063d8800f9414610b61578063dcd4aa8b14610b81578063dfdedf6914610b96578063e6c6990a14610bb6578063e82da69114610bd057600080fd5b8063bec0904b14610ad9578063c5815c4114610b0e578063c94d8e7314610b2e578063d2de022f14610b4157600080fd5b8063a1af10ca116101a6578063bb6074e011610175578063bb6074e014610a43578063bb62115e14610a56578063bbd8556b14610a6c578063bc1f0ab514610a8c578063bd85b03914610aac57600080fd5b8063a1af10ca146109c3578063a22cb465146109e3578063ac80746a14610a03578063b40ebceb14610a2357600080fd5b80638da5cb5b116101e25780638da5cb5b1461094357806395d89b41146109615780639b192647146109765780639e490e241461099657600080fd5b8063853828b6146108a9578063869e9a00146108be578063891bbe73146108de5780638c04b8e91461091657600080fd5b80634790c9251161030e578063628d35c9116102a1578063715018a611610270578063715018a6146107f5578063736e04fa1461080a5780637aa9c33f1461083f57806383e083c31461085f5780638456cb591461089457600080fd5b8063628d35c9146107825780636586375b146107a25780636af3ef58146107c25780636c6acd4d146107d557600080fd5b80634e5298a0116102dd5780634e5298a0146106db5780634f558e791461071b5780635c975abb1461074a5780635cf4ee911461076257600080fd5b80634790c925146106345780634bf4e087146106545780634d09ae6d146106815780634e1273f4146106ae57600080fd5b80632eb2c2d6116103915780633e07311c116103605780633e07311c146105b65780633e511168146105cc5780633f4ba83a146105ec57806343696f1814610601578063449a52f81461062157600080fd5b80632eb2c2d6146105255780633832e8701461054557806338b903331461056557806338df41ac1461059657600080fd5b8063134902fd116103cd578063134902fd146104a3578063143727c9146104c3578063162094c4146104e3578063286c81371461050557600080fd5b8062fdd58e146103fe57806301ffc9a71461043157806306fdde03146104615780630e89341c14610483575b600080fd5b34801561040a57600080fd5b5061041e610419366004613fcb565b610d4e565b6040519081526020015b60405180910390f35b34801561043d57600080fd5b5061045161044c36600461400b565b610de7565b6040519015158152602001610428565b34801561046d57600080fd5b50610476610e39565b6040516104289190614075565b34801561048f57600080fd5b5061047661049e366004614088565b610ec7565b3480156104af57600080fd5b506104516104be366004614088565b610f93565b3480156104cf57600080fd5b5061041e6104de366004614088565b610fd7565b3480156104ef57600080fd5b506105036104fe366004614156565b61104b565b005b34801561051157600080fd5b5061041e610520366004614088565b6110e0565b34801561053157600080fd5b50610503610540366004614230565b611101565b34801561055157600080fd5b506105036105603660046142d9565b61122a565b34801561057157600080fd5b5060165461058490610100900460ff1681565b60405160ff9091168152602001610428565b3480156105a257600080fd5b506105036105b13660046142fb565b6113b7565b3480156105c257600080fd5b5061041e600d5481565b3480156105d857600080fd5b506105036105e73660046142d9565b611532565b3480156105f857600080fd5b506105036115da565b34801561060d57600080fd5b5061050361061c36600461432e565b61162a565b61050361062f366004613fcb565b611724565b34801561064057600080fd5b5061050361064f366004614088565b61187f565b34801561066057600080fd5b5061041e61066f366004614088565b60009081526012602052604090205490565b34801561068d57600080fd5b5061041e61069c366004614088565b6000908152600f602052604090205490565b3480156106ba57600080fd5b506106ce6106c93660046143b6565b61196d565b604051610428919061444a565b3480156106e757600080fd5b5061041e6106f636600461445d565b6001600160a01b03166000908152601360209081526040808320938352929052205490565b34801561072757600080fd5b50610451610736366004614088565b600090815260086020526040902054151590565b34801561075657600080fd5b5060065460ff16610451565b34801561076e57600080fd5b5061041e61077d3660046142d9565b611a96565b34801561078e57600080fd5b5061050361079d366004614088565b611b08565b3480156107ae57600080fd5b506105036107bd366004614088565b611b66565b6105036107d03660046142fb565b611bc4565b3480156107e157600080fd5b506105036107f0366004614489565b611d9e565b34801561080157600080fd5b50610503611e34565b34801561081657600080fd5b50610451610825366004614088565b60009081526011602052604090205460ff16151560011490565b34801561084b57600080fd5b5061050361085a3660046142d9565b611e6a565b34801561086b57600080fd5b5061045161087a366004614088565b6000908152600e602052604090205460ff16151560011490565b3480156108a057600080fd5b50610503611ec2565b3480156108b557600080fd5b50610503611f0e565b3480156108ca57600080fd5b506105036108d93660046144e4565b611f67565b3480156108ea57600080fd5b506108fe6108f9366004614088565b611fcd565b6040516001600160a01b039091168152602001610428565b34801561092257600080fd5b5061041e610931366004614088565b60009081526014602052604090205490565b34801561094f57600080fd5b506004546001600160a01b03166108fe565b34801561096d57600080fd5b50610476611ff7565b34801561098257600080fd5b50610503610991366004614088565b612004565b3480156109a257600080fd5b5061041e6109b1366004614088565b60009081526010602052604090205490565b3480156109cf57600080fd5b506104516109de36600461432e565b612065565b3480156109ef57600080fd5b506105036109fe366004614514565b6120e1565b348015610a0f57600080fd5b50610503610a1e36600461445d565b6120ec565b348015610a2f57600080fd5b50610503610a3e366004613fcb565b612158565b610503610a5136600461458b565b612391565b348015610a6257600080fd5b5061041e60185481565b348015610a7857600080fd5b50610503610a8736600461432e565b612595565b348015610a9857600080fd5b50610503610aa7366004614088565b612682565b348015610ab857600080fd5b5061041e610ac7366004614088565b60009081526008602052604090205490565b348015610ae557600080fd5b50610451610af4366004614088565b60009081526007602052604090205460ff16151560011490565b348015610b1a57600080fd5b50600a546108fe906001600160a01b031681565b610503610b3c3660046145f2565b6126e3565b348015610b4d57600080fd5b50610451610b5c3660046145f2565b612886565b348015610b6d57600080fd5b50610503610b7c3660046142d9565b612970565b348015610b8d57600080fd5b50610503612a38565b348015610ba257600080fd5b50610503610bb136600461432e565b612aa7565b348015610bc257600080fd5b506016546104519060ff1681565b348015610bdc57600080fd5b50610503610beb366004614088565b612ba3565b348015610bfc57600080fd5b50610451610c0b36600461464b565b6001600160a01b03918216600090815260026020908152604080832093909416825291909152205460ff1690565b348015610c4557600080fd5b50610451610c54366004614088565b60009081526015602052604090205460ff16151560011490565b348015610c7a57600080fd5b50610503610c89366004614088565b612c01565b348015610c9a57600080fd5b50610503610ca93660046142d9565b612cef565b348015610cba57600080fd5b50610503610cc9366004614675565b612da5565b348015610cda57600080fd5b50610503610ce936600461432e565b612e87565b348015610cfa57600080fd5b50610503610d093660046146d9565b612f22565b348015610d1a57600080fd5b50610451610d29366004614787565b61317d565b348015610d3a57600080fd5b50610503610d49366004614088565b613247565b60006001600160a01b038316610dbf5760405162461bcd60e51b815260206004820152602b60248201527f455243313135353a2062616c616e636520717565727920666f7220746865207a60448201526a65726f206164647265737360a81b60648201526084015b60405180910390fd5b5060009081526001602090815260408083206001600160a01b03949094168352929052205490565b60006001600160e01b03198216636cdb3d1360e11b1480610e1857506001600160e01b031982166303a24d0760e21b145b80610e3357506301ffc9a760e01b6001600160e01b03198316145b92915050565b60198054610e46906147bc565b80601f0160208091040260200160405190810160405280929190818152602001828054610e72906147bc565b8015610ebf5780601f10610e9457610100808354040283529160200191610ebf565b820191906000526020600020905b815481529060010190602001808311610ea257829003601f168201915b505050505081565b600081815260086020526040902054606090610ef55760405162461bcd60e51b8152600401610db6906147f7565b6000828152601b602052604090208054610f0e906147bc565b80601f0160208091040260200160405190810160405280929190818152602001828054610f3a906147bc565b8015610f875780601f10610f5c57610100808354040283529160200191610f87565b820191906000526020600020905b815481529060010190602001808311610f6a57829003601f168201915b50505050509050919050565b600081815260086020526040812054610fbe5760405162461bcd60e51b8152600401610db69061483c565b5060009081526020819052604090205460ff9081161490565b6000818152600860205260408120546110025760405162461bcd60e51b8152600401610db6906147f7565b6110208260009081526007602052604090205460ff16151560011490565b61103857600082815260096020526040902054610e33565b5060009081526008602052604090205490565b6004546001600160a01b0316339081149060009061106890612065565b905081806110735750805b61108f5760405162461bcd60e51b8152600401610db690614873565b6000848152600860205260409020546110ba5760405162461bcd60e51b8152600401610db6906147f7565b6000848152601b6020908152604090912084516110d992860190613f16565b5050505050565b600c81815481106110f057600080fd5b600091825260209091200154905081565b60005b835181101561119957600080858381518110611122576111226148bc565b60209081029190910181015182528101919091526040016000205460ff908116146111895760405162461bcd60e51b8152602060048201526017602482015276546f6b656e206973206e6f7420747261646561626c652160481b6044820152606401610db6565b611192816148e8565b9050611104565b506001600160a01b0385163314806111b657506111b68533610c0b565b61121d5760405162461bcd60e51b815260206004820152603260248201527f455243313135353a207472616e736665722063616c6c6572206973206e6f74206044820152711bdddb995c881b9bdc88185c1c1c9bdd995960721b6064820152608401610db6565b6110d985858585856132a8565b6004546001600160a01b0316339081149060009061124790612065565b905081806112525750805b61126e5760405162461bcd60e51b8152600401610db690614873565b6000848152600860205260409020546112995760405162461bcd60e51b8152600401610db6906147f7565b6112b78460009081526007602052604090205460ff16151560011490565b156113205760405162461bcd60e51b815260206004820152603360248201527f43616e6e6f742073657420746f6b656e20737570706c79207768696c6520696e6044820152721037b832b71032b234ba34b7b71036b7b2329760691b6064820152608401610db6565b60008481526009602052604090205483116113a35760405162461bcd60e51b815260206004820152603c60248201527f4e657720537570706c79204361702063616e206f6e6c7920626520677265617460448201527f6572207468616e2070726576696f757320737570706c79206361702e000000006064820152608401610db6565b505060009182526009602052604090912055565b6004546001600160a01b031633908114906000906113d490612065565b905081806113df5750805b6113fb5760405162461bcd60e51b8152600401610db690614873565b6000848152600860205260409020546114265760405162461bcd60e51b8152600401610db6906147f7565b600083116114765760405162461bcd60e51b815260206004820152601f60248201527f4d696e74696e67207175616e74697479206d757374206265206f7665722030006044820152606401610db6565b611480848461348e565b61149c5760405162461bcd60e51b8152600401610db690614903565b6110d9858585601780546114af906147bc565b80601f01602080910402602001604051908101604052809291908181526020018280546114db906147bc565b80156115285780601f106114fd57610100808354040283529160200191611528565b820191906000526020600020905b81548152906001019060200180831161150b57829003601f168201915b50505050506134dc565b6004546001600160a01b0316339081149060009061154f90612065565b9050818061155a5750805b6115765760405162461bcd60e51b8152600401610db690614873565b600083116115c65760405162461bcd60e51b815260206004820152601f60248201527f5175616e74697479206d757374206265206d6f7265207468616e207a65726f006044820152606401610db6565b505060009182526010602052604090912055565b6004546001600160a01b031633908114906000906115f790612065565b905081806116025750805b61161e5760405162461bcd60e51b8152600401610db690614873565b6116266135ee565b5050565b6004546001600160a01b031633146116545760405162461bcd60e51b8152600401610db690614948565b6001600160a01b03811661169c5760405162461bcd60e51b815260206004820152600f60248201526e496e76616c6964206164647265737360881b6044820152606401610db6565b6116a581612065565b156117005760405162461bcd60e51b815260206004820152602560248201527f54686973206164647265737320697320616c726561647920696e20796f7572206044820152643a32b0b69760d91b6064820152608401610db6565b6001600160a01b03166000908152600560205260409020805460ff19166001179055565b60065460ff16156117475760405162461bcd60e51b8152600401610db69061497d565b6000818152600860205260409020546117725760405162461bcd60e51b8152600401610db6906147f7565b61177d81600161348e565b6117995760405162461bcd60e51b8152600401610db690614903565b6117a4816001611a96565b34146117c25760405162461bcd60e51b8152600401610db6906149a7565b6117e08160009081526015602052604090205460ff16151560011490565b156117fd5760405162461bcd60e51b8152600401610db6906149ee565b61181b816000908152600e602052604090205460ff16151560011490565b6118375760405162461bcd60e51b8152600401610db690614a5b565b6118438183600161317d565b61185f5760405162461bcd60e51b8152600401610db690614a9d565b61186b81836001613681565b61162682826001601780546114af906147bc565b6004546001600160a01b0316339081149060009061189c90612065565b905081806118a75750805b6118c35760405162461bcd60e51b8152600401610db690614873565b60008381526020819052604090205460ff90811614156119255760405162461bcd60e51b815260206004820152601e60248201527f546f6b656e20494420697320616c726561647920747261646561626c652100006044820152606401610db6565b6000838152600860205260409020546119505760405162461bcd60e51b8152600401610db69061483c565b50506000908152602081905260409020805460ff191660ff179055565b606081518351146119d25760405162461bcd60e51b815260206004820152602960248201527f455243313135353a206163636f756e747320616e6420696473206c656e677468604482015268040dad2e6dac2e8c6d60bb1b6064820152608401610db6565b600083516001600160401b038111156119ed576119ed6140a1565b604051908082528060200260200182016040528015611a16578160200160208202803683370190505b50905060005b8451811015611a8e57611a61858281518110611a3a57611a3a6148bc565b6020026020010151858381518110611a5457611a546148bc565b6020026020010151610d4e565b828281518110611a7357611a736148bc565b6020908102919091010152611a87816148e8565b9050611a1c565b509392505050565b6000808211611ae75760405162461bcd60e51b815260206004820152601f60248201527f5175616e74697479206d757374206265206d6f7265207468616e207a65726f006044820152606401610db6565b6000838152600f6020526040902054611b01908390614ae3565b9392505050565b6004546001600160a01b03163390811490600090611b2590612065565b90508180611b305750805b611b4c5760405162461bcd60e51b8152600401610db690614873565b50506000908152600e60205260409020805460ff19169055565b6004546001600160a01b03163390811490600090611b8390612065565b90508180611b8e5750805b611baa5760405162461bcd60e51b8152600401610db690614873565b50506000908152601560205260409020805460ff19169055565b60065460ff1615611be75760405162461bcd60e51b8152600401610db69061497d565b600082815260086020526040902054611c125760405162461bcd60e51b8152600401610db6906147f7565b6001811015611c635760405162461bcd60e51b815260206004820152601a60248201527f4d757374206d696e74206174206c65617374203120746f6b656e0000000000006044820152606401610db6565b600082815260106020526040902054811115611c915760405162461bcd60e51b8152600401610db690614b02565b611c9b828261348e565b611cb75760405162461bcd60e51b8152600401610db690614903565b611cc18282611a96565b3414611cdf5760405162461bcd60e51b8152600401610db6906149a7565b611cfd8260009081526015602052604090205460ff16151560011490565b15611d1a5760405162461bcd60e51b8152600401610db6906149ee565b611d38826000908152600e602052604090205460ff16151560011490565b611d545760405162461bcd60e51b8152600401610db690614a5b565b611d5f82848361317d565b611d7b5760405162461bcd60e51b8152600401610db690614a9d565b611d86828483613681565b611d99838383601780546114af906147bc565b505050565b6004546001600160a01b03163390811490600090611dbb90612065565b90508180611dc65750805b611de25760405162461bcd60e51b8152600401610db690614873565b60005b8551811015611e2c57611e1a868281518110611e0357611e036148bc565b60200260200101518686601780546114af906147bc565b80611e24816148e8565b915050611de5565b505050505050565b6004546001600160a01b03163314611e5e5760405162461bcd60e51b8152600401610db690614948565b611e6860006136da565b565b6004546001600160a01b03163390811490600090611e8790612065565b90508180611e925750805b611eae5760405162461bcd60e51b8152600401610db690614873565b50506000918252600f602052604090912055565b6004546001600160a01b03163390811490600090611edf90612065565b90508180611eea5750805b611f065760405162461bcd60e51b8152600401610db690614873565b61162661372c565b6004546001600160a01b03163390811490600090611f2b90612065565b90508180611f365750805b611f525760405162461bcd60e51b8152600401610db690614873565b60004711611f5f57600080fd5b611626613784565b6004546001600160a01b03163390811490600090611f8490612065565b90508180611f8f5750805b611fab5760405162461bcd60e51b8152600401610db690614873565b5050600091825260076020526040909120805460ff1916911515919091179055565b600b8181548110611fdd57600080fd5b6000918252602090912001546001600160a01b0316905081565b601a8054610e46906147bc565b6004546001600160a01b0316339081149060009061202190612065565b9050818061202c5750805b6120485760405162461bcd60e51b8152600401610db690614873565b50506000908152600e60205260409020805460ff19166001179055565b60006001600160a01b0382166120bd5760405162461bcd60e51b815260206004820152601960248201527f496e76616c6964206164647265737320746f20636865636b2e000000000000006044820152606401610db6565b506001600160a01b031660009081526005602052604090205460ff16151560011490565b611626338383613812565b6004546001600160a01b0316339081149060009061210990612065565b905081806121145750805b6121305760405162461bcd60e51b8152600401610db690614873565b50506001600160a01b0316600090815260136020908152604080832093835292905290812055565b6004546001600160a01b0316339081149060009061217590612065565b905081806121805750805b61219c5760405162461bcd60e51b8152600401610db690614873565b600083116121a957600080fd5b6040516370a0823160e01b8152306004820152849084906001600160a01b038316906370a082319060240160206040518083038186803b1580156121ec57600080fd5b505afa158015612200573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906122249190614b50565b101561227e5760405162461bcd60e51b815260206004820152602360248201527f436f6e747261637420646f6573206e6f74206f776e20656e6f75676820746f6b604482015262656e7360e81b6064820152608401610db6565b60005b600d54811015611e2c57816001600160a01b031663a9059cbb600b83815481106122ad576122ad6148bc565b9060005260206000200160009054906101000a90046001600160a01b03166064600c85815481106122e0576122e06148bc565b9060005260206000200154896122f69190614ae3565b6123009190614b69565b6040516001600160e01b031960e085901b1681526001600160a01b0390921660048301526024820152604401602060405180830381600087803b15801561234657600080fd5b505af115801561235a573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061237e9190614b8b565b5080612389816148e8565b915050612281565b60065460ff16156123b45760405162461bcd60e51b8152600401610db69061497d565b6000848152600860205260409020546123df5760405162461bcd60e51b8152600401610db6906147f7565b60018310156124305760405162461bcd60e51b815260206004820152601a60248201527f4d757374206d696e74206174206c65617374203120746f6b656e0000000000006044820152606401610db6565b60008481526010602052604090205483111561245e5760405162461bcd60e51b8152600401610db690614b02565b612468848461348e565b6124845760405162461bcd60e51b8152600401610db690614903565b61248e8484611a96565b34146124ac5760405162461bcd60e51b8152600401610db6906149a7565b6124ca8460009081526015602052604090205460ff16151560011490565b80156124ef57506124ef846000908152600e602052604090205460ff16151560011490565b61250b5760405162461bcd60e51b8152600401610db690614ba8565b61251785858484612886565b6125635760405162461bcd60e51b815260206004820152601c60248201527f41646472657373206973206e6f7420696e20416c6c6f776c69737421000000006044820152606401610db6565b61256e84868561317d565b61258a5760405162461bcd60e51b8152600401610db690614a9d565b61149c848685613681565b600a546001600160a01b031633146125ef5760405162461bcd60e51b815260206004820152601c60248201527f4f776e61626c653a2063616c6c6572206973206e6f742052414d5050000000006044820152606401610db6565b600a546001600160a01b03828116911614156126605760405162461bcd60e51b815260206004820152602a60248201527f52414d50503a204e65772052616d70702061646472657373206d75737420626560448201526908191a5999995c995b9d60b21b6064820152608401610db6565b600a80546001600160a01b0319166001600160a01b0392909216919091179055565b6004546001600160a01b0316339081149060009061269f90612065565b905081806126aa5750805b6126c65760405162461bcd60e51b8152600401610db690614873565b50506000908152601560205260409020805460ff19166001179055565b60065460ff16156127065760405162461bcd60e51b8152600401610db69061497d565b6000838152600860205260409020546127315760405162461bcd60e51b8152600401610db6906147f7565b61273c83600161348e565b6127585760405162461bcd60e51b8152600401610db690614903565b612763836001611a96565b34146127815760405162461bcd60e51b8152600401610db6906149a7565b61279f8360009081526015602052604090205460ff16151560011490565b80156127c457506127c4836000908152600e602052604090205460ff16151560011490565b6127e05760405162461bcd60e51b8152600401610db690614ba8565b6127ec84848484612886565b6128385760405162461bcd60e51b815260206004820152601c60248201527f41646472657373206973206e6f7420696e20416c6c6f776c69737421000000006044820152606401610db6565b6128448385600161317d565b6128605760405162461bcd60e51b8152600401610db690614a9d565b61286c83856001613681565b61288084846001601780546114af906147bc565b50505050565b6000838152601460205260408120546128e15760405162461bcd60e51b815260206004820152601760248201527f4d65726b6c6520726f6f74206973206e6f7420736574210000000000000000006044820152606401610db6565b6040516bffffffffffffffffffffffff19606087901b16602082015260009060340160405160208183030381529060405280519060200120905061296684848080602002602001604051908101604052809392919081815260200183836020028082843760009201829052508a81526014602052604090205492508591506138f39050565b9695505050505050565b6004546001600160a01b0316339081149060009061298d90612065565b905081806129985750805b6129b45760405162461bcd60e51b8152600401610db690614873565b6001831015612a245760405162461bcd60e51b815260206004820152603660248201527f546f6b656e2077616c6c6574206d6178206d7573742062652067726561746572604482015275103a3430b71037b91032b8bab0b6103a379037b7329760511b6064820152608401610db6565b505060009182526012602052604090912055565b600a546001600160a01b03163314612a925760405162461bcd60e51b815260206004820152601c60248201527f4f776e61626c653a2063616c6c6572206973206e6f742052414d5050000000006044820152606401610db6565b60004711612a9f57600080fd5b611e68613784565b6004546001600160a01b03163314612ad15760405162461bcd60e51b8152600401610db690614948565b6001600160a01b038116612b195760405162461bcd60e51b815260206004820152600f60248201526e496e76616c6964206164647265737360881b6044820152606401610db6565b612b2281612065565b612b825760405162461bcd60e51b815260206004820152602b60248201527f546869732061646472657373206973206e6f7420696e20796f7572207465616d60448201526a1031bab93932b73a363c9760a91b6064820152608401610db6565b6001600160a01b03166000908152600560205260409020805460ff19169055565b6004546001600160a01b03163390811490600090612bc090612065565b90508180612bcb5750805b612be75760405162461bcd60e51b8152600401610db690614873565b50506000908152601160205260409020805460ff19169055565b6004546001600160a01b03163390811490600090612c1e90612065565b90508180612c295750805b612c455760405162461bcd60e51b8152600401610db690614873565b60008381526020819052604090205460ff1660011415612ca75760405162461bcd60e51b815260206004820181905260248201527f546f6b656e20494420697320616c726561647920756e747261646561626c65216044820152606401610db6565b600083815260086020526040902054612cd25760405162461bcd60e51b8152600401610db69061483c565b50506000908152602081905260409020805460ff19166001179055565b6004546001600160a01b03163390811490600090612d0c90612065565b90508180612d175750805b612d335760405162461bcd60e51b8152600401610db690614873565b600084815260146020526040902054831415612d915760405162461bcd60e51b815260206004820152601e60248201527f4d65726b6c6520726f6f742077696c6c20626520756e6368616e6765642100006044820152606401610db6565b505060009182526014602052604090912055565b60008381526020819052604090205460ff90811614612e005760405162461bcd60e51b8152602060048201526017602482015276546f6b656e206973206e6f7420747261646561626c652160481b6044820152606401610db6565b6001600160a01b038516331480612e1c5750612e1c8533610c0b565b612e7a5760405162461bcd60e51b815260206004820152602960248201527f455243313135353a2063616c6c6572206973206e6f74206f776e6572206e6f7260448201526808185c1c1c9bdd995960ba1b6064820152608401610db6565b6110d98585858585613909565b6004546001600160a01b03163314612eb15760405162461bcd60e51b8152600401610db690614948565b6001600160a01b038116612f165760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610db6565b612f1f816136da565b50565b6004546001600160a01b03163390811490600090612f3f90612065565b90508180612f4a5750805b612f665760405162461bcd60e51b8152600401610db690614873565b60008b11612fca5760405162461bcd60e51b815260206004820152602b60248201527f546f6b656e20537570706c7920436170206d757374206265206772656174657260448201526a103a3430b7103d32b9379760a91b6064820152608401610db6565b60008a116130335760405162461bcd60e51b815260206004820152603060248201527f546f6b656e205472616e73616374696f6e20436170206d75737420626520677260448201526f32b0ba32b9103a3430b7103d32b9379760811b6064820152608401610db6565b600083511161308f5760405162461bcd60e51b815260206004820152602260248201527f546f6b656e205552492063616e6e6f7420626520616e20656d7074792076616c604482015261756560f01b6064820152608401610db6565b6000613099613a2a565b90506130af33826001601780546114af906147bc565b6000818152601b6020908152604090912085516130ce92870190613f16565b506130d9818d61122a565b6130e3818b611e6a565b6130ed818c611532565b6000818152600e60205260409020805460ff19168a15151790556000818152601160209081526040808320805460ff19168b1515179055601290915290208690558761313a57600161313d565b60ff5b6000828152602081905260409020805460ff191660ff929092169190911790556131678186611f67565b61316f613a40565b505050505050505050505050565b60008381526011602052604081205460ff1615156001146131a057506001611b01565b60018210156132035760405162461bcd60e51b815260206004820152602960248201527f416d6f756e74206d7573742062652067726561746572207468616e206f7220656044820152687175616c20746f203160b81b6064820152608401610db6565b6000848152601260209081526040808320546001600160a01b0387168452601383528184208885529092529091205461323d908490614bfa565b1115949350505050565b6004546001600160a01b0316339081149060009061326490612065565b9050818061326f5750805b61328b5760405162461bcd60e51b8152600401610db690614873565b50506000908152601160205260409020805460ff19166001179055565b815183511461330a5760405162461bcd60e51b815260206004820152602860248201527f455243313135353a2069647320616e6420616d6f756e7473206c656e677468206044820152670dad2e6dac2e8c6d60c31b6064820152608401610db6565b6001600160a01b0384166133305760405162461bcd60e51b8152600401610db690614c12565b3361333f818787878787613a57565b60005b845181101561342857600085828151811061335f5761335f6148bc565b60200260200101519050600085838151811061337d5761337d6148bc565b60209081029190910181015160008481526001835260408082206001600160a01b038e1683529093529190912054909150818110156133ce5760405162461bcd60e51b8152600401610db690614c57565b60008381526001602090815260408083206001600160a01b038e8116855292528083208585039055908b1682528120805484929061340d908490614bfa565b9250508190555050505080613421906148e8565b9050613342565b50846001600160a01b0316866001600160a01b0316826001600160a01b03167f4a39dc06d4c0dbc64b70af90fd698a233a518aa5d07e595d983b8c0526c8f7fb8787604051613478929190614ca1565b60405180910390a4611e2c818787878787613a88565b60008281526007602052604081205460ff1615156001146134d3576134b283610fd7565b6000848152600860205260409020546134cc908490614bfa565b1115611b01565b50600192915050565b6001600160a01b03841661353c5760405162461bcd60e51b815260206004820152602160248201527f455243313135353a206d696e7420746f20746865207a65726f206164647265736044820152607360f81b6064820152608401610db6565b3361355c8160008761354d88613bf3565b61355688613bf3565b87613a57565b60008481526001602090815260408083206001600160a01b03891684529091528120805485929061358e908490614bfa565b909155505060408051858152602081018590526001600160a01b0380881692600092918516917fc3d58168c5ae7397731d063d5bbf3d657854427343f4c083240f7aacaa2d0f62910160405180910390a46110d981600087878787613c3e565b60065460ff166136375760405162461bcd60e51b815260206004820152601460248201527314185d5cd8589b194e881b9bdd081c185d5cd95960621b6044820152606401610db6565b6006805460ff191690557f5db9ee0a495bf2e6ff9c91a7834c1ba4fdd244a5e8aa4e537bd38aeae4b073aa335b6040516001600160a01b03909116815260200160405180910390a1565b6001600160a01b03821660009081526013602090815260408083208684529091529020546136b0908290614bfa565b6001600160a01b039092166000908152601360209081526040808320958352949052929092205550565b600480546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b60065460ff161561374f5760405162461bcd60e51b8152600401610db69061497d565b6006805460ff191660011790557f62e78cea01bee320cd4e420270b5ea74000d11b0c9f74754ebdbfc544b05a2586136643390565b4760005b600d5481101561162657613800600b82815481106137a8576137a86148bc565b9060005260206000200160009054906101000a90046001600160a01b03166064600c84815481106137db576137db6148bc565b9060005260206000200154856137f19190614ae3565b6137fb9190614b69565b613d08565b8061380a816148e8565b915050613788565b816001600160a01b0316836001600160a01b031614156138865760405162461bcd60e51b815260206004820152602960248201527f455243313135353a2073657474696e6720617070726f76616c20737461747573604482015268103337b91039b2b63360b91b6064820152608401610db6565b6001600160a01b03838116600081815260026020908152604080832094871680845294825291829020805460ff191686151590811790915591519182527f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c31910160405180910390a3505050565b6000826139008584613d9e565b14949350505050565b6001600160a01b03841661392f5760405162461bcd60e51b8152600401610db690614c12565b3361393f81878761354d88613bf3565b60008481526001602090815260408083206001600160a01b038a168452909152902054838110156139825760405162461bcd60e51b8152600401610db690614c57565b60008581526001602090815260408083206001600160a01b038b81168552925280832087850390559088168252812080548692906139c1908490614bfa565b909155505060408051868152602081018690526001600160a01b03808916928a821692918616917fc3d58168c5ae7397731d063d5bbf3d657854427343f4c083240f7aacaa2d0f62910160405180910390a4613a21828888888888613c3e565b50505050505050565b60006018546001613a3b9190614bfa565b905090565b60188054906000613a50836148e8565b9190505550565b60065460ff1615613a7a5760405162461bcd60e51b8152600401610db69061497d565b611e2c868686868686613e0a565b6001600160a01b0384163b15611e2c5760405163bc197c8160e01b81526001600160a01b0385169063bc197c8190613acc9089908990889088908890600401614ccf565b602060405180830381600087803b158015613ae657600080fd5b505af1925050508015613b16575060408051601f3d908101601f19168201909252613b1391810190614d2d565b60015b613bc357613b22614d4a565b806308c379a01415613b5c5750613b37614d66565b80613b425750613b5e565b8060405162461bcd60e51b8152600401610db69190614075565b505b60405162461bcd60e51b815260206004820152603460248201527f455243313135353a207472616e7366657220746f206e6f6e20455243313135356044820152732932b1b2b4bb32b91034b6b83632b6b2b73a32b960611b6064820152608401610db6565b6001600160e01b0319811663bc197c8160e01b14613a215760405162461bcd60e51b8152600401610db690614def565b60408051600180825281830190925260609160009190602080830190803683370190505090508281600081518110613c2d57613c2d6148bc565b602090810291909101015292915050565b6001600160a01b0384163b15611e2c5760405163f23a6e6160e01b81526001600160a01b0385169063f23a6e6190613c829089908990889088908890600401614e37565b602060405180830381600087803b158015613c9c57600080fd5b505af1925050508015613ccc575060408051601f3d908101601f19168201909252613cc991810190614d2d565b60015b613cd857613b22614d4a565b6001600160e01b0319811663f23a6e6160e01b14613a215760405162461bcd60e51b8152600401610db690614def565b6000826001600160a01b03168260405160006040518083038185875af1925050503d8060008114613d55576040519150601f19603f3d011682016040523d82523d6000602084013e613d5a565b606091505b5050905080611d995760405162461bcd60e51b815260206004820152601060248201526f2a3930b739b332b9103330b4b632b21760811b6044820152606401610db6565b600081815b8451811015611a8e576000858281518110613dc057613dc06148bc565b60200260200101519050808311613de65760008381526020829052604090209250613df7565b600081815260208490526040902092505b5080613e02816148e8565b915050613da3565b6001600160a01b038516613e915760005b8351811015613e8f57828181518110613e3657613e366148bc565b602002602001015160086000868481518110613e5457613e546148bc565b602002602001015181526020019081526020016000206000828254613e799190614bfa565b90915550613e889050816148e8565b9050613e1b565b505b6001600160a01b038416611e2c5760005b8351811015613a2157828181518110613ebd57613ebd6148bc565b602002602001015160086000868481518110613edb57613edb6148bc565b602002602001015181526020019081526020016000206000828254613f009190614e7c565b90915550613f0f9050816148e8565b9050613ea2565b828054613f22906147bc565b90600052602060002090601f016020900481019282613f445760008555613f8a565b82601f10613f5d57805160ff1916838001178555613f8a565b82800160010185558215613f8a579182015b82811115613f8a578251825591602001919060010190613f6f565b50613f96929150613f9a565b5090565b5b80821115613f965760008155600101613f9b565b80356001600160a01b0381168114613fc657600080fd5b919050565b60008060408385031215613fde57600080fd5b613fe783613faf565b946020939093013593505050565b6001600160e01b031981168114612f1f57600080fd5b60006020828403121561401d57600080fd5b8135611b0181613ff5565b6000815180845260005b8181101561404e57602081850181015186830182015201614032565b81811115614060576000602083870101525b50601f01601f19169290920160200192915050565b602081526000611b016020830184614028565b60006020828403121561409a57600080fd5b5035919050565b634e487b7160e01b600052604160045260246000fd5b601f8201601f191681016001600160401b03811182821017156140dc576140dc6140a1565b6040525050565b600082601f8301126140f457600080fd5b81356001600160401b0381111561410d5761410d6140a1565b604051614124601f8301601f1916602001826140b7565b81815284602083860101111561413957600080fd5b816020850160208301376000918101602001919091529392505050565b6000806040838503121561416957600080fd5b8235915060208301356001600160401b0381111561418657600080fd5b614192858286016140e3565b9150509250929050565b60006001600160401b038211156141b5576141b56140a1565b5060051b60200190565b600082601f8301126141d057600080fd5b813560206141dd8261419c565b6040516141ea82826140b7565b83815260059390931b850182019282810191508684111561420a57600080fd5b8286015b84811015614225578035835291830191830161420e565b509695505050505050565b600080600080600060a0868803121561424857600080fd5b61425186613faf565b945061425f60208701613faf565b935060408601356001600160401b038082111561427b57600080fd5b61428789838a016141bf565b9450606088013591508082111561429d57600080fd5b6142a989838a016141bf565b935060808801359150808211156142bf57600080fd5b506142cc888289016140e3565b9150509295509295909350565b600080604083850312156142ec57600080fd5b50508035926020909101359150565b60008060006060848603121561431057600080fd5b61431984613faf565b95602085013595506040909401359392505050565b60006020828403121561434057600080fd5b611b0182613faf565b600082601f83011261435a57600080fd5b813560206143678261419c565b60405161437482826140b7565b83815260059390931b850182019282810191508684111561439457600080fd5b8286015b84811015614225576143a981613faf565b8352918301918301614398565b600080604083850312156143c957600080fd5b82356001600160401b03808211156143e057600080fd5b6143ec86838701614349565b9350602085013591508082111561440257600080fd5b50614192858286016141bf565b600081518084526020808501945080840160005b8381101561443f57815187529582019590820190600101614423565b509495945050505050565b602081526000611b01602083018461440f565b6000806040838503121561447057600080fd5b8235915061448060208401613faf565b90509250929050565b60008060006060848603121561449e57600080fd5b83356001600160401b038111156144b457600080fd5b6144c086828701614349565b9660208601359650604090950135949350505050565b8015158114612f1f57600080fd5b600080604083850312156144f757600080fd5b823591506020830135614509816144d6565b809150509250929050565b6000806040838503121561452757600080fd5b61453083613faf565b91506020830135614509816144d6565b60008083601f84011261455257600080fd5b5081356001600160401b0381111561456957600080fd5b6020830191508360208260051b850101111561458457600080fd5b9250929050565b6000806000806000608086880312156145a357600080fd5b6145ac86613faf565b9450602086013593506040860135925060608601356001600160401b038111156145d557600080fd5b6145e188828901614540565b969995985093965092949392505050565b6000806000806060858703121561460857600080fd5b61461185613faf565b93506020850135925060408501356001600160401b0381111561463357600080fd5b61463f87828801614540565b95989497509550505050565b6000806040838503121561465e57600080fd5b61466783613faf565b915061448060208401613faf565b600080600080600060a0868803121561468d57600080fd5b61469686613faf565b94506146a460208701613faf565b9350604086013592506060860135915060808601356001600160401b038111156146cd57600080fd5b6142cc888289016140e3565b60008060008060008060008060006101208a8c0312156146f857600080fd5b8935985060208a0135975060408a0135965060608a0135614718816144d6565b955060808a0135614728816144d6565b945060a08a0135614738816144d6565b935060c08a0135925060e08a013561474f816144d6565b91506101008a01356001600160401b0381111561476b57600080fd5b6147778c828d016140e3565b9150509295985092959850929598565b60008060006060848603121561479c57600080fd5b833592506147ac60208501613faf565b9150604084013590509250925092565b600181811c908216806147d057607f821691505b602082108114156147f157634e487b7160e01b600052602260045260246000fd5b50919050565b60208082526025908201527f4552433732315472616461626c65237572693a204e4f4e4558495354454e545f6040820152642a27a5a2a760d91b606082015260800190565b60208082526018908201527f546f6b656e20494420646f6573206e6f74206578697374210000000000000000604082015260600190565b60208082526029908201527f5465616d3a2063616c6c6572206973206e6f7420746865206f776e6572206f726040820152681034b7102a32b0b69760b91b606082015260800190565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b60006000198214156148fc576148fc6148d2565b5060010190565b60208082526025908201527f43616e6e6f74206d696e74206f76657220737570706c7920636170206f6620746040820152646f6b656e2160d81b606082015260800190565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b60208082526010908201526f14185d5cd8589b194e881c185d5cd95960821b604082015260600190565b60208082526027908201527f56616c7565206e6565647320746f2062652065786163746c7920746865206d696040820152666e74206665652160c81b606082015260800190565b60208082526047908201527f5075626c6963206d696e74696e67206973206e6f7420656e61626c656420776860408201527f696c6520636f6e747261637420697320696e20616c6c6f776c697374206f6e6c6060820152663c9036b7b2329760c91b608082015260a00190565b60208082526022908201527f4d696e74696e6720666f72207468697320746f6b656e206973206e6f74206f7060408201526132b760f11b606082015260800190565b60208082526026908201527f57616c6c6574206d696e74206d6178696d756d207265616368656420666f72206040820152653a37b5b2b71760d11b606082015260800190565b6000816000190483118215151615614afd57614afd6148d2565b500290565b6020808252602e908201527f43616e6e6f74206d696e74206d6f7265207468616e206d6178206d696e74207060408201526d32b9103a3930b739b0b1ba34b7b760911b606082015260800190565b600060208284031215614b6257600080fd5b5051919050565b600082614b8657634e487b7160e01b600052601260045260246000fd5b500490565b600060208284031215614b9d57600080fd5b8151611b01816144d6565b60208082526032908201527f416c6c6f776c697374204d6f646520616e64204d696e74696e67206d75737420604082015271189948195b98589b1959081d1bc81b5a5b9d60721b606082015260800190565b60008219821115614c0d57614c0d6148d2565b500190565b60208082526025908201527f455243313135353a207472616e7366657220746f20746865207a65726f206164604082015264647265737360d81b606082015260800190565b6020808252602a908201527f455243313135353a20696e73756666696369656e742062616c616e636520666f60408201526939103a3930b739b332b960b11b606082015260800190565b604081526000614cb4604083018561440f565b8281036020840152614cc6818561440f565b95945050505050565b6001600160a01b0386811682528516602082015260a060408201819052600090614cfb9083018661440f565b8281036060840152614d0d818661440f565b90508281036080840152614d218185614028565b98975050505050505050565b600060208284031215614d3f57600080fd5b8151611b0181613ff5565b600060033d1115614d635760046000803e5060005160e01c5b90565b600060443d1015614d745790565b6040516003193d81016004833e81513d6001600160401b038160248401118184111715614da357505050505090565b8285019150815181811115614dbb5750505050505090565b843d8701016020828501011115614dd55750505050505090565b614de4602082860101876140b7565b509095945050505050565b60208082526028908201527f455243313135353a204552433131353552656365697665722072656a656374656040820152676420746f6b656e7360c01b606082015260800190565b6001600160a01b03868116825285166020820152604081018490526060810183905260a060808201819052600090614e7190830184614028565b979650505050505050565b600082821015614e8e57614e8e6148d2565b50039056fea2646970667358221220b676a819dbff47cc00c26816728b1da02a00d591c7e638e777bce0660f65dd5564736f6c63430008090033
Deployed Bytecode
0x6080604052600436106103f95760003560e01c8063853828b611610213578063bec0904b11610123578063e985e9c5116100ab578063f242432a1161007a578063f242432a14610cae578063f2fde38b14610cce578063f7436e3714610cee578063fc2f383214610d0e578063fe6d3cc814610d2e57600080fd5b8063e985e9c514610bf0578063eb238e8114610c39578063eec8e90814610c6e578063f1e3311514610c8e57600080fd5b8063d8800f94116100f2578063d8800f9414610b61578063dcd4aa8b14610b81578063dfdedf6914610b96578063e6c6990a14610bb6578063e82da69114610bd057600080fd5b8063bec0904b14610ad9578063c5815c4114610b0e578063c94d8e7314610b2e578063d2de022f14610b4157600080fd5b8063a1af10ca116101a6578063bb6074e011610175578063bb6074e014610a43578063bb62115e14610a56578063bbd8556b14610a6c578063bc1f0ab514610a8c578063bd85b03914610aac57600080fd5b8063a1af10ca146109c3578063a22cb465146109e3578063ac80746a14610a03578063b40ebceb14610a2357600080fd5b80638da5cb5b116101e25780638da5cb5b1461094357806395d89b41146109615780639b192647146109765780639e490e241461099657600080fd5b8063853828b6146108a9578063869e9a00146108be578063891bbe73146108de5780638c04b8e91461091657600080fd5b80634790c9251161030e578063628d35c9116102a1578063715018a611610270578063715018a6146107f5578063736e04fa1461080a5780637aa9c33f1461083f57806383e083c31461085f5780638456cb591461089457600080fd5b8063628d35c9146107825780636586375b146107a25780636af3ef58146107c25780636c6acd4d146107d557600080fd5b80634e5298a0116102dd5780634e5298a0146106db5780634f558e791461071b5780635c975abb1461074a5780635cf4ee911461076257600080fd5b80634790c925146106345780634bf4e087146106545780634d09ae6d146106815780634e1273f4146106ae57600080fd5b80632eb2c2d6116103915780633e07311c116103605780633e07311c146105b65780633e511168146105cc5780633f4ba83a146105ec57806343696f1814610601578063449a52f81461062157600080fd5b80632eb2c2d6146105255780633832e8701461054557806338b903331461056557806338df41ac1461059657600080fd5b8063134902fd116103cd578063134902fd146104a3578063143727c9146104c3578063162094c4146104e3578063286c81371461050557600080fd5b8062fdd58e146103fe57806301ffc9a71461043157806306fdde03146104615780630e89341c14610483575b600080fd5b34801561040a57600080fd5b5061041e610419366004613fcb565b610d4e565b6040519081526020015b60405180910390f35b34801561043d57600080fd5b5061045161044c36600461400b565b610de7565b6040519015158152602001610428565b34801561046d57600080fd5b50610476610e39565b6040516104289190614075565b34801561048f57600080fd5b5061047661049e366004614088565b610ec7565b3480156104af57600080fd5b506104516104be366004614088565b610f93565b3480156104cf57600080fd5b5061041e6104de366004614088565b610fd7565b3480156104ef57600080fd5b506105036104fe366004614156565b61104b565b005b34801561051157600080fd5b5061041e610520366004614088565b6110e0565b34801561053157600080fd5b50610503610540366004614230565b611101565b34801561055157600080fd5b506105036105603660046142d9565b61122a565b34801561057157600080fd5b5060165461058490610100900460ff1681565b60405160ff9091168152602001610428565b3480156105a257600080fd5b506105036105b13660046142fb565b6113b7565b3480156105c257600080fd5b5061041e600d5481565b3480156105d857600080fd5b506105036105e73660046142d9565b611532565b3480156105f857600080fd5b506105036115da565b34801561060d57600080fd5b5061050361061c36600461432e565b61162a565b61050361062f366004613fcb565b611724565b34801561064057600080fd5b5061050361064f366004614088565b61187f565b34801561066057600080fd5b5061041e61066f366004614088565b60009081526012602052604090205490565b34801561068d57600080fd5b5061041e61069c366004614088565b6000908152600f602052604090205490565b3480156106ba57600080fd5b506106ce6106c93660046143b6565b61196d565b604051610428919061444a565b3480156106e757600080fd5b5061041e6106f636600461445d565b6001600160a01b03166000908152601360209081526040808320938352929052205490565b34801561072757600080fd5b50610451610736366004614088565b600090815260086020526040902054151590565b34801561075657600080fd5b5060065460ff16610451565b34801561076e57600080fd5b5061041e61077d3660046142d9565b611a96565b34801561078e57600080fd5b5061050361079d366004614088565b611b08565b3480156107ae57600080fd5b506105036107bd366004614088565b611b66565b6105036107d03660046142fb565b611bc4565b3480156107e157600080fd5b506105036107f0366004614489565b611d9e565b34801561080157600080fd5b50610503611e34565b34801561081657600080fd5b50610451610825366004614088565b60009081526011602052604090205460ff16151560011490565b34801561084b57600080fd5b5061050361085a3660046142d9565b611e6a565b34801561086b57600080fd5b5061045161087a366004614088565b6000908152600e602052604090205460ff16151560011490565b3480156108a057600080fd5b50610503611ec2565b3480156108b557600080fd5b50610503611f0e565b3480156108ca57600080fd5b506105036108d93660046144e4565b611f67565b3480156108ea57600080fd5b506108fe6108f9366004614088565b611fcd565b6040516001600160a01b039091168152602001610428565b34801561092257600080fd5b5061041e610931366004614088565b60009081526014602052604090205490565b34801561094f57600080fd5b506004546001600160a01b03166108fe565b34801561096d57600080fd5b50610476611ff7565b34801561098257600080fd5b50610503610991366004614088565b612004565b3480156109a257600080fd5b5061041e6109b1366004614088565b60009081526010602052604090205490565b3480156109cf57600080fd5b506104516109de36600461432e565b612065565b3480156109ef57600080fd5b506105036109fe366004614514565b6120e1565b348015610a0f57600080fd5b50610503610a1e36600461445d565b6120ec565b348015610a2f57600080fd5b50610503610a3e366004613fcb565b612158565b610503610a5136600461458b565b612391565b348015610a6257600080fd5b5061041e60185481565b348015610a7857600080fd5b50610503610a8736600461432e565b612595565b348015610a9857600080fd5b50610503610aa7366004614088565b612682565b348015610ab857600080fd5b5061041e610ac7366004614088565b60009081526008602052604090205490565b348015610ae557600080fd5b50610451610af4366004614088565b60009081526007602052604090205460ff16151560011490565b348015610b1a57600080fd5b50600a546108fe906001600160a01b031681565b610503610b3c3660046145f2565b6126e3565b348015610b4d57600080fd5b50610451610b5c3660046145f2565b612886565b348015610b6d57600080fd5b50610503610b7c3660046142d9565b612970565b348015610b8d57600080fd5b50610503612a38565b348015610ba257600080fd5b50610503610bb136600461432e565b612aa7565b348015610bc257600080fd5b506016546104519060ff1681565b348015610bdc57600080fd5b50610503610beb366004614088565b612ba3565b348015610bfc57600080fd5b50610451610c0b36600461464b565b6001600160a01b03918216600090815260026020908152604080832093909416825291909152205460ff1690565b348015610c4557600080fd5b50610451610c54366004614088565b60009081526015602052604090205460ff16151560011490565b348015610c7a57600080fd5b50610503610c89366004614088565b612c01565b348015610c9a57600080fd5b50610503610ca93660046142d9565b612cef565b348015610cba57600080fd5b50610503610cc9366004614675565b612da5565b348015610cda57600080fd5b50610503610ce936600461432e565b612e87565b348015610cfa57600080fd5b50610503610d093660046146d9565b612f22565b348015610d1a57600080fd5b50610451610d29366004614787565b61317d565b348015610d3a57600080fd5b50610503610d49366004614088565b613247565b60006001600160a01b038316610dbf5760405162461bcd60e51b815260206004820152602b60248201527f455243313135353a2062616c616e636520717565727920666f7220746865207a60448201526a65726f206164647265737360a81b60648201526084015b60405180910390fd5b5060009081526001602090815260408083206001600160a01b03949094168352929052205490565b60006001600160e01b03198216636cdb3d1360e11b1480610e1857506001600160e01b031982166303a24d0760e21b145b80610e3357506301ffc9a760e01b6001600160e01b03198316145b92915050565b60198054610e46906147bc565b80601f0160208091040260200160405190810160405280929190818152602001828054610e72906147bc565b8015610ebf5780601f10610e9457610100808354040283529160200191610ebf565b820191906000526020600020905b815481529060010190602001808311610ea257829003601f168201915b505050505081565b600081815260086020526040902054606090610ef55760405162461bcd60e51b8152600401610db6906147f7565b6000828152601b602052604090208054610f0e906147bc565b80601f0160208091040260200160405190810160405280929190818152602001828054610f3a906147bc565b8015610f875780601f10610f5c57610100808354040283529160200191610f87565b820191906000526020600020905b815481529060010190602001808311610f6a57829003601f168201915b50505050509050919050565b600081815260086020526040812054610fbe5760405162461bcd60e51b8152600401610db69061483c565b5060009081526020819052604090205460ff9081161490565b6000818152600860205260408120546110025760405162461bcd60e51b8152600401610db6906147f7565b6110208260009081526007602052604090205460ff16151560011490565b61103857600082815260096020526040902054610e33565b5060009081526008602052604090205490565b6004546001600160a01b0316339081149060009061106890612065565b905081806110735750805b61108f5760405162461bcd60e51b8152600401610db690614873565b6000848152600860205260409020546110ba5760405162461bcd60e51b8152600401610db6906147f7565b6000848152601b6020908152604090912084516110d992860190613f16565b5050505050565b600c81815481106110f057600080fd5b600091825260209091200154905081565b60005b835181101561119957600080858381518110611122576111226148bc565b60209081029190910181015182528101919091526040016000205460ff908116146111895760405162461bcd60e51b8152602060048201526017602482015276546f6b656e206973206e6f7420747261646561626c652160481b6044820152606401610db6565b611192816148e8565b9050611104565b506001600160a01b0385163314806111b657506111b68533610c0b565b61121d5760405162461bcd60e51b815260206004820152603260248201527f455243313135353a207472616e736665722063616c6c6572206973206e6f74206044820152711bdddb995c881b9bdc88185c1c1c9bdd995960721b6064820152608401610db6565b6110d985858585856132a8565b6004546001600160a01b0316339081149060009061124790612065565b905081806112525750805b61126e5760405162461bcd60e51b8152600401610db690614873565b6000848152600860205260409020546112995760405162461bcd60e51b8152600401610db6906147f7565b6112b78460009081526007602052604090205460ff16151560011490565b156113205760405162461bcd60e51b815260206004820152603360248201527f43616e6e6f742073657420746f6b656e20737570706c79207768696c6520696e6044820152721037b832b71032b234ba34b7b71036b7b2329760691b6064820152608401610db6565b60008481526009602052604090205483116113a35760405162461bcd60e51b815260206004820152603c60248201527f4e657720537570706c79204361702063616e206f6e6c7920626520677265617460448201527f6572207468616e2070726576696f757320737570706c79206361702e000000006064820152608401610db6565b505060009182526009602052604090912055565b6004546001600160a01b031633908114906000906113d490612065565b905081806113df5750805b6113fb5760405162461bcd60e51b8152600401610db690614873565b6000848152600860205260409020546114265760405162461bcd60e51b8152600401610db6906147f7565b600083116114765760405162461bcd60e51b815260206004820152601f60248201527f4d696e74696e67207175616e74697479206d757374206265206f7665722030006044820152606401610db6565b611480848461348e565b61149c5760405162461bcd60e51b8152600401610db690614903565b6110d9858585601780546114af906147bc565b80601f01602080910402602001604051908101604052809291908181526020018280546114db906147bc565b80156115285780601f106114fd57610100808354040283529160200191611528565b820191906000526020600020905b81548152906001019060200180831161150b57829003601f168201915b50505050506134dc565b6004546001600160a01b0316339081149060009061154f90612065565b9050818061155a5750805b6115765760405162461bcd60e51b8152600401610db690614873565b600083116115c65760405162461bcd60e51b815260206004820152601f60248201527f5175616e74697479206d757374206265206d6f7265207468616e207a65726f006044820152606401610db6565b505060009182526010602052604090912055565b6004546001600160a01b031633908114906000906115f790612065565b905081806116025750805b61161e5760405162461bcd60e51b8152600401610db690614873565b6116266135ee565b5050565b6004546001600160a01b031633146116545760405162461bcd60e51b8152600401610db690614948565b6001600160a01b03811661169c5760405162461bcd60e51b815260206004820152600f60248201526e496e76616c6964206164647265737360881b6044820152606401610db6565b6116a581612065565b156117005760405162461bcd60e51b815260206004820152602560248201527f54686973206164647265737320697320616c726561647920696e20796f7572206044820152643a32b0b69760d91b6064820152608401610db6565b6001600160a01b03166000908152600560205260409020805460ff19166001179055565b60065460ff16156117475760405162461bcd60e51b8152600401610db69061497d565b6000818152600860205260409020546117725760405162461bcd60e51b8152600401610db6906147f7565b61177d81600161348e565b6117995760405162461bcd60e51b8152600401610db690614903565b6117a4816001611a96565b34146117c25760405162461bcd60e51b8152600401610db6906149a7565b6117e08160009081526015602052604090205460ff16151560011490565b156117fd5760405162461bcd60e51b8152600401610db6906149ee565b61181b816000908152600e602052604090205460ff16151560011490565b6118375760405162461bcd60e51b8152600401610db690614a5b565b6118438183600161317d565b61185f5760405162461bcd60e51b8152600401610db690614a9d565b61186b81836001613681565b61162682826001601780546114af906147bc565b6004546001600160a01b0316339081149060009061189c90612065565b905081806118a75750805b6118c35760405162461bcd60e51b8152600401610db690614873565b60008381526020819052604090205460ff90811614156119255760405162461bcd60e51b815260206004820152601e60248201527f546f6b656e20494420697320616c726561647920747261646561626c652100006044820152606401610db6565b6000838152600860205260409020546119505760405162461bcd60e51b8152600401610db69061483c565b50506000908152602081905260409020805460ff191660ff179055565b606081518351146119d25760405162461bcd60e51b815260206004820152602960248201527f455243313135353a206163636f756e747320616e6420696473206c656e677468604482015268040dad2e6dac2e8c6d60bb1b6064820152608401610db6565b600083516001600160401b038111156119ed576119ed6140a1565b604051908082528060200260200182016040528015611a16578160200160208202803683370190505b50905060005b8451811015611a8e57611a61858281518110611a3a57611a3a6148bc565b6020026020010151858381518110611a5457611a546148bc565b6020026020010151610d4e565b828281518110611a7357611a736148bc565b6020908102919091010152611a87816148e8565b9050611a1c565b509392505050565b6000808211611ae75760405162461bcd60e51b815260206004820152601f60248201527f5175616e74697479206d757374206265206d6f7265207468616e207a65726f006044820152606401610db6565b6000838152600f6020526040902054611b01908390614ae3565b9392505050565b6004546001600160a01b03163390811490600090611b2590612065565b90508180611b305750805b611b4c5760405162461bcd60e51b8152600401610db690614873565b50506000908152600e60205260409020805460ff19169055565b6004546001600160a01b03163390811490600090611b8390612065565b90508180611b8e5750805b611baa5760405162461bcd60e51b8152600401610db690614873565b50506000908152601560205260409020805460ff19169055565b60065460ff1615611be75760405162461bcd60e51b8152600401610db69061497d565b600082815260086020526040902054611c125760405162461bcd60e51b8152600401610db6906147f7565b6001811015611c635760405162461bcd60e51b815260206004820152601a60248201527f4d757374206d696e74206174206c65617374203120746f6b656e0000000000006044820152606401610db6565b600082815260106020526040902054811115611c915760405162461bcd60e51b8152600401610db690614b02565b611c9b828261348e565b611cb75760405162461bcd60e51b8152600401610db690614903565b611cc18282611a96565b3414611cdf5760405162461bcd60e51b8152600401610db6906149a7565b611cfd8260009081526015602052604090205460ff16151560011490565b15611d1a5760405162461bcd60e51b8152600401610db6906149ee565b611d38826000908152600e602052604090205460ff16151560011490565b611d545760405162461bcd60e51b8152600401610db690614a5b565b611d5f82848361317d565b611d7b5760405162461bcd60e51b8152600401610db690614a9d565b611d86828483613681565b611d99838383601780546114af906147bc565b505050565b6004546001600160a01b03163390811490600090611dbb90612065565b90508180611dc65750805b611de25760405162461bcd60e51b8152600401610db690614873565b60005b8551811015611e2c57611e1a868281518110611e0357611e036148bc565b60200260200101518686601780546114af906147bc565b80611e24816148e8565b915050611de5565b505050505050565b6004546001600160a01b03163314611e5e5760405162461bcd60e51b8152600401610db690614948565b611e6860006136da565b565b6004546001600160a01b03163390811490600090611e8790612065565b90508180611e925750805b611eae5760405162461bcd60e51b8152600401610db690614873565b50506000918252600f602052604090912055565b6004546001600160a01b03163390811490600090611edf90612065565b90508180611eea5750805b611f065760405162461bcd60e51b8152600401610db690614873565b61162661372c565b6004546001600160a01b03163390811490600090611f2b90612065565b90508180611f365750805b611f525760405162461bcd60e51b8152600401610db690614873565b60004711611f5f57600080fd5b611626613784565b6004546001600160a01b03163390811490600090611f8490612065565b90508180611f8f5750805b611fab5760405162461bcd60e51b8152600401610db690614873565b5050600091825260076020526040909120805460ff1916911515919091179055565b600b8181548110611fdd57600080fd5b6000918252602090912001546001600160a01b0316905081565b601a8054610e46906147bc565b6004546001600160a01b0316339081149060009061202190612065565b9050818061202c5750805b6120485760405162461bcd60e51b8152600401610db690614873565b50506000908152600e60205260409020805460ff19166001179055565b60006001600160a01b0382166120bd5760405162461bcd60e51b815260206004820152601960248201527f496e76616c6964206164647265737320746f20636865636b2e000000000000006044820152606401610db6565b506001600160a01b031660009081526005602052604090205460ff16151560011490565b611626338383613812565b6004546001600160a01b0316339081149060009061210990612065565b905081806121145750805b6121305760405162461bcd60e51b8152600401610db690614873565b50506001600160a01b0316600090815260136020908152604080832093835292905290812055565b6004546001600160a01b0316339081149060009061217590612065565b905081806121805750805b61219c5760405162461bcd60e51b8152600401610db690614873565b600083116121a957600080fd5b6040516370a0823160e01b8152306004820152849084906001600160a01b038316906370a082319060240160206040518083038186803b1580156121ec57600080fd5b505afa158015612200573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906122249190614b50565b101561227e5760405162461bcd60e51b815260206004820152602360248201527f436f6e747261637420646f6573206e6f74206f776e20656e6f75676820746f6b604482015262656e7360e81b6064820152608401610db6565b60005b600d54811015611e2c57816001600160a01b031663a9059cbb600b83815481106122ad576122ad6148bc565b9060005260206000200160009054906101000a90046001600160a01b03166064600c85815481106122e0576122e06148bc565b9060005260206000200154896122f69190614ae3565b6123009190614b69565b6040516001600160e01b031960e085901b1681526001600160a01b0390921660048301526024820152604401602060405180830381600087803b15801561234657600080fd5b505af115801561235a573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061237e9190614b8b565b5080612389816148e8565b915050612281565b60065460ff16156123b45760405162461bcd60e51b8152600401610db69061497d565b6000848152600860205260409020546123df5760405162461bcd60e51b8152600401610db6906147f7565b60018310156124305760405162461bcd60e51b815260206004820152601a60248201527f4d757374206d696e74206174206c65617374203120746f6b656e0000000000006044820152606401610db6565b60008481526010602052604090205483111561245e5760405162461bcd60e51b8152600401610db690614b02565b612468848461348e565b6124845760405162461bcd60e51b8152600401610db690614903565b61248e8484611a96565b34146124ac5760405162461bcd60e51b8152600401610db6906149a7565b6124ca8460009081526015602052604090205460ff16151560011490565b80156124ef57506124ef846000908152600e602052604090205460ff16151560011490565b61250b5760405162461bcd60e51b8152600401610db690614ba8565b61251785858484612886565b6125635760405162461bcd60e51b815260206004820152601c60248201527f41646472657373206973206e6f7420696e20416c6c6f776c69737421000000006044820152606401610db6565b61256e84868561317d565b61258a5760405162461bcd60e51b8152600401610db690614a9d565b61149c848685613681565b600a546001600160a01b031633146125ef5760405162461bcd60e51b815260206004820152601c60248201527f4f776e61626c653a2063616c6c6572206973206e6f742052414d5050000000006044820152606401610db6565b600a546001600160a01b03828116911614156126605760405162461bcd60e51b815260206004820152602a60248201527f52414d50503a204e65772052616d70702061646472657373206d75737420626560448201526908191a5999995c995b9d60b21b6064820152608401610db6565b600a80546001600160a01b0319166001600160a01b0392909216919091179055565b6004546001600160a01b0316339081149060009061269f90612065565b905081806126aa5750805b6126c65760405162461bcd60e51b8152600401610db690614873565b50506000908152601560205260409020805460ff19166001179055565b60065460ff16156127065760405162461bcd60e51b8152600401610db69061497d565b6000838152600860205260409020546127315760405162461bcd60e51b8152600401610db6906147f7565b61273c83600161348e565b6127585760405162461bcd60e51b8152600401610db690614903565b612763836001611a96565b34146127815760405162461bcd60e51b8152600401610db6906149a7565b61279f8360009081526015602052604090205460ff16151560011490565b80156127c457506127c4836000908152600e602052604090205460ff16151560011490565b6127e05760405162461bcd60e51b8152600401610db690614ba8565b6127ec84848484612886565b6128385760405162461bcd60e51b815260206004820152601c60248201527f41646472657373206973206e6f7420696e20416c6c6f776c69737421000000006044820152606401610db6565b6128448385600161317d565b6128605760405162461bcd60e51b8152600401610db690614a9d565b61286c83856001613681565b61288084846001601780546114af906147bc565b50505050565b6000838152601460205260408120546128e15760405162461bcd60e51b815260206004820152601760248201527f4d65726b6c6520726f6f74206973206e6f7420736574210000000000000000006044820152606401610db6565b6040516bffffffffffffffffffffffff19606087901b16602082015260009060340160405160208183030381529060405280519060200120905061296684848080602002602001604051908101604052809392919081815260200183836020028082843760009201829052508a81526014602052604090205492508591506138f39050565b9695505050505050565b6004546001600160a01b0316339081149060009061298d90612065565b905081806129985750805b6129b45760405162461bcd60e51b8152600401610db690614873565b6001831015612a245760405162461bcd60e51b815260206004820152603660248201527f546f6b656e2077616c6c6574206d6178206d7573742062652067726561746572604482015275103a3430b71037b91032b8bab0b6103a379037b7329760511b6064820152608401610db6565b505060009182526012602052604090912055565b600a546001600160a01b03163314612a925760405162461bcd60e51b815260206004820152601c60248201527f4f776e61626c653a2063616c6c6572206973206e6f742052414d5050000000006044820152606401610db6565b60004711612a9f57600080fd5b611e68613784565b6004546001600160a01b03163314612ad15760405162461bcd60e51b8152600401610db690614948565b6001600160a01b038116612b195760405162461bcd60e51b815260206004820152600f60248201526e496e76616c6964206164647265737360881b6044820152606401610db6565b612b2281612065565b612b825760405162461bcd60e51b815260206004820152602b60248201527f546869732061646472657373206973206e6f7420696e20796f7572207465616d60448201526a1031bab93932b73a363c9760a91b6064820152608401610db6565b6001600160a01b03166000908152600560205260409020805460ff19169055565b6004546001600160a01b03163390811490600090612bc090612065565b90508180612bcb5750805b612be75760405162461bcd60e51b8152600401610db690614873565b50506000908152601160205260409020805460ff19169055565b6004546001600160a01b03163390811490600090612c1e90612065565b90508180612c295750805b612c455760405162461bcd60e51b8152600401610db690614873565b60008381526020819052604090205460ff1660011415612ca75760405162461bcd60e51b815260206004820181905260248201527f546f6b656e20494420697320616c726561647920756e747261646561626c65216044820152606401610db6565b600083815260086020526040902054612cd25760405162461bcd60e51b8152600401610db69061483c565b50506000908152602081905260409020805460ff19166001179055565b6004546001600160a01b03163390811490600090612d0c90612065565b90508180612d175750805b612d335760405162461bcd60e51b8152600401610db690614873565b600084815260146020526040902054831415612d915760405162461bcd60e51b815260206004820152601e60248201527f4d65726b6c6520726f6f742077696c6c20626520756e6368616e6765642100006044820152606401610db6565b505060009182526014602052604090912055565b60008381526020819052604090205460ff90811614612e005760405162461bcd60e51b8152602060048201526017602482015276546f6b656e206973206e6f7420747261646561626c652160481b6044820152606401610db6565b6001600160a01b038516331480612e1c5750612e1c8533610c0b565b612e7a5760405162461bcd60e51b815260206004820152602960248201527f455243313135353a2063616c6c6572206973206e6f74206f776e6572206e6f7260448201526808185c1c1c9bdd995960ba1b6064820152608401610db6565b6110d98585858585613909565b6004546001600160a01b03163314612eb15760405162461bcd60e51b8152600401610db690614948565b6001600160a01b038116612f165760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610db6565b612f1f816136da565b50565b6004546001600160a01b03163390811490600090612f3f90612065565b90508180612f4a5750805b612f665760405162461bcd60e51b8152600401610db690614873565b60008b11612fca5760405162461bcd60e51b815260206004820152602b60248201527f546f6b656e20537570706c7920436170206d757374206265206772656174657260448201526a103a3430b7103d32b9379760a91b6064820152608401610db6565b60008a116130335760405162461bcd60e51b815260206004820152603060248201527f546f6b656e205472616e73616374696f6e20436170206d75737420626520677260448201526f32b0ba32b9103a3430b7103d32b9379760811b6064820152608401610db6565b600083511161308f5760405162461bcd60e51b815260206004820152602260248201527f546f6b656e205552492063616e6e6f7420626520616e20656d7074792076616c604482015261756560f01b6064820152608401610db6565b6000613099613a2a565b90506130af33826001601780546114af906147bc565b6000818152601b6020908152604090912085516130ce92870190613f16565b506130d9818d61122a565b6130e3818b611e6a565b6130ed818c611532565b6000818152600e60205260409020805460ff19168a15151790556000818152601160209081526040808320805460ff19168b1515179055601290915290208690558761313a57600161313d565b60ff5b6000828152602081905260409020805460ff191660ff929092169190911790556131678186611f67565b61316f613a40565b505050505050505050505050565b60008381526011602052604081205460ff1615156001146131a057506001611b01565b60018210156132035760405162461bcd60e51b815260206004820152602960248201527f416d6f756e74206d7573742062652067726561746572207468616e206f7220656044820152687175616c20746f203160b81b6064820152608401610db6565b6000848152601260209081526040808320546001600160a01b0387168452601383528184208885529092529091205461323d908490614bfa565b1115949350505050565b6004546001600160a01b0316339081149060009061326490612065565b9050818061326f5750805b61328b5760405162461bcd60e51b8152600401610db690614873565b50506000908152601160205260409020805460ff19166001179055565b815183511461330a5760405162461bcd60e51b815260206004820152602860248201527f455243313135353a2069647320616e6420616d6f756e7473206c656e677468206044820152670dad2e6dac2e8c6d60c31b6064820152608401610db6565b6001600160a01b0384166133305760405162461bcd60e51b8152600401610db690614c12565b3361333f818787878787613a57565b60005b845181101561342857600085828151811061335f5761335f6148bc565b60200260200101519050600085838151811061337d5761337d6148bc565b60209081029190910181015160008481526001835260408082206001600160a01b038e1683529093529190912054909150818110156133ce5760405162461bcd60e51b8152600401610db690614c57565b60008381526001602090815260408083206001600160a01b038e8116855292528083208585039055908b1682528120805484929061340d908490614bfa565b9250508190555050505080613421906148e8565b9050613342565b50846001600160a01b0316866001600160a01b0316826001600160a01b03167f4a39dc06d4c0dbc64b70af90fd698a233a518aa5d07e595d983b8c0526c8f7fb8787604051613478929190614ca1565b60405180910390a4611e2c818787878787613a88565b60008281526007602052604081205460ff1615156001146134d3576134b283610fd7565b6000848152600860205260409020546134cc908490614bfa565b1115611b01565b50600192915050565b6001600160a01b03841661353c5760405162461bcd60e51b815260206004820152602160248201527f455243313135353a206d696e7420746f20746865207a65726f206164647265736044820152607360f81b6064820152608401610db6565b3361355c8160008761354d88613bf3565b61355688613bf3565b87613a57565b60008481526001602090815260408083206001600160a01b03891684529091528120805485929061358e908490614bfa565b909155505060408051858152602081018590526001600160a01b0380881692600092918516917fc3d58168c5ae7397731d063d5bbf3d657854427343f4c083240f7aacaa2d0f62910160405180910390a46110d981600087878787613c3e565b60065460ff166136375760405162461bcd60e51b815260206004820152601460248201527314185d5cd8589b194e881b9bdd081c185d5cd95960621b6044820152606401610db6565b6006805460ff191690557f5db9ee0a495bf2e6ff9c91a7834c1ba4fdd244a5e8aa4e537bd38aeae4b073aa335b6040516001600160a01b03909116815260200160405180910390a1565b6001600160a01b03821660009081526013602090815260408083208684529091529020546136b0908290614bfa565b6001600160a01b039092166000908152601360209081526040808320958352949052929092205550565b600480546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a35050565b60065460ff161561374f5760405162461bcd60e51b8152600401610db69061497d565b6006805460ff191660011790557f62e78cea01bee320cd4e420270b5ea74000d11b0c9f74754ebdbfc544b05a2586136643390565b4760005b600d5481101561162657613800600b82815481106137a8576137a86148bc565b9060005260206000200160009054906101000a90046001600160a01b03166064600c84815481106137db576137db6148bc565b9060005260206000200154856137f19190614ae3565b6137fb9190614b69565b613d08565b8061380a816148e8565b915050613788565b816001600160a01b0316836001600160a01b031614156138865760405162461bcd60e51b815260206004820152602960248201527f455243313135353a2073657474696e6720617070726f76616c20737461747573604482015268103337b91039b2b63360b91b6064820152608401610db6565b6001600160a01b03838116600081815260026020908152604080832094871680845294825291829020805460ff191686151590811790915591519182527f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c31910160405180910390a3505050565b6000826139008584613d9e565b14949350505050565b6001600160a01b03841661392f5760405162461bcd60e51b8152600401610db690614c12565b3361393f81878761354d88613bf3565b60008481526001602090815260408083206001600160a01b038a168452909152902054838110156139825760405162461bcd60e51b8152600401610db690614c57565b60008581526001602090815260408083206001600160a01b038b81168552925280832087850390559088168252812080548692906139c1908490614bfa565b909155505060408051868152602081018690526001600160a01b03808916928a821692918616917fc3d58168c5ae7397731d063d5bbf3d657854427343f4c083240f7aacaa2d0f62910160405180910390a4613a21828888888888613c3e565b50505050505050565b60006018546001613a3b9190614bfa565b905090565b60188054906000613a50836148e8565b9190505550565b60065460ff1615613a7a5760405162461bcd60e51b8152600401610db69061497d565b611e2c868686868686613e0a565b6001600160a01b0384163b15611e2c5760405163bc197c8160e01b81526001600160a01b0385169063bc197c8190613acc9089908990889088908890600401614ccf565b602060405180830381600087803b158015613ae657600080fd5b505af1925050508015613b16575060408051601f3d908101601f19168201909252613b1391810190614d2d565b60015b613bc357613b22614d4a565b806308c379a01415613b5c5750613b37614d66565b80613b425750613b5e565b8060405162461bcd60e51b8152600401610db69190614075565b505b60405162461bcd60e51b815260206004820152603460248201527f455243313135353a207472616e7366657220746f206e6f6e20455243313135356044820152732932b1b2b4bb32b91034b6b83632b6b2b73a32b960611b6064820152608401610db6565b6001600160e01b0319811663bc197c8160e01b14613a215760405162461bcd60e51b8152600401610db690614def565b60408051600180825281830190925260609160009190602080830190803683370190505090508281600081518110613c2d57613c2d6148bc565b602090810291909101015292915050565b6001600160a01b0384163b15611e2c5760405163f23a6e6160e01b81526001600160a01b0385169063f23a6e6190613c829089908990889088908890600401614e37565b602060405180830381600087803b158015613c9c57600080fd5b505af1925050508015613ccc575060408051601f3d908101601f19168201909252613cc991810190614d2d565b60015b613cd857613b22614d4a565b6001600160e01b0319811663f23a6e6160e01b14613a215760405162461bcd60e51b8152600401610db690614def565b6000826001600160a01b03168260405160006040518083038185875af1925050503d8060008114613d55576040519150601f19603f3d011682016040523d82523d6000602084013e613d5a565b606091505b5050905080611d995760405162461bcd60e51b815260206004820152601060248201526f2a3930b739b332b9103330b4b632b21760811b6044820152606401610db6565b600081815b8451811015611a8e576000858281518110613dc057613dc06148bc565b60200260200101519050808311613de65760008381526020829052604090209250613df7565b600081815260208490526040902092505b5080613e02816148e8565b915050613da3565b6001600160a01b038516613e915760005b8351811015613e8f57828181518110613e3657613e366148bc565b602002602001015160086000868481518110613e5457613e546148bc565b602002602001015181526020019081526020016000206000828254613e799190614bfa565b90915550613e889050816148e8565b9050613e1b565b505b6001600160a01b038416611e2c5760005b8351811015613a2157828181518110613ebd57613ebd6148bc565b602002602001015160086000868481518110613edb57613edb6148bc565b602002602001015181526020019081526020016000206000828254613f009190614e7c565b90915550613f0f9050816148e8565b9050613ea2565b828054613f22906147bc565b90600052602060002090601f016020900481019282613f445760008555613f8a565b82601f10613f5d57805160ff1916838001178555613f8a565b82800160010185558215613f8a579182015b82811115613f8a578251825591602001919060010190613f6f565b50613f96929150613f9a565b5090565b5b80821115613f965760008155600101613f9b565b80356001600160a01b0381168114613fc657600080fd5b919050565b60008060408385031215613fde57600080fd5b613fe783613faf565b946020939093013593505050565b6001600160e01b031981168114612f1f57600080fd5b60006020828403121561401d57600080fd5b8135611b0181613ff5565b6000815180845260005b8181101561404e57602081850181015186830182015201614032565b81811115614060576000602083870101525b50601f01601f19169290920160200192915050565b602081526000611b016020830184614028565b60006020828403121561409a57600080fd5b5035919050565b634e487b7160e01b600052604160045260246000fd5b601f8201601f191681016001600160401b03811182821017156140dc576140dc6140a1565b6040525050565b600082601f8301126140f457600080fd5b81356001600160401b0381111561410d5761410d6140a1565b604051614124601f8301601f1916602001826140b7565b81815284602083860101111561413957600080fd5b816020850160208301376000918101602001919091529392505050565b6000806040838503121561416957600080fd5b8235915060208301356001600160401b0381111561418657600080fd5b614192858286016140e3565b9150509250929050565b60006001600160401b038211156141b5576141b56140a1565b5060051b60200190565b600082601f8301126141d057600080fd5b813560206141dd8261419c565b6040516141ea82826140b7565b83815260059390931b850182019282810191508684111561420a57600080fd5b8286015b84811015614225578035835291830191830161420e565b509695505050505050565b600080600080600060a0868803121561424857600080fd5b61425186613faf565b945061425f60208701613faf565b935060408601356001600160401b038082111561427b57600080fd5b61428789838a016141bf565b9450606088013591508082111561429d57600080fd5b6142a989838a016141bf565b935060808801359150808211156142bf57600080fd5b506142cc888289016140e3565b9150509295509295909350565b600080604083850312156142ec57600080fd5b50508035926020909101359150565b60008060006060848603121561431057600080fd5b61431984613faf565b95602085013595506040909401359392505050565b60006020828403121561434057600080fd5b611b0182613faf565b600082601f83011261435a57600080fd5b813560206143678261419c565b60405161437482826140b7565b83815260059390931b850182019282810191508684111561439457600080fd5b8286015b84811015614225576143a981613faf565b8352918301918301614398565b600080604083850312156143c957600080fd5b82356001600160401b03808211156143e057600080fd5b6143ec86838701614349565b9350602085013591508082111561440257600080fd5b50614192858286016141bf565b600081518084526020808501945080840160005b8381101561443f57815187529582019590820190600101614423565b509495945050505050565b602081526000611b01602083018461440f565b6000806040838503121561447057600080fd5b8235915061448060208401613faf565b90509250929050565b60008060006060848603121561449e57600080fd5b83356001600160401b038111156144b457600080fd5b6144c086828701614349565b9660208601359650604090950135949350505050565b8015158114612f1f57600080fd5b600080604083850312156144f757600080fd5b823591506020830135614509816144d6565b809150509250929050565b6000806040838503121561452757600080fd5b61453083613faf565b91506020830135614509816144d6565b60008083601f84011261455257600080fd5b5081356001600160401b0381111561456957600080fd5b6020830191508360208260051b850101111561458457600080fd5b9250929050565b6000806000806000608086880312156145a357600080fd5b6145ac86613faf565b9450602086013593506040860135925060608601356001600160401b038111156145d557600080fd5b6145e188828901614540565b969995985093965092949392505050565b6000806000806060858703121561460857600080fd5b61461185613faf565b93506020850135925060408501356001600160401b0381111561463357600080fd5b61463f87828801614540565b95989497509550505050565b6000806040838503121561465e57600080fd5b61466783613faf565b915061448060208401613faf565b600080600080600060a0868803121561468d57600080fd5b61469686613faf565b94506146a460208701613faf565b9350604086013592506060860135915060808601356001600160401b038111156146cd57600080fd5b6142cc888289016140e3565b60008060008060008060008060006101208a8c0312156146f857600080fd5b8935985060208a0135975060408a0135965060608a0135614718816144d6565b955060808a0135614728816144d6565b945060a08a0135614738816144d6565b935060c08a0135925060e08a013561474f816144d6565b91506101008a01356001600160401b0381111561476b57600080fd5b6147778c828d016140e3565b9150509295985092959850929598565b60008060006060848603121561479c57600080fd5b833592506147ac60208501613faf565b9150604084013590509250925092565b600181811c908216806147d057607f821691505b602082108114156147f157634e487b7160e01b600052602260045260246000fd5b50919050565b60208082526025908201527f4552433732315472616461626c65237572693a204e4f4e4558495354454e545f6040820152642a27a5a2a760d91b606082015260800190565b60208082526018908201527f546f6b656e20494420646f6573206e6f74206578697374210000000000000000604082015260600190565b60208082526029908201527f5465616d3a2063616c6c6572206973206e6f7420746865206f776e6572206f726040820152681034b7102a32b0b69760b91b606082015260800190565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b60006000198214156148fc576148fc6148d2565b5060010190565b60208082526025908201527f43616e6e6f74206d696e74206f76657220737570706c7920636170206f6620746040820152646f6b656e2160d81b606082015260800190565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b60208082526010908201526f14185d5cd8589b194e881c185d5cd95960821b604082015260600190565b60208082526027908201527f56616c7565206e6565647320746f2062652065786163746c7920746865206d696040820152666e74206665652160c81b606082015260800190565b60208082526047908201527f5075626c6963206d696e74696e67206973206e6f7420656e61626c656420776860408201527f696c6520636f6e747261637420697320696e20616c6c6f776c697374206f6e6c6060820152663c9036b7b2329760c91b608082015260a00190565b60208082526022908201527f4d696e74696e6720666f72207468697320746f6b656e206973206e6f74206f7060408201526132b760f11b606082015260800190565b60208082526026908201527f57616c6c6574206d696e74206d6178696d756d207265616368656420666f72206040820152653a37b5b2b71760d11b606082015260800190565b6000816000190483118215151615614afd57614afd6148d2565b500290565b6020808252602e908201527f43616e6e6f74206d696e74206d6f7265207468616e206d6178206d696e74207060408201526d32b9103a3930b739b0b1ba34b7b760911b606082015260800190565b600060208284031215614b6257600080fd5b5051919050565b600082614b8657634e487b7160e01b600052601260045260246000fd5b500490565b600060208284031215614b9d57600080fd5b8151611b01816144d6565b60208082526032908201527f416c6c6f776c697374204d6f646520616e64204d696e74696e67206d75737420604082015271189948195b98589b1959081d1bc81b5a5b9d60721b606082015260800190565b60008219821115614c0d57614c0d6148d2565b500190565b60208082526025908201527f455243313135353a207472616e7366657220746f20746865207a65726f206164604082015264647265737360d81b606082015260800190565b6020808252602a908201527f455243313135353a20696e73756666696369656e742062616c616e636520666f60408201526939103a3930b739b332b960b11b606082015260800190565b604081526000614cb4604083018561440f565b8281036020840152614cc6818561440f565b95945050505050565b6001600160a01b0386811682528516602082015260a060408201819052600090614cfb9083018661440f565b8281036060840152614d0d818661440f565b90508281036080840152614d218185614028565b98975050505050505050565b600060208284031215614d3f57600080fd5b8151611b0181613ff5565b600060033d1115614d635760046000803e5060005160e01c5b90565b600060443d1015614d745790565b6040516003193d81016004833e81513d6001600160401b038160248401118184111715614da357505050505090565b8285019150815181811115614dbb5750505050505090565b843d8701016020828501011115614dd55750505050505090565b614de4602082860101876140b7565b509095945050505050565b60208082526028908201527f455243313135353a204552433131353552656365697665722072656a656374656040820152676420746f6b656e7360c01b606082015260800190565b6001600160a01b03868116825285166020820152604081018490526060810183905260a060808201819052600090614e7190830184614028565b979650505050505050565b600082821015614e8e57614e8e6148d2565b50039056fea2646970667358221220b676a819dbff47cc00c26816728b1da02a00d591c7e638e777bce0660f65dd5564736f6c63430008090033
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.