@rivetkit/rivetkit-native 0.0.0-pr.4669.7c31bd8 → 0.0.0-pr.4672.159c9b3

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/index.d.ts CHANGED
@@ -18,7 +18,7 @@ export interface QueryResult {
18
18
  rows: Array<Array<any>>
19
19
  }
20
20
  /** Open a native SQLite database backed by the envoy's KV channel. */
21
- export declare function openDatabaseFromEnvoy(jsHandle: JsEnvoyHandle, actorId: string): Promise<JsNativeDatabase>
21
+ export declare function openDatabaseFromEnvoy(jsHandle: JsEnvoyHandle, actorId: string, preloadedEntries?: Array<JsKvEntry> | undefined | null): Promise<JsNativeDatabase>
22
22
  /** Configuration for starting the native envoy client. */
23
23
  export interface JsEnvoyConfig {
24
24
  endpoint: string
@@ -60,6 +60,9 @@ export declare function startEnvoySyncJs(config: JsEnvoyConfig, eventCallback: (
60
60
  export declare function startEnvoyJs(config: JsEnvoyConfig, eventCallback: (event: any) => void): JsEnvoyHandle
61
61
  /** Native SQLite database handle exposed to JavaScript. */
62
62
  export declare class JsNativeDatabase {
63
+ takeLastKvError(): string | null
64
+ resetVfsTelemetry(): void
65
+ snapshotVfsTelemetry(): any
63
66
  run(sql: string, params?: Array<JsBindParam> | undefined | null): Promise<ExecuteResult>
64
67
  query(sql: string, params?: Array<JsBindParam> | undefined | null): Promise<QueryResult>
65
68
  exec(sql: string): Promise<QueryResult>
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@rivetkit/rivetkit-native",
3
- "version": "0.0.0-pr.4669.7c31bd8",
3
+ "version": "0.0.0-pr.4672.159c9b3",
4
4
  "description": "Native N-API addon for RivetKit providing envoy client and SQLite access",
5
5
  "license": "Apache-2.0",
6
6
  "main": "index.js",
@@ -49,15 +49,15 @@
49
49
  },
50
50
  "dependencies": {
51
51
  "@napi-rs/cli": "^2.18.4",
52
- "@rivetkit/engine-envoy-protocol": "0.0.0-pr.4669.7c31bd8"
52
+ "@rivetkit/engine-envoy-protocol": "0.0.0-pr.4672.159c9b3"
53
53
  },
54
54
  "optionalDependencies": {
55
- "@rivetkit/rivetkit-native-darwin-arm64": "0.0.0-pr.4669.7c31bd8",
56
- "@rivetkit/rivetkit-native-darwin-x64": "0.0.0-pr.4669.7c31bd8",
57
- "@rivetkit/rivetkit-native-linux-arm64-gnu": "0.0.0-pr.4669.7c31bd8",
58
- "@rivetkit/rivetkit-native-linux-arm64-musl": "0.0.0-pr.4669.7c31bd8",
59
- "@rivetkit/rivetkit-native-linux-x64-gnu": "0.0.0-pr.4669.7c31bd8",
60
- "@rivetkit/rivetkit-native-linux-x64-musl": "0.0.0-pr.4669.7c31bd8",
61
- "@rivetkit/rivetkit-native-win32-x64-msvc": "0.0.0-pr.4669.7c31bd8"
55
+ "@rivetkit/rivetkit-native-darwin-arm64": "0.0.0-pr.4672.159c9b3",
56
+ "@rivetkit/rivetkit-native-darwin-x64": "0.0.0-pr.4672.159c9b3",
57
+ "@rivetkit/rivetkit-native-linux-arm64-gnu": "0.0.0-pr.4672.159c9b3",
58
+ "@rivetkit/rivetkit-native-linux-arm64-musl": "0.0.0-pr.4672.159c9b3",
59
+ "@rivetkit/rivetkit-native-linux-x64-gnu": "0.0.0-pr.4672.159c9b3",
60
+ "@rivetkit/rivetkit-native-linux-x64-musl": "0.0.0-pr.4672.159c9b3",
61
+ "@rivetkit/rivetkit-native-win32-x64-msvc": "0.0.0-pr.4672.159c9b3"
62
62
  }
63
63
  }
package/wrapper.d.ts CHANGED
@@ -29,9 +29,16 @@ export interface EnvoyHandle {
29
29
  sleepActor(actorId: string, generation?: number): void;
30
30
  stopActor(actorId: string, generation?: number, error?: string): void;
31
31
  destroyActor(actorId: string, generation?: number): void;
32
- setAlarm(actorId: string, alarmTs: number | null, generation?: number): void;
32
+ setAlarm(
33
+ actorId: string,
34
+ alarmTs: number | null,
35
+ generation?: number,
36
+ ): void;
33
37
  kvGet(actorId: string, keys: Uint8Array[]): Promise<(Uint8Array | null)[]>;
34
- kvListAll(actorId: string, options?: KvListOptions): Promise<[Uint8Array, Uint8Array][]>;
38
+ kvListAll(
39
+ actorId: string,
40
+ options?: KvListOptions,
41
+ ): Promise<[Uint8Array, Uint8Array][]>;
35
42
  kvListRange(
36
43
  actorId: string,
37
44
  start: Uint8Array,
@@ -46,7 +53,11 @@ export interface EnvoyHandle {
46
53
  ): Promise<[Uint8Array, Uint8Array][]>;
47
54
  kvPut(actorId: string, entries: [Uint8Array, Uint8Array][]): Promise<void>;
48
55
  kvDelete(actorId: string, keys: Uint8Array[]): Promise<void>;
49
- kvDeleteRange(actorId: string, start: Uint8Array, end: Uint8Array): Promise<void>;
56
+ kvDeleteRange(
57
+ actorId: string,
58
+ start: Uint8Array,
59
+ end: Uint8Array,
60
+ ): Promise<void>;
50
61
  kvDrop(actorId: string): Promise<void>;
51
62
  restoreHibernatingRequests(
52
63
  actorId: string,
@@ -105,7 +116,9 @@ export interface EnvoyConfig {
105
116
  actorId: string,
106
117
  generation: number,
107
118
  config: import("@rivetkit/engine-envoy-protocol").ActorConfig,
108
- preloadedKv: import("@rivetkit/engine-envoy-protocol").PreloadedKv | null,
119
+ preloadedKv:
120
+ | import("@rivetkit/engine-envoy-protocol").PreloadedKv
121
+ | null,
109
122
  ) => Promise<void>;
110
123
  onActorStop: (
111
124
  envoyHandle: EnvoyHandle,
@@ -126,19 +139,6 @@ export declare function startEnvoy(config: EnvoyConfig): Promise<EnvoyHandle>;
126
139
  export declare function openDatabaseFromEnvoy(
127
140
  handle: EnvoyHandle,
128
141
  actorId: string,
142
+ preloadedEntries?: readonly [Uint8Array, Uint8Array][] | null,
129
143
  ): Promise<JsNativeDatabase>;
130
-
131
- export interface NativeRawDatabase {
132
- execute: <TRow extends Record<string, unknown> = Record<string, unknown>>(
133
- query: string,
134
- ...args: unknown[]
135
- ) => Promise<TRow[]>;
136
- close: () => Promise<void>;
137
- }
138
-
139
- export declare function openRawDatabaseFromEnvoy(
140
- handle: EnvoyHandle,
141
- actorId: string,
142
- ): Promise<NativeRawDatabase>;
143
-
144
144
  export declare const utils: {};
package/wrapper.js CHANGED
@@ -134,7 +134,7 @@ function startEnvoySync(config) {
134
134
  poolName: config.poolName,
135
135
  version: config.version,
136
136
  metadata: config.metadata || null,
137
- notGlobal: config.notGlobal,
137
+ notGlobal: config.notGlobal ?? false,
138
138
  },
139
139
  (event) => {
140
140
  handleEvent(event, config, wrappedHandle);
@@ -158,154 +158,39 @@ async function startEnvoy(config) {
158
158
  /**
159
159
  * Open a native database backed by envoy KV.
160
160
  */
161
- async function openDatabaseFromEnvoy(handle, actorId) {
161
+ async function openDatabaseFromEnvoy(handle, actorId, preloadedEntries) {
162
162
  const rawHandle = handle._raw || handle;
163
- return native.openDatabaseFromEnvoy(rawHandle, actorId);
164
- }
165
-
166
- function isPlainObject(value) {
167
- return (
168
- !!value &&
169
- typeof value === "object" &&
170
- !Array.isArray(value) &&
171
- Object.getPrototypeOf(value) === Object.prototype
163
+ const nativePreloadedEntries = preloadedEntries
164
+ ? preloadedEntries.map(([key, value]) => ({
165
+ key: Buffer.from(key),
166
+ value: Buffer.from(value),
167
+ }))
168
+ : null;
169
+ return native.openDatabaseFromEnvoy(
170
+ rawHandle,
171
+ actorId,
172
+ nativePreloadedEntries,
172
173
  );
173
174
  }
174
175
 
175
- function toNativeBinding(value) {
176
- if (value === null || value === undefined) {
177
- return { kind: "null" };
178
- }
179
- if (typeof value === "bigint") {
180
- return { kind: "int", intValue: Number(value) };
181
- }
182
- if (typeof value === "number") {
183
- return Number.isInteger(value)
184
- ? { kind: "int", intValue: value }
185
- : { kind: "float", floatValue: value };
186
- }
187
- if (typeof value === "string") {
188
- return { kind: "text", textValue: value };
189
- }
190
- if (value instanceof ArrayBuffer) {
191
- return { kind: "blob", blobValue: Buffer.from(value) };
176
+ function decodePreloadedKv(preloadedKv) {
177
+ if (!preloadedKv) {
178
+ return null;
192
179
  }
193
- if (ArrayBuffer.isView(value)) {
194
- return {
195
- kind: "blob",
196
- blobValue: Buffer.from(value.buffer, value.byteOffset, value.byteLength),
197
- };
198
- }
199
-
200
- throw new Error(`unsupported sqlite binding type: ${typeof value}`);
201
- }
202
180
 
203
- function extractNamedSqliteParameters(sql) {
204
- return [...sql.matchAll(/([:@$][A-Za-z_][A-Za-z0-9_]*)/g)].map(
205
- (match) => match[1],
206
- );
207
- }
208
-
209
- function getNamedSqliteBinding(bindings, name) {
210
- if (name in bindings) {
211
- return bindings[name];
212
- }
213
-
214
- const bareName = name.slice(1);
215
- if (bareName in bindings) {
216
- return bindings[bareName];
217
- }
218
-
219
- for (const prefix of [":", "@", "$"]) {
220
- const candidate = `${prefix}${bareName}`;
221
- if (candidate in bindings) {
222
- return bindings[candidate];
223
- }
224
- }
225
-
226
- return undefined;
227
- }
228
-
229
- function normalizeBindings(sql, args) {
230
- if (!args || args.length === 0) {
231
- return [];
232
- }
233
-
234
- if (
235
- args.length === 1 &&
236
- isPlainObject(args[0]) &&
237
- !(args[0] instanceof Uint8Array)
238
- ) {
239
- const names = extractNamedSqliteParameters(sql);
240
- if (names.length === 0) {
241
- throw new Error(
242
- "native sqlite object bindings require named placeholders in the SQL statement",
243
- );
244
- }
245
- return names.map((name) => {
246
- const value = getNamedSqliteBinding(args[0], name);
247
- if (value === undefined) {
248
- throw new Error(`missing bind parameter: ${name}`);
249
- }
250
- return toNativeBinding(value);
251
- });
252
- }
253
-
254
- return args.map(toNativeBinding);
255
- }
256
-
257
- function mapRows(rows, columns) {
258
- return rows.map((row) => {
259
- const rowObject = {};
260
- for (let i = 0; i < columns.length; i++) {
261
- rowObject[columns[i]] = row[i];
262
- }
263
- return rowObject;
264
- });
265
- }
266
-
267
- async function openRawDatabaseFromEnvoy(handle, actorId) {
268
- const nativeDb = await openDatabaseFromEnvoy(handle, actorId);
269
- let closed = false;
270
-
271
- const ensureOpen = () => {
272
- if (closed) {
273
- throw new Error("database is closed");
274
- }
275
- };
181
+ const decodeBytes = (value) => Uint8Array.from(Buffer.from(value, "base64"));
276
182
 
277
183
  return {
278
- execute: async (query, ...args) => {
279
- ensureOpen();
280
-
281
- if (args.length > 0) {
282
- const bindings = normalizeBindings(query, args);
283
- const token = query.trimStart().slice(0, 16).toUpperCase();
284
- const returnsRows =
285
- token.startsWith("SELECT") ||
286
- token.startsWith("PRAGMA") ||
287
- token.startsWith("WITH") ||
288
- /\bRETURNING\b/i.test(query);
289
-
290
- if (returnsRows) {
291
- const result = await nativeDb.query(query, bindings);
292
- return mapRows(result.rows, result.columns);
293
- }
294
-
295
- await nativeDb.run(query, bindings);
296
- return [];
297
- }
298
-
299
- const result = await nativeDb.exec(query);
300
- return mapRows(result.rows, result.columns);
301
- },
302
- close: async () => {
303
- if (closed) {
304
- return;
305
- }
306
- closed = true;
307
- await nativeDb.close();
308
- },
184
+ entries: (preloadedKv.entries || []).map((entry) => ({
185
+ key: decodeBytes(entry.key),
186
+ value: decodeBytes(entry.value),
187
+ metadata: {
188
+ version: decodeBytes(entry.metadata.version),
189
+ updateTs: entry.metadata.updateTs,
190
+ },
191
+ })),
192
+ requestedGetKeys: (preloadedKv.requestedGetKeys || []).map(decodeBytes),
193
+ requestedPrefixes: (preloadedKv.requestedPrefixes || []).map(decodeBytes),
309
194
  };
310
195
  }
311
196
 
@@ -330,7 +215,7 @@ function handleEvent(event, config, wrappedHandle) {
330
215
  event.actorId,
331
216
  event.generation,
332
217
  actorConfig,
333
- null, // preloadedKv
218
+ decodePreloadedKv(event.preloadedKv),
334
219
  ),
335
220
  ).then(
336
221
  async () => {
@@ -574,4 +459,3 @@ function handleEvent(event, config, wrappedHandle) {
574
459
  module.exports.startEnvoy = startEnvoy;
575
460
  module.exports.startEnvoySync = startEnvoySync;
576
461
  module.exports.openDatabaseFromEnvoy = openDatabaseFromEnvoy;
577
- module.exports.openRawDatabaseFromEnvoy = openRawDatabaseFromEnvoy;