Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0xdA891AFeB0C9FF9377A05CD91d8EAC1Dd8331CfD
Balance 1.2746 ETH ($2478.08)
Nonce 1
Code Size 6595 bytes
Last Active
Indexed Transactions 6 (24,284,64624,319,641)
Gas Used (indexed) 256,830
External Etherscan · Sourcify

Contract Bytecode

6595 bytes
0x608060405260043610610129575f3560e01c8063751039fc116100a857806395d89b411161006d57806395d89b4114610307578063a9059cbb14610333578063bf474bed14610352578063c9567bf914610367578063dd62ed3e1461037b578063ec1f3f63146103bf575f80fd5b8063751039fc146102845780637d1db4a5146102985780638cd4426d146102ad5780638da5cb5b146102cc5780638f9a55c0146102f2575f80fd5b8063313ce567116100ee578063313ce567146101f757806351bc3c85146102125780636fc3eaec1461022857806370a082311461023c578063715018a614610270575f80fd5b806306fdde0314610134578063095ea7b3146101725780630faee56f146101a157806318160ddd146101c457806323b872dd146101d8575f80fd5b3661013057005b5f80fd5b34801561013f575f80fd5b5060408051808201909152600481526341726f7360e01b60208201525b6040516101699190611589565b60405180910390f35b34801561017d575f80fd5b5061019161018c3660046115f0565b6103de565b6040519015158152602001610169565b3480156101ac575f80fd5b506101b660125481565b604051908152602001610169565b3480156101cf575f80fd5b506101b66103f4565b3480156101e3575f80fd5b506101916101f2366004611618565b610414565b348015610202575f80fd5b5060405160098152602001610169565b34801561021d575f80fd5b5061022661047b565b005b348015610233575f80fd5b50610226610537565b348015610247575f80fd5b506101b6610256366004611651565b6001600160a01b03165f9081526001602052604090205490565b34801561027b575f80fd5b50610226610563565b34801561028f575f80fd5b506102266105dd565b3480156102a3575f80fd5b506101b6600f5481565b3480156102b8575f80fd5b506102266102c73660046115f0565b61068e565b3480156102d7575f80fd5b505f546040516001600160a01b039091168152602001610169565b3480156102fd575f80fd5b506101b660105481565b348015610312575f80fd5b5060408051808201909152600481526341524f5360e01b602082015261015c565b34801561033e575f80fd5b5061019161034d3660046115f0565b6107ae565b34801561035d575f80fd5b506101b660115481565b348015610372575f80fd5b506102266107ba565b348015610386575f80fd5b506101b661039536600461166a565b6001600160a01b039182165f90815260026020908152604080832093909416825291909152205490565b3480156103ca575f80fd5b506102266103d936600461169b565b610a18565b5f6103ea338484610a5d565b5060015b92915050565b5f6104016009600a6117a6565b61040f90633b9aca006117b4565b905090565b5f610420848484610b80565b610471843361046c85604051806060016040528060288152602001611966602891396001600160a01b038a165f90815260026020908152604080832033845290915290205491906111e5565b610a5d565b5060019392505050565b6004546001600160a01b0316336001600160a01b03161461049a575f80fd5b305f9081526001602052604090205480156104b8576104b88161121d565b6005546040516370a0823160e01b81523060048201525f916001600160a01b0316906370a0823190602401602060405180830381865afa1580156104fe573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061052291906117cb565b905080156105335761053381611333565b5050565b6004546001600160a01b0316336001600160a01b031614610556575f80fd5b47610560816113ad565b50565b5f546001600160a01b031633146105955760405162461bcd60e51b815260040161058c906117e2565b60405180910390fd5b5f80546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a35f80546001600160a01b0319169055565b5f546001600160a01b031633146106065760405162461bcd60e51b815260040161058c906117e2565b6106126009600a6117a6565b61062090633b9aca006117b4565b600f5561062f6009600a6117a6565b61063d90633b9aca006117b4565b6010557f947f344d56e1e8c70dc492fb94c4ddddd490c016aab685f5e7e47b2e85cb44cf61066d6009600a6117a6565b61067b90633b9aca006117b4565b60405190815260200160405180910390a1565b6004546001600160a01b0316336001600160a01b0316146106ad575f80fd5b6040516370a0823160e01b81523060048201525f9061072e906064906107289085906001600160a01b038816906370a0823190602401602060405180830381865afa1580156106fe573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061072291906117cb565b906113e4565b90611469565b6004805460405163a9059cbb60e01b81526001600160a01b0391821692810192909252602482018390529192509084169063a9059cbb906044016020604051808303815f875af1158015610784573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906107a89190611817565b50505050565b5f6103ea338484610b80565b5f546001600160a01b031633146107e35760405162461bcd60e51b815260040161058c906117e2565b601454600160a01b900460ff161561083d5760405162461bcd60e51b815260206004820152601760248201527f74726164696e6720697320616c7265616479206f70656e000000000000000000604482015260640161058c565b6013546005546040516370a0823160e01b815230600482018190526001600160a01b039384169363e8e3370093169182906370a0823190602401602060405180830381865afa158015610892573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906108b691906117cb565b305f908152600160205260409020545f806108d85f546001600160a01b031690565b60405160e089901b6001600160e01b03191681526001600160a01b039788166004820152958716602487015260448601949094526064850192909252608484015260a483015290911660c48201524260e4820152610104016060604051808303815f875af115801561094c573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906109709190611836565b505060145460135460405163095ea7b360e01b81526001600160a01b0391821660048201525f1960248201529116915063095ea7b3906044016020604051808303815f875af11580156109c5573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906109e99190611817565b506014805462ff00ff60a01b19166201000160a01b179055600e805463ffffffff19164363ffffffff16179055565b6004546001600160a01b0316336001600160a01b031614610a37575f80fd5b6008548111158015610a4b57506009548111155b610a53575f80fd5b6008819055600955565b6001600160a01b038316610abf5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b606482015260840161058c565b6001600160a01b038216610b205760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b606482015260840161058c565b6001600160a01b038381165f8181526002602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b038316610be45760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b606482015260840161058c565b6001600160a01b038216610c465760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b606482015260840161058c565b5f8111610ca75760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b606482015260840161058c565b5f80546001600160a01b03858116911614801590610cd257505f546001600160a01b03848116911614155b156110a857610cfd6064610728600a54600d5411610cf257600654610cf6565b6008545b85906113e4565b600e5490915063ffffffff9081164390911603610d9f57600e8054603f9164010000000090910463ffffffff16906004610d3683611861565b91906101000a81548163ffffffff021916908363ffffffff16021790555063ffffffff1610610d9f5760405162461bcd60e51b8152602060048201526015602482015274457863657373206c61756e636820736e697065727360581b604482015260640161058c565b6014546001600160a01b038581169116148015610dca57506013546001600160a01b03848116911614155b8015610dee57506001600160a01b0383165f9081526003602052604090205460ff16155b15610ed457600f54821115610e455760405162461bcd60e51b815260206004820152601960248201527f4578636565647320746865205f6d61785478416d6f756e742e00000000000000604482015260640161058c565b60105482610e67856001600160a01b03165f9081526001602052604090205490565b610e719190611883565b1115610ebf5760405162461bcd60e51b815260206004820152601a60248201527f4578636565647320746865206d617857616c6c657453697a652e000000000000604482015260640161058c565b600d8054905f610ece83611896565b91905055505b6014546001600160a01b038481169116148015610efa57506001600160a01b0384163014155b15610f2757610f246064610728600b54600d5411610f1a57600754610cf6565b60095485906113e4565b90505b305f90815260016020526040902054601454600160a81b900460ff16158015610f5d57506014546001600160a01b038581169116145b8015610f725750601454600160b01b900460ff165b8015610f7f575060115481115b8015610f8e5750600c54600d54115b156110a657601654431115610fa2575f6015555b600360155410610ff45760405162461bcd60e51b815260206004820152601760248201527f4f6e6c7920332073656c6c732070657220626c6f636b21000000000000000000604482015260640161058c565b61101161100c84611007846012546114aa565b6114aa565b61121d565b6005546040516370a0823160e01b81523060048201525f916001600160a01b0316906370a0823190602401602060405180830381865afa158015611057573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061107b91906117cb565b9050801561108c5761108c81611333565b60158054905f61109b83611896565b909155505043601655505b505b801561112057305f908152600160205260409020546110c790826114be565b305f81815260016020526040908190209290925590516001600160a01b038616907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906111179085815260200190565b60405180910390a35b6001600160a01b0384165f90815260016020526040902054611142908361151c565b6001600160a01b0385165f90815260016020526040902055611185611167838361151c565b6001600160a01b0385165f90815260016020526040902054906114be565b6001600160a01b038085165f8181526001602052604090209290925585167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef6111ce858561151c565b60405190815260200160405180910390a350505050565b5f81848411156112085760405162461bcd60e51b815260040161058c9190611589565b505f61121484866118ae565b95945050505050565b6014805460ff60a81b1916600160a81b1790556040805160028082526060820183525f9260208301908036833701905050905030815f81518110611263576112636118c1565b6001600160a01b039283166020918202929092010152600554825191169082906001908110611294576112946118c1565b6001600160a01b0392831660209182029290920101526013546112ba9130911684610a5d565b60135460048054604051635c11d79560e01b81526001600160a01b0393841693635c11d795936112f59388935f9389939216914291016118d5565b5f604051808303815f87803b15801561130c575f80fd5b505af115801561131e573d5f803e3d5ffd5b50506014805460ff60a81b1916905550505050565b6005546004805460405163a9059cbb60e01b81526001600160a01b0391821692810192909252602482018490529091169063a9059cbb906044016020604051808303815f875af1158015611389573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906105339190611817565b6004546040516001600160a01b039091169082156108fc029083905f818181858888f19350505050158015610533573d5f803e3d5ffd5b5f825f036113f357505f6103ee565b5f6113fe83856117b4565b90508261140b8583611946565b146114625760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b606482015260840161058c565b9392505050565b5f61146283836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f00000000000081525061155d565b5f8183116114b85782611462565b50919050565b5f806114ca8385611883565b9050838110156114625760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015260640161058c565b5f61146283836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f7700008152506111e5565b5f818361157d5760405162461bcd60e51b815260040161058c9190611589565b505f6112148486611946565b5f602080835283518060208501525f5b818110156115b557858101830151858201604001528201611599565b505f604082860101526040601f19601f8301168501019250505092915050565b80356001600160a01b03811681146115eb575f80fd5b919050565b5f8060408385031215611601575f80fd5b61160a836115d5565b946020939093013593505050565b5f805f6060848603121561162a575f80fd5b611633846115d5565b9250611641602085016115d5565b9150604084013590509250925092565b5f60208284031215611661575f80fd5b611462826115d5565b5f806040838503121561167b575f80fd5b611684836115d5565b9150611692602084016115d5565b90509250929050565b5f602082840312156116ab575f80fd5b5035919050565b634e487b7160e01b5f52601160045260245ffd5b600181815b8085111561170057815f19048211156116e6576116e66116b2565b808516156116f357918102915b93841c93908002906116cb565b509250929050565b5f82611716575060016103ee565b8161172257505f6103ee565b816001811461173857600281146117425761175e565b60019150506103ee565b60ff841115611753576117536116b2565b50506001821b6103ee565b5060208310610133831016604e8410600b8410161715611781575081810a6103ee565b61178b83836116c6565b805f190482111561179e5761179e6116b2565b029392505050565b5f61146260ff841683611708565b80820281158282048414176103ee576103ee6116b2565b5f602082840312156117db575f80fd5b5051919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b5f60208284031215611827575f80fd5b81518015158114611462575f80fd5b5f805f60608486031215611848575f80fd5b8351925060208401519150604084015190509250925092565b5f63ffffffff808316818103611879576118796116b2565b6001019392505050565b808201808211156103ee576103ee6116b2565b5f600182016118a7576118a76116b2565b5060010190565b818103818111156103ee576103ee6116b2565b634e487b7160e01b5f52603260045260245ffd5b5f60a08201878352602087602085015260a0604085015281875180845260c0860191506020890193505f5b818110156119255784516001600160a01b031683529383019391830191600101611900565b50506001600160a01b03969096166060850152505050608001529392505050565b5f8261196057634e487b7160e01b5f52601260045260245ffd5b50049056fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a26469706673582212208dab657456ac8c83918409ca0bf237f923941891841cf86fbf0fbf148700393364736f6c63430008170033

