Contract 0x729e154625c8c66db8b507b53d2da7b3dd02e7b5

 
 
Txn Hash Method
Block
From
To
Value [Txn Fee]
0xffde409bc964050a29f12d239c414d4ff6d7bd61d18f3307ae4bf338c9b1ea7fSet Approval For...130442822021-11-29 7:09:5713 hrs 3 mins ago0x76ffa1b437cfdad0509547db4d9971e73ed2826e IN  0x729e154625c8c66db8b507b53d2da7b3dd02e7b50 BNB0.000224325
0x6db863d22f704097e9743252b73ed3baabc7c1f0c97e204ad83e5f1330433823Transfer From130438972021-11-29 6:47:0213 hrs 26 mins ago0xf15ba5d47c63079ef9d6e6149e325b0b76d58610 IN  0x729e154625c8c66db8b507b53d2da7b3dd02e7b50 BNB0.000317000078
0xfd3b729b2bc3e841ad3ad763a6901f8314096c22b52aba5926c2f2d482fbd3f2Transfer From130438912021-11-29 6:46:3913 hrs 26 mins ago0xf15ba5d47c63079ef9d6e6149e325b0b76d58610 IN  0x729e154625c8c66db8b507b53d2da7b3dd02e7b50 BNB0.000392000096
0x12a65c7d9a006955f7d6f7139ae2be7f6f241b07639364d7b959e37c557feb69Transfer From130438842021-11-29 6:46:1413 hrs 26 mins ago0xf15ba5d47c63079ef9d6e6149e325b0b76d58610 IN  0x729e154625c8c66db8b507b53d2da7b3dd02e7b50 BNB0.000392000096
0xd2780e31c4ce2e1e1985b6e45b6c1976cbede851b9ccc57b2f93ff44714ce024Register Proxy130284782021-11-28 16:51:351 day 3 hrs ago0x668910a521863a0290d604cea80cd21b27b4f660 IN  0x729e154625c8c66db8b507b53d2da7b3dd02e7b50 BNB0.00022381
0x75fc573d25d88e79d79eeeaa1f9d01bad04b4ad2683f9e24b7c059fa8a27395eRegister Proxy130284702021-11-28 16:51:111 day 3 hrs ago0x668910a521863a0290d604cea80cd21b27b4f660 IN  0x729e154625c8c66db8b507b53d2da7b3dd02e7b50 BNB0.000111905
0x9b2a15324f28cf5acce1a1e92297bc5cec1045db155b30cdabd5d6ab9d331ab6Set Approval For...130212272021-11-28 10:19:161 day 9 hrs ago0x7232a54e2df1fcfc0e4a624d692124bb78ec0263 IN  0x729e154625c8c66db8b507b53d2da7b3dd02e7b50 BNB0.000224325
0x79da2563130ddd635889ff7251510ef7866414275c5c942684765f5c19532fcfSet Approval For...129911022021-11-27 7:28:322 days 12 hrs ago0x10f374bc9e1265322dc0e3760b22b1f2a9a51f0a IN  0x729e154625c8c66db8b507b53d2da7b3dd02e7b50 BNB0.000224325
0x080945b827bcec37c4f4911b66ab84491243676ec72e1fea6ab172c625d73c98Mint129722112021-11-26 14:27:023 days 5 hrs ago0x1929ef365fa3742054b4d33a7a054c5414b0dda6 IN  0x729e154625c8c66db8b507b53d2da7b3dd02e7b50 BNB0.000889865
0x5f261db9810c5ab90d28ff8e664a9522eb27186ad9ff4b14226415af9b68baaaRegister Proxy129721882021-11-26 14:25:533 days 5 hrs ago0x1929ef365fa3742054b4d33a7a054c5414b0dda6 IN  0x729e154625c8c66db8b507b53d2da7b3dd02e7b50 BNB0.001208535
0x193be47b605f6d35c81542ae2a3b84099ee47d6437ef32230febed555da6c897Register Proxy129686142021-11-26 11:10:073 days 9 hrs ago0xe001b37e076bac67811f344fca5fcd92936cb74d IN  0x729e154625c8c66db8b507b53d2da7b3dd02e7b50 BNB0.001208535
0x52c20733055fc8726311b36924f9ed53c43c5237c61fc367ae861418a0811dbcSet Approval For...129685842021-11-26 11:08:373 days 9 hrs ago0x57f96ccc24ba3825a361f1e11b7a61c1e00f0e9f IN  0x729e154625c8c66db8b507b53d2da7b3dd02e7b50 BNB0.000240252075
0x4dd8d21fdeb87290d555fcc6792188bb40294dbf8397fa287c71f1b2bf292987Transfer From129382532021-11-25 6:50:404 days 13 hrs ago0x3ddd04439725053f6009d18b4e0bdcd5ff001170 IN  0x729e154625c8c66db8b507b53d2da7b3dd02e7b50 BNB0.00033937848
0x40f678905ea0503a454953da5442a88acafe87313d689adc6c3594a54139ea9bMint128842672021-11-23 7:33:136 days 12 hrs ago0xa268201ed32762616e77de3437e08880abce888a IN  0x729e154625c8c66db8b507b53d2da7b3dd02e7b50 BNB0.000889865
0x8f5cf53e6c99b7022c77947893bc62c75e84a7b98ff704f73866ca6327fdf4abRegister Proxy128842522021-11-23 7:32:286 days 12 hrs ago0xa268201ed32762616e77de3437e08880abce888a IN  0x729e154625c8c66db8b507b53d2da7b3dd02e7b50 BNB0.001208535
0x0c17f2e90c256d8ca5f9d7da216ad10bb108d66d0b34d05f3acd996f4b06246aMint128824122021-11-23 5:58:226 days 14 hrs ago0x719743e3efa881650f78ba00da1ecc5c0c63ca95 IN  0x729e154625c8c66db8b507b53d2da7b3dd02e7b50 BNB0.000889865
0xf9ee05a3f54707a829f0b8df203dce0196aff922cedf29d477888eb6e1aa4128Register Proxy128823942021-11-23 5:57:286 days 14 hrs ago0x719743e3efa881650f78ba00da1ecc5c0c63ca95 IN  0x729e154625c8c66db8b507b53d2da7b3dd02e7b50 BNB0.001208535
0x6f89d973ca1642fd0c7c19d350312a9164d73c2c304a3ae0ccc983bba701d081Mint128822582021-11-23 5:50:406 days 14 hrs ago0x5e745aace240dffa2358c2b47f3eff4a3a85e12b IN  0x729e154625c8c66db8b507b53d2da7b3dd02e7b50 BNB0.000889865
0x88adc384e3735b75679c69925022928146ee714fbdd6b2937b3f7c8d8c1fb3a8Register Proxy128822462021-11-23 5:50:046 days 14 hrs ago0x5e745aace240dffa2358c2b47f3eff4a3a85e12b IN  0x729e154625c8c66db8b507b53d2da7b3dd02e7b50 BNB0.001208535
0xa695d95711870f518045e189f0acbe4fb643789f3cee4d1fc85e98e9c39d11b5Register Proxy128657872021-11-22 15:47:497 days 4 hrs ago0x69f8df0073ae98a1b93b3984d75241514c282f2e IN  0x729e154625c8c66db8b507b53d2da7b3dd02e7b50 BNB0.000111905
0x114a227f7f364d588ccf25ccca6a7cc3f450b7374399cd78f4c37fe68cddfb1eRegister Proxy128654462021-11-22 15:29:027 days 4 hrs ago0x59c39a79011ddee2596b8b6f9b52784718c1e1fa IN  0x729e154625c8c66db8b507b53d2da7b3dd02e7b50 BNB0.000111905
0xbbb05c85ec61191d81a8cf617c035179ff58b6b7bbf35fa7a515f090d7f7f7feRegister Proxy128653752021-11-22 15:25:297 days 4 hrs ago0x59c39a79011ddee2596b8b6f9b52784718c1e1fa IN  0x729e154625c8c66db8b507b53d2da7b3dd02e7b50 BNB0.001208535
0x6735b2fe32da533efcf5f328ba84a49db4b8da1e8eda61ba85b0c2ada41c2eebRegister Proxy128648482021-11-22 14:58:027 days 5 hrs ago0x69f8df0073ae98a1b93b3984d75241514c282f2e IN  0x729e154625c8c66db8b507b53d2da7b3dd02e7b50 BNB0.001208535
0xfe638706fa2f413615dd0bcd84ed1a25275458897b6d375fab9f11a304aceaa9Mint128628632021-11-22 13:10:127 days 7 hrs ago0xc48efd5092c819c91c313967657a958b2d803c51 IN  0x729e154625c8c66db8b507b53d2da7b3dd02e7b50 BNB0.000889865
0xe122b99434516e45ff828c3eebdf4fd383a1b4204c6d05bdc6269f28da657925Register Proxy128628032021-11-22 13:07:027 days 7 hrs ago0xc48efd5092c819c91c313967657a958b2d803c51 IN  0x729e154625c8c66db8b507b53d2da7b3dd02e7b50 BNB0.001208535
[ Download CSV Export 
Latest 25 internal transaction
Parent Txn Hash Block From To Value
0x5f261db9810c5ab90d28ff8e664a9522eb27186ad9ff4b14226415af9b68baaa129721882021-11-26 14:25:533 days 5 hrs ago 0x729e154625c8c66db8b507b53d2da7b3dd02e7b5  Contract Creation0 BNB
0x193be47b605f6d35c81542ae2a3b84099ee47d6437ef32230febed555da6c897129686142021-11-26 11:10:073 days 9 hrs ago 0x729e154625c8c66db8b507b53d2da7b3dd02e7b5  Contract Creation0 BNB
0x8f5cf53e6c99b7022c77947893bc62c75e84a7b98ff704f73866ca6327fdf4ab128842522021-11-23 7:32:286 days 12 hrs ago 0x729e154625c8c66db8b507b53d2da7b3dd02e7b5  Contract Creation0 BNB
0xf9ee05a3f54707a829f0b8df203dce0196aff922cedf29d477888eb6e1aa4128128823942021-11-23 5:57:286 days 14 hrs ago 0x729e154625c8c66db8b507b53d2da7b3dd02e7b5  Contract Creation0 BNB
0x88adc384e3735b75679c69925022928146ee714fbdd6b2937b3f7c8d8c1fb3a8128822462021-11-23 5:50:046 days 14 hrs ago 0x729e154625c8c66db8b507b53d2da7b3dd02e7b5  Contract Creation0 BNB
0xbbb05c85ec61191d81a8cf617c035179ff58b6b7bbf35fa7a515f090d7f7f7fe128653752021-11-22 15:25:297 days 4 hrs ago 0x729e154625c8c66db8b507b53d2da7b3dd02e7b5  Contract Creation0 BNB
0x6735b2fe32da533efcf5f328ba84a49db4b8da1e8eda61ba85b0c2ada41c2eeb128648482021-11-22 14:58:027 days 5 hrs ago 0x729e154625c8c66db8b507b53d2da7b3dd02e7b5  Contract Creation0 BNB
0xe122b99434516e45ff828c3eebdf4fd383a1b4204c6d05bdc6269f28da657925128628032021-11-22 13:07:027 days 7 hrs ago 0x729e154625c8c66db8b507b53d2da7b3dd02e7b5  Contract Creation0 BNB
0xac3d0259b1348e2892f4e6e1aeb0a8d6061caf4756f230400d30d30e8941bd17128626982021-11-22 13:01:467 days 7 hrs ago 0x729e154625c8c66db8b507b53d2da7b3dd02e7b5  Contract Creation0 BNB
0xf6a1ac852b4c7abf716b35a7ef5029efda2509c18e41065dab26320199575ab3128624822021-11-22 12:50:217 days 7 hrs ago 0x729e154625c8c66db8b507b53d2da7b3dd02e7b5  Contract Creation0 BNB
0x8d206aeb4844a3854b69893e2f2dc158a903e5adc491dc2d6fe6b45514380bea128370352021-11-21 15:12:228 days 5 hrs ago 0x729e154625c8c66db8b507b53d2da7b3dd02e7b5  Contract Creation0 BNB
0x3d235de592a5b3c9f91e1ac244d858b88b7b90d0e3970c713b4cdb838f8ddc10128341742021-11-21 12:40:198 days 7 hrs ago 0x729e154625c8c66db8b507b53d2da7b3dd02e7b5  Contract Creation0 BNB
0xa1336b2ca267d57c61b72cd94b392e30ec9d909c8c548c40f4fbffc89b12b216128321132021-11-21 10:52:368 days 9 hrs ago 0x729e154625c8c66db8b507b53d2da7b3dd02e7b5  Contract Creation0 BNB
0xc65498ca0337a2360bdab4217895152e56e07dfbe94266bb3977a007df041184128276472021-11-21 7:06:248 days 13 hrs ago 0x729e154625c8c66db8b507b53d2da7b3dd02e7b5  Contract Creation0 BNB
0x9dfa06391945eea3f7f2bb50bd064f6f98f090028ff5c2c25c7225a8a75215f5128275232021-11-21 7:00:118 days 13 hrs ago 0x729e154625c8c66db8b507b53d2da7b3dd02e7b5  Contract Creation0 BNB
0xdcc6ef761ff1293922fecd7b353af7194bcfd4ef30ef24c51a17c0fb8a9da241128274342021-11-21 6:55:448 days 13 hrs ago 0x729e154625c8c66db8b507b53d2da7b3dd02e7b5  Contract Creation0 BNB
0xec65e1d9281a5602756fa937e69111ed1493354bd8abb91e17203143aebe28ca128273292021-11-21 6:50:298 days 13 hrs ago 0x729e154625c8c66db8b507b53d2da7b3dd02e7b5  Contract Creation0 BNB
0xe06f419556f2f6f853f78be7b91c4e340355baa0335ec3fee4fa6d720414f502128271552021-11-21 6:41:478 days 13 hrs ago 0x729e154625c8c66db8b507b53d2da7b3dd02e7b5  Contract Creation0 BNB
0x16693ad584f507572a7e85926e95fe904d9eedf7d653a53e1c789d90c564c236128269082021-11-21 6:28:338 days 13 hrs ago 0x729e154625c8c66db8b507b53d2da7b3dd02e7b5  Contract Creation0 BNB
0x2b7df200af664e5a94dbdd7df402a85c865a46e2fad9fe8c61b652fed9854215128268332021-11-21 6:24:478 days 13 hrs ago 0x729e154625c8c66db8b507b53d2da7b3dd02e7b5  Contract Creation0 BNB
0xc1e276110dce73829b537810908721eca078cece5f2d932d7460fb683470a011128266492021-11-21 6:15:358 days 13 hrs ago 0x729e154625c8c66db8b507b53d2da7b3dd02e7b5  Contract Creation0 BNB
0xc879f8dc5a10b705331293dd713bec3653f32f075b4de9a4d48e95c9999a780e128266482021-11-21 6:15:328 days 13 hrs ago 0x729e154625c8c66db8b507b53d2da7b3dd02e7b5  Contract Creation0 BNB
0x072722d760beeb3dc1ceb95766f7e11bc809741ef9c01b4fdbb3a6c96d36ced2128264722021-11-21 6:06:448 days 14 hrs ago 0x729e154625c8c66db8b507b53d2da7b3dd02e7b5  Contract Creation0 BNB
0x66a85b8b9b33c4fe8f1361e59b7ed03a5626b468948196c813887de18439987a128262912021-11-21 5:57:398 days 14 hrs ago 0x729e154625c8c66db8b507b53d2da7b3dd02e7b5  Contract Creation0 BNB
0x76991cd4b07dc99344d1b36d04bdd76faebc64929e7c15f792ac75ad10f27568128261302021-11-21 5:49:358 days 14 hrs ago 0x729e154625c8c66db8b507b53d2da7b3dd02e7b5  Contract Creation0 BNB
[ Download CSV Export 
Loading

Contract Source Code Verified (Exact Match)

Contract Name:
WrappedPunk

Compiler Version
v0.5.11+commit.22be8592

Optimization Enabled:
No with 200 runs

Other Settings:
default evmVersion, None license

Contract Source Code (Solidity)

/**
 *Submitted for verification at BscScan.com on 2021-09-08
*/

// SPDX-License-Identifier: MIT
pragma solidity ^0.5.0;

/*
 * @dev Provides information about the current execution context, including the
 * sender of the transaction and its data. While these are generally available
 * via msg.sender and msg.data, they should not be accessed in such a direct
 * manner, since when dealing with GSN meta-transactions the account sending and
 * paying for execution may not be the actual sender (as far as an application
 * is concerned).
 *
 * This contract is only required for intermediate, library-like contracts.
 */
contract Context {
    // Empty internal constructor, to prevent people from mistakenly deploying
    // an instance of this contract, which should be used via inheritance.
    constructor() internal {}

    // solhint-disable-previous-line no-empty-blocks

    function _msgSender() internal view returns (address payable) {
        return msg.sender;
    }

    function _msgData() internal view returns (bytes memory) {
        this; // silence state mutability warning without generating bytecode - see https://github.com/ethereum/solidity/issues/2691
        return msg.data;
    }
}

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

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

    /**
     * @dev Initializes the contract setting the deployer as the initial owner.
     */
    constructor() internal {
        address msgSender = _msgSender();

        _owner = msgSender;

        emit OwnershipTransferred(address(0), msgSender);
    }

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

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

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

        _owner = address(0);
    }

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

        emit OwnershipTransferred(_owner, newOwner);

        _owner = newOwner;
    }
}

