Contract 0xc1Caf0C19A8AC28c41Fe59bA6c754e4b9bd54dE9 3

 
Txn Hash
Method
Block
From
To
Value
0x4d15c3afaf818357bc493c2578b1602ad855acdc9c00d0e917de5e8258d25f42Safe Transfer Fr...153662862022-08-18 17:23:155 hrs 36 mins ago0x93aaf89387ca8319ebbd937ae888d10a580fa897 IN  CryptoSkulls: CryptoSkulls Token0 Ether0.‍00394308 37.‍008995
0x102017a46f7d123d97c8fd8afadb4687c7e0bc9762a1074ba504d4a05f0ac8f2Set Approval For...153662732022-08-18 17:19:555 hrs 39 mins ago0x23ab5dc8ad77b3dab371bc8b577a33b62216ed98 IN  CryptoSkulls: CryptoSkulls Token0 Ether0.‍00121492 26.‍33694095
0x20c452cc90517c6f57b2c44dc90fb7086be732a8bd6035f16b613d551e9340fdSet Approval For...153660422022-08-18 16:26:196 hrs 33 mins agoENS Name z00t.eth IN  CryptoSkulls: CryptoSkulls Token0 Ether0.‍00144965 31.‍42533485
0x47454ba2d4ee6c10697996b585fa7d544ac5528422a464834a0b604ed15e7a10Set Approval For...153656552022-08-18 14:56:278 hrs 3 mins ago0xab0763815f1d2df957526e18edc062469ae05b14 IN  CryptoSkulls: CryptoSkulls Token0 Ether0.‍00155404 33.‍68835681
0x6d7484f94b591ade1a64fc492aeae99de1ebcbf636817c0f834f7424f47887e4Safe Transfer Fr...153656282022-08-18 14:51:538 hrs 7 mins agoENS Name 0x-art.eth IN  CryptoSkulls: CryptoSkulls Token0 Ether0.‍00203098 17.‍79313882
0xa84887457b58e88f0db7e8db764fdf7e1607108e55dea7950be61563814ee1dcSet Approval For...153643792022-08-18 10:05:3112 hrs 53 mins ago0x42a6649e216b9d1ade1d48a214b90efa16bfea17 IN  CryptoSkulls: CryptoSkulls Token0 Ether0.‍00033297 7.‍21813397
0x8dea94d2e73e5b092426efefac2f2c1c1eb43facdabcb1c216b1bb3cb9d6cdf5Set Approval For...153643272022-08-18 9:53:1613 hrs 6 mins ago0xd1563584b36f03bbe7319d3cf4183700b3bfb24e IN  CryptoSkulls: CryptoSkulls Token0 Ether0.‍00026543 5.‍75405019
0x879520b8b4b5328f698aa87a71ecd89e3d2a12828d97f4b4ec494d67ac59dbf0Set Approval For...153639442022-08-18 8:29:1014 hrs 30 mins ago0x160e47b9d0e946356e91ec909a662a576213724c IN  CryptoSkulls: CryptoSkulls Token0 Ether0.‍00043053 9.‍33316232
0x726083520018bb8d9dff341d7f5f85844b2f512b0ce98091050ac7237415446fSafe Transfer Fr...153635622022-08-18 6:53:2916 hrs 5 mins ago0x91a0edde67ba3e14585fd3f482a751870dcf2fd6 IN  CryptoSkulls: CryptoSkulls Token0 Ether0.‍00076361 8.‍27816176
0x46f474fe50c7182fb0caa3117f1586486e35dcc65a60e3a7f5a93555b87e8681Safe Transfer Fr...153635592022-08-18 6:53:1016 hrs 6 mins ago0x91a0edde67ba3e14585fd3f482a751870dcf2fd6 IN  CryptoSkulls: CryptoSkulls Token0 Ether0.‍00082658 9.‍75395161
0x9292bfe06cf61d3849b5a4b95953ecaf498bd0f8d4148059cc8dde9d9a0d96f5Safe Transfer Fr...153635562022-08-18 6:52:2316 hrs 7 mins ago0x91a0edde67ba3e14585fd3f482a751870dcf2fd6 IN  CryptoSkulls: CryptoSkulls Token0 Ether0.‍00087338 8.‍10827413
0x25261e20f5a291c0fe7928241c8667d568e7d886b8aff216f6ec1a576b80437eSet Approval For...153630352022-08-18 4:51:5018 hrs 7 mins ago0x246f12ac4dc03a9b6284de458d284c709a9a60e3 IN  CryptoSkulls: CryptoSkulls Token0 Ether0.‍00030804 6.‍67768446
0x07ba3f637442a33b900972e78d4ce8b44bb0dc0e5d5425f54dceb9667ab4bfa5Set Approval For...153618712022-08-18 0:33:0022 hrs 26 mins ago0x7dff47820fa7ef1c2eae54803b9c06a6fcace40d IN  CryptoSkulls: CryptoSkulls Token0 Ether0.‍00066659 14.‍42405621
0x5c127357de0c2942b3cfef3fc98de73f88856507a6a94d56a39614ef4b9cfea1Set Approval For...153618662022-08-18 0:31:3322 hrs 27 mins ago0x7dff47820fa7ef1c2eae54803b9c06a6fcace40d IN  CryptoSkulls: CryptoSkulls Token0 Ether0.‍00065589 14.‍21831502
0x542c14ba6fcacf282c74aecc8f222a0dd336bf6fd6ff417d37eeffb733a652c0Set Approval For...153617182022-08-17 23:59:5622 hrs 59 mins agoENS Name calzonenft.eth IN  CryptoSkulls: CryptoSkulls Token0 Ether0.‍00049931 10.‍80441734
0xbd2717eab49375ce87068f7d1d983e62735a565415e2e58aabcbebee08be79f4Transfer From153616762022-08-17 23:50:1723 hrs 9 mins ago0xd40de9d4389021192cc8607bd4c85e2d682bf097 IN  CryptoSkulls: CryptoSkulls Token0 Ether0.‍00214873 20.‍71985337
0x3f2dd03862547f7df3ccad09588afb71feecd29421ff324c80eada250db1cbf9Set Approval For...153613462022-08-17 22:36:261 day 23 mins ago0xea66e134e87e1811a1c3b12608e345fee146cf6f IN  CryptoSkulls: CryptoSkulls Token0 Ether0.‍00051354 11.‍13251499
0x9f737edc077aeb1541916480c4ba9d0ac6ca8bdfda230ae5e566556468f46883Set Approval For...153602712022-08-17 18:19:331 day 4 hrs agoENS Name mdilone.eth IN  CryptoSkulls: CryptoSkulls Token0 Ether0.‍00174977 37.‍93137911
0x54be875314b3a83100a80e395c164d0364b5bd3287e463a93446f2d6ef9d9c84Safe Transfer Fr...153595772022-08-17 15:40:371 day 7 hrs agoCryptoSkulls: Deployer IN  CryptoSkulls: CryptoSkulls Token0 Ether0.‍00078163 8.‍191944
0x29c8b8b43334da28fb3332cecd4d3195874134c1dd6919247efe41ae9f8484acSet Approval For...153573302022-08-17 7:18:261 day 15 hrs ago0x1e5da7c4355455f14221d507b88f6c794b749ce0 IN  CryptoSkulls: CryptoSkulls Token0 Ether0.‍0003946 8.‍55414072
0xe25437292babe191dc738bff96fab6c7c7c6a0c9b3e5b32a4454c88d168c1452Set Approval For...153569072022-08-17 5:35:451 day 17 hrs agoENS Name goonler.eth IN  CryptoSkulls: CryptoSkulls Token0 Ether0.‍00024792 5.‍37444625
0x60c0545e8b275d3196d22a24a06a96c2c4c032cd1ee0ce0b583841e0479b87ccSet Approval For...153568812022-08-17 5:30:531 day 17 hrs ago0xfeb1797e4f6fc613e556eb62724e29a08c5ca2d9 IN  CryptoSkulls: CryptoSkulls Token0 Ether0.‍00025551 5.‍53908603
0x02defa78c77fbe5d16719bf2b34d3b9da254e55bc9eca82dc059b7c7b18b1471Set Approval For...153563402022-08-17 3:35:101 day 19 hrs agoENS Name metafool.eth IN  CryptoSkulls: CryptoSkulls Token0 Ether0.‍0006734914.‍6
0xe10baa80725553eb41e332765a6e48c3c5fc897cdb77b481c3ebabb18f34925eSet Approval For...153558222022-08-17 1:26:501 day 21 hrs ago0x15781d87d6515b52ae4cb5be5e30925691aed2a8 IN  CryptoSkulls: CryptoSkulls Token0 Ether0.‍00051124 11.‍08270807
0x7807780359e727b597ffbb098fa66f02bdd7aa156e79e3b7f91427432824a6d4Safe Transfer Fr...153557742022-08-17 1:16:151 day 21 hrs ago0xa25cfd946019835d521cc963212b68dc7ba7036e IN  CryptoSkulls: CryptoSkulls Token0 Ether0.‍001050859.‍8
[ Download CSV Export 

OVERVIEW

CryptoSkulls are 10,000 collectible ERC-721 Non-Fungible Tokens. CryptoSkulls characters are unique pixel art images with Uniqueness Index property that represents the rareness of the token.

View more zero value Internal Transactions in Advanced View mode
Loading

Contract Source Code Verified (Exact Match)

Contract Name:
CryptoSkulls

Compiler Version
v0.5.2+commit.1df8f40c

Optimization Enabled:
No with 200 runs

Other Settings:
default evmVersion

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2019-05-20
*/

pragma solidity ^0.5.2;

/**
 * @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;
    }
}


/**
 * @title IERC165
 * @dev https://eips.ethereum.org/EIPS/eip-165
 */
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);
}




