@perena/bankineco-sdk 1.0.30 → 1.0.31
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/dist/services/oracle/updateSeedLPPrice.d.ts.map +1 -1
- package/dist/services/oracle/updateSeedLPPrice.js +6 -2
- package/dist/services/oracle/updateSeedLPPrice.js.map +1 -1
- package/dist/utils/oldUtils.d.ts +0 -2
- package/dist/utils/oldUtils.d.ts.map +1 -1
- package/dist/utils/oldUtils.js +60 -52
- package/dist/utils/oldUtils.js.map +1 -1
- package/package.json +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"updateSeedLPPrice.d.ts","sourceRoot":"","sources":["../../../src/services/oracle/updateSeedLPPrice.ts"],"names":[],"mappings":"AAeA,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;
|
|
1
|
+
{"version":3,"file":"updateSeedLPPrice.d.ts","sourceRoot":"","sources":["../../../src/services/oracle/updateSeedLPPrice.ts"],"names":[],"mappings":"AAeA,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAoF1C,wBAAsB,oBAAoB,CACxC,GAAG,EAAE,WAAW,EAChB,eAAe,EAAE,MAAM,EACvB,MAAM,EAAE,MAAM,iBAQf"}
|
|
@@ -6,7 +6,7 @@ const bankinecoProgram_1 = require("../bankinecoProgram");
|
|
|
6
6
|
const utils_1 = require("../../utils");
|
|
7
7
|
const constants_1 = require("../../constants");
|
|
8
8
|
const anchor_1 = require("@coral-xyz/anchor");
|
|
9
|
-
|
|
9
|
+
// import { getOldUsdStarPriceFromBurnSim } from "../../utils/oldUtils";
|
|
10
10
|
async function updatePrice(bankineco, signerKeypairFp) {
|
|
11
11
|
const vaultState = bankineco.vaultPDA(bankineco.bankPDA(constants_1.USD_STAR_BANK_INDEX), new web3_js_1.PublicKey(constants_1.OLD_USD_STAR), constants_1.OLD_USD_STAR_CONTRACT_INDEX);
|
|
12
12
|
const oracleState = bankineco.oraclePDA(vaultState);
|
|
@@ -21,7 +21,11 @@ async function updatePrice(bankineco, signerKeypairFp) {
|
|
|
21
21
|
const currentOracleUiPrices = oracleInfo.data.oraclePrices.map((x) => (0, utils_1.toUiAmount)(x, decimals));
|
|
22
22
|
const currentReportedUiPrice = (0, utils_1.toUiAmount)(oracleInfo.data.oraclePrices[associatedOracleIdx], decimals);
|
|
23
23
|
const lastUpdatedTs = oracleInfo.data.oracleLastTs[associatedOracleIdx];
|
|
24
|
-
const impliedPrice = await
|
|
24
|
+
// const impliedPrice = await getOldUsdStarPriceFromBurnSim(
|
|
25
|
+
// bankineco.provider,
|
|
26
|
+
// signerKeypairFp
|
|
27
|
+
// );
|
|
28
|
+
const impliedPrice = 1;
|
|
25
29
|
const diffMs = Date.now() - lastUpdatedTs.toNumber() * 1000;
|
|
26
30
|
const hoursSinceLastUpdate = diffMs / (1000 * 60 * 60);
|
|
27
31
|
console.log("Current oracle index: ", associatedOracleIdx);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"updateSeedLPPrice.js","sourceRoot":"","sources":["../../../src/services/oracle/updateSeedLPPrice.ts"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"updateSeedLPPrice.js","sourceRoot":"","sources":["../../../src/services/oracle/updateSeedLPPrice.ts"],"names":[],"mappings":"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"}
|
package/dist/utils/oldUtils.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"oldUtils.d.ts","sourceRoot":"","sources":["../../src/utils/oldUtils.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"oldUtils.d.ts","sourceRoot":"","sources":["../../src/utils/oldUtils.ts"],"names":[],"mappings":""}
|
package/dist/utils/oldUtils.js
CHANGED
|
@@ -1,54 +1,62 @@
|
|
|
1
1
|
"use strict";
|
|
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
|
-
|
|
2
|
+
// import {
|
|
3
|
+
// init,
|
|
4
|
+
// removeLiquidity,
|
|
5
|
+
// PRODUCTION_POOLS,
|
|
6
|
+
// swapExactIn,
|
|
7
|
+
// } from "@perena/numeraire-sdk";
|
|
8
|
+
// import { AnchorProvider, setProvider, Wallet } from "@coral-xyz/anchor";
|
|
9
|
+
// import { resolveFp } from "./localUtils";
|
|
10
|
+
// import { PublicKey } from "@solana/web3.js";
|
|
11
|
+
// export async function getOldUsdStarPriceFromBurnSim(
|
|
12
|
+
// provider: AnchorProvider,
|
|
13
|
+
// signerKeypairFp: string
|
|
14
|
+
// ) {
|
|
15
|
+
// // Needed when using the numeraire-sdk
|
|
16
|
+
// process.env.ANCHOR_PROVIDER_URL = provider.connection.rpcEndpoint;
|
|
17
|
+
// process.env.ANCHOR_WALLET = resolveFp(signerKeypairFp);
|
|
18
|
+
// // Intialize numeraire sdk
|
|
19
|
+
// init({ applyD: false });
|
|
20
|
+
// setProvider(provider);
|
|
21
|
+
// const decimals = 6;
|
|
22
|
+
// const d = 10 ** decimals;
|
|
23
|
+
// // Simulate the burn of 1 Seedpool LP
|
|
24
|
+
// const { call } = await removeLiquidity({
|
|
25
|
+
// pool: new PublicKey(PRODUCTION_POOLS.tripool),
|
|
26
|
+
// lpTokenRedeemAmount: 1 * d,
|
|
27
|
+
// out: 1,
|
|
28
|
+
// });
|
|
29
|
+
// let simulatedBurn = await call.simulate({ commitment: "confirmed" });
|
|
30
|
+
// console.log("Simulated burn...");
|
|
31
|
+
// // Retrieve the output amounts in PYUSD, USDT and USDC
|
|
32
|
+
// let burningTransfers1 = simulatedBurn.events[0].data.xReserveDeltas;
|
|
33
|
+
// let amountUsdc = Number(burningTransfers1[0]) / 1_000_000;
|
|
34
|
+
// let amountUsdt = Number(burningTransfers1[1]) / 1_000_000;
|
|
35
|
+
// let amountPyusd = Number(burningTransfers1[2]) / 1_000_000;
|
|
36
|
+
// // Calculate the burned amount of USDStar
|
|
37
|
+
// let burnedUsdstar =
|
|
38
|
+
// Number(simulatedBurn.events[0].data.lpTokenRedeemAmount) / 1000000;
|
|
39
|
+
// // Deduct the onchain USDT price from the USDC-USDT price practiced on Numeraire
|
|
40
|
+
// // We're assuming the numeraire local USDC-USDT price is in line with the rest of the market
|
|
41
|
+
// // This is an important assumption but it seams valid to me because otherwise the Numeraire price would be arbitraged
|
|
42
|
+
// // We're also not considering slippage here
|
|
43
|
+
// const callSwap1 = await swapExactIn({
|
|
44
|
+
// pool: new PublicKey(PRODUCTION_POOLS.tripool),
|
|
45
|
+
// in: 1,
|
|
46
|
+
// out: 0,
|
|
47
|
+
// exactAmountIn: 100_000,
|
|
48
|
+
// minAmountOut: 0,
|
|
49
|
+
// });
|
|
50
|
+
// let simulatedUsdtSell = await callSwap1.call.simulate({
|
|
51
|
+
// commitment: "confirmed",
|
|
52
|
+
// });
|
|
53
|
+
// let spentUsdt = simulatedUsdtSell.events[0].data.amountIn;
|
|
54
|
+
// let gatheredUsdc = simulatedUsdtSell.events[0].data.amountOut;
|
|
55
|
+
// let impliedUsdtPrice = gatheredUsdc / spentUsdt;
|
|
56
|
+
// // With the below formula, we're assuming PYUSD will always be 1 USDC
|
|
57
|
+
// // The implied price is also in USDC ie we get a price of 1 Seedpool = X USDC (and not 1 Seedpool = W USD)
|
|
58
|
+
// let impliedPrice =
|
|
59
|
+
// (amountUsdc + amountUsdt * impliedUsdtPrice + amountPyusd) / burnedUsdstar;
|
|
60
|
+
// return impliedPrice;
|
|
61
|
+
// }
|
|
54
62
|
//# sourceMappingURL=oldUtils.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"oldUtils.js","sourceRoot":"","sources":["../../src/utils/oldUtils.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"oldUtils.js","sourceRoot":"","sources":["../../src/utils/oldUtils.ts"],"names":[],"mappings":";AAAA,WAAW;AACX,UAAU;AACV,qBAAqB;AACrB,sBAAsB;AACtB,iBAAiB;AACjB,kCAAkC;AAClC,2EAA2E;AAC3E,4CAA4C;AAC5C,+CAA+C;AAE/C,uDAAuD;AACvD,8BAA8B;AAC9B,4BAA4B;AAC5B,MAAM;AACN,2CAA2C;AAC3C,uEAAuE;AACvE,4DAA4D;AAE5D,+BAA+B;AAC/B,6BAA6B;AAC7B,2BAA2B;AAE3B,wBAAwB;AACxB,8BAA8B;AAC9B,0CAA0C;AAC1C,6CAA6C;AAC7C,qDAAqD;AACrD,kCAAkC;AAClC,cAAc;AACd,QAAQ;AACR,0EAA0E;AAC1E,sCAAsC;AACtC,2DAA2D;AAC3D,yEAAyE;AAEzE,+DAA+D;AAC/D,+DAA+D;AAC/D,gEAAgE;AAChE,8CAA8C;AAC9C,wBAAwB;AACxB,0EAA0E;AAE1E,qFAAqF;AACrF,iGAAiG;AACjG,0HAA0H;AAC1H,gDAAgD;AAChD,0CAA0C;AAC1C,qDAAqD;AACrD,aAAa;AACb,cAAc;AACd,8BAA8B;AAC9B,uBAAuB;AACvB,QAAQ;AAER,4DAA4D;AAC5D,+BAA+B;AAC/B,QAAQ;AACR,+DAA+D;AAC/D,mEAAmE;AACnE,qDAAqD;AAErD,0EAA0E;AAC1E,+GAA+G;AAC/G,uBAAuB;AACvB,kFAAkF;AAElF,yBAAyB;AACzB,IAAI"}
|