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.
- package/README.md +28 -0
- package/build/src/configuration-types.d.ts +5 -0
- package/build/src/configuration-types.d.ts.map +1 -1
- package/build/src/configuration-types.js +2 -1
- package/build/src/configuration.d.ts +4 -0
- package/build/src/configuration.d.ts.map +1 -1
- package/build/src/configuration.js +20 -2
- package/build/src/database/drivers/base.d.ts +48 -0
- package/build/src/database/drivers/base.d.ts.map +1 -1
- package/build/src/database/drivers/base.js +117 -3
- package/build/src/database/drivers/mssql/index.d.ts.map +1 -1
- package/build/src/database/drivers/mssql/index.js +15 -34
- package/build/src/database/drivers/mssql/table.d.ts.map +1 -1
- package/build/src/database/drivers/mssql/table.js +79 -73
- package/build/src/database/drivers/mysql/index.d.ts.map +1 -1
- package/build/src/database/drivers/mysql/index.js +11 -9
- package/build/src/database/drivers/mysql/table.d.ts.map +1 -1
- package/build/src/database/drivers/mysql/table.js +61 -55
- package/build/src/database/drivers/pgsql/index.d.ts.map +1 -1
- package/build/src/database/drivers/pgsql/index.js +11 -9
- package/build/src/database/drivers/pgsql/table.d.ts.map +1 -1
- package/build/src/database/drivers/pgsql/table.js +80 -74
- package/build/src/database/drivers/sqlite/base.d.ts.map +1 -1
- package/build/src/database/drivers/sqlite/base.js +11 -27
- package/build/src/database/drivers/sqlite/table.d.ts.map +1 -1
- package/build/src/database/drivers/sqlite/table.js +38 -32
- package/build/src/database/pool/async-tracked-multi-connection.d.ts.map +1 -1
- package/build/src/database/pool/async-tracked-multi-connection.js +17 -1
- package/build/src/database/pool/base.d.ts +11 -0
- package/build/src/database/pool/base.d.ts.map +1 -1
- package/build/src/database/pool/base.js +18 -1
- package/build/src/database/pool/single-multi-use.d.ts.map +1 -1
- package/build/src/database/pool/single-multi-use.js +9 -1
- package/build/src/environment-handlers/base.d.ts +4 -0
- package/build/src/environment-handlers/base.d.ts.map +1 -1
- package/build/src/environment-handlers/base.js +7 -1
- package/build/src/environment-handlers/node/cli/commands/generate/base-models.js +2 -2
- package/build/src/environment-handlers/node.d.ts.map +1 -1
- package/build/src/environment-handlers/node.js +8 -1
- package/build/src/http-server/client/request-runner.js +2 -2
- package/build/src/testing/test-runner.js +2 -2
- package/build/src/utils/backtrace-cleaner-node.d.ts +5 -0
- package/build/src/utils/backtrace-cleaner-node.d.ts.map +1 -0
- package/build/src/utils/backtrace-cleaner-node.js +75 -0
- package/build/src/utils/backtrace-cleaner.d.ts +11 -1
- package/build/src/utils/backtrace-cleaner.d.ts.map +1 -1
- package/build/src/utils/backtrace-cleaner.js +13 -21
- package/build/tsconfig.tsbuildinfo +1 -1
- package/package.json +1 -1
|
@@ -86,6 +86,10 @@ export default class VelociousDatabaseDriversBase {
|
|
|
86
86
|
idSeq = undefined;
|
|
87
87
|
/** @type {Array<Array<() => void | Promise<void>>>} */
|
|
88
88
|
_afterCommitCallbackFrames;
|
|
89
|
+
/** @type {Map<string, Promise<unknown>>} */
|
|
90
|
+
_schemaCache;
|
|
91
|
+
/** @type {(() => void) | undefined} */
|
|
92
|
+
_schemaCacheInvalidator;
|
|
89
93
|
/**
|
|
90
94
|
* @param {import("../../configuration-types.js").DatabaseConfigurationType} config - Configuration object.
|
|
91
95
|
* @param {import("../../configuration.js").default} configuration - Configuration instance.
|
|
@@ -98,6 +102,7 @@ export default class VelociousDatabaseDriversBase {
|
|
|
98
102
|
this._afterCommitCallbackFrames = [];
|
|
99
103
|
this._transactionsCount = 0;
|
|
100
104
|
this._transactionsActionsMutex = new Mutex();
|
|
105
|
+
this._schemaCache = new Map();
|
|
101
106
|
}
|
|
102
107
|
/**
|
|
103
108
|
* @param {string} tableName - Table name.
|
|
@@ -156,6 +161,7 @@ export default class VelociousDatabaseDriversBase {
|
|
|
156
161
|
* @returns {Promise<void>} - Resolves when complete.
|
|
157
162
|
*/
|
|
158
163
|
async reconnect() {
|
|
164
|
+
this.clearSchemaCache();
|
|
159
165
|
await this.close();
|
|
160
166
|
await this.connect();
|
|
161
167
|
}
|
|
@@ -270,6 +276,81 @@ export default class VelociousDatabaseDriversBase {
|
|
|
270
276
|
getIdSeq() {
|
|
271
277
|
return this.idSeq;
|
|
272
278
|
}
|
|
279
|
+
/**
|
|
280
|
+
* Clears cached schema metadata for this driver instance.
|
|
281
|
+
* @returns {void} - No return value.
|
|
282
|
+
*/
|
|
283
|
+
clearSchemaCache() {
|
|
284
|
+
if (this._schemaCacheInvalidator) {
|
|
285
|
+
this._schemaCacheInvalidator();
|
|
286
|
+
return;
|
|
287
|
+
}
|
|
288
|
+
this._clearLocalSchemaCache();
|
|
289
|
+
}
|
|
290
|
+
/**
|
|
291
|
+
* Clears only the metadata cached on this driver instance.
|
|
292
|
+
* @returns {void} - No return value.
|
|
293
|
+
*/
|
|
294
|
+
_clearLocalSchemaCache() {
|
|
295
|
+
this._schemaCache.clear();
|
|
296
|
+
}
|
|
297
|
+
/**
|
|
298
|
+
* @param {() => void} invalidator - Callback used to clear schema caches that share this driver pool.
|
|
299
|
+
* @returns {void} - No return value.
|
|
300
|
+
*/
|
|
301
|
+
setSchemaCacheInvalidator(invalidator) {
|
|
302
|
+
this._schemaCacheInvalidator = invalidator;
|
|
303
|
+
}
|
|
304
|
+
/**
|
|
305
|
+
* @returns {boolean} - Whether schema metadata caching is enabled.
|
|
306
|
+
*/
|
|
307
|
+
_schemaCacheEnabled() {
|
|
308
|
+
return this.getArgs().schemaCache !== false;
|
|
309
|
+
}
|
|
310
|
+
/**
|
|
311
|
+
* @template T
|
|
312
|
+
* @param {string} cacheKey - Schema cache key.
|
|
313
|
+
* @param {() => Promise<T>} callback - Cache miss callback.
|
|
314
|
+
* @returns {Promise<T>} - Resolves with the cached metadata.
|
|
315
|
+
*/
|
|
316
|
+
async _cachedSchemaMetadata(cacheKey, callback) {
|
|
317
|
+
if (!this._schemaCacheEnabled())
|
|
318
|
+
return await callback();
|
|
319
|
+
const existingPromise = this._schemaCache.get(cacheKey);
|
|
320
|
+
if (existingPromise) {
|
|
321
|
+
return /** @type {T} */ (this._schemaCacheReturnValue(await existingPromise));
|
|
322
|
+
}
|
|
323
|
+
const promise = (async () => await callback())();
|
|
324
|
+
this._schemaCache.set(cacheKey, promise);
|
|
325
|
+
try {
|
|
326
|
+
return /** @type {T} */ (this._schemaCacheReturnValue(await promise));
|
|
327
|
+
}
|
|
328
|
+
catch (error) {
|
|
329
|
+
if (this._schemaCache.get(cacheKey) === promise) {
|
|
330
|
+
this._schemaCache.delete(cacheKey);
|
|
331
|
+
}
|
|
332
|
+
throw error;
|
|
333
|
+
}
|
|
334
|
+
}
|
|
335
|
+
/**
|
|
336
|
+
* @template T
|
|
337
|
+
* @param {string} tableName - Table name.
|
|
338
|
+
* @param {string} metadataName - Metadata name.
|
|
339
|
+
* @param {() => Promise<T>} callback - Cache miss callback.
|
|
340
|
+
* @returns {Promise<T>} - Resolves with the cached table metadata.
|
|
341
|
+
*/
|
|
342
|
+
async _cachedTableSchemaMetadata(tableName, metadataName, callback) {
|
|
343
|
+
return await this._cachedSchemaMetadata(`table:${tableName}:${metadataName}`, callback);
|
|
344
|
+
}
|
|
345
|
+
/**
|
|
346
|
+
* @param {unknown} value - Cached value.
|
|
347
|
+
* @returns {unknown} - Value returned to callers.
|
|
348
|
+
*/
|
|
349
|
+
_schemaCacheReturnValue(value) {
|
|
350
|
+
if (Array.isArray(value))
|
|
351
|
+
return value.slice();
|
|
352
|
+
return value;
|
|
353
|
+
}
|
|
273
354
|
/**
|
|
274
355
|
* @abstract
|
|
275
356
|
* @returns {Promise<Array<import("./base-table.js").default>>} - Resolves with the tables.
|
|
@@ -685,8 +766,35 @@ export default class VelociousDatabaseDriversBase {
|
|
|
685
766
|
sql
|
|
686
767
|
});
|
|
687
768
|
}
|
|
769
|
+
if (this._schemaCacheInvalidatingSql(sql)) {
|
|
770
|
+
this.clearSchemaCache();
|
|
771
|
+
}
|
|
688
772
|
return result;
|
|
689
773
|
}
|
|
774
|
+
/**
|
|
775
|
+
* @param {string} sql - SQL string.
|
|
776
|
+
* @returns {boolean} - Whether the SQL should invalidate schema metadata.
|
|
777
|
+
*/
|
|
778
|
+
_schemaCacheInvalidatingSql(sql) {
|
|
779
|
+
const normalized = sql
|
|
780
|
+
.trim()
|
|
781
|
+
.replace(/^\ufeff/, "")
|
|
782
|
+
.replace(/\/\*[\s\S]*?\*\//g, " ")
|
|
783
|
+
.replace(/--[^\n]*(\n|$)/g, " ")
|
|
784
|
+
.replace(/\s+/g, " ")
|
|
785
|
+
.toLowerCase();
|
|
786
|
+
if (!normalized)
|
|
787
|
+
return false;
|
|
788
|
+
if (/^(create|alter|drop|rename)\b/.test(normalized))
|
|
789
|
+
return true;
|
|
790
|
+
if (/^comment\s+on\b/.test(normalized))
|
|
791
|
+
return true;
|
|
792
|
+
if (/^exec(?:ute)?\s+sp_rename\b/.test(normalized))
|
|
793
|
+
return true;
|
|
794
|
+
if (/^if\b[\s\S]*\bbegin\s+(create|alter|drop|rename)\b/.test(normalized))
|
|
795
|
+
return true;
|
|
796
|
+
return false;
|
|
797
|
+
}
|
|
690
798
|
/**
|
|
691
799
|
* @returns {boolean} - Whether query logging is enabled for this driver.
|
|
692
800
|
*/
|
|
@@ -719,12 +827,18 @@ export default class VelociousDatabaseDriversBase {
|
|
|
719
827
|
* @returns {string | undefined} - Source line when an application frame is available.
|
|
720
828
|
*/
|
|
721
829
|
_querySourceLine(sourceStack) {
|
|
722
|
-
if (!sourceStack
|
|
830
|
+
if (!sourceStack)
|
|
831
|
+
return undefined;
|
|
832
|
+
const applicationDirectory = typeof this.configuration?.getDirectoryIfAvailable === "function"
|
|
833
|
+
? this.configuration.getDirectoryIfAvailable()
|
|
834
|
+
: this.configuration?.getDirectory?.();
|
|
835
|
+
if (!applicationDirectory)
|
|
723
836
|
return undefined;
|
|
724
837
|
const error = new Error("Query source");
|
|
725
838
|
error.stack = sourceStack;
|
|
726
839
|
return BacktraceCleaner.getApplicationSourceLine(error, {
|
|
727
|
-
applicationDirectory
|
|
840
|
+
applicationDirectory,
|
|
841
|
+
frameworkSourceDirectory: this.configuration.getEnvironmentHandler().getFrameworkSourceDirectory()
|
|
728
842
|
});
|
|
729
843
|
}
|
|
730
844
|
/**
|
|
@@ -1042,4 +1156,4 @@ export default class VelociousDatabaseDriversBase {
|
|
|
1042
1156
|
throw new Error(`'isAdvisoryLockHeld' not implemented for ${this.constructor.name}`);
|
|
1043
1157
|
}
|
|
1044
1158
|
}
|
|
1045
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base.js","sourceRoot":"","sources":["../../../../src/database/drivers/base.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\n/**\n * @typedef {object} CreateIndexSqlArgs\n * @property {Array<string | import(\"./../table-data/table-column.js\").default>} columns - Columns to include in the index.\n * @property {boolean} [ifNotExists] - Skip creation if the index already exists.\n * @property {string} [name] - Explicit index name to use.\n * @property {boolean} [unique] - Whether the index should enforce uniqueness.\n * @property {string} tableName - Name of the table to add the index to.\n */\n/**\n * @typedef {object} DropTableSqlArgsType\n * @property {boolean} [cascade] - Whether dependent objects should be dropped too.\n * @property {boolean} [ifExists] - Skip dropping if the table does not exist.\n */\n/**\n * @typedef {object} DeleteSqlArgsType\n * @property {string} tableName - Table name to delete from.\n * @property {{[key: string]: any}} conditions - Conditions used to build the delete WHERE clause.\n */\n/**\n * @typedef {object} InsertSqlArgsType\n * @property {string[]} [columns] - Column names for `rows` inserts.\n * @property {{[key: string]: any}} [data] - Column/value pairs for a single-row insert.\n * @property {boolean} [multiple] - Whether this insert should be treated as multi-row.\n * @property {string[]} [returnLastInsertedColumnNames] - Column names to return after insert.\n * @property {Array<Array<any>>} [rows] - Row values for a multi-row insert.\n * @property {string} tableName - Table name to insert into.\n */\n/**\n * @typedef {Record<string, any>} QueryRowType\n * @typedef {Array<QueryRowType>} QueryResultType\n */\n/**\n * @typedef {object} RetryableDatabaseErrorResult\n * @property {boolean} retry - Whether the error should be retried.\n * @property {boolean} reconnect - Whether to reconnect before retrying.\n * @property {number} [maxTries] - Override the max retry attempts.\n * @property {number} [waitMs] - Wait time before retrying in milliseconds.\n */\n/**\n * @typedef {object} QueryOptions\n * @property {string} [logName] - Query log subject.\n * @property {boolean} [logQuery] - Whether to log the query.\n * @property {string} [sourceStack] - Stack captured at the caller boundary.\n */\n/**\n * @typedef {object}UpdateSqlArgsType\n * @property {object} conditions - Conditions used to build the update WHERE clause.\n * @property {object} data - Column/value pairs to update.\n * @property {string} tableName - Table name to update.\n */\n/**\n * @typedef {object}UpsertSqlArgsType\n * @property {string[]} conflictColumns - Columns that define a conflict.\n * @property {object} data - Column/value pairs to insert.\n * @property {string} tableName - Table name to upsert into.\n * @property {string[]} updateColumns - Columns to update on conflict.\n */\n\nimport BacktraceCleaner from \"../../utils/backtrace-cleaner.js\"\nimport Logger from \"../../logger.js\"\nimport Query from \"../query/index.js\"\nimport Handler from \"../handler.js\"\nimport Mutex from \"epic-locks/build/mutex.js\"\nimport strftime from \"strftime\"\nimport UUID from \"pure-uuid\"\nimport TableData from \"../table-data/index.js\"\nimport TableColumn from \"../table-data/table-column.js\"\nimport TableForeignKey from \"../table-data/table-foreign-key.js\"\nimport wait from \"awaitery/build/wait.js\"\n\n/** @returns {number} - Current high-resolution-ish timestamp in milliseconds. */\nfunction nowMs() {\n  if (globalThis.performance && typeof globalThis.performance.now == \"function\") {\n    return globalThis.performance.now()\n  }\n\n  return Date.now()\n}\n\n/**\n * @param {number} elapsedMs - Elapsed milliseconds.\n * @returns {string} - Formatted elapsed milliseconds.\n */\nfunction formatElapsedMs(elapsedMs) {\n  return `${Math.max(elapsedMs, 0).toFixed(1)}ms`\n}\n\nexport default class VelociousDatabaseDriversBase {\n  /** @type {number | undefined} */\n  idSeq = undefined\n  /** @type {Array<Array<() => void | Promise<void>>>} */\n  _afterCommitCallbackFrames\n\n  /**\n   * @param {import(\"../../configuration-types.js\").DatabaseConfigurationType} config - Configuration object.\n   * @param {import(\"../../configuration.js\").default} configuration - Configuration instance.\n   */\n  constructor(config, configuration) {\n    this._args = config\n    this.configuration = configuration\n    this.mutex = new Mutex() // Can be used to lock this instance for exclusive use\n    this.logger = new Logger(this)\n    this._afterCommitCallbackFrames = []\n    this._transactionsCount = 0\n    this._transactionsActionsMutex = new Mutex()\n  }\n\n  /**\n   * @param {string} tableName - Table name.\n   * @param {string} columnName - Column name.\n   * @param {string} referencedTableName - Referenced table name.\n   * @param {string} referencedColumnName - Referenced column name.\n   * @param {object} args - Options object.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async addForeignKey(tableName, columnName, referencedTableName, referencedColumnName, args) {\n    this._assertNotReadOnly()\n    const tableForeignKeyArgs = Object.assign(\n      {\n        columnName,\n        tableName,\n        referencedColumnName,\n        referencedTableName\n      },\n      args\n    )\n    const tableForeignKey = new TableForeignKey(tableForeignKeyArgs)\n    const tableData = new TableData(tableName)\n\n    tableData.addForeignKey(tableForeignKey)\n\n    const alterTableSQLs = await this.alterTableSQLs(tableData)\n\n    for (const alterTableSQL of alterTableSQLs) {\n      await this.query(alterTableSQL)\n    }\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  alterTableSQLs(_tableData) { // eslint-disable-line no-unused-vars\n    throw new Error(\"alterTableSQLs not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  connect() {\n    throw new Error(\"'connect' not implemented\")\n  }\n\n  /**\n   * Optional close hook for database drivers.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async close() {\n    // No-op by default\n  }\n\n  /**\n   * Optional disconnect hook for database drivers.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async disconnect() {\n    // No-op by default\n  }\n\n  /**\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async reconnect() {\n    await this.close()\n    await this.connect()\n  }\n\n  /**\n   * @abstract\n   * @param {string} databaseName - Database name.\n   * @param {object} [args] - Options object.\n   * @param {boolean} [args.ifNotExists] - Whether if not exists.\n   * @param {string} [args.databaseCharset] - Database-default character set (driver-specific; mysql/mariadb).\n   * @param {string} [args.databaseCollation] - Database-default collation (driver-specific; mysql/mariadb).\n   * @returns {string[]} - SQL statements.\n   */\n  createDatabaseSql(databaseName, args) { throw new Error(\"'createDatabaseSql' not implemented\") } // eslint-disable-line no-unused-vars\n\n  /**\n   * @abstract\n   * @param {string} databaseName - Database name.\n   * @param {object} [args] - Options object.\n   * @param {boolean} [args.ifExists] - Whether if exists.\n   * @returns {string[]} - SQL statements.\n   */\n  dropDatabaseSql(databaseName, args) { throw new Error(\"'dropDatabaseSql' not implemented\") } // eslint-disable-line no-unused-vars\n\n  /**\n   * @abstract\n   * @param {CreateIndexSqlArgs} indexData - Index data.\n   * @returns {Promise<string[]>} - Resolves with SQL statements.\n   */\n  async createIndexSQLs(indexData) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'createIndexSQLs' not implemented\")\n  }\n\n  /**\n   * @param {import(\"../table-data/index.js\").default} tableData - Table data.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async createTable(tableData) {\n    this._assertNotReadOnly()\n    const sqls = await this.createTableSql(tableData)\n\n    for (const sql of sqls) {\n      await this.query(sql)\n    }\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) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'createTableSql' not implemented\")\n  }\n\n  /**\n   * @param {DeleteSqlArgsType} args - Options object.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async delete(args) {\n    this._assertNotReadOnly()\n    const sql = this.deleteSql(args)\n\n    await this.query(sql)\n  }\n\n  /**\n   * @abstract\n   * @param {DeleteSqlArgsType} args - Options object.\n   * @returns {string} - SQL string.\n   */\n  deleteSql(args) { // eslint-disable-line no-unused-vars\n    throw new Error(`'deleteSql' not implemented`)\n  }\n\n  /**\n   * @param {string} tableName - Table name.\n   * @param {DropTableSqlArgsType} [args] - Options object.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async dropTable(tableName, args) {\n    this._assertNotReadOnly()\n    const sqls = await this.dropTableSQLs(tableName, args)\n\n    for (const sql of sqls) {\n      await this.query(sql)\n    }\n  }\n\n  /**\n   * @abstract\n   * @param {string} tableName - Table name.\n   * @param {DropTableSqlArgsType} [args] - Options object.\n   * @returns {Promise<string[]>} - Resolves with SQL statements.\n   */\n  async dropTableSQLs(tableName, args) { // eslint-disable-line no-unused-vars\n    throw new Error(\"dropTableSQLs not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @param {any} value - Value to use.\n   * @returns {any} - The escape.\n   */\n  escape(value) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'escape' not implemented\")\n  }\n\n  /**\n   * @returns {import(\"../../configuration-types.js\").DatabaseConfigurationType} - The args.\n   */\n  getArgs() {\n    return this._args\n  }\n\n  /**\n   * @returns {import(\"../../configuration.js\").default} - The configuration.\n   */\n  getConfiguration() {\n    if (!this.configuration) throw new Error(\"No configuration set\")\n\n    return this.configuration\n  }\n\n  /**\n   * @returns {number | undefined} - The id seq.\n   */\n  getIdSeq() {\n    return this.idSeq\n  }\n\n  /**\n   * @abstract\n   * @returns {Promise<Array<import(\"./base-table.js\").default>>} - Resolves with the tables.\n   */\n  getTables() {\n    throw new Error(`${this.constructor.name}#getTables not implemented`)\n  }\n\n  /**\n   * @returns {Promise<string | null>} - Resolves with SQL string.\n   */\n  async structureSql() {\n    return null\n  }\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 tables = await this.getTables()\n    const tableNames = []\n    let table\n\n    for (const candidate of tables) {\n      const candidateName = candidate.getName()\n\n      if (candidateName == name) {\n        table = candidate\n        break\n      }\n\n      tableNames.push(candidateName)\n    }\n\n    if (!table && args?.throwError !== false) {\n      throw new Error(this._missingTableErrorMessage(name, tableNames))\n    }\n\n    return table\n  }\n\n  /**\n   * @param {string} name - Table name.\n   * @param {string[]} tableNames - Available table names.\n   * @returns {string} - Error message.\n   */\n  _missingTableErrorMessage(name, tableNames) {\n    const environment = this.getConfiguration().getEnvironment()\n    const args = this.getArgs()\n    const databaseName = args?.database || args?.name || args?.useDatabase || \"unknown\"\n\n    return `Couldn't find a table by that name \"${name}\" in: ${tableNames.join(\", \")} (environment: ${environment}, database: ${databaseName})`\n  }\n\n  /**\n   * @param {string} name - Name.\n   * @returns {Promise<import(\"./base-table.js\").default>} - Resolves with the table by name or fail.\n   */\n  async getTableByNameOrFail(name) {\n    return /** @type {import(\"./base-table.js\").default} */ (await this.getTableByName(name, {throwError: true}))\n  }\n\n  /**\n   * @abstract\n   * @returns {string} - The type.\n   */\n  getType() {\n    throw new Error(\"'type' not implemented\")\n  }\n\n  /**\n   * @param {InsertSqlArgsType} args - Options object.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async insert(args) {\n    this._assertNotReadOnly()\n    const sql = this.insertSql(args)\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 insertMultiple(tableName, columns, rows) {\n    this._assertNotReadOnly()\n\n    const sql = this.insertSql({columns, tableName, rows})\n\n    await this.query(sql)\n  }\n\n  /**\n   * @abstract\n   * @param {InsertSqlArgsType} args - Options object.\n   * @returns {string} - SQL string.\n   */\n  insertSql(args) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'insertSql' not implemented\")\n  }\n\n  /**\n   * @param {UpsertSqlArgsType} args - Options object.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async upsert(args) {\n    this._assertNotReadOnly()\n    const sql = this.upsertSql(args)\n\n    await this.query(sql)\n  }\n\n  /**\n   * @abstract\n   * @returns {Promise<number>} - Resolves with the last insert id.\n   */\n  lastInsertID() {\n    throw new Error(`${this.constructor.name}#lastInsertID not implemented`)\n  }\n\n  /**\n   * @param {any} value - Value to use.\n   * @returns {any} - The convert value.\n   */\n  _convertValue(value) {\n    if (typeof value === \"boolean\") {\n      return value ? 1 : 0\n    }\n\n    if (value instanceof Date) {\n      return strftime(\"%F %T.%L\", value)\n    }\n\n    return value\n  }\n\n  /**\n   * @abstract\n   * @returns {import(\"../query-parser/options.js\").default} - The options options.\n   */\n  options() {\n    throw new Error(\"'options' not implemented.\")\n  }\n\n  /**\n   * @param {any} value - Value to use.\n   * @returns {number | string} - The quote.\n   */\n  quote(value) {\n    if (typeof value == \"number\") return value\n\n    const escapedValue = this.escape(value)\n    const result = `\"${escapedValue}\"`\n\n    return result\n  }\n\n  /**\n   * @param {string} columnName - Column name.\n   * @returns {string} - The quote column.\n   */\n  quoteColumn(columnName) {\n    return this.options().quoteColumnName(columnName)\n  }\n\n  /**\n   * @param {string} columnName - Column name.\n   * @returns {string} - The quote index.\n   */\n  quoteIndex(columnName) {\n    return this.options().quoteIndexName(columnName)\n  }\n\n  /**\n   * @param {string} tableName - Table name.\n   * @returns {string} - The quote table.\n   */\n  quoteTable(tableName) {\n    return this.options().quoteTableName(tableName)\n  }\n\n  /**\n   * @param {any} value - Value from database.\n   * @returns {any} - Normalized value.\n   */\n\n  /**\n   * @returns {Query} - The new query.\n   */\n  newQuery() {\n    const handler = new Handler()\n\n    return new Query({\n      driver: this,\n      handler\n    })\n  }\n\n  /**\n   * @param {string} tableName - Table name.\n   * @returns {Promise<QueryResultType>} - Resolves with the select.\n   */\n  async select(tableName) {\n    const query = this.newQuery()\n\n    const sql = query\n      .from(tableName)\n      .toSql()\n\n    return await this.query(sql)\n  }\n\n  /**\n   * @param {number | undefined} newIdSeq - New id seq.\n   * @returns {void} - No return value.\n   */\n  setIdSeq(newIdSeq) {\n    this.idSeq = newIdSeq\n  }\n\n  /**\n   * @abstract\n   * @returns {boolean} - Whether set auto increment when primary key.\n   */\n  shouldSetAutoIncrementWhenPrimaryKey() {\n    throw new Error(`'shouldSetAutoIncrementWhenPrimaryKey' not implemented`)\n  }\n\n  /**\n   * @returns {boolean} - Whether supports default primary key uuid.\n   */\n  supportsDefaultPrimaryKeyUUID() { return false }\n\n  /**\n   * @abstract\n   * @returns {boolean} - Whether supports insert into returning.\n   */\n  supportsInsertIntoReturning() { return false }\n\n  /**\n   * @param {string} tableName - Table name.\n   * @returns {Promise<boolean>} - Resolves with Whether table exists.\n   */\n  async tableExists(tableName) {\n    const tables = await this.getTables()\n    const table = tables.find((table) => table.getName() == tableName)\n\n    if (table) return true\n\n    return false\n  }\n\n  /**\n   * @param {() => Promise<void>} callback - Callback function.\n   * @returns {Promise<any>} - Resolves with the transaction.\n   */\n  async transaction(callback) {\n    const savePointName = this.generateSavePointName()\n    /** @type {Array<() => void | Promise<void>>} */\n    const callbackFrame = []\n    let transactionStarted = false\n    let savePointStarted = false\n\n    this._afterCommitCallbackFrames.push(callbackFrame)\n\n    if (this._transactionsCount == 0) {\n      this.logger.debug(\"Start transaction\")\n      await this.startTransaction()\n      transactionStarted = true\n    } else {\n      this.logger.debug(\"Start savepoint\", savePointName)\n      await this.startSavePoint(savePointName)\n      savePointStarted = true\n    }\n\n    let result\n\n    try {\n      result = await callback()\n\n      if (savePointStarted) {\n        this.logger.debug(\"Release savepoint\", savePointName)\n        await this.releaseSavePoint(savePointName)\n      }\n\n      if (transactionStarted) {\n        this.logger.debug(\"Commit transaction\")\n        await this.commitTransaction()\n      }\n\n      await this._commitAfterCommitCallbackFrame()\n    } catch (error) {\n      if (error instanceof Error) {\n        this.logger.debug(\"Transaction error\", error.message)\n      } else {\n        this.logger.debug(\"Transaction error\", error)\n      }\n\n      let transactionRolledBack = false\n\n      if (savePointStarted) {\n        this.logger.debug(\"Rollback savepoint\", savePointName)\n        try {\n          await this.rollbackSavePoint(savePointName)\n        } catch (savePointError) {\n          const message = savePointError instanceof Error ? savePointError.message : `${savePointError}`\n\n          // MySQL sometimes drops savepoints unexpectedly; fall back to rolling back the full transaction\n          if (message.includes(\"SAVEPOINT\") || message.includes(\"ER_SP_DOES_NOT_EXIST\")) {\n            this.logger.debug(\"Savepoint rollback failed; rolling back entire transaction instead\")\n            await this.rollbackTransaction()\n            transactionRolledBack = true\n          } else {\n            throw savePointError\n          }\n        }\n      }\n\n      if (transactionStarted && !transactionRolledBack) {\n        this.logger.debug(\"Rollback transaction\")\n        await this.rollbackTransaction()\n      }\n\n      this._afterCommitCallbackFrames.pop()\n\n      throw error\n    }\n\n    return result\n  }\n\n  /**\n   * Runs a callback after the surrounding transaction commits.\n   * If no transaction is active, the callback runs immediately.\n   * @param {() => void | Promise<void>} callback - Callback.\n   * @returns {Promise<void>} - Resolves when the callback has been registered or run.\n   */\n  async afterCommit(callback) {\n    const currentFrame = this._afterCommitCallbackFrames[this._afterCommitCallbackFrames.length - 1]\n\n    if (!currentFrame) {\n      await callback()\n      return\n    }\n\n    currentFrame.push(callback)\n  }\n\n  /**\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async startTransaction() {\n    await this._transactionsActionsMutex.sync(async () => {\n      await this._startTransactionAction()\n      this._transactionsCount++\n    })\n  }\n\n  /**\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async _startTransactionAction() {\n    await this.query(\"BEGIN TRANSACTION\")\n  }\n\n  /**\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async commitTransaction() {\n    await this._transactionsActionsMutex.sync(async () => {\n      await this._commitTransactionAction()\n      this._transactionsCount--\n    })\n  }\n\n  /**\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async _commitTransactionAction() {\n    await this.query(\"COMMIT\")\n  }\n\n  /**\n   * Merges committed callbacks into the parent transaction frame or runs them when the outermost commit completes.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async _commitAfterCommitCallbackFrame() {\n    const committedCallbacks = this._afterCommitCallbackFrames.pop()\n\n    if (!committedCallbacks || committedCallbacks.length === 0) return\n\n    const parentFrame = this._afterCommitCallbackFrames[this._afterCommitCallbackFrames.length - 1]\n\n    if (parentFrame) {\n      parentFrame.push(...committedCallbacks)\n      return\n    }\n\n    for (const callback of committedCallbacks) {\n      await callback()\n    }\n  }\n\n  /**\n   * @param {string} sql - SQL string.\n   * @param {QueryOptions} [options] - Query options.\n   * @returns {Promise<QueryResultType>} - Resolves with the query.\n   */\n  async query(sql, options = {}) {\n    this._assertWritableQuery(sql)\n\n    let tries = 0\n    const maxTries = 5\n    const requestTiming = this.configuration.getCurrentRequestTiming()\n    const logQuery = options.logQuery ?? this._queryLoggingEnabled()\n    const sourceStack = logQuery ? (options.sourceStack || Error().stack) : undefined\n\n    while (tries < maxTries) {\n      tries++\n\n      try {\n        return await this._queryActualWithLogging(sql, {...options, logQuery, sourceStack}, requestTiming, tries)\n      } catch (error) {\n        if (!(error instanceof Error)) throw error\n\n        const retryInfo = this.retryableDatabaseError(error)\n\n        if (tries < maxTries && retryInfo.retry) {\n          if (retryInfo.reconnect) {\n            if (this._transactionsCount > 0) {\n              throw new Error(`Cannot reconnect while a transaction is active (${this._transactionsCount}). Original error: ${error.message}`, {cause: error})\n            }\n\n            await this.reconnect()\n          }\n\n          const waitMs = typeof retryInfo.waitMs === \"number\" && Number.isFinite(retryInfo.waitMs) ? retryInfo.waitMs : 100\n\n          if (waitMs > 0) await wait(waitMs)\n          this.logger.warn(`Retrying query because failed with: ${error.stack}`)\n          // Retry\n        } else {\n          throw error\n        }\n      }\n    }\n\n    throw new Error(\"'query' unexpected came here\")\n  }\n\n  /**\n   * @param {string} sql - SQL string.\n   * @param {QueryOptions} options - Query options.\n   * @param {import(\"../../http-server/client/request-timing.js\").default | undefined} requestTiming - Request timing.\n   * @param {number} tries - Query attempt count.\n   * @returns {Promise<QueryResultType>} - Resolves with the query.\n   */\n  async _queryActualWithLogging(sql, options, requestTiming, tries) {\n    const startedAtMs = nowMs()\n    let result\n\n    if (requestTiming && tries === 1) {\n      result = await requestTiming.measureDbQuery(async () => await this._queryActual(sql))\n    } else if (requestTiming) {\n      result = await requestTiming.measure(\"db\", async () => await this._queryActual(sql))\n    } else {\n      result = await this._queryActual(sql)\n    }\n\n    const elapsedMs = nowMs() - startedAtMs\n\n    if (options.logQuery !== false) {\n      await this._logQuery({\n        elapsedMs,\n        logName: options.logName || \"SQL\",\n        sourceStack: options.sourceStack,\n        sql\n      })\n    }\n\n    return result\n  }\n\n  /**\n   * @returns {boolean} - Whether query logging is enabled for this driver.\n   */\n  _queryLoggingEnabled() {\n    if (typeof this.configuration?.getQueryLoggingEnabled !== \"function\") return true\n    if (!this.configuration.getQueryLoggingEnabled()) return false\n\n    const logger = new Logger(\"SQL\", {configuration: this.configuration})\n\n    return logger.isLevelEnabled(\"info\")\n  }\n\n  /**\n   * @param {object} args - Options object.\n   * @param {number} args.elapsedMs - Elapsed milliseconds.\n   * @param {string} args.logName - Query log subject.\n   * @param {string | undefined} args.sourceStack - Source stack.\n   * @param {string} args.sql - SQL string.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async _logQuery({elapsedMs, logName, sourceStack, sql}) {\n    const logger = new Logger(logName, {configuration: this.configuration})\n    const sourceLine = this._querySourceLine(sourceStack)\n    const message = sourceLine\n      ? `(${formatElapsedMs(elapsedMs)})  ${sql}\\n  ↳ ${sourceLine}`\n      : `(${formatElapsedMs(elapsedMs)})  ${sql}`\n\n    await logger.info(message)\n  }\n\n  /**\n   * @param {string | undefined} sourceStack - Source stack.\n   * @returns {string | undefined} - Source line when an application frame is available.\n   */\n  _querySourceLine(sourceStack) {\n    if (!sourceStack || typeof this.configuration?.getDirectory !== \"function\") return undefined\n\n    const error = new Error(\"Query source\")\n\n    error.stack = sourceStack\n\n    return BacktraceCleaner.getApplicationSourceLine(error, {\n      applicationDirectory: this.configuration.getDirectory()\n    })\n  }\n\n  /**\n   * @abstract\n   * @param {string} sql - SQL string.\n   * @returns {Promise<QueryResultType>} - Resolves with the query actual.\n   */\n  _queryActual(sql) { // eslint-disable-line no-unused-vars\n    throw new Error(`queryActual not implemented`)\n  }\n\n  /**\n   * @abstract\n   * @param {Query} _query - Query instance.\n   * @returns {string} - SQL string.\n   */\n  queryToSql(_query) { throw new Error(\"queryToSql not implemented\") } // eslint-disable-line no-unused-vars\n\n  /**\n   * @param {Error} _error - Error instance.\n   * @returns {RetryableDatabaseErrorResult} - Retry info.\n   */\n  retryableDatabaseError(_error) { // eslint-disable-line no-unused-vars\n    return {retry: false, reconnect: false}\n  }\n\n  /**\n   * @param {string} sql - SQL string.\n   * @returns {void} - No return value.\n   */\n  _assertWritableQuery(sql) {\n    if (!this.isReadOnly()) return\n    if (!this._sqlLooksLikeWrite(sql)) return\n\n    throw new Error(\"Database is read-only\")\n  }\n\n  /**\n   * @returns {void} - No return value.\n   */\n  _assertNotReadOnly() {\n    if (this.isReadOnly()) {\n      throw new Error(\"Database is read-only\")\n    }\n  }\n\n  /**\n   * @param {string} sql - SQL string.\n   * @returns {boolean} - SQL representation.\n   */\n  _sqlLooksLikeWrite(sql) {\n    const normalized = sql.trim().toLowerCase()\n\n    if (!normalized) return false\n\n    if (\n      normalized.startsWith(\"select\") ||\n      normalized.startsWith(\"show\") ||\n      normalized.startsWith(\"pragma\") ||\n      normalized.startsWith(\"explain\") ||\n      normalized.startsWith(\"describe\")\n    ) {\n      return false\n    }\n\n    if (normalized.startsWith(\"with\")) {\n      const withMatch = normalized.match(/^\\s*with[\\s\\S]+?\\)\\s*(select|insert|update|delete|merge|replace)\\b/)\n\n      if (withMatch) {\n        return withMatch[1] !== \"select\"\n      }\n\n      return false\n    }\n\n    const keywordMatch = normalized.match(/^\\s*(\\w+)/)\n    const keyword = keywordMatch ? keywordMatch[1] : \"\"\n\n    return [\n      \"insert\",\n      \"update\",\n      \"delete\",\n      \"create\",\n      \"alter\",\n      \"drop\",\n      \"truncate\",\n      \"merge\",\n      \"replace\"\n    ].includes(keyword)\n  }\n\n  /** @returns {boolean} - Whether read only.  */\n  isReadOnly() {\n    return Boolean(this.getArgs().readOnly)\n  }\n\n  /**\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async rollbackTransaction() {\n    await this._transactionsActionsMutex.sync(async () => {\n      try {\n        await this._rollbackTransactionAction()\n      } finally {\n        this._transactionsCount--\n      }\n    })\n  }\n\n  /**\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async _rollbackTransactionAction() {\n    await this.query(\"ROLLBACK\")\n  }\n\n  /**\n   * @returns {string} - The generate save point name.\n   */\n  generateSavePointName() {\n    return `sp${new UUID(4).format().replaceAll(\"-\", \"\")}`\n  }\n\n  /**\n   * @param {string} savePointName - Save point name.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async startSavePoint(savePointName) {\n    await this._transactionsActionsMutex.sync(async () => {\n      await this._startSavePointAction(savePointName)\n    })\n  }\n\n  /**\n   * @param {string} savePointName - Save point name.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async _startSavePointAction(savePointName) {\n    await this.query(`SAVEPOINT ${savePointName}`)\n  }\n\n  /**\n   * @param {string} tableName - Table name.\n   * @param {string} oldColumnName - Previous column name.\n   * @param {string} newColumnName - New column name.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async renameColumn(tableName, oldColumnName, newColumnName) {\n    this._assertNotReadOnly()\n    const tableColumn = new TableColumn(oldColumnName)\n\n    tableColumn.setNewName(newColumnName)\n\n    const tableData = new TableData(tableName)\n\n    tableData.addColumn(tableColumn)\n\n    const alterTableSQLs = await this.alterTableSQLs(tableData)\n\n    for (const alterTableSQL of alterTableSQLs) {\n      await this.query(alterTableSQL)\n    }\n  }\n\n  /**\n   * @param {string} savePointName - Save point name.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async releaseSavePoint(savePointName) {\n    await this._transactionsActionsMutex.sync(async () => {\n      await this._releaseSavePointAction(savePointName)\n    })\n  }\n\n  /**\n   * @param {string} savePointName - Save point name.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async _releaseSavePointAction(savePointName) {\n    try {\n      await this.query(`RELEASE SAVEPOINT ${savePointName}`)\n    } catch (error) {\n      const message = error instanceof Error ? error.message : `${error}`\n\n      // Savepoint may already be gone if the database rolled back automatically\n      if (message.toLowerCase().includes(\"savepoint\") && message.toLowerCase().includes(\"does not exist\")) {\n        this.logger.debug(`Release savepoint ignored because it no longer exists: ${savePointName}`)\n        return\n      }\n\n      throw error\n    }\n  }\n\n  /**\n   * @param {string} savePointName - Save point name.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async rollbackSavePoint(savePointName) {\n    await this._transactionsActionsMutex.sync(async () => {\n      await this._rollbackSavePointAction(savePointName)\n    })\n  }\n\n  /**\n   * @param {string} savePointName - Save point name.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async _rollbackSavePointAction(savePointName) {\n    await this.query(`ROLLBACK TO SAVEPOINT ${savePointName}`)\n  }\n\n  /**\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async truncateAllTables() {\n    this._assertNotReadOnly()\n    await this.withDisabledForeignKeys(async () => {\n      let tries = 0\n\n      while(tries <= 5) {\n        tries++\n\n        const tables = await this.getTables()\n        const truncateErrors = []\n\n        for (const table of tables) {\n          if (table.getName() != \"schema_migrations\") {\n            try {\n              await table.truncate({cascade: true})\n            } catch (error) {\n              console.error(error)\n              truncateErrors.push(error)\n            }\n          }\n        }\n\n        if (truncateErrors.length == 0) {\n          break\n        } else if (tries <= 5) {\n          // Retry\n        } else {\n          throw truncateErrors[0]\n        }\n      }\n    })\n  }\n\n  /**\n   * @param {UpdateSqlArgsType} args - Options object.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async update(args) {\n    this._assertNotReadOnly()\n    const sql = this.updateSql(args)\n\n    await this.query(sql)\n  }\n\n  /**\n   * @abstract\n   * @param {UpdateSqlArgsType} args - Options object.\n   * @returns {string} - SQL string.\n   */\n  updateSql(args) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'disableForeignKeys' not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @param {UpsertSqlArgsType} args - Options object.\n   * @returns {string} - SQL string.\n   */\n  upsertSql(args) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'upsertSql' not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  disableForeignKeys() {\n    throw new Error(\"'disableForeignKeys' not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  enableForeignKeys() {\n    throw new Error(\"'enableForeignKeys' not implemented\")\n  }\n\n  /**\n   * @param {function() : void} callback - Callback function.\n   * @returns {Promise<any>} - Resolves with the with disabled foreign keys.\n   */\n  async withDisabledForeignKeys(callback) {\n    await this.disableForeignKeys()\n\n    try {\n      return await callback()\n    } finally {\n      await this.enableForeignKeys()\n    }\n  }\n\n  /**\n   * Blocks until a named advisory lock is acquired on this connection.\n   * Advisory locks are connection-scoped and do not interact with row or\n   * table locks; they are purely cooperative between callers that use the\n   * same name and let you serialize functionality without blocking readers\n   * or writers that do not participate in the same lock.\n   *\n   * @abstract\n   * @param {string} name - Lock name.\n   * @param {{timeoutMs?: number | null}} [_args] - Optional timeout in milliseconds; `null` or undefined blocks forever.\n   * @returns {Promise<boolean>} - Resolves to true when the lock has been acquired, false if the timeout elapsed.\n   */\n  acquireAdvisoryLock(name, _args = {}) { // eslint-disable-line no-unused-vars\n    throw new Error(`'acquireAdvisoryLock' not implemented for ${this.constructor.name}`)\n  }\n\n  /**\n   * Attempts to acquire a named advisory lock without blocking.\n   *\n   * @abstract\n   * @param {string} name - Lock name.\n   * @returns {Promise<boolean>} - Resolves to true if the lock was acquired, false if it was already held.\n   */\n  tryAcquireAdvisoryLock(name) { // eslint-disable-line no-unused-vars\n    throw new Error(`'tryAcquireAdvisoryLock' not implemented for ${this.constructor.name}`)\n  }\n\n  /**\n   * Releases a named advisory lock previously acquired on this connection.\n   *\n   * @abstract\n   * @param {string} name - Lock name.\n   * @returns {Promise<boolean>} - Resolves to true if the lock was held by this session and has now been released.\n   */\n  releaseAdvisoryLock(name) { // eslint-disable-line no-unused-vars\n    throw new Error(`'releaseAdvisoryLock' not implemented for ${this.constructor.name}`)\n  }\n\n  /**\n   * Checks whether a named advisory lock is currently held by any session.\n   * Intended as an introspection helper; callers who need to act on the\n   * result should prefer `tryAcquireAdvisoryLock` to avoid a TOCTOU race.\n   *\n   * @abstract\n   * @param {string} name - Lock name.\n   * @returns {Promise<boolean>} - Resolves to true if the lock is held by any session.\n   */\n  isAdvisoryLockHeld(name) { // eslint-disable-line no-unused-vars\n    throw new Error(`'isAdvisoryLockHeld' not implemented for ${this.constructor.name}`)\n  }\n}\n"]}
|
|
1159
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base.js","sourceRoot":"","sources":["../../../../src/database/drivers/base.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\n/**\n * @typedef {object} CreateIndexSqlArgs\n * @property {Array<string | import(\"./../table-data/table-column.js\").default>} columns - Columns to include in the index.\n * @property {boolean} [ifNotExists] - Skip creation if the index already exists.\n * @property {string} [name] - Explicit index name to use.\n * @property {boolean} [unique] - Whether the index should enforce uniqueness.\n * @property {string} tableName - Name of the table to add the index to.\n */\n/**\n * @typedef {object} DropTableSqlArgsType\n * @property {boolean} [cascade] - Whether dependent objects should be dropped too.\n * @property {boolean} [ifExists] - Skip dropping if the table does not exist.\n */\n/**\n * @typedef {object} DeleteSqlArgsType\n * @property {string} tableName - Table name to delete from.\n * @property {{[key: string]: any}} conditions - Conditions used to build the delete WHERE clause.\n */\n/**\n * @typedef {object} InsertSqlArgsType\n * @property {string[]} [columns] - Column names for `rows` inserts.\n * @property {{[key: string]: any}} [data] - Column/value pairs for a single-row insert.\n * @property {boolean} [multiple] - Whether this insert should be treated as multi-row.\n * @property {string[]} [returnLastInsertedColumnNames] - Column names to return after insert.\n * @property {Array<Array<any>>} [rows] - Row values for a multi-row insert.\n * @property {string} tableName - Table name to insert into.\n */\n/**\n * @typedef {Record<string, any>} QueryRowType\n * @typedef {Array<QueryRowType>} QueryResultType\n */\n/**\n * @typedef {object} RetryableDatabaseErrorResult\n * @property {boolean} retry - Whether the error should be retried.\n * @property {boolean} reconnect - Whether to reconnect before retrying.\n * @property {number} [maxTries] - Override the max retry attempts.\n * @property {number} [waitMs] - Wait time before retrying in milliseconds.\n */\n/**\n * @typedef {object} QueryOptions\n * @property {string} [logName] - Query log subject.\n * @property {boolean} [logQuery] - Whether to log the query.\n * @property {string} [sourceStack] - Stack captured at the caller boundary.\n */\n/**\n * @typedef {object}UpdateSqlArgsType\n * @property {object} conditions - Conditions used to build the update WHERE clause.\n * @property {object} data - Column/value pairs to update.\n * @property {string} tableName - Table name to update.\n */\n/**\n * @typedef {object}UpsertSqlArgsType\n * @property {string[]} conflictColumns - Columns that define a conflict.\n * @property {object} data - Column/value pairs to insert.\n * @property {string} tableName - Table name to upsert into.\n * @property {string[]} updateColumns - Columns to update on conflict.\n */\n\nimport BacktraceCleaner from \"../../utils/backtrace-cleaner.js\"\nimport Logger from \"../../logger.js\"\nimport Query from \"../query/index.js\"\nimport Handler from \"../handler.js\"\nimport Mutex from \"epic-locks/build/mutex.js\"\nimport strftime from \"strftime\"\nimport UUID from \"pure-uuid\"\nimport TableData from \"../table-data/index.js\"\nimport TableColumn from \"../table-data/table-column.js\"\nimport TableForeignKey from \"../table-data/table-foreign-key.js\"\nimport wait from \"awaitery/build/wait.js\"\n\n/** @returns {number} - Current high-resolution-ish timestamp in milliseconds. */\nfunction nowMs() {\n  if (globalThis.performance && typeof globalThis.performance.now == \"function\") {\n    return globalThis.performance.now()\n  }\n\n  return Date.now()\n}\n\n/**\n * @param {number} elapsedMs - Elapsed milliseconds.\n * @returns {string} - Formatted elapsed milliseconds.\n */\nfunction formatElapsedMs(elapsedMs) {\n  return `${Math.max(elapsedMs, 0).toFixed(1)}ms`\n}\n\nexport default class VelociousDatabaseDriversBase {\n  /** @type {number | undefined} */\n  idSeq = undefined\n  /** @type {Array<Array<() => void | Promise<void>>>} */\n  _afterCommitCallbackFrames\n  /** @type {Map<string, Promise<unknown>>} */\n  _schemaCache\n  /** @type {(() => void) | undefined} */\n  _schemaCacheInvalidator\n\n  /**\n   * @param {import(\"../../configuration-types.js\").DatabaseConfigurationType} config - Configuration object.\n   * @param {import(\"../../configuration.js\").default} configuration - Configuration instance.\n   */\n  constructor(config, configuration) {\n    this._args = config\n    this.configuration = configuration\n    this.mutex = new Mutex() // Can be used to lock this instance for exclusive use\n    this.logger = new Logger(this)\n    this._afterCommitCallbackFrames = []\n    this._transactionsCount = 0\n    this._transactionsActionsMutex = new Mutex()\n    this._schemaCache = new Map()\n  }\n\n  /**\n   * @param {string} tableName - Table name.\n   * @param {string} columnName - Column name.\n   * @param {string} referencedTableName - Referenced table name.\n   * @param {string} referencedColumnName - Referenced column name.\n   * @param {object} args - Options object.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async addForeignKey(tableName, columnName, referencedTableName, referencedColumnName, args) {\n    this._assertNotReadOnly()\n    const tableForeignKeyArgs = Object.assign(\n      {\n        columnName,\n        tableName,\n        referencedColumnName,\n        referencedTableName\n      },\n      args\n    )\n    const tableForeignKey = new TableForeignKey(tableForeignKeyArgs)\n    const tableData = new TableData(tableName)\n\n    tableData.addForeignKey(tableForeignKey)\n\n    const alterTableSQLs = await this.alterTableSQLs(tableData)\n\n    for (const alterTableSQL of alterTableSQLs) {\n      await this.query(alterTableSQL)\n    }\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  alterTableSQLs(_tableData) { // eslint-disable-line no-unused-vars\n    throw new Error(\"alterTableSQLs not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  connect() {\n    throw new Error(\"'connect' not implemented\")\n  }\n\n  /**\n   * Optional close hook for database drivers.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async close() {\n    // No-op by default\n  }\n\n  /**\n   * Optional disconnect hook for database drivers.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async disconnect() {\n    // No-op by default\n  }\n\n  /**\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async reconnect() {\n    this.clearSchemaCache()\n    await this.close()\n    await this.connect()\n  }\n\n  /**\n   * @abstract\n   * @param {string} databaseName - Database name.\n   * @param {object} [args] - Options object.\n   * @param {boolean} [args.ifNotExists] - Whether if not exists.\n   * @param {string} [args.databaseCharset] - Database-default character set (driver-specific; mysql/mariadb).\n   * @param {string} [args.databaseCollation] - Database-default collation (driver-specific; mysql/mariadb).\n   * @returns {string[]} - SQL statements.\n   */\n  createDatabaseSql(databaseName, args) { throw new Error(\"'createDatabaseSql' not implemented\") } // eslint-disable-line no-unused-vars\n\n  /**\n   * @abstract\n   * @param {string} databaseName - Database name.\n   * @param {object} [args] - Options object.\n   * @param {boolean} [args.ifExists] - Whether if exists.\n   * @returns {string[]} - SQL statements.\n   */\n  dropDatabaseSql(databaseName, args) { throw new Error(\"'dropDatabaseSql' not implemented\") } // eslint-disable-line no-unused-vars\n\n  /**\n   * @abstract\n   * @param {CreateIndexSqlArgs} indexData - Index data.\n   * @returns {Promise<string[]>} - Resolves with SQL statements.\n   */\n  async createIndexSQLs(indexData) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'createIndexSQLs' not implemented\")\n  }\n\n  /**\n   * @param {import(\"../table-data/index.js\").default} tableData - Table data.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async createTable(tableData) {\n    this._assertNotReadOnly()\n    const sqls = await this.createTableSql(tableData)\n\n    for (const sql of sqls) {\n      await this.query(sql)\n    }\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) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'createTableSql' not implemented\")\n  }\n\n  /**\n   * @param {DeleteSqlArgsType} args - Options object.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async delete(args) {\n    this._assertNotReadOnly()\n    const sql = this.deleteSql(args)\n\n    await this.query(sql)\n  }\n\n  /**\n   * @abstract\n   * @param {DeleteSqlArgsType} args - Options object.\n   * @returns {string} - SQL string.\n   */\n  deleteSql(args) { // eslint-disable-line no-unused-vars\n    throw new Error(`'deleteSql' not implemented`)\n  }\n\n  /**\n   * @param {string} tableName - Table name.\n   * @param {DropTableSqlArgsType} [args] - Options object.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async dropTable(tableName, args) {\n    this._assertNotReadOnly()\n    const sqls = await this.dropTableSQLs(tableName, args)\n\n    for (const sql of sqls) {\n      await this.query(sql)\n    }\n  }\n\n  /**\n   * @abstract\n   * @param {string} tableName - Table name.\n   * @param {DropTableSqlArgsType} [args] - Options object.\n   * @returns {Promise<string[]>} - Resolves with SQL statements.\n   */\n  async dropTableSQLs(tableName, args) { // eslint-disable-line no-unused-vars\n    throw new Error(\"dropTableSQLs not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @param {any} value - Value to use.\n   * @returns {any} - The escape.\n   */\n  escape(value) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'escape' not implemented\")\n  }\n\n  /**\n   * @returns {import(\"../../configuration-types.js\").DatabaseConfigurationType} - The args.\n   */\n  getArgs() {\n    return this._args\n  }\n\n  /**\n   * @returns {import(\"../../configuration.js\").default} - The configuration.\n   */\n  getConfiguration() {\n    if (!this.configuration) throw new Error(\"No configuration set\")\n\n    return this.configuration\n  }\n\n  /**\n   * @returns {number | undefined} - The id seq.\n   */\n  getIdSeq() {\n    return this.idSeq\n  }\n\n  /**\n   * Clears cached schema metadata for this driver instance.\n   * @returns {void} - No return value.\n   */\n  clearSchemaCache() {\n    if (this._schemaCacheInvalidator) {\n      this._schemaCacheInvalidator()\n      return\n    }\n\n    this._clearLocalSchemaCache()\n  }\n\n  /**\n   * Clears only the metadata cached on this driver instance.\n   * @returns {void} - No return value.\n   */\n  _clearLocalSchemaCache() {\n    this._schemaCache.clear()\n  }\n\n  /**\n   * @param {() => void} invalidator - Callback used to clear schema caches that share this driver pool.\n   * @returns {void} - No return value.\n   */\n  setSchemaCacheInvalidator(invalidator) {\n    this._schemaCacheInvalidator = invalidator\n  }\n\n  /**\n   * @returns {boolean} - Whether schema metadata caching is enabled.\n   */\n  _schemaCacheEnabled() {\n    return this.getArgs().schemaCache !== false\n  }\n\n  /**\n   * @template T\n   * @param {string} cacheKey - Schema cache key.\n   * @param {() => Promise<T>} callback - Cache miss callback.\n   * @returns {Promise<T>} - Resolves with the cached metadata.\n   */\n  async _cachedSchemaMetadata(cacheKey, callback) {\n    if (!this._schemaCacheEnabled()) return await callback()\n\n    const existingPromise = this._schemaCache.get(cacheKey)\n\n    if (existingPromise) {\n      return /** @type {T} */ (this._schemaCacheReturnValue(await existingPromise))\n    }\n\n    const promise = (async () => await callback())()\n\n    this._schemaCache.set(cacheKey, promise)\n\n    try {\n      return /** @type {T} */ (this._schemaCacheReturnValue(await promise))\n    } catch (error) {\n      if (this._schemaCache.get(cacheKey) === promise) {\n        this._schemaCache.delete(cacheKey)\n      }\n\n      throw error\n    }\n  }\n\n  /**\n   * @template T\n   * @param {string} tableName - Table name.\n   * @param {string} metadataName - Metadata name.\n   * @param {() => Promise<T>} callback - Cache miss callback.\n   * @returns {Promise<T>} - Resolves with the cached table metadata.\n   */\n  async _cachedTableSchemaMetadata(tableName, metadataName, callback) {\n    return await this._cachedSchemaMetadata(`table:${tableName}:${metadataName}`, callback)\n  }\n\n  /**\n   * @param {unknown} value - Cached value.\n   * @returns {unknown} - Value returned to callers.\n   */\n  _schemaCacheReturnValue(value) {\n    if (Array.isArray(value)) return value.slice()\n\n    return value\n  }\n\n  /**\n   * @abstract\n   * @returns {Promise<Array<import(\"./base-table.js\").default>>} - Resolves with the tables.\n   */\n  getTables() {\n    throw new Error(`${this.constructor.name}#getTables not implemented`)\n  }\n\n  /**\n   * @returns {Promise<string | null>} - Resolves with SQL string.\n   */\n  async structureSql() {\n    return null\n  }\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 tables = await this.getTables()\n    const tableNames = []\n    let table\n\n    for (const candidate of tables) {\n      const candidateName = candidate.getName()\n\n      if (candidateName == name) {\n        table = candidate\n        break\n      }\n\n      tableNames.push(candidateName)\n    }\n\n    if (!table && args?.throwError !== false) {\n      throw new Error(this._missingTableErrorMessage(name, tableNames))\n    }\n\n    return table\n  }\n\n  /**\n   * @param {string} name - Table name.\n   * @param {string[]} tableNames - Available table names.\n   * @returns {string} - Error message.\n   */\n  _missingTableErrorMessage(name, tableNames) {\n    const environment = this.getConfiguration().getEnvironment()\n    const args = this.getArgs()\n    const databaseName = args?.database || args?.name || args?.useDatabase || \"unknown\"\n\n    return `Couldn't find a table by that name \"${name}\" in: ${tableNames.join(\", \")} (environment: ${environment}, database: ${databaseName})`\n  }\n\n  /**\n   * @param {string} name - Name.\n   * @returns {Promise<import(\"./base-table.js\").default>} - Resolves with the table by name or fail.\n   */\n  async getTableByNameOrFail(name) {\n    return /** @type {import(\"./base-table.js\").default} */ (await this.getTableByName(name, {throwError: true}))\n  }\n\n  /**\n   * @abstract\n   * @returns {string} - The type.\n   */\n  getType() {\n    throw new Error(\"'type' not implemented\")\n  }\n\n  /**\n   * @param {InsertSqlArgsType} args - Options object.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async insert(args) {\n    this._assertNotReadOnly()\n    const sql = this.insertSql(args)\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 insertMultiple(tableName, columns, rows) {\n    this._assertNotReadOnly()\n\n    const sql = this.insertSql({columns, tableName, rows})\n\n    await this.query(sql)\n  }\n\n  /**\n   * @abstract\n   * @param {InsertSqlArgsType} args - Options object.\n   * @returns {string} - SQL string.\n   */\n  insertSql(args) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'insertSql' not implemented\")\n  }\n\n  /**\n   * @param {UpsertSqlArgsType} args - Options object.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async upsert(args) {\n    this._assertNotReadOnly()\n    const sql = this.upsertSql(args)\n\n    await this.query(sql)\n  }\n\n  /**\n   * @abstract\n   * @returns {Promise<number>} - Resolves with the last insert id.\n   */\n  lastInsertID() {\n    throw new Error(`${this.constructor.name}#lastInsertID not implemented`)\n  }\n\n  /**\n   * @param {any} value - Value to use.\n   * @returns {any} - The convert value.\n   */\n  _convertValue(value) {\n    if (typeof value === \"boolean\") {\n      return value ? 1 : 0\n    }\n\n    if (value instanceof Date) {\n      return strftime(\"%F %T.%L\", value)\n    }\n\n    return value\n  }\n\n  /**\n   * @abstract\n   * @returns {import(\"../query-parser/options.js\").default} - The options options.\n   */\n  options() {\n    throw new Error(\"'options' not implemented.\")\n  }\n\n  /**\n   * @param {any} value - Value to use.\n   * @returns {number | string} - The quote.\n   */\n  quote(value) {\n    if (typeof value == \"number\") return value\n\n    const escapedValue = this.escape(value)\n    const result = `\"${escapedValue}\"`\n\n    return result\n  }\n\n  /**\n   * @param {string} columnName - Column name.\n   * @returns {string} - The quote column.\n   */\n  quoteColumn(columnName) {\n    return this.options().quoteColumnName(columnName)\n  }\n\n  /**\n   * @param {string} columnName - Column name.\n   * @returns {string} - The quote index.\n   */\n  quoteIndex(columnName) {\n    return this.options().quoteIndexName(columnName)\n  }\n\n  /**\n   * @param {string} tableName - Table name.\n   * @returns {string} - The quote table.\n   */\n  quoteTable(tableName) {\n    return this.options().quoteTableName(tableName)\n  }\n\n  /**\n   * @param {any} value - Value from database.\n   * @returns {any} - Normalized value.\n   */\n\n  /**\n   * @returns {Query} - The new query.\n   */\n  newQuery() {\n    const handler = new Handler()\n\n    return new Query({\n      driver: this,\n      handler\n    })\n  }\n\n  /**\n   * @param {string} tableName - Table name.\n   * @returns {Promise<QueryResultType>} - Resolves with the select.\n   */\n  async select(tableName) {\n    const query = this.newQuery()\n\n    const sql = query\n      .from(tableName)\n      .toSql()\n\n    return await this.query(sql)\n  }\n\n  /**\n   * @param {number | undefined} newIdSeq - New id seq.\n   * @returns {void} - No return value.\n   */\n  setIdSeq(newIdSeq) {\n    this.idSeq = newIdSeq\n  }\n\n  /**\n   * @abstract\n   * @returns {boolean} - Whether set auto increment when primary key.\n   */\n  shouldSetAutoIncrementWhenPrimaryKey() {\n    throw new Error(`'shouldSetAutoIncrementWhenPrimaryKey' not implemented`)\n  }\n\n  /**\n   * @returns {boolean} - Whether supports default primary key uuid.\n   */\n  supportsDefaultPrimaryKeyUUID() { return false }\n\n  /**\n   * @abstract\n   * @returns {boolean} - Whether supports insert into returning.\n   */\n  supportsInsertIntoReturning() { return false }\n\n  /**\n   * @param {string} tableName - Table name.\n   * @returns {Promise<boolean>} - Resolves with Whether table exists.\n   */\n  async tableExists(tableName) {\n    const tables = await this.getTables()\n    const table = tables.find((table) => table.getName() == tableName)\n\n    if (table) return true\n\n    return false\n  }\n\n  /**\n   * @param {() => Promise<void>} callback - Callback function.\n   * @returns {Promise<any>} - Resolves with the transaction.\n   */\n  async transaction(callback) {\n    const savePointName = this.generateSavePointName()\n    /** @type {Array<() => void | Promise<void>>} */\n    const callbackFrame = []\n    let transactionStarted = false\n    let savePointStarted = false\n\n    this._afterCommitCallbackFrames.push(callbackFrame)\n\n    if (this._transactionsCount == 0) {\n      this.logger.debug(\"Start transaction\")\n      await this.startTransaction()\n      transactionStarted = true\n    } else {\n      this.logger.debug(\"Start savepoint\", savePointName)\n      await this.startSavePoint(savePointName)\n      savePointStarted = true\n    }\n\n    let result\n\n    try {\n      result = await callback()\n\n      if (savePointStarted) {\n        this.logger.debug(\"Release savepoint\", savePointName)\n        await this.releaseSavePoint(savePointName)\n      }\n\n      if (transactionStarted) {\n        this.logger.debug(\"Commit transaction\")\n        await this.commitTransaction()\n      }\n\n      await this._commitAfterCommitCallbackFrame()\n    } catch (error) {\n      if (error instanceof Error) {\n        this.logger.debug(\"Transaction error\", error.message)\n      } else {\n        this.logger.debug(\"Transaction error\", error)\n      }\n\n      let transactionRolledBack = false\n\n      if (savePointStarted) {\n        this.logger.debug(\"Rollback savepoint\", savePointName)\n        try {\n          await this.rollbackSavePoint(savePointName)\n        } catch (savePointError) {\n          const message = savePointError instanceof Error ? savePointError.message : `${savePointError}`\n\n          // MySQL sometimes drops savepoints unexpectedly; fall back to rolling back the full transaction\n          if (message.includes(\"SAVEPOINT\") || message.includes(\"ER_SP_DOES_NOT_EXIST\")) {\n            this.logger.debug(\"Savepoint rollback failed; rolling back entire transaction instead\")\n            await this.rollbackTransaction()\n            transactionRolledBack = true\n          } else {\n            throw savePointError\n          }\n        }\n      }\n\n      if (transactionStarted && !transactionRolledBack) {\n        this.logger.debug(\"Rollback transaction\")\n        await this.rollbackTransaction()\n      }\n\n      this._afterCommitCallbackFrames.pop()\n\n      throw error\n    }\n\n    return result\n  }\n\n  /**\n   * Runs a callback after the surrounding transaction commits.\n   * If no transaction is active, the callback runs immediately.\n   * @param {() => void | Promise<void>} callback - Callback.\n   * @returns {Promise<void>} - Resolves when the callback has been registered or run.\n   */\n  async afterCommit(callback) {\n    const currentFrame = this._afterCommitCallbackFrames[this._afterCommitCallbackFrames.length - 1]\n\n    if (!currentFrame) {\n      await callback()\n      return\n    }\n\n    currentFrame.push(callback)\n  }\n\n  /**\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async startTransaction() {\n    await this._transactionsActionsMutex.sync(async () => {\n      await this._startTransactionAction()\n      this._transactionsCount++\n    })\n  }\n\n  /**\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async _startTransactionAction() {\n    await this.query(\"BEGIN TRANSACTION\")\n  }\n\n  /**\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async commitTransaction() {\n    await this._transactionsActionsMutex.sync(async () => {\n      await this._commitTransactionAction()\n      this._transactionsCount--\n    })\n  }\n\n  /**\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async _commitTransactionAction() {\n    await this.query(\"COMMIT\")\n  }\n\n  /**\n   * Merges committed callbacks into the parent transaction frame or runs them when the outermost commit completes.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async _commitAfterCommitCallbackFrame() {\n    const committedCallbacks = this._afterCommitCallbackFrames.pop()\n\n    if (!committedCallbacks || committedCallbacks.length === 0) return\n\n    const parentFrame = this._afterCommitCallbackFrames[this._afterCommitCallbackFrames.length - 1]\n\n    if (parentFrame) {\n      parentFrame.push(...committedCallbacks)\n      return\n    }\n\n    for (const callback of committedCallbacks) {\n      await callback()\n    }\n  }\n\n  /**\n   * @param {string} sql - SQL string.\n   * @param {QueryOptions} [options] - Query options.\n   * @returns {Promise<QueryResultType>} - Resolves with the query.\n   */\n  async query(sql, options = {}) {\n    this._assertWritableQuery(sql)\n\n    let tries = 0\n    const maxTries = 5\n    const requestTiming = this.configuration.getCurrentRequestTiming()\n    const logQuery = options.logQuery ?? this._queryLoggingEnabled()\n    const sourceStack = logQuery ? (options.sourceStack || Error().stack) : undefined\n\n    while (tries < maxTries) {\n      tries++\n\n      try {\n        return await this._queryActualWithLogging(sql, {...options, logQuery, sourceStack}, requestTiming, tries)\n      } catch (error) {\n        if (!(error instanceof Error)) throw error\n\n        const retryInfo = this.retryableDatabaseError(error)\n\n        if (tries < maxTries && retryInfo.retry) {\n          if (retryInfo.reconnect) {\n            if (this._transactionsCount > 0) {\n              throw new Error(`Cannot reconnect while a transaction is active (${this._transactionsCount}). Original error: ${error.message}`, {cause: error})\n            }\n\n            await this.reconnect()\n          }\n\n          const waitMs = typeof retryInfo.waitMs === \"number\" && Number.isFinite(retryInfo.waitMs) ? retryInfo.waitMs : 100\n\n          if (waitMs > 0) await wait(waitMs)\n          this.logger.warn(`Retrying query because failed with: ${error.stack}`)\n          // Retry\n        } else {\n          throw error\n        }\n      }\n    }\n\n    throw new Error(\"'query' unexpected came here\")\n  }\n\n  /**\n   * @param {string} sql - SQL string.\n   * @param {QueryOptions} options - Query options.\n   * @param {import(\"../../http-server/client/request-timing.js\").default | undefined} requestTiming - Request timing.\n   * @param {number} tries - Query attempt count.\n   * @returns {Promise<QueryResultType>} - Resolves with the query.\n   */\n  async _queryActualWithLogging(sql, options, requestTiming, tries) {\n    const startedAtMs = nowMs()\n    let result\n\n    if (requestTiming && tries === 1) {\n      result = await requestTiming.measureDbQuery(async () => await this._queryActual(sql))\n    } else if (requestTiming) {\n      result = await requestTiming.measure(\"db\", async () => await this._queryActual(sql))\n    } else {\n      result = await this._queryActual(sql)\n    }\n\n    const elapsedMs = nowMs() - startedAtMs\n\n    if (options.logQuery !== false) {\n      await this._logQuery({\n        elapsedMs,\n        logName: options.logName || \"SQL\",\n        sourceStack: options.sourceStack,\n        sql\n      })\n    }\n\n    if (this._schemaCacheInvalidatingSql(sql)) {\n      this.clearSchemaCache()\n    }\n\n    return result\n  }\n\n  /**\n   * @param {string} sql - SQL string.\n   * @returns {boolean} - Whether the SQL should invalidate schema metadata.\n   */\n  _schemaCacheInvalidatingSql(sql) {\n    const normalized = sql\n      .trim()\n      .replace(/^\\ufeff/, \"\")\n      .replace(/\\/\\*[\\s\\S]*?\\*\\//g, \" \")\n      .replace(/--[^\\n]*(\\n|$)/g, \" \")\n      .replace(/\\s+/g, \" \")\n      .toLowerCase()\n\n    if (!normalized) return false\n    if (/^(create|alter|drop|rename)\\b/.test(normalized)) return true\n    if (/^comment\\s+on\\b/.test(normalized)) return true\n    if (/^exec(?:ute)?\\s+sp_rename\\b/.test(normalized)) return true\n    if (/^if\\b[\\s\\S]*\\bbegin\\s+(create|alter|drop|rename)\\b/.test(normalized)) return true\n\n    return false\n  }\n\n  /**\n   * @returns {boolean} - Whether query logging is enabled for this driver.\n   */\n  _queryLoggingEnabled() {\n    if (typeof this.configuration?.getQueryLoggingEnabled !== \"function\") return true\n    if (!this.configuration.getQueryLoggingEnabled()) return false\n\n    const logger = new Logger(\"SQL\", {configuration: this.configuration})\n\n    return logger.isLevelEnabled(\"info\")\n  }\n\n  /**\n   * @param {object} args - Options object.\n   * @param {number} args.elapsedMs - Elapsed milliseconds.\n   * @param {string} args.logName - Query log subject.\n   * @param {string | undefined} args.sourceStack - Source stack.\n   * @param {string} args.sql - SQL string.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async _logQuery({elapsedMs, logName, sourceStack, sql}) {\n    const logger = new Logger(logName, {configuration: this.configuration})\n    const sourceLine = this._querySourceLine(sourceStack)\n    const message = sourceLine\n      ? `(${formatElapsedMs(elapsedMs)})  ${sql}\\n  ↳ ${sourceLine}`\n      : `(${formatElapsedMs(elapsedMs)})  ${sql}`\n\n    await logger.info(message)\n  }\n\n  /**\n   * @param {string | undefined} sourceStack - Source stack.\n   * @returns {string | undefined} - Source line when an application frame is available.\n   */\n  _querySourceLine(sourceStack) {\n    if (!sourceStack) return undefined\n\n    const applicationDirectory = typeof this.configuration?.getDirectoryIfAvailable === \"function\"\n      ? this.configuration.getDirectoryIfAvailable()\n      : this.configuration?.getDirectory?.()\n\n    if (!applicationDirectory) return undefined\n\n    const error = new Error(\"Query source\")\n\n    error.stack = sourceStack\n\n    return BacktraceCleaner.getApplicationSourceLine(error, {\n      applicationDirectory,\n      frameworkSourceDirectory: this.configuration.getEnvironmentHandler().getFrameworkSourceDirectory()\n    })\n  }\n\n  /**\n   * @abstract\n   * @param {string} sql - SQL string.\n   * @returns {Promise<QueryResultType>} - Resolves with the query actual.\n   */\n  _queryActual(sql) { // eslint-disable-line no-unused-vars\n    throw new Error(`queryActual not implemented`)\n  }\n\n  /**\n   * @abstract\n   * @param {Query} _query - Query instance.\n   * @returns {string} - SQL string.\n   */\n  queryToSql(_query) { throw new Error(\"queryToSql not implemented\") } // eslint-disable-line no-unused-vars\n\n  /**\n   * @param {Error} _error - Error instance.\n   * @returns {RetryableDatabaseErrorResult} - Retry info.\n   */\n  retryableDatabaseError(_error) { // eslint-disable-line no-unused-vars\n    return {retry: false, reconnect: false}\n  }\n\n  /**\n   * @param {string} sql - SQL string.\n   * @returns {void} - No return value.\n   */\n  _assertWritableQuery(sql) {\n    if (!this.isReadOnly()) return\n    if (!this._sqlLooksLikeWrite(sql)) return\n\n    throw new Error(\"Database is read-only\")\n  }\n\n  /**\n   * @returns {void} - No return value.\n   */\n  _assertNotReadOnly() {\n    if (this.isReadOnly()) {\n      throw new Error(\"Database is read-only\")\n    }\n  }\n\n  /**\n   * @param {string} sql - SQL string.\n   * @returns {boolean} - SQL representation.\n   */\n  _sqlLooksLikeWrite(sql) {\n    const normalized = sql.trim().toLowerCase()\n\n    if (!normalized) return false\n\n    if (\n      normalized.startsWith(\"select\") ||\n      normalized.startsWith(\"show\") ||\n      normalized.startsWith(\"pragma\") ||\n      normalized.startsWith(\"explain\") ||\n      normalized.startsWith(\"describe\")\n    ) {\n      return false\n    }\n\n    if (normalized.startsWith(\"with\")) {\n      const withMatch = normalized.match(/^\\s*with[\\s\\S]+?\\)\\s*(select|insert|update|delete|merge|replace)\\b/)\n\n      if (withMatch) {\n        return withMatch[1] !== \"select\"\n      }\n\n      return false\n    }\n\n    const keywordMatch = normalized.match(/^\\s*(\\w+)/)\n    const keyword = keywordMatch ? keywordMatch[1] : \"\"\n\n    return [\n      \"insert\",\n      \"update\",\n      \"delete\",\n      \"create\",\n      \"alter\",\n      \"drop\",\n      \"truncate\",\n      \"merge\",\n      \"replace\"\n    ].includes(keyword)\n  }\n\n  /** @returns {boolean} - Whether read only.  */\n  isReadOnly() {\n    return Boolean(this.getArgs().readOnly)\n  }\n\n  /**\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async rollbackTransaction() {\n    await this._transactionsActionsMutex.sync(async () => {\n      try {\n        await this._rollbackTransactionAction()\n      } finally {\n        this._transactionsCount--\n      }\n    })\n  }\n\n  /**\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async _rollbackTransactionAction() {\n    await this.query(\"ROLLBACK\")\n  }\n\n  /**\n   * @returns {string} - The generate save point name.\n   */\n  generateSavePointName() {\n    return `sp${new UUID(4).format().replaceAll(\"-\", \"\")}`\n  }\n\n  /**\n   * @param {string} savePointName - Save point name.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async startSavePoint(savePointName) {\n    await this._transactionsActionsMutex.sync(async () => {\n      await this._startSavePointAction(savePointName)\n    })\n  }\n\n  /**\n   * @param {string} savePointName - Save point name.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async _startSavePointAction(savePointName) {\n    await this.query(`SAVEPOINT ${savePointName}`)\n  }\n\n  /**\n   * @param {string} tableName - Table name.\n   * @param {string} oldColumnName - Previous column name.\n   * @param {string} newColumnName - New column name.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async renameColumn(tableName, oldColumnName, newColumnName) {\n    this._assertNotReadOnly()\n    const tableColumn = new TableColumn(oldColumnName)\n\n    tableColumn.setNewName(newColumnName)\n\n    const tableData = new TableData(tableName)\n\n    tableData.addColumn(tableColumn)\n\n    const alterTableSQLs = await this.alterTableSQLs(tableData)\n\n    for (const alterTableSQL of alterTableSQLs) {\n      await this.query(alterTableSQL)\n    }\n  }\n\n  /**\n   * @param {string} savePointName - Save point name.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async releaseSavePoint(savePointName) {\n    await this._transactionsActionsMutex.sync(async () => {\n      await this._releaseSavePointAction(savePointName)\n    })\n  }\n\n  /**\n   * @param {string} savePointName - Save point name.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async _releaseSavePointAction(savePointName) {\n    try {\n      await this.query(`RELEASE SAVEPOINT ${savePointName}`)\n    } catch (error) {\n      const message = error instanceof Error ? error.message : `${error}`\n\n      // Savepoint may already be gone if the database rolled back automatically\n      if (message.toLowerCase().includes(\"savepoint\") && message.toLowerCase().includes(\"does not exist\")) {\n        this.logger.debug(`Release savepoint ignored because it no longer exists: ${savePointName}`)\n        return\n      }\n\n      throw error\n    }\n  }\n\n  /**\n   * @param {string} savePointName - Save point name.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async rollbackSavePoint(savePointName) {\n    await this._transactionsActionsMutex.sync(async () => {\n      await this._rollbackSavePointAction(savePointName)\n    })\n  }\n\n  /**\n   * @param {string} savePointName - Save point name.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async _rollbackSavePointAction(savePointName) {\n    await this.query(`ROLLBACK TO SAVEPOINT ${savePointName}`)\n  }\n\n  /**\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async truncateAllTables() {\n    this._assertNotReadOnly()\n    await this.withDisabledForeignKeys(async () => {\n      let tries = 0\n\n      while(tries <= 5) {\n        tries++\n\n        const tables = await this.getTables()\n        const truncateErrors = []\n\n        for (const table of tables) {\n          if (table.getName() != \"schema_migrations\") {\n            try {\n              await table.truncate({cascade: true})\n            } catch (error) {\n              console.error(error)\n              truncateErrors.push(error)\n            }\n          }\n        }\n\n        if (truncateErrors.length == 0) {\n          break\n        } else if (tries <= 5) {\n          // Retry\n        } else {\n          throw truncateErrors[0]\n        }\n      }\n    })\n  }\n\n  /**\n   * @param {UpdateSqlArgsType} args - Options object.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async update(args) {\n    this._assertNotReadOnly()\n    const sql = this.updateSql(args)\n\n    await this.query(sql)\n  }\n\n  /**\n   * @abstract\n   * @param {UpdateSqlArgsType} args - Options object.\n   * @returns {string} - SQL string.\n   */\n  updateSql(args) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'disableForeignKeys' not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @param {UpsertSqlArgsType} args - Options object.\n   * @returns {string} - SQL string.\n   */\n  upsertSql(args) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'upsertSql' not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  disableForeignKeys() {\n    throw new Error(\"'disableForeignKeys' not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  enableForeignKeys() {\n    throw new Error(\"'enableForeignKeys' not implemented\")\n  }\n\n  /**\n   * @param {function() : void} callback - Callback function.\n   * @returns {Promise<any>} - Resolves with the with disabled foreign keys.\n   */\n  async withDisabledForeignKeys(callback) {\n    await this.disableForeignKeys()\n\n    try {\n      return await callback()\n    } finally {\n      await this.enableForeignKeys()\n    }\n  }\n\n  /**\n   * Blocks until a named advisory lock is acquired on this connection.\n   * Advisory locks are connection-scoped and do not interact with row or\n   * table locks; they are purely cooperative between callers that use the\n   * same name and let you serialize functionality without blocking readers\n   * or writers that do not participate in the same lock.\n   *\n   * @abstract\n   * @param {string} name - Lock name.\n   * @param {{timeoutMs?: number | null}} [_args] - Optional timeout in milliseconds; `null` or undefined blocks forever.\n   * @returns {Promise<boolean>} - Resolves to true when the lock has been acquired, false if the timeout elapsed.\n   */\n  acquireAdvisoryLock(name, _args = {}) { // eslint-disable-line no-unused-vars\n    throw new Error(`'acquireAdvisoryLock' not implemented for ${this.constructor.name}`)\n  }\n\n  /**\n   * Attempts to acquire a named advisory lock without blocking.\n   *\n   * @abstract\n   * @param {string} name - Lock name.\n   * @returns {Promise<boolean>} - Resolves to true if the lock was acquired, false if it was already held.\n   */\n  tryAcquireAdvisoryLock(name) { // eslint-disable-line no-unused-vars\n    throw new Error(`'tryAcquireAdvisoryLock' not implemented for ${this.constructor.name}`)\n  }\n\n  /**\n   * Releases a named advisory lock previously acquired on this connection.\n   *\n   * @abstract\n   * @param {string} name - Lock name.\n   * @returns {Promise<boolean>} - Resolves to true if the lock was held by this session and has now been released.\n   */\n  releaseAdvisoryLock(name) { // eslint-disable-line no-unused-vars\n    throw new Error(`'releaseAdvisoryLock' not implemented for ${this.constructor.name}`)\n  }\n\n  /**\n   * Checks whether a named advisory lock is currently held by any session.\n   * Intended as an introspection helper; callers who need to act on the\n   * result should prefer `tryAcquireAdvisoryLock` to avoid a TOCTOU race.\n   *\n   * @abstract\n   * @param {string} name - Lock name.\n   * @returns {Promise<boolean>} - Resolves to true if the lock is held by any session.\n   */\n  isAdvisoryLockHeld(name) { // eslint-disable-line no-unused-vars\n    throw new Error(`'isAdvisoryLockHeld' not implemented for ${this.constructor.name}`)\n  }\n}\n"]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/database/drivers/mssql/index.js"],"names":[],"mappings":"AAwBA;IAUM,6CAAqD;IAavD,0DAA+B;IAqBjC;;;;;OAKG;IACH,gCALW,MAAM,SAEd;QAAuB,WAAW;KAClC,GAAU,MAAM,EAAE,CAOpB;IAqCD;;OAEG;IACH,mBAFa,OAAO,CAAC,MAAM,CAAC,CAM3B;IA2BD;;OAEG;IACH,kBAFa,MAAM,CAEiB;IA6CpC;;;OAGG;IACH,cAHW,OAAO,GACL,MAAM,CAUlB;IAED;;;OAGG;IACH,aAHW,OAAO,GACL,MAAM,GAAG,MAAM,CAS3B;
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/database/drivers/mssql/index.js"],"names":[],"mappings":"AAwBA;IAUM,6CAAqD;IAavD,0DAA+B;IAqBjC;;;;;OAKG;IACH,gCALW,MAAM,SAEd;QAAuB,WAAW;KAClC,GAAU,MAAM,EAAE,CAOpB;IAqCD;;OAEG;IACH,mBAFa,OAAO,CAAC,MAAM,CAAC,CAM3B;IA2BD;;OAEG;IACH,kBAFa,MAAM,CAEiB;IA6CpC;;;OAGG;IACH,cAHW,OAAO,GACL,MAAM,CAUlB;IAED;;;OAGG;IACH,aAHW,OAAO,GACL,MAAM,GAAG,MAAM,CAS3B;IAoED,6BAOC;IAIqB,8BAA2C;CAsNlE;iBAjgBgB,YAAY;kBAWX,OAAO;oBADL,cAAc"}
|