Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0xb6377bfBae51FcF923360Ad08c5800494399e20C
Balance 0 ETH
Nonce 1
Code Size 6750 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

6750 bytes
0x6080604052600436106101d15760003560e01c80638da5cb5b116100f7578063c492f04611610095578063da00097d11610064578063da00097d1461055c578063dd62ed3e1461057d578063f0cd1dac146105c3578063f2fde38b146105d957600080fd5b8063c492f046146104d7578063c49b9a80146104f7578063c816841b14610517578063d158272d1461053757600080fd5b8063a073d37f116100d1578063a073d37f14610462578063a457c2d714610477578063a9059cbb14610497578063b2bdfa7b146104b757600080fd5b80638da5cb5b1461041a578063914eb66a1461043857806395d89b411461044d57600080fd5b8063395093511161016f5780635342acb41161013e5780635342acb41461038957806370a08231146103b957806382eefb43146103ef5780638456cb591461040557600080fd5b806339509351146102f65780633b97084a146103165780633ecad271146103385780634a74bb021461036857600080fd5b80631694505e116101ab5780631694505e1461027057806318160ddd1461029557806323b872dd146102b4578063313ce567146102d457600080fd5b806306fdde03146101dd578063095ea7b3146102085780631245e3471461023857600080fd5b366101d857005b600080fd5b3480156101e957600080fd5b506101f26105f9565b6040516101ff91906117ea565b60405180910390f35b34801561021457600080fd5b506102286102233660046116c2565b61068b565b60405190151581526020016101ff565b34801561024457600080fd5b50600454610258906001600160a01b031681565b6040516001600160a01b0390911681526020016101ff565b34801561027c57600080fd5b50600d546102589061010090046001600160a01b031681565b3480156102a157600080fd5b50600b545b6040519081526020016101ff565b3480156102c057600080fd5b506102286102cf366004611681565b6106a2565b3480156102e057600080fd5b5060035460405160ff90911681526020016101ff565b34801561030257600080fd5b506102286103113660046116c2565b61070d565b34801561032257600080fd5b5061033661033136600461178d565b610743565b005b34801561034457600080fd5b5061022861035336600461160e565b60086020526000908152604090205460ff1681565b34801561037457600080fd5b50600e5461022890600160a81b900460ff1681565b34801561039557600080fd5b506102286103a436600461160e565b60076020526000908152604090205460ff1681565b3480156103c557600080fd5b506102a66103d436600461160e565b6001600160a01b031660009081526005602052604090205490565b3480156103fb57600080fd5b506102a6600a5481565b34801561041157600080fd5b5061033661077b565b34801561042657600080fd5b506000546001600160a01b0316610258565b34801561044457600080fd5b506103366107b4565b34801561045957600080fd5b506101f2610828565b34801561046e57600080fd5b50600c546102a6565b34801561048357600080fd5b506102286104923660046116c2565b610837565b3480156104a357600080fd5b506102286104b23660046116c2565b610886565b3480156104c357600080fd5b50600054610258906001600160a01b031681565b3480156104e357600080fd5b506103366104f23660046116ee565b610893565b34801561050357600080fd5b50610336610512366004611772565b610934565b34801561052357600080fd5b50600e54610258906001600160a01b031681565b34801561054357600080fd5b506003546102589061010090046001600160a01b031681565b34801561056857600080fd5b50600e5461022890600160b01b900460ff1681565b34801561058957600080fd5b506102a6610598366004611648565b6001600160a01b03918216600090815260066020908152604080832093909416825291909152205490565b3480156105cf57600080fd5b506102a660095481565b3480156105e557600080fd5b506103366105f436600461160e565b6109b6565b60606001805461060890611941565b80601f016020809104026020016040519081016040528092919081815260200182805461063490611941565b80156106815780601f1061065657610100808354040283529160200191610681565b820191906000526020600020905b81548152906001019060200180831161066457829003601f168201915b5050505050905090565b6000610698338484610aa0565b5060015b92915050565b60006106af848484610bc4565b5061070284336106fd856040518060600160405280602881526020016119dc602891396001600160a01b038a1660009081526006602090815260408083203384529091529020549190610fac565b610aa0565b5060015b9392505050565b3360008181526006602090815260408083206001600160a01b038716845290915281205490916106989185906106fd9086610fe6565b6000546001600160a01b031633146107765760405162461bcd60e51b815260040161076d9061183f565b60405180910390fd5b600c55565b6000546001600160a01b031633146107a55760405162461bcd60e51b815260040161076d9061183f565b600d805460ff19166001179055565b6000546001600160a01b031633146107de5760405162461bcd60e51b815260040161076d9061183f565b600080546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600080546001600160a01b0319169055565b60606002805461060890611941565b600061069833846106fd85604051806060016040528060258152602001611a04602591393360009081526006602090815260408083206001600160a01b038d1684529091529020549190610fac565b6000610702338484610bc4565b6000546001600160a01b031633146108bd5760405162461bcd60e51b815260040161076d9061183f565b60005b8281101561092e5781600760008686858181106108df576108df6119ad565b90506020020160208101906108f4919061160e565b6001600160a01b031681526020810191909152604001600020805460ff1916911515919091179055806109268161197c565b9150506108c0565b50505050565b6000546001600160a01b0316331461095e5760405162461bcd60e51b815260040161076d9061183f565b600e8054821515600160a81b0260ff60a81b199091161790556040517f53726dfcaf90650aa7eb35524f4d3220f07413c8d6cb404cc8c18bf5591bc159906109ab90831515815260200190565b60405180910390a150565b6000546001600160a01b031633146109e05760405162461bcd60e51b815260040161076d9061183f565b6001600160a01b038116610a455760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b606482015260840161076d565b600080546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a3600080546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b038316610b025760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b606482015260840161076d565b6001600160a01b038216610b635760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b606482015260840161076d565b6001600160a01b0383811660008181526006602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b60006001600160a01b038416610c2a5760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b606482015260840161076d565b6001600160a01b038316610c8c5760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b606482015260840161076d565b60008211610cee5760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b606482015260840161076d565b6001600160a01b03841660009081526007602052604090205460ff16158015610d3057506001600160a01b03831660009081526007602052604090205460ff16155b15610db7576001600160a01b03841660009081526008602052604090205460ff1680610d7457506001600160a01b03831660009081526008602052604090205460ff165b15610db757600d5460ff16610db75760405162461bcd60e51b81526020600482015260096024820152681b9bdd081cdd185c9d60ba1b604482015260640161076d565b600e54600160a01b900460ff1615610ddb57610dd4848484611045565b9050610706565b30600090815260056020526040902054600c5481108015908190610e095750600e54600160a01b900460ff16155b8015610e2e57506001600160a01b03861660009081526008602052604090205460ff16155b8015610e435750600e54600160a81b900460ff165b15610e6957600e54600160b01b900460ff1615610e6057600c5491505b610e698261112b565b6040805180820182526014815273496e73756666696369656e742042616c616e636560601b6020808301919091526001600160a01b038916600090815260059091529190912054610ebb918690610fac565b6001600160a01b038716600090815260056020908152604080832093909355600790529081205460ff1680610f0857506001600160a01b03861660009081526007602052604090205460ff165b610f1c57610f178787876111c0565b610f1e565b845b6001600160a01b038716600090815260056020526040902054909150610f449082610fe6565b6001600160a01b0380881660008181526005602052604090819020939093559151908916907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef90610f989085815260200190565b60405180910390a360019350505050610706565b60008184841115610fd05760405162461bcd60e51b815260040161076d91906117ea565b506000610fdd848661192a565b95945050505050565b600080610ff383856118d1565b9050838110156107065760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015260640161076d565b6040805180820182526014815273496e73756666696369656e742042616c616e636560601b6020808301919091526001600160a01b0386166000908152600590915291822054611096918490610fac565b6001600160a01b0380861660009081526005602052604080822093909355908516815220546110c59083610fe6565b6001600160a01b0380851660008181526005602052604090819020939093559151908616907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906111199086815260200190565b60405180910390a35060019392505050565b600e805460ff60a01b1916600160a01b179055611147816112c8565b476000611160606461115a84603261148d565b9061150c565b9050600061116e838361154e565b90508015611191576003546111919061010090046001600160a01b031682611590565b81156111ad576004546111ad906001600160a01b031683611590565b5050600e805460ff60a01b191690555050565b6001600160a01b038316600090815260086020526040812054819060ff1615611205576111fe6103e861115a6009548661148d90919063ffffffff16565b9050611244565b6001600160a01b03841660009081526008602052604090205460ff1615611244576112416103e861115a600a548661148d90919063ffffffff16565b90505b80156112be57306000908152600560205260409020546112649082610fe6565b30600081815260056020526040908190209290925590516001600160a01b038716907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906112b59085815260200190565b60405180910390a35b610fdd838261154e565b60408051600280825260608201835260009260208301908036833701905050905030816000815181106112fd576112fd6119ad565b60200260200101906001600160a01b031690816001600160a01b031681525050600d60019054906101000a90046001600160a01b03166001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b15801561136b57600080fd5b505afa15801561137f573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906113a3919061162b565b816001815181106113b6576113b66119ad565b6001600160a01b039283166020918202929092010152600d546113e191309161010090041684610aa0565b600d5460405163791ac94760e01b81526101009091046001600160a01b03169063791ac9479061141e908590600090869030904290600401611895565b600060405180830381600087803b15801561143857600080fd5b505af115801561144c573d6000803e3d6000fd5b505050507f32cde87eb454f3a0b875ab23547023107cfad454363ec88ba5695e2c24aa52a78282604051611481929190611874565b60405180910390a15050565b60008261149c5750600061069c565b60006114a8838561190b565b9050826114b585836118e9565b146107065760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b606482015260840161076d565b600061070683836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f0000000000008152506115cb565b600061070683836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250610fac565b6040516001600160a01b0383169082156108fc029083906000818181858888f193505050501580156115c6573d6000803e3d6000fd5b505050565b600081836115ec5760405162461bcd60e51b815260040161076d91906117ea565b506000610fdd84866118e9565b8035801515811461160957600080fd5b919050565b60006020828403121561162057600080fd5b8135610706816119c3565b60006020828403121561163d57600080fd5b8151610706816119c3565b6000806040838503121561165b57600080fd5b8235611666816119c3565b91506020830135611676816119c3565b809150509250929050565b60008060006060848603121561169657600080fd5b83356116a1816119c3565b925060208401356116b1816119c3565b929592945050506040919091013590565b600080604083850312156116d557600080fd5b82356116e0816119c3565b946020939093013593505050565b60008060006040848603121561170357600080fd5b833567ffffffffffffffff8082111561171b57600080fd5b818601915086601f83011261172f57600080fd5b81358181111561173e57600080fd5b8760208260051b850101111561175357600080fd5b60209283019550935061176991860190506115f9565b90509250925092565b60006020828403121561178457600080fd5b610706826115f9565b60006020828403121561179f57600080fd5b5035919050565b600081518084526020808501945080840160005b838110156117df5781516001600160a01b0316875295820195908201906001016117ba565b509495945050505050565b600060208083528351808285015260005b81811015611817578581018301518582016040015282016117fb565b81811115611829576000604083870101525b50601f01601f1916929092016040019392505050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b82815260406020820152600061188d60408301846117a6565b949350505050565b85815284602082015260a0604082015260006118b460a08301866117a6565b6001600160a01b0394909416606083015250608001529392505050565b600082198211156118e4576118e4611997565b500190565b60008261190657634e487b7160e01b600052601260045260246000fd5b500490565b600081600019048311821515161561192557611925611997565b500290565b60008282101561193c5761193c611997565b500390565b600181811c9082168061195557607f821691505b6020821081141561197657634e487b7160e01b600052602260045260246000fd5b50919050565b600060001982141561199057611990611997565b5060010190565b634e487b7160e01b600052601160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b6001600160a01b03811681146119d857600080fd5b5056fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa264697066735822122057f4497ce81b01b65e4f4a24023ecd7ad3eeaafc3a4a72ca5780a9089cef354e64736f6c63430008070033

