ETH Price: $3,622.82 (+9.03%)

Contract

0x7194d3EdeC8a6E814553a1700a58482C3867D871
 

Overview

ETH Balance

0 ETH

Eth Value

$0.00

Multichain Info

No addresses found
Transaction Hash
Method
Block
From
To
Claim154351502022-08-29 16:25:55821 days ago1661790355IN
0x7194d3Ed...C3867D871
0 ETH0.001890420.00792404
Claim153384542022-08-14 7:39:40836 days ago1660462780IN
0x7194d3Ed...C3867D871
0 ETH0.000474755.20286863
Claim153384352022-08-14 7:36:29836 days ago1660462589IN
0x7194d3Ed...C3867D871
0 ETH0.000492625.39865741
Claim152912812022-08-06 21:52:20843 days ago1659822740IN
0x7194d3Ed...C3867D871
0 ETH0.0014193212.09870521
Claim152867212022-08-06 4:52:18844 days ago1659761538IN
0x7194d3Ed...C3867D871
0 ETH0.0014333910
Claim152728352022-08-04 0:59:12846 days ago1659574752IN
0x7194d3Ed...C3867D871
0 ETH0.000505036.5264381
Claim152601122022-08-02 1:16:03848 days ago1659402963IN
0x7194d3Ed...C3867D871
0 ETH0.0012258913.43459416
Claim152383592022-07-29 16:09:13852 days ago1659110953IN
0x7194d3Ed...C3867D871
0 ETH0.0063866252.09146056
Claim152092532022-07-25 3:19:50856 days ago1658719190IN
0x7194d3Ed...C3867D871
0 ETH0.001688789.44629033
Claim152070232022-07-24 18:53:29857 days ago1658688809IN
0x7194d3Ed...C3867D871
0 ETH0.0010894711.93955226
Claim152014952022-07-23 21:56:00857 days ago1658613360IN
0x7194d3Ed...C3867D871
0 ETH0.0021642117.1381124
Claim151948342022-07-22 21:16:07858 days ago1658524567IN
0x7194d3Ed...C3867D871
0 ETH0.001142939.74272316
Claim151890012022-07-21 23:41:23859 days ago1658446883IN
0x7194d3Ed...C3867D871
0 ETH0.0029717531.45282462
Claim151771692022-07-20 3:37:43861 days ago1658288263IN
0x7194d3Ed...C3867D871
0 ETH0.0022904417.6344396
Claim151761262022-07-19 23:47:40861 days ago1658274460IN
0x7194d3Ed...C3867D871
0 ETH0.0019059520.17251504
Claim151747092022-07-19 18:32:10862 days ago1658255530IN
0x7194d3Ed...C3867D871
0 ETH0.004683727.642583
Claim151722182022-07-19 9:20:05862 days ago1658222405IN
0x7194d3Ed...C3867D871
0 ETH0.003252339.61334099
Claim151703222022-07-19 2:19:04862 days ago1658197144IN
0x7194d3Ed...C3867D871
0 ETH0.0031767821.30651804
Claim151628182022-07-17 22:30:57863 days ago1658097057IN
0x7194d3Ed...C3867D871
0 ETH0.0073492319.99448461
Claim151606452022-07-17 14:16:06864 days ago1658067366IN
0x7194d3Ed...C3867D871
0 ETH0.0079420327.922835
Claim151604712022-07-17 13:37:45864 days ago1658065065IN
0x7194d3Ed...C3867D871
0 ETH0.0036547416.81747499
Claim151558042022-07-16 20:16:13865 days ago1658002573IN
0x7194d3Ed...C3867D871
0 ETH0.0020675313.04758645
Claim151520102022-07-16 6:05:04865 days ago1657951504IN
0x7194d3Ed...C3867D871
0 ETH0.0009729510.29768732
Claim151496992022-07-15 21:26:49865 days ago1657920409IN
0x7194d3Ed...C3867D871
0 ETH0.0027047529.64144662
Claim151469402022-07-15 11:20:04866 days ago1657884004IN
0x7194d3Ed...C3867D871
0 ETH0.0039876126.31240882
View all transactions

View more zero value Internal Transactions in Advanced View mode

Advanced mode:
Loading...
Loading

Contract Source Code Verified (Exact Match)

Contract Name:
WNS_Pass_Claim

Compiler Version
v0.8.4+commit.c7e474f2

Optimization Enabled:
Yes with 1500 runs

Other Settings:
default evmVersion
File 1 of 11 : WNS_Pass_Claim.sol
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.2;

import "@openzeppelin/contracts/access/Ownable.sol";
import "@openzeppelin/contracts/token/ERC721/IERC721.sol";
import "@openzeppelin/contracts/security/ReentrancyGuard.sol";

import "./IWNS_Passes.sol";
import "./INFTW_Escrow.sol";

