velocious 1.0.175 → 1.0.177

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 (32) hide show
  1. package/build/src/database/drivers/base.d.ts +3 -2
  2. package/build/src/database/drivers/base.d.ts.map +1 -1
  3. package/build/src/database/drivers/base.js +2 -2
  4. package/build/src/database/query/index.d.ts +6 -1
  5. package/build/src/database/query/index.d.ts.map +1 -1
  6. package/build/src/database/query/index.js +21 -1
  7. package/build/src/database/query/join-object.d.ts +6 -0
  8. package/build/src/database/query/join-object.d.ts.map +1 -1
  9. package/build/src/database/query/join-object.js +26 -12
  10. package/build/src/database/query/model-class-query.d.ts +5 -0
  11. package/build/src/database/query/model-class-query.d.ts.map +1 -1
  12. package/build/src/database/query/model-class-query.js +32 -1
  13. package/build/src/database/query/where-not.d.ts +9 -0
  14. package/build/src/database/query/where-not.d.ts.map +1 -0
  15. package/build/src/database/query/where-not.js +19 -0
  16. package/build/src/testing/base-expect.d.ts +13 -0
  17. package/build/src/testing/base-expect.d.ts.map +1 -0
  18. package/build/src/testing/base-expect.js +14 -0
  19. package/build/src/testing/expect-to-change.d.ts +27 -0
  20. package/build/src/testing/expect-to-change.d.ts.map +1 -0
  21. package/build/src/testing/expect-to-change.js +43 -0
  22. package/build/src/testing/expect-utils.d.ts +45 -0
  23. package/build/src/testing/expect-utils.d.ts.map +1 -0
  24. package/build/src/testing/expect-utils.js +190 -0
  25. package/build/src/testing/expect.d.ts +137 -0
  26. package/build/src/testing/expect.d.ts.map +1 -0
  27. package/build/src/testing/expect.js +619 -0
  28. package/build/src/testing/test.d.ts +4 -152
  29. package/build/src/testing/test.d.ts.map +1 -1
  30. package/build/src/testing/test.js +3 -655
  31. package/build/tsconfig.tsbuildinfo +1 -1
  32. package/package.json +3 -3
@@ -8,10 +8,10 @@ export default class VelociousDatabaseDriversBase {
8
8
  idSeq: number | undefined;
9
9
  _args: import("../../configuration-types.js").DatabaseConfigurationType;
10
10
  configuration: import("../../configuration.js").default;
11
- mutex: any;
11
+ mutex: Mutex;
12
12
  logger: Logger;
13
13
  _transactionsCount: number;
14
- _transactionsActionsMutex: any;
14
+ _transactionsActionsMutex: Mutex;
15
15
  /**
16
16
  * @param {string} tableName - Table name.
17
17
  * @param {string} columnName - Column name.
@@ -457,6 +457,7 @@ export type UpdateSqlArgsType = {
457
457
  */
458
458
  tableName: string;
459
459
  };
460
+ import Mutex from "epic-locks/build/mutex.js";
460
461
  import { Logger } from "../../logger.js";
461
462
  import Query from "../query/index.js";
462
463
  //# sourceMappingURL=base.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"base.d.ts","sourceRoot":"","sources":["../../../../src/database/drivers/base.js"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"base.d.ts","sourceRoot":"","sources":["../../../../src/database/drivers/base.js"],"names":[],"mappings":"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"}
@@ -39,7 +39,7 @@
39
39
  import { Logger } from "../../logger.js";
40
40
  import Query from "../query/index.js";
41
41
  import Handler from "../handler.js";
42
- import Mutex from "epic-locks/src/mutex.js";
42
+ import Mutex from "epic-locks/build/mutex.js";
43
43
  import strftime from "strftime";
44
44
  import UUID from "pure-uuid";
45
45
  import TableData from "../table-data/index.js";
@@ -784,4 +784,4 @@ export default class VelociousDatabaseDriversBase {
784
784
  }
785
785
  }
786
786
  }
