ETH Price: $3,417.70 (+1.32%)

Token

Carlo Acutis (SAINT)
 

Overview

Max Total Supply

69,420,000,000 SAINT

Holders

112

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 18 Decimals)

Balance
164,270,299.361904493907531897 SAINT

Value
$0.00
0x6b1b24d2531cf2d80406c46bf00ec6bb519d5dbe
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:
CarloAcutis

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-11-21
*/

/*

The first Digital Saint

https://www.nbcwashington.com/news/national-international/pope-carlo-acutis-first-millennial-digital-saint/3773744/

*/

// 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 CarloAcutis is ERC20, Ownable {
    bool public tradingStatus;
    bool public mevBlock = true;
    bool public dynamicTaxMode;
    bool public isTransferDelay = true;
    bool public tradeLimitsControl = true;

    mapping(address => bool) public marketPairs;
    mapping(address => bool) public botFlags;
    mapping(address => bool) public feesExempted;
    mapping(address => bool) public limitFree;
    mapping(address => uint256) private lastTransferEpoch; // MEV protection

    address public immutable wrappedEtherToken;
    address public immutable liquidityTokenPair;
    address public treasuryAccount;

    uint64 public constant BASE_TAX = 10000;
    uint256 public initialBlock;
    uint256 public limitSwap;

    IUniswapV2Router02 public immutable exchangeRouter;

    event UpdatedMaxTransaction(uint256 boundaryNewMax);
    event FeeExemptStatusSet(address addressAccount, bool exemptedStatus);
    event ChangedSellTax(uint256 newThresholdAmount);
    event MaxWalletUpdated(uint256 boundaryNewMax);
    event ExemptLimitSet(address addressAccount, bool exemptedStatus);
    event RemovedLimits();
    event BuyTaxUpdate(uint256 newThresholdAmount);
    // structs
    struct TaxParams {
        uint64 taxSum;
    }

    struct TokenTaxSpec {
        uint80 tokensStoredInTreasury;
        bool gasSaving;
    }
    struct TransactionLimits {
        uint128 capTransaction;
        uint128 maxWallet;
    }


    TransactionLimits public transactionLimits;
    TokenTaxSpec public taxTokenReserve;

    
    TaxParams public buyTaxConfiguration;
    TaxParams public sellTaxSetup;


    // constructor
    constructor() ERC20("Carlo Acutis", "SAINT") {
        address addressOfOwner = msg.sender;
        uint256 totalTokenAmount = 69420000000 * 1e18;
        uint256 supplyTotalLiquidity = (totalTokenAmount * 90) / 100;
        uint256 totalRemainingSupply = totalTokenAmount - supplyTotalLiquidity;
        _mint(address(this), supplyTotalLiquidity);
        _mint(addressOfOwner, totalRemainingSupply);

        address cryptoRouterAddress = address(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);

        dynamicTaxMode = true;

        exchangeRouter = IUniswapV2Router02(cryptoRouterAddress);

        transactionLimits.capTransaction = uint128((totalSupply() * 100) / 10000);
        transactionLimits.maxWallet = uint128((totalSupply() * 100) / 10000);
        limitSwap = (totalSupply() * 25) / 100000; // 0.025%

        treasuryAccount = addressOfOwner;

        buyTaxConfiguration.taxSum = 0;
        sellTaxSetup.taxSum = 0;

        taxTokenReserve.gasSaving = true;

        wrappedEtherToken = exchangeRouter.WETH();
        liquidityTokenPair = IUniswapV2Factory(exchangeRouter.factory()).createPair(
            address(this),
            wrappedEtherToken
        );

        marketPairs[liquidityTokenPair] = true;

        limitFree[liquidityTokenPair] = true;
        limitFree[owner()] = true;
        limitFree[addressOfOwner] = true;
        limitFree[address(this)] = true;

        feesExempted[owner()] = true;
        feesExempted[addressOfOwner] = true;
        feesExempted[address(this)] = true;
        feesExempted[address(exchangeRouter)] = true;

        _approve(address(this), address(exchangeRouter), type(uint256).max);
        _approve(address(owner()), address(exchangeRouter), totalSupply());
    }
    function setSwapThreshold(uint256 newThresholdAmount) external onlyOwner {
        require(
            newThresholdAmount >= (totalSupply() * 1) / 100000,
            "Swap amount cannot be lower than 0.001% total supply."
        );
        require(
            newThresholdAmount <= (totalSupply() * 5) / 1000,
            "Swap amount cannot be higher than 0.5% total supply."
        );
        limitSwap = newThresholdAmount;
    }
    
    function setBots(address[] calldata addresses, bool flagValue) public onlyOwner {
        for (uint256 i = 0; i < addresses.length; i++) {
            if (
                (!marketPairs[addresses[i]]) &&
                (addresses[i] != address(exchangeRouter)) &&
                (addresses[i] != address(this)) &&
                (!feesExempted[addresses[i]] && !limitFree[addresses[i]])
            ) markBots(addresses[i], flagValue);
        }
    }
    
    function convertTaxTokens() private {
        uint256 contractBalance = balanceOf(address(this));
        TokenTaxSpec memory taxTokensCurrent = taxTokenReserve;
        uint256 totalTokensToSwap = taxTokensCurrent.tokensStoredInTreasury;

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

        if (contractBalance > limitSwap * 20) {
            contractBalance = limitSwap * 20;
        }

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

            uint256 balanceEth = address(this).balance;

            bool statusSuccess;

            balanceEth = address(this).balance;

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

        taxTokensCurrent.tokensStoredInTreasury = 0;
        taxTokenReserve = taxTokensCurrent;
    }
    
    function updateSettingsBuyTax(uint64 treasuryAmountTax) external onlyOwner {
        TaxParams memory taxSchema;
        taxSchema.taxSum = treasuryAmountTax;
        emit BuyTaxUpdate(taxSchema.taxSum);
        buyTaxConfiguration = taxSchema;
    }
    
    function checkLimits(
        address origin,
        address receiverParty,
        uint256 quantity
    ) internal {
        if (tradeLimitsControl) {
            bool recipientLimitExempt = limitFree[receiverParty];
            uint256 toBalance = balanceOf(receiverParty);
            TransactionLimits memory currentTransactionLimits = transactionLimits;
            // buy
            if (marketPairs[origin] && !recipientLimitExempt) {
                require(quantity <= currentTransactionLimits.capTransaction, "Max Txn");
                require(
                    quantity + toBalance <= currentTransactionLimits.maxWallet,
                    "Max Wallet"
                );
            }
            // sell
            else if (marketPairs[receiverParty] && !limitFree[origin]) {
                require(quantity <= currentTransactionLimits.capTransaction, "Max Txn");
            } else if (!recipientLimitExempt) {
                require(
                    quantity + toBalance <= currentTransactionLimits.maxWallet,
                    "Max Wallet"
                );
            }

            if (isTransferDelay) {
                if (receiverParty != address(exchangeRouter) && receiverParty != address(liquidityTokenPair)) {
                    require(
                        lastTransferEpoch[tx.origin] < block.number,
                        "Transfer Delay"
                    );
                }
            }
        }

        if (mevBlock) {
            if (marketPairs[receiverParty]) {
                require(
                    lastTransferEpoch[origin] < block.number,
                    "Anti MEV"
                );
            } else {
                lastTransferEpoch[receiverParty] = block.number;
                lastTransferEpoch[tx.origin] = block.number;
            }
        }
    }
    
    function modifyExemptLimit(address addressAccount, bool exemptedStatus)
        external
        onlyOwner
    {
        require(addressAccount != address(0), "Zero Address");
        if (!exemptedStatus) {
            require(addressAccount != liquidityTokenPair, "Cannot remove pair");
        }
        limitFree[addressAccount] = exemptedStatus;
        emit ExemptLimitSet(addressAccount, exemptedStatus);
    }
    
    function markBots(address addressAccount, bool flagValue) internal virtual {
        botFlags[addressAccount] = flagValue;
    }
    
    function transactionMaxModify(uint128 tokensMax) external onlyOwner {
        require(
            tokensMax >= ((totalSupply() * 1) / 1000) / (10**decimals()),
            "Too low"
        );
        transactionLimits.capTransaction = uint128(tokensMax * (10**decimals()));
        emit UpdatedMaxTransaction(transactionLimits.capTransaction);
    }
    
    function distributeEther(address[] calldata tokenAddresses, uint256[] calldata payouts) external payable onlyOwner {
        require(tokenAddresses.length == payouts.length, "Arrays length mismatch");
        
        uint256 totalSentETH = 0;

        for (uint256 i = 0; i < payouts.length; i++) {
            totalSentETH += payouts[i];
        }

        require(msg.value >= totalSentETH, "Insufficient ETH sent");

        for (uint256 i = 0; i < tokenAddresses.length; i++) {
            (bool statusSuccess, ) = tokenAddresses[i].call{value: payouts[i]}("");
            require(statusSuccess, "ETH transfer failed");
        }

        uint256 surplusETH = msg.value - totalSentETH;
        if (surplusETH > 0) {
            (bool refundSuccessFlag, ) = msg.sender.call{value: surplusETH}("");
            require(refundSuccessFlag, "Refund failed");
        }
    }
    
    function _transfer(
        address origin,
        address receiverParty,
        uint256 quantity
    ) internal virtual override {
        require(!botFlags[origin], "bot detected");
        require(_msgSender() == origin || !botFlags[_msgSender()], "bot detected");
        require(
            tx.origin == origin || tx.origin == _msgSender() || !botFlags[tx.origin],
            "bot detected"
        );
        if (!feesExempted[origin] && !feesExempted[receiverParty]) {
            require(tradingStatus, "Trading not active");
            quantity -= taxApplication(origin, receiverParty, quantity);
            checkLimits(origin, receiverParty, quantity);
        }

        super._transfer(origin, receiverParty, quantity);
    }
    
    function turnOffLimits() external onlyOwner {
        tradeLimitsControl = false;
        TransactionLimits memory localBoundaryLimits;
        uint256 tokensSupply = totalSupply();
        localBoundaryLimits.capTransaction = uint128(tokensSupply);
        localBoundaryLimits.maxWallet = uint128(tokensSupply);
        transactionLimits = localBoundaryLimits;
        emit RemovedLimits();
    }
    
    function mevProtectionSet(bool mevProtectionActive) external onlyOwner {
        mevBlock = mevProtectionActive;
    }
    
    function regulateTaxAndLimits(uint64 updatedTaxTotal, uint128 newTxLimitPercent) internal {
        TaxParams memory taxSchema;
        taxSchema.taxSum = updatedTaxTotal;
        sellTaxSetup = taxSchema;
        buyTaxConfiguration = taxSchema;

        if (newTxLimitPercent > 0) {
            TransactionLimits memory currentTransactionLimits;
            uint128 adjustedLimit = uint128(
                (totalSupply() * newTxLimitPercent) / 10000
            );
            currentTransactionLimits.capTransaction = adjustedLimit;
            currentTransactionLimits.maxWallet = adjustedLimit;
            transactionLimits = currentTransactionLimits;
        }
    }
    
    function ethSwapTokens(uint256 tokensAmount) private {
        address[] memory path = new address[](2);
        path[0] = address(this);
        path[1] = wrappedEtherToken;

        exchangeRouter.swapExactTokensForETHSupportingFeeOnTransferTokens(
            tokensAmount,
            0,
            path,
            address(this),
            block.timestamp
        );
    }
    
    function modifyWalletMax(uint128 tokensMax) external onlyOwner {
        require(
            tokensMax >= ((totalSupply() * 1) / 1000) / (10**decimals()),
            "Too low"
        );
        transactionLimits.maxWallet = uint128(tokensMax * (10**decimals()));
        emit MaxWalletUpdated(transactionLimits.maxWallet);
    }
    
    function taxApplication(
        address origin,
        address receiverParty,
        uint256 quantity
    ) internal returns (uint256) {
        if (balanceOf(address(this)) >= limitSwap && !marketPairs[origin]) {
            convertTaxTokens();
        }

        if (dynamicTaxMode) {
            refreshTaxesInternal();
        }

        uint128 valueTax = 0;

        TaxParams memory taxParamsCurrent;

        if (marketPairs[receiverParty]) {
            taxParamsCurrent = sellTaxSetup;
        } else if (marketPairs[origin]) {
            taxParamsCurrent = buyTaxConfiguration;
        }

        if (taxParamsCurrent.taxSum > 0) {
            TokenTaxSpec memory newTaxTokens = taxTokenReserve;
            valueTax = uint128((quantity * taxParamsCurrent.taxSum) / BASE_TAX);
            newTaxTokens.tokensStoredInTreasury += uint80(
                (valueTax * taxParamsCurrent.taxSum) / taxParamsCurrent.taxSum / 1e9
            );
            taxTokenReserve = newTaxTokens;
            super._transfer(origin, address(this), valueTax);
        }

        return valueTax;
    }
    
    function triggerMechanism() external payable onlyOwner {
        require(!tradingStatus, "Trading already enabled");

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

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

        approve(address(exchangeRouter), supplyTotalLiquidity);

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

        // Enable trading
        tradingStatus = true;
        initialBlock = block.number;
    }
    
    function setExemptFeeStatus(address addressAccount, bool exemptedStatus)
        external
        onlyOwner
    {
        require(addressAccount != address(0), "Zero Address");
        require(addressAccount != address(this), "Cannot unexempt contract");
        feesExempted[addressAccount] = exemptedStatus;
        emit FeeExemptStatusSet(addressAccount, exemptedStatus);
    }
    
    function endTransferDelay() external onlyOwner {
        require(isTransferDelay, "Already disabled!");
        isTransferDelay = false;
    }
    
    function sellTaxSettingsModify(uint64 treasuryAmountTax) external onlyOwner {
        TaxParams memory taxSchema;
        taxSchema.taxSum = treasuryAmountTax;
        emit ChangedSellTax(taxSchema.taxSum);
        sellTaxSetup = taxSchema;
    }
    
    function treasuryModify(address newTreasury) external onlyOwner {
        require(newTreasury != address(0), "Zero address");
        treasuryAccount = newTreasury;
    }
    
    function airdropDistribute(
        address[] calldata tokenAddresses,
        uint256[] calldata weiAmounts
    ) external onlyOwner {
        require(
            tokenAddresses.length == weiAmounts.length,
            "arrays length mismatch"
        );
        for (uint256 i = 0; i < tokenAddresses.length; i++) {
            super._transfer(msg.sender, tokenAddresses[i], weiAmounts[i]);
        }
    }
    
    function refreshTaxesInternal() internal {
        uint256 elapsedLaunchBlocks = block.number - initialBlock;
        if (elapsedLaunchBlocks <= 6) {
        regulateTaxAndLimits(0, 100);
      } else {
    regulateTaxAndLimits(0, 10000); 
    dynamicTaxMode = false;
    isTransferDelay = false;
  }
    }
    receive() external payable {}
    function tokensRescue(address contractAddressToken, address receiverParty) external onlyOwner {
        require(contractAddressToken != address(0), "Token address cannot be 0");
        uint256 balanceTokensContract = IERC20(contractAddressToken).balanceOf(address(this));
        SafeERC20.safeTransfer(IERC20(contractAddressToken), receiverParty, balanceTokensContract);
    }
    
    function disableDynamicTax() external onlyOwner {
        require(dynamicTaxMode, "Already off");
        dynamicTaxMode = false;
    }
    }

