-
Notifications
You must be signed in to change notification settings - Fork 2
/
Public_Oracle.sol
71 lines (59 loc) · 2.16 KB
/
Public_Oracle.sol
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
pragma solidity ^0.4.17;
import "github.com/oraclize/ethereum-api/oraclizeAPI.sol";
contract Oracle is usingOraclize{
/*Variables*/
//Private queryId for Oraclize callback
bytes32 private queryID;
//Mapping of documents stored in the oracle
mapping(uint => uint) public oracle_values;
mapping(uint => bool) public queried;
/*Events*/
event DocumentStored(uint _key, uint _value);
event newOraclizeQuery(string description);
/*Functions*/
/*
RetrieveData - Returns stored value by given key
@param "_date": Daily unix timestamp of key storing value (GMT 00:00:00)
*/
function RetrieveData(uint _date) public constant returns (uint data) {
uint value = oracle_values[_date];
return value;
}
/*
PushData - Sends an Oraclize query for entered API
*/
function PushData() public {
uint _key = now - (now % 86400);
require(queried[_key] == false);
if (oraclize_getPrice("URL") > this.balance) {
newOraclizeQuery("Oraclize query was NOT sent, please add some ETH to cover for the query fee");
} else {
newOraclizeQuery("Oraclize queries sent");
queryID = oraclize_query("URL", "json(https://api.gdax.com/products/BTC-USD/ticker).price");
queried[_key] = true;
}
}
/*
_callback - used by Oraclize to return value of PushData API call
@param "_oraclizeID": unique oraclize identifier of call
@param "_result": Result of API call in string format
*/
function __callback(bytes32 _oraclizeID, string _result) {
require(msg.sender == oraclize_cbAddress() && _oraclizeID == queryID);
uint _value = parseInt(_result,3);
uint _key = now - (now % 86400);
oracle_values[_key] = _value;
DocumentStored(_key, _value);
}
/*
fund - Allows the contract to be funded in order to pay for oraclize calls
*/
function fund() public payable {}
/*
getQuery - Returns true or false based upon whether an API query has been initialized (or completed) for given date
@param "_date": Daily unix timestamp of key storing value (GMT 00:00:00)
*/
function getQuery(uint _date) public view returns(bool _isValue){
return queried[_date];
}
}