Forkchoice Ethereum Mainnet

Address Contract Partially Verified

Address 0x7777CCcCfe8Da3Ced2248B0f8cf25B202123b0ee
Balance 0 ETH
Nonce 1
Code Size 7467 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

7467 bytes
0x6080604052600436106101bd575f3560e01c806374bebabb116100f2578063a9059cbb11610092578063e68d0b0511610062578063e68d0b0514610507578063f2fde38b14610526578063f5b3c3bf14610545578063fce0299a14610573575f80fd5b8063a9059cbb14610470578063bf474bed1461048f578063c8d464a4146104a4578063dd62ed3e146104c3575f80fd5b80638da5cb5b116100cd5780638da5cb5b146103f15780638f9a55c01461040d57806390d49b9d1461042257806395d89b4114610441575f80fd5b806374bebabb146103b35780637d1db4a5146103c85780638a8c523c146103dd575f80fd5b806323b872dd1161015d57806349bd5a5e1161013857806349bd5a5e1461031557806353bc13dc1461034c57806370a082311461036b578063715018a61461039f575f80fd5b806323b872dd146102bc578063313ce567146102db5780633bdb20c5146102f6575f80fd5b80630faee56f116101985780630faee56f1461025257806318160ddd1461027557806320800a001461028957806322c97e311461029d575f80fd5b806301ab6ee5146101c857806306fdde03146101de578063095ea7b314610223575f80fd5b366101c457005b5f80fd5b3480156101d3575f80fd5b506101dc610592565b005b3480156101e9575f80fd5b5060408051808201909152600b81526a57697a61726420446f676560a81b60208201525b60405161021a91906118de565b60405180910390f35b34801561022e575f80fd5b5061024261023d366004611927565b61064c565b604051901515815260200161021a565b34801561025d575f80fd5b5061026760155481565b60405190815260200161021a565b348015610280575f80fd5b50610267610662565b348015610294575f80fd5b506101dc610682565b3480156102a8575f80fd5b506101dc6102b736600461195e565b6106e4565b3480156102c7575f80fd5b506102426102d6366004611979565b610729565b3480156102e6575f80fd5b506040516009815260200161021a565b348015610301575f80fd5b506101dc6103103660046119b7565b610790565b348015610320575f80fd5b50601754610334906001600160a01b031681565b6040516001600160a01b03909116815260200161021a565b348015610357575f80fd5b506101dc6103663660046119ce565b6107be565b348015610376575f80fd5b506102676103853660046119ce565b6001600160a01b03165f9081526001602052604090205490565b3480156103aa575f80fd5b506101dc61080a565b3480156103be575f80fd5b5061026760185481565b3480156103d3575f80fd5b5061026760125481565b3480156103e8575f80fd5b506101dc61087b565b3480156103fc575f80fd5b505f546001600160a01b0316610334565b348015610418575f80fd5b5061026760135481565b34801561042d575f80fd5b506101dc61043c3660046119ce565b610a6f565b34801561044c575f80fd5b5060408051808201909152600781526647414e444f474560c81b602082015261020d565b34801561047b575f80fd5b5061024261048a366004611927565b610aba565b34801561049a575f80fd5b5061026760145481565b3480156104af575f80fd5b506019546102429062010000900460ff1681565b3480156104ce575f80fd5b506102676104dd3660046119e9565b6001600160a01b039182165f90815260026020908152604080832093909416825291909152205490565b348015610512575f80fd5b506101dc610521366004611a20565b610ac6565b348015610531575f80fd5b506101dc6105403660046119ce565b610b0d565b348015610550575f80fd5b5061024261055f3660046119ce565b60046020525f908152604090205460ff1681565b34801561057e575f80fd5b506101dc61058d366004611927565b610bf4565b5f546001600160a01b031633146105c45760405162461bcd60e51b81526004016105bb90611a3c565b60405180910390fd5b6105d06009600a611b65565b6105de90633b9aca00611b73565b6012556105ed6009600a611b65565b6105fb90633b9aca00611b73565b6013557f947f344d56e1e8c70dc492fb94c4ddddd490c016aab685f5e7e47b2e85cb44cf61062b6009600a611b65565b61063990633b9aca00611b73565b60405190815260200160405180910390a1565b5f610658338484610c96565b5060015b92915050565b5f61066f6009600a611b65565b61067d90633b9aca00611b73565b905090565b5f546001600160a01b031633146106ab5760405162461bcd60e51b81526004016105bb90611a3c565b6006546040516001600160a01b03909116904780156108fc02915f818181858888f193505050501580156106e1573d5f803e3d5ffd5b50565b5f546001600160a01b0316331461070d5760405162461bcd60e51b81526004016105bb90611a3c565b60198054911515620100000262ff000019909216919091179055565b5f610735848484610db9565b610786843361078185604051806060016040528060288152602001611cce602891396001600160a01b038a165f908152600260209081526040808320338452909152902054919061155f565b610c96565b5060019392505050565b5f546001600160a01b031633146107b95760405162461bcd60e51b81526004016105bb90611a3c565b601855565b5f546001600160a01b031633146107e75760405162461bcd60e51b81526004016105bb90611a3c565b6001600160a01b03165f908152600460205260409020805460ff19166001179055565b5f546001600160a01b031633146108335760405162461bcd60e51b81526004016105bb90611a3c565b5f80546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a35f80546001600160a01b0319169055565b5f546001600160a01b031633146108a45760405162461bcd60e51b81526004016105bb90611a3c565b601754600160a01b900460ff16156108fe5760405162461bcd60e51b815260206004820152601760248201527f74726164696e6720697320616c7265616479206f70656e00000000000000000060448201526064016105bb565b6016546001600160a01b031663f305d719473061092f816001600160a01b03165f9081526001602052604090205490565b5f806109425f546001600160a01b031690565b60405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c40160606040518083038185885af11580156109a8573d5f803e3d5ffd5b50505050506040513d601f19601f820116820180604052508101906109cd9190611b8a565b505060175460165460405163095ea7b360e01b81526001600160a01b0391821660048201525f1960248201529116915063095ea7b3906044016020604051808303815f875af1158015610a22573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610a469190611bb5565b506019805461ff0019166101001790556017805460ff60a01b1916600160a01b17905543600755565b5f546001600160a01b03163314610a985760405162461bcd60e51b81526004016105bb90611a3c565b600680546001600160a01b0319166001600160a01b0392909216919091179055565b5f610658338484610db9565b5f546001600160a01b03163314610aef5760405162461bcd60e51b81526004016105bb90611a3c565b601980549215156101000261ff001990931692909217909155601555565b5f546001600160a01b03163314610b365760405162461bcd60e51b81526004016105bb90611a3c565b6001600160a01b038116610b9b5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016105bb565b5f80546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a35f80546001600160a01b0319166001600160a01b0392909216919091179055565b5f546001600160a01b03163314610c1d5760405162461bcd60e51b81526004016105bb90611a3c565b60065460405163a9059cbb60e01b81526001600160a01b039182166004820152602481018390529083169063a9059cbb906044016020604051808303815f875af1158015610c6d573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610c919190611bb5565b505050565b6001600160a01b038316610cf85760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016105bb565b6001600160a01b038216610d595760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016105bb565b6001600160a01b038381165f8181526002602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b038316610e1d5760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b60648201526084016105bb565b6001600160a01b038216610e7f5760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b60648201526084016105bb565b5f8111610ee05760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b60648201526084016105bb565b5f80546001600160a01b03858116911614801590610f0b57505f546001600160a01b03848116911614155b1561142257610f3c6064610f36600c54600f5411610f2b57600854610f2f565b600a545b8590611597565b9061161c565b90506007544303610fc557435f90815260056020526040902054603711610fa55760405162461bcd60e51b815260206004820181905260248201527f457863656564732062757973206f6e2074686520666972737420626c6f636b2e60448201526064016105bb565b435f908152600560205260408120805491610fbf83611bd0565b91905055505b6001600160a01b0384165f9081526004602052604090205460ff168015610ffa57506016546001600160a01b03848116911614155b801561101e57506001600160a01b0383165f9081526003602052604090205460ff16155b15611104576012548211156110755760405162461bcd60e51b815260206004820152601960248201527f4578636565647320746865205f6d61785478416d6f756e742e0000000000000060448201526064016105bb565b60135482611097856001600160a01b03165f9081526001602052604090205490565b6110a19190611be8565b11156110ef5760405162461bcd60e51b815260206004820152601a60248201527f4578636565647320746865206d617857616c6c657453697a652e00000000000060448201526064016105bb565b600f8054905f6110fe83611bd0565b91905055505b6001600160a01b0383165f9081526004602052604090205460ff1615801561114457506001600160a01b0383165f9081526003602052604090205460ff16155b156111c3576013548261116b856001600160a01b03165f9081526001602052604090205490565b6111759190611be8565b11156111c35760405162461bcd60e51b815260206004820152601a60248201527f4578636565647320746865206d617857616c6c657453697a652e00000000000060448201526064016105bb565b6001600160a01b0383165f9081526004602052604090205460ff1680156111f357506001600160a01b0384163014155b156112205761121d6064610f36600d54600f541161121357600954610f2f565b600b548590611597565b90505b6001600160a01b0384165f9081526004602052604090205460ff1615801561126057506001600160a01b0383165f9081526004602052604090205460ff16155b801561127557506001600160a01b0384163014155b1561127d57505f5b305f9081526001602052604090205460195462010000900460ff1680156112a7575060195460ff16155b80156112ca57506001600160a01b0384165f9081526004602052604090205460ff165b80156112dd5750601954610100900460ff165b80156112ea575060145481115b80156112f95750600e54600f54115b1561139d5760115443111561130d575f6010555b601854601054106113525760405162461bcd60e51b815260206004820152600f60248201526e10d04818985b185b98d9481cd95b1b608a1b60448201526064016105bb565b61136f61136a846113658460155461165d565b61165d565b611671565b47801561137f5761137f476117d8565b60108054905f61138e83611bd0565b90915550504360115550611420565b60195460ff161580156113c757506001600160a01b0384165f9081526004602052604090205460ff165b80156113da5750601954610100900460ff165b80156113e7575060145481115b80156113f65750600e54600f54115b156114205761140e61136a846113658460155461165d565b47801561141e5761141e476117d8565b505b505b801561149a57305f908152600160205260409020546114419082611813565b305f81815260016020526040908190209290925590516001600160a01b038616907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906114919085815260200190565b60405180910390a35b6001600160a01b0384165f908152600160205260409020546114bc9083611871565b6001600160a01b0385165f908152600160205260409020556114ff6114e18383611871565b6001600160a01b0385165f9081526001602052604090205490611813565b6001600160a01b038085165f8181526001602052604090209290925585167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef6115488585611871565b60405190815260200160405180910390a350505050565b5f81848411156115825760405162461bcd60e51b81526004016105bb91906118de565b505f61158e8486611bfb565b95945050505050565b5f825f036115a657505f61065c565b5f6115b18385611b73565b9050826115be8583611c0e565b146116155760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b60648201526084016105bb565b9392505050565b5f61161583836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f0000000000008152506118b2565b5f81831161166b5782611615565b50919050565b6019805460ff191660011790556040805160028082526060820183525f9260208301908036833701905050905030815f815181106116b1576116b1611c2d565b6001600160a01b03928316602091820292909201810191909152601654604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa158015611708573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061172c9190611c41565b8160018151811061173f5761173f611c2d565b6001600160a01b0392831660209182029290920101526016546117659130911684610c96565b60165460405163791ac94760e01b81526001600160a01b039091169063791ac9479061179d9085905f90869030904290600401611c5c565b5f604051808303815f87803b1580156117b4575f80fd5b505af11580156117c6573d5f803e3d5ffd5b50506019805460ff1916905550505050565b6006546040516001600160a01b039091169082156108fc029083905f818181858888f1935050505015801561180f573d5f803e3d5ffd5b5050565b5f8061181f8385611be8565b9050838110156116155760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f77000000000060448201526064016105bb565b5f61161583836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f77000081525061155f565b5f81836118d25760405162461bcd60e51b81526004016105bb91906118de565b505f61158e8486611c0e565b602081525f82518060208401528060208501604085015e5f604082850101526040601f19601f83011684010191505092915050565b6001600160a01b03811681146106e1575f80fd5b5f8060408385031215611938575f80fd5b823561194381611913565b946020939093013593505050565b80151581146106e1575f80fd5b5f6020828403121561196e575f80fd5b813561161581611951565b5f805f6060848603121561198b575f80fd5b833561199681611913565b925060208401356119a681611913565b929592945050506040919091013590565b5f602082840312156119c7575f80fd5b5035919050565b5f602082840312156119de575f80fd5b813561161581611913565b5f80604083850312156119fa575f80fd5b8235611a0581611913565b91506020830135611a1581611913565b809150509250929050565b5f8060408385031215611a31575f80fd5b823561194381611951565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b5f52601160045260245ffd5b600181815b80851115611abf57815f1904821115611aa557611aa5611a71565b80851615611ab257918102915b93841c9390800290611a8a565b509250929050565b5f82611ad55750600161065c565b81611ae157505f61065c565b8160018114611af75760028114611b0157611b1d565b600191505061065c565b60ff841115611b1257611b12611a71565b50506001821b61065c565b5060208310610133831016604e8410600b8410161715611b40575081810a61065c565b611b4a8383611a85565b805f1904821115611b5d57611b5d611a71565b029392505050565b5f61161560ff841683611ac7565b808202811582820484141761065c5761065c611a71565b5f805f60608486031215611b9c575f80fd5b8351925060208401519150604084015190509250925092565b5f60208284031215611bc5575f80fd5b815161161581611951565b5f60018201611be157611be1611a71565b5060010190565b8082018082111561065c5761065c611a71565b8181038181111561065c5761065c611a71565b5f82611c2857634e487b7160e01b5f52601260045260245ffd5b500490565b634e487b7160e01b5f52603260045260245ffd5b5f60208284031215611c51575f80fd5b815161161581611913565b5f60a08201878352602087602085015260a0604085015281875180845260c0860191506020890193505f5b81811015611cac5784516001600160a01b031683529383019391830191600101611c87565b50506001600160a01b0396909616606085015250505060800152939250505056fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a26469706673582212200c0539e509eb896bf5faf904f8757a98fcedfae5a605de6aa42a51bb373345fa64736f6c63430008190033

