velocious 1.0.179 → 1.0.180

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.
@@ -1,8 +1,3 @@
1
- /**
2
- * @typedef {{[key: string]: boolean | NestedPreloadRecord }} NestedPreloadRecord
3
- * @typedef {string | string[] | import("./select-base.js").default | import("./select-base.js").default[]} SelectArgumentType
4
- * @typedef {object | string} WhereArgumentType
5
- */
6
1
  /**
7
2
  * @typedef {object} QueryArgsType
8
3
  * @property {import("../drivers/base.js").default | (() => import("../drivers/base.js").default)} driver - Driver instance or factory for query execution.
@@ -68,10 +63,10 @@ export default class VelociousDatabaseQuery {
68
63
  */
69
64
  group(group: string): this;
70
65
  /**
71
- * @param {string | import("./join-object.js").JoinObject} join - Join clause or join descriptor.
66
+ * @param {string | string[] | import("./join-object.js").JoinObjectInput} join - Join clause or join descriptor.
72
67
  * @returns {this} - The joins.
73
68
  */
74
- joins(join: string | import("./join-object.js").JoinObject): this;
69
+ joins(join: string | string[] | import("./join-object.js").JoinObjectInput): this;
75
70
  /**
76
71
  * @param {number} value - Value to use.
77
72
  * @returns {this} - The limit.
@@ -137,7 +132,7 @@ export default class VelociousDatabaseQuery {
137
132
  get driver(): import("../drivers/base.js").default;
138
133
  }
139
134
  export type NestedPreloadRecord = {
140
- [key: string]: boolean | NestedPreloadRecord;
135
+ [key: string]: boolean | string | string[] | NestedPreloadRecord;
141
136
  };
142
137
  export type SelectArgumentType = string | string[] | import("./select-base.js").default | import("./select-base.js").default[];
143
138
  export type WhereArgumentType = object | string;
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/database/query/index.js"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/database/query/index.js"],"names":[],"mappings":"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"}
@@ -11,10 +11,76 @@ import WhereHash from "./where-hash.js";
11
11
  import WhereNot from "./where-not.js";
12
12
  import WherePlain from "./where-plain.js";
13
13
  /**
14
- * @typedef {{[key: string]: boolean | NestedPreloadRecord }} NestedPreloadRecord
14
+ * @typedef {{[key: string]: boolean | string | string[] | NestedPreloadRecord }} NestedPreloadRecord
15
15
  * @typedef {string | string[] | import("./select-base.js").default | import("./select-base.js").default[]} SelectArgumentType
16
16
  * @typedef {object | string} WhereArgumentType
17
17
  */
18
+ /**
19
+ * @param {import("./join-object.js").JoinObjectInput | string | string[]} join - Join data in shorthand or nested form.
20
+ * @returns {import("./join-object.js").JoinObject} - Normalized join record.
21
+ */
22
+ function normalizeJoinObject(join) {
23
+ if (!join)
24
+ return {};
25
+ if (typeof join == "string") {
26
+ return { [join]: true };
27
+ }
28
+ if (Array.isArray(join)) {
29
+ /** @type {import("./join-object.js").JoinObject} */
30
+ const result = {};
31
+ for (const entry of join) {
32
+ if (typeof entry == "string") {
33
+ const existing = result[entry];
34
+ result[entry] = mergeJoinValue(existing, true);
35
+ continue;
36
+ }
37
+ if (isPlainObject(entry)) {
38
+ const normalized = normalizeJoinObject(entry);
39
+ for (const [key, value] of Object.entries(normalized)) {
40
+ const existing = result[key];
41
+ result[key] = mergeJoinValue(existing, value);
42
+ }
43
+ continue;
44
+ }
45
+ throw new Error(`Invalid join entry type: ${typeof entry}`);
46
+ }
47
+ return result;
48
+ }
49
+ if (!isPlainObject(join)) {
50
+ throw new Error(`Invalid join type: ${typeof join}`);
51
+ }
52
+ /** @type {import("./join-object.js").JoinObject} */
53
+ const result = {};
54
+ for (const [key, value] of Object.entries(join)) {
55
+ if (value === true || value === false) {
56
+ const existing = result[key];
57
+ result[key] = mergeJoinValue(existing, value);
58
+ continue;
59
+ }
60
+ if (typeof value == "string" || Array.isArray(value) || isPlainObject(value)) {
61
+ const existing = result[key];
62
+ result[key] = mergeJoinValue(existing, normalizeJoinObject(value));
63
+ continue;
64
+ }
65
+ throw new Error(`Invalid join value for ${key}: ${typeof value}`);
66
+ }
67
+ return result;
68
+ }
69
+ /**
70
+ * @param {import("./join-object.js").JoinObject[string] | undefined} existing - Existing normalized join value.
71
+ * @param {import("./join-object.js").JoinObject[string]} incoming - Incoming normalized join value.
72
+ * @returns {import("./join-object.js").JoinObject[string]} - Merged join value.
73
+ */
74
+ function mergeJoinValue(existing, incoming) {
75
+ if (!existing)
76
+ return incoming;
77
+ if (existing === true || incoming === true)
78
+ return true;
79
+ if (typeof existing == "object" && typeof incoming == "object") {
80
+ return { ...existing, ...incoming };
81
+ }
82
+ return incoming;
83
+ }
18
84
  /**
19
85
  * @typedef {object} QueryArgsType
20
86
  * @property {import("../drivers/base.js").default | (() => import("../drivers/base.js").default)} driver - Driver instance or factory for query execution.
@@ -114,15 +180,18 @@ export default class VelociousDatabaseQuery {
114
180
  return this;
115
181
  }
116
182
  /**
117
- * @param {string | import("./join-object.js").JoinObject} join - Join clause or join descriptor.
183
+ * @param {string | string[] | import("./join-object.js").JoinObjectInput} join - Join clause or join descriptor.
118
184
  * @returns {this} - The joins.
119
185
  */
