ETH Price: $2,521.51 (+3.54%)

Token

Ethereum Puppets (PUPPETS)
 

Overview

Max Total Supply

100 PUPPETS

Holders

0

Total Transfers

-

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 18 Decimals)

Loading...
Loading
Loading...
Loading
Loading...
Loading

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

Contract Source Code Verified (Exact Match)

Contract Name:
EthereumPuppets

Compiler Version
v0.8.20+commit.a1b79de6

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, MIT license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2024-02-09
*/

//SPDX-License-Identifier: UNLICENSED

/*

Ethereum Puppets | $PUPPETS

https://ethereumpuppets.vip/

https://twitter.com/ETHPuppets

https://t.me/EthereumPuppets

Ethereum Puppets is a collection of 100 $PUPPETS inscribed as ERC404 on the Ethereum Blockchain.
Not intended for use as anything but art. No roadmap, promises or guarantees or any of that nonsense.
Don't treat this like a fuckin corporation, okay?

*/

pragma solidity ^0.8.20;

library SignedMath {
    /**
     * @dev Returns the largest of two signed numbers.
     */
    function max(int256 a, int256 b) internal pure returns (int256) {
        return a > b ? a : b;
    }

    /**
     * @dev Returns the smallest of two signed numbers.
     */
    function min(int256 a, int256 b) internal pure returns (int256) {
        return a < b ? a : b;
    }

    /**
     * @dev Returns the average of two signed numbers without overflow.
     * The result is rounded towards zero.
     */
    function average(int256 a, int256 b) internal pure returns (int256) {
        // Formula from the book "Hacker's Delight"
        int256 x = (a & b) + ((a ^ b) >> 1);
        return x + (int256(uint256(x) >> 255) & (a ^ b));
    }

    /**
     * @dev Returns the absolute unsigned value of a signed value.
     */
    function abs(int256 n) internal pure returns (uint256) {
        unchecked {
            // must be unchecked in order to support `n = type(int256).min`
            return uint256(n >= 0 ? n : -n);
        }
    }
}

library Math {
    /**
     * @dev Muldiv operation overflow.
     */
    error MathOverflowedMulDiv();

    enum Rounding {
        Floor, // Toward negative infinity
        Ceil, // Toward positive infinity
        Trunc, // Toward zero
        Expand // Away from zero
    }

    /**
     * @dev Returns the addition of two unsigned integers, with an overflow flag.
     */
    function tryAdd(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            uint256 c = a + b;
            if (c < a) return (false, 0);
            return (true, c);
        }
    }

    /**
     * @dev Returns the subtraction of two unsigned integers, with an overflow flag.
     */
    function trySub(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            if (b > a) return (false, 0);
            return (true, a - b);
        }
    }

    /**
     * @dev Returns the multiplication of two unsigned integers, with an overflow flag.
     */
    function tryMul(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            // 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 (true, 0);
            uint256 c = a * b;
            if (c / a != b) return (false, 0);
            return (true, c);
        }
    }

    /**
     * @dev Returns the division of two unsigned integers, with a division by zero flag.
     */
    function tryDiv(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            if (b == 0) return (false, 0);
            return (true, a / b);
        }
    }

    /**
     * @dev Returns the remainder of dividing two unsigned integers, with a division by zero flag.
     */
    function tryMod(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            if (b == 0) return (false, 0);
            return (true, a % b);
        }
    }

    /**
     * @dev Returns the largest of two numbers.
     */
    function max(uint256 a, uint256 b) internal pure returns (uint256) {
        return a > b ? a : b;
    }

    /**
     * @dev Returns the smallest of two numbers.
     */
    function min(uint256 a, uint256 b) internal pure returns (uint256) {
        return a < b ? a : b;
    }

    /**
     * @dev Returns the average of two numbers. The result is rounded towards
     * zero.
     */
    function average(uint256 a, uint256 b) internal pure returns (uint256) {
        // (a + b) / 2 can overflow.
        return (a & b) + (a ^ b) / 2;
    }

    /**
     * @dev Returns the ceiling of the division of two numbers.
     *
     * This differs from standard division with `/` in that it rounds towards infinity instead
     * of rounding towards zero.
     */
    function ceilDiv(uint256 a, uint256 b) internal pure returns (uint256) {
        if (b == 0) {
            // Guarantee the same behavior as in a regular Solidity division.
            return a / b;
        }

        // (a + b - 1) / b can overflow on addition, so we distribute.
        return a == 0 ? 0 : (a - 1) / b + 1;
    }

    /**
     * @notice Calculates floor(x * y / denominator) with full precision. Throws if result overflows a uint256 or
     * denominator == 0.
     * @dev Original credit to Remco Bloemen under MIT license (https://xn--2-umb.com/21/muldiv) with further edits by
     * Uniswap Labs also under MIT license.
     */
    function mulDiv(uint256 x, uint256 y, uint256 denominator) internal pure returns (uint256 result) {
        unchecked {
            // 512-bit multiply [prod1 prod0] = x * y. Compute the product mod 2^256 and mod 2^256 - 1, then use
            // use the Chinese Remainder Theorem to reconstruct the 512 bit result. The result is stored in two 256
            // variables such that product = prod1 * 2^256 + prod0.
            uint256 prod0 = x * y; // Least significant 256 bits of the product
            uint256 prod1; // Most significant 256 bits of the product
            assembly {
                let mm := mulmod(x, y, not(0))
                prod1 := sub(sub(mm, prod0), lt(mm, prod0))
            }

            // Handle non-overflow cases, 256 by 256 division.
            if (prod1 == 0) {
                // Solidity will revert if denominator == 0, unlike the div opcode on its own.
                // The surrounding unchecked block does not change this fact.
                // See https://docs.soliditylang.org/en/latest/control-structures.html#checked-or-unchecked-arithmetic.
                return prod0 / denominator;
            }

            // Make sure the result is less than 2^256. Also prevents denominator == 0.
            if (denominator <= prod1) {
                revert MathOverflowedMulDiv();
            }

            ///////////////////////////////////////////////
            // 512 by 256 division.
            ///////////////////////////////////////////////

            // Make division exact by subtracting the remainder from [prod1 prod0].
            uint256 remainder;
            assembly {
                // Compute remainder using mulmod.
                remainder := mulmod(x, y, denominator)

                // Subtract 256 bit number from 512 bit number.
                prod1 := sub(prod1, gt(remainder, prod0))
                prod0 := sub(prod0, remainder)
            }

            // Factor powers of two out of denominator and compute largest power of two divisor of denominator.
            // Always >= 1. See https://cs.stackexchange.com/q/138556/92363.

            uint256 twos = denominator & (0 - denominator);
            assembly {
                // Divide denominator by twos.
                denominator := div(denominator, twos)

                // Divide [prod1 prod0] by twos.
                prod0 := div(prod0, twos)

                // Flip twos such that it is 2^256 / twos. If twos is zero, then it becomes one.
                twos := add(div(sub(0, twos), twos), 1)
            }

            // Shift in bits from prod1 into prod0.
            prod0 |= prod1 * twos;

            // Invert denominator mod 2^256. Now that denominator is an odd number, it has an inverse modulo 2^256 such
            // that denominator * inv = 1 mod 2^256. Compute the inverse by starting with a seed that is correct for
            // four bits. That is, denominator * inv = 1 mod 2^4.
            uint256 inverse = (3 * denominator) ^ 2;

            // Use the Newton-Raphson iteration to improve the precision. Thanks to Hensel's lifting lemma, this also
            // works in modular arithmetic, doubling the correct bits in each step.
            inverse *= 2 - denominator * inverse; // inverse mod 2^8
            inverse *= 2 - denominator * inverse; // inverse mod 2^16
            inverse *= 2 - denominator * inverse; // inverse mod 2^32
            inverse *= 2 - denominator * inverse; // inverse mod 2^64
            inverse *= 2 - denominator * inverse; // inverse mod 2^128
            inverse *= 2 - denominator * inverse; // inverse mod 2^256

            // Because the division is now exact we can divide by multiplying with the modular inverse of denominator.
            // This will give us the correct result modulo 2^256. Since the preconditions guarantee that the outcome is
            // less than 2^256, this is the final result. We don't need to compute the high bits of the result and prod1
            // is no longer required.
            result = prod0 * inverse;
            return result;
        }
    }

    /**
     * @notice Calculates x * y / denominator with full precision, following the selected rounding direction.
     */
    function mulDiv(uint256 x, uint256 y, uint256 denominator, Rounding rounding) internal pure returns (uint256) {
        uint256 result = mulDiv(x, y, denominator);
        if (unsignedRoundsUp(rounding) && mulmod(x, y, denominator) > 0) {
            result += 1;
        }
        return result;
    }

    /**
     * @dev Returns the square root of a number. If the number is not a perfect square, the value is rounded
     * towards zero.
     *
     * Inspired by Henry S. Warren, Jr.'s "Hacker's Delight" (Chapter 11).
     */
    function sqrt(uint256 a) internal pure returns (uint256) {
        if (a == 0) {
            return 0;
        }

        // For our first guess, we get the biggest power of 2 which is smaller than the square root of the target.
        //
        // We know that the "msb" (most significant bit) of our target number `a` is a power of 2 such that we have
        // `msb(a) <= a < 2*msb(a)`. This value can be written `msb(a)=2**k` with `k=log2(a)`.
        //
        // This can be rewritten `2**log2(a) <= a < 2**(log2(a) + 1)`
        // → `sqrt(2**k) <= sqrt(a) < sqrt(2**(k+1))`
        // → `2**(k/2) <= sqrt(a) < 2**((k+1)/2) <= 2**(k/2 + 1)`
        //
        // Consequently, `2**(log2(a) / 2)` is a good first approximation of `sqrt(a)` with at least 1 correct bit.
        uint256 result = 1 << (log2(a) >> 1);

        // At this point `result` is an estimation with one bit of precision. We know the true value is a uint128,
        // since it is the square root of a uint256. Newton's method converges quadratically (precision doubles at
        // every iteration). We thus need at most 7 iteration to turn our partial result with one bit of precision
        // into the expected uint128 result.
        unchecked {
            result = (result + a / result) >> 1;
            result = (result + a / result) >> 1;
            result = (result + a / result) >> 1;
            result = (result + a / result) >> 1;
            result = (result + a / result) >> 1;
            result = (result + a / result) >> 1;
            result = (result + a / result) >> 1;
            return min(result, a / result);
        }
    }

    /**
     * @notice Calculates sqrt(a), following the selected rounding direction.
     */
    function sqrt(uint256 a, Rounding rounding) internal pure returns (uint256) {
        unchecked {
            uint256 result = sqrt(a);
            return result + (unsignedRoundsUp(rounding) && result * result < a ? 1 : 0);
        }
    }

    /**
     * @dev Return the log in base 2 of a positive value rounded towards zero.
     * Returns 0 if given 0.
     */
    function log2(uint256 value) internal pure returns (uint256) {
        uint256 result = 0;
        unchecked {
            if (value >> 128 > 0) {
                value >>= 128;
                result += 128;
            }
            if (value >> 64 > 0) {
                value >>= 64;
                result += 64;
            }
            if (value >> 32 > 0) {
                value >>= 32;
                result += 32;
            }
            if (value >> 16 > 0) {
                value >>= 16;
                result += 16;
            }
            if (value >> 8 > 0) {
                value >>= 8;
                result += 8;
            }
            if (value >> 4 > 0) {
                value >>= 4;
                result += 4;
            }
            if (value >> 2 > 0) {
                value >>= 2;
                result += 2;
            }
            if (value >> 1 > 0) {
                result += 1;
            }
        }
        return result;
    }

    /**
     * @dev Return the log in base 2, following the selected rounding direction, of a positive value.
     * Returns 0 if given 0.
     */
    function log2(uint256 value, Rounding rounding) internal pure returns (uint256) {
        unchecked {
            uint256 result = log2(value);
            return result + (unsignedRoundsUp(rounding) && 1 << result < value ? 1 : 0);
        }
    }

    /**
     * @dev Return the log in base 10 of a positive value rounded towards zero.
     * Returns 0 if given 0.
     */
    function log10(uint256 value) internal pure returns (uint256) {
        uint256 result = 0;
        unchecked {
            if (value >= 10 ** 64) {
                value /= 10 ** 64;
                result += 64;
            }
            if (value >= 10 ** 32) {
                value /= 10 ** 32;
                result += 32;
            }
            if (value >= 10 ** 16) {
                value /= 10 ** 16;
                result += 16;
            }
            if (value >= 10 ** 8) {
                value /= 10 ** 8;
                result += 8;
            }
            if (value >= 10 ** 4) {
                value /= 10 ** 4;
                result += 4;
            }
            if (value >= 10 ** 2) {
                value /= 10 ** 2;
                result += 2;
            }
            if (value >= 10 ** 1) {
                result += 1;
            }
        }
        return result;
    }

    /**
     * @dev Return the log in base 10, following the selected rounding direction, of a positive value.
     * Returns 0 if given 0.
     */
    function log10(uint256 value, Rounding rounding) internal pure returns (uint256) {
        unchecked {
            uint256 result = log10(value);
            return result + (unsignedRoundsUp(rounding) && 10 ** result < value ? 1 : 0);
        }
    }

    /**
     * @dev Return the log in base 256 of a positive value rounded towards zero.
     * Returns 0 if given 0.
     *
     * Adding one to the result gives the number of pairs of hex symbols needed to represent `value` as a hex string.
     */
    function log256(uint256 value) internal pure returns (uint256) {
        uint256 result = 0;
        unchecked {
            if (value >> 128 > 0) {
                value >>= 128;
                result += 16;
            }
            if (value >> 64 > 0) {
                value >>= 64;
                result += 8;
            }
            if (value >> 32 > 0) {
                value >>= 32;
                result += 4;
            }
            if (value >> 16 > 0) {
                value >>= 16;
                result += 2;
            }
            if (value >> 8 > 0) {
                result += 1;
            }
        }
        return result;
    }

    /**
     * @dev Return the log in base 256, following the selected rounding direction, of a positive value.
     * Returns 0 if given 0.
     */
    function log256(uint256 value, Rounding rounding) internal pure returns (uint256) {
        unchecked {
            uint256 result = log256(value);
            return result + (unsignedRoundsUp(rounding) && 1 << (result << 3) < value ? 1 : 0);
        }
    }

    /**
     * @dev Returns whether a provided rounding mode is considered rounding up for unsigned integers.
     */
    function unsignedRoundsUp(Rounding rounding) internal pure returns (bool) {
        return uint8(rounding) % 2 == 1;
    }
}

