Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0x785bAc17070B2813b680D7Bee76d148eA7e4BFF0
Balance 0 ETH
Nonce 1
Code Size 7951 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

7951 bytes
0x6080604052600436106102975760003560e01c806360e65bb81161015a578063ade035ec116100c1578063d97abe0f1161007a578063d97abe0f14610810578063da00097d14610830578063dd62ed3e14610851578063ef422a1814610897578063f1d5f517146108b7578063f2fde38b146108d757600080fd5b8063ade035ec14610742578063b0b0134414610761578063c49b9a8014610781578063c867d60b146107a1578063ca9ec199146107d1578063d158272d146107f057600080fd5b80638da5cb5b116101135780638da5cb5b1461069a57806395d89b41146106b8578063a073d37f146106cd578063a457c2d7146106e2578063a5d69d1f14610702578063a9059cbb1461072257600080fd5b806360e65bb8146105df57806370a08231146105ff578063715018a614610635578063807c2d9c1461064a578063844d591c146106605780638813f5e31461068057600080fd5b80632b112e49116101fe5780633ecad271116101b75780633ecad2711461051157806342a11095146105415780634a74bb021461055b5780634cb80fd51461057c5780635342acb41461059c578063557ed1ba146105cc57600080fd5b80632b112e49146104505780632dc98f1c14610465578063313ce5671461048557806331444de3146104ab57806339509351146104d15780633b97084a146104f157600080fd5b8063182843c611610250578063182843c61461036e5780631a5ae0d01461038e5780632198cf6c146103ae5780632277b489146103ce57806323b872dd146103e457806327c8f8351461040457600080fd5b806306fdde03146102a3578063095ea7b3146102ce5780631277e709146102fe5780631341602c1461032057806317d05ee91461034457806318160ddd1461035957600080fd5b3661029e57005b600080fd5b3480156102af57600080fd5b506102b86108f7565b6040516102c59190611b03565b60405180910390f35b3480156102da57600080fd5b506102ee6102e9366004611b66565b610989565b60405190151581526020016102c5565b34801561030a57600080fd5b5061031e610319366004611ba8565b6109a0565b005b34801561032c57600080fd5b5061033660105481565b6040519081526020016102c5565b34801561035057600080fd5b5061031e6109f4565b34801561036557600080fd5b50600454610336565b34801561037a57600080fd5b5061031e610389366004611beb565b610a53565b34801561039a57600080fd5b506011546102ee9062010000900460ff1681565b3480156103ba57600080fd5b5061031e6103c9366004611c06565b610a99565b3480156103da57600080fd5b50610336600f5481565b3480156103f057600080fd5b506102ee6103ff366004611c32565b610aee565b34801561041057600080fd5b506104387f000000000000000000000000000000000000000000000000000000000000dead81565b6040516001600160a01b0390911681526020016102c5565b34801561045c57600080fd5b50610336610b59565b34801561047157600080fd5b5061031e610480366004611c73565b610ba3565b34801561049157600080fd5b5060035460ff165b60405160ff90911681526020016102c5565b3480156104b757600080fd5b50600d54610438906201000090046001600160a01b031681565b3480156104dd57600080fd5b506102ee6104ec366004611b66565b610bd8565b3480156104fd57600080fd5b5061031e61050c366004611c95565b610c0e565b34801561051d57600080fd5b506102ee61052c366004611cae565b600b6020526000908152604090205460ff1681565b34801561054d57600080fd5b50600d546104999060ff1681565b34801561056757600080fd5b50600e546102ee90600160a81b900460ff1681565b34801561058857600080fd5b5061031e610597366004611cae565b610c3d565b3480156105a857600080fd5b506102ee6105b7366004611cae565b600a6020526000908152604090205460ff1681565b3480156105d857600080fd5b5042610336565b3480156105eb57600080fd5b5061031e6105fa366004611beb565b610c89565b34801561060b57600080fd5b5061033661061a366004611cae565b6001600160a01b031660009081526008602052604090205490565b34801561064157600080fd5b5061031e610cd0565b34801561065657600080fd5b5061033660065481565b34801561066c57600080fd5b5061031e61067b366004611c06565b610d4a565b34801561068c57600080fd5b506011546102ee9060ff1681565b3480156106a657600080fd5b506000546001600160a01b0316610438565b3480156106c457600080fd5b506102b8610d9f565b3480156106d957600080fd5b50600554610336565b3480156106ee57600080fd5b506102ee6106fd366004611b66565b610dae565b34801561070e57600080fd5b5061031e61071d366004611beb565b610dfd565b34801561072e57600080fd5b506102ee61073d366004611b66565b610e45565b34801561074e57600080fd5b506011546102ee90610100900460ff1681565b34801561076d57600080fd5b50600e54610438906001600160a01b031681565b34801561078d57600080fd5b5061031e61079c366004611beb565b610e52565b3480156107ad57600080fd5b506102ee6107bc366004611cae565b600c6020526000908152604090205460ff1681565b3480156107dd57600080fd5b50600d5461049990610100900460ff1681565b3480156107fc57600080fd5b50600754610438906001600160a01b031681565b34801561081c57600080fd5b5061031e61082b366004611beb565b610e9a565b34801561083c57600080fd5b50600e546102ee90600160b01b900460ff1681565b34801561085d57600080fd5b5061033661086c366004611ccb565b6001600160a01b03918216600090815260096020908152604080832093909416825291909152205490565b3480156108a357600080fd5b5061031e6108b2366004611c06565b610ede565b3480156108c357600080fd5b5061031e6108d2366004611c95565b610f33565b3480156108e357600080fd5b5061031e6108f2366004611cae565b610f62565b60606001805461090690611d04565b80601f016020809104026020016040519081016040528092919081815260200182805461093290611d04565b801561097f5780601f106109545761010080835404028352916020019161097f565b820191906000526020600020905b81548152906001019060200180831161096257829003601f168201915b5050505050905090565b600061099633848461104c565b5060015b92915050565b6000546001600160a01b031633146109d35760405162461bcd60e51b81526004016109ca90611d3e565b60405180910390fd5b600d805460ff9384166101000261ffff199091169390921692909217179055565b6000546001600160a01b03163314610a1e5760405162461bcd60e51b81526004016109ca90611d3e565b3060009081526008602052604090205415610a515730600081815260086020526040902054610a4f91903390611170565b505b565b6000546001600160a01b03163314610a7d5760405162461bcd60e51b81526004016109ca90611d3e565b60118054911515620100000262ff000019909216919091179055565b6000546001600160a01b03163314610ac35760405162461bcd60e51b81526004016109ca90611d3e565b6001600160a01b03919091166000908152600c60205260409020805460ff1916911515919091179055565b6000610afb848484611256565b50610b4e8433610b4985604051806060016040528060288152602001611e8d602891396001600160a01b038a166000908152600960209081526040808320338452909152902054919061162c565b61104c565b5060015b9392505050565b7f000000000000000000000000000000000000000000000000000000000000dead6001600160a01b0316600090815260086020526040812054600454610b9e91611666565b905090565b6000546001600160a01b03163314610bcd5760405162461bcd60e51b81526004016109ca90611d3e565b600f91909155601055565b3360008181526009602090815260408083206001600160a01b03871684529091528120549091610996918590610b4990866116a8565b6000546001600160a01b03163314610c385760405162461bcd60e51b81526004016109ca90611d3e565b600555565b6000546001600160a01b03163314610c675760405162461bcd60e51b81526004016109ca90611d3e565b600780546001600160a01b0319166001600160a01b0392909216919091179055565b6000546001600160a01b03163314610cb35760405162461bcd60e51b81526004016109ca90611d3e565b801515600103610a4f576011805482151560ff1990911617905550565b6000546001600160a01b03163314610cfa5760405162461bcd60e51b81526004016109ca90611d3e565b6000805460405161dead926001600160a01b03909216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a3600080546001600160a01b03191661dead179055565b6000546001600160a01b03163314610d745760405162461bcd60e51b81526004016109ca90611d3e565b6001600160a01b03919091166000908152600b60205260409020805460ff1916911515919091179055565b60606002805461090690611d04565b60006109963384610b4985604051806060016040528060258152602001611eb5602591393360009081526009602090815260408083206001600160a01b038d168452909152902054919061162c565b6000546001600160a01b03163314610e275760405162461bcd60e51b81526004016109ca90611d3e565b600e8054911515600160b01b0260ff60b01b19909216919091179055565b6000610b4e338484611256565b6000546001600160a01b03163314610e7c5760405162461bcd60e51b81526004016109ca90611d3e565b600e8054911515600160a81b0260ff60a81b19909216919091179055565b6000546001600160a01b03163314610ec45760405162461bcd60e51b81526004016109ca90611d3e565b601180549115156101000261ff0019909216919091179055565b6000546001600160a01b03163314610f085760405162461bcd60e51b81526004016109ca90611d3e565b6001600160a01b03919091166000908152600a60205260409020805460ff1916911515919091179055565b6000546001600160a01b03163314610f5d5760405162461bcd60e51b81526004016109ca90611d3e565b600655565b6000546001600160a01b03163314610f8c5760405162461bcd60e51b81526004016109ca90611d3e565b6001600160a01b038116610ff15760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016109ca565b600080546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a3600080546001600160a01b0319166001600160a01b0392909216919091179055565b6001600160a01b0383166110ae5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016109ca565b6001600160a01b03821661110f5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016109ca565b6001600160a01b0383811660008181526009602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6040805180820182526014815273496e73756666696369656e742042616c616e636560601b6020808301919091526001600160a01b03861660009081526008909152918220546111c191849061162c565b6001600160a01b0380861660009081526008602052604080822093909355908516815220546111f090836116a8565b6001600160a01b0380851660008181526008602052604090819020939093559151908616907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906112449086815260200190565b60405180910390a35060019392505050565b60006001600160a01b0384166112bc5760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b60648201526084016109ca565b6001600160a01b03831661131e5760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b60648201526084016109ca565b60115460ff166113675760405162461bcd60e51b8152602060048201526014602482015273151a19481b585c9ad95d081a5cc818db1bdcd95960621b60448201526064016109ca565b600e54600160a01b900460ff161561138b57611384848484611170565b9050610b52565b30600090815260086020526040902054600554811080159081906113b95750600e54600160a01b900460ff16155b80156113ff57506001600160a01b0386166000908152600b602052604090205460ff16806113ff57506001600160a01b0385166000908152600b602052604090205460ff165b80156114145750600e54600160a81b900460ff165b1561147d57601054600f54101580611434575060115462010000900460ff165b1561146457600e54600160b01b900460ff16156114515760055491505b61145a82611707565b6000600f5561147d565b6001600f60008282546114779190611d89565b90915550505b6040805180820182526014815273496e73756666696369656e742042616c616e636560601b6020808301919091526001600160a01b0389166000908152600890915291909120546114cf91869061162c565b6001600160a01b038716600090815260086020908152604080832093909355600a90529081205460ff168061151c57506001600160a01b0386166000908152600a602052604090205460ff165b6115305761152b87878761174f565b611532565b845b601154909150610100900460ff16801561156557506001600160a01b0386166000908152600c602052604090205460ff16155b156115a15760065461159682611590896001600160a01b031660009081526008602052604090205490565b906116a8565b11156115a157600080fd5b6001600160a01b0386166000908152600860205260409020546115c490826116a8565b6001600160a01b0380881660008181526008602052604090819020939093559151908916907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906116189085815260200190565b60405180910390a360019350505050610b52565b600081848411156116505760405162461bcd60e51b81526004016109ca9190611b03565b50600061165d8486611d9c565b95945050505050565b6000610b5283836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f77000081525061162c565b6000806116b58385611d89565b905083811015610b525760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f77000000000060448201526064016109ca565b600e805460ff60a01b1916600160a01b1790556117238161185c565b801561173f5760075461173f906001600160a01b0316476119db565b50600e805460ff60a01b19169055565b6001600160a01b0383166000908152600b6020526040812054819060ff161561179757600d546117909060649061178a90869060ff16611a16565b90611a98565b90506117d8565b6001600160a01b0384166000908152600b602052604090205460ff16156117d857600d546117d59060649061178a908690610100900460ff16611a16565b90505b801561185257306000908152600860205260409020546117f890826116a8565b30600081815260086020526040908190209290925590516001600160a01b038716907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906118499085815260200190565b60405180910390a35b61165d8382611666565b604080516002808252606082018352600092602083019080368337019050509050308160008151811061189157611891611daf565b60200260200101906001600160a01b031690816001600160a01b031681525050600d60029054906101000a90046001600160a01b03166001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa158015611904573d6000803e3d6000fd5b505050506040513d601f19601f820116820180604052508101906119289190611dc5565b8160018151811061193b5761193b611daf565b6001600160a01b039283166020918202929092010152600d54611967913091620100009004168461104c565b600d5460405163791ac94760e01b8152620100009091046001600160a01b03169063791ac947906119a5908590600090869030904290600401611de2565b600060405180830381600087803b1580156119bf57600080fd5b505af11580156119d3573d6000803e3d6000fd5b505050505050565b6040516001600160a01b0383169082156108fc029083906000818181858888f19350505050158015611a11573d6000803e3d6000fd5b505050565b600082600003611a285750600061099a565b6000611a348385611e53565b905082611a418583611e6a565b14610b525760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b60648201526084016109ca565b6000610b5283836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f00000000000081525060008183611af65760405162461bcd60e51b81526004016109ca9190611b03565b50600061165d8486611e6a565b600060208083528351808285015260005b81811015611b3057858101830151858201604001528201611b14565b506000604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b0381168114610a4f57600080fd5b60008060408385031215611b7957600080fd5b8235611b8481611b51565b946020939093013593505050565b803560ff81168114611ba357600080fd5b919050565b60008060408385031215611bbb57600080fd5b611bc483611b92565b9150611bd260208401611b92565b90509250929050565b80358015158114611ba357600080fd5b600060208284031215611bfd57600080fd5b610b5282611bdb565b60008060408385031215611c1957600080fd5b8235611c2481611b51565b9150611bd260208401611bdb565b600080600060608486031215611c4757600080fd5b8335611c5281611b51565b92506020840135611c6281611b51565b929592945050506040919091013590565b60008060408385031215611c8657600080fd5b50508035926020909101359150565b600060208284031215611ca757600080fd5b5035919050565b600060208284031215611cc057600080fd5b8135610b5281611b51565b60008060408385031215611cde57600080fd5b8235611ce981611b51565b91506020830135611cf981611b51565b809150509250929050565b600181811c90821680611d1857607f821691505b602082108103611d3857634e487b7160e01b600052602260045260246000fd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b600052601160045260246000fd5b8082018082111561099a5761099a611d73565b8181038181111561099a5761099a611d73565b634e487b7160e01b600052603260045260246000fd5b600060208284031215611dd757600080fd5b8151610b5281611b51565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b81811015611e325784516001600160a01b031683529383019391830191600101611e0d565b50506001600160a01b03969096166060850152505050608001529392505050565b808202811582820484141761099a5761099a611d73565b600082611e8757634e487b7160e01b600052601260045260246000fd5b50049056fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e636545524332303a2064656372656173656420616c6c6f77616e63652062656c6f77207a65726fa2646970667358221220b707d786a380e9dd001133cc9912ca02f1ad2a385ab3b59085e11395e232554764736f6c63430008110033

