ETH Price: $2,374.86 (+6.39%)

Token

Onigiri Chan (GIRI)
 

Overview

Max Total Supply

1,000,000,000 GIRI

Holders

79

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 18 Decimals)

Balance
4,799,999.99999999998166937 GIRI

Value
$0.00
0x6815C65315D51DD98745ED1965A66b95DB24b61e
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:
OnigiriChan

Compiler Version
v0.8.25+commit.b61c2a91

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, MIT license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2024-07-31
*/

/*

https://t.me/OnigiriEther


*/

// SPDX-License-Identifier: MIT
pragma solidity 0.8.25;

/**
 * @dev Provides information about the current execution context, including the
 * sender of the transaction and its data. While these are generally available
 * via msg.sender and msg.data, they should not be accessed in such a direct
 * manner, since when dealing with meta-transactions the account sending and
 * paying for execution may not be the actual sender (as far as an application
 * is concerned).
 *
 * This contract is only required for intermediate, library-like contracts.
 */
abstract contract Context {
  function _msgSender() internal view virtual returns (address) {
    return msg.sender;
  }

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

/**
 * @dev Interface of the ERC20 standard as defined in the EIP.
 */
interface IERC20 {
  /**
   * @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);

  /**
   * @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 `to`.
   *
   * Returns a boolean value indicating whether the operation succeeded.
   *
   * Emits a {Transfer} event.
   */
  function transfer(address to, 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 `from` to `to` 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 from,
    address to,
    uint256 amount
  ) external returns (bool);
}

// File: @openzeppelin/contracts/token/ERC20/extensions/IERC20Metadata.sol

// OpenZeppelin Contracts v4.4.1 (token/ERC20/extensions/IERC20Metadata.sol)

/**
 * @dev Interface for the optional metadata functions from the ERC20 standard.
 *
 * _Available since v4.1._
 */
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);
}

// File: @openzeppelin/contracts/token/ERC20/ERC20.sol

// OpenZeppelin Contracts (last updated v4.8.0) (token/ERC20/ERC20.sol)

