velocious 1.0.156 → 1.0.157

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.
@@ -42,7 +42,10 @@ export default class VelociousDatabaseConnectionDriversSqliteSqlAlterTable exten
42
42
  tableData.setName(tempTableName);
43
43
  const newTableData = new TableData(tempTableName);
44
44
  for (const tableDataColumn of currentTableData.getColumns()) {
45
- const newTableDataColumn = tableData.getColumns().find((newTableDataColumn) => newTableDataColumn.getName() == tableDataColumn.getName());
45
+ let newTableDataColumn = tableData.getColumns().find((newTableDataColumn) => newTableDataColumn.getName() == tableDataColumn.getName());
46
+ if (newTableDataColumn && newTableDataColumn.isNewColumn()) {
47
+ newTableDataColumn = undefined;
48
+ }
46
49
  if (newTableDataColumn) {
47
50
  newTableDataColumn.setAutoIncrement(tableDataColumn.getAutoIncrement());
48
51
  newTableDataColumn.setDefault(tableDataColumn.getDefault());
@@ -54,9 +57,13 @@ export default class VelociousDatabaseConnectionDriversSqliteSqlAlterTable exten
54
57
  }
55
58
  newTableData.addColumn(newTableDataColumn || tableDataColumn);
56
59
  }
60
+ // SQLite rebuilds use existing columns plus new ones; avoid duplicating a column that already exists.
61
+ const existingColumnNames = new Set(currentTableData.getColumns().map((column) => column.getName()));
57
62
  for (const tableDataColumn of tableData.getColumns()) {
58
63
  if (!tableDataColumn.isNewColumn())
59
64
  continue;
65
+ if (existingColumnNames.has(tableDataColumn.getName()))
66
+ continue;
60
67
  newTableData.addColumn(tableDataColumn);
61
68
  }
62
69
  const foundForeignKeys = [];
@@ -120,4 +127,4 @@ export default class VelociousDatabaseConnectionDriversSqliteSqlAlterTable exten
120
127
  return sqls;
121
128
  }
