ETH Price: $3,394.24 (+1.29%)
Gas: 6.34 Gwei

Token

SPEECH (SPEECH)
 

Overview

Max Total Supply

420,000,000,000,000 SPEECH

Holders

43

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 18 Decimals)

Balance
2,206,073,621,166.698540916584335411 SPEECH

Value
$0.00
0x4b2542d6841a58dc93a5aab9b2f393da15a8eb26
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:
SPEECH

Compiler Version
v0.8.20+commit.a1b79de6

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion
File 1 of 1 : 1.sol
// SPDX-License-Identifier: MIT


/**

Twitter: https://twitter.com/speech_token
Telegram: https://t.me/+iFwuCtbyjEFiNzNh
Medium:  https://tinyurl.com/sdwqwdasd
Web: https://speech-matters.org/


The first creative writing/learning bot/technology to help young kids with speech problems have a better way of practicing to engage in dialogues

enabling them to practice their language skills in a conversational manner. Based on their responses they will be able to mold and change the adaptive

learning model via AI to better understand and speak.

*/
pragma solidity >=0.5.0;

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

    function feeTo() external view returns (address);
    function feeToSetter() external view returns (address);

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

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

    function setFeeTo(address) external;
    function setFeeToSetter(address) external;
}

// File: @uniswap/v2-periphery/contracts/interfaces/IUniswapV2Router01.sol
pragma solidity >=0.6.2;

interface IUniswapV2Router01 {
    function factory() external pure returns (address);
    function WETH() external pure returns (address);

