Forkchoice Ethereum Mainnet

Address Contract Partially Verified

Address 0x85BBCA2a7B2F85C4aBdc6a91e21137226Eb33C54
Balance 0 ETH
Nonce 1
Code Size 7877 bytes
Indexed Transactions 0 (1 on-chain, 1.6% indexed)
External Etherscan · Sourcify

Contract Bytecode

7877 bytes
Copy Bytecode
0x6080604052600436106102295760003560e01c80637571336a11610123578063bbc0c742116100ab578063e2f456051161006f578063e2f4560514610671578063eba4c33314610687578063ee40166e146106a7578063f2fde38b146106bd578063fb002c97146106dd57600080fd5b8063bbc0c742146105bb578063c0246668146105d5578063d257b34f146105f5578063d85ba06314610615578063dd62ed3e1461062b57600080fd5b80639a7a23d6116100f25780639a7a23d614610515578063a457c2d714610535578063a62068ce14610555578063a9059cbb1461056b578063b62496f51461058b57600080fd5b80637571336a146104ad5780638a8c523c146104cd5780638da5cb5b146104e257806395d89b411461050057600080fd5b8063499b8394116101b15780636a486a8e116101755780636a486a8e1461040d5780636ddd17131461042357806370a0823114610442578063715018a61461047857806371fc46881461048d57600080fd5b8063499b8394146103935780634f77f6c0146103b557806351f205e4146103cb57806358a6d531146103e05780635a139dd4146103f757600080fd5b806318160ddd116101f857806318160ddd146102f857806323b872dd14610317578063313ce567146103375780633950935114610353578063452ed4f11461037357600080fd5b806306fdde03146102355780630758d92414610260578063095ea7b31461029857806310d5de53146102c857600080fd5b3661023057005b600080fd5b34801561024157600080fd5b5061024a6106f3565b6040516102579190611aee565b60405180910390f35b34801561026c57600080fd5b50600654610280906001600160a01b031681565b6040516001600160a01b039091168152602001610257565b3480156102a457600080fd5b506102b86102b3366004611b58565b610785565b6040519015158152602001610257565b3480156102d457600080fd5b506102b86102e3366004611b84565b60136020526000908152604090205460ff1681565b34801561030457600080fd5b506002545b604051908152602001610257565b34801561032357600080fd5b506102b8610332366004611ba8565b61079b565b34801561034357600080fd5b5060405160128152602001610257565b34801561035f57600080fd5b506102b861036e366004611b58565b61084a565b34801561037f57600080fd5b50600754610280906001600160a01b031681565b34801561039f57600080fd5b506103b36103ae366004611b84565b610886565b005b3480156103c157600080fd5b5061030960105481565b3480156103d757600080fd5b506103b3610937565b3480156103ec57600080fd5b50600b5443106102b8565b34801561040357600080fd5b50610309600e5481565b34801561041957600080fd5b50610309600f5481565b34801561042f57600080fd5b50600c546102b890610100900460ff1681565b34801561044e57600080fd5b5061030961045d366004611b84565b6001600160a01b031660009081526020819052604090205490565b34801561048457600080fd5b506103b3610a47565b34801561049957600080fd5b506103b36104a8366004611be9565b610abb565b3480156104b957600080fd5b506103b36104c8366004611c02565b610b43565b3480156104d957600080fd5b506103b3610c0b565b3480156104ee57600080fd5b506005546001600160a01b0316610280565b34801561050c57600080fd5b5061024a610cd6565b34801561052157600080fd5b506103b3610530366004611c02565b610ce5565b34801561054157600080fd5b506102b8610550366004611b58565b610dd9565b34801561056157600080fd5b50610309600b5481565b34801561057757600080fd5b506102b8610586366004611b58565b610e72565b34801561059757600080fd5b506102b86105a6366004611b84565b60146020526000908152604090205460ff1681565b3480156105c757600080fd5b50600c546102b89060ff1681565b3480156105e157600080fd5b506103b36105f0366004611c02565b610e7f565b34801561060157600080fd5b506103b3610610366004611be9565b610f08565b34801561062157600080fd5b50610309600d5481565b34801561063757600080fd5b50610309610646366004611c40565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b34801561067d57600080fd5b5061030960085481565b34801561069357600080fd5b506103b36106a2366004611be9565b611053565b3480156106b357600080fd5b50610309600a5481565b3480156106c957600080fd5b506103b36106d8366004611b84565b6110d8565b3480156106e957600080fd5b5061030960115481565b60606003805461070290611c6e565b80601f016020809104026020016040519081016040528092919081815260200182805461072e90611c6e565b801561077b5780601f106107505761010080835404028352916020019161077b565b820191906000526020600020905b81548152906001019060200180831161075e57829003601f168201915b5050505050905090565b60006107923384846111c3565b50600192915050565b60006107a88484846112e7565b6001600160a01b0384166000908152600160209081526040808320338452909152902054828110156108325760405162461bcd60e51b815260206004820152602860248201527f45524332303a207472616e7366657220616d6f756e74206578636565647320616044820152676c6c6f77616e636560c01b60648201526084015b60405180910390fd5b61083f85338584036111c3565b506001949350505050565b3360008181526001602090815260408083206001600160a01b03871684529091528120549091610792918590610881908690611cbe565b6111c3565b6005546001600160a01b031633146108b05760405162461bcd60e51b815260040161082990611cd6565b6001600160a01b0381166109155760405162461bcd60e51b815260206004820152602660248201527f5f6f7065726174696f6e734164647265737320616464726573732063616e6e6f60448201526507420626520360d41b6064820152608401610829565b600980546001600160a01b0319166001600160a01b0392909216919091179055565b6005546001600160a01b031633146109615760405162461bcd60e51b815260040161082990611cd6565b6008543060009081526020819052604090205410156109ea576040805162461bcd60e51b81526020600482015260248101919091527f43616e206f6e6c792073776170207768656e20746f6b656e20616d6f756e742060448201527f6973206174206f7220686967686572207468616e207265737472696374696f6e6064820152608401610829565b6007805460ff60a01b1916600160a01b179055610a056116fe565b6007805460ff60a01b191690556040514281527f1b56c383f4f48fc992e45667ea4eabae777b9cca68b516a9562d8cda78f1bb329060200160405180910390a1565b6005546001600160a01b03163314610a715760405162461bcd60e51b815260040161082990611cd6565b6005546040516000916001600160a01b0316907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600580546001600160a01b0319169055565b6005546001600160a01b03163314610ae55760405162461bcd60e51b815260040161082990611cd6565b600e819055600d8190556064811115610b405760405162461bcd60e51b815260206004820152601e60248201527f4d757374206b65657020666565732061742031303025206f72206c65737300006044820152606401610829565b50565b6005546001600160a01b03163314610b6d5760405162461bcd60e51b815260040161082990611cd6565b80610be0576007546001600160a01b0390811690831603610be05760405162461bcd60e51b815260206004820152602760248201527f43616e6e6f742072656d6f766520756e697377617020706169722066726f6d2060448201526636b0bc103a3c3760c91b6064820152608401610829565b6001600160a01b03919091166000908152601360205260409020805460ff1916911515919091179055565b6005546001600160a01b03163314610c355760405162461bcd60e51b815260040161082990611cd6565b600c5460ff1615610c885760405162461bcd60e51b815260206004820152601760248201527f43616e6e6f74207265656e61626c652074726164696e670000000000000000006044820152606401610829565b600c805461ffff191661010117905543600a819055610ca8906028611cbe565b600b556040517fa56feb2d31b9a7424db0be063fd450863979c9e2382cf5110f869bd1ad361bb790600090a1565b60606004805461070290611c6e565b6005546001600160a01b03163314610d0f5760405162461bcd60e51b815260040161082990611cd6565b6007546001600160a01b0390811690831603610d935760405162461bcd60e51b815260206004820152603960248201527f54686520706169722063616e6e6f742062652072656d6f7665642066726f6d2060448201527f6175746f6d617465644d61726b65744d616b65725061697273000000000000006064820152608401610829565b610d9d82826117b6565b604051811515906001600160a01b038416907fffa9187bf1f18bf477bd0ea1bcbb64e93b6a98132473929edfce215cd9b16fab90600090a35050565b3360009081526001602090815260408083206001600160a01b038616845290915281205482811015610e5b5760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b6064820152608401610829565b610e6833858584036111c3565b5060019392505050565b60006107923384846112e7565b6005546001600160a01b03163314610ea95760405162461bcd60e51b815260040161082990611cd6565b6001600160a01b038216600081815260126020908152604091829020805460ff191685151590811790915591519182527f9d8f7706ea1113d1a167b526eca956215946dd36cc7df39eb16180222d8b5df7910160405180910390a25050565b6005546001600160a01b03163314610f325760405162461bcd60e51b815260040161082990611cd6565b620186a0610f3f60025490565b610f4a906001611d0b565b610f549190611d2a565b811015610fc15760405162461bcd60e51b815260206004820152603560248201527f5377617020616d6f756e742063616e6e6f74206265206c6f776572207468616e60448201527410181718181892903a37ba30b61039bab838363c9760591b6064820152608401610829565b6103e8610fcd60025490565b610fd8906001611d0b565b610fe29190611d2a565b81111561104e5760405162461bcd60e51b815260206004820152603460248201527f5377617020616d6f756e742063616e6e6f742062652068696768657220746861604482015273371018171892903a37ba30b61039bab838363c9760611b6064820152608401610829565b600855565b6005546001600160a01b0316331461107d5760405162461bcd60e51b815260040161082990611cd6565b6010819055600f8190556064811115610b405760405162461bcd60e51b815260206004820152601e60248201527f4d757374206b65657020666565732061742031303025206f72206c65737300006044820152606401610829565b6005546001600160a01b031633146111025760405162461bcd60e51b815260040161082990611cd6565b6001600160a01b0381166111675760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610829565b6005546040516001600160a01b038084169216907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e090600090a3600580546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b0383166112255760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610829565b6001600160a01b0382166112865760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610829565b6001600160a01b0383811660008181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b03831661130d5760405162461bcd60e51b815260040161082990611d4c565b6001600160a01b0382166113335760405162461bcd60e51b815260040161082990611d91565b600081116113835760405162461bcd60e51b815260206004820152601d60248201527f616d6f756e74206d7573742062652067726561746572207468616e20300000006044820152606401610829565b600c5460ff16611411576001600160a01b03831660009081526012602052604090205460ff16806113cc57506001600160a01b03821660009081526012602052604090205460ff165b6114115760405162461bcd60e51b81526020600482015260166024820152752a3930b234b7339034b9903737ba1030b1ba34bb329760511b6044820152606401610829565b306000908152602081905260409020546008548110801590819061143c5750600c54610100900460ff165b80156114525750600754600160a01b900460ff16155b801561147757506001600160a01b03851660009081526014602052604090205460ff16155b801561149c57506001600160a01b03851660009081526012602052604090205460ff16155b80156114c157506001600160a01b03841660009081526012602052604090205460ff16155b156114ef576007805460ff60a01b1916600160a01b1790556114e16116fe565b6007805460ff60a01b191690555b6001600160a01b03851660009081526012602052604090205460019060ff168061153157506001600160a01b03851660009081526012602052604090205460ff165b1561153a575060005b600081156116ea57600b544310801561156b57506001600160a01b03871660009081526014602052604090205460ff165b801561159057506001600160a01b03861660009081526014602052604090205460ff16155b801561159e57506000600d54115b156115f35760646115b0866014611d0b565b6115ba9190611d2a565b9050600d54600e54826115cd9190611d0b565b6115d79190611d2a565b601160008282546115e89190611cbe565b909155506116cc9050565b6001600160a01b03861660009081526014602052604090205460ff16801561161d57506000600f54115b1561164f576064600f54866116329190611d0b565b61163c9190611d2a565b9050600f54601054826115cd9190611d0b565b6001600160a01b03871660009081526014602052604090205460ff16801561167957506000600d54115b156116cc576064600d548661168e9190611d0b565b6116989190611d2a565b9050600d54600e54826116ab9190611d0b565b6116b59190611d2a565b601160008282546116c69190611cbe565b90915550505b80156116dd576116dd8730836117e4565b6116e78186611dd4565b94505b6116f58787876117e4565b50505050505050565b3060009081526020819052604090205460115481158061171c575080155b15611725575050565b600854611733906014611d0b565b82111561174b57600854611748906014611d0b565b91505b600061175683611939565b600060118190556009546040516001600160a01b039091169147919081818185875af1925050503d80600081146117a9576040519150601f19603f3d011682016040523d82523d6000602084013e6117ae565b606091505b505050505050565b6001600160a01b0382166000908152601460205260409020805460ff1916821515179055610d9d8282611a8b565b6001600160a01b03831661180a5760405162461bcd60e51b815260040161082990611d4c565b6001600160a01b0382166118305760405162461bcd60e51b815260040161082990611d91565b6001600160a01b038316600090815260208190526040902054818110156118a85760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b6064820152608401610829565b6001600160a01b038085166000908152602081905260408082208585039055918516815290812080548492906118df908490611cbe565b92505081905550826001600160a01b0316846001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef8460405161192b91815260200190565b60405180910390a350505050565b604080516002808252606082018352600092602083019080368337019050509050308160008151811061196e5761196e611deb565b6001600160a01b03928316602091820292909201810191909152600654604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa1580156119c7573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906119eb9190611e01565b816001815181106119fe576119fe611deb565b6001600160a01b039283166020918202929092010152600654611a2491309116846111c3565b60065460405163791ac94760e01b81526001600160a01b039091169063791ac94790611a5d908590600090869030904290600401611e1e565b600060405180830381600087803b158015611a7757600080fd5b505af11580156117ae573d6000803e3d6000fd5b6001600160a01b038216600081815260136020908152604091829020805460ff19168515159081179091558251938452908301527f6b4f1be9103e6cbcd38ca4a922334f2c3109b260130a6676a987f94088fd6746910160405180910390a15050565b600060208083528351808285015260005b81811015611b1b57858101830151858201604001528201611aff565b81811115611b2d576000604083870101525b50601f01601f1916929092016040019392505050565b6001600160a01b0381168114610b4057600080fd5b60008060408385031215611b6b57600080fd5b8235611b7681611b43565b946020939093013593505050565b600060208284031215611b9657600080fd5b8135611ba181611b43565b9392505050565b600080600060608486031215611bbd57600080fd5b8335611bc881611b43565b92506020840135611bd881611b43565b929592945050506040919091013590565b600060208284031215611bfb57600080fd5b5035919050565b60008060408385031215611c1557600080fd5b8235611c2081611b43565b915060208301358015158114611c3557600080fd5b809150509250929050565b60008060408385031215611c5357600080fd5b8235611c5e81611b43565b91506020830135611c3581611b43565b600181811c90821680611c8257607f821691505b602082108103611ca257634e487b7160e01b600052602260045260246000fd5b50919050565b634e487b7160e01b600052601160045260246000fd5b60008219821115611cd157611cd1611ca8565b500190565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b6000816000190483118215151615611d2557611d25611ca8565b500290565b600082611d4757634e487b7160e01b600052601260045260246000fd5b500490565b60208082526025908201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604082015264647265737360d81b606082015260800190565b60208082526023908201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260408201526265737360e81b606082015260800190565b600082821015611de657611de6611ca8565b500390565b634e487b7160e01b600052603260045260246000fd5b600060208284031215611e1357600080fd5b8151611ba181611b43565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b81811015611e6e5784516001600160a01b031683529383019391830191600101611e49565b50506001600160a01b0396909616606085015250505060800152939250505056fea264697066735822122008c736084b34938707ae57733570221bbc7f1a2c378dbddd94758a85b1291f0964736f6c634300080f0033

