Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0x013058AcA52837F35f0BB15Ede1EF4A628288f0f
Balance 0 ETH
Nonce 1
Code Size 6604 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

6604 bytes
0x608060405260043610610134575f3560e01c8063715018a6116100a857806395d89b411161006d57806395d89b4114610343578063a9059cbb14610373578063bf474bed14610392578063dd62ed3e146103a7578063f2fde38b146103eb578063f5b3c3bf1461040a575f80fd5b8063715018a6146102d55780637d1db4a5146102e95780638a8c523c146102fe5780638da5cb5b146103125780638f9a55c01461032e575f80fd5b806320800a00116100f957806320800a00146101fd57806323b872dd14610211578063313ce5671461023057806349bd5a5e1461024b578063573761981461028257806370a08231146102a1575f80fd5b806301ab6ee51461013f57806306fdde0314610155578063095ea7b3146101975780630faee56f146101c657806318160ddd146101e9575f80fd5b3661013b57005b5f80fd5b34801561014a575f80fd5b50610153610438565b005b348015610160575f80fd5b50604080518082019091526008815267436f6c6f7373757360c01b60208201525b60405161018e91906115d6565b60405180910390f35b3480156101a2575f80fd5b506101b66101b136600461161f565b6104f2565b604051901515815260200161018e565b3480156101d1575f80fd5b506101db60155481565b60405190815260200161018e565b3480156101f4575f80fd5b506101db610508565b348015610208575f80fd5b50610153610528565b34801561021c575f80fd5b506101b661022b366004611649565b610580565b34801561023b575f80fd5b506040516009815260200161018e565b348015610256575f80fd5b5060175461026a906001600160a01b031681565b6040516001600160a01b03909116815260200161018e565b34801561028d575f80fd5b5061015361029c36600461161f565b6105e7565b3480156102ac575f80fd5b506101db6102bb366004611687565b6001600160a01b03165f9081526001602052604090205490565b3480156102e0575f80fd5b5061015361067f565b3480156102f4575f80fd5b506101db60125481565b348015610309575f80fd5b506101536106f0565b34801561031d575f80fd5b505f546001600160a01b031661026a565b348015610339575f80fd5b506101db60135481565b34801561034e575f80fd5b50604080518082019091526008815267434f4c4f5353555360c01b6020820152610181565b34801561037e575f80fd5b506101b661038d36600461161f565b6108e4565b34801561039d575f80fd5b506101db60145481565b3480156103b2575f80fd5b506101db6103c13660046116a2565b6001600160a01b039182165f90815260026020908152604080832093909416825291909152205490565b3480156103f6575f80fd5b50610153610405366004611687565b6108f0565b348015610415575f80fd5b506101b6610424366004611687565b60046020525f908152604090205460ff1681565b5f546001600160a01b0316331461046a5760405162461bcd60e51b8152600401610461906116d9565b60405180910390fd5b6104766009600a611802565b610484906305f5e100611810565b6012556104936009600a611802565b6104a1906305f5e100611810565b6013557f947f344d56e1e8c70dc492fb94c4ddddd490c016aab685f5e7e47b2e85cb44cf6104d16009600a611802565b6104df906305f5e100611810565b60405190815260200160405180910390a1565b5f6104fe3384846109d7565b5060015b92915050565b5f6105156009600a611802565b610523906305f5e100611810565b905090565b6006546001600160a01b0316336001600160a01b031614610547575f80fd5b6006546040516001600160a01b03909116904780156108fc02915f818181858888f1935050505015801561057d573d5f803e3d5ffd5b50565b5f61058c848484610afa565b6105dd84336105d88560405180606001604052806028815260200161196f602891396001600160a01b038a165f9081526002602090815260408083203384529091529020549190611257565b6109d7565b5060019392505050565b6006546001600160a01b0316336001600160a01b031614610606575f80fd5b60065460405163a9059cbb60e01b81526001600160a01b039182166004820152602481018390529083169063a9059cbb906044016020604051808303815f875af1158015610656573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061067a9190611827565b505050565b5f546001600160a01b031633146106a85760405162461bcd60e51b8152600401610461906116d9565b5f80546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a35f80546001600160a01b0319169055565b5f546001600160a01b031633146107195760405162461bcd60e51b8152600401610461906116d9565b601754600160a01b900460ff16156107735760405162461bcd60e51b815260206004820152601760248201527f74726164696e6720697320616c7265616479206f70656e0000000000000000006044820152606401610461565b6016546001600160a01b031663f305d71947306107a4816001600160a01b03165f9081526001602052604090205490565b5f806107b75f546001600160a01b031690565b60405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c40160606040518083038185885af115801561081d573d5f803e3d5ffd5b50505050506040513d601f19601f820116820180604052508101906108429190611846565b505060175460165460405163095ea7b360e01b81526001600160a01b0391821660048201525f1960248201529116915063095ea7b3906044016020604051808303815f875af1158015610897573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906108bb9190611827565b50601a805461ff0019166101001790556017805460ff60a01b1916600160a01b17905543600755565b5f6104fe338484610afa565b5f546001600160a01b031633146109195760405162461bcd60e51b8152600401610461906116d9565b6001600160a01b03811661097e5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610461565b5f80546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a35f80546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b038316610a395760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610461565b6001600160a01b038216610a9a5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610461565b6001600160a01b038381165f8181526002602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b038316610b5e5760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b6064820152608401610461565b6001600160a01b038216610bc05760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b6064820152608401610461565b5f8111610c215760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b6064820152608401610461565b5f80546001600160a01b03858116911614801590610c4c57505f546001600160a01b03848116911614155b1561111a57610c7d6064610c77600c54600f5411610c6c57600854610c70565b600a545b859061128f565b90611314565b90506007544303610d0757601954435f9081526005602052604090205410610ce75760405162461bcd60e51b815260206004820181905260248201527f457863656564732062757973206f6e2074686520666972737420626c6f636b2e6044820152606401610461565b435f908152600560205260408120805491610d0183611871565b91905055505b6001600160a01b0384165f9081526004602052604090205460ff168015610d3c57506016546001600160a01b03848116911614155b8015610d6057506001600160a01b0383165f9081526003602052604090205460ff16155b15610e4657601254821115610db75760405162461bcd60e51b815260206004820152601960248201527f4578636565647320746865205f6d61785478416d6f756e742e000000000000006044820152606401610461565b60135482610dd9856001600160a01b03165f9081526001602052604090205490565b610de39190611889565b1115610e315760405162461bcd60e51b815260206004820152601a60248201527f4578636565647320746865206d617857616c6c657453697a652e0000000000006044820152606401610461565b600f8054905f610e4083611871565b91905055505b6001600160a01b0383165f9081526004602052604090205460ff16158015610e8657506001600160a01b0383165f9081526003602052604090205460ff16155b15610f055760135482610ead856001600160a01b03165f9081526001602052604090205490565b610eb79190611889565b1115610f055760405162461bcd60e51b815260206004820152601a60248201527f4578636565647320746865206d617857616c6c657453697a652e0000000000006044820152606401610461565b6001600160a01b0383165f9081526004602052604090205460ff168015610f3557506001600160a01b0384163014155b15610f6257610f5f6064610c77600d54600f5411610f5557600954610c70565b600b54859061128f565b90505b6001600160a01b0384165f9081526004602052604090205460ff16158015610fa257506001600160a01b0383165f9081526004602052604090205460ff16155b8015610fb757506001600160a01b0384163014155b15610fbf57505f5b305f90815260016020526040902054601a5460ff16158015610ff857506001600160a01b0384165f9081526004602052604090205460ff165b801561100b5750601a54610100900460ff165b8015611018575060145481115b80156110275750600e54600f54115b156110955760115443111561103b575f6010555b6018546010541061104a575f80fd5b6110676110628461105d84601554611355565b611355565b611369565b47801561107757611077476114d0565b60108054905f61108683611871565b90915550504360115550611118565b601a5460ff161580156110bf57506001600160a01b0384165f9081526004602052604090205460ff165b80156110d25750601a54610100900460ff165b80156110df575060145481115b80156110ee5750600e54600f54115b15611118576111066110628461105d84601554611355565b47801561111657611116476114d0565b505b505b801561119257305f90815260016020526040902054611139908261150b565b305f81815260016020526040908190209290925590516001600160a01b038616907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906111899085815260200190565b60405180910390a35b6001600160a01b0384165f908152600160205260409020546111b49083611569565b6001600160a01b0385165f908152600160205260409020556111f76111d98383611569565b6001600160a01b0385165f908152600160205260409020549061150b565b6001600160a01b038085165f8181526001602052604090209290925585167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef6112408585611569565b60405190815260200160405180910390a350505050565b5f818484111561127a5760405162461bcd60e51b815260040161046191906115d6565b505f611286848661189c565b95945050505050565b5f825f0361129e57505f610502565b5f6112a98385611810565b9050826112b685836118af565b1461130d5760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b6064820152608401610461565b9392505050565b5f61130d83836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f0000000000008152506115aa565b5f818311611363578261130d565b50919050565b601a805460ff191660011790556040805160028082526060820183525f9260208301908036833701905050905030815f815181106113a9576113a96118ce565b6001600160a01b03928316602091820292909201810191909152601654604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa158015611400573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061142491906118e2565b81600181518110611437576114376118ce565b6001600160a01b03928316602091820292909201015260165461145d91309116846109d7565b60165460405163791ac94760e01b81526001600160a01b039091169063791ac947906114959085905f908690309042906004016118fd565b5f604051808303815f87803b1580156114ac575f80fd5b505af11580156114be573d5f803e3d5ffd5b5050601a805460ff1916905550505050565b6006546040516001600160a01b039091169082156108fc029083905f818181858888f19350505050158015611507573d5f803e3d5ffd5b5050565b5f806115178385611889565b90508381101561130d5760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f7700000000006044820152606401610461565b5f61130d83836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611257565b5f81836115ca5760405162461bcd60e51b815260040161046191906115d6565b505f61128684866118af565b602081525f82518060208401528060208501604085015e5f604082850101526040601f19601f83011684010191505092915050565b6001600160a01b038116811461057d575f80fd5b5f8060408385031215611630575f80fd5b823561163b8161160b565b946020939093013593505050565b5f805f6060848603121561165b575f80fd5b83356116668161160b565b925060208401356116768161160b565b929592945050506040919091013590565b5f60208284031215611697575f80fd5b813561130d8161160b565b5f80604083850312156116b3575f80fd5b82356116be8161160b565b915060208301356116ce8161160b565b809150509250929050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b5f52601160045260245ffd5b600181815b8085111561175c57815f19048211156117425761174261170e565b8085161561174f57918102915b93841c9390800290611727565b509250929050565b5f8261177257506001610502565b8161177e57505f610502565b8160018114611794576002811461179e576117ba565b6001915050610502565b60ff8411156117af576117af61170e565b50506001821b610502565b5060208310610133831016604e8410600b84101617156117dd575081810a610502565b6117e78383611722565b805f19048211156117fa576117fa61170e565b029392505050565b5f61130d60ff841683611764565b80820281158282048414176105025761050261170e565b5f60208284031215611837575f80fd5b8151801515811461130d575f80fd5b5f805f60608486031215611858575f80fd5b8351925060208401519150604084015190509250925092565b5f600182016118825761188261170e565b5060010190565b808201808211156105025761050261170e565b818103818111156105025761050261170e565b5f826118c957634e487b7160e01b5f52601260045260245ffd5b500490565b634e487b7160e01b5f52603260045260245ffd5b5f602082840312156118f2575f80fd5b815161130d8161160b565b5f60a08201878352602087602085015260a0604085015281875180845260c0860191506020890193505f5b8181101561194d5784516001600160a01b031683529383019391830191600101611928565b50506001600160a01b0396909616606085015250505060800152939250505056fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a264697066735822122033d7d4805f845188b294091bbf9a9cb0d33d0eccc80f5c177de2afdafe022dd164736f6c63430008190033

