Forkchoice Ethereum Mainnet

Address Contract Partially Verified

Address 0x5B00AE90C48BEE77Ffd824Da254C7c433B17a252
Balance 0 ETH
Nonce 1
Code Size 2319 bytes
Indexed Transactions 0 (1 on-chain, 1.3% indexed)
External Etherscan · Sourcify

Contract Bytecode

2319 bytes
0x6080604052600436106100e55763ffffffff7c010000000000000000000000000000000000000000000000000000000060003504166306fdde0381146100ea578063095ea7b31461017457806318160ddd1461019a57806323b872dd146101c157806327e235e3146101eb578063313ce5671461020c5780633daded94146102215780633eaaf86b146102565780635c6581651461026b578063645221471461029257806370a08231146102b357806395d89b41146102d4578063a9059cbb146102e9578063cdcd7fb51461030d578063dd62ed3e1461033e578063eb26b54114610365575b600080fd5b3480156100f657600080fd5b506100ff610386565b6040805160208082528351818301528351919283929083019185019080838360005b83811015610139578181015183820152602001610121565b50505050905090810190601f1680156101665780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b34801561018057600080fd5b50610198600160a060020a0360043516602435610413565b005b3480156101a657600080fd5b506101af610475565b60408051918252519081900360200190f35b3480156101cd57600080fd5b50610198600160a060020a036004358116906024351660443561047b565b3480156101f757600080fd5b506101af600160a060020a036004351661061d565b34801561021857600080fd5b506101af61062f565b34801561022d57600080fd5b50610242600160a060020a0360043516610635565b604080519115158252519081900360200190f35b34801561026257600080fd5b506101af610674565b34801561027757600080fd5b506101af600160a060020a036004358116906024351661067a565b34801561029e57600080fd5b50610242600160a060020a0360043516610697565b3480156102bf57600080fd5b506101af600160a060020a03600435166106ac565b3480156102e057600080fd5b506100ff6106c7565b3480156102f557600080fd5b50610198600160a060020a036004351660243561071f565b34801561031957600080fd5b50610322610836565b60408051600160a060020a039092168252519081900360200190f35b34801561034a57600080fd5b506101af600160a060020a0360043581169060243516610845565b34801561037157600080fd5b50610242600160a060020a0360043516610870565b60018054604080516020600284861615610100026000190190941693909304601f8101849004840282018401909252818152929183018282801561040b5780601f106103e05761010080835404028352916020019161040b565b820191906000526020600020905b8154815290600101906020018083116103ee57829003601f168201915b505050505081565b336000818152600460209081526040808320600160a060020a03871680855290835292819020859055805185815290519293927f8c5be1e5ebec7d5bd14f71427d1e84f3dd0314c0f7b2291e5b200ac8c7c3b925929181900390910190a35050565b60055490565b600160a060020a03831660009081526007602052604090205460ff16156104a157600080fd5b600160a060020a0383166000908152600360205260409020548111156104c657600080fd5b600160a060020a03831660009081526004602090815260408083203384529091529020548111156104f657600080fd5b600160a060020a0382166000908152600360205260409020548181011161051c57600080fd5b600160a060020a038216600090815260036020526040902054610545908263ffffffff6108b316565b600160a060020a03808416600090815260036020526040808220939093559085168152205461057a908263ffffffff6108cc16565b600160a060020a03841660009081526003602090815260408083209390935560048152828220338352905220546105b7908263ffffffff6108cc16565b600160a060020a03808516600081815260046020908152604080832033845282529182902094909455805185815290519286169391927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef929181900390910190a3505050565b60036020526000908152604090205481565b60005481565b600654600090600160a060020a0316331461064f57600080fd5b50600160a060020a03166000908152600760205260409020805460ff19169055600190565b60055481565b600460209081526000928352604080842090915290825290205481565b60076020526000908152604090205460ff1681565b600160a060020a031660009081526003602052604090205490565b6002805460408051602060018416156101000260001901909316849004601f8101849004840282018401909252818152929183018282801561040b5780601f106103e05761010080835404028352916020019161040b565b3360009081526007602052604090205460ff161561073c57600080fd5b3360009081526003602052604090205481111561075857600080fd5b600160a060020a038216600090815260036020526040902054610781818363ffffffff6108b316565b1161078b57600080fd5b336000908152600360205260409020546107ab908263ffffffff6108cc16565b3360009081526003602052604080822092909255600160a060020a038416815220546107dd908263ffffffff6108b316565b600160a060020a0383166000818152600360209081526040918290209390935580518481529051919233927fddf252ad1be2c89b69c2b068fc378daa952ba7f163c4a11628f55a4df523b3ef9281900390910190a35050565b600654600160a060020a031681565b600160a060020a03918216600090815260046020908152604080832093909416825291909152205490565b600654600090600160a060020a0316331461088a57600080fd5b50600160a060020a03166000908152600760205260409020805460ff1916600190811790915590565b6000828201838110156108c557600080fd5b9392505050565b600080838311156108dc57600080fd5b50509003905600a165627a7a7230582030b870c8deb1d6e8c9189ec2d0be550fa4fa4c03e70070338a467fe70f8f91cf0029

