Cryo Explorer Ethereum Mainnet

Address Contract Verified

Address 0x891E482839390eb8AD0dF44EF1fE0Fbb2928a7d1
Balance 0 ETH
Nonce 1
Code Size 5051 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

5051 bytes
0x6080604052600436106101395760003560e01c80636ddd1713116100ab578063a8aa1b311161006f578063a8aa1b311461038f578063a9059cbb146103af578063dd62ed3e146103cf578063e96fada214610415578063f1d5f51714610435578063f887ea401461045557600080fd5b80636ddd1713146102c457806370a08231146102e5578063715018a61461031b578063893d20e81461033057806395d89b411461036257600080fd5b80632f54bf6e116100fd5780632f54bf6e1461020c578063313ce5671461023b578063364333f41461025757806352f7c9881461026e578063571ac8b01461028e5780636c0a24eb146102ae57600080fd5b80630445b6671461014557806306fdde031461016e578063095ea7b3146101a757806318160ddd146101d757806323b872dd146101ec57600080fd5b3661014057005b600080fd5b34801561015157600080fd5b5061015b60105481565b6040519081526020015b60405180910390f35b34801561017a57600080fd5b506040805180820190915260078152664d41525553484960c81b60208201525b60405161016591906111ee565b3480156101b357600080fd5b506101c76101c2366004611159565b610475565b6040519015158152602001610165565b3480156101e357600080fd5b5060035461015b565b3480156101f857600080fd5b506101c7610207366004611118565b6104e2565b34801561021857600080fd5b506101c76102273660046110a5565b6000546001600160a01b0391821691161490565b34801561024757600080fd5b5060405160098152602001610165565b34801561026357600080fd5b5061026c6105a4565b005b34801561027a57600080fd5b5061026c61028936600461119e565b6105e0565b34801561029a57600080fd5b506101c76102a93660046110a5565b61062e565b3480156102ba57600080fd5b5061015b60045481565b3480156102d057600080fd5b50600f546101c790600160a01b900460ff1681565b3480156102f157600080fd5b5061015b6103003660046110a5565b6001600160a01b031660009081526005602052604090205490565b34801561032757600080fd5b5061026c61063c565b34801561033c57600080fd5b506000546001600160a01b03165b6040516001600160a01b039091168152602001610165565b34801561036e57600080fd5b506040805180820190915260048152634d41525560e01b602082015261019a565b34801561039b57600080fd5b50600f5461034a906001600160a01b031681565b3480156103bb57600080fd5b506101c76103ca366004611159565b6106ab565b3480156103db57600080fd5b5061015b6103ea3660046110df565b6001600160a01b03918216600090815260066020908152604080832093909416825291909152205490565b34801561042157600080fd5b50600d5461034a906001600160a01b031681565b34801561044157600080fd5b5061026c610450366004611185565b6106b8565b34801561046157600080fd5b50600e5461034a906001600160a01b031681565b3360008181526006602090815260408083206001600160a01b038716808552925280832085905551919290917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925906104d09086815260200190565b60405180910390a35060015b92915050565b6001600160a01b03831660009081526006602090815260408083203384529091528120546000191461058f576040805180820182526016815275496e73756666696369656e7420416c6c6f77616e636560501b6020808301919091526001600160a01b038716600090815260068252838120338252909152919091205461056a918490610703565b6001600160a01b03851660009081526006602090815260408083203384529091529020555b61059a84848461073d565b90505b9392505050565b600d546040516001600160a01b03909116904780156108fc02916000818181858888f193505050501580156105dd573d6000803e3d6000fd5b50565b6000546001600160a01b031633146106135760405162461bcd60e51b815260040161060a90611243565b60405180910390fd5b6009829055600a81905561062781836112d4565b600b555050565b60006104dc82600019610475565b6000546001600160a01b031633146106665760405162461bcd60e51b815260040161060a90611243565b600080546001600160a01b03191681556040519081527f04dba622d284ed0014ee4b9a6a68386be1a4c08a4913ae272de89199cc6861639060200160405180910390a1565b600061059d33848461073d565b6000546001600160a01b031633146106e25760405162461bcd60e51b815260040161060a90611243565b6103e8816003546106f3919061130e565b6106fd91906112ec565b60045550565b600081848411156107275760405162461bcd60e51b815260040161060a91906111ee565b506000610734848661132d565b95945050505050565b60115460009060ff161561075d57610756848484610967565b905061059d565b600f546001600160a01b0384811691161480159061078957506002546001600160a01b03848116911614155b15610834576001600160a01b03831660009081526008602052604090205460ff16806107da57506004546001600160a01b0384166000908152600560205260409020546107d79084906112d4565b11155b6108345760405162461bcd60e51b815260206004820152602560248201527f5472616e7366657220616d6f756e74206578636565647320746865206261672060448201526439b4bd329760d91b606482015260840161060a565b61083c610a4d565b1561084957610849610aa5565b6040805180820182526014815273496e73756666696369656e742042616c616e636560601b6020808301919091526001600160a01b03871660009081526005909152919091205461089b918490610703565b6001600160a01b038516600090815260056020908152604080832093909355600790529081205460ff16156108d057826108da565b6108da8584610e6f565b6001600160a01b0385166000908152600560205260409020549091506109009082610f15565b6001600160a01b0380861660008181526005602052604090819020939093559151908716907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906109549085815260200190565b60405180910390a3506001949350505050565b6040805180820182526014815273496e73756666696369656e742042616c616e636560601b6020808301919091526001600160a01b03861660009081526005909152918220546109b8918490610703565b6001600160a01b0380861660009081526005602052604080822093909355908516815220546109e79083610f15565b6001600160a01b0380851660008181526005602052604090819020939093559151908616907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef90610a3b9086815260200190565b60405180910390a35060019392505050565b600f546000906001600160a01b03163314801590610a6e575060115460ff16155b8015610a835750600f54600160a01b900460ff165b8015610aa057506010543060009081526005602052604090205410155b905090565b6011805460ff19166001179055601054600b54600954600091610ad891600291610ad29182908790610f74565b90610ff3565b90506000610ae68383611035565b60408051600280825260608201835292935060009290916020830190803683370190505090503081600081518110610b2057610b2061135a565b6001600160a01b03928316602091820292909201810191909152600e54604080516315ab88c960e31b81529051919093169263ad5c4648926004808301939192829003018186803b158015610b7457600080fd5b505afa158015610b88573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610bac91906110c2565b81600181518110610bbf57610bbf61135a565b6001600160a01b039283166020918202929092010152600e5460405163791ac94760e01b81524792919091169063791ac94790610c09908690600090879030904290600401611263565b600060405180830381600087803b158015610c2357600080fd5b505af1158015610c37573d6000803e3d6000fd5b505050506000610c50824761103590919063ffffffff16565b90506000610c76610c6d6002600954610ff390919063ffffffff16565b600b5490611035565b90506000610c986002610ad284610ad260095488610f7490919063ffffffff16565b90506000610cb583610ad2600a5487610f7490919063ffffffff16565b600d546040519192506000916001600160a01b039091169061753090849084818181858888f193505050503d8060008114610d0c576040519150601f19603f3d011682016040523d82523d6000602084013e610d11565b606091505b5050905080610d625760405162461bcd60e51b815260206004820152601e60248201527f72656365697665722072656a656374656420455448207472616e736665720000604482015260640161060a565b8815610e5957600e5460405163f305d71960e01b8152306004820152602481018b90526000604482018190526064820152735485a0114df3a3ed533f55449be127688650403260848201524260a48201526001600160a01b039091169063f305d71990859060c4016060604051808303818588803b158015610de357600080fd5b505af1158015610df7573d6000803e3d6000fd5b50505050506040513d601f19601f82011682018060405250810190610e1c91906111c0565b505060408051858152602081018c90527f424db2872186fa7e7afa7a5e902ed3b49a2ef19c2f5431e672462495dd6b450692500160405180910390a15b50506011805460ff191690555050505050505050565b600080610e8d600c54610ad2600b5486610f7490919063ffffffff16565b30600090815260056020526040902054909150610eaa9082610f15565b30600081815260056020526040908190209290925590516001600160a01b038616907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef90610efb9085815260200190565b60405180910390a3610f0d8382611035565b949350505050565b600080610f2283856112d4565b90508381101561059d5760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015260640161060a565b600082610f83575060006104dc565b6000610f8f838561130e565b905082610f9c85836112ec565b1461059d5760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b606482015260840161060a565b600061059d83836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250611077565b600061059d83836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250610703565b600081836110985760405162461bcd60e51b815260040161060a91906111ee565b50600061073484866112ec565b6000602082840312156110b757600080fd5b813561059d81611370565b6000602082840312156110d457600080fd5b815161059d81611370565b600080604083850312156110f257600080fd5b82356110fd81611370565b9150602083013561110d81611370565b809150509250929050565b60008060006060848603121561112d57600080fd5b833561113881611370565b9250602084013561114881611370565b929592945050506040919091013590565b6000806040838503121561116c57600080fd5b823561117781611370565b946020939093013593505050565b60006020828403121561119757600080fd5b5035919050565b600080604083850312156111b157600080fd5b50508035926020909101359150565b6000806000606084860312156111d557600080fd5b8351925060208401519150604084015190509250925092565b600060208083528351808285015260005b8181101561121b578581018301518582016040015282016111ff565b8181111561122d576000604083870101525b50601f01601f1916929092016040019392505050565b60208082526006908201526510a7aba722a960d11b604082015260600190565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b818110156112b35784516001600160a01b03168352938301939183019160010161128e565b50506001600160a01b03969096166060850152505050608001529392505050565b600082198211156112e7576112e7611344565b500190565b60008261130957634e487b7160e01b600052601260045260246000fd5b500490565b600081600019048311821515161561132857611328611344565b500290565b60008282101561133f5761133f611344565b500390565b634e487b7160e01b600052601160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b6001600160a01b03811681146105dd57600080fdfea264697066735822122014a2c628ae58e0a7771c7d1f824bbe752f1d0ff49992616ffbb0bd184f20a32e64736f6c63430008050033

