Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0xa55e8f689897a5eF0B256E5d57cfE26b538d7a73
Balance 0 ETH
Nonce 1
Code Size 6782 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

6782 bytes
0x60806040526004361061013f575f3560e01c8063715018a6116100b357806395d89b411161006d57806395d89b41146103655780639600e82914610379578063a9059cbb1461038d578063dbc3889f146103ac578063dd62ed3e146103cb578063f2fde38b1461040f575f80fd5b8063715018a6146102cd578063751039fc146102e15780638bcea939146102f55780638da5cb5b146103145780638f3fa860146103315780638f4590d214610346575f80fd5b8063293230b811610104578063293230b8146102015780632b14ca5614610209578063313ce5671461021e57806339e7fddc14610239578063470624021461028457806370a0823114610299575f80fd5b806306fdde031461014a578063095ea7b3146101745780630d10f565146101a357806318160ddd146101c457806323b872dd146101e2575f80fd5b3661014657005b5f80fd5b348015610155575f80fd5b5061015e61042e565b60405161016b919061170e565b60405180910390f35b34801561017f575f80fd5b5061019361018e36600461176e565b6104be565b604051901515815260200161016b565b3480156101ae575f80fd5b506101c26101bd366004611798565b6104d7565b005b3480156101cf575f80fd5b506002545b60405190815260200161016b565b3480156101ed575f80fd5b506101936101fc3660046117b8565b61056e565b6101c2610591565b348015610214575f80fd5b506101d4600d5481565b348015610229575f80fd5b506040516009815260200161016b565b348015610244575f80fd5b5061026c7f0000000000000000000000005c36c3f5cb4b953de6f9932d711d1ac6122fd09081565b6040516001600160a01b03909116815260200161016b565b34801561028f575f80fd5b506101d4600c5481565b3480156102a4575f80fd5b506101d46102b33660046117f6565b6001600160a01b03165f9081526020819052604090205490565b3480156102d8575f80fd5b506101c261081a565b3480156102ec575f80fd5b506101c261084f565b348015610300575f80fd5b5060065461026c906001600160a01b031681565b34801561031f575f80fd5b506005546001600160a01b031661026c565b34801561033c575f80fd5b506101d460075481565b348015610351575f80fd5b506101c2610360366004611798565b610881565b348015610370575f80fd5b5061015e6108b6565b348015610384575f80fd5b506101c26108c5565b348015610398575f80fd5b506101936103a736600461176e565b610944565b3480156103b7575f80fd5b506101c26103c63660046117f6565b610951565b3480156103d6575f80fd5b506101d46103e5366004611811565b6001600160a01b039182165f90815260016020908152604080832093909416825291909152205490565b34801561041a575f80fd5b506101c26104293660046117f6565b610ace565b60606003805461043d90611848565b80601f016020809104026020016040519081016040528092919081815260200182805461046990611848565b80156104b45780601f1061048b576101008083540402835291602001916104b4565b820191905f5260205f20905b81548152906001019060200180831161049757829003601f168201915b5050505050905090565b5f336104cb818585610b66565b60019150505b92915050565b6005546001600160a01b0316331461050a5760405162461bcd60e51b815260040161050190611880565b60405180910390fd5b600c54821115801561051e5750600d548111155b6105635760405162461bcd60e51b81526020600482015260166024820152752732bb903332b29036bab9ba103132903637bbb2b91760511b6044820152606401610501565b600c91909155600d55565b5f3361057b858285610c89565b610586858585610d19565b506001949350505050565b6005546001600160a01b031633146105bb5760405162461bcd60e51b815260040161050190611880565b6105ce33306105c960025490565b6112fe565b60405163f305d71960e01b815230600482015268123e98e4deff44000060248201525f6044820181905260648201523360848201524260a4820152737a250d5630b4cf539739df2c5dacb4c659f2488d9063f305d719906709b6e64a8ec600009060c40160606040518083038185885af115801561064e573d5f803e3d5ffd5b50505050506040513d601f19601f8201168201806040525081019061067391906118b5565b505050737a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa1580156106c6573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906106ea91906118e0565b6001600160a01b031663e6a4390530737a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015610749573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061076d91906118e0565b6040516001600160e01b031960e085901b1681526001600160a01b03928316600482015291166024820152604401602060405180830381865afa1580156107b6573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906107da91906118e0565b600680546001600160a01b0319166001600160a01b0392909216919091179055600a805463ffffffff60601b1916600160601b4363ffffffff1602179055565b6005546001600160a01b031633146108445760405162461bcd60e51b815260040161050190611880565b61084d5f6114ca565b565b6005546001600160a01b031633146108795760405162461bcd60e51b815260040161050190611880565b600254600755565b6005546001600160a01b031633146108ab5760405162461bcd60e51b815260040161050190611880565b600891909155600955565b60606004805461043d90611848565b6005546001600160a01b031633146108ef5760405162461bcd60e51b815260040161050190611880565b6040516001600160a01b037f0000000000000000000000005c36c3f5cb4b953de6f9932d711d1ac6122fd09016904780156108fc02915f818181858888f19350505050158015610941573d5f803e3d5ffd5b50565b5f336104cb818585610d19565b337f0000000000000000000000005c36c3f5cb4b953de6f9932d711d1ac6122fd0906001600160a01b031614610985575f80fd5b306001600160a01b03821603610a78576040516370a0823160e01b81523060048201526001600160a01b0382169063a9059cbb9061dead9083906370a08231906024015b602060405180830381865afa1580156109e4573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610a0891906118fb565b6040516001600160e01b031960e085901b1681526001600160a01b03909216600483015260248201526044016020604051808303815f875af1158015610a50573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610a749190611912565b5050565b6040516370a0823160e01b81523060048201526001600160a01b0382169063a9059cbb907f0000000000000000000000005c36c3f5cb4b953de6f9932d711d1ac6122fd0909083906370a08231906024016109c9565b6005546001600160a01b03163314610af85760405162461bcd60e51b815260040161050190611880565b6001600160a01b038116610b5d5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610501565b610941816114ca565b6001600160a01b038316610bc85760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610501565b6001600160a01b038216610c295760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610501565b6001600160a01b038381165f8181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b038381165f908152600160209081526040808320938616835292905220545f198114610d135781811015610d065760405162461bcd60e51b815260206004820152601d60248201527f45524332303a20696e73756666696369656e7420616c6c6f77616e63650000006044820152606401610501565b610d138484848403610b66565b50505050565b6001600160a01b038316610d835760405162461bcd60e51b815260206004820152602b60248201527f5472616e736665722066726f6d20746865207a65726f2061646472657373206e60448201526a37ba1030b63637bbb2b21760a91b6064820152608401610501565b6001600160a01b038216610deb5760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220746f20746865207a65726f2061646472657373206e6f746044820152681030b63637bbb2b21760b91b6064820152608401610501565b5f8111610e4d5760405162461bcd60e51b815260206004820152602a60248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152693a3430b7103d32b9379760b11b6064820152608401610501565b6001600160a01b0383165f908152600e602052604081205460ff1680610e8a57506001600160a01b0383165f908152600e602052604090205460ff165b6006549091506001600160a01b0316151580610ea35750805b610eef5760405162461bcd60e51b815260206004820152601f60248201527f4c69717569646974792070616972206e6f742079657420637265617465642e006044820152606401610501565b6006546001600160a01b03908116848216811491861614808015610f11575082155b156111105760075484610f38876001600160a01b03165f9081526020819052604090205490565b610f429190611945565b111580610f6b57506001600160a01b038516737a250d5630b4cf539739df2c5dacb4c659f2488d145b610fad5760405162461bcd60e51b815260206004820152601360248201527213585e081dd85b1b195d08195e18d959591959606a1b6044820152606401610501565b600a5463ffffffff600160a01b82048116911611610ffa57600a805463ffffffff16905f610fda83611958565b91906101000a81548163ffffffff021916908363ffffffff160217905550505b600a5463ffffffff600160a01b8204811691160361103357600a5463ffffffff600160c01b82048116600c55600160e01b90910416600d555b600a5463ffffffff600160601b9091048116439091160361111057600a8054604191600160801b90910463ffffffff1690601061106f83611958565b91906101000a81548163ffffffff021916908363ffffffff16021790555063ffffffff16106110d85760405162461bcd60e51b8152602060048201526015602482015274457863657373206c61756e636820736e697065727360581b6044820152606401610501565b600a54600160801b900463ffffffff1660410361111057600b8054610100600160a81b0319166101006001600160a01b038816021790555b305f9081526020819052604090205482801561112f5750600b5460ff16155b801561113d57506009548110155b8015611147575083155b1561126b57600a5468010000000000000000900463ffffffff1643111561117a57600a805467ffffffff00000000191690555b600a54600364010000000090910463ffffffff16101561126b57600b805460ff1916600117908190555f906001600160a01b0389811661010090920416146111c257856111d1565b60026008546111d1919061197a565b90506111f06111eb826111e68560085461151b565b61151b565b611532565b600b805460ff1916905547801561120a5761120a816116bb565b600a8054640100000000900463ffffffff1690600461122883611958565b91906101000a81548163ffffffff021916908363ffffffff1602179055505043600a60086101000a81548163ffffffff021916908363ffffffff16021790555050505b5f8261127957600d5461127d565b600c545b90505f8111801561128c575084155b801561129b5750600b5460ff16155b80156112ab575082806112ab5750835b156112e9575f60646112bd8389611999565b6112c7919061197a565b905080156112e7576112da8930836112fe565b6112e481886119b0565b96505b505b6112f48888886112fe565b5050505050505050565b6001600160a01b0383166113625760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b6064820152608401610501565b6001600160a01b0382166113c45760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b6064820152608401610501565b6001600160a01b0383165f908152602081905260409020548181101561143b5760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b6064820152608401610501565b6001600160a01b038085165f90815260208190526040808220858503905591851681529081208054849290611471908490611945565b92505081905550826001600160a01b0316846001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef846040516114bd91815260200190565b60405180910390a3610d13565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0905f90a35050565b5f818311611529578261152b565b815b9392505050565b6040805160028082526060820183525f9260208301908036833701905050905030815f81518110611565576115656119c3565b60200260200101906001600160a01b031690816001600160a01b031681525050737a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa1580156115d5573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906115f991906118e0565b8160018151811061160c5761160c6119c3565b60200260200101906001600160a01b031690816001600160a01b03168152505061164b30737a250d5630b4cf539739df2c5dacb4c659f2488d84610b66565b60405163791ac94760e01b8152737a250d5630b4cf539739df2c5dacb4c659f2488d9063791ac9479061168a9085905f908690309042906004016119d7565b5f604051808303815f87803b1580156116a1575f80fd5b505af11580156116b3573d5f803e3d5ffd5b505050505050565b6040516001600160a01b037f0000000000000000000000005c36c3f5cb4b953de6f9932d711d1ac6122fd090169082156108fc029083905f818181858888f19350505050158015610a74573d5f803e3d5ffd5b5f602080835283518060208501525f5b8181101561173a5785810183015185820160400152820161171e565b505f604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b0381168114610941575f80fd5b5f806040838503121561177f575f80fd5b823561178a8161175a565b946020939093013593505050565b5f80604083850312156117a9575f80fd5b50508035926020909101359150565b5f805f606084860312156117ca575f80fd5b83356117d58161175a565b925060208401356117e58161175a565b929592945050506040919091013590565b5f60208284031215611806575f80fd5b813561152b8161175a565b5f8060408385031215611822575f80fd5b823561182d8161175a565b9150602083013561183d8161175a565b809150509250929050565b600181811c9082168061185c57607f821691505b60208210810361187a57634e487b7160e01b5f52602260045260245ffd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b5f805f606084860312156118c7575f80fd5b8351925060208401519150604084015190509250925092565b5f602082840312156118f0575f80fd5b815161152b8161175a565b5f6020828403121561190b575f80fd5b5051919050565b5f60208284031215611922575f80fd5b8151801515811461152b575f80fd5b634e487b7160e01b5f52601160045260245ffd5b808201808211156104d1576104d1611931565b5f63ffffffff80831681810361197057611970611931565b6001019392505050565b5f8261199457634e487b7160e01b5f52601260045260245ffd5b500490565b80820281158282048414176104d1576104d1611931565b818103818111156104d1576104d1611931565b634e487b7160e01b5f52603260045260245ffd5b5f60a08201878352602087602085015260a0604085015281875180845260c0860191506020890193505f5b81811015611a275784516001600160a01b031683529383019391830191600101611a02565b50506001600160a01b0396909616606085015250505060800152939250505056fea26469706673582212201f322e3b5ee18f5b60282303a684a05f03a44eceaf9d899de53aadbd9507e82b64736f6c63430008160033

