Forkchoice Ethereum Mainnet

Address Contract Partially Verified

Address 0x3ED14EB42e852E73B0eB8a4b92A84DF020008eb1
Balance 0.102834 ETH ($212.61)
Nonce 1
Code Size 8214 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

8214 bytes
0x6080604052600436106101735760003560e01c806370a08231116100c8578063a983e4c811610084578063dd62ed3e11610061578063dd62ed3e146104c8578063dd705ff61461050e578063f2fde38b1461052e578063f3bc9ab01461054e57005b8063a983e4c814610473578063b5e1024614610493578063c9567bf9146104b357005b806370a0823114610392578063715018a6146103c8578063731987e3146103dd5780638da5cb5b146103fd57806395d89b4114610425578063a9059cbb1461045357005b8063313ce5671161012f5780633be00bc71161010c5780633be00bc7146103045780633f4218e01461031957806340c10f191461035257806345167f261461037257005b8063313ce567146102a85780633185f281146102c457806336dacd1f146102e457005b806306fdde031461017c578063095ea7b3146101bb5780630e947bd8146101eb57806318160ddd146102495780631c21f4571461026857806323b872dd1461028857005b3661017a57005b005b34801561018857600080fd5b506040805180820190915260048152634c696c7960e01b60208201525b6040516101b29190611b66565b60405180910390f35b3480156101c757600080fd5b506101db6101d6366004611bd0565b610569565b60405190151581526020016101b2565b3480156101f757600080fd5b5061022e610206366004611bfa565b6001600160a01b03166000908152601a60205260409020805460018201546002909201549092565b604080519384526020840192909252908201526060016101b2565b34801561025557600080fd5b506003545b6040519081526020016101b2565b34801561027457600080fd5b5061017a610283366004611c15565b610580565b34801561029457600080fd5b506101db6102a3366004611c58565b610675565b3480156102b457600080fd5b50604051601281526020016101b2565b3480156102d057600080fd5b5061017a6102df366004611ca4565b61071f565b3480156102f057600080fd5b5061017a6102ff366004611d1f565b61082d565b34801561031057600080fd5b5061017a61090a565b34801561032557600080fd5b506101db610334366004611bfa565b6001600160a01b03166000908152601b602052604090205460ff1690565b34801561035e57600080fd5b5061017a61036d366004611bd0565b610a3e565b34801561037e57600080fd5b5061017a61038d366004611d38565b610a76565b34801561039e57600080fd5b5061025a6103ad366004611bfa565b6001600160a01b031660009081526001602052604090205490565b3480156103d457600080fd5b5061017a610b03565b3480156103e957600080fd5b5061017a6103f8366004611d1f565b610b37565b34801561040957600080fd5b506000546040516001600160a01b0390911681526020016101b2565b34801561043157600080fd5b50604080518082019091526005815264244c494c5960d81b60208201526101a5565b34801561045f57600080fd5b506101db61046e366004611bd0565b610c6e565b34801561047f57600080fd5b5061017a61048e366004611d6b565b610c7b565b34801561049f57600080fd5b5061017a6104ae366004611d6b565b610e1f565b3480156104bf57600080fd5b5061017a610f0a565b3480156104d457600080fd5b5061025a6104e3366004611d97565b6001600160a01b03918216600090815260026020908152604080832093909416825291909152205490565b34801561051a57600080fd5b5061017a610529366004611dc1565b610f96565b34801561053a57600080fd5b5061017a610549366004611bfa565b611024565b34801561055a57600080fd5b5060155460165460175461022e565b60006105763384846110bc565b5060015b92915050565b6000546001600160a01b031633146105b35760405162461bcd60e51b81526004016105aa90611df4565b60405180910390fd5b600480546001600160a01b038581166001600160a01b031992831681179093556005805486831690841681178255600680548785169516851781556000868152601b60209081526040808320805460ff1990811660019081179092559654881684528184208054881682179055935490961682529085902080549094169091179092558251948552908401528201527fde145ec6f1793d5ad81aded80dcfddf13a1c1cdd652f2f2f10012b43b309b20b906060015b60405180910390a1505050565b60006106828484846111e0565b6001600160a01b0384166000908152600260209081526040808320338452909152902054828110156107075760405162461bcd60e51b815260206004820152602860248201527f45524332303a207472616e7366657220616d6f756e74206578636565647320616044820152676c6c6f77616e636560c01b60648201526084016105aa565b61071485338584036110bc565b506001949350505050565b6000546001600160a01b031633146107495760405162461bcd60e51b81526004016105aa90611df4565b8160005b818110156108265782601b600087878581811061076c5761076c611e29565b90506020020160208101906107819190611bfa565b6001600160a01b031681526020810191909152604001600020805460ff19169115159190911790558484828181106107bb576107bb611e29565b90506020020160208101906107d09190611bfa565b6001600160a01b03167f2f640a0ab7e2a6d9ec57f3932923908568f2984073dcebac1b9a3db32debe91d8460405161080c911515815260200190565b60405180910390a28061081e81611e55565b91505061074d565b5050505050565b6000546001600160a01b031633146108575760405162461bcd60e51b81526004016105aa90611df4565b600e5481116108ce5760405162461bcd60e51b815260206004820152603960248201527f4c494c594c4f473a3a204d61782068616c76696e67206d75737420626520686960448201527f67686572207468616e20746865207072696f722076616c75650000000000000060648201526084016105aa565b600e8190556040518181527fa4697db1f1b076a8a902307d14f5d9a2afbe9c58933f3f80c747bd3d02b25e01906020015b60405180910390a150565b6000546001600160a01b031633146109345760405162461bcd60e51b81526004016105aa90611df4565b600061096b6011546109656010546012600a6109509190611f52565b61095f906461c9f36800611f61565b906118c5565b906118d8565b90506001601054101561097b5750565b600454600a546109a6916001600160a01b0316906109a1906064906109659086906118c5565b6118e4565b600554600b546109cc916001600160a01b0316906109a1906064906109659086906118c5565b600654600c546109f2916001600160a01b0316906109a1906064906109659086906118c5565b600e546012541015610a3a57610a21610a18601254600f546118c590919063ffffffff16565b601054906119bc565b60105560128054906000610a3483611e55565b91905055505b505b565b6000546001600160a01b03163314610a685760405162461bcd60e51b81526004016105aa90611df4565b610a7282826118e4565b5050565b6000546001600160a01b03163314610aa05760405162461bcd60e51b81526004016105aa90611df4565b6001600160a01b0382166000818152601c6020908152604091829020805460ff19168515159081179091558251938452908301527f1e71719b96ca7e93812afcce6915bf5fce856b2ef956f7b83f07b1265423bc50910160405180910390a15050565b6000546001600160a01b03163314610b2d5760405162461bcd60e51b81526004016105aa90611df4565b610a3c60006119c8565b6000546001600160a01b03163314610b615760405162461bcd60e51b81526004016105aa90611df4565b60008111610bce5760405162461bcd60e51b815260206004820152603460248201527f4c494c594c4f473a3a2048616c76696e6720726564756374696f6e206d75737460448201527320626520686967686572207468616e207a65726f60601b60648201526084016105aa565b60648110610c395760405162461bcd60e51b815260206004820152603260248201527f4c494c594c4f473a3a2048616c76696e6720726564756374696f6e206d7573746044820152710206265206c6f776572207468616e203130360741b60648201526084016105aa565b600f8190556040518181527f45f469c6dd586dc503baf365bbc7024d5d556d9ece7ddf65f27c8ce3787d3bc9906020016108ff565b60006105763384846111e0565b6000546001600160a01b03163314610ca55760405162461bcd60e51b81526004016105aa90611df4565b60008311610d085760405162461bcd60e51b815260206004820152602a60248201527f4c494c594c4f473a3a2042757920746178206d75737420626520686967686572604482015269207468616e207a65726f60b01b60648201526084016105aa565b60008211610d6c5760405162461bcd60e51b815260206004820152602b60248201527f4c494c594c4f473a3a2053656c6c20746178206d75737420626520686967686560448201526a72207468616e207a65726f60a81b60648201526084016105aa565b60008111610dd25760405162461bcd60e51b815260206004820152602d60248201527f4c494c594c4f473a3a204e6f726d616c20746178206d7573742062652068696760448201526c686572207468616e207a65726f60981b60648201526084016105aa565b60078390556008829055600981905560408051848152602081018490529081018290527f4edbdf12092392c7d7e3c32a25cce7dc147e18e10eea069f23ec6f9a83a58b0f90606001610668565b6000546001600160a01b03163314610e495760405162461bcd60e51b81526004016105aa90611df4565b80610e548385611f78565b610e5e9190611f78565b606414610ebd5760405162461bcd60e51b815260206004820152602760248201527f4c494c594c4f473a3a2054617820616c6c6f636174696f6e206973206e6f742060448201526618dbdc9c9958dd60ca1b60648201526084016105aa565b600a839055600b829055600c81905560408051848152602081018490529081018290527f1c445907ee3fa546b1efa310d7f2600e4fc56ca7ed8c3e0af9e1161c5903688e90606001610668565b6000546001600160a01b03163314610f345760405162461bcd60e51b81526004016105aa90611df4565b6019805460ff60a01b1916600160a01b908117918290556040517f76f69943a2756d687cf7ae40efea861deaafb28c2f7a68532134f90057ec69f392610f8c92900460ff169042909115158252602082015260400190565b60405180910390a1565b6000546001600160a01b03163314610fc05760405162461bcd60e51b81526004016105aa90611df4565b6019805460ff60a81b1916600160a81b8515159081029190911790915560148390556013829055604080519182526020820184905281018290527f5615b91c861299662bed50a58c3a8bc7f4dc9f7b7e318d95317f62930016be8d90606001610668565b6000546001600160a01b0316331461104e5760405162461bcd60e51b81526004016105aa90611df4565b6001600160a01b0381166110b35760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b60648201526084016105aa565b610a3a816119c8565b6001600160a01b03831661111e5760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016105aa565b6001600160a01b03821661117f5760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016105aa565b6001600160a01b0383811660008181526002602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b600081116112305760405162461bcd60e51b815260206004820152601b60248201527f45524332303a207472616e7366657220616d6f756e74207a65726f000000000060448201526064016105aa565b6001600160a01b0383166112945760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b60648201526084016105aa565b6001600160a01b0382166112f65760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b60648201526084016105aa565b6001600160a01b0383166000908152601b602052604081205460ff168061133557506001600160a01b0383166000908152601b602052604090205460ff165b601954909150600160a01b900460ff168061134d5750805b6113995760405162461bcd60e51b815260206004820181905260248201527f4c494c594c4f473a3a2054726164696e67206973206e6f7420616c6c6f77656460448201526064016105aa565b6001600160a01b0383166000908152601c602052604090205460ff161580156113c0575080155b80156113d55750601954600160a81b900460ff165b156114af5760145482111561142c5760405162461bcd60e51b815260206004820181905260248201527f4c494c594c4f473a3a20496e73756666696369656e7420747820616d6f756e7460448201526064016105aa565b6013546001600160a01b038416600090815260016020526040902054611453908490611f78565b11156114af5760405162461bcd60e51b815260206004820152602560248201527f4c494c594c4f473a3a20496e73756666696369656e742074726164696e6720616044820152641b5bdd5b9d60da1b60648201526084016105aa565b6000806114bc8686611a18565b156114cf576114cc868686611a6c565b91505b6114d984836119bc565b6001600160a01b0387166000908152600160205260409020549091506114ff90856119bc565b6001600160a01b03808816600090815260016020526040808220939093559087168152205461152e9082611b5a565b6001600160a01b038087166000818152600160205260409081902093909355915190881690600080516020611fc1833981519152906115709085815260200190565b60405180910390a38115611757576115bc61159b6064610965600a54866118c590919063ffffffff16565b6004546001600160a01b031660009081526001602052604090205490611b5a565b6004546001600160a01b0316600090815260016020526040902055600b54611611906115f0906064906109659086906118c5565b6005546001600160a01b031660009081526001602052604090205490611b5a565b6005546001600160a01b0316600090815260016020526040902055600c5461166690611645906064906109659086906118c5565b6006546001600160a01b031660009081526001602052604090205490611b5a565b6006546001600160a01b03908116600090815260016020526040902091909155600454600a5490821691881690600080516020611fc1833981519152906116b5906064906109659088906118c5565b60405190815260200160405180910390a3600554600b546001600160a01b0391821691881690600080516020611fc1833981519152906116fd906064906109659088906118c5565b60405190815260200160405180910390a3600654600c546001600160a01b0391821691881690600080516020611fc183398151915290611745906064906109659088906118c5565b60405190815260200160405180910390a35b6001600160a01b0386166000908152601c602052604090205460ff16801561179857506001600160a01b0385166000908152601c602052604090205460ff16155b156117e9576001600160a01b0385166000908152601a6020526040812080548692906117c5908490611f78565b9250508190555083601560008282546117de9190611f78565b909155506118bd9050565b6001600160a01b0386166000908152601c602052604090205460ff1615801561182a57506001600160a01b0385166000908152601c602052604090205460ff165b15611873576001600160a01b0386166000908152601a60205260408120600101805486929061185a908490611f78565b9250508190555083601660008282546117de9190611f78565b6001600160a01b0386166000908152601a60205260408120600201805486929061189e908490611f78565b9250508190555083601760008282546118b79190611f78565b90915550505b505050505050565b60006118d18284611f61565b9392505050565b60006118d18284611f8b565b6001600160a01b0382166119455760405162461bcd60e51b815260206004820152602260248201527f4c494c594c4f473a3a204d696e7420746f20746865207a65726f206164647265604482015261737360f01b60648201526084016105aa565b80600360008282546119579190611f78565b90915550506001600160a01b03821660009081526001602052604081208054839290611984908490611f78565b90915550506040518181526001600160a01b03831690600090600080516020611fc18339815191529060200160405180910390a35050565b60006118d18284611fad565b600080546001600160a01b038381166001600160a01b0319831681178455604051919092169283917f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e09190a35050565b6001600160a01b0382166000908152601b602052604081205460ff1680611a5757506001600160a01b0382166000908152601b602052604090205460ff165b15611a645750600061057a565b50600161057a565b6001600160a01b0383166000908152601c6020526040812054819060ff1615611ab157611aaa6103e8610965600754866118c590919063ffffffff16565b9050611b52565b6001600160a01b0384166000908152601c602052604090205460ff1615611aed57611aaa6103e8610965600854866118c590919063ffffffff16565b6001600160a01b0385166000908152601c602052604090205460ff16158015611b2f57506001600160a01b0384166000908152601c602052604090205460ff16155b15611b5257611b4f6103e8610965600954866118c590919063ffffffff16565b90505b949350505050565b60006118d18284611f78565b600060208083528351808285015260005b81811015611b9357858101830151858201604001528201611b77565b506000604082860101526040601f19601f8301168501019250505092915050565b80356001600160a01b0381168114611bcb57600080fd5b919050565b60008060408385031215611be357600080fd5b611bec83611bb4565b946020939093013593505050565b600060208284031215611c0c57600080fd5b6118d182611bb4565b600080600060608486031215611c2a57600080fd5b611c3384611bb4565b9250611c4160208501611bb4565b9150611c4f60408501611bb4565b90509250925092565b600080600060608486031215611c6d57600080fd5b611c7684611bb4565b9250611c8460208501611bb4565b9150604084013590509250925092565b80358015158114611bcb57600080fd5b600080600060408486031215611cb957600080fd5b833567ffffffffffffffff80821115611cd157600080fd5b818601915086601f830112611ce557600080fd5b813581811115611cf457600080fd5b8760208260051b8501011115611d0957600080fd5b602092830195509350611c4f9186019050611c94565b600060208284031215611d3157600080fd5b5035919050565b60008060408385031215611d4b57600080fd5b611d5483611bb4565b9150611d6260208401611c94565b90509250929050565b600080600060608486031215611d8057600080fd5b505081359360208301359350604090920135919050565b60008060408385031215611daa57600080fd5b611db383611bb4565b9150611d6260208401611bb4565b600080600060608486031215611dd657600080fd5b611ddf84611c94565b95602085013595506040909401359392505050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b600052603260045260246000fd5b634e487b7160e01b600052601160045260246000fd5b600060018201611e6757611e67611e3f565b5060010190565b600181815b80851115611ea9578160001904821115611e8f57611e8f611e3f565b80851615611e9c57918102915b93841c9390800290611e73565b509250929050565b600082611ec05750600161057a565b81611ecd5750600061057a565b8160018114611ee35760028114611eed57611f09565b600191505061057a565b60ff841115611efe57611efe611e3f565b50506001821b61057a565b5060208310610133831016604e8410600b8410161715611f2c575081810a61057a565b611f368383611e6e565b8060001904821115611f4a57611f4a611e3f565b029392505050565b60006118d160ff841683611eb1565b808202811582820484141761057a5761057a611e3f565b8082018082111561057a5761057a611e3f565b600082611fa857634e487b7160e01b600052601260045260246000fd5b500490565b8181038181111561057a5761057a611e3f56feddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3efa2646970667358221220dcf349fbb5b2124ca8cde13d58661142505ccec8c0e3ef9e2266f06c75608cbe64736f6c63430008130033

