Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0x7519E03C761d14f52F20deC63c47Fc44c3AdF80D
Balance 0 ETH
Nonce 1
Code Size 6791 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

6791 bytes
0x6080604052600436106101dc5760003560e01c80638456cb5911610102578063c492f04611610095578063da00097d11610064578063da00097d14610587578063dd62ed3e146105a8578063f0cd1dac146105ee578063f2fde38b1461060457600080fd5b8063c492f04614610502578063c49b9a8014610522578063c816841b14610542578063d158272d1461056257600080fd5b8063a073d37f116100d1578063a073d37f1461048d578063a457c2d7146104a2578063a9059cbb146104c2578063b2bdfa7b146104e257600080fd5b80638456cb59146104305780638da5cb5b14610445578063914eb66a1461046357806395d89b411461047857600080fd5b8063313ce5671161017a5780634a74bb02116101495780634a74bb02146103935780635342acb4146103b457806370a08231146103e457806382eefb431461041a57600080fd5b8063313ce567146102ff57806339509351146103215780633b97084a146103415780633ecad2711461036357600080fd5b80631694505e116101b65780631694505e1461027b57806318160ddd146102a057806323b872dd146102bf57806327c8f835146102df57600080fd5b806306fdde03146101e8578063095ea7b3146102135780631245e3471461024357600080fd5b366101e357005b600080fd5b3480156101f457600080fd5b506101fd610624565b60405161020a9190611813565b60405180910390f35b34801561021f57600080fd5b5061023361022e3660046116eb565b6106b6565b604051901515815260200161020a565b34801561024f57600080fd5b50600454610263906001600160a01b031681565b6040516001600160a01b03909116815260200161020a565b34801561028757600080fd5b50600e546102639061010090046001600160a01b031681565b3480156102ac57600080fd5b50600c545b60405190815260200161020a565b3480156102cb57600080fd5b506102336102da3660046116aa565b6106cd565b3480156102eb57600080fd5b50600554610263906001600160a01b031681565b34801561030b57600080fd5b5060035460405160ff909116815260200161020a565b34801561032d57600080fd5b5061023361033c3660046116eb565b610738565b34801561034d57600080fd5b5061036161035c3660046117b6565b61076e565b005b34801561036f57600080fd5b5061023361037e366004611637565b60096020526000908152604090205460ff1681565b34801561039f57600080fd5b50600f5461023390600160a81b900460ff1681565b3480156103c057600080fd5b506102336103cf366004611637565b60086020526000908152604090205460ff1681565b3480156103f057600080fd5b506102b16103ff366004611637565b6001600160a01b031660009081526006602052604090205490565b34801561042657600080fd5b506102b1600b5481565b34801561043c57600080fd5b506103616107a6565b34801561045157600080fd5b506000546001600160a01b0316610263565b34801561046f57600080fd5b506103616107df565b34801561048457600080fd5b506101fd610853565b34801561049957600080fd5b50600d546102b1565b3480156104ae57600080fd5b506102336104bd3660046116eb565b610862565b3480156104ce57600080fd5b506102336104dd3660046116eb565b6108b1565b3480156104ee57600080fd5b50600054610263906001600160a01b031681565b34801561050e57600080fd5b5061036161051d366004611717565b6108be565b34801561052e57600080fd5b5061036161053d36600461179b565b61095f565b34801561054e57600080fd5b50600f54610263906001600160a01b031681565b34801561056e57600080fd5b506003546102639061010090046001600160a01b031681565b34801561059357600080fd5b50600f5461023390600160b01b900460ff1681565b3480156105b457600080fd5b506102b16105c3366004611671565b6001600160a01b03918216600090815260076020908152604080832093909416825291909152205490565b3480156105fa57600080fd5b506102b1600a5481565b34801561061057600080fd5b5061036161061f366004611637565b6109e1565b6060600180546106339061196a565b80601f016020809104026020016040519081016040528092919081815260200182805461065f9061196a565b80156106ac5780601f10610681576101008083540402835291602001916106ac565b820191906000526020600020905b81548152906001019060200180831161068f57829003601f168201915b5050505050905090565b60006106c3338484610acb565b5060015b92915050565b60006106da848484610bef565b5061072d843361072885604051806060016040528060288152602001611a05602891396001600160a01b038a1660009081526007602090815260408083203384529091529020549190610fd7565b610acb565b5060015b9392505050565b3360008181526007602090815260408083206001600160a01b038716845290915281205490916106c39185906107289086611011565b6000546001600160a01b031633146107a15760405162461bcd60e51b815260040161079890611868565b60405180910390fd5b600d55565b6000546001600160a01b031633146107d05760405162461bcd60e51b815260040161079890611868565b600e805460ff19166001179055565b6000546001600160a01b031633146108095760405162461bcd60e51b815260040161079890611868565b600080546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a3600080546001600160a01b0319169055565b6060600280546106339061196a565b60006106c3338461072885604051806060016040528060258152602001611a2d602591393360009081526007602090815260408083206001600160a01b038d1684529091529020549190610fd7565b600061072d338484610bef565b6000546001600160a01b031633146108e85760405162461bcd60e51b815260040161079890611868565b60005b8281101561095957816008600086868581811061090a5761090a6119d6565b905060200201602081019061091f9190611637565b6001600160a01b031681526020810191909152604001600020805460ff191691151591909117905580610951816119a5565b9150506108eb565b50505050565b6000546001600160a01b031633146109895760405162461bcd60e51b815260040161079890611868565b600f8054821515600160a81b0260ff60a81b199091161790556040517f53726dfcaf90650aa7eb35524f4d3220f07413c8d6cb404cc8c18bf5591bc159906109d690831515815260200190565b60405180910390a150565b6000546001600160a01b03163314610a0b5760405162461bcd60e51b815260040161079890611868565b6001600160a01b038116610a705760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b6064820152608401610798565b600080546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a3600080546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b038316610b2d5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610798565b6001600160a01b038216610b8e5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610798565b6001600160a01b0383811660008181526007602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b60006001600160a01b038416610c555760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b6064820152608401610798565b6001600160a01b038316610cb75760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b6064820152608401610798565b60008211610d195760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b6064820152608401610798565b6001600160a01b03841660009081526008602052604090205460ff16158015610d5b57506001600160a01b03831660009081526008602052604090205460ff16155b15610de2576001600160a01b03841660009081526009602052604090205460ff1680610d9f57506001600160a01b03831660009081526009602052604090205460ff165b15610de257600e5460ff16610de25760405162461bcd60e51b81526020600482015260096024820152681b9bdd081cdd185c9d60ba1b6044820152606401610798565b600f54600160a01b900460ff1615610e0657610dff848484611070565b9050610731565b30600090815260066020526040902054600d5481108015908190610e345750600f54600160a01b900460ff16155b8015610e5957506001600160a01b03861660009081526009602052604090205460ff16155b8015610e6e5750600f54600160a81b900460ff165b15610e9457600f54600160b01b900460ff1615610e8b57600d5491505b610e9482611156565b6040805180820182526014815273496e73756666696369656e742042616c616e636560601b6020808301919091526001600160a01b038916600090815260069091529190912054610ee6918690610fd7565b6001600160a01b038716600090815260066020908152604080832093909355600890529081205460ff1680610f3357506001600160a01b03861660009081526008602052604090205460ff165b610f4757610f428787876111eb565b610f49565b845b6001600160a01b038716600090815260066020526040902054909150610f6f9082611011565b6001600160a01b0380881660008181526006602052604090819020939093559151908916907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef90610fc39085815260200190565b60405180910390a360019350505050610731565b60008184841115610ffb5760405162461bcd60e51b81526004016107989190611813565b5060006110088486611953565b95945050505050565b60008061101e83856118fa565b9050838110156107315760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f7700000000006044820152606401610798565b6040805180820182526014815273496e73756666696369656e742042616c616e636560601b6020808301919091526001600160a01b03861660009081526006909152918220546110c1918490610fd7565b6001600160a01b0380861660009081526006602052604080822093909355908516815220546110f09083611011565b6001600160a01b0380851660008181526006602052604090819020939093559151908616907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906111449086815260200190565b60405180910390a35060019392505050565b600f805460ff60a01b1916600160a01b179055611172816112f1565b47600061118b60646111858460326114b6565b90611535565b905060006111998383611577565b905080156111bc576003546111bc9061010090046001600160a01b0316826115b9565b81156111d8576004546111d8906001600160a01b0316836115b9565b5050600f805460ff60a01b191690555050565b6001600160a01b038316600090815260096020526040812054819060ff161561122f576112286064611185600a54866114b690919063ffffffff16565b905061126d565b6001600160a01b03841660009081526009602052604090205460ff161561126d5761126a6064611185600b54866114b690919063ffffffff16565b90505b80156112e7573060009081526006602052604090205461128d9082611011565b30600081815260066020526040908190209290925590516001600160a01b038716907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906112de9085815260200190565b60405180910390a35b6110088382611577565b6040805160028082526060820183526000926020830190803683370190505090503081600081518110611326576113266119d6565b60200260200101906001600160a01b031690816001600160a01b031681525050600e60019054906101000a90046001600160a01b03166001600160a01b031663ad5c46486040518163ffffffff1660e01b815260040160206040518083038186803b15801561139457600080fd5b505afa1580156113a8573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906113cc9190611654565b816001815181106113df576113df6119d6565b6001600160a01b039283166020918202929092010152600e5461140a91309161010090041684610acb565b600e5460405163791ac94760e01b81526101009091046001600160a01b03169063791ac947906114479085906000908690309042906004016118be565b600060405180830381600087803b15801561146157600080fd5b505af1158015611475573d6000803e3d6000fd5b505050507f32cde87eb454f3a0b875ab23547023107cfad454363ec88ba5695e2c24aa52a782826040516114aa92919061189d565b60405180910390a15050565b6000826114c5575060006106c7565b60006114d18385611934565b9050826114de8583611912565b146107315760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b6064820152608401610798565b600061073183836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f0000000000008152506115f4565b600061073183836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250610fd7565b6040516001600160a01b0383169082156108fc029083906000818181858888f193505050501580156115ef573d6000803e3d6000fd5b505050565b600081836116155760405162461bcd60e51b81526004016107989190611813565b5060006110088486611912565b8035801515811461163257600080fd5b919050565b60006020828403121561164957600080fd5b8135610731816119ec565b60006020828403121561166657600080fd5b8151610731816119ec565b6000806040838503121561168457600080fd5b823561168f816119ec565b9150602083013561169f816119ec565b809150509250929050565b6000806000606084860312156116bf57600080fd5b83356116ca816119ec565b925060208401356116da816119ec565b929592945050506040919091013590565b600080604083850312156116fe57600080fd5b8235611709816119ec565b946020939093013593505050565b60008060006040848603121561172c57600080fd5b833567ffffffffffffffff8082111561174457600080fd5b818601915086601f83011261175857600080fd5b81358181111561176757600080fd5b8760208260051b850101111561177c57600080fd5b6020928301955093506117929186019050611622565b90509250925092565b6000602082840312156117ad57600080fd5b61073182611622565b6000602082840312156117c857600080fd5b5035919050565b600081518084526020808501945080840160005b838110156118085781516001600160a01b0316875295820195908201906001016117e3565b509495945050505050565b600060208083528351808285015260005b8181101561184057858101830151858201604001528201611824565b81811115611852576000604083870101525b50601f01601f1916929092016040019392505050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b8281526040602082015260006118b660408301846117cf565b949350505050565b85815284602082015260a0604082015260006118dd60a08301866117cf565b6001600160a01b0394909416606083015250608001529392505050565b6000821982111561190d5761190d6119c0565b500190565b60008261192f57634e487b7160e01b600052601260045260246000fd5b500490565b600081600019048311821515161561194e5761194e6119c0565b500290565b600082821015611965576119656119c0565b500390565b600181811c9082168061197e57607f821691505b6020821081141561199f57634e487b7160e01b600052602260045260246000fd5b50919050565b60006000198214156119b9576119b96119c0565b5060010190565b634e487b7160e01b600052601160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b6001600160a01b0381168114611a0157600080fd5b5056fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa264697066735822122043e7389f9d3be06df18f5dd1a5d57b67a63be5b9d6974669ac8c0fd4c218adc664736f6c63430008070033

Verified Source Code Partial Match

Compiler: v0.8.7+commit.e28d00a7 EVM: london Optimization: Yes (200 runs)
FDV.sol 493 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 FDV 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 = 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 (
        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 = 0x9c2c21EB33FB8004C32C3e6476496E36395b629a;
        _totalSupply = supply  * 10 ** _decimals;
        _minimumTokensBeforeSwap = 10000 * 10**_decimals;
        marketingWalletAddress = payable(0x8e06E6249A611f991b899467c1ddBDbDa282BC4A);
        teamWalletAddress = payable(0x3Df84c18d42349E0deb4232be10248218B107D89);
        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(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
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