@strapi/database 5.45.0 → 5.46.0

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.
@@ -3,7 +3,7 @@ import DatabaseError from '../errors/database.mjs';
3
3
  import { transactionCtx } from '../transaction-context.mjs';
4
4
  import { isKnexQuery } from '../utils/knex.mjs';
5
5
  import { applySearch } from './helpers/search.mjs';
6
- import { buildStatusSortExpression, wrapWithDeepSort, processOrderBy } from './helpers/order-by.mjs';
6
+ import { toKnexOrderByDescriptor, wrapWithDeepSort, processOrderBy } from './helpers/order-by.mjs';
7
7
  import { applyJoins, createJoin } from './helpers/join.mjs';
8
8
  import applyPopulate from './helpers/populate/apply.mjs';
9
9
  import processPopulate from './helpers/populate/process.mjs';
@@ -285,9 +285,44 @@ const createQueryBuilder = (uid, db, initialState = {})=>{
285
285
  db
286
286
  });
287
287
  state.data = toRow(meta, state.data);
288
+ this.ensurePaginationOrderStability();
288
289
  this.processSelect();
289
290
  this.state.processed = true;
290
291
  },
292
+ /**
293
+ * OFFSET/LIMIT without a unique ORDER BY is undefined behavior on SQL databases (notably MySQL).
294
+ * That can repeat or skip rows across pages. Deep sort already appends a primary-key tie-breaker;
295
+ * for all other paginated selects, append id ASC when it is not already the last sort key.
296
+ */ ensurePaginationOrderStability () {
297
+ if (state.type !== 'select' || state.first) {
298
+ return;
299
+ }
300
+ if (state.limit === null && state.offset === null) {
301
+ return;
302
+ }
303
+ if (state.limit === -1) {
304
+ return;
305
+ }
306
+ if (this.shouldUseDeepSort()) {
307
+ return;
308
+ }
309
+ if (!meta.attributes.id) {
310
+ return;
311
+ }
312
+ const idColumnName = toColumnName(meta, 'id');
313
+ const aliasedId = this.aliasColumn(idColumnName);
314
+ const lastOrder = state.orderBy[state.orderBy.length - 1];
315
+ if (lastOrder && lastOrder.column === aliasedId) {
316
+ return;
317
+ }
318
+ state.orderBy = [
319
+ ...state.orderBy,
320
+ {
321
+ column: aliasedId,
322
+ order: 'asc'
323
+ }
324
+ ];
325
+ },
291
326
  shouldUseDistinct () {
292
327
  return state.joins.length > 0 && _.isEmpty(state.groupBy);
293
328
  },
@@ -425,20 +460,6 @@ const createQueryBuilder = (uid, db, initialState = {})=>{
425
460
  if (state.offset) {
426
461
  qb.offset(state.offset);
427
462
  }
428
- if (state.orderBy.length > 0) {
429
- // Convert raw-expression entries (e.g. status) to Knex.Raw before passing to orderBy.
430
- // Knex's TS types don't accept Raw in the column position, so cast to any[].
431
- const knexOrderBy = state.orderBy.map((entry)=>{
432
- if ('rawExpression' in entry && entry.rawExpression === 'status') {
433
- return {
434
- column: buildStatusSortExpression(db, tableName, this.alias, entry.isI18n),
435
- order: entry.order
436
- };
437
- }
438
- return entry;
439
- });
440
- qb.orderBy(knexOrderBy);
441
- }
442
463
  if (state.first) {
443
464
  qb.first();
444
465
  }
@@ -459,9 +480,20 @@ const createQueryBuilder = (uid, db, initialState = {})=>{
459
480
  });
460
481
  });
461
482
  }