/**
 * @dev Contract module which allows children to implement an emergency stop
 * mechanism that can be triggered by an authorized account.
 *
 * This module is used through inheritance. It will make available the
 * modifiers `whenNotPaused` and `whenPaused`, which can be applied to
 * the functions of your contract. Note that they will not be pausable by
 * simply including this module, only once the modifiers are put in place.
 */
contract Pausable is Context {
    /**
     * @dev Emitted when the pause is triggered by `account`.
     */
    event Paused(address account);

    /**
     * @dev Emitted when the pause is lifted by `account`.
     */
    event Unpaused(address account);

    bool private _paused;

    /**
     * @dev Initializes the contract in unpaused state.
     */
    constructor() internal {
        _paused = false;
    }

    /**
     * @dev Returns true if the contract is paused, and false otherwise.
     */
    function paused() public view returns (bool) {
        return _paused;
    }

    /**
     * @dev Modifier to make a function callable only when the contract is not paused.
     *
     * Requirements:
     *
     * - The contract must not be paused.
     */
    modifier whenNotPaused() {
        require(!_paused, "Pausable: paused");
        _;
    }

    /**
     * @dev Modifier to make a function callable only when the contract is paused.
     *
     * Requirements:
     *
     * - The contract must be paused.
     */
    modifier whenPaused() {
        require(_paused, "Pausable: not paused");
        _;
    }

    /**
     * @dev Triggers stopped state.
     *
     * Requirements:
     *
     * - The contract must not be paused.
     */
    function _pause() internal whenNotPaused {
        _paused = true;

        emit Paused(_msgSender());
    }

    /**
     * @dev Returns to normal state.
     *
     * Requirements:
     *
     * - The contract must be paused.
     */
    function _unpause() internal whenPaused {
        _paused = false;

        emit Unpaused(_msgSender());
    }
}

/**
 * @title ERC-721 Non-Fungible Token Standard, optional enumeration extension
 * @dev See https://eips.ethereum.org/EIPS/eip-721
 */
interface IERC721Enumerable {
    /**
     * @dev Returns the total amount of tokens stored by the contract.
     */
    function totalSupply() external view returns (uint256);

    /**
     * @dev Returns a token ID owned by `owner` at a given `index` of its token list.
     * Use along with {balanceOf} to enumerate all of ``owner``'s tokens.
     */
    function tokenOfOwnerByIndex(address owner, uint256 index)
        external
        view
        returns (uint256 tokenId);

    /**
     * @dev Returns a token ID at a given `index` of all the tokens stored by the contract.
     * Use along with {totalSupply} to enumerate all tokens.
     */
    function tokenByIndex(uint256 index) external view returns (uint256);
}

/**
 * @dev Wrappers over Solidity's arithmetic operations with added overflow
 * checks.
 *
 * Arithmetic operations in Solidity wrap on overflow. This can easily result
 * in bugs, because programmers usually assume that an overflow raises an
 * error, which is the standard behavior in high level programming languages.
 * `SafeMath` restores this intuition by reverting the transaction when an
 * operation overflows.
 *
 * Using this library instead of the unchecked operations eliminates an entire
 * class of bugs, so it's recommended to use it always.
 */
library SafeMath {
    /**
     * @dev Returns the addition of two unsigned integers, reverting on
     * overflow.
     *
     * Counterpart to Solidity's `+` operator.
     *
     * Requirements:
     * - Addition cannot overflow.
     */
    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        uint256 c = a + b;

        require(c >= a, "SafeMath: addition overflow");

        return c;
    }

    /**
     * @dev Returns the subtraction of two unsigned integers, reverting on
     * overflow (when the result is negative).
     *
     * Counterpart to Solidity's `-` operator.
     *
     * Requirements:
     * - Subtraction cannot overflow.
     */
    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
        require(b <= a, "SafeMath: subtraction overflow");

        return a - b;
    }

    /**
     * @dev Returns the multiplication of two unsigned integers, reverting on
     * overflow.
     *
     * Counterpart to Solidity's `*` operator.
     *
     * Requirements:
     * - Multiplication cannot overflow.
     */
    function mul(uint256 a, uint256 b) internal pure returns (uint256) {
        // Gas optimization: this is cheaper than requiring 'a' not being zero, but the
        // benefit is lost if 'b' is also tested.
        // See: https://github.com/OpenZeppelin/openzeppelin-contracts/pull/522
        if (a == 0) {
            return 0;
        }

        uint256 c = a * b;

        require(c / a == b, "SafeMath: multiplication overflow");

        return c;
    }

    /**
     * @dev Returns the integer division of two unsigned integers. Reverts on
     * division by zero. The result is rounded towards zero.
     *
     * Counterpart to Solidity's `/` operator. Note: this function uses a
     * `revert` opcode (which leaves remaining gas untouched) while Solidity
     * uses an invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     * - The divisor cannot be zero.
     */
    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        require(b > 0, "SafeMath: division by zero");

        return a / b;
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers. (unsigned integer modulo),
     * Reverts when dividing by zero.
     *
     * Counterpart to Solidity's `%` operator. This function uses a `revert`
     * opcode (which leaves remaining gas untouched) while Solidity uses an
     * invalid opcode to revert (consuming all remaining gas).
     *
     * Requirements:
     * - The divisor cannot be zero.
     */
    function mod(uint256 a, uint256 b) internal pure returns (uint256) {
        require(b > 0, "SafeMath: modulo by zero");

        return a % b;
    }
}

/**
 * @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 {
        // The {SafeMath} overflow check can be skipped here, see the comment at the top
        counter._value += 1;
    }

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

/**
 * @dev Collection of functions related to the address type
 */
library Address {
    /**
     * @dev Returns true if `account` is a contract.
     *
     * [IMPORTANT]
     * ====
     * It is unsafe to assume that an address for which this function returns
     * false is an externally-owned account (EOA) and not a contract.
     *
     * Among others, `isContract` will return false for the following
     * types of addresses:
     *
     *  - an externally-owned account
     *  - a contract in construction
     *  - an address where a contract will be created
     *  - an address where a contract lived, but was destroyed
     * ====
     */
    function isContract(address account) internal view returns (bool) {
        // According to EIP-1052, 0x0 is the value returned for not-yet created accounts
        // and 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470 is returned
        // for accounts without code, i.e. `keccak256('')`
        bytes32 codehash;
        bytes32 accountHash = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470;

        // solhint-disable-next-line no-inline-assembly
        assembly {
            codehash := extcodehash(account)
        }

        return (codehash != accountHash && codehash != 0x0);
    }

    /**
     * @dev Converts an `address` into `address payable`. Note that this is
     * simply a type cast: the actual underlying value is not changed.
     *
     * _Available since v2.4.0._
     */
    function toPayable(address account)
        internal
        pure
        returns (address payable)
    {
        return address(uint160(account));
    }
}

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

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

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

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

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

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

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

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

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

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

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

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

/**
 * @title ERC721 token receiver interface
 * @dev Interface for any contract that wants to support safeTransfers
 * from ERC721 asset contracts.
 */