787
- //# 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}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\nimport {Logger} from \"../../logger.js\"\nimport Query from \"../query/index.js\"\nimport Handler from \"../handler.js\"\nimport Mutex from \"epic-locks/src/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\nexport default class VelociousDatabaseDriversBase {\n  /** @type {number | undefined} */\n  idSeq = undefined\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._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   * @abstract\n   * @param {string} databaseName - Database name.\n   * @param {object} [args] - Options object.\n   * @param {boolean} [args.ifNotExists] - Whether if not exists.\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 {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) throw new Error(`Couldn't find a table by that name \"${name}\" in: ${tableNames.join(\", \")}`)\n\n    return table\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 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   * @abstract\n   * @param {string} tableName - Table name.\n   * @param {Array<string>} columns - Column names.\n   * @param {Array<Array<string>>} rows - Rows to insert.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async insertMultiple(tableName, columns, rows) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'insertMultiple' not implemented\")\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   * @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    let transactionStarted = false\n    let savePointStarted = false\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    } 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      throw error\n    }\n\n    return result\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   * @param {string} sql - SQL string.\n   * @returns {Promise<QueryResultType>} - Resolves with the query.\n   */\n  async query(sql) {\n    this._assertWritableQuery(sql)\n\n    let tries = 0\n\n    while(tries < 5) {\n      tries++\n\n      try {\n        return await this._queryActual(sql)\n      } catch (error) {\n        if (error instanceof Error && tries < 5 && this.retryableDatabaseError(error)) {\n          await wait(100)\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   * @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 {boolean} - Whether retryable database error.\n   */\n  retryableDatabaseError(_error) { // eslint-disable-line no-unused-vars\n    return 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      await this._rollbackTransactionAction()\n      this._transactionsCount--\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   * @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"]}
787
+ //# 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}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\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\nexport default class VelociousDatabaseDriversBase {\n  /** @type {number | undefined} */\n  idSeq = undefined\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._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   * @abstract\n   * @param {string} databaseName - Database name.\n   * @param {object} [args] - Options object.\n   * @param {boolean} [args.ifNotExists] - Whether if not exists.\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 {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) throw new Error(`Couldn't find a table by that name \"${name}\" in: ${tableNames.join(\", \")}`)\n\n    return table\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 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   * @abstract\n   * @param {string} tableName - Table name.\n   * @param {Array<string>} columns - Column names.\n   * @param {Array<Array<string>>} rows - Rows to insert.\n   * @returns {Promise<void>} - Resolves when complete.\n   */\n  async insertMultiple(tableName, columns, rows) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'insertMultiple' not implemented\")\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   * @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    let transactionStarted = false\n    let savePointStarted = false\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    } 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      throw error\n    }\n\n    return result\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   * @param {string} sql - SQL string.\n   * @returns {Promise<QueryResultType>} - Resolves with the query.\n   */\n  async query(sql) {\n    this._assertWritableQuery(sql)\n\n    let tries = 0\n\n    while(tries < 5) {\n      tries++\n\n      try {\n        return await this._queryActual(sql)\n      } catch (error) {\n        if (error instanceof Error && tries < 5 && this.retryableDatabaseError(error)) {\n          await wait(100)\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   * @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 {boolean} - Whether retryable database error.\n   */\n  retryableDatabaseError(_error) { // eslint-disable-line no-unused-vars\n    return 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      await this._rollbackTransactionAction()\n      this._transactionsCount--\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   * @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"]}
@@ -42,6 +42,11 @@ export default class VelociousDatabaseQuery {
42
42
  _selects: SelectBase[];
43
43
  /** @type {import("./where-base.js").default[]} */
44
44
  _wheres: import("./where-base.js").default[];
45
+ /**
46
+ * @param {WhereArgumentType} where - Where.
47
+ * @returns {this} This query instance
48
+ */
49
+ where(where: WhereArgumentType): this;
45
50
  /** @returns {this} - The clone. */
46
51
  clone(): this;
47
52
  /** @returns {import("./from-base.js").default[]} - The froms. */
@@ -124,7 +129,7 @@ export default class VelociousDatabaseQuery {
124
129
  * @param {WhereArgumentType} where - Where.
125
130
  * @returns {this} This query instance
126
131
  */
127
- where(where: WhereArgumentType): this;
132
+ whereNot(where: WhereArgumentType): this;
128
133
  /**
129
134
  * Resolves the current driver lazily.
130
135
  * @returns {import("../drivers/base.js").default} - A value.
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/database/query/index.js"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/database/query/index.js"],"names":[],"mappings":"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"}
@@ -8,6 +8,7 @@ import OrderPlain from "./order-plain.js";
8
8
  import SelectBase from "./select-base.js";
9
9
  import SelectPlain from "./select-plain.js";
10
10
  import WhereHash from "./where-hash.js";
11
+ import WhereNot from "./where-not.js";
11
12
  import WherePlain from "./where-plain.js";
12
13
  /**
13
14
  * @typedef {{[key: string]: boolean | NestedPreloadRecord }} NestedPreloadRecord
@@ -57,6 +58,9 @@ export default class VelociousDatabaseQuery {
57
58
  this._selects = selects;
58
59
  /** @type {import("./where-base.js").default[]} */
59
60
  this._wheres = wheres;
61
+ const boundWhere = this.where.bind(this);
62
+ boundWhere.not = this.whereNot.bind(this);
63
+ this.where = boundWhere;
60
64
  }
61
65
  /** @returns {this} - The clone. */
62
66
  clone() {
@@ -258,6 +262,22 @@ export default class VelociousDatabaseQuery {
258
262
  }
259
263
  return this;
260
264
  }
265
+ /**
266
+ * @param {WhereArgumentType} where - Where.
267
+ * @returns {this} This query instance
268
+ */
269
+ whereNot(where) {
270
+ if (typeof where == "string") {
271
+ this._wheres.push(new WhereNot(new WherePlain(this, where)));
272
+ }
273
+ else if (typeof where == "object" && (where.constructor.name == "object" || where.constructor.name == "Object")) {
274
+ this._wheres.push(new WhereNot(new WhereHash(this, where)));
275
+ }
276
+ else {
277
+ throw new Error(`Invalid type of where: ${typeof where} (${where.constructor.name})`);
278
+ }
279
+ return this;
280
+ }
261
281
  /**
262
282
  * Resolves the current driver lazily.
263
283
  * @returns {import("../drivers/base.js").default} - A value.
@@ -266,4 +286,4 @@ export default class VelociousDatabaseQuery {
266
286
  return this._driverFn();
267
287
  }
268
288
  }
269
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/database/query/index.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport FromPlain from \"./from-plain.js\"\nimport {isPlainObject} from \"is-plain-object\"\nimport JoinObject from \"./join-object.js\"\nimport JoinPlain from \"./join-plain.js\"\nimport {Logger} from \"../../logger.js\"\nimport OrderPlain from \"./order-plain.js\"\nimport SelectBase from \"./select-base.js\"\nimport SelectPlain from \"./select-plain.js\"\nimport WhereHash from \"./where-hash.js\"\nimport WherePlain from \"./where-plain.js\"\n\n/**\n * @typedef {{[key: string]: boolean | NestedPreloadRecord }} NestedPreloadRecord\n * @typedef {string | string[] | import(\"./select-base.js\").default | import(\"./select-base.js\").default[]} SelectArgumentType\n * @typedef {object | string} WhereArgumentType\n */\n\n/**\n * @typedef {object} QueryArgsType\n * @property {import(\"../drivers/base.js\").default | (() => import(\"../drivers/base.js\").default)} driver - Driver instance or factory for query execution.\n * @property {Array<import(\"./from-base.js\").default>} [froms] - FROM clauses for the query.\n * @property {string[]} [groups] - GROUP BY columns.\n * @property {Array<import(\"./join-base.js\").default>} [joins] - JOIN clauses for the query.\n * @property {import(\"../handler.js\").default} handler - Handler used for executing and transforming results.\n * @property {number | null} [limit] - LIMIT clause value.\n * @property {number | null} [offset] - OFFSET clause value.\n * @property {Array<import(\"./order-base.js\").default>} [orders] - ORDER BY clauses.\n * @property {number | null} [page] - Page number for pagination.\n * @property {number} [perPage] - Records per page for pagination.\n * @property {NestedPreloadRecord} [preload] - Preload graph for related records.\n * @property {Array<import(\"./select-base.js\").default>} [selects] - SELECT clauses for the query.\n * @property {boolean} [distinct] - Whether the query should use DISTINCT.\n * @property {Array<import(\"./where-base.js\").default>} [wheres] - WHERE conditions for the query.\n */\n\nexport default class VelociousDatabaseQuery {\n  /**\n   * @param {QueryArgsType} args - Options object.\n   */\n  constructor({\n    driver,\n    froms = [],\n    groups = [],\n    joins = [],\n    handler,\n    limit = null,\n    offset = null,\n    orders = [],\n    page = null,\n    perPage,\n    preload = {},\n    distinct = false,\n    selects = [],\n    wheres = []\n  }) {\n    if (!driver) throw new Error(\"No driver given to query\")\n    if (!handler) throw new Error(\"No handler given to query\")\n\n    /** @type {() => import(\"../drivers/base.js\").default} */\n    this._driverFn = typeof driver === \"function\" ? driver : () => driver\n    this.handler = handler\n    this.logger = new Logger(this)\n    this._froms = froms\n    this._groups = groups\n    this._joins = joins\n    this._limit = limit\n    this._offset = offset\n    this._orders = orders\n    this._page = page\n    this._perPage = perPage\n    this._preload = preload\n    this._distinct = distinct\n    this._selects = selects\n\n    /** @type {import(\"./where-base.js\").default[]} */\n    this._wheres = wheres\n  }\n\n  /** @returns {this} - The clone.  */\n  clone() {\n    const QueryClass = /** @type {new (args: QueryArgsType) => this} */ (this.constructor)\n    const newQuery = new QueryClass({\n      driver: this._driverFn,\n      froms: [...this._froms],\n      handler: this.handler.clone(),\n      groups: [...this._groups],\n      joins: [...this._joins],\n      limit: this._limit,\n      offset: this._offset,\n      orders: [...this._orders],\n      page: this._page,\n      perPage: this._perPage,\n      preload: {...this._preload},\n      distinct: this._distinct,\n      selects: [...this._selects],\n      wheres: [...this._wheres]\n    })\n\n    return newQuery\n  }\n\n  /** @returns {import(\"./from-base.js\").default[]} - The froms.  */\n  getFroms() {\n    return this._froms\n  }\n\n  /** @returns {string[]} - The groups.  */\n  getGroups() {\n    return this._groups\n  }\n\n  /** @returns {import(\"../query-parser/options.js\").default} - The options options.  */\n  getOptions() { return this.driver.options() }\n\n  /** @returns {Array<import(\"./select-base.js\").default>} - The selects.  */\n  getSelects() { return this._selects }\n\n  /**\n   * @param {string|import(\"./from-base.js\").default} from - From.\n   * @returns {this} - The from.\n   */\n  from(from) {\n    if (typeof from == \"string\") from = new FromPlain(from)\n\n    this._froms.push(from)\n    return this\n  }\n\n  /**\n   * @param {string} group - Group.\n   * @returns {this} - The group.\n   */\n  group(group) {\n    this._groups.push(group)\n    return this\n  }\n\n  /**\n   * @param {string | import(\"./join-object.js\").JoinObject} join - Join clause or join descriptor.\n   * @returns {this} - The joins.\n   */\n  joins(join) {\n    if (typeof join == \"string\") {\n      this._joins.push(new JoinPlain(join))\n    } else if (isPlainObject(join)) {\n      this._joins.push(new JoinObject(join))\n    } else {\n      throw new Error(`Unknown type of join: ${typeof join}`)\n    }\n\n    return this\n  }\n\n  /**\n   * @param {number} value - Value to use.\n   * @returns {this} - The limit.\n   */\n  limit(value) {\n    this._limit = value\n    return this\n  }\n\n  /**\n   * @param {number} value - Value to use.\n   * @returns {this} - The offset.\n   */\n  offset(value) {\n    this._offset = value\n    return this\n  }\n\n  /**\n   * @param {string | number} order - Order.\n   * @returns {this} - The order.\n   */\n  order(order) {\n    if (typeof order == \"string\") {\n      this._orders.push(new OrderPlain(this, order))\n    } else if (typeof order == \"number\") {\n      this._orders.push(new OrderPlain(this, `${order}`))\n    } else {\n      throw new Error(`Unknown order type: ${typeof order}`)\n    }\n\n    return this\n  }\n\n  /**\n   * @param {number} pageNumber - Page number.\n   * @returns {this} - The page.\n   */\n  page(pageNumber) {\n    const perPage = this._perPage || 30\n    const offset = (pageNumber - 1) * perPage\n    const limit = perPage\n\n    this._page = pageNumber\n    this.limit(limit)\n    this.offset(offset)\n    return this\n  }\n\n  /**\n   * @param {number} perPage - Page size.\n   * @returns {this} - The per page.\n   */\n  perPage(perPage) {\n    this._perPage = perPage\n    return this\n  }\n\n  /**\n   * @param {string | number} order - Order.\n   * @returns {this} - The reorder.\n   */\n  reorder(order) {\n    this._orders = []\n    this.order(order)\n    return this\n  }\n\n  /** @returns {this} - The reverse order.  */\n  reverseOrder() {\n    for (const order of this._orders) {\n      order.setReverseOrder(true)\n    }\n\n    return this\n  }\n\n  /**\n   * @param {boolean} [value] - Value to use.\n   * @returns {this} - The distinct.\n   */\n  distinct(value = true) {\n    this._distinct = value\n    return this\n  }\n\n  /**\n   * @param {SelectArgumentType} select - Select.\n   * @returns {this} - The select.\n   */\n  select(select) {\n    if (Array.isArray(select)) {\n      for (const selectInArray of select) {\n        this.select(selectInArray)\n      }\n\n      return this\n    }\n\n    if (typeof select == \"string\") {\n      this._selects.push(new SelectPlain(select))\n    } else if (select instanceof SelectBase) {\n      this._selects.push(select)\n    } else {\n      throw new Error(`Invalid select type: ${typeof select}`)\n    }\n\n    return this\n  }\n\n  /**\n   * @returns {Promise<Array<object>>} Array of results from the database\n   */\n  async _executeQuery() {\n    const sql = this.toSql()\n    const results = await this.driver.query(sql)\n\n    this.logger.debug(() => [\"SQL:\", sql])\n\n    return results\n  }\n\n  /** @returns {Promise<Array<object>>} Array of results from the database */\n  async results() {\n    return await this._executeQuery()\n  }\n\n  /**\n   * Generates SQL string representing this query\n   * @returns {string} SQL string representing this query\n   */\n  toSql() { return this.driver.queryToSql(this) }\n\n  /**\n   * @param {WhereArgumentType} where - Where.\n   * @returns {this} This query instance\n   */\n  where(where) {\n    if (typeof where == \"string\") {\n      this._wheres.push(new WherePlain(this, where))\n    } else if (typeof where == \"object\" && (where.constructor.name == \"object\" || where.constructor.name == \"Object\")) {\n      this._wheres.push(new WhereHash(this, where))\n    } else {\n      throw new Error(`Invalid type of where: ${typeof where} (${where.constructor.name})`)\n    }\n\n    return this\n  }\n\n  /**\n   * Resolves the current driver lazily.\n   * @returns {import(\"../drivers/base.js\").default} - A value.\n   */\n  get driver() {\n    return this._driverFn()\n  }\n}\n"]}
289
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/database/query/index.js"],"names":[],"mappings":"AAAA,YAAY;AAEZ,OAAO,SAAS,MAAM,iBAAiB,CAAA;AACvC,OAAO,EAAC,aAAa,EAAC,MAAM,iBAAiB,CAAA;AAC7C,OAAO,UAAU,MAAM,kBAAkB,CAAA;AACzC,OAAO,SAAS,MAAM,iBAAiB,CAAA;AACvC,OAAO,EAAC,MAAM,EAAC,MAAM,iBAAiB,CAAA;AACtC,OAAO,UAAU,MAAM,kBAAkB,CAAA;AACzC,OAAO,UAAU,MAAM,kBAAkB,CAAA;AACzC,OAAO,WAAW,MAAM,mBAAmB,CAAA;AAC3C,OAAO,SAAS,MAAM,iBAAiB,CAAA;AACvC,OAAO,QAAQ,MAAM,gBAAgB,CAAA;AACrC,OAAO,UAAU,MAAM,kBAAkB,CAAA;AAEzC;;;;GAIG;AAEH;;;;;;;;;;;;;;;;GAgBG;AAEH,MAAM,CAAC,OAAO,OAAO,sBAAsB;IACzC;;OAEG;IACH,YAAY,EACV,MAAM,EACN,KAAK,GAAG,EAAE,EACV,MAAM,GAAG,EAAE,EACX,KAAK,GAAG,EAAE,EACV,OAAO,EACP,KAAK,GAAG,IAAI,EACZ,MAAM,GAAG,IAAI,EACb,MAAM,GAAG,EAAE,EACX,IAAI,GAAG,IAAI,EACX,OAAO,EACP,OAAO,GAAG,EAAE,EACZ,QAAQ,GAAG,KAAK,EAChB,OAAO,GAAG,EAAE,EACZ,MAAM,GAAG,EAAE,EACZ;QACC,IAAI,CAAC,MAAM;YAAE,MAAM,IAAI,KAAK,CAAC,0BAA0B,CAAC,CAAA;QACxD,IAAI,CAAC,OAAO;YAAE,MAAM,IAAI,KAAK,CAAC,2BAA2B,CAAC,CAAA;QAE1D,yDAAyD;QACzD,IAAI,CAAC,SAAS,GAAG,OAAO,MAAM,KAAK,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,MAAM,CAAA;QACrE,IAAI,CAAC,OAAO,GAAG,OAAO,CAAA;QACtB,IAAI,CAAC,MAAM,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,CAAA;QAC9B,IAAI,CAAC,MAAM,GAAG,KAAK,CAAA;QACnB,IAAI,CAAC,OAAO,GAAG,MAAM,CAAA;QACrB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAA;QACnB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAA;QACnB,IAAI,CAAC,OAAO,GAAG,MAAM,CAAA;QACrB,IAAI,CAAC,OAAO,GAAG,MAAM,CAAA;QACrB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAA;QACjB,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAA;QACvB,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAA;QACvB,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAA;QACzB,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAA;QAEvB,kDAAkD;QAClD,IAAI,CAAC,OAAO,GAAG,MAAM,CAAA;QAErB,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QACxC,UAAU,CAAC,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QACzC,IAAI,CAAC,KAAK,GAAG,UAAU,CAAA;IACzB,CAAC;IAED,oCAAoC;IACpC,KAAK;QACH,MAAM,UAAU,GAAG,gDAAgD,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAA;QACtF,MAAM,QAAQ,GAAG,IAAI,UAAU,CAAC;YAC9B,MAAM,EAAE,IAAI,CAAC,SAAS;YACtB,KAAK,EAAE,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC;YACvB,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE;YAC7B,MAAM,EAAE,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC;YACzB,KAAK,EAAE,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC;YACvB,KAAK,EAAE,IAAI,CAAC,MAAM;YAClB,MAAM,EAAE,IAAI,CAAC,OAAO;YACpB,MAAM,EAAE,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC;YACzB,IAAI,EAAE,IAAI,CAAC,KAAK;YAChB,OAAO,EAAE,IAAI,CAAC,QAAQ;YACtB,OAAO,EAAE,EAAC,GAAG,IAAI,CAAC,QAAQ,EAAC;YAC3B,QAAQ,EAAE,IAAI,CAAC,SAAS;YACxB,OAAO,EAAE,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC;YAC3B,MAAM,EAAE,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC;SAC1B,CAAC,CAAA;QAEF,OAAO,QAAQ,CAAA;IACjB,CAAC;IAED,kEAAkE;IAClE,QAAQ;QACN,OAAO,IAAI,CAAC,MAAM,CAAA;IACpB,CAAC;IAED,yCAAyC;IACzC,SAAS;QACP,OAAO,IAAI,CAAC,OAAO,CAAA;IACrB,CAAC;IAED,sFAAsF;IACtF,UAAU,KAAK,OAAO,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAA,CAAC,CAAC;IAE7C,2EAA2E;IAC3E,UAAU,KAAK,OAAO,IAAI,CAAC,QAAQ,CAAA,CAAC,CAAC;IAErC;;;OAGG;IACH,IAAI,CAAC,IAAI;QACP,IAAI,OAAO,IAAI,IAAI,QAAQ;YAAE,IAAI,GAAG,IAAI,SAAS,CAAC,IAAI,CAAC,CAAA;QAEvD,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QACtB,OAAO,IAAI,CAAA;IACb,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,KAAK;QACT,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;QACxB,OAAO,IAAI,CAAA;IACb,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,IAAI;QACR,IAAI,OAAO,IAAI,IAAI,QAAQ,EAAE,CAAC;YAC5B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,SAAS,CAAC,IAAI,CAAC,CAAC,CAAA;QACvC,CAAC;aAAM,IAAI,aAAa,CAAC,IAAI,CAAC,EAAE,CAAC;YAC/B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,UAAU,CAAC,IAAI,CAAC,CAAC,CAAA;QACxC,CAAC;aAAM,CAAC;YACN,MAAM,IAAI,KAAK,CAAC,yBAAyB,OAAO,IAAI,EAAE,CAAC,CAAA;QACzD,CAAC;QAED,OAAO,IAAI,CAAA;IACb,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,KAAK;QACT,IAAI,CAAC,MAAM,GAAG,KAAK,CAAA;QACnB,OAAO,IAAI,CAAA;IACb,CAAC;IAED;;;OAGG;IACH,MAAM,CAAC,KAAK;QACV,IAAI,CAAC,OAAO,GAAG,KAAK,CAAA;QACpB,OAAO,IAAI,CAAA;IACb,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,KAAK;QACT,IAAI,OAAO,KAAK,IAAI,QAAQ,EAAE,CAAC;YAC7B,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,UAAU,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,CAAA;QAChD,CAAC;aAAM,IAAI,OAAO,KAAK,IAAI,QAAQ,EAAE,CAAC;YACpC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,UAAU,CAAC,IAAI,EAAE,GAAG,KAAK,EAAE,CAAC,CAAC,CAAA;QACrD,CAAC;aAAM,CAAC;YACN,MAAM,IAAI,KAAK,CAAC,uBAAuB,OAAO,KAAK,EAAE,CAAC,CAAA;QACxD,CAAC;QAED,OAAO,IAAI,CAAA;IACb,CAAC;IAED;;;OAGG;IACH,IAAI,CAAC,UAAU;QACb,MAAM,OAAO,GAAG,IAAI,CAAC,QAAQ,IAAI,EAAE,CAAA;QACnC,MAAM,MAAM,GAAG,CAAC,UAAU,GAAG,CAAC,CAAC,GAAG,OAAO,CAAA;QACzC,MAAM,KAAK,GAAG,OAAO,CAAA;QAErB,IAAI,CAAC,KAAK,GAAG,UAAU,CAAA;QACvB,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAA;QACjB,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;QACnB,OAAO,IAAI,CAAA;IACb,CAAC;IAED;;;OAGG;IACH,OAAO,CAAC,OAAO;QACb,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAA;QACvB,OAAO,IAAI,CAAA;IACb,CAAC;IAED;;;OAGG;IACH,OAAO,CAAC,KAAK;QACX,IAAI,CAAC,OAAO,GAAG,EAAE,CAAA;QACjB,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAA;QACjB,OAAO,IAAI,CAAA;IACb,CAAC;IAED,4CAA4C;IAC5C,YAAY;QACV,KAAK,MAAM,KAAK,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjC,KAAK,CAAC,eAAe,CAAC,IAAI,CAAC,CAAA;QAC7B,CAAC;QAED,OAAO,IAAI,CAAA;IACb,CAAC;IAED;;;OAGG;IACH,QAAQ,CAAC,KAAK,GAAG,IAAI;QACnB,IAAI,CAAC,SAAS,GAAG,KAAK,CAAA;QACtB,OAAO,IAAI,CAAA;IACb,CAAC;IAED;;;OAGG;IACH,MAAM,CAAC,MAAM;QACX,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC;YAC1B,KAAK,MAAM,aAAa,IAAI,MAAM,EAAE,CAAC;gBACnC,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,CAAA;YAC5B,CAAC;YAED,OAAO,IAAI,CAAA;QACb,CAAC;QAED,IAAI,OAAO,MAAM,IAAI,QAAQ,EAAE,CAAC;YAC9B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,WAAW,CAAC,MAAM,CAAC,CAAC,CAAA;QAC7C,CAAC;aAAM,IAAI,MAAM,YAAY,UAAU,EAAE,CAAC;YACxC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;QAC5B,CAAC;aAAM,CAAC;YACN,MAAM,IAAI,KAAK,CAAC,wBAAwB,OAAO,MAAM,EAAE,CAAC,CAAA;QAC1D,CAAC;QAED,OAAO,IAAI,CAAA;IACb,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,aAAa;QACjB,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,EAAE,CAAA;QACxB,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;QAE5C,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC,CAAA;QAEtC,OAAO,OAAO,CAAA;IAChB,CAAC;IAED,2EAA2E;IAC3E,KAAK,CAAC,OAAO;QACX,OAAO,MAAM,IAAI,CAAC,aAAa,EAAE,CAAA;IACnC,CAAC;IAED;;;OAGG;IACH,KAAK,KAAK,OAAO,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,CAAA,CAAC,CAAC;IAE/C;;;OAGG;IACH,KAAK,CAAC,KAAK;QACT,IAAI,OAAO,KAAK,IAAI,QAAQ,EAAE,CAAC;YAC7B,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,UAAU,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,CAAA;QAChD,CAAC;aAAM,IAAI,OAAO,KAAK,IAAI,QAAQ,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,IAAI,IAAI,QAAQ,IAAI,KAAK,CAAC,WAAW,CAAC,IAAI,IAAI,QAAQ,CAAC,EAAE,CAAC;YAClH,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,SAAS,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,CAAA;QAC/C,CAAC;aAAM,CAAC;YACN,MAAM,IAAI,KAAK,CAAC,0BAA0B,OAAO,KAAK,KAAK,KAAK,CAAC,WAAW,CAAC,IAAI,GAAG,CAAC,CAAA;QACvF,CAAC;QAED,OAAO,IAAI,CAAA;IACb,CAAC;IAED;;;OAGG;IACH,QAAQ,CAAC,KAAK;QACZ,IAAI,OAAO,KAAK,IAAI,QAAQ,EAAE,CAAC;YAC7B,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,QAAQ,CAAC,IAAI,UAAU,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC,CAAA;QAC9D,CAAC;aAAM,IAAI,OAAO,KAAK,IAAI,QAAQ,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,IAAI,IAAI,QAAQ,IAAI,KAAK,CAAC,WAAW,CAAC,IAAI,IAAI,QAAQ,CAAC,EAAE,CAAC;YAClH,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,QAAQ,CAAC,IAAI,SAAS,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC,CAAA;QAC7D,CAAC;aAAM,CAAC;YACN,MAAM,IAAI,KAAK,CAAC,0BAA0B,OAAO,KAAK,KAAK,KAAK,CAAC,WAAW,CAAC,IAAI,GAAG,CAAC,CAAA;QACvF,CAAC;QAED,OAAO,IAAI,CAAA;IACb,CAAC;IAED;;;OAGG;IACH,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,SAAS,EAAE,CAAA;IACzB,CAAC;CACF","sourcesContent":["// @ts-check\n\nimport FromPlain from \"./from-plain.js\"\nimport {isPlainObject} from \"is-plain-object\"\nimport JoinObject from \"./join-object.js\"\nimport JoinPlain from \"./join-plain.js\"\nimport {Logger} from \"../../logger.js\"\nimport OrderPlain from \"./order-plain.js\"\nimport SelectBase from \"./select-base.js\"\nimport SelectPlain from \"./select-plain.js\"\nimport WhereHash from \"./where-hash.js\"\nimport WhereNot from \"./where-not.js\"\nimport WherePlain from \"./where-plain.js\"\n\n/**\n * @typedef {{[key: string]: boolean | NestedPreloadRecord }} NestedPreloadRecord\n * @typedef {string | string[] | import(\"./select-base.js\").default | import(\"./select-base.js\").default[]} SelectArgumentType\n * @typedef {object | string} WhereArgumentType\n */\n\n/**\n * @typedef {object} QueryArgsType\n * @property {import(\"../drivers/base.js\").default | (() => import(\"../drivers/base.js\").default)} driver - Driver instance or factory for query execution.\n * @property {Array<import(\"./from-base.js\").default>} [froms] - FROM clauses for the query.\n * @property {string[]} [groups] - GROUP BY columns.\n * @property {Array<import(\"./join-base.js\").default>} [joins] - JOIN clauses for the query.\n * @property {import(\"../handler.js\").default} handler - Handler used for executing and transforming results.\n * @property {number | null} [limit] - LIMIT clause value.\n * @property {number | null} [offset] - OFFSET clause value.\n * @property {Array<import(\"./order-base.js\").default>} [orders] - ORDER BY clauses.\n * @property {number | null} [page] - Page number for pagination.\n * @property {number} [perPage] - Records per page for pagination.\n * @property {NestedPreloadRecord} [preload] - Preload graph for related records.\n * @property {Array<import(\"./select-base.js\").default>} [selects] - SELECT clauses for the query.\n * @property {boolean} [distinct] - Whether the query should use DISTINCT.\n * @property {Array<import(\"./where-base.js\").default>} [wheres] - WHERE conditions for the query.\n */\n\nexport default class VelociousDatabaseQuery {\n  /**\n   * @param {QueryArgsType} args - Options object.\n   */\n  constructor({\n    driver,\n    froms = [],\n    groups = [],\n    joins = [],\n    handler,\n    limit = null,\n    offset = null,\n    orders = [],\n    page = null,\n    perPage,\n    preload = {},\n    distinct = false,\n    selects = [],\n    wheres = []\n  }) {\n    if (!driver) throw new Error(\"No driver given to query\")\n    if (!handler) throw new Error(\"No handler given to query\")\n\n    /** @type {() => import(\"../drivers/base.js\").default} */\n    this._driverFn = typeof driver === \"function\" ? driver : () => driver\n    this.handler = handler\n    this.logger = new Logger(this)\n    this._froms = froms\n    this._groups = groups\n    this._joins = joins\n    this._limit = limit\n    this._offset = offset\n    this._orders = orders\n    this._page = page\n    this._perPage = perPage\n    this._preload = preload\n    this._distinct = distinct\n    this._selects = selects\n\n    /** @type {import(\"./where-base.js\").default[]} */\n    this._wheres = wheres\n\n    const boundWhere = this.where.bind(this)\n    boundWhere.not = this.whereNot.bind(this)\n    this.where = boundWhere\n  }\n\n  /** @returns {this} - The clone.  */\n  clone() {\n    const QueryClass = /** @type {new (args: QueryArgsType) => this} */ (this.constructor)\n    const newQuery = new QueryClass({\n      driver: this._driverFn,\n      froms: [...this._froms],\n      handler: this.handler.clone(),\n      groups: [...this._groups],\n      joins: [...this._joins],\n      limit: this._limit,\n      offset: this._offset,\n      orders: [...this._orders],\n      page: this._page,\n      perPage: this._perPage,\n      preload: {...this._preload},\n      distinct: this._distinct,\n      selects: [...this._selects],\n      wheres: [...this._wheres]\n    })\n\n    return newQuery\n  }\n\n  /** @returns {import(\"./from-base.js\").default[]} - The froms.  */\n  getFroms() {\n    return this._froms\n  }\n\n  /** @returns {string[]} - The groups.  */\n  getGroups() {\n    return this._groups\n  }\n\n  /** @returns {import(\"../query-parser/options.js\").default} - The options options.  */\n  getOptions() { return this.driver.options() }\n\n  /** @returns {Array<import(\"./select-base.js\").default>} - The selects.  */\n  getSelects() { return this._selects }\n\n  /**\n   * @param {string|import(\"./from-base.js\").default} from - From.\n   * @returns {this} - The from.\n   */\n  from(from) {\n    if (typeof from == \"string\") from = new FromPlain(from)\n\n    this._froms.push(from)\n    return this\n  }\n\n  /**\n   * @param {string} group - Group.\n   * @returns {this} - The group.\n   */\n  group(group) {\n    this._groups.push(group)\n    return this\n  }\n\n  /**\n   * @param {string | import(\"./join-object.js\").JoinObject} join - Join clause or join descriptor.\n   * @returns {this} - The joins.\n   */\n  joins(join) {\n    if (typeof join == \"string\") {\n      this._joins.push(new JoinPlain(join))\n    } else if (isPlainObject(join)) {\n      this._joins.push(new JoinObject(join))\n    } else {\n      throw new Error(`Unknown type of join: ${typeof join}`)\n    }\n\n    return this\n  }\n\n  /**\n   * @param {number} value - Value to use.\n   * @returns {this} - The limit.\n   */\n  limit(value) {\n    this._limit = value\n    return this\n  }\n\n  /**\n   * @param {number} value - Value to use.\n   * @returns {this} - The offset.\n   */\n  offset(value) {\n    this._offset = value\n    return this\n  }\n\n  /**\n   * @param {string | number} order - Order.\n   * @returns {this} - The order.\n   */\n  order(order) {\n    if (typeof order == \"string\") {\n      this._orders.push(new OrderPlain(this, order))\n    } else if (typeof order == \"number\") {\n      this._orders.push(new OrderPlain(this, `${order}`))\n    } else {\n      throw new Error(`Unknown order type: ${typeof order}`)\n    }\n\n    return this\n  }\n\n  /**\n   * @param {number} pageNumber - Page number.\n   * @returns {this} - The page.\n   */\n  page(pageNumber) {\n    const perPage = this._perPage || 30\n    const offset = (pageNumber - 1) * perPage\n    const limit = perPage\n\n    this._page = pageNumber\n    this.limit(limit)\n    this.offset(offset)\n    return this\n  }\n\n  /**\n   * @param {number} perPage - Page size.\n   * @returns {this} - The per page.\n   */\n  perPage(perPage) {\n    this._perPage = perPage\n    return this\n  }\n\n  /**\n   * @param {string | number} order - Order.\n   * @returns {this} - The reorder.\n   */\n  reorder(order) {\n    this._orders = []\n    this.order(order)\n    return this\n  }\n\n  /** @returns {this} - The reverse order.  */\n  reverseOrder() {\n    for (const order of this._orders) {\n      order.setReverseOrder(true)\n    }\n\n    return this\n  }\n\n  /**\n   * @param {boolean} [value] - Value to use.\n   * @returns {this} - The distinct.\n   */\n  distinct(value = true) {\n    this._distinct = value\n    return this\n  }\n\n  /**\n   * @param {SelectArgumentType} select - Select.\n   * @returns {this} - The select.\n   */\n  select(select) {\n    if (Array.isArray(select)) {\n      for (const selectInArray of select) {\n        this.select(selectInArray)\n      }\n\n      return this\n    }\n\n    if (typeof select == \"string\") {\n      this._selects.push(new SelectPlain(select))\n    } else if (select instanceof SelectBase) {\n      this._selects.push(select)\n    } else {\n      throw new Error(`Invalid select type: ${typeof select}`)\n    }\n\n    return this\n  }\n\n  /**\n   * @returns {Promise<Array<object>>} Array of results from the database\n   */\n  async _executeQuery() {\n    const sql = this.toSql()\n    const results = await this.driver.query(sql)\n\n    this.logger.debug(() => [\"SQL:\", sql])\n\n    return results\n  }\n\n  /** @returns {Promise<Array<object>>} Array of results from the database */\n  async results() {\n    return await this._executeQuery()\n  }\n\n  /**\n   * Generates SQL string representing this query\n   * @returns {string} SQL string representing this query\n   */\n  toSql() { return this.driver.queryToSql(this) }\n\n  /**\n   * @param {WhereArgumentType} where - Where.\n   * @returns {this} This query instance\n   */\n  where(where) {\n    if (typeof where == \"string\") {\n      this._wheres.push(new WherePlain(this, where))\n    } else if (typeof where == \"object\" && (where.constructor.name == \"object\" || where.constructor.name == \"Object\")) {\n      this._wheres.push(new WhereHash(this, where))\n    } else {\n      throw new Error(`Invalid type of where: ${typeof where} (${where.constructor.name})`)\n    }\n\n    return this\n  }\n\n  /**\n   * @param {WhereArgumentType} where - Where.\n   * @returns {this} This query instance\n   */\n  whereNot(where) {\n    if (typeof where == \"string\") {\n      this._wheres.push(new WhereNot(new WherePlain(this, where)))\n    } else if (typeof where == \"object\" && (where.constructor.name == \"object\" || where.constructor.name == \"Object\")) {\n      this._wheres.push(new WhereNot(new WhereHash(this, where)))\n    } else {\n      throw new Error(`Invalid type of where: ${typeof where} (${where.constructor.name})`)\n    }\n\n    return this\n  }\n\n  /**\n   * Resolves the current driver lazily.\n   * @returns {import(\"../drivers/base.js\").default} - A value.\n   */\n  get driver() {\n    return this._driverFn()\n  }\n}\n"]}
@@ -33,6 +33,12 @@ export default class VelociousDatabaseQueryJoinObject extends JoinBase {
33
33
  joinPath: string[];
34
34
  targetTableRef: string;
35
35
  }): string;
36
+ /**
37
+ * @param {import("./where-base.js").default} where - Where.
38
+ * @param {string} targetTableRef - Target table reference.
39
+ * @returns {string} - Scope where SQL.
40
+ */
41
+ _scopeSqlForWhere(where: import("./where-base.js").default, targetTableRef: string): string;
36
42
  }
