Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0x82089a9c7c4a07352F7433fBce1D4Ee9a722fF29
Balance 0 ETH
Nonce 1
Code Size 5001 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

5001 bytes
0x6080604052600436106101395760003560e01c80636ddd1713116100ab578063a8aa1b311161006f578063a8aa1b311461035d578063a9059cbb1461037d578063dd62ed3e1461039d578063e96fada2146103e3578063f1d5f51714610403578063f887ea401461042357600080fd5b80636ddd1713146102bf57806370a08231146102e0578063715018a614610316578063893d20e81461032b57806395d89b411461016e57600080fd5b80632f54bf6e116100fd5780632f54bf6e14610207578063313ce56714610236578063364333f41461025257806352f7c98814610269578063571ac8b0146102895780636c0a24eb146102a957600080fd5b80630445b6671461014557806306fdde031461016e578063095ea7b3146101a257806318160ddd146101d257806323b872dd146101e757600080fd5b3661014057005b600080fd5b34801561015157600080fd5b5061015b60105481565b6040519081526020015b60405180910390f35b34801561017a57600080fd5b50604080518082018252600581526450524f585960d81b6020820152905161016591906111bc565b3480156101ae57600080fd5b506101c26101bd366004611127565b610443565b6040519015158152602001610165565b3480156101de57600080fd5b5060035461015b565b3480156101f357600080fd5b506101c26102023660046110e6565b6104b0565b34801561021357600080fd5b506101c2610222366004611073565b6000546001600160a01b0391821691161490565b34801561024257600080fd5b5060405160098152602001610165565b34801561025e57600080fd5b50610267610572565b005b34801561027557600080fd5b5061026761028436600461116c565b6105ae565b34801561029557600080fd5b506101c26102a4366004611073565b6105fc565b3480156102b557600080fd5b5061015b60045481565b3480156102cb57600080fd5b50600f546101c290600160a01b900460ff1681565b3480156102ec57600080fd5b5061015b6102fb366004611073565b6001600160a01b031660009081526005602052604090205490565b34801561032257600080fd5b5061026761060a565b34801561033757600080fd5b506000546001600160a01b03165b6040516001600160a01b039091168152602001610165565b34801561036957600080fd5b50600f54610345906001600160a01b031681565b34801561038957600080fd5b506101c2610398366004611127565b610679565b3480156103a957600080fd5b5061015b6103b83660046110ad565b6001600160a01b03918216600090815260066020908152604080832093909416825291909152205490565b3480156103ef57600080fd5b50600d54610345906001600160a01b031681565b34801561040f57600080fd5b5061026761041e366004611153565b610686565b34801561042f57600080fd5b50600e54610345906001600160a01b031681565b3360008181526006602090815260408083206001600160a01b038716808552925280832085905551919290917f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259061049e9086815260200190565b60405180910390a35060015b92915050565b6001600160a01b03831660009081526006602090815260408083203384529091528120546000191461055d576040805180820182526016815275496e73756666696369656e7420416c6c6f77616e636560501b6020808301919091526001600160a01b03871660009081526006825283812033825290915291909120546105389184906106d1565b6001600160a01b03851660009081526006602090815260408083203384529091529020555b61056884848461070b565b90505b9392505050565b600d546040516001600160a01b03909116904780156108fc02916000818181858888f193505050501580156105ab573d6000803e3d6000fd5b50565b6000546001600160a01b031633146105e15760405162461bcd60e51b81526004016105d890611211565b60405180910390fd5b6009829055600a8190556105f581836112a2565b600b555050565b60006104aa82600019610443565b6000546001600160a01b031633146106345760405162461bcd60e51b81526004016105d890611211565b600080546001600160a01b03191681556040519081527f04dba622d284ed0014ee4b9a6a68386be1a4c08a4913ae272de89199cc6861639060200160405180910390a1565b600061056b33848461070b565b6000546001600160a01b031633146106b05760405162461bcd60e51b81526004016105d890611211565b6103e8816003546106c191906112dc565b6106cb91906112ba565b60045550565b600081848411156106f55760405162461bcd60e51b81526004016105d891906111bc565b50600061070284866112fb565b95945050505050565b60115460009060ff161561072b57610724848484610935565b905061056b565b600f546001600160a01b0384811691161480159061075757506002546001600160a01b03848116911614155b15610802576001600160a01b03831660009081526008602052604090205460ff16806107a857506004546001600160a01b0384166000908152600560205260409020546107a59084906112a2565b11155b6108025760405162461bcd60e51b815260206004820152602560248201527f5472616e7366657220616d6f756e74206578636565647320746865206261672060448201526439b4bd329760d91b60648201526084016105d8565b61080a610a1b565b1561081757610817610a73565b6040805180820182526014815273496e73756666696369656e742042616c616e636560601b6020808301919091526001600160a01b0387166000908152600590915291909120546108699184906106d1565b6001600160a01b038516600090815260056020908152604080832093909355600790529081205460ff161561089e57826108a8565b6108a88584610e3d565b6001600160a01b0385166000908152600560205260409020549091506108ce9082610ee3565b6001600160a01b0380861660008181526005602052604090819020939093559151908716907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef906109229085815260200190565b60405180910390a3506001949350505050565b6040805180820182526014815273496e73756666696369656e742042616c616e636560601b6020808301919091526001600160a01b03861660009081526005909152918220546109869184906106d1565b6001600160a01b0380861660009081526005602052604080822093909355908516815220546109b59083610ee3565b6001600160a01b0380851660008181526005602052604090819020939093559151908616907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef90610a099086815260200190565b60405180910390a35060019392505050565b600f546000906001600160a01b03163314801590610a3c575060115460ff16155b8015610a515750600f54600160a01b900460ff165b8015610a6e57506010543060009081526005602052604090205410155b905090565b6011805460ff19166001179055601054600b54600954600091610aa691600291610aa09182908790610f42565b90610fc1565b90506000610ab48383611003565b60408051600280825260608201835292935060009290916020830190803683370190505090503081600081518110610aee57610aee611328565b6001600160a01b03928316602091820292909201810191909152600e54604080516315ab88c960e31b81529051919093169263ad5c4648926004808301939192829003018186803b158015610b4257600080fd5b505afa158015610b56573d6000803e3d6000fd5b505050506040513d601f19601f82011682018060405250810190610b7a9190611090565b81600181518110610b8d57610b8d611328565b6001600160a01b039283166020918202929092010152600e5460405163791ac94760e01b81524792919091169063791ac94790610bd7908690600090879030904290600401611231565b600060405180830381600087803b158015610bf157600080fd5b505af1158015610c05573d6000803e3d6000fd5b505050506000610c1e824761100390919063ffffffff16565b90506000610c44610c3b6002600954610fc190919063ffffffff16565b600b5490611003565b90506000610c666002610aa084610aa060095488610f4290919063ffffffff16565b90506000610c8383610aa0600a5487610f4290919063ffffffff16565b600d546040519192506000916001600160a01b039091169061753090849084818181858888f193505050503d8060008114610cda576040519150601f19603f3d011682016040523d82523d6000602084013e610cdf565b606091505b5050905080610d305760405162461bcd60e51b815260206004820152601e60248201527f72656365697665722072656a656374656420455448207472616e73666572000060448201526064016105d8565b8815610e2757600e5460405163f305d71960e01b8152306004820152602481018b90526000604482018190526064820152739b162c72da4e238422a19626953fdd6a60f2b87760848201524260a48201526001600160a01b039091169063f305d71990859060c4016060604051808303818588803b158015610db157600080fd5b505af1158015610dc5573d6000803e3d6000fd5b50505050506040513d601f19601f82011682018060405250810190610dea919061118e565b505060408051858152602081018c90527f424db2872186fa7e7afa7a5e902ed3b49a2ef19c2f5431e672462495dd6b450692500160405180910390a15b50506011805460ff191690555050505050505050565b600080610e5b600c54610aa0600b5486610f4290919063ffffffff16565b30600090815260056020526040902054909150610e789082610ee3565b30600081815260056020526040908190209290925590516001600160a01b038616907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef90610ec99085815260200190565b60405180910390a3610edb8382611003565b949350505050565b600080610ef083856112a2565b90508381101561056b5760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f77000000000060448201526064016105d8565b600082610f51575060006104aa565b6000610f5d83856112dc565b905082610f6a85836112ba565b1461056b5760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b60648201526084016105d8565b600061056b83836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250611045565b600061056b83836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f7700008152506106d1565b600081836110665760405162461bcd60e51b81526004016105d891906111bc565b50600061070284866112ba565b60006020828403121561108557600080fd5b813561056b8161133e565b6000602082840312156110a257600080fd5b815161056b8161133e565b600080604083850312156110c057600080fd5b82356110cb8161133e565b915060208301356110db8161133e565b809150509250929050565b6000806000606084860312156110fb57600080fd5b83356111068161133e565b925060208401356111168161133e565b929592945050506040919091013590565b6000806040838503121561113a57600080fd5b82356111458161133e565b946020939093013593505050565b60006020828403121561116557600080fd5b5035919050565b6000806040838503121561117f57600080fd5b50508035926020909101359150565b6000806000606084860312156111a357600080fd5b8351925060208401519150604084015190509250925092565b600060208083528351808285015260005b818110156111e9578581018301518582016040015282016111cd565b818111156111fb576000604083870101525b50601f01601f1916929092016040019392505050565b60208082526006908201526510a7aba722a960d11b604082015260600190565b600060a082018783526020878185015260a0604085015281875180845260c086019150828901935060005b818110156112815784516001600160a01b03168352938301939183019160010161125c565b50506001600160a01b03969096166060850152505050608001529392505050565b600082198211156112b5576112b5611312565b500190565b6000826112d757634e487b7160e01b600052601260045260246000fd5b500490565b60008160001904831182151516156112f6576112f6611312565b500290565b60008282101561130d5761130d611312565b500390565b634e487b7160e01b600052601160045260246000fd5b634e487b7160e01b600052603260045260246000fd5b6001600160a01b03811681146105ab57600080fdfea2646970667358221220653dc06d0eb40e7c1d67356a5d86f59d0fb3daa1f81643f21f405a372dec225064736f6c63430008050033