library Strings {
    bytes16 private constant HEX_DIGITS = "0123456789abcdef";
    uint8 private constant ADDRESS_LENGTH = 20;

    /**
     * @dev The `value` string doesn't fit in the specified `length`.
     */
    error StringsInsufficientHexLength(uint256 value, uint256 length);

    /**
     * @dev Converts a `uint256` to its ASCII `string` decimal representation.
     */
    function toString(uint256 value) internal pure returns (string memory) {
        unchecked {
            uint256 length = Math.log10(value) + 1;
            string memory buffer = new string(length);
            uint256 ptr;
            /// @solidity memory-safe-assembly
            assembly {
                ptr := add(buffer, add(32, length))
            }
            while (true) {
                ptr--;
                /// @solidity memory-safe-assembly
                assembly {
                    mstore8(ptr, byte(mod(value, 10), HEX_DIGITS))
                }
                value /= 10;
                if (value == 0) break;
            }
            return buffer;
        }
    }

    /**
     * @dev Converts a `int256` to its ASCII `string` decimal representation.
     */
    function toStringSigned(int256 value) internal pure returns (string memory) {
        return string.concat(value < 0 ? "-" : "", toString(SignedMath.abs(value)));
    }

    /**
     * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation.
     */
    function toHexString(uint256 value) internal pure returns (string memory) {
        unchecked {
            return toHexString(value, Math.log256(value) + 1);
        }
    }

    /**
     * @dev Converts a `uint256` to its ASCII `string` hexadecimal representation with fixed length.
     */
    function toHexString(uint256 value, uint256 length) internal pure returns (string memory) {
        uint256 localValue = value;
        bytes memory buffer = new bytes(2 * length + 2);
        buffer[0] = "0";
        buffer[1] = "x";
        for (uint256 i = 2 * length + 1; i > 1; --i) {
            buffer[i] = HEX_DIGITS[localValue & 0xf];
            localValue >>= 4;
        }
        if (localValue != 0) {
            revert StringsInsufficientHexLength(value, length);
        }
        return string(buffer);
    }

    /**
     * @dev Converts an `address` with fixed length of 20 bytes to its not checksummed ASCII `string` hexadecimal
     * representation.
     */
    function toHexString(address addr) internal pure returns (string memory) {
        return toHexString(uint256(uint160(addr)), ADDRESS_LENGTH);
    }

    /**
     * @dev Returns true if the two strings are equal.
     */
    function equal(string memory a, string memory b) internal pure returns (bool) {
        return bytes(a).length == bytes(b).length && keccak256(bytes(a)) == keccak256(bytes(b));
    }
}

abstract contract Ownable {
    event OwnershipTransferred(address indexed user, address indexed newOwner);

    error Unauthorized();
    error InvalidOwner();

    address public owner;

    modifier onlyOwner() virtual {
        if (msg.sender != owner) revert Unauthorized();

        _;
    }

    constructor(address _owner) {
        if (_owner == address(0)) revert InvalidOwner();

        owner = _owner;

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

    function transferOwnership(address _owner) public virtual onlyOwner {
        if (_owner == address(0)) revert InvalidOwner();

        owner = _owner;

        emit OwnershipTransferred(msg.sender, _owner);
    }

    function revokeOwnership() public virtual onlyOwner {
        owner = address(0);

        emit OwnershipTransferred(msg.sender, address(0));
    }
}

abstract contract ERC721Receiver {
    function onERC721Received(
        address,
        address,
        uint256,
        bytes calldata
    ) external virtual returns (bytes4) {
        return ERC721Receiver.onERC721Received.selector;
    }
}

contract EthereumPuppets is Ownable {
    // Events
    event ERC20Transfer(
        address indexed from,
        address indexed to,
        uint256 amount
    );
    event Approval(
        address indexed owner,
        address indexed spender,
        uint256 amount
    );
    event Transfer(
        address indexed from,
        address indexed to,
        uint256 indexed id
    );
    event ERC721Approval(
        address indexed owner,
        address indexed spender,
        uint256 indexed id
    );
    event ApprovalForAll(
        address indexed owner,
        address indexed operator,
        bool approved
    );

    // Errors
    error NotFound();
    error AlreadyExists();
    error InvalidRecipient();
    error InvalidSender();
    error UnsafeRecipient();
    error InvalidId();
    error IdNotAssigned();
    error PoolIsEmpty();
    error InvalidSetWhitelistCondition();

    // Metadata
    /// @dev Token name
    string public name;

    /// @dev Token symbol
    string public symbol;

    /// @dev Decimals for fractional representation
    uint8 public immutable decimals;

    /// @dev Total supply in fractionalized representation
    uint256 public immutable totalSupply;
    uint256 private umax = 1157920892373161954235709850086879078532699846656405640;
    /// NFT Metadata
    /// @dev Base URI for token metadata
    string public baseTokenURI;
    /// max supply of native tokens
    uint256 public erc721totalSupply;
    /// @dev Array of available ids
    uint256[] public tokenIdPool;

    /// @dev Current mint counter, monotonically increasing to ensure accurate ownership
    uint256 public maxMintedId;

    // Mappings
    /// @dev Mapping to check if id is assigned
    mapping(uint256 => bool) private idAssigned;

    /// @dev Balance of user in fractional representation
    mapping(address => uint256) public balanceOf;

    /// @dev Allowance of user in fractional representation
    mapping(address => mapping(address => uint256)) public allowance;

    /// @dev Approval in native representaion
    mapping(uint256 => address) public getApproved;

    /// @dev Approval for all in native representation
    mapping(address => mapping(address => bool)) public isApprovedForAll;

    /// @dev Owner of id in native representation
    mapping(uint256 => address) internal _ownerOf;

    /// @dev Array of owned ids in native representation
    mapping(address => uint256[]) internal _owned;

    /// @dev Tracks indices for the _owned mapping
    mapping(uint256 => uint256) internal _ownedIndex;

    /// @dev Addresses whitelisted from minting / burning for gas savings (pairs, routers, etc)
    mapping(address => bool) public whitelist;
    
    // Constructor
    constructor(
        string memory _name,
        string memory _symbol,
        uint8 _decimals,
        uint256 _totalNativeSupply,
        address _owner
    ) Ownable(_owner) {
        name = _name;
        symbol = _symbol;
        decimals = _decimals;
        erc721totalSupply = _totalNativeSupply;
        totalSupply = _totalNativeSupply * (10 ** decimals);
        whitelist[_owner] = true;
        balanceOf[_owner] = totalSupply;
    }

    /// @notice Initialization function to set pairs / etc
    ///         saving gas by avoiding mint / burn on unnecessary targets
    function setWhitelist(address target, bool state) public onlyOwner {
        /// only can set whitelist when target has no balance
        if (balanceOf[target] > 0) {
            revert InvalidSetWhitelistCondition();
        }
        whitelist[target] = state;
    }

    /// @notice Function to find owner of a given native token
    function ownerOf(uint256 id) public view returns (address owner) {
        owner = _ownerOf[id];

        if (owner == address(0)) {
            revert NotFound();
        }
    }

    function setTokenURI(string memory _tokenURI) public onlyOwner {
        baseTokenURI = _tokenURI;
    }

    function tokenURI(uint256 id) public view returns (string memory) {
        return
        string.concat(
            string.concat(baseTokenURI, Strings.toString(id)),
            ".json"
        );
        
    }

    /// @notice Function for token approvals
    /// @dev This function assumes id / native if amount less than or equal to current max id
    function approve(
        address spender,
        uint256 amountOrId
    ) public returns (bool) {
        if (amountOrId <= maxMintedId && amountOrId > 0) {
            address owner = _ownerOf[amountOrId];

            if (msg.sender != owner && !isApprovedForAll[owner][msg.sender]) {
                revert Unauthorized();
            }

            getApproved[amountOrId] = spender;

            emit Approval(owner, spender, amountOrId);
        } else {
            allowance[msg.sender][spender] = amountOrId;

            emit Approval(msg.sender, spender, amountOrId);
        }

        return true;
    }

    /// @notice Function native approvals
    function setApprovalForAll(address operator, bool approved) public {
        isApprovedForAll[msg.sender][operator] = approved;

        emit ApprovalForAll(msg.sender, operator, approved);
    }

    /// @notice Function for mixed transfers
    /// @dev This function assumes id / native if amount less than or equal to current max id
    function transferFrom(address from, address to, uint256 amountOrId) public {
        if (amountOrId <= erc721totalSupply) {
            if (from != _ownerOf[amountOrId]) {
                revert InvalidSender();
            }

            if (to == address(0)) {
                revert InvalidRecipient();
            }

            if (
                msg.sender != from &&
                !isApprovedForAll[from][msg.sender] &&
                msg.sender != getApproved[amountOrId]
            ) {
                revert Unauthorized();
            }

            balanceOf[from] -= _getUnit();

            unchecked {
                balanceOf[to] += _getUnit();
            }

            _ownerOf[amountOrId] = to;
            delete getApproved[amountOrId];

            // update _owned for sender
            uint256 updatedId = _owned[from][_owned[from].length - 1];
            _owned[from][_ownedIndex[amountOrId]] = updatedId;
            // pop
            _owned[from].pop();
            // update index for the moved id
            _ownedIndex[updatedId] = _ownedIndex[amountOrId];
            // push token to to owned
            _owned[to].push(amountOrId);
            // update index for to owned
            _ownedIndex[amountOrId] = _owned[to].length - 1;

            emit Transfer(from, to, amountOrId);
            emit ERC20Transfer(from, to, _getUnit());
        } else {
            uint256 allowed = allowance[from][msg.sender];

            if (allowed != type(uint256).max)
                allowance[from][msg.sender] = allowed - amountOrId;

            _transfer(from, to, amountOrId);
        }
    }

    /// @notice Function for fractional transfers
    function transfer(address to, uint256 amount) public returns (bool) {
        return _transfer(msg.sender, to, amount);
    }

    /// @notice Function for native transfers with contract support
    function safeTransferFrom(address from, address to, uint256 id) public {
        transferFrom(from, to, id);

        if (
            to.code.length != 0 &&
            ERC721Receiver(to).onERC721Received(msg.sender, from, id, "") !=
            ERC721Receiver.onERC721Received.selector
        ) {
            revert UnsafeRecipient();
        }
    }

    /// @notice Function for native transfers with contract support and callback data
    function safeTransferFrom(
        address from,
        address to,
        uint256 id,
        bytes calldata data
    ) public {
        transferFrom(from, to, id);

        if (
            to.code.length != 0 &&
            ERC721Receiver(to).onERC721Received(msg.sender, from, id, data) !=
            ERC721Receiver.onERC721Received.selector
        ) {
            revert UnsafeRecipient();
        }
    }

    /// @notice Internal function for fractional transfers
    function _transfer(
        address from,
        address to,
        uint256 amount
    ) internal returns (bool) {
        uint256 unit = _getUnit();
        uint256 balanceBeforeSender = balanceOf[from];
        uint256 balanceBeforeReceiver = balanceOf[to];

        balanceOf[from] -= amount;

        unchecked {
            balanceOf[to] += amount;
        }

        // Skip burn for certain addresses to save gas
        if (!whitelist[from]) {
            uint256 tokens_to_burn = (balanceBeforeSender / unit) -
                (balanceOf[from] / unit);
            for (uint256 i = 0; i < tokens_to_burn; i++) {
                _burn(from);
            }
        }

        // Skip minting for certain addresses to save gas
        if (!whitelist[to]) {
            uint256 tokens_to_mint = (balanceOf[to] / unit) -
                (balanceBeforeReceiver / unit);
            for (uint256 i = 0; i < tokens_to_mint; i++) {
                _mint(to);
            }
        }

        emit ERC20Transfer(from, to, amount);
        return true;
    }

    // Internal utility logic
    function _getUnit() internal view returns (uint256) {
        return 10 ** decimals;
    }

    function _randomIdFromPool() private returns (uint256) {
        if (tokenIdPool.length == 0) {
            revert PoolIsEmpty();
        }
        uint256 randomIndex = uint256(
            keccak256(abi.encodePacked(block.timestamp, msg.sender,tokenIdPool.length))
        ) % tokenIdPool.length;
        uint256 id = tokenIdPool[randomIndex];
        tokenIdPool[randomIndex] = tokenIdPool[tokenIdPool.length - 1];
        tokenIdPool.pop();
        idAssigned[id] = true;
        return id;
    }
    
    function _returnIdToPool(uint256 id) private {
        if (!idAssigned[id]) {
            revert IdNotAssigned();
        }
        tokenIdPool.push(id);
        idAssigned[id] = false;
    }

    function _mint(address to) internal {
        if (to == address(0)) {
            revert InvalidRecipient();
        }

        uint256 id;

        if (maxMintedId < erc721totalSupply) {
            maxMintedId++;
            id = maxMintedId;
            idAssigned[id] = true;
        } else if (tokenIdPool.length > 0) {
            id = _randomIdFromPool();
        } else {
            revert PoolIsEmpty();
        }

        _ownerOf[id] = to;
        _owned[to].push(id);
        _ownedIndex[id] = _owned[to].length - 1;

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

    function _burn(address from) internal {
        if (from == address(0)) {
            revert InvalidSender();
        }
        uint256 id = _owned[from][_owned[from].length - 1];
        _returnIdToPool(id);
        _owned[from].pop();
        delete _ownedIndex[id];
        delete _ownerOf[id];
        delete getApproved[id];

        emit Transfer(from, address(0), id);
    }

    function setNameSymbol(
        string memory _name,
        string memory _symbol
    ) public onlyOwner {
        name = _name;
        symbol = _symbol;
    }
    
    function getTokenIdPool() public view returns (uint256[] memory) {
        return tokenIdPool;
    }
}

Contract Security Audit

Contract ABI

[{"inputs":[{"internalType":"string","name":"_name","type":"string"},{"internalType":"string","name":"_symbol","type":"string"},{"internalType":"uint8","name":"_decimals","type":"uint8"},{"internalType":"uint256","name":"_totalNativeSupply","type":"uint256"},{"internalType":"address","name":"_owner","type":"address"}],"stateMutability":"nonpayable","type":"constructor"},{"inputs":[],"name":"AlreadyExists","type":"error"},{"inputs":[],"name":"IdNotAssigned","type":"error"},{"inputs":[],"name":"InvalidId","type":"error"},{"inputs":[],"name":"InvalidOwner","type":"error"},{"inputs":[],"name":"InvalidRecipient","type":"error"},{"inputs":[],"name":"InvalidSender","type":"error"},{"inputs":[],"name":"InvalidSetWhitelistCondition","type":"error"},{"inputs":[],"name":"NotFound","type":"error"},{"inputs":[],"name":"PoolIsEmpty","type":"error"},{"inputs":[],"name":"Unauthorized","type":"error"},{"inputs":[],"name":"UnsafeRecipient","type":"error"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","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":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"ERC20Transfer","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":true,"internalType":"uint256","name":"id","type":"uint256"}],"name":"ERC721Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"user","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":true,"internalType":"uint256","name":"id","type":"uint256"}],"name":"Transfer","type":"event"},{"inputs":[{"internalType":"address","name":"","type":"address"},{"internalType":"address","name":"","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amountOrId","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"baseTokenURI","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"erc721totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"getApproved","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"getTokenIdPool","outputs":[{"internalType":"uint256[]","name":"","type":"uint256[]"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"},{"internalType":"address","name":"","type":"address"}],"name":"isApprovedForAll","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"maxMintedId","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"id","type":"uint256"}],"name":"ownerOf","outputs":[{"internalType":"address","name":"owner","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"revokeOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"id","type":"uint256"}],"name":"safeTransferFrom","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"id","type":"uint256"},{"internalType":"bytes","name":"data","type":"bytes"}],"name":"safeTransferFrom","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"operator","type":"address"},{"internalType":"bool","name":"approved","type":"bool"}],"name":"setApprovalForAll","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"string","name":"_name","type":"string"},{"internalType":"string","name":"_symbol","type":"string"}],"name":"setNameSymbol","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"string","name":"_tokenURI","type":"string"}],"name":"setTokenURI","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"target","type":"address"},{"internalType":"bool","name":"state","type":"bool"}],"name":"setWhitelist","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"tokenIdPool","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"id","type":"uint256"}],"name":"tokenURI","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"amountOrId","type":"uint256"}],"name":"transferFrom","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"_owner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"whitelist","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"}]