contract WNS_Pass_Claim is Ownable, ReentrancyGuard {
  IWNS_Passes immutable wnsPasses;
  INFTWEscrow immutable nftwEscrow;
  IERC721 immutable nftw;
  IERC721 immutable avatars;
  IERC721 immutable grayboys;

  uint256 private constant PREREGISTRATION_PASS_TYPE_ID = 2;

  mapping(uint256 => bool) public worldsClaimed;
  mapping(uint256 => bool) public avatarsClaimed;
  mapping(uint256 => bool) public graysboysClaimed;

  bool public secondClaimEnabled = false;

  constructor(address _wnsPasses, address _nftw, address _nftwEscrow, address _avatars, address _grayboys) {
    wnsPasses = IWNS_Passes(_wnsPasses);
    nftw = IERC721(_nftw);
    nftwEscrow = INFTWEscrow(_nftwEscrow);
    avatars = IERC721(_avatars);
    grayboys = IERC721(_grayboys);
  }

  function claim(uint256[] calldata _worldIds, uint256[] calldata _avatarIds, uint256[] calldata _grayboyIds) external nonReentrant {
    uint256 claimTotal = 0;

    for (uint256 i = 0; i < _worldIds.length; i++) {
      uint256 worldId = _worldIds[i];

      INFTWEscrow.WorldInfo memory worldInfo = nftwEscrow.getWorldInfo(worldId);

      require(nftw.ownerOf(worldId) == msg.sender || worldInfo.owner == msg.sender, "Claimer is not owner");
      require(!worldsClaimed[worldId], "Pass already claimed for world");

      worldsClaimed[worldId] = true;
      claimTotal++;
    }

    if (_avatarIds.length > 0 || _grayboyIds.length > 0) {
      require(secondClaimEnabled, "Second claim for avatars and gray boys is not yet enabled.");

      for (uint256 i = 0; i < _avatarIds.length; i++) {
        uint256 avatarId = _avatarIds[i];

        require(avatars.ownerOf(avatarId) == msg.sender, "Claimer is not owner");
        require(!avatarsClaimed[avatarId], "Pass already claimed for avatar");

        avatarsClaimed[avatarId] = true;
        claimTotal++;
      }

      for (uint256 i = 0; i < _grayboyIds.length; i++) {
        uint256 grayboyId = _grayboyIds[i];

        require(grayboys.ownerOf(grayboyId) == msg.sender, "Claimer is not owner");
        require(!graysboysClaimed[grayboyId], "Pass already claimed for gray boy");

        graysboysClaimed[grayboyId] = true;
        claimTotal++;
      }
    }

    if (claimTotal > 0) {
      wnsPasses.mintTypeToAddress(PREREGISTRATION_PASS_TYPE_ID, claimTotal, msg.sender);
    }
  }

  function toggleSecondClaim(bool _enabled) external onlyOwner {
    secondClaimEnabled = _enabled;
  }
}

File 2 of 11 : Ownable.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.1 (access/Ownable.sol)

pragma solidity ^0.8.0;

import "../utils/Context.sol";

/**
 * @dev Contract module which provides a basic access control mechanism, where
 * there is an account (an owner) that can be granted exclusive access to
 * specific functions.
 *
 * By default, the owner account will be the one that deploys the contract. This
 * can later be changed with {transferOwnership}.
 *
 * This module is used through inheritance. It will make available the modifier
 * `onlyOwner`, which can be applied to your functions to restrict their use to
 * the owner.
 */
abstract contract Ownable is Context {
    address private _owner;

    event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);

    /**
     * @dev Initializes the contract setting the deployer as the initial owner.
     */
    constructor() {
        _transferOwnership(_msgSender());
    }

    /**
     * @dev Returns the address of the current owner.
     */
    function owner() public view virtual returns (address) {
        return _owner;
    }

    /**
     * @dev Throws if called by any account other than the owner.
     */
    modifier onlyOwner() {
        require(owner() == _msgSender(), "Ownable: caller is not the owner");
        _;
    }

    /**
     * @dev Leaves the contract without owner. It will not be possible to call
     * `onlyOwner` functions anymore. Can only be called by the current owner.
     *
     * NOTE: Renouncing ownership will leave the contract without an owner,
     * thereby removing any functionality that is only available to the owner.
     */
    function renounceOwnership() public virtual onlyOwner {
        _transferOwnership(address(0));
    }

    /**
     * @dev Transfers ownership of the contract to a new account (`newOwner`).
     * Can only be called by the current owner.
     */
    function transferOwnership(address newOwner) public virtual onlyOwner {
        require(newOwner != address(0), "Ownable: new owner is the zero address");
        _transferOwnership(newOwner);
    }

    /**
     * @dev Transfers ownership of the contract to a new account (`newOwner`).
     * Internal function without access restriction.
     */
    function _transferOwnership(address newOwner) internal virtual {
        address oldOwner = _owner;
        _owner = newOwner;
        emit OwnershipTransferred(oldOwner, newOwner);
    }
}

File 3 of 11 : IERC721.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v4.6.0) (token/ERC721/IERC721.sol)

pragma solidity ^0.8.0;

import "../../utils/introspection/IERC165.sol";

/**
 * @dev Required interface of an ERC721 compliant contract.
 */
interface IERC721 is IERC165 {
    /**
     * @dev Emitted when `tokenId` token is transferred from `from` to `to`.
     */
    event Transfer(address indexed from, address indexed to, uint256 indexed tokenId);

    /**
     * @dev Emitted when `owner` enables `approved` to manage the `tokenId` token.
     */
    event Approval(address indexed owner, address indexed approved, uint256 indexed tokenId);

    /**
     * @dev Emitted when `owner` enables or disables (`approved`) `operator` to manage all of its assets.
     */
    event ApprovalForAll(address indexed owner, address indexed operator, bool approved);

    /**
     * @dev Returns the number of tokens in ``owner``'s account.
     */
    function balanceOf(address owner) external view returns (uint256 balance);

    /**
     * @dev Returns the owner of the `tokenId` token.
     *
     * Requirements:
     *
     * - `tokenId` must exist.
     */
    function ownerOf(uint256 tokenId) external view returns (address owner);

    /**
     * @dev Safely transfers `tokenId` token from `from` to `to`.
     *
     * Requirements:
     *
     * - `from` cannot be the zero address.
     * - `to` cannot be the zero address.
     * - `tokenId` token must exist and be owned by `from`.
     * - If the caller is not `from`, it must be approved to move this token by either {approve} or {setApprovalForAll}.
     * - If `to` refers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called upon a safe transfer.
     *
     * Emits a {Transfer} event.
     */
    function safeTransferFrom(
        address from,
        address to,
        uint256 tokenId,
        bytes calldata data
    ) external;