120
186
  joins(join) {
121
187
  if (typeof join == "string") {
122
188
  this._joins.push(new JoinPlain(join));
123
189
  }
190
+ else if (Array.isArray(join)) {
191
+ this._joins.push(new JoinObject(normalizeJoinObject(join)));
192
+ }
124
193
  else if (isPlainObject(join)) {
125
- this._joins.push(new JoinObject(join));
194
+ this._joins.push(new JoinObject(normalizeJoinObject(join)));
126
195
  }
127
196
  else {
128
197
  throw new Error(`Unknown type of join: ${typeof join}`);
@@ -286,4 +355,4 @@ export default class VelociousDatabaseQuery {
286
355
  return this._driverFn();
287
356
  }
288
357
  }
289
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/database/query/index.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport FromPlain from \"./from-plain.js\"\nimport {isPlainObject} from \"is-plain-object\"\nimport JoinObject from \"./join-object.js\"\nimport JoinPlain from \"./join-plain.js\"\nimport {Logger} from \"../../logger.js\"\nimport OrderPlain from \"./order-plain.js\"\nimport SelectBase from \"./select-base.js\"\nimport SelectPlain from \"./select-plain.js\"\nimport WhereHash from \"./where-hash.js\"\nimport WhereNot from \"./where-not.js\"\nimport WherePlain from \"./where-plain.js\"\n\n/**\n * @typedef {{[key: string]: boolean | NestedPreloadRecord }} NestedPreloadRecord\n * @typedef {string | string[] | import(\"./select-base.js\").default | import(\"./select-base.js\").default[]} SelectArgumentType\n * @typedef {object | string} WhereArgumentType\n */\n\n/**\n * @typedef {object} QueryArgsType\n * @property {import(\"../drivers/base.js\").default | (() => import(\"../drivers/base.js\").default)} driver - Driver instance or factory for query execution.\n * @property {Array<import(\"./from-base.js\").default>} [froms] - FROM clauses for the query.\n * @property {string[]} [groups] - GROUP BY columns.\n * @property {Array<import(\"./join-base.js\").default>} [joins] - JOIN clauses for the query.\n * @property {import(\"../handler.js\").default} handler - Handler used for executing and transforming results.\n * @property {number | null} [limit] - LIMIT clause value.\n * @property {number | null} [offset] - OFFSET clause value.\n * @property {Array<import(\"./order-base.js\").default>} [orders] - ORDER BY clauses.\n * @property {number | null} [page] - Page number for pagination.\n * @property {number} [perPage] - Records per page for pagination.\n * @property {NestedPreloadRecord} [preload] - Preload graph for related records.\n * @property {Array<import(\"./select-base.js\").default>} [selects] - SELECT clauses for the query.\n * @property {boolean} [distinct] - Whether the query should use DISTINCT.\n * @property {Array<import(\"./where-base.js\").default>} [wheres] - WHERE conditions for the query.\n */\n\nexport default class VelociousDatabaseQuery {\n  /**\n   * @param {QueryArgsType} args - Options object.\n   */\n  constructor({\n    driver,\n    froms = [],\n    groups = [],\n    joins = [],\n    handler,\n    limit = null,\n    offset = null,\n    orders = [],\n    page = null,\n    perPage,\n    preload = {},\n    distinct = false,\n    selects = [],\n    wheres = []\n  }) {\n    if (!driver) throw new Error(\"No driver given to query\")\n    if (!handler) throw new Error(\"No handler given to query\")\n\n    /** @type {() => import(\"../drivers/base.js\").default} */\n    this._driverFn = typeof driver === \"function\" ? driver : () => driver\n    this.handler = handler\n    this.logger = new Logger(this)\n    this._froms = froms\n    this._groups = groups\n    this._joins = joins\n    this._limit = limit\n    this._offset = offset\n    this._orders = orders\n    this._page = page\n    this._perPage = perPage\n    this._preload = preload\n    this._distinct = distinct\n    this._selects = selects\n\n    /** @type {import(\"./where-base.js\").default[]} */\n    this._wheres = wheres\n\n    const boundWhere = this.where.bind(this)\n    boundWhere.not = this.whereNot.bind(this)\n    this.where = boundWhere\n  }\n\n  /** @returns {this} - The clone.  */\n  clone() {\n    const QueryClass = /** @type {new (args: QueryArgsType) => this} */ (this.constructor)\n    const newQuery = new QueryClass({\n      driver: this._driverFn,\n      froms: [...this._froms],\n      handler: this.handler.clone(),\n      groups: [...this._groups],\n      joins: [...this._joins],\n      limit: this._limit,\n      offset: this._offset,\n      orders: [...this._orders],\n      page: this._page,\n      perPage: this._perPage,\n      preload: {...this._preload},\n      distinct: this._distinct,\n      selects: [...this._selects],\n      wheres: [...this._wheres]\n    })\n\n    return newQuery\n  }\n\n  /** @returns {import(\"./from-base.js\").default[]} - The froms.  */\n  getFroms() {\n    return this._froms\n  }\n\n  /** @returns {string[]} - The groups.  */\n  getGroups() {\n    return this._groups\n  }\n\n  /** @returns {import(\"../query-parser/options.js\").default} - The options options.  */\n  getOptions() { return this.driver.options() }\n\n  /** @returns {Array<import(\"./select-base.js\").default>} - The selects.  */\n  getSelects() { return this._selects }\n\n  /**\n   * @param {string|import(\"./from-base.js\").default} from - From.\n   * @returns {this} - The from.\n   */\n  from(from) {\n    if (typeof from == \"string\") from = new FromPlain(from)\n\n    this._froms.push(from)\n    return this\n  }\n\n  /**\n   * @param {string} group - Group.\n   * @returns {this} - The group.\n   */\n  group(group) {\n    this._groups.push(group)\n    return this\n  }\n\n  /**\n   * @param {string | import(\"./join-object.js\").JoinObject} join - Join clause or join descriptor.\n   * @returns {this} - The joins.\n   */\n  joins(join) {\n    if (typeof join == \"string\") {\n      this._joins.push(new JoinPlain(join))\n    } else if (isPlainObject(join)) {\n      this._joins.push(new JoinObject(join))\n    } else {\n      throw new Error(`Unknown type of join: ${typeof join}`)\n    }\n\n    return this\n  }\n\n  /**\n   * @param {number} value - Value to use.\n   * @returns {this} - The limit.\n   */\n  limit(value) {\n    this._limit = value\n    return this\n  }\n\n  /**\n   * @param {number} value - Value to use.\n   * @returns {this} - The offset.\n   */\n  offset(value) {\n    this._offset = value\n    return this\n  }\n\n  /**\n   * @param {string | number} order - Order.\n   * @returns {this} - The order.\n   */\n  order(order) {\n    if (typeof order == \"string\") {\n      this._orders.push(new OrderPlain(this, order))\n    } else if (typeof order == \"number\") {\n      this._orders.push(new OrderPlain(this, `${order}`))\n    } else {\n      throw new Error(`Unknown order type: ${typeof order}`)\n    }\n\n    return this\n  }\n\n  /**\n   * @param {number} pageNumber - Page number.\n   * @returns {this} - The page.\n   */\n  page(pageNumber) {\n    const perPage = this._perPage || 30\n    const offset = (pageNumber - 1) * perPage\n    const limit = perPage\n\n    this._page = pageNumber\n    this.limit(limit)\n    this.offset(offset)\n    return this\n  }\n\n  /**\n   * @param {number} perPage - Page size.\n   * @returns {this} - The per page.\n   */\n  perPage(perPage) {\n    this._perPage = perPage\n    return this\n  }\n\n  /**\n   * @param {string | number} order - Order.\n   * @returns {this} - The reorder.\n   */\n  reorder(order) {\n    this._orders = []\n    this.order(order)\n    return this\n  }\n\n  /** @returns {this} - The reverse order.  */\n  reverseOrder() {\n    for (const order of this._orders) {\n      order.setReverseOrder(true)\n    }\n\n    return this\n  }\n\n  /**\n   * @param {boolean} [value] - Value to use.\n   * @returns {this} - The distinct.\n   */\n  distinct(value = true) {\n    this._distinct = value\n    return this\n  }\n\n  /**\n   * @param {SelectArgumentType} select - Select.\n   * @returns {this} - The select.\n   */\n  select(select) {\n    if (Array.isArray(select)) {\n      for (const selectInArray of select) {\n        this.select(selectInArray)\n      }\n\n      return this\n    }\n\n    if (typeof select == \"string\") {\n      this._selects.push(new SelectPlain(select))\n    } else if (select instanceof SelectBase) {\n      this._selects.push(select)\n    } else {\n      throw new Error(`Invalid select type: ${typeof select}`)\n    }\n\n    return this\n  }\n\n  /**\n   * @returns {Promise<Array<object>>} Array of results from the database\n   */\n  async _executeQuery() {\n    const sql = this.toSql()\n    const results = await this.driver.query(sql)\n\n    this.logger.debug(() => [\"SQL:\", sql])\n\n    return results\n  }\n\n  /** @returns {Promise<Array<object>>} Array of results from the database */\n  async results() {\n    return await this._executeQuery()\n  }\n\n  /**\n   * Generates SQL string representing this query\n   * @returns {string} SQL string representing this query\n   */\n  toSql() { return this.driver.queryToSql(this) }\n\n  /**\n   * @param {WhereArgumentType} where - Where.\n   * @returns {this} This query instance\n   */\n  where(where) {\n    if (typeof where == \"string\") {\n      this._wheres.push(new WherePlain(this, where))\n    } else if (typeof where == \"object\" && (where.constructor.name == \"object\" || where.constructor.name == \"Object\")) {\n      this._wheres.push(new WhereHash(this, where))\n    } else {\n      throw new Error(`Invalid type of where: ${typeof where} (${where.constructor.name})`)\n    }\n\n    return this\n  }\n\n  /**\n   * @param {WhereArgumentType} where - Where.\n   * @returns {this} This query instance\n   */\n  whereNot(where) {\n    if (typeof where == \"string\") {\n      this._wheres.push(new WhereNot(new WherePlain(this, where)))\n    } else if (typeof where == \"object\" && (where.constructor.name == \"object\" || where.constructor.name == \"Object\")) {\n      this._wheres.push(new WhereNot(new WhereHash(this, where)))\n    } else {\n      throw new Error(`Invalid type of where: ${typeof where} (${where.constructor.name})`)\n    }\n\n    return this\n  }\n\n  /**\n   * Resolves the current driver lazily.\n   * @returns {import(\"../drivers/base.js\").default} - A value.\n   */\n  get driver() {\n    return this._driverFn()\n  }\n}\n"]}
358
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/database/query/index.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport FromPlain from \"./from-plain.js\"\nimport {isPlainObject} from \"is-plain-object\"\nimport JoinObject from \"./join-object.js\"\nimport JoinPlain from \"./join-plain.js\"\nimport {Logger} from \"../../logger.js\"\nimport OrderPlain from \"./order-plain.js\"\nimport SelectBase from \"./select-base.js\"\nimport SelectPlain from \"./select-plain.js\"\nimport WhereHash from \"./where-hash.js\"\nimport WhereNot from \"./where-not.js\"\nimport WherePlain from \"./where-plain.js\"\n\n/**\n * @typedef {{[key: string]: boolean | string | string[] | NestedPreloadRecord }} NestedPreloadRecord\n * @typedef {string | string[] | import(\"./select-base.js\").default | import(\"./select-base.js\").default[]} SelectArgumentType\n * @typedef {object | string} WhereArgumentType\n */\n\n/**\n * @param {import(\"./join-object.js\").JoinObjectInput | string | string[]} join - Join data in shorthand or nested form.\n * @returns {import(\"./join-object.js\").JoinObject} - Normalized join record.\n */\nfunction normalizeJoinObject(join) {\n  if (!join) return {}\n\n  if (typeof join == \"string\") {\n    return {[join]: true}\n  }\n\n  if (Array.isArray(join)) {\n    /** @type {import(\"./join-object.js\").JoinObject} */\n    const result = {}\n\n    for (const entry of join) {\n      if (typeof entry == \"string\") {\n        const existing = result[entry]\n        result[entry] = mergeJoinValue(existing, true)\n        continue\n      }\n\n      if (isPlainObject(entry)) {\n        const normalized = normalizeJoinObject(entry)\n\n        for (const [key, value] of Object.entries(normalized)) {\n          const existing = result[key]\n          result[key] = mergeJoinValue(existing, value)\n        }\n        continue\n      }\n\n      throw new Error(`Invalid join entry type: ${typeof entry}`)\n    }\n\n    return result\n  }\n\n  if (!isPlainObject(join)) {\n    throw new Error(`Invalid join type: ${typeof join}`)\n  }\n\n  /** @type {import(\"./join-object.js\").JoinObject} */\n  const result = {}\n\n  for (const [key, value] of Object.entries(join)) {\n    if (value === true || value === false) {\n      const existing = result[key]\n      result[key] = mergeJoinValue(existing, value)\n      continue\n    }\n\n    if (typeof value == \"string\" || Array.isArray(value) || isPlainObject(value)) {\n      const existing = result[key]\n      result[key] = mergeJoinValue(existing, normalizeJoinObject(value))\n      continue\n    }\n\n    throw new Error(`Invalid join value for ${key}: ${typeof value}`)\n  }\n\n  return result\n}\n\n/**\n * @param {import(\"./join-object.js\").JoinObject[string] | undefined} existing - Existing normalized join value.\n * @param {import(\"./join-object.js\").JoinObject[string]} incoming - Incoming normalized join value.\n * @returns {import(\"./join-object.js\").JoinObject[string]} - Merged join value.\n */\nfunction mergeJoinValue(existing, incoming) {\n  if (!existing) return incoming\n  if (existing === true || incoming === true) return true\n\n  if (typeof existing == \"object\" && typeof incoming == \"object\") {\n    return {...existing, ...incoming}\n  }\n\n  return incoming\n}\n\n/**\n * @typedef {object} QueryArgsType\n * @property {import(\"../drivers/base.js\").default | (() => import(\"../drivers/base.js\").default)} driver - Driver instance or factory for query execution.\n * @property {Array<import(\"./from-base.js\").default>} [froms] - FROM clauses for the query.\n * @property {string[]} [groups] - GROUP BY columns.\n * @property {Array<import(\"./join-base.js\").default>} [joins] - JOIN clauses for the query.\n * @property {import(\"../handler.js\").default} handler - Handler used for executing and transforming results.\n * @property {number | null} [limit] - LIMIT clause value.\n * @property {number | null} [offset] - OFFSET clause value.\n * @property {Array<import(\"./order-base.js\").default>} [orders] - ORDER BY clauses.\n * @property {number | null} [page] - Page number for pagination.\n * @property {number} [perPage] - Records per page for pagination.\n * @property {NestedPreloadRecord} [preload] - Preload graph for related records.\n * @property {Array<import(\"./select-base.js\").default>} [selects] - SELECT clauses for the query.\n * @property {boolean} [distinct] - Whether the query should use DISTINCT.\n * @property {Array<import(\"./where-base.js\").default>} [wheres] - WHERE conditions for the query.\n */\n\nexport default class VelociousDatabaseQuery {\n  /**\n   * @param {QueryArgsType} args - Options object.\n   */\n  constructor({\n    driver,\n    froms = [],\n    groups = [],\n    joins = [],\n    handler,\n    limit = null,\n    offset = null,\n    orders = [],\n    page = null,\n    perPage,\n    preload = {},\n    distinct = false,\n    selects = [],\n    wheres = []\n  }) {\n    if (!driver) throw new Error(\"No driver given to query\")\n    if (!handler) throw new Error(\"No handler given to query\")\n\n    /** @type {() => import(\"../drivers/base.js\").default} */\n    this._driverFn = typeof driver === \"function\" ? driver : () => driver\n    this.handler = handler\n    this.logger = new Logger(this)\n    this._froms = froms\n    this._groups = groups\n    this._joins = joins\n    this._limit = limit\n    this._offset = offset\n    this._orders = orders\n    this._page = page\n    this._perPage = perPage\n    this._preload = preload\n    this._distinct = distinct\n    this._selects = selects\n\n    /** @type {import(\"./where-base.js\").default[]} */\n    this._wheres = wheres\n\n    const boundWhere = this.where.bind(this)\n    boundWhere.not = this.whereNot.bind(this)\n    this.where = boundWhere\n  }\n\n  /** @returns {this} - The clone.  */\n  clone() {\n    const QueryClass = /** @type {new (args: QueryArgsType) => this} */ (this.constructor)\n    const newQuery = new QueryClass({\n      driver: this._driverFn,\n      froms: [...this._froms],\n      handler: this.handler.clone(),\n      groups: [...this._groups],\n      joins: [...this._joins],\n      limit: this._limit,\n      offset: this._offset,\n      orders: [...this._orders],\n      page: this._page,\n      perPage: this._perPage,\n      preload: {...this._preload},\n      distinct: this._distinct,\n      selects: [...this._selects],\n      wheres: [...this._wheres]\n    })\n\n    return newQuery\n  }\n\n  /** @returns {import(\"./from-base.js\").default[]} - The froms.  */\n  getFroms() {\n    return this._froms\n  }\n\n  /** @returns {string[]} - The groups.  */\n  getGroups() {\n    return this._groups\n  }\n\n  /** @returns {import(\"../query-parser/options.js\").default} - The options options.  */\n  getOptions() { return this.driver.options() }\n\n  /** @returns {Array<import(\"./select-base.js\").default>} - The selects.  */\n  getSelects() { return this._selects }\n\n  /**\n   * @param {string|import(\"./from-base.js\").default} from - From.\n   * @returns {this} - The from.\n   */\n  from(from) {\n    if (typeof from == \"string\") from = new FromPlain(from)\n\n    this._froms.push(from)\n    return this\n  }\n\n  /**\n   * @param {string} group - Group.\n   * @returns {this} - The group.\n   */\n  group(group) {\n    this._groups.push(group)\n    return this\n  }\n\n  /**\n   * @param {string | string[] | import(\"./join-object.js\").JoinObjectInput} join - Join clause or join descriptor.\n   * @returns {this} - The joins.\n   */\n  joins(join) {\n    if (typeof join == \"string\") {\n      this._joins.push(new JoinPlain(join))\n    } else if (Array.isArray(join)) {\n      this._joins.push(new JoinObject(normalizeJoinObject(join)))\n    } else if (isPlainObject(join)) {\n      this._joins.push(new JoinObject(normalizeJoinObject(join)))\n    } else {\n      throw new Error(`Unknown type of join: ${typeof join}`)\n    }\n\n    return this\n  }\n\n  /**\n   * @param {number} value - Value to use.\n   * @returns {this} - The limit.\n   */\n  limit(value) {\n    this._limit = value\n    return this\n  }\n\n  /**\n   * @param {number} value - Value to use.\n   * @returns {this} - The offset.\n   */\n  offset(value) {\n    this._offset = value\n    return this\n  }\n\n  /**\n   * @param {string | number} order - Order.\n   * @returns {this} - The order.\n   */\n  order(order) {\n    if (typeof order == \"string\") {\n      this._orders.push(new OrderPlain(this, order))\n    } else if (typeof order == \"number\") {\n      this._orders.push(new OrderPlain(this, `${order}`))\n    } else {\n      throw new Error(`Unknown order type: ${typeof order}`)\n    }\n\n    return this\n  }\n\n  /**\n   * @param {number} pageNumber - Page number.\n   * @returns {this} - The page.\n   */\n  page(pageNumber) {\n    const perPage = this._perPage || 30\n    const offset = (pageNumber - 1) * perPage\n    const limit = perPage\n\n    this._page = pageNumber\n    this.limit(limit)\n    this.offset(offset)\n    return this\n  }\n\n  /**\n   * @param {number} perPage - Page size.\n   * @returns {this} - The per page.\n   */\n  perPage(perPage) {\n    this._perPage = perPage\n    return this\n  }\n\n  /**\n   * @param {string | number} order - Order.\n   * @returns {this} - The reorder.\n   */\n  reorder(order) {\n    this._orders = []\n    this.order(order)\n    return this\n  }\n\n  /** @returns {this} - The reverse order.  */\n  reverseOrder() {\n    for (const order of this._orders) {\n      order.setReverseOrder(true)\n    }\n\n    return this\n  }\n\n  /**\n   * @param {boolean} [value] - Value to use.\n   * @returns {this} - The distinct.\n   */\n  distinct(value = true) {\n    this._distinct = value\n    return this\n  }\n\n  /**\n   * @param {SelectArgumentType} select - Select.\n   * @returns {this} - The select.\n   */\n  select(select) {\n    if (Array.isArray(select)) {\n      for (const selectInArray of select) {\n        this.select(selectInArray)\n      }\n\n      return this\n    }\n\n    if (typeof select == \"string\") {\n      this._selects.push(new SelectPlain(select))\n    } else if (select instanceof SelectBase) {\n      this._selects.push(select)\n    } else {\n      throw new Error(`Invalid select type: ${typeof select}`)\n    }\n\n    return this\n  }\n\n  /**\n   * @returns {Promise<Array<object>>} Array of results from the database\n   */\n  async _executeQuery() {\n    const sql = this.toSql()\n    const results = await this.driver.query(sql)\n\n    this.logger.debug(() => [\"SQL:\", sql])\n\n    return results\n  }\n\n  /** @returns {Promise<Array<object>>} Array of results from the database */\n  async results() {\n    return await this._executeQuery()\n  }\n\n  /**\n   * Generates SQL string representing this query\n   * @returns {string} SQL string representing this query\n   */\n  toSql() { return this.driver.queryToSql(this) }\n\n  /**\n   * @param {WhereArgumentType} where - Where.\n   * @returns {this} This query instance\n   */\n  where(where) {\n    if (typeof where == \"string\") {\n      this._wheres.push(new WherePlain(this, where))\n    } else if (typeof where == \"object\" && (where.constructor.name == \"object\" || where.constructor.name == \"Object\")) {\n      this._wheres.push(new WhereHash(this, where))\n    } else {\n      throw new Error(`Invalid type of where: ${typeof where} (${where.constructor.name})`)\n    }\n\n    return this\n  }\n\n  /**\n   * @param {WhereArgumentType} where - Where.\n   * @returns {this} This query instance\n   */\n  whereNot(where) {\n    if (typeof where == \"string\") {\n      this._wheres.push(new WhereNot(new WherePlain(this, where)))\n    } else if (typeof where == \"object\" && (where.constructor.name == \"object\" || where.constructor.name == \"Object\")) {\n      this._wheres.push(new WhereNot(new WhereHash(this, where)))\n    } else {\n      throw new Error(`Invalid type of where: ${typeof where} (${where.constructor.name})`)\n    }\n\n    return this\n  }\n\n  /**\n   * Resolves the current driver lazily.\n   * @returns {import(\"../drivers/base.js\").default} - A value.\n   */\n  get driver() {\n    return this._driverFn()\n  }\n}\n"]}
@@ -1,4 +1,5 @@
1
1
  /**
2
+ * @typedef {{[key: string]: boolean | string | string[] | JoinObjectInput}} JoinObjectInput
2
3
  * @typedef {{[key: string]: boolean | JoinObject}} JoinObject
3
4
  */
