velocious 1.0.140 → 1.0.142

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 (40) hide show
  1. package/README.md +21 -0
  2. package/build/src/configuration-types.d.ts +12 -2
  3. package/build/src/configuration-types.d.ts.map +1 -1
  4. package/build/src/configuration-types.js +4 -2
  5. package/build/src/configuration.d.ts +11 -2
  6. package/build/src/configuration.d.ts.map +1 -1
  7. package/build/src/configuration.js +34 -8
  8. package/build/src/database/drivers/mssql/index.js +2 -2
  9. package/build/src/database/drivers/sqlite/sql/alter-table.js +3 -3
  10. package/build/src/database/migrator.d.ts.map +1 -1
  11. package/build/src/database/migrator.js +4 -4
  12. package/build/src/database/pool/async-tracked-multi-connection.d.ts.map +1 -1
  13. package/build/src/database/pool/async-tracked-multi-connection.js +16 -13
  14. package/build/src/database/pool/base.d.ts +6 -0
  15. package/build/src/database/pool/base.d.ts.map +1 -1
  16. package/build/src/database/pool/base.js +9 -1
  17. package/build/src/database/pool/single-multi-use.d.ts.map +1 -1
  18. package/build/src/database/pool/single-multi-use.js +6 -4
  19. package/build/src/database/query/model-class-query.d.ts +6 -0
  20. package/build/src/database/query/model-class-query.d.ts.map +1 -1
  21. package/build/src/database/query/model-class-query.js +28 -1
  22. package/build/src/database/record/index.d.ts +7 -0
  23. package/build/src/database/record/index.d.ts.map +1 -1
  24. package/build/src/database/record/index.js +10 -1
  25. package/build/src/database/table-data/index.d.ts.map +1 -1
  26. package/build/src/database/table-data/index.js +4 -3
  27. package/build/src/database/table-data/table-column.d.ts.map +1 -1
  28. package/build/src/database/table-data/table-column.js +30 -8
  29. package/build/src/http-client/index.js +3 -3
  30. package/build/src/http-server/client/request-buffer/index.js +5 -5
  31. package/build/src/http-server/client/request-runner.js +2 -2
  32. package/build/src/http-server/server-client.js +5 -5
  33. package/build/src/http-server/worker-handler/index.js +2 -2
  34. package/build/src/http-server/worker-handler/worker-thread.d.ts.map +1 -1
  35. package/build/src/http-server/worker-handler/worker-thread.js +7 -7
  36. package/build/src/logger.d.ts +17 -3
  37. package/build/src/logger.d.ts.map +1 -1
  38. package/build/src/logger.js +75 -33
  39. package/build/src/routes/resolver.js +4 -4
  40. package/package.json +1 -1
@@ -71,7 +71,7 @@ export default class VelociousDatabaseConnectionDriversSqliteSqlAlterTable exten
71
71
  const tableDataColumn = newTableData.getColumns().find((newTableDataColumn) => newTableDataColumn.getName() == actualTableDataForeignKey.getColumnName());
72
72
  if (!tableDataColumn)
73
73
  throw new Error(`Couldn't find column for foreign key: ${actualTableDataForeignKey.getName()}`);
74
- this.logger.debug(() => [`Setting foreign key on column ${tableDataColumn.getName()}`]);
74
+ this.logger.debugLowLevel(() => `Setting foreign key on column ${tableDataColumn.getName()}`);
75
75
  tableDataColumn.setForeignKey(actualTableDataForeignKey);
76
76
  }
77
77
  for (const foreignKey of tableData.getForeignKeys()) {
@@ -83,7 +83,7 @@ export default class VelociousDatabaseConnectionDriversSqliteSqlAlterTable exten
83
83
  const tableDataColumn = newTableData.getColumns().find((newTableDataColumn) => newTableDataColumn.getName() == foreignKey.getColumnName());
84
84
  if (!tableDataColumn)
85
85
  throw new Error(`Couldn't find column for foreign key: ${foreignKey.getName()}`);
86
- this.logger.debug(() => [`Setting foreign key on column ${tableDataColumn.getName()}`]);
86
+ this.logger.debugLowLevel(() => `Setting foreign key on column ${tableDataColumn.getName()}`);
87
87
  tableDataColumn.setForeignKey(foreignKey);
88
88
  }
89
89
  const createNewTableSQL = await this.getDriver().createTableSql(newTableData);
@@ -120,4 +120,4 @@ export default class VelociousDatabaseConnectionDriversSqliteSqlAlterTable exten
120
120
  return sqls;
121
121
  }
122
122
  }