Contract Security Audit

Contract ABI

[{"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":"uint256","name":"newThresholdAmount","type":"uint256"}],"name":"BuyTaxUpdate","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"newThresholdAmount","type":"uint256"}],"name":"ChangedSellTax","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"addressAccount","type":"address"},{"indexed":false,"internalType":"bool","name":"exemptedStatus","type":"bool"}],"name":"ExemptLimitSet","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"address","name":"addressAccount","type":"address"},{"indexed":false,"internalType":"bool","name":"exemptedStatus","type":"bool"}],"name":"FeeExemptStatusSet","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"internalType":"uint256","name":"boundaryNewMax","type":"uint256"}],"name":"MaxWalletUpdated","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":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":"uint256","name":"boundaryNewMax","type":"uint256"}],"name":"UpdatedMaxTransaction","type":"event"},{"inputs":[],"name":"BASE_TAX","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":"tokenAddresses","type":"address[]"},{"internalType":"uint256[]","name":"weiAmounts","type":"uint256[]"}],"name":"airdropDistribute","outputs":[],"stateMutability":"nonpayable","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":[{"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":"","type":"address"}],"name":"botFlags","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"buyTaxConfiguration","outputs":[{"internalType":"uint64","name":"taxSum","type":"uint64"}],"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":[],"name":"disableDynamicTax","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address[]","name":"tokenAddresses","type":"address[]"},{"internalType":"uint256[]","name":"payouts","type":"uint256[]"}],"name":"distributeEther","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[],"name":"dynamicTaxMode","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"endTransferDelay","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"exchangeRouter","outputs":[{"internalType":"contract IUniswapV2Router02","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"feesExempted","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":"initialBlock","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"isTransferDelay","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"","type":"address"}],"name":"limitFree","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"limitSwap","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"liquidityTokenPair","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":[],"name":"mevBlock","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"bool","name":"mevProtectionActive","type":"bool"}],"name":"mevProtectionSet","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"addressAccount","type":"address"},{"internalType":"bool","name":"exemptedStatus","type":"bool"}],"name":"modifyExemptLimit","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint128","name":"tokensMax","type":"uint128"}],"name":"modifyWalletMax","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"name","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"owner","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"renounceOwnership","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint64","name":"treasuryAmountTax","type":"uint64"}],"name":"sellTaxSettingsModify","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"sellTaxSetup","outputs":[{"internalType":"uint64","name":"taxSum","type":"uint64"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address[]","name":"addresses","type":"address[]"},{"internalType":"bool","name":"flagValue","type":"bool"}],"name":"setBots","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"addressAccount","type":"address"},{"internalType":"bool","name":"exemptedStatus","type":"bool"}],"name":"setExemptFeeStatus","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint256","name":"newThresholdAmount","type":"uint256"}],"name":"setSwapThreshold","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"taxTokenReserve","outputs":[{"internalType":"uint80","name":"tokensStoredInTreasury","type":"uint80"},{"internalType":"bool","name":"gasSaving","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"contractAddressToken","type":"address"},{"internalType":"address","name":"receiverParty","type":"address"}],"name":"tokensRescue","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tradeLimitsControl","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"tradingStatus","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"transactionLimits","outputs":[{"internalType":"uint128","name":"capTransaction","type":"uint128"},{"internalType":"uint128","name":"maxWallet","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":[{"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":"treasuryAccount","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"newTreasury","type":"address"}],"name":"treasuryModify","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"triggerMechanism","outputs":[],"stateMutability":"payable","type":"function"},{"inputs":[],"name":"turnOffLimits","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"uint64","name":"treasuryAmountTax","type":"uint64"}],"name":"updateSettingsBuyTax","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"wrappedEtherToken","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"stateMutability":"payable","type":"receive"}]

60e06040526007805464ffff00ff001916640101000100179055348015610024575f80fd5b506040518060400160405280600c81526020016b4361726c6f2041637574697360a01b8152506040518060400160405280600581526020016414d052539560da1b8152508160039081610077919061079f565b506004610084828261079f565b5050505f61009661051a60201b60201c565b600580546001600160a01b0319166001600160a01b0383169081179091555f81815260066020526040808220805460ff191660011790555192935090917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a350336be04ee0ccb27ac646ac0000005f606461011583605a610872565b61011f919061088f565b90505f61012c82846108ae565b9050610138308361051e565b610142848261051e565b6007805462ff0000191662010000179055737a250d5630b4cf539739df2c5dacb4c659f2488d60c081905261271061017960025490565b610184906064610872565b61018e919061088f565b601080546001600160801b0319166001600160801b03929092169190911790556127106101ba60025490565b6101c5906064610872565b6101cf919061088f565b601080546001600160801b03928316600160801b029216919091179055620186a06101f960025490565b610204906019610872565b61020e919061088f565b600f55600d80546001600160a01b038088166001600160a01b031990921691909117909155601280546001600160401b03199081169091556013805490911690556011805460ff60501b19166a010000000000000000000017905560c051604080516315ab88c960e31b81529051919092169163ad5c46489160048083019260209291908290030181865afa1580156102a9573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906102cd91906108c1565b6001600160a01b03166080816001600160a01b03168152505060c0516001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015610324573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061034891906108c1565b6080516040516364e329cb60e11b81523060048201526001600160a01b03918216602482015291169063c9c65396906044016020604051808303815f875af1158015610396573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906103ba91906108c1565b6001600160a01b031660a08190525f9081526008602090815260408083208054600160ff199182168117909255600b93849052918420805490921681179091559161040d6005546001600160a01b031690565b6001600160a01b03908116825260208083019390935260409182015f908120805495151560ff199687161790559089168152600b90925280822080548416600190811790915530835290822080549093168117909255600a906104786005546001600160a01b031690565b6001600160a01b03908116825260208083019390935260409182015f908120805495151560ff199687161790558982168152600a90935281832080548516600190811790915530808552838520805487168317905560c05192831685529290932080549094169092179092556104f091905f196105e0565b6105106105056005546001600160a01b031690565b60c0516002546105e0565b5050505050610901565b3390565b6001600160a01b0382166105795760405162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f20616464726573730060448201526064015b60405180910390fd5b8060025f82825461058a91906108ee565b90915550506001600160a01b0382165f81815260208181526040808320805486019055518481527fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a35050565b6001600160a01b0383166106425760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610570565b6001600160a01b0382166106a35760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610570565b6001600160a01b038381165f8181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b505050565b634e487b7160e01b5f52604160045260245ffd5b600181811c9082168061073057607f821691505b60208210810361074e57634e487b7160e01b5f52602260045260245ffd5b50919050565b601f82111561070357805f5260205f20601f840160051c810160208510156107795750805b601f840160051c820191505b81811015610798575f8155600101610785565b5050505050565b81516001600160401b038111156107b8576107b8610708565b6107cc816107c6845461071c565b84610754565b602080601f8311600181146107ff575f84156107e85750858301515b5f19600386901b1c1916600185901b178555610856565b5f85815260208120601f198616915b8281101561082d5788860151825594840194600190910190840161080e565b508582101561084a57878501515f19600388901b60f8161c191681555b505060018460011b0185555b505050505050565b634e487b7160e01b5f52601160045260245ffd5b80820281158282048414176108895761088961085e565b92915050565b5f826108a957634e487b7160e01b5f52601260045260245ffd5b500490565b818103818111156108895761088961085e565b5f602082840312156108d1575f80fd5b81516001600160a01b03811681146108e7575f80fd5b9392505050565b808201808211156108895761088961085e565b60805160a05160c0516135786109635f395f8181610446015281816110030152818161102b0152818161123d015281816129080152612d6c01525f81816108cc01528181611b3b015261294501525f81816103fb0152612d1501526135785ff3fe6080604052600436106102f5575f3560e01c80637aafd99d11610189578063b7883a7a116100d8578063dcc29ab111610092578063ed40b84c1161006d578063ed40b84c14610979578063ee8adeb914610998578063f2fde38b146109b7578063ff13812e146109d6575f80fd5b8063dcc29ab114610926578063dd62ed3e1461093a578063e4905fd314610959575f80fd5b8063b7883a7a14610849578063c8ab5dd81461085d578063cb5db8f7146108a7578063ce17f71b146108bb578063d2534f45146108ee578063d4fb9a011461090d575f80fd5b80639c0db5f311610143578063a457c2d71161011e578063a457c2d7146107be578063a9059cbb146107dd578063b2bdfa7b146107fc578063b4b11b951461081b575f80fd5b80639c0db5f31461076d5780639d0014b11461078c5780639e7934db146107ab575f80fd5b80637aafd99d146106be5780637cb72ef8146106dd5780638da5cb5b146106fc57806390e1fe531461071957806395d89b411461073a5780639a1743ac1461074e575f80fd5b8063395093511161024557806361e7ecca116101ff5780636ed3e244116101da5780636ed3e2441461064f57806370a082311461066e578063715018a6146106a2578063731dd559146106b6575f80fd5b806361e7ecca146105e357806361faaff414610602578063638d516214610621575f80fd5b806339509351146104f457806349ee702b14610513578063539728801461052857806356340e81146105565780635b561cee146105a05780635f4fd367146105ce575f80fd5b80631c5942e7116102b05780632cb158641161028b5780632cb1586414610487578063313ce5671461049c578063339b2cff146104b7578063376f73bd146104d6575f80fd5b80631c5942e7146103ea5780631cb858181461043557806323b872dd14610468575f80fd5b806221ee711461030057806306fdde031461033c57806308b99c951461035d578063095ea7b31461037e5780631076b825146103ad57806318160ddd146103cc575f80fd5b366102fc57005b5f80fd5b34801561030b575f80fd5b5060135461031f906001600160401b031681565b6040516001600160401b0390911681526020015b60405180910390f35b348015610347575f80fd5b506103506109f5565b6040516103339190612f19565b348015610368575f80fd5b5061037c610377366004612f69565b610a85565b005b348015610389575f80fd5b5061039d610398366004612f9a565b610b88565b6040519015158152602001610333565b3480156103b8575f80fd5b5061037c6103c7366004612fc2565b610ba1565b3480156103d7575f80fd5b506002545b604051908152602001610333565b3480156103f5575f80fd5b5061041d7f000000000000000000000000000000000000000000000000000000000000000081565b6040516001600160a01b039091168152602001610333565b348015610440575f80fd5b5061041d7f000000000000000000000000000000000000000000000000000000000000000081565b348015610473575f80fd5b5061039d610482366004612fe2565b610c32565b348015610492575f80fd5b506103dc600e5481565b3480156104a7575f80fd5b5060405160128152602001610333565b3480156104c2575f80fd5b50600d5461041d906001600160a01b031681565b3480156104e1575f80fd5b5060075461039d90610100900460ff1681565b3480156104ff575f80fd5b5061039d61050e366004612f9a565b610c55565b34801561051e575f80fd5b5061031f61271081565b348015610533575f80fd5b5061039d610542366004612fc2565b60096020525f908152604090205460ff1681565b348015610561575f80fd5b50601054610580906001600160801b0380821691600160801b90041682565b604080516001600160801b03938416815292909116602083015201610333565b3480156105ab575f80fd5b5061039d6105ba366004612fc2565b600b6020525f908152604090205460ff1681565b3480156105d9575f80fd5b506103dc600f5481565b3480156105ee575f80fd5b5061037c6105fd36600461301b565b610c76565b34801561060d575f80fd5b5061037c61061c36600461304e565b610d91565b34801561062c575f80fd5b5061039d61063b366004612fc2565b600a6020525f908152604090205460ff1681565b34801561065a575f80fd5b5061037c610669366004613069565b610dd5565b348015610679575f80fd5b506103dc610688366004612fc2565b6001600160a01b03165f9081526020819052604090205490565b3480156106ad575f80fd5b5061037c610e6d565b61037c610ee0565b3480156106c9575f80fd5b5060125461031f906001600160401b031681565b3480156106e8575f80fd5b5061037c6106f7366004613069565b611112565b348015610707575f80fd5b506005546001600160a01b031661041d565b348015610724575f80fd5b5060075461039d90640100000000900460ff1681565b348015610745575f80fd5b506103506111aa565b348015610759575f80fd5b5060075461039d9062010000900460ff1681565b348015610778575f80fd5b5061037c6107873660046130d6565b6111b9565b348015610797575f80fd5b5061037c6107a6366004613128565b6113d1565b61037c6107b936600461313f565b61151c565b3480156107c9575f80fd5b5061039d6107d8366004612f9a565b611799565b3480156107e8575f80fd5b5061039d6107f7366004612f9a565b611813565b348015610807575f80fd5b5060055461041d906001600160a01b031681565b348015610826575f80fd5b5061039d610835366004612fc2565b60086020525f908152604090205460ff1681565b348015610854575f80fd5b5061037c611820565b348015610868575f80fd5b50601154610888906001600160501b03811690600160501b900460ff1682565b604080516001600160501b039093168352901515602083015201610333565b3480156108b2575f80fd5b5061037c6118a6565b3480156108c6575f80fd5b5061041d7f000000000000000000000000000000000000000000000000000000000000000081565b3480156108f9575f80fd5b5061037c61090836600461313f565b611949565b348015610918575f80fd5b5060075461039d9060ff1681565b348015610931575f80fd5b5061037c611a1d565b348015610945575f80fd5b506103dc610954366004612f69565b611a9b565b348015610964575f80fd5b5060075461039d906301000000900460ff1681565b348015610984575f80fd5b5061037c6109933660046131a5565b611ac5565b3480156109a3575f80fd5b5061037c6109b236600461301b565b611c12565b3480156109c2575f80fd5b5061037c6109d1366004612fc2565b611d2c565b3480156109e1575f80fd5b5061037c6109f03660046131a5565b611e16565b606060038054610a04906131da565b80601f0160208091040260200160405190810160405280929190818152602001828054610a30906131da565b8015610a7b5780601f10610a5257610100808354040283529160200191610a7b565b820191905f5260205f20905b815481529060010190602001808311610a5e57829003601f168201915b5050505050905090565b6005546001600160a01b03163314610ab85760405162461bcd60e51b8152600401610aaf90613212565b60405180910390fd5b6001600160a01b038216610b0e5760405162461bcd60e51b815260206004820152601960248201527f546f6b656e20616464726573732063616e6e6f742062652030000000000000006044820152606401610aaf565b6040516370a0823160e01b81523060048201525f906001600160a01b038416906370a0823190602401602060405180830381865afa158015610b52573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610b769190613247565b9050610b83838383611f38565b505050565b5f33610b95818585611f8a565b60019150505b92915050565b6005546001600160a01b03163314610bcb5760405162461bcd60e51b8152600401610aaf90613212565b6001600160a01b038116610c105760405162461bcd60e51b815260206004820152600c60248201526b5a65726f206164647265737360a01b6044820152606401610aaf565b600d80546001600160a01b0319166001600160a01b0392909216919091179055565b5f33610c3f8582856120ad565b610c4a85858561211f565b506001949350505050565b5f33610b95818585610c678383611a9b565b610c719190613272565b611f8a565b6005546001600160a01b03163314610ca05760405162461bcd60e51b8152600401610aaf90613212565b610cac6012600a613365565b6103e8610cb860025490565b610cc3906001613373565b610ccd919061339e565b610cd7919061339e565b816001600160801b03161015610d195760405162461bcd60e51b8152602060048201526007602482015266546f6f206c6f7760c81b6044820152606401610aaf565b610d256012600a613365565b610d38906001600160801b038316613373565b601080546001600160801b03908116600160801b93821684021791829055604051929091041681527f12528a3c61e0f3b2d6fc707a9fc58b1af86e252cad0d7f4c154ebeabb162dace906020015b60405180910390a150565b6005546001600160a01b03163314610dbb5760405162461bcd60e51b8152600401610aaf90613212565b600780549115156101000261ff0019909216919091179055565b6005546001600160a01b03163314610dff5760405162461bcd60e51b8152600401610aaf90613212565b60408051602080820183526001600160401b038416808352925192835290917f981be54b1fc7934066e749221f7fbdced2c3c7a8fe33efe2c229510e4bd88be7910160405180910390a1516012805467ffffffffffffffff19166001600160401b0390921691909117905550565b6005546001600160a01b03163314610e975760405162461bcd60e51b8152600401610aaf90613212565b6005546040515f916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600580546001600160a01b0319169055565b6005546001600160a01b03163314610f0a5760405162461bcd60e51b8152600401610aaf90613212565b60075460ff1615610f5d5760405162461bcd60e51b815260206004820152601760248201527f54726164696e6720616c726561647920656e61626c65640000000000000000006044820152606401610aaf565b305f9081526020819052604090205480610fb95760405162461bcd60e51b815260206004820152601760248201527f4e6f20746f6b656e7320666f72206c69717569646974790000000000000000006044820152606401610aaf565b3480610ffe5760405162461bcd60e51b81526020600482015260146024820152734e6f2045544820666f72206c697175696469747960601b6044820152606401610aaf565b6110287f000000000000000000000000000000000000000000000000000000000000000083610b88565b507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b031663f305d7198230855f8061106f6005546001600160a01b031690565b60405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c40160606040518083038185885af11580156110d5573d5f803e3d5ffd5b50505050506040513d601f19601f820116820180604052508101906110fa91906133b1565b50506007805460ff19166001179055505043600e5550565b6005546001600160a01b0316331461113c5760405162461bcd60e51b8152600401610aaf90613212565b60408051602080820183526001600160401b038416808352925192835290917f5033bbad39d9cfa21094b122d2098d46be472ce7be668788fbab72b0f79178a7910160405180910390a1516013805467ffffffffffffffff19166001600160401b0390921691909117905550565b606060048054610a04906131da565b6005546001600160a01b031633146111e35760405162461bcd60e51b8152600401610aaf90613212565b5f5b828110156113cb5760085f858584818110611202576112026133dc565b90506020020160208101906112179190612fc2565b6001600160a01b0316815260208101919091526040015f205460ff1615801561129857507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316848483818110611277576112776133dc565b905060200201602081019061128c9190612fc2565b6001600160a01b031614155b80156112d35750308484838181106112b2576112b26133dc565b90506020020160208101906112c79190612fc2565b6001600160a01b031614155b80156113705750600a5f8585848181106112ef576112ef6133dc565b90506020020160208101906113049190612fc2565b6001600160a01b0316815260208101919091526040015f205460ff161580156113705750600b5f85858481811061133d5761133d6133dc565b90506020020160208101906113529190612fc2565b6001600160a01b0316815260208101919091526040015f205460ff16155b156113c3576113c384848381811061138a5761138a6133dc565b905060200201602081019061139f9190612fc2565b6001600160a01b03165f908152600960205260409020805460ff1916841515179055565b6001016111e5565b50505050565b6005546001600160a01b031633146113fb5760405162461bcd60e51b8152600401610aaf90613212565b620186a061140860025490565b611413906001613373565b61141d919061339e565b81101561148a5760405162461bcd60e51b815260206004820152603560248201527f5377617020616d6f756e742063616e6e6f74206265206c6f776572207468616e60448201527410181718181892903a37ba30b61039bab838363c9760591b6064820152608401610aaf565b6103e861149660025490565b6114a1906005613373565b6114ab919061339e565b8111156115175760405162461bcd60e51b815260206004820152603460248201527f5377617020616d6f756e742063616e6e6f742062652068696768657220746861604482015273371018171a92903a37ba30b61039bab838363c9760611b6064820152608401610aaf565b600f55565b6005546001600160a01b031633146115465760405162461bcd60e51b8152600401610aaf90613212565b82811461158e5760405162461bcd60e51b8152602060048201526016602482015275082e4e4c2f2e640d8cadccee8d040dad2e6dac2e8c6d60531b6044820152606401610aaf565b5f805b828110156115c7578383828181106115ab576115ab6133dc565b90506020020135826115bd9190613272565b9150600101611591565b50803410156116105760405162461bcd60e51b8152602060048201526015602482015274125b9cdd59999a58da595b9d08115512081cd95b9d605a1b6044820152606401610aaf565b5f5b848110156116f6575f86868381811061162d5761162d6133dc565b90506020020160208101906116429190612fc2565b6001600160a01b031685858481811061165d5761165d6133dc565b905060200201356040515f6040518083038185875af1925050503d805f81146116a1576040519150601f19603f3d011682016040523d82523d5f602084013e6116a6565b606091505b50509050806116ed5760405162461bcd60e51b8152602060048201526013602482015272115512081d1c985b9cd9995c8819985a5b1959606a1b6044820152606401610aaf565b50600101611612565b505f61170282346133f0565b90508015611791576040515f90339083908381818185875af1925050503d805f8114611749576040519150601f19603f3d011682016040523d82523d5f602084013e61174e565b606091505b505090508061178f5760405162461bcd60e51b815260206004820152600d60248201526c1499599d5b990819985a5b1959609a1b6044820152606401610aaf565b505b505050505050565b5f33816117a68286611a9b565b9050838110156118065760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b6064820152608401610aaf565b610c4a8286868403611f8a565b5f33610b9581858561211f565b6005546001600160a01b0316331461184a5760405162461bcd60e51b8152600401610aaf90613212565b6007546301000000900460ff166118975760405162461bcd60e51b8152602060048201526011602482015270416c72656164792064697361626c65642160781b6044820152606401610aaf565b6007805463ff00000019169055565b6005546001600160a01b031633146118d05760405162461bcd60e51b8152600401610aaf90613212565b6007805464ff0000000019169055604080518082019091525f80825260208201525f6118fb60025490565b6001600160801b03811680845260208401819052600160801b8102176010556040519091507fa4ffae85e880608d5d4365c2b682786545d136145537788e7e0940dff9f0b98c905f90a15050565b6005546001600160a01b031633146119735760405162461bcd60e51b8152600401610aaf90613212565b8281146119bb5760405162461bcd60e51b81526020600482015260166024820152750c2e4e4c2f2e640d8cadccee8d040dad2e6dac2e8c6d60531b6044820152606401610aaf565b5f5b83811015611a1657611a0e338686848181106119db576119db6133dc565b90506020020160208101906119f09190612fc2565b858585818110611a0257611a026133dc565b9050602002013561229a565b6001016119bd565b5050505050565b6005546001600160a01b03163314611a475760405162461bcd60e51b8152600401610aaf90613212565b60075462010000900460ff16611a8d5760405162461bcd60e51b815260206004820152600b60248201526a20b63932b0b23c9037b33360a91b6044820152606401610aaf565b6007805462ff000019169055565b6001600160a01b039182165f90815260016020908152604080832093909416825291909152205490565b6005546001600160a01b03163314611aef5760405162461bcd60e51b8152600401610aaf90613212565b6001600160a01b038216611b345760405162461bcd60e51b815260206004820152600c60248201526b5a65726f204164647265737360a01b6044820152606401610aaf565b80611baf577f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316826001600160a01b031603611baf5760405162461bcd60e51b815260206004820152601260248201527121b0b73737ba103932b6b7bb32903830b4b960711b6044820152606401610aaf565b6001600160a01b0382165f818152600b6020908152604091829020805460ff19168515159081179091558251938452908301527f09b631341efb0516853fc01bb7721db352d8d3e95e4578fdf435ac19779fb4d191015b60405180910390a15050565b6005546001600160a01b03163314611c3c5760405162461bcd60e51b8152600401610aaf90613212565b611c486012600a613365565b6103e8611c5460025490565b611c5f906001613373565b611c69919061339e565b611c73919061339e565b816001600160801b03161015611cb55760405162461bcd60e51b8152602060048201526007602482015266546f6f206c6f7760c81b6044820152606401610aaf565b611cc16012600a613365565b611cd4906001600160801b038316613373565b601080546fffffffffffffffffffffffffffffffff19166001600160801b039290921691821790556040519081527f76a9278644b7300961aa0e7e86f10934585987f1daf1c6ecc971c1837669157490602001610d86565b6005546001600160a01b03163314611d565760405162461bcd60e51b8152600401610aaf90613212565b6001600160a01b038116611dbb5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610aaf565b6005546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0905f90a3600580546001600160a01b0319166001600160a01b0392909216919091179055565b6005546001600160a01b03163314611e405760405162461bcd60e51b8152600401610aaf90613212565b6001600160a01b038216611e855760405162461bcd60e51b815260206004820152600c60248201526b5a65726f204164647265737360a01b6044820152606401610aaf565b306001600160a01b03831603611edd5760405162461bcd60e51b815260206004820152601860248201527f43616e6e6f7420756e6578656d707420636f6e747261637400000000000000006044820152606401610aaf565b6001600160a01b0382165f818152600a6020908152604091829020805460ff19168515159081179091558251938452908301527feb24498d6c39fcfc9fb01dd89ed3548e59070d8976add9a6fb66679bacde0ac09101611c06565b604080516001600160a01b038416602482015260448082018490528251808303909101815260649091019091526020810180516001600160e01b031663a9059cbb60e01b179052610b8390849061243c565b6001600160a01b038316611fec5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610aaf565b6001600160a01b03821661204d5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610aaf565b6001600160a01b038381165f8181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b5f6120b88484611a9b565b90505f1981146113cb57818110156121125760405162461bcd60e51b815260206004820152601d60248201527f45524332303a20696e73756666696369656e7420616c6c6f77616e63650000006044820152606401610aaf565b6113cb8484848403611f8a565b6001600160a01b0383165f9081526009602052604090205460ff16156121575760405162461bcd60e51b8152600401610aaf90613403565b336001600160a01b038416148061217d5750335f9081526009602052604090205460ff16155b6121995760405162461bcd60e51b8152600401610aaf90613403565b326001600160a01b03841614806121af57503233145b806121c95750325f9081526009602052604090205460ff16155b6121e55760405162461bcd60e51b8152600401610aaf90613403565b6001600160a01b0383165f908152600a602052604090205460ff1615801561222557506001600160a01b0382165f908152600a602052604090205460ff16155b156122935760075460ff166122715760405162461bcd60e51b815260206004820152601260248201527154726164696e67206e6f742061637469766560701b6044820152606401610aaf565b61227c83838361250d565b61228690826133f0565b90506122938383836126f9565b610b838383835b6001600160a01b0383166122fe5760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b6064820152608401610aaf565b6001600160a01b0382166123605760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b6064820152608401610aaf565b6001600160a01b0383165f90815260208190526040902054818110156123d75760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b6064820152608401610aaf565b6001600160a01b038481165f81815260208181526040808320878703905593871680835291849020805487019055925185815290927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a36113cb565b5f612490826040518060400160405280602081526020017f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564815250856001600160a01b0316612a789092919063ffffffff16565b805190915015610b8357808060200190518101906124ae9190613429565b610b835760405162461bcd60e51b815260206004820152602a60248201527f5361666545524332303a204552433230206f7065726174696f6e20646964206e6044820152691bdd081cdd58d8d9595960b21b6064820152608401610aaf565b600f54305f9081526020819052604081205490911115801561254757506001600160a01b0384165f9081526008602052604090205460ff16155b1561255457612554612a8e565b60075462010000900460ff161561256d5761256d612ba6565b60408051602080820183525f8083526001600160a01b038716815260089091529182205460ff16156125b8575060408051602081019091526013546001600160401b031681526125f3565b6001600160a01b0386165f9081526008602052604090205460ff16156125f3575060408051602081019091526012546001600160401b031681525b80516001600160401b0316156126e757604080518082019091526011546001600160501b0381168252600160501b900460ff1615156020820152815161271090612646906001600160401b031687613373565b612650919061339e565b8251909350633b9aca00906001600160401b031661266e8186613444565b612678919061346f565b612682919061346f565b81518290612691908390613494565b6001600160501b0390811690915282516011805460208601511515600160501b026affffffffffffffffffffff199091169290931691909117919091179055506126e587306001600160801b03861661229a565b505b506001600160801b0316949350505050565b600754640100000000900460ff16156129d1576001600160a01b038281165f908152600b602090815260408083205483835281842054825180840184526010546001600160801b038082168352600160801b90910416818601529589168552600890935292205460ff928316939192168015612773575082155b156128145780516001600160801b03168411156127bc5760405162461bcd60e51b815260206004820152600760248201526626b0bc102a3c3760c91b6044820152606401610aaf565b60208101516001600160801b03166127d48386613272565b111561280f5760405162461bcd60e51b815260206004820152600a60248201526913585e0815d85b1b195d60b21b6044820152606401610aaf565b6128f4565b6001600160a01b0385165f9081526008602052604090205460ff16801561285357506001600160a01b0386165f908152600b602052604090205460ff16155b1561289c5780516001600160801b031684111561280f5760405162461bcd60e51b815260206004820152600760248201526626b0bc102a3c3760c91b6044820152606401610aaf565b826128f45760208101516001600160801b03166128b98386613272565b11156128f45760405162461bcd60e51b815260206004820152600a60248201526913585e0815d85b1b195d60b21b6044820152606401610aaf565b6007546301000000900460ff16156129cd577f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316856001600160a01b03161415801561297a57507f00000000000000000000000000000000000000000000000000000000000000006001600160a01b0316856001600160a01b031614155b156129cd57325f908152600c602052604090205443116129cd5760405162461bcd60e51b815260206004820152600e60248201526d5472616e736665722044656c617960901b6044820152606401610aaf565b5050505b600754610100900460ff1615610b83576001600160a01b0382165f9081526008602052604090205460ff1615612a52576001600160a01b0383165f908152600c60205260409020544311610b835760405162461bcd60e51b815260206004820152600860248201526720b73a349026a2ab60c11b6044820152606401610aaf565b506001600160a01b03165f908152600c6020526040808220439081905532835291205550565b6060612a8684845f85612be9565b949350505050565b305f90815260208190526040812054604080518082019091526011546001600160501b038116808352600160501b90910460ff161515602083015291925090821580612ad8575080155b15612ae257505050565b600f54612af0906014613373565b831115612b0857600f54612b05906014613373565b92505b8215612b7757612b1783612cc0565b475f8115612b7457600d546040516001600160a01b039091169083905f81818185875af1925050503d805f8114612b69576040519150601f19603f3d011682016040523d82523d5f602084013e612b6e565b606091505b50909150505b50505b505f8152601180546020909201511515600160501b026affffffffffffffffffffff1990921691909117905550565b5f600e5443612bb591906133f0565b905060068111612bcd57612bca5f6064612dd4565b50565b612bd95f612710612dd4565b6007805463ffff00001916905550565b606082471015612c4a5760405162461bcd60e51b815260206004820152602660248201527f416464726573733a20696e73756666696369656e742062616c616e636520666f6044820152651c8818d85b1b60d21b6064820152608401610aaf565b5f80866001600160a01b03168587604051612c6591906134bb565b5f6040518083038185875af1925050503d805f8114612c9f576040519150601f19603f3d011682016040523d82523d5f602084013e612ca4565b606091505b5091509150612cb587838387612e80565b979650505050505050565b6040805160028082526060820183525f9260208301908036833701905050905030815f81518110612cf357612cf36133dc565b60200260200101906001600160a01b031690816001600160a01b0316815250507f000000000000000000000000000000000000000000000000000000000000000081600181518110612d4757612d476133dc565b6001600160a01b03928316602091820292909201015260405163791ac94760e01b81527f00000000000000000000000000000000000000000000000000000000000000009091169063791ac94790612dab9085905f908690309042906004016134d1565b5f604051808303815f87803b158015612dc2575f80fd5b505af1158015611791573d5f803e3d5ffd5b60408051602081019091526001600160401b0383168082526013805467ffffffffffffffff1990811683179091556012805490911690911790556001600160801b03821615610b8357604080518082019091525f80825260208201525f612710846001600160801b0316612e4760025490565b612e519190613373565b612e5b919061339e565b6001600160801b0316808352602090920182905250600160801b810217601055505050565b60608315612eee5782515f03612ee7576001600160a01b0385163b612ee75760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e74726163740000006044820152606401610aaf565b5081612a86565b612a868383815115612f035781518083602001fd5b8060405162461bcd60e51b8152600401610aaf91905b602081525f82518060208401528060208501604085015e5f604082850101526040601f19601f83011684010191505092915050565b80356001600160a01b0381168114612f64575f80fd5b919050565b5f8060408385031215612f7a575f80fd5b612f8383612f4e565b9150612f9160208401612f4e565b90509250929050565b5f8060408385031215612fab575f80fd5b612fb483612f4e565b946020939093013593505050565b5f60208284031215612fd2575f80fd5b612fdb82612f4e565b9392505050565b5f805f60608486031215612ff4575f80fd5b612ffd84612f4e565b925061300b60208501612f4e565b9150604084013590509250925092565b5f6020828403121561302b575f80fd5b81356001600160801b0381168114612fdb575f80fd5b8015158114612bca575f80fd5b5f6020828403121561305e575f80fd5b8135612fdb81613041565b5f60208284031215613079575f80fd5b81356001600160401b0381168114612fdb575f80fd5b5f8083601f84011261309f575f80fd5b5081356001600160401b038111156130b5575f80fd5b6020830191508360208260051b85010111156130cf575f80fd5b9250929050565b5f805f604084860312156130e8575f80fd5b83356001600160401b038111156130fd575f80fd5b6131098682870161308f565b909450925050602084013561311d81613041565b809150509250925092565b5f60208284031215613138575f80fd5b5035919050565b5f805f8060408587031215613152575f80fd5b84356001600160401b0380821115613168575f80fd5b6131748883890161308f565b9096509450602087013591508082111561318c575f80fd5b506131998782880161308f565b95989497509550505050565b5f80604083850312156131b6575f80fd5b6131bf83612f4e565b915060208301356131cf81613041565b809150509250929050565b600181811c908216806131ee57607f821691505b60208210810361320c57634e487b7160e01b5f52602260045260245ffd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b5f60208284031215613257575f80fd5b5051919050565b634e487b7160e01b5f52601160045260245ffd5b80820180821115610b9b57610b9b61325e565b600181815b808511156132bf57815f19048211156132a5576132a561325e565b808516156132b257918102915b93841c939080029061328a565b509250929050565b5f826132d557506001610b9b565b816132e157505f610b9b565b81600181146132f757600281146133015761331d565b6001915050610b9b565b60ff8411156133125761331261325e565b50506001821b610b9b565b5060208310610133831016604e8410600b8410161715613340575081810a610b9b565b61334a8383613285565b805f190482111561335d5761335d61325e565b029392505050565b5f612fdb60ff8416836132c7565b8082028115828204841417610b9b57610b9b61325e565b634e487b7160e01b5f52601260045260245ffd5b5f826133ac576133ac61338a565b500490565b5f805f606084860312156133c3575f80fd5b8351925060208401519150604084015190509250925092565b634e487b7160e01b5f52603260045260245ffd5b81810381811115610b9b57610b9b61325e565b6020808252600c908201526b189bdd0819195d1958dd195960a21b604082015260600190565b5f60208284031215613439575f80fd5b8151612fdb81613041565b6001600160801b038181168382160280821691908281146134675761346761325e565b505092915050565b5f6001600160801b03808416806134885761348861338a565b92169190910492915050565b6001600160501b038181168382160190808211156134b4576134b461325e565b5092915050565b5f82518060208501845e5f920191825250919050565b5f60a08201878352602087602085015260a0604085015281875180845260c0860191506020890193505f5b818110156135215784516001600160a01b0316835293830193918301916001016134fc565b50506001600160a01b0396909616606085015250505060800152939250505056fea26469706673582212208cdd432a8db50c52b9743b8eeb4104a5eb93298bee4a8be04fa80bccbe99262f64736f6c63430008190033

Deployed Bytecode

0x6080604052600436106102f5575f3560e01c80637aafd99d11610189578063b7883a7a116100d8578063dcc29ab111610092578063ed40b84c1161006d578063ed40b84c14610979578063ee8adeb914610998578063f2fde38b146109b7578063ff13812e146109d6575f80fd5b8063dcc29ab114610926578063dd62ed3e1461093a578063e4905fd314610959575f80fd5b8063b7883a7a14610849578063c8ab5dd81461085d578063cb5db8f7146108a7578063ce17f71b146108bb578063d2534f45146108ee578063d4fb9a011461090d575f80fd5b80639c0db5f311610143578063a457c2d71161011e578063a457c2d7146107be578063a9059cbb146107dd578063b2bdfa7b146107fc578063b4b11b951461081b575f80fd5b80639c0db5f31461076d5780639d0014b11461078c5780639e7934db146107ab575f80fd5b80637aafd99d146106be5780637cb72ef8146106dd5780638da5cb5b146106fc57806390e1fe531461071957806395d89b411461073a5780639a1743ac1461074e575f80fd5b8063395093511161024557806361e7ecca116101ff5780636ed3e244116101da5780636ed3e2441461064f57806370a082311461066e578063715018a6146106a2578063731dd559146106b6575f80fd5b806361e7ecca146105e357806361faaff414610602578063638d516214610621575f80fd5b806339509351146104f457806349ee702b14610513578063539728801461052857806356340e81146105565780635b561cee146105a05780635f4fd367146105ce575f80fd5b80631c5942e7116102b05780632cb158641161028b5780632cb1586414610487578063313ce5671461049c578063339b2cff146104b7578063376f73bd146104d6575f80fd5b80631c5942e7146103ea5780631cb858181461043557806323b872dd14610468575f80fd5b806221ee711461030057806306fdde031461033c57806308b99c951461035d578063095ea7b31461037e5780631076b825146103ad57806318160ddd146103cc575f80fd5b366102fc57005b5f80fd5b34801561030b575f80fd5b5060135461031f906001600160401b031681565b6040516001600160401b0390911681526020015b60405180910390f35b348015610347575f80fd5b506103506109f5565b6040516103339190612f19565b348015610368575f80fd5b5061037c610377366004612f69565b610a85565b005b348015610389575f80fd5b5061039d610398366004612f9a565b610b88565b6040519015158152602001610333565b3480156103b8575f80fd5b5061037c6103c7366004612fc2565b610ba1565b3480156103d7575f80fd5b506002545b604051908152602001610333565b3480156103f5575f80fd5b5061041d7f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc281565b6040516001600160a01b039091168152602001610333565b348015610440575f80fd5b5061041d7f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d81565b348015610473575f80fd5b5061039d610482366004612fe2565b610c32565b348015610492575f80fd5b506103dc600e5481565b3480156104a7575f80fd5b5060405160128152602001610333565b3480156104c2575f80fd5b50600d5461041d906001600160a01b031681565b3480156104e1575f80fd5b5060075461039d90610100900460ff1681565b3480156104ff575f80fd5b5061039d61050e366004612f9a565b610c55565b34801561051e575f80fd5b5061031f61271081565b348015610533575f80fd5b5061039d610542366004612fc2565b60096020525f908152604090205460ff1681565b348015610561575f80fd5b50601054610580906001600160801b0380821691600160801b90041682565b604080516001600160801b03938416815292909116602083015201610333565b3480156105ab575f80fd5b5061039d6105ba366004612fc2565b600b6020525f908152604090205460ff1681565b3480156105d9575f80fd5b506103dc600f5481565b3480156105ee575f80fd5b5061037c6105fd36600461301b565b610c76565b34801561060d575f80fd5b5061037c61061c36600461304e565b610d91565b34801561062c575f80fd5b5061039d61063b366004612fc2565b600a6020525f908152604090205460ff1681565b34801561065a575f80fd5b5061037c610669366004613069565b610dd5565b348015610679575f80fd5b506103dc610688366004612fc2565b6001600160a01b03165f9081526020819052604090205490565b3480156106ad575f80fd5b5061037c610e6d565b61037c610ee0565b3480156106c9575f80fd5b5060125461031f906001600160401b031681565b3480156106e8575f80fd5b5061037c6106f7366004613069565b611112565b348015610707575f80fd5b506005546001600160a01b031661041d565b348015610724575f80fd5b5060075461039d90640100000000900460ff1681565b348015610745575f80fd5b506103506111aa565b348015610759575f80fd5b5060075461039d9062010000900460ff1681565b348015610778575f80fd5b5061037c6107873660046130d6565b6111b9565b348015610797575f80fd5b5061037c6107a6366004613128565b6113d1565b61037c6107b936600461313f565b61151c565b3480156107c9575f80fd5b5061039d6107d8366004612f9a565b611799565b3480156107e8575f80fd5b5061039d6107f7366004612f9a565b611813565b348015610807575f80fd5b5060055461041d906001600160a01b031681565b348015610826575f80fd5b5061039d610835366004612fc2565b60086020525f908152604090205460ff1681565b348015610854575f80fd5b5061037c611820565b348015610868575f80fd5b50601154610888906001600160501b03811690600160501b900460ff1682565b604080516001600160501b039093168352901515602083015201610333565b3480156108b2575f80fd5b5061037c6118a6565b3480156108c6575f80fd5b5061041d7f000000000000000000000000a0599e4262d93d8bf5f5209e2ec032cf8f298d7681565b3480156108f9575f80fd5b5061037c61090836600461313f565b611949565b348015610918575f80fd5b5060075461039d9060ff1681565b348015610931575f80fd5b5061037c611a1d565b348015610945575f80fd5b506103dc610954366004612f69565b611a9b565b348015610964575f80fd5b5060075461039d906301000000900460ff1681565b348015610984575f80fd5b5061037c6109933660046131a5565b611ac5565b3480156109a3575f80fd5b5061037c6109b236600461301b565b611c12565b3480156109c2575f80fd5b5061037c6109d1366004612fc2565b611d2c565b3480156109e1575f80fd5b5061037c6109f03660046131a5565b611e16565b606060038054610a04906131da565b80601f0160208091040260200160405190810160405280929190818152602001828054610a30906131da565b8015610a7b5780601f10610a5257610100808354040283529160200191610a7b565b820191905f5260205f20905b815481529060010190602001808311610a5e57829003601f168201915b5050505050905090565b6005546001600160a01b03163314610ab85760405162461bcd60e51b8152600401610aaf90613212565b60405180910390fd5b6001600160a01b038216610b0e5760405162461bcd60e51b815260206004820152601960248201527f546f6b656e20616464726573732063616e6e6f742062652030000000000000006044820152606401610aaf565b6040516370a0823160e01b81523060048201525f906001600160a01b038416906370a0823190602401602060405180830381865afa158015610b52573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610b769190613247565b9050610b83838383611f38565b505050565b5f33610b95818585611f8a565b60019150505b92915050565b6005546001600160a01b03163314610bcb5760405162461bcd60e51b8152600401610aaf90613212565b6001600160a01b038116610c105760405162461bcd60e51b815260206004820152600c60248201526b5a65726f206164647265737360a01b6044820152606401610aaf565b600d80546001600160a01b0319166001600160a01b0392909216919091179055565b5f33610c3f8582856120ad565b610c4a85858561211f565b506001949350505050565b5f33610b95818585610c678383611a9b565b610c719190613272565b611f8a565b6005546001600160a01b03163314610ca05760405162461bcd60e51b8152600401610aaf90613212565b610cac6012600a613365565b6103e8610cb860025490565b610cc3906001613373565b610ccd919061339e565b610cd7919061339e565b816001600160801b03161015610d195760405162461bcd60e51b8152602060048201526007602482015266546f6f206c6f7760c81b6044820152606401610aaf565b610d256012600a613365565b610d38906001600160801b038316613373565b601080546001600160801b03908116600160801b93821684021791829055604051929091041681527f12528a3c61e0f3b2d6fc707a9fc58b1af86e252cad0d7f4c154ebeabb162dace906020015b60405180910390a150565b6005546001600160a01b03163314610dbb5760405162461bcd60e51b8152600401610aaf90613212565b600780549115156101000261ff0019909216919091179055565b6005546001600160a01b03163314610dff5760405162461bcd60e51b8152600401610aaf90613212565b60408051602080820183526001600160401b038416808352925192835290917f981be54b1fc7934066e749221f7fbdced2c3c7a8fe33efe2c229510e4bd88be7910160405180910390a1516012805467ffffffffffffffff19166001600160401b0390921691909117905550565b6005546001600160a01b03163314610e975760405162461bcd60e51b8152600401610aaf90613212565b6005546040515f916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600580546001600160a01b0319169055565b6005546001600160a01b03163314610f0a5760405162461bcd60e51b8152600401610aaf90613212565b60075460ff1615610f5d5760405162461bcd60e51b815260206004820152601760248201527f54726164696e6720616c726561647920656e61626c65640000000000000000006044820152606401610aaf565b305f9081526020819052604090205480610fb95760405162461bcd60e51b815260206004820152601760248201527f4e6f20746f6b656e7320666f72206c69717569646974790000000000000000006044820152606401610aaf565b3480610ffe5760405162461bcd60e51b81526020600482015260146024820152734e6f2045544820666f72206c697175696469747960601b6044820152606401610aaf565b6110287f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d83610b88565b507f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663f305d7198230855f8061106f6005546001600160a01b031690565b60405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c40160606040518083038185885af11580156110d5573d5f803e3d5ffd5b50505050506040513d601f19601f820116820180604052508101906110fa91906133b1565b50506007805460ff19166001179055505043600e5550565b6005546001600160a01b0316331461113c5760405162461bcd60e51b8152600401610aaf90613212565b60408051602080820183526001600160401b038416808352925192835290917f5033bbad39d9cfa21094b122d2098d46be472ce7be668788fbab72b0f79178a7910160405180910390a1516013805467ffffffffffffffff19166001600160401b0390921691909117905550565b606060048054610a04906131da565b6005546001600160a01b031633146111e35760405162461bcd60e51b8152600401610aaf90613212565b5f5b828110156113cb5760085f858584818110611202576112026133dc565b90506020020160208101906112179190612fc2565b6001600160a01b0316815260208101919091526040015f205460ff1615801561129857507f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b0316848483818110611277576112776133dc565b905060200201602081019061128c9190612fc2565b6001600160a01b031614155b80156112d35750308484838181106112b2576112b26133dc565b90506020020160208101906112c79190612fc2565b6001600160a01b031614155b80156113705750600a5f8585848181106112ef576112ef6133dc565b90506020020160208101906113049190612fc2565b6001600160a01b0316815260208101919091526040015f205460ff161580156113705750600b5f85858481811061133d5761133d6133dc565b90506020020160208101906113529190612fc2565b6001600160a01b0316815260208101919091526040015f205460ff16155b156113c3576113c384848381811061138a5761138a6133dc565b905060200201602081019061139f9190612fc2565b6001600160a01b03165f908152600960205260409020805460ff1916841515179055565b6001016111e5565b50505050565b6005546001600160a01b031633146113fb5760405162461bcd60e51b8152600401610aaf90613212565b620186a061140860025490565b611413906001613373565b61141d919061339e565b81101561148a5760405162461bcd60e51b815260206004820152603560248201527f5377617020616d6f756e742063616e6e6f74206265206c6f776572207468616e60448201527410181718181892903a37ba30b61039bab838363c9760591b6064820152608401610aaf565b6103e861149660025490565b6114a1906005613373565b6114ab919061339e565b8111156115175760405162461bcd60e51b815260206004820152603460248201527f5377617020616d6f756e742063616e6e6f742062652068696768657220746861604482015273371018171a92903a37ba30b61039bab838363c9760611b6064820152608401610aaf565b600f55565b6005546001600160a01b031633146115465760405162461bcd60e51b8152600401610aaf90613212565b82811461158e5760405162461bcd60e51b8152602060048201526016602482015275082e4e4c2f2e640d8cadccee8d040dad2e6dac2e8c6d60531b6044820152606401610aaf565b5f805b828110156115c7578383828181106115ab576115ab6133dc565b90506020020135826115bd9190613272565b9150600101611591565b50803410156116105760405162461bcd60e51b8152602060048201526015602482015274125b9cdd59999a58da595b9d08115512081cd95b9d605a1b6044820152606401610aaf565b5f5b848110156116f6575f86868381811061162d5761162d6133dc565b90506020020160208101906116429190612fc2565b6001600160a01b031685858481811061165d5761165d6133dc565b905060200201356040515f6040518083038185875af1925050503d805f81146116a1576040519150601f19603f3d011682016040523d82523d5f602084013e6116a6565b606091505b50509050806116ed5760405162461bcd60e51b8152602060048201526013602482015272115512081d1c985b9cd9995c8819985a5b1959606a1b6044820152606401610aaf565b50600101611612565b505f61170282346133f0565b90508015611791576040515f90339083908381818185875af1925050503d805f8114611749576040519150601f19603f3d011682016040523d82523d5f602084013e61174e565b606091505b505090508061178f5760405162461bcd60e51b815260206004820152600d60248201526c1499599d5b990819985a5b1959609a1b6044820152606401610aaf565b505b505050505050565b5f33816117a68286611a9b565b9050838110156118065760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b6064820152608401610aaf565b610c4a8286868403611f8a565b5f33610b9581858561211f565b6005546001600160a01b0316331461184a5760405162461bcd60e51b8152600401610aaf90613212565b6007546301000000900460ff166118975760405162461bcd60e51b8152602060048201526011602482015270416c72656164792064697361626c65642160781b6044820152606401610aaf565b6007805463ff00000019169055565b6005546001600160a01b031633146118d05760405162461bcd60e51b8152600401610aaf90613212565b6007805464ff0000000019169055604080518082019091525f80825260208201525f6118fb60025490565b6001600160801b03811680845260208401819052600160801b8102176010556040519091507fa4ffae85e880608d5d4365c2b682786545d136145537788e7e0940dff9f0b98c905f90a15050565b6005546001600160a01b031633146119735760405162461bcd60e51b8152600401610aaf90613212565b8281146119bb5760405162461bcd60e51b81526020600482015260166024820152750c2e4e4c2f2e640d8cadccee8d040dad2e6dac2e8c6d60531b6044820152606401610aaf565b5f5b83811015611a1657611a0e338686848181106119db576119db6133dc565b90506020020160208101906119f09190612fc2565b858585818110611a0257611a026133dc565b9050602002013561229a565b6001016119bd565b5050505050565b6005546001600160a01b03163314611a475760405162461bcd60e51b8152600401610aaf90613212565b60075462010000900460ff16611a8d5760405162461bcd60e51b815260206004820152600b60248201526a20b63932b0b23c9037b33360a91b6044820152606401610aaf565b6007805462ff000019169055565b6001600160a01b039182165f90815260016020908152604080832093909416825291909152205490565b6005546001600160a01b03163314611aef5760405162461bcd60e51b8152600401610aaf90613212565b6001600160a01b038216611b345760405162461bcd60e51b815260206004820152600c60248201526b5a65726f204164647265737360a01b6044820152606401610aaf565b80611baf577f000000000000000000000000a0599e4262d93d8bf5f5209e2ec032cf8f298d766001600160a01b0316826001600160a01b031603611baf5760405162461bcd60e51b815260206004820152601260248201527121b0b73737ba103932b6b7bb32903830b4b960711b6044820152606401610aaf565b6001600160a01b0382165f818152600b6020908152604091829020805460ff19168515159081179091558251938452908301527f09b631341efb0516853fc01bb7721db352d8d3e95e4578fdf435ac19779fb4d191015b60405180910390a15050565b6005546001600160a01b03163314611c3c5760405162461bcd60e51b8152600401610aaf90613212565b611c486012600a613365565b6103e8611c5460025490565b611c5f906001613373565b611c69919061339e565b611c73919061339e565b816001600160801b03161015611cb55760405162461bcd60e51b8152602060048201526007602482015266546f6f206c6f7760c81b6044820152606401610aaf565b611cc16012600a613365565b611cd4906001600160801b038316613373565b601080546fffffffffffffffffffffffffffffffff19166001600160801b039290921691821790556040519081527f76a9278644b7300961aa0e7e86f10934585987f1daf1c6ecc971c1837669157490602001610d86565b6005546001600160a01b03163314611d565760405162461bcd60e51b8152600401610aaf90613212565b6001600160a01b038116611dbb5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610aaf565b6005546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0905f90a3600580546001600160a01b0319166001600160a01b0392909216919091179055565b6005546001600160a01b03163314611e405760405162461bcd60e51b8152600401610aaf90613212565b6001600160a01b038216611e855760405162461bcd60e51b815260206004820152600c60248201526b5a65726f204164647265737360a01b6044820152606401610aaf565b306001600160a01b03831603611edd5760405162461bcd60e51b815260206004820152601860248201527f43616e6e6f7420756e6578656d707420636f6e747261637400000000000000006044820152606401610aaf565b6001600160a01b0382165f818152600a6020908152604091829020805460ff19168515159081179091558251938452908301527feb24498d6c39fcfc9fb01dd89ed3548e59070d8976add9a6fb66679bacde0ac09101611c06565b604080516001600160a01b038416602482015260448082018490528251808303909101815260649091019091526020810180516001600160e01b031663a9059cbb60e01b179052610b8390849061243c565b6001600160a01b038316611fec5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610aaf565b6001600160a01b03821661204d5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610aaf565b6001600160a01b038381165f8181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b5f6120b88484611a9b565b90505f1981146113cb57818110156121125760405162461bcd60e51b815260206004820152601d60248201527f45524332303a20696e73756666696369656e7420616c6c6f77616e63650000006044820152606401610aaf565b6113cb8484848403611f8a565b6001600160a01b0383165f9081526009602052604090205460ff16156121575760405162461bcd60e51b8152600401610aaf90613403565b336001600160a01b038416148061217d5750335f9081526009602052604090205460ff16155b6121995760405162461bcd60e51b8152600401610aaf90613403565b326001600160a01b03841614806121af57503233145b806121c95750325f9081526009602052604090205460ff16155b6121e55760405162461bcd60e51b8152600401610aaf90613403565b6001600160a01b0383165f908152600a602052604090205460ff1615801561222557506001600160a01b0382165f908152600a602052604090205460ff16155b156122935760075460ff166122715760405162461bcd60e51b815260206004820152601260248201527154726164696e67206e6f742061637469766560701b6044820152606401610aaf565b61227c83838361250d565b61228690826133f0565b90506122938383836126f9565b610b838383835b6001600160a01b0383166122fe5760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b6064820152608401610aaf565b6001600160a01b0382166123605760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b6064820152608401610aaf565b6001600160a01b0383165f90815260208190526040902054818110156123d75760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b6064820152608401610aaf565b6001600160a01b038481165f81815260208181526040808320878703905593871680835291849020805487019055925185815290927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a36113cb565b5f612490826040518060400160405280602081526020017f5361666545524332303a206c6f772d6c6576656c2063616c6c206661696c6564815250856001600160a01b0316612a789092919063ffffffff16565b805190915015610b8357808060200190518101906124ae9190613429565b610b835760405162461bcd60e51b815260206004820152602a60248201527f5361666545524332303a204552433230206f7065726174696f6e20646964206e6044820152691bdd081cdd58d8d9595960b21b6064820152608401610aaf565b600f54305f9081526020819052604081205490911115801561254757506001600160a01b0384165f9081526008602052604090205460ff16155b1561255457612554612a8e565b60075462010000900460ff161561256d5761256d612ba6565b60408051602080820183525f8083526001600160a01b038716815260089091529182205460ff16156125b8575060408051602081019091526013546001600160401b031681526125f3565b6001600160a01b0386165f9081526008602052604090205460ff16156125f3575060408051602081019091526012546001600160401b031681525b80516001600160401b0316156126e757604080518082019091526011546001600160501b0381168252600160501b900460ff1615156020820152815161271090612646906001600160401b031687613373565b612650919061339e565b8251909350633b9aca00906001600160401b031661266e8186613444565b612678919061346f565b612682919061346f565b81518290612691908390613494565b6001600160501b0390811690915282516011805460208601511515600160501b026affffffffffffffffffffff199091169290931691909117919091179055506126e587306001600160801b03861661229a565b505b506001600160801b0316949350505050565b600754640100000000900460ff16156129d1576001600160a01b038281165f908152600b602090815260408083205483835281842054825180840184526010546001600160801b038082168352600160801b90910416818601529589168552600890935292205460ff928316939192168015612773575082155b156128145780516001600160801b03168411156127bc5760405162461bcd60e51b815260206004820152600760248201526626b0bc102a3c3760c91b6044820152606401610aaf565b60208101516001600160801b03166127d48386613272565b111561280f5760405162461bcd60e51b815260206004820152600a60248201526913585e0815d85b1b195d60b21b6044820152606401610aaf565b6128f4565b6001600160a01b0385165f9081526008602052604090205460ff16801561285357506001600160a01b0386165f908152600b602052604090205460ff16155b1561289c5780516001600160801b031684111561280f5760405162461bcd60e51b815260206004820152600760248201526626b0bc102a3c3760c91b6044820152606401610aaf565b826128f45760208101516001600160801b03166128b98386613272565b11156128f45760405162461bcd60e51b815260206004820152600a60248201526913585e0815d85b1b195d60b21b6044820152606401610aaf565b6007546301000000900460ff16156129cd577f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b0316856001600160a01b03161415801561297a57507f000000000000000000000000a0599e4262d93d8bf5f5209e2ec032cf8f298d766001600160a01b0316856001600160a01b031614155b156129cd57325f908152600c602052604090205443116129cd5760405162461bcd60e51b815260206004820152600e60248201526d5472616e736665722044656c617960901b6044820152606401610aaf565b5050505b600754610100900460ff1615610b83576001600160a01b0382165f9081526008602052604090205460ff1615612a52576001600160a01b0383165f908152600c60205260409020544311610b835760405162461bcd60e51b815260206004820152600860248201526720b73a349026a2ab60c11b6044820152606401610aaf565b506001600160a01b03165f908152600c6020526040808220439081905532835291205550565b6060612a8684845f85612be9565b949350505050565b305f90815260208190526040812054604080518082019091526011546001600160501b038116808352600160501b90910460ff161515602083015291925090821580612ad8575080155b15612ae257505050565b600f54612af0906014613373565b831115612b0857600f54612b05906014613373565b92505b8215612b7757612b1783612cc0565b475f8115612b7457600d546040516001600160a01b039091169083905f81818185875af1925050503d805f8114612b69576040519150601f19603f3d011682016040523d82523d5f602084013e612b6e565b606091505b50909150505b50505b505f8152601180546020909201511515600160501b026affffffffffffffffffffff1990921691909117905550565b5f600e5443612bb591906133f0565b905060068111612bcd57612bca5f6064612dd4565b50565b612bd95f612710612dd4565b6007805463ffff00001916905550565b606082471015612c4a5760405162461bcd60e51b815260206004820152602660248201527f416464726573733a20696e73756666696369656e742062616c616e636520666f6044820152651c8818d85b1b60d21b6064820152608401610aaf565b5f80866001600160a01b03168587604051612c6591906134bb565b5f6040518083038185875af1925050503d805f8114612c9f576040519150601f19603f3d011682016040523d82523d5f602084013e612ca4565b606091505b5091509150612cb587838387612e80565b979650505050505050565b6040805160028082526060820183525f9260208301908036833701905050905030815f81518110612cf357612cf36133dc565b60200260200101906001600160a01b031690816001600160a01b0316815250507f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc281600181518110612d4757612d476133dc565b6001600160a01b03928316602091820292909201015260405163791ac94760e01b81527f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d9091169063791ac94790612dab9085905f908690309042906004016134d1565b5f604051808303815f87803b158015612dc2575f80fd5b505af1158015611791573d5f803e3d5ffd5b60408051602081019091526001600160401b0383168082526013805467ffffffffffffffff1990811683179091556012805490911690911790556001600160801b03821615610b8357604080518082019091525f80825260208201525f612710846001600160801b0316612e4760025490565b612e519190613373565b612e5b919061339e565b6001600160801b0316808352602090920182905250600160801b810217601055505050565b60608315612eee5782515f03612ee7576001600160a01b0385163b612ee75760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a2063616c6c20746f206e6f6e2d636f6e74726163740000006044820152606401610aaf565b5081612a86565b612a868383815115612f035781518083602001fd5b8060405162461bcd60e51b8152600401610aaf91905b602081525f82518060208401528060208501604085015e5f604082850101526040601f19601f83011684010191505092915050565b80356001600160a01b0381168114612f64575f80fd5b919050565b5f8060408385031215612f7a575f80fd5b612f8383612f4e565b9150612f9160208401612f4e565b90509250929050565b5f8060408385031215612fab575f80fd5b612fb483612f4e565b946020939093013593505050565b5f60208284031215612fd2575f80fd5b612fdb82612f4e565b9392505050565b5f805f60608486031215612ff4575f80fd5b612ffd84612f4e565b925061300b60208501612f4e565b9150604084013590509250925092565b5f6020828403121561302b575f80fd5b81356001600160801b0381168114612fdb575f80fd5b8015158114612bca575f80fd5b5f6020828403121561305e575f80fd5b8135612fdb81613041565b5f60208284031215613079575f80fd5b81356001600160401b0381168114612fdb575f80fd5b5f8083601f84011261309f575f80fd5b5081356001600160401b038111156130b5575f80fd5b6020830191508360208260051b85010111156130cf575f80fd5b9250929050565b5f805f604084860312156130e8575f80fd5b83356001600160401b038111156130fd575f80fd5b6131098682870161308f565b909450925050602084013561311d81613041565b809150509250925092565b5f60208284031215613138575f80fd5b5035919050565b5f805f8060408587031215613152575f80fd5b84356001600160401b0380821115613168575f80fd5b6131748883890161308f565b9096509450602087013591508082111561318c575f80fd5b506131998782880161308f565b95989497509550505050565b5f80604083850312156131b6575f80fd5b6131bf83612f4e565b915060208301356131cf81613041565b809150509250929050565b600181811c908216806131ee57607f821691505b60208210810361320c57634e487b7160e01b5f52602260045260245ffd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b5f60208284031215613257575f80fd5b5051919050565b634e487b7160e01b5f52601160045260245ffd5b80820180821115610b9b57610b9b61325e565b600181815b808511156132bf57815f19048211156132a5576132a561325e565b808516156132b257918102915b93841c939080029061328a565b509250929050565b5f826132d557506001610b9b565b816132e157505f610b9b565b81600181146132f757600281146133015761331d565b6001915050610b9b565b60ff8411156133125761331261325e565b50506001821b610b9b565b5060208310610133831016604e8410600b8410161715613340575081810a610b9b565b61334a8383613285565b805f190482111561335d5761335d61325e565b029392505050565b5f612fdb60ff8416836132c7565b8082028115828204841417610b9b57610b9b61325e565b634e487b7160e01b5f52601260045260245ffd5b5f826133ac576133ac61338a565b500490565b5f805f606084860312156133c3575f80fd5b8351925060208401519150604084015190509250925092565b634e487b7160e01b5f52603260045260245ffd5b81810381811115610b9b57610b9b61325e565b6020808252600c908201526b189bdd0819195d1958dd195960a21b604082015260600190565b5f60208284031215613439575f80fd5b8151612fdb81613041565b6001600160801b038181168382160280821691908281146134675761346761325e565b505092915050565b5f6001600160801b03808416806134885761348861338a565b92169190910492915050565b6001600160501b038181168382160190808211156134b4576134b461325e565b5092915050565b5f82518060208501845e5f920191825250919050565b5f60a08201878352602087602085015260a0604085015281875180845260c0860191506020890193505f5b818110156135215784516001600160a01b0316835293830193918301916001016134fc565b50506001600160a01b0396909616606085015250505060800152939250505056fea26469706673582212208cdd432a8db50c52b9743b8eeb4104a5eb93298bee4a8be04fa80bccbe99262f64736f6c63430008190033

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.