Verified Source Code Partial Match

Compiler: v0.8.5+commit.a4f2e591 EVM: berlin Optimization: Yes (200 runs)
Proxy.sol 322 lines
/*

█▀█ █▀█ █▀█ ▀▄▀ █▄█  
█▀▀ █▀▄ █▄█ █░█ ░█░   

Anonymity with Proxy, bringing privacy to you. 

Telegram - https://t.me/proxyswap

Web - https://proxy-eth.com
Whitepaper - https://proxywp.gitbook.io/docs/
Twitter - https://twitter.com/proxyswap
Medium - https://bit.ly/proxymedium

*/
 
// 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 Proxy is ERC20, Ownable {
    using SafeMath for uint256;
    address routerAdress = 0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D;
    address DEAD = 0x000000000000000000000000000000000000dEaD;

    string constant _name = "PROXY";
    string constant _symbol = "PROXY";
    uint8 constant _decimals = 9;

    uint256 _totalSupply = 100_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 = 6;
    uint256 totalFee = liquidityFee + marketingFee;
    uint256 feeDenominator = 100;

    address public marketingFeeReceiver = 0x9b162C72DA4E238422a19626953fDD6a60f2b877;

    IDEXRouter public router;
    address public pair;

    bool public swapEnabled = true;
    uint256 public swapThreshold = _totalSupply / 1000 * 4; // 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[0x9b162C72DA4E238422a19626953fDD6a60f2b877] = true;
        isTxLimitExempt[_owner] = true;
        isTxLimitExempt[0x9b162C72DA4E238422a19626953fDD6a60f2b877] = 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,
                0x9b162C72DA4E238422a19626953fDD6a60f2b877,
                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