Verified Source Code Partial Match

Compiler: v0.8.15+commit.e14f2714 EVM: london Optimization: Yes (200 runs)
X2.sol 608 lines
/**
 * Website.  : x20.vip
 * Twitter   : twitter.com/x2coineth
 * Telegram. : t.me/x2coineth
 */

// SPDX-License-Identifier: MIT

pragma solidity 0.8.15;

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

    function _msgData() internal view virtual returns (bytes calldata) {
        this; // silence state mutability warning without generating bytecode - see https://github.com/ethereum/solidity/issues/2691
        return msg.data;
    }
}

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

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

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

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

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

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

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

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

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

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

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

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

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

    uint256 private _totalSupply;

    string private _name;
    string private _symbol;

    constructor(string memory name_, string memory symbol_) {
        _name = name_;
        _symbol = symbol_;
    }

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

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

    function decimals() public view virtual override returns (uint8) {
        return 18;
    }

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

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

    function transfer(address recipient, uint256 amount) public virtual override returns (bool) {
        _transfer(_msgSender(), recipient, amount);
        return true;
    }

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

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

    function transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) public virtual override returns (bool) {
        _transfer(sender, recipient, amount);

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

        return true;
    }

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

    function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {
        uint256 currentAllowance = _allowances[_msgSender()][spender];
        require(currentAllowance >= subtractedValue, "ERC20: decreased allowance below zero");
        unchecked {
            _approve(_msgSender(), spender, currentAllowance - subtractedValue);
        }

        return true;
    }

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

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

        emit Transfer(sender, recipient, amount);
    }

    function _createInitialSupply(address account, uint256 amount) internal virtual {
        require(account != address(0), "ERC20: mint to the zero address");

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

    function _burn(address account, uint256 amount) internal virtual {
        require(account != address(0), "ERC20: burn from the zero address");
        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);
    }

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

