@powersync/node 0.4.2 → 0.4.4

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.
@@ -0,0 +1,153 @@
1
+ 'use strict';
2
+
3
+ var path = require('node:path');
4
+ var BetterSQLite3Database = require('@powersync/better-sqlite3');
5
+ var Comlink = require('comlink');
6
+ var node_worker_threads = require('node:worker_threads');
7
+ var OS = require('node:os');
8
+ var url = require('node:url');
9
+
10
+ var _documentCurrentScript = typeof document !== 'undefined' ? document.currentScript : null;
11
+ function _interopNamespaceDefault(e) {
12
+ var n = Object.create(null);
13
+ if (e) {
14
+ Object.keys(e).forEach(function (k) {
15
+ if (k !== 'default') {
16
+ var d = Object.getOwnPropertyDescriptor(e, k);
17
+ Object.defineProperty(n, k, d.get ? d : {
18
+ enumerable: true,
19
+ get: function () { return e[k]; }
20
+ });
21
+ }
22
+ });
23
+ }
24
+ n.default = e;
25
+ return Object.freeze(n);
26
+ }
27
+
28
+ var path__namespace = /*#__PURE__*/_interopNamespaceDefault(path);
29
+ var Comlink__namespace = /*#__PURE__*/_interopNamespaceDefault(Comlink);
30
+
31
+ class BlockingAsyncDatabase {
32
+ db;
33
+ uncommittedUpdatedTables = new Set();
34
+ committedUpdatedTables = new Set();
35
+ constructor(db) {
36
+ this.db = db;
37
+ db.function('node_thread_id', () => node_worker_threads.threadId);
38
+ }
39
+ collectCommittedUpdates() {
40
+ const resolved = Promise.resolve([...this.committedUpdatedTables]);
41
+ this.committedUpdatedTables.clear();
42
+ return resolved;
43
+ }
44
+ installUpdateHooks() {
45
+ this.db.updateHook((_op, _dbName, tableName, _rowid) => {
46
+ this.uncommittedUpdatedTables.add(tableName);
47
+ });
48
+ this.db.commitHook(() => {
49
+ for (const tableName of this.uncommittedUpdatedTables) {
50
+ this.committedUpdatedTables.add(tableName);
51
+ }
52
+ this.uncommittedUpdatedTables.clear();
53
+ return true;
54
+ });
55
+ this.db.rollbackHook(() => {
56
+ this.uncommittedUpdatedTables.clear();
57
+ });
58
+ }
59
+ async close() {
60
+ this.db.close();
61
+ }
62
+ async execute(query, params) {
63
+ const stmt = this.db.prepare(query);
64
+ if (stmt.reader) {
65
+ const rows = stmt.all(params);
66
+ return {
67
+ rowsAffected: 0,
68
+ rows: {
69
+ _array: rows,
70
+ length: rows.length
71
+ }
72
+ };
73
+ }
74
+ else {
75
+ const info = stmt.run(params);
76
+ return {
77
+ rowsAffected: info.changes,
78
+ insertId: Number(info.lastInsertRowid)
79
+ };
80
+ }
81
+ }
82
+ async executeRaw(query, params) {
83
+ const stmt = this.db.prepare(query);
84
+ if (stmt.reader) {
85
+ return stmt.raw().all(params);
86
+ }
87
+ else {
88
+ stmt.raw().run(params);
89
+ return [];
90
+ }
91
+ }
92
+ async executeBatch(query, params) {
93
+ params = params ?? [];
94
+ let rowsAffected = 0;
95
+ const stmt = this.db.prepare(query);
96
+ for (const paramSet of params) {
97
+ const info = stmt.run(paramSet);
98
+ rowsAffected += info.changes;
99
+ }
100
+ return { rowsAffected };
101
+ }
102
+ }
103
+ class BetterSqliteWorker {
104
+ options;
105
+ constructor(options) {
106
+ this.options = options;
107
+ }
108
+ async open(path, isWriter) {
109
+ const baseDB = new BetterSQLite3Database(path);
110
+ baseDB.pragma('journal_mode = WAL');
111
+ baseDB.loadExtension(this.options.extensionPath(), 'sqlite3_powersync_init');
112
+ if (!isWriter) {
113
+ baseDB.pragma('query_only = true');
114
+ }
115
+ const asyncDb = new BlockingAsyncDatabase(baseDB);
116
+ asyncDb.installUpdateHooks();
117
+ return Comlink__namespace.proxy(asyncDb);
118
+ }
119
+ }
120
+ function startPowerSyncWorker(options) {
121
+ const resolvedOptions = {
122
+ extensionPath() {
123
+ const isCommonJsModule = true ?? false;
124
+ const platform = OS.platform();
125
+ let extensionPath;
126
+ if (platform === 'win32') {
127
+ extensionPath = 'powersync.dll';
128
+ }
129
+ else if (platform === 'linux') {
130
+ extensionPath = 'libpowersync.so';
131
+ }
132
+ else if (platform === 'darwin') {
133
+ extensionPath = 'libpowersync.dylib';
134
+ }
135
+ else {
136
+ throw 'Unknown platform, PowerSync for Node.js currently supports Windows, Linux and macOS.';
137
+ }
138
+ let resolved;
139
+ if (isCommonJsModule) {
140
+ resolved = path__namespace.resolve(__dirname, '../lib/', extensionPath);
141
+ }
142
+ else {
143
+ resolved = url.fileURLToPath(new URL(`../${extensionPath}`, (typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.src || new URL('DefaultWorker.cjs', document.baseURI).href))));
144
+ }
145
+ return resolved;
146
+ },
147
+ ...options
148
+ };
149
+ Comlink__namespace.expose(new BetterSqliteWorker(resolvedOptions), node_worker_threads.parentPort);
150
+ }
151
+
152
+ startPowerSyncWorker();
153
+ //# sourceMappingURL=DefaultWorker.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DefaultWorker.cjs","sources":["../lib/db/SqliteWorker.js","../lib/db/DefaultWorker.js"],"sourcesContent":["import * as path from 'node:path';\nimport BetterSQLite3Database from '@powersync/better-sqlite3';\nimport * as Comlink from 'comlink';\nimport { parentPort, threadId } from 'node:worker_threads';\nimport OS from 'node:os';\nimport url from 'node:url';\nclass BlockingAsyncDatabase {\n db;\n uncommittedUpdatedTables = new Set();\n committedUpdatedTables = new Set();\n constructor(db) {\n this.db = db;\n db.function('node_thread_id', () => threadId);\n }\n collectCommittedUpdates() {\n const resolved = Promise.resolve([...this.committedUpdatedTables]);\n this.committedUpdatedTables.clear();\n return resolved;\n }\n installUpdateHooks() {\n this.db.updateHook((_op, _dbName, tableName, _rowid) => {\n this.uncommittedUpdatedTables.add(tableName);\n });\n this.db.commitHook(() => {\n for (const tableName of this.uncommittedUpdatedTables) {\n this.committedUpdatedTables.add(tableName);\n }\n this.uncommittedUpdatedTables.clear();\n return true;\n });\n this.db.rollbackHook(() => {\n this.uncommittedUpdatedTables.clear();\n });\n }\n async close() {\n this.db.close();\n }\n async execute(query, params) {\n const stmt = this.db.prepare(query);\n if (stmt.reader) {\n const rows = stmt.all(params);\n return {\n rowsAffected: 0,\n rows: {\n _array: rows,\n length: rows.length\n }\n };\n }\n else {\n const info = stmt.run(params);\n return {\n rowsAffected: info.changes,\n insertId: Number(info.lastInsertRowid)\n };\n }\n }\n async executeRaw(query, params) {\n const stmt = this.db.prepare(query);\n if (stmt.reader) {\n return stmt.raw().all(params);\n }\n else {\n stmt.raw().run(params);\n return [];\n }\n }\n async executeBatch(query, params) {\n params = params ?? [];\n let rowsAffected = 0;\n const stmt = this.db.prepare(query);\n for (const paramSet of params) {\n const info = stmt.run(paramSet);\n rowsAffected += info.changes;\n }\n return { rowsAffected };\n }\n}\nclass BetterSqliteWorker {\n options;\n constructor(options) {\n this.options = options;\n }\n async open(path, isWriter) {\n const baseDB = new BetterSQLite3Database(path);\n baseDB.pragma('journal_mode = WAL');\n baseDB.loadExtension(this.options.extensionPath(), 'sqlite3_powersync_init');\n if (!isWriter) {\n baseDB.pragma('query_only = true');\n }\n const asyncDb = new BlockingAsyncDatabase(baseDB);\n asyncDb.installUpdateHooks();\n return Comlink.proxy(asyncDb);\n }\n}\nexport function startPowerSyncWorker(options) {\n const resolvedOptions = {\n extensionPath() {\n const isCommonJsModule = import.meta.isBundlingToCommonJs ?? false;\n const platform = OS.platform();\n let extensionPath;\n if (platform === 'win32') {\n extensionPath = 'powersync.dll';\n }\n else if (platform === 'linux') {\n extensionPath = 'libpowersync.so';\n }\n else if (platform === 'darwin') {\n extensionPath = 'libpowersync.dylib';\n }\n else {\n throw 'Unknown platform, PowerSync for Node.js currently supports Windows, Linux and macOS.';\n }\n let resolved;\n if (isCommonJsModule) {\n resolved = path.resolve(__dirname, '../lib/', extensionPath);\n }\n else {\n resolved = url.fileURLToPath(new URL(`../${extensionPath}`, import.meta.url));\n }\n return resolved;\n },\n ...options\n };\n Comlink.expose(new BetterSqliteWorker(resolvedOptions), parentPort);\n}\n","import { startPowerSyncWorker } from './SqliteWorker.js';\nstartPowerSyncWorker();\n"],"names":["threadId","Comlink","path","parentPort"],"mappings":"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"}
@@ -0,0 +1,501 @@
1
+ 'use strict';
2
+
3
+ var common = require('@powersync/common');
4
+ var os = require('node:os');
5
+ var bson = require('bson');
6
+ var Agent = require('proxy-agent');
7
+ var undici = require('undici');
8
+ var ws = require('ws');
9
+ var Lock = require('async-lock');
10
+ var fs = require('node:fs/promises');
11
+ var path = require('node:path');
12
+ var node_worker_threads = require('node:worker_threads');
13
+ var Comlink = require('comlink');
14
+ var node_async_hooks = require('node:async_hooks');
15
+
16
+ var _documentCurrentScript = typeof document !== 'undefined' ? document.currentScript : null;
17
+ function _interopNamespaceDefault(e) {
18
+ var n = Object.create(null);
19
+ if (e) {
20
+ Object.keys(e).forEach(function (k) {
21
+ if (k !== 'default') {
22
+ var d = Object.getOwnPropertyDescriptor(e, k);
23
+ Object.defineProperty(n, k, d.get ? d : {
24
+ enumerable: true,
25
+ get: function () { return e[k]; }
26
+ });
27
+ }
28
+ });
29
+ }
30
+ n.default = e;
31
+ return Object.freeze(n);
32
+ }
33
+
34
+ var os__namespace = /*#__PURE__*/_interopNamespaceDefault(os);
35
+ var path__namespace = /*#__PURE__*/_interopNamespaceDefault(path);
36
+ var Comlink__namespace = /*#__PURE__*/_interopNamespaceDefault(Comlink);
37
+
38
+ class NodeFetchProvider extends common.FetchImplementationProvider {
39
+ getFetch() {
40
+ return fetch.bind(globalThis);
41
+ }
42
+ }
43
+ class NodeRemote extends common.AbstractRemote {
44
+ connector;
45
+ logger;
46
+ constructor(connector, logger = common.DEFAULT_REMOTE_LOGGER, options) {
47
+ // EnvHttpProxyAgent automatically uses relevant env vars for HTTP
48
+ const dispatcher = options?.dispatcher ?? new undici.EnvHttpProxyAgent();
49
+ super(connector, logger, {
50
+ fetchImplementation: options?.fetchImplementation ?? new NodeFetchProvider(),
51
+ fetchOptions: {
52
+ dispatcher
53
+ },
54
+ ...(options ?? {})
55
+ });
56
+ this.connector = connector;
57
+ this.logger = logger;
58
+ }
59
+ createSocket(url) {
60
+ return new ws.WebSocket(url, {
61
+ // Automatically uses relevant env vars for web sockets
62
+ agent: new Agent.ProxyAgent(),
63
+ headers: {
64
+ 'User-Agent': this.getUserAgent()
65
+ }
66
+ }); // This is compatible in Node environments
67
+ }
68
+ getUserAgent() {
69
+ return [
70
+ super.getUserAgent(),
71
+ `powersync-node`,
72
+ `node/${process.versions.node}`,
73
+ `${os__namespace.platform()}/${os__namespace.release()}`
74
+ ].join(' ');
75
+ }
76
+ async getBSON() {
77
+ return bson.BSON;
78
+ }
79
+ }
80
+
81
+ /**
82
+ * Global locks which prevent multiple instances from syncing
83
+ * concurrently.
84
+ */
85
+ const LOCKS = new Map();
86
+ const lockTypes = new Set(Object.values(common.LockType));
87
+ class NodeStreamingSyncImplementation extends common.AbstractStreamingSyncImplementation {
88
+ locks;
89
+ constructor(options) {
90
+ super(options);
91
+ this.initLocks();
92
+ }
93
+ /**
94
+ * Configures global locks on sync process
95
+ */
96
+ initLocks() {
97
+ const { identifier } = this.options;
98
+ if (identifier && LOCKS.has(identifier)) {
99
+ this.locks = LOCKS.get(identifier);
100
+ return;
101
+ }
102
+ this.locks = new Lock();
103
+ if (identifier) {
104
+ LOCKS.set(identifier, this.locks);
105
+ }
106
+ }
107
+ obtainLock(lockOptions) {
108
+ if (!lockTypes.has(lockOptions.type)) {
109
+ throw new Error(`Lock type ${lockOptions.type} not found`);
110
+ }
111
+ return this.locks.acquire(lockOptions.type, async () => {
112
+ if (lockOptions.signal?.aborted) {
113
+ throw new Error('Aborted');
114
+ }
115
+ return lockOptions.callback();
116
+ });
117
+ }
118
+ }
119
+
120
+ /**
121
+ * A PowerSync database connection implemented with RPC calls to a background worker.
122
+ */
123
+ class RemoteConnection {
124
+ isBusy = false;
125
+ worker;
126
+ comlink;
127
+ database;
128
+ constructor(worker, comlink, database) {
129
+ this.worker = worker;
130
+ this.comlink = comlink;
131
+ this.database = database;
132
+ }
133
+ /**
134
+ * Runs the inner function, but appends the stack trace where this function was called. This is useful for workers
135
+ * because stack traces from worker errors are otherwise unrelated to the application issue that has caused them.
136
+ */
137
+ async recoverTrace(inner) {
138
+ const trace = {};
139
+ Error.captureStackTrace(trace);
140
+ try {
141
+ return await inner();
142
+ }
143
+ catch (e) {
144
+ if (e instanceof Error && e.stack) {
145
+ e.stack += trace.stack;
146
+ }
147
+ throw e;
148
+ }
149
+ }
150
+ executeBatch(query, params = []) {
151
+ return this.recoverTrace(async () => {
152
+ const result = await this.database.executeBatch(query, params ?? []);
153
+ return RemoteConnection.wrapQueryResult(result);
154
+ });
155
+ }
156
+ execute(query, params) {
157
+ return this.recoverTrace(async () => {
158
+ const result = await this.database.execute(query, params ?? []);
159
+ return RemoteConnection.wrapQueryResult(result);
160
+ });
161
+ }
162
+ executeRaw(query, params) {
163
+ return this.recoverTrace(async () => {
164
+ return await this.database.executeRaw(query, params ?? []);
165
+ });
166
+ }
167
+ async getAll(sql, parameters) {
168
+ const res = await this.execute(sql, parameters);
169
+ return res.rows?._array ?? [];
170
+ }
171
+ async getOptional(sql, parameters) {
172
+ const res = await this.execute(sql, parameters);
173
+ return res.rows?.item(0) ?? null;
174
+ }
175
+ async get(sql, parameters) {
176
+ const res = await this.execute(sql, parameters);
177
+ const first = res.rows?.item(0);
178
+ if (!first) {
179
+ throw new Error('Result set is empty');
180
+ }
181
+ return first;
182
+ }
183
+ async refreshSchema() {
184
+ await this.execute("pragma table_info('sqlite_master')");
185
+ }
186
+ async close() {
187
+ await this.database.close();
188
+ this.database[Comlink.releaseProxy]();
189
+ this.comlink[Comlink.releaseProxy]();
190
+ await this.worker.terminate();
191
+ }
192
+ static wrapQueryResult(result) {
193
+ let rows = undefined;
194
+ if (result.rows) {
195
+ rows = {
196
+ ...result.rows,
197
+ item: (idx) => result.rows?._array[idx]
198
+ };
199
+ }
200
+ return {
201
+ ...result,
202
+ rows
203
+ };
204
+ }
205
+ }
206
+
207
+ const READ_CONNECTIONS = 5;
208
+ /**
209
+ * Adapter for better-sqlite3
210
+ */
211
+ class BetterSQLite3DBAdapter extends common.BaseObserver {
212
+ options;
213
+ name;
214
+ readConnections;
215
+ writeConnection;
216
+ readQueue = [];
217
+ writeQueue = [];
218
+ constructor(options) {
219
+ super();
220
+ if (options.readWorkerCount != null && options.readWorkerCount < 1) {
221
+ throw `Needs at least one worker for reads, got ${options.readWorkerCount}`;
222
+ }
223
+ this.options = options;
224
+ this.name = options.dbFilename;
225
+ }
226
+ async initialize() {
227
+ let dbFilePath = this.options.dbFilename;
228
+ if (this.options.dbLocation !== undefined) {
229
+ // Make sure the dbLocation exists, we get a TypeError from better-sqlite3 otherwise.
230
+ let directoryExists = false;
231
+ try {
232
+ const stat = await fs.stat(this.options.dbLocation);
233
+ directoryExists = stat.isDirectory();
234
+ }
235
+ catch (_) {
236
+ // If we can't even stat, the directory won't be accessible to SQLite either.
237
+ }
238
+ if (!directoryExists) {
239
+ throw new Error(`The dbLocation directory at "${this.options.dbLocation}" does not exist. Please create it before opening the PowerSync database!`);
240
+ }
241
+ dbFilePath = path__namespace.join(this.options.dbLocation, dbFilePath);
242
+ }
243
+ const openWorker = async (isWriter) => {
244
+ const isCommonJsModule = true ?? false;
245
+ let worker;
246
+ const workerName = isWriter ? `write ${dbFilePath}` : `read ${dbFilePath}`;
247
+ const workerFactory = this.options.openWorker ?? ((...args) => new node_worker_threads.Worker(...args));
248
+ if (isCommonJsModule) {
249
+ worker = workerFactory(path__namespace.resolve(__dirname, 'DefaultWorker.cjs'), { name: workerName });
250
+ }
251
+ else {
252
+ worker = workerFactory(new URL('./DefaultWorker.js', (typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.src || new URL('bundle.cjs', document.baseURI).href))), { name: workerName });
253
+ }
254
+ const listeners = new WeakMap();
255
+ const comlink = Comlink__namespace.wrap({
256
+ postMessage: worker.postMessage.bind(worker),
257
+ addEventListener: (type, listener) => {
258
+ let resolved = 'handleEvent' in listener ? listener.handleEvent.bind(listener) : listener;
259
+ // Comlink wants message events, but the message event on workers in Node returns the data only.
260
+ if (type === 'message') {
261
+ const original = resolved;
262
+ resolved = (data) => {
263
+ original({ data });
264
+ };
265
+ }
266
+ listeners.set(listener, resolved);
267
+ worker.addListener(type, resolved);
268
+ },
269
+ removeEventListener: (type, listener) => {
270
+ const resolved = listeners.get(listener);
271
+ if (!resolved) {
272
+ return;
273
+ }
274
+ worker.removeListener(type, resolved);
275
+ }
276
+ });
277
+ worker.once('error', (e) => {
278
+ console.error('Unexpected PowerSync database worker error', e);
279
+ });
280
+ const database = (await comlink.open(dbFilePath, isWriter));
281
+ return new RemoteConnection(worker, comlink, database);
282
+ };
283
+ // Open the writer first to avoid multiple threads enabling WAL concurrently (causing "database is locked" errors).
284
+ this.writeConnection = await openWorker(true);
285
+ const createWorkers = [];
286
+ const amountOfReaders = this.options.readWorkerCount ?? READ_CONNECTIONS;
287
+ for (let i = 0; i < amountOfReaders; i++) {
288
+ createWorkers.push(openWorker(false));
289
+ }
290
+ this.readConnections = await Promise.all(createWorkers);
291
+ }
292
+ async close() {
293
+ await this.writeConnection.close();
294
+ for (const connection of this.readConnections) {
295
+ await connection.close();
296
+ }
297
+ }
298
+ readLock(fn, _options) {
299
+ let resolveConnectionPromise;
300
+ const connectionPromise = new Promise((resolve, _reject) => {
301
+ resolveConnectionPromise = node_async_hooks.AsyncResource.bind(resolve);
302
+ });
303
+ const connection = this.readConnections.find((connection) => !connection.isBusy);
304
+ if (connection) {
305
+ connection.isBusy = true;
306
+ resolveConnectionPromise(connection);
307
+ }
308
+ else {
309
+ this.readQueue.push(resolveConnectionPromise);
310
+ }
311
+ return (async () => {
312
+ const connection = await connectionPromise;
313
+ try {
314
+ return await fn(connection);
315
+ }
316
+ finally {
317
+ const next = this.readQueue.shift();
318
+ if (next) {
319
+ next(connection);
320
+ }
321
+ else {
322
+ connection.isBusy = false;
323
+ }
324
+ }
325
+ })();
326
+ }
327
+ writeLock(fn, _options) {
328
+ let resolveLockPromise;
329
+ const lockPromise = new Promise((resolve, _reject) => {
330
+ resolveLockPromise = node_async_hooks.AsyncResource.bind(resolve);
331
+ });
332
+ if (!this.writeConnection.isBusy) {
333
+ this.writeConnection.isBusy = true;
334
+ resolveLockPromise();
335
+ }
336
+ else {
337
+ this.writeQueue.push(resolveLockPromise);
338
+ }
339
+ return (async () => {
340
+ await lockPromise;
341
+ try {
342
+ try {
343
+ return await fn(this.writeConnection);
344
+ }
345
+ finally {
346
+ const updates = await this.writeConnection.database.collectCommittedUpdates();
347
+ if (updates.length > 0) {
348
+ const event = {
349
+ tables: updates,
350
+ groupedUpdates: {},
351
+ rawUpdates: []
352
+ };
353
+ this.iterateListeners((cb) => cb.tablesUpdated?.(event));
354
+ }
355
+ }
356
+ }
357
+ finally {
358
+ const next = this.writeQueue.shift();
359
+ if (next) {
360
+ next();
361
+ }
362
+ else {
363
+ this.writeConnection.isBusy = false;
364
+ }
365
+ }
366
+ })();
367
+ }
368
+ readTransaction(fn, _options) {
369
+ return this.readLock((ctx) => this.internalTransaction(ctx, fn));
370
+ }
371
+ writeTransaction(fn, _options) {
372
+ return this.writeLock((ctx) => this.internalTransaction(ctx, fn));
373
+ }
374
+ async internalTransaction(connection, fn) {
375
+ let finalized = false;
376
+ const commit = async () => {
377
+ if (!finalized) {
378
+ finalized = true;
379
+ await connection.execute('COMMIT');
380
+ }
381
+ return { rowsAffected: 0 };
382
+ };
383
+ const rollback = async () => {
384
+ if (!finalized) {
385
+ finalized = true;
386
+ await connection.execute('ROLLBACK');
387
+ }
388
+ return { rowsAffected: 0 };
389
+ };
390
+ try {
391
+ await connection.execute('BEGIN');
392
+ const result = await fn({
393
+ execute: (query, params) => connection.execute(query, params),
394
+ executeRaw: (query, params) => connection.executeRaw(query, params),
395
+ executeBatch: (query, params) => connection.executeBatch(query, params),
396
+ get: (query, params) => connection.get(query, params),
397
+ getAll: (query, params) => connection.getAll(query, params),
398
+ getOptional: (query, params) => connection.getOptional(query, params),
399
+ commit,
400
+ rollback
401
+ });
402
+ await commit();
403
+ return result;
404
+ }
405
+ catch (ex) {
406
+ try {
407
+ await rollback();
408
+ }
409
+ catch (ex2) {
410
+ // In rare cases, a rollback may fail.
411
+ // Safe to ignore.
412
+ }
413
+ throw ex;
414
+ }
415
+ }
416
+ getAll(sql, parameters) {
417
+ return this.readLock((ctx) => ctx.getAll(sql, parameters));
418
+ }
419
+ getOptional(sql, parameters) {
420
+ return this.readLock((ctx) => ctx.getOptional(sql, parameters));
421
+ }
422
+ get(sql, parameters) {
423
+ return this.readLock((ctx) => ctx.get(sql, parameters));
424
+ }
425
+ execute(query, params) {
426
+ return this.writeLock((ctx) => ctx.execute(query, params));
427
+ }
428
+ executeRaw(query, params) {
429
+ return this.writeLock((ctx) => ctx.executeRaw(query, params));
430
+ }
431
+ executeBatch(query, params) {
432
+ return this.writeTransaction((ctx) => ctx.executeBatch(query, params));
433
+ }
434
+ async refreshSchema() {
435
+ await this.writeConnection.refreshSchema();
436
+ for (const readConnection of this.readConnections) {
437
+ await readConnection.refreshSchema();
438
+ }
439
+ }
440
+ }
441
+
442
+ /**
443
+ * A PowerSync database which provides SQLite functionality
444
+ * which is automatically synced.
445
+ *
446
+ * @example
447
+ * ```typescript
448
+ * export const db = new PowerSyncDatabase({
449
+ * schema: AppSchema,
450
+ * database: {
451
+ * dbFilename: 'example.db'
452
+ * }
453
+ * });
454
+ * ```
455
+ */
456
+ class PowerSyncDatabase extends common.AbstractPowerSyncDatabase {
457
+ constructor(options) {
458
+ super(options);
459
+ }
460
+ async _initialize() {
461
+ await this.database.initialize();
462
+ }
463
+ /**
464
+ * Opens a DBAdapter using better-sqlite3 as the default SQLite open factory.
465
+ */
466
+ openDBAdapter(options) {
467
+ return new BetterSQLite3DBAdapter(options.database);
468
+ }
469
+ generateBucketStorageAdapter() {
470
+ return new common.SqliteBucketStorage(this.database, common.AbstractPowerSyncDatabase.transactionMutex);
471
+ }
472
+ connect(connector, options) {
473
+ return super.connect(connector, options);
474
+ }
475
+ generateSyncStreamImplementation(connector, options) {
476
+ const remote = new NodeRemote(connector, this.options.logger, {
477
+ dispatcher: options.dispatcher,
478
+ ...this.options.remoteOptions
479
+ });
480
+ return new NodeStreamingSyncImplementation({
481
+ adapter: this.bucketStorageAdapter,
482
+ remote,
483
+ uploadCrud: async () => {
484
+ await this.waitForReady();
485
+ await connector.uploadData(this);
486
+ },
487
+ retryDelayMs: this.options.retryDelayMs,
488
+ crudUploadThrottleMs: this.options.crudUploadThrottleMs,
489
+ identifier: this.database.name
490
+ });
491
+ }
492
+ }
493
+
494
+ exports.PowerSyncDatabase = PowerSyncDatabase;
495
+ Object.keys(common).forEach(function (k) {
496
+ if (k !== 'default' && !Object.prototype.hasOwnProperty.call(exports, k)) Object.defineProperty(exports, k, {
497
+ enumerable: true,
498
+ get: function () { return common[k]; }
499
+ });
500
+ });
501
+ //# sourceMappingURL=bundle.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bundle.cjs","sources":["../lib/sync/stream/NodeRemote.js","../lib/sync/stream/NodeStreamingSyncImplementation.js","../lib/db/RemoteConnection.js","../lib/db/BetterSQLite3DBAdapter.js","../lib/db/PowerSyncDatabase.js"],"sourcesContent":["import * as os from 'node:os';\nimport { AbstractRemote, DEFAULT_REMOTE_LOGGER, FetchImplementationProvider } from '@powersync/common';\nimport { BSON } from 'bson';\nimport Agent from 'proxy-agent';\nimport { EnvHttpProxyAgent } from 'undici';\nimport { WebSocket } from 'ws';\nexport const STREAMING_POST_TIMEOUT_MS = 30_000;\nclass NodeFetchProvider extends FetchImplementationProvider {\n getFetch() {\n return fetch.bind(globalThis);\n }\n}\nexport class NodeRemote extends AbstractRemote {\n connector;\n logger;\n constructor(connector, logger = DEFAULT_REMOTE_LOGGER, options) {\n // EnvHttpProxyAgent automatically uses relevant env vars for HTTP\n const dispatcher = options?.dispatcher ?? new EnvHttpProxyAgent();\n super(connector, logger, {\n fetchImplementation: options?.fetchImplementation ?? new NodeFetchProvider(),\n fetchOptions: {\n dispatcher\n },\n ...(options ?? {})\n });\n this.connector = connector;\n this.logger = logger;\n }\n createSocket(url) {\n return new WebSocket(url, {\n // Automatically uses relevant env vars for web sockets\n agent: new Agent.ProxyAgent(),\n headers: {\n 'User-Agent': this.getUserAgent()\n }\n }); // This is compatible in Node environments\n }\n getUserAgent() {\n return [\n super.getUserAgent(),\n `powersync-node`,\n `node/${process.versions.node}`,\n `${os.platform()}/${os.release()}`\n ].join(' ');\n }\n async getBSON() {\n return BSON;\n }\n}\n","import { AbstractStreamingSyncImplementation, LockType } from '@powersync/common';\nimport Lock from 'async-lock';\n/**\n * Global locks which prevent multiple instances from syncing\n * concurrently.\n */\nconst LOCKS = new Map();\nconst lockTypes = new Set(Object.values(LockType));\nexport class NodeStreamingSyncImplementation extends AbstractStreamingSyncImplementation {\n locks;\n constructor(options) {\n super(options);\n this.initLocks();\n }\n /**\n * Configures global locks on sync process\n */\n initLocks() {\n const { identifier } = this.options;\n if (identifier && LOCKS.has(identifier)) {\n this.locks = LOCKS.get(identifier);\n return;\n }\n this.locks = new Lock();\n if (identifier) {\n LOCKS.set(identifier, this.locks);\n }\n }\n obtainLock(lockOptions) {\n if (!lockTypes.has(lockOptions.type)) {\n throw new Error(`Lock type ${lockOptions.type} not found`);\n }\n return this.locks.acquire(lockOptions.type, async () => {\n if (lockOptions.signal?.aborted) {\n throw new Error('Aborted');\n }\n return lockOptions.callback();\n });\n }\n}\n","import { releaseProxy } from 'comlink';\n/**\n * A PowerSync database connection implemented with RPC calls to a background worker.\n */\nexport class RemoteConnection {\n isBusy = false;\n worker;\n comlink;\n database;\n constructor(worker, comlink, database) {\n this.worker = worker;\n this.comlink = comlink;\n this.database = database;\n }\n /**\n * Runs the inner function, but appends the stack trace where this function was called. This is useful for workers\n * because stack traces from worker errors are otherwise unrelated to the application issue that has caused them.\n */\n async recoverTrace(inner) {\n const trace = {};\n Error.captureStackTrace(trace);\n try {\n return await inner();\n }\n catch (e) {\n if (e instanceof Error && e.stack) {\n e.stack += trace.stack;\n }\n throw e;\n }\n }\n executeBatch(query, params = []) {\n return this.recoverTrace(async () => {\n const result = await this.database.executeBatch(query, params ?? []);\n return RemoteConnection.wrapQueryResult(result);\n });\n }\n execute(query, params) {\n return this.recoverTrace(async () => {\n const result = await this.database.execute(query, params ?? []);\n return RemoteConnection.wrapQueryResult(result);\n });\n }\n executeRaw(query, params) {\n return this.recoverTrace(async () => {\n return await this.database.executeRaw(query, params ?? []);\n });\n }\n async getAll(sql, parameters) {\n const res = await this.execute(sql, parameters);\n return res.rows?._array ?? [];\n }\n async getOptional(sql, parameters) {\n const res = await this.execute(sql, parameters);\n return res.rows?.item(0) ?? null;\n }\n async get(sql, parameters) {\n const res = await this.execute(sql, parameters);\n const first = res.rows?.item(0);\n if (!first) {\n throw new Error('Result set is empty');\n }\n return first;\n }\n async refreshSchema() {\n await this.execute(\"pragma table_info('sqlite_master')\");\n }\n async close() {\n await this.database.close();\n this.database[releaseProxy]();\n this.comlink[releaseProxy]();\n await this.worker.terminate();\n }\n static wrapQueryResult(result) {\n let rows = undefined;\n if (result.rows) {\n rows = {\n ...result.rows,\n item: (idx) => result.rows?._array[idx]\n };\n }\n return {\n ...result,\n rows\n };\n }\n}\n","import fs from 'node:fs/promises';\nimport * as path from 'node:path';\nimport { Worker } from 'node:worker_threads';\nimport * as Comlink from 'comlink';\nimport { BaseObserver } from '@powersync/common';\nimport { AsyncResource } from 'node:async_hooks';\nimport { RemoteConnection } from './RemoteConnection.js';\nconst READ_CONNECTIONS = 5;\n/**\n * Adapter for better-sqlite3\n */\nexport class BetterSQLite3DBAdapter extends BaseObserver {\n options;\n name;\n readConnections;\n writeConnection;\n readQueue = [];\n writeQueue = [];\n constructor(options) {\n super();\n if (options.readWorkerCount != null && options.readWorkerCount < 1) {\n throw `Needs at least one worker for reads, got ${options.readWorkerCount}`;\n }\n this.options = options;\n this.name = options.dbFilename;\n }\n async initialize() {\n let dbFilePath = this.options.dbFilename;\n if (this.options.dbLocation !== undefined) {\n // Make sure the dbLocation exists, we get a TypeError from better-sqlite3 otherwise.\n let directoryExists = false;\n try {\n const stat = await fs.stat(this.options.dbLocation);\n directoryExists = stat.isDirectory();\n }\n catch (_) {\n // If we can't even stat, the directory won't be accessible to SQLite either.\n }\n if (!directoryExists) {\n throw new Error(`The dbLocation directory at \"${this.options.dbLocation}\" does not exist. Please create it before opening the PowerSync database!`);\n }\n dbFilePath = path.join(this.options.dbLocation, dbFilePath);\n }\n const openWorker = async (isWriter) => {\n const isCommonJsModule = import.meta.isBundlingToCommonJs ?? false;\n let worker;\n const workerName = isWriter ? `write ${dbFilePath}` : `read ${dbFilePath}`;\n const workerFactory = this.options.openWorker ?? ((...args) => new Worker(...args));\n if (isCommonJsModule) {\n worker = workerFactory(path.resolve(__dirname, 'DefaultWorker.cjs'), { name: workerName });\n }\n else {\n worker = workerFactory(new URL('./DefaultWorker.js', import.meta.url), { name: workerName });\n }\n const listeners = new WeakMap();\n const comlink = Comlink.wrap({\n postMessage: worker.postMessage.bind(worker),\n addEventListener: (type, listener) => {\n let resolved = 'handleEvent' in listener ? listener.handleEvent.bind(listener) : listener;\n // Comlink wants message events, but the message event on workers in Node returns the data only.\n if (type === 'message') {\n const original = resolved;\n resolved = (data) => {\n original({ data });\n };\n }\n listeners.set(listener, resolved);\n worker.addListener(type, resolved);\n },\n removeEventListener: (type, listener) => {\n const resolved = listeners.get(listener);\n if (!resolved) {\n return;\n }\n worker.removeListener(type, resolved);\n }\n });\n worker.once('error', (e) => {\n console.error('Unexpected PowerSync database worker error', e);\n });\n const database = (await comlink.open(dbFilePath, isWriter));\n return new RemoteConnection(worker, comlink, database);\n };\n // Open the writer first to avoid multiple threads enabling WAL concurrently (causing \"database is locked\" errors).\n this.writeConnection = await openWorker(true);\n const createWorkers = [];\n const amountOfReaders = this.options.readWorkerCount ?? READ_CONNECTIONS;\n for (let i = 0; i < amountOfReaders; i++) {\n createWorkers.push(openWorker(false));\n }\n this.readConnections = await Promise.all(createWorkers);\n }\n async close() {\n await this.writeConnection.close();\n for (const connection of this.readConnections) {\n await connection.close();\n }\n }\n readLock(fn, _options) {\n let resolveConnectionPromise;\n const connectionPromise = new Promise((resolve, _reject) => {\n resolveConnectionPromise = AsyncResource.bind(resolve);\n });\n const connection = this.readConnections.find((connection) => !connection.isBusy);\n if (connection) {\n connection.isBusy = true;\n resolveConnectionPromise(connection);\n }\n else {\n this.readQueue.push(resolveConnectionPromise);\n }\n return (async () => {\n const connection = await connectionPromise;\n try {\n return await fn(connection);\n }\n finally {\n const next = this.readQueue.shift();\n if (next) {\n next(connection);\n }\n else {\n connection.isBusy = false;\n }\n }\n })();\n }\n writeLock(fn, _options) {\n let resolveLockPromise;\n const lockPromise = new Promise((resolve, _reject) => {\n resolveLockPromise = AsyncResource.bind(resolve);\n });\n if (!this.writeConnection.isBusy) {\n this.writeConnection.isBusy = true;\n resolveLockPromise();\n }\n else {\n this.writeQueue.push(resolveLockPromise);\n }\n return (async () => {\n await lockPromise;\n try {\n try {\n return await fn(this.writeConnection);\n }\n finally {\n const updates = await this.writeConnection.database.collectCommittedUpdates();\n if (updates.length > 0) {\n const event = {\n tables: updates,\n groupedUpdates: {},\n rawUpdates: []\n };\n this.iterateListeners((cb) => cb.tablesUpdated?.(event));\n }\n }\n }\n finally {\n const next = this.writeQueue.shift();\n if (next) {\n next();\n }\n else {\n this.writeConnection.isBusy = false;\n }\n }\n })();\n }\n readTransaction(fn, _options) {\n return this.readLock((ctx) => this.internalTransaction(ctx, fn));\n }\n writeTransaction(fn, _options) {\n return this.writeLock((ctx) => this.internalTransaction(ctx, fn));\n }\n async internalTransaction(connection, fn) {\n let finalized = false;\n const commit = async () => {\n if (!finalized) {\n finalized = true;\n await connection.execute('COMMIT');\n }\n return { rowsAffected: 0 };\n };\n const rollback = async () => {\n if (!finalized) {\n finalized = true;\n await connection.execute('ROLLBACK');\n }\n return { rowsAffected: 0 };\n };\n try {\n await connection.execute('BEGIN');\n const result = await fn({\n execute: (query, params) => connection.execute(query, params),\n executeRaw: (query, params) => connection.executeRaw(query, params),\n executeBatch: (query, params) => connection.executeBatch(query, params),\n get: (query, params) => connection.get(query, params),\n getAll: (query, params) => connection.getAll(query, params),\n getOptional: (query, params) => connection.getOptional(query, params),\n commit,\n rollback\n });\n await commit();\n return result;\n }\n catch (ex) {\n try {\n await rollback();\n }\n catch (ex2) {\n // In rare cases, a rollback may fail.\n // Safe to ignore.\n }\n throw ex;\n }\n }\n getAll(sql, parameters) {\n return this.readLock((ctx) => ctx.getAll(sql, parameters));\n }\n getOptional(sql, parameters) {\n return this.readLock((ctx) => ctx.getOptional(sql, parameters));\n }\n get(sql, parameters) {\n return this.readLock((ctx) => ctx.get(sql, parameters));\n }\n execute(query, params) {\n return this.writeLock((ctx) => ctx.execute(query, params));\n }\n executeRaw(query, params) {\n return this.writeLock((ctx) => ctx.executeRaw(query, params));\n }\n executeBatch(query, params) {\n return this.writeTransaction((ctx) => ctx.executeBatch(query, params));\n }\n async refreshSchema() {\n await this.writeConnection.refreshSchema();\n for (const readConnection of this.readConnections) {\n await readConnection.refreshSchema();\n }\n }\n}\n","import { AbstractPowerSyncDatabase, SqliteBucketStorage } from '@powersync/common';\nimport { NodeRemote } from '../sync/stream/NodeRemote.js';\nimport { NodeStreamingSyncImplementation } from '../sync/stream/NodeStreamingSyncImplementation.js';\nimport { BetterSQLite3DBAdapter } from './BetterSQLite3DBAdapter.js';\n/**\n * A PowerSync database which provides SQLite functionality\n * which is automatically synced.\n *\n * @example\n * ```typescript\n * export const db = new PowerSyncDatabase({\n * schema: AppSchema,\n * database: {\n * dbFilename: 'example.db'\n * }\n * });\n * ```\n */\nexport class PowerSyncDatabase extends AbstractPowerSyncDatabase {\n constructor(options) {\n super(options);\n }\n async _initialize() {\n await this.database.initialize();\n }\n /**\n * Opens a DBAdapter using better-sqlite3 as the default SQLite open factory.\n */\n openDBAdapter(options) {\n return new BetterSQLite3DBAdapter(options.database);\n }\n generateBucketStorageAdapter() {\n return new SqliteBucketStorage(this.database, AbstractPowerSyncDatabase.transactionMutex);\n }\n connect(connector, options) {\n return super.connect(connector, options);\n }\n generateSyncStreamImplementation(connector, options) {\n const remote = new NodeRemote(connector, this.options.logger, {\n dispatcher: options.dispatcher,\n ...this.options.remoteOptions\n });\n return new NodeStreamingSyncImplementation({\n adapter: this.bucketStorageAdapter,\n remote,\n uploadCrud: async () => {\n await this.waitForReady();\n await connector.uploadData(this);\n },\n retryDelayMs: this.options.retryDelayMs,\n crudUploadThrottleMs: this.options.crudUploadThrottleMs,\n identifier: this.database.name\n });\n }\n}\n"],"names":["FetchImplementationProvider","AbstractRemote","DEFAULT_REMOTE_LOGGER","EnvHttpProxyAgent","WebSocket","os","BSON","LockType","AbstractStreamingSyncImplementation","releaseProxy","BaseObserver","path","Worker","Comlink","AsyncResource","AbstractPowerSyncDatabase","SqliteBucketStorage"],"mappings":"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"}
@@ -0,0 +1,153 @@
1
+ 'use strict';
2
+
3
+ var path = require('node:path');
4
+ var BetterSQLite3Database = require('@powersync/better-sqlite3');
5
+ var Comlink = require('comlink');
6
+ var node_worker_threads = require('node:worker_threads');
7
+ var OS = require('node:os');
8
+ var url = require('node:url');
9
+
10
+ var _documentCurrentScript = typeof document !== 'undefined' ? document.currentScript : null;
11
+ function _interopNamespaceDefault(e) {
12
+ var n = Object.create(null);
13
+ if (e) {
14
+ Object.keys(e).forEach(function (k) {
15
+ if (k !== 'default') {
16
+ var d = Object.getOwnPropertyDescriptor(e, k);
17
+ Object.defineProperty(n, k, d.get ? d : {
18
+ enumerable: true,
19
+ get: function () { return e[k]; }
20
+ });
21
+ }
22
+ });
23
+ }
24
+ n.default = e;
25
+ return Object.freeze(n);
26
+ }
27
+
28
+ var path__namespace = /*#__PURE__*/_interopNamespaceDefault(path);
29
+ var Comlink__namespace = /*#__PURE__*/_interopNamespaceDefault(Comlink);
30
+
31
+ class BlockingAsyncDatabase {
32
+ db;
33
+ uncommittedUpdatedTables = new Set();
34
+ committedUpdatedTables = new Set();
35
+ constructor(db) {
36
+ this.db = db;
37
+ db.function('node_thread_id', () => node_worker_threads.threadId);
38
+ }
39
+ collectCommittedUpdates() {
40
+ const resolved = Promise.resolve([...this.committedUpdatedTables]);
41
+ this.committedUpdatedTables.clear();
42
+ return resolved;
43
+ }
44
+ installUpdateHooks() {
45
+ this.db.updateHook((_op, _dbName, tableName, _rowid) => {
46
+ this.uncommittedUpdatedTables.add(tableName);
47
+ });
48
+ this.db.commitHook(() => {
49
+ for (const tableName of this.uncommittedUpdatedTables) {
50
+ this.committedUpdatedTables.add(tableName);
51
+ }
52
+ this.uncommittedUpdatedTables.clear();
53
+ return true;
54
+ });
55
+ this.db.rollbackHook(() => {
56
+ this.uncommittedUpdatedTables.clear();
57
+ });
58
+ }
59
+ async close() {
60
+ this.db.close();
61
+ }
62
+ async execute(query, params) {
63
+ const stmt = this.db.prepare(query);
64
+ if (stmt.reader) {
65
+ const rows = stmt.all(params);
66
+ return {
67
+ rowsAffected: 0,
68
+ rows: {
69
+ _array: rows,
70
+ length: rows.length
71
+ }
72
+ };
73
+ }
74
+ else {
75
+ const info = stmt.run(params);
76
+ return {
77
+ rowsAffected: info.changes,
78
+ insertId: Number(info.lastInsertRowid)
79
+ };
80
+ }
81
+ }
82
+ async executeRaw(query, params) {
83
+ const stmt = this.db.prepare(query);
84
+ if (stmt.reader) {
85
+ return stmt.raw().all(params);
86
+ }
87
+ else {
88
+ stmt.raw().run(params);
89
+ return [];
90
+ }
91
+ }
92
+ async executeBatch(query, params) {
93
+ params = params ?? [];
94
+ let rowsAffected = 0;
95
+ const stmt = this.db.prepare(query);
96
+ for (const paramSet of params) {
97
+ const info = stmt.run(paramSet);
98
+ rowsAffected += info.changes;
99
+ }
100
+ return { rowsAffected };
101
+ }
102
+ }
103
+ class BetterSqliteWorker {
104
+ options;
105
+ constructor(options) {
106
+ this.options = options;
107
+ }
108
+ async open(path, isWriter) {
109
+ const baseDB = new BetterSQLite3Database(path);
110
+ baseDB.pragma('journal_mode = WAL');
111
+ baseDB.loadExtension(this.options.extensionPath(), 'sqlite3_powersync_init');
112
+ if (!isWriter) {
113
+ baseDB.pragma('query_only = true');
114
+ }
115
+ const asyncDb = new BlockingAsyncDatabase(baseDB);
116
+ asyncDb.installUpdateHooks();
117
+ return Comlink__namespace.proxy(asyncDb);
118
+ }
119
+ }
120
+ function startPowerSyncWorker(options) {
121
+ const resolvedOptions = {
122
+ extensionPath() {
123
+ const isCommonJsModule = true ?? false;
124
+ const platform = OS.platform();
125
+ let extensionPath;
126
+ if (platform === 'win32') {
127
+ extensionPath = 'powersync.dll';
128
+ }
129
+ else if (platform === 'linux') {
130
+ extensionPath = 'libpowersync.so';
131
+ }
132
+ else if (platform === 'darwin') {
133
+ extensionPath = 'libpowersync.dylib';
134
+ }
135
+ else {
136
+ throw 'Unknown platform, PowerSync for Node.js currently supports Windows, Linux and macOS.';
137
+ }
138
+ let resolved;
139
+ if (isCommonJsModule) {
140
+ resolved = path__namespace.resolve(__dirname, '../lib/', extensionPath);
141
+ }
142
+ else {
143
+ resolved = url.fileURLToPath(new URL(`../${extensionPath}`, (typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.src || new URL('worker.cjs', document.baseURI).href))));
144
+ }
145
+ return resolved;
146
+ },
147
+ ...options
148
+ };
149
+ Comlink__namespace.expose(new BetterSqliteWorker(resolvedOptions), node_worker_threads.parentPort);
150
+ }
151
+
152
+ exports.startPowerSyncWorker = startPowerSyncWorker;
153
+ //# sourceMappingURL=worker.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"worker.cjs","sources":["../lib/db/SqliteWorker.js"],"sourcesContent":["import * as path from 'node:path';\nimport BetterSQLite3Database from '@powersync/better-sqlite3';\nimport * as Comlink from 'comlink';\nimport { parentPort, threadId } from 'node:worker_threads';\nimport OS from 'node:os';\nimport url from 'node:url';\nclass BlockingAsyncDatabase {\n db;\n uncommittedUpdatedTables = new Set();\n committedUpdatedTables = new Set();\n constructor(db) {\n this.db = db;\n db.function('node_thread_id', () => threadId);\n }\n collectCommittedUpdates() {\n const resolved = Promise.resolve([...this.committedUpdatedTables]);\n this.committedUpdatedTables.clear();\n return resolved;\n }\n installUpdateHooks() {\n this.db.updateHook((_op, _dbName, tableName, _rowid) => {\n this.uncommittedUpdatedTables.add(tableName);\n });\n this.db.commitHook(() => {\n for (const tableName of this.uncommittedUpdatedTables) {\n this.committedUpdatedTables.add(tableName);\n }\n this.uncommittedUpdatedTables.clear();\n return true;\n });\n this.db.rollbackHook(() => {\n this.uncommittedUpdatedTables.clear();\n });\n }\n async close() {\n this.db.close();\n }\n async execute(query, params) {\n const stmt = this.db.prepare(query);\n if (stmt.reader) {\n const rows = stmt.all(params);\n return {\n rowsAffected: 0,\n rows: {\n _array: rows,\n length: rows.length\n }\n };\n }\n else {\n const info = stmt.run(params);\n return {\n rowsAffected: info.changes,\n insertId: Number(info.lastInsertRowid)\n };\n }\n }\n async executeRaw(query, params) {\n const stmt = this.db.prepare(query);\n if (stmt.reader) {\n return stmt.raw().all(params);\n }\n else {\n stmt.raw().run(params);\n return [];\n }\n }\n async executeBatch(query, params) {\n params = params ?? [];\n let rowsAffected = 0;\n const stmt = this.db.prepare(query);\n for (const paramSet of params) {\n const info = stmt.run(paramSet);\n rowsAffected += info.changes;\n }\n return { rowsAffected };\n }\n}\nclass BetterSqliteWorker {\n options;\n constructor(options) {\n this.options = options;\n }\n async open(path, isWriter) {\n const baseDB = new BetterSQLite3Database(path);\n baseDB.pragma('journal_mode = WAL');\n baseDB.loadExtension(this.options.extensionPath(), 'sqlite3_powersync_init');\n if (!isWriter) {\n baseDB.pragma('query_only = true');\n }\n const asyncDb = new BlockingAsyncDatabase(baseDB);\n asyncDb.installUpdateHooks();\n return Comlink.proxy(asyncDb);\n }\n}\nexport function startPowerSyncWorker(options) {\n const resolvedOptions = {\n extensionPath() {\n const isCommonJsModule = import.meta.isBundlingToCommonJs ?? false;\n const platform = OS.platform();\n let extensionPath;\n if (platform === 'win32') {\n extensionPath = 'powersync.dll';\n }\n else if (platform === 'linux') {\n extensionPath = 'libpowersync.so';\n }\n else if (platform === 'darwin') {\n extensionPath = 'libpowersync.dylib';\n }\n else {\n throw 'Unknown platform, PowerSync for Node.js currently supports Windows, Linux and macOS.';\n }\n let resolved;\n if (isCommonJsModule) {\n resolved = path.resolve(__dirname, '../lib/', extensionPath);\n }\n else {\n resolved = url.fileURLToPath(new URL(`../${extensionPath}`, import.meta.url));\n }\n return resolved;\n },\n ...options\n };\n Comlink.expose(new BetterSqliteWorker(resolvedOptions), parentPort);\n}\n"],"names":["threadId","Comlink","path","parentPort"],"mappings":"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"}
package/package.json CHANGED
@@ -1,11 +1,12 @@
1
1
  {
2
2
  "name": "@powersync/node",
3
- "version": "0.4.2",
3
+ "version": "0.4.4",
4
4
  "publishConfig": {
5
5
  "registry": "https://registry.npmjs.org/",
6
6
  "access": "public"
7
7
  },
8
8
  "description": "PowerSync Node.js SDK. Sync Postgres, MongoDB or MySQL with SQLite in your Node.js app",
9
+ "main": "lib/index.js",
9
10
  "files": [
10
11
  "lib",
11
12
  "dist",
@@ -39,7 +40,7 @@
39
40
  "@powersync/common": "^1.31.0"
40
41
  },
41
42
  "dependencies": {
42
- "@powersync/better-sqlite3": "^0.1.1",
43
+ "@powersync/better-sqlite3": "^0.2.0",
43
44
  "async-lock": "^1.4.0",
44
45
  "bson": "^6.6.0",
45
46
  "comlink": "^4.4.2",
@@ -66,7 +67,7 @@
66
67
  "scripts": {
67
68
  "install": "node download_core.js",
68
69
  "build": "tsc -b && rollup --config",
69
- "build:prod": "tsc -b --sourceMap false",
70
+ "build:prod": "tsc -b --sourceMap false && rollup --config",
70
71
  "clean": "rm -rf lib dist tsconfig.tsbuildinfo dist",
71
72
  "watch": "tsc -b -w",
72
73
  "test": "vitest"