    /**
     * @dev Safely transfers `tokenId` token from `from` to `to`, checking first that contract recipients
     * are aware of the ERC721 protocol to prevent tokens from being forever locked.
     *
     * Requirements:
     *
     * - `from` cannot be the zero address.
     * - `to` cannot be the zero address.
     * - `tokenId` token must exist and be owned by `from`.
     * - If the caller is not `from`, it must be have been allowed to move this token by either {approve} or {setApprovalForAll}.
     * - If `to` refers to a smart contract, it must implement {IERC721Receiver-onERC721Received}, which is called upon a safe transfer.
     *
     * Emits a {Transfer} event.
     */
    function safeTransferFrom(
        address from,
        address to,
        uint256 tokenId
    ) external;

    /**
     * @dev Transfers `tokenId` token from `from` to `to`.
     *
     * WARNING: Usage of this method is discouraged, use {safeTransferFrom} whenever possible.
     *
     * Requirements:
     *
     * - `from` cannot be the zero address.
     * - `to` cannot be the zero address.
     * - `tokenId` token must be owned by `from`.
     * - If the caller is not `from`, it must be approved to move this token by either {approve} or {setApprovalForAll}.
     *
     * Emits a {Transfer} event.
     */
    function transferFrom(
        address from,
        address to,
        uint256 tokenId
    ) external;

    /**
     * @dev Gives permission to `to` to transfer `tokenId` token to another account.
     * The approval is cleared when the token is transferred.
     *
     * Only a single account can be approved at a time, so approving the zero address clears previous approvals.
     *
     * Requirements:
     *
     * - The caller must own the token or be an approved operator.
     * - `tokenId` must exist.
     *
     * Emits an {Approval} event.
     */
    function approve(address to, uint256 tokenId) external;

    /**
     * @dev Approve or remove `operator` as an operator for the caller.
     * Operators can call {transferFrom} or {safeTransferFrom} for any token owned by the caller.
     *
     * Requirements:
     *
     * - The `operator` cannot be the caller.
     *
     * Emits an {ApprovalForAll} event.
     */
    function setApprovalForAll(address operator, bool _approved) external;

    /**
     * @dev Returns the account approved for `tokenId` token.
     *
     * Requirements:
     *
     * - `tokenId` must exist.
     */
    function getApproved(uint256 tokenId) external view returns (address operator);

    /**
     * @dev Returns if the `operator` is allowed to manage all of the assets of `owner`.
     *
     * See {setApprovalForAll}
     */
    function isApprovedForAll(address owner, address operator) external view returns (bool);
}

File 4 of 11 : ReentrancyGuard.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.1 (security/ReentrancyGuard.sol)

pragma solidity ^0.8.0;

/**
 * @dev Contract module that helps prevent reentrant calls to a function.
 *
 * Inheriting from `ReentrancyGuard` will make the {nonReentrant} modifier
 * available, which can be applied to functions to make sure there are no nested
 * (reentrant) calls to them.
 *
 * Note that because there is a single `nonReentrant` guard, functions marked as
 * `nonReentrant` may not call one another. This can be worked around by making
 * those functions `private`, and then adding `external` `nonReentrant` entry
 * points to them.
 *
 * TIP: If you would like to learn more about reentrancy and alternative ways
 * to protect against it, check out our blog post
 * https://blog.openzeppelin.com/reentrancy-after-istanbul/[Reentrancy After Istanbul].
 */
abstract contract ReentrancyGuard {
    // Booleans are more expensive than uint256 or any type that takes up a full
    // word because each write operation emits an extra SLOAD to first read the
    // slot's contents, replace the bits taken up by the boolean, and then write
    // back. This is the compiler's defense against contract upgrades and
    // pointer aliasing, and it cannot be disabled.

    // The values being non-zero value makes deployment a bit more expensive,
    // but in exchange the refund on every call to nonReentrant will be lower in
    // amount. Since refunds are capped to a percentage of the total
    // transaction's gas, it is best to keep them low in cases like this one, to
    // increase the likelihood of the full refund coming into effect.
    uint256 private constant _NOT_ENTERED = 1;
    uint256 private constant _ENTERED = 2;

    uint256 private _status;

    constructor() {
        _status = _NOT_ENTERED;
    }

    /**
     * @dev Prevents a contract from calling itself, directly or indirectly.
     * Calling a `nonReentrant` function from another `nonReentrant`
     * function is not supported. It is possible to prevent this from happening
     * by making the `nonReentrant` function external, and making it call a
     * `private` function that does the actual work.
     */
    modifier nonReentrant() {
        // On the first call to nonReentrant, _notEntered will be true
        require(_status != _ENTERED, "ReentrancyGuard: reentrant call");

        // Any calls to nonReentrant after this point will fail
        _status = _ENTERED;

        _;

        // By storing the original value once again, a refund is triggered (see
        // https://eips.ethereum.org/EIPS/eip-2200)
        _status = _NOT_ENTERED;
    }
}

File 5 of 11 : IWNS_Passes.sol
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.2;

import "@openzeppelin/contracts/token/ERC1155/IERC1155.sol";

interface IWNS_Passes is IERC1155 {
  function burnTypeBulk(uint256 _typeId, address[] calldata owners) external;
  function burnTypeForOwnerAddress(uint256 _typeId, uint256 _quantity, address _typeOwnerAddress) external returns (bool);
  function mintTypeToAddress(uint256 _typeId, uint256 _quantity, address _toAddress) external returns (bool);
  function bulkSafeTransfer(uint256 _typeId, uint256 _quantityPerRecipient, address[] calldata recipients) external;
}

File 6 of 11 : INFTW_Escrow.sol
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.2;

import "@openzeppelin/contracts/token/ERC721/IERC721Receiver.sol";
import "@openzeppelin/contracts/utils/introspection/IERC165.sol";
import "@openzeppelin/contracts/token/ERC20/IERC20.sol";

interface INFTWEscrow is IERC165, IERC20, IERC721Receiver {
    event WeightUpdated(address indexed user, bool increase, uint weight, uint timestamp);
    event WorldStaked(uint256 indexed tokenId, address indexed user);
    event WorldUnstaked(uint256 indexed tokenId, address indexed user);

