@ichidao/ichi-vaults-sdk 0.0.20 → 0.0.21
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +41 -4
- package/dist/src/functions/calculateDtr.d.ts +3 -0
- package/dist/src/functions/calculateDtr.js +220 -0
- package/dist/src/functions/calculateDtr.js.map +1 -0
- package/dist/src/functions/calculateFees.d.ts +2 -1
- package/dist/src/functions/calculateFees.js +20 -121
- package/dist/src/functions/calculateFees.js.map +1 -1
- package/dist/src/functions/priceFromPool.d.ts +7 -0
- package/dist/src/functions/priceFromPool.js +199 -0
- package/dist/src/functions/priceFromPool.js.map +1 -0
- package/dist/src/functions/vaultEvents.d.ts +6 -0
- package/dist/src/functions/{fees.js → vaultEvents.js} +132 -4
- package/dist/src/functions/vaultEvents.js.map +1 -0
- package/dist/src/graphql/queries.d.ts +2 -0
- package/dist/src/graphql/queries.js +8 -4
- package/dist/src/graphql/queries.js.map +1 -1
- package/dist/src/index.cjs.js +2 -1
- package/dist/src/index.d.ts +1 -0
- package/dist/src/index.esm.js +2 -1
- package/dist/src/index.js +1 -0
- package/dist/src/index.js.map +1 -1
- package/dist/src/src/functions/calculateDtr.d.ts +3 -0
- package/dist/src/src/functions/calculateFees.d.ts +2 -1
- package/dist/src/src/functions/priceFromPool.d.ts +7 -0
- package/dist/src/src/functions/vaultEvents.d.ts +6 -0
- package/dist/src/src/graphql/queries.d.ts +2 -0
- package/dist/src/src/index.d.ts +1 -0
- package/dist/src/src/types/index.d.ts +19 -0
- package/dist/src/src/types/vaultQueryData.d.ts +7 -1
- package/dist/src/types/index.d.ts +19 -0
- package/dist/src/types/vaultQueryData.d.ts +7 -1
- package/package.json +1 -1
- package/dist/src/functions/fees.d.ts +0 -4
- package/dist/src/functions/fees.js.map +0 -1
- package/dist/src/src/functions/fees.d.ts +0 -4
@@ -0,0 +1,199 @@
|
|
1
|
+
"use strict";
|
2
|
+
/* eslint-disable no-redeclare */
|
3
|
+
/* eslint-disable import/prefer-default-export */
|
4
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
5
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
6
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
7
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
8
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
9
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
10
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
11
|
+
});
|
12
|
+
};
|
13
|
+
var __generator = (this && this.__generator) || function (thisArg, body) {
|
14
|
+
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
|
15
|
+
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
16
|
+
function verb(n) { return function (v) { return step([n, v]); }; }
|
17
|
+
function step(op) {
|
18
|
+
if (f) throw new TypeError("Generator is already executing.");
|
19
|
+
while (g && (g = 0, op[0] && (_ = 0)), _) try {
|
20
|
+
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
|
21
|
+
if (y = 0, t) op = [op[0] & 2, t.value];
|
22
|
+
switch (op[0]) {
|
23
|
+
case 0: case 1: t = op; break;
|
24
|
+
case 4: _.label++; return { value: op[1], done: false };
|
25
|
+
case 5: _.label++; y = op[1]; op = [0]; continue;
|
26
|
+
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
27
|
+
default:
|
28
|
+
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
29
|
+
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
30
|
+
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
31
|
+
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
32
|
+
if (t[2]) _.ops.pop();
|
33
|
+
_.trys.pop(); continue;
|
34
|
+
}
|
35
|
+
op = body.call(thisArg, _);
|
36
|
+
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
37
|
+
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
38
|
+
}
|
39
|
+
};
|
40
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
41
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
42
|
+
};
|
43
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
44
|
+
exports.getVaultTvl = exports.getCurrentDtr = exports.getCurrPrice = exports.getSqrtPriceFromPool = void 0;
|
45
|
+
var types_1 = require("../types");
|
46
|
+
// eslint-disable-next-line import/no-cycle
|
47
|
+
var vault_1 = require("./vault");
|
48
|
+
var balances_1 = require("./balances");
|
49
|
+
var getPrice_1 = __importDefault(require("../utils/getPrice"));
|
50
|
+
var contracts_1 = require("../contracts");
|
51
|
+
var addresses_1 = __importDefault(require("../utils/config/addresses"));
|
52
|
+
function getSqrtPriceFromPool(vaultAddress, jsonProvider, dex) {
|
53
|
+
var _a;
|
54
|
+
return __awaiter(this, void 0, void 0, function () {
|
55
|
+
var chainId, vault, vaultContract, poolAddress, poolContract, globalState, poolContract, slot0, e_1;
|
56
|
+
return __generator(this, function (_b) {
|
57
|
+
switch (_b.label) {
|
58
|
+
case 0: return [4 /*yield*/, jsonProvider.getNetwork()];
|
59
|
+
case 1:
|
60
|
+
chainId = (_b.sent()).chainId;
|
61
|
+
if (!Object.values(types_1.SupportedChainId).includes(chainId)) {
|
62
|
+
throw new Error("Unsupported chainId: ".concat(chainId !== null && chainId !== void 0 ? chainId : 'undefined'));
|
63
|
+
}
|
64
|
+
return [4 /*yield*/, (0, vault_1.getIchiVaultInfo)(chainId, dex, vaultAddress, jsonProvider)];
|
65
|
+
case 2:
|
66
|
+
vault = _b.sent();
|
67
|
+
if (!vault)
|
68
|
+
throw new Error("Vault ".concat(vaultAddress, " not found on chain ").concat(chainId, " and dex ").concat(dex));
|
69
|
+
_b.label = 3;
|
70
|
+
case 3:
|
71
|
+
_b.trys.push([3, 9, , 10]);
|
72
|
+
vaultContract = (0, contracts_1.getIchiVaultContract)(vaultAddress, jsonProvider);
|
73
|
+
return [4 /*yield*/, vaultContract.pool()];
|
74
|
+
case 4:
|
75
|
+
poolAddress = _b.sent();
|
76
|
+
if (!((_a = addresses_1.default[chainId][dex]) === null || _a === void 0 ? void 0 : _a.isAlgebra)) return [3 /*break*/, 6];
|
77
|
+
poolContract = (0, contracts_1.getAlgebraPoolContract)(poolAddress, jsonProvider);
|
78
|
+
return [4 /*yield*/, poolContract.globalState()];
|
79
|
+
case 5:
|
80
|
+
globalState = _b.sent();
|
81
|
+
return [2 /*return*/, globalState.price];
|
82
|
+
case 6:
|
83
|
+
poolContract = (0, contracts_1.getUniswapV3PoolContract)(poolAddress, jsonProvider);
|
84
|
+
return [4 /*yield*/, poolContract.slot0()];
|
85
|
+
case 7:
|
86
|
+
slot0 = _b.sent();
|
87
|
+
return [2 /*return*/, slot0[0]];
|
88
|
+
case 8: return [3 /*break*/, 10];
|
89
|
+
case 9:
|
90
|
+
e_1 = _b.sent();
|
91
|
+
console.error("Could not get price from vault ".concat(vaultAddress, " "));
|
92
|
+
throw e_1;
|
93
|
+
case 10: return [2 /*return*/];
|
94
|
+
}
|
95
|
+
});
|
96
|
+
});
|
97
|
+
}
|
98
|
+
exports.getSqrtPriceFromPool = getSqrtPriceFromPool;
|
99
|
+
// current price in pool of scarse token in deposit tokens
|
100
|
+
function getCurrPrice(vaultAddress, jsonProvider, dex, isVaultInverted, token0decimals, token1decimals) {
|
101
|
+
return __awaiter(this, void 0, void 0, function () {
|
102
|
+
var chainId, vault, sqrtPrice, depositTokenDecimals, scarseTokenDecimals, price, e_2;
|
103
|
+
return __generator(this, function (_a) {
|
104
|
+
switch (_a.label) {
|
105
|
+
case 0: return [4 /*yield*/, jsonProvider.getNetwork()];
|
106
|
+
case 1:
|
107
|
+
chainId = (_a.sent()).chainId;
|
108
|
+
if (!Object.values(types_1.SupportedChainId).includes(chainId)) {
|
109
|
+
throw new Error("Unsupported chainId: ".concat(chainId !== null && chainId !== void 0 ? chainId : 'undefined'));
|
110
|
+
}
|
111
|
+
return [4 /*yield*/, (0, vault_1.getIchiVaultInfo)(chainId, dex, vaultAddress, jsonProvider)];
|
112
|
+
case 2:
|
113
|
+
vault = _a.sent();
|
114
|
+
if (!vault)
|
115
|
+
throw new Error("Vault ".concat(vaultAddress, " not found on chain ").concat(chainId, " and dex ").concat(dex));
|
116
|
+
_a.label = 3;
|
117
|
+
case 3:
|
118
|
+
_a.trys.push([3, 5, , 6]);
|
119
|
+
return [4 /*yield*/, getSqrtPriceFromPool(vaultAddress, jsonProvider, dex)];
|
120
|
+
case 4:
|
121
|
+
sqrtPrice = _a.sent();
|
122
|
+
depositTokenDecimals = isVaultInverted ? token1decimals : token0decimals;
|
123
|
+
scarseTokenDecimals = isVaultInverted ? token0decimals : token1decimals;
|
124
|
+
price = (0, getPrice_1.default)(isVaultInverted, sqrtPrice, depositTokenDecimals, scarseTokenDecimals, 15);
|
125
|
+
return [2 /*return*/, price];
|
126
|
+
case 5:
|
127
|
+
e_2 = _a.sent();
|
128
|
+
console.error("Could not get price from vault ".concat(vaultAddress, " "));
|
129
|
+
throw e_2;
|
130
|
+
case 6: return [2 /*return*/];
|
131
|
+
}
|
132
|
+
});
|
133
|
+
});
|
134
|
+
}
|
135
|
+
exports.getCurrPrice = getCurrPrice;
|
136
|
+
// total amounts at deposit or withdrawal in deposit tokens
|
137
|
+
function getCurrentDtr(vaultAddress, jsonProvider, dex, isVaultInverted, token0decimals, token1decimals) {
|
138
|
+
return __awaiter(this, void 0, void 0, function () {
|
139
|
+
var chainId, vault, totalAmounts, price, dtr;
|
140
|
+
return __generator(this, function (_a) {
|
141
|
+
switch (_a.label) {
|
142
|
+
case 0: return [4 /*yield*/, jsonProvider.getNetwork()];
|
143
|
+
case 1:
|
144
|
+
chainId = (_a.sent()).chainId;
|
145
|
+
if (!Object.values(types_1.SupportedChainId).includes(chainId)) {
|
146
|
+
throw new Error("Unsupported chainId: ".concat(chainId !== null && chainId !== void 0 ? chainId : 'undefined'));
|
147
|
+
}
|
148
|
+
return [4 /*yield*/, (0, vault_1.getIchiVaultInfo)(chainId, dex, vaultAddress, jsonProvider)];
|
149
|
+
case 2:
|
150
|
+
vault = _a.sent();
|
151
|
+
if (!vault)
|
152
|
+
throw new Error("Vault ".concat(vaultAddress, " not found on chain ").concat(chainId, " and dex ").concat(dex));
|
153
|
+
return [4 /*yield*/, (0, balances_1.getTotalAmounts)(vaultAddress, jsonProvider, dex)];
|
154
|
+
case 3:
|
155
|
+
totalAmounts = _a.sent();
|
156
|
+
return [4 /*yield*/, getCurrPrice(vaultAddress, jsonProvider, dex, isVaultInverted, token0decimals, token1decimals)];
|
157
|
+
case 4:
|
158
|
+
price = _a.sent();
|
159
|
+
dtr = !isVaultInverted
|
160
|
+
? (Number(totalAmounts.total0) / (Number(totalAmounts.total0) + Number(totalAmounts.total1) * price)) * 100
|
161
|
+
: (Number(totalAmounts.total1) / (Number(totalAmounts.total1) + Number(totalAmounts.total0) * price)) * 100;
|
162
|
+
return [2 /*return*/, dtr];
|
163
|
+
}
|
164
|
+
});
|
165
|
+
});
|
166
|
+
}
|
167
|
+
exports.getCurrentDtr = getCurrentDtr;
|
168
|
+
function getVaultTvl(vaultAddress, jsonProvider, dex, isVaultInverted, token0decimals, token1decimals) {
|
169
|
+
return __awaiter(this, void 0, void 0, function () {
|
170
|
+
var chainId, vault, totalAmounts, price, tvl;
|
171
|
+
return __generator(this, function (_a) {
|
172
|
+
switch (_a.label) {
|
173
|
+
case 0: return [4 /*yield*/, jsonProvider.getNetwork()];
|
174
|
+
case 1:
|
175
|
+
chainId = (_a.sent()).chainId;
|
176
|
+
if (!Object.values(types_1.SupportedChainId).includes(chainId)) {
|
177
|
+
throw new Error("Unsupported chainId: ".concat(chainId !== null && chainId !== void 0 ? chainId : 'undefined'));
|
178
|
+
}
|
179
|
+
return [4 /*yield*/, (0, vault_1.getIchiVaultInfo)(chainId, dex, vaultAddress, jsonProvider)];
|
180
|
+
case 2:
|
181
|
+
vault = _a.sent();
|
182
|
+
if (!vault)
|
183
|
+
throw new Error("Vault ".concat(vaultAddress, " not found on chain ").concat(chainId, " and dex ").concat(dex));
|
184
|
+
return [4 /*yield*/, (0, balances_1.getTotalAmounts)(vaultAddress, jsonProvider, dex)];
|
185
|
+
case 3:
|
186
|
+
totalAmounts = _a.sent();
|
187
|
+
return [4 /*yield*/, getCurrPrice(vaultAddress, jsonProvider, dex, isVaultInverted, token0decimals, token1decimals)];
|
188
|
+
case 4:
|
189
|
+
price = _a.sent();
|
190
|
+
tvl = !isVaultInverted
|
191
|
+
? Number(totalAmounts.total0) + Number(totalAmounts.total1) * price
|
192
|
+
: Number(totalAmounts.total1) + Number(totalAmounts.total0) * price;
|
193
|
+
return [2 /*return*/, tvl];
|
194
|
+
}
|
195
|
+
});
|
196
|
+
});
|
197
|
+
}
|
198
|
+
exports.getVaultTvl = getVaultTvl;
|
199
|
+
//# sourceMappingURL=priceFromPool.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"priceFromPool.js","sourceRoot":"","sources":["../../../src/functions/priceFromPool.ts"],"names":[],"mappings":"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"}
|
@@ -0,0 +1,6 @@
|
|
1
|
+
import { JsonRpcProvider } from '@ethersproject/providers';
|
2
|
+
import { SupportedDex, Fees, VaultTransactionEvent } from '../types';
|
3
|
+
export declare function getRebalances(vaultAddress: string, jsonProvider: JsonRpcProvider, dex: SupportedDex, days?: number): Promise<Fees[]>;
|
4
|
+
export declare function getFeesCollectedEvents(vaultAddress: string, jsonProvider: JsonRpcProvider, dex: SupportedDex, days?: number): Promise<Fees[]>;
|
5
|
+
export declare function getDeposits(vaultAddress: string, jsonProvider: JsonRpcProvider, dex: SupportedDex, days?: number): Promise<VaultTransactionEvent[]>;
|
6
|
+
export declare function getWithdraws(vaultAddress: string, jsonProvider: JsonRpcProvider, dex: SupportedDex, days?: number): Promise<VaultTransactionEvent[]>;
|
@@ -39,7 +39,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
39
39
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
40
40
|
};
|
41
41
|
Object.defineProperty(exports, "__esModule", { value: true });
|
42
|
-
exports.getFeesCollectedEvents = exports.getRebalances = void 0;
|
42
|
+
exports.getWithdraws = exports.getDeposits = exports.getFeesCollectedEvents = exports.getRebalances = void 0;
|
43
43
|
/* eslint-disable camelcase */
|
44
44
|
/* eslint-disable no-await-in-loop */
|
45
45
|
/* eslint-disable radix */
|
@@ -50,7 +50,6 @@ var constants_1 = require("../graphql/constants");
|
|
50
50
|
var queries_1 = require("../graphql/queries");
|
51
51
|
var timestamps_1 = __importDefault(require("../utils/timestamps"));
|
52
52
|
var promises = {};
|
53
|
-
// eslint-disable-next-line import/prefer-default-export
|
54
53
|
function getRebalances(vaultAddress, jsonProvider, dex, days) {
|
55
54
|
var _a;
|
56
55
|
return __awaiter(this, void 0, void 0, function () {
|
@@ -116,7 +115,6 @@ function getRebalances(vaultAddress, jsonProvider, dex, days) {
|
|
116
115
|
});
|
117
116
|
}
|
118
117
|
exports.getRebalances = getRebalances;
|
119
|
-
// eslint-disable-next-line import/prefer-default-export
|
120
118
|
function getFeesCollectedEvents(vaultAddress, jsonProvider, dex, days) {
|
121
119
|
var _a, _b;
|
122
120
|
return __awaiter(this, void 0, void 0, function () {
|
@@ -186,4 +184,134 @@ function getFeesCollectedEvents(vaultAddress, jsonProvider, dex, days) {
|
|
186
184
|
});
|
187
185
|
}
|
188
186
|
exports.getFeesCollectedEvents = getFeesCollectedEvents;
|
189
|
-
|
187
|
+
function getDeposits(vaultAddress, jsonProvider, dex, days) {
|
188
|
+
var _a;
|
189
|
+
return __awaiter(this, void 0, void 0, function () {
|
190
|
+
var chainId, key, url, currTimestamp, startTimestamp, depositEvents_1, endOfData, page, result;
|
191
|
+
return __generator(this, function (_b) {
|
192
|
+
switch (_b.label) {
|
193
|
+
case 0: return [4 /*yield*/, jsonProvider.getNetwork()];
|
194
|
+
case 1:
|
195
|
+
chainId = (_b.sent()).chainId;
|
196
|
+
if (!Object.values(types_1.SupportedChainId).includes(chainId)) {
|
197
|
+
throw new Error("Unsupported chainId: ".concat(chainId !== null && chainId !== void 0 ? chainId : 'undefined'));
|
198
|
+
}
|
199
|
+
key = "".concat(chainId + vaultAddress + days, "-deposits");
|
200
|
+
if (Object.prototype.hasOwnProperty.call(promises, key))
|
201
|
+
return [2 /*return*/, promises[key]];
|
202
|
+
url = (_a = constants_1.graphUrls[chainId][dex]) === null || _a === void 0 ? void 0 : _a.url;
|
203
|
+
if (!url)
|
204
|
+
throw new Error("Unsupported DEX ".concat(dex, " on chain ").concat(chainId));
|
205
|
+
currTimestamp = Date.now();
|
206
|
+
startTimestamp = days
|
207
|
+
? parseInt(((currTimestamp - (0, timestamps_1.default)(days)) / 1000).toString()).toString()
|
208
|
+
: '0';
|
209
|
+
if (!(url === 'none' && jsonProvider)) return [3 /*break*/, 2];
|
210
|
+
throw new Error("Unsupported function for DEX ".concat(dex, " on chain ").concat(chainId));
|
211
|
+
case 2:
|
212
|
+
depositEvents_1 = [];
|
213
|
+
endOfData = false;
|
214
|
+
page = 0;
|
215
|
+
_b.label = 3;
|
216
|
+
case 3:
|
217
|
+
if (!!endOfData) return [3 /*break*/, 5];
|
218
|
+
return [4 /*yield*/, (0, graphql_request_1.request)(url, (0, queries_1.vaultDepositsQuery)(page), {
|
219
|
+
vaultAddress: vaultAddress,
|
220
|
+
createdAtTimestamp_gt: startTimestamp,
|
221
|
+
})
|
222
|
+
.then(function (_a) {
|
223
|
+
var vaultDeposits = _a.vaultDeposits;
|
224
|
+
return vaultDeposits;
|
225
|
+
})
|
226
|
+
.catch(function (err) {
|
227
|
+
console.error(err);
|
228
|
+
})];
|
229
|
+
case 4:
|
230
|
+
result = _b.sent();
|
231
|
+
if (result) {
|
232
|
+
depositEvents_1.push.apply(depositEvents_1, result);
|
233
|
+
page += 1;
|
234
|
+
if (result.length < 1000) {
|
235
|
+
endOfData = true;
|
236
|
+
}
|
237
|
+
}
|
238
|
+
else {
|
239
|
+
endOfData = true;
|
240
|
+
}
|
241
|
+
return [3 /*break*/, 3];
|
242
|
+
case 5:
|
243
|
+
promises[key] = new Promise(function (resolve) { return resolve(depositEvents_1); }).finally(function () {
|
244
|
+
return setTimeout(function () { return delete promises[key]; }, 2 * 60 * 100 /* 2 mins */);
|
245
|
+
});
|
246
|
+
return [2 /*return*/, depositEvents_1];
|
247
|
+
}
|
248
|
+
});
|
249
|
+
});
|
250
|
+
}
|
251
|
+
exports.getDeposits = getDeposits;
|
252
|
+
function getWithdraws(vaultAddress, jsonProvider, dex, days) {
|
253
|
+
var _a;
|
254
|
+
return __awaiter(this, void 0, void 0, function () {
|
255
|
+
var chainId, key, url, currTimestamp, startTimestamp, withdrawEvents_1, endOfData, page, result;
|
256
|
+
return __generator(this, function (_b) {
|
257
|
+
switch (_b.label) {
|
258
|
+
case 0: return [4 /*yield*/, jsonProvider.getNetwork()];
|
259
|
+
case 1:
|
260
|
+
chainId = (_b.sent()).chainId;
|
261
|
+
if (!Object.values(types_1.SupportedChainId).includes(chainId)) {
|
262
|
+
throw new Error("Unsupported chainId: ".concat(chainId !== null && chainId !== void 0 ? chainId : 'undefined'));
|
263
|
+
}
|
264
|
+
key = "".concat(chainId + vaultAddress + days, "-withdraws");
|
265
|
+
if (Object.prototype.hasOwnProperty.call(promises, key))
|
266
|
+
return [2 /*return*/, promises[key]];
|
267
|
+
url = (_a = constants_1.graphUrls[chainId][dex]) === null || _a === void 0 ? void 0 : _a.url;
|
268
|
+
if (!url)
|
269
|
+
throw new Error("Unsupported DEX ".concat(dex, " on chain ").concat(chainId));
|
270
|
+
currTimestamp = Date.now();
|
271
|
+
startTimestamp = days
|
272
|
+
? parseInt(((currTimestamp - (0, timestamps_1.default)(days)) / 1000).toString()).toString()
|
273
|
+
: '0';
|
274
|
+
if (!(url === 'none' && jsonProvider)) return [3 /*break*/, 2];
|
275
|
+
throw new Error("Unsupported function for DEX ".concat(dex, " on chain ").concat(chainId));
|
276
|
+
case 2:
|
277
|
+
withdrawEvents_1 = [];
|
278
|
+
endOfData = false;
|
279
|
+
page = 0;
|
280
|
+
_b.label = 3;
|
281
|
+
case 3:
|
282
|
+
if (!!endOfData) return [3 /*break*/, 5];
|
283
|
+
return [4 /*yield*/, (0, graphql_request_1.request)(url, (0, queries_1.vaultWithdrawsQuery)(page), {
|
284
|
+
vaultAddress: vaultAddress,
|
285
|
+
createdAtTimestamp_gt: startTimestamp,
|
286
|
+
})
|
287
|
+
.then(function (_a) {
|
288
|
+
var vaultWithdraws = _a.vaultWithdraws;
|
289
|
+
return vaultWithdraws;
|
290
|
+
})
|
291
|
+
.catch(function (err) {
|
292
|
+
console.error(err);
|
293
|
+
})];
|
294
|
+
case 4:
|
295
|
+
result = _b.sent();
|
296
|
+
if (result) {
|
297
|
+
withdrawEvents_1.push.apply(withdrawEvents_1, result);
|
298
|
+
page += 1;
|
299
|
+
if (result.length < 1000) {
|
300
|
+
endOfData = true;
|
301
|
+
}
|
302
|
+
}
|
303
|
+
else {
|
304
|
+
endOfData = true;
|
305
|
+
}
|
306
|
+
return [3 /*break*/, 3];
|
307
|
+
case 5:
|
308
|
+
promises[key] = new Promise(function (resolve) { return resolve(withdrawEvents_1); }).finally(function () {
|
309
|
+
return setTimeout(function () { return delete promises[key]; }, 2 * 60 * 100 /* 2 mins */);
|
310
|
+
});
|
311
|
+
return [2 /*return*/, withdrawEvents_1];
|
312
|
+
}
|
313
|
+
});
|
314
|
+
});
|
315
|
+
}
|
316
|
+
exports.getWithdraws = getWithdraws;
|
317
|
+
//# sourceMappingURL=vaultEvents.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"vaultEvents.js","sourceRoot":"","sources":["../../../src/functions/vaultEvents.ts"],"names":[],"mappings":"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"}
|
@@ -2,3 +2,5 @@ export declare const vaultQuery: string;
|
|
2
2
|
export declare const vaultByTokensQuery: string;
|
3
3
|
export declare const rebalancesQuery: (page: number) => string;
|
4
4
|
export declare const vaultCollectFeesQuery: (page: number) => string;
|
5
|
+
export declare const vaultDepositsQuery: (page: number) => string;
|
6
|
+
export declare const vaultWithdrawsQuery: (page: number) => string;
|
@@ -4,14 +4,18 @@ var __makeTemplateObject = (this && this.__makeTemplateObject) || function (cook
|
|
4
4
|
return cooked;
|
5
5
|
};
|
6
6
|
Object.defineProperty(exports, "__esModule", { value: true });
|
7
|
-
exports.vaultCollectFeesQuery = exports.rebalancesQuery = exports.vaultByTokensQuery = exports.vaultQuery = void 0;
|
7
|
+
exports.vaultWithdrawsQuery = exports.vaultDepositsQuery = exports.vaultCollectFeesQuery = exports.rebalancesQuery = exports.vaultByTokensQuery = exports.vaultQuery = void 0;
|
8
8
|
// eslint-disable-next-line import/no-unresolved
|
9
9
|
var graphql_request_1 = require("graphql-request");
|
10
10
|
exports.vaultQuery = (0, graphql_request_1.gql)(templateObject_1 || (templateObject_1 = __makeTemplateObject(["\n query ($vaultAddress: String!) {\n ichiVault(id: $vaultAddress) {\n id\n tokenA\n tokenB\n allowTokenA\n allowTokenB\n }\n }\n"], ["\n query ($vaultAddress: String!) {\n ichiVault(id: $vaultAddress) {\n id\n tokenA\n tokenB\n allowTokenA\n allowTokenB\n }\n }\n"])));
|
11
11
|
exports.vaultByTokensQuery = (0, graphql_request_1.gql)(templateObject_2 || (templateObject_2 = __makeTemplateObject(["\n query ($addressTokenA: String!, $addressTokenB: String!) {\n ichiVaults(where: { tokenA: $addressTokenA, tokenB: $addressTokenB }) {\n id\n tokenA\n tokenB\n allowTokenA\n allowTokenB\n }\n }\n"], ["\n query ($addressTokenA: String!, $addressTokenB: String!) {\n ichiVaults(where: { tokenA: $addressTokenA, tokenB: $addressTokenB }) {\n id\n tokenA\n tokenB\n allowTokenA\n allowTokenB\n }\n }\n"])));
|
12
|
-
var rebalancesQuery = function (page) { return (0, graphql_request_1.gql)(templateObject_3 || (templateObject_3 = __makeTemplateObject(["\n query ($vaultAddress: String!, $createdAtTimestamp_gt: String!) {\n vaultRebalances(first:1000, skip: ", ", where: { vault: $vaultAddress, createdAtTimestamp_gt: $createdAtTimestamp_gt }) {\n feeAmount0\n feeAmount1\n createdAtTimestamp\n vault\n sqrtPrice\n }\n }\n"], ["\n query ($vaultAddress: String!, $createdAtTimestamp_gt: String!) {\n vaultRebalances(first:1000, skip: ", ", where: { vault: $vaultAddress, createdAtTimestamp_gt: $createdAtTimestamp_gt }) {\n feeAmount0\n feeAmount1\n createdAtTimestamp\n vault\n sqrtPrice\n }\n }\n"])), page * 1000); };
|
12
|
+
var rebalancesQuery = function (page) { return (0, graphql_request_1.gql)(templateObject_3 || (templateObject_3 = __makeTemplateObject(["\n query ($vaultAddress: String!, $createdAtTimestamp_gt: String!) {\n vaultRebalances(first:1000, skip: ", ", where: { vault: $vaultAddress, createdAtTimestamp_gt: $createdAtTimestamp_gt }) {\n feeAmount0\n feeAmount1\n totalAmount0\n totalAmount1\n createdAtTimestamp\n vault\n sqrtPrice\n }\n }\n"], ["\n query ($vaultAddress: String!, $createdAtTimestamp_gt: String!) {\n vaultRebalances(first:1000, skip: ", ", where: { vault: $vaultAddress, createdAtTimestamp_gt: $createdAtTimestamp_gt }) {\n feeAmount0\n feeAmount1\n totalAmount0\n totalAmount1\n createdAtTimestamp\n vault\n sqrtPrice\n }\n }\n"])), page * 1000); };
|
13
13
|
exports.rebalancesQuery = rebalancesQuery;
|
14
|
-
var vaultCollectFeesQuery = function (page) { return (0, graphql_request_1.gql)(templateObject_4 || (templateObject_4 = __makeTemplateObject(["\n query ($vaultAddress: String!, $createdAtTimestamp_gt: String!) {\n vaultCollectFees(first: 1000, skip: ", ", where: { vault: $vaultAddress, createdAtTimestamp_gt: $createdAtTimestamp_gt }) {\n feeAmount0\n feeAmount1\n createdAtTimestamp\n vault\n sqrtPrice\n }\n }\n"], ["\n query ($vaultAddress: String!, $createdAtTimestamp_gt: String!) {\n vaultCollectFees(first: 1000, skip: ", ", where: { vault: $vaultAddress, createdAtTimestamp_gt: $createdAtTimestamp_gt }) {\n feeAmount0\n feeAmount1\n createdAtTimestamp\n vault\n sqrtPrice\n }\n }\n"])), page * 1000); };
|
14
|
+
var vaultCollectFeesQuery = function (page) { return (0, graphql_request_1.gql)(templateObject_4 || (templateObject_4 = __makeTemplateObject(["\n query ($vaultAddress: String!, $createdAtTimestamp_gt: String!) {\n vaultCollectFees(first: 1000, skip: ", ", where: { vault: $vaultAddress, createdAtTimestamp_gt: $createdAtTimestamp_gt }) {\n feeAmount0\n feeAmount1\n totalAmount0\n totalAmount1\n createdAtTimestamp\n vault\n sqrtPrice\n }\n }\n"], ["\n query ($vaultAddress: String!, $createdAtTimestamp_gt: String!) {\n vaultCollectFees(first: 1000, skip: ", ", where: { vault: $vaultAddress, createdAtTimestamp_gt: $createdAtTimestamp_gt }) {\n feeAmount0\n feeAmount1\n totalAmount0\n totalAmount1\n createdAtTimestamp\n vault\n sqrtPrice\n }\n }\n"])), page * 1000); };
|
15
15
|
exports.vaultCollectFeesQuery = vaultCollectFeesQuery;
|
16
|
-
var
|
16
|
+
var vaultDepositsQuery = function (page) { return (0, graphql_request_1.gql)(templateObject_5 || (templateObject_5 = __makeTemplateObject(["\n query ($vaultAddress: String!, $createdAtTimestamp_gt: String!) {\n vaultDeposits(first: 1000, skip: ", ", where: { vault: $vaultAddress, createdAtTimestamp_gt: $createdAtTimestamp_gt }) {\n vault\n createdAtTimestamp\n totalAmount0\n totalAmount1\n totalAmount0BeforeEvent\n totalAmount1BeforeEvent\n sqrtPrice\n }\n }\n"], ["\n query ($vaultAddress: String!, $createdAtTimestamp_gt: String!) {\n vaultDeposits(first: 1000, skip: ", ", where: { vault: $vaultAddress, createdAtTimestamp_gt: $createdAtTimestamp_gt }) {\n vault\n createdAtTimestamp\n totalAmount0\n totalAmount1\n totalAmount0BeforeEvent\n totalAmount1BeforeEvent\n sqrtPrice\n }\n }\n"])), page * 1000); };
|
17
|
+
exports.vaultDepositsQuery = vaultDepositsQuery;
|
18
|
+
var vaultWithdrawsQuery = function (page) { return (0, graphql_request_1.gql)(templateObject_6 || (templateObject_6 = __makeTemplateObject(["\n query ($vaultAddress: String!, $createdAtTimestamp_gt: String!) {\n vaultWithdraws(first: 1000, skip: ", ", where: { vault: $vaultAddress, createdAtTimestamp_gt: $createdAtTimestamp_gt }) {\n createdAtTimestamp\n totalAmount0\n totalAmount1\n totalAmount0BeforeEvent\n totalAmount1BeforeEvent\n vault\n sqrtPrice\n }\n }\n"], ["\n query ($vaultAddress: String!, $createdAtTimestamp_gt: String!) {\n vaultWithdraws(first: 1000, skip: ", ", where: { vault: $vaultAddress, createdAtTimestamp_gt: $createdAtTimestamp_gt }) {\n createdAtTimestamp\n totalAmount0\n totalAmount1\n totalAmount0BeforeEvent\n totalAmount1BeforeEvent\n vault\n sqrtPrice\n }\n }\n"])), page * 1000); };
|
19
|
+
exports.vaultWithdrawsQuery = vaultWithdrawsQuery;
|
20
|
+
var templateObject_1, templateObject_2, templateObject_3, templateObject_4, templateObject_5, templateObject_6;
|
17
21
|
//# sourceMappingURL=queries.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"queries.js","sourceRoot":"","sources":["../../../src/graphql/queries.ts"],"names":[],"mappings":";;;;;;;AAAA,gDAAgD;AAChD,mDAAsC;AAEzB,QAAA,UAAU,OAAG,qBAAG,wOAAA,oKAU5B,KAAC;AAEW,QAAA,kBAAkB,OAAG,qBAAG,2SAAA,uOAUpC,KAAC;AAEK,IAAM,eAAe,GAAG,UAAC,IAAY,IAAK,WAAA,qBAAG,
|
1
|
+
{"version":3,"file":"queries.js","sourceRoot":"","sources":["../../../src/graphql/queries.ts"],"names":[],"mappings":";;;;;;;AAAA,gDAAgD;AAChD,mDAAsC;AAEzB,QAAA,UAAU,OAAG,qBAAG,wOAAA,oKAU5B,KAAC;AAEW,QAAA,kBAAkB,OAAG,qBAAG,2SAAA,uOAUpC,KAAC;AAEK,IAAM,eAAe,GAAG,UAAC,IAAY,IAAK,WAAA,qBAAG,4ZAAA,+GAEZ,EAEpC,uOAUH,KAXK,IAAI,GAAG,IAAI,GAHgC,CAchD,CAAC;AAdW,QAAA,eAAe,mBAc1B;AAEK,IAAM,qBAAqB,GAAG,UAAC,IAAY,IAAK,WAAA,qBAAG,8ZAAA,iHAEhB,EAEtC,uOAUH,KAXK,IAAI,GAAG,IAAI,GAHsC,CActD,CAAC;AAdW,QAAA,qBAAqB,yBAchC;AAEK,IAAM,kBAAkB,GAAG,UAAC,IAAY,IAAK,WAAA,qBAAG,qbAAA,8GAEhB,EAEnC,iQAUH,KAXK,IAAI,GAAG,IAAI,GAHmC,CAcnD,CAAC;AAdW,QAAA,kBAAkB,sBAc7B;AAEK,IAAM,mBAAmB,GAAG,UAAC,IAAY,IAAK,WAAA,qBAAG,sbAAA,+GAEhB,EAEpC,iQAUH,KAXK,IAAI,GAAG,IAAI,GAHoC,CAcpD,CAAC;AAdW,QAAA,mBAAmB,uBAc9B"}
|
package/dist/src/index.cjs.js
CHANGED
@@ -2,7 +2,7 @@
|
|
2
2
|
/**
|
3
3
|
* @license
|
4
4
|
* author: ICHI DAO <core@ichi.org>
|
5
|
-
* ichi-vaults-sdk.js v0.0.
|
5
|
+
* ichi-vaults-sdk.js v0.0.21
|
6
6
|
* Released under the MIT license.
|
7
7
|
*/
|
8
8
|
|
@@ -17,4 +17,5 @@ tslib_1.__exportStar(require("./functions/deposit"), exports);
|
|
17
17
|
tslib_1.__exportStar(require("./functions/withdraw"), exports);
|
18
18
|
tslib_1.__exportStar(require("./functions/vault"), exports);
|
19
19
|
tslib_1.__exportStar(require("./functions/calculateFees"), exports);
|
20
|
+
tslib_1.__exportStar(require("./functions/calculateDtr"), exports);
|
20
21
|
tslib_1.__exportStar(require("./types/index"), exports);
|
package/dist/src/index.d.ts
CHANGED
package/dist/src/index.esm.js
CHANGED
@@ -2,7 +2,7 @@
|
|
2
2
|
/**
|
3
3
|
* @license
|
4
4
|
* author: ICHI DAO <core@ichi.org>
|
5
|
-
* ichi-vaults-sdk.js v0.0.
|
5
|
+
* ichi-vaults-sdk.js v0.0.21
|
6
6
|
* Released under the MIT license.
|
7
7
|
*/
|
8
8
|
|
@@ -15,4 +15,5 @@ tslib_1.__exportStar(require("./functions/deposit"), exports);
|
|
15
15
|
tslib_1.__exportStar(require("./functions/withdraw"), exports);
|
16
16
|
tslib_1.__exportStar(require("./functions/vault"), exports);
|
17
17
|
tslib_1.__exportStar(require("./functions/calculateFees"), exports);
|
18
|
+
tslib_1.__exportStar(require("./functions/calculateDtr"), exports);
|
18
19
|
tslib_1.__exportStar(require("./types/index"), exports);
|
package/dist/src/index.js
CHANGED
@@ -21,5 +21,6 @@ __exportStar(require("./functions/deposit"), exports);
|
|
21
21
|
__exportStar(require("./functions/withdraw"), exports);
|
22
22
|
__exportStar(require("./functions/vault"), exports);
|
23
23
|
__exportStar(require("./functions/calculateFees"), exports);
|
24
|
+
__exportStar(require("./functions/calculateDtr"), exports);
|
24
25
|
__exportStar(require("./types/index"), exports);
|
25
26
|
//# sourceMappingURL=index.js.map
|
package/dist/src/index.js.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,iDAAiD;AACjD,2CAA2C;AAC3C,uDAAqC;AACrC,sDAAoC;AACpC,uDAAqC;AACrC,oDAAkC;AAClC,4DAA0C;AAC1C,gDAA8B"}
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,iDAAiD;AACjD,2CAA2C;AAC3C,uDAAqC;AACrC,sDAAoC;AACpC,uDAAqC;AACrC,oDAAkC;AAClC,4DAA0C;AAC1C,2DAAyC;AACzC,gDAA8B"}
|
@@ -0,0 +1,3 @@
|
|
1
|
+
import { JsonRpcProvider } from '@ethersproject/providers';
|
2
|
+
import { AverageDepositTokenRatio, SupportedDex } from '../types';
|
3
|
+
export declare function getAverageDepositTokenRatios(vaultAddress: string, jsonProvider: JsonRpcProvider, dex: SupportedDex, timeIntervals?: number[]): Promise<AverageDepositTokenRatio[]>;
|
@@ -1,5 +1,6 @@
|
|
1
1
|
import { JsonRpcProvider } from '@ethersproject/providers';
|
2
|
-
import { FeesInfo, SupportedDex, TotalAmounts, TotalAmountsBN } from '../types';
|
2
|
+
import { Fees, FeesInfo, SupportedDex, TotalAmounts, TotalAmountsBN } from '../types';
|
3
|
+
export declare function getTotalAmountsAtFeeCollectionEvent(objFees: Fees, isVaultInverted: boolean, token0Decimals: number, token1Decimals: number): [number, number];
|
3
4
|
export declare function getFeesCollected(vaultAddress: string, jsonProvider: JsonRpcProvider, dex: SupportedDex, days?: number): Promise<TotalAmounts>;
|
4
5
|
export declare function getFeesCollected(vaultAddress: string, jsonProvider: JsonRpcProvider, dex: SupportedDex, raw: true, days?: number): Promise<TotalAmountsBN>;
|
5
6
|
export declare function getFeesCollectedInfo(vaultAddress: string, jsonProvider: JsonRpcProvider, dex: SupportedDex, forDays?: number[]): Promise<FeesInfo[]>;
|
@@ -0,0 +1,7 @@
|
|
1
|
+
import { JsonRpcProvider } from '@ethersproject/providers';
|
2
|
+
import { BigNumber } from '@ethersproject/bignumber';
|
3
|
+
import { SupportedDex } from '../types';
|
4
|
+
export declare function getSqrtPriceFromPool(vaultAddress: string, jsonProvider: JsonRpcProvider, dex: SupportedDex): Promise<BigNumber>;
|
5
|
+
export declare function getCurrPrice(vaultAddress: string, jsonProvider: JsonRpcProvider, dex: SupportedDex, isVaultInverted: boolean, token0decimals: number, token1decimals: number): Promise<number>;
|
6
|
+
export declare function getCurrentDtr(vaultAddress: string, jsonProvider: JsonRpcProvider, dex: SupportedDex, isVaultInverted: boolean, token0decimals: number, token1decimals: number): Promise<number>;
|
7
|
+
export declare function getVaultTvl(vaultAddress: string, jsonProvider: JsonRpcProvider, dex: SupportedDex, isVaultInverted: boolean, token0decimals: number, token1decimals: number): Promise<number>;
|
@@ -0,0 +1,6 @@
|
|
1
|
+
import { JsonRpcProvider } from '@ethersproject/providers';
|
2
|
+
import { SupportedDex, Fees, VaultTransactionEvent } from '../types';
|
3
|
+
export declare function getRebalances(vaultAddress: string, jsonProvider: JsonRpcProvider, dex: SupportedDex, days?: number): Promise<Fees[]>;
|
4
|
+
export declare function getFeesCollectedEvents(vaultAddress: string, jsonProvider: JsonRpcProvider, dex: SupportedDex, days?: number): Promise<Fees[]>;
|
5
|
+
export declare function getDeposits(vaultAddress: string, jsonProvider: JsonRpcProvider, dex: SupportedDex, days?: number): Promise<VaultTransactionEvent[]>;
|
6
|
+
export declare function getWithdraws(vaultAddress: string, jsonProvider: JsonRpcProvider, dex: SupportedDex, days?: number): Promise<VaultTransactionEvent[]>;
|
@@ -2,3 +2,5 @@ export declare const vaultQuery: string;
|
|
2
2
|
export declare const vaultByTokensQuery: string;
|
3
3
|
export declare const rebalancesQuery: (page: number) => string;
|
4
4
|
export declare const vaultCollectFeesQuery: (page: number) => string;
|
5
|
+
export declare const vaultDepositsQuery: (page: number) => string;
|
6
|
+
export declare const vaultWithdrawsQuery: (page: number) => string;
|
package/dist/src/src/index.d.ts
CHANGED
@@ -57,6 +57,17 @@ export interface IchiVault {
|
|
57
57
|
export interface Fees {
|
58
58
|
feeAmount0: string;
|
59
59
|
feeAmount1: string;
|
60
|
+
totalAmount0: string;
|
61
|
+
totalAmount1: string;
|
62
|
+
createdAtTimestamp: string;
|
63
|
+
vault: string;
|
64
|
+
sqrtPrice: string;
|
65
|
+
}
|
66
|
+
export interface VaultTransactionEvent {
|
67
|
+
totalAmount0: string;
|
68
|
+
totalAmount1: string;
|
69
|
+
totalAmount0BeforeEvent: string;
|
70
|
+
totalAmount1BeforeEvent: string;
|
60
71
|
createdAtTimestamp: string;
|
61
72
|
vault: string;
|
62
73
|
sqrtPrice: string;
|
@@ -67,3 +78,11 @@ export type FeesInfo = {
|
|
67
78
|
feeAmount1: string;
|
68
79
|
pctAPR: number;
|
69
80
|
};
|
81
|
+
export type DepositTokenRatio = {
|
82
|
+
atTimestamp: string;
|
83
|
+
percent: number;
|
84
|
+
};
|
85
|
+
export type AverageDepositTokenRatio = {
|
86
|
+
timePeriod: number;
|
87
|
+
percent: number;
|
88
|
+
};
|
@@ -1,4 +1,4 @@
|
|
1
|
-
import { IchiVault, Fees } from '..';
|
1
|
+
import { IchiVault, Fees, VaultTransactionEvent } from '..';
|
2
2
|
export interface VaultQueryData {
|
3
3
|
ichiVault: IchiVault;
|
4
4
|
}
|
@@ -11,3 +11,9 @@ export interface RebalancesQueryData {
|
|
11
11
|
export interface CollectFeesQueryData {
|
12
12
|
vaultCollectFees: Fees[];
|
13
13
|
}
|
14
|
+
export interface VaultDepositsQueryData {
|
15
|
+
vaultDeposits: VaultTransactionEvent[];
|
16
|
+
}
|
17
|
+
export interface VaultWithdrawsQueryData {
|
18
|
+
vaultWithdraws: VaultTransactionEvent[];
|
19
|
+
}
|
@@ -57,6 +57,17 @@ export interface IchiVault {
|
|
57
57
|
export interface Fees {
|
58
58
|
feeAmount0: string;
|
59
59
|
feeAmount1: string;
|
60
|
+
totalAmount0: string;
|
61
|
+
totalAmount1: string;
|
62
|
+
createdAtTimestamp: string;
|
63
|
+
vault: string;
|
64
|
+
sqrtPrice: string;
|
65
|
+
}
|
66
|
+
export interface VaultTransactionEvent {
|
67
|
+
totalAmount0: string;
|
68
|
+
totalAmount1: string;
|
69
|
+
totalAmount0BeforeEvent: string;
|
70
|
+
totalAmount1BeforeEvent: string;
|
60
71
|
createdAtTimestamp: string;
|
61
72
|
vault: string;
|
62
73
|
sqrtPrice: string;
|
@@ -67,3 +78,11 @@ export type FeesInfo = {
|
|
67
78
|
feeAmount1: string;
|
68
79
|
pctAPR: number;
|
69
80
|
};
|
81
|
+
export type DepositTokenRatio = {
|
82
|
+
atTimestamp: string;
|
83
|
+
percent: number;
|
84
|
+
};
|
85
|
+
export type AverageDepositTokenRatio = {
|
86
|
+
timePeriod: number;
|
87
|
+
percent: number;
|
88
|
+
};
|