/**
 * @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;
    }
}


library Strings {
    // via https://github.com/oraclize/ethereum-api/blob/master/oraclizeAPI_0.5.sol
    function strConcat(string memory _a, string memory _b, string memory _c, string memory _d, string memory _e) internal pure returns (string memory) {
        bytes memory _ba = bytes(_a);
        bytes memory _bb = bytes(_b);
        bytes memory _bc = bytes(_c);
        bytes memory _bd = bytes(_d);
        bytes memory _be = bytes(_e);
        string memory abcde = new string(_ba.length + _bb.length + _bc.length + _bd.length + _be.length);
        bytes memory babcde = bytes(abcde);
        uint k = 0;
        for (uint i = 0; i < _ba.length; i++) babcde[k++] = _ba[i];
        for (uint i = 0; i < _bb.length; i++) babcde[k++] = _bb[i];
        for (uint i = 0; i < _bc.length; i++) babcde[k++] = _bc[i];
        for (uint i = 0; i < _bd.length; i++) babcde[k++] = _bd[i];
        for (uint i = 0; i < _be.length; i++) babcde[k++] = _be[i];
        return string(babcde);
    }

    function strConcat(string memory _a, string memory _b, string memory _c, string memory _d) internal pure returns (string memory) {
        return strConcat(_a, _b, _c, _d, "");
    }

    function strConcat(string memory _a, string memory _b, string memory _c) internal pure returns (string memory) {
        return strConcat(_a, _b, _c, "", "");
    }

    function strConcat(string memory _a, string memory _b) internal pure returns (string memory) {
        return strConcat(_a, _b, "", "", "");
    }

    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 - 1;
        while (_i != 0) {
            bstr[k--] = byte(uint8(48 + _i % 10));
            _i /= 10;
        }
        return string(bstr);
    }
}










/**
 * @title ERC721 Non-Fungible Token Standard basic interface
 * @dev see https://eips.ethereum.org/EIPS/eip-721
 */
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;
}



/**
 * @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 `bytes4(keccak256("onERC721Received(address,address,uint256,bytes)"))`
     */
    function onERC721Received(address operator, address from, uint256 tokenId, bytes memory data)
    public returns (bytes4);
}




/**
 * 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;
    }
}





/**
 * @title Counters
 * @author Matt Condon (@shrugs)
 * @dev Provides counters that can only be incremented or decremented by one. This can be used e.g. to track the number
 * of elements in a mapping, issuing ERC721 ids, or counting request ids
 *
 * Include with `using Counters for Counters.Counter;`
 * Since it is not possible to overflow a 256 bit integer with increments of one, `increment` can skip the SafeMath
 * overflow check, thereby saving gas. This does assume however correct usage, in that the underlying `_value` is never
 * directly accessed.
 */
library Counters {
    using SafeMath for uint256;

    struct Counter {
        // This variable should never be directly accessed by users of the library: interactions must be restricted to
        // the library's function. As of Solidity v0.5.2, this cannot be enforced, though there is a proposal to add
        // this feature: see https://github.com/ethereum/solidity/issues/4637
        uint256 _value; // default: 0
    }

    function current(Counter storage counter) internal view returns (uint256) {
        return counter._value;
    }

    function increment(Counter storage counter) internal {
        counter._value += 1;
    }

    function decrement(Counter storage counter) internal {
        counter._value = counter._value.sub(1);
    }
}



/**
 * @title ERC721 Non-Fungible Token Standard basic implementation
 * @dev see https://eips.ethereum.org/EIPS/eip-721
 */
contract ERC721 is ERC165, IERC721 {
    using SafeMath for uint256;
    using Address for address;
    using Counters for Counters.Counter;

    // Equals to `bytes4(keccak256("onERC721Received(address,address,uint256,bytes)"))`
    // which can be also obtained as `IERC721Receiver(0).onERC721Received.selector`
    bytes4 private constant _ERC721_RECEIVED = 0x150b7a02;

    // Mapping from token ID to owner
    mapping (uint256 => address) private _tokenOwner;

    // Mapping from token ID to approved address
    mapping (uint256 => address) private _tokenApprovals;

    // Mapping from owner to number of owned token
    mapping (address => Counters.Counter) private _ownedTokensCount;

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

    bytes4 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);
    }

    /**
     * @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].current();
    }

    /**
     * @dev Gets the owner of the specified token ID
     * @param tokenId uint256 ID of the token to query the owner of
     * @return address currently marked as the owner of the given token ID
     */
    function ownerOf(uint256 tokenId) public view returns (address) {
        address owner = _tokenOwner[tokenId];
        require(owner != address(0));
        return owner;
    }

    /**
     * @dev Approves another address to transfer the given token ID
     * The zero address indicates there is no approved address.
     * There can only be one approved address per token at a given time.
     * Can only be called by the token owner or an approved operator.
     * @param to address to be approved for the given token ID
     * @param tokenId uint256 ID of the token to be approved
     */
    function approve(address to, uint256 tokenId) public {
        address owner = ownerOf(tokenId);
        require(to != owner);
        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 bool whether the token exists
     */
    function _exists(uint256 tokenId) internal view returns (bool) {
        address owner = _tokenOwner[tokenId];
        return owner != address(0);
    }

    /**
     * @dev Returns whether the given spender can transfer a given token ID
     * @param spender address of the spender to query
     * @param tokenId uint256 ID of the token to be transferred
     * @return bool whether the msg.sender is approved for the given token ID,
     * is an operator of the owner, or is the owner of the token
     */
    function _isApprovedOrOwner(address spender, uint256 tokenId) internal view returns (bool) {
        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].increment();

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

    /**
     * @dev Internal function to burn a specific token
     * Reverts if the token does not exist
     * Deprecated, use _burn(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].decrement();
        _tokenOwner[tokenId] = address(0);

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

    /**
     * @dev Internal function to burn a specific token
     * Reverts if the token does not exist
     * @param tokenId uint256 ID of the token being burned
     */
    function _burn(uint256 tokenId) internal {
        _burn(ownerOf(tokenId), tokenId);
    }

    /**
     * @dev Internal function to transfer ownership of a given token ID to another address.
     * As opposed to transferFrom, this imposes no restrictions on msg.sender.
     * @param from current owner of the token
     * @param to address to receive the ownership of the given token ID
     * @param tokenId uint256 ID of the token to be transferred
     */
    function _transferFrom(address from, address to, uint256 tokenId) internal {
        require(ownerOf(tokenId) == from);
        require(to != address(0));

        _clearApproval(tokenId);

        _ownedTokensCount[from].decrement();
        _ownedTokensCount[to].increment();

        _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 bool whether the call correctly returned the expected magic value
     */
    function _checkOnERC721Received(address from, address to, uint256 tokenId, bytes memory _data)
        internal returns (bool)
    {
        if (!to.isContract()) {
            return true;
        }

        bytes4 retval = IERC721Receiver(to).onERC721Received(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);
        }
    }
}







/**
 * @title ERC-721 Non-Fungible Token Standard, optional enumeration extension
 * @dev See https://eips.ethereum.org/EIPS/eip-721
 */
contract IERC721Enumerable is IERC721 {
    function totalSupply() public view returns (uint256);
    function tokenOfOwnerByIndex(address owner, uint256 index) public view returns (uint256 tokenId);

    function tokenByIndex(uint256 index) public view returns (uint256);
}




/**
 * @title ERC-721 Non-Fungible Token with optional enumeration extension logic
 * @dev See https://eips.ethereum.org/EIPS/eip-721
 */
