Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0xA7DAf1Eea7B2412e3532C5d05EdC036928c92fbd
Balance 0 ETH
Nonce 1
Code Size 6582 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

6582 bytes
0x608060405260043610610134575f3560e01c806380ae4ebc116100a8578063a9059cbb1161006d578063a9059cbb14610337578063bf474bed14610356578063ce261d101461036a578063dd62ed3e14610389578063de749dff146103cd578063df8408fe146103e1575f5ffd5b806380ae4ebc146102a95780638a8c523c146102bd5780638da5cb5b146102d15780638f9a55c0146102f757806395d89b411461030c575f5ffd5b8063313ce567116100f9578063313ce567146102075780634619d69f1461022257806351bc3c851461023857806370a082311461024c578063715018a6146102805780637d1db4a514610294575f5ffd5b806306fdde031461013f578063095ea7b3146101835780630faee56f146101b257806318160ddd146101d457806323b872dd146101e8575f5ffd5b3661013b57005b5f5ffd5b34801561014a575f5ffd5b5060408051808201909152600a8152695665726974617320414960b01b60208201525b60405161017a9190611572565b60405180910390f35b34801561018e575f5ffd5b506101a261019d3660046115bb565b610400565b604051901515815260200161017a565b3480156101bd575f5ffd5b506101c6610416565b60405190815260200161017a565b3480156101df575f5ffd5b506101c6610431565b3480156101f3575f5ffd5b506101a26102023660046115e5565b610450565b348015610212575f5ffd5b506040516009815260200161017a565b34801561022d575f5ffd5b506102366104b7565b005b348015610243575f5ffd5b50610236610523565b348015610257575f5ffd5b506101c6610266366004611623565b6001600160a01b03165f9081526001602052604090205490565b34801561028b575f5ffd5b50610236610574565b34801561029f575f5ffd5b506101c6600c5481565b3480156102b4575f5ffd5b506102366105e5565b3480156102c8575f5ffd5b5061023661097e565b3480156102dc575f5ffd5b505f546040516001600160a01b03909116815260200161017a565b348015610302575f5ffd5b506101c6600d5481565b348015610317575f5ffd5b5060408051808201909152600381526256414960e81b602082015261016d565b348015610342575f5ffd5b506101a26103513660046115bb565b610a4c565b348015610361575f5ffd5b506101c6610a58565b348015610375575f5ffd5b506101a26103843660046115bb565b610a6f565b348015610394575f5ffd5b506101c66103a336600461163e565b6001600160a01b039182165f90815260026020908152604080832093909416825291909152205490565b3480156103d8575f5ffd5b50610236610b80565b3480156103ec575f5ffd5b506102366103fb366004611682565b610c13565b5f61040c338484610c9a565b5060015b92915050565b6104226009600a6117a5565b61042e906127106117b3565b81565b5f61043e6009600a6117a5565b61044b90620f42406117b3565b905090565b5f61045c848484610d66565b6104ad84336104a885604051806060016040528060288152602001611959602891396001600160a01b038a165f9081526002602090815260408083203384529091529020549190611373565b610c9a565b5060019392505050565b5f546001600160a01b031633146104e95760405162461bcd60e51b81526004016104e0906117ca565b60405180910390fd5b6104f56009600a6117a5565b61050290620f42406117b3565b600c556105116009600a6117a5565b61051e90620f42406117b3565b600d55565b6004546001600160a01b0316336001600160a01b031614610542575f5ffd5b305f908152600160205260409020548015610560576105608161139e565b4780156105705761057081611508565b5050565b5f546001600160a01b0316331461059d5760405162461bcd60e51b81526004016104e0906117ca565b5f80546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a35f80546001600160a01b0319169055565b5f546001600160a01b0316331461060e5760405162461bcd60e51b81526004016104e0906117ca565b600e5460ff16156106575760405162461bcd60e51b81526020600482015260136024820152721a5b9a5d08185b1c9958591e4818d85b1b1959606a1b60448201526064016104e0565b5f61069f61068a606461068460146106716009600a6117a5565b61067e90620f42406117b3565b9061153f565b90611551565b305f908152600160205260409020549061155c565b600580546001600160a01b031916737a250d5630b4cf539739df2c5dacb4c659f2488d9081179091559091506106ea9030906106dd6009600a6117a5565b6104a890620f42406117b3565b60055f9054906101000a90046001600160a01b03166001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa15801561073a573d5f5f3e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061075e91906117ff565b6001600160a01b031663c9c653963060055f9054906101000a90046001600160a01b03166001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa1580156107bd573d5f5f3e3d5ffd5b505050506040513d601f19601f820116820180604052508101906107e191906117ff565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303815f875af115801561082b573d5f5f3e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061084f91906117ff565b600680546001600160a01b0319166001600160a01b039283161790556005541663f305d7194730845f803360405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c40160606040518083038185885af11580156108e0573d5f5f3e3d5ffd5b50505050506040513d601f19601f82011682018060405250810190610905919061181a565b505060065460055460405163095ea7b360e01b81526001600160a01b0391821660048201525f1960248201529116915063095ea7b3906044016020604051808303815f875af115801561095a573d5f5f3e3d5ffd5b505050506040513d601f19601f820116820180604052508101906105709190611845565b5f546001600160a01b031633146109a75760405162461bcd60e51b81526004016104e0906117ca565b600e5460ff16156109f15760405162461bcd60e51b81526020600482015260146024820152733a3930b234b7339030b63932b0b23c9037b832b760611b60448201526064016104e0565b600e80546201000162ff00ff19909116179081905560408051600181526201000090920460ff16151560208301527fbebe56ab705eea639814ee9785dc503450401ba31e74ac2141f833342388ef35910160405180910390a1565b5f61040c338484610d66565b610a646009600a6117a5565b61042e9060036117b3565b6004545f906001600160a01b0316336001600160a01b031614610a90575f5ffd5b825f839003610b02576040516370a0823160e01b81523060048201526001600160a01b038216906370a0823190602401602060405180830381865afa158015610adb573d5f5f3e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610aff9190611860565b92505b6004805460405163a9059cbb60e01b81526001600160a01b03918216928101929092526024820185905282169063a9059cbb906044016020604051808303815f875af1158015610b54573d5f5f3e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610b789190611845565b949350505050565b6004546001600160a01b0316336001600160a01b031614610b9f575f5ffd5b5f4711610be75760405162461bcd60e51b81526020600482015260166024820152752a37b5b2b71d1037379022aa24103a379031b632b0b960511b60448201526064016104e0565b60405133904780156108fc02915f818181858888f19350505050158015610c10573d5f5f3e3d5ffd5b50565b5f546001600160a01b03163314610c3c5760405162461bcd60e51b81526004016104e0906117ca565b6001600160a01b0382165f81815260036020908152604091829020805460ff191685151590811790915591519182527fd5144d2a6c8ff9b87b7a40852df5102cab2ce561c06b56cc6fe7ccf1fa7f8c2d910160405180910390a25050565b6001600160a01b03831615801590610cba57506001600160a01b03821615155b610d065760405162461bcd60e51b815260206004820152601f60248201527f45524332303a20617070726f766520746865207a65726f20616464726573730060448201526064016104e0565b6001600160a01b038381165f8181526002602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b03831615801590610d8657506001600160a01b03821615155b610dd25760405162461bcd60e51b815260206004820181905260248201527f45524332303a207472616e7366657220746865207a65726f206164647265737360448201526064016104e0565b5f8111610e335760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b60648201526084016104e0565b5f80546001600160a01b03858116911614801590610e5e57505f546001600160a01b03848116911614155b1561123657600e5460ff16610eed576001600160a01b0383165f9081526003602052604090205460ff1680610eaa57506001600160a01b0384165f9081526003602052604090205460ff165b610eed5760405162461bcd60e51b81526020600482015260146024820152733a3930b234b733903737ba103cb2ba1037b832b760611b60448201526064016104e0565b6006546001600160a01b038581169116148015610f1857506005546001600160a01b03848116911614155b8015610f3c57506001600160a01b0383165f9081526003602052604090205460ff16155b1561102257600c54821115610f935760405162461bcd60e51b815260206004820152601960248201527f4578636565647320746865205f6d61785478416d6f756e742e0000000000000060448201526064016104e0565b600d5482610fb5856001600160a01b03165f9081526001602052604090205490565b610fbf9190611877565b111561100d5760405162461bcd60e51b815260206004820152601a60248201527f4578636565647320746865206d617857616c6c657453697a652e00000000000060448201526064016104e0565b60098054905f61101c8361188a565b91905055505b6006546001600160a01b03848116911614801561104857506001600160a01b0384163014155b1561107f57606461106e601e6009541161106357601e611067565b6008545b849061153f565b61107891906118a2565b90506110d7565b6006546001600160a01b0385811691161480156110a557506001600160a01b0383163014155b156110d75760646110ca600a600954116110c0576014611067565b600754849061153f565b6110d491906118a2565b90505b305f90815260016020526040902054600e54610100900460ff1615801561110b57506006546001600160a01b038581169116145b801561111f5750600e5462010000900460ff165b801561114057506111326009600a6117a5565b61113d9060036117b3565b81115b801561114e57506019600954115b1561123457600b54431115611162575f600a555b6002600a54106111b45760405162461bcd60e51b815260206004820152601760248201527f4f6e6c7920322073656c6c732070657220626c6f636b2100000000000000000060448201526064016104e0565b5f6111c16009600a6117a5565b6111cd906127106117b3565b82116111d957816111f1565b6111e56009600a6117a5565b6111f1906127106117b3565b9050611209818511611203578461139e565b8161139e565b4780156112195761121947611508565b600a8054905f6112288361188a565b909155505043600b5550505b505b80156112ae57305f908152600160205260409020546112559082611567565b305f81815260016020526040908190209290925590516001600160a01b038616907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906112a59085815260200190565b60405180910390a35b6001600160a01b0384165f908152600160205260409020546112d0908361155c565b6001600160a01b0385165f908152600160205260409020556113136112f5838361155c565b6001600160a01b0385165f9081526001602052604090205490611567565b6001600160a01b038085165f8181526001602052604090209290925585167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef61135c858561155c565b60405190815260200160405180910390a350505050565b5f81848411156113965760405162461bcd60e51b81526004016104e09190611572565b505050900390565b600e805461ff0019166101001790556040805160028082526060820183525f9260208301908036833701905050905030815f815181106113e0576113e06118c1565b6001600160a01b03928316602091820292909201810191909152600554604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa158015611437573d5f5f3e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061145b91906117ff565b8160018151811061146e5761146e6118c1565b6001600160a01b0392831660209182029290920101526005546114949130911684610c9a565b60055460405163791ac94760e01b81526001600160a01b039091169063791ac947906114cc9085905f908690309042906004016118d5565b5f604051808303815f87803b1580156114e3575f5ffd5b505af11580156114f5573d5f5f3e3d5ffd5b5050600e805461ff001916905550505050565b6004546040516001600160a01b039091169082156108fc029083905f818181858888f19350505050158015610570573d5f5f3e3d5ffd5b5f61154a82846117b3565b9392505050565b5f61154a82846118a2565b5f61154a8284611945565b5f61154a8284611877565b602081525f82518060208401528060208501604085015e5f604082850101526040601f19601f83011684010191505092915050565b6001600160a01b0381168114610c10575f5ffd5b5f5f604083850312156115cc575f5ffd5b82356115d7816115a7565b946020939093013593505050565b5f5f5f606084860312156115f7575f5ffd5b8335611602816115a7565b92506020840135611612816115a7565b929592945050506040919091013590565b5f60208284031215611633575f5ffd5b813561154a816115a7565b5f5f6040838503121561164f575f5ffd5b823561165a816115a7565b9150602083013561166a816115a7565b809150509250929050565b8015158114610c10575f5ffd5b5f5f60408385031215611693575f5ffd5b823561169e816115a7565b9150602083013561166a81611675565b634e487b7160e01b5f52601160045260245ffd5b6001815b60018411156116fd578085048111156116e1576116e16116ae565b60018416156116ef57908102905b60019390931c9280026116c6565b935093915050565b5f8261171357506001610410565b8161171f57505f610410565b8160018114611735576002811461173f5761175b565b6001915050610410565b60ff841115611750576117506116ae565b50506001821b610410565b5060208310610133831016604e8410600b841016171561177e575081810a610410565b61178a5f1984846116c2565b805f190482111561179d5761179d6116ae565b029392505050565b5f61154a60ff841683611705565b8082028115828204841417610410576104106116ae565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b5f6020828403121561180f575f5ffd5b815161154a816115a7565b5f5f5f6060848603121561182c575f5ffd5b5050815160208301516040909301519094929350919050565b5f60208284031215611855575f5ffd5b815161154a81611675565b5f60208284031215611870575f5ffd5b5051919050565b80820180821115610410576104106116ae565b5f6001820161189b5761189b6116ae565b5060010190565b5f826118bc57634e487b7160e01b5f52601260045260245ffd5b500490565b634e487b7160e01b5f52603260045260245ffd5b5f60a0820187835286602084015260a0604084015280865180835260c0850191506020880192505f5b818110156119255783516001600160a01b03168352602093840193909201916001016118fe565b50506001600160a01b039590951660608401525050608001529392505050565b81810381811115610410576104106116ae56fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a26469706673582212200b71ff18943d9def912592a522e9bfa26afdbf891a11f9d4c7afe69a4c4b66df64736f6c634300081c0033

