Feature Tip: Add private address tag to any address under My Name Tag !
ERC-1155
Overview
Max Total Supply
1,352 PCKLEDNS
Holders
969
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:
PickleEditions
Compiler Version
v0.8.17+commit.8df45f5f
Optimization Enabled:
No with 200 runs
Other Settings:
default evmVersion
Contract Source Code (Solidity Standard Json-Input format)
// SPDX-License-Identifier: MIT pragma solidity ^0.8.0; /** * ██████ ██ ██████ ██ ██ ██ ███████ * ██ ██ ██ ██ ██ ██ ██ ██ * ██████ ██ ██ █████ ██ █████ * ██ ██ ██ ██ ██ ██ ██ * ██ ██ ██████ ██ ██ ███████ ███████ * * * ███████ ██████ ██ ████████ ██ ██████ ███ ██ ███████ * ██ ██ ██ ██ ██ ██ ██ ██ ████ ██ ██ * █████ ██ ██ ██ ██ ██ ██ ██ ██ ██ ██ ███████ * ██ ██ ██ ██ ██ ██ ██ ██ ██ ██ ██ ██ * ███████ ██████ ██ ██ ██ ██████ ██ ████ ███████ * * by @wij_not + @p0pps for Mustard Labs Novemeber 2022 */ import "@openzeppelin/contracts/access/AccessControl.sol"; import "@openzeppelin/contracts/token/ERC1155/ERC1155.sol"; import "@openzeppelin/contracts/token/ERC1155/extensions/ERC1155Supply.sol"; import "@openzeppelin/contracts/interfaces/IERC1363.sol"; import "@openzeppelin/contracts/interfaces/IERC1363Receiver.sol"; import "@openzeppelin/contracts/utils/Strings.sol"; contract PickleEditions is AccessControl, ERC1155, ERC1155Supply, IERC1363Receiver { using Strings for uint256; bytes32 public constant MINTER_ROLE = keccak256("MINTER_ROLE"); address public beneficiary; address public ml_beneficiary; uint public split; IERC1363 public immutable token; mapping(uint256 => uint256) public prices; mapping(uint256 => uint256) public minted; mapping(uint256 => uint256) public available; mapping(uint256 => uint256) private limits; mapping(uint256 => string) private customURIs; string private suffix = ".json"; string public name = "Pickle Editions"; string public symbol = "PCKLEDNS"; constructor() ERC1155("") { _grantRole(DEFAULT_ADMIN_ROLE, msg.sender); _grantRole(MINTER_ROLE, msg.sender); // token = IERC1363(0xf46AbB1865Fbef39c2a02B33C0EBAE2Fb9E897AB); // REG on goerli token = IERC1363(0x78b5C6149C87c82EDCffC73C230395abbc56DdD5); // REG on mainnet setURI("https://static.mustardlabs.io/pickles/editions/data/"); // default base URI prices[1] = 69 * 10 ** 18; available[1] = 64; split = 50; beneficiary = msg.sender; ml_beneficiary = 0xb4005DB54aDecf669BaBC3efb19B9B7E3978ebc2; } // view function limit(uint _tokenId) public view returns (uint) { return limits[_tokenId] + 1; } function intToBytes(uint _itemId) public pure returns (bytes memory) { return abi.encode(_itemId); } // mint function onTransferReceived(address operator, address from, uint256 value, bytes memory data) public override returns (bytes4) { require(msg.sender == address(token)); uint256 itemId = abi.decode(data, (uint256)); uint256 itemPrice = prices[itemId]; require(itemPrice > 0, "Item price not set"); require(value >= itemPrice, "invalid payment value"); require(minted[itemId] <= available[itemId], "None left to mint"); require(balanceOf(operator, itemId) <= limits[itemId], "Already minted limit"); uint _splitAmount = (itemPrice * split) / 100; token.transfer(beneficiary, _splitAmount); token.transfer(ml_beneficiary, itemPrice - _splitAmount); minted[itemId]++; _mint(operator, itemId, 1, bytes("")); if (value > itemPrice) { token.transfer(from, value - itemPrice); } return IERC1363Receiver.onTransferReceived.selector; } // admin function setURI(string memory newuri) public onlyRole(MINTER_ROLE) { _setURI(newuri); } function mint(address _to, uint _itemId, uint _count) public onlyRole(MINTER_ROLE) { _mint(_to, _itemId, _count, bytes("")); } function setPrice(uint256 itemId, uint256 newprice) public onlyRole(MINTER_ROLE) { prices[itemId] = newprice; } function setLimits(uint256 itemId, uint256 _limit) public onlyRole(MINTER_ROLE) { limits[itemId] = _limit; } function setNumAvailable(uint256 itemId, uint256 _limit) public onlyRole(MINTER_ROLE) { available[itemId] = _limit; } function increaseNumAvailable(uint itemId, uint _value) public onlyRole(MINTER_ROLE) { available[itemId] += _value; } function setURISuffix(string memory _suffix) public onlyRole(MINTER_ROLE) { suffix = _suffix; } function setName(string memory _name) public onlyRole(MINTER_ROLE) { name = _name; } function setSplit(uint _val) public { require(msg.sender == ml_beneficiary, "Not ml admin"); split = _val; } function setMLBenefiary(address _addr) public { require(msg.sender == ml_beneficiary, "Not ml admin"); ml_beneficiary = _addr; } function setCustomBaseURI(uint itemId, string memory _uri) public onlyRole(MINTER_ROLE) { // ex. "ipfs://QmWnXeqt4goxe7FiUaBsRrg4C75byJLSixzYKPZyD77Wm1/" customURIs[itemId] = _uri; } // overrides function uri(uint256 id) public view override returns (string memory) { string memory _filename = string.concat(id.toString(), suffix); return bytes(customURIs[id]).length > 0 ? string.concat(customURIs[id], _filename) : string.concat(super.uri(id), _filename); } function _beforeTokenTransfer(address operator, address from, address to, uint256[] memory ids, uint256[] memory amounts, bytes memory data) internal override(ERC1155, ERC1155Supply) { super._beforeTokenTransfer(operator, from, to, ids, amounts, data); } function supportsInterface(bytes4 interfaceId) public view override(ERC1155, AccessControl) returns (bool) { return super.supportsInterface(interfaceId); } }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts (last updated v4.8.0) (utils/Strings.sol) pragma solidity ^0.8.0; import "./math/Math.sol"; /** * @dev String operations. */ library Strings { bytes16 private constant _SYMBOLS = "0123456789abcdef"; uint8 private constant _ADDRESS_LENGTH = 20; /** * @dev Converts a `uint256` to its ASCII `string` decimal representation. */ function toString(uint256 value) internal pure returns (string memory) { unchecked { uint256 length = Math.log10(value) + 1; string memory buffer = new string(length); uint256 ptr; /// @solidity memory-safe-assembly assembly { ptr := add(buffer, add(32, length)) } while (true) { ptr--; /// @solidity memory-safe-assembly assembly { mstore8(ptr, byte(mod(value, 10), _SYMBOLS)) } value /= 10; if (value == 0) break; } return buffer; } } /** * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation. */ function toHexString(uint256 value) internal pure returns (string memory) { unchecked { return toHexString(value, Math.log256(value) + 1); } } /** * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation with fixed length. */ function toHexString(uint256 value, uint256 length) internal pure returns (string memory) { bytes memory buffer = new bytes(2 * length + 2); buffer[0] = "0"; buffer[1] = "x"; for (uint256 i = 2 * length + 1; i > 1; --i) { buffer[i] = _SYMBOLS[value & 0xf]; value >>= 4; } require(value == 0, "Strings: hex length insufficient"); return string(buffer); } /** * @dev Converts an `address` with fixed length of 20 bytes to its not checksummed ASCII `string` hexadecimal representation. */ function toHexString(address addr) internal pure returns (string memory) { return toHexString(uint256(uint160(addr)), _ADDRESS_LENGTH); } }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts v4.4.1 (interfaces/IERC1363Receiver.sol) pragma solidity ^0.8.0; interface IERC1363Receiver { /* * Note: the ERC-165 identifier for this interface is 0x88a7ca5c. * 0x88a7ca5c === bytes4(keccak256("onTransferReceived(address,address,uint256,bytes)")) */ /** * @notice Handle the receipt of ERC1363 tokens * @dev Any ERC1363 smart contract calls this function on the recipient * after a `transfer` or a `transferFrom`. This function MAY throw to revert and reject the * transfer. Return of other than the magic value MUST result in the * transaction being reverted. * Note: the token contract address is always the message sender. * @param operator address The address which called `transferAndCall` or `transferFromAndCall` function * @param from address The address which are token transferred from * @param value uint256 The amount of tokens transferred * @param data bytes Additional data with no specified format * @return `bytes4(keccak256("onTransferReceived(address,address,uint256,bytes)"))` * unless throwing */ function onTransferReceived( address operator, address from, uint256 value, bytes memory data ) external returns (bytes4); }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts v4.4.1 (interfaces/IERC1363.sol) pragma solidity ^0.8.0; import "./IERC20.sol"; import "./IERC165.sol"; interface IERC1363 is IERC165, IERC20 { /* * Note: the ERC-165 identifier for this interface is 0x4bbee2df. * 0x4bbee2df === * bytes4(keccak256('transferAndCall(address,uint256)')) ^ * bytes4(keccak256('transferAndCall(address,uint256,bytes)')) ^ * bytes4(keccak256('transferFromAndCall(address,address,uint256)')) ^ * bytes4(keccak256('transferFromAndCall(address,address,uint256,bytes)')) */ /* * Note: the ERC-165 identifier for this interface is 0xfb9ec8ce. * 0xfb9ec8ce === * bytes4(keccak256('approveAndCall(address,uint256)')) ^ * bytes4(keccak256('approveAndCall(address,uint256,bytes)')) */ /** * @dev Transfer tokens from `msg.sender` to another address and then call `onTransferReceived` on receiver * @param to address The address which you want to transfer to * @param value uint256 The amount of tokens to be transferred * @return true unless throwing */ function transferAndCall(address to, uint256 value) external returns (bool); /** * @dev Transfer tokens from `msg.sender` to another address and then call `onTransferReceived` on receiver * @param to address The address which you want to transfer to * @param value uint256 The amount of tokens to be transferred * @param data bytes Additional data with no specified format, sent in call to `to` * @return true unless throwing */ function transferAndCall( address to, uint256 value, bytes memory data ) external returns (bool); /** * @dev Transfer tokens from one address to another and then call `onTransferReceived` on receiver * @param from address The address which you want to send tokens from * @param to address The address which you want to transfer to * @param value uint256 The amount of tokens to be transferred * @return true unless throwing */ function transferFromAndCall( address from, address to, uint256 value ) external returns (bool); /** * @dev Transfer tokens from one address to another and then call `onTransferReceived` on receiver * @param from address The address which you want to send tokens from * @param to address The address which you want to transfer to * @param value uint256 The amount of tokens to be transferred * @param data bytes Additional data with no specified format, sent in call to `to` * @return true unless throwing */ function transferFromAndCall( address from, address to, uint256 value, bytes memory data ) external returns (bool); /** * @dev Approve the passed address to spend the specified amount of tokens on behalf of msg.sender * and then call `onApprovalReceived` on spender. * @param spender address The address which will spend the funds * @param value uint256 The amount of tokens to be spent */ function approveAndCall(address spender, uint256 value) external returns (bool); /** * @dev Approve the passed address to spend the specified amount of tokens on behalf of msg.sender * and then call `onApprovalReceived` on spender. * @param spender address The address which will spend the funds * @param value uint256 The amount of tokens to be spent * @param data bytes Additional data with no specified format, sent in call to `spender` */ function approveAndCall( address spender, uint256 value, bytes memory data ) external returns (bool); }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts (last updated v4.6.0) (token/ERC1155/extensions/ERC1155Supply.sol) pragma solidity ^0.8.0; import "../ERC1155.sol"; /** * @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 { mapping(uint256 => uint256) private _totalSupply; /** * @dev Total amount of tokens in with a given id. */ function totalSupply(uint256 id) public view virtual returns (uint256) { return _totalSupply[id]; } /** * @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) { uint256 id = ids[i]; uint256 amount = amounts[i]; uint256 supply = _totalSupply[id]; require(supply >= amount, "ERC1155: burn amount exceeds totalSupply"); unchecked { _totalSupply[id] = supply - amount; } } } } }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts (last updated v4.8.0) (token/ERC1155/ERC1155.sol) pragma solidity ^0.8.0; import "./IERC1155.sol"; import "./IERC1155Receiver.sol"; import "./extensions/IERC1155MetadataURI.sol"; import "../../utils/Address.sol"; import "../../utils/Context.sol"; import "../../utils/introspection/ERC165.sol"; /** * @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 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: address zero is not a valid owner"); 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( from == _msgSender() || isApprovedForAll(from, _msgSender()), "ERC1155: caller is not token owner or 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 { require( from == _msgSender() || isApprovedForAll(from, _msgSender()), "ERC1155: caller is not token owner or 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(); uint256[] memory ids = _asSingletonArray(id); uint256[] memory amounts = _asSingletonArray(amount); _beforeTokenTransfer(operator, from, to, ids, amounts, 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); _afterTokenTransfer(operator, from, to, ids, amounts, data); _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); _afterTokenTransfer(operator, from, to, ids, amounts, data); _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(); uint256[] memory ids = _asSingletonArray(id); uint256[] memory amounts = _asSingletonArray(amount); _beforeTokenTransfer(operator, address(0), to, ids, amounts, data); _balances[id][to] += amount; emit TransferSingle(operator, address(0), to, id, amount); _afterTokenTransfer(operator, address(0), to, ids, amounts, data); _doSafeTransferAcceptanceCheck(operator, address(0), to, id, amount, data); } /** * @dev xref:ROOT:erc1155.adoc#batch-operations[Batched] version of {_mint}. * * 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 _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); _afterTokenTransfer(operator, address(0), to, ids, amounts, data); _doSafeBatchTransferAcceptanceCheck(operator, address(0), to, ids, amounts, data); } /** * @dev Destroys `amount` tokens of token type `id` from `from` * * Emits a {TransferSingle} event. * * 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(); uint256[] memory ids = _asSingletonArray(id); uint256[] memory amounts = _asSingletonArray(amount); _beforeTokenTransfer(operator, from, address(0), ids, amounts, ""); 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); _afterTokenTransfer(operator, from, address(0), ids, amounts, ""); } /** * @dev xref:ROOT:erc1155.adoc#batch-operations[Batched] version of {_burn}. * * Emits a {TransferBatch} event. * * 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); _afterTokenTransfer(operator, from, address(0), ids, amounts, ""); } /** * @dev Approve `operator` to operate on all of `owner` tokens * * Emits an {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 `ids` and `amounts` 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 {} /** * @dev Hook that is called after 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 _afterTokenTransfer( 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; } }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts (last updated v4.8.0) (access/AccessControl.sol) pragma solidity ^0.8.0; import "./IAccessControl.sol"; import "../utils/Context.sol"; import "../utils/Strings.sol"; import "../utils/introspection/ERC165.sol"; /** * @dev Contract module that allows children to implement role-based access * control mechanisms. This is a lightweight version that doesn't allow enumerating role * members except through off-chain means by accessing the contract event logs. Some * applications may benefit from on-chain enumerability, for those cases see * {AccessControlEnumerable}. * * Roles are referred to by their `bytes32` identifier. These should be exposed * in the external API and be unique. The best way to achieve this is by * using `public constant` hash digests: * * ``` * bytes32 public constant MY_ROLE = keccak256("MY_ROLE"); * ``` * * Roles can be used to represent a set of permissions. To restrict access to a * function call, use {hasRole}: * * ``` * function foo() public { * require(hasRole(MY_ROLE, msg.sender)); * ... * } * ``` * * Roles can be granted and revoked dynamically via the {grantRole} and * {revokeRole} functions. Each role has an associated admin role, and only * accounts that have a role's admin role can call {grantRole} and {revokeRole}. * * By default, the admin role for all roles is `DEFAULT_ADMIN_ROLE`, which means * that only accounts with this role will be able to grant or revoke other * roles. More complex role relationships can be created by using * {_setRoleAdmin}. * * WARNING: The `DEFAULT_ADMIN_ROLE` is also its own admin: it has permission to * grant and revoke this role. Extra precautions should be taken to secure * accounts that have been granted it. */ abstract contract AccessControl is Context, IAccessControl, ERC165 { struct RoleData { mapping(address => bool) members; bytes32 adminRole; } mapping(bytes32 => RoleData) private _roles; bytes32 public constant DEFAULT_ADMIN_ROLE = 0x00; /** * @dev Modifier that checks that an account has a specific role. Reverts * with a standardized message including the required role. * * The format of the revert reason is given by the following regular expression: * * /^AccessControl: account (0x[0-9a-f]{40}) is missing role (0x[0-9a-f]{64})$/ * * _Available since v4.1._ */ modifier onlyRole(bytes32 role) { _checkRole(role); _; } /** * @dev See {IERC165-supportsInterface}. */ function supportsInterface(bytes4 interfaceId) public view virtual override returns (bool) { return interfaceId == type(IAccessControl).interfaceId || super.supportsInterface(interfaceId); } /** * @dev Returns `true` if `account` has been granted `role`. */ function hasRole(bytes32 role, address account) public view virtual override returns (bool) { return _roles[role].members[account]; } /** * @dev Revert with a standard message if `_msgSender()` is missing `role`. * Overriding this function changes the behavior of the {onlyRole} modifier. * * Format of the revert message is described in {_checkRole}. * * _Available since v4.6._ */ function _checkRole(bytes32 role) internal view virtual { _checkRole(role, _msgSender()); } /** * @dev Revert with a standard message if `account` is missing `role`. * * The format of the revert reason is given by the following regular expression: * * /^AccessControl: account (0x[0-9a-f]{40}) is missing role (0x[0-9a-f]{64})$/ */ function _checkRole(bytes32 role, address account) internal view virtual { if (!hasRole(role, account)) { revert( string( abi.encodePacked( "AccessControl: account ", Strings.toHexString(account), " is missing role ", Strings.toHexString(uint256(role), 32) ) ) ); } } /** * @dev Returns the admin role that controls `role`. See {grantRole} and * {revokeRole}. * * To change a role's admin, use {_setRoleAdmin}. */ function getRoleAdmin(bytes32 role) public view virtual override returns (bytes32) { return _roles[role].adminRole; } /** * @dev Grants `role` to `account`. * * If `account` had not been already granted `role`, emits a {RoleGranted} * event. * * Requirements: * * - the caller must have ``role``'s admin role. * * May emit a {RoleGranted} event. */ function grantRole(bytes32 role, address account) public virtual override onlyRole(getRoleAdmin(role)) { _grantRole(role, account); } /** * @dev Revokes `role` from `account`. * * If `account` had been granted `role`, emits a {RoleRevoked} event. * * Requirements: * * - the caller must have ``role``'s admin role. * * May emit a {RoleRevoked} event. */ function revokeRole(bytes32 role, address account) public virtual override onlyRole(getRoleAdmin(role)) { _revokeRole(role, account); } /** * @dev Revokes `role` from the calling account. * * Roles are often managed via {grantRole} and {revokeRole}: this function's * purpose is to provide a mechanism for accounts to lose their privileges * if they are compromised (such as when a trusted device is misplaced). * * If the calling account had been revoked `role`, emits a {RoleRevoked} * event. * * Requirements: * * - the caller must be `account`. * * May emit a {RoleRevoked} event. */ function renounceRole(bytes32 role, address account) public virtual override { require(account == _msgSender(), "AccessControl: can only renounce roles for self"); _revokeRole(role, account); } /** * @dev Grants `role` to `account`. * * If `account` had not been already granted `role`, emits a {RoleGranted} * event. Note that unlike {grantRole}, this function doesn't perform any * checks on the calling account. * * May emit a {RoleGranted} event. * * [WARNING] * ==== * This function should only be called from the constructor when setting * up the initial roles for the system. * * Using this function in any other way is effectively circumventing the admin * system imposed by {AccessControl}. * ==== * * NOTE: This function is deprecated in favor of {_grantRole}. */ function _setupRole(bytes32 role, address account) internal virtual { _grantRole(role, account); } /** * @dev Sets `adminRole` as ``role``'s admin role. * * Emits a {RoleAdminChanged} event. */ function _setRoleAdmin(bytes32 role, bytes32 adminRole) internal virtual { bytes32 previousAdminRole = getRoleAdmin(role); _roles[role].adminRole = adminRole; emit RoleAdminChanged(role, previousAdminRole, adminRole); } /** * @dev Grants `role` to `account`. * * Internal function without access restriction. * * May emit a {RoleGranted} event. */ function _grantRole(bytes32 role, address account) internal virtual { if (!hasRole(role, account)) { _roles[role].members[account] = true; emit RoleGranted(role, account, _msgSender()); } } /** * @dev Revokes `role` from `account`. * * Internal function without access restriction. * * May emit a {RoleRevoked} event. */ function _revokeRole(bytes32 role, address account) internal virtual { if (hasRole(role, account)) { _roles[role].members[account] = false; emit RoleRevoked(role, account, _msgSender()); } } }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts (last updated v4.8.0) (utils/math/Math.sol) pragma solidity ^0.8.0; /** * @dev Standard math utilities missing in the Solidity language. */ library Math { enum Rounding { Down, // Toward negative infinity Up, // Toward infinity Zero // Toward zero } /** * @dev Returns the largest of two numbers. */ function max(uint256 a, uint256 b) internal pure returns (uint256) { return a > b ? a : b; } /** * @dev Returns the smallest of two numbers. */ function min(uint256 a, uint256 b) internal pure returns (uint256) { return a < b ? a : b; } /** * @dev Returns the average of two numbers. The result is rounded towards * zero. */ function average(uint256 a, uint256 b) internal pure returns (uint256) { // (a + b) / 2 can overflow. return (a & b) + (a ^ b) / 2; } /** * @dev Returns the ceiling of the division of two numbers. * * This differs from standard division with `/` in that it rounds up instead * of rounding down. */ function ceilDiv(uint256 a, uint256 b) internal pure returns (uint256) { // (a + b - 1) / b can overflow on addition, so we distribute. return a == 0 ? 0 : (a - 1) / b + 1; } /** * @notice Calculates floor(x * y / denominator) with full precision. Throws if result overflows a uint256 or denominator == 0 * @dev Original credit to Remco Bloemen under MIT license (https://xn--2-umb.com/21/muldiv) * with further edits by Uniswap Labs also under MIT license. */ function mulDiv( uint256 x, uint256 y, uint256 denominator ) internal pure returns (uint256 result) { unchecked { // 512-bit multiply [prod1 prod0] = x * y. Compute the product mod 2^256 and mod 2^256 - 1, then use // use the Chinese Remainder Theorem to reconstruct the 512 bit result. The result is stored in two 256 // variables such that product = prod1 * 2^256 + prod0. uint256 prod0; // Least significant 256 bits of the product uint256 prod1; // Most significant 256 bits of the product assembly { let mm := mulmod(x, y, not(0)) prod0 := mul(x, y) prod1 := sub(sub(mm, prod0), lt(mm, prod0)) } // Handle non-overflow cases, 256 by 256 division. if (prod1 == 0) { return prod0 / denominator; } // Make sure the result is less than 2^256. Also prevents denominator == 0. require(denominator > prod1); /////////////////////////////////////////////// // 512 by 256 division. /////////////////////////////////////////////// // Make division exact by subtracting the remainder from [prod1 prod0]. uint256 remainder; assembly { // Compute remainder using mulmod. remainder := mulmod(x, y, denominator) // Subtract 256 bit number from 512 bit number. prod1 := sub(prod1, gt(remainder, prod0)) prod0 := sub(prod0, remainder) } // Factor powers of two out of denominator and compute largest power of two divisor of denominator. Always >= 1. // See https://cs.stackexchange.com/q/138556/92363. // Does not overflow because the denominator cannot be zero at this stage in the function. uint256 twos = denominator & (~denominator + 1); assembly { // Divide denominator by twos. denominator := div(denominator, twos) // Divide [prod1 prod0] by twos. prod0 := div(prod0, twos) // Flip twos such that it is 2^256 / twos. If twos is zero, then it becomes one. twos := add(div(sub(0, twos), twos), 1) } // Shift in bits from prod1 into prod0. prod0 |= prod1 * twos; // Invert denominator mod 2^256. Now that denominator is an odd number, it has an inverse modulo 2^256 such // that denominator * inv = 1 mod 2^256. Compute the inverse by starting with a seed that is correct for // four bits. That is, denominator * inv = 1 mod 2^4. uint256 inverse = (3 * denominator) ^ 2; // Use the Newton-Raphson iteration to improve the precision. Thanks to Hensel's lifting lemma, this also works // in modular arithmetic, doubling the correct bits in each step. inverse *= 2 - denominator * inverse; // inverse mod 2^8 inverse *= 2 - denominator * inverse; // inverse mod 2^16 inverse *= 2 - denominator * inverse; // inverse mod 2^32 inverse *= 2 - denominator * inverse; // inverse mod 2^64 inverse *= 2 - denominator * inverse; // inverse mod 2^128 inverse *= 2 - denominator * inverse; // inverse mod 2^256 // Because the division is now exact we can divide by multiplying with the modular inverse of denominator. // This will give us the correct result modulo 2^256. Since the preconditions guarantee that the outcome is // less than 2^256, this is the final result. We don't need to compute the high bits of the result and prod1 // is no longer required. result = prod0 * inverse; return result; } } /** * @notice Calculates x * y / denominator with full precision, following the selected rounding direction. */ function mulDiv( uint256 x, uint256 y, uint256 denominator, Rounding rounding ) internal pure returns (uint256) { uint256 result = mulDiv(x, y, denominator); if (rounding == Rounding.Up && mulmod(x, y, denominator) > 0) { result += 1; } return result; } /** * @dev Returns the square root of a number. If the number is not a perfect square, the value is rounded down. * * Inspired by Henry S. Warren, Jr.'s "Hacker's Delight" (Chapter 11). */ function sqrt(uint256 a) internal pure returns (uint256) { if (a == 0) { return 0; } // For our first guess, we get the biggest power of 2 which is smaller than the square root of the target. // // We know that the "msb" (most significant bit) of our target number `a` is a power of 2 such that we have // `msb(a) <= a < 2*msb(a)`. This value can be written `msb(a)=2**k` with `k=log2(a)`. // // This can be rewritten `2**log2(a) <= a < 2**(log2(a) + 1)` // → `sqrt(2**k) <= sqrt(a) < sqrt(2**(k+1))` // → `2**(k/2) <= sqrt(a) < 2**((k+1)/2) <= 2**(k/2 + 1)` // // Consequently, `2**(log2(a) / 2)` is a good first approximation of `sqrt(a)` with at least 1 correct bit. uint256 result = 1 << (log2(a) >> 1); // At this point `result` is an estimation with one bit of precision. We know the true value is a uint128, // since it is the square root of a uint256. Newton's method converges quadratically (precision doubles at // every iteration). We thus need at most 7 iteration to turn our partial result with one bit of precision // into the expected uint128 result. unchecked { result = (result + a / result) >> 1; result = (result + a / result) >> 1; result = (result + a / result) >> 1; result = (result + a / result) >> 1; result = (result + a / result) >> 1; result = (result + a / result) >> 1; result = (result + a / result) >> 1; return min(result, a / result); } } /** * @notice Calculates sqrt(a), following the selected rounding direction. */ function sqrt(uint256 a, Rounding rounding) internal pure returns (uint256) { unchecked { uint256 result = sqrt(a); return result + (rounding == Rounding.Up && result * result < a ? 1 : 0); } } /** * @dev Return the log in base 2, rounded down, of a positive value. * Returns 0 if given 0. */ function log2(uint256 value) internal pure returns (uint256) { uint256 result = 0; unchecked { if (value >> 128 > 0) { value >>= 128; result += 128; } if (value >> 64 > 0) { value >>= 64; result += 64; } if (value >> 32 > 0) { value >>= 32; result += 32; } if (value >> 16 > 0) { value >>= 16; result += 16; } if (value >> 8 > 0) { value >>= 8; result += 8; } if (value >> 4 > 0) { value >>= 4; result += 4; } if (value >> 2 > 0) { value >>= 2; result += 2; } if (value >> 1 > 0) { result += 1; } } return result; } /** * @dev Return the log in base 2, following the selected rounding direction, of a positive value. * Returns 0 if given 0. */ function log2(uint256 value, Rounding rounding) internal pure returns (uint256) { unchecked { uint256 result = log2(value); return result + (rounding == Rounding.Up && 1 << result < value ? 1 : 0); } } /** * @dev Return the log in base 10, rounded down, of a positive value. * Returns 0 if given 0. */ function log10(uint256 value) internal pure returns (uint256) { uint256 result = 0; unchecked { if (value >= 10**64) { value /= 10**64; result += 64; } if (value >= 10**32) { value /= 10**32; result += 32; } if (value >= 10**16) { value /= 10**16; result += 16; } if (value >= 10**8) { value /= 10**8; result += 8; } if (value >= 10**4) { value /= 10**4; result += 4; } if (value >= 10**2) { value /= 10**2; result += 2; } if (value >= 10**1) { result += 1; } } return result; } /** * @dev Return the log in base 10, following the selected rounding direction, of a positive value. * Returns 0 if given 0. */ function log10(uint256 value, Rounding rounding) internal pure returns (uint256) { unchecked { uint256 result = log10(value); return result + (rounding == Rounding.Up && 10**result < value ? 1 : 0); } } /** * @dev Return the log in base 256, rounded down, of a positive value. * Returns 0 if given 0. * * Adding one to the result gives the number of pairs of hex symbols needed to represent `value` as a hex string. */ function log256(uint256 value) internal pure returns (uint256) { uint256 result = 0; unchecked { if (value >> 128 > 0) { value >>= 128; result += 16; } if (value >> 64 > 0) { value >>= 64; result += 8; } if (value >> 32 > 0) { value >>= 32; result += 4; } if (value >> 16 > 0) { value >>= 16; result += 2; } if (value >> 8 > 0) { result += 1; } } return result; } /** * @dev Return the log in base 10, following the selected rounding direction, of a positive value. * Returns 0 if given 0. */ function log256(uint256 value, Rounding rounding) internal pure returns (uint256) { unchecked { uint256 result = log256(value); return result + (rounding == Rounding.Up && 1 << (result * 8) < value ? 1 : 0); } } }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts v4.4.1 (utils/introspection/ERC165.sol) pragma solidity ^0.8.0; import "./IERC165.sol"; /** * @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; } }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts v4.4.1 (utils/Context.sol) pragma solidity ^0.8.0; /** * @dev Provides information about the current execution context, including the * sender of the transaction and its data. While these are generally available * via msg.sender and msg.data, they should not be accessed in such a direct * manner, since when dealing with meta-transactions the account sending and * paying for execution may not be the actual sender (as far as an application * is concerned). * * This contract is only required for intermediate, library-like contracts. */ abstract contract Context { function _msgSender() internal view virtual returns (address) { return msg.sender; } function _msgData() internal view virtual returns (bytes calldata) { return msg.data; } }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts (last updated v4.8.0) (utils/Address.sol) pragma solidity ^0.8.1; /** * @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 * ==== * * [IMPORTANT] * ==== * You shouldn't rely on `isContract` to protect against flash loan attacks! * * Preventing calls from contracts is highly discouraged. It breaks composability, breaks support for smart wallets * like Gnosis Safe, and does not provide security since it can be circumvented by calling from a contract * constructor. * ==== */ function isContract(address account) internal view returns (bool) { // This method relies on extcodesize/address.code.length, which returns 0 // for contracts in construction, since the code is only stored at the end // of the constructor execution. return account.code.length > 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 functionCallWithValue(target, data, 0, "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"); (bool success, bytes memory returndata) = target.call{value: value}(data); return verifyCallResultFromTarget(target, 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) { (bool success, bytes memory returndata) = target.staticcall(data); return verifyCallResultFromTarget(target, 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) { (bool success, bytes memory returndata) = target.delegatecall(data); return verifyCallResultFromTarget(target, success, returndata, errorMessage); } /** * @dev Tool to verify that a low level call to smart-contract was successful, and revert (either by bubbling * the revert reason or using the provided one) in case of unsuccessful call or if target was not a contract. * * _Available since v4.8._ */ function verifyCallResultFromTarget( address target, bool success, bytes memory returndata, string memory errorMessage ) internal view returns (bytes memory) { if (success) { if (returndata.length == 0) { // only check isContract if the call was successful and the return data is empty // otherwise we already know that it was a contract require(isContract(target), "Address: call to non-contract"); } return returndata; } else { _revert(returndata, errorMessage); } } /** * @dev Tool to verify that a low level call was successful, and revert if it wasn't, either by bubbling the * revert reason or 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 { _revert(returndata, errorMessage); } } function _revert(bytes memory returndata, string memory errorMessage) private pure { // 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 /// @solidity memory-safe-assembly assembly { let returndata_size := mload(returndata) revert(add(32, returndata), returndata_size) } } else { revert(errorMessage); } } }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts v4.4.1 (token/ERC1155/extensions/IERC1155MetadataURI.sol) pragma solidity ^0.8.0; import "../IERC1155.sol"; /** * @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); }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts (last updated v4.5.0) (token/ERC1155/IERC1155Receiver.sol) pragma solidity ^0.8.0; import "../../utils/introspection/IERC165.sol"; /** * @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. * * NOTE: 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. * * NOTE: 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); }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts (last updated v4.7.0) (token/ERC1155/IERC1155.sol) pragma solidity ^0.8.0; import "../../utils/introspection/IERC165.sol"; /** * @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 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; }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts v4.4.1 (interfaces/IERC165.sol) pragma solidity ^0.8.0; import "../utils/introspection/IERC165.sol";
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts v4.4.1 (interfaces/IERC20.sol) pragma solidity ^0.8.0; import "../token/ERC20/IERC20.sol";
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts v4.4.1 (access/IAccessControl.sol) pragma solidity ^0.8.0; /** * @dev External interface of AccessControl declared to support ERC165 detection. */ interface IAccessControl { /** * @dev Emitted when `newAdminRole` is set as ``role``'s admin role, replacing `previousAdminRole` * * `DEFAULT_ADMIN_ROLE` is the starting admin for all roles, despite * {RoleAdminChanged} not being emitted signaling this. * * _Available since v3.1._ */ event RoleAdminChanged(bytes32 indexed role, bytes32 indexed previousAdminRole, bytes32 indexed newAdminRole); /** * @dev Emitted when `account` is granted `role`. * * `sender` is the account that originated the contract call, an admin role * bearer except when using {AccessControl-_setupRole}. */ event RoleGranted(bytes32 indexed role, address indexed account, address indexed sender); /** * @dev Emitted when `account` is revoked `role`. * * `sender` is the account that originated the contract call: * - if using `revokeRole`, it is the admin role bearer * - if using `renounceRole`, it is the role bearer (i.e. `account`) */ event RoleRevoked(bytes32 indexed role, address indexed account, address indexed sender); /** * @dev Returns `true` if `account` has been granted `role`. */ function hasRole(bytes32 role, address account) external view returns (bool); /** * @dev Returns the admin role that controls `role`. See {grantRole} and * {revokeRole}. * * To change a role's admin, use {AccessControl-_setRoleAdmin}. */ function getRoleAdmin(bytes32 role) external view returns (bytes32); /** * @dev Grants `role` to `account`. * * If `account` had not been already granted `role`, emits a {RoleGranted} * event. * * Requirements: * * - the caller must have ``role``'s admin role. */ function grantRole(bytes32 role, address account) external; /** * @dev Revokes `role` from `account`. * * If `account` had been granted `role`, emits a {RoleRevoked} event. * * Requirements: * * - the caller must have ``role``'s admin role. */ function revokeRole(bytes32 role, address account) external; /** * @dev Revokes `role` from the calling account. * * Roles are often managed via {grantRole} and {revokeRole}: this function's * purpose is to provide a mechanism for accounts to lose their privileges * if they are compromised (such as when a trusted device is misplaced). * * If the calling account had been granted `role`, emits a {RoleRevoked} * event. * * Requirements: * * - the caller must be `account`. */ function renounceRole(bytes32 role, address account) external; }
// SPDX-License-Identifier: MIT // 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); }
// SPDX-License-Identifier: MIT // OpenZeppelin Contracts (last updated v4.6.0) (token/ERC20/IERC20.sol) pragma solidity ^0.8.0; /** * @dev Interface of the ERC20 standard as defined in the EIP. */ interface IERC20 { /** * @dev Emitted when `value` tokens are moved from one account (`from`) to * another (`to`). * * Note that `value` may be zero. */ event Transfer(address indexed from, address indexed to, uint256 value); /** * @dev Emitted when the allowance of a `spender` for an `owner` is set by * a call to {approve}. `value` is the new allowance. */ event Approval(address indexed owner, address indexed spender, uint256 value); /** * @dev Returns the amount of tokens in existence. */ function totalSupply() external view returns (uint256); /** * @dev Returns the amount of tokens owned by `account`. */ function balanceOf(address account) external view returns (uint256); /** * @dev Moves `amount` tokens from the caller's account to `to`. * * Returns a boolean value indicating whether the operation succeeded. * * Emits a {Transfer} event. */ function transfer(address to, uint256 amount) external returns (bool); /** * @dev Returns the remaining number of tokens that `spender` will be * allowed to spend on behalf of `owner` through {transferFrom}. This is * zero by default. * * This value changes when {approve} or {transferFrom} are called. */ function allowance(address owner, address spender) external view returns (uint256); /** * @dev Sets `amount` as the allowance of `spender` over the caller's tokens. * * Returns a boolean value indicating whether the operation succeeded. * * IMPORTANT: Beware that changing an allowance with this method brings the risk * that someone may use both the old and the new allowance by unfortunate * transaction ordering. One possible solution to mitigate this race * condition is to first reduce the spender's allowance to 0 and set the * desired value afterwards: * https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729 * * Emits an {Approval} event. */ function approve(address spender, uint256 amount) external returns (bool); /** * @dev Moves `amount` tokens from `from` to `to` using the * allowance mechanism. `amount` is then deducted from the caller's * allowance. * * Returns a boolean value indicating whether the operation succeeded. * * Emits a {Transfer} event. */ function transferFrom( address from, address to, uint256 amount ) external returns (bool); }
{ "optimizer": { "enabled": false, "runs": 200 }, "outputSelection": { "*": { "*": [ "evm.bytecode", "evm.deployedBytecode", "devdoc", "userdoc", "metadata", "abi" ] } } }
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":"bytes32","name":"role","type":"bytes32"},{"indexed":true,"internalType":"bytes32","name":"previousAdminRole","type":"bytes32"},{"indexed":true,"internalType":"bytes32","name":"newAdminRole","type":"bytes32"}],"name":"RoleAdminChanged","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"role","type":"bytes32"},{"indexed":true,"internalType":"address","name":"account","type":"address"},{"indexed":true,"internalType":"address","name":"sender","type":"address"}],"name":"RoleGranted","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"bytes32","name":"role","type":"bytes32"},{"indexed":true,"internalType":"address","name":"account","type":"address"},{"indexed":true,"internalType":"address","name":"sender","type":"address"}],"name":"RoleRevoked","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"},{"inputs":[],"name":"DEFAULT_ADMIN_ROLE","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"MINTER_ROLE","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"available","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","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":[],"name":"beneficiary","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"id","type":"uint256"}],"name":"exists","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bytes32","name":"role","type":"bytes32"}],"name":"getRoleAdmin","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bytes32","name":"role","type":"bytes32"},{"internalType":"address","name":"account","type":"address"}],"name":"grantRole","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bytes32","name":"role","type":"bytes32"},{"internalType":"address","name":"account","type":"address"}],"name":"hasRole","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"itemId","type":"uint256"},{"internalType":"uint256","name":"_value","type":"uint256"}],"name":"increaseNumAvailable","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_itemId","type":"uint256"}],"name":"intToBytes","outputs":[{"internalType":"bytes","name":"","type":"bytes"}],"stateMutability":"pure","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":"_tokenId","type":"uint256"}],"name":"limit","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"_to","type":"address"},{"internalType":"uint256","name":"_itemId","type":"uint256"},{"internalType":"uint256","name":"_count","type":"uint256"}],"name":"mint","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"minted","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"ml_beneficiary","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"operator","type":"address"},{"internalType":"address","name":"from","type":"address"},{"internalType":"uint256","name":"value","type":"uint256"},{"internalType":"bytes","name":"data","type":"bytes"}],"name":"onTransferReceived","outputs":[{"internalType":"bytes4","name":"","type":"bytes4"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"prices","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bytes32","name":"role","type":"bytes32"},{"internalType":"address","name":"account","type":"address"}],"name":"renounceRole","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"bytes32","name":"role","type":"bytes32"},{"internalType":"address","name":"account","type":"address"}],"name":"revokeRole","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":"itemId","type":"uint256"},{"internalType":"string","name":"_uri","type":"string"}],"name":"setCustomBaseURI","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"itemId","type":"uint256"},{"internalType":"uint256","name":"_limit","type":"uint256"}],"name":"setLimits","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_addr","type":"address"}],"name":"setMLBenefiary","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"string","name":"_name","type":"string"}],"name":"setName","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"itemId","type":"uint256"},{"internalType":"uint256","name":"_limit","type":"uint256"}],"name":"setNumAvailable","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"itemId","type":"uint256"},{"internalType":"uint256","name":"newprice","type":"uint256"}],"name":"setPrice","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"_val","type":"uint256"}],"name":"setSplit","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"string","name":"newuri","type":"string"}],"name":"setURI","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"string","name":"_suffix","type":"string"}],"name":"setURISuffix","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"split","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bytes4","name":"interfaceId","type":"bytes4"}],"name":"supportsInterface","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"token","outputs":[{"internalType":"contract IERC1363","name":"","type":"address"}],"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":"uint256","name":"id","type":"uint256"}],"name":"uri","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"}]
Contract Creation Code
60a06040526040518060400160405280600581526020017f2e6a736f6e000000000000000000000000000000000000000000000000000000815250600d90816200004a919062000a3b565b506040518060400160405280600f81526020017f5069636b6c652045646974696f6e730000000000000000000000000000000000815250600e908162000091919062000a3b565b506040518060400160405280600881526020017f50434b4c45444e53000000000000000000000000000000000000000000000000815250600f9081620000d8919062000a3b565b50348015620000e657600080fd5b50604051806020016040528060008152506200010881620002a260201b60201c565b506200011e6000801b33620002b760201b60201c565b620001507f9f2df0fed2c77648de5860a4cc508cd0818c85b8b8a1ab4ceeef8d981c8956a633620002b760201b60201c565b7378b5c6149c87c82edcffc73c230395abbc56ddd573ffffffffffffffffffffffffffffffffffffffff1660808173ffffffffffffffffffffffffffffffffffffffff1681525050620001c26040518060600160405280603481526020016200608b60349139620003a860201b60201c565b6803bd913e6c1df400006008600060018152602001908152602001600020819055506040600a60006001815260200190815260200160002081905550603260078190555033600560006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555073b4005db54adecf669babc3efb19b9b7e3978ebc2600660006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555062000e7d565b8060039081620002b3919062000a3b565b5050565b620002c98282620003ef60201b60201c565b620003a457600160008084815260200190815260200160002060000160008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff021916908315150217905550620003496200045960201b60201c565b73ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff16837f2f8788117e7eff1d82e926ec794901d17c78024a50270940304540a733656f0d60405160405180910390a45b5050565b7f9f2df0fed2c77648de5860a4cc508cd0818c85b8b8a1ab4ceeef8d981c8956a6620003da816200046160201b60201c565b620003eb82620002a260201b60201c565b5050565b600080600084815260200190815260200160002060000160008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16905092915050565b600033905090565b6200048281620004766200045960201b60201c565b6200048560201b60201c565b50565b620004978282620003ef60201b60201c565b6200052d57620004b2816200053160201b620018dc1760201c565b620004cd8360001c60206200056660201b620019091760201c565b604051602001620004e092919062000c30565b6040516020818303038152906040526040517f08c379a000000000000000000000000000000000000000000000000000000000815260040162000524919062000cd5565b60405180910390fd5b5050565b60606200055f8273ffffffffffffffffffffffffffffffffffffffff16601460ff166200056660201b60201c565b9050919050565b6060600060028360026200057b919062000d28565b62000587919062000d73565b67ffffffffffffffff811115620005a357620005a2620007cc565b5b6040519080825280601f01601f191660200182016040528015620005d65781602001600182028036833780820191505090505b5090507f30000000000000000000000000000000000000000000000000000000000000008160008151811062000611576200061062000dae565b5b60200101907effffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916908160001a9053507f78000000000000000000000000000000000000000000000000000000000000008160018151811062000678576200067762000dae565b5b60200101907effffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916908160001a90535060006001846002620006ba919062000d28565b620006c6919062000d73565b90505b600181111562000770577f3031323334353637383961626364656600000000000000000000000000000000600f8616601081106200070c576200070b62000dae565b5b1a60f81b82828151811062000726576200072562000dae565b5b60200101907effffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916908160001a905350600485901c945080620007689062000ddd565b9050620006c9565b5060008414620007b7576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401620007ae9062000e5b565b60405180910390fd5b8091505092915050565b600081519050919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052604160045260246000fd5b7f4e487b7100000000000000000000000000000000000000000000000000000000600052602260045260246000fd5b600060028204905060018216806200084357607f821691505b602082108103620008595762000858620007fb565b5b50919050565b60008190508160005260206000209050919050565b60006020601f8301049050919050565b600082821b905092915050565b600060088302620008c37fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff8262000884565b620008cf868362000884565b95508019841693508086168417925050509392505050565b6000819050919050565b6000819050919050565b60006200091c620009166200091084620008e7565b620008f1565b620008e7565b9050919050565b6000819050919050565b6200093883620008fb565b62000950620009478262000923565b84845462000891565b825550505050565b600090565b6200096762000958565b620009748184846200092d565b505050565b5b818110156200099c57620009906000826200095d565b6001810190506200097a565b5050565b601f821115620009eb57620009b5816200085f565b620009c08462000874565b81016020851015620009d0578190505b620009e8620009df8562000874565b83018262000979565b50505b505050565b600082821c905092915050565b600062000a1060001984600802620009f0565b1980831691505092915050565b600062000a2b8383620009fd565b9150826002028217905092915050565b62000a4682620007c1565b67ffffffffffffffff81111562000a625762000a61620007cc565b5b62000a6e82546200082a565b62000a7b828285620009a0565b600060209050601f83116001811462000ab3576000841562000a9e578287015190505b62000aaa858262000a1d565b86555062000b1a565b601f19841662000ac3866200085f565b60005b8281101562000aed5784890151825560018201915060208501945060208101905062000ac6565b8683101562000b0d578489015162000b09601f891682620009fd565b8355505b6001600288020188555050505b505050505050565b600081905092915050565b7f416363657373436f6e74726f6c3a206163636f756e7420000000000000000000600082015250565b600062000b6560178362000b22565b915062000b728262000b2d565b601782019050919050565b60005b8381101562000b9d57808201518184015260208101905062000b80565b60008484015250505050565b600062000bb682620007c1565b62000bc2818562000b22565b935062000bd481856020860162000b7d565b80840191505092915050565b7f206973206d697373696e6720726f6c6520000000000000000000000000000000600082015250565b600062000c1860118362000b22565b915062000c258262000be0565b601182019050919050565b600062000c3d8262000b56565b915062000c4b828562000ba9565b915062000c588262000c09565b915062000c66828462000ba9565b91508190509392505050565b600082825260208201905092915050565b6000601f19601f8301169050919050565b600062000ca182620007c1565b62000cad818562000c72565b935062000cbf81856020860162000b7d565b62000cca8162000c83565b840191505092915050565b6000602082019050818103600083015262000cf1818462000c94565b905092915050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b600062000d3582620008e7565b915062000d4283620008e7565b925082820262000d5281620008e7565b9150828204841483151762000d6c5762000d6b62000cf9565b5b5092915050565b600062000d8082620008e7565b915062000d8d83620008e7565b925082820190508082111562000da85762000da762000cf9565b5b92915050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052603260045260246000fd5b600062000dea82620008e7565b91506000820362000e005762000dff62000cf9565b5b600182039050919050565b7f537472696e67733a20686578206c656e67746820696e73756666696369656e74600082015250565b600062000e4360208362000c72565b915062000e508262000e0b565b602082019050919050565b6000602082019050818103600083015262000e768162000e34565b9050919050565b6080516151d662000eb560003960008181610f3d01528181611131015281816111f20152818161130b01526118ba01526151d66000f3fe608060405234801561001057600080fd5b50600436106102475760003560e01c806388a7ca5c1161013b578063c321d1e0116100b8578063e985e9c51161007c578063e985e9c514610744578063f242432a14610774578063f765417614610790578063f7d97577146107ae578063fc0c546a146107ca57610247565b8063c321d1e0146106b6578063c4590d3f146106d2578063c47f0027146106ee578063d53913931461070a578063d547741f1461072857610247565b8063a217fddf116100ff578063a217fddf146105fe578063a22cb4651461061c578063bc31c1c114610638578063bd85b03914610668578063be6eec391461069857610247565b806388a7ca5c1461053457806391d148541461056457806395d89b411461059457806396e494e8146105b257806399b84258146105e257610247565b806336568abe116101c95780635ef033ae1161018d5780635ef033ae14610480578063674e694f146104b05780637dc0bf3f146104cc57806381b3e575146104fc57806386f840e61461051857610247565b806336568abe146103ca57806338af3eed146103e65780634e1273f4146104045780634f558e79146104345780635bb671131461046457610247565b8063156e29f611610210578063156e29f614610316578063243bcfcb14610332578063248a9ca3146103625780632eb2c2d6146103925780632f2ff15d146103ae57610247565b8062fdd58e1461024c57806301ffc9a71461027c57806302fe5305146102ac57806306fdde03146102c85780630e89341c146102e6575b600080fd5b610266600480360381019061026191906131fd565b6107e8565b604051610273919061324c565b60405180910390f35b610296600480360381019061029191906132bf565b6108b1565b6040516102a39190613307565b60405180910390f35b6102c660048036038101906102c19190613468565b6108c3565b005b6102d06108fa565b6040516102dd9190613530565b60405180910390f35b61030060048036038101906102fb9190613552565b610988565b60405161030d9190613530565b60405180910390f35b610330600480360381019061032b919061357f565b610a4c565b005b61034c60048036038101906103479190613552565b610a97565b604051610359919061324c565b60405180910390f35b61037c60048036038101906103779190613608565b610ac0565b6040516103899190613644565b60405180910390f35b6103ac60048036038101906103a791906137c8565b610adf565b005b6103c860048036038101906103c39190613897565b610b80565b005b6103e460048036038101906103df9190613897565b610ba1565b005b6103ee610c24565b6040516103fb91906138e6565b60405180910390f35b61041e600480360381019061041991906139c4565b610c4a565b60405161042b9190613afa565b60405180910390f35b61044e60048036038101906104499190613552565b610d63565b60405161045b9190613307565b60405180910390f35b61047e60048036038101906104799190613b1c565b610d77565b005b61049a60048036038101906104959190613552565b610dc7565b6040516104a79190613bcd565b60405180910390f35b6104ca60048036038101906104c59190613552565b610df0565b005b6104e660048036038101906104e19190613552565b610e8a565b6040516104f3919061324c565b60405180910390f35b61051660048036038101906105119190613468565b610ea2565b005b610532600480360381019061052d9190613bef565b610ee0565b005b61054e60048036038101906105499190613c2f565b610f39565b60405161055b9190613cc1565b60405180910390f35b61057e60048036038101906105799190613897565b6113c9565b60405161058b9190613307565b60405180910390f35b61059c611433565b6040516105a99190613530565b60405180910390f35b6105cc60048036038101906105c79190613552565b6114c1565b6040516105d9919061324c565b60405180910390f35b6105fc60048036038101906105f79190613cdc565b6114d9565b005b6106066115ad565b6040516106139190613644565b60405180910390f35b61063660048036038101906106319190613d35565b6115b4565b005b610652600480360381019061064d9190613552565b6115ca565b60405161065f919061324c565b60405180910390f35b610682600480360381019061067d9190613552565b6115e2565b60405161068f919061324c565b60405180910390f35b6106a06115ff565b6040516106ad91906138e6565b60405180910390f35b6106d060048036038101906106cb9190613bef565b611625565b005b6106ec60048036038101906106e79190613bef565b61166c565b005b61070860048036038101906107039190613468565b6116b3565b005b6107126116f1565b60405161071f9190613644565b60405180910390f35b610742600480360381019061073d9190613897565b611715565b005b61075e60048036038101906107599190613d75565b611736565b60405161076b9190613307565b60405180910390f35b61078e60048036038101906107899190613db5565b6117ca565b005b61079861186b565b6040516107a5919061324c565b60405180910390f35b6107c860048036038101906107c39190613bef565b611871565b005b6107d26118b8565b6040516107df9190613eab565b60405180910390f35b60008073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1603610858576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161084f90613f38565b60405180910390fd5b6001600083815260200190815260200160002060008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054905092915050565b60006108bc82611b45565b9050919050565b7f9f2df0fed2c77648de5860a4cc508cd0818c85b8b8a1ab4ceeef8d981c8956a66108ed81611c27565b6108f682611c3b565b5050565b600e805461090790613f87565b80601f016020809104026020016040519081016040528092919081815260200182805461093390613f87565b80156109805780601f1061095557610100808354040283529160200191610980565b820191906000526020600020905b81548152906001019060200180831161096357829003601f168201915b505050505081565b6060600061099583611c4e565b600d6040516020016109a892919061408c565b60405160208183030381529060405290506000600c600085815260200190815260200160002080546109d990613f87565b905011610a0f576109e983611d1c565b816040516020016109fb9291906140b0565b604051602081830303815290604052610a44565b600c600084815260200190815260200160002081604051602001610a349291906140d4565b6040516020818303038152906040525b915050919050565b7f9f2df0fed2c77648de5860a4cc508cd0818c85b8b8a1ab4ceeef8d981c8956a6610a7681611c27565b610a9184848460405180602001604052806000815250611db0565b50505050565b60006001600b600084815260200190815260200160002054610ab99190614127565b9050919050565b6000806000838152602001908152602001600020600101549050919050565b610ae7611f61565b73ffffffffffffffffffffffffffffffffffffffff168573ffffffffffffffffffffffffffffffffffffffff161480610b2d5750610b2c85610b27611f61565b611736565b5b610b6c576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610b63906141cd565b60405180910390fd5b610b798585858585611f69565b5050505050565b610b8982610ac0565b610b9281611c27565b610b9c838361228d565b505050565b610ba9611f61565b73ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff1614610c16576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610c0d9061425f565b60405180910390fd5b610c20828261236d565b5050565b600560009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b60608151835114610c90576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610c87906142f1565b60405180910390fd5b6000835167ffffffffffffffff811115610cad57610cac61333d565b5b604051908082528060200260200182016040528015610cdb5781602001602082028036833780820191505090505b50905060005b8451811015610d5857610d28858281518110610d0057610cff614311565b5b6020026020010151858381518110610d1b57610d1a614311565b5b60200260200101516107e8565b828281518110610d3b57610d3a614311565b5b60200260200101818152505080610d5190614340565b9050610ce1565b508091505092915050565b600080610d6f836115e2565b119050919050565b7f9f2df0fed2c77648de5860a4cc508cd0818c85b8b8a1ab4ceeef8d981c8956a6610da181611c27565b81600c60008581526020019081526020016000209081610dc19190614515565b50505050565b606081604051602001610dda919061324c565b6040516020818303038152906040529050919050565b600660009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff1614610e80576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610e7790614633565b60405180910390fd5b8060078190555050565b60096020528060005260406000206000915090505481565b7f9f2df0fed2c77648de5860a4cc508cd0818c85b8b8a1ab4ceeef8d981c8956a6610ecc81611c27565b81600d9081610edb9190614515565b505050565b7f9f2df0fed2c77648de5860a4cc508cd0818c85b8b8a1ab4ceeef8d981c8956a6610f0a81611c27565b81600a60008581526020019081526020016000206000828254610f2d9190614127565b92505081905550505050565b60007f000000000000000000000000000000000000000000000000000000000000000073ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff1614610f9357600080fd5b600082806020019051810190610fa99190614668565b905060006008600083815260200190815260200160002054905060008111611006576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610ffd906146e1565b60405180910390fd5b80851015611049576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016110409061474d565b60405180910390fd5b600a600083815260200190815260200160002054600960008481526020019081526020016000205411156110b2576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016110a9906147b9565b60405180910390fd5b600b6000838152602001908152602001600020546110d088846107e8565b1115611111576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161110890614825565b60405180910390fd5b60006064600754836111239190614845565b61112d91906148b6565b90507f000000000000000000000000000000000000000000000000000000000000000073ffffffffffffffffffffffffffffffffffffffff1663a9059cbb600560009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16836040518363ffffffff1660e01b81526004016111ac9291906148e7565b6020604051808303816000875af11580156111cb573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906111ef9190614925565b507f000000000000000000000000000000000000000000000000000000000000000073ffffffffffffffffffffffffffffffffffffffff1663a9059cbb600660009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16838561125b9190614952565b6040518363ffffffff1660e01b81526004016112789291906148e7565b6020604051808303816000875af1158015611297573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906112bb9190614925565b506009600084815260200190815260200160002060008154809291906112e090614340565b91905055506113018884600160405180602001604052806000815250611db0565b818611156113b4577f000000000000000000000000000000000000000000000000000000000000000073ffffffffffffffffffffffffffffffffffffffff1663a9059cbb8884896113529190614952565b6040518363ffffffff1660e01b815260040161136f9291906148e7565b6020604051808303816000875af115801561138e573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906113b29190614925565b505b6388a7ca5c60e01b9350505050949350505050565b600080600084815260200190815260200160002060000160008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16905092915050565b600f805461144090613f87565b80601f016020809104026020016040519081016040528092919081815260200182805461146c90613f87565b80156114b95780601f1061148e576101008083540402835291602001916114b9565b820191906000526020600020905b81548152906001019060200180831161149c57829003601f168201915b505050505081565b600a6020528060005260406000206000915090505481565b600660009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff1614611569576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161156090614633565b60405180910390fd5b80600660006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555050565b6000801b81565b6115c66115bf611f61565b838361244e565b5050565b60086020528060005260406000206000915090505481565b600060046000838152602001908152602001600020549050919050565b600660009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b7f9f2df0fed2c77648de5860a4cc508cd0818c85b8b8a1ab4ceeef8d981c8956a661164f81611c27565b81600a600085815260200190815260200160002081905550505050565b7f9f2df0fed2c77648de5860a4cc508cd0818c85b8b8a1ab4ceeef8d981c8956a661169681611c27565b81600b600085815260200190815260200160002081905550505050565b7f9f2df0fed2c77648de5860a4cc508cd0818c85b8b8a1ab4ceeef8d981c8956a66116dd81611c27565b81600e90816116ec9190614515565b505050565b7f9f2df0fed2c77648de5860a4cc508cd0818c85b8b8a1ab4ceeef8d981c8956a681565b61171e82610ac0565b61172781611c27565b611731838361236d565b505050565b6000600260008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16905092915050565b6117d2611f61565b73ffffffffffffffffffffffffffffffffffffffff168573ffffffffffffffffffffffffffffffffffffffff161480611818575061181785611812611f61565b611736565b5b611857576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161184e906141cd565b60405180910390fd5b61186485858585856125ba565b5050505050565b60075481565b7f9f2df0fed2c77648de5860a4cc508cd0818c85b8b8a1ab4ceeef8d981c8956a661189b81611c27565b816008600085815260200190815260200160002081905550505050565b7f000000000000000000000000000000000000000000000000000000000000000081565b60606119028273ffffffffffffffffffffffffffffffffffffffff16601460ff16611909565b9050919050565b60606000600283600261191c9190614845565b6119269190614127565b67ffffffffffffffff81111561193f5761193e61333d565b5b6040519080825280601f01601f1916602001820160405280156119715781602001600182028036833780820191505090505b5090507f3000000000000000000000000000000000000000000000000000000000000000816000815181106119a9576119a8614311565b5b60200101907effffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916908160001a9053507f780000000000000000000000000000000000000000000000000000000000000081600181518110611a0d57611a0c614311565b5b60200101907effffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916908160001a90535060006001846002611a4d9190614845565b611a579190614127565b90505b6001811115611af7577f3031323334353637383961626364656600000000000000000000000000000000600f861660108110611a9957611a98614311565b5b1a60f81b828281518110611ab057611aaf614311565b5b60200101907effffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916908160001a905350600485901c945080611af090614986565b9050611a5a565b5060008414611b3b576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611b32906149fb565b60405180910390fd5b8091505092915050565b60007fd9b67a26000000000000000000000000000000000000000000000000000000007bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916827bffffffffffffffffffffffffffffffffffffffffffffffffffffffff19161480611c1057507f0e89341c000000000000000000000000000000000000000000000000000000007bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916827bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916145b80611c205750611c1f82612858565b5b9050919050565b611c3881611c33611f61565b6128d2565b50565b8060039081611c4a9190614515565b5050565b606060006001611c5d84612957565b01905060008167ffffffffffffffff811115611c7c57611c7b61333d565b5b6040519080825280601f01601f191660200182016040528015611cae5781602001600182028036833780820191505090505b509050600082602001820190505b600115611d11578080600190039150507f3031323334353637383961626364656600000000000000000000000000000000600a86061a8153600a8581611d0557611d04614887565b5b04945060008503611cbc575b819350505050919050565b606060038054611d2b90613f87565b80601f0160208091040260200160405190810160405280929190818152602001828054611d5790613f87565b8015611da45780601f10611d7957610100808354040283529160200191611da4565b820191906000526020600020905b815481529060010190602001808311611d8757829003601f168201915b50505050509050919050565b600073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1603611e1f576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611e1690614a8d565b60405180910390fd5b6000611e29611f61565b90506000611e3685612aaa565b90506000611e4385612aaa565b9050611e5483600089858589612b24565b846001600088815260200190815260200160002060008973ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000206000828254611eb49190614127565b925050819055508673ffffffffffffffffffffffffffffffffffffffff16600073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fc3d58168c5ae7397731d063d5bbf3d657854427343f4c083240f7aacaa2d0f628989604051611f32929190614aad565b60405180910390a4611f4983600089858589612b3a565b611f5883600089898989612b42565b50505050505050565b600033905090565b8151835114611fad576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611fa490614b48565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff160361201c576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161201390614bda565b60405180910390fd5b6000612026611f61565b9050612036818787878787612b24565b60005b84518110156121ea57600085828151811061205757612056614311565b5b60200260200101519050600085838151811061207657612075614311565b5b6020026020010151905060006001600084815260200190815260200160002060008b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054905081811015612118576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161210f90614c6c565b60405180910390fd5b8181036001600085815260200190815260200160002060008c73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002081905550816001600085815260200190815260200160002060008b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008282546121cf9190614127565b92505081905550505050806121e390614340565b9050612039565b508473ffffffffffffffffffffffffffffffffffffffff168673ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff167f4a39dc06d4c0dbc64b70af90fd698a233a518aa5d07e595d983b8c0526c8f7fb8787604051612261929190614c8c565b60405180910390a4612277818787878787612b3a565b612285818787878787612d19565b505050505050565b61229782826113c9565b61236957600160008084815260200190815260200160002060000160008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff02191690831515021790555061230e611f61565b73ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff16837f2f8788117e7eff1d82e926ec794901d17c78024a50270940304540a733656f0d60405160405180910390a45b5050565b61237782826113c9565b1561244a57600080600084815260200190815260200160002060000160008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff0219169083151502179055506123ef611f61565b73ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff16837ff6391f5c32d9c69d2a47ea670b442974b53935d1edc7fd64eb21e047a839171b60405160405180910390a45b5050565b8173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff16036124bc576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016124b390614d35565b60405180910390fd5b80600260008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff0219169083151502179055508173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c31836040516125ad9190613307565b60405180910390a3505050565b600073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1603612629576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161262090614bda565b60405180910390fd5b6000612633611f61565b9050600061264085612aaa565b9050600061264d85612aaa565b905061265d838989858589612b24565b60006001600088815260200190815260200160002060008a73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020549050858110156126f5576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016126ec90614c6c565b60405180910390fd5b8581036001600089815260200190815260200160002060008b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002081905550856001600089815260200190815260200160002060008a73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008282546127ac9190614127565b925050819055508773ffffffffffffffffffffffffffffffffffffffff168973ffffffffffffffffffffffffffffffffffffffff168573ffffffffffffffffffffffffffffffffffffffff167fc3d58168c5ae7397731d063d5bbf3d657854427343f4c083240f7aacaa2d0f628a8a604051612829929190614aad565b60405180910390a461283f848a8a86868a612b3a565b61284d848a8a8a8a8a612b42565b505050505050505050565b60007f7965db0b000000000000000000000000000000000000000000000000000000007bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916827bffffffffffffffffffffffffffffffffffffffffffffffffffffffff191614806128cb57506128ca82612ef0565b5b9050919050565b6128dc82826113c9565b612953576128e9816118dc565b6128f78360001c6020611909565b604051602001612908929190614ded565b6040516020818303038152906040526040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161294a9190613530565b60405180910390fd5b5050565b600080600090507a184f03e93ff9f4daa797ed6e38ed64bf6a1f01000000000000000083106129b5577a184f03e93ff9f4daa797ed6e38ed64bf6a1f01000000000000000083816129ab576129aa614887565b5b0492506040810190505b6d04ee2d6d415b85acef810000000083106129f2576d04ee2d6d415b85acef810000000083816129e8576129e7614887565b5b0492506020810190505b662386f26fc100008310612a2157662386f26fc100008381612a1757612a16614887565b5b0492506010810190505b6305f5e1008310612a4a576305f5e1008381612a4057612a3f614887565b5b0492506008810190505b6127108310612a6f576127108381612a6557612a64614887565b5b0492506004810190505b60648310612a925760648381612a8857612a87614887565b5b0492506002810190505b600a8310612aa1576001810190505b80915050919050565b60606000600167ffffffffffffffff811115612ac957612ac861333d565b5b604051908082528060200260200182016040528015612af75781602001602082028036833780820191505090505b5090508281600081518110612b0f57612b0e614311565b5b60200260200101818152505080915050919050565b612b32868686868686612f5a565b505050505050565b505050505050565b612b618473ffffffffffffffffffffffffffffffffffffffff1661312a565b15612d11578373ffffffffffffffffffffffffffffffffffffffff1663f23a6e6187878686866040518663ffffffff1660e01b8152600401612ba7959493929190614e27565b6020604051808303816000875af1925050508015612be357506040513d601f19601f82011682018060405250810190612be09190614e96565b60015b612c8857612bef614ed0565b806308c379a003612c4b5750612c03614ef2565b80612c0e5750612c4d565b806040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401612c429190613530565b60405180910390fd5b505b6040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401612c7f90614ff4565b60405180910390fd5b63f23a6e6160e01b7bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916817bffffffffffffffffffffffffffffffffffffffffffffffffffffffff191614612d0f576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401612d0690615086565b60405180910390fd5b505b505050505050565b612d388473ffffffffffffffffffffffffffffffffffffffff1661312a565b15612ee8578373ffffffffffffffffffffffffffffffffffffffff1663bc197c8187878686866040518663ffffffff1660e01b8152600401612d7e9594939291906150a6565b6020604051808303816000875af1925050508015612dba57506040513d601f19601f82011682018060405250810190612db79190614e96565b60015b612e5f57612dc6614ed0565b806308c379a003612e225750612dda614ef2565b80612de55750612e24565b806040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401612e199190613530565b60405180910390fd5b505b6040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401612e5690614ff4565b60405180910390fd5b63bc197c8160e01b7bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916817bffffffffffffffffffffffffffffffffffffffffffffffffffffffff191614612ee6576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401612edd90615086565b60405180910390fd5b505b505050505050565b60007f01ffc9a7000000000000000000000000000000000000000000000000000000007bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916827bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916149050919050565b612f6886868686868661314d565b600073ffffffffffffffffffffffffffffffffffffffff168573ffffffffffffffffffffffffffffffffffffffff16036130195760005b835181101561301757828181518110612fbb57612fba614311565b5b602002602001015160046000868481518110612fda57612fd9614311565b5b602002602001015181526020019081526020016000206000828254612fff9190614127565b925050819055508061301090614340565b9050612f9f565b505b600073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16036131225760005b835181101561312057600084828151811061306e5761306d614311565b5b60200260200101519050600084838151811061308d5761308c614311565b5b60200260200101519050600060046000848152602001908152602001600020549050818110156130f2576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016130e990615180565b60405180910390fd5b81810360046000858152602001908152602001600020819055505050508061311990614340565b9050613050565b505b505050505050565b6000808273ffffffffffffffffffffffffffffffffffffffff163b119050919050565b505050505050565b6000604051905090565b600080fd5b600080fd5b600073ffffffffffffffffffffffffffffffffffffffff82169050919050565b600061319482613169565b9050919050565b6131a481613189565b81146131af57600080fd5b50565b6000813590506131c18161319b565b92915050565b6000819050919050565b6131da816131c7565b81146131e557600080fd5b50565b6000813590506131f7816131d1565b92915050565b600080604083850312156132145761321361315f565b5b6000613222858286016131b2565b9250506020613233858286016131e8565b9150509250929050565b613246816131c7565b82525050565b6000602082019050613261600083018461323d565b92915050565b60007fffffffff0000000000000000000000000000000000000000000000000000000082169050919050565b61329c81613267565b81146132a757600080fd5b50565b6000813590506132b981613293565b92915050565b6000602082840312156132d5576132d461315f565b5b60006132e3848285016132aa565b91505092915050565b60008115159050919050565b613301816132ec565b82525050565b600060208201905061331c60008301846132f8565b92915050565b600080fd5b600080fd5b6000601f19601f8301169050919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052604160045260246000fd5b6133758261332c565b810181811067ffffffffffffffff821117156133945761339361333d565b5b80604052505050565b60006133a7613155565b90506133b3828261336c565b919050565b600067ffffffffffffffff8211156133d3576133d261333d565b5b6133dc8261332c565b9050602081019050919050565b82818337600083830152505050565b600061340b613406846133b8565b61339d565b90508281526020810184848401111561342757613426613327565b5b6134328482856133e9565b509392505050565b600082601f83011261344f5761344e613322565b5b813561345f8482602086016133f8565b91505092915050565b60006020828403121561347e5761347d61315f565b5b600082013567ffffffffffffffff81111561349c5761349b613164565b5b6134a88482850161343a565b91505092915050565b600081519050919050565b600082825260208201905092915050565b60005b838110156134eb5780820151818401526020810190506134d0565b60008484015250505050565b6000613502826134b1565b61350c81856134bc565b935061351c8185602086016134cd565b6135258161332c565b840191505092915050565b6000602082019050818103600083015261354a81846134f7565b905092915050565b6000602082840312156135685761356761315f565b5b6000613576848285016131e8565b91505092915050565b6000806000606084860312156135985761359761315f565b5b60006135a6868287016131b2565b93505060206135b7868287016131e8565b92505060406135c8868287016131e8565b9150509250925092565b6000819050919050565b6135e5816135d2565b81146135f057600080fd5b50565b600081359050613602816135dc565b92915050565b60006020828403121561361e5761361d61315f565b5b600061362c848285016135f3565b91505092915050565b61363e816135d2565b82525050565b60006020820190506136596000830184613635565b92915050565b600067ffffffffffffffff82111561367a5761367961333d565b5b602082029050602081019050919050565b600080fd5b60006136a361369e8461365f565b61339d565b905080838252602082019050602084028301858111156136c6576136c561368b565b5b835b818110156136ef57806136db88826131e8565b8452602084019350506020810190506136c8565b5050509392505050565b600082601f83011261370e5761370d613322565b5b813561371e848260208601613690565b91505092915050565b600067ffffffffffffffff8211156137425761374161333d565b5b61374b8261332c565b9050602081019050919050565b600061376b61376684613727565b61339d565b90508281526020810184848401111561378757613786613327565b5b6137928482856133e9565b509392505050565b600082601f8301126137af576137ae613322565b5b81356137bf848260208601613758565b91505092915050565b600080600080600060a086880312156137e4576137e361315f565b5b60006137f2888289016131b2565b9550506020613803888289016131b2565b945050604086013567ffffffffffffffff81111561382457613823613164565b5b613830888289016136f9565b935050606086013567ffffffffffffffff81111561385157613850613164565b5b61385d888289016136f9565b925050608086013567ffffffffffffffff81111561387e5761387d613164565b5b61388a8882890161379a565b9150509295509295909350565b600080604083850312156138ae576138ad61315f565b5b60006138bc858286016135f3565b92505060206138cd858286016131b2565b9150509250929050565b6138e081613189565b82525050565b60006020820190506138fb60008301846138d7565b92915050565b600067ffffffffffffffff82111561391c5761391b61333d565b5b602082029050602081019050919050565b600061394061393b84613901565b61339d565b905080838252602082019050602084028301858111156139635761396261368b565b5b835b8181101561398c578061397888826131b2565b845260208401935050602081019050613965565b5050509392505050565b600082601f8301126139ab576139aa613322565b5b81356139bb84826020860161392d565b91505092915050565b600080604083850312156139db576139da61315f565b5b600083013567ffffffffffffffff8111156139f9576139f8613164565b5b613a0585828601613996565b925050602083013567ffffffffffffffff811115613a2657613a25613164565b5b613a32858286016136f9565b9150509250929050565b600081519050919050565b600082825260208201905092915050565b6000819050602082019050919050565b613a71816131c7565b82525050565b6000613a838383613a68565b60208301905092915050565b6000602082019050919050565b6000613aa782613a3c565b613ab18185613a47565b9350613abc83613a58565b8060005b83811015613aed578151613ad48882613a77565b9750613adf83613a8f565b925050600181019050613ac0565b5085935050505092915050565b60006020820190508181036000830152613b148184613a9c565b905092915050565b60008060408385031215613b3357613b3261315f565b5b6000613b41858286016131e8565b925050602083013567ffffffffffffffff811115613b6257613b61613164565b5b613b6e8582860161343a565b9150509250929050565b600081519050919050565b600082825260208201905092915050565b6000613b9f82613b78565b613ba98185613b83565b9350613bb98185602086016134cd565b613bc28161332c565b840191505092915050565b60006020820190508181036000830152613be78184613b94565b905092915050565b60008060408385031215613c0657613c0561315f565b5b6000613c14858286016131e8565b9250506020613c25858286016131e8565b9150509250929050565b60008060008060808587031215613c4957613c4861315f565b5b6000613c57878288016131b2565b9450506020613c68878288016131b2565b9350506040613c79878288016131e8565b925050606085013567ffffffffffffffff811115613c9a57613c99613164565b5b613ca68782880161379a565b91505092959194509250565b613cbb81613267565b82525050565b6000602082019050613cd66000830184613cb2565b92915050565b600060208284031215613cf257613cf161315f565b5b6000613d00848285016131b2565b91505092915050565b613d12816132ec565b8114613d1d57600080fd5b50565b600081359050613d2f81613d09565b92915050565b60008060408385031215613d4c57613d4b61315f565b5b6000613d5a858286016131b2565b9250506020613d6b85828601613d20565b9150509250929050565b60008060408385031215613d8c57613d8b61315f565b5b6000613d9a858286016131b2565b9250506020613dab858286016131b2565b9150509250929050565b600080600080600060a08688031215613dd157613dd061315f565b5b6000613ddf888289016131b2565b9550506020613df0888289016131b2565b9450506040613e01888289016131e8565b9350506060613e12888289016131e8565b925050608086013567ffffffffffffffff811115613e3357613e32613164565b5b613e3f8882890161379a565b9150509295509295909350565b6000819050919050565b6000613e71613e6c613e6784613169565b613e4c565b613169565b9050919050565b6000613e8382613e56565b9050919050565b6000613e9582613e78565b9050919050565b613ea581613e8a565b82525050565b6000602082019050613ec06000830184613e9c565b92915050565b7f455243313135353a2061646472657373207a65726f206973206e6f742061207660008201527f616c6964206f776e657200000000000000000000000000000000000000000000602082015250565b6000613f22602a836134bc565b9150613f2d82613ec6565b604082019050919050565b60006020820190508181036000830152613f5181613f15565b9050919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052602260045260246000fd5b60006002820490506001821680613f9f57607f821691505b602082108103613fb257613fb1613f58565b5b50919050565b600081905092915050565b6000613fce826134b1565b613fd88185613fb8565b9350613fe88185602086016134cd565b80840191505092915050565b60008190508160005260206000209050919050565b6000815461401681613f87565b6140208186613fb8565b9450600182166000811461403b576001811461405057614083565b60ff1983168652811515820286019350614083565b61405985613ff4565b60005b8381101561407b5781548189015260018201915060208101905061405c565b838801955050505b50505092915050565b60006140988285613fc3565b91506140a48284614009565b91508190509392505050565b60006140bc8285613fc3565b91506140c88284613fc3565b91508190509392505050565b60006140e08285614009565b91506140ec8284613fc3565b91508190509392505050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b6000614132826131c7565b915061413d836131c7565b9250828201905080821115614155576141546140f8565b5b92915050565b7f455243313135353a2063616c6c6572206973206e6f7420746f6b656e206f776e60008201527f6572206f7220617070726f766564000000000000000000000000000000000000602082015250565b60006141b7602e836134bc565b91506141c28261415b565b604082019050919050565b600060208201905081810360008301526141e6816141aa565b9050919050565b7f416363657373436f6e74726f6c3a2063616e206f6e6c792072656e6f756e636560008201527f20726f6c657320666f722073656c660000000000000000000000000000000000602082015250565b6000614249602f836134bc565b9150614254826141ed565b604082019050919050565b600060208201905081810360008301526142788161423c565b9050919050565b7f455243313135353a206163636f756e747320616e6420696473206c656e67746860008201527f206d69736d617463680000000000000000000000000000000000000000000000602082015250565b60006142db6029836134bc565b91506142e68261427f565b604082019050919050565b6000602082019050818103600083015261430a816142ce565b9050919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052603260045260246000fd5b600061434b826131c7565b91507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff820361437d5761437c6140f8565b5b600182019050919050565b60006020601f8301049050919050565b600082821b905092915050565b6000600883026143d57fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff82614398565b6143df8683614398565b95508019841693508086168417925050509392505050565b600061441261440d614408846131c7565b613e4c565b6131c7565b9050919050565b6000819050919050565b61442c836143f7565b61444061443882614419565b8484546143a5565b825550505050565b600090565b614455614448565b614460818484614423565b505050565b5b818110156144845761447960008261444d565b600181019050614466565b5050565b601f8211156144c95761449a81613ff4565b6144a384614388565b810160208510156144b2578190505b6144c66144be85614388565b830182614465565b50505b505050565b600082821c905092915050565b60006144ec600019846008026144ce565b1980831691505092915050565b600061450583836144db565b9150826002028217905092915050565b61451e826134b1565b67ffffffffffffffff8111156145375761453661333d565b5b6145418254613f87565b61454c828285614488565b600060209050601f83116001811461457f576000841561456d578287015190505b61457785826144f9565b8655506145df565b601f19841661458d86613ff4565b60005b828110156145b557848901518255600182019150602085019450602081019050614590565b868310156145d257848901516145ce601f8916826144db565b8355505b6001600288020188555050505b505050505050565b7f4e6f74206d6c2061646d696e0000000000000000000000000000000000000000600082015250565b600061461d600c836134bc565b9150614628826145e7565b602082019050919050565b6000602082019050818103600083015261464c81614610565b9050919050565b600081519050614662816131d1565b92915050565b60006020828403121561467e5761467d61315f565b5b600061468c84828501614653565b91505092915050565b7f4974656d207072696365206e6f74207365740000000000000000000000000000600082015250565b60006146cb6012836134bc565b91506146d682614695565b602082019050919050565b600060208201905081810360008301526146fa816146be565b9050919050565b7f696e76616c6964207061796d656e742076616c75650000000000000000000000600082015250565b60006147376015836134bc565b915061474282614701565b602082019050919050565b600060208201905081810360008301526147668161472a565b9050919050565b7f4e6f6e65206c65667420746f206d696e74000000000000000000000000000000600082015250565b60006147a36011836134bc565b91506147ae8261476d565b602082019050919050565b600060208201905081810360008301526147d281614796565b9050919050565b7f416c7265616479206d696e746564206c696d6974000000000000000000000000600082015250565b600061480f6014836134bc565b915061481a826147d9565b602082019050919050565b6000602082019050818103600083015261483e81614802565b9050919050565b6000614850826131c7565b915061485b836131c7565b9250828202614869816131c7565b915082820484148315176148805761487f6140f8565b5b5092915050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601260045260246000fd5b60006148c1826131c7565b91506148cc836131c7565b9250826148dc576148db614887565b5b828204905092915050565b60006040820190506148fc60008301856138d7565b614909602083018461323d565b9392505050565b60008151905061491f81613d09565b92915050565b60006020828403121561493b5761493a61315f565b5b600061494984828501614910565b91505092915050565b600061495d826131c7565b9150614968836131c7565b92508282039050818111156149805761497f6140f8565b5b92915050565b6000614991826131c7565b9150600082036149a4576149a36140f8565b5b600182039050919050565b7f537472696e67733a20686578206c656e67746820696e73756666696369656e74600082015250565b60006149e56020836134bc565b91506149f0826149af565b602082019050919050565b60006020820190508181036000830152614a14816149d8565b9050919050565b7f455243313135353a206d696e7420746f20746865207a65726f2061646472657360008201527f7300000000000000000000000000000000000000000000000000000000000000602082015250565b6000614a776021836134bc565b9150614a8282614a1b565b604082019050919050565b60006020820190508181036000830152614aa681614a6a565b9050919050565b6000604082019050614ac2600083018561323d565b614acf602083018461323d565b9392505050565b7f455243313135353a2069647320616e6420616d6f756e7473206c656e6774682060008201527f6d69736d61746368000000000000000000000000000000000000000000000000602082015250565b6000614b326028836134bc565b9150614b3d82614ad6565b604082019050919050565b60006020820190508181036000830152614b6181614b25565b9050919050565b7f455243313135353a207472616e7366657220746f20746865207a65726f20616460008201527f6472657373000000000000000000000000000000000000000000000000000000602082015250565b6000614bc46025836134bc565b9150614bcf82614b68565b604082019050919050565b60006020820190508181036000830152614bf381614bb7565b9050919050565b7f455243313135353a20696e73756666696369656e742062616c616e636520666f60008201527f72207472616e7366657200000000000000000000000000000000000000000000602082015250565b6000614c56602a836134bc565b9150614c6182614bfa565b604082019050919050565b60006020820190508181036000830152614c8581614c49565b9050919050565b60006040820190508181036000830152614ca68185613a9c565b90508181036020830152614cba8184613a9c565b90509392505050565b7f455243313135353a2073657474696e6720617070726f76616c2073746174757360008201527f20666f722073656c660000000000000000000000000000000000000000000000602082015250565b6000614d1f6029836134bc565b9150614d2a82614cc3565b604082019050919050565b60006020820190508181036000830152614d4e81614d12565b9050919050565b7f416363657373436f6e74726f6c3a206163636f756e7420000000000000000000600082015250565b6000614d8b601783613fb8565b9150614d9682614d55565b601782019050919050565b7f206973206d697373696e6720726f6c6520000000000000000000000000000000600082015250565b6000614dd7601183613fb8565b9150614de282614da1565b601182019050919050565b6000614df882614d7e565b9150614e048285613fc3565b9150614e0f82614dca565b9150614e1b8284613fc3565b91508190509392505050565b600060a082019050614e3c60008301886138d7565b614e4960208301876138d7565b614e56604083018661323d565b614e63606083018561323d565b8181036080830152614e758184613b94565b90509695505050505050565b600081519050614e9081613293565b92915050565b600060208284031215614eac57614eab61315f565b5b6000614eba84828501614e81565b91505092915050565b60008160e01c9050919050565b600060033d1115614eef5760046000803e614eec600051614ec3565b90505b90565b600060443d10614f7f57614f04613155565b60043d036004823e80513d602482011167ffffffffffffffff82111715614f2c575050614f7f565b808201805167ffffffffffffffff811115614f4a5750505050614f7f565b80602083010160043d038501811115614f67575050505050614f7f565b614f768260200185018661336c565b82955050505050505b90565b7f455243313135353a207472616e7366657220746f206e6f6e2d4552433131353560008201527f526563656976657220696d706c656d656e746572000000000000000000000000602082015250565b6000614fde6034836134bc565b9150614fe982614f82565b604082019050919050565b6000602082019050818103600083015261500d81614fd1565b9050919050565b7f455243313135353a204552433131353552656365697665722072656a6563746560008201527f6420746f6b656e73000000000000000000000000000000000000000000000000602082015250565b60006150706028836134bc565b915061507b82615014565b604082019050919050565b6000602082019050818103600083015261509f81615063565b9050919050565b600060a0820190506150bb60008301886138d7565b6150c860208301876138d7565b81810360408301526150da8186613a9c565b905081810360608301526150ee8185613a9c565b905081810360808301526151028184613b94565b90509695505050505050565b7f455243313135353a206275726e20616d6f756e74206578636565647320746f7460008201527f616c537570706c79000000000000000000000000000000000000000000000000602082015250565b600061516a6028836134bc565b91506151758261510e565b604082019050919050565b600060208201905081810360008301526151998161515d565b905091905056fea26469706673582212203e081b43f22c5f665a5ee637ebcb8e7641c7d9cbe16d51b81715804ba2d16a3564736f6c6343000811003368747470733a2f2f7374617469632e6d7573746172646c6162732e696f2f7069636b6c65732f65646974696f6e732f646174612f
Deployed Bytecode
0x608060405234801561001057600080fd5b50600436106102475760003560e01c806388a7ca5c1161013b578063c321d1e0116100b8578063e985e9c51161007c578063e985e9c514610744578063f242432a14610774578063f765417614610790578063f7d97577146107ae578063fc0c546a146107ca57610247565b8063c321d1e0146106b6578063c4590d3f146106d2578063c47f0027146106ee578063d53913931461070a578063d547741f1461072857610247565b8063a217fddf116100ff578063a217fddf146105fe578063a22cb4651461061c578063bc31c1c114610638578063bd85b03914610668578063be6eec391461069857610247565b806388a7ca5c1461053457806391d148541461056457806395d89b411461059457806396e494e8146105b257806399b84258146105e257610247565b806336568abe116101c95780635ef033ae1161018d5780635ef033ae14610480578063674e694f146104b05780637dc0bf3f146104cc57806381b3e575146104fc57806386f840e61461051857610247565b806336568abe146103ca57806338af3eed146103e65780634e1273f4146104045780634f558e79146104345780635bb671131461046457610247565b8063156e29f611610210578063156e29f614610316578063243bcfcb14610332578063248a9ca3146103625780632eb2c2d6146103925780632f2ff15d146103ae57610247565b8062fdd58e1461024c57806301ffc9a71461027c57806302fe5305146102ac57806306fdde03146102c85780630e89341c146102e6575b600080fd5b610266600480360381019061026191906131fd565b6107e8565b604051610273919061324c565b60405180910390f35b610296600480360381019061029191906132bf565b6108b1565b6040516102a39190613307565b60405180910390f35b6102c660048036038101906102c19190613468565b6108c3565b005b6102d06108fa565b6040516102dd9190613530565b60405180910390f35b61030060048036038101906102fb9190613552565b610988565b60405161030d9190613530565b60405180910390f35b610330600480360381019061032b919061357f565b610a4c565b005b61034c60048036038101906103479190613552565b610a97565b604051610359919061324c565b60405180910390f35b61037c60048036038101906103779190613608565b610ac0565b6040516103899190613644565b60405180910390f35b6103ac60048036038101906103a791906137c8565b610adf565b005b6103c860048036038101906103c39190613897565b610b80565b005b6103e460048036038101906103df9190613897565b610ba1565b005b6103ee610c24565b6040516103fb91906138e6565b60405180910390f35b61041e600480360381019061041991906139c4565b610c4a565b60405161042b9190613afa565b60405180910390f35b61044e60048036038101906104499190613552565b610d63565b60405161045b9190613307565b60405180910390f35b61047e60048036038101906104799190613b1c565b610d77565b005b61049a60048036038101906104959190613552565b610dc7565b6040516104a79190613bcd565b60405180910390f35b6104ca60048036038101906104c59190613552565b610df0565b005b6104e660048036038101906104e19190613552565b610e8a565b6040516104f3919061324c565b60405180910390f35b61051660048036038101906105119190613468565b610ea2565b005b610532600480360381019061052d9190613bef565b610ee0565b005b61054e60048036038101906105499190613c2f565b610f39565b60405161055b9190613cc1565b60405180910390f35b61057e60048036038101906105799190613897565b6113c9565b60405161058b9190613307565b60405180910390f35b61059c611433565b6040516105a99190613530565b60405180910390f35b6105cc60048036038101906105c79190613552565b6114c1565b6040516105d9919061324c565b60405180910390f35b6105fc60048036038101906105f79190613cdc565b6114d9565b005b6106066115ad565b6040516106139190613644565b60405180910390f35b61063660048036038101906106319190613d35565b6115b4565b005b610652600480360381019061064d9190613552565b6115ca565b60405161065f919061324c565b60405180910390f35b610682600480360381019061067d9190613552565b6115e2565b60405161068f919061324c565b60405180910390f35b6106a06115ff565b6040516106ad91906138e6565b60405180910390f35b6106d060048036038101906106cb9190613bef565b611625565b005b6106ec60048036038101906106e79190613bef565b61166c565b005b61070860048036038101906107039190613468565b6116b3565b005b6107126116f1565b60405161071f9190613644565b60405180910390f35b610742600480360381019061073d9190613897565b611715565b005b61075e60048036038101906107599190613d75565b611736565b60405161076b9190613307565b60405180910390f35b61078e60048036038101906107899190613db5565b6117ca565b005b61079861186b565b6040516107a5919061324c565b60405180910390f35b6107c860048036038101906107c39190613bef565b611871565b005b6107d26118b8565b6040516107df9190613eab565b60405180910390f35b60008073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1603610858576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161084f90613f38565b60405180910390fd5b6001600083815260200190815260200160002060008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054905092915050565b60006108bc82611b45565b9050919050565b7f9f2df0fed2c77648de5860a4cc508cd0818c85b8b8a1ab4ceeef8d981c8956a66108ed81611c27565b6108f682611c3b565b5050565b600e805461090790613f87565b80601f016020809104026020016040519081016040528092919081815260200182805461093390613f87565b80156109805780601f1061095557610100808354040283529160200191610980565b820191906000526020600020905b81548152906001019060200180831161096357829003601f168201915b505050505081565b6060600061099583611c4e565b600d6040516020016109a892919061408c565b60405160208183030381529060405290506000600c600085815260200190815260200160002080546109d990613f87565b905011610a0f576109e983611d1c565b816040516020016109fb9291906140b0565b604051602081830303815290604052610a44565b600c600084815260200190815260200160002081604051602001610a349291906140d4565b6040516020818303038152906040525b915050919050565b7f9f2df0fed2c77648de5860a4cc508cd0818c85b8b8a1ab4ceeef8d981c8956a6610a7681611c27565b610a9184848460405180602001604052806000815250611db0565b50505050565b60006001600b600084815260200190815260200160002054610ab99190614127565b9050919050565b6000806000838152602001908152602001600020600101549050919050565b610ae7611f61565b73ffffffffffffffffffffffffffffffffffffffff168573ffffffffffffffffffffffffffffffffffffffff161480610b2d5750610b2c85610b27611f61565b611736565b5b610b6c576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610b63906141cd565b60405180910390fd5b610b798585858585611f69565b5050505050565b610b8982610ac0565b610b9281611c27565b610b9c838361228d565b505050565b610ba9611f61565b73ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff1614610c16576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610c0d9061425f565b60405180910390fd5b610c20828261236d565b5050565b600560009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b60608151835114610c90576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610c87906142f1565b60405180910390fd5b6000835167ffffffffffffffff811115610cad57610cac61333d565b5b604051908082528060200260200182016040528015610cdb5781602001602082028036833780820191505090505b50905060005b8451811015610d5857610d28858281518110610d0057610cff614311565b5b6020026020010151858381518110610d1b57610d1a614311565b5b60200260200101516107e8565b828281518110610d3b57610d3a614311565b5b60200260200101818152505080610d5190614340565b9050610ce1565b508091505092915050565b600080610d6f836115e2565b119050919050565b7f9f2df0fed2c77648de5860a4cc508cd0818c85b8b8a1ab4ceeef8d981c8956a6610da181611c27565b81600c60008581526020019081526020016000209081610dc19190614515565b50505050565b606081604051602001610dda919061324c565b6040516020818303038152906040529050919050565b600660009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff1614610e80576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610e7790614633565b60405180910390fd5b8060078190555050565b60096020528060005260406000206000915090505481565b7f9f2df0fed2c77648de5860a4cc508cd0818c85b8b8a1ab4ceeef8d981c8956a6610ecc81611c27565b81600d9081610edb9190614515565b505050565b7f9f2df0fed2c77648de5860a4cc508cd0818c85b8b8a1ab4ceeef8d981c8956a6610f0a81611c27565b81600a60008581526020019081526020016000206000828254610f2d9190614127565b92505081905550505050565b60007f00000000000000000000000078b5c6149c87c82edcffc73c230395abbc56ddd573ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff1614610f9357600080fd5b600082806020019051810190610fa99190614668565b905060006008600083815260200190815260200160002054905060008111611006576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401610ffd906146e1565b60405180910390fd5b80851015611049576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016110409061474d565b60405180910390fd5b600a600083815260200190815260200160002054600960008481526020019081526020016000205411156110b2576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016110a9906147b9565b60405180910390fd5b600b6000838152602001908152602001600020546110d088846107e8565b1115611111576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161110890614825565b60405180910390fd5b60006064600754836111239190614845565b61112d91906148b6565b90507f00000000000000000000000078b5c6149c87c82edcffc73c230395abbc56ddd573ffffffffffffffffffffffffffffffffffffffff1663a9059cbb600560009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16836040518363ffffffff1660e01b81526004016111ac9291906148e7565b6020604051808303816000875af11580156111cb573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906111ef9190614925565b507f00000000000000000000000078b5c6149c87c82edcffc73c230395abbc56ddd573ffffffffffffffffffffffffffffffffffffffff1663a9059cbb600660009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16838561125b9190614952565b6040518363ffffffff1660e01b81526004016112789291906148e7565b6020604051808303816000875af1158015611297573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906112bb9190614925565b506009600084815260200190815260200160002060008154809291906112e090614340565b91905055506113018884600160405180602001604052806000815250611db0565b818611156113b4577f00000000000000000000000078b5c6149c87c82edcffc73c230395abbc56ddd573ffffffffffffffffffffffffffffffffffffffff1663a9059cbb8884896113529190614952565b6040518363ffffffff1660e01b815260040161136f9291906148e7565b6020604051808303816000875af115801561138e573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906113b29190614925565b505b6388a7ca5c60e01b9350505050949350505050565b600080600084815260200190815260200160002060000160008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16905092915050565b600f805461144090613f87565b80601f016020809104026020016040519081016040528092919081815260200182805461146c90613f87565b80156114b95780601f1061148e576101008083540402835291602001916114b9565b820191906000526020600020905b81548152906001019060200180831161149c57829003601f168201915b505050505081565b600a6020528060005260406000206000915090505481565b600660009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff1614611569576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161156090614633565b60405180910390fd5b80600660006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555050565b6000801b81565b6115c66115bf611f61565b838361244e565b5050565b60086020528060005260406000206000915090505481565b600060046000838152602001908152602001600020549050919050565b600660009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b7f9f2df0fed2c77648de5860a4cc508cd0818c85b8b8a1ab4ceeef8d981c8956a661164f81611c27565b81600a600085815260200190815260200160002081905550505050565b7f9f2df0fed2c77648de5860a4cc508cd0818c85b8b8a1ab4ceeef8d981c8956a661169681611c27565b81600b600085815260200190815260200160002081905550505050565b7f9f2df0fed2c77648de5860a4cc508cd0818c85b8b8a1ab4ceeef8d981c8956a66116dd81611c27565b81600e90816116ec9190614515565b505050565b7f9f2df0fed2c77648de5860a4cc508cd0818c85b8b8a1ab4ceeef8d981c8956a681565b61171e82610ac0565b61172781611c27565b611731838361236d565b505050565b6000600260008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16905092915050565b6117d2611f61565b73ffffffffffffffffffffffffffffffffffffffff168573ffffffffffffffffffffffffffffffffffffffff161480611818575061181785611812611f61565b611736565b5b611857576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161184e906141cd565b60405180910390fd5b61186485858585856125ba565b5050505050565b60075481565b7f9f2df0fed2c77648de5860a4cc508cd0818c85b8b8a1ab4ceeef8d981c8956a661189b81611c27565b816008600085815260200190815260200160002081905550505050565b7f00000000000000000000000078b5c6149c87c82edcffc73c230395abbc56ddd581565b60606119028273ffffffffffffffffffffffffffffffffffffffff16601460ff16611909565b9050919050565b60606000600283600261191c9190614845565b6119269190614127565b67ffffffffffffffff81111561193f5761193e61333d565b5b6040519080825280601f01601f1916602001820160405280156119715781602001600182028036833780820191505090505b5090507f3000000000000000000000000000000000000000000000000000000000000000816000815181106119a9576119a8614311565b5b60200101907effffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916908160001a9053507f780000000000000000000000000000000000000000000000000000000000000081600181518110611a0d57611a0c614311565b5b60200101907effffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916908160001a90535060006001846002611a4d9190614845565b611a579190614127565b90505b6001811115611af7577f3031323334353637383961626364656600000000000000000000000000000000600f861660108110611a9957611a98614311565b5b1a60f81b828281518110611ab057611aaf614311565b5b60200101907effffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916908160001a905350600485901c945080611af090614986565b9050611a5a565b5060008414611b3b576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611b32906149fb565b60405180910390fd5b8091505092915050565b60007fd9b67a26000000000000000000000000000000000000000000000000000000007bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916827bffffffffffffffffffffffffffffffffffffffffffffffffffffffff19161480611c1057507f0e89341c000000000000000000000000000000000000000000000000000000007bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916827bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916145b80611c205750611c1f82612858565b5b9050919050565b611c3881611c33611f61565b6128d2565b50565b8060039081611c4a9190614515565b5050565b606060006001611c5d84612957565b01905060008167ffffffffffffffff811115611c7c57611c7b61333d565b5b6040519080825280601f01601f191660200182016040528015611cae5781602001600182028036833780820191505090505b509050600082602001820190505b600115611d11578080600190039150507f3031323334353637383961626364656600000000000000000000000000000000600a86061a8153600a8581611d0557611d04614887565b5b04945060008503611cbc575b819350505050919050565b606060038054611d2b90613f87565b80601f0160208091040260200160405190810160405280929190818152602001828054611d5790613f87565b8015611da45780601f10611d7957610100808354040283529160200191611da4565b820191906000526020600020905b815481529060010190602001808311611d8757829003601f168201915b50505050509050919050565b600073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1603611e1f576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611e1690614a8d565b60405180910390fd5b6000611e29611f61565b90506000611e3685612aaa565b90506000611e4385612aaa565b9050611e5483600089858589612b24565b846001600088815260200190815260200160002060008973ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000206000828254611eb49190614127565b925050819055508673ffffffffffffffffffffffffffffffffffffffff16600073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fc3d58168c5ae7397731d063d5bbf3d657854427343f4c083240f7aacaa2d0f628989604051611f32929190614aad565b60405180910390a4611f4983600089858589612b3a565b611f5883600089898989612b42565b50505050505050565b600033905090565b8151835114611fad576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401611fa490614b48565b60405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff160361201c576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161201390614bda565b60405180910390fd5b6000612026611f61565b9050612036818787878787612b24565b60005b84518110156121ea57600085828151811061205757612056614311565b5b60200260200101519050600085838151811061207657612075614311565b5b6020026020010151905060006001600084815260200190815260200160002060008b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054905081811015612118576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161210f90614c6c565b60405180910390fd5b8181036001600085815260200190815260200160002060008c73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002081905550816001600085815260200190815260200160002060008b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008282546121cf9190614127565b92505081905550505050806121e390614340565b9050612039565b508473ffffffffffffffffffffffffffffffffffffffff168673ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff167f4a39dc06d4c0dbc64b70af90fd698a233a518aa5d07e595d983b8c0526c8f7fb8787604051612261929190614c8c565b60405180910390a4612277818787878787612b3a565b612285818787878787612d19565b505050505050565b61229782826113c9565b61236957600160008084815260200190815260200160002060000160008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff02191690831515021790555061230e611f61565b73ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff16837f2f8788117e7eff1d82e926ec794901d17c78024a50270940304540a733656f0d60405160405180910390a45b5050565b61237782826113c9565b1561244a57600080600084815260200190815260200160002060000160008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff0219169083151502179055506123ef611f61565b73ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff16837ff6391f5c32d9c69d2a47ea670b442974b53935d1edc7fd64eb21e047a839171b60405160405180910390a45b5050565b8173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff16036124bc576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016124b390614d35565b60405180910390fd5b80600260008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff0219169083151502179055508173ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c31836040516125ad9190613307565b60405180910390a3505050565b600073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1603612629576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161262090614bda565b60405180910390fd5b6000612633611f61565b9050600061264085612aaa565b9050600061264d85612aaa565b905061265d838989858589612b24565b60006001600088815260200190815260200160002060008a73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020549050858110156126f5576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016126ec90614c6c565b60405180910390fd5b8581036001600089815260200190815260200160002060008b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002081905550856001600089815260200190815260200160002060008a73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008282546127ac9190614127565b925050819055508773ffffffffffffffffffffffffffffffffffffffff168973ffffffffffffffffffffffffffffffffffffffff168573ffffffffffffffffffffffffffffffffffffffff167fc3d58168c5ae7397731d063d5bbf3d657854427343f4c083240f7aacaa2d0f628a8a604051612829929190614aad565b60405180910390a461283f848a8a86868a612b3a565b61284d848a8a8a8a8a612b42565b505050505050505050565b60007f7965db0b000000000000000000000000000000000000000000000000000000007bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916827bffffffffffffffffffffffffffffffffffffffffffffffffffffffff191614806128cb57506128ca82612ef0565b5b9050919050565b6128dc82826113c9565b612953576128e9816118dc565b6128f78360001c6020611909565b604051602001612908929190614ded565b6040516020818303038152906040526040517f08c379a000000000000000000000000000000000000000000000000000000000815260040161294a9190613530565b60405180910390fd5b5050565b600080600090507a184f03e93ff9f4daa797ed6e38ed64bf6a1f01000000000000000083106129b5577a184f03e93ff9f4daa797ed6e38ed64bf6a1f01000000000000000083816129ab576129aa614887565b5b0492506040810190505b6d04ee2d6d415b85acef810000000083106129f2576d04ee2d6d415b85acef810000000083816129e8576129e7614887565b5b0492506020810190505b662386f26fc100008310612a2157662386f26fc100008381612a1757612a16614887565b5b0492506010810190505b6305f5e1008310612a4a576305f5e1008381612a4057612a3f614887565b5b0492506008810190505b6127108310612a6f576127108381612a6557612a64614887565b5b0492506004810190505b60648310612a925760648381612a8857612a87614887565b5b0492506002810190505b600a8310612aa1576001810190505b80915050919050565b60606000600167ffffffffffffffff811115612ac957612ac861333d565b5b604051908082528060200260200182016040528015612af75781602001602082028036833780820191505090505b5090508281600081518110612b0f57612b0e614311565b5b60200260200101818152505080915050919050565b612b32868686868686612f5a565b505050505050565b505050505050565b612b618473ffffffffffffffffffffffffffffffffffffffff1661312a565b15612d11578373ffffffffffffffffffffffffffffffffffffffff1663f23a6e6187878686866040518663ffffffff1660e01b8152600401612ba7959493929190614e27565b6020604051808303816000875af1925050508015612be357506040513d601f19601f82011682018060405250810190612be09190614e96565b60015b612c8857612bef614ed0565b806308c379a003612c4b5750612c03614ef2565b80612c0e5750612c4d565b806040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401612c429190613530565b60405180910390fd5b505b6040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401612c7f90614ff4565b60405180910390fd5b63f23a6e6160e01b7bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916817bffffffffffffffffffffffffffffffffffffffffffffffffffffffff191614612d0f576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401612d0690615086565b60405180910390fd5b505b505050505050565b612d388473ffffffffffffffffffffffffffffffffffffffff1661312a565b15612ee8578373ffffffffffffffffffffffffffffffffffffffff1663bc197c8187878686866040518663ffffffff1660e01b8152600401612d7e9594939291906150a6565b6020604051808303816000875af1925050508015612dba57506040513d601f19601f82011682018060405250810190612db79190614e96565b60015b612e5f57612dc6614ed0565b806308c379a003612e225750612dda614ef2565b80612de55750612e24565b806040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401612e199190613530565b60405180910390fd5b505b6040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401612e5690614ff4565b60405180910390fd5b63bc197c8160e01b7bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916817bffffffffffffffffffffffffffffffffffffffffffffffffffffffff191614612ee6576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401612edd90615086565b60405180910390fd5b505b505050505050565b60007f01ffc9a7000000000000000000000000000000000000000000000000000000007bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916827bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916149050919050565b612f6886868686868661314d565b600073ffffffffffffffffffffffffffffffffffffffff168573ffffffffffffffffffffffffffffffffffffffff16036130195760005b835181101561301757828181518110612fbb57612fba614311565b5b602002602001015160046000868481518110612fda57612fd9614311565b5b602002602001015181526020019081526020016000206000828254612fff9190614127565b925050819055508061301090614340565b9050612f9f565b505b600073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff16036131225760005b835181101561312057600084828151811061306e5761306d614311565b5b60200260200101519050600084838151811061308d5761308c614311565b5b60200260200101519050600060046000848152602001908152602001600020549050818110156130f2576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004016130e990615180565b60405180910390fd5b81810360046000858152602001908152602001600020819055505050508061311990614340565b9050613050565b505b505050505050565b6000808273ffffffffffffffffffffffffffffffffffffffff163b119050919050565b505050505050565b6000604051905090565b600080fd5b600080fd5b600073ffffffffffffffffffffffffffffffffffffffff82169050919050565b600061319482613169565b9050919050565b6131a481613189565b81146131af57600080fd5b50565b6000813590506131c18161319b565b92915050565b6000819050919050565b6131da816131c7565b81146131e557600080fd5b50565b6000813590506131f7816131d1565b92915050565b600080604083850312156132145761321361315f565b5b6000613222858286016131b2565b9250506020613233858286016131e8565b9150509250929050565b613246816131c7565b82525050565b6000602082019050613261600083018461323d565b92915050565b60007fffffffff0000000000000000000000000000000000000000000000000000000082169050919050565b61329c81613267565b81146132a757600080fd5b50565b6000813590506132b981613293565b92915050565b6000602082840312156132d5576132d461315f565b5b60006132e3848285016132aa565b91505092915050565b60008115159050919050565b613301816132ec565b82525050565b600060208201905061331c60008301846132f8565b92915050565b600080fd5b600080fd5b6000601f19601f8301169050919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052604160045260246000fd5b6133758261332c565b810181811067ffffffffffffffff821117156133945761339361333d565b5b80604052505050565b60006133a7613155565b90506133b3828261336c565b919050565b600067ffffffffffffffff8211156133d3576133d261333d565b5b6133dc8261332c565b9050602081019050919050565b82818337600083830152505050565b600061340b613406846133b8565b61339d565b90508281526020810184848401111561342757613426613327565b5b6134328482856133e9565b509392505050565b600082601f83011261344f5761344e613322565b5b813561345f8482602086016133f8565b91505092915050565b60006020828403121561347e5761347d61315f565b5b600082013567ffffffffffffffff81111561349c5761349b613164565b5b6134a88482850161343a565b91505092915050565b600081519050919050565b600082825260208201905092915050565b60005b838110156134eb5780820151818401526020810190506134d0565b60008484015250505050565b6000613502826134b1565b61350c81856134bc565b935061351c8185602086016134cd565b6135258161332c565b840191505092915050565b6000602082019050818103600083015261354a81846134f7565b905092915050565b6000602082840312156135685761356761315f565b5b6000613576848285016131e8565b91505092915050565b6000806000606084860312156135985761359761315f565b5b60006135a6868287016131b2565b93505060206135b7868287016131e8565b92505060406135c8868287016131e8565b9150509250925092565b6000819050919050565b6135e5816135d2565b81146135f057600080fd5b50565b600081359050613602816135dc565b92915050565b60006020828403121561361e5761361d61315f565b5b600061362c848285016135f3565b91505092915050565b61363e816135d2565b82525050565b60006020820190506136596000830184613635565b92915050565b600067ffffffffffffffff82111561367a5761367961333d565b5b602082029050602081019050919050565b600080fd5b60006136a361369e8461365f565b61339d565b905080838252602082019050602084028301858111156136c6576136c561368b565b5b835b818110156136ef57806136db88826131e8565b8452602084019350506020810190506136c8565b5050509392505050565b600082601f83011261370e5761370d613322565b5b813561371e848260208601613690565b91505092915050565b600067ffffffffffffffff8211156137425761374161333d565b5b61374b8261332c565b9050602081019050919050565b600061376b61376684613727565b61339d565b90508281526020810184848401111561378757613786613327565b5b6137928482856133e9565b509392505050565b600082601f8301126137af576137ae613322565b5b81356137bf848260208601613758565b91505092915050565b600080600080600060a086880312156137e4576137e361315f565b5b60006137f2888289016131b2565b9550506020613803888289016131b2565b945050604086013567ffffffffffffffff81111561382457613823613164565b5b613830888289016136f9565b935050606086013567ffffffffffffffff81111561385157613850613164565b5b61385d888289016136f9565b925050608086013567ffffffffffffffff81111561387e5761387d613164565b5b61388a8882890161379a565b9150509295509295909350565b600080604083850312156138ae576138ad61315f565b5b60006138bc858286016135f3565b92505060206138cd858286016131b2565b9150509250929050565b6138e081613189565b82525050565b60006020820190506138fb60008301846138d7565b92915050565b600067ffffffffffffffff82111561391c5761391b61333d565b5b602082029050602081019050919050565b600061394061393b84613901565b61339d565b905080838252602082019050602084028301858111156139635761396261368b565b5b835b8181101561398c578061397888826131b2565b845260208401935050602081019050613965565b5050509392505050565b600082601f8301126139ab576139aa613322565b5b81356139bb84826020860161392d565b91505092915050565b600080604083850312156139db576139da61315f565b5b600083013567ffffffffffffffff8111156139f9576139f8613164565b5b613a0585828601613996565b925050602083013567ffffffffffffffff811115613a2657613a25613164565b5b613a32858286016136f9565b9150509250929050565b600081519050919050565b600082825260208201905092915050565b6000819050602082019050919050565b613a71816131c7565b82525050565b6000613a838383613a68565b60208301905092915050565b6000602082019050919050565b6000613aa782613a3c565b613ab18185613a47565b9350613abc83613a58565b8060005b83811015613aed578151613ad48882613a77565b9750613adf83613a8f565b925050600181019050613ac0565b5085935050505092915050565b60006020820190508181036000830152613b148184613a9c565b905092915050565b60008060408385031215613b3357613b3261315f565b5b6000613b41858286016131e8565b925050602083013567ffffffffffffffff811115613b6257613b61613164565b5b613b6e8582860161343a565b9150509250929050565b600081519050919050565b600082825260208201905092915050565b6000613b9f82613b78565b613ba98185613b83565b9350613bb98185602086016134cd565b613bc28161332c565b840191505092915050565b60006020820190508181036000830152613be78184613b94565b905092915050565b60008060408385031215613c0657613c0561315f565b5b6000613c14858286016131e8565b9250506020613c25858286016131e8565b9150509250929050565b60008060008060808587031215613c4957613c4861315f565b5b6000613c57878288016131b2565b9450506020613c68878288016131b2565b9350506040613c79878288016131e8565b925050606085013567ffffffffffffffff811115613c9a57613c99613164565b5b613ca68782880161379a565b91505092959194509250565b613cbb81613267565b82525050565b6000602082019050613cd66000830184613cb2565b92915050565b600060208284031215613cf257613cf161315f565b5b6000613d00848285016131b2565b91505092915050565b613d12816132ec565b8114613d1d57600080fd5b50565b600081359050613d2f81613d09565b92915050565b60008060408385031215613d4c57613d4b61315f565b5b6000613d5a858286016131b2565b9250506020613d6b85828601613d20565b9150509250929050565b60008060408385031215613d8c57613d8b61315f565b5b6000613d9a858286016131b2565b9250506020613dab858286016131b2565b9150509250929050565b600080600080600060a08688031215613dd157613dd061315f565b5b6000613ddf888289016131b2565b9550506020613df0888289016131b2565b9450506040613e01888289016131e8565b9350506060613e12888289016131e8565b925050608086013567ffffffffffffffff811115613e3357613e32613164565b5b613e3f8882890161379a565b9150509295509295909350565b6000819050919050565b6000613e71613e6c613e6784613169565b613e4c565b613169565b9050919050565b6000613e8382613e56565b9050919050565b6000613e9582613e78565b9050919050565b613ea581613e8a565b82525050565b6000602082019050613ec06000830184613e9c565b92915050565b7f455243313135353a2061646472657373207a65726f206973206e6f742061207660008201527f616c6964206f776e657200000000000000000000000000000000000000000000602082015250565b6000613f22602a836134bc565b9150613f2d82613ec6565b604082019050919050565b60006020820190508181036000830152613f5181613f15565b9050919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052602260045260246000fd5b60006002820490506001821680613f9f57607f821691505b602082108103613fb257613fb1613f58565b5b50919050565b600081905092915050565b6000613fce826134b1565b613fd88185613fb8565b9350613fe88185602086016134cd565b80840191505092915050565b60008190508160005260206000209050919050565b6000815461401681613f87565b6140208186613fb8565b9450600182166000811461403b576001811461405057614083565b60ff1983168652811515820286019350614083565b61405985613ff4565b60005b8381101561407b5781548189015260018201915060208101905061405c565b838801955050505b50505092915050565b60006140988285613fc3565b91506140a48284614009565b91508190509392505050565b60006140bc8285613fc3565b91506140c88284613fc3565b91508190509392505050565b60006140e08285614009565b91506140ec8284613fc3565b91508190509392505050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b6000614132826131c7565b915061413d836131c7565b9250828201905080821115614155576141546140f8565b5b92915050565b7f455243313135353a2063616c6c6572206973206e6f7420746f6b656e206f776e60008201527f6572206f7220617070726f766564000000000000000000000000000000000000602082015250565b60006141b7602e836134bc565b91506141c28261415b565b604082019050919050565b600060208201905081810360008301526141e6816141aa565b9050919050565b7f416363657373436f6e74726f6c3a2063616e206f6e6c792072656e6f756e636560008201527f20726f6c657320666f722073656c660000000000000000000000000000000000602082015250565b6000614249602f836134bc565b9150614254826141ed565b604082019050919050565b600060208201905081810360008301526142788161423c565b9050919050565b7f455243313135353a206163636f756e747320616e6420696473206c656e67746860008201527f206d69736d617463680000000000000000000000000000000000000000000000602082015250565b60006142db6029836134bc565b91506142e68261427f565b604082019050919050565b6000602082019050818103600083015261430a816142ce565b9050919050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052603260045260246000fd5b600061434b826131c7565b91507fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff820361437d5761437c6140f8565b5b600182019050919050565b60006020601f8301049050919050565b600082821b905092915050565b6000600883026143d57fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff82614398565b6143df8683614398565b95508019841693508086168417925050509392505050565b600061441261440d614408846131c7565b613e4c565b6131c7565b9050919050565b6000819050919050565b61442c836143f7565b61444061443882614419565b8484546143a5565b825550505050565b600090565b614455614448565b614460818484614423565b505050565b5b818110156144845761447960008261444d565b600181019050614466565b5050565b601f8211156144c95761449a81613ff4565b6144a384614388565b810160208510156144b2578190505b6144c66144be85614388565b830182614465565b50505b505050565b600082821c905092915050565b60006144ec600019846008026144ce565b1980831691505092915050565b600061450583836144db565b9150826002028217905092915050565b61451e826134b1565b67ffffffffffffffff8111156145375761453661333d565b5b6145418254613f87565b61454c828285614488565b600060209050601f83116001811461457f576000841561456d578287015190505b61457785826144f9565b8655506145df565b601f19841661458d86613ff4565b60005b828110156145b557848901518255600182019150602085019450602081019050614590565b868310156145d257848901516145ce601f8916826144db565b8355505b6001600288020188555050505b505050505050565b7f4e6f74206d6c2061646d696e0000000000000000000000000000000000000000600082015250565b600061461d600c836134bc565b9150614628826145e7565b602082019050919050565b6000602082019050818103600083015261464c81614610565b9050919050565b600081519050614662816131d1565b92915050565b60006020828403121561467e5761467d61315f565b5b600061468c84828501614653565b91505092915050565b7f4974656d207072696365206e6f74207365740000000000000000000000000000600082015250565b60006146cb6012836134bc565b91506146d682614695565b602082019050919050565b600060208201905081810360008301526146fa816146be565b9050919050565b7f696e76616c6964207061796d656e742076616c75650000000000000000000000600082015250565b60006147376015836134bc565b915061474282614701565b602082019050919050565b600060208201905081810360008301526147668161472a565b9050919050565b7f4e6f6e65206c65667420746f206d696e74000000000000000000000000000000600082015250565b60006147a36011836134bc565b91506147ae8261476d565b602082019050919050565b600060208201905081810360008301526147d281614796565b9050919050565b7f416c7265616479206d696e746564206c696d6974000000000000000000000000600082015250565b600061480f6014836134bc565b915061481a826147d9565b602082019050919050565b6000602082019050818103600083015261483e81614802565b9050919050565b6000614850826131c7565b915061485b836131c7565b9250828202614869816131c7565b915082820484148315176148805761487f6140f8565b5b5092915050565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601260045260246000fd5b60006148c1826131c7565b91506148cc836131c7565b9250826148dc576148db614887565b5b828204905092915050565b60006040820190506148fc60008301856138d7565b614909602083018461323d565b9392505050565b60008151905061491f81613d09565b92915050565b60006020828403121561493b5761493a61315f565b5b600061494984828501614910565b91505092915050565b600061495d826131c7565b9150614968836131c7565b92508282039050818111156149805761497f6140f8565b5b92915050565b6000614991826131c7565b9150600082036149a4576149a36140f8565b5b600182039050919050565b7f537472696e67733a20686578206c656e67746820696e73756666696369656e74600082015250565b60006149e56020836134bc565b91506149f0826149af565b602082019050919050565b60006020820190508181036000830152614a14816149d8565b9050919050565b7f455243313135353a206d696e7420746f20746865207a65726f2061646472657360008201527f7300000000000000000000000000000000000000000000000000000000000000602082015250565b6000614a776021836134bc565b9150614a8282614a1b565b604082019050919050565b60006020820190508181036000830152614aa681614a6a565b9050919050565b6000604082019050614ac2600083018561323d565b614acf602083018461323d565b9392505050565b7f455243313135353a2069647320616e6420616d6f756e7473206c656e6774682060008201527f6d69736d61746368000000000000000000000000000000000000000000000000602082015250565b6000614b326028836134bc565b9150614b3d82614ad6565b604082019050919050565b60006020820190508181036000830152614b6181614b25565b9050919050565b7f455243313135353a207472616e7366657220746f20746865207a65726f20616460008201527f6472657373000000000000000000000000000000000000000000000000000000602082015250565b6000614bc46025836134bc565b9150614bcf82614b68565b604082019050919050565b60006020820190508181036000830152614bf381614bb7565b9050919050565b7f455243313135353a20696e73756666696369656e742062616c616e636520666f60008201527f72207472616e7366657200000000000000000000000000000000000000000000602082015250565b6000614c56602a836134bc565b9150614c6182614bfa565b604082019050919050565b60006020820190508181036000830152614c8581614c49565b9050919050565b60006040820190508181036000830152614ca68185613a9c565b90508181036020830152614cba8184613a9c565b90509392505050565b7f455243313135353a2073657474696e6720617070726f76616c2073746174757360008201527f20666f722073656c660000000000000000000000000000000000000000000000602082015250565b6000614d1f6029836134bc565b9150614d2a82614cc3565b604082019050919050565b60006020820190508181036000830152614d4e81614d12565b9050919050565b7f416363657373436f6e74726f6c3a206163636f756e7420000000000000000000600082015250565b6000614d8b601783613fb8565b9150614d9682614d55565b601782019050919050565b7f206973206d697373696e6720726f6c6520000000000000000000000000000000600082015250565b6000614dd7601183613fb8565b9150614de282614da1565b601182019050919050565b6000614df882614d7e565b9150614e048285613fc3565b9150614e0f82614dca565b9150614e1b8284613fc3565b91508190509392505050565b600060a082019050614e3c60008301886138d7565b614e4960208301876138d7565b614e56604083018661323d565b614e63606083018561323d565b8181036080830152614e758184613b94565b90509695505050505050565b600081519050614e9081613293565b92915050565b600060208284031215614eac57614eab61315f565b5b6000614eba84828501614e81565b91505092915050565b60008160e01c9050919050565b600060033d1115614eef5760046000803e614eec600051614ec3565b90505b90565b600060443d10614f7f57614f04613155565b60043d036004823e80513d602482011167ffffffffffffffff82111715614f2c575050614f7f565b808201805167ffffffffffffffff811115614f4a5750505050614f7f565b80602083010160043d038501811115614f67575050505050614f7f565b614f768260200185018661336c565b82955050505050505b90565b7f455243313135353a207472616e7366657220746f206e6f6e2d4552433131353560008201527f526563656976657220696d706c656d656e746572000000000000000000000000602082015250565b6000614fde6034836134bc565b9150614fe982614f82565b604082019050919050565b6000602082019050818103600083015261500d81614fd1565b9050919050565b7f455243313135353a204552433131353552656365697665722072656a6563746560008201527f6420746f6b656e73000000000000000000000000000000000000000000000000602082015250565b60006150706028836134bc565b915061507b82615014565b604082019050919050565b6000602082019050818103600083015261509f81615063565b9050919050565b600060a0820190506150bb60008301886138d7565b6150c860208301876138d7565b81810360408301526150da8186613a9c565b905081810360608301526150ee8185613a9c565b905081810360808301526151028184613b94565b90509695505050505050565b7f455243313135353a206275726e20616d6f756e74206578636565647320746f7460008201527f616c537570706c79000000000000000000000000000000000000000000000000602082015250565b600061516a6028836134bc565b91506151758261510e565b604082019050919050565b600060208201905081810360008301526151998161515d565b905091905056fea26469706673582212203e081b43f22c5f665a5ee637ebcb8e7641c7d9cbe16d51b81715804ba2d16a3564736f6c63430008110033
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.