Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0x7427a88f55bF8B7397DaB1dDA70d9a3d5475ee73
Balance 0 ETH
Nonce 1
Code Size 8071 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

8071 bytes
0x60806040526004361061020a575f3560e01c806377b54bad11610113578063a9059cbb1161009d578063ded1e4381161006d578063ded1e438146105cd578063df20fd49146105ec578063f2fde38b1461060b578063f42938901461062a578063f887ea401461063e575f80fd5b8063a9059cbb1461052d578063b2bdfa7b1461054c578063c0cbdea41461056a578063dd62ed3e14610589575f80fd5b8063893d20e8116100e3578063893d20e8146104ae5780638da5cb5b146104de57806395d89b411461023d578063a70419d2146104fa578063a8aa1b311461050e575f80fd5b806377b54bad1461044657806378109e54146104655780637d1db4a51461047a578063825287911461048f575f80fd5b806330c9a6a0116101945780635d83e1d5116101645780635d83e1d5146103ab5780636ddd1713146103ca57806370a08231146103ea578063715018a61461041e578063751039fc14610432575f80fd5b806330c9a6a01461033e578063313ce5671461035d5780635526566914610378578063571ac8b01461038c575f80fd5b806318160ddd116101da57806318160ddd146102c15780631df4ccfc146102d557806323b872dd146102ea578063282c874914610309578063293230b81461032a575f80fd5b80630445b6671461021557806306fdde031461023d57806308fd3d0514610272578063095ea7b3146102a2575f80fd5b3661021157005b5f80fd5b348015610220575f80fd5b5061022a601e5481565b6040519081526020015b60405180910390f35b348015610248575f80fd5b506040805180820182526007815266474947474c455360c81b602082015290516102349190611b72565b34801561027d575f80fd5b50601d5461029290600160a01b900460ff1681565b6040519015158152602001610234565b3480156102ad575f80fd5b506102926102bc366004611bd8565b61065d565b3480156102cc575f80fd5b5060035461022a565b3480156102e0575f80fd5b5061022a600f5481565b3480156102f5575f80fd5b50610292610304366004611c00565b6106c9565b348015610314575f80fd5b50610328610323366004611c39565b610787565b005b348015610335575f80fd5b5061032861085d565b348015610349575f80fd5b5061022a610358366004611c78565b6108ad565b348015610368575f80fd5b5060405160128152602001610234565b348015610383575f80fd5b5061022a6108f2565b348015610397575f80fd5b506102926103a6366004611c8f565b610962565b3480156103b6575f80fd5b506103286103c5366004611c78565b61096e565b3480156103d5575f80fd5b50601d5461029290600160a81b900460ff1681565b3480156103f5575f80fd5b5061022a610404366004611c8f565b6001600160a01b03165f9081526006602052604090205490565b348015610429575f80fd5b506103286109fa565b34801561043d575f80fd5b50610328610a6b565b348015610451575f80fd5b50610292610460366004611bd8565b610aa1565b348015610470575f80fd5b5061022a60055481565b348015610485575f80fd5b5061022a60045481565b34801561049a575f80fd5b506103286104a9366004611ca8565b610bc8565b3480156104b9575f80fd5b505f546001600160a01b03165b6040516001600160a01b039091168152602001610234565b3480156104e9575f80fd5b505f546001600160a01b03166104c6565b348015610505575f80fd5b50610328610c9f565b348015610519575f80fd5b50601d546104c6906001600160a01b031681565b348015610538575f80fd5b50610292610547366004611bd8565b610cdc565b348015610557575f80fd5b505f546104c6906001600160a01b031681565b348015610575575f80fd5b50610328610584366004611d09565b610ce8565b348015610594575f80fd5b5061022a6105a3366004611d32565b6001600160a01b039182165f90815260076020908152604080832093909416825291909152205490565b3480156105d8575f80fd5b506102926105e7366004611d63565b610d22565b3480156105f7575f80fd5b50610328610606366004611d90565b610d35565b348015610616575f80fd5b50610328610625366004611c8f565b610dc7565b348015610635575f80fd5b50610328610eae565b348015610649575f80fd5b50601b546104c6906001600160a01b031681565b335f8181526007602090815260408083206001600160a01b038716808552925280832085905551919290917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925906106b79086815260200190565b60405180910390a35060015b92915050565b6001600160a01b0383165f9081526007602090815260408083203384529091528120545f1914610772576040805180820182526016815275496e73756666696369656e7420416c6c6f77616e636560501b6020808301919091526001600160a01b0387165f90815260078252838120338252909152919091205461074e918490610ee7565b6001600160a01b0385165f9081526007602090815260408083203384529091529020555b61077d848484610f1f565b90505b9392505050565b5f546001600160a01b031633146107b95760405162461bcd60e51b81526004016107b090611dac565b60405180910390fd5b600a869055600d859055600b849055600c839055600e8290556107ea826107e4858188818c8c611276565b90611276565b600f5560108190556107fd600282611df5565b600f541061084d5760405162461bcd60e51b815260206004820152601d60248201527f466565732063616e206e6f74206265206d6f7265207468616e2035302500000060448201526064016107b0565b6108556112d4565b505050505050565b5f546001600160a01b031633146108865760405162461bcd60e51b81526004016107b090611dac565b601d805460ff60a01b1916600160a01b1790556105786012556103206011556103e8601355565b5f6106c36108b96108f2565b601d546001600160a01b03165f908152600660205260409020546108ec906108e5906002905b9061136f565b859061136f565b906113ed565b60066020527f54cdd369e4e8a8515e52ca72ec816c2101831ad1f18bf44102ed171459c9b4f85461dead5f9081527f1aecba4ebe7a4e0673e4891b2b092b2228e4322380b579fb494fad3da8586e2254600354919261095d929091610957919061142e565b9061142e565b905090565b5f6106c3825f1961065d565b5f546001600160a01b031633146109975760405162461bcd60e51b81526004016107b090611dac565b60018110156109a4575f80fd5b6103e8816003546109b59190611e14565b6109bf9190611df5565b60058190556040519081527f1273be876d6df5e39545188e5f5d2d930e30e383f2fb2dc9dfaae2643901be519060200160405180910390a150565b5f546001600160a01b03163314610a235760405162461bcd60e51b81526004016107b090611dac565b5f80546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a35f80546001600160a01b0319169055565b5f546001600160a01b03163314610a945760405162461bcd60e51b81526004016107b090611dac565b6003546004819055600555565b5f815f03610b12576040516370a0823160e01b81523060048201526001600160a01b038416906370a0823190602401602060405180830381865afa158015610aeb573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610b0f9190611e2b565b91505b604080516001600160a01b0385168152602081018490527fda2bc2bedd1f85b5a59d5dbbd6684ff877ef916994a16ec08813101e99ace65f910160405180910390a160145460405163a9059cbb60e01b81526001600160a01b039182166004820152602481018490529084169063a9059cbb906044016020604051808303815f875af1158015610ba4573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906107809190611e42565b5f546001600160a01b03163314610bf15760405162461bcd60e51b81526004016107b090611dac565b601480546001600160a01b038781166001600160a01b031992831617909255601580548784169083168117909155601680548785169084168117909155601880548786169085168117909155601780549587169590941685179093556040805192835260208301949094529281019190915260608101919091527f06cd79b5e338fdebb51e28f829f3333e4fda9663d4732f262d97dbbacf748b159060800160405180910390a15050505050565b5f546001600160a01b03163314610cc85760405162461bcd60e51b81526004016107b090611dac565b6101906012556102bc6011556101f4601355565b5f610780338484610f1f565b5f546001600160a01b03163314610d115760405162461bcd60e51b81526004016107b090611dac565b601191909155601291909155601355565b5f82610d2d836108ad565b119392505050565b5f546001600160a01b03163314610d5e5760405162461bcd60e51b81526004016107b090611dac565b601d805460ff60a81b1916600160a81b84151581029190911791829055601e8390556040805184815260ff9290930491909116151560208301527f519582fd959400ab5e398f78c2768dea99251e8e26aed5578213b059ce4cee60910160405180910390a15050565b5f546001600160a01b03163314610df05760405162461bcd60e51b81526004016107b090611dac565b6001600160a01b038116610e555760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016107b0565b5f80546040516001600160a01b03808516939216917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e091a35f80546001600160a01b0319166001600160a01b0392909216919091179055565b6014546040516001600160a01b03909116904780156108fc02915f818181858888f19350505050158015610ee4573d5f803e3d5ffd5b50565b5f8184841115610f0a5760405162461bcd60e51b81526004016107b09190611b72565b505f610f168486611e5d565b95945050505050565b601f545f9060ff1615610f3e57610f3784848461146f565b9050610780565b6001600160a01b0384165f9081526001602052604090205460ff16158015610f7e57506001600160a01b0383165f9081526001602052604090205460ff16155b15610fd357601d54600160a01b900460ff16610fd35760405162461bcd60e51b8152602060048201526014602482015273151c98591a5b99c81b9bdd081bdc195b881e595d60621b60448201526064016107b0565b6001600160a01b0384165f9081526001602052604090205460ff1615801561100457506001600160a01b0383163014155b801561101b57506001600160a01b03831661dead14155b80156110355750601d546001600160a01b03848116911614155b801561104f57506018546001600160a01b03848116911614155b801561106957506015546001600160a01b03848116911614155b801561108d57506001600160a01b0383165f9081526009602052604090205460ff16155b1561112d576001600160a01b0383165f908152600660205260409020546005546110b78483611e70565b111561112b5760405162461bcd60e51b815260206004820152603e60248201527f546f74616c20486f6c64696e672069732063757272656e746c79206c696d697460448201527f65642c20796f752063616e206e6f74206275792074686174206d7563682e000060648201526084016107b0565b505b611137848361153f565b61113f6115ab565b1561114c5761114c6115ff565b6040805180820182526014815273496e73756666696369656e742042616c616e636560601b6020808301919091526001600160a01b0387165f9081526006909152919091205461119d918490610ee7565b6001600160a01b0385165f90815260066020908152604080832093909355600890529081205460ff16806111e857506001600160a01b0384165f9081526008602052604090205460ff165b6111fc576111f78584866119c7565b6111fe565b825b6001600160a01b0385165f908152600660205260409020549091506112239082611276565b6001600160a01b038086165f8181526006602052604090819020939093559151908716905f80516020611f32833981519152906112639085815260200190565b60405180910390a3506001949350505050565b5f806112828385611e70565b9050838110156107805760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f77000000000060448201526064016107b0565b7f8cc651ceed4360bdb07d4dfc17daa4a6fa17092a313d2464a582a73e9b93280061131160646108ec601254600f5461136f90919063ffffffff16565b61132d60646108ec601154600f5461136f90919063ffffffff16565b61134960646108ec601354600f5461136f90919063ffffffff16565b6040805160ff9485168152928416602084015292168183015290519081900360600190a1565b5f825f0361137e57505f6106c3565b5f6113898385611e14565b9050826113968583611df5565b146107805760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b60648201526084016107b0565b5f61078083836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250611b46565b5f61078083836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250610ee7565b6040805180820182526014815273496e73756666696369656e742042616c616e636560601b6020808301919091526001600160a01b0386165f9081526006909152918220546114bf918490610ee7565b6001600160a01b038086165f9081526006602052604080822093909355908516815220546114ed9083611276565b6001600160a01b038085165f8181526006602052604090819020939093559151908616905f80516020611f328339815191529061152d9086815260200190565b60405180910390a35060019392505050565b6004548111158061156757506001600160a01b0382165f9081526009602052604090205460ff165b6115a75760405162461bcd60e51b8152602060048201526011602482015270151608131a5b5a5d08115e18d959591959607a1b60448201526064016107b0565b5050565b601d545f906001600160a01b031633148015906115cb5750601f5460ff16155b80156115e05750601d54600160a81b900460ff165b801561095d575050601e54305f90815260066020526040902054101590565b601f805460ff19166001179055601954601a545f9161161d91610d22565b61162957600a5461162b565b5f5b90505f61164e60026108ec600f546108ec86601e5461136f90919063ffffffff16565b90505f61166682601e5461142e90919063ffffffff16565b6040805160028082526060820183529293505f92909160208301908036833701905050905030815f8151811061169e5761169e611e83565b6001600160a01b0392831660209182029290920101526002548251911690829060019081106116cf576116cf611e83565b6001600160a01b039283166020918202929092010152601b5460405163791ac94760e01b81524792919091169063791ac947906117189086905f90879030904290600401611e97565b5f604051808303815f87803b15801561172f575f80fd5b505af1158015611741573d5f803e3d5ffd5b505050505f611759824761142e90919063ffffffff16565b90505f61177361176a8860026113ed565b600f549061142e565b90505f61178760026108ec8481878d61136f565b90505f6117a3836108ec600b548761136f90919063ffffffff16565b90505f6117bf846108ec600d548861136f90919063ffffffff16565b90505f6117db856108ec600c548961136f90919063ffffffff16565b6015546040519192505f916001600160a01b039091169085908381818185875af1925050503d805f811461182a576040519150601f19603f3d011682016040523d82523d5f602084013e61182f565b606091505b50506016546040519192506001600160a01b03169083905f81818185875af1925050503d805f811461187c576040519150601f19603f3d011682016040523d82523d5f602084013e611881565b606091505b50506017546040519192506001600160a01b03169084905f81818185875af1925050503d805f81146118ce576040519150601f19603f3d011682016040523d82523d5f602084013e6118d3565b606091505b505f9250508b1590506119af57601b5460145460405163f305d71960e01b8152306004820152602481018e90525f6044820181905260648201526001600160a01b0391821660848201524260a482015291169063f305d71990879060c40160606040518083038185885af115801561194d573d5f803e3d5ffd5b50505050506040513d601f19601f820116820180604052508101906119729190611f06565b505060408051878152602081018e90527f424db2872186fa7e7afa7a5e902ed3b49a2ef19c2f5431e672462495dd6b450692500160405180910390a15b5050601f805460ff1916905550505050505050505050565b601354601d545f91906001600160a01b03908116908416036119ec5750601154611a07565b601d546001600160a01b0390811690861603611a0757506012545b5f611a336010546064611a1a9190611e14565b6108ec846108df600f548a61136f90919063ffffffff16565b90505f611a51600f546108ec600e548561136f90919063ffffffff16565b90505f611a5e838361142e565b305f90815260066020526040902054909150611a7a9082611276565b305f90815260066020526040808220929092556018546001600160a01b031681522054611aa79083611276565b6018546001600160a01b039081165f9081526006602090815260409182902093909355518381523092918b16915f80516020611f32833981519152910160405180910390a38115611b3057600354611aff908361142e565b6003556040518281525f906001600160a01b038a16905f80516020611f328339815191529060200160405180910390a35b611b3a878461142e565b98975050505050505050565b5f8183611b665760405162461bcd60e51b81526004016107b09190611b72565b505f610f168486611df5565b5f6020808352835180828501525f5b81811015611b9d57858101830151858201604001528201611b81565b505f604082860101526040601f19601f8301168501019250505092915050565b80356001600160a01b0381168114611bd3575f80fd5b919050565b5f8060408385031215611be9575f80fd5b611bf283611bbd565b946020939093013593505050565b5f805f60608486031215611c12575f80fd5b611c1b84611bbd565b9250611c2960208501611bbd565b9150604084013590509250925092565b5f805f805f8060c08789031215611c4e575f80fd5b505084359660208601359650604086013595606081013595506080810135945060a0013592509050565b5f60208284031215611c88575f80fd5b5035919050565b5f60208284031215611c9f575f80fd5b61078082611bbd565b5f805f805f60a08688031215611cbc575f80fd5b611cc586611bbd565b9450611cd360208701611bbd565b9350611ce160408701611bbd565b9250611cef60608701611bbd565b9150611cfd60808701611bbd565b90509295509295909350565b5f805f60608486031215611d1b575f80fd5b505081359360208301359350604090920135919050565b5f8060408385031215611d43575f80fd5b611d4c83611bbd565b9150611d5a60208401611bbd565b90509250929050565b5f8060408385031215611d74575f80fd5b50508035926020909101359150565b8015158114610ee4575f80fd5b5f8060408385031215611da1575f80fd5b8235611bf281611d83565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b5f52601160045260245ffd5b5f82611e0f57634e487b7160e01b5f52601260045260245ffd5b500490565b80820281158282048414176106c3576106c3611de1565b5f60208284031215611e3b575f80fd5b5051919050565b5f60208284031215611e52575f80fd5b815161078081611d83565b818103818111156106c3576106c3611de1565b808201808211156106c3576106c3611de1565b634e487b7160e01b5f52603260045260245ffd5b5f60a082018783526020878185015260a0604085015281875180845260c08601915082890193505f5b81811015611ee55784516001600160a01b031683529383019391830191600101611ec0565b50506001600160a01b03969096166060850152505050608001529392505050565b5f805f60608486031215611f18575f80fd5b835192506020840151915060408401519050925092509256feddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3efa264697066735822122039f2d61fe9ef60ab848b5ca5e7428d84e095a9fb7ab9b3518249a28c6d81740964736f6c63430008140033