interface IERC721Receiver {
    /**
     * @notice Handle the receipt of an NFT
     * @dev The ERC721 smart contract calls this function on the recipient
     * after a {IERC721-safeTransferFrom}. This function MUST return the function selector,
     * otherwise the caller will revert the transaction. The selector to be
     * returned can be obtained as `this.onERC721Received.selector`. This
     * function MAY throw to revert and reject the transfer.
     * Note: the ERC721 contract address is always the message sender.
     * @param operator The address which called `safeTransferFrom` function
     * @param from The address which previously owned the token
     * @param tokenId The NFT identifier which is being transferred
     * @param data Additional data with no specified format
     * @return bytes4 `bytes4(keccak256("onERC721Received(address,address,uint256,bytes)"))`
     */
    function onERC721Received(
        address operator,
        address from,
        uint256 tokenId,
        bytes calldata data
    ) external returns (bytes4);
}

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

/**
 * @dev Implementation of the {IERC165} interface.
 *
 * Contracts may inherit from this and call {_registerInterface} to declare
 * their support of an interface.
 */
contract ERC165 is IERC165 {
    /*
     * bytes4(keccak256('supportsInterface(bytes4)')) == 0x01ffc9a7
     */
    bytes4 private constant _INTERFACE_ID_ERC165 = 0x01ffc9a7;

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

    constructor() internal {
        // Derived contracts need only register support for their own interfaces,
        // we register support for ERC165 itself here
        _registerInterface(_INTERFACE_ID_ERC165);
    }

    /**
     * @dev See {IERC165-supportsInterface}.
     *
     * Time complexity O(1), guaranteed to always use less than 30 000 gas.
     */
    function supportsInterface(bytes4 interfaceId) public view returns (bool) {
        return _supportedInterfaces[interfaceId];
    }

    /**
     * @dev Registers the contract as an implementer of the interface defined by
     * `interfaceId`. Support of the actual ERC165 interface is automatic and
     * registering its interface id is not required.
     *
     * See {IERC165-supportsInterface}.
     *
     * Requirements:
     *
     * - `interfaceId` cannot be the ERC165 invalid interface (`0xffffffff`).
     */
    function _registerInterface(bytes4 interfaceId) internal {
        require(interfaceId != 0xffffffff, "ERC165: invalid interface id");

        _supportedInterfaces[interfaceId] = true;
    }
}

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

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

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

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

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

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

    /*
     *     bytes4(keccak256('balanceOf(address)')) == 0x70a08231
     *     bytes4(keccak256('ownerOf(uint256)')) == 0x6352211e
     *     bytes4(keccak256('approve(address,uint256)')) == 0x095ea7b3
     *     bytes4(keccak256('getApproved(uint256)')) == 0x081812fc
     *     bytes4(keccak256('setApprovalForAll(address,bool)')) == 0xa22cb465
     *     bytes4(keccak256('isApprovedForAll(address,address)')) == 0xe985e9c5
     *     bytes4(keccak256('transferFrom(address,address,uint256)')) == 0x23b872dd
     *     bytes4(keccak256('safeTransferFrom(address,address,uint256)')) == 0x42842e0e
     *     bytes4(keccak256('safeTransferFrom(address,address,uint256,bytes)')) == 0xb88d4fde
     *
     *     => 0x70a08231 ^ 0x6352211e ^ 0x095ea7b3 ^ 0x081812fc ^
     *        0xa22cb465 ^ 0xe985e9c ^ 0x23b872dd ^ 0x42842e0e ^ 0xb88d4fde == 0x80ac58cd
     */
    bytes4 private constant _INTERFACE_ID_ERC721 = 0x80ac58cd;

    constructor() public {
        // Register the supported interfaces to conform to ERC721 via ERC165
        _registerInterface(_INTERFACE_ID_ERC721);
    }

    /**
     * @dev Gets the balance of the specified address.
     * @param owner address to query the balance of
     * @return uint256 representing the amount owned by the passed address
     */
    function balanceOf(address owner) public view returns (uint256) {
        require(
            owner != address(0),
            "ERC721: balance query for the zero address"
        );

        return _ownedTokensCount[owner].current();
    }

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

        require(
            owner != address(0),
            "ERC721: owner query for nonexistent token"
        );

        return owner;
    }

    /**
     * @dev Approves another address to transfer the given token ID
     * The zero address indicates there is no approved address.
     * There can only be one approved address per token at a given time.
     * Can only be called by the token owner or an approved operator.
     * @param to address to be approved for the given token ID
     * @param tokenId uint256 ID of the token to be approved
     */
    function approve(address to, uint256 tokenId) public {
        address owner = ownerOf(tokenId);

        require(to != owner, "ERC721: approval to current owner");

        require(
            _msgSender() == owner || isApprovedForAll(owner, _msgSender()),
            "ERC721: approve caller is not owner nor approved for all"
        );

        _tokenApprovals[tokenId] = to;

        emit Approval(owner, to, tokenId);
    }

    /**
     * @dev Gets the approved address for a token ID, or zero if no address set
     * Reverts if the token ID does not exist.
     * @param tokenId uint256 ID of the token to query the approval of
     * @return address currently approved for the given token ID
     */
    function getApproved(uint256 tokenId) public view returns (address) {
        require(
            _exists(tokenId),
            "ERC721: approved query for nonexistent token"
        );

        return _tokenApprovals[tokenId];
    }

    /**
     * @dev Sets or unsets the approval of a given operator
     * An operator is allowed to transfer all tokens of the sender on their behalf.
     * @param to operator address to set the approval
     * @param approved representing the status of the approval to be set
     */
    function setApprovalForAll(address to, bool approved) public {
        address msgSender = _msgSender();

        require(to != msgSender, "ERC721: approve to caller");

        _operatorApprovals[msgSender][to] = approved;

        emit ApprovalForAll(msgSender, to, approved);
    }

    /**
     * @dev Tells whether an operator is approved by a given owner.
     * @param owner owner address which you want to query the approval of
     * @param operator operator address which you want to query the approval of
     * @return bool whether the given operator is approved by the given owner
     */
    function isApprovedForAll(address owner, address operator)
        public
        view
        returns (bool)
    {
        return _operatorApprovals[owner][operator];
    }

    /**
     * @dev Transfers the ownership of a given token ID to another address.
     * Usage of this method is discouraged, use {safeTransferFrom} whenever possible.
     * Requires the msg.sender to be the owner, approved, or operator.
     * @param from current owner of the token
     * @param to address to receive the ownership of the given token ID
     * @param tokenId uint256 ID of the token to be transferred
     */
    function transferFrom(
        address from,
        address to,
        uint256 tokenId
    ) public {
        // solhint-disable-next-line max-line-length
        require(
            _isApprovedOrOwner(_msgSender(), tokenId),
            "ERC721: transfer caller is not owner nor approved"
        );

        _transferFrom(from, to, tokenId);
    }

    /**
     * @dev Safely transfers the ownership of a given token ID to another address
     * If the target address is a contract, it must implement {IERC721Receiver-onERC721Received},
     * which is called upon a safe transfer, and return the magic value
     * `bytes4(keccak256("onERC721Received(address,address,uint256,bytes)"))`; otherwise,
     * the transfer is reverted.
     * Requires the msg.sender to be the owner, approved, or operator
     * @param from current owner of the token
     * @param to address to receive the ownership of the given token ID
     * @param tokenId uint256 ID of the token to be transferred
     */
    function safeTransferFrom(
        address from,
        address to,
        uint256 tokenId
    ) public {
        safeTransferFrom(from, to, tokenId, "");
    }

    /**
     * @dev Safely transfers the ownership of a given token ID to another address
     * If the target address is a contract, it must implement {IERC721Receiver-onERC721Received},
     * which is called upon a safe transfer, and return the magic value
     * `bytes4(keccak256("onERC721Received(address,address,uint256,bytes)"))`; otherwise,
     * the transfer is reverted.
     * Requires the _msgSender() to be the owner, approved, or operator
     * @param from current owner of the token
     * @param to address to receive the ownership of the given token ID
     * @param tokenId uint256 ID of the token to be transferred
     * @param _data bytes data to send along with a safe transfer check
     */
    function safeTransferFrom(
        address from,
        address to,
        uint256 tokenId,
        bytes memory _data
    ) public {
        require(
            _isApprovedOrOwner(_msgSender(), tokenId),
            "ERC721: transfer caller is not owner nor approved"
        );

        _safeTransferFrom(from, to, tokenId, _data);
    }

    /**
     * @dev Safely transfers the ownership of a given token ID to another address
     * If the target address is a contract, it must implement `onERC721Received`,
     * which is called upon a safe transfer, and return the magic value
     * `bytes4(keccak256("onERC721Received(address,address,uint256,bytes)"))`; otherwise,
     * the transfer is reverted.
     * Requires the msg.sender to be the owner, approved, or operator
     * @param from current owner of the token
     * @param to address to receive the ownership of the given token ID
     * @param tokenId uint256 ID of the token to be transferred
     * @param _data bytes data to send along with a safe transfer check
     */
    function _safeTransferFrom(
        address from,
        address to,
        uint256 tokenId,
        bytes memory _data
    ) internal {
        _transferFrom(from, to, tokenId);

        require(
            _checkOnERC721Received(from, to, tokenId, _data),
            "ERC721: transfer to non ERC721Receiver implementer"
        );
    }

    /**
     * @dev Returns whether the specified token exists.
     * @param tokenId uint256 ID of the token to query the existence of
     * @return bool whether the token exists
     */
    function _exists(uint256 tokenId) internal view returns (bool) {
        return _tokenOwner[tokenId] != address(0);
    }

    /**
     * @dev Returns whether the given spender can transfer a given token ID.
     * @param spender address of the spender to query
     * @param tokenId uint256 ID of the token to be transferred
     * @return bool whether the msg.sender is approved for the given token ID,
     * is an operator of the owner, or is the owner of the token
     */
    function _isApprovedOrOwner(address spender, uint256 tokenId)
        internal
        view
        returns (bool)
    {
        require(
            _exists(tokenId),
            "ERC721: operator query for nonexistent token"
        );

        address owner = ownerOf(tokenId);

        return (spender == owner ||
            getApproved(tokenId) == spender ||
            isApprovedForAll(owner, spender));
    }

    /**
     * @dev Internal function to safely mint a new token.
     * Reverts if the given token ID already exists.
     * If the target address is a contract, it must implement `onERC721Received`,
     * which is called upon a safe transfer, and return the magic value
     * `bytes4(keccak256("onERC721Received(address,address,uint256,bytes)"))`; otherwise,
     * the transfer is reverted.
     * @param to The address that will own the minted token
     * @param tokenId uint256 ID of the token to be minted
     */
    function _safeMint(address to, uint256 tokenId) internal {
        _safeMint(to, tokenId, "");
    }

    /**
     * @dev Internal function to safely mint a new token.
     * Reverts if the given token ID already exists.
     * If the target address is a contract, it must implement `onERC721Received`,
     * which is called upon a safe transfer, and return the magic value
     * `bytes4(keccak256("onERC721Received(address,address,uint256,bytes)"))`; otherwise,
     * the transfer is reverted.
     * @param to The address that will own the minted token
     * @param tokenId uint256 ID of the token to be minted
     * @param _data bytes data to send along with a safe transfer check
     */
    function _safeMint(
        address to,
        uint256 tokenId,
        bytes memory _data
    ) internal {
        _mint(to, tokenId);

        require(
            _checkOnERC721Received(address(0), to, tokenId, _data),
            "ERC721: transfer to non ERC721Receiver implementer"
        );
    }

    /**
     * @dev Internal function to mint a new token.
     * Reverts if the given token ID already exists.
     * @param to The address that will own the minted token
     * @param tokenId uint256 ID of the token to be minted
     */
    function _mint(address to, uint256 tokenId) internal {
        require(to != address(0), "ERC721: mint to the zero address");
        require(!_exists(tokenId), "ERC721: token already minted");

        _tokenOwner[tokenId] = to;
        _ownedTokensCount[to].increment();

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

    /**
     * @dev Internal function to burn a specific token.
     * Reverts if the token does not exist.
     * Deprecated, use {_burn} instead.
     * @param owner owner of the token to burn
     * @param tokenId uint256 ID of the token being burned
     */
    function _burn(address owner, uint256 tokenId) internal {
        require(
            ownerOf(tokenId) == owner,
            "ERC721: burn of token that is not own"
        );

        _clearApproval(tokenId);

        _ownedTokensCount[owner].decrement();
        _tokenOwner[tokenId] = address(0);

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

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

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

        _clearApproval(tokenId);

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

        _tokenOwner[tokenId] = to;

        emit Transfer(from, to, tokenId);
    }

    /**
     * @dev Internal function to invoke {IERC721Receiver-onERC721Received} on a target address.
     * The call is not executed if the target address is not a contract.
     *
     * This is an internal detail of the `ERC721` contract and its use is deprecated.
     * @param from address representing the previous owner of the given token ID
     * @param to target address that will receive the tokens
     * @param tokenId uint256 ID of the token to be transferred
     * @param _data bytes optional data to send along with the call
     * @return bool whether the call correctly returned the expected magic value
     */
    function _checkOnERC721Received(
        address from,
        address to,
        uint256 tokenId,
        bytes memory _data
    ) internal returns (bool) {
        if (!to.isContract()) {
            return true;
        }

        // solhint-disable-next-line avoid-low-level-calls
        (bool success, bytes memory returndata) = to.call(
            abi.encodeWithSelector(
                IERC721Receiver(to).onERC721Received.selector,
                _msgSender(),
                from,
                tokenId,
                _data
            )
        );

        if (!success) {
            if (returndata.length > 0) {
                // solhint-disable-next-line no-inline-assembly
                assembly {
                    let returndata_size := mload(returndata)
                    revert(add(32, returndata), returndata_size)
                }
            } else {
                revert("ERC721: transfer to non ERC721Receiver implementer");
            }
        } else {
            bytes4 retval = abi.decode(returndata, (bytes4));
            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 with optional enumeration extension logic
 * @dev See https://eips.ethereum.org/EIPS/eip-721
 */
contract ERC721Enumerable is ERC721, IERC721Enumerable {
    // Mapping from owner to list of owned token IDs
    mapping(address => uint256[]) private _ownedTokens;

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

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

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

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

    constructor() public {
        // Register the supported interface to conform to ERC721Enumerable via ERC165
        _registerInterface(_INTERFACE_ID_ERC721_ENUMERABLE);
    }

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

        return _ownedTokens[owner][index];
    }

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

    /**
     * @dev Gets the token ID at a given index of all the tokens in this contract
     * Reverts if the index is greater or equal to the total number of tokens.
     * @param index uint256 representing the index to be accessed of the tokens list
     * @return uint256 token ID at the given index of the tokens list
     */
    function tokenByIndex(uint256 index) public view returns (uint256) {
        require(
            index < totalSupply(),
            "ERC721Enumerable: global index out of bounds"
        );

        return _allTokens[index];
    }

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

        _removeTokenFromOwnerEnumeration(from, tokenId);

        _addTokenToOwnerEnumeration(to, tokenId);
    }

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

        _addTokenToOwnerEnumeration(to, tokenId);

        _addTokenToAllTokensEnumeration(tokenId);
    }

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

        _removeTokenFromOwnerEnumeration(owner, tokenId);

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

        _removeTokenFromAllTokensEnumeration(tokenId);
    }

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

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

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

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

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

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

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

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

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

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

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

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

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

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