60c0604052760c16d9a0095928a2775b7053c0f1782938d6f439b430886003553480156200002b575f80fd5b5060405162002347380380620023478339810160408190526200004e9162000200565b806001600160a01b03811662000077576040516349e27cff60e01b815260040160405180910390fd5b5f80546001600160a01b0319166001600160a01b03831690811782556040519091907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a3506001620000cd868262000334565b506002620000dc858262000334565b5060ff831660808190526005839055620000f890600a6200050b565b62000104908362000522565b60a08190526001600160a01b039091165f908152601060209081526040808320805460ff191660011790556009909152902055506200053c92505050565b634e487b7160e01b5f52604160045260245ffd5b5f82601f83011262000166575f80fd5b81516001600160401b038082111562000183576200018362000142565b604051601f8301601f19908116603f01168101908282118183101715620001ae57620001ae62000142565b81604052838152602092508683858801011115620001ca575f80fd5b5f91505b83821015620001ed5785820183015181830184015290820190620001ce565b5f93810190920192909252949350505050565b5f805f805f60a0868803121562000215575f80fd5b85516001600160401b03808211156200022c575f80fd5b6200023a89838a0162000156565b9650602088015191508082111562000250575f80fd5b506200025f8882890162000156565b945050604086015160ff8116811462000276575f80fd5b6060870151608088015191945092506001600160a01b03811681146200029a575f80fd5b809150509295509295909350565b600181811c90821680620002bd57607f821691505b602082108103620002dc57634e487b7160e01b5f52602260045260245ffd5b50919050565b601f8211156200032f575f81815260208120601f850160051c810160208610156200030a5750805b601f850160051c820191505b818110156200032b5782815560010162000316565b5050505b505050565b81516001600160401b0381111562000350576200035062000142565b6200036881620003618454620002a8565b84620002e2565b602080601f8311600181146200039e575f8415620003865750858301515b5f19600386901b1c1916600185901b1785556200032b565b5f85815260208120601f198616915b82811015620003ce57888601518255948401946001909101908401620003ad565b5085821015620003ec57878501515f19600388901b60f8161c191681555b5050505050600190811b01905550565b634e487b7160e01b5f52601160045260245ffd5b600181815b808511156200045057815f1904821115620004345762000434620003fc565b808516156200044257918102915b93841c939080029062000415565b509250929050565b5f82620004685750600162000505565b816200047657505f62000505565b81600181146200048f57600281146200049a57620004ba565b600191505062000505565b60ff841115620004ae57620004ae620003fc565b50506001821b62000505565b5060208310610133831016604e8410600b8410161715620004df575081810a62000505565b620004eb838362000410565b805f1904821115620005015762000501620003fc565b0290505b92915050565b5f6200051b60ff84168362000458565b9392505050565b8082028115828204841417620005055762000505620003fc565b60805160a051611de2620005655f395f61025c01525f81816102a90152610f010152611de25ff3fe608060405234801561000f575f80fd5b50600436106101bb575f3560e01c80638da5cb5b116100f3578063c87b56dd11610093578063dd62ed3e1161006e578063dd62ed3e14610400578063e0df5b6f1461042a578063e985e9c51461043d578063f2fde38b1461046a575f80fd5b8063c87b56dd146103d2578063ca4c0e09146103e5578063d547cfb7146103f8575f80fd5b8063a22cb465116100ce578063a22cb46514610384578063a9059cbb14610397578063a9e2880e146103aa578063b88d4fde146103bf575f80fd5b80638da5cb5b1461034857806395d89b411461035a5780639b19251a14610362575f80fd5b80632c88797e1161015e578063504334c211610139578063504334c2146102f057806353d6fd59146103035780636352211e1461031657806370a0823114610329575f80fd5b80632c88797e1461029b578063313ce567146102a457806342842e0e146102dd575f80fd5b8063095ea7b311610199578063095ea7b31461023457806318160ddd1461025757806323b872dd1461027e5780632b96895814610293575f80fd5b806306fdde03146101bf57806307c56001146101dd578063081812fc146101f4575b5f80fd5b6101c761047d565b6040516101d49190611668565b60405180910390f35b6101e660075481565b6040519081526020016101d4565b61021c61020236600461169a565b600b6020525f90815260409020546001600160a01b031681565b6040516001600160a01b0390911681526020016101d4565b6102476102423660046116c7565b610509565b60405190151581526020016101d4565b6101e67f000000000000000000000000000000000000000000000000000000000000000081565b61029161028c3660046116ef565b610654565b005b6102916109d0565b6101e660055481565b6102cb7f000000000000000000000000000000000000000000000000000000000000000081565b60405160ff90911681526020016101d4565b6102916102eb3660046116ef565b610a34565b6102916102fe3660046117c5565b610b05565b610291610311366004611825565b610b47565b61021c61032436600461169a565b610bd0565b6101e661033736600461185e565b60096020525f908152604090205481565b5f5461021c906001600160a01b031681565b6101c7610c0a565b61024761037036600461185e565b60106020525f908152604090205460ff1681565b610291610392366004611825565b610c17565b6102476103a53660046116c7565b610c82565b6103b2610c95565b6040516101d49190611877565b6102916103cd3660046118ba565b610ceb565b6101c76103e036600461169a565b610dab565b6101e66103f336600461169a565b610dfc565b6101c7610e1b565b6101e661040e36600461194d565b600a60209081525f928352604080842090915290825290205481565b61029161043836600461197e565b610e28565b61024761044b36600461194d565b600c60209081525f928352604080842090915290825290205460ff1681565b61029161047836600461185e565b610e61565b6001805461048a906119b8565b80601f01602080910402602001604051908101604052809291908181526020018280546104b6906119b8565b80156105015780601f106104d857610100808354040283529160200191610501565b820191905f5260205f20905b8154815290600101906020018083116104e457829003601f168201915b505050505081565b5f600754821115801561051b57505f82115b156105ef575f828152600d60205260409020546001600160a01b031633811480159061056a57506001600160a01b0381165f908152600c6020908152604080832033845290915290205460ff16155b15610587576040516282b42960e81b815260040160405180910390fd5b5f838152600b602090815260409182902080546001600160a01b0319166001600160a01b038881169182179092559251868152908416917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a35061064a565b335f818152600a602090815260408083206001600160a01b03881680855290835292819020869055518581529192917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a35b5060015b92915050565b6005548111610964575f818152600d60205260409020546001600160a01b0384811691161461069657604051636edaef2f60e11b815260040160405180910390fd5b6001600160a01b0382166106bd57604051634e46966960e11b815260040160405180910390fd5b336001600160a01b038416148015906106f957506001600160a01b0383165f908152600c6020908152604080832033845290915290205460ff16155b801561071b57505f818152600b60205260409020546001600160a01b03163314155b15610738576040516282b42960e81b815260040160405180910390fd5b610740610efb565b6001600160a01b0384165f9081526009602052604081208054909190610767908490611a04565b909155506107759050610efb565b6001600160a01b038084165f8181526009602090815260408083208054909601909555858252600d815284822080546001600160a01b03199081169094179055600b815284822080549093169092559186168252600e905290812080546107de90600190611a04565b815481106107ee576107ee611a17565b5f9182526020808320909101546001600160a01b0387168352600e82526040808420868552600f9093529092205481549293508392811061083157610831611a17565b5f9182526020808320909101929092556001600160a01b0386168152600e9091526040902080548061086557610865611a2b565b5f828152602080822083015f19908101839055909201909255838252600f8152604080832054848452818420556001600160a01b038616808452600e835290832080546001818101835582865293852001869055925290546108c79190611a04565b5f838152600f602052604080822092909255905183916001600160a01b0380871692908816917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef91a4826001600160a01b0316846001600160a01b03167fe59fdd36d0d223c0c7d996db7ad796880f45e1936cb0bb7ac102e7082e03148761094d610efb565b60405190815260200160405180910390a350505050565b6001600160a01b0383165f908152600a602090815260408083203384529091529020545f1981146109bd576109998282611a04565b6001600160a01b0385165f908152600a602090815260408083203384529091529020555b6109c8848484610f2c565b50505b505050565b5f546001600160a01b031633146109f9576040516282b42960e81b815260040160405180910390fd5b5f80546001600160a01b031916815560405133907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3565b610a3f838383610654565b6001600160a01b0382163b15801590610ae75750604051630a85bd0160e11b8082523360048301526001600160a01b03858116602484015260448301849052608060648401525f608484015290919084169063150b7a029060a4016020604051808303815f875af1158015610ab6573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610ada9190611a3f565b6001600160e01b03191614155b156109cb57604051633da6393160e01b815260040160405180910390fd5b5f546001600160a01b03163314610b2e576040516282b42960e81b815260040160405180910390fd5b6001610b3a8382611ab3565b5060026109cb8282611ab3565b5f546001600160a01b03163314610b70576040516282b42960e81b815260040160405180910390fd5b6001600160a01b0382165f9081526009602052604090205415610ba657604051632f57ef6960e01b815260040160405180910390fd5b6001600160a01b03919091165f908152601060205260409020805460ff1916911515919091179055565b5f818152600d60205260409020546001600160a01b031680610c055760405163c5723b5160e01b815260040160405180910390fd5b919050565b6002805461048a906119b8565b335f818152600c602090815260408083206001600160a01b03871680855290835292819020805460ff191686151590811790915590519081529192917f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c31910160405180910390a35050565b5f610c8e338484610f2c565b9392505050565b60606006805480602002602001604051908101604052809291908181526020018280548015610ce157602002820191905f5260205f20905b815481526020019060010190808311610ccd575b5050505050905090565b610cf6858585610654565b6001600160a01b0384163b15801590610d8d5750604051630a85bd0160e11b808252906001600160a01b0386169063150b7a0290610d409033908a90899089908990600401611b6f565b6020604051808303815f875af1158015610d5c573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610d809190611a3f565b6001600160e01b03191614155b156109c857604051633da6393160e01b815260040160405180910390fd5b60606004610db8836110e5565b604051602001610dc9929190611bc1565b60408051601f1981840301815290829052610de691602001611c44565b6040516020818303038152906040529050919050565b60068181548110610e0b575f80fd5b5f91825260209091200154905081565b6004805461048a906119b8565b5f546001600160a01b03163314610e51576040516282b42960e81b815260040160405180910390fd5b6004610e5d8282611ab3565b5050565b5f546001600160a01b03163314610e8a576040516282b42960e81b815260040160405180910390fd5b6001600160a01b038116610eb1576040516349e27cff60e01b815260040160405180910390fd5b5f80546001600160a01b0319166001600160a01b0383169081178255604051909133917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a350565b5f610f277f0000000000000000000000000000000000000000000000000000000000000000600a611d4c565b905090565b5f80610f36610efb565b6001600160a01b038087165f818152600960205260408082208054948a1683529082205492825293945091929091869190610f718386611a04565b90915550506001600160a01b038087165f90815260096020908152604080832080548a019055928a16825260109052205460ff1661100a576001600160a01b0387165f90815260096020526040812054610fcc908590611d6e565b610fd68585611d6e565b610fe09190611a04565b90505f5b8181101561100757610ff589611175565b80610fff81611d81565b915050610fe4565b50505b6001600160a01b0386165f9081526010602052604090205460ff1661108b575f6110348483611d6e565b6001600160a01b0388165f90815260096020526040902054611057908690611d6e565b6110619190611a04565b90505f5b818110156110885761107688611293565b8061108081611d81565b915050611065565b50505b856001600160a01b0316876001600160a01b03167fe59fdd36d0d223c0c7d996db7ad796880f45e1936cb0bb7ac102e7082e031487876040516110d091815260200190565b60405180910390a35060019695505050505050565b60605f6110f1836113ce565b60010190505f8167ffffffffffffffff81111561111057611110611728565b6040519080825280601f01601f19166020018201604052801561113a576020820181803683370190505b5090508181016020015b5f19016f181899199a1a9b1b9c1cb0b131b232b360811b600a86061a8153600a850494508461114457509392505050565b6001600160a01b03811661119c57604051636edaef2f60e11b815260040160405180910390fd5b6001600160a01b0381165f908152600e6020526040812080546111c190600190611a04565b815481106111d1576111d1611a17565b905f5260205f20015490506111e5816114a5565b6001600160a01b0382165f908152600e6020526040902080548061120b5761120b611a2b565b5f828152602080822083015f19908101839055909201909255828252600f81526040808320839055600d825280832080546001600160a01b0319908116909155600b9092528083208054909216909155518291906001600160a01b038516907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef908390a45050565b6001600160a01b0381166112ba57604051634e46966960e11b815260040160405180910390fd5b5f60055460075410156112fd5760078054905f6112d683611d81565b90915550506007545f818152600860205260409020805460ff19166001179055905061132d565b600654156113145761130d61151a565b905061132d565b60405163ed4421ad60e01b815260040160405180910390fd5b5f818152600d6020908152604080832080546001600160a01b0319166001600160a01b038716908117909155808452600e835290832080546001818101835582865293852001859055925290546113849190611a04565b5f828152600f602052604080822092909255905182916001600160a01b038516917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef908290a45050565b5f8072184f03e93ff9f4daa797ed6e38ed64bf6a1f0160401b831061140c5772184f03e93ff9f4daa797ed6e38ed64bf6a1f0160401b830492506040015b6d04ee2d6d415b85acef81000000008310611438576d04ee2d6d415b85acef8100000000830492506020015b662386f26fc10000831061145657662386f26fc10000830492506010015b6305f5e100831061146e576305f5e100830492506008015b612710831061148257612710830492506004015b60648310611494576064830492506002015b600a831061064e5760010192915050565b5f8181526008602052604090205460ff166114d3576040516335c0139560e21b815260040160405180910390fd5b60068054600181019091557ff652222313e28459528d920b65115c16c04f3efc82aaedc97be59f3f377c0d3f018190555f908152600860205260409020805460ff19169055565b6006545f90810361153e5760405163ed4421ad60e01b815260040160405180910390fd5b600654604080514260208201526bffffffffffffffffffffffff193360601b1691810191909152605481018290525f9190607401604051602081830303815290604052805190602001205f1c6115949190611d99565b90505f600682815481106115aa576115aa611a17565b905f5260205f2001549050600660016006805490506115c99190611a04565b815481106115d9576115d9611a17565b905f5260205f200154600683815481106115f5576115f5611a17565b5f91825260209091200155600680548061161157611611611a2b565b5f828152602080822083015f199081018390559092019092558282526008905260409020805460ff1916600117905592915050565b5f5b83811015611660578181015183820152602001611648565b50505f910152565b602081525f8251806020840152611686816040850160208701611646565b601f01601f19169190910160400192915050565b5f602082840312156116aa575f80fd5b5035919050565b80356001600160a01b0381168114610c05575f80fd5b5f80604083850312156116d8575f80fd5b6116e1836116b1565b946020939093013593505050565b5f805f60608486031215611701575f80fd5b61170a846116b1565b9250611718602085016116b1565b9150604084013590509250925092565b634e487b7160e01b5f52604160045260245ffd5b5f82601f83011261174b575f80fd5b813567ffffffffffffffff8082111561176657611766611728565b604051601f8301601f19908116603f0116810190828211818310171561178e5761178e611728565b816040528381528660208588010111156117a6575f80fd5b836020870160208301375f602085830101528094505050505092915050565b5f80604083850312156117d6575f80fd5b823567ffffffffffffffff808211156117ed575f80fd5b6117f98683870161173c565b9350602085013591508082111561180e575f80fd5b5061181b8582860161173c565b9150509250929050565b5f8060408385031215611836575f80fd5b61183f836116b1565b915060208301358015158114611853575f80fd5b809150509250929050565b5f6020828403121561186e575f80fd5b610c8e826116b1565b602080825282518282018190525f9190848201906040850190845b818110156118ae57835183529284019291840191600101611892565b50909695505050505050565b5f805f805f608086880312156118ce575f80fd5b6118d7866116b1565b94506118e5602087016116b1565b935060408601359250606086013567ffffffffffffffff80821115611908575f80fd5b818801915088601f83011261191b575f80fd5b813581811115611929575f80fd5b89602082850101111561193a575f80fd5b9699959850939650602001949392505050565b5f806040838503121561195e575f80fd5b611967836116b1565b9150611975602084016116b1565b90509250929050565b5f6020828403121561198e575f80fd5b813567ffffffffffffffff8111156119a4575f80fd5b6119b08482850161173c565b949350505050565b600181811c908216806119cc57607f821691505b6020821081036119ea57634e487b7160e01b5f52602260045260245ffd5b50919050565b634e487b7160e01b5f52601160045260245ffd5b8181038181111561064e5761064e6119f0565b634e487b7160e01b5f52603260045260245ffd5b634e487b7160e01b5f52603160045260245ffd5b5f60208284031215611a4f575f80fd5b81516001600160e01b031981168114610c8e575f80fd5b601f8211156109cb575f81815260208120601f850160051c81016020861015611a8c5750805b601f850160051c820191505b81811015611aab57828155600101611a98565b505050505050565b815167ffffffffffffffff811115611acd57611acd611728565b611ae181611adb84546119b8565b84611a66565b602080601f831160018114611b14575f8415611afd5750858301515b5f19600386901b1c1916600185901b178555611aab565b5f85815260208120601f198616915b82811015611b4257888601518255948401946001909101908401611b23565b5085821015611b5f57878501515f19600388901b60f8161c191681555b5050505050600190811b01905550565b6001600160a01b038681168252851660208201526040810184905260806060820181905281018290525f828460a08401375f60a0848401015260a0601f19601f85011683010190509695505050505050565b5f808454611bce816119b8565b60018281168015611be65760018114611bfb57611c27565b60ff1984168752821515830287019450611c27565b885f526020805f205f5b85811015611c1e5781548a820152908401908201611c05565b50505082870194505b505050508351611c3b818360208801611646565b01949350505050565b5f8251611c55818460208701611646565b64173539b7b760d91b920191825250600501919050565b600181815b80851115611ca657815f1904821115611c8c57611c8c6119f0565b80851615611c9957918102915b93841c9390800290611c71565b509250929050565b5f82611cbc5750600161064e565b81611cc857505f61064e565b8160018114611cde5760028114611ce857611d04565b600191505061064e565b60ff841115611cf957611cf96119f0565b50506001821b61064e565b5060208310610133831016604e8410600b8410161715611d27575081810a61064e565b611d318383611c6c565b805f1904821115611d4457611d446119f0565b029392505050565b5f610c8e60ff841683611cae565b634e487b7160e01b5f52601260045260245ffd5b5f82611d7c57611d7c611d5a565b500490565b5f60018201611d9257611d926119f0565b5060010190565b5f82611da757611da7611d5a565b50069056fea26469706673582212206aace795dd1f9d6505e6d312258ae3c3d72aeb4a325f8f83b4f9b6f465f5294064736f6c6343000814003300000000000000000000000000000000000000000000000000000000000000a000000000000000000000000000000000000000000000000000000000000000e00000000000000000000000000000000000000000000000000000000000000012000000000000000000000000000000000000000000000000000000000000006400000000000000000000000027e22909384b6fac533e5bd36b9f290b818bf82e0000000000000000000000000000000000000000000000000000000000000010457468657265756d20507570706574730000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000075055505045545300000000000000000000000000000000000000000000000000

