Feature Tip: Add private address tag to any address under My Name Tag !
Overview
ETH Balance
6.569219581705976254 ETH
Eth Value
$20,385.05 (@ $3,103.12/ETH)Token Holdings
More Info
Private Name Tags
ContractCreator
Latest 25 from a total of 919 transactions
Transaction Hash |
Method
|
Block
|
From
|
To
|
Value | ||||
---|---|---|---|---|---|---|---|---|---|
Withdraw My All ... | 19852552 | 7 days ago | IN | 0 ETH | 0.00039778 | ||||
Withdraw My All ... | 18655979 | 174 days ago | IN | 0 ETH | 0.00470396 | ||||
Withdraw My All ... | 18464563 | 201 days ago | IN | 0 ETH | 0.00401236 | ||||
Withdraw My All ... | 18455203 | 202 days ago | IN | 0 ETH | 0.00124557 | ||||
Withdraw My All ... | 18166896 | 243 days ago | IN | 0 ETH | 0.00172163 | ||||
Withdraw My Rewa... | 18166711 | 243 days ago | IN | 0 ETH | 0.00055553 | ||||
Withdraw My All ... | 17567874 | 327 days ago | IN | 0 ETH | 0.00190939 | ||||
Withdraw My All ... | 17566261 | 327 days ago | IN | 0 ETH | 0.00258963 | ||||
Withdraw My All ... | 16919448 | 418 days ago | IN | 0 ETH | 0.00236913 | ||||
Withdraw My All ... | 16881852 | 424 days ago | IN | 0 ETH | 0.00040461 | ||||
Withdraw My All ... | 16877030 | 424 days ago | IN | 0 ETH | 0.00245078 | ||||
Withdraw My All ... | 16866537 | 426 days ago | IN | 0 ETH | 0.00217206 | ||||
Withdraw My All ... | 16616943 | 461 days ago | IN | 0 ETH | 0.00461529 | ||||
Withdraw My All ... | 16563879 | 468 days ago | IN | 0 ETH | 0.00187392 | ||||
Withdraw My Rewa... | 16550534 | 470 days ago | IN | 0 ETH | 0.00256628 | ||||
Withdraw My Rewa... | 16473934 | 481 days ago | IN | 0 ETH | 0.0009471 | ||||
Withdraw My All ... | 16417646 | 489 days ago | IN | 0 ETH | 0.00345509 | ||||
Withdraw My All ... | 16405135 | 490 days ago | IN | 0 ETH | 0.00599566 | ||||
Withdraw My All ... | 16391704 | 492 days ago | IN | 0 ETH | 0.00223458 | ||||
Withdraw My All ... | 15975913 | 550 days ago | IN | 0 ETH | 0.00283622 | ||||
Withdraw My All ... | 15903351 | 560 days ago | IN | 0 ETH | 0.00398977 | ||||
Withdraw My All ... | 15856076 | 567 days ago | IN | 0 ETH | 0.00354331 | ||||
Withdraw My All ... | 15787187 | 577 days ago | IN | 0 ETH | 0.00913726 | ||||
Withdraw My Rewa... | 15760426 | 580 days ago | IN | 0 ETH | 0.00072552 | ||||
Withdraw My Rewa... | 15760285 | 580 days ago | IN | 0 ETH | 0.00077686 |
Latest 25 internal transactions (View All)
Advanced mode:
Parent Transaction Hash | Block | From | To | Value | ||
---|---|---|---|---|---|---|
19852552 | 7 days ago | 0.0670673 ETH | ||||
18655979 | 174 days ago | 0.08528857 ETH | ||||
18455203 | 202 days ago | 0.02147717 ETH | ||||
18166896 | 243 days ago | 0.02756246 ETH | ||||
18166711 | 243 days ago | 0.00523351 ETH | ||||
17567874 | 327 days ago | 0.18091394 ETH | ||||
17566261 | 327 days ago | 0.04991478 ETH | ||||
16877030 | 424 days ago | 0.00321695 ETH | ||||
16866537 | 426 days ago | 0.61617444 ETH | ||||
16616943 | 461 days ago | 0.02650327 ETH | ||||
16563879 | 468 days ago | 0.00138739 ETH | ||||
16550534 | 470 days ago | 0.00440934 ETH | ||||
16473934 | 481 days ago | 0.00532841 ETH | ||||
16417646 | 489 days ago | 0.30951031 ETH | ||||
16405135 | 490 days ago | 0.00829003 ETH | ||||
16391704 | 492 days ago | 0.06535714 ETH | ||||
15975913 | 550 days ago | 0.03457423 ETH | ||||
15903351 | 560 days ago | 0.09769711 ETH | ||||
15856076 | 567 days ago | 0.21863095 ETH | ||||
15787187 | 577 days ago | 0.04592653 ETH | ||||
15760426 | 580 days ago | 0.02104114 ETH | ||||
15760285 | 580 days ago | 0.05046916 ETH | ||||
15754251 | 581 days ago | 0.06312344 ETH | ||||
15754223 | 581 days ago | 0.10520573 ETH | ||||
15754189 | 581 days ago | 0.18088104 ETH |
Loading...
Loading
Contract Name:
CSPLGuildPool
Compiler Version
v0.5.5+commit.47a71e8f
Contract Source Code (Solidity)
/** *Submitted for verification at Etherscan.io on 2020-02-02 */ // File: openzeppelin-solidity/contracts/GSN/Context.sol pragma solidity ^0.5.0; /* * @dev Provides information about the current execution context, including the * sender of the transaction and its data. While these are generally available * via msg.sender and msg.data, they should not be accessed in such a direct * manner, since when dealing with GSN meta-transactions the account sending and * paying for execution may not be the actual sender (as far as an application * is concerned). * * This contract is only required for intermediate, library-like contracts. */ contract Context { // Empty internal constructor, to prevent people from mistakenly deploying // an instance of this contract, which should be used via inheritance. constructor () internal { } // solhint-disable-previous-line no-empty-blocks function _msgSender() internal view returns (address payable) { return msg.sender; } function _msgData() internal view returns (bytes memory) { this; // silence state mutability warning without generating bytecode - see https://github.com/ethereum/solidity/issues/2691 return msg.data; } } // File: openzeppelin-solidity/contracts/access/Roles.sol pragma solidity ^0.5.0; /** * @title Roles * @dev Library for managing addresses assigned to a Role. */ library Roles { struct Role { mapping (address => bool) bearer; } /** * @dev Give an account access to this role. */ function add(Role storage role, address account) internal { require(!has(role, account), "Roles: account already has role"); role.bearer[account] = true; } /** * @dev Remove an account's access to this role. */ function remove(Role storage role, address account) internal { require(has(role, account), "Roles: account does not have role"); role.bearer[account] = false; } /** * @dev Check if an account has this role. * @return bool */ function has(Role storage role, address account) internal view returns (bool) { require(account != address(0), "Roles: account is the zero address"); return role.bearer[account]; } } // File: openzeppelin-solidity/contracts/access/roles/PauserRole.sol pragma solidity ^0.5.0; contract PauserRole is Context { using Roles for Roles.Role; event PauserAdded(address indexed account); event PauserRemoved(address indexed account); Roles.Role private _pausers; constructor () internal { _addPauser(_msgSender()); } modifier onlyPauser() { require(isPauser(_msgSender()), "PauserRole: caller does not have the Pauser role"); _; } function isPauser(address account) public view returns (bool) { return _pausers.has(account); } function addPauser(address account) public onlyPauser { _addPauser(account); } function renouncePauser() public { _removePauser(_msgSender()); } function _addPauser(address account) internal { _pausers.add(account); emit PauserAdded(account); } function _removePauser(address account) internal { _pausers.remove(account); emit PauserRemoved(account); } } // File: openzeppelin-solidity/contracts/lifecycle/Pausable.sol pragma solidity ^0.5.0; /** * @dev Contract module which allows children to implement an emergency stop * mechanism that can be triggered by an authorized account. * * This module is used through inheritance. It will make available the * modifiers `whenNotPaused` and `whenPaused`, which can be applied to * the functions of your contract. Note that they will not be pausable by * simply including this module, only once the modifiers are put in place. */ contract Pausable is Context, PauserRole { /** * @dev Emitted when the pause is triggered by a pauser (`account`). */ event Paused(address account); /** * @dev Emitted when the pause is lifted by a pauser (`account`). */ event Unpaused(address account); bool private _paused; /** * @dev Initializes the contract in unpaused state. Assigns the Pauser role * to the deployer. */ constructor () internal { _paused = false; } /** * @dev Returns true if the contract is paused, and false otherwise. */ function paused() public view returns (bool) { return _paused; } /** * @dev Modifier to make a function callable only when the contract is not paused. */ modifier whenNotPaused() { require(!_paused, "Pausable: paused"); _; } /** * @dev Modifier to make a function callable only when the contract is paused. */ modifier whenPaused() { require(_paused, "Pausable: not paused"); _; } /** * @dev Called by a pauser to pause, triggers stopped state. */ function pause() public onlyPauser whenNotPaused { _paused = true; emit Paused(_msgSender()); } /** * @dev Called by a pauser to unpause, returns to normal state. */ function unpause() public onlyPauser whenPaused { _paused = false; emit Unpaused(_msgSender()); } } // File: openzeppelin-solidity/contracts/ownership/Ownable.sol pragma solidity ^0.5.0; /** * @dev Contract module which provides a basic access control mechanism, where * there is an account (an owner) that can be granted exclusive access to * specific functions. * * This module is used through inheritance. It will make available the modifier * `onlyOwner`, which can be applied to your functions to restrict their use to * the owner. */ contract Ownable is Context { address private _owner; event OwnershipTransferred(address indexed previousOwner, address indexed newOwner); /** * @dev Initializes the contract setting the deployer as the initial owner. */ constructor () internal { _owner = _msgSender(); emit OwnershipTransferred(address(0), _owner); } /** * @dev Returns the address of the current owner. */ function owner() public view returns (address) { return _owner; } /** * @dev Throws if called by any account other than the owner. */ modifier onlyOwner() { require(isOwner(), "Ownable: caller is not the owner"); _; } /** * @dev Returns true if the caller is the current owner. */ function isOwner() public view returns (bool) { return _msgSender() == _owner; } /** * @dev Leaves the contract without owner. It will not be possible to call * `onlyOwner` functions anymore. Can only be called by the current owner. * * NOTE: Renouncing ownership will leave the contract without an owner, * thereby removing any functionality that is only available to the owner. */ function renounceOwnership() public onlyOwner { emit OwnershipTransferred(_owner, address(0)); _owner = address(0); } /** * @dev Transfers ownership of the contract to a new account (`newOwner`). * Can only be called by the current owner. */ function transferOwnership(address newOwner) public onlyOwner { _transferOwnership(newOwner); } /** * @dev Transfers ownership of the contract to a new account (`newOwner`). */ function _transferOwnership(address newOwner) internal { require(newOwner != address(0), "Ownable: new owner is the zero address"); emit OwnershipTransferred(_owner, newOwner); _owner = newOwner; } } // File: openzeppelin-solidity/contracts/introspection/IERC165.sol pragma solidity ^0.5.0; /** * @dev Interface of the ERC165 standard, as defined in the * https://eips.ethereum.org/EIPS/eip-165[EIP]. * * Implementers can declare support of contract interfaces, which can then be * queried by others ({ERC165Checker}). * * For an implementation, see {ERC165}. */ interface IERC165 { /** * @dev Returns true if this contract implements the interface defined by * `interfaceId`. See the corresponding * https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section] * to learn more about how these ids are created. * * This function call must use less than 30 000 gas. */ function supportsInterface(bytes4 interfaceId) external view returns (bool); } // File: openzeppelin-solidity/contracts/token/ERC721/IERC721.sol pragma solidity ^0.5.0; /** * @dev Required interface of an ERC721 compliant contract. */ contract IERC721 is IERC165 { event Transfer(address indexed from, address indexed to, uint256 indexed tokenId); event Approval(address indexed owner, address indexed approved, uint256 indexed tokenId); event ApprovalForAll(address indexed owner, address indexed operator, bool approved); /** * @dev Returns the number of NFTs in `owner`'s account. */ function balanceOf(address owner) public view returns (uint256 balance); /** * @dev Returns the owner of the NFT specified by `tokenId`. */ function ownerOf(uint256 tokenId) public view returns (address owner); /** * @dev Transfers a specific NFT (`tokenId`) from one account (`from`) to * another (`to`). * * * * Requirements: * - `from`, `to` cannot be zero. * - `tokenId` must be owned by `from`. * - If the caller is not `from`, it must be have been allowed to move this * NFT by either {approve} or {setApprovalForAll}. */ function safeTransferFrom(address from, address to, uint256 tokenId) public; /** * @dev Transfers a specific NFT (`tokenId`) from one account (`from`) to * another (`to`). * * Requirements: * - If the caller is not `from`, it must be approved to move this NFT by * either {approve} or {setApprovalForAll}. */ function transferFrom(address from, address to, uint256 tokenId) public; function approve(address to, uint256 tokenId) public; function getApproved(uint256 tokenId) public view returns (address operator); function setApprovalForAll(address operator, bool _approved) public; function isApprovedForAll(address owner, address operator) public view returns (bool); function safeTransferFrom(address from, address to, uint256 tokenId, bytes memory data) public; } // File: openzeppelin-solidity/contracts/token/ERC721/IERC721Receiver.sol pragma solidity ^0.5.0; /** * @title ERC721 token receiver interface * @dev Interface for any contract that wants to support safeTransfers * from ERC721 asset contracts. */ contract IERC721Receiver { /** * @notice Handle the receipt of an NFT * @dev The ERC721 smart contract calls this function on the recipient * after a {IERC721-safeTransferFrom}. This function MUST return the function selector, * otherwise the caller will revert the transaction. The selector to be * returned can be obtained as `this.onERC721Received.selector`. This * function MAY throw to revert and reject the transfer. * Note: the ERC721 contract address is always the message sender. * @param operator The address which called `safeTransferFrom` function * @param from The address which previously owned the token * @param tokenId The NFT identifier which is being transferred * @param data Additional data with no specified format * @return bytes4 `bytes4(keccak256("onERC721Received(address,address,uint256,bytes)"))` */ function onERC721Received(address operator, address from, uint256 tokenId, bytes memory data) public returns (bytes4); } // File: openzeppelin-solidity/contracts/math/SafeMath.sol pragma solidity ^0.5.0; /** * @dev Wrappers over Solidity's arithmetic operations with added overflow * checks. * * Arithmetic operations in Solidity wrap on overflow. This can easily result * in bugs, because programmers usually assume that an overflow raises an * error, which is the standard behavior in high level programming languages. * `SafeMath` restores this intuition by reverting the transaction when an * operation overflows. * * Using this library instead of the unchecked operations eliminates an entire * class of bugs, so it's recommended to use it always. */ library SafeMath { /** * @dev Returns the addition of two unsigned integers, reverting on * overflow. * * Counterpart to Solidity's `+` operator. * * Requirements: * - Addition cannot overflow. */ function add(uint256 a, uint256 b) internal pure returns (uint256) { uint256 c = a + b; require(c >= a, "SafeMath: addition overflow"); return c; } /** * @dev Returns the subtraction of two unsigned integers, reverting on * overflow (when the result is negative). * * Counterpart to Solidity's `-` operator. * * Requirements: * - Subtraction cannot overflow. */ function sub(uint256 a, uint256 b) internal pure returns (uint256) { return sub(a, b, "SafeMath: subtraction overflow"); } /** * @dev Returns the subtraction of two unsigned integers, reverting with custom message on * overflow (when the result is negative). * * Counterpart to Solidity's `-` operator. * * Requirements: * - Subtraction cannot overflow. * * _Available since v2.4.0._ */ function sub(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) { require(b <= a, errorMessage); uint256 c = a - b; return c; } /** * @dev Returns the multiplication of two unsigned integers, reverting on * overflow. * * Counterpart to Solidity's `*` operator. * * Requirements: * - Multiplication cannot overflow. */ function mul(uint256 a, uint256 b) internal pure returns (uint256) { // Gas optimization: this is cheaper than requiring 'a' not being zero, but the // benefit is lost if 'b' is also tested. // See: https://github.com/OpenZeppelin/openzeppelin-contracts/pull/522 if (a == 0) { return 0; } uint256 c = a * b; require(c / a == b, "SafeMath: multiplication overflow"); return c; } /** * @dev Returns the integer division of two unsigned integers. Reverts on * division by zero. The result is rounded towards zero. * * Counterpart to Solidity's `/` operator. Note: this function uses a * `revert` opcode (which leaves remaining gas untouched) while Solidity * uses an invalid opcode to revert (consuming all remaining gas). * * Requirements: * - The divisor cannot be zero. */ function div(uint256 a, uint256 b) internal pure returns (uint256) { return div(a, b, "SafeMath: division by zero"); } /** * @dev Returns the integer division of two unsigned integers. Reverts with custom message on * division by zero. The result is rounded towards zero. * * Counterpart to Solidity's `/` operator. Note: this function uses a * `revert` opcode (which leaves remaining gas untouched) while Solidity * uses an invalid opcode to revert (consuming all remaining gas). * * Requirements: * - The divisor cannot be zero. * * _Available since v2.4.0._ */ function div(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) { // Solidity only automatically asserts when dividing by 0 require(b > 0, errorMessage); uint256 c = a / b; // assert(a == b * c + a % b); // There is no case in which this doesn't hold return c; } /** * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo), * Reverts when dividing by zero. * * Counterpart to Solidity's `%` operator. This function uses a `revert` * opcode (which leaves remaining gas untouched) while Solidity uses an * invalid opcode to revert (consuming all remaining gas). * * Requirements: * - The divisor cannot be zero. */ function mod(uint256 a, uint256 b) internal pure returns (uint256) { return mod(a, b, "SafeMath: modulo by zero"); } /** * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo), * Reverts with custom message when dividing by zero. * * Counterpart to Solidity's `%` operator. This function uses a `revert` * opcode (which leaves remaining gas untouched) while Solidity uses an * invalid opcode to revert (consuming all remaining gas). * * Requirements: * - The divisor cannot be zero. * * _Available since v2.4.0._ */ function mod(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) { require(b != 0, errorMessage); return a % b; } } // File: openzeppelin-solidity/contracts/utils/Address.sol pragma solidity ^0.5.5; /** * @dev Collection of functions related to the address type */ library Address { /** * @dev Returns true if `account` is a contract. * * This test is non-exhaustive, and there may be false-negatives: during the * execution of a contract's constructor, its address will be reported as * not containing 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. */ function isContract(address account) internal view returns (bool) { // This method relies in extcodesize, which returns 0 for contracts in // construction, since the code is only stored at the end of the // constructor execution. // According to EIP-1052, 0x0 is the value returned for not-yet created accounts // and 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470 is returned // for accounts without code, i.e. `keccak256('')` bytes32 codehash; bytes32 accountHash = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470; // solhint-disable-next-line no-inline-assembly assembly { codehash := extcodehash(account) } return (codehash != 0x0 && codehash != accountHash); } /** * @dev Converts an `address` into `address payable`. Note that this is * simply a type cast: the actual underlying value is not changed. * * _Available since v2.4.0._ */ function toPayable(address account) internal pure returns (address payable) { return address(uint160(account)); } /** * @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]. * * _Available since v2.4.0._ */ function sendValue(address payable recipient, uint256 amount) internal { require(address(this).balance >= amount, "Address: insufficient balance"); // solhint-disable-next-line avoid-call-value (bool success, ) = recipient.call.value(amount)(""); require(success, "Address: unable to send value, recipient may have reverted"); } } // File: openzeppelin-solidity/contracts/drafts/Counters.sol pragma solidity ^0.5.0; /** * @title Counters * @author Matt Condon (@shrugs) * @dev Provides counters that can only be incremented or decremented by one. This can be used e.g. to track the number * of elements in a mapping, issuing ERC721 ids, or counting request ids. * * Include with `using Counters for Counters.Counter;` * Since it is not possible to overflow a 256 bit integer with increments of one, `increment` can skip the {SafeMath} * overflow check, thereby saving gas. This does assume however correct usage, in that the underlying `_value` is never * directly accessed. */ library Counters { using SafeMath for uint256; struct Counter { // This variable should never be directly accessed by users of the library: interactions must be restricted to // the library's function. As of Solidity v0.5.2, this cannot be enforced, though there is a proposal to add // this feature: see https://github.com/ethereum/solidity/issues/4637 uint256 _value; // default: 0 } function current(Counter storage counter) internal view returns (uint256) { return counter._value; } function increment(Counter storage counter) internal { counter._value += 1; } function decrement(Counter storage counter) internal { counter._value = counter._value.sub(1); } } // File: openzeppelin-solidity/contracts/introspection/ERC165.sol pragma solidity ^0.5.0; /** * @dev Implementation of the {IERC165} interface. * * Contracts may inherit from this and call {_registerInterface} to declare * their support of an interface. */ contract ERC165 is IERC165 { /* * bytes4(keccak256('supportsInterface(bytes4)')) == 0x01ffc9a7 */ bytes4 private constant _INTERFACE_ID_ERC165 = 0x01ffc9a7; /** * @dev Mapping of interface ids to whether or not it's supported. */ mapping(bytes4 => bool) private _supportedInterfaces; constructor () internal { // Derived contracts need only register support for their own interfaces, // we register support for ERC165 itself here _registerInterface(_INTERFACE_ID_ERC165); } /** * @dev See {IERC165-supportsInterface}. * * Time complexity O(1), guaranteed to always use less than 30 000 gas. */ function supportsInterface(bytes4 interfaceId) external view returns (bool) { return _supportedInterfaces[interfaceId]; } /** * @dev Registers the contract as an implementer of the interface defined by * `interfaceId`. Support of the actual ERC165 interface is automatic and * registering its interface id is not required. * * See {IERC165-supportsInterface}. * * Requirements: * * - `interfaceId` cannot be the ERC165 invalid interface (`0xffffffff`). */ function _registerInterface(bytes4 interfaceId) internal { require(interfaceId != 0xffffffff, "ERC165: invalid interface id"); _supportedInterfaces[interfaceId] = true; } } // File: openzeppelin-solidity/contracts/token/ERC721/ERC721.sol pragma solidity ^0.5.0; /** * @title ERC721 Non-Fungible Token Standard basic implementation * @dev see https://eips.ethereum.org/EIPS/eip-721 */ contract ERC721 is Context, ERC165, IERC721 { using SafeMath for uint256; using Address for address; using Counters for Counters.Counter; // Equals to `bytes4(keccak256("onERC721Received(address,address,uint256,bytes)"))` // which can be also obtained as `IERC721Receiver(0).onERC721Received.selector` bytes4 private constant _ERC721_RECEIVED = 0x150b7a02; // Mapping from token ID to owner mapping (uint256 => address) private _tokenOwner; // Mapping from token ID to approved address mapping (uint256 => address) private _tokenApprovals; // Mapping from owner to number of owned token mapping (address => Counters.Counter) private _ownedTokensCount; // Mapping from owner to operator approvals mapping (address => mapping (address => bool)) private _operatorApprovals; /* * bytes4(keccak256('balanceOf(address)')) == 0x70a08231 * bytes4(keccak256('ownerOf(uint256)')) == 0x6352211e * bytes4(keccak256('approve(address,uint256)')) == 0x095ea7b3 * bytes4(keccak256('getApproved(uint256)')) == 0x081812fc * bytes4(keccak256('setApprovalForAll(address,bool)')) == 0xa22cb465 * bytes4(keccak256('isApprovedForAll(address,address)')) == 0xe985e9c5 * bytes4(keccak256('transferFrom(address,address,uint256)')) == 0x23b872dd * bytes4(keccak256('safeTransferFrom(address,address,uint256)')) == 0x42842e0e * bytes4(keccak256('safeTransferFrom(address,address,uint256,bytes)')) == 0xb88d4fde * * => 0x70a08231 ^ 0x6352211e ^ 0x095ea7b3 ^ 0x081812fc ^ * 0xa22cb465 ^ 0xe985e9c ^ 0x23b872dd ^ 0x42842e0e ^ 0xb88d4fde == 0x80ac58cd */ bytes4 private constant _INTERFACE_ID_ERC721 = 0x80ac58cd; constructor () public { // register the supported interfaces to conform to ERC721 via ERC165 _registerInterface(_INTERFACE_ID_ERC721); } /** * @dev Gets the balance of the specified address. * @param owner address to query the balance of * @return uint256 representing the amount owned by the passed address */ function balanceOf(address owner) public view returns (uint256) { require(owner != address(0), "ERC721: balance query for the zero address"); return _ownedTokensCount[owner].current(); } /** * @dev Gets the owner of the specified token ID. * @param tokenId uint256 ID of the token to query the owner of * @return address currently marked as the owner of the given token ID */ function ownerOf(uint256 tokenId) public view returns (address) { address owner = _tokenOwner[tokenId]; require(owner != address(0), "ERC721: owner query for nonexistent token"); return owner; } /** * @dev Approves another address to transfer the given token ID * The zero address indicates there is no approved address. * There can only be one approved address per token at a given time. * Can only be called by the token owner or an approved operator. * @param to address to be approved for the given token ID * @param tokenId uint256 ID of the token to be approved */ function approve(address to, uint256 tokenId) public { address owner = ownerOf(tokenId); require(to != owner, "ERC721: approval to current owner"); require(_msgSender() == owner || isApprovedForAll(owner, _msgSender()), "ERC721: approve caller is not owner nor approved for all" ); _tokenApprovals[tokenId] = to; emit Approval(owner, to, tokenId); } /** * @dev Gets the approved address for a token ID, or zero if no address set * Reverts if the token ID does not exist. * @param tokenId uint256 ID of the token to query the approval of * @return address currently approved for the given token ID */ function getApproved(uint256 tokenId) public view returns (address) { require(_exists(tokenId), "ERC721: approved query for nonexistent token"); return _tokenApprovals[tokenId]; } /** * @dev Sets or unsets the approval of a given operator * An operator is allowed to transfer all tokens of the sender on their behalf. * @param to operator address to set the approval * @param approved representing the status of the approval to be set */ function setApprovalForAll(address to, bool approved) public { require(to != _msgSender(), "ERC721: approve to caller"); _operatorApprovals[_msgSender()][to] = approved; emit ApprovalForAll(_msgSender(), to, approved); } /** * @dev Tells whether an operator is approved by a given owner. * @param owner owner address which you want to query the approval of * @param operator operator address which you want to query the approval of * @return bool whether the given operator is approved by the given owner */ function isApprovedForAll(address owner, address operator) public view returns (bool) { return _operatorApprovals[owner][operator]; } /** * @dev Transfers the ownership of a given token ID to another address. * Usage of this method is discouraged, use {safeTransferFrom} whenever possible. * Requires the msg.sender to be the owner, approved, or operator. * @param from current owner of the token * @param to address to receive the ownership of the given token ID * @param tokenId uint256 ID of the token to be transferred */ function transferFrom(address from, address to, uint256 tokenId) public { //solhint-disable-next-line max-line-length require(_isApprovedOrOwner(_msgSender(), tokenId), "ERC721: transfer caller is not owner nor approved"); _transferFrom(from, to, tokenId); } /** * @dev Safely transfers the ownership of a given token ID to another address * If the target address is a contract, it must implement {IERC721Receiver-onERC721Received}, * which is called upon a safe transfer, and return the magic value * `bytes4(keccak256("onERC721Received(address,address,uint256,bytes)"))`; otherwise, * the transfer is reverted. * Requires the msg.sender to be the owner, approved, or operator * @param from current owner of the token * @param to address to receive the ownership of the given token ID * @param tokenId uint256 ID of the token to be transferred */ function safeTransferFrom(address from, address to, uint256 tokenId) public { safeTransferFrom(from, to, tokenId, ""); } /** * @dev Safely transfers the ownership of a given token ID to another address * If the target address is a contract, it must implement {IERC721Receiver-onERC721Received}, * which is called upon a safe transfer, and return the magic value * `bytes4(keccak256("onERC721Received(address,address,uint256,bytes)"))`; otherwise, * the transfer is reverted. * Requires the _msgSender() to be the owner, approved, or operator * @param from current owner of the token * @param to address to receive the ownership of the given token ID * @param tokenId uint256 ID of the token to be transferred * @param _data bytes data to send along with a safe transfer check */ function safeTransferFrom(address from, address to, uint256 tokenId, bytes memory _data) public { require(_isApprovedOrOwner(_msgSender(), tokenId), "ERC721: transfer caller is not owner nor approved"); _safeTransferFrom(from, to, tokenId, _data); } /** * @dev Safely transfers the ownership of a given token ID to another address * If the target address is a contract, it must implement `onERC721Received`, * which is called upon a safe transfer, and return the magic value * `bytes4(keccak256("onERC721Received(address,address,uint256,bytes)"))`; otherwise, * the transfer is reverted. * Requires the msg.sender to be the owner, approved, or operator * @param from current owner of the token * @param to address to receive the ownership of the given token ID * @param tokenId uint256 ID of the token to be transferred * @param _data bytes data to send along with a safe transfer check */ function _safeTransferFrom(address from, address to, uint256 tokenId, bytes memory _data) internal { _transferFrom(from, to, tokenId); require(_checkOnERC721Received(from, to, tokenId, _data), "ERC721: transfer to non ERC721Receiver implementer"); } /** * @dev Returns whether the specified token exists. * @param tokenId uint256 ID of the token to query the existence of * @return bool whether the token exists */ function _exists(uint256 tokenId) internal view returns (bool) { address owner = _tokenOwner[tokenId]; return owner != address(0); } /** * @dev Returns whether the given spender can transfer a given token ID. * @param spender address of the spender to query * @param tokenId uint256 ID of the token to be transferred * @return bool whether the msg.sender is approved for the given token ID, * is an operator of the owner, or is the owner of the token */ function _isApprovedOrOwner(address spender, uint256 tokenId) internal view returns (bool) { require(_exists(tokenId), "ERC721: operator query for nonexistent token"); address owner = ownerOf(tokenId); return (spender == owner || getApproved(tokenId) == spender || isApprovedForAll(owner, spender)); } /** * @dev Internal function to safely mint a new token. * Reverts if the given token ID already exists. * If the target address is a contract, it must implement `onERC721Received`, * which is called upon a safe transfer, and return the magic value * `bytes4(keccak256("onERC721Received(address,address,uint256,bytes)"))`; otherwise, * the transfer is reverted. * @param to The address that will own the minted token * @param tokenId uint256 ID of the token to be minted */ function _safeMint(address to, uint256 tokenId) internal { _safeMint(to, tokenId, ""); } /** * @dev Internal function to safely mint a new token. * Reverts if the given token ID already exists. * If the target address is a contract, it must implement `onERC721Received`, * which is called upon a safe transfer, and return the magic value * `bytes4(keccak256("onERC721Received(address,address,uint256,bytes)"))`; otherwise, * the transfer is reverted. * @param to The address that will own the minted token * @param tokenId uint256 ID of the token to be minted * @param _data bytes data to send along with a safe transfer check */ function _safeMint(address to, uint256 tokenId, bytes memory _data) internal { _mint(to, tokenId); require(_checkOnERC721Received(address(0), to, tokenId, _data), "ERC721: transfer to non ERC721Receiver implementer"); } /** * @dev Internal function to mint a new token. * Reverts if the given token ID already exists. * @param to The address that will own the minted token * @param tokenId uint256 ID of the token to be minted */ function _mint(address to, uint256 tokenId) internal { require(to != address(0), "ERC721: mint to the zero address"); require(!_exists(tokenId), "ERC721: token already minted"); _tokenOwner[tokenId] = to; _ownedTokensCount[to].increment(); emit Transfer(address(0), to, tokenId); } /** * @dev Internal function to burn a specific token. * Reverts if the token does not exist. * Deprecated, use {_burn} instead. * @param owner owner of the token to burn * @param tokenId uint256 ID of the token being burned */ function _burn(address owner, uint256 tokenId) internal { require(ownerOf(tokenId) == owner, "ERC721: burn of token that is not own"); _clearApproval(tokenId); _ownedTokensCount[owner].decrement(); _tokenOwner[tokenId] = address(0); emit Transfer(owner, address(0), tokenId); } /** * @dev Internal function to burn a specific token. * Reverts if the token does not exist. * @param tokenId uint256 ID of the token being burned */ function _burn(uint256 tokenId) internal { _burn(ownerOf(tokenId), tokenId); } /** * @dev Internal function to transfer ownership of a given token ID to another address. * As opposed to {transferFrom}, this imposes no restrictions on msg.sender. * @param from current owner of the token * @param to address to receive the ownership of the given token ID * @param tokenId uint256 ID of the token to be transferred */ function _transferFrom(address from, address to, uint256 tokenId) internal { require(ownerOf(tokenId) == from, "ERC721: transfer of token that is not own"); require(to != address(0), "ERC721: transfer to the zero address"); _clearApproval(tokenId); _ownedTokensCount[from].decrement(); _ownedTokensCount[to].increment(); _tokenOwner[tokenId] = to; emit Transfer(from, to, tokenId); } /** * @dev Internal function to invoke {IERC721Receiver-onERC721Received} on a target address. * The call is not executed if the target address is not a contract. * * This function is deprecated. * @param from address representing the previous owner of the given token ID * @param to target address that will receive the tokens * @param tokenId uint256 ID of the token to be transferred * @param _data bytes optional data to send along with the call * @return bool whether the call correctly returned the expected magic value */ function _checkOnERC721Received(address from, address to, uint256 tokenId, bytes memory _data) internal returns (bool) { if (!to.isContract()) { return true; } bytes4 retval = IERC721Receiver(to).onERC721Received(_msgSender(), from, tokenId, _data); return (retval == _ERC721_RECEIVED); } /** * @dev Private function to clear current approval of a given token ID. * @param tokenId uint256 ID of the token to be transferred */ function _clearApproval(uint256 tokenId) private { if (_tokenApprovals[tokenId] != address(0)) { _tokenApprovals[tokenId] = address(0); } } } // File: openzeppelin-solidity/contracts/token/ERC721/IERC721Enumerable.sol pragma solidity ^0.5.0; /** * @title ERC-721 Non-Fungible Token Standard, optional enumeration extension * @dev See https://eips.ethereum.org/EIPS/eip-721 */ contract IERC721Enumerable is IERC721 { function totalSupply() public view returns (uint256); function tokenOfOwnerByIndex(address owner, uint256 index) public view returns (uint256 tokenId); function tokenByIndex(uint256 index) public view returns (uint256); } // File: openzeppelin-solidity/contracts/token/ERC721/ERC721Enumerable.sol pragma solidity ^0.5.0; /** * @title ERC-721 Non-Fungible Token with optional enumeration extension logic * @dev See https://eips.ethereum.org/EIPS/eip-721 */ contract ERC721Enumerable is Context, ERC165, ERC721, IERC721Enumerable { // Mapping from owner to list of owned token IDs mapping(address => uint256[]) private _ownedTokens; // Mapping from token ID to index of the owner tokens list mapping(uint256 => uint256) private _ownedTokensIndex; // Array with all token ids, used for enumeration uint256[] private _allTokens; // Mapping from token id to position in the allTokens array mapping(uint256 => uint256) private _allTokensIndex; /* * bytes4(keccak256('totalSupply()')) == 0x18160ddd * bytes4(keccak256('tokenOfOwnerByIndex(address,uint256)')) == 0x2f745c59 * bytes4(keccak256('tokenByIndex(uint256)')) == 0x4f6ccce7 * * => 0x18160ddd ^ 0x2f745c59 ^ 0x4f6ccce7 == 0x780e9d63 */ bytes4 private constant _INTERFACE_ID_ERC721_ENUMERABLE = 0x780e9d63; /** * @dev Constructor function. */ constructor () public { // register the supported interface to conform to ERC721Enumerable via ERC165 _registerInterface(_INTERFACE_ID_ERC721_ENUMERABLE); } /** * @dev Gets the token ID at a given index of the tokens list of the requested owner. * @param owner address owning the tokens list to be accessed * @param index uint256 representing the index to be accessed of the requested tokens list * @return uint256 token ID at the given index of the tokens list owned by the requested address */ function tokenOfOwnerByIndex(address owner, uint256 index) public view returns (uint256) { require(index < balanceOf(owner), "ERC721Enumerable: owner index out of bounds"); return _ownedTokens[owner][index]; } /** * @dev Gets the total amount of tokens stored by the contract. * @return uint256 representing the total amount of tokens */ function totalSupply() public view returns (uint256) { return _allTokens.length; } /** * @dev Gets the token ID at a given index of all the tokens in this contract * Reverts if the index is greater or equal to the total number of tokens. * @param index uint256 representing the index to be accessed of the tokens list * @return uint256 token ID at the given index of the tokens list */ function tokenByIndex(uint256 index) public view returns (uint256) { require(index < totalSupply(), "ERC721Enumerable: global index out of bounds"); return _allTokens[index]; } /** * @dev Internal function to transfer ownership of a given token ID to another address. * As opposed to transferFrom, this imposes no restrictions on msg.sender. * @param from current owner of the token * @param to address to receive the ownership of the given token ID * @param tokenId uint256 ID of the token to be transferred */ function _transferFrom(address from, address to, uint256 tokenId) internal { super._transferFrom(from, to, tokenId); _removeTokenFromOwnerEnumeration(from, tokenId); _addTokenToOwnerEnumeration(to, tokenId); } /** * @dev Internal function to mint a new token. * Reverts if the given token ID already exists. * @param to address the beneficiary that will own the minted token * @param tokenId uint256 ID of the token to be minted */ function _mint(address to, uint256 tokenId) internal { super._mint(to, tokenId); _addTokenToOwnerEnumeration(to, tokenId); _addTokenToAllTokensEnumeration(tokenId); } /** * @dev Internal function to burn a specific token. * Reverts if the token does not exist. * Deprecated, use {ERC721-_burn} instead. * @param owner owner of the token to burn * @param tokenId uint256 ID of the token being burned */ function _burn(address owner, uint256 tokenId) internal { super._burn(owner, tokenId); _removeTokenFromOwnerEnumeration(owner, tokenId); // Since tokenId will be deleted, we can clear its slot in _ownedTokensIndex to trigger a gas refund _ownedTokensIndex[tokenId] = 0; _removeTokenFromAllTokensEnumeration(tokenId); } /** * @dev Gets the list of token IDs of the requested owner. * @param owner address owning the tokens * @return uint256[] List of token IDs owned by the requested address */ function _tokensOfOwner(address owner) internal view returns (uint256[] storage) { return _ownedTokens[owner]; } /** * @dev Private function to add a token to this extension's ownership-tracking data structures. * @param to address representing the new owner of the given token ID * @param tokenId uint256 ID of the token to be added to the tokens list of the given address */ function _addTokenToOwnerEnumeration(address to, uint256 tokenId) private { _ownedTokensIndex[tokenId] = _ownedTokens[to].length; _ownedTokens[to].push(tokenId); } /** * @dev Private function to add a token to this extension's token tracking data structures. * @param tokenId uint256 ID of the token to be added to the tokens list */ function _addTokenToAllTokensEnumeration(uint256 tokenId) private { _allTokensIndex[tokenId] = _allTokens.length; _allTokens.push(tokenId); } /** * @dev Private function to remove a token from this extension's ownership-tracking data structures. Note that * while the token is not assigned a new owner, the `_ownedTokensIndex` mapping is _not_ updated: this allows for * gas optimizations e.g. when performing a transfer operation (avoiding double writes). * This has O(1) time complexity, but alters the order of the _ownedTokens array. * @param from address representing the previous owner of the given token ID * @param tokenId uint256 ID of the token to be removed from the tokens list of the given address */ function _removeTokenFromOwnerEnumeration(address from, uint256 tokenId) private { // To prevent a gap in from's tokens array, we store the last token in the index of the token to delete, and // then delete the last slot (swap and pop). uint256 lastTokenIndex = _ownedTokens[from].length.sub(1); uint256 tokenIndex = _ownedTokensIndex[tokenId]; // When the token to delete is the last token, the swap operation is unnecessary if (tokenIndex != lastTokenIndex) { uint256 lastTokenId = _ownedTokens[from][lastTokenIndex]; _ownedTokens[from][tokenIndex] = lastTokenId; // Move the last token to the slot of the to-delete token _ownedTokensIndex[lastTokenId] = tokenIndex; // Update the moved token's index } // This also deletes the contents at the last position of the array _ownedTokens[from].length--; // Note that _ownedTokensIndex[tokenId] hasn't been cleared: it still points to the old slot (now occupied by // lastTokenId, or just over the end of the array if the token was the last one). } /** * @dev Private function to remove a token from this extension's token tracking data structures. * This has O(1) time complexity, but alters the order of the _allTokens array. * @param tokenId uint256 ID of the token to be removed from the tokens list */ function _removeTokenFromAllTokensEnumeration(uint256 tokenId) private { // To prevent a gap in the tokens array, we store the last token in the index of the token to delete, and // then delete the last slot (swap and pop). uint256 lastTokenIndex = _allTokens.length.sub(1); uint256 tokenIndex = _allTokensIndex[tokenId]; // When the token to delete is the last token, the swap operation is unnecessary. However, since this occurs so // rarely (when the last minted token is burnt) that we still do the swap here to avoid the gas cost of adding // an 'if' statement (like in _removeTokenFromOwnerEnumeration) uint256 lastTokenId = _allTokens[lastTokenIndex]; _allTokens[tokenIndex] = lastTokenId; // Move the last token to the slot of the to-delete token _allTokensIndex[lastTokenId] = tokenIndex; // Update the moved token's index // This also deletes the contents at the last position of the array _allTokens.length--; _allTokensIndex[tokenId] = 0; } } // File: openzeppelin-solidity/contracts/token/ERC721/IERC721Metadata.sol pragma solidity ^0.5.0; /** * @title ERC-721 Non-Fungible Token Standard, optional metadata extension * @dev See https://eips.ethereum.org/EIPS/eip-721 */ contract IERC721Metadata is IERC721 { function name() external view returns (string memory); function symbol() external view returns (string memory); function tokenURI(uint256 tokenId) external view returns (string memory); } // File: openzeppelin-solidity/contracts/token/ERC721/ERC721Metadata.sol pragma solidity ^0.5.0; contract ERC721Metadata is Context, ERC165, ERC721, IERC721Metadata { // Token name string private _name; // Token symbol string private _symbol; // Optional mapping for token URIs mapping(uint256 => string) private _tokenURIs; /* * bytes4(keccak256('name()')) == 0x06fdde03 * bytes4(keccak256('symbol()')) == 0x95d89b41 * bytes4(keccak256('tokenURI(uint256)')) == 0xc87b56dd * * => 0x06fdde03 ^ 0x95d89b41 ^ 0xc87b56dd == 0x5b5e139f */ bytes4 private constant _INTERFACE_ID_ERC721_METADATA = 0x5b5e139f; /** * @dev Constructor function */ constructor (string memory name, string memory symbol) public { _name = name; _symbol = symbol; // register the supported interfaces to conform to ERC721 via ERC165 _registerInterface(_INTERFACE_ID_ERC721_METADATA); } /** * @dev Gets the token name. * @return string representing the token name */ function name() external view returns (string memory) { return _name; } /** * @dev Gets the token symbol. * @return string representing the token symbol */ function symbol() external view returns (string memory) { return _symbol; } /** * @dev Returns an URI for a given token ID. * Throws if the token ID does not exist. May return an empty string. * @param tokenId uint256 ID of the token to query */ function tokenURI(uint256 tokenId) external view returns (string memory) { require(_exists(tokenId), "ERC721Metadata: URI query for nonexistent token"); return _tokenURIs[tokenId]; } /** * @dev Internal function to set the token URI for a given token. * Reverts if the token ID does not exist. * @param tokenId uint256 ID of the token to set its URI * @param uri string URI to assign */ function _setTokenURI(uint256 tokenId, string memory uri) internal { require(_exists(tokenId), "ERC721Metadata: URI set of nonexistent token"); _tokenURIs[tokenId] = uri; } /** * @dev Internal function to burn a specific token. * Reverts if the token does not exist. * Deprecated, use _burn(uint256) instead. * @param owner owner of the token to burn * @param tokenId uint256 ID of the token being burned by the msg.sender */ function _burn(address owner, uint256 tokenId) internal { super._burn(owner, tokenId); // Clear metadata (if any) if (bytes(_tokenURIs[tokenId]).length != 0) { delete _tokenURIs[tokenId]; } } } // File: openzeppelin-solidity/contracts/token/ERC721/ERC721Full.sol pragma solidity ^0.5.0; /** * @title Full ERC721 Token * @dev This implementation includes all the required and some optional functionality of the ERC721 standard * Moreover, it includes approve all functionality using operator terminology. * * See https://eips.ethereum.org/EIPS/eip-721 */ contract ERC721Full is ERC721, ERC721Enumerable, ERC721Metadata { constructor (string memory name, string memory symbol) public ERC721Metadata(name, symbol) { // solhint-disable-previous-line no-empty-blocks } } // File: openzeppelin-solidity/contracts/access/roles/MinterRole.sol pragma solidity ^0.5.0; contract MinterRole is Context { using Roles for Roles.Role; event MinterAdded(address indexed account); event MinterRemoved(address indexed account); Roles.Role private _minters; constructor () internal { _addMinter(_msgSender()); } modifier onlyMinter() { require(isMinter(_msgSender()), "MinterRole: caller does not have the Minter role"); _; } function isMinter(address account) public view returns (bool) { return _minters.has(account); } function addMinter(address account) public onlyMinter { _addMinter(account); } function renounceMinter() public { _removeMinter(_msgSender()); } function _addMinter(address account) internal { _minters.add(account); emit MinterAdded(account); } function _removeMinter(address account) internal { _minters.remove(account); emit MinterRemoved(account); } } // File: openzeppelin-solidity/contracts/token/ERC721/ERC721Mintable.sol pragma solidity ^0.5.0; /** * @title ERC721Mintable * @dev ERC721 minting logic. */ contract ERC721Mintable is ERC721, MinterRole { /** * @dev Function to mint tokens. * @param to The address that will receive the minted token. * @param tokenId The token id to mint. * @return A boolean that indicates if the operation was successful. */ function mint(address to, uint256 tokenId) public onlyMinter returns (bool) { _mint(to, tokenId); return true; } /** * @dev Function to safely mint tokens. * @param to The address that will receive the minted token. * @param tokenId The token id to mint. * @return A boolean that indicates if the operation was successful. */ function safeMint(address to, uint256 tokenId) public onlyMinter returns (bool) { _safeMint(to, tokenId); return true; } /** * @dev Function to safely mint tokens. * @param to The address that will receive the minted token. * @param tokenId The token id to mint. * @param _data bytes data to send along with a safe transfer check. * @return A boolean that indicates if the operation was successful. */ function safeMint(address to, uint256 tokenId, bytes memory _data) public onlyMinter returns (bool) { _safeMint(to, tokenId, _data); return true; } } // File: openzeppelin-solidity/contracts/token/ERC721/ERC721Pausable.sol pragma solidity ^0.5.0; /** * @title ERC721 Non-Fungible Pausable token * @dev ERC721 modified with pausable transfers. */ contract ERC721Pausable is ERC721, Pausable { function approve(address to, uint256 tokenId) public whenNotPaused { super.approve(to, tokenId); } function setApprovalForAll(address to, bool approved) public whenNotPaused { super.setApprovalForAll(to, approved); } function _transferFrom(address from, address to, uint256 tokenId) internal whenNotPaused { super._transferFrom(from, to, tokenId); } } // File: contracts/GuildAsset.sol pragma solidity ^0.5.5; contract GuildAsset is ERC721Full, ERC721Mintable, ERC721Pausable { uint16 public constant GUILD_TYPE_OFFSET = 10000; uint16 public constant GUILD_RARITY_OFFSET = 1000; uint256 public constant SHARE_RATE_DECIMAL = 10**18; uint16 public constant LEGENDARY_RARITY = 3; uint16 public constant GOLD_RARITY = 2; uint16 public constant SILVER_RARITY = 1; uint16 public constant NO_GUILD = 0; string public tokenURIPrefix = "https://cryptospells.jp/metadata/guild/"; mapping(uint16 => uint256) private guildTypeToTotalVolume; mapping(uint16 => uint256) private guildTypeToStockSupplyLimit; mapping(uint16 => mapping(uint16 => uint256)) private guildTypeAndRarityToStockSupply; mapping(uint16 => uint256[]) private guildTypeToGuildStockList; mapping(uint16 => uint256) private guildTypeToGuildStockIndex; mapping(uint16 => mapping(uint16 => uint256)) private guildTypeAndRarityToGuildStockCount; mapping(uint16 => uint256) private rarityToStockVolume; // ロックアップ期間用変数 //mapping(uint256 => bool) private allowed; constructor() ERC721Full("CryptoSpells:Guild", "CSPL") public { rarityToStockVolume[LEGENDARY_RARITY] = 100; rarityToStockVolume[GOLD_RARITY] = 10; rarityToStockVolume[SILVER_RARITY] = 1; guildTypeToTotalVolume[NO_GUILD] = 0; } function setSupplyAndStock( uint16 _guildType, // 3桁。ギルドごと1つ uint256 _totalVolume, uint256 _stockSupplyLimit, uint256 legendarySupply, uint256 goldSupply, uint256 silverSupply ) external onlyMinter { require(_guildType != 0, "guildType 0 is noguild"); require(_totalVolume != 0, "totalVolume must not be 0"); //require(getMintedStockCount(_guildType) == 0, "This GuildType already exists"); require( legendarySupply.mul(rarityToStockVolume[LEGENDARY_RARITY]) .add(goldSupply.mul(rarityToStockVolume[GOLD_RARITY])) .add(silverSupply.mul(rarityToStockVolume[SILVER_RARITY])) == _totalVolume ); require( legendarySupply .add(goldSupply) .add(silverSupply) == _stockSupplyLimit ); guildTypeToTotalVolume[_guildType] = _totalVolume; guildTypeToStockSupplyLimit[_guildType] = _stockSupplyLimit; guildTypeAndRarityToStockSupply[_guildType][LEGENDARY_RARITY] = legendarySupply; guildTypeAndRarityToStockSupply[_guildType][GOLD_RARITY] = goldSupply; guildTypeAndRarityToStockSupply[_guildType][SILVER_RARITY] = silverSupply; } // mapping(uint16 => uint16) private guildTypeToSupplyLimit; // ロックアップ期間用 /* function approve(address _to, uint256 _tokenId) public { require(allowed[_tokenId]); super.approve(_to, _tokenId); } function transferFrom(address _from, address _to, uint256 _tokenId) public { require(allowed[_tokenId]); super.transferFrom(_from, _to, _tokenId); } function unLockToken(uint256 _tokenId) public onlyMinter { allowed[_tokenId] = true; } function canTransfer(uint256 _tokenId) public view returns (bool) { return allowed[_tokenId]; } */ function isAlreadyMinted(uint256 _tokenId) public view returns (bool) { return _exists(_tokenId); } function isValidGuildStock(uint256 _guildTokenId) public view { uint16 rarity = getRarity(_guildTokenId); require((rarityToStockVolume[rarity] > 0), "invalid rarityToStockVolume"); uint16 guildType = getGuildType(_guildTokenId); require((guildTypeToTotalVolume[guildType] > 0), "invalid guildTypeToTotalVolume"); uint256 serial = _guildTokenId % GUILD_TYPE_OFFSET; require(serial != 0, "invalid serial zero"); require(serial <= guildTypeAndRarityToStockSupply[guildType][rarity], "invalid serial guildTypeAndRarityToStockSupply"); } function getTotalVolume(uint16 _guildType) public view returns (uint256) { return guildTypeToTotalVolume[_guildType]; } function getStockSupplyLimit(uint16 _guildType) public view returns (uint256) { return guildTypeToStockSupplyLimit[_guildType]; } function getGuildType(uint256 _guildTokenId) public view returns (uint16) { uint16 _guildType = uint16((_guildTokenId.div(GUILD_TYPE_OFFSET)) % GUILD_RARITY_OFFSET); return _guildType; } function getRarity(uint256 _guildTokenId) public view returns (uint16) { return uint16(_guildTokenId.div(GUILD_TYPE_OFFSET).div(GUILD_RARITY_OFFSET) % 10); } function getMintedStockCount(uint16 _guildType) public view returns (uint256) { return guildTypeToGuildStockIndex[_guildType]; } function getMintedStockCountByRarity(uint16 _guildType, uint16 _rarity) public view returns (uint256) { return guildTypeAndRarityToGuildStockCount[_guildType][_rarity]; } function getStockSupplyByRarity(uint16 _guildType, uint16 _rarity) public view returns (uint256) { return guildTypeAndRarityToStockSupply[_guildType][_rarity]; } function getMintedStockList(uint16 _guildType) public view returns (uint256[] memory) { return guildTypeToGuildStockList[_guildType]; } function getStockVolumeByRarity(uint16 _rarity) public view returns (uint256) { return rarityToStockVolume[_rarity]; } function getShareRateWithDecimal(uint256 _guildTokenId) public view returns (uint256, uint256) { return ( getStockVolumeByRarity(getRarity(_guildTokenId)) .mul(SHARE_RATE_DECIMAL) .div(getTotalVolume(getGuildType(_guildTokenId))), SHARE_RATE_DECIMAL ); } /* function setSupplyLimit(uint16 _guildType, uint16 _supplyLimit) external onlyMinter { require(_supplyLimit != 0); require(guildTypeToSupplyLimit[_guildType] == 0 || _supplyLimit < guildTypeToSupplyLimit[_guildType], "_supplyLimit is bigger"); guildTypeToSupplyLimit[_guildType] = _supplyLimit; } */ function setTokenURIPrefix(string calldata _tokenURIPrefix) external onlyMinter { tokenURIPrefix = _tokenURIPrefix; } /* function getSupplyLimit(uint16 _guildType) public view returns (uint16) { return guildTypeToSupplyLimit[_guildType]; } */ function mintGuildStock(address _owner, uint256 _guildTokenId) public onlyMinter { // _guildStockがtokenId require(!isAlreadyMinted(_guildTokenId), "is Already Minted"); // バリデーションチェック isValidGuildStock(_guildTokenId); // supplyチェック uint16 _guildType = getGuildType(_guildTokenId); require(guildTypeToGuildStockIndex[_guildType] < guildTypeToStockSupplyLimit[_guildType]); uint16 rarity = getRarity(_guildTokenId); require(guildTypeAndRarityToGuildStockCount[_guildType][rarity] < guildTypeAndRarityToStockSupply[_guildType][rarity], "supply over"); _mint(_owner, _guildTokenId); guildTypeToGuildStockList[_guildType].push(_guildTokenId); guildTypeToGuildStockIndex[_guildType]++; guildTypeAndRarityToGuildStockCount[_guildType][rarity]++; } /* function mintGuildAsset(address _owner, uint256 _tokenId) public onlyMinter { // 200010001 uint16 _guildType = uint16(_tokenId / GUILD_TYPE_OFFSET); uint16 _guildTypeIndex = uint16(_tokenId % GUILD_TYPE_OFFSET) - 1; require(_guildTypeIndex < guildTypeToSupplyLimit[_guildType], "supply over"); _mint(_owner, _tokenId); } */ function tokenURI(uint256 tokenId) public view returns (string memory) { bytes32 tokenIdBytes; if (tokenId == 0) { tokenIdBytes = "0"; } else { uint256 value = tokenId; while (value > 0) { tokenIdBytes = bytes32(uint256(tokenIdBytes) / (2 ** 8)); tokenIdBytes |= bytes32(((value % 10) + 48) * 2 ** (8 * 31)); value /= 10; } } bytes memory prefixBytes = bytes(tokenURIPrefix); bytes memory tokenURIBytes = new bytes(prefixBytes.length + tokenIdBytes.length); uint8 i; uint8 index = 0; for (i = 0; i < prefixBytes.length; i++) { tokenURIBytes[index] = prefixBytes[i]; index++; } for (i = 0; i < tokenIdBytes.length; i++) { tokenURIBytes[index] = tokenIdBytes[i]; index++; } return string(tokenURIBytes); } } // File: contracts/CSPLGuildPool.sol pragma solidity ^0.5.5; contract ReentrancyGuard { /// @dev counter to allow mutex lock with only one SSTORE operation uint256 private _guardCounter; constructor () internal { // The counter starts at one to prevent changing it from zero to a non-zero // value, which is a more expensive operation. _guardCounter = 1; } /** * @dev Prevents a contract from calling itself, directly or indirectly. * Calling a `nonReentrant` function from another `nonReentrant` * function is not supported. It is possible to prevent this from happening * by making the `nonReentrant` function external, and make it call a * `private` function that does the actual work. */ modifier nonReentrant() { _guardCounter += 1; uint256 localCounter = _guardCounter; _; require(localCounter == _guardCounter); } } contract CSPLGuildPool is Ownable, Pausable, ReentrancyGuard { GuildAsset public guildAsset; // ギルドタイプごとの総量 mapping(uint16 => uint256) private guildTypeToTotalAmount; // ギルドトークン単位のこれまで引き出した量 mapping(uint256 => uint256) private guildStockToWithdrawnAmount; // 引き出し可能なアドレスリスト mapping(address => bool) private allowedAddresses; event EthAddedToPool( uint16 indexed guildType, address txSender, address indexed purchaseBy, uint256 value, uint256 at ); event WithdrawEther( uint256 indexed guildTokenId, address indexed owner, uint256 value, uint256 at ); event AllowedAddressSet( address allowedAddress, bool allowedStatus ); constructor(address _guildAssetAddress) public { guildAsset = GuildAsset(_guildAssetAddress); } // GuildAseetコントラクトのコントラクトアドレス変更 function setGuildAssetAddress(address _guildAssetAddress) external onlyOwner() { guildAsset = GuildAsset(_guildAssetAddress); } // getter setter function getAllowedAddress(address _address) public view returns (bool) { return allowedAddresses[_address]; } function setAllowedAddress(address _address, bool desired) external onlyOwner() { allowedAddresses[_address] = desired; } function getGuildStockWithdrawnAmount(uint256 _guildTokenId) public view returns (uint256) { return guildStockToWithdrawnAmount[_guildTokenId]; } function getGuildTypeToTotalAmount(uint16 _guildType) public view returns (uint256) { return guildTypeToTotalAmount[_guildType]; } // poolに追加(buySPLから呼ばれる) // TODO function addEthToGuildPool(uint16 _guildType, address _purchaseBy) external payable whenNotPaused() nonReentrant() { //function addEthToGuildPool(uint16 _guildType, address _purchaseBy, uint256 value) external { require(guildAsset.getTotalVolume(_guildType) > 0); require(allowedAddresses[msg.sender]); guildTypeToTotalAmount[_guildType] += msg.value; emit EthAddedToPool( _guildType, msg.sender, _purchaseBy, msg.value, block.timestamp ); } function withdrawMyAllRewards() external whenNotPaused() nonReentrant() { require(getWithdrawableBalance(msg.sender) > 0); uint256 withdrawValue; uint256 balance = guildAsset.balanceOf(msg.sender); for (uint256 i=balance; i > 0; i--) { uint256 guildStock = guildAsset.tokenOfOwnerByIndex(msg.sender, i-1); uint256 tmpAmount = getGuildStockWithdrawableBalance(guildStock); withdrawValue += tmpAmount; guildStockToWithdrawnAmount[guildStock] += tmpAmount; emit WithdrawEther( guildStock, msg.sender, tmpAmount, block.timestamp ); } msg.sender.transfer(withdrawValue); } // 引き出し function withdrawMyReward(uint256 _guildTokenId) external whenNotPaused() nonReentrant() { require(guildAsset.ownerOf(_guildTokenId) == msg.sender); uint256 withdrawableAmount = getGuildStockWithdrawableBalance(_guildTokenId); require(withdrawableAmount > 0); guildStockToWithdrawnAmount[_guildTokenId] += withdrawableAmount; msg.sender.transfer(withdrawableAmount); emit WithdrawEther( _guildTokenId, msg.sender, withdrawableAmount, block.timestamp ); } // ギルドトークンごとの引き出し可能な量 // 全体の総和×割合-これまで引き出した量 function getGuildStockWithdrawableBalance(uint256 _guildTokenId) public view returns (uint256) { guildAsset.isValidGuildStock(_guildTokenId); uint16 _guildType = guildAsset.getGuildType(_guildTokenId); (uint256 shareRate, uint256 decimal) = guildAsset.getShareRateWithDecimal(_guildTokenId); uint256 maxAmount = guildTypeToTotalAmount[_guildType] * shareRate / decimal; return maxAmount - guildStockToWithdrawnAmount[_guildTokenId]; } // そのオーナーの引き出し可能な総量 function getWithdrawableBalance(address _ownerAddress) public view returns (uint256) { uint256 balance = guildAsset.balanceOf(_ownerAddress); uint256 withdrawableAmount; for (uint256 i=balance; i > 0; i--) { uint256 guildTokenId = guildAsset.tokenOfOwnerByIndex(_ownerAddress, i-1); withdrawableAmount += getGuildStockWithdrawableBalance(guildTokenId); } return withdrawableAmount; } } /* solhint-enable indent*/
Contract Security Audit
- No Contract Security Audit Submitted- Submit Audit Here
[{"constant":true,"inputs":[{"name":"_guildTokenId","type":"uint256"}],"name":"getGuildStockWithdrawableBalance","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[],"name":"unpause","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"name":"account","type":"address"}],"name":"isPauser","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"_guildTokenId","type":"uint256"}],"name":"withdrawMyReward","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"paused","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"guildAsset","outputs":[{"name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[],"name":"renouncePauser","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"name":"_guildType","type":"uint16"}],"name":"getGuildTypeToTotalAmount","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[],"name":"renounceOwnership","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[],"name":"withdrawMyAllRewards","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"account","type":"address"}],"name":"addPauser","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"name":"_ownerAddress","type":"address"}],"name":"getWithdrawableBalance","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[],"name":"pause","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"owner","outputs":[{"name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"isOwner","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"name":"_guildTokenId","type":"uint256"}],"name":"getGuildStockWithdrawnAmount","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"_guildAssetAddress","type":"address"}],"name":"setGuildAssetAddress","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"name":"_address","type":"address"}],"name":"getAllowedAddress","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"_guildType","type":"uint16"},{"name":"_purchaseBy","type":"address"}],"name":"addEthToGuildPool","outputs":[],"payable":true,"stateMutability":"payable","type":"function"},{"constant":false,"inputs":[{"name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"_address","type":"address"},{"name":"desired","type":"bool"}],"name":"setAllowedAddress","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"inputs":[{"name":"_guildAssetAddress","type":"address"}],"payable":false,"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"name":"guildType","type":"uint16"},{"indexed":false,"name":"txSender","type":"address"},{"indexed":true,"name":"purchaseBy","type":"address"},{"indexed":false,"name":"value","type":"uint256"},{"indexed":false,"name":"at","type":"uint256"}],"name":"EthAddedToPool","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"name":"guildTokenId","type":"uint256"},{"indexed":true,"name":"owner","type":"address"},{"indexed":false,"name":"value","type":"uint256"},{"indexed":false,"name":"at","type":"uint256"}],"name":"WithdrawEther","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"name":"allowedAddress","type":"address"},{"indexed":false,"name":"allowedStatus","type":"bool"}],"name":"AllowedAddressSet","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"name":"account","type":"address"}],"name":"Paused","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"name":"account","type":"address"}],"name":"Unpaused","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"name":"account","type":"address"}],"name":"PauserAdded","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"name":"account","type":"address"}],"name":"PauserRemoved","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"name":"previousOwner","type":"address"},{"indexed":true,"name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"}]
Contract Creation Code
60806040523480156200001157600080fd5b50604051602080620024f6833981018060405260208110156200003357600080fd5b8101908080519060200190929190505050620000546200019a60201b60201c565b6000806101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055506000809054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16600073ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a36200012f620001236200019a60201b60201c565b620001a260201b60201c565b6000600260006101000a81548160ff021916908315150217905550600160038190555080600460006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555050620003cb565b600033905090565b620001bd8160016200020360201b62001f571790919060201c565b8073ffffffffffffffffffffffffffffffffffffffff167f6719d08c1888103bea251a4ed56406bd0c3e69723c8a1686e017e7bbe159b6f860405160405180910390a250565b620002158282620002e960201b60201c565b1515156200028b576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252601f8152602001807f526f6c65733a206163636f756e7420616c72656164792068617320726f6c650081525060200191505060405180910390fd5b60018260000160008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff0219169083151502179055505050565b60008073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff161415151562000374576040517f08c379a0000000000000000000000000000000000000000000000000000000008152600401808060200182810382526022815260200180620024d46022913960400191505060405180910390fd5b8260000160008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16905092915050565b6120f980620003db6000396000f3fe60806040526004361061012a5760003560e01c806382dc1ec4116100ab578063a3a7e3e41161006f578063a3a7e3e4146104aa578063a881cdf6146104f9578063ced7ed2c1461054a578063e073af72146105b3578063f2fde38b14610605578063fae36986146106565761012a565b806382dc1ec414610357578063843592d3146103a85780638456cb591461040d5780638da5cb5b146104245780638f32d59b1461047b5761012a565b80636e9f6529116100f25780636e9f6529146102685780636ef8d66d146102bf5780636f1fa432146102d6578063715018a614610329578063760b8cc2146103405761012a565b8063078405c11461012f5780633f4ba83a1461017e57806346fbf68e1461019557806356990e65146101fe5780635c975abb14610239575b600080fd5b34801561013b57600080fd5b506101686004803603602081101561015257600080fd5b81019080803590602001909291905050506106b3565b6040518082815260200191505060405180910390f35b34801561018a57600080fd5b506101936108fe565b005b3480156101a157600080fd5b506101e4600480360360208110156101b857600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff169060200190929190505050610a70565b604051808215151515815260200191505060405180910390f35b34801561020a57600080fd5b506102376004803603602081101561022157600080fd5b8101908080359060200190929190505050610a8d565b005b34801561024557600080fd5b5061024e610d01565b604051808215151515815260200191505060405180910390f35b34801561027457600080fd5b5061027d610d18565b604051808273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390f35b3480156102cb57600080fd5b506102d4610d3e565b005b3480156102e257600080fd5b50610313600480360360208110156102f957600080fd5b81019080803561ffff169060200190929190505050610d50565b6040518082815260200191505060405180910390f35b34801561033557600080fd5b5061033e610d75565b005b34801561034c57600080fd5b50610355610eb0565b005b34801561036357600080fd5b506103a66004803603602081101561037a57600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff169060200190929190505050611232565b005b3480156103b457600080fd5b506103f7600480360360208110156103cb57600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff1690602001909291905050506112a5565b6040518082815260200191505060405180910390f35b34801561041957600080fd5b506104226114a4565b005b34801561043057600080fd5b50610439611617565b604051808273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390f35b34801561048757600080fd5b50610490611640565b604051808215151515815260200191505060405180910390f35b3480156104b657600080fd5b506104e3600480360360208110156104cd57600080fd5b810190808035906020019092919050505061169e565b6040518082815260200191505060405180910390f35b34801561050557600080fd5b506105486004803603602081101561051c57600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff1690602001909291905050506116bb565b005b34801561055657600080fd5b506105996004803603602081101561056d57600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff16906020019092919050505061177b565b604051808215151515815260200191505060405180910390f35b610603600480360360408110156105c957600080fd5b81019080803561ffff169060200190929190803573ffffffffffffffffffffffffffffffffffffffff1690602001909291905050506117d1565b005b34801561061157600080fd5b506106546004803603602081101561062857600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff169060200190929190505050611a57565b005b34801561066257600080fd5b506106b16004803603604081101561067957600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff169060200190929190803515159060200190929190505050611adf565b005b6000600460009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16633f6fcc59836040518263ffffffff1660e01b81526004018082815260200191505060006040518083038186803b15801561072857600080fd5b505afa15801561073c573d6000803e3d6000fd5b505050506000600460009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663fc044eb2846040518263ffffffff1660e01b81526004018082815260200191505060206040518083038186803b1580156107b557600080fd5b505afa1580156107c9573d6000803e3d6000fd5b505050506040513d60208110156107df57600080fd5b81019080805190602001909291905050509050600080600460009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16631ee2ec93866040518263ffffffff1660e01b815260040180828152602001915050604080518083038186803b15801561086757600080fd5b505afa15801561087b573d6000803e3d6000fd5b505050506040513d604081101561089157600080fd5b8101908080519060200190929190805190602001909291905050509150915060008183600560008761ffff1661ffff16815260200190815260200160002054028115156108da57fe5b04905060066000878152602001908152602001600020548103945050505050919050565b61090e610909611bb6565b610a70565b1515610965576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260308152602001806120356030913960400191505060405180910390fd5b600260009054906101000a900460ff1615156109e9576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260148152602001807f5061757361626c653a206e6f742070617573656400000000000000000000000081525060200191505060405180910390fd5b6000600260006101000a81548160ff0219169083151502179055507f5db9ee0a495bf2e6ff9c91a7834c1ba4fdd244a5e8aa4e537bd38aeae4b073aa610a2d611bb6565b604051808273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390a1565b6000610a86826001611bbe90919063ffffffff16565b9050919050565b600260009054906101000a900460ff16151515610b12576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260108152602001807f5061757361626c653a207061757365640000000000000000000000000000000081525060200191505060405180910390fd5b6001600360008282540192505081905550600060035490503373ffffffffffffffffffffffffffffffffffffffff16600460009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16636352211e846040518263ffffffff1660e01b81526004018082815260200191505060206040518083038186803b158015610bb457600080fd5b505afa158015610bc8573d6000803e3d6000fd5b505050506040513d6020811015610bde57600080fd5b810190808051906020019092919050505073ffffffffffffffffffffffffffffffffffffffff16141515610c1157600080fd5b6000610c1c836106b3565b9050600081111515610c2d57600080fd5b8060066000858152602001908152602001600020600082825401925050819055503373ffffffffffffffffffffffffffffffffffffffff166108fc829081150290604051600060405180830381858888f19350505050158015610c94573d6000803e3d6000fd5b503373ffffffffffffffffffffffffffffffffffffffff16837fa2af676ed4f1045c96ac2b367997d51c256e9d758a41490190108d260e9634f78342604051808381526020018281526020019250505060405180910390a35060035481141515610cfd57600080fd5b5050565b6000600260009054906101000a900460ff16905090565b600460009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b610d4e610d49611bb6565b611c9e565b565b6000600560008361ffff1661ffff168152602001908152602001600020549050919050565b610d7d611640565b1515610df1576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260208152602001807f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657281525060200191505060405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff166000809054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a360008060006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550565b600260009054906101000a900460ff16151515610f35576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260108152602001807f5061757361626c653a207061757365640000000000000000000000000000000081525060200191505060405180910390fd5b6001600360008282540192505081905550600060035490506000610f58336112a5565b111515610f6457600080fd5b600080600460009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166370a08231336040518263ffffffff1660e01b8152600401808273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200191505060206040518083038186803b15801561100657600080fd5b505afa15801561101a573d6000803e3d6000fd5b505050506040513d602081101561103057600080fd5b8101908080519060200190929190505050905060008190505b60008111156111d5576000600460009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16632f745c5933600185036040518363ffffffff1660e01b8152600401808373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020018281526020019250505060206040518083038186803b1580156110fe57600080fd5b505afa158015611112573d6000803e3d6000fd5b505050506040513d602081101561112857600080fd5b810190808051906020019092919050505090506000611146826106b3565b905080850194508060066000848152602001908152602001600020600082825401925050819055503373ffffffffffffffffffffffffffffffffffffffff16827fa2af676ed4f1045c96ac2b367997d51c256e9d758a41490190108d260e9634f78342604051808381526020018281526020019250505060405180910390a35050808060019003915050611049565b503373ffffffffffffffffffffffffffffffffffffffff166108fc839081150290604051600060405180830381858888f1935050505015801561121c573d6000803e3d6000fd5b5050506003548114151561122f57600080fd5b50565b61124261123d611bb6565b610a70565b1515611299576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260308152602001806120356030913960400191505060405180910390fd5b6112a281611cf8565b50565b600080600460009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166370a08231846040518263ffffffff1660e01b8152600401808273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200191505060206040518083038186803b15801561134757600080fd5b505afa15801561135b573d6000803e3d6000fd5b505050506040513d602081101561137157600080fd5b810190808051906020019092919050505090506000808290505b6000811115611499576000600460009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16632f745c5987600185036040518363ffffffff1660e01b8152600401808373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020018281526020019250505060206040518083038186803b15801561144057600080fd5b505afa158015611454573d6000803e3d6000fd5b505050506040513d602081101561146a57600080fd5b81019080805190602001909291905050509050611486816106b3565b830192505080806001900391505061138b565b508092505050919050565b6114b46114af611bb6565b610a70565b151561150b576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260308152602001806120356030913960400191505060405180910390fd5b600260009054906101000a900460ff16151515611590576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260108152602001807f5061757361626c653a207061757365640000000000000000000000000000000081525060200191505060405180910390fd5b6001600260006101000a81548160ff0219169083151502179055507f62e78cea01bee320cd4e420270b5ea74000d11b0c9f74754ebdbfc544b05a2586115d4611bb6565b604051808273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390a1565b60008060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b60008060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16611682611bb6565b73ffffffffffffffffffffffffffffffffffffffff1614905090565b600060066000838152602001908152602001600020549050919050565b6116c3611640565b1515611737576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260208152602001807f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657281525060200191505060405180910390fd5b80600460006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555050565b6000600760008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff169050919050565b600260009054906101000a900460ff16151515611856576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260108152602001807f5061757361626c653a207061757365640000000000000000000000000000000081525060200191505060405180910390fd5b6001600360008282540192505081905550600060035490506000600460009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663fbba7b62856040518263ffffffff1660e01b8152600401808261ffff1661ffff16815260200191505060206040518083038186803b1580156118eb57600080fd5b505afa1580156118ff573d6000803e3d6000fd5b505050506040513d602081101561191557600080fd5b810190808051906020019092919050505011151561193257600080fd5b600760003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16151561198a57600080fd5b34600560008561ffff1661ffff168152602001908152602001600020600082825401925050819055508173ffffffffffffffffffffffffffffffffffffffff168361ffff167f47fc953414cd61a5494c179efb796283502f867ea6d50a54853a0281f1b7c3fc333442604051808473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001838152602001828152602001935050505060405180910390a360035481141515611a5257600080fd5b505050565b611a5f611640565b1515611ad3576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260208152602001807f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657281525060200191505060405180910390fd5b611adc81611d52565b50565b611ae7611640565b1515611b5b576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260208152602001807f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657281525060200191505060405180910390fd5b80600760008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff0219169083151502179055505050565b600033905090565b60008073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1614151515611c47576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260228152602001806120ac6022913960400191505060405180910390fd5b8260000160008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16905092915050565b611cb2816001611e9890919063ffffffff16565b8073ffffffffffffffffffffffffffffffffffffffff167fcd265ebaf09df2871cc7bd4133404a235ba12eff2041bb89d9c714a2621c7c7e60405160405180910390a250565b611d0c816001611f5790919063ffffffff16565b8073ffffffffffffffffffffffffffffffffffffffff167f6719d08c1888103bea251a4ed56406bd0c3e69723c8a1686e017e7bbe159b6f860405160405180910390a250565b600073ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff1614151515611dda576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260268152602001806120656026913960400191505060405180910390fd5b8073ffffffffffffffffffffffffffffffffffffffff166000809054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a3806000806101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555050565b611ea28282611bbe565b1515611ef9576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252602181526020018061208b6021913960400191505060405180910390fd5b60008260000160008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff0219169083151502179055505050565b611f618282611bbe565b151515611fd6576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252601f8152602001807f526f6c65733a206163636f756e7420616c72656164792068617320726f6c650081525060200191505060405180910390fd5b60018260000160008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff021916908315150217905550505056fe506175736572526f6c653a2063616c6c657220646f6573206e6f742068617665207468652050617573657220726f6c654f776e61626c653a206e6577206f776e657220697320746865207a65726f2061646472657373526f6c65733a206163636f756e7420646f6573206e6f74206861766520726f6c65526f6c65733a206163636f756e7420697320746865207a65726f2061646472657373a165627a7a72305820016740467952be8fb3f852d88b57f427ca0914dff1c00c1806eb2d7dc66cca600029526f6c65733a206163636f756e7420697320746865207a65726f2061646472657373000000000000000000000000a8abf045fe1a9ef0583e436393a6e4e0b483f717
Deployed Bytecode
0x60806040526004361061012a5760003560e01c806382dc1ec4116100ab578063a3a7e3e41161006f578063a3a7e3e4146104aa578063a881cdf6146104f9578063ced7ed2c1461054a578063e073af72146105b3578063f2fde38b14610605578063fae36986146106565761012a565b806382dc1ec414610357578063843592d3146103a85780638456cb591461040d5780638da5cb5b146104245780638f32d59b1461047b5761012a565b80636e9f6529116100f25780636e9f6529146102685780636ef8d66d146102bf5780636f1fa432146102d6578063715018a614610329578063760b8cc2146103405761012a565b8063078405c11461012f5780633f4ba83a1461017e57806346fbf68e1461019557806356990e65146101fe5780635c975abb14610239575b600080fd5b34801561013b57600080fd5b506101686004803603602081101561015257600080fd5b81019080803590602001909291905050506106b3565b6040518082815260200191505060405180910390f35b34801561018a57600080fd5b506101936108fe565b005b3480156101a157600080fd5b506101e4600480360360208110156101b857600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff169060200190929190505050610a70565b604051808215151515815260200191505060405180910390f35b34801561020a57600080fd5b506102376004803603602081101561022157600080fd5b8101908080359060200190929190505050610a8d565b005b34801561024557600080fd5b5061024e610d01565b604051808215151515815260200191505060405180910390f35b34801561027457600080fd5b5061027d610d18565b604051808273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390f35b3480156102cb57600080fd5b506102d4610d3e565b005b3480156102e257600080fd5b50610313600480360360208110156102f957600080fd5b81019080803561ffff169060200190929190505050610d50565b6040518082815260200191505060405180910390f35b34801561033557600080fd5b5061033e610d75565b005b34801561034c57600080fd5b50610355610eb0565b005b34801561036357600080fd5b506103a66004803603602081101561037a57600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff169060200190929190505050611232565b005b3480156103b457600080fd5b506103f7600480360360208110156103cb57600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff1690602001909291905050506112a5565b6040518082815260200191505060405180910390f35b34801561041957600080fd5b506104226114a4565b005b34801561043057600080fd5b50610439611617565b604051808273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390f35b34801561048757600080fd5b50610490611640565b604051808215151515815260200191505060405180910390f35b3480156104b657600080fd5b506104e3600480360360208110156104cd57600080fd5b810190808035906020019092919050505061169e565b6040518082815260200191505060405180910390f35b34801561050557600080fd5b506105486004803603602081101561051c57600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff1690602001909291905050506116bb565b005b34801561055657600080fd5b506105996004803603602081101561056d57600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff16906020019092919050505061177b565b604051808215151515815260200191505060405180910390f35b610603600480360360408110156105c957600080fd5b81019080803561ffff169060200190929190803573ffffffffffffffffffffffffffffffffffffffff1690602001909291905050506117d1565b005b34801561061157600080fd5b506106546004803603602081101561062857600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff169060200190929190505050611a57565b005b34801561066257600080fd5b506106b16004803603604081101561067957600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff169060200190929190803515159060200190929190505050611adf565b005b6000600460009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16633f6fcc59836040518263ffffffff1660e01b81526004018082815260200191505060006040518083038186803b15801561072857600080fd5b505afa15801561073c573d6000803e3d6000fd5b505050506000600460009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663fc044eb2846040518263ffffffff1660e01b81526004018082815260200191505060206040518083038186803b1580156107b557600080fd5b505afa1580156107c9573d6000803e3d6000fd5b505050506040513d60208110156107df57600080fd5b81019080805190602001909291905050509050600080600460009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16631ee2ec93866040518263ffffffff1660e01b815260040180828152602001915050604080518083038186803b15801561086757600080fd5b505afa15801561087b573d6000803e3d6000fd5b505050506040513d604081101561089157600080fd5b8101908080519060200190929190805190602001909291905050509150915060008183600560008761ffff1661ffff16815260200190815260200160002054028115156108da57fe5b04905060066000878152602001908152602001600020548103945050505050919050565b61090e610909611bb6565b610a70565b1515610965576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260308152602001806120356030913960400191505060405180910390fd5b600260009054906101000a900460ff1615156109e9576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260148152602001807f5061757361626c653a206e6f742070617573656400000000000000000000000081525060200191505060405180910390fd5b6000600260006101000a81548160ff0219169083151502179055507f5db9ee0a495bf2e6ff9c91a7834c1ba4fdd244a5e8aa4e537bd38aeae4b073aa610a2d611bb6565b604051808273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390a1565b6000610a86826001611bbe90919063ffffffff16565b9050919050565b600260009054906101000a900460ff16151515610b12576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260108152602001807f5061757361626c653a207061757365640000000000000000000000000000000081525060200191505060405180910390fd5b6001600360008282540192505081905550600060035490503373ffffffffffffffffffffffffffffffffffffffff16600460009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16636352211e846040518263ffffffff1660e01b81526004018082815260200191505060206040518083038186803b158015610bb457600080fd5b505afa158015610bc8573d6000803e3d6000fd5b505050506040513d6020811015610bde57600080fd5b810190808051906020019092919050505073ffffffffffffffffffffffffffffffffffffffff16141515610c1157600080fd5b6000610c1c836106b3565b9050600081111515610c2d57600080fd5b8060066000858152602001908152602001600020600082825401925050819055503373ffffffffffffffffffffffffffffffffffffffff166108fc829081150290604051600060405180830381858888f19350505050158015610c94573d6000803e3d6000fd5b503373ffffffffffffffffffffffffffffffffffffffff16837fa2af676ed4f1045c96ac2b367997d51c256e9d758a41490190108d260e9634f78342604051808381526020018281526020019250505060405180910390a35060035481141515610cfd57600080fd5b5050565b6000600260009054906101000a900460ff16905090565b600460009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b610d4e610d49611bb6565b611c9e565b565b6000600560008361ffff1661ffff168152602001908152602001600020549050919050565b610d7d611640565b1515610df1576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260208152602001807f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657281525060200191505060405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff166000809054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a360008060006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550565b600260009054906101000a900460ff16151515610f35576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260108152602001807f5061757361626c653a207061757365640000000000000000000000000000000081525060200191505060405180910390fd5b6001600360008282540192505081905550600060035490506000610f58336112a5565b111515610f6457600080fd5b600080600460009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166370a08231336040518263ffffffff1660e01b8152600401808273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200191505060206040518083038186803b15801561100657600080fd5b505afa15801561101a573d6000803e3d6000fd5b505050506040513d602081101561103057600080fd5b8101908080519060200190929190505050905060008190505b60008111156111d5576000600460009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16632f745c5933600185036040518363ffffffff1660e01b8152600401808373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020018281526020019250505060206040518083038186803b1580156110fe57600080fd5b505afa158015611112573d6000803e3d6000fd5b505050506040513d602081101561112857600080fd5b810190808051906020019092919050505090506000611146826106b3565b905080850194508060066000848152602001908152602001600020600082825401925050819055503373ffffffffffffffffffffffffffffffffffffffff16827fa2af676ed4f1045c96ac2b367997d51c256e9d758a41490190108d260e9634f78342604051808381526020018281526020019250505060405180910390a35050808060019003915050611049565b503373ffffffffffffffffffffffffffffffffffffffff166108fc839081150290604051600060405180830381858888f1935050505015801561121c573d6000803e3d6000fd5b5050506003548114151561122f57600080fd5b50565b61124261123d611bb6565b610a70565b1515611299576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260308152602001806120356030913960400191505060405180910390fd5b6112a281611cf8565b50565b600080600460009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff166370a08231846040518263ffffffff1660e01b8152600401808273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200191505060206040518083038186803b15801561134757600080fd5b505afa15801561135b573d6000803e3d6000fd5b505050506040513d602081101561137157600080fd5b810190808051906020019092919050505090506000808290505b6000811115611499576000600460009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16632f745c5987600185036040518363ffffffff1660e01b8152600401808373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020018281526020019250505060206040518083038186803b15801561144057600080fd5b505afa158015611454573d6000803e3d6000fd5b505050506040513d602081101561146a57600080fd5b81019080805190602001909291905050509050611486816106b3565b830192505080806001900391505061138b565b508092505050919050565b6114b46114af611bb6565b610a70565b151561150b576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260308152602001806120356030913960400191505060405180910390fd5b600260009054906101000a900460ff16151515611590576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260108152602001807f5061757361626c653a207061757365640000000000000000000000000000000081525060200191505060405180910390fd5b6001600260006101000a81548160ff0219169083151502179055507f62e78cea01bee320cd4e420270b5ea74000d11b0c9f74754ebdbfc544b05a2586115d4611bb6565b604051808273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390a1565b60008060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b60008060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16611682611bb6565b73ffffffffffffffffffffffffffffffffffffffff1614905090565b600060066000838152602001908152602001600020549050919050565b6116c3611640565b1515611737576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260208152602001807f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657281525060200191505060405180910390fd5b80600460006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555050565b6000600760008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff169050919050565b600260009054906101000a900460ff16151515611856576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260108152602001807f5061757361626c653a207061757365640000000000000000000000000000000081525060200191505060405180910390fd5b6001600360008282540192505081905550600060035490506000600460009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1663fbba7b62856040518263ffffffff1660e01b8152600401808261ffff1661ffff16815260200191505060206040518083038186803b1580156118eb57600080fd5b505afa1580156118ff573d6000803e3d6000fd5b505050506040513d602081101561191557600080fd5b810190808051906020019092919050505011151561193257600080fd5b600760003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16151561198a57600080fd5b34600560008561ffff1661ffff168152602001908152602001600020600082825401925050819055508173ffffffffffffffffffffffffffffffffffffffff168361ffff167f47fc953414cd61a5494c179efb796283502f867ea6d50a54853a0281f1b7c3fc333442604051808473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001838152602001828152602001935050505060405180910390a360035481141515611a5257600080fd5b505050565b611a5f611640565b1515611ad3576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260208152602001807f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657281525060200191505060405180910390fd5b611adc81611d52565b50565b611ae7611640565b1515611b5b576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260208152602001807f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657281525060200191505060405180910390fd5b80600760008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff0219169083151502179055505050565b600033905090565b60008073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1614151515611c47576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260228152602001806120ac6022913960400191505060405180910390fd5b8260000160008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16905092915050565b611cb2816001611e9890919063ffffffff16565b8073ffffffffffffffffffffffffffffffffffffffff167fcd265ebaf09df2871cc7bd4133404a235ba12eff2041bb89d9c714a2621c7c7e60405160405180910390a250565b611d0c816001611f5790919063ffffffff16565b8073ffffffffffffffffffffffffffffffffffffffff167f6719d08c1888103bea251a4ed56406bd0c3e69723c8a1686e017e7bbe159b6f860405160405180910390a250565b600073ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff1614151515611dda576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260268152602001806120656026913960400191505060405180910390fd5b8073ffffffffffffffffffffffffffffffffffffffff166000809054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a3806000806101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555050565b611ea28282611bbe565b1515611ef9576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252602181526020018061208b6021913960400191505060405180910390fd5b60008260000160008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff0219169083151502179055505050565b611f618282611bbe565b151515611fd6576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252601f8152602001807f526f6c65733a206163636f756e7420616c72656164792068617320726f6c650081525060200191505060405180910390fd5b60018260000160008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff021916908315150217905550505056fe506175736572526f6c653a2063616c6c657220646f6573206e6f742068617665207468652050617573657220726f6c654f776e61626c653a206e6577206f776e657220697320746865207a65726f2061646472657373526f6c65733a206163636f756e7420646f6573206e6f74206861766520726f6c65526f6c65733a206163636f756e7420697320746865207a65726f2061646472657373a165627a7a72305820016740467952be8fb3f852d88b57f427ca0914dff1c00c1806eb2d7dc66cca600029
Constructor Arguments (ABI-Encoded and is the last bytes of the Contract Creation Code above)
000000000000000000000000a8abf045fe1a9ef0583e436393a6e4e0b483f717
-----Decoded View---------------
Arg [0] : _guildAssetAddress (address): 0xa8ABF045fe1A9Ef0583e436393a6E4E0B483F717
-----Encoded View---------------
1 Constructor Arguments found :
Arg [0] : 000000000000000000000000a8abf045fe1a9ef0583e436393a6e4e0b483f717
Deployed Bytecode Sourcemap
65679:4623:0:-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;69343:464;;8:9:-1;5:2;;;30:1;27;20:12;5:2;69343:464:0;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;69343:464:0;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;5347:120;;8:9:-1;5:2;;;30:1;27;20:12;5:2;5347:120:0;;;:::i;:::-;;2818:109;;8:9:-1;5:2;;;30:1;27;20:12;5:2;2818:109:0;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;2818:109:0;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;68691:524;;8:9:-1;5:2;;;30:1;27;20:12;5:2;68691:524:0;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;68691:524:0;;;;;;;;;;;;;;;;;:::i;:::-;;4554:78;;8:9:-1;5:2;;;30:1;27;20:12;5:2;4554:78:0;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;65747:28;;8:9:-1;5:2;;;30:1;27;20:12;5:2;65747:28:0;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;3035:79;;8:9:-1;5:2;;;30:1;27;20:12;5:2;3035:79:0;;;:::i;:::-;;67262:138;;8:9:-1;5:2;;;30:1;27;20:12;5:2;67262:138:0;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;67262:138:0;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;7206:140;;8:9:-1;5:2;;;30:1;27;20:12;5:2;7206:140:0;;;:::i;:::-;;67982:684;;8:9:-1;5:2;;;30:1;27;20:12;5:2;67982:684:0;;;:::i;:::-;;2935:92;;8:9:-1;5:2;;;30:1;27;20:12;5:2;2935:92:0;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;2935:92:0;;;;;;;;;;;;;;;;;;;:::i;:::-;;69868:429;;8:9:-1;5:2;;;30:1;27;20:12;5:2;69868:429:0;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;69868:429:0;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;5134:118;;8:9:-1;5:2;;;30:1;27;20:12;5:2;5134:118:0;;;:::i;:::-;;6395:79;;8:9:-1;5:2;;;30:1;27;20:12;5:2;6395:79:0;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;6761:94;;8:9:-1;5:2;;;30:1;27;20:12;5:2;6761:94:0;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;67103:153;;8:9:-1;5:2;;;30:1;27;20:12;5:2;67103:153:0;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;67103:153:0;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;66683:135;;8:9:-1;5:2;;;30:1;27;20:12;5:2;66683:135:0;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;66683:135:0;;;;;;;;;;;;;;;;;;;:::i;:::-;;66844:118;;8:9:-1;5:2;;;30:1;27;20:12;5:2;66844:118:0;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;66844:118:0;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;67467:509;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;67467:509:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;7501:109;;8:9:-1;5:2;;;30:1;27;20:12;5:2;7501:109:0;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;7501:109:0;;;;;;;;;;;;;;;;;;;:::i;:::-;;66968:129;;8:9:-1;5:2;;;30:1;27;20:12;5:2;66968:129:0;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;66968:129:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;69343:464;69429:7;69445:10;;;;;;;;;;;:28;;;69474:13;69445:43;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;69445:43:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;69445:43:0;;;;69497:17;69517:10;;;;;;;;;;;:23;;;69541:13;69517:38;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;69517:38:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;69517:38:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;69517:38:0;;;;;;;;;;;;;;;;69497:58;;69563:17;69582:15;69601:10;;;;;;;;;;;:34;;;69636:13;69601:49;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;69601:49:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;69601:49:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;69601:49:0;;;;;;;;;;;;;;;;;;;;;;;;;69562:88;;;;69657:17;69726:7;69714:9;69677:22;:34;69700:10;69677:34;;;;;;;;;;;;;;;;:46;:56;;;;;;;;69657:76;;69759:27;:42;69787:13;69759:42;;;;;;;;;;;;69747:9;:54;69740:61;;;;;;69343:464;;;:::o;5347:120::-;2715:22;2724:12;:10;:12::i;:::-;2715:8;:22::i;:::-;2707:83;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4990:7;;;;;;;;;;;4982:40;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;5416:5;5406:7;;:15;;;;;;;;;;;;;;;;;;5437:22;5446:12;:10;:12::i;:::-;5437:22;;;;;;;;;;;;;;;;;;;;;;5347:120::o;2818:109::-;2874:4;2898:21;2911:7;2898:8;:12;;:21;;;;:::i;:::-;2891:28;;2818:109;;;:::o;68691:524::-;4791:7;;;;;;;;;;;4790:8;4782:37;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;65555:1;65538:13;;:18;;;;;;;;;;;65567:20;65590:13;;65567:36;;68832:10;68795:47;;:10;;;;;;;;;;;:18;;;68814:13;68795:33;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;68795:33:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;68795:33:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;68795:33:0;;;;;;;;;;;;;;;;:47;;;68787:56;;;;;;;;68850:26;68879:47;68912:13;68879:32;:47::i;:::-;68850:76;;68962:1;68941:18;:22;68933:31;;;;;;;;69019:18;68973:27;:42;69001:13;68973:42;;;;;;;;;;;;:64;;;;;;;;;;;69044:10;:19;;:39;69064:18;69044:39;;;;;;;;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;69044:39:0;69141:10;69097:112;;69119:13;69097:112;69160:18;69187:15;69097:112;;;;;;;;;;;;;;;;;;;;;;;;65614:1;65650:13;;65634:12;:29;65626:38;;;;;;;;4830:1;68691:524;:::o;4554:78::-;4593:4;4617:7;;;;;;;;;;;4610:14;;4554:78;:::o;65747:28::-;;;;;;;;;;;;;:::o;3035:79::-;3079:27;3093:12;:10;:12::i;:::-;3079:13;:27::i;:::-;3035:79::o;67262:138::-;67337:7;67360:22;:34;67383:10;67360:34;;;;;;;;;;;;;;;;67353:41;;67262:138;;;:::o;7206:140::-;6607:9;:7;:9::i;:::-;6599:54;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;7305:1;7268:40;;7289:6;;;;;;;;;;;7268:40;;;;;;;;;;;;7336:1;7319:6;;:19;;;;;;;;;;;;;;;;;;7206:140::o;67982:684::-;4791:7;;;;;;;;;;;4790:8;4782:37;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;65555:1;65538:13;;:18;;;;;;;;;;;65567:20;65590:13;;65567:36;;68106:1;68069:34;68092:10;68069:22;:34::i;:::-;:38;68061:47;;;;;;;;68117:21;68145:15;68163:10;;;;;;;;;;;:20;;;68184:10;68163:32;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;68163:32:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;68163:32:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;68163:32:0;;;;;;;;;;;;;;;;68145:50;;68209:9;68219:7;68209:17;;68204:416;68232:1;68228;:5;68204:416;;;68249:18;68270:10;;;;;;;;;;;:30;;;68301:10;68315:1;68313;:3;68270:47;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;68270:47:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;68270:47:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;68270:47:0;;;;;;;;;;;;;;;;68249:68;;68326:17;68346:44;68379:10;68346:32;:44::i;:::-;68326:64;;68416:9;68399:26;;;;68477:9;68434:27;:39;68462:10;68434:39;;;;;;;;;;;;:52;;;;;;;;;;;68547:10;68502:110;;68526:10;68502:110;68568:9;68588:15;68502:110;;;;;;;;;;;;;;;;;;;;;;;;68204:416;;68235:3;;;;;;;;68204:416;;;;68626:10;:19;;:34;68646:13;68626:34;;;;;;;;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;68626:34:0;65614:1;;65650:13;;65634:12;:29;65626:38;;;;;;;;4830:1;67982:684::o;2935:92::-;2715:22;2724:12;:10;:12::i;:::-;2715:8;:22::i;:::-;2707:83;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;3000:19;3011:7;3000:10;:19::i;:::-;2935:92;:::o;69868:429::-;69944:7;69960:15;69978:10;;;;;;;;;;;:20;;;69999:13;69978:35;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;69978:35:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;69978:35:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;69978:35:0;;;;;;;;;;;;;;;;69960:53;;70020:26;70060:9;70070:7;70060:17;;70055:203;70083:1;70079;:5;70055:203;;;70100:20;70123:10;;;;;;;;;;;:30;;;70154:13;70171:1;70169;:3;70123:50;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;70123:50:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;70123:50:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;70123:50:0;;;;;;;;;;;;;;;;70100:73;;70204:46;70237:12;70204:32;:46::i;:::-;70182:68;;;;70055:203;70086:3;;;;;;;;70055:203;;;;70273:18;70266:25;;;;69868:429;;;:::o;5134:118::-;2715:22;2724:12;:10;:12::i;:::-;2715:8;:22::i;:::-;2707:83;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4791:7;;;;;;;;;;;4790:8;4782:37;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;5204:4;5194:7;;:14;;;;;;;;;;;;;;;;;;5224:20;5231:12;:10;:12::i;:::-;5224:20;;;;;;;;;;;;;;;;;;;;;;5134:118::o;6395:79::-;6433:7;6460:6;;;;;;;;;;;6453:13;;6395:79;:::o;6761:94::-;6801:4;6841:6;;;;;;;;;;;6825:22;;:12;:10;:12::i;:::-;:22;;;6818:29;;6761:94;:::o;67103:153::-;67185:7;67208:27;:42;67236:13;67208:42;;;;;;;;;;;;67201:49;;67103:153;;;:::o;66683:135::-;6607:9;:7;:9::i;:::-;6599:54;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;66793:18;66769:10;;:43;;;;;;;;;;;;;;;;;;66683:135;:::o;66844:118::-;66910:4;66930:16;:26;66947:8;66930:26;;;;;;;;;;;;;;;;;;;;;;;;;66923:33;;66844:118;;;:::o;67467:509::-;4791:7;;;;;;;;;;;4790:8;4782:37;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;65555:1;65538:13;;:18;;;;;;;;;;;65567:20;65590:13;;65567:36;;67735:1;67695:10;;;;;;;;;;;:25;;;67721:10;67695:37;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;67695:37:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;67695:37:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;67695:37:0;;;;;;;;;;;;;;;;:41;67687:50;;;;;;;;67752:16;:28;67769:10;67752:28;;;;;;;;;;;;;;;;;;;;;;;;;67744:37;;;;;;;;67826:9;67788:22;:34;67811:10;67788:34;;;;;;;;;;;;;;;;:47;;;;;;;;;;;67910:11;67849:121;;67872:10;67849:121;;;67891:10;67930:9;67948:15;67849:121;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;65650:13;;65634:12;:29;65626:38;;;;;;;;4830:1;67467:509;;:::o;7501:109::-;6607:9;:7;:9::i;:::-;6599:54;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;7574:28;7593:8;7574:18;:28::i;:::-;7501:109;:::o;66968:129::-;6607:9;:7;:9::i;:::-;6599:54;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;67084:7;67055:16;:26;67072:8;67055:26;;;;;;;;;;;;;;;;:36;;;;;;;;;;;;;;;;;;66968:129;;:::o;866:98::-;911:15;946:10;939:17;;866:98;:::o;2075:203::-;2147:4;2191:1;2172:21;;:7;:21;;;;2164:68;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;2250:4;:11;;:20;2262:7;2250:20;;;;;;;;;;;;;;;;;;;;;;;;;2243:27;;2075:203;;;;:::o;3252:130::-;3312:24;3328:7;3312:8;:15;;:24;;;;:::i;:::-;3366:7;3352:22;;;;;;;;;;;;3252:130;:::o;3122:122::-;3179:21;3192:7;3179:8;:12;;:21;;;;:::i;:::-;3228:7;3216:20;;;;;;;;;;;;3122:122;:::o;7716:229::-;7810:1;7790:22;;:8;:22;;;;7782:73;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;7900:8;7871:38;;7892:6;;;;;;;;;;;7871:38;;;;;;;;;;;;7929:8;7920:6;;:17;;;;;;;;;;;;;;;;;;7716:229;:::o;1797:183::-;1877:18;1881:4;1887:7;1877:3;:18::i;:::-;1869:64;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;1967:5;1944:4;:11;;:20;1956:7;1944:20;;;;;;;;;;;;;;;;:28;;;;;;;;;;;;;;;;;;1797:183;;:::o;1539:178::-;1617:18;1621:4;1627:7;1617:3;:18::i;:::-;1616:19;1608:63;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;1705:4;1682;:11;;:20;1694:7;1682:20;;;;;;;;;;;;;;;;:27;;;;;;;;;;;;;;;;;;1539:178;;:::o
Swarm Source
bzzr://016740467952be8fb3f852d88b57f427ca0914dff1c00c1806eb2d7dc66cca60
Loading...
Loading
Loading...
Loading
Multichain Portfolio | 25 Chains
Chain | Token | Portfolio % | Price | Amount | Value |
---|---|---|---|---|---|
ETH | Ether (ETH) | 100.00% | $3,103.12 | 6.5692 | $20,385.05 |
Loading...
Loading
[ Download: CSV Export ]
[ Download: CSV Export ]
A contract address hosts a smart contract, which is a set of code stored on the blockchain that runs when predetermined conditions are met. Learn more about addresses in our Knowledge Base.