From 1b6aef5644ca7ff6e0a7cac2991a8f997e6a6ea8 Mon Sep 17 00:00:00 2001 From: microwavedcola1 Date: Fri, 30 Aug 2024 08:01:06 +0200 Subject: [PATCH] ts sb crank: Fix types Signed-off-by: microwavedcola1 --- ts/client/scripts/sb-on-demand-crank-utils.ts | 10 ++++++++-- ts/client/scripts/sb-on-demand-crank.ts | 8 +++++--- 2 files changed, 13 insertions(+), 5 deletions(-) diff --git a/ts/client/scripts/sb-on-demand-crank-utils.ts b/ts/client/scripts/sb-on-demand-crank-utils.ts index 1ee11e66f..8a2b99db4 100644 --- a/ts/client/scripts/sb-on-demand-crank-utils.ts +++ b/ts/client/scripts/sb-on-demand-crank-utils.ts @@ -1,13 +1,16 @@ import { PublicKey } from '@solana/web3.js'; +import { TokenIndex } from '../src/accounts/bank'; import { Group } from '../src/accounts/group'; +import { PerpMarketIndex } from '../src/accounts/perp'; import { ZERO_I80F48 } from '../src/numbers/I80F48'; export interface OraclesFromMangoGroupInterface { oraclePk: PublicKey; name: string; fallbackForOracle: PublicKey | undefined; - tokenIndex: number | undefined; // todo remove - perpMarketIndex: number | undefined; + tokenIndex: TokenIndex | undefined; // todo remove + perpMarketIndex: PerpMarketIndex | undefined; + isOracleStaleOrUnconfident: boolean; // todo: add tier when program mango-v4 24.3 is released } @@ -37,6 +40,7 @@ export function getOraclesForMangoGroup( fallbackForOracle: undefined, tokenIndex: b[0].tokenIndex, perpMarketIndex: undefined, + isOracleStaleOrUnconfident: false, }; }); @@ -50,6 +54,7 @@ export function getOraclesForMangoGroup( fallbackForOracle: undefined, tokenIndex: undefined, perpMarketIndex: pM.perpMarketIndex, + isOracleStaleOrUnconfident: false, }; }); @@ -72,6 +77,7 @@ export function getOraclesForMangoGroup( fallbackForOracle: b[0].oracle, tokenIndex: b[0].tokenIndex, perpMarketIndex: undefined, + isOracleStaleOrUnconfident: false, }; }) .filter((item) => !item.oraclePk.equals(PublicKey.default)); diff --git a/ts/client/scripts/sb-on-demand-crank.ts b/ts/client/scripts/sb-on-demand-crank.ts index 240959f35..a3a715e55 100644 --- a/ts/client/scripts/sb-on-demand-crank.ts +++ b/ts/client/scripts/sb-on-demand-crank.ts @@ -9,10 +9,10 @@ import { } from '@solana/web3.js'; import { CrossbarClient, + ON_DEMAND_MAINNET_PID, PullFeed, Queue, RecentSlotHashes, - SB_ON_DEMAND_PID, } from '@switchboard-xyz/on-demand'; import fs from 'fs'; import chunk from 'lodash/chunk'; @@ -472,7 +472,7 @@ async function prepareCandidateOracles( .map((o, i) => { return { oracle: o, ai: ais[i] }; }) - .filter((item) => item.ai?.owner.equals(SB_ON_DEMAND_PID)); + .filter((item) => item.ai?.owner.equals(ON_DEMAND_MAINNET_PID)); // parse account info data const parsedOracles = sbodOracles.map((item) => { @@ -526,6 +526,7 @@ function extendOraclesManually( fallbackForOracle: undefined, tokenIndex: undefined, perpMarketIndex: undefined, + isOracleStaleOrUnconfident: false, }, ]; } @@ -545,6 +546,7 @@ function extendOraclesManually( fallbackForOracle: undefined, tokenIndex: undefined, perpMarketIndex: undefined, + isOracleStaleOrUnconfident: false, }; }); } @@ -589,7 +591,7 @@ async function setupSwitchboard(client: MangoClient): Promise<{ queue: PublicKey; }> { const idl = await Anchor30Program.fetchIdl( - SB_ON_DEMAND_PID, + ON_DEMAND_MAINNET_PID, client.program.provider, ); const sbOnDemandProgram = new Anchor30Program(idl!, client.program.provider);