velocious 1.0.361 → 1.0.363
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +3 -0
- package/build/src/database/query/model-class-query.d.ts +2 -0
- package/build/src/database/query/model-class-query.d.ts.map +1 -1
- package/build/src/database/query/model-class-query.js +18 -1
- package/build/src/frontend-model-controller.d.ts +2 -0
- package/build/src/frontend-model-controller.d.ts.map +1 -1
- package/build/src/frontend-model-controller.js +14 -1
- package/build/src/frontend-model-resource/base-resource.d.ts +9 -0
- package/build/src/frontend-model-resource/base-resource.d.ts.map +1 -1
- package/build/src/frontend-model-resource/base-resource.js +16 -1
- package/build/src/frontend-models/base.d.ts.map +1 -1
- package/build/src/frontend-models/base.js +21 -2
- package/build/src/frontend-models/query.d.ts.map +1 -1
- package/build/src/frontend-models/query.js +17 -3
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -360,6 +360,7 @@ This creates `src/frontend-models/user.js` (and one file per configured resource
|
|
|
360
360
|
- `await Task.sort({project: {account: [["name", "desc"], ["createdAt", "asc"]]}}).toArray()`
|
|
361
361
|
- `await Task.group({project: {account: ["id"]}}).toArray()`
|
|
362
362
|
- `await Task.sort({comments: ["body", "asc"]}).distinct().toArray()`
|
|
363
|
+
- `await Task.count()`
|
|
363
364
|
- `await Task.pluck("id")`
|
|
364
365
|
- `await Task.pluck({project: ["id"]})`
|
|
365
366
|
- `await User.preload({projects: ["tasks"]}).toArray()`
|
|
@@ -1222,6 +1223,8 @@ const totalTasks = await Task.count()
|
|
|
1222
1223
|
const distinctProjects = await Task.joins({project: true}).distinct().count()
|
|
1223
1224
|
```
|
|
1224
1225
|
|
|
1226
|
+
Frontend-model `count()` runs as a backend aggregate, so list UIs can request counts without loading and serializing every matching model.
|
|
1227
|
+
|
|
1225
1228
|
### First and last
|
|
1226
1229
|
|
|
1227
1230
|
```js
|
|
@@ -61,6 +61,8 @@ export default class VelociousDatabaseQueryModelClassQuery<MC extends typeof imp
|
|
|
61
61
|
tableNameFor(...path: string[]): string;
|
|
62
62
|
/** @returns {Promise<number>} - Resolves with the count. */
|
|
63
63
|
count(): Promise<number>;
|
|
64
|
+
/** @returns {Promise<number>} - Resolves with the count after pagination is applied. */
|
|
65
|
+
paginatedCount(): Promise<number>;
|
|
64
66
|
/**
|
|
65
67
|
* @param {import("./index.js").SelectArgumentType} select - Select.
|
|
66
68
|
* @returns {this} - The select.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"model-class-query.d.ts","sourceRoot":"","sources":["../../../../src/database/query/model-class-query.js"],"names":[],"mappings":"AAuIA;;GAEG;AACH;;;GAGG;AAEH;;;GAGG;AACH,2DAX4D,EAAE,SAAjD,cAAe,oBAAoB,EAAE,OAAQ;IAYxD,+EAA+E;IAC/E,kBADY,uBAAuB,CAAC,EAAE,CAAC,EAsBtC;IAbC,iBAAiB;IACjB,YADW,EAAE,CACe;IAE5B,uBAAuB;IACvB,eADW,MAAM,EAAE,CACyB;IAC5C,0BAAsF;IACtF,gCAAiE;IAEjE,yDAAyD;IACzD,YADW,OAAO,iBAAiB,EAAE,cAAc,EAAE,CACM;IAE3D,yDAAyD;IACzD,YADW,OAAO,iBAAiB,EAAE,cAAc,EAAE,CACM;IAG7D,oCAAoC;IACpC,SADc,IAAI,CA2BjB;IAED;;;;;;;OAOG;IACH,gBAHW,OAAO,iBAAiB,EAAE,aAAa,GACrC,IAAI,CAQhB;IAED;;;;;;;;;;;;;OAaG;IACH,gBAHW,OAAO,iBAAiB,EAAE,aAAa,GACrC,IAAI,CAQhB;IAED;;;;;;;;;OASG;IACH,sBAHc,MAAM,EAAA,GACP,MAAM,CAIlB;IAED,6DAA6D;IAC7D,SADc,OAAO,CAAC,MAAM,CAAC,
|
|
1
|
+
{"version":3,"file":"model-class-query.d.ts","sourceRoot":"","sources":["../../../../src/database/query/model-class-query.js"],"names":[],"mappings":"AAuIA;;GAEG;AACH;;;GAGG;AAEH;;;GAGG;AACH,2DAX4D,EAAE,SAAjD,cAAe,oBAAoB,EAAE,OAAQ;IAYxD,+EAA+E;IAC/E,kBADY,uBAAuB,CAAC,EAAE,CAAC,EAsBtC;IAbC,iBAAiB;IACjB,YADW,EAAE,CACe;IAE5B,uBAAuB;IACvB,eADW,MAAM,EAAE,CACyB;IAC5C,0BAAsF;IACtF,gCAAiE;IAEjE,yDAAyD;IACzD,YADW,OAAO,iBAAiB,EAAE,cAAc,EAAE,CACM;IAE3D,yDAAyD;IACzD,YADW,OAAO,iBAAiB,EAAE,cAAc,EAAE,CACM;IAG7D,oCAAoC;IACpC,SADc,IAAI,CA2BjB;IAED;;;;;;;OAOG;IACH,gBAHW,OAAO,iBAAiB,EAAE,aAAa,GACrC,IAAI,CAQhB;IAED;;;;;;;;;;;;;OAaG;IACH,gBAHW,OAAO,iBAAiB,EAAE,aAAa,GACrC,IAAI,CAQhB;IAED;;;;;;;;;OASG;IACH,sBAHc,MAAM,EAAA,GACP,MAAM,CAIlB;IAED,6DAA6D;IAC7D,SADc,OAAO,CAAC,MAAM,CAAC,CA4C5B;IAED,wFAAwF;IACxF,kBADc,OAAO,CAAC,MAAM,CAAC,CAkB5B;IAED;;;OAGG;IACH,eAHW,OAAO,YAAY,EAAE,kBAAkB,GACrC,IAAI,CA0BhB;IAED;;OAEG;IACH,sBAFa,MAAM,CAiBlB;IAED,wCAAwC;IACxC,iBADc,EAAE,CAKf;IAED,gDAAgD;IAChD,mBADc,MAAM,EAAE,CAGrB;IAED,yEAAyE;IACzE,kBADc,OAAO,mBAAmB,EAAE,OAAO,CAGhD;IAED,0DAA0D;IAC1D,4BADc,OAAO,CAGpB;IAED;;;OAGG;IACH,8BAHW,MAAM,EAAE,GACN,IAAI,CAKhB;IAED;;;OAGG;IACH,2BAHW,MAAM,EAAE,GACN,qCAAqC,CAAC,EAAE,CAAC,CASrD;IAED;;;OAGG;IACH,mCAHW,MAAM,EAAE,GACN,MAAM,CAIlB;IAED;;;OAGG;IACH,oCAHW,MAAM,EAAE,GACN,cAAc,oBAAoB,EAAE,OAAO,CAiBvD;IAED;;;OAGG;IACH,wBAHW,MAAM,EAAE,GACN;QAAC,SAAS,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,GAAG,SAAS,CAAA;KAAC,CAM1D;IAED;;;OAGG;IACH,4BAHW,MAAM,EAAE,GACN,MAAM,CAMlB;IAED;;;OAGG;IACH,kCAHc,MAAM,EAAA,GACP,MAAM,CAMlB;IAED;;;OAGG;IACH,yBAHc,MAAM,EAAA,GACP,MAAM,CAIlB;IAED;;;;OAIG;IACH,6BAJW,OAAO,4BAA4B,EAAE,oBAAoB,GAAG,MAAM,GAAG,MAAM,EAAE,yBAC7E,OAAO,4BAA4B,EAAE,oBAAoB,GACvD,IAAI,CAehB;IAED;;;OAGG;IACH,iCAHW,OAAO,4BAA4B,EAAE,oBAAoB,GACvD,IAAI,CAmBhB;IAED;;;;;OAKG;IACH,mDAJG;QAAuB,QAAQ,EAAvB,MAAM,EAAE;QACwD,eAAe,EAA/E,OAAO,4BAA4B,EAAE,oBAAoB;KACjE,GAAU,IAAI,CAuDhB;IAED;;;;OAIG;IACH,sCAJW,cAAc,oBAAoB,EAAE,OAAO,YAC3C,MAAM,EAAE,GACN,qCAAqC,CAAC,EAAE,CAAC,CAUrD;IAED,0DAA0D;IAC1D,cADc,OAAO,CAAC,IAAI,CAAC,CAO1B;IAED;;;;;;OAMG;IACH,gBAHW,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GACjB,OAAO,CAAC,IAAI,CAAC,CAgCzB;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,CAQ5C;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,CAUrC;IAED;;;;OAIG;IACH,+BAJW,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,aACnB,CAAS,IAAgB,EAAhB,YAAY,CAAC,EAAE,CAAC,KAAI,IAAI,GAC/B,OAAO,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC,CAerC;IAED,8EAA8E;IAC9E,SADc,OAAO,CAAC,YAAY,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAM7C;IAED,6EAA6E;IAC7E,QADc,OAAO,CAAC,YAAY,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAO7C;IAED;;;OAGG;IACH,cAHW,OAAO,YAAY,EAAE,mBAAmB,GAAG,MAAM,GAAG,KAAK,CAAC,MAAM,GAAG,OAAO,YAAY,EAAE,mBAAmB,CAAC,GAC1G,IAAI,CAMhB;IAED;;;OAGG;IACH,QAFa,OAAO,CAAC,KAAK,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC,CAAC,CA+C5C;IAED;;;OAGG;IACH,WAFa,OAAO,CAAC,KAAK,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC,CAAC,CAI5C;IAED;;;;OAIG;IACH,kBAHW,CAAG,MAAM,GAAC,MAAM,EAAE,GAAA,GAChB,OAAO,CAAC,GAAG,EAAE,CAAC,CAmC1B;IAED;;;OAGG;IACH,aAHW,OAAO,YAAY,EAAE,iBAAiB,GACpC,IAAI,CAiChB;IAED;;;OAGG;IACH,gBAHW,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GACjB,IAAI,CAmBhB;IAED;;;OAGG;IACH,gBAHW,OAAO,YAAY,EAAE,iBAAiB,GACpC,IAAI,CAiChB;CASF;oCAtzB2D,EAAE,SAAjD,cAAe,oBAAoB,EAAE,OAAQ,kDAC7C,OAAO,YAAY,EAAE,aAAa,GAAG;IAAC,UAAU,EAAE,EAAE,CAAC;IAAC,YAAY,CAAC,EAAE,MAAM,EAAE,CAAC;IAAC,WAAW,CAAC,EAAE,OAAO,mBAAmB,EAAE,OAAO,CAAC;IAAC,qBAAqB,CAAC,EAAE,OAAO,CAAC;IAAC,SAAS,CAAC,EAAE,OAAO,iBAAiB,EAAE,cAAc,EAAE,CAAC;IAAC,SAAS,CAAC,EAAE,OAAO,iBAAiB,EAAE,cAAc,EAAE,CAAA;CAAC;0BAnIrQ,YAAY;wBAGd,mBAAmB"}
|
|
@@ -214,6 +214,9 @@ export default class VelociousDatabaseQueryModelClassQuery extends DatabaseQuery
|
|
|
214
214
|
}
|
|
215
215
|
/** @returns {Promise<number>} - Resolves with the count. */
|
|
216
216
|
async count() {
|
|
217
|
+
if (this._limit !== null || this._offset !== null) {
|
|
218
|
+
return await this.paginatedCount();
|
|
219
|
+
}
|
|
217
220
|
// Generate count SQL
|
|
218
221
|
const primaryKey = `${this.driver.quoteTable(this.getModelClass().tableName())}.${this.driver.quoteColumn(this.getModelClass().primaryKey())}`;
|
|
219
222
|
const distinctPrefix = this._distinct ? "DISTINCT " : "";
|
|
@@ -243,6 +246,20 @@ export default class VelociousDatabaseQueryModelClassQuery extends DatabaseQuery
|
|
|
243
246
|
}
|
|
244
247
|
return countResult;
|
|
245
248
|
}
|
|
249
|
+
/** @returns {Promise<number>} - Resolves with the count after pagination is applied. */
|
|
250
|
+
async paginatedCount() {
|
|
251
|
+
const countQuery = this.clone();
|
|
252
|
+
const countSql = this.driver.getType() == "pgsql" ? "COUNT(*)::int" : "COUNT(*)";
|
|
253
|
+
const sql = [
|
|
254
|
+
`SELECT ${countSql} AS ${this.driver.quoteColumn("count")}`,
|
|
255
|
+
`FROM (${countQuery.toSql()}) AS ${this.driver.quoteTable("paginated_count_rows")}`
|
|
256
|
+
].join(" ");
|
|
257
|
+
const results = /** @type {{count: number}[]} */ (await this.driver.query(sql, { logName: this.queryLogName("Count") }));
|
|
258
|
+
if (results.length != 1 || !("count" in results[0])) {
|
|
259
|
+
throw new Error("Invalid count result");
|
|
260
|
+
}
|
|
261
|
+
return results[0].count;
|
|
262
|
+
}
|
|
246
263
|
/**
|
|
247
264
|
* @param {import("./index.js").SelectArgumentType} select - Select.
|
|
248
265
|
* @returns {this} - The select.
|
|
@@ -1033,4 +1050,4 @@ function hasRelationshipWhereOperatorTuples(value) {
|
|
|
1033
1050
|
return false;
|
|
1034
1051
|
}
|
|
1035
1052
|
}
|
|
1036
|
-
//# 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 {normalizeQueryDataSpec, runQueryData} from \"./query-data.js\"\nimport {normalizeWithCount, runWithCount} from \"./with-count.js\"\nimport DatabaseQuery from \"./index.js\"\nimport JoinObject from \"./join-object.js\"\nimport JoinPlain from \"./join-plain.js\"\nimport JoinTracker from \"./join-tracker.js\"\nimport RecordNotFoundError from \"../record/record-not-found-error.js\"\nimport {normalizeRansackParams, parseRansackSort} from \"../../utils/ransack.js\"\nimport {isModelScopeDescriptor} from \"../../utils/model-scope.js\"\nimport WhereModelClassHash from \"./where-model-class-hash.js\"\nimport WhereNot from \"./where-not.js\"\nimport JoinsParser from \"../query-parser/joins-parser.js\"\nimport WhereParser from \"../query-parser/where-parser.js\"\n\n/**\n * @param {string} value - Potentially quoted SQL identifier.\n * @returns {string} - Unquoted identifier.\n */\nfunction unquoteSqlIdentifier(value) {\n  const trimmed = value.trim()\n\n  if (trimmed.length >= 2 && ((trimmed.startsWith(\"`\") && trimmed.endsWith(\"`\")) || (trimmed.startsWith(\"\\\"\") && trimmed.endsWith(\"\\\"\")))) {\n    return trimmed.slice(1, -1)\n  }\n\n  if (trimmed.length >= 2 && trimmed.startsWith(\"[\") && trimmed.endsWith(\"]\")) {\n    return trimmed.slice(1, -1)\n  }\n\n  return trimmed\n}\n\n/**\n * @param {string} fromPlain - FROM clause source.\n * @returns {string | null} - Parsed table reference or null when unsupported.\n */\nfunction parseFromPlainTableReference(fromPlain) {\n  const trimmed = fromPlain.trim()\n\n  if (trimmed.length < 1) return null\n\n  const aliasMatch = trimmed.match(/(?:^|\\s)(?:AS\\s+)?([`\"]?[a-zA-Z_][a-zA-Z0-9_]*[`\"]?|\\[[a-zA-Z_][a-zA-Z0-9_]*\\])\\s*$/i)\n\n  if (!aliasMatch || !aliasMatch[1]) return null\n\n  return unquoteSqlIdentifier(aliasMatch[1])\n}\n\n/**\n * @param {string | string[]} path - Scope path input.\n * @returns {string[]} - Normalized path.\n */\nfunction normalizeScopePath(path) {\n  if (typeof path === \"string\") {\n    if (path.length < 1) throw new Error(\"Scope path strings must be non-empty\")\n\n    return [path]\n  }\n\n  if (!Array.isArray(path)) {\n    throw new Error(`Invalid scope path type: ${typeof path}`)\n  }\n\n  for (const entry of path) {\n    if (typeof entry !== \"string\" || entry.length < 1) {\n      throw new Error(\"Scope path entries must be non-empty strings\")\n    }\n  }\n\n  return [...path]\n}\n\n/**\n * @param {import(\"./index.js\").NestedPreloadRecord | string | Array<string | import(\"./index.js\").NestedPreloadRecord>} preload - Preload data in shorthand or nested form.\n * @returns {import(\"./index.js\").NestedPreloadRecord} - Normalized preload record.\n */\nfunction normalizePreloadRecord(preload) {\n  if (!preload) return {}\n\n  if (typeof preload == \"string\") {\n    return {[preload]: true}\n  }\n\n  if (Array.isArray(preload)) {\n    /** @type {import(\"./index.js\").NestedPreloadRecord} */\n    const result = {}\n\n    for (const entry of preload) {\n      if (typeof entry == \"string\") {\n        result[entry] = true\n        continue\n      }\n\n      if (isPlainObject(entry)) {\n        incorporate(result, normalizePreloadRecord(entry))\n        continue\n      }\n\n      throw new Error(`Invalid preload entry type: ${typeof entry}`)\n    }\n\n    return result\n  }\n\n  if (!isPlainObject(preload)) {\n    throw new Error(`Invalid preload type: ${typeof preload}`)\n  }\n\n  /** @type {import(\"./index.js\").NestedPreloadRecord} */\n  const result = {}\n\n  for (const [key, value] of Object.entries(preload)) {\n    if (value === true || value === false) {\n      result[key] = value\n      continue\n    }\n\n    if (typeof value == \"string\" || Array.isArray(value) || isPlainObject(value)) {\n      result[key] = normalizePreloadRecord(value)\n      continue\n    }\n\n    throw new Error(`Invalid preload value for ${key}: ${typeof value}`)\n  }\n\n  return result\n}\n\n/**\n * @template {typeof import(\"../record/index.js\").default} [MC=typeof import(\"../record/index.js\").default]\n */\n/**\n * @template {typeof import(\"../record/index.js\").default} [MC=typeof import(\"../record/index.js\").default]\n * @typedef {import(\"./index.js\").QueryArgsType & {modelClass: MC, joinBasePath?: string[], joinTracker?: import(\"./join-tracker.js\").default, forceQualifyBaseTable?: boolean, withCount?: import(\"./with-count.js\").WithCountEntry[], queryData?: import(\"./query-data.js\").QueryDataEntry[]}} ModelClassQueryArgsType\n */\n\n/**\n * A generic query over some model type.\n * @template {typeof import(\"../record/index.js\").default} [MC=typeof import(\"../record/index.js\").default]\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    /** @type {string[]} */\n    this._joinBasePath = args.joinBasePath || []\n    this._joinTracker = args.joinTracker || new JoinTracker({modelClass: this.modelClass})\n    this._forceQualifyBaseTable = Boolean(args.forceQualifyBaseTable)\n\n    /** @type {import(\"./with-count.js\").WithCountEntry[]} */\n    this._withCount = args.withCount ? [...args.withCount] : []\n\n    /** @type {import(\"./query-data.js\").QueryDataEntry[]} */\n    this._queryData = args.queryData ? [...args.queryData] : []\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      joinBasePath: [...this._joinBasePath],\n      joinTracker: this._joinTracker.clone(),\n      forceQualifyBaseTable: this._forceQualifyBaseTable,\n      withCount: [...this._withCount],\n      queryData: [...this._queryData]\n    }))\n\n    // @ts-expect-error\n    return newQuery\n  }\n\n  /**\n   * Tell the query to attach one or more association counts onto every\n   * loaded record. The counts land as regular attributes on each record;\n   * read them with `model.readAttribute(\"<name>Count\")`.\n   *\n   * @param {import(\"./with-count.js\").WithCountSpec} spec - Count spec in shorthand or nested form.\n   * @returns {this} - This query, for chaining.\n   */\n  withCount(spec) {\n    for (const entry of normalizeWithCount(spec)) {\n      this._withCount.push(entry)\n    }\n\n    return this\n  }\n\n  /**\n   * Attach one or more consumer-defined, per-row computed values onto\n   * every loaded root record. Leaf strings in the spec are names of\n   * functions previously registered via `Model.queryData(name, fn)`.\n   * Nested object keys are relationship names traced from the root to\n   * the model that declares the fn. Every resulting SELECT alias is\n   * attached to the **root** record (not to the intermediate joined\n   * rows); read values with `record.queryData(aliasName)`.\n   *\n   * See also `src/database/query/query-data.js`.\n   *\n   * @param {import(\"./query-data.js\").QueryDataSpec} spec - Spec in shorthand or nested form.\n   * @returns {this} - This query, for chaining.\n   */\n  queryData(spec) {\n    for (const entry of normalizeQueryDataSpec(spec)) {\n      this._queryData.push(entry)\n    }\n\n    return this\n  }\n\n  /**\n   * Return the table reference (alias or table name) registered for the\n   * given relationship chain, relative to the query's current join base\n   * path. Convenience wrapper around `getTableReferenceForJoin` for use\n   * inside `queryData` callbacks where the writer's intent reads more\n   * naturally as \"give me the table name for 'tasks'\".\n   *\n   * @param {...string} path - Relationship path segments.\n   * @returns {string} - Unquoted table reference.\n   */\n  tableNameFor(...path) {\n    return this.getTableReferenceForJoin(...path)\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      logName: countQuery.queryLogName(\"Count\")\n    }))\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  /**\n   * @param {import(\"./index.js\").SelectArgumentType} select - Select.\n   * @returns {this} - The select.\n   */\n  select(select) {\n    if (Array.isArray(select)) {\n      for (const selectEntry of select) {\n        this.select(selectEntry)\n      }\n\n      return this\n    }\n\n    if (typeof select === \"string\") {\n      const trimmedSelect = select.trim()\n\n      if (/^[a-zA-Z_][a-zA-Z0-9_]*$/.test(trimmedSelect)) {\n        const modelClass = this.getModelClass()\n        const attributeMap = modelClass.getAttributeNameToColumnNameMap()\n        const columnName = attributeMap[trimmedSelect] || trimmedSelect\n        const tableReference = this.rootTableReference()\n        const qualifiedColumn = `${this.driver.quoteTable(tableReference)}.${this.driver.quoteColumn(columnName)}`\n\n        return super.select(qualifiedColumn)\n      }\n    }\n\n    return super.select(select)\n  }\n\n  /**\n   * @returns {string} - Root table reference for query select qualification.\n   */\n  rootTableReference() {\n    const froms = this.getFroms()\n    const lastFrom = froms[froms.length - 1]\n\n    if (lastFrom && typeof /** @type {any} */ (lastFrom).tableName === \"string\") {\n      return /** @type {any} */ (lastFrom).tableName\n    }\n\n    if (lastFrom && typeof /** @type {any} */ (lastFrom).plain === \"string\") {\n      const parsedReference = parseFromPlainTableReference(/** @type {any} */ (lastFrom).plain)\n\n      if (parsedReference) return parsedReference\n    }\n\n    return this.getTableReferenceForJoin()\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 {string[]} - The join base path. */\n  getJoinBasePath() {\n    return this._joinBasePath\n  }\n\n  /** @returns {import(\"./join-tracker.js\").default} - The join tracker. */\n  getJoinTracker() {\n    return this._joinTracker\n  }\n\n  /** @returns {boolean} - Whether to qualify base table. */\n  getForceQualifyBaseTable() {\n    return this._forceQualifyBaseTable\n  }\n\n  /**\n   * @param {string[]} joinBasePath - Join base path.\n   * @returns {this} - The query with updated base path.\n   */\n  setJoinBasePath(joinBasePath) {\n    this._joinBasePath = joinBasePath\n    return this\n  }\n\n  /**\n   * @param {string[]} joinBasePath - Join base path.\n   * @returns {VelociousDatabaseQueryModelClassQuery<MC>} - The scoped query.\n   */\n  withJoinPath(joinBasePath) {\n    const scopedQuery = /** @type {VelociousDatabaseQueryModelClassQuery<MC>} */ (this.clone())\n\n    scopedQuery._joinBasePath = joinBasePath\n    scopedQuery._joinTracker = this._joinTracker\n\n    return scopedQuery\n  }\n\n  /**\n   * @param {string[]} path - Join path.\n   * @returns {string} - Table name for path.\n   */\n  _resolveTableNameForJoinPath(path) {\n    return this._resolveModelClassForJoinPath(path).tableName()\n  }\n\n  /**\n   * @param {string[]} path - Join path.\n   * @returns {typeof import(\"../record/index.js\").default} - Target model class.\n   */\n  _resolveModelClassForJoinPath(path) {\n    let modelClass = this._joinTracker.getRootModelClass()\n\n    for (const relationshipName of path) {\n      const relationship = modelClass.getRelationshipByName(relationshipName)\n      const targetModelClass = relationship.getTargetModelClass()\n\n      if (!targetModelClass) {\n        throw new Error(`No target model class for ${modelClass.name}#${relationshipName}`)\n      }\n\n      modelClass = targetModelClass\n    }\n\n    return modelClass\n  }\n\n  /**\n   * @param {string[]} path - Join path.\n   * @returns {{tableName: string, alias: string | undefined}} - The entry.\n   */\n  _registerJoinPath(path) {\n    const tableName = this._resolveTableNameForJoinPath(path)\n\n    return this._joinTracker.registerPath(path, tableName)\n  }\n\n  /**\n   * @param {string[]} path - Join path.\n   * @returns {string} - Unquoted table reference (alias or table name).\n   */\n  getJoinTableReference(path) {\n    const entry = this._joinTracker.getEntry(path) || this._registerJoinPath(path)\n\n    return entry.alias || entry.tableName\n  }\n\n  /**\n   * @param {...string} path - Join path segments.\n   * @returns {string} - Unquoted table reference (alias or table name).\n   */\n  getTableReferenceForJoin(...path) {\n    const fullPath = this._joinBasePath.concat(path)\n\n    return this.getJoinTableReference(fullPath)\n  }\n\n  /**\n   * @param {...string} path - Join path segments.\n   * @returns {string} - Quoted table name for join path.\n   */\n  getTableForJoin(...path) {\n    return this.driver.quoteTable(this.getTableReferenceForJoin(...path))\n  }\n\n  /**\n   * @param {import(\"../../utils/model-scope.js\").ModelScopeDescriptor | string | string[]} pathOrScopeDescriptor - Scope descriptor or join path.\n   * @param {import(\"../../utils/model-scope.js\").ModelScopeDescriptor} [maybeScopeDescriptor] - Scope descriptor when path is given.\n   * @returns {this} - Scoped query.\n   */\n  scope(pathOrScopeDescriptor, maybeScopeDescriptor) {\n    if (isModelScopeDescriptor(pathOrScopeDescriptor) && !maybeScopeDescriptor) {\n      return this._applyRootScope(pathOrScopeDescriptor)\n    }\n\n    if (!maybeScopeDescriptor) {\n      throw new Error(\"scope(path, descriptor) requires a scope descriptor\")\n    }\n\n    return this._applyJoinPathScope({\n      joinPath: normalizeScopePath(/** @type {string | string[]} */ (pathOrScopeDescriptor)),\n      scopeDescriptor: maybeScopeDescriptor\n    })\n  }\n\n  /**\n   * @param {import(\"../../utils/model-scope.js\").ModelScopeDescriptor} scopeDescriptor - Scope descriptor.\n   * @returns {this} - Scoped query.\n   */\n  _applyRootScope(scopeDescriptor) {\n    if (!isModelScopeDescriptor(scopeDescriptor)) {\n      throw new Error(\"scope() expects a descriptor returned by defineScope(...).scope(...)\")\n    }\n\n    if (scopeDescriptor.modelClass !== this.getModelClass()) {\n      throw new Error(`Cannot apply ${scopeDescriptor.modelClass.name} scope to ${this.getModelClass().name} query`)\n    }\n\n    const scopedQuery = /** @type {this | void} */ (scopeDescriptor.callback({\n      driver: this.driver,\n      modelClass: this.getModelClass(),\n      query: this,\n      table: this.rootTableReference()\n    }, ...scopeDescriptor.scopeArgs))\n\n    return scopedQuery || this\n  }\n\n  /**\n   * @param {object} args - Join-path scope options.\n   * @param {string[]} args.joinPath - Join path relative to the current query.\n   * @param {import(\"../../utils/model-scope.js\").ModelScopeDescriptor} args.scopeDescriptor - Scope descriptor.\n   * @returns {this} - Scoped query.\n   */\n  _applyJoinPathScope({joinPath, scopeDescriptor}) {\n    if (!isModelScopeDescriptor(scopeDescriptor)) {\n      throw new Error(\"scope() expects a descriptor returned by defineScope(...).scope(...)\")\n    }\n\n    const fullJoinPath = this.getJoinBasePath().concat(joinPath)\n    const targetModelClass = this._resolveModelClassForJoinPath(fullJoinPath)\n\n    if (scopeDescriptor.modelClass !== targetModelClass) {\n      throw new Error(`Cannot apply ${scopeDescriptor.modelClass.name} scope to join path ${fullJoinPath.join(\".\")} (${targetModelClass.name})`)\n    }\n\n    const scopedQuery = this.buildJoinScopeQuery(targetModelClass, fullJoinPath)\n    const originalJoinCount = scopedQuery._joins.length\n    const originalWhereCount = scopedQuery._wheres.length\n    const appliedQuery = /** @type {typeof scopedQuery | void} */ (scopeDescriptor.callback({\n      driver: scopedQuery.driver,\n      modelClass: targetModelClass,\n      path: [...fullJoinPath],\n      query: scopedQuery,\n      table: scopedQuery.getTableReferenceForJoin()\n    }, ...scopeDescriptor.scopeArgs)) || scopedQuery\n\n    if (appliedQuery.getFroms().length !== scopedQuery.getFroms().length ||\n      appliedQuery.getGroups().length !== scopedQuery.getGroups().length ||\n      appliedQuery.getSelects().length !== scopedQuery.getSelects().length ||\n      appliedQuery._orders.length !== scopedQuery._orders.length ||\n      appliedQuery._limit !== scopedQuery._limit ||\n      appliedQuery._offset !== scopedQuery._offset ||\n      appliedQuery._page !== scopedQuery._page ||\n      appliedQuery._perPage !== scopedQuery._perPage ||\n      appliedQuery._distinct !== scopedQuery._distinct ||\n      Object.keys(appliedQuery._preload).length !== Object.keys(scopedQuery._preload).length) {\n      throw new Error(\"Joined-path scopes may only add where(...) and joins(...) clauses\")\n    }\n\n    if (appliedQuery._joins.length > originalJoinCount) {\n      for (const join of appliedQuery._joins.slice(originalJoinCount)) {\n        if (join instanceof JoinObject) {\n          this._joins.push(new JoinObject(join.object, fullJoinPath))\n        } else if (join instanceof JoinPlain) {\n          this._joins.push(join)\n        } else {\n          this._joins.push(join)\n        }\n      }\n    }\n\n    if (appliedQuery._wheres.length > originalWhereCount) {\n      this._wheres.push(...appliedQuery._wheres.slice(originalWhereCount))\n    }\n\n    return this\n  }\n\n  /**\n   * @param {typeof import(\"../record/index.js\").default} targetModelClass - Target model class.\n   * @param {string[]} joinPath - Join path.\n   * @returns {VelociousDatabaseQueryModelClassQuery<MC>} - The scoped join query.\n   */\n  buildJoinScopeQuery(targetModelClass, joinPath) {\n    const scopedQuery = /** @type {VelociousDatabaseQueryModelClassQuery<MC>} */ (targetModelClass._newQuery())\n\n    scopedQuery._joinTracker = this._joinTracker\n    scopedQuery._joinBasePath = joinPath\n    scopedQuery._forceQualifyBaseTable = true\n\n    return scopedQuery\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   * Executes a bulk UPDATE on all rows matching the query's WHERE\n   * clause. Bypasses model lifecycle callbacks — use this for\n   * efficient batch updates where per-row hooks aren't needed.\n   * @param {Record<string, any>} data - camelCase attribute names → values.\n   * @returns {Promise<void>} - Resolves when the update completes.\n   */\n  async updateAll(data) {\n    const driver = this.driver\n    const tableName = this.getModelClass().tableName()\n    const entries = Object.entries(data)\n\n    if (entries.length === 0) return\n\n    const setCols = entries.map(([key, value]) => {\n      const columnName = inflection.underscore(key)\n      const quoted = value === null ? \"NULL\" : driver.quote(value)\n\n      return `${driver.quoteColumn(columnName)} = ${quoted}`\n    }).join(\", \")\n\n    const joinsSql = new JoinsParser({pretty: false, query: this}).toSql()\n    const whereSql = new WhereParser({pretty: false, query: this}).toSql()\n    let sql\n\n    if (joinsSql.length > 0) {\n      // Use a subquery for cross-driver compatibility (SQLite\n      // doesn't support UPDATE ... JOIN).\n      const pk = driver.quoteColumn(this.getModelClass().primaryKey())\n      const qt = driver.quoteTable(tableName)\n\n      sql = `UPDATE ${qt} SET ${setCols} WHERE ${pk} IN (SELECT ${qt}.${pk} FROM ${qt}${joinsSql}${whereSql})`\n    } else {\n      sql = `UPDATE ${driver.quoteTable(tableName)} SET ${setCols}${whereSql}`\n    }\n\n    await driver.query(sql, {logName: this.queryLogName(\"Update All\")})\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    const newQuery = /** @type {VelociousDatabaseQueryModelClassQuery<MC>} */ (this.clone())\n\n    newQuery.where(conditions)\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    const record = await this.findBy(conditions)\n\n    if (!record) {\n      throw new Error(\"Record not found\")\n    }\n\n    return record\n  }\n\n  /**\n   * @param {Record<string, any>} 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> | null>} - 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] || null\n  }\n\n  /** @returns {Promise<InstanceType<MC> | null>} - 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] || null\n  }\n\n  /**\n   * @param {import(\"./index.js\").NestedPreloadRecord | string | Array<string | import(\"./index.js\").NestedPreloadRecord>} data - Data payload.\n   * @returns {this} - The preload.\n   */\n  preload(data) {\n    const normalizedPreload = normalizePreloadRecord(data)\n    incorporate(this._preload, normalizedPreload)\n    return this\n  }\n\n  /**\n   * Loads query results into model instances.\n   * @returns {Promise<Array<InstanceType<MC>>>} - Resolves with the array.\n   */\n  async load() {\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    // Share a single cohort reference across every sibling record so that\n    // auto-preload can batch lazy relationship access later.\n    for (const model of models) {\n      model._loadCohort = models\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    if (this._withCount.length > 0 && models.length > 0) {\n      await runWithCount({\n        entries: this._withCount,\n        modelClass: this.modelClass,\n        models\n      })\n    }\n\n    if (this._queryData.length > 0 && models.length > 0) {\n      await runQueryData({\n        entries: this._queryData,\n        rootModelClass: this.modelClass,\n        rootModels: models\n      })\n    }\n\n    return models\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    return await this.load()\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({logName: query.queryLogName(\"Pluck\")})\n\n    if (columnNames.length === 1) {\n      const [columnName] = columnNames\n      return rows.map((row) => /** @type {Record<string, any>} */ (row)[columnName])\n    }\n\n    return rows.map((row) => {\n      const rowHash = /** @type {Record<string, any>} */ (row)\n\n      return columnNames.map((columnName) => rowHash[columnName])\n    })\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 = this.getForceQualifyBaseTable() || 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   * @param {Record<string, any>} params - Ransack-style params hash. Supports `s` key for sorting (e.g., `{s: \"name asc\"}`).\n   * @returns {this} - Query with Ransack filters and sort applied.\n   */\n  ransack(params) {\n    const {s, ...filterParams} = params\n    const conditions = normalizeRansackParams(this.getModelClass(), filterParams)\n\n    for (const condition of conditions) {\n      applyRansackCondition({condition, query: this})\n    }\n\n    if (typeof s === \"string\" && s.trim().length > 0) {\n      const sorts = parseRansackSort(this.getModelClass(), s)\n\n      for (const sortDef of sorts) {\n        this.order(`${sortDef.attribute} ${sortDef.direction}`)\n      }\n    }\n\n    return this\n  }\n\n  /**\n   * @param {import(\"./index.js\").WhereArgumentType} where - Where.\n   * @returns {this} This query instance\n   */\n  whereNot(where) {\n    if (typeof where == \"string\") {\n      return super.whereNot(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 = this.getForceQualifyBaseTable() || Object.keys(joinObject).length > 0\n        this._wheres.push(new WhereNot(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.whereNot(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   * @param {string} operation - Query operation.\n   * @returns {string} - Query log name.\n   */\n  queryLogName(operation) {\n    return `${this.getModelClass().name} ${operation}`\n  }\n}\n\n/**\n * @param {object} args - Options.\n * @param {import(\"../../utils/ransack.js\").RansackCondition} args.condition - Normalized Ransack condition.\n * @param {import(\"./model-class-query.js\").default<any>} args.query - Query instance.\n * @returns {void}\n */\nfunction applyRansackCondition({condition, query}) {\n  if (condition.predicate === \"eq\" || condition.predicate === \"in\") {\n    query.where(buildNestedRansackHash({condition, value: condition.value}))\n    return\n  }\n\n  if (condition.predicate === \"not_eq\" || condition.predicate === \"not_in\") {\n    query.whereNot(buildNestedRansackHash({condition, value: condition.value}))\n    return\n  }\n\n  if (condition.predicate === \"null\") {\n    if (condition.value) {\n      query.where(buildNestedRansackHash({condition, value: null}))\n    } else {\n      query.whereNot(buildNestedRansackHash({condition, value: null}))\n    }\n\n    return\n  }\n\n  query.where(buildNestedRansackTupleHash({\n    condition,\n    operator: ransackTupleOperator(condition.predicate),\n    value: ransackTupleValue(condition)\n  }))\n}\n\n/**\n * @param {object} args - Options.\n * @param {import(\"../../utils/ransack.js\").RansackCondition} args.condition - Normalized Ransack condition.\n * @param {any} args.value - Final value.\n * @returns {Record<string, any>} - Nested hash suitable for query.where/query.whereNot.\n */\nfunction buildNestedRansackHash({condition, value}) {\n  /** @type {Record<string, any>} */\n  let hash = {[condition.attributeName]: value}\n\n  for (let index = condition.path.length - 1; index >= 0; index -= 1) {\n    hash = {[condition.path[index]]: hash}\n  }\n\n  return hash\n}\n\n/**\n * @param {object} args - Options.\n * @param {import(\"../../utils/ransack.js\").RansackCondition} args.condition - Normalized Ransack condition.\n * @param {\"gt\" | \"gteq\" | \"lt\" | \"lteq\" | \"like\"} args.operator - Tuple operator.\n * @param {any} args.value - Final value.\n * @returns {Record<string, any>} - Nested tuple hash suitable for query.where.\n */\nfunction buildNestedRansackTupleHash({condition, operator, value}) {\n  /** @type {Record<string, any>} */\n  let hash = {\n    [condition.attributeName]: [[condition.attributeName, operator, value]]\n  }\n\n  for (let index = condition.path.length - 1; index >= 0; index -= 1) {\n    hash = {[condition.path[index]]: hash}\n  }\n\n  return hash\n}\n\n/**\n * @param {import(\"../../utils/ransack.js\").RansackPredicate} predicate - Ransack predicate.\n * @returns {\"gt\" | \"gteq\" | \"lt\" | \"lteq\" | \"like\"} - Query tuple operator.\n */\nfunction ransackTupleOperator(predicate) {\n  if (predicate === \"gt\" || predicate === \"gteq\" || predicate === \"lt\" || predicate === \"lteq\") {\n    return predicate\n  }\n\n  return \"like\"\n}\n\n/**\n * @param {import(\"../../utils/ransack.js\").RansackCondition} condition - Ransack condition.\n * @returns {any} - Query tuple value.\n */\nfunction ransackTupleValue(condition) {\n  if (condition.predicate === \"cont\") return `%${condition.value}%`\n  if (condition.predicate === \"start\") return `${condition.value}%`\n  if (condition.predicate === \"end\") return `%${condition.value}`\n\n  return condition.value\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\n  if (attributeMap[key]) return attributeMap[key]\n\n  const columnMap = modelClass.getColumnNameToAttributeNameMap()\n  const underscored = inflection.underscore(key)\n\n  return columnMap[key] || columnMap[underscored] || 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    const relationship = getRelationshipByName(modelClass, key)\n\n    if (isNested) {\n      if (relationship) {\n        const targetModelClass = relationship.getTargetModelClass()\n        if (!targetModelClass) {\n          fallbackHash[key] = value\n          continue\n        }\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 if (relationship && hasRelationshipWhereOperatorTuples(value)) {\n      resolvedHash[key] = normalizeRelationshipWhereOperatorTuples(value)\n    } else {\n      const columnName = resolveColumnName(modelClass, key)\n\n      if (columnName) {\n        resolvedHash[columnName] = 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    const relationship = getRelationshipByName(modelClass, key)\n\n    if (!relationship) continue\n\n    if (isPlainObject(value)) {\n      const targetModelClass = relationship.getTargetModelClass()\n      if (!targetModelClass) continue\n      const nestedJoinObject = buildJoinObjectFromWhereHash({hash: value, modelClass: targetModelClass})\n\n      joinObject[key] = Object.keys(nestedJoinObject).length > 0 ? nestedJoinObject : true\n      continue\n    }\n\n    if (hasRelationshipWhereOperatorTuples(value)) {\n      joinObject[key] = true\n    }\n  }\n\n  return joinObject\n}\n\nconst relationshipWhereOperators = new Set([\"eq\", \"notEq\", \"gt\", \"gteq\", \"lt\", \"lteq\", \"like\", \">\", \">=\", \"<\", \"<=\"])\n\n/**\n * @param {string} operator - Raw relationship where operator.\n * @returns {\"eq\" | \"notEq\" | \"gt\" | \"gteq\" | \"lt\" | \"lteq\" | \"like\"} - Normalized operator.\n */\nfunction normalizeRelationshipWhereOperator(operator) {\n  const operatorAliases = {\n    \"<\": \"lt\",\n    \"<=\": \"lteq\",\n    \">\": \"gt\",\n    \">=\": \"gteq\"\n  }\n\n  return /** @type {\"eq\" | \"notEq\" | \"gt\" | \"gteq\" | \"lt\" | \"lteq\" | \"like\"} */ (\n    operatorAliases[/** @type {\"<\" | \"<=\" | \">\" | \">=\"} */ (operator)] || operator\n  )\n}\n\n/**\n * @param {unknown} tupleValue - Candidate tuple.\n * @returns {boolean} - Whether this is a relationship where tuple.\n */\nfunction isRelationshipWhereOperatorTuple(tupleValue) {\n  if (!Array.isArray(tupleValue) || tupleValue.length < 3) {\n    return false\n  }\n\n  return typeof tupleValue[0] === \"string\" &&\n    typeof tupleValue[1] === \"string\" &&\n    relationshipWhereOperators.has(tupleValue[1])\n}\n\n/**\n * @param {unknown} value - Candidate value.\n * @returns {Array<[string, \"eq\" | \"notEq\" | \"gt\" | \"gteq\" | \"lt\" | \"lteq\" | \"like\", any]>} - Normalized tuples.\n */\nfunction normalizeRelationshipWhereOperatorTuples(value) {\n  if (!Array.isArray(value)) {\n    throw new Error(`Invalid relationship where tuple container type: ${typeof value}`)\n  }\n\n  /** @type {Array<[string, \"eq\" | \"notEq\" | \"gt\" | \"gteq\" | \"lt\" | \"lteq\" | \"like\", any]>} */\n  const normalized = []\n    /** @param {unknown} conditionValue - Candidate nested condition. */\n    const addCondition = (conditionValue) => {\n      if (isRelationshipWhereOperatorTuple(conditionValue)) {\n        const tuple = /** @type {[string, \"eq\" | \"notEq\" | \"gt\" | \"gteq\" | \"lt\" | \"lteq\" | \"like\" | \">\" | \">=\" | \"<\" | \"<=\", any, ...unknown[]]} */ (conditionValue)\n        const normalizedOperator = normalizeRelationshipWhereOperator(tuple[1])\n\n        normalized.push([\n          tuple[0],\n          normalizedOperator,\n          tuple[2]\n        ])\n\n        if (tuple.length > 3) {\n          for (let index = 3; index < tuple.length; index += 1) {\n            addCondition(tuple[index])\n          }\n      }\n\n      return\n    }\n\n    if (!Array.isArray(conditionValue)) {\n      throw new Error(\"Relationship where conditions must be tuples\")\n    }\n\n    /** @type {unknown[]} */ (conditionValue).forEach((nestedConditionValue) => {\n      addCondition(nestedConditionValue)\n    })\n  }\n\n  addCondition(value)\n\n  if (normalized.length < 1) {\n    throw new Error(\"Relationship where tuple container cannot be empty\")\n  }\n\n  return normalized\n}\n\n/**\n * @param {unknown} value - Candidate relationship where value.\n * @returns {boolean} - Whether value can be normalized to relationship tuples.\n */\nfunction hasRelationshipWhereOperatorTuples(value) {\n  try {\n    normalizeRelationshipWhereOperatorTuples(value)\n\n    return true\n  } catch {\n    return false\n  }\n}\n"]}
|
|
1053
|
+
//# 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 {normalizeQueryDataSpec, runQueryData} from \"./query-data.js\"\nimport {normalizeWithCount, runWithCount} from \"./with-count.js\"\nimport DatabaseQuery from \"./index.js\"\nimport JoinObject from \"./join-object.js\"\nimport JoinPlain from \"./join-plain.js\"\nimport JoinTracker from \"./join-tracker.js\"\nimport RecordNotFoundError from \"../record/record-not-found-error.js\"\nimport {normalizeRansackParams, parseRansackSort} from \"../../utils/ransack.js\"\nimport {isModelScopeDescriptor} from \"../../utils/model-scope.js\"\nimport WhereModelClassHash from \"./where-model-class-hash.js\"\nimport WhereNot from \"./where-not.js\"\nimport JoinsParser from \"../query-parser/joins-parser.js\"\nimport WhereParser from \"../query-parser/where-parser.js\"\n\n/**\n * @param {string} value - Potentially quoted SQL identifier.\n * @returns {string} - Unquoted identifier.\n */\nfunction unquoteSqlIdentifier(value) {\n  const trimmed = value.trim()\n\n  if (trimmed.length >= 2 && ((trimmed.startsWith(\"`\") && trimmed.endsWith(\"`\")) || (trimmed.startsWith(\"\\\"\") && trimmed.endsWith(\"\\\"\")))) {\n    return trimmed.slice(1, -1)\n  }\n\n  if (trimmed.length >= 2 && trimmed.startsWith(\"[\") && trimmed.endsWith(\"]\")) {\n    return trimmed.slice(1, -1)\n  }\n\n  return trimmed\n}\n\n/**\n * @param {string} fromPlain - FROM clause source.\n * @returns {string | null} - Parsed table reference or null when unsupported.\n */\nfunction parseFromPlainTableReference(fromPlain) {\n  const trimmed = fromPlain.trim()\n\n  if (trimmed.length < 1) return null\n\n  const aliasMatch = trimmed.match(/(?:^|\\s)(?:AS\\s+)?([`\"]?[a-zA-Z_][a-zA-Z0-9_]*[`\"]?|\\[[a-zA-Z_][a-zA-Z0-9_]*\\])\\s*$/i)\n\n  if (!aliasMatch || !aliasMatch[1]) return null\n\n  return unquoteSqlIdentifier(aliasMatch[1])\n}\n\n/**\n * @param {string | string[]} path - Scope path input.\n * @returns {string[]} - Normalized path.\n */\nfunction normalizeScopePath(path) {\n  if (typeof path === \"string\") {\n    if (path.length < 1) throw new Error(\"Scope path strings must be non-empty\")\n\n    return [path]\n  }\n\n  if (!Array.isArray(path)) {\n    throw new Error(`Invalid scope path type: ${typeof path}`)\n  }\n\n  for (const entry of path) {\n    if (typeof entry !== \"string\" || entry.length < 1) {\n      throw new Error(\"Scope path entries must be non-empty strings\")\n    }\n  }\n\n  return [...path]\n}\n\n/**\n * @param {import(\"./index.js\").NestedPreloadRecord | string | Array<string | import(\"./index.js\").NestedPreloadRecord>} preload - Preload data in shorthand or nested form.\n * @returns {import(\"./index.js\").NestedPreloadRecord} - Normalized preload record.\n */\nfunction normalizePreloadRecord(preload) {\n  if (!preload) return {}\n\n  if (typeof preload == \"string\") {\n    return {[preload]: true}\n  }\n\n  if (Array.isArray(preload)) {\n    /** @type {import(\"./index.js\").NestedPreloadRecord} */\n    const result = {}\n\n    for (const entry of preload) {\n      if (typeof entry == \"string\") {\n        result[entry] = true\n        continue\n      }\n\n      if (isPlainObject(entry)) {\n        incorporate(result, normalizePreloadRecord(entry))\n        continue\n      }\n\n      throw new Error(`Invalid preload entry type: ${typeof entry}`)\n    }\n\n    return result\n  }\n\n  if (!isPlainObject(preload)) {\n    throw new Error(`Invalid preload type: ${typeof preload}`)\n  }\n\n  /** @type {import(\"./index.js\").NestedPreloadRecord} */\n  const result = {}\n\n  for (const [key, value] of Object.entries(preload)) {\n    if (value === true || value === false) {\n      result[key] = value\n      continue\n    }\n\n    if (typeof value == \"string\" || Array.isArray(value) || isPlainObject(value)) {\n      result[key] = normalizePreloadRecord(value)\n      continue\n    }\n\n    throw new Error(`Invalid preload value for ${key}: ${typeof value}`)\n  }\n\n  return result\n}\n\n/**\n * @template {typeof import(\"../record/index.js\").default} [MC=typeof import(\"../record/index.js\").default]\n */\n/**\n * @template {typeof import(\"../record/index.js\").default} [MC=typeof import(\"../record/index.js\").default]\n * @typedef {import(\"./index.js\").QueryArgsType & {modelClass: MC, joinBasePath?: string[], joinTracker?: import(\"./join-tracker.js\").default, forceQualifyBaseTable?: boolean, withCount?: import(\"./with-count.js\").WithCountEntry[], queryData?: import(\"./query-data.js\").QueryDataEntry[]}} ModelClassQueryArgsType\n */\n\n/**\n * A generic query over some model type.\n * @template {typeof import(\"../record/index.js\").default} [MC=typeof import(\"../record/index.js\").default]\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    /** @type {string[]} */\n    this._joinBasePath = args.joinBasePath || []\n    this._joinTracker = args.joinTracker || new JoinTracker({modelClass: this.modelClass})\n    this._forceQualifyBaseTable = Boolean(args.forceQualifyBaseTable)\n\n    /** @type {import(\"./with-count.js\").WithCountEntry[]} */\n    this._withCount = args.withCount ? [...args.withCount] : []\n\n    /** @type {import(\"./query-data.js\").QueryDataEntry[]} */\n    this._queryData = args.queryData ? [...args.queryData] : []\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      joinBasePath: [...this._joinBasePath],\n      joinTracker: this._joinTracker.clone(),\n      forceQualifyBaseTable: this._forceQualifyBaseTable,\n      withCount: [...this._withCount],\n      queryData: [...this._queryData]\n    }))\n\n    // @ts-expect-error\n    return newQuery\n  }\n\n  /**\n   * Tell the query to attach one or more association counts onto every\n   * loaded record. The counts land as regular attributes on each record;\n   * read them with `model.readAttribute(\"<name>Count\")`.\n   *\n   * @param {import(\"./with-count.js\").WithCountSpec} spec - Count spec in shorthand or nested form.\n   * @returns {this} - This query, for chaining.\n   */\n  withCount(spec) {\n    for (const entry of normalizeWithCount(spec)) {\n      this._withCount.push(entry)\n    }\n\n    return this\n  }\n\n  /**\n   * Attach one or more consumer-defined, per-row computed values onto\n   * every loaded root record. Leaf strings in the spec are names of\n   * functions previously registered via `Model.queryData(name, fn)`.\n   * Nested object keys are relationship names traced from the root to\n   * the model that declares the fn. Every resulting SELECT alias is\n   * attached to the **root** record (not to the intermediate joined\n   * rows); read values with `record.queryData(aliasName)`.\n   *\n   * See also `src/database/query/query-data.js`.\n   *\n   * @param {import(\"./query-data.js\").QueryDataSpec} spec - Spec in shorthand or nested form.\n   * @returns {this} - This query, for chaining.\n   */\n  queryData(spec) {\n    for (const entry of normalizeQueryDataSpec(spec)) {\n      this._queryData.push(entry)\n    }\n\n    return this\n  }\n\n  /**\n   * Return the table reference (alias or table name) registered for the\n   * given relationship chain, relative to the query's current join base\n   * path. Convenience wrapper around `getTableReferenceForJoin` for use\n   * inside `queryData` callbacks where the writer's intent reads more\n   * naturally as \"give me the table name for 'tasks'\".\n   *\n   * @param {...string} path - Relationship path segments.\n   * @returns {string} - Unquoted table reference.\n   */\n  tableNameFor(...path) {\n    return this.getTableReferenceForJoin(...path)\n  }\n\n  /** @returns {Promise<number>} - Resolves with the count.  */\n  async count() {\n    if (this._limit !== null || this._offset !== null) {\n      return await this.paginatedCount()\n    }\n\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      logName: countQuery.queryLogName(\"Count\")\n    }))\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 {Promise<number>} - Resolves with the count after pagination is applied. */\n  async paginatedCount() {\n    const countQuery = this.clone()\n    const countSql = this.driver.getType() == \"pgsql\" ? \"COUNT(*)::int\" : \"COUNT(*)\"\n    const sql = [\n      `SELECT ${countSql} AS ${this.driver.quoteColumn(\"count\")}`,\n      `FROM (${countQuery.toSql()}) AS ${this.driver.quoteTable(\"paginated_count_rows\")}`\n    ].join(\" \")\n    const results = /** @type {{count: number}[]} */ (await this.driver.query(\n      sql,\n      {logName: this.queryLogName(\"Count\")}\n    ))\n\n    if (results.length != 1 || !(\"count\" in results[0])) {\n      throw new Error(\"Invalid count result\")\n    }\n\n    return results[0].count\n  }\n\n  /**\n   * @param {import(\"./index.js\").SelectArgumentType} select - Select.\n   * @returns {this} - The select.\n   */\n  select(select) {\n    if (Array.isArray(select)) {\n      for (const selectEntry of select) {\n        this.select(selectEntry)\n      }\n\n      return this\n    }\n\n    if (typeof select === \"string\") {\n      const trimmedSelect = select.trim()\n\n      if (/^[a-zA-Z_][a-zA-Z0-9_]*$/.test(trimmedSelect)) {\n        const modelClass = this.getModelClass()\n        const attributeMap = modelClass.getAttributeNameToColumnNameMap()\n        const columnName = attributeMap[trimmedSelect] || trimmedSelect\n        const tableReference = this.rootTableReference()\n        const qualifiedColumn = `${this.driver.quoteTable(tableReference)}.${this.driver.quoteColumn(columnName)}`\n\n        return super.select(qualifiedColumn)\n      }\n    }\n\n    return super.select(select)\n  }\n\n  /**\n   * @returns {string} - Root table reference for query select qualification.\n   */\n  rootTableReference() {\n    const froms = this.getFroms()\n    const lastFrom = froms[froms.length - 1]\n\n    if (lastFrom && typeof /** @type {any} */ (lastFrom).tableName === \"string\") {\n      return /** @type {any} */ (lastFrom).tableName\n    }\n\n    if (lastFrom && typeof /** @type {any} */ (lastFrom).plain === \"string\") {\n      const parsedReference = parseFromPlainTableReference(/** @type {any} */ (lastFrom).plain)\n\n      if (parsedReference) return parsedReference\n    }\n\n    return this.getTableReferenceForJoin()\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 {string[]} - The join base path. */\n  getJoinBasePath() {\n    return this._joinBasePath\n  }\n\n  /** @returns {import(\"./join-tracker.js\").default} - The join tracker. */\n  getJoinTracker() {\n    return this._joinTracker\n  }\n\n  /** @returns {boolean} - Whether to qualify base table. */\n  getForceQualifyBaseTable() {\n    return this._forceQualifyBaseTable\n  }\n\n  /**\n   * @param {string[]} joinBasePath - Join base path.\n   * @returns {this} - The query with updated base path.\n   */\n  setJoinBasePath(joinBasePath) {\n    this._joinBasePath = joinBasePath\n    return this\n  }\n\n  /**\n   * @param {string[]} joinBasePath - Join base path.\n   * @returns {VelociousDatabaseQueryModelClassQuery<MC>} - The scoped query.\n   */\n  withJoinPath(joinBasePath) {\n    const scopedQuery = /** @type {VelociousDatabaseQueryModelClassQuery<MC>} */ (this.clone())\n\n    scopedQuery._joinBasePath = joinBasePath\n    scopedQuery._joinTracker = this._joinTracker\n\n    return scopedQuery\n  }\n\n  /**\n   * @param {string[]} path - Join path.\n   * @returns {string} - Table name for path.\n   */\n  _resolveTableNameForJoinPath(path) {\n    return this._resolveModelClassForJoinPath(path).tableName()\n  }\n\n  /**\n   * @param {string[]} path - Join path.\n   * @returns {typeof import(\"../record/index.js\").default} - Target model class.\n   */\n  _resolveModelClassForJoinPath(path) {\n    let modelClass = this._joinTracker.getRootModelClass()\n\n    for (const relationshipName of path) {\n      const relationship = modelClass.getRelationshipByName(relationshipName)\n      const targetModelClass = relationship.getTargetModelClass()\n\n      if (!targetModelClass) {\n        throw new Error(`No target model class for ${modelClass.name}#${relationshipName}`)\n      }\n\n      modelClass = targetModelClass\n    }\n\n    return modelClass\n  }\n\n  /**\n   * @param {string[]} path - Join path.\n   * @returns {{tableName: string, alias: string | undefined}} - The entry.\n   */\n  _registerJoinPath(path) {\n    const tableName = this._resolveTableNameForJoinPath(path)\n\n    return this._joinTracker.registerPath(path, tableName)\n  }\n\n  /**\n   * @param {string[]} path - Join path.\n   * @returns {string} - Unquoted table reference (alias or table name).\n   */\n  getJoinTableReference(path) {\n    const entry = this._joinTracker.getEntry(path) || this._registerJoinPath(path)\n\n    return entry.alias || entry.tableName\n  }\n\n  /**\n   * @param {...string} path - Join path segments.\n   * @returns {string} - Unquoted table reference (alias or table name).\n   */\n  getTableReferenceForJoin(...path) {\n    const fullPath = this._joinBasePath.concat(path)\n\n    return this.getJoinTableReference(fullPath)\n  }\n\n  /**\n   * @param {...string} path - Join path segments.\n   * @returns {string} - Quoted table name for join path.\n   */\n  getTableForJoin(...path) {\n    return this.driver.quoteTable(this.getTableReferenceForJoin(...path))\n  }\n\n  /**\n   * @param {import(\"../../utils/model-scope.js\").ModelScopeDescriptor | string | string[]} pathOrScopeDescriptor - Scope descriptor or join path.\n   * @param {import(\"../../utils/model-scope.js\").ModelScopeDescriptor} [maybeScopeDescriptor] - Scope descriptor when path is given.\n   * @returns {this} - Scoped query.\n   */\n  scope(pathOrScopeDescriptor, maybeScopeDescriptor) {\n    if (isModelScopeDescriptor(pathOrScopeDescriptor) && !maybeScopeDescriptor) {\n      return this._applyRootScope(pathOrScopeDescriptor)\n    }\n\n    if (!maybeScopeDescriptor) {\n      throw new Error(\"scope(path, descriptor) requires a scope descriptor\")\n    }\n\n    return this._applyJoinPathScope({\n      joinPath: normalizeScopePath(/** @type {string | string[]} */ (pathOrScopeDescriptor)),\n      scopeDescriptor: maybeScopeDescriptor\n    })\n  }\n\n  /**\n   * @param {import(\"../../utils/model-scope.js\").ModelScopeDescriptor} scopeDescriptor - Scope descriptor.\n   * @returns {this} - Scoped query.\n   */\n  _applyRootScope(scopeDescriptor) {\n    if (!isModelScopeDescriptor(scopeDescriptor)) {\n      throw new Error(\"scope() expects a descriptor returned by defineScope(...).scope(...)\")\n    }\n\n    if (scopeDescriptor.modelClass !== this.getModelClass()) {\n      throw new Error(`Cannot apply ${scopeDescriptor.modelClass.name} scope to ${this.getModelClass().name} query`)\n    }\n\n    const scopedQuery = /** @type {this | void} */ (scopeDescriptor.callback({\n      driver: this.driver,\n      modelClass: this.getModelClass(),\n      query: this,\n      table: this.rootTableReference()\n    }, ...scopeDescriptor.scopeArgs))\n\n    return scopedQuery || this\n  }\n\n  /**\n   * @param {object} args - Join-path scope options.\n   * @param {string[]} args.joinPath - Join path relative to the current query.\n   * @param {import(\"../../utils/model-scope.js\").ModelScopeDescriptor} args.scopeDescriptor - Scope descriptor.\n   * @returns {this} - Scoped query.\n   */\n  _applyJoinPathScope({joinPath, scopeDescriptor}) {\n    if (!isModelScopeDescriptor(scopeDescriptor)) {\n      throw new Error(\"scope() expects a descriptor returned by defineScope(...).scope(...)\")\n    }\n\n    const fullJoinPath = this.getJoinBasePath().concat(joinPath)\n    const targetModelClass = this._resolveModelClassForJoinPath(fullJoinPath)\n\n    if (scopeDescriptor.modelClass !== targetModelClass) {\n      throw new Error(`Cannot apply ${scopeDescriptor.modelClass.name} scope to join path ${fullJoinPath.join(\".\")} (${targetModelClass.name})`)\n    }\n\n    const scopedQuery = this.buildJoinScopeQuery(targetModelClass, fullJoinPath)\n    const originalJoinCount = scopedQuery._joins.length\n    const originalWhereCount = scopedQuery._wheres.length\n    const appliedQuery = /** @type {typeof scopedQuery | void} */ (scopeDescriptor.callback({\n      driver: scopedQuery.driver,\n      modelClass: targetModelClass,\n      path: [...fullJoinPath],\n      query: scopedQuery,\n      table: scopedQuery.getTableReferenceForJoin()\n    }, ...scopeDescriptor.scopeArgs)) || scopedQuery\n\n    if (appliedQuery.getFroms().length !== scopedQuery.getFroms().length ||\n      appliedQuery.getGroups().length !== scopedQuery.getGroups().length ||\n      appliedQuery.getSelects().length !== scopedQuery.getSelects().length ||\n      appliedQuery._orders.length !== scopedQuery._orders.length ||\n      appliedQuery._limit !== scopedQuery._limit ||\n      appliedQuery._offset !== scopedQuery._offset ||\n      appliedQuery._page !== scopedQuery._page ||\n      appliedQuery._perPage !== scopedQuery._perPage ||\n      appliedQuery._distinct !== scopedQuery._distinct ||\n      Object.keys(appliedQuery._preload).length !== Object.keys(scopedQuery._preload).length) {\n      throw new Error(\"Joined-path scopes may only add where(...) and joins(...) clauses\")\n    }\n\n    if (appliedQuery._joins.length > originalJoinCount) {\n      for (const join of appliedQuery._joins.slice(originalJoinCount)) {\n        if (join instanceof JoinObject) {\n          this._joins.push(new JoinObject(join.object, fullJoinPath))\n        } else if (join instanceof JoinPlain) {\n          this._joins.push(join)\n        } else {\n          this._joins.push(join)\n        }\n      }\n    }\n\n    if (appliedQuery._wheres.length > originalWhereCount) {\n      this._wheres.push(...appliedQuery._wheres.slice(originalWhereCount))\n    }\n\n    return this\n  }\n\n  /**\n   * @param {typeof import(\"../record/index.js\").default} targetModelClass - Target model class.\n   * @param {string[]} joinPath - Join path.\n   * @returns {VelociousDatabaseQueryModelClassQuery<MC>} - The scoped join query.\n   */\n  buildJoinScopeQuery(targetModelClass, joinPath) {\n    const scopedQuery = /** @type {VelociousDatabaseQueryModelClassQuery<MC>} */ (targetModelClass._newQuery())\n\n    scopedQuery._joinTracker = this._joinTracker\n    scopedQuery._joinBasePath = joinPath\n    scopedQuery._forceQualifyBaseTable = true\n\n    return scopedQuery\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   * Executes a bulk UPDATE on all rows matching the query's WHERE\n   * clause. Bypasses model lifecycle callbacks — use this for\n   * efficient batch updates where per-row hooks aren't needed.\n   * @param {Record<string, any>} data - camelCase attribute names → values.\n   * @returns {Promise<void>} - Resolves when the update completes.\n   */\n  async updateAll(data) {\n    const driver = this.driver\n    const tableName = this.getModelClass().tableName()\n    const entries = Object.entries(data)\n\n    if (entries.length === 0) return\n\n    const setCols = entries.map(([key, value]) => {\n      const columnName = inflection.underscore(key)\n      const quoted = value === null ? \"NULL\" : driver.quote(value)\n\n      return `${driver.quoteColumn(columnName)} = ${quoted}`\n    }).join(\", \")\n\n    const joinsSql = new JoinsParser({pretty: false, query: this}).toSql()\n    const whereSql = new WhereParser({pretty: false, query: this}).toSql()\n    let sql\n\n    if (joinsSql.length > 0) {\n      // Use a subquery for cross-driver compatibility (SQLite\n      // doesn't support UPDATE ... JOIN).\n      const pk = driver.quoteColumn(this.getModelClass().primaryKey())\n      const qt = driver.quoteTable(tableName)\n\n      sql = `UPDATE ${qt} SET ${setCols} WHERE ${pk} IN (SELECT ${qt}.${pk} FROM ${qt}${joinsSql}${whereSql})`\n    } else {\n      sql = `UPDATE ${driver.quoteTable(tableName)} SET ${setCols}${whereSql}`\n    }\n\n    await driver.query(sql, {logName: this.queryLogName(\"Update All\")})\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    const newQuery = /** @type {VelociousDatabaseQueryModelClassQuery<MC>} */ (this.clone())\n\n    newQuery.where(conditions)\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    const record = await this.findBy(conditions)\n\n    if (!record) {\n      throw new Error(\"Record not found\")\n    }\n\n    return record\n  }\n\n  /**\n   * @param {Record<string, any>} 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> | null>} - 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] || null\n  }\n\n  /** @returns {Promise<InstanceType<MC> | null>} - 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] || null\n  }\n\n  /**\n   * @param {import(\"./index.js\").NestedPreloadRecord | string | Array<string | import(\"./index.js\").NestedPreloadRecord>} data - Data payload.\n   * @returns {this} - The preload.\n   */\n  preload(data) {\n    const normalizedPreload = normalizePreloadRecord(data)\n    incorporate(this._preload, normalizedPreload)\n    return this\n  }\n\n  /**\n   * Loads query results into model instances.\n   * @returns {Promise<Array<InstanceType<MC>>>} - Resolves with the array.\n   */\n  async load() {\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    // Share a single cohort reference across every sibling record so that\n    // auto-preload can batch lazy relationship access later.\n    for (const model of models) {\n      model._loadCohort = models\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    if (this._withCount.length > 0 && models.length > 0) {\n      await runWithCount({\n        entries: this._withCount,\n        modelClass: this.modelClass,\n        models\n      })\n    }\n\n    if (this._queryData.length > 0 && models.length > 0) {\n      await runQueryData({\n        entries: this._queryData,\n        rootModelClass: this.modelClass,\n        rootModels: models\n      })\n    }\n\n    return models\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    return await this.load()\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({logName: query.queryLogName(\"Pluck\")})\n\n    if (columnNames.length === 1) {\n      const [columnName] = columnNames\n      return rows.map((row) => /** @type {Record<string, any>} */ (row)[columnName])\n    }\n\n    return rows.map((row) => {\n      const rowHash = /** @type {Record<string, any>} */ (row)\n\n      return columnNames.map((columnName) => rowHash[columnName])\n    })\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 = this.getForceQualifyBaseTable() || 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   * @param {Record<string, any>} params - Ransack-style params hash. Supports `s` key for sorting (e.g., `{s: \"name asc\"}`).\n   * @returns {this} - Query with Ransack filters and sort applied.\n   */\n  ransack(params) {\n    const {s, ...filterParams} = params\n    const conditions = normalizeRansackParams(this.getModelClass(), filterParams)\n\n    for (const condition of conditions) {\n      applyRansackCondition({condition, query: this})\n    }\n\n    if (typeof s === \"string\" && s.trim().length > 0) {\n      const sorts = parseRansackSort(this.getModelClass(), s)\n\n      for (const sortDef of sorts) {\n        this.order(`${sortDef.attribute} ${sortDef.direction}`)\n      }\n    }\n\n    return this\n  }\n\n  /**\n   * @param {import(\"./index.js\").WhereArgumentType} where - Where.\n   * @returns {this} This query instance\n   */\n  whereNot(where) {\n    if (typeof where == \"string\") {\n      return super.whereNot(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 = this.getForceQualifyBaseTable() || Object.keys(joinObject).length > 0\n        this._wheres.push(new WhereNot(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.whereNot(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   * @param {string} operation - Query operation.\n   * @returns {string} - Query log name.\n   */\n  queryLogName(operation) {\n    return `${this.getModelClass().name} ${operation}`\n  }\n}\n\n/**\n * @param {object} args - Options.\n * @param {import(\"../../utils/ransack.js\").RansackCondition} args.condition - Normalized Ransack condition.\n * @param {import(\"./model-class-query.js\").default<any>} args.query - Query instance.\n * @returns {void}\n */\nfunction applyRansackCondition({condition, query}) {\n  if (condition.predicate === \"eq\" || condition.predicate === \"in\") {\n    query.where(buildNestedRansackHash({condition, value: condition.value}))\n    return\n  }\n\n  if (condition.predicate === \"not_eq\" || condition.predicate === \"not_in\") {\n    query.whereNot(buildNestedRansackHash({condition, value: condition.value}))\n    return\n  }\n\n  if (condition.predicate === \"null\") {\n    if (condition.value) {\n      query.where(buildNestedRansackHash({condition, value: null}))\n    } else {\n      query.whereNot(buildNestedRansackHash({condition, value: null}))\n    }\n\n    return\n  }\n\n  query.where(buildNestedRansackTupleHash({\n    condition,\n    operator: ransackTupleOperator(condition.predicate),\n    value: ransackTupleValue(condition)\n  }))\n}\n\n/**\n * @param {object} args - Options.\n * @param {import(\"../../utils/ransack.js\").RansackCondition} args.condition - Normalized Ransack condition.\n * @param {any} args.value - Final value.\n * @returns {Record<string, any>} - Nested hash suitable for query.where/query.whereNot.\n */\nfunction buildNestedRansackHash({condition, value}) {\n  /** @type {Record<string, any>} */\n  let hash = {[condition.attributeName]: value}\n\n  for (let index = condition.path.length - 1; index >= 0; index -= 1) {\n    hash = {[condition.path[index]]: hash}\n  }\n\n  return hash\n}\n\n/**\n * @param {object} args - Options.\n * @param {import(\"../../utils/ransack.js\").RansackCondition} args.condition - Normalized Ransack condition.\n * @param {\"gt\" | \"gteq\" | \"lt\" | \"lteq\" | \"like\"} args.operator - Tuple operator.\n * @param {any} args.value - Final value.\n * @returns {Record<string, any>} - Nested tuple hash suitable for query.where.\n */\nfunction buildNestedRansackTupleHash({condition, operator, value}) {\n  /** @type {Record<string, any>} */\n  let hash = {\n    [condition.attributeName]: [[condition.attributeName, operator, value]]\n  }\n\n  for (let index = condition.path.length - 1; index >= 0; index -= 1) {\n    hash = {[condition.path[index]]: hash}\n  }\n\n  return hash\n}\n\n/**\n * @param {import(\"../../utils/ransack.js\").RansackPredicate} predicate - Ransack predicate.\n * @returns {\"gt\" | \"gteq\" | \"lt\" | \"lteq\" | \"like\"} - Query tuple operator.\n */\nfunction ransackTupleOperator(predicate) {\n  if (predicate === \"gt\" || predicate === \"gteq\" || predicate === \"lt\" || predicate === \"lteq\") {\n    return predicate\n  }\n\n  return \"like\"\n}\n\n/**\n * @param {import(\"../../utils/ransack.js\").RansackCondition} condition - Ransack condition.\n * @returns {any} - Query tuple value.\n */\nfunction ransackTupleValue(condition) {\n  if (condition.predicate === \"cont\") return `%${condition.value}%`\n  if (condition.predicate === \"start\") return `${condition.value}%`\n  if (condition.predicate === \"end\") return `%${condition.value}`\n\n  return condition.value\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\n  if (attributeMap[key]) return attributeMap[key]\n\n  const columnMap = modelClass.getColumnNameToAttributeNameMap()\n  const underscored = inflection.underscore(key)\n\n  return columnMap[key] || columnMap[underscored] || 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    const relationship = getRelationshipByName(modelClass, key)\n\n    if (isNested) {\n      if (relationship) {\n        const targetModelClass = relationship.getTargetModelClass()\n        if (!targetModelClass) {\n          fallbackHash[key] = value\n          continue\n        }\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 if (relationship && hasRelationshipWhereOperatorTuples(value)) {\n      resolvedHash[key] = normalizeRelationshipWhereOperatorTuples(value)\n    } else {\n      const columnName = resolveColumnName(modelClass, key)\n\n      if (columnName) {\n        resolvedHash[columnName] = 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    const relationship = getRelationshipByName(modelClass, key)\n\n    if (!relationship) continue\n\n    if (isPlainObject(value)) {\n      const targetModelClass = relationship.getTargetModelClass()\n      if (!targetModelClass) continue\n      const nestedJoinObject = buildJoinObjectFromWhereHash({hash: value, modelClass: targetModelClass})\n\n      joinObject[key] = Object.keys(nestedJoinObject).length > 0 ? nestedJoinObject : true\n      continue\n    }\n\n    if (hasRelationshipWhereOperatorTuples(value)) {\n      joinObject[key] = true\n    }\n  }\n\n  return joinObject\n}\n\nconst relationshipWhereOperators = new Set([\"eq\", \"notEq\", \"gt\", \"gteq\", \"lt\", \"lteq\", \"like\", \">\", \">=\", \"<\", \"<=\"])\n\n/**\n * @param {string} operator - Raw relationship where operator.\n * @returns {\"eq\" | \"notEq\" | \"gt\" | \"gteq\" | \"lt\" | \"lteq\" | \"like\"} - Normalized operator.\n */\nfunction normalizeRelationshipWhereOperator(operator) {\n  const operatorAliases = {\n    \"<\": \"lt\",\n    \"<=\": \"lteq\",\n    \">\": \"gt\",\n    \">=\": \"gteq\"\n  }\n\n  return /** @type {\"eq\" | \"notEq\" | \"gt\" | \"gteq\" | \"lt\" | \"lteq\" | \"like\"} */ (\n    operatorAliases[/** @type {\"<\" | \"<=\" | \">\" | \">=\"} */ (operator)] || operator\n  )\n}\n\n/**\n * @param {unknown} tupleValue - Candidate tuple.\n * @returns {boolean} - Whether this is a relationship where tuple.\n */\nfunction isRelationshipWhereOperatorTuple(tupleValue) {\n  if (!Array.isArray(tupleValue) || tupleValue.length < 3) {\n    return false\n  }\n\n  return typeof tupleValue[0] === \"string\" &&\n    typeof tupleValue[1] === \"string\" &&\n    relationshipWhereOperators.has(tupleValue[1])\n}\n\n/**\n * @param {unknown} value - Candidate value.\n * @returns {Array<[string, \"eq\" | \"notEq\" | \"gt\" | \"gteq\" | \"lt\" | \"lteq\" | \"like\", any]>} - Normalized tuples.\n */\nfunction normalizeRelationshipWhereOperatorTuples(value) {\n  if (!Array.isArray(value)) {\n    throw new Error(`Invalid relationship where tuple container type: ${typeof value}`)\n  }\n\n  /** @type {Array<[string, \"eq\" | \"notEq\" | \"gt\" | \"gteq\" | \"lt\" | \"lteq\" | \"like\", any]>} */\n  const normalized = []\n    /** @param {unknown} conditionValue - Candidate nested condition. */\n    const addCondition = (conditionValue) => {\n      if (isRelationshipWhereOperatorTuple(conditionValue)) {\n        const tuple = /** @type {[string, \"eq\" | \"notEq\" | \"gt\" | \"gteq\" | \"lt\" | \"lteq\" | \"like\" | \">\" | \">=\" | \"<\" | \"<=\", any, ...unknown[]]} */ (conditionValue)\n        const normalizedOperator = normalizeRelationshipWhereOperator(tuple[1])\n\n        normalized.push([\n          tuple[0],\n          normalizedOperator,\n          tuple[2]\n        ])\n\n        if (tuple.length > 3) {\n          for (let index = 3; index < tuple.length; index += 1) {\n            addCondition(tuple[index])\n          }\n      }\n\n      return\n    }\n\n    if (!Array.isArray(conditionValue)) {\n      throw new Error(\"Relationship where conditions must be tuples\")\n    }\n\n    /** @type {unknown[]} */ (conditionValue).forEach((nestedConditionValue) => {\n      addCondition(nestedConditionValue)\n    })\n  }\n\n  addCondition(value)\n\n  if (normalized.length < 1) {\n    throw new Error(\"Relationship where tuple container cannot be empty\")\n  }\n\n  return normalized\n}\n\n/**\n * @param {unknown} value - Candidate relationship where value.\n * @returns {boolean} - Whether value can be normalized to relationship tuples.\n */\nfunction hasRelationshipWhereOperatorTuples(value) {\n  try {\n    normalizeRelationshipWhereOperatorTuples(value)\n\n    return true\n  } catch {\n    return false\n  }\n}\n"]}
|
|
@@ -155,6 +155,8 @@ export default class FrontendModelController extends Controller {
|
|
|
155
155
|
frontendModelDistinct(): boolean | null;
|
|
156
156
|
/** @returns {FrontendModelPluck[]} - Frontend pluck definitions. */
|
|
157
157
|
frontendModelPluck(): FrontendModelPluck[];
|
|
158
|
+
/** @returns {boolean} - Whether the request asks for an aggregate count. */
|
|
159
|
+
frontendModelCountRequested(): boolean;
|
|
158
160
|
/**
|
|
159
161
|
* @returns {Array<{attributeName: string, relationshipName: string, where?: Record<string, unknown>}>}
|
|
160
162
|
* Frontend withCount entries. Empty array when not requested.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"frontend-model-controller.d.ts","sourceRoot":"","sources":["../../src/frontend-model-controller.js"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"frontend-model-controller.d.ts","sourceRoot":"","sources":["../../src/frontend-model-controller.js"],"names":[],"mappings":"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"}
|