velocious 1.0.363 → 1.0.366

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 (49) hide show
  1. package/README.md +28 -0
  2. package/build/src/configuration-types.d.ts +5 -0
  3. package/build/src/configuration-types.d.ts.map +1 -1
  4. package/build/src/configuration-types.js +2 -1
  5. package/build/src/configuration.d.ts +4 -0
  6. package/build/src/configuration.d.ts.map +1 -1
  7. package/build/src/configuration.js +20 -2
  8. package/build/src/database/drivers/base.d.ts +48 -0
  9. package/build/src/database/drivers/base.d.ts.map +1 -1
  10. package/build/src/database/drivers/base.js +117 -3
  11. package/build/src/database/drivers/mssql/index.d.ts.map +1 -1
  12. package/build/src/database/drivers/mssql/index.js +15 -34
  13. package/build/src/database/drivers/mssql/table.d.ts.map +1 -1
  14. package/build/src/database/drivers/mssql/table.js +79 -73
  15. package/build/src/database/drivers/mysql/index.d.ts.map +1 -1
  16. package/build/src/database/drivers/mysql/index.js +11 -9
  17. package/build/src/database/drivers/mysql/table.d.ts.map +1 -1
  18. package/build/src/database/drivers/mysql/table.js +61 -55
  19. package/build/src/database/drivers/pgsql/index.d.ts.map +1 -1
  20. package/build/src/database/drivers/pgsql/index.js +11 -9
  21. package/build/src/database/drivers/pgsql/table.d.ts.map +1 -1
  22. package/build/src/database/drivers/pgsql/table.js +80 -74
  23. package/build/src/database/drivers/sqlite/base.d.ts.map +1 -1
  24. package/build/src/database/drivers/sqlite/base.js +11 -27
  25. package/build/src/database/drivers/sqlite/table.d.ts.map +1 -1
  26. package/build/src/database/drivers/sqlite/table.js +38 -32
  27. package/build/src/database/pool/async-tracked-multi-connection.d.ts.map +1 -1
  28. package/build/src/database/pool/async-tracked-multi-connection.js +17 -1
  29. package/build/src/database/pool/base.d.ts +11 -0
  30. package/build/src/database/pool/base.d.ts.map +1 -1
  31. package/build/src/database/pool/base.js +18 -1
  32. package/build/src/database/pool/single-multi-use.d.ts.map +1 -1
  33. package/build/src/database/pool/single-multi-use.js +9 -1
  34. package/build/src/environment-handlers/base.d.ts +4 -0
  35. package/build/src/environment-handlers/base.d.ts.map +1 -1
  36. package/build/src/environment-handlers/base.js +7 -1
  37. package/build/src/environment-handlers/node/cli/commands/generate/base-models.js +2 -2
  38. package/build/src/environment-handlers/node.d.ts.map +1 -1
  39. package/build/src/environment-handlers/node.js +8 -1
  40. package/build/src/http-server/client/request-runner.js +2 -2
  41. package/build/src/testing/test-runner.js +2 -2
  42. package/build/src/utils/backtrace-cleaner-node.d.ts +5 -0
  43. package/build/src/utils/backtrace-cleaner-node.d.ts.map +1 -0
  44. package/build/src/utils/backtrace-cleaner-node.js +75 -0
  45. package/build/src/utils/backtrace-cleaner.d.ts +11 -1
  46. package/build/src/utils/backtrace-cleaner.d.ts.map +1 -1
  47. package/build/src/utils/backtrace-cleaner.js +13 -21
  48. package/build/tsconfig.tsbuildinfo +1 -1
  49. package/package.json +1 -1
@@ -14,95 +14,101 @@ export default class VelociousDatabaseDriversPgsqlTable extends BaseTable {
14
14
  this.driver = driver;
15
15
  }
16
16
  async getColumns() {
17
- const result = await this.driver.query(`
18
- SELECT
19
- columns.*,
20
- CASE WHEN key_column_usage.column_name IS NOT NULL THEN 1 ELSE 0 END AS is_primary_key,
21
- col_description((columns.table_schema || '.' || columns.table_name)::regclass, columns.ordinal_position) AS column_comment
17
+ return await this.getDriver()._cachedTableSchemaMetadata(this.getName(), "columns", async () => {
18
+ const result = await this.driver.query(`
19
+ SELECT
20
+ columns.*,
21
+ CASE WHEN key_column_usage.column_name IS NOT NULL THEN 1 ELSE 0 END AS is_primary_key,
22
+ col_description((columns.table_schema || '.' || columns.table_name)::regclass, columns.ordinal_position) AS column_comment
22
23
 
23
- FROM
24
- information_schema.columns AS columns
24
+ FROM
25
+ information_schema.columns AS columns
25
26
 
26
- LEFT JOIN information_schema.table_constraints AS table_constraints ON
27
- table_constraints.table_name = columns.table_name AND
28
- table_constraints.table_schema = columns.table_schema AND
29
- table_constraints.constraint_type = 'PRIMARY KEY'
27
+ LEFT JOIN information_schema.table_constraints AS table_constraints ON
28
+ table_constraints.table_name = columns.table_name AND
29
+ table_constraints.table_schema = columns.table_schema AND
30
+ table_constraints.constraint_type = 'PRIMARY KEY'
30
31
 
31
- LEFT JOIN information_schema.key_column_usage AS key_column_usage ON
32
- key_column_usage.constraint_name = table_constraints.constraint_name AND
33
- key_column_usage.table_schema = table_constraints.table_schema AND
34
- key_column_usage.table_name = columns.table_name AND
35
- key_column_usage.column_name = columns.column_name
32
+ LEFT JOIN information_schema.key_column_usage AS key_column_usage ON
33
+ key_column_usage.constraint_name = table_constraints.constraint_name AND
34
+ key_column_usage.table_schema = table_constraints.table_schema AND
35
+ key_column_usage.table_name = columns.table_name AND
36
+ key_column_usage.column_name = columns.column_name
36
37
 
37
- WHERE
38
- columns.table_catalog = CURRENT_DATABASE() AND
39
- columns.table_schema = 'public' AND
40
- columns.table_name = '${this.getName()}'
41
- `);
42
- const columns = [];
43
- for (const data of result) {
44
- const column = new Column(this, data);
45
- columns.push(column);
46
- }
47
- return columns;
38
+ WHERE
39
+ columns.table_catalog = CURRENT_DATABASE() AND
40
+ columns.table_schema = 'public' AND
41
+ columns.table_name = '${this.getName()}'
42
+ `);
43
+ const columns = [];
44
+ for (const data of result) {
45
+ const column = new Column(this, data);
46
+ columns.push(column);
47
+ }
48
+ return columns;
49
+ });
48
50
  }
49
51
  async getForeignKeys() {
50
- const sql = `
51
- SELECT
52
- tc.constraint_name,
53
- tc.table_name,
54
- kcu.column_name,
55
- ccu.table_name AS foreign_table_name,
56
- ccu.column_name AS foreign_column_name
52
+ return await this.getDriver()._cachedTableSchemaMetadata(this.getName(), "foreignKeys", async () => {
53
+ const sql = `
54
+ SELECT
55
+ tc.constraint_name,
56
+ tc.table_name,
57
+ kcu.column_name,
58
+ ccu.table_name AS foreign_table_name,
59
+ ccu.column_name AS foreign_column_name
57
60
 
58
- FROM
59
- information_schema.table_constraints AS tc
61
+ FROM
62
+ information_schema.table_constraints AS tc
60
63
 
61
- JOIN information_schema.key_column_usage AS kcu ON
62
- tc.constraint_name = kcu.constraint_name
64
+ JOIN information_schema.key_column_usage AS kcu ON
65
+ tc.constraint_name = kcu.constraint_name
63
66
 
64
- JOIN information_schema.constraint_column_usage AS ccu
65
- ON ccu.constraint_name = tc.constraint_name
67
+ JOIN information_schema.constraint_column_usage AS ccu
68
+ ON ccu.constraint_name = tc.constraint_name
66
69
 
67
- WHERE
68
- constraint_type = 'FOREIGN KEY' AND
69
- tc.table_catalog = CURRENT_DATABASE() AND
70
- tc.table_name = ${this.getDriver().quote(this.getName())}
71
- `;
72
- const foreignKeyRows = await this.getDriver().query(sql);
73
- const foreignKeys = [];
74
- for (const foreignKeyRow of foreignKeyRows) {
75
- const foreignKey = new ForeignKey(foreignKeyRow);
76
- foreignKeys.push(foreignKey);
77
- }
78
- return foreignKeys;
70
+ WHERE
71
+ constraint_type = 'FOREIGN KEY' AND
72
+ tc.table_catalog = CURRENT_DATABASE() AND
73
+ tc.table_name = ${this.getDriver().quote(this.getName())}
74
+ `;
75
+ const foreignKeyRows = await this.getDriver().query(sql);
76
+ const foreignKeys = [];
77
+ for (const foreignKeyRow of foreignKeyRows) {
78
+ const foreignKey = new ForeignKey(foreignKeyRow);
79
+ foreignKeys.push(foreignKey);
80
+ }
81
+ return foreignKeys;
82
+ });
79
83
  }
80
84
  async getIndexes() {
81
- const options = this.getOptions();
82
- const indexesRows = await this.getDriver().query(`
83
- SELECT
84
- pg_attribute.attname AS column_name,
85
- pg_index.indexrelid::regclass as index_name,
86
- pg_class.relnamespace::regnamespace as schema_name,
87
- pg_class.relname as table_name,
88
- pg_index.indisprimary as is_primary_key,
89
- pg_index.indisunique as is_unique
90
- FROM pg_index
91
- JOIN pg_class ON pg_class.oid = pg_index.indrelid
92
- JOIN pg_attribute ON pg_attribute.attrelid = pg_class.oid AND pg_attribute.attnum = ANY(pg_index.indkey)
93
- WHERE
94
- pg_class.relname = ${options.quote(this.getName())}
95
- `);
96
- const indexes = [];
97
- for (const indexRow of indexesRows) {
98
- const columnsIndex = new ColumnsIndex(this, indexRow);
99
- indexes.push(columnsIndex);
100
- }
101
- return indexes;
85
+ return await this.getDriver()._cachedTableSchemaMetadata(this.getName(), "indexes", async () => {
86
+ const options = this.getOptions();
87
+ const indexesRows = await this.getDriver().query(`
88
+ SELECT
89
+ pg_attribute.attname AS column_name,
90
+ pg_index.indexrelid::regclass as index_name,
91
+ pg_class.relnamespace::regnamespace as schema_name,
92
+ pg_class.relname as table_name,
93
+ pg_index.indisprimary as is_primary_key,
94
+ pg_index.indisunique as is_unique
95
+ FROM pg_index
96
+ JOIN pg_class ON pg_class.oid = pg_index.indrelid
97
+ JOIN pg_attribute ON pg_attribute.attrelid = pg_class.oid AND pg_attribute.attnum = ANY(pg_index.indkey)
98
+ WHERE
99
+ pg_class.relname = ${options.quote(this.getName())}
100
+ `);
101
+ const indexes = [];
102
+ for (const indexRow of indexesRows) {
103
+ const columnsIndex = new ColumnsIndex(this, indexRow);
104
+ indexes.push(columnsIndex);
105
+ }
106
+ return indexes;
107
+ });
102
108
  }
103
109
  /** @returns {string} - The table name. */
104
110
  getName() {
105
111
  return this.data.table_name;
106
112
  }
107
113
  }