462
- if (state.joins.length > 0) {
483
+ /**
484
+ * Join `orderBy` (e.g. join-table ordinal for relations) must precede root `state.orderBy`
485
+ * when both are emitted. Otherwise pagination stability (`ensurePaginationOrderStability`)
486
+ * appending `id ASC` on the root alias wins over distinct target ids and breaks relation ordering.
487
+ */ if (state.joins.length > 0) {
463
488
  applyJoins(qb, state.joins);
464
489
  }
490
+ if (state.orderBy.length > 0) {
491
+ // `processState` normalizes entries to OrderByValue[] (string/object input from `.init()`).
492
+ const knexOrderBy = state.orderBy.map((entry)=>toKnexOrderByDescriptor(db, tableName, this.alias, entry));
493
+ // Knex compound `orderBy` typings list `column: string | QueryBuilder` — `Knex.Raw` works at runtime
494
+ // (e.g. `status` sort). See helpers.toKnexOrderByDescriptor / buildStatusSortExpression.
495
+ qb.orderBy(knexOrderBy);
496
+ }
465
497
  if (this.shouldUseDeepSort()) {
466
498
  return wrapWithDeepSort(qb, {
467
499
  qb: this,
@@ -1 +1 @@
1
- {"version":3,"file":"query-builder.mjs","sources":["../../src/query/query-builder.ts"],"sourcesContent":["import type { Knex } from 'knex';\nimport _ from 'lodash/fp';\n\nimport type { Database } from '..';\n\nimport { DatabaseError } from '../errors';\nimport { transactionCtx } from '../transaction-context';\nimport { isKnexQuery } from '../utils/knex';\nimport * as helpers from './helpers';\nimport type { Join } from './helpers/join';\n\ninterface State {\n type: 'select' | 'insert' | 'update' | 'delete' | 'count' | 'max' | 'truncate';\n select: Array<string | Knex.Raw>;\n count: string | null;\n max: string | null;\n first: boolean;\n data: Record<string, unknown> | (null | Record<string, unknown>)[] | null;\n where: Record<string, unknown>[];\n joins: Join[];\n populate: object | null;\n limit: number | null;\n offset: number | null;\n transaction: any;\n forUpdate: boolean;\n onConflict: any;\n merge: any;\n ignore: boolean;\n orderBy: any[];\n groupBy: any[];\n increments: any[];\n decrements: any[];\n aliasCounter: number;\n filters: any;\n search: string;\n processed: boolean;\n}\n\nexport interface QueryBuilder {\n alias: string;\n state: State;\n raw: Knex.RawBuilder;\n\n getAlias(): string;\n\n clone(): QueryBuilder;\n\n select(args: string | Array<string | Knex.Raw>): QueryBuilder;\n\n addSelect(args: string | string[]): QueryBuilder;\n\n insert<TData extends Record<string, unknown> | Record<string, unknown>[]>(\n data: TData\n ): QueryBuilder;\n\n onConflict(args: any): QueryBuilder;\n\n merge(args: any): QueryBuilder;\n\n ignore(): QueryBuilder;\n\n delete(): QueryBuilder;\n\n ref(name: string): any;\n\n update<TData extends Record<string, unknown>>(data: TData): QueryBuilder;\n\n increment(column: string, amount?: number): QueryBuilder;\n\n decrement(column: string, amount?: number): QueryBuilder;\n\n count(count?: string): QueryBuilder;\n\n max(column: string): QueryBuilder;\n\n where(where?: object): QueryBuilder;\n\n limit(limit: number): QueryBuilder;\n\n offset(offset: number): QueryBuilder;\n\n orderBy(orderBy: any): QueryBuilder;\n\n groupBy(groupBy: any): QueryBuilder;\n\n populate(populate: any): QueryBuilder;\n\n search(query: string): QueryBuilder;\n\n transacting(transaction: any): QueryBuilder;\n\n forUpdate(): QueryBuilder;\n\n init(params?: any): QueryBuilder;\n\n filters(filters: any): void;\n\n first(): QueryBuilder;\n\n join(join: any): QueryBuilder;\n\n mustUseAlias(): boolean;\n\n aliasColumn(key: any, alias?: string): any;\n\n shouldUseSubQuery(): boolean;\n\n runSubQuery(): any;\n\n processState(): void;\n\n shouldUseDistinct(): boolean;\n\n shouldUseDeepSort(): boolean;\n\n processSelect(): void;\n\n getKnexQuery(): Knex.QueryBuilder;\n\n execute<T>(options?: { mapResults?: boolean }): Promise<T>;\n\n stream(options?: { mapResults?: boolean }): helpers.ReadableQuery;\n}\n\nconst createQueryBuilder = (\n uid: string,\n db: Database,\n initialState: Partial<State> = {}\n): QueryBuilder => {\n const meta = db.metadata.get(uid);\n const { tableName } = meta;\n\n const state: State = _.defaults(\n {\n type: 'select',\n select: [],\n count: null,\n max: null,\n first: false,\n data: null,\n where: [],\n joins: [],\n populate: null,\n limit: null,\n offset: null,\n transaction: null,\n forUpdate: false,\n onConflict: null,\n merge: null,\n ignore: false,\n orderBy: [],\n groupBy: [],\n increments: [],\n decrements: [],\n aliasCounter: 0,\n filters: null,\n search: null,\n processed: false,\n },\n initialState\n );\n\n const getAlias = () => {\n const alias = `t${state.aliasCounter}`;\n\n state.aliasCounter += 1;\n\n return alias;\n };\n\n return {\n alias: getAlias(),\n getAlias,\n state,\n\n clone() {\n return createQueryBuilder(uid, db, state);\n },\n\n select(args) {\n state.type = 'select';\n state.select = _.uniq(_.castArray(args));\n\n return this;\n },\n\n addSelect(args) {\n state.select = _.uniq([...state.select, ..._.castArray(args)]);\n\n return this;\n },\n\n insert(data) {\n state.type = 'insert';\n state.data = data;\n\n return this;\n },\n\n onConflict(args) {\n state.onConflict = args;\n\n return this;\n },\n\n merge(args) {\n state.merge = args;\n\n return this;\n },\n\n ignore() {\n state.ignore = true;\n\n return this;\n },\n\n delete() {\n state.type = 'delete';\n\n return this;\n },\n\n ref(name) {\n return db.connection.ref(helpers.toColumnName(meta, name));\n },\n\n update(data) {\n state.type = 'update';\n state.data = data;\n\n return this;\n },\n\n increment(column, amount = 1) {\n state.type = 'update';\n state.increments.push({ column, amount });\n\n return this;\n },\n\n decrement(column, amount = 1) {\n state.type = 'update';\n state.decrements.push({ column, amount });\n\n return this;\n },\n\n count(count = 'id') {\n state.type = 'count';\n state.count = count;\n\n return this;\n },\n\n max(column: string) {\n state.type = 'max';\n state.max = column;\n\n return this;\n },\n\n where(where: Record<string, unknown> = {}) {\n if (!_.isPlainObject(where)) {\n throw new Error('Where must be an object');\n }\n\n state.where.push(where);\n\n return this;\n },\n\n limit(limit) {\n state.limit = limit;\n return this;\n },\n\n offset(offset) {\n state.offset = offset;\n return this;\n },\n\n orderBy(orderBy) {\n state.orderBy = orderBy;\n return this;\n },\n\n groupBy(groupBy) {\n state.groupBy = groupBy;\n return this;\n },\n\n populate(populate) {\n state.populate = populate;\n return this;\n },\n\n search(query) {\n state.search = query;\n return this;\n },\n\n transacting(transaction) {\n state.transaction = transaction;\n return this;\n },\n\n forUpdate() {\n state.forUpdate = true;\n return this;\n },\n\n init(params = {}) {\n const { _q, filters, where, select, limit, offset, orderBy, groupBy, populate } = params;\n\n if (!_.isNil(where)) {\n this.where(where);\n }\n\n if (!_.isNil(_q)) {\n this.search(_q);\n }\n\n if (!_.isNil(select)) {\n this.select(select);\n } else {\n this.select('*');\n }\n\n if (!_.isNil(limit)) {\n this.limit(limit);\n }\n\n if (!_.isNil(offset)) {\n this.offset(offset);\n }\n\n if (!_.isNil(orderBy)) {\n this.orderBy(orderBy);\n }\n\n if (!_.isNil(groupBy)) {\n this.groupBy(groupBy);\n }\n\n if (!_.isNil(populate)) {\n this.populate(populate);\n }\n\n if (!_.isNil(filters)) {\n this.filters(filters);\n }\n\n return this;\n },\n\n filters(filters) {\n state.filters = filters;\n },\n\n first() {\n state.first = true;\n return this;\n },\n\n join(join) {\n if (!join.targetField) {\n state.joins.push(join);\n return this;\n }\n\n const model = db.metadata.get(uid);\n const attribute = model.attributes[join.targetField];\n\n helpers.createJoin(\n { db, qb: this, uid },\n {\n alias: this.alias,\n refAlias: join.alias,\n attributeName: join.targetField,\n attribute,\n }\n );\n\n return this;\n },\n\n mustUseAlias() {\n return ['select', 'count'].includes(state.type);\n },\n\n aliasColumn(key: string | unknown, alias: string): string | unknown {\n if (typeof key !== 'string') {\n return key;\n }\n\n if (key.indexOf('.') >= 0) {\n return key;\n }\n\n if (!_.isNil(alias)) {\n return `${alias}.${key}`;\n }\n\n return this.mustUseAlias() ? `${this.alias}.${key}` : key;\n },\n\n raw: db.connection.raw.bind(db.connection),\n\n shouldUseSubQuery() {\n return ['delete', 'update'].includes(state.type) && state.joins.length > 0;\n },\n\n runSubQuery() {\n const originalType = state.type;\n\n this.select('id');\n const subQB = this.getKnexQuery();\n\n const nestedSubQuery = db.getConnection().select('id').from(subQB.as('subQuery'));\n const connection = db.getConnection(tableName);\n\n return (connection[originalType] as Knex)().whereIn('id', nestedSubQuery);\n },\n\n processState() {\n if (this.state.processed) {\n return;\n }\n\n state.orderBy = helpers.processOrderBy(state.orderBy, { qb: this, uid, db });\n\n if (!_.isNil(state.filters)) {\n if (_.isFunction(state.filters)) {\n const filters = state.filters({ qb: this, uid, meta, db });\n\n if (!_.isNil(filters)) {\n state.where.push(filters);\n }\n } else {\n state.where.push(state.filters);\n }\n }\n\n state.where = helpers.processWhere(state.where, { qb: this, uid, db });\n state.populate = helpers.processPopulate(state.populate, { qb: this, uid, db });\n\n state.data = helpers.toRow(meta, state.data);\n\n this.processSelect();\n\n this.state.processed = true;\n },\n\n shouldUseDistinct() {\n return state.joins.length > 0 && _.isEmpty(state.groupBy);\n },\n\n shouldUseDeepSort() {\n return (\n state.orderBy\n .filter((ob: any) => 'column' in ob && ob.column.indexOf('.') >= 0)\n .filter((ob: any) => {\n const col = ob.column.split('.');\n\n for (let i = 0; i < col.length - 1; i += 1) {\n const el = col[i];\n\n // order by \"rel\".\"xxx\"\n const isRelationAttribute = meta.attributes[el]?.type === 'relation';\n\n // order by \"t2\".\"xxx\"\n const isAliasedRelation = Object.values(state.joins)\n .map((join) => join.alias)\n .includes(el);\n\n if (isRelationAttribute || isAliasedRelation) {\n return true;\n }\n }\n\n return false;\n }).length > 0\n );\n },\n\n processSelect() {\n state.select = state.select.map((field) => {\n if (isKnexQuery(field)) {\n return field;\n }\n\n return helpers.toColumnName(meta, field);\n });\n\n if (this.shouldUseDistinct()) {\n const joinsOrderByColumns = state.joins.flatMap((join) => {\n return _.keys(join.orderBy).map((key) => this.aliasColumn(key, join.alias));\n });\n // Only include column-based orderBy entries (skip raw expressions like status)\n const orderByColumns = state.orderBy\n .filter((ob: any) => 'column' in ob)\n .map((ob: any) => ob.column);\n\n state.select = _.uniq([...joinsOrderByColumns, ...orderByColumns, ...state.select]);\n }\n },\n\n getKnexQuery() {\n if (!state.type) {\n this.select('*');\n }\n\n const aliasedTableName = this.mustUseAlias() ? `${tableName} as ${this.alias}` : tableName;\n\n const qb = db.getConnection(aliasedTableName);\n\n // The state should always be processed before calling shouldUseSubQuery as it\n // relies on the presence or absence of joins to determine the need of a subquery\n this.processState();\n\n if (this.shouldUseSubQuery()) {\n return this.runSubQuery();\n }\n\n switch (state.type) {\n case 'select': {\n qb.select(state.select.map((column) => this.aliasColumn(column)));\n\n if (this.shouldUseDistinct()) {\n qb.distinct();\n }\n\n break;\n }\n case 'count': {\n const dbColumnName = this.aliasColumn(helpers.toColumnName(meta, state.count));\n\n if (this.shouldUseDistinct()) {\n qb.countDistinct({ count: dbColumnName });\n } else {\n qb.count({ count: dbColumnName });\n }\n break;\n }\n case 'max': {\n const dbColumnName = this.aliasColumn(helpers.toColumnName(meta, state.max));\n qb.max({ max: dbColumnName });\n break;\n }\n case 'insert': {\n qb.insert(state.data);\n\n if (db.dialect.useReturning() && _.has('id', meta.attributes)) {\n qb.returning('id');\n }\n\n break;\n }\n case 'update': {\n if (state.data) {\n qb.update(state.data);\n }\n break;\n }\n case 'delete': {\n qb.delete();\n\n break;\n }\n case 'truncate': {\n qb.truncate();\n break;\n }\n default: {\n throw new Error('Unknown query type');\n }\n }\n\n if (state.transaction) {\n qb.transacting(state.transaction);\n }\n\n if (state.forUpdate) {\n qb.forUpdate();\n }\n\n if (!_.isEmpty(state.increments)) {\n state.increments.forEach((incr) => qb.increment(incr.column, incr.amount));\n }\n\n if (!_.isEmpty(state.decrements)) {\n state.decrements.forEach((decr) => qb.decrement(decr.column, decr.amount));\n }\n\n if (state.onConflict) {\n if (state.merge) {\n qb.onConflict(state.onConflict).merge(state.merge);\n } else if (state.ignore) {\n qb.onConflict(state.onConflict).ignore();\n }\n }\n\n if (state.limit) {\n qb.limit(state.limit);\n }\n\n if (state.offset) {\n qb.offset(state.offset);\n }\n\n if (state.orderBy.length > 0) {\n // Convert raw-expression entries (e.g. status) to Knex.Raw before passing to orderBy.\n // Knex's TS types don't accept Raw in the column position, so cast to any[].\n const knexOrderBy = state.orderBy.map((entry: any) => {\n if ('rawExpression' in entry && entry.rawExpression === 'status') {\n return {\n column: helpers.buildStatusSortExpression(db, tableName, this.alias, entry.isI18n),\n order: entry.order,\n };\n }\n return entry;\n });\n qb.orderBy(knexOrderBy);\n }\n\n if (state.first) {\n qb.first();\n }\n\n if (state.groupBy.length > 0) {\n qb.groupBy(state.groupBy);\n }\n\n // if there are joins and it is a delete or update use a sub query\n if (state.where) {\n helpers.applyWhere(qb, state.where);\n }\n\n // if there are joins and it is a delete or update use a sub query\n if (state.search) {\n qb.where((subQb) => {\n helpers.applySearch(subQb, state.search, { qb: this, db, uid });\n });\n }\n\n if (state.joins.length > 0) {\n helpers.applyJoins(qb, state.joins);\n }\n\n if (this.shouldUseDeepSort()) {\n return helpers.wrapWithDeepSort(qb, { qb: this, db, uid });\n }\n\n return qb;\n },\n\n async execute({ mapResults = true } = {}) {\n try {\n const qb = this.getKnexQuery();\n\n const transaction = transactionCtx.get();\n if (transaction) {\n qb.transacting(transaction);\n }\n\n const rows = await qb;\n\n if (state.populate && !_.isNil(rows)) {\n await helpers.applyPopulate(_.castArray(rows), state.populate, {\n qb: this,\n uid,\n db,\n });\n }\n\n let results = rows;\n if (mapResults && state.type === 'select') {\n results = helpers.fromRow(meta, rows);\n }\n\n return results;\n } catch (error) {\n if (error instanceof Error) {\n db.dialect.transformErrors(error);\n } else {\n throw error;\n }\n }\n },\n\n stream({ mapResults = true } = {}) {\n if (state.type === 'select') {\n return new helpers.ReadableQuery({ qb: this, db, uid, mapResults });\n }\n\n throw new DatabaseError(\n `query-builder.stream() has been called with an unsupported query type: \"${state.type}\"`\n );\n },\n };\n};\n\nexport default createQueryBuilder;\n"],"names":["createQueryBuilder","uid","db","initialState","meta","metadata","get","tableName","state","_","defaults","type","select","count","max","first","data","where","joins","populate","limit","offset","transaction","forUpdate","onConflict","merge","ignore","orderBy","groupBy","increments","decrements","aliasCounter","filters","search","processed","getAlias","alias","clone","args","uniq","castArray","addSelect","insert","delete","ref","name","connection","helpers","update","increment","column","amount","push","decrement","isPlainObject","Error","query","transacting","init","params","_q","isNil","join","targetField","model","attribute","attributes","qb","refAlias","attributeName","mustUseAlias","includes","aliasColumn","key","indexOf","raw","bind","shouldUseSubQuery","length","runSubQuery","originalType","subQB","getKnexQuery","nestedSubQuery","getConnection","from","as","whereIn","processState","isFunction","processSelect","shouldUseDistinct","isEmpty","shouldUseDeepSort","filter","ob","col","split","i","el","isRelationAttribute","isAliasedRelation","Object","values","map","field","isKnexQuery","joinsOrderByColumns","flatMap","keys","orderByColumns","aliasedTableName","distinct","dbColumnName","countDistinct","dialect","useReturning","has","returning","truncate","forEach","incr","decr","knexOrderBy","entry","rawExpression","isI18n","order","subQb","execute","mapResults","transactionCtx","rows","results","error","transformErrors","stream","DatabaseError"],"mappings":"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"}
1
+ {"version":3,"file":"query-builder.mjs","sources":["../../src/query/query-builder.ts"],"sourcesContent":["import type { Knex } from 'knex';\nimport _ from 'lodash/fp';\n\nimport type { Database } from '..';\n\nimport { DatabaseError } from '../errors';\nimport { transactionCtx } from '../transaction-context';\nimport { isKnexQuery } from '../utils/knex';\nimport * as helpers from './helpers';\nimport type { Join } from './helpers/join';\nimport type { OrderByValue } from './helpers/order-by';\n\ninterface State {\n type: 'select' | 'insert' | 'update' | 'delete' | 'count' | 'max' | 'truncate';\n select: Array<string | Knex.Raw>;\n count: string | null;\n max: string | null;\n first: boolean;\n data: Record<string, unknown> | (null | Record<string, unknown>)[] | null;\n where: Record<string, unknown>[];\n joins: Join[];\n populate: object | null;\n limit: number | null;\n offset: number | null;\n transaction: any;\n forUpdate: boolean;\n onConflict: any;\n merge: any;\n ignore: boolean;\n orderBy: any[];\n groupBy: any[];\n increments: any[];\n decrements: any[];\n aliasCounter: number;\n filters: any;\n search: string;\n processed: boolean;\n}\n\nexport interface QueryBuilder {\n alias: string;\n state: State;\n raw: Knex.RawBuilder;\n\n getAlias(): string;\n\n clone(): QueryBuilder;\n\n select(args: string | Array<string | Knex.Raw>): QueryBuilder;\n\n addSelect(args: string | string[]): QueryBuilder;\n\n insert<TData extends Record<string, unknown> | Record<string, unknown>[]>(\n data: TData\n ): QueryBuilder;\n\n onConflict(args: any): QueryBuilder;\n\n merge(args: any): QueryBuilder;\n\n ignore(): QueryBuilder;\n\n delete(): QueryBuilder;\n\n ref(name: string): any;\n\n update<TData extends Record<string, unknown>>(data: TData): QueryBuilder;\n\n increment(column: string, amount?: number): QueryBuilder;\n\n decrement(column: string, amount?: number): QueryBuilder;\n\n count(count?: string): QueryBuilder;\n\n max(column: string): QueryBuilder;\n\n where(where?: object): QueryBuilder;\n\n limit(limit: number): QueryBuilder;\n\n offset(offset: number): QueryBuilder;\n\n orderBy(orderBy: any): QueryBuilder;\n\n groupBy(groupBy: any): QueryBuilder;\n\n populate(populate: any): QueryBuilder;\n\n search(query: string): QueryBuilder;\n\n transacting(transaction: any): QueryBuilder;\n\n forUpdate(): QueryBuilder;\n\n init(params?: any): QueryBuilder;\n\n filters(filters: any): void;\n\n first(): QueryBuilder;\n\n join(join: any): QueryBuilder;\n\n mustUseAlias(): boolean;\n\n aliasColumn(key: any, alias?: string): any;\n\n shouldUseSubQuery(): boolean;\n\n runSubQuery(): any;\n\n processState(): void;\n\n ensurePaginationOrderStability(): void;\n\n shouldUseDistinct(): boolean;\n\n shouldUseDeepSort(): boolean;\n\n processSelect(): void;\n\n getKnexQuery(): Knex.QueryBuilder;\n\n execute<T>(options?: { mapResults?: boolean }): Promise<T>;\n\n stream(options?: { mapResults?: boolean }): helpers.ReadableQuery;\n}\n\nconst createQueryBuilder = (\n uid: string,\n db: Database,\n initialState: Partial<State> = {}\n): QueryBuilder => {\n const meta = db.metadata.get(uid);\n const { tableName } = meta;\n\n const state: State = _.defaults(\n {\n type: 'select',\n select: [],\n count: null,\n max: null,\n first: false,\n data: null,\n where: [],\n joins: [],\n populate: null,\n limit: null,\n offset: null,\n transaction: null,\n forUpdate: false,\n onConflict: null,\n merge: null,\n ignore: false,\n orderBy: [],\n groupBy: [],\n increments: [],\n decrements: [],\n aliasCounter: 0,\n filters: null,\n search: null,\n processed: false,\n },\n initialState\n );\n\n const getAlias = () => {\n const alias = `t${state.aliasCounter}`;\n\n state.aliasCounter += 1;\n\n return alias;\n };\n\n return {\n alias: getAlias(),\n getAlias,\n state,\n\n clone() {\n return createQueryBuilder(uid, db, state);\n },\n\n select(args) {\n state.type = 'select';\n state.select = _.uniq(_.castArray(args));\n\n return this;\n },\n\n addSelect(args) {\n state.select = _.uniq([...state.select, ..._.castArray(args)]);\n\n return this;\n },\n\n insert(data) {\n state.type = 'insert';\n state.data = data;\n\n return this;\n },\n\n onConflict(args) {\n state.onConflict = args;\n\n return this;\n },\n\n merge(args) {\n state.merge = args;\n\n return this;\n },\n\n ignore() {\n state.ignore = true;\n\n return this;\n },\n\n delete() {\n state.type = 'delete';\n\n return this;\n },\n\n ref(name) {\n return db.connection.ref(helpers.toColumnName(meta, name));\n },\n\n update(data) {\n state.type = 'update';\n state.data = data;\n\n return this;\n },\n\n increment(column, amount = 1) {\n state.type = 'update';\n state.increments.push({ column, amount });\n\n return this;\n },\n\n decrement(column, amount = 1) {\n state.type = 'update';\n state.decrements.push({ column, amount });\n\n return this;\n },\n\n count(count = 'id') {\n state.type = 'count';\n state.count = count;\n\n return this;\n },\n\n max(column: string) {\n state.type = 'max';\n state.max = column;\n\n return this;\n },\n\n where(where: Record<string, unknown> = {}) {\n if (!_.isPlainObject(where)) {\n throw new Error('Where must be an object');\n }\n\n state.where.push(where);\n\n return this;\n },\n\n limit(limit) {\n state.limit = limit;\n return this;\n },\n\n offset(offset) {\n state.offset = offset;\n return this;\n },\n\n orderBy(orderBy) {\n state.orderBy = orderBy;\n return this;\n },\n\n groupBy(groupBy) {\n state.groupBy = groupBy;\n return this;\n },\n\n populate(populate) {\n state.populate = populate;\n return this;\n },\n\n search(query) {\n state.search = query;\n return this;\n },\n\n transacting(transaction) {\n state.transaction = transaction;\n return this;\n },\n\n forUpdate() {\n state.forUpdate = true;\n return this;\n },\n\n init(params = {}) {\n const { _q, filters, where, select, limit, offset, orderBy, groupBy, populate } = params;\n\n if (!_.isNil(where)) {\n this.where(where);\n }\n\n if (!_.isNil(_q)) {\n this.search(_q);\n }\n\n if (!_.isNil(select)) {\n this.select(select);\n } else {\n this.select('*');\n }\n\n if (!_.isNil(limit)) {\n this.limit(limit);\n }\n\n if (!_.isNil(offset)) {\n this.offset(offset);\n }\n\n if (!_.isNil(orderBy)) {\n this.orderBy(orderBy);\n }\n\n if (!_.isNil(groupBy)) {\n this.groupBy(groupBy);\n }\n\n if (!_.isNil(populate)) {\n this.populate(populate);\n }\n\n if (!_.isNil(filters)) {\n this.filters(filters);\n }\n\n return this;\n },\n\n filters(filters) {\n state.filters = filters;\n },\n\n first() {\n state.first = true;\n return this;\n },\n\n join(join) {\n if (!join.targetField) {\n state.joins.push(join);\n return this;\n }\n\n const model = db.metadata.get(uid);\n const attribute = model.attributes[join.targetField];\n\n helpers.createJoin(\n { db, qb: this, uid },\n {\n alias: this.alias,\n refAlias: join.alias,\n attributeName: join.targetField,\n attribute,\n }\n );\n\n return this;\n },\n\n mustUseAlias() {\n return ['select', 'count'].includes(state.type);\n },\n\n aliasColumn(key: string | unknown, alias: string): string | unknown {\n if (typeof key !== 'string') {\n return key;\n }\n\n if (key.indexOf('.') >= 0) {\n return key;\n }\n\n if (!_.isNil(alias)) {\n return `${alias}.${key}`;\n }\n\n return this.mustUseAlias() ? `${this.alias}.${key}` : key;\n },\n\n raw: db.connection.raw.bind(db.connection),\n\n shouldUseSubQuery() {\n return ['delete', 'update'].includes(state.type) && state.joins.length > 0;\n },\n\n runSubQuery() {\n const originalType = state.type;\n\n this.select('id');\n const subQB = this.getKnexQuery();\n\n const nestedSubQuery = db.getConnection().select('id').from(subQB.as('subQuery'));\n const connection = db.getConnection(tableName);\n\n return (connection[originalType] as Knex)().whereIn('id', nestedSubQuery);\n },\n\n processState() {\n if (this.state.processed) {\n return;\n }\n\n state.orderBy = helpers.processOrderBy(state.orderBy, { qb: this, uid, db });\n\n if (!_.isNil(state.filters)) {\n if (_.isFunction(state.filters)) {\n const filters = state.filters({ qb: this, uid, meta, db });\n\n if (!_.isNil(filters)) {\n state.where.push(filters);\n }\n } else {\n state.where.push(state.filters);\n }\n }\n\n state.where = helpers.processWhere(state.where, { qb: this, uid, db });\n state.populate = helpers.processPopulate(state.populate, { qb: this, uid, db });\n\n state.data = helpers.toRow(meta, state.data);\n\n this.ensurePaginationOrderStability();\n\n this.processSelect();\n\n this.state.processed = true;\n },\n\n /**\n * OFFSET/LIMIT without a unique ORDER BY is undefined behavior on SQL databases (notably MySQL).\n * That can repeat or skip rows across pages. Deep sort already appends a primary-key tie-breaker;\n * for all other paginated selects, append id ASC when it is not already the last sort key.\n */\n ensurePaginationOrderStability() {\n if (state.type !== 'select' || state.first) {\n return;\n }\n\n if (state.limit === null && state.offset === null) {\n return;\n }\n\n if (state.limit === -1) {\n return;\n }\n\n if (this.shouldUseDeepSort()) {\n return;\n }\n\n if (!meta.attributes.id) {\n return;\n }\n\n const idColumnName = helpers.toColumnName(meta, 'id');\n const aliasedId = this.aliasColumn(idColumnName);\n const lastOrder = state.orderBy[state.orderBy.length - 1];\n\n if (lastOrder && lastOrder.column === aliasedId) {\n return;\n }\n\n state.orderBy = [...state.orderBy, { column: aliasedId, order: 'asc' }];\n },\n\n shouldUseDistinct() {\n return state.joins.length > 0 && _.isEmpty(state.groupBy);\n },\n\n shouldUseDeepSort() {\n return (\n state.orderBy\n .filter((ob: any) => 'column' in ob && ob.column.indexOf('.') >= 0)\n .filter((ob: any) => {\n const col = ob.column.split('.');\n\n for (let i = 0; i < col.length - 1; i += 1) {\n const el = col[i];\n\n // order by \"rel\".\"xxx\"\n const isRelationAttribute = meta.attributes[el]?.type === 'relation';\n\n // order by \"t2\".\"xxx\"\n const isAliasedRelation = Object.values(state.joins)\n .map((join) => join.alias)\n .includes(el);\n\n if (isRelationAttribute || isAliasedRelation) {\n return true;\n }\n }\n\n return false;\n }).length > 0\n );\n },\n\n processSelect() {\n state.select = state.select.map((field) => {\n if (isKnexQuery(field)) {\n return field;\n }\n\n return helpers.toColumnName(meta, field);\n });\n\n if (this.shouldUseDistinct()) {\n const joinsOrderByColumns = state.joins.flatMap((join) => {\n return _.keys(join.orderBy).map((key) => this.aliasColumn(key, join.alias));\n });\n // Only include column-based orderBy entries (skip raw expressions like status)\n const orderByColumns = state.orderBy\n .filter((ob: any) => 'column' in ob)\n .map((ob: any) => ob.column);\n\n state.select = _.uniq([...joinsOrderByColumns, ...orderByColumns, ...state.select]);\n }\n },\n\n getKnexQuery() {\n if (!state.type) {\n this.select('*');\n }\n\n const aliasedTableName = this.mustUseAlias() ? `${tableName} as ${this.alias}` : tableName;\n\n const qb = db.getConnection(aliasedTableName);\n\n // The state should always be processed before calling shouldUseSubQuery as it\n // relies on the presence or absence of joins to determine the need of a subquery\n this.processState();\n\n if (this.shouldUseSubQuery()) {\n return this.runSubQuery();\n }\n\n switch (state.type) {\n case 'select': {\n qb.select(state.select.map((column) => this.aliasColumn(column)));\n\n if (this.shouldUseDistinct()) {\n qb.distinct();\n }\n\n break;\n }\n case 'count': {\n const dbColumnName = this.aliasColumn(helpers.toColumnName(meta, state.count));\n\n if (this.shouldUseDistinct()) {\n qb.countDistinct({ count: dbColumnName });\n } else {\n qb.count({ count: dbColumnName });\n }\n break;\n }\n case 'max': {\n const dbColumnName = this.aliasColumn(helpers.toColumnName(meta, state.max));\n qb.max({ max: dbColumnName });\n break;\n }\n case 'insert': {\n qb.insert(state.data);\n\n if (db.dialect.useReturning() && _.has('id', meta.attributes)) {\n qb.returning('id');\n }\n\n break;\n }\n case 'update': {\n if (state.data) {\n qb.update(state.data);\n }\n break;\n }\n case 'delete': {\n qb.delete();\n\n break;\n }\n case 'truncate': {\n qb.truncate();\n break;\n }\n default: {\n throw new Error('Unknown query type');\n }\n }\n\n if (state.transaction) {\n qb.transacting(state.transaction);\n }\n\n if (state.forUpdate) {\n qb.forUpdate();\n }\n\n if (!_.isEmpty(state.increments)) {\n state.increments.forEach((incr) => qb.increment(incr.column, incr.amount));\n }\n\n if (!_.isEmpty(state.decrements)) {\n state.decrements.forEach((decr) => qb.decrement(decr.column, decr.amount));\n }\n\n if (state.onConflict) {\n if (state.merge) {\n qb.onConflict(state.onConflict).merge(state.merge);\n } else if (state.ignore) {\n qb.onConflict(state.onConflict).ignore();\n }\n }\n\n if (state.limit) {\n qb.limit(state.limit);\n }\n\n if (state.offset) {\n qb.offset(state.offset);\n }\n\n if (state.first) {\n qb.first();\n }\n\n if (state.groupBy.length > 0) {\n qb.groupBy(state.groupBy);\n }\n\n // if there are joins and it is a delete or update use a sub query\n if (state.where) {\n helpers.applyWhere(qb, state.where);\n }\n\n // if there are joins and it is a delete or update use a sub query\n if (state.search) {\n qb.where((subQb) => {\n helpers.applySearch(subQb, state.search, { qb: this, db, uid });\n });\n }\n\n /**\n * Join `orderBy` (e.g. join-table ordinal for relations) must precede root `state.orderBy`\n * when both are emitted. Otherwise pagination stability (`ensurePaginationOrderStability`)\n * appending `id ASC` on the root alias wins over distinct target ids and breaks relation ordering.\n */\n if (state.joins.length > 0) {\n helpers.applyJoins(qb, state.joins);\n }\n\n if (state.orderBy.length > 0) {\n // `processState` normalizes entries to OrderByValue[] (string/object input from `.init()`).\n const knexOrderBy: helpers.KnexOrderByColumnDescriptor[] = (\n state.orderBy as OrderByValue[]\n ).map((entry) => helpers.toKnexOrderByDescriptor(db, tableName, this.alias, entry));\n // Knex compound `orderBy` typings list `column: string | QueryBuilder` — `Knex.Raw` works at runtime\n // (e.g. `status` sort). See helpers.toKnexOrderByDescriptor / buildStatusSortExpression.\n qb.orderBy(knexOrderBy as never);\n }\n\n if (this.shouldUseDeepSort()) {\n return helpers.wrapWithDeepSort(qb, { qb: this, db, uid });\n }\n\n return qb;\n },\n\n async execute({ mapResults = true } = {}) {\n try {\n const qb = this.getKnexQuery();\n\n const transaction = transactionCtx.get();\n if (transaction) {\n qb.transacting(transaction);\n }\n\n const rows = await qb;\n\n if (state.populate && !_.isNil(rows)) {\n await helpers.applyPopulate(_.castArray(rows), state.populate, {\n qb: this,\n uid,\n db,\n });\n }\n\n let results = rows;\n if (mapResults && state.type === 'select') {\n results = helpers.fromRow(meta, rows);\n }\n\n return results;\n } catch (error) {\n if (error instanceof Error) {\n db.dialect.transformErrors(error);\n } else {\n throw error;\n }\n }\n },\n\n stream({ mapResults = true } = {}) {\n if (state.type === 'select') {\n return new helpers.ReadableQuery({ qb: this, db, uid, mapResults });\n }\n\n throw new DatabaseError(\n `query-builder.stream() has been called with an unsupported query type: \"${state.type}\"`\n );\n },\n };\n};\n\nexport default createQueryBuilder;\n"],"names":["createQueryBuilder","uid","db","initialState","meta","metadata","get","tableName","state","_","defaults","type","select","count","max","first","data","where","joins","populate","limit","offset","transaction","forUpdate","onConflict","merge","ignore","orderBy","groupBy","increments","decrements","aliasCounter","filters","search","processed","getAlias","alias","clone","args","uniq","castArray","addSelect","insert","delete","ref","name","connection","helpers","update","increment","column","amount","push","decrement","isPlainObject","Error","query","transacting","init","params","_q","isNil","join","targetField","model","attribute","attributes","qb","refAlias","attributeName","mustUseAlias","includes","aliasColumn","key","indexOf","raw","bind","shouldUseSubQuery","length","runSubQuery","originalType","subQB","getKnexQuery","nestedSubQuery","getConnection","from","as","whereIn","processState","isFunction","ensurePaginationOrderStability","processSelect","shouldUseDeepSort","id","idColumnName","aliasedId","lastOrder","order","shouldUseDistinct","isEmpty","filter","ob","col","split","i","el","isRelationAttribute","isAliasedRelation","Object","values","map","field","isKnexQuery","joinsOrderByColumns","flatMap","keys","orderByColumns","aliasedTableName","distinct","dbColumnName","countDistinct","dialect","useReturning","has","returning","truncate","forEach","incr","decr","subQb","knexOrderBy","entry","execute","mapResults","transactionCtx","rows","results","error","transformErrors","stream","DatabaseError"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"storage.d.ts","sourceRoot":"","sources":["../../src/schema/storage.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,IAAI,CAAC;AACnC,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;6BAIlB,QAAQ;YAmBV,QAAQ;QACpB,EAAE,EAAE,MAAM,CAAC;QACX,IAAI,EAAE,IAAI,CAAC;QACX,IAAI,EAAE,MAAM,CAAC;QACb,MAAM,EAAE,MAAM,CAAC;KAChB,GAAG,IAAI,CAAC;uBAmCU,MAAM;gBAIP,MAAM;;;AA/D5B,wBAuFE"}
1
+ {"version":3,"file":"storage.d.ts","sourceRoot":"","sources":["../../src/schema/storage.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,IAAI,CAAC;AACnC,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;6BAIlB,QAAQ;YAmBV,QAAQ;QACpB,EAAE,EAAE,MAAM,CAAC;QACX,IAAI,EAAE,IAAI,CAAC;QACX,IAAI,EAAE,MAAM,CAAC;QACb,MAAM,EAAE,MAAM,CAAC;KAChB,GAAG,IAAI,CAAC;uBAmCU,MAAM;gBASP,MAAM;;;AApE5B,wBA4FE"}
@@ -42,7 +42,12 @@ var createSchemaStorage = ((db)=>{
42
42
  };
43
43
  },
44
44
  hashSchema (schema) {
45
- return crypto.createHash('sha256').update(JSON.stringify(schema)).digest('hex');
45
+ // Sort tables by name for deterministic hashing regardless of insertion order
46
+ const sorted = {
47
+ ...schema,
48
+ tables: schema.tables.toSorted((a, b)=>a.name.localeCompare(b.name))
49
+ };
50
+ return crypto.createHash('sha256').update(JSON.stringify(sorted)).digest('hex');
46
51
  },
47
52
  async add (schema) {
48
53
  await checkTableExists();
@@ -1 +1 @@
1
- {"version":3,"file":"storage.js","sources":["../../src/schema/storage.ts"],"sourcesContent":["import crypto from 'crypto';\n\nimport type { Database } from '..';\nimport type { Schema } from './types';\n\nconst TABLE_NAME = 'strapi_database_schema';\n\nexport default (db: Database) => {\n const hasSchemaTable = () => db.getSchemaConnection().hasTable(TABLE_NAME);\n\n const createSchemaTable = () => {\n return db.getSchemaConnection().createTable(TABLE_NAME, (t) => {\n t.increments('id');\n t.json('schema');\n t.datetime('time', { useTz: false });\n t.string('hash');\n });\n };\n\n const checkTableExists = async () => {\n if (!(await hasSchemaTable())) {\n await createSchemaTable();\n }\n };\n\n return {\n async read(): Promise<{\n id: number;\n time: Date;\n hash: string;\n schema: Schema;\n } | null> {\n await checkTableExists();\n\n // NOTE: We get the ID first before fetching the exact entry for performance on MySQL/MariaDB\n // See: https://github.com/strapi/strapi/issues/20312\n const getSchemaID = await db\n .getConnection()\n .select('id')\n .from(TABLE_NAME)\n .orderBy('time', 'DESC')\n .first();\n\n if (!getSchemaID) {\n return null;\n }\n\n const res = await db\n .getConnection()\n .select('*')\n .from(TABLE_NAME)\n .where({ id: getSchemaID.id })\n .first();\n\n if (!res) {\n return null;\n }\n\n const parsedSchema = typeof res.schema === 'object' ? res.schema : JSON.parse(res.schema);\n\n return {\n ...res,\n schema: parsedSchema,\n };\n },\n\n hashSchema(schema: Schema) {\n return crypto.createHash('sha256').update(JSON.stringify(schema)).digest('hex');\n },\n\n async add(schema: Schema) {\n await checkTableExists();\n\n // NOTE: we can remove this to add history\n await db.getConnection(TABLE_NAME).delete();\n\n const time = new Date();\n\n await db\n .getConnection()\n .insert({\n schema: JSON.stringify(schema),\n hash: this.hashSchema(schema),\n time,\n })\n .into(TABLE_NAME);\n },\n\n async clear() {\n await checkTableExists();\n\n await db.getConnection(TABLE_NAME).truncate();\n },\n };\n};\n"],"names":["TABLE_NAME","db","hasSchemaTable","getSchemaConnection","hasTable","createSchemaTable","createTable","t","increments","json","datetime","useTz","string","checkTableExists","read","getSchemaID","getConnection","select","from","orderBy","first","res","where","id","parsedSchema","schema","JSON","parse","hashSchema","crypto","createHash","update","stringify","digest","add","delete","time","Date","insert","hash","into","clear","truncate"],"mappings":"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"}
1
+ {"version":3,"file":"storage.js","sources":["../../src/schema/storage.ts"],"sourcesContent":["import crypto from 'crypto';\n\nimport type { Database } from '..';\nimport type { Schema } from './types';\n\nconst TABLE_NAME = 'strapi_database_schema';\n\nexport default (db: Database) => {\n const hasSchemaTable = () => db.getSchemaConnection().hasTable(TABLE_NAME);\n\n const createSchemaTable = () => {\n return db.getSchemaConnection().createTable(TABLE_NAME, (t) => {\n t.increments('id');\n t.json('schema');\n t.datetime('time', { useTz: false });\n t.string('hash');\n });\n };\n\n const checkTableExists = async () => {\n if (!(await hasSchemaTable())) {\n await createSchemaTable();\n }\n };\n\n return {\n async read(): Promise<{\n id: number;\n time: Date;\n hash: string;\n schema: Schema;\n } | null> {\n await checkTableExists();\n\n // NOTE: We get the ID first before fetching the exact entry for performance on MySQL/MariaDB\n // See: https://github.com/strapi/strapi/issues/20312\n const getSchemaID = await db\n .getConnection()\n .select('id')\n .from(TABLE_NAME)\n .orderBy('time', 'DESC')\n .first();\n\n if (!getSchemaID) {\n return null;\n }\n\n const res = await db\n .getConnection()\n .select('*')\n .from(TABLE_NAME)\n .where({ id: getSchemaID.id })\n .first();\n\n if (!res) {\n return null;\n }\n\n const parsedSchema = typeof res.schema === 'object' ? res.schema : JSON.parse(res.schema);\n\n return {\n ...res,\n schema: parsedSchema,\n };\n },\n\n hashSchema(schema: Schema) {\n // Sort tables by name for deterministic hashing regardless of insertion order\n const sorted = {\n ...schema,\n tables: schema.tables.toSorted((a, b) => a.name.localeCompare(b.name)),\n };\n return crypto.createHash('sha256').update(JSON.stringify(sorted)).digest('hex');\n },\n\n async add(schema: Schema) {\n await checkTableExists();\n\n // NOTE: we can remove this to add history\n await db.getConnection(TABLE_NAME).delete();\n\n const time = new Date();\n\n await db\n .getConnection()\n .insert({\n schema: JSON.stringify(schema),\n hash: this.hashSchema(schema),\n time,\n })\n .into(TABLE_NAME);\n },\n\n async clear() {\n await checkTableExists();\n\n await db.getConnection(TABLE_NAME).truncate();\n },\n };\n};\n"],"names":["TABLE_NAME","db","hasSchemaTable","getSchemaConnection","hasTable","createSchemaTable","createTable","t","increments","json","datetime","useTz","string","checkTableExists","read","getSchemaID","getConnection","select","from","orderBy","first","res","where","id","parsedSchema","schema","JSON","parse","hashSchema","sorted","tables","toSorted","a","b","name","localeCompare","crypto","createHash","update","stringify","digest","add","delete","time","Date","insert","hash","into","clear","truncate"],"mappings":"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"}
@@ -40,7 +40,12 @@ var createSchemaStorage = ((db)=>{
40
40
  };
41
41
  },
42
42
  hashSchema (schema) {
43
- return crypto.createHash('sha256').update(JSON.stringify(schema)).digest('hex');
43
+ // Sort tables by name for deterministic hashing regardless of insertion order
44
+ const sorted = {
45
+ ...schema,
46
+ tables: schema.tables.toSorted((a, b)=>a.name.localeCompare(b.name))
47
+ };
48
+ return crypto.createHash('sha256').update(JSON.stringify(sorted)).digest('hex');
44
49
  },
45
50
  async add (schema) {
46
51
  await checkTableExists();
@@ -1 +1 @@
1
- {"version":3,"file":"storage.mjs","sources":["../../src/schema/storage.ts"],"sourcesContent":["import crypto from 'crypto';\n\nimport type { Database } from '..';\nimport type { Schema } from './types';\n\nconst TABLE_NAME = 'strapi_database_schema';\n\nexport default (db: Database) => {\n const hasSchemaTable = () => db.getSchemaConnection().hasTable(TABLE_NAME);\n\n const createSchemaTable = () => {\n return db.getSchemaConnection().createTable(TABLE_NAME, (t) => {\n t.increments('id');\n t.json('schema');\n t.datetime('time', { useTz: false });\n t.string('hash');\n });\n };\n\n const checkTableExists = async () => {\n if (!(await hasSchemaTable())) {\n await createSchemaTable();\n }\n };\n\n return {\n async read(): Promise<{\n id: number;\n time: Date;\n hash: string;\n schema: Schema;\n } | null> {\n await checkTableExists();\n\n // NOTE: We get the ID first before fetching the exact entry for performance on MySQL/MariaDB\n // See: https://github.com/strapi/strapi/issues/20312\n const getSchemaID = await db\n .getConnection()\n .select('id')\n .from(TABLE_NAME)\n .orderBy('time', 'DESC')\n .first();\n\n if (!getSchemaID) {\n return null;\n }\n\n const res = await db\n .getConnection()\n .select('*')\n .from(TABLE_NAME)\n .where({ id: getSchemaID.id })\n .first();\n\n if (!res) {\n return null;\n }\n\n const parsedSchema = typeof res.schema === 'object' ? res.schema : JSON.parse(res.schema);\n\n return {\n ...res,\n schema: parsedSchema,\n };\n },\n\n hashSchema(schema: Schema) {\n return crypto.createHash('sha256').update(JSON.stringify(schema)).digest('hex');\n },\n\n async add(schema: Schema) {\n await checkTableExists();\n\n // NOTE: we can remove this to add history\n await db.getConnection(TABLE_NAME).delete();\n\n const time = new Date();\n\n await db\n .getConnection()\n .insert({\n schema: JSON.stringify(schema),\n hash: this.hashSchema(schema),\n time,\n })\n .into(TABLE_NAME);\n },\n\n async clear() {\n await checkTableExists();\n\n await db.getConnection(TABLE_NAME).truncate();\n },\n };\n};\n"],"names":["TABLE_NAME","db","hasSchemaTable","getSchemaConnection","hasTable","createSchemaTable","createTable","t","increments","json","datetime","useTz","string","checkTableExists","read","getSchemaID","getConnection","select","from","orderBy","first","res","where","id","parsedSchema","schema","JSON","parse","hashSchema","crypto","createHash","update","stringify","digest","add","delete","time","Date","insert","hash","into","clear","truncate"],"mappings":"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"}
1
+ {"version":3,"file":"storage.mjs","sources":["../../src/schema/storage.ts"],"sourcesContent":["import crypto from 'crypto';\n\nimport type { Database } from '..';\nimport type { Schema } from './types';\n\nconst TABLE_NAME = 'strapi_database_schema';\n\nexport default (db: Database) => {\n const hasSchemaTable = () => db.getSchemaConnection().hasTable(TABLE_NAME);\n\n const createSchemaTable = () => {\n return db.getSchemaConnection().createTable(TABLE_NAME, (t) => {\n t.increments('id');\n t.json('schema');\n t.datetime('time', { useTz: false });\n t.string('hash');\n });\n };\n\n const checkTableExists = async () => {\n if (!(await hasSchemaTable())) {\n await createSchemaTable();\n }\n };\n\n return {\n async read(): Promise<{\n id: number;\n time: Date;\n hash: string;\n schema: Schema;\n } | null> {\n await checkTableExists();\n\n // NOTE: We get the ID first before fetching the exact entry for performance on MySQL/MariaDB\n // See: https://github.com/strapi/strapi/issues/20312\n const getSchemaID = await db\n .getConnection()\n .select('id')\n .from(TABLE_NAME)\n .orderBy('time', 'DESC')\n .first();\n\n if (!getSchemaID) {\n return null;\n }\n\n const res = await db\n .getConnection()\n .select('*')\n .from(TABLE_NAME)\n .where({ id: getSchemaID.id })\n .first();\n\n if (!res) {\n return null;\n }\n\n const parsedSchema = typeof res.schema === 'object' ? res.schema : JSON.parse(res.schema);\n\n return {\n ...res,\n schema: parsedSchema,\n };\n },\n\n hashSchema(schema: Schema) {\n // Sort tables by name for deterministic hashing regardless of insertion order\n const sorted = {\n ...schema,\n tables: schema.tables.toSorted((a, b) => a.name.localeCompare(b.name)),\n };\n return crypto.createHash('sha256').update(JSON.stringify(sorted)).digest('hex');\n },\n\n async add(schema: Schema) {\n await checkTableExists();\n\n // NOTE: we can remove this to add history\n await db.getConnection(TABLE_NAME).delete();\n\n const time = new Date();\n\n await db\n .getConnection()\n .insert({\n schema: JSON.stringify(schema),\n hash: this.hashSchema(schema),\n time,\n })\n .into(TABLE_NAME);\n },\n\n async clear() {\n await checkTableExists();\n\n await db.getConnection(TABLE_NAME).truncate();\n },\n };\n};\n"],"names":["TABLE_NAME","db","hasSchemaTable","getSchemaConnection","hasTable","createSchemaTable","createTable","t","increments","json","datetime","useTz","string","checkTableExists","read","getSchemaID","getConnection","select","from","orderBy","first","res","where","id","parsedSchema","schema","JSON","parse","hashSchema","sorted","tables","toSorted","a","b","name","localeCompare","crypto","createHash","update","stringify","digest","add","delete","time","Date","insert","hash","into","clear","truncate"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@strapi/database",
3
- "version": "5.45.0",
3
+ "version": "5.46.0",
4
4
  "description": "Strapi's database layer",
5
5
  "homepage": "https://strapi.io",
6
6
  "bugs": {
@@ -43,7 +43,7 @@
43
43
  },
44
44
  "dependencies": {
45
45
  "@paralleldrive/cuid2": "2.2.2",
46
- "@strapi/utils": "5.45.0",
46
+ "@strapi/utils": "5.46.0",
47
47
  "ajv": "8.18.0",
48
48
  "date-fns": "2.30.0",
49
49
  "debug": "4.3.4",
@@ -55,8 +55,8 @@
55
55
  },
56
56
  "devDependencies": {
57
57
  "@types/fs-extra": "11.0.4",
58
- "eslint-config-custom": "5.45.0",
59
- "tsconfig": "5.45.0"
58
+ "eslint-config-custom": "5.46.0",
59
+ "tsconfig": "5.46.0"
60
60
  },
61
61
  "engines": {
62
62
  "node": ">=20.0.0 <=24.x.x",