Transaction Hash:
Block:
20849279 at Sep-28-2024 12:57:35 PM +UTC
Transaction Fee:
0.000482806633523172 ETH
$1.18
Gas Used:
49,182 Gas / 9.816734446 Gwei
Emitted Events:
241 |
XaurumGammaToken.Transfer( _from=[Sender] 0x6a5b338b88610d71a134349d284c50c791765e8e, _to=0x11F4216CA60Bcb9DdBd80505B801Aa40661059d4, _value=207380000 )
|
Account State Difference:
Address | Before | After | State Difference | ||
---|---|---|---|---|---|
0x4838B106...B0BAD5f97
Miner
| (Titan Builder) | 14.605047001228597238 Eth | 14.605095199588597238 Eth | 0.00004819836 | |
0x533ef098...aA39CD8CD | |||||
0x6a5B338b...791765e8E |
0.009863956990056 Eth
Nonce: 74
|
0.009381150356532828 Eth
Nonce: 75
| 0.000482806633523172 |
Execution Trace
XaurumGammaToken.transfer( _to=0x11F4216CA60Bcb9DdBd80505B801Aa40661059d4, _value=207380000 ) => ( success=True )
transfer[ERC20TokenInterface (ln:87)]
contract SafeMath { uint256 constant public MAX_UINT256 = 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF; function safeAdd(uint256 x, uint256 y) constant internal returns (uint256 z) { require(x <= MAX_UINT256 - y); return x + y; } function safeSub(uint256 x, uint256 y) constant internal returns (uint256 z) { require(x >= y); return x - y; } function safeMul(uint256 x, uint256 y) constant internal returns (uint256 z) { if (y == 0) { return 0; } require(x <= (MAX_UINT256 / y)); return x * y; } } contract Owned { address public owner; address public newOwner; function Owned() { owner = msg.sender; } modifier onlyOwner { assert(msg.sender == owner); _; } function transferOwnership(address _newOwner) public onlyOwner { require(_newOwner != owner); newOwner = _newOwner; } function acceptOwnership() public { require(msg.sender == newOwner); OwnerUpdate(owner, newOwner); owner = newOwner; newOwner = 0x0; } event OwnerUpdate(address _prevOwner, address _newOwner); } contract Lockable is Owned { uint256 public lockedUntilBlock; event ContractLocked(uint256 _untilBlock, string _reason); modifier lockAffected { require(block.number > lockedUntilBlock); _; } function lockFromSelf(uint256 _untilBlock, string _reason) internal { lockedUntilBlock = _untilBlock; ContractLocked(_untilBlock, _reason); } function lockUntil(uint256 _untilBlock, string _reason) onlyOwner public { lockedUntilBlock = _untilBlock; ContractLocked(_untilBlock, _reason); } } contract tokenRecipientInterface { function receiveApproval(address _from, uint256 _value, address _token, bytes _extraData); } contract OwnedInterface { address public owner; address public newOwner; modifier onlyOwner { _; } } contract ERC20TokenInterface { function totalSupply() public constant returns (uint256 _totalSupply); function balanceOf(address _owner) public constant returns (uint256 balance); function transfer(address _to, uint256 _value) public returns (bool success); function transferFrom(address _from, address _to, uint256 _value) public returns (bool success); function approve(address _spender, uint256 _value) public returns (bool success); function allowance(address _owner, address _spender) public constant returns (uint256 remaining); event Transfer(address indexed _from, address indexed _to, uint256 _value); event Approval(address indexed _owner, address indexed _spender, uint256 _value); } contract ERC20PrivateInterface { uint256 supply; mapping (address => uint256) balances; mapping (address => mapping (address => uint256)) allowances; event Transfer(address indexed _from, address indexed _to, uint256 _value); event Approval(address indexed _owner, address indexed _spender, uint256 _value); } contract ERC20Token is ERC20TokenInterface, SafeMath, Owned, Lockable { /* Public variables of the token */ string public standard; string public name; string public symbol; uint8 public decimals; /* Private variables of the token */ uint256 supply = 0; mapping (address => uint256) balances; mapping (address => mapping (address => uint256)) allowances; event Mint(address indexed _to, uint256 _value); event Burn(address indexed _from, uint _value); /* Returns total supply of issued tokens */ function totalSupply() constant returns (uint256) { return supply; } /* Returns balance of address */ function balanceOf(address _owner) constant returns (uint256 balance) { return balances[_owner]; } /* Transfers tokens from your address to other */ function transfer(address _to, uint256 _value) lockAffected returns (bool success) { require(_to != 0x0 && _to != address(this)); balances[msg.sender] = safeSub(balanceOf(msg.sender), _value); // Deduct senders balance balances[_to] = safeAdd(balanceOf(_to), _value); // Add recivers blaance Transfer(msg.sender, _to, _value); // Raise Transfer event return true; } /* Approve other address to spend tokens on your account */ function approve(address _spender, uint256 _value) lockAffected returns (bool success) { allowances[msg.sender][_spender] = _value; // Set allowance Approval(msg.sender, _spender, _value); // Raise Approval event return true; } /* Approve and then communicate the approved contract in a single tx */ function approveAndCall(address _spender, uint256 _value, bytes _extraData) lockAffected returns (bool success) { tokenRecipientInterface spender = tokenRecipientInterface(_spender); // Cast spender to tokenRecipient contract approve(_spender, _value); // Set approval to contract for _value spender.receiveApproval(msg.sender, _value, this, _extraData); // Raise method on _spender contract return true; } /* A contract attempts to get the coins */ function transferFrom(address _from, address _to, uint256 _value) lockAffected returns (bool success) { require(_to != 0x0 && _to != address(this)); balances[_from] = safeSub(balanceOf(_from), _value); // Deduct senders balance balances[_to] = safeAdd(balanceOf(_to), _value); // Add recipient blaance allowances[_from][msg.sender] = safeSub(allowances[_from][msg.sender], _value); // Deduct allowance for this address Transfer(_from, _to, _value); // Raise Transfer event return true; } function allowance(address _owner, address _spender) constant returns (uint256 remaining) { return allowances[_owner][_spender]; } function mint(address _to, uint256 _amount) onlyOwner { supply = safeAdd(supply, _amount); balances[_to] = safeAdd(balances[_to], _amount); Mint(_to, _amount); Transfer(0x0, _to, _amount); } function burn(uint _amount) lockAffected { balances[msg.sender] = safeSub(balanceOf(msg.sender), _amount); supply = safeSub(supply, _amount); Burn(msg.sender, _amount); Transfer(msg.sender, 0x0, _amount); } function salvageTokensFromContract(address _tokenAddress, address _to, uint _amount) onlyOwner { ERC20TokenInterface(_tokenAddress).transfer(_to, _amount); } } contract XaurumGammaToken is ERC20Token { /* Initializes contract */ function XaurumGammaToken() { standard = "XGM token v1.0"; name = "XaurumGamma"; symbol = "XGM"; decimals = 8; lockFromSelf(4352535, "Lock before distribution"); } }