123
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alter-table.js","sourceRoot":"","sources":["../../../../../../src/database/drivers/sqlite/sql/alter-table.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport AlterTableBase from \"../../../query/alter-table-base.js\"\nimport CreateIndexBase from \"../../../query/create-index-base.js\"\nimport {Logger} from \"../../../../logger.js\"\nimport restArgsError from \"../../../../utils/rest-args-error.js\"\nimport TableData from \"../../../table-data/index.js\"\n\nexport default class VelociousDatabaseConnectionDriversSqliteSqlAlterTable extends AlterTableBase {\n  /**\n   * @param {object} args\n   * @param {import(\"../../base.js\").default} args.driver\n   * @param {import(\"../../../table-data/index.js\").default} args.tableData\n   */\n  constructor({driver, tableData, ...restArgs}) {\n    restArgsError(restArgs)\n\n    if (!(tableData instanceof TableData)) throw new Error(\"Invalid table data was given\")\n\n    super({driver, tableData})\n    this.logger = new Logger(this)\n    this.tableData = tableData\n  }\n\n  /**\n   * @returns {Promise<string[]>}\n   */\n  async toSQLs() {\n    const {tableData} = this\n    const table = await this.getDriver().getTableByName(tableData.getName())\n\n    if (!table) throw new Error(`Table ${tableData.getName()} does not exist`)\n\n    const currentTableData = await table.getTableData()\n    const options = this.getOptions()\n    const tableName = tableData.getName()\n    const tempTableName = `${tableData.getName()}AlterTableTemp`\n    const newColumnNames = currentTableData.getColumns()\n      .filter((column) => !column.isNewColumn())\n      .map((column) => {\n        const newTableColumn = tableData.getColumns().find((tableColumn) => tableColumn.getName() == column.getName())\n\n        return newTableColumn?.getNewName() || newTableColumn?.getName() || column.getNewName() || column.getName()\n      })\n    const oldColumnNames = currentTableData.getColumns().filter((column) => !column.isNewColumn()).map((column) => column.getName())\n    const newColumnsSQL = newColumnNames.map((name) => options.quoteColumnName(name)).join(\", \")\n    const oldColumnsSQL = oldColumnNames.map((name) => options.quoteColumnName(name)).join(\", \")\n\n    tableData.setName(tempTableName)\n\n    const newTableData = new TableData(tempTableName)\n\n    for (const tableDataColumn of currentTableData.getColumns()) {\n      const newTableDataColumn = tableData.getColumns().find((newTableDataColumn) => newTableDataColumn.getName() == tableDataColumn.getName())\n\n      if (newTableDataColumn) {\n        newTableDataColumn.setAutoIncrement(tableDataColumn.getAutoIncrement())\n        newTableDataColumn.setDefault(tableDataColumn.getDefault())\n        newTableDataColumn.setIndex(tableDataColumn.getIndex())\n        newTableDataColumn.setForeignKey(tableDataColumn.getForeignKey())\n        newTableDataColumn.setMaxLength(tableDataColumn.getMaxLength())\n        newTableDataColumn.setPrimaryKey(tableDataColumn.getPrimaryKey())\n        newTableDataColumn.setType(tableDataColumn.getType())\n      }\n\n      newTableData.addColumn(newTableDataColumn || tableDataColumn)\n    }\n\n    for (const tableDataColumn of tableData.getColumns()) {\n      if (!tableDataColumn.isNewColumn()) continue\n\n      newTableData.addColumn(tableDataColumn)\n    }\n\n    const foundForeignKeys = []\n\n    for (const tableDataForeignKey of currentTableData.getForeignKeys()) {\n      const newTableDataForeignKey = newTableData.getForeignKeys().find((newTableDataForeignKey) => newTableDataForeignKey.getName() == tableDataForeignKey.getName())\n\n      if (newTableDataForeignKey) foundForeignKeys.push(newTableDataForeignKey.getName())\n\n      const actualTableDataForeignKey = newTableDataForeignKey || tableDataForeignKey\n\n      // Register foreign key on the table\n      newTableData.addForeignKey(actualTableDataForeignKey)\n\n      // Register foreign key on the column\n      const tableDataColumn = newTableData.getColumns().find((newTableDataColumn) => newTableDataColumn.getName() == actualTableDataForeignKey.getColumnName())\n\n      if (!tableDataColumn) throw new Error(`Couldn't find column for foreign key: ${actualTableDataForeignKey.getName()}`)\n\n      this.logger.debug(() => [`Setting foreign key on column ${tableDataColumn.getName()}`])\n      tableDataColumn.setForeignKey(actualTableDataForeignKey)\n    }\n\n    for (const foreignKey of tableData.getForeignKeys()) {\n      if (foundForeignKeys.includes(foreignKey.getName())) continue\n\n      // Register foreign key on the table\n      newTableData.addForeignKey(foreignKey)\n\n      // Register foreign key on the column\n      const tableDataColumn = newTableData.getColumns().find((newTableDataColumn) => newTableDataColumn.getName() == foreignKey.getColumnName())\n\n      if (!tableDataColumn) throw new Error(`Couldn't find column for foreign key: ${foreignKey.getName()}`)\n\n      this.logger.debug(() => [`Setting foreign key on column ${tableDataColumn.getName()}`])\n      tableDataColumn.setForeignKey(foreignKey)\n    }\n\n    const createNewTableSQL = await this.getDriver().createTableSql(newTableData)\n    const insertSQL = `INSERT INTO ${options.quoteTableName(tempTableName)} (${newColumnsSQL}) SELECT ${oldColumnsSQL} FROM ${options.quoteTableName(tableName)}`\n    const dropTableSQLs = `DROP TABLE ${options.quoteTableName(tableName)}`\n    const renameTableSQL = `ALTER TABLE ${options.quoteTableName(tempTableName)} RENAME TO ${options.quoteTableName(tableName)}`\n    const sqls = []\n\n    for (const sql of createNewTableSQL) {\n      sqls.push(sql)\n    }\n\n    sqls.push(insertSQL)\n    sqls.push(dropTableSQLs)\n    sqls.push(renameTableSQL)\n\n    for (const tableDataIndex of currentTableData.getIndexes()) {\n      const newTableDataIndex = newTableData.getIndexes().find((newTableDataIndex) => newTableDataIndex.getName() == tableDataIndex.getName())\n      const actualTableIndex = newTableDataIndex || tableDataIndex\n\n      newTableData.addIndex(actualTableIndex)\n\n      const columnNames = actualTableIndex.getColumns().map((columnName) => {\n        const newTableColumn = tableData.getColumns().find((tableColumn) => tableColumn.getName() == columnName)\n\n        return newTableColumn?.getNewName() || newTableColumn?.getName() || columnName\n      })\n\n      const createIndexArgs = {\n        columns: columnNames,\n        driver: this.getDriver(),\n        name: actualTableIndex.getName(),\n        tableName,\n        unique: actualTableIndex.getUnique()\n      }\n      const createIndexSQLs = await new CreateIndexBase(createIndexArgs).toSQLs()\n\n      for (const createIndexSQL of createIndexSQLs) {\n        sqls.push(createIndexSQL)\n      }\n    }\n\n    return sqls\n  }\n}\n"]}
123
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alter-table.js","sourceRoot":"","sources":["../../../../../../src/database/drivers/sqlite/sql/alter-table.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport AlterTableBase from \"../../../query/alter-table-base.js\"\nimport CreateIndexBase from \"../../../query/create-index-base.js\"\nimport {Logger} from \"../../../../logger.js\"\nimport restArgsError from \"../../../../utils/rest-args-error.js\"\nimport TableData from \"../../../table-data/index.js\"\n\nexport default class VelociousDatabaseConnectionDriversSqliteSqlAlterTable extends AlterTableBase {\n  /**\n   * @param {object} args\n   * @param {import(\"../../base.js\").default} args.driver\n   * @param {import(\"../../../table-data/index.js\").default} args.tableData\n   */\n  constructor({driver, tableData, ...restArgs}) {\n    restArgsError(restArgs)\n\n    if (!(tableData instanceof TableData)) throw new Error(\"Invalid table data was given\")\n\n    super({driver, tableData})\n    this.logger = new Logger(this)\n    this.tableData = tableData\n  }\n\n  /**\n   * @returns {Promise<string[]>}\n   */\n  async toSQLs() {\n    const {tableData} = this\n    const table = await this.getDriver().getTableByName(tableData.getName())\n\n    if (!table) throw new Error(`Table ${tableData.getName()} does not exist`)\n\n    const currentTableData = await table.getTableData()\n    const options = this.getOptions()\n    const tableName = tableData.getName()\n    const tempTableName = `${tableData.getName()}AlterTableTemp`\n    const newColumnNames = currentTableData.getColumns()\n      .filter((column) => !column.isNewColumn())\n      .map((column) => {\n        const newTableColumn = tableData.getColumns().find((tableColumn) => tableColumn.getName() == column.getName())\n\n        return newTableColumn?.getNewName() || newTableColumn?.getName() || column.getNewName() || column.getName()\n      })\n    const oldColumnNames = currentTableData.getColumns().filter((column) => !column.isNewColumn()).map((column) => column.getName())\n    const newColumnsSQL = newColumnNames.map((name) => options.quoteColumnName(name)).join(\", \")\n    const oldColumnsSQL = oldColumnNames.map((name) => options.quoteColumnName(name)).join(\", \")\n\n    tableData.setName(tempTableName)\n\n    const newTableData = new TableData(tempTableName)\n\n    for (const tableDataColumn of currentTableData.getColumns()) {\n      const newTableDataColumn = tableData.getColumns().find((newTableDataColumn) => newTableDataColumn.getName() == tableDataColumn.getName())\n\n      if (newTableDataColumn) {\n        newTableDataColumn.setAutoIncrement(tableDataColumn.getAutoIncrement())\n        newTableDataColumn.setDefault(tableDataColumn.getDefault())\n        newTableDataColumn.setIndex(tableDataColumn.getIndex())\n        newTableDataColumn.setForeignKey(tableDataColumn.getForeignKey())\n        newTableDataColumn.setMaxLength(tableDataColumn.getMaxLength())\n        newTableDataColumn.setPrimaryKey(tableDataColumn.getPrimaryKey())\n        newTableDataColumn.setType(tableDataColumn.getType())\n      }\n\n      newTableData.addColumn(newTableDataColumn || tableDataColumn)\n    }\n\n    for (const tableDataColumn of tableData.getColumns()) {\n      if (!tableDataColumn.isNewColumn()) continue\n\n      newTableData.addColumn(tableDataColumn)\n    }\n\n    const foundForeignKeys = []\n\n    for (const tableDataForeignKey of currentTableData.getForeignKeys()) {\n      const newTableDataForeignKey = newTableData.getForeignKeys().find((newTableDataForeignKey) => newTableDataForeignKey.getName() == tableDataForeignKey.getName())\n\n      if (newTableDataForeignKey) foundForeignKeys.push(newTableDataForeignKey.getName())\n\n      const actualTableDataForeignKey = newTableDataForeignKey || tableDataForeignKey\n\n      // Register foreign key on the table\n      newTableData.addForeignKey(actualTableDataForeignKey)\n\n      // Register foreign key on the column\n      const tableDataColumn = newTableData.getColumns().find((newTableDataColumn) => newTableDataColumn.getName() == actualTableDataForeignKey.getColumnName())\n\n      if (!tableDataColumn) throw new Error(`Couldn't find column for foreign key: ${actualTableDataForeignKey.getName()}`)\n\n      this.logger.debugLowLevel(() => `Setting foreign key on column ${tableDataColumn.getName()}`)\n      tableDataColumn.setForeignKey(actualTableDataForeignKey)\n    }\n\n    for (const foreignKey of tableData.getForeignKeys()) {\n      if (foundForeignKeys.includes(foreignKey.getName())) continue\n\n      // Register foreign key on the table\n      newTableData.addForeignKey(foreignKey)\n\n      // Register foreign key on the column\n      const tableDataColumn = newTableData.getColumns().find((newTableDataColumn) => newTableDataColumn.getName() == foreignKey.getColumnName())\n\n      if (!tableDataColumn) throw new Error(`Couldn't find column for foreign key: ${foreignKey.getName()}`)\n\n      this.logger.debugLowLevel(() => `Setting foreign key on column ${tableDataColumn.getName()}`)\n      tableDataColumn.setForeignKey(foreignKey)\n    }\n\n    const createNewTableSQL = await this.getDriver().createTableSql(newTableData)\n    const insertSQL = `INSERT INTO ${options.quoteTableName(tempTableName)} (${newColumnsSQL}) SELECT ${oldColumnsSQL} FROM ${options.quoteTableName(tableName)}`\n    const dropTableSQLs = `DROP TABLE ${options.quoteTableName(tableName)}`\n    const renameTableSQL = `ALTER TABLE ${options.quoteTableName(tempTableName)} RENAME TO ${options.quoteTableName(tableName)}`\n    const sqls = []\n\n    for (const sql of createNewTableSQL) {\n      sqls.push(sql)\n    }\n\n    sqls.push(insertSQL)\n    sqls.push(dropTableSQLs)\n    sqls.push(renameTableSQL)\n\n    for (const tableDataIndex of currentTableData.getIndexes()) {\n      const newTableDataIndex = newTableData.getIndexes().find((newTableDataIndex) => newTableDataIndex.getName() == tableDataIndex.getName())\n      const actualTableIndex = newTableDataIndex || tableDataIndex\n\n      newTableData.addIndex(actualTableIndex)\n\n      const columnNames = actualTableIndex.getColumns().map((columnName) => {\n        const newTableColumn = tableData.getColumns().find((tableColumn) => tableColumn.getName() == columnName)\n\n        return newTableColumn?.getNewName() || newTableColumn?.getName() || columnName\n      })\n\n      const createIndexArgs = {\n        columns: columnNames,\n        driver: this.getDriver(),\n        name: actualTableIndex.getName(),\n        tableName,\n        unique: actualTableIndex.getUnique()\n      }\n      const createIndexSQLs = await new CreateIndexBase(createIndexArgs).toSQLs()\n\n      for (const createIndexSQL of createIndexSQLs) {\n        sqls.push(createIndexSQL)\n      }\n    }\n\n    return sqls\n  }\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"migrator.d.ts","sourceRoot":"","sources":["../../../src/database/migrator.js"],"names":[],"mappings":"AASA;IAIE;;;OAGG;IACH,4CAFG;QAAoD,aAAa,EAAzD,OAAO,qBAAqB,EAAE,OAAO;KAC/C,EAQA;IAdD,sDAAsD;IACtD,oBADW,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,CAC3B;IAWrB,qDAAkC;IAClC,eAA8C;IAIhD,+BAA+B;IAC/B,WADc,OAAO,CAAC,IAAI,CAAC,CAI1B;IAED,+BAA+B;IAC/B,yBADc,OAAO,CAAC,IAAI,CAAC,CA+B1B;IAED,8BAEC;IAED;;;;OAIG;IACH,qCAJW,MAAM,WACN,MAAM,GACJ,OAAO,CAWnB;IAED;;;OAGG;IACH,oBAHW,OAAO,qBAAqB,EAAE,mBAAmB,EAAE,kBACnD,OAAO,qBAAqB,EAAE,0BAA0B,iBAuBlE;IAED;;;OAGG;IACH,+CAHW,OAAO,qBAAqB,EAAE,2BAA2B,GACvD,OAAO,CAAC,IAAI,CAAC,CA6CzB;IAED;;OAEG;IACH,oBAFa,OAAO,CAAC,IAAI,CAAC,CASzB;IAED,+BAA+B;IAC/B,0BADc,OAAO,CAAC,IAAI,CAAC,CA8B1B;IAED;;;OAGG;IACH,yBAHW,OAAO,mBAAmB,EAAE,OAAO,GACjC,OAAO,CAAC,OAAO,CAAC,CAQ5B;IAED;;;OAGG;IACH,sCAHW,OAAO,qBAAqB,EAAE,2BAA2B,GACvD,OAAO,CAAC,IAAI,CAAC,CAkCzB;IAED;;OAEG;IACH,SAFa,OAAO,CAAC,IAAI,CAAC,CAoCzB;IAED;;;;OAIG;IACH,gBAJW,OAAO,qBAAqB,EAAE,mBAAmB,EAAE,kBACnD,OAAO,qBAAqB,EAAE,0BAA0B,GACtD,OAAO,CAAC,IAAI,CAAC,CAyBzB;IAED;;OAEG;IACH,2BAFa,OAAO,CAAC,MAAM,GAAG,SAAS,CAAC,CAiBvC;IAED;;;;;OAKG;IACH,6DAJG;QAAgE,SAAS,EAAjE,OAAO,qBAAqB,EAAE,mBAAmB;QACQ,gBAAgB,EAAzE,OAAO,qBAAqB,EAAE,oBAAoB;QACpC,SAAS,GAAvB,MAAM;KAAkB,iBAiGlC;CACF;uBA3boB,cAAc"}
1
+ {"version":3,"file":"migrator.d.ts","sourceRoot":"","sources":["../../../src/database/migrator.js"],"names":[],"mappings":"AASA;IAIE;;;OAGG;IACH,4CAFG;QAAoD,aAAa,EAAzD,OAAO,qBAAqB,EAAE,OAAO;KAC/C,EAQA;IAdD,sDAAsD;IACtD,oBADW,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,CAC3B;IAWrB,qDAAkC;IAClC,eAA8B;IAIhC,+BAA+B;IAC/B,WADc,OAAO,CAAC,IAAI,CAAC,CAI1B;IAED,+BAA+B;IAC/B,yBADc,OAAO,CAAC,IAAI,CAAC,CA+B1B;IAED,8BAEC;IAED;;;;OAIG;IACH,qCAJW,MAAM,WACN,MAAM,GACJ,OAAO,CAWnB;IAED;;;OAGG;IACH,oBAHW,OAAO,qBAAqB,EAAE,mBAAmB,EAAE,kBACnD,OAAO,qBAAqB,EAAE,0BAA0B,iBAuBlE;IAED;;;OAGG;IACH,+CAHW,OAAO,qBAAqB,EAAE,2BAA2B,GACvD,OAAO,CAAC,IAAI,CAAC,CA6CzB;IAED;;OAEG;IACH,oBAFa,OAAO,CAAC,IAAI,CAAC,CASzB;IAED,+BAA+B;IAC/B,0BADc,OAAO,CAAC,IAAI,CAAC,CA8B1B;IAED;;;OAGG;IACH,yBAHW,OAAO,mBAAmB,EAAE,OAAO,GACjC,OAAO,CAAC,OAAO,CAAC,CAQ5B;IAED;;;OAGG;IACH,sCAHW,OAAO,qBAAqB,EAAE,2BAA2B,GACvD,OAAO,CAAC,IAAI,CAAC,CAkCzB;IAED;;OAEG;IACH,SAFa,OAAO,CAAC,IAAI,CAAC,CAoCzB;IAED;;;;OAIG;IACH,gBAJW,OAAO,qBAAqB,EAAE,mBAAmB,EAAE,kBACnD,OAAO,qBAAqB,EAAE,0BAA0B,GACtD,OAAO,CAAC,IAAI,CAAC,CAyBzB;IAED;;OAEG;IACH,2BAFa,OAAO,CAAC,MAAM,GAAG,SAAS,CAAC,CAiBvC;IAED;;;;;OAKG;IACH,6DAJG;QAAgE,SAAS,EAAjE,OAAO,qBAAqB,EAAE,mBAAmB;QACQ,gBAAgB,EAAzE,OAAO,qBAAqB,EAAE,oBAAoB;QACpC,SAAS,GAAvB,MAAM;KAAkB,iBAiGlC;CACF;uBA3boB,cAAc"}
@@ -17,7 +17,7 @@ export default class VelociousDatabaseMigrator {
17
17
  if (!configuration)
18
18
  throw new Error("configuration argument is required");
19
19
  this.configuration = configuration;
20
- this.logger = new Logger(this, { debug: false });
20
+ this.logger = new Logger(this);
21
21
  }
22
22
  /** @returns {Promise<void>} */