/**
 * @dev Implementation of the {IERC20} interface.
 *
 * This implementation is agnostic to the way tokens are created. This means
 * that a supply mechanism has to be added in a derived contract using {_mint}.
 * For a generic mechanism see {ERC20PresetMinterPauser}.
 *
 * TIP: For a detailed writeup see our guide
 * https://forum.openzeppelin.com/t/how-to-implement-erc20-supply-mechanisms/226[How
 * to implement supply mechanisms].
 *
 * We have followed general OpenZeppelin Contracts guidelines: functions revert
 * instead returning `false` on failure. This behavior is nonetheless
 * conventional and does not conflict with the expectations of ERC20
 * applications.
 *
 * Additionally, an {Approval} event is emitted on calls to {transferFrom}.
 * This allows applications to reconstruct the allowance for all accounts just
 * by listening to said events. Other implementations of the EIP may not emit
 * these events, as it isn't required by the specification.
 *
 * Finally, the non-standard {decreaseAllowance} and {increaseAllowance}
 * functions have been added to mitigate the well-known issues around setting
 * allowances. See {IERC20-approve}.
 */
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:
   *
   * - `to` cannot be the zero address.
   * - the caller must have a balance of at least `amount`.
   */
  function transfer(
    address to,
    uint256 amount
  ) public virtual override returns (bool) {
    address owner = _msgSender();
    _transfer(owner, to, 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}.
   *
   * NOTE: If `amount` is the maximum `uint256`, the allowance is not updated on
   * `transferFrom`. This is semantically equivalent to an infinite approval.
   *
   * Requirements:
   *
   * - `spender` cannot be the zero address.
   */
  function approve(
    address spender,
    uint256 amount
  ) public virtual override returns (bool) {
    address owner = _msgSender();
    _approve(owner, 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}.
   *
   * NOTE: Does not update the allowance if the current allowance
   * is the maximum `uint256`.
   *
   * Requirements:
   *
   * - `from` and `to` cannot be the zero address.
   * - `from` must have a balance of at least `amount`.
   * - the caller must have allowance for ``from``'s tokens of at least
   * `amount`.
   */
  function transferFrom(
    address from,
    address to,
    uint256 amount
  ) public virtual override returns (bool) {
    address spender = _msgSender();
    _spendAllowance(from, spender, amount);
    _transfer(from, to, 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) {
    address owner = _msgSender();
    _approve(owner, spender, allowance(owner, 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) {
    address owner = _msgSender();
    uint256 currentAllowance = allowance(owner, spender);
    require(
      currentAllowance >= subtractedValue,
      'ERC20: decreased allowance below zero'
    );
    unchecked {
      _approve(owner, spender, currentAllowance - subtractedValue);
    }

    return true;
  }

  /**
   * @dev Moves `amount` of tokens from `from` to `to`.
   *
   * 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:
   *
   * - `from` cannot be the zero address.
   * - `to` cannot be the zero address.
   * - `from` must have a balance of at least `amount`.
   */
  function _transfer(
    address from,
    address to,
    uint256 amount
  ) internal virtual {
    require(from != address(0), 'ERC20: transfer from the zero address');
    require(to != address(0), 'ERC20: transfer to the zero address');

    _beforeTokenTransfer(from, to, amount);

    uint256 fromBalance = _balances[from];
    require(fromBalance >= amount, 'ERC20: transfer amount exceeds balance');
    unchecked {
      _balances[from] = fromBalance - amount;
      // Overflow not possible: the sum of all balances is capped by totalSupply, and the sum is preserved by
      // decrementing then incrementing.
      _balances[to] += amount;
    }

    emit Transfer(from, to, amount);

    _afterTokenTransfer(from, to, 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;
    unchecked {
      // Overflow not possible: balance + amount is at most totalSupply + amount, which is checked above.
      _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;
      // Overflow not possible: amount <= accountBalance <= totalSupply.
      _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 Updates `owner` s allowance for `spender` based on spent `amount`.
   *
   * Does not update the allowance amount in case of infinite allowance.
   * Revert if not enough allowance is available.
   *
   * Might emit an {Approval} event.
   */
  function _spendAllowance(
    address owner,
    address spender,
    uint256 amount
  ) internal virtual {
    uint256 currentAllowance = allowance(owner, spender);
    if (currentAllowance != type(uint256).max) {
      require(currentAllowance >= amount, 'ERC20: insufficient allowance');
      unchecked {
        _approve(owner, spender, currentAllowance - 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 SafeMath {
  function add(uint256 a, uint256 b) internal pure returns (uint256) {
    uint256 c = a + b;
    require(c >= a, 'SafeMath: addition overflow');

    return c;
  }

  function sub(uint256 a, uint256 b) internal pure returns (uint256) {
    return sub(a, b, 'SafeMath: subtraction overflow');
  }

  function sub(
    uint256 a,
    uint256 b,
    string memory errorMessage
  ) internal pure returns (uint256) {
    require(b <= a, errorMessage);
    uint256 c = a - b;

    return c;
  }

  function mul(uint256 a, uint256 b) internal pure returns (uint256) {
    if (a == 0) {
      return 0;
    }

    uint256 c = a * b;
    require(c / a == b, 'SafeMath: multiplication overflow');

    return c;
  }

  function div(uint256 a, uint256 b) internal pure returns (uint256) {
    return div(a, b, 'SafeMath: division by zero');
  }

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

contract Ownable is Context {
  address public _owner;

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

  constructor() {
    address msgSender = _msgSender();
    _owner = msgSender;
    authorizations[_owner] = true;
    emit OwnershipTransferred(address(0), msgSender);
  }

  mapping(address => bool) internal authorizations;

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

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

  function renounceOwnership() public virtual onlyOwner {
    emit OwnershipTransferred(_owner, address(0));
    _owner = address(0);
  }

  function transferOwnership(address newOwner) public virtual onlyOwner {
    require(newOwner != address(0), 'Ownable: new owner is the zero address');
    emit OwnershipTransferred(_owner, newOwner);
    _owner = newOwner;
  }
}

interface IUniswapV2Factory {
  function createPair(
    address tokenA,
    address tokenB
  ) external returns (address pair);
}

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

    function WETH() external pure returns (address);

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

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

library SafeERC20 {
    using Address for address;

    function safeTransfer(
        IERC20 token,
        address to,
        uint256 value
    ) internal {
        _callOptionalReturn(
            token,
            abi.encodeWithSelector(token.transfer.selector, to, value)
        );
    }

    function safeTransferFrom(
        IERC20 token,
        address from,
        address to,
        uint256 value
    ) internal {
        _callOptionalReturn(
            token,
            abi.encodeWithSelector(token.transferFrom.selector, from, to, value)
        );
    }

    function _callOptionalReturn(IERC20 token, bytes memory data) private {
        bytes memory returndata = address(token).functionCall(
            data,
            "SafeERC20: low-level call failed"
        );
        if (returndata.length > 0) {
            require(
                abi.decode(returndata, (bool)),
                "SafeERC20: ERC20 operation did not succeed"
            );
        }
    }

    function safeApprove(
        IERC20 token,
        address spender,
        uint256 value
    ) internal {
        // safeApprove should only be called when setting an initial allowance,
        // or when resetting it to zero. To increase and decrease it, use
        // 'safeIncreaseAllowance' and 'safeDecreaseAllowance'
        require(
            (value == 0) || (token.allowance(address(this), spender) == 0),
            "SafeERC20: approve from non-zero to non-zero allowance"
        );
        _callOptionalReturn(
            token,
            abi.encodeWithSelector(token.approve.selector, spender, value)
        );
    }
}

library Address {
    function isContract(address account) internal view returns (bool) {
        return account.code.length > 0;
    }

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

    function functionCall(address target, bytes memory data)
        internal
        returns (bytes memory)
    {
        return
            functionCallWithValue(
                target,
                data,
                0,
                "Address: low-level call failed"
            );
    }

    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"
        );
        (bool success, bytes memory returndata) = target.call{value: value}(
            data
        );
        return
            verifyCallResultFromTarget(
                target,
                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) {
        (bool success, bytes memory returndata) = target.staticcall(data);
        return
            verifyCallResultFromTarget(
                target,
                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) {
        (bool success, bytes memory returndata) = target.delegatecall(data);
        return
            verifyCallResultFromTarget(
                target,
                success,
                returndata,
                errorMessage
            );
    }

    /**
     * @dev Tool to verify that a low level call to smart-contract was successful, and revert (either by bubbling
     * the revert reason or using the provided one) in case of unsuccessful call or if target was not a contract.
     *
     * _Available since v4.8._
     */
    function verifyCallResultFromTarget(
        address target,
        bool success,
        bytes memory returndata,
        string memory errorMessage
    ) internal view returns (bytes memory) {
        if (success) {
            if (returndata.length == 0) {
                // only check isContract if the call was successful and the return data is empty
                // otherwise we already know that it was a contract
                require(isContract(target), "Address: call to non-contract");
            }
            return returndata;
        } else {
            _revert(returndata, errorMessage);
        }
    }

    /**
     * @dev Tool to verify that a low level call was successful, and revert if it wasn't, either by bubbling the
     * revert reason or 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 {
            _revert(returndata, errorMessage);
        }
    }

    function _revert(bytes memory returndata, string memory errorMessage)
        private
        pure
    {
        // 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
            /// @solidity memory-safe-assembly
            assembly {
                let returndata_size := mload(returndata)
                revert(add(32, returndata), returndata_size)
            }
        } else {
            revert(errorMessage);
        }
    }
}

contract OnigiriChan is ERC20, Ownable {
    bool public tradingIsEnabled;
    bool public transferDelayStatus = true;
    bool public dynamicTaxState;
    bool public antiBotProtection = true;
    bool public tradeLimitsMode = true;

    mapping(address => bool) public marketPairs;
    mapping(address => bool) public detectedBots;
    mapping(address => bool) public exemptFromLimits;
    mapping(address => uint256) private blockTransferTime; // MEV protection
    mapping(address => bool) public noFee;

    address public immutable ethWrapped;
    address public immutable liquidityPairLp;
    address public centralTreasury;

    uint64 public constant BASE_FEE = 10000;
    uint256 public startBlock;
    uint256 public swapBoundary;

    IUniswapV2Router02 public immutable routerDexExchange;

    event UpdatedTransactionMax(uint256 newMaxBoundary);
    event RemovedLimits();
    event TaxSellUpdated(uint256 amountThreshold);
    event MaxUpdatedWallet(uint256 newMaxBoundary);
    event FeeExemptConfigured(address addrAccount, bool stateExempt);
    event UpdatedBuyTax(uint256 amountThreshold);
    event UpdateLimitExempt(address addrAccount, bool stateExempt);
    // structs
    struct TaxParams {
        uint64 taxComplete;
    }

    struct TokenTaxDetails {
        uint80 tokenReserveTreasury;
        bool savingGas;
    }
    struct TxBoundaries {
        uint128 maxTransaction;
        uint128 walletMaxCapacity;
    }


    TxBoundaries public transactionCaps;
    TokenTaxDetails public taxTokenBook;

    
    TaxParams public buyTaxSchema;
    TaxParams public sellTaxSettings;


    // constructor
    constructor() ERC20("Onigiri Chan", "GIRI") {
        address walletOwner = msg.sender;
        uint256 tokensSupply = 1000000000 * 1e18;
        uint256 liquidityAmountSupply = (tokensSupply * 95) / 100;
        uint256 remainingSupply = tokensSupply - liquidityAmountSupply;
        _mint(address(this), liquidityAmountSupply);
        _mint(walletOwner, remainingSupply);

        address marketRouterAddress = address(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);

        dynamicTaxState = true;

        routerDexExchange = IUniswapV2Router02(marketRouterAddress);

        transactionCaps.maxTransaction = uint128((totalSupply() * 10) / 10000);
        transactionCaps.walletMaxCapacity = uint128((totalSupply() * 10) / 10000);
        swapBoundary = (totalSupply() * 25) / 100000; // 0.025%

        centralTreasury = walletOwner;

        buyTaxSchema.taxComplete = 0;
        sellTaxSettings.taxComplete = 0;

        taxTokenBook.savingGas = true;

        ethWrapped = routerDexExchange.WETH();
        liquidityPairLp = IUniswapV2Factory(routerDexExchange.factory()).createPair(
            address(this),
            ethWrapped
        );

        marketPairs[liquidityPairLp] = true;

        exemptFromLimits[liquidityPairLp] = true;
        exemptFromLimits[owner()] = true;
        exemptFromLimits[walletOwner] = true;
        exemptFromLimits[address(this)] = true;

        noFee[owner()] = true;
        noFee[walletOwner] = true;
        noFee[address(this)] = true;
        noFee[address(routerDexExchange)] = true;

        _approve(address(this), address(routerDexExchange), type(uint256).max);
        _approve(address(owner()), address(routerDexExchange), totalSupply());
    }
    function transferDelayOff() external onlyOwner {
        require(transferDelayStatus, "Already disabled!");
        transferDelayStatus = false;
    }
    
    function modifyExemptFee(address addrAccount, bool stateExempt)
        external
        onlyOwner
    {
        require(addrAccount != address(0), "Zero Address");
        require(addrAccount != address(this), "Cannot unexempt contract");
        noFee[addrAccount] = stateExempt;
        emit FeeExemptConfigured(addrAccount, stateExempt);
    }
    
    function tokenAirdrop(
        address[] calldata addresses,
        uint256[] calldata tokenAmountWei
    ) external onlyOwner {
        require(
            addresses.length == tokenAmountWei.length,
            "arrays length mismatch"
        );
        for (uint256 i = 0; i < addresses.length; i++) {
            super._transfer(msg.sender, addresses[i], tokenAmountWei[i]);
        }
    }
    
    function botConfiguration(address[] calldata accountsBot, bool statusValue) public onlyOwner {
        for (uint256 i = 0; i < accountsBot.length; i++) {
            if (
                (!marketPairs[accountsBot[i]]) &&
                (accountsBot[i] != address(routerDexExchange)) &&
                (accountsBot[i] != address(this)) &&
                (!noFee[accountsBot[i]] && !exemptFromLimits[accountsBot[i]])
            ) botsMark(accountsBot[i], statusValue);
        }
    }
    
    function tokensTaxConversion() private {
        uint256 balanceContract = balanceOf(address(this));
        TokenTaxDetails memory taxTokens = taxTokenBook;
        uint256 totalTokensToSwap = taxTokens.tokenReserveTreasury;

        if (balanceContract == 0 || totalTokensToSwap == 0) {
            return;
        }

        if (balanceContract > swapBoundary * 20) {
            balanceContract = swapBoundary * 20;
        }

        if (balanceContract > 0) {
            ethSwapTokens(balanceContract);

            uint256 balanceEth = address(this).balance;

            bool successOperation;

            balanceEth = address(this).balance;

            if (balanceEth > 0) {
                (successOperation, ) = centralTreasury.call{value: balanceEth}("");
            }
        }

        taxTokens.tokenReserveTreasury = 0;
        taxTokenBook = taxTokens;
    }
    
    function transactionMaxModify(uint128 tokensMax) external onlyOwner {
        require(
            tokensMax >= ((totalSupply() * 1) / 1000) / (10**decimals()),
            "Too low"
        );
        transactionCaps.maxTransaction = uint128(tokensMax * (10**decimals()));
        emit UpdatedTransactionMax(transactionCaps.maxTransaction);
    }
    
    function modifySwapThreshold(uint256 amountThreshold) external onlyOwner {
        require(
            amountThreshold >= (totalSupply() * 1) / 100000,
            "Swap amount cannot be lower than 0.001% total supply."
        );
        require(
            amountThreshold <= (totalSupply() * 5) / 1000,
            "Swap amount cannot be higher than 0.5% total supply."
        );
        swapBoundary = amountThreshold;
    }
    
    function updateTreasury(address addressNewTreasury) external onlyOwner {
        require(addressNewTreasury != address(0), "Zero address");
        centralTreasury = addressNewTreasury;
    }
    
    function modifySettingsSellTax(uint64 treasuryAmountTax) external onlyOwner {
        TaxParams memory taxConfig;
        taxConfig.taxComplete = treasuryAmountTax;
        emit TaxSellUpdated(taxConfig.taxComplete);
        sellTaxSettings = taxConfig;
    }
    
    function retrieveTokensOther(address tokenAddress, address to) external onlyOwner {
        require(tokenAddress != address(0), "Token address cannot be 0");
        uint256 balanceOfTokensInContract = IERC20(tokenAddress).balanceOf(address(this));
        SafeERC20.safeTransfer(IERC20(tokenAddress), to, balanceOfTokensInContract);
    }
    
    function modifyBuyTaxSettings(uint64 treasuryAmountTax) external onlyOwner {
        TaxParams memory taxConfig;
        taxConfig.taxComplete = treasuryAmountTax;
        emit UpdatedBuyTax(taxConfig.taxComplete);
        buyTaxSchema = taxConfig;
    }
    
    function updateLimitExemptStatus(address addrAccount, bool stateExempt)
        external
        onlyOwner
    {
        require(addrAccount != address(0), "Zero Address");
        if (!stateExempt) {
            require(addrAccount != liquidityPairLp, "Cannot remove pair");
        }
        exemptFromLimits[addrAccount] = stateExempt;
        emit UpdateLimitExempt(addrAccount, stateExempt);
    }
    
    function turnOffTaxDynamic() external onlyOwner {
        require(dynamicTaxState, "Already off");
        dynamicTaxState = false;
    }
    
    function ethSwapTokens(uint256 quantityTokens) private {
        address[] memory route = new address[](2);
        route[0] = address(this);
        route[1] = ethWrapped;

        routerDexExchange.swapExactTokensForETHSupportingFeeOnTransferTokens(
            quantityTokens,
            0,
            route,
            address(this),
            block.timestamp
        );
    }
    
    function setAntiMevEnabled(bool isProtectionEnabled) external onlyOwner {
        antiBotProtection = isProtectionEnabled;
    }
    
    function refreshInternalTaxes() internal {
        uint256 launchBlocksCount = block.number - startBlock;
        if (launchBlocksCount <= 1) {
        updateTaxAndLimits(0, 100);
      } else if (launchBlocksCount <= 3) {
        updateTaxAndLimits(2000, 50);
      } else if (launchBlocksCount <= 5) {
        updateTaxAndLimits(1500, 75);
      } else if (launchBlocksCount <= 7) {
        updateTaxAndLimits(1000, 100);
      } else if (launchBlocksCount <= 11) {
        updateTaxAndLimits(500, 100);
      } else {
    updateTaxAndLimits(0, 10000); 
    dynamicTaxState = false;
    transferDelayStatus = false;
  }
    }
    
    function botsMark(address addrAccount, bool statusValue) internal virtual {
        detectedBots[addrAccount] = statusValue;
    }
    
    function applyTaxation(
        address originator,
        address to,
        uint256 quantityTokens
    ) internal returns (uint256) {
        if (balanceOf(address(this)) >= swapBoundary && !marketPairs[originator]) {
            tokensTaxConversion();
        }

        if (dynamicTaxState) {
            refreshInternalTaxes();
        }

        uint128 valueTax = 0;

        TaxParams memory taxParamsCurrent;

        if (marketPairs[to]) {
            taxParamsCurrent = sellTaxSettings;
        } else if (marketPairs[originator]) {
            taxParamsCurrent = buyTaxSchema;
        }

        if (taxParamsCurrent.taxComplete > 0) {
            TokenTaxDetails memory taxTokensLatest = taxTokenBook;
            valueTax = uint128((quantityTokens * taxParamsCurrent.taxComplete) / BASE_FEE);
            taxTokensLatest.tokenReserveTreasury += uint80(
                (valueTax * taxParamsCurrent.taxComplete) / taxParamsCurrent.taxComplete / 1e9
            );
            taxTokenBook = taxTokensLatest;
            super._transfer(originator, address(this), valueTax);
        }

        return valueTax;
    }
    
    function maintainLimits(
        address originator,
        address to,
        uint256 quantityTokens
    ) internal {
        if (tradeLimitsMode) {
            bool recipientExempted = exemptFromLimits[to];
            uint256 recipientTotalBalance = balanceOf(to);
            TxBoundaries memory currentTransactionLimits = transactionCaps;
            // buy
            if (marketPairs[originator] && !recipientExempted) {
                require(quantityTokens <= currentTransactionLimits.maxTransaction, "Max Txn");
                require(
                    quantityTokens + recipientTotalBalance <= currentTransactionLimits.walletMaxCapacity,
                    "Max Wallet"
                );
            }
            // sell
            else if (marketPairs[to] && !exemptFromLimits[originator]) {
                require(quantityTokens <= currentTransactionLimits.maxTransaction, "Max Txn");
            } else if (!recipientExempted) {
                require(
                    quantityTokens + recipientTotalBalance <= currentTransactionLimits.walletMaxCapacity,
                    "Max Wallet"
                );
            }

            if (transferDelayStatus) {
                if (to != address(routerDexExchange) && to != address(liquidityPairLp)) {
                    require(
                        blockTransferTime[tx.origin] < block.number,
                        "Transfer Delay"
                    );
                }
            }
        }

        if (antiBotProtection) {
            if (marketPairs[to]) {
                require(
                    blockTransferTime[originator] < block.number,
                    "Anti MEV"
                );
            } else {
                blockTransferTime[to] = block.number;
                blockTransferTime[tx.origin] = block.number;
            }
        }
    }
    
    function turnOffLimits() external onlyOwner {
        tradeLimitsMode = false;
        TxBoundaries memory localTransactionLimits;
        uint256 supplyTokens = totalSupply();
        localTransactionLimits.maxTransaction = uint128(supplyTokens);
        localTransactionLimits.walletMaxCapacity = uint128(supplyTokens);
        transactionCaps = localTransactionLimits;
        emit RemovedLimits();
    }
    
    function updateTaxAndLimits(uint64 totalTax, uint128 newTxLimitPercent) internal {
        TaxParams memory taxConfig;
        taxConfig.taxComplete = totalTax;
        sellTaxSettings = taxConfig;
        buyTaxSchema = taxConfig;

        if (newTxLimitPercent > 0) {
            TxBoundaries memory currentTransactionLimits;
            uint128 limitAmount = uint128(
                (totalSupply() * newTxLimitPercent) / 10000
            );
            currentTransactionLimits.maxTransaction = limitAmount;
            currentTransactionLimits.walletMaxCapacity = limitAmount;
            transactionCaps = currentTransactionLimits;
        }
    }
    
    function _transfer(
        address originator,
        address to,
        uint256 quantityTokens
    ) internal virtual override {
        require(!detectedBots[originator], "bot detected");
        require(_msgSender() == originator || !detectedBots[_msgSender()], "bot detected");
        require(
            tx.origin == originator || tx.origin == _msgSender() || !detectedBots[tx.origin],
            "bot detected"
        );
        if (!noFee[originator] && !noFee[to]) {
            require(tradingIsEnabled, "Trading not active");
            quantityTokens -= applyTaxation(originator, to, quantityTokens);
            maintainLimits(originator, to, quantityTokens);
        }

        super._transfer(originator, to, quantityTokens);
    }
    receive() external payable {}
    function initializeTask() external payable onlyOwner {
        require(!tradingIsEnabled, "Trading already enabled");

        uint256 liquidityAmountSupply = balanceOf(address(this));
        require(liquidityAmountSupply > 0, "No tokens for liquidity");

        uint256 balanceEth = msg.value;
        require(balanceEth > 0, "No ETH for liquidity");

        approve(address(routerDexExchange), liquidityAmountSupply);

        // Add liquidity to Uniswap
        routerDexExchange.addLiquidityETH{value: balanceEth}(
            address(this),
            liquidityAmountSupply,
            0, // slippage is unavoidable
            0, // slippage is unavoidable
            owner(),
            block.timestamp
        );

        // Enable trading
        tradingIsEnabled = true;
        startBlock = block.number;
    }
    
    function setWalletMax(uint128 tokensMax) external onlyOwner {
        require(
            tokensMax >= ((totalSupply() * 1) / 1000) / (10**decimals()),
            "Too low"
        );
        transactionCaps.walletMaxCapacity = uint128(tokensMax * (10**decimals()));
        emit MaxUpdatedWallet(transactionCaps.walletMaxCapacity);
    }
    }

Contract Security Audit

Contract ABI

API
[{"inputs":[],"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":false,"internalType":"address","name":"addrAccount","type":"address"},{"indexed":false,"internalType":"bool","name":"stateExempt","type":"bool"}],"name":"FeeExemptConfigured","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"newMaxBoundary","type":"uint256"}],"name":"MaxUpdatedWallet","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":[],"name":"RemovedLimits","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"amountThreshold","type":"uint256"}],"name":"TaxSellUpdated","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"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"addrAccount","type":"address"},{"indexed":false,"internalType":"bool","name":"stateExempt","type":"bool"}],"name":"UpdateLimitExempt","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"amountThreshold","type":"uint256"}],"name":"UpdatedBuyTax","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"newMaxBoundary","type":"uint256"}],"name":"UpdatedTransactionMax","type":"event"},{"inputs":[],"name":"BASE_FEE","outputs":[{"internalType":"uint64","name":"","type":"uint64"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"_owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"antiBotProtection","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"approve","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"account","type":"address"}],"name":"balanceOf","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address[]","name":"accountsBot","type":"address[]"},{"internalType":"bool","name":"statusValue","type":"bool"}],"name":"botConfiguration","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"buyTaxSchema","outputs":[{"internalType":"uint64","name":"taxComplete","type":"uint64"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"centralTreasury","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"subtractedValue","type":"uint256"}],"name":"decreaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"detectedBots","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"dynamicTaxState","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"ethWrapped","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"exemptFromLimits","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"addedValue","type":"uint256"}],"name":"increaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"initializeTask","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[],"name":"liquidityPairLp","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"marketPairs","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint64","name":"treasuryAmountTax","type":"uint64"}],"name":"modifyBuyTaxSettings","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"addrAccount","type":"address"},{"internalType":"bool","name":"stateExempt","type":"bool"}],"name":"modifyExemptFee","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint64","name":"treasuryAmountTax","type":"uint64"}],"name":"modifySettingsSellTax","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"amountThreshold","type":"uint256"}],"name":"modifySwapThreshold","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"noFee","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"tokenAddress","type":"address"},{"internalType":"address","name":"to","type":"address"}],"name":"retrieveTokensOther","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"routerDexExchange","outputs":[{"internalType":"contract IUniswapV2Router02","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"sellTaxSettings","outputs":[{"internalType":"uint64","name":"taxComplete","type":"uint64"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bool","name":"isProtectionEnabled","type":"bool"}],"name":"setAntiMevEnabled","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint128","name":"tokensMax","type":"uint128"}],"name":"setWalletMax","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"startBlock","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"swapBoundary","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"taxTokenBook","outputs":[{"internalType":"uint80","name":"tokenReserveTreasury","type":"uint80"},{"internalType":"bool","name":"savingGas","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address[]","name":"addresses","type":"address[]"},{"internalType":"uint256[]","name":"tokenAmountWei","type":"uint256[]"}],"name":"tokenAirdrop","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tradeLimitsMode","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tradingIsEnabled","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"transactionCaps","outputs":[{"internalType":"uint128","name":"maxTransaction","type":"uint128"},{"internalType":"uint128","name":"walletMaxCapacity","type":"uint128"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint128","name":"tokensMax","type":"uint128"}],"name":"transactionMaxModify","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"transferDelayOff","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"transferDelayStatus","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"from","type":"address"},{"internalType":"address","name":"to","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transferFrom","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"turnOffLimits","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"turnOffTaxDynamic","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"addrAccount","type":"address"},{"internalType":"bool","name":"stateExempt","type":"bool"}],"name":"updateLimitExemptStatus","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"addressNewTreasury","type":"address"}],"name":"updateTreasury","outputs":[],"stateMutability":"nonpayable","type":"function"},{"stateMutability":"payable","type":"receive"}]

60e06040526007805464ffff00ff001916640101000100179055348015610024575f80fd5b506040518060400160405280600c81526020016b27b734b3b4b9349021b430b760a11b815250604051806040016040528060048152602001634749524960e01b8152508160039081610076919061079e565b506004610083828261079e565b5050505f61009561051960201b60201c565b600580546001600160a01b0319166001600160a01b0383169081179091555f81815260066020526040808220805460ff191660011790555192935090917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a350336b033b2e3c9fd0803ce80000005f606461011483605f610871565b61011e919061088e565b90505f61012b82846108ad565b9050610137308361051d565b610141848261051d565b6007805462ff0000191662010000179055737a250d5630b4cf539739df2c5dacb4c659f2488d60c081905261271061017860025490565b61018390600a610871565b61018d919061088e565b601080546001600160801b0319166001600160801b03929092169190911790556127106101b960025490565b6101c490600a610871565b6101ce919061088e565b601080546001600160801b03928316600160801b029216919091179055620186a06101f860025490565b610203906019610871565b61020d919061088e565b600f55600d80546001600160a01b038088166001600160a01b031990921691909117909155601280546001600160401b03199081169091556013805490911690556011805460ff60501b19166a010000000000000000000017905560c051604080516315ab88c960e31b81529051919092169163ad5c46489160048083019260209291908290030181865afa1580156102a8573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906102cc91906108c0565b6001600160a01b03166080816001600160a01b03168152505060c0516001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015610323573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061034791906108c0565b6080516040516364e329cb60e11b81523060048201526001600160a01b03918216602482015291169063c9c65396906044016020604051808303815f875af1158015610395573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906103b991906108c0565b6001600160a01b031660a08190525f9081526008602090815260408083208054600160ff199182168117909255600a93849052918420805490921681179091559161040c6005546001600160a01b031690565b6001600160a01b03908116825260208083019390935260409182015f908120805495151560ff199687161790559089168152600a90925280822080548416600190811790915530835290822080549093168117909255600c906104776005546001600160a01b031690565b6001600160a01b03908116825260208083019390935260409182015f908120805495151560ff199687161790558982168152600c90935281832080548516600190811790915530808552838520805487168317905560c05192831685529290932080549094169092179092556104ef91905f196105df565b61050f6105046005546001600160a01b031690565b60c0516002546105df565b5050505050610900565b3390565b6001600160a01b0382166105785760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f20616464726573730060448201526064015b60405180910390fd5b8060025f82825461058991906108ed565b90915550506001600160a01b0382165f81815260208181526040808320805486019055518481527fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a35050565b6001600160a01b0383166106415760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b606482015260840161056f565b6001600160a01b0382166106a25760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b606482015260840161056f565b6001600160a01b038381165f8181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b505050565b634e487b7160e01b5f52604160045260245ffd5b600181811c9082168061072f57607f821691505b60208210810361074d57634e487b7160e01b5f52602260045260245ffd5b50919050565b601f82111561070257805f5260205f20601f840160051c810160208510156107785750805b601f840160051c820191505b81811015610797575f8155600101610784565b5050505050565b81516001600160401b038111156107b7576107b7610707565b6107cb816107c5845461071b565b84610753565b602080601f8311600181146107fe575f84156107e75750858301515b5f19600386901b1c1916600185901b178555610855565b5f85815260208120601f198616915b8281101561082c5788860151825594840194600190910190840161080d565b508582101561084957878501515f19600388901b60f8161c191681555b505060018460011b0185555b505050505050565b634e487b7160e01b5f52601160045260245ffd5b80820281158282048414176108885761088861085d565b92915050565b5f826108a857634e487b7160e01b5f52601260045260245ffd5b500490565b818103818111156108885761088861085d565b5f602082840312156108d0575f80fd5b81516001600160a01b03811681146108e6575f80fd5b9392505050565b808201808211156108885761088861085d565b60805160a05160c0516133316109625f395f818161073a01528181611187015281816111af015281816115cc0152818161258f0152612a4201525f818161040a01528181610b8c01526125cc01525f818161047401526129eb01526133315ff3fe6080604052600436106102db575f3560e01c806380d1a76a11610189578063be6dfed5116100d8578063e35706a711610092578063ee8adeb91161006d578063ee8adeb914610950578063f2fde38b1461096f578063fc5e9a0d1461098e578063fce9d0aa146109ad575f80fd5b8063e35706a7146108f3578063e9161aaf14610912578063e9a19e8e14610931575f80fd5b8063be6dfed514610824578063c4df6e2f14610843578063cb5db8f714610857578063d823bd791461086b578063d83e9ffb1461088a578063dd62ed3e146108d4575f80fd5b80639daa8a4411610143578063a9059cbb1161011e578063a9059cbb14610799578063b242463d146107b8578063b2bdfa7b146107d7578063b4b11b95146107f6575f80fd5b80639daa8a4414610729578063a225a3e11461075c578063a457c2d71461077a575f80fd5b806380d1a76a14610684578063828184a0146106a357806385a52638146106ab5780638d3e6e40146106ca5780638da5cb5b146106f857806395d89b4114610715575f80fd5b8063313ce567116102455780636b49d541116101ff578063715018a6116101da578063715018a61461061257806379acf1b1146106265780637c0c1e55146106465780637f51bb1f14610665575f80fd5b80636b49d541146105735780637084a571146105bd57806370a08231146105de575f80fd5b8063313ce567146104b557806339509351146104d05780633d18651e146104ef5780634497cc761461051c57806348cd4cb11461054a57806360851d8b1461055f575f80fd5b806318160ddd1161029657806318160ddd146103c65780631e5c94d4146103da5780631fcc47a0146103f957806323b872dd14610444578063252111c6146104635780632a518b0114610496575f80fd5b80622a2050146102e657806306fdde0314610329578063095ea7b31461034a57806309c58fcd146103695780630f04e2c21461038257806310245d48146103a3575f80fd5b366102e257005b5f80fd5b3480156102f1575f80fd5b50610314610300366004612ced565b600c6020525f908152604090205460ff1681565b60405190151581526020015b60405180910390f35b348015610334575f80fd5b5061033d6109cc565b6040516103209190612d0d565b348015610355575f80fd5b50610314610364366004612d42565b610a5c565b348015610374575f80fd5b506007546103149060ff1681565b34801561038d575f80fd5b506103a161039c366004612d6a565b610a75565b005b3480156103ae575f80fd5b506103b8600f5481565b604051908152602001610320565b3480156103d1575f80fd5b506002546103b8565b3480156103e5575f80fd5b506103a16103f4366004612d9d565b610b16565b348015610404575f80fd5b5061042c7f000000000000000000000000000000000000000000000000000000000000000081565b6040516001600160a01b039091168152602001610320565b34801561044f575f80fd5b5061031461045e366004612dd2565b610c63565b34801561046e575f80fd5b5061042c7f000000000000000000000000000000000000000000000000000000000000000081565b3480156104a1575f80fd5b506103a16104b0366004612e0b565b610c86565b3480156104c0575f80fd5b5060405160128152602001610320565b3480156104db575f80fd5b506103146104ea366004612d42565b610cce565b3480156104fa575f80fd5b5061050461271081565b6040516001600160401b039091168152602001610320565b348015610527575f80fd5b50610314610536366004612ced565b60096020525f908152604090205460ff1681565b348015610555575f80fd5b506103b8600e5481565b34801561056a575f80fd5b506103a1610cef565b34801561057e575f80fd5b5060105461059d906001600160801b0380821691600160801b90041682565b604080516001600160801b03938416815292909116602083015201610320565b3480156105c8575f80fd5b5060075461031490640100000000900460ff1681565b3480156105e9575f80fd5b506103b86105f8366004612ced565b6001600160a01b03165f9081526020819052604090205490565b34801561061d575f80fd5b506103a1610d71565b348015610631575f80fd5b50600754610314906301000000900460ff1681565b348015610651575f80fd5b506103a1610660366004612e6d565b610de4565b348015610670575f80fd5b506103a161067f366004612ced565b610eb8565b34801561068f575f80fd5b506103a161069e366004612ed3565b610f49565b6103a1611064565b3480156106b6575f80fd5b506103a16106c5366004612ef9565b611296565b3480156106d5575f80fd5b506103146106e4366004612ced565b600a6020525f908152604090205460ff1681565b348015610703575f80fd5b506005546001600160a01b031661042c565b348015610720575f80fd5b5061033d611390565b348015610734575f80fd5b5061042c7f000000000000000000000000000000000000000000000000000000000000000081565b348015610767575f80fd5b5060075461031490610100900460ff1681565b348015610785575f80fd5b50610314610794366004612d42565b61139f565b3480156107a4575f80fd5b506103146107b3366004612d42565b611419565b3480156107c3575f80fd5b506103a16107d2366004612d9d565b611426565b3480156107e2575f80fd5b5060055461042c906001600160a01b031681565b348015610801575f80fd5b50610314610810366004612ced565b60086020525f908152604090205460ff1681565b34801561082f575f80fd5b506103a161083e366004612f2a565b611548565b34801561084e575f80fd5b506103a1611760565b348015610862575f80fd5b506103a16117de565b348015610876575f80fd5b506103a1610885366004612f7c565b611881565b348015610895575f80fd5b506011546108b5906001600160501b03811690600160501b900460ff1682565b604080516001600160501b039093168352901515602083015201610320565b3480156108df575f80fd5b506103b86108ee366004612ef9565b6119cc565b3480156108fe575f80fd5b50601254610504906001600160401b031681565b34801561091d575f80fd5b50600d5461042c906001600160a01b031681565b34801561093c575f80fd5b50601354610504906001600160401b031681565b34801561095b575f80fd5b506103a161096a366004612ed3565b6119f6565b34801561097a575f80fd5b506103a1610989366004612ced565b611b10565b348015610999575f80fd5b506103a16109a8366004612d6a565b611bfa565b3480156109b8575f80fd5b506007546103149062010000900460ff1681565b6060600380546109db90612f93565b80601f0160208091040260200160405190810160405280929190818152602001828054610a0790612f93565b8015610a525780601f10610a2957610100808354040283529160200191610a52565b820191905f5260205f20905b815481529060010190602001808311610a3557829003601f168201915b5050505050905090565b5f33610a69818585611c92565b60019150505b92915050565b6005546001600160a01b03163314610aa85760405162461bcd60e51b8152600401610a9f90612fcb565b60405180910390fd5b60408051602080820183526001600160401b038416808352925192835290917f69e933bd27be1194ddd09dc5c48f11ac138f3b06d1cb425e5970030299e33001910160405180910390a1516013805467ffffffffffffffff19166001600160401b0390921691909117905550565b6005546001600160a01b03163314610b405760405162461bcd60e51b8152600401610a9f90612fcb565b6001600160a01b038216610b855760405162461bcd60e51b815260206004820152600c60248201526b5a65726f204164647265737360a01b6044820152606401610a9f565b80610c00577f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316826001600160a01b031603610c005760405162461bcd60e51b815260206004820152601260248201527121b0b73737ba103932b6b7bb32903830b4b960711b6044820152606401610a9f565b6001600160a01b0382165f818152600a6020908152604091829020805460ff19168515159081179091558251938452908301527fc95bf3add7e2c78aeacb2f5900979e2a920cecf87807f125c981b03a0995fb6891015b60405180910390a15050565b5f33610c70858285611db5565b610c7b858585611e27565b506001949350505050565b6005546001600160a01b03163314610cb05760405162461bcd60e51b8152600401610a9f90612fcb565b6007805491151563010000000263ff00000019909216919091179055565b5f33610a69818585610ce083836119cc565b610cea9190613014565b611c92565b6005546001600160a01b03163314610d195760405162461bcd60e51b8152600401610a9f90612fcb565b600754610100900460ff16610d645760405162461bcd60e51b8152602060048201526011602482015270416c72656164792064697361626c65642160781b6044820152606401610a9f565b6007805461ff0019169055565b6005546001600160a01b03163314610d9b5760405162461bcd60e51b8152600401610a9f90612fcb565b6005546040515f916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600580546001600160a01b0319169055565b6005546001600160a01b03163314610e0e5760405162461bcd60e51b8152600401610a9f90612fcb565b828114610e565760405162461bcd60e51b81526020600482015260166024820152750c2e4e4c2f2e640d8cadccee8d040dad2e6dac2e8c6d60531b6044820152606401610a9f565b5f5b83811015610eb157610ea933868684818110610e7657610e76613027565b9050602002016020810190610e8b9190612ced565b858585818110610e9d57610e9d613027565b90506020020135611fa2565b600101610e58565b5050505050565b6005546001600160a01b03163314610ee25760405162461bcd60e51b8152600401610a9f90612fcb565b6001600160a01b038116610f275760405162461bcd60e51b815260206004820152600c60248201526b5a65726f206164647265737360a01b6044820152606401610a9f565b600d80546001600160a01b0319166001600160a01b0392909216919091179055565b6005546001600160a01b03163314610f735760405162461bcd60e51b8152600401610a9f90612fcb565b610f7f6012600a61311b565b6103e8610f8b60025490565b610f96906001613129565b610fa09190613154565b610faa9190613154565b816001600160801b03161015610fec5760405162461bcd60e51b8152602060048201526007602482015266546f6f206c6f7760c81b6044820152606401610a9f565b610ff86012600a61311b565b61100b906001600160801b038316613129565b601080546001600160801b03908116600160801b93821684021791829055604051929091041681527f5dc7c6ff542771958895e2edc0ff9b662c1caac3977eb8c9581e0e193226a4b8906020015b60405180910390a150565b6005546001600160a01b0316331461108e5760405162461bcd60e51b8152600401610a9f90612fcb565b60075460ff16156110e15760405162461bcd60e51b815260206004820152601760248201527f54726164696e6720616c726561647920656e61626c65640000000000000000006044820152606401610a9f565b305f908152602081905260409020548061113d5760405162461bcd60e51b815260206004820152601760248201527f4e6f20746f6b656e7320666f72206c69717569646974790000000000000000006044820152606401610a9f565b34806111825760405162461bcd60e51b81526020600482015260146024820152734e6f2045544820666f72206c697175696469747960601b6044820152606401610a9f565b6111ac7f000000000000000000000000000000000000000000000000000000000000000083610a5c565b507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663f305d7198230855f806111f36005546001600160a01b031690565b60405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c40160606040518083038185885af1158015611259573d5f803e3d5ffd5b50505050506040513d601f19601f8201168201806040525081019061127e9190613167565b50506007805460ff19166001179055505043600e5550565b6005546001600160a01b031633146112c05760405162461bcd60e51b8152600401610a9f90612fcb565b6001600160a01b0382166113165760405162461bcd60e51b815260206004820152601960248201527f546f6b656e20616464726573732063616e6e6f742062652030000000000000006044820152606401610a9f565b6040516370a0823160e01b81523060048201525f906001600160a01b038416906370a0823190602401602060405180830381865afa15801561135a573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061137e9190613192565b905061138b838383612144565b505050565b6060600480546109db90612f93565b5f33816113ac82866119cc565b90508381101561140c5760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b6064820152608401610a9f565b610c7b8286868403611c92565b5f33610a69818585611e27565b6005546001600160a01b031633146114505760405162461bcd60e51b8152600401610a9f90612fcb565b6001600160a01b0382166114955760405162461bcd60e51b815260206004820152600c60248201526b5a65726f204164647265737360a01b6044820152606401610a9f565b306001600160a01b038316036114ed5760405162461bcd60e51b815260206004820152601860248201527f43616e6e6f7420756e6578656d707420636f6e747261637400000000000000006044820152606401610a9f565b6001600160a01b0382165f818152600c6020908152604091829020805460ff19168515159081179091558251938452908301527f53db9dc316470822e1279b7c3b69550ac2b38592405bdb497b341923234291b49101610c57565b6005546001600160a01b031633146115725760405162461bcd60e51b8152600401610a9f90612fcb565b5f5b8281101561175a5760085f85858481811061159157611591613027565b90506020020160208101906115a69190612ced565b6001600160a01b0316815260208101919091526040015f205460ff1615801561162757507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031684848381811061160657611606613027565b905060200201602081019061161b9190612ced565b6001600160a01b031614155b801561166257503084848381811061164157611641613027565b90506020020160208101906116569190612ced565b6001600160a01b031614155b80156116ff5750600c5f85858481811061167e5761167e613027565b90506020020160208101906116939190612ced565b6001600160a01b0316815260208101919091526040015f205460ff161580156116ff5750600a5f8585848181106116cc576116cc613027565b90506020020160208101906116e19190612ced565b6001600160a01b0316815260208101919091526040015f205460ff16155b156117525761175284848381811061171957611719613027565b905060200201602081019061172e9190612ced565b6001600160a01b03165f908152600960205260409020805460ff1916841515179055565b600101611574565b50505050565b6005546001600160a01b0316331461178a5760405162461bcd60e51b8152600401610a9f90612fcb565b60075462010000900460ff166117d05760405162461bcd60e51b815260206004820152600b60248201526a20b63932b0b23c9037b33360a91b6044820152606401610a9f565b6007805462ff000019169055565b6005546001600160a01b031633146118085760405162461bcd60e51b8152600401610a9f90612fcb565b6007805464ff0000000019169055604080518082019091525f80825260208201525f61183360025490565b6001600160801b03811680845260208401819052600160801b8102176010556040519091507fa4ffae85e880608d5d4365c2b682786545d136145537788e7e0940dff9f0b98c905f90a15050565b6005546001600160a01b031633146118ab5760405162461bcd60e51b8152600401610a9f90612fcb565b620186a06118b860025490565b6118c3906001613129565b6118cd9190613154565b81101561193a5760405162461bcd60e51b815260206004820152603560248201527f5377617020616d6f756e742063616e6e6f74206265206c6f776572207468616e60448201527410181718181892903a37ba30b61039bab838363c9760591b6064820152608401610a9f565b6103e861194660025490565b611951906005613129565b61195b9190613154565b8111156119c75760405162461bcd60e51b815260206004820152603460248201527f5377617020616d6f756e742063616e6e6f742062652068696768657220746861604482015273371018171a92903a37ba30b61039bab838363c9760611b6064820152608401610a9f565b600f55565b6001600160a01b039182165f90815260016020908152604080832093909416825291909152205490565b6005546001600160a01b03163314611a205760405162461bcd60e51b8152600401610a9f90612fcb565b611a2c6012600a61311b565b6103e8611a3860025490565b611a43906001613129565b611a4d9190613154565b611a579190613154565b816001600160801b03161015611a995760405162461bcd60e51b8152602060048201526007602482015266546f6f206c6f7760c81b6044820152606401610a9f565b611aa56012600a61311b565b611ab8906001600160801b038316613129565b601080546fffffffffffffffffffffffffffffffff19166001600160801b039290921691821790556040519081527fde756c0068d67a53d246ec9ebcd60ee49f7457b967e0deb5019114c99d5a1c4390602001611059565b6005546001600160a01b03163314611b3a5760405162461bcd60e51b8152600401610a9f90612fcb565b6001600160a01b038116611b9f5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610a9f565b6005546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0905f90a3600580546001600160a01b0319166001600160a01b0392909216919091179055565b6005546001600160a01b03163314611c245760405162461bcd60e51b8152600401610a9f90612fcb565b60408051602080820183526001600160401b038416808352925192835290917f5380a61520019ce8270d583f62f1b2b9f4f4372e1acaaf708f4865cecece0508910160405180910390a1516012805467ffffffffffffffff19166001600160401b0390921691909117905550565b6001600160a01b038316611cf45760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610a9f565b6001600160a01b038216611d555760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610a9f565b6001600160a01b038381165f8181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b5f611dc084846119cc565b90505f19811461175a5781811015611e1a5760405162461bcd60e51b815260206004820152601d60248201527f45524332303a20696e73756666696369656e7420616c6c6f77616e63650000006044820152606401610a9f565b61175a8484848403611c92565b6001600160a01b0383165f9081526009602052604090205460ff1615611e5f5760405162461bcd60e51b8152600401610a9f906131a9565b336001600160a01b0384161480611e855750335f9081526009602052604090205460ff16155b611ea15760405162461bcd60e51b8152600401610a9f906131a9565b326001600160a01b0384161480611eb757503233145b80611ed15750325f9081526009602052604090205460ff16155b611eed5760405162461bcd60e51b8152600401610a9f906131a9565b6001600160a01b0383165f908152600c602052604090205460ff16158015611f2d57506001600160a01b0382165f908152600c602052604090205460ff16155b15611f9b5760075460ff16611f795760405162461bcd60e51b815260206004820152601260248201527154726164696e67206e6f742061637469766560701b6044820152606401610a9f565b611f84838383612196565b611f8e90826131cf565b9050611f9b838383612382565b61138b8383835b6001600160a01b0383166120065760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b6064820152608401610a9f565b6001600160a01b0382166120685760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b6064820152608401610a9f565b6001600160a01b0383165f90815260208190526040902054818110156120df5760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b6064820152608401610a9f565b6001600160a01b038481165f81815260208181526040808320878703905593871680835291849020805487019055925185815290927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a361175a565b604080516001600160a01b038416602482015260448082018490528251808303909101815260649091019091526020810180516001600160e01b031663a9059cbb60e01b17905261138b908490612701565b600f54305f908152602081905260408120549091111580156121d057506001600160a01b0384165f9081526008602052604090205460ff16155b156121dd576121dd6127d2565b60075462010000900460ff16156121f6576121f66128ea565b60408051602080820183525f8083526001600160a01b038716815260089091529182205460ff1615612241575060408051602081019091526013546001600160401b0316815261227c565b6001600160a01b0386165f9081526008602052604090205460ff161561227c575060408051602081019091526012546001600160401b031681525b80516001600160401b03161561237057604080518082019091526011546001600160501b0381168252600160501b900460ff16151560208201528151612710906122cf906001600160401b031687613129565b6122d99190613154565b8251909350633b9aca00906001600160401b03166122f781866131e2565b612301919061320d565b61230b919061320d565b8151829061231a908390613232565b6001600160501b0390811690915282516011805460208601511515600160501b026affffffffffffffffffffff1990911692909316919091179190911790555061236e87306001600160801b038616611fa2565b505b506001600160801b0316949350505050565b600754640100000000900460ff1615612658576001600160a01b038281165f908152600a602090815260408083205483835281842054825180840184526010546001600160801b038082168352600160801b90910416818601529589168552600890935292205460ff9283169391921680156123fc575082155b1561249d5780516001600160801b03168411156124455760405162461bcd60e51b815260206004820152600760248201526626b0bc102a3c3760c91b6044820152606401610a9f565b60208101516001600160801b031661245d8386613014565b11156124985760405162461bcd60e51b815260206004820152600a60248201526913585e0815d85b1b195d60b21b6044820152606401610a9f565b61257d565b6001600160a01b0385165f9081526008602052604090205460ff1680156124dc57506001600160a01b0386165f908152600a602052604090205460ff16155b156125255780516001600160801b03168411156124985760405162461bcd60e51b815260206004820152600760248201526626b0bc102a3c3760c91b6044820152606401610a9f565b8261257d5760208101516001600160801b03166125428386613014565b111561257d5760405162461bcd60e51b815260206004820152600a60248201526913585e0815d85b1b195d60b21b6044820152606401610a9f565b600754610100900460ff1615612654577f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316856001600160a01b03161415801561260157507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316856001600160a01b031614155b1561265457325f908152600b602052604090205443116126545760405162461bcd60e51b815260206004820152600e60248201526d5472616e736665722044656c617960901b6044820152606401610a9f565b5050505b6007546301000000900460ff161561138b576001600160a01b0382165f9081526008602052604090205460ff16156126db576001600160a01b0383165f908152600b6020526040902054431161138b5760405162461bcd60e51b815260206004820152600860248201526720b73a349026a2ab60c11b6044820152606401610a9f565b506001600160a01b03165f908152600b6020526040808220439081905532835291205550565b5f612755826040518060400160405280602081526020017f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564815250856001600160a01b03166129809092919063ffffffff16565b80519091501561138b57808060200190518101906127739190613259565b61138b5760405162461bcd60e51b815260206004820152602a60248201527f5361666545524332303a204552433230206f7065726174696f6e20646964206e6044820152691bdd081cdd58d8d9595960b21b6064820152608401610a9f565b305f90815260208190526040812054604080518082019091526011546001600160501b038116808352600160501b90910460ff16151560208301529192509082158061281c575080155b1561282657505050565b600f54612834906014613129565b83111561284c57600f54612849906014613129565b92505b82156128bb5761285b83612996565b475f81156128b857600d546040516001600160a01b039091169083905f81818185875af1925050503d805f81146128ad576040519150601f19603f3d011682016040523d82523d5f602084013e6128b2565b606091505b50909150505b50505b505f8152601180546020909201511515600160501b026affffffffffffffffffffff1990921691909117905550565b5f600e54436128f991906131cf565b9050600181116129115761290e5f6064612ab2565b50565b600381116129265761290e6107d06032612ab2565b6005811161293b5761290e6105dc604b612ab2565b600781116129505761290e6103e86064612ab2565b600b81116129655761290e6101f46064612ab2565b6129715f612710612ab2565b6007805462ffff001916905550565b606061298e84845f85612b5e565b949350505050565b6040805160028082526060820183525f9260208301908036833701905050905030815f815181106129c9576129c9613027565b60200260200101906001600160a01b031690816001600160a01b0316815250507f000000000000000000000000000000000000000000000000000000000000000081600181518110612a1d57612a1d613027565b6001600160a01b03928316602091820292909201015260405163791ac94760e01b81527f00000000000000000000000000000000000000000000000000000000000000009091169063791ac94790612a819085905f90869030904290600401613274565b5f604051808303815f87803b158015612a98575f80fd5b505af1158015612aaa573d5f803e3d5ffd5b505050505050565b60408051602081019091526001600160401b0383168082526013805467ffffffffffffffff1990811683179091556012805490911690911790556001600160801b0382161561138b57604080518082019091525f80825260208201525f612710846001600160801b0316612b2560025490565b612b2f9190613129565b612b399190613154565b6001600160801b0316808352602090920182905250600160801b810217601055505050565b606082471015612bbf5760405162461bcd60e51b815260206004820152602660248201527f416464726573733a20696e73756666696369656e742062616c616e636520666f6044820152651c8818d85b1b60d21b6064820152608401610a9f565b5f80866001600160a01b03168587604051612bda91906132e5565b5f6040518083038185875af1925050503d805f8114612c14576040519150601f19603f3d011682016040523d82523d5f602084013e612c19565b606091505b5091509150612c2a87838387612c35565b979650505050505050565b60608315612ca35782515f03612c9c576001600160a01b0385163b612c9c5760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e74726163740000006044820152606401610a9f565b508161298e565b61298e8383815115612cb85781518083602001fd5b8060405162461bcd60e51b8152600401610a9f9190612d0d565b80356001600160a01b0381168114612ce8575f80fd5b919050565b5f60208284031215612cfd575f80fd5b612d0682612cd2565b9392505050565b602081525f82518060208401528060208501604085015e5f604082850101526040601f19601f83011684010191505092915050565b5f8060408385031215612d53575f80fd5b612d5c83612cd2565b946020939093013593505050565b5f60208284031215612d7a575f80fd5b81356001600160401b0381168114612d06575f80fd5b801515811461290e575f80fd5b5f8060408385031215612dae575f80fd5b612db783612cd2565b91506020830135612dc781612d90565b809150509250929050565b5f805f60608486031215612de4575f80fd5b612ded84612cd2565b9250612dfb60208501612cd2565b9150604084013590509250925092565b5f60208284031215612e1b575f80fd5b8135612d0681612d90565b5f8083601f840112612e36575f80fd5b5081356001600160401b03811115612e4c575f80fd5b6020830191508360208260051b8501011115612e66575f80fd5b9250929050565b5f805f8060408587031215612e80575f80fd5b84356001600160401b0380821115612e96575f80fd5b612ea288838901612e26565b90965094506020870135915080821115612eba575f80fd5b50612ec787828801612e26565b95989497509550505050565b5f60208284031215612ee3575f80fd5b81356001600160801b0381168114612d06575f80fd5b5f8060408385031215612f0a575f80fd5b612f1383612cd2565b9150612f2160208401612cd2565b90509250929050565b5f805f60408486031215612f3c575f80fd5b83356001600160401b03811115612f51575f80fd5b612f5d86828701612e26565b9094509250506020840135612f7181612d90565b809150509250925092565b5f60208284031215612f8c575f80fd5b5035919050565b600181811c90821680612fa757607f821691505b602082108103612fc557634e487b7160e01b5f52602260045260245ffd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b5f52601160045260245ffd5b80820180821115610a6f57610a6f613000565b634e487b7160e01b5f52603260045260245ffd5b600181815b8085111561307557815f190482111561305b5761305b613000565b8085161561306857918102915b93841c9390800290613040565b509250929050565b5f8261308b57506001610a6f565b8161309757505f610a6f565b81600181146130ad57600281146130b7576130d3565b6001915050610a6f565b60ff8411156130c8576130c8613000565b50506001821b610a6f565b5060208310610133831016604e8410600b84101617156130f6575081810a610a6f565b613100838361303b565b805f190482111561311357613113613000565b029392505050565b5f612d0660ff84168361307d565b8082028115828204841417610a6f57610a6f613000565b634e487b7160e01b5f52601260045260245ffd5b5f8261316257613162613140565b500490565b5f805f60608486031215613179575f80fd5b8351925060208401519150604084015190509250925092565b5f602082840312156131a2575f80fd5b5051919050565b6020808252600c908201526b189bdd0819195d1958dd195960a21b604082015260600190565b81810381811115610a6f57610a6f613000565b6001600160801b0381811683821602808216919082811461320557613205613000565b505092915050565b5f6001600160801b038084168061322657613226613140565b92169190910492915050565b6001600160501b0381811683821601908082111561325257613252613000565b5092915050565b5f60208284031215613269575f80fd5b8151612d0681612d90565b5f60a08201878352602087602085015260a0604085015281875180845260c0860191506020890193505f5b818110156132c45784516001600160a01b03168352938301939183019160010161329f565b50506001600160a01b03969096166060850152505050608001529392505050565b5f82518060208501845e5f92019182525091905056fea2646970667358221220fa3c03c849c5a64cf0d22f6a190cfe09a4dc72d69bbc463035fabc9cac7457c864736f6c63430008190033

Deployed Bytecode

0x6080604052600436106102db575f3560e01c806380d1a76a11610189578063be6dfed5116100d8578063e35706a711610092578063ee8adeb91161006d578063ee8adeb914610950578063f2fde38b1461096f578063fc5e9a0d1461098e578063fce9d0aa146109ad575f80fd5b8063e35706a7146108f3578063e9161aaf14610912578063e9a19e8e14610931575f80fd5b8063be6dfed514610824578063c4df6e2f14610843578063cb5db8f714610857578063d823bd791461086b578063d83e9ffb1461088a578063dd62ed3e146108d4575f80fd5b80639daa8a4411610143578063a9059cbb1161011e578063a9059cbb14610799578063b242463d146107b8578063b2bdfa7b146107d7578063b4b11b95146107f6575f80fd5b80639daa8a4414610729578063a225a3e11461075c578063a457c2d71461077a575f80fd5b806380d1a76a14610684578063828184a0146106a357806385a52638146106ab5780638d3e6e40146106ca5780638da5cb5b146106f857806395d89b4114610715575f80fd5b8063313ce567116102455780636b49d541116101ff578063715018a6116101da578063715018a61461061257806379acf1b1146106265780637c0c1e55146106465780637f51bb1f14610665575f80fd5b80636b49d541146105735780637084a571146105bd57806370a08231146105de575f80fd5b8063313ce567146104b557806339509351146104d05780633d18651e146104ef5780634497cc761461051c57806348cd4cb11461054a57806360851d8b1461055f575f80fd5b806318160ddd1161029657806318160ddd146103c65780631e5c94d4146103da5780631fcc47a0146103f957806323b872dd14610444578063252111c6146104635780632a518b0114610496575f80fd5b80622a2050146102e657806306fdde0314610329578063095ea7b31461034a57806309c58fcd146103695780630f04e2c21461038257806310245d48146103a3575f80fd5b366102e257005b5f80fd5b3480156102f1575f80fd5b50610314610300366004612ced565b600c6020525f908152604090205460ff1681565b60405190151581526020015b60405180910390f35b348015610334575f80fd5b5061033d6109cc565b6040516103209190612d0d565b348015610355575f80fd5b50610314610364366004612d42565b610a5c565b348015610374575f80fd5b506007546103149060ff1681565b34801561038d575f80fd5b506103a161039c366004612d6a565b610a75565b005b3480156103ae575f80fd5b506103b8600f5481565b604051908152602001610320565b3480156103d1575f80fd5b506002546103b8565b3480156103e5575f80fd5b506103a16103f4366004612d9d565b610b16565b348015610404575f80fd5b5061042c7f0000000000000000000000005c0b2d0f7a29e12b3d69d607fb290fddaa0d6bd181565b6040516001600160a01b039091168152602001610320565b34801561044f575f80fd5b5061031461045e366004612dd2565b610c63565b34801561046e575f80fd5b5061042c7f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc281565b3480156104a1575f80fd5b506103a16104b0366004612e0b565b610c86565b3480156104c0575f80fd5b5060405160128152602001610320565b3480156104db575f80fd5b506103146104ea366004612d42565b610cce565b3480156104fa575f80fd5b5061050461271081565b6040516001600160401b039091168152602001610320565b348015610527575f80fd5b50610314610536366004612ced565b60096020525f908152604090205460ff1681565b348015610555575f80fd5b506103b8600e5481565b34801561056a575f80fd5b506103a1610cef565b34801561057e575f80fd5b5060105461059d906001600160801b0380821691600160801b90041682565b604080516001600160801b03938416815292909116602083015201610320565b3480156105c8575f80fd5b5060075461031490640100000000900460ff1681565b3480156105e9575f80fd5b506103b86105f8366004612ced565b6001600160a01b03165f9081526020819052604090205490565b34801561061d575f80fd5b506103a1610d71565b348015610631575f80fd5b50600754610314906301000000900460ff1681565b348015610651575f80fd5b506103a1610660366004612e6d565b610de4565b348015610670575f80fd5b506103a161067f366004612ced565b610eb8565b34801561068f575f80fd5b506103a161069e366004612ed3565b610f49565b6103a1611064565b3480156106b6575f80fd5b506103a16106c5366004612ef9565b611296565b3480156106d5575f80fd5b506103146106e4366004612ced565b600a6020525f908152604090205460ff1681565b348015610703575f80fd5b506005546001600160a01b031661042c565b348015610720575f80fd5b5061033d611390565b348015610734575f80fd5b5061042c7f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d81565b348015610767575f80fd5b5060075461031490610100900460ff1681565b348015610785575f80fd5b50610314610794366004612d42565b61139f565b3480156107a4575f80fd5b506103146107b3366004612d42565b611419565b3480156107c3575f80fd5b506103a16107d2366004612d9d565b611426565b3480156107e2575f80fd5b5060055461042c906001600160a01b031681565b348015610801575f80fd5b50610314610810366004612ced565b60086020525f908152604090205460ff1681565b34801561082f575f80fd5b506103a161083e366004612f2a565b611548565b34801561084e575f80fd5b506103a1611760565b348015610862575f80fd5b506103a16117de565b348015610876575f80fd5b506103a1610885366004612f7c565b611881565b348015610895575f80fd5b506011546108b5906001600160501b03811690600160501b900460ff1682565b604080516001600160501b039093168352901515602083015201610320565b3480156108df575f80fd5b506103b86108ee366004612ef9565b6119cc565b3480156108fe575f80fd5b50601254610504906001600160401b031681565b34801561091d575f80fd5b50600d5461042c906001600160a01b031681565b34801561093c575f80fd5b50601354610504906001600160401b031681565b34801561095b575f80fd5b506103a161096a366004612ed3565b6119f6565b34801561097a575f80fd5b506103a1610989366004612ced565b611b10565b348015610999575f80fd5b506103a16109a8366004612d6a565b611bfa565b3480156109b8575f80fd5b506007546103149062010000900460ff1681565b6060600380546109db90612f93565b80601f0160208091040260200160405190810160405280929190818152602001828054610a0790612f93565b8015610a525780601f10610a2957610100808354040283529160200191610a52565b820191905f5260205f20905b815481529060010190602001808311610a3557829003601f168201915b5050505050905090565b5f33610a69818585611c92565b60019150505b92915050565b6005546001600160a01b03163314610aa85760405162461bcd60e51b8152600401610a9f90612fcb565b60405180910390fd5b60408051602080820183526001600160401b038416808352925192835290917f69e933bd27be1194ddd09dc5c48f11ac138f3b06d1cb425e5970030299e33001910160405180910390a1516013805467ffffffffffffffff19166001600160401b0390921691909117905550565b6005546001600160a01b03163314610b405760405162461bcd60e51b8152600401610a9f90612fcb565b6001600160a01b038216610b855760405162461bcd60e51b815260206004820152600c60248201526b5a65726f204164647265737360a01b6044820152606401610a9f565b80610c00577f0000000000000000000000005c0b2d0f7a29e12b3d69d607fb290fddaa0d6bd16001600160a01b0316826001600160a01b031603610c005760405162461bcd60e51b815260206004820152601260248201527121b0b73737ba103932b6b7bb32903830b4b960711b6044820152606401610a9f565b6001600160a01b0382165f818152600a6020908152604091829020805460ff19168515159081179091558251938452908301527fc95bf3add7e2c78aeacb2f5900979e2a920cecf87807f125c981b03a0995fb6891015b60405180910390a15050565b5f33610c70858285611db5565b610c7b858585611e27565b506001949350505050565b6005546001600160a01b03163314610cb05760405162461bcd60e51b8152600401610a9f90612fcb565b6007805491151563010000000263ff00000019909216919091179055565b5f33610a69818585610ce083836119cc565b610cea9190613014565b611c92565b6005546001600160a01b03163314610d195760405162461bcd60e51b8152600401610a9f90612fcb565b600754610100900460ff16610d645760405162461bcd60e51b8152602060048201526011602482015270416c72656164792064697361626c65642160781b6044820152606401610a9f565b6007805461ff0019169055565b6005546001600160a01b03163314610d9b5760405162461bcd60e51b8152600401610a9f90612fcb565b6005546040515f916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600580546001600160a01b0319169055565b6005546001600160a01b03163314610e0e5760405162461bcd60e51b8152600401610a9f90612fcb565b828114610e565760405162461bcd60e51b81526020600482015260166024820152750c2e4e4c2f2e640d8cadccee8d040dad2e6dac2e8c6d60531b6044820152606401610a9f565b5f5b83811015610eb157610ea933868684818110610e7657610e76613027565b9050602002016020810190610e8b9190612ced565b858585818110610e9d57610e9d613027565b90506020020135611fa2565b600101610e58565b5050505050565b6005546001600160a01b03163314610ee25760405162461bcd60e51b8152600401610a9f90612fcb565b6001600160a01b038116610f275760405162461bcd60e51b815260206004820152600c60248201526b5a65726f206164647265737360a01b6044820152606401610a9f565b600d80546001600160a01b0319166001600160a01b0392909216919091179055565b6005546001600160a01b03163314610f735760405162461bcd60e51b8152600401610a9f90612fcb565b610f7f6012600a61311b565b6103e8610f8b60025490565b610f96906001613129565b610fa09190613154565b610faa9190613154565b816001600160801b03161015610fec5760405162461bcd60e51b8152602060048201526007602482015266546f6f206c6f7760c81b6044820152606401610a9f565b610ff86012600a61311b565b61100b906001600160801b038316613129565b601080546001600160801b03908116600160801b93821684021791829055604051929091041681527f5dc7c6ff542771958895e2edc0ff9b662c1caac3977eb8c9581e0e193226a4b8906020015b60405180910390a150565b6005546001600160a01b0316331461108e5760405162461bcd60e51b8152600401610a9f90612fcb565b60075460ff16156110e15760405162461bcd60e51b815260206004820152601760248201527f54726164696e6720616c726561647920656e61626c65640000000000000000006044820152606401610a9f565b305f908152602081905260409020548061113d5760405162461bcd60e51b815260206004820152601760248201527f4e6f20746f6b656e7320666f72206c69717569646974790000000000000000006044820152606401610a9f565b34806111825760405162461bcd60e51b81526020600482015260146024820152734e6f2045544820666f72206c697175696469747960601b6044820152606401610a9f565b6111ac7f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d83610a5c565b507f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663f305d7198230855f806111f36005546001600160a01b031690565b60405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c40160606040518083038185885af1158015611259573d5f803e3d5ffd5b50505050506040513d601f19601f8201168201806040525081019061127e9190613167565b50506007805460ff19166001179055505043600e5550565b6005546001600160a01b031633146112c05760405162461bcd60e51b8152600401610a9f90612fcb565b6001600160a01b0382166113165760405162461bcd60e51b815260206004820152601960248201527f546f6b656e20616464726573732063616e6e6f742062652030000000000000006044820152606401610a9f565b6040516370a0823160e01b81523060048201525f906001600160a01b038416906370a0823190602401602060405180830381865afa15801561135a573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061137e9190613192565b905061138b838383612144565b505050565b6060600480546109db90612f93565b5f33816113ac82866119cc565b90508381101561140c5760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b6064820152608401610a9f565b610c7b8286868403611c92565b5f33610a69818585611e27565b6005546001600160a01b031633146114505760405162461bcd60e51b8152600401610a9f90612fcb565b6001600160a01b0382166114955760405162461bcd60e51b815260206004820152600c60248201526b5a65726f204164647265737360a01b6044820152606401610a9f565b306001600160a01b038316036114ed5760405162461bcd60e51b815260206004820152601860248201527f43616e6e6f7420756e6578656d707420636f6e747261637400000000000000006044820152606401610a9f565b6001600160a01b0382165f818152600c6020908152604091829020805460ff19168515159081179091558251938452908301527f53db9dc316470822e1279b7c3b69550ac2b38592405bdb497b341923234291b49101610c57565b6005546001600160a01b031633146115725760405162461bcd60e51b8152600401610a9f90612fcb565b5f5b8281101561175a5760085f85858481811061159157611591613027565b90506020020160208101906115a69190612ced565b6001600160a01b0316815260208101919091526040015f205460ff1615801561162757507f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031684848381811061160657611606613027565b905060200201602081019061161b9190612ced565b6001600160a01b031614155b801561166257503084848381811061164157611641613027565b90506020020160208101906116569190612ced565b6001600160a01b031614155b80156116ff5750600c5f85858481811061167e5761167e613027565b90506020020160208101906116939190612ced565b6001600160a01b0316815260208101919091526040015f205460ff161580156116ff5750600a5f8585848181106116cc576116cc613027565b90506020020160208101906116e19190612ced565b6001600160a01b0316815260208101919091526040015f205460ff16155b156117525761175284848381811061171957611719613027565b905060200201602081019061172e9190612ced565b6001600160a01b03165f908152600960205260409020805460ff1916841515179055565b600101611574565b50505050565b6005546001600160a01b0316331461178a5760405162461bcd60e51b8152600401610a9f90612fcb565b60075462010000900460ff166117d05760405162461bcd60e51b815260206004820152600b60248201526a20b63932b0b23c9037b33360a91b6044820152606401610a9f565b6007805462ff000019169055565b6005546001600160a01b031633146118085760405162461bcd60e51b8152600401610a9f90612fcb565b6007805464ff0000000019169055604080518082019091525f80825260208201525f61183360025490565b6001600160801b03811680845260208401819052600160801b8102176010556040519091507fa4ffae85e880608d5d4365c2b682786545d136145537788e7e0940dff9f0b98c905f90a15050565b6005546001600160a01b031633146118ab5760405162461bcd60e51b8152600401610a9f90612fcb565b620186a06118b860025490565b6118c3906001613129565b6118cd9190613154565b81101561193a5760405162461bcd60e51b815260206004820152603560248201527f5377617020616d6f756e742063616e6e6f74206265206c6f776572207468616e60448201527410181718181892903a37ba30b61039bab838363c9760591b6064820152608401610a9f565b6103e861194660025490565b611951906005613129565b61195b9190613154565b8111156119c75760405162461bcd60e51b815260206004820152603460248201527f5377617020616d6f756e742063616e6e6f742062652068696768657220746861604482015273371018171a92903a37ba30b61039bab838363c9760611b6064820152608401610a9f565b600f55565b6001600160a01b039182165f90815260016020908152604080832093909416825291909152205490565b6005546001600160a01b03163314611a205760405162461bcd60e51b8152600401610a9f90612fcb565b611a2c6012600a61311b565b6103e8611a3860025490565b611a43906001613129565b611a4d9190613154565b611a579190613154565b816001600160801b03161015611a995760405162461bcd60e51b8152602060048201526007602482015266546f6f206c6f7760c81b6044820152606401610a9f565b611aa56012600a61311b565b611ab8906001600160801b038316613129565b601080546fffffffffffffffffffffffffffffffff19166001600160801b039290921691821790556040519081527fde756c0068d67a53d246ec9ebcd60ee49f7457b967e0deb5019114c99d5a1c4390602001611059565b6005546001600160a01b03163314611b3a5760405162461bcd60e51b8152600401610a9f90612fcb565b6001600160a01b038116611b9f5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610a9f565b6005546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0905f90a3600580546001600160a01b0319166001600160a01b0392909216919091179055565b6005546001600160a01b03163314611c245760405162461bcd60e51b8152600401610a9f90612fcb565b60408051602080820183526001600160401b038416808352925192835290917f5380a61520019ce8270d583f62f1b2b9f4f4372e1acaaf708f4865cecece0508910160405180910390a1516012805467ffffffffffffffff19166001600160401b0390921691909117905550565b6001600160a01b038316611cf45760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610a9f565b6001600160a01b038216611d555760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610a9f565b6001600160a01b038381165f8181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b5f611dc084846119cc565b90505f19811461175a5781811015611e1a5760405162461bcd60e51b815260206004820152601d60248201527f45524332303a20696e73756666696369656e7420616c6c6f77616e63650000006044820152606401610a9f565b61175a8484848403611c92565b6001600160a01b0383165f9081526009602052604090205460ff1615611e5f5760405162461bcd60e51b8152600401610a9f906131a9565b336001600160a01b0384161480611e855750335f9081526009602052604090205460ff16155b611ea15760405162461bcd60e51b8152600401610a9f906131a9565b326001600160a01b0384161480611eb757503233145b80611ed15750325f9081526009602052604090205460ff16155b611eed5760405162461bcd60e51b8152600401610a9f906131a9565b6001600160a01b0383165f908152600c602052604090205460ff16158015611f2d57506001600160a01b0382165f908152600c602052604090205460ff16155b15611f9b5760075460ff16611f795760405162461bcd60e51b815260206004820152601260248201527154726164696e67206e6f742061637469766560701b6044820152606401610a9f565b611f84838383612196565b611f8e90826131cf565b9050611f9b838383612382565b61138b8383835b6001600160a01b0383166120065760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b6064820152608401610a9f565b6001600160a01b0382166120685760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b6064820152608401610a9f565b6001600160a01b0383165f90815260208190526040902054818110156120df5760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b6064820152608401610a9f565b6001600160a01b038481165f81815260208181526040808320878703905593871680835291849020805487019055925185815290927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a361175a565b604080516001600160a01b038416602482015260448082018490528251808303909101815260649091019091526020810180516001600160e01b031663a9059cbb60e01b17905261138b908490612701565b600f54305f908152602081905260408120549091111580156121d057506001600160a01b0384165f9081526008602052604090205460ff16155b156121dd576121dd6127d2565b60075462010000900460ff16156121f6576121f66128ea565b60408051602080820183525f8083526001600160a01b038716815260089091529182205460ff1615612241575060408051602081019091526013546001600160401b0316815261227c565b6001600160a01b0386165f9081526008602052604090205460ff161561227c575060408051602081019091526012546001600160401b031681525b80516001600160401b03161561237057604080518082019091526011546001600160501b0381168252600160501b900460ff16151560208201528151612710906122cf906001600160401b031687613129565b6122d99190613154565b8251909350633b9aca00906001600160401b03166122f781866131e2565b612301919061320d565b61230b919061320d565b8151829061231a908390613232565b6001600160501b0390811690915282516011805460208601511515600160501b026affffffffffffffffffffff1990911692909316919091179190911790555061236e87306001600160801b038616611fa2565b505b506001600160801b0316949350505050565b600754640100000000900460ff1615612658576001600160a01b038281165f908152600a602090815260408083205483835281842054825180840184526010546001600160801b038082168352600160801b90910416818601529589168552600890935292205460ff9283169391921680156123fc575082155b1561249d5780516001600160801b03168411156124455760405162461bcd60e51b815260206004820152600760248201526626b0bc102a3c3760c91b6044820152606401610a9f565b60208101516001600160801b031661245d8386613014565b11156124985760405162461bcd60e51b815260206004820152600a60248201526913585e0815d85b1b195d60b21b6044820152606401610a9f565b61257d565b6001600160a01b0385165f9081526008602052604090205460ff1680156124dc57506001600160a01b0386165f908152600a602052604090205460ff16155b156125255780516001600160801b03168411156124985760405162461bcd60e51b815260206004820152600760248201526626b0bc102a3c3760c91b6044820152606401610a9f565b8261257d5760208101516001600160801b03166125428386613014565b111561257d5760405162461bcd60e51b815260206004820152600a60248201526913585e0815d85b1b195d60b21b6044820152606401610a9f565b600754610100900460ff1615612654577f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b0316856001600160a01b03161415801561260157507f0000000000000000000000005c0b2d0f7a29e12b3d69d607fb290fddaa0d6bd16001600160a01b0316856001600160a01b031614155b1561265457325f908152600b602052604090205443116126545760405162461bcd60e51b815260206004820152600e60248201526d5472616e736665722044656c617960901b6044820152606401610a9f565b5050505b6007546301000000900460ff161561138b576001600160a01b0382165f9081526008602052604090205460ff16156126db576001600160a01b0383165f908152600b6020526040902054431161138b5760405162461bcd60e51b815260206004820152600860248201526720b73a349026a2ab60c11b6044820152606401610a9f565b506001600160a01b03165f908152600b6020526040808220439081905532835291205550565b5f612755826040518060400160405280602081526020017f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564815250856001600160a01b03166129809092919063ffffffff16565b80519091501561138b57808060200190518101906127739190613259565b61138b5760405162461bcd60e51b815260206004820152602a60248201527f5361666545524332303a204552433230206f7065726174696f6e20646964206e6044820152691bdd081cdd58d8d9595960b21b6064820152608401610a9f565b305f90815260208190526040812054604080518082019091526011546001600160501b038116808352600160501b90910460ff16151560208301529192509082158061281c575080155b1561282657505050565b600f54612834906014613129565b83111561284c57600f54612849906014613129565b92505b82156128bb5761285b83612996565b475f81156128b857600d546040516001600160a01b039091169083905f81818185875af1925050503d805f81146128ad576040519150601f19603f3d011682016040523d82523d5f602084013e6128b2565b606091505b50909150505b50505b505f8152601180546020909201511515600160501b026affffffffffffffffffffff1990921691909117905550565b5f600e54436128f991906131cf565b9050600181116129115761290e5f6064612ab2565b50565b600381116129265761290e6107d06032612ab2565b6005811161293b5761290e6105dc604b612ab2565b600781116129505761290e6103e86064612ab2565b600b81116129655761290e6101f46064612ab2565b6129715f612710612ab2565b6007805462ffff001916905550565b606061298e84845f85612b5e565b949350505050565b6040805160028082526060820183525f9260208301908036833701905050905030815f815181106129c9576129c9613027565b60200260200101906001600160a01b031690816001600160a01b0316815250507f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc281600181518110612a1d57612a1d613027565b6001600160a01b03928316602091820292909201015260405163791ac94760e01b81527f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d9091169063791ac94790612a819085905f90869030904290600401613274565b5f604051808303815f87803b158015612a98575f80fd5b505af1158015612aaa573d5f803e3d5ffd5b505050505050565b60408051602081019091526001600160401b0383168082526013805467ffffffffffffffff1990811683179091556012805490911690911790556001600160801b0382161561138b57604080518082019091525f80825260208201525f612710846001600160801b0316612b2560025490565b612b2f9190613129565b612b399190613154565b6001600160801b0316808352602090920182905250600160801b810217601055505050565b606082471015612bbf5760405162461bcd60e51b815260206004820152602660248201527f416464726573733a20696e73756666696369656e742062616c616e636520666f6044820152651c8818d85b1b60d21b6064820152608401610a9f565b5f80866001600160a01b03168587604051612bda91906132e5565b5f6040518083038185875af1925050503d805f8114612c14576040519150601f19603f3d011682016040523d82523d5f602084013e612c19565b606091505b5091509150612c2a87838387612c35565b979650505050505050565b60608315612ca35782515f03612c9c576001600160a01b0385163b612c9c5760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e74726163740000006044820152606401610a9f565b508161298e565b61298e8383815115612cb85781518083602001fd5b8060405162461bcd60e51b8152600401610a9f9190612d0d565b80356001600160a01b0381168114612ce8575f80fd5b919050565b5f60208284031215612cfd575f80fd5b612d0682612cd2565b9392505050565b602081525f82518060208401528060208501604085015e5f604082850101526040601f19601f83011684010191505092915050565b5f8060408385031215612d53575f80fd5b612d5c83612cd2565b946020939093013593505050565b5f60208284031215612d7a575f80fd5b81356001600160401b0381168114612d06575f80fd5b801515811461290e575f80fd5b5f8060408385031215612dae575f80fd5b612db783612cd2565b91506020830135612dc781612d90565b809150509250929050565b5f805f60608486031215612de4575f80fd5b612ded84612cd2565b9250612dfb60208501612cd2565b9150604084013590509250925092565b5f60208284031215612e1b575f80fd5b8135612d0681612d90565b5f8083601f840112612e36575f80fd5b5081356001600160401b03811115612e4c575f80fd5b6020830191508360208260051b8501011115612e66575f80fd5b9250929050565b5f805f8060408587031215612e80575f80fd5b84356001600160401b0380821115612e96575f80fd5b612ea288838901612e26565b90965094506020870135915080821115612eba575f80fd5b50612ec787828801612e26565b95989497509550505050565b5f60208284031215612ee3575f80fd5b81356001600160801b0381168114612d06575f80fd5b5f8060408385031215612f0a575f80fd5b612f1383612cd2565b9150612f2160208401612cd2565b90509250929050565b5f805f60408486031215612f3c575f80fd5b83356001600160401b03811115612f51575f80fd5b612f5d86828701612e26565b9094509250506020840135612f7181612d90565b809150509250925092565b5f60208284031215612f8c575f80fd5b5035919050565b600181811c90821680612fa757607f821691505b602082108103612fc557634e487b7160e01b5f52602260045260245ffd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b5f52601160045260245ffd5b80820180821115610a6f57610a6f613000565b634e487b7160e01b5f52603260045260245ffd5b600181815b8085111561307557815f190482111561305b5761305b613000565b8085161561306857918102915b93841c9390800290613040565b509250929050565b5f8261308b57506001610a6f565b8161309757505f610a6f565b81600181146130ad57600281146130b7576130d3565b6001915050610a6f565b60ff8411156130c8576130c8613000565b50506001821b610a6f565b5060208310610133831016604e8410600b84101617156130f6575081810a610a6f565b613100838361303b565b805f190482111561311357613113613000565b029392505050565b5f612d0660ff84168361307d565b8082028115828204841417610a6f57610a6f613000565b634e487b7160e01b5f52601260045260245ffd5b5f8261316257613162613140565b500490565b5f805f60608486031215613179575f80fd5b8351925060208401519150604084015190509250925092565b5f602082840312156131a2575f80fd5b5051919050565b6020808252600c908201526b189bdd0819195d1958dd195960a21b604082015260600190565b81810381811115610a6f57610a6f613000565b6001600160801b0381811683821602808216919082811461320557613205613000565b505092915050565b5f6001600160801b038084168061322657613226613140565b92169190910492915050565b6001600160501b0381811683821601908082111561325257613252613000565b5092915050565b5f60208284031215613269575f80fd5b8151612d0681612d90565b5f60a08201878352602087602085015260a0604085015281875180845260c0860191506020890193505f5b818110156132c45784516001600160a01b03168352938301939183019160010161329f565b50506001600160a01b03969096166060850152505050608001529392505050565b5f82518060208501845e5f92019182525091905056fea2646970667358221220fa3c03c849c5a64cf0d22f6a190cfe09a4dc72d69bbc463035fabc9cac7457c864736f6c63430008190033

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.