    event RewardsSet(uint32 start, uint32 end, uint256 rate);
    event RewardsUpdated(uint32 start, uint32 end, uint256 rate);
    event RewardsPerWeightUpdated(uint256 accumulated);
    event UserRewardsUpdated(address user, uint256 userRewards, uint256 paidRewardPerWeight);
    event RewardClaimed(address receiver, uint256 claimed);

    struct WorldInfo {
        uint16 weight;          // weight based on rarity
        address owner;          // staked to, otherwise owner == 0
        uint16 deposit;         // unit is ether, paid in WRLD. The deposit is deducted from the last payment(s) since the deposit is non-custodial
        uint16 rentalPerDay;    // unit is ether, paid in WRLD. Total is deposit + rentalPerDay * days
        uint16 minRentDays;     // must rent for at least min rent days, otherwise deposit is forfeited up to this amount
        uint32 rentableUntil;   // timestamp in unix epoch
    }

    struct RewardsPeriod {
        uint32 start;           // reward start time, in unix epoch
        uint32 end;             // reward end time, in unix epoch
    }

    struct RewardsPerWeight {
        uint32 totalWeight;
        uint96 accumulated;
        uint32 lastUpdated;
        uint96 rate;
    }

    struct UserRewards {
        uint32 stakedWeight;
        uint96 accumulated;
        uint96 checkpoint;
    }

    // view functions
    function getWorldInfo(uint tokenId) external view returns(WorldInfo memory);
    function checkUserRewards(address user) external view returns(uint);
    function onERC721Received(address, address, uint256, bytes calldata) external view override returns(bytes4);

    // public functions
    function initialStake(uint[] calldata tokenIds, uint[] calldata weights, address stakeTo,
        uint16 _deposit, uint16 _rentalPerDay, uint16 _minRentDays, uint32 _rentableUntil, uint32 _maxTimestamp, bytes calldata _signature)
        external;

    function stake(uint[] calldata tokenIds, address stakeTo,
        uint16 _deposit, uint16 _rentalPerDay, uint16 _minRentDays, uint32 _rentableUntil)
        external;

    function updateRent(uint[] calldata tokenIds,
        uint16 _deposit, uint16 _rentalPerDay, uint16 _minRentDays, uint32 _rentableUntil)
        external;

    function extendRentalPeriod(uint tokenId, uint32 _rentableUntil) external;

    function unstake(uint[] calldata tokenIds, address unstakeTo) external;

    function claim(address to) external;
}

File 7 of 11 : Context.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.1 (utils/Context.sol)

pragma solidity ^0.8.0;

/**
 * @dev Provides information about the current execution context, including the
 * sender of the transaction and its data. While these are generally available
 * via msg.sender and msg.data, they should not be accessed in such a direct
 * manner, since when dealing with meta-transactions the account sending and
 * paying for execution may not be the actual sender (as far as an application
 * is concerned).
 *
 * This contract is only required for intermediate, library-like contracts.
 */
abstract contract Context {
    function _msgSender() internal view virtual returns (address) {
        return msg.sender;
    }

    function _msgData() internal view virtual returns (bytes calldata) {
        return msg.data;
    }
}

File 8 of 11 : IERC165.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.1 (utils/introspection/IERC165.sol)

pragma solidity ^0.8.0;

/**
 * @dev Interface of the ERC165 standard, as defined in the
 * https://eips.ethereum.org/EIPS/eip-165[EIP].
 *
 * Implementers can declare support of contract interfaces, which can then be
 * queried by others ({ERC165Checker}).
 *
 * For an implementation, see {ERC165}.
 */
interface IERC165 {
    /**
     * @dev Returns true if this contract implements the interface defined by
     * `interfaceId`. See the corresponding
     * https://eips.ethereum.org/EIPS/eip-165#how-interfaces-are-identified[EIP section]
     * to learn more about how these ids are created.
     *
     * This function call must use less than 30 000 gas.
     */
    function supportsInterface(bytes4 interfaceId) external view returns (bool);
}

File 9 of 11 : IERC1155.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.1 (token/ERC1155/IERC1155.sol)

pragma solidity ^0.8.0;

import "../../utils/introspection/IERC165.sol";

/**
 * @dev Required interface of an ERC1155 compliant contract, as defined in the
 * https://eips.ethereum.org/EIPS/eip-1155[EIP].
 *
 * _Available since v3.1._
 */
interface IERC1155 is IERC165 {
    /**
     * @dev Emitted when `value` tokens of token type `id` are transferred from `from` to `to` by `operator`.
     */
    event TransferSingle(address indexed operator, address indexed from, address indexed to, uint256 id, uint256 value);

    /**
     * @dev Equivalent to multiple {TransferSingle} events, where `operator`, `from` and `to` are the same for all
     * transfers.
     */
    event TransferBatch(
        address indexed operator,
        address indexed from,
        address indexed to,
        uint256[] ids,
        uint256[] values
    );

    /**
     * @dev Emitted when `account` grants or revokes permission to `operator` to transfer their tokens, according to
     * `approved`.
     */
    event ApprovalForAll(address indexed account, address indexed operator, bool approved);

    /**
     * @dev Emitted when the URI for token type `id` changes to `value`, if it is a non-programmatic URI.
     *
     * If an {URI} event was emitted for `id`, the standard
     * https://eips.ethereum.org/EIPS/eip-1155#metadata-extensions[guarantees] that `value` will equal the value
     * returned by {IERC1155MetadataURI-uri}.
     */
    event URI(string value, uint256 indexed id);

    /**
     * @dev Returns the amount of tokens of token type `id` owned by `account`.
     *
     * Requirements:
     *
     * - `account` cannot be the zero address.
     */
    function balanceOf(address account, uint256 id) external view returns (uint256);