23
23
  async prepare() {
@@ -153,7 +153,7 @@ export default class VelociousDatabaseMigrator {
153
153
  continue;
154
154
  }
155
155
  if (!await this.migrationsTableExist(db)) {
156
- this.logger.log(`Migration table does not exist for ${dbIdentifier} - skipping loading migrations versions for it`);
156
+ this.logger.info(`Migration table does not exist for ${dbIdentifier} - skipping loading migrations versions for it`);
157
157
  continue;
158
158
  }
159
159
  const rows = await db.select("schema_migrations");
@@ -217,7 +217,7 @@ export default class VelociousDatabaseMigrator {
217
217
  let anyTableDropped = false;
218
218
  try {
219
219
  for (const table of await db.getTables()) {
220
- this.logger.log(`Dropping table ${table.getName()}`);
220
+ this.logger.info(`Dropping table ${table.getName()}`);
221
221
  try {
222
222
  await db.dropTable(table.getName(), { cascade: true });
223
223
  anyTableDropped = true;
@@ -385,4 +385,4 @@ export default class VelociousDatabaseMigrator {
385
385
  }
386
386
  }
387
387
  }
388
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"migrator.js","sourceRoot":"","sources":["../../../src/database/migrator.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport {digg} from \"diggerize\"\nimport * as inflection from \"inflection\"\nimport {Logger} from \"../logger.js\"\nimport {NotImplementedError} from \"./migration/index.js\"\nimport restArgsError from \"../utils/rest-args-error.js\"\nimport TableData from \"./table-data/index.js\"\n\nexport default class VelociousDatabaseMigrator {\n  /** @type {Record<string, Record<string, boolean>>} */\n  migrationsVersions = {}\n\n  /**\n   * @param {object} args\n   * @param {import(\"../configuration.js\").default} args.configuration\n   */\n  constructor({configuration, ...restArgs}) {\n    restArgsError(restArgs)\n\n    if (!configuration) throw new Error(\"configuration argument is required\")\n\n    this.configuration = configuration\n    this.logger = new Logger(this, {debug: false})\n  }\n\n\n  /** @returns {Promise<void>} */\n  async prepare() {\n    await this.createMigrationsTable()\n    await this.loadMigrationsVersions()\n  }\n\n  /** @returns {Promise<void>} */\n  async createMigrationsTable() {\n    const dbs = await this.configuration.getCurrentConnections()\n\n    for (const dbIdentifier in dbs) {\n      const db = dbs[dbIdentifier]\n      const databaseConfiguration = this.configuration.getDatabaseIdentifier(dbIdentifier)\n\n      if (!databaseConfiguration.migrations) {\n        this.logger.debug(`${dbIdentifier} isn't configured for migrations - skipping creating migrations table for it`)\n        continue\n      }\n\n      const exists = await this.migrationsTableExist(db)\n\n      if (exists) {\n        this.logger.debug(`${dbIdentifier} migrations table already exists - skipping`)\n      } else {\n        this.logger.debug(\"New TableData for schema_migrations\")\n        const schemaMigrationsTable = new TableData(\"schema_migrations\", {ifNotExists: true})\n\n        schemaMigrationsTable.string(\"version\", {null: false, primaryKey: true})\n\n        const createSchemaMigrationsTableSqls = await db.createTableSql(schemaMigrationsTable)\n\n        for (const createSchemaMigrationsTableSql of createSchemaMigrationsTableSqls) {\n          this.logger.debug(`Creating migrations table with SQL`, createSchemaMigrationsTableSql)\n          await db.query(createSchemaMigrationsTableSql)\n        }\n      }\n    }\n  }\n\n  async dropDatabase() {\n    throw new Error(\"Not implemented yet\")\n  }\n\n  /**\n   * @param {string} dbIdentifier\n   * @param {number} version\n   * @returns {boolean}\n   */\n  hasRunMigrationVersion(dbIdentifier, version) {\n    if (!this.migrationsVersions) throw new Error(\"Migrations versions hasn't been loaded yet\")\n    if (!this.migrationsVersions[dbIdentifier]) throw new Error(`Migrations versions hasn't been loaded yet for db: ${dbIdentifier}`)\n\n    if (version in this.migrationsVersions[dbIdentifier]) {\n      return true\n    }\n\n    return false\n  }\n\n  /**\n   * @param {import(\"./migrator/types.js\").MigrationObjectType[]} files\n   * @param {import(\"./migrator/types.js\").ImportFullpathCallbackType} importCallback\n   */\n  async migrateFiles(files, importCallback) {\n    await this.configuration.ensureConnections(async () => {\n      for (const migration of files) {\n        await this.runMigrationFile({\n          migration,\n          requireMigration: async () => {\n            if (!migration.fullPath) throw new Error(`Migration didn't have a fullPath key: ${Object.keys(migration).join(\", \")}`)\n\n            const migrationImport = await importCallback(migration.fullPath)\n\n            if (!migrationImport) {\n              throw new Error(`Migration file must export migration class: ${migration.fullPath}`)\n            }\n\n            return migrationImport\n          }\n        })\n      }\n\n      await this._afterMigrations()\n    })\n  }\n\n  /**\n   * @param {import(\"./migrator/types.js\").RequireMigrationContextType} requireContext\n   * @returns {Promise<void>}\n   */\n  async migrateFilesFromRequireContext(requireContext) {\n    /** @type {import(\"./migrator/types.js\").MigrationObjectType[]} */\n    let files = []\n\n    for (const file of requireContext.keys()) {\n      // \"13,14\" because somes \"require-context\"-npm-module deletes first character!?\n      const match = file.match(/(\\d{13,14})-(.+)\\.js$/)\n\n      if (!match) continue\n\n      // Fix require-context-npm-module deletes first character\n      let fileName = file\n      let dateNumber = match[1]\n\n      if (dateNumber.length == 13) {\n        dateNumber = `2${dateNumber}`\n        fileName = `2${fileName}`\n      }\n\n      // Parse regex\n      const date = parseInt(dateNumber)\n      const migrationName = match[2]\n      const migrationClassName = inflection.camelize(migrationName.replaceAll(\"-\", \"_\"))\n\n      files.push({\n        file: fileName,\n        date,\n        migrationClassName\n      })\n    }\n\n    files = files.sort((migration1, migration2) => migration1.date - migration2.date)\n\n    await this.configuration.ensureConnections(async () => {\n      for (const migration of files) {\n        await this.runMigrationFile({\n          migration,\n          requireMigration: async () => requireContext(migration.file).default\n        })\n      }\n\n      await this._afterMigrations()\n    })\n  }\n\n  /**\n   * @returns {Promise<void>}\n   */\n  async _afterMigrations() {\n    const environmentHandler = this.configuration.getEnvironmentHandler()\n    const dbs = await this.configuration.getCurrentConnections()\n\n    if (!environmentHandler || !dbs || Object.keys(dbs).length == 0) return\n\n    await environmentHandler.afterMigrations({dbs})\n  }\n\n  /** @returns {Promise<void>} */\n  async loadMigrationsVersions() {\n    this.migrationsVersions = {}\n\n    const dbs = await this.configuration.getCurrentConnections()\n\n    for (const dbIdentifier in dbs) {\n      const db = dbs[dbIdentifier]\n      const databaseConfiguration = this.configuration.getDatabaseIdentifier(dbIdentifier)\n\n      if (!databaseConfiguration.migrations) {\n        this.logger.debug(`${dbIdentifier} isn't configured for migrations - skipping loading migrations versions for it`)\n        continue\n      }\n\n      if (!await this.migrationsTableExist(db)) {\n        this.logger.log(`Migration table does not exist for ${dbIdentifier} - skipping loading migrations versions for it`)\n        continue\n      }\n\n      const rows = await db.select(\"schema_migrations\")\n\n      this.migrationsVersions[dbIdentifier] = {}\n\n      for (const row of rows) {\n        const version = digg(row, \"version\")\n\n        this.migrationsVersions[dbIdentifier][version] = true\n      }\n    }\n  }\n\n  /**\n   * @param {import(\"./drivers/base.js\").default} db\n   * @returns {Promise<boolean>}\n   */\n  async migrationsTableExist(db) {\n    const schemaTable = await db.getTableByName(\"schema_migrations\", {throwError: false})\n\n    if (!schemaTable) return false\n\n    return true\n  }\n\n  /**\n   * @param {import(\"./migrator/types.js\").RequireMigrationContextType} requireContext\n   * @returns {Promise<void>}\n   */\n  async executeRequireContext(requireContext) {\n    const migrationFiles = requireContext.keys()\n\n    /** @type {import(\"./migrator/types.js\").MigrationObjectType[]} */\n    let files = []\n\n    for (const file of migrationFiles) {\n      const match = file.match(/^(\\d{14})-(.+)\\.js$/)\n\n      if (!match) continue\n\n      const date = parseInt(match[1])\n      const migrationName = match[2]\n      const migrationClassName = inflection.camelize(migrationName)\n\n      const migrationObject = /** @type {import(\"./migrator/types.js\").MigrationObjectType} */ ({\n        file,\n        date,\n        migrationClassName\n      })\n\n      files.push(migrationObject)\n    }\n\n    files = files.sort((migration1, migration2) => migration1.date - migration2.date)\n\n    for (const migration of files) {\n      await this.runMigrationFile({\n        migration,\n        requireMigration: async () => requireContext(migration.file).default\n      })\n    }\n  }\n\n  /**\n   * @returns {Promise<void>}\n   */\n  async reset() {\n    const dbs = await this.configuration.getCurrentConnections()\n\n    for (const dbIdentifier in dbs) {\n      const db = dbs[dbIdentifier]\n\n      await db.withDisabledForeignKeys(async () => {\n        while (true) {\n          const errors = []\n          let anyTableDropped = false\n\n          try {\n            for (const table of await db.getTables()) {\n              this.logger.log(`Dropping table ${table.getName()}`)\n\n              try {\n                await db.dropTable(table.getName(), {cascade: true})\n                anyTableDropped = true\n              } catch (error) {\n                errors.push(error)\n              }\n            }\n\n            break\n          } catch (error) { // eslint-disable-line no-unused-vars\n            if (errors.length > 0 && anyTableDropped) {\n              // Retry\n            } else {\n              throw errors[0]\n            }\n          }\n        }\n      })\n    }\n  }\n\n  /**\n   * @param {import(\"./migrator/types.js\").MigrationObjectType[]} files\n   * @param {import(\"./migrator/types.js\").ImportFullpathCallbackType} importCallback Function to import a file\n   * @returns {Promise<void>}\n   */\n  async rollback(files, importCallback) {\n    const latestMigrationVersion = await this._latestMigrationVersion()\n\n    if (!latestMigrationVersion) {\n      throw new Error(\"No migrations have been run yet\")\n    }\n\n    const latestMigrationVersionNumber = parseInt(latestMigrationVersion)\n    const migration = files.find((file) => file.date == latestMigrationVersionNumber)\n\n    if (!migration) {\n      throw new Error(`Migration file for version ${latestMigrationVersionNumber} not found`)\n    }\n\n    await this.runMigrationFile({\n      migration,\n      requireMigration: async () => {\n        if (!migration.fullPath) throw new Error(`Migration didn't have a fullPath key: ${Object.keys(migration).join(\", \")}`)\n\n        return await importCallback(migration.fullPath)\n      },\n      direction: \"down\"\n    })\n  }\n\n  /**\n   * @returns {Promise<string | undefined>} The latest migration version\n   */\n  async _latestMigrationVersion() {\n    if (!this.migrationsVersions) await this.loadMigrationsVersions()\n\n    /** @type {string | undefined} */\n    let highestVersion\n\n    for (const dbIdentifier in this.migrationsVersions) {\n      for (const migrationVersion in this.migrationsVersions[dbIdentifier]) {\n        if (!highestVersion || migrationVersion > highestVersion) {\n          highestVersion = migrationVersion\n        }\n      }\n    }\n\n    return highestVersion\n  }\n\n  /**\n   * @param {object} args\n   * @param {import(\"./migrator/types.js\").MigrationObjectType} args.migration\n   * @param {import(\"./migrator/types.js\").RequireMigrationType} args.requireMigration\n   * @param {string} [args.direction]\n   */\n  async runMigrationFile({migration, requireMigration, direction = \"up\"}) {\n    if (!this.configuration) throw new Error(\"No configuration set\")\n    if (!this.configuration.isDatabasePoolInitialized()) await this.configuration.initializeDatabasePool()\n    if (!this.migrationsVersions) await this.loadMigrationsVersions()\n\n    const dbs = await this.configuration.getCurrentConnections()\n    const migrationClass = await requireMigration()\n\n    if (!migrationClass || typeof migrationClass !== \"function\") {\n      throw new Error(`Migration ${migration.file} must export a default migration class. Type: ${typeof migrationClass}`)\n    }\n\n    const migrationDatabaseIdentifiers = migrationClass.getDatabaseIdentifiers() || [\"default\"]\n\n    for (const dbIdentifier in dbs) {\n      const databaseConfiguration = this.configuration.getDatabaseIdentifier(dbIdentifier)\n\n      if (!databaseConfiguration.migrations) {\n        this.logger.debug(`${dbIdentifier} isn't configured for migrations - skipping migration ${digg(migration, \"date\")}`)\n        continue\n      }\n\n      if (!migrationDatabaseIdentifiers.includes(dbIdentifier)) {\n        this.logger.debug(`${dbIdentifier} shouldn't run migration ${migration.file}`, {migrationDatabaseIdentifiers})\n        continue\n      }\n\n      if (direction == \"up\") {\n        if (this.hasRunMigrationVersion(dbIdentifier, migration.date)) {\n          this.logger.debug(`${dbIdentifier} has already run migration ${migration.file}`)\n          continue\n        }\n      } else if (direction == \"down\") {\n        if (!this.hasRunMigrationVersion(dbIdentifier, migration.date)) {\n          this.logger.debug(`${dbIdentifier} hasn't run migration ${migration.file}`)\n          continue\n        }\n      } else {\n        throw new Error(`Unknown direction: ${direction}`)\n      }\n\n      this.logger.debug(`Running migration on ${dbIdentifier}: ${migration.file}`, {migrationDatabaseIdentifiers})\n\n      const db = dbs[dbIdentifier]\n      const MigrationClass = migrationClass\n      const migrationInstance = new MigrationClass({\n        configuration: this.configuration,\n        databaseIdentifier: dbIdentifier,\n        db\n      })\n      const dateString = `${digg(migration, \"date\")}`\n\n      if (direction == \"up\") {\n        try {\n          await migrationInstance.change()\n        } catch (changeError) {\n          if (changeError instanceof NotImplementedError) {\n            try {\n              await migrationInstance.up()\n            } catch (upError) {\n              if (upError instanceof NotImplementedError) {\n                throw new Error(`'change' or 'up' didn't exist on migration: ${migration.file}`)\n              } else {\n                throw upError\n              }\n            }\n          } else {\n            throw changeError\n          }\n        }\n\n        const existingSchemaMigrations = await db.newQuery()\n          .from(\"schema_migrations\")\n          .where({version: dateString})\n          .results()\n\n        if (existingSchemaMigrations.length == 0) {\n          await db.insert({tableName: \"schema_migrations\", data: {version: dateString}})\n        }\n      } else if (direction == \"down\") {\n        try {\n          await migrationInstance.down()\n        } catch (downError) {\n          if (downError instanceof NotImplementedError) {\n            throw new Error(`'down' didn't exist on migration: ${migration.file} or migrating down with a change method isn't currently supported`)\n          } else {\n            throw downError\n          }\n        }\n\n        await db.delete({tableName: \"schema_migrations\", conditions: {version: dateString}})\n      } else {\n        throw new Error(`Unknown direction: ${direction}`)\n      }\n    }\n  }\n}\n"]}
388
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"migrator.js","sourceRoot":"","sources":["../../../src/database/migrator.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport {digg} from \"diggerize\"\nimport * as inflection from \"inflection\"\nimport {Logger} from \"../logger.js\"\nimport {NotImplementedError} from \"./migration/index.js\"\nimport restArgsError from \"../utils/rest-args-error.js\"\nimport TableData from \"./table-data/index.js\"\n\nexport default class VelociousDatabaseMigrator {\n  /** @type {Record<string, Record<string, boolean>>} */\n  migrationsVersions = {}\n\n  /**\n   * @param {object} args\n   * @param {import(\"../configuration.js\").default} args.configuration\n   */\n  constructor({configuration, ...restArgs}) {\n    restArgsError(restArgs)\n\n    if (!configuration) throw new Error(\"configuration argument is required\")\n\n    this.configuration = configuration\n    this.logger = new Logger(this)\n  }\n\n\n  /** @returns {Promise<void>} */\n  async prepare() {\n    await this.createMigrationsTable()\n    await this.loadMigrationsVersions()\n  }\n\n  /** @returns {Promise<void>} */\n  async createMigrationsTable() {\n    const dbs = await this.configuration.getCurrentConnections()\n\n    for (const dbIdentifier in dbs) {\n      const db = dbs[dbIdentifier]\n      const databaseConfiguration = this.configuration.getDatabaseIdentifier(dbIdentifier)\n\n      if (!databaseConfiguration.migrations) {\n        this.logger.debug(`${dbIdentifier} isn't configured for migrations - skipping creating migrations table for it`)\n        continue\n      }\n\n      const exists = await this.migrationsTableExist(db)\n\n      if (exists) {\n        this.logger.debug(`${dbIdentifier} migrations table already exists - skipping`)\n      } else {\n        this.logger.debug(\"New TableData for schema_migrations\")\n        const schemaMigrationsTable = new TableData(\"schema_migrations\", {ifNotExists: true})\n\n        schemaMigrationsTable.string(\"version\", {null: false, primaryKey: true})\n\n        const createSchemaMigrationsTableSqls = await db.createTableSql(schemaMigrationsTable)\n\n        for (const createSchemaMigrationsTableSql of createSchemaMigrationsTableSqls) {\n          this.logger.debug(`Creating migrations table with SQL`, createSchemaMigrationsTableSql)\n          await db.query(createSchemaMigrationsTableSql)\n        }\n      }\n    }\n  }\n\n  async dropDatabase() {\n    throw new Error(\"Not implemented yet\")\n  }\n\n  /**\n   * @param {string} dbIdentifier\n   * @param {number} version\n   * @returns {boolean}\n   */\n  hasRunMigrationVersion(dbIdentifier, version) {\n    if (!this.migrationsVersions) throw new Error(\"Migrations versions hasn't been loaded yet\")\n    if (!this.migrationsVersions[dbIdentifier]) throw new Error(`Migrations versions hasn't been loaded yet for db: ${dbIdentifier}`)\n\n    if (version in this.migrationsVersions[dbIdentifier]) {\n      return true\n    }\n\n    return false\n  }\n\n  /**\n   * @param {import(\"./migrator/types.js\").MigrationObjectType[]} files\n   * @param {import(\"./migrator/types.js\").ImportFullpathCallbackType} importCallback\n   */\n  async migrateFiles(files, importCallback) {\n    await this.configuration.ensureConnections(async () => {\n      for (const migration of files) {\n        await this.runMigrationFile({\n          migration,\n          requireMigration: async () => {\n            if (!migration.fullPath) throw new Error(`Migration didn't have a fullPath key: ${Object.keys(migration).join(\", \")}`)\n\n            const migrationImport = await importCallback(migration.fullPath)\n\n            if (!migrationImport) {\n              throw new Error(`Migration file must export migration class: ${migration.fullPath}`)\n            }\n\n            return migrationImport\n          }\n        })\n      }\n\n      await this._afterMigrations()\n    })\n  }\n\n  /**\n   * @param {import(\"./migrator/types.js\").RequireMigrationContextType} requireContext\n   * @returns {Promise<void>}\n   */\n  async migrateFilesFromRequireContext(requireContext) {\n    /** @type {import(\"./migrator/types.js\").MigrationObjectType[]} */\n    let files = []\n\n    for (const file of requireContext.keys()) {\n      // \"13,14\" because somes \"require-context\"-npm-module deletes first character!?\n      const match = file.match(/(\\d{13,14})-(.+)\\.js$/)\n\n      if (!match) continue\n\n      // Fix require-context-npm-module deletes first character\n      let fileName = file\n      let dateNumber = match[1]\n\n      if (dateNumber.length == 13) {\n        dateNumber = `2${dateNumber}`\n        fileName = `2${fileName}`\n      }\n\n      // Parse regex\n      const date = parseInt(dateNumber)\n      const migrationName = match[2]\n      const migrationClassName = inflection.camelize(migrationName.replaceAll(\"-\", \"_\"))\n\n      files.push({\n        file: fileName,\n        date,\n        migrationClassName\n      })\n    }\n\n    files = files.sort((migration1, migration2) => migration1.date - migration2.date)\n\n    await this.configuration.ensureConnections(async () => {\n      for (const migration of files) {\n        await this.runMigrationFile({\n          migration,\n          requireMigration: async () => requireContext(migration.file).default\n        })\n      }\n\n      await this._afterMigrations()\n    })\n  }\n\n  /**\n   * @returns {Promise<void>}\n   */\n  async _afterMigrations() {\n    const environmentHandler = this.configuration.getEnvironmentHandler()\n    const dbs = await this.configuration.getCurrentConnections()\n\n    if (!environmentHandler || !dbs || Object.keys(dbs).length == 0) return\n\n    await environmentHandler.afterMigrations({dbs})\n  }\n\n  /** @returns {Promise<void>} */\n  async loadMigrationsVersions() {\n    this.migrationsVersions = {}\n\n    const dbs = await this.configuration.getCurrentConnections()\n\n    for (const dbIdentifier in dbs) {\n      const db = dbs[dbIdentifier]\n      const databaseConfiguration = this.configuration.getDatabaseIdentifier(dbIdentifier)\n\n      if (!databaseConfiguration.migrations) {\n        this.logger.debug(`${dbIdentifier} isn't configured for migrations - skipping loading migrations versions for it`)\n        continue\n      }\n\n      if (!await this.migrationsTableExist(db)) {\n        this.logger.info(`Migration table does not exist for ${dbIdentifier} - skipping loading migrations versions for it`)\n        continue\n      }\n\n      const rows = await db.select(\"schema_migrations\")\n\n      this.migrationsVersions[dbIdentifier] = {}\n\n      for (const row of rows) {\n        const version = digg(row, \"version\")\n\n        this.migrationsVersions[dbIdentifier][version] = true\n      }\n    }\n  }\n\n  /**\n   * @param {import(\"./drivers/base.js\").default} db\n   * @returns {Promise<boolean>}\n   */\n  async migrationsTableExist(db) {\n    const schemaTable = await db.getTableByName(\"schema_migrations\", {throwError: false})\n\n    if (!schemaTable) return false\n\n    return true\n  }\n\n  /**\n   * @param {import(\"./migrator/types.js\").RequireMigrationContextType} requireContext\n   * @returns {Promise<void>}\n   */\n  async executeRequireContext(requireContext) {\n    const migrationFiles = requireContext.keys()\n\n    /** @type {import(\"./migrator/types.js\").MigrationObjectType[]} */\n    let files = []\n\n    for (const file of migrationFiles) {\n      const match = file.match(/^(\\d{14})-(.+)\\.js$/)\n\n      if (!match) continue\n\n      const date = parseInt(match[1])\n      const migrationName = match[2]\n      const migrationClassName = inflection.camelize(migrationName)\n\n      const migrationObject = /** @type {import(\"./migrator/types.js\").MigrationObjectType} */ ({\n        file,\n        date,\n        migrationClassName\n      })\n\n      files.push(migrationObject)\n    }\n\n    files = files.sort((migration1, migration2) => migration1.date - migration2.date)\n\n    for (const migration of files) {\n      await this.runMigrationFile({\n        migration,\n        requireMigration: async () => requireContext(migration.file).default\n      })\n    }\n  }\n\n  /**\n   * @returns {Promise<void>}\n   */\n  async reset() {\n    const dbs = await this.configuration.getCurrentConnections()\n\n    for (const dbIdentifier in dbs) {\n      const db = dbs[dbIdentifier]\n\n      await db.withDisabledForeignKeys(async () => {\n        while (true) {\n          const errors = []\n          let anyTableDropped = false\n\n          try {\n            for (const table of await db.getTables()) {\n              this.logger.info(`Dropping table ${table.getName()}`)\n\n              try {\n                await db.dropTable(table.getName(), {cascade: true})\n                anyTableDropped = true\n              } catch (error) {\n                errors.push(error)\n              }\n            }\n\n            break\n          } catch (error) { // eslint-disable-line no-unused-vars\n            if (errors.length > 0 && anyTableDropped) {\n              // Retry\n            } else {\n              throw errors[0]\n            }\n          }\n        }\n      })\n    }\n  }\n\n  /**\n   * @param {import(\"./migrator/types.js\").MigrationObjectType[]} files\n   * @param {import(\"./migrator/types.js\").ImportFullpathCallbackType} importCallback Function to import a file\n   * @returns {Promise<void>}\n   */\n  async rollback(files, importCallback) {\n    const latestMigrationVersion = await this._latestMigrationVersion()\n\n    if (!latestMigrationVersion) {\n      throw new Error(\"No migrations have been run yet\")\n    }\n\n    const latestMigrationVersionNumber = parseInt(latestMigrationVersion)\n    const migration = files.find((file) => file.date == latestMigrationVersionNumber)\n\n    if (!migration) {\n      throw new Error(`Migration file for version ${latestMigrationVersionNumber} not found`)\n    }\n\n    await this.runMigrationFile({\n      migration,\n      requireMigration: async () => {\n        if (!migration.fullPath) throw new Error(`Migration didn't have a fullPath key: ${Object.keys(migration).join(\", \")}`)\n\n        return await importCallback(migration.fullPath)\n      },\n      direction: \"down\"\n    })\n  }\n\n  /**\n   * @returns {Promise<string | undefined>} The latest migration version\n   */\n  async _latestMigrationVersion() {\n    if (!this.migrationsVersions) await this.loadMigrationsVersions()\n\n    /** @type {string | undefined} */\n    let highestVersion\n\n    for (const dbIdentifier in this.migrationsVersions) {\n      for (const migrationVersion in this.migrationsVersions[dbIdentifier]) {\n        if (!highestVersion || migrationVersion > highestVersion) {\n          highestVersion = migrationVersion\n        }\n      }\n    }\n\n    return highestVersion\n  }\n\n  /**\n   * @param {object} args\n   * @param {import(\"./migrator/types.js\").MigrationObjectType} args.migration\n   * @param {import(\"./migrator/types.js\").RequireMigrationType} args.requireMigration\n   * @param {string} [args.direction]\n   */\n  async runMigrationFile({migration, requireMigration, direction = \"up\"}) {\n    if (!this.configuration) throw new Error(\"No configuration set\")\n    if (!this.configuration.isDatabasePoolInitialized()) await this.configuration.initializeDatabasePool()\n    if (!this.migrationsVersions) await this.loadMigrationsVersions()\n\n    const dbs = await this.configuration.getCurrentConnections()\n    const migrationClass = await requireMigration()\n\n    if (!migrationClass || typeof migrationClass !== \"function\") {\n      throw new Error(`Migration ${migration.file} must export a default migration class. Type: ${typeof migrationClass}`)\n    }\n\n    const migrationDatabaseIdentifiers = migrationClass.getDatabaseIdentifiers() || [\"default\"]\n\n    for (const dbIdentifier in dbs) {\n      const databaseConfiguration = this.configuration.getDatabaseIdentifier(dbIdentifier)\n\n      if (!databaseConfiguration.migrations) {\n        this.logger.debug(`${dbIdentifier} isn't configured for migrations - skipping migration ${digg(migration, \"date\")}`)\n        continue\n      }\n\n      if (!migrationDatabaseIdentifiers.includes(dbIdentifier)) {\n        this.logger.debug(`${dbIdentifier} shouldn't run migration ${migration.file}`, {migrationDatabaseIdentifiers})\n        continue\n      }\n\n      if (direction == \"up\") {\n        if (this.hasRunMigrationVersion(dbIdentifier, migration.date)) {\n          this.logger.debug(`${dbIdentifier} has already run migration ${migration.file}`)\n          continue\n        }\n      } else if (direction == \"down\") {\n        if (!this.hasRunMigrationVersion(dbIdentifier, migration.date)) {\n          this.logger.debug(`${dbIdentifier} hasn't run migration ${migration.file}`)\n          continue\n        }\n      } else {\n        throw new Error(`Unknown direction: ${direction}`)\n      }\n\n      this.logger.debug(`Running migration on ${dbIdentifier}: ${migration.file}`, {migrationDatabaseIdentifiers})\n\n      const db = dbs[dbIdentifier]\n      const MigrationClass = migrationClass\n      const migrationInstance = new MigrationClass({\n        configuration: this.configuration,\n        databaseIdentifier: dbIdentifier,\n        db\n      })\n      const dateString = `${digg(migration, \"date\")}`\n\n      if (direction == \"up\") {\n        try {\n          await migrationInstance.change()\n        } catch (changeError) {\n          if (changeError instanceof NotImplementedError) {\n            try {\n              await migrationInstance.up()\n            } catch (upError) {\n              if (upError instanceof NotImplementedError) {\n                throw new Error(`'change' or 'up' didn't exist on migration: ${migration.file}`)\n              } else {\n                throw upError\n              }\n            }\n          } else {\n            throw changeError\n          }\n        }\n\n        const existingSchemaMigrations = await db.newQuery()\n          .from(\"schema_migrations\")\n          .where({version: dateString})\n          .results()\n\n        if (existingSchemaMigrations.length == 0) {\n          await db.insert({tableName: \"schema_migrations\", data: {version: dateString}})\n        }\n      } else if (direction == \"down\") {\n        try {\n          await migrationInstance.down()\n        } catch (downError) {\n          if (downError instanceof NotImplementedError) {\n            throw new Error(`'down' didn't exist on migration: ${migration.file} or migrating down with a change method isn't currently supported`)\n          } else {\n            throw downError\n          }\n        }\n\n        await db.delete({tableName: \"schema_migrations\", conditions: {version: dateString}})\n      } else {\n        throw new Error(`Unknown direction: ${direction}`)\n      }\n    }\n  }\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"async-tracked-multi-connection.d.ts","sourceRoot":"","sources":["../../../../src/database/pool/async-tracked-multi-connection.js"],"names":[],"mappings":"AAKA;IACE;;;OAGG;IACH,0BAFU,OAAO,CAAC,OAAO,wBAAwB,EAAE,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,oBAAoB,EAAE,OAAO,CAAC,CAAC,CAEzE;IAsJxC;;;;;OAKG;IACH,0CAJW,MAAM,CAAC,MAAM,EAAE,OAAO,oBAAoB,EAAE,OAAO,CAAC,kBACpD,OAAO,wBAAwB,EAAE,OAAO,GACtC,IAAI,CAchB;IAED;;;;OAIG;IACH,8CAHW,OAAO,wBAAwB,EAAE,OAAO,GACtC,IAAI,CAShB;IApLD,0CAA2C;IAE3C,qDAAqD;IACrD,aADW,OAAO,oBAAoB,EAAE,OAAO,EAAE,CACjC;IAEhB,mEAAmE;IACnE,kBADW,MAAM,CAAC,MAAM,EAAE,OAAO,oBAAoB,EAAE,OAAO,CAAC,CAC1C;IAErB,cAAS;IA+FT;;;;OAIG;IACH,gCAHW,OAAO,oBAAoB,EAAE,OAAO,GAClC,IAAI,CAYhB;IAoBD;;OAEG;IACH,uBAFa,OAAO,oBAAoB,EAAE,OAAO,GAAG,SAAS,CAO5D;CAmCF;qBA9LoB,WAAW;kCADA,aAAa"}
1
+ {"version":3,"file":"async-tracked-multi-connection.d.ts","sourceRoot":"","sources":["../../../../src/database/pool/async-tracked-multi-connection.js"],"names":[],"mappings":"AAKA;IACE;;;OAGG;IACH,0BAFU,OAAO,CAAC,OAAO,wBAAwB,EAAE,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,oBAAoB,EAAE,OAAO,CAAC,CAAC,CAEzE;IA2JxC;;;;;OAKG;IACH,0CAJW,MAAM,CAAC,MAAM,EAAE,OAAO,oBAAoB,EAAE,OAAO,CAAC,kBACpD,OAAO,wBAAwB,EAAE,OAAO,GACtC,IAAI,CAchB;IAED;;;;OAIG;IACH,8CAHW,OAAO,wBAAwB,EAAE,OAAO,GACtC,IAAI,CAShB;IAzLD,0CAA2C;IAE3C,qDAAqD;IACrD,aADW,OAAO,oBAAoB,EAAE,OAAO,EAAE,CACjC;IAEhB,mEAAmE;IACnE,kBADW,MAAM,CAAC,MAAM,EAAE,OAAO,oBAAoB,EAAE,OAAO,CAAC,CAC1C;IAErB,cAAS;IAuFT;;;;OAIG;IACH,gCAHW,OAAO,oBAAoB,EAAE,OAAO,GAClC,IAAI,CAYhB;IAiCD;;OAEG;IACH,uBAFa,OAAO,oBAAoB,EAAE,OAAO,GAAG,SAAS,CAO5D;CAmCF;qBAnMoB,WAAW;kCADA,aAAa"}
@@ -21,9 +21,7 @@ export default class VelociousDatabasePoolAsyncTrackedMultiConnection extends Ba
21
21
  constructor({ configuration, identifier }) {
22
22
  super({ configuration, identifier });
23
23
  }
24
- /**
25
- * @param {import("../drivers/base.js").default} connection
26
- */
24
+ /** @param {import("../drivers/base.js").default} connection */
27
25
  checkin(connection) {
28
26
  const id = connection.getIdSeq();
29
27
  if (typeof id !== "number") {
@@ -35,9 +33,7 @@ export default class VelociousDatabasePoolAsyncTrackedMultiConnection extends Ba
35
33
  connection.setIdSeq(undefined);
36
34
  this.connections.push(connection);
37
35
  }
38
- /**
39
- * @returns {Promise<import("../drivers/base.js").default>}
40
- */
36
+ /** @returns {Promise<import("../drivers/base.js").default>} */
41
37
  async checkout() {
42
38
  let connection = this.connections.shift();
43
39
  if (!connection) {
@@ -50,9 +46,7 @@ export default class VelociousDatabasePoolAsyncTrackedMultiConnection extends Ba
50
46
  this.connectionsInUse[id] = connection;
51
47
  return connection;
52
48
  }
53
- /**
54
- * @param {function(import("../drivers/base.js").default) : void} callback
55
- */
49
+ /** @param {function(import("../drivers/base.js").default) : void} callback */
56
50
  async withConnection(callback) {
57
51
  const connection = await this.checkout();
58
52
  const id = connection.getIdSeq();
@@ -65,9 +59,7 @@ export default class VelociousDatabasePoolAsyncTrackedMultiConnection extends Ba
65
59
  }
66
60
  });
67
61
  }
68
- /**
69
- * @returns {import("../drivers/base.js").default}
70
- */
62
+ /** @returns {import("../drivers/base.js").default} */
71
63
  getCurrentConnection() {
72
64
  const id = this.asyncLocalStorage.getStore();
73
65
  if (id === undefined) {
@@ -114,6 +106,17 @@ export default class VelociousDatabasePoolAsyncTrackedMultiConnection extends Ba
114
106
  this.setGlobalConnection(connection);
115
107
  return connection;
116
108
  }
109
+ /**
110
+ * Returns the connection tied to the current async context, if any.
111
+ * Does not fall back to the global connection.
112
+ * @returns {import("../drivers/base.js").default | undefined}
113
+ */
114
+ getCurrentContextConnection() {
115
+ const id = this.asyncLocalStorage.getStore();
116
+ if (id === undefined)
117
+ return undefined;
118
+ return this.getCurrentConnection();
119
+ }
117
120
  /**
118
121
  * @returns {import("../drivers/base.js").default | undefined}
119
122
  */
@@ -152,4 +155,4 @@ export default class VelociousDatabasePoolAsyncTrackedMultiConnection extends Ba
152
155
  this.globalConnections.delete(configuration);
153
156
  }
154
157
  }
155
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"async-tracked-multi-connection.js","sourceRoot":"","sources":["../../../../src/database/pool/async-tracked-multi-connection.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport {AsyncLocalStorage} from \"async_hooks\"\nimport BasePool from \"./base.js\"\n\nexport default class VelociousDatabasePoolAsyncTrackedMultiConnection extends BasePool {\n  /**\n   * Global fallback connections keyed by configuration instance and pool identifier.\n   * @type {WeakMap<import(\"../../configuration.js\").default, Record<string, import(\"../drivers/base.js\").default>>}\n   */\n  static globalConnections = new WeakMap()\n\n  asyncLocalStorage = new AsyncLocalStorage()\n\n  /** @type {import(\"../drivers/base.js\").default[]} */\n  connections = []\n\n  /** @type {Record<number, import(\"../drivers/base.js\").default>} */\n  connectionsInUse = {}\n\n  idSeq = 0\n\n  /**\n   * @param {object} args\n   * @param {import(\"../../configuration.js\").default} args.configuration\n   * @param {string} args.identifier\n   */\n  constructor({configuration, identifier}) {\n    super({configuration, identifier})\n  }\n\n  /**\n   * @param {import(\"../drivers/base.js\").default} connection\n   */\n  checkin(connection) {\n    const id = connection.getIdSeq()\n\n    if (typeof id !== \"number\") {\n      throw new Error(`idSeq on connection wasn't set? '${typeof id}' = ${id}`)\n    }\n\n    if (id in this.connectionsInUse) {\n      delete this.connectionsInUse[id]\n    }\n\n    connection.setIdSeq(undefined)\n\n    this.connections.push(connection)\n  }\n\n  /**\n   * @returns {Promise<import(\"../drivers/base.js\").default>}\n   */\n  async checkout() {\n    let connection = this.connections.shift()\n\n    if (!connection) {\n      connection = await this.spawnConnection()\n    }\n\n    if (connection.getIdSeq() !== undefined) throw new Error(`Connection already has an ID-seq - is it in use? ${connection.getIdSeq()}`)\n\n    const id = this.idSeq++\n\n    connection.setIdSeq(id)\n    this.connectionsInUse[id] = connection\n\n    return connection\n  }\n\n  /**\n   * @param {function(import(\"../drivers/base.js\").default) : void} callback\n   */\n  async withConnection(callback) {\n    const connection = await this.checkout()\n    const id = connection.getIdSeq()\n\n    await this.asyncLocalStorage.run(id, async () => {\n      try {\n        await callback(connection)\n      } finally {\n        this.checkin(connection)\n      }\n    })\n  }\n\n  /**\n   * @returns {import(\"../drivers/base.js\").default}\n   */\n  getCurrentConnection() {\n    const id = this.asyncLocalStorage.getStore()\n\n    if (id === undefined) {\n      const fallbackConnection = this.getGlobalConnection()\n\n      if (fallbackConnection) {\n        return fallbackConnection\n      }\n\n      throw new Error(\"ID hasn't been set for this async context\")\n    }\n\n    if (!(id in this.connectionsInUse)) {\n      throw new Error(`Connection ${id} doesn't exist any more - has it been checked in again?`)\n    }\n\n    const currentConnection = this.connectionsInUse[id]\n\n    if (!currentConnection) {\n      throw new Error(`Couldn't get current connection from that ID: ${id}`)\n    }\n\n    return currentConnection\n  }\n\n  /**\n   * Registers a fallback connection for this pool identifier that will be used when no async context is available.\n   * @param {import(\"../drivers/base.js\").default} connection\n   * @returns {void}\n   */\n  setGlobalConnection(connection) {\n    const klass = /** @type {typeof VelociousDatabasePoolAsyncTrackedMultiConnection} */ (this.constructor)\n    let mapForConfiguration = klass.globalConnections.get(this.configuration)\n\n    if (!mapForConfiguration) {\n      mapForConfiguration = {}\n      klass.globalConnections.set(this.configuration, mapForConfiguration)\n    }\n\n    mapForConfiguration[this.identifier] = connection\n  }\n\n  /**\n   * Ensures a global fallback connection exists for this pool identifier and returns it.\n   * If one is already set, it is returned and also made available in the pool queue.\n   * Otherwise a new connection is spawned, registered, and queued.\n   * @returns {Promise<import(\"../drivers/base.js\").default>}\n   */\n  async ensureGlobalConnection() {\n    const existing = this.getGlobalConnection()\n\n    if (existing) return existing\n\n    const connection = await this.spawnConnection()\n\n    this.setGlobalConnection(connection)\n\n    return connection\n  }\n\n  /**\n   * @returns {import(\"../drivers/base.js\").default | undefined}\n   */\n  getGlobalConnection() {\n    const klass = /** @type {typeof VelociousDatabasePoolAsyncTrackedMultiConnection} */ (this.constructor)\n    const mapForConfiguration = klass.globalConnections.get(this.configuration)\n\n    return mapForConfiguration?.[this.identifier]\n  }\n\n  /**\n   * Replaces all globally registered fallback connections.\n   * @param {Record<string, import(\"../drivers/base.js\").default>} [connections]\n   * @param {import(\"../../configuration.js\").default} [configuration]\n   * @returns {void}\n   */\n  static setGlobalConnections(connections, configuration) {\n    if (!connections && !configuration) {\n      this.globalConnections = new WeakMap()\n      return\n    }\n\n    if (!configuration) {\n      this.globalConnections = new WeakMap()\n      return\n    }\n\n    this.globalConnections.set(configuration, connections || {})\n  }\n\n  /**\n   * Clears globally registered fallback connections for all configurations or a single configuration.\n   * @param {import(\"../../configuration.js\").default} [configuration]\n   * @returns {void}\n   */\n  static clearGlobalConnections(configuration) {\n    if (!configuration) {\n      this.globalConnections = new WeakMap()\n      return\n    }\n\n    this.globalConnections.delete(configuration)\n  }\n}\n"]}
158
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"async-tracked-multi-connection.js","sourceRoot":"","sources":["../../../../src/database/pool/async-tracked-multi-connection.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport {AsyncLocalStorage} from \"async_hooks\"\nimport BasePool from \"./base.js\"\n\nexport default class VelociousDatabasePoolAsyncTrackedMultiConnection extends BasePool {\n  /**\n   * Global fallback connections keyed by configuration instance and pool identifier.\n   * @type {WeakMap<import(\"../../configuration.js\").default, Record<string, import(\"../drivers/base.js\").default>>}\n   */\n  static globalConnections = new WeakMap()\n\n  asyncLocalStorage = new AsyncLocalStorage()\n\n  /** @type {import(\"../drivers/base.js\").default[]} */\n  connections = []\n\n  /** @type {Record<number, import(\"../drivers/base.js\").default>} */\n  connectionsInUse = {}\n\n  idSeq = 0\n\n  /**\n   * @param {object} args\n   * @param {import(\"../../configuration.js\").default} args.configuration\n   * @param {string} args.identifier\n   */\n  constructor({configuration, identifier}) {\n    super({configuration, identifier})\n  }\n\n  /** @param {import(\"../drivers/base.js\").default} connection */\n  checkin(connection) {\n    const id = connection.getIdSeq()\n\n    if (typeof id !== \"number\") {\n      throw new Error(`idSeq on connection wasn't set? '${typeof id}' = ${id}`)\n    }\n\n    if (id in this.connectionsInUse) {\n      delete this.connectionsInUse[id]\n    }\n\n    connection.setIdSeq(undefined)\n\n    this.connections.push(connection)\n  }\n\n  /** @returns {Promise<import(\"../drivers/base.js\").default>} */\n  async checkout() {\n    let connection = this.connections.shift()\n\n    if (!connection) {\n      connection = await this.spawnConnection()\n    }\n\n    if (connection.getIdSeq() !== undefined) throw new Error(`Connection already has an ID-seq - is it in use? ${connection.getIdSeq()}`)\n\n    const id = this.idSeq++\n\n    connection.setIdSeq(id)\n    this.connectionsInUse[id] = connection\n\n    return connection\n  }\n\n  /** @param {function(import(\"../drivers/base.js\").default) : void} callback */\n  async withConnection(callback) {\n    const connection = await this.checkout()\n    const id = connection.getIdSeq()\n\n    await this.asyncLocalStorage.run(id, async () => {\n      try {\n        await callback(connection)\n      } finally {\n        this.checkin(connection)\n      }\n    })\n  }\n\n  /** @returns {import(\"../drivers/base.js\").default} */\n  getCurrentConnection() {\n    const id = this.asyncLocalStorage.getStore()\n\n    if (id === undefined) {\n      const fallbackConnection = this.getGlobalConnection()\n\n      if (fallbackConnection) {\n        return fallbackConnection\n      }\n\n      throw new Error(\"ID hasn't been set for this async context\")\n    }\n\n    if (!(id in this.connectionsInUse)) {\n      throw new Error(`Connection ${id} doesn't exist any more - has it been checked in again?`)\n    }\n\n    const currentConnection = this.connectionsInUse[id]\n\n    if (!currentConnection) {\n      throw new Error(`Couldn't get current connection from that ID: ${id}`)\n    }\n\n    return currentConnection\n  }\n\n  /**\n   * Registers a fallback connection for this pool identifier that will be used when no async context is available.\n   * @param {import(\"../drivers/base.js\").default} connection\n   * @returns {void}\n   */\n  setGlobalConnection(connection) {\n    const klass = /** @type {typeof VelociousDatabasePoolAsyncTrackedMultiConnection} */ (this.constructor)\n    let mapForConfiguration = klass.globalConnections.get(this.configuration)\n\n    if (!mapForConfiguration) {\n      mapForConfiguration = {}\n      klass.globalConnections.set(this.configuration, mapForConfiguration)\n    }\n\n    mapForConfiguration[this.identifier] = connection\n  }\n\n  /**\n   * Ensures a global fallback connection exists for this pool identifier and returns it.\n   * If one is already set, it is returned and also made available in the pool queue.\n   * Otherwise a new connection is spawned, registered, and queued.\n   * @returns {Promise<import(\"../drivers/base.js\").default>}\n   */\n  async ensureGlobalConnection() {\n    const existing = this.getGlobalConnection()\n\n    if (existing) return existing\n\n    const connection = await this.spawnConnection()\n\n    this.setGlobalConnection(connection)\n\n    return connection\n  }\n\n  /**\n   * Returns the connection tied to the current async context, if any.\n   * Does not fall back to the global connection.\n   * @returns {import(\"../drivers/base.js\").default | undefined}\n   */\n  getCurrentContextConnection() {\n    const id = this.asyncLocalStorage.getStore()\n\n    if (id === undefined) return undefined\n\n    return this.getCurrentConnection()\n  }\n\n  /**\n   * @returns {import(\"../drivers/base.js\").default | undefined}\n   */\n  getGlobalConnection() {\n    const klass = /** @type {typeof VelociousDatabasePoolAsyncTrackedMultiConnection} */ (this.constructor)\n    const mapForConfiguration = klass.globalConnections.get(this.configuration)\n\n    return mapForConfiguration?.[this.identifier]\n  }\n\n  /**\n   * Replaces all globally registered fallback connections.\n   * @param {Record<string, import(\"../drivers/base.js\").default>} [connections]\n   * @param {import(\"../../configuration.js\").default} [configuration]\n   * @returns {void}\n   */\n  static setGlobalConnections(connections, configuration) {\n    if (!connections && !configuration) {\n      this.globalConnections = new WeakMap()\n      return\n    }\n\n    if (!configuration) {\n      this.globalConnections = new WeakMap()\n      return\n    }\n\n    this.globalConnections.set(configuration, connections || {})\n  }\n\n  /**\n   * Clears globally registered fallback connections for all configurations or a single configuration.\n   * @param {import(\"../../configuration.js\").default} [configuration]\n   * @returns {void}\n   */\n  static clearGlobalConnections(configuration) {\n    if (!configuration) {\n      this.globalConnections = new WeakMap()\n      return\n    }\n\n    this.globalConnections.delete(configuration)\n  }\n}\n"]}
@@ -31,6 +31,12 @@ declare class VelociousDatabasePoolBase {
31
31
  * @returns {import("../drivers/base.js").default}
32
32
  */
33
33
  getCurrentConnection(): import("../drivers/base.js").default;
34
+ /**
35
+ * Returns the connection pinned to the current context, if any.
36
+ * Default implementation defers to `getCurrentConnection`.
37
+ * @returns {import("../drivers/base.js").default | undefined}
38
+ */
39
+ getCurrentContextConnection(): import("../drivers/base.js").default | undefined;
34
40
  /**
35
41
  * @returns {{driver: typeof import("../drivers/base.js").default, type: string}}
36
42
  */
@@ -1 +1 @@
1
- {"version":3,"file":"base.d.ts","sourceRoot":"","sources":["../../../../src/database/pool/base.js"],"names":[],"mappings":";AAYA;IACE;;OAEG;IACH,kBAFa,yBAAyB,CAMrC;IAED;;;;OAIG;IACH,2CAHG;QAA4B,aAAa,EAAjC,aAAa;QACA,UAAU,EAAvB,MAAM;KAChB,EASA;IAPC,6BAA6D;IAK7D,mBAA4B;IAC5B,eAA8B;IAGhC;;;OAGG;IACH,qBAFW,OAAO,oBAAoB,EAAE,OAAO,QAI9C;IAED;;;OAGG;IACH,YAFa,OAAO,CAAC,OAAO,oBAAoB,EAAE,OAAO,CAAC,CAIzD;IAED;;;OAGG;IACH,wBAFa,OAAO,oBAAoB,EAAE,OAAO,CAIhD;IAED;;OAEG;IACH,oBAFa;QAAC,MAAM,EAAE,cAAc,oBAAoB,EAAE,OAAO,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAC,CAI/E;IAED;;;OAGG;IACH,kBAFa,MAAM,CAIlB;IAED;;OAEG;IACH,cAFa,IAAI,CAIhB;IAED;;OAEG;IACH,4BAFW,cAAc,oBAAoB,EAAE,OAAO,QAIrD;IADC,yDAA8B;IAGhC;;OAEG;IACH,mBAFa,OAAO,CAAC,OAAO,oBAAoB,EAAE,OAAO,CAAC,CAUzD;IAED;;;;OAIG;IACH,yCAHG;QAA4D,MAAM,EAA1D,cAAc,oBAAoB,EAAE,OAAO;KACnD,GAAU,OAAO,CAAC,OAAO,oBAAoB,EAAE,OAAO,CAAC,CAYzD;IAED;;;;OAIG;IACH,0BAHW,CAAS,IAAoC,EAApC,OAAO,oBAAoB,EAAE,OAAO,KAAI,IAAI,GACnD,OAAO,CAAC,IAAI,CAAC,CAIzB;IAED;;;;OAIG;IACH,0BAFa,OAAO,CAAC,OAAO,oBAAoB,EAAE,OAAO,CAAC,CAIzD;CACF;0BAvIyB,wBAAwB;uBAE7B,iBAAiB"}
1
+ {"version":3,"file":"base.d.ts","sourceRoot":"","sources":["../../../../src/database/pool/base.js"],"names":[],"mappings":";AAYA;IACE;;OAEG;IACH,kBAFa,yBAAyB,CAMrC;IAED;;;;OAIG;IACH,2CAHG;QAA4B,aAAa,EAAjC,aAAa;QACA,UAAU,EAAvB,MAAM;KAChB,EASA;IAPC,6BAA6D;IAK7D,mBAA4B;IAC5B,eAA8B;IAGhC;;;OAGG;IACH,qBAFW,OAAO,oBAAoB,EAAE,OAAO,QAI9C;IAED;;;OAGG;IACH,YAFa,OAAO,CAAC,OAAO,oBAAoB,EAAE,OAAO,CAAC,CAIzD;IAED;;;OAGG;IACH,wBAFa,OAAO,oBAAoB,EAAE,OAAO,CAIhD;IAED;;;;OAIG;IACH,+BAFa,OAAO,oBAAoB,EAAE,OAAO,GAAG,SAAS,CAI5D;IAED;;OAEG;IACH,oBAFa;QAAC,MAAM,EAAE,cAAc,oBAAoB,EAAE,OAAO,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAC,CAI/E;IAED;;;OAGG;IACH,kBAFa,MAAM,CAIlB;IAED;;OAEG;IACH,cAFa,IAAI,CAIhB;IAED;;OAEG;IACH,4BAFW,cAAc,oBAAoB,EAAE,OAAO,QAIrD;IADC,yDAA8B;IAGhC;;OAEG;IACH,mBAFa,OAAO,CAAC,OAAO,oBAAoB,EAAE,OAAO,CAAC,CAUzD;IAED;;;;OAIG;IACH,yCAHG;QAA4D,MAAM,EAA1D,cAAc,oBAAoB,EAAE,OAAO;KACnD,GAAU,OAAO,CAAC,OAAO,oBAAoB,EAAE,OAAO,CAAC,CAYzD;IAED;;;;OAIG;IACH,0BAHW,CAAS,IAAoC,EAApC,OAAO,oBAAoB,EAAE,OAAO,KAAI,IAAI,GACnD,OAAO,CAAC,IAAI,CAAC,CAIzB;IAED;;;;OAIG;IACH,0BAFa,OAAO,CAAC,OAAO,oBAAoB,EAAE,OAAO,CAAC,CAIzD;CACF;0BAhJyB,wBAAwB;uBAE7B,iBAAiB"}
@@ -51,6 +51,14 @@ class VelociousDatabasePoolBase {
51
51
  getCurrentConnection() {
52
52
  throw new Error("'getCurrentConnection' not implemented");
53
53
  }
54
+ /**
55
+ * Returns the connection pinned to the current context, if any.
56
+ * Default implementation defers to `getCurrentConnection`.
57
+ * @returns {import("../drivers/base.js").default | undefined}
58
+ */
59
+ getCurrentContextConnection() {
60
+ return this.getCurrentConnection();
61
+ }
54
62
  /**
55
63
  * @returns {{driver: typeof import("../drivers/base.js").default, type: string}}
56
64
  */
@@ -117,4 +125,4 @@ class VelociousDatabasePoolBase {
117
125
  }
118
126
  baseMethodsForward(VelociousDatabasePoolBase);
119
127
  export default VelociousDatabasePoolBase;
120
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base.js","sourceRoot":"","sources":["../../../../src/database/pool/base.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport Configuration from \"../../configuration.js\"\nimport {digg} from \"diggerize\"\nimport {Logger} from \"../../logger.js\"\nimport baseMethodsForward from \"./base-methods-forward.js\"\n\n/** @type {{currentPool: VelociousDatabasePoolBase | null}} */\nconst shared = {\n  currentPool: null\n}\n\nclass VelociousDatabasePoolBase {\n  /**\n   * @returns {VelociousDatabasePoolBase}\n   */\n  static current() {\n    if (!shared.currentPool) throw new Error(\"A database pool hasn't been set\")\n\n    return shared.currentPool\n  }\n\n  /**\n   * @param {object} args\n   * @param {Configuration} args.configuration\n   * @param {string} args.identifier\n   */\n  constructor({configuration, identifier}) {\n    this.configuration = configuration || Configuration.current()\n\n    if (!this.configuration) throw new Error(\"No configuration given\")\n    if (!identifier) throw new Error(\"No identifier was given\")\n\n    this.identifier = identifier\n    this.logger = new Logger(this)\n  }\n\n  /**\n   * @abstract\n   * @param {import(\"../drivers/base.js\").default} _connection\n   */\n  checkin(_connection) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'checkin' not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @returns {Promise<import(\"../drivers/base.js\").default>}\n   */\n  checkout() {\n    throw new Error(\"'checkout' not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @returns {import(\"../drivers/base.js\").default}\n   */\n  getCurrentConnection() {\n    throw new Error(\"'getCurrentConnection' not implemented\")\n  }\n\n  /**\n   * @returns {{driver: typeof import(\"../drivers/base.js\").default, type: string}}\n   */\n  getConfiguration() {\n    return digg(this.configuration.getDatabaseConfiguration(), this.identifier)\n  }\n\n  /**\n   * @abstract\n   * @returns {string}\n   */\n  primaryKeyType() {\n    throw new Error(\"'primaryKeyType' not implemented\")\n  }\n\n  /**\n   * @returns {void}\n   */\n  setCurrent() {\n    shared.currentPool = this\n  }\n\n  /**\n   * @param {typeof import(\"../drivers/base.js\").default} driverClass\n   */\n  setDriverClass(driverClass) {\n    this.driverClass = driverClass\n  }\n\n  /**\n   * @returns {Promise<import(\"../drivers/base.js\").default>}\n   */\n  async spawnConnection() {\n    const databaseConfig = this.getConfiguration()\n\n    this.logger.debug(\"spawnConnection\", {identifier: this.identifier, databaseConfig})\n\n    const connection = await this.spawnConnectionWithConfiguration(databaseConfig)\n\n    return connection\n  }\n\n  /**\n   * @param {object} config\n   * @param {typeof import(\"../drivers/base.js\").default} config.driver\n   * @returns {Promise<import(\"../drivers/base.js\").default>}\n   */\n  async spawnConnectionWithConfiguration(config) {\n    const DriverClass = config.driver || this.driverClass\n\n    if (!DriverClass) throw new Error(\"No driver class set in database pool or in given config\")\n\n    const connection = new DriverClass(config, this.configuration)\n\n    await connection.connect()\n\n    return connection\n  }\n\n  /**\n   * @abstract\n   * @param {function(import(\"../drivers/base.js\").default) : void} _callback\n   * @returns {Promise<void>}\n   */\n  withConnection(_callback) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'withConnection' not implemented\")\n  }\n\n  /**\n   * Ensures a reusable connection exists for contexts where AsyncLocalStorage isn't set.\n   * Default implementation just checks out a connection.\n   * @returns {Promise<import(\"../drivers/base.js\").default>}\n   */\n  async ensureGlobalConnection() {\n    return await this.checkout()\n  }\n}\n\nbaseMethodsForward(VelociousDatabasePoolBase)\n\nexport default VelociousDatabasePoolBase\n"]}
128
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base.js","sourceRoot":"","sources":["../../../../src/database/pool/base.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport Configuration from \"../../configuration.js\"\nimport {digg} from \"diggerize\"\nimport {Logger} from \"../../logger.js\"\nimport baseMethodsForward from \"./base-methods-forward.js\"\n\n/** @type {{currentPool: VelociousDatabasePoolBase | null}} */\nconst shared = {\n  currentPool: null\n}\n\nclass VelociousDatabasePoolBase {\n  /**\n   * @returns {VelociousDatabasePoolBase}\n   */\n  static current() {\n    if (!shared.currentPool) throw new Error(\"A database pool hasn't been set\")\n\n    return shared.currentPool\n  }\n\n  /**\n   * @param {object} args\n   * @param {Configuration} args.configuration\n   * @param {string} args.identifier\n   */\n  constructor({configuration, identifier}) {\n    this.configuration = configuration || Configuration.current()\n\n    if (!this.configuration) throw new Error(\"No configuration given\")\n    if (!identifier) throw new Error(\"No identifier was given\")\n\n    this.identifier = identifier\n    this.logger = new Logger(this)\n  }\n\n  /**\n   * @abstract\n   * @param {import(\"../drivers/base.js\").default} _connection\n   */\n  checkin(_connection) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'checkin' not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @returns {Promise<import(\"../drivers/base.js\").default>}\n   */\n  checkout() {\n    throw new Error(\"'checkout' not implemented\")\n  }\n\n  /**\n   * @abstract\n   * @returns {import(\"../drivers/base.js\").default}\n   */\n  getCurrentConnection() {\n    throw new Error(\"'getCurrentConnection' not implemented\")\n  }\n\n  /**\n   * Returns the connection pinned to the current context, if any.\n   * Default implementation defers to `getCurrentConnection`.\n   * @returns {import(\"../drivers/base.js\").default | undefined}\n   */\n  getCurrentContextConnection() {\n    return this.getCurrentConnection()\n  }\n\n  /**\n   * @returns {{driver: typeof import(\"../drivers/base.js\").default, type: string}}\n   */\n  getConfiguration() {\n    return digg(this.configuration.getDatabaseConfiguration(), this.identifier)\n  }\n\n  /**\n   * @abstract\n   * @returns {string}\n   */\n  primaryKeyType() {\n    throw new Error(\"'primaryKeyType' not implemented\")\n  }\n\n  /**\n   * @returns {void}\n   */\n  setCurrent() {\n    shared.currentPool = this\n  }\n\n  /**\n   * @param {typeof import(\"../drivers/base.js\").default} driverClass\n   */\n  setDriverClass(driverClass) {\n    this.driverClass = driverClass\n  }\n\n  /**\n   * @returns {Promise<import(\"../drivers/base.js\").default>}\n   */\n  async spawnConnection() {\n    const databaseConfig = this.getConfiguration()\n\n    this.logger.debug(\"spawnConnection\", {identifier: this.identifier, databaseConfig})\n\n    const connection = await this.spawnConnectionWithConfiguration(databaseConfig)\n\n    return connection\n  }\n\n  /**\n   * @param {object} config\n   * @param {typeof import(\"../drivers/base.js\").default} config.driver\n   * @returns {Promise<import(\"../drivers/base.js\").default>}\n   */\n  async spawnConnectionWithConfiguration(config) {\n    const DriverClass = config.driver || this.driverClass\n\n    if (!DriverClass) throw new Error(\"No driver class set in database pool or in given config\")\n\n    const connection = new DriverClass(config, this.configuration)\n\n    await connection.connect()\n\n    return connection\n  }\n\n  /**\n   * @abstract\n   * @param {function(import(\"../drivers/base.js\").default) : void} _callback\n   * @returns {Promise<void>}\n   */\n  withConnection(_callback) { // eslint-disable-line no-unused-vars\n    throw new Error(\"'withConnection' not implemented\")\n  }\n\n  /**\n   * Ensures a reusable connection exists for contexts where AsyncLocalStorage isn't set.\n   * Default implementation just checks out a connection.\n   * @returns {Promise<import(\"../drivers/base.js\").default>}\n   */\n  async ensureGlobalConnection() {\n    return await this.checkout()\n  }\n}\n\nbaseMethodsForward(VelociousDatabasePoolBase)\n\nexport default VelociousDatabasePoolBase\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"single-multi-use.d.ts","sourceRoot":"","sources":["../../../../src/database/pool/single-multi-use.js"],"names":[],"mappings":"AAIA;IAaM,iDAA8C;CAyBnD;qBAxCoB,WAAW"}
1
+ {"version":3,"file":"single-multi-use.d.ts","sourceRoot":"","sources":["../../../../src/database/pool/single-multi-use.js"],"names":[],"mappings":"AAIA;IAaM,iDAA8C;CA4BnD;qBA3CoB,WAAW"}
@@ -23,14 +23,16 @@ export default class VelociousDatabasePoolSingleMultiUser extends BasePool {
23
23
  const connection = await this.checkout();
24
24
  await callback(connection);
25
25
  }