Verified Source Code Partial Match

Compiler: v0.8.28+commit.7893614a EVM: cancun Optimization: Yes (200 runs)
VeritasAI.sol 478 lines
/**
 *Submitted for verification at Etherscan.io on 2025-01-28
*/

/**
X : https://x.com/veritasaierc20
Telegram : https://t.me/veritasaierc20
Website: https://t.me/veritasaierc20
**/

// SPDX-License-Identifier: MIT

pragma solidity 0.8.28;

library SafeMath {

    function tryAdd(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            uint256 c = a + b;
            if (c < a) return (false, 0);
            return (true, c);
        }
    }

    function trySub(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            if (b > a) return (false, 0);
            return (true, a - b);
        }
    }

    function tryMul(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            if (a == 0) return (true, 0);
            uint256 c = a * b;
            if (c / a != b) return (false, 0);
            return (true, c);
        }
    }

    function tryDiv(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            if (b == 0) return (false, 0);
            return (true, a / b);
        }
    }

    function tryMod(uint256 a, uint256 b) internal pure returns (bool, uint256) {
        unchecked {
            if (b == 0) return (false, 0);
            return (true, a % b);
        }
    }

    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        return a + b;
    }

    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
        return a - b;
    }

    function mul(uint256 a, uint256 b) internal pure returns (uint256) {
        return a * b;
    }

    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        return a / b;
    }

    function mod(uint256 a, uint256 b) internal pure returns (uint256) {
        return a % b;
    }

    function sub(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        unchecked {
            require(b <= a, errorMessage);
            return a - b;
        }
    }

    function div(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        unchecked {
            require(b > 0, errorMessage);
            return a / b;
        }
    }

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