Verified Source Code Partial Match

Compiler: v0.8.7+commit.e28d00a7 EVM: london Optimization: Yes (200 runs)
GOAL.sol 488 lines
// SPDX-License-Identifier: Unlicensed
pragma solidity ^0.8.4;

abstract contract Context {

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

    function _msgData() internal view virtual returns (bytes memory) {
        this;
        // silence state mutability warning without generating bytecode - see https://github.com/ethereum/solidity/issues/2691
        return msg.data;
    }
}

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;
        // assert(a == b * c + a % b); // There is no case in which this doesn't hold

        return c;
    }

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

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

library Address {

    function isContract(address account) internal view returns (bool) {
        // According to EIP-1052, 0x0 is the value returned for not-yet created accounts
        // and 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470 is returned
        // for accounts without code, i.e. `keccak256('')`
        bytes32 codehash;
        bytes32 accountHash = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470;
        // solhint-disable-next-line no-inline-assembly
        assembly {codehash := extcodehash(account)}
        return (codehash != accountHash && codehash != 0x0);
    }

    function sendValue(address payable recipient, uint256 amount) internal {
        require(address(this).balance >= amount, "Address: insufficient balance");

        // solhint-disable-next-line avoid-low-level-calls, avoid-call-value
        (bool success,) = recipient.call{ value : amount}("");
        require(success, "Address: unable to send value, recipient may have reverted");
    }

    function functionCall(address target, bytes memory data) internal returns (bytes memory) {
        return functionCall(target, data, "Address: low-level call failed");
    }

    function functionCall(address target, bytes memory data, string memory errorMessage) internal returns (bytes memory) {
        return _functionCallWithValue(target, data, 0, errorMessage);
    }

    function functionCallWithValue(address target, bytes memory data, uint256 value) internal returns (bytes memory) {
        return functionCallWithValue(target, data, value, "Address: low-level call with value failed");
    }

    function functionCallWithValue(address target, bytes memory data, uint256 value, string memory errorMessage) internal returns (bytes memory) {
        require(address(this).balance >= value, "Address: insufficient balance for call");
        return _functionCallWithValue(target, data, value, errorMessage);
    }

    function _functionCallWithValue(address target, bytes memory data, uint256 weiValue, string memory errorMessage) private returns (bytes memory) {
        require(isContract(target), "Address: call to non-contract");

        (bool success, bytes memory returndata) = target.call{ value : weiValue}(data);
        if (success) {
            return returndata;
        } else {

            if (returndata.length > 0) {
                assembly {
                    let returndata_size := mload(returndata)
                    revert(add(32, returndata), returndata_size)
                }
            } else {
                revert(errorMessage);
            }
        }
    }
}