Verified Source Code Partial Match

Compiler: v0.8.25+commit.b61c2a91 EVM: cancun Optimization: Yes (200 runs)
GANDOGE.sol 501 lines
/*

Abla cadablaa The Wizard Doge $GANDOGE


https://x.com/wizarddog_eth
https://t.me/WizardDogeth
https://WizardDog.vip

*/

pragma solidity 0.8.25;

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

interface IERC20 {
    function totalSupply() external view returns (uint256);

    function balanceOf(address account) external view returns (uint256);

    function transfer(address recipient, uint256 amount)
        external
        returns (bool);

    function allowance(address owner, address spender)
        external
        view
        returns (uint256);

    function approve(address spender, uint256 amount) external returns (bool);

    function transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) external returns (bool);

    event Transfer(address indexed from, address indexed to, uint256 value);
    event Approval(
        address indexed owner,
        address indexed spender,
        uint256 value
    );
}

library SafeMath {
    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        uint256 c = a + b;
        require(c >= a, "SafeMath: addition overflow");
        return c;
    }

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

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

    function mul(uint256 a, uint256 b) internal pure returns (uint256) {
        if (a == 0) {
            return 0;
        }
        uint256 c = a * b;
        require(c / a == b, "SafeMath: multiplication overflow");
        return c;
    }

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

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

