@event-driven-io/dumbo 0.13.0-beta.21 → 0.13.0-beta.23
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/dist/{chunk-FC4JR2R3.js → chunk-56QRSCG5.js} +2 -2
- package/dist/{chunk-65DKXURG.js → chunk-5OX6NE4Z.js} +2 -2
- package/dist/{chunk-IVJ3SNPJ.js → chunk-5SCFH2HY.js} +2 -2
- package/dist/{chunk-AMACBMAZ.cjs → chunk-7D7WADBK.cjs} +186 -98
- package/dist/chunk-7D7WADBK.cjs.map +1 -0
- package/dist/{chunk-H7ZKIJHB.cjs → chunk-7RMJPFU5.cjs} +6 -6
- package/dist/{chunk-H7ZKIJHB.cjs.map → chunk-7RMJPFU5.cjs.map} +1 -1
- package/dist/{chunk-7WEBHXZD.cjs → chunk-HXQYRDCR.cjs} +43 -43
- package/dist/{chunk-7WEBHXZD.cjs.map → chunk-HXQYRDCR.cjs.map} +1 -1
- package/dist/{chunk-T4A6BQRA.js → chunk-LPIIB75Q.js} +120 -32
- package/dist/chunk-LPIIB75Q.js.map +1 -0
- package/dist/{chunk-XO5T5N5S.js → chunk-QUAG4MBP.js} +294 -14
- package/dist/chunk-QUAG4MBP.js.map +1 -0
- package/dist/{chunk-XOQHZABK.cjs → chunk-QVEVSWG6.cjs} +307 -27
- package/dist/chunk-QVEVSWG6.cjs.map +1 -0
- package/dist/{chunk-R7P7CNMK.cjs → chunk-TMFEMKPE.cjs} +4 -4
- package/dist/{chunk-R7P7CNMK.cjs.map → chunk-TMFEMKPE.cjs.map} +1 -1
- package/dist/cloudflare.cjs +66 -61
- package/dist/cloudflare.cjs.map +1 -1
- package/dist/cloudflare.d.cts +4 -4
- package/dist/cloudflare.d.ts +4 -4
- package/dist/cloudflare.js +9 -4
- package/dist/cloudflare.js.map +1 -1
- package/dist/{columnProcessors-Difrrk4c.d.cts → columnProcessors-CsQjv8si.d.cts} +1 -1
- package/dist/{columnProcessors-C7fRa54L.d.ts → columnProcessors-giHzjHuv.d.ts} +1 -1
- package/dist/{connectionString-oeg1LD5V.d.ts → connectionString-J4yRT71A.d.cts} +40 -31
- package/dist/{connectionString-oeg1LD5V.d.cts → connectionString-J4yRT71A.d.ts} +40 -31
- package/dist/index.cjs +7 -5
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +3 -3
- package/dist/index.d.ts +3 -3
- package/dist/index.js +5 -3
- package/dist/index.js.map +1 -1
- package/dist/pg.cjs +39 -38
- package/dist/pg.cjs.map +1 -1
- package/dist/pg.d.cts +7 -7
- package/dist/pg.d.ts +7 -7
- package/dist/pg.js +5 -4
- package/dist/pg.js.map +1 -1
- package/dist/postgresql.cjs +4 -4
- package/dist/postgresql.d.cts +2 -2
- package/dist/postgresql.d.ts +2 -2
- package/dist/postgresql.js +3 -3
- package/dist/sqlite.cjs +8 -4
- package/dist/sqlite.cjs.map +1 -1
- package/dist/sqlite.d.cts +49 -23
- package/dist/sqlite.d.ts +49 -23
- package/dist/sqlite.js +7 -3
- package/dist/sqlite3.cjs +65 -28
- package/dist/sqlite3.cjs.map +1 -1
- package/dist/sqlite3.d.cts +11 -11
- package/dist/sqlite3.d.ts +11 -11
- package/dist/sqlite3.js +48 -11
- package/dist/sqlite3.js.map +1 -1
- package/package.json +1 -1
- package/dist/chunk-AMACBMAZ.cjs.map +0 -1
- package/dist/chunk-T4A6BQRA.js.map +0 -1
- package/dist/chunk-XO5T5N5S.js.map +0 -1
- package/dist/chunk-XOQHZABK.cjs.map +0 -1
- /package/dist/{chunk-FC4JR2R3.js.map → chunk-56QRSCG5.js.map} +0 -0
- /package/dist/{chunk-65DKXURG.js.map → chunk-5OX6NE4Z.js.map} +0 -0
- /package/dist/{chunk-IVJ3SNPJ.js.map → chunk-5SCFH2HY.js.map} +0 -0
|
@@ -19,6 +19,7 @@ import {
|
|
|
19
19
|
createAlwaysNewConnectionPool,
|
|
20
20
|
createAmbientConnection,
|
|
21
21
|
createAmbientConnectionPool,
|
|
22
|
+
createBoundedConnectionPool,
|
|
22
23
|
createConnection,
|
|
23
24
|
createSingletonConnectionPool,
|
|
24
25
|
defaultProcessorsRegistry,
|
|
@@ -28,7 +29,7 @@ import {
|
|
|
28
29
|
registerFormatter,
|
|
29
30
|
sqlExecutor,
|
|
30
31
|
tracer
|
|
31
|
-
} from "./chunk-
|
|
32
|
+
} from "./chunk-QUAG4MBP.js";
|
|
32
33
|
|
|
33
34
|
// src/storage/sqlite/core/errors/errorMapper.ts
|
|
34
35
|
var getSqliteErrorCode = (error) => {
|
|
@@ -209,9 +210,6 @@ var sqliteExecute = async (database, handle) => {
|
|
|
209
210
|
var sqliteSQLExecutor = (driverType, serializer, formatter, errorMapper) => ({
|
|
210
211
|
driverType,
|
|
211
212
|
query: async (client, sql, options) => {
|
|
212
|
-
if (options?.timeoutMs) {
|
|
213
|
-
await client.query(SQL`PRAGMA busy_timeout = ${options.timeoutMs}`);
|
|
214
|
-
}
|
|
215
213
|
tracer.info("db:sql:query", {
|
|
216
214
|
query: (formatter ?? sqliteFormatter).format(sql, { serializer }).query,
|
|
217
215
|
params: (formatter ?? sqliteFormatter).format(sql, { serializer }).params,
|
|
@@ -234,9 +232,6 @@ var sqliteSQLExecutor = (driverType, serializer, formatter, errorMapper) => ({
|
|
|
234
232
|
}
|
|
235
233
|
},
|
|
236
234
|
batchQuery: async (client, sqls, options) => {
|
|
237
|
-
if (options?.timeoutMs) {
|
|
238
|
-
await client.query(SQL`PRAGMA busy_timeout = ${options.timeoutMs}`);
|
|
239
|
-
}
|
|
240
235
|
try {
|
|
241
236
|
const results = await client.batchQuery(sqls, options);
|
|
242
237
|
if (options?.mapping) {
|
|
@@ -254,9 +249,6 @@ var sqliteSQLExecutor = (driverType, serializer, formatter, errorMapper) => ({
|
|
|
254
249
|
}
|
|
255
250
|
},
|
|
256
251
|
command: async (client, sql, options) => {
|
|
257
|
-
if (options?.timeoutMs) {
|
|
258
|
-
await client.query(SQL`PRAGMA busy_timeout = ${options.timeoutMs}`);
|
|
259
|
-
}
|
|
260
252
|
tracer.info("db:sql:command", {
|
|
261
253
|
query: (formatter ?? sqliteFormatter).format(sql, { serializer }).query,
|
|
262
254
|
params: (formatter ?? sqliteFormatter).format(sql, { serializer }).params,
|
|
@@ -270,9 +262,6 @@ var sqliteSQLExecutor = (driverType, serializer, formatter, errorMapper) => ({
|
|
|
270
262
|
}
|
|
271
263
|
},
|
|
272
264
|
batchCommand: async (client, sqls, options) => {
|
|
273
|
-
if (options?.timeoutMs) {
|
|
274
|
-
await client.query(SQL`PRAGMA busy_timeout = ${options.timeoutMs}`);
|
|
275
|
-
}
|
|
276
265
|
try {
|
|
277
266
|
return await client.batchCommand(sqls, options);
|
|
278
267
|
} catch (error) {
|
|
@@ -283,6 +272,37 @@ var sqliteSQLExecutor = (driverType, serializer, formatter, errorMapper) => ({
|
|
|
283
272
|
formatter: formatter ?? sqliteFormatter
|
|
284
273
|
});
|
|
285
274
|
|
|
275
|
+
// src/storage/sqlite/core/pool/dualPool.ts
|
|
276
|
+
import { cpus } from "os";
|
|
277
|
+
var sqliteDualConnectionPool = (options) => {
|
|
278
|
+
const { sqliteConnectionFactory, connectionOptions } = options;
|
|
279
|
+
const readerPoolSize = options.readerPoolSize ?? Math.max(4, cpus().length);
|
|
280
|
+
const writerPool = createSingletonConnectionPool({
|
|
281
|
+
driverType: options.driverType,
|
|
282
|
+
getConnection: () => sqliteConnectionFactory(connectionOptions)
|
|
283
|
+
});
|
|
284
|
+
const readerPool = createBoundedConnectionPool({
|
|
285
|
+
driverType: options.driverType,
|
|
286
|
+
getConnection: () => sqliteConnectionFactory(connectionOptions),
|
|
287
|
+
maxConnections: readerPoolSize
|
|
288
|
+
});
|
|
289
|
+
return {
|
|
290
|
+
driverType: options.driverType,
|
|
291
|
+
connection: (connectionOptions2) => connectionOptions2?.readonly ? readerPool.connection(connectionOptions2) : writerPool.connection(connectionOptions2),
|
|
292
|
+
execute: {
|
|
293
|
+
query: (...args) => readerPool.execute.query(...args),
|
|
294
|
+
batchQuery: (...args) => readerPool.execute.batchQuery(...args),
|
|
295
|
+
command: (...args) => writerPool.execute.command(...args),
|
|
296
|
+
batchCommand: (...args) => writerPool.execute.batchCommand(...args)
|
|
297
|
+
},
|
|
298
|
+
withConnection: (handle, connectionOptions2) => connectionOptions2?.readonly ? readerPool.withConnection(handle, connectionOptions2) : writerPool.withConnection(handle, connectionOptions2),
|
|
299
|
+
transaction: writerPool.transaction,
|
|
300
|
+
withTransaction: writerPool.withTransaction,
|
|
301
|
+
close: () => Promise.all([writerPool.close(), readerPool.close()]).then(() => {
|
|
302
|
+
})
|
|
303
|
+
};
|
|
304
|
+
};
|
|
305
|
+
|
|
286
306
|
// src/storage/sqlite/core/pool/pool.ts
|
|
287
307
|
var isInMemoryDatabase = (options) => {
|
|
288
308
|
if ("fileName" in options) {
|
|
@@ -316,11 +336,14 @@ var sqliteAlwaysNewConnectionPool = (options) => {
|
|
|
316
336
|
};
|
|
317
337
|
var toSqlitePoolOptions = (options) => {
|
|
318
338
|
const { singleton, ...rest } = options;
|
|
319
|
-
const
|
|
320
|
-
if (
|
|
339
|
+
const isInMemory = isInMemoryDatabase(options);
|
|
340
|
+
if (isInMemory) {
|
|
341
|
+
return { ...rest, singleton: true };
|
|
342
|
+
}
|
|
343
|
+
if (singleton === true) {
|
|
321
344
|
return { ...rest, singleton: true };
|
|
322
345
|
}
|
|
323
|
-
return { ...rest,
|
|
346
|
+
return { ...rest, dual: true };
|
|
324
347
|
};
|
|
325
348
|
function sqlitePool(options) {
|
|
326
349
|
const { driverType } = options;
|
|
@@ -329,15 +352,24 @@ function sqlitePool(options) {
|
|
|
329
352
|
driverType,
|
|
330
353
|
connection: options.connection
|
|
331
354
|
});
|
|
355
|
+
if ("dual" in options && options.dual) {
|
|
356
|
+
return sqliteDualConnectionPool(
|
|
357
|
+
options
|
|
358
|
+
);
|
|
359
|
+
}
|
|
332
360
|
if (options.singleton === true && options.sqliteConnectionFactory) {
|
|
333
361
|
return createSingletonConnectionPool({
|
|
334
362
|
driverType,
|
|
335
|
-
getConnection: () => options.sqliteConnectionFactory(
|
|
363
|
+
getConnection: () => options.sqliteConnectionFactory(
|
|
364
|
+
options.connectionOptions
|
|
365
|
+
)
|
|
336
366
|
});
|
|
337
367
|
}
|
|
338
368
|
return createAlwaysNewConnectionPool({
|
|
339
369
|
driverType,
|
|
340
|
-
getConnection: () => options.sqliteConnectionFactory(
|
|
370
|
+
getConnection: () => options.sqliteConnectionFactory(
|
|
371
|
+
options.connectionOptions
|
|
372
|
+
)
|
|
341
373
|
});
|
|
342
374
|
}
|
|
343
375
|
|
|
@@ -357,6 +389,41 @@ var SQLiteConnectionString = (connectionString) => {
|
|
|
357
389
|
}
|
|
358
390
|
return connectionString;
|
|
359
391
|
};
|
|
392
|
+
var parsePragmasFromConnectionString = (connectionString) => {
|
|
393
|
+
const str = String(connectionString);
|
|
394
|
+
if (!str.startsWith("file:")) {
|
|
395
|
+
return {};
|
|
396
|
+
}
|
|
397
|
+
const url = new URL(str);
|
|
398
|
+
const params = url.searchParams;
|
|
399
|
+
const pragmas = {};
|
|
400
|
+
const journalMode = params.get("journal_mode");
|
|
401
|
+
if (journalMode !== null) {
|
|
402
|
+
pragmas.journal_mode = journalMode;
|
|
403
|
+
}
|
|
404
|
+
const synchronous = params.get("synchronous");
|
|
405
|
+
if (synchronous !== null) {
|
|
406
|
+
pragmas.synchronous = synchronous;
|
|
407
|
+
}
|
|
408
|
+
const cacheSize = params.get("cache_size");
|
|
409
|
+
if (cacheSize !== null) {
|
|
410
|
+
pragmas.cache_size = parseInt(cacheSize, 10);
|
|
411
|
+
}
|
|
412
|
+
const foreignKeys = params.get("foreign_keys");
|
|
413
|
+
if (foreignKeys !== null) {
|
|
414
|
+
const val = foreignKeys.toLowerCase();
|
|
415
|
+
pragmas.foreign_keys = val === "true" || val === "on" || val === "1";
|
|
416
|
+
}
|
|
417
|
+
const tempStore = params.get("temp_store");
|
|
418
|
+
if (tempStore !== null) {
|
|
419
|
+
pragmas.temp_store = tempStore.toUpperCase();
|
|
420
|
+
}
|
|
421
|
+
const busyTimeout = params.get("busy_timeout");
|
|
422
|
+
if (busyTimeout !== null) {
|
|
423
|
+
pragmas.busy_timeout = parseInt(busyTimeout, 10);
|
|
424
|
+
}
|
|
425
|
+
return pragmas;
|
|
426
|
+
};
|
|
360
427
|
|
|
361
428
|
// src/storage/sqlite/core/connections/index.ts
|
|
362
429
|
var isSQLiteError = (error) => {
|
|
@@ -391,6 +458,7 @@ var sqliteAmbientClientConnection = (options) => {
|
|
|
391
458
|
driverType,
|
|
392
459
|
initTransaction,
|
|
393
460
|
allowNestedTransactions,
|
|
461
|
+
defaultTransactionMode,
|
|
394
462
|
serializer,
|
|
395
463
|
errorMapper
|
|
396
464
|
} = options;
|
|
@@ -401,7 +469,8 @@ var sqliteAmbientClientConnection = (options) => {
|
|
|
401
469
|
driverType,
|
|
402
470
|
connection,
|
|
403
471
|
allowNestedTransactions ?? false,
|
|
404
|
-
serializer
|
|
472
|
+
serializer,
|
|
473
|
+
defaultTransactionMode
|
|
405
474
|
)),
|
|
406
475
|
executor: ({ serializer: serializer2 }) => sqliteSQLExecutor(driverType, serializer2, void 0, errorMapper),
|
|
407
476
|
serializer
|
|
@@ -430,7 +499,8 @@ var sqliteClientConnection = (options) => {
|
|
|
430
499
|
options.driverType,
|
|
431
500
|
connection,
|
|
432
501
|
connectionOptions.transactionOptions?.allowNestedTransactions ?? false,
|
|
433
|
-
serializer
|
|
502
|
+
serializer,
|
|
503
|
+
connectionOptions.defaultTransactionMode
|
|
434
504
|
),
|
|
435
505
|
executor: ({ serializer: serializer2 }) => sqliteSQLExecutor(options.driverType, serializer2),
|
|
436
506
|
serializer
|
|
@@ -453,7 +523,8 @@ var sqlitePoolClientConnection = (options) => {
|
|
|
453
523
|
options.driverType,
|
|
454
524
|
connection,
|
|
455
525
|
connectionOptions.transactionOptions?.allowNestedTransactions ?? false,
|
|
456
|
-
serializer
|
|
526
|
+
serializer,
|
|
527
|
+
connectionOptions.defaultTransactionMode
|
|
457
528
|
),
|
|
458
529
|
executor: ({ serializer: serializer2 }) => sqliteSQLExecutor(options.driverType, serializer2),
|
|
459
530
|
serializer
|
|
@@ -463,12 +534,20 @@ function sqliteConnection(options) {
|
|
|
463
534
|
return options.type === "Client" ? sqliteClientConnection(options) : sqlitePoolClientConnection(options);
|
|
464
535
|
}
|
|
465
536
|
var InMemorySQLiteDatabase = SQLiteConnectionString(":memory:");
|
|
537
|
+
var DEFAULT_SQLITE_PRAGMA_OPTIONS = {
|
|
538
|
+
journal_mode: "WAL",
|
|
539
|
+
synchronous: "NORMAL",
|
|
540
|
+
cache_size: -1e6,
|
|
541
|
+
foreign_keys: true,
|
|
542
|
+
temp_store: "MEMORY",
|
|
543
|
+
busy_timeout: 5e3
|
|
544
|
+
};
|
|
466
545
|
|
|
467
546
|
// src/storage/sqlite/core/transactions/index.ts
|
|
468
|
-
var sqliteTransaction = (driverType, connection, allowNestedTransactions, serializer) => (getClient, options) => {
|
|
547
|
+
var sqliteTransaction = (driverType, connection, allowNestedTransactions, serializer, defaultTransactionMode) => (getClient, options) => {
|
|
469
548
|
const transactionCounter = transactionNestingCounter();
|
|
470
549
|
allowNestedTransactions = options?.allowNestedTransactions ?? allowNestedTransactions;
|
|
471
|
-
|
|
550
|
+
const transaction = {
|
|
472
551
|
connection: connection(),
|
|
473
552
|
driverType,
|
|
474
553
|
begin: async function() {
|
|
@@ -476,23 +555,28 @@ var sqliteTransaction = (driverType, connection, allowNestedTransactions, serial
|
|
|
476
555
|
if (allowNestedTransactions) {
|
|
477
556
|
if (transactionCounter.level >= 1) {
|
|
478
557
|
transactionCounter.increment();
|
|
479
|
-
|
|
480
|
-
|
|
481
|
-
|
|
558
|
+
if (options?.useSavepoints) {
|
|
559
|
+
await client.query(
|
|
560
|
+
SQL`SAVEPOINT transaction${SQL.plain(transactionCounter.level.toString())}`
|
|
561
|
+
);
|
|
562
|
+
}
|
|
482
563
|
return;
|
|
483
564
|
}
|
|
484
565
|
transactionCounter.increment();
|
|
485
566
|
}
|
|
486
|
-
|
|
567
|
+
const mode = options?.mode ?? defaultTransactionMode ?? "IMMEDIATE";
|
|
568
|
+
await client.query(SQL`BEGIN ${SQL.plain(mode)} TRANSACTION`);
|
|
487
569
|
},
|
|
488
570
|
commit: async function() {
|
|
489
571
|
const client = await getClient;
|
|
490
572
|
try {
|
|
491
573
|
if (allowNestedTransactions) {
|
|
492
574
|
if (transactionCounter.level > 1) {
|
|
493
|
-
|
|
494
|
-
|
|
495
|
-
|
|
575
|
+
if (options?.useSavepoints) {
|
|
576
|
+
await client.query(
|
|
577
|
+
SQL`RELEASE transaction${SQL.plain(transactionCounter.level.toString())}`
|
|
578
|
+
);
|
|
579
|
+
}
|
|
496
580
|
transactionCounter.decrement();
|
|
497
581
|
return;
|
|
498
582
|
}
|
|
@@ -526,8 +610,10 @@ var sqliteTransaction = (driverType, connection, allowNestedTransactions, serial
|
|
|
526
610
|
},
|
|
527
611
|
execute: sqlExecutor(sqliteSQLExecutor(driverType, serializer), {
|
|
528
612
|
connect: () => getClient
|
|
529
|
-
})
|
|
613
|
+
}),
|
|
614
|
+
_transactionOptions: options ?? {}
|
|
530
615
|
};
|
|
616
|
+
return transaction;
|
|
531
617
|
};
|
|
532
618
|
|
|
533
619
|
export {
|
|
@@ -537,6 +623,7 @@ export {
|
|
|
537
623
|
sqliteSQLExecutor,
|
|
538
624
|
sqliteTransaction,
|
|
539
625
|
SQLiteConnectionString,
|
|
626
|
+
parsePragmasFromConnectionString,
|
|
540
627
|
isSQLiteError,
|
|
541
628
|
transactionNestingCounter,
|
|
542
629
|
sqliteAmbientClientConnection,
|
|
@@ -544,6 +631,7 @@ export {
|
|
|
544
631
|
sqlitePoolClientConnection,
|
|
545
632
|
sqliteConnection,
|
|
546
633
|
InMemorySQLiteDatabase,
|
|
634
|
+
DEFAULT_SQLITE_PRAGMA_OPTIONS,
|
|
547
635
|
isInMemoryDatabase,
|
|
548
636
|
sqliteAmbientConnectionPool,
|
|
549
637
|
sqliteSingletonConnectionPool,
|
|
@@ -553,4 +641,4 @@ export {
|
|
|
553
641
|
DefaultSQLiteMigratorOptions,
|
|
554
642
|
SQLiteDatabaseName
|
|
555
643
|
};
|
|
556
|
-
//# sourceMappingURL=chunk-
|
|
644
|
+
//# sourceMappingURL=chunk-LPIIB75Q.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/storage/sqlite/core/errors/errorMapper.ts","../src/storage/sqlite/core/sql/processors/columProcessors.ts","../src/storage/sqlite/core/sql/formatter/index.ts","../src/storage/sqlite/core/execute/execute.ts","../src/storage/sqlite/core/pool/dualPool.ts","../src/storage/sqlite/core/pool/pool.ts","../src/storage/sqlite/core/schema/migrations.ts","../src/storage/sqlite/core/index.ts","../src/storage/sqlite/core/connections/connectionString.ts","../src/storage/sqlite/core/connections/index.ts","../src/storage/sqlite/core/transactions/index.ts"],"sourcesContent":["import {\n CheckViolationError,\n ConnectionError,\n DataError,\n DeadlockError,\n DumboError,\n ForeignKeyViolationError,\n InsufficientResourcesError,\n IntegrityConstraintViolationError,\n InvalidOperationError,\n LockNotAvailableError,\n NotNullViolationError,\n SerializationError,\n SystemError,\n UniqueConstraintError,\n} from '../../../../core/errors';\n\n/**\n * Extracts the SQLite error code string from a `sqlite3` driver error.\n *\n * The `sqlite3` (node-sqlite3) driver sets `error.code` to a string like\n * `'SQLITE_CONSTRAINT'` and `error.errno` to the numeric result code.\n * See: https://github.com/TryGhost/node-sqlite3\n */\nconst getSqliteErrorCode = (error: unknown): string | undefined => {\n if (\n error instanceof Error &&\n 'code' in error &&\n typeof (error as Record<string, unknown>).code === 'string'\n ) {\n return (error as Record<string, unknown>).code as string;\n }\n return undefined;\n};\n\nconst getErrorMessage = (error: unknown): string | undefined =>\n error instanceof Error ? error.message : undefined;\n\nconst asError = (error: unknown): Error | undefined =>\n error instanceof Error ? error : undefined;\n\n/**\n * Maps a constraint error to a specific DumboError subtype by inspecting the\n * error message. The `sqlite3` driver only exposes the primary result code\n * `SQLITE_CONSTRAINT` — the constraint subtype (UNIQUE, FOREIGN KEY, etc.)\n * is embedded in the message string by SQLite, e.g.:\n * \"SQLITE_CONSTRAINT: UNIQUE constraint failed: users.email\"\n *\n * Reference: https://www.sqlite.org/rescode.html (extended result codes 275–3091)\n */\nconst mapConstraintError = (\n message: string | undefined,\n innerError: Error | undefined,\n): DumboError => {\n const upperMessage = message?.toUpperCase() ?? '';\n\n // SQLITE_CONSTRAINT_UNIQUE (2067) / SQLITE_CONSTRAINT_PRIMARYKEY (1555)\n if (upperMessage.includes('UNIQUE') || upperMessage.includes('PRIMARY KEY'))\n return new UniqueConstraintError(message, innerError);\n\n // SQLITE_CONSTRAINT_FOREIGNKEY (787)\n if (upperMessage.includes('FOREIGN KEY'))\n return new ForeignKeyViolationError(message, innerError);\n\n // SQLITE_CONSTRAINT_NOTNULL (1299)\n if (upperMessage.includes('NOT NULL'))\n return new NotNullViolationError(message, innerError);\n\n // SQLITE_CONSTRAINT_CHECK (275)\n if (upperMessage.includes('CHECK'))\n return new CheckViolationError(message, innerError);\n\n // SQLITE_CONSTRAINT_ROWID (2579), SQLITE_CONSTRAINT_TRIGGER (1811),\n // SQLITE_CONSTRAINT_COMMITHOOK (531), SQLITE_CONSTRAINT_PINNED (2835),\n // SQLITE_CONSTRAINT_DATATYPE (3091), etc.\n return new IntegrityConstraintViolationError(message, innerError);\n};\n\n/**\n * Maps a SQLite error (from the `sqlite3` / node-sqlite3 driver) to a typed\n * DumboError based on the SQLite result code.\n *\n * Result code reference: https://www.sqlite.org/rescode.html\n *\n * Falls back to a generic DumboError (500) if the error is not a recognized SQLite error.\n */\nexport const mapSqliteError = (error: unknown): DumboError => {\n if (DumboError.isInstanceOf<DumboError>(error)) return error;\n\n const code = getSqliteErrorCode(error);\n if (!code)\n return new DumboError({\n errorCode: 500,\n message: getErrorMessage(error),\n innerError: asError(error),\n });\n\n const message = getErrorMessage(error);\n const innerError = asError(error);\n\n switch (code) {\n // ── Constraint violations (19) ──\n // node-sqlite3 only exposes the primary code; subtype is in the message.\n case 'SQLITE_CONSTRAINT':\n return mapConstraintError(message, innerError);\n\n // ── Busy / lock contention ──\n // SQLITE_BUSY (5): conflict with a separate database connection\n case 'SQLITE_BUSY':\n return new LockNotAvailableError(message, innerError);\n\n // SQLITE_LOCKED (6): conflict within the same connection or shared cache\n case 'SQLITE_LOCKED':\n return new DeadlockError(message, innerError);\n\n // SQLITE_PROTOCOL (15): WAL locking race condition\n case 'SQLITE_PROTOCOL':\n return new LockNotAvailableError(message, innerError);\n\n // ── Connection / open errors ──\n // SQLITE_CANTOPEN (14): unable to open database file\n case 'SQLITE_CANTOPEN':\n return new ConnectionError(message, innerError);\n\n // SQLITE_NOTADB (26): file is not a database\n case 'SQLITE_NOTADB':\n return new ConnectionError(message, innerError);\n\n // ── Resource exhaustion ──\n // SQLITE_NOMEM (7): out of memory\n case 'SQLITE_NOMEM':\n return new InsufficientResourcesError(message, innerError);\n\n // SQLITE_FULL (13): disk full\n case 'SQLITE_FULL':\n return new InsufficientResourcesError(message, innerError);\n\n // ── System / I/O errors ──\n // SQLITE_IOERR (10): operating system I/O error\n case 'SQLITE_IOERR':\n return new SystemError(message, innerError);\n\n // SQLITE_CORRUPT (11): database file is corrupted\n case 'SQLITE_CORRUPT':\n return new SystemError(message, innerError);\n\n // SQLITE_INTERNAL (2): internal SQLite malfunction\n case 'SQLITE_INTERNAL':\n return new SystemError(message, innerError);\n\n // SQLITE_NOLFS (22): large file support unavailable\n case 'SQLITE_NOLFS':\n return new SystemError(message, innerError);\n\n // ── Data errors ──\n // SQLITE_TOOBIG (18): string or BLOB too large\n case 'SQLITE_TOOBIG':\n return new DataError(message, innerError);\n\n // SQLITE_MISMATCH (20): datatype mismatch\n case 'SQLITE_MISMATCH':\n return new DataError(message, innerError);\n\n // SQLITE_RANGE (25): bind parameter index out of range\n case 'SQLITE_RANGE':\n return new DataError(message, innerError);\n\n // ── Invalid operations ──\n // SQLITE_ERROR (1): generic SQL error (syntax errors, missing tables, etc.)\n case 'SQLITE_ERROR':\n return new InvalidOperationError(message, innerError);\n\n // SQLITE_READONLY (8): attempt to write to a read-only database\n case 'SQLITE_READONLY':\n return new InvalidOperationError(message, innerError);\n\n // SQLITE_MISUSE (21): API misuse\n case 'SQLITE_MISUSE':\n return new InvalidOperationError(message, innerError);\n\n // SQLITE_AUTH (23): authorization denied\n case 'SQLITE_AUTH':\n return new InvalidOperationError(message, innerError);\n\n // SQLITE_PERM (3): access permission denied\n case 'SQLITE_PERM':\n return new InvalidOperationError(message, innerError);\n\n // SQLITE_SCHEMA (17): schema changed, statement needs re-preparation\n case 'SQLITE_SCHEMA':\n return new InvalidOperationError(message, innerError);\n\n // ── Transaction / abort ──\n // SQLITE_ABORT (4): operation aborted (e.g. by rollback)\n case 'SQLITE_ABORT':\n return new SerializationError(message, innerError);\n\n // SQLITE_INTERRUPT (9): operation interrupted\n case 'SQLITE_INTERRUPT':\n return new SerializationError(message, innerError);\n }\n\n return new DumboError({\n errorCode: 500,\n message,\n innerError,\n });\n};\n","import {\n mapDefaultSQLColumnProcessors,\n type DefaultSQLColumnProcessors,\n type DefaultSQLColumnToken,\n type SQLProcessorContext,\n} from '../../../../../core';\n\nconst mapColumnType = (\n token: DefaultSQLColumnToken,\n { builder }: SQLProcessorContext,\n): void => {\n let columnSQL: string;\n const { sqlTokenType } = token;\n switch (sqlTokenType) {\n case 'SQL_COLUMN_AUTO_INCREMENT':\n columnSQL = `INTEGER ${token.primaryKey ? 'PRIMARY KEY' : ''} AUTOINCREMENT`;\n break;\n case 'SQL_COLUMN_BIGINT':\n columnSQL = 'INTEGER';\n break;\n case 'SQL_COLUMN_SERIAL':\n columnSQL = 'INTEGER';\n break;\n case 'SQL_COLUMN_INTEGER':\n columnSQL = 'INTEGER';\n break;\n case 'SQL_COLUMN_JSONB':\n columnSQL = 'BLOB';\n break;\n case 'SQL_COLUMN_BIGSERIAL':\n columnSQL = 'INTEGER';\n break;\n case 'SQL_COLUMN_TIMESTAMP':\n columnSQL = 'DATETIME';\n break;\n case 'SQL_COLUMN_TIMESTAMPTZ':\n columnSQL = 'DATETIME';\n break;\n case 'SQL_COLUMN_VARCHAR':\n columnSQL = `VARCHAR ${Number.isNaN(token.length) ? '' : `(${token.length})`}`;\n break;\n default: {\n const exhaustiveCheck: never = sqlTokenType;\n // eslint-disable-next-line @typescript-eslint/restrict-template-expressions\n throw new Error(`Unknown column type: ${exhaustiveCheck}`);\n }\n }\n builder.addSQL(columnSQL);\n};\n\nexport const sqliteColumnProcessors: DefaultSQLColumnProcessors =\n mapDefaultSQLColumnProcessors(mapColumnType);\n","import {\n defaultProcessorsRegistry,\n registerFormatter,\n SQLFormatter,\n SQLProcessorsRegistry,\n} from '../../../../../core/sql';\nimport { sqliteColumnProcessors } from '../processors';\n\nconst sqliteSQLProcessorsRegistry = SQLProcessorsRegistry({\n from: defaultProcessorsRegistry,\n}).register(sqliteColumnProcessors);\n\nconst sqliteFormatter: SQLFormatter = SQLFormatter({\n processorsRegistry: sqliteSQLProcessorsRegistry,\n});\n\nregisterFormatter('SQLite', sqliteFormatter);\n\nexport { sqliteFormatter };\n","import type { SQLiteDriverType } from '..';\nimport type { JSONSerializer, SQLFormatter, SQL } from '../../../../core';\nimport {\n mapSQLQueryResult,\n tracer,\n type BatchSQLCommandOptions,\n type DbSQLExecutor,\n type QueryResult,\n type QueryResultRow,\n type SQLCommandOptions,\n type SQLQueryOptions,\n} from '../../../../core';\nimport type { DumboError } from '../../../../core/errors';\nimport type { SQLiteClient } from '../connections';\nimport { mapSqliteError } from '../errors/errorMapper';\nimport { sqliteFormatter } from '../sql/formatter';\n\nexport type SQLiteErrorMapper = (error: unknown) => DumboError;\n\nexport const sqliteExecute = async <Result = void>(\n database: SQLiteClient,\n handle: (client: SQLiteClient) => Promise<Result>,\n) => {\n try {\n return await handle(database);\n } finally {\n await database.close();\n }\n};\n\nexport type SQLiteSQLExecutor<\n DriverType extends SQLiteDriverType = SQLiteDriverType,\n> = DbSQLExecutor<DriverType, SQLiteClient>;\n\nexport const sqliteSQLExecutor = <\n DriverType extends SQLiteDriverType = SQLiteDriverType,\n>(\n driverType: DriverType,\n serializer: JSONSerializer,\n formatter?: SQLFormatter,\n errorMapper?: SQLiteErrorMapper,\n): SQLiteSQLExecutor<DriverType> => ({\n driverType,\n query: async <Result extends QueryResultRow = QueryResultRow>(\n client: SQLiteClient,\n sql: SQL,\n options?: SQLQueryOptions,\n ): Promise<QueryResult<Result>> => {\n tracer.info('db:sql:query', {\n query: (formatter ?? sqliteFormatter).format(sql, { serializer }).query,\n params: (formatter ?? sqliteFormatter).format(sql, { serializer }).params,\n debugSQL: (formatter ?? sqliteFormatter).describe(sql, { serializer }),\n });\n\n try {\n let result = await client.query<Result>(sql, options);\n\n if (options?.mapping) {\n result = {\n ...result,\n rows: result.rows.map((row) =>\n mapSQLQueryResult(row, options.mapping!),\n ),\n };\n }\n\n return result;\n } catch (error) {\n tracer.error('db:sql:query:execute:error', { error });\n throw (errorMapper ?? mapSqliteError)(error);\n }\n },\n batchQuery: async <Result extends QueryResultRow = QueryResultRow>(\n client: SQLiteClient,\n sqls: SQL[],\n options?: SQLQueryOptions,\n ): Promise<QueryResult<Result>[]> => {\n try {\n const results = await client.batchQuery<Result>(sqls, options);\n\n if (options?.mapping) {\n return results.map((result) => ({\n ...result,\n rows: result.rows.map((row) =>\n mapSQLQueryResult(row, options.mapping!),\n ),\n }));\n }\n\n return results;\n } catch (error) {\n tracer.error('db:sql:batch_query:execute:error', { error });\n throw (errorMapper ?? mapSqliteError)(error);\n }\n },\n command: async <Result extends QueryResultRow = QueryResultRow>(\n client: SQLiteClient,\n sql: SQL,\n options?: SQLCommandOptions,\n ): Promise<QueryResult<Result>> => {\n tracer.info('db:sql:command', {\n query: (formatter ?? sqliteFormatter).format(sql, { serializer }).query,\n params: (formatter ?? sqliteFormatter).format(sql, { serializer }).params,\n debugSQL: (formatter ?? sqliteFormatter).describe(sql, { serializer }),\n });\n\n try {\n return await client.command<Result>(sql, options);\n } catch (error) {\n tracer.error('db:sql:command:execute:error', { error });\n throw (errorMapper ?? mapSqliteError)(error);\n }\n },\n batchCommand: async <Result extends QueryResultRow = QueryResultRow>(\n client: SQLiteClient,\n sqls: SQL[],\n options?: BatchSQLCommandOptions,\n ): Promise<QueryResult<Result>[]> => {\n try {\n return await client.batchCommand<Result>(sqls, options);\n } catch (error) {\n tracer.error('db:sql:batch_command:execute:error', { error });\n throw (errorMapper ?? mapSqliteError)(error);\n }\n },\n formatter: formatter ?? sqliteFormatter,\n});\n","import { cpus } from 'os';\nimport {\n createBoundedConnectionPool,\n createSingletonConnectionPool,\n} from '../../../../core';\nimport type {\n AnySQLiteConnection,\n SQLiteConnectionFactory,\n SQLiteConnectionOptions,\n} from '../connections';\nimport type { SQLitePool } from './pool';\n\nexport type SQLiteDualPoolOptions<\n SQLiteConnectionType extends AnySQLiteConnection,\n ConnectionOptions extends SQLiteConnectionOptions,\n> = {\n driverType: SQLiteConnectionType['driverType'];\n dual: true;\n singleton?: false;\n pooled?: true;\n connection?: never;\n readerPoolSize?: number;\n sqliteConnectionFactory: SQLiteConnectionFactory<\n SQLiteConnectionType,\n ConnectionOptions\n >;\n connectionOptions: ConnectionOptions;\n};\n\nexport const sqliteDualConnectionPool = <\n SQLiteConnectionType extends AnySQLiteConnection,\n ConnectionOptions extends SQLiteConnectionOptions,\n>(\n options: SQLiteDualPoolOptions<SQLiteConnectionType, ConnectionOptions>,\n): SQLitePool<SQLiteConnectionType> => {\n const { sqliteConnectionFactory, connectionOptions } = options;\n const readerPoolSize = options.readerPoolSize ?? Math.max(4, cpus().length);\n\n const writerPool = createSingletonConnectionPool({\n driverType: options.driverType,\n getConnection: () => sqliteConnectionFactory(connectionOptions),\n });\n\n const readerPool = createBoundedConnectionPool({\n driverType: options.driverType,\n getConnection: () => sqliteConnectionFactory(connectionOptions),\n maxConnections: readerPoolSize,\n });\n\n return {\n driverType: options.driverType,\n connection: (connectionOptions) =>\n connectionOptions?.readonly\n ? readerPool.connection(connectionOptions)\n : writerPool.connection(connectionOptions),\n execute: {\n query: (...args) => readerPool.execute.query(...args),\n batchQuery: (...args) => readerPool.execute.batchQuery(...args),\n command: (...args) => writerPool.execute.command(...args),\n batchCommand: (...args) => writerPool.execute.batchCommand(...args),\n },\n withConnection: (handle, connectionOptions) =>\n connectionOptions?.readonly\n ? readerPool.withConnection(handle, connectionOptions)\n : writerPool.withConnection(handle, connectionOptions),\n transaction: writerPool.transaction,\n withTransaction: writerPool.withTransaction,\n close: () =>\n Promise.all([writerPool.close(), readerPool.close()]).then(() => {}),\n };\n};\n","import type { SQLiteConnectionString } from '..';\nimport {\n InMemorySQLiteDatabase,\n type AnySQLiteConnection,\n type SQLiteConnectionFactory,\n type SQLiteConnectionOptions,\n} from '..';\nimport type { JSONSerializer } from '../../../../core';\nimport {\n createAlwaysNewConnectionPool,\n createAmbientConnectionPool,\n createSingletonConnectionPool,\n type ConnectionPool,\n} from '../../../../core';\nimport {\n sqliteDualConnectionPool,\n type SQLiteDualPoolOptions,\n} from './dualPool';\n\nexport type SQLiteFileNameOrConnectionString =\n | {\n fileName: string | SQLiteConnectionString;\n connectionString?: never;\n }\n | {\n connectionString: string | SQLiteConnectionString;\n fileName?: never;\n };\n\nexport const isInMemoryDatabase = (\n options: Record<string, unknown>,\n): boolean => {\n if ('fileName' in options) {\n return options.fileName === InMemorySQLiteDatabase;\n }\n if ('connectionString' in options) {\n return options.connectionString === InMemorySQLiteDatabase;\n }\n return false;\n};\n\nexport type SQLiteAmbientConnectionPool<\n SQLiteConnectionType extends AnySQLiteConnection = AnySQLiteConnection,\n> = ConnectionPool<SQLiteConnectionType>;\n\ntype SQLiteAmbientConnectionPoolOptions<\n SQLiteConnectionType extends AnySQLiteConnection = AnySQLiteConnection,\n> = {\n singleton?: true;\n pooled?: false;\n sqliteConnectionFactory?: never;\n connection: SQLiteConnectionType;\n connectionOptions?: never;\n};\n\nexport const sqliteAmbientConnectionPool = <\n SQLiteConnectionType extends AnySQLiteConnection = AnySQLiteConnection,\n>(\n options: {\n driverType: SQLiteConnectionType['driverType'];\n } & SQLiteAmbientConnectionPoolOptions<SQLiteConnectionType['driverType']>,\n): SQLiteAmbientConnectionPool<SQLiteConnectionType['driverType']> => {\n const { connection, driverType } = options;\n\n return createAmbientConnectionPool<SQLiteConnectionType>({\n driverType,\n connection: connection,\n }) as unknown as SQLiteAmbientConnectionPool<\n SQLiteConnectionType['driverType']\n >;\n};\n\ntype SQLiteSingletonConnectionPoolOptions<\n SQLiteConnectionType extends AnySQLiteConnection = AnySQLiteConnection,\n ConnectionOptions extends SQLiteConnectionOptions = SQLiteConnectionOptions,\n> = {\n singleton: true;\n pooled?: true;\n sqliteConnectionFactory: SQLiteConnectionFactory<\n SQLiteConnectionType,\n ConnectionOptions\n >;\n connection?: never;\n connectionOptions: ConnectionOptions;\n};\n\nexport type SQLiteSingletonConnectionPool<\n SQLiteConnectionType extends AnySQLiteConnection = AnySQLiteConnection,\n> = ConnectionPool<SQLiteConnectionType>;\n\nexport const sqliteSingletonConnectionPool = <\n SQLiteConnectionType extends AnySQLiteConnection = AnySQLiteConnection,\n ConnectionOptions extends SQLiteConnectionOptions & Record<string, unknown> =\n SQLiteConnectionOptions & Record<string, unknown>,\n>(\n options: {\n driverType: SQLiteConnectionType['driverType'];\n } & SQLiteSingletonConnectionPoolOptions<\n SQLiteConnectionType,\n ConnectionOptions\n >,\n): SQLiteSingletonConnectionPool<SQLiteConnectionType> => {\n const { driverType, sqliteConnectionFactory, connectionOptions } = options;\n\n return createSingletonConnectionPool<SQLiteConnectionType>({\n driverType,\n getConnection: () => sqliteConnectionFactory(connectionOptions),\n }) as unknown as SQLiteSingletonConnectionPool<SQLiteConnectionType>;\n};\n\ntype SQLiteAlwaysNewPoolOptions<\n SQLiteConnectionType extends AnySQLiteConnection = AnySQLiteConnection,\n ConnectionOptions extends SQLiteConnectionOptions = SQLiteConnectionOptions,\n> = {\n singleton?: false;\n pooled?: true;\n sqliteConnectionFactory: SQLiteConnectionFactory<\n SQLiteConnectionType,\n ConnectionOptions\n >;\n connection?: never;\n connectionOptions: ConnectionOptions;\n};\n\nexport type SQLiteAlwaysNewConnectionPool<\n SQLiteConnectionType extends AnySQLiteConnection = AnySQLiteConnection,\n> = ConnectionPool<SQLiteConnectionType>;\n\nexport const sqliteAlwaysNewConnectionPool = <\n SQLiteConnectionType extends AnySQLiteConnection = AnySQLiteConnection,\n ConnectionOptions extends SQLiteConnectionOptions & Record<string, unknown> =\n SQLiteConnectionOptions & Record<string, unknown>,\n>(\n options: {\n driverType: SQLiteConnectionType['driverType'];\n } & SQLiteAlwaysNewPoolOptions<SQLiteConnectionType, ConnectionOptions>,\n): SQLiteAlwaysNewConnectionPool<SQLiteConnectionType> => {\n const { driverType, sqliteConnectionFactory, connectionOptions } = options;\n\n return createAlwaysNewConnectionPool<SQLiteConnectionType>({\n driverType,\n getConnection: () => sqliteConnectionFactory(connectionOptions),\n }) as unknown as SQLiteAlwaysNewConnectionPool<SQLiteConnectionType>;\n};\n\nexport type SQLitePoolOptions<\n SQLiteConnectionType extends AnySQLiteConnection = AnySQLiteConnection,\n ConnectionOptions extends SQLiteConnectionOptions = SQLiteConnectionOptions,\n> = (\n | SQLiteAlwaysNewPoolOptions<SQLiteConnectionType, ConnectionOptions>\n | SQLiteSingletonConnectionPoolOptions<\n SQLiteConnectionType,\n ConnectionOptions\n >\n | SQLiteAmbientConnectionPoolOptions<SQLiteConnectionType>\n | SQLiteDualPoolOptions<SQLiteConnectionType, ConnectionOptions>\n) & {\n driverType: SQLiteConnectionType['driverType'];\n serializer?: JSONSerializer;\n};\n\nexport type SQLitePool<\n SQLiteConnectionType extends AnySQLiteConnection = AnySQLiteConnection,\n> =\n | SQLiteAmbientConnectionPool<SQLiteConnectionType>\n | SQLiteSingletonConnectionPool<SQLiteConnectionType>\n | SQLiteAlwaysNewConnectionPool<SQLiteConnectionType>;\n\nexport type SQLitePoolFactoryOptions<\n SQLiteConnectionType extends AnySQLiteConnection,\n ConnectionOptions extends SQLiteConnectionOptions,\n> = Omit<\n SQLitePoolOptions<SQLiteConnectionType, ConnectionOptions>,\n 'singleton'\n> & {\n singleton?: boolean;\n};\n\nexport const toSqlitePoolOptions = <\n SQLiteConnectionType extends AnySQLiteConnection,\n ConnectionOptions extends SQLiteConnectionOptions,\n>(\n options: SQLitePoolFactoryOptions<SQLiteConnectionType, ConnectionOptions>,\n): SQLitePoolOptions<SQLiteConnectionType, ConnectionOptions> => {\n const { singleton, ...rest } = options;\n const isInMemory = isInMemoryDatabase(options);\n\n if (isInMemory) {\n return { ...rest, singleton: true } as SQLitePoolOptions<\n SQLiteConnectionType,\n ConnectionOptions\n >;\n }\n\n if (singleton === true) {\n return { ...rest, singleton: true } as SQLitePoolOptions<\n SQLiteConnectionType,\n ConnectionOptions\n >;\n }\n\n return { ...rest, dual: true } as SQLitePoolOptions<\n SQLiteConnectionType,\n ConnectionOptions\n >;\n};\n\nexport function sqlitePool<\n SQLiteConnectionType extends AnySQLiteConnection = AnySQLiteConnection,\n ConnectionOptions extends SQLiteConnectionOptions = SQLiteConnectionOptions,\n>(\n options: SQLitePoolOptions<SQLiteConnectionType, ConnectionOptions>,\n): SQLitePool<SQLiteConnectionType> {\n const { driverType } = options;\n\n // TODO: Handle dates and bigints\n // setSQLiteTypeParser(serializer ?? JSONSerializer);\n\n if (\n (\n options as SQLiteAmbientConnectionPoolOptions<SQLiteConnectionType> & {\n driverType: SQLiteConnectionType['driverType'];\n }\n ).connection\n )\n return createAmbientConnectionPool<SQLiteConnectionType>({\n driverType,\n connection: (\n options as SQLiteAmbientConnectionPoolOptions<SQLiteConnectionType> & {\n driverType: SQLiteConnectionType['driverType'];\n }\n ).connection,\n });\n\n if ('dual' in options && options.dual) {\n return sqliteDualConnectionPool(\n options as SQLiteDualPoolOptions<SQLiteConnectionType, ConnectionOptions>,\n );\n }\n\n if (\n options.singleton === true &&\n (\n options as SQLiteSingletonConnectionPoolOptions<\n SQLiteConnectionType,\n ConnectionOptions\n > & { driverType: SQLiteConnectionType['driverType'] }\n ).sqliteConnectionFactory\n ) {\n return createSingletonConnectionPool({\n driverType,\n getConnection: () =>\n (\n options as SQLiteSingletonConnectionPoolOptions<\n SQLiteConnectionType,\n ConnectionOptions\n > & { driverType: SQLiteConnectionType['driverType'] }\n ).sqliteConnectionFactory(\n (\n options as SQLiteSingletonConnectionPoolOptions<\n SQLiteConnectionType,\n ConnectionOptions\n > & { driverType: SQLiteConnectionType['driverType'] }\n ).connectionOptions,\n ),\n });\n }\n\n return createAlwaysNewConnectionPool({\n driverType,\n getConnection: () =>\n (\n options as SQLiteAlwaysNewPoolOptions<\n SQLiteConnectionType,\n ConnectionOptions\n > & { driverType: SQLiteConnectionType['driverType'] }\n ).sqliteConnectionFactory(\n (\n options as SQLiteAlwaysNewPoolOptions<\n SQLiteConnectionType,\n ConnectionOptions\n > & { driverType: SQLiteConnectionType['driverType'] }\n ).connectionOptions,\n ),\n });\n}\n","import {\n registerDefaultMigratorOptions,\n type MigratorOptions,\n} from '../../../../core';\n\nexport const DefaultSQLiteMigratorOptions: MigratorOptions = {};\n\nregisterDefaultMigratorOptions('SQLite', DefaultSQLiteMigratorOptions);\n","import type { DatabaseDriverType } from '../../..';\n\nexport * from './connections';\nexport * from './errors';\nexport * from './execute';\nexport * from './pool';\nexport * from './schema';\nexport * from './sql';\nexport * from './transactions';\n\nexport type SQLiteDatabaseName = 'SQLite';\nexport const SQLiteDatabaseName = 'SQLite';\n\nexport type SQLiteDriverType<DriverName extends string = string> =\n DatabaseDriverType<SQLiteDatabaseName, DriverName>;\n\nexport type SQLiteDatabaseType = 'SQLite';\n","import type { DatabaseConnectionString } from '../../../all';\nimport type { SQLitePragmaOptions } from './index';\n\nexport type SQLiteConnectionString = DatabaseConnectionString<\n 'SQLite',\n `file:${string}` | `:memory:` | `/${string}` | `./${string}`\n>;\n\nexport const SQLiteConnectionString = (\n connectionString: string,\n): SQLiteConnectionString => {\n if (\n !connectionString.startsWith('file:') &&\n connectionString !== ':memory:' &&\n !connectionString.startsWith('/') &&\n !connectionString.startsWith('./')\n ) {\n throw new Error(\n `Invalid SQLite connection string: ${connectionString}. It should start with \"file:\", \":memory:\", \"/\", or \"./\".`,\n );\n }\n return connectionString as SQLiteConnectionString;\n};\n\nexport const parsePragmasFromConnectionString = (\n connectionString: string | SQLiteConnectionString,\n): Partial<SQLitePragmaOptions> => {\n const str = String(connectionString);\n\n if (!str.startsWith('file:')) {\n return {};\n }\n\n const url = new URL(str);\n const params = url.searchParams;\n const pragmas: Partial<SQLitePragmaOptions> = {};\n\n const journalMode = params.get('journal_mode');\n if (journalMode !== null) {\n pragmas.journal_mode = journalMode as\n | 'DELETE'\n | 'TRUNCATE'\n | 'PERSIST'\n | 'MEMORY'\n | 'WAL'\n | 'OFF';\n }\n\n const synchronous = params.get('synchronous');\n if (synchronous !== null) {\n pragmas.synchronous = synchronous as 'OFF' | 'NORMAL' | 'FULL' | 'EXTRA';\n }\n\n const cacheSize = params.get('cache_size');\n if (cacheSize !== null) {\n pragmas.cache_size = parseInt(cacheSize, 10);\n }\n\n const foreignKeys = params.get('foreign_keys');\n if (foreignKeys !== null) {\n const val = foreignKeys.toLowerCase();\n pragmas.foreign_keys = val === 'true' || val === 'on' || val === '1';\n }\n\n const tempStore = params.get('temp_store');\n if (tempStore !== null) {\n pragmas.temp_store = tempStore.toUpperCase() as\n | 'DEFAULT'\n | 'FILE'\n | 'MEMORY';\n }\n\n const busyTimeout = params.get('busy_timeout');\n if (busyTimeout !== null) {\n pragmas.busy_timeout = parseInt(busyTimeout, 10);\n }\n\n return pragmas;\n};\n","import {\n SQLiteConnectionString,\n sqliteSQLExecutor,\n type SQLiteDriverType,\n type SQLiteErrorMapper,\n} from '..';\nimport type { JSONSerializer } from '../../../../core';\nimport {\n createAmbientConnection,\n createConnection,\n type AnyConnection,\n type BatchSQLCommandOptions,\n type Connection,\n type ConnectionOptions,\n type DatabaseTransaction,\n type InferDbClientFromConnection,\n type InferDriverTypeFromConnection,\n type InitTransaction,\n type SQLCommandOptions,\n type SQLExecutor,\n} from '../../../../core';\nimport { sqliteTransaction, type SQLiteTransactionMode } from '../transactions';\n\nexport type SQLiteCommandOptions = SQLCommandOptions & {\n ignoreChangesCount?: boolean;\n};\n\nexport type BatchSQLiteCommandOptions = SQLiteCommandOptions &\n BatchSQLCommandOptions;\n\nexport type SQLiteParameters =\n | object\n | string\n | bigint\n | number\n | boolean\n | null;\n\nexport type SQLiteClient = {\n connect: () => Promise<void>;\n close: () => Promise<void>;\n} & SQLExecutor;\n\nexport type SQLitePoolClient = {\n release: () => void;\n} & SQLExecutor;\n\nexport type SQLiteClientFactory<\n SQLiteClientType extends SQLiteClient = SQLiteClient,\n ClientOptions = SQLiteClientOptions,\n> = (options: ClientOptions) => SQLiteClientType;\n\nexport type SQLiteClientOrPoolClient = SQLitePoolClient | SQLiteClient;\n\nexport interface SQLiteError extends Error {\n errno: number;\n}\n\nexport const isSQLiteError = (error: unknown): error is SQLiteError => {\n if (error instanceof Error && 'code' in error) {\n return true;\n }\n\n return false;\n};\n\nexport type SQLiteClientConnection<\n Self extends AnyConnection = AnyConnection,\n DriverType extends SQLiteDriverType = SQLiteDriverType,\n SQLiteClientType extends SQLiteClient = SQLiteClient,\n TransactionType extends DatabaseTransaction<Self> = DatabaseTransaction<Self>,\n> = Connection<Self, DriverType, SQLiteClientType, TransactionType>;\n\nexport type SQLitePoolClientConnection<\n Self extends AnyConnection = AnyConnection,\n DriverType extends SQLiteDriverType = SQLiteDriverType,\n SQLitePoolClientType extends SQLitePoolClient = SQLitePoolClient,\n TransactionType extends DatabaseTransaction<Self> = DatabaseTransaction<Self>,\n> = Connection<Self, DriverType, SQLitePoolClientType, TransactionType>;\n\nexport type SQLiteConnection<\n Self extends AnyConnection = AnyConnection,\n DriverType extends SQLiteDriverType = SQLiteDriverType,\n SQLiteClientType extends SQLiteClientOrPoolClient =\n | SQLiteClient\n | SQLitePoolClient,\n TransactionType extends DatabaseTransaction<Self> = DatabaseTransaction<Self>,\n> =\n | (SQLiteClientType extends SQLiteClient\n ? SQLiteClientConnection<\n Self,\n DriverType,\n SQLiteClientType,\n TransactionType\n >\n : never)\n | (SQLiteClientType extends SQLitePoolClient\n ? SQLitePoolClientConnection<\n Self,\n DriverType,\n SQLiteClientType,\n TransactionType\n >\n : never);\n\nexport type AnySQLiteClientConnection =\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n SQLiteClientConnection<any, any>;\n\nexport type AnySQLitePoolClientConnection =\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n SQLitePoolClientConnection<any, any, any, any>;\n\nexport type AnySQLiteConnection =\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n SQLiteConnection<any, any, any, any>;\n\nexport type SQLiteConnectionOptions<\n ConnectionType extends AnySQLiteConnection = AnySQLiteConnection,\n> = ConnectionOptions<ConnectionType> & SQLiteClientOptions;\n\nexport type SQLiteClientConnectionDefinitionOptions<\n SQLiteConnectionType extends AnySQLiteClientConnection =\n AnySQLiteClientConnection,\n ConnectionOptions = SQLiteConnectionOptions,\n> = {\n driverType: InferDriverTypeFromConnection<SQLiteConnectionType>;\n type: 'Client';\n sqliteClientFactory: SQLiteClientFactory<\n InferDbClientFromConnection<SQLiteConnectionType>,\n ConnectionOptions\n >;\n connectionOptions: SQLiteConnectionOptions<SQLiteConnectionType>;\n serializer: JSONSerializer;\n};\n\nexport type SQLitePoolConnectionDefinitionOptions<\n SQLiteConnectionType extends AnySQLitePoolClientConnection =\n AnySQLitePoolClientConnection,\n ConnectionOptions = SQLiteConnectionOptions,\n> = {\n driverType: InferDriverTypeFromConnection<SQLiteConnectionType>;\n type: 'PoolClient';\n sqliteClientFactory: SQLiteClientFactory<\n InferDbClientFromConnection<SQLiteConnectionType>,\n ConnectionOptions\n >;\n connectionOptions: SQLiteConnectionOptions<SQLiteConnectionType>;\n serializer: JSONSerializer;\n};\n\nexport type SQLiteConnectionDefinitionOptions<\n SQLiteConnectionType extends AnySQLitePoolClientConnection =\n AnySQLitePoolClientConnection,\n ClientOptions = SQLiteClientOptions,\n> =\n | SQLiteClientConnectionDefinitionOptions<SQLiteConnectionType, ClientOptions>\n | SQLitePoolConnectionDefinitionOptions<SQLiteConnectionType, ClientOptions>;\n\nexport type SQLiteConnectionFactory<\n SQLiteConnectionType extends AnySQLiteConnection = AnySQLiteConnection,\n ConnectionOptions extends SQLiteConnectionOptions = SQLiteConnectionOptions,\n> = (options: ConnectionOptions) => SQLiteConnectionType;\n\nexport type TransactionNestingCounter = {\n increment: () => void;\n decrement: () => void;\n reset: () => void;\n level: number;\n};\n\nexport const transactionNestingCounter = (): TransactionNestingCounter => {\n let transactionLevel = 0;\n\n return {\n reset: () => {\n transactionLevel = 0;\n },\n increment: () => {\n transactionLevel++;\n },\n decrement: () => {\n transactionLevel--;\n\n if (transactionLevel < 0) {\n throw new Error('Transaction level is out of bounds');\n }\n },\n get level() {\n return transactionLevel;\n },\n };\n};\n\nexport type SqliteAmbientClientConnectionOptions<\n SQLiteConnectionType extends AnySQLiteClientConnection =\n AnySQLiteClientConnection,\n> = {\n driverType: SQLiteConnectionType['driverType'];\n client: InferDbClientFromConnection<SQLiteConnectionType>;\n initTransaction?: InitTransaction<SQLiteConnectionType>;\n allowNestedTransactions?: boolean;\n defaultTransactionMode?: SQLiteTransactionMode;\n serializer: JSONSerializer;\n errorMapper?: SQLiteErrorMapper;\n};\n\nexport const sqliteAmbientClientConnection = <\n SQLiteConnectionType extends AnySQLiteClientConnection =\n AnySQLiteClientConnection,\n>(\n options: SqliteAmbientClientConnectionOptions<SQLiteConnectionType>,\n) => {\n const {\n client,\n driverType,\n initTransaction,\n allowNestedTransactions,\n defaultTransactionMode,\n serializer,\n errorMapper,\n } = options;\n\n return createAmbientConnection<SQLiteConnectionType>({\n driverType,\n client,\n initTransaction:\n initTransaction ??\n ((connection) =>\n sqliteTransaction(\n driverType,\n connection,\n allowNestedTransactions ?? false,\n serializer,\n defaultTransactionMode,\n )),\n executor: ({ serializer }) =>\n sqliteSQLExecutor(driverType, serializer, undefined, errorMapper),\n serializer,\n });\n};\n\nexport const sqliteClientConnection = <\n SQLiteConnectionType extends AnySQLiteClientConnection =\n AnySQLiteClientConnection,\n ClientOptions = SQLiteClientOptions,\n>(\n options: SQLiteClientConnectionDefinitionOptions<\n SQLiteConnectionType,\n ClientOptions\n >,\n): SQLiteConnectionType => {\n const { connectionOptions, sqliteClientFactory, serializer } = options;\n\n let client: InferDbClientFromConnection<SQLiteConnectionType> | null = null;\n\n const connect = async (): Promise<\n InferDbClientFromConnection<SQLiteConnectionType>\n > => {\n if (client) return Promise.resolve(client);\n\n client = sqliteClientFactory(connectionOptions as ClientOptions);\n\n if (client && 'connect' in client && typeof client.connect === 'function')\n await client.connect();\n\n return client;\n };\n\n return createConnection({\n driverType: options.driverType,\n connect,\n close: async () => {\n if (client && 'close' in client && typeof client.close === 'function')\n await client.close();\n else if (\n client &&\n 'release' in client &&\n typeof client.release === 'function'\n )\n // eslint-disable-next-line @typescript-eslint/no-unsafe-call\n client.release();\n },\n initTransaction: (connection) =>\n sqliteTransaction(\n options.driverType,\n connection,\n connectionOptions.transactionOptions?.allowNestedTransactions ?? false,\n serializer,\n connectionOptions.defaultTransactionMode,\n ),\n executor: ({ serializer }) =>\n sqliteSQLExecutor(options.driverType, serializer),\n serializer,\n });\n};\n\nexport const sqlitePoolClientConnection = <\n SQLiteConnectionType extends AnySQLiteClientConnection =\n AnySQLiteClientConnection,\n ClientOptions = SQLiteClientOptions,\n>(\n options: SQLitePoolConnectionDefinitionOptions<\n SQLiteConnectionType,\n ClientOptions\n >,\n): SQLiteConnectionType => {\n const { connectionOptions, sqliteClientFactory, serializer } = options;\n\n let client: InferDbClientFromConnection<SQLiteConnectionType> | null = null;\n\n const connect = async (): Promise<\n InferDbClientFromConnection<SQLiteConnectionType>\n > => {\n if (client) return Promise.resolve(client);\n\n client = sqliteClientFactory(connectionOptions as ClientOptions);\n\n await client.connect();\n\n return client;\n };\n\n return createConnection({\n driverType: options.driverType,\n connect,\n close: () =>\n client !== null\n ? Promise.resolve((client as unknown as SQLitePoolClient).release())\n : Promise.resolve(),\n initTransaction: (connection) =>\n sqliteTransaction(\n options.driverType,\n connection,\n connectionOptions.transactionOptions?.allowNestedTransactions ?? false,\n serializer,\n connectionOptions.defaultTransactionMode,\n ),\n executor: ({ serializer }) =>\n sqliteSQLExecutor(options.driverType, serializer),\n serializer,\n });\n};\n\nexport function sqliteConnection<\n SQLiteConnectionType extends AnySQLiteConnection = AnySQLiteConnection,\n ClientOptions = SQLiteClientOptions,\n>(\n options: SQLiteConnectionDefinitionOptions<\n SQLiteConnectionType,\n ClientOptions\n >,\n): SQLiteConnectionType {\n return options.type === 'Client'\n ? sqliteClientConnection(options)\n : sqlitePoolClientConnection(options);\n}\n\nexport type InMemorySQLiteDatabase = ':memory:';\nexport const InMemorySQLiteDatabase = SQLiteConnectionString(':memory:');\n\nexport type SQLitePragmaOptions = {\n journal_mode?: 'DELETE' | 'TRUNCATE' | 'PERSIST' | 'MEMORY' | 'WAL' | 'OFF';\n synchronous?: 'OFF' | 'NORMAL' | 'FULL' | 'EXTRA';\n cache_size?: number;\n foreign_keys?: boolean;\n temp_store?: 'DEFAULT' | 'FILE' | 'MEMORY';\n busy_timeout?: number;\n};\n\nexport const DEFAULT_SQLITE_PRAGMA_OPTIONS: SQLitePragmaOptions = {\n journal_mode: 'WAL',\n synchronous: 'NORMAL',\n cache_size: -1000000,\n foreign_keys: true,\n temp_store: 'MEMORY',\n busy_timeout: 5000,\n};\n\nexport type SQLiteClientOptions = {\n pragmaOptions?: Partial<SQLitePragmaOptions>;\n defaultTransactionMode?: SQLiteTransactionMode;\n};\n\nexport * from './connectionString';\n","import type {\n InferTransactionFromConnection,\n JSONSerializer,\n} from '../../../../core';\nimport {\n SQL,\n sqlExecutor,\n type DatabaseTransaction,\n type DatabaseTransactionOptions,\n type InferDbClientFromConnection,\n} from '../../../../core';\nimport { sqliteSQLExecutor } from '../../core/execute';\nimport {\n transactionNestingCounter,\n type AnySQLiteConnection,\n type SQLiteClientOrPoolClient,\n} from '../connections';\n\nexport type SQLiteTransaction<\n ConnectionType extends AnySQLiteConnection = AnySQLiteConnection,\n TransactionOptions extends SQLiteTransactionOptions =\n SQLiteTransactionOptions,\n> = DatabaseTransaction<ConnectionType, TransactionOptions>;\n\nexport type SQLiteTransactionMode = 'DEFERRED' | 'IMMEDIATE' | 'EXCLUSIVE';\n\nexport type SQLiteTransactionOptions = DatabaseTransactionOptions & {\n mode?: SQLiteTransactionMode;\n useSavepoints?: boolean;\n};\n\nexport const sqliteTransaction =\n <ConnectionType extends AnySQLiteConnection = AnySQLiteConnection>(\n driverType: ConnectionType['driverType'],\n connection: () => ConnectionType,\n allowNestedTransactions: boolean,\n serializer: JSONSerializer,\n defaultTransactionMode?: 'IMMEDIATE' | 'DEFERRED' | 'EXCLUSIVE',\n ) =>\n (\n getClient: Promise<InferDbClientFromConnection<ConnectionType>>,\n options?: {\n close: (\n client: InferDbClientFromConnection<ConnectionType>,\n error?: unknown,\n ) => Promise<void>;\n } & SQLiteTransactionOptions,\n ): InferTransactionFromConnection<ConnectionType> => {\n const transactionCounter = transactionNestingCounter();\n allowNestedTransactions =\n options?.allowNestedTransactions ?? allowNestedTransactions;\n\n const transaction: DatabaseTransaction<ConnectionType> = {\n connection: connection(),\n driverType,\n begin: async function () {\n const client = (await getClient) as SQLiteClientOrPoolClient;\n\n if (allowNestedTransactions) {\n if (transactionCounter.level >= 1) {\n transactionCounter.increment();\n if (options?.useSavepoints) {\n await client.query(\n SQL`SAVEPOINT transaction${SQL.plain(transactionCounter.level.toString())}`,\n );\n }\n return;\n }\n\n transactionCounter.increment();\n }\n\n const mode = options?.mode ?? defaultTransactionMode ?? 'IMMEDIATE';\n await client.query(SQL`BEGIN ${SQL.plain(mode)} TRANSACTION`);\n },\n commit: async function () {\n const client = (await getClient) as SQLiteClientOrPoolClient;\n\n try {\n if (allowNestedTransactions) {\n if (transactionCounter.level > 1) {\n if (options?.useSavepoints) {\n await client.query(\n SQL`RELEASE transaction${SQL.plain(transactionCounter.level.toString())}`,\n );\n }\n transactionCounter.decrement();\n\n return;\n }\n\n transactionCounter.reset();\n }\n await client.query(SQL`COMMIT`);\n } finally {\n if (options?.close)\n await options?.close(\n client as InferDbClientFromConnection<ConnectionType>,\n );\n }\n },\n rollback: async function (error?: unknown) {\n const client = (await getClient) as SQLiteClientOrPoolClient;\n try {\n if (allowNestedTransactions) {\n if (transactionCounter.level > 1) {\n transactionCounter.decrement();\n return;\n }\n }\n\n await client.query(SQL`ROLLBACK`);\n } finally {\n if (options?.close)\n await options?.close(\n client as InferDbClientFromConnection<ConnectionType>,\n error,\n );\n }\n },\n execute: sqlExecutor(sqliteSQLExecutor(driverType, serializer), {\n connect: () => getClient,\n }),\n _transactionOptions: options ?? {},\n };\n\n // eslint-disable-next-line @typescript-eslint/no-unsafe-return\n return transaction as InferTransactionFromConnection<ConnectionType>;\n };\n"],"mappings":"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","names":["connectionOptions","serializer"]}
|