Transaction Hash:
Block:
8010063 at Jun-22-2019 08:33:44 PM +UTC
Transaction Fee:
0.000819525 ETH
$2.12
Gas Used:
273,175 Gas / 3 Gwei
Emitted Events:
19 |
Oraclize.0xb76d0edd90c6a07aa3ff7a222d7f5933e29c6acc660c059c97837f05c4ca1a84( 0xb76d0edd90c6a07aa3ff7a222d7f5933e29c6acc660c059c97837f05c4ca1a84, 00000000000000000000000052af063278c6489a9def8b27615fa813797cded1, 5c3b7b39ddc32cbd938ac37cb5307b63bb72cf36f2a8f504f6a57da5d28ac714, 0000000000000000000000000000000000000000000000000000000000000000, 0000000000000000000000000000000000000000000000000000000000000100, 0000000000000000000000000000000000000000000000000000000000000140, 0000000000000000000000000000000000000000000000000000000000030d40, 1100000000000000000000000000000000000000000000000000000000000000, 00000000000000000000000000000000000000000000000000000000b2d05e00, 0000000000000000000000000000000000000000000000000000000000000003, 55524c0000000000000000000000000000000000000000000000000000000000, 00000000000000000000000000000000000000000000000000000000000000a9, 68746d6c2868747470733a2f2f747769747465722e636f6d2f6775676f6f6c63, 6f2f7374617475732f313134323532383834323838313534343139323f733d32, 30292e7870617468282f2f6469765b636f6e7461696e732840636c6173732c20, 277065726d616c696e6b2d74776565742d636f6e7461696e657227295d2f2f70, 5b636f6e7461696e732840636c6173732c202774776565742d7465787427295d, 2f2f746578742829290000000000000000000000000000000000000000000000 )
|
20 |
0x52af063278c6489a9def8b27615fa813797cded1.0xb32b648e951ebf08b3c09f106fb318849a0473f4eb780c7931c8d006cce8de03( 0xb32b648e951ebf08b3c09f106fb318849a0473f4eb780c7931c8d006cce8de03, 0x00000000000000000000000010207a6078b9652840d7988965416d357e74a387, 0x5c3b7b39ddc32cbd938ac37cb5307b63bb72cf36f2a8f504f6a57da5d28ac714, 7477697474657200000000000000000000000000000000000000000000000000, 0000000000000000000000000000000000000000000000000000000000000080, 00000000000000000000000000000000000000000000000000000000000000c0, 0000000000000000000000000000000000000000000000000000000000000100, 0000000000000000000000000000000000000000000000000000000000000008, 6775676f6f6c636f000000000000000000000000000000000000000000000000, 0000000000000000000000000000000000000000000000000000000000000008, 6775676f6f6c636f000000000000000000000000000000000000000000000000, 000000000000000000000000000000000000000000000000000000000000003c, 68747470733a2f2f747769747465722e636f6d2f6775676f6f6c636f2f737461, 7475732f313134323532383834323838313534343139323f733d323000000000 )
|
Account State Difference:
Address | Before | After | State Difference | ||
---|---|---|---|---|---|
0x10207A60...57E74A387 |
0.0162832 Eth
Nonce: 0
|
0.010463675 Eth
Nonce: 1
| 0.005819525 | ||
0x3dBDc81a...e395fDcf6 | 97.89311912960760242 Eth | 97.89388190062134027 Eth | 0.00076277101373785 | ||
0x52Af0632...3797cDed1 | 5.2858037373449588 Eth | 5.29004096633122095 Eth | 0.00423722898626215 | ||
0x5A0b54D5...D3E029c4c
Miner
| (Spark Pool) | 3,916.216529876348963139 Eth | 3,916.217349401348963139 Eth | 0.000819525 |
Execution Trace
ETH 0.005
0x52af063278c6489a9def8b27615fa813797cded1.1d695136( )
-
OraclizeAddrResolver.CALL( )
-
Oraclize.ca6ad1e4( )
-
OraclizeAddrResolver.CALL( )
-
Oraclize.688dcfd7( )
-
OraclizeAddrResolver.CALL( )
-
Oraclize.2ef3accc( )
- ETH 0.00076277101373785
Oraclize.c51be90f( )
File 1 of 2: Oraclize
File 2 of 2: OraclizeAddrResolver
/* Copyright (c) 2015-2016 Oraclize SRL Copyright (c) 2016-2017 Oraclize LTD */ /* Oraclize Connector v1.2.0 */ // 'compressed' alternative, where all modifiers have been changed to FUNCTIONS // which is cheaper for deployment, potentially cheaper execution pragma solidity ^0.4.11; contract Oraclize { mapping (address => uint) reqc; mapping (address => byte) public cbAddresses; mapping (address => bool) public offchainPayment; event Log1(address sender, bytes32 cid, uint timestamp, string datasource, string arg, uint gaslimit, byte proofType, uint gasPrice); event Log2(address sender, bytes32 cid, uint timestamp, string datasource, string arg1, string arg2, uint gaslimit, byte proofType, uint gasPrice); event LogN(address sender, bytes32 cid, uint timestamp, string datasource, bytes args, uint gaslimit, byte proofType, uint gasPrice); event Log1_fnc(address sender, bytes32 cid, uint timestamp, string datasource, string arg, function() external callback, uint gaslimit, byte proofType, uint gasPrice); event Log2_fnc(address sender, bytes32 cid, uint timestamp, string datasource, string arg1, string arg2, function() external callback, uint gaslimit, byte proofType, uint gasPrice); event LogN_fnc(address sender, bytes32 cid, uint timestamp, string datasource, bytes args, function() external callback, uint gaslimit, byte proofType, uint gasPrice); event Emit_OffchainPaymentFlag(address indexed idx_sender, address sender, bool indexed idx_flag, bool flag); address owner; address paymentFlagger; function changeAdmin(address _newAdmin) external { onlyadmin(); owner = _newAdmin; } function changePaymentFlagger(address _newFlagger) external { onlyadmin(); paymentFlagger = _newFlagger; } function addCbAddress(address newCbAddress, byte addressType) external { onlyadmin(); //bytes memory nil = ''; addCbAddress(newCbAddress, addressType, hex''); } // proof is currently a placeholder for when associated proof for addressType is added function addCbAddress(address newCbAddress, byte addressType, bytes proof) public { onlyadmin(); cbAddresses[newCbAddress] = addressType; } function removeCbAddress(address newCbAddress) external { onlyadmin(); delete cbAddresses[newCbAddress]; } function cbAddress() constant returns (address _cbAddress) { if (cbAddresses[tx.origin] != 0) _cbAddress = tx.origin; } function addDSource(string dsname, uint multiplier) external { addDSource(dsname, 0x00, multiplier); } function addDSource(string dsname, byte proofType, uint multiplier) public { onlyadmin(); bytes32 dsname_hash = sha3(dsname, proofType); dsources[dsources.length++] = dsname_hash; price_multiplier[dsname_hash] = multiplier; } // Utilized by bridge function multiAddDSource(bytes32[] dsHash, uint256[] multiplier) external { onlyadmin(); // dsHash -> sha3(DATASOURCE_NAME, PROOF_TYPE); for (uint i=0; i<dsHash.length; i++) { dsources[dsources.length++] = dsHash[i]; price_multiplier[dsHash[i]] = multiplier[i]; } } function multisetProofType(uint[] _proofType, address[] _addr) external { onlyadmin(); for (uint i=0; i<_addr.length; i++) addr_proofType[_addr[i]] = byte(_proofType[i]); } function multisetCustomGasPrice(uint[] _gasPrice, address[] _addr) external { onlyadmin(); for (uint i=0; i<_addr.length; i++) addr_gasPrice[_addr[i]] = _gasPrice[i]; } uint gasprice = 20000000000; function setGasPrice(uint newgasprice) external { onlyadmin(); gasprice = newgasprice; } function setBasePrice(uint new_baseprice) external { //0.001 usd in ether onlyadmin(); baseprice = new_baseprice; for (uint i=0; i<dsources.length; i++) price[dsources[i]] = new_baseprice*price_multiplier[dsources[i]]; } function setBasePrice(uint new_baseprice, bytes proofID) external { //0.001 usd in ether onlyadmin(); baseprice = new_baseprice; for (uint i=0; i<dsources.length; i++) price[dsources[i]] = new_baseprice*price_multiplier[dsources[i]]; } function setOffchainPayment(address _addr, bool _flag) external { if (msg.sender != paymentFlagger) throw; offchainPayment[_addr] = _flag; Emit_OffchainPaymentFlag(_addr, _addr, _flag, _flag); } function withdrawFunds(address _addr) external { onlyadmin(); _addr.send(this.balance); } // unnecessary? //function() {} function Oraclize() { owner = msg.sender; } // Pesudo-modifiers function onlyadmin() private { if (msg.sender != owner) throw; } function costs(string datasource, uint gaslimit) private returns (uint price) { price = getPrice(datasource, gaslimit, msg.sender); if (msg.value >= price){ uint diff = msg.value - price; if (diff > 0) { // added for correct query cost to be returned if(!msg.sender.send(diff)) { throw; } } } else throw; } mapping (address => byte) addr_proofType; mapping (address => uint) addr_gasPrice; uint public baseprice; mapping (bytes32 => uint) price; mapping (bytes32 => uint) price_multiplier; bytes32[] dsources; bytes32[] public randomDS_sessionPubKeysHash; function randomDS_updateSessionPubKeysHash(bytes32[] _newSessionPubKeysHash) external { onlyadmin(); randomDS_sessionPubKeysHash.length = 0; for (uint i=0; i<_newSessionPubKeysHash.length; i++) randomDS_sessionPubKeysHash.push(_newSessionPubKeysHash[i]); } function randomDS_getSessionPubKeyHash() external constant returns (bytes32) { uint i = uint(sha3(reqc[msg.sender]))%randomDS_sessionPubKeysHash.length; return randomDS_sessionPubKeysHash[i]; } function setProofType(byte _proofType) external { addr_proofType[msg.sender] = _proofType; } function setCustomGasPrice(uint _gasPrice) external { addr_gasPrice[msg.sender] = _gasPrice; } function getPrice(string _datasource) public returns (uint _dsprice) { return getPrice(_datasource, msg.sender); } function getPrice(string _datasource, uint _gaslimit) public returns (uint _dsprice) { return getPrice(_datasource, _gaslimit, msg.sender); } function getPrice(string _datasource, address _addr) private returns (uint _dsprice) { return getPrice(_datasource, 200000, _addr); } function getPrice(string _datasource, uint _gaslimit, address _addr) private returns (uint _dsprice) { uint gasprice_ = addr_gasPrice[_addr]; if ( (offchainPayment[_addr]) ||( (_gaslimit <= 200000)&& (reqc[_addr] == 0)&& (gasprice_ <= gasprice)&& (tx.origin != cbAddress()) ) ) return 0; if (gasprice_ == 0) gasprice_ = gasprice; _dsprice = price[sha3(_datasource, addr_proofType[_addr])]; _dsprice += _gaslimit*gasprice_; return _dsprice; } function getCodeSize(address _addr) private constant returns(uint _size) { assembly { _size := extcodesize(_addr) } } function query(string _datasource, string _arg) payable external returns (bytes32 _id) { return query1(0, _datasource, _arg, 200000); } function query1(string _datasource, string _arg) payable external returns (bytes32 _id) { return query1(0, _datasource, _arg, 200000); } function query2(string _datasource, string _arg1, string _arg2) payable external returns (bytes32 _id) { return query2(0, _datasource, _arg1, _arg2, 200000); } function queryN(string _datasource, bytes _args) payable external returns (bytes32 _id) { return queryN(0, _datasource, _args, 200000); } function query(uint _timestamp, string _datasource, string _arg) payable external returns (bytes32 _id) { return query1(_timestamp, _datasource, _arg, 200000); } function query1(uint _timestamp, string _datasource, string _arg) payable external returns (bytes32 _id) { return query1(_timestamp, _datasource, _arg, 200000); } function query2(uint _timestamp, string _datasource, string _arg1, string _arg2) payable external returns (bytes32 _id) { return query2(_timestamp, _datasource, _arg1, _arg2, 200000); } function queryN(uint _timestamp, string _datasource, bytes _args) payable external returns (bytes32 _id) { return queryN(_timestamp, _datasource, _args, 200000); } /* Needless? function query(uint _timestamp, string _datasource, string _arg, uint _gaslimit) payable external returns (bytes32 _id) { return query1(_timestamp, _datasource, _arg, _gaslimit); } */ function query_withGasLimit(uint _timestamp, string _datasource, string _arg, uint _gaslimit) payable external returns (bytes32 _id) { return query1(_timestamp, _datasource, _arg, _gaslimit); } function query1_withGasLimit(uint _timestamp, string _datasource, string _arg, uint _gaslimit) payable external returns (bytes32 _id) { return query1(_timestamp, _datasource, _arg, _gaslimit); } function query2_withGasLimit(uint _timestamp, string _datasource, string _arg1, string _arg2, uint _gaslimit) payable external returns (bytes32 _id) { return query2(_timestamp, _datasource, _arg1, _arg2, _gaslimit); } function queryN_withGasLimit(uint _timestamp, string _datasource, bytes _args, uint _gaslimit) payable external returns (bytes32 _id) { return queryN(_timestamp, _datasource, _args, _gaslimit); } function query1(uint _timestamp, string _datasource, string _arg, uint _gaslimit) payable public returns (bytes32 _id) { costs(_datasource, _gaslimit); if ((_timestamp > now+3600*24*60)||(_gaslimit > block.gaslimit)) throw; _id = sha3(this, msg.sender, reqc[msg.sender]); reqc[msg.sender]++; Log1(msg.sender, _id, _timestamp, _datasource, _arg, _gaslimit, addr_proofType[msg.sender], addr_gasPrice[msg.sender]); return _id; } function query2(uint _timestamp, string _datasource, string _arg1, string _arg2, uint _gaslimit) payable public returns (bytes32 _id) { costs(_datasource, _gaslimit); if ((_timestamp > now+3600*24*60)||(_gaslimit > block.gaslimit)) throw; _id = sha3(this, msg.sender, reqc[msg.sender]); reqc[msg.sender]++; Log2(msg.sender, _id, _timestamp, _datasource, _arg1, _arg2, _gaslimit, addr_proofType[msg.sender], addr_gasPrice[msg.sender]); return _id; } function queryN(uint _timestamp, string _datasource, bytes _args, uint _gaslimit) payable public returns (bytes32 _id) { costs(_datasource, _gaslimit); if ((_timestamp > now+3600*24*60)||(_gaslimit > block.gaslimit)) throw; _id = sha3(this, msg.sender, reqc[msg.sender]); reqc[msg.sender]++; LogN(msg.sender, _id, _timestamp, _datasource, _args, _gaslimit, addr_proofType[msg.sender], addr_gasPrice[msg.sender]); return _id; } function query1_fnc(uint _timestamp, string _datasource, string _arg, function() external _fnc, uint _gaslimit) payable public returns (bytes32 _id) { costs(_datasource, _gaslimit); if ((_timestamp > now+3600*24*60)||(_gaslimit > block.gaslimit)||address(_fnc) != msg.sender) throw; _id = sha3(this, msg.sender, reqc[msg.sender]); reqc[msg.sender]++; Log1_fnc(msg.sender, _id, _timestamp, _datasource, _arg, _fnc, _gaslimit, addr_proofType[msg.sender], addr_gasPrice[msg.sender]); return _id; } function query2_fnc(uint _timestamp, string _datasource, string _arg1, string _arg2, function() external _fnc, uint _gaslimit) payable public returns (bytes32 _id) { costs(_datasource, _gaslimit); if ((_timestamp > now+3600*24*60)||(_gaslimit > block.gaslimit)||address(_fnc) != msg.sender) throw; _id = sha3(this, msg.sender, reqc[msg.sender]); reqc[msg.sender]++; Log2_fnc(msg.sender, _id, _timestamp, _datasource, _arg1, _arg2, _fnc, _gaslimit, addr_proofType[msg.sender], addr_gasPrice[msg.sender]); return _id; } function queryN_fnc(uint _timestamp, string _datasource, bytes _args, function() external _fnc, uint _gaslimit) payable public returns (bytes32 _id) { costs(_datasource, _gaslimit); if ((_timestamp > now+3600*24*60)||(_gaslimit > block.gaslimit)||address(_fnc) != msg.sender) throw; _id = sha3(this, msg.sender, reqc[msg.sender]); reqc[msg.sender]++; LogN_fnc(msg.sender, _id, _timestamp, _datasource, _args, _fnc, _gaslimit, addr_proofType[msg.sender], addr_gasPrice[msg.sender]); return _id; } }
File 2 of 2: OraclizeAddrResolver
/* Copyright (c) 2015-2016 Oraclize SRL Copyright (c) 2016 Oraclize LTD */ contract OraclizeAddrResolver { address public addr; address owner; function OraclizeAddrResolver(){ owner = msg.sender; } function changeOwner(address newowner){ if (msg.sender != owner) throw; owner = newowner; } function getAddress() returns (address oaddr){ return addr; } function setAddr(address newaddr){ if (msg.sender != owner) throw; addr = newaddr; } }