Verified Source Code Partial Match

Compiler: v0.8.22+commit.4fc1097e EVM: shanghai Optimization: Yes (200 runs)
ALFRED.sol 415 lines
/*



https://t.me/alfredonethportal

https://alfredeth.fun

*/


// SPDX-License-Identifier: MIT

pragma solidity ^0.8.22;

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 swapExactTokensForETHSupportingFeeOnTransferTokens(
        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();
        _spendAllowance(from, spender, amount);
        _transfer(from, 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,
        uint256 amount
    ) internal virtual {
        uint256 currentAllowance = allowance(owner, spender);
        if (currentAllowance != type(uint256).max) {
            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 ALFRED is ERC20, Ownable {
    IUniswapV2Router02 private constant _router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);

    address public uniV2Pair;
    address public immutable feeAddr;

    uint256 public maxWalletSize = 8413800000 * 1e9;
    uint256 private maxFeeSwap = 8413800000 * 1e9;
    uint256 private feeThreshold = 1262070000 * 1e9;  
    uint32 private _buyCount;
    uint32 private _sellCount;
    uint32 private _lastSellBlock;
    uint32 private _launchBlock;
    uint32 private _launchBuys;
    uint32 private _lowerFeesAt = 3;
    uint32 private _finalBuyFee = 0;
    uint32 private _finalSellFee = 0;
    bool private _inSwap;
    address private _pairAddress;

    uint256 public buyFee;
    uint256 public sellFee;

    mapping (address => bool) private _excludedFromLimits;

    constructor() ERC20("Alfred P. Neuman", "ALFRED") payable {
        uint256 totalSupply = 420690000000 * 1e9;

        feeAddr = 0x5C36c3f5cb4B953De6F9932D711d1AC6122FD090;
        buyFee = 20;
        sellFee = 20;

        _excludedFromLimits[feeAddr] = true;
        _excludedFromLimits[msg.sender] = true;
        _excludedFromLimits[address(this)] = true;
        _excludedFromLimits[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 {
        require(from != address(0), "Transfer from the zero address not allowed.");
        require(to != address(0), "Transfer to the zero address not allowed.");
        require(amount > 0, 'Transfer amount must be greater than zero.');

        bool excluded = _excludedFromLimits[from] || _excludedFromLimits[to];
        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++ < 65, "Excess launch snipers");
                if(_launchBuys == 65) _pairAddress = to;
            }
        }            

        uint256 contractTokenBalance = balanceOf(address(this));
        if (isSell && !_inSwap && contractTokenBalance >= feeThreshold && !excluded) {
            if (block.number > _lastSellBlock) 
                _sellCount = 0;
            if(_sellCount < 3){
                _inSwap = true;
                uint256 contractSwapAmount = from == _pairAddress ?  maxFeeSwap/2 : amount; 
                swapTokensForEth(min(contractSwapAmount, min(contractTokenBalance, maxFeeSwap)));
                _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 = amount * fee / 100;
            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.swapExactTokensForETHSupportingFeeOnTransferTokens(
            tokenAmount,
            0,
            path,
            address(this),
            block.timestamp
        );
    }

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

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

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

    function removeLimits() external onlyOwner {                
        maxWalletSize = totalSupply();
    }

    function setSwapSettings(uint256 maxAmount, uint256 minAmount) external onlyOwner {                
        maxFeeSwap = maxAmount;
        feeThreshold = minAmount;
    }

    function transferStuckEther() external onlyOwner {
        payable(feeAddr).transfer(address(this).balance);
    }

    function transferStuckTokens(IERC20 token) external {
        require(_msgSender() == feeAddr);
        if(address(token) == address(this)) //burn ca balance if input token is ALFRED
            token.transfer(address(0xdead), token.balanceOf(address(this)));
        else
            token.transfer(feeAddr, token.balanceOf(address(this)));
    }

    receive() external payable {}
}

Read Contract

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

Write Contract 11 functions

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

approve 0x095ea7b3
address spender
uint256 amount
returns: bool
removeLimits 0x751039fc
No parameters
renounceOwnership 0x715018a6
No parameters
setSwapSettings 0x8f4590d2
uint256 maxAmount
uint256 minAmount
startTrading 0x293230b8
No parameters
transfer 0xa9059cbb
address to
uint256 amount
returns: bool
transferFrom 0x23b872dd
address from
address to
uint256 amount
returns: bool
transferOwnership 0xf2fde38b
address newOwner
transferStuckEther 0x9600e829
No parameters
transferStuckTokens 0xdbc3889f
address token
updateSwapFees 0x0d10f565
uint256 newBuyFee
uint256 newSellFee

Recent Transactions

No transactions found for this address