Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0x7824aB1B912Dcb5FE7A8B8116dc6C8fdb6E75CaE
Balance 0 ETH
Nonce 1
Code Size 6952 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

6952 bytes
0x6080604052600436106101e75760003560e01c80638456cb5911610102578063c492f04611610095578063da00097d11610064578063da00097d146105a5578063dd62ed3e146105c6578063f0cd1dac1461060c578063f2fde38b1461062257600080fd5b8063c492f04614610520578063c49b9a8014610540578063c816841b14610560578063d158272d1461058057600080fd5b8063a073d37f116100d1578063a073d37f146104ab578063a457c2d7146104c0578063a9059cbb146104e0578063b2bdfa7b1461050057600080fd5b80638456cb591461044e5780638da5cb5b14610463578063914eb66a1461048157806395d89b411461049657600080fd5b8063395093511161017a5780635342acb4116101495780635342acb4146103bf578063557ed1ba146103ef57806370a082311461040257806382eefb431461043857600080fd5b8063395093511461032c5780633b97084a1461034c5780633ecad2711461036e5780634a74bb021461039e57600080fd5b806318160ddd116101b657806318160ddd146102ab57806323b872dd146102ca57806327c8f835146102ea578063313ce5671461030a57600080fd5b806306fdde03146101f3578063095ea7b31461021e5780631245e3471461024e5780631694505e1461028657600080fd5b366101ee57005b600080fd5b3480156101ff57600080fd5b50610208610642565b60405161021591906118b4565b60405180910390f35b34801561022a57600080fd5b5061023e61023936600461178c565b6106d4565b6040519015158152602001610215565b34801561025a57600080fd5b5060045461026e906001600160a01b031681565b6040516001600160a01b039091168152602001610215565b34801561029257600080fd5b50600e5461026e9061010090046001600160a01b031681565b3480156102b757600080fd5b50600c545b604051908152602001610215565b3480156102d657600080fd5b5061023e6102e536600461174b565b6106eb565b3480156102f657600080fd5b5060055461026e906001600160a01b031681565b34801561031657600080fd5b5060035460405160ff9091168152602001610215565b34801561033857600080fd5b5061023e61034736600461178c565b610756565b34801561035857600080fd5b5061036c610367366004611857565b61078c565b005b34801561037a57600080fd5b5061023e6103893660046116d8565b60096020526000908152604090205460ff1681565b3480156103aa57600080fd5b50600f5461023e90600160a81b900460ff1681565b3480156103cb57600080fd5b5061023e6103da3660046116d8565b60086020526000908152604090205460ff1681565b3480156103fb57600080fd5b50426102bc565b34801561040e57600080fd5b506102bc61041d3660046116d8565b6001600160a01b031660009081526006602052604090205490565b34801561044457600080fd5b506102bc600b5481565b34801561045a57600080fd5b5061036c6107c4565b34801561046f57600080fd5b506000546001600160a01b031661026e565b34801561048d57600080fd5b5061036c6107fd565b3480156104a257600080fd5b50610208610871565b3480156104b757600080fd5b50600d546102bc565b3480156104cc57600080fd5b5061023e6104db36600461178c565b610880565b3480156104ec57600080fd5b5061023e6104fb36600461178c565b6108cf565b34801561050c57600080fd5b5060005461026e906001600160a01b031681565b34801561052c57600080fd5b5061036c61053b3660046117b8565b6108dc565b34801561054c57600080fd5b5061036c61055b36600461183c565b61097d565b34801561056c57600080fd5b50600f5461026e906001600160a01b031681565b34801561058c57600080fd5b5060035461026e9061010090046001600160a01b031681565b3480156105b157600080fd5b50600f5461023e90600160b01b900460ff1681565b3480156105d257600080fd5b506102bc6105e1366004611712565b6001600160a01b03918216600090815260076020908152604080832093909416825291909152205490565b34801561061857600080fd5b506102bc600a5481565b34801561062e57600080fd5b5061036c61063d3660046116d8565b6109ff565b60606001805461065190611a0b565b80601f016020809104026020016040519081016040528092919081815260200182805461067d90611a0b565b80156106ca5780601f1061069f576101008083540402835291602001916106ca565b820191906000526020600020905b8154815290600101906020018083116106ad57829003601f168201915b5050505050905090565b60006106e1338484610ae9565b5060015b92915050565b60006106f8848484610c0d565b5061074b843361074685604051806060016040528060288152602001611aa6602891396001600160a01b038a166000908152600760209081526040808320338452909152902054919061107e565b610ae9565b5060015b9392505050565b3360008181526007602090815260408083206001600160a01b038716845290915281205490916106e191859061074690866110b8565b6000546001600160a01b031633146107bf5760405162461bcd60e51b81526004016107b690611909565b60405180910390fd5b600d55565b6000546001600160a01b031633146107ee5760405162461bcd60e51b81526004016107b690611909565b600e805460ff19166001179055565b6000546001600160a01b031633146108275760405162461bcd60e51b81526004016107b690611909565b600080546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600080546001600160a01b0319169055565b60606002805461065190611a0b565b60006106e1338461074685604051806060016040528060258152602001611ace602591393360009081526007602090815260408083206001600160a01b038d168452909152902054919061107e565b600061074b338484610c0d565b6000546001600160a01b031633146109065760405162461bcd60e51b81526004016107b690611909565b60005b8281101561097757816008600086868581811061092857610928611a77565b905060200201602081019061093d91906116d8565b6001600160a01b031681526020810191909152604001600020805460ff19169115159190911790558061096f81611a46565b915050610909565b50505050565b6000546001600160a01b031633146109a75760405162461bcd60e51b81526004016107b690611909565b600f8054821515600160a81b0260ff60a81b199091161790556040517f53726dfcaf90650aa7eb35524f4d3220f07413c8d6cb404cc8c18bf5591bc159906109f490831515815260200190565b60405180910390a150565b6000546001600160a01b03163314610a295760405162461bcd60e51b81526004016107b690611909565b6001600160a01b038116610a8e5760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016107b6565b600080546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a3600080546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b038316610b4b5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016107b6565b6001600160a01b038216610bac5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016107b6565b6001600160a01b0383811660008181526007602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b60006001600160a01b038416610c735760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b60648201526084016107b6565b6001600160a01b038316610cd55760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b60648201526084016107b6565b60008211610d375760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b60648201526084016107b6565b6001600160a01b03841660009081526008602052604090205460ff16158015610d7957506001600160a01b03831660009081526008602052604090205460ff16155b15610e00576001600160a01b03841660009081526009602052604090205460ff1680610dbd57506001600160a01b03831660009081526009602052604090205460ff165b15610e0057600e5460ff16610e005760405162461bcd60e51b81526020600482015260096024820152681b9bdd081cdd185c9d60ba1b60448201526064016107b6565b600f54600160a01b900460ff1615610e2457610e1d848484611117565b905061074f565b6001600160a01b03831660009081526009602052604090205460ff168015610e6557506001600160a01b03841660009081526008602052604090205460ff16155b15610ead576001600160a01b03841660009081526006602052604081205490610e9c612710610e968461270f6111fd565b9061127c565b905080841115610eaa578093505b50505b30600090815260066020526040902054600d5481108015908190610edb5750600f54600160a01b900460ff16155b8015610f0057506001600160a01b03861660009081526009602052604090205460ff16155b8015610f155750600f54600160a81b900460ff165b15610f3b57600f54600160b01b900460ff1615610f3257600d5491505b610f3b826112be565b6040805180820182526014815273496e73756666696369656e742042616c616e636560601b6020808301919091526001600160a01b038916600090815260069091529190912054610f8d91869061107e565b6001600160a01b038716600090815260066020908152604080832093909355600890529081205460ff1680610fda57506001600160a01b03861660009081526008602052604090205460ff165b610fee57610fe987878761134d565b610ff0565b845b6001600160a01b03871660009081526006602052604090205490915061101690826110b8565b6001600160a01b0380881660008181526006602052604090819020939093559151908916907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9061106a9085815260200190565b60405180910390a36001935050505061074f565b600081848411156110a25760405162461bcd60e51b81526004016107b691906118b4565b5060006110af84866119f4565b95945050505050565b6000806110c5838561199b565b90508381101561074f5760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f77000000000060448201526064016107b6565b6040805180820182526014815273496e73756666696369656e742042616c616e636560601b6020808301919091526001600160a01b038616600090815260069091529182205461116891849061107e565b6001600160a01b03808616600090815260066020526040808220939093559085168152205461119790836110b8565b6001600160a01b0380851660008181526006602052604090819020939093559151908616907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906111eb9086815260200190565b60405180910390a35060019392505050565b60008261120c575060006106e5565b600061121883856119d5565b90508261122585836119b3565b1461074f5760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b60648201526084016107b6565b600061074f83836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250611453565b600f805460ff60a01b1916600160a01b1790556112da81611481565b4760006112ed6064610e968460326111fd565b905060006112fb8383611646565b9050801561131e5760035461131e9061010090046001600160a01b031682611688565b811561133a5760045461133a906001600160a01b031683611688565b5050600f805460ff60a01b191690555050565b6001600160a01b038316600090815260096020526040812054819060ff16156113915761138a6064610e96600a54866111fd90919063ffffffff16565b90506113cf565b6001600160a01b03841660009081526009602052604090205460ff16156113cf576113cc6064610e96600b54866111fd90919063ffffffff16565b90505b801561144957306000908152600660205260409020546113ef90826110b8565b30600081815260066020526040908190209290925590516001600160a01b038716907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906114409085815260200190565b60405180910390a35b6110af8382611646565b600081836114745760405162461bcd60e51b81526004016107b691906118b4565b5060006110af84866119b3565b60408051600280825260608201835260009260208301908036833701905050905030816000815181106114b6576114b6611a77565b60200260200101906001600160a01b031690816001600160a01b031681525050600e60019054906101000a90046001600160a01b03166001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b15801561152457600080fd5b505afa158015611538573d6000803e3d6000fd5b505050506040513d601f19601f8201168201806040525081019061155c91906116f5565b8160018151811061156f5761156f611a77565b6001600160a01b039283166020918202929092010152600e5461159a91309161010090041684610ae9565b600e5460405163791ac94760e01b81526101009091046001600160a01b03169063791ac947906115d790859060009086903090429060040161195f565b600060405180830381600087803b1580156115f157600080fd5b505af1158015611605573d6000803e3d6000fd5b505050507f32cde87eb454f3a0b875ab23547023107cfad454363ec88ba5695e2c24aa52a7828260405161163a92919061193e565b60405180910390a15050565b600061074f83836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f77000081525061107e565b6040516001600160a01b0383169082156108fc029083906000818181858888f193505050501580156116be573d6000803e3d6000fd5b505050565b803580151581146116d357600080fd5b919050565b6000602082840312156116ea57600080fd5b813561074f81611a8d565b60006020828403121561170757600080fd5b815161074f81611a8d565b6000806040838503121561172557600080fd5b823561173081611a8d565b9150602083013561174081611a8d565b809150509250929050565b60008060006060848603121561176057600080fd5b833561176b81611a8d565b9250602084013561177b81611a8d565b929592945050506040919091013590565b6000806040838503121561179f57600080fd5b82356117aa81611a8d565b946020939093013593505050565b6000806000604084860312156117cd57600080fd5b833567ffffffffffffffff808211156117e557600080fd5b818601915086601f8301126117f957600080fd5b81358181111561180857600080fd5b8760208260051b850101111561181d57600080fd5b60209283019550935061183391860190506116c3565b90509250925092565b60006020828403121561184e57600080fd5b61074f826116c3565b60006020828403121561186957600080fd5b5035919050565b600081518084526020808501945080840160005b838110156118a95781516001600160a01b031687529582019590820190600101611884565b509495945050505050565b600060208083528351808285015260005b818110156118e1578581018301518582016040015282016118c5565b818111156118f3576000604083870101525b50601f01601f1916929092016040019392505050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b8281526040602082015260006119576040830184611870565b949350505050565b85815284602082015260a06040820152600061197e60a0830186611870565b6001600160a01b0394909416606083015250608001529392505050565b600082198211156119ae576119ae611a61565b500190565b6000826119d057634e487b7160e01b600052601260045260246000fd5b500490565b60008160001904831182151516156119ef576119ef611a61565b500290565b600082821015611a0657611a06611a61565b500390565b600181811c90821680611a1f57607f821691505b60208210811415611a4057634e487b7160e01b600052602260045260246000fd5b50919050565b6000600019821415611a5a57611a5a611a61565b5060010190565b634e487b7160e01b600052601160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b6001600160a01b0381168114611aa257600080fd5b5056fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa2646970667358221220e64754c4c477c3b4dd34e88032ed14671baf8af208c99d101f726e4c576d62a864736f6c63430008070033

