@drift-labs/sdk 2.142.0-beta.22 → 2.142.0-beta.24
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/VERSION +1 -1
- package/lib/browser/constants/perpMarkets.js +35 -0
- package/lib/browser/events/parse.d.ts +2 -0
- package/lib/browser/events/parse.js +94 -1
- package/lib/browser/events/types.d.ts +20 -1
- package/lib/node/constants/perpMarkets.d.ts.map +1 -1
- package/lib/node/constants/perpMarkets.js +35 -0
- package/lib/node/events/parse.d.ts +2 -0
- package/lib/node/events/parse.d.ts.map +1 -1
- package/lib/node/events/parse.js +94 -1
- package/lib/node/events/types.d.ts +20 -1
- package/lib/node/events/types.d.ts.map +1 -1
- package/package.json +2 -1
- package/src/constants/perpMarkets.ts +37 -0
- package/src/events/parse.ts +115 -0
- package/src/events/types.ts +23 -1
- package/tests/events/parseLogsForCuUsage.ts +139 -0
package/VERSION
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
2.142.0-beta.
|
|
1
|
+
2.142.0-beta.24
|
|
@@ -1252,6 +1252,41 @@ exports.MainnetPerpMarkets = [
|
|
|
1252
1252
|
pythFeedId: '0xf2b3ab1c49e35e881003c3c0482d18b181a1560b697b844c24c8f85aba1cab95',
|
|
1253
1253
|
pythLazerId: 2316,
|
|
1254
1254
|
},
|
|
1255
|
+
{
|
|
1256
|
+
fullName: 'ZCash',
|
|
1257
|
+
category: ['Privacy'],
|
|
1258
|
+
symbol: 'ZEC-PERP',
|
|
1259
|
+
baseAssetSymbol: 'ZEC',
|
|
1260
|
+
marketIndex: 79,
|
|
1261
|
+
oracle: new web3_js_1.PublicKey('BXunfRSyiQWJHv88qMvE42mpMpksWEC8Bf13p2msnRms'),
|
|
1262
|
+
launchTs: 1760366017000,
|
|
1263
|
+
oracleSource: types_1.OracleSource.PYTH_LAZER,
|
|
1264
|
+
pythFeedId: '0xbe9b59d178f0d6a97ab4c343bff2aa69caa1eaae3e9048a65788c529b125bb24',
|
|
1265
|
+
pythLazerId: 66,
|
|
1266
|
+
},
|
|
1267
|
+
{
|
|
1268
|
+
fullName: 'Mantle',
|
|
1269
|
+
category: ['L1'],
|
|
1270
|
+
symbol: 'MNT-PERP',
|
|
1271
|
+
baseAssetSymbol: 'MNT',
|
|
1272
|
+
marketIndex: 80,
|
|
1273
|
+
oracle: new web3_js_1.PublicKey('Gy7cJ4U1nxMA44XXC3hwqkpcxEB1mZTYiwJVkaqZfU7u'),
|
|
1274
|
+
launchTs: 1760366017000,
|
|
1275
|
+
oracleSource: types_1.OracleSource.PYTH_LAZER,
|
|
1276
|
+
pythFeedId: '0x4e3037c822d852d79af3ac80e35eb420ee3b870dca49f9344a38ef4773fb0585',
|
|
1277
|
+
pythLazerId: 199,
|
|
1278
|
+
},
|
|
1279
|
+
{
|
|
1280
|
+
fullName: '1KPUMP',
|
|
1281
|
+
category: ['Launchpad'],
|
|
1282
|
+
symbol: '1KPUMP-PERP',
|
|
1283
|
+
baseAssetSymbol: '1KPUMP',
|
|
1284
|
+
marketIndex: 81,
|
|
1285
|
+
oracle: new web3_js_1.PublicKey('5r8RWTaRiMgr9Lph3FTUE3sGb1vymhpCrm83Bovjfcps'),
|
|
1286
|
+
launchTs: 1760366017000,
|
|
1287
|
+
oracleSource: types_1.OracleSource.PYTH_LAZER_1K,
|
|
1288
|
+
pythLazerId: 1578,
|
|
1289
|
+
},
|
|
1255
1290
|
];
|
|
1256
1291
|
exports.PerpMarkets = {
|
|
1257
1292
|
devnet: exports.DevnetPerpMarkets,
|
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
import { Program, Event } from '@coral-xyz/anchor';
|
|
2
|
+
import { CuUsageEvent } from './types';
|
|
2
3
|
export declare function parseLogs(program: Program, logs: string[], programId?: string): Event[];
|
|
3
4
|
export declare function parseLogsWithRaw(program: Program, logs: string[], programId?: string): {
|
|
4
5
|
events: Event[];
|
|
5
6
|
rawLogs: string[];
|
|
6
7
|
};
|
|
8
|
+
export declare function parseLogsForCuUsage(logs: string[], programId?: string): Event<CuUsageEvent>[];
|
|
@@ -1,11 +1,13 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.parseLogsWithRaw = exports.parseLogs = void 0;
|
|
3
|
+
exports.parseLogsForCuUsage = exports.parseLogsWithRaw = exports.parseLogs = void 0;
|
|
4
4
|
const driftProgramId = 'dRiftyHA39MWEi3m9aunc5MzRF1JYuBsbn6VPcn33UH';
|
|
5
5
|
const PROGRAM_LOG = 'Program log: ';
|
|
6
|
+
const PROGRAM_INSTRUCTION = 'Program log: Instruction: ';
|
|
6
7
|
const PROGRAM_DATA = 'Program data: ';
|
|
7
8
|
const PROGRAM_LOG_START_INDEX = PROGRAM_LOG.length;
|
|
8
9
|
const PROGRAM_DATA_START_INDEX = PROGRAM_DATA.length;
|
|
10
|
+
const PROGRAM_INSTRUCTION_START_INDEX = PROGRAM_INSTRUCTION.length;
|
|
9
11
|
function parseLogs(program, logs, programId = driftProgramId) {
|
|
10
12
|
const { events } = parseLogsWithRaw(program, logs, programId);
|
|
11
13
|
return events;
|
|
@@ -87,6 +89,7 @@ function handleSystemLog(log, programId = driftProgramId) {
|
|
|
87
89
|
class ExecutionContext {
|
|
88
90
|
constructor() {
|
|
89
91
|
this.stack = [];
|
|
92
|
+
this.ixStack = [];
|
|
90
93
|
}
|
|
91
94
|
program() {
|
|
92
95
|
if (!this.stack.length) {
|
|
@@ -103,4 +106,94 @@ class ExecutionContext {
|
|
|
103
106
|
}
|
|
104
107
|
this.stack.pop();
|
|
105
108
|
}
|
|
109
|
+
ix() {
|
|
110
|
+
if (!this.ixStack.length) {
|
|
111
|
+
throw new Error('Expected the ix stack to have elements');
|
|
112
|
+
}
|
|
113
|
+
return this.ixStack[this.ixStack.length - 1];
|
|
114
|
+
}
|
|
115
|
+
pushIx(newIx) {
|
|
116
|
+
this.ixStack.push(newIx);
|
|
117
|
+
}
|
|
118
|
+
popIx() {
|
|
119
|
+
this.ixStack.pop();
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
function parseLogsForCuUsage(logs, programId = driftProgramId) {
|
|
123
|
+
const cuUsageEvents = [];
|
|
124
|
+
const execution = new ExecutionContext();
|
|
125
|
+
for (const log of logs) {
|
|
126
|
+
if (log.startsWith('Log truncated')) {
|
|
127
|
+
break;
|
|
128
|
+
}
|
|
129
|
+
const [newProgram, newIx, didPopProgram, didPopIx] = handleLogForCuUsage(execution, log, programId);
|
|
130
|
+
if (newProgram) {
|
|
131
|
+
execution.push(newProgram);
|
|
132
|
+
}
|
|
133
|
+
if (newIx) {
|
|
134
|
+
execution.pushIx(newIx);
|
|
135
|
+
}
|
|
136
|
+
if (didPopProgram) {
|
|
137
|
+
execution.pop();
|
|
138
|
+
}
|
|
139
|
+
if (didPopIx !== null) {
|
|
140
|
+
cuUsageEvents.push({
|
|
141
|
+
name: 'CuUsage',
|
|
142
|
+
data: {
|
|
143
|
+
instruction: execution.ix(),
|
|
144
|
+
cuUsage: didPopIx,
|
|
145
|
+
},
|
|
146
|
+
});
|
|
147
|
+
execution.popIx();
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
return cuUsageEvents;
|
|
151
|
+
}
|
|
152
|
+
exports.parseLogsForCuUsage = parseLogsForCuUsage;
|
|
153
|
+
function handleLogForCuUsage(execution, log, programId = driftProgramId) {
|
|
154
|
+
if (execution.stack.length > 0 && execution.program() === programId) {
|
|
155
|
+
return handleProgramLogForCuUsage(log, programId);
|
|
156
|
+
}
|
|
157
|
+
else {
|
|
158
|
+
return handleSystemLogForCuUsage(log, programId);
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
function handleProgramLogForCuUsage(log, programId = driftProgramId) {
|
|
162
|
+
if (log.startsWith(PROGRAM_INSTRUCTION)) {
|
|
163
|
+
const ixStr = log.slice(PROGRAM_INSTRUCTION_START_INDEX);
|
|
164
|
+
return [null, ixStr, false, null];
|
|
165
|
+
}
|
|
166
|
+
else {
|
|
167
|
+
return handleSystemLogForCuUsage(log, programId);
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
function handleSystemLogForCuUsage(log, programId = driftProgramId) {
|
|
171
|
+
// System component.
|
|
172
|
+
const logStart = log.split(':')[0];
|
|
173
|
+
const programStart = `Program ${programId} invoke`;
|
|
174
|
+
// Did the program finish executing?
|
|
175
|
+
if (logStart.match(/^Program (.*) success/g) !== null) {
|
|
176
|
+
return [null, null, true, null];
|
|
177
|
+
// Recursive call.
|
|
178
|
+
}
|
|
179
|
+
else if (logStart.startsWith(programStart)) {
|
|
180
|
+
return [programId, null, false, null];
|
|
181
|
+
// Consumed CU log.
|
|
182
|
+
}
|
|
183
|
+
else if (log.startsWith(`Program ${programId} consumed `)) {
|
|
184
|
+
// Extract CU usage, e.g. 'Program ... consumed 29242 of 199700 compute units'
|
|
185
|
+
// We need to extract the consumed value (29242)
|
|
186
|
+
const matches = log.match(/consumed (\d+) of \d+ compute units/);
|
|
187
|
+
if (matches) {
|
|
188
|
+
return [null, null, false, Number(matches[1])];
|
|
189
|
+
}
|
|
190
|
+
return [null, null, false, null];
|
|
191
|
+
}
|
|
192
|
+
// CPI call.
|
|
193
|
+
else if (logStart.includes('invoke')) {
|
|
194
|
+
return ['cpi', null, false, null]; // Any string will do.
|
|
195
|
+
}
|
|
196
|
+
else {
|
|
197
|
+
return [null, null, false, null];
|
|
198
|
+
}
|
|
106
199
|
}
|
|
@@ -52,7 +52,7 @@ export type EventMap = {
|
|
|
52
52
|
LPSwapRecord: Event<LPSwapRecord>;
|
|
53
53
|
};
|
|
54
54
|
export type EventType = keyof EventMap;
|
|
55
|
-
export type DriftEvent = Event<DepositRecord> | Event<FundingPaymentRecord> | Event<LiquidationRecord> | Event<FundingRateRecord> | Event<OrderRecord> | Event<OrderActionRecord> | Event<SettlePnlRecord> | Event<NewUserRecord> | Event<LPRecord> | Event<InsuranceFundRecord> | Event<SpotInterestRecord> | Event<InsuranceFundStakeRecord> | Event<CurveRecord> | Event<SwapRecord> | Event<SpotMarketVaultDepositRecord> | Event<SignedMsgOrderRecord> | Event<DeleteUserRecord> | Event<FuelSweepRecord> | Event<FuelSeasonRecord> | Event<InsuranceFundSwapRecord> | Event<TransferProtocolIfSharesToRevenuePoolRecord> | Event<LPSettleRecord> | Event<LPMintRedeemRecord> | Event<LPSwapRecord> | Event<LPBorrowLendDepositRecord>;
|
|
55
|
+
export type DriftEvent = Event<DepositRecord> | Event<FundingPaymentRecord> | Event<LiquidationRecord> | Event<FundingRateRecord> | Event<OrderRecord> | Event<OrderActionRecord> | Event<SettlePnlRecord> | Event<NewUserRecord> | Event<LPRecord> | Event<InsuranceFundRecord> | Event<SpotInterestRecord> | Event<InsuranceFundStakeRecord> | Event<CurveRecord> | Event<SwapRecord> | Event<SpotMarketVaultDepositRecord> | Event<SignedMsgOrderRecord> | Event<DeleteUserRecord> | Event<FuelSweepRecord> | Event<FuelSeasonRecord> | Event<InsuranceFundSwapRecord> | Event<TransferProtocolIfSharesToRevenuePoolRecord> | Event<LPSettleRecord> | Event<LPMintRedeemRecord> | Event<LPSwapRecord> | Event<LPBorrowLendDepositRecord> | Event<CuUsage>;
|
|
56
56
|
export interface EventSubscriberEvents {
|
|
57
57
|
newEvent: (event: WrappedEvent<EventType>) => void;
|
|
58
58
|
}
|
|
@@ -84,3 +84,22 @@ export type EventsServerLogProviderConfig = StreamingLogProviderConfig & {
|
|
|
84
84
|
url: string;
|
|
85
85
|
};
|
|
86
86
|
export type LogProviderConfig = WebSocketLogProviderConfig | PollingLogProviderConfig | EventsServerLogProviderConfig;
|
|
87
|
+
export type CuUsageEvent = {
|
|
88
|
+
name: 'CuUsage';
|
|
89
|
+
fields: [
|
|
90
|
+
{
|
|
91
|
+
name: 'instruction';
|
|
92
|
+
type: 'string';
|
|
93
|
+
index: false;
|
|
94
|
+
},
|
|
95
|
+
{
|
|
96
|
+
name: 'cuUsage';
|
|
97
|
+
type: 'u32';
|
|
98
|
+
index: false;
|
|
99
|
+
}
|
|
100
|
+
];
|
|
101
|
+
};
|
|
102
|
+
export type CuUsage = {
|
|
103
|
+
instruction: string;
|
|
104
|
+
cuUsage: number;
|
|
105
|
+
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"perpMarkets.d.ts","sourceRoot":"","sources":["../../../src/constants/perpMarkets.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC5C,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AACxC,OAAO,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAC;AAErC,MAAM,MAAM,gBAAgB,GAAG;IAC9B,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAC;IACpB,MAAM,EAAE,MAAM,CAAC;IACf,eAAe,EAAE,MAAM,CAAC;IACxB,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,EAAE,MAAM,CAAC;IACjB,MAAM,EAAE,SAAS,CAAC;IAClB,YAAY,EAAE,YAAY,CAAC;IAC3B,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,WAAW,CAAC,EAAE,MAAM,CAAC;CACrB,CAAC;AAEF,eAAO,MAAM,iBAAiB,EAAE,gBAAgB,EA6W/C,CAAC;AAEF,eAAO,MAAM,kBAAkB,EAAE,gBAAgB,
|
|
1
|
+
{"version":3,"file":"perpMarkets.d.ts","sourceRoot":"","sources":["../../../src/constants/perpMarkets.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC5C,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AACxC,OAAO,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAC;AAErC,MAAM,MAAM,gBAAgB,GAAG;IAC9B,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAC;IACpB,MAAM,EAAE,MAAM,CAAC;IACf,eAAe,EAAE,MAAM,CAAC;IACxB,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,EAAE,MAAM,CAAC;IACjB,MAAM,EAAE,SAAS,CAAC;IAClB,YAAY,EAAE,YAAY,CAAC;IAC3B,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,WAAW,CAAC,EAAE,MAAM,CAAC;CACrB,CAAC;AAEF,eAAO,MAAM,iBAAiB,EAAE,gBAAgB,EA6W/C,CAAC;AAEF,eAAO,MAAM,kBAAkB,EAAE,gBAAgB,EA8+BhD,CAAC;AAEF,eAAO,MAAM,WAAW,EAAE;KAAG,GAAG,IAAI,QAAQ,GAAG,gBAAgB,EAAE;CAGhE,CAAC"}
|
|
@@ -1252,6 +1252,41 @@ exports.MainnetPerpMarkets = [
|
|
|
1252
1252
|
pythFeedId: '0xf2b3ab1c49e35e881003c3c0482d18b181a1560b697b844c24c8f85aba1cab95',
|
|
1253
1253
|
pythLazerId: 2316,
|
|
1254
1254
|
},
|
|
1255
|
+
{
|
|
1256
|
+
fullName: 'ZCash',
|
|
1257
|
+
category: ['Privacy'],
|
|
1258
|
+
symbol: 'ZEC-PERP',
|
|
1259
|
+
baseAssetSymbol: 'ZEC',
|
|
1260
|
+
marketIndex: 79,
|
|
1261
|
+
oracle: new web3_js_1.PublicKey('BXunfRSyiQWJHv88qMvE42mpMpksWEC8Bf13p2msnRms'),
|
|
1262
|
+
launchTs: 1760366017000,
|
|
1263
|
+
oracleSource: types_1.OracleSource.PYTH_LAZER,
|
|
1264
|
+
pythFeedId: '0xbe9b59d178f0d6a97ab4c343bff2aa69caa1eaae3e9048a65788c529b125bb24',
|
|
1265
|
+
pythLazerId: 66,
|
|
1266
|
+
},
|
|
1267
|
+
{
|
|
1268
|
+
fullName: 'Mantle',
|
|
1269
|
+
category: ['L1'],
|
|
1270
|
+
symbol: 'MNT-PERP',
|
|
1271
|
+
baseAssetSymbol: 'MNT',
|
|
1272
|
+
marketIndex: 80,
|
|
1273
|
+
oracle: new web3_js_1.PublicKey('Gy7cJ4U1nxMA44XXC3hwqkpcxEB1mZTYiwJVkaqZfU7u'),
|
|
1274
|
+
launchTs: 1760366017000,
|
|
1275
|
+
oracleSource: types_1.OracleSource.PYTH_LAZER,
|
|
1276
|
+
pythFeedId: '0x4e3037c822d852d79af3ac80e35eb420ee3b870dca49f9344a38ef4773fb0585',
|
|
1277
|
+
pythLazerId: 199,
|
|
1278
|
+
},
|
|
1279
|
+
{
|
|
1280
|
+
fullName: '1KPUMP',
|
|
1281
|
+
category: ['Launchpad'],
|
|
1282
|
+
symbol: '1KPUMP-PERP',
|
|
1283
|
+
baseAssetSymbol: '1KPUMP',
|
|
1284
|
+
marketIndex: 81,
|
|
1285
|
+
oracle: new web3_js_1.PublicKey('5r8RWTaRiMgr9Lph3FTUE3sGb1vymhpCrm83Bovjfcps'),
|
|
1286
|
+
launchTs: 1760366017000,
|
|
1287
|
+
oracleSource: types_1.OracleSource.PYTH_LAZER_1K,
|
|
1288
|
+
pythLazerId: 1578,
|
|
1289
|
+
},
|
|
1255
1290
|
];
|
|
1256
1291
|
exports.PerpMarkets = {
|
|
1257
1292
|
devnet: exports.DevnetPerpMarkets,
|
|
@@ -1,7 +1,9 @@
|
|
|
1
1
|
import { Program, Event } from '@coral-xyz/anchor';
|
|
2
|
+
import { CuUsageEvent } from './types';
|
|
2
3
|
export declare function parseLogs(program: Program, logs: string[], programId?: string): Event[];
|
|
3
4
|
export declare function parseLogsWithRaw(program: Program, logs: string[], programId?: string): {
|
|
4
5
|
events: Event[];
|
|
5
6
|
rawLogs: string[];
|
|
6
7
|
};
|
|
8
|
+
export declare function parseLogsForCuUsage(logs: string[], programId?: string): Event<CuUsageEvent>[];
|
|
7
9
|
//# sourceMappingURL=parse.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"parse.d.ts","sourceRoot":"","sources":["../../../src/events/parse.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAC;
|
|
1
|
+
{"version":3,"file":"parse.d.ts","sourceRoot":"","sources":["../../../src/events/parse.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAC;AACnD,OAAO,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAUvC,wBAAgB,SAAS,CACxB,OAAO,EAAE,OAAO,EAChB,IAAI,EAAE,MAAM,EAAE,EACd,SAAS,SAAiB,GACxB,KAAK,EAAE,CAGT;AAED,wBAAgB,gBAAgB,CAC/B,OAAO,EAAE,OAAO,EAChB,IAAI,EAAE,MAAM,EAAE,EACd,SAAS,SAAiB,GACxB;IAAE,MAAM,EAAE,KAAK,EAAE,CAAC;IAAC,OAAO,EAAE,MAAM,EAAE,CAAA;CAAE,CA2BxC;AAsGD,wBAAgB,mBAAmB,CAClC,IAAI,EAAE,MAAM,EAAE,EACd,SAAS,SAAiB,GACxB,KAAK,CAAC,YAAY,CAAC,EAAE,CAmCvB"}
|
package/lib/node/events/parse.js
CHANGED
|
@@ -1,11 +1,13 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.parseLogsWithRaw = exports.parseLogs = void 0;
|
|
3
|
+
exports.parseLogsForCuUsage = exports.parseLogsWithRaw = exports.parseLogs = void 0;
|
|
4
4
|
const driftProgramId = 'dRiftyHA39MWEi3m9aunc5MzRF1JYuBsbn6VPcn33UH';
|
|
5
5
|
const PROGRAM_LOG = 'Program log: ';
|
|
6
|
+
const PROGRAM_INSTRUCTION = 'Program log: Instruction: ';
|
|
6
7
|
const PROGRAM_DATA = 'Program data: ';
|
|
7
8
|
const PROGRAM_LOG_START_INDEX = PROGRAM_LOG.length;
|
|
8
9
|
const PROGRAM_DATA_START_INDEX = PROGRAM_DATA.length;
|
|
10
|
+
const PROGRAM_INSTRUCTION_START_INDEX = PROGRAM_INSTRUCTION.length;
|
|
9
11
|
function parseLogs(program, logs, programId = driftProgramId) {
|
|
10
12
|
const { events } = parseLogsWithRaw(program, logs, programId);
|
|
11
13
|
return events;
|
|
@@ -87,6 +89,7 @@ function handleSystemLog(log, programId = driftProgramId) {
|
|
|
87
89
|
class ExecutionContext {
|
|
88
90
|
constructor() {
|
|
89
91
|
this.stack = [];
|
|
92
|
+
this.ixStack = [];
|
|
90
93
|
}
|
|
91
94
|
program() {
|
|
92
95
|
if (!this.stack.length) {
|
|
@@ -103,4 +106,94 @@ class ExecutionContext {
|
|
|
103
106
|
}
|
|
104
107
|
this.stack.pop();
|
|
105
108
|
}
|
|
109
|
+
ix() {
|
|
110
|
+
if (!this.ixStack.length) {
|
|
111
|
+
throw new Error('Expected the ix stack to have elements');
|
|
112
|
+
}
|
|
113
|
+
return this.ixStack[this.ixStack.length - 1];
|
|
114
|
+
}
|
|
115
|
+
pushIx(newIx) {
|
|
116
|
+
this.ixStack.push(newIx);
|
|
117
|
+
}
|
|
118
|
+
popIx() {
|
|
119
|
+
this.ixStack.pop();
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
function parseLogsForCuUsage(logs, programId = driftProgramId) {
|
|
123
|
+
const cuUsageEvents = [];
|
|
124
|
+
const execution = new ExecutionContext();
|
|
125
|
+
for (const log of logs) {
|
|
126
|
+
if (log.startsWith('Log truncated')) {
|
|
127
|
+
break;
|
|
128
|
+
}
|
|
129
|
+
const [newProgram, newIx, didPopProgram, didPopIx] = handleLogForCuUsage(execution, log, programId);
|
|
130
|
+
if (newProgram) {
|
|
131
|
+
execution.push(newProgram);
|
|
132
|
+
}
|
|
133
|
+
if (newIx) {
|
|
134
|
+
execution.pushIx(newIx);
|
|
135
|
+
}
|
|
136
|
+
if (didPopProgram) {
|
|
137
|
+
execution.pop();
|
|
138
|
+
}
|
|
139
|
+
if (didPopIx !== null) {
|
|
140
|
+
cuUsageEvents.push({
|
|
141
|
+
name: 'CuUsage',
|
|
142
|
+
data: {
|
|
143
|
+
instruction: execution.ix(),
|
|
144
|
+
cuUsage: didPopIx,
|
|
145
|
+
},
|
|
146
|
+
});
|
|
147
|
+
execution.popIx();
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
return cuUsageEvents;
|
|
151
|
+
}
|
|
152
|
+
exports.parseLogsForCuUsage = parseLogsForCuUsage;
|
|
153
|
+
function handleLogForCuUsage(execution, log, programId = driftProgramId) {
|
|
154
|
+
if (execution.stack.length > 0 && execution.program() === programId) {
|
|
155
|
+
return handleProgramLogForCuUsage(log, programId);
|
|
156
|
+
}
|
|
157
|
+
else {
|
|
158
|
+
return handleSystemLogForCuUsage(log, programId);
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
function handleProgramLogForCuUsage(log, programId = driftProgramId) {
|
|
162
|
+
if (log.startsWith(PROGRAM_INSTRUCTION)) {
|
|
163
|
+
const ixStr = log.slice(PROGRAM_INSTRUCTION_START_INDEX);
|
|
164
|
+
return [null, ixStr, false, null];
|
|
165
|
+
}
|
|
166
|
+
else {
|
|
167
|
+
return handleSystemLogForCuUsage(log, programId);
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
function handleSystemLogForCuUsage(log, programId = driftProgramId) {
|
|
171
|
+
// System component.
|
|
172
|
+
const logStart = log.split(':')[0];
|
|
173
|
+
const programStart = `Program ${programId} invoke`;
|
|
174
|
+
// Did the program finish executing?
|
|
175
|
+
if (logStart.match(/^Program (.*) success/g) !== null) {
|
|
176
|
+
return [null, null, true, null];
|
|
177
|
+
// Recursive call.
|
|
178
|
+
}
|
|
179
|
+
else if (logStart.startsWith(programStart)) {
|
|
180
|
+
return [programId, null, false, null];
|
|
181
|
+
// Consumed CU log.
|
|
182
|
+
}
|
|
183
|
+
else if (log.startsWith(`Program ${programId} consumed `)) {
|
|
184
|
+
// Extract CU usage, e.g. 'Program ... consumed 29242 of 199700 compute units'
|
|
185
|
+
// We need to extract the consumed value (29242)
|
|
186
|
+
const matches = log.match(/consumed (\d+) of \d+ compute units/);
|
|
187
|
+
if (matches) {
|
|
188
|
+
return [null, null, false, Number(matches[1])];
|
|
189
|
+
}
|
|
190
|
+
return [null, null, false, null];
|
|
191
|
+
}
|
|
192
|
+
// CPI call.
|
|
193
|
+
else if (logStart.includes('invoke')) {
|
|
194
|
+
return ['cpi', null, false, null]; // Any string will do.
|
|
195
|
+
}
|
|
196
|
+
else {
|
|
197
|
+
return [null, null, false, null];
|
|
198
|
+
}
|
|
106
199
|
}
|
|
@@ -52,7 +52,7 @@ export type EventMap = {
|
|
|
52
52
|
LPSwapRecord: Event<LPSwapRecord>;
|
|
53
53
|
};
|
|
54
54
|
export type EventType = keyof EventMap;
|
|
55
|
-
export type DriftEvent = Event<DepositRecord> | Event<FundingPaymentRecord> | Event<LiquidationRecord> | Event<FundingRateRecord> | Event<OrderRecord> | Event<OrderActionRecord> | Event<SettlePnlRecord> | Event<NewUserRecord> | Event<LPRecord> | Event<InsuranceFundRecord> | Event<SpotInterestRecord> | Event<InsuranceFundStakeRecord> | Event<CurveRecord> | Event<SwapRecord> | Event<SpotMarketVaultDepositRecord> | Event<SignedMsgOrderRecord> | Event<DeleteUserRecord> | Event<FuelSweepRecord> | Event<FuelSeasonRecord> | Event<InsuranceFundSwapRecord> | Event<TransferProtocolIfSharesToRevenuePoolRecord> | Event<LPSettleRecord> | Event<LPMintRedeemRecord> | Event<LPSwapRecord> | Event<LPBorrowLendDepositRecord>;
|
|
55
|
+
export type DriftEvent = Event<DepositRecord> | Event<FundingPaymentRecord> | Event<LiquidationRecord> | Event<FundingRateRecord> | Event<OrderRecord> | Event<OrderActionRecord> | Event<SettlePnlRecord> | Event<NewUserRecord> | Event<LPRecord> | Event<InsuranceFundRecord> | Event<SpotInterestRecord> | Event<InsuranceFundStakeRecord> | Event<CurveRecord> | Event<SwapRecord> | Event<SpotMarketVaultDepositRecord> | Event<SignedMsgOrderRecord> | Event<DeleteUserRecord> | Event<FuelSweepRecord> | Event<FuelSeasonRecord> | Event<InsuranceFundSwapRecord> | Event<TransferProtocolIfSharesToRevenuePoolRecord> | Event<LPSettleRecord> | Event<LPMintRedeemRecord> | Event<LPSwapRecord> | Event<LPBorrowLendDepositRecord> | Event<CuUsage>;
|
|
56
56
|
export interface EventSubscriberEvents {
|
|
57
57
|
newEvent: (event: WrappedEvent<EventType>) => void;
|
|
58
58
|
}
|
|
@@ -84,4 +84,23 @@ export type EventsServerLogProviderConfig = StreamingLogProviderConfig & {
|
|
|
84
84
|
url: string;
|
|
85
85
|
};
|
|
86
86
|
export type LogProviderConfig = WebSocketLogProviderConfig | PollingLogProviderConfig | EventsServerLogProviderConfig;
|
|
87
|
+
export type CuUsageEvent = {
|
|
88
|
+
name: 'CuUsage';
|
|
89
|
+
fields: [
|
|
90
|
+
{
|
|
91
|
+
name: 'instruction';
|
|
92
|
+
type: 'string';
|
|
93
|
+
index: false;
|
|
94
|
+
},
|
|
95
|
+
{
|
|
96
|
+
name: 'cuUsage';
|
|
97
|
+
type: 'u32';
|
|
98
|
+
index: false;
|
|
99
|
+
}
|
|
100
|
+
];
|
|
101
|
+
};
|
|
102
|
+
export type CuUsage = {
|
|
103
|
+
instruction: string;
|
|
104
|
+
cuUsage: number;
|
|
105
|
+
};
|
|
87
106
|
//# sourceMappingURL=types.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/events/types.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/events/types.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@drift-labs/sdk",
|
|
3
|
-
"version": "2.142.0-beta.
|
|
3
|
+
"version": "2.142.0-beta.24",
|
|
4
4
|
"main": "lib/node/index.js",
|
|
5
5
|
"types": "lib/node/index.d.ts",
|
|
6
6
|
"module": "./lib/browser/index.js",
|
|
@@ -20,6 +20,7 @@
|
|
|
20
20
|
"test:bignum": "mocha -r ts-node/register tests/bn/**/*.ts",
|
|
21
21
|
"test:ci": "mocha -r ts-node/register tests/ci/**/*.ts",
|
|
22
22
|
"test:dlob": "mocha -r ts-node/register tests/dlob/**/*.ts",
|
|
23
|
+
"test:events": "mocha -r ts-node/register tests/events/**/*.ts",
|
|
23
24
|
"patch-and-pub": "npm version patch --force && npm publish",
|
|
24
25
|
"prettify": "prettier --check './src/***/*.ts'",
|
|
25
26
|
"prettify:fix": "prettier --write './{src,tests}/***/*.ts'",
|
|
@@ -1351,6 +1351,43 @@ export const MainnetPerpMarkets: PerpMarketConfig[] = [
|
|
|
1351
1351
|
'0xf2b3ab1c49e35e881003c3c0482d18b181a1560b697b844c24c8f85aba1cab95',
|
|
1352
1352
|
pythLazerId: 2316,
|
|
1353
1353
|
},
|
|
1354
|
+
{
|
|
1355
|
+
fullName: 'ZCash',
|
|
1356
|
+
category: ['Privacy'],
|
|
1357
|
+
symbol: 'ZEC-PERP',
|
|
1358
|
+
baseAssetSymbol: 'ZEC',
|
|
1359
|
+
marketIndex: 79,
|
|
1360
|
+
oracle: new PublicKey('BXunfRSyiQWJHv88qMvE42mpMpksWEC8Bf13p2msnRms'),
|
|
1361
|
+
launchTs: 1760366017000,
|
|
1362
|
+
oracleSource: OracleSource.PYTH_LAZER,
|
|
1363
|
+
pythFeedId:
|
|
1364
|
+
'0xbe9b59d178f0d6a97ab4c343bff2aa69caa1eaae3e9048a65788c529b125bb24',
|
|
1365
|
+
pythLazerId: 66,
|
|
1366
|
+
},
|
|
1367
|
+
{
|
|
1368
|
+
fullName: 'Mantle',
|
|
1369
|
+
category: ['L1'],
|
|
1370
|
+
symbol: 'MNT-PERP',
|
|
1371
|
+
baseAssetSymbol: 'MNT',
|
|
1372
|
+
marketIndex: 80,
|
|
1373
|
+
oracle: new PublicKey('Gy7cJ4U1nxMA44XXC3hwqkpcxEB1mZTYiwJVkaqZfU7u'),
|
|
1374
|
+
launchTs: 1760366017000,
|
|
1375
|
+
oracleSource: OracleSource.PYTH_LAZER,
|
|
1376
|
+
pythFeedId:
|
|
1377
|
+
'0x4e3037c822d852d79af3ac80e35eb420ee3b870dca49f9344a38ef4773fb0585',
|
|
1378
|
+
pythLazerId: 199,
|
|
1379
|
+
},
|
|
1380
|
+
{
|
|
1381
|
+
fullName: '1KPUMP',
|
|
1382
|
+
category: ['Launchpad'],
|
|
1383
|
+
symbol: '1KPUMP-PERP',
|
|
1384
|
+
baseAssetSymbol: '1KPUMP',
|
|
1385
|
+
marketIndex: 81,
|
|
1386
|
+
oracle: new PublicKey('5r8RWTaRiMgr9Lph3FTUE3sGb1vymhpCrm83Bovjfcps'),
|
|
1387
|
+
launchTs: 1760366017000,
|
|
1388
|
+
oracleSource: OracleSource.PYTH_LAZER_1K,
|
|
1389
|
+
pythLazerId: 1578,
|
|
1390
|
+
},
|
|
1354
1391
|
];
|
|
1355
1392
|
|
|
1356
1393
|
export const PerpMarkets: { [key in DriftEnv]: PerpMarketConfig[] } = {
|
package/src/events/parse.ts
CHANGED
|
@@ -1,10 +1,13 @@
|
|
|
1
1
|
import { Program, Event } from '@coral-xyz/anchor';
|
|
2
|
+
import { CuUsageEvent } from './types';
|
|
2
3
|
|
|
3
4
|
const driftProgramId = 'dRiftyHA39MWEi3m9aunc5MzRF1JYuBsbn6VPcn33UH';
|
|
4
5
|
const PROGRAM_LOG = 'Program log: ';
|
|
6
|
+
const PROGRAM_INSTRUCTION = 'Program log: Instruction: ';
|
|
5
7
|
const PROGRAM_DATA = 'Program data: ';
|
|
6
8
|
const PROGRAM_LOG_START_INDEX = PROGRAM_LOG.length;
|
|
7
9
|
const PROGRAM_DATA_START_INDEX = PROGRAM_DATA.length;
|
|
10
|
+
const PROGRAM_INSTRUCTION_START_INDEX = PROGRAM_INSTRUCTION.length;
|
|
8
11
|
|
|
9
12
|
export function parseLogs(
|
|
10
13
|
program: Program,
|
|
@@ -112,6 +115,7 @@ function handleSystemLog(
|
|
|
112
115
|
// executing for a given log.
|
|
113
116
|
class ExecutionContext {
|
|
114
117
|
stack: string[] = [];
|
|
118
|
+
ixStack: string[] = [];
|
|
115
119
|
|
|
116
120
|
program(): string {
|
|
117
121
|
if (!this.stack.length) {
|
|
@@ -130,4 +134,115 @@ class ExecutionContext {
|
|
|
130
134
|
}
|
|
131
135
|
this.stack.pop();
|
|
132
136
|
}
|
|
137
|
+
|
|
138
|
+
ix(): string {
|
|
139
|
+
if (!this.ixStack.length) {
|
|
140
|
+
throw new Error('Expected the ix stack to have elements');
|
|
141
|
+
}
|
|
142
|
+
return this.ixStack[this.ixStack.length - 1];
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
pushIx(newIx: string) {
|
|
146
|
+
this.ixStack.push(newIx);
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
popIx() {
|
|
150
|
+
this.ixStack.pop();
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
|
|
154
|
+
export function parseLogsForCuUsage(
|
|
155
|
+
logs: string[],
|
|
156
|
+
programId = driftProgramId
|
|
157
|
+
): Event<CuUsageEvent>[] {
|
|
158
|
+
const cuUsageEvents: Event<CuUsageEvent>[] = [];
|
|
159
|
+
|
|
160
|
+
const execution = new ExecutionContext();
|
|
161
|
+
for (const log of logs) {
|
|
162
|
+
if (log.startsWith('Log truncated')) {
|
|
163
|
+
break;
|
|
164
|
+
}
|
|
165
|
+
|
|
166
|
+
const [newProgram, newIx, didPopProgram, didPopIx] = handleLogForCuUsage(
|
|
167
|
+
execution,
|
|
168
|
+
log,
|
|
169
|
+
programId
|
|
170
|
+
);
|
|
171
|
+
if (newProgram) {
|
|
172
|
+
execution.push(newProgram);
|
|
173
|
+
}
|
|
174
|
+
if (newIx) {
|
|
175
|
+
execution.pushIx(newIx);
|
|
176
|
+
}
|
|
177
|
+
if (didPopProgram) {
|
|
178
|
+
execution.pop();
|
|
179
|
+
}
|
|
180
|
+
if (didPopIx !== null) {
|
|
181
|
+
cuUsageEvents.push({
|
|
182
|
+
name: 'CuUsage',
|
|
183
|
+
data: {
|
|
184
|
+
instruction: execution.ix(),
|
|
185
|
+
cuUsage: didPopIx!,
|
|
186
|
+
},
|
|
187
|
+
} as any);
|
|
188
|
+
execution.popIx();
|
|
189
|
+
}
|
|
190
|
+
}
|
|
191
|
+
return cuUsageEvents;
|
|
192
|
+
}
|
|
193
|
+
|
|
194
|
+
function handleLogForCuUsage(
|
|
195
|
+
execution: ExecutionContext,
|
|
196
|
+
log: string,
|
|
197
|
+
programId = driftProgramId
|
|
198
|
+
): [string | null, string | null, boolean, number | null] {
|
|
199
|
+
if (execution.stack.length > 0 && execution.program() === programId) {
|
|
200
|
+
return handleProgramLogForCuUsage(log, programId);
|
|
201
|
+
} else {
|
|
202
|
+
return handleSystemLogForCuUsage(log, programId);
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
|
|
206
|
+
function handleProgramLogForCuUsage(
|
|
207
|
+
log: string,
|
|
208
|
+
programId = driftProgramId
|
|
209
|
+
): [string | null, string | null, boolean, number | null] {
|
|
210
|
+
if (log.startsWith(PROGRAM_INSTRUCTION)) {
|
|
211
|
+
const ixStr = log.slice(PROGRAM_INSTRUCTION_START_INDEX);
|
|
212
|
+
return [null, ixStr, false, null];
|
|
213
|
+
} else {
|
|
214
|
+
return handleSystemLogForCuUsage(log, programId);
|
|
215
|
+
}
|
|
216
|
+
}
|
|
217
|
+
|
|
218
|
+
function handleSystemLogForCuUsage(
|
|
219
|
+
log: string,
|
|
220
|
+
programId = driftProgramId
|
|
221
|
+
): [string | null, string | null, boolean, number | null] {
|
|
222
|
+
// System component.
|
|
223
|
+
const logStart = log.split(':')[0];
|
|
224
|
+
const programStart = `Program ${programId} invoke`;
|
|
225
|
+
|
|
226
|
+
// Did the program finish executing?
|
|
227
|
+
if (logStart.match(/^Program (.*) success/g) !== null) {
|
|
228
|
+
return [null, null, true, null];
|
|
229
|
+
// Recursive call.
|
|
230
|
+
} else if (logStart.startsWith(programStart)) {
|
|
231
|
+
return [programId, null, false, null];
|
|
232
|
+
// Consumed CU log.
|
|
233
|
+
} else if (log.startsWith(`Program ${programId} consumed `)) {
|
|
234
|
+
// Extract CU usage, e.g. 'Program ... consumed 29242 of 199700 compute units'
|
|
235
|
+
// We need to extract the consumed value (29242)
|
|
236
|
+
const matches = log.match(/consumed (\d+) of \d+ compute units/);
|
|
237
|
+
if (matches) {
|
|
238
|
+
return [null, null, false, Number(matches[1])];
|
|
239
|
+
}
|
|
240
|
+
return [null, null, false, null];
|
|
241
|
+
}
|
|
242
|
+
// CPI call.
|
|
243
|
+
else if (logStart.includes('invoke')) {
|
|
244
|
+
return ['cpi', null, false, null]; // Any string will do.
|
|
245
|
+
} else {
|
|
246
|
+
return [null, null, false, null];
|
|
247
|
+
}
|
|
133
248
|
}
|
package/src/events/types.ts
CHANGED
|
@@ -149,7 +149,8 @@ export type DriftEvent =
|
|
|
149
149
|
| Event<LPSettleRecord>
|
|
150
150
|
| Event<LPMintRedeemRecord>
|
|
151
151
|
| Event<LPSwapRecord>
|
|
152
|
-
| Event<LPBorrowLendDepositRecord
|
|
152
|
+
| Event<LPBorrowLendDepositRecord>
|
|
153
|
+
| Event<CuUsage>;
|
|
153
154
|
|
|
154
155
|
export interface EventSubscriberEvents {
|
|
155
156
|
newEvent: (event: WrappedEvent<EventType>) => void;
|
|
@@ -213,3 +214,24 @@ export type LogProviderConfig =
|
|
|
213
214
|
| WebSocketLogProviderConfig
|
|
214
215
|
| PollingLogProviderConfig
|
|
215
216
|
| EventsServerLogProviderConfig;
|
|
217
|
+
|
|
218
|
+
export type CuUsageEvent = {
|
|
219
|
+
name: 'CuUsage';
|
|
220
|
+
fields: [
|
|
221
|
+
{
|
|
222
|
+
name: 'instruction';
|
|
223
|
+
type: 'string';
|
|
224
|
+
index: false;
|
|
225
|
+
},
|
|
226
|
+
{
|
|
227
|
+
name: 'cuUsage';
|
|
228
|
+
type: 'u32';
|
|
229
|
+
index: false;
|
|
230
|
+
},
|
|
231
|
+
];
|
|
232
|
+
};
|
|
233
|
+
|
|
234
|
+
export type CuUsage = {
|
|
235
|
+
instruction: string;
|
|
236
|
+
cuUsage: number;
|
|
237
|
+
};
|
|
@@ -0,0 +1,139 @@
|
|
|
1
|
+
import { expect } from 'chai';
|
|
2
|
+
import { parseLogsForCuUsage } from '../../src/events/parse';
|
|
3
|
+
|
|
4
|
+
// if you used the '@types/mocha' method to install mocha type definitions, uncomment the following line
|
|
5
|
+
// import 'mocha';
|
|
6
|
+
|
|
7
|
+
describe('parseLogsForCuUsage Tests', () => {
|
|
8
|
+
it('can parse single ix', () => {
|
|
9
|
+
const logs = [
|
|
10
|
+
'Program ComputeBudget111111111111111111111111111111 invoke [1]',
|
|
11
|
+
'Program ComputeBudget111111111111111111111111111111 success',
|
|
12
|
+
'Program ComputeBudget111111111111111111111111111111 invoke [1]',
|
|
13
|
+
'Program ComputeBudget111111111111111111111111111111 success',
|
|
14
|
+
'Program dRiftyHA39MWEi3m9aunc5MzRF1JYuBsbn6VPcn33UH invoke [1]',
|
|
15
|
+
'Program log: Instruction: UpdateFundingRate',
|
|
16
|
+
'Program log: correcting mark twap update (oracle previously invalid for 1625 seconds)',
|
|
17
|
+
'Program data: Ze4o5EYuPXWjSrNoAAAAADkUAAAAAAAAZTIKAAAAAAAAAAAAAAAAAGwIAGYvdqgAAAAAAAAAAAAxpQahVMKdAAAAAAAAAAAAK0cfnMcFowAAAAAAAAAAAGUyCgAAAAAAAAAAAAAAAAAbXpy4n6WoAAAAAAAAAAAAGAAXbsHunQAAAAAAAAAAAObum9evM6MAAAAAAAAAAAAA9PA5+UYKAAAAAAAAAAAAAKhuDZ0RCgAAAAAAAAAAAABMgixcNQAAAAAAAAAAAAA9NqYKSgAAAAAAAAAAAAAA4nylcy0AAAAAAAAAAAAAAMvCAAAAAAAAAAAAAAAAAACOjAkAAAAAAET3AgAAAAAAAAAAAAAAAAAMAQAAHgA=',
|
|
18
|
+
'Program data: RAP/GoVbk/6jSrNoAAAAAA0rAAAAAAAAHgBxcgEAAAAAAHFyAQAAAAAAAAAAAAAAAABxcgEAAAAAAAAAAAAAAAAAZRuYAQAAAAAAAAAAAAAAAJMNmAEAAAAAAAAAAAAAAAC0eAkAAAAAAByBCQAAAAAAWUbv4v////8ATIIsXDUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA==',
|
|
19
|
+
'Program dRiftyHA39MWEi3m9aunc5MzRF1JYuBsbn6VPcn33UH consumed 102636 of 143817 compute units',
|
|
20
|
+
'Program dRiftyHA39MWEi3m9aunc5MzRF1JYuBsbn6VPcn33UH success',
|
|
21
|
+
];
|
|
22
|
+
const cuUsage = parseLogsForCuUsage(logs);
|
|
23
|
+
expect(cuUsage).to.deep.equal([
|
|
24
|
+
{
|
|
25
|
+
name: 'CuUsage',
|
|
26
|
+
data: {
|
|
27
|
+
instruction: 'UpdateFundingRate',
|
|
28
|
+
cuUsage: 102636,
|
|
29
|
+
}
|
|
30
|
+
},
|
|
31
|
+
]);
|
|
32
|
+
});
|
|
33
|
+
|
|
34
|
+
it('can parse multiple ixs', () => {
|
|
35
|
+
const logs = [
|
|
36
|
+
'Program ComputeBudget111111111111111111111111111111 invoke [1]',
|
|
37
|
+
'Program ComputeBudget111111111111111111111111111111 success',
|
|
38
|
+
'Program ComputeBudget111111111111111111111111111111 invoke [1]',
|
|
39
|
+
'Program ComputeBudget111111111111111111111111111111 success',
|
|
40
|
+
'Program dRiftyHA39MWEi3m9aunc5MzRF1JYuBsbn6VPcn33UH invoke [1]',
|
|
41
|
+
'Program log: Instruction: PostPythLazerOracleUpdate',
|
|
42
|
+
'Program log: Skipping new lazer update. current ts 1756622092550000 >= next ts 1756622092000000',
|
|
43
|
+
'Program log: Skipping new lazer update. current ts 1756622092550000 >= next ts 1756622092000000',
|
|
44
|
+
'Program log: Skipping new lazer update. current ts 1756622092550000 >= next ts 1756622092000000',
|
|
45
|
+
'Program log: Price updated to 433158894',
|
|
46
|
+
'Program log: Posting new lazer update. current ts 1756622079000000 < next ts 1756622092000000',
|
|
47
|
+
'Program dRiftyHA39MWEi3m9aunc5MzRF1JYuBsbn6VPcn33UH consumed 29242 of 199700 compute units',
|
|
48
|
+
'Program dRiftyHA39MWEi3m9aunc5MzRF1JYuBsbn6VPcn33UH success',
|
|
49
|
+
'Program dRiftyHA39MWEi3m9aunc5MzRF1JYuBsbn6VPcn33UH invoke [1]',
|
|
50
|
+
'Program log: Instruction: UpdatePerpBidAskTwap',
|
|
51
|
+
'Program log: estimated_bid = None estimated_ask = None',
|
|
52
|
+
'Program log: after amm bid twap = 204332308 -> 204328128 \n ask twap = 204350474 -> 204347149 \n ts = 1756622080 -> 1756622092',
|
|
53
|
+
'Program dRiftyHA39MWEi3m9aunc5MzRF1JYuBsbn6VPcn33UH consumed 71006 of 170458 compute units',
|
|
54
|
+
'Program dRiftyHA39MWEi3m9aunc5MzRF1JYuBsbn6VPcn33UH success',
|
|
55
|
+
];
|
|
56
|
+
const cuUsage = parseLogsForCuUsage(logs);
|
|
57
|
+
expect(cuUsage).to.deep.equal([
|
|
58
|
+
{
|
|
59
|
+
name: 'CuUsage',
|
|
60
|
+
data: {
|
|
61
|
+
instruction: 'PostPythLazerOracleUpdate',
|
|
62
|
+
cuUsage: 29242,
|
|
63
|
+
}
|
|
64
|
+
},
|
|
65
|
+
{
|
|
66
|
+
name: 'CuUsage',
|
|
67
|
+
data: {
|
|
68
|
+
instruction: 'UpdatePerpBidAskTwap',
|
|
69
|
+
cuUsage: 71006,
|
|
70
|
+
}
|
|
71
|
+
},
|
|
72
|
+
]);
|
|
73
|
+
});
|
|
74
|
+
|
|
75
|
+
it('can parse ixs with CPI (swaps)', () => {
|
|
76
|
+
const logs = [
|
|
77
|
+
'Program ComputeBudget111111111111111111111111111111 invoke [1]',
|
|
78
|
+
'Program ComputeBudget111111111111111111111111111111 success',
|
|
79
|
+
'Program ComputeBudget111111111111111111111111111111 invoke [1]',
|
|
80
|
+
'Program ComputeBudget111111111111111111111111111111 success',
|
|
81
|
+
'Program dRiftyHA39MWEi3m9aunc5MzRF1JYuBsbn6VPcn33UH invoke [1]',
|
|
82
|
+
'Program log: Instruction: BeginSwap',
|
|
83
|
+
'Program data: t7rLuuG7X4K7X+loAAAAAAAAoDz72UK0JwQAAAAAAAAAAMS7r8ACAAAAAAAAAAAAAAB36Aiv26cZAwAAAAAAAAAArDDOLAMAAAAAAAAAAAAAAAA1DAAUzQAAoLsNAA==',
|
|
84
|
+
'Program data: t7rLuuG7X4K7X+loAAAAAAEASQcRhBUVAQAAAAAAAAAAAG3WGn8CAAAAAAAAAAAAAADBBakRTIoAAAAAAAAAAAAAFfFDwgIAAAAAAAAAAAAAAAA1DACghgEAYOMWAA==',
|
|
85
|
+
'Program TokenkegQfeZyiNwAJbNbGKPFXCWuBvf9Ss623VQ5DA invoke [2]',
|
|
86
|
+
'Program log: Instruction: Transfer',
|
|
87
|
+
'Program TokenkegQfeZyiNwAJbNbGKPFXCWuBvf9Ss623VQ5DA consumed 4645 of 1336324 compute units',
|
|
88
|
+
'Program TokenkegQfeZyiNwAJbNbGKPFXCWuBvf9Ss623VQ5DA success',
|
|
89
|
+
'Program dRiftyHA39MWEi3m9aunc5MzRF1JYuBsbn6VPcn33UH consumed 79071 of 1399700 compute units',
|
|
90
|
+
'Program dRiftyHA39MWEi3m9aunc5MzRF1JYuBsbn6VPcn33UH success',
|
|
91
|
+
'Program JUP6LkbZbjS1jKKwapdHNy74zcZ3tLUZoi5QNyVTaV4 invoke [1]',
|
|
92
|
+
'Program log: Instruction: Route',
|
|
93
|
+
'Program SV2EYYJyRz2YhfXwXnhNAevDEui5Q6yrfyo13WtupPF invoke [2]',
|
|
94
|
+
'Program data: S3VCwUhV8CXSyrcV3EtPUNCsQJvXpBqCGUobEJZVRnl5bVAAAAAAAFUFNBYAAAAAAAAAAAAAAAAAAAAAAAAAAA==',
|
|
95
|
+
'Program TokenkegQfeZyiNwAJbNbGKPFXCWuBvf9Ss623VQ5DA invoke [3]',
|
|
96
|
+
'Program log: Instruction: Transfer',
|
|
97
|
+
'Program TokenkegQfeZyiNwAJbNbGKPFXCWuBvf9Ss623VQ5DA consumed 4645 of 1255262 compute units',
|
|
98
|
+
'Program TokenkegQfeZyiNwAJbNbGKPFXCWuBvf9Ss623VQ5DA success',
|
|
99
|
+
'Program TokenkegQfeZyiNwAJbNbGKPFXCWuBvf9Ss623VQ5DA invoke [3]',
|
|
100
|
+
'Program log: Instruction: Transfer',
|
|
101
|
+
'Program TokenkegQfeZyiNwAJbNbGKPFXCWuBvf9Ss623VQ5DA consumed 4736 of 1249195 compute units',
|
|
102
|
+
'Program TokenkegQfeZyiNwAJbNbGKPFXCWuBvf9Ss623VQ5DA success',
|
|
103
|
+
'Program SV2EYYJyRz2YhfXwXnhNAevDEui5Q6yrfyo13WtupPF consumed 69257 of 1311915 compute units',
|
|
104
|
+
'Program SV2EYYJyRz2YhfXwXnhNAevDEui5Q6yrfyo13WtupPF success',
|
|
105
|
+
'Program JUP6LkbZbjS1jKKwapdHNy74zcZ3tLUZoi5QNyVTaV4 invoke [2]',
|
|
106
|
+
'Program JUP6LkbZbjS1jKKwapdHNy74zcZ3tLUZoi5QNyVTaV4 consumed 199 of 1241147 compute units',
|
|
107
|
+
'Program JUP6LkbZbjS1jKKwapdHNy74zcZ3tLUZoi5QNyVTaV4 success',
|
|
108
|
+
'Program JUP6LkbZbjS1jKKwapdHNy74zcZ3tLUZoi5QNyVTaV4 consumed 81059 of 1320629 compute units',
|
|
109
|
+
'Program return: JUP6LkbZbjS1jKKwapdHNy74zcZ3tLUZoi5QNyVTaV4 Z/tXxXEAAAA=',
|
|
110
|
+
'Program JUP6LkbZbjS1jKKwapdHNy74zcZ3tLUZoi5QNyVTaV4 success',
|
|
111
|
+
'Program dRiftyHA39MWEi3m9aunc5MzRF1JYuBsbn6VPcn33UH invoke [1]',
|
|
112
|
+
'Program log: Instruction: EndSwap',
|
|
113
|
+
'Program TokenkegQfeZyiNwAJbNbGKPFXCWuBvf9Ss623VQ5DA invoke [2]',
|
|
114
|
+
'Program log: Instruction: Transfer',
|
|
115
|
+
'Program TokenkegQfeZyiNwAJbNbGKPFXCWuBvf9Ss623VQ5DA consumed 4736 of 1187840 compute units',
|
|
116
|
+
'Program TokenkegQfeZyiNwAJbNbGKPFXCWuBvf9Ss623VQ5DA success',
|
|
117
|
+
'Program data: ort7woo4+vG7X+loAAAAAJ1Bg8Gp9WhWrw9VRm1UiC0KW6LRC2am2mjhfd3lzm6WZ/tXxXEAAAAA6HZIFwAAAAEAAAAJdDEMAAAAANFBDwAAAAAAAAAAAAAAAAA=',
|
|
118
|
+
'Program dRiftyHA39MWEi3m9aunc5MzRF1JYuBsbn6VPcn33UH consumed 156076 of 1239570 compute units',
|
|
119
|
+
'Program dRiftyHA39MWEi3m9aunc5MzRF1JYuBsbn6VPcn33UH success',
|
|
120
|
+
];
|
|
121
|
+
const cuUsage = parseLogsForCuUsage(logs);
|
|
122
|
+
expect(cuUsage).to.deep.equal([
|
|
123
|
+
{
|
|
124
|
+
name: 'CuUsage',
|
|
125
|
+
data: {
|
|
126
|
+
instruction: 'BeginSwap',
|
|
127
|
+
cuUsage: 79071,
|
|
128
|
+
}
|
|
129
|
+
},
|
|
130
|
+
{
|
|
131
|
+
name: 'CuUsage',
|
|
132
|
+
data: {
|
|
133
|
+
instruction: 'EndSwap',
|
|
134
|
+
cuUsage: 156076,
|
|
135
|
+
}
|
|
136
|
+
},
|
|
137
|
+
]);
|
|
138
|
+
});
|
|
139
|
+
});
|