    /**
     * @dev xref:ROOT:erc1155.adoc#batch-operations[Batched] version of {balanceOf}.
     *
     * Requirements:
     *
     * - `accounts` and `ids` must have the same length.
     */
    function balanceOfBatch(address[] calldata accounts, uint256[] calldata ids)
        external
        view
        returns (uint256[] memory);

    /**
     * @dev Grants or revokes permission to `operator` to transfer the caller's tokens, according to `approved`,
     *
     * Emits an {ApprovalForAll} event.
     *
     * Requirements:
     *
     * - `operator` cannot be the caller.
     */
    function setApprovalForAll(address operator, bool approved) external;

    /**
     * @dev Returns true if `operator` is approved to transfer ``account``'s tokens.
     *
     * See {setApprovalForAll}.
     */
    function isApprovedForAll(address account, address operator) external view returns (bool);

    /**
     * @dev Transfers `amount` tokens of token type `id` from `from` to `to`.
     *
     * Emits a {TransferSingle} event.
     *
     * Requirements:
     *
     * - `to` cannot be the zero address.
     * - If the caller is not `from`, it must be have been approved to spend ``from``'s tokens via {setApprovalForAll}.
     * - `from` must have a balance of tokens of type `id` of at least `amount`.
     * - If `to` refers to a smart contract, it must implement {IERC1155Receiver-onERC1155Received} and return the
     * acceptance magic value.
     */
    function safeTransferFrom(
        address from,
        address to,
        uint256 id,
        uint256 amount,
        bytes calldata data
    ) external;

    /**
     * @dev xref:ROOT:erc1155.adoc#batch-operations[Batched] version of {safeTransferFrom}.
     *
     * Emits a {TransferBatch} event.
     *
     * Requirements:
     *
     * - `ids` and `amounts` must have the same length.
     * - If `to` refers to a smart contract, it must implement {IERC1155Receiver-onERC1155BatchReceived} and return the
     * acceptance magic value.
     */
    function safeBatchTransferFrom(
        address from,
        address to,
        uint256[] calldata ids,
        uint256[] calldata amounts,
        bytes calldata data
    ) external;
}

File 10 of 11 : IERC721Receiver.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v4.6.0) (token/ERC721/IERC721Receiver.sol)

pragma solidity ^0.8.0;

/**
 * @title ERC721 token receiver interface
 * @dev Interface for any contract that wants to support safeTransfers
 * from ERC721 asset contracts.
 */
interface IERC721Receiver {
    /**
     * @dev Whenever an {IERC721} `tokenId` token is transferred to this contract via {IERC721-safeTransferFrom}
     * by `operator` from `from`, this function is called.
     *
     * It must return its Solidity selector to confirm the token transfer.
     * If any other value is returned or the interface is not implemented by the recipient, the transfer will be reverted.
     *
     * The selector can be obtained in Solidity with `IERC721Receiver.onERC721Received.selector`.
     */
    function onERC721Received(
        address operator,
        address from,
        uint256 tokenId,
        bytes calldata data
    ) external returns (bytes4);
}

File 11 of 11 : IERC20.sol
// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts (last updated v4.6.0) (token/ERC20/IERC20.sol)

pragma solidity ^0.8.0;

/**
 * @dev Interface of the ERC20 standard as defined in the EIP.
 */
interface IERC20 {
    /**
     * @dev Emitted when `value` tokens are moved from one account (`from`) to
     * another (`to`).
     *
     * Note that `value` may be zero.
     */
    event Transfer(address indexed from, address indexed to, uint256 value);

    /**
     * @dev Emitted when the allowance of a `spender` for an `owner` is set by
     * a call to {approve}. `value` is the new allowance.
     */
    event Approval(address indexed owner, address indexed spender, uint256 value);

    /**
     * @dev Returns the amount of tokens in existence.
     */
    function totalSupply() external view returns (uint256);

    /**
     * @dev Returns the amount of tokens owned by `account`.
     */
    function balanceOf(address account) external view returns (uint256);

    /**
     * @dev Moves `amount` tokens from the caller's account to `to`.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * Emits a {Transfer} event.
     */
    function transfer(address to, uint256 amount) external returns (bool);

    /**
     * @dev Returns the remaining number of tokens that `spender` will be
     * allowed to spend on behalf of `owner` through {transferFrom}. This is
     * zero by default.
     *
     * This value changes when {approve} or {transferFrom} are called.
     */
    function allowance(address owner, address spender) external view returns (uint256);

    /**
     * @dev Sets `amount` as the allowance of `spender` over the caller's tokens.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * IMPORTANT: Beware that changing an allowance with this method brings the risk
     * that someone may use both the old and the new allowance by unfortunate
     * transaction ordering. One possible solution to mitigate this race
     * condition is to first reduce the spender's allowance to 0 and set the
     * desired value afterwards:
     * https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729
     *
     * Emits an {Approval} event.
     */
    function approve(address spender, uint256 amount) external returns (bool);

    /**
     * @dev Moves `amount` tokens from `from` to `to` using the
     * allowance mechanism. `amount` is then deducted from the caller's
     * allowance.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * Emits a {Transfer} event.
     */
    function transferFrom(
        address from,
        address to,
        uint256 amount
    ) external returns (bool);
}

Settings
{
  "optimizer": {
    "enabled": true,
    "runs": 1500
  },
  "outputSelection": {
    "*": {
      "*": [
        "evm.bytecode",
        "evm.deployedBytecode",
        "devdoc",
        "userdoc",
        "metadata",
        "abi"
      ]
    }
  },
  "libraries": {}
}

Contract Security Audit

Contract ABI

[{"inputs":[{"internalType":"address","name":"_wnsPasses","type":"address"},{"internalType":"address","name":"_nftw","type":"address"},{"internalType":"address","name":"_nftwEscrow","type":"address"},{"internalType":"address","name":"_avatars","type":"address"},{"internalType":"address","name":"_grayboys","type":"address"}],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"avatarsClaimed","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256[]","name":"_worldIds","type":"uint256[]"},{"internalType":"uint256[]","name":"_avatarIds","type":"uint256[]"},{"internalType":"uint256[]","name":"_grayboyIds","type":"uint256[]"}],"name":"claim","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"graysboysClaimed","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"secondClaimEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bool","name":"_enabled","type":"bool"}],"name":"toggleSecondClaim","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"worldsClaimed","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"}]