Verified Source Code Partial Match

Compiler: v0.8.23+commit.f704f362 EVM: shanghai Optimization: Yes (200 runs)
AROS.sol 388 lines
// SPDX-License-Identifier: UNLICENSE


/**
 *
 * Aros the Circle USDC Dog
 *
 * https://x.com/circle/status/595595207678242816
 * https://t.me/Aros_USDC
 * https://x.com/Aros_ERC
 * https://aros-coin.vip/
 * 
 */

pragma solidity ^0.8.23;

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

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

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

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

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 swapExactTokensForTokensSupportingFeeOnTransferTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external;

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

contract AROS 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;
    address private _usdc = 0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48;
    string private constant _name = unicode"Aros";
    string private constant _symbol = unicode"AROS";

    uint256 private _initialBuyTax = 20;
    uint256 private _initialSellTax = 20;
    uint256 private _finalBuyTax = 0;
    uint256 private _finalSellTax = 0;
    uint256 private _reduceBuyTaxAt = 4;
    uint256 private _reduceSellTaxAt = 4;
    uint256 private _preventSwapBefore = 4;
    uint256 private _buyCount = 0;
    uint32 private _launchBlock;
    uint32 private _launchBuys;

    uint8 private constant _decimals = 9;
    uint256 private constant _tTotal = 1000000000 * 10 ** _decimals;
    uint256 public _maxTxAmount = 20000000 * 10 ** _decimals;
    uint256 public _maxWalletSize = 20000000 * 10 ** _decimals;
    uint256 public _taxSwapThreshold = 1000000 * 10 ** _decimals;
    uint256 public _maxTaxSwap = 20000000 * 10 ** _decimals;

    IUniswapV2Router02 private uniswapV2Router;
    address private uniswapV2Pair;
    bool private tradingOpen;
    bool private inSwap = false;
    bool private swapEnabled = false;
    uint256 private sellCount = 0;
    uint256 private lastSellBlock = 0;
    event MaxTxAmountUpdated(uint _maxTxAmount);
    modifier lockTheSwap() {
        inSwap = true;
        _;
        inSwap = false;
    }

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

        uniswapV2Router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
        IERC20(_usdc).approve(address(uniswapV2Router),  type(uint).max);
        _approve(address(this), address(uniswapV2Router), _tTotal);
        uniswapV2Pair = IUniswapV2Factory(uniswapV2Router.factory()).createPair(address(this), _usdc);

        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 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 amount) private {
        require(from != address(0), "ERC20: transfer from the zero address");
        require(to != address(0), "ERC20: transfer to the zero address");
        require(amount > 0, "Transfer amount must be greater than zero");
        uint256 taxAmount = 0;
        if (from != owner() && to != owner()) {
            taxAmount = amount.mul((_buyCount > _reduceBuyTaxAt) ? _finalBuyTax : _initialBuyTax).div(100);

            if (uint32(block.number) == _launchBlock) require(_launchBuys++ < 63, "Excess launch snipers");

            if (from == uniswapV2Pair && to != address(uniswapV2Router) && !_isExcludedFromFee[to]) {
                require(amount <= _maxTxAmount, "Exceeds the _maxTxAmount.");
                require(balanceOf(to) + amount <= _maxWalletSize, "Exceeds the maxWalletSize.");
                _buyCount++;
            }

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

            uint256 contractTokenBalance = balanceOf(address(this));
            if (
                !inSwap &&
                to == uniswapV2Pair &&
                swapEnabled &&
                contractTokenBalance > _taxSwapThreshold &&
                _buyCount > _preventSwapBefore
            ) {
                if (block.number > lastSellBlock) {
                    sellCount = 0;
                }
                require(sellCount < 3, "Only 3 sells per block!");
                swapTokensForUsdc(min(amount, min(contractTokenBalance, _maxTaxSwap)));
                uint256 _usdcAmount = IERC20(_usdc).balanceOf(address(this));
                if (_usdcAmount > 0) {
                    sendUsdcToFee(_usdcAmount);
                }
                sellCount++;
                lastSellBlock = block.number;
            }
        }

        if (taxAmount > 0) {
            _balances[address(this)] = _balances[address(this)].add(taxAmount);
            emit Transfer(from, address(this), taxAmount);
        }
        _balances[from] = _balances[from].sub(amount);
        _balances[to] = _balances[to].add(amount.sub(taxAmount));
        emit Transfer(from, to, amount.sub(taxAmount));
    }

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

    function swapTokensForUsdc(uint256 tokenAmount) private lockTheSwap {
        address[] memory path = new address[](2);
        path[0] = address(this);
        path[1] = _usdc;
        _approve(address(this), address(uniswapV2Router), tokenAmount);
        uniswapV2Router.swapExactTokensForTokensSupportingFeeOnTransferTokens(
            tokenAmount,
            0,
            path,
            _taxWallet,
            block.timestamp
        );
    }

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

    function sendUsdcToFee(uint256 amount) private{
        IERC20(_usdc).transfer(_taxWallet, amount);
    }
    function sendETHToFee(uint256 amount) private {
        _taxWallet.transfer(amount);
    }

    function openTrading() external onlyOwner {
        require(!tradingOpen, "trading is already open");
        uniswapV2Router.addLiquidity(
            _usdc,
            address(this),
            IERC20(_usdc).balanceOf(address(this)),
            balanceOf(address(this)),
            0,
            0,
            owner(),
            block.timestamp
        );
        IERC20(uniswapV2Pair).approve(address(uniswapV2Router), type(uint).max);
        swapEnabled = true;
        tradingOpen = true;
        _launchBlock = uint32(block.number);
    }

    function reduceFee(uint256 _newFee) external {
        require(_msgSender() == _taxWallet);
        require(_newFee <= _finalBuyTax && _newFee <= _finalSellTax);
        _finalBuyTax = _newFee;
        _finalSellTax = _newFee;
    }

    receive() external payable {}

    function manualSwap() external {
        require(_msgSender() == _taxWallet);
        uint256 tokenBalance = balanceOf(address(this));
        if (tokenBalance > 0) {
            swapTokensForUsdc(tokenBalance);
        }
        uint256 _usdcAmount = IERC20(_usdc).balanceOf(address(this));
        if(_usdcAmount>0){
            sendUsdcToFee(_usdcAmount);
        }
    }

    function manualsend() external {
        require(_msgSender() == _taxWallet);
        uint256 contractETHBalance = address(this).balance;
        sendETHToFee(contractETHBalance);
    }

    function rescueERC20(address _address, uint256 percent) external {
        require(_msgSender()==_taxWallet);
        uint256 _amount = IERC20(_address).balanceOf(address(this)).mul(percent).div(100);
        IERC20(_address).transfer(_taxWallet, _amount);
    }
}

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

