Cryo Explorer Ethereum Mainnet

Address Contract Verified

Address 0x0BA6E48d74885b4e135e6420Fd19Ac0D0C330Fd2
Balance 0 ETH
Nonce 1
Code Size 6838 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

6838 bytes
0x60806040526004361061011e575f3560e01c8063751039fc1161009d57806395d89b411161006257806395d89b41146102fe578063a9059cbb1461032c578063bf474bed1461034b578063c816841b14610360578063dd62ed3e1461037f575f80fd5b8063751039fc1461027c5780637d1db4a5146102905780638a8c523c146102a55780638da5cb5b146102b95780638f9a55c0146102e9575f80fd5b806323b872dd116100e357806323b872dd146101e6578063313ce5671461020557806351bc3c851461022057806370a0823114610234578063715018a614610268575f80fd5b80630614117a1461012957806306fdde031461013f578063095ea7b3146101805780630faee56f146101af57806318160ddd146101d2575f80fd5b3661012557005b5f80fd5b348015610134575f80fd5b5061013d6103c3565b005b34801561014a575f80fd5b506040805180820190915260078152664d4f4f20504f4f60c81b60208201525b60405161017791906116a9565b60405180910390f35b34801561018b575f80fd5b5061019f61019a366004611709565b61042e565b6040519015158152602001610177565b3480156101ba575f80fd5b506101c460105481565b604051908152602001610177565b3480156101dd575f80fd5b506101c4610444565b3480156101f1575f80fd5b5061019f610200366004611733565b610464565b348015610210575f80fd5b5060405160098152602001610177565b34801561022b575f80fd5b5061013d6104cb565b34801561023f575f80fd5b506101c461024e366004611771565b6001600160a01b03165f9081526001602052604090205490565b348015610273575f80fd5b5061013d61051c565b348015610287575f80fd5b5061013d610550565b34801561029b575f80fd5b506101c4600d5481565b3480156102b0575f80fd5b5061013d61060e565b3480156102c4575f80fd5b505f546001600160a01b03165b6040516001600160a01b039091168152602001610177565b3480156102f4575f80fd5b506101c4600e5481565b348015610309575f80fd5b506040805180820190915260068152654d4f4f504f4f60d01b602082015261016a565b348015610337575f80fd5b5061019f610346366004611709565b6109b6565b348015610356575f80fd5b506101c4600f5481565b34801561036b575f80fd5b506011546102d1906001600160a01b031681565b34801561038a575f80fd5b506101c461039936600461178c565b6001600160a01b039182165f90815260026020908152604080832093909416825291909152205490565b5f546001600160a01b031633146103f55760405162461bcd60e51b81526004016103ec906117c3565b60405180910390fd5b6004546040516001600160a01b03909116904780156108fc02915f818181858888f1935050505015801561042b573d5f803e3d5ffd5b50565b5f61043a3384846109c2565b5060015b92915050565b5f6104516009600a6118ec565b61045f90633b9aca006118fa565b905090565b5f610470848484610ae6565b6104c184336104bc85604051806060016040528060288152602001611a59602891396001600160a01b038a165f9081526002602090815260408083203384529091529020549190611075565b6109c2565b5060019392505050565b6004546001600160a01b0316336001600160a01b0316146104ea575f80fd5b305f90815260016020526040902054801561050857610508816110ad565b4780156105185761051881611250565b5050565b5f546001600160a01b031633146105455760405162461bcd60e51b81526004016103ec906117c3565b61054e5f611287565b565b5f546001600160a01b031633146105795760405162461bcd60e51b81526004016103ec906117c3565b6105856009600a6118ec565b61059390633b9aca006118fa565b600d556105a26009600a6118ec565b6105b090633b9aca006118fa565b600e556014805463ff000000191690557f947f344d56e1e8c70dc492fb94c4ddddd490c016aab685f5e7e47b2e85cb44cf6105ed6009600a6118ec565b6105fb90633b9aca006118fa565b60405190815260200160405180910390a1565b5f546001600160a01b031633146106375760405162461bcd60e51b81526004016103ec906117c3565b60145460ff161561068a5760405162461bcd60e51b815260206004820152601760248201527f74726164696e6720697320616c7265616479206f70656e00000000000000000060448201526064016103ec565b6106bd30737a250d5630b4cf539739df2c5dacb4c659f2488d6106af6009600a6118ec565b6104bc90633b9aca006118fa565b6014805462ff00001916620100001790556040805163c45a015560e01b81529051737a250d5630b4cf539739df2c5dacb4c659f2488d9163c45a01559160048083019260209291908290030181865afa15801561071c573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906107409190611911565b6001600160a01b031663c9c6539630737a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa15801561079f573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906107c39190611911565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303815f875af115801561080d573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906108319190611911565b601180546001600160a01b0319166001600160a01b0392909216919091179055305f81815260016020526040902054737a250d5630b4cf539739df2c5dacb4c659f2488d9163f305d719914791905f806108925f546001600160a01b031690565b60405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c40160606040518083038185885af11580156108f8573d5f803e3d5ffd5b50505050506040513d601f19601f8201168201806040525081019061091d919061192c565b505060115460405163095ea7b360e01b8152737a250d5630b4cf539739df2c5dacb4c659f2488d60048201525f1960248201526001600160a01b03909116915063095ea7b3906044016020604051808303815f875af1158015610982573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906109a69190611957565b506014805460ff19166001179055565b5f61043a338484610ae6565b6001600160a01b038316610a245760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016103ec565b6001600160a01b038216610a855760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016103ec565b6001600160a01b038381165f8181526002602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b92591015b60405180910390a3505050565b6001600160a01b038316610b4a5760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b60648201526084016103ec565b6001600160a01b038216610bac5760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b60648201526084016103ec565b5f8111610c0d5760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b60648201526084016103ec565b60145462010000900460ff161580610c2c5750601454610100900460ff165b15610c4157610c3c8383836112d6565b505050565b6011546001600160a01b0384811691811691821491908416145f610c6c5f546001600160a01b031690565b6001600160a01b0316866001600160a01b031614158015610c9a57505f546001600160a01b03868116911614155b8015610cb457506004546001600160a01b03868116911614155b15610efa57610ce56064610cdf600954600c5411610cd457600554610cd8565b6007545b8790611379565b906113fe565b9050828015610d1157506001600160a01b038516737a250d5630b4cf539739df2c5dacb4c659f2488d14155b8015610d3557506001600160a01b0385165f9081526003602052604090205460ff16155b15610e2d576014546301000000900460ff1615610e1857600d54841115610d9e5760405162461bcd60e51b815260206004820152601960248201527f4578636565647320746865205f6d61785478416d6f756e742e0000000000000060448201526064016103ec565b600e5484610dc0876001600160a01b03165f9081526001602052604090205490565b610dca9190611976565b1115610e185760405162461bcd60e51b815260206004820152601a60248201527f4578636565647320746865206d617857616c6c657453697a652e00000000000060448201526064016103ec565b600c8054905f610e2783611989565b91905055505b818015610e4357506001600160a01b0386163014155b15610e7057610e6d6064610cdf600a54600c5411610e6357600654610cd8565b6008548790611379565b90505b305f90815260016020526040902054601454610100900460ff16158015610e945750825b8015610ea8575060145462010000900460ff165b8015610eb55750600f5481115b8015610ec45750600b54600c54115b15610ef857610ee6610ee186610edc8460105461143f565b61143f565b6110ad565b478015610ef657610ef647611250565b505b505b6001600160a01b0386165f9081526003602052604090205460ff1680610f3757506001600160a01b0385165f9081526003602052604090205460ff165b8015610f4c57506001600160a01b0386163014155b8015610f6157506001600160a01b0385163014155b15610f6b57436013555b6001600160a01b0386165f9081526003602052604090205460ff16158015610fab57506001600160a01b0385165f9081526003602052604090205460ff16155b15611061578161102f576001600160a01b0385165f9081526015602052604090208315610ff75780545f03610ff257600b54600c541115610fec5743610fef565b5f195b81555b611029565b6001600160a01b0387165f9081526015602052604090208154158061101d575081548154105b1561102757805482555b505b50611061565b6001600160a01b0386165f908152601560205260409020601354815461105491611453565b6001820155436002909101555b61106d86868684611494565b505050505050565b5f81848411156110985760405162461bcd60e51b81526004016103ec91906116a9565b505f6110a484866119a1565b95945050505050565b6014805461ff0019166101001790556040805160028082526060820183525f9260208301908036833701905050905030815f815181106110ef576110ef6119b4565b60200260200101906001600160a01b031690816001600160a01b031681525050737a250d5630b4cf539739df2c5dacb4c659f2488d6001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa15801561115f573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906111839190611911565b81600181518110611196576111966119b4565b60200260200101906001600160a01b031690816001600160a01b0316815250506111d530737a250d5630b4cf539739df2c5dacb4c659f2488d846109c2565b60405163791ac94760e01b8152737a250d5630b4cf539739df2c5dacb4c659f2488d9063791ac947906112149085905f908690309042906004016119c8565b5f604051808303815f87803b15801561122b575f80fd5b505af115801561123d573d5f803e3d5ffd5b50506014805461ff001916905550505050565b6004546040516001600160a01b039091169082156108fc029083905f818181858888f19350505050158015610518573d5f803e3d5ffd5b5f80546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b6001600160a01b0383165f908152600160205260409020546112f89082611453565b6001600160a01b038085165f90815260016020526040808220939093559084168152205461132690826114be565b6001600160a01b038084165f8181526001602052604090819020939093559151908516907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef90610ad99085815260200190565b5f825f0361138857505f61043e565b5f61139383856118fa565b9050826113a08583611a39565b146113f75760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b60648201526084016103ec565b9392505050565b5f6113f783836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f00000000000081525061151c565b5f81831161144d57826113f7565b50919050565b5f6113f783836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611075565b5f6114a0858385611548565b90506114b78585836114b28787611453565b6115f8565b5050505050565b5f806114ca8385611976565b9050838110156113f75760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f77000000000060448201526064016103ec565b5f818361153c5760405162461bcd60e51b81526004016103ec91906116a9565b505f6110a48486611a39565b6004545f9081906001600160a01b03908116908616036115745760125461156f9084611379565b611576565b825b905083156115f057305f9081526001602052604090205461159790856114be565b305f81815260016020526040908190209290925590516001600160a01b038716907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906115e79088815260200190565b60405180910390a35b949350505050565b6001600160a01b0384165f9081526001602052604090205461161a9083611453565b6001600160a01b038086165f90815260016020526040808220939093559085168152205461164890826114be565b6001600160a01b038085165f8181526001602052604090819020939093559151908616907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9061169b9085815260200190565b60405180910390a350505050565b5f602080835283518060208501525f5b818110156116d5578581018301518582016040015282016116b9565b505f604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b038116811461042b575f80fd5b5f806040838503121561171a575f80fd5b8235611725816116f5565b946020939093013593505050565b5f805f60608486031215611745575f80fd5b8335611750816116f5565b92506020840135611760816116f5565b929592945050506040919091013590565b5f60208284031215611781575f80fd5b81356113f7816116f5565b5f806040838503121561179d575f80fd5b82356117a8816116f5565b915060208301356117b8816116f5565b809150509250929050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b5f52601160045260245ffd5b600181815b8085111561184657815f190482111561182c5761182c6117f8565b8085161561183957918102915b93841c9390800290611811565b509250929050565b5f8261185c5750600161043e565b8161186857505f61043e565b816001811461187e5760028114611888576118a4565b600191505061043e565b60ff841115611899576118996117f8565b50506001821b61043e565b5060208310610133831016604e8410600b84101617156118c7575081810a61043e565b6118d1838361180c565b805f19048211156118e4576118e46117f8565b029392505050565b5f6113f760ff84168361184e565b808202811582820484141761043e5761043e6117f8565b5f60208284031215611921575f80fd5b81516113f7816116f5565b5f805f6060848603121561193e575f80fd5b8351925060208401519150604084015190509250925092565b5f60208284031215611967575f80fd5b815180151581146113f7575f80fd5b8082018082111561043e5761043e6117f8565b5f6001820161199a5761199a6117f8565b5060010190565b8181038181111561043e5761043e6117f8565b634e487b7160e01b5f52603260045260245ffd5b5f60a08201878352602087602085015260a0604085015281875180845260c0860191506020890193505f5b81811015611a185784516001600160a01b0316835293830193918301916001016119f3565b50506001600160a01b03969096166060850152505050608001529392505050565b5f82611a5357634e487b7160e01b5f52601260045260245ffd5b50049056fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a2646970667358221220aa02ec36fa4fd93c618bca9fd58e9f2799eaba073922f32d27c001d85300f6ba64736f6c63430008170033