Verified Source Code Partial Match

Compiler: v0.8.25+commit.b61c2a91 EVM: cancun Optimization: Yes (200 runs)
Colossus.sol 346 lines
/*

https://t.me/Colossus_Eth

*/

// SPDX-License-Identifier: MIT

pragma solidity 0.8.25;

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

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

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 factory() external pure returns (address);
    function WETH() external pure returns (address);
    function addLiquidityETH(
        address token,
        uint amountTokenDesired,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external payable returns (uint amountToken, uint amountETH, uint liquidity);
}

contract Colossus is Context, IERC20, Ownable {
    using SafeMath for uint256;
    mapping (address => uint256) private _balances;
    mapping (address => mapping (address => uint256)) private _allowances;
    mapping (address => bool) private isExile;
    mapping (address => bool) public marketPair;
    mapping (uint256 => uint256) private perBuyCount;
    address payable private _taxWallet;
    uint256 private firstBlock = 0;

    uint256 private _initialBuyTax=19;
    uint256 private _initialSellTax=20;
    uint256 private _finalBuyTax=0;
    uint256 private _finalSellTax=0;

    uint256 private _reduceBuyTaxAt=30;

    uint256 private _reduceSellTaxAt=35;
    uint256 private _preventSwapBefore=35;
    uint256 private _buyCount=0;
    uint256 private sellCount = 0;
    uint256 private lastSellBlock = 0;

    uint8 private constant _decimals = 9;
    uint256 private constant _tTotal = 100000000 * 10**_decimals;
    string private constant _name = unicode"Colossus";
    string private constant _symbol = unicode"COLOSSUS";
    uint256 public _maxTxAmount =   2000000 * 10**_decimals;
    uint256 public _maxWalletSize = 2000000 * 10**_decimals;
    uint256 public _taxSwapThreshold= 1000000 * 10**_decimals;
    uint256 public _maxTaxSwap= 1500000 * 10**_decimals;

    IUniswapV2Router02 private uniswapV2Router;
    address public uniswapV2Pair;
    bool private tradingOpen;
    uint256 private sellsPerBlock = 3;
    uint256 private buysFirstBlock = 60;
    bool private inSwap = false;
    bool private swapEnabled = false;

    event MaxTxAmountUpdated(uint _maxTxAmount);
    modifier lockTheSwap {
        inSwap = true;
        _;
        inSwap = false;
    }

    constructor () {

        _taxWallet = payable(_msgSender());
        _balances[address(this)] = _tTotal;
        isExile[owner()] = true;
        isExile[address(this)] = true;
        isExile[address(uniswapV2Pair)] = true;
        
        emit Transfer(address(0), address(this), _tTotal);

        uniswapV2Router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
        _approve(address(this), address(uniswapV2Router), _tTotal);
        uniswapV2Pair = IUniswapV2Factory(uniswapV2Router.factory()).createPair(address(this), uniswapV2Router.WETH());
        marketPair[address(uniswapV2Pair)] = true;
        isExile[address(uniswapV2Pair)] = true;
    }

    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(block.number == firstBlock){
               require(perBuyCount[block.number] < buysFirstBlock, "Exceeds buys on the first block.");
               perBuyCount[block.number]++;
            }

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

            if (!marketPair[to] && ! isExile[to]) {
                require(balanceOf(to) + amount <= _maxWalletSize, "Exceeds the maxWalletSize.");
            }

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

        if (!marketPair[from] && !marketPair[to] && from!= address(this) ) {
                taxAmount = 0;
            }

            uint256 contractTokenBalance = balanceOf(address(this));
            if (!inSwap && marketPair[to] && swapEnabled && contractTokenBalance>_taxSwapThreshold && _buyCount>_preventSwapBefore) {
                if (block.number > lastSellBlock) {
                    sellCount = 0;
                }
                require(sellCount < sellsPerBlock);
                swapTokensForEth(min(amount,min(contractTokenBalance,_maxTaxSwap)));
                uint256 contractETHBalance = address(this).balance;
                if(contractETHBalance > 0) {
                    sendETHToFee(address(this).balance);
                }
                sellCount++;
                lastSellBlock = block.number;
            }

            else if(!inSwap && marketPair[to] && swapEnabled && contractTokenBalance>_taxSwapThreshold && _buyCount>_preventSwapBefore) {
                swapTokensForEth(min(amount,min(contractTokenBalance,_maxTaxSwap)));
                uint256 contractETHBalance = address(this).balance;
                if(contractETHBalance > 0) {
                    sendETHToFee(address(this).balance);
                }
            }
        }

        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 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 sendETHToFee(uint256 amount) private {
        _taxWallet.transfer(amount);
    }

    function rescueETH() external {
        require(_msgSender() == _taxWallet);
        payable(_taxWallet).transfer(address(this).balance);
    }

    function rescueTokens(address _tokenAddr, uint _amount) external {
        require(_msgSender() == _taxWallet);
        IERC20(_tokenAddr).transfer(_taxWallet, _amount);
    }

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

    function enableTrading() external onlyOwner() {
        require(!tradingOpen,"trading is already open");
        uniswapV2Router.addLiquidityETH{value: address(this).balance}(address(this),balanceOf(address(this)),0,0,owner(),block.timestamp);
        IERC20(uniswapV2Pair).approve(address(uniswapV2Router), type(uint).max);
        swapEnabled = true;
        tradingOpen = true;
        firstBlock = block.number;
    }

    receive() external payable {}
}

Read Contract

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

Write Contract 9 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
isNotRestricted 0x01ab6ee5
No parameters
renounceOwnership 0x715018a6
No parameters
rescueETH 0x20800a00
No parameters
rescueTokens 0x57376198
address _tokenAddr
uint256 _amount
transfer 0xa9059cbb
address recipient
uint256 amount
returns: bool
transferFrom 0x23b872dd
address sender
address recipient
uint256 amount
returns: bool
transferOwnership 0xf2fde38b
address newOwner

Recent Transactions

No transactions found for this address