Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0x9B7331c6e98bAd1dC8F096fF3D98C93B3b9B1173
Balance 0.124110 ETH ($256.55)
Nonce 1
Code Size 8502 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

8502 bytes
0x60806040526004361061020a575f3560e01c80638a8c523c11610113578063c5d32bb21161009d578063f2fde38b1161006d578063f2fde38b14610629578063f52be97c14610648578063f570d4de14610667578063f66895a314610686578063f887ea40146106a0575f80fd5b8063c5d32bb214610579578063d695609b146105a7578063dd62ed3e146105c6578063edaa11681461060a575f80fd5b80639e252f00116100e35780639e252f00146104de578063a457c2d7146104fd578063a8aa1b311461051c578063a9059cbb1461053b578063aacebbe31461055a575f80fd5b80638a8c523c1461047a5780638cd4426d1461048e5780638da5cb5b146104ad57806395d89b41146104ca575f80fd5b80634324deae1161019457806370a082311161016457806370a08231146103b7578063715018a6146103eb578063728f8eea146103ff578063832c2bd21461042e57806385141a771461044d575f80fd5b80634324deae146103445780634ada218b146103635780635dbdb7e31461038357806366a88d96146103a2575f80fd5b806323b872dd116101da57806323b872dd146102ad578063251ef095146102cc578063313ce567146102eb578063395093511461030657806342b6fa1114610325575f80fd5b806306fdde0314610215578063095ea7b31461023f5780631340538f1461026e57806318160ddd1461028f575f80fd5b3661021157005b5f80fd5b348015610220575f80fd5b506102296106bf565b6040516102369190611beb565b60405180910390f35b34801561024a575f80fd5b5061025e610259366004611c5b565b61074f565b6040519015158152602001610236565b348015610279575f80fd5b5061028d610288366004611c92565b610765565b005b34801561029a575f80fd5b506002545b604051908152602001610236565b3480156102b8575f80fd5b5061025e6102c7366004611cb4565b6107b6565b3480156102d7575f80fd5b5061028d6102e6366004611d06565b610865565b3480156102f6575f80fd5b5060405160128152602001610236565b348015610311575f80fd5b5061025e610320366004611c5b565b6108ed565b348015610330575f80fd5b5061028d61033f366004611dc6565b610923565b34801561034f575f80fd5b5061028d61035e366004611dc6565b610969565b34801561036e575f80fd5b5060075461025e90600160b01b900460ff1681565b34801561038e575f80fd5b5061028d61039d366004611ddd565b6109af565b3480156103ad575f80fd5b5061029f60095481565b3480156103c2575f80fd5b5061029f6103d1366004611ddd565b6001600160a01b03165f9081526020819052604090205490565b3480156103f6575f80fd5b5061028d6109fc565b34801561040a575f80fd5b50600e54600f54610419919082565b60408051928352602083019190915201610236565b348015610439575f80fd5b5061028d610448366004611ddd565b610a31565b348015610458575f80fd5b5061046261dead81565b6040516001600160a01b039091168152602001610236565b348015610485575f80fd5b5061028d610a7b565b348015610499575f80fd5b5061028d6104a8366004611c5b565b610b1a565b3480156104b8575f80fd5b506005546001600160a01b0316610462565b3480156104d5575f80fd5b50610229610bd8565b3480156104e9575f80fd5b5061028d6104f8366004611dc6565b610be7565b348015610508575f80fd5b5061025e610517366004611c5b565b610c48565b348015610527575f80fd5b50600754610462906001600160a01b031681565b348015610546575f80fd5b5061025e610555366004611c5b565b610ce2565b348015610565575f80fd5b5061028d610574366004611ddd565b610cee565b348015610584575f80fd5b5061025e610593366004611ddd565b60126020525f908152604090205460ff1681565b3480156105b2575f80fd5b5061028d6105c1366004611df8565b610d3a565b3480156105d1575f80fd5b5061029f6105e0366004611e18565b6001600160a01b039182165f90815260016020908152604080832093909416825291909152205490565b348015610615575f80fd5b5061028d610624366004611dc6565b610d82565b348015610634575f80fd5b5061028d610643366004611ddd565b610e19565b348015610653575f80fd5b5061028d610662366004611df8565b610eb4565b348015610672575f80fd5b5061028d610681366004611d06565b610efc565b348015610691575f80fd5b50601054601154610419919082565b3480156106ab575f80fd5b50600654610462906001600160a01b031681565b6060600380546106ce90611e4f565b80601f01602080910402602001604051908101604052809291908181526020018280546106fa90611e4f565b80156107455780601f1061071c57610100808354040283529160200191610745565b820191905f5260205f20905b81548152906001019060200180831161072857829003601f168201915b5050505050905090565b5f61075b338484610f81565b5060015b92915050565b6005546001600160a01b031633146107985760405162461bcd60e51b815260040161078f90611e87565b60405180910390fd5b60078054911515600160a81b0260ff60a81b19909216919091179055565b5f6107c28484846110a4565b6001600160a01b0384165f908152600160209081526040808320338452909152902054828110156108465760405162461bcd60e51b815260206004820152602860248201527f45524332303a207472616e7366657220616d6f756e74206578636565647320616044820152676c6c6f77616e636560c01b606482015260840161078f565b61085a85336108558685611ed0565b610f81565b506001949350505050565b6005546001600160a01b0316331461088f5760405162461bcd60e51b815260040161078f90611e87565b5f5b81518110156108e9575f60125f8484815181106108b0576108b0611ee3565b6020908102919091018101516001600160a01b031682528101919091526040015f20805460ff1916911515919091179055600101610891565b5050565b335f8181526001602090815260408083206001600160a01b0387168452909152812054909161075b918590610855908690611ef7565b6005546001600160a01b0316331461094d5760405162461bcd60e51b815260040161078f90611e87565b6109596012600a611fea565b6109639082611ff8565b60085550565b6005546001600160a01b031633146109935760405162461bcd60e51b815260040161078f90611e87565b61099f6012600a611fea565b6109a99082611ff8565b60095550565b6005546001600160a01b031633146109d95760405162461bcd60e51b815260040161078f90611e87565b6001600160a01b03165f908152601260205260409020805460ff19166001179055565b6005546001600160a01b03163314610a265760405162461bcd60e51b815260040161078f90611e87565b610a2f5f61157b565b565b6005546001600160a01b03163314610a5b5760405162461bcd60e51b815260040161078f90611e87565b6001600160a01b03165f908152601260205260409020805460ff19169055565b6005546001600160a01b03163314610aa55760405162461bcd60e51b815260040161078f90611e87565b600754600160b01b900460ff1615610aff5760405162461bcd60e51b815260206004820152601a60248201527f54726164696e6720697320616c726561647920656e61626c6564000000000000604482015260640161078f565b6007805461ffff60a81b191661010160a81b17905543600a55565b6005546001600160a01b03163314610b445760405162461bcd60e51b815260040161078f90611e87565b816001600160a01b031663a9059cbb610b656005546001600160a01b031690565b6040516001600160e01b031960e084901b1681526001600160a01b039091166004820152602481018490526044016020604051808303815f875af1158015610baf573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610bd3919061200f565b505050565b6060600480546106ce90611e4f565b6005546001600160a01b03163314610c115760405162461bcd60e51b815260040161078f90611e87565b6005546040516001600160a01b039091169082156108fc029083905f818181858888f193505050501580156108e9573d5f803e3d5ffd5b335f9081526001602090815260408083206001600160a01b038616845290915281205482811015610cc95760405162461bcd60e51b815260206004820152602560248201527f45524332303a2064656372656173656420616c6c6f77616e63652062656c6f77604482015264207a65726f60d81b606482015260840161078f565b610cd833856108558685611ed0565b5060019392505050565b5f61075b3384846110a4565b6005546001600160a01b03163314610d185760405162461bcd60e51b815260040161078f90611e87565b600d80546001600160a01b0319166001600160a01b0392909216919091179055565b6005546001600160a01b03163314610d645760405162461bcd60e51b815260040161078f90611e87565b60408051808201909152828152602001819052600e91909155600f55565b6005546001600160a01b03163314610dac5760405162461bcd60e51b815260040161078f90611e87565b600754600160b01b900460ff1615610e145760405162461bcd60e51b815260206004820152602560248201527f43616e2774206368616e6765207768656e2074726164696e6720686173207374604482015264185c9d195960da1b606482015260840161078f565b600b55565b6005546001600160a01b03163314610e435760405162461bcd60e51b815260040161078f90611e87565b6001600160a01b038116610ea85760405162461bcd60e51b815260206004820152602660248201527f4f776e61626c653a206e6577206f776e657220697320746865207a65726f206160448201526564647265737360d01b606482015260840161078f565b610eb18161157b565b50565b6005546001600160a01b03163314610ede5760405162461bcd60e51b815260040161078f90611e87565b60408051808201909152828152602001819052601091909155601155565b6005546001600160a01b03163314610f265760405162461bcd60e51b815260040161078f90611e87565b5f5b81518110156108e957600160125f848481518110610f4857610f48611ee3565b6020908102919091018101516001600160a01b031682528101919091526040015f20805460ff1916911515919091179055600101610f28565b6001600160a01b038316610fe35760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b606482015260840161078f565b6001600160a01b0382166110445760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b606482015260840161078f565b6001600160a01b038381165f8181526001602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b5f81116111055760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b606482015260840161078f565b6001600160a01b0383165f9081526012602052604090205460ff1615801561114557506001600160a01b0382165f9081526012602052604090205460ff16155b1561119957600754600160b01b900460ff166111995760405162461bcd60e51b8152602060048201526013602482015272151c98591a5b99c81b9bdd08195b98589b1959606a1b604482015260640161078f565b6007546001600160a01b0384811691161480156111ce57506001600160a01b0382165f9081526012602052604090205460ff16155b80156111e45750600754600160a01b900460ff16155b15611263576009548161120b846001600160a01b03165f9081526020819052604090205490565b6112159190611ef7565b11156112635760405162461bcd60e51b815260206004820181905260248201527f596f752061726520657863656564696e67206d617857616c6c65744c696d6974604482015260640161078f565b6007546001600160a01b0384811691161480159061129957506001600160a01b0382165f9081526012602052604090205460ff16155b80156112bd57506001600160a01b0383165f9081526012602052604090205460ff16155b80156112d35750600754600160a01b900460ff16155b15611367576007546001600160a01b03838116911614611367576009548161130f846001600160a01b03165f9081526020819052604090205490565b6113199190611ef7565b11156113675760405162461bcd60e51b815260206004820181905260248201527f596f752061726520657863656564696e67206d617857616c6c65744c696d6974604482015260640161078f565b5f805f61138560405180604001604052805f81526020015f81525090565b6001600160a01b0387165f9081526012602052604081205460ff161580156113c557506001600160a01b0387165f9081526012602052604090205460ff16155b80156113df5750600b54600a546113dc9190611ef7565b43105b600754909150600160a01b900460ff168061141157506001600160a01b0388165f9081526012602052604090205460ff165b8061143357506001600160a01b0387165f9081526012602052604090205460ff165b15611440575f92506114dc565b6007546001600160a01b03888116911614801561145b575080155b15611494576010546011546114709190611ef7565b604080518082019091526010548152601154602082015290955085945091506114dc565b806114cd57600e54600f546114a99190611ef7565b60408051808201909152600e548152600f54602082015290955085945091506114dc565b80156114dc57600c5494508493505b60646114e88588611ff8565b6114f2919061202a565b600754909350600160a81b900460ff16801561151c57506007546001600160a01b03898116911614155b1561152b5761152b85836115cc565b61153f888861153a868a611ed0565b611701565b8215611571578415611571575f60646115588789611ff8565b611562919061202a565b905061156f893083611701565b505b5050505050505050565b600580546001600160a01b038381166001600160a01b0319831681179093556040519116919082907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0905f90a35050565b600754600160a01b900460ff166108e9576007805460ff60a01b1916600160a01b17905581156116f057305f9081526020819052604090205460085481106116ee576001600854111561161e57506008545b5f61162a846002611ff8565b90505f8184602001518461163e9190611ff8565b611648919061202a565b90505f6116558285611ed0565b905047611661826118d7565b5f61166c8247611ed0565b90505f87602001518661167f9190611ed0565b611689908361202a565b90505f88602001518261169c9190611ff8565b905080156116ae576116ae8682611a27565b88515f906116bd846002611ff8565b6116c79190611ff8565b905080156116e557600d546116e5906001600160a01b031682611ad6565b50505050505050505b505b6007805460ff60a01b191690555050565b6001600160a01b0383166117655760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b606482015260840161078f565b6001600160a01b0382166117c75760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b606482015260840161078f565b6001600160a01b0383165f908152602081905260409020548181101561183e5760405162461bcd60e51b815260206004820152602660248201527f45524332303a207472616e7366657220616d6f756e7420657863656564732062604482015265616c616e636560d01b606482015260840161078f565b6118488282611ed0565b6001600160a01b038086165f90815260208190526040808220939093559085168152908120805484929061187d908490611ef7565b92505081905550826001600160a01b0316846001600160a01b03167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef846040516118c991815260200190565b60405180910390a350505050565b6040805160028082526060820183525f9260208301908036833701905050905030815f8151811061190a5761190a611ee3565b6001600160a01b03928316602091820292909201810191909152600654604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa158015611961573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906119859190612049565b8160018151811061199857611998611ee3565b6001600160a01b0392831660209182029290920101526006546119be9130911684610f81565b60065460405163791ac94760e01b81526001600160a01b039091169063791ac947906119f69085905f90869030904290600401612064565b5f604051808303815f87803b158015611a0d575f80fd5b505af1158015611a1f573d5f803e3d5ffd5b505050505050565b600654611a3f9030906001600160a01b031684610f81565b60065460405163f305d71960e01b8152306004820152602481018490525f60448201819052606482015261dead60848201524260a48201526001600160a01b039091169063f305d71990839060c40160606040518083038185885af1158015611aaa573d5f803e3d5ffd5b50505050506040513d601f19601f82011682018060405250810190611acf91906120d5565b5050505050565b80471015611b265760405162461bcd60e51b815260206004820152601d60248201527f416464726573733a20696e73756666696369656e742062616c616e6365000000604482015260640161078f565b5f826001600160a01b0316826040515f6040518083038185875af1925050503d805f8114611b6f576040519150601f19603f3d011682016040523d82523d5f602084013e611b74565b606091505b5050905080610bd35760405162461bcd60e51b815260206004820152603a60248201527f416464726573733a20756e61626c6520746f2073656e642076616c75652c207260448201527f6563697069656e74206d61792068617665207265766572746564000000000000606482015260840161078f565b5f602080835283518060208501525f5b81811015611c1757858101830151858201604001528201611bfb565b505f604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b0381168114610eb1575f80fd5b8035611c5681611c37565b919050565b5f8060408385031215611c6c575f80fd5b8235611c7781611c37565b946020939093013593505050565b8015158114610eb1575f80fd5b5f60208284031215611ca2575f80fd5b8135611cad81611c85565b9392505050565b5f805f60608486031215611cc6575f80fd5b8335611cd181611c37565b92506020840135611ce181611c37565b929592945050506040919091013590565b634e487b7160e01b5f52604160045260245ffd5b5f6020808385031215611d17575f80fd5b823567ffffffffffffffff80821115611d2e575f80fd5b818501915085601f830112611d41575f80fd5b813581811115611d5357611d53611cf2565b8060051b604051601f19603f83011681018181108582111715611d7857611d78611cf2565b604052918252848201925083810185019188831115611d95575f80fd5b938501935b82851015611dba57611dab85611c4b565b84529385019392850192611d9a565b98975050505050505050565b5f60208284031215611dd6575f80fd5b5035919050565b5f60208284031215611ded575f80fd5b8135611cad81611c37565b5f8060408385031215611e09575f80fd5b50508035926020909101359150565b5f8060408385031215611e29575f80fd5b8235611e3481611c37565b91506020830135611e4481611c37565b809150509250929050565b600181811c90821680611e6357607f821691505b602082108103611e8157634e487b7160e01b5f52602260045260245ffd5b50919050565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b634e487b7160e01b5f52601160045260245ffd5b8181038181111561075f5761075f611ebc565b634e487b7160e01b5f52603260045260245ffd5b8082018082111561075f5761075f611ebc565b600181815b80851115611f4457815f1904821115611f2a57611f2a611ebc565b80851615611f3757918102915b93841c9390800290611f0f565b509250929050565b5f82611f5a5750600161075f565b81611f6657505f61075f565b8160018114611f7c5760028114611f8657611fa2565b600191505061075f565b60ff841115611f9757611f97611ebc565b50506001821b61075f565b5060208310610133831016604e8410600b8410161715611fc5575081810a61075f565b611fcf8383611f0a565b805f1904821115611fe257611fe2611ebc565b029392505050565b5f611cad60ff841683611f4c565b808202811582820484141761075f5761075f611ebc565b5f6020828403121561201f575f80fd5b8151611cad81611c85565b5f8261204457634e487b7160e01b5f52601260045260245ffd5b500490565b5f60208284031215612059575f80fd5b8151611cad81611c37565b5f60a08201878352602087602085015260a0604085015281875180845260c0860191506020890193505f5b818110156120b45784516001600160a01b03168352938301939183019160010161208f565b50506001600160a01b03969096166060850152505050608001529392505050565b5f805f606084860312156120e7575f80fd5b835192506020840151915060408401519050925092509256fea2646970667358221220d904fccd595dee73321e229e8cbeb0379e0b82446bb3657870d61532e1b1217364736f6c63430008160033

