ETH Price: $3,698.61 (+2.98%)

Token

ERC-20: SEER: Web3 Identity (SDID)
 

Overview

Max Total Supply

0 SDID

Holders

1,815

Market

Volume (24H)

N/A

Min Price (24H)

N/A

Max Price (24H)

N/A

Other Info

Filtered by Token Holder
silvghe.eth
Balance
1 SDID
0x46D7ACAD8CD02d1E6497cF0D6283Bda45cc31892
Loading...
Loading
Loading...
Loading
Loading...
Loading

Click here to update the token information / general information
# Exchange Pair Price  24H Volume % Volume

Contract Source Code Verified (Exact Match)

Contract Name:
BaseRegistrarImplementation

Compiler Version
v0.5.16+commit.9c3226ce

Optimization Enabled:
Yes with 10000 runs

Other Settings:
default evmVersion, MIT license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2022-09-27
*/

// File: @ensdomains/ens/contracts/ENS.sol

pragma solidity >=0.4.24;

interface ENS {

    // Logged when the owner of a node assigns a new owner to a subnode.
    event NewOwner(bytes32 indexed node, bytes32 indexed label, address owner);

    // Logged when the owner of a node transfers ownership to a new account.
    event Transfer(bytes32 indexed node, address owner);

    // Logged when the resolver for a node changes.
    event NewResolver(bytes32 indexed node, address resolver);

    // Logged when the TTL of a node changes
    event NewTTL(bytes32 indexed node, uint64 ttl);

    // Logged when an operator is added or removed.
    event ApprovalForAll(address indexed owner, address indexed operator, bool approved);

    function setRecord(bytes32 node, address owner, address resolver, uint64 ttl) external;
    function setSubnodeRecord(bytes32 node, bytes32 label, address owner, address resolver, uint64 ttl) external;
    function setSubnodeOwner(bytes32 node, bytes32 label, address owner) external returns(bytes32);
    function setResolver(bytes32 node, address resolver) external;
    function setOwner(bytes32 node, address owner) external;
    function setTTL(bytes32 node, uint64 ttl) external;
    function setApprovalForAll(address operator, bool approved) external;
    function owner(bytes32 node) external view returns (address);
    function resolver(bytes32 node) external view returns (address);
    function ttl(bytes32 node) external view returns (uint64);
    function recordExists(bytes32 node) external view returns (bool);
    function isApprovedForAll(address owner, address operator) external view returns (bool);
}

// File: openzeppelin-solidity/contracts/introspection/IERC165.sol

pragma solidity ^0.5.0;

/**
 * @title IERC165
 * @dev https://github.com/ethereum/EIPs/blob/master/EIPS/eip-165.md
 */
interface IERC165 {
    /**
     * @notice Query if a contract implements an interface
     * @param interfaceId The interface identifier, as specified in ERC-165
     * @dev Interface identification is specified in ERC-165. This function
     * uses 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;


/**
 * @title ERC721 Non-Fungible Token Standard basic interface
 * @dev see https://github.com/ethereum/EIPs/blob/master/EIPS/eip-721.md
 */
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);

    function balanceOf(address owner) public view returns (uint256 balance);
    function ownerOf(uint256 tokenId) public view returns (address owner);

    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 transferFrom(address from, address to, uint256 tokenId) public;
    function safeTransferFrom(address from, address to, uint256 tokenId) public;

    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 `safeTransfer`. 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(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;

/**
 * @title SafeMath
 * @dev Unsigned math operations with safety checks that revert on error
 */
library SafeMath {
    /**
    * @dev Multiplies two unsigned integers, reverts on 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-solidity/pull/522
        if (a == 0) {
            return 0;
        }

        uint256 c = a * b;
        require(c / a == b);

        return c;
    }

    /**
    * @dev Integer division of two unsigned integers truncating the quotient, reverts on division by zero.
    */
    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        // Solidity only automatically asserts when dividing by 0
        require(b > 0);
        uint256 c = a / b;
        // assert(a == b * c + a % b); // There is no case in which this doesn't hold

        return c;
    }

    /**
    * @dev Subtracts two unsigned integers, reverts on overflow (i.e. if subtrahend is greater than minuend).
    */
    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
        require(b <= a);
        uint256 c = a - b;

        return c;
    }

    /**
    * @dev Adds two unsigned integers, reverts on overflow.
    */
    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        uint256 c = a + b;
        require(c >= a);

        return c;
    }

    /**
    * @dev Divides two unsigned integers and returns the remainder (unsigned integer modulo),
    * reverts when dividing by zero.
    */
    function mod(uint256 a, uint256 b) internal pure returns (uint256) {
        require(b != 0);
        return a % b;
    }
}

// File: openzeppelin-solidity/contracts/utils/Address.sol

pragma solidity ^0.5.0;

/**
 * Utility library of inline functions on addresses
 */
library Address {
    /**
     * Returns whether the target address is a contract
     * @dev This function will return false if invoked during the constructor of a contract,
     * as the code is not actually created until after the constructor finishes.
     * @param account address of the account to check
     * @return whether the target address is a contract
     */
    function isContract(address account) internal view returns (bool) {
        uint256 size;
        // XXX Currently there is no better way to check if there is a contract in an address
        // than to check the size of the code at that address.
        // See https://ethereum.stackexchange.com/a/14016/36603
        // for more details about how this works.
        // TODO Check this again before the Serenity release, because all addresses will be
        // contracts then.
        // solhint-disable-next-line no-inline-assembly
        assembly { size := extcodesize(account) }
        return size > 0;
    }
}

// File: openzeppelin-solidity/contracts/introspection/ERC165.sol

pragma solidity ^0.5.0;


/**
 * @title ERC165
 * @author Matt Condon (@shrugs)
 * @dev Implements ERC165 using a lookup table.
 */
contract ERC165 is IERC165 {
    bytes4 private constant _INTERFACE_ID_ERC165 = 0x01ffc9a7;
    /**
     * 0x01ffc9a7 ===
     *     bytes4(keccak256('supportsInterface(bytes4)'))
     */

    /**
     * @dev a mapping of interface id to whether or not it's supported
     */
    mapping(bytes4 => bool) private _supportedInterfaces;

    /**
     * @dev A contract implementing SupportsInterfaceWithLookup
     * implement ERC165 itself
     */
    constructor () internal {
        _registerInterface(_INTERFACE_ID_ERC165);
    }

    /**
     * @dev implement supportsInterface(bytes4) using a lookup table
     */
    function supportsInterface(bytes4 interfaceId) external view returns (bool) {
        return _supportedInterfaces[interfaceId];
    }

    /**
     * @dev internal method for registering an interface
     */
    function _registerInterface(bytes4 interfaceId) internal {
        require(interfaceId != 0xffffffff);
        _supportedInterfaces[interfaceId] = true;
    }
}

/**
 * @title ERC-721 Non-Fungible Token Standard, optional metadata extension
 * @dev See https://eips.ethereum.org/EIPS/eip-721
 */
contract IERC721Metadata is IERC721 {
    /**
     * @dev Returns the token collection name.
     */
    function name() external view returns (string memory);

    /**
     * @dev Returns the token collection symbol.
     */
    function symbol() external view returns (string memory);

    /**
     * @dev Returns the Uniform Resource Identifier (URI) for `tokenId` token.
     */
    function tokenURI(uint256 tokenId) external view returns (string memory);
}

// File: openzeppelin-solidity/contracts/token/ERC721/ERC721.sol

pragma solidity ^0.5.0;






/**
 * @title ERC721 Non-Fungible Token Standard basic implementation
 * @dev see https://github.com/ethereum/EIPs/blob/master/EIPS/eip-721.md
 */
contract ERC721 is ERC165, IERC721Metadata {
    using SafeMath for uint256;
    using Address for address;

    // Token name
    string public name;
    // Token symbol
    string public symbol;

    string public uriPrefix = "";
    // 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 => uint256) private _ownedTokensCount;

    // Mapping from owner to operator approvals
    mapping (address => mapping (address => bool)) private _operatorApprovals;

    bytes4 private constant _INTERFACE_ID_ERC721 = 0x80ac58cd;
    /*
     * 0x80ac58cd ===
     *     bytes4(keccak256('balanceOf(address)')) ^
     *     bytes4(keccak256('ownerOf(uint256)')) ^
     *     bytes4(keccak256('approve(address,uint256)')) ^
     *     bytes4(keccak256('getApproved(uint256)')) ^
     *     bytes4(keccak256('setApprovalForAll(address,bool)')) ^
     *     bytes4(keccak256('isApprovedForAll(address,address)')) ^
     *     bytes4(keccak256('transferFrom(address,address,uint256)')) ^
     *     bytes4(keccak256('safeTransferFrom(address,address,uint256)')) ^
     *     bytes4(keccak256('safeTransferFrom(address,address,uint256,bytes)'))
     */

    constructor () public {
        // register the supported interfaces to conform to ERC721 via ERC165
        _registerInterface(_INTERFACE_ID_ERC721);
        name ="SEER: Web3 Identity";
        symbol ="SDID";
    }

    /**
     * @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));
        return _ownedTokensCount[owner];
    }

    /**
     * @dev Gets the owner of the specified token ID
     * @param tokenId uint256 ID of the token to query the owner of
     * @return owner 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));
        return owner;
    }

    function _baseURI() internal view returns (string memory) {
        return uriPrefix;
    }

    /**
     * @dev See {IERC721Metadata-tokenURI}.
     */
    function tokenURI(uint256 tokenId) public view  returns (string memory) {
        require(_tokenOwner[tokenId] != address(0));
        string memory baseURI = _baseURI();
        return bytes(baseURI).length > 0 ? string(abi.encodePacked(baseURI, uint2str(tokenId))) : "";
    }

    function uint2str(uint _i) internal pure returns (string memory _uintAsString) {
        if (_i == 0) {
            return "0";
        }
        uint j = _i;
        uint len;
        while (j != 0) {
            len++;
            j /= 10;
        }
        bytes memory bstr = new bytes(len);
        uint k = len;
        while (_i != 0) {
            k = k-1;
            uint8 temp = (48 + uint8(_i - _i / 10 * 10));
            bytes1 b1 = bytes1(temp);
            bstr[k] = b1;
            _i /= 10;
        }
        return string(bstr);
    }

    /**
     * @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);
        require(msg.sender == owner || isApprovedForAll(owner, msg.sender));

        _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));
        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 != msg.sender);
        _operatorApprovals[msg.sender][to] = approved;
        emit ApprovalForAll(msg.sender, 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 {
        require(_isApprovedOrOwner(msg.sender, tokenId));

        _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 `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 `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) public {
        transferFrom(from, to, tokenId);
        require(_checkOnERC721Received(from, to, tokenId, _data));
    }

    /**
     * @dev Returns whether the specified token exists
     * @param tokenId uint256 ID of the token to query the existence of
     * @return 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) {
        address owner = ownerOf(tokenId);
        return (spender == owner || getApproved(tokenId) == spender || isApprovedForAll(owner, spender));
    }

    /**
     * @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));
        require(!_exists(tokenId));

        _tokenOwner[tokenId] = to;
        _ownedTokensCount[to] = _ownedTokensCount[to].add(1);

        emit Transfer(address(0), to, tokenId);
    }

    /**
     * @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
     */
    function _burn(address owner, uint256 tokenId) internal {
        require(ownerOf(tokenId) == owner);

        _clearApproval(tokenId);

        _ownedTokensCount[owner] = _ownedTokensCount[owner].sub(1);
        _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);
        require(to != address(0));

        _clearApproval(tokenId);

        _ownedTokensCount[from] = _ownedTokensCount[from].sub(1);
        _ownedTokensCount[to] = _ownedTokensCount[to].add(1);

        _tokenOwner[tokenId] = to;

        emit Transfer(from, to, tokenId);
    }

    /**
     * @dev Internal function to invoke `onERC721Received` on a target address
     * The call is not executed if the target address is not a contract
     * @param from address representing the previous owner of the given token ID
     * @param to target address that will receive the tokens
     * @param tokenId uint256 ID of the token to be transferred
     * @param _data bytes optional data to send along with the call
     * @return 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(msg.sender, 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/ownership/Ownable.sol

pragma solidity ^0.5.0;

/**
 * @title Ownable
 * @dev The Ownable contract has an owner address, and provides basic authorization control
 * functions, this simplifies the implementation of "user permissions".
 */
