-
Notifications
You must be signed in to change notification settings - Fork 1
/
lib.rs
203 lines (174 loc) · 5.77 KB
/
lib.rs
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
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
//
// SYMBOLS DIAAPI TEST CONTRACT/EXAMPLE
//
use near_sdk::borsh::{self, BorshDeserialize, BorshSerialize};
use near_sdk::serde::{Deserialize, Serialize};
use near_sdk::{env, near_bindgen, Gas};
use near_sdk::json_types::{U128};
#[global_allocator]
static ALLOC: near_sdk::wee_alloc::WeeAlloc = near_sdk::wee_alloc::WeeAlloc::INIT;
const ONE_NEAR:u128 = 1_000_000_000_000_000_000_000_000;
const ONE_NEAR_CENT:u128 = ONE_NEAR/100;
const DEPOSIT_FOR_REQUEST: u128 = ONE_NEAR_CENT; // amount that clients have to attach to make a request to the api
const GAS_FOR_REQUEST: Gas = 50_000_000_000_000;
const DIA_GATEWAY_ACCOUNT_ID: &str = "contract.dia.oracles.testnet";
const SIGNER_DIA_ORACLES_ACCOUNT_ID:&str = "dia.oracles.testnet";
#[near_bindgen]
#[derive(BorshDeserialize, BorshSerialize)]
pub struct SymbolsTestContract {
pub request_id: u128,
pub callback_response: Response
}
#[derive(Serialize)]
#[serde(crate = "near_sdk::serde")]
pub struct DiaGatewayRequestArgs {
request_id: U128,
data_key: String,
data_item: String,
callback: String
}
#[derive(Deserialize, Serialize, BorshDeserialize, BorshSerialize, Clone)]
#[serde(crate = "near_sdk::serde")]
#[serde(untagged)]
pub enum ResponseData{
Symbols (SymbolsData),
None
}
#[derive(Serialize, BorshDeserialize, BorshSerialize, Clone)]
#[serde(crate = "near_sdk::serde")]
pub struct Response{
request_id: U128,
err: String,
data: ResponseData,
}
#[derive(Deserialize, Serialize, BorshDeserialize, BorshSerialize, Clone)]
#[serde(crate = "near_sdk::serde")]
#[allow(non_snake_case)]
pub struct SymbolsData {
Symbols: Vec<String>
}
impl Default for SymbolsTestContract {
fn default() -> Self {
env::panic(b"This contract should be initialized before usage")
}
}
#[near_bindgen]
impl SymbolsTestContract {
#[init]
pub fn new()-> Self{
/* Prevent re-initializations */
assert!(!env::state_exists(), "This contract is already initialized");
return Self {
request_id: 100,
callback_response: Response{
request_id: 0.into(),
err: String::new(),
data: ResponseData::None
}
};
}
/******************/
/* Config methods */
/******************/
///Set request_id to a supplied value
pub fn set_id(&mut self, request_id: U128){
self.request_id = request_id.0;
}
///Get request_id
pub fn get_id(&self)-> U128{
return self.request_id.into();
}
/****************/
/* Test methods */
/****************/
///Make a request to the dia-gateway smart contract
#[payable]
pub fn make_request(&mut self, data_item: String)-> near_sdk::Promise{
self.request_id+=1;
return near_sdk::Promise::new(String::from(DIA_GATEWAY_ACCOUNT_ID)).function_call(
b"request".to_vec(),
near_sdk::serde_json::to_vec(&DiaGatewayRequestArgs {
request_id: U128::from(self.request_id),
data_key: String::from("symbols"),
data_item: data_item,
callback: String::from("callback")
}).unwrap(),
DEPOSIT_FOR_REQUEST,
GAS_FOR_REQUEST
);
}
///View the dia-adapter response to the contract's request
pub fn get_callback_response(&self)-> Response{
return self.callback_response.clone();
}
///Clear cached response
pub fn clear_callback_response(&mut self) {
self.callback_response.data = ResponseData::None; //Clear
}
/***********************/
/* Dia adapter methods */
/***********************/
///Callback to receive dia-api data
pub fn callback(&mut self, request_id:U128, err: String, data: ResponseData){
//verify data origin
assert!(env::signer_account_id() == SIGNER_DIA_ORACLES_ACCOUNT_ID);
//check for errrors in the request
assert!(err.len()==0,err);
//use symbols
match &data {
ResponseData::None => env::log("empty data".as_bytes()),
ResponseData::Symbols(x)=>env::log(format!("Symbols {:?}", x.Symbols).as_bytes())
}
//store last response
self.callback_response = Response {
request_id: request_id,
err: err,
data: data
};
}
}
/**************/
/* Unit tests */
/**************/
#[cfg(test)]
mod tests {
use super::*;
use near_sdk::MockedBlockchain;
use near_sdk::{testing_env, VMContext};
/// Set the contract context
pub fn initialize() {
let context = get_context(String::from("client.testnet"), 10);
testing_env!(context);
}
/// Defines the context for the contract
fn get_context(predecessor_account_id: String, storage_usage: u64) -> VMContext {
VMContext {
current_account_id: "dia.oracles.testnet".to_string(),
signer_account_id: "dia.oracles.testnet".to_string(),
signer_account_pk: vec![0, 1, 2],
predecessor_account_id,
input: vec![],
block_index: 0,
block_timestamp: 0,
account_balance: 0,
account_locked_balance: 0,
storage_usage,
attached_deposit: 0,
prepaid_gas: 10u64.pow(18),
random_seed: vec![0, 1, 2],
is_view: false,
output_data_receivers: vec![],
epoch_height: 19,
}
}
///Test get_id and set_id methods
#[test]
fn test_id() {
initialize();
/* Initialize contract */
let mut contract = super::SymbolsTestContract::new();
let id: U128 = 13123123.into();
contract.set_id(id.clone());
assert_eq!(contract.get_id(), id, "Contract id is different from the expected");
}
}