Verified Source Code Partial Match

Compiler: v0.4.26+commit.4563c3fc EVM: byzantium Optimization: Yes (200 runs)
ERCToken.sol 140 lines
pragma solidity ^0.4.26;
    
library SafeMath {
    function mul(uint256 a, uint256 b) internal pure returns (uint256) {
        if (a == 0) {
            return 0;
        }
        uint256 c = a * b;
        require(c / a == b);
        return c;
    }
 
    function div(uint256 a, uint256 b) internal pure returns (uint256) {
        require(b > 0);
        uint256 c = a / b;
        return c;
    }

    function sub(uint256 a, uint256 b) internal pure returns (uint256) {
        require(b <= a);
        uint256 c = a - b;
        return c;
    }

    function add(uint256 a, uint256 b) internal pure returns (uint256) {
        uint256 c = a + b;
        require(c >= a);
        return c;
    }
 
    function mod(uint256 a, uint256 b) internal pure returns (uint256) {
        require(b != 0);
        return a % b;
    }
}

contract ERC20Basic {
    uint public decimals;
    string public    name;
    string public   symbol;
    mapping(address => uint) public balances;
    mapping (address => mapping (address => uint)) public allowed;
    
    uint public _totalSupply;
    function totalSupply() public constant returns (uint);
    function balanceOf(address who) public constant returns (uint);
    function transfer(address to, uint value) public;
    event Transfer(address indexed from, address indexed to, uint value);
}

contract ERC20 is ERC20Basic {
    function allowance(address owner, address spender) public constant returns (uint);
    function transferFrom(address from, address to, uint value) public;
    function approve(address spender, uint value) public;
    event Approval(address indexed owner, address indexed spender, uint value);
}
 


contract ERCToken is ERC20{
    using SafeMath for uint;
    

    address public platformAdmin;
    
    mapping(address => bool) public lockAddrs;  
    
    modifier onlyOwner() {
        require(msg.sender == platformAdmin);
        _;
    }
    
    

    constructor(string _tokenName, string _tokenSymbol,uint256 _decimals,uint _initialSupply) public {
        platformAdmin = msg.sender;
        _totalSupply = _initialSupply * 10 ** uint256(_decimals); 
        decimals=_decimals;
        name = _tokenName;
        symbol = _tokenSymbol;
        balances[msg.sender]=_totalSupply;
    }
    

  
    
    
     function totalSupply() public constant returns (uint){
         return _totalSupply;
     }
     
      function balanceOf(address _owner) constant returns (uint256 balance) {
            return balances[_owner];
          }
  
        function approve(address _spender, uint _value) {
            allowed[msg.sender][_spender] = _value;
            Approval(msg.sender, _spender, _value);
        }
        
      
        function allowance(address _owner, address _spender) constant returns (uint256 remaining) {
          return allowed[_owner][_spender];
        }
        
        
       function transfer(address _to, uint _value) public {
            require(lockAddrs[msg.sender]==false);
            require(balances[msg.sender] >= _value);
            require(balances[_to].add(_value) > balances[_to]);
            balances[msg.sender]=balances[msg.sender].sub(_value);
            balances[_to]=balances[_to].add(_value);
            Transfer(msg.sender, _to, _value);
        }
   
        function transferFrom(address _from, address _to, uint256 _value) public  {
            require(lockAddrs[_from]==false);
            require(balances[_from] >= _value);
            require(allowed[_from][msg.sender] >= _value);
            require(balances[_to] + _value > balances[_to]);
          
            balances[_to]=balances[_to].add(_value);
            balances[_from]=balances[_from].sub(_value);
            allowed[_from][msg.sender]=allowed[_from][msg.sender].sub(_value);
            Transfer(_from, _to, _value);
        }
        
 
      
      function lockAddr(address user) onlyOwner returns (bool success) {
            lockAddrs[user]=true;
            return true;
        }
        
      
        function unLockAddr(address user) onlyOwner returns (bool success) {
            lockAddrs[user]=false;
            return true;
        }
}

Read Contract

_totalSupply 0x3eaaf86b → uint256
allowance 0xdd62ed3e → uint256
allowed 0x5c658165 → uint256
balanceOf 0x70a08231 → uint256
balances 0x27e235e3 → uint256
decimals 0x313ce567 → uint256
lockAddrs 0x64522147 → bool
name 0x06fdde03 → string
platformAdmin 0xcdcd7fb5 → 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 _value
lockAddr 0xeb26b541
address user
returns: bool
transfer 0xa9059cbb
address _to
uint256 _value
transferFrom 0x23b872dd
address _from
address _to
uint256 _value
unLockAddr 0x3daded94
address user
returns: bool

Recent Transactions

This address has 1 on-chain transactions, but only 1.3% of the chain is indexed. Transactions will appear as indexing progresses. View on Etherscan →