contract ERC721Enumerable is ERC165, ERC721, IERC721Enumerable {
    // Mapping from owner to list of owned token IDs
    mapping(address => uint256[]) private _ownedTokens;

    // Mapping from token ID to index of the owner tokens list
    mapping(uint256 => uint256) private _ownedTokensIndex;

    // Array with all token ids, used for enumeration
    uint256[] private _allTokens;

    // Mapping from token id to position in the allTokens array
    mapping(uint256 => uint256) private _allTokensIndex;

    bytes4 private constant _INTERFACE_ID_ERC721_ENUMERABLE = 0x780e9d63;
    /*
     * 0x780e9d63 ===
     *     bytes4(keccak256('totalSupply()')) ^
     *     bytes4(keccak256('tokenOfOwnerByIndex(address,uint256)')) ^
     *     bytes4(keccak256('tokenByIndex(uint256)'))
     */

    /**
     * @dev Constructor function
     */
    constructor () public {
        // register the supported interface to conform to ERC721Enumerable via ERC165
        _registerInterface(_INTERFACE_ID_ERC721_ENUMERABLE);
    }

    /**
     * @dev Gets the token ID at a given index of the tokens list of the requested owner
     * @param owner address owning the tokens list to be accessed
     * @param index uint256 representing the index to be accessed of the requested tokens list
     * @return uint256 token ID at the given index of the tokens list owned by the requested address
     */
    function tokenOfOwnerByIndex(address owner, uint256 index) public view returns (uint256) {
        require(index < balanceOf(owner));
        return _ownedTokens[owner][index];
    }

    /**
     * @dev Gets the total amount of tokens stored by the contract
     * @return uint256 representing the total amount of tokens
     */
    function totalSupply() public view returns (uint256) {
        return _allTokens.length;
    }

    /**
     * @dev Gets the token ID at a given index of all the tokens in this contract
     * Reverts if the index is greater or equal to the total number of tokens
     * @param index uint256 representing the index to be accessed of the tokens list
     * @return uint256 token ID at the given index of the tokens list
     */
    function tokenByIndex(uint256 index) public view returns (uint256) {
        require(index < totalSupply());
        return _allTokens[index];
    }

    /**
     * @dev Internal function to transfer ownership of a given token ID to another address.
     * As opposed to transferFrom, this imposes no restrictions on msg.sender.
     * @param from current owner of the token
     * @param to address to receive the ownership of the given token ID
     * @param tokenId uint256 ID of the token to be transferred
     */
    function _transferFrom(address from, address to, uint256 tokenId) internal {
        super._transferFrom(from, to, tokenId);

        _removeTokenFromOwnerEnumeration(from, tokenId);

        _addTokenToOwnerEnumeration(to, tokenId);
    }

    /**
     * @dev Internal function to mint a new token
     * Reverts if the given token ID already exists
     * @param to address the beneficiary that will own the minted token
     * @param tokenId uint256 ID of the token to be minted
     */
    function _mint(address to, uint256 tokenId) internal {
        super._mint(to, tokenId);

        _addTokenToOwnerEnumeration(to, tokenId);

        _addTokenToAllTokensEnumeration(tokenId);
    }

    /**
     * @dev Internal function to burn a specific token
     * Reverts if the token does not exist
     * Deprecated, use _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 {
        super._burn(owner, tokenId);

        _removeTokenFromOwnerEnumeration(owner, tokenId);
        // Since tokenId will be deleted, we can clear its slot in _ownedTokensIndex to trigger a gas refund
        _ownedTokensIndex[tokenId] = 0;

        _removeTokenFromAllTokensEnumeration(tokenId);
    }

    /**
     * @dev Gets the list of token IDs of the requested owner
     * @param owner address owning the tokens
     * @return uint256[] List of token IDs owned by the requested address
     */
    function _tokensOfOwner(address owner) internal view returns (uint256[] storage) {
        return _ownedTokens[owner];
    }

    /**
     * @dev Private function to add a token to this extension's ownership-tracking data structures.
     * @param to address representing the new owner of the given token ID
     * @param tokenId uint256 ID of the token to be added to the tokens list of the given address
     */
    function _addTokenToOwnerEnumeration(address to, uint256 tokenId) private {
        _ownedTokensIndex[tokenId] = _ownedTokens[to].length;
        _ownedTokens[to].push(tokenId);
    }

    /**
     * @dev Private function to add a token to this extension's token tracking data structures.
     * @param tokenId uint256 ID of the token to be added to the tokens list
     */
    function _addTokenToAllTokensEnumeration(uint256 tokenId) private {
        _allTokensIndex[tokenId] = _allTokens.length;
        _allTokens.push(tokenId);
    }

    /**
     * @dev Private function to remove a token from this extension's ownership-tracking data structures. Note that
     * while the token is not assigned a new owner, the _ownedTokensIndex mapping is _not_ updated: this allows for
     * gas optimizations e.g. when performing a transfer operation (avoiding double writes).
     * This has O(1) time complexity, but alters the order of the _ownedTokens array.
     * @param from address representing the previous owner of the given token ID
     * @param tokenId uint256 ID of the token to be removed from the tokens list of the given address
     */
    function _removeTokenFromOwnerEnumeration(address from, uint256 tokenId) private {
        // To prevent a gap in from's tokens array, we store the last token in the index of the token to delete, and
        // then delete the last slot (swap and pop).

        uint256 lastTokenIndex = _ownedTokens[from].length.sub(1);
        uint256 tokenIndex = _ownedTokensIndex[tokenId];

        // When the token to delete is the last token, the swap operation is unnecessary
        if (tokenIndex != lastTokenIndex) {
            uint256 lastTokenId = _ownedTokens[from][lastTokenIndex];

            _ownedTokens[from][tokenIndex] = lastTokenId; // Move the last token to the slot of the to-delete token
            _ownedTokensIndex[lastTokenId] = tokenIndex; // Update the moved token's index
        }

        // This also deletes the contents at the last position of the array
        _ownedTokens[from].length--;

        // Note that _ownedTokensIndex[tokenId] hasn't been cleared: it still points to the old slot (now occupied by
        // lastTokenId, or just over the end of the array if the token was the last one).
    }

    /**
     * @dev Private function to remove a token from this extension's token tracking data structures.
     * This has O(1) time complexity, but alters the order of the _allTokens array.
     * @param tokenId uint256 ID of the token to be removed from the tokens list
     */
    function _removeTokenFromAllTokensEnumeration(uint256 tokenId) private {
        // To prevent a gap in the tokens array, we store the last token in the index of the token to delete, and
        // then delete the last slot (swap and pop).

        uint256 lastTokenIndex = _allTokens.length.sub(1);
        uint256 tokenIndex = _allTokensIndex[tokenId];

        // When the token to delete is the last token, the swap operation is unnecessary. However, since this occurs so
        // rarely (when the last minted token is burnt) that we still do the swap here to avoid the gas cost of adding
        // an 'if' statement (like in _removeTokenFromOwnerEnumeration)
        uint256 lastTokenId = _allTokens[lastTokenIndex];

        _allTokens[tokenIndex] = lastTokenId; // Move the last token to the slot of the to-delete token
        _allTokensIndex[lastTokenId] = tokenIndex; // Update the moved token's index

        // This also deletes the contents at the last position of the array
        _allTokens.length--;
        _allTokensIndex[tokenId] = 0;
    }
}








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



contract ERC721Metadata is ERC165, ERC721, IERC721Metadata {
    // Token name
    string private _name;

    // Token symbol
    string private _symbol;

    // Optional mapping for token URIs
    mapping(uint256 => string) private _tokenURIs;

    bytes4 private constant _INTERFACE_ID_ERC721_METADATA = 0x5b5e139f;
    /*
     * 0x5b5e139f ===
     *     bytes4(keccak256('name()')) ^
     *     bytes4(keccak256('symbol()')) ^
     *     bytes4(keccak256('tokenURI(uint256)'))
     */

    /**
     * @dev Constructor function
     */
    constructor (string memory name, string memory symbol) public {
        _name = name;
        _symbol = symbol;

        // register the supported interfaces to conform to ERC721 via ERC165
        _registerInterface(_INTERFACE_ID_ERC721_METADATA);
    }

    /**
     * @dev Gets the token name
     * @return string representing the token name
     */
    function name() external view returns (string memory) {
        return _name;
    }

    /**
     * @dev Gets the token symbol
     * @return string representing the token symbol
     */
    function symbol() external view returns (string memory) {
        return _symbol;
    }

    /**
     * @dev Returns an URI for a given token ID
     * Throws if the token ID does not exist. May return an empty string.
     * @param tokenId uint256 ID of the token to query
     */
    function tokenURI(uint256 tokenId) external view returns (string memory) {
        require(_exists(tokenId));
        return _tokenURIs[tokenId];
    }

    /**
     * @dev Internal function to set the token URI for a given token
     * Reverts if the token ID does not exist
     * @param tokenId uint256 ID of the token to set its URI
     * @param uri string URI to assign
     */
    function _setTokenURI(uint256 tokenId, string memory uri) internal {
        require(_exists(tokenId));
        _tokenURIs[tokenId] = uri;
    }

    /**
     * @dev Internal function to burn a specific token
     * Reverts if the token does not exist
     * Deprecated, use _burn(uint256) instead
     * @param owner owner of the token to burn
     * @param tokenId uint256 ID of the token being burned by the msg.sender
     */
    function _burn(address owner, uint256 tokenId) internal {
        super._burn(owner, tokenId);

        // Clear metadata (if any)
        if (bytes(_tokenURIs[tokenId]).length != 0) {
            delete _tokenURIs[tokenId];
        }
    }
}