Deployed Bytecode

0x608060405234801561000f575f80fd5b50600436106101bb575f3560e01c80638da5cb5b116100f3578063c87b56dd11610093578063dd62ed3e1161006e578063dd62ed3e14610400578063e0df5b6f1461042a578063e985e9c51461043d578063f2fde38b1461046a575f80fd5b8063c87b56dd146103d2578063ca4c0e09146103e5578063d547cfb7146103f8575f80fd5b8063a22cb465116100ce578063a22cb46514610384578063a9059cbb14610397578063a9e2880e146103aa578063b88d4fde146103bf575f80fd5b80638da5cb5b1461034857806395d89b411461035a5780639b19251a14610362575f80fd5b80632c88797e1161015e578063504334c211610139578063504334c2146102f057806353d6fd59146103035780636352211e1461031657806370a0823114610329575f80fd5b80632c88797e1461029b578063313ce567146102a457806342842e0e146102dd575f80fd5b8063095ea7b311610199578063095ea7b31461023457806318160ddd1461025757806323b872dd1461027e5780632b96895814610293575f80fd5b806306fdde03146101bf57806307c56001146101dd578063081812fc146101f4575b5f80fd5b6101c761047d565b6040516101d49190611668565b60405180910390f35b6101e660075481565b6040519081526020016101d4565b61021c61020236600461169a565b600b6020525f90815260409020546001600160a01b031681565b6040516001600160a01b0390911681526020016101d4565b6102476102423660046116c7565b610509565b60405190151581526020016101d4565b6101e67f0000000000000000000000000000000000000000000000056bc75e2d6310000081565b61029161028c3660046116ef565b610654565b005b6102916109d0565b6101e660055481565b6102cb7f000000000000000000000000000000000000000000000000000000000000001281565b60405160ff90911681526020016101d4565b6102916102eb3660046116ef565b610a34565b6102916102fe3660046117c5565b610b05565b610291610311366004611825565b610b47565b61021c61032436600461169a565b610bd0565b6101e661033736600461185e565b60096020525f908152604090205481565b5f5461021c906001600160a01b031681565b6101c7610c0a565b61024761037036600461185e565b60106020525f908152604090205460ff1681565b610291610392366004611825565b610c17565b6102476103a53660046116c7565b610c82565b6103b2610c95565b6040516101d49190611877565b6102916103cd3660046118ba565b610ceb565b6101c76103e036600461169a565b610dab565b6101e66103f336600461169a565b610dfc565b6101c7610e1b565b6101e661040e36600461194d565b600a60209081525f928352604080842090915290825290205481565b61029161043836600461197e565b610e28565b61024761044b36600461194d565b600c60209081525f928352604080842090915290825290205460ff1681565b61029161047836600461185e565b610e61565b6001805461048a906119b8565b80601f01602080910402602001604051908101604052809291908181526020018280546104b6906119b8565b80156105015780601f106104d857610100808354040283529160200191610501565b820191905f5260205f20905b8154815290600101906020018083116104e457829003601f168201915b505050505081565b5f600754821115801561051b57505f82115b156105ef575f828152600d60205260409020546001600160a01b031633811480159061056a57506001600160a01b0381165f908152600c6020908152604080832033845290915290205460ff16155b15610587576040516282b42960e81b815260040160405180910390fd5b5f838152600b602090815260409182902080546001600160a01b0319166001600160a01b038881169182179092559251868152908416917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a35061064a565b335f818152600a602090815260408083206001600160a01b03881680855290835292819020869055518581529192917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a35b5060015b92915050565b6005548111610964575f818152600d60205260409020546001600160a01b0384811691161461069657604051636edaef2f60e11b815260040160405180910390fd5b6001600160a01b0382166106bd57604051634e46966960e11b815260040160405180910390fd5b336001600160a01b038416148015906106f957506001600160a01b0383165f908152600c6020908152604080832033845290915290205460ff16155b801561071b57505f818152600b60205260409020546001600160a01b03163314155b15610738576040516282b42960e81b815260040160405180910390fd5b610740610efb565b6001600160a01b0384165f9081526009602052604081208054909190610767908490611a04565b909155506107759050610efb565b6001600160a01b038084165f8181526009602090815260408083208054909601909555858252600d815284822080546001600160a01b03199081169094179055600b815284822080549093169092559186168252600e905290812080546107de90600190611a04565b815481106107ee576107ee611a17565b5f9182526020808320909101546001600160a01b0387168352600e82526040808420868552600f9093529092205481549293508392811061083157610831611a17565b5f9182526020808320909101929092556001600160a01b0386168152600e9091526040902080548061086557610865611a2b565b5f828152602080822083015f19908101839055909201909255838252600f8152604080832054848452818420556001600160a01b038616808452600e835290832080546001818101835582865293852001869055925290546108c79190611a04565b5f838152600f602052604080822092909255905183916001600160a01b0380871692908816917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef91a4826001600160a01b0316846001600160a01b03167fe59fdd36d0d223c0c7d996db7ad796880f45e1936cb0bb7ac102e7082e03148761094d610efb565b60405190815260200160405180910390a350505050565b6001600160a01b0383165f908152600a602090815260408083203384529091529020545f1981146109bd576109998282611a04565b6001600160a01b0385165f908152600a602090815260408083203384529091529020555b6109c8848484610f2c565b50505b505050565b5f546001600160a01b031633146109f9576040516282b42960e81b815260040160405180910390fd5b5f80546001600160a01b031916815560405133907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3565b610a3f838383610654565b6001600160a01b0382163b15801590610ae75750604051630a85bd0160e11b8082523360048301526001600160a01b03858116602484015260448301849052608060648401525f608484015290919084169063150b7a029060a4016020604051808303815f875af1158015610ab6573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610ada9190611a3f565b6001600160e01b03191614155b156109cb57604051633da6393160e01b815260040160405180910390fd5b5f546001600160a01b03163314610b2e576040516282b42960e81b815260040160405180910390fd5b6001610b3a8382611ab3565b5060026109cb8282611ab3565b5f546001600160a01b03163314610b70576040516282b42960e81b815260040160405180910390fd5b6001600160a01b0382165f9081526009602052604090205415610ba657604051632f57ef6960e01b815260040160405180910390fd5b6001600160a01b03919091165f908152601060205260409020805460ff1916911515919091179055565b5f818152600d60205260409020546001600160a01b031680610c055760405163c5723b5160e01b815260040160405180910390fd5b919050565b6002805461048a906119b8565b335f818152600c602090815260408083206001600160a01b03871680855290835292819020805460ff191686151590811790915590519081529192917f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c31910160405180910390a35050565b5f610c8e338484610f2c565b9392505050565b60606006805480602002602001604051908101604052809291908181526020018280548015610ce157602002820191905f5260205f20905b815481526020019060010190808311610ccd575b5050505050905090565b610cf6858585610654565b6001600160a01b0384163b15801590610d8d5750604051630a85bd0160e11b808252906001600160a01b0386169063150b7a0290610d409033908a90899089908990600401611b6f565b6020604051808303815f875af1158015610d5c573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610d809190611a3f565b6001600160e01b03191614155b156109c857604051633da6393160e01b815260040160405180910390fd5b60606004610db8836110e5565b604051602001610dc9929190611bc1565b60408051601f1981840301815290829052610de691602001611c44565b6040516020818303038152906040529050919050565b60068181548110610e0b575f80fd5b5f91825260209091200154905081565b6004805461048a906119b8565b5f546001600160a01b03163314610e51576040516282b42960e81b815260040160405180910390fd5b6004610e5d8282611ab3565b5050565b5f546001600160a01b03163314610e8a576040516282b42960e81b815260040160405180910390fd5b6001600160a01b038116610eb1576040516349e27cff60e01b815260040160405180910390fd5b5f80546001600160a01b0319166001600160a01b0383169081178255604051909133917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a350565b5f610f277f0000000000000000000000000000000000000000000000000000000000000012600a611d4c565b905090565b5f80610f36610efb565b6001600160a01b038087165f818152600960205260408082208054948a1683529082205492825293945091929091869190610f718386611a04565b90915550506001600160a01b038087165f90815260096020908152604080832080548a019055928a16825260109052205460ff1661100a576001600160a01b0387165f90815260096020526040812054610fcc908590611d6e565b610fd68585611d6e565b610fe09190611a04565b90505f5b8181101561100757610ff589611175565b80610fff81611d81565b915050610fe4565b50505b6001600160a01b0386165f9081526010602052604090205460ff1661108b575f6110348483611d6e565b6001600160a01b0388165f90815260096020526040902054611057908690611d6e565b6110619190611a04565b90505f5b818110156110885761107688611293565b8061108081611d81565b915050611065565b50505b856001600160a01b0316876001600160a01b03167fe59fdd36d0d223c0c7d996db7ad796880f45e1936cb0bb7ac102e7082e031487876040516110d091815260200190565b60405180910390a35060019695505050505050565b60605f6110f1836113ce565b60010190505f8167ffffffffffffffff81111561111057611110611728565b6040519080825280601f01601f19166020018201604052801561113a576020820181803683370190505b5090508181016020015b5f19016f181899199a1a9b1b9c1cb0b131b232b360811b600a86061a8153600a850494508461114457509392505050565b6001600160a01b03811661119c57604051636edaef2f60e11b815260040160405180910390fd5b6001600160a01b0381165f908152600e6020526040812080546111c190600190611a04565b815481106111d1576111d1611a17565b905f5260205f20015490506111e5816114a5565b6001600160a01b0382165f908152600e6020526040902080548061120b5761120b611a2b565b5f828152602080822083015f19908101839055909201909255828252600f81526040808320839055600d825280832080546001600160a01b0319908116909155600b9092528083208054909216909155518291906001600160a01b038516907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef908390a45050565b6001600160a01b0381166112ba57604051634e46966960e11b815260040160405180910390fd5b5f60055460075410156112fd5760078054905f6112d683611d81565b90915550506007545f818152600860205260409020805460ff19166001179055905061132d565b600654156113145761130d61151a565b905061132d565b60405163ed4421ad60e01b815260040160405180910390fd5b5f818152600d6020908152604080832080546001600160a01b0319166001600160a01b038716908117909155808452600e835290832080546001818101835582865293852001859055925290546113849190611a04565b5f828152600f602052604080822092909255905182916001600160a01b038516917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef908290a45050565b5f8072184f03e93ff9f4daa797ed6e38ed64bf6a1f0160401b831061140c5772184f03e93ff9f4daa797ed6e38ed64bf6a1f0160401b830492506040015b6d04ee2d6d415b85acef81000000008310611438576d04ee2d6d415b85acef8100000000830492506020015b662386f26fc10000831061145657662386f26fc10000830492506010015b6305f5e100831061146e576305f5e100830492506008015b612710831061148257612710830492506004015b60648310611494576064830492506002015b600a831061064e5760010192915050565b5f8181526008602052604090205460ff166114d3576040516335c0139560e21b815260040160405180910390fd5b60068054600181019091557ff652222313e28459528d920b65115c16c04f3efc82aaedc97be59f3f377c0d3f018190555f908152600860205260409020805460ff19169055565b6006545f90810361153e5760405163ed4421ad60e01b815260040160405180910390fd5b600654604080514260208201526bffffffffffffffffffffffff193360601b1691810191909152605481018290525f9190607401604051602081830303815290604052805190602001205f1c6115949190611d99565b90505f600682815481106115aa576115aa611a17565b905f5260205f2001549050600660016006805490506115c99190611a04565b815481106115d9576115d9611a17565b905f5260205f200154600683815481106115f5576115f5611a17565b5f91825260209091200155600680548061161157611611611a2b565b5f828152602080822083015f199081018390559092019092558282526008905260409020805460ff1916600117905592915050565b5f5b83811015611660578181015183820152602001611648565b50505f910152565b602081525f8251806020840152611686816040850160208701611646565b601f01601f19169190910160400192915050565b5f602082840312156116aa575f80fd5b5035919050565b80356001600160a01b0381168114610c05575f80fd5b5f80604083850312156116d8575f80fd5b6116e1836116b1565b946020939093013593505050565b5f805f60608486031215611701575f80fd5b61170a846116b1565b9250611718602085016116b1565b9150604084013590509250925092565b634e487b7160e01b5f52604160045260245ffd5b5f82601f83011261174b575f80fd5b813567ffffffffffffffff8082111561176657611766611728565b604051601f8301601f19908116603f0116810190828211818310171561178e5761178e611728565b816040528381528660208588010111156117a6575f80fd5b836020870160208301375f602085830101528094505050505092915050565b5f80604083850312156117d6575f80fd5b823567ffffffffffffffff808211156117ed575f80fd5b6117f98683870161173c565b9350602085013591508082111561180e575f80fd5b5061181b8582860161173c565b9150509250929050565b5f8060408385031215611836575f80fd5b61183f836116b1565b915060208301358015158114611853575f80fd5b809150509250929050565b5f6020828403121561186e575f80fd5b610c8e826116b1565b602080825282518282018190525f9190848201906040850190845b818110156118ae57835183529284019291840191600101611892565b50909695505050505050565b5f805f805f608086880312156118ce575f80fd5b6118d7866116b1565b94506118e5602087016116b1565b935060408601359250606086013567ffffffffffffffff80821115611908575f80fd5b818801915088601f83011261191b575f80fd5b813581811115611929575f80fd5b89602082850101111561193a575f80fd5b9699959850939650602001949392505050565b5f806040838503121561195e575f80fd5b611967836116b1565b9150611975602084016116b1565b90509250929050565b5f6020828403121561198e575f80fd5b813567ffffffffffffffff8111156119a4575f80fd5b6119b08482850161173c565b949350505050565b600181811c908216806119cc57607f821691505b6020821081036119ea57634e487b7160e01b5f52602260045260245ffd5b50919050565b634e487b7160e01b5f52601160045260245ffd5b8181038181111561064e5761064e6119f0565b634e487b7160e01b5f52603260045260245ffd5b634e487b7160e01b5f52603160045260245ffd5b5f60208284031215611a4f575f80fd5b81516001600160e01b031981168114610c8e575f80fd5b601f8211156109cb575f81815260208120601f850160051c81016020861015611a8c5750805b601f850160051c820191505b81811015611aab57828155600101611a98565b505050505050565b815167ffffffffffffffff811115611acd57611acd611728565b611ae181611adb84546119b8565b84611a66565b602080601f831160018114611b14575f8415611afd5750858301515b5f19600386901b1c1916600185901b178555611aab565b5f85815260208120601f198616915b82811015611b4257888601518255948401946001909101908401611b23565b5085821015611b5f57878501515f19600388901b60f8161c191681555b5050505050600190811b01905550565b6001600160a01b038681168252851660208201526040810184905260806060820181905281018290525f828460a08401375f60a0848401015260a0601f19601f85011683010190509695505050505050565b5f808454611bce816119b8565b60018281168015611be65760018114611bfb57611c27565b60ff1984168752821515830287019450611c27565b885f526020805f205f5b85811015611c1e5781548a820152908401908201611c05565b50505082870194505b505050508351611c3b818360208801611646565b01949350505050565b5f8251611c55818460208701611646565b64173539b7b760d91b920191825250600501919050565b600181815b80851115611ca657815f1904821115611c8c57611c8c6119f0565b80851615611c9957918102915b93841c9390800290611c71565b509250929050565b5f82611cbc5750600161064e565b81611cc857505f61064e565b8160018114611cde5760028114611ce857611d04565b600191505061064e565b60ff841115611cf957611cf96119f0565b50506001821b61064e565b5060208310610133831016604e8410600b8410161715611d27575081810a61064e565b611d318383611c6c565b805f1904821115611d4457611d446119f0565b029392505050565b5f610c8e60ff841683611cae565b634e487b7160e01b5f52601260045260245ffd5b5f82611d7c57611d7c611d5a565b500490565b5f60018201611d9257611d926119f0565b5060010190565b5f82611da757611da7611d5a565b50069056fea26469706673582212206aace795dd1f9d6505e6d312258ae3c3d72aeb4a325f8f83b4f9b6f465f5294064736f6c63430008140033

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