26
- /**
27
- * @returns {import("../drivers/base.js").default}
28
- */
26
+ /** @returns {import("../drivers/base.js").default} */
29
27
  getCurrentConnection() {
30
28
  if (!this.connection) {
31
29
  throw new Error("A connection hasn't been made yet");
32
30
  }
33
31
  return this.connection;
34
32
  }
33
+ /** @returns {import("../drivers/base.js").default | undefined} */
34
+ getCurrentContextConnection() {
35
+ return this.connection;
36
+ }
35
37
  }
36
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2luZ2xlLW11bHRpLXVzZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9kYXRhYmFzZS9wb29sL3NpbmdsZS1tdWx0aS11c2UuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsWUFBWTtBQUVaLE9BQU8sUUFBUSxNQUFNLFdBQVcsQ0FBQTtBQUVoQyxNQUFNLENBQUMsT0FBTyxPQUFPLG9DQUFxQyxTQUFRLFFBQVE7SUFDeEU7O09BRUc7SUFDSCxPQUFPLENBQUMsV0FBVztRQUNqQixhQUFhO0lBQ2YsQ0FBQztJQUVEOztPQUVHO0lBQ0gsS0FBSyxDQUFDLFFBQVE7UUFDWixJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO1lBQ3JCLElBQUksQ0FBQyxVQUFVLEdBQUcsTUFBTSxJQUFJLENBQUMsZUFBZSxFQUFFLENBQUE7UUFDaEQsQ0FBQztRQUVELE9BQU8sSUFBSSxDQUFDLFVBQVUsQ0FBQTtJQUN4QixDQUFDO0lBRUQ7O09BRUc7SUFDSCxLQUFLLENBQUMsY0FBYyxDQUFDLFFBQVE7UUFDM0IsTUFBTSxVQUFVLEdBQUcsTUFBTSxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUE7UUFFeEMsTUFBTSxRQUFRLENBQUMsVUFBVSxDQUFDLENBQUE7SUFDNUIsQ0FBQztJQUVEOztPQUVHO0lBQ0gsb0JBQW9CO1FBQ2xCLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUM7WUFDckIsTUFBTSxJQUFJLEtBQUssQ0FBQyxtQ0FBbUMsQ0FBQyxDQUFBO1FBQ3RELENBQUM7UUFFRCxPQUFPLElBQUksQ0FBQyxVQUFVLENBQUE7SUFDeEIsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQHRzLWNoZWNrXG5cbmltcG9ydCBCYXNlUG9vbCBmcm9tIFwiLi9iYXNlLmpzXCJcblxuZXhwb3J0IGRlZmF1bHQgY2xhc3MgVmVsb2Npb3VzRGF0YWJhc2VQb29sU2luZ2xlTXVsdGlVc2VyIGV4dGVuZHMgQmFzZVBvb2wge1xuICAvKipcbiAgICogQHBhcmFtIHtpbXBvcnQoXCIuLi9kcml2ZXJzL2Jhc2UuanNcIikuZGVmYXVsdH0gX2Nvbm5lY3Rpb25cbiAgICovXG4gIGNoZWNraW4oX2Nvbm5lY3Rpb24pIHsgLy8gZXNsaW50LWRpc2FibGUtbGluZSBuby11bnVzZWQtdmFyc1xuICAgIC8vIERvIG5vdGhpbmdcbiAgfVxuXG4gIC8qKlxuICAgKiBAcmV0dXJucyB7UHJvbWlzZTxpbXBvcnQoXCIuLi9kcml2ZXJzL2Jhc2UuanNcIikuZGVmYXVsdD59XG4gICAqL1xuICBhc3luYyBjaGVja291dCgpIHtcbiAgICBpZiAoIXRoaXMuY29ubmVjdGlvbikge1xuICAgICAgdGhpcy5jb25uZWN0aW9uID0gYXdhaXQgdGhpcy5zcGF3bkNvbm5lY3Rpb24oKVxuICAgIH1cblxuICAgIHJldHVybiB0aGlzLmNvbm5lY3Rpb25cbiAgfVxuXG4gIC8qKlxuICAgKiBAcGFyYW0ge2Z1bmN0aW9uKGltcG9ydChcIi4uL2RyaXZlcnMvYmFzZS5qc1wiKS5kZWZhdWx0KSA6IHZvaWR9IGNhbGxiYWNrXG4gICAqL1xuICBhc3luYyB3aXRoQ29ubmVjdGlvbihjYWxsYmFjaykge1xuICAgIGNvbnN0IGNvbm5lY3Rpb24gPSBhd2FpdCB0aGlzLmNoZWNrb3V0KClcblxuICAgIGF3YWl0IGNhbGxiYWNrKGNvbm5lY3Rpb24pXG4gIH1cblxuICAvKipcbiAgICogQHJldHVybnMge2ltcG9ydChcIi4uL2RyaXZlcnMvYmFzZS5qc1wiKS5kZWZhdWx0fVxuICAgKi9cbiAgZ2V0Q3VycmVudENvbm5lY3Rpb24oKSB7XG4gICAgaWYgKCF0aGlzLmNvbm5lY3Rpb24pIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihcIkEgY29ubmVjdGlvbiBoYXNuJ3QgYmVlbiBtYWRlIHlldFwiKVxuICAgIH1cblxuICAgIHJldHVybiB0aGlzLmNvbm5lY3Rpb25cbiAgfVxufVxuIl19
38
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2luZ2xlLW11bHRpLXVzZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9kYXRhYmFzZS9wb29sL3NpbmdsZS1tdWx0aS11c2UuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsWUFBWTtBQUVaLE9BQU8sUUFBUSxNQUFNLFdBQVcsQ0FBQTtBQUVoQyxNQUFNLENBQUMsT0FBTyxPQUFPLG9DQUFxQyxTQUFRLFFBQVE7SUFDeEU7O09BRUc7SUFDSCxPQUFPLENBQUMsV0FBVztRQUNqQixhQUFhO0lBQ2YsQ0FBQztJQUVEOztPQUVHO0lBQ0gsS0FBSyxDQUFDLFFBQVE7UUFDWixJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO1lBQ3JCLElBQUksQ0FBQyxVQUFVLEdBQUcsTUFBTSxJQUFJLENBQUMsZUFBZSxFQUFFLENBQUE7UUFDaEQsQ0FBQztRQUVELE9BQU8sSUFBSSxDQUFDLFVBQVUsQ0FBQTtJQUN4QixDQUFDO0lBRUQ7O09BRUc7SUFDSCxLQUFLLENBQUMsY0FBYyxDQUFDLFFBQVE7UUFDM0IsTUFBTSxVQUFVLEdBQUcsTUFBTSxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUE7UUFFeEMsTUFBTSxRQUFRLENBQUMsVUFBVSxDQUFDLENBQUE7SUFDNUIsQ0FBQztJQUVELHNEQUFzRDtJQUN0RCxvQkFBb0I7UUFDbEIsSUFBSSxDQUFDLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztZQUNyQixNQUFNLElBQUksS0FBSyxDQUFDLG1DQUFtQyxDQUFDLENBQUE7UUFDdEQsQ0FBQztRQUVELE9BQU8sSUFBSSxDQUFDLFVBQVUsQ0FBQTtJQUN4QixDQUFDO0lBRUQsa0VBQWtFO0lBQ2xFLDJCQUEyQjtRQUN6QixPQUFPLElBQUksQ0FBQyxVQUFVLENBQUE7SUFDeEIsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQHRzLWNoZWNrXG5cbmltcG9ydCBCYXNlUG9vbCBmcm9tIFwiLi9iYXNlLmpzXCJcblxuZXhwb3J0IGRlZmF1bHQgY2xhc3MgVmVsb2Npb3VzRGF0YWJhc2VQb29sU2luZ2xlTXVsdGlVc2VyIGV4dGVuZHMgQmFzZVBvb2wge1xuICAvKipcbiAgICogQHBhcmFtIHtpbXBvcnQoXCIuLi9kcml2ZXJzL2Jhc2UuanNcIikuZGVmYXVsdH0gX2Nvbm5lY3Rpb25cbiAgICovXG4gIGNoZWNraW4oX2Nvbm5lY3Rpb24pIHsgLy8gZXNsaW50LWRpc2FibGUtbGluZSBuby11bnVzZWQtdmFyc1xuICAgIC8vIERvIG5vdGhpbmdcbiAgfVxuXG4gIC8qKlxuICAgKiBAcmV0dXJucyB7UHJvbWlzZTxpbXBvcnQoXCIuLi9kcml2ZXJzL2Jhc2UuanNcIikuZGVmYXVsdD59XG4gICAqL1xuICBhc3luYyBjaGVja291dCgpIHtcbiAgICBpZiAoIXRoaXMuY29ubmVjdGlvbikge1xuICAgICAgdGhpcy5jb25uZWN0aW9uID0gYXdhaXQgdGhpcy5zcGF3bkNvbm5lY3Rpb24oKVxuICAgIH1cblxuICAgIHJldHVybiB0aGlzLmNvbm5lY3Rpb25cbiAgfVxuXG4gIC8qKlxuICAgKiBAcGFyYW0ge2Z1bmN0aW9uKGltcG9ydChcIi4uL2RyaXZlcnMvYmFzZS5qc1wiKS5kZWZhdWx0KSA6IHZvaWR9IGNhbGxiYWNrXG4gICAqL1xuICBhc3luYyB3aXRoQ29ubmVjdGlvbihjYWxsYmFjaykge1xuICAgIGNvbnN0IGNvbm5lY3Rpb24gPSBhd2FpdCB0aGlzLmNoZWNrb3V0KClcblxuICAgIGF3YWl0IGNhbGxiYWNrKGNvbm5lY3Rpb24pXG4gIH1cblxuICAvKiogQHJldHVybnMge2ltcG9ydChcIi4uL2RyaXZlcnMvYmFzZS5qc1wiKS5kZWZhdWx0fSAqL1xuICBnZXRDdXJyZW50Q29ubmVjdGlvbigpIHtcbiAgICBpZiAoIXRoaXMuY29ubmVjdGlvbikge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKFwiQSBjb25uZWN0aW9uIGhhc24ndCBiZWVuIG1hZGUgeWV0XCIpXG4gICAgfVxuXG4gICAgcmV0dXJuIHRoaXMuY29ubmVjdGlvblxuICB9XG5cbiAgLyoqIEByZXR1cm5zIHtpbXBvcnQoXCIuLi9kcml2ZXJzL2Jhc2UuanNcIikuZGVmYXVsdCB8IHVuZGVmaW5lZH0gKi9cbiAgZ2V0Q3VycmVudENvbnRleHRDb25uZWN0aW9uKCkge1xuICAgIHJldHVybiB0aGlzLmNvbm5lY3Rpb25cbiAgfVxufVxuIl19
@@ -69,6 +69,12 @@ export default class VelociousDatabaseQueryModelClassQuery<MC extends typeof imp
69
69
  * @returns {Promise<Array<InstanceType<MC>>>}