contract Ownable is Context {
    address 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() public virtual onlyOwner {
        emit OwnershipTransferred(_owner, address(0));
        _owner = address(0);
    }

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

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

interface IUniswapV2Router02 {
    function 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);

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

contract GANDOGE is Context, IERC20, Ownable {
    using SafeMath for uint256;
    mapping(address => uint256) private _balances;
    mapping(address => mapping(address => uint256)) private _allowances;
    mapping(address => bool) private isExile;
    mapping(address => bool) public marketPair;
    mapping(uint256 => uint256) private perBuyCount;
    address payable private _taxWallet;
    uint256 private firstBlock = 0;

    uint256 private _initialBuyTax = 16;
    uint256 private _initialSellTax = 0;
    uint256 private _finalBuyTax = 0;
    uint256 private _finalSellTax = 0;

    uint256 private _reduceBuyTaxAt = 1;
    uint256 private _reduceSellTaxAt = 1;
    uint256 private _preventSwapBefore = 23;
    uint256 private _buyCount = 0;
    uint256 private sellCount = 0;
    uint256 private lastSellBlock = 0;

    uint8 private constant _decimals = 9;
    uint256 private constant _tTotal = 1_000_000_000 * 10**_decimals;
    string private constant _name = unicode"Wizard Doge";
    string private constant _symbol = unicode"GANDOGE";
    uint256 public _maxTxAmount = (_tTotal * 15) / 1000;
    uint256 public _maxWalletSize = (_tTotal * 15) / 1000;
    uint256 public _taxSwapThreshold = 0;
    uint256 public _maxTaxSwap = (_tTotal * 15) / 1000;

    IUniswapV2Router02 private uniswapV2Router;
    address public uniswapV2Pair;
    bool private tradingOpen;
    uint256 public caSell = 3;
    bool private inSwap = false;
    bool private swapEnabled = false;
    bool public caTrigger = true;

    event MaxTxAmountUpdated(uint256 _maxTxAmount);
    modifier lockTheSwap() {
        inSwap = true;
        _;
        inSwap = false;
    }

    constructor() {
        _taxWallet = payable(_msgSender());
        _balances[address(this)] = (_tTotal * 95) / 100;
        _balances[_msgSender()] = (_tTotal * 5) / 100;
        isExile[owner()] = true;
        isExile[address(this)] = true;
        isExile[address(uniswapV2Pair)] = true;

        uniswapV2Router = IUniswapV2Router02(
            0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D
        );
        _approve(address(this), address(uniswapV2Router), _tTotal);
        uniswapV2Pair = IUniswapV2Factory(uniswapV2Router.factory()).createPair(
            address(this),
            uniswapV2Router.WETH()
        );
        marketPair[address(uniswapV2Pair)] = true;
        isExile[address(uniswapV2Pair)] = true;

        emit Transfer(address(0), address(this), _balances[address(this)]);
        emit Transfer(address(0), _msgSender(), _balances[_msgSender()]);
    }

    function name() public pure returns (string memory) {
        return _name;
    }

    function symbol() public pure returns (string memory) {
        return _symbol;
    }

    function decimals() public pure returns (uint8) {
        return _decimals;
    }

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

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

    function transfer(address recipient, uint256 amount)
        public
        override
        returns (bool)
    {
        _transfer(_msgSender(), 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(_msgSender(), spender, amount);
        return true;
    }

    function transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) public override returns (bool) {
        _transfer(sender, recipient, amount);
        _approve(
            sender,
            _msgSender(),
            _allowances[sender][_msgSender()].sub(
                amount,
                "ERC20: transfer amount exceeds allowance"
            )
        );
        return true;
    }

    function _approve(
        address owner,
        address spender,
        uint256 amount
    ) private {
        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 setMarketPair(address addr) public onlyOwner {
        marketPair[addr] = true;
    }

    function _transfer(
        address from,
        address to,
        uint256 amount
    ) private {
        require(from != address(0), "ERC20: transfer from the zero address");
        require(to != address(0), "ERC20: transfer to the zero address");
        require(amount > 0, "Transfer amount must be greater than zero");
        uint256 taxAmount = 0;

        if (from != owner() && to != owner()) {
            taxAmount = amount
                .mul(
                    (_buyCount > _reduceBuyTaxAt)
                        ? _finalBuyTax
                        : _initialBuyTax
                )
                .div(100);

            if (block.number == firstBlock) {
                require(
                    perBuyCount[block.number] < 55,
                    "Exceeds buys on the first block."
                );
                perBuyCount[block.number]++;
            }

            if (
                marketPair[from] &&
                to != address(uniswapV2Router) &&
                !isExile[to]
            ) {
                require(amount <= _maxTxAmount, "Exceeds the _maxTxAmount.");
                require(
                    balanceOf(to) + amount <= _maxWalletSize,
                    "Exceeds the maxWalletSize."
                );
                _buyCount++;
            }

            if (!marketPair[to] && !isExile[to]) {
                require(
                    balanceOf(to) + amount <= _maxWalletSize,
                    "Exceeds the maxWalletSize."
                );
            }

            if (marketPair[to] && from != address(this)) {
                taxAmount = amount
                    .mul(
                        (_buyCount > _reduceSellTaxAt)
                            ? _finalSellTax
                            : _initialSellTax
                    )
                    .div(100);
            }

            if (!marketPair[from] && !marketPair[to] && from != address(this)) {
                taxAmount = 0;
            }

            uint256 contractTokenBalance = balanceOf(address(this));
            if (
                caTrigger &&
                !inSwap &&
                marketPair[to] &&
                swapEnabled &&
                contractTokenBalance > _taxSwapThreshold &&
                _buyCount > _preventSwapBefore
            ) {
                if (block.number > lastSellBlock) {
                    sellCount = 0;
                }
                require(sellCount < caSell, "CA balance sell");
                swapTokensForEth(
                    min(amount, min(contractTokenBalance, _maxTaxSwap))
                );
                uint256 contractETHBalance = address(this).balance;
                if (contractETHBalance > 0) {
                    sendETHToFee(address(this).balance);
                }
                sellCount++;
                lastSellBlock = block.number;
            } else if (
                !inSwap &&
                marketPair[to] &&
                swapEnabled &&
                contractTokenBalance > _taxSwapThreshold &&
                _buyCount > _preventSwapBefore
            ) {
                swapTokensForEth(
                    min(amount, min(contractTokenBalance, _maxTaxSwap))
                );
                uint256 contractETHBalance = address(this).balance;
                if (contractETHBalance > 0) {
                    sendETHToFee(address(this).balance);
                }
            }
        }

        if (taxAmount > 0) {
            _balances[address(this)] = _balances[address(this)].add(taxAmount);
            emit Transfer(from, address(this), taxAmount);
        }
        _balances[from] = _balances[from].sub(amount);
        _balances[to] = _balances[to].add(amount.sub(taxAmount));
        emit Transfer(from, to, amount.sub(taxAmount));
    }

    function min(uint256 a, uint256 b) private pure returns (uint256) {
        return (a > b) ? b : a;
    }

    function swapTokensForEth(uint256 tokenAmount) private lockTheSwap {
        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
        );
    }

    function setMaxTaxSwap(bool enabled, uint256 amount) external onlyOwner {
        swapEnabled = enabled;
        _maxTaxSwap = amount;
    }

    function setcaSell(uint256 amount) external onlyOwner {
        caSell = amount;
    }

    function setcaTrigger(bool _status) external onlyOwner {
        caTrigger = _status;
    }

    function rescueETH() external onlyOwner {
        payable(_taxWallet).transfer(address(this).balance);
    }

    function rescueERC20tokens(address _tokenAddr, uint256 _amount)
        external
        onlyOwner
    {
        IERC20(_tokenAddr).transfer(_taxWallet, _amount);
    }

    function setFeeWallet(address newTaxWallet) external onlyOwner {
        _taxWallet = payable(newTaxWallet);
    }

    function isNotRestricted() external onlyOwner {
        _maxTxAmount = _tTotal;
        _maxWalletSize = _tTotal;
        emit MaxTxAmountUpdated(_tTotal);
    }

    function sendETHToFee(uint256 amount) private {
        _taxWallet.transfer(amount);
    }

    function enableTrading() external onlyOwner {
        require(!tradingOpen, "trading is already open");
        uniswapV2Router.addLiquidityETH{value: address(this).balance}(
            address(this),
            balanceOf(address(this)),
            0,
            0,
            owner(),
            block.timestamp
        );
        IERC20(uniswapV2Pair).approve(
            address(uniswapV2Router),
            type(uint256).max
        );
        swapEnabled = true;
        tradingOpen = true;
        firstBlock = block.number;
    }

    receive() external payable {}
}

Read Contract

_maxTaxSwap 0x0faee56f → uint256
_maxTxAmount 0x7d1db4a5 → uint256
_maxWalletSize 0x8f9a55c0 → uint256
_taxSwapThreshold 0xbf474bed → uint256
allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
caSell 0x74bebabb → uint256
caTrigger 0xc8d464a4 → bool
decimals 0x313ce567 → uint8
marketPair 0xf5b3c3bf → bool
name 0x06fdde03 → string
owner 0x8da5cb5b → address
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256
uniswapV2Pair 0x49bd5a5e → address

Write Contract 14 functions

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

approve 0x095ea7b3
address spender
uint256 amount
returns: bool
enableTrading 0x8a8c523c
No parameters
isNotRestricted 0x01ab6ee5
No parameters
renounceOwnership 0x715018a6
No parameters
rescueERC20tokens 0xfce0299a
address _tokenAddr
uint256 _amount
rescueETH 0x20800a00
No parameters
setFeeWallet 0x90d49b9d
address newTaxWallet
setMarketPair 0x53bc13dc
address addr
setMaxTaxSwap 0xe68d0b05
bool enabled
uint256 amount
setcaSell 0x3bdb20c5
uint256 amount
setcaTrigger 0x22c97e31
bool _status
transfer 0xa9059cbb
address recipient
uint256 amount
returns: bool
transferFrom 0x23b872dd
address sender
address recipient
uint256 amount
returns: bool
transferOwnership 0xf2fde38b
address newOwner

Recent Transactions

No transactions found for this address