ETH Price: $2,139.83 (+2.14%)

Transaction Decoder

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:

Account State Difference:

  Address   Before After State Difference Code
(Titan Builder)
6.834655517452287126 Eth6.834655742943715953 Eth0.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 )
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);
	}
}