70
70
  */
71
71
  toArray(): Promise<Array<InstanceType<MC>>>;
72
+ /**
73
+ * Plucks one or more columns directly from the database without instantiating models.
74
+ * @param {...string|string[]} columns
75
+ * @returns {Promise<any[]>}
76
+ */
77
+ pluck(...columns: (string | string[])[]): Promise<any[]>;
72
78
  }
73
79
  export type ModelClassQueryArgsType<MC extends typeof import("../record/index.js").default> = import("./index.js").QueryArgsType & {
74
80
  modelClass: MC;
@@ -1 +1 @@
1
- {"version":3,"file":"model-class-query.d.ts","sourceRoot":"","sources":["../../../../src/database/query/model-class-query.js"],"names":[],"mappings":"AASA;;GAEG;AACH;;;GAGG;AAEH;;;GAGG;AACH,2DAX2D,EAAE,SAAhD,cAAe,oBAAoB,EAAE,OAAQ;IAYxD,gDAAgD;IAChD,kBADY,uBAAuB,CAAC,EAAE,CAAC,EAWtC;IAFC,iBAAiB;IACjB,YADW,EAAE,CACe;IAG9B,sBAAsB;IACtB,SADc,IAAI,CAqBjB;IAED,iCAAiC;IACjC,SADc,OAAO,CAAC,MAAM,CAAC,CAmC5B;IAED,oBAAoB;IACpB,iBADc,EAAE,CAKf;IAED,+BAA+B;IAC/B,cADc,OAAO,CAAC,IAAI,CAAC,CAO1B;IAED;;;OAGG;IACH,eAHW,MAAM,GAAC,MAAM,GACX,OAAO,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC,CAmBrC;IAED;;;OAGG;IACH,mBAHW;QAAC,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAA;KAAC,GAClB,OAAO,CAAC,YAAY,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAiB5C;IAED;;;;OAIG;IACH,2BAJW;QAAC,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAA;KAAC,aACpB,CAAS,IAAgB,EAAhB,YAAY,CAAC,EAAE,CAAC,KAAI,IAAI,GAC/B,OAAO,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC,CAUrC;IAED;;;OAGG;IACH,yBAHW;QAAC,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAA;KAAC,GAClB,OAAO,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC,CAuBrC;IAED;;;;OAIG;IACH,+BAJW,MAAM,aACN,CAAS,IAAgB,EAAhB,YAAY,CAAC,EAAE,CAAC,KAAI,IAAI,GAC/B,OAAO,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC,CAerC;IAED,uDAAuD;IACvD,SADc,OAAO,CAAC,YAAY,CAAC,EAAE,CAAC,GAAG,SAAS,CAAC,CAMlD;IAED,uDAAuD;IACvD,QADc,OAAO,CAAC,YAAY,CAAC,EAAE,CAAC,GAAG,SAAS,CAAC,CAOlD;IAED;;;OAGG;IACH,cAHW,OAAO,YAAY,EAAE,mBAAmB,GACtC,IAAI,CAKhB;IAED;;;OAGG;IACH,WAFa,OAAO,CAAC,KAAK,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC,CAAC,CAyB5C;CACF;oCAlQ0D,EAAE,SAAhD,cAAe,oBAAoB,EAAE,OAAQ,IAC7C,OAAO,YAAY,EAAE,aAAa,GAAG;IAAC,UAAU,EAAE,EAAE,CAAA;CAAC;0BARxC,YAAY"}
1
+ {"version":3,"file":"model-class-query.d.ts","sourceRoot":"","sources":["../../../../src/database/query/model-class-query.js"],"names":[],"mappings":"AASA;;GAEG;AACH;;;GAGG;AAEH;;;GAGG;AACH,2DAX2D,EAAE,SAAhD,cAAe,oBAAoB,EAAE,OAAQ;IAYxD,gDAAgD;IAChD,kBADY,uBAAuB,CAAC,EAAE,CAAC,EAWtC;IAFC,iBAAiB;IACjB,YADW,EAAE,CACe;IAG9B,sBAAsB;IACtB,SADc,IAAI,CAqBjB;IAED,iCAAiC;IACjC,SADc,OAAO,CAAC,MAAM,CAAC,CAmC5B;IAED,oBAAoB;IACpB,iBADc,EAAE,CAKf;IAED,+BAA+B;IAC/B,cADc,OAAO,CAAC,IAAI,CAAC,CAO1B;IAED;;;OAGG;IACH,eAHW,MAAM,GAAC,MAAM,GACX,OAAO,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC,CAmBrC;IAED;;;OAGG;IACH,mBAHW;QAAC,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAA;KAAC,GAClB,OAAO,CAAC,YAAY,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAiB5C;IAED;;;;OAIG;IACH,2BAJW;QAAC,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAA;KAAC,aACpB,CAAS,IAAgB,EAAhB,YAAY,CAAC,EAAE,CAAC,KAAI,IAAI,GAC/B,OAAO,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC,CAUrC;IAED;;;OAGG;IACH,yBAHW;QAAC,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAA;KAAC,GAClB,OAAO,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC,CAuBrC;IAED;;;;OAIG;IACH,+BAJW,MAAM,aACN,CAAS,IAAgB,EAAhB,YAAY,CAAC,EAAE,CAAC,KAAI,IAAI,GAC/B,OAAO,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC,CAerC;IAED,uDAAuD;IACvD,SADc,OAAO,CAAC,YAAY,CAAC,EAAE,CAAC,GAAG,SAAS,CAAC,CAMlD;IAED,uDAAuD;IACvD,QADc,OAAO,CAAC,YAAY,CAAC,EAAE,CAAC,GAAG,SAAS,CAAC,CAOlD;IAED;;;OAGG;IACH,cAHW,OAAO,YAAY,EAAE,mBAAmB,GACtC,IAAI,CAKhB;IAED;;;OAGG;IACH,WAFa,OAAO,CAAC,KAAK,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC,CAAC,CAyB5C;IAED;;;;OAIG;IACH,kBAHW,CAAG,MAAM,GAAC,MAAM,EAAE,GAAA,GAChB,OAAO,CAAC,GAAG,EAAE,CAAC,CA+B1B;CACF;oCAtS0D,EAAE,SAAhD,cAAe,oBAAoB,EAAE,OAAQ,IAC7C,OAAO,YAAY,EAAE,aAAa,GAAG;IAAC,UAAU,EAAE,EAAE,CAAA;CAAC;0BARxC,YAAY"}