Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0x166958B8A29A49d5E62eD67bf26E5ad739AEf9aF
Balance 0 ETH
Nonce 1
Code Size 4347 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

4347 bytes
0x60806040526004361061011e575f3560e01c8063751039fc1161009d578063a9059cbb11610062578063a9059cbb14610330578063cc1776d31461034f578063dd62ed3e14610364578063f177ff2a146103a8578063f2fde38b146103da575f80fd5b8063751039fc1461028c5780638c0b5e22146102a05780638da5cb5b146102b55780638ea0a979146102e557806395d89b4114610304575f80fd5b806329e7d7cb116100e357806329e7d7cb146101f5578063313ce567146102145780634f7041a51461022f57806370a0823114610244578063715018a614610278575f80fd5b806306fdde0314610129578063095ea7b31461016957806318160ddd1461019857806323b872dd146101c0578063293230b8146101df575f80fd5b3661012557005b5f80fd5b348015610134575f80fd5b50604080518082019091526006815265273aba36b0b760d11b60208201525b6040516101609190610e65565b60405180910390f35b348015610174575f80fd5b50610188610183366004610ecb565b6103f9565b6040519015158152602001610160565b3480156101a3575f80fd5b506b033b2e3c9fd0803ce80000005b604051908152602001610160565b3480156101cb575f80fd5b506101886101da366004610ef3565b61040f565b3480156101ea575f80fd5b506101f361045f565b005b348015610200575f80fd5b506101f361020f366004610f2c565b6104a4565b34801561021f575f80fd5b5060405160128152602001610160565b34801561023a575f80fd5b506101b260055481565b34801561024f575f80fd5b506101b261025e366004610f4c565b6001600160a01b03165f9081526002602052604090205490565b348015610283575f80fd5b506101f3610590565b348015610297575f80fd5b506101f3610601565b3480156102ab575f80fd5b506101b260095481565b3480156102c0575f80fd5b505f546001600160a01b03165b6040516001600160a01b039091168152602001610160565b3480156102f0575f80fd5b506101f36102ff366004610f4c565b61063c565b34801561030f575f80fd5b506040805180820190915260048152634e55545360e01b6020820152610153565b34801561033b575f80fd5b5061018861034a366004610ecb565b610688565b34801561035a575f80fd5b506101b260065481565b34801561036f575f80fd5b506101b261037e366004610f6c565b6001600160a01b039182165f90815260036020908152604080832093909416825291909152205490565b3480156103b3575f80fd5b507f00000000000000000000000042c18e4c5334ad3da1057f86b26e1c691f70a6fe6102cd565b3480156103e5575f80fd5b506101f36103f4366004610f4c565b610694565b5f6104053384846106c9565b5060015b92915050565b5f61041b8484846107ec565b6001600160a01b0384165f90815260036020908152604080832033808552925290912054610455918691610450908690610fb1565b6106c9565b5060019392505050565b5f546001600160a01b031633146104915760405162461bcd60e51b815260040161048890610fc4565b60405180910390fd5b6007805460ff1916600117905543600855565b5f546001600160a01b031633146104cd5760405162461bcd60e51b815260040161048890610fc4565b607882106105295760405162461bcd60e51b815260206004820152602360248201527f43616e6e6f742073657420627579207461782067726561746572207468616e2060448201526231322560e81b6064820152608401610488565b607881106105855760405162461bcd60e51b8152602060048201526024808201527f43616e6e6f74207365742073656c6c207461782067726561746572207468616e6044820152632031322560e01b6064820152608401610488565b600591909155600655565b5f546001600160a01b031633146105b95760405162461bcd60e51b815260040161048890610fc4565b5f80546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a35f80546001600160a01b0319169055565b5f546001600160a01b0316331461062a5760405162461bcd60e51b815260040161048890610fc4565b6b033b2e3c9fd0803ce8000000600955565b5f546001600160a01b031633146106655760405162461bcd60e51b815260040161048890610fc4565b6001600160a01b03165f908152600460205260409020805460ff19166001179055565b5f6104053384846107ec565b5f546001600160a01b031633146106bd5760405162461bcd60e51b815260040161048890610fc4565b6106c681610da7565b50565b6001600160a01b03831661072b5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610488565b6001600160a01b03821661078c5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610488565b6001600160a01b038381165f8181526003602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b0383166108505760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b6064820152608401610488565b633b9aca0081116108965760405162461bcd60e51b815260206004820152601060248201526f135a5b881d1c985b9cd9995c88185b5d60821b6044820152606401610488565b6001600160a01b0383165f9081526004602052604081205460ff16806108d357506001600160a01b0383165f9081526004602052604090205460ff165b156108df57505f610c3c565b60075460ff16158015906108f557506009548211155b61094c5760405162461bcd60e51b815260206004820152602260248201527f4c61756e6368202f204d6178205478416d6f756e74203125206174206c61756e6044820152610c6d60f31b6064820152608401610488565b600754610100900460ff16600103610a0b576001600160a01b0384165f9081526002602052604081208054849290610985908490610fb1565b90915550506001600160a01b0383165f90815260026020526040812080548492906109b1908490610ff9565b92505081905550826001600160a01b0316846001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef846040516109fd91815260200190565b60405180910390a350505050565b7f00000000000000000000000083ae8f202b803b2ad6c77847ffd12da16cce1bb06001600160a01b0316846001600160a01b031603610a4d5750600554610c3c565b7f00000000000000000000000083ae8f202b803b2ad6c77847ffd12da16cce1bb06001600160a01b0316836001600160a01b031603610c3957305f90815260026020526040902054683635c9adc5dea0000081118015610ab55750600754610100900460ff16155b15610c2f576a084595161401484a000000811115610adb57506a084595161401484a0000005b6007805461ff0019166101001790556040805160028082526060820183525f9260208301908036833701905050905030815f81518110610b1d57610b1d61100c565b60200260200101906001600160a01b031690816001600160a01b0316815250507f000000000000000000000000c02aaa39b223fe8d0a0e5c4f27ead9083c756cc281600181518110610b7157610b7161100c565b6001600160a01b03928316602091820292909201015260405163791ac94760e01b81527f0000000000000000000000007a250d5630b4cf539739df2c5dacb4c659f2488d9091169063791ac94790610bf59085905f9086907f00000000000000000000000042c18e4c5334ad3da1057f86b26e1c691f70a6fe904290600401611020565b5f604051808303815f87803b158015610c0c575f80fd5b505af1158015610c1e573d5f803e3d5ffd5b50506007805461ff00191690555050505b5050600654610c3c565b505f5b8015610d7a575f6064610c4f838561108f565b610c5991906110a6565b90505f610c668285610fb1565b6001600160a01b0387165f90815260026020526040812080549293508692909190610c92908490610fb1565b90915550506001600160a01b0385165f9081526002602052604081208054839290610cbe908490610ff9565b9091555050305f9081526002602052604081208054849290610ce1908490610ff9565b909155505060405182815230906001600160a01b038816907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9060200160405180910390a3846001600160a01b0316866001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051610d6b91815260200190565b60405180910390a35050610da1565b6001600160a01b0384165f9081526002602052604081208054849290610985908490610fb1565b50505050565b6001600160a01b038116610e0c5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610488565b5f80546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a35f80546001600160a01b0319166001600160a01b0392909216919091179055565b5f6020808352835180828501525f5b81811015610e9057858101830151858201604001528201610e74565b505f604082860101526040601f19601f8301168501019250505092915050565b80356001600160a01b0381168114610ec6575f80fd5b919050565b5f8060408385031215610edc575f80fd5b610ee583610eb0565b946020939093013593505050565b5f805f60608486031215610f05575f80fd5b610f0e84610eb0565b9250610f1c60208501610eb0565b9150604084013590509250925092565b5f8060408385031215610f3d575f80fd5b50508035926020909101359150565b5f60208284031215610f5c575f80fd5b610f6582610eb0565b9392505050565b5f8060408385031215610f7d575f80fd5b610f8683610eb0565b9150610f9460208401610eb0565b90509250929050565b634e487b7160e01b5f52601160045260245ffd5b8181038181111561040957610409610f9d565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b8082018082111561040957610409610f9d565b634e487b7160e01b5f52603260045260245ffd5b5f60a082018783526020878185015260a0604085015281875180845260c08601915082890193505f5b8181101561106e5784516001600160a01b031683529383019391830191600101611049565b50506001600160a01b03969096166060850152505050608001529392505050565b808202811582820484141761040957610409610f9d565b5f826110c057634e487b7160e01b5f52601260045260245ffd5b50049056fea26469706673582212206250cea595c57e9b8efaece33590a745d25daba56dba27eca02e91d06319306b64736f6c63430008140033

