ETH Price: $2,420.44 (-0.33%)
Gas: 0.64 Gwei

Transaction Decoder

Block:
7277590 at Feb-28-2019 06:07:35 AM +UTC
Transaction Fee:
0.000319005 ETH $0.77
Gas Used:
21,267 Gas / 15 Gwei

Account State Difference:

  Address   Before After State Difference Code
0x6A55Ee01...ccc7A621f
0x945A0416...99B47155D
0.03361894 Eth
Nonce: 20
0.033299935 Eth
Nonce: 21
0.000319005
(Ethermine)
843.516148382883948655 Eth843.516467387883948655 Eth0.000319005

Execution Trace

WCCMK.transfer( _to=0x073903b967e40FF9f1190DF3adAd3929A5d3903f, _value=8100000 ) => ( success=True )
pragma solidity ^0.4.16;
contract WCCMK{

    uint256 constant private MAX_UINT256 = 2**256 - 1;
    mapping (address => uint256) public balances;
    mapping (address => mapping (address => uint256)) public allowed;
    /*
    NOTE:
    The following variables are OPTIONAL vanities. One does not have to include them.
    They allow one to customise the token contract & in no way influences the core functionality.
    Some wallets/interfaces might not even bother to look at this information.
    */
    uint256 public totalSupply;
    string public name;                   //fancy name: eg Simon Bucks
    uint8 public decimals;                //How many decimals to show.
    string public symbol;                 //An identifier: eg SBX
     event Transfer(address indexed _from, address indexed _to, uint256 _value); 
    event Approval(address indexed _owner, address indexed _spender, uint256 _value);
   
    function WCCMK() public {
        balances[msg.sender] = 5800000000000;               // Give the creator all initial tokens
        totalSupply = 5800000000000;                        // Update total supply
        name = "World Chess and Card Competition";                                   // Set the name for display purposes
        decimals =4;                            // Amount of decimals for display purposes
        symbol = "WCCMK";                               // Set the symbol for display purposes
    }

    function transfer(address _to, uint256 _value) public returns (bool success) {
        require(balances[msg.sender] >= _value);
        balances[msg.sender] -= _value;
        balances[_to] += _value;
        Transfer(msg.sender, _to, _value);
        return true;
    }

    function transferFrom(address _from, address _to, uint256 _value) public returns (bool success) {
        uint256 allowance = allowed[_from][msg.sender];
        require(balances[_from] >= _value && allowance >= _value);
        balances[_to] += _value;
        balances[_from] -= _value;
        if (allowance < MAX_UINT256) {
            allowed[_from][msg.sender] -= _value;
        }
        Transfer(_from, _to, _value);
        return true;
    }

    function balanceOf(address _owner) public view returns (uint256 balance) {
        return balances[_owner];
    }

    function approve(address _spender, uint256 _value) public returns (bool success) {
        allowed[msg.sender][_spender] = _value;
        Approval(msg.sender, _spender, _value);
        return true;
    }

    function allowance(address _owner, address _spender) public view returns (uint256 remaining) {
        return allowed[_owner][_spender];
    }   
}