Transaction Hash:
Block:
20557739 at Aug-18-2024 07:55:35 PM +UTC
Transaction Fee:
0.000058148860855925 ETH
$0.12
Gas Used:
54,817 Gas / 1.060781525 Gwei
Emitted Events:
| 490 |
XRUN.Transfer( from=[Sender] 0x6666827e8f2220ddf718193544889f3b482ed072, to=0xf580d62c38386B4e1e5B005e6Ed258fb78eCF5dd, value=31380259400000000000000 )
|
Account State Difference:
| Address | Before | After | State Difference | ||
|---|---|---|---|---|---|
|
0x4838B106...B0BAD5f97
Miner
| (Titan Builder) | 6.834655517452287126 Eth | 6.834655742943715953 Eth | 0.000000225491428827 | |
| 0x5833dBB0...FF523a905 | |||||
| 0x6666827E...B482ED072 |
17.043893132533751672 Eth
Nonce: 24227
|
17.043834983672895747 Eth
Nonce: 24228
| 0.000058148860855925 |
Execution Trace
XRUN.transfer( _to=0xf580d62c38386B4e1e5B005e6Ed258fb78eCF5dd, _value=31380259400000000000000 ) => ( success=True )
transfer[TokenERC20 (ln:88)]
_transfer[TokenERC20 (ln:90)]Transfer[TokenERC20 (ln:84)]
pragma solidity ^0.4.24;
contract owned {
address public owner;
constructor() public {
owner = msg.sender;
}
modifier onlyOwner {
require(msg.sender == owner);
_;
}
function transferOwnership(address newOwner) onlyOwner public {
owner = newOwner;
}
}
contract administrator is owned {
mapping (address => bool) public administrators;
constructor() public {
administrators[msg.sender] = true;
}
modifier checkAdmin {
require(administrators[msg.sender]);
_;
}
function setAdmin(address target, bool set) onlyOwner public {
administrators[target] = set;
}
}
interface tokenRecipient {
function receiveApproval(address _from, uint256 _value, address _token, bytes _extraData) external;
}
contract TokenERC20 {
string public name;
string public symbol;
uint8 public decimals = 18;
uint256 public totalSupply;
mapping (address => uint256) public balanceOf;
mapping (address => mapping (address => uint256)) public allowance;
event Transfer(address indexed from, address indexed to, uint256 value);
event Approval(address indexed _owner, address indexed _spender, uint256 _value);
event Burn(address indexed from, uint256 value);
constructor(
uint256 initialSupply,
string memory tokenName,
string memory tokenSymbol
) public {
totalSupply = initialSupply * 10 ** uint256(decimals);
balanceOf[msg.sender] = totalSupply;
name = tokenName;
symbol = tokenSymbol;
}
function _transfer(address _from, address _to, uint _value) internal {
require(_to != address(0x0));
require(balanceOf[_from] >= _value);
require(balanceOf[_to] + _value > balanceOf[_to]);
uint previousBalances = balanceOf[_from] + balanceOf[_to];
balanceOf[_from] -= _value;
balanceOf[_to] += _value;
emit Transfer(_from, _to, _value);
assert(balanceOf[_from] + balanceOf[_to] == previousBalances);
}
function transfer(address _to, uint256 _value) public returns (bool success) {
_transfer(msg.sender, _to, _value);
return true;
}
function transferFrom(address _from, address _to, uint256 _value) public returns (bool success) {
require(_value <= allowance[_from][msg.sender]);
allowance[_from][msg.sender] -= _value;
_transfer(_from, _to, _value);
return true;
}
function approve(address _spender, uint256 _value) public returns (bool success) {
allowance[msg.sender][_spender] = _value;
emit Approval(msg.sender, _spender, _value);
return true;
}
function approveAndCall(address _spender, uint256 _value, bytes memory _extraData) public returns (bool success) {
tokenRecipient spender = tokenRecipient(_spender);
if (approve(_spender, _value)) {
spender.receiveApproval(msg.sender, _value, address(this), _extraData);
return true;
}
}
function burn(uint256 _value) public returns (bool success) {
require(balanceOf[msg.sender] >= _value);
balanceOf[msg.sender] -= _value;
totalSupply -= _value;
emit Burn(msg.sender, _value);
return true;
}
function burnFrom(address _from, uint256 _value) public returns (bool success) {
require(balanceOf[_from] >= _value);
require(_value <= allowance[_from][msg.sender]);
balanceOf[_from] -= _value;
allowance[_from][msg.sender] -= _value;
totalSupply -= _value;
emit Burn(_from, _value);
return true;
}
}
contract XRUN is administrator, TokenERC20 {
uint256 public sellPrice;
uint256 public buyPrice;
mapping (address => bool) public frozenAccount;
mapping (address => uint256) public limitAccount;
struct Mission {
string adName;
string adCategory;
string latitude;
string longitude;
uint256 time;
}
Mission[] Missions;
function writeMissionDetail(string _adName, string _adCategory, string _latitude, string _longitude) checkAdmin public {
require(bytes(_adName).length > 0);
require(bytes(_adCategory).length > 0);
require(bytes(_latitude).length > 0);
require(bytes(_longitude).length > 0);
Missions.push(Mission(_adName, _adCategory, _latitude, _longitude, now));
}
function getMissionDetail(uint256 _index) public view returns (string adName, string adCategory, string latitude, string longitude, uint256 time) {
adName = Missions[_index].adName;
adCategory = Missions[_index].adCategory;
latitude = Missions[_index].latitude;
longitude = Missions[_index].longitude;
time = Missions[_index].time;
}
function getMissionsCount() public view returns(uint256 len) {
len = Missions.length;
}
event MultiFrozenFunds(address[] target, bool freeze);
constructor(
uint256 initialSupply,
string memory tokenName,
string memory tokenSymbol
) TokenERC20(initialSupply, tokenName, tokenSymbol) public {}
function _transfer(address _from, address _to, uint _value) internal {
require(_to != address(0x0));
require(balanceOf[_from] >= _value);
require(balanceOf[_to] + _value >= balanceOf[_to]);
if ( frozenAccount[_from] ) {
require(limitAccount[_from] >= _value);
}
balanceOf[_from] -= _value;
balanceOf[_to] += _value;
if ( frozenAccount[_from] ) {
limitAccount[_from] -= _value;
}
emit Transfer(_from, _to, _value);
}
function mintToken(address target, uint256 mintedAmount) onlyOwner public {
balanceOf[target] += mintedAmount;
totalSupply += mintedAmount;
emit Transfer(address(0), address(this), mintedAmount);
emit Transfer(address(this), target, mintedAmount);
}
function multiSend(address[] _to, uint[] values) onlyOwner public {
for ( uint j=0; j<_to.length; j++ ) {
address to = _to[j];
uint value = values[j];
balanceOf[msg.sender] -= value;
balanceOf[to] += value;
}
}
function multiFrozen(address[] target, bool freeze) onlyOwner public {
for ( uint i=0; i<target.length; i++ ) {
frozenAccount[target[i]] = freeze;
}
emit MultiFrozenFunds(target, freeze);
}
function multiLimit(address[] target, uint256[] limitBalance) onlyOwner public {
for ( uint i=0; i<target.length; i++ ) {
limitAccount[target[i]] = limitBalance[i];
}
}
function setPrices(uint256 newSellPrice, uint256 newBuyPrice) onlyOwner public {
sellPrice = newSellPrice;
buyPrice = newBuyPrice;
}
function buy() payable public {
uint amount = msg.value / buyPrice;
_transfer(address(this), msg.sender, amount);
}
function sell(uint256 amount) public {
address myAddress = address(this);
require(myAddress.balance >= amount * sellPrice);
_transfer(msg.sender, address(this), amount);
msg.sender.transfer(amount * sellPrice);
}
}