@drift-labs/sdk 2.142.0-beta.23 → 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 CHANGED
@@ -1 +1 @@
1
- 2.142.0-beta.23
1
+ 2.142.0-beta.24
@@ -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,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;AAQnD,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"}
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"}
@@ -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.23",
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'",
@@ -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
  }
@@ -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
+ });