/**
 * @title Full ERC721 Token
 * This implementation includes all the required and some optional functionality of the ERC721 standard
 * Moreover, it includes approve all functionality using operator terminology
 * @dev see https://eips.ethereum.org/EIPS/eip-721
 */
contract ERC721Full is ERC721, ERC721Enumerable, ERC721Metadata {
    constructor (string memory name, string memory symbol) public ERC721Metadata(name, symbol) {
        // solhint-disable-previous-line no-empty-blocks
    }
}



/**
 * @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.
     * It will not be possible to call the functions with the `onlyOwner`
     * modifier anymore.
     * @notice Renouncing ownership will leave the contract without an owner,
     * thereby removing any functionality that is only available to the owner.
     */
    function renounceOwnership() public onlyOwner {
        emit OwnershipTransferred(_owner, address(0));
        _owner = address(0);
    }

    /**
     * @dev 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;
    }
}



contract OwnableDelegateProxy { }

contract ProxyRegistry {
    mapping(address => OwnableDelegateProxy) public proxies;
}

contract CryptoSkulls is ERC721Full, Ownable {
    using Strings for string;

    string public imageHash = "ee45d31baca263402d1ed0a6f3262ced177420365fe10f3dcf069b32b105fef7";

    address proxyRegistryAddress;
    string baseTokenURI = "";

    constructor (string memory name,
                 string memory symbol,
                 address _proxyRegistryAddress)
        ERC721Full(name, symbol) public {

        proxyRegistryAddress = _proxyRegistryAddress;
    }

    function mint(uint256[] calldata tokenIds) external onlyOwner {
        address owner = owner();

        uint256 length = tokenIds.length;

        for (uint256 i = 0; i < length; i++) {
            uint256 tokenId = tokenIds[i];

            require(tokenId >= 0 && tokenId <= 9999);

            _mint(owner, tokenId);
        }
    }

    function setBaseTokenURI(string calldata _baseTokenURI) external onlyOwner {
        baseTokenURI = _baseTokenURI;
    }

    function setProxyRegistryAddress(address _proxyRegistryAddress) external onlyOwner {
        proxyRegistryAddress = _proxyRegistryAddress;
    }

    function tokenURI(uint256 _tokenId) external view returns (string memory) {
        return Strings.strConcat(
            baseTokenURI,
            Strings.uint2str(_tokenId)
        );
    }

    /**
     * Override isApprovedForAll to whitelist user's OpenSea proxy accounts to enable gas-less listings.
     */
    function isApprovedForAll(address owner, address operator) public view returns (bool) {
        // Whitelist OpenSea proxy contract for easy trading.
        ProxyRegistry proxyRegistry = ProxyRegistry(proxyRegistryAddress);
        if (address(proxyRegistry.proxies(owner)) == operator) {
            return true;
        }

        return super.isApprovedForAll(owner, operator);
    }
}

Contract Security Audit

Contract ABI