122
129
  }
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 - Options object.\n   * @param {import(\"../../base.js\").default} args.driver - Database driver instance.\n   * @param {import(\"../../../table-data/index.js\").default} args.tableData - Table data.\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[]>} - Resolves with SQL statements.\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"]}
130
+ //# 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 - Options object.\n   * @param {import(\"../../base.js\").default} args.driver - Database driver instance.\n   * @param {import(\"../../../table-data/index.js\").default} args.tableData - Table data.\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[]>} - Resolves with SQL statements.\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      let newTableDataColumn = tableData.getColumns().find((newTableDataColumn) => newTableDataColumn.getName() == tableDataColumn.getName())\n\n      if (newTableDataColumn && newTableDataColumn.isNewColumn()) {\n        newTableDataColumn = undefined\n      }\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    // SQLite rebuilds use existing columns plus new ones; avoid duplicating a column that already exists.\n    const existingColumnNames = new Set(currentTableData.getColumns().map((column) => column.getName()))\n\n    for (const tableDataColumn of tableData.getColumns()) {\n      if (!tableDataColumn.isNewColumn()) continue\n      if (existingColumnNames.has(tableDataColumn.getName())) 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"]}
@@ -30,13 +30,13 @@ export default class VelociousDatabaseQueryAlterTableBase extends QueryBase {
30
30
  sql += ", ";
31
31
  if (column.isNewColumn()) {
32
32
  sql += "ADD ";
33
- sql += column.getSQL({ driver: this.getDriver(), forAlterTable: true });
33
+ sql += column.getSQL({ driver: this.getDriver(), forAlterTable: false });
34
34
  }
35
35
  else if (column.getNewName()) {
36
36
  sql += `RENAME COLUMN ${options.quoteColumnName(column.getName())} TO ${options.quoteColumnName(column.getNewName())}`;
37
37
  }
38
38
  else if (column.getDropColumn()) {
39
- sql += `DROP COLUMN ${options.quoteColumnName}`;
39
+ sql += `DROP COLUMN ${options.quoteColumnName(column.getName())}`;
40
40
  }
41
41
  else {
42
42
  if (databaseType == "mssql" || databaseType == "pgsql") {
@@ -53,4 +53,4 @@ export default class VelociousDatabaseQueryAlterTableBase extends QueryBase {
53
53
  return sqls;
54
54
  }
55
55
  }
56
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWx0ZXItdGFibGUtYmFzZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9kYXRhYmFzZS9xdWVyeS9hbHRlci10YWJsZS1iYXNlLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLFlBQVk7QUFFWixPQUFPLFNBQVMsTUFBTSxXQUFXLENBQUE7QUFDakMsT0FBTyxhQUFhLE1BQU0sZ0NBQWdDLENBQUE7QUFDMUQsT0FBTyxTQUFTLE1BQU0sd0JBQXdCLENBQUE7QUFFOUMsTUFBTSxDQUFDLE9BQU8sT0FBTyxvQ0FBcUMsU0FBUSxTQUFTO0lBQ3pFOzs7O09BSUc7SUFDSCxZQUFZLEVBQUMsTUFBTSxFQUFFLFNBQVMsRUFBRSxHQUFHLFFBQVEsRUFBQztRQUMxQyxhQUFhLENBQUMsUUFBUSxDQUFDLENBQUE7UUFFdkIsSUFBSSxDQUFDLENBQUMsU0FBUyxZQUFZLFNBQVMsQ0FBQztZQUFFLE1BQU0sSUFBSSxLQUFLLENBQUMsOEJBQThCLENBQUMsQ0FBQTtRQUV0RixLQUFLLENBQUMsRUFBQyxNQUFNLEVBQUMsQ0FBQyxDQUFBO1FBQ2YsSUFBSSxDQUFDLFNBQVMsR0FBRyxTQUFTLENBQUE7SUFDNUIsQ0FBQztJQUVEOztPQUVHO0lBQ0gsS0FBSyxDQUFDLE1BQU07UUFDVixNQUFNLFlBQVksR0FBRyxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUMsT0FBTyxFQUFFLENBQUE7UUFDL0MsTUFBTSxJQUFJLEdBQUcsRUFBRSxDQUFBO1FBQ2YsTUFBTSxFQUFDLFNBQVMsRUFBQyxHQUFHLElBQUksQ0FBQTtRQUN4QixNQUFNLE9BQU8sR0FBRyxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUE7UUFFakMsSUFBSSxHQUFHLEdBQUcsZUFBZSxPQUFPLENBQUMsY0FBYyxDQUFDLFNBQVMsQ0FBQyxPQUFPLEVBQUUsQ0FBQyxHQUFHLENBQUE7UUFDdkUsSUFBSSxZQUFZLEdBQUcsQ0FBQyxDQUFBO1FBRXBCLEtBQUssTUFBTSxNQUFNLElBQUksU0FBUyxDQUFDLFVBQVUsRUFBRSxFQUFFLENBQUM7WUFDNUMsSUFBSSxZQUFZLEdBQUcsQ0FBQztnQkFBRSxHQUFHLElBQUksSUFBSSxDQUFBO1lBRWpDLElBQUksTUFBTSxDQUFDLFdBQVcsRUFBRSxFQUFFLENBQUM7Z0JBQ3pCLEdBQUcsSUFBSSxNQUFNLENBQUE7Z0JBQ2IsR0FBRyxJQUFJLE1BQU0sQ0FBQyxNQUFNLENBQUMsRUFBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLFNBQVMsRUFBRSxFQUFFLGFBQWEsRUFBRSxJQUFJLEVBQUMsQ0FBQyxDQUFBO1lBQ3ZFLENBQUM7aUJBQU0sSUFBSSxNQUFNLENBQUMsVUFBVSxFQUFFLEVBQUUsQ0FBQztnQkFDL0IsR0FBRyxJQUFJLGlCQUFpQixPQUFPLENBQUMsZUFBZSxDQUFDLE1BQU0sQ0FBQyxPQUFPLEVBQUUsQ0FBQyxPQUFPLE9BQU8sQ0FBQyxlQUFlLENBQUMsTUFBTSxDQUFDLFVBQVUsRUFBRSxDQUFDLEVBQUUsQ0FBQTtZQUN4SCxDQUFDO2lCQUFNLElBQUksTUFBTSxDQUFDLGFBQWEsRUFBRSxFQUFFLENBQUM7Z0JBQ2xDLEdBQUcsSUFBSSxlQUFlLE9BQU8sQ0FBQyxlQUFlLEVBQUUsQ0FBQTtZQUNqRCxDQUFDO2lCQUFNLENBQUM7Z0JBQ04sSUFBSSxZQUFZLElBQUksT0FBTyxJQUFJLFlBQVksSUFBSSxPQUFPLEVBQUUsQ0FBQztvQkFDdkQsR0FBRyxJQUFJLGVBQWUsQ0FBQTtnQkFDeEIsQ0FBQztxQkFBTSxDQUFDO29CQUNOLEdBQUcsSUFBSSxTQUFTLENBQUE7Z0JBQ2xCLENBQUM7Z0JBRUQsR0FBRyxJQUFJLE1BQU0sQ0FBQyxNQUFNLENBQUMsRUFBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLFNBQVMsRUFBRSxFQUFFLGFBQWEsRUFBRSxJQUFJLEVBQUMsQ0FBQyxDQUFBO1lBQ3ZFLENBQUM7WUFHRCxZQUFZLEVBQUUsQ0FBQTtRQUNoQixDQUFDO1FBRUQsSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQTtRQUVkLE9BQU8sSUFBSSxDQUFBO0lBQ2IsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQHRzLWNoZWNrXG5cbmltcG9ydCBRdWVyeUJhc2UgZnJvbSBcIi4vYmFzZS5qc1wiXG5pbXBvcnQgcmVzdEFyZ3NFcnJvciBmcm9tIFwiLi4vLi4vdXRpbHMvcmVzdC1hcmdzLWVycm9yLmpzXCJcbmltcG9ydCBUYWJsZURhdGEgZnJvbSBcIi4uL3RhYmxlLWRhdGEvaW5kZXguanNcIlxuXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBWZWxvY2lvdXNEYXRhYmFzZVF1ZXJ5QWx0ZXJUYWJsZUJhc2UgZXh0ZW5kcyBRdWVyeUJhc2Uge1xuICAvKipcbiAgICogQHBhcmFtIHtvYmplY3R9IGFyZ3MgLSBPcHRpb25zIG9iamVjdC5cbiAgICogQHBhcmFtIHtpbXBvcnQoXCIuLi9kcml2ZXJzL2Jhc2UuanNcIikuZGVmYXVsdH0gYXJncy5kcml2ZXIgLSBEYXRhYmFzZSBkcml2ZXIgaW5zdGFuY2UuXG4gICAqIEBwYXJhbSB7VGFibGVEYXRhfSBhcmdzLnRhYmxlRGF0YSAtIFRhYmxlIGRhdGEuXG4gICAqL1xuICBjb25zdHJ1Y3Rvcih7ZHJpdmVyLCB0YWJsZURhdGEsIC4uLnJlc3RBcmdzfSkge1xuICAgIHJlc3RBcmdzRXJyb3IocmVzdEFyZ3MpXG5cbiAgICBpZiAoISh0YWJsZURhdGEgaW5zdGFuY2VvZiBUYWJsZURhdGEpKSB0aHJvdyBuZXcgRXJyb3IoXCJJbnZhbGlkIHRhYmxlIGRhdGEgd2FzIGdpdmVuXCIpXG5cbiAgICBzdXBlcih7ZHJpdmVyfSlcbiAgICB0aGlzLnRhYmxlRGF0YSA9IHRhYmxlRGF0YVxuICB9XG5cbiAgLyoqXG4gICAqIEByZXR1cm5zIHtQcm9taXNlPHN0cmluZ1tdPn0gLSBSZXNvbHZlcyB3aXRoIFNRTCBzdGF0ZW1lbnRzLlxuICAgKi9cbiAgYXN5bmMgdG9TUUxzKCkge1xuICAgIGNvbnN0IGRhdGFiYXNlVHlwZSA9IHRoaXMuZ2V0RHJpdmVyKCkuZ2V0VHlwZSgpXG4gICAgY29uc3Qgc3FscyA9IFtdXG4gICAgY29uc3Qge3RhYmxlRGF0YX0gPSB0aGlzXG4gICAgY29uc3Qgb3B0aW9ucyA9IHRoaXMuZ2V0T3B0aW9ucygpXG5cbiAgICBsZXQgc3FsID0gYEFMVEVSIFRBQkxFICR7b3B0aW9ucy5xdW90ZVRhYmxlTmFtZSh0YWJsZURhdGEuZ2V0TmFtZSgpKX0gYFxuICAgIGxldCBjb2x1bW5zQ291bnQgPSAwXG5cbiAgICBmb3IgKGNvbnN0IGNvbHVtbiBvZiB0YWJsZURhdGEuZ2V0Q29sdW1ucygpKSB7XG4gICAgICBpZiAoY29sdW1uc0NvdW50ID4gMCkgc3FsICs9IFwiLCBcIlxuXG4gICAgICBpZiAoY29sdW1uLmlzTmV3Q29sdW1uKCkpIHtcbiAgICAgICAgc3FsICs9IFwiQUREIFwiXG4gICAgICAgIHNxbCArPSBjb2x1bW4uZ2V0U1FMKHtkcml2ZXI6IHRoaXMuZ2V0RHJpdmVyKCksIGZvckFsdGVyVGFibGU6IHRydWV9KVxuICAgICAgfSBlbHNlIGlmIChjb2x1bW4uZ2V0TmV3TmFtZSgpKSB7XG4gICAgICAgIHNxbCArPSBgUkVOQU1FIENPTFVNTiAke29wdGlvbnMucXVvdGVDb2x1bW5OYW1lKGNvbHVtbi5nZXROYW1lKCkpfSBUTyAke29wdGlvbnMucXVvdGVDb2x1bW5OYW1lKGNvbHVtbi5nZXROZXdOYW1lKCkpfWBcbiAgICAgIH0gZWxzZSBpZiAoY29sdW1uLmdldERyb3BDb2x1bW4oKSkge1xuICAgICAgICBzcWwgKz0gYERST1AgQ09MVU1OICR7b3B0aW9ucy5xdW90ZUNvbHVtbk5hbWV9YFxuICAgICAgfSBlbHNlIHtcbiAgICAgICAgaWYgKGRhdGFiYXNlVHlwZSA9PSBcIm1zc3FsXCIgfHwgZGF0YWJhc2VUeXBlID09IFwicGdzcWxcIikge1xuICAgICAgICAgIHNxbCArPSBcIkFMVEVSIENPTFVNTiBcIlxuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIHNxbCArPSBcIk1PRElGWSBcIlxuICAgICAgICB9XG5cbiAgICAgICAgc3FsICs9IGNvbHVtbi5nZXRTUUwoe2RyaXZlcjogdGhpcy5nZXREcml2ZXIoKSwgZm9yQWx0ZXJUYWJsZTogdHJ1ZX0pXG4gICAgICB9XG5cblxuICAgICAgY29sdW1uc0NvdW50KytcbiAgICB9XG5cbiAgICBzcWxzLnB1c2goc3FsKVxuXG4gICAgcmV0dXJuIHNxbHNcbiAgfVxufVxuIl19
56
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWx0ZXItdGFibGUtYmFzZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9kYXRhYmFzZS9xdWVyeS9hbHRlci10YWJsZS1iYXNlLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLFlBQVk7QUFFWixPQUFPLFNBQVMsTUFBTSxXQUFXLENBQUE7QUFDakMsT0FBTyxhQUFhLE1BQU0sZ0NBQWdDLENBQUE7QUFDMUQsT0FBTyxTQUFTLE1BQU0sd0JBQXdCLENBQUE7QUFFOUMsTUFBTSxDQUFDLE9BQU8sT0FBTyxvQ0FBcUMsU0FBUSxTQUFTO0lBQ3pFOzs7O09BSUc7SUFDSCxZQUFZLEVBQUMsTUFBTSxFQUFFLFNBQVMsRUFBRSxHQUFHLFFBQVEsRUFBQztRQUMxQyxhQUFhLENBQUMsUUFBUSxDQUFDLENBQUE7UUFFdkIsSUFBSSxDQUFDLENBQUMsU0FBUyxZQUFZLFNBQVMsQ0FBQztZQUFFLE1BQU0sSUFBSSxLQUFLLENBQUMsOEJBQThCLENBQUMsQ0FBQTtRQUV0RixLQUFLLENBQUMsRUFBQyxNQUFNLEVBQUMsQ0FBQyxDQUFBO1FBQ2YsSUFBSSxDQUFDLFNBQVMsR0FBRyxTQUFTLENBQUE7SUFDNUIsQ0FBQztJQUVEOztPQUVHO0lBQ0gsS0FBSyxDQUFDLE1BQU07UUFDVixNQUFNLFlBQVksR0FBRyxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUMsT0FBTyxFQUFFLENBQUE7UUFDL0MsTUFBTSxJQUFJLEdBQUcsRUFBRSxDQUFBO1FBQ2YsTUFBTSxFQUFDLFNBQVMsRUFBQyxHQUFHLElBQUksQ0FBQTtRQUN4QixNQUFNLE9BQU8sR0FBRyxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUE7UUFFakMsSUFBSSxHQUFHLEdBQUcsZUFBZSxPQUFPLENBQUMsY0FBYyxDQUFDLFNBQVMsQ0FBQyxPQUFPLEVBQUUsQ0FBQyxHQUFHLENBQUE7UUFDdkUsSUFBSSxZQUFZLEdBQUcsQ0FBQyxDQUFBO1FBRXBCLEtBQUssTUFBTSxNQUFNLElBQUksU0FBUyxDQUFDLFVBQVUsRUFBRSxFQUFFLENBQUM7WUFDNUMsSUFBSSxZQUFZLEdBQUcsQ0FBQztnQkFBRSxHQUFHLElBQUksSUFBSSxDQUFBO1lBRWpDLElBQUksTUFBTSxDQUFDLFdBQVcsRUFBRSxFQUFFLENBQUM7Z0JBQ3pCLEdBQUcsSUFBSSxNQUFNLENBQUE7Z0JBQ2IsR0FBRyxJQUFJLE1BQU0sQ0FBQyxNQUFNLENBQUMsRUFBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLFNBQVMsRUFBRSxFQUFFLGFBQWEsRUFBRSxLQUFLLEVBQUMsQ0FBQyxDQUFBO1lBQ3hFLENBQUM7aUJBQU0sSUFBSSxNQUFNLENBQUMsVUFBVSxFQUFFLEVBQUUsQ0FBQztnQkFDL0IsR0FBRyxJQUFJLGlCQUFpQixPQUFPLENBQUMsZUFBZSxDQUFDLE1BQU0sQ0FBQyxPQUFPLEVBQUUsQ0FBQyxPQUFPLE9BQU8sQ0FBQyxlQUFlLENBQUMsTUFBTSxDQUFDLFVBQVUsRUFBRSxDQUFDLEVBQUUsQ0FBQTtZQUN4SCxDQUFDO2lCQUFNLElBQUksTUFBTSxDQUFDLGFBQWEsRUFBRSxFQUFFLENBQUM7Z0JBQ2xDLEdBQUcsSUFBSSxlQUFlLE9BQU8sQ0FBQyxlQUFlLENBQUMsTUFBTSxDQUFDLE9BQU8sRUFBRSxDQUFDLEVBQUUsQ0FBQTtZQUNuRSxDQUFDO2lCQUFNLENBQUM7Z0JBQ04sSUFBSSxZQUFZLElBQUksT0FBTyxJQUFJLFlBQVksSUFBSSxPQUFPLEVBQUUsQ0FBQztvQkFDdkQsR0FBRyxJQUFJLGVBQWUsQ0FBQTtnQkFDeEIsQ0FBQztxQkFBTSxDQUFDO29CQUNOLEdBQUcsSUFBSSxTQUFTLENBQUE7Z0JBQ2xCLENBQUM7Z0JBRUQsR0FBRyxJQUFJLE1BQU0sQ0FBQyxNQUFNLENBQUMsRUFBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLFNBQVMsRUFBRSxFQUFFLGFBQWEsRUFBRSxJQUFJLEVBQUMsQ0FBQyxDQUFBO1lBQ3ZFLENBQUM7WUFHRCxZQUFZLEVBQUUsQ0FBQTtRQUNoQixDQUFDO1FBRUQsSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQTtRQUVkLE9BQU8sSUFBSSxDQUFBO0lBQ2IsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQHRzLWNoZWNrXG5cbmltcG9ydCBRdWVyeUJhc2UgZnJvbSBcIi4vYmFzZS5qc1wiXG5pbXBvcnQgcmVzdEFyZ3NFcnJvciBmcm9tIFwiLi4vLi4vdXRpbHMvcmVzdC1hcmdzLWVycm9yLmpzXCJcbmltcG9ydCBUYWJsZURhdGEgZnJvbSBcIi4uL3RhYmxlLWRhdGEvaW5kZXguanNcIlxuXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBWZWxvY2lvdXNEYXRhYmFzZVF1ZXJ5QWx0ZXJUYWJsZUJhc2UgZXh0ZW5kcyBRdWVyeUJhc2Uge1xuICAvKipcbiAgICogQHBhcmFtIHtvYmplY3R9IGFyZ3MgLSBPcHRpb25zIG9iamVjdC5cbiAgICogQHBhcmFtIHtpbXBvcnQoXCIuLi9kcml2ZXJzL2Jhc2UuanNcIikuZGVmYXVsdH0gYXJncy5kcml2ZXIgLSBEYXRhYmFzZSBkcml2ZXIgaW5zdGFuY2UuXG4gICAqIEBwYXJhbSB7VGFibGVEYXRhfSBhcmdzLnRhYmxlRGF0YSAtIFRhYmxlIGRhdGEuXG4gICAqL1xuICBjb25zdHJ1Y3Rvcih7ZHJpdmVyLCB0YWJsZURhdGEsIC4uLnJlc3RBcmdzfSkge1xuICAgIHJlc3RBcmdzRXJyb3IocmVzdEFyZ3MpXG5cbiAgICBpZiAoISh0YWJsZURhdGEgaW5zdGFuY2VvZiBUYWJsZURhdGEpKSB0aHJvdyBuZXcgRXJyb3IoXCJJbnZhbGlkIHRhYmxlIGRhdGEgd2FzIGdpdmVuXCIpXG5cbiAgICBzdXBlcih7ZHJpdmVyfSlcbiAgICB0aGlzLnRhYmxlRGF0YSA9IHRhYmxlRGF0YVxuICB9XG5cbiAgLyoqXG4gICAqIEByZXR1cm5zIHtQcm9taXNlPHN0cmluZ1tdPn0gLSBSZXNvbHZlcyB3aXRoIFNRTCBzdGF0ZW1lbnRzLlxuICAgKi9cbiAgYXN5bmMgdG9TUUxzKCkge1xuICAgIGNvbnN0IGRhdGFiYXNlVHlwZSA9IHRoaXMuZ2V0RHJpdmVyKCkuZ2V0VHlwZSgpXG4gICAgY29uc3Qgc3FscyA9IFtdXG4gICAgY29uc3Qge3RhYmxlRGF0YX0gPSB0aGlzXG4gICAgY29uc3Qgb3B0aW9ucyA9IHRoaXMuZ2V0T3B0aW9ucygpXG5cbiAgICBsZXQgc3FsID0gYEFMVEVSIFRBQkxFICR7b3B0aW9ucy5xdW90ZVRhYmxlTmFtZSh0YWJsZURhdGEuZ2V0TmFtZSgpKX0gYFxuICAgIGxldCBjb2x1bW5zQ291bnQgPSAwXG5cbiAgICBmb3IgKGNvbnN0IGNvbHVtbiBvZiB0YWJsZURhdGEuZ2V0Q29sdW1ucygpKSB7XG4gICAgICBpZiAoY29sdW1uc0NvdW50ID4gMCkgc3FsICs9IFwiLCBcIlxuXG4gICAgICBpZiAoY29sdW1uLmlzTmV3Q29sdW1uKCkpIHtcbiAgICAgICAgc3FsICs9IFwiQUREIFwiXG4gICAgICAgIHNxbCArPSBjb2x1bW4uZ2V0U1FMKHtkcml2ZXI6IHRoaXMuZ2V0RHJpdmVyKCksIGZvckFsdGVyVGFibGU6IGZhbHNlfSlcbiAgICAgIH0gZWxzZSBpZiAoY29sdW1uLmdldE5ld05hbWUoKSkge1xuICAgICAgICBzcWwgKz0gYFJFTkFNRSBDT0xVTU4gJHtvcHRpb25zLnF1b3RlQ29sdW1uTmFtZShjb2x1bW4uZ2V0TmFtZSgpKX0gVE8gJHtvcHRpb25zLnF1b3RlQ29sdW1uTmFtZShjb2x1bW4uZ2V0TmV3TmFtZSgpKX1gXG4gICAgICB9IGVsc2UgaWYgKGNvbHVtbi5nZXREcm9wQ29sdW1uKCkpIHtcbiAgICAgICAgc3FsICs9IGBEUk9QIENPTFVNTiAke29wdGlvbnMucXVvdGVDb2x1bW5OYW1lKGNvbHVtbi5nZXROYW1lKCkpfWBcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIGlmIChkYXRhYmFzZVR5cGUgPT0gXCJtc3NxbFwiIHx8IGRhdGFiYXNlVHlwZSA9PSBcInBnc3FsXCIpIHtcbiAgICAgICAgICBzcWwgKz0gXCJBTFRFUiBDT0xVTU4gXCJcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICBzcWwgKz0gXCJNT0RJRlkgXCJcbiAgICAgICAgfVxuXG4gICAgICAgIHNxbCArPSBjb2x1bW4uZ2V0U1FMKHtkcml2ZXI6IHRoaXMuZ2V0RHJpdmVyKCksIGZvckFsdGVyVGFibGU6IHRydWV9KVxuICAgICAgfVxuXG5cbiAgICAgIGNvbHVtbnNDb3VudCsrXG4gICAgfVxuXG4gICAgc3Fscy5wdXNoKHNxbClcblxuICAgIHJldHVybiBzcWxzXG4gIH1cbn1cbiJdfQ==
@@ -75,6 +75,11 @@ export default class VelociousDatabaseQueryModelClassQuery<MC extends typeof imp
75
75
  * @returns {Promise<any[]>} - Resolves with the pluck.
76
76
  */
77
77
  pluck(...columns: (string | string[])[]): Promise<any[]>;
78
+ /**
79
+ * @param {import("./index.js").WhereArgumentType} where - Where.
80
+ * @returns {this} This query instance
81
+ */
82
+ where(where: import("./index.js").WhereArgumentType): this;
78
83
  }
79
84
  export type ModelClassQueryArgsType<MC extends typeof import("../record/index.js").default> = import("./index.js").QueryArgsType & {
80
85
  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,+EAA+E;IAC/E,kBADY,uBAAuB,CAAC,EAAE,CAAC,EAWtC;IAFC,iBAAiB;IACjB,YADW,EAAE,CACe;IAG9B,oCAAoC;IACpC,SADc,IAAI,CAsBjB;IAED,6DAA6D;IAC7D,SADc,OAAO,CAAC,MAAM,CAAC,CAsC5B;IAED,wCAAwC;IACxC,iBADc,EAAE,CAKf;IAED,0DAA0D;IAC1D,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,MAAM,GAAG,MAAM,CAAA;KAAC,GAC9B,OAAO,CAAC,YAAY,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAiB5C;IAED;;;;OAIG;IACH,2BAJW;QAAC,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,CAAA;KAAC,aAChC,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,MAAM,GAAG,MAAM,CAAA;KAAC,GAC9B,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,mFAAmF;IACnF,SADc,OAAO,CAAC,YAAY,CAAC,EAAE,CAAC,GAAG,SAAS,CAAC,CAMlD;IAED,kFAAkF;IAClF,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;oCA1S0D,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":"AAWA;;GAEG;AACH;;;GAGG;AAEH;;;GAGG;AACH,2DAX2D,EAAE,SAAhD,cAAe,oBAAoB,EAAE,OAAQ;IAYxD,+EAA+E;IAC/E,kBADY,uBAAuB,CAAC,EAAE,CAAC,EAWtC;IAFC,iBAAiB;IACjB,YADW,EAAE,CACe;IAG9B,oCAAoC;IACpC,SADc,IAAI,CAsBjB;IAED,6DAA6D;IAC7D,SADc,OAAO,CAAC,MAAM,CAAC,CAsC5B;IAED,wCAAwC;IACxC,iBADc,EAAE,CAKf;IAED,0DAA0D;IAC1D,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,MAAM,GAAG,MAAM,CAAA;KAAC,GAC9B,OAAO,CAAC,YAAY,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAiB5C;IAED;;;;OAIG;IACH,2BAJW;QAAC,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,CAAA;KAAC,aAChC,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,MAAM,GAAG,MAAM,CAAA;KAAC,GAC9B,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,mFAAmF;IACnF,SADc,OAAO,CAAC,YAAY,CAAC,EAAE,CAAC,GAAG,SAAS,CAAC,CAMlD;IAED,kFAAkF;IAClF,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;IAED;;;OAGG;IACH,aAHW,OAAO,YAAY,EAAE,iBAAiB,GACpC,IAAI,CAiChB;CACF;oCA/U0D,EAAE,SAAhD,cAAe,oBAAoB,EAAE,OAAQ,IAC7C,OAAO,YAAY,EAAE,aAAa,GAAG;IAAC,UAAU,EAAE,EAAE,CAAA;CAAC;0BATxC,YAAY"}
@@ -1,10 +1,12 @@
1
1
  // @ts-check
2
2
  import { incorporate } from "incorporator";
3
3
  import * as inflection from "inflection";
4
+ import { isPlainObject } from "is-plain-object";
4
5
  import { Logger } from "../../logger.js";
5
6
  import Preloader from "./preloader.js";
6
7
  import DatabaseQuery from "./index.js";
7
8
  import RecordNotFoundError from "../record/record-not-found-error.js";
9
+ import WhereModelClassHash from "./where-model-class-hash.js";
8
10
  /**
9
11
  * @template {typeof import("../record/index.js").default} MC
10
12
  */
@@ -240,5 +242,124 @@ export default class VelociousDatabaseQueryModelClassQuery extends DatabaseQuery
240
242
  }
241
243
  return rows.map((row) => columnNames.map((columnName) => row[columnName]));
242
244
  }