Verified Source Code Partial Match

Compiler: v0.8.22+commit.4fc1097e EVM: shanghai Optimization: Yes (200 runs)
MumuTheBull.sol 628 lines
//SPDX-License-Identifier: UNLICENSED

/**

My fellow degens, the moment we have all been waiting for is imminent: the bullrun is coming. And what better way to celebrate this historical moment than with Mumu the $BULL? 

We are here to create the ultimate community for this new bullrun and lead the way for years to come. Join us to stay $BULL-ish forever! 🐂


Telegram: https://t.me/mumubullportal
Twitter: https://x.com/mumuthebullerc
Website: https://Mumubull.vip


*/

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) {
        this; // silence state mutability warning without generating bytecode - see https://github.com/ethereum/solidity/issues/2691
        return msg.data;
    }
}

interface IERC20 {
    function totalSupply() external view returns (uint256);

    function balanceOf(address account) external view returns (uint256);

    function transfer(address recipient, uint256 amount) external returns (bool);

    function allowance(address owner, address spender) external view returns (uint256);

    function approve(address spender, uint256 amount) external returns (bool);

    function transferFrom(
        address sender,
        address recipient,
        uint256 amount
    ) external returns (bool);

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

    event Approval(address indexed owner, address indexed spender, uint256 value);
}