Verified Source Code Partial Match

Compiler: v0.8.20+commit.a1b79de6 EVM: shanghai Optimization: Yes (200 runs)
Nutman.sol 326 lines
pragma solidity 0.8.20;

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

contract Ownable is Context {
    address private _owner;
    address private _previousOwner;
    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 transferOwnership(address newOwner) public onlyOwner {
        _transferOwnership(newOwner);
    }

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

    function renounceOwnership() public virtual onlyOwner {
        emit OwnershipTransferred(_owner, address(0));
        _owner = address(0);
    }
}

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

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

contract Nutman is Context, IERC20, Ownable {
    string private constant _name = "Nutman";
    string private constant _symbol = "NUTS";
    uint256 private constant _totalSupply = 1_000_000_000e18;
    uint256 private constant onePercent = 10_000_000e18;
    uint256 private constant minSwap = 1_000e18;
    uint8 private constant _decimals = 18;
    mapping(address => uint256) private _balance;
    mapping(address => mapping(address => uint256)) private _allowances;
    mapping(address => bool) private _isExcludedFromFeeWallet;

    IUniswapV2Router02 immutable uniswapV2Router;
    address immutable uniswapV2Pair;
    address immutable WETH;
    address payable immutable marketingWallet;

    uint256 public buyTax;
    uint256 public sellTax;

    uint8 private launch;
    uint8 private inSwapAndLiquify;

    uint256 private launchBlock;
    uint256 public maxTxAmount = onePercent * 2; //max Tx for first mins after launch



    constructor() {
        uniswapV2Router = IUniswapV2Router02(
            0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D
        );
        WETH = uniswapV2Router.WETH();
        buyTax = 0;
        sellTax = 0;

        uniswapV2Pair = IUniswapV2Factory(uniswapV2Router.factory()).createPair(
            address(this),
            WETH
        );

        marketingWallet = payable(msg.sender);
        _balance[msg.sender] = _totalSupply;
        _isExcludedFromFeeWallet[marketingWallet] = true;
        _isExcludedFromFeeWallet[msg.sender] = true;
        _isExcludedFromFeeWallet[address(this)] = true;
        _allowances[address(this)][address(uniswapV2Router)] = type(uint256)
            .max;
        _allowances[msg.sender][address(uniswapV2Router)] = type(uint256).max;
        _allowances[marketingWallet][address(uniswapV2Router)] = type(uint256)
            .max;

        emit Transfer(address(0), _msgSender(), _totalSupply);
    }

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

    function setMarketingWallet() public view returns (address) {
        return marketingWallet;
    }

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

    function balanceOf(address account) public view override returns (uint256) {
        return _balance[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()] - amount
        );
        return true;
    }

    function removeLimits() external onlyOwner {
        maxTxAmount = _totalSupply;
    }

    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 startTrading() external onlyOwner {
        launch = 1;
        launchBlock = block.number;
    }

    function excludeWalletFromFees(address wallet) external onlyOwner {
        _isExcludedFromFeeWallet[wallet] = true;
    }

    function updateFeeAmount(uint256 newBuyTax, uint256 newSellTax) external onlyOwner {
        require(newBuyTax < 120, "Cannot set buy tax greater than 12%");
        require(newSellTax < 120, "Cannot set sell tax greater than 12%");
        buyTax = newBuyTax;
        sellTax = newSellTax;
    }

    function _transfer(
        address from,
        address to,
        uint256 amount
    ) private {
        require(from != address(0), "ERC20: transfer from the zero address");
        require(amount > 1e9, "Min transfer amt");

        uint256 _tax;
        if (_isExcludedFromFeeWallet[from] || _isExcludedFromFeeWallet[to]) {
            _tax = 0;
        } else {
            require(
                launch != 0 && amount <= maxTxAmount,
                "Launch / Max TxAmount 1% at launch"
            );

            if (inSwapAndLiquify == 1) {
                //No tax transfer
                _balance[from] -= amount;
                _balance[to] += amount;

                emit Transfer(from, to, amount);
                return;
            }

            if (from == uniswapV2Pair) {
                _tax = buyTax;
            } else if (to == uniswapV2Pair) {
                uint256 tokensToSwap = _balance[address(this)];
                if (tokensToSwap > minSwap && inSwapAndLiquify == 0) {
                    if (tokensToSwap > onePercent) {
                        tokensToSwap = onePercent;
                    }
                    inSwapAndLiquify = 1;
                    address[] memory path = new address[](2);
                    path[0] = address(this);
                    path[1] = WETH;
                    uniswapV2Router
                        .swapExactTokensForETHSupportingFeeOnTransferTokens(
                            tokensToSwap,
                            0,
                            path,
                            marketingWallet,
                            block.timestamp
                        );
                    inSwapAndLiquify = 0;
                }
                _tax = sellTax;
            } else {
                _tax = 0;
            }
        }

        //Is there tax for sender|receiver?
        if (_tax != 0) {
            //Tax transfer
            uint256 taxTokens = (amount * _tax) / 100;
            uint256 transferAmount = amount - taxTokens;

            _balance[from] -= amount;
            _balance[to] += transferAmount;
            _balance[address(this)] += taxTokens;
            emit Transfer(from, address(this), taxTokens);
            emit Transfer(from, to, transferAmount);
        } else {
            //No tax transfer
            _balance[from] -= amount;
            _balance[to] += amount;

            emit Transfer(from, to, amount);
        }
    }

    receive() external payable {}
}

Read Contract

allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
buyTax 0x4f7041a5 → uint256
decimals 0x313ce567 → uint8
maxTxAmount 0x8c0b5e22 → uint256
name 0x06fdde03 → string
owner 0x8da5cb5b → address
sellTax 0xcc1776d3 → uint256
setMarketingWallet 0xf177ff2a → address
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256

Write Contract 9 functions

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

approve 0x095ea7b3
address spender
uint256 amount
returns: bool
excludeWalletFromFees 0x8ea0a979
address wallet
removeLimits 0x751039fc
No parameters
renounceOwnership 0x715018a6
No parameters
startTrading 0x293230b8
No parameters
transfer 0xa9059cbb
address recipient
uint256 amount
returns: bool
transferFrom 0x23b872dd
address sender
address recipient
uint256 amount
returns: bool
transferOwnership 0xf2fde38b
address newOwner
updateFeeAmount 0x29e7d7cb
uint256 newBuyTax
uint256 newSellTax

Recent Transactions

No transactions found for this address