4
5
  export default class VelociousDatabaseQueryJoinObject extends JoinBase {
@@ -40,6 +41,9 @@ export default class VelociousDatabaseQueryJoinObject extends JoinBase {
40
41
  */
41
42
  _scopeSqlForWhere(where: import("./where-base.js").default, targetTableRef: string): string;
42
43
  }
44
+ export type JoinObjectInput = {
45
+ [key: string]: boolean | string | string[] | JoinObjectInput;
46
+ };
43
47
  export type JoinObject = {
44
48
  [key: string]: boolean | JoinObject;
45
49
  };
@@ -1 +1 @@
1
- {"version":3,"file":"join-object.d.ts","sourceRoot":"","sources":["../../../../src/database/query/join-object.js"],"names":[],"mappings":"AAMA;;GAEG;AAEH;IACE;;OAEG;IACH,oBAFW,UAAU,EAKpB;IADC,mBAAoB;IAGtB,gBAaC;IAED;;;;;;;OAOG;IACH,iBAPW,UAAU,cACV,cAAc,oBAAoB,EAAE,OAAO,OAC3C,MAAM,cACN,MAAM,QACN,MAAM,EAAE,GACN,MAAM,CAmDlB;IAED;;;;;;;;OAQG;IACH,+EAPG;QAAgE,YAAY,EAApE,OAAO,iCAAiC,EAAE,OAAO;QACF,KAAK,EAApD,6CAAwC;QACU,gBAAgB,EAAlE,cAAc,oBAAoB,EAAE,OAAO;QAC5B,QAAQ,EAAvB,MAAM,EAAE;QACK,cAAc,EAA3B,MAAM;KACd,GAAU,MAAM,CAkBlB;IAED;;;;OAIG;IACH,yBAJW,OAAO,iBAAiB,EAAE,OAAO,kBACjC,MAAM,GACJ,MAAM,CAuBlB;CACF;yBA5IY;IAAC,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,GAAG,UAAU,CAAA;CAAC;qBAL7B,gBAAgB"}
1
+ {"version":3,"file":"join-object.d.ts","sourceRoot":"","sources":["../../../../src/database/query/join-object.js"],"names":[],"mappings":"AAMA;;;GAGG;AAEH;IACE;;OAEG;IACH,oBAFW,UAAU,EAKpB;IADC,mBAAoB;IAGtB,gBAaC;IAED;;;;;;;OAOG;IACH,iBAPW,UAAU,cACV,cAAc,oBAAoB,EAAE,OAAO,OAC3C,MAAM,cACN,MAAM,QACN,MAAM,EAAE,GACN,MAAM,CAmDlB;IAED;;;;;;;;OAQG;IACH,+EAPG;QAAgE,YAAY,EAApE,OAAO,iCAAiC,EAAE,OAAO;QACF,KAAK,EAApD,6CAAwC;QACU,gBAAgB,EAAlE,cAAc,oBAAoB,EAAE,OAAO;QAC5B,QAAQ,EAAvB,MAAM,EAAE;QACK,cAAc,EAA3B,MAAM;KACd,GAAU,MAAM,CAkBlB;IAED;;;;OAIG;IACH,yBAJW,OAAO,iBAAiB,EAAE,OAAO,kBACjC,MAAM,GACJ,MAAM,CAuBlB;CACF;8BA7IY;IAAC,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,GAAG,MAAM,GAAG,MAAM,EAAE,GAAG,eAAe,CAAA;CAAC;yBAC9D;IAAC,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,GAAG,UAAU,CAAA;CAAC;qBAN7B,gBAAgB"}
@@ -3,6 +3,7 @@ import JoinBase from "./join-base.js";
3
3
  import WhereHash from "./where-hash.js";
4
4
  import WhereNot from "./where-not.js";
5
5
  /**
6
+ * @typedef {{[key: string]: boolean | string | string[] | JoinObjectInput}} JoinObjectInput
6
7
  * @typedef {{[key: string]: boolean | JoinObject}} JoinObject
7
8
  */
8
9
  export default class VelociousDatabaseQueryJoinObject extends JoinBase {
@@ -123,4 +124,4 @@ export default class VelociousDatabaseQueryJoinObject extends JoinBase {
123
124
  return where.toSql();
124
125
  }
125
126
  }
126
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"join-object.js","sourceRoot":"","sources":["../../../../src/database/query/join-object.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport JoinBase from \"./join-base.js\"\nimport WhereHash from \"./where-hash.js\"\nimport WhereNot from \"./where-not.js\"\n\n/**\n * @typedef {{[key: string]: boolean | JoinObject}} JoinObject\n */\n\nexport default class VelociousDatabaseQueryJoinObject extends JoinBase {\n  /**\n   * @param {JoinObject} object - Object.\n   */\n  constructor(object) {\n    super()\n    this.object = object\n  }\n\n  toSql() {\n    const query = this.getQuery()\n\n    if (query.constructor.name != \"VelociousDatabaseQueryModelClassQuery\") {\n      throw new Error(`Query has to be a ModelClassQuery but was a ${query.constructor.name}`)\n    }\n\n    // @ts-expect-error\n    const ModelClass = /** @type {typeof import(\"../record/index.js\").default} */ (query.modelClass)\n\n    const modelQuery = /** @type {import(\"./model-class-query.js\").default} */ (query)\n\n    return this.joinObject(this.object, ModelClass, \"\", 0, modelQuery.getJoinBasePath())\n  }\n\n  /**\n   * @param {JoinObject} join - Join.\n   * @param {typeof import(\"../record/index.js\").default} modelClass - Model class.\n   * @param {string} sql - SQL string.\n   * @param {number} joinsCount - Joins count.\n   * @param {string[]} path - Join path.\n   * @returns {string} - The join object.\n   */\n  joinObject(join, modelClass, sql, joinsCount, path) {\n    const pretty = this.pretty\n    const conn = this.getQuery().driver\n    const query = /** @type {import(\"./model-class-query.js\").default} */ (this.getQuery())\n\n    for (const joinKey in join) {\n      const joinValue = join[joinKey]\n      const relationship = modelClass.getRelationshipByName(joinKey)\n      const targetModelClass = relationship.getTargetModelClass()\n      const joinPath = path.concat([joinKey])\n      const parentTableRef = query.getJoinTableReference(path)\n      const targetEntry = query._registerJoinPath(joinPath)\n      const targetTableRef = targetEntry.alias || targetEntry.tableName\n      const joinTableSql = targetEntry.alias\n        ? `${conn.quoteTable(targetEntry.tableName)} AS ${conn.quoteTable(targetEntry.alias)}`\n        : conn.quoteTable(targetEntry.tableName)\n\n      if (joinsCount > 0) {\n        if (pretty) {\n          sql += \"\\n\\n\"\n        } else {\n          sql += \" \"\n        }\n      }\n\n      sql += `LEFT JOIN ${joinTableSql} ON `\n\n      if (relationship.getType() == \"belongsTo\") {\n        sql += `${conn.quoteTable(targetTableRef)}.${conn.quoteColumn(relationship.getPrimaryKey())} = `\n        sql += `${conn.quoteTable(parentTableRef)}.${conn.quoteColumn(relationship.getForeignKey())}`\n      } else if (relationship.getType() == \"hasMany\" || relationship.getType() == \"hasOne\") {\n        sql += `${conn.quoteTable(targetTableRef)}.${conn.quoteColumn(relationship.getForeignKey())} = `\n        sql += `${conn.quoteTable(parentTableRef)}.${conn.quoteColumn(relationship.getPrimaryKey())}`\n      } else {\n        throw new Error(`Unknown relationship type: ${relationship.getType()}`)\n      }\n\n      const scopeSql = this._scopeSql({relationship, query, targetModelClass, joinPath, targetTableRef})\n\n      if (scopeSql) {\n        sql += ` AND ${scopeSql}`\n      }\n\n      if (typeof joinValue == \"object\") {\n        sql = this.joinObject(joinValue, targetModelClass, sql, joinsCount + 1, joinPath)\n      }\n    }\n\n    return sql\n  }\n\n  /**\n   * @param {object} args - Options object.\n   * @param {import(\"../record/relationships/base.js\").default} args.relationship - Relationship definition.\n   * @param {import(\"./model-class-query.js\").default} args.query - Model class query.\n   * @param {typeof import(\"../record/index.js\").default} args.targetModelClass - Target model class.\n   * @param {string[]} args.joinPath - Join path.\n   * @param {string} args.targetTableRef - Target table reference.\n   * @returns {string} - Scope SQL.\n   */\n  _scopeSql({relationship, query, targetModelClass, joinPath, targetTableRef}) {\n    if (!relationship.getScope()) return \"\"\n\n    const scopedQuery = query.buildJoinScopeQuery(targetModelClass, joinPath)\n    const appliedQuery = relationship.applyScope(scopedQuery) || scopedQuery\n    const wheres = appliedQuery._wheres\n\n    if (!wheres || wheres.length === 0) return \"\"\n\n    const parts = []\n\n    for (const where of wheres) {\n      parts.push(this._scopeSqlForWhere(where, targetTableRef))\n    }\n\n    return parts.join(\" AND \")\n  }\n\n  /**\n   * @param {import(\"./where-base.js\").default} where - Where.\n   * @param {string} targetTableRef - Target table reference.\n   * @returns {string} - Scope where SQL.\n   */\n  _scopeSqlForWhere(where, targetTableRef) {\n    if (where instanceof WhereHash) {\n      const hash = where.hash\n      const hasNested = Object.values(hash).some((value) => value !== null && typeof value === \"object\" && !Array.isArray(value))\n\n      return hasNested\n        ? where.toSql()\n        : `(${where._whereSQLFromHash(hash, targetTableRef)})`\n    }\n\n    if (where instanceof WhereNot && where.where instanceof WhereHash) {\n      const hash = where.where.hash\n      const hasNested = Object.values(hash).some((value) => value !== null && typeof value === \"object\" && !Array.isArray(value))\n      const innerSql = hasNested\n        ? where.where.toSql()\n        : `(${where.where._whereSQLFromHash(hash, targetTableRef)})`\n\n      return `NOT (${innerSql})`\n    }\n\n    return where.toSql()\n  }\n}\n"]}
127
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"join-object.js","sourceRoot":"","sources":["../../../../src/database/query/join-object.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport JoinBase from \"./join-base.js\"\nimport WhereHash from \"./where-hash.js\"\nimport WhereNot from \"./where-not.js\"\n\n/**\n * @typedef {{[key: string]: boolean | string | string[] | JoinObjectInput}} JoinObjectInput\n * @typedef {{[key: string]: boolean | JoinObject}} JoinObject\n */\n\nexport default class VelociousDatabaseQueryJoinObject extends JoinBase {\n  /**\n   * @param {JoinObject} object - Object.\n   */\n  constructor(object) {\n    super()\n    this.object = object\n  }\n\n  toSql() {\n    const query = this.getQuery()\n\n    if (query.constructor.name != \"VelociousDatabaseQueryModelClassQuery\") {\n      throw new Error(`Query has to be a ModelClassQuery but was a ${query.constructor.name}`)\n    }\n\n    // @ts-expect-error\n    const ModelClass = /** @type {typeof import(\"../record/index.js\").default} */ (query.modelClass)\n\n    const modelQuery = /** @type {import(\"./model-class-query.js\").default} */ (query)\n\n    return this.joinObject(this.object, ModelClass, \"\", 0, modelQuery.getJoinBasePath())\n  }\n\n  /**\n   * @param {JoinObject} join - Join.\n   * @param {typeof import(\"../record/index.js\").default} modelClass - Model class.\n   * @param {string} sql - SQL string.\n   * @param {number} joinsCount - Joins count.\n   * @param {string[]} path - Join path.\n   * @returns {string} - The join object.\n   */\n  joinObject(join, modelClass, sql, joinsCount, path) {\n    const pretty = this.pretty\n    const conn = this.getQuery().driver\n    const query = /** @type {import(\"./model-class-query.js\").default} */ (this.getQuery())\n\n    for (const joinKey in join) {\n      const joinValue = join[joinKey]\n      const relationship = modelClass.getRelationshipByName(joinKey)\n      const targetModelClass = relationship.getTargetModelClass()\n      const joinPath = path.concat([joinKey])\n      const parentTableRef = query.getJoinTableReference(path)\n      const targetEntry = query._registerJoinPath(joinPath)\n      const targetTableRef = targetEntry.alias || targetEntry.tableName\n      const joinTableSql = targetEntry.alias\n        ? `${conn.quoteTable(targetEntry.tableName)} AS ${conn.quoteTable(targetEntry.alias)}`\n        : conn.quoteTable(targetEntry.tableName)\n\n      if (joinsCount > 0) {\n        if (pretty) {\n          sql += \"\\n\\n\"\n        } else {\n          sql += \" \"\n        }\n      }\n\n      sql += `LEFT JOIN ${joinTableSql} ON `\n\n      if (relationship.getType() == \"belongsTo\") {\n        sql += `${conn.quoteTable(targetTableRef)}.${conn.quoteColumn(relationship.getPrimaryKey())} = `\n        sql += `${conn.quoteTable(parentTableRef)}.${conn.quoteColumn(relationship.getForeignKey())}`\n      } else if (relationship.getType() == \"hasMany\" || relationship.getType() == \"hasOne\") {\n        sql += `${conn.quoteTable(targetTableRef)}.${conn.quoteColumn(relationship.getForeignKey())} = `\n        sql += `${conn.quoteTable(parentTableRef)}.${conn.quoteColumn(relationship.getPrimaryKey())}`\n      } else {\n        throw new Error(`Unknown relationship type: ${relationship.getType()}`)\n      }\n\n      const scopeSql = this._scopeSql({relationship, query, targetModelClass, joinPath, targetTableRef})\n\n      if (scopeSql) {\n        sql += ` AND ${scopeSql}`\n      }\n\n      if (typeof joinValue == \"object\") {\n        sql = this.joinObject(joinValue, targetModelClass, sql, joinsCount + 1, joinPath)\n      }\n    }\n\n    return sql\n  }\n\n  /**\n   * @param {object} args - Options object.\n   * @param {import(\"../record/relationships/base.js\").default} args.relationship - Relationship definition.\n   * @param {import(\"./model-class-query.js\").default} args.query - Model class query.\n   * @param {typeof import(\"../record/index.js\").default} args.targetModelClass - Target model class.\n   * @param {string[]} args.joinPath - Join path.\n   * @param {string} args.targetTableRef - Target table reference.\n   * @returns {string} - Scope SQL.\n   */\n  _scopeSql({relationship, query, targetModelClass, joinPath, targetTableRef}) {\n    if (!relationship.getScope()) return \"\"\n\n    const scopedQuery = query.buildJoinScopeQuery(targetModelClass, joinPath)\n    const appliedQuery = relationship.applyScope(scopedQuery) || scopedQuery\n    const wheres = appliedQuery._wheres\n\n    if (!wheres || wheres.length === 0) return \"\"\n\n    const parts = []\n\n    for (const where of wheres) {\n      parts.push(this._scopeSqlForWhere(where, targetTableRef))\n    }\n\n    return parts.join(\" AND \")\n  }\n\n  /**\n   * @param {import(\"./where-base.js\").default} where - Where.\n   * @param {string} targetTableRef - Target table reference.\n   * @returns {string} - Scope where SQL.\n   */\n  _scopeSqlForWhere(where, targetTableRef) {\n    if (where instanceof WhereHash) {\n      const hash = where.hash\n      const hasNested = Object.values(hash).some((value) => value !== null && typeof value === \"object\" && !Array.isArray(value))\n\n      return hasNested\n        ? where.toSql()\n        : `(${where._whereSQLFromHash(hash, targetTableRef)})`\n    }\n\n    if (where instanceof WhereNot && where.where instanceof WhereHash) {\n      const hash = where.where.hash\n      const hasNested = Object.values(hash).some((value) => value !== null && typeof value === \"object\" && !Array.isArray(value))\n      const innerSql = hasNested\n        ? where.where.toSql()\n        : `(${where.where._whereSQLFromHash(hash, targetTableRef)})`\n\n      return `NOT (${innerSql})`\n    }\n\n    return where.toSql()\n  }\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"model-class-query.d.ts","sourceRoot":"","sources":["../../../../src/database/query/model-class-query.js"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"model-class-query.d.ts","sourceRoot":"","sources":["../../../../src/database/query/model-class-query.js"],"names":[],"mappings":"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"}
@@ -9,6 +9,50 @@ import JoinTracker from "./join-tracker.js";
9
9
  import RecordNotFoundError from "../record/record-not-found-error.js";
10
10
  import WhereModelClassHash from "./where-model-class-hash.js";
11
11
  import WhereNot from "./where-not.js";
12
+ /**
13
+ * @param {import("./index.js").NestedPreloadRecord | string | string[]} preload - Preload data in shorthand or nested form.
14
+ * @returns {import("./index.js").NestedPreloadRecord} - Normalized preload record.
15
+ */
16
+ function normalizePreloadRecord(preload) {
17
+ if (!preload)
18
+ return {};
19
+ if (typeof preload == "string") {
20
+ return { [preload]: true };
21
+ }
22
+ if (Array.isArray(preload)) {
23
+ /** @type {import("./index.js").NestedPreloadRecord} */
24
+ const result = {};
25
+ for (const entry of preload) {
26
+ if (typeof entry == "string") {
27
+ result[entry] = true;
28
+ continue;
29
+ }
30
+ if (isPlainObject(entry)) {
31
+ incorporate(result, normalizePreloadRecord(entry));
32
+ continue;
33
+ }
34
+ throw new Error(`Invalid preload entry type: ${typeof entry}`);
35
+ }
36
+ return result;
37
+ }
38
+ if (!isPlainObject(preload)) {
39
+ throw new Error(`Invalid preload type: ${typeof preload}`);
40
+ }
41
+ /** @type {import("./index.js").NestedPreloadRecord} */
42
+ const result = {};
43
+ for (const [key, value] of Object.entries(preload)) {
44
+ if (value === true || value === false) {
45
+ result[key] = value;
46
+ continue;
47
+ }
48
+ if (typeof value == "string" || Array.isArray(value) || isPlainObject(value)) {
49
+ result[key] = normalizePreloadRecord(value);
50
+ continue;
51
+ }
52
+ throw new Error(`Invalid preload value for ${key}: ${typeof value}`);
53
+ }
54
+ return result;
55
+ }
12
56
  /**
13
57
  * @template {typeof import("../record/index.js").default} MC
14
58
  */
@@ -289,7 +333,8 @@ export default class VelociousDatabaseQueryModelClassQuery extends DatabaseQuery
289
333
  * @returns {this} - The preload.
290
334
  */
291
335
  preload(data) {
292
- incorporate(this._preload, data);
336
+ const normalizedPreload = normalizePreloadRecord(data);
337
+ incorporate(this._preload, normalizedPreload);
293
338
  return this;
294
339
  }
295
340
  /**
@@ -492,4 +537,4 @@ function buildJoinObjectFromWhereHash({ hash, modelClass }) {
492
537
  }
493
538
  return joinObject;
494
539
  }
495
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"model-class-query.js","sourceRoot":"","sources":["../../../../src/database/query/model-class-query.js"],"names":[],"mappings":"AAAA,YAAY;AAEZ,OAAO,EAAC,WAAW,EAAC,MAAM,cAAc,CAAA;AACxC,OAAO,KAAK,UAAU,MAAM,YAAY,CAAA;AACxC,OAAO,EAAC,aAAa,EAAC,MAAM,iBAAiB,CAAA;AAC7C,OAAO,EAAC,MAAM,EAAC,MAAM,iBAAiB,CAAA;AACtC,OAAO,SAAS,MAAM,gBAAgB,CAAA;AACtC,OAAO,aAAa,MAAM,YAAY,CAAA;AACtC,OAAO,WAAW,MAAM,mBAAmB,CAAA;AAC3C,OAAO,mBAAmB,MAAM,qCAAqC,CAAA;AACrE,OAAO,mBAAmB,MAAM,6BAA6B,CAAA;AAC7D,OAAO,QAAQ,MAAM,gBAAgB,CAAA;AAErC;;GAEG;AACH;;;GAGG;AAEH;;;GAGG;AACH,MAAM,CAAC,OAAO,OAAO,qCAAsC,SAAQ,aAAa;IAC9E,+EAA+E;IAC/E,YAAY,IAAI;QACd,MAAM,EAAC,UAAU,EAAC,GAAG,IAAI,CAAA;QAEzB,IAAI,CAAC,UAAU;YAAE,MAAM,IAAI,KAAK,CAAC,0BAA0B,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;QAE1F,KAAK,CAAC,IAAI,CAAC,CAAA;QACX,IAAI,CAAC,MAAM,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,CAAA;QAE9B,iBAAiB;QACjB,IAAI,CAAC,UAAU,GAAG,UAAU,CAAA;QAE5B,uBAAuB;QACvB,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,YAAY,IAAI,EAAE,CAAA;QAC5C,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,WAAW,IAAI,IAAI,WAAW,CAAC,EAAC,UAAU,EAAE,IAAI,CAAC,UAAU,EAAC,CAAC,CAAA;QACtF,IAAI,CAAC,sBAAsB,GAAG,OAAO,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAA;IACnE,CAAC;IAED,oCAAoC;IACpC,KAAK;QACH,MAAM,QAAQ,GAAG,wDAAwD,CAAC,CAAC,IAAI,qCAAqC,CAAC;YACnH,MAAM,EAAE,IAAI,CAAC,SAAS;YACtB,KAAK,EAAE,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC;YACvB,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE;YAC7B,MAAM,EAAE,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC;YACzB,KAAK,EAAE,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC;YACvB,KAAK,EAAE,IAAI,CAAC,MAAM;YAClB,UAAU,EAAE,IAAI,CAAC,UAAU;YAC3B,MAAM,EAAE,IAAI,CAAC,OAAO;YACpB,MAAM,EAAE,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC;YACzB,IAAI,EAAE,IAAI,CAAC,KAAK;YAChB,OAAO,EAAE,IAAI,CAAC,QAAQ;YACtB,OAAO,EAAE,EAAC,GAAG,IAAI,CAAC,QAAQ,EAAC;YAC3B,QAAQ,EAAE,IAAI,CAAC,SAAS;YACxB,OAAO,EAAE,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC;YAC3B,MAAM,EAAE,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC;YACzB,YAAY,EAAE,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC;YACrC,WAAW,EAAE,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE;YACtC,qBAAqB,EAAE,IAAI,CAAC,sBAAsB;SACnD,CAAC,CAAC,CAAA;QAEH,mBAAmB;QACnB,OAAO,QAAQ,CAAA;IACjB,CAAC;IAED,6DAA6D;IAC7D,KAAK,CAAC,KAAK;QACT,qBAAqB;QACrB,MAAM,UAAU,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,SAAS,EAAE,CAAC,IAAI,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,UAAU,EAAE,CAAC,EAAE,CAAA;QAC9I,MAAM,cAAc,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,CAAA;QACxD,IAAI,GAAG,GAAG,SAAS,cAAc,GAAG,UAAU,GAAG,CAAA;QAEjD,IAAI,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,IAAI,OAAO;YAAE,GAAG,IAAI,OAAO,CAAA;QAEpD,GAAG,IAAI,WAAW,CAAA;QAGlB,gCAAgC;QAChC,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,EAAE,CAAA;QAE/B,UAAU,CAAC,SAAS,GAAG,KAAK,CAAA;QAC5B,UAAU,CAAC,QAAQ,GAAG,EAAE,CAAA;QACxB,UAAU,CAAC,MAAM,CAAC,GAAG,CAAC,CAAA;QAEtB,MAAM,OAAO,GAAG,gCAAgC,CAAC,CAAC,MAAM,UAAU,CAAC,aAAa,EAAE,CAAC,CAAA;QAEnF,6DAA6D;QAC7D,IAAI,OAAO,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;YACxB,OAAO,OAAO,CAAC,CAAC,CAAC,CAAC,KAAK,CAAA;QACzB,CAAC;QAED,iEAAiE;QACjE,IAAI,WAAW,GAAG,CAAC,CAAA;QAEnB,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;YAC7B,IAAI,CAAC,CAAC,OAAO,IAAI,MAAM,CAAC,EAAE,CAAC;gBACzB,MAAM,IAAI,KAAK,CAAC,sBAAsB,CAAC,CAAA;YACzC,CAAC;YAED,WAAW,IAAI,MAAM,CAAC,KAAK,CAAA;QAC7B,CAAC;QAED,OAAO,WAAW,CAAA;IACpB,CAAC;IAED,wCAAwC;IACxC,aAAa;QACX,IAAI,CAAC,IAAI,CAAC,UAAU;YAAE,MAAM,IAAI,KAAK,CAAC,oBAAoB,CAAC,CAAA;QAE3D,OAAO,IAAI,CAAC,UAAU,CAAA;IACxB,CAAC;IAED,gDAAgD;IAChD,eAAe;QACb,OAAO,IAAI,CAAC,aAAa,CAAA;IAC3B,CAAC;IAED,yEAAyE;IACzE,cAAc;QACZ,OAAO,IAAI,CAAC,YAAY,CAAA;IAC1B,CAAC;IAED,0DAA0D;IAC1D,wBAAwB;QACtB,OAAO,IAAI,CAAC,sBAAsB,CAAA;IACpC,CAAC;IAED;;;OAGG;IACH,eAAe,CAAC,YAAY;QAC1B,IAAI,CAAC,aAAa,GAAG,YAAY,CAAA;QACjC,OAAO,IAAI,CAAA;IACb,CAAC;IAED;;;OAGG;IACH,YAAY,CAAC,YAAY;QACvB,MAAM,WAAW,GAAG,wDAAwD,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAA;QAE3F,WAAW,CAAC,aAAa,GAAG,YAAY,CAAA;QACxC,WAAW,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,CAAA;QAE5C,OAAO,WAAW,CAAA;IACpB,CAAC;IAED;;;OAGG;IACH,4BAA4B,CAAC,IAAI;QAC/B,IAAI,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,iBAAiB,EAAE,CAAA;QAEtD,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO,UAAU,CAAC,SAAS,EAAE,CAAA;QAEpD,KAAK,MAAM,gBAAgB,IAAI,IAAI,EAAE,CAAC;YACpC,MAAM,YAAY,GAAG,UAAU,CAAC,qBAAqB,CAAC,gBAAgB,CAAC,CAAA;YACvE,MAAM,gBAAgB,GAAG,YAAY,CAAC,mBAAmB,EAAE,CAAA;YAE3D,IAAI,CAAC,gBAAgB,EAAE,CAAC;gBACtB,MAAM,IAAI,KAAK,CAAC,6BAA6B,UAAU,CAAC,IAAI,IAAI,gBAAgB,EAAE,CAAC,CAAA;YACrF,CAAC;YAED,UAAU,GAAG,gBAAgB,CAAA;QAC/B,CAAC;QAED,OAAO,UAAU,CAAC,SAAS,EAAE,CAAA;IAC/B,CAAC;IAED;;;OAGG;IACH,iBAAiB,CAAC,IAAI;QACpB,MAAM,SAAS,GAAG,IAAI,CAAC,4BAA4B,CAAC,IAAI,CAAC,CAAA;QAEzD,OAAO,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC,IAAI,EAAE,SAAS,CAAC,CAAA;IACxD,CAAC;IAED;;;OAGG;IACH,qBAAqB,CAAC,IAAI;QACxB,MAAM,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAA;QAE9E,OAAO,KAAK,CAAC,KAAK,IAAI,KAAK,CAAC,SAAS,CAAA;IACvC,CAAC;IAED;;;OAGG;IACH,wBAAwB,CAAC,GAAG,IAAI;QAC9B,MAAM,QAAQ,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,CAAA;QAEhD,OAAO,IAAI,CAAC,qBAAqB,CAAC,QAAQ,CAAC,CAAA;IAC7C,CAAC;IAED;;;OAGG;IACH,eAAe,CAAC,GAAG,IAAI;QACrB,OAAO,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,wBAAwB,CAAC,GAAG,IAAI,CAAC,CAAC,CAAA;IACvE,CAAC;IAED;;;;OAIG;IACH,mBAAmB,CAAC,gBAAgB,EAAE,QAAQ;QAC5C,MAAM,WAAW,GAAG,wDAAwD,CAAC,CAAC,gBAAgB,CAAC,SAAS,EAAE,CAAC,CAAA;QAE3G,WAAW,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,CAAA;QAC5C,WAAW,CAAC,aAAa,GAAG,QAAQ,CAAA;QACpC,WAAW,CAAC,sBAAsB,GAAG,IAAI,CAAA;QAEzC,OAAO,WAAW,CAAA;IACpB,CAAC;IAED,0DAA0D;IAC1D,KAAK,CAAC,UAAU;QACd,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,OAAO,EAAE,CAAA;QAEpC,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;YAC7B,MAAM,MAAM,CAAC,OAAO,EAAE,CAAA;QACxB,CAAC;IACH,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,IAAI,CAAC,QAAQ;QACjB,+CAA+C;QAC/C,MAAM,UAAU,GAAG,EAAE,CAAA;QAErB,UAAU,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,UAAU,EAAE,CAAC,GAAG,QAAQ,CAAA;QAExD,MAAM,QAAQ,GAAG,wDAAwD,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAA;QAExF,QAAQ,CAAC,KAAK,CAAC,UAAU,CAAC,CAAA;QAE1B,MAAM,MAAM,GAAG,CAAC,MAAM,QAAQ,CAAC,KAAK,EAAE,CAAC,CAAA;QAEvC,IAAI,CAAC,MAAM,EAAE,CAAC;YACZ,MAAM,IAAI,mBAAmB,CAAC,iBAAiB,IAAI,CAAC,aAAa,EAAE,CAAC,IAAI,UAAU,IAAI,CAAC,aAAa,EAAE,CAAC,UAAU,EAAE,KAAK,QAAQ,EAAE,CAAC,CAAA;QACrI,CAAC;QAED,OAAO,MAAM,CAAA;IACf,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,MAAM,CAAC,UAAU;QACrB,+CAA+C;QAC/C,MAAM,aAAa,GAAG,EAAE,CAAA;QAExB,KAAK,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;YAC7B,MAAM,aAAa,GAAG,UAAU,CAAC,UAAU,CAAC,GAAG,CAAC,CAAA;YAEhD,aAAa,CAAC,aAAa,CAAC,GAAG,UAAU,CAAC,GAAG,CAAC,CAAA;QAChD,CAAC;QAED,MAAM,QAAQ,GAAG,wDAAwD,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAA;QAExF,QAAQ,CAAC,KAAK,CAAC,aAAa,CAAC,CAAA;QAE7B,OAAO,MAAM,QAAQ,CAAC,KAAK,EAAE,CAAA;IAC/B,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,cAAc,CAAC,UAAU,EAAE,QAAQ;QACvC,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,kBAAkB,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAA;QAElE,IAAI,MAAM,CAAC,WAAW,EAAE,EAAE,CAAC;YACzB,MAAM,MAAM,CAAC,IAAI,EAAE,CAAA;QACrB,CAAC;QAED,OAAO,MAAM,CAAA;IACf,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,YAAY,CAAC,UAAU;QAC3B,+CAA+C;QAC/C,MAAM,aAAa,GAAG,EAAE,CAAA;QAExB,KAAK,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;YAC7B,MAAM,aAAa,GAAG,UAAU,CAAC,UAAU,CAAC,GAAG,CAAC,CAAA;YAEhD,aAAa,CAAC,aAAa,CAAC,GAAG,UAAU,CAAC,GAAG,CAAC,CAAA;QAChD,CAAC;QAED,MAAM,QAAQ,GAAG,wDAAwD,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAA;QAExF,QAAQ,CAAC,KAAK,CAAC,aAAa,CAAC,CAAA;QAE7B,MAAM,KAAK,GAAG,MAAM,QAAQ,CAAC,KAAK,EAAE,CAAA;QAEpC,IAAI,CAAC,KAAK,EAAE,CAAC;YACX,MAAM,IAAI,KAAK,CAAC,kBAAkB,CAAC,CAAA;QACrC,CAAC;QAED,OAAO,KAAK,CAAA;IACd,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,kBAAkB,CAAC,UAAU,EAAE,QAAQ;QAC3C,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAA;QAE5C,IAAI,MAAM;YAAE,OAAO,MAAM,CAAA;QAEzB,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,EAAE,CAAA;QACvC,MAAM,SAAS,GAAG,+BAA+B,CAAC,CAAC,IAAI,UAAU,CAAC,UAAU,CAAC,CAAC,CAAA;QAE9E,IAAI,QAAQ,EAAE,CAAC;YACb,QAAQ,CAAC,SAAS,CAAC,CAAA;QACrB,CAAC;QAED,OAAO,SAAS,CAAA;IAClB,CAAC;IAED,mFAAmF;IACnF,KAAK,CAAC,KAAK;QACT,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,SAAS,EAAE,CAAC,IAAI,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,eAAe,EAAE,CAAC,EAAE,CAAC,CAAA;QAChL,MAAM,OAAO,GAAG,MAAM,QAAQ,CAAC,OAAO,EAAE,CAAA;QAExC,OAAO,OAAO,CAAC,CAAC,CAAC,CAAA;IACnB,CAAC;IAED,kFAAkF;IAClF,KAAK,CAAC,IAAI;QACR,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC,UAAU,EAAE,CAAA;QACpD,MAAM,SAAS,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC,SAAS,EAAE,CAAA;QAClD,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,KAAK,EAAE,CAAC,OAAO,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,SAAS,CAAC,IAAI,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,OAAO,EAAE,CAAA;QAEjJ,OAAO,OAAO,CAAC,CAAC,CAAC,CAAA;IACnB,CAAC;IAED;;;OAGG;IACH,OAAO,CAAC,IAAI;QACV,WAAW,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAA;QAChC,OAAO,IAAI,CAAA;IACb,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,OAAO;QACX,MAAM,MAAM,GAAG,EAAE,CAAA;QACjB,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,OAAO,EAAE,CAAA;QAEpC,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;YAC7B,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,EAAE,CAAA;YACvC,MAAM,KAAK,GAAG,+BAA+B,CAAC,CAAC,IAAI,UAAU,EAAE,CAAC,CAAA;YAEhE,KAAK,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAA;YAChC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;QACpB,CAAC;QAED,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,MAAM,GAAG,CAAC,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC/D,MAAM,SAAS,GAAG,IAAI,SAAS,CAAC;gBAC9B,UAAU,EAAE,IAAI,CAAC,UAAU;gBAC3B,MAAM;gBACN,OAAO,EAAE,IAAI,CAAC,QAAQ;aACvB,CAAC,CAAA;YAEF,MAAM,SAAS,CAAC,GAAG,EAAE,CAAA;QACvB,CAAC;QAED,OAAO,MAAM,CAAA;IACf,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,KAAK,CAAC,GAAG,OAAO;QACpB,MAAM,WAAW,GAAG,OAAO,CAAC,IAAI,EAAE,CAAA;QAElC,IAAI,WAAW,CAAC,MAAM,KAAK,CAAC;YAAE,MAAM,IAAI,KAAK,CAAC,2BAA2B,CAAC,CAAA;QAE1E,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,EAAE,CAAA;QACvC,MAAM,SAAS,GAAG,UAAU,CAAC,SAAS,EAAE,CAAA;QACxC,MAAM,YAAY,GAAG,UAAU,CAAC,+BAA+B,EAAE,CAAA;QACjE,MAAM,WAAW,GAAG,WAAW,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,YAAY,CAAC,MAAM,CAAC,IAAI,MAAM,CAAC,CAAA;QAE/E,MAAM,KAAK,GAAG,wDAAwD,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAA;QAErF,KAAK,CAAC,QAAQ,GAAG,EAAE,CAAA;QACnB,KAAK,CAAC,QAAQ,GAAG,EAAE,CAAA;QAEnB,WAAW,CAAC,OAAO,CAAC,CAAC,UAAU,EAAE,EAAE;YACjC,MAAM,SAAS,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,SAAS,CAAC,IAAI,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,UAAU,CAAC,EAAE,CAAA;YAE/F,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,CAAA;QACzB,CAAC,CAAC,CAAA;QAEF,MAAM,IAAI,GAAG,MAAM,KAAK,CAAC,aAAa,EAAE,CAAA;QAExC,IAAI,WAAW,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC7B,MAAM,CAAC,UAAU,CAAC,GAAG,WAAW,CAAA;YAChC,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,CAAA;QAC3C,CAAC;QAED,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,UAAU,EAAE,EAAE,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,CAAA;IAC5E,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,KAAK;QACT,IAAI,OAAO,KAAK,IAAI,QAAQ,EAAE,CAAC;YAC7B,OAAO,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAA;QAC3B,CAAC;QAED,IAAI,aAAa,CAAC,KAAK,CAAC,EAAE,CAAC;YACzB,MAAM,EAAC,YAAY,EAAE,YAAY,EAAC,GAAG,cAAc,CAAC,EAAC,IAAI,EAAE,KAAK,EAAE,UAAU,EAAE,IAAI,CAAC,aAAa,EAAE,EAAC,CAAC,CAAA;YACpG,MAAM,UAAU,GAAG,4BAA4B,CAAC,EAAC,IAAI,EAAE,KAAK,EAAE,UAAU,EAAE,IAAI,CAAC,aAAa,EAAE,EAAC,CAAC,CAAA;YAEhG,IAAI,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBACvC,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAA;YACxB,CAAC;YAED,IAAI,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBACzC,MAAM,gBAAgB,GAAG,IAAI,CAAC,wBAAwB,EAAE,IAAI,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM,GAAG,CAAC,CAAA;gBAC9F,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,mBAAmB,CAAC;oBACxC,IAAI,EAAE,YAAY;oBAClB,UAAU,EAAE,IAAI,CAAC,aAAa,EAAE;oBAChC,gBAAgB;oBAChB,KAAK,EAAE,IAAI;iBACZ,CAAC,CAAC,CAAA;YACL,CAAC;YAED,IAAI,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBACzC,KAAK,CAAC,KAAK,CAAC,YAAY,CAAC,CAAA;YAC3B,CAAC;YAED,OAAO,IAAI,CAAA;QACb,CAAC;QAED,MAAM,IAAI,KAAK,CAAC,0BAA0B,OAAO,KAAK,KAAK,KAAK,CAAC,WAAW,CAAC,IAAI,GAAG,CAAC,CAAA;IACvF,CAAC;IAED;;;OAGG;IACH,QAAQ,CAAC,KAAK;QACZ,IAAI,OAAO,KAAK,IAAI,QAAQ,EAAE,CAAC;YAC7B,OAAO,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAA;QAC9B,CAAC;QAED,IAAI,aAAa,CAAC,KAAK,CAAC,EAAE,CAAC;YACzB,MAAM,EAAC,YAAY,EAAE,YAAY,EAAC,GAAG,cAAc,CAAC,EAAC,IAAI,EAAE,KAAK,EAAE,UAAU,EAAE,IAAI,CAAC,aAAa,EAAE,EAAC,CAAC,CAAA;YACpG,MAAM,UAAU,GAAG,4BAA4B,CAAC,EAAC,IAAI,EAAE,KAAK,EAAE,UAAU,EAAE,IAAI,CAAC,aAAa,EAAE,EAAC,CAAC,CAAA;YAEhG,IAAI,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBACvC,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAA;YACxB,CAAC;YAED,IAAI,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBACzC,MAAM,gBAAgB,GAAG,IAAI,CAAC,wBAAwB,EAAE,IAAI,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM,GAAG,CAAC,CAAA;gBAC9F,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,QAAQ,CAAC,IAAI,mBAAmB,CAAC;oBACrD,IAAI,EAAE,YAAY;oBAClB,UAAU,EAAE,IAAI,CAAC,aAAa,EAAE;oBAChC,gBAAgB;oBAChB,KAAK,EAAE,IAAI;iBACZ,CAAC,CAAC,CAAC,CAAA;YACN,CAAC;YAED,IAAI,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBACzC,KAAK,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAA;YAC9B,CAAC;YAED,OAAO,IAAI,CAAA;QACb,CAAC;QAED,MAAM,IAAI,KAAK,CAAC,0BAA0B,OAAO,KAAK,KAAK,KAAK,CAAC,WAAW,CAAC,IAAI,GAAG,CAAC,CAAA;IACvF,CAAC;CACF;AAED;;;;GAIG;AACH,SAAS,qBAAqB,CAAC,UAAU,EAAE,gBAAgB;IACzD,OAAO,UAAU,CAAC,mBAAmB,EAAE,CAAC,gBAAgB,CAAC,CAAA;AAC3D,CAAC;AAED;;;;GAIG;AACH,SAAS,iBAAiB,CAAC,UAAU,EAAE,GAAG;IACxC,MAAM,YAAY,GAAG,UAAU,CAAC,+BAA+B,EAAE,CAAA;IACjE,MAAM,UAAU,GAAG,YAAY,CAAC,GAAG,CAAC,CAAA;IAEpC,IAAI,UAAU;QAAE,OAAO,UAAU,CAAA;IAEjC,OAAO,SAAS,CAAA;AAClB,CAAC;AAED;;;;;GAKG;AACH,SAAS,cAAc,CAAC,EAAC,IAAI,EAAE,UAAU,EAAC;IACxC,kCAAkC;IAClC,MAAM,YAAY,GAAG,EAAE,CAAA;IACvB,kCAAkC;IAClC,MAAM,YAAY,GAAG,EAAE,CAAA;IAEvB,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE,CAAC;QACvB,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,CAAA;QACvB,MAAM,QAAQ,GAAG,aAAa,CAAC,KAAK,CAAC,CAAA;QAErC,IAAI,QAAQ,EAAE,CAAC;YACb,MAAM,YAAY,GAAG,qBAAqB,CAAC,UAAU,EAAE,GAAG,CAAC,CAAA;YAE3D,IAAI,YAAY,EAAE,CAAC;gBACjB,MAAM,gBAAgB,GAAG,YAAY,CAAC,mBAAmB,EAAE,CAAA;gBAC3D,MAAM,YAAY,GAAG,cAAc,CAAC,EAAC,IAAI,EAAE,KAAK,EAAE,UAAU,EAAE,gBAAgB,EAAC,CAAC,CAAA;gBAChF,MAAM,kBAAkB,GAAG,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC,CAAA;gBACjE,MAAM,kBAAkB,GAAG,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC,CAAA;gBAEjE,IAAI,kBAAkB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;oBAClC,YAAY,CAAC,GAAG,CAAC,GAAG,YAAY,CAAC,YAAY,CAAA;gBAC/C,CAAC;gBAED,IAAI,kBAAkB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;oBAClC,MAAM,SAAS,GAAG,gBAAgB,CAAC,SAAS,EAAE,CAAA;oBAE9C,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC;wBAAE,YAAY,CAAC,SAAS,CAAC,GAAG,EAAE,CAAA;oBAC1D,MAAM,CAAC,MAAM,CAAC,YAAY,CAAC,SAAS,CAAC,EAAE,YAAY,CAAC,YAAY,CAAC,CAAA;gBACnE,CAAC;YACH,CAAC;iBAAM,CAAC;gBACN,YAAY,CAAC,GAAG,CAAC,GAAG,KAAK,CAAA;YAC3B,CAAC;QACH,CAAC;aAAM,CAAC;YACN,MAAM,UAAU,GAAG,iBAAiB,CAAC,UAAU,EAAE,GAAG,CAAC,CAAA;YAErD,IAAI,UAAU,EAAE,CAAC;gBACf,YAAY,CAAC,GAAG,CAAC,GAAG,KAAK,CAAA;YAC3B,CAAC;iBAAM,CAAC;gBACN,YAAY,CAAC,GAAG,CAAC,GAAG,KAAK,CAAA;YAC3B,CAAC;QACH,CAAC;IACH,CAAC;IAED,OAAO,EAAC,YAAY,EAAE,YAAY,EAAC,CAAA;AACrC,CAAC;AAED;;;;;GAKG;AACH,SAAS,4BAA4B,CAAC,EAAC,IAAI,EAAE,UAAU,EAAC;IACtD,kCAAkC;IAClC,MAAM,UAAU,GAAG,EAAE,CAAA;IAErB,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE,CAAC;QACvB,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,CAAA;QAEvB,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC;YAAE,SAAQ;QAEnC,MAAM,YAAY,GAAG,qBAAqB,CAAC,UAAU,EAAE,GAAG,CAAC,CAAA;QAE3D,IAAI,CAAC,YAAY;YAAE,SAAQ;QAE3B,MAAM,gBAAgB,GAAG,YAAY,CAAC,mBAAmB,EAAE,CAAA;QAC3D,MAAM,gBAAgB,GAAG,4BAA4B,CAAC,EAAC,IAAI,EAAE,KAAK,EAAE,UAAU,EAAE,gBAAgB,EAAC,CAAC,CAAA;QAElG,UAAU,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC,CAAC,IAAI,CAAA;IACtF,CAAC;IAED,OAAO,UAAU,CAAA;AACnB,CAAC","sourcesContent":["// @ts-check\n\nimport {incorporate} from \"incorporator\"\nimport * as inflection from \"inflection\"\nimport {isPlainObject} from \"is-plain-object\"\nimport {Logger} from \"../../logger.js\"\nimport Preloader from \"./preloader.js\"\nimport DatabaseQuery from \"./index.js\"\nimport JoinTracker from \"./join-tracker.js\"\nimport RecordNotFoundError from \"../record/record-not-found-error.js\"\nimport WhereModelClassHash from \"./where-model-class-hash.js\"\nimport WhereNot from \"./where-not.js\"\n\n/**\n * @template {typeof import(\"../record/index.js\").default} MC\n */\n/**\n * @template {typeof import(\"../record/index.js\").default} MC\n * @typedef {import(\"./index.js\").QueryArgsType & {modelClass: MC, joinBasePath?: string[], joinTracker?: import(\"./join-tracker.js\").default, forceQualifyBaseTable?: boolean}} ModelClassQueryArgsType\n */\n\n/**\n * A generic query over some model type.\n * @template {typeof import(\"../record/index.js\").default} MC\n */\nexport default class VelociousDatabaseQueryModelClassQuery extends DatabaseQuery {\n  /** @param {ModelClassQueryArgsType<MC>} args - Query constructor arguments. */\n  constructor(args) {\n    const {modelClass} = args\n\n    if (!modelClass) throw new Error(`No modelClass given in ${Object.keys(args).join(\", \")}`)\n\n    super(args)\n    this.logger = new Logger(this)\n\n    /** @type {MC} */\n    this.modelClass = modelClass\n\n    /** @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\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    }))\n\n    // @ts-expect-error\n    return newQuery\n  }\n\n  /** @returns {Promise<number>} - Resolves with the count.  */\n  async count() {\n    // Generate count SQL\n    const primaryKey = `${this.driver.quoteTable(this.getModelClass().tableName())}.${this.driver.quoteColumn(this.getModelClass().primaryKey())}`\n    const distinctPrefix = this._distinct ? \"DISTINCT \" : \"\"\n    let sql = `COUNT(${distinctPrefix}${primaryKey})`\n\n    if (this.driver.getType() == \"pgsql\") sql += \"::int\"\n\n    sql += \" AS count\"\n\n\n    // Clone query and execute count\n    const countQuery = this.clone()\n\n    countQuery._distinct = false\n    countQuery._selects = []\n    countQuery.select(sql)\n\n    const results = /** @type {{count: number}[]} */ (await countQuery._executeQuery())\n\n    // The query isn't grouped and a single result has been given\n    if (results.length == 1) {\n      return results[0].count\n    }\n\n    // The query may be grouped and a lot of different counts a given\n    let countResult = 0\n\n    for (const result of results) {\n      if (!(\"count\" in result)) {\n        throw new Error(\"Invalid count result\")\n      }\n\n      countResult += result.count\n    }\n\n    return countResult\n  }\n\n  /** @returns {MC} - The model class.  */\n  getModelClass() {\n    if (!this.modelClass) throw new Error(\"modelClass not set\")\n\n    return this.modelClass\n  }\n\n  /** @returns {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    let modelClass = this._joinTracker.getRootModelClass()\n\n    if (path.length === 0) return modelClass.tableName()\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.tableName()\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 {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   * @param {number|string} recordId - Record id.\n   * @returns {Promise<InstanceType<MC>>} - Resolves with the find.\n   */\n  async find(recordId) {\n    /** @type {{[key: string]: number | string}} */\n    const conditions = {}\n\n    conditions[this.getModelClass().primaryKey()] = recordId\n\n    const newQuery = /** @type {VelociousDatabaseQueryModelClassQuery<MC>} */ (this.clone())\n\n    newQuery.where(conditions)\n\n    const record = (await newQuery.first())\n\n    if (!record) {\n      throw new RecordNotFoundError(`Couldn't find ${this.getModelClass().name} with '${this.getModelClass().primaryKey()}'=${recordId}`)\n    }\n\n    return record\n  }\n\n  /**\n   * @param {{[key: string]: string | number}} conditions - Conditions hash keyed by attribute name.\n   * @returns {Promise<InstanceType<MC> | null>} - Resolves with the by.\n   */\n  async findBy(conditions) {\n    /** @type {{[key: string]: number | string}} */\n    const newConditions = {}\n\n    for (const key in conditions) {\n      const keyUnderscore = inflection.underscore(key)\n\n      newConditions[keyUnderscore] = conditions[key]\n    }\n\n    const newQuery = /** @type {VelociousDatabaseQueryModelClassQuery<MC>} */ (this.clone())\n\n    newQuery.where(newConditions)\n\n    return await newQuery.first()\n  }\n\n  /**\n   * @param {{[key: string]: string | number}} conditions - Conditions hash keyed by attribute name.\n   * @param {function(InstanceType<MC>) : void} [callback] - Callback function.\n   * @returns {Promise<InstanceType<MC>>} - Resolves with the or create by.\n   */\n  async findOrCreateBy(conditions, callback) {\n    const record = await this.findOrInitializeBy(conditions, callback)\n\n    if (record.isNewRecord()) {\n      await record.save()\n    }\n\n    return record\n  }\n\n  /**\n   * @param {{[key: string]: string | number}} conditions - Conditions hash keyed by attribute name.\n   * @returns {Promise<InstanceType<MC>>} - Resolves with the by or fail.\n   */\n  async findByOrFail(conditions) {\n    /** @type {{[key: string]: number | string}} */\n    const newConditions = {}\n\n    for (const key in conditions) {\n      const keyUnderscore = inflection.underscore(key)\n\n      newConditions[keyUnderscore] = conditions[key]\n    }\n\n    const newQuery = /** @type {VelociousDatabaseQueryModelClassQuery<MC>} */ (this.clone())\n\n    newQuery.where(newConditions)\n\n    const model = await newQuery.first()\n\n    if (!model) {\n      throw new Error(\"Record not found\")\n    }\n\n    return model\n  }\n\n  /**\n   * @param {object} conditions - Conditions.\n   * @param {function(InstanceType<MC>) : void} [callback] - Callback function.\n   * @returns {Promise<InstanceType<MC>>} - Resolves with the or initialize by.\n   */\n  async findOrInitializeBy(conditions, callback) {\n    const record = await this.findBy(conditions)\n\n    if (record) return record\n\n    const ModelClass = this.getModelClass()\n    const newRecord = /** @type {InstanceType<MC>} */ (new ModelClass(conditions))\n\n    if (callback) {\n      callback(newRecord)\n    }\n\n    return newRecord\n  }\n\n  /** @returns {Promise<InstanceType<MC> | undefined>} - Resolves with the first.  */\n  async first() {\n    const newQuery = this.clone().limit(1).reorder(`${this.driver.quoteTable(this.getModelClass().tableName())}.${this.driver.quoteColumn(this.getModelClass().orderableColumn())}`)\n    const results = await newQuery.toArray()\n\n    return results[0]\n  }\n\n  /** @returns {Promise<InstanceType<MC> | undefined>} - Resolves with the last.  */\n  async last() {\n    const primaryKey = this.getModelClass().primaryKey()\n    const tableName = this.getModelClass().tableName()\n    const results = await this.clone().reorder(`${this.driver.quoteTable(tableName)}.${this.driver.quoteColumn(primaryKey)} DESC`).limit(1).toArray()\n\n    return results[0]\n  }\n\n  /**\n   * @param {import(\"./index.js\").NestedPreloadRecord} data - Data payload.\n   * @returns {this} - The preload.\n   */\n  preload(data) {\n    incorporate(this._preload, data)\n    return this\n  }\n\n  /**\n   * Converts query results to array of model instances\n   * @returns {Promise<Array<InstanceType<MC>>>} - Resolves with the array.\n   */\n  async toArray() {\n    const models = []\n    const results = await this.results()\n\n    for (const result of results) {\n      const ModelClass = this.getModelClass()\n      const model = /** @type {InstanceType<MC>} */ (new ModelClass())\n\n      model.loadExistingRecord(result)\n      models.push(model)\n    }\n\n    if (Object.keys(this._preload).length > 0 && models.length > 0) {\n      const preloader = new Preloader({\n        modelClass: this.modelClass,\n        models,\n        preload: this._preload\n      })\n\n      await preloader.run()\n    }\n\n    return models\n  }\n\n  /**\n   * Plucks one or more columns directly from the database without instantiating models.\n   * @param {...string|string[]} columns - Column names.\n   * @returns {Promise<any[]>} - Resolves with the pluck.\n   */\n  async pluck(...columns) {\n    const flatColumns = columns.flat()\n\n    if (flatColumns.length === 0) throw new Error(\"No columns given to pluck\")\n\n    const modelClass = this.getModelClass()\n    const tableName = modelClass.tableName()\n    const attributeMap = modelClass.getAttributeNameToColumnNameMap()\n    const columnNames = flatColumns.map((column) => attributeMap[column] || column)\n\n    const query = /** @type {VelociousDatabaseQueryModelClassQuery<MC>} */ (this.clone())\n\n    query._preload = {}\n    query._selects = []\n\n    columnNames.forEach((columnName) => {\n      const selectSql = `${this.driver.quoteTable(tableName)}.${this.driver.quoteColumn(columnName)}`\n\n      query.select(selectSql)\n    })\n\n    const rows = await query._executeQuery()\n\n    if (columnNames.length === 1) {\n      const [columnName] = columnNames\n      return rows.map((row) => row[columnName])\n    }\n\n    return rows.map((row) => columnNames.map((columnName) => row[columnName]))\n  }\n\n  /**\n   * @param {import(\"./index.js\").WhereArgumentType} where - Where.\n   * @returns {this} This query instance\n   */\n  where(where) {\n    if (typeof where == \"string\") {\n      return super.where(where)\n    }\n\n    if (isPlainObject(where)) {\n      const {resolvedHash, fallbackHash} = splitWhereHash({hash: where, modelClass: this.getModelClass()})\n      const joinObject = buildJoinObjectFromWhereHash({hash: where, modelClass: this.getModelClass()})\n\n      if (Object.keys(joinObject).length > 0) {\n        this.joins(joinObject)\n      }\n\n      if (Object.keys(resolvedHash).length > 0) {\n        const qualifyBaseTable = 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 {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/**\n * @param {typeof import(\"../record/index.js\").default} modelClass - Model class.\n * @param {string} relationshipName - Relationship name.\n * @returns {import(\"../record/relationships/base.js\").default | undefined} - The relationship.\n */\nfunction getRelationshipByName(modelClass, relationshipName) {\n  return modelClass.getRelationshipsMap()[relationshipName]\n}\n\n/**\n * @param {typeof import(\"../record/index.js\").default} modelClass - Model class.\n * @param {string} key - Attribute or column name.\n * @returns {string | undefined} - The resolved column name.\n */\nfunction resolveColumnName(modelClass, key) {\n  const attributeMap = modelClass.getAttributeNameToColumnNameMap()\n  const columnName = attributeMap[key]\n\n  if (columnName) return columnName\n\n  return undefined\n}\n\n/**\n * @param {object} args - Options.\n * @param {Record<string, any>} args.hash - Where hash.\n * @param {typeof import(\"../record/index.js\").default} args.modelClass - Model class.\n * @returns {{resolvedHash: Record<string, any>, fallbackHash: Record<string, any>}} - Split hashes.\n */\nfunction splitWhereHash({hash, modelClass}) {\n  /** @type {Record<string, any>} */\n  const resolvedHash = {}\n  /** @type {Record<string, any>} */\n  const fallbackHash = {}\n\n  for (const key in hash) {\n    const value = hash[key]\n    const isNested = isPlainObject(value)\n\n    if (isNested) {\n      const relationship = getRelationshipByName(modelClass, key)\n\n      if (relationship) {\n        const targetModelClass = relationship.getTargetModelClass()\n        const nestedResult = splitWhereHash({hash: value, modelClass: targetModelClass})\n        const nestedResolvedKeys = Object.keys(nestedResult.resolvedHash)\n        const nestedFallbackKeys = Object.keys(nestedResult.fallbackHash)\n\n        if (nestedResolvedKeys.length > 0) {\n          resolvedHash[key] = nestedResult.resolvedHash\n        }\n\n        if (nestedFallbackKeys.length > 0) {\n          const tableName = targetModelClass.tableName()\n\n          if (!fallbackHash[tableName]) fallbackHash[tableName] = {}\n          Object.assign(fallbackHash[tableName], nestedResult.fallbackHash)\n        }\n      } else {\n        fallbackHash[key] = value\n      }\n    } else {\n      const columnName = resolveColumnName(modelClass, key)\n\n      if (columnName) {\n        resolvedHash[key] = value\n      } else {\n        fallbackHash[key] = value\n      }\n    }\n  }\n\n  return {resolvedHash, fallbackHash}\n}\n\n/**\n * @param {object} args - Options.\n * @param {Record<string, any>} args.hash - Where hash.\n * @param {typeof import(\"../record/index.js\").default} args.modelClass - Model class.\n * @returns {Record<string, any>} - Join object.\n */\nfunction buildJoinObjectFromWhereHash({hash, modelClass}) {\n  /** @type {Record<string, any>} */\n  const joinObject = {}\n\n  for (const key in hash) {\n    const value = hash[key]\n\n    if (!isPlainObject(value)) continue\n\n    const relationship = getRelationshipByName(modelClass, key)\n\n    if (!relationship) continue\n\n    const targetModelClass = relationship.getTargetModelClass()\n    const nestedJoinObject = buildJoinObjectFromWhereHash({hash: value, modelClass: targetModelClass})\n\n    joinObject[key] = Object.keys(nestedJoinObject).length > 0 ? nestedJoinObject : true\n  }\n\n  return joinObject\n}\n"]}
540
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"model-class-query.js","sourceRoot":"","sources":["../../../../src/database/query/model-class-query.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport {incorporate} from \"incorporator\"\nimport * as inflection from \"inflection\"\nimport {isPlainObject} from \"is-plain-object\"\nimport {Logger} from \"../../logger.js\"\nimport Preloader from \"./preloader.js\"\nimport DatabaseQuery from \"./index.js\"\nimport JoinTracker from \"./join-tracker.js\"\nimport RecordNotFoundError from \"../record/record-not-found-error.js\"\nimport WhereModelClassHash from \"./where-model-class-hash.js\"\nimport WhereNot from \"./where-not.js\"\n\n/**\n * @param {import(\"./index.js\").NestedPreloadRecord | string | string[]} 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\n */\n/**\n * @template {typeof import(\"../record/index.js\").default} MC\n * @typedef {import(\"./index.js\").QueryArgsType & {modelClass: MC, joinBasePath?: string[], joinTracker?: import(\"./join-tracker.js\").default, forceQualifyBaseTable?: boolean}} ModelClassQueryArgsType\n */\n\n/**\n * A generic query over some model type.\n * @template {typeof import(\"../record/index.js\").default} MC\n */\nexport default class VelociousDatabaseQueryModelClassQuery extends DatabaseQuery {\n  /** @param {ModelClassQueryArgsType<MC>} args - Query constructor arguments. */\n  constructor(args) {\n    const {modelClass} = args\n\n    if (!modelClass) throw new Error(`No modelClass given in ${Object.keys(args).join(\", \")}`)\n\n    super(args)\n    this.logger = new Logger(this)\n\n    /** @type {MC} */\n    this.modelClass = modelClass\n\n    /** @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\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    }))\n\n    // @ts-expect-error\n    return newQuery\n  }\n\n  /** @returns {Promise<number>} - Resolves with the count.  */\n  async count() {\n    // Generate count SQL\n    const primaryKey = `${this.driver.quoteTable(this.getModelClass().tableName())}.${this.driver.quoteColumn(this.getModelClass().primaryKey())}`\n    const distinctPrefix = this._distinct ? \"DISTINCT \" : \"\"\n    let sql = `COUNT(${distinctPrefix}${primaryKey})`\n\n    if (this.driver.getType() == \"pgsql\") sql += \"::int\"\n\n    sql += \" AS count\"\n\n\n    // Clone query and execute count\n    const countQuery = this.clone()\n\n    countQuery._distinct = false\n    countQuery._selects = []\n    countQuery.select(sql)\n\n    const results = /** @type {{count: number}[]} */ (await countQuery._executeQuery())\n\n    // The query isn't grouped and a single result has been given\n    if (results.length == 1) {\n      return results[0].count\n    }\n\n    // The query may be grouped and a lot of different counts a given\n    let countResult = 0\n\n    for (const result of results) {\n      if (!(\"count\" in result)) {\n        throw new Error(\"Invalid count result\")\n      }\n\n      countResult += result.count\n    }\n\n    return countResult\n  }\n\n  /** @returns {MC} - The model class.  */\n  getModelClass() {\n    if (!this.modelClass) throw new Error(\"modelClass not set\")\n\n    return this.modelClass\n  }\n\n  /** @returns {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    let modelClass = this._joinTracker.getRootModelClass()\n\n    if (path.length === 0) return modelClass.tableName()\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.tableName()\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 {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   * @param {number|string} recordId - Record id.\n   * @returns {Promise<InstanceType<MC>>} - Resolves with the find.\n   */\n  async find(recordId) {\n    /** @type {{[key: string]: number | string}} */\n    const conditions = {}\n\n    conditions[this.getModelClass().primaryKey()] = recordId\n\n    const newQuery = /** @type {VelociousDatabaseQueryModelClassQuery<MC>} */ (this.clone())\n\n    newQuery.where(conditions)\n\n    const record = (await newQuery.first())\n\n    if (!record) {\n      throw new RecordNotFoundError(`Couldn't find ${this.getModelClass().name} with '${this.getModelClass().primaryKey()}'=${recordId}`)\n    }\n\n    return record\n  }\n\n  /**\n   * @param {{[key: string]: string | number}} conditions - Conditions hash keyed by attribute name.\n   * @returns {Promise<InstanceType<MC> | null>} - Resolves with the by.\n   */\n  async findBy(conditions) {\n    /** @type {{[key: string]: number | string}} */\n    const newConditions = {}\n\n    for (const key in conditions) {\n      const keyUnderscore = inflection.underscore(key)\n\n      newConditions[keyUnderscore] = conditions[key]\n    }\n\n    const newQuery = /** @type {VelociousDatabaseQueryModelClassQuery<MC>} */ (this.clone())\n\n    newQuery.where(newConditions)\n\n    return await newQuery.first()\n  }\n\n  /**\n   * @param {{[key: string]: string | number}} conditions - Conditions hash keyed by attribute name.\n   * @param {function(InstanceType<MC>) : void} [callback] - Callback function.\n   * @returns {Promise<InstanceType<MC>>} - Resolves with the or create by.\n   */\n  async findOrCreateBy(conditions, callback) {\n    const record = await this.findOrInitializeBy(conditions, callback)\n\n    if (record.isNewRecord()) {\n      await record.save()\n    }\n\n    return record\n  }\n\n  /**\n   * @param {{[key: string]: string | number}} conditions - Conditions hash keyed by attribute name.\n   * @returns {Promise<InstanceType<MC>>} - Resolves with the by or fail.\n   */\n  async findByOrFail(conditions) {\n    /** @type {{[key: string]: number | string}} */\n    const newConditions = {}\n\n    for (const key in conditions) {\n      const keyUnderscore = inflection.underscore(key)\n\n      newConditions[keyUnderscore] = conditions[key]\n    }\n\n    const newQuery = /** @type {VelociousDatabaseQueryModelClassQuery<MC>} */ (this.clone())\n\n    newQuery.where(newConditions)\n\n    const model = await newQuery.first()\n\n    if (!model) {\n      throw new Error(\"Record not found\")\n    }\n\n    return model\n  }\n\n  /**\n   * @param {object} conditions - Conditions.\n   * @param {function(InstanceType<MC>) : void} [callback] - Callback function.\n   * @returns {Promise<InstanceType<MC>>} - Resolves with the or initialize by.\n   */\n  async findOrInitializeBy(conditions, callback) {\n    const record = await this.findBy(conditions)\n\n    if (record) return record\n\n    const ModelClass = this.getModelClass()\n    const newRecord = /** @type {InstanceType<MC>} */ (new ModelClass(conditions))\n\n    if (callback) {\n      callback(newRecord)\n    }\n\n    return newRecord\n  }\n\n  /** @returns {Promise<InstanceType<MC> | undefined>} - Resolves with the first.  */\n  async first() {\n    const newQuery = this.clone().limit(1).reorder(`${this.driver.quoteTable(this.getModelClass().tableName())}.${this.driver.quoteColumn(this.getModelClass().orderableColumn())}`)\n    const results = await newQuery.toArray()\n\n    return results[0]\n  }\n\n  /** @returns {Promise<InstanceType<MC> | undefined>} - Resolves with the last.  */\n  async last() {\n    const primaryKey = this.getModelClass().primaryKey()\n    const tableName = this.getModelClass().tableName()\n    const results = await this.clone().reorder(`${this.driver.quoteTable(tableName)}.${this.driver.quoteColumn(primaryKey)} DESC`).limit(1).toArray()\n\n    return results[0]\n  }\n\n  /**\n   * @param {import(\"./index.js\").NestedPreloadRecord} data - Data payload.\n   * @returns {this} - The preload.\n   */\n  preload(data) {\n    const normalizedPreload = normalizePreloadRecord(data)\n    incorporate(this._preload, normalizedPreload)\n    return this\n  }\n\n  /**\n   * Converts query results to array of model instances\n   * @returns {Promise<Array<InstanceType<MC>>>} - Resolves with the array.\n   */\n  async toArray() {\n    const models = []\n    const results = await this.results()\n\n    for (const result of results) {\n      const ModelClass = this.getModelClass()\n      const model = /** @type {InstanceType<MC>} */ (new ModelClass())\n\n      model.loadExistingRecord(result)\n      models.push(model)\n    }\n\n    if (Object.keys(this._preload).length > 0 && models.length > 0) {\n      const preloader = new Preloader({\n        modelClass: this.modelClass,\n        models,\n        preload: this._preload\n      })\n\n      await preloader.run()\n    }\n\n    return models\n  }\n\n  /**\n   * Plucks one or more columns directly from the database without instantiating models.\n   * @param {...string|string[]} columns - Column names.\n   * @returns {Promise<any[]>} - Resolves with the pluck.\n   */\n  async pluck(...columns) {\n    const flatColumns = columns.flat()\n\n    if (flatColumns.length === 0) throw new Error(\"No columns given to pluck\")\n\n    const modelClass = this.getModelClass()\n    const tableName = modelClass.tableName()\n    const attributeMap = modelClass.getAttributeNameToColumnNameMap()\n    const columnNames = flatColumns.map((column) => attributeMap[column] || column)\n\n    const query = /** @type {VelociousDatabaseQueryModelClassQuery<MC>} */ (this.clone())\n\n    query._preload = {}\n    query._selects = []\n\n    columnNames.forEach((columnName) => {\n      const selectSql = `${this.driver.quoteTable(tableName)}.${this.driver.quoteColumn(columnName)}`\n\n      query.select(selectSql)\n    })\n\n    const rows = await query._executeQuery()\n\n    if (columnNames.length === 1) {\n      const [columnName] = columnNames\n      return rows.map((row) => row[columnName])\n    }\n\n    return rows.map((row) => columnNames.map((columnName) => row[columnName]))\n  }\n\n  /**\n   * @param {import(\"./index.js\").WhereArgumentType} where - Where.\n   * @returns {this} This query instance\n   */\n  where(where) {\n    if (typeof where == \"string\") {\n      return super.where(where)\n    }\n\n    if (isPlainObject(where)) {\n      const {resolvedHash, fallbackHash} = splitWhereHash({hash: where, modelClass: this.getModelClass()})\n      const joinObject = buildJoinObjectFromWhereHash({hash: where, modelClass: this.getModelClass()})\n\n      if (Object.keys(joinObject).length > 0) {\n        this.joins(joinObject)\n      }\n\n      if (Object.keys(resolvedHash).length > 0) {\n        const qualifyBaseTable = 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 {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/**\n * @param {typeof import(\"../record/index.js\").default} modelClass - Model class.\n * @param {string} relationshipName - Relationship name.\n * @returns {import(\"../record/relationships/base.js\").default | undefined} - The relationship.\n */\nfunction getRelationshipByName(modelClass, relationshipName) {\n  return modelClass.getRelationshipsMap()[relationshipName]\n}\n\n/**\n * @param {typeof import(\"../record/index.js\").default} modelClass - Model class.\n * @param {string} key - Attribute or column name.\n * @returns {string | undefined} - The resolved column name.\n */\nfunction resolveColumnName(modelClass, key) {\n  const attributeMap = modelClass.getAttributeNameToColumnNameMap()\n  const columnName = attributeMap[key]\n\n  if (columnName) return columnName\n\n  return undefined\n}\n\n/**\n * @param {object} args - Options.\n * @param {Record<string, any>} args.hash - Where hash.\n * @param {typeof import(\"../record/index.js\").default} args.modelClass - Model class.\n * @returns {{resolvedHash: Record<string, any>, fallbackHash: Record<string, any>}} - Split hashes.\n */\nfunction splitWhereHash({hash, modelClass}) {\n  /** @type {Record<string, any>} */\n  const resolvedHash = {}\n  /** @type {Record<string, any>} */\n  const fallbackHash = {}\n\n  for (const key in hash) {\n    const value = hash[key]\n    const isNested = isPlainObject(value)\n\n    if (isNested) {\n      const relationship = getRelationshipByName(modelClass, key)\n\n      if (relationship) {\n        const targetModelClass = relationship.getTargetModelClass()\n        const nestedResult = splitWhereHash({hash: value, modelClass: targetModelClass})\n        const nestedResolvedKeys = Object.keys(nestedResult.resolvedHash)\n        const nestedFallbackKeys = Object.keys(nestedResult.fallbackHash)\n\n        if (nestedResolvedKeys.length > 0) {\n          resolvedHash[key] = nestedResult.resolvedHash\n        }\n\n        if (nestedFallbackKeys.length > 0) {\n          const tableName = targetModelClass.tableName()\n\n          if (!fallbackHash[tableName]) fallbackHash[tableName] = {}\n          Object.assign(fallbackHash[tableName], nestedResult.fallbackHash)\n        }\n      } else {\n        fallbackHash[key] = value\n      }\n    } else {\n      const columnName = resolveColumnName(modelClass, key)\n\n      if (columnName) {\n        resolvedHash[key] = value\n      } else {\n        fallbackHash[key] = value\n      }\n    }\n  }\n\n  return {resolvedHash, fallbackHash}\n}\n\n/**\n * @param {object} args - Options.\n * @param {Record<string, any>} args.hash - Where hash.\n * @param {typeof import(\"../record/index.js\").default} args.modelClass - Model class.\n * @returns {Record<string, any>} - Join object.\n */\nfunction buildJoinObjectFromWhereHash({hash, modelClass}) {\n  /** @type {Record<string, any>} */\n  const joinObject = {}\n\n  for (const key in hash) {\n    const value = hash[key]\n\n    if (!isPlainObject(value)) continue\n\n    const relationship = getRelationshipByName(modelClass, key)\n\n    if (!relationship) continue\n\n    const targetModelClass = relationship.getTargetModelClass()\n    const nestedJoinObject = buildJoinObjectFromWhereHash({hash: value, modelClass: targetModelClass})\n\n    joinObject[key] = Object.keys(nestedJoinObject).length > 0 ? nestedJoinObject : true\n  }\n\n  return joinObject\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"preloader.d.ts","sourceRoot":"","sources":["../../../../src/database/query/preloader.js"],"names":[],"mappings":"AAOA;IACE;;;;;OAKG;IACH,0DAJG;QAA0D,UAAU,EAA5D,cAAc,oBAAoB,EAAE,OAAO;QACE,MAAM,EAAnD,OAAO,oBAAoB,EAAE,OAAO,EAAE;QACgB,OAAO,EAA7D,OAAO,mBAAmB,EAAE,mBAAmB;KACzD,EAOA;IAHC,wDAA4B;IAC5B,+CAAoB;IACpB,yDAAsB;IAGxB,qBAuDC;CACF"}
1
+ {"version":3,"file":"preloader.d.ts","sourceRoot":"","sources":["../../../../src/database/query/preloader.js"],"names":[],"mappings":"AAsEA;IACE;;;;;OAKG;IACH,0DAJG;QAA0D,UAAU,EAA5D,cAAc,oBAAoB,EAAE,OAAO;QACE,MAAM,EAAnD,OAAO,oBAAoB,EAAE,OAAO,EAAE;QACgB,OAAO,EAA7D,OAAO,mBAAmB,EAAE,mBAAmB;KACzD,EAOA;IAHC,wDAA4B;IAC5B,+CAAoB;IACpB,yDAAsB;IAGxB,qBAwDC;CACF"}
@@ -3,6 +3,57 @@ import BelongsToPreloader from "./preloader/belongs-to.js";
3
3
  import HasManyPreloader from "./preloader/has-many.js";
4
4
  import HasOnePreloader from "./preloader/has-one.js";
5
5
  import restArgsError from "../../utils/rest-args-error.js";
6
+ /**
7
+ * @param {import("../query/index.js").NestedPreloadRecord | string | string[] | boolean} preload - Preload data in shorthand or nested form.
8
+ * @returns {import("../query/index.js").NestedPreloadRecord | null} - Normalized nested preload record.
9
+ */
10
+ function normalizeNestedPreload(preload) {
11
+ if (!preload || typeof preload == "boolean")
12
+ return null;
13
+ if (typeof preload == "string") {
14
+ return { [preload]: true };
15
+ }
16
+ if (Array.isArray(preload)) {
17
+ /** @type {import("../query/index.js").NestedPreloadRecord} */
18
+ const result = {};
19
+ for (const entry of preload) {
20
+ if (typeof entry == "string") {
21
+ result[entry] = true;
22
+ continue;
23
+ }
24
+ if (entry && typeof entry == "object") {
25
+ const normalizedEntry = normalizeNestedPreload(entry);
26
+ if (normalizedEntry) {
27
+ for (const [key, value] of Object.entries(normalizedEntry)) {
28
+ result[key] = value;
29
+ }
30
+ }
31
+ continue;
32
+ }
33
+ throw new Error(`Invalid preload entry type: ${typeof entry}`);
34
+ }
35
+ return result;
36
+ }
37
+ if (preload && typeof preload == "object") {
38
+ /** @type {import("../query/index.js").NestedPreloadRecord} */
39
+ const result = {};
40
+ for (const [key, value] of Object.entries(preload)) {
41
+ if (value === true || value === false) {
42
+ result[key] = value;
43
+ continue;
44
+ }
45
+ const normalizedValue = normalizeNestedPreload(value);
46
+ if (normalizedValue) {
47
+ result[key] = normalizedValue;
48
+ }
49
+ else {
50
+ throw new Error(`Invalid preload value for ${key}: ${typeof value}`);
51
+ }
52
+ }
53
+ return result;
54
+ }
55
+ throw new Error(`Invalid preload type: ${typeof preload}`);
56
+ }
6
57
  export default class VelociousDatabaseQueryPreloader {
7
58
  /**
8
59
  * @param {object} args - Options object.
@@ -42,7 +93,8 @@ export default class VelociousDatabaseQueryPreloader {
42
93
  const targetModelsByClassName = Array.isArray(preloadResult) ? undefined : preloadResult?.targetModelsByClassName;
43
94
  // Handle any further preloads in the tree
44
95
  const newPreload = this.preload[preloadRelationshipName];
45
- if (typeof newPreload == "object" && targetModels.length > 0) {
96
+ const normalizedPreload = normalizeNestedPreload(newPreload);
97
+ if (normalizedPreload && targetModels.length > 0) {
46
98
  if (relationship.getPolymorphic() && targetModelsByClassName) {
47
99
  const configuration = relationship.getConfiguration();
48
100
  for (const className in targetModelsByClassName) {
@@ -50,7 +102,7 @@ export default class VelociousDatabaseQueryPreloader {
50
102
  if (models.length == 0)
51
103
  continue;
52
104
  const targetModelClass = configuration.getModelClass(className);
53
- const preloader = new VelociousDatabaseQueryPreloader({ modelClass: targetModelClass, models, preload: newPreload });
105
+ const preloader = new VelociousDatabaseQueryPreloader({ modelClass: targetModelClass, models, preload: normalizedPreload });
54
106
  await preloader.run();
55
107
  }
56
108
  }
@@ -58,11 +110,11 @@ export default class VelociousDatabaseQueryPreloader {
58
110
  const targetModelClass = relationship.getTargetModelClass();
59
111
  if (!targetModelClass)
60
112
  throw new Error("No target model class could be gotten from relationship");
61
- const preloader = new VelociousDatabaseQueryPreloader({ modelClass: targetModelClass, models: targetModels, preload: newPreload });
113
+ const preloader = new VelociousDatabaseQueryPreloader({ modelClass: targetModelClass, models: targetModels, preload: normalizedPreload });
62
114
  await preloader.run();
63
115
  }
64
116
  }
65
117
  }
66
118
  }
67
119
  }
68
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"preloader.js","sourceRoot":"","sources":["../../../../src/database/query/preloader.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport BelongsToPreloader from \"./preloader/belongs-to.js\"\nimport HasManyPreloader from \"./preloader/has-many.js\"\nimport HasOnePreloader from \"./preloader/has-one.js\"\nimport restArgsError from \"../../utils/rest-args-error.js\"\n\nexport default class VelociousDatabaseQueryPreloader {\n  /**\n   * @param {object} args - Options object.\n   * @param {typeof import(\"../record/index.js\").default} args.modelClass - Model class.\n   * @param {import(\"../record/index.js\").default[]} args.models - Model instances.\n   * @param {import(\"../query/index.js\").NestedPreloadRecord} args.preload - Preload.\n   */\n  constructor({modelClass, models, preload, ...restArgs}) {\n    restArgsError(restArgs)\n\n    this.modelClass = modelClass\n    this.models = models\n    this.preload = preload\n  }\n\n  async run() {\n    for (const preloadRelationshipName in this.preload) {\n      const relationship = this.modelClass.getRelationshipByName(preloadRelationshipName)\n      let preloadResult\n\n      if (relationship.getType() == \"belongsTo\") {\n        const belongsToRelationship = /** @type {import(\"../record/relationships/belongs-to.js\").default} */ (relationship)\n        const hasManyPreloader = new BelongsToPreloader({models: this.models, relationship: belongsToRelationship})\n\n        preloadResult = await hasManyPreloader.run()\n      } else if (relationship.getType() == \"hasMany\") {\n        const hasManyRelationship = /** @type {import(\"../record/relationships/has-many.js\").default} */ (relationship)\n        const hasManyPreloader = new HasManyPreloader({models: this.models, relationship: hasManyRelationship})\n\n        preloadResult = await hasManyPreloader.run()\n      } else if (relationship.getType() == \"hasOne\") {\n        const hasOneRelationship = /** @type {import(\"../record/relationships/has-one.js\").default} */ (relationship)\n        const hasOnePreloader = new HasOnePreloader({models: this.models, relationship: hasOneRelationship})\n\n        preloadResult = await hasOnePreloader.run()\n      } else {\n        throw new Error(`Unknown relationship type: ${relationship.getType()}`)\n      }\n\n      const targetModels = Array.isArray(preloadResult) ? preloadResult : (preloadResult?.targetModels || [])\n      const targetModelsByClassName = Array.isArray(preloadResult) ? undefined : preloadResult?.targetModelsByClassName\n\n      // Handle any further preloads in the tree\n      const newPreload = this.preload[preloadRelationshipName]\n\n      if (typeof newPreload == \"object\" && targetModels.length > 0) {\n        if (relationship.getPolymorphic() && targetModelsByClassName) {\n          const configuration = relationship.getConfiguration()\n\n          for (const className in targetModelsByClassName) {\n            const models = targetModelsByClassName[className]\n\n            if (models.length == 0) continue\n\n            const targetModelClass = configuration.getModelClass(className)\n            const preloader = new VelociousDatabaseQueryPreloader({modelClass: targetModelClass, models, preload: newPreload})\n\n            await preloader.run()\n          }\n        } else {\n          const targetModelClass = relationship.getTargetModelClass()\n\n          if (!targetModelClass) throw new Error(\"No target model class could be gotten from relationship\")\n\n          const preloader = new VelociousDatabaseQueryPreloader({modelClass: targetModelClass, models: targetModels, preload: newPreload})\n\n          await preloader.run()\n        }\n      }\n    }\n  }\n}\n"]}
120
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"preloader.js","sourceRoot":"","sources":["../../../../src/database/query/preloader.js"],"names":[],"mappings":"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","sourcesContent":["// @ts-check\n\nimport BelongsToPreloader from \"./preloader/belongs-to.js\"\nimport HasManyPreloader from \"./preloader/has-many.js\"\nimport HasOnePreloader from \"./preloader/has-one.js\"\nimport restArgsError from \"../../utils/rest-args-error.js\"\n\n/**\n * @param {import(\"../query/index.js\").NestedPreloadRecord | string | string[] | boolean} preload - Preload data in shorthand or nested form.\n * @returns {import(\"../query/index.js\").NestedPreloadRecord | null} - Normalized nested preload record.\n */\nfunction normalizeNestedPreload(preload) {\n  if (!preload || typeof preload == \"boolean\") return null\n\n  if (typeof preload == \"string\") {\n    return {[preload]: true}\n  }\n\n  if (Array.isArray(preload)) {\n    /** @type {import(\"../query/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 (entry && typeof entry == \"object\") {\n        const normalizedEntry = normalizeNestedPreload(entry)\n\n        if (normalizedEntry) {\n          for (const [key, value] of Object.entries(normalizedEntry)) {\n            result[key] = value\n          }\n        }\n        continue\n      }\n\n      throw new Error(`Invalid preload entry type: ${typeof entry}`)\n    }\n\n    return result\n  }\n\n  if (preload && typeof preload == \"object\") {\n    /** @type {import(\"../query/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      const normalizedValue = normalizeNestedPreload(value)\n\n      if (normalizedValue) {\n        result[key] = normalizedValue\n      } else {\n        throw new Error(`Invalid preload value for ${key}: ${typeof value}`)\n      }\n    }\n\n    return result\n  }\n\n  throw new Error(`Invalid preload type: ${typeof preload}`)\n}\n\nexport default class VelociousDatabaseQueryPreloader {\n  /**\n   * @param {object} args - Options object.\n   * @param {typeof import(\"../record/index.js\").default} args.modelClass - Model class.\n   * @param {import(\"../record/index.js\").default[]} args.models - Model instances.\n   * @param {import(\"../query/index.js\").NestedPreloadRecord} args.preload - Preload.\n   */\n  constructor({modelClass, models, preload, ...restArgs}) {\n    restArgsError(restArgs)\n\n    this.modelClass = modelClass\n    this.models = models\n    this.preload = preload\n  }\n\n  async run() {\n    for (const preloadRelationshipName in this.preload) {\n      const relationship = this.modelClass.getRelationshipByName(preloadRelationshipName)\n      let preloadResult\n\n      if (relationship.getType() == \"belongsTo\") {\n        const belongsToRelationship = /** @type {import(\"../record/relationships/belongs-to.js\").default} */ (relationship)\n        const hasManyPreloader = new BelongsToPreloader({models: this.models, relationship: belongsToRelationship})\n\n        preloadResult = await hasManyPreloader.run()\n      } else if (relationship.getType() == \"hasMany\") {\n        const hasManyRelationship = /** @type {import(\"../record/relationships/has-many.js\").default} */ (relationship)\n        const hasManyPreloader = new HasManyPreloader({models: this.models, relationship: hasManyRelationship})\n\n        preloadResult = await hasManyPreloader.run()\n      } else if (relationship.getType() == \"hasOne\") {\n        const hasOneRelationship = /** @type {import(\"../record/relationships/has-one.js\").default} */ (relationship)\n        const hasOnePreloader = new HasOnePreloader({models: this.models, relationship: hasOneRelationship})\n\n        preloadResult = await hasOnePreloader.run()\n      } else {\n        throw new Error(`Unknown relationship type: ${relationship.getType()}`)\n      }\n\n      const targetModels = Array.isArray(preloadResult) ? preloadResult : (preloadResult?.targetModels || [])\n      const targetModelsByClassName = Array.isArray(preloadResult) ? undefined : preloadResult?.targetModelsByClassName\n\n      // Handle any further preloads in the tree\n      const newPreload = this.preload[preloadRelationshipName]\n      const normalizedPreload = normalizeNestedPreload(newPreload)\n\n      if (normalizedPreload && targetModels.length > 0) {\n        if (relationship.getPolymorphic() && targetModelsByClassName) {\n          const configuration = relationship.getConfiguration()\n\n          for (const className in targetModelsByClassName) {\n            const models = targetModelsByClassName[className]\n\n            if (models.length == 0) continue\n\n            const targetModelClass = configuration.getModelClass(className)\n            const preloader = new VelociousDatabaseQueryPreloader({modelClass: targetModelClass, models, preload: normalizedPreload})\n\n            await preloader.run()\n          }\n        } else {\n          const targetModelClass = relationship.getTargetModelClass()\n\n          if (!targetModelClass) throw new Error(\"No target model class could be gotten from relationship\")\n\n          const preloader = new VelociousDatabaseQueryPreloader({modelClass: targetModelClass, models: targetModels, preload: normalizedPreload})\n\n          await preloader.run()\n        }\n      }\n    }\n  }\n}\n"]}
package/package.json CHANGED
@@ -3,7 +3,7 @@
3
3
  "velocious": "build/bin/velocious.js"
4
4
  },
5
5
  "name": "velocious",
6
- "version": "1.0.179",
6
+ "version": "1.0.180",
7
7
  "main": "build/index.js",
8
8
  "types": "build/index.d.ts",
9
9
  "files": [