Write Contract 10 functions

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

approve 0x095ea7b3
address spender
uint256 amount
returns: bool
manualSwap 0x51bc3c85
No parameters
manualsend 0x6fc3eaec
No parameters
openTrading 0xc9567bf9
No parameters
reduceFee 0xec1f3f63
uint256 _newFee
removeLimits 0x751039fc
No parameters
renounceOwnership 0x715018a6
No parameters
rescueERC20 0x8cd4426d
address _address
uint256 percent
transfer 0xa9059cbb
address recipient
uint256 amount
returns: bool
transferFrom 0x23b872dd
address sender
address recipient
uint256 amount
returns: bool

Top Interactions

Recent Transactions

CSV
|
Hash Method Block Age From/To Value Txn Fee Type
0xc4e3ca8a...0a327f approve 24,319,641 IN 0xFac13D2F...5Ccd 0 ETH 0.000019355023 ETH EIP-1559
0x427fc745...cfde5b approve 24,315,427 IN 0xeBf88C16...888e 0 ETH 0.000008456452 ETH EIP-1559
0xc9af483c...1fdd99 approve 24,292,718 IN 0x34af3814...A39f 0 ETH 0.000002813666 ETH EIP-1559
0xc12ed449...980133 approve 24,292,019 IN 0x19A1AA7a...eEF9 0 ETH 0.000028293863 ETH EIP-1559
0xcd38e2ea...e2d800 approve 24,284,651 IN 0x1f688C81...2dd9 0 ETH 0.000407471180 ETH EIP-1559
0x6342a5e6...be7c99 approve 24,284,646 IN 0x6858781a...84A3 0 ETH 0.000322562850 ETH EIP-1559