contract Ownable {
    address private _owner;

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

    /**
     * @dev The Ownable constructor sets the original `owner` of the contract to the sender
     * account.
     */
    constructor () internal {
        _owner = msg.sender;
        emit OwnershipTransferred(address(0), _owner);
    }

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

    /**
     * @dev Throws if called by any account other than the owner.
     */
    modifier onlyOwner() {
        require(isOwner());
        _;
    }

    /**
     * @return true if `msg.sender` is the owner of the contract.
     */
    function isOwner() public view returns (bool) {
        return msg.sender == _owner;
    }

    /**
     * @dev Allows the current owner to relinquish control of the contract.
     * @notice Renouncing to ownership will leave the contract without an owner.
     * It will not be possible to call the functions with the `onlyOwner`
     * modifier anymore.
     */
    function renounceOwnership() public onlyOwner {
        emit OwnershipTransferred(_owner, address(0));
        _owner = address(0);
    }

    /**
     * @dev Allows the current owner to transfer control of the contract to a newOwner.
     * @param newOwner The address to transfer ownership to.
     */
    function transferOwnership(address newOwner) public onlyOwner {
        _transferOwnership(newOwner);
    }

    /**
     * @dev Transfers control of the contract to a newOwner.
     * @param newOwner The address to transfer ownership to.
     */
    function _transferOwnership(address newOwner) internal {
        require(newOwner != address(0));
        emit OwnershipTransferred(_owner, newOwner);
        _owner = newOwner;
    }
}

// File: @ensdomains/ethregistrar/contracts/BaseRegistrar.sol

pragma solidity >=0.4.24;




contract BaseRegistrar is IERC721, Ownable {
    uint constant public GRACE_PERIOD = 90 days;

    event ControllerAdded(address indexed controller);
    event ControllerRemoved(address indexed controller);
    event NameMigrated(uint256 indexed id, address indexed owner, uint expires);
    event NameRegistered(uint256 indexed id, address indexed owner, uint expires);
    event NameRenewed(uint256 indexed id, uint expires);

    // The ENS registry
    ENS public ens;

    // The namehash of the TLD this registrar owns (eg, .eth)
    bytes32 public baseNode;

    // A map of addresses that are authorised to register and renew names.
    mapping(address=>bool) public controllers;

    // Authorises a controller, who can register and renew domains.
    function addController(address controller) external;

    // Revoke controller permission for an address.
    function removeController(address controller) external;

    // Set the resolver for the TLD this registrar manages.
    function setResolver(address resolver) external;

    // Returns the expiration timestamp of the specified label hash.
    function nameExpires(uint256 id) external view returns(uint);

    // Returns true iff the specified name is available for registration.
    function available(uint256 id) public view returns(bool);

    /**
     * @dev Register a name.
     */
    function register(uint256 id, address owner, uint duration) external returns(uint);

    function renew(uint256 id, uint duration) external returns(uint);

    /**
     * @dev Reclaim ownership of a name in ENS, if you own it in the registrar.
     */
    function reclaim(uint256 id, address owner) external;
}




// File: @ensdomains/ethregistrar/contracts/BaseRegistrarImplementation.sol

pragma solidity ^0.5.0;




contract BaseRegistrarImplementation is BaseRegistrar, ERC721 {
    // A map of expiry times
    mapping(uint256=>uint) expiries;

    bytes4 constant private INTERFACE_META_ID = bytes4(keccak256("supportsInterface(bytes4)"));
    bytes4 constant private ERC721_ID = bytes4(
        keccak256("balanceOf(address)") ^
        keccak256("ownerOf(uint256)") ^
        keccak256("approve(address,uint256)") ^
        keccak256("getApproved(uint256)") ^
        keccak256("setApprovalForAll(address,bool)") ^
        keccak256("isApprovedForAll(address,address)") ^
        keccak256("transferFrom(address,address,uint256)") ^
        keccak256("safeTransferFrom(address,address,uint256)") ^
        keccak256("safeTransferFrom(address,address,uint256,bytes)")
    );
    bytes4 constant private RECLAIM_ID = bytes4(keccak256("reclaim(uint256,address)"));
    bytes4 constant private METADATA_ID = bytes4(
        keccak256("name()")^
        keccak256("symbol()")^
        keccak256("tokenURI(uint256)")
    );

    constructor(ENS _ens, bytes32 _baseNode) public {
        ens = _ens;
        baseNode = _baseNode;
    }

    modifier live {
        require(ens.owner(baseNode) == address(this));
        _;
    }

    modifier onlyController {
        require(controllers[msg.sender]);
        _;
    }

    /**
     * @dev Gets the owner of the specified token ID. Names become unowned
     *      when their registration expires.
     * @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) {
        require(expiries[tokenId] > now);
        return super.ownerOf(tokenId);
    }

    // Authorises a controller, who can register and renew domains.
    function addController(address controller) external onlyOwner {
        controllers[controller] = true;
        emit ControllerAdded(controller);
    }

    // Revoke controller permission for an address.
    function removeController(address controller) external onlyOwner {
        controllers[controller] = false;
        emit ControllerRemoved(controller);
    }

    // Set the resolver for the TLD this registrar manages.
    function setResolver(address resolver) external onlyOwner {
        ens.setResolver(baseNode, resolver);
    }

    // Returns the expiration timestamp of the specified id.
    function nameExpires(uint256 id) external view returns(uint) {
        return expiries[id];
    }

    // Returns true iff the specified name is available for registration.
    function available(uint256 id) public view returns(bool) {
        // Not available if it's registered here or in its grace period.
        return expiries[id] + GRACE_PERIOD < now;
    }

    /**
     * @dev Register a name.
     * @param id The token ID (keccak256 of the label).
     * @param owner The address that should own the registration.
     * @param duration Duration in seconds for the registration.
     */
    function register(uint256 id, address owner, uint duration) external returns(uint) {
      return _register(id, owner, duration, true);
    }

    /**
     * @dev Register a name, without modifying the registry.
     * @param id The token ID (keccak256 of the label).
     * @param owner The address that should own the registration.
     * @param duration Duration in seconds for the registration.
     */
    function registerOnly(uint256 id, address owner, uint duration) external returns(uint) {
      return _register(id, owner, duration, false);
    }

    function _register(uint256 id, address owner, uint duration, bool updateRegistry) internal live onlyController returns(uint) {
        require(available(id));
        require(now + duration + GRACE_PERIOD > now + GRACE_PERIOD); // Prevent future overflow

        expiries[id] = now + duration;
        if(_exists(id)) {
            // Name was previously owned, and expired
            _burn(id);
        }
        _mint(owner, id);
        if(updateRegistry) {
            ens.setSubnodeOwner(baseNode, bytes32(id), owner);
        }

        emit NameRegistered(id, owner, now + duration);

        return now + duration;
    }

    function renew(uint256 id, uint duration) external live onlyController returns(uint) {
        require(expiries[id] + GRACE_PERIOD >= now); // Name must be registered here or in grace period
        require(expiries[id] + duration + GRACE_PERIOD > duration + GRACE_PERIOD); // Prevent future overflow

        expiries[id] += duration;
        emit NameRenewed(id, expiries[id]);
        return expiries[id];
    }

    /**
     * @dev Reclaim ownership of a name in ENS, if you own it in the registrar.
     */
    function reclaim(uint256 id, address owner) external live {
        require(_isApprovedOrOwner(msg.sender, id));
        ens.setSubnodeOwner(baseNode, bytes32(id), owner);
    }

    function setUriPrefix(string memory _uriPrefix) public onlyOwner {
        uriPrefix = _uriPrefix;
    }

    function supportsInterface(bytes4 interfaceID) external view returns (bool) {
        return interfaceID == INTERFACE_META_ID ||
               interfaceID == ERC721_ID ||
               interfaceID == RECLAIM_ID ||
               interfaceID == METADATA_ID;
    }
}