6101206040526005805460ff191690553480156200001c57600080fd5b5060405162001047380380620010478339810160408190526200003f91620000f3565b6200004a3362000086565b600180556001600160601b0319606095861b811660805293851b841660c05291841b831660a052831b821660e05290911b166101005262000162565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b80516001600160a01b0381168114620000ee57600080fd5b919050565b600080600080600060a086880312156200010b578081fd5b6200011686620000d6565b94506200012660208701620000d6565b93506200013660408701620000d6565b92506200014660608701620000d6565b91506200015660808701620000d6565b90509295509295909350565b60805160601c60a05160601c60c05160601c60e05160601c6101005160601c610e91620001b660003960006107f001526000610622015260006103d4015260006102fc015260006109e50152610e916000f3fe608060405234801561001057600080fd5b50600436106100a35760003560e01c80638da5cb5b11610076578063deb78f3b1161005b578063deb78f3b14610138578063f2fde38b1461015b578063f4a851fb1461016e57600080fd5b80638da5cb5b1461010a578063c9684a8d1461012557600080fd5b80630a66701f146100a857806323660008146100bd57806329f3afd7146100df578063715018a614610102575b600080fd5b6100bb6100b6366004610d17565b610191565b005b6005546100ca9060ff1681565b60405190151581526020015b60405180910390f35b6100ca6100ed366004610df9565b60036020526000908152604090205460ff1681565b6100bb610203565b6000546040516001600160a01b0390911681526020016100d6565b6100bb610133366004610c81565b610269565b6100ca610146366004610df9565b60046020526000908152604090205460ff1681565b6100bb610169366004610c42565b610a78565b6100ca61017c366004610df9565b60026020526000908152604090205460ff1681565b6000546001600160a01b031633146101f05760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064015b60405180910390fd5b6005805460ff1916911515919091179055565b6000546001600160a01b0316331461025d5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064016101e7565b6102676000610b5a565b565b600260015414156102bc5760405162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c0060448201526064016101e7565b60026001556000805b868110156105555760008888838181106102ef57634e487b7160e01b600052603260045260246000fd5b90506020020135905060007f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663c19b4ccd836040518263ffffffff1660e01b815260040161034891815260200190565b60c06040518083038186803b15801561036057600080fd5b505afa158015610374573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906103989190610d4f565b6040517f6352211e0000000000000000000000000000000000000000000000000000000081526004810184905290915033906001600160a01b037f00000000000000000000000000000000000000000000000000000000000000001690636352211e9060240160206040518083038186803b15801561041657600080fd5b505afa15801561042a573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061044e9190610c65565b6001600160a01b0316148061046f575060208101516001600160a01b031633145b6104bb5760405162461bcd60e51b815260206004820152601460248201527f436c61696d6572206973206e6f74206f776e657200000000000000000000000060448201526064016101e7565b60008281526002602052604090205460ff161561051a5760405162461bcd60e51b815260206004820152601e60248201527f5061737320616c726561647920636c61696d656420666f7220776f726c64000060448201526064016101e7565b6000828152600260205260409020805460ff191660011790558361053d81610e11565b9450505050808061054d90610e11565b9150506102c5565b508315158061056357508115155b156109a35760055460ff166105e05760405162461bcd60e51b815260206004820152603a60248201527f5365636f6e6420636c61696d20666f72206176617461727320616e642067726160448201527f7920626f7973206973206e6f742079657420656e61626c65642e00000000000060648201526084016101e7565b60005b848110156107ad57600086868381811061060d57634e487b7160e01b600052603260045260246000fd5b905060200201359050336001600160a01b03167f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316636352211e836040518263ffffffff1660e01b815260040161066e91815260200190565b60206040518083038186803b15801561068657600080fd5b505afa15801561069a573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906106be9190610c65565b6001600160a01b0316146107145760405162461bcd60e51b815260206004820152601460248201527f436c61696d6572206973206e6f74206f776e657200000000000000000000000060448201526064016101e7565b60008181526003602052604090205460ff16156107735760405162461bcd60e51b815260206004820152601f60248201527f5061737320616c726561647920636c61696d656420666f72206176617461720060448201526064016101e7565b6000818152600360205260409020805460ff191660011790558261079681610e11565b9350505080806107a590610e11565b9150506105e3565b5060005b828110156109a15760008484838181106107db57634e487b7160e01b600052603260045260246000fd5b905060200201359050336001600160a01b03167f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316636352211e836040518263ffffffff1660e01b815260040161083c91815260200190565b60206040518083038186803b15801561085457600080fd5b505afa158015610868573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061088c9190610c65565b6001600160a01b0316146108e25760405162461bcd60e51b815260206004820152601460248201527f436c61696d6572206973206e6f74206f776e657200000000000000000000000060448201526064016101e7565b60008181526004602052604090205460ff16156109675760405162461bcd60e51b815260206004820152602160248201527f5061737320616c726561647920636c61696d656420666f72206772617920626f60448201527f790000000000000000000000000000000000000000000000000000000000000060648201526084016101e7565b6000818152600460205260409020805460ff191660011790558261098a81610e11565b93505050808061099990610e11565b9150506107b1565b505b8015610a6b576040517f8c791c0f00000000000000000000000000000000000000000000000000000000815260026004820152602481018290523360448201527f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031690638c791c0f90606401602060405180830381600087803b158015610a3157600080fd5b505af1158015610a45573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610a699190610d33565b505b5050600180555050505050565b6000546001600160a01b03163314610ad25760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064016101e7565b6001600160a01b038116610b4e5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201527f646472657373000000000000000000000000000000000000000000000000000060648201526084016101e7565b610b5781610b5a565b50565b600080546001600160a01b038381167fffffffffffffffffffffffff0000000000000000000000000000000000000000831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b8051610bcd81610e38565b919050565b60008083601f840112610be3578182fd5b50813567ffffffffffffffff811115610bfa578182fd5b6020830191508360208260051b8501011115610c1557600080fd5b9250929050565b805161ffff81168114610bcd57600080fd5b805163ffffffff81168114610bcd57600080fd5b600060208284031215610c53578081fd5b8135610c5e81610e38565b9392505050565b600060208284031215610c76578081fd5b8151610c5e81610e38565b60008060008060008060608789031215610c99578182fd5b863567ffffffffffffffff80821115610cb0578384fd5b610cbc8a838b01610bd2565b90985096506020890135915080821115610cd4578384fd5b610ce08a838b01610bd2565b90965094506040890135915080821115610cf8578384fd5b50610d0589828a01610bd2565b979a9699509497509295939492505050565b600060208284031215610d28578081fd5b8135610c5e81610e4d565b600060208284031215610d44578081fd5b8151610c5e81610e4d565b600060c08284031215610d60578081fd5b60405160c0810181811067ffffffffffffffff82111715610d8f57634e487b7160e01b83526041600452602483fd5b604052610d9b83610c1c565b8152610da960208401610bc2565b6020820152610dba60408401610c1c565b6040820152610dcb60608401610c1c565b6060820152610ddc60808401610c1c565b6080820152610ded60a08401610c2e565b60a08201529392505050565b600060208284031215610e0a578081fd5b5035919050565b6000600019821415610e3157634e487b7160e01b81526011600452602481fd5b5060010190565b6001600160a01b0381168114610b5757600080fd5b8015158114610b5757600080fdfea26469706673582212201f1193b3b27b082f98a805d90ec2465747b7eb29a458ecbf034d06421ebe65e964736f6c63430008040033000000000000000000000000605757a5cceb44ced7a5be421735e0151333c338000000000000000000000000bd4455da5929d5639ee098abfaa3241e9ae111af00000000000000000000000069f0b8c5e94f6b64d832b7d9b15f3a88cb2f6f4b00000000000000000000000005745e72fb8b4a9b51118a168d956760e4a364440000000000000000000000008d4100897447d173289560bc85c5c432be4f44e4