    function addLiquidity(
        address tokenA,
        address tokenB,
        uint amountADesired,
        uint amountBDesired,
        uint amountAMin,
        uint amountBMin,
        address to,
        uint deadline
    ) external returns (uint amountA, uint amountB, uint liquidity);
    function addLiquidityETH(
        address token,
        uint amountTokenDesired,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external payable returns (uint amountToken, uint amountETH, uint liquidity);
    function removeLiquidity(
        address tokenA,
        address tokenB,
        uint liquidity,
        uint amountAMin,
        uint amountBMin,
        address to,
        uint deadline
    ) external returns (uint amountA, uint amountB);
    function removeLiquidityETH(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external returns (uint amountToken, uint amountETH);
    function removeLiquidityWithPermit(
        address tokenA,
        address tokenB,
        uint liquidity,
        uint amountAMin,
        uint amountBMin,
        address to,
        uint deadline,
        bool approveMax, uint8 v, bytes32 r, bytes32 s
    ) external returns (uint amountA, uint amountB);
    function removeLiquidityETHWithPermit(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline,
        bool approveMax, uint8 v, bytes32 r, bytes32 s
    ) external returns (uint amountToken, uint amountETH);
    function swapExactTokensForTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external returns (uint[] memory amounts);
    function swapTokensForExactTokens(
        uint amountOut,
        uint amountInMax,
        address[] calldata path,
        address to,
        uint deadline
    ) external returns (uint[] memory amounts);
    function swapExactETHForTokens(uint amountOutMin, address[] calldata path, address to, uint deadline)
        external
        payable
        returns (uint[] memory amounts);
    function swapTokensForExactETH(uint amountOut, uint amountInMax, address[] calldata path, address to, uint deadline)
        external
        returns (uint[] memory amounts);
    function swapExactTokensForETH(uint amountIn, uint amountOutMin, address[] calldata path, address to, uint deadline)
        external
        returns (uint[] memory amounts);
    function swapETHForExactTokens(uint amountOut, address[] calldata path, address to, uint deadline)
        external
        payable
        returns (uint[] memory amounts);

    function quote(uint amountA, uint reserveA, uint reserveB) external pure returns (uint amountB);
    function getAmountOut(uint amountIn, uint reserveIn, uint reserveOut) external pure returns (uint amountOut);
    function getAmountIn(uint amountOut, uint reserveIn, uint reserveOut) external pure returns (uint amountIn);
    function getAmountsOut(uint amountIn, address[] calldata path) external view returns (uint[] memory amounts);
    function getAmountsIn(uint amountOut, address[] calldata path) external view returns (uint[] memory amounts);
}

// File: @uniswap/v2-periphery/contracts/interfaces/IUniswapV2Router02.sol
pragma solidity >=0.6.2;


interface IUniswapV2Router02 is IUniswapV2Router01 {
    function removeLiquidityETHSupportingFeeOnTransferTokens(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external returns (uint amountETH);
    function removeLiquidityETHWithPermitSupportingFeeOnTransferTokens(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline,
        bool approveMax, uint8 v, bytes32 r, bytes32 s
    ) external returns (uint amountETH);

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

// File: @openzeppelin/contracts/utils/Context.sol


// OpenZeppelin Contracts v4.4.1 (utils/Context.sol)

pragma solidity ^0.8.0;

/**
 * @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;
    }
}

// File: @openzeppelin/contracts/access/Ownable.sol


// OpenZeppelin Contracts (last updated v4.7.0) (access/Ownable.sol)

pragma solidity ^0.8.0;


/**
 * @dev Contract module which provides a basic access control mechanism, where
 * there is an account (an owner) that can be granted exclusive access to
 * specific functions.
 *
 * By default, the owner account will be the one that deploys the contract. This
 * can later be changed with {transferOwnership}.
 *
 * This module is used through inheritance. It will make available the modifier
 * `onlyOwner`, which can be applied to your functions to restrict their use to
 * the owner.
 */
abstract contract Ownable is Context {
    address private _owner;

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

    /**
     * @dev Initializes the contract setting the deployer as the initial owner.
     */
    constructor() {
        _transferOwnership(_msgSender());
    }

    /**
     * @dev Throws if called by any account other than the owner.
     */
    modifier onlyOwner() {
        _checkOwner();
        _;
    }

    /**
     * @dev Returns the address of the current owner.
     */
    function owner() public view virtual returns (address) {
        return _owner;
    }

    /**
     * @dev Throws if the sender is not the owner.
     */
    function _checkOwner() internal view virtual {
        require(owner() == _msgSender(), "Ownable: caller is not the owner");
    }

    /**
     * @dev Leaves the contract without owner. It will not be possible to call
     * `onlyOwner` functions anymore. Can only be called by the current owner.
     *
     * NOTE: Renouncing ownership will leave the contract without an owner,
     * thereby removing any functionality that is only available to the owner.
     */
    function renounceOwnership() public virtual onlyOwner {
        _transferOwnership(address(0));
    }

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

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

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


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

pragma solidity ^0.8.0;

/**
 * @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);
}






pragma solidity ^0.8.18;





contract SPEECH is IERC20, Ownable {
    string public name = "SPEECH";
    string public symbol = "SPEECH";
    uint8 public decimals = 18;
    uint256 private constant _totalSupply = 420_000_000_000_000 * 10**18;
    mapping(address => uint256) private _balances;
    mapping(address => mapping(address => uint256)) private _allowances;
    IUniswapV2Router02 public uniswapV2Router;
    address public uniswapV2Pair;
    bool private inSwapAndLiquify;

    event LiquidityAdded(uint256 tokenAmount, uint256 ethAmount);

    constructor() {
        _balances[msg.sender] = _totalSupply;
        IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
        uniswapV2Pair = IUniswapV2Factory(_uniswapV2Router.factory()).createPair(address(this), _uniswapV2Router.WETH());
        uniswapV2Router = _uniswapV2Router;

        emit Transfer(address(0), msg.sender, _totalSupply);
    }

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

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

    function transfer(address recipient, uint256 amount) public override returns (bool) {
        _transfer(msg.sender, recipient, amount);
        return true;
    }

    function allowance(address owner, address spender) public view override returns (uint256) {
        return _allowances[owner][spender];
    }

    function approve(address spender, uint256 amount) public override returns (bool) {
        _approve(msg.sender, spender, amount);
        return true;
    }

    function transferFrom(address sender, address recipient, uint256 amount) public override returns (bool) {
        _transfer(sender, recipient, amount);
        _approve(sender, msg.sender, _allowances[sender][msg.sender] - amount);
        return true;
    }

    function increaseAllowance(address spender, uint256 addedValue) public returns (bool) {
        _approve(msg.sender, spender, _allowances[msg.sender][spender] + addedValue);
        return true;
    }

    function decreaseAllowance(address spender, uint256 subtractedValue) public returns (bool) {
        uint256 currentAllowance = _allowances[msg.sender][spender];
        require(currentAllowance >= subtractedValue, "ERC20: decreased allowance below zero");
        _approve(msg.sender, spender, currentAllowance - subtractedValue);
        return true;
    }

        function _transfer(address sender, address recipient, uint256 amount) internal {
        require(sender != address(0), "ERC20: transfer from the zero address");
        require(recipient != address(0), "ERC20: transfer to the zero address");
        require(amount > 0, "ERC20: transfer amount must be greater than zero");
        require(_balances[sender] >= amount, "ERC20: transfer amount exceeds balance");

        _balances[sender] -= amount;
        _balances[recipient] += amount;
        emit Transfer(sender, recipient, amount);
    }

    function _approve(address owner, address spender, uint256 amount) internal {
        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);
    }

    function addLiquidity(uint256 tokenAmount, uint256 ethAmount) external onlyOwner {
        _approve(address(this), address(uniswapV2Router), tokenAmount);
        uniswapV2Router.addLiquidityETH{value: ethAmount}(address(this), tokenAmount,
            0, // slippage is unavoidable
           0, // slippage is unavoidable
            address(this),
           block.timestamp
       );
        inSwapAndLiquify = false;
        emit LiquidityAdded(tokenAmount, ethAmount);
    }

    function withdrawETH(uint256 amount) external onlyOwner {
      require(amount <= address(this).balance, "Not enough ETH in the contract");
        (bool success,) = payable(msg.sender).call{value: amount}("");
       require(success, "Withdrawal failed");
    }

    receive() external payable {}

    fallback() external payable {}

}

Settings
{
  "optimizer": {
    "enabled": true,
    "runs": 200
  },
  "outputSelection": {
    "*": {
      "*": [
        "evm.bytecode",
        "evm.deployedBytecode",
        "devdoc",
        "userdoc",
        "metadata",
        "abi"
      ]
    }
  }
}

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":"tokenAmount","type":"uint256"},{"indexed":false,"internalType":"uint256","name":"ethAmount","type":"uint256"}],"name":"LiquidityAdded","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"stateMutability":"payable","type":"fallback"},{"inputs":[{"internalType":"uint256","name":"tokenAmount","type":"uint256"},{"internalType":"uint256","name":"ethAmount","type":"uint256"}],"name":"addLiquidity","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":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"subtractedValue","type":"uint256"}],"name":"decreaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"spender","type":"address"},{"internalType":"uint256","name":"addedValue","type":"uint256"}],"name":"increaseAllowance","outputs":[{"internalType":"bool","name":"","type":"bool"}],"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":[],"name":"symbol","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"totalSupply","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"pure","type":"function"},{"inputs":[{"internalType":"address","name":"recipient","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"transfer","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"inputs":[{"internalType":"address","name":"sender","type":"address"},{"internalType":"address","name":"recipient","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":"uniswapV2Pair","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"uniswapV2Router","outputs":[{"internalType":"contract IUniswapV2Router02","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"withdrawETH","outputs":[],"stateMutability":"nonpayable","type":"function"},{"stateMutability":"payable","type":"receive"}]

60c060405260066080908152650a6a08a8a86960d31b60a0526001906200002790826200035d565b506040805180820190915260068152650a6a08a8a86960d31b60208201526002906200005490826200035d565b506003805460ff191660121790553480156200006e575f80fd5b506200007a336200026e565b335f908152600460208181526040928390206d14b5253145b397d65451000000009055825163c45a015560e01b81529251737a250d5630b4cf539739df2c5dacb4c659f2488d93849363c45a0155938282019390929091908290030181865afa158015620000ea573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019062000110919062000425565b6001600160a01b031663c9c6539630836001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa1580156200015c573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019062000182919062000425565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303815f875af1158015620001cd573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190620001f3919062000425565b600780546001600160a01b03199081166001600160a01b0393841617909155600680549091169183169190911790556040516d14b5253145b397d6545100000000815233905f907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a35062000454565b5f80546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b634e487b7160e01b5f52604160045260245ffd5b600181811c90821680620002e657607f821691505b6020821081036200030557634e487b7160e01b5f52602260045260245ffd5b50919050565b601f82111562000358575f81815260208120601f850160051c81016020861015620003335750805b601f850160051c820191505b8181101562000354578281556001016200033f565b5050505b505050565b81516001600160401b03811115620003795762000379620002bd565b62000391816200038a8454620002d1565b846200030b565b602080601f831160018114620003c7575f8415620003af5750858301515b5f19600386901b1c1916600185901b17855562000354565b5f85815260208120601f198616915b82811015620003f757888601518255948401946001909101908401620003d6565b50858210156200041557878501515f19600388901b60f8161c191681555b5050505050600190811b01905550565b5f6020828403121562000436575f80fd5b81516001600160a01b03811681146200044d575f80fd5b9392505050565b610e1680620004625f395ff3fe608060405260043610610100575f3560e01c8063715018a61161008e578063a457c2d711610060578063a457c2d7146102e2578063a9059cbb14610301578063dd62ed3e14610320578063f14210a614610364578063f2fde38b1461038357005b8063715018a61461027f5780638da5cb5b1461029357806395d89b41146102af5780639cd441da146102c357005b806323b872dd116100d257806323b872dd146101c3578063313ce567146101e2578063395093511461020d57806349bd5a5e1461022c57806370a082311461024b57005b806306fdde0314610109578063095ea7b3146101335780631694505e1461016257806318160ddd1461019957005b3661010757005b005b348015610114575f80fd5b5061011d6103a2565b60405161012a9190610bf4565b60405180910390f35b34801561013e575f80fd5b5061015261014d366004610c5a565b61042e565b604051901515815260200161012a565b34801561016d575f80fd5b50600654610181906001600160a01b031681565b6040516001600160a01b03909116815260200161012a565b3480156101a4575f80fd5b506d14b5253145b397d65451000000005b60405190815260200161012a565b3480156101ce575f80fd5b506101526101dd366004610c82565b610444565b3480156101ed575f80fd5b506003546101fb9060ff1681565b60405160ff909116815260200161012a565b348015610218575f80fd5b50610152610227366004610c5a565b610494565b348015610237575f80fd5b50600754610181906001600160a01b031681565b348015610256575f80fd5b506101b5610265366004610cbb565b6001600160a01b03165f9081526004602052604090205490565b34801561028a575f80fd5b506101076104ca565b34801561029e575f80fd5b505f546001600160a01b0316610181565b3480156102ba575f80fd5b5061011d6104dd565b3480156102ce575f80fd5b506101076102dd366004610cdb565b6104ea565b3480156102ed575f80fd5b506101526102fc366004610c5a565b6105e6565b34801561030c575f80fd5b5061015261031b366004610c5a565b61067b565b34801561032b575f80fd5b506101b561033a366004610cfb565b6001600160a01b039182165f90815260056020908152604080832093909416825291909152205490565b34801561036f575f80fd5b5061010761037e366004610d2c565b610687565b34801561038e575f80fd5b5061010761039d366004610cbb565b61076c565b600180546103af90610d43565b80601f01602080910402602001604051908101604052809291908181526020018280546103db90610d43565b80156104265780601f106103fd57610100808354040283529160200191610426565b820191905f5260205f20905b81548152906001019060200180831161040957829003601f168201915b505050505081565b5f61043a3384846107e5565b5060015b92915050565b5f610450848484610909565b6001600160a01b0384165f9081526005602090815260408083203380855292529091205461048a918691610485908690610d8f565b6107e5565b5060019392505050565b335f8181526005602090815260408083206001600160a01b0387168452909152812054909161043a918590610485908690610da2565b6104d2610b4c565b6104db5f610ba5565b565b600280546103af90610d43565b6104f2610b4c565b60065461050a9030906001600160a01b0316846107e5565b60065460405163f305d71960e01b81523060048201819052602482018590525f60448301819052606483015260848201524260a48201526001600160a01b039091169063f305d71990839060c40160606040518083038185885af1158015610574573d5f803e3d5ffd5b50505050506040513d601f19601f820116820180604052508101906105999190610db5565b50506007805460ff60a01b191690555060408051838152602081018390527f38f8a0c92f4c5b0b6877f878cb4c0c8d348a47b76d716c8e78f425043df9515b910160405180910390a15050565b335f9081526005602090815260408083206001600160a01b03861684529091528120548281101561066c5760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b60648201526084015b60405180910390fd5b61048a33856104858685610d8f565b5f61043a338484610909565b61068f610b4c565b478111156106df5760405162461bcd60e51b815260206004820152601e60248201527f4e6f7420656e6f7567682045544820696e2074686520636f6e747261637400006044820152606401610663565b6040515f90339083908381818185875af1925050503d805f811461071e576040519150601f19603f3d011682016040523d82523d5f602084013e610723565b606091505b50509050806107685760405162461bcd60e51b815260206004820152601160248201527015da5d1a191c985dd85b0819985a5b1959607a1b6044820152606401610663565b5050565b610774610b4c565b6001600160a01b0381166107d95760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610663565b6107e281610ba5565b50565b6001600160a01b0383166108475760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610663565b6001600160a01b0382166108a85760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610663565b6001600160a01b038381165f8181526005602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b03831661096d5760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b6064820152608401610663565b6001600160a01b0382166109cf5760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b6064820152608401610663565b5f8111610a375760405162461bcd60e51b815260206004820152603060248201527f45524332303a207472616e7366657220616d6f756e74206d757374206265206760448201526f726561746572207468616e207a65726f60801b6064820152608401610663565b6001600160a01b0383165f90815260046020526040902054811115610aad5760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b6064820152608401610663565b6001600160a01b0383165f9081526004602052604081208054839290610ad4908490610d8f565b90915550506001600160a01b0382165f9081526004602052604081208054839290610b00908490610da2565b92505081905550816001600160a01b0316836001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef836040516108fc91815260200190565b5f546001600160a01b031633146104db5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65726044820152606401610663565b5f80546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b5f6020808352835180828501525f5b81811015610c1f57858101830151858201604001528201610c03565b505f604082860101526040601f19601f8301168501019250505092915050565b80356001600160a01b0381168114610c55575f80fd5b919050565b5f8060408385031215610c6b575f80fd5b610c7483610c3f565b946020939093013593505050565b5f805f60608486031215610c94575f80fd5b610c9d84610c3f565b9250610cab60208501610c3f565b9150604084013590509250925092565b5f60208284031215610ccb575f80fd5b610cd482610c3f565b9392505050565b5f8060408385031215610cec575f80fd5b50508035926020909101359150565b5f8060408385031215610d0c575f80fd5b610d1583610c3f565b9150610d2360208401610c3f565b90509250929050565b5f60208284031215610d3c575f80fd5b5035919050565b600181811c90821680610d5757607f821691505b602082108103610d7557634e487b7160e01b5f52602260045260245ffd5b50919050565b634e487b7160e01b5f52601160045260245ffd5b8181038181111561043e5761043e610d7b565b8082018082111561043e5761043e610d7b565b5f805f60608486031215610dc7575f80fd5b835192506020840151915060408401519050925092509256fea2646970667358221220299b37a718d86772b7bc493bbd2533a63f666cd36f7206302564a21fc4b526ef64736f6c63430008140033

Deployed Bytecode

0x608060405260043610610100575f3560e01c8063715018a61161008e578063a457c2d711610060578063a457c2d7146102e2578063a9059cbb14610301578063dd62ed3e14610320578063f14210a614610364578063f2fde38b1461038357005b8063715018a61461027f5780638da5cb5b1461029357806395d89b41146102af5780639cd441da146102c357005b806323b872dd116100d257806323b872dd146101c3578063313ce567146101e2578063395093511461020d57806349bd5a5e1461022c57806370a082311461024b57005b806306fdde0314610109578063095ea7b3146101335780631694505e1461016257806318160ddd1461019957005b3661010757005b005b348015610114575f80fd5b5061011d6103a2565b60405161012a9190610bf4565b60405180910390f35b34801561013e575f80fd5b5061015261014d366004610c5a565b61042e565b604051901515815260200161012a565b34801561016d575f80fd5b50600654610181906001600160a01b031681565b6040516001600160a01b03909116815260200161012a565b3480156101a4575f80fd5b506d14b5253145b397d65451000000005b60405190815260200161012a565b3480156101ce575f80fd5b506101526101dd366004610c82565b610444565b3480156101ed575f80fd5b506003546101fb9060ff1681565b60405160ff909116815260200161012a565b348015610218575f80fd5b50610152610227366004610c5a565b610494565b348015610237575f80fd5b50600754610181906001600160a01b031681565b348015610256575f80fd5b506101b5610265366004610cbb565b6001600160a01b03165f9081526004602052604090205490565b34801561028a575f80fd5b506101076104ca565b34801561029e575f80fd5b505f546001600160a01b0316610181565b3480156102ba575f80fd5b5061011d6104dd565b3480156102ce575f80fd5b506101076102dd366004610cdb565b6104ea565b3480156102ed575f80fd5b506101526102fc366004610c5a565b6105e6565b34801561030c575f80fd5b5061015261031b366004610c5a565b61067b565b34801561032b575f80fd5b506101b561033a366004610cfb565b6001600160a01b039182165f90815260056020908152604080832093909416825291909152205490565b34801561036f575f80fd5b5061010761037e366004610d2c565b610687565b34801561038e575f80fd5b5061010761039d366004610cbb565b61076c565b600180546103af90610d43565b80601f01602080910402602001604051908101604052809291908181526020018280546103db90610d43565b80156104265780601f106103fd57610100808354040283529160200191610426565b820191905f5260205f20905b81548152906001019060200180831161040957829003601f168201915b505050505081565b5f61043a3384846107e5565b5060015b92915050565b5f610450848484610909565b6001600160a01b0384165f9081526005602090815260408083203380855292529091205461048a918691610485908690610d8f565b6107e5565b5060019392505050565b335f8181526005602090815260408083206001600160a01b0387168452909152812054909161043a918590610485908690610da2565b6104d2610b4c565b6104db5f610ba5565b565b600280546103af90610d43565b6104f2610b4c565b60065461050a9030906001600160a01b0316846107e5565b60065460405163f305d71960e01b81523060048201819052602482018590525f60448301819052606483015260848201524260a48201526001600160a01b039091169063f305d71990839060c40160606040518083038185885af1158015610574573d5f803e3d5ffd5b50505050506040513d601f19601f820116820180604052508101906105999190610db5565b50506007805460ff60a01b191690555060408051838152602081018390527f38f8a0c92f4c5b0b6877f878cb4c0c8d348a47b76d716c8e78f425043df9515b910160405180910390a15050565b335f9081526005602090815260408083206001600160a01b03861684529091528120548281101561066c5760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b60648201526084015b60405180910390fd5b61048a33856104858685610d8f565b5f61043a338484610909565b61068f610b4c565b478111156106df5760405162461bcd60e51b815260206004820152601e60248201527f4e6f7420656e6f7567682045544820696e2074686520636f6e747261637400006044820152606401610663565b6040515f90339083908381818185875af1925050503d805f811461071e576040519150601f19603f3d011682016040523d82523d5f602084013e610723565b606091505b50509050806107685760405162461bcd60e51b815260206004820152601160248201527015da5d1a191c985dd85b0819985a5b1959607a1b6044820152606401610663565b5050565b610774610b4c565b6001600160a01b0381166107d95760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610663565b6107e281610ba5565b50565b6001600160a01b0383166108475760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610663565b6001600160a01b0382166108a85760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610663565b6001600160a01b038381165f8181526005602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b03831661096d5760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b6064820152608401610663565b6001600160a01b0382166109cf5760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b6064820152608401610663565b5f8111610a375760405162461bcd60e51b815260206004820152603060248201527f45524332303a207472616e7366657220616d6f756e74206d757374206265206760448201526f726561746572207468616e207a65726f60801b6064820152608401610663565b6001600160a01b0383165f90815260046020526040902054811115610aad5760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b6064820152608401610663565b6001600160a01b0383165f9081526004602052604081208054839290610ad4908490610d8f565b90915550506001600160a01b0382165f9081526004602052604081208054839290610b00908490610da2565b92505081905550816001600160a01b0316836001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef836040516108fc91815260200190565b5f546001600160a01b031633146104db5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65726044820152606401610663565b5f80546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b5f6020808352835180828501525f5b81811015610c1f57858101830151858201604001528201610c03565b505f604082860101526040601f19601f8301168501019250505092915050565b80356001600160a01b0381168114610c55575f80fd5b919050565b5f8060408385031215610c6b575f80fd5b610c7483610c3f565b946020939093013593505050565b5f805f60608486031215610c94575f80fd5b610c9d84610c3f565b9250610cab60208501610c3f565b9150604084013590509250925092565b5f60208284031215610ccb575f80fd5b610cd482610c3f565b9392505050565b5f8060408385031215610cec575f80fd5b50508035926020909101359150565b5f8060408385031215610d0c575f80fd5b610d1583610c3f565b9150610d2360208401610c3f565b90509250929050565b5f60208284031215610d3c575f80fd5b5035919050565b600181811c90821680610d5757607f821691505b602082108103610d7557634e487b7160e01b5f52602260045260245ffd5b50919050565b634e487b7160e01b5f52601160045260245ffd5b8181038181111561043e5761043e610d7b565b8082018082111561043e5761043e610d7b565b5f805f60608486031215610dc7575f80fd5b835192506020840151915060408401519050925092509256fea2646970667358221220299b37a718d86772b7bc493bbd2533a63f666cd36f7206302564a21fc4b526ef64736f6c63430008140033

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.