Verified Source Code Partial Match

Compiler: v0.8.19+commit.7dd6d404 EVM: paris Optimization: Yes (200 runs)
LILY.sol 598 lines
//SPDX-License-Identifier: MIT

// File: contracts/interfaces/IERC20.sol

pragma solidity ^0.8.19;

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

    function isFeeExempt(address addr) external view returns (bool);

    function getTradingInfo(address trader) external view returns (uint256, uint256, uint256);

    function getTotalTradingInfo() external view returns (uint256, uint256, uint256);

    event Transfer(address indexed from, address indexed to, uint256 value);

    event Approval(address indexed owner, address indexed spender, uint256 value);
}
// File: contracts/interfaces/IERC20Metadata.sol

pragma solidity ^0.8.19;


interface IERC20Metadata is IERC20 {
    function name() external view returns (string memory);

    function symbol() external view returns (string memory);

    function decimals() external view returns (uint8);
}
// File: contracts/libraries/SafeMath.sol

pragma solidity ^0.8.19;

library SafeMath {
    function tryAdd(
        uint256 a,
        uint256 b
    ) internal pure returns (bool, uint256) {
        unchecked {
            uint256 c = a + b;
            if (c < a) return (false, 0);
            return (true, c);
        }
    }

    function trySub(
        uint256 a,
        uint256 b
    ) internal pure returns (bool, uint256) {
        unchecked {
            if (b > a) return (false, 0);
            return (true, a - b);
        }
    }

    function tryMul(
        uint256 a,
        uint256 b
    ) internal pure returns (bool, uint256) {
        unchecked {
            if (a == 0) return (true, 0);
            uint256 c = a * b;
            if (c / a != b) return (false, 0);
            return (true, c);
        }
    }

    function tryDiv(
        uint256 a,
        uint256 b
    ) internal pure returns (bool, uint256) {
        unchecked {
            if (b == 0) return (false, 0);
            return (true, a / b);
        }
    }

    function tryMod(
        uint256 a,
        uint256 b
    ) internal pure returns (bool, uint256) {
        unchecked {
            if (b == 0) return (false, 0);
            return (true, a % b);
        }
    }

    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        return a + b;
    }

    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
        return a - b;
    }

    function mul(uint256 a, uint256 b) internal pure returns (uint256) {
        return a * b;
    }

    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        return a / b;
    }

    function mod(uint256 a, uint256 b) internal pure returns (uint256) {
        return a % b;
    }

    function sub(
        uint256 a,
        uint256 b,
        string memory errorMessage
    ) internal pure returns (uint256) {
        unchecked {
            require(b <= a, errorMessage);
            return a - b;
        }
    }

    function div(
        uint256 a,
        uint256 b,
        string memory errorMessage
    ) internal pure returns (uint256) {
        unchecked {
            require(b > 0, errorMessage);
            return a / b;
        }
    }

    function mod(
        uint256 a,
        uint256 b,
        string memory errorMessage
    ) internal pure returns (uint256) {
        unchecked {
            require(b > 0, errorMessage);
            return a % b;
        }
    }
}
// File: contracts/libraries/Context.sol