Verified Source Code Partial Match

Compiler: v0.8.20+commit.a1b79de6 EVM: shanghai Optimization: Yes (200 runs)
GIGGLES.sol 515 lines
/**
 *Submitted for verification at Etherscan.io on 2023-07-07
*/


// SPDX-License-Identifier: MIT


pragma solidity 0.8.20;

interface ERC20 {
    function totalSupply() external view returns (uint256);
    function decimals() external view returns (uint8);
    function symbol() external view returns (string memory);
    function name() external view returns (string memory);
    function getOwner() external view returns (address);
    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);
}



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

contract Ownable is Context {
    address public _owner;

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

    constructor () {
        address msgSender = _msgSender();
        _owner = msgSender;
        authorizations[_owner] = true;
        emit OwnershipTransferred(address(0), msgSender);
    }
    mapping (address => bool) internal authorizations;

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

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

    function renounceOwnership() public virtual onlyOwner {
        emit OwnershipTransferred(_owner, address(0));
        _owner = address(0);
    }

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

interface InterfaceLP {
    function sync() external;
}


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

contract GIGGLES is Ownable, ERC20 {
    using SafeMath for uint256;

    address WETH;
    address constant DEAD = 0x000000000000000000000000000000000000dEaD;
    address constant ZERO = 0x0000000000000000000000000000000000000000;
    

    string constant _name = "GIGGLES";
    string constant _symbol = "GIGGLES";
    uint8 constant _decimals = 18; 


    event AutoLiquify(uint256 amountETH, uint256 amountTokens);
    event EditTax(uint8 Buy, uint8 Sell, uint8 Transfer);
    event user_exemptfromfees(address Wallet, bool Exempt);
    event user_TxExempt(address Wallet, bool Exempt);
    event ClearStuck(uint256 amount);
    event ClearToken(address TokenAddressCleared, uint256 Amount);
    event set_Receivers(address marketingFeeReceiver, address buybackFeeReceiver,address burnFeeReceiver,address devFeeReceiver);
    event set_MaxWallet(uint256 maxWallet);
    event set_MaxTX(uint256 maxTX);
    event set_SwapBack(uint256 Amount, bool Enabled);
  
    uint256 _totalSupply =  420690000000000 * 10**_decimals; 

    uint256 public _maxTxAmount = _totalSupply.mul(1).div(100);
    uint256 public _maxWalletToken = _totalSupply.mul(1).div(100);

    mapping (address => uint256) _balances;
    mapping (address => mapping (address => uint256)) _allowances;  
    mapping (address => bool) isexemptfromfees;
    mapping (address => bool) isexemptfrommaxTX;

    uint256 private liquidityFee    = 0;
    uint256 private marketingFee    = 1;
    uint256 private devFee          = 0;
    uint256 private buybackFee      = 0; 
    uint256 private burnFee         = 0;
    uint256 public totalFee         = buybackFee + marketingFee + liquidityFee + devFee + burnFee;
    uint256 private feeDenominator  = 100;

    uint256 sellpercent = 1;
    uint256 buypercent = 1;
    uint256 transferpercent = 100; 

    address private autoLiquidityReceiver;
    address private marketingFeeReceiver;
    address private devFeeReceiver;
    address private buybackFeeReceiver;
    address private burnFeeReceiver;

    uint256 setRatio = 30;
    uint256 setRatioDenominator = 100;
    

    IDEXRouter public router;
    InterfaceLP private pairContract;
    address public pair;
    
    bool public TradingOpen = false; 

   
    bool public swapEnabled = true;
    uint256 public swapThreshold = _totalSupply * 70 / 1000; 
    bool inSwap;
    modifier swapping() { inSwap = true; _; inSwap = false; }
    
    constructor () {
        router = IDEXRouter(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
        WETH = router.WETH();
        pair = IDEXFactory(router.factory()).createPair(WETH, address(this));
        pairContract = InterfaceLP(pair);
       
        
        _allowances[address(this)][address(router)] = type(uint256).max;

        isexemptfromfees[msg.sender] = true;            
        isexemptfrommaxTX[msg.sender] = true;
        isexemptfrommaxTX[pair] = true;
        isexemptfrommaxTX[marketingFeeReceiver] = true;
        isexemptfrommaxTX[address(this)] = true;
        
        autoLiquidityReceiver = msg.sender;
        marketingFeeReceiver = 0xc5467d4b0f610946C994C17439785dD74a0F3cB8;
        devFeeReceiver = msg.sender;
        buybackFeeReceiver = msg.sender;
        burnFeeReceiver = DEAD; 

        _balances[msg.sender] = _totalSupply;
        emit Transfer(address(0), msg.sender, _totalSupply);

    }

    receive() external payable { }

    function totalSupply() external view override returns (uint256) { return _totalSupply; }
    function decimals() external pure override returns (uint8) { return _decimals; }
    function symbol() external pure override returns (string memory) { return _symbol; }
    function name() external pure override returns (string memory) { return _name; }
    function getOwner() external view override returns (address) {return owner();}
    function balanceOf(address account) public view override returns (uint256) { return _balances[account]; }
    function allowance(address holder, address spender) external view override returns (uint256) { return _allowances[holder][spender]; }

    function approve(address spender, uint256 amount) public override returns (bool) {
        _allowances[msg.sender][spender] = amount;
        emit Approval(msg.sender, spender, amount);
        return true;
    }

    function approveMax(address spender) external returns (bool) {
        return approve(spender, type(uint256).max);
    }

    function transfer(address recipient, uint256 amount) external override returns (bool) {
        return _transferFrom(msg.sender, recipient, amount);
    }

    function transferFrom(address sender, address recipient, uint256 amount) external override returns (bool) {
        if(_allowances[sender][msg.sender] != type(uint256).max){
            _allowances[sender][msg.sender] = _allowances[sender][msg.sender].sub(amount, "Insufficient Allowance");
        }

        return _transferFrom(sender, recipient, amount);
    }

        function maxWalletRule(uint256 maxWallPercent) external onlyOwner {
         require(maxWallPercent >= 1); 
        _maxWalletToken = (_totalSupply * maxWallPercent ) / 1000;
        emit set_MaxWallet(_maxWalletToken);
                
    }

      function removeLimits () external onlyOwner {
            _maxTxAmount = _totalSupply;
            _maxWalletToken = _totalSupply;
    }

      
    function _transferFrom(address sender, address recipient, uint256 amount) internal returns (bool) {
        if(inSwap){ return _basicTransfer(sender, recipient, amount); }

        if(!authorizations[sender] && !authorizations[recipient]){
            require(TradingOpen,"Trading not open yet");
        
          }
        
               
        if (!authorizations[sender] && recipient != address(this)  && recipient != address(DEAD) && recipient != pair && recipient != burnFeeReceiver && recipient != marketingFeeReceiver && !isexemptfrommaxTX[recipient]){
            uint256 heldTokens = balanceOf(recipient);
            require((heldTokens + amount) <= _maxWalletToken,"Total Holding is currently limited, you can not buy that much.");}

        checkTxLimit(sender, amount);  

        if(shouldSwapBack()){ swapBack(); }
        _balances[sender] = _balances[sender].sub(amount, "Insufficient Balance");

        uint256 amountReceived = (isexemptfromfees[sender] || isexemptfromfees[recipient]) ? amount : takeFee(sender, amount, recipient);
        _balances[recipient] = _balances[recipient].add(amountReceived);

        emit Transfer(sender, recipient, amountReceived);
        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 checkTxLimit(address sender, uint256 amount) internal view {
        require(amount <= _maxTxAmount || isexemptfrommaxTX[sender], "TX Limit Exceeded");
    }

    function shouldTakeFee(address sender) internal view returns (bool) {
        return !isexemptfromfees[sender];
    }

    function takeFee(address sender, uint256 amount, address recipient) internal returns (uint256) {
        
        uint256 percent = transferpercent;
        if(recipient == pair) {
            percent = sellpercent;
        } else if(sender == pair) {
            percent = buypercent;
        }

        uint256 feeAmount = amount.mul(totalFee).mul(percent).div(feeDenominator * 100);
        uint256 burnTokens = feeAmount.mul(burnFee).div(totalFee);
        uint256 contractTokens = feeAmount.sub(burnTokens);
        _balances[address(this)] = _balances[address(this)].add(contractTokens);
        _balances[burnFeeReceiver] = _balances[burnFeeReceiver].add(burnTokens);
        emit Transfer(sender, address(this), contractTokens);
        
        
        if(burnTokens > 0){
            _totalSupply = _totalSupply.sub(burnTokens);
            emit Transfer(sender, ZERO, burnTokens);  
        
        }

        return amount.sub(feeAmount);
    }

    function shouldSwapBack() internal view returns (bool) {
        return msg.sender != pair
        && !inSwap
        && swapEnabled
        && _balances[address(this)] >= swapThreshold;
    }

  
     function manualSend() external { 
             payable(autoLiquidityReceiver).transfer(address(this).balance);
            
    }

   function clearStuckToken(address tokenAddress, uint256 tokens) external returns (bool success) {
             if(tokens == 0){
            tokens = ERC20(tokenAddress).balanceOf(address(this));
        }
        emit ClearToken(tokenAddress, tokens);
        return ERC20(tokenAddress).transfer(autoLiquidityReceiver, tokens);
    }

    function setStructure(uint256 _percentonbuy, uint256 _percentonsell, uint256 _wallettransfer) external onlyOwner {
        sellpercent = _percentonsell;
        buypercent = _percentonbuy;
        transferpercent = _wallettransfer;    
          
    }
       
    function startTrading() public onlyOwner {
        TradingOpen = true;
        buypercent = 1400;
        sellpercent = 800;
        transferpercent = 1000;
                              
    }

      function reduceFee() public onlyOwner {
       
        buypercent = 400;
        sellpercent = 700;
        transferpercent = 500;
                              
    }

             
    function swapBack() internal swapping {
        uint256 dynamicLiquidityFee = checkRatio(setRatio, setRatioDenominator) ? 0 : liquidityFee;
        uint256 amountToLiquify = swapThreshold.mul(dynamicLiquidityFee).div(totalFee).div(2);
        uint256 amountToSwap = swapThreshold.sub(amountToLiquify);

        address[] memory path = new address[](2);
        path[0] = address(this);
        path[1] = WETH;

        uint256 balanceBefore = address(this).balance;

        router.swapExactTokensForETHSupportingFeeOnTransferTokens(
            amountToSwap,
            0,
            path,
            address(this),
            block.timestamp
        );

        uint256 amountETH = address(this).balance.sub(balanceBefore);

        uint256 totalETHFee = totalFee.sub(dynamicLiquidityFee.div(2));
        
        uint256 amountETHLiquidity = amountETH.mul(dynamicLiquidityFee).div(totalETHFee).div(2);
        uint256 amountETHMarketing = amountETH.mul(marketingFee).div(totalETHFee);
        uint256 amountETHbuyback = amountETH.mul(buybackFee).div(totalETHFee);
        uint256 amountETHdev = amountETH.mul(devFee).div(totalETHFee);

        (bool tmpSuccess,) = payable(marketingFeeReceiver).call{value: amountETHMarketing}("");
        (tmpSuccess,) = payable(devFeeReceiver).call{value: amountETHdev}("");
        (tmpSuccess,) = payable(buybackFeeReceiver).call{value: amountETHbuyback}("");
        
        tmpSuccess = false;

        if(amountToLiquify > 0){
            router.addLiquidityETH{value: amountETHLiquidity}(
                address(this),
                amountToLiquify,
                0,
                0,
                autoLiquidityReceiver,
                block.timestamp
            );
            emit AutoLiquify(amountETHLiquidity, amountToLiquify);
        }
    }
    
  
    function set_fees() internal {
      
        emit EditTax( uint8(totalFee.mul(buypercent).div(100)),
            uint8(totalFee.mul(sellpercent).div(100)),
            uint8(totalFee.mul(transferpercent).div(100))
            );
    }
    
    function setParameters(uint256 _liquidityFee, uint256 _buybackFee, uint256 _marketingFee, uint256 _devFee, uint256 _burnFee, uint256 _feeDenominator) external onlyOwner {
        liquidityFee = _liquidityFee;
        buybackFee = _buybackFee;
        marketingFee = _marketingFee;
        devFee = _devFee;
        burnFee = _burnFee;
        totalFee = _liquidityFee.add(_buybackFee).add(_marketingFee).add(_devFee).add(_burnFee);
        feeDenominator = _feeDenominator;
        require(totalFee < feeDenominator / 2, "Fees can not be more than 50%"); 
        set_fees();
    }

   
    function setWallets(address _autoLiquidityReceiver, address _marketingFeeReceiver, address _devFeeReceiver, address _burnFeeReceiver, address _buybackFeeReceiver) external onlyOwner {
        autoLiquidityReceiver = _autoLiquidityReceiver;
        marketingFeeReceiver = _marketingFeeReceiver;
        devFeeReceiver = _devFeeReceiver;
        burnFeeReceiver = _burnFeeReceiver;
        buybackFeeReceiver = _buybackFeeReceiver;

        emit set_Receivers(marketingFeeReceiver, buybackFeeReceiver, burnFeeReceiver, devFeeReceiver);
    }

    function setSwapBackSettings(bool _enabled, uint256 _amount) external onlyOwner {
        swapEnabled = _enabled;
        swapThreshold = _amount;
        emit set_SwapBack(swapThreshold, swapEnabled);
    }

    function checkRatio(uint256 ratio, uint256 accuracy) public view returns (bool) {
        return showBacking(accuracy) > ratio;
    }

    function showBacking(uint256 accuracy) public view returns (uint256) {
        return accuracy.mul(balanceOf(pair).mul(2)).div(showSupply());
    }
    
    function showSupply() public view returns (uint256) {
        return _totalSupply.sub(balanceOf(DEAD)).sub(balanceOf(ZERO));
    }


}

Read Contract

TradingOpen 0x08fd3d05 → bool
_maxTxAmount 0x7d1db4a5 → uint256
_maxWalletToken 0x78109e54 → uint256
_owner 0xb2bdfa7b → address
allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
checkRatio 0xded1e438 → bool
decimals 0x313ce567 → uint8
getOwner 0x893d20e8 → address
name 0x06fdde03 → string
owner 0x8da5cb5b → address
pair 0xa8aa1b31 → address
router 0xf887ea40 → address
showBacking 0x30c9a6a0 → uint256
showSupply 0x55265669 → uint256
swapEnabled 0x6ddd1713 → bool
swapThreshold 0x0445b667 → uint256
symbol 0x95d89b41 → string
totalFee 0x1df4ccfc → uint256
totalSupply 0x18160ddd → uint256

Write Contract 16 functions

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

approve 0x095ea7b3
address spender
uint256 amount
returns: bool
approveMax 0x571ac8b0
address spender
returns: bool
clearStuckToken 0x77b54bad
address tokenAddress
uint256 tokens
returns: bool
manualSend 0xf4293890
No parameters
maxWalletRule 0x5d83e1d5
uint256 maxWallPercent
reduceFee 0xa70419d2
No parameters
removeLimits 0x751039fc
No parameters
renounceOwnership 0x715018a6
No parameters
setParameters 0x282c8749
uint256 _liquidityFee
uint256 _buybackFee
uint256 _marketingFee
uint256 _devFee
uint256 _burnFee
uint256 _feeDenominator
setStructure 0xc0cbdea4
uint256 _percentonbuy
uint256 _percentonsell
uint256 _wallettransfer
setSwapBackSettings 0xdf20fd49
bool _enabled
uint256 _amount
setWallets 0x82528791
address _autoLiquidityReceiver
address _marketingFeeReceiver
address _devFeeReceiver
address _burnFeeReceiver
address _buybackFeeReceiver
startTrading 0x293230b8
No parameters
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