@strapi/core 5.41.0 → 5.42.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.
@@ -1 +1 @@
1
- {"version":3,"file":"repository.mjs","sources":["../../../src/services/document-service/repository.ts"],"sourcesContent":["import { omit, assoc, merge, curry, isEmpty, pick } from 'lodash/fp';\n\nimport {\n async,\n contentTypes as contentTypesUtils,\n validate,\n errors,\n createModelCache,\n} from '@strapi/utils';\n\nimport type { UID, Modules } from '@strapi/types';\nimport { wrapInTransaction, type RepositoryFactoryMethod } from './common';\nimport * as DP from './draft-and-publish';\nimport * as i18n from './internationalization';\nimport { copyNonLocalizedFields } from './internationalization';\nimport * as components from './components';\n\nimport { createEntriesService } from './entries';\nimport { ALLOWED_DOCUMENT_ROOT_PARAM_KEYS, pickSelectionParams } from './params';\nimport { createDocumentId } from '../../utils/transform-content-types-to-models';\nimport { getDeepPopulate } from './utils/populate';\nimport { transformParamsToQuery } from './transform/query';\nimport { transformParamsDocumentId } from './transform/id-transform';\nimport { createEventManager } from './events';\nimport * as unidirectionalRelations from './utils/unidirectional-relations';\nimport * as bidirectionalRelations from './utils/bidirectional-relations';\nimport entityValidator from '../entity-validator';\nimport { addFirstPublishedAtToDraft, filterDataFirstPublishedAt } from './first-published-at';\nimport { runParallelWithOrderedErrors } from './utils/ordered-parallel';\n\nconst { validators } = validate;\n\n// we have to typecast to reconcile the differences between validator and database getModel\nconst getModel = ((schema: UID.Schema) => strapi.getModel(schema)) as (schema: string) => any;\n\n// config.api.documents.strictParams: false/undefined (pass through), true (throw on invalid)\n\n// BCP 47–style locale format: 2–3 letter language code (any case), optional subtags (-XX or -XXX...), max 35 chars\nconst LOCALE_FORMAT = /^[a-zA-Z]{2,3}(-[a-zA-Z0-9]{2,8})*$/;\nconst MAX_LOCALE_LENGTH = 35;\n\n/** Treat as \"param not provided\": null, undefined, or empty string (e.g. from query/JSON). */\nconst isParamEmpty = (v: unknown): boolean => v === undefined || v === null || v === '';\n\nexport const createContentTypeRepository: RepositoryFactoryMethod = (\n uid,\n validator = entityValidator\n) => {\n const contentType = strapi.contentType(uid);\n const hasDraftAndPublish = contentTypesUtils.hasDraftAndPublish(contentType);\n\n // Define the validations that should be performed\n const sortValidations = ['nonAttributesOperators', 'dynamicZones', 'morphRelations'];\n const fieldValidations = ['scalarAttributes'];\n const filtersValidations = ['nonAttributesOperators', 'dynamicZones', 'morphRelations'];\n const populateValidations = {\n sort: sortValidations,\n field: fieldValidations,\n filters: filtersValidations,\n populate: ['nonAttributesOperators'],\n };\n\n /**\n * Checks status parameter. When strict is true, throws on invalid status.\n * Valid values are 'published' and 'draft'; for types without D&P they are currently ignored but may throw in the future\n */\n const checkStatus = (\n params: Record<string, unknown>,\n strict: boolean\n ): Record<string, unknown> => {\n if (!strict) {\n return params;\n }\n\n if (isParamEmpty(params.status)) {\n delete params.status;\n return params;\n }\n\n if (params.status !== 'published' && params.status !== 'draft') {\n throw new errors.ValidationError(\n `Invalid parameter at 'status'. Expected 'published' or 'draft', received: ${params.status}`\n );\n }\n\n return params;\n };\n\n /**\n * Checks locale parameter. When strict is true, throws on invalid locale value.\n * Accepts only: string (single locale or '*'), array of locale strings (e.g. bulk publish),\n * empty string, null, or undefined (removed but allowed)\n */\n const checkLocale = (\n params: Record<string, unknown>,\n strict: boolean\n ): Record<string, unknown> => {\n if (!strict) {\n return params;\n }\n\n if (isParamEmpty(params.locale)) {\n delete params.locale;\n return params;\n }\n\n // Reject objects (we only accept string, array of strings, empty string, null, undefined)\n if (typeof params.locale === 'object' && !Array.isArray(params.locale)) {\n throw new errors.ValidationError(\n `Invalid parameter at 'locale'. Expected a string, array of strings, empty string, null, or undefined; received: object`,\n { received: params.locale }\n );\n }\n\n const validateAndNormalizeOne = (value: unknown, path: string): string => {\n if (typeof value !== 'string') {\n throw new errors.ValidationError(\n `Invalid parameter at '${path}'. Expected a string, received: ${typeof value}`,\n { received: value }\n );\n }\n if (value === '*') return value;\n const isEmpty = value.length === 0;\n const tooLong = value.length > MAX_LOCALE_LENGTH;\n const invalidFormat = !LOCALE_FORMAT.test(value);\n if (isEmpty || tooLong || invalidFormat) {\n let reason: string;\n if (isEmpty) {\n reason = 'Locale cannot be empty';\n } else if (tooLong) {\n reason = `Locale exceeds maximum length of ${MAX_LOCALE_LENGTH} characters`;\n } else {\n reason = 'Locale must be a valid BCP 47 format (e.g. en, en-US, zh-Hans)';\n }\n throw new errors.ValidationError(`Invalid parameter at '${path}'. ${reason}.`);\n }\n return value;\n };\n\n if (Array.isArray(params.locale)) {\n const filtered = (params.locale as unknown[]).filter(\n (item): item is string => typeof item === 'string' && !isParamEmpty(item)\n );\n if (filtered.length === 0) {\n delete params.locale;\n return params;\n }\n params.locale = filtered.map((item, i) => validateAndNormalizeOne(item, `locale[${i}]`));\n return params;\n }\n\n params.locale = validateAndNormalizeOne(params.locale, 'locale');\n return params;\n };\n\n /**\n * Pagination param parsing (used only when strict).\n * Contract: empty (null/undefined/'') → undefined (omit from result).\n * present but invalid → throw ValidationError.\n * present and valid → return normalized value.\n */\n const parsePaginationInt = (\n name: string,\n value: unknown,\n strict: boolean,\n spec: { min: number; allowMinusOne?: boolean }\n ): number | undefined => {\n if (isParamEmpty(value)) return undefined;\n const num = Number(value);\n const valid =\n Number.isInteger(num) && (num >= spec.min || (spec.allowMinusOne === true && num === -1));\n if (!valid && strict) {\n const expected = spec.allowMinusOne\n ? `integer >= ${spec.min} or -1`\n : `integer >= ${spec.min}`;\n throw new errors.ValidationError(\n `Invalid parameter at '${name}'. Expected ${expected}, received: ${value}`\n );\n }\n return valid ? num : undefined;\n };\n\n const parseWithCount = (value: unknown): boolean | undefined => {\n if (isParamEmpty(value)) return undefined;\n if (typeof value === 'boolean') return value;\n if (typeof value === 'string' && (value === 'true' || value === 'false'))\n return value === 'true';\n throw new errors.ValidationError(\n `Invalid parameter at 'withCount'. Expected a boolean, received: ${typeof value}`\n );\n };\n\n const PAGINATION_KEYS = ['page', 'pageSize', 'start', 'limit', 'withCount'] as const;\n\n /**\n * When strict: empty → omit, invalid → throw, valid → include.\n * When not strict: return params unchanged.\n */\n const checkPagination = (\n params: Record<string, unknown>,\n strict: boolean\n ): Record<string, unknown> => {\n if (!strict) return params;\n\n const hasPage = !isParamEmpty(params.page) || !isParamEmpty(params.pageSize);\n const hasOffset = !isParamEmpty(params.start) || !isParamEmpty(params.limit);\n if (hasPage && hasOffset) {\n throw new errors.ValidationError(\n 'Invalid pagination parameters. Cannot use both page-based (page, pageSize) and offset-based (start, limit) pagination in the same query.'\n );\n }\n\n const page = parsePaginationInt('page', params.page, strict, { min: 1 });\n const pageSize = parsePaginationInt('pageSize', params.pageSize, strict, { min: 1 });\n const start = parsePaginationInt('start', params.start, strict, { min: 0 });\n const limit = parsePaginationInt('limit', params.limit, strict, {\n min: 1,\n allowMinusOne: true,\n });\n const withCount = parseWithCount(params.withCount);\n\n const result = { ...omit(PAGINATION_KEYS, params) };\n if (page !== undefined) result.page = page;\n if (pageSize !== undefined) result.pageSize = pageSize;\n if (start !== undefined) result.start = start;\n if (limit !== undefined) result.limit = limit;\n if (withCount !== undefined) result.withCount = withCount;\n return result;\n };\n\n /**\n * When strict is true, strip to allowed root-level keys so only those reach the query.\n * Extra params (e.g. from content API addQueryParams) are allowed in so middlewares see them,\n * but are stripped here before the query pipeline; they never affect the document query.\n */\n const checkUnrecognizedRootParams = (\n params: Record<string, unknown>,\n strict: boolean\n ): Record<string, unknown> => {\n if (!strict) {\n return params;\n }\n\n return pick(ALLOWED_DOCUMENT_ROOT_PARAM_KEYS as unknown as string[], params) as Record<\n string,\n unknown\n >;\n };\n\n const validateParams = async (\n params: Modules.Documents.Params.All\n ): Promise<Modules.Documents.Params.All> => {\n // Cache model lookups for this request to avoid repeating the same work\n const modelCache = createModelCache(getModel);\n\n const ctx = { schema: contentType, getModel: modelCache.getModel };\n\n // Only validate what is actually provided\n const validations: Promise<unknown>[] = [];\n\n if (params.filters && !isEmpty(params.filters)) {\n validations.push(validators.validateFilters(ctx, params.filters, filtersValidations));\n }\n\n if (params.sort && !isEmpty(params.sort)) {\n validations.push(validators.validateSort(ctx, params.sort, sortValidations));\n }\n\n if (params.fields && !isEmpty(params.fields)) {\n validations.push(validators.validateFields(ctx, params.fields, fieldValidations));\n }\n\n if (params.populate && !isEmpty(params.populate)) {\n validations.push(validators.validatePopulate(ctx, params.populate, populateValidations));\n }\n\n // Run validations together but keep the same error order as before\n await runParallelWithOrderedErrors(validations);\n\n // Clean up cache after validation\n modelCache.clear();\n\n // Strip lookup from params, it's only used internally\n if (params.lookup) {\n throw new errors.ValidationError(\"Invalid params: 'lookup'\");\n }\n\n // Validate status, locale, and pagination based on config\n // config.api.documents.strictParams: false/undefined (pass through), true (throw on invalid)\n const rawStrictParams: unknown = strapi.config.get('api.documents.strictParams', undefined);\n\n if (rawStrictParams !== undefined && rawStrictParams !== false && rawStrictParams !== true) {\n throw new errors.ValidationError(\n `Invalid config.api.documents.strictParams value: \"${rawStrictParams}\". Expected boolean (true or false).`\n );\n }\n\n const strict = rawStrictParams === true;\n\n let processedParams: Record<string, unknown>;\n if (strict) {\n processedParams = checkUnrecognizedRootParams(params as Record<string, unknown>, strict);\n processedParams = checkStatus(processedParams, strict);\n processedParams = checkLocale(processedParams, strict);\n processedParams = checkPagination(processedParams, strict);\n } else {\n processedParams = params as Record<string, unknown>;\n }\n\n return processedParams as Modules.Documents.Params.All;\n };\n\n const entries = createEntriesService(uid, validator);\n\n const eventManager = createEventManager(strapi, uid);\n const emitEvent = curry(eventManager.emitEvent);\n\n async function findMany(params = {} as any) {\n const query = await async.pipe(\n validateParams,\n DP.defaultToDraft,\n DP.statusToLookup(contentType),\n\n i18n.defaultLocale(contentType),\n i18n.multiLocaleToLookup(contentType),\n transformParamsDocumentId(uid),\n transformParamsToQuery(uid)\n )(params || {});\n\n return strapi.db.query(uid).findMany(query);\n }\n\n async function findFirst(params = {} as any) {\n const query = await async.pipe(\n validateParams,\n DP.defaultToDraft,\n DP.statusToLookup(contentType),\n\n i18n.defaultLocale(contentType),\n i18n.localeToLookup(contentType),\n transformParamsDocumentId(uid),\n transformParamsToQuery(uid)\n )(params);\n\n return strapi.db.query(uid).findOne(query);\n }\n\n // TODO: do we really want to add filters on the findOne now that we have findFirst ?\n async function findOne(opts = {} as any) {\n const { documentId, ...params } = opts;\n\n const query = await async.pipe(\n validateParams,\n DP.defaultToDraft,\n DP.statusToLookup(contentType),\n\n i18n.defaultLocale(contentType),\n i18n.localeToLookup(contentType),\n transformParamsDocumentId(uid),\n transformParamsToQuery(uid),\n (query) => assoc('where', { ...query.where, documentId }, query)\n )(params);\n\n return strapi.db.query(uid).findOne(query);\n }\n\n async function deleteDocument(opts = {} as any) {\n const { documentId, ...params } = opts;\n\n const query = await async.pipe(\n validateParams,\n omit('status'),\n i18n.defaultLocale(contentType),\n i18n.multiLocaleToLookup(contentType),\n transformParamsToQuery(uid),\n (query) => assoc('where', { ...query.where, documentId }, query)\n )(params);\n\n if (hasDraftAndPublish && params.status === 'draft') {\n throw new Error('Cannot delete a draft document');\n }\n\n const entriesToDelete = await strapi.db.query(uid).findMany(query);\n\n // Delete all matched entries and its components\n const deletedEntries = await async.map(entriesToDelete, (entryToDelete: any) =>\n entries.delete(entryToDelete.id)\n );\n\n entriesToDelete.forEach(emitEvent('entry.delete'));\n\n return { documentId, entries: deletedEntries };\n }\n\n async function create(opts = {} as any) {\n const { documentId, ...params } = opts;\n\n const queryParams = await async.pipe(\n validateParams,\n DP.filterDataPublishedAt,\n DP.setStatusToDraft(contentType),\n DP.statusToData(contentType),\n i18n.defaultLocale(contentType),\n i18n.localeToData(contentType)\n )(params);\n\n const doc = await entries.create(queryParams);\n\n emitEvent('entry.create', doc);\n\n if (hasDraftAndPublish && params.status === 'published') {\n return publish({\n ...params,\n documentId: doc.documentId,\n }).then((doc) => doc.entries[0]);\n }\n\n return doc;\n }\n\n async function clone(opts = {} as any) {\n const { documentId, ...params } = opts;\n\n const queryParams = await async.pipe(\n validateParams,\n DP.filterDataPublishedAt,\n i18n.defaultLocale(contentType),\n i18n.multiLocaleToLookup(contentType)\n )(params);\n\n // Get deep populate\n const entriesToClone = await strapi.db.query(uid).findMany({\n where: {\n ...queryParams?.lookup,\n documentId,\n // DP Enabled: Clone drafts\n // DP Disabled: Clone only the existing version (published)\n publishedAt: { $null: hasDraftAndPublish },\n },\n populate: getDeepPopulate(uid, { relationalFields: ['id'] }),\n });\n\n const clonedEntries = await async.map(\n entriesToClone,\n async.pipe(\n omit(['id', 'createdAt', 'updatedAt']),\n // assign new documentId\n assoc('documentId', createDocumentId()),\n // Merge new data into it\n (data) => merge(data, queryParams.data),\n (data) => entries.create({ ...queryParams, data, status: 'draft' })\n )\n );\n\n clonedEntries.forEach(emitEvent('entry.create'));\n\n return { documentId: clonedEntries.at(0)?.documentId, entries: clonedEntries };\n }\n\n async function update(opts = {} as any) {\n const { documentId, ...params } = opts;\n\n const queryParams = await async.pipe(\n validateParams,\n DP.filterDataPublishedAt,\n filterDataFirstPublishedAt,\n DP.setStatusToDraft(contentType),\n DP.statusToLookup(contentType),\n DP.statusToData(contentType),\n // Default locale will be set if not provided\n i18n.defaultLocale(contentType),\n i18n.localeToLookup(contentType),\n i18n.localeToData(contentType)\n )(params);\n\n const { data, ...restParams } = await transformParamsDocumentId(uid, queryParams || {});\n const query = transformParamsToQuery(uid, pickSelectionParams(restParams || {}) as any);\n\n // Validation\n // Find if document exists\n const entryToUpdate = await strapi.db\n .query(uid)\n .findOne({ ...query, where: { ...queryParams?.lookup, ...query?.where, documentId } });\n\n let updatedDraft = null;\n if (entryToUpdate) {\n updatedDraft = await entries.update(entryToUpdate, queryParams);\n emitEvent('entry.update', updatedDraft);\n }\n\n if (!updatedDraft) {\n const documentExists = await strapi.db\n .query(contentType.uid)\n .findOne({ where: { documentId } });\n\n if (documentExists) {\n const mergedData = await copyNonLocalizedFields(contentType, documentId, {\n ...queryParams.data,\n documentId,\n });\n\n updatedDraft = await entries.create({\n ...queryParams,\n data: mergedData,\n });\n emitEvent('entry.create', updatedDraft);\n }\n }\n\n if (hasDraftAndPublish && updatedDraft && params.status === 'published') {\n return publish({\n ...params,\n documentId,\n }).then((doc) => doc.entries[0]);\n }\n\n return updatedDraft;\n }\n\n async function count(params = {} as any) {\n const query = await async.pipe(\n validateParams,\n DP.defaultStatus(contentType),\n DP.statusToLookup(contentType),\n\n i18n.defaultLocale(contentType),\n i18n.multiLocaleToLookup(contentType),\n transformParamsToQuery(uid)\n )(params);\n\n return strapi.db.query(uid).count(query);\n }\n\n async function publish(opts = {} as any) {\n const { documentId, ...params } = opts;\n\n const queryParams = await async.pipe(\n validateParams,\n i18n.defaultLocale(contentType),\n i18n.multiLocaleToLookup(contentType)\n )(params);\n\n const [draftsToPublish, oldPublishedVersions] = await Promise.all([\n strapi.db.query(uid).findMany({\n where: {\n ...queryParams?.lookup,\n documentId,\n publishedAt: null, // Ignore lookup\n },\n // Populate relations, media, compos and dz\n populate: getDeepPopulate(uid, { relationalFields: ['documentId', 'locale'] }),\n }),\n strapi.db.query(uid).findMany({\n where: {\n ...queryParams?.lookup,\n documentId,\n publishedAt: { $ne: null },\n },\n select: ['id', 'locale'],\n }),\n ]);\n\n // Load any unidirectional relation targetting the old published entries\n const relationsToSync = await unidirectionalRelations.load(\n uid,\n {\n newVersions: draftsToPublish,\n oldVersions: oldPublishedVersions,\n },\n {\n shouldPropagateRelation: components.createComponentRelationFilter(),\n }\n );\n\n const bidirectionalRelationsToSync = await bidirectionalRelations.load(uid, {\n newVersions: draftsToPublish,\n oldVersions: oldPublishedVersions,\n });\n\n // Delete old published versions\n await async.map(oldPublishedVersions, (entry: any) => entries.delete(entry.id));\n\n // Add firstPublishedAt to draft if it doesn't exist\n const updatedDraft = await async.map(draftsToPublish, (draft: any) =>\n addFirstPublishedAtToDraft(draft, entries.update, contentType)\n );\n\n // Transform draft entry data and create published versions\n const publishedEntries = await async.map(updatedDraft, (draft: any) =>\n entries.publish(draft, queryParams)\n );\n\n // Sync unidirectional relations with the new published entries\n await unidirectionalRelations.sync(\n [...oldPublishedVersions, ...updatedDraft],\n publishedEntries,\n relationsToSync\n );\n\n await bidirectionalRelations.sync(\n [...oldPublishedVersions, ...updatedDraft],\n publishedEntries,\n bidirectionalRelationsToSync\n );\n\n publishedEntries.forEach(emitEvent('entry.publish'));\n\n return { documentId, entries: publishedEntries };\n }\n\n async function unpublish(opts = {} as any) {\n const { documentId, ...params } = opts;\n\n const query = await async.pipe(\n validateParams,\n i18n.defaultLocale(contentType),\n i18n.multiLocaleToLookup(contentType),\n transformParamsToQuery(uid),\n (query) => assoc('where', { ...query.where, documentId, publishedAt: { $ne: null } }, query)\n )(params);\n\n // Delete all published versions\n const versionsToDelete = await strapi.db.query(uid).findMany(query);\n await async.map(versionsToDelete, (entry: any) => entries.delete(entry.id));\n\n versionsToDelete.forEach(emitEvent('entry.unpublish'));\n return { documentId, entries: versionsToDelete };\n }\n\n async function discardDraft(opts = {} as any) {\n const { documentId, ...params } = opts;\n\n const queryParams = await async.pipe(\n validateParams,\n i18n.defaultLocale(contentType),\n i18n.multiLocaleToLookup(contentType)\n )(params);\n\n const [versionsToDraft, oldDrafts] = await Promise.all([\n strapi.db.query(uid).findMany({\n where: {\n ...queryParams?.lookup,\n documentId,\n publishedAt: { $ne: null },\n },\n // Populate relations, media, compos and dz\n populate: getDeepPopulate(uid, { relationalFields: ['documentId', 'locale'] }),\n }),\n strapi.db.query(uid).findMany({\n where: {\n ...queryParams?.lookup,\n documentId,\n publishedAt: null,\n },\n select: ['id', 'locale'],\n }),\n ]);\n\n // Load any unidirectional relation targeting the old drafts\n const relationsToSync = await unidirectionalRelations.load(\n uid,\n {\n newVersions: versionsToDraft,\n oldVersions: oldDrafts,\n },\n {\n shouldPropagateRelation: components.createComponentRelationFilter(),\n }\n );\n\n const bidirectionalRelationsToSync = await bidirectionalRelations.load(uid, {\n newVersions: versionsToDraft,\n oldVersions: oldDrafts,\n });\n\n // Delete old drafts\n await async.map(oldDrafts, (entry: any) => entries.delete(entry.id));\n\n // Transform published entry data and create draft versions\n const draftEntries = await async.map(versionsToDraft, (entry: any) =>\n entries.discardDraft(entry, queryParams)\n );\n\n // Sync unidirectional relations with the new draft entries\n await unidirectionalRelations.sync(\n [...oldDrafts, ...versionsToDraft],\n draftEntries,\n relationsToSync\n );\n\n await bidirectionalRelations.sync(\n [...oldDrafts, ...versionsToDraft],\n draftEntries,\n bidirectionalRelationsToSync\n );\n\n draftEntries.forEach(emitEvent('entry.draft-discard'));\n return { documentId, entries: draftEntries };\n }\n\n async function updateComponents(entry: any, data: any) {\n return components.updateComponents(uid, entry, data);\n }\n\n function omitComponentData(data: any) {\n return components.omitComponentData(contentType, data);\n }\n\n return {\n findMany: wrapInTransaction(findMany),\n findFirst: wrapInTransaction(findFirst),\n findOne: wrapInTransaction(findOne),\n delete: wrapInTransaction(deleteDocument),\n create: wrapInTransaction(create),\n clone: wrapInTransaction(clone),\n update: wrapInTransaction(update),\n count: wrapInTransaction(count),\n publish: hasDraftAndPublish ? wrapInTransaction(publish) : (undefined as any),\n unpublish: hasDraftAndPublish ? wrapInTransaction(unpublish) : (undefined as any),\n discardDraft: hasDraftAndPublish ? wrapInTransaction(discardDraft) : (undefined as any),\n\n updateComponents,\n omitComponentData,\n };\n};\n"],"names":["validators","validate","getModel","schema","strapi","LOCALE_FORMAT","MAX_LOCALE_LENGTH","isParamEmpty","v","undefined","createContentTypeRepository","uid","validator","entityValidator","contentType","hasDraftAndPublish","contentTypesUtils","sortValidations","fieldValidations","filtersValidations","populateValidations","sort","field","filters","populate","checkStatus","params","strict","status","errors","ValidationError","checkLocale","locale","Array","isArray","received","validateAndNormalizeOne","value","path","isEmpty","length","tooLong","invalidFormat","test","reason","filtered","filter","item","map","i","parsePaginationInt","name","spec","num","Number","valid","isInteger","min","allowMinusOne","expected","parseWithCount","PAGINATION_KEYS","checkPagination","hasPage","page","pageSize","hasOffset","start","limit","withCount","result","omit","checkUnrecognizedRootParams","pick","ALLOWED_DOCUMENT_ROOT_PARAM_KEYS","validateParams","modelCache","createModelCache","ctx","validations","push","validateFilters","validateSort","fields","validateFields","validatePopulate","runParallelWithOrderedErrors","clear","lookup","rawStrictParams","config","get","processedParams","entries","createEntriesService","eventManager","createEventManager","emitEvent","curry","findMany","query","async","pipe","DP","i18n","transformParamsDocumentId","transformParamsToQuery","db","findFirst","findOne","opts","documentId","assoc","where","deleteDocument","Error","entriesToDelete","deletedEntries","entryToDelete","delete","id","forEach","create","queryParams","doc","publish","then","clone","entriesToClone","publishedAt","$null","getDeepPopulate","relationalFields","clonedEntries","createDocumentId","data","merge","at","update","filterDataFirstPublishedAt","restParams","pickSelectionParams","entryToUpdate","updatedDraft","documentExists","mergedData","copyNonLocalizedFields","count","draftsToPublish","oldPublishedVersions","Promise","all","$ne","select","relationsToSync","unidirectionalRelations","newVersions","oldVersions","shouldPropagateRelation","components","bidirectionalRelationsToSync","bidirectionalRelations","entry","draft","addFirstPublishedAtToDraft","publishedEntries","unpublish","versionsToDelete","discardDraft","versionsToDraft","oldDrafts","draftEntries","updateComponents","omitComponentData","wrapInTransaction"],"mappings":"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"}
1
+ {"version":3,"file":"repository.mjs","sources":["../../../src/services/document-service/repository.ts"],"sourcesContent":["import { omit, assoc, merge, curry, isEmpty, pick } from 'lodash/fp';\n\nimport {\n async,\n contentTypes as contentTypesUtils,\n validate,\n errors,\n createModelCache,\n} from '@strapi/utils';\n\nimport type { UID, Modules } from '@strapi/types';\nimport { wrapInTransaction, type RepositoryFactoryMethod } from './common';\nimport * as DP from './draft-and-publish';\nimport * as i18n from './internationalization';\nimport { copyNonLocalizedFields } from './internationalization';\nimport * as components from './components';\n\nimport { createEntriesService } from './entries';\nimport { ALLOWED_DOCUMENT_ROOT_PARAM_KEYS, pickSelectionParams } from './params';\nimport { createDocumentId } from '../../utils/transform-content-types-to-models';\nimport { getDeepPopulate } from './utils/populate';\nimport { transformParamsToQuery } from './transform/query';\nimport { transformParamsDocumentId } from './transform/id-transform';\nimport { createEventManager } from './events';\nimport * as unidirectionalRelations from './utils/unidirectional-relations';\nimport * as bidirectionalRelations from './utils/bidirectional-relations';\nimport entityValidator from '../entity-validator';\nimport { addFirstPublishedAtToDraft, filterDataFirstPublishedAt } from './first-published-at';\nimport { runParallelWithOrderedErrors } from './utils/ordered-parallel';\n\nconst { validators } = validate;\n\n// we have to typecast to reconcile the differences between validator and database getModel\nconst getModel = ((schema: UID.Schema) => strapi.getModel(schema)) as (schema: string) => any;\n\n// config.api.documents.strictParams: false/undefined (pass through), true (throw on invalid)\n\n// BCP 47–style locale format: 2–3 letter language code (any case), optional subtags (-XX or -XXX...), max 35 chars\nconst LOCALE_FORMAT = /^[a-zA-Z]{2,3}(-[a-zA-Z0-9]{2,8})*$/;\nconst MAX_LOCALE_LENGTH = 35;\n\n/** Treat as \"param not provided\": null, undefined, or empty string (e.g. from query/JSON). */\nconst isParamEmpty = (v: unknown): boolean => v === undefined || v === null || v === '';\n\nexport const createContentTypeRepository: RepositoryFactoryMethod = (\n uid,\n validator = entityValidator\n) => {\n const contentType = strapi.contentType(uid);\n const hasDraftAndPublish = contentTypesUtils.hasDraftAndPublish(contentType);\n\n // Define the validations that should be performed\n const sortValidations = ['nonAttributesOperators', 'dynamicZones', 'morphRelations'];\n const fieldValidations = ['scalarAttributes'];\n const filtersValidations = ['nonAttributesOperators', 'dynamicZones', 'morphRelations'];\n const populateValidations = {\n sort: sortValidations,\n field: fieldValidations,\n filters: filtersValidations,\n populate: ['nonAttributesOperators'],\n };\n\n /**\n * Checks status parameter. When strict is true, throws on invalid status.\n * Valid values are 'published' and 'draft'; for types without D&P they are currently ignored but may throw in the future\n */\n const checkStatus = (\n params: Record<string, unknown>,\n strict: boolean\n ): Record<string, unknown> => {\n if (!strict) {\n return params;\n }\n\n if (isParamEmpty(params.status)) {\n delete params.status;\n return params;\n }\n\n if (params.status !== 'published' && params.status !== 'draft') {\n throw new errors.ValidationError(\n `Invalid parameter at 'status'. Expected 'published' or 'draft', received: ${params.status}`\n );\n }\n\n return params;\n };\n\n /**\n * Checks locale parameter. When strict is true, throws on invalid locale value.\n * Accepts only: string (single locale or '*'), array of locale strings (e.g. bulk publish),\n * empty string, null, or undefined (removed but allowed)\n */\n const checkLocale = (\n params: Record<string, unknown>,\n strict: boolean\n ): Record<string, unknown> => {\n if (!strict) {\n return params;\n }\n\n if (isParamEmpty(params.locale)) {\n delete params.locale;\n return params;\n }\n\n // Reject objects (we only accept string, array of strings, empty string, null, undefined)\n if (typeof params.locale === 'object' && !Array.isArray(params.locale)) {\n throw new errors.ValidationError(\n `Invalid parameter at 'locale'. Expected a string, array of strings, empty string, null, or undefined; received: object`,\n { received: params.locale }\n );\n }\n\n const validateAndNormalizeOne = (value: unknown, path: string): string => {\n if (typeof value !== 'string') {\n throw new errors.ValidationError(\n `Invalid parameter at '${path}'. Expected a string, received: ${typeof value}`,\n { received: value }\n );\n }\n if (value === '*') return value;\n const isEmpty = value.length === 0;\n const tooLong = value.length > MAX_LOCALE_LENGTH;\n const invalidFormat = !LOCALE_FORMAT.test(value);\n if (isEmpty || tooLong || invalidFormat) {\n let reason: string;\n if (isEmpty) {\n reason = 'Locale cannot be empty';\n } else if (tooLong) {\n reason = `Locale exceeds maximum length of ${MAX_LOCALE_LENGTH} characters`;\n } else {\n reason = 'Locale must be a valid BCP 47 format (e.g. en, en-US, zh-Hans)';\n }\n throw new errors.ValidationError(`Invalid parameter at '${path}'. ${reason}.`);\n }\n return value;\n };\n\n if (Array.isArray(params.locale)) {\n const filtered = (params.locale as unknown[]).filter(\n (item): item is string => typeof item === 'string' && !isParamEmpty(item)\n );\n if (filtered.length === 0) {\n delete params.locale;\n return params;\n }\n params.locale = filtered.map((item, i) => validateAndNormalizeOne(item, `locale[${i}]`));\n return params;\n }\n\n params.locale = validateAndNormalizeOne(params.locale, 'locale');\n return params;\n };\n\n /**\n * Pagination param parsing (used only when strict).\n * Contract: empty (null/undefined/'') → undefined (omit from result).\n * present but invalid → throw ValidationError.\n * present and valid → return normalized value.\n */\n const parsePaginationInt = (\n name: string,\n value: unknown,\n strict: boolean,\n spec: { min: number; allowMinusOne?: boolean }\n ): number | undefined => {\n if (isParamEmpty(value)) return undefined;\n const num = Number(value);\n const valid =\n Number.isInteger(num) && (num >= spec.min || (spec.allowMinusOne === true && num === -1));\n if (!valid && strict) {\n const expected = spec.allowMinusOne\n ? `integer >= ${spec.min} or -1`\n : `integer >= ${spec.min}`;\n throw new errors.ValidationError(\n `Invalid parameter at '${name}'. Expected ${expected}, received: ${value}`\n );\n }\n return valid ? num : undefined;\n };\n\n const parseWithCount = (value: unknown): boolean | undefined => {\n if (isParamEmpty(value)) return undefined;\n if (typeof value === 'boolean') return value;\n if (typeof value === 'string' && (value === 'true' || value === 'false'))\n return value === 'true';\n throw new errors.ValidationError(\n `Invalid parameter at 'withCount'. Expected a boolean, received: ${typeof value}`\n );\n };\n\n const PAGINATION_KEYS = ['page', 'pageSize', 'start', 'limit', 'withCount'] as const;\n\n /**\n * When strict: empty → omit, invalid → throw, valid → include.\n * When not strict: return params unchanged.\n */\n const checkPagination = (\n params: Record<string, unknown>,\n strict: boolean\n ): Record<string, unknown> => {\n if (!strict) return params;\n\n const hasPage = !isParamEmpty(params.page) || !isParamEmpty(params.pageSize);\n const hasOffset = !isParamEmpty(params.start) || !isParamEmpty(params.limit);\n if (hasPage && hasOffset) {\n throw new errors.ValidationError(\n 'Invalid pagination parameters. Cannot use both page-based (page, pageSize) and offset-based (start, limit) pagination in the same query.'\n );\n }\n\n const page = parsePaginationInt('page', params.page, strict, { min: 1 });\n const pageSize = parsePaginationInt('pageSize', params.pageSize, strict, { min: 1 });\n const start = parsePaginationInt('start', params.start, strict, { min: 0 });\n const limit = parsePaginationInt('limit', params.limit, strict, {\n min: 1,\n allowMinusOne: true,\n });\n const withCount = parseWithCount(params.withCount);\n\n const result = { ...omit(PAGINATION_KEYS, params) };\n if (page !== undefined) result.page = page;\n if (pageSize !== undefined) result.pageSize = pageSize;\n if (start !== undefined) result.start = start;\n if (limit !== undefined) result.limit = limit;\n if (withCount !== undefined) result.withCount = withCount;\n return result;\n };\n\n /**\n * When strict is true, strip to allowed root-level keys so only those reach the query.\n * Extra params (e.g. from content API addQueryParams) are allowed in so middlewares see them,\n * but are stripped here before the query pipeline; they never affect the document query.\n */\n const checkUnrecognizedRootParams = (\n params: Record<string, unknown>,\n strict: boolean\n ): Record<string, unknown> => {\n if (!strict) {\n return params;\n }\n\n return pick(ALLOWED_DOCUMENT_ROOT_PARAM_KEYS as unknown as string[], params) as Record<\n string,\n unknown\n >;\n };\n\n const validateParams = async (\n params: Modules.Documents.Params.All\n ): Promise<Modules.Documents.Params.All> => {\n // Cache model lookups for this request to avoid repeating the same work\n const modelCache = createModelCache(getModel);\n\n const ctx = { schema: contentType, getModel: modelCache.getModel };\n\n // Only validate what is actually provided\n const validations: Promise<unknown>[] = [];\n\n if (params.filters && !isEmpty(params.filters)) {\n validations.push(validators.validateFilters(ctx, params.filters, filtersValidations));\n }\n\n if (params.sort && !isEmpty(params.sort)) {\n validations.push(validators.validateSort(ctx, params.sort, sortValidations));\n }\n\n if (params.fields && !isEmpty(params.fields)) {\n validations.push(validators.validateFields(ctx, params.fields, fieldValidations));\n }\n\n if (params.populate && !isEmpty(params.populate)) {\n validations.push(validators.validatePopulate(ctx, params.populate, populateValidations));\n }\n\n // Run validations together but keep the same error order as before\n await runParallelWithOrderedErrors(validations);\n\n // Clean up cache after validation\n modelCache.clear();\n\n // Strip lookup from params, it's only used internally\n if (params.lookup) {\n throw new errors.ValidationError(\"Invalid params: 'lookup'\");\n }\n\n // Validate status, locale, and pagination based on config\n // config.api.documents.strictParams: false/undefined (pass through), true (throw on invalid)\n const rawStrictParams: unknown = strapi.config.get('api.documents.strictParams', undefined);\n\n if (rawStrictParams !== undefined && rawStrictParams !== false && rawStrictParams !== true) {\n throw new errors.ValidationError(\n `Invalid config.api.documents.strictParams value: \"${rawStrictParams}\". Expected boolean (true or false).`\n );\n }\n\n const strict = rawStrictParams === true;\n\n let processedParams: Record<string, unknown>;\n if (strict) {\n processedParams = checkUnrecognizedRootParams(params as Record<string, unknown>, strict);\n processedParams = checkStatus(processedParams, strict);\n processedParams = checkLocale(processedParams, strict);\n processedParams = checkPagination(processedParams, strict);\n } else {\n processedParams = params as Record<string, unknown>;\n }\n\n return processedParams as Modules.Documents.Params.All;\n };\n\n const entries = createEntriesService(uid, validator);\n\n const eventManager = createEventManager(strapi, uid);\n const emitEvent = curry(eventManager.emitEvent);\n\n async function findMany(params = {} as any) {\n const query = await async.pipe(\n validateParams,\n DP.defaultToDraft,\n DP.statusToLookup(contentType),\n\n i18n.defaultLocale(contentType),\n i18n.multiLocaleToLookup(contentType),\n transformParamsDocumentId(uid),\n transformParamsToQuery(uid)\n )(params || {});\n\n return strapi.db.query(uid).findMany(query);\n }\n\n async function findFirst(params = {} as any) {\n const query = await async.pipe(\n validateParams,\n DP.defaultToDraft,\n DP.statusToLookup(contentType),\n\n i18n.defaultLocale(contentType),\n i18n.localeToLookup(contentType),\n transformParamsDocumentId(uid),\n transformParamsToQuery(uid)\n )(params);\n\n return strapi.db.query(uid).findOne(query);\n }\n\n // TODO: do we really want to add filters on the findOne now that we have findFirst ?\n async function findOne(opts = {} as any) {\n const { documentId, ...params } = opts;\n\n const query = await async.pipe(\n validateParams,\n DP.defaultToDraft,\n DP.statusToLookup(contentType),\n\n i18n.defaultLocale(contentType),\n i18n.localeToLookup(contentType),\n transformParamsDocumentId(uid),\n transformParamsToQuery(uid),\n (query) => assoc('where', { ...query.where, documentId }, query)\n )(params);\n\n return strapi.db.query(uid).findOne(query);\n }\n\n async function deleteDocument(opts = {} as any) {\n const { documentId, ...params } = opts;\n\n const query = await async.pipe(\n validateParams,\n omit('status'),\n i18n.defaultLocale(contentType),\n i18n.multiLocaleToLookup(contentType),\n transformParamsToQuery(uid),\n (query) => assoc('where', { ...query.where, documentId }, query)\n )(params);\n\n if (hasDraftAndPublish && params.status === 'draft') {\n throw new Error('Cannot delete a draft document');\n }\n\n const entriesToDelete = await strapi.db.query(uid).findMany(query);\n\n // Delete all matched entries and its components\n const deletedEntries = await async.map(entriesToDelete, (entryToDelete: any) =>\n entries.delete(entryToDelete.id)\n );\n\n entriesToDelete.forEach(emitEvent('entry.delete'));\n\n return { documentId, entries: deletedEntries };\n }\n\n async function create(opts = {} as any) {\n const { documentId, ...params } = opts;\n\n const queryParams = await async.pipe(\n validateParams,\n DP.filterDataPublishedAt,\n DP.setStatusToDraft(contentType),\n DP.statusToData(contentType),\n i18n.defaultLocale(contentType),\n i18n.localeToData(contentType)\n )(params);\n\n const doc = await entries.create(queryParams);\n\n emitEvent('entry.create', doc);\n\n if (hasDraftAndPublish && params.status === 'published') {\n return publish({\n ...params,\n documentId: doc.documentId,\n }).then((doc) => doc.entries[0]);\n }\n\n return doc;\n }\n\n async function clone(opts = {} as any) {\n const { documentId, ...params } = opts;\n\n const queryParams = await async.pipe(\n validateParams,\n DP.filterDataPublishedAt,\n i18n.defaultLocale(contentType),\n i18n.multiLocaleToLookup(contentType)\n )(params);\n\n // Get deep populate\n const entriesToClone = await strapi.db.query(uid).findMany({\n where: {\n ...queryParams?.lookup,\n documentId,\n // DP Enabled: Clone drafts\n // DP Disabled: Clone only the existing version (published)\n publishedAt: { $null: hasDraftAndPublish },\n },\n populate: getDeepPopulate(uid, { relationalFields: ['id'] }),\n });\n\n const clonedEntries = await async.map(\n entriesToClone,\n async.pipe(\n omit(['id', 'createdAt', 'updatedAt']),\n // assign new documentId\n assoc('documentId', createDocumentId()),\n // Merge new data into it\n (data) => merge(data, queryParams.data),\n (data) => entries.create({ ...queryParams, data, status: 'draft' })\n )\n );\n\n clonedEntries.forEach(emitEvent('entry.create'));\n\n return { documentId: clonedEntries.at(0)?.documentId, entries: clonedEntries };\n }\n\n async function update(opts = {} as any) {\n const { documentId, ...params } = opts;\n\n const queryParams = await async.pipe(\n validateParams,\n DP.filterDataPublishedAt,\n filterDataFirstPublishedAt,\n DP.setStatusToDraft(contentType),\n DP.statusToLookup(contentType),\n DP.statusToData(contentType),\n // Default locale will be set if not provided\n i18n.defaultLocale(contentType),\n i18n.localeToLookup(contentType),\n i18n.localeToData(contentType)\n )(params);\n\n const { data, ...restParams } = await transformParamsDocumentId(uid, queryParams || {});\n const query = transformParamsToQuery(uid, pickSelectionParams(restParams || {}) as any);\n\n // Validation\n // Find if document exists\n const entryToUpdate = await strapi.db\n .query(uid)\n .findOne({ ...query, where: { ...queryParams?.lookup, ...query?.where, documentId } });\n\n let updatedDraft = null;\n if (entryToUpdate) {\n updatedDraft = await entries.update(entryToUpdate, queryParams);\n emitEvent('entry.update', updatedDraft);\n }\n\n if (!updatedDraft) {\n const documentExists = await strapi.db\n .query(contentType.uid)\n .findOne({ where: { documentId } });\n\n if (documentExists) {\n const mergedData = await copyNonLocalizedFields(contentType, documentId, {\n ...queryParams.data,\n documentId,\n });\n\n updatedDraft = await entries.create({\n ...queryParams,\n data: mergedData,\n });\n emitEvent('entry.create', updatedDraft);\n }\n }\n\n if (hasDraftAndPublish && updatedDraft && params.status === 'published') {\n return publish({\n ...params,\n documentId,\n }).then((doc) => doc.entries[0]);\n }\n\n return updatedDraft;\n }\n\n async function count(params = {} as any) {\n const query = await async.pipe(\n validateParams,\n DP.defaultStatus(contentType),\n DP.statusToLookup(contentType),\n\n i18n.defaultLocale(contentType),\n i18n.multiLocaleToLookup(contentType),\n transformParamsToQuery(uid)\n )(params);\n\n return strapi.db.query(uid).count(query);\n }\n\n async function publish(opts = {} as any) {\n const { documentId, ...params } = opts;\n\n const queryParams = await async.pipe(\n validateParams,\n i18n.defaultLocale(contentType),\n i18n.multiLocaleToLookup(contentType)\n )(params);\n\n const [draftsToPublish, oldPublishedVersions] = await Promise.all([\n strapi.db.query(uid).findMany({\n where: {\n ...queryParams?.lookup,\n documentId,\n publishedAt: null, // Ignore lookup\n },\n // Populate relations, media, compos and dz\n populate: getDeepPopulate(uid, { relationalFields: ['documentId', 'locale'] }),\n }),\n strapi.db.query(uid).findMany({\n where: {\n ...queryParams?.lookup,\n documentId,\n publishedAt: { $ne: null },\n },\n select: ['id', 'locale'],\n }),\n ]);\n\n // Load any unidirectional relation targetting the old published entries\n const relationsToSync = await unidirectionalRelations.load(\n uid,\n {\n newVersions: draftsToPublish,\n oldVersions: oldPublishedVersions,\n },\n {\n shouldPropagateRelation: components.createComponentRelationFilter(),\n }\n );\n\n const bidirectionalRelationsToSync = await bidirectionalRelations.load(uid, {\n newVersions: draftsToPublish,\n oldVersions: oldPublishedVersions,\n });\n\n // Delete old published versions\n await async.map(oldPublishedVersions, (entry: any) => entries.delete(entry.id));\n\n // Add firstPublishedAt to draft if it doesn't exist\n const updatedDraft = await async.map(draftsToPublish, (draft: any) =>\n addFirstPublishedAtToDraft(draft, entries.update, contentType)\n );\n\n // Transform draft entry data and create published versions\n const publishedEntries = await async.map(updatedDraft, (draft: any) =>\n entries.publish(draft, queryParams)\n );\n\n // Sync unidirectional relations with the new published entries\n await unidirectionalRelations.sync(\n [...oldPublishedVersions, ...updatedDraft],\n publishedEntries,\n relationsToSync\n );\n\n await bidirectionalRelations.sync(\n [...oldPublishedVersions, ...updatedDraft],\n publishedEntries,\n bidirectionalRelationsToSync\n );\n\n publishedEntries.forEach(emitEvent('entry.publish'));\n\n return { documentId, entries: publishedEntries };\n }\n\n async function unpublish(opts = {} as any) {\n const { documentId, ...params } = opts;\n\n const query = await async.pipe(\n validateParams,\n i18n.defaultLocale(contentType),\n i18n.multiLocaleToLookup(contentType),\n transformParamsToQuery(uid),\n (query) => assoc('where', { ...query.where, documentId, publishedAt: { $ne: null } }, query)\n )(params);\n\n // Delete all published versions\n const versionsToDelete = await strapi.db.query(uid).findMany(query);\n await async.map(versionsToDelete, (entry: any) => entries.delete(entry.id));\n\n versionsToDelete.forEach(emitEvent('entry.unpublish'));\n return { documentId, entries: versionsToDelete };\n }\n\n async function discardDraft(opts = {} as any) {\n const { documentId, ...params } = opts;\n\n const queryParams = await async.pipe(\n validateParams,\n i18n.defaultLocale(contentType),\n i18n.multiLocaleToLookup(contentType)\n )(params);\n\n const [versionsToDraft, oldDrafts] = await Promise.all([\n strapi.db.query(uid).findMany({\n where: {\n ...queryParams?.lookup,\n documentId,\n publishedAt: { $ne: null },\n },\n // Populate relations, media, compos and dz\n populate: getDeepPopulate(uid, { relationalFields: ['documentId', 'locale'] }),\n }),\n strapi.db.query(uid).findMany({\n where: {\n ...queryParams?.lookup,\n documentId,\n publishedAt: null,\n },\n select: ['id', 'locale'],\n }),\n ]);\n\n // Load any unidirectional relation targeting the old drafts\n const relationsToSync = await unidirectionalRelations.load(\n uid,\n {\n newVersions: versionsToDraft,\n oldVersions: oldDrafts,\n },\n {\n shouldPropagateRelation: components.createComponentRelationFilter(),\n }\n );\n\n const bidirectionalRelationsToSync = await bidirectionalRelations.load(uid, {\n newVersions: versionsToDraft,\n oldVersions: oldDrafts,\n });\n\n // Delete old drafts\n await async.map(oldDrafts, (entry: any) => entries.delete(entry.id));\n\n // Transform published entry data and create draft versions\n const draftEntries = await async.map(versionsToDraft, (entry: any) =>\n entries.discardDraft(entry, queryParams)\n );\n\n // Sync unidirectional relations with the new draft entries\n await unidirectionalRelations.sync(\n [...oldDrafts, ...versionsToDraft],\n draftEntries,\n relationsToSync\n );\n\n await bidirectionalRelations.sync(\n [...oldDrafts, ...versionsToDraft],\n draftEntries,\n bidirectionalRelationsToSync\n );\n\n draftEntries.forEach(emitEvent('entry.draft-discard'));\n return { documentId, entries: draftEntries };\n }\n\n async function updateComponents(entry: any, data: any) {\n return components.updateComponents(uid, entry, data);\n }\n\n function omitComponentData(data: any) {\n return components.omitComponentData(contentType, data);\n }\n\n return {\n findMany: wrapInTransaction(findMany),\n findFirst: wrapInTransaction(findFirst),\n findOne: wrapInTransaction(findOne),\n delete: wrapInTransaction(deleteDocument),\n create: wrapInTransaction(create),\n clone: wrapInTransaction(clone),\n update: wrapInTransaction(update),\n count: wrapInTransaction(count),\n publish: hasDraftAndPublish ? wrapInTransaction(publish) : (undefined as any),\n unpublish: hasDraftAndPublish ? wrapInTransaction(unpublish) : (undefined as any),\n discardDraft: hasDraftAndPublish ? wrapInTransaction(discardDraft) : (undefined as any),\n\n updateComponents,\n omitComponentData,\n };\n};\n"],"names":["validators","validate","getModel","schema","strapi","LOCALE_FORMAT","MAX_LOCALE_LENGTH","isParamEmpty","v","undefined","createContentTypeRepository","uid","validator","entityValidator","contentType","hasDraftAndPublish","contentTypesUtils","sortValidations","fieldValidations","filtersValidations","populateValidations","sort","field","filters","populate","checkStatus","params","strict","status","errors","ValidationError","checkLocale","locale","Array","isArray","received","validateAndNormalizeOne","value","path","isEmpty","length","tooLong","invalidFormat","test","reason","filtered","filter","item","map","i","parsePaginationInt","name","spec","num","Number","valid","isInteger","min","allowMinusOne","expected","parseWithCount","PAGINATION_KEYS","checkPagination","hasPage","page","pageSize","hasOffset","start","limit","withCount","result","omit","checkUnrecognizedRootParams","pick","ALLOWED_DOCUMENT_ROOT_PARAM_KEYS","validateParams","modelCache","createModelCache","ctx","validations","push","validateFilters","validateSort","fields","validateFields","validatePopulate","runParallelWithOrderedErrors","clear","lookup","rawStrictParams","config","get","processedParams","entries","createEntriesService","eventManager","createEventManager","emitEvent","curry","findMany","query","async","pipe","DP","i18n","transformParamsDocumentId","transformParamsToQuery","db","findFirst","findOne","opts","documentId","assoc","where","deleteDocument","Error","entriesToDelete","deletedEntries","entryToDelete","delete","id","forEach","create","queryParams","doc","publish","then","clone","entriesToClone","publishedAt","$null","getDeepPopulate","relationalFields","clonedEntries","createDocumentId","data","merge","at","update","filterDataFirstPublishedAt","restParams","pickSelectionParams","entryToUpdate","updatedDraft","documentExists","mergedData","copyNonLocalizedFields","count","draftsToPublish","oldPublishedVersions","Promise","all","$ne","select","relationsToSync","unidirectionalRelations","newVersions","oldVersions","shouldPropagateRelation","components","bidirectionalRelationsToSync","bidirectionalRelations","entry","draft","addFirstPublishedAtToDraft","publishedEntries","unpublish","versionsToDelete","discardDraft","versionsToDraft","oldDrafts","draftEntries","updateComponents","omitComponentData","wrapInTransaction"],"mappings":"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"}
@@ -13,6 +13,10 @@ interface LoadContext {
13
13
  interface RelationEntry {
14
14
  joinTable: JoinTable;
15
15
  relations: Record<string, unknown>[];
16
+ /** FK column for the entity being published */
17
+ entityColumn: string;
18
+ /** FK column for the related entity */
19
+ relatedColumn: string;
16
20
  }
17
21
  /**
18
22
  * Loads all bidirectional relations that need to be synchronized when content entries change state
@@ -59,7 +63,7 @@ interface RelationEntry {
59
63
  * @param context - Object containing arrays of old and new entry versions
60
64
  * @returns Array of objects containing join table metadata and relations to be updated
61
65
  */
62
- declare const load: (uid: UID.ContentType, { oldVersions }: LoadContext) => Promise<RelationEntry[]>;
66
+ declare const load: (uid: UID.ContentType, { oldVersions, newVersions }: LoadContext) => Promise<RelationEntry[]>;
63
67
  /**
64
68
  * Synchronizes the order of bidirectional relations after content entries have changed state.
65
69
  *
@@ -1 +1 @@
1
- {"version":3,"file":"bidirectional-relations.d.ts","sourceRoot":"","sources":["../../../../src/services/document-service/utils/bidirectional-relations.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,GAAG,EAAU,MAAM,eAAe,CAAC;AACjD,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAElD,UAAU,WAAW;IACnB,WAAW,EAAE;QAAE,EAAE,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE,EAAE,CAAC;IAC9C,WAAW,EAAE;QAAE,EAAE,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE,EAAE,CAAC;CAC/C;AAED,UAAU,aAAa;IACrB,SAAS,EAAE,SAAS,CAAC;IACrB,SAAS,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAC;CACtC;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4CG;AACH,QAAA,MAAM,IAAI,QAAe,IAAI,WAAW,mBAAmB,WAAW,6BAmDrE,CAAC;AAEF;;;;;;;;;;;;;;;;;;;;;;;;;GAyBG;AACH,QAAA,MAAM,IAAI,eACI;IAAE,EAAE,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,EAAE,cAChC;IAAE,EAAE,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,EAAE,qBACzB,aAAa,EAAE,kBAyFnC,CAAC;AAEF,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC"}
1
+ {"version":3,"file":"bidirectional-relations.d.ts","sourceRoot":"","sources":["../../../../src/services/document-service/utils/bidirectional-relations.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,GAAG,EAAU,MAAM,eAAe,CAAC;AACjD,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAElD,UAAU,WAAW;IACnB,WAAW,EAAE;QAAE,EAAE,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE,EAAE,CAAC;IAC9C,WAAW,EAAE;QAAE,EAAE,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE,EAAE,CAAC;CAC/C;AAED,UAAU,aAAa;IACrB,SAAS,EAAE,SAAS,CAAC;IACrB,SAAS,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAC;IACrC,+CAA+C;IAC/C,YAAY,EAAE,MAAM,CAAC;IACrB,uCAAuC;IACvC,aAAa,EAAE,MAAM,CAAC;CACvB;AA2ID;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4CG;AACH,QAAA,MAAM,IAAI,QAAe,IAAI,WAAW,gCAAgC,WAAW,6BAiElF,CAAC;AAEF;;;;;;;;;;;;;;;;;;;;;;;;;GAyBG;AACH,QAAA,MAAM,IAAI,eACI;IAAE,EAAE,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,EAAE,cAChC;IAAE,EAAE,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,EAAE,qBACzB,aAAa,EAAE,kBA6FnC,CAAC;AAEF,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC"}
@@ -2,6 +2,86 @@
2
2
 
3
3
  var fp = require('lodash/fp');
4
4
 
5
+ /** Draft id → published id for rows that already have a published counterpart (same document_id + locale). */ const draftToPublishedMap = async (trx, tableName, rowIds)=>{
6
+ const uniqueIds = [
7
+ ...new Set(rowIds)
8
+ ];
9
+ if (uniqueIds.length === 0) {
10
+ return new Map();
11
+ }
12
+ const draftEntries = await strapi.db.getConnection().select('id', 'document_id', 'locale').from(tableName).whereIn('id', uniqueIds).transacting(trx);
13
+ if (draftEntries.length === 0) {
14
+ return new Map();
15
+ }
16
+ const pubEntries = await strapi.db.getConnection().select('id', 'document_id', 'locale').from(tableName).whereNotNull('published_at').whereIn('document_id', draftEntries.map((e)=>e.document_id)).transacting(trx);
17
+ const pubByDocLocale = new Map(pubEntries.map((e)=>[
18
+ `${e.document_id}_${e.locale}`,
19
+ e.id
20
+ ]));
21
+ const map = new Map();
22
+ for (const d of draftEntries){
23
+ const pubId = pubByDocLocale.get(`${d.document_id}_${d.locale}`);
24
+ if (pubId) {
25
+ map.set(String(d.id), String(pubId));
26
+ }
27
+ }
28
+ return map;
29
+ };
30
+ const remapRelatedIds = (rows, relatedCol, idMap)=>rows.map((row)=>{
31
+ const next = idMap.get(String(row[relatedCol]));
32
+ return next ? {
33
+ ...row,
34
+ [relatedCol]: next
35
+ } : row;
36
+ });
37
+ /**
38
+ * Reads join rows tied to the entry being published (`publishedCol` IN draft/old ids) and returns
39
+ * batches for `sync()`. When the FK in `relatedCol` points at a D&P type, maps known draft ids to
40
+ * published ids; otherwise keeps draft ids so sync can still run after both sides exist.
41
+ */ const captureJoinBatches = async (trx, opts)=>{
42
+ const { joinTable, publishedCol, relatedCol, relatedUid, relatedHasDraftAndPublish, schemaUid, oldVersions, newVersions } = opts;
43
+ const batches = [];
44
+ const { name: table } = joinTable;
45
+ const oldIds = oldVersions.map((e)=>e.id);
46
+ if (oldIds.length > 0) {
47
+ const existing = await strapi.db.getConnection().select('*').from(table).whereIn(publishedCol, oldIds).transacting(trx);
48
+ if (existing.length > 0) {
49
+ batches.push({
50
+ joinTable,
51
+ relations: existing,
52
+ entityColumn: publishedCol,
53
+ relatedColumn: relatedCol
54
+ });
55
+ }
56
+ }
57
+ if (!strapi.contentTypes[schemaUid]) {
58
+ return batches;
59
+ }
60
+ const oldLocales = new Set(oldVersions.map((e)=>e.locale));
61
+ const draftsOnly = newVersions.filter((v)=>!oldLocales.has(v.locale));
62
+ if (draftsOnly.length === 0) {
63
+ return batches;
64
+ }
65
+ const draftIds = draftsOnly.map((e)=>e.id);
66
+ const draftRows = await strapi.db.getConnection().select('*').from(table).whereIn(publishedCol, draftIds).transacting(trx);
67
+ if (draftRows.length === 0) {
68
+ return batches;
69
+ }
70
+ let relations = draftRows;
71
+ if (relatedHasDraftAndPublish) {
72
+ const meta = strapi.db.metadata.get(relatedUid);
73
+ const relatedIds = draftRows.map((r)=>r[relatedCol]);
74
+ const map = await draftToPublishedMap(trx, meta.tableName, relatedIds);
75
+ relations = remapRelatedIds(draftRows, relatedCol, map);
76
+ }
77
+ batches.push({
78
+ joinTable,
79
+ relations,
80
+ entityColumn: publishedCol,
81
+ relatedColumn: relatedCol
82
+ });
83
+ return batches;
84
+ };
5
85
  /**
6
86
  * Loads all bidirectional relations that need to be synchronized when content entries change state
7
87
  * (e.g., during publish/unpublish operations).
@@ -46,40 +126,45 @@ var fp = require('lodash/fp');
46
126
  * @param uid - The unique identifier of the content type being processed
47
127
  * @param context - Object containing arrays of old and new entry versions
48
128
  * @returns Array of objects containing join table metadata and relations to be updated
49
- */ const load = async (uid, { oldVersions })=>{
129
+ */ const load = async (uid, { oldVersions, newVersions })=>{
50
130
  const relationsToUpdate = [];
51
131
  await strapi.db.transaction(async ({ trx })=>{
52
- const contentTypes = Object.values(strapi.contentTypes);
53
- const components = Object.values(strapi.components);
54
- for (const model of [
55
- ...contentTypes,
56
- ...components
57
- ]){
132
+ const models = [
133
+ ...Object.values(strapi.contentTypes),
134
+ ...Object.values(strapi.components)
135
+ ];
136
+ for (const model of models){
58
137
  const dbModel = strapi.db.metadata.get(model.uid);
59
138
  for (const attribute of Object.values(dbModel.attributes)){
60
- // Skip if not a bidirectional relation targeting our content type
61
- if (attribute.type !== 'relation' || attribute.target !== uid || !(attribute.inversedBy || attribute.mappedBy)) {
139
+ const joinTable = attribute.joinTable;
140
+ if (attribute.type !== 'relation' || !joinTable) {
62
141
  continue;
63
142
  }
64
- // If it's a self referencing relation, there is no need to sync any relation
65
- // The order will already be handled as both sides are inside the same content type
66
- if (model.uid === uid) {
143
+ if (!(attribute.inversedBy || attribute.mappedBy)) {
67
144
  continue;
68
145
  }
69
- const joinTable = attribute.joinTable;
70
- if (!joinTable) {
146
+ // Owning side: e.g. Author.articles when publishing an Author.
147
+ const isOwningSide = !!attribute.inversedBy && model.uid === uid && attribute.relation === 'manyToMany' && model.uid !== attribute.target;
148
+ // Inverse side: e.g. Article.authors when publishing an Article.
149
+ const isInverseSide = attribute.target === uid && model.uid !== uid;
150
+ if (!isOwningSide && !isInverseSide) {
71
151
  continue;
72
152
  }
73
- const { name: targetColumnName } = joinTable.inverseJoinColumn;
74
- // Load all relations that need their order preserved
75
- const oldEntryIds = oldVersions.map((entry)=>entry.id);
76
- const existingRelations = await strapi.db.getConnection().select('*').from(joinTable.name).whereIn(targetColumnName, oldEntryIds).transacting(trx);
77
- if (existingRelations.length > 0) {
78
- relationsToUpdate.push({
79
- joinTable,
80
- relations: existingRelations
81
- });
82
- }
153
+ // Direction determines which join column belongs to the entity being published
154
+ const publishedCol = isOwningSide ? joinTable.joinColumn.name : joinTable.inverseJoinColumn.name;
155
+ const relatedCol = isOwningSide ? joinTable.inverseJoinColumn.name : joinTable.joinColumn.name;
156
+ const relatedUid = isOwningSide ? attribute.target : model.uid;
157
+ const batches = await captureJoinBatches(trx, {
158
+ joinTable,
159
+ publishedCol,
160
+ relatedCol,
161
+ relatedUid,
162
+ relatedHasDraftAndPublish: isOwningSide ? !!strapi.contentTypes[relatedUid]?.options?.draftAndPublish : !!model.options?.draftAndPublish,
163
+ schemaUid: model.uid,
164
+ oldVersions,
165
+ newVersions
166
+ });
167
+ relationsToUpdate.push(...batches);
83
168
  }
84
169
  }
85
170
  });
@@ -111,21 +196,19 @@ var fp = require('lodash/fp');
111
196
  * @param newEntries - Array of new entry versions with their IDs and locales
112
197
  * @param existingRelations - Array of join table data containing the relations to be updated
113
198
  */ const sync = async (oldEntries, newEntries, existingRelations)=>{
114
- // Group new entries by locale for easier lookup
115
199
  const newEntriesByLocale = fp.keyBy('locale', newEntries);
116
- // Create a mapping of old entry IDs to new entry IDs based on locale
117
200
  const entryIdMapping = oldEntries.reduce((acc, oldEntry)=>{
118
201
  const newEntry = newEntriesByLocale[oldEntry.locale];
119
- if (!newEntry) return acc;
202
+ if (!newEntry) {
203
+ return acc;
204
+ }
120
205
  acc[oldEntry.id] = newEntry.id;
121
206
  return acc;
122
207
  }, {});
123
208
  const republishedEntryIds = new Set(newEntries.map((e)=>String(e.id)));
124
209
  const isRepublishedEntry = (id)=>republishedEntryIds.has(String(id));
125
210
  await strapi.db.transaction(async ({ trx })=>{
126
- for (const { joinTable, relations } of existingRelations){
127
- const sourceColumn = joinTable.inverseJoinColumn.name;
128
- const targetColumn = joinTable.joinColumn.name;
211
+ for (const { joinTable, relations, entityColumn: sourceColumn, relatedColumn: targetColumn } of existingRelations){
129
212
  const orderColumn = joinTable.orderColumnName;
130
213
  // Failsafe in case those don't exist
131
214
  if (!sourceColumn || !targetColumn || !orderColumn) {
@@ -165,7 +248,8 @@ var fp = require('lodash/fp');
165
248
  [orderColumn]: originalOrder
166
249
  }));
167
250
  if (toInsert.length) {
168
- await trx.batchInsert(joinTable.name, toInsert, 1000);
251
+ const batchSize = strapi.db.dialect.getBatchInsertSize();
252
+ await trx.batchInsert(joinTable.name, toInsert, batchSize);
169
253
  }
170
254
  }
171
255
  });
@@ -1 +1 @@
1
- {"version":3,"file":"bidirectional-relations.js","sources":["../../../../src/services/document-service/utils/bidirectional-relations.ts"],"sourcesContent":["/* eslint-disable no-continue */\nimport { keyBy, omit } from 'lodash/fp';\nimport type { UID, Schema } from '@strapi/types';\nimport type { JoinTable } from '@strapi/database';\n\ninterface LoadContext {\n oldVersions: { id: string; locale: string }[];\n newVersions: { id: string; locale: string }[];\n}\n\ninterface RelationEntry {\n joinTable: JoinTable;\n relations: Record<string, unknown>[];\n}\n\n/**\n * Loads all bidirectional relations that need to be synchronized when content entries change state\n * (e.g., during publish/unpublish operations).\n *\n * In Strapi, bidirectional relations allow maintaining order from both sides of the relation.\n * When an entry is published, the following occurs:\n *\n * 1. The old published entry is deleted\n * 2. A new entry is created with all its relations\n *\n * This process affects relation ordering in the following way:\n *\n * Initial state (Entry A related to X, Y, Z):\n * ```\n * Entry A (draft) Entry A (published)\n * │ │\n * ├──(1)→ X ├──(1)→ X\n * ├──(2)→ Y ├──(2)→ Y\n * └──(3)→ Z └──(3)→ Z\n *\n * X's perspective: Y's perspective: Z's perspective:\n * └──(2)→ Entry A └──(1)→ Entry A └──(3)→ Entry A\n * ```\n *\n * After publishing Entry A (without relation order sync):\n * ```\n * Entry A (draft) Entry A (new published)\n * │ │\n * ├──(1)→ X ├──(1)→ X\n * ├──(2)→ Y ├──(2)→ Y\n * └──(3)→ Z └──(3)→ Z\n *\n * X's perspective: Y's perspective: Z's perspective:\n * └──(3)→ Entry A └──(3)→ Entry A └──(3)→ Entry A\n * (all relations appear last in order)\n * ```\n *\n * This module preserves the original ordering from both perspectives by:\n * 1. Capturing the relation order before the entry state changes\n * 2. Restoring this order after the new relations are created\n *\n * @param uid - The unique identifier of the content type being processed\n * @param context - Object containing arrays of old and new entry versions\n * @returns Array of objects containing join table metadata and relations to be updated\n */\nconst load = async (uid: UID.ContentType, { oldVersions }: LoadContext) => {\n const relationsToUpdate: RelationEntry[] = [];\n\n await strapi.db.transaction(async ({ trx }) => {\n const contentTypes = Object.values(strapi.contentTypes) as Schema.ContentType[];\n const components = Object.values(strapi.components) as Schema.Component[];\n\n for (const model of [...contentTypes, ...components]) {\n const dbModel = strapi.db.metadata.get(model.uid);\n\n for (const attribute of Object.values(dbModel.attributes) as Record<string, any>[]) {\n // Skip if not a bidirectional relation targeting our content type\n if (\n attribute.type !== 'relation' ||\n attribute.target !== uid ||\n !(attribute.inversedBy || attribute.mappedBy)\n ) {\n continue;\n }\n\n // If it's a self referencing relation, there is no need to sync any relation\n // The order will already be handled as both sides are inside the same content type\n if (model.uid === uid) {\n continue;\n }\n\n const joinTable = attribute.joinTable;\n if (!joinTable) {\n continue;\n }\n\n const { name: targetColumnName } = joinTable.inverseJoinColumn;\n\n // Load all relations that need their order preserved\n const oldEntryIds = oldVersions.map((entry) => entry.id);\n\n const existingRelations = await strapi.db\n .getConnection()\n .select('*')\n .from(joinTable.name)\n .whereIn(targetColumnName, oldEntryIds)\n .transacting(trx);\n\n if (existingRelations.length > 0) {\n relationsToUpdate.push({ joinTable, relations: existingRelations });\n }\n }\n }\n });\n\n return relationsToUpdate;\n};\n\n/**\n * Synchronizes the order of bidirectional relations after content entries have changed state.\n *\n * When entries change state (e.g., draft → published), their IDs change and all relations are recreated.\n * While the order of relations from the entry's perspective is maintained (as they're created in order),\n * the inverse relations (from related entries' perspective) would all appear last in order since they're new.\n *\n * Example:\n * ```\n * Before publish:\n * Article(id:1) →(order:1)→ Category(id:5)\n * Category(id:5) →(order:3)→ Article(id:1)\n *\n * After publish (without sync):\n * Article(id:2) →(order:1)→ Category(id:5) [order preserved]\n * Category(id:5) →(order:99)→ Article(id:2) [order lost - appears last]\n *\n * After sync:\n * Article(id:2) →(order:1)→ Category(id:5) [order preserved]\n * Category(id:5) →(order:3)→ Article(id:2) [order restored]\n * ```\n *\n * @param oldEntries - Array of previous entry versions with their IDs and locales\n * @param newEntries - Array of new entry versions with their IDs and locales\n * @param existingRelations - Array of join table data containing the relations to be updated\n */\nconst sync = async (\n oldEntries: { id: string; locale: string }[],\n newEntries: { id: string; locale: string }[],\n existingRelations: RelationEntry[]\n) => {\n // Group new entries by locale for easier lookup\n const newEntriesByLocale = keyBy('locale', newEntries);\n\n // Create a mapping of old entry IDs to new entry IDs based on locale\n const entryIdMapping = oldEntries.reduce(\n (acc, oldEntry) => {\n const newEntry = newEntriesByLocale[oldEntry.locale];\n if (!newEntry) return acc;\n acc[oldEntry.id] = newEntry.id;\n return acc;\n },\n {} as Record<string, string>\n );\n\n const republishedEntryIds = new Set(newEntries.map((e) => String(e.id)));\n const isRepublishedEntry = (id: string | number) => republishedEntryIds.has(String(id));\n\n await strapi.db.transaction(async ({ trx }) => {\n for (const { joinTable, relations } of existingRelations) {\n const sourceColumn = joinTable.inverseJoinColumn.name;\n const targetColumn = joinTable.joinColumn.name;\n const orderColumn = joinTable.orderColumnName;\n\n // Failsafe in case those don't exist\n if (!sourceColumn || !targetColumn || !orderColumn) {\n continue;\n }\n\n const mappedRelations = relations\n .map((relation) => ({\n relation,\n oldSourceId: relation[sourceColumn] as string,\n targetId: relation[targetColumn] as string,\n originalOrder: relation[orderColumn],\n newSourceId: entryIdMapping[relation[sourceColumn] as string],\n }))\n .filter((r): r is typeof r & { newSourceId: string } => Boolean(r.newSourceId));\n\n if (!mappedRelations.length) continue;\n\n const newSourceIds = mappedRelations.map((r) => r.newSourceId);\n\n // Batch UPDATE: set each row's order in a single statement using CASE\n const caseFragments = mappedRelations.map(() => `WHEN ?? = ? AND ?? = ? THEN ?`);\n const caseBindings = mappedRelations.flatMap(({ newSourceId, targetId, originalOrder }) => [\n sourceColumn,\n newSourceId,\n targetColumn,\n targetId,\n originalOrder,\n ]);\n\n await trx(joinTable.name)\n .whereIn(sourceColumn, newSourceIds)\n .update({\n [orderColumn]: trx.raw(`CASE ${caseFragments.join(' ')} ELSE ?? END`, [\n ...caseBindings,\n orderColumn,\n ]),\n });\n\n // Batch SELECT: find which rows exist so we know what to insert\n const existingRows = await trx(joinTable.name)\n .whereIn(sourceColumn, newSourceIds)\n .select(sourceColumn, targetColumn);\n\n const existingSet = new Set(\n existingRows.map((r: Record<string, unknown>) => `${r[sourceColumn]}:${r[targetColumn]}`)\n );\n\n // Batch INSERT: insert cascade-deleted rows that aren't from republished sources\n const toInsert = mappedRelations\n .filter(\n ({ newSourceId, targetId }) =>\n !existingSet.has(`${newSourceId}:${targetId}`) && !isRepublishedEntry(newSourceId)\n )\n .map(({ relation, newSourceId, originalOrder }) => ({\n ...omit(strapi.db.metadata.identifiers.ID_COLUMN, relation),\n [sourceColumn]: newSourceId,\n [orderColumn]: originalOrder,\n }));\n\n if (toInsert.length) {\n await trx.batchInsert(joinTable.name, toInsert, 1000);\n }\n }\n });\n};\n\nexport { load, sync };\n"],"names":["load","uid","oldVersions","relationsToUpdate","strapi","db","transaction","trx","contentTypes","Object","values","components","model","dbModel","metadata","get","attribute","attributes","type","target","inversedBy","mappedBy","joinTable","name","targetColumnName","inverseJoinColumn","oldEntryIds","map","entry","id","existingRelations","getConnection","select","from","whereIn","transacting","length","push","relations","sync","oldEntries","newEntries","newEntriesByLocale","keyBy","entryIdMapping","reduce","acc","oldEntry","newEntry","locale","republishedEntryIds","Set","e","String","isRepublishedEntry","has","sourceColumn","targetColumn","joinColumn","orderColumn","orderColumnName","mappedRelations","relation","oldSourceId","targetId","originalOrder","newSourceId","filter","r","Boolean","newSourceIds","caseFragments","caseBindings","flatMap","update","raw","join","existingRows","existingSet","toInsert","omit","identifiers","ID_COLUMN","batchInsert"],"mappings":"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"}
1
+ {"version":3,"file":"bidirectional-relations.js","sources":["../../../../src/services/document-service/utils/bidirectional-relations.ts"],"sourcesContent":["import { keyBy, omit } from 'lodash/fp';\nimport type { UID, Schema } from '@strapi/types';\nimport type { JoinTable } from '@strapi/database';\n\ninterface LoadContext {\n oldVersions: { id: string; locale: string }[];\n newVersions: { id: string; locale: string }[];\n}\n\ninterface RelationEntry {\n joinTable: JoinTable;\n relations: Record<string, unknown>[];\n /** FK column for the entity being published */\n entityColumn: string;\n /** FK column for the related entity */\n relatedColumn: string;\n}\n\n/** Draft id → published id for rows that already have a published counterpart (same document_id + locale). */\nconst draftToPublishedMap = async (trx: any, tableName: string, rowIds: unknown[]) => {\n const uniqueIds = [...new Set(rowIds)];\n if (uniqueIds.length === 0) {\n return new Map<string, string>();\n }\n\n const draftEntries = await strapi.db\n .getConnection()\n .select('id', 'document_id', 'locale')\n .from(tableName)\n .whereIn('id', uniqueIds as any)\n .transacting(trx);\n\n if (draftEntries.length === 0) {\n return new Map<string, string>();\n }\n\n const pubEntries = await strapi.db\n .getConnection()\n .select('id', 'document_id', 'locale')\n .from(tableName)\n .whereNotNull('published_at')\n .whereIn(\n 'document_id',\n draftEntries.map((e: any) => e.document_id)\n )\n .transacting(trx);\n\n const pubByDocLocale = new Map(\n pubEntries.map((e: any) => [`${e.document_id}_${e.locale}`, e.id])\n );\n\n const map = new Map<string, string>();\n for (const d of draftEntries) {\n const pubId = pubByDocLocale.get(`${d.document_id}_${d.locale}`);\n if (pubId) {\n map.set(String(d.id), String(pubId));\n }\n }\n return map;\n};\n\nconst remapRelatedIds = (rows: any[], relatedCol: string, idMap: Map<string, string>) =>\n rows.map((row) => {\n const next = idMap.get(String(row[relatedCol]));\n return next ? { ...row, [relatedCol]: next } : row;\n });\n\n/**\n * Reads join rows tied to the entry being published (`publishedCol` IN draft/old ids) and returns\n * batches for `sync()`. When the FK in `relatedCol` points at a D&P type, maps known draft ids to\n * published ids; otherwise keeps draft ids so sync can still run after both sides exist.\n */\nconst captureJoinBatches = async (\n trx: any,\n opts: {\n joinTable: any;\n /** Column holding ids of the document being published (the `uid` passed to load). */\n publishedCol: string;\n /** The other FK; may be remapped via draftToPublishedMap. */\n relatedCol: string;\n /** Content type behind `relatedCol` (used for D&P + table name). */\n relatedUid: UID.ContentType;\n relatedHasDraftAndPublish: boolean;\n /** Model that owns this attribute; draft capture is skipped for components. */\n schemaUid: UID.ContentType;\n oldVersions: LoadContext['oldVersions'];\n newVersions: LoadContext['newVersions'];\n }\n): Promise<RelationEntry[]> => {\n const {\n joinTable,\n publishedCol,\n relatedCol,\n relatedUid,\n relatedHasDraftAndPublish,\n schemaUid,\n oldVersions,\n newVersions,\n } = opts;\n\n const batches: RelationEntry[] = [];\n const { name: table } = joinTable;\n\n const oldIds = oldVersions.map((e) => e.id);\n if (oldIds.length > 0) {\n const existing = await strapi.db\n .getConnection()\n .select('*')\n .from(table)\n .whereIn(publishedCol, oldIds)\n .transacting(trx);\n if (existing.length > 0) {\n batches.push({\n joinTable,\n relations: existing,\n entityColumn: publishedCol,\n relatedColumn: relatedCol,\n });\n }\n }\n\n if (!strapi.contentTypes[schemaUid]) {\n return batches;\n }\n\n const oldLocales = new Set(oldVersions.map((e) => e.locale));\n const draftsOnly = newVersions.filter((v) => !oldLocales.has(v.locale));\n if (draftsOnly.length === 0) {\n return batches;\n }\n\n const draftIds = draftsOnly.map((e) => e.id);\n const draftRows = await strapi.db\n .getConnection()\n .select('*')\n .from(table)\n .whereIn(publishedCol, draftIds)\n .transacting(trx);\n\n if (draftRows.length === 0) {\n return batches;\n }\n\n let relations = draftRows;\n if (relatedHasDraftAndPublish) {\n const meta = strapi.db.metadata.get(relatedUid);\n const relatedIds = draftRows.map((r: any) => r[relatedCol]);\n const map = await draftToPublishedMap(trx, meta.tableName, relatedIds);\n relations = remapRelatedIds(draftRows, relatedCol, map);\n }\n\n batches.push({ joinTable, relations, entityColumn: publishedCol, relatedColumn: relatedCol });\n return batches;\n};\n\n/**\n * Loads all bidirectional relations that need to be synchronized when content entries change state\n * (e.g., during publish/unpublish operations).\n *\n * In Strapi, bidirectional relations allow maintaining order from both sides of the relation.\n * When an entry is published, the following occurs:\n *\n * 1. The old published entry is deleted\n * 2. A new entry is created with all its relations\n *\n * This process affects relation ordering in the following way:\n *\n * Initial state (Entry A related to X, Y, Z):\n * ```\n * Entry A (draft) Entry A (published)\n * │ │\n * ├──(1)→ X ├──(1)→ X\n * ├──(2)→ Y ├──(2)→ Y\n * └──(3)→ Z └──(3)→ Z\n *\n * X's perspective: Y's perspective: Z's perspective:\n * └──(2)→ Entry A └──(1)→ Entry A └──(3)→ Entry A\n * ```\n *\n * After publishing Entry A (without relation order sync):\n * ```\n * Entry A (draft) Entry A (new published)\n * │ │\n * ├──(1)→ X ├──(1)→ X\n * ├──(2)→ Y ├──(2)→ Y\n * └──(3)→ Z └──(3)→ Z\n *\n * X's perspective: Y's perspective: Z's perspective:\n * └──(3)→ Entry A └──(3)→ Entry A └──(3)→ Entry A\n * (all relations appear last in order)\n * ```\n *\n * This module preserves the original ordering from both perspectives by:\n * 1. Capturing the relation order before the entry state changes\n * 2. Restoring this order after the new relations are created\n *\n * @param uid - The unique identifier of the content type being processed\n * @param context - Object containing arrays of old and new entry versions\n * @returns Array of objects containing join table metadata and relations to be updated\n */\nconst load = async (uid: UID.ContentType, { oldVersions, newVersions }: LoadContext) => {\n const relationsToUpdate: RelationEntry[] = [];\n\n await strapi.db.transaction(async ({ trx }) => {\n const models = [\n ...(Object.values(strapi.contentTypes) as Schema.ContentType[]),\n ...Object.values(strapi.components),\n ];\n\n for (const model of models) {\n const dbModel = strapi.db.metadata.get(model.uid);\n\n for (const attribute of Object.values(dbModel.attributes) as Record<string, any>[]) {\n const joinTable = attribute.joinTable;\n\n if (attribute.type !== 'relation' || !joinTable) {\n continue;\n }\n\n if (!(attribute.inversedBy || attribute.mappedBy)) {\n continue;\n }\n\n // Owning side: e.g. Author.articles when publishing an Author.\n const isOwningSide =\n !!attribute.inversedBy &&\n model.uid === uid &&\n attribute.relation === 'manyToMany' &&\n model.uid !== attribute.target;\n\n // Inverse side: e.g. Article.authors when publishing an Article.\n const isInverseSide = attribute.target === uid && model.uid !== uid;\n\n if (!isOwningSide && !isInverseSide) {\n continue;\n }\n\n // Direction determines which join column belongs to the entity being published\n const publishedCol = isOwningSide\n ? joinTable.joinColumn.name\n : joinTable.inverseJoinColumn.name;\n const relatedCol = isOwningSide\n ? joinTable.inverseJoinColumn.name\n : joinTable.joinColumn.name;\n\n const relatedUid = (isOwningSide ? attribute.target : model.uid) as UID.ContentType;\n\n const batches = await captureJoinBatches(trx, {\n joinTable,\n publishedCol,\n relatedCol,\n relatedUid,\n relatedHasDraftAndPublish: isOwningSide\n ? !!strapi.contentTypes[relatedUid]?.options?.draftAndPublish\n : !!model.options?.draftAndPublish,\n schemaUid: model.uid as UID.ContentType,\n oldVersions,\n newVersions,\n });\n relationsToUpdate.push(...batches);\n }\n }\n });\n\n return relationsToUpdate;\n};\n\n/**\n * Synchronizes the order of bidirectional relations after content entries have changed state.\n *\n * When entries change state (e.g., draft → published), their IDs change and all relations are recreated.\n * While the order of relations from the entry's perspective is maintained (as they're created in order),\n * the inverse relations (from related entries' perspective) would all appear last in order since they're new.\n *\n * Example:\n * ```\n * Before publish:\n * Article(id:1) →(order:1)→ Category(id:5)\n * Category(id:5) →(order:3)→ Article(id:1)\n *\n * After publish (without sync):\n * Article(id:2) →(order:1)→ Category(id:5) [order preserved]\n * Category(id:5) →(order:99)→ Article(id:2) [order lost - appears last]\n *\n * After sync:\n * Article(id:2) →(order:1)→ Category(id:5) [order preserved]\n * Category(id:5) →(order:3)→ Article(id:2) [order restored]\n * ```\n *\n * @param oldEntries - Array of previous entry versions with their IDs and locales\n * @param newEntries - Array of new entry versions with their IDs and locales\n * @param existingRelations - Array of join table data containing the relations to be updated\n */\nconst sync = async (\n oldEntries: { id: string; locale: string }[],\n newEntries: { id: string; locale: string }[],\n existingRelations: RelationEntry[]\n) => {\n const newEntriesByLocale = keyBy('locale', newEntries);\n\n const entryIdMapping = oldEntries.reduce(\n (acc, oldEntry) => {\n const newEntry = newEntriesByLocale[oldEntry.locale];\n if (!newEntry) {\n return acc;\n }\n acc[oldEntry.id] = newEntry.id;\n return acc;\n },\n {} as Record<string, string>\n );\n\n const republishedEntryIds = new Set(newEntries.map((e) => String(e.id)));\n const isRepublishedEntry = (id: string | number) => republishedEntryIds.has(String(id));\n\n await strapi.db.transaction(async ({ trx }) => {\n for (const {\n joinTable,\n relations,\n entityColumn: sourceColumn,\n relatedColumn: targetColumn,\n } of existingRelations) {\n const orderColumn = joinTable.orderColumnName;\n\n // Failsafe in case those don't exist\n if (!sourceColumn || !targetColumn || !orderColumn) {\n continue;\n }\n\n const mappedRelations = relations\n .map((relation) => ({\n relation,\n oldSourceId: relation[sourceColumn] as string,\n targetId: relation[targetColumn] as string,\n originalOrder: relation[orderColumn],\n newSourceId: entryIdMapping[relation[sourceColumn] as string],\n }))\n .filter((r): r is typeof r & { newSourceId: string } => Boolean(r.newSourceId));\n\n if (!mappedRelations.length) continue;\n\n const newSourceIds = mappedRelations.map((r) => r.newSourceId);\n\n // Batch UPDATE: set each row's order in a single statement using CASE\n const caseFragments = mappedRelations.map(() => `WHEN ?? = ? AND ?? = ? THEN ?`);\n const caseBindings = mappedRelations.flatMap(({ newSourceId, targetId, originalOrder }) => [\n sourceColumn,\n newSourceId,\n targetColumn,\n targetId,\n originalOrder,\n ]);\n\n await trx(joinTable.name)\n .whereIn(sourceColumn, newSourceIds)\n .update({\n [orderColumn]: trx.raw(`CASE ${caseFragments.join(' ')} ELSE ?? END`, [\n ...caseBindings,\n orderColumn,\n ]),\n });\n\n // Batch SELECT: find which rows exist so we know what to insert\n const existingRows = await trx(joinTable.name)\n .whereIn(sourceColumn, newSourceIds)\n .select(sourceColumn, targetColumn);\n\n const existingSet = new Set(\n existingRows.map((r: Record<string, unknown>) => `${r[sourceColumn]}:${r[targetColumn]}`)\n );\n\n // Batch INSERT: insert cascade-deleted rows that aren't from republished sources\n const toInsert = mappedRelations\n .filter(\n ({ newSourceId, targetId }) =>\n !existingSet.has(`${newSourceId}:${targetId}`) && !isRepublishedEntry(newSourceId)\n )\n .map(({ relation, newSourceId, originalOrder }) => ({\n ...omit(strapi.db.metadata.identifiers.ID_COLUMN, relation),\n [sourceColumn]: newSourceId,\n [orderColumn]: originalOrder,\n }));\n\n if (toInsert.length) {\n const batchSize = strapi.db.dialect.getBatchInsertSize();\n await trx.batchInsert(joinTable.name, toInsert, batchSize);\n }\n }\n });\n};\n\nexport { load, sync };\n"],"names":["draftToPublishedMap","trx","tableName","rowIds","uniqueIds","Set","length","Map","draftEntries","strapi","db","getConnection","select","from","whereIn","transacting","pubEntries","whereNotNull","map","e","document_id","pubByDocLocale","locale","id","d","pubId","get","set","String","remapRelatedIds","rows","relatedCol","idMap","row","next","captureJoinBatches","opts","joinTable","publishedCol","relatedUid","relatedHasDraftAndPublish","schemaUid","oldVersions","newVersions","batches","name","table","oldIds","existing","push","relations","entityColumn","relatedColumn","contentTypes","oldLocales","draftsOnly","filter","v","has","draftIds","draftRows","meta","metadata","relatedIds","r","load","uid","relationsToUpdate","transaction","models","Object","values","components","model","dbModel","attribute","attributes","type","inversedBy","mappedBy","isOwningSide","relation","target","isInverseSide","joinColumn","inverseJoinColumn","options","draftAndPublish","sync","oldEntries","newEntries","existingRelations","newEntriesByLocale","keyBy","entryIdMapping","reduce","acc","oldEntry","newEntry","republishedEntryIds","isRepublishedEntry","sourceColumn","targetColumn","orderColumn","orderColumnName","mappedRelations","oldSourceId","targetId","originalOrder","newSourceId","Boolean","newSourceIds","caseFragments","caseBindings","flatMap","update","raw","join","existingRows","existingSet","toInsert","omit","identifiers","ID_COLUMN","batchSize","dialect","getBatchInsertSize","batchInsert"],"mappings":"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"}