245
+ /**
246
+ * @param {import("./index.js").WhereArgumentType} where - Where.
247
+ * @returns {this} This query instance
248
+ */
249
+ where(where) {
250
+ if (typeof where == "string") {
251
+ return super.where(where);
252
+ }
253
+ if (isPlainObject(where)) {
254
+ const { resolvedHash, fallbackHash } = splitWhereHash({ hash: where, modelClass: this.getModelClass() });
255
+ const joinObject = buildJoinObjectFromWhereHash({ hash: where, modelClass: this.getModelClass() });
256
+ if (Object.keys(joinObject).length > 0) {
257
+ this.joins(joinObject);
258
+ }
259
+ if (Object.keys(resolvedHash).length > 0) {
260
+ const qualifyBaseTable = Object.keys(joinObject).length > 0;
261
+ this._wheres.push(new WhereModelClassHash({
262
+ hash: resolvedHash,
263
+ modelClass: this.getModelClass(),
264
+ qualifyBaseTable,
265
+ query: this
266
+ }));
267
+ }
268
+ if (Object.keys(fallbackHash).length > 0) {
269
+ super.where(fallbackHash);
270
+ }
271
+ return this;
272
+ }
273
+ throw new Error(`Invalid type of where: ${typeof where} (${where.constructor.name})`);
274
+ }
275
+ }
276
+ /**
277
+ * @param {typeof import("../record/index.js").default} modelClass - Model class.
278
+ * @param {string} relationshipName - Relationship name.
279
+ * @returns {import("../record/relationships/base.js").default | undefined} - The relationship.
280
+ */
281
+ function getRelationshipByName(modelClass, relationshipName) {
282
+ return modelClass.getRelationshipsMap()[relationshipName];
283
+ }
284
+ /**
285
+ * @param {typeof import("../record/index.js").default} modelClass - Model class.
286
+ * @param {string} key - Attribute or column name.
287
+ * @returns {string | undefined} - The resolved column name.
288
+ */
289
+ function resolveColumnName(modelClass, key) {
290
+ const attributeMap = modelClass.getAttributeNameToColumnNameMap();
291
+ const columnName = attributeMap[key];
292
+ if (columnName)
293
+ return columnName;
294
+ return undefined;
295
+ }
296
+ /**
297
+ * @param {object} args - Options.
298
+ * @param {Record<string, any>} args.hash - Where hash.
299
+ * @param {typeof import("../record/index.js").default} args.modelClass - Model class.
300
+ * @returns {{resolvedHash: Record<string, any>, fallbackHash: Record<string, any>}} - Split hashes.
301
+ */
302
+ function splitWhereHash({ hash, modelClass }) {
303
+ /** @type {Record<string, any>} */
304
+ const resolvedHash = {};
305
+ /** @type {Record<string, any>} */
306
+ const fallbackHash = {};
307
+ for (const key in hash) {
308
+ const value = hash[key];
309
+ const isNested = isPlainObject(value);
310
+ if (isNested) {
311
+ const relationship = getRelationshipByName(modelClass, key);
312
+ if (relationship) {
313
+ const targetModelClass = relationship.getTargetModelClass();
314
+ const nestedResult = splitWhereHash({ hash: value, modelClass: targetModelClass });
315
+ const nestedResolvedKeys = Object.keys(nestedResult.resolvedHash);
316
+ const nestedFallbackKeys = Object.keys(nestedResult.fallbackHash);
317
+ if (nestedResolvedKeys.length > 0) {
318
+ resolvedHash[key] = nestedResult.resolvedHash;
319
+ }
320
+ if (nestedFallbackKeys.length > 0) {
321
+ const tableName = targetModelClass.tableName();
322
+ if (!fallbackHash[tableName])
323
+ fallbackHash[tableName] = {};
324
+ Object.assign(fallbackHash[tableName], nestedResult.fallbackHash);
325
+ }
326
+ }
327
+ else {
328
+ fallbackHash[key] = value;
329
+ }
330
+ }
331
+ else {
332
+ const columnName = resolveColumnName(modelClass, key);
333
+ if (columnName) {
334
+ resolvedHash[key] = value;
335
+ }
336
+ else {
337
+ fallbackHash[key] = value;
338
+ }
339
+ }
340
+ }
341
+ return { resolvedHash, fallbackHash };
342
+ }
343
+ /**
344
+ * @param {object} args - Options.
345
+ * @param {Record<string, any>} args.hash - Where hash.
346
+ * @param {typeof import("../record/index.js").default} args.modelClass - Model class.
347
+ * @returns {Record<string, any>} - Join object.
348
+ */
349
+ function buildJoinObjectFromWhereHash({ hash, modelClass }) {
350
+ /** @type {Record<string, any>} */
351
+ const joinObject = {};
352
+ for (const key in hash) {
353
+ const value = hash[key];
354
+ if (!isPlainObject(value))
355
+ continue;
356
+ const relationship = getRelationshipByName(modelClass, key);
357
+ if (!relationship)
358
+ continue;
359
+ const targetModelClass = relationship.getTargetModelClass();
360
+ const nestedJoinObject = buildJoinObjectFromWhereHash({ hash: value, modelClass: targetModelClass });
361
+ joinObject[key] = Object.keys(nestedJoinObject).length > 0 ? nestedJoinObject : true;
362
+ }
363
+ return joinObject;
243
364
  }