/**
 * @title Strings
 * @dev String operations.
 */
library Strings {
    /**
     * @dev Converts a `uint256` to a `string`.
     * via OraclizeAPI - MIT licence
     * https://github.com/oraclize/ethereum-api/blob/b42146b063c7d6ee1358846c198246239e9360e8/oraclizeAPI_0.4.25.sol
     */
    function fromUint256(uint256 value) internal pure returns (string memory) {
        if (value == 0) {
            return "0";
        }

        uint256 temp = value;
        uint256 digits;

        while (temp != 0) {
            digits++;
            temp /= 10;
        }

        bytes memory buffer = new bytes(digits);
        uint256 index = digits - 1;

        temp = value;

        while (temp != 0) {
            buffer[index--] = bytes1(uint8(48 + (temp % 10)));
            temp /= 10;
        }

        return string(buffer);
    }
}

/**
 * @title ERC-721 Non-Fungible Token Standard, optional metadata extension
 * @dev See https://eips.ethereum.org/EIPS/eip-721
 */
interface IERC721Metadata {
    /**
     * @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);
}

contract ERC721Metadata is ERC721, IERC721Metadata {
    using Strings for uint256;

    // Token name
    string private _name;

    // Token symbol
    string private _symbol;

    // Base URI
    string private _baseURI;

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

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

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

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

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

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

    /**
     * @dev Returns the URI for a given token ID. May return an empty string.
     *
     * If a base URI is set (via {_setBaseURI}), it is added as a prefix to the
     * token's own URI (via {_setTokenURI}).
     *
     * If there is a base URI but no token URI, the token's ID will be used as
     * its URI when appending it to the base URI. This pattern for autogenerated
     * token URIs can lead to large gas savings.
     *
     * .Examples
     * |===
     * |`_setBaseURI()` |`_setTokenURI()` |`tokenURI()`
     * | ""
     * | ""
     * | ""
     * | ""
     * | "token.uri/123"
     * | "token.uri/123"
     * | "token.uri/"
     * | "123"
     * | "token.uri/123"
     * | "token.uri/"
     * | ""
     * | "token.uri/<tokenId>"
     * |===
     *
     * Requirements:
     *
     * - `tokenId` must exist.
     */
    function tokenURI(uint256 tokenId) public view returns (string memory) {
        require(
            _exists(tokenId),
            "ERC721Metadata: URI query for nonexistent token"
        );

        string memory _tokenURI = _tokenURIs[tokenId];

        // If there is no base URI, return the token URI.
        if (bytes(_baseURI).length == 0) {
            return _tokenURI;
        }

        // If both are set, concatenate the baseURI and tokenURI (via abi.encodePacked).
        if (bytes(_tokenURI).length > 0) {
            return string(abi.encodePacked(_baseURI, _tokenURI));
        }

        // If there is a baseURI but no tokenURI, concatenate the tokenID to the baseURI.
        return string(abi.encodePacked(_baseURI, tokenId.fromUint256(), ".png"));
    }

    /**
     * @dev Internal function to set the token URI for a given token.
     *
     * Reverts if the token ID does not exist.
     *
     * TIP: if all token IDs share a prefix (e.g. if your URIs look like
     * `http://api.myproject.com/token/<id>`), use {_setBaseURI} to store
     * it and save gas.
     */
    function _setTokenURI(uint256 tokenId, string memory _tokenURI) internal {
        require(
            _exists(tokenId),
            "ERC721Metadata: URI set of nonexistent token"
        );

        _tokenURIs[tokenId] = _tokenURI;
    }

    /**
     * @dev Internal function to set the base URI for all token IDs. It is
     * automatically added as a prefix to the value returned in {tokenURI}.
     *
     * _Available since v2.5.0._
     */
    function _setBaseURI(string memory baseURI) internal {
        _baseURI = baseURI;
    }

    /**
     * @dev Returns the base URI set via {_setBaseURI}. This will be
     * automatically added as a preffix in {tokenURI} to each token's URI, when
     * they are non-empty.
     *
     * _Available since v2.5.0._
     */
    function baseURI() public view returns (string memory) {
        return _baseURI;
    }

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

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

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

interface ICryptoPunk {
    function punkIndexToAddress(uint256 punkIndex) external returns (address);

    function punksOfferedForSale(uint256 punkIndex)
        external
        returns (
            bool,
            uint256,
            address,
            uint256,
            address
        );

    function buyPunk(uint256 punkIndex) external payable;

    function transferPunk(address to, uint256 punkIndex) external;
}

contract UserProxy {
    address private _owner;

    /**
     * @dev Initializes the contract settings
     */
    constructor() public {
        _owner = msg.sender;
    }

    /**
     * @dev Transfers punk to the smart contract owner
     */
    function transfer(address punkContract, uint256 punkIndex)
        external
        returns (bool)
    {
        if (_owner != msg.sender) {
            return false;
        }

        (bool result, ) = punkContract.call(
            abi.encodeWithSignature(
                "transferPunk(address,uint256)",
                _owner,
                punkIndex
            )
        );

        return result;
    }
}

contract WrappedPunk is Ownable, ERC721Full, Pausable {
    event ProxyRegistered(address user, address proxy);

    // Instance of cryptopunk smart contract
    ICryptoPunk private _punkContract;

    // Mapping from user address to proxy address
    mapping(address => address) private _proxies;

    /**
     * @dev Initializes the contract settings
     */
    constructor(address punkContract)
        public
        ERC721Full("Wrapped Cryptopunks", "WPUNKS")
    {
        _punkContract = ICryptoPunk(punkContract);
    }

    /**
     * @dev Gets address of cryptopunk smart contract
     */
    function punkContract() public view returns (address) {
        return address(_punkContract);
    }

    /**
     * @dev Sets the base URI for all token
     */
    function setBaseURI(string memory baseUri) public onlyOwner {
        _setBaseURI(baseUri);
    }

    /**
     * @dev Triggers smart contract to stopped state
     */
    function pause() public onlyOwner {
        _pause();
    }

    /**
     * @dev Returns smart contract to normal state
     */
    function unpause() public onlyOwner {
        _unpause();
    }

    /**
     * @dev Registers proxy
     */
    function registerProxy() public {
        address sender = _msgSender();

        require(
            _proxies[sender] == address(0),
            "PunkWrapper: caller has registered the proxy"
        );

        address proxy = address(new UserProxy());

        _proxies[sender] = proxy;

        emit ProxyRegistered(sender, proxy);
    }

    /**
     * @dev Gets proxy address
     */
    function proxyInfo(address user) public view returns (address) {
        return _proxies[user];
    }

    /**
     * @dev Mints a wrapped punk
     */
    function mint(uint256 punkIndex) public whenNotPaused {
        address sender = _msgSender();

        UserProxy proxy = UserProxy(_proxies[sender]);

        require(
            proxy.transfer(address(_punkContract), punkIndex),
            "PunkWrapper: transfer fail"
        );

        _mint(sender, punkIndex);
    }

    /**
     * @dev Burns a specific wrapped punk
     */
    function burn(uint256 punkIndex) public whenNotPaused {
        address sender = _msgSender();

        require(
            _isApprovedOrOwner(sender, punkIndex),
            "PunkWrapper: caller is not owner nor approved"
        );

        _burn(punkIndex);

        // Transfers ownership of punk on original cryptopunk smart contract to caller
        _punkContract.transferPunk(sender, punkIndex);
    }

    /**
     * @dev Internal function to transfer ownership of a given punk index to another address
     */
    function _transferFrom(
        address from,
        address to,
        uint256 punkIndex
    ) internal whenNotPaused {
        super._transferFrom(from, to, punkIndex);
    }
}

Contract Security Audit

Contract ABI

[{"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":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"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":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":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"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":true,"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"uint256","name":"index","type":"uint256"}],"name":"tokenOfOwnerByIndex","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[],"name":"unpause","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":"uint256","name":"punkIndex","type":"uint256"}],"name":"burn","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"internalType":"uint256","name":"index","type":"uint256"}],"name":"tokenByIndex","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"string","name":"baseUri","type":"string"}],"name":"setBaseURI","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"paused","outputs":[{"internalType":"bool","name":"","type":"bool"}],"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":true,"inputs":[],"name":"baseURI","outputs":[{"internalType":"string","name":"","type":"string"}],"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":false,"inputs":[],"name":"renounceOwnership","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[],"name":"pause","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"internalType":"uint256","name":"punkIndex","type":"uint256"}],"name":"mint","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":true,"inputs":[{"internalType":"address","name":"user","type":"address"}],"name":"proxyInfo","outputs":[{"internalType":"address","name":"","type":"address"}],"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"},{"internalType":"bytes","name":"_data","type":"bytes"}],"name":"safeTransferFrom","outputs":[],"payable":false,"stateMutability":"nonpayable","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":[],"name":"registerProxy","outputs":[],"payable":false,"stateMutability":"nonpayable","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":false,"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"punkContract","outputs":[{"internalType":"address","name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"punkContract","type":"address"}],"payable":false,"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"user","type":"address"},{"indexed":false,"internalType":"address","name":"proxy","type":"address"}],"name":"ProxyRegistered","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"account","type":"address"}],"name":"Paused","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"account","type":"address"}],"name":"Unpaused","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"},{"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":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"}]

