ETH Price: $3,457.20 (-1.42%)
Gas: 4 Gwei

Pepe404 (PEPE)
 

Overview

TokenID

2799

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:
Pepe404

Compiler Version
v0.8.24+commit.e11b9ed9

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, Unlicense license

Contract Source Code (Solidity)

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

//SPDX-License-Identifier: UNLICENSED

//Twitter: https://twitter.com/pepe404_erc
//Telegram: https://t.me/Pepe404_erc

// ░▒▓███████▓▒░░▒▓████████▓▒░▒▓███████▓▒░░▒▓████████▓▒░▒▓█▓▒░░▒▓█▓▒░▒▓████████▓▒░▒▓█▓▒░░▒▓█▓▒░ 
// ░▒▓█▓▒░░▒▓█▓▒░▒▓█▓▒░      ░▒▓█▓▒░░▒▓█▓▒░▒▓█▓▒░      ░▒▓█▓▒░░▒▓█▓▒░▒▓█▓▒░░▒▓█▓▒░▒▓█▓▒░░▒▓█▓▒░ 
// ░▒▓█▓▒░░▒▓█▓▒░▒▓█▓▒░      ░▒▓█▓▒░░▒▓█▓▒░▒▓█▓▒░      ░▒▓█▓▒░░▒▓█▓▒░▒▓█▓▒░░▒▓█▓▒░▒▓█▓▒░░▒▓█▓▒░ 
// ░▒▓███████▓▒░░▒▓██████▓▒░ ░▒▓███████▓▒░░▒▓██████▓▒░ ░▒▓████████▓▒░▒▓█▓▒░░▒▓█▓▒░▒▓████████▓▒░ 
// ░▒▓█▓▒░      ░▒▓█▓▒░      ░▒▓█▓▒░      ░▒▓█▓▒░             ░▒▓█▓▒░▒▓█▓▒░░▒▓█▓▒░      ░▒▓█▓▒░ 
// ░▒▓█▓▒░      ░▒▓█▓▒░      ░▒▓█▓▒░      ░▒▓█▓▒░             ░▒▓█▓▒░▒▓█▓▒░░▒▓█▓▒░      ░▒▓█▓▒░ 
// ░▒▓█▓▒░      ░▒▓████████▓▒░▒▓█▓▒░      ░▒▓████████▓▒░      ░▒▓█▓▒░▒▓████████▓▒░      ░▒▓█▓▒░ 
pragma solidity ^0.8.0;

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

abstract contract ERC404 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();

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

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

    // Mappings
    /// @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;
        totalSupply = _totalNativeSupply * (10 ** decimals);
    }

    /// @notice Initialization function to set pairs / etc
    ///         saving gas by avoiding mint / burn on unnecessary targets
    function setWhitelist(address target, bool state) public onlyOwner {
        whitelist[target] = state;
    }

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

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

    /// @notice tokenURI must be implemented by child contract
    function tokenURI(uint256 id) public view virtual returns (string memory);

    /// @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 virtual returns (bool) {
        if (amountOrId <= minted && 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 virtual {
        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 virtual {
        if (amountOrId <= minted) {
            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 virtual 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 virtual {
        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 virtual {
        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 _mint(address to) internal virtual {
        if (to == address(0)) {
            revert InvalidRecipient();
        }

        unchecked {
            minted++;
        }

        uint256 id = minted;

        if (_ownerOf[id] != address(0)) {
            revert AlreadyExists();
        }

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

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

    function _burn(address from) internal virtual {
        if (from == address(0)) {
            revert InvalidSender();
        }

        uint256 id = _owned[from][_owned[from].length - 1];
        _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
    ) internal {
        name = _name;
        symbol = _symbol;
    }
}

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;
    }
}
/**
 * @dev Standard signed math utilities missing in the Solidity language.
 */
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);
        }
    }
}

/**
 * @dev String operations.
 */
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));
    }
}

contract Pepe404 is ERC404 {
    string public dataURI;
    string public baseTokenURI;

    constructor(
        address _owner
    ) ERC404("Pepe404", "PEPE", 18, 4000, _owner) {
        balanceOf[_owner] = 4000 * 10 ** 18;
    }

    function setDataURI(string memory _dataURI) public onlyOwner {
        dataURI = _dataURI;
    }

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

    function setNameSymbol(
        string memory _name,
        string memory _symbol
    ) public onlyOwner {
        _setNameSymbol(_name, _symbol);
    }

    function tokenURI(uint256 id) public view override returns (string memory) {
        if (bytes(baseTokenURI).length > 0) {
            return string.concat(baseTokenURI, Strings.toString(id));
        } else {
            uint8 seed = uint8(bytes1(keccak256(abi.encodePacked(id))));
            string memory image;
            string memory trait;

            if (seed <= 128) {
                image = "redhat.jpg";
                trait = "Red Hat";
            } else if (seed <= 192) {
                image = "wolf.jpg";
                trait = "Wolf";
            } else if (seed <= 240) {
                image = "wizard.jpg";
                trait = "Wizard";
            } else if (seed <= 255) {
                image = "crown.jpg";
                trait = "Crown";
            }

            string memory jsonPreImage = string.concat(
                string.concat(
                    string.concat('{"name": "Pepe404 #', Strings.toString(id)),
                    '","description":"A collection of 4,000 Pepes enabled by ERC404, an experimental token standard.","external_url":"https://twitter.com/pepe404_erc","image":"'
                ),
                string.concat(dataURI, image)
            );
            string memory jsonPostImage = string.concat(
                '","attributes":[{"trait_type":"Trait","value":"',
                trait
            );
            string memory jsonPostTraits = '"}]}';

            return
                string.concat(
                    "data:application/json;utf8,",
                    string.concat(
                        string.concat(jsonPreImage, jsonPostImage),
                        jsonPostTraits
                    )
                );
        }
    }
}

Contract Security Audit

Contract ABI