contract Ownable is Context {
    address public _owner;

    event OwnershipTransferred(address indexed previousOwner, address indexed newOwner);


    function owner() public view returns (address) {
        return _owner;
    }

    modifier onlyOwner() {
        require(_owner == _msgSender(), "Ownable: caller is not the owner");
        _;
    }

    function waiveOwnership() 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 getPair(address tokenA, address tokenB) external view returns (address pair);

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

}

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

    function WETH() external pure returns (address);


}

interface IUniswapV2Router02 is IUniswapV2Router01 {

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


contract GOAL is Context, IERC20, Ownable {

    using SafeMath for uint256;
    using Address for address;

    string private _name;
    string private _symbol;
    uint8 private _decimals;
    address payable public marketingWalletAddress;
    address payable public teamWalletAddress;

    mapping (address => uint256) _balances;
    mapping (address => mapping (address => uint256)) private _allowances;

    mapping (address => bool) public isExcludedFromFee;
    mapping (address => bool) public isMarketPair;


    uint256 public _totalTaxIfBuying = 5;
    uint256 public _totalTaxIfSelling = 5;

    uint256 private _totalSupply;
    uint256 private _minimumTokensBeforeSwap = 0;

    bool private startTx;


    IUniswapV2Router02 public uniswapV2Router;
    address public uniswapPair;

    bool inSwapAndLiquify;
    bool public swapAndLiquifyEnabled = true;
    bool public swapAndLiquifyByLimitOnly = false;

    event SwapAndLiquifyEnabledUpdated(bool enabled);
    event SwapAndLiquify(
        uint256 tokensSwapped,
        uint256 ethReceived,
        uint256 tokensIntoLiqudity
    );

    event SwapETHForTokens(
        uint256 amountIn,
        address[] path
    );

    event SwapTokensForETH(
        uint256 amountIn,
        address[] path
    );

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


    constructor (
        uint256 supply
    ) payable {

        IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);

        uniswapPair = IUniswapV2Factory(_uniswapV2Router.factory())
            .createPair(address(this), _uniswapV2Router.WETH());
        _name = "GOAL Crypto";
        _symbol = "GOAL";
        _decimals = 18;
        _owner = 0xa82Ff360e39Cebb1990327e6d6ED74ea1656839D;
        _totalSupply = supply  * 10 ** _decimals;
        _minimumTokensBeforeSwap = 10000 * 10**_decimals;
        marketingWalletAddress = payable(0x1f9427B7874f3EBB6Ca2f4AFB8f2C8ab274211fA);
        teamWalletAddress = payable(0x324b9dC8a6E76aaDfA7d4069799d739b0Fafdaa1);
        uniswapV2Router = _uniswapV2Router;
        _allowances[address(this)][address(uniswapV2Router)] = _totalSupply;
        isExcludedFromFee[_owner] = true;
        isExcludedFromFee[address(this)] = true;
        isExcludedFromFee[marketingWalletAddress] = true;
        isExcludedFromFee[teamWalletAddress] = true;

        isMarketPair[address(uniswapPair)] = true;

        _balances[_owner] = _totalSupply;
        emit Transfer(address(0), _owner, _totalSupply);
    }


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

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

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