Deployed Bytecode

0x608060405234801561001057600080fd5b50600436106100a35760003560e01c80638da5cb5b11610076578063deb78f3b1161005b578063deb78f3b14610138578063f2fde38b1461015b578063f4a851fb1461016e57600080fd5b80638da5cb5b1461010a578063c9684a8d1461012557600080fd5b80630a66701f146100a857806323660008146100bd57806329f3afd7146100df578063715018a614610102575b600080fd5b6100bb6100b6366004610d17565b610191565b005b6005546100ca9060ff1681565b60405190151581526020015b60405180910390f35b6100ca6100ed366004610df9565b60036020526000908152604090205460ff1681565b6100bb610203565b6000546040516001600160a01b0390911681526020016100d6565b6100bb610133366004610c81565b610269565b6100ca610146366004610df9565b60046020526000908152604090205460ff1681565b6100bb610169366004610c42565b610a78565b6100ca61017c366004610df9565b60026020526000908152604090205460ff1681565b6000546001600160a01b031633146101f05760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064015b60405180910390fd5b6005805460ff1916911515919091179055565b6000546001600160a01b0316331461025d5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064016101e7565b6102676000610b5a565b565b600260015414156102bc5760405162461bcd60e51b815260206004820152601f60248201527f5265656e7472616e637947756172643a207265656e7472616e742063616c6c0060448201526064016101e7565b60026001556000805b868110156105555760008888838181106102ef57634e487b7160e01b600052603260045260246000fd5b90506020020135905060007f00000000000000000000000069f0b8c5e94f6b64d832b7d9b15f3a88cb2f6f4b6001600160a01b031663c19b4ccd836040518263ffffffff1660e01b815260040161034891815260200190565b60c06040518083038186803b15801561036057600080fd5b505afa158015610374573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906103989190610d4f565b6040517f6352211e0000000000000000000000000000000000000000000000000000000081526004810184905290915033906001600160a01b037f000000000000000000000000bd4455da5929d5639ee098abfaa3241e9ae111af1690636352211e9060240160206040518083038186803b15801561041657600080fd5b505afa15801561042a573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061044e9190610c65565b6001600160a01b0316148061046f575060208101516001600160a01b031633145b6104bb5760405162461bcd60e51b815260206004820152601460248201527f436c61696d6572206973206e6f74206f776e657200000000000000000000000060448201526064016101e7565b60008281526002602052604090205460ff161561051a5760405162461bcd60e51b815260206004820152601e60248201527f5061737320616c726561647920636c61696d656420666f7220776f726c64000060448201526064016101e7565b6000828152600260205260409020805460ff191660011790558361053d81610e11565b9450505050808061054d90610e11565b9150506102c5565b508315158061056357508115155b156109a35760055460ff166105e05760405162461bcd60e51b815260206004820152603a60248201527f5365636f6e6420636c61696d20666f72206176617461727320616e642067726160448201527f7920626f7973206973206e6f742079657420656e61626c65642e00000000000060648201526084016101e7565b60005b848110156107ad57600086868381811061060d57634e487b7160e01b600052603260045260246000fd5b905060200201359050336001600160a01b03167f00000000000000000000000005745e72fb8b4a9b51118a168d956760e4a364446001600160a01b0316636352211e836040518263ffffffff1660e01b815260040161066e91815260200190565b60206040518083038186803b15801561068657600080fd5b505afa15801561069a573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906106be9190610c65565b6001600160a01b0316146107145760405162461bcd60e51b815260206004820152601460248201527f436c61696d6572206973206e6f74206f776e657200000000000000000000000060448201526064016101e7565b60008181526003602052604090205460ff16156107735760405162461bcd60e51b815260206004820152601f60248201527f5061737320616c726561647920636c61696d656420666f72206176617461720060448201526064016101e7565b6000818152600360205260409020805460ff191660011790558261079681610e11565b9350505080806107a590610e11565b9150506105e3565b5060005b828110156109a15760008484838181106107db57634e487b7160e01b600052603260045260246000fd5b905060200201359050336001600160a01b03167f0000000000000000000000008d4100897447d173289560bc85c5c432be4f44e46001600160a01b0316636352211e836040518263ffffffff1660e01b815260040161083c91815260200190565b60206040518083038186803b15801561085457600080fd5b505afa158015610868573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061088c9190610c65565b6001600160a01b0316146108e25760405162461bcd60e51b815260206004820152601460248201527f436c61696d6572206973206e6f74206f776e657200000000000000000000000060448201526064016101e7565b60008181526004602052604090205460ff16156109675760405162461bcd60e51b815260206004820152602160248201527f5061737320616c726561647920636c61696d656420666f72206772617920626f60448201527f790000000000000000000000000000000000000000000000000000000000000060648201526084016101e7565b6000818152600460205260409020805460ff191660011790558261098a81610e11565b93505050808061099990610e11565b9150506107b1565b505b8015610a6b576040517f8c791c0f00000000000000000000000000000000000000000000000000000000815260026004820152602481018290523360448201527f000000000000000000000000605757a5cceb44ced7a5be421735e0151333c3386001600160a01b031690638c791c0f90606401602060405180830381600087803b158015610a3157600080fd5b505af1158015610a45573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610a699190610d33565b505b5050600180555050505050565b6000546001600160a01b03163314610ad25760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064016101e7565b6001600160a01b038116610b4e5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201527f646472657373000000000000000000000000000000000000000000000000000060648201526084016101e7565b610b5781610b5a565b50565b600080546001600160a01b038381167fffffffffffffffffffffffff0000000000000000000000000000000000000000831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b8051610bcd81610e38565b919050565b60008083601f840112610be3578182fd5b50813567ffffffffffffffff811115610bfa578182fd5b6020830191508360208260051b8501011115610c1557600080fd5b9250929050565b805161ffff81168114610bcd57600080fd5b805163ffffffff81168114610bcd57600080fd5b600060208284031215610c53578081fd5b8135610c5e81610e38565b9392505050565b600060208284031215610c76578081fd5b8151610c5e81610e38565b60008060008060008060608789031215610c99578182fd5b863567ffffffffffffffff80821115610cb0578384fd5b610cbc8a838b01610bd2565b90985096506020890135915080821115610cd4578384fd5b610ce08a838b01610bd2565b90965094506040890135915080821115610cf8578384fd5b50610d0589828a01610bd2565b979a9699509497509295939492505050565b600060208284031215610d28578081fd5b8135610c5e81610e4d565b600060208284031215610d44578081fd5b8151610c5e81610e4d565b600060c08284031215610d60578081fd5b60405160c0810181811067ffffffffffffffff82111715610d8f57634e487b7160e01b83526041600452602483fd5b604052610d9b83610c1c565b8152610da960208401610bc2565b6020820152610dba60408401610c1c565b6040820152610dcb60608401610c1c565b6060820152610ddc60808401610c1c565b6080820152610ded60a08401610c2e565b60a08201529392505050565b600060208284031215610e0a578081fd5b5035919050565b6000600019821415610e3157634e487b7160e01b81526011600452602481fd5b5060010190565b6001600160a01b0381168114610b5757600080fd5b8015158114610b5757600080fdfea26469706673582212201f1193b3b27b082f98a805d90ec2465747b7eb29a458ecbf034d06421ebe65e964736f6c63430008040033