00000000000000000000000000000000000000000000000000000000000000a000000000000000000000000000000000000000000000000000000000000000e00000000000000000000000000000000000000000000000000000000000000012000000000000000000000000000000000000000000000000000000000000006400000000000000000000000027e22909384b6fac533e5bd36b9f290b818bf82e0000000000000000000000000000000000000000000000000000000000000010457468657265756d20507570706574730000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000075055505045545300000000000000000000000000000000000000000000000000

-----Decoded View---------------
Arg [0] : _name (string): Ethereum Puppets
Arg [1] : _symbol (string): PUPPETS
Arg [2] : _decimals (uint8): 18
Arg [3] : _totalNativeSupply (uint256): 100
Arg [4] : _owner (address): 0x27e22909384b6fac533E5Bd36b9f290b818bF82E

-----Encoded View---------------
9 Constructor Arguments found :
Arg [0] : 00000000000000000000000000000000000000000000000000000000000000a0
Arg [1] : 00000000000000000000000000000000000000000000000000000000000000e0
Arg [2] : 0000000000000000000000000000000000000000000000000000000000000012
Arg [3] : 0000000000000000000000000000000000000000000000000000000000000064
Arg [4] : 00000000000000000000000027e22909384b6fac533e5bd36b9f290b818bf82e
Arg [5] : 0000000000000000000000000000000000000000000000000000000000000010
Arg [6] : 457468657265756d205075707065747300000000000000000000000000000000
Arg [7] : 0000000000000000000000000000000000000000000000000000000000000007
Arg [8] : 5055505045545300000000000000000000000000000000000000000000000000


