ETH Price: $3,252.91 (+2.44%)
Gas: 3 Gwei

Token

JPG_DividendTracker (JPG_DT)
 

Overview

Max Total Supply

5,356,344.88371405384023332 JPG_DT

Holders

402

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 18 Decimals)

Balance
1,869.1455340615429647 JPG_DT

Value
$0.00
0x6792d25b50e1c729adfcc8cebae6b366380cc866
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:
DividendTracker

Compiler Version
v0.8.10+commit.fc410830

Optimization Enabled:
Yes with 5000 runs

Other Settings:
default evmVersion, MIT license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2022-02-13
*/

/*
   Find us on Twitter https://twitter.com/JPEGMorganCap
   https://jpegmorgan.capital/
   https://t.me/jpegmorgan

   A labor of love for @sodefi from Misa. 
   WGMI
    
*/

// SPDX-License-Identifier: MIT

pragma solidity =0.8.10 >=0.8.0 <0.9.0;
pragma experimental ABIEncoderV2;


abstract contract Context {
    function _msgSender() internal view virtual returns (address) {
        return msg.sender;
    }

    function _msgData() internal view virtual returns (bytes calldata) {
        return msg.data;
    }
}

abstract contract Ownable is Context {
    address private _owner;

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

    constructor() {
        _transferOwnership(_msgSender());
    }

    function owner() public view virtual returns (address) {
        return _owner;
    }

    modifier onlyOwner() {
        require(owner() == _msgSender(), "Ownable: caller is not the owner");
        _;
    }

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

    /**
     * @dev Transfers ownership of the contract to a new account (`newOwner`).
     * Internal function without access restriction.
     */
    function _transferOwnership(address newOwner) internal virtual {
        address oldOwner = _owner;
        _owner = newOwner;
        emit OwnershipTransferred(oldOwner, newOwner);
    }
}

interface IERC20 {
    /**
     * @dev Returns the amount of tokens in existence.
     */
    function totalSupply() external view returns (uint256);

    /**
     * @dev Returns the amount of tokens owned by `account`.
     */
    function balanceOf(address account) external view returns (uint256);

    /**
     * @dev Moves `amount` tokens from the caller's account to `recipient`.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * Emits a {Transfer} event.
     */
    function transfer(address recipient, uint256 amount) external returns (bool);

    /**
     * @dev Returns the remaining number of tokens that `spender` will be
     * allowed to spend on behalf of `owner` through {transferFrom}. This is
     * zero by default.
     *
     * This value changes when {approve} or {transferFrom} are called.
     */
    function allowance(address owner, address spender) external view returns (uint256);

    /**
     * @dev Sets `amount` as the allowance of `spender` over the caller's tokens.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * IMPORTANT: Beware that changing an allowance with this method brings the risk
     * that someone may use both the old and the new allowance by unfortunate
     * transaction ordering. One possible solution to mitigate this race
     * condition is to first reduce the spender's allowance to 0 and set the
     * desired value afterwards:
     * https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729
     *
     * Emits an {Approval} event.
     */
    function approve(address spender, uint256 amount) external returns (bool);

    /**
     * @dev Moves `amount` tokens from `sender` to `recipient` using the
     * allowance mechanism. `amount` is then deducted from the caller's
     * allowance.
     *
     * Returns a boolean value indicating whether the operation succeeded.
     *
     * Emits a {Transfer} event.
     */
    function transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) external returns (bool);

    /**
     * @dev Emitted when `value` tokens are moved from one account (`from`) to
     * another (`to`).
     *
     * Note that `value` may be zero.
     */
    event Transfer(address indexed from, address indexed to, uint256 value);

    /**
     * @dev Emitted when the allowance of a `spender` for an `owner` is set by
     * a call to {approve}. `value` is the new allowance.
     */
    event Approval(address indexed owner, address indexed spender, uint256 value);
}

interface IERC20Metadata is IERC20 {
    /**
     * @dev Returns the name of the token.
     */
    function name() external view returns (string memory);

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

    /**
     * @dev Returns the decimals places of the token.
     */
    function decimals() external view returns (uint8);
}

contract ERC20 is Context, IERC20, IERC20Metadata {
    mapping(address => uint256) private _balances;

    mapping(address => mapping(address => uint256)) private _allowances;

    uint256 private _totalSupply;

    string private _name;
    string private _symbol;

    /**
     * @dev Sets the values for {name} and {symbol}.
     *
     * The default value of {decimals} is 18. To select a different value for
     * {decimals} you should overload it.
     *
     * All two of these values are immutable: they can only be set once during
     * construction.
     */
    constructor(string memory name_, string memory symbol_) {
        _name = name_;
        _symbol = symbol_;
    }

    /**
     * @dev Returns the name of the token.
     */
    function name() public view virtual override returns (string memory) {
        return _name;
    }

    /**
     * @dev Returns the symbol of the token, usually a shorter version of the
     * name.
     */
    function symbol() public view virtual override returns (string memory) {
        return _symbol;
    }

    /**
     * @dev Returns the number of decimals used to get its user representation.
     * For example, if `decimals` equals `2`, a balance of `505` tokens should
     * be displayed to a user as `5.05` (`505 / 10 ** 2`).
     *
     * Tokens usually opt for a value of 18, imitating the relationship between
     * Ether and Wei. This is the value {ERC20} uses, unless this function is
     * overridden;
     *
     * NOTE: This information is only used for _display_ purposes: it in
     * no way affects any of the arithmetic of the contract, including
     * {IERC20-balanceOf} and {IERC20-transfer}.
     */
    function decimals() public view virtual override returns (uint8) {
        return 18;
    }

    /**
     * @dev See {IERC20-totalSupply}.
     */
    function totalSupply() public view virtual override returns (uint256) {
        return _totalSupply;
    }

    /**
     * @dev See {IERC20-balanceOf}.
     */
    function balanceOf(address account) public view virtual override returns (uint256) {
        return _balances[account];
    }

    /**
     * @dev See {IERC20-transfer}.
     *
     * Requirements:
     *
     * - `recipient` cannot be the zero address.
     * - the caller must have a balance of at least `amount`.
     */
    function transfer(address recipient, uint256 amount) public virtual override returns (bool) {
        _transfer(_msgSender(), recipient, amount);
        return true;
    }

    /**
     * @dev See {IERC20-allowance}.
     */
    function allowance(address owner, address spender) public view virtual override returns (uint256) {
        return _allowances[owner][spender];
    }

    /**
     * @dev See {IERC20-approve}.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     */
    function approve(address spender, uint256 amount) public virtual override returns (bool) {
        _approve(_msgSender(), spender, amount);
        return true;
    }

    /**
     * @dev See {IERC20-transferFrom}.
     *
     * Emits an {Approval} event indicating the updated allowance. This is not
     * required by the EIP. See the note at the beginning of {ERC20}.
     *
     * Requirements:
     *
     * - `sender` and `recipient` cannot be the zero address.
     * - `sender` must have a balance of at least `amount`.
     * - the caller must have allowance for ``sender``'s tokens of at least
     * `amount`.
     */
    function transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) public virtual override returns (bool) {
        _transfer(sender, recipient, amount);

        uint256 currentAllowance = _allowances[sender][_msgSender()];
        require(currentAllowance >= amount, "ERC20: transfer amount exceeds allowance");
        unchecked {
            _approve(sender, _msgSender(), currentAllowance - amount);
        }

        return true;
    }

    /**
     * @dev Atomically increases the allowance granted to `spender` by the caller.
     *
     * This is an alternative to {approve} that can be used as a mitigation for
     * problems described in {IERC20-approve}.
     *
     * Emits an {Approval} event indicating the updated allowance.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     */
    function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) {
        _approve(_msgSender(), spender, _allowances[_msgSender()][spender] + addedValue);
        return true;
    }

    /**
     * @dev Atomically decreases the allowance granted to `spender` by the caller.
     *
     * This is an alternative to {approve} that can be used as a mitigation for
     * problems described in {IERC20-approve}.
     *
     * Emits an {Approval} event indicating the updated allowance.
     *
     * Requirements:
     *
     * - `spender` cannot be the zero address.
     * - `spender` must have allowance for the caller of at least
     * `subtractedValue`.
     */
    function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {
        uint256 currentAllowance = _allowances[_msgSender()][spender];
        require(currentAllowance >= subtractedValue, "ERC20: decreased allowance below zero");
        unchecked {
            _approve(_msgSender(), spender, currentAllowance - subtractedValue);
        }

        return true;
    }

    /**
     * @dev Moves `amount` of tokens from `sender` to `recipient`.
     *
     * This internal function is equivalent to {transfer}, and can be used to
     * e.g. implement automatic token fees, slashing mechanisms, etc.
     *
     * Emits a {Transfer} event.
     *
     * Requirements:
     *
     * - `sender` cannot be the zero address.
     * - `recipient` cannot be the zero address.
     * - `sender` must have a balance of at least `amount`.
     */
    function _transfer(
        address sender,
        address recipient,
        uint256 amount
    ) internal virtual {
        require(sender != address(0), "ERC20: transfer from the zero address");
        require(recipient != address(0), "ERC20: transfer to the zero address");

        _beforeTokenTransfer(sender, recipient, amount);

        uint256 senderBalance = _balances[sender];
        require(senderBalance >= amount, "ERC20: transfer amount exceeds balance");
        unchecked {
            _balances[sender] = senderBalance - amount;
        }
        _balances[recipient] += amount;

        emit Transfer(sender, recipient, amount);

        _afterTokenTransfer(sender, recipient, amount);
    }

    /** @dev Creates `amount` tokens and assigns them to `account`, increasing
     * the total supply.
     *
     * Emits a {Transfer} event with `from` set to the zero address.
     *
     * Requirements:
     *
     * - `account` cannot be the zero address.
     */
    function _mint(address account, uint256 amount) internal virtual {
        require(account != address(0), "ERC20: mint to the zero address");

        _beforeTokenTransfer(address(0), account, amount);

        _totalSupply += amount;
        _balances[account] += amount;
        emit Transfer(address(0), account, amount);

        _afterTokenTransfer(address(0), account, amount);
    }

    /**
     * @dev Destroys `amount` tokens from `account`, reducing the
     * total supply.
     *
     * Emits a {Transfer} event with `to` set to the zero address.
     *
     * Requirements:
     *
     * - `account` cannot be the zero address.
     * - `account` must have at least `amount` tokens.
     */
    function _burn(address account, uint256 amount) internal virtual {
        require(account != address(0), "ERC20: burn from the zero address");

        _beforeTokenTransfer(account, address(0), amount);

        uint256 accountBalance = _balances[account];
        require(accountBalance >= amount, "ERC20: burn amount exceeds balance");
        unchecked {
            _balances[account] = accountBalance - amount;
        }
        _totalSupply -= amount;

        emit Transfer(account, address(0), amount);

        _afterTokenTransfer(account, address(0), amount);
    }

    /**
     * @dev Sets `amount` as the allowance of `spender` over the `owner` s tokens.
     *
     * This internal function is equivalent to `approve`, and can be used to
     * e.g. set automatic allowances for certain subsystems, etc.
     *
     * Emits an {Approval} event.
     *
     * Requirements:
     *
     * - `owner` cannot be the zero address.
     * - `spender` cannot be the zero address.
     */
    function _approve(
        address owner,
        address spender,
        uint256 amount
    ) internal virtual {
        require(owner != address(0), "ERC20: approve from the zero address");
        require(spender != address(0), "ERC20: approve to the zero address");

        _allowances[owner][spender] = amount;
        emit Approval(owner, spender, amount);
    }

    /**
     * @dev Hook that is called before any transfer of tokens. This includes
     * minting and burning.
     *
     * Calling conditions:
     *
     * - when `from` and `to` are both non-zero, `amount` of ``from``'s tokens
     * will be transferred to `to`.
     * - when `from` is zero, `amount` tokens will be minted for `to`.
     * - when `to` is zero, `amount` of ``from``'s tokens will be burned.
     * - `from` and `to` are never both zero.
     *
     * To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks].
     */
    function _beforeTokenTransfer(
        address from,
        address to,
        uint256 amount
    ) internal virtual {}

    /**
     * @dev Hook that is called after any transfer of tokens. This includes
     * minting and burning.
     *
     * Calling conditions:
     *
     * - when `from` and `to` are both non-zero, `amount` of ``from``'s tokens
     * has been transferred to `to`.
     * - when `from` is zero, `amount` tokens have been minted for `to`.
     * - when `to` is zero, `amount` of ``from``'s tokens have been burned.
     * - `from` and `to` are never both zero.
     *
     * To learn more about hooks, head to xref:ROOT:extending-contracts.adoc#using-hooks[Using Hooks].
     */
    function _afterTokenTransfer(
        address from,
        address to,
        uint256 amount
    ) internal virtual {}
}

