@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.
Files changed (62) hide show
  1. package/dist/{chunk-FC4JR2R3.js → chunk-56QRSCG5.js} +2 -2
  2. package/dist/{chunk-65DKXURG.js → chunk-5OX6NE4Z.js} +2 -2
  3. package/dist/{chunk-IVJ3SNPJ.js → chunk-5SCFH2HY.js} +2 -2
  4. package/dist/{chunk-AMACBMAZ.cjs → chunk-7D7WADBK.cjs} +186 -98
  5. package/dist/chunk-7D7WADBK.cjs.map +1 -0
  6. package/dist/{chunk-H7ZKIJHB.cjs → chunk-7RMJPFU5.cjs} +6 -6
  7. package/dist/{chunk-H7ZKIJHB.cjs.map → chunk-7RMJPFU5.cjs.map} +1 -1
  8. package/dist/{chunk-7WEBHXZD.cjs → chunk-HXQYRDCR.cjs} +43 -43
  9. package/dist/{chunk-7WEBHXZD.cjs.map → chunk-HXQYRDCR.cjs.map} +1 -1
  10. package/dist/{chunk-T4A6BQRA.js → chunk-LPIIB75Q.js} +120 -32
  11. package/dist/chunk-LPIIB75Q.js.map +1 -0
  12. package/dist/{chunk-XO5T5N5S.js → chunk-QUAG4MBP.js} +294 -14
  13. package/dist/chunk-QUAG4MBP.js.map +1 -0
  14. package/dist/{chunk-XOQHZABK.cjs → chunk-QVEVSWG6.cjs} +307 -27
  15. package/dist/chunk-QVEVSWG6.cjs.map +1 -0
  16. package/dist/{chunk-R7P7CNMK.cjs → chunk-TMFEMKPE.cjs} +4 -4
  17. package/dist/{chunk-R7P7CNMK.cjs.map → chunk-TMFEMKPE.cjs.map} +1 -1
  18. package/dist/cloudflare.cjs +66 -61
  19. package/dist/cloudflare.cjs.map +1 -1
  20. package/dist/cloudflare.d.cts +4 -4
  21. package/dist/cloudflare.d.ts +4 -4
  22. package/dist/cloudflare.js +9 -4
  23. package/dist/cloudflare.js.map +1 -1
  24. package/dist/{columnProcessors-Difrrk4c.d.cts → columnProcessors-CsQjv8si.d.cts} +1 -1
  25. package/dist/{columnProcessors-C7fRa54L.d.ts → columnProcessors-giHzjHuv.d.ts} +1 -1
  26. package/dist/{connectionString-oeg1LD5V.d.ts → connectionString-J4yRT71A.d.cts} +40 -31
  27. package/dist/{connectionString-oeg1LD5V.d.cts → connectionString-J4yRT71A.d.ts} +40 -31
  28. package/dist/index.cjs +7 -5
  29. package/dist/index.cjs.map +1 -1
  30. package/dist/index.d.cts +3 -3
  31. package/dist/index.d.ts +3 -3
  32. package/dist/index.js +5 -3
  33. package/dist/index.js.map +1 -1
  34. package/dist/pg.cjs +39 -38
  35. package/dist/pg.cjs.map +1 -1
  36. package/dist/pg.d.cts +7 -7
  37. package/dist/pg.d.ts +7 -7
  38. package/dist/pg.js +5 -4
  39. package/dist/pg.js.map +1 -1
  40. package/dist/postgresql.cjs +4 -4
  41. package/dist/postgresql.d.cts +2 -2
  42. package/dist/postgresql.d.ts +2 -2
  43. package/dist/postgresql.js +3 -3
  44. package/dist/sqlite.cjs +8 -4
  45. package/dist/sqlite.cjs.map +1 -1
  46. package/dist/sqlite.d.cts +49 -23
  47. package/dist/sqlite.d.ts +49 -23
  48. package/dist/sqlite.js +7 -3
  49. package/dist/sqlite3.cjs +65 -28
  50. package/dist/sqlite3.cjs.map +1 -1
  51. package/dist/sqlite3.d.cts +11 -11
  52. package/dist/sqlite3.d.ts +11 -11
  53. package/dist/sqlite3.js +48 -11
  54. package/dist/sqlite3.js.map +1 -1
  55. package/package.json +1 -1
  56. package/dist/chunk-AMACBMAZ.cjs.map +0 -1
  57. package/dist/chunk-T4A6BQRA.js.map +0 -1
  58. package/dist/chunk-XO5T5N5S.js.map +0 -1
  59. package/dist/chunk-XOQHZABK.cjs.map +0 -1
  60. /package/dist/{chunk-FC4JR2R3.js.map → chunk-56QRSCG5.js.map} +0 -0
  61. /package/dist/{chunk-65DKXURG.js.map → chunk-5OX6NE4Z.js.map} +0 -0
  62. /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-XO5T5N5S.js";
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 useSingleton = singleton ?? isInMemoryDatabase(options);
320
- if (useSingleton) {
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, singleton: false };
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(options.connectionOptions)
363
+ getConnection: () => options.sqliteConnectionFactory(
364
+ options.connectionOptions
365
+ )
336
366
  });
337
367
  }
338
368
  return createAlwaysNewConnectionPool({
339
369
  driverType,
340
- getConnection: () => options.sqliteConnectionFactory(options.connectionOptions)
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
- return {
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
- await client.query(
480
- SQL`SAVEPOINT transaction${SQL.plain(transactionCounter.level.toString())}`
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
- await client.query(SQL`BEGIN TRANSACTION`);
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
- await client.query(
494
- SQL`RELEASE transaction${SQL.plain(transactionCounter.level.toString())}`
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-T4A6BQRA.js.map
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"]}