pragma solidity ^0.8.19;

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

    function _msgData() internal view virtual returns (bytes calldata) {
        return msg.data;
    }
}
// File: contracts/libraries/Ownable.sol

pragma solidity ^0.8.19;


abstract contract Ownable is Context {
    address private _owner;

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

    constructor() {
        _transferOwnership(_msgSender());
    }

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

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

    function renounceOwnership() public virtual onlyOwner {
        _transferOwnership(address(0));
    }

    function transferOwnership(address newOwner) public virtual onlyOwner {
        require(newOwner != address(0), "Ownable: new owner is the zero address");
        _transferOwnership(newOwner);
    }

    function _transferOwnership(address newOwner) internal virtual {
        address oldOwner = _owner;
        _owner = newOwner;
        emit OwnershipTransferred(oldOwner, newOwner);
    }
}

interface IUniswapV2Factory {
    event PairCreated(
        address indexed token0,
        address indexed token1,
        address pair,
        uint256
    );

    function feeTo() external view returns (address);

    function feeToSetter() external view returns (address);

    function getPair(
        address tokenA,
        address tokenB
    ) external view returns (address pair);

    function allPairs(uint256) external view returns (address pair);

    function allPairsLength() external view returns (uint256);

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

    function setFeeTo(address) external;

    function setFeeToSetter(address) external;
}

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

    function WETH() external pure returns (address);

    function addLiquidity(
        address tokenA,
        address tokenB,
        uint256 amountADesired,
        uint256 amountBDesired,
        uint256 amountAMin,
        uint256 amountBMin,
        address to,
        uint256 deadline
    ) external returns (uint256 amountA, uint256 amountB, uint256 liquidity);

    function addLiquidityETH(
        address token,
        uint256 amountTokenDesired,
        uint256 amountTokenMin,
        uint256 amountETHMin,
        address to,
        uint256 deadline
    )
        external
        payable
        returns (uint256 amountToken, uint256 amountETH, uint256 liquidity);

    function swapExactTokensForTokensSupportingFeeOnTransferTokens(
        uint256 amountIn,
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external;

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

    function swapExactTokensForETHSupportingFeeOnTransferTokens(
        uint256 amountIn,
        uint256 amountOutMin,
        address[] calldata path,
        address to,
        uint256 deadline
    ) external;
}
// File: contracts/LILY.sol