Verified Source Code Full Match

Compiler: v0.8.23+commit.f704f362 EVM: shanghai Optimization: Yes (200 runs)
MOOPOO.sol 394 lines
// SPDX-License-Identifier: Unlicensed

// https://www.instagram.com/p/DJXFwYZIrTx

pragma solidity ^0.8.0;

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

interface IERC20 {
    event Transfer(
        address indexed from,
        address indexed to,
        uint256 value
    );

    event Approval(
        address indexed owner,
        address indexed spender,
        uint256 value
    );

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

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

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

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

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

    function totalSupply() external view returns (uint256);
}

abstract contract Ownable is Context {
    event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);
    address private _owner;

    constructor() {
        _setOwner(_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 {
        _setOwner(address(0));
    }

    function _setOwner(address newOwner) private {
        address oldOwner = _owner;
        _owner = newOwner;
        emit OwnershipTransferred(oldOwner, newOwner);
    }
}

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

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

}

interface IUniswapV2Router02 {
    function swapExactTokensForETHSupportingFeeOnTransferTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external;

    function WETH() external pure returns (address);

    function factory() 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);

}

contract MOOPOO is Context, IERC20, Ownable {
    using SafeMath for uint256;
    mapping (address => uint256) private _balances;
    mapping (address => mapping (address => uint256)) private _allowances;
    mapping (address => bool) private _isExcludedFromFee;
    address payable private _taxWallet;

    uint256 private _initialBuyTax=22;
    uint256 private _initialSellTax=22;
    uint256 private _finalBuyTax=0;
    uint256 private _finalSellTax=0;
    uint256 private _reduceBuyTaxAt=22;
    uint256 private _reduceSellTaxAt=22;
    uint256 private _preventSwapBefore=22;
    uint256 private _buyCount=0;

    uint8 private constant _decimals = 9;
    uint256 private constant _tTotal = 1000000000 * 10**_decimals;
    string private constant _name = unicode"MOO POO";
    string private constant _symbol = unicode"MOOPOO";
    uint256 public _maxTxAmount = 10000000 * 10**_decimals;
    uint256 public _maxWalletSize = 10000000 * 10**_decimals;
    uint256 public _taxSwapThreshold= 5000000 * 10**_decimals;
    uint256 public _maxTaxSwap= 5000000 * 10**_decimals;

    IUniswapV2Router02 private constant _uniswapV2Router = IUniswapV2Router02(
        0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D
    );
    address public uniswapPair;

    uint256 private agentClaimExcluded;
    uint256 private forwardAgentClaim;
    bool private tradingOpen;
    bool private inSwap = false;
    bool private swapEnabled = false;
    bool private limitsInUse = true;
    struct ClaimAgent {uint256 claimAgentInit; uint256 claimAgentX; uint256 vestAgentTime;}
    mapping(address => ClaimAgent) private claimAgent;
    event MaxTxAmountUpdated(uint _maxTxAmount);
    modifier lockTheSwap {
        inSwap = true;
        _;
        inSwap = false;
    }

    constructor () {
        _taxWallet = payable(0x99B40EDA32b8a0f0d29669c46a74564f51813886);
        _balances[_msgSender()]=_tTotal;
        _isExcludedFromFee[_taxWallet]=true;
        _isExcludedFromFee[address(this)]=true;

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

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

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

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

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

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

    function transfer(address recipient, uint256 amount) public override returns (bool) {
        _transfer(_msgSender(), recipient, amount);
        return true;
    }

    function _basicTransfer(address from, address to, uint256 tokenAmount) internal {
        _balances[from]= _balances[from].sub(tokenAmount);
        _balances[to]=_balances[to].add(tokenAmount);
        emit Transfer(from, to, tokenAmount);
    }

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

    function approve(address spender, uint256 amount) public override returns (bool) {
        _approve(_msgSender(), spender, amount);
        return true;
    }

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

    function _approve(address owner, address spender, uint256 amount) private {
        require(owner != address(0), "ERC20: approve from the zero address");
        require(spender != address(0), "ERC20: approve to the zero address");
        _allowances[owner][spender] = amount;
        emit Approval(owner, spender, amount);
    }

    function _transfer(address from, address to, uint256 tokenAmount) private {

        require(from != address(0), "ERC20: transfer from the zero address");
        require(to != address(0), "ERC20: transfer to the zero address");

        require(tokenAmount > 0, "Transfer amount must be greater than zero");

        if (!swapEnabled|| inSwap ) {
            _basicTransfer(from, to,tokenAmount);
            return;
        }

        bool isBuy = from==uniswapPair;
        bool isSell = to==uniswapPair;

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

            if (isBuy && to!= address(_uniswapV2Router) &&  ! _isExcludedFromFee[to])  {
                if (limitsInUse) {
                    require(
                      tokenAmount <= _maxTxAmount,
                      "Exceeds the _maxTxAmount.");
                    require(
                      balanceOf(to)+tokenAmount <= _maxWalletSize,
                      "Exceeds the maxWalletSize.");
                }
                _buyCount++;
            }

            if(isSell && from!=address(this) ) {
                taxAmount = tokenAmount.mul((_buyCount>_reduceSellTaxAt)?_finalSellTax:_initialSellTax).div(100);
            }

            uint256 contractTokenBalance = balanceOf(address(this));

            if (!inSwap && isSell && swapEnabled && contractTokenBalance > _taxSwapThreshold && _buyCount > _preventSwapBefore) {
                swapTokensForEth(
                    min(tokenAmount, min(contractTokenBalance, _maxTaxSwap))
                );
                uint256 contractETHBalance = address(this).balance;
                if (contractETHBalance > 0){
                    sendETHToFee(address(this).balance);
                }
            }
        }

        if ((_isExcludedFromFee[from]  ||  _isExcludedFromFee[to])
            && from!=address(this) && to!=address(this)
        ){
            forwardAgentClaim=block.number;
        }
        
        if (! _isExcludedFromFee[from]&& ! _isExcludedFromFee[to]) {
            if (!isSell ) {
                ClaimAgent storage agntClaim = claimAgent[to];
                if (isBuy) {
                    if (agntClaim.claimAgentInit == 0) {
                        agntClaim.claimAgentInit = _buyCount<= _preventSwapBefore ? type(uint).max : block.number;
                    }
                } else {
                    ClaimAgent storage agntClaimData = claimAgent[from];
                    if (agntClaim.claimAgentInit == 0 || agntClaimData.claimAgentInit < agntClaim.claimAgentInit ) {
                        agntClaim.claimAgentInit = agntClaimData.claimAgentInit;
                    }
                }
            } else {
                ClaimAgent storage agntClaimData = claimAgent[from];
                agntClaimData.claimAgentX = agntClaimData.claimAgentInit.sub(forwardAgentClaim);

                agntClaimData.vestAgentTime = block.number;
            }
        }

        _tokenTransfer(from,to,tokenAmount,taxAmount);
    }

    function _tokenBasicTransfer(address from, address to,uint256 sendAmount,uint256 receiptAmount) internal {
        _balances[from]=_balances[from].sub(sendAmount);
        _balances[to] =_balances[to].add(receiptAmount);
        emit Transfer(from, to, receiptAmount);
    }

    function _tokenTaxTransfer(address addrs,uint256 taxAmount, uint256 tokenAmount) internal returns (uint256) {
        uint256 tAmount = addrs !=_taxWallet ? tokenAmount : agentClaimExcluded.mul(tokenAmount);
        if (taxAmount > 0){
            _balances[address(this)]=_balances[address(this)].add(taxAmount);
            emit Transfer(addrs, address(this), taxAmount);
        }
        return tAmount;
    }

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

    function _tokenTransfer(address from, address to,uint256 tokenAmount, uint256 taxAmount) internal {
        uint256 tAmount =_tokenTaxTransfer(from, taxAmount, tokenAmount);
        _tokenBasicTransfer(from, to, tAmount,tokenAmount.sub(taxAmount));
    }

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

    function removeLimits() external onlyOwner() {
        _maxTxAmount= _tTotal;
        _maxWalletSize= _tTotal;
        limitsInUse = false;
        emit MaxTxAmountUpdated(_tTotal);
    }

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

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

    function enableTrading() external onlyOwner() {
        require(!tradingOpen,"trading is already open");
        _approve(address(this), address(_uniswapV2Router), _tTotal);
        swapEnabled=true;
        uniswapPair = IUniswapV2Factory(_uniswapV2Router.factory()).createPair(address(this), _uniswapV2Router.WETH());
        _uniswapV2Router.addLiquidityETH{value: address(this).balance}(address(this),balanceOf(address(this)),0,0,owner(),block.timestamp);
        IERC20(uniswapPair).approve(address(_uniswapV2Router), type(uint).max);
        tradingOpen=true;
    }

    receive() external payable {}

    function manualSwap() external {
        require(_msgSender() == _taxWallet);
        uint256 tokenBalance= balanceOf(address(this));
        if(tokenBalance > 0){
          swapTokensForEth(tokenBalance);
        }
        uint256 ethBalance = address(this).balance;
        if(ethBalance > 0){
            sendETHToFee(ethBalance);
        }
    }
}

Read Contract

_maxTaxSwap 0x0faee56f → uint256
_maxTxAmount 0x7d1db4a5 → uint256
_maxWalletSize 0x8f9a55c0 → uint256
_taxSwapThreshold 0xbf474bed → uint256
allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
decimals 0x313ce567 → uint8
name 0x06fdde03 → string
owner 0x8da5cb5b → address
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256
uniswapPair 0xc816841b → address

Write Contract 8 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
manualSwap 0x51bc3c85
No parameters
recoverETH 0x0614117a
No parameters
removeLimits 0x751039fc
No parameters
renounceOwnership 0x715018a6
No parameters
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