[{"constant":true,"inputs":[{"name":"interfaceId","type":"bytes4"}],"name":"supportsInterface","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"name","outputs":[{"name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"name":"tokenId","type":"uint256"}],"name":"getApproved","outputs":[{"name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"to","type":"address"},{"name":"tokenId","type":"uint256"}],"name":"approve","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"totalSupply","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"from","type":"address"},{"name":"to","type":"address"},{"name":"tokenId","type":"uint256"}],"name":"transferFrom","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"name":"owner","type":"address"},{"name":"index","type":"uint256"}],"name":"tokenOfOwnerByIndex","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"_baseTokenURI","type":"string"}],"name":"setBaseTokenURI","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"from","type":"address"},{"name":"to","type":"address"},{"name":"tokenId","type":"uint256"}],"name":"safeTransferFrom","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"name":"index","type":"uint256"}],"name":"tokenByIndex","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"imageHash","outputs":[{"name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"name":"tokenId","type":"uint256"}],"name":"ownerOf","outputs":[{"name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"name":"owner","type":"address"}],"name":"balanceOf","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[],"name":"renounceOwnership","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"owner","outputs":[{"name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"isOwner","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"symbol","outputs":[{"name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"to","type":"address"},{"name":"approved","type":"bool"}],"name":"setApprovalForAll","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"from","type":"address"},{"name":"to","type":"address"},{"name":"tokenId","type":"uint256"},{"name":"_data","type":"bytes"}],"name":"safeTransferFrom","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"name":"_tokenId","type":"uint256"}],"name":"tokenURI","outputs":[{"name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"_proxyRegistryAddress","type":"address"}],"name":"setProxyRegistryAddress","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"name":"owner","type":"address"},{"name":"operator","type":"address"}],"name":"isApprovedForAll","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"tokenIds","type":"uint256[]"}],"name":"mint","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"inputs":[{"name":"name","type":"string"},{"name":"symbol","type":"string"},{"name":"_proxyRegistryAddress","type":"address"}],"payable":false,"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"name":"previousOwner","type":"address"},{"indexed":true,"name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"name":"from","type":"address"},{"indexed":true,"name":"to","type":"address"},{"indexed":true,"name":"tokenId","type":"uint256"}],"name":"Transfer","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"name":"owner","type":"address"},{"indexed":true,"name":"approved","type":"address"},{"indexed":true,"name":"tokenId","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"name":"owner","type":"address"},{"indexed":true,"name":"operator","type":"address"},{"indexed":false,"name":"approved","type":"bool"}],"name":"ApprovalForAll","type":"event"}]

60806040526060604051908101604052806040815260200162002e7a60409139600d9080519060200190620000369291906200043c565b506020604051908101604052806000815250600f90805190602001906200005f9291906200043c565b503480156200006d57600080fd5b5060405162002eba38038062002eba833981018060405260608110156200009357600080fd5b810190808051640100000000811115620000ac57600080fd5b82810190506020810184811115620000c357600080fd5b8151856001820283011164010000000082111715620000e157600080fd5b50509291906020018051640100000000811115620000fe57600080fd5b828101905060208101848111156200011557600080fd5b81518560018202830111640100000000821117156200013357600080fd5b50509291906020018051906020019092919050505082828181620001896301ffc9a77c0100000000000000000000000000000000000000000000000000000000026200037e640100000000026401000000009004565b620001c66380ac58cd7c0100000000000000000000000000000000000000000000000000000000026200037e640100000000026401000000009004565b6200020363780e9d637c0100000000000000000000000000000000000000000000000000000000026200037e640100000000026401000000009004565b81600990805190602001906200021b9291906200043c565b5080600a9080519060200190620002349291906200043c565b5062000272635b5e139f7c0100000000000000000000000000000000000000000000000000000000026200037e640100000000026401000000009004565b5050505033600c60006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550600c60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16600073ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a380600e60006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550505050620004eb565b63ffffffff7c010000000000000000000000000000000000000000000000000000000002817bffffffffffffffffffffffffffffffffffffffffffffffffffffffff191614151515620003d057600080fd5b6001600080837bffffffffffffffffffffffffffffffffffffffffffffffffffffffff19167bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916815260200190815260200160002060006101000a81548160ff02191690831515021790555050565b828054600181600116156101000203166002900490600052602060002090601f016020900481019282601f106200047f57805160ff1916838001178555620004b0565b82800160010185558215620004b0579182015b82811115620004af57825182559160200191906001019062000492565b5b509050620004bf9190620004c3565b5090565b620004e891905b80821115620004e4576000816000905550600101620004ca565b5090565b90565b61297f80620004fb6000396000f3fe608060405234801561001057600080fd5b5060043610610175576000357c01000000000000000000000000000000000000000000000000000000009004806370a08231116100e0578063b88d4fde11610099578063b88d4fde146107c7578063c87b56dd146108cc578063d26ea6c014610973578063e985e9c5146109b7578063f2fde38b14610a33578063f8e93ef914610a7757610175565b806370a0823114610626578063715018a61461067e5780638da5cb5b146106885780638f32d59b146106d257806395d89b41146106f4578063a22cb4651461077757610175565b80632f745c59116101325780632f745c59146103aa57806330176e131461040c57806342842e0e146104855780634f6ccce7146104f357806351605d80146105355780636352211e146105b857610175565b806301ffc9a71461017a57806306fdde03146101df578063081812fc14610262578063095ea7b3146102d057806318160ddd1461031e57806323b872dd1461033c575b600080fd5b6101c56004803603602081101561019057600080fd5b8101908080357bffffffffffffffffffffffffffffffffffffffffffffffffffffffff19169060200190929190505050610af0565b604051808215151515815260200191505060405180910390f35b6101e7610b57565b6040518080602001828103825283818151815260200191508051906020019080838360005b8381101561022757808201518184015260208101905061020c565b50505050905090810190601f1680156102545780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b61028e6004803603602081101561027857600080fd5b8101908080359060200190929190505050610bf9565b604051808273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390f35b61031c600480360360408110156102e657600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff16906020019092919080359060200190929190505050610c4a565b005b610326610d8f565b6040518082815260200191505060405180910390f35b6103a86004803603606081101561035257600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff169060200190929190803573ffffffffffffffffffffffffffffffffffffffff16906020019092919080359060200190929190505050610d9c565b005b6103f6600480360360408110156103c057600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff16906020019092919080359060200190929190505050610dc1565b6040518082815260200191505060405180910390f35b6104836004803603602081101561042257600080fd5b810190808035906020019064010000000081111561043f57600080fd5b82018360208201111561045157600080fd5b8035906020019184600183028401116401000000008311171561047357600080fd5b9091929391929390505050610e38565b005b6104f16004803603606081101561049b57600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff169060200190929190803573ffffffffffffffffffffffffffffffffffffffff16906020019092919080359060200190929190505050610e61565b005b61051f6004803603602081101561050957600080fd5b8101908080359060200190929190505050610e82565b6040518082815260200191505060405180910390f35b61053d610eba565b6040518080602001828103825283818151815260200191508051906020019080838360005b8381101561057d578082015181840152602081019050610562565b50505050905090810190601f1680156105aa5780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b6105e4600480360360208110156105ce57600080fd5b8101908080359060200190929190505050610f58565b604051808273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390f35b6106686004803603602081101561063c57600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff169060200190929190505050610fd6565b6040518082815260200191505060405180910390f35b610686611061565b005b610690611135565b604051808273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390f35b6106da61115f565b604051808215151515815260200191505060405180910390f35b6106fc6111b7565b6040518080602001828103825283818151815260200191508051906020019080838360005b8381101561073c578082015181840152602081019050610721565b50505050905090810190601f1680156107695780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b6107c56004803603604081101561078d57600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff169060200190929190803515159060200190929190505050611259565b005b6108ca600480360360808110156107dd57600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff169060200190929190803573ffffffffffffffffffffffffffffffffffffffff169060200190929190803590602001909291908035906020019064010000000081111561084457600080fd5b82018360208201111561085657600080fd5b8035906020019184600183028401116401000000008311171561087857600080fd5b91908080601f016020809104026020016040519081016040528093929190818152602001838380828437600081840152601f19601f820116905080830192505050505050509192919290505050611395565b005b6108f8600480360360208110156108e257600080fd5b81019080803590602001909291905050506113bd565b6040518080602001828103825283818151815260200191508051906020019080838360005b8381101561093857808201518184015260208101905061091d565b50505050905090810190601f1680156109655780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b6109b56004803603602081101561098957600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff169060200190929190505050611472565b005b610a19600480360360408110156109cd57600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff169060200190929190803573ffffffffffffffffffffffffffffffffffffffff1690602001909291905050506114c9565b604051808215151515815260200191505060405180910390f35b610a7560048036036020811015610a4957600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff169060200190929190505050611616565b005b610aee60048036036020811015610a8d57600080fd5b8101908080359060200190640100000000811115610aaa57600080fd5b820183602082011115610abc57600080fd5b80359060200191846020830284011164010000000083111715610ade57600080fd5b9091929391929390505050611635565b005b6000806000837bffffffffffffffffffffffffffffffffffffffffffffffffffffffff19167bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916815260200190815260200160002060009054906101000a900460ff169050919050565b606060098054600181600116156101000203166002900480601f016020809104026020016040519081016040528092919081815260200182805460018160011615610100020316600290048015610bef5780601f10610bc457610100808354040283529160200191610bef565b820191906000526020600020905b815481529060010190602001808311610bd257829003601f168201915b5050505050905090565b6000610c04826116c0565b1515610c0f57600080fd5b6002600083815260200190815260200160002060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff169050919050565b6000610c5582610f58565b90508073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff1614151515610c9257600080fd5b8073ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff161480610cd25750610cd181336114c9565b5b1515610cdd57600080fd5b826002600084815260200190815260200160002060006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550818373ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92560405160405180910390a4505050565b6000600780549050905090565b610da63382611732565b1515610db157600080fd5b610dbc8383836117c7565b505050565b6000610dcc83610fd6565b82101515610dd957600080fd5b600560008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002082815481101515610e2557fe5b9060005260206000200154905092915050565b610e4061115f565b1515610e4b57600080fd5b8181600f9190610e5c929190612882565b505050565b610e7d8383836020604051908101604052806000815250611395565b505050565b6000610e8c610d8f565b82101515610e9957600080fd5b600782815481101515610ea857fe5b90600052602060002001549050919050565b600d8054600181600116156101000203166002900480601f016020809104026020016040519081016040528092919081815260200182805460018160011615610100020316600290048015610f505780601f10610f2557610100808354040283529160200191610f50565b820191906000526020600020905b815481529060010190602001808311610f3357829003601f168201915b505050505081565b6000806001600084815260200190815260200160002060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff169050600073ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff1614151515610fcd57600080fd5b80915050919050565b60008073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff161415151561101357600080fd5b61105a600360008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000206117eb565b9050919050565b61106961115f565b151561107457600080fd5b600073ffffffffffffffffffffffffffffffffffffffff16600c60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a36000600c60006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550565b6000600c60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b6000600c60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff1614905090565b6060600a8054600181600116156101000203166002900480601f01602080910402602001604051908101604052809291908181526020018280546001816001161561010002031660029004801561124f5780601f106112245761010080835404028352916020019161124f565b820191906000526020600020905b81548152906001019060200180831161123257829003601f168201915b5050505050905090565b3373ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff161415151561129457600080fd5b80600460003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff0219169083151502179055508173ffffffffffffffffffffffffffffffffffffffff163373ffffffffffffffffffffffffffffffffffffffff167f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c3183604051808215151515815260200191505060405180910390a35050565b6113a0848484610d9c565b6113ac848484846117f9565b15156113b757600080fd5b50505050565b606061146b600f8054600181600116156101000203166002900480601f0160208091040260200160405190810160405280929190818152602001828054600181600116156101000203166002900480156114585780601f1061142d57610100808354040283529160200191611458565b820191906000526020600020905b81548152906001019060200180831161143b57829003601f168201915b505050505061146684611a1c565b611b75565b9050919050565b61147a61115f565b151561148557600080fd5b80600e60006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555050565b600080600e60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1690508273ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff1663c4552791866040518263ffffffff167c0100000000000000000000000000000000000000000000000000000000028152600401808273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200191505060206040518083038186803b1580156115a157600080fd5b505afa1580156115b5573d6000803e3d6000fd5b505050506040513d60208110156115cb57600080fd5b810190808051906020019092919050505073ffffffffffffffffffffffffffffffffffffffff161415611602576001915050611610565b61160c8484611bbc565b9150505b92915050565b61161e61115f565b151561162957600080fd5b61163281611c50565b50565b61163d61115f565b151561164857600080fd5b6000611652611135565b9050600083839050905060008090505b818110156116b9576000858583818110151561167a57fe5b90506020020135905060008110158015611696575061270f8111155b15156116a157600080fd5b6116ab8482611d4c565b508080600101915050611662565b5050505050565b6000806001600084815260200190815260200160002060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff169050600073ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff161415915050919050565b60008061173e83610f58565b90508073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1614806117ad57508373ffffffffffffffffffffffffffffffffffffffff1661179584610bf9565b73ffffffffffffffffffffffffffffffffffffffff16145b806117be57506117bd81856114c9565b5b91505092915050565b6117d2838383611d6d565b6117dc8382611f34565b6117e682826120d8565b505050565b600081600001549050919050565b600061181a8473ffffffffffffffffffffffffffffffffffffffff1661219f565b15156118295760019050611a14565b60008473ffffffffffffffffffffffffffffffffffffffff1663150b7a02338887876040518563ffffffff167c0100000000000000000000000000000000000000000000000000000000028152600401808573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020018473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200183815260200180602001828103825283818151815260200191508051906020019080838360005b83811015611920578082015181840152602081019050611905565b50505050905090810190601f16801561194d5780820380516001836020036101000a031916815260200191505b5095505050505050602060405180830381600087803b15801561196f57600080fd5b505af1158015611983573d6000803e3d6000fd5b505050506040513d602081101561199957600080fd5b8101908080519060200190929190505050905063150b7a027c0100000000000000000000000000000000000000000000000000000000027bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916817bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916149150505b949350505050565b60606000821415611a64576040805190810160405280600181526020017f30000000000000000000000000000000000000000000000000000000000000008152509050611b70565b600082905060005b600082141515611a92578080600101915050600a82811515611a8a57fe5b049150611a6c565b6060816040519080825280601f01601f191660200182016040528015611ac75781602001600182028038833980820191505090505b50905060006001830390505b600086141515611b6857600a86811515611ae957fe5b066030017f010000000000000000000000000000000000000000000000000000000000000002828280600190039350815181101515611b2457fe5b9060200101907effffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916908160001a905350600a86811515611b6057fe5b049550611ad3565b819450505050505b919050565b6060611bb483836020604051908101604052806000815250602060405190810160405280600081525060206040519081016040528060008152506121b2565b905092915050565b6000600460008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16905092915050565b600073ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff1614151515611c8c57600080fd5b8073ffffffffffffffffffffffffffffffffffffffff16600c60009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a380600c60006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555050565b611d5682826125d1565b611d6082826120d8565b611d698161271b565b5050565b8273ffffffffffffffffffffffffffffffffffffffff16611d8d82610f58565b73ffffffffffffffffffffffffffffffffffffffff16141515611daf57600080fd5b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1614151515611deb57600080fd5b611df481612767565b611e3b600360008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020612827565b611e82600360008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002061284a565b816001600083815260200190815260200160002060006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550808273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60405160405180910390a4505050565b6000611f8c6001600560008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000208054905061286090919063ffffffff16565b9050600060066000848152602001908152602001600020549050818114151561207f576000600560008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002083815481101515611ffd57fe5b9060005260206000200154905080600560008773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000208381548110151561205757fe5b9060005260206000200181905550816006600083815260200190815260200160002081905550505b600560008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000208054809190600190036120d19190612902565b5050505050565b600560008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020805490506006600083815260200190815260200160002081905550600560008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000208190806001815401808255809150509060018203906000526020600020016000909192909190915055505050565b600080823b905060008111915050919050565b6060808690506060869050606086905060608690506060869050606081518351855187518951010101016040519080825280601f01601f19166020018201604052801561220e5781602001600182028038833980820191505090505b5090506060819050600080905060008090505b88518110156122d457888181518110151561223857fe5b9060200101517f010000000000000000000000000000000000000000000000000000000000000090047f010000000000000000000000000000000000000000000000000000000000000002838380600101945081518110151561229757fe5b9060200101907effffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916908160001a9053508080600101915050612221565b5060008090505b875181101561238e5787818151811015156122f257fe5b9060200101517f010000000000000000000000000000000000000000000000000000000000000090047f010000000000000000000000000000000000000000000000000000000000000002838380600101945081518110151561235157fe5b9060200101907effffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916908160001a90535080806001019150506122db565b5060008090505b86518110156124485786818151811015156123ac57fe5b9060200101517f010000000000000000000000000000000000000000000000000000000000000090047f010000000000000000000000000000000000000000000000000000000000000002838380600101945081518110151561240b57fe5b9060200101907effffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916908160001a9053508080600101915050612395565b5060008090505b855181101561250257858181518110151561246657fe5b9060200101517f010000000000000000000000000000000000000000000000000000000000000090047f01000000000000000000000000000000000000000000000000000000000000000283838060010194508151811015156124c557fe5b9060200101907effffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916908160001a905350808060010191505061244f565b5060008090505b84518110156125bc57848181518110151561252057fe5b9060200101517f010000000000000000000000000000000000000000000000000000000000000090047f010000000000000000000000000000000000000000000000000000000000000002838380600101945081518110151561257f57fe5b9060200101907effffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916908160001a9053508080600101915050612509565b50819850505050505050505095945050505050565b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff161415151561260d57600080fd5b612616816116c0565b15151561262257600080fd5b816001600083815260200190815260200160002060006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055506126bb600360008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002061284a565b808273ffffffffffffffffffffffffffffffffffffffff16600073ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60405160405180910390a45050565b6007805490506008600083815260200190815260200160002081905550600781908060018154018082558091505090600182039060005260206000200160009091929091909150555050565b600073ffffffffffffffffffffffffffffffffffffffff166002600083815260200190815260200160002060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff161415156128245760006002600083815260200190815260200160002060006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055505b50565b61283f6001826000015461286090919063ffffffff16565b816000018190555050565b6001816000016000828254019250508190555050565b600082821115151561287157600080fd5b600082840390508091505092915050565b828054600181600116156101000203166002900490600052602060002090601f016020900481019282601f106128c357803560ff19168380011785556128f1565b828001600101855582156128f1579182015b828111156128f05782358255916020019190600101906128d5565b5b5090506128fe919061292e565b5090565b81548183558181111561292957818360005260206000209182019101612928919061292e565b5b505050565b61295091905b8082111561294c576000816000905550600101612934565b5090565b9056fea165627a7a72305820efcc7455469ab10f8be3482145f44ca6f71d9c621a8a1f0d5cb50dbb3f7f88ab002965653435643331626163613236333430326431656430613666333236326365643137373432303336356665313066336463663036396233326231303566656637000000000000000000000000000000000000000000000000000000000000006000000000000000000000000000000000000000000000000000000000000000a0000000000000000000000000a5409ec958c83c3f309868babaca7c86dcb077c1000000000000000000000000000000000000000000000000000000000000000c43727970746f536b756c6c730000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000c43727970746f536b756c6c730000000000000000000000000000000000000000

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

000000000000000000000000000000000000000000000000000000000000006000000000000000000000000000000000000000000000000000000000000000a0000000000000000000000000a5409ec958c83c3f309868babaca7c86dcb077c1000000000000000000000000000000000000000000000000000000000000000c43727970746f536b756c6c730000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000c43727970746f536b756c6c730000000000000000000000000000000000000000

-----Decoded View---------------
Arg [0] : name (string): CryptoSkulls
Arg [1] : symbol (string): CryptoSkulls
Arg [2] : _proxyRegistryAddress (address): 0xa5409ec958c83c3f309868babaca7c86dcb077c1

-----Encoded View---------------
7 Constructor Arguments found :
Arg [0] : 0000000000000000000000000000000000000000000000000000000000000060
Arg [1] : 00000000000000000000000000000000000000000000000000000000000000a0
Arg [2] : 000000000000000000000000a5409ec958c83c3f309868babaca7c86dcb077c1
Arg [3] : 000000000000000000000000000000000000000000000000000000000000000c
Arg [4] : 43727970746f536b756c6c730000000000000000000000000000000000000000
Arg [5] : 000000000000000000000000000000000000000000000000000000000000000c
Arg [6] : 43727970746f536b756c6c730000000000000000000000000000000000000000


Deployed ByteCode Sourcemap

36712:1857:0:-;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;36712:1857:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;3145:135;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;3145:135:0;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;32253:85;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;23:1:-1;8:100;33:3;30:1;27:10;8:100;;;99:1;94:3;90:11;84:18;80:1;75:3;71:11;64:39;52:2;49:1;45:10;40:15;;8:100;;;12:14;32253:85:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;14041:154;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;14041:154:0;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;13449:299;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;13449:299:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;24233:96;;;:::i;:::-;;;;;;;;;;;;;;;;;;;15632:184;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;15632:184:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;23890:185;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;23890:185:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;37559:122;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;37559:122:0;;;;;;;;;;21:11:-1;8;5:28;2:2;;;46:1;43;36:12;2:2;37559:122:0;;35:9:-1;28:4;12:14;8:25;5:40;2:2;;;58:1;55;48:12;2:2;37559:122: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;37559:122:0;;;;;;;;;;;;:::i;:::-;;16462:134;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;16462:134:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;24674:151;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;24674:151:0;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;36797:92;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;23:1:-1;8:100;33:3;30:1;27:10;8:100;;;99:1;94:3;90:11;84:18;80:1;75:3;71:11;64:39;52:2;49:1;45:10;40:15;;8:100;;;12:14;36797:92:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;12837:181;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;12837:181:0;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;12449:163;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;12449:163:0;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;35808:140;;;:::i;:::-;;35018:79;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;35353:92;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;32452:89;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;23:1:-1;8:100;33:3;30:1;27:10;8:100;;;99:1;94:3;90:11;84:18;80:1;75:3;71:11;64:39;52:2;49:1;45:10;40:15;;8:100;;;12:14;32452:89:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;14495:217;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;14495:217:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;17315:214;;;;;;13:3:-1;8;5:12;2:2;;;30:1;27;20:12;2:2;17315:214:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;21:11:-1;8;5:28;2:2;;;46:1;43;36:12;2:2;17315:214:0;;35:9:-1;28:4;12:14;8:25;5:40;2:2;;;58:1;55;48:12;2:2;17315: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;17315:214:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;30:3:-1;22:6;14;1:33;99:1;93:3;85:6;81:16;74:27;137:4;133:9;126:4;121:3;117:14;113:30;106:37;;169:3;161:6;157:16;147:26;;17315:214:0;;;;;;;;;;;;;;;:::i;:::-;;37843:196;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;37843:196:0;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;23:1:-1;8:100;33:3;30:1;27:10;8:100;;;99:1;94:3;90:11;84:18;80:1;75:3;71:11;64:39;52:2;49:1;45:10;40:15;;8:100;;;12:14;37843:196:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;37689:146;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;37689:146:0;;;;;;;;;;;;;;;;;;;:::i;:::-;;38171:395;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;38171:395:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;36125:109;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;36125:109:0;;;;;;;;;;;;;;;;;;;:::i;:::-;;37202:349;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;37202:349:0;;;;;;;;;;21:11:-1;8;5:28;2:2;;;46:1;43;36:12;2:2;37202:349:0;;35:9:-1;28:4;12:14;8:25;5:40;2:2;;;58:1;55;48:12;2:2;37202:349:0;;;;;;101:9:-1;95:2;81:12;77:21;67:8;63:36;60:51;39:11;25:12;22:29;11:108;8:2;;;132:1;129;122:12;8:2;37202:349:0;;;;;;;;;;;;:::i;:::-;;3145:135;3215:4;3239:20;:33;3260:11;3239:33;;;;;;;;;;;;;;;;;;;;;;;;;;;3232:40;;3145:135;;;:::o;32253:85::-;32292:13;32325:5;32318:12;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;32253:85;:::o;14041:154::-;14100:7;14128:16;14136:7;14128;:16::i;:::-;14120:25;;;;;;;;14163:15;:24;14179:7;14163:24;;;;;;;;;;;;;;;;;;;;;14156:31;;14041:154;;;:::o;13449:299::-;13513:13;13529:16;13537:7;13529;:16::i;:::-;13513:32;;13570:5;13564:11;;:2;:11;;;;13556:20;;;;;;;;13609:5;13595:19;;:10;:19;;;:58;;;;13618:35;13635:5;13642:10;13618:16;:35::i;:::-;13595:58;13587:67;;;;;;;;13694:2;13667:15;:24;13683:7;13667:24;;;;;;;;;;;;:29;;;;;;;;;;;;;;;;;;13732:7;13728:2;13712:28;;13721:5;13712:28;;;;;;;;;;;;13449:299;;;:::o;24233:96::-;24277:7;24304:10;:17;;;;24297:24;;24233:96;:::o;15632:184::-;15723:39;15742:10;15754:7;15723:18;:39::i;:::-;15715:48;;;;;;;;15776:32;15790:4;15796:2;15800:7;15776:13;:32::i;:::-;15632:184;;;:::o;23890:185::-;23970:7;24006:16;24016:5;24006:9;:16::i;:::-;23998:5;:24;23990:33;;;;;;;;24041:12;:19;24054:5;24041:19;;;;;;;;;;;;;;;24061:5;24041:26;;;;;;;;;;;;;;;;;;24034:33;;23890:185;;;;:::o;37559:122::-;35230:9;:7;:9::i;:::-;35222:18;;;;;;;;37660:13;;37645:12;:28;;;;;;;:::i;:::-;;37559:122;;:::o;16462:134::-;16549:39;16566:4;16572:2;16576:7;16549:39;;;;;;;;;;;;;:16;:39::i;:::-;16462:134;;;:::o;24674:151::-;24732:7;24768:13;:11;:13::i;:::-;24760:5;:21;24752:30;;;;;;;;24800:10;24811:5;24800:17;;;;;;;;;;;;;;;;;;24793:24;;24674:151;;;:::o;36797:92::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::o;12837:181::-;12892:7;12912:13;12928:11;:20;12940:7;12928:20;;;;;;;;;;;;;;;;;;;;;12912:36;;12984:1;12967:19;;:5;:19;;;;12959:28;;;;;;;;13005:5;12998:12;;;12837:181;;;:::o;12449:163::-;12504:7;12549:1;12532:19;;:5;:19;;;;12524:28;;;;;;;;12570:34;:17;:24;12588:5;12570:24;;;;;;;;;;;;;;;:32;:34::i;:::-;12563:41;;12449:163;;;:::o;35808:140::-;35230:9;:7;:9::i;:::-;35222:18;;;;;;;;35907:1;35870:40;;35891:6;;;;;;;;;;;35870:40;;;;;;;;;;;;35938:1;35921:6;;:19;;;;;;;;;;;;;;;;;;35808:140::o;35018:79::-;35056:7;35083:6;;;;;;;;;;;35076:13;;35018:79;:::o;35353:92::-;35393:4;35431:6;;;;;;;;;;;35417:20;;:10;:20;;;35410:27;;35353:92;:::o;32452:89::-;32493:13;32526:7;32519:14;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;32452:89;:::o;14495:217::-;14581:10;14575:16;;:2;:16;;;;14567:25;;;;;;;;14640:8;14603:18;:30;14622:10;14603:30;;;;;;;;;;;;;;;:34;14634:2;14603:34;;;;;;;;;;;;;;;;:45;;;;;;;;;;;;;;;;;;14691:2;14664:40;;14679:10;14664:40;;;14695:8;14664:40;;;;;;;;;;;;;;;;;;;;;;14495:217;;:::o;17315:214::-;17422:31;17435:4;17441:2;17445:7;17422:12;:31::i;:::-;17472:48;17495:4;17501:2;17505:7;17514:5;17472:22;:48::i;:::-;17464:57;;;;;;;;17315:214;;;;:::o;37843:196::-;37902:13;37935:96;37967:12;37935:96;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;37994:26;38011:8;37994:16;:26::i;:::-;37935:17;:96::i;:::-;37928:103;;37843:196;;;:::o;37689:146::-;35230:9;:7;:9::i;:::-;35222:18;;;;;;;;37806:21;37783:20;;:44;;;;;;;;;;;;;;;;;;37689:146;:::o;38171:395::-;38251:4;38331:27;38375:20;;;;;;;;;;;38331:65;;38452:8;38411:49;;38419:13;:21;;;38441:5;38419:28;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;38419:28:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;38419:28:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;38419:28:0;;;;;;;;;;;;;;;;38411:49;;;38407:93;;;38484:4;38477:11;;;;;38407:93;38519:39;38542:5;38549:8;38519:22;:39::i;:::-;38512:46;;;38171:395;;;;;:::o;36125:109::-;35230:9;:7;:9::i;:::-;35222:18;;;;;;;;36198:28;36217:8;36198:18;:28::i;:::-;36125:109;:::o;37202:349::-;35230:9;:7;:9::i;:::-;35222:18;;;;;;;;37275:13;37291:7;:5;:7::i;:::-;37275:23;;37311:14;37328:8;;:15;;37311:32;;37361:9;37373:1;37361:13;;37356:188;37380:6;37376:1;:10;37356:188;;;37408:15;37426:8;;37435:1;37426:11;;;;;;;;;;;;;;;37408:29;;37473:1;37462:7;:12;;:31;;;;;37489:4;37478:7;:15;;37462:31;37454:40;;;;;;;;37511:21;37517:5;37524:7;37511:5;:21::i;:::-;37356:188;37388:3;;;;;;;37356:188;;;;35251:1;;37202:349;;:::o;17730:155::-;17787:4;17804:13;17820:11;:20;17832:7;17820:20;;;;;;;;;;;;;;;;;;;;;17804:36;;17875:1;17858:19;;:5;:19;;;;17851:26;;;17730:155;;;:::o;18254:249::-;18339:4;18356:13;18372:16;18380:7;18372;:16::i;:::-;18356:32;;18418:5;18407:16;;:7;:16;;;:51;;;;18451:7;18427:31;;:20;18439:7;18427:11;:20::i;:::-;:31;;;18407:51;:87;;;;18462:32;18479:5;18486:7;18462:16;:32::i;:::-;18407:87;18399:96;;;18254:249;;;;:::o;25209:245::-;25295:38;25315:4;25321:2;25325:7;25295:19;:38::i;:::-;25346:47;25379:4;25385:7;25346:32;:47::i;:::-;25406:40;25434:2;25438:7;25406:27;:40::i;:::-;25209:245;;;:::o;10065:114::-;10130:7;10157;:14;;;10150:21;;10065:114;;;:::o;21170:356::-;21292:4;21319:15;:2;:13;;;:15::i;:::-;21318:16;21314:60;;;21358:4;21351:11;;;;21314:60;21386:13;21418:2;21402:36;;;21439:10;21451:4;21457:7;21466:5;21402:70;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;23:1:-1;8:100;33:3;30:1;27:10;8:100;;;99:1;94:3;90:11;84:18;80:1;75:3;71:11;64:39;52:2;49:1;45:10;40:15;;8:100;;;12:14;21402:70:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;21402:70:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;21402:70:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;21402:70:0;;;;;;;;;;;;;;;;21386:86;;10904:10;21501:16;;21491:26;;;:6;:26;;;;21483:35;;;21170:356;;;;;;;:::o;5072:482::-;5122:27;5172:1;5166:2;:7;5162:50;;;5190:10;;;;;;;;;;;;;;;;;;;;;;5162:50;5222:6;5231:2;5222:11;;5244:8;5263:69;5275:1;5270;:6;;5263:69;;;5293:5;;;;;;;5318:2;5313:7;;;;;;;;;;;5263:69;;;5342:17;5372:3;5362:14;;;;;;;;;;;;;;;;;;;;;;;;;29:1:-1;21:6;17:14;116:4;104:10;96:6;87:34;147:4;139:6;135:17;125:27;;0:156;5362:14:0;;;;5342:34;;5387:6;5402:1;5396:3;:7;5387:16;;5414:103;5427:1;5421:2;:7;;5414:103;;;5478:2;5473;:7;;;;;;;;5468:2;:12;5457:25;;5445:4;5450:3;;;;;;;5445:9;;;;;;;;;;;;;;:37;;;;;;;;;;;5503:2;5497:8;;;;;;;;;;;5414:103;;;5541:4;5527:19;;;;;;5072:482;;;;:::o;4916:148::-;4994:13;5027:29;5037:2;5041;5027:29;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:9;:29::i;:::-;5020:36;;4916:148;;;;:::o;15041:147::-;15121:4;15145:18;:25;15164:5;15145:25;;;;;;;;;;;;;;;:35;15171:8;15145:35;;;;;;;;;;;;;;;;;;;;;;;;;15138:42;;15041:147;;;;:::o;36384:187::-;36478:1;36458:22;;:8;:22;;;;36450:31;;;;;;;;36526:8;36497:38;;36518:6;;;;;;;;;;;36497:38;;;;;;;;;;;;36555:8;36546:6;;:17;;;;;;;;;;;;;;;;;;36384:187;:::o;25717:202::-;25781:24;25793:2;25797:7;25781:11;:24::i;:::-;25818:40;25846:2;25850:7;25818:27;:40::i;:::-;25871;25903:7;25871:31;:40::i;:::-;25717:202;;:::o;20257:374::-;20371:4;20351:24;;:16;20359:7;20351;:16::i;:::-;:24;;;20343:33;;;;;;;;20409:1;20395:16;;:2;:16;;;;20387:25;;;;;;;;20425:23;20440:7;20425:14;:23::i;:::-;20461:35;:17;:23;20479:4;20461:23;;;;;;;;;;;;;;;:33;:35::i;:::-;20507:33;:17;:21;20525:2;20507:21;;;;;;;;;;;;;;;:31;:33::i;:::-;20576:2;20553:11;:20;20565:7;20553:20;;;;;;;;;;;;:25;;;;;;;;;;;;;;;;;;20615:7;20611:2;20596:27;;20605:4;20596:27;;;;;;;;;;;;20257:374;;;:::o;28386:1148::-;28652:22;28677:32;28707:1;28677:12;:18;28690:4;28677:18;;;;;;;;;;;;;;;:25;;;;:29;;:32;;;;:::i;:::-;28652:57;;28720:18;28741:17;:26;28759:7;28741:26;;;;;;;;;;;;28720:47;;28888:14;28874:10;:28;;28870:328;;;28919:19;28941:12;:18;28954:4;28941:18;;;;;;;;;;;;;;;28960:14;28941:34;;;;;;;;;;;;;;;;;;28919:56;;29025:11;28992:12;:18;29005:4;28992:18;;;;;;;;;;;;;;;29011:10;28992:30;;;;;;;;;;;;;;;;;:44;;;;29142:10;29109:17;:30;29127:11;29109:30;;;;;;;;;;;:43;;;;28870:328;;29287:12;:18;29300:4;29287:18;;;;;;;;;;;;;;;:27;;;;;;;;;;;;:::i;:::-;;28386:1148;;;;:::o;27210:186::-;27324:12;:16;27337:2;27324:16;;;;;;;;;;;;;;;:23;;;;27295:17;:26;27313:7;27295:26;;;;;;;;;;;:52;;;;27358:12;:16;27371:2;27358:16;;;;;;;;;;;;;;;27380:7;27358:30;;39:1:-1;33:3;27:10;23:18;57:10;52:3;45:23;79:10;72:17;;0:93;27358:30:0;;;;;;;;;;;;;;;;;;;;;;27210:186;;:::o;8397:627::-;8457:4;8474:12;8981:7;8969:20;8961:28;;9015:1;9008:4;:8;9001:15;;;8397:627;;;:::o;3642:900::-;3774:13;3800:16;3825:2;3800:28;;3839:16;3864:2;3839:28;;3878:16;3903:2;3878:28;;3917:16;3942:2;3917:28;;3956:16;3981:2;3956:28;;3995:19;4080:3;:10;4067:3;:10;4054:3;:10;4041:3;:10;4028:3;:10;:23;:36;:49;:62;4017:74;;;;;;;;;;;;;;;;;;;;;;;;;29:1:-1;21:6;17:14;116:4;104:10;96:6;87:34;147:4;139:6;135:17;125:27;;0:156;4017:74:0;;;;3995:96;;4102:19;4130:5;4102:34;;4147:6;4156:1;4147:10;;4173:6;4182:1;4173:10;;4168:58;4189:3;:10;4185:1;:14;4168:58;;;4220:3;4224:1;4220:6;;;;;;;;;;;;;;;;;;;;4206;4213:3;;;;;;4206:11;;;;;;;;;;;;;;:20;;;;;;;;;;;4201:3;;;;;;;4168:58;;;;4242:6;4251:1;4242:10;;4237:58;4258:3;:10;4254:1;:14;4237:58;;;4289:3;4293:1;4289:6;;;;;;;;;;;;;;;;;;;;4275;4282:3;;;;;;4275:11;;;;;;;;;;;;;;:20;;;;;;;;;;;4270:3;;;;;;;4237:58;;;;4311:6;4320:1;4311:10;;4306:58;4327:3;:10;4323:1;:14;4306:58;;;4358:3;4362:1;4358:6;;;;;;;;;;;;;;;;;;;;4344;4351:3;;;;;;4344:11;;;;;;;;;;;;;;:20;;;;;;;;;;;4339:3;;;;;;;4306:58;;;;4380:6;4389:1;4380:10;;4375:58;4396:3;:10;4392:1;:14;4375:58;;;4427:3;4431:1;4427:6;;;;;;;;;;;;;;;;;;;;4413;4420:3;;;;;;4413:11;;;;;;;;;;;;;;:20;;;;;;;;;;;4408:3;;;;;;;4375:58;;;;4449:6;4458:1;4449:10;;4444:58;4465:3;:10;4461:1;:14;4444:58;;;4496:3;4500:1;4496:6;;;;;;;;;;;;;;;;;;;;4482;4489:3;;;;;;4482:11;;;;;;;;;;;;;;:20;;;;;;;;;;;4477:3;;;;;;;4444:58;;;;4527:6;4513:21;;;;;;;;;;3642:900;;;;;;;:::o;18754:267::-;18840:1;18826:16;;:2;:16;;;;18818:25;;;;;;;;18863:16;18871:7;18863;:16::i;:::-;18862:17;18854:26;;;;;;;;18916:2;18893:11;:20;18905:7;18893:20;;;;;;;;;;;;:25;;;;;;;;;;;;;;;;;;18929:33;:17;:21;18947:2;18929:21;;;;;;;;;;;;;;;:31;:33::i;:::-;19005:7;19001:2;18980:33;;18997:1;18980:33;;;;;;;;;;;;18754:267;;:::o;27597:164::-;27701:10;:17;;;;27674:15;:24;27690:7;27674:24;;;;;;;;;;;:44;;;;27729:10;27745:7;27729:24;;39:1:-1;33:3;27:10;23:18;57:10;52:3;45:23;79:10;72:17;;0:93;27729:24:0;;;;;;;;;;;;;;;;;;;;;;27597:164;:::o;21693:175::-;21793:1;21757:38;;:15;:24;21773:7;21757:24;;;;;;;;;;;;;;;;;;;;;:38;;;;21753:108;;;21847:1;21812:15;:24;21828:7;21812:24;;;;;;;;;;;;:37;;;;;;;;;;;;;;;;;;21753:108;21693:175;:::o;10286:110::-;10367:21;10386:1;10367:7;:14;;;:18;;:21;;;;:::i;:::-;10350:7;:14;;:38;;;;10286:110;:::o;10187:91::-;10269:1;10251:7;:14;;;:19;;;;;;;;;;;10187:91;:::o;1250:150::-;1308:7;1341:1;1336;:6;;1328:15;;;;;;;;1354:9;1370:1;1366;:5;1354:17;;1391:1;1384:8;;;1250:150;;;;:::o;36712:1857::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;:::o;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;:::o;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;:::o

Swarm Source

bzzr://efcc7455469ab10f8be3482145f44ca6f71d9c621a8a1f0d5cb50dbb3f7f88ab
Block Transaction Difficulty Gas Used Reward
Block Uncle Number Difficulty Gas Used Reward
Loading
Loading
Make sure to use the "Vote Down" button for any spammy posts, and the "Vote Up" for interesting conversations.

A contract address hosts a smart contract, which is a set of code stored on the blockchain that runs when predetermined conditions are met. Learn more about addresses in our Knowledge Base.