108
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvZGF0YWJhc2UvZHJpdmVycy9wZ3NxbC90YWJsZS5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxZQUFZO0FBRVosT0FBTyxTQUFTLE1BQU0sa0JBQWtCLENBQUE7QUFDeEMsT0FBTyxNQUFNLE1BQU0sYUFBYSxDQUFBO0FBQ2hDLE9BQU8sWUFBWSxNQUFNLG9CQUFvQixDQUFBO0FBQzdDLE9BQU8sVUFBVSxNQUFNLGtCQUFrQixDQUFBO0FBRXpDLE1BQU0sQ0FBQyxPQUFPLE9BQU8sa0NBQW1DLFNBQVEsU0FBUztJQUN2RTs7O09BR0c7SUFDSCxZQUFZLE1BQU0sRUFBRSxJQUFJO1FBQ3RCLEtBQUssRUFBRSxDQUFBO1FBQ1AsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUE7UUFDaEIsSUFBSSxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUE7SUFDdEIsQ0FBQztJQUVELEtBQUssQ0FBQyxVQUFVO1FBQ2QsTUFBTSxNQUFNLEdBQUcsTUFBTSxJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Z0NBdUJYLElBQUksQ0FBQyxPQUFPLEVBQUU7S0FDekMsQ0FBQyxDQUFBO1FBQ0YsTUFBTSxPQUFPLEdBQUcsRUFBRSxDQUFBO1FBRWxCLEtBQUssTUFBTSxJQUFJLElBQUksTUFBTSxFQUFFLENBQUM7WUFDMUIsTUFBTSxNQUFNLEdBQUcsSUFBSSxNQUFNLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxDQUFBO1lBRXJDLE9BQU8sQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUE7UUFDdEIsQ0FBQztRQUVELE9BQU8sT0FBTyxDQUFBO0lBQ2hCLENBQUM7SUFFRCxLQUFLLENBQUMsY0FBYztRQUNsQixNQUFNLEdBQUcsR0FBRzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7MEJBb0JVLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO0tBQzNELENBQUE7UUFFRCxNQUFNLGNBQWMsR0FBRyxNQUFNLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUE7UUFDeEQsTUFBTSxXQUFXLEdBQUcsRUFBRSxDQUFBO1FBRXRCLEtBQUssTUFBTSxhQUFhLElBQUksY0FBYyxFQUFFLENBQUM7WUFDM0MsTUFBTSxVQUFVLEdBQUcsSUFBSSxVQUFVLENBQUMsYUFBYSxDQUFDLENBQUE7WUFFaEQsV0FBVyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQTtRQUM5QixDQUFDO1FBRUQsT0FBTyxXQUFXLENBQUE7SUFDcEIsQ0FBQztJQUVELEtBQUssQ0FBQyxVQUFVO1FBQ2QsTUFBTSxPQUFPLEdBQUcsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFBO1FBRWpDLE1BQU0sV0FBVyxHQUFHLE1BQU0sSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDLEtBQUssQ0FBQzs7Ozs7Ozs7Ozs7OzZCQVl4QixPQUFPLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztLQUNyRCxDQUFDLENBQUE7UUFFRixNQUFNLE9BQU8sR0FBRyxFQUFFLENBQUE7UUFFbEIsS0FBSyxNQUFNLFFBQVEsSUFBSSxXQUFXLEVBQUUsQ0FBQztZQUNuQyxNQUFNLFlBQVksR0FBRyxJQUFJLFlBQVksQ0FBQyxJQUFJLEVBQUUsUUFBUSxDQUFDLENBQUE7WUFFckQsT0FBTyxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQTtRQUM1QixDQUFDO1FBRUQsT0FBTyxPQUFPLENBQUE7SUFDaEIsQ0FBQztJQUVELDBDQUEwQztJQUMxQyxPQUFPO1FBQ0wsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQTtJQUM3QixDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBAdHMtY2hlY2tcblxuaW1wb3J0IEJhc2VUYWJsZSBmcm9tIFwiLi4vYmFzZS10YWJsZS5qc1wiXG5pbXBvcnQgQ29sdW1uIGZyb20gXCIuL2NvbHVtbi5qc1wiXG5pbXBvcnQgQ29sdW1uc0luZGV4IGZyb20gXCIuL2NvbHVtbnMtaW5kZXguanNcIlxuaW1wb3J0IEZvcmVpZ25LZXkgZnJvbSBcIi4vZm9yZWlnbi1rZXkuanNcIlxuXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBWZWxvY2lvdXNEYXRhYmFzZURyaXZlcnNQZ3NxbFRhYmxlIGV4dGVuZHMgQmFzZVRhYmxlIHtcbiAgLyoqXG4gICAqIEBwYXJhbSB7aW1wb3J0KFwiLi4vYmFzZS5qc1wiKS5kZWZhdWx0fSBkcml2ZXIgLSBEYXRhYmFzZSBkcml2ZXIgaW5zdGFuY2UuXG4gICAqIEBwYXJhbSB7UmVjb3JkPHN0cmluZywgc3RyaW5nPn0gZGF0YSAtIERhdGEgcGF5bG9hZC5cbiAgICovXG4gIGNvbnN0cnVjdG9yKGRyaXZlciwgZGF0YSkge1xuICAgIHN1cGVyKClcbiAgICB0aGlzLmRhdGEgPSBkYXRhXG4gICAgdGhpcy5kcml2ZXIgPSBkcml2ZXJcbiAgfVxuXG4gIGFzeW5jIGdldENvbHVtbnMoKSB7XG4gICAgY29uc3QgcmVzdWx0ID0gYXdhaXQgdGhpcy5kcml2ZXIucXVlcnkoYFxuICAgICAgU0VMRUNUXG4gICAgICAgIGNvbHVtbnMuKixcbiAgICAgICAgQ0FTRSBXSEVOIGtleV9jb2x1bW5fdXNhZ2UuY29sdW1uX25hbWUgSVMgTk9UIE5VTEwgVEhFTiAxIEVMU0UgMCBFTkQgQVMgaXNfcHJpbWFyeV9rZXksXG4gICAgICAgIGNvbF9kZXNjcmlwdGlvbigoY29sdW1ucy50YWJsZV9zY2hlbWEgfHwgJy4nIHx8IGNvbHVtbnMudGFibGVfbmFtZSk6OnJlZ2NsYXNzLCBjb2x1bW5zLm9yZGluYWxfcG9zaXRpb24pIEFTIGNvbHVtbl9jb21tZW50XG5cbiAgICAgIEZST01cbiAgICAgICAgaW5mb3JtYXRpb25fc2NoZW1hLmNvbHVtbnMgQVMgY29sdW1uc1xuXG4gICAgICBMRUZUIEpPSU4gaW5mb3JtYXRpb25fc2NoZW1hLnRhYmxlX2NvbnN0cmFpbnRzIEFTIHRhYmxlX2NvbnN0cmFpbnRzIE9OXG4gICAgICAgIHRhYmxlX2NvbnN0cmFpbnRzLnRhYmxlX25hbWUgPSBjb2x1bW5zLnRhYmxlX25hbWUgQU5EXG4gICAgICAgIHRhYmxlX2NvbnN0cmFpbnRzLnRhYmxlX3NjaGVtYSA9IGNvbHVtbnMudGFibGVfc2NoZW1hIEFORFxuICAgICAgICB0YWJsZV9jb25zdHJhaW50cy5jb25zdHJhaW50X3R5cGUgPSAnUFJJTUFSWSBLRVknXG5cbiAgICAgIExFRlQgSk9JTiBpbmZvcm1hdGlvbl9zY2hlbWEua2V5X2NvbHVtbl91c2FnZSBBUyBrZXlfY29sdW1uX3VzYWdlIE9OXG4gICAgICAgIGtleV9jb2x1bW5fdXNhZ2UuY29uc3RyYWludF9uYW1lID0gdGFibGVfY29uc3RyYWludHMuY29uc3RyYWludF9uYW1lIEFORFxuICAgICAgICBrZXlfY29sdW1uX3VzYWdlLnRhYmxlX3NjaGVtYSA9IHRhYmxlX2NvbnN0cmFpbnRzLnRhYmxlX3NjaGVtYSBBTkRcbiAgICAgICAga2V5X2NvbHVtbl91c2FnZS50YWJsZV9uYW1lID0gY29sdW1ucy50YWJsZV9uYW1lIEFORFxuICAgICAgICBrZXlfY29sdW1uX3VzYWdlLmNvbHVtbl9uYW1lID0gY29sdW1ucy5jb2x1bW5fbmFtZVxuXG4gICAgICBXSEVSRVxuICAgICAgICBjb2x1bW5zLnRhYmxlX2NhdGFsb2cgPSBDVVJSRU5UX0RBVEFCQVNFKCkgQU5EXG4gICAgICAgIGNvbHVtbnMudGFibGVfc2NoZW1hID0gJ3B1YmxpYycgQU5EXG4gICAgICAgIGNvbHVtbnMudGFibGVfbmFtZSA9ICcke3RoaXMuZ2V0TmFtZSgpfSdcbiAgICBgKVxuICAgIGNvbnN0IGNvbHVtbnMgPSBbXVxuXG4gICAgZm9yIChjb25zdCBkYXRhIG9mIHJlc3VsdCkge1xuICAgICAgY29uc3QgY29sdW1uID0gbmV3IENvbHVtbih0aGlzLCBkYXRhKVxuXG4gICAgICBjb2x1bW5zLnB1c2goY29sdW1uKVxuICAgIH1cblxuICAgIHJldHVybiBjb2x1bW5zXG4gIH1cblxuICBhc3luYyBnZXRGb3JlaWduS2V5cygpIHtcbiAgICBjb25zdCBzcWwgPSBgXG4gICAgICBTRUxFQ1RcbiAgICAgICAgdGMuY29uc3RyYWludF9uYW1lLFxuICAgICAgICB0Yy50YWJsZV9uYW1lLFxuICAgICAgICBrY3UuY29sdW1uX25hbWUsXG4gICAgICAgIGNjdS50YWJsZV9uYW1lIEFTIGZvcmVpZ25fdGFibGVfbmFtZSxcbiAgICAgICAgY2N1LmNvbHVtbl9uYW1lIEFTIGZvcmVpZ25fY29sdW1uX25hbWVcblxuICAgICAgRlJPTVxuICAgICAgICBpbmZvcm1hdGlvbl9zY2hlbWEudGFibGVfY29uc3RyYWludHMgQVMgdGNcblxuICAgICAgSk9JTiBpbmZvcm1hdGlvbl9zY2hlbWEua2V5X2NvbHVtbl91c2FnZSBBUyBrY3UgT05cbiAgICAgICAgdGMuY29uc3RyYWludF9uYW1lID0ga2N1LmNvbnN0cmFpbnRfbmFtZVxuXG4gICAgICBKT0lOIGluZm9ybWF0aW9uX3NjaGVtYS5jb25zdHJhaW50X2NvbHVtbl91c2FnZSBBUyBjY3VcbiAgICAgICAgT04gY2N1LmNvbnN0cmFpbnRfbmFtZSA9IHRjLmNvbnN0cmFpbnRfbmFtZVxuXG4gICAgICBXSEVSRVxuICAgICAgICBjb25zdHJhaW50X3R5cGUgPSAnRk9SRUlHTiBLRVknIEFORFxuICAgICAgICB0Yy50YWJsZV9jYXRhbG9nID0gQ1VSUkVOVF9EQVRBQkFTRSgpIEFORFxuICAgICAgICB0Yy50YWJsZV9uYW1lID0gJHt0aGlzLmdldERyaXZlcigpLnF1b3RlKHRoaXMuZ2V0TmFtZSgpKX1cbiAgICBgXG5cbiAgICBjb25zdCBmb3JlaWduS2V5Um93cyA9IGF3YWl0IHRoaXMuZ2V0RHJpdmVyKCkucXVlcnkoc3FsKVxuICAgIGNvbnN0IGZvcmVpZ25LZXlzID0gW11cblxuICAgIGZvciAoY29uc3QgZm9yZWlnbktleVJvdyBvZiBmb3JlaWduS2V5Um93cykge1xuICAgICAgY29uc3QgZm9yZWlnbktleSA9IG5ldyBGb3JlaWduS2V5KGZvcmVpZ25LZXlSb3cpXG5cbiAgICAgIGZvcmVpZ25LZXlzLnB1c2goZm9yZWlnbktleSlcbiAgICB9XG5cbiAgICByZXR1cm4gZm9yZWlnbktleXNcbiAgfVxuXG4gIGFzeW5jIGdldEluZGV4ZXMoKSB7XG4gICAgY29uc3Qgb3B0aW9ucyA9IHRoaXMuZ2V0T3B0aW9ucygpXG5cbiAgICBjb25zdCBpbmRleGVzUm93cyA9IGF3YWl0IHRoaXMuZ2V0RHJpdmVyKCkucXVlcnkoYFxuICAgICAgU0VMRUNUXG4gICAgICAgIHBnX2F0dHJpYnV0ZS5hdHRuYW1lIEFTIGNvbHVtbl9uYW1lLFxuICAgICAgICBwZ19pbmRleC5pbmRleHJlbGlkOjpyZWdjbGFzcyBhcyBpbmRleF9uYW1lLFxuICAgICAgICBwZ19jbGFzcy5yZWxuYW1lc3BhY2U6OnJlZ25hbWVzcGFjZSBhcyBzY2hlbWFfbmFtZSxcbiAgICAgICAgcGdfY2xhc3MucmVsbmFtZSBhcyB0YWJsZV9uYW1lLFxuICAgICAgICBwZ19pbmRleC5pbmRpc3ByaW1hcnkgYXMgaXNfcHJpbWFyeV9rZXksXG4gICAgICAgIHBnX2luZGV4LmluZGlzdW5pcXVlIGFzIGlzX3VuaXF1ZVxuICAgICAgRlJPTSBwZ19pbmRleFxuICAgICAgSk9JTiBwZ19jbGFzcyBPTiBwZ19jbGFzcy5vaWQgPSBwZ19pbmRleC5pbmRyZWxpZFxuICAgICAgSk9JTiBwZ19hdHRyaWJ1dGUgT04gcGdfYXR0cmlidXRlLmF0dHJlbGlkID0gcGdfY2xhc3Mub2lkIEFORCBwZ19hdHRyaWJ1dGUuYXR0bnVtID0gQU5ZKHBnX2luZGV4LmluZGtleSlcbiAgICAgIFdIRVJFXG4gICAgICAgIHBnX2NsYXNzLnJlbG5hbWUgPSAke29wdGlvbnMucXVvdGUodGhpcy5nZXROYW1lKCkpfVxuICAgIGApXG5cbiAgICBjb25zdCBpbmRleGVzID0gW11cblxuICAgIGZvciAoY29uc3QgaW5kZXhSb3cgb2YgaW5kZXhlc1Jvd3MpIHtcbiAgICAgIGNvbnN0IGNvbHVtbnNJbmRleCA9IG5ldyBDb2x1bW5zSW5kZXgodGhpcywgaW5kZXhSb3cpXG5cbiAgICAgIGluZGV4ZXMucHVzaChjb2x1bW5zSW5kZXgpXG4gICAgfVxuXG4gICAgcmV0dXJuIGluZGV4ZXNcbiAgfVxuXG4gIC8qKiBAcmV0dXJucyB7c3RyaW5nfSAtIFRoZSB0YWJsZSBuYW1lLiAqL1xuICBnZXROYW1lKCkge1xuICAgIHJldHVybiB0aGlzLmRhdGEudGFibGVfbmFtZVxuICB9XG59XG4iXX0=
114
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.js","sourceRoot":"","sources":["../../../../../src/database/drivers/pgsql/table.js"],"names":[],"mappings":"AAAA,YAAY;AAEZ,OAAO,SAAS,MAAM,kBAAkB,CAAA;AACxC,OAAO,MAAM,MAAM,aAAa,CAAA;AAChC,OAAO,YAAY,MAAM,oBAAoB,CAAA;AAC7C,OAAO,UAAU,MAAM,kBAAkB,CAAA;AAEzC,MAAM,CAAC,OAAO,OAAO,kCAAmC,SAAQ,SAAS;IACvE;;;OAGG;IACH,YAAY,MAAM,EAAE,IAAI;QACtB,KAAK,EAAE,CAAA;QACP,IAAI,CAAC,IAAI,GAAG,IAAI,CAAA;QAChB,IAAI,CAAC,MAAM,GAAG,MAAM,CAAA;IACtB,CAAC;IAED,KAAK,CAAC,UAAU;QACd,OAAO,MAAM,IAAI,CAAC,SAAS,EAAE,CAAC,0BAA0B,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,SAAS,EAAE,KAAK,IAAI,EAAE;YAC7F,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC;;;;;;;;;;;;;;;;;;;;;;;kCAuBX,IAAI,CAAC,OAAO,EAAE;OACzC,CAAC,CAAA;YACF,MAAM,OAAO,GAAG,EAAE,CAAA;YAElB,KAAK,MAAM,IAAI,IAAI,MAAM,EAAE,CAAC;gBAC1B,MAAM,MAAM,GAAG,IAAI,MAAM,CAAC,IAAI,EAAE,IAAI,CAAC,CAAA;gBAErC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;YACtB,CAAC;YAED,OAAO,OAAO,CAAA;QAChB,CAAC,CAAC,CAAA;IACJ,CAAC;IAED,KAAK,CAAC,cAAc;QAClB,OAAO,MAAM,IAAI,CAAC,SAAS,EAAE,CAAC,0BAA0B,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,aAAa,EAAE,KAAK,IAAI,EAAE;YACjG,MAAM,GAAG,GAAG;;;;;;;;;;;;;;;;;;;;4BAoBU,IAAI,CAAC,SAAS,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;OAC3D,CAAA;YAED,MAAM,cAAc,GAAG,MAAM,IAAI,CAAC,SAAS,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;YACxD,MAAM,WAAW,GAAG,EAAE,CAAA;YAEtB,KAAK,MAAM,aAAa,IAAI,cAAc,EAAE,CAAC;gBAC3C,MAAM,UAAU,GAAG,IAAI,UAAU,CAAC,aAAa,CAAC,CAAA;gBAEhD,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,CAAA;YAC9B,CAAC;YAED,OAAO,WAAW,CAAA;QACpB,CAAC,CAAC,CAAA;IACJ,CAAC;IAED,KAAK,CAAC,UAAU;QACd,OAAO,MAAM,IAAI,CAAC,SAAS,EAAE,CAAC,0BAA0B,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,SAAS,EAAE,KAAK,IAAI,EAAE;YAC7F,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,CAAA;YAEjC,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,SAAS,EAAE,CAAC,KAAK,CAAC;;;;;;;;;;;;+BAYxB,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;OACrD,CAAC,CAAA;YAEF,MAAM,OAAO,GAAG,EAAE,CAAA;YAElB,KAAK,MAAM,QAAQ,IAAI,WAAW,EAAE,CAAC;gBACnC,MAAM,YAAY,GAAG,IAAI,YAAY,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAA;gBAErD,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,CAAA;YAC5B,CAAC;YAED,OAAO,OAAO,CAAA;QAChB,CAAC,CAAC,CAAA;IACJ,CAAC;IAED,0CAA0C;IAC1C,OAAO;QACL,OAAO,IAAI,CAAC,IAAI,CAAC,UAAU,CAAA;IAC7B,CAAC;CACF","sourcesContent":["// @ts-check\n\nimport BaseTable from \"../base-table.js\"\nimport Column from \"./column.js\"\nimport ColumnsIndex from \"./columns-index.js\"\nimport ForeignKey from \"./foreign-key.js\"\n\nexport default class VelociousDatabaseDriversPgsqlTable extends BaseTable {\n  /**\n   * @param {import(\"../base.js\").default} driver - Database driver instance.\n   * @param {Record<string, string>} data - Data payload.\n   */\n  constructor(driver, data) {\n    super()\n    this.data = data\n    this.driver = driver\n  }\n\n  async getColumns() {\n    return await this.getDriver()._cachedTableSchemaMetadata(this.getName(), \"columns\", async () => {\n      const result = await this.driver.query(`\n        SELECT\n          columns.*,\n          CASE WHEN key_column_usage.column_name IS NOT NULL THEN 1 ELSE 0 END AS is_primary_key,\n          col_description((columns.table_schema || '.' || columns.table_name)::regclass, columns.ordinal_position) AS column_comment\n\n        FROM\n          information_schema.columns AS columns\n\n        LEFT JOIN information_schema.table_constraints AS table_constraints ON\n          table_constraints.table_name = columns.table_name AND\n          table_constraints.table_schema = columns.table_schema AND\n          table_constraints.constraint_type = 'PRIMARY KEY'\n\n        LEFT JOIN information_schema.key_column_usage AS key_column_usage ON\n          key_column_usage.constraint_name = table_constraints.constraint_name AND\n          key_column_usage.table_schema = table_constraints.table_schema AND\n          key_column_usage.table_name = columns.table_name AND\n          key_column_usage.column_name = columns.column_name\n\n        WHERE\n          columns.table_catalog = CURRENT_DATABASE() AND\n          columns.table_schema = 'public' AND\n          columns.table_name = '${this.getName()}'\n      `)\n      const columns = []\n\n      for (const data of result) {\n        const column = new Column(this, data)\n\n        columns.push(column)\n      }\n\n      return columns\n    })\n  }\n\n  async getForeignKeys() {\n    return await this.getDriver()._cachedTableSchemaMetadata(this.getName(), \"foreignKeys\", async () => {\n      const sql = `\n        SELECT\n          tc.constraint_name,\n          tc.table_name,\n          kcu.column_name,\n          ccu.table_name AS foreign_table_name,\n          ccu.column_name AS foreign_column_name\n\n        FROM\n          information_schema.table_constraints AS tc\n\n        JOIN information_schema.key_column_usage AS kcu ON\n          tc.constraint_name = kcu.constraint_name\n\n        JOIN information_schema.constraint_column_usage AS ccu\n          ON ccu.constraint_name = tc.constraint_name\n\n        WHERE\n          constraint_type = 'FOREIGN KEY' AND\n          tc.table_catalog = CURRENT_DATABASE() AND\n          tc.table_name = ${this.getDriver().quote(this.getName())}\n      `\n\n      const foreignKeyRows = await this.getDriver().query(sql)\n      const foreignKeys = []\n\n      for (const foreignKeyRow of foreignKeyRows) {\n        const foreignKey = new ForeignKey(foreignKeyRow)\n\n        foreignKeys.push(foreignKey)\n      }\n\n      return foreignKeys\n    })\n  }\n\n  async getIndexes() {\n    return await this.getDriver()._cachedTableSchemaMetadata(this.getName(), \"indexes\", async () => {\n      const options = this.getOptions()\n\n      const indexesRows = await this.getDriver().query(`\n        SELECT\n          pg_attribute.attname AS column_name,\n          pg_index.indexrelid::regclass as index_name,\n          pg_class.relnamespace::regnamespace as schema_name,\n          pg_class.relname as table_name,\n          pg_index.indisprimary as is_primary_key,\n          pg_index.indisunique as is_unique\n        FROM pg_index\n        JOIN pg_class ON pg_class.oid = pg_index.indrelid\n        JOIN pg_attribute ON pg_attribute.attrelid = pg_class.oid AND pg_attribute.attnum = ANY(pg_index.indkey)\n        WHERE\n          pg_class.relname = ${options.quote(this.getName())}\n      `)\n\n      const indexes = []\n\n      for (const indexRow of indexesRows) {\n        const columnsIndex = new ColumnsIndex(this, indexRow)\n\n        indexes.push(columnsIndex)\n      }\n\n      return indexes\n    })\n  }\n\n  /** @returns {string} - The table name. */\n  getName() {\n    return this.data.table_name\n  }\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"base.d.ts","sourceRoot":"","sources":["../../../../../src/database/drivers/sqlite/base.js"],"names":[],"mappings":"AAmBA;IACE,iCAAiC;IACjC,cADW,MAAM,GAAG,SAAS,CACL;IACxB,iCAAiC;IACjC,cADW,MAAM,GAAG,SAAS,CACL;IACxB,iCAAiC;IACjC,cADW,MAAM,GAAG,SAAS,CACL;IAoCxB,wBAEC;IA6FD;;OAEG;IACH,gCAFa,OAAO,CAenB;IAiBD;;;;;OAKG;IACH,0CALW,MAAM,WACN,KAAK,CAAC,MAAM,CAAC,QACb,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,GACnB,OAAO,CAAC,IAAI,CAAC,CAOzB;IAED;;;;;OAKG;IACH,yCALW,MAAM,WACN,KAAK,CAAC,MAAM,CAAC,QACb,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,GACnB,OAAO,CAAC,IAAI,CAAC,CA4BzB;IAED,6BAIC;IAED,mBAIC;IAHqB,8BAAiC;IAKvD;;OAEG;IACH,kBAFa,MAAM,CAEkB;IAQrC,iCAcC;IAPC,4BAA+C;CAkMlD;;4BAWS;QAAC,YAAY,EAAE,GAAG,CAAC,MAAM,EAAE,kCAAkC,CAAC,CAAC;QAAC,aAAa,EAAE,GAAG,CAAC,MAAM,EAAE,KAAK,CAAC,MAAM,IAAI,CAAC,CAAC,CAAA;KAAC;;;iBAldvG,YAAY;oBAOT,cAAc"}
1
+ {"version":3,"file":"base.d.ts","sourceRoot":"","sources":["../../../../../src/database/drivers/sqlite/base.js"],"names":[],"mappings":"AAmBA;IACE,iCAAiC;IACjC,cADW,MAAM,GAAG,SAAS,CACL;IACxB,iCAAiC;IACjC,cADW,MAAM,GAAG,SAAS,CACL;IACxB,iCAAiC;IACjC,cADW,MAAM,GAAG,SAAS,CACL;IAoCxB,wBAEC;IAyED;;OAEG;IACH,gCAFa,OAAO,CAenB;IAiBD;;;;;OAKG;IACH,0CALW,MAAM,WACN,KAAK,CAAC,MAAM,CAAC,QACb,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,GACnB,OAAO,CAAC,IAAI,CAAC,CAOzB;IAED;;;;;OAKG;IACH,yCALW,MAAM,WACN,KAAK,CAAC,MAAM,CAAC,QACb,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,GACnB,OAAO,CAAC,IAAI,CAAC,CA4BzB;IAED,6BAIC;IAED,mBAIC;IAHqB,8BAAiC;IAKvD;;OAEG;IACH,kBAFa,MAAM,CAEkB;IAQrC,iCAcC;IAPC,4BAA+C;CAkMlD;;4BAWS;QAAC,YAAY,EAAE,GAAG,CAAC,MAAM,EAAE,kCAAkC,CAAC,CAAC;QAAC,aAAa,EAAE,GAAG,CAAC,MAAM,EAAE,KAAK,CAAC,MAAM,IAAI,CAAC,CAAC,CAAA;KAAC;;;iBA9bvG,YAAY;oBAOT,cAAc"}
@@ -83,33 +83,17 @@ export default class VelociousDatabaseDriversSqliteBase extends Base {
83
83
  * @returns {string} - SQL string.
84
84
  */
85
85
  insertSql(args) { return new Insert(Object.assign({ driver: this }, args)).toSql(); }
86
- /**
87
- * @param {string} name - Name.
88
- * @param {object} [args] - Options object.
89
- * @param {boolean} args.throwError - Whether throw error.
90
- * @returns {Promise<import("../base-table.js").default | undefined>} - Resolves with the table by name.
91
- */
92
- async getTableByName(name, args) {
93
- const result = await this.query(`SELECT name FROM sqlite_master WHERE type = 'table' AND name = ${this.quote(name)} LIMIT 1`);
94
- const row = result[0];
95
- if (row) {
96
- return new Table({ driver: this, row: /** @type {Record<string, string | number | null>} */ (row) });
97
- }
98
- if (args?.throwError !== false) {
99
- const tables = await this.getTables();
100
- const tableNames = tables.map((table) => table.getName());
101
- throw new Error(this._missingTableErrorMessage(name, tableNames));
102
- }
103
- }
104
86
  /** @returns {Promise<Array<import("../base-table.js").default>>} - Resolves with the tables. */
105
87
  async getTables() {
106
- const result = await this.query("SELECT name FROM sqlite_master WHERE type = 'table' ORDER BY name");
107
- const tables = [];
108
- for (const row of result) {
109
- const table = new Table({ driver: this, row: /** @type {Record<string, string | number | null>} */ (row) });
110
- tables.push(table);
111
- }
112
- return tables;
88
+ return await this._cachedSchemaMetadata("tables", async () => {
89
+ const result = await this.query("SELECT name FROM sqlite_master WHERE type = 'table' ORDER BY name");
90
+ const tables = [];
91
+ for (const row of result) {
92
+ const table = new Table({ driver: this, row: /** @type {Record<string, string | number | null>} */ (row) });
93
+ tables.push(table);
94
+ }
95
+ return tables;
96
+ });
113
97
  }
114
98
  /**
115
99
  * @param {string} tableName - Table name.
@@ -278,7 +262,7 @@ export default class VelociousDatabaseDriversSqliteBase extends Base {
278
262
  * @returns {Promise<string | null>} - Resolves with SQL string.
279
263
  */
280
264
  async structureSql() {
281
- return await new StructureSql({ driver: this }).toSql();
265
+ return await this._cachedSchemaMetadata("structureSql", async () => await new StructureSql({ driver: this }).toSql());
282
266
  }
283
267
  /**
284
268
  * Blocks until an in-process advisory lock with the given name is
@@ -397,4 +381,4 @@ VelociousDatabaseDriversSqliteBase._advisoryLockState = {
397
381
  ownersByName: new Map(),
398
382
  waitersByName: new Map()
399
383
  };
400
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base.js","sourceRoot":"","sources":["../../../../../src/database/drivers/sqlite/base.js"],"names":[],"mappings":"AAAA,YAAY;AAEZ,OAAO,EAAC,IAAI,EAAC,MAAM,WAAW,CAAA;AAE9B,OAAO,UAAU,MAAM,sBAAsB,CAAA;AAC7C,OAAO,IAAI,MAAM,YAAY,CAAA;AAC7B,OAAO,WAAW,MAAM,uBAAuB,CAAA;AAC/C,OAAO,WAAW,MAAM,uBAAuB,CAAA;AAC/C,OAAO,MAAM,MAAM,iBAAiB,CAAA;AACpC,OAAO,SAAS,MAAM,qBAAqB,CAAA;AAC3C,OAAO,YAAY,MAAM,mBAAmB,CAAA;AAC5C,OAAO,MAAM,MAAM,iBAAiB,CAAA;AACpC,OAAO,OAAO,MAAM,cAAc,CAAA;AAClC,OAAO,WAAW,MAAM,mBAAmB,CAAA;AAC3C,OAAO,KAAK,MAAM,YAAY,CAAA;AAC9B,OAAO,YAAY,MAAM,oBAAoB,CAAA;AAC7C,OAAO,MAAM,MAAM,iBAAiB,CAAA;AACpC,OAAO,MAAM,MAAM,iBAAiB,CAAA;AAEpC,MAAM,CAAC,OAAO,OAAO,kCAAmC,SAAQ,IAAI;IAClE,iCAAiC;IACjC,YAAY,GAAG,SAAS,CAAA;IACxB,iCAAiC;IACjC,YAAY,GAAG,SAAS,CAAA;IACxB,iCAAiC;IACjC,YAAY,GAAG,SAAS,CAAA;IAExB;;;OAGG;IACH,KAAK,CAAC,cAAc,CAAC,SAAS;QAC5B,MAAM,SAAS,GAAG,EAAC,MAAM,EAAE,IAAI,EAAE,SAAS,EAAC,CAAA;QAC3C,MAAM,UAAU,GAAG,IAAI,UAAU,CAAC,SAAS,CAAC,CAAA;QAE5C,OAAO,MAAM,UAAU,CAAC,MAAM,EAAE,CAAA;IAClC,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,eAAe,CAAC,SAAS;QAC7B,MAAM,UAAU,GAAG,MAAM,CAAC,MAAM,CAAC,EAAC,MAAM,EAAE,IAAI,EAAC,EAAE,SAAS,CAAC,CAAA;QAC3D,MAAM,WAAW,GAAG,IAAI,WAAW,CAAC,UAAU,CAAC,CAAA;QAE/C,OAAO,MAAM,WAAW,CAAC,MAAM,EAAE,CAAA;IACnC,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,cAAc,CAAC,SAAS;QAC5B,MAAM,UAAU,GAAG,EAAC,SAAS,EAAE,MAAM,EAAE,IAAI,EAAE,kBAAkB,EAAE,KAAK,EAAC,CAAA;QACvE,MAAM,WAAW,GAAG,IAAI,WAAW,CAAC,UAAU,CAAC,CAAA;QAE/C,OAAO,MAAM,WAAW,CAAC,KAAK,EAAE,CAAA;IAClC,CAAC;IAED,eAAe;QACb,OAAO,IAAI,CAAA;IACb,CAAC;IAED,KAAK,CAAC,kBAAkB;QACtB,MAAM,IAAI,CAAC,KAAK,CAAC,yBAAyB,CAAC,CAAA;IAC7C,CAAC;IAED,KAAK,CAAC,iBAAiB;QACrB,MAAM,IAAI,CAAC,KAAK,CAAC,yBAAyB,CAAC,CAAA;IAC7C,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,aAAa,CAAC,SAAS,EAAE,IAAI,GAAG,EAAE;QACtC,MAAM,MAAM,GAAG,2CAA2C,CAAC,CAAC,IAAI,CAAC,CAAA;QACjE,MAAM,QAAQ,GAAG,MAAM,CAAC,MAAM,CAAC,EAAC,SAAS,EAAE,MAAM,EAAC,EAAE,IAAI,CAAC,CAAA;QACzD,MAAM,SAAS,GAAG,IAAI,SAAS,CAAC,QAAQ,CAAC,CAAA;QAEzC,OAAO,MAAM,SAAS,CAAC,MAAM,EAAE,CAAA;IACjC,CAAC;IAED;;;OAGG;IACH,SAAS,CAAC,IAAI,IAAI,OAAO,IAAI,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,EAAC,MAAM,EAAE,IAAI,EAAC,EAAE,IAAI,CAAC,CAAC,CAAC,KAAK,EAAE,CAAA,CAAC,CAAC;IAElF;;OAEG;IACH,OAAO,KAAK,OAAO,QAAQ,CAAA,CAAC,CAAC;IAE7B;;;OAGG;IACH,SAAS,CAAC,IAAI,IAAI,OAAO,IAAI,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,EAAC,MAAM,EAAE,IAAI,EAAC,EAAE,IAAI,CAAC,CAAC,CAAC,KAAK,EAAE,CAAA,CAAC,CAAC;IAElF;;;;;OAKG;IACH,KAAK,CAAC,cAAc,CAAC,IAAI,EAAE,IAAI;QAC7B,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,kEAAkE,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,CAAA;QAC7H,MAAM,GAAG,GAAG,MAAM,CAAC,CAAC,CAAC,CAAA;QAErB,IAAI,GAAG,EAAE,CAAC;YACR,OAAO,IAAI,KAAK,CAAC,EAAC,MAAM,EAAE,IAAI,EAAE,GAAG,EAAE,qDAAqD,CAAC,CAAC,GAAG,CAAC,EAAC,CAAC,CAAA;QACpG,CAAC;QAED,IAAI,IAAI,EAAE,UAAU,KAAK,KAAK,EAAE,CAAC;YAC/B,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,SAAS,EAAE,CAAA;YACrC,MAAM,UAAU,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC,CAAA;YAEzD,MAAM,IAAI,KAAK,CAAC,IAAI,CAAC,yBAAyB,CAAC,IAAI,EAAE,UAAU,CAAC,CAAC,CAAA;QACnE,CAAC;IACH,CAAC;IAED,iGAAiG;IACjG,KAAK,CAAC,SAAS;QACb,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,mEAAmE,CAAC,CAAA;QACpG,MAAM,MAAM,GAAG,EAAE,CAAA;QAEjB,KAAK,MAAM,GAAG,IAAI,MAAM,EAAE,CAAC;YACzB,MAAM,KAAK,GAAG,IAAI,KAAK,CAAC,EAAC,MAAM,EAAE,IAAI,EAAE,GAAG,EAAE,qDAAqD,CAAC,CAAC,GAAG,CAAC,EAAC,CAAC,CAAA;YAEzG,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;QACpB,CAAC;QAED,OAAO,MAAM,CAAA;IACf,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,cAAc,CAAC,SAAS,EAAE,OAAO,EAAE,IAAI;QAC3C,IAAI,CAAC,kBAAkB,EAAE,CAAA;QACzB,MAAM,IAAI,CAAC,eAAe,EAAE,CAAA;QAE5B,IAAI,IAAI,CAAC,4BAA4B,EAAE,EAAE,CAAC;YACxC,MAAM,IAAI,CAAC,8BAA8B,CAAC,SAAS,EAAE,OAAO,EAAE,IAAI,CAAC,CAAA;QACrE,CAAC;aAAM,CAAC;YACN,MAAM,IAAI,CAAC,6BAA6B,CAAC,SAAS,EAAE,OAAO,EAAE,IAAI,CAAC,CAAA;QACpE,CAAC;IACH,CAAC;IAED;;OAEG;IACH,4BAA4B;QAC1B,qBAAqB;QACrB,MAAM,YAAY,GAAG,IAAI,CAAC,YAAY,IAAI,CAAC,CAAA;QAC3C,qBAAqB;QACrB,MAAM,YAAY,GAAG,IAAI,CAAC,YAAY,IAAI,CAAC,CAAA;QAC3C,qBAAqB;QACrB,MAAM,YAAY,GAAG,IAAI,CAAC,YAAY,IAAI,CAAC,CAAA;QAE3C,IAAI,YAAY,IAAI,CAAC;YAAE,OAAO,IAAI,CAAA;QAClC,IAAI,YAAY,IAAI,CAAC,IAAI,YAAY,IAAI,CAAC;YAAE,OAAO,IAAI,CAAA;QACvD,IAAI,YAAY,IAAI,CAAC,IAAI,YAAY,IAAI,CAAC,IAAI,YAAY,IAAI,EAAE;YAAE,OAAO,IAAI,CAAA;QAE7E,OAAO,KAAK,CAAA;IACd,CAAC;IAED;;OAEG;IACH,2BAA2B;QACzB,qBAAqB;QACrB,MAAM,YAAY,GAAG,IAAI,CAAC,YAAY,IAAI,CAAC,CAAA;QAC3C,qBAAqB;QACrB,MAAM,YAAY,GAAG,IAAI,CAAC,YAAY,IAAI,CAAC,CAAA;QAE3C,IAAI,YAAY,IAAI,CAAC;YAAE,OAAO,IAAI,CAAA;QAClC,IAAI,YAAY,IAAI,CAAC,IAAI,YAAY,IAAI,EAAE;YAAE,OAAO,IAAI,CAAA;QAExD,OAAO,KAAK,CAAA;IACd,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,8BAA8B,CAAC,SAAS,EAAE,OAAO,EAAE,IAAI;QAC3D,IAAI,CAAC,kBAAkB,EAAE,CAAA;QACzB,MAAM,GAAG,GAAG,IAAI,MAAM,CAAC,EAAC,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,SAAS,EAAC,CAAC,CAAC,KAAK,EAAE,CAAA;QAExE,MAAM,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;IACvB,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,6BAA6B,CAAC,SAAS,EAAE,OAAO,EAAE,IAAI;QAC1D,IAAI,CAAC,kBAAkB,EAAE,CAAA;QACzB,uBAAuB;QACvB,MAAM,IAAI,GAAG,EAAE,CAAA;QAEf,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE,CAAC;YACvB,kCAAkC;YAClC,MAAM,IAAI,GAAG,EAAE,CAAA;YAEf,KAAK,MAAM,WAAW,IAAI,OAAO,EAAE,CAAC;gBAClC,MAAM,UAAU,GAAG,OAAO,CAAC,WAAW,CAAC,CAAA;gBACvC,MAAM,KAAK,GAAG,GAAG,CAAC,WAAW,CAAC,CAAA;gBAE9B,IAAI,CAAC,UAAU,CAAC,GAAG,KAAK,CAAA;YAC1B,CAAC;YAED,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,EAAC,SAAS,EAAE,IAAI,EAAC,CAAC,CAAA;YAEnD,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;QACtB,CAAC;QAED,MAAM,IAAI,CAAC,WAAW,CAAC,KAAK,IAAI,EAAE;YAChC,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE,CAAC;gBACvB,MAAM,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;YACvB,CAAC;QACH,CAAC,CAAC,CAAA;IACJ,CAAC;IAED,KAAK,CAAC,YAAY;QAChB,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,8CAA8C,CAAC,CAAA;QAE/E,OAAO,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,gBAAgB,CAAC,CAAA;IAC1C,CAAC;IAED,OAAO;QACL,IAAI,CAAC,IAAI,CAAC,QAAQ;YAAE,IAAI,CAAC,QAAQ,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC,CAAA;QAErD,OAAO,IAAI,CAAC,QAAQ,CAAA;IACtB,CAAC;IAED;;OAEG;IACH,cAAc,KAAK,OAAO,SAAS,CAAA,CAAC,CAAC,CAAC,0DAA0D;IAEhG;;;OAGG;IACH,UAAU,CAAC,KAAK,IAAI,OAAO,IAAI,WAAW,CAAC,EAAC,KAAK,EAAC,CAAC,CAAC,KAAK,EAAE,CAAA,CAAC,CAAC;IAE7D,KAAK,CAAC,eAAe;QACnB,IAAI,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YAC3C,OAAM;QACR,CAAC;QAED,MAAM,aAAa,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,oCAAoC,CAAC,CAAA;QAE5E,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAA;QAE/C,MAAM,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;QAE5C,IAAI,CAAC,YAAY,GAAG,MAAM,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAA;QAC3C,IAAI,CAAC,YAAY,GAAG,MAAM,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAA;QAC3C,IAAI,CAAC,YAAY,GAAG,MAAM,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAA;IAC7C,CAAC;IAED,oCAAoC,KAAK,OAAO,KAAK,CAAA,CAAC,CAAC;IACvD,6BAA6B,KAAK,OAAO,KAAK,CAAA,CAAC,CAAC;IAEhD;;;OAGG;IACH,MAAM,CAAC,KAAK;QACV,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAA;QAEjC,MAAM,IAAI,GAAG,OAAO,KAAK,CAAA;QAEzB,IAAI,IAAI,IAAI,QAAQ;YAAE,KAAK,GAAG,GAAG,KAAK,EAAE,CAAA;QAExC,MAAM,gBAAgB,GAAG,YAAY,CAAC,KAAK,EAAE,IAAI,CAAC,CAAA;QAClD,MAAM,MAAM,GAAG,gBAAgB,CAAC,SAAS,CAAC,CAAC,EAAE,gBAAgB,CAAC,MAAM,GAAG,CAAC,CAAC,CAAA;QAEzE,OAAO,MAAM,CAAA;IACf,CAAC;IAED;;;OAGG;IACH,sBAAsB,CAAC,KAAK;QAC1B,MAAM,WAAW,GAAG,CAClB,KAAK,CAAC,OAAO,EAAE,UAAU,CAAC,sCAAsC,CAAC;YACjE,KAAK,CAAC,OAAO,EAAE,UAAU,CAAC,oBAAoB,CAAC;YAC/C,KAAK,CAAC,OAAO,EAAE,QAAQ,CAAC,8CAA8C,CAAC,CACxE,CAAA;QAED,OAAO,EAAC,KAAK,EAAE,WAAW,EAAE,SAAS,EAAE,KAAK,EAAC,CAAA;IAC/C,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,KAAK;QACT,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAA;QAEjC,MAAM,IAAI,GAAG,OAAO,KAAK,CAAA;QAEzB,IAAI,IAAI,IAAI,QAAQ;YAAE,OAAO,qBAAqB,CAAC,CAAC,KAAK,CAAC,CAAA;QAC1D,IAAI,IAAI,IAAI,QAAQ;YAAE,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC,CAAA;QAE3C,OAAO,YAAY,CAAC,KAAK,EAAE,IAAI,CAAC,CAAA;IAClC,CAAC;IAED;;;OAGG;IACH,SAAS,CAAC,EAAC,UAAU,EAAE,IAAI,EAAE,SAAS,EAAC,IAAI,OAAO,IAAI,MAAM,CAAC,EAAC,UAAU,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,SAAS,EAAC,CAAC,CAAC,KAAK,EAAE,CAAA,CAAC,CAAC;IAEnH;;;OAGG;IACH,SAAS,CAAC,IAAI,IAAI,OAAO,IAAI,MAAM,CAAC,EAAC,GAAG,IAAI,EAAE,MAAM,EAAE,IAAI,EAAC,CAAC,CAAC,KAAK,EAAE,CAAA,CAAC,CAAC;IAEtE;;OAEG;IACH,KAAK,CAAC,YAAY;QAChB,OAAO,MAAM,IAAI,YAAY,CAAC,EAAC,MAAM,EAAE,IAAI,EAAC,CAAC,CAAC,KAAK,EAAE,CAAA;IACvD,CAAC;IAED;;;;;;;;;;;;;;OAcG;IACH,KAAK,CAAC,mBAAmB,CAAC,IAAI,EAAE,EAAC,SAAS,EAAC,GAAG,EAAE;QAC9C,MAAM,KAAK,GAAG,kCAAkC,CAAC,kBAAkB,CAAA;QAEnE,OAAO,KAAK,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC;YACpC,IAAI,WAAW,GAAG,IAAI,CAAA;YAEtB,IAAI,OAAO,SAAS,KAAK,QAAQ,IAAI,SAAS,IAAI,CAAC,EAAE,CAAC;gBACpD,WAAW,GAAG,SAAS,CAAA;gBAEvB,IAAI,WAAW,IAAI,CAAC;oBAAE,OAAO,KAAK,CAAA;YACpC,CAAC;YAED,MAAM,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;gBAC5B,MAAM,OAAO,GAAG,KAAK,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,EAAE,CAAA;gBACnD,oCAAoC;gBACpC,IAAI,aAAa,GAAG,IAAI,CAAA;gBACxB,kCAAkC;gBAClC,IAAI,gBAAgB,GAAG,IAAI,CAAA;gBAE3B,gBAAgB,GAAG,GAAG,EAAE;oBACtB,IAAI,aAAa;wBAAE,YAAY,CAAC,aAAa,CAAC,CAAA;oBAE9C,MAAM,OAAO,GAAG,KAAK,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,EAAE,CAAA;oBACnD,MAAM,KAAK,GAAG,OAAO,CAAC,OAAO,CAAC,yBAAyB,CAAC,CAAC,gBAAgB,CAAC,CAAC,CAAA;oBAE3E,IAAI,KAAK,IAAI,CAAC;wBAAE,OAAO,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAA;oBACxC,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC;wBAAE,KAAK,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,CAAA;oBAE1D,OAAO,CAAC,SAAS,CAAC,CAAA;gBACpB,CAAC,CAAA;gBAED,OAAO,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAA;gBAC9B,KAAK,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,EAAE,OAAO,CAAC,CAAA;gBAEtC,IAAI,WAAW,KAAK,IAAI,EAAE,CAAC;oBACzB,aAAa,GAAG,UAAU,CAAC,GAAG,EAAE;wBAC9B,IAAI,gBAAgB;4BAAE,gBAAgB,EAAE,CAAA;oBAC1C,CAAC,EAAE,WAAW,CAAC,CAAA;gBACjB,CAAC;YACH,CAAC,CAAC,CAAA;YAEF,IAAI,OAAO,SAAS,KAAK,QAAQ,IAAI,SAAS,IAAI,CAAC,IAAI,KAAK,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC;gBACpF,OAAO,KAAK,CAAA;YACd,CAAC;QACH,CAAC;QAED,KAAK,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,EAAE,IAAI,CAAC,CAAA;QAElC,OAAO,IAAI,CAAA;IACb,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,sBAAsB,CAAC,IAAI;QAC/B,MAAM,KAAK,GAAG,kCAAkC,CAAC,kBAAkB,CAAA;QAEnE,IAAI,KAAK,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC;YAAE,OAAO,KAAK,CAAA;QAE9C,KAAK,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,EAAE,IAAI,CAAC,CAAA;QAElC,OAAO,IAAI,CAAA;IACb,CAAC;IAED;;;;;;;;;OASG;IACH,KAAK,CAAC,mBAAmB,CAAC,IAAI;QAC5B,MAAM,KAAK,GAAG,kCAAkC,CAAC,kBAAkB,CAAA;QACnE,MAAM,KAAK,GAAG,KAAK,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,CAAA;QAE1C,IAAI,KAAK,KAAK,IAAI;YAAE,OAAO,KAAK,CAAA;QAEhC,KAAK,CAAC,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,CAAA;QAE/B,MAAM,OAAO,GAAG,KAAK,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,CAAC,CAAA;QAE7C,IAAI,OAAO,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAClC,MAAM,UAAU,GAAG,OAAO,CAAC,KAAK,EAAE,CAAA;YAElC,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC;gBAAE,KAAK,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,CAAA;YAC1D,IAAI,UAAU;gBAAE,UAAU,EAAE,CAAA;QAC9B,CAAC;QAED,OAAO,IAAI,CAAA;IACb,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,kBAAkB,CAAC,IAAI;QAC3B,OAAO,kCAAkC,CAAC,kBAAkB,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,CAAA;IACrF,CAAC;CACF;AAED;;;;;;;;;;GAUG;AACH,kCAAkC,CAAC,kBAAkB,GAAG;IACtD,YAAY,EAAE,IAAI,GAAG,EAAE;IACvB,aAAa,EAAE,IAAI,GAAG,EAAE;CACzB,CAAA","sourcesContent":["// @ts-check\n\nimport {digg} from \"diggerize\"\n\nimport AlterTable from \"./sql/alter-table.js\"\nimport Base from \"../base.js\"\nimport CreateIndex from \"./sql/create-index.js\"\nimport CreateTable from \"./sql/create-table.js\"\nimport Delete from \"./sql/delete.js\"\nimport DropTable from \"./sql/drop-table.js\"\nimport escapeString from \"sql-escape-string\"\nimport Insert from \"./sql/insert.js\"\nimport Options from \"./options.js\"\nimport QueryParser from \"./query-parser.js\"\nimport Table from \"./table.js\"\nimport StructureSql from \"./structure-sql.js\"\nimport Upsert from \"./sql/upsert.js\"\nimport Update from \"./sql/update.js\"\n\nexport default class VelociousDatabaseDriversSqliteBase extends Base {\n  /** @type {number | undefined} */\n  versionMajor = undefined\n  /** @type {number | undefined} */\n  versionMinor = undefined\n  /** @type {number | undefined} */\n  versionPatch = undefined\n\n  /**\n   * @param {import(\"../../table-data/index.js\").default} tableData - Table data.\n   * @returns {Promise<string[]>} - Resolves with SQL statements.\n   */\n  async alterTableSQLs(tableData) {\n    const alterArgs = {driver: this, tableData}\n    const alterTable = new AlterTable(alterArgs)\n\n    return await alterTable.toSQLs()\n  }\n\n  /**\n   * @param {import(\"../base.js\").CreateIndexSqlArgs} indexData - Index data.\n   * @returns {Promise<string[]>} - Resolves with SQL statements.\n   */\n  async createIndexSQLs(indexData) {\n    const createArgs = Object.assign({driver: this}, indexData)\n    const createIndex = new CreateIndex(createArgs)\n\n    return await createIndex.toSQLs()\n  }\n\n  /**\n   * @abstract\n   * @param {import(\"../../table-data/index.js\").default} tableData - Table data.\n   * @returns {Promise<string[]>} - Resolves with SQL statements.\n   */\n  async createTableSql(tableData) {\n    const createArgs = {tableData, driver: this, indexInCreateTable: false}\n    const createTable = new CreateTable(createArgs)\n\n    return await createTable.toSql()\n  }\n\n  currentDatabase() {\n    return null\n  }\n\n  async disableForeignKeys() {\n    await this.query(\"PRAGMA foreign_keys = 0\")\n  }\n\n  async enableForeignKeys() {\n    await this.query(\"PRAGMA foreign_keys = 1\")\n  }\n\n  /**\n   * @param {string} tableName - Table name.\n   * @param {import(\"../base.js\").DropTableSqlArgsType} [args] - Options object.\n   * @returns {Promise<string[]>} - Resolves with SQL statements.\n   */\n  async dropTableSQLs(tableName, args = {}) {\n    const driver = /** @type {import(\"../base.js\").default} */ (this)\n    const dropArgs = Object.assign({tableName, driver}, args)\n    const dropTable = new DropTable(dropArgs)\n\n    return await dropTable.toSQLs()\n  }\n\n  /**\n   * @param {import(\"../base.js\").DeleteSqlArgsType} args - Options object.\n   * @returns {string} - SQL string.\n   */\n  deleteSql(args) { return new Delete(Object.assign({driver: this}, args)).toSql() }\n\n  /**\n   * @returns {string} - The type.\n   */\n  getType() { return \"sqlite\" }\n\n  /**\n   * @param {import(\"../base.js\").InsertSqlArgsType} args - Options object.\n   * @returns {string} - SQL string.\n   */\n  insertSql(args) { return new Insert(Object.assign({driver: this}, args)).toSql() }\n\n  /**\n   * @param {string} name - Name.\n   * @param {object} [args] - Options object.\n   * @param {boolean} args.throwError - Whether throw error.\n   * @returns {Promise<import(\"../base-table.js\").default | undefined>} - Resolves with the table by name.\n   */\n  async getTableByName(name, args) {\n    const result = await this.query(`SELECT name FROM sqlite_master WHERE type = 'table' AND name = ${this.quote(name)} LIMIT 1`)\n    const row = result[0]\n\n    if (row) {\n      return new Table({driver: this, row: /** @type {Record<string, string | number | null>} */ (row)})\n    }\n\n    if (args?.throwError !== false) {\n      const tables = await this.getTables()\n      const tableNames = tables.map((table) => table.getName())\n\n      throw new Error(this._missingTableErrorMessage(name, tableNames))\n    }\n  }\n\n  /** @returns {Promise<Array<import(\"../base-table.js\").default>>} - Resolves with the tables.  */\n  async getTables() {\n    const result = await this.query(\"SELECT name FROM sqlite_master WHERE type = 'table' ORDER BY name\")\n    const tables = []\n\n    for (const row of result) {\n      const table = new Table({driver: this, row: /** @type {Record<string, string | number | null>} */ (row)})\n\n      tables.push(table)\n    }\n\n    return tables\n  }\n\n  /**\n   * @param {string} tableName - Table name.\n   * @param {Array<string>} columns - Column names.\n   * @param {Array<Array<unknown>>} rows - Rows to insert.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async insertMultiple(tableName, columns, rows) {\n    this._assertNotReadOnly()\n    await this.registerVersion()\n\n    if (this.supportsMultipleInsertValues()) {\n      await this.insertMultipleWithSingleInsert(tableName, columns, rows)\n    } else {\n      await this.insertMultipleWithTransaction(tableName, columns, rows)\n    }\n  }\n\n  /**\n   * @returns {boolean} - Whether supports multiple insert values.\n   */\n  supportsMultipleInsertValues() {\n    /** @type {number} */\n    const versionMajor = this.versionMajor || 0\n    /** @type {number} */\n    const versionMinor = this.versionMinor || 0\n    /** @type {number} */\n    const versionPatch = this.versionPatch || 0\n\n    if (versionMajor >= 4) return true\n    if (versionMajor == 3 && versionMinor >= 8) return true\n    if (versionMajor == 3 && versionMinor == 7 && versionPatch >= 11) return true\n\n    return false\n  }\n\n  /**\n   * @returns {boolean} - Whether supports insert into returning.\n   */\n  supportsInsertIntoReturning() {\n    /** @type {number} */\n    const versionMajor = this.versionMajor || 0\n    /** @type {number} */\n    const versionMinor = this.versionMinor || 0\n\n    if (versionMajor >= 4) return true\n    if (versionMajor == 3 && versionMinor >= 35) return true\n\n    return false\n  }\n\n  /**\n   * @param {string} tableName - Table name.\n   * @param {Array<string>} columns - Column names.\n   * @param {Array<Array<unknown>>} rows - Rows to insert.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async insertMultipleWithSingleInsert(tableName, columns, rows) {\n    this._assertNotReadOnly()\n    const sql = new Insert({columns, driver: this, rows, tableName}).toSql()\n\n    await this.query(sql)\n  }\n\n  /**\n   * @param {string} tableName - Table name.\n   * @param {Array<string>} columns - Column names.\n   * @param {Array<Array<unknown>>} rows - Rows to insert.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async insertMultipleWithTransaction(tableName, columns, rows) {\n    this._assertNotReadOnly()\n    /** @type {string[]} */\n    const sqls = []\n\n    for (const row of rows) {\n      /** @type {Record<string, any>} */\n      const data = {}\n\n      for (const columnIndex in columns) {\n        const columnName = columns[columnIndex]\n        const value = row[columnIndex]\n\n        data[columnName] = value\n      }\n\n      const insertSql = this.insertSql({tableName, data})\n\n      sqls.push(insertSql)\n    }\n\n    await this.transaction(async () => {\n      for (const sql of sqls) {\n        await this.query(sql)\n      }\n    })\n  }\n\n  async lastInsertID() {\n    const result = await this.query(\"SELECT LAST_INSERT_ROWID() AS last_insert_id\")\n\n    return digg(result, 0, \"last_insert_id\")\n  }\n\n  options() {\n    if (!this._options) this._options = new Options(this)\n\n    return this._options\n  }\n\n  /**\n   * @returns {string} - The type of the primary key for this driver.\n   */\n  primaryKeyType() { return \"integer\" } // Because bigint on SQLite doesn't support auto increment\n\n  /**\n   * @param {import(\"../../query/index.js\").default} query - Query instance.\n   * @returns {string} - SQL string.\n   */\n  queryToSql(query) { return new QueryParser({query}).toSql() }\n\n  async registerVersion() {\n    if (this.versionMajor || this.versionMinor) {\n      return\n    }\n\n    const versionResult = await this.query(\"SELECT sqlite_version() AS version\")\n\n    this.version = String(versionResult[0].version)\n\n    const versionParts = this.version.split(\".\")\n\n    this.versionMajor = Number(versionParts[0])\n    this.versionMinor = Number(versionParts[1])\n    this.versionPatch = Number(versionParts[2])\n  }\n\n  shouldSetAutoIncrementWhenPrimaryKey() { return false }\n  supportsDefaultPrimaryKeyUUID() { return false }\n\n  /**\n   * @param {any} value - Value to use.\n   * @returns {any} - The escape.\n   */\n  escape(value) {\n    value = this._convertValue(value)\n\n    const type = typeof value\n\n    if (type != \"string\") value = `${value}`\n\n    const resultWithQuotes = escapeString(value, null)\n    const result = resultWithQuotes.substring(1, resultWithQuotes.length - 1)\n\n    return result\n  }\n\n  /**\n   * @param {Error} error - Error instance.\n   * @returns {import(\"../base.js\").RetryableDatabaseErrorResult} - Retry info.\n   */\n  retryableDatabaseError(error) {\n    const shouldRetry = (\n      error.message?.startsWith(\"attempt to write a readonly database\") ||\n      error.message?.startsWith(\"database is locked\") ||\n      error.message?.includes(\"→ Caused by: Error code : database is locked\")\n    )\n\n    return {retry: shouldRetry, reconnect: false}\n  }\n\n  /**\n   * @param {any} value - Value to use.\n   * @returns {string | number} - The quoted value.\n   */\n  quote(value) {\n    value = this._convertValue(value)\n\n    const type = typeof value\n\n    if (type == \"number\") return /** @type {number} */ (value)\n    if (type != \"string\") value = String(value)\n\n    return escapeString(value, null)\n  }\n\n  /**\n   * @param {import(\"../base.js\").UpdateSqlArgsType} args - Options object.\n   * @returns {string} - SQL string.\n   */\n  updateSql({conditions, data, tableName}) { return new Update({conditions, data, driver: this, tableName}).toSql() }\n\n  /**\n   * @param {import(\"../base.js\").UpsertSqlArgsType} args - Options object.\n   * @returns {string} - SQL string.\n   */\n  upsertSql(args) { return new Upsert({...args, driver: this}).toSql() }\n\n  /**\n   * @returns {Promise<string | null>} - Resolves with SQL string.\n   */\n  async structureSql() {\n    return await new StructureSql({driver: this}).toSql()\n  }\n\n  /**\n   * Blocks until an in-process advisory lock with the given name is\n   * acquired. SQLite has no built-in advisory lock primitive, so this is\n   * implemented as a process-local waiter queue. Typical SQLite deployments\n   * run inside a single Node process, which is exactly the scope this\n   * emulation covers; multi-process SQLite setups should not rely on this\n   * for cross-process mutual exclusion.\n   *\n   * The owning driver instance is recorded so that `releaseAdvisoryLock`\n   * can refuse to release a lock that was acquired by someone else.\n   *\n   * @param {string} name - Lock name.\n   * @param {{timeoutMs?: number | null}} [args] - Optional timeout in milliseconds; `null`, `undefined`, or negative blocks forever.\n   * @returns {Promise<boolean>} - True if the lock was acquired, false if the timeout elapsed.\n   */\n  async acquireAdvisoryLock(name, {timeoutMs} = {}) {\n    const state = VelociousDatabaseDriversSqliteBase._advisoryLockState\n\n    while (state.ownersByName.has(name)) {\n      let remainingMs = null\n\n      if (typeof timeoutMs === \"number\" && timeoutMs >= 0) {\n        remainingMs = timeoutMs\n\n        if (remainingMs <= 0) return false\n      }\n\n      await new Promise((resolve) => {\n        const waiters = state.waitersByName.get(name) || []\n        /** @type {NodeJS.Timeout | null} */\n        let timeoutHandle = null\n        /** @type {(() => void) | null} */\n        let removeAndResolve = null\n\n        removeAndResolve = () => {\n          if (timeoutHandle) clearTimeout(timeoutHandle)\n\n          const current = state.waitersByName.get(name) || []\n          const index = current.indexOf(/** @type {() => void} */ (removeAndResolve))\n\n          if (index >= 0) current.splice(index, 1)\n          if (current.length === 0) state.waitersByName.delete(name)\n\n          resolve(undefined)\n        }\n\n        waiters.push(removeAndResolve)\n        state.waitersByName.set(name, waiters)\n\n        if (remainingMs !== null) {\n          timeoutHandle = setTimeout(() => {\n            if (removeAndResolve) removeAndResolve()\n          }, remainingMs)\n        }\n      })\n\n      if (typeof timeoutMs === \"number\" && timeoutMs >= 0 && state.ownersByName.has(name)) {\n        return false\n      }\n    }\n\n    state.ownersByName.set(name, this)\n\n    return true\n  }\n\n  /**\n   * @param {string} name - Lock name.\n   * @returns {Promise<boolean>} - True if the lock was acquired, false if it was already held.\n   */\n  async tryAcquireAdvisoryLock(name) {\n    const state = VelociousDatabaseDriversSqliteBase._advisoryLockState\n\n    if (state.ownersByName.has(name)) return false\n\n    state.ownersByName.set(name, this)\n\n    return true\n  }\n\n  /**\n   * Releases the lock only if **this** driver instance owns it. Calling\n   * release for a lock owned by another driver instance is a no-op that\n   * returns `false`, matching the \"you can only release locks you own\"\n   * contract of MySQL's `RELEASE_LOCK` and PostgreSQL's\n   * `pg_advisory_unlock`.\n   *\n   * @param {string} name - Lock name.\n   * @returns {Promise<boolean>} - True if the lock was held by this driver and has now been released.\n   */\n  async releaseAdvisoryLock(name) {\n    const state = VelociousDatabaseDriversSqliteBase._advisoryLockState\n    const owner = state.ownersByName.get(name)\n\n    if (owner !== this) return false\n\n    state.ownersByName.delete(name)\n\n    const waiters = state.waitersByName.get(name)\n\n    if (waiters && waiters.length > 0) {\n      const nextWaiter = waiters.shift()\n\n      if (waiters.length === 0) state.waitersByName.delete(name)\n      if (nextWaiter) nextWaiter()\n    }\n\n    return true\n  }\n\n  /**\n   * @param {string} name - Lock name.\n   * @returns {Promise<boolean>} - True if any driver instance currently holds the lock.\n   */\n  async isAdvisoryLockHeld(name) {\n    return VelociousDatabaseDriversSqliteBase._advisoryLockState.ownersByName.has(name)\n  }\n}\n\n/**\n * Process-wide state for the SQLite advisory lock emulation. Shared across\n * every SQLite driver instance (native, web, sql.js) because there is no\n * concept of \"connection\" to distinguish them at the SQLite level.\n *\n * `ownersByName` maps each held lock name to the driver instance that\n * acquired it so `releaseAdvisoryLock` can reject releases from drivers\n * that do not own the lock.\n *\n * @type {{ownersByName: Map<string, VelociousDatabaseDriversSqliteBase>, waitersByName: Map<string, Array<() => void>>}}\n */\nVelociousDatabaseDriversSqliteBase._advisoryLockState = {\n  ownersByName: new Map(),\n  waitersByName: new Map()\n}\n"]}
384
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base.js","sourceRoot":"","sources":["../../../../../src/database/drivers/sqlite/base.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport {digg} from \"diggerize\"\n\nimport AlterTable from \"./sql/alter-table.js\"\nimport Base from \"../base.js\"\nimport CreateIndex from \"./sql/create-index.js\"\nimport CreateTable from \"./sql/create-table.js\"\nimport Delete from \"./sql/delete.js\"\nimport DropTable from \"./sql/drop-table.js\"\nimport escapeString from \"sql-escape-string\"\nimport Insert from \"./sql/insert.js\"\nimport Options from \"./options.js\"\nimport QueryParser from \"./query-parser.js\"\nimport Table from \"./table.js\"\nimport StructureSql from \"./structure-sql.js\"\nimport Upsert from \"./sql/upsert.js\"\nimport Update from \"./sql/update.js\"\n\nexport default class VelociousDatabaseDriversSqliteBase extends Base {\n  /** @type {number | undefined} */\n  versionMajor = undefined\n  /** @type {number | undefined} */\n  versionMinor = undefined\n  /** @type {number | undefined} */\n  versionPatch = undefined\n\n  /**\n   * @param {import(\"../../table-data/index.js\").default} tableData - Table data.\n   * @returns {Promise<string[]>} - Resolves with SQL statements.\n   */\n  async alterTableSQLs(tableData) {\n    const alterArgs = {driver: this, tableData}\n    const alterTable = new AlterTable(alterArgs)\n\n    return await alterTable.toSQLs()\n  }\n\n  /**\n   * @param {import(\"../base.js\").CreateIndexSqlArgs} indexData - Index data.\n   * @returns {Promise<string[]>} - Resolves with SQL statements.\n   */\n  async createIndexSQLs(indexData) {\n    const createArgs = Object.assign({driver: this}, indexData)\n    const createIndex = new CreateIndex(createArgs)\n\n    return await createIndex.toSQLs()\n  }\n\n  /**\n   * @abstract\n   * @param {import(\"../../table-data/index.js\").default} tableData - Table data.\n   * @returns {Promise<string[]>} - Resolves with SQL statements.\n   */\n  async createTableSql(tableData) {\n    const createArgs = {tableData, driver: this, indexInCreateTable: false}\n    const createTable = new CreateTable(createArgs)\n\n    return await createTable.toSql()\n  }\n\n  currentDatabase() {\n    return null\n  }\n\n  async disableForeignKeys() {\n    await this.query(\"PRAGMA foreign_keys = 0\")\n  }\n\n  async enableForeignKeys() {\n    await this.query(\"PRAGMA foreign_keys = 1\")\n  }\n\n  /**\n   * @param {string} tableName - Table name.\n   * @param {import(\"../base.js\").DropTableSqlArgsType} [args] - Options object.\n   * @returns {Promise<string[]>} - Resolves with SQL statements.\n   */\n  async dropTableSQLs(tableName, args = {}) {\n    const driver = /** @type {import(\"../base.js\").default} */ (this)\n    const dropArgs = Object.assign({tableName, driver}, args)\n    const dropTable = new DropTable(dropArgs)\n\n    return await dropTable.toSQLs()\n  }\n\n  /**\n   * @param {import(\"../base.js\").DeleteSqlArgsType} args - Options object.\n   * @returns {string} - SQL string.\n   */\n  deleteSql(args) { return new Delete(Object.assign({driver: this}, args)).toSql() }\n\n  /**\n   * @returns {string} - The type.\n   */\n  getType() { return \"sqlite\" }\n\n  /**\n   * @param {import(\"../base.js\").InsertSqlArgsType} args - Options object.\n   * @returns {string} - SQL string.\n   */\n  insertSql(args) { return new Insert(Object.assign({driver: this}, args)).toSql() }\n\n  /** @returns {Promise<Array<import(\"../base-table.js\").default>>} - Resolves with the tables.  */\n  async getTables() {\n    return await this._cachedSchemaMetadata(\"tables\", async () => {\n      const result = await this.query(\"SELECT name FROM sqlite_master WHERE type = 'table' ORDER BY name\")\n      const tables = []\n\n      for (const row of result) {\n        const table = new Table({driver: this, row: /** @type {Record<string, string | number | null>} */ (row)})\n\n        tables.push(table)\n      }\n\n      return tables\n    })\n  }\n\n  /**\n   * @param {string} tableName - Table name.\n   * @param {Array<string>} columns - Column names.\n   * @param {Array<Array<unknown>>} rows - Rows to insert.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async insertMultiple(tableName, columns, rows) {\n    this._assertNotReadOnly()\n    await this.registerVersion()\n\n    if (this.supportsMultipleInsertValues()) {\n      await this.insertMultipleWithSingleInsert(tableName, columns, rows)\n    } else {\n      await this.insertMultipleWithTransaction(tableName, columns, rows)\n    }\n  }\n\n  /**\n   * @returns {boolean} - Whether supports multiple insert values.\n   */\n  supportsMultipleInsertValues() {\n    /** @type {number} */\n    const versionMajor = this.versionMajor || 0\n    /** @type {number} */\n    const versionMinor = this.versionMinor || 0\n    /** @type {number} */\n    const versionPatch = this.versionPatch || 0\n\n    if (versionMajor >= 4) return true\n    if (versionMajor == 3 && versionMinor >= 8) return true\n    if (versionMajor == 3 && versionMinor == 7 && versionPatch >= 11) return true\n\n    return false\n  }\n\n  /**\n   * @returns {boolean} - Whether supports insert into returning.\n   */\n  supportsInsertIntoReturning() {\n    /** @type {number} */\n    const versionMajor = this.versionMajor || 0\n    /** @type {number} */\n    const versionMinor = this.versionMinor || 0\n\n    if (versionMajor >= 4) return true\n    if (versionMajor == 3 && versionMinor >= 35) return true\n\n    return false\n  }\n\n  /**\n   * @param {string} tableName - Table name.\n   * @param {Array<string>} columns - Column names.\n   * @param {Array<Array<unknown>>} rows - Rows to insert.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async insertMultipleWithSingleInsert(tableName, columns, rows) {\n    this._assertNotReadOnly()\n    const sql = new Insert({columns, driver: this, rows, tableName}).toSql()\n\n    await this.query(sql)\n  }\n\n  /**\n   * @param {string} tableName - Table name.\n   * @param {Array<string>} columns - Column names.\n   * @param {Array<Array<unknown>>} rows - Rows to insert.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async insertMultipleWithTransaction(tableName, columns, rows) {\n    this._assertNotReadOnly()\n    /** @type {string[]} */\n    const sqls = []\n\n    for (const row of rows) {\n      /** @type {Record<string, any>} */\n      const data = {}\n\n      for (const columnIndex in columns) {\n        const columnName = columns[columnIndex]\n        const value = row[columnIndex]\n\n        data[columnName] = value\n      }\n\n      const insertSql = this.insertSql({tableName, data})\n\n      sqls.push(insertSql)\n    }\n\n    await this.transaction(async () => {\n      for (const sql of sqls) {\n        await this.query(sql)\n      }\n    })\n  }\n\n  async lastInsertID() {\n    const result = await this.query(\"SELECT LAST_INSERT_ROWID() AS last_insert_id\")\n\n    return digg(result, 0, \"last_insert_id\")\n  }\n\n  options() {\n    if (!this._options) this._options = new Options(this)\n\n    return this._options\n  }\n\n  /**\n   * @returns {string} - The type of the primary key for this driver.\n   */\n  primaryKeyType() { return \"integer\" } // Because bigint on SQLite doesn't support auto increment\n\n  /**\n   * @param {import(\"../../query/index.js\").default} query - Query instance.\n   * @returns {string} - SQL string.\n   */\n  queryToSql(query) { return new QueryParser({query}).toSql() }\n\n  async registerVersion() {\n    if (this.versionMajor || this.versionMinor) {\n      return\n    }\n\n    const versionResult = await this.query(\"SELECT sqlite_version() AS version\")\n\n    this.version = String(versionResult[0].version)\n\n    const versionParts = this.version.split(\".\")\n\n    this.versionMajor = Number(versionParts[0])\n    this.versionMinor = Number(versionParts[1])\n    this.versionPatch = Number(versionParts[2])\n  }\n\n  shouldSetAutoIncrementWhenPrimaryKey() { return false }\n  supportsDefaultPrimaryKeyUUID() { return false }\n\n  /**\n   * @param {any} value - Value to use.\n   * @returns {any} - The escape.\n   */\n  escape(value) {\n    value = this._convertValue(value)\n\n    const type = typeof value\n\n    if (type != \"string\") value = `${value}`\n\n    const resultWithQuotes = escapeString(value, null)\n    const result = resultWithQuotes.substring(1, resultWithQuotes.length - 1)\n\n    return result\n  }\n\n  /**\n   * @param {Error} error - Error instance.\n   * @returns {import(\"../base.js\").RetryableDatabaseErrorResult} - Retry info.\n   */\n  retryableDatabaseError(error) {\n    const shouldRetry = (\n      error.message?.startsWith(\"attempt to write a readonly database\") ||\n      error.message?.startsWith(\"database is locked\") ||\n      error.message?.includes(\"→ Caused by: Error code : database is locked\")\n    )\n\n    return {retry: shouldRetry, reconnect: false}\n  }\n\n  /**\n   * @param {any} value - Value to use.\n   * @returns {string | number} - The quoted value.\n   */\n  quote(value) {\n    value = this._convertValue(value)\n\n    const type = typeof value\n\n    if (type == \"number\") return /** @type {number} */ (value)\n    if (type != \"string\") value = String(value)\n\n    return escapeString(value, null)\n  }\n\n  /**\n   * @param {import(\"../base.js\").UpdateSqlArgsType} args - Options object.\n   * @returns {string} - SQL string.\n   */\n  updateSql({conditions, data, tableName}) { return new Update({conditions, data, driver: this, tableName}).toSql() }\n\n  /**\n   * @param {import(\"../base.js\").UpsertSqlArgsType} args - Options object.\n   * @returns {string} - SQL string.\n   */\n  upsertSql(args) { return new Upsert({...args, driver: this}).toSql() }\n\n  /**\n   * @returns {Promise<string | null>} - Resolves with SQL string.\n   */\n  async structureSql() {\n    return await this._cachedSchemaMetadata(\"structureSql\", async () => await new StructureSql({driver: this}).toSql())\n  }\n\n  /**\n   * Blocks until an in-process advisory lock with the given name is\n   * acquired. SQLite has no built-in advisory lock primitive, so this is\n   * implemented as a process-local waiter queue. Typical SQLite deployments\n   * run inside a single Node process, which is exactly the scope this\n   * emulation covers; multi-process SQLite setups should not rely on this\n   * for cross-process mutual exclusion.\n   *\n   * The owning driver instance is recorded so that `releaseAdvisoryLock`\n   * can refuse to release a lock that was acquired by someone else.\n   *\n   * @param {string} name - Lock name.\n   * @param {{timeoutMs?: number | null}} [args] - Optional timeout in milliseconds; `null`, `undefined`, or negative blocks forever.\n   * @returns {Promise<boolean>} - True if the lock was acquired, false if the timeout elapsed.\n   */\n  async acquireAdvisoryLock(name, {timeoutMs} = {}) {\n    const state = VelociousDatabaseDriversSqliteBase._advisoryLockState\n\n    while (state.ownersByName.has(name)) {\n      let remainingMs = null\n\n      if (typeof timeoutMs === \"number\" && timeoutMs >= 0) {\n        remainingMs = timeoutMs\n\n        if (remainingMs <= 0) return false\n      }\n\n      await new Promise((resolve) => {\n        const waiters = state.waitersByName.get(name) || []\n        /** @type {NodeJS.Timeout | null} */\n        let timeoutHandle = null\n        /** @type {(() => void) | null} */\n        let removeAndResolve = null\n\n        removeAndResolve = () => {\n          if (timeoutHandle) clearTimeout(timeoutHandle)\n\n          const current = state.waitersByName.get(name) || []\n          const index = current.indexOf(/** @type {() => void} */ (removeAndResolve))\n\n          if (index >= 0) current.splice(index, 1)\n          if (current.length === 0) state.waitersByName.delete(name)\n\n          resolve(undefined)\n        }\n\n        waiters.push(removeAndResolve)\n        state.waitersByName.set(name, waiters)\n\n        if (remainingMs !== null) {\n          timeoutHandle = setTimeout(() => {\n            if (removeAndResolve) removeAndResolve()\n          }, remainingMs)\n        }\n      })\n\n      if (typeof timeoutMs === \"number\" && timeoutMs >= 0 && state.ownersByName.has(name)) {\n        return false\n      }\n    }\n\n    state.ownersByName.set(name, this)\n\n    return true\n  }\n\n  /**\n   * @param {string} name - Lock name.\n   * @returns {Promise<boolean>} - True if the lock was acquired, false if it was already held.\n   */\n  async tryAcquireAdvisoryLock(name) {\n    const state = VelociousDatabaseDriversSqliteBase._advisoryLockState\n\n    if (state.ownersByName.has(name)) return false\n\n    state.ownersByName.set(name, this)\n\n    return true\n  }\n\n  /**\n   * Releases the lock only if **this** driver instance owns it. Calling\n   * release for a lock owned by another driver instance is a no-op that\n   * returns `false`, matching the \"you can only release locks you own\"\n   * contract of MySQL's `RELEASE_LOCK` and PostgreSQL's\n   * `pg_advisory_unlock`.\n   *\n   * @param {string} name - Lock name.\n   * @returns {Promise<boolean>} - True if the lock was held by this driver and has now been released.\n   */\n  async releaseAdvisoryLock(name) {\n    const state = VelociousDatabaseDriversSqliteBase._advisoryLockState\n    const owner = state.ownersByName.get(name)\n\n    if (owner !== this) return false\n\n    state.ownersByName.delete(name)\n\n    const waiters = state.waitersByName.get(name)\n\n    if (waiters && waiters.length > 0) {\n      const nextWaiter = waiters.shift()\n\n      if (waiters.length === 0) state.waitersByName.delete(name)\n      if (nextWaiter) nextWaiter()\n    }\n\n    return true\n  }\n\n  /**\n   * @param {string} name - Lock name.\n   * @returns {Promise<boolean>} - True if any driver instance currently holds the lock.\n   */\n  async isAdvisoryLockHeld(name) {\n    return VelociousDatabaseDriversSqliteBase._advisoryLockState.ownersByName.has(name)\n  }\n}\n\n/**\n * Process-wide state for the SQLite advisory lock emulation. Shared across\n * every SQLite driver instance (native, web, sql.js) because there is no\n * concept of \"connection\" to distinguish them at the SQLite level.\n *\n * `ownersByName` maps each held lock name to the driver instance that\n * acquired it so `releaseAdvisoryLock` can reject releases from drivers\n * that do not own the lock.\n *\n * @type {{ownersByName: Map<string, VelociousDatabaseDriversSqliteBase>, waitersByName: Map<string, Array<() => void>>}}\n */\nVelociousDatabaseDriversSqliteBase._advisoryLockState = {\n  ownersByName: new Map(),\n  waitersByName: new Map()\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"table.d.ts","sourceRoot":"","sources":["../../../../../src/database/drivers/sqlite/table.js"],"names":[],"mappings":"AAOA;IACE;;;;OAIG;IACH,6BAHG;QAA2C,MAAM,EAAzC,OAAO,YAAY,EAAE,OAAO;QACiB,GAAG,EAAhD,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI,CAAC;KAChD,EAKA;IAFC,qCAAoB;IACpB,4CAAc;IAiBhB,wCAWC;IAED,sCA0BC;IAED;;;OAGG;IACH,0BAHW,MAAM,GACJ,MAAM,EAAE,CA4BpB;CAUF;sBAhHqB,kBAAkB;uBAGjB,kBAAkB;yBADhB,oBAAoB"}
1
+ {"version":3,"file":"table.d.ts","sourceRoot":"","sources":["../../../../../src/database/drivers/sqlite/table.js"],"names":[],"mappings":"AAOA;IACE;;;;OAIG;IACH,6BAHG;QAA2C,MAAM,EAAzC,OAAO,YAAY,EAAE,OAAO;QACiB,GAAG,EAAhD,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI,CAAC;KAChD,EAKA;IAFC,qCAAoB;IACpB,4CAAc;IAmBhB,wCAaC;IAED,sCA4BC;IAED;;;OAGG;IACH,0BAHW,MAAM,GACJ,MAAM,EAAE,CA4BpB;CAUF;sBAtHqB,kBAAkB;uBAGjB,kBAAkB;yBADhB,oBAAoB"}
@@ -16,42 +16,48 @@ export default class VelociousDatabaseDriversSqliteTable extends BaseTable {
16
16
  }
17
17
  /** @returns {Promise<Array<import("../base-column.js").default>>} - Resolves with the columns. */
18
18
  async getColumns() {
19
- const result = await this.driver.query(`PRAGMA table_info('${this.getName()}')`);
20
- const columns = [];
21
- for (const columnData of result) {
22
- const column = new Column({ column: columnData, driver: this.driver, table: this });
23
- columns.push(column);
24
- }
25
- return columns;
19
+ return await this.getDriver()._cachedTableSchemaMetadata(this.getName(), "columns", async () => {
20
+ const result = await this.driver.query(`PRAGMA table_info('${this.getName()}')`);
21
+ const columns = [];
22
+ for (const columnData of result) {
23
+ const column = new Column({ column: columnData, driver: this.driver, table: this });
24
+ columns.push(column);
25
+ }
26
+ return columns;
27
+ });
26
28
  }
27
29
  async getForeignKeys() {
28
- const foreignKeysData = await this.driver.query(`SELECT * FROM pragma_foreign_key_list(${this.driver.quote(this.getName())})`);
29
- const foreignKeys = [];
30
- for (const foreignKeyData of foreignKeysData) {
31
- const foreignKey = new ForeignKey(foreignKeyData, { tableName: this.getName() });
32
- foreignKeys.push(foreignKey);
33
- }
34
- return foreignKeys;
30
+ return await this.getDriver()._cachedTableSchemaMetadata(this.getName(), "foreignKeys", async () => {
31
+ const foreignKeysData = await this.driver.query(`SELECT * FROM pragma_foreign_key_list(${this.driver.quote(this.getName())})`);
32
+ const foreignKeys = [];
33
+ for (const foreignKeyData of foreignKeysData) {
34
+ const foreignKey = new ForeignKey(foreignKeyData, { tableName: this.getName() });
35
+ foreignKeys.push(foreignKey);
36
+ }
37
+ return foreignKeys;
38
+ });
35
39
  }
36
40
  async getIndexes() {
37
- const rows = await this.getDriver().query(`PRAGMA index_list(${this.getOptions().quoteTableName(this.getName())})`);
38
- const indexes = [];
39
- for (const row of rows) {
40
- const indexName = row.name;
41
- if (typeof indexName == "string" && indexName.startsWith("sqlite_autoindex_")) {
42
- // Skip SQLite internal auto indexes (e.g. primary key / unique constraints)
43
- continue;
41
+ return await this.getDriver()._cachedTableSchemaMetadata(this.getName(), "indexes", async () => {
42
+ const rows = await this.getDriver().query(`PRAGMA index_list(${this.getOptions().quoteTableName(this.getName())})`);
43
+ const indexes = [];
44
+ for (const row of rows) {
45
+ const indexName = row.name;
46
+ if (typeof indexName == "string" && indexName.startsWith("sqlite_autoindex_")) {
47
+ // Skip SQLite internal auto indexes (e.g. primary key / unique constraints)
48
+ continue;
49
+ }
50
+ const columnsIndex = new ColumnsIndex(this, row);
51
+ const indexMasterData = await this.getDriver().query(`SELECT * FROM sqlite_master WHERE type = 'index' AND name = ${this.getOptions().quote(columnsIndex.getName())}`);
52
+ const sql = indexMasterData[0]?.sql;
53
+ if (!sql)
54
+ throw new Error(`Could not find SQL for index ${columnsIndex.getName()}`);
55
+ const indexData = /** @type {typeof columnsIndex.data & {columnNames?: string[]}} */ (columnsIndex.data);
56
+ indexData.columnNames = this._parseColumnsFromSQL(String(sql));
57
+ indexes.push(columnsIndex);
44
58
  }
45
- const columnsIndex = new ColumnsIndex(this, row);
46
- const indexMasterData = await this.getDriver().query(`SELECT * FROM sqlite_master WHERE type = 'index' AND name = ${this.getOptions().quote(columnsIndex.getName())}`);
47
- const sql = indexMasterData[0]?.sql;
48
- if (!sql)
49
- throw new Error(`Could not find SQL for index ${columnsIndex.getName()}`);
50
- const indexData = /** @type {typeof columnsIndex.data & {columnNames?: string[]}} */ (columnsIndex.data);
51
- indexData.columnNames = this._parseColumnsFromSQL(String(sql));
52
- indexes.push(columnsIndex);
53
- }
54
- return indexes;
59
+ return indexes;
60
+ });
55
61
  }
56
62
  /**
57
63
  * @param {string} sql - SQL string.
@@ -89,4 +95,4 @@ export default class VelociousDatabaseDriversSqliteTable extends BaseTable {
89
95
  return String(this.row.name);
90
96
  }
91
97
  }
92
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.js","sourceRoot":"","sources":["../../../../../src/database/drivers/sqlite/table.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport BaseTable from \"../base-table.js\"\nimport Column from \"./column.js\"\nimport ColumnsIndex from \"./columns-index.js\"\nimport ForeignKey from \"./foreign-key.js\"\n\nexport default class VelociousDatabaseDriversSqliteTable extends BaseTable {\n  /**\n   * @param {object} args - Options object.\n   * @param {import(\"../base.js\").default} args.driver - Database driver instance.\n   * @param {Record<string, string | number | null>} args.row - Row data.\n   */\n  constructor({driver, row}) {\n    super()\n    this.driver = driver\n    this.row = row\n  }\n\n  /** @returns {Promise<Array<import(\"../base-column.js\").default>>} - Resolves with the columns.  */\n  async getColumns() {\n    const result = await this.driver.query(`PRAGMA table_info('${this.getName()}')`)\n    const columns = []\n\n    for (const columnData of result) {\n      const column = new Column({column: columnData, driver: this.driver, table: this})\n\n      columns.push(column)\n    }\n\n    return columns\n  }\n\n  async getForeignKeys() {\n    const foreignKeysData = await this.driver.query(`SELECT * FROM pragma_foreign_key_list(${this.driver.quote(this.getName())})`)\n    const foreignKeys = []\n\n    for (const foreignKeyData of foreignKeysData) {\n      const foreignKey = new ForeignKey(foreignKeyData, {tableName: this.getName()})\n\n      foreignKeys.push(foreignKey)\n    }\n\n    return foreignKeys\n  }\n\n  async getIndexes() {\n    const rows = await this.getDriver().query(`PRAGMA index_list(${this.getOptions().quoteTableName(this.getName())})`)\n    const indexes = []\n\n    for (const row of rows) {\n      const indexName = row.name\n\n      if (typeof indexName == \"string\" && indexName.startsWith(\"sqlite_autoindex_\")) {\n        // Skip SQLite internal auto indexes (e.g. primary key / unique constraints)\n        continue\n      }\n\n      const columnsIndex = new ColumnsIndex(this, row)\n      const indexMasterData = await this.getDriver().query(`SELECT * FROM sqlite_master WHERE type = 'index' AND name = ${this.getOptions().quote(columnsIndex.getName())}`)\n      const sql = indexMasterData[0]?.sql\n\n      if (!sql) throw new Error(`Could not find SQL for index ${columnsIndex.getName()}`)\n\n      const indexData = /** @type {typeof columnsIndex.data & {columnNames?: string[]}} */ (columnsIndex.data)\n\n      indexData.columnNames = this._parseColumnsFromSQL(String(sql))\n\n      indexes.push(columnsIndex)\n    }\n\n    return indexes\n  }\n\n  /**\n   * @param {string} sql - SQL string.\n   * @returns {string[]} - SQL statements.\n   */\n  _parseColumnsFromSQL(sql) {\n    if (!sql) throw new Error(`Invalid SQL given (${typeof sql}): ${sql}`)\n\n    const columnsSQLMatch = sql.match(/\\((.+?)\\)/)\n\n    if (!columnsSQLMatch) {\n      throw new Error(`Could not match columns from SQL: ${sql}`)\n    }\n\n    const columnsSQL = columnsSQLMatch[1].split(\",\")\n    const columnNames = []\n\n    for (const column of columnsSQL) {\n      const matchTicks = column.match(/`(.+)`/)\n      const matchQuotes = column.match(/\"(.+)\"/)\n\n      if (matchTicks) {\n        columnNames.push(matchTicks[1])\n      } else if (matchQuotes) {\n        columnNames.push(matchQuotes[1])\n      } else{\n        throw new Error(`Couldn't parse column part: ${column}`)\n      }\n    }\n\n    return columnNames\n  }\n\n  /** @returns {string} - The table name. */\n  getName() {\n    if (!this.row.name) {\n      throw new Error(\"No name given for SQLite table\")\n    }\n\n    return String(this.row.name)\n  }\n}\n"]}
98
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.js","sourceRoot":"","sources":["../../../../../src/database/drivers/sqlite/table.js"],"names":[],"mappings":"AAAA,YAAY;AAEZ,OAAO,SAAS,MAAM,kBAAkB,CAAA;AACxC,OAAO,MAAM,MAAM,aAAa,CAAA;AAChC,OAAO,YAAY,MAAM,oBAAoB,CAAA;AAC7C,OAAO,UAAU,MAAM,kBAAkB,CAAA;AAEzC,MAAM,CAAC,OAAO,OAAO,mCAAoC,SAAQ,SAAS;IACxE;;;;OAIG;IACH,YAAY,EAAC,MAAM,EAAE,GAAG,EAAC;QACvB,KAAK,EAAE,CAAA;QACP,IAAI,CAAC,MAAM,GAAG,MAAM,CAAA;QACpB,IAAI,CAAC,GAAG,GAAG,GAAG,CAAA;IAChB,CAAC;IAED,mGAAmG;IACnG,KAAK,CAAC,UAAU;QACd,OAAO,MAAM,IAAI,CAAC,SAAS,EAAE,CAAC,0BAA0B,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,SAAS,EAAE,KAAK,IAAI,EAAE;YAC7F,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,sBAAsB,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,CAAA;YAChF,MAAM,OAAO,GAAG,EAAE,CAAA;YAElB,KAAK,MAAM,UAAU,IAAI,MAAM,EAAE,CAAC;gBAChC,MAAM,MAAM,GAAG,IAAI,MAAM,CAAC,EAAC,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,KAAK,EAAE,IAAI,EAAC,CAAC,CAAA;gBAEjF,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;YACtB,CAAC;YAED,OAAO,OAAO,CAAA;QAChB,CAAC,CAAC,CAAA;IACJ,CAAC;IAED,KAAK,CAAC,cAAc;QAClB,OAAO,MAAM,IAAI,CAAC,SAAS,EAAE,CAAC,0BAA0B,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,aAAa,EAAE,KAAK,IAAI,EAAE;YACjG,MAAM,eAAe,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,yCAAyC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,GAAG,CAAC,CAAA;YAC9H,MAAM,WAAW,GAAG,EAAE,CAAA;YAEtB,KAAK,MAAM,cAAc,IAAI,eAAe,EAAE,CAAC;gBAC7C,MAAM,UAAU,GAAG,IAAI,UAAU,CAAC,cAAc,EAAE,EAAC,SAAS,EAAE,IAAI,CAAC,OAAO,EAAE,EAAC,CAAC,CAAA;gBAE9E,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,CAAA;YAC9B,CAAC;YAED,OAAO,WAAW,CAAA;QACpB,CAAC,CAAC,CAAA;IACJ,CAAC;IAED,KAAK,CAAC,UAAU;QACd,OAAO,MAAM,IAAI,CAAC,SAAS,EAAE,CAAC,0BAA0B,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,SAAS,EAAE,KAAK,IAAI,EAAE;YAC7F,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,SAAS,EAAE,CAAC,KAAK,CAAC,qBAAqB,IAAI,CAAC,UAAU,EAAE,CAAC,cAAc,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,GAAG,CAAC,CAAA;YACnH,MAAM,OAAO,GAAG,EAAE,CAAA;YAElB,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE,CAAC;gBACvB,MAAM,SAAS,GAAG,GAAG,CAAC,IAAI,CAAA;gBAE1B,IAAI,OAAO,SAAS,IAAI,QAAQ,IAAI,SAAS,CAAC,UAAU,CAAC,mBAAmB,CAAC,EAAE,CAAC;oBAC9E,4EAA4E;oBAC5E,SAAQ;gBACV,CAAC;gBAED,MAAM,YAAY,GAAG,IAAI,YAAY,CAAC,IAAI,EAAE,GAAG,CAAC,CAAA;gBAChD,MAAM,eAAe,GAAG,MAAM,IAAI,CAAC,SAAS,EAAE,CAAC,KAAK,CAAC,+DAA+D,IAAI,CAAC,UAAU,EAAE,CAAC,KAAK,CAAC,YAAY,CAAC,OAAO,EAAE,CAAC,EAAE,CAAC,CAAA;gBACtK,MAAM,GAAG,GAAG,eAAe,CAAC,CAAC,CAAC,EAAE,GAAG,CAAA;gBAEnC,IAAI,CAAC,GAAG;oBAAE,MAAM,IAAI,KAAK,CAAC,gCAAgC,YAAY,CAAC,OAAO,EAAE,EAAE,CAAC,CAAA;gBAEnF,MAAM,SAAS,GAAG,kEAAkE,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,CAAA;gBAExG,SAAS,CAAC,WAAW,GAAG,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAA;gBAE9D,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,CAAA;YAC5B,CAAC;YAED,OAAO,OAAO,CAAA;QAChB,CAAC,CAAC,CAAA;IACJ,CAAC;IAED;;;OAGG;IACH,oBAAoB,CAAC,GAAG;QACtB,IAAI,CAAC,GAAG;YAAE,MAAM,IAAI,KAAK,CAAC,sBAAsB,OAAO,GAAG,MAAM,GAAG,EAAE,CAAC,CAAA;QAEtE,MAAM,eAAe,GAAG,GAAG,CAAC,KAAK,CAAC,WAAW,CAAC,CAAA;QAE9C,IAAI,CAAC,eAAe,EAAE,CAAC;YACrB,MAAM,IAAI,KAAK,CAAC,qCAAqC,GAAG,EAAE,CAAC,CAAA;QAC7D,CAAC;QAED,MAAM,UAAU,GAAG,eAAe,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;QAChD,MAAM,WAAW,GAAG,EAAE,CAAA;QAEtB,KAAK,MAAM,MAAM,IAAI,UAAU,EAAE,CAAC;YAChC,MAAM,UAAU,GAAG,MAAM,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAA;YACzC,MAAM,WAAW,GAAG,MAAM,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAA;YAE1C,IAAI,UAAU,EAAE,CAAC;gBACf,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAA;YACjC,CAAC;iBAAM,IAAI,WAAW,EAAE,CAAC;gBACvB,WAAW,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAA;YAClC,CAAC;iBAAK,CAAC;gBACL,MAAM,IAAI,KAAK,CAAC,+BAA+B,MAAM,EAAE,CAAC,CAAA;YAC1D,CAAC;QACH,CAAC;QAED,OAAO,WAAW,CAAA;IACpB,CAAC;IAED,0CAA0C;IAC1C,OAAO;QACL,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC;YACnB,MAAM,IAAI,KAAK,CAAC,gCAAgC,CAAC,CAAA;QACnD,CAAC;QAED,OAAO,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAA;IAC9B,CAAC;CACF","sourcesContent":["// @ts-check\n\nimport BaseTable from \"../base-table.js\"\nimport Column from \"./column.js\"\nimport ColumnsIndex from \"./columns-index.js\"\nimport ForeignKey from \"./foreign-key.js\"\n\nexport default class VelociousDatabaseDriversSqliteTable extends BaseTable {\n  /**\n   * @param {object} args - Options object.\n   * @param {import(\"../base.js\").default} args.driver - Database driver instance.\n   * @param {Record<string, string | number | null>} args.row - Row data.\n   */\n  constructor({driver, row}) {\n    super()\n    this.driver = driver\n    this.row = row\n  }\n\n  /** @returns {Promise<Array<import(\"../base-column.js\").default>>} - Resolves with the columns.  */\n  async getColumns() {\n    return await this.getDriver()._cachedTableSchemaMetadata(this.getName(), \"columns\", async () => {\n      const result = await this.driver.query(`PRAGMA table_info('${this.getName()}')`)\n      const columns = []\n\n      for (const columnData of result) {\n        const column = new Column({column: columnData, driver: this.driver, table: this})\n\n        columns.push(column)\n      }\n\n      return columns\n    })\n  }\n\n  async getForeignKeys() {\n    return await this.getDriver()._cachedTableSchemaMetadata(this.getName(), \"foreignKeys\", async () => {\n      const foreignKeysData = await this.driver.query(`SELECT * FROM pragma_foreign_key_list(${this.driver.quote(this.getName())})`)\n      const foreignKeys = []\n\n      for (const foreignKeyData of foreignKeysData) {\n        const foreignKey = new ForeignKey(foreignKeyData, {tableName: this.getName()})\n\n        foreignKeys.push(foreignKey)\n      }\n\n      return foreignKeys\n    })\n  }\n\n  async getIndexes() {\n    return await this.getDriver()._cachedTableSchemaMetadata(this.getName(), \"indexes\", async () => {\n      const rows = await this.getDriver().query(`PRAGMA index_list(${this.getOptions().quoteTableName(this.getName())})`)\n      const indexes = []\n\n      for (const row of rows) {\n        const indexName = row.name\n\n        if (typeof indexName == \"string\" && indexName.startsWith(\"sqlite_autoindex_\")) {\n          // Skip SQLite internal auto indexes (e.g. primary key / unique constraints)\n          continue\n        }\n\n        const columnsIndex = new ColumnsIndex(this, row)\n        const indexMasterData = await this.getDriver().query(`SELECT * FROM sqlite_master WHERE type = 'index' AND name = ${this.getOptions().quote(columnsIndex.getName())}`)\n        const sql = indexMasterData[0]?.sql\n\n        if (!sql) throw new Error(`Could not find SQL for index ${columnsIndex.getName()}`)\n\n        const indexData = /** @type {typeof columnsIndex.data & {columnNames?: string[]}} */ (columnsIndex.data)\n\n        indexData.columnNames = this._parseColumnsFromSQL(String(sql))\n\n        indexes.push(columnsIndex)\n      }\n\n      return indexes\n    })\n  }\n\n  /**\n   * @param {string} sql - SQL string.\n   * @returns {string[]} - SQL statements.\n   */\n  _parseColumnsFromSQL(sql) {\n    if (!sql) throw new Error(`Invalid SQL given (${typeof sql}): ${sql}`)\n\n    const columnsSQLMatch = sql.match(/\\((.+?)\\)/)\n\n    if (!columnsSQLMatch) {\n      throw new Error(`Could not match columns from SQL: ${sql}`)\n    }\n\n    const columnsSQL = columnsSQLMatch[1].split(\",\")\n    const columnNames = []\n\n    for (const column of columnsSQL) {\n      const matchTicks = column.match(/`(.+)`/)\n      const matchQuotes = column.match(/\"(.+)\"/)\n\n      if (matchTicks) {\n        columnNames.push(matchTicks[1])\n      } else if (matchQuotes) {\n        columnNames.push(matchQuotes[1])\n      } else{\n        throw new Error(`Couldn't parse column part: ${column}`)\n      }\n    }\n\n    return columnNames\n  }\n\n  /** @returns {string} - The table name. */\n  getName() {\n    if (!this.row.name) {\n      throw new Error(\"No name given for SQLite table\")\n    }\n\n    return String(this.row.name)\n  }\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"async-tracked-multi-connection.d.ts","sourceRoot":"","sources":["../../../../src/database/pool/async-tracked-multi-connection.js"],"names":[],"mappings":"AAKA,8CAAoE;AAEpE;IACE;;;OAGG;IACH,0BAFU,OAAO,CAAC,OAAO,wBAAwB,EAAE,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,oBAAoB,EAAE,OAAO,CAAC,CAAC,CAEzE;IA6NxC;;;;;OAKG;IACH,0CAJW,MAAM,CAAC,MAAM,EAAE,OAAO,oBAAoB,EAAE,OAAO,CAAC,kBACpD,OAAO,wBAAwB,EAAE,OAAO,GACtC,IAAI,CAchB;IAED;;;;OAIG;IACH,8CAHW,OAAO,wBAAwB,EAAE,OAAO,GACtC,IAAI,CAShB;IA3PD,0CAA2C;IAE3C;;;;;OAKG;IACH,uBAFU,OAAO,oBAAoB,EAAE,OAAO,GAAG,SAAS,CAEzB;IAEjC,qDAAqD;IACrD,aADW,OAAO,oBAAoB,EAAE,OAAO,EAAE,CACjC;IAEhB,mEAAmE;IACnE,kBADW,MAAM,CAAC,MAAM,EAAE,OAAO,oBAAoB,EAAE,OAAO,CAAC,CAC1C;IAErB,cAAS;IAiGT;;;;OAIG;IACH,gCAHW,OAAO,oBAAoB,EAAE,OAAO,GAClC,IAAI,CAYhB;IAoBD;;;;;OAKG;IACH,oCAHW,OAAO,oBAAoB,EAAE,OAAO,GAClC,IAAI,CAIhB;IAED,sBAAsB;IACtB,6BADc,IAAI,CAGjB;IAeD;;OAEG;IACH,uBAFa,OAAO,oBAAoB,EAAE,OAAO,GAAG,SAAS,CAW5D;CAgEF;qBAvQoB,WAAW;kCADA,aAAa"}
1
+ {"version":3,"file":"async-tracked-multi-connection.d.ts","sourceRoot":"","sources":["../../../../src/database/pool/async-tracked-multi-connection.js"],"names":[],"mappings":"AAKA,8CAAoE;AAEpE;IACE;;;OAGG;IACH,0BAFU,OAAO,CAAC,OAAO,wBAAwB,EAAE,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,oBAAoB,EAAE,OAAO,CAAC,CAAC,CAEzE;IA8OxC;;;;;OAKG;IACH,0CAJW,MAAM,CAAC,MAAM,EAAE,OAAO,oBAAoB,EAAE,OAAO,CAAC,kBACpD,OAAO,wBAAwB,EAAE,OAAO,GACtC,IAAI,CAchB;IAED;;;;OAIG;IACH,8CAHW,OAAO,wBAAwB,EAAE,OAAO,GACtC,IAAI,CAShB;IA5QD,0CAA2C;IAE3C;;;;;OAKG;IACH,uBAFU,OAAO,oBAAoB,EAAE,OAAO,GAAG,SAAS,CAEzB;IAEjC,qDAAqD;IACrD,aADW,OAAO,oBAAoB,EAAE,OAAO,EAAE,CACjC;IAEhB,mEAAmE;IACnE,kBADW,MAAM,CAAC,MAAM,EAAE,OAAO,oBAAoB,EAAE,OAAO,CAAC,CAC1C;IAErB,cAAS;IAiGT;;;;OAIG;IACH,gCAHW,OAAO,oBAAoB,EAAE,OAAO,GAClC,IAAI,CAYhB;IAoBD;;;;;OAKG;IACH,oCAHW,OAAO,oBAAoB,EAAE,OAAO,GAClC,IAAI,CAIhB;IAED,sBAAsB;IACtB,6BADc,IAAI,CAGjB;IAeD;;OAEG;IACH,uBAFa,OAAO,oBAAoB,EAAE,OAAO,GAAG,SAAS,CAW5D;CAiFF;qBAxRoB,WAAW;kCADA,aAAa"}