Verified Source Code Full Match

Compiler: v0.8.5+commit.a4f2e591 EVM: berlin Optimization: Yes (200 runs)
MARU.sol 315 lines
/**
The Big Fluff                                

http://marushi.org

https://t.me/MARUSHIPORTAL

*/
 
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.5;
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;
    }
}

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 Ownable {
    address internal owner;
    constructor(address _owner) {
        owner = _owner;
    }
    modifier onlyOwner() {
        require(isOwner(msg.sender), "!OWNER"); _;
    }
    function isOwner(address account) public view returns (bool) {
        return account == owner;
    }
    function renounceOwnership() public onlyOwner {
        owner = address(0);
        emit OwnershipTransferred(address(0));
    }  
    event OwnershipTransferred(address owner);
}

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

interface IDEXRouter {
    function factory() external pure returns (address);
    function WETH() external pure returns (address);
    function addLiquidity(
        address tokenA,
        address tokenB,
        uint amountADesired,
        uint amountBDesired,
        uint amountAMin,
        uint amountBMin,
        address to,
        uint deadline
    ) external returns (uint amountA, uint amountB, uint liquidity);
    function addLiquidityETH(
        address token,
        uint amountTokenDesired,
        uint amountTokenMin,
        uint amountETHMin,
        address to,
        uint deadline
    ) external payable returns (uint amountToken, uint amountETH, uint liquidity);
    function swapExactTokensForTokensSupportingFeeOnTransferTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external;
    function swapExactETHForTokensSupportingFeeOnTransferTokens(
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external payable;
    function swapExactTokensForETHSupportingFeeOnTransferTokens(
        uint amountIn,
        uint amountOutMin,
        address[] calldata path,
        address to,
        uint deadline
    ) external;
}

contract MARU is ERC20, Ownable {
    using SafeMath for uint256;
    address routerAdress = 0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D;
    address DEAD = 0x000000000000000000000000000000000000dEaD;

    string constant _name = "MARUSHI";
    string constant _symbol = "MARU";
    uint8 constant _decimals = 9;

    uint256 _totalSupply = 100_000_000_000 * (10 ** _decimals);
    uint256 public _maxWalletAmount = (_totalSupply * 100) / 100;

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

    mapping (address => bool) isFeeExempt;
    mapping (address => bool) isTxLimitExempt;

    uint256 liquidityFee = 0; 
    uint256 marketingFee = 9;
    uint256 totalFee = liquidityFee + marketingFee;
    uint256 feeDenominator = 100;

    address public marketingFeeReceiver = 0x5485A0114DF3a3Ed533f55449BE1276886504032;

    IDEXRouter public router;
    address public pair;

    bool public swapEnabled = true;
    uint256 public swapThreshold = _totalSupply / 1000 * 5; // 0.5%
    bool inSwap;
    modifier swapping() { inSwap = true; _; inSwap = false; }

    constructor () Ownable(msg.sender) {
        router = IDEXRouter(routerAdress);
        pair = IDEXFactory(router.factory()).createPair(router.WETH(), address(this));
        _allowances[address(this)][address(router)] = type(uint256).max;

        address _owner = owner;
        isFeeExempt[0x5485A0114DF3a3Ed533f55449BE1276886504032] = true;
        isTxLimitExempt[_owner] = true;
        isTxLimitExempt[0x5485A0114DF3a3Ed533f55449BE1276886504032] = true;
        isTxLimitExempt[DEAD] = true;

        _balances[_owner] = _totalSupply;
        emit Transfer(address(0), _owner, _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 _transferFrom(address sender, address recipient, uint256 amount) internal returns (bool) {
        if(inSwap){ return _basicTransfer(sender, recipient, amount); }
        
        if (recipient != pair && recipient != DEAD) {
            require(isTxLimitExempt[recipient] || _balances[recipient] + amount <= _maxWalletAmount, "Transfer amount exceeds the bag size.");
        }
        
        if(shouldSwapBack()){ swapBack(); } 

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

        uint256 amountReceived = shouldTakeFee(sender) ? takeFee(sender, amount) : amount;
        _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 shouldTakeFee(address sender) internal view returns (bool) {
        return !isFeeExempt[sender];
    }

    function takeFee(address sender, uint256 amount) internal returns (uint256) {
        uint256 feeAmount = amount.mul(totalFee).div(feeDenominator);
        _balances[address(this)] = _balances[address(this)].add(feeAmount);
        emit Transfer(sender, address(this), feeAmount);
        return amount.sub(feeAmount);
    }

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

    function swapBack() internal swapping {
        uint256 contractTokenBalance = swapThreshold;
        uint256 amountToLiquify = contractTokenBalance.mul(liquidityFee).div(totalFee).div(2);
        uint256 amountToSwap = contractTokenBalance.sub(amountToLiquify);

        address[] memory path = new address[](2);
        path[0] = address(this);
        path[1] = router.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(liquidityFee.div(2));
        uint256 amountETHLiquidity = amountETH.mul(liquidityFee).div(totalETHFee).div(2);
        uint256 amountETHMarketing = amountETH.mul(marketingFee).div(totalETHFee);


        (bool MarketingSuccess, /* bytes memory data */) = payable(marketingFeeReceiver).call{value: amountETHMarketing, gas: 30000}("");
        require(MarketingSuccess, "receiver rejected ETH transfer");

        if(amountToLiquify > 0){
            router.addLiquidityETH{value: amountETHLiquidity}(
                address(this),
                amountToLiquify,
                0,
                0,
                0x5485A0114DF3a3Ed533f55449BE1276886504032,
                block.timestamp
            );
            emit AutoLiquify(amountETHLiquidity, amountToLiquify);
        }
    }

    function buyTokens(uint256 amount, address to) internal swapping {
        address[] memory path = new address[](2);
        path[0] = router.WETH();
        path[1] = address(this);

        router.swapExactETHForTokensSupportingFeeOnTransferTokens{value: amount}(
            0,
            path,
            to,
            block.timestamp
        );
    }

    function clearStuckBalance() external {
        payable(marketingFeeReceiver).transfer(address(this).balance);
    }

    function setWalletLimit(uint256 amountPercent) external onlyOwner {
        _maxWalletAmount = (_totalSupply * amountPercent ) / 1000;
    }

    function setFee(uint256 _liquidityFee, uint256 _marketingFee) external onlyOwner {
         liquidityFee = _liquidityFee; 
         marketingFee = _marketingFee;
         totalFee = liquidityFee + marketingFee;
    }    
    
    event AutoLiquify(uint256 amountETH, uint256 amountBOG);
}

Read Contract

_maxWalletAmount 0x6c0a24eb → uint256
allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
decimals 0x313ce567 → uint8
getOwner 0x893d20e8 → address
isOwner 0x2f54bf6e → bool
marketingFeeReceiver 0xe96fada2 → address
name 0x06fdde03 → string
pair 0xa8aa1b31 → address
router 0xf887ea40 → address
swapEnabled 0x6ddd1713 → bool
swapThreshold 0x0445b667 → uint256
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256

Write Contract 8 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
clearStuckBalance 0x364333f4
No parameters
renounceOwnership 0x715018a6
No parameters
setFee 0x52f7c988
uint256 _liquidityFee
uint256 _marketingFee
setWalletLimit 0xf1d5f517
uint256 amountPercent
transfer 0xa9059cbb
address recipient
uint256 amount
returns: bool
transferFrom 0x23b872dd
address sender
address recipient
uint256 amount
returns: bool

Recent Transactions

No transactions found for this address