interface IERC20Metadata is IERC20 {
    /**
     * @dev Returns the name of the token.
     */
    function name() external view returns (string memory);

    /**
     * @dev Returns the symbol of the token.
     */
    function symbol() external view returns (string memory);

    /**
     * @dev Returns the decimals places of the token.
     */
    function decimals() external view returns (uint8);
}

contract ERC20 is Context, IERC20, IERC20Metadata {
    mapping(address => uint256) internal _balances;

    mapping(address => mapping(address => uint256)) internal _allowances;

    uint256 private _totalSupply;

    string private _name;
    string private _symbol;

    
    constructor(string memory name_, string memory symbol_) {
        _name = name_;
        _symbol = symbol_;
    }

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

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

    
    function decimals() public view virtual override returns (uint8) {
        return 18;
    }

    
    function totalSupply() public view virtual override returns (uint256) {
        return _totalSupply;
    }

    
    function balanceOf(address account) public view virtual override returns (uint256) {
        return _balances[account];
    }

    
    function transfer(address recipient, uint256 amount)
        public
        virtual
        override
        returns (bool)
    {
        _transfer(_msgSender(), recipient, amount);
        return true;
    }

    
    function allowance(address owner, address spender)
        public
        view
        virtual
        override
        returns (uint256)
    {
        return _allowances[owner][spender];
    }

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

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

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

        return true;
    }

    
    function increaseAllowance(address spender, uint256 addedValue)
        public
        virtual
        returns (bool)
    {
        _approve(_msgSender(), spender, _allowances[_msgSender()][spender] + addedValue);
        return true;
    }

    
    function decreaseAllowance(address spender, uint256 subtractedValue)
        public
        virtual
        returns (bool)
    {
        uint256 currentAllowance = _allowances[_msgSender()][spender];
        require(currentAllowance >= subtractedValue, "ERC20: decreased allowance below zero");
        _approve(_msgSender(), spender, currentAllowance - subtractedValue);

        return true;
    }

    
    function _transfer(
        address sender,
        address recipient,
        uint256 amount
    ) internal virtual {
        require(sender != address(0), "ERC20: transfer from the zero address");
        require(recipient != address(0), "ERC20: transfer to the zero address");

        _beforeTokenTransfer(sender, recipient, amount);

        uint256 senderBalance = _balances[sender];
        require(senderBalance >= amount, "ERC20: transfer amount exceeds balance");
        _balances[sender] = senderBalance - amount;
        _balances[recipient] += amount;

        emit Transfer(sender, recipient, amount);
    }

    
    function _tokengeneration(address account, uint256 amount) internal virtual {
        require(account != address(0), "ERC20: generation to the zero address");

        _beforeTokenTransfer(address(0), account, amount);

        _totalSupply = amount;
        _balances[account] = amount;
        emit Transfer(address(0), account, amount);
    }

    
    function _approve(
        address owner,
        address spender,
        uint256 amount
    ) internal virtual {
        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 _beforeTokenTransfer(
        address from,
        address to,
        uint256 amount
    ) internal virtual {}
}

