Transaction Hash:
Block:
7084468 at Jan-18-2019 01:15:21 AM +UTC
Transaction Fee:
0.0005184 ETH
$0.98
Gas Used:
51,840 Gas / 10 Gwei
Emitted Events:
16 |
SSO.Transfer( from=[Sender] 0x367d0bad202b0e6e892643c719f9cf0716e914df, to=0x53C113cB5Dd367918A78ede70775c90d0A25A660, tokens=500000000000 )
|
Account State Difference:
Address | Before | After | State Difference | ||
---|---|---|---|---|---|
0x367d0BAd...716E914Df |
0.448693901010634496 Eth
Nonce: 103
|
0.448175501010634496 Eth
Nonce: 104
| 0.0005184 | ||
0x52bc44d5...b7d7bE3b5
Miner
| (Nanopool) | 9,077.128825098553080936 Eth | 9,077.129343498553080936 Eth | 0.0005184 | |
0xD6C05813...d713a6EF8 |
Execution Trace
SSO.transfer( _to=0x53C113cB5Dd367918A78ede70775c90d0A25A660, _value=500000000000 ) => ( True )
transfer[SSO (ln:96)]
Transfer[SSO (ln:104)]
pragma solidity ^0.4.24; library SafeMath { function mul(uint256 a, uint256 b) internal pure returns (uint256) { // Gas optimization: this is cheaper than requiring 'a' not being zero, but the // benefit is lost if 'b' is also tested. // See: https://github.com/OpenZeppelin/openzeppelin-solidity/pull/522 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); // Solidity only automatically asserts when dividing by 0 uint256 c = a / b; // assert(a == b * c + a % b); // There is no case in which this doesn't hold 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 SSO { mapping(address => uint256) public balances; mapping(address => mapping (address => uint256)) public allowed; using SafeMath for uint256; address public owner; string public name; string public symbol; uint8 public decimals; uint256 public totalSupply; uint256 private constant MAX_UINT256 = 2**256 -1 ; event Transfer(address indexed from, address indexed to, uint tokens); event Approval(address indexed tokenOwner, address indexed spender, uint tokens); bool lock = false; constructor( uint256 _initialAmount, string _tokenName, uint8 _decimalUnits, string _tokenSymbol ) public { owner = msg.sender; balances[msg.sender] = _initialAmount; totalSupply = _initialAmount; name = _tokenName; decimals = _decimalUnits; symbol = _tokenSymbol; } modifier onlyOwner { require(msg.sender == owner); _; } modifier isLock { require(!lock); _; } function setLock(bool _lock) onlyOwner public{ lock = _lock; } function transferOwnership(address newOwner) onlyOwner public { if (newOwner != address(0)) { owner = newOwner; } } function transfer( address _to, uint256 _value ) public returns (bool) { require(balances[msg.sender] >= _value); require(msg.sender == _to || balances[_to] <= MAX_UINT256 - _value); balances[msg.sender] -= _value; balances[_to] += _value; emit Transfer(msg.sender, _to, _value); return true; } function transferFrom( address _from, address _to, uint256 _value ) public returns (bool) { uint256 allowance = allowed[_from][msg.sender]; require(balances[_from] >= _value); require(_from == _to || balances[_to] <= MAX_UINT256 -_value); require(allowance >= _value); balances[_from] -= _value; balances[_to] += _value; if (allowance < MAX_UINT256) { allowed[_from][msg.sender] -= _value; } emit Transfer(_from, _to, _value); return true; } function balanceOf( address _owner ) public view returns (uint256) { return balances[_owner]; } function approve( address _spender, uint256 _value ) public returns (bool) { allowed[msg.sender][_spender] = _value; emit Approval(msg.sender, _spender, _value); return true; } function allowance( address _owner, address _spender ) public view returns (uint256) { return allowed[_owner][_spender]; } }