244
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"model-class-query.js","sourceRoot":"","sources":["../../../../src/database/query/model-class-query.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport {incorporate} from \"incorporator\"\nimport * as inflection from \"inflection\"\nimport {Logger} from \"../../logger.js\"\nimport Preloader from \"./preloader.js\"\nimport DatabaseQuery from \"./index.js\"\nimport RecordNotFoundError from \"../record/record-not-found-error.js\"\n\n/**\n * @template {typeof import(\"../record/index.js\").default} MC\n */\n/**\n * @template {typeof import(\"../record/index.js\").default} MC\n * @typedef {import(\"./index.js\").QueryArgsType & {modelClass: MC}} ModelClassQueryArgsType\n */\n\n/**\n * A generic query over some model type.\n * @template {typeof import(\"../record/index.js\").default} MC\n */\nexport default class VelociousDatabaseQueryModelClassQuery extends DatabaseQuery {\n  /** @param {ModelClassQueryArgsType<MC>} args - Query constructor arguments. */\n  constructor(args) {\n    const {modelClass} = args\n\n    if (!modelClass) throw new Error(`No modelClass given in ${Object.keys(args).join(\", \")}`)\n\n    super(args)\n    this.logger = new Logger(this)\n\n    /** @type {MC} */\n    this.modelClass = modelClass\n  }\n\n  /** @returns {this} - The clone.  */\n  clone() {\n    const newQuery = /** @type {VelociousDatabaseQueryModelClassQuery<MC>} */ (new VelociousDatabaseQueryModelClassQuery({\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      modelClass: this.modelClass,\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    // @ts-expect-error\n    return newQuery\n  }\n\n  /** @returns {Promise<number>} - Resolves with the count.  */\n  async count() {\n    // Generate count SQL\n    const primaryKey = `${this.driver.quoteTable(this.getModelClass().tableName())}.${this.driver.quoteColumn(this.getModelClass().primaryKey())}`\n    const distinctPrefix = this._distinct ? \"DISTINCT \" : \"\"\n    let sql = `COUNT(${distinctPrefix}${primaryKey})`\n\n    if (this.driver.getType() == \"pgsql\") sql += \"::int\"\n\n    sql += \" AS count\"\n\n\n    // Clone query and execute count\n    const countQuery = this.clone()\n\n    countQuery._distinct = false\n    countQuery._selects = []\n    countQuery.select(sql)\n\n    const results = /** @type {{count: number}[]} */ (await countQuery._executeQuery())\n\n    // The query isn't grouped and a single result has been given\n    if (results.length == 1) {\n      return results[0].count\n    }\n\n    // The query may be grouped and a lot of different counts a given\n    let countResult = 0\n\n    for (const result of results) {\n      if (!(\"count\" in result)) {\n        throw new Error(\"Invalid count result\")\n      }\n\n      countResult += result.count\n    }\n\n    return countResult\n  }\n\n  /** @returns {MC} - The model class.  */\n  getModelClass() {\n    if (!this.modelClass) throw new Error(\"modelClass not set\")\n\n    return this.modelClass\n  }\n\n  /** @returns {Promise<void>} - Resolves when complete.  */\n  async destroyAll() {\n    const records = await this.toArray()\n\n    for (const record of records) {\n      await record.destroy()\n    }\n  }\n\n  /**\n   * @param {number|string} recordId - Record id.\n   * @returns {Promise<InstanceType<MC>>} - Resolves with the find.\n   */\n  async find(recordId) {\n    /** @type {{[key: string]: number | string}} */\n    const conditions = {}\n\n    conditions[this.getModelClass().primaryKey()] = recordId\n\n    const newQuery = /** @type {VelociousDatabaseQueryModelClassQuery<MC>} */ (this.clone())\n\n    newQuery.where(conditions)\n\n    const record = (await newQuery.first())\n\n    if (!record) {\n      throw new RecordNotFoundError(`Couldn't find ${this.getModelClass().name} with '${this.getModelClass().primaryKey()}'=${recordId}`)\n    }\n\n    return record\n  }\n\n  /**\n   * @param {{[key: string]: string | number}} conditions - Conditions hash keyed by attribute name.\n   * @returns {Promise<InstanceType<MC> | null>} - Resolves with the by.\n   */\n  async findBy(conditions) {\n    /** @type {{[key: string]: number | string}} */\n    const newConditions = {}\n\n    for (const key in conditions) {\n      const keyUnderscore = inflection.underscore(key)\n\n      newConditions[keyUnderscore] = conditions[key]\n    }\n\n    const newQuery = /** @type {VelociousDatabaseQueryModelClassQuery<MC>} */ (this.clone())\n\n    newQuery.where(newConditions)\n\n    return await newQuery.first()\n  }\n\n  /**\n   * @param {{[key: string]: string | number}} conditions - Conditions hash keyed by attribute name.\n   * @param {function(InstanceType<MC>) : void} [callback] - Callback function.\n   * @returns {Promise<InstanceType<MC>>} - Resolves with the or create by.\n   */\n  async findOrCreateBy(conditions, callback) {\n    const record = await this.findOrInitializeBy(conditions, callback)\n\n    if (record.isNewRecord()) {\n      await record.save()\n    }\n\n    return record\n  }\n\n  /**\n   * @param {{[key: string]: string | number}} conditions - Conditions hash keyed by attribute name.\n   * @returns {Promise<InstanceType<MC>>} - Resolves with the by or fail.\n   */\n  async findByOrFail(conditions) {\n    /** @type {{[key: string]: number | string}} */\n    const newConditions = {}\n\n    for (const key in conditions) {\n      const keyUnderscore = inflection.underscore(key)\n\n      newConditions[keyUnderscore] = conditions[key]\n    }\n\n    const newQuery = /** @type {VelociousDatabaseQueryModelClassQuery<MC>} */ (this.clone())\n\n    newQuery.where(newConditions)\n\n    const model = await newQuery.first()\n\n    if (!model) {\n      throw new Error(\"Record not found\")\n    }\n\n    return model\n  }\n\n  /**\n   * @param {object} conditions - Conditions.\n   * @param {function(InstanceType<MC>) : void} [callback] - Callback function.\n   * @returns {Promise<InstanceType<MC>>} - Resolves with the or initialize by.\n   */\n  async findOrInitializeBy(conditions, callback) {\n    const record = await this.findBy(conditions)\n\n    if (record) return record\n\n    const ModelClass = this.getModelClass()\n    const newRecord = /** @type {InstanceType<MC>} */ (new ModelClass(conditions))\n\n    if (callback) {\n      callback(newRecord)\n    }\n\n    return newRecord\n  }\n\n  /** @returns {Promise<InstanceType<MC> | undefined>} - Resolves with the first.  */\n  async first() {\n    const newQuery = this.clone().limit(1).reorder(`${this.driver.quoteTable(this.getModelClass().tableName())}.${this.driver.quoteColumn(this.getModelClass().orderableColumn())}`)\n    const results = await newQuery.toArray()\n\n    return results[0]\n  }\n\n  /** @returns {Promise<InstanceType<MC> | undefined>} - Resolves with the last.  */\n  async last() {\n    const primaryKey = this.getModelClass().primaryKey()\n    const tableName = this.getModelClass().tableName()\n    const results = await this.clone().reorder(`${this.driver.quoteTable(tableName)}.${this.driver.quoteColumn(primaryKey)} DESC`).limit(1).toArray()\n\n    return results[0]\n  }\n\n  /**\n   * @param {import(\"./index.js\").NestedPreloadRecord} data - Data payload.\n   * @returns {this} - The preload.\n   */\n  preload(data) {\n    incorporate(this._preload, data)\n    return this\n  }\n\n  /**\n   * Converts query results to array of model instances\n   * @returns {Promise<Array<InstanceType<MC>>>} - Resolves with the array.\n   */\n  async toArray() {\n    const models = []\n    const results = await this.results()\n\n    for (const result of results) {\n      const ModelClass = this.getModelClass()\n      const model = /** @type {InstanceType<MC>} */ (new ModelClass())\n\n      model.loadExistingRecord(result)\n      models.push(model)\n    }\n\n    if (Object.keys(this._preload).length > 0 && models.length > 0) {\n      const preloader = new Preloader({\n        modelClass: this.modelClass,\n        models,\n        preload: this._preload\n      })\n\n      await preloader.run()\n    }\n\n    return models\n  }\n\n  /**\n   * Plucks one or more columns directly from the database without instantiating models.\n   * @param {...string|string[]} columns - Column names.\n   * @returns {Promise<any[]>} - Resolves with the pluck.\n   */\n  async pluck(...columns) {\n    const flatColumns = columns.flat()\n\n    if (flatColumns.length === 0) throw new Error(\"No columns given to pluck\")\n\n    const modelClass = this.getModelClass()\n    const tableName = modelClass.tableName()\n    const attributeMap = modelClass.getAttributeNameToColumnNameMap()\n    const columnNames = flatColumns.map((column) => attributeMap[column] || column)\n\n    const query = /** @type {VelociousDatabaseQueryModelClassQuery<MC>} */ (this.clone())\n\n    query._preload = {}\n    query._selects = []\n\n    columnNames.forEach((columnName) => {\n      const selectSql = `${this.driver.quoteTable(tableName)}.${this.driver.quoteColumn(columnName)}`\n\n      query.select(selectSql)\n    })\n\n    const rows = await query._executeQuery()\n\n    if (columnNames.length === 1) {\n      const [columnName] = columnNames\n      return rows.map((row) => row[columnName])\n    }\n\n    return rows.map((row) => columnNames.map((columnName) => row[columnName]))\n  }\n}\n\n"]}
365
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"model-class-query.js","sourceRoot":"","sources":["../../../../src/database/query/model-class-query.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport {incorporate} from \"incorporator\"\nimport * as inflection from \"inflection\"\nimport {isPlainObject} from \"is-plain-object\"\nimport {Logger} from \"../../logger.js\"\nimport Preloader from \"./preloader.js\"\nimport DatabaseQuery from \"./index.js\"\nimport RecordNotFoundError from \"../record/record-not-found-error.js\"\nimport WhereModelClassHash from \"./where-model-class-hash.js\"\n\n/**\n * @template {typeof import(\"../record/index.js\").default} MC\n */\n/**\n * @template {typeof import(\"../record/index.js\").default} MC\n * @typedef {import(\"./index.js\").QueryArgsType & {modelClass: MC}} ModelClassQueryArgsType\n */\n\n/**\n * A generic query over some model type.\n * @template {typeof import(\"../record/index.js\").default} MC\n */\nexport default class VelociousDatabaseQueryModelClassQuery extends DatabaseQuery {\n  /** @param {ModelClassQueryArgsType<MC>} args - Query constructor arguments. */\n  constructor(args) {\n    const {modelClass} = args\n\n    if (!modelClass) throw new Error(`No modelClass given in ${Object.keys(args).join(\", \")}`)\n\n    super(args)\n    this.logger = new Logger(this)\n\n    /** @type {MC} */\n    this.modelClass = modelClass\n  }\n\n  /** @returns {this} - The clone.  */\n  clone() {\n    const newQuery = /** @type {VelociousDatabaseQueryModelClassQuery<MC>} */ (new VelociousDatabaseQueryModelClassQuery({\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      modelClass: this.modelClass,\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    // @ts-expect-error\n    return newQuery\n  }\n\n  /** @returns {Promise<number>} - Resolves with the count.  */\n  async count() {\n    // Generate count SQL\n    const primaryKey = `${this.driver.quoteTable(this.getModelClass().tableName())}.${this.driver.quoteColumn(this.getModelClass().primaryKey())}`\n    const distinctPrefix = this._distinct ? \"DISTINCT \" : \"\"\n    let sql = `COUNT(${distinctPrefix}${primaryKey})`\n\n    if (this.driver.getType() == \"pgsql\") sql += \"::int\"\n\n    sql += \" AS count\"\n\n\n    // Clone query and execute count\n    const countQuery = this.clone()\n\n    countQuery._distinct = false\n    countQuery._selects = []\n    countQuery.select(sql)\n\n    const results = /** @type {{count: number}[]} */ (await countQuery._executeQuery())\n\n    // The query isn't grouped and a single result has been given\n    if (results.length == 1) {\n      return results[0].count\n    }\n\n    // The query may be grouped and a lot of different counts a given\n    let countResult = 0\n\n    for (const result of results) {\n      if (!(\"count\" in result)) {\n        throw new Error(\"Invalid count result\")\n      }\n\n      countResult += result.count\n    }\n\n    return countResult\n  }\n\n  /** @returns {MC} - The model class.  */\n  getModelClass() {\n    if (!this.modelClass) throw new Error(\"modelClass not set\")\n\n    return this.modelClass\n  }\n\n  /** @returns {Promise<void>} - Resolves when complete.  */\n  async destroyAll() {\n    const records = await this.toArray()\n\n    for (const record of records) {\n      await record.destroy()\n    }\n  }\n\n  /**\n   * @param {number|string} recordId - Record id.\n   * @returns {Promise<InstanceType<MC>>} - Resolves with the find.\n   */\n  async find(recordId) {\n    /** @type {{[key: string]: number | string}} */\n    const conditions = {}\n\n    conditions[this.getModelClass().primaryKey()] = recordId\n\n    const newQuery = /** @type {VelociousDatabaseQueryModelClassQuery<MC>} */ (this.clone())\n\n    newQuery.where(conditions)\n\n    const record = (await newQuery.first())\n\n    if (!record) {\n      throw new RecordNotFoundError(`Couldn't find ${this.getModelClass().name} with '${this.getModelClass().primaryKey()}'=${recordId}`)\n    }\n\n    return record\n  }\n\n  /**\n   * @param {{[key: string]: string | number}} conditions - Conditions hash keyed by attribute name.\n   * @returns {Promise<InstanceType<MC> | null>} - Resolves with the by.\n   */\n  async findBy(conditions) {\n    /** @type {{[key: string]: number | string}} */\n    const newConditions = {}\n\n    for (const key in conditions) {\n      const keyUnderscore = inflection.underscore(key)\n\n      newConditions[keyUnderscore] = conditions[key]\n    }\n\n    const newQuery = /** @type {VelociousDatabaseQueryModelClassQuery<MC>} */ (this.clone())\n\n    newQuery.where(newConditions)\n\n    return await newQuery.first()\n  }\n\n  /**\n   * @param {{[key: string]: string | number}} conditions - Conditions hash keyed by attribute name.\n   * @param {function(InstanceType<MC>) : void} [callback] - Callback function.\n   * @returns {Promise<InstanceType<MC>>} - Resolves with the or create by.\n   */\n  async findOrCreateBy(conditions, callback) {\n    const record = await this.findOrInitializeBy(conditions, callback)\n\n    if (record.isNewRecord()) {\n      await record.save()\n    }\n\n    return record\n  }\n\n  /**\n   * @param {{[key: string]: string | number}} conditions - Conditions hash keyed by attribute name.\n   * @returns {Promise<InstanceType<MC>>} - Resolves with the by or fail.\n   */\n  async findByOrFail(conditions) {\n    /** @type {{[key: string]: number | string}} */\n    const newConditions = {}\n\n    for (const key in conditions) {\n      const keyUnderscore = inflection.underscore(key)\n\n      newConditions[keyUnderscore] = conditions[key]\n    }\n\n    const newQuery = /** @type {VelociousDatabaseQueryModelClassQuery<MC>} */ (this.clone())\n\n    newQuery.where(newConditions)\n\n    const model = await newQuery.first()\n\n    if (!model) {\n      throw new Error(\"Record not found\")\n    }\n\n    return model\n  }\n\n  /**\n   * @param {object} conditions - Conditions.\n   * @param {function(InstanceType<MC>) : void} [callback] - Callback function.\n   * @returns {Promise<InstanceType<MC>>} - Resolves with the or initialize by.\n   */\n  async findOrInitializeBy(conditions, callback) {\n    const record = await this.findBy(conditions)\n\n    if (record) return record\n\n    const ModelClass = this.getModelClass()\n    const newRecord = /** @type {InstanceType<MC>} */ (new ModelClass(conditions))\n\n    if (callback) {\n      callback(newRecord)\n    }\n\n    return newRecord\n  }\n\n  /** @returns {Promise<InstanceType<MC> | undefined>} - Resolves with the first.  */\n  async first() {\n    const newQuery = this.clone().limit(1).reorder(`${this.driver.quoteTable(this.getModelClass().tableName())}.${this.driver.quoteColumn(this.getModelClass().orderableColumn())}`)\n    const results = await newQuery.toArray()\n\n    return results[0]\n  }\n\n  /** @returns {Promise<InstanceType<MC> | undefined>} - Resolves with the last.  */\n  async last() {\n    const primaryKey = this.getModelClass().primaryKey()\n    const tableName = this.getModelClass().tableName()\n    const results = await this.clone().reorder(`${this.driver.quoteTable(tableName)}.${this.driver.quoteColumn(primaryKey)} DESC`).limit(1).toArray()\n\n    return results[0]\n  }\n\n  /**\n   * @param {import(\"./index.js\").NestedPreloadRecord} data - Data payload.\n   * @returns {this} - The preload.\n   */\n  preload(data) {\n    incorporate(this._preload, data)\n    return this\n  }\n\n  /**\n   * Converts query results to array of model instances\n   * @returns {Promise<Array<InstanceType<MC>>>} - Resolves with the array.\n   */\n  async toArray() {\n    const models = []\n    const results = await this.results()\n\n    for (const result of results) {\n      const ModelClass = this.getModelClass()\n      const model = /** @type {InstanceType<MC>} */ (new ModelClass())\n\n      model.loadExistingRecord(result)\n      models.push(model)\n    }\n\n    if (Object.keys(this._preload).length > 0 && models.length > 0) {\n      const preloader = new Preloader({\n        modelClass: this.modelClass,\n        models,\n        preload: this._preload\n      })\n\n      await preloader.run()\n    }\n\n    return models\n  }\n\n  /**\n   * Plucks one or more columns directly from the database without instantiating models.\n   * @param {...string|string[]} columns - Column names.\n   * @returns {Promise<any[]>} - Resolves with the pluck.\n   */\n  async pluck(...columns) {\n    const flatColumns = columns.flat()\n\n    if (flatColumns.length === 0) throw new Error(\"No columns given to pluck\")\n\n    const modelClass = this.getModelClass()\n    const tableName = modelClass.tableName()\n    const attributeMap = modelClass.getAttributeNameToColumnNameMap()\n    const columnNames = flatColumns.map((column) => attributeMap[column] || column)\n\n    const query = /** @type {VelociousDatabaseQueryModelClassQuery<MC>} */ (this.clone())\n\n    query._preload = {}\n    query._selects = []\n\n    columnNames.forEach((columnName) => {\n      const selectSql = `${this.driver.quoteTable(tableName)}.${this.driver.quoteColumn(columnName)}`\n\n      query.select(selectSql)\n    })\n\n    const rows = await query._executeQuery()\n\n    if (columnNames.length === 1) {\n      const [columnName] = columnNames\n      return rows.map((row) => row[columnName])\n    }\n\n    return rows.map((row) => columnNames.map((columnName) => row[columnName]))\n  }\n\n  /**\n   * @param {import(\"./index.js\").WhereArgumentType} where - Where.\n   * @returns {this} This query instance\n   */\n  where(where) {\n    if (typeof where == \"string\") {\n      return super.where(where)\n    }\n\n    if (isPlainObject(where)) {\n      const {resolvedHash, fallbackHash} = splitWhereHash({hash: where, modelClass: this.getModelClass()})\n      const joinObject = buildJoinObjectFromWhereHash({hash: where, modelClass: this.getModelClass()})\n\n      if (Object.keys(joinObject).length > 0) {\n        this.joins(joinObject)\n      }\n\n      if (Object.keys(resolvedHash).length > 0) {\n        const qualifyBaseTable = Object.keys(joinObject).length > 0\n        this._wheres.push(new WhereModelClassHash({\n          hash: resolvedHash,\n          modelClass: this.getModelClass(),\n          qualifyBaseTable,\n          query: this\n        }))\n      }\n\n      if (Object.keys(fallbackHash).length > 0) {\n        super.where(fallbackHash)\n      }\n\n      return this\n    }\n\n    throw new Error(`Invalid type of where: ${typeof where} (${where.constructor.name})`)\n  }\n}\n\n/**\n * @param {typeof import(\"../record/index.js\").default} modelClass - Model class.\n * @param {string} relationshipName - Relationship name.\n * @returns {import(\"../record/relationships/base.js\").default | undefined} - The relationship.\n */\nfunction getRelationshipByName(modelClass, relationshipName) {\n  return modelClass.getRelationshipsMap()[relationshipName]\n}\n\n/**\n * @param {typeof import(\"../record/index.js\").default} modelClass - Model class.\n * @param {string} key - Attribute or column name.\n * @returns {string | undefined} - The resolved column name.\n */\nfunction resolveColumnName(modelClass, key) {\n  const attributeMap = modelClass.getAttributeNameToColumnNameMap()\n  const columnName = attributeMap[key]\n\n  if (columnName) return columnName\n\n  return undefined\n}\n\n/**\n * @param {object} args - Options.\n * @param {Record<string, any>} args.hash - Where hash.\n * @param {typeof import(\"../record/index.js\").default} args.modelClass - Model class.\n * @returns {{resolvedHash: Record<string, any>, fallbackHash: Record<string, any>}} - Split hashes.\n */\nfunction splitWhereHash({hash, modelClass}) {\n  /** @type {Record<string, any>} */\n  const resolvedHash = {}\n  /** @type {Record<string, any>} */\n  const fallbackHash = {}\n\n  for (const key in hash) {\n    const value = hash[key]\n    const isNested = isPlainObject(value)\n\n    if (isNested) {\n      const relationship = getRelationshipByName(modelClass, key)\n\n      if (relationship) {\n        const targetModelClass = relationship.getTargetModelClass()\n        const nestedResult = splitWhereHash({hash: value, modelClass: targetModelClass})\n        const nestedResolvedKeys = Object.keys(nestedResult.resolvedHash)\n        const nestedFallbackKeys = Object.keys(nestedResult.fallbackHash)\n\n        if (nestedResolvedKeys.length > 0) {\n          resolvedHash[key] = nestedResult.resolvedHash\n        }\n\n        if (nestedFallbackKeys.length > 0) {\n          const tableName = targetModelClass.tableName()\n\n          if (!fallbackHash[tableName]) fallbackHash[tableName] = {}\n          Object.assign(fallbackHash[tableName], nestedResult.fallbackHash)\n        }\n      } else {\n        fallbackHash[key] = value\n      }\n    } else {\n      const columnName = resolveColumnName(modelClass, key)\n\n      if (columnName) {\n        resolvedHash[key] = value\n      } else {\n        fallbackHash[key] = value\n      }\n    }\n  }\n\n  return {resolvedHash, fallbackHash}\n}\n\n/**\n * @param {object} args - Options.\n * @param {Record<string, any>} args.hash - Where hash.\n * @param {typeof import(\"../record/index.js\").default} args.modelClass - Model class.\n * @returns {Record<string, any>} - Join object.\n */\nfunction buildJoinObjectFromWhereHash({hash, modelClass}) {\n  /** @type {Record<string, any>} */\n  const joinObject = {}\n\n  for (const key in hash) {\n    const value = hash[key]\n\n    if (!isPlainObject(value)) continue\n\n    const relationship = getRelationshipByName(modelClass, key)\n\n    if (!relationship) continue\n\n    const targetModelClass = relationship.getTargetModelClass()\n    const nestedJoinObject = buildJoinObjectFromWhereHash({hash: value, modelClass: targetModelClass})\n\n    joinObject[key] = Object.keys(nestedJoinObject).length > 0 ? nestedJoinObject : true\n  }\n\n  return joinObject\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"where-hash.d.ts","sourceRoot":"","sources":["../../../../src/database/query/where-hash.js"],"names":[],"mappings":"AAIA;;GAEG;AAEH;IACE;;;OAGG;IACH,mBAHW,OAAO,YAAY,EAAE,OAAO,QAC5B,SAAS,EAMnB;IAFC,gBAAgB;IAgBlB;;;;;OAKG;IACH,wBALW,SAAS,cACT,MAAM,UACN,MAAM,GACJ,MAAM,CAiClB;CACF;wBAhEY;IAAC,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,IAAI,GAAG,KAAK,CAAC,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,IAAI,CAAC,GAAG,SAAS,CAAA;CAAC;sBAH9F,iBAAiB"}
1
+ {"version":3,"file":"where-hash.d.ts","sourceRoot":"","sources":["../../../../src/database/query/where-hash.js"],"names":[],"mappings":"AAIA;;GAEG;AAEH;IACE;;;OAGG;IACH,mBAHW,OAAO,YAAY,EAAE,OAAO,QAC5B,SAAS,EAMnB;IAFC,gBAAgB;IAgBlB;;;;;OAKG;IACH,wBALW,SAAS,cACT,MAAM,UACN,MAAM,GACJ,MAAM,CAoClB;CACF;wBAnEY;IAAC,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,IAAI,GAAG,KAAK,CAAC,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,IAAI,CAAC,GAAG,SAAS,CAAA;CAAC;sBAH9F,iBAAiB"}
@@ -33,7 +33,12 @@ export default class VelociousDatabaseQueryWhereHash extends WhereBase {
33
33
  let sql = "";
34
34
  for (const whereKey in hash) {
35
35
  const whereValue = hash[whereKey];
36
- if (!Array.isArray(whereValue) && whereValue !== null && typeof whereValue == "object") {
36
+ if (Array.isArray(whereValue) && whereValue.length === 0) {
37
+ if (index > 0)
38
+ sql += " AND ";
39
+ sql += "1=0";
40
+ }
41
+ else if (!Array.isArray(whereValue) && whereValue !== null && typeof whereValue == "object") {
37
42
  sql += this._whereSQLFromHash(whereValue, whereKey, index);
38
43
  }
39
44
  else {
@@ -58,4 +63,4 @@ export default class VelociousDatabaseQueryWhereHash extends WhereBase {
58
63
  return sql;
59
64
  }
60
65
  }
61
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2hlcmUtaGFzaC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9kYXRhYmFzZS9xdWVyeS93aGVyZS1oYXNoLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLFlBQVk7QUFFWixPQUFPLFNBQVMsTUFBTSxpQkFBaUIsQ0FBQTtBQUV2Qzs7R0FFRztBQUVILE1BQU0sQ0FBQyxPQUFPLE9BQU8sK0JBQWdDLFNBQVEsU0FBUztJQUNwRTs7O09BR0c7SUFDSCxZQUFZLEtBQUssRUFBRSxJQUFJO1FBQ3JCLEtBQUssRUFBRSxDQUFBO1FBQ1AsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUE7UUFDaEIsSUFBSSxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUE7SUFDcEIsQ0FBQztJQUVEOztPQUVHO0lBQ0gsS0FBSztRQUNILElBQUksR0FBRyxHQUFHLEdBQUcsQ0FBQTtRQUViLEdBQUcsSUFBSSxJQUFJLENBQUMsaUJBQWlCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFBO1FBQ3hDLEdBQUcsSUFBSSxHQUFHLENBQUE7UUFFVixPQUFPLEdBQUcsQ0FBQTtJQUNaLENBQUM7SUFFRDs7Ozs7T0FLRztJQUNILGlCQUFpQixDQUFDLElBQUksRUFBRSxTQUFTLEVBQUUsS0FBSyxHQUFHLENBQUM7UUFDMUMsTUFBTSxPQUFPLEdBQUcsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFBO1FBQ2pDLElBQUksR0FBRyxHQUFHLEVBQUUsQ0FBQTtRQUVaLEtBQUssTUFBTSxRQUFRLElBQUksSUFBSSxFQUFFLENBQUM7WUFDNUIsTUFBTSxVQUFVLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFBO1lBRWpDLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLFVBQVUsQ0FBQyxJQUFJLFVBQVUsS0FBSyxJQUFJLElBQUksT0FBTyxVQUFVLElBQUksUUFBUSxFQUFFLENBQUM7Z0JBQ3ZGLEdBQUcsSUFBSSxJQUFJLENBQUMsaUJBQWlCLENBQUMsVUFBVSxFQUFFLFFBQVEsRUFBRSxLQUFLLENBQUMsQ0FBQTtZQUM1RCxDQUFDO2lCQUFNLENBQUM7Z0JBQ04sSUFBSSxLQUFLLEdBQUcsQ0FBQztvQkFBRSxHQUFHLElBQUksT0FBTyxDQUFBO2dCQUU3QixJQUFJLFNBQVMsRUFBRSxDQUFDO29CQUNkLEdBQUcsSUFBSSxHQUFHLE9BQU8sQ0FBQyxjQUFjLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQTtnQkFDaEQsQ0FBQztnQkFFRCxHQUFHLElBQUksR0FBRyxPQUFPLENBQUMsZUFBZSxDQUFDLFFBQVEsQ0FBQyxFQUFFLENBQUE7Z0JBRTdDLElBQUksS0FBSyxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUMsRUFBRSxDQUFDO29CQUM5QixHQUFHLElBQUksUUFBUSxVQUFVLENBQUMsR0FBRyxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUE7Z0JBQzlFLENBQUM7cUJBQU0sSUFBSSxVQUFVLEtBQUssSUFBSSxFQUFFLENBQUM7b0JBQy9CLEdBQUcsSUFBSSxVQUFVLENBQUE7Z0JBQ25CLENBQUM7cUJBQU0sQ0FBQztvQkFDTixHQUFHLElBQUksTUFBTSxPQUFPLENBQUMsS0FBSyxDQUFDLFVBQVUsQ0FBQyxFQUFFLENBQUE7Z0JBQzFDLENBQUM7WUFDSCxDQUFDO1lBRUQsS0FBSyxFQUFFLENBQUE7UUFDVCxDQUFDO1FBRUQsT0FBTyxHQUFHLENBQUE7SUFDWixDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBAdHMtY2hlY2tcblxuaW1wb3J0IFdoZXJlQmFzZSBmcm9tIFwiLi93aGVyZS1iYXNlLmpzXCJcblxuLyoqXG4gKiBAdHlwZWRlZiB7e1trZXk6IHN0cmluZ106IHN0cmluZyB8IG51bWJlciB8IGJvb2xlYW4gfCBudWxsIHwgQXJyYXk8c3RyaW5nIHwgbnVtYmVyIHwgYm9vbGVhbiB8IG51bGw+IHwgV2hlcmVIYXNofX0gV2hlcmVIYXNoXG4gKi9cblxuZXhwb3J0IGRlZmF1bHQgY2xhc3MgVmVsb2Npb3VzRGF0YWJhc2VRdWVyeVdoZXJlSGFzaCBleHRlbmRzIFdoZXJlQmFzZSB7XG4gIC8qKlxuICAgKiBAcGFyYW0ge2ltcG9ydChcIi4vaW5kZXguanNcIikuZGVmYXVsdH0gcXVlcnkgLSBRdWVyeSBpbnN0YW5jZS5cbiAgICogQHBhcmFtIHtXaGVyZUhhc2h9IGhhc2ggLSBIYXNoLlxuICAgKi9cbiAgY29uc3RydWN0b3IocXVlcnksIGhhc2gpIHtcbiAgICBzdXBlcigpXG4gICAgdGhpcy5oYXNoID0gaGFzaFxuICAgIHRoaXMucXVlcnkgPSBxdWVyeVxuICB9XG5cbiAgLyoqXG4gICAqIEByZXR1cm5zIHtzdHJpbmd9IC0gU1FMIHN0cmluZy5cbiAgICovXG4gIHRvU3FsKCkge1xuICAgIGxldCBzcWwgPSBcIihcIlxuXG4gICAgc3FsICs9IHRoaXMuX3doZXJlU1FMRnJvbUhhc2godGhpcy5oYXNoKVxuICAgIHNxbCArPSBcIilcIlxuXG4gICAgcmV0dXJuIHNxbFxuICB9XG5cbiAgLyoqXG4gICAqIEBwYXJhbSB7V2hlcmVIYXNofSBoYXNoIC0gSGFzaC5cbiAgICogQHBhcmFtIHtzdHJpbmd9IFt0YWJsZU5hbWVdIC0gVGFibGUgbmFtZS5cbiAgICogQHBhcmFtIHtudW1iZXJ9IGluZGV4IC0gSW5kZXggdmFsdWUuXG4gICAqIEByZXR1cm5zIHtzdHJpbmd9IC0gU1FMIHN0cmluZy5cbiAgICovXG4gIF93aGVyZVNRTEZyb21IYXNoKGhhc2gsIHRhYmxlTmFtZSwgaW5kZXggPSAwKSB7XG4gICAgY29uc3Qgb3B0aW9ucyA9IHRoaXMuZ2V0T3B0aW9ucygpXG4gICAgbGV0IHNxbCA9IFwiXCJcblxuICAgIGZvciAoY29uc3Qgd2hlcmVLZXkgaW4gaGFzaCkge1xuICAgICAgY29uc3Qgd2hlcmVWYWx1ZSA9IGhhc2hbd2hlcmVLZXldXG5cbiAgICAgIGlmICghQXJyYXkuaXNBcnJheSh3aGVyZVZhbHVlKSAmJiB3aGVyZVZhbHVlICE9PSBudWxsICYmIHR5cGVvZiB3aGVyZVZhbHVlID09IFwib2JqZWN0XCIpIHtcbiAgICAgICAgc3FsICs9IHRoaXMuX3doZXJlU1FMRnJvbUhhc2god2hlcmVWYWx1ZSwgd2hlcmVLZXksIGluZGV4KVxuICAgICAgfSBlbHNlIHtcbiAgICAgICAgaWYgKGluZGV4ID4gMCkgc3FsICs9IFwiIEFORCBcIlxuXG4gICAgICAgIGlmICh0YWJsZU5hbWUpIHtcbiAgICAgICAgICBzcWwgKz0gYCR7b3B0aW9ucy5xdW90ZVRhYmxlTmFtZSh0YWJsZU5hbWUpfS5gXG4gICAgICAgIH1cblxuICAgICAgICBzcWwgKz0gYCR7b3B0aW9ucy5xdW90ZUNvbHVtbk5hbWUod2hlcmVLZXkpfWBcblxuICAgICAgICBpZiAoQXJyYXkuaXNBcnJheSh3aGVyZVZhbHVlKSkge1xuICAgICAgICAgIHNxbCArPSBgIElOICgke3doZXJlVmFsdWUubWFwKCh2YWx1ZSkgPT4gb3B0aW9ucy5xdW90ZSh2YWx1ZSkpLmpvaW4oXCIsIFwiKX0pYFxuICAgICAgICB9IGVsc2UgaWYgKHdoZXJlVmFsdWUgPT09IG51bGwpIHtcbiAgICAgICAgICBzcWwgKz0gXCIgSVMgTlVMTFwiXG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgc3FsICs9IGAgPSAke29wdGlvbnMucXVvdGUod2hlcmVWYWx1ZSl9YFxuICAgICAgICB9XG4gICAgICB9XG5cbiAgICAgIGluZGV4KytcbiAgICB9XG5cbiAgICByZXR1cm4gc3FsXG4gIH1cbn1cbiJdfQ==
66
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2hlcmUtaGFzaC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9kYXRhYmFzZS9xdWVyeS93aGVyZS1oYXNoLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLFlBQVk7QUFFWixPQUFPLFNBQVMsTUFBTSxpQkFBaUIsQ0FBQTtBQUV2Qzs7R0FFRztBQUVILE1BQU0sQ0FBQyxPQUFPLE9BQU8sK0JBQWdDLFNBQVEsU0FBUztJQUNwRTs7O09BR0c7SUFDSCxZQUFZLEtBQUssRUFBRSxJQUFJO1FBQ3JCLEtBQUssRUFBRSxDQUFBO1FBQ1AsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUE7UUFDaEIsSUFBSSxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUE7SUFDcEIsQ0FBQztJQUVEOztPQUVHO0lBQ0gsS0FBSztRQUNILElBQUksR0FBRyxHQUFHLEdBQUcsQ0FBQTtRQUViLEdBQUcsSUFBSSxJQUFJLENBQUMsaUJBQWlCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFBO1FBQ3hDLEdBQUcsSUFBSSxHQUFHLENBQUE7UUFFVixPQUFPLEdBQUcsQ0FBQTtJQUNaLENBQUM7SUFFRDs7Ozs7T0FLRztJQUNILGlCQUFpQixDQUFDLElBQUksRUFBRSxTQUFTLEVBQUUsS0FBSyxHQUFHLENBQUM7UUFDMUMsTUFBTSxPQUFPLEdBQUcsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFBO1FBQ2pDLElBQUksR0FBRyxHQUFHLEVBQUUsQ0FBQTtRQUVaLEtBQUssTUFBTSxRQUFRLElBQUksSUFBSSxFQUFFLENBQUM7WUFDNUIsTUFBTSxVQUFVLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFBO1lBRWpDLElBQUksS0FBSyxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUMsSUFBSSxVQUFVLENBQUMsTUFBTSxLQUFLLENBQUMsRUFBRSxDQUFDO2dCQUN6RCxJQUFJLEtBQUssR0FBRyxDQUFDO29CQUFFLEdBQUcsSUFBSSxPQUFPLENBQUE7Z0JBQzdCLEdBQUcsSUFBSSxLQUFLLENBQUE7WUFDZCxDQUFDO2lCQUFNLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLFVBQVUsQ0FBQyxJQUFJLFVBQVUsS0FBSyxJQUFJLElBQUksT0FBTyxVQUFVLElBQUksUUFBUSxFQUFFLENBQUM7Z0JBQzlGLEdBQUcsSUFBSSxJQUFJLENBQUMsaUJBQWlCLENBQUMsVUFBVSxFQUFFLFFBQVEsRUFBRSxLQUFLLENBQUMsQ0FBQTtZQUM1RCxDQUFDO2lCQUFNLENBQUM7Z0JBQ04sSUFBSSxLQUFLLEdBQUcsQ0FBQztvQkFBRSxHQUFHLElBQUksT0FBTyxDQUFBO2dCQUU3QixJQUFJLFNBQVMsRUFBRSxDQUFDO29CQUNkLEdBQUcsSUFBSSxHQUFHLE9BQU8sQ0FBQyxjQUFjLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQTtnQkFDaEQsQ0FBQztnQkFFRCxHQUFHLElBQUksR0FBRyxPQUFPLENBQUMsZUFBZSxDQUFDLFFBQVEsQ0FBQyxFQUFFLENBQUE7Z0JBRTdDLElBQUksS0FBSyxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUMsRUFBRSxDQUFDO29CQUM5QixHQUFHLElBQUksUUFBUSxVQUFVLENBQUMsR0FBRyxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUE7Z0JBQzlFLENBQUM7cUJBQU0sSUFBSSxVQUFVLEtBQUssSUFBSSxFQUFFLENBQUM7b0JBQy9CLEdBQUcsSUFBSSxVQUFVLENBQUE7Z0JBQ25CLENBQUM7cUJBQU0sQ0FBQztvQkFDTixHQUFHLElBQUksTUFBTSxPQUFPLENBQUMsS0FBSyxDQUFDLFVBQVUsQ0FBQyxFQUFFLENBQUE7Z0JBQzFDLENBQUM7WUFDSCxDQUFDO1lBRUQsS0FBSyxFQUFFLENBQUE7UUFDVCxDQUFDO1FBRUQsT0FBTyxHQUFHLENBQUE7SUFDWixDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBAdHMtY2hlY2tcblxuaW1wb3J0IFdoZXJlQmFzZSBmcm9tIFwiLi93aGVyZS1iYXNlLmpzXCJcblxuLyoqXG4gKiBAdHlwZWRlZiB7e1trZXk6IHN0cmluZ106IHN0cmluZyB8IG51bWJlciB8IGJvb2xlYW4gfCBudWxsIHwgQXJyYXk8c3RyaW5nIHwgbnVtYmVyIHwgYm9vbGVhbiB8IG51bGw+IHwgV2hlcmVIYXNofX0gV2hlcmVIYXNoXG4gKi9cblxuZXhwb3J0IGRlZmF1bHQgY2xhc3MgVmVsb2Npb3VzRGF0YWJhc2VRdWVyeVdoZXJlSGFzaCBleHRlbmRzIFdoZXJlQmFzZSB7XG4gIC8qKlxuICAgKiBAcGFyYW0ge2ltcG9ydChcIi4vaW5kZXguanNcIikuZGVmYXVsdH0gcXVlcnkgLSBRdWVyeSBpbnN0YW5jZS5cbiAgICogQHBhcmFtIHtXaGVyZUhhc2h9IGhhc2ggLSBIYXNoLlxuICAgKi9cbiAgY29uc3RydWN0b3IocXVlcnksIGhhc2gpIHtcbiAgICBzdXBlcigpXG4gICAgdGhpcy5oYXNoID0gaGFzaFxuICAgIHRoaXMucXVlcnkgPSBxdWVyeVxuICB9XG5cbiAgLyoqXG4gICAqIEByZXR1cm5zIHtzdHJpbmd9IC0gU1FMIHN0cmluZy5cbiAgICovXG4gIHRvU3FsKCkge1xuICAgIGxldCBzcWwgPSBcIihcIlxuXG4gICAgc3FsICs9IHRoaXMuX3doZXJlU1FMRnJvbUhhc2godGhpcy5oYXNoKVxuICAgIHNxbCArPSBcIilcIlxuXG4gICAgcmV0dXJuIHNxbFxuICB9XG5cbiAgLyoqXG4gICAqIEBwYXJhbSB7V2hlcmVIYXNofSBoYXNoIC0gSGFzaC5cbiAgICogQHBhcmFtIHtzdHJpbmd9IFt0YWJsZU5hbWVdIC0gVGFibGUgbmFtZS5cbiAgICogQHBhcmFtIHtudW1iZXJ9IGluZGV4IC0gSW5kZXggdmFsdWUuXG4gICAqIEByZXR1cm5zIHtzdHJpbmd9IC0gU1FMIHN0cmluZy5cbiAgICovXG4gIF93aGVyZVNRTEZyb21IYXNoKGhhc2gsIHRhYmxlTmFtZSwgaW5kZXggPSAwKSB7XG4gICAgY29uc3Qgb3B0aW9ucyA9IHRoaXMuZ2V0T3B0aW9ucygpXG4gICAgbGV0IHNxbCA9IFwiXCJcblxuICAgIGZvciAoY29uc3Qgd2hlcmVLZXkgaW4gaGFzaCkge1xuICAgICAgY29uc3Qgd2hlcmVWYWx1ZSA9IGhhc2hbd2hlcmVLZXldXG5cbiAgICAgIGlmIChBcnJheS5pc0FycmF5KHdoZXJlVmFsdWUpICYmIHdoZXJlVmFsdWUubGVuZ3RoID09PSAwKSB7XG4gICAgICAgIGlmIChpbmRleCA+IDApIHNxbCArPSBcIiBBTkQgXCJcbiAgICAgICAgc3FsICs9IFwiMT0wXCJcbiAgICAgIH0gZWxzZSBpZiAoIUFycmF5LmlzQXJyYXkod2hlcmVWYWx1ZSkgJiYgd2hlcmVWYWx1ZSAhPT0gbnVsbCAmJiB0eXBlb2Ygd2hlcmVWYWx1ZSA9PSBcIm9iamVjdFwiKSB7XG4gICAgICAgIHNxbCArPSB0aGlzLl93aGVyZVNRTEZyb21IYXNoKHdoZXJlVmFsdWUsIHdoZXJlS2V5LCBpbmRleClcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIGlmIChpbmRleCA+IDApIHNxbCArPSBcIiBBTkQgXCJcblxuICAgICAgICBpZiAodGFibGVOYW1lKSB7XG4gICAgICAgICAgc3FsICs9IGAke29wdGlvbnMucXVvdGVUYWJsZU5hbWUodGFibGVOYW1lKX0uYFxuICAgICAgICB9XG5cbiAgICAgICAgc3FsICs9IGAke29wdGlvbnMucXVvdGVDb2x1bW5OYW1lKHdoZXJlS2V5KX1gXG5cbiAgICAgICAgaWYgKEFycmF5LmlzQXJyYXkod2hlcmVWYWx1ZSkpIHtcbiAgICAgICAgICBzcWwgKz0gYCBJTiAoJHt3aGVyZVZhbHVlLm1hcCgodmFsdWUpID0+IG9wdGlvbnMucXVvdGUodmFsdWUpKS5qb2luKFwiLCBcIil9KWBcbiAgICAgICAgfSBlbHNlIGlmICh3aGVyZVZhbHVlID09PSBudWxsKSB7XG4gICAgICAgICAgc3FsICs9IFwiIElTIE5VTExcIlxuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIHNxbCArPSBgID0gJHtvcHRpb25zLnF1b3RlKHdoZXJlVmFsdWUpfWBcbiAgICAgICAgfVxuICAgICAgfVxuXG4gICAgICBpbmRleCsrXG4gICAgfVxuXG4gICAgcmV0dXJuIHNxbFxuICB9XG59XG4iXX0=
@@ -0,0 +1,62 @@
1
+ /**
2
+ * @typedef {{[key: string]: string | number | boolean | null | Array<string | number | boolean | null> | Record<string, any>}} WhereHash
3
+ */
4
+ export default class VelociousDatabaseQueryWhereModelClassHash extends WhereBase {
5
+ /**
6
+ * @param {object} args - Options object.
7
+ * @param {import("./index.js").default} args.query - Query instance.
8
+ * @param {WhereHash} args.hash - Hash.
9
+ * @param {typeof import("../record/index.js").default} args.modelClass - Model class.
10
+ * @param {boolean} [args.qualifyBaseTable] - Whether to qualify base table columns.
11
+ */
12
+ constructor({ query, hash, modelClass, qualifyBaseTable }: {
13
+ query: import("./index.js").default;
14
+ hash: WhereHash;
15
+ modelClass: typeof import("../record/index.js").default;
16
+ qualifyBaseTable?: boolean;
17
+ });
18
+ hash: WhereHash;
19
+ modelClass: typeof import("../record/index.js").default;
20
+ qualifyBaseTable: boolean;
21
+ /**
22
+ * @returns {typeof import("../record/index.js").default} - The model class.
23
+ */
24
+ getModelClass(): typeof import("../record/index.js").default;
25
+ /**
26
+ * @param {typeof import("../record/index.js").default} modelClass - Model class.
27
+ * @param {string} key - Attribute or column name.
28
+ * @returns {string | undefined} - The resolved column name.
29
+ */
30
+ _resolveColumnName(modelClass: typeof import("../record/index.js").default, key: string): string | undefined;
31
+ /**
32
+ * @param {typeof import("../record/index.js").default} modelClass - Model class.
33
+ * @param {string} relationshipName - Relationship name.
34
+ * @returns {import("../record/relationships/base.js").default | undefined} - The relationship.
35
+ */
36
+ _getRelationship(modelClass: typeof import("../record/index.js").default, relationshipName: string): import("../record/relationships/base.js").default | undefined;
37
+ /**
38
+ * @param {object} args - Options object.
39
+ * @param {typeof import("../record/index.js").default} args.modelClass - Model class.
40
+ * @param {string} args.columnName - Column name.
41
+ * @param {any} args.value - Value to normalize.
42
+ * @returns {any} - Normalized value.
43
+ */
44
+ _normalizeSqliteBooleanValue({ modelClass, columnName, value }: {
45
+ modelClass: typeof import("../record/index.js").default;
46
+ columnName: string;
47
+ value: any;
48
+ }): any;
49
+ /**
50
+ * @param {WhereHash} hash - Hash.
51
+ * @param {typeof import("../record/index.js").default} modelClass - Model class.
52
+ * @param {string} [tableName] - Table name.
53
+ * @param {number} index - Index value.
54
+ * @returns {string} - SQL string.
55
+ */
56
+ _whereSQLFromHash(hash: WhereHash, modelClass: typeof import("../record/index.js").default, tableName?: string, index?: number): string;
57
+ }
58
+ export type WhereHash = {
59
+ [key: string]: string | number | boolean | null | Array<string | number | boolean | null> | Record<string, any>;
60
+ };
61
+ import WhereBase from "./where-base.js";
62
+ //# sourceMappingURL=where-model-class-hash.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"where-model-class-hash.d.ts","sourceRoot":"","sources":["../../../../src/database/query/where-model-class-hash.js"],"names":[],"mappings":"AAKA;;GAEG;AAEH;IACE;;;;;;OAMG;IACH,2DALG;QAA2C,KAAK,EAAxC,OAAO,YAAY,EAAE,OAAO;QACZ,IAAI,EAApB,SAAS;QACyC,UAAU,EAA5D,cAAc,oBAAoB,EAAE,OAAO;QAC5B,gBAAgB,GAA/B,OAAO;KACjB,EAOA;IAJC,gBAAgB;IAChB,wDAA4B;IAC5B,0BAAwC;IAI1C;;OAEG;IACH,iBAFa,cAAc,oBAAoB,EAAE,OAAO,CAMvD;IAgBD;;;;OAIG;IACH,+BAJW,cAAc,oBAAoB,EAAE,OAAO,OAC3C,MAAM,GACJ,MAAM,GAAG,SAAS,CAS9B;IAED;;;;OAIG;IACH,6BAJW,cAAc,oBAAoB,EAAE,OAAO,oBAC3C,MAAM,GACJ,OAAO,iCAAiC,EAAE,OAAO,GAAG,SAAS,CAIzE;IAED;;;;;;OAMG;IACH,gEALG;QAA0D,UAAU,EAA5D,cAAc,oBAAoB,EAAE,OAAO;QAC9B,UAAU,EAAvB,MAAM;QACI,KAAK,EAAf,GAAG;KACX,GAAU,GAAG,CAqBf;IAED;;;;;;OAMG;IACH,wBANW,SAAS,cACT,cAAc,oBAAoB,EAAE,OAAO,cAC3C,MAAM,UACN,MAAM,GACJ,MAAM,CAgElB;CACF;wBAnKY;IAAC,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,IAAI,GAAG,KAAK,CAAC,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,IAAI,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;CAAC;sBAHxG,iBAAiB"}