Contract Security Audit

Contract ABI

[{"inputs":[{"internalType":"contract ENS","name":"_ens","type":"address"},{"internalType":"bytes32","name":"_baseNode","type":"bytes32"}],"payable":false,"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"approved","type":"address"},{"indexed":true,"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"operator","type":"address"},{"indexed":false,"internalType":"bool","name":"approved","type":"bool"}],"name":"ApprovalForAll","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"controller","type":"address"}],"name":"ControllerAdded","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"controller","type":"address"}],"name":"ControllerRemoved","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"uint256","name":"id","type":"uint256"},{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":false,"internalType":"uint256","name":"expires","type":"uint256"}],"name":"NameMigrated","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"uint256","name":"id","type":"uint256"},{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":false,"internalType":"uint256","name":"expires","type":"uint256"}],"name":"NameRegistered","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"uint256","name":"id","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"expires","type":"uint256"}],"name":"NameRenewed","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":true,"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"Transfer","type":"event"},{"constant":true,"inputs":[],"name":"GRACE_PERIOD","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"controller","type":"address"}],"name":"addController","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"approve","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"internalType":"uint256","name":"id","type":"uint256"}],"name":"available","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"address","name":"owner","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"baseNode","outputs":[{"internalType":"bytes32","name":"","type":"bytes32"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"controllers","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"ens","outputs":[{"internalType":"contract ENS","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"getApproved","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"operator","type":"address"}],"name":"isApprovedForAll","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"isOwner","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"uint256","name":"id","type":"uint256"}],"name":"nameExpires","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"ownerOf","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"uint256","name":"id","type":"uint256"},{"internalType":"address","name":"owner","type":"address"}],"name":"reclaim","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"uint256","name":"id","type":"uint256"},{"internalType":"address","name":"owner","type":"address"},{"internalType":"uint256","name":"duration","type":"uint256"}],"name":"register","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"uint256","name":"id","type":"uint256"},{"internalType":"address","name":"owner","type":"address"},{"internalType":"uint256","name":"duration","type":"uint256"}],"name":"registerOnly","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"controller","type":"address"}],"name":"removeController","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"uint256","name":"id","type":"uint256"},{"internalType":"uint256","name":"duration","type":"uint256"}],"name":"renew","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[],"name":"renounceOwnership","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"safeTransferFrom","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"},{"internalType":"bytes","name":"_data","type":"bytes"}],"name":"safeTransferFrom","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"bool","name":"approved","type":"bool"}],"name":"setApprovalForAll","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"resolver","type":"address"}],"name":"setResolver","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"string","name":"_uriPrefix","type":"string"}],"name":"setUriPrefix","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"internalType":"bytes4","name":"interfaceID","type":"bytes4"}],"name":"supportsInterface","outputs":[{"internalType":"bool","name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"tokenURI","outputs":[{"internalType":"string","name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"tokenId","type":"uint256"}],"name":"transferFrom","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"uriPrefix","outputs":[{"internalType":"string","name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"}]

60a06040819052600060808190526200001b91600791620001b6565b503480156200002957600080fd5b506040516200230c3803806200230c833981810160405260408110156200004f57600080fd5b508051602090910151620000736301ffc9a760e01b6001600160e01b036200017916565b600180546001600160a01b0319163317908190556040516001600160a01b0391909116906000907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a3620000da6380ac58cd60e01b6001600160e01b036200017916565b6040805180820190915260138082527f534545523a2057656233204964656e746974790000000000000000000000000060209092019182526200012091600591620001b6565b506040805180820190915260048082526314d1125160e21b60209092019182526200014e91600691620001b6565b50600280546001600160a01b0319166001600160a01b0393909316929092179091556003556200025b565b6001600160e01b031980821614156200019157600080fd5b6001600160e01b0319166000908152602081905260409020805460ff19166001179055565b828054600181600116156101000203166002900490600052602060002090601f016020900481019282601f10620001f957805160ff191683800117855562000229565b8280016001018555821562000229579182015b82811115620002295782518255916020019190600101906200020c565b50620002379291506200023b565b5090565b6200025891905b8082111562000237576000815560010162000242565b90565b6120a1806200026b6000396000f3fe608060405234801561001057600080fd5b50600436106101f05760003560e01c80638f32d59b1161010f578063c87b56dd116100a2578063e985e9c511610071578063e985e9c514610711578063f2fde38b1461073f578063f6a74ed714610765578063fca247ac1461078b576101f0565b8063c87b56dd146106a9578063d6e4fa86146106c6578063da8c229e146106e3578063ddf7fcb014610709576101f0565b8063a7fc7a07116100de578063a7fc7a0714610592578063b88d4fde146105b8578063c1a287e21461067e578063c475abff14610686576101f0565b80638f32d59b1461053757806395d89b411461053f57806396e494e814610547578063a22cb46514610564576101f0565b806342842e0e1161018757806370a082311161015657806370a082311461045b578063715018a6146104815780637ec4a659146104895780638da5cb5b1461052f576101f0565b806342842e0e146103da5780634e543b261461041057806362b99ad4146104365780636352211e1461043e576101f0565b80630e297b45116101c35780630e297b451461032c57806323b872dd1461037057806328ed4f6c146103a65780633f15457f146103d2576101f0565b806301ffc9a7146101f557806306fdde0314610248578063081812fc146102c5578063095ea7b3146102fe575b600080fd5b6102346004803603602081101561020b57600080fd5b50357fffffffff00000000000000000000000000000000000000000000000000000000166107bd565b604080519115158252519081900360200190f35b610250610acd565b6040805160208082528351818301528351919283929083019185019080838360005b8381101561028a578181015183820152602001610272565b50505050905090810190601f1680156102b75780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b6102e2600480360360208110156102db57600080fd5b5035610b5b565b604080516001600160a01b039092168252519081900360200190f35b61032a6004803603604081101561031457600080fd5b506001600160a01b038135169060200135610b8b565b005b61035e6004803603606081101561034257600080fd5b508035906001600160a01b036020820135169060400135610c50565b60408051918252519081900360200190f35b61032a6004803603606081101561038657600080fd5b506001600160a01b03813581169160208101359091169060400135610c67565b61032a600480360360408110156103bc57600080fd5b50803590602001356001600160a01b0316610c8a565b6102e2610dec565b61032a600480360360608110156103f057600080fd5b506001600160a01b03813581169160208101359091169060400135610dfb565b61032a6004803603602081101561042657600080fd5b50356001600160a01b0316610e16565b610250610eb3565b6102e26004803603602081101561045457600080fd5b5035610f0e565b61035e6004803603602081101561047157600080fd5b50356001600160a01b0316610f31565b61032a610f62565b61032a6004803603602081101561049f57600080fd5b8101906020810181356401000000008111156104ba57600080fd5b8201836020820111156104cc57600080fd5b803590602001918460018302840111640100000000831117156104ee57600080fd5b91908080601f016020809104026020016040519081016040528093929190818152602001838380828437600092019190915250929550610fd5945050505050565b6102e2610ffd565b61023461100d565b61025061101e565b6102346004803603602081101561055d57600080fd5b5035611079565b61032a6004803603604081101561057a57600080fd5b506001600160a01b0381351690602001351515611094565b61032a600480360360208110156105a857600080fd5b50356001600160a01b0316611136565b61032a600480360360808110156105ce57600080fd5b6001600160a01b0382358116926020810135909116916040820135919081019060808101606082013564010000000081111561060957600080fd5b82018360208201111561061b57600080fd5b8035906020019184600183028401116401000000008311171561063d57600080fd5b91908080601f0160208091040260200160405190810160405280939291908181526020018383808284376000920191909152509295506111b1945050505050565b61035e6111d1565b61035e6004803603604081101561069c57600080fd5b50803590602001356111d8565b610250600480360360208110156106bf57600080fd5b5035611346565b61035e600480360360208110156106dc57600080fd5b5035611491565b610234600480360360208110156106f957600080fd5b50356001600160a01b03166114a3565b61035e6114b8565b6102346004803603604081101561072757600080fd5b506001600160a01b03813581169160200135166114be565b61032a6004803603602081101561075557600080fd5b50356001600160a01b03166114ec565b61032a6004803603602081101561077b57600080fd5b50356001600160a01b0316611509565b61035e600480360360608110156107a157600080fd5b508035906001600160a01b036020820135169060400135611581565b604080517f737570706f727473496e74657266616365286279746573342900000000000000815290519081900360190190206000907fffffffff000000000000000000000000000000000000000000000000000000008381169116148061099f575060405180602f61201d823960405190819003602f0181209150806029611ff482396040519081900360290181209150806025611fcf8239604051908190036025018120915080602161204c8239604080519182900360210182207f736574417070726f76616c466f72416c6c28616464726573732c626f6f6c29008352815192839003601f0183207f676574417070726f7665642875696e7432353629000000000000000000000000845282519384900360140184207f617070726f766528616464726573732c75696e74323536290000000000000000855283519485900360180185207f6f776e65724f662875696e743235362900000000000000000000000000000000865284519586900360100186207f62616c616e63654f66286164647265737329000000000000000000000000000087529451958690036012019095207fffffffff000000000000000000000000000000000000000000000000000000008c811691909518909518181818939093189390931893909318161490505b806109ff5750604080517f7265636c61696d2875696e743235362c61646472657373290000000000000000815290519081900360180190207fffffffff000000000000000000000000000000000000000000000000000000008381169116145b80610ac55750604080517f746f6b656e5552492875696e7432353629000000000000000000000000000000815281519081900360110181207f73796d626f6c2829000000000000000000000000000000000000000000000000825282519182900360080182207f6e616d652829000000000000000000000000000000000000000000000000000083529251918290036006019091207fffffffff000000000000000000000000000000000000000000000000000000008581169190931890911891909116145b90505b919050565b6005805460408051602060026001851615610100026000190190941693909304601f81018490048402820184019092528181529291830182828015610b535780601f10610b2857610100808354040283529160200191610b53565b820191906000526020600020905b815481529060010190602001808311610b3657829003601f168201915b505050505081565b6000610b6682611590565b610b6f57600080fd5b506000908152600960205260409020546001600160a01b031690565b6000610b9682610f0e565b9050806001600160a01b0316836001600160a01b03161415610bb757600080fd5b336001600160a01b0382161480610bd35750610bd381336114be565b610bdc57600080fd5b60008281526009602052604080822080547fffffffffffffffffffffffff0000000000000000000000000000000000000000166001600160a01b0387811691821790925591518593918516917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591a4505050565b6000610c5f84848460006115ad565b949350505050565b610c7133826117cb565b610c7a57600080fd5b610c85838383611822565b505050565b600254600354604080517f02571be300000000000000000000000000000000000000000000000000000000815260048101929092525130926001600160a01b0316916302571be3916024808301926020929190829003018186803b158015610cf157600080fd5b505afa158015610d05573d6000803e3d6000fd5b505050506040513d6020811015610d1b57600080fd5b50516001600160a01b031614610d3057600080fd5b610d3a33836117cb565b610d4357600080fd5b600254600354604080517f06ab59230000000000000000000000000000000000000000000000000000000081526004810192909252602482018590526001600160a01b03848116604484015290519216916306ab5923916064808201926020929091908290030181600087803b158015610dbc57600080fd5b505af1158015610dd0573d6000803e3d6000fd5b505050506040513d6020811015610de657600080fd5b50505050565b6002546001600160a01b031681565b610c85838383604051806020016040528060008152506111b1565b610e1e61100d565b610e2757600080fd5b600254600354604080517f1896f70a00000000000000000000000000000000000000000000000000000000815260048101929092526001600160a01b0384811660248401529051921691631896f70a9160448082019260009290919082900301818387803b158015610e9857600080fd5b505af1158015610eac573d6000803e3d6000fd5b5050505050565b6007805460408051602060026001851615610100026000190190941693909304601f81018490048402820184019092528181529291830182828015610b535780601f10610b2857610100808354040283529160200191610b53565b6000818152600c60205260408120544210610f2857600080fd5b610ac582611947565b60006001600160a01b038216610f4657600080fd5b506001600160a01b03166000908152600a602052604090205490565b610f6a61100d565b610f7357600080fd5b6001546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600180547fffffffffffffffffffffffff0000000000000000000000000000000000000000169055565b610fdd61100d565b610fe657600080fd5b8051610ff9906007906020840190611f36565b5050565b6001546001600160a01b03165b90565b6001546001600160a01b0316331490565b6006805460408051602060026001851615610100026000190190941693909304601f81018490048402820184019092528181529291830182828015610b535780601f10610b2857610100808354040283529160200191610b53565b6000908152600c6020526040902054426276a7009091011090565b6001600160a01b0382163314156110aa57600080fd5b336000818152600b602090815260408083206001600160a01b0387168085529083529281902080547fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff0016861515908117909155815190815290519293927f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c31929181900390910190a35050565b61113e61100d565b61114757600080fd5b6001600160a01b03811660008181526004602052604080822080547fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff00166001179055517f0a8bb31534c0ed46f380cb867bd5c803a189ced9a764e30b3a4991a9901d74749190a250565b6111bc848484610c67565b6111c884848484611969565b610de657600080fd5b6276a70081565b600254600354604080517f02571be300000000000000000000000000000000000000000000000000000000815260048101929092525160009230926001600160a01b03909116916302571be391602480820192602092909190829003018186803b15801561124557600080fd5b505afa158015611259573d6000803e3d6000fd5b505050506040513d602081101561126f57600080fd5b50516001600160a01b03161461128457600080fd5b3360009081526004602052604090205460ff166112a057600080fd5b6000838152600c6020526040902054426276a70090910110156112c257600080fd5b6000838152600c60205260409020546276a70083810191840101116112e657600080fd5b6000838152600c602090815260409182902080548501908190558251908152915185927f9b87a00e30f1ac65d898f070f8a3488fe60517182d0a2098e1b4b93a54aa9bd692908290030190a250506000908152600c602052604090205490565b6000818152600860205260409020546060906001600160a01b031661136a57600080fd5b6060611374611ae6565b90506000815111611394576040518060200160405280600081525061148a565b8061139e84611b7c565b6040516020018083805190602001908083835b602083106113ee57805182527fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffe090920191602091820191016113b1565b51815160209384036101000a600019018019909216911617905285519190930192850191508083835b6020831061145457805182527fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffe09092019160209182019101611417565b6001836020036101000a038019825116818451168082178552505050505050905001925050506040516020818303038152906040525b9392505050565b6000908152600c602052604090205490565b60046020526000908152604090205460ff1681565b60035481565b6001600160a01b039182166000908152600b6020908152604080832093909416825291909152205460ff1690565b6114f461100d565b6114fd57600080fd5b61150681611c7b565b50565b61151161100d565b61151a57600080fd5b6001600160a01b03811660008181526004602052604080822080547fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff00169055517f33d83959be2573f5453b12eb9d43b3499bc57d96bd2f067ba44803c859e811139190a250565b6000610c5f84848460016115ad565b6000908152600860205260409020546001600160a01b0316151590565b600254600354604080517f02571be300000000000000000000000000000000000000000000000000000000815260048101929092525160009230926001600160a01b03909116916302571be391602480820192602092909190829003018186803b15801561161a57600080fd5b505afa15801561162e573d6000803e3d6000fd5b505050506040513d602081101561164457600080fd5b50516001600160a01b03161461165957600080fd5b3360009081526004602052604090205460ff1661167557600080fd5b61167e85611079565b61168757600080fd5b6276a70042016276a700844201011161169f57600080fd5b6000858152600c6020526040902042840190556116bb85611590565b156116c9576116c985611d02565b6116d38486611d14565b811561177f57600254600354604080517f06ab59230000000000000000000000000000000000000000000000000000000081526004810192909252602482018890526001600160a01b03878116604484015290519216916306ab5923916064808201926020929091908290030181600087803b15801561175257600080fd5b505af1158015611766573d6000803e3d6000fd5b505050506040513d602081101561177c57600080fd5b50505b60408051428501815290516001600160a01b0386169187917fb3d987963d01b2f68493b4bdb130988f157ea43070d4ad840fee0466ed9370d99181900360200190a35050420192915050565b6000806117d783610f0e565b9050806001600160a01b0316846001600160a01b031614806118125750836001600160a01b031661180784610b5b565b6001600160a01b0316145b80610c5f5750610c5f81856114be565b826001600160a01b031661183582610f0e565b6001600160a01b03161461184857600080fd5b6001600160a01b03821661185b57600080fd5b61186481611ddf565b6001600160a01b0383166000908152600a602052604090205461188e90600163ffffffff611e3216565b6001600160a01b038085166000908152600a602052604080822093909355908416815220546118c490600163ffffffff611e4716565b6001600160a01b038084166000818152600a60209081526040808320959095558582526008905283812080547fffffffffffffffffffffffff000000000000000000000000000000000000000016831790559251849391928716917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef91a4505050565b6000818152600860205260408120546001600160a01b031680610ac557600080fd5b600061197d846001600160a01b0316611e59565b61198957506001610c5f565b6040517f150b7a0200000000000000000000000000000000000000000000000000000000815233600482018181526001600160a01b03888116602485015260448401879052608060648501908152865160848601528651600095928a169463150b7a029490938c938b938b939260a4019060208501908083838e5b83811015611a1c578181015183820152602001611a04565b50505050905090810190601f168015611a495780820380516001836020036101000a031916815260200191505b5095505050505050602060405180830381600087803b158015611a6b57600080fd5b505af1158015611a7f573d6000803e3d6000fd5b505050506040513d6020811015611a9557600080fd5b50517fffffffff00000000000000000000000000000000000000000000000000000000167f150b7a020000000000000000000000000000000000000000000000000000000014915050949350505050565b60078054604080516020601f6002600019610100600188161502019095169490940493840181900481028201810190925282815260609390929091830182828015611b725780601f10611b4757610100808354040283529160200191611b72565b820191906000526020600020905b815481529060010190602001808311611b5557829003601f168201915b5050505050905090565b606081611bbd575060408051808201909152600181527f30000000000000000000000000000000000000000000000000000000000000006020820152610ac8565b8160005b8115611bd557600101600a82049150611bc1565b6060816040519080825280601f01601f191660200182016040528015611c02576020820181803883390190505b509050815b8515611c7257600019016000600a8704600a028703603001905060008160f81b905080848481518110611c3657fe5b60200101907effffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916908160001a905350600a880497505050611c07565b50949350505050565b6001600160a01b038116611c8e57600080fd5b6001546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600180547fffffffffffffffffffffffff0000000000000000000000000000000000000000166001600160a01b0392909216919091179055565b611506611d0e82610f0e565b82611e5f565b6001600160a01b038216611d2757600080fd5b611d3081611590565b15611d3a57600080fd5b600081815260086020908152604080832080547fffffffffffffffffffffffff0000000000000000000000000000000000000000166001600160a01b0387169081179091558352600a909152902054611d94906001611e47565b6001600160a01b0383166000818152600a60205260408082209390935591518392907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef908290a45050565b6000818152600960205260409020546001600160a01b03161561150657600090815260096020526040902080547fffffffffffffffffffffffff0000000000000000000000000000000000000000169055565b600082821115611e4157600080fd5b50900390565b60008282018381101561148a57600080fd5b3b151590565b816001600160a01b0316611e7282610f0e565b6001600160a01b031614611e8557600080fd5b611e8e81611ddf565b6001600160a01b0382166000908152600a6020526040902054611eb890600163ffffffff611e3216565b6001600160a01b0383166000818152600a60209081526040808320949094558482526008905282812080547fffffffffffffffffffffffff00000000000000000000000000000000000000001690559151839291907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef908390a45050565b828054600181600116156101000203166002900490600052602060002090601f016020900481019282601f10611f7757805160ff1916838001178555611fa4565b82800160010185558215611fa4579182015b82811115611fa4578251825591602001919060010190611f89565b50611fb0929150611fb4565b5090565b61100a91905b80821115611fb05760008155600101611fba56fe7472616e7366657246726f6d28616464726573732c616464726573732c75696e7432353629736166655472616e7366657246726f6d28616464726573732c616464726573732c75696e7432353629736166655472616e7366657246726f6d28616464726573732c616464726573732c75696e743235362c6279746573296973417070726f766564466f72416c6c28616464726573732c6164647265737329a265627a7a72315820d5fd311b852d8927cb40f7434fec8e2e486d6232260baf71cfcb7a92017a75fc64736f6c634300051000320000000000000000000000006c106583b7079794aa80f947fc09febc5276c9c5587d09fe5fa45354680537d38145a28b772971e0f293af3ee0c536fc919710fb

Deployed Bytecode

0x608060405234801561001057600080fd5b50600436106101f05760003560e01c80638f32d59b1161010f578063c87b56dd116100a2578063e985e9c511610071578063e985e9c514610711578063f2fde38b1461073f578063f6a74ed714610765578063fca247ac1461078b576101f0565b8063c87b56dd146106a9578063d6e4fa86146106c6578063da8c229e146106e3578063ddf7fcb014610709576101f0565b8063a7fc7a07116100de578063a7fc7a0714610592578063b88d4fde146105b8578063c1a287e21461067e578063c475abff14610686576101f0565b80638f32d59b1461053757806395d89b411461053f57806396e494e814610547578063a22cb46514610564576101f0565b806342842e0e1161018757806370a082311161015657806370a082311461045b578063715018a6146104815780637ec4a659146104895780638da5cb5b1461052f576101f0565b806342842e0e146103da5780634e543b261461041057806362b99ad4146104365780636352211e1461043e576101f0565b80630e297b45116101c35780630e297b451461032c57806323b872dd1461037057806328ed4f6c146103a65780633f15457f146103d2576101f0565b806301ffc9a7146101f557806306fdde0314610248578063081812fc146102c5578063095ea7b3146102fe575b600080fd5b6102346004803603602081101561020b57600080fd5b50357fffffffff00000000000000000000000000000000000000000000000000000000166107bd565b604080519115158252519081900360200190f35b610250610acd565b6040805160208082528351818301528351919283929083019185019080838360005b8381101561028a578181015183820152602001610272565b50505050905090810190601f1680156102b75780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b6102e2600480360360208110156102db57600080fd5b5035610b5b565b604080516001600160a01b039092168252519081900360200190f35b61032a6004803603604081101561031457600080fd5b506001600160a01b038135169060200135610b8b565b005b61035e6004803603606081101561034257600080fd5b508035906001600160a01b036020820135169060400135610c50565b60408051918252519081900360200190f35b61032a6004803603606081101561038657600080fd5b506001600160a01b03813581169160208101359091169060400135610c67565b61032a600480360360408110156103bc57600080fd5b50803590602001356001600160a01b0316610c8a565b6102e2610dec565b61032a600480360360608110156103f057600080fd5b506001600160a01b03813581169160208101359091169060400135610dfb565b61032a6004803603602081101561042657600080fd5b50356001600160a01b0316610e16565b610250610eb3565b6102e26004803603602081101561045457600080fd5b5035610f0e565b61035e6004803603602081101561047157600080fd5b50356001600160a01b0316610f31565b61032a610f62565b61032a6004803603602081101561049f57600080fd5b8101906020810181356401000000008111156104ba57600080fd5b8201836020820111156104cc57600080fd5b803590602001918460018302840111640100000000831117156104ee57600080fd5b91908080601f016020809104026020016040519081016040528093929190818152602001838380828437600092019190915250929550610fd5945050505050565b6102e2610ffd565b61023461100d565b61025061101e565b6102346004803603602081101561055d57600080fd5b5035611079565b61032a6004803603604081101561057a57600080fd5b506001600160a01b0381351690602001351515611094565b61032a600480360360208110156105a857600080fd5b50356001600160a01b0316611136565b61032a600480360360808110156105ce57600080fd5b6001600160a01b0382358116926020810135909116916040820135919081019060808101606082013564010000000081111561060957600080fd5b82018360208201111561061b57600080fd5b8035906020019184600183028401116401000000008311171561063d57600080fd5b91908080601f0160208091040260200160405190810160405280939291908181526020018383808284376000920191909152509295506111b1945050505050565b61035e6111d1565b61035e6004803603604081101561069c57600080fd5b50803590602001356111d8565b610250600480360360208110156106bf57600080fd5b5035611346565b61035e600480360360208110156106dc57600080fd5b5035611491565b610234600480360360208110156106f957600080fd5b50356001600160a01b03166114a3565b61035e6114b8565b6102346004803603604081101561072757600080fd5b506001600160a01b03813581169160200135166114be565b61032a6004803603602081101561075557600080fd5b50356001600160a01b03166114ec565b61032a6004803603602081101561077b57600080fd5b50356001600160a01b0316611509565b61035e600480360360608110156107a157600080fd5b508035906001600160a01b036020820135169060400135611581565b604080517f737570706f727473496e74657266616365286279746573342900000000000000815290519081900360190190206000907fffffffff000000000000000000000000000000000000000000000000000000008381169116148061099f575060405180602f61201d823960405190819003602f0181209150806029611ff482396040519081900360290181209150806025611fcf8239604051908190036025018120915080602161204c8239604080519182900360210182207f736574417070726f76616c466f72416c6c28616464726573732c626f6f6c29008352815192839003601f0183207f676574417070726f7665642875696e7432353629000000000000000000000000845282519384900360140184207f617070726f766528616464726573732c75696e74323536290000000000000000855283519485900360180185207f6f776e65724f662875696e743235362900000000000000000000000000000000865284519586900360100186207f62616c616e63654f66286164647265737329000000000000000000000000000087529451958690036012019095207fffffffff000000000000000000000000000000000000000000000000000000008c811691909518909518181818939093189390931893909318161490505b806109ff5750604080517f7265636c61696d2875696e743235362c61646472657373290000000000000000815290519081900360180190207fffffffff000000000000000000000000000000000000000000000000000000008381169116145b80610ac55750604080517f746f6b656e5552492875696e7432353629000000000000000000000000000000815281519081900360110181207f73796d626f6c2829000000000000000000000000000000000000000000000000825282519182900360080182207f6e616d652829000000000000000000000000000000000000000000000000000083529251918290036006019091207fffffffff000000000000000000000000000000000000000000000000000000008581169190931890911891909116145b90505b919050565b6005805460408051602060026001851615610100026000190190941693909304601f81018490048402820184019092528181529291830182828015610b535780601f10610b2857610100808354040283529160200191610b53565b820191906000526020600020905b815481529060010190602001808311610b3657829003601f168201915b505050505081565b6000610b6682611590565b610b6f57600080fd5b506000908152600960205260409020546001600160a01b031690565b6000610b9682610f0e565b9050806001600160a01b0316836001600160a01b03161415610bb757600080fd5b336001600160a01b0382161480610bd35750610bd381336114be565b610bdc57600080fd5b60008281526009602052604080822080547fffffffffffffffffffffffff0000000000000000000000000000000000000000166001600160a01b0387811691821790925591518593918516917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591a4505050565b6000610c5f84848460006115ad565b949350505050565b610c7133826117cb565b610c7a57600080fd5b610c85838383611822565b505050565b600254600354604080517f02571be300000000000000000000000000000000000000000000000000000000815260048101929092525130926001600160a01b0316916302571be3916024808301926020929190829003018186803b158015610cf157600080fd5b505afa158015610d05573d6000803e3d6000fd5b505050506040513d6020811015610d1b57600080fd5b50516001600160a01b031614610d3057600080fd5b610d3a33836117cb565b610d4357600080fd5b600254600354604080517f06ab59230000000000000000000000000000000000000000000000000000000081526004810192909252602482018590526001600160a01b03848116604484015290519216916306ab5923916064808201926020929091908290030181600087803b158015610dbc57600080fd5b505af1158015610dd0573d6000803e3d6000fd5b505050506040513d6020811015610de657600080fd5b50505050565b6002546001600160a01b031681565b610c85838383604051806020016040528060008152506111b1565b610e1e61100d565b610e2757600080fd5b600254600354604080517f1896f70a00000000000000000000000000000000000000000000000000000000815260048101929092526001600160a01b0384811660248401529051921691631896f70a9160448082019260009290919082900301818387803b158015610e9857600080fd5b505af1158015610eac573d6000803e3d6000fd5b5050505050565b6007805460408051602060026001851615610100026000190190941693909304601f81018490048402820184019092528181529291830182828015610b535780601f10610b2857610100808354040283529160200191610b53565b6000818152600c60205260408120544210610f2857600080fd5b610ac582611947565b60006001600160a01b038216610f4657600080fd5b506001600160a01b03166000908152600a602052604090205490565b610f6a61100d565b610f7357600080fd5b6001546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600180547fffffffffffffffffffffffff0000000000000000000000000000000000000000169055565b610fdd61100d565b610fe657600080fd5b8051610ff9906007906020840190611f36565b5050565b6001546001600160a01b03165b90565b6001546001600160a01b0316331490565b6006805460408051602060026001851615610100026000190190941693909304601f81018490048402820184019092528181529291830182828015610b535780601f10610b2857610100808354040283529160200191610b53565b6000908152600c6020526040902054426276a7009091011090565b6001600160a01b0382163314156110aa57600080fd5b336000818152600b602090815260408083206001600160a01b0387168085529083529281902080547fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff0016861515908117909155815190815290519293927f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c31929181900390910190a35050565b61113e61100d565b61114757600080fd5b6001600160a01b03811660008181526004602052604080822080547fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff00166001179055517f0a8bb31534c0ed46f380cb867bd5c803a189ced9a764e30b3a4991a9901d74749190a250565b6111bc848484610c67565b6111c884848484611969565b610de657600080fd5b6276a70081565b600254600354604080517f02571be300000000000000000000000000000000000000000000000000000000815260048101929092525160009230926001600160a01b03909116916302571be391602480820192602092909190829003018186803b15801561124557600080fd5b505afa158015611259573d6000803e3d6000fd5b505050506040513d602081101561126f57600080fd5b50516001600160a01b03161461128457600080fd5b3360009081526004602052604090205460ff166112a057600080fd5b6000838152600c6020526040902054426276a70090910110156112c257600080fd5b6000838152600c60205260409020546276a70083810191840101116112e657600080fd5b6000838152600c602090815260409182902080548501908190558251908152915185927f9b87a00e30f1ac65d898f070f8a3488fe60517182d0a2098e1b4b93a54aa9bd692908290030190a250506000908152600c602052604090205490565b6000818152600860205260409020546060906001600160a01b031661136a57600080fd5b6060611374611ae6565b90506000815111611394576040518060200160405280600081525061148a565b8061139e84611b7c565b6040516020018083805190602001908083835b602083106113ee57805182527fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffe090920191602091820191016113b1565b51815160209384036101000a600019018019909216911617905285519190930192850191508083835b6020831061145457805182527fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffe09092019160209182019101611417565b6001836020036101000a038019825116818451168082178552505050505050905001925050506040516020818303038152906040525b9392505050565b6000908152600c602052604090205490565b60046020526000908152604090205460ff1681565b60035481565b6001600160a01b039182166000908152600b6020908152604080832093909416825291909152205460ff1690565b6114f461100d565b6114fd57600080fd5b61150681611c7b565b50565b61151161100d565b61151a57600080fd5b6001600160a01b03811660008181526004602052604080822080547fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff00169055517f33d83959be2573f5453b12eb9d43b3499bc57d96bd2f067ba44803c859e811139190a250565b6000610c5f84848460016115ad565b6000908152600860205260409020546001600160a01b0316151590565b600254600354604080517f02571be300000000000000000000000000000000000000000000000000000000815260048101929092525160009230926001600160a01b03909116916302571be391602480820192602092909190829003018186803b15801561161a57600080fd5b505afa15801561162e573d6000803e3d6000fd5b505050506040513d602081101561164457600080fd5b50516001600160a01b03161461165957600080fd5b3360009081526004602052604090205460ff1661167557600080fd5b61167e85611079565b61168757600080fd5b6276a70042016276a700844201011161169f57600080fd5b6000858152600c6020526040902042840190556116bb85611590565b156116c9576116c985611d02565b6116d38486611d14565b811561177f57600254600354604080517f06ab59230000000000000000000000000000000000000000000000000000000081526004810192909252602482018890526001600160a01b03878116604484015290519216916306ab5923916064808201926020929091908290030181600087803b15801561175257600080fd5b505af1158015611766573d6000803e3d6000fd5b505050506040513d602081101561177c57600080fd5b50505b60408051428501815290516001600160a01b0386169187917fb3d987963d01b2f68493b4bdb130988f157ea43070d4ad840fee0466ed9370d99181900360200190a35050420192915050565b6000806117d783610f0e565b9050806001600160a01b0316846001600160a01b031614806118125750836001600160a01b031661180784610b5b565b6001600160a01b0316145b80610c5f5750610c5f81856114be565b826001600160a01b031661183582610f0e565b6001600160a01b03161461184857600080fd5b6001600160a01b03821661185b57600080fd5b61186481611ddf565b6001600160a01b0383166000908152600a602052604090205461188e90600163ffffffff611e3216565b6001600160a01b038085166000908152600a602052604080822093909355908416815220546118c490600163ffffffff611e4716565b6001600160a01b038084166000818152600a60209081526040808320959095558582526008905283812080547fffffffffffffffffffffffff000000000000000000000000000000000000000016831790559251849391928716917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef91a4505050565b6000818152600860205260408120546001600160a01b031680610ac557600080fd5b600061197d846001600160a01b0316611e59565b61198957506001610c5f565b6040517f150b7a0200000000000000000000000000000000000000000000000000000000815233600482018181526001600160a01b03888116602485015260448401879052608060648501908152865160848601528651600095928a169463150b7a029490938c938b938b939260a4019060208501908083838e5b83811015611a1c578181015183820152602001611a04565b50505050905090810190601f168015611a495780820380516001836020036101000a031916815260200191505b5095505050505050602060405180830381600087803b158015611a6b57600080fd5b505af1158015611a7f573d6000803e3d6000fd5b505050506040513d6020811015611a9557600080fd5b50517fffffffff00000000000000000000000000000000000000000000000000000000167f150b7a020000000000000000000000000000000000000000000000000000000014915050949350505050565b60078054604080516020601f6002600019610100600188161502019095169490940493840181900481028201810190925282815260609390929091830182828015611b725780601f10611b4757610100808354040283529160200191611b72565b820191906000526020600020905b815481529060010190602001808311611b5557829003601f168201915b5050505050905090565b606081611bbd575060408051808201909152600181527f30000000000000000000000000000000000000000000000000000000000000006020820152610ac8565b8160005b8115611bd557600101600a82049150611bc1565b6060816040519080825280601f01601f191660200182016040528015611c02576020820181803883390190505b509050815b8515611c7257600019016000600a8704600a028703603001905060008160f81b905080848481518110611c3657fe5b60200101907effffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916908160001a905350600a880497505050611c07565b50949350505050565b6001600160a01b038116611c8e57600080fd5b6001546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600180547fffffffffffffffffffffffff0000000000000000000000000000000000000000166001600160a01b0392909216919091179055565b611506611d0e82610f0e565b82611e5f565b6001600160a01b038216611d2757600080fd5b611d3081611590565b15611d3a57600080fd5b600081815260086020908152604080832080547fffffffffffffffffffffffff0000000000000000000000000000000000000000166001600160a01b0387169081179091558352600a909152902054611d94906001611e47565b6001600160a01b0383166000818152600a60205260408082209390935591518392907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef908290a45050565b6000818152600960205260409020546001600160a01b03161561150657600090815260096020526040902080547fffffffffffffffffffffffff0000000000000000000000000000000000000000169055565b600082821115611e4157600080fd5b50900390565b60008282018381101561148a57600080fd5b3b151590565b816001600160a01b0316611e7282610f0e565b6001600160a01b031614611e8557600080fd5b611e8e81611ddf565b6001600160a01b0382166000908152600a6020526040902054611eb890600163ffffffff611e3216565b6001600160a01b0383166000818152600a60209081526040808320949094558482526008905282812080547fffffffffffffffffffffffff00000000000000000000000000000000000000001690559151839291907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef908390a45050565b828054600181600116156101000203166002900490600052602060002090601f016020900481019282601f10611f7757805160ff1916838001178555611fa4565b82800160010185558215611fa4579182015b82811115611fa4578251825591602001919060010190611f89565b50611fb0929150611fb4565b5090565b61100a91905b80821115611fb05760008155600101611fba56fe7472616e7366657246726f6d28616464726573732c616464726573732c75696e7432353629736166655472616e7366657246726f6d28616464726573732c616464726573732c75696e7432353629736166655472616e7366657246726f6d28616464726573732c616464726573732c75696e743235362c6279746573296973417070726f766564466f72416c6c28616464726573732c6164647265737329a265627a7a72315820d5fd311b852d8927cb40f7434fec8e2e486d6232260baf71cfcb7a92017a75fc64736f6c63430005100032

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

0000000000000000000000006c106583b7079794aa80f947fc09febc5276c9c5587d09fe5fa45354680537d38145a28b772971e0f293af3ee0c536fc919710fb

-----Decoded View---------------
Arg [0] : _ens (address): 0x6c106583B7079794Aa80F947FC09FEbc5276c9C5
Arg [1] : _baseNode (bytes32): 0x587d09fe5fa45354680537d38145a28b772971e0f293af3ee0c536fc919710fb

-----Encoded View---------------
2 Constructor Arguments found :
Arg [0] : 0000000000000000000000006c106583b7079794aa80f947fc09febc5276c9c5
Arg [1] : 587d09fe5fa45354680537d38145a28b772971e0f293af3ee0c536fc919710fb


Deployed Bytecode Sourcemap

26884:5439:0:-;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;26884:5439:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;32051:269;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;32051:269:0;;;;:::i;:::-;;;;;;;;;;;;;;;;;;10249:18;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8:100:-1;33:3;30:1;27:10;8:100;;;90:11;;;84:18;71:11;;;64:39;52:2;45:10;8:100;;;12:14;10249:18:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;14798:154;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;14798:154:0;;:::i;:::-;;;;-1:-1:-1;;;;;14798:154:0;;;;;;;;;;;;;;14206:299;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;;;;;;14206:299:0;;;;;;;;:::i;:::-;;30410:148;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;30410:148:0;;;-1:-1:-1;;;;;30410:148:0;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;16388:184;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;;;;;;16388:184:0;;;;;;;;;;;;;;;;;:::i;31749:180::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;31749:180:0;;;;;;-1:-1:-1;;;;;31749:180:0;;:::i;25510:14::-;;;:::i;17225:134::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;;;;;;17225:134:0;;;;;;;;;;;;;;;;;:::i;29189:112::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;29189:112:0;-1:-1:-1;;;;;29189:112:0;;:::i;10324:28::-;;;:::i;28513:155::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;28513:155:0;;:::i;12175:153::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;12175:153:0;-1:-1:-1;;;;;12175:153:0;;:::i;24173:140::-;;;:::i;31937:106::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;31937:106:0;;;;;;;;21:11:-1;5:28;;2:2;;;46:1;43;36:12;2:2;31937:106:0;;35:9:-1;28:4;12:14;8:25;5:40;2:2;;;58:1;55;48:12;2:2;31937:106:0;;;;;;100:9:-1;95:1;81:12;77:20;67:8;63:35;60:50;39:11;25:12;22:29;11:107;8:2;;;131:1;128;121:12;8:2;31937:106:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;30:3:-1;22:6;14;1:33;99:1;81:16;;74:27;;;;-1:-1;31937:106:0;;-1:-1:-1;31937:106:0;;-1:-1:-1;;;;;31937:106:0:i;23460:79::-;;;:::i;23795:92::-;;;:::i;10295:20::-;;;:::i;29553:190::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;29553:190:0;;:::i;15252:217::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;;;;;;15252:217:0;;;;;;;;;;:::i;28745:154::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;28745:154:0;-1:-1:-1;;;;;28745:154:0;;:::i;18078:214::-;;;;;;13:3:-1;8;5:12;2:2;;;30:1;27;20:12;2:2;-1:-1;;;;;18078:214:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;21:11:-1;5:28;;2:2;;;46:1;43;36:12;2:2;18078:214:0;;35:9:-1;28:4;12:14;8:25;5:40;2:2;;;58:1;55;48:12;2:2;18078:214:0;;;;;;100:9:-1;95:1;81:12;77:20;67:8;63:35;60:50;39:11;25:12;22:29;11:107;8:2;;;131:1;128;121:12;8:2;18078:214:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;30:3:-1;22:6;14;1:33;99:1;81:16;;74:27;;;;-1:-1;18078:214:0;;-1:-1:-1;18078:214:0;;-1:-1:-1;;;;;18078:214:0:i;25093:43::-;;;:::i;31221:421::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;31221:421:0;;;;;;;:::i;12912:282::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;12912:282:0;;:::i;29371:99::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;29371:99:0;;:::i;25704:41::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;25704:41:0;-1:-1:-1;;;;;25704:41:0;;:::i;25596:23::-;;;:::i;15798:147::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;;;;;;15798:147:0;;;;;;;;;;:::i;24490:109::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;24490:109:0;-1:-1:-1;;;;;24490:109:0;;:::i;28960:160::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;28960:160:0;-1:-1:-1;;;;;28960:160:0;;:::i;29989:143::-;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;29989:143:0;;;-1:-1:-1;;;;;29989:143:0;;;;;;;;;;:::i;32051:269::-;27074:38;;;;;;;;;;;;;;;;32121:4;;32145:32;;;;;;;;:76;;-1:-1:-1;27593:60:0;;;;;;;;;;;;;;;;;;-1:-1:-1;27593:60:0;27527:54;;27593:60;27527:54;;;;;;;;;;;;-1:-1:-1;27527:54:0;27465:50;;27527:54;27465:50;;;;;;;;;;;;-1:-1:-1;27465:50:0;27407:46;;27465:50;27407:46;;;;;;;;;;;;27351:44;;;;;;;;;;;;;27306:33;;;;;;;;;;;;;27257:37;;;;;;;;;;;;;27216:29;;;;;;;;;;;;;27173:31;;;;;;;;;;;;;;32197:24;;;;27173:72;;;;:121;;;:166;:222;:280;:342;;;;:408;;;;:480;;;;32197:24;;;-1:-1:-1;32145:76:0;:121;;;-1:-1:-1;27711:37:0;;;;;;;;;;;;;;;;32241:25;;;;;;;32145:121;:167;;;-1:-1:-1;27873:30:0;;;;;;;;;;;;;;;;27841:21;;;;;;;;;;;;;27811:19;;;;;;;;;;;;;;32286:26;;;;27811:51;;;;:92;;;32286:26;;;;;32145:167;32138:174;;32051:269;;;;:::o;10249:18::-;;;;;;;;;;;;;;;-1:-1:-1;;10249:18:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::o;14798:154::-;14857:7;14885:16;14893:7;14885;:16::i;:::-;14877:25;;;;;;-1:-1:-1;14920:24:0;;;;:15;:24;;;;;;-1:-1:-1;;;;;14920:24:0;;14798:154::o;14206:299::-;14270:13;14286:16;14294:7;14286;:16::i;:::-;14270:32;;14327:5;-1:-1:-1;;;;;14321:11:0;:2;-1:-1:-1;;;;;14321:11:0;;;14313:20;;;;;;14352:10;-1:-1:-1;;;;;14352:19:0;;;;:58;;;14375:35;14392:5;14399:10;14375:16;:35::i;:::-;14344:67;;;;;;14424:24;;;;:15;:24;;;;;;:29;;;;-1:-1:-1;;;;;14424:29:0;;;;;;;;;14469:28;;14424:24;;14469:28;;;;;;;14206:299;;;:::o;30410:148::-;30491:4;30513:37;30523:2;30527:5;30534:8;30544:5;30513:9;:37::i;:::-;30506:44;30410:148;-1:-1:-1;;;;30410:148:0:o;16388:184::-;16479:39;16498:10;16510:7;16479:18;:39::i;:::-;16471:48;;;;;;16532:32;16546:4;16552:2;16556:7;16532:13;:32::i;:::-;16388:184;;;:::o;31749:180::-;28068:3;;28078:8;;28068:19;;;;;;;;;;;;;;28099:4;;-1:-1:-1;;;;;28068:3:0;;:9;;:19;;;;;;;;;;;;;;:3;:19;;;5:2:-1;;;;30:1;27;20:12;5:2;28068:19:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;28068:19:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;28068:19:0;-1:-1:-1;;;;;28068:36:0;;28060:45;;;;;;31826:34;31845:10;31857:2;31826:18;:34::i;:::-;31818:43;;;;;;31872:3;;31892:8;;31872:49;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;31872:49:0;;;;;;;;;:3;;;:19;;:49;;;;;;;;;;;;;;;:3;;:49;;;5:2:-1;;;;30:1;27;20:12;5:2;31872:49:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;31872:49:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;;;;31749:180:0:o;25510:14::-;;;-1:-1:-1;;;;;25510:14:0;;:::o;17225:134::-;17312:39;17329:4;17335:2;17339:7;17312:39;;;;;;;;;;;;:16;:39::i;29189:112::-;23672:9;:7;:9::i;:::-;23664:18;;;;;;29258:3;;29274:8;;29258:35;;;;;;;;;;;;;-1:-1:-1;;;;;29258:35:0;;;;;;;;;:3;;;:15;;:35;;;;;:3;;:35;;;;;;;;:3;;:35;;;5:2:-1;;;;30:1;27;20:12;5:2;29258:35:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;29258:35:0;;;;29189:112;:::o;10324:28::-;;;;;;;;;;;;;;;-1:-1:-1;;10324:28:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;28513:155;28568:7;28596:17;;;:8;:17;;;;;;28616:3;-1:-1:-1;28588:32:0;;;;;;28638:22;28652:7;28638:13;:22::i;12175:153::-;12230:7;-1:-1:-1;;;;;12258:19:0;;12250:28;;;;;;-1:-1:-1;;;;;;12296:24:0;;;;;:17;:24;;;;;;;12175:153::o;24173:140::-;23672:9;:7;:9::i;:::-;23664:18;;;;;;24256:6;;24235:40;;24272:1;;-1:-1:-1;;;;;24256:6:0;;24235:40;;24272:1;;24235:40;24286:6;:19;;;;;;24173:140::o;31937:106::-;23672:9;:7;:9::i;:::-;23664:18;;;;;;32013:22;;;;:9;;:22;;;;;:::i;:::-;;31937:106;:::o;23460:79::-;23525:6;;-1:-1:-1;;;;;23525:6:0;23460:79;;:::o;23795:92::-;23873:6;;-1:-1:-1;;;;;23873:6:0;23859:10;:20;;23795:92::o;10295:20::-;;;;;;;;;;;;;;;-1:-1:-1;;10295:20:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;29553:190;29604:4;29702:12;;;:8;:12;;;;;;29732:3;25129:7;29702:27;;;:33;;29553:190::o;15252:217::-;-1:-1:-1;;;;;15332:16:0;;15338:10;15332:16;;15324:25;;;;;;15379:10;15360:30;;;;:18;:30;;;;;;;;-1:-1:-1;;;;;15360:34:0;;;;;;;;;;;;:45;;;;;;;;;;;;;15421:40;;;;;;;15360:34;;15379:10;15421:40;;;;;;;;;;;15252:217;;:::o;28745:154::-;23672:9;:7;:9::i;:::-;23664:18;;;;;;-1:-1:-1;;;;;28818:23:0;;;;;;:11;:23;;;;;;:30;;;;28844:4;28818:30;;;28864:27;;;28818:23;28864:27;28745:154;:::o;18078:214::-;18185:31;18198:4;18204:2;18208:7;18185:12;:31::i;:::-;18235:48;18258:4;18264:2;18268:7;18277:5;18235:22;:48::i;:::-;18227:57;;;;;25093:43;25129:7;25093:43;:::o;31221:421::-;28068:3;;28078:8;;28068:19;;;;;;;;;;;;;;-1:-1:-1;;28099:4:0;;-1:-1:-1;;;;;28068:3:0;;;;:9;;:19;;;;;;;;;;;;;;;:3;:19;;;5:2:-1;;;;30:1;27;20:12;5:2;28068:19:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;28068:19:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;28068:19:0;-1:-1:-1;;;;;28068:36:0;;28060:45;;;;;;28188:10;28176:23;;;;:11;:23;;;;;;;;28168:32;;;;;;31325:12;;;;:8;:12;;;;;;31356:3;25129:7;31325:27;;;:34;;31317:43;;;;;;31430:12;;;;:8;:12;;;;;;25129:7;31471:23;;;31430;;;:38;:64;31422:73;;;;;;31535:12;;;;:8;:12;;;;;;;;;:24;;;;;;;;31575:29;;;;;;;31544:2;;31575:29;;;;;;;;;-1:-1:-1;;31622:12:0;;;;:8;:12;;;;;;;31221:421::o;12912:282::-;13035:1;13003:20;;;:11;:20;;;;;;12969:13;;-1:-1:-1;;;;;13003:20:0;12995:43;;;;;;13049:21;13073:10;:8;:10::i;:::-;13049:34;;13125:1;13107:7;13101:21;:25;:85;;;;;;;;;;;;;;;;;13153:7;13162:17;13171:7;13162:8;:17::i;:::-;13136:44;;;;;;;;;;;;;;;36:153:-1;66:2;61:3;58:11;36:153;;176:10;;164:23;;139:12;;;;;98:2;89:12;;;;114;36:153;;;299:10;344;;263:2;259:12;;;254:3;250:22;-1:-1;;246:30;311:9;;295:26;;;340:21;;377:20;365:33;;13136:44:0;;;;;;;;;;-1:-1:-1;13136:44:0;;;36:153:-1;66:2;61:3;58:11;36:153;;176:10;;164:23;;139:12;;;;;98:2;89:12;;;;114;36:153;;;274:1;267:3;263:2;259:12;254:3;250:22;246:30;315:4;311:9;305:3;299:10;295:26;356:4;350:3;344:10;340:21;389:7;380;377:20;372:3;365:33;3:399;;;13136:44:0;;;;;;;;;;;;49:4:-1;39:7;30;26:21;22:32;13:7;6:49;13136:44:0;;;13101:85;13094:92;12912:282;-1:-1:-1;;;12912:282:0:o;29371:99::-;29426:4;29450:12;;;:8;:12;;;;;;;29371:99::o;25704:41::-;;;;;;;;;;;;;;;:::o;25596:23::-;;;;:::o;15798:147::-;-1:-1:-1;;;;;15902:25:0;;;15878:4;15902:25;;;:18;:25;;;;;;;;:35;;;;;;;;;;;;;;;15798:147::o;24490:109::-;23672:9;:7;:9::i;:::-;23664:18;;;;;;24563:28;24582:8;24563:18;:28::i;:::-;24490:109;:::o;28960:160::-;23672:9;:7;:9::i;:::-;23664:18;;;;;;-1:-1:-1;;;;;29036:23:0;;29062:5;29036:23;;;:11;:23;;;;;;:31;;;;;;29083:29;;;29062:5;29083:29;28960:160;:::o;29989:143::-;30066:4;30088:36;30098:2;30102:5;30109:8;30119:4;30088:9;:36::i;18488:155::-;18545:4;18578:20;;;:11;:20;;;;;;-1:-1:-1;;;;;18578:20:0;18616:19;;;18488:155::o;30566:647::-;28068:3;;28078:8;;28068:19;;;;;;;;;;;;;;-1:-1:-1;;28099:4:0;;-1:-1:-1;;;;;28068:3:0;;;;:9;;:19;;;;;;;;;;;;;;;:3;:19;;;5:2:-1;;;;30:1;27;20:12;5:2;28068:19:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;28068:19:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;28068:19:0;-1:-1:-1;;;;;28068:36:0;;28060:45;;;;;;28188:10;28176:23;;;;:11;:23;;;;;;;;28168:32;;;;;;30710:13;30720:2;30710:9;:13::i;:::-;30702:22;;;;;;25129:7;30775:3;:18;25129:7;30749:8;30743:3;:14;:29;:50;30735:59;;;;;;30834:12;;;;:8;:12;;;;;30849:3;:14;;30834:29;;30877:11;30843:2;30877:7;:11::i;:::-;30874:107;;;30960:9;30966:2;30960:5;:9::i;:::-;30991:16;30997:5;31004:2;30991:5;:16::i;:::-;31021:14;31018:95;;;31052:3;;31072:8;;31052:49;;;;;;;;;;;;;;;;;;;-1:-1:-1;;;;;31052:49:0;;;;;;;;;:3;;;:19;;:49;;;;;;;;;;;;;;;:3;;:49;;;5:2:-1;;;;30:1;27;20:12;5:2;31052:49:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;31052:49:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;;31018:95:0;31130:41;;;31156:3;:14;;31130:41;;;;-1:-1:-1;;;;;31130:41:0;;;31145:2;;31130:41;;;;;;;;;-1:-1:-1;;31191:3:0;:14;;30566:647;-1:-1:-1;;30566:647:0:o;19015:249::-;19100:4;19117:13;19133:16;19141:7;19133;:16::i;:::-;19117:32;;19179:5;-1:-1:-1;;;;;19168:16:0;:7;-1:-1:-1;;;;;19168:16:0;;:51;;;;19212:7;-1:-1:-1;;;;;19188:31:0;:20;19200:7;19188:11;:20::i;:::-;-1:-1:-1;;;;;19188:31:0;;19168:51;:87;;;;19223:32;19240:5;19247:7;19223:16;:32::i;21058:414::-;21172:4;-1:-1:-1;;;;;21152:24:0;:16;21160:7;21152;:16::i;:::-;-1:-1:-1;;;;;21152:24:0;;21144:33;;;;;;-1:-1:-1;;;;;21196:16:0;;21188:25;;;;;;21226:23;21241:7;21226:14;:23::i;:::-;-1:-1:-1;;;;;21288:23:0;;;;;;:17;:23;;;;;;:30;;21316:1;21288:30;:27;:30;:::i;:::-;-1:-1:-1;;;;;21262:23:0;;;;;;;:17;:23;;;;;;:56;;;;21353:21;;;;;;;:28;;21379:1;21353:28;:25;:28;:::i;:::-;-1:-1:-1;;;;;21329:21:0;;;;;;;:17;:21;;;;;;;;:52;;;;21394:20;;;:11;:20;;;;;:25;;;;;;;;21437:27;;21406:7;;21329:21;;21437:27;;;;;;21058:414;;;:::o;12559:181::-;12614:7;12650:20;;;:11;:20;;;;;;-1:-1:-1;;;;;12650:20:0;12689:19;12681:28;;;;;22006:356;22128:4;22155:15;:2;-1:-1:-1;;;;;22155:13:0;;:15::i;:::-;22150:60;;-1:-1:-1;22194:4:0;22187:11;;22150:60;22238:70;;;;;22275:10;22238:70;;;;;;-1:-1:-1;;;;;22238:70:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;22222:13;;22238:36;;;;;;22275:10;;22287:4;;22293:7;;22302:5;;22238:70;;;;;;;;;;;22222:13;8:100:-1;33:3;30:1;27:10;8:100;;;90:11;;;84:18;71:11;;;64:39;52:2;45:10;8:100;;;12:14;22238:70:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;22238:70:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;22238:70:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;-1:-1;22238:70:0;22327:26;;22337:16;22327:26;;-1:-1:-1;;22006:356:0;;;;;;:::o;12748:93::-;12824:9;12817:16;;;;;;;;-1:-1:-1;;12817:16:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;12791:13;;12817:16;;12824:9;;12817:16;;12824:9;12817:16;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;12748:93;:::o;13202:573::-;13252:27;13296:7;13292:50;;-1:-1:-1;13320:10:0;;;;;;;;;;;;;;;;;;;13292:50;13361:2;13352:6;13393:69;13400:6;;13393:69;;13423:5;;13448:2;13443:7;;;;13393:69;;;13472:17;13502:3;13492:14;;;;;;;;;;;;;;;;;;;;;;;;;21:6:-1;;104:10;13492:14:0;87:34:-1;135:17;;-1:-1;13492:14:0;-1:-1:-1;13472:34:0;-1:-1:-1;13526:3:0;13540:198;13547:7;;13540:198;;-1:-1:-1;;13575:3:0;13593:10;13628:2;13623;:7;13633:2;13623:12;13618:2;:17;13607:2;:29;13593:44;;13652:9;13671:4;13664:12;;13652:24;;13701:2;13691:4;13696:1;13691:7;;;;;;;;;;;:12;;;;;;;;;;-1:-1:-1;13724:2:0;13718:8;;;;13540:198;;;;;-1:-1:-1;13762:4:0;13202:573;-1:-1:-1;;;;13202:573:0:o;24749:187::-;-1:-1:-1;;;;;24823:22:0;;24815:31;;;;;;24883:6;;24862:38;;-1:-1:-1;;;;;24862:38:0;;;;24883:6;;24862:38;;24883:6;;24862:38;24911:6;:17;;;;-1:-1:-1;;;;;24911:17:0;;;;;;;;;;24749:187::o;20583:92::-;20635:32;20641:16;20649:7;20641;:16::i;:::-;20659:7;20635:5;:32::i;19515:286::-;-1:-1:-1;;;;;19587:16:0;;19579:25;;;;;;19624:16;19632:7;19624;:16::i;:::-;19623:17;19615:26;;;;;;19654:20;;;;:11;:20;;;;;;;;:25;;;;-1:-1:-1;;;;;19654:25:0;;;;;;;;19714:21;;:17;:21;;;;;;:28;;-1:-1:-1;19714:25:0;:28::i;:::-;-1:-1:-1;;;;;19690:21:0;;;;;;:17;:21;;;;;;:52;;;;19760:33;;19785:7;;19690:21;19760:33;;19690:21;;19760:33;19515:286;;:::o;22529:175::-;22629:1;22593:24;;;:15;:24;;;;;;-1:-1:-1;;;;;22593:24:0;:38;22589:108;;22683:1;22648:24;;;:15;:24;;;;;:37;;;;;;22529:175::o;6150:150::-;6208:7;6241:1;6236;:6;;6228:15;;;;;;-1:-1:-1;6266:5:0;;;6150:150::o;6386:::-;6444:7;6476:5;;;6500:6;;;;6492:15;;;;;7363:627;7935:20;7974:8;;;7363:627::o;20083:314::-;20178:5;-1:-1:-1;;;;;20158:25:0;:16;20166:7;20158;:16::i;:::-;-1:-1:-1;;;;;20158:25:0;;20150:34;;;;;;20197:23;20212:7;20197:14;:23::i;:::-;-1:-1:-1;;;;;20260:24:0;;;;;;:17;:24;;;;;;:31;;20289:1;20260:31;:28;:31;:::i;:::-;-1:-1:-1;;;;;20233:24:0;;;;;;:17;:24;;;;;;;;:58;;;;20302:20;;;:11;:20;;;;;:33;;;;;;20353:36;;20314:7;;20233:24;;20353:36;;20233:24;;20353:36;20083:314;;:::o;26884:5439::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;26884:5439:0;;;-1:-1:-1;26884:5439:0;:::i;:::-;;;:::o;:::-;;;;;;;;;;;;;;;;;

Swarm Source

bzzr://d5fd311b852d8927cb40f7434fec8e2e486d6232260baf71cfcb7a92017a75fc
Loading...
Loading
Loading...
Loading
[ Download: CSV Export  ]
[ Download: CSV Export  ]

A token is a representation of an on-chain or off-chain asset. The token page shows information such as price, total supply, holders, transfers and social links. Learn more about this page in our Knowledge Base.