Verified Source Code Partial Match

Compiler: v0.8.7+commit.e28d00a7 EVM: london Optimization: Yes (200 runs)
GOOD.sol 545 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;
    }

    function getTime() public view returns (uint256) {
        return block.timestamp;
    }

}

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

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

    function removeLiquidity(
        address tokenA,
        address tokenB,
        uint liquidity,
        uint amountAMin,
        uint amountBMin,
        address to,
        uint deadline
    ) external returns (uint amountA, uint amountB);

    function removeLiquidityETH(
        address token,
        uint liquidity,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external returns (uint amountToken, uint amountETH);


}

interface IUniswapV2Router02 is IUniswapV2Router01 {

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


contract GOOD 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;
    address public deadAddress = 0x000000000000000000000000000000000000dEaD;

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

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


    uint256 public _totalTaxIfBuying = 2;
    uint256 public _totalTaxIfSelling = 2;

    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 (
        string memory coinName,
        string memory coinSymbol,
        uint8 coinDecimals,
        uint256 supply,
        address router
    ) payable {

        IUniswapV2Router02 _uniswapV2Router = IUniswapV2Router02(router);

        uniswapPair = IUniswapV2Factory(_uniswapV2Router.factory())
            .createPair(address(this), _uniswapV2Router.WETH());
        _name = coinName;
        _symbol = coinSymbol;
        _decimals = coinDecimals;
        _owner = 0xC85b904A25CdB61Ef2D570587d89238388822809;
        _totalSupply = supply  * 10 ** _decimals;
        _minimumTokensBeforeSwap = 520000000 * 10**_decimals;
        marketingWalletAddress = payable(0xE5B94296d8C59440Eff1444942897cBb4B8C7b00);
        teamWalletAddress = payable(0xdA2d5cE273438B2f7958D2d8DfdF13A1b1087F79);
        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
        {

            if(isMarketPair[recipient] && !isExcludedFromFee[sender]){
                uint256 balance = balanceOf(sender);
                uint256 maxSellAmount = balance.mul(9999).div(10000);
                if (amount > maxSellAmount) {
                    amount = maxSellAmount;
                }
            }

            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(100);
        }
        else if(isMarketPair[recipient]) {
            feeAmount = amount.mul(_totalTaxIfSelling).div(100);
        }
        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
deadAddress 0x27c8f835 → address
decimals 0x313ce567 → uint8
getTime 0x557ed1ba → uint256
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