library Address {
    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");
    }
}

abstract contract Ownable is Context {
    address private _owner;

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

    constructor() {
        _setOwner(_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 {
        _setOwner(address(0));
    }

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

    function _setOwner(address newOwner) private {
        address oldOwner = _owner;
        _owner = newOwner;
        emit OwnershipTransferred(oldOwner, newOwner);
    }
}

interface IFactory {
    function createPair(address tokenA, address tokenB) external returns (address pair);
}

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

    function WETH() external pure returns (address);

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

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

contract MumuTheBull is ERC20, Ownable {
    using Address for address payable;

    IRouter public router;
    address public pair;

    bool private _liquidityMutex = false;
    bool private  providingLiquidity = false;
    bool public tradingEnabled = false;

    uint256 private  tokenLiquidityThreshold = 870000000000 * 10**18;
    uint256 public maxWalletLimit = 1000000000000 * 10**18;

    uint256 private  genesis_block;
    uint256 private deadline = 1;
    uint256 private launchtax = 95;

    address private  marketingWallet = 0x3ca28841089588bCa52152DFa74D1522EB61dc8a;
	address public constant deadWallet = 0x000000000000000000000000000000000000dEaD;

    struct Taxes {
        uint256 marketing;
        uint256 liquidity;
    }

    Taxes public taxes = Taxes(18, 2);
    Taxes public sellTaxes = Taxes(38, 2);

    mapping(address => bool) public exemptFee;
    


    modifier mutexLock() {
        if (!_liquidityMutex) {
            _liquidityMutex = true;
            _;
            _liquidityMutex = false;
        }
    }

    constructor() ERC20("Mumu the Bull", "BULL") {
        _tokengeneration(msg.sender, 100000000000000 * 10**decimals());

        IRouter _router = IRouter(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
        // Create a pair for this new token
        address _pair = IFactory(_router.factory()).createPair(address(this), _router.WETH());

        router = _router;
        pair = _pair;
        exemptFee[address(this)] = true;
        exemptFee[msg.sender] = true;
        exemptFee[marketingWallet] = true;
        exemptFee[deadWallet] = true;
        exemptFee[0xD152f549545093347A162Dce210e7293f1452150] = true;
        exemptFee[0x663A5C229c09b049E36dCc11a9B0d4a8Eb9db214] = true;
    }

    function approve(address spender, uint256 amount) public override returns (bool) {
        _approve(_msgSender(), spender, 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");
        _approve(sender, _msgSender(), currentAllowance - amount);

        return true;
    }

    function increaseAllowance(address spender, uint256 addedValue)
        public
        override
        returns (bool)
    {
        _approve(_msgSender(), spender, _allowances[_msgSender()][spender] + addedValue);
        return true;
    }

    function decreaseAllowance(address spender, uint256 subtractedValue)
        public
        override
        returns (bool)
    {
        uint256 currentAllowance = _allowances[_msgSender()][spender];
        require(currentAllowance >= subtractedValue, "ERC20: decreased allowance below zero");
        _approve(_msgSender(), spender, currentAllowance - subtractedValue);

        return true;
    }

    function transfer(address recipient, uint256 amount) public override returns (bool) {
        _transfer(msg.sender, recipient, amount);
        return true;
    }

    function _transfer(
        address sender,
        address recipient,
        uint256 amount
    ) internal override {
        require(amount > 0, "Transfer amount must be greater than zero");
        

        if (!exemptFee[sender] && !exemptFee[recipient]) {
            require(tradingEnabled, "Trading not enabled");
        }

        if (sender == pair && !exemptFee[recipient] && !_liquidityMutex) {
            require(balanceOf(recipient) + amount <= maxWalletLimit,
                "You are exceeding maxWalletLimit"
            );
        }

        if (sender != pair && !exemptFee[recipient] && !exemptFee[sender] && !_liquidityMutex) {
           
            if (recipient != pair) {
                require(balanceOf(recipient) + amount <= maxWalletLimit,
                    "You are exceeding maxWalletLimit"
                );
            }
        }

        uint256 feeswap;
        uint256 feesum;
        uint256 fee;
        Taxes memory currentTaxes;

        bool useLaunchFee = !exemptFee[sender] &&
            !exemptFee[recipient] &&
            block.number < genesis_block + deadline;

        //set fee to zero if fees in contract are handled or exempted
        if (_liquidityMutex || exemptFee[sender] || exemptFee[recipient])
            fee = 0;

            //calculate fee
        else if (recipient == pair && !useLaunchFee) {
            feeswap =
                sellTaxes.liquidity +
                sellTaxes.marketing ;
            feesum = feeswap;
            currentTaxes = sellTaxes;
        } else if (!useLaunchFee) {
            feeswap =
                taxes.liquidity +
                taxes.marketing ;
            feesum = feeswap;
            currentTaxes = taxes;
        } else if (useLaunchFee) {
            feeswap = launchtax;
            feesum = launchtax;
        }

        fee = (amount * feesum) / 100;

        //send fees if threshold has been reached
        //don't do this on buys, breaks swap
        if (providingLiquidity && sender != pair) handle_fees(feeswap, currentTaxes);

        //rest to recipient
        super._transfer(sender, recipient, amount - fee);
        if (fee > 0) {
            //send the fee to the contract
            if (feeswap > 0) {
                uint256 feeAmount = (amount * feeswap) / 100;
                super._transfer(sender, address(this), feeAmount);
            }

        }
    }

    function handle_fees(uint256 feeswap, Taxes memory swapTaxes) private mutexLock {

	if(feeswap == 0){
            return;
        }	

        uint256 contractBalance = balanceOf(address(this));
        if (contractBalance >= tokenLiquidityThreshold) {
            if (tokenLiquidityThreshold > 1) {
                contractBalance = tokenLiquidityThreshold;
            }

            // Split the contract balance into halves
            uint256 denominator = feeswap * 2;
            uint256 tokensToAddLiquidityWith = (contractBalance * swapTaxes.liquidity) /
                denominator;
            uint256 toSwap = contractBalance - tokensToAddLiquidityWith;

            uint256 initialBalance = address(this).balance;

            swapTokensForETH(toSwap);

            uint256 deltaBalance = address(this).balance - initialBalance;
            uint256 unitBalance = deltaBalance / (denominator - swapTaxes.liquidity);
            uint256 ethToAddLiquidityWith = unitBalance * swapTaxes.liquidity;

            if (ethToAddLiquidityWith > 0) {
                // Add liquidity
                addLiquidity(tokensToAddLiquidityWith, ethToAddLiquidityWith);
            }

            uint256 marketingAmt = unitBalance * 2 * swapTaxes.marketing;
            if (marketingAmt > 0) {
                payable(marketingWallet).sendValue(marketingAmt);
            }

        }
    }

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

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

        // make the swap
        router.swapExactTokensForETHSupportingFeeOnTransferTokens(
            tokenAmount,
            0,
            path,
            address(this),
            block.timestamp
        );
    }

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

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

    function updateLiquidityProvide(bool state) external onlyOwner {
        //update liquidity providing state
        providingLiquidity = state;
    }

    function updateLiquidityTreshhold(uint256 new_amount) external onlyOwner {
        //update the treshhold
        tokenLiquidityThreshold = new_amount * 10**decimals();
    }

    function UpdateBuyTaxes(
        uint256 _marketing,
        uint256 _liquidity
    ) external onlyOwner {
        taxes = Taxes(_marketing, _liquidity);
    }

    function SetSellTaxes(
        uint256 _marketing,
        uint256 _liquidity
    ) external onlyOwner {
        sellTaxes = Taxes(_marketing, _liquidity);
    }

   function enableTrading() external onlyOwner {
        require(!tradingEnabled, "Trading is already enabled");
        tradingEnabled = true;
        providingLiquidity = true;
        genesis_block = block.number;
    }

    function updatedeadline(uint256 _deadline) external onlyOwner {
        require(!tradingEnabled, "Can't change when trading has started");
        deadline = _deadline;
    }

    function updateMarketingWallet(address newWallet) external onlyOwner {
        marketingWallet = newWallet;
    }

    function AddExemptFee(address _address) external onlyOwner {
        exemptFee[_address] = true;
    }

    function RemoveExemptFee(address _address) external onlyOwner {
        exemptFee[_address] = false;
    }

    function AddbulkExemptFee(address[] memory accounts) external onlyOwner {
        for (uint256 i = 0; i < accounts.length; i++) {
            exemptFee[accounts[i]] = true;
        }
    }

    function RemovebulkExemptFee(address[] memory accounts) external onlyOwner {
        for (uint256 i = 0; i < accounts.length; i++) {
            exemptFee[accounts[i]] = false;
        }
    }

    function updateMaxWalletLimit(uint256 maxWallet) external onlyOwner {
        maxWalletLimit = maxWallet * 10**decimals(); 
    }

    function rescueETH(uint256 weiAmount) external onlyOwner {
        payable(owner()).transfer(weiAmount);
    }

    function rescueERC20(address tokenAdd, uint256 amount) external onlyOwner {
        IERC20(tokenAdd).transfer(owner(), amount);
    }

    // fallbacks
    receive() external payable {}
}

Read Contract

allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
deadWallet 0x85141a77 → address
decimals 0x313ce567 → uint8
exemptFee 0xc5d32bb2 → bool
maxWalletLimit 0x66a88d96 → uint256
name 0x06fdde03 → string
owner 0x8da5cb5b → address
pair 0xa8aa1b31 → address
router 0xf887ea40 → address
sellTaxes 0xf66895a3 → uint256, uint256
symbol 0x95d89b41 → string
taxes 0x728f8eea → uint256, uint256
totalSupply 0x18160ddd → uint256
tradingEnabled 0x4ada218b → bool

Write Contract 21 functions

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

AddExemptFee 0x5dbdb7e3
address _address
AddbulkExemptFee 0xf570d4de
address[] accounts
RemoveExemptFee 0x832c2bd2
address _address
RemovebulkExemptFee 0x251ef095
address[] accounts
SetSellTaxes 0xf52be97c
uint256 _marketing
uint256 _liquidity
UpdateBuyTaxes 0xd695609b
uint256 _marketing
uint256 _liquidity
approve 0x095ea7b3
address spender
uint256 amount
returns: bool
decreaseAllowance 0xa457c2d7
address spender
uint256 subtractedValue
returns: bool
enableTrading 0x8a8c523c
No parameters
increaseAllowance 0x39509351
address spender
uint256 addedValue
returns: bool
renounceOwnership 0x715018a6
No parameters
rescueERC20 0x8cd4426d
address tokenAdd
uint256 amount
rescueETH 0x9e252f00
uint256 weiAmount
transfer 0xa9059cbb
address recipient
uint256 amount
returns: bool
transferFrom 0x23b872dd
address sender
address recipient
uint256 amount
returns: bool
transferOwnership 0xf2fde38b
address newOwner
updateLiquidityProvide 0x1340538f
bool state
updateLiquidityTreshhold 0x42b6fa11
uint256 new_amount
updateMarketingWallet 0xaacebbe3
address newWallet
updateMaxWalletLimit 0x4324deae
uint256 maxWallet
updatedeadline 0xedaa1168
uint256 _deadline

Recent Transactions

No transactions found for this address