pragma solidity ^0.8.19;

contract LILY is Context, IERC20Metadata, Ownable {
    using SafeMath for uint256;

    struct TradingInfo {
        uint256 boughtAmount;
        uint256 soldAmount;
        uint256 transferredAmount;
    }

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

    uint256 private _totalSupply;
    string private constant _name = "Lily";
    string private constant _symbol = "$LILY";
    uint8 private constant _decimals = 18;
    uint256 private constant _hardCap = 420_000_000_000 * (10 ** _decimals);

    address payable _liquidityWallet;
    address payable _rewardWallet;
    address payable _companyWallet;

    uint256 _buyTax = 15;
    uint256 _sellTax = 20;
    uint256 _normalTax = 5;

    uint256 _liquidityWalletTaxAllocation = 45;
    uint256 _rewardWalletTaxAllocation = 40;
    uint256 _companyWalletTaxAllocation = 15;

    uint256 _initialMintRatio = 25;
    uint256 _maxHalvings = 120;
    uint256 _halvingReduction = 25;
    uint256 _mintRate = 3000;
    uint256 _mintDenom = 100000;
    uint256 _halvingCount = 1;
    uint256 _maxHoldingAmount = _hardCap.div(400);
    uint256 _maxTxAmount = _hardCap.div(800);

    uint256 _totalBoughtAmount = 0;
    uint256 _totalSoldAmount = 0;
    uint256 _totalTransferredAmount = 0;

    IUniswapV2Router02 _uniswapRouter;
    address _uniswapPair;
    bool _tradingOpen = false;
    bool _limited = true;

    mapping(address => TradingInfo) _tradingInfo;
    mapping(address => bool) _isFeeExempt;
    mapping(address => bool) _automatedMarketMakerPairs;

    event OpenTrading(bool flag, uint256 timeStamp);
    event HalvingMint(address to, uint256 amount, uint256 halvingCount);
    event SetAutomatedMarketMakerPairs(address ammPair, bool flag);
    event SetLimitation(bool limit, uint256 maxTxAmount, uint256 maxHoldingAmount);
    event SetFeeExempt(address indexed addr, bool value);
    event SetTax(uint256 buyTax, uint256 sellTax, uint256 normalTax);
    event SetTaxWallet(address liquidityWallet, address rewardWallet, address companyWallet);
    event SetTaxAllocation(uint256 liquidityWalletTaxAllocation, uint256 rewardWalletTaxAllocation, uint256 companyWalletTaxAllocation);
    event SetMaxHalving(uint256 maxHalving);
    event SetHalvingReduction(uint256 halvingReduction);

    constructor() {
        _uniswapRouter = IUniswapV2Router02(
            0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D
        );
        _uniswapPair = IUniswapV2Factory(_uniswapRouter.factory())
            .createPair(address(this), _uniswapRouter.WETH());
        _mint(msg.sender, _hardCap.mul(_initialMintRatio).div(100));
        _automatedMarketMakerPairs[_uniswapPair] = true;
        _isFeeExempt[msg.sender] = true;
        _isFeeExempt[address(this)] = true;
    }

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

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

    function decimals() public pure override 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 transfer(address recipient, uint256 amount) public override returns (bool) {
        _transfer(_msgSender(), recipient, amount);
        return true;
    }

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

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

    function transferFrom(address sender, address recipient, uint256 amount) public override returns (bool) {
        _transfer(sender, recipient, amount);

        uint256 currentAllowance = _allowances[sender][_msgSender()];
        require(
            currentAllowance >= amount,
            "ERC20: transfer amount exceeds allowance"
        );
        unchecked {
            _approve(sender, _msgSender(), currentAllowance - amount);
        }

        return true;
    }

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

        _allowances[from][to] = amount;
        emit Approval(from, to, amount);
    }

    function _transfer(address from, address to, uint256 amount) private {
        require(amount > 0, "ERC20: transfer amount zero");
        require(from != address(0), "ERC20: transfer from the zero address");
        require(to != address(0), "ERC20: transfer to the zero address");
        
        bool excludedAccount = _isFeeExempt[from] || _isFeeExempt[to];
        require(_tradingOpen || excludedAccount, "LILYLOG:: Trading is not allowed");

        if (!_automatedMarketMakerPairs[to] && !excludedAccount && _limited) {
            require(amount <= _maxTxAmount, "LILYLOG:: Insufficient tx amount");
            require(_balances[to] + amount <= _maxHoldingAmount, "LILYLOG:: Insufficient trading amount");
        }

        uint256 taxAmount = 0;
        uint256 sendAmount;

        if (shouldTakeFee(from, to)) {
            taxAmount = calculateTax(from, to, amount);
        }

        sendAmount = amount.sub(taxAmount);
        _balances[from] = _balances[from].sub(amount);
        _balances[to] = _balances[to].add(sendAmount);
        emit Transfer(from, to, sendAmount);

        if (taxAmount > 0) {
            _balances[_liquidityWallet] = _balances[_liquidityWallet].add(taxAmount.mul(_liquidityWalletTaxAllocation).div(100));
            _balances[_rewardWallet] = _balances[_rewardWallet].add(taxAmount.mul(_rewardWalletTaxAllocation).div(100));
            _balances[_companyWallet] = _balances[_companyWallet].add(taxAmount.mul(_companyWalletTaxAllocation).div(100));
            emit Transfer(from, _liquidityWallet, taxAmount.mul(_liquidityWalletTaxAllocation).div(100));
            emit Transfer(from, _rewardWallet, taxAmount.mul(_rewardWalletTaxAllocation).div(100));
            emit Transfer(from, _companyWallet, taxAmount.mul(_companyWalletTaxAllocation).div(100));
        }

        if (_automatedMarketMakerPairs[from] && !_automatedMarketMakerPairs[to]) {
            _tradingInfo[to].boughtAmount += amount;
            _totalBoughtAmount += amount;
        } else if (!_automatedMarketMakerPairs[from] && _automatedMarketMakerPairs[to]) {
            _tradingInfo[from].soldAmount += amount;
            _totalSoldAmount += amount;
        } else {
            _tradingInfo[from].transferredAmount += amount;
            _totalTransferredAmount += amount;
        }
    }

    function _mint(address account, uint256 amount) private {
        require(account != address(0), "LILYLOG:: Mint to the zero address");
        _totalSupply += amount;
        _balances[account] += amount;
        emit Transfer(address(0), account, amount);
    }

    function mint(address account, uint256 amount) external onlyOwner {
        _mint(account, amount);
    }

    function halvingMint() external onlyOwner() {
        uint256 mintAmount = _hardCap.mul(_mintRate).div(_mintDenom);
        if (_mintRate < 1)
            return;
        _mint(_liquidityWallet, mintAmount.mul(_liquidityWalletTaxAllocation).div(100));
        _mint(_rewardWallet, mintAmount.mul(_rewardWalletTaxAllocation).div(100));
        _mint(_companyWallet, mintAmount.mul(_companyWalletTaxAllocation).div(100));
        if (_halvingCount < _maxHalvings) {
            _mintRate = _mintRate.sub(_halvingReduction.mul(_halvingCount));
            _halvingCount++;
        }        
    }

    function shouldTakeFee(address from, address to) private view returns (bool) {
        if (_isFeeExempt[from] || _isFeeExempt[to]) {
            return false;
        } else {
            return true;
        }
    }

    function calculateTax(address from, address to, uint amount) private view returns (uint256) {
        uint256 taxAmount = 0;
        if (_automatedMarketMakerPairs[from]) {
            taxAmount = amount.mul(_buyTax).div(1000);
        } else if (_automatedMarketMakerPairs[to]) {
            taxAmount = amount.mul(_sellTax).div(1000);
        } else if (!_automatedMarketMakerPairs[from] && !_automatedMarketMakerPairs[to]) {
            taxAmount = amount.mul(_normalTax).div(1000);
        }
        return taxAmount;
    }

    function setFeeExempt(address[] calldata addressLists, bool value) external onlyOwner {
        uint256 length = addressLists.length;
        for (uint256 i = 0; i < length; i ++) {
            _isFeeExempt[addressLists[i]] = value;
            emit SetFeeExempt(addressLists[i], value);
        }
    }

    function openTrading() external onlyOwner {
        _tradingOpen = true;
        emit OpenTrading(_tradingOpen, block.timestamp);
    }

    function setAutomatedMarketMakerPairs(address ammPair, bool flag) external onlyOwner {
        _automatedMarketMakerPairs[ammPair] = flag;
        emit SetAutomatedMarketMakerPairs(ammPair, flag);
    }

    function setLimitation(bool limited, uint256 maxTxAmount, uint256 maxHoldingAmount) external onlyOwner {
        _limited = limited;
        _maxTxAmount = maxTxAmount;
        _maxHoldingAmount = maxHoldingAmount;
        emit SetLimitation(limited, maxTxAmount, maxHoldingAmount);
    }

    function setTax(uint256 buyTax, uint256 sellTax, uint256 normalTax) external onlyOwner {
        require(buyTax > 0, "LILYLOG:: Buy tax must be higher than zero");
        require(sellTax > 0, "LILYLOG:: Sell tax must be higher than zero");
        require(normalTax > 0, "LILYLOG:: Normal tax must be higher than zero");
        _buyTax = buyTax;
        _sellTax = sellTax;
        _normalTax = normalTax;
        emit SetTax(buyTax, sellTax, normalTax);
    }

    function setTaxAllocation(uint256 liquidityWalletTaxAllocation, uint256 rewardWalletTaxAllocation, uint256 companyWalletTaxAllocation) external onlyOwner {
        require(liquidityWalletTaxAllocation + rewardWalletTaxAllocation + companyWalletTaxAllocation == 100, "LILYLOG:: Tax allocation is not correct");
        _liquidityWalletTaxAllocation = liquidityWalletTaxAllocation;
        _rewardWalletTaxAllocation = rewardWalletTaxAllocation;
        _companyWalletTaxAllocation = companyWalletTaxAllocation;
        emit SetTaxAllocation(liquidityWalletTaxAllocation, rewardWalletTaxAllocation, companyWalletTaxAllocation);
    }

    function setTaxWallet(address liquidityWallet, address rewardWallet, address companyWallet) external onlyOwner {
        _liquidityWallet = payable(liquidityWallet);
        _rewardWallet = payable(rewardWallet);
        _companyWallet = payable(companyWallet);
        _isFeeExempt[_liquidityWallet] = true;
        _isFeeExempt[_rewardWallet] = true;
        _isFeeExempt[_companyWallet] = true;
        emit SetTaxWallet(liquidityWallet, rewardWallet, companyWallet);
    }

    function setMaxHalving(uint256 maxHalvings) external onlyOwner {
        require(maxHalvings > _maxHalvings, "LILYLOG:: Max halving must be higher than the prior value");
        _maxHalvings = maxHalvings;
        emit SetMaxHalving(maxHalvings);
    }

    function setHalvingReduction(uint256 halvingReduction) external onlyOwner {
        require(halvingReduction > 0, "LILYLOG:: Halving reduction must be higher than zero");
        require(halvingReduction < 100, "LILYLOG:: Halving reduction must be lower than 100");
        _halvingReduction = halvingReduction;
        emit SetHalvingReduction(halvingReduction);
    }

    function isFeeExempt(address addr) external view returns (bool) {
        return _isFeeExempt[addr];
    }

    function getTradingInfo(address trader) external view returns (uint256, uint256, uint256) {
        return (_tradingInfo[trader].boughtAmount, _tradingInfo[trader].soldAmount, _tradingInfo[trader].transferredAmount);
    }

    function getTotalTradingInfo() external view returns (uint256, uint256, uint256) {
        return (_totalBoughtAmount, _totalSoldAmount, _totalTransferredAmount);
    }

    receive() payable external {}
    
    fallback() payable external {}
}