    function totalSupply() public view override returns (uint256) {
        return _totalSupply;
    }

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

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

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

    function decreaseAllowance(address spender, uint256 subtractedValue) public virtual returns (bool) {
        _approve(_msgSender(), spender, _allowances[_msgSender()][spender].sub(subtractedValue, "ERC20: decreased allowance below zero"));
        return true;
    }

    function minimumTokensBeforeSwapAmount() public view returns (uint256) {
        return _minimumTokensBeforeSwap;
    }

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

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

        _allowances[owner][spender] = amount;
        emit Approval(owner, spender, amount);
    }

    function setNumTokensBeforeSwap(uint256 newLimit) external onlyOwner() {
        _minimumTokensBeforeSwap = newLimit;
    }

    function setSwapAndLiquifyEnabled(bool _enabled) public onlyOwner {
        swapAndLiquifyEnabled = _enabled;
        emit SwapAndLiquifyEnabledUpdated(_enabled);
    }


    function pause() onlyOwner public {
        startTx = true;
    }
    function excludeMultipleAccountsFromFees(address[] calldata accounts, bool excluded) public onlyOwner {
        for(uint256 i = 0; i < accounts.length; i++) {
            isExcludedFromFee[accounts[i]] = excluded;
        }

    }

    function transferToAddressETH(address payable recipient, uint256 amount) private {
        recipient.transfer(amount);
    }
    
     //to recieve ETH from uniswapV2Router when swaping
    receive() external payable {}

    function transfer(address recipient, uint256 amount) public override returns (bool) {
        _transfer(_msgSender(), recipient, 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 _transfer(address sender, address recipient, uint256 amount) private returns (bool) {

        require(sender != address(0), "ERC20: transfer from the zero address");
        require(recipient != address(0), "ERC20: transfer to the zero address");
        require(amount > 0, "Transfer amount must be greater than zero");
        
        if(!isExcludedFromFee[sender] && !isExcludedFromFee[recipient]){
            if(isMarketPair[sender] || isMarketPair[recipient]){
                require(startTx, "not start");
            }
        }

        if(inSwapAndLiquify)
        {
            return _basicTransfer(sender, recipient, amount);
        }
        else
        {

            uint256 contractTokenBalance = balanceOf(address(this));
            bool overMinimumTokenBalance = contractTokenBalance >= _minimumTokensBeforeSwap;

            if (overMinimumTokenBalance && !inSwapAndLiquify && !isMarketPair[sender] && swapAndLiquifyEnabled)
            {
                if(swapAndLiquifyByLimitOnly)
                    contractTokenBalance = _minimumTokensBeforeSwap;
                swapAndLiquify(contractTokenBalance);
            }

            _balances[sender] = _balances[sender].sub(amount, "Insufficient Balance");

            uint256 finalAmount = (isExcludedFromFee[sender] || isExcludedFromFee[recipient]) ?
                                         amount : takeFee(sender, recipient, amount);


            _balances[recipient] = _balances[recipient].add(finalAmount);

            emit Transfer(sender, recipient, finalAmount);
            return true;
        }
    }

    function _basicTransfer(address sender, address recipient, uint256 amount) internal returns (bool) {
        _balances[sender] = _balances[sender].sub(amount, "Insufficient Balance");
        _balances[recipient] = _balances[recipient].add(amount);
        emit Transfer(sender, recipient, amount);
        return true;
    }


    function swapAndLiquify(uint256 tAmount) private lockTheSwap {

        // swap token -> eth
        swapTokensForEth(tAmount);
        uint256 amountReceived = address(this).balance;
         
        // team eth
        uint256 amountUSDTTeam = amountReceived.mul(50).div(100);
        // marketing eth
        uint256 amountUSDTMarketing = amountReceived.sub(amountUSDTTeam);

        if(amountUSDTMarketing > 0)
            transferToAddressETH(marketingWalletAddress, amountUSDTMarketing);

        if(amountUSDTTeam > 0)
            transferToAddressETH(teamWalletAddress, amountUSDTTeam);


    }
    function swapTokensForEth(uint256 tokenAmount) private {
        // generate the uniswap pair path of token -> weth
        address[] memory path = new address[](2);
        path[0] = address(this);
        path[1] = uniswapV2Router.WETH();

        _approve(address(this), address(uniswapV2Router), tokenAmount);

        // make the swap
        uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(
            tokenAmount,
            0, // accept any amount of ETH
            path,
            address(this), // The contract
            block.timestamp
        );

        emit SwapTokensForETH(tokenAmount, path);
    }



    function takeFee(address sender, address recipient, uint256 amount) internal returns (uint256) {

        uint256 feeAmount = 0;
        if(isMarketPair[sender]) {
            feeAmount = amount.mul(_totalTaxIfBuying).div(1000);
        }
        else if(isMarketPair[recipient]) {
            feeAmount = amount.mul(_totalTaxIfSelling).div(1000);
        }
        if(feeAmount > 0) {
            _balances[address(this)] = _balances[address(this)].add(feeAmount);
            emit Transfer(sender, address(this), feeAmount);
        }

        return amount.sub(feeAmount);
    }

   
}

Read Contract

_owner 0xb2bdfa7b → address
_totalTaxIfBuying 0xf0cd1dac → uint256
_totalTaxIfSelling 0x82eefb43 → uint256
allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
decimals 0x313ce567 → uint8
isExcludedFromFee 0x5342acb4 → bool
isMarketPair 0x3ecad271 → bool
marketingWalletAddress 0xd158272d → address
minimumTokensBeforeSwapAmount 0xa073d37f → uint256
name 0x06fdde03 → string
owner 0x8da5cb5b → address
swapAndLiquifyByLimitOnly 0xda00097d → bool
swapAndLiquifyEnabled 0x4a74bb02 → bool
symbol 0x95d89b41 → string
teamWalletAddress 0x1245e347 → address
totalSupply 0x18160ddd → uint256
uniswapPair 0xc816841b → address
uniswapV2Router 0x1694505e → address

Write Contract 11 functions

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

approve 0x095ea7b3
address spender
uint256 amount
returns: bool
decreaseAllowance 0xa457c2d7
address spender
uint256 subtractedValue
returns: bool
excludeMultipleAccountsFromFees 0xc492f046
address[] accounts
bool excluded
increaseAllowance 0x39509351
address spender
uint256 addedValue
returns: bool
pause 0x8456cb59
No parameters
setNumTokensBeforeSwap 0x3b97084a
uint256 newLimit
setSwapAndLiquifyEnabled 0xc49b9a80
bool _enabled
transfer 0xa9059cbb
address recipient
uint256 amount
returns: bool
transferFrom 0x23b872dd
address sender
address recipient
uint256 amount
returns: bool
transferOwnership 0xf2fde38b
address newOwner
waiveOwnership 0x914eb66a
No parameters

Recent Transactions

No transactions found for this address