[{"inputs":[{"internalType":"address","name":"_owner","type":"address"}],"stateMutability":"nonpayable","type":"constructor"},{"inputs":[],"name":"AlreadyExists","type":"error"},{"inputs":[],"name":"InvalidOwner","type":"error"},{"inputs":[],"name":"InvalidRecipient","type":"error"},{"inputs":[],"name":"InvalidSender","type":"error"},{"inputs":[],"name":"NotFound","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":"dataURI","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"","type":"uint256"}],"name":"getApproved","outputs":[{"internalType":"address","name":"","type":"address"}],"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":"minted","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":"_dataURI","type":"string"}],"name":"setDataURI","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":"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"}]

60c060405234801562000010575f80fd5b506040516200239c3803806200239c833981016040819052620000339162000157565b604080518082018252600781526614195c194d0c0d60ca1b602080830191909152825180840190935260048352635045504560e01b90830152906012610fa084806001600160a01b0381166200009c576040516349e27cff60e01b815260040160405180910390fd5b5f80546001600160a01b0319166001600160a01b03831690811782556040519091907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a3506001620000f2868262000224565b50600262000101858262000224565b5060ff831660808190526200011890600a620003ff565b6200012490836200040f565b60a0525050506001600160a01b039092165f90815260046020526040902068d8d726b7177a800000905550620004299050565b5f6020828403121562000168575f80fd5b81516001600160a01b03811681146200017f575f80fd5b9392505050565b634e487b7160e01b5f52604160045260245ffd5b600181811c90821680620001af57607f821691505b602082108103620001ce57634e487b7160e01b5f52602260045260245ffd5b50919050565b601f8211156200021f57805f5260205f20601f840160051c81016020851015620001fb5750805b601f840160051c820191505b818110156200021c575f815560010162000207565b50505b505050565b81516001600160401b0381111562000240576200024062000186565b62000258816200025184546200019a565b84620001d4565b602080601f8311600181146200028e575f8415620002765750858301515b5f19600386901b1c1916600185901b178555620002e8565b5f85815260208120601f198616915b82811015620002be578886015182559484019460019091019084016200029d565b5085821015620002dc57878501515f19600388901b60f8161c191681555b505060018460011b0185555b505050505050565b634e487b7160e01b5f52601160045260245ffd5b600181815b808511156200034457815f1904821115620003285762000328620002f0565b808516156200033657918102915b93841c939080029062000309565b509250929050565b5f826200035c57506001620003f9565b816200036a57505f620003f9565b81600181146200038357600281146200038e57620003ae565b6001915050620003f9565b60ff841115620003a257620003a2620002f0565b50506001821b620003f9565b5060208310610133831016604e8410600b8410161715620003d3575081810a620003f9565b620003df838362000304565b805f1904821115620003f557620003f5620002f0565b0290505b92915050565b5f6200017f60ff8416836200034c565b8082028115828204841417620003f957620003f9620002f0565b60805160a051611f4a620004525f395f61022b01525f818161029001526111000152611f4a5ff3fe608060405234801561000f575f80fd5b50600436106101a1575f3560e01c806370a08231116100f3578063c87b56dd11610093578063e0df5b6f1161006e578063e0df5b6f146103f2578063e985e9c514610405578063f28ca1dd14610432578063f2fde38b1461043a575f80fd5b8063c87b56dd146103ad578063d547cfb7146103c0578063dd62ed3e146103c8575f80fd5b80639b19251a116100ce5780639b19251a14610352578063a22cb46514610374578063a9059cbb14610387578063b88d4fde1461039a575f80fd5b806370a08231146103195780638da5cb5b1461033857806395d89b411461034a575f80fd5b80632b9689581161015e5780634f02c420116101395780634f02c420146102d7578063504334c2146102e057806353d6fd59146102f35780636352211e14610306575f80fd5b80632b96895814610283578063313ce5671461028b57806342842e0e146102c4575f80fd5b806306fdde03146101a5578063081812fc146101c3578063095ea7b31461020357806318160ddd1461022657806318d217c31461025b57806323b872dd14610270575b5f80fd5b6101ad61044d565b6040516101ba919061169b565b60405180910390f35b6101eb6101d13660046116cd565b60066020525f90815260409020546001600160a01b031681565b6040516001600160a01b0390911681526020016101ba565b6102166102113660046116fa565b6104d9565b60405190151581526020016101ba565b61024d7f000000000000000000000000000000000000000000000000000000000000000081565b6040519081526020016101ba565b61026e6102693660046117bf565b610624565b005b61026e61027e3660046117f9565b61065d565b61026e6109d9565b6102b27f000000000000000000000000000000000000000000000000000000000000000081565b60405160ff90911681526020016101ba565b61026e6102d23660046117f9565b610a3d565b61024d60035481565b61026e6102ee366004611832565b610b0e565b61026e610301366004611892565b610b41565b6101eb6103143660046116cd565b610b94565b61024d6103273660046118cb565b60046020525f908152604090205481565b5f546101eb906001600160a01b031681565b6101ad610bce565b6102166103603660046118cb565b600b6020525f908152604090205460ff1681565b61026e610382366004611892565b610bdb565b6102166103953660046116fa565b610c46565b61026e6103a83660046118e4565b610c59565b6101ad6103bb3660046116cd565b610d19565b6101ad611011565b61024d6103d6366004611977565b600560209081525f928352604080842090915290825290205481565b61026e6104003660046117bf565b61101e565b610216610413366004611977565b600760209081525f928352604080842090915290825290205460ff1681565b6101ad611053565b61026e6104483660046118cb565b611060565b6001805461045a906119a8565b80601f0160208091040260200160405190810160405280929190818152602001828054610486906119a8565b80156104d15780601f106104a8576101008083540402835291602001916104d1565b820191905f5260205f20905b8154815290600101906020018083116104b457829003601f168201915b505050505081565b5f60035482111580156104eb57505f82115b156105bf575f828152600860205260409020546001600160a01b031633811480159061053a57506001600160a01b0381165f90815260076020908152604080832033845290915290205460ff16155b15610557576040516282b42960e81b815260040160405180910390fd5b5f8381526006602090815260409182902080546001600160a01b0319166001600160a01b038881169182179092559251868152908416917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a35061061a565b335f8181526005602090815260408083206001600160a01b03881680855290835292819020869055518581529192917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a35b5060015b92915050565b5f546001600160a01b0316331461064d576040516282b42960e81b815260040160405180910390fd5b600c6106598282611a24565b5050565b600354811161096d575f818152600860205260409020546001600160a01b0384811691161461069f57604051636edaef2f60e11b815260040160405180910390fd5b6001600160a01b0382166106c657604051634e46966960e11b815260040160405180910390fd5b336001600160a01b0384161480159061070257506001600160a01b0383165f90815260076020908152604080832033845290915290205460ff16155b801561072457505f818152600660205260409020546001600160a01b03163314155b15610741576040516282b42960e81b815260040160405180910390fd5b6107496110fa565b6001600160a01b0384165f9081526004602052604081208054909190610770908490611af8565b9091555061077e90506110fa565b6001600160a01b038084165f81815260046020908152604080832080549096019095558582526008815284822080546001600160a01b0319908116909417905560068152848220805490931690925591861682526009905290812080546107e790600190611af8565b815481106107f7576107f7611b0b565b5f9182526020808320909101546001600160a01b0387168352600982526040808420868552600a9093529092205481549293508392811061083a5761083a611b0b565b5f9182526020808320909101929092556001600160a01b038616815260099091526040902080548061086e5761086e611b1f565b5f828152602080822083015f19908101839055909201909255838252600a8152604080832054848452818420556001600160a01b0386168084526009835290832080546001818101835582865293852001869055925290546108d09190611af8565b5f838152600a602052604080822092909255905183916001600160a01b0380871692908816917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef91a4826001600160a01b0316846001600160a01b03167fe59fdd36d0d223c0c7d996db7ad796880f45e1936cb0bb7ac102e7082e0314876109566110fa565b60405190815260200160405180910390a350505050565b6001600160a01b0383165f9081526005602090815260408083203384529091529020545f1981146109c6576109a28282611af8565b6001600160a01b0385165f9081526005602090815260408083203384529091529020555b6109d184848461112b565b50505b505050565b5f546001600160a01b03163314610a02576040516282b42960e81b815260040160405180910390fd5b5f80546001600160a01b031916815560405133907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3565b610a4883838361065d565b6001600160a01b0382163b15801590610af05750604051630a85bd0160e11b8082523360048301526001600160a01b03858116602484015260448301849052608060648401525f608484015290919084169063150b7a029060a4016020604051808303815f875af1158015610abf573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610ae39190611b33565b6001600160e01b03191614155b156109d457604051633da6393160e01b815260040160405180910390fd5b5f546001600160a01b03163314610b37576040516282b42960e81b815260040160405180910390fd5b61065982826112d0565b5f546001600160a01b03163314610b6a576040516282b42960e81b815260040160405180910390fd5b6001600160a01b03919091165f908152600b60205260409020805460ff1916911515919091179055565b5f818152600860205260409020546001600160a01b031680610bc95760405163c5723b5160e01b815260040160405180910390fd5b919050565b6002805461045a906119a8565b335f8181526007602090815260408083206001600160a01b03871680855290835292819020805460ff191686151590811790915590519081529192917f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c31910160405180910390a35050565b5f610c5233848461112b565b9392505050565b610c6485858561065d565b6001600160a01b0384163b15801590610cfb5750604051630a85bd0160e11b808252906001600160a01b0386169063150b7a0290610cae9033908a90899089908990600401611b5a565b6020604051808303815f875af1158015610cca573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610cee9190611b33565b6001600160e01b03191614155b156109d157604051633da6393160e01b815260040160405180910390fd5b60605f600d8054610d29906119a8565b90501115610d6357600d610d3c836112e9565b604051602001610d4d929190611bac565b6040516020818303038152906040529050919050565b5f82604051602001610d7791815260200190565b6040516020818303038152906040528051906020012060f81c905060608060808360ff1611610dec576040518060400160405280600a8152602001697265646861742e6a706760b01b8152509150604051806040016040528060078152602001661499590812185d60ca1b8152509050610ee4565b60c08360ff1611610e3e5760405180604001604052806008815260200167776f6c662e6a706760c01b8152509150604051806040016040528060048152602001632bb7b63360e11b8152509050610ee4565b60f08360ff1611610e94576040518060400160405280600a81526020016977697a6172642e6a706760b01b81525091506040518060400160405280600681526020016515da5e985c9960d21b8152509050610ee4565b60ff8360ff1611610ee4576040518060400160405280600981526020016863726f776e2e6a706760b81b81525091506040518060400160405280600581526020016421b937bbb760d91b81525090505b5f610eee866112e9565b604051602001610efe9190611c2f565b60408051601f1981840301815290829052610f1b91602001611c6a565b604051602081830303815290604052600c84604051602001610f3e929190611bac565b60408051601f1981840301815290829052610f5c9291602001611d42565b60405160208183030381529060405290505f82604051602001610f7f9190611d67565b60408051601f1981840301815282820182526004835263227d5d7d60e01b6020848101919091529151909350610fb9918591859101611d42565b60408051601f1981840301815290829052610fd8918390602001611d42565b60408051601f1981840301815290829052610ff591602001611dc3565b6040516020818303038152906040529650505050505050919050565b600d805461045a906119a8565b5f546001600160a01b03163314611047576040516282b42960e81b815260040160405180910390fd5b600d6106598282611a24565b600c805461045a906119a8565b5f546001600160a01b03163314611089576040516282b42960e81b815260040160405180910390fd5b6001600160a01b0381166110b0576040516349e27cff60e01b815260040160405180910390fd5b5f80546001600160a01b0319166001600160a01b0383169081178255604051909133917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a350565b5f6111267f0000000000000000000000000000000000000000000000000000000000000000600a611ee7565b905090565b5f806111356110fa565b6001600160a01b038087165f818152600460205260408082208054948a16835290822054928252939450919290918691906111708386611af8565b90915550506001600160a01b038087165f90815260046020908152604080832080548a019055928a168252600b9052205460ff166111ff576001600160a01b0387165f908152600460205260408120546111cb908590611ef5565b6111d58585611ef5565b6111df9190611af8565b90505f5b818110156111fc576111f489611379565b6001016111e3565b50505b6001600160a01b0386165f908152600b602052604090205460ff16611276575f6112298483611ef5565b6001600160a01b0388165f9081526004602052604090205461124c908690611ef5565b6112569190611af8565b90505f5b818110156112735761126b8861149a565b60010161125a565b50505b856001600160a01b0316876001600160a01b03167fe59fdd36d0d223c0c7d996db7ad796880f45e1936cb0bb7ac102e7082e031487876040516112bb91815260200190565b60405180910390a35060019695505050505050565b60016112dc8382611a24565b5060026109d48282611a24565b60605f6112f5836115a2565b60010190505f8167ffffffffffffffff81111561131457611314611722565b6040519080825280601f01601f19166020018201604052801561133e576020820181803683370190505b5090508181016020015b5f19016f181899199a1a9b1b9c1cb0b131b232b360811b600a86061a8153600a850494508461134857509392505050565b6001600160a01b0381166113a057604051636edaef2f60e11b815260040160405180910390fd5b6001600160a01b0381165f90815260096020526040812080546113c590600190611af8565b815481106113d5576113d5611b0b565b905f5260205f200154905060095f836001600160a01b03166001600160a01b031681526020019081526020015f2080548061141257611412611b1f565b5f828152602080822083015f19908101839055909201909255828252600a815260408083208390556008825280832080546001600160a01b031990811690915560069092528083208054909216909155518291906001600160a01b038516907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef908390a45050565b6001600160a01b0381166114c157604051634e46966960e11b815260040160405180910390fd5b60038054600101908190555f818152600860205260409020546001600160a01b0316156115015760405163119b4fd360e11b815260040160405180910390fd5b5f81815260086020908152604080832080546001600160a01b0319166001600160a01b0387169081179091558084526009835290832080546001818101835582865293852001859055925290546115589190611af8565b5f828152600a602052604080822092909255905182916001600160a01b038516917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef908290a45050565b5f8072184f03e93ff9f4daa797ed6e38ed64bf6a1f0160401b83106115e05772184f03e93ff9f4daa797ed6e38ed64bf6a1f0160401b830492506040015b6d04ee2d6d415b85acef8100000000831061160c576d04ee2d6d415b85acef8100000000830492506020015b662386f26fc10000831061162a57662386f26fc10000830492506010015b6305f5e1008310611642576305f5e100830492506008015b612710831061165657612710830492506004015b60648310611668576064830492506002015b600a831061061e5760010192915050565b5f5b8381101561169357818101518382015260200161167b565b50505f910152565b602081525f82518060208401526116b9816040850160208701611679565b601f01601f19169190910160400192915050565b5f602082840312156116dd575f80fd5b5035919050565b80356001600160a01b0381168114610bc9575f80fd5b5f806040838503121561170b575f80fd5b611714836116e4565b946020939093013593505050565b634e487b7160e01b5f52604160045260245ffd5b5f82601f830112611745575f80fd5b813567ffffffffffffffff8082111561176057611760611722565b604051601f8301601f19908116603f0116810190828211818310171561178857611788611722565b816040528381528660208588010111156117a0575f80fd5b836020870160208301375f602085830101528094505050505092915050565b5f602082840312156117cf575f80fd5b813567ffffffffffffffff8111156117e5575f80fd5b6117f184828501611736565b949350505050565b5f805f6060848603121561180b575f80fd5b611814846116e4565b9250611822602085016116e4565b9150604084013590509250925092565b5f8060408385031215611843575f80fd5b823567ffffffffffffffff8082111561185a575f80fd5b61186686838701611736565b9350602085013591508082111561187b575f80fd5b5061188885828601611736565b9150509250929050565b5f80604083850312156118a3575f80fd5b6118ac836116e4565b9150602083013580151581146118c0575f80fd5b809150509250929050565b5f602082840312156118db575f80fd5b610c52826116e4565b5f805f805f608086880312156118f8575f80fd5b611901866116e4565b945061190f602087016116e4565b935060408601359250606086013567ffffffffffffffff80821115611932575f80fd5b818801915088601f830112611945575f80fd5b813581811115611953575f80fd5b896020828501011115611964575f80fd5b9699959850939650602001949392505050565b5f8060408385031215611988575f80fd5b611991836116e4565b915061199f602084016116e4565b90509250929050565b600181811c908216806119bc57607f821691505b6020821081036119da57634e487b7160e01b5f52602260045260245ffd5b50919050565b601f8211156109d457805f5260205f20601f840160051c81016020851015611a055750805b601f840160051c820191505b818110156109d1575f8155600101611a11565b815167ffffffffffffffff811115611a3e57611a3e611722565b611a5281611a4c84546119a8565b846119e0565b602080601f831160018114611a85575f8415611a6e5750858301515b5f19600386901b1c1916600185901b178555611adc565b5f85815260208120601f198616915b82811015611ab357888601518255948401946001909101908401611a94565b5085821015611ad057878501515f19600388901b60f8161c191681555b505060018460011b0185555b505050505050565b634e487b7160e01b5f52601160045260245ffd5b8181038181111561061e5761061e611ae4565b634e487b7160e01b5f52603260045260245ffd5b634e487b7160e01b5f52603160045260245ffd5b5f60208284031215611b43575f80fd5b81516001600160e01b031981168114610c52575f80fd5b6001600160a01b038681168252851660208201526040810184905260806060820181905281018290525f828460a08401375f60a0848401015260a0601f19601f85011683010190509695505050505050565b5f808454611bb9816119a8565b60018281168015611bd15760018114611be657611c12565b60ff1984168752821515830287019450611c12565b885f526020805f205f5b85811015611c095781548a820152908401908201611bf0565b50505082870194505b505050508351611c26818360208801611679565b01949350505050565b727b226e616d65223a202250657065343034202360681b815281515f90611c5d816013850160208701611679565b9190910160130192915050565b5f8251611c7b818460208701611679565b7f222c226465736372697074696f6e223a224120636f6c6c656374696f6e206f669201918252507f20342c30303020506570657320656e61626c6564206279204552433430342c2060208201527f616e206578706572696d656e74616c20746f6b656e207374616e646172642e2260408201527f2c2265787465726e616c5f75726c223a2268747470733a2f2f7477697474657260608201527f2e636f6d2f706570653430345f657263222c22696d616765223a2200000000006080820152609b01919050565b5f8351611d53818460208801611679565b835190830190611c26818360208801611679565b7f222c2261747472696275746573223a5b7b2274726169745f74797065223a225481526e3930b4ba1116113b30b63ab2911d1160891b60208201525f8251611db681602f850160208701611679565b91909101602f0192915050565b7f646174613a6170706c69636174696f6e2f6a736f6e3b757466382c000000000081525f8251611dfa81601b850160208701611679565b91909101601b0192915050565b600181815b80851115611e4157815f1904821115611e2757611e27611ae4565b80851615611e3457918102915b93841c9390800290611e0c565b509250929050565b5f82611e575750600161061e565b81611e6357505f61061e565b8160018114611e795760028114611e8357611e9f565b600191505061061e565b60ff841115611e9457611e94611ae4565b50506001821b61061e565b5060208310610133831016604e8410600b8410161715611ec2575081810a61061e565b611ecc8383611e07565b805f1904821115611edf57611edf611ae4565b029392505050565b5f610c5260ff841683611e49565b5f82611f0f57634e487b7160e01b5f52601260045260245ffd5b50049056fea26469706673582212207c76284d2370ff0344de3bd1d95984419cd8b3718b2212484a16c9d44946709864736f6c63430008180033000000000000000000000000a71b5f53c3a18d5df819884e3c51201327f7a545

Deployed Bytecode

0x608060405234801561000f575f80fd5b50600436106101a1575f3560e01c806370a08231116100f3578063c87b56dd11610093578063e0df5b6f1161006e578063e0df5b6f146103f2578063e985e9c514610405578063f28ca1dd14610432578063f2fde38b1461043a575f80fd5b8063c87b56dd146103ad578063d547cfb7146103c0578063dd62ed3e146103c8575f80fd5b80639b19251a116100ce5780639b19251a14610352578063a22cb46514610374578063a9059cbb14610387578063b88d4fde1461039a575f80fd5b806370a08231146103195780638da5cb5b1461033857806395d89b411461034a575f80fd5b80632b9689581161015e5780634f02c420116101395780634f02c420146102d7578063504334c2146102e057806353d6fd59146102f35780636352211e14610306575f80fd5b80632b96895814610283578063313ce5671461028b57806342842e0e146102c4575f80fd5b806306fdde03146101a5578063081812fc146101c3578063095ea7b31461020357806318160ddd1461022657806318d217c31461025b57806323b872dd14610270575b5f80fd5b6101ad61044d565b6040516101ba919061169b565b60405180910390f35b6101eb6101d13660046116cd565b60066020525f90815260409020546001600160a01b031681565b6040516001600160a01b0390911681526020016101ba565b6102166102113660046116fa565b6104d9565b60405190151581526020016101ba565b61024d7f0000000000000000000000000000000000000000000000d8d726b7177a80000081565b6040519081526020016101ba565b61026e6102693660046117bf565b610624565b005b61026e61027e3660046117f9565b61065d565b61026e6109d9565b6102b27f000000000000000000000000000000000000000000000000000000000000001281565b60405160ff90911681526020016101ba565b61026e6102d23660046117f9565b610a3d565b61024d60035481565b61026e6102ee366004611832565b610b0e565b61026e610301366004611892565b610b41565b6101eb6103143660046116cd565b610b94565b61024d6103273660046118cb565b60046020525f908152604090205481565b5f546101eb906001600160a01b031681565b6101ad610bce565b6102166103603660046118cb565b600b6020525f908152604090205460ff1681565b61026e610382366004611892565b610bdb565b6102166103953660046116fa565b610c46565b61026e6103a83660046118e4565b610c59565b6101ad6103bb3660046116cd565b610d19565b6101ad611011565b61024d6103d6366004611977565b600560209081525f928352604080842090915290825290205481565b61026e6104003660046117bf565b61101e565b610216610413366004611977565b600760209081525f928352604080842090915290825290205460ff1681565b6101ad611053565b61026e6104483660046118cb565b611060565b6001805461045a906119a8565b80601f0160208091040260200160405190810160405280929190818152602001828054610486906119a8565b80156104d15780601f106104a8576101008083540402835291602001916104d1565b820191905f5260205f20905b8154815290600101906020018083116104b457829003601f168201915b505050505081565b5f60035482111580156104eb57505f82115b156105bf575f828152600860205260409020546001600160a01b031633811480159061053a57506001600160a01b0381165f90815260076020908152604080832033845290915290205460ff16155b15610557576040516282b42960e81b815260040160405180910390fd5b5f8381526006602090815260409182902080546001600160a01b0319166001600160a01b038881169182179092559251868152908416917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a35061061a565b335f8181526005602090815260408083206001600160a01b03881680855290835292819020869055518581529192917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a35b5060015b92915050565b5f546001600160a01b0316331461064d576040516282b42960e81b815260040160405180910390fd5b600c6106598282611a24565b5050565b600354811161096d575f818152600860205260409020546001600160a01b0384811691161461069f57604051636edaef2f60e11b815260040160405180910390fd5b6001600160a01b0382166106c657604051634e46966960e11b815260040160405180910390fd5b336001600160a01b0384161480159061070257506001600160a01b0383165f90815260076020908152604080832033845290915290205460ff16155b801561072457505f818152600660205260409020546001600160a01b03163314155b15610741576040516282b42960e81b815260040160405180910390fd5b6107496110fa565b6001600160a01b0384165f9081526004602052604081208054909190610770908490611af8565b9091555061077e90506110fa565b6001600160a01b038084165f81815260046020908152604080832080549096019095558582526008815284822080546001600160a01b0319908116909417905560068152848220805490931690925591861682526009905290812080546107e790600190611af8565b815481106107f7576107f7611b0b565b5f9182526020808320909101546001600160a01b0387168352600982526040808420868552600a9093529092205481549293508392811061083a5761083a611b0b565b5f9182526020808320909101929092556001600160a01b038616815260099091526040902080548061086e5761086e611b1f565b5f828152602080822083015f19908101839055909201909255838252600a8152604080832054848452818420556001600160a01b0386168084526009835290832080546001818101835582865293852001869055925290546108d09190611af8565b5f838152600a602052604080822092909255905183916001600160a01b0380871692908816917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef91a4826001600160a01b0316846001600160a01b03167fe59fdd36d0d223c0c7d996db7ad796880f45e1936cb0bb7ac102e7082e0314876109566110fa565b60405190815260200160405180910390a350505050565b6001600160a01b0383165f9081526005602090815260408083203384529091529020545f1981146109c6576109a28282611af8565b6001600160a01b0385165f9081526005602090815260408083203384529091529020555b6109d184848461112b565b50505b505050565b5f546001600160a01b03163314610a02576040516282b42960e81b815260040160405180910390fd5b5f80546001600160a01b031916815560405133907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3565b610a4883838361065d565b6001600160a01b0382163b15801590610af05750604051630a85bd0160e11b8082523360048301526001600160a01b03858116602484015260448301849052608060648401525f608484015290919084169063150b7a029060a4016020604051808303815f875af1158015610abf573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610ae39190611b33565b6001600160e01b03191614155b156109d457604051633da6393160e01b815260040160405180910390fd5b5f546001600160a01b03163314610b37576040516282b42960e81b815260040160405180910390fd5b61065982826112d0565b5f546001600160a01b03163314610b6a576040516282b42960e81b815260040160405180910390fd5b6001600160a01b03919091165f908152600b60205260409020805460ff1916911515919091179055565b5f818152600860205260409020546001600160a01b031680610bc95760405163c5723b5160e01b815260040160405180910390fd5b919050565b6002805461045a906119a8565b335f8181526007602090815260408083206001600160a01b03871680855290835292819020805460ff191686151590811790915590519081529192917f17307eab39ab6107e8899845ad3d59bd9653f200f220920489ca2b5937696c31910160405180910390a35050565b5f610c5233848461112b565b9392505050565b610c6485858561065d565b6001600160a01b0384163b15801590610cfb5750604051630a85bd0160e11b808252906001600160a01b0386169063150b7a0290610cae9033908a90899089908990600401611b5a565b6020604051808303815f875af1158015610cca573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610cee9190611b33565b6001600160e01b03191614155b156109d157604051633da6393160e01b815260040160405180910390fd5b60605f600d8054610d29906119a8565b90501115610d6357600d610d3c836112e9565b604051602001610d4d929190611bac565b6040516020818303038152906040529050919050565b5f82604051602001610d7791815260200190565b6040516020818303038152906040528051906020012060f81c905060608060808360ff1611610dec576040518060400160405280600a8152602001697265646861742e6a706760b01b8152509150604051806040016040528060078152602001661499590812185d60ca1b8152509050610ee4565b60c08360ff1611610e3e5760405180604001604052806008815260200167776f6c662e6a706760c01b8152509150604051806040016040528060048152602001632bb7b63360e11b8152509050610ee4565b60f08360ff1611610e94576040518060400160405280600a81526020016977697a6172642e6a706760b01b81525091506040518060400160405280600681526020016515da5e985c9960d21b8152509050610ee4565b60ff8360ff1611610ee4576040518060400160405280600981526020016863726f776e2e6a706760b81b81525091506040518060400160405280600581526020016421b937bbb760d91b81525090505b5f610eee866112e9565b604051602001610efe9190611c2f565b60408051601f1981840301815290829052610f1b91602001611c6a565b604051602081830303815290604052600c84604051602001610f3e929190611bac565b60408051601f1981840301815290829052610f5c9291602001611d42565b60405160208183030381529060405290505f82604051602001610f7f9190611d67565b60408051601f1981840301815282820182526004835263227d5d7d60e01b6020848101919091529151909350610fb9918591859101611d42565b60408051601f1981840301815290829052610fd8918390602001611d42565b60408051601f1981840301815290829052610ff591602001611dc3565b6040516020818303038152906040529650505050505050919050565b600d805461045a906119a8565b5f546001600160a01b03163314611047576040516282b42960e81b815260040160405180910390fd5b600d6106598282611a24565b600c805461045a906119a8565b5f546001600160a01b03163314611089576040516282b42960e81b815260040160405180910390fd5b6001600160a01b0381166110b0576040516349e27cff60e01b815260040160405180910390fd5b5f80546001600160a01b0319166001600160a01b0383169081178255604051909133917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a350565b5f6111267f0000000000000000000000000000000000000000000000000000000000000012600a611ee7565b905090565b5f806111356110fa565b6001600160a01b038087165f818152600460205260408082208054948a16835290822054928252939450919290918691906111708386611af8565b90915550506001600160a01b038087165f90815260046020908152604080832080548a019055928a168252600b9052205460ff166111ff576001600160a01b0387165f908152600460205260408120546111cb908590611ef5565b6111d58585611ef5565b6111df9190611af8565b90505f5b818110156111fc576111f489611379565b6001016111e3565b50505b6001600160a01b0386165f908152600b602052604090205460ff16611276575f6112298483611ef5565b6001600160a01b0388165f9081526004602052604090205461124c908690611ef5565b6112569190611af8565b90505f5b818110156112735761126b8861149a565b60010161125a565b50505b856001600160a01b0316876001600160a01b03167fe59fdd36d0d223c0c7d996db7ad796880f45e1936cb0bb7ac102e7082e031487876040516112bb91815260200190565b60405180910390a35060019695505050505050565b60016112dc8382611a24565b5060026109d48282611a24565b60605f6112f5836115a2565b60010190505f8167ffffffffffffffff81111561131457611314611722565b6040519080825280601f01601f19166020018201604052801561133e576020820181803683370190505b5090508181016020015b5f19016f181899199a1a9b1b9c1cb0b131b232b360811b600a86061a8153600a850494508461134857509392505050565b6001600160a01b0381166113a057604051636edaef2f60e11b815260040160405180910390fd5b6001600160a01b0381165f90815260096020526040812080546113c590600190611af8565b815481106113d5576113d5611b0b565b905f5260205f200154905060095f836001600160a01b03166001600160a01b031681526020019081526020015f2080548061141257611412611b1f565b5f828152602080822083015f19908101839055909201909255828252600a815260408083208390556008825280832080546001600160a01b031990811690915560069092528083208054909216909155518291906001600160a01b038516907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef908390a45050565b6001600160a01b0381166114c157604051634e46966960e11b815260040160405180910390fd5b60038054600101908190555f818152600860205260409020546001600160a01b0316156115015760405163119b4fd360e11b815260040160405180910390fd5b5f81815260086020908152604080832080546001600160a01b0319166001600160a01b0387169081179091558084526009835290832080546001818101835582865293852001859055925290546115589190611af8565b5f828152600a602052604080822092909255905182916001600160a01b038516917fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef908290a45050565b5f8072184f03e93ff9f4daa797ed6e38ed64bf6a1f0160401b83106115e05772184f03e93ff9f4daa797ed6e38ed64bf6a1f0160401b830492506040015b6d04ee2d6d415b85acef8100000000831061160c576d04ee2d6d415b85acef8100000000830492506020015b662386f26fc10000831061162a57662386f26fc10000830492506010015b6305f5e1008310611642576305f5e100830492506008015b612710831061165657612710830492506004015b60648310611668576064830492506002015b600a831061061e5760010192915050565b5f5b8381101561169357818101518382015260200161167b565b50505f910152565b602081525f82518060208401526116b9816040850160208701611679565b601f01601f19169190910160400192915050565b5f602082840312156116dd575f80fd5b5035919050565b80356001600160a01b0381168114610bc9575f80fd5b5f806040838503121561170b575f80fd5b611714836116e4565b946020939093013593505050565b634e487b7160e01b5f52604160045260245ffd5b5f82601f830112611745575f80fd5b813567ffffffffffffffff8082111561176057611760611722565b604051601f8301601f19908116603f0116810190828211818310171561178857611788611722565b816040528381528660208588010111156117a0575f80fd5b836020870160208301375f602085830101528094505050505092915050565b5f602082840312156117cf575f80fd5b813567ffffffffffffffff8111156117e5575f80fd5b6117f184828501611736565b949350505050565b5f805f6060848603121561180b575f80fd5b611814846116e4565b9250611822602085016116e4565b9150604084013590509250925092565b5f8060408385031215611843575f80fd5b823567ffffffffffffffff8082111561185a575f80fd5b61186686838701611736565b9350602085013591508082111561187b575f80fd5b5061188885828601611736565b9150509250929050565b5f80604083850312156118a3575f80fd5b6118ac836116e4565b9150602083013580151581146118c0575f80fd5b809150509250929050565b5f602082840312156118db575f80fd5b610c52826116e4565b5f805f805f608086880312156118f8575f80fd5b611901866116e4565b945061190f602087016116e4565b935060408601359250606086013567ffffffffffffffff80821115611932575f80fd5b818801915088601f830112611945575f80fd5b813581811115611953575f80fd5b896020828501011115611964575f80fd5b9699959850939650602001949392505050565b5f8060408385031215611988575f80fd5b611991836116e4565b915061199f602084016116e4565b90509250929050565b600181811c908216806119bc57607f821691505b6020821081036119da57634e487b7160e01b5f52602260045260245ffd5b50919050565b601f8211156109d457805f5260205f20601f840160051c81016020851015611a055750805b601f840160051c820191505b818110156109d1575f8155600101611a11565b815167ffffffffffffffff811115611a3e57611a3e611722565b611a5281611a4c84546119a8565b846119e0565b602080601f831160018114611a85575f8415611a6e5750858301515b5f19600386901b1c1916600185901b178555611adc565b5f85815260208120601f198616915b82811015611ab357888601518255948401946001909101908401611a94565b5085821015611ad057878501515f19600388901b60f8161c191681555b505060018460011b0185555b505050505050565b634e487b7160e01b5f52601160045260245ffd5b8181038181111561061e5761061e611ae4565b634e487b7160e01b5f52603260045260245ffd5b634e487b7160e01b5f52603160045260245ffd5b5f60208284031215611b43575f80fd5b81516001600160e01b031981168114610c52575f80fd5b6001600160a01b038681168252851660208201526040810184905260806060820181905281018290525f828460a08401375f60a0848401015260a0601f19601f85011683010190509695505050505050565b5f808454611bb9816119a8565b60018281168015611bd15760018114611be657611c12565b60ff1984168752821515830287019450611c12565b885f526020805f205f5b85811015611c095781548a820152908401908201611bf0565b50505082870194505b505050508351611c26818360208801611679565b01949350505050565b727b226e616d65223a202250657065343034202360681b815281515f90611c5d816013850160208701611679565b9190910160130192915050565b5f8251611c7b818460208701611679565b7f222c226465736372697074696f6e223a224120636f6c6c656374696f6e206f669201918252507f20342c30303020506570657320656e61626c6564206279204552433430342c2060208201527f616e206578706572696d656e74616c20746f6b656e207374616e646172642e2260408201527f2c2265787465726e616c5f75726c223a2268747470733a2f2f7477697474657260608201527f2e636f6d2f706570653430345f657263222c22696d616765223a2200000000006080820152609b01919050565b5f8351611d53818460208801611679565b835190830190611c26818360208801611679565b7f222c2261747472696275746573223a5b7b2274726169745f74797065223a225481526e3930b4ba1116113b30b63ab2911d1160891b60208201525f8251611db681602f850160208701611679565b91909101602f0192915050565b7f646174613a6170706c69636174696f6e2f6a736f6e3b757466382c000000000081525f8251611dfa81601b850160208701611679565b91909101601b0192915050565b600181815b80851115611e4157815f1904821115611e2757611e27611ae4565b80851615611e3457918102915b93841c9390800290611e0c565b509250929050565b5f82611e575750600161061e565b81611e6357505f61061e565b8160018114611e795760028114611e8357611e9f565b600191505061061e565b60ff841115611e9457611e94611ae4565b50506001821b61061e565b5060208310610133831016604e8410600b8410161715611ec2575081810a61061e565b611ecc8383611e07565b805f1904821115611edf57611edf611ae4565b029392505050565b5f610c5260ff841683611e49565b5f82611f0f57634e487b7160e01b5f52601260045260245ffd5b50049056fea26469706673582212207c76284d2370ff0344de3bd1d95984419cd8b3718b2212484a16c9d44946709864736f6c63430008180033

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

000000000000000000000000a71b5f53c3a18d5df819884e3c51201327f7a545

-----Decoded View---------------
Arg [0] : _owner (address): 0xA71b5F53c3A18d5dF819884E3c51201327F7a545

-----Encoded View---------------
1 Constructor Arguments found :
Arg [0] : 000000000000000000000000a71b5f53c3a18d5df819884e3c51201327f7a545


Deployed Bytecode Sourcemap

32225:2410:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;3893:18;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;4604:46;;;;;;:::i;:::-;;;;;;;;;;;;-1:-1:-1;;;;;4604:46:0;;;;;;-1:-1:-1;;;;;1019:32:1;;;1001:51;;989:2;974:18;4604:46:0;855:203:1;6435:642:0;;;;;;:::i;:::-;;:::i;:::-;;;1665:14:1;;1658:22;1640:41;;1628:2;1613:18;6435:642:0;1500:187:1;4129:36:0;;;;;;;;1838:25:1;;;1826:2;1811:18;4129:36:0;1692:177:1;32472:98:0;;;;;;:::i;:::-;;:::i;:::-;;7484:1716;;;;;;:::i;:::-;;:::i;2609:151::-;;;:::i;4029:31::-;;;;;;;;3562:4:1;3550:17;;;3532:36;;3520:2;3505:18;4029:31:0;3390:184:1;9496:405:0;;;;;;:::i;:::-;;:::i;4264:21::-;;;;;;32692:158;;;;;;:::i;:::-;;:::i;5764:111::-;;;;;;:::i;:::-;;:::i;5947:193::-;;;;;;:::i;:::-;;:::i;4370:44::-;;;;;;:::i;:::-;;;;;;;;;;;;;;2050:20;;;;;-1:-1:-1;;;;;2050:20:0;;;3947;;;:::i;5215:41::-;;;;;;:::i;:::-;;;;;;;;;;;;;;;;7128:207;;;;;;:::i;:::-;;:::i;9259:160::-;;;;;;:::i;:::-;;:::i;9996:437::-;;;;;;:::i;:::-;;:::i;32858:1774::-;;;;;;:::i;:::-;;:::i;32287:26::-;;;:::i;4484:64::-;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;32578:106;;;;;;:::i;:::-;;:::i;4715:68::-;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;32259:21;;;:::i;2382:219::-;;;;;;:::i;:::-;;:::i;3893:18::-;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::o;6435:642::-;6538:4;6573:6;;6559:10;:20;;:38;;;;;6596:1;6583:10;:14;6559:38;6555:491;;;6614:13;6630:20;;;:8;:20;;;;;;-1:-1:-1;;;;;6630:20:0;6671:10;:19;;;;;:59;;-1:-1:-1;;;;;;6695:23:0;;;;;;:16;:23;;;;;;;;6719:10;6695:35;;;;;;;;;;6694:36;6671:59;6667:121;;;6758:14;;-1:-1:-1;;;6758:14:0;;;;;;;;;;;6667:121;6804:23;;;;:11;:23;;;;;;;;;:33;;-1:-1:-1;;;;;;6804:33:0;-1:-1:-1;;;;;6804:33:0;;;;;;;;;6859:36;;1838:25:1;;;6859:36:0;;;;;;1811:18:1;6859:36:0;;;;;;;6599:308;6555:491;;;6938:10;6928:21;;;;:9;:21;;;;;;;;-1:-1:-1;;;;;6928:30:0;;;;;;;;;;;;:43;;;6993:41;1838:25:1;;;6928:30:0;;6938:10;6993:41;;1811:18:1;6993:41:0;;;;;;;6555:491;-1:-1:-1;7065:4:0;6435:642;;;;;:::o;32472:98::-;2137:5;;-1:-1:-1;;;;;2137:5:0;2123:10;:19;2119:46;;2151:14;;-1:-1:-1;;;2151:14:0;;;;;;;;;;;2119:46;32544:7:::1;:18;32554:8:::0;32544:7;:18:::1;:::i;:::-;;32472:98:::0;:::o;7484:1716::-;7630:6;;7616:10;:20;7612:1581;;7665:20;;;;:8;:20;;;;;;-1:-1:-1;;;;;7657:28:0;;;7665:20;;7657:28;7653:91;;7713:15;;-1:-1:-1;;;7713:15:0;;;;;;;;;;;7653:91;-1:-1:-1;;;;;7764:16:0;;7760:82;;7808:18;;-1:-1:-1;;;7808:18:0;;;;;;;;;;;7760:82;7880:10;-1:-1:-1;;;;;7880:18:0;;;;;;:74;;-1:-1:-1;;;;;;7920:22:0;;;;;;:16;:22;;;;;;;;7943:10;7920:34;;;;;;;;;;7919:35;7880:74;:132;;;;-1:-1:-1;7989:23:0;;;;:11;:23;;;;;;-1:-1:-1;;;;;7989:23:0;7975:10;:37;;7880:132;7858:226;;;8054:14;;-1:-1:-1;;;8054:14:0;;;;;;;;;;;7858:226;8119:10;:8;:10::i;:::-;-1:-1:-1;;;;;8100:15:0;;;;;;:9;:15;;;;;:29;;:15;;;:29;;;;;:::i;:::-;;;;-1:-1:-1;8192:10:0;;-1:-1:-1;8192:8:0;:10::i;:::-;-1:-1:-1;;;;;8175:13:0;;;;;;;:9;:13;;;;;;;;:27;;;;;;;;8234:20;;;:8;:20;;;;;:25;;-1:-1:-1;;;;;;8234:25:0;;;;;;;;8281:11;:23;;;;;8274:30;;;;;;;;8382:12;;;;;:6;:12;;;;;8395:19;;:23;;-1:-1:-1;;8395:23:0;:::i;:::-;8382:37;;;;;;;;:::i;:::-;;;;;;;;;;;;;-1:-1:-1;;;;;8434:12:0;;;;:6;:12;;;;;;8447:23;;;:11;:23;;;;;;;8434:37;;8382;;-1:-1:-1;8382:37:0;;8434;;;;;;:::i;:::-;;;;;;;;;;;;:49;;;;-1:-1:-1;;;;;8518:12:0;;;;:6;:12;;;;;;:18;;;;;;;:::i;:::-;;;;;;;;;;;-1:-1:-1;;8518:18:0;;;;;;;;;;;;8622:23;;;:11;:23;;;;;;;8597:22;;;;;;:48;-1:-1:-1;;;;;8699:10:0;;;;;:6;:10;;;;;:27;;8518:18;8699:27;;;;;;;;;;;;;;;8809:10;;:17;;:21;;8518:18;8809:21;:::i;:::-;8783:23;;;;:11;:23;;;;;;:47;;;;8852:30;;8795:10;;-1:-1:-1;;;;;8852:30:0;;;;;;;;;;;8922:2;-1:-1:-1;;;;;8902:35:0;8916:4;-1:-1:-1;;;;;8902:35:0;;8926:10;:8;:10::i;:::-;8902:35;;1838:25:1;;;1826:2;1811:18;8902:35:0;;;;;;;7638:1311;7484:1716;;;:::o;7612:1581::-;-1:-1:-1;;;;;8988:15:0;;8970;8988;;;:9;:15;;;;;;;;9004:10;8988:27;;;;;;;;-1:-1:-1;;9036:28:0;;9032:101;;9113:20;9123:10;9113:7;:20;:::i;:::-;-1:-1:-1;;;;;9083:15:0;;;;;;:9;:15;;;;;;;;9099:10;9083:27;;;;;;;:50;9032:101;9150:31;9160:4;9166:2;9170:10;9150:9;:31::i;:::-;;8955:238;7612:1581;7484:1716;;;:::o;2609:151::-;2137:5;;-1:-1:-1;;;;;2137:5:0;2123:10;:19;2119:46;;2151:14;;-1:-1:-1;;;2151:14:0;;;;;;;;;;;2119:46;2688:1:::1;2672:18:::0;;-1:-1:-1;;;;;;2672:18:0::1;::::0;;2708:44:::1;::::0;2729:10:::1;::::0;2708:44:::1;::::0;2688:1;;2708:44:::1;2609:151::o:0;9496:405::-;9620:26;9633:4;9639:2;9643;9620:12;:26::i;:::-;-1:-1:-1;;;;;9677:14:0;;;:19;;;;:154;;-1:-1:-1;9713:61:0;;-1:-1:-1;;;9713:61:0;;;9749:10;9713:61;;;9137:34:1;-1:-1:-1;;;;;9207:15:1;;;9187:18;;;9180:43;9239:18;;;9232:34;;;9302:3;9282:18;;;9275:31;-1:-1:-1;9322:19:1;;;9315:30;9791:40:0;;9713:35;;;;9791:40;;9362:19:1;;9713:61:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;-1:-1:-1;;;;;;9713:118:0;;;9677:154;9659:235;;;9865:17;;-1:-1:-1;;;9865:17:0;;;;;;;;;;;32692:158;2137:5;;-1:-1:-1;;;;;2137:5:0;2123:10;:19;2119:46;;2151:14;;-1:-1:-1;;;2151:14:0;;;;;;;;;;;2119:46;32812:30:::1;32827:5;32834:7;32812:14;:30::i;5764:111::-:0;2137:5;;-1:-1:-1;;;;;2137:5:0;2123:10;:19;2119:46;;2151:14;;-1:-1:-1;;;2151:14:0;;;;;;;;;;;2119:46;-1:-1:-1;;;;;5842:17:0;;;::::1;;::::0;;;:9:::1;:17;::::0;;;;:25;;-1:-1:-1;;5842:25:0::1;::::0;::::1;;::::0;;;::::1;::::0;;5764:111::o;5947:193::-;6005:13;6039:12;;;:8;:12;;;;;;-1:-1:-1;;;;;6039:12:0;;6064:69;;6111:10;;-1:-1:-1;;;6111:10:0;;;;;;;;;;;6064:69;5947:193;;;:::o;3947:20::-;;;;;;;:::i;7128:207::-;7231:10;7214:28;;;;:16;:28;;;;;;;;-1:-1:-1;;;;;7214:38:0;;;;;;;;;;;;:49;;-1:-1:-1;;7214:49:0;;;;;;;;;;7281:46;;1640:41:1;;;7214:38:0;;7231:10;7281:46;;1613:18:1;7281:46:0;;;;;;;7128:207;;:::o;9259:160::-;9354:4;9378:33;9388:10;9400:2;9404:6;9378:9;:33::i;:::-;9371:40;9259:160;-1:-1:-1;;;9259:160:0:o;9996:437::-;10150:26;10163:4;10169:2;10173;10150:12;:26::i;:::-;-1:-1:-1;;;;;10207:14:0;;;:19;;;;:156;;-1:-1:-1;10243:63:0;;-1:-1:-1;;;10243:63:0;;;10323:40;-1:-1:-1;;;;;10243:35:0;;;10323:40;;10243:63;;10279:10;;10291:4;;10297:2;;10301:4;;;;10243:63;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;-1:-1:-1;;;;;;10243:120:0;;;10207:156;10189:237;;;10397:17;;-1:-1:-1;;;10397:17:0;;;;;;;;;;;32858:1774;32918:13;32977:1;32954:12;32948:26;;;;;:::i;:::-;;;:30;32944:1681;;;33016:12;33030:20;33047:2;33030:16;:20::i;:::-;33002:49;;;;;;;;;:::i;:::-;;;;;;;;;;;;;32995:56;;32858:1774;;;:::o;32944:1681::-;33084:10;33137:2;33120:20;;;;;;11509:19:1;;11553:2;11544:12;;11380:182;33120:20:0;;;;;;;;;;;;;33110:31;;;;;;33097:46;;33084:59;;33158:19;33192;33240:3;33232:4;:11;;;33228:441;;33264:20;;;;;;;;;;;;;-1:-1:-1;;;33264:20:0;;;;;33303:17;;;;;;;;;;;;;-1:-1:-1;;;33303:17:0;;;;;33228:441;;;33354:3;33346:4;:11;;;33342:327;;33378:18;;;;;;;;;;;;;-1:-1:-1;;;33378:18:0;;;;;33415:14;;;;;;;;;;;;;-1:-1:-1;;;33415:14:0;;;;;33342:327;;;33463:3;33455:4;:11;;;33451:218;;33487:20;;;;;;;;;;;;;-1:-1:-1;;;33487:20:0;;;;;33526:16;;;;;;;;;;;;;-1:-1:-1;;;33526:16:0;;;;;33451:218;;;33576:3;33568:4;:11;;;33564:105;;33600:19;;;;;;;;;;;;;-1:-1:-1;;;33600:19:0;;;;;33638:15;;;;;;;;;;;;;-1:-1:-1;;;33638:15:0;;;;;33564:105;33685:26;33819:20;33836:2;33819:16;:20::i;:::-;33782:58;;;;;;;;:::i;:::-;;;;-1:-1:-1;;33782:58:0;;;;;;;;;;33746:293;;33782:58;33746:293;;:::i;:::-;;;;;;;;;;;;;34072:7;34081:5;34058:29;;;;;;;;;:::i;:::-;;;;-1:-1:-1;;34058:29:0;;;;;;;;;;33714:388;;;34058:29;33714:388;;:::i;:::-;;;;;;;;;;;;;33685:417;;34117:27;34247:5;34147:120;;;;;;;;:::i;:::-;;;;-1:-1:-1;;34147:120:0;;;;;;34282:37;;;;;;;;-1:-1:-1;;;34147:120:0;34282:37;;;;;;;34488:42;;34147:120;;-1:-1:-1;34488:42:0;;34502:12;;34147:120;;34488:42;;:::i;:::-;;;;-1:-1:-1;;34488:42:0;;;;;;;;;;34448:146;;34557:14;;34488:42;34448:146;;:::i;:::-;;;;-1:-1:-1;;34448:146:0;;;;;;;;;;34360:253;;34448:146;34360:253;;:::i;:::-;;;;;;;;;;;;;34336:277;;;;;;;;32858:1774;;;:::o;32287:26::-;;;;;;;:::i;32578:106::-;2137:5;;-1:-1:-1;;;;;2137:5:0;2123:10;:19;2119:46;;2151:14;;-1:-1:-1;;;2151:14:0;;;;;;;;;;;2119:46;32652:12:::1;:24;32667:9:::0;32652:12;:24:::1;:::i;32259:21::-:0;;;;;;;:::i;2382:219::-;2137:5;;-1:-1:-1;;;;;2137:5:0;2123:10;:19;2119:46;;2151:14;;-1:-1:-1;;;2151:14:0;;;;;;;;;;;2119:46;-1:-1:-1;;;;;2465:20:0;::::1;2461:47;;2494:14;;-1:-1:-1::0;;;2494:14:0::1;;;;;;;;;;;2461:47;2521:5;:14:::0;;-1:-1:-1;;;;;;2521:14:0::1;-1:-1:-1::0;;;;;2521:14:0;::::1;::::0;;::::1;::::0;;2553:40:::1;::::0;2521:14;;2574:10:::1;::::0;2553:40:::1;::::0;2521:5;2553:40:::1;2382:219:::0;:::o;11633:92::-;11676:7;11703:14;11709:8;11703:2;:14;:::i;:::-;11696:21;;11633:92;:::o;10501:1093::-;10614:4;10631:12;10646:10;:8;:10::i;:::-;-1:-1:-1;;;;;10697:15:0;;;10667:27;10697:15;;;:9;:15;;;;;;;;10755:13;;;;;;;;;10781:15;;;10631:25;;-1:-1:-1;10697:15:0;;10755:13;;10800:6;;10697:15;10781:25;10800:6;10697:15;10781:25;:::i;:::-;;;;-1:-1:-1;;;;;;;10844:13:0;;;;;;;:9;:13;;;;;;;;:23;;;;;;10952:15;;;;;:9;:15;;;;;;10947:251;;-1:-1:-1;;;;;11058:15:0;;10984:22;11058:15;;;:9;:15;;;;;;:22;;11076:4;;11058:22;:::i;:::-;11010:26;11032:4;11010:19;:26;:::i;:::-;11009:72;;;;:::i;:::-;10984:97;;11101:9;11096:91;11120:14;11116:1;:18;11096:91;;;11160:11;11166:4;11160:5;:11::i;:::-;11136:3;;11096:91;;;;10969:229;10947:251;-1:-1:-1;;;;;11274:13:0;;;;;;:9;:13;;;;;;;;11269:247;;11304:22;11372:28;11396:4;11372:21;:28;:::i;:::-;-1:-1:-1;;;;;11330:13:0;;;;;;:9;:13;;;;;;:20;;11346:4;;11330:20;:::i;:::-;11329:72;;;;:::i;:::-;11304:97;;11421:9;11416:89;11440:14;11436:1;:18;11416:89;;;11480:9;11486:2;11480:5;:9::i;:::-;11456:3;;11416:89;;;;11289:227;11269:247;11553:2;-1:-1:-1;;;;;11533:31:0;11547:4;-1:-1:-1;;;;;11533:31:0;;11557:6;11533:31;;;;1838:25:1;;1826:2;1811:18;;1692:177;11533:31:0;;;;;;;;-1:-1:-1;11582:4:0;;10501:1093;-1:-1:-1;;;;;;10501:1093:0:o;12596:160::-;12709:4;:12;12716:5;12709:4;:12;:::i;:::-;-1:-1:-1;12732:6:0;:16;12741:7;12732:6;:16;:::i;29690:718::-;29746:13;29797:14;29814:17;29825:5;29814:10;:17::i;:::-;29834:1;29814:21;29797:38;;29850:20;29884:6;29873:18;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;-1:-1:-1;29873:18:0;-1:-1:-1;29850:41:0;-1:-1:-1;30015:28:0;;;30031:2;30015:28;30072:290;-1:-1:-1;;30104:5:0;-1:-1:-1;;;30241:2:0;30230:14;;30225:32;30104:5;30212:46;30304:2;30295:11;;;-1:-1:-1;30325:21:0;30072:290;30325:21;-1:-1:-1;30383:6:0;29690:718;-1:-1:-1;;;29690:718:0:o;12215:373::-;-1:-1:-1;;;;;12276:18:0;;12272:73;;12318:15;;-1:-1:-1;;;12318:15:0;;;;;;;;;;;12272:73;-1:-1:-1;;;;;12370:12:0;;12357:10;12370:12;;;:6;:12;;;;;12383:19;;:23;;12405:1;;12383:23;:::i;:::-;12370:37;;;;;;;;:::i;:::-;;;;;;;;;12357:50;;12418:6;:12;12425:4;-1:-1:-1;;;;;12418:12:0;-1:-1:-1;;;;;12418:12:0;;;;;;;;;;;;:18;;;;;;;:::i;:::-;;;;;;;;;;;-1:-1:-1;;12418:18:0;;;;;;;;;;;;12454:15;;;:11;:15;;;;;;12447:22;;;12487:8;:12;;;;;12480:19;;-1:-1:-1;;;;;;12480:19:0;;;;;;12517:11;:15;;;;;;12510:22;;;;;;;;12550:30;12466:2;;12418:18;-1:-1:-1;;;;;12550:30:0;;;;;12418:18;;12550:30;12261:327;12215:373;:::o;11733:474::-;-1:-1:-1;;;;;11792:16:0;;11788:74;;11832:18;;-1:-1:-1;;;11832:18:0;;;;;;;;;;;11788:74;11899:6;:8;;;;;;;;:6;11967:12;;;:8;:12;;;;;;-1:-1:-1;;;;;11967:12:0;:26;11963:81;;12017:15;;-1:-1:-1;;;12017:15:0;;;;;;;;;;;11963:81;12056:12;;;;:8;:12;;;;;;;;:17;;-1:-1:-1;;;;;;12056:17:0;-1:-1:-1;;;;;12056:17:0;;;;;;;;12084:10;;;:6;:10;;;;;:19;;-1:-1:-1;12084:19:0;;;;;;;;;;;;;;;12132:10;;:17;;:21;;-1:-1:-1;12132:21:0;:::i;:::-;12114:15;;;;:11;:15;;;;;;:39;;;;12171:28;;12126:2;;-1:-1:-1;;;;;12171:28:0;;;;;12114:15;;12171:28;11777:430;11733:474;:::o;25086:948::-;25139:7;;-1:-1:-1;;;25217:17:0;;25213:106;;-1:-1:-1;;;25255:17:0;;;-1:-1:-1;25301:2:0;25291:12;25213:106;25346:8;25337:5;:17;25333:106;;25384:8;25375:17;;;-1:-1:-1;25421:2:0;25411:12;25333:106;25466:8;25457:5;:17;25453:106;;25504:8;25495:17;;;-1:-1:-1;25541:2:0;25531:12;25453:106;25586:7;25577:5;:16;25573:103;;25623:7;25614:16;;;-1:-1:-1;25659:1:0;25649:11;25573:103;25703:7;25694:5;:16;25690:103;;25740:7;25731:16;;;-1:-1:-1;25776:1:0;25766:11;25690:103;25820:7;25811:5;:16;25807:103;;25857:7;25848:16;;;-1:-1:-1;25893:1:0;25883:11;25807:103;25937:7;25928:5;:16;25924:68;;25975:1;25965:11;26020:6;25086:948;-1:-1:-1;;25086:948: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;670:180::-;729:6;782:2;770:9;761:7;757:23;753:32;750:52;;;798:1;795;788:12;750:52;-1:-1:-1;821:23:1;;670:180;-1:-1:-1;670:180:1:o;1063:173::-;1131:20;;-1:-1:-1;;;;;1180:31:1;;1170:42;;1160:70;;1226:1;1223;1216:12;1241:254;1309:6;1317;1370:2;1358:9;1349:7;1345:23;1341:32;1338:52;;;1386:1;1383;1376:12;1338:52;1409:29;1428:9;1409:29;:::i;:::-;1399:39;1485:2;1470:18;;;;1457:32;;-1:-1:-1;;;1241:254:1:o;1874:127::-;1935:10;1930:3;1926:20;1923:1;1916:31;1966:4;1963:1;1956:15;1990:4;1987:1;1980:15;2006:719;2049:5;2102:3;2095:4;2087:6;2083:17;2079:27;2069:55;;2120:1;2117;2110:12;2069:55;2156:6;2143:20;2182:18;2219:2;2215;2212:10;2209:36;;;2225:18;;:::i;:::-;2300:2;2294:9;2268:2;2354:13;;-1:-1:-1;;2350:22:1;;;2374:2;2346:31;2342:40;2330:53;;;2398:18;;;2418:22;;;2395:46;2392:72;;;2444:18;;:::i;:::-;2484:10;2480:2;2473:22;2519:2;2511:6;2504:18;2565:3;2558:4;2553:2;2545:6;2541:15;2537:26;2534:35;2531:55;;;2582:1;2579;2572:12;2531:55;2646:2;2639:4;2631:6;2627:17;2620:4;2612:6;2608:17;2595:54;2693:1;2686:4;2681:2;2673:6;2669:15;2665:26;2658:37;2713:6;2704:15;;;;;;2006:719;;;;:::o;2730:322::-;2799:6;2852:2;2840:9;2831:7;2827:23;2823:32;2820:52;;;2868:1;2865;2858:12;2820:52;2908:9;2895:23;2941:18;2933:6;2930:30;2927:50;;;2973:1;2970;2963:12;2927:50;2996;3038:7;3029:6;3018:9;3014:22;2996:50;:::i;:::-;2986:60;2730:322;-1:-1:-1;;;;2730:322:1:o;3057:328::-;3134:6;3142;3150;3203:2;3191:9;3182:7;3178:23;3174:32;3171:52;;;3219:1;3216;3209:12;3171:52;3242:29;3261:9;3242:29;:::i;:::-;3232:39;;3290:38;3324:2;3313:9;3309:18;3290:38;:::i;:::-;3280:48;;3375:2;3364:9;3360:18;3347:32;3337:42;;3057:328;;;;;:::o;3579:543::-;3667:6;3675;3728:2;3716:9;3707:7;3703:23;3699:32;3696:52;;;3744:1;3741;3734:12;3696:52;3784:9;3771:23;3813:18;3854:2;3846:6;3843:14;3840:34;;;3870:1;3867;3860:12;3840:34;3893:50;3935:7;3926:6;3915:9;3911:22;3893:50;:::i;:::-;3883:60;;3996:2;3985:9;3981:18;3968:32;3952:48;;4025:2;4015:8;4012:16;4009:36;;;4041:1;4038;4031:12;4009:36;;4064:52;4108:7;4097:8;4086:9;4082:24;4064:52;:::i;:::-;4054:62;;;3579:543;;;;;:::o;4127:347::-;4192:6;4200;4253:2;4241:9;4232:7;4228:23;4224:32;4221:52;;;4269:1;4266;4259:12;4221:52;4292:29;4311:9;4292:29;:::i;:::-;4282:39;;4371:2;4360:9;4356:18;4343:32;4418:5;4411:13;4404:21;4397:5;4394:32;4384:60;;4440:1;4437;4430:12;4384:60;4463:5;4453:15;;;4127:347;;;;;:::o;4479:186::-;4538:6;4591:2;4579:9;4570:7;4566:23;4562:32;4559:52;;;4607:1;4604;4597:12;4559:52;4630:29;4649:9;4630:29;:::i;4670:808::-;4767:6;4775;4783;4791;4799;4852:3;4840:9;4831:7;4827:23;4823:33;4820:53;;;4869:1;4866;4859:12;4820:53;4892:29;4911:9;4892:29;:::i;:::-;4882:39;;4940:38;4974:2;4963:9;4959:18;4940:38;:::i;:::-;4930:48;;5025:2;5014:9;5010:18;4997:32;4987:42;;5080:2;5069:9;5065:18;5052:32;5103:18;5144:2;5136:6;5133:14;5130:34;;;5160:1;5157;5150:12;5130:34;5198:6;5187:9;5183:22;5173:32;;5243:7;5236:4;5232:2;5228:13;5224:27;5214:55;;5265:1;5262;5255:12;5214:55;5305:2;5292:16;5331:2;5323:6;5320:14;5317:34;;;5347:1;5344;5337:12;5317:34;5392:7;5387:2;5378:6;5374:2;5370:15;5366:24;5363:37;5360:57;;;5413:1;5410;5403:12;5360:57;4670:808;;;;-1:-1:-1;4670:808:1;;-1:-1:-1;5444:2:1;5436:11;;5466:6;4670:808;-1:-1:-1;;;4670:808:1:o;5483:260::-;5551:6;5559;5612:2;5600:9;5591:7;5587:23;5583:32;5580:52;;;5628:1;5625;5618:12;5580:52;5651:29;5670:9;5651:29;:::i;:::-;5641:39;;5699:38;5733:2;5722:9;5718:18;5699:38;:::i;:::-;5689:48;;5483:260;;;;;:::o;5748:380::-;5827:1;5823:12;;;;5870;;;5891:61;;5945:4;5937:6;5933:17;5923:27;;5891:61;5998:2;5990:6;5987:14;5967:18;5964:38;5961:161;;6044:10;6039:3;6035:20;6032:1;6025:31;6079:4;6076:1;6069:15;6107:4;6104:1;6097:15;5961:161;;5748:380;;;:::o;6259:518::-;6361:2;6356:3;6353:11;6350:421;;;6397:5;6394:1;6387:16;6441:4;6438:1;6428:18;6511:2;6499:10;6495:19;6492:1;6488:27;6482:4;6478:38;6547:4;6535:10;6532:20;6529:47;;;-1:-1:-1;6570:4:1;6529:47;6625:2;6620:3;6616:12;6613:1;6609:20;6603:4;6599:31;6589:41;;6680:81;6698:2;6691:5;6688:13;6680:81;;;6757:1;6743:16;;6724:1;6713:13;6680:81;;6953:1345;7079:3;7073:10;7106:18;7098:6;7095:30;7092:56;;;7128:18;;:::i;:::-;7157:97;7247:6;7207:38;7239:4;7233:11;7207:38;:::i;:::-;7201:4;7157:97;:::i;:::-;7309:4;;7366:2;7355:14;;7383:1;7378:663;;;;8085:1;8102:6;8099:89;;;-1:-1:-1;8154:19:1;;;8148:26;8099:89;-1:-1:-1;;6910:1:1;6906:11;;;6902:24;6898:29;6888:40;6934:1;6930:11;;;6885:57;8201:81;;7348:944;;7378:663;6206:1;6199:14;;;6243:4;6230:18;;-1:-1:-1;;7414:20:1;;;7532:236;7546:7;7543:1;7540:14;7532:236;;;7635:19;;;7629:26;7614:42;;7727:27;;;;7695:1;7683:14;;;;7562:19;;7532:236;;;7536:3;7796:6;7787:7;7784:19;7781:201;;;7857:19;;;7851:26;-1:-1:-1;;7940:1:1;7936:14;;;7952:3;7932:24;7928:37;7924:42;7909:58;7894:74;;7781:201;;;8028:1;8019:6;8016:1;8012:14;8008:22;8002:4;7995:36;7348:944;;;;;6953:1345;;:::o;8303:127::-;8364:10;8359:3;8355:20;8352:1;8345:31;8395:4;8392:1;8385:15;8419:4;8416:1;8409:15;8435:128;8502:9;;;8523:11;;;8520:37;;;8537:18;;:::i;8568:127::-;8629:10;8624:3;8620:20;8617:1;8610:31;8660:4;8657:1;8650:15;8684:4;8681:1;8674:15;8700:127;8761:10;8756:3;8752:20;8749:1;8742:31;8792:4;8789:1;8782:15;8816:4;8813:1;8806:15;9392:290;9461:6;9514:2;9502:9;9493:7;9489:23;9485:32;9482:52;;;9530:1;9527;9520:12;9482:52;9556:16;;-1:-1:-1;;;;;;9601:32:1;;9591:43;;9581:71;;9648:1;9645;9638:12;9687:662;-1:-1:-1;;;;;9966:15:1;;;9948:34;;10018:15;;10013:2;9998:18;;9991:43;10065:2;10050:18;;10043:34;;;10113:3;10108:2;10093:18;;10086:31;;;10133:19;;10126:35;;;9891:4;10154:6;10204;9928:3;10183:19;;10170:49;10269:1;10263:3;10254:6;10243:9;10239:22;10235:32;10228:43;10339:3;10332:2;10328:7;10323:2;10315:6;10311:15;10307:29;10296:9;10292:45;10288:55;10280:63;;9687:662;;;;;;;;:::o;10354:1021::-;10530:3;10559:1;10592:6;10586:13;10622:36;10648:9;10622:36;:::i;:::-;10677:1;10694:17;;;10720:133;;;;10867:1;10862:358;;;;10687:533;;10720:133;-1:-1:-1;;10753:24:1;;10741:37;;10826:14;;10819:22;10807:35;;10798:45;;;-1:-1:-1;10720:133:1;;10862:358;10893:6;10890:1;10883:17;10923:4;10968;10965:1;10955:18;10995:1;11009:165;11023:6;11020:1;11017:13;11009:165;;;11101:14;;11088:11;;;11081:35;11144:16;;;;11038:10;;11009:165;;;11013:3;;;11203:6;11198:3;11194:16;11187:23;;10687:533;;;;;11251:6;11245:13;11267:68;11326:8;11321:3;11314:4;11306:6;11302:17;11267:68;:::i;:::-;11351:18;;10354:1021;-1:-1:-1;;;;10354:1021:1:o;11567:470::-;-1:-1:-1;;;11807:63:1;;11893:13;;11789:3;;11915:75;11893:13;11978:2;11969:12;;11962:4;11950:17;;11915:75;:::i;:::-;12010:16;;;;12028:2;12006:25;;11567:470;-1:-1:-1;;11567:470:1:o;12042:884::-;12274:3;12312:6;12306:13;12328:66;12387:6;12382:3;12375:4;12367:6;12363:17;12328:66;:::i;:::-;12455;12416:16;;12441:81;;;-1:-1:-1;12556:34:1;12549:4;12538:16;;12531:60;12623:66;12618:2;12607:14;;12600:90;12722:66;12717:2;12706:14;;12699:90;12822:66;12816:3;12805:15;;12798:91;12916:3;12905:15;;12042:884;-1:-1:-1;12042:884:1:o;12931:496::-;13110:3;13148:6;13142:13;13164:66;13223:6;13218:3;13211:4;13203:6;13199:17;13164:66;:::i;:::-;13293:13;;13252:16;;;;13315:70;13293:13;13252:16;13362:4;13350:17;;13315:70;:::i;13432:567::-;13694:66;13689:3;13682:79;13800:32;13795:3;13791:42;13786:2;13781:3;13777:12;13770:64;13664:3;13863:6;13857:13;13879:73;13945:6;13940:2;13935:3;13931:12;13926:2;13918:6;13914:15;13879:73;:::i;:::-;13972:16;;;;13990:2;13968:25;;13432:567;-1:-1:-1;;13432:567:1:o;14004:449::-;14256:29;14251:3;14244:42;14226:3;14315:6;14309:13;14331:75;14399:6;14394:2;14389:3;14385:12;14378:4;14370:6;14366:17;14331:75;:::i;:::-;14426:16;;;;14444:2;14422:25;;14004:449;-1:-1:-1;;14004:449:1:o;14458:416::-;14547:1;14584:5;14547:1;14598:270;14619:7;14609:8;14606:21;14598:270;;;14678:4;14674:1;14670:6;14666:17;14660:4;14657:27;14654:53;;;14687:18;;:::i;:::-;14737:7;14727:8;14723:22;14720:55;;;14757:16;;;;14720:55;14836:22;;;;14796:15;;;;14598:270;;;14602:3;14458:416;;;;;:::o;14879:806::-;14928:5;14958:8;14948:80;;-1:-1:-1;14999:1:1;15013:5;;14948:80;15047:4;15037:76;;-1:-1:-1;15084:1:1;15098:5;;15037:76;15129:4;15147:1;15142:59;;;;15215:1;15210:130;;;;15122:218;;15142:59;15172:1;15163:10;;15186:5;;;15210:130;15247:3;15237:8;15234:17;15231:43;;;15254:18;;:::i;:::-;-1:-1:-1;;15310:1:1;15296:16;;15325:5;;15122:218;;15424:2;15414:8;15411:16;15405:3;15399:4;15396:13;15392:36;15386:2;15376:8;15373:16;15368:2;15362:4;15359:12;15355:35;15352:77;15349:159;;;-1:-1:-1;15461:19:1;;;15493:5;;15349:159;15540:34;15565:8;15559:4;15540:34;:::i;:::-;15610:6;15606:1;15602:6;15598:19;15589:7;15586:32;15583:58;;;15621:18;;:::i;:::-;15659:20;;14879:806;-1:-1:-1;;;14879:806:1:o;15690:140::-;15748:5;15777:47;15818:4;15808:8;15804:19;15798:4;15777:47;:::i;15967:217::-;16007:1;16033;16023:132;;16077:10;16072:3;16068:20;16065:1;16058:31;16112:4;16109:1;16102:15;16140:4;16137:1;16130:15;16023:132;-1:-1:-1;16169:9:1;;15967:217::o

Swarm Source

ipfs://7c76284d2370ff0344de3bd1d95984419cd8b3718b2212484a16c9d449467098
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.