Read Contract

allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
decimals 0x313ce567 → uint8
getTotalTradingInfo 0xf3bc9ab0 → uint256, uint256, uint256
getTradingInfo 0x0e947bd8 → uint256, uint256, uint256
isFeeExempt 0x3f4218e0 → bool
name 0x06fdde03 → string
owner 0x8da5cb5b → address
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256

Write Contract 16 functions

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

approve 0x095ea7b3
address to
uint256 amount
returns: bool
halvingMint 0x3be00bc7
No parameters
mint 0x40c10f19
address account
uint256 amount
openTrading 0xc9567bf9
No parameters
renounceOwnership 0x715018a6
No parameters
setAutomatedMarketMakerPairs 0x45167f26
address ammPair
bool flag
setFeeExempt 0x3185f281
address[] addressLists
bool value
setHalvingReduction 0x731987e3
uint256 halvingReduction
setLimitation 0xdd705ff6
bool limited
uint256 maxTxAmount
uint256 maxHoldingAmount
setMaxHalving 0x36dacd1f
uint256 maxHalvings
setTax 0xa983e4c8
uint256 buyTax
uint256 sellTax
uint256 normalTax
setTaxAllocation 0xb5e10246
uint256 liquidityWalletTaxAllocation
uint256 rewardWalletTaxAllocation
uint256 companyWalletTaxAllocation
setTaxWallet 0x1c21f457
address liquidityWallet
address rewardWallet
address companyWallet
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