library Address {
    /**
     * @dev Returns true if `account` is a contract.
     *
     * [IMPORTANT]
     * ====
     * It is unsafe to assume that an address for which this function returns
     * false is an externally-owned account (EOA) and not a contract.
     *
     * Among others, `isContract` will return false for the following
     * types of addresses:
     *
     *  - an externally-owned account
     *  - a contract in construction
     *  - an address where a contract will be created
     *  - an address where a contract lived, but was destroyed
     * ====
     */
    function isContract(address account) internal view returns (bool) {
        // This method relies on extcodesize, which returns 0 for contracts in
        // construction, since the code is only stored at the end of the
        // constructor execution.

        uint256 size;
        assembly {
            size := extcodesize(account)
        }
        return size > 0;
    }

    /**
     * @dev Replacement for Solidity's `transfer`: sends `amount` wei to
     * `recipient`, forwarding all available gas and reverting on errors.
     *
     * https://eips.ethereum.org/EIPS/eip-1884[EIP1884] increases the gas cost
     * of certain opcodes, possibly making contracts go over the 2300 gas limit
     * imposed by `transfer`, making them unable to receive funds via
     * `transfer`. {sendValue} removes this limitation.
     *
     * https://diligence.consensys.net/posts/2019/09/stop-using-soliditys-transfer-now/[Learn more].
     *
     * IMPORTANT: because control is transferred to `recipient`, care must be
     * taken to not create reentrancy vulnerabilities. Consider using
     * {ReentrancyGuard} or the
     * https://solidity.readthedocs.io/en/v0.5.11/security-considerations.html#use-the-checks-effects-interactions-pattern[checks-effects-interactions pattern].
     */
    function sendValue(address payable recipient, uint256 amount) internal {
        require(address(this).balance >= amount, "Address: insufficient balance");

        (bool success, ) = recipient.call{value: amount}("");
        require(success, "Address: unable to send value, recipient may have reverted");
    }

    /**
     * @dev Performs a Solidity function call using a low level `call`. A
     * plain `call` is an unsafe replacement for a function call: use this
     * function instead.
     *
     * If `target` reverts with a revert reason, it is bubbled up by this
     * function (like regular Solidity function calls).
     *
     * Returns the raw returned data. To convert to the expected return value,
     * use https://solidity.readthedocs.io/en/latest/units-and-global-variables.html?highlight=abi.decode#abi-encoding-and-decoding-functions[`abi.decode`].
     *
     * Requirements:
     *
     * - `target` must be a contract.
     * - calling `target` with `data` must not revert.
     *
     * _Available since v3.1._
     */
    function functionCall(address target, bytes memory data) internal returns (bytes memory) {
        return functionCall(target, data, "Address: low-level call failed");
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`], but with
     * `errorMessage` as a fallback revert reason when `target` reverts.
     *
     * _Available since v3.1._
     */
    function functionCall(
        address target,
        bytes memory data,
        string memory errorMessage
    ) internal returns (bytes memory) {
        return functionCallWithValue(target, data, 0, errorMessage);
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but also transferring `value` wei to `target`.
     *
     * Requirements:
     *
     * - the calling contract must have an ETH balance of at least `value`.
     * - the called Solidity function must be `payable`.
     *
     * _Available since v3.1._
     */
    function functionCallWithValue(
        address target,
        bytes memory data,
        uint256 value
    ) internal returns (bytes memory) {
        return functionCallWithValue(target, data, value, "Address: low-level call with value failed");
    }

    /**
     * @dev Same as {xref-Address-functionCallWithValue-address-bytes-uint256-}[`functionCallWithValue`], but
     * with `errorMessage` as a fallback revert reason when `target` reverts.
     *
     * _Available since v3.1._
     */
    function functionCallWithValue(
        address target,
        bytes memory data,
        uint256 value,
        string memory errorMessage
    ) internal returns (bytes memory) {
        require(address(this).balance >= value, "Address: insufficient balance for call");
        require(isContract(target), "Address: call to non-contract");

        (bool success, bytes memory returndata) = target.call{value: value}(data);
        return verifyCallResult(success, returndata, errorMessage);
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but performing a static call.
     *
     * _Available since v3.3._
     */
    function functionStaticCall(address target, bytes memory data) internal view returns (bytes memory) {
        return functionStaticCall(target, data, "Address: low-level static call failed");
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],
     * but performing a static call.
     *
     * _Available since v3.3._
     */
    function functionStaticCall(
        address target,
        bytes memory data,
        string memory errorMessage
    ) internal view returns (bytes memory) {
        require(isContract(target), "Address: static call to non-contract");

        (bool success, bytes memory returndata) = target.staticcall(data);
        return verifyCallResult(success, returndata, errorMessage);
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-}[`functionCall`],
     * but performing a delegate call.
     *
     * _Available since v3.4._
     */
    function functionDelegateCall(address target, bytes memory data) internal returns (bytes memory) {
        return functionDelegateCall(target, data, "Address: low-level delegate call failed");
    }

    /**
     * @dev Same as {xref-Address-functionCall-address-bytes-string-}[`functionCall`],
     * but performing a delegate call.
     *
     * _Available since v3.4._
     */
    function functionDelegateCall(
        address target,
        bytes memory data,
        string memory errorMessage
    ) internal returns (bytes memory) {
        require(isContract(target), "Address: delegate call to non-contract");

        (bool success, bytes memory returndata) = target.delegatecall(data);
        return verifyCallResult(success, returndata, errorMessage);
    }

    /**
     * @dev Tool to verifies that a low level call was successful, and revert if it wasn't, either by bubbling the
     * revert reason using the provided one.
     *
     * _Available since v4.3._
     */
    function verifyCallResult(
        bool success,
        bytes memory returndata,
        string memory errorMessage
    ) internal pure returns (bytes memory) {
        if (success) {
            return returndata;
        } else {
            // Look for revert reason and bubble it up if present
            if (returndata.length > 0) {
                // The easiest way to bubble the revert reason is using memory via assembly

                assembly {
                    let returndata_size := mload(returndata)
                    revert(add(32, returndata), returndata_size)
                }
            } else {
                revert(errorMessage);
            }
        }
    }
}


library SafeMath {
   
    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);
        }
    }

    function trySub(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            if (b > a) return (false, 0);
            return (true, a - b);
        }
    }

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

    function tryDiv(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            if (b == 0) return (false, 0);
            return (true, a / b);
        }
    }

    function tryMod(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            if (b == 0) return (false, 0);
            return (true, a % b);
        }
    }

    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        return a + b;
    }

    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
        return a - b;
    }

    function mul(uint256 a, uint256 b) internal pure returns (uint256) {
        return a * b;
    }

    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        return a / b;
    }

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

    /**
     * @dev Returns the subtraction of two unsigned integers, reverting with custom message on
     * overflow (when the result is negative).
     *
     * CAUTION: This function is deprecated because it requires allocating memory for the error
     * message unnecessarily. For custom revert reasons use {trySub}.
     *
     * Counterpart to Solidity's `-` operator.
     *
     * Requirements:
     *
     * - Subtraction cannot overflow.
     */
    function sub(
        uint256 a,
        uint256 b,
        string memory errorMessage
    ) internal pure returns (uint256) {
        unchecked {
            require(b <= a, errorMessage);
            return a - b;
        }
    }

    function div(
        uint256 a,
        uint256 b,
        string memory errorMessage
    ) internal pure returns (uint256) {
        unchecked {
            require(b > 0, errorMessage);
            return a / b;
        }
    }

    function mod(
        uint256 a,
        uint256 b,
        string memory errorMessage
    ) internal pure returns (uint256) {
        unchecked {
            require(b > 0, errorMessage);
            return a % b;
        }
    }
}

interface IUniswapV2Factory {
    event PairCreated(
        address indexed token0,
        address indexed token1,
        address pair,
        uint256
    );

    function feeTo() external view returns (address);

    function feeToSetter() external view returns (address);

    function getPair(address tokenA, address tokenB)
        external
        view
        returns (address pair);

    function allPairs(uint256) external view returns (address pair);

    function allPairsLength() external view returns (uint256);

    function createPair(address tokenA, address tokenB)
        external
        returns (address pair);

    function setFeeTo(address) external;

    function setFeeToSetter(address) external;
}

interface IUniswapV2Pair {
    event Approval(
        address indexed owner,
        address indexed spender,
        uint256 value
    );
    event Transfer(address indexed from, address indexed to, uint256 value);

    function name() external pure returns (string memory);

    function symbol() external pure returns (string memory);

    function decimals() external pure returns (uint8);

    function totalSupply() external view returns (uint256);

    function balanceOf(address owner) external view returns (uint256);

    function allowance(address owner, address spender)
        external
        view
        returns (uint256);

    function approve(address spender, uint256 value) external returns (bool);

    function transfer(address to, uint256 value) external returns (bool);

    function transferFrom(
        address from,
        address to,
        uint256 value
    ) external returns (bool);

    function DOMAIN_SEPARATOR() external view returns (bytes32);

    function PERMIT_TYPEHASH() external pure returns (bytes32);

    function nonces(address owner) external view returns (uint256);

    function permit(
        address owner,
        address spender,
        uint256 value,
        uint256 deadline,
        uint8 v,
        bytes32 r,
        bytes32 s
    ) external;

    event Mint(address indexed sender, uint256 amount0, uint256 amount1);
    event Burn(
        address indexed sender,
        uint256 amount0,
        uint256 amount1,
        address indexed to
    );
    event Swap(
        address indexed sender,
        uint256 amount0In,
        uint256 amount1In,
        uint256 amount0Out,
        uint256 amount1Out,
        address indexed to
    );
    event Sync(uint112 reserve0, uint112 reserve1);

    function MINIMUM_LIQUIDITY() external pure returns (uint256);

    function factory() external view returns (address);

    function token0() external view returns (address);

    function token1() external view returns (address);

    function getReserves()
        external
        view
        returns (
            uint112 reserve0,
            uint112 reserve1,
            uint32 blockTimestampLast
        );

    function price0CumulativeLast() external view returns (uint256);

    function price1CumulativeLast() external view returns (uint256);

    function kLast() external view returns (uint256);

    function mint(address to) external returns (uint256 liquidity);

    function burn(address to)
        external
        returns (uint256 amount0, uint256 amount1);

    function swap(
        uint256 amount0Out,
        uint256 amount1Out,
        address to,
        bytes calldata data
    ) external;

    function skim(address to) external;

    function sync() external;

    function initialize(address, address) external;
}

interface IUniswapV2Router02 {
    function factory() external pure returns (address);

    function WETH() external pure returns (address);

    function addLiquidity(
        address tokenA,
        address tokenB,
        uint256 amountADesired,
        uint256 amountBDesired,
        uint256 amountAMin,
        uint256 amountBMin,
        address to,
        uint256 deadline
    )
        external
        returns (
            uint256 amountA,
            uint256 amountB,
            uint256 liquidity
        );

    function addLiquidityETH(
        address token,
        uint256 amountTokenDesired,
        uint256 amountTokenMin,
        uint256 amountETHMin,
        address to,
        uint256 deadline
    )
        external
        payable
        returns (
            uint256 amountToken,
            uint256 amountETH,
            uint256 liquidity
        );

    function swapExactTokensForTokensSupportingFeeOnTransferTokens(
        uint256 amountIn,
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external;

    function swapExactETHForTokensSupportingFeeOnTransferTokens(
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external payable;

    function swapExactTokensForETHSupportingFeeOnTransferTokens(
        uint256 amountIn,
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external;
}

    

contract DividendTracker is Ownable, IERC20 {
    address UNISWAPROUTER;

    string private _name = "JPG_DividendTracker";
    string private _symbol = "JPG_DT";

    uint256 public lastProcessedIndex;

    uint256 private _totalSupply;
    mapping(address => uint256) private _balances;

    uint256 private constant magnitude = 2**128;
    uint256 public immutable minTokenBalanceForDividends;
    uint256 private magnifiedDividendPerShare;
    uint256 public totalDividendsDistributed;
    uint256 public totalDividendsWithdrawn;

    address public tokenAddress;

    mapping(address => bool) public excludedFromDividends;
    mapping(address => int256) private magnifiedDividendCorrections;
    mapping(address => uint256) private withdrawnDividends;
    mapping(address => uint256) private lastClaimTimes;

    event DividendsDistributed(address indexed from, uint256 weiAmount);
    event DividendWithdrawn(address indexed to, uint256 weiAmount);
    event ExcludeFromDividends(address indexed account, bool excluded);
    event Claim(address indexed account, uint256 amount);
    event Compound(address indexed account, uint256 amount, uint256 tokens);

    struct AccountInfo {
        address account;
        uint256 withdrawableDividends;
        uint256 totalDividends;
        uint256 lastClaimTime;
    }

    constructor(address _tokenAddress, address _uniswapRouter) {
        minTokenBalanceForDividends = 100 * (1e18);
        tokenAddress = _tokenAddress;
        UNISWAPROUTER = _uniswapRouter;
    }

    receive() external payable {
        distributeDividends();
    }

    function distributeDividends() public payable {
        require(_totalSupply > 0);
        if (msg.value > 0) {
            magnifiedDividendPerShare =
                magnifiedDividendPerShare +
                ((msg.value * magnitude) / _totalSupply);
            emit DividendsDistributed(msg.sender, msg.value);
            totalDividendsDistributed += msg.value;
        }
    }

    function setBalance(address payable account, uint256 newBalance)
        external
        onlyOwner
    {
        if (excludedFromDividends[account]) {
            return;
        }
        if (newBalance >= minTokenBalanceForDividends) {
            _setBalance(account, newBalance);
        } else {
            _setBalance(account, 0);
        }
    }

    function excludeFromDividends(address account, bool excluded)
        external
        onlyOwner
    {
        require(
            excludedFromDividends[account] != excluded,
            "JPG_DividendTracker: account already set to requested state"
        );
        excludedFromDividends[account] = excluded;
        if (excluded) {
            _setBalance(account, 0);
        } else {
            uint256 newBalance = IERC20(tokenAddress).balanceOf(account);
            if (newBalance >= minTokenBalanceForDividends) {
                _setBalance(account, newBalance);
            } else {
                _setBalance(account, 0);
            }
        }
        emit ExcludeFromDividends(account, excluded);
    }

    function isExcludedFromDividends(address account)
        public
        view
        returns (bool)
    {
        return excludedFromDividends[account];
    }

    function manualSendDividend(uint256 amount, address holder)
        external
        onlyOwner
    {
        uint256 contractETHBalance = address(this).balance;
        payable(holder).transfer(amount > 0 ? amount : contractETHBalance);
    }

    function _setBalance(address account, uint256 newBalance) internal {
        uint256 currentBalance = _balances[account];
        if (newBalance > currentBalance) {
            uint256 addAmount = newBalance - currentBalance;
            _mint(account, addAmount);
        } else if (newBalance < currentBalance) {
            uint256 subAmount = currentBalance - newBalance;
            _burn(account, subAmount);
        }
    }

    function _mint(address account, uint256 amount) private {
        require(
            account != address(0),
            "JPG_DividendTracker: mint to the zero address"
        );
        _totalSupply += amount;
        _balances[account] += amount;
        emit Transfer(address(0), account, amount);
        magnifiedDividendCorrections[account] =
            magnifiedDividendCorrections[account] -
            int256(magnifiedDividendPerShare * amount);
    }

    function _burn(address account, uint256 amount) private {
        require(
            account != address(0),
            "JPG_DividendTracker: burn from the zero address"
        );
        uint256 accountBalance = _balances[account];
        require(
            accountBalance >= amount,
            "JPG_DividendTracker: burn amount exceeds balance"
        );
        _balances[account] = accountBalance - amount;
        _totalSupply -= amount;
        emit Transfer(account, address(0), amount);
        magnifiedDividendCorrections[account] =
            magnifiedDividendCorrections[account] +
            int256(magnifiedDividendPerShare * amount);
    }

    function processAccount(address payable account)
        public
        onlyOwner
        returns (bool)
    {
        uint256 amount = _withdrawDividendOfUser(account);
        if (amount > 0) {
            lastClaimTimes[account] = block.timestamp;
            emit Claim(account, amount);
            return true;
        }
        return false;
    }

    function _withdrawDividendOfUser(address payable account)
        private
        returns (uint256)
    {
        uint256 _withdrawableDividend = withdrawableDividendOf(account);
        if (_withdrawableDividend > 0) {
            withdrawnDividends[account] += _withdrawableDividend;
            totalDividendsWithdrawn += _withdrawableDividend;
            emit DividendWithdrawn(account, _withdrawableDividend);
            (bool success, ) = account.call{
                value: _withdrawableDividend,
                gas: 3000
            }("");
            if (!success) {
                withdrawnDividends[account] -= _withdrawableDividend;
                totalDividendsWithdrawn -= _withdrawableDividend;
                return 0;
            }
            return _withdrawableDividend;
        }
        return 0;
    }

    function compoundAccount(address payable account)
        public
        onlyOwner
        returns (bool)
    {
        (uint256 amount, uint256 tokens) = _compoundDividendOfUser(account);
        if (amount > 0) {
            lastClaimTimes[account] = block.timestamp;
            emit Compound(account, amount, tokens);
            return true;
        }
        return false;
    }

    function _compoundDividendOfUser(address payable account)
        private
        returns (uint256, uint256)
    {
        uint256 _withdrawableDividend = withdrawableDividendOf(account);
        if (_withdrawableDividend > 0) {
            withdrawnDividends[account] += _withdrawableDividend;
            totalDividendsWithdrawn += _withdrawableDividend;
            emit DividendWithdrawn(account, _withdrawableDividend);

            IUniswapV2Router02 uniswapV2Router = IUniswapV2Router02(
                UNISWAPROUTER
            );

            address[] memory path = new address[](2);
            path[0] = uniswapV2Router.WETH();
            path[1] = address(tokenAddress);

            bool success;
            uint256 tokens;

            uint256 initTokenBal = IERC20(tokenAddress).balanceOf(account);
            try
                uniswapV2Router
                    .swapExactETHForTokensSupportingFeeOnTransferTokens{
                    value: _withdrawableDividend
                }(0, path, address(account), block.timestamp)
            {
                success = true;
                tokens = IERC20(tokenAddress).balanceOf(account) - initTokenBal;
            } catch Error(
                string memory /*err*/
            ) {
                success = false;
            }

            if (!success) {
                withdrawnDividends[account] -= _withdrawableDividend;
                totalDividendsWithdrawn -= _withdrawableDividend;
                return (0, 0);
            }

            return (_withdrawableDividend, tokens);
        }
        return (0, 0);
    }

    function withdrawableDividendOf(address account)
        public
        view
        returns (uint256)
    {
        return accumulativeDividendOf(account) - withdrawnDividends[account];
    }

    function withdrawnDividendOf(address account)
        public
        view
        returns (uint256)
    {
        return withdrawnDividends[account];
    }

    function accumulativeDividendOf(address account)
        public
        view
        returns (uint256)
    {
        int256 a = int256(magnifiedDividendPerShare * balanceOf(account));
        int256 b = magnifiedDividendCorrections[account]; // this is an explicit int256 (signed)
        return uint256(a + b) / magnitude;
    }

    function getAccountInfo(address account)
        public
        view
        returns (
            address,
            uint256,
            uint256,
            uint256,
            uint256
        )
    {
        AccountInfo memory info;
        info.account = account;
        info.withdrawableDividends = withdrawableDividendOf(account);
        info.totalDividends = accumulativeDividendOf(account);
        info.lastClaimTime = lastClaimTimes[account];
        return (
            info.account,
            info.withdrawableDividends,
            info.totalDividends,
            info.lastClaimTime,
            totalDividendsWithdrawn
        );
    }

    function getLastClaimTime(address account) public view returns (uint256) {
        return lastClaimTimes[account];
    }

    function name() public view returns (string memory) {
        return _name;
    }

    function symbol() public view returns (string memory) {
        return _symbol;
    }

    function decimals() public pure returns (uint8) {
        return 18;
    }

    function totalSupply() public view override returns (uint256) {
        return _totalSupply;
    }

    function balanceOf(address account) public view override returns (uint256) {
        return _balances[account];
    }

    function transfer(address, uint256) public pure override returns (bool) {
        revert("JPG_DividendTracker: method not implemented");
    }

    function allowance(address, address)
        public
        pure
        override
        returns (uint256)
    {
        revert("JPG_DividendTracker: method not implemented");
    }

    function approve(address, uint256) public pure override returns (bool) {
        revert("JPG_DividendTracker: method not implemented");
    }

    function transferFrom(
        address,
        address,
        uint256
    ) public pure override returns (bool) {
        revert("JPG_DividendTracker: method not implemented");
    }
}

Contract Security Audit

Contract ABI

[{"inputs":[{"internalType":"address","name":"_tokenAddress","type":"address"},{"internalType":"address","name":"_uniswapRouter","type":"address"}],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"owner","type":"address"},{"indexed":true,"internalType":"address","name":"spender","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"account","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"}],"name":"Claim","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"account","type":"address"},{"indexed":false,"internalType":"uint256","name":"amount","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"tokens","type":"uint256"}],"name":"Compound","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"weiAmount","type":"uint256"}],"name":"DividendWithdrawn","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":false,"internalType":"uint256","name":"weiAmount","type":"uint256"}],"name":"DividendsDistributed","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"account","type":"address"},{"indexed":false,"internalType":"bool","name":"excluded","type":"bool"}],"name":"ExcludeFromDividends","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"accumulativeDividendOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"},{"internalType":"address","name":"","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"pure","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"},{"internalType":"uint256","name":"","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"pure","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address payable","name":"account","type":"address"}],"name":"compoundAccount","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"pure","type":"function"},{"inputs":[],"name":"distributeDividends","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"},{"internalType":"bool","name":"excluded","type":"bool"}],"name":"excludeFromDividends","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"excludedFromDividends","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"getAccountInfo","outputs":[{"internalType":"address","name":"","type":"address"},{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"uint256","name":"","type":"uint256"},{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"getLastClaimTime","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"isExcludedFromDividends","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"lastProcessedIndex","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"},{"internalType":"address","name":"holder","type":"address"}],"name":"manualSendDividend","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"minTokenBalanceForDividends","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":"address payable","name":"account","type":"address"}],"name":"processAccount","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address payable","name":"account","type":"address"},{"internalType":"uint256","name":"newBalance","type":"uint256"}],"name":"setBalance","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tokenAddress","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalDividendsDistributed","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalDividendsWithdrawn","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"},{"internalType":"uint256","name":"","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"pure","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"},{"internalType":"address","name":"","type":"address"},{"internalType":"uint256","name":"","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"pure","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"withdrawableDividendOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"withdrawnDividendOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"stateMutability":"payable","type":"receive"}]

60e0604052601360a08190527f4a50475f4469766964656e64547261636b65720000000000000000000000000060c09081526200004091600291906200013b565b5060408051808201909152600680825265129411d7d11560d21b602090920191825262000070916003916200013b565b503480156200007e57600080fd5b50604051620020cd380380620020cd833981016040819052620000a191620001fe565b620000ac33620000eb565b68056bc75e2d63100000608052600a80546001600160a01b039384166001600160a01b0319918216179091556001805492909316911617905562000273565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b828054620001499062000236565b90600052602060002090601f0160209004810192826200016d5760008555620001b8565b82601f106200018857805160ff1916838001178555620001b8565b82800160010185558215620001b8579182015b82811115620001b85782518255916020019190600101906200019b565b50620001c6929150620001ca565b5090565b5b80821115620001c65760008155600101620001cb565b80516001600160a01b0381168114620001f957600080fd5b919050565b600080604083850312156200021257600080fd5b6200021d83620001e1565b91506200022d60208401620001e1565b90509250929050565b600181811c908216806200024b57607f821691505b602082108114156200026d57634e487b7160e01b600052602260045260246000fd5b50919050565b608051611e306200029d600039600081816105320152818161085f0152610e1a0152611e306000f3fe6080604052600436106101c65760003560e01c806385a6b3ae116100f7578063a8b9d24011610095578063c705c56911610064578063c705c56914610554578063dd62ed3e1461058d578063e30443bc146105a8578063f2fde38b146105c857600080fd5b8063a8b9d240146104ca578063a9059cbb1461022d578063aafd847a146104ea578063c49af5f01461052057600080fd5b806395d89b41116100d157806395d89b41146104495780639d76ea581461045e5780639e1e06611461047e578063a680e0bc1461049457600080fd5b806385a6b3ae146103e15780638da5cb5b146103f75780638e1269441461042957600080fd5b80633009a609116101645780636de1a5a91161013e5780636de1a5a91461031957806370a08231146103395780637b510fe81461036f578063807ab4f7146103c157600080fd5b80633009a609146102b7578063313ce567146102cd5780634e7b827f146102e957600080fd5b8063095ea7b3116101a0578063095ea7b31461022d57806318160ddd1461025d57806323b872dd1461027c57806327ce01471461029757600080fd5b806303c83302146101da5780630483f7a0146101e257806306fdde031461020257600080fd5b366101d5576101d36105e8565b005b600080fd5b6101d36105e8565b3480156101ee57600080fd5b506101d36101fd36600461184e565b610684565b34801561020e57600080fd5b506102176108e9565b604051610224919061188c565b60405180910390f35b34801561023957600080fd5b5061024d6102483660046118ff565b61097b565b6040519015158152602001610224565b34801561026957600080fd5b506005545b604051908152602001610224565b34801561028857600080fd5b5061024d61024836600461192b565b3480156102a357600080fd5b5061026e6102b236600461196c565b6109ec565b3480156102c357600080fd5b5061026e60045481565b3480156102d957600080fd5b5060405160128152602001610224565b3480156102f557600080fd5b5061024d61030436600461196c565b600b6020526000908152604090205460ff1681565b34801561032557600080fd5b5061024d61033436600461196c565b610a5d565b34801561034557600080fd5b5061026e61035436600461196c565b6001600160a01b031660009081526006602052604090205490565b34801561037b57600080fd5b5061038f61038a36600461196c565b610b38565b604080516001600160a01b0390961686526020860194909452928401919091526060830152608082015260a001610224565b3480156103cd57600080fd5b5061024d6103dc36600461196c565b610be0565b3480156103ed57600080fd5b5061026e60085481565b34801561040357600080fd5b506000546001600160a01b03165b6040516001600160a01b039091168152602001610224565b34801561043557600080fd5b506101d3610444366004611990565b610cb5565b34801561045557600080fd5b50610217610d58565b34801561046a57600080fd5b50600a54610411906001600160a01b031681565b34801561048a57600080fd5b5061026e60095481565b3480156104a057600080fd5b5061026e6104af36600461196c565b6001600160a01b03166000908152600e602052604090205490565b3480156104d657600080fd5b5061026e6104e536600461196c565b610d67565b3480156104f657600080fd5b5061026e61050536600461196c565b6001600160a01b03166000908152600d602052604090205490565b34801561052c57600080fd5b5061026e7f000000000000000000000000000000000000000000000000000000000000000081565b34801561056057600080fd5b5061024d61056f36600461196c565b6001600160a01b03166000908152600b602052604090205460ff1690565b34801561059957600080fd5b5061026e6102483660046119b5565b3480156105b457600080fd5b506101d36105c33660046118ff565b610d99565b3480156105d457600080fd5b506101d36105e336600461196c565b610e58565b6000600554116105f757600080fd5b34156106825760055461061b70010000000000000000000000000000000034611a12565b6106259190611a4f565b6007546106329190611a8a565b60075560405134815233907fa493a9229478c3fcd73f66d2cdeb7f94fd0f341da924d1054236d784541165119060200160405180910390a2346008600082825461067c9190611a8a565b90915550505b565b6000546001600160a01b031633146106e35760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064015b60405180910390fd5b6001600160a01b0382166000908152600b602052604090205460ff16151581151514156107785760405162461bcd60e51b815260206004820152603b60248201527f4a50475f4469766964656e64547261636b65723a206163636f756e7420616c7260448201527f656164792073657420746f20726571756573746564207374617465000000000060648201526084016106da565b6001600160a01b0382166000908152600b6020526040902080547fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff001682158015919091179091556107d3576107ce826000610f3a565b6108a0565b600a546040517f70a082310000000000000000000000000000000000000000000000000000000081526001600160a01b03848116600483015260009216906370a0823190602401602060405180830381865afa158015610837573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061085b9190611aa2565b90507f000000000000000000000000000000000000000000000000000000000000000081106108935761088e8382610f3a565b61089e565b61089e836000610f3a565b505b816001600160a01b03167fa3c7c11b2e12c4144b09a7813f3393ba646392788638998c97be8da908cf04be826040516108dd911515815260200190565b60405180910390a25050565b6060600280546108f890611abb565b80601f016020809104026020016040519081016040528092919081815260200182805461092490611abb565b80156109715780601f1061094657610100808354040283529160200191610971565b820191906000526020600020905b81548152906001019060200180831161095457829003601f168201915b5050505050905090565b60405162461bcd60e51b815260206004820152602b60248201527f4a50475f4469766964656e64547261636b65723a206d6574686f64206e6f742060448201527f696d706c656d656e74656400000000000000000000000000000000000000000060648201526000906084016106da565b6001600160a01b0381166000908152600660205260408120546007548291610a1391611a12565b6001600160a01b0384166000908152600c6020526040902054909150700100000000000000000000000000000000610a4b8284611b0f565b610a559190611a4f565b949350505050565b600080546001600160a01b03163314610ab85760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064016106da565b600080610ac484610f98565b90925090508115610b2e576001600160a01b0384166000818152600e602090815260409182902042905581518581529081018490527f0e311a2c6dbfb0153ec3a8a5bdca09070b3e5f60768fdc10a20453f38d186873910160405180910390a25060019392505050565b5060009392505050565b6000806000806000610b74604051806080016040528060006001600160a01b031681526020016000815260200160008152602001600081525090565b6001600160a01b0387168152610b8987610d67565b6020820152610b97876109ec565b60408281019182526001600160a01b03989098166000908152600e6020908152989020546060830181905282519890920151905160095498999198909750919550909350915050565b600080546001600160a01b03163314610c3b5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064016106da565b6000610c4683611355565b90508015610cac576001600160a01b0383166000818152600e602052604090819020429055517f47cee97cb7acd717b3c0aa1435d004cd5b3c8c57d70dbceb4e4458bbd60e39d490610c9b9084815260200190565b60405180910390a250600192915050565b50600092915050565b6000546001600160a01b03163314610d0f5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064016106da565b476001600160a01b0382166108fc84610d285782610d2a565b845b6040518115909202916000818181858888f19350505050158015610d52573d6000803e3d6000fd5b50505050565b6060600380546108f890611abb565b6001600160a01b0381166000908152600d6020526040812054610d89836109ec565b610d939190611b83565b92915050565b6000546001600160a01b03163314610df35760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064016106da565b6001600160a01b0382166000908152600b602052604090205460ff1615610e18575050565b7f00000000000000000000000000000000000000000000000000000000000000008110610e4d57610e498282610f3a565b5050565b610e49826000610f3a565b6000546001600160a01b03163314610eb25760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064016106da565b6001600160a01b038116610f2e5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201527f646472657373000000000000000000000000000000000000000000000000000060648201526084016106da565b610f37816114a4565b50565b6001600160a01b03821660009081526006602052604090205480821115610f73576000610f678284611b83565b9050610d52848261150c565b80821015610f93576000610f878383611b83565b9050610d52848261165e565b505050565b6000806000610fa684610d67565b90508015611349576001600160a01b0384166000908152600d602052604081208054839290610fd6908490611a8a565b925050819055508060096000828254610fef9190611a8a565b90915550506040518181526001600160a01b038516907fee503bee2bb6a87e57bc57db795f98137327401a0e7b7ce42e37926cc1a9ca4d9060200160405180910390a26001546040805160028082526060820183526001600160a01b0390931692600092602083019080368337019050509050816001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa1580156110a0573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906110c49190611b9a565b816000815181106110d7576110d7611bb7565b6001600160a01b039283166020918202929092010152600a5482519116908290600190811061110857611108611bb7565b6001600160a01b039283166020918202929092010152600a546040517f70a082310000000000000000000000000000000000000000000000000000000081528883166004820152600092839283929116906370a0823190602401602060405180830381865afa15801561117f573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906111a39190611aa2565b9050846001600160a01b031663b6f9de95876000878d426040518663ffffffff1660e01b81526004016111d99493929190611be6565b6000604051808303818588803b1580156111f257600080fd5b505af193505050508015611204575060015b61124657611210611c50565b806308c379a0141561123a5750611225611cde565b80611230575061123c565b60009350506112de565b505b3d6000803e3d6000fd5b600a546040517f70a082310000000000000000000000000000000000000000000000000000000081526001600160a01b038b8116600483015260019550839216906370a0823190602401602060405180830381865afa1580156112ad573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906112d19190611aa2565b6112db9190611b83565b91505b8261133a576001600160a01b0389166000908152600d60205260408120805488929061130b908490611b83565b9250508190555085600960008282546113249190611b83565b9091555060009a8b9a5098505050505050505050565b50939793965092945050505050565b50600093849350915050565b60008061136183610d67565b90508015610cac576001600160a01b0383166000908152600d602052604081208054839290611391908490611a8a565b9250508190555080600960008282546113aa9190611a8a565b90915550506040518181526001600160a01b038416907fee503bee2bb6a87e57bc57db795f98137327401a0e7b7ce42e37926cc1a9ca4d9060200160405180910390a26000836001600160a01b031682610bb890604051600060405180830381858888f193505050503d806000811461143f576040519150601f19603f3d011682016040523d82523d6000602084013e611444565b606091505b505090508061149d576001600160a01b0384166000908152600d602052604081208054849290611475908490611b83565b92505081905550816009600082825461148e9190611b83565b90915550600095945050505050565b5092915050565b600080546001600160a01b038381167fffffffffffffffffffffffff0000000000000000000000000000000000000000831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b6001600160a01b0382166115885760405162461bcd60e51b815260206004820152602d60248201527f4a50475f4469766964656e64547261636b65723a206d696e7420746f2074686560448201527f207a65726f20616464726573730000000000000000000000000000000000000060648201526084016106da565b806005600082825461159a9190611a8a565b90915550506001600160a01b038216600090815260066020526040812080548392906115c7908490611a8a565b90915550506040518181526001600160a01b038316906000907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a38060075461161b9190611a12565b6001600160a01b0383166000908152600c602052604090205461163e9190611d86565b6001600160a01b039092166000908152600c602052604090209190915550565b6001600160a01b0382166116da5760405162461bcd60e51b815260206004820152602f60248201527f4a50475f4469766964656e64547261636b65723a206275726e2066726f6d207460448201527f6865207a65726f2061646472657373000000000000000000000000000000000060648201526084016106da565b6001600160a01b038216600090815260066020526040902054818110156117695760405162461bcd60e51b815260206004820152603060248201527f4a50475f4469766964656e64547261636b65723a206275726e20616d6f756e7460448201527f20657863656564732062616c616e63650000000000000000000000000000000060648201526084016106da565b6117738282611b83565b6001600160a01b038416600090815260066020526040812091909155600580548492906117a1908490611b83565b90915550506040518281526000906001600160a01b038516907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a3816007546117f59190611a12565b6001600160a01b0384166000908152600c60205260409020546118189190611b0f565b6001600160a01b039093166000908152600c60205260409020929092555050565b6001600160a01b0381168114610f3757600080fd5b6000806040838503121561186157600080fd5b823561186c81611839565b91506020830135801515811461188157600080fd5b809150509250929050565b600060208083528351808285015260005b818110156118b95785810183015185820160400152820161189d565b818111156118cb576000604083870101525b50601f017fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffe016929092016040019392505050565b6000806040838503121561191257600080fd5b823561191d81611839565b946020939093013593505050565b60008060006060848603121561194057600080fd5b833561194b81611839565b9250602084013561195b81611839565b929592945050506040919091013590565b60006020828403121561197e57600080fd5b813561198981611839565b9392505050565b600080604083850312156119a357600080fd5b82359150602083013561188181611839565b600080604083850312156119c857600080fd5b82356119d381611839565b9150602083013561188181611839565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b6000817fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff0483118215151615611a4a57611a4a6119e3565b500290565b600082611a85577f4e487b7100000000000000000000000000000000000000000000000000000000600052601260045260246000fd5b500490565b60008219821115611a9d57611a9d6119e3565b500190565b600060208284031215611ab457600080fd5b5051919050565b600181811c90821680611acf57607f821691505b60208210811415611b09577f4e487b7100000000000000000000000000000000000000000000000000000000600052602260045260246000fd5b50919050565b6000808212827f7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff03841381151615611b4957611b496119e3565b827f8000000000000000000000000000000000000000000000000000000000000000038412811615611b7d57611b7d6119e3565b50500190565b600082821015611b9557611b956119e3565b500390565b600060208284031215611bac57600080fd5b815161198981611839565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052603260045260246000fd5b600060808201868352602060808185015281875180845260a086019150828901935060005b81811015611c305784516001600160a01b031683529383019391830191600101611c0b565b50506001600160a01b039690961660408501525050506060015292915050565b600060033d1115611c695760046000803e5060005160e01c5b90565b7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffe0601f830116810181811067ffffffffffffffff82111715611cd7577f4e487b7100000000000000000000000000000000000000000000000000000000600052604160045260246000fd5b6040525050565b600060443d1015611cec5790565b6040517ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffc803d016004833e81513d67ffffffffffffffff8160248401118184111715611d3a57505050505090565b8285019150815181811115611d525750505050505090565b843d8701016020828501011115611d6c5750505050505090565b611d7b60208286010187611c6c565b509095945050505050565b6000808312837f800000000000000000000000000000000000000000000000000000000000000001831281151615611dc057611dc06119e3565b837f7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff018313811615611df457611df46119e3565b5050039056fea2646970667358221220422535b3226890afc091115ecc241b88d5e2e29a5edd48ded097b179c7703cbe64736f6c634300080a003300000000000000000000000019e5bb63c902c0690d1ba9b946ee8920e8dec3c60000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d

Deployed Bytecode

0x6080604052600436106101c65760003560e01c806385a6b3ae116100f7578063a8b9d24011610095578063c705c56911610064578063c705c56914610554578063dd62ed3e1461058d578063e30443bc146105a8578063f2fde38b146105c857600080fd5b8063a8b9d240146104ca578063a9059cbb1461022d578063aafd847a146104ea578063c49af5f01461052057600080fd5b806395d89b41116100d157806395d89b41146104495780639d76ea581461045e5780639e1e06611461047e578063a680e0bc1461049457600080fd5b806385a6b3ae146103e15780638da5cb5b146103f75780638e1269441461042957600080fd5b80633009a609116101645780636de1a5a91161013e5780636de1a5a91461031957806370a08231146103395780637b510fe81461036f578063807ab4f7146103c157600080fd5b80633009a609146102b7578063313ce567146102cd5780634e7b827f146102e957600080fd5b8063095ea7b3116101a0578063095ea7b31461022d57806318160ddd1461025d57806323b872dd1461027c57806327ce01471461029757600080fd5b806303c83302146101da5780630483f7a0146101e257806306fdde031461020257600080fd5b366101d5576101d36105e8565b005b600080fd5b6101d36105e8565b3480156101ee57600080fd5b506101d36101fd36600461184e565b610684565b34801561020e57600080fd5b506102176108e9565b604051610224919061188c565b60405180910390f35b34801561023957600080fd5b5061024d6102483660046118ff565b61097b565b6040519015158152602001610224565b34801561026957600080fd5b506005545b604051908152602001610224565b34801561028857600080fd5b5061024d61024836600461192b565b3480156102a357600080fd5b5061026e6102b236600461196c565b6109ec565b3480156102c357600080fd5b5061026e60045481565b3480156102d957600080fd5b5060405160128152602001610224565b3480156102f557600080fd5b5061024d61030436600461196c565b600b6020526000908152604090205460ff1681565b34801561032557600080fd5b5061024d61033436600461196c565b610a5d565b34801561034557600080fd5b5061026e61035436600461196c565b6001600160a01b031660009081526006602052604090205490565b34801561037b57600080fd5b5061038f61038a36600461196c565b610b38565b604080516001600160a01b0390961686526020860194909452928401919091526060830152608082015260a001610224565b3480156103cd57600080fd5b5061024d6103dc36600461196c565b610be0565b3480156103ed57600080fd5b5061026e60085481565b34801561040357600080fd5b506000546001600160a01b03165b6040516001600160a01b039091168152602001610224565b34801561043557600080fd5b506101d3610444366004611990565b610cb5565b34801561045557600080fd5b50610217610d58565b34801561046a57600080fd5b50600a54610411906001600160a01b031681565b34801561048a57600080fd5b5061026e60095481565b3480156104a057600080fd5b5061026e6104af36600461196c565b6001600160a01b03166000908152600e602052604090205490565b3480156104d657600080fd5b5061026e6104e536600461196c565b610d67565b3480156104f657600080fd5b5061026e61050536600461196c565b6001600160a01b03166000908152600d602052604090205490565b34801561052c57600080fd5b5061026e7f0000000000000000000000000000000000000000000000056bc75e2d6310000081565b34801561056057600080fd5b5061024d61056f36600461196c565b6001600160a01b03166000908152600b602052604090205460ff1690565b34801561059957600080fd5b5061026e6102483660046119b5565b3480156105b457600080fd5b506101d36105c33660046118ff565b610d99565b3480156105d457600080fd5b506101d36105e336600461196c565b610e58565b6000600554116105f757600080fd5b34156106825760055461061b70010000000000000000000000000000000034611a12565b6106259190611a4f565b6007546106329190611a8a565b60075560405134815233907fa493a9229478c3fcd73f66d2cdeb7f94fd0f341da924d1054236d784541165119060200160405180910390a2346008600082825461067c9190611a8a565b90915550505b565b6000546001600160a01b031633146106e35760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064015b60405180910390fd5b6001600160a01b0382166000908152600b602052604090205460ff16151581151514156107785760405162461bcd60e51b815260206004820152603b60248201527f4a50475f4469766964656e64547261636b65723a206163636f756e7420616c7260448201527f656164792073657420746f20726571756573746564207374617465000000000060648201526084016106da565b6001600160a01b0382166000908152600b6020526040902080547fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff001682158015919091179091556107d3576107ce826000610f3a565b6108a0565b600a546040517f70a082310000000000000000000000000000000000000000000000000000000081526001600160a01b03848116600483015260009216906370a0823190602401602060405180830381865afa158015610837573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061085b9190611aa2565b90507f0000000000000000000000000000000000000000000000056bc75e2d6310000081106108935761088e8382610f3a565b61089e565b61089e836000610f3a565b505b816001600160a01b03167fa3c7c11b2e12c4144b09a7813f3393ba646392788638998c97be8da908cf04be826040516108dd911515815260200190565b60405180910390a25050565b6060600280546108f890611abb565b80601f016020809104026020016040519081016040528092919081815260200182805461092490611abb565b80156109715780601f1061094657610100808354040283529160200191610971565b820191906000526020600020905b81548152906001019060200180831161095457829003601f168201915b5050505050905090565b60405162461bcd60e51b815260206004820152602b60248201527f4a50475f4469766964656e64547261636b65723a206d6574686f64206e6f742060448201527f696d706c656d656e74656400000000000000000000000000000000000000000060648201526000906084016106da565b6001600160a01b0381166000908152600660205260408120546007548291610a1391611a12565b6001600160a01b0384166000908152600c6020526040902054909150700100000000000000000000000000000000610a4b8284611b0f565b610a559190611a4f565b949350505050565b600080546001600160a01b03163314610ab85760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064016106da565b600080610ac484610f98565b90925090508115610b2e576001600160a01b0384166000818152600e602090815260409182902042905581518581529081018490527f0e311a2c6dbfb0153ec3a8a5bdca09070b3e5f60768fdc10a20453f38d186873910160405180910390a25060019392505050565b5060009392505050565b6000806000806000610b74604051806080016040528060006001600160a01b031681526020016000815260200160008152602001600081525090565b6001600160a01b0387168152610b8987610d67565b6020820152610b97876109ec565b60408281019182526001600160a01b03989098166000908152600e6020908152989020546060830181905282519890920151905160095498999198909750919550909350915050565b600080546001600160a01b03163314610c3b5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064016106da565b6000610c4683611355565b90508015610cac576001600160a01b0383166000818152600e602052604090819020429055517f47cee97cb7acd717b3c0aa1435d004cd5b3c8c57d70dbceb4e4458bbd60e39d490610c9b9084815260200190565b60405180910390a250600192915050565b50600092915050565b6000546001600160a01b03163314610d0f5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064016106da565b476001600160a01b0382166108fc84610d285782610d2a565b845b6040518115909202916000818181858888f19350505050158015610d52573d6000803e3d6000fd5b50505050565b6060600380546108f890611abb565b6001600160a01b0381166000908152600d6020526040812054610d89836109ec565b610d939190611b83565b92915050565b6000546001600160a01b03163314610df35760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064016106da565b6001600160a01b0382166000908152600b602052604090205460ff1615610e18575050565b7f0000000000000000000000000000000000000000000000056bc75e2d631000008110610e4d57610e498282610f3a565b5050565b610e49826000610f3a565b6000546001600160a01b03163314610eb25760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064016106da565b6001600160a01b038116610f2e5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201527f646472657373000000000000000000000000000000000000000000000000000060648201526084016106da565b610f37816114a4565b50565b6001600160a01b03821660009081526006602052604090205480821115610f73576000610f678284611b83565b9050610d52848261150c565b80821015610f93576000610f878383611b83565b9050610d52848261165e565b505050565b6000806000610fa684610d67565b90508015611349576001600160a01b0384166000908152600d602052604081208054839290610fd6908490611a8a565b925050819055508060096000828254610fef9190611a8a565b90915550506040518181526001600160a01b038516907fee503bee2bb6a87e57bc57db795f98137327401a0e7b7ce42e37926cc1a9ca4d9060200160405180910390a26001546040805160028082526060820183526001600160a01b0390931692600092602083019080368337019050509050816001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa1580156110a0573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906110c49190611b9a565b816000815181106110d7576110d7611bb7565b6001600160a01b039283166020918202929092010152600a5482519116908290600190811061110857611108611bb7565b6001600160a01b039283166020918202929092010152600a546040517f70a082310000000000000000000000000000000000000000000000000000000081528883166004820152600092839283929116906370a0823190602401602060405180830381865afa15801561117f573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906111a39190611aa2565b9050846001600160a01b031663b6f9de95876000878d426040518663ffffffff1660e01b81526004016111d99493929190611be6565b6000604051808303818588803b1580156111f257600080fd5b505af193505050508015611204575060015b61124657611210611c50565b806308c379a0141561123a5750611225611cde565b80611230575061123c565b60009350506112de565b505b3d6000803e3d6000fd5b600a546040517f70a082310000000000000000000000000000000000000000000000000000000081526001600160a01b038b8116600483015260019550839216906370a0823190602401602060405180830381865afa1580156112ad573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906112d19190611aa2565b6112db9190611b83565b91505b8261133a576001600160a01b0389166000908152600d60205260408120805488929061130b908490611b83565b9250508190555085600960008282546113249190611b83565b9091555060009a8b9a5098505050505050505050565b50939793965092945050505050565b50600093849350915050565b60008061136183610d67565b90508015610cac576001600160a01b0383166000908152600d602052604081208054839290611391908490611a8a565b9250508190555080600960008282546113aa9190611a8a565b90915550506040518181526001600160a01b038416907fee503bee2bb6a87e57bc57db795f98137327401a0e7b7ce42e37926cc1a9ca4d9060200160405180910390a26000836001600160a01b031682610bb890604051600060405180830381858888f193505050503d806000811461143f576040519150601f19603f3d011682016040523d82523d6000602084013e611444565b606091505b505090508061149d576001600160a01b0384166000908152600d602052604081208054849290611475908490611b83565b92505081905550816009600082825461148e9190611b83565b90915550600095945050505050565b5092915050565b600080546001600160a01b038381167fffffffffffffffffffffffff0000000000000000000000000000000000000000831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b6001600160a01b0382166115885760405162461bcd60e51b815260206004820152602d60248201527f4a50475f4469766964656e64547261636b65723a206d696e7420746f2074686560448201527f207a65726f20616464726573730000000000000000000000000000000000000060648201526084016106da565b806005600082825461159a9190611a8a565b90915550506001600160a01b038216600090815260066020526040812080548392906115c7908490611a8a565b90915550506040518181526001600160a01b038316906000907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a38060075461161b9190611a12565b6001600160a01b0383166000908152600c602052604090205461163e9190611d86565b6001600160a01b039092166000908152600c602052604090209190915550565b6001600160a01b0382166116da5760405162461bcd60e51b815260206004820152602f60248201527f4a50475f4469766964656e64547261636b65723a206275726e2066726f6d207460448201527f6865207a65726f2061646472657373000000000000000000000000000000000060648201526084016106da565b6001600160a01b038216600090815260066020526040902054818110156117695760405162461bcd60e51b815260206004820152603060248201527f4a50475f4469766964656e64547261636b65723a206275726e20616d6f756e7460448201527f20657863656564732062616c616e63650000000000000000000000000000000060648201526084016106da565b6117738282611b83565b6001600160a01b038416600090815260066020526040812091909155600580548492906117a1908490611b83565b90915550506040518281526000906001600160a01b038516907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a3816007546117f59190611a12565b6001600160a01b0384166000908152600c60205260409020546118189190611b0f565b6001600160a01b039093166000908152600c60205260409020929092555050565b6001600160a01b0381168114610f3757600080fd5b6000806040838503121561186157600080fd5b823561186c81611839565b91506020830135801515811461188157600080fd5b809150509250929050565b600060208083528351808285015260005b818110156118b95785810183015185820160400152820161189d565b818111156118cb576000604083870101525b50601f017fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffe016929092016040019392505050565b6000806040838503121561191257600080fd5b823561191d81611839565b946020939093013593505050565b60008060006060848603121561194057600080fd5b833561194b81611839565b9250602084013561195b81611839565b929592945050506040919091013590565b60006020828403121561197e57600080fd5b813561198981611839565b9392505050565b600080604083850312156119a357600080fd5b82359150602083013561188181611839565b600080604083850312156119c857600080fd5b82356119d381611839565b9150602083013561188181611839565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052601160045260246000fd5b6000817fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff0483118215151615611a4a57611a4a6119e3565b500290565b600082611a85577f4e487b7100000000000000000000000000000000000000000000000000000000600052601260045260246000fd5b500490565b60008219821115611a9d57611a9d6119e3565b500190565b600060208284031215611ab457600080fd5b5051919050565b600181811c90821680611acf57607f821691505b60208210811415611b09577f4e487b7100000000000000000000000000000000000000000000000000000000600052602260045260246000fd5b50919050565b6000808212827f7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff03841381151615611b4957611b496119e3565b827f8000000000000000000000000000000000000000000000000000000000000000038412811615611b7d57611b7d6119e3565b50500190565b600082821015611b9557611b956119e3565b500390565b600060208284031215611bac57600080fd5b815161198981611839565b7f4e487b7100000000000000000000000000000000000000000000000000000000600052603260045260246000fd5b600060808201868352602060808185015281875180845260a086019150828901935060005b81811015611c305784516001600160a01b031683529383019391830191600101611c0b565b50506001600160a01b039690961660408501525050506060015292915050565b600060033d1115611c695760046000803e5060005160e01c5b90565b7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffe0601f830116810181811067ffffffffffffffff82111715611cd7577f4e487b7100000000000000000000000000000000000000000000000000000000600052604160045260246000fd5b6040525050565b600060443d1015611cec5790565b6040517ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffc803d016004833e81513d67ffffffffffffffff8160248401118184111715611d3a57505050505090565b8285019150815181811115611d525750505050505090565b843d8701016020828501011115611d6c5750505050505090565b611d7b60208286010187611c6c565b509095945050505050565b6000808312837f800000000000000000000000000000000000000000000000000000000000000001831281151615611dc057611dc06119e3565b837f7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff018313811615611df457611df46119e3565b5050039056fea2646970667358221220422535b3226890afc091115ecc241b88d5e2e29a5edd48ded097b179c7703cbe64736f6c634300080a0033

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

00000000000000000000000019e5bb63c902c0690d1ba9b946ee8920e8dec3c60000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d

-----Decoded View---------------
Arg [0] : _tokenAddress (address): 0x19E5bb63c902C0690d1BA9B946ee8920E8dEC3C6
Arg [1] : _uniswapRouter (address): 0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D

-----Encoded View---------------
2 Constructor Arguments found :
Arg [0] : 00000000000000000000000019e5bb63c902c0690d1ba9b946ee8920e8dec3c6
Arg [1] : 0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d


Deployed Bytecode Sourcemap

32343:11251:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;33952:21;:19;:21::i;:::-;32343:11251;;;;;33989:392;;;:::i;34763:740::-;;;;;;;;;;-1:-1:-1;34763:740:0;;;;;:::i;:::-;;:::i;42395:83::-;;;;;;;;;;;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;43249:143;;;;;;;;;;-1:-1:-1;43249:143:0;;;;;:::i;:::-;;:::i;:::-;;;1740:14:1;;1733:22;1715:41;;1703:2;1688:18;43249:143:0;1575:187:1;42665:100:0;;;;;;;;;;-1:-1:-1;42745:12:0;;42665:100;;;1913:25:1;;;1901:2;1886:18;42665:100:0;1767:177:1;43400:191:0;;;;;;;;;;-1:-1:-1;43400:191:0;;;;;:::i;41230:337::-;;;;;;;;;;-1:-1:-1;41230:337:0;;;;;:::i;:::-;;:::i;32517:33::-;;;;;;;;;;;;;;;;42581:76;;;;;;;;;;-1:-1:-1;42581:76:0;;42647:2;2804:36:1;;2792:2;2777:18;42581:76:0;2662:184:1;32935:53:0;;;;;;;;;;-1:-1:-1;32935:53:0;;;;;:::i;:::-;;;;;;;;;;;;;;;;38792:396;;;;;;;;;;-1:-1:-1;38792:396:0;;;;;:::i;:::-;;:::i;42773:119::-;;;;;;;;;;-1:-1:-1;42773:119:0;;;;;:::i;:::-;-1:-1:-1;;;;;42866:18:0;42839:7;42866:18;;;:9;:18;;;;;;;42773:119;41575:682;;;;;;;;;;-1:-1:-1;41575:682:0;;;;;:::i;:::-;;:::i;:::-;;;;-1:-1:-1;;;;;3388:55:1;;;3370:74;;3475:2;3460:18;;3453:34;;;;3503:18;;;3496:34;;;;3561:2;3546:18;;3539:34;3604:3;3589:19;;3582:35;3357:3;3342:19;41575:682:0;3111:512:1;37558:366:0;;;;;;;;;;-1:-1:-1;37558:366:0;;;;;:::i;:::-;;:::i;32805:40::-;;;;;;;;;;;;;;;;790:87;;;;;;;;;;-1:-1:-1;836:7:0;863:6;-1:-1:-1;;;;;863:6:0;790:87;;;-1:-1:-1;;;;;3792:55:1;;;3774:74;;3762:2;3747:18;790:87:0;3628:226:1;35684:248:0;;;;;;;;;;-1:-1:-1;35684:248:0;;;;;:::i;:::-;;:::i;42486:87::-;;;;;;;;;;;;;:::i;32899:27::-;;;;;;;;;;-1:-1:-1;32899:27:0;;;;-1:-1:-1;;;;;32899:27:0;;;32852:38;;;;;;;;;;;;;;;;42265:122;;;;;;;;;;-1:-1:-1;42265:122:0;;;;;:::i;:::-;-1:-1:-1;;;;;42356:23:0;42329:7;42356:23;;;:14;:23;;;;;;;42265:122;40855:198;;;;;;;;;;-1:-1:-1;40855:198:0;;;;;:::i;:::-;;:::i;41061:161::-;;;;;;;;;;-1:-1:-1;41061:161:0;;;;;:::i;:::-;-1:-1:-1;;;;;41187:27:0;41155:7;41187:27;;;:18;:27;;;;;;;41061:161;32698:52;;;;;;;;;;;;;;;35511:165;;;;;;;;;;-1:-1:-1;35511:165:0;;;;;:::i;:::-;-1:-1:-1;;;;;35638:30:0;35609:4;35638:30;;;:21;:30;;;;;;;;;35511:165;43052:189;;;;;;;;;;-1:-1:-1;43052:189:0;;;;;:::i;34389:366::-;;;;;;;;;;-1:-1:-1;34389:366:0;;;;;:::i;:::-;;:::i;1160:201::-;;;;;;;;;;-1:-1:-1;1160:201:0;;;;;:::i;:::-;;:::i;33989:392::-;34069:1;34054:12;;:16;34046:25;;;;;;34086:9;:13;34082:292;;34233:12;;34208:21;32685:6;34208:9;:21;:::i;:::-;34207:38;;;;:::i;:::-;34161:25;;:85;;;;:::i;:::-;34116:25;:130;34266:43;;34299:9;1913:25:1;;34287:10:0;;34266:43;;1901:2:1;1886:18;34266:43:0;;;;;;;34353:9;34324:25;;:38;;;;;;;:::i;:::-;;;;-1:-1:-1;;34082:292:0;33989:392::o;34763:740::-;836:7;863:6;-1:-1:-1;;;;;863:6:0;416:10;925:23;917:68;;;;-1:-1:-1;;;917:68:0;;5936:2:1;917:68:0;;;5918:21:1;;;5955:18;;;5948:30;6014:34;5994:18;;;5987:62;6066:18;;917:68:0;;;;;;;;;-1:-1:-1;;;;;34900:30:0;::::1;;::::0;;;:21:::1;:30;::::0;;;;;::::1;;:42;;::::0;::::1;;;;34878:151;;;::::0;-1:-1:-1;;;34878:151:0;;6297:2:1;34878:151:0::1;::::0;::::1;6279:21:1::0;6336:2;6316:18;;;6309:30;6375:34;6355:18;;;6348:62;6446:29;6426:18;;;6419:57;6493:19;;34878:151:0::1;6095:423:1::0;34878:151:0::1;-1:-1:-1::0;;;;;35040:30:0;::::1;;::::0;;;:21:::1;:30;::::0;;;;:41;;;::::1;::::0;::::1;::::0;::::1;::::0;;;::::1;::::0;;;35092:349:::1;;35121:23;35133:7;35142:1;35121:11;:23::i;:::-;35092:349;;;35205:12;::::0;35198:39:::1;::::0;;;;-1:-1:-1;;;;;3792:55:1;;;35198:39:0::1;::::0;::::1;3774:74:1::0;35177:18:0::1;::::0;35205:12:::1;::::0;35198:30:::1;::::0;3747:18:1;;35198:39:0::1;;;;;;;;;;;;;;;;;::::0;::::1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;35177:60;;35270:27;35256:10;:41;35252:178;;35318:32;35330:7;35339:10;35318:11;:32::i;:::-;35252:178;;;35391:23;35403:7;35412:1;35391:11;:23::i;:::-;35162:279;35092:349;35477:7;-1:-1:-1::0;;;;;35456:39:0::1;;35486:8;35456:39;;;;1740:14:1::0;1733:22;1715:41;;1703:2;1688:18;;1575:187;35456:39:0::1;;;;;;;;34763:740:::0;;:::o;42395:83::-;42432:13;42465:5;42458:12;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;42395:83;:::o;43249:143::-;43331:53;;-1:-1:-1;;;43331:53:0;;7356:2:1;43331:53:0;;;7338:21:1;7395:2;7375:18;;;7368:30;7434:34;7414:18;;;7407:62;7505:13;7485:18;;;7478:41;43314:4:0;;7536:19:1;;43331:53:0;7154:407:1;41230:337:0;-1:-1:-1;;;;;42866:18:0;;41327:7;42866:18;;;:9;:18;;;;;;41370:25;;41327:7;;41370:46;;;:::i;:::-;-1:-1:-1;;;;;41439:37:0;;41428:8;41439:37;;;:28;:37;;;;;;41352:65;;-1:-1:-1;32685:6:0;41541:5;41439:37;41352:65;41541:5;:::i;:::-;41533:26;;;;:::i;:::-;41526:33;41230:337;-1:-1:-1;;;;41230:337:0:o;38792:396::-;38895:4;863:6;;-1:-1:-1;;;;;863:6:0;416:10;925:23;917:68;;;;-1:-1:-1;;;917:68:0;;5936:2:1;917:68:0;;;5918:21:1;;;5955:18;;;5948:30;6014:34;5994:18;;;5987:62;6066:18;;917:68:0;5734:356:1;917:68:0;38918:14:::1;38934::::0;38952:32:::1;38976:7;38952:23;:32::i;:::-;38917:67:::0;;-1:-1:-1;38917:67:0;-1:-1:-1;38999:10:0;;38995:163:::1;;-1:-1:-1::0;;;;;39026:23:0;::::1;;::::0;;;:14:::1;:23;::::0;;;;;;;;39052:15:::1;39026:41:::0;;39087:33;;8112:25:1;;;8153:18;;;8146:34;;;39087:33:0::1;::::0;8085:18:1;39087:33:0::1;;;;;;;-1:-1:-1::0;39142:4:0::1;::::0;38792:396;-1:-1:-1;;;38792:396:0:o;38995:163::-:1;-1:-1:-1::0;39175:5:0::1;::::0;38792:396;-1:-1:-1;;;38792:396:0:o;41575:682::-;41678:7;41700;41722;41744;41766;41801:23;-1:-1:-1;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;41801:23:0;-1:-1:-1;;;;;41835:22:0;;;;41897:31;41850:7;41897:22;:31::i;:::-;41868:26;;;:60;41961:31;41984:7;41961:22;:31::i;:::-;41939:19;;;;:53;;;-1:-1:-1;;;;;42024:23:0;;;;;;;;:14;:23;;;;;;;;42003:18;;;:44;;;42080:12;;42107:26;;;;;42148:19;;42215:23;;42080:12;;42107:26;;42148:19;;-1:-1:-1;42024:23:0;;-1:-1:-1;42215:23:0;;-1:-1:-1;41575:682:0;-1:-1:-1;;41575:682:0:o;37558:366::-;37660:4;863:6;;-1:-1:-1;;;;;863:6:0;416:10;925:23;917:68;;;;-1:-1:-1;;;917:68:0;;5936:2:1;917:68:0;;;5918:21:1;;;5955:18;;;5948:30;6014:34;5994:18;;;5987:62;6066:18;;917:68:0;5734:356:1;917:68:0;37682:14:::1;37699:32;37723:7;37699:23;:32::i;:::-;37682:49:::0;-1:-1:-1;37746:10:0;;37742:152:::1;;-1:-1:-1::0;;;;;37773:23:0;::::1;;::::0;;;:14:::1;:23;::::0;;;;;;37799:15:::1;37773:41:::0;;37834:22;::::1;::::0;::::1;::::0;37849:6;1913:25:1;;1901:2;1886:18;;1767:177;37834:22:0::1;;;;;;;;-1:-1:-1::0;37878:4:0::1;::::0;38792:396;-1:-1:-1;;38792:396:0:o;37742:152::-:1;-1:-1:-1::0;37911:5:0::1;::::0;37558:366;-1:-1:-1;;37558:366:0:o;35684:248::-;836:7;863:6;-1:-1:-1;;;;;863:6:0;416:10;925:23;917:68;;;;-1:-1:-1;;;917:68:0;;5936:2:1;917:68:0;;;5918:21:1;;;5955:18;;;5948:30;6014:34;5994:18;;;5987:62;6066:18;;917:68:0;5734:356:1;917:68:0;35826:21:::1;-1:-1:-1::0;;;;;35858:24:0;::::1;:66;35883:10:::0;:40:::1;;35905:18;35883:40;;;35896:6;35883:40;35858:66;::::0;;::::1;::::0;;::::1;::::0;::::1;::::0;;;;;;::::1;;;;;;;;;;;;;::::0;::::1;;;;;;35786:146;35684:248:::0;;:::o;42486:87::-;42525:13;42558:7;42551:14;;;;;:::i;40855:198::-;-1:-1:-1;;;;;41018:27:0;;40952:7;41018:27;;;:18;:27;;;;;;40984:31;41037:7;40984:22;:31::i;:::-;:61;;;;:::i;:::-;40977:68;40855:198;-1:-1:-1;;40855:198:0:o;34389:366::-;836:7;863:6;-1:-1:-1;;;;;863:6:0;416:10;925:23;917:68;;;;-1:-1:-1;;;917:68:0;;5936:2:1;917:68:0;;;5918:21:1;;;5955:18;;;5948:30;6014:34;5994:18;;;5987:62;6066:18;;917:68:0;5734:356:1;917:68:0;-1:-1:-1;;;;;34511:30:0;::::1;;::::0;;;:21:::1;:30;::::0;;;;;::::1;;34507:69;;;34389:366:::0;;:::o;34507:69::-:1;34604:27;34590:10;:41;34586:162;;34648:32;34660:7;34669:10;34648:11;:32::i;:::-;34389:366:::0;;:::o;34586:162::-:1;34713:23;34725:7;34734:1;34713:11;:23::i;1160:201::-:0;836:7;863:6;-1:-1:-1;;;;;863:6:0;416:10;925:23;917:68;;;;-1:-1:-1;;;917:68:0;;5936:2:1;917:68:0;;;5918:21:1;;;5955:18;;;5948:30;6014:34;5994:18;;;5987:62;6066:18;;917:68:0;5734:356:1;917:68:0;-1:-1:-1;;;;;1249:22:0;::::1;1241:73;;;::::0;-1:-1:-1;;;1241:73:0;;8523:2:1;1241:73:0::1;::::0;::::1;8505:21:1::0;8562:2;8542:18;;;8535:30;8601:34;8581:18;;;8574:62;8672:8;8652:18;;;8645:36;8698:19;;1241:73:0::1;8321:402:1::0;1241:73:0::1;1325:28;1344:8;1325:18;:28::i;:::-;1160:201:::0;:::o;35940:439::-;-1:-1:-1;;;;;36043:18:0;;36018:22;36043:18;;;:9;:18;;;;;;36076:27;;;36072:300;;;36120:17;36140:27;36153:14;36140:10;:27;:::i;:::-;36120:47;;36182:25;36188:7;36197:9;36182:5;:25::i;36072:300::-;36242:14;36229:10;:27;36225:147;;;36273:17;36293:27;36310:10;36293:14;:27;:::i;:::-;36273:47;;36335:25;36341:7;36350:9;36335:5;:25::i;36225:147::-;36007:372;35940:439;;:::o;39196:1651::-;39289:7;39298;39323:29;39355:31;39378:7;39355:22;:31::i;:::-;39323:63;-1:-1:-1;39401:25:0;;39397:1419;;-1:-1:-1;;;;;39443:27:0;;;;;;:18;:27;;;;;:52;;39474:21;;39443:27;:52;;39474:21;;39443:52;:::i;:::-;;;;;;;;39537:21;39510:23;;:48;;;;;;;:::i;:::-;;;;-1:-1:-1;;39578:49:0;;1913:25:1;;;-1:-1:-1;;;;;39578:49:0;;;;;1901:2:1;1886:18;39578:49:0;;;;;;;39718:13;;39787:16;;;39801:1;39787:16;;;;;;;;-1:-1:-1;;;;;39718:13:0;;;;39644:34;;39787:16;;;;;;;;;;-1:-1:-1;39787:16:0;39763:40;;39828:15;-1:-1:-1;;;;;39828:20:0;;:22;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;39818:4;39823:1;39818:7;;;;;;;;:::i;:::-;-1:-1:-1;;;;;39818:32:0;;;:7;;;;;;;;;:32;39883:12;;39865:7;;39883:12;;;39865:4;;39883:12;;39865:7;;;;;;:::i;:::-;-1:-1:-1;;;;;39865:31:0;;;:7;;;;;;;;;:31;40001:12;;39994:39;;;;;3792:55:1;;;39994:39:0;;;3774:74:1;39913:12:0;;;;;;40001;;;39994:30;;3747:18:1;;39994:39:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;39971:62;;40069:15;-1:-1:-1;;;;;40069:88:0;;40187:21;40228:1;40231:4;40245:7;40255:15;40069:202;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;40048:486;;;;:::i;:::-;;;;;;;;;;:::i;:::-;;;;;;;;40513:5;40503:15;;40417:117;40048:486;;;;;;;;;;;;;40353:12;;40346:39;;;;;-1:-1:-1;;;;;3792:55:1;;;40346:39:0;;;3774:74:1;40314:4:0;;-1:-1:-1;40388:12:0;;40353;;40346:30;;3747:18:1;;40346:39:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;:54;;;;:::i;:::-;40337:63;;40048:486;40555:7;40550:200;;-1:-1:-1;;;;;40583:27:0;;;;;;:18;:27;;;;;:52;;40614:21;;40583:27;:52;;40614:21;;40583:52;:::i;:::-;;;;;;;;40681:21;40654:23;;:48;;;;;;;:::i;:::-;;;;-1:-1:-1;40729:1:0;;;;-1:-1:-1;39196:1651:0;-1:-1:-1;;;;;;;;;39196:1651:0:o;40550:200::-;-1:-1:-1;40774:21:0;;40797:6;;-1:-1:-1;39196:1651:0;;-1:-1:-1;;;;;39196:1651:0:o;39397:1419::-;-1:-1:-1;40834:1:0;;;;-1:-1:-1;39196:1651:0;-1:-1:-1;;39196:1651:0:o;37932:852::-;38025:7;38050:29;38082:31;38105:7;38082:22;:31::i;:::-;38050:63;-1:-1:-1;38128:25:0;;38124:634;;-1:-1:-1;;;;;38170:27:0;;;;;;:18;:27;;;;;:52;;38201:21;;38170:27;:52;;38201:21;;38170:52;:::i;:::-;;;;;;;;38264:21;38237:23;;:48;;;;;;;:::i;:::-;;;;-1:-1:-1;;38305:49:0;;1913:25:1;;;-1:-1:-1;;;;;38305:49:0;;;;;1901:2:1;1886:18;38305:49:0;;;;;;;38370:12;38388:7;-1:-1:-1;;;;;38388:12:0;38426:21;38471:4;38388:106;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;38369:125;;;38514:7;38509:195;;-1:-1:-1;;;;;38542:27:0;;;;;;:18;:27;;;;;:52;;38573:21;;38542:27;:52;;38573:21;;38542:52;:::i;:::-;;;;;;;;38640:21;38613:23;;:48;;;;;;;:::i;:::-;;;;-1:-1:-1;38687:1:0;;37932:852;-1:-1:-1;;;;;37932:852:0:o;38509:195::-;-1:-1:-1;38725:21:0;37932:852;-1:-1:-1;;37932:852:0:o;1521:191::-;1595:16;1614:6;;-1:-1:-1;;;;;1631:17:0;;;;;;;;;;1664:40;;1614:6;;;;;;;1664:40;;1595:16;1664:40;1584:128;1521:191;:::o;36387:475::-;-1:-1:-1;;;;;36476:21:0;;36454:116;;;;-1:-1:-1;;;36454:116:0;;12359:2:1;36454:116:0;;;12341:21:1;12398:2;12378:18;;;12371:30;12437:34;12417:18;;;12410:62;12508:15;12488:18;;;12481:43;12541:19;;36454:116:0;12157:409:1;36454:116:0;36597:6;36581:12;;:22;;;;;;;:::i;:::-;;;;-1:-1:-1;;;;;;;36614:18:0;;;;;;:9;:18;;;;;:28;;36636:6;;36614:18;:28;;36636:6;;36614:28;:::i;:::-;;;;-1:-1:-1;;36658:37:0;;1913:25:1;;;-1:-1:-1;;;;;36658:37:0;;;36675:1;;36658:37;;1901:2:1;1886:18;36658:37:0;;;;;;;36847:6;36819:25;;:34;;;;:::i;:::-;-1:-1:-1;;;;;36759:37:0;;;;;;:28;:37;;;;;;:95;;;;:::i;:::-;-1:-1:-1;;;;;36706:37:0;;;;;;;:28;:37;;;;;:148;;;;-1:-1:-1;36387:475:0:o;36870:680::-;-1:-1:-1;;;;;36959:21:0;;36937:118;;;;-1:-1:-1;;;36937:118:0;;13147:2:1;36937:118:0;;;13129:21:1;13186:2;13166:18;;;13159:30;13225:34;13205:18;;;13198:62;13296:17;13276:18;;;13269:45;13331:19;;36937:118:0;12945:411:1;36937:118:0;-1:-1:-1;;;;;37091:18:0;;37066:22;37091:18;;;:9;:18;;;;;;37142:24;;;;37120:122;;;;-1:-1:-1;;;37120:122:0;;13563:2:1;37120:122:0;;;13545:21:1;13602:2;13582:18;;;13575:30;13641:34;13621:18;;;13614:62;13712:18;13692;;;13685:46;13748:19;;37120:122:0;13361:412:1;37120:122:0;37274:23;37291:6;37274:14;:23;:::i;:::-;-1:-1:-1;;;;;37253:18:0;;;;;;:9;:18;;;;;:44;;;;37308:12;:22;;37324:6;;37253:18;37308:22;;37324:6;;37308:22;:::i;:::-;;;;-1:-1:-1;;37346:37:0;;1913:25:1;;;37372:1:0;;-1:-1:-1;;;;;37346:37:0;;;;;1901:2:1;1886:18;37346:37:0;;;;;;;37535:6;37507:25;;:34;;;;:::i;:::-;-1:-1:-1;;;;;37447:37:0;;;;;;:28;:37;;;;;;:95;;;;:::i;:::-;-1:-1:-1;;;;;37394:37:0;;;;;;;:28;:37;;;;;:148;;;;-1:-1:-1;;36870:680:0:o;14:154:1:-;-1:-1:-1;;;;;93:5:1;89:54;82:5;79:65;69:93;;158:1;155;148:12;173:416;238:6;246;299:2;287:9;278:7;274:23;270:32;267:52;;;315:1;312;305:12;267:52;354:9;341:23;373:31;398:5;373:31;:::i;:::-;423:5;-1:-1:-1;480:2:1;465:18;;452:32;522:15;;515:23;503:36;;493:64;;553:1;550;543:12;493:64;576:7;566:17;;;173:416;;;;;:::o;594:656::-;706:4;735:2;764;753:9;746:21;796:6;790:13;839:6;834:2;823:9;819:18;812:34;864:1;874:140;888:6;885:1;882:13;874:140;;;983:14;;;979:23;;973:30;949:17;;;968:2;945:26;938:66;903:10;;874:140;;;1032:6;1029:1;1026:13;1023:91;;;1102:1;1097:2;1088:6;1077:9;1073:22;1069:31;1062:42;1023:91;-1:-1:-1;1166:2:1;1154:15;1171:66;1150:88;1135:104;;;;1241:2;1131:113;;594:656;-1:-1:-1;;;594:656:1:o;1255:315::-;1323:6;1331;1384:2;1372:9;1363:7;1359:23;1355:32;1352:52;;;1400:1;1397;1390:12;1352:52;1439:9;1426:23;1458:31;1483:5;1458:31;:::i;:::-;1508:5;1560:2;1545:18;;;;1532:32;;-1:-1:-1;;;1255:315:1:o;1949:456::-;2026:6;2034;2042;2095:2;2083:9;2074:7;2070:23;2066:32;2063:52;;;2111:1;2108;2101:12;2063:52;2150:9;2137:23;2169:31;2194:5;2169:31;:::i;:::-;2219:5;-1:-1:-1;2276:2:1;2261:18;;2248:32;2289:33;2248:32;2289:33;:::i;:::-;1949:456;;2341:7;;-1:-1:-1;;;2395:2:1;2380:18;;;;2367:32;;1949:456::o;2410:247::-;2469:6;2522:2;2510:9;2501:7;2497:23;2493:32;2490:52;;;2538:1;2535;2528:12;2490:52;2577:9;2564:23;2596:31;2621:5;2596:31;:::i;:::-;2646:5;2410:247;-1:-1:-1;;;2410:247:1:o;3859:315::-;3927:6;3935;3988:2;3976:9;3967:7;3963:23;3959:32;3956:52;;;4004:1;4001;3994:12;3956:52;4040:9;4027:23;4017:33;;4100:2;4089:9;4085:18;4072:32;4113:31;4138:5;4113:31;:::i;4179:388::-;4247:6;4255;4308:2;4296:9;4287:7;4283:23;4279:32;4276:52;;;4324:1;4321;4314:12;4276:52;4363:9;4350:23;4382:31;4407:5;4382:31;:::i;:::-;4432:5;-1:-1:-1;4489:2:1;4474:18;;4461:32;4502:33;4461:32;4502:33;:::i;4900:184::-;4952:77;4949:1;4942:88;5049:4;5046:1;5039:15;5073:4;5070:1;5063:15;5089:228;5129:7;5255:1;5187:66;5183:74;5180:1;5177:81;5172:1;5165:9;5158:17;5154:105;5151:131;;;5262:18;;:::i;:::-;-1:-1:-1;5302:9:1;;5089:228::o;5322:274::-;5362:1;5388;5378:189;;5423:77;5420:1;5413:88;5524:4;5521:1;5514:15;5552:4;5549:1;5542:15;5378:189;-1:-1:-1;5581:9:1;;5322:274::o;5601:128::-;5641:3;5672:1;5668:6;5665:1;5662:13;5659:39;;;5678:18;;:::i;:::-;-1:-1:-1;5714:9:1;;5601:128::o;6523:184::-;6593:6;6646:2;6634:9;6625:7;6621:23;6617:32;6614:52;;;6662:1;6659;6652:12;6614:52;-1:-1:-1;6685:16:1;;6523:184;-1:-1:-1;6523:184:1:o;6712:437::-;6791:1;6787:12;;;;6834;;;6855:61;;6909:4;6901:6;6897:17;6887:27;;6855:61;6962:2;6954:6;6951:14;6931:18;6928:38;6925:218;;;6999:77;6996:1;6989:88;7100:4;7097:1;7090:15;7128:4;7125:1;7118:15;6925:218;;6712:437;;;:::o;7566:367::-;7605:3;7640:1;7637;7633:9;7749:1;7681:66;7677:74;7674:1;7670:82;7665:2;7658:10;7654:99;7651:125;;;7756:18;;:::i;:::-;7875:1;7807:66;7803:74;7800:1;7796:82;7792:2;7788:91;7785:117;;;7882:18;;:::i;:::-;-1:-1:-1;;7918:9:1;;7566:367::o;8191:125::-;8231:4;8259:1;8256;8253:8;8250:34;;;8264:18;;:::i;:::-;-1:-1:-1;8301:9:1;;8191:125::o;8917:251::-;8987:6;9040:2;9028:9;9019:7;9015:23;9011:32;9008:52;;;9056:1;9053;9046:12;9008:52;9088:9;9082:16;9107:31;9132:5;9107:31;:::i;9173:184::-;9225:77;9222:1;9215:88;9322:4;9319:1;9312:15;9346:4;9343:1;9336:15;9601:954;9835:4;9883:3;9872:9;9868:19;9914:6;9903:9;9896:25;9940:2;9978:3;9973:2;9962:9;9958:18;9951:31;10002:6;10037;10031:13;10068:6;10060;10053:22;10106:3;10095:9;10091:19;10084:26;;10145:2;10137:6;10133:15;10119:29;;10166:1;10176:218;10190:6;10187:1;10184:13;10176:218;;;10255:13;;-1:-1:-1;;;;;10251:62:1;10239:75;;10369:15;;;;10334:12;;;;10212:1;10205:9;10176:218;;;-1:-1:-1;;;;;;;10450:55:1;;;;10445:2;10430:18;;10423:83;-1:-1:-1;;;10537:2:1;10522:18;10515:34;10411:3;9601:954;-1:-1:-1;;9601:954:1:o;10560:179::-;10595:3;10637:1;10619:16;10616:23;10613:120;;;10683:1;10680;10677;10662:23;-1:-1:-1;10720:1:1;10714:8;10709:3;10705:18;10613:120;10560:179;:::o;10744:462::-;10850:66;10845:2;10839:4;10835:13;10831:86;10823:6;10819:99;10984:6;10972:10;10969:22;10948:18;10936:10;10933:34;10930:62;10927:242;;;11025:77;11022:1;11015:88;11126:4;11123:1;11116:15;11154:4;11151:1;11144:15;10927:242;11185:2;11178:22;-1:-1:-1;;10744:462:1:o;11211:731::-;11250:3;11292:4;11274:16;11271:26;11268:39;;;11211:731;:::o;11268:39::-;11334:2;11328:9;11356:66;11477:2;11459:16;11455:25;11452:1;11446:4;11431:50;11510:4;11504:11;11534:16;11569:18;11640:2;11633:4;11625:6;11621:17;11618:25;11613:2;11605:6;11602:14;11599:45;11596:58;;;11647:5;;;;;11211:731;:::o;11596:58::-;11684:6;11678:4;11674:17;11663:28;;11720:3;11714:10;11747:2;11739:6;11736:14;11733:27;;;11753:5;;;;;;11211:731;:::o;11733:27::-;11837:2;11818:16;11812:4;11808:27;11804:36;11797:4;11788:6;11783:3;11779:16;11775:27;11772:69;11769:82;;;11844:5;;;;;;11211:731;:::o;11769:82::-;11860:57;11911:4;11902:6;11894;11890:19;11886:30;11880:4;11860:57;:::i;:::-;-1:-1:-1;11933:3:1;;11211:731;-1:-1:-1;;;;;11211:731:1:o;12571:369::-;12610:4;12646:1;12643;12639:9;12755:1;12687:66;12683:74;12680:1;12676:82;12671:2;12664:10;12660:99;12657:125;;;12762:18;;:::i;:::-;12881:1;12813:66;12809:74;12806:1;12802:82;12798:2;12794:91;12791:117;;;12888:18;;:::i;:::-;-1:-1:-1;;12925:9:1;;12571:369::o

Swarm Source

ipfs://422535b3226890afc091115ecc241b88d5e2e29a5edd48ded097b179c7703cbe
Loading...
Loading
Loading...
Loading
[ Download: CSV Export  ]
[ Download: CSV Export  ]

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