37
43
  export type JoinObject = {
38
44
  [key: string]: boolean | JoinObject;
@@ -1 +1 @@
1
- {"version":3,"file":"join-object.d.ts","sourceRoot":"","sources":["../../../../src/database/query/join-object.js"],"names":[],"mappings":"AAKA;;GAEG;AAEH;IACE;;OAEG;IACH,oBAFW,UAAU,EAKpB;IADC,mBAAoB;IAGtB,gBAaC;IAED;;;;;;;OAOG;IACH,iBAPW,UAAU,cACV,cAAc,oBAAoB,EAAE,OAAO,OAC3C,MAAM,cACN,MAAM,QACN,MAAM,EAAE,GACN,MAAM,CAmDlB;IAED;;;;;;;;OAQG;IACH,+EAPG;QAAgE,YAAY,EAApE,OAAO,iCAAiC,EAAE,OAAO;QACF,KAAK,EAApD,6CAAwC;QACU,gBAAgB,EAAlE,cAAc,oBAAoB,EAAE,OAAO;QAC5B,QAAQ,EAAvB,MAAM,EAAE;QACK,cAAc,EAA3B,MAAM;KACd,GAAU,MAAM,CA4BlB;CACF;yBA1HY;IAAC,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,GAAG,UAAU,CAAA;CAAC;qBAJ7B,gBAAgB"}
1
+ {"version":3,"file":"join-object.d.ts","sourceRoot":"","sources":["../../../../src/database/query/join-object.js"],"names":[],"mappings":"AAMA;;GAEG;AAEH;IACE;;OAEG;IACH,oBAFW,UAAU,EAKpB;IADC,mBAAoB;IAGtB,gBAaC;IAED;;;;;;;OAOG;IACH,iBAPW,UAAU,cACV,cAAc,oBAAoB,EAAE,OAAO,OAC3C,MAAM,cACN,MAAM,QACN,MAAM,EAAE,GACN,MAAM,CAmDlB;IAED;;;;;;;;OAQG;IACH,+EAPG;QAAgE,YAAY,EAApE,OAAO,iCAAiC,EAAE,OAAO;QACF,KAAK,EAApD,6CAAwC;QACU,gBAAgB,EAAlE,cAAc,oBAAoB,EAAE,OAAO;QAC5B,QAAQ,EAAvB,MAAM,EAAE;QACK,cAAc,EAA3B,MAAM;KACd,GAAU,MAAM,CAkBlB;IAED;;;;OAIG;IACH,yBAJW,OAAO,iBAAiB,EAAE,OAAO,kBACjC,MAAM,GACJ,MAAM,CAuBlB;CACF;yBA5IY;IAAC,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,GAAG,UAAU,CAAA;CAAC;qBAL7B,gBAAgB"}