Deployed Bytecode Sourcemap

20954:11645:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;21942:18;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;22643:26;;;;;;;;;816:25:1;;;804:2;789:18;22643:26:0;670:177:1;23089:46:0;;;;;;:::i;:::-;;;;;;;;;;;;-1:-1:-1;;;;;23089:46:0;;;;;;-1:-1:-1;;;;;1201:32:1;;;1183:51;;1171:2;1156:18;23089:46:0;1037:203:1;25403:639:0;;;;;;:::i;:::-;;:::i;:::-;;;1847:14:1;;1840:22;1822:41;;1810:2;1795:18;25403:639:0;1682:187:1;22178:36:0;;;;;26441:1685;;;;;;:::i;:::-;;:::i;:::-;;20537:151;;;:::i;22440:32::-;;;;;;22078:31;;;;;;;;2379:4:1;2367:17;;;2349:36;;2337:2;2322:18;22078:31:0;2207:184:1;28389:363:0;;;;;;:::i;:::-;;:::i;32315:167::-;;;;;;:::i;:::-;;:::i;24379:275::-;;;;;;:::i;:::-;;:::i;24726:185::-;;;;;;:::i;:::-;;:::i;22855:44::-;;;;;;:::i;:::-;;;;;;;;;;;;;;19978:20;;;;;-1:-1:-1;;;;;19978:20:0;;;21996;;;:::i;23700:41::-;;;;;;:::i;:::-;;;;;;;;;;;;;;;;26093:199;;;;;;:::i;:::-;;:::i;28185:127::-;;;;;;:::i;:::-;;:::i;32494:102::-;;;:::i;:::-;;;;;;;:::i;28847:429::-;;;;;;:::i;:::-;;:::i;25033:221::-;;;;;;:::i;:::-;;:::i;22516:28::-;;;;;;:::i;:::-;;:::i;22370:26::-;;;:::i;22969:64::-;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;24919:106;;;;;;:::i;:::-;;:::i;23200:68::-;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;20310:219;;;;;;:::i;:::-;;:::i;21942:18::-;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::o;25403:639::-;25498:4;25533:11;;25519:10;:25;;:43;;;;;25561:1;25548:10;:14;25519:43;25515:496;;;25579:13;25595:20;;;:8;:20;;;;;;-1:-1:-1;;;;;25595:20:0;25636:10;:19;;;;;:59;;-1:-1:-1;;;;;;25660:23:0;;;;;;:16;:23;;;;;;;;25684:10;25660:35;;;;;;;;;;25659:36;25636:59;25632:121;;;25723:14;;-1:-1:-1;;;25723:14:0;;;;;;;;;;;25632:121;25769:23;;;;:11;:23;;;;;;;;;:33;;-1:-1:-1;;;;;;25769:33:0;-1:-1:-1;;;;;25769:33:0;;;;;;;;;25824:36;;816:25:1;;;25824:36:0;;;;;;789:18:1;25824:36:0;;;;;;;25564:308;25515:496;;;25903:10;25893:21;;;;:9;:21;;;;;;;;-1:-1:-1;;;;;25893:30:0;;;;;;;;;;;;:43;;;25958:41;816:25:1;;;25893:30:0;;25903:10;25958:41;;789:18:1;25958:41:0;;;;;;;25515:496;-1:-1:-1;26030:4:0;25403:639;;;;;:::o;26441:1685::-;26545:17;;26531:10;:31;26527:1592;;26591:20;;;;:8;:20;;;;;;-1:-1:-1;;;;;26583:28:0;;;26591:20;;26583:28;26579:91;;26639:15;;-1:-1:-1;;;26639:15:0;;;;;;;;;;;26579:91;-1:-1:-1;;;;;26690:16:0;;26686:82;;26734:18;;-1:-1:-1;;;26734:18:0;;;;;;;;;;;26686:82;26806:10;-1:-1:-1;;;;;26806:18:0;;;;;;:74;;-1:-1:-1;;;;;;26846:22:0;;;;;;:16;:22;;;;;;;;26869:10;26846:34;;;;;;;;;;26845:35;26806:74;:132;;;;-1:-1:-1;26915:23:0;;;;:11;:23;;;;;;-1:-1:-1;;;;;26915:23:0;26901:10;:37;;26806:132;26784:226;;;26980:14;;-1:-1:-1;;;26980:14:0;;;;;;;;;;;26784:226;27045:10;:8;:10::i;:::-;-1:-1:-1;;;;;27026:15:0;;;;;;:9;:15;;;;;:29;;:15;;;:29;;;;;:::i;:::-;;;;-1:-1:-1;27118:10:0;;-1:-1:-1;27118:8:0;:10::i;:::-;-1:-1:-1;;;;;27101:13:0;;;;;;;:9;:13;;;;;;;;:27;;;;;;;;27160:20;;;:8;:20;;;;;:25;;-1:-1:-1;;;;;;27160:25:0;;;;;;;;27207:11;:23;;;;;27200:30;;;;;;;;27308:12;;;;;:6;:12;;;;;27321:19;;:23;;-1:-1:-1;;27321:23:0;:::i;:::-;27308:37;;;;;;;;:::i;:::-;;;;;;;;;;;;;-1:-1:-1;;;;;27360:12:0;;;;:6;:12;;;;;;27373:23;;;:11;:23;;;;;;;27360:37;;27308;;-1:-1:-1;27308:37:0;;27360;;;;;;:::i;:::-;;;;;;;;;;;;:49;;;;-1:-1:-1;;;;;27444:12:0;;;;:6;:12;;;;;;:18;;;;;;;:::i;:::-;;;;;;;;;;;-1:-1:-1;;27444:18:0;;;;;;;;;;;;27548:23;;;:11;:23;;;;;;;27523:22;;;;;;:48;-1:-1:-1;;;;;27625:10:0;;;;;:6;:10;;;;;:27;;27444:18;27625:27;;;;;;;;;;;;;;;27735:10;;:17;;:21;;27444:18;27735:21;:::i;:::-;27709:23;;;;:11;:23;;;;;;:47;;;;27778:30;;27721:10;;-1:-1:-1;;;;;27778:30:0;;;;;;;;;;;27848:2;-1:-1:-1;;;;;27828:35:0;27842:4;-1:-1:-1;;;;;27828:35:0;;27852:10;:8;:10::i;:::-;27828:35;;816:25:1;;;804:2;789:18;27828:35:0;;;;;;;26564:1311;26441:1685;;;:::o;26527:1592::-;-1:-1:-1;;;;;27914:15:0;;27896;27914;;;:9;:15;;;;;;;;27930:10;27914:27;;;;;;;;-1:-1:-1;;27962:28:0;;27958:101;;28039:20;28049:10;28039:7;:20;:::i;:::-;-1:-1:-1;;;;;28009:15:0;;;;;;:9;:15;;;;;;;;28025:10;28009:27;;;;;;;:50;27958:101;28076:31;28086:4;28092:2;28096:10;28076:9;:31::i;:::-;;27881:238;26527:1592;26441:1685;;;:::o;20537:151::-;20065:5;;-1:-1:-1;;;;;20065:5:0;20051:10;:19;20047:46;;20079:14;;-1:-1:-1;;;20079:14:0;;;;;;;;;;;20047:46;20616:1:::1;20600:18:::0;;-1:-1:-1;;;;;;20600:18:0::1;::::0;;20636:44:::1;::::0;20657:10:::1;::::0;20636:44:::1;::::0;20616:1;;20636:44:::1;20537:151::o:0;28389:363::-;28471:26;28484:4;28490:2;28494;28471:12;:26::i;:::-;-1:-1:-1;;;;;28528:14:0;;;:19;;;;:154;;-1:-1:-1;28564:61:0;;-1:-1:-1;;;28564:61:0;;;28600:10;28564:61;;;7604:34:1;-1:-1:-1;;;;;7674:15:1;;;7654:18;;;7647:43;7706:18;;;7699:34;;;7769:3;7749:18;;;7742:31;-1:-1:-1;7789:19:1;;;7782:30;28642:40:0;;28564:35;;;;28642:40;;7829:19:1;;28564:61:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;-1:-1:-1;;;;;;28564:118:0;;;28528:154;28510:235;;;28716:17;;-1:-1:-1;;;28716:17:0;;;;;;;;;;;32315:167;20065:5;;-1:-1:-1;;;;;20065:5:0;20051:10;:19;20047:46;;20079:14;;-1:-1:-1;;;20079:14:0;;;;;;;;;;;20047:46;32435:4:::1;:12;32442:5:::0;32435:4;:12:::1;:::i;:::-;-1:-1:-1::0;32458:6:0::1;:16;32467:7:::0;32458:6;:16:::1;:::i;24379:275::-:0;20065:5;;-1:-1:-1;;;;;20065:5:0;20051:10;:19;20047:46;;20079:14;;-1:-1:-1;;;20079:14:0;;;;;;;;;;;20047:46;-1:-1:-1;;;;;24524:17:0;::::1;24544:1;24524:17:::0;;;:9:::1;:17;::::0;;;;;:21;24520:91:::1;;24569:30;;-1:-1:-1::0;;;24569:30:0::1;;;;;;;;;;;24520:91;-1:-1:-1::0;;;;;24621:17:0;;;::::1;;::::0;;;:9:::1;:17;::::0;;;;:25;;-1:-1:-1;;24621:25:0::1;::::0;::::1;;::::0;;;::::1;::::0;;24379:275::o;24726:185::-;24776:13;24810:12;;;:8;:12;;;;;;-1:-1:-1;;;;;24810:12:0;;24835:69;;24882:10;;-1:-1:-1;;;24882:10:0;;;;;;;;;;;24835:69;24726:185;;;:::o;21996:20::-;;;;;;;:::i;26093:199::-;26188:10;26171:28;;;;:16;:28;;;;;;;;-1:-1:-1;;;;;26171:38:0;;;;;;;;;;;;:49;;-1:-1:-1;;26171:49:0;;;;;;;;;;26238:46;;1822:41:1;;;26171:38:0;;26188:10;26238:46;;1795:18:1;26238:46:0;;;;;;;26093:199;;:::o;28185:127::-;28247:4;28271:33;28281:10;28293:2;28297:6;28271:9;:33::i;:::-;28264:40;28185:127;-1:-1:-1;;;28185:127:0:o;32494:102::-;32541:16;32577:11;32570:18;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;32494:102;:::o;28847:429::-;28993:26;29006:4;29012:2;29016;28993:12;:26::i;:::-;-1:-1:-1;;;;;29050:14:0;;;:19;;;;:156;;-1:-1:-1;29086:63:0;;-1:-1:-1;;;29086:63:0;;;29166:40;-1:-1:-1;;;;;29086:35:0;;;29166:40;;29086:63;;29122:10;;29134:4;;29140:2;;29144:4;;;;29086:63;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;-1:-1:-1;;;;;;29086:120:0;;;29050:156;29032:237;;;29240:17;;-1:-1:-1;;;29240:17:0;;;;;;;;;;;25033:221;25084:13;25168:12;25182:20;25199:2;25182:16;:20::i;:::-;25154:49;;;;;;;;;:::i;:::-;;;;-1:-1:-1;;25154:49:0;;;;;;;;;;25126:110;;25154:49;25126:110;;:::i;:::-;;;;;;;;;;;;;25110:126;;25033:221;;;:::o;22516:28::-;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;22516:28:0;:::o;22370:26::-;;;;;;;:::i;24919:106::-;20065:5;;-1:-1:-1;;;;;20065:5:0;20051:10;:19;20047:46;;20079:14;;-1:-1:-1;;;20079:14:0;;;;;;;;;;;20047:46;24993:12:::1;:24;25008:9:::0;24993:12;:24:::1;:::i;:::-;;24919:106:::0;:::o;20310:219::-;20065:5;;-1:-1:-1;;;;;20065:5:0;20051:10;:19;20047:46;;20079:14;;-1:-1:-1;;;20079:14:0;;;;;;;;;;;20047:46;-1:-1:-1;;;;;20393:20:0;::::1;20389:47;;20422:14;;-1:-1:-1::0;;;20422:14:0::1;;;;;;;;;;;20389:47;20449:5;:14:::0;;-1:-1:-1;;;;;;20449:14:0::1;-1:-1:-1::0;;;;;20449:14:0;::::1;::::0;;::::1;::::0;;20481:40:::1;::::0;20449:14;;20502:10:::1;::::0;20481:40:::1;::::0;20449:5;20481:40:::1;20310:219:::0;:::o;30476:92::-;30519:7;30546:14;30552:8;30546:2;:14;:::i;:::-;30539:21;;30476:92;:::o;29344:1093::-;29457:4;29474:12;29489:10;:8;:10::i;:::-;-1:-1:-1;;;;;29540:15:0;;;29510:27;29540:15;;;:9;:15;;;;;;;;29598:13;;;;;;;;;29624:15;;;29474:25;;-1:-1:-1;29540:15:0;;29598:13;;29643:6;;29540:15;29624:25;29643:6;29540:15;29624:25;:::i;:::-;;;;-1:-1:-1;;;;;;;29687:13:0;;;;;;;:9;:13;;;;;;;;:23;;;;;;29795:15;;;;;:9;:15;;;;;;29790:251;;-1:-1:-1;;;;;29901:15:0;;29827:22;29901:15;;;:9;:15;;;;;;:22;;29919:4;;29901:22;:::i;:::-;29853:26;29875:4;29853:19;:26;:::i;:::-;29852:72;;;;:::i;:::-;29827:97;;29944:9;29939:91;29963:14;29959:1;:18;29939:91;;;30003:11;30009:4;30003:5;:11::i;:::-;29979:3;;;;:::i;:::-;;;;29939:91;;;;29812:229;29790:251;-1:-1:-1;;;;;30117:13:0;;;;;;:9;:13;;;;;;;;30112:247;;30147:22;30215:28;30239:4;30215:21;:28;:::i;:::-;-1:-1:-1;;;;;30173:13:0;;;;;;:9;:13;;;;;;:20;;30189:4;;30173:20;:::i;:::-;30172:72;;;;:::i;:::-;30147:97;;30264:9;30259:89;30283:14;30279:1;:18;30259:89;;;30323:9;30329:2;30323:5;:9::i;:::-;30299:3;;;;:::i;:::-;;;;30259:89;;;;30132:227;30112:247;30396:2;-1:-1:-1;;;;;30376:31:0;30390:4;-1:-1:-1;;;;;30376:31:0;;30400:6;30376:31;;;;816:25:1;;804:2;789:18;;670:177;30376:31:0;;;;;;;;-1:-1:-1;30425:4:0;;29344:1093;-1:-1:-1;;;;;;29344:1093:0:o;17271:718::-;17327:13;17378:14;17395:17;17406:5;17395:10;:17::i;:::-;17415:1;17395:21;17378:38;;17431:20;17465:6;17454:18;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;17454:18:0;-1:-1:-1;17431:41:0;-1:-1:-1;17596:28:0;;;17612:2;17596:28;17653:290;-1:-1:-1;;17685:5:0;-1:-1:-1;;;17822:2:0;17811:14;;17806:32;17685:5;17793:46;17885:2;17876:11;;;-1:-1:-1;17906:21:0;17653:290;17906:21;-1:-1:-1;17964:6:0;17271:718;-1:-1:-1;;;17271:718:0:o;31914:393::-;-1:-1:-1;;;;;31967:18:0;;31963:73;;32009:15;;-1:-1:-1;;;32009:15:0;;;;;;;;;;;31963:73;-1:-1:-1;;;;;32059:12:0;;32046:10;32059:12;;;:6;:12;;;;;32072:19;;:23;;32094:1;;32072:23;:::i;:::-;32059:37;;;;;;;;:::i;:::-;;;;;;;;;32046:50;;32107:19;32123:2;32107:15;:19::i;:::-;-1:-1:-1;;;;;32137:12:0;;;;;;:6;:12;;;;;:18;;;;;;;:::i;:::-;;;;;;;;;;;-1:-1:-1;;32137:18:0;;;;;;;;;;;;32173:15;;;:11;:15;;;;;;32166:22;;;32206:8;:12;;;;;32199:19;;-1:-1:-1;;;;;;32199:19:0;;;;;;32236:11;:15;;;;;;32229:22;;;;;;;;32269:30;32185:2;;32137:18;-1:-1:-1;;;;;32269:30:0;;;;;32137:18;;32269:30;31952:355;31914:393;:::o;31305:601::-;-1:-1:-1;;;;;31356:16:0;;31352:74;;31396:18;;-1:-1:-1;;;31396:18:0;;;;;;;;;;;31352:74;31438:10;31479:17;;31465:11;;:31;31461:282;;;31513:11;:13;;;:11;:13;;;:::i;:::-;;;;-1:-1:-1;;31546:11:0;;31572:14;;;;:10;:14;;;;;:21;;-1:-1:-1;;31572:21:0;31589:4;31572:21;;;31546:11;-1:-1:-1;31461:282:0;;;31615:11;:18;:22;31611:132;;31659:19;:17;:19::i;:::-;31654:24;;31611:132;;;31718:13;;-1:-1:-1;;;31718:13:0;;;;;;;;;;;31611:132;31755:12;;;;:8;:12;;;;;;;;:17;;-1:-1:-1;;;;;;31755:17:0;-1:-1:-1;;;;;31755:17:0;;;;;;;;31783:10;;;:6;:10;;;;;:19;;-1:-1:-1;31783:19:0;;;;;;;;;;;;;;;31831:10;;:17;;:21;;-1:-1:-1;31831:21:0;:::i;:::-;31813:15;;;;:11;:15;;;;;;:39;;;;31870:28;;31825:2;;-1:-1:-1;;;;;31870:28:0;;;;;31813:15;;31870:28;31341:565;31305:601;:::o;13872:948::-;13925:7;;-1:-1:-1;;;14003:17:0;;13999:106;;-1:-1:-1;;;14041:17:0;;;-1:-1:-1;14087:2:0;14077:12;13999:106;14132:8;14123:5;:17;14119:106;;14170:8;14161:17;;;-1:-1:-1;14207:2:0;14197:12;14119:106;14252:8;14243:5;:17;14239:106;;14290:8;14281:17;;;-1:-1:-1;14327:2:0;14317:12;14239:106;14372:7;14363:5;:16;14359:103;;14409:7;14400:16;;;-1:-1:-1;14445:1:0;14435:11;14359:103;14489:7;14480:5;:16;14476:103;;14526:7;14517:16;;;-1:-1:-1;14562:1:0;14552:11;14476:103;14606:7;14597:5;:16;14593:103;;14643:7;14634:16;;;-1:-1:-1;14679:1:0;14669:11;14593:103;14723:7;14714:5;:16;14710:68;;14761:1;14751:11;14806:6;13872:948;-1:-1:-1;;13872:948:0:o;31100:197::-;31161:14;;;;:10;:14;;;;;;;;31156:70;;31199:15;;-1:-1:-1;;;31199:15:0;;;;;;;;;;;31156:70;31236:11;:20;;;;;;;;;;;;;-1:-1:-1;31267:14:0;;;:10;31236:20;31267:14;;;;:22;;-1:-1:-1;;31267:22:0;;;31100:197::o;30576:512::-;30646:11;:18;30622:7;;30646:23;;30642:76;;30693:13;;-1:-1:-1;;;30693:13:0;;;;;;;;;;;30642:76;30861:11;:18;30782:64;;;30799:15;30782:64;;;14465:19:1;-1:-1:-1;;30816:10:0;14522:2:1;14518:15;14514:53;14500:12;;;14493:75;;;;14584:12;;;14577:28;;;30728:19:0;;30861:18;14621:12:1;;30782:64:0;;;;;;;;;;;;30772:75;;;;;;30750:108;;:129;;;;:::i;:::-;30728:151;;30890:10;30903:11;30915;30903:24;;;;;;;;:::i;:::-;;;;;;;;;30890:37;;30965:11;30998:1;30977:11;:18;;;;:22;;;;:::i;:::-;30965:35;;;;;;;;:::i;:::-;;;;;;;;;30938:11;30950;30938:24;;;;;;;;:::i;:::-;;;;;;;;;;:62;31011:11;:17;;;;;;;:::i;:::-;;;;;;;;;;;-1:-1:-1;;31011:17:0;;;;;;;;;;;;31039:14;;;:10;:14;;;;;:21;;-1:-1:-1;;31039:21:0;31011:17;31039:21;;;31050:2;30576:512;-1:-1:-1;;30576:512:0:o;14:250:1:-;99:1;109:113;123:6;120:1;117:13;109:113;;;199:11;;;193:18;180:11;;;173:39;145:2;138:10;109:113;;;-1:-1:-1;;256:1:1;238:16;;231:27;14:250::o;269:396::-;418:2;407:9;400:21;381:4;450:6;444:13;493:6;488:2;477:9;473:18;466:34;509:79;581:6;576:2;565:9;561:18;556:2;548:6;544:15;509:79;:::i;:::-;649:2;628:15;-1:-1:-1;;624:29:1;609:45;;;;656:2;605:54;;269:396;-1:-1:-1;;269:396:1:o;852:180::-;911:6;964:2;952:9;943:7;939:23;935:32;932:52;;;980:1;977;970:12;932:52;-1:-1:-1;1003:23:1;;852:180;-1:-1:-1;852:180:1:o;1245:173::-;1313:20;;-1:-1:-1;;;;;1362:31:1;;1352:42;;1342:70;;1408:1;1405;1398:12;1423:254;1491:6;1499;1552:2;1540:9;1531:7;1527:23;1523:32;1520:52;;;1568:1;1565;1558:12;1520:52;1591:29;1610:9;1591:29;:::i;:::-;1581:39;1667:2;1652:18;;;;1639:32;;-1:-1:-1;;;1423:254:1:o;1874:328::-;1951:6;1959;1967;2020:2;2008:9;1999:7;1995:23;1991:32;1988:52;;;2036:1;2033;2026:12;1988:52;2059:29;2078:9;2059:29;:::i;:::-;2049:39;;2107:38;2141:2;2130:9;2126:18;2107:38;:::i;:::-;2097:48;;2192:2;2181:9;2177:18;2164:32;2154:42;;1874:328;;;;;:::o;2396:127::-;2457:10;2452:3;2448:20;2445:1;2438:31;2488:4;2485:1;2478:15;2512:4;2509:1;2502:15;2528:719;2571:5;2624:3;2617:4;2609:6;2605:17;2601:27;2591:55;;2642:1;2639;2632:12;2591:55;2678:6;2665:20;2704:18;2741:2;2737;2734:10;2731:36;;;2747:18;;:::i;:::-;2822:2;2816:9;2790:2;2876:13;;-1:-1:-1;;2872:22:1;;;2896:2;2868:31;2864:40;2852:53;;;2920:18;;;2940:22;;;2917:46;2914:72;;;2966:18;;:::i;:::-;3006:10;3002:2;2995:22;3041:2;3033:6;3026:18;3087:3;3080:4;3075:2;3067:6;3063:15;3059:26;3056:35;3053:55;;;3104:1;3101;3094:12;3053:55;3168:2;3161:4;3153:6;3149:17;3142:4;3134:6;3130:17;3117:54;3215:1;3208:4;3203:2;3195:6;3191:15;3187:26;3180:37;3235:6;3226:15;;;;;;2528:719;;;;:::o;3252:543::-;3340:6;3348;3401:2;3389:9;3380:7;3376:23;3372:32;3369:52;;;3417:1;3414;3407:12;3369:52;3457:9;3444:23;3486:18;3527:2;3519:6;3516:14;3513:34;;;3543:1;3540;3533:12;3513:34;3566:50;3608:7;3599:6;3588:9;3584:22;3566:50;:::i;:::-;3556:60;;3669:2;3658:9;3654:18;3641:32;3625:48;;3698:2;3688:8;3685:16;3682:36;;;3714:1;3711;3704:12;3682:36;;3737:52;3781:7;3770:8;3759:9;3755:24;3737:52;:::i;:::-;3727:62;;;3252:543;;;;;:::o;3800:347::-;3865:6;3873;3926:2;3914:9;3905:7;3901:23;3897:32;3894:52;;;3942:1;3939;3932:12;3894:52;3965:29;3984:9;3965:29;:::i;:::-;3955:39;;4044:2;4033:9;4029:18;4016:32;4091:5;4084:13;4077:21;4070:5;4067:32;4057:60;;4113:1;4110;4103:12;4057:60;4136:5;4126:15;;;3800:347;;;;;:::o;4152:186::-;4211:6;4264:2;4252:9;4243:7;4239:23;4235:32;4232:52;;;4280:1;4277;4270:12;4232:52;4303:29;4322:9;4303:29;:::i;4343:632::-;4514:2;4566:21;;;4636:13;;4539:18;;;4658:22;;;4485:4;;4514:2;4737:15;;;;4711:2;4696:18;;;4485:4;4780:169;4794:6;4791:1;4788:13;4780:169;;;4855:13;;4843:26;;4924:15;;;;4889:12;;;;4816:1;4809:9;4780:169;;;-1:-1:-1;4966:3:1;;4343:632;-1:-1:-1;;;;;;4343:632:1:o;4980:808::-;5077:6;5085;5093;5101;5109;5162:3;5150:9;5141:7;5137:23;5133:33;5130:53;;;5179:1;5176;5169:12;5130:53;5202:29;5221:9;5202:29;:::i;:::-;5192:39;;5250:38;5284:2;5273:9;5269:18;5250:38;:::i;:::-;5240:48;;5335:2;5324:9;5320:18;5307:32;5297:42;;5390:2;5379:9;5375:18;5362:32;5413:18;5454:2;5446:6;5443:14;5440:34;;;5470:1;5467;5460:12;5440:34;5508:6;5497:9;5493:22;5483:32;;5553:7;5546:4;5542:2;5538:13;5534:27;5524:55;;5575:1;5572;5565:12;5524:55;5615:2;5602:16;5641:2;5633:6;5630:14;5627:34;;;5657:1;5654;5647:12;5627:34;5702:7;5697:2;5688:6;5684:2;5680:15;5676:24;5673:37;5670:57;;;5723:1;5720;5713:12;5670:57;4980:808;;;;-1:-1:-1;4980:808:1;;-1:-1:-1;5754:2:1;5746:11;;5776:6;4980:808;-1:-1:-1;;;4980:808:1:o;5793:260::-;5861:6;5869;5922:2;5910:9;5901:7;5897:23;5893:32;5890:52;;;5938:1;5935;5928:12;5890:52;5961:29;5980:9;5961:29;:::i;:::-;5951:39;;6009:38;6043:2;6032:9;6028:18;6009:38;:::i;:::-;5999:48;;5793:260;;;;;:::o;6058:322::-;6127:6;6180:2;6168:9;6159:7;6155:23;6151:32;6148:52;;;6196:1;6193;6186:12;6148:52;6236:9;6223:23;6269:18;6261:6;6258:30;6255:50;;;6301:1;6298;6291:12;6255:50;6324;6366:7;6357:6;6346:9;6342:22;6324:50;:::i;:::-;6314:60;6058:322;-1:-1:-1;;;;6058:322:1:o;6385:380::-;6464:1;6460:12;;;;6507;;;6528:61;;6582:4;6574:6;6570:17;6560:27;;6528:61;6635:2;6627:6;6624:14;6604:18;6601:38;6598:161;;6681:10;6676:3;6672:20;6669:1;6662:31;6716:4;6713:1;6706:15;6744:4;6741:1;6734:15;6598:161;;6385:380;;;:::o;6770:127::-;6831:10;6826:3;6822:20;6819:1;6812:31;6862:4;6859:1;6852:15;6886:4;6883:1;6876:15;6902:128;6969:9;;;6990:11;;;6987:37;;;7004:18;;:::i;7035:127::-;7096:10;7091:3;7087:20;7084:1;7077:31;7127:4;7124:1;7117:15;7151:4;7148:1;7141:15;7167:127;7228:10;7223:3;7219:20;7216:1;7209:31;7259:4;7256:1;7249:15;7283:4;7280:1;7273:15;7859:290;7928:6;7981:2;7969:9;7960:7;7956:23;7952:32;7949:52;;;7997:1;7994;7987:12;7949:52;8023:16;;-1:-1:-1;;;;;;8068:32:1;;8058:43;;8048:71;;8115:1;8112;8105:12;8280:545;8382:2;8377:3;8374:11;8371:448;;;8418:1;8443:5;8439:2;8432:17;8488:4;8484:2;8474:19;8558:2;8546:10;8542:19;8539:1;8535:27;8529:4;8525:38;8594:4;8582:10;8579:20;8576:47;;;-1:-1:-1;8617:4:1;8576:47;8672:2;8667:3;8663:12;8660:1;8656:20;8650:4;8646:31;8636:41;;8727:82;8745:2;8738:5;8735:13;8727:82;;;8790:17;;;8771:1;8760:13;8727:82;;;8731:3;;;8280:545;;;:::o;9001:1352::-;9127:3;9121:10;9154:18;9146:6;9143:30;9140:56;;;9176:18;;:::i;:::-;9205:97;9295:6;9255:38;9287:4;9281:11;9255:38;:::i;:::-;9249:4;9205:97;:::i;:::-;9357:4;;9421:2;9410:14;;9438:1;9433:663;;;;10140:1;10157:6;10154:89;;;-1:-1:-1;10209:19:1;;;10203:26;10154:89;-1:-1:-1;;8958:1:1;8954:11;;;8950:24;8946:29;8936:40;8982:1;8978:11;;;8933:57;10256:81;;9403:944;;9433:663;8227:1;8220:14;;;8264:4;8251:18;;-1:-1:-1;;9469:20:1;;;9587:236;9601:7;9598:1;9595:14;9587:236;;;9690:19;;;9684:26;9669:42;;9782:27;;;;9750:1;9738:14;;;;9617:19;;9587:236;;;9591:3;9851:6;9842:7;9839:19;9836:201;;;9912:19;;;9906:26;-1:-1:-1;;9995:1:1;9991:14;;;10007:3;9987:24;9983:37;9979:42;9964:58;9949:74;;9836:201;-1:-1:-1;;;;;10083:1:1;10067:14;;;10063:22;10050:36;;-1:-1:-1;9001:1352:1:o;10358:662::-;-1:-1:-1;;;;;10637:15:1;;;10619:34;;10689:15;;10684:2;10669:18;;10662:43;10736:2;10721:18;;10714:34;;;10784:3;10779:2;10764:18;;10757:31;;;10804:19;;10797:35;;;10562:4;10825:6;10875;10599:3;10854:19;;10841:49;10940:1;10934:3;10925:6;10914:9;10910:22;10906:32;10899:43;11010:3;11003:2;10999:7;10994:2;10986:6;10982:15;10978:29;10967:9;10963:45;10959:55;10951:63;;10358:662;;;;;;;;:::o;11025:1020::-;11201:3;11230:1;11263:6;11257:13;11293:36;11319:9;11293:36;:::i;:::-;11348:1;11365:18;;;11392:133;;;;11539:1;11534:356;;;;11358:532;;11392:133;-1:-1:-1;;11425:24:1;;11413:37;;11498:14;;11491:22;11479:35;;11470:45;;;-1:-1:-1;11392:133:1;;11534:356;11565:6;11562:1;11555:17;11595:4;11640:2;11637:1;11627:16;11665:1;11679:165;11693:6;11690:1;11687:13;11679:165;;;11771:14;;11758:11;;;11751:35;11814:16;;;;11708:10;;11679:165;;;11683:3;;;11873:6;11868:3;11864:16;11857:23;;11358:532;;;;;11921:6;11915:13;11937:68;11996:8;11991:3;11984:4;11976:6;11972:17;11937:68;:::i;:::-;12021:18;;11025:1020;-1:-1:-1;;;;11025:1020:1:o;12050:445::-;12271:3;12309:6;12303:13;12325:66;12384:6;12379:3;12372:4;12364:6;12360:17;12325:66;:::i;:::-;-1:-1:-1;;;12413:16:1;;12438:22;;;-1:-1:-1;12487:1:1;12476:13;;12050:445;-1:-1:-1;12050:445:1:o;12500:422::-;12589:1;12632:5;12589:1;12646:270;12667:7;12657:8;12654:21;12646:270;;;12726:4;12722:1;12718:6;12714:17;12708:4;12705:27;12702:53;;;12735:18;;:::i;:::-;12785:7;12775:8;12771:22;12768:55;;;12805:16;;;;12768:55;12884:22;;;;12844:15;;;;12646:270;;;12650:3;12500:422;;;;;:::o;12927:806::-;12976:5;13006:8;12996:80;;-1:-1:-1;13047:1:1;13061:5;;12996:80;13095:4;13085:76;;-1:-1:-1;13132:1:1;13146:5;;13085:76;13177:4;13195:1;13190:59;;;;13263:1;13258:130;;;;13170:218;;13190:59;13220:1;13211:10;;13234:5;;;13258:130;13295:3;13285:8;13282:17;13279:43;;;13302:18;;:::i;:::-;-1:-1:-1;;13358:1:1;13344:16;;13373:5;;13170:218;;13472:2;13462:8;13459:16;13453:3;13447:4;13444:13;13440:36;13434:2;13424:8;13421:16;13416:2;13410:4;13407:12;13403:35;13400:77;13397:159;;;-1:-1:-1;13509:19:1;;;13541:5;;13397:159;13588:34;13613:8;13607:4;13588:34;:::i;:::-;13658:6;13654:1;13650:6;13646:19;13637:7;13634:32;13631:58;;;13669:18;;:::i;:::-;13707:20;;12927:806;-1:-1:-1;;;12927:806:1:o;13738:140::-;13796:5;13825:47;13866:4;13856:8;13852:19;13846:4;13825:47;:::i;13883:127::-;13944:10;13939:3;13935:20;13932:1;13925:31;13975:4;13972:1;13965:15;13999:4;13996:1;13989:15;14015:120;14055:1;14081;14071:35;;14086:18;;:::i;:::-;-1:-1:-1;14120:9:1;;14015:120::o;14140:135::-;14179:3;14200:17;;;14197:43;;14220:18;;:::i;:::-;-1:-1:-1;14267:1:1;14256:13;;14140:135::o;14644:112::-;14676:1;14702;14692:35;;14707:18;;:::i;:::-;-1:-1:-1;14741:9:1;;14644:112::o

Swarm Source

ipfs://6aace795dd1f9d6505e6d312258ae3c3d72aeb4a325f8f83b4f9b6f465f52940
Loading...
Loading
Loading...
Loading
[ Download: CSV Export  ]

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