60806040523480156200001157600080fd5b506040516200482e3803806200482e833981810160405260208110156200003757600080fd5b81019080805190602001909291905050506040518060400160405280601381526020017f577261707065642043727970746f70756e6b73000000000000000000000000008152506040518060400160405280600681526020017f5750554e4b53000000000000000000000000000000000000000000000000000081525081816000620000c86200025f60201b60201c565b9050806000806101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055508073ffffffffffffffffffffffffffffffffffffffff16600073ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a3506200017e6301ffc9a760e01b6200026760201b60201c565b620001966380ac58cd60e01b6200026760201b60201c565b620001ae63780e9d6360e01b6200026760201b60201c565b81600a9080519060200190620001c692919062000370565b5080600b9080519060200190620001df92919062000370565b50620001f8635b5e139f60e01b6200026760201b60201c565b505050506000600e60006101000a81548160ff02191690831515021790555080600e60016101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550506200041f565b600033905090565b63ffffffff60e01b817bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916141562000304576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252601c8152602001807f4552433136353a20696e76616c696420696e746572666163652069640000000081525060200191505060405180910390fd5b6001806000837bffffffffffffffffffffffffffffffffffffffffffffffffffffffff19167bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916815260200190815260200160002060006101000a81548160ff02191690831515021790555050565b828054600181600116156101000203166002900490600052602060002090601f016020900481019282601f10620003b357805160ff1916838001178555620003e4565b82800160010185558215620003e4579182015b82811115620003e3578251825591602001919060010190620003c6565b5b509050620003f39190620003f7565b5090565b6200041c91905b8082111562000418576000816000905550600101620003fe565b5090565b90565b6143ff806200042f6000396000f3fe608060405234801561001057600080fd5b50600436106101cf5760003560e01c80636c0360eb11610104578063a22cb465116100a2578063ddd81f8211610071578063ddd81f8214610b03578063e985e9c514610b0d578063f2fde38b14610b89578063f97e48ee14610bcd576101cf565b8063a22cb46514610883578063a9c7b2c8146108d3578063b88d4fde14610957578063c87b56dd14610a5c576101cf565b80638456cb59116100de5780638456cb591461077e5780638da5cb5b1461078857806395d89b41146107d2578063a0712d6814610855576101cf565b80636c0360eb1461069957806370a082311461071c578063715018a614610774576101cf565b80633f4ba83a116101715780634f6ccce71161014b5780634f6ccce71461050c57806355f804b31461054e5780635c975abb146106095780636352211e1461062b576101cf565b80633f4ba83a1461046657806342842e0e1461047057806342966c68146104de576101cf565b8063095ea7b3116101ad578063095ea7b31461032a57806318160ddd1461037857806323b872dd146103965780632f745c5914610404576101cf565b806301ffc9a7146101d457806306fdde0314610239578063081812fc146102bc575b600080fd5b61021f600480360360208110156101ea57600080fd5b8101908080357bffffffffffffffffffffffffffffffffffffffffffffffffffffffff19169060200190929190505050610c17565b604051808215151515815260200191505060405180910390f35b610241610c7f565b6040518080602001828103825283818151815260200191508051906020019080838360005b83811015610281578082015181840152602081019050610266565b50505050905090810190601f1680156102ae5780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b6102e8600480360360208110156102d257600080fd5b8101908080359060200190929190505050610d21565b604051808273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390f35b6103766004803603604081101561034057600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff16906020019092919080359060200190929190505050610dbc565b005b610380610fa3565b6040518082815260200191505060405180910390f35b610402600480360360608110156103ac57600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff169060200190929190803573ffffffffffffffffffffffffffffffffffffffff16906020019092919080359060200190929190505050610fb0565b005b6104506004803603604081101561041a57600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff16906020019092919080359060200190929190505050611026565b6040518082815260200191505060405180910390f35b61046e6110e5565b005b6104dc6004803603606081101561048657600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff169060200190929190803573ffffffffffffffffffffffffffffffffffffffff169060200190929190803590602001909291905050506111b8565b005b61050a600480360360208110156104f457600080fd5b81019080803590602001909291905050506111d8565b005b6105386004803603602081101561052257600080fd5b8101908080359060200190929190505050611394565b6040518082815260200191505060405180910390f35b6106076004803603602081101561056457600080fd5b810190808035906020019064010000000081111561058157600080fd5b82018360208201111561059357600080fd5b803590602001918460018302840111640100000000831117156105b557600080fd5b91908080601f016020809104026020016040519081016040528093929190818152602001838380828437600081840152601f19601f820116905080830192505050505050509192919290505050611414565b005b6106116114e9565b604051808215151515815260200191505060405180910390f35b6106576004803603602081101561064157600080fd5b8101908080359060200190929190505050611500565b604051808273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390f35b6106a16115c8565b6040518080602001828103825283818151815260200191508051906020019080838360005b838110156106e15780820151818401526020810190506106c6565b50505050905090810190601f16801561070e5780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b61075e6004803603602081101561073257600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff16906020019092919050505061166a565b6040518082815260200191505060405180910390f35b61077c61173f565b005b6107866118c7565b005b61079061199a565b604051808273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390f35b6107da6119c3565b6040518080602001828103825283818151815260200191508051906020019080838360005b8381101561081a5780820151818401526020810190506107ff565b50505050905090810190601f1680156108475780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b6108816004803603602081101561086b57600080fd5b8101908080359060200190929190505050611a65565b005b6108d16004803603604081101561089957600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff169060200190929190803515159060200190929190505050611cbd565b005b610915600480360360208110156108e957600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff169060200190929190505050611e6d565b604051808273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390f35b610a5a6004803603608081101561096d57600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff169060200190929190803573ffffffffffffffffffffffffffffffffffffffff16906020019092919080359060200190929190803590602001906401000000008111156109d457600080fd5b8201836020820111156109e657600080fd5b80359060200191846001830284011164010000000083111715610a0857600080fd5b91908080601f016020809104026020016040519081016040528093929190818152602001838380828437600081840152601f19601f820116905080830192505050505050509192919290505050611ed6565b005b610a8860048036036020811015610a7257600080fd5b8101908080359060200190929190505050611f4e565b6040518080602001828103825283818151815260200191508051906020019080838360005b83811015610ac8578082015181840152602081019050610aad565b50505050905090810190601f168015610af55780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b610b0b61225f565b005b610b6f60048036036040811015610b2357600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff169060200190929190803573ffffffffffffffffffffffffffffffffffffffff169060200190929190505050612495565b604051808215151515815260200191505060405180910390f35b610bcb60048036036020811015610b9f57600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff169060200190929190505050612529565b005b610bd5612736565b604051808273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390f35b600060016000837bffffffffffffffffffffffffffffffffffffffffffffffffffffffff19167bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916815260200190815260200160002060009054906101000a900460ff169050919050565b6060600a8054600181600116156101000203166002900480601f016020809104026020016040519081016040528092919081815260200182805460018160011615610100020316600290048015610d175780601f10610cec57610100808354040283529160200191610d17565b820191906000526020600020905b815481529060010190602001808311610cfa57829003601f168201915b5050505050905090565b6000610d2c82612760565b610d81576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252602c8152602001806142a4602c913960400191505060405180910390fd5b6003600083815260200190815260200160002060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff169050919050565b6000610dc782611500565b90508073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff161415610e4e576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260218152602001806143286021913960400191505060405180910390fd5b8073ffffffffffffffffffffffffffffffffffffffff16610e6d6127cc565b73ffffffffffffffffffffffffffffffffffffffff161480610e9c5750610e9b81610e966127cc565b612495565b5b610ef1576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260388152602001806141ed6038913960400191505060405180910390fd5b826003600084815260200190815260200160002060006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550818373ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff167f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92560405160405180910390a4505050565b6000600880549050905090565b610fc1610fbb6127cc565b826127d4565b611016576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260318152602001806143496031913960400191505060405180910390fd5b6110218383836128c8565b505050565b60006110318361166a565b8210611088576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252602b81526020018061411a602b913960400191505060405180910390fd5b600660008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002082815481106110d257fe5b9060005260206000200154905092915050565b6110ed6127cc565b73ffffffffffffffffffffffffffffffffffffffff166000809054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16146111ae576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260208152602001807f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657281525060200191505060405180910390fd5b6111b661295b565b565b6111d383838360405180602001604052806000815250611ed6565b505050565b600e60009054906101000a900460ff161561125b576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260108152602001807f5061757361626c653a207061757365640000000000000000000000000000000081525060200191505060405180910390fd5b60006112656127cc565b905061127181836127d4565b6112c6576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252602d8152602001806140ed602d913960400191505060405180910390fd5b6112cf82612a64565b600e60019054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16638b72a2ec82846040518363ffffffff1660e01b8152600401808373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200182815260200192505050600060405180830381600087803b15801561137857600080fd5b505af115801561138c573d6000803e3d6000fd5b505050505050565b600061139e610fa3565b82106113f5576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252602c81526020018061437a602c913960400191505060405180910390fd5b6008828154811061140257fe5b90600052602060002001549050919050565b61141c6127cc565b73ffffffffffffffffffffffffffffffffffffffff166000809054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16146114dd576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260208152602001807f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657281525060200191505060405180910390fd5b6114e681612a79565b50565b6000600e60009054906101000a900460ff16905090565b6000806002600084815260200190815260200160002060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff169050600073ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff1614156115bf576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252602981526020018061424f6029913960400191505060405180910390fd5b80915050919050565b6060600c8054600181600116156101000203166002900480601f0160208091040260200160405190810160405280929190818152602001828054600181600116156101000203166002900480156116605780601f1061163557610100808354040283529160200191611660565b820191906000526020600020905b81548152906001019060200180831161164357829003601f168201915b5050505050905090565b60008073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff1614156116f1576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252602a815260200180614225602a913960400191505060405180910390fd5b611738600460008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020612a93565b9050919050565b6117476127cc565b73ffffffffffffffffffffffffffffffffffffffff166000809054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614611808576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260208152602001807f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657281525060200191505060405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff166000809054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a360008060006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550565b6118cf6127cc565b73ffffffffffffffffffffffffffffffffffffffff166000809054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614611990576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260208152602001807f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657281525060200191505060405180910390fd5b611998612aa1565b565b60008060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b6060600b8054600181600116156101000203166002900480601f016020809104026020016040519081016040528092919081815260200182805460018160011615610100020316600290048015611a5b5780601f10611a3057610100808354040283529160200191611a5b565b820191906000526020600020905b815481529060010190602001808311611a3e57829003601f168201915b5050505050905090565b600e60009054906101000a900460ff1615611ae8576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260108152602001807f5061757361626c653a207061757365640000000000000000000000000000000081525060200191505060405180910390fd5b6000611af26127cc565b90506000600f60008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1690508073ffffffffffffffffffffffffffffffffffffffff1663a9059cbb600e60019054906101000a900473ffffffffffffffffffffffffffffffffffffffff16856040518363ffffffff1660e01b8152600401808373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200182815260200192505050602060405180830381600087803b158015611c0157600080fd5b505af1158015611c15573d6000803e3d6000fd5b505050506040513d6020811015611c2b57600080fd5b8101908080519060200190929190505050611cae576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252601a8152602001807f50756e6b577261707065723a207472616e73666572206661696c00000000000081525060200191505060405180910390fd5b611cb88284612bab565b505050565b6000611cc76127cc565b90508073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff161415611d6b576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260198152602001807f4552433732313a20617070726f766520746f2063616c6c65720000000000000081525060200191505060405180910390fd5b81600560008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff0219169083151502179055508273ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff167f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c3184604051808215151515815260200191505060405180910390a3505050565b6000600f60008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff169050919050565b611ee7611ee16127cc565b836127d4565b611f3c576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260318152602001806143496031913960400191505060405180910390fd5b611f4884848484612bcc565b50505050565b6060611f5982612760565b611fae576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252602f8152602001806142f9602f913960400191505060405180910390fd5b6060600d60008481526020019081526020016000208054600181600116156101000203166002900480601f0160208091040260200160405190810160405280929190818152602001828054600181600116156101000203166002900480156120575780601f1061202c57610100808354040283529160200191612057565b820191906000526020600020905b81548152906001019060200180831161203a57829003601f168201915b505050505090506000600c8054600181600116156101000203166002900490501415612086578091505061225a565b60008151111561215f57600c8160405160200180838054600181600116156101000203166002900480156120f15780601f106120cf5761010080835404028352918201916120f1565b820191906000526020600020905b8154815290600101906020018083116120dd575b505082805190602001908083835b6020831061212257805182526020820191506020810190506020830392506120ff565b6001836020036101000a0380198251168184511680821785525050505050509050019250505060405160208183030381529060405291505061225a565b600c61216a84612c3e565b60405160200180838054600181600116156101000203166002900480156121c85780601f106121a65761010080835404028352918201916121c8565b820191906000526020600020905b8154815290600101906020018083116121b4575b505082805190602001908083835b602083106121f957805182526020820191506020810190506020830392506121d6565b6001836020036101000a038019825116818451168082178552505050505050905001807f2e706e6700000000000000000000000000000000000000000000000000000000815250600401925050506040516020818303038152906040529150505b919050565b60006122696127cc565b9050600073ffffffffffffffffffffffffffffffffffffffff16600f60008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff161461234f576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252602c815260200180614278602c913960400191505060405180910390fd5b600060405161235d90613c97565b604051809103906000f080158015612379573d6000803e3d6000fd5b50905080600f60008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055507f3623f8bd4da9524cfaa08c81b8194f759ca625e8d761f4cc2cea23e63d3f4b128282604051808373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020018273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019250505060405180910390a15050565b6000600560008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff16905092915050565b6125316127cc565b73ffffffffffffffffffffffffffffffffffffffff166000809054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16146125f2576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260208152602001807f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657281525060200191505060405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168173ffffffffffffffffffffffffffffffffffffffff161415612678576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260268152602001806141776026913960400191505060405180910390fd5b8073ffffffffffffffffffffffffffffffffffffffff166000809054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff167f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e060405160405180910390a3806000806101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555050565b6000600e60019054906101000a900473ffffffffffffffffffffffffffffffffffffffff16905090565b60008073ffffffffffffffffffffffffffffffffffffffff166002600084815260200190815260200160002060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1614159050919050565b600033905090565b60006127df82612760565b612834576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252602c8152602001806141c1602c913960400191505060405180910390fd5b600061283f83611500565b90508073ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff1614806128ae57508373ffffffffffffffffffffffffffffffffffffffff1661289684610d21565b73ffffffffffffffffffffffffffffffffffffffff16145b806128bf57506128be8185612495565b5b91505092915050565b600e60009054906101000a900460ff161561294b576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260108152602001807f5061757361626c653a207061757365640000000000000000000000000000000081525060200191505060405180910390fd5b612956838383612d6e565b505050565b600e60009054906101000a900460ff166129dd576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260148152602001807f5061757361626c653a206e6f742070617573656400000000000000000000000081525060200191505060405180910390fd5b6000600e60006101000a81548160ff0219169083151502179055507f5db9ee0a495bf2e6ff9c91a7834c1ba4fdd244a5e8aa4e537bd38aeae4b073aa612a216127cc565b604051808273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390a1565b612a76612a7082611500565b82612d92565b50565b80600c9080519060200190612a8f929190613ca4565b5050565b600081600001549050919050565b600e60009054906101000a900460ff1615612b24576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260108152602001807f5061757361626c653a207061757365640000000000000000000000000000000081525060200191505060405180910390fd5b6001600e60006101000a81548160ff0219169083151502179055507f62e78cea01bee320cd4e420270b5ea74000d11b0c9f74754ebdbfc544b05a258612b686127cc565b604051808273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390a1565b612bb58282612def565b612bbf8282613007565b612bc8816130ce565b5050565b612bd78484846128c8565b612be38484848461311a565b612c38576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260328152602001806141456032913960400191505060405180910390fd5b50505050565b60606000821415612c86576040518060400160405280600181526020017f30000000000000000000000000000000000000000000000000000000000000008152509050612d69565b600082905060005b60008214612cb0578080600101915050600a8281612ca857fe5b049150612c8e565b6060816040519080825280601f01601f191660200182016040528015612ce55781602001600182028038833980820191505090505b50905060006001830390508593505b60008414612d6157600a8481612d0657fe5b0660300160f81b82828060019003935081518110612d2057fe5b60200101907effffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916908160001a905350600a8481612d5957fe5b049350612cf4565b819450505050505b919050565b612d79838383613456565b612d8383826136b1565b612d8d8282613007565b505050565b612d9c828261384f565b6000600d600083815260200190815260200160002080546001816001161561010002031660029004905014612deb57600d60008281526020019081526020016000206000612dea9190613d24565b5b5050565b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff161415612e92576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260208152602001807f4552433732313a206d696e7420746f20746865207a65726f206164647265737381525060200191505060405180910390fd5b612e9b81612760565b15612f0e576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252601c8152602001807f4552433732313a20746f6b656e20616c7265616479206d696e7465640000000081525060200191505060405180910390fd5b816002600083815260200190815260200160002060006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550612fa7600460008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020613889565b808273ffffffffffffffffffffffffffffffffffffffff16600073ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60405160405180910390a45050565b600660008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020805490506007600083815260200190815260200160002081905550600660008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000208190806001815401808255809150509060018203906000526020600020016000909192909190915055505050565b6008805490506009600083815260200190815260200160002081905550600881908060018154018082558091505090600182039060005260206000200160009091929091909150555050565b600061313b8473ffffffffffffffffffffffffffffffffffffffff1661389f565b613148576001905061344e565b600060608573ffffffffffffffffffffffffffffffffffffffff168673ffffffffffffffffffffffffffffffffffffffff1663150b7a02905060e01b61318c6127cc565b898888604051602401808573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020018473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200183815260200180602001828103825283818151815260200191508051906020019080838360005b8381101561323c578082015181840152602081019050613221565b50505050905090810190601f1680156132695780820380516001836020036101000a031916815260200191505b5095505050505050604051602081830303815290604052907bffffffffffffffffffffffffffffffffffffffffffffffffffffffff19166020820180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff83818316178352505050506040518082805190602001908083835b6020831061330157805182526020820191506020810190506020830392506132de565b6001836020036101000a0380198251168184511680821785525050505050509050019150506000604051808303816000865af19150503d8060008114613363576040519150601f19603f3d011682016040523d82523d6000602084013e613368565b606091505b5091509150816133d6576000815111156133855780518082602001fd5b6040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260328152602001806141456032913960400191505060405180910390fd5b60008180602001905160208110156133ed57600080fd5b8101908080519060200190929190505050905063150b7a0260e01b7bffffffffffffffffffffffffffffffffffffffffffffffffffffffff1916817bffffffffffffffffffffffffffffffffffffffffffffffffffffffff19161493505050505b949350505050565b8273ffffffffffffffffffffffffffffffffffffffff1661347682611500565b73ffffffffffffffffffffffffffffffffffffffff16146134e2576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260298152602001806142d06029913960400191505060405180910390fd5b600073ffffffffffffffffffffffffffffffffffffffff168273ffffffffffffffffffffffffffffffffffffffff161415613568576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252602481526020018061419d6024913960400191505060405180910390fd5b613571816138ea565b6135b8600460008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000206139a8565b6135ff600460008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020613889565b816002600083815260200190815260200160002060006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550808273ffffffffffffffffffffffffffffffffffffffff168473ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60405160405180910390a4505050565b60006137096001600660008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020805490506139cb90919063ffffffff16565b90506000600760008481526020019081526020016000205490508181146137f6576000600660008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020838154811061377657fe5b9060005260206000200154905080600660008773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002083815481106137ce57fe5b9060005260206000200181905550816007600083815260200190815260200160002081905550505b600660008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000208054809190600190036138489190613d6c565b5050505050565b6138598282613a4e565b61386382826136b1565b6000600760008381526020019081526020016000208190555061388581613bdd565b5050565b6001816000016000828254019250508190555050565b60008060007fc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a47060001b9050833f91508082141580156138e157506000801b8214155b92505050919050565b600073ffffffffffffffffffffffffffffffffffffffff166003600083815260200190815260200160002060009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16146139a55760006003600083815260200190815260200160002060006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055505b50565b6139c0600182600001546139cb90919063ffffffff16565b816000018190555050565b600082821115613a43576040517f08c379a000000000000000000000000000000000000000000000000000000000815260040180806020018281038252601e8152602001807f536166654d6174683a207375627472616374696f6e206f766572666c6f77000081525060200191505060405180910390fd5b818303905092915050565b8173ffffffffffffffffffffffffffffffffffffffff16613a6e82611500565b73ffffffffffffffffffffffffffffffffffffffff1614613ada576040517f08c379a00000000000000000000000000000000000000000000000000000000081526004018080602001828103825260258152602001806143a66025913960400191505060405180910390fd5b613ae3816138ea565b613b2a600460008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000206139a8565b60006002600083815260200190815260200160002060006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555080600073ffffffffffffffffffffffffffffffffffffffff168373ffffffffffffffffffffffffffffffffffffffff167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef60405160405180910390a45050565b6000613bf860016008805490506139cb90919063ffffffff16565b9050600060096000848152602001908152602001600020549050600060088381548110613c2157fe5b906000526020600020015490508060088381548110613c3c57fe5b90600052602060002001819055508160096000838152602001908152602001600020819055506008805480919060019003613c779190613d6c565b506000600960008681526020019081526020016000208190555050505050565b61032f80613dbe83390190565b828054600181600116156101000203166002900490600052602060002090601f016020900481019282601f10613ce557805160ff1916838001178555613d13565b82800160010185558215613d13579182015b82811115613d12578251825591602001919060010190613cf7565b5b509050613d209190613d98565b5090565b50805460018160011615610100020316600290046000825580601f10613d4a5750613d69565b601f016020900490600052602060002090810190613d689190613d98565b5b50565b815481835581811115613d9357818360005260206000209182019101613d929190613d98565b5b505050565b613dba91905b80821115613db6576000816000905550600101613d9e565b5090565b9056fe608060405234801561001057600080fd5b50336000806101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff1602179055506102cf806100606000396000f3fe608060405234801561001057600080fd5b506004361061002b5760003560e01c8063a9059cbb14610030575b600080fd5b61007c6004803603604081101561004657600080fd5b81019080803573ffffffffffffffffffffffffffffffffffffffff16906020019092919080359060200190929190505050610096565b604051808215151515815260200191505060405180910390f35b60003373ffffffffffffffffffffffffffffffffffffffff166000809054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16146100f55760009050610294565b60008373ffffffffffffffffffffffffffffffffffffffff166000809054906101000a900473ffffffffffffffffffffffffffffffffffffffff1684604051602401808373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001828152602001925050506040516020818303038152906040527f8b72a2ec000000000000000000000000000000000000000000000000000000007bffffffffffffffffffffffffffffffffffffffffffffffffffffffff19166020820180517bffffffffffffffffffffffffffffffffffffffffffffffffffffffff83818316178352505050506040518082805190602001908083835b602083106102245780518252602082019150602081019050602083039250610201565b6001836020036101000a0380198251168184511680821785525050505050509050019150506000604051808303816000865af19150503d8060008114610286576040519150601f19603f3d011682016040523d82523d6000602084013e61028b565b606091505b50509050809150505b9291505056fea265627a7a7231582090b8a077727bedb1556d2daa84f45f16e8bf4e7cebeed303290b02c49db5df5664736f6c634300050b003250756e6b577261707065723a2063616c6c6572206973206e6f74206f776e6572206e6f7220617070726f766564455243373231456e756d657261626c653a206f776e657220696e646578206f7574206f6620626f756e64734552433732313a207472616e7366657220746f206e6f6e20455243373231526563656976657220696d706c656d656e7465724f776e61626c653a206e6577206f776e657220697320746865207a65726f20616464726573734552433732313a207472616e7366657220746f20746865207a65726f20616464726573734552433732313a206f70657261746f7220717565727920666f72206e6f6e6578697374656e7420746f6b656e4552433732313a20617070726f76652063616c6c6572206973206e6f74206f776e6572206e6f7220617070726f76656420666f7220616c6c4552433732313a2062616c616e636520717565727920666f7220746865207a65726f20616464726573734552433732313a206f776e657220717565727920666f72206e6f6e6578697374656e7420746f6b656e50756e6b577261707065723a2063616c6c6572206861732072656769737465726564207468652070726f78794552433732313a20617070726f76656420717565727920666f72206e6f6e6578697374656e7420746f6b656e4552433732313a207472616e73666572206f6620746f6b656e2074686174206973206e6f74206f776e4552433732314d657461646174613a2055524920717565727920666f72206e6f6e6578697374656e7420746f6b656e4552433732313a20617070726f76616c20746f2063757272656e74206f776e65724552433732313a207472616e736665722063616c6c6572206973206e6f74206f776e6572206e6f7220617070726f766564455243373231456e756d657261626c653a20676c6f62616c20696e646578206f7574206f6620626f756e64734552433732313a206275726e206f6620746f6b656e2074686174206973206e6f74206f776ea265627a7a723158203feef4c2dfaf98bd73752500fb56c0e5ebd5a42510b81c0621ce50fcad3ce44864736f6c634300050b003200000000000000000000000067599afad05ee1fcdc93a177e40644d08ea80854

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