contract Ownable is Context {
    address private _owner;

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

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

    function renounceOwnership() external 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 IDexRouter {
    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 swapExactETHForTokensSupportingFeeOnTransferTokens(
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external payable;

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

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

contract X2 is ERC20, Ownable {


    IDexRouter public dexRouter;
    address public lpPair;

    bool private swapping;
    uint256 public swapTokensAtAmount;

    address operationsAddress;

    uint256 public tradingActiveBlock = 0; 
    uint256 public blockForPenaltyEnd;

    bool public tradingActive = false;
    bool public swapEnabled = false;


    uint256 public buyTotalFees;
    uint256 public buyOperationsFee;

    uint256 public sellTotalFees;
    uint256 public sellOperationsFee;

    uint256 public tokensForOperations;

    mapping (address => bool) private _isExcludedFromFees;
    mapping (address => bool) public _isExcludedMaxTransactionAmount;


    mapping (address => bool) public automatedMarketMakerPairs;

    event SetAutomatedMarketMakerPair(address indexed pair, bool indexed value);

    event EnabledTrading();

    event RemovedLimits();

    event ExcludeFromFees(address indexed account, bool isExcluded);

    event UpdatedOperationsAddress(address indexed newWallet);

    event MaxTransactionExclusion(address _address, bool excluded);


    event OwnerForcedSwapBack(uint256 timestamp);


    event SwapAndLiquify(
        uint256 tokensSwapped,
        uint256 ethReceived,
        uint256 tokensIntoLiquidity
    );

    constructor() ERC20("X 2.0", "X2.0") {

        address newOwner = msg.sender; // can leave alone if owner is deployer.

        IDexRouter _dexRouter = IDexRouter(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
        dexRouter = _dexRouter;

        // create pair
        lpPair = IDexFactory(_dexRouter.factory()).createPair(address(this), _dexRouter.WETH());
        _excludeFromMaxTransaction(address(lpPair), true);
        _setAutomatedMarketMakerPair(address(lpPair), true);

        uint256 totalSupply = 100000000 * 1e18;

        swapTokensAtAmount = totalSupply * 5 / 10000;

        buyOperationsFee = 3;

        buyTotalFees = buyOperationsFee;

        sellOperationsFee = 3;

        sellTotalFees = sellOperationsFee;

        _excludeFromMaxTransaction(newOwner, true);
        _excludeFromMaxTransaction(address(this), true);
        _excludeFromMaxTransaction(address(0xdead), true);

        excludeFromFees(newOwner, true);
        excludeFromFees(address(this), true);
        excludeFromFees(address(0xdead), true);

        operationsAddress = address(newOwner);

        _createInitialSupply(newOwner, totalSupply);
        transferOwnership(newOwner);
    }

    receive() external payable {}

    // only enable if no plan to airdrop

    function enableTrading() external onlyOwner {
        require(!tradingActive, "Cannot reenable trading");
        tradingActive = true;
        swapEnabled = true;
        tradingActiveBlock = block.number;
        blockForPenaltyEnd = tradingActiveBlock + 40;
        emit EnabledTrading();
    }

    // change the minimum amount of tokens to sell from fees
    function updateSwapTokensAtAmount(uint256 newAmount) external onlyOwner {
        require(newAmount >= totalSupply() * 1 / 100000, "Swap amount cannot be lower than 0.001% total supply.");
        require(newAmount <= totalSupply() * 1 / 1000, "Swap amount cannot be higher than 0.1% total supply.");
        swapTokensAtAmount = newAmount;
    }

    function _excludeFromMaxTransaction(address updAds, bool isExcluded) private {
        _isExcludedMaxTransactionAmount[updAds] = isExcluded;
        emit MaxTransactionExclusion(updAds, isExcluded);
    }


    function excludeFromMaxTransaction(address updAds, bool isEx) external onlyOwner {
        if(!isEx){
            require(updAds != lpPair, "Cannot remove uniswap pair from max txn");
        }
        _isExcludedMaxTransactionAmount[updAds] = isEx;
    }

    function setAutomatedMarketMakerPair(address pair, bool value) external onlyOwner {
        require(pair != lpPair, "The pair cannot be removed from automatedMarketMakerPairs");

        _setAutomatedMarketMakerPair(pair, value);
        emit SetAutomatedMarketMakerPair(pair, value);
    }

    function _setAutomatedMarketMakerPair(address pair, bool value) private {
        automatedMarketMakerPairs[pair] = value;

        _excludeFromMaxTransaction(pair, value);

        emit SetAutomatedMarketMakerPair(pair, value);
    }

    function updateBuyFees(uint256 _operationsFee) external onlyOwner {
        buyOperationsFee = _operationsFee;
        buyTotalFees = buyOperationsFee;
        require(buyTotalFees <= 100, "Must keep fees at 100% or less");
    }

    function updateSellFees(uint256 _operationsFee) external onlyOwner {
        sellOperationsFee = _operationsFee;
        sellTotalFees = sellOperationsFee;
        require(sellTotalFees <= 100, "Must keep fees at 100% or less");
    }


    function excludeFromFees(address account, bool excluded) public onlyOwner {
        _isExcludedFromFees[account] = excluded;
        emit ExcludeFromFees(account, excluded);
    }

    function _transfer(address from, address to, uint256 amount) internal override {

        require(from != address(0), "ERC20: transfer from the zero address");
        require(to != address(0), "ERC20: transfer to the zero address");
        require(amount > 0, "amount must be greater than 0");

        if(!tradingActive){
            require(_isExcludedFromFees[from] || _isExcludedFromFees[to], "Trading is not active.");
        }

        uint256 contractTokenBalance = balanceOf(address(this));

        bool canSwap = contractTokenBalance >= swapTokensAtAmount;

        if(canSwap && swapEnabled && !swapping && !automatedMarketMakerPairs[from] && !_isExcludedFromFees[from] && !_isExcludedFromFees[to]) {
            swapping = true;

            swapBack();

            swapping = false;
        }

        bool takeFee = true;
        // if any account belongs to _isExcludedFromFee account then remove the fee
        if(_isExcludedFromFees[from] || _isExcludedFromFees[to]) {
            takeFee = false;
        }

        uint256 fees = 0;
        // only take fees on buys/sells, do not take on wallet transfers
        if(takeFee){
            if(earlyBuyPenaltyInEffect() && automatedMarketMakerPairs[from] && !automatedMarketMakerPairs[to] && buyTotalFees > 0){
                fees = amount * 20 / 100;
                tokensForOperations += fees * buyOperationsFee / buyTotalFees;
            }

            // on sell
            else if (automatedMarketMakerPairs[to] && sellTotalFees > 0){
                fees = amount * sellTotalFees / 100;
                tokensForOperations += fees * sellOperationsFee / sellTotalFees;
            }

            // on buy
            else if(automatedMarketMakerPairs[from] && buyTotalFees > 0) {
                fees = amount * buyTotalFees / 100;
                tokensForOperations += fees * buyOperationsFee / buyTotalFees;
            }

            if(fees > 0){
                super._transfer(from, address(this), fees);
            }

            amount -= fees;
        }

        super._transfer(from, to, amount);
    }

    function earlyBuyPenaltyInEffect() public view returns (bool){
        return block.number < blockForPenaltyEnd;
    }

    function swapTokensForEth(uint256 tokenAmount) private {

        // generate the uniswap pair path of token -> weth
        address[] memory path = new address[](2);
        path[0] = address(this);
        path[1] = dexRouter.WETH();

        _approve(address(this), address(dexRouter), tokenAmount);

        // make the swap
        dexRouter.swapExactTokensForETHSupportingFeeOnTransferTokens(
            tokenAmount,
            0, // accept any amount of ETH
            path,
            address(this),
            block.timestamp
        );
    }

    function addLiquidity(uint256 tokenAmount, uint256 ethAmount) private {
        // approve token transfer to cover all possible scenarios
        _approve(address(this), address(dexRouter), tokenAmount);

        // add the liquidity
        dexRouter.addLiquidityETH{value: ethAmount}(
            address(this),
            tokenAmount,
            0, // slippage is unavoidable
            0, // slippage is unavoidable
            address(0xdead),
            block.timestamp
        );
    }

    function swapBack() private {


        uint256 contractBalance = balanceOf(address(this));
        uint256 totalTokensToSwap = tokensForOperations ;

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

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

        bool success;

        swapTokensForEth(contractBalance);
        tokensForOperations = 0;

        (success,) = address(operationsAddress).call{value: address(this).balance}("");
    }

    function setOperationsAddress(address _operationsAddress) external onlyOwner {
        require(_operationsAddress != address(0), "_operationsAddress address cannot be 0");
        operationsAddress = payable(_operationsAddress);
    }


    function forceSwapBack() external onlyOwner {
        require(balanceOf(address(this)) >= swapTokensAtAmount, "Can only swap when token amount is at or higher than restriction");
        swapping = true;
        swapBack();
        swapping = false;
        emit OwnerForcedSwapBack(block.timestamp);
    }

}

Read Contract

_isExcludedMaxTransactionAmount 0x10d5de53 → bool
allowance 0xdd62ed3e → uint256
automatedMarketMakerPairs 0xb62496f5 → bool
balanceOf 0x70a08231 → uint256
blockForPenaltyEnd 0xa62068ce → uint256
buyOperationsFee 0x5a139dd4 → uint256
buyTotalFees 0xd85ba063 → uint256
decimals 0x313ce567 → uint8
dexRouter 0x0758d924 → address
earlyBuyPenaltyInEffect 0x58a6d531 → bool
lpPair 0x452ed4f1 → address
name 0x06fdde03 → string
owner 0x8da5cb5b → address
sellOperationsFee 0x4f77f6c0 → uint256
sellTotalFees 0x6a486a8e → uint256
swapEnabled 0x6ddd1713 → bool
swapTokensAtAmount 0xe2f45605 → uint256
symbol 0x95d89b41 → string
tokensForOperations 0xfb002c97 → uint256
totalSupply 0x18160ddd → uint256
tradingActive 0xbbc0c742 → bool
tradingActiveBlock 0xee40166e → uint256

Write Contract 16 functions

These functions modify contract state and require a wallet transaction to execute.

approve 0x095ea7b3
address spender
uint256 amount
returns: bool
decreaseAllowance 0xa457c2d7
address spender
uint256 subtractedValue
returns: bool
enableTrading 0x8a8c523c
No parameters
excludeFromFees 0xc0246668
address account
bool excluded
excludeFromMaxTransaction 0x7571336a
address updAds
bool isEx
forceSwapBack 0x51f205e4
No parameters
increaseAllowance 0x39509351
address spender
uint256 addedValue
returns: bool
renounceOwnership 0x715018a6
No parameters
setAutomatedMarketMakerPair 0x9a7a23d6
address pair
bool value
setOperationsAddress 0x499b8394
address _operationsAddress
transfer 0xa9059cbb
address recipient
uint256 amount
returns: bool
transferFrom 0x23b872dd
address sender
address recipient
uint256 amount
returns: bool
transferOwnership 0xf2fde38b
address newOwner
updateBuyFees 0x71fc4688
uint256 _operationsFee
updateSellFees 0xeba4c333
uint256 _operationsFee
updateSwapTokensAtAmount 0xd257b34f
uint256 newAmount

Recent Transactions

This address has 1 on-chain transactions, but only 1.6% of the chain is indexed. Transactions will appear as indexing progresses. View on Etherscan →