Constructor Arguments (ABI-Encoded and is the last bytes of the Contract Creation Code above)

000000000000000000000000605757a5cceb44ced7a5be421735e0151333c338000000000000000000000000bd4455da5929d5639ee098abfaa3241e9ae111af00000000000000000000000069f0b8c5e94f6b64d832b7d9b15f3a88cb2f6f4b00000000000000000000000005745e72fb8b4a9b51118a168d956760e4a364440000000000000000000000008d4100897447d173289560bc85c5c432be4f44e4

-----Decoded View---------------
Arg [0] : _wnsPasses (address): 0x605757A5cCEB44Ced7A5Be421735E0151333c338
Arg [1] : _nftw (address): 0xBD4455dA5929D5639EE098ABFaa3241e9ae111Af
Arg [2] : _nftwEscrow (address): 0x69F0b8C5e94f6B64D832B7D9B15F3A88cB2f6F4b
Arg [3] : _avatars (address): 0x05745e72fB8b4a9b51118A168D956760e4a36444
Arg [4] : _grayboys (address): 0x8d4100897447d173289560BC85c5C432Be4f44E4

-----Encoded View---------------
5 Constructor Arguments found :
Arg [0] : 000000000000000000000000605757a5cceb44ced7a5be421735e0151333c338
Arg [1] : 000000000000000000000000bd4455da5929d5639ee098abfaa3241e9ae111af
Arg [2] : 00000000000000000000000069f0b8c5e94f6b64d832b7d9b15f3a88cb2f6f4b
Arg [3] : 00000000000000000000000005745e72fb8b4a9b51118a168d956760e4a36444
Arg [4] : 0000000000000000000000008d4100897447d173289560bc85c5c432be4f44e4


Block Transaction Difficulty Gas Used Reward
View All Blocks Produced

Block Uncle Number Difficulty Gas Used Reward
View All Uncles
Loading...
Loading
Loading...
Loading

Validator Index Block Amount
View All Withdrawals

Transaction Hash Block Value Eth2 PubKey Valid
View All Deposits
Loading...
Loading
[ 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.