00000000000000000000000067599afad05ee1fcdc93a177e40644d08ea80854

-----Decoded View---------------
Arg [0] : punkContract (address): 0x67599afad05ee1fcdc93a177e40644d08ea80854

-----Encoded View---------------
1 Constructor Arguments found :
Arg [0] : 00000000000000000000000067599afad05ee1fcdc93a177e40644d08ea80854


Deployed ByteCode Sourcemap

54977:2946:0:-;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;54977:2946:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;20648:133;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;20648:133:0;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;49553:83;;;:::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;49553:83:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;25597:241;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;25597:241:0;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;24861:443;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;24861:443:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;40101:96;;;:::i;:::-;;;;;;;;;;;;;;;;;;;27387:364;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;27387:364:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;39639:303;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;39639:303:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;56094:65;;;:::i;:::-;;28413:168;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;28413:168:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;57194:422;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;57194:422:0;;;;;;;;;;;;;;;;;:::i;:::-;;40543:238;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;40543:238:0;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;55776:99;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;55776:99:0;;;;;;;;;;21:11:-1;8;5:28;2:2;;;46:1;43;36:12;2:2;55776:99:0;;35:9:-1;28:4;12:14;8:25;5:40;2:2;;;58:1;55;48:12;2:2;55776:99: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;55776:99: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;;55776:99:0;;;;;;;;;;;;;;;:::i;:::-;;4419:78;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;24163:267;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;24163:267:0;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;52651: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;52651:89:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;23689:248;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;23689:248:0;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;2855:142;;;:::i;:::-;;55955:61;;;:::i;:::-;;2213:79;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;49751:87;;;:::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;49751:87:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;56790:335;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;56790:335:0;;;;;;;;;;;;;;;;;:::i;:::-;;26139:292;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;26139:292:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;56627:103;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;56627:103:0;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;29318:354;;;;;;13:3:-1;8;5:12;2:2;;;30:1;27;20:12;2:2;29318:354:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;21:11:-1;8;5:28;2:2;;;46:1;43;36:12;2:2;29318:354:0;;35:9:-1;28:4;12:14;8:25;5:40;2:2;;;58:1;55;48:12;2:2;29318:354: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;29318:354: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;;29318:354:0;;;;;;;;;;;;;;;:::i;:::-;;50714:798;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;50714:798: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;50714:798:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;56214:355;;;:::i;:::-;;26761:179;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;26761:179:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;3152:277;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;3152:277:0;;;;;;;;;;;;;;;;;;;:::i;:::-;;55603:102;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;20648:133;20716:4;20740:20;:33;20761:11;20740:33;;;;;;;;;;;;;;;;;;;;;;;;;;;20733:40;;20648:133;;;:::o;49553:83::-;49590:13;49623:5;49616:12;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;49553:83;:::o;25597:241::-;25656:7;25698:16;25706:7;25698;:16::i;:::-;25676:110;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;25806:15;:24;25822:7;25806:24;;;;;;;;;;;;;;;;;;;;;25799:31;;25597:241;;;:::o;24861:443::-;24925:13;24941:16;24949:7;24941;:16::i;:::-;24925:32;;24984:5;24978:11;;:2;:11;;;;24970:57;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;25078:5;25062:21;;:12;:10;:12::i;:::-;:21;;;:62;;;;25087:37;25104:5;25111:12;:10;:12::i;:::-;25087:16;:37::i;:::-;25062:62;25040:168;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;25248:2;25221:15;:24;25237:7;25221:24;;;;;;;;;;;;:29;;;;;;;;;;;;;;;;;;25288:7;25284:2;25268:28;;25277:5;25268:28;;;;;;;;;;;;24861:443;;;:::o;40101:96::-;40145:7;40172:10;:17;;;;40165:24;;40101:96;:::o;27387:364::-;27580:41;27599:12;:10;:12::i;:::-;27613:7;27580:18;:41::i;:::-;27558:140;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;27711:32;27725:4;27731:2;27735:7;27711:13;:32::i;:::-;27387:364;;;:::o;39639:303::-;39746:7;39801:16;39811:5;39801:9;:16::i;:::-;39793:5;:24;39771:117;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;39908:12;:19;39921:5;39908:19;;;;;;;;;;;;;;;39928:5;39908:26;;;;;;;;;;;;;;;;39901:33;;39639:303;;;;:::o;56094:65::-;2435:12;:10;:12::i;:::-;2425:22;;:6;;;;;;;;;;;:22;;;2417:67;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;56141:10;:8;:10::i;:::-;56094:65::o;28413:168::-;28534:39;28551:4;28557:2;28561:7;28534:39;;;;;;;;;;;;:16;:39::i;:::-;28413:168;;;:::o;57194:422::-;4737:7;;;;;;;;;;;4736:8;4728:37;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;57259:14;57276:12;:10;:12::i;:::-;57259:29;;57323:37;57342:6;57350:9;57323:18;:37::i;:::-;57301:132;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;57446:16;57452:9;57446:5;:16::i;:::-;57563:13;;;;;;;;;;;:26;;;57590:6;57598:9;57563:45;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;57563:45:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;57563:45:0;;;;4776:1;57194:422;:::o;40543:238::-;40601:7;40651:13;:11;:13::i;:::-;40643:5;:21;40621:115;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;40756:10;40767:5;40756:17;;;;;;;;;;;;;;;;40749:24;;40543:238;;;:::o;55776:99::-;2435:12;:10;:12::i;:::-;2425:22;;:6;;;;;;;;;;;:22;;;2417:67;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;55847:20;55859:7;55847:11;:20::i;:::-;55776:99;:::o;4419:78::-;4458:4;4482:7;;;;;;;;;;;4475:14;;4419:78;:::o;24163:267::-;24218:7;24238:13;24254:11;:20;24266:7;24254:20;;;;;;;;;;;;;;;;;;;;;24238:36;;24326:1;24309:19;;:5;:19;;;;24287:110;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;24417:5;24410:12;;;24163:267;;;:::o;52651:89::-;52691:13;52724:8;52717:15;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;52651:89;:::o;23689:248::-;23744:7;23803:1;23786:19;;:5;:19;;;;23764:111;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;23895:34;:17;:24;23913:5;23895:24;;;;;;;;;;;;;;;:32;:34::i;:::-;23888:41;;23689:248;;;:::o;2855:142::-;2435:12;:10;:12::i;:::-;2425:22;;:6;;;;;;;;;;;:22;;;2417:67;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;2954:1;2917:40;;2938:6;;;;;;;;;;;2917:40;;;;;;;;;;;;2987:1;2970:6;;:19;;;;;;;;;;;;;;;;;;2855:142::o;55955:61::-;2435:12;:10;:12::i;:::-;2425:22;;:6;;;;;;;;;;;:22;;;2417:67;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;56000:8;:6;:8::i;:::-;55955:61::o;2213:79::-;2251:7;2278:6;;;;;;;;;;;2271:13;;2213:79;:::o;49751:87::-;49790:13;49823:7;49816:14;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;49751:87;:::o;56790:335::-;4737:7;;;;;;;;;;;4736:8;4728:37;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;56855:14;56872:12;:10;:12::i;:::-;56855:29;;56897:15;56925:8;:16;56934:6;56925:16;;;;;;;;;;;;;;;;;;;;;;;;;56897:45;;56977:5;:14;;;57000:13;;;;;;;;;;;57016:9;56977:49;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8:9:-1;5:2;;;30:1;27;20:12;5:2;56977:49:0;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;56977:49:0;;;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;56977:49:0;;;;;;;;;;;;;;;;56955:125;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;57093:24;57099:6;57107:9;57093:5;:24::i;:::-;4776:1;;56790:335;:::o;26139:292::-;26211:17;26231:12;:10;:12::i;:::-;26211:32;;26270:9;26264:15;;:2;:15;;;;26256:53;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;26358:8;26322:18;:29;26341:9;26322:29;;;;;;;;;;;;;;;:33;26352:2;26322:33;;;;;;;;;;;;;;;;:44;;;;;;;;;;;;;;;;;;26410:2;26384:39;;26399:9;26384:39;;;26414:8;26384:39;;;;;;;;;;;;;;;;;;;;;;26139:292;;;:::o;56627:103::-;56681:7;56708:8;:14;56717:4;56708:14;;;;;;;;;;;;;;;;;;;;;;;;;56701:21;;56627:103;;;:::o;29318:354::-;29490:41;29509:12;:10;:12::i;:::-;29523:7;29490:18;:41::i;:::-;29468:140;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;29621:43;29639:4;29645:2;29649:7;29658:5;29621:17;:43::i;:::-;29318:354;;;;:::o;50714:798::-;50770:13;50818:16;50826:7;50818;:16::i;:::-;50796:113;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;50922:23;50948:10;:19;50959:7;50948:19;;;;;;;;;;;50922:45;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;51069:1;51049:8;51043:22;;;;;;;;;;;;;;;;:27;51039:76;;;51094:9;51087:16;;;;;51039:76;51247:1;51227:9;51221:23;:27;51217:112;;;51296:8;51306:9;51279:37;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;36:153:-1;66:2;61:3;58:11;36:153;;182:3;176:10;171:3;164:23;98:2;93:3;89:12;82:19;;123:2;118:3;114:12;107:19;;148:2;143:3;139:12;132:19;;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;;;51279:37:0;;;;;;;;;;;;49:4:-1;39:7;30;26:21;22:32;13:7;6:49;51279:37:0;;;51265:52;;;;;51217:112;51463:8;51473:21;:7;:19;:21::i;:::-;51446:57;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;36:153:-1;66:2;61:3;58:11;36:153;;182:3;176:10;171:3;164:23;98:2;93:3;89:12;82:19;;123:2;118:3;114:12;107:19;;148:2;143:3;139:12;132:19;;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;;;51446:57:0;;;;;;;;;;;;;;;;;;;49:4:-1;39:7;30;26:21;22:32;13:7;6:49;51446:57:0;;;51432:72;;;50714:798;;;;:::o;56214:355::-;56257:14;56274:12;:10;:12::i;:::-;56257:29;;56349:1;56321:30;;:8;:16;56330:6;56321:16;;;;;;;;;;;;;;;;;;;;;;;;;:30;;;56299:124;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;56436:13;56460:15;;;;;:::i;:::-;;;;;;;;;;;8:9:-1;5:2;;;45:16;42:1;39;24:38;77:16;74:1;67:27;5:2;56460:15:0;56436:40;;56508:5;56489:8;:16;56498:6;56489:16;;;;;;;;;;;;;;;;:24;;;;;;;;;;;;;;;;;;56531:30;56547:6;56555:5;56531:30;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;56214:355;;:::o;26761:179::-;26868:4;26897:18;:25;26916:5;26897:25;;;;;;;;;;;;;;;:35;26923:8;26897:35;;;;;;;;;;;;;;;;;;;;;;;;;26890:42;;26761:179;;;;:::o;3152:277::-;2435:12;:10;:12::i;:::-;2425:22;;:6;;;;;;;;;;;:22;;;2417:67;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;3267:1;3247:22;;:8;:22;;;;3225:110;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;3382:8;3353:38;;3374:6;;;;;;;;;;;3353:38;;;;;;;;;;;;3413:8;3404:6;;:17;;;;;;;;;;;;;;;;;;3152:277;:::o;55603:102::-;55648:7;55683:13;;;;;;;;;;;55668:29;;55603:102;:::o;30947:123::-;31004:4;31060:1;31028:34;;:11;:20;31040:7;31028:20;;;;;;;;;;;;;;;;;;;;;:34;;;;31021:41;;30947:123;;;:::o;839:98::-;884:15;919:10;912:17;;839:98;:::o;31440:432::-;31552:4;31596:16;31604:7;31596;:16::i;:::-;31574:110;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;31697:13;31713:16;31721:7;31713;:16::i;:::-;31697:32;;31761:5;31750:16;;:7;:16;;;:64;;;;31807:7;31783:31;;:20;31795:7;31783:11;:20::i;:::-;:31;;;31750:64;:113;;;;31831:32;31848:5;31855:7;31831:16;:32::i;:::-;31750:113;31742:122;;;31440:432;;;;:::o;57736:184::-;4737:7;;;;;;;;;;;4736:8;4728:37;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;57872:40;57892:4;57898:2;57902:9;57872:19;:40::i;:::-;57736:184;;;:::o;5462:114::-;5013:7;;;;;;;;;;;5005:40;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;5523:5;5513:7;;:15;;;;;;;;;;;;;;;;;;5546:22;5555:12;:10;:12::i;:::-;5546:22;;;;;;;;;;;;;;;;;;;;;;5462:114::o;34867:92::-;34919:32;34925:16;34933:7;34925;:16::i;:::-;34943:7;34919:5;:32::i;:::-;34867:92;:::o;52314:90::-;52389:7;52378:8;:18;;;;;;;;;;;;:::i;:::-;;52314:90;:::o;10918:114::-;10983:7;11010;:14;;;11003:21;;10918:114;;;:::o;5209:112::-;4737:7;;;;;;;;;;;4736:8;4728:37;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;5271:4;5261:7;;:14;;;;;;;;;;;;;;;;;;5293:20;5300:12;:10;:12::i;:::-;5293:20;;;;;;;;;;;;;;;;;;;;;;5209:112::o;41709:202::-;41773:24;41785:2;41789:7;41773:11;:24::i;:::-;41810:40;41838:2;41842:7;41810:27;:40::i;:::-;41863;41895:7;41863:31;:40::i;:::-;41709:202;;:::o;30391:354::-;30544:32;30558:4;30564:2;30568:7;30544:13;:32::i;:::-;30611:48;30634:4;30640:2;30644:7;30653:5;30611:22;:48::i;:::-;30589:148;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;30391:354;;;;:::o;47267:572::-;47326:13;47365:1;47356:5;:10;47352:53;;;47383:10;;;;;;;;;;;;;;;;;;;;;47352:53;47417:12;47432:5;47417:20;;47448:14;47475:78;47490:1;47482:4;:9;47475:78;;47508:8;;;;;;;47539:2;47531:10;;;;;;;;;47475:78;;;47565:19;47597:6;47587:17;;;;;;;;;;;;;;;;;;;;;;;;;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;47587:17:0;;;;47565:39;;47615:13;47640:1;47631:6;:10;47615:26;;47661:5;47654:12;;47679:119;47694:1;47686:4;:9;47679:119;;47756:2;47749:4;:9;;;;;;47743:2;:16;47730:31;;47712:6;47719:7;;;;;;;47712:15;;;;;;;;;;;:49;;;;;;;;;;;47784:2;47776:10;;;;;;;;;47679:119;;;47824:6;47810:21;;;;;;47267:572;;;;:::o;41165:279::-;41285:38;41305:4;41311:2;41315:7;41285:19;:38::i;:::-;41336:47;41369:4;41375:7;41336:32;:47::i;:::-;41396:40;41424:2;41428:7;41396:27;:40::i;:::-;41165:279;;;:::o;53042:248::-;53109:27;53121:5;53128:7;53109:11;:27::i;:::-;53227:1;53196:10;:19;53207:7;53196:19;;;;;;;;;;;53190:33;;;;;;;;;;;;;;;;:38;53186:97;;53252:10;:19;53263:7;53252:19;;;;;;;;;;;;53245:26;;;;:::i;:::-;53186:97;53042:248;;:::o;33697:335::-;33783:1;33769:16;;:2;:16;;;;33761:61;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;33842:16;33850:7;33842;:16::i;:::-;33841:17;33833:58;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;33927:2;33904:11;:20;33916:7;33904:20;;;;;;;;;;;;:25;;;;;;;;;;;;;;;;;;33940:33;:17;:21;33958:2;33940:21;;;;;;;;;;;;;;;:31;:33::i;:::-;34016:7;34012:2;33991:33;;34008:1;33991:33;;;;;;;;;;;;33697:335;;:::o;43240:186::-;43354:12;:16;43367:2;43354:16;;;;;;;;;;;;;;;:23;;;;43325:17;:26;43343:7;43325:26;;;;;;;;;;;:52;;;;43388:12;:16;43401:2;43388:16;;;;;;;;;;;;;;;43410:7;43388:30;;39:1:-1;33:3;27:10;23:18;57:10;52:3;45:23;79:10;72:17;;0:93;43388:30:0;;;;;;;;;;;;;;;;;;;;;;43240:186;;:::o;43627:164::-;43731:10;:17;;;;43704:15;:24;43720:7;43704:24;;;;;;;;;;;:44;;;;43759:10;43775:7;43759:24;;39:1:-1;33:3;27:10;23:18;57:10;52:3;45:23;79:10;72:17;;0:93;43759:24:0;;;;;;;;;;;;;;;;;;;;;;43627:164;:::o;36527:1160::-;36683:4;36705:15;:2;:13;;;:15::i;:::-;36700:60;;36744:4;36737:11;;;;36700:60;36833:12;36847:23;36874:2;:7;;36953:2;36937:36;;;:45;;;;37001:12;:10;:12::i;:::-;37032:4;37055:7;37081:5;36896:205;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;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;36896:205:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;49:4:-1;39:7;30;26:21;22:32;13:7;6:49;36896:205:0;;;;;;;38:4:-1;29:7;25:18;67:10;61:17;96:58;199:8;192:4;186;182:15;179:29;167:10;160:49;0:215;;;36896:205:0;36874:238;;;;;;;;;;;;;36:153:-1;66:2;61:3;58:11;36:153;;182:3;176:10;171:3;164:23;98:2;93:3;89:12;82:19;;123:2;118:3;114:12;107:19;;148:2;143:3;139:12;132:19;;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;;;36874:238:0;;;;;;;;;;;;;;;;;;;;;;;;14:1:-1;21;16:31;;;;75:4;69:11;64:16;;144:4;140:9;133:4;115:16;111:27;107:43;104:1;100:51;94:4;87:65;169:16;166:1;159:27;225:16;222:1;215:4;212:1;208:12;193:49;7:242;;16:31;36:4;31:9;;7:242;;36832:280:0;;;;37130:7;37125:555;;37178:1;37158:10;:17;:21;37154:384;;;37326:10;37320:17;37387:15;37374:10;37370:2;37366:19;37359:44;37274:148;37462:60;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;37125:555;37570:13;37597:10;37586:32;;;;;13:2:-1;8:3;5:11;2:2;;;29:1;26;19:12;2:2;37586:32:0;;;;;;;;;;;;;;;;37570:48;;21896:10;37651:16;;37641:26;;;:6;:26;;;;37633:35;;;;;36527:1160;;;;;;;:::o;35345:530::-;35507:4;35487:24;;:16;35495:7;35487;:16::i;:::-;:24;;;35465:115;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;35613:1;35599:16;;:2;:16;;;;35591:65;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;35669:23;35684:7;35669:14;:23::i;:::-;35705:35;:17;:23;35723:4;35705:23;;;;;;;;;;;;;;;:33;:35::i;:::-;35751:33;:17;:21;35769:2;35751:21;;;;;;;;;;;;;;;:31;:33::i;:::-;35820:2;35797:11;:20;35809:7;35797:20;;;;;;;;;;;;:25;;;;;;;;;;;;;;;;;;35859:7;35855:2;35840:27;;35849:4;35840:27;;;;;;;;;;;;35345:530;;;:::o;44418:1162::-;44698:22;44723:32;44753:1;44723:12;:18;44736:4;44723:18;;;;;;;;;;;;;;;:25;;;;:29;;:32;;;;:::i;:::-;44698:57;;44766:18;44787:17;:26;44805:7;44787:26;;;;;;;;;;;;44766:47;;44934:14;44920:10;:28;44916:328;;44965:19;44987:12;:18;45000:4;44987:18;;;;;;;;;;;;;;;45006:14;44987:34;;;;;;;;;;;;;;;;44965:56;;45071:11;45038:12;:18;45051:4;45038:18;;;;;;;;;;;;;;;45057:10;45038:30;;;;;;;;;;;;;;;:44;;;;45188:10;45155:17;:30;45173:11;45155:30;;;;;;;;;;;:43;;;;44916:328;;45333:12;:18;45346:4;45333:18;;;;;;;;;;;;;;;:27;;;;;;;;;;;;:::i;:::-;;44418:1162;;;;:::o;42195:374::-;42262:27;42274:5;42281:7;42262:11;:27::i;:::-;42302:48;42335:5;42342:7;42302:32;:48::i;:::-;42502:1;42473:17;:26;42491:7;42473:26;;;;;;;;;;;:30;;;;42516:45;42553:7;42516:36;:45::i;:::-;42195:374;;:::o;11040:181::-;11212:1;11194:7;:14;;;:19;;;;;;;;;;;11040:181;:::o;12027:645::-;12087:4;12349:16;12376:19;12398:66;12376:88;;;;12582:7;12570:20;12558:32;;12633:11;12621:8;:23;;:42;;;;;12660:3;12648:15;;:8;:15;;12621:42;12613:51;;;;12027:645;;;:::o;37855:175::-;37955:1;37919:38;;:15;:24;37935:7;37919:24;;;;;;;;;;;;;;;;;;;;;:38;;;37915:108;;38009:1;37974:15;:24;37990:7;37974:24;;;;;;;;;;;;:37;;;;;;;;;;;;;;;;;;37915:108;37855:175;:::o;11229:110::-;11310:21;11329:1;11310:7;:14;;;:18;;:21;;;;:::i;:::-;11293:7;:14;;:38;;;;11229:110;:::o;7765:160::-;7823:7;7856:1;7851;:6;;7843:49;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;7916:1;7912;:5;7905:12;;7765:160;;;;:::o;34309:370::-;34418:5;34398:25;;:16;34406:7;34398;:16::i;:::-;:25;;;34376:112;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;34501:23;34516:7;34501:14;:23::i;:::-;34537:36;:17;:24;34555:5;34537:24;;;;;;;;;;;;;;;:34;:36::i;:::-;34615:1;34584:11;:20;34596:7;34584:20;;;;;;;;;;;;:33;;;;;;;;;;;;;;;;;;34663:7;34659:1;34635:36;;34644:5;34635:36;;;;;;;;;;;;34309:370;;:::o;45875:1082::-;46128:22;46153:24;46175:1;46153:10;:17;;;;:21;;:24;;;;:::i;:::-;46128:49;;46188:18;46209:15;:24;46225:7;46209:24;;;;;;;;;;;;46188:45;;46560:19;46582:10;46593:14;46582:26;;;;;;;;;;;;;;;;46560:48;;46646:11;46621:10;46632;46621:22;;;;;;;;;;;;;;;:36;;;;46757:10;46726:15;:28;46742:11;46726:28;;;;;;;;;;;:41;;;;46891:10;:19;;;;;;;;;;;;:::i;:::-;;46948:1;46921:15;:24;46937:7;46921:24;;;;;;;;;;;:28;;;;45875:1082;;;;:::o;54977:2946::-;;;;;;;;:::o;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;:::o;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;:::o;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;:::o;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;:::o

Swarm Source

bzzr://3feef4c2dfaf98bd73752500fb56c0e5ebd5a42510b81c0621ce50fcad3ce448
Block Transaction Gas Used Reward
Age Block Fee Address BC Fee Address Voting Power Jailed Incoming
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.