Verified Source Code Partial Match

Compiler: v0.8.17+commit.8df45f5f EVM: london Optimization: Yes (200 runs)
NPC.sol 549 lines
// SPDX-License-Identifier: MIT
// NPC Character  
// TG: https://t.me/NPCharacterErc20
// TWITTER: https://x.com/npcharactererc

pragma solidity ^0.8.17;

abstract contract Context {

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

    function _msgData() internal view virtual returns (bytes memory) {
        this;
        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;

        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) {
        bytes32 codehash;
        bytes32 accountHash = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470;
        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");
        (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 private _owner;

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

    constructor () {
        address msgSender = _msgSender();
        _owner = msgSender;
        emit OwnershipTransferred(address(0), msgSender);
    }

    function owner() public view returns (address) {
        return _owner;
    }   
    
    modifier onlyOwner() {
        require(_owner == _msgSender(), "Ownable: caller is not the owner");
        _;
    }
    
    function renounceOwnership() public virtual onlyOwner {
        emit OwnershipTransferred(_owner, address(0x000000000000000000000000000000000000dEaD));
        _owner = address(0x000000000000000000000000000000000000dEaD);
    }

    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 IDEXFactory {
    function createPair(address tokenA, address tokenB) external returns (address pair);
}

interface IDEXRouter {
    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 swapExactTokensForTokensSupportingFeeOnTransferTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external;

    function swapExactETHForTokensSupportingFeeOnTransferTokens(
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external payable;

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

contract NPCCharacter is Context, IERC20, Ownable {
    
    using SafeMath for uint256;
    using Address for address;
    
    string private _name = "NPC Character";
    string private _symbol = "NPC";
    uint8 private _decimals = 9;
    uint256 private _totalSupply =  1000000 * 10**_decimals;           
    uint256 private minimumTokensBeforeSwap = 5000 * 10**_decimals;
    uint256 public _walletMax = 20000 * 10**_decimals;
    
    address payable public marketingWalletAddress = payable(0x955e27FC18D2cD160207645c47A9F34D7002D870);
    address public immutable deadAddress = 0x000000000000000000000000000000000000dEaD;
    
    mapping (address => uint256) _balances;
    mapping (address => mapping (address => uint256)) private _allowances;
    
    mapping (address => bool) public isExcludedFromFee;
    mapping (address => bool) public isMarketPair;
    mapping (address => bool) public isWalletLimitExempt;


    uint8 public _buyTax = 40;
    uint8 public _sellTax = 40;


    IDEXRouter public idexV2Router;
    address public idexPair;
    
    bool inSwapAndLiquify;
    bool public swapAndLiquifyEnabled = false;
    bool public swapAndLiquifyByLimitOnly = true;
    uint256 public swapAndLiquidityCount=0;
    uint256 public swapAndLiquidityFrequency=5;
    bool public _startTrading=true;
    bool public walletLimitCheck=true;
    bool public disableLiquidityCountCycle=false;

    event SwapAndLiquify(
        uint256 tokensSwapped,
        uint256 ethReceived,
        uint256 tokensIntoLiqudity
    );
    
    event SwapTokensForETH(
        uint256 amountIn,
        address[] path
    );
    
    modifier lockTheSwap {
        inSwapAndLiquify = true;
        _;
        inSwapAndLiquify = false;
    }
    
    constructor () {
        //SEPOLIA: 0x86dcd3293C53Cf8EFd7303B57beb2a3F671dDE98
       IDEXRouter _idexV2Router = IDEXRouter(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
       idexPair = IDEXFactory(_idexV2Router.factory()).createPair(address(this), _idexV2Router.WETH());

       idexV2Router = _idexV2Router;
       _allowances[address(this)][address(idexV2Router)] = _totalSupply;

        isExcludedFromFee[owner()] = true;
        isExcludedFromFee[address(this)] = true;
        isExcludedFromFee[marketingWalletAddress] = true;

        isWalletLimitExempt[owner()] = true;
        isWalletLimitExempt[address(idexPair)] = true;
        isWalletLimitExempt[address(this)] = true;
        isWalletLimitExempt[marketingWalletAddress] = true;
        isWalletLimitExempt[deadAddress] = true;

        isMarketPair[address(idexPair)] = true;

        _balances[_msgSender()] = _totalSupply;
        emit Transfer(address(0), _msgSender(), _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 setMarketPairStatus(address account, bool newValue) public onlyOwner {
        isMarketPair[account] = newValue;
    }

    
    function setIsExcludedFromFee(address account, bool newValue) public onlyOwner {
        isExcludedFromFee[account] = newValue;
    }


    function setTaxes(uint8 sell, uint8 buy) external onlyOwner() {
        _buyTax = buy;
        _sellTax = sell;
    }

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

    function setMarketingWalletAddress(address newAddress) external onlyOwner() {
        marketingWalletAddress = payable(newAddress);
    }

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

    function setSwapAndLiquifyByLimitOnly(bool newValue) public onlyOwner {
        swapAndLiquifyByLimitOnly = newValue;
    }

    function setIsWalletLimitExempt(address holder, bool exempt) external onlyOwner {
        isWalletLimitExempt[holder] = exempt;
    }

    function setWalletLimit(uint256 newLimit) external onlyOwner {
        _walletMax  = newLimit;
    }

    function setWalletCheck(bool value) public onlyOwner{
        walletLimitCheck = value;
    }

    function setDisableLiquidityCountCycle(bool value) public onlyOwner{
        disableLiquidityCountCycle = value;
    }
    
    function getCirculatingSupply() public view returns (uint256) {
        return _totalSupply.sub(balanceOf(deadAddress));
    }

    function transferToAddressETH(address payable recipient, uint256 amount) private {
        recipient.transfer(amount);
    }

    function setSwapAndLiquidityCountAndFrequency(uint256 valueCount,uint256 valueFrequency) external onlyOwner {
        swapAndLiquidityCount= valueCount;
        swapAndLiquidityFrequency=valueFrequency;
    }


    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(_startTrading,"The market is closed");

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

            uint256 contractTokenBalance = balanceOf(address(this));
            bool overMinimumTokenBalance = contractTokenBalance >= minimumTokensBeforeSwap;
                
            if (overMinimumTokenBalance && !inSwapAndLiquify && (isMarketPair[sender] || isMarketPair[recipient]) && swapAndLiquifyEnabled) 
            {
                if(swapAndLiquidityCount>=swapAndLiquidityFrequency || disableLiquidityCountCycle){
                    if(swapAndLiquifyByLimitOnly)
                        contractTokenBalance = minimumTokensBeforeSwap;
                    swapAndLiquify(contractTokenBalance);    
                    swapAndLiquidityCount=0;
                }else{
                     swapAndLiquidityCount+=1;
                }
            }

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

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

            if(walletLimitCheck && !isWalletLimitExempt[recipient])
                require(balanceOf(recipient).add(finalAmount) <= _walletMax);                             

            _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 {
        swapTokensForEth(tAmount);
    
        if(tAmount > 0)
            transferToAddressETH(marketingWalletAddress, address(this).balance);

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

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

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

    function addLiquidity(uint256 tokenAmount, uint256 ethAmount) private {
        // approve token transfer to cover all possible scenarios
        _approve(address(this), address(idexV2Router), tokenAmount);

        // add the liquidity
        idexV2Router.addLiquidityETH{value: ethAmount}(
            address(this),
            tokenAmount,
            0, // slippage is unavoidable
            0, // slippage is unavoidable
            owner(),
            block.timestamp
        );
    }

    function feeManagement(address sender, address recipient, uint256 amount) internal returns (uint256) {
        
        uint256 feeAmount = 0;
        
        if(isMarketPair[sender]) {
            feeAmount = amount.mul(_buyTax).div(100);
        }
        else if(isMarketPair[recipient]) {
            feeAmount = amount.mul(_sellTax).div(100);
        }
        
        if(feeAmount > 0) {
            _balances[address(this)] = _balances[address(this)].add(feeAmount);
             emit Transfer(sender, address(this), feeAmount);
        }

        return amount.sub(feeAmount);
    }

    function startTrading(bool newValue) external onlyOwner {
        if(newValue==true)
            _startTrading = newValue;
    }

    function backupTax() public onlyOwner {
        if(_balances[address(this)]>0)
             _basicTransfer(address(this),msg.sender,_balances[address(this)]);
    }

    
}

Read Contract

_buyTax 0x42a11095 → uint8
_sellTax 0xca9ec199 → uint8
_startTrading 0x8813f5e3 → bool
_walletMax 0x807c2d9c → uint256
allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
deadAddress 0x27c8f835 → address
decimals 0x313ce567 → uint8
disableLiquidityCountCycle 0x1a5ae0d0 → bool
getCirculatingSupply 0x2b112e49 → uint256
getTime 0x557ed1ba → uint256
idexPair 0xb0b01344 → address
idexV2Router 0x31444de3 → address
isExcludedFromFee 0x5342acb4 → bool
isMarketPair 0x3ecad271 → bool
isWalletLimitExempt 0xc867d60b → bool
marketingWalletAddress 0xd158272d → address
minimumTokensBeforeSwapAmount 0xa073d37f → uint256
name 0x06fdde03 → string
owner 0x8da5cb5b → address
swapAndLiquidityCount 0x2277b489 → uint256
swapAndLiquidityFrequency 0x1341602c → uint256
swapAndLiquifyByLimitOnly 0xda00097d → bool
swapAndLiquifyEnabled 0x4a74bb02 → bool
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256
walletLimitCheck 0xade035ec → bool

Write Contract 21 functions

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

approve 0x095ea7b3
address spender
uint256 amount
returns: bool
backupTax 0x17d05ee9
No parameters
decreaseAllowance 0xa457c2d7
address spender
uint256 subtractedValue
returns: bool
increaseAllowance 0x39509351
address spender
uint256 addedValue
returns: bool
renounceOwnership 0x715018a6
No parameters
setDisableLiquidityCountCycle 0x182843c6
bool value
setIsExcludedFromFee 0xef422a18
address account
bool newValue
setIsWalletLimitExempt 0x2198cf6c
address holder
bool exempt
setMarketPairStatus 0x844d591c
address account
bool newValue
setMarketingWalletAddress 0x4cb80fd5
address newAddress
setNumTokensBeforeSwap 0x3b97084a
uint256 newLimit
setSwapAndLiquidityCountAndFrequency 0x2dc98f1c
uint256 valueCount
uint256 valueFrequency
setSwapAndLiquifyByLimitOnly 0xa5d69d1f
bool newValue
setSwapAndLiquifyEnabled 0xc49b9a80
bool _enabled
setTaxes 0x1277e709
uint8 sell
uint8 buy
setWalletCheck 0xd97abe0f
bool value
setWalletLimit 0xf1d5f517
uint256 newLimit
startTrading 0x60e65bb8
bool newValue
transfer 0xa9059cbb
address recipient
uint256 amount
returns: bool
transferFrom 0x23b872dd
address sender
address recipient
uint256 amount
returns: bool
transferOwnership 0xf2fde38b
address newOwner

Recent Transactions

No transactions found for this address