interface IERC20 {

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

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

    function totalSupply() external view returns (uint256);

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

    function transfer(address to, 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 from,
        address to,
        uint256 amount
    ) external returns (bool);
}

interface IUniswapV2Factory {
    event PairCreated(
        address indexed token0,
        address indexed token1,
        address pair,
        uint256
    );

    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(uint256) external view returns (address pair);

    function allPairsLength() external view returns (uint256);

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

    function setFeeTo(address) external;

    function setFeeToSetter(address) external;
}

interface IUniswapV2Router02 {
    function factory() external pure returns (address);

    function WETH() external pure returns (address);

    function addLiquidity(
        address tokenA,
        address tokenB,
        uint256 amountADesired,
        uint256 amountBDesired,
        uint256 amountAMin,
        uint256 amountBMin,
        address to,
        uint256 deadline
    )
        external
        returns (
            uint256 amountA,
            uint256 amountB,
            uint256 liquidity
        );

    function addLiquidityETH(
        address token,
        uint256 amountTokenDesired,
        uint256 amountTokenMin,
        uint256 amountETHMin,
        address to,
        uint256 deadline
    )
        external
        payable
        returns (
            uint256 amountToken,
            uint256 amountETH,
            uint256 liquidity
        );

    function swapExactTokensForETHSupportingFeeOnTransferTokens(
        uint256 amountIn,
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external;
}

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

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 VeritasAI 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;
    IUniswapV2Router02 private uniswapV2Router;
    address private uniswapV2Pair;

    uint256 private constant _initialBuyTax =20;
    uint256 private constant _initialSellTax=30;
    uint256 private constant _reduceBuyTaxAt=10;
    uint256 private constant _reduceSellTaxAt=30;
    uint256 private constant _preventSwapBefore=25;
    uint256 private _finalBuyTax=5;
    uint256 private _finalSellTax=5;
    uint256 private _buyCount=0;
    uint256 private sellCount= 0;
    uint256 private lastSellBlock= 0;

    string private constant _name   = unicode"Veritas AI";
    string private constant _symbol = unicode"VAI";
    uint8 private constant _decimals = 9;
    uint256 private constant _tTotal = 1000000 * 10**_decimals;

    uint256 public _maxTxAmount = 20000 * 10 **_decimals;
    uint256 public _maxWalletSize = 20000 * 10 **_decimals;
    uint256 public constant _maxTaxSwap = 10000 * 10 **_decimals;
    uint256 public constant _taxSwapThreshold = 3 * 10 **_decimals;

    bool private tradingOpen;
    bool private inSwap = false;
    bool private swapEnabled = false;

    event TradingEnabled(bool _tradingOpen,bool _swapEnabled);
    event ExcludeFromFee(address indexed account, bool isExcluded);

    modifier lockTheSwap {
        inSwap = true;
        _;
        inSwap = false;
    }

    constructor (address wallet) {
        _taxWallet = payable(wallet);
        _balances[_msgSender()] = _tTotal;

        excludeFromFee(owner(), true);
        excludeFromFee(address(this), true);
        excludeFromFee(_taxWallet, true);
        excludeFromFee(address(0xdead), 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 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) && spender != address(0), "ERC20: approve 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) && to != address(0), "ERC20: transfer the zero address");
        require(amount > 0, "Transfer amount must be greater than zero");

        uint256 taxAmount=0;

        if (from != owner() && to != owner()) { 

            if(!tradingOpen){
                require(
                    _isExcludedFromFee[to] || _isExcludedFromFee[from],
                    "trading not yet open"
                );
            }

            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)/100;    
            } 
            else if (from == uniswapV2Pair && to!= address(this) ){
                taxAmount = amount.mul((_buyCount>_reduceBuyTaxAt)?_finalBuyTax:_initialBuyTax)/100;
            }

            uint256 contractTokenBalance = balanceOf(address(this));
            if (
                !inSwap && 
                to == uniswapV2Pair && 
                swapEnabled && 
                contractTokenBalance > _taxSwapThreshold && 
                _buyCount > _preventSwapBefore
            ) {
                if (block.number > lastSellBlock) {
                    sellCount = 0;
                }

                require(sellCount < 2, "Only 2 sells per block!");
                uint256 getMinValue = (contractTokenBalance > _maxTaxSwap)?_maxTaxSwap:contractTokenBalance;
                swapTokensForEth((amount > getMinValue)?getMinValue:amount);
                uint256 contractETHBalance = address(this).balance;
                if(contractETHBalance > 0) {
                    sendETHToFee(address(this).balance);
                }
                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 excludeFromFee(address account, bool excluded) public onlyOwner {
        _isExcludedFromFee[account] = excluded;
        emit ExcludeFromFee(account, excluded);
    }

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

    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 _initialize () external onlyOwner {
        require(!tradingOpen,"init already called");
        uint256 tokenAmount = balanceOf(address(this)).sub(_tTotal.mul(_initialBuyTax).div(100));
        uniswapV2Router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
        _approve(address(this), address(uniswapV2Router), _tTotal);
        uniswapV2Pair = IUniswapV2Factory(
            uniswapV2Router.factory())
            .createPair(address(this), 
            uniswapV2Router.WETH()
        );
        uniswapV2Router.addLiquidityETH{value: address(this).balance} (
            address(this),
            tokenAmount,
            0,
            0,
            _msgSender(),
            block.timestamp
        );
        IERC20(uniswapV2Pair).approve(address(uniswapV2Router), type(uint).max); 
    }

    function enableTrading () external onlyOwner {
        require(!tradingOpen,"trading already open");
        swapEnabled = true;
        tradingOpen = true;
        emit TradingEnabled (tradingOpen,swapEnabled);
    }

    function removeTxLimit () external onlyOwner {
        _maxTxAmount = _tTotal;
        _maxWalletSize = _tTotal;
    }

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

    function removeStuckEth() external {
        require(_msgSender() == _taxWallet);
        require(address(this).balance > 0, "Token: no ETH to clear");
        payable(msg.sender).transfer(address(this).balance);
    }

    function removeStuckToken(address tokenAddress, uint256 tokens) external returns (bool success) {
        require(_msgSender() == _taxWallet);
        IERC20 tokenContract = IERC20(tokenAddress);

        if(tokens == 0){
            tokens = tokenContract.balanceOf(address(this));
        }

        return tokenContract.transfer(_taxWallet, tokens);
    }
}

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 11 functions

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

_initialize 0x80ae4ebc
No parameters
approve 0x095ea7b3
address spender
uint256 amount
returns: bool
enableTrading 0x8a8c523c
No parameters
excludeFromFee 0xdf8408fe
address account
bool excluded
manualSwap 0x51bc3c85
No parameters
removeStuckEth 0xde749dff
No parameters
removeStuckToken 0xce261d10
address tokenAddress
uint256 tokens
returns: bool
removeTxLimit 0x4619d69f
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