@strapi/core 5.36.0 → 5.37.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.
Files changed (76) hide show
  1. package/dist/core-api/controller/index.d.ts.map +1 -1
  2. package/dist/core-api/controller/index.js +17 -16
  3. package/dist/core-api/controller/index.js.map +1 -1
  4. package/dist/core-api/controller/index.mjs +17 -16
  5. package/dist/core-api/controller/index.mjs.map +1 -1
  6. package/dist/core-api/routes/index.js +15 -2
  7. package/dist/core-api/routes/index.js.map +1 -1
  8. package/dist/core-api/routes/index.mjs +15 -2
  9. package/dist/core-api/routes/index.mjs.map +1 -1
  10. package/dist/core-api/routes/validation/content-type.d.ts +5 -1
  11. package/dist/core-api/routes/validation/content-type.d.ts.map +1 -1
  12. package/dist/core-api/routes/validation/content-type.js +10 -0
  13. package/dist/core-api/routes/validation/content-type.js.map +1 -1
  14. package/dist/core-api/routes/validation/content-type.mjs +10 -0
  15. package/dist/core-api/routes/validation/content-type.mjs.map +1 -1
  16. package/dist/migrations/database/5.0.0-discard-drafts.d.ts +21 -7
  17. package/dist/migrations/database/5.0.0-discard-drafts.d.ts.map +1 -1
  18. package/dist/migrations/database/5.0.0-discard-drafts.js +1936 -59
  19. package/dist/migrations/database/5.0.0-discard-drafts.js.map +1 -1
  20. package/dist/migrations/database/5.0.0-discard-drafts.mjs +1937 -60
  21. package/dist/migrations/database/5.0.0-discard-drafts.mjs.map +1 -1
  22. package/dist/package.json.js +19 -15
  23. package/dist/package.json.js.map +1 -1
  24. package/dist/package.json.mjs +19 -15
  25. package/dist/package.json.mjs.map +1 -1
  26. package/dist/services/content-api/index.d.ts +6 -3
  27. package/dist/services/content-api/index.d.ts.map +1 -1
  28. package/dist/services/content-api/index.js +165 -3
  29. package/dist/services/content-api/index.js.map +1 -1
  30. package/dist/services/content-api/index.mjs +147 -4
  31. package/dist/services/content-api/index.mjs.map +1 -1
  32. package/dist/services/cron.d.ts.map +1 -1
  33. package/dist/services/cron.js +3 -0
  34. package/dist/services/cron.js.map +1 -1
  35. package/dist/services/cron.mjs +3 -0
  36. package/dist/services/cron.mjs.map +1 -1
  37. package/dist/services/document-service/draft-and-publish.d.ts +16 -2
  38. package/dist/services/document-service/draft-and-publish.d.ts.map +1 -1
  39. package/dist/services/document-service/draft-and-publish.js +53 -0
  40. package/dist/services/document-service/draft-and-publish.js.map +1 -1
  41. package/dist/services/document-service/draft-and-publish.mjs +53 -2
  42. package/dist/services/document-service/draft-and-publish.mjs.map +1 -1
  43. package/dist/services/document-service/params.d.ts +24 -0
  44. package/dist/services/document-service/params.d.ts.map +1 -1
  45. package/dist/services/document-service/params.js +33 -0
  46. package/dist/services/document-service/params.js.map +1 -1
  47. package/dist/services/document-service/params.mjs +31 -1
  48. package/dist/services/document-service/params.mjs.map +1 -1
  49. package/dist/services/document-service/repository.d.ts.map +1 -1
  50. package/dist/services/document-service/repository.js +165 -4
  51. package/dist/services/document-service/repository.js.map +1 -1
  52. package/dist/services/document-service/repository.mjs +167 -6
  53. package/dist/services/document-service/repository.mjs.map +1 -1
  54. package/dist/services/document-service/transform/query.d.ts.map +1 -1
  55. package/dist/services/document-service/transform/query.js +39 -3
  56. package/dist/services/document-service/transform/query.js.map +1 -1
  57. package/dist/services/document-service/transform/query.mjs +37 -1
  58. package/dist/services/document-service/transform/query.mjs.map +1 -1
  59. package/dist/services/entity-validator/validators.d.ts.map +1 -1
  60. package/dist/services/entity-validator/validators.js +22 -5
  61. package/dist/services/entity-validator/validators.js.map +1 -1
  62. package/dist/services/entity-validator/validators.mjs +22 -5
  63. package/dist/services/entity-validator/validators.mjs.map +1 -1
  64. package/dist/services/server/register-routes.js +3 -0
  65. package/dist/services/server/register-routes.js.map +1 -1
  66. package/dist/services/server/register-routes.mjs +3 -0
  67. package/dist/services/server/register-routes.mjs.map +1 -1
  68. package/dist/services/webhook-runner.js +2 -2
  69. package/dist/services/webhook-runner.js.map +1 -1
  70. package/dist/services/webhook-runner.mjs +2 -2
  71. package/dist/services/webhook-runner.mjs.map +1 -1
  72. package/dist/services/worker-queue.js +2 -2
  73. package/dist/services/worker-queue.js.map +1 -1
  74. package/dist/services/worker-queue.mjs +2 -2
  75. package/dist/services/worker-queue.mjs.map +1 -1
  76. package/package.json +19 -15
@@ -1 +1 @@
1
- {"version":3,"file":"repository.mjs","sources":["../../../src/services/document-service/repository.ts"],"sourcesContent":["import { omit, assoc, merge, curry, isEmpty } 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 } 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 { 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\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 const validateParams = async (params: any) => {\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 // TODO: add validate status, locale, pagination\n\n return params;\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 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 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 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 (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 validateParams,\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 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","createContentTypeRepository","uid","validator","entityValidator","contentType","hasDraftAndPublish","contentTypesUtils","sortValidations","fieldValidations","filtersValidations","populateValidations","sort","field","filters","populate","validateParams","params","modelCache","createModelCache","ctx","validations","isEmpty","push","validateFilters","validateSort","fields","validateFields","validatePopulate","runParallelWithOrderedErrors","clear","lookup","errors","ValidationError","entries","createEntriesService","eventManager","createEventManager","emitEvent","curry","findMany","query","async","pipe","DP","i18n","transformParamsDocumentId","transformParamsToQuery","db","findFirst","findOne","opts","documentId","assoc","where","deleteDocument","omit","status","Error","entriesToDelete","deletedEntries","map","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","undefined"],"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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"}
@@ -1 +1 @@
1
- {"version":3,"file":"query.d.ts","sourceRoot":"","sources":["../../../../src/services/document-service/transform/query.ts"],"names":[],"mappings":";AAAA,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,eAAe,CAAC;AAIzC,QAAA,MAAM,sBAAsB,yDAI1B,CAAC;AAEH,OAAO,EAAE,sBAAsB,EAAE,CAAC"}
1
+ {"version":3,"file":"query.d.ts","sourceRoot":"","sources":["../../../../src/services/document-service/transform/query.ts"],"names":[],"mappings":";AAAA,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,eAAe,CAAC;AAOzC,QAAA,MAAM,sBAAsB,yDAsC1B,CAAC;AAEH,OAAO,EAAE,sBAAsB,EAAE,CAAC"}
@@ -1,11 +1,47 @@
1
1
  'use strict';
2
2
 
3
3
  var fp = require('lodash/fp');
4
+ var draftAndPublish = require('../draft-and-publish.js');
5
+ var params = require('../params.js');
4
6
 
5
- const transformParamsToQuery = fp.curry((uid, params)=>{
6
- const query = strapi.get('query-params').transform(uid, params);
7
+ const transformParamsToQuery = fp.curry((uid, params$1)=>{
8
+ const allowlisted = params.pickAllowedQueryParams(params$1 ?? {});
9
+ const query = strapi.get('query-params').transform(uid, allowlisted);
10
+ // Parse and validate hasPublishedVersion if provided (from allowlisted params only)
11
+ const hasPublishedVersion = draftAndPublish.parseHasPublishedVersion(allowlisted?.hasPublishedVersion);
12
+ // If hasPublishedVersion is set, wrap the existing filters function to also
13
+ // apply the hasPublishedVersion condition. This ensures the condition is
14
+ // applied to both root and nested (populate) queries.
15
+ if (hasPublishedVersion !== undefined) {
16
+ const existingFilters = query.filters;
17
+ query.filters = ({ meta, ...rest })=>{
18
+ // Get the existing filters result (from status param)
19
+ let existingResult = {};
20
+ if (typeof existingFilters === 'function') {
21
+ existingResult = existingFilters({
22
+ meta,
23
+ ...rest
24
+ }) || {};
25
+ } else if (existingFilters) {
26
+ existingResult = existingFilters;
27
+ }
28
+ // Get the hasPublishedVersion condition for this specific model
29
+ const hasPublishedCondition = draftAndPublish.getHasPublishedVersionCondition(meta.uid, hasPublishedVersion);
30
+ // Merge both conditions
31
+ if (hasPublishedCondition) {
32
+ const conditions = [
33
+ existingResult,
34
+ hasPublishedCondition
35
+ ].filter((c)=>Object.keys(c).length);
36
+ return {
37
+ $and: conditions
38
+ };
39
+ }
40
+ return existingResult;
41
+ };
42
+ }
7
43
  return fp.assoc('where', {
8
- ...params?.lookup,
44
+ ...params$1?.lookup,
9
45
  ...query.where
10
46
  }, query);
11
47
  });
@@ -1 +1 @@
1
- {"version":3,"file":"query.js","sources":["../../../../src/services/document-service/transform/query.ts"],"sourcesContent":["import type { UID } from '@strapi/types';\n\nimport { curry, assoc } from 'lodash/fp';\n\nconst transformParamsToQuery = curry((uid: UID.Schema, params: any) => {\n const query = strapi.get('query-params').transform(uid, params);\n\n return assoc('where', { ...params?.lookup, ...query.where }, query);\n});\n\nexport { transformParamsToQuery };\n"],"names":["transformParamsToQuery","curry","uid","params","query","strapi","get","transform","assoc","lookup","where"],"mappings":";;;;AAIMA,MAAAA,sBAAAA,GAAyBC,QAAM,CAAA,CAACC,GAAiBC,EAAAA,MAAAA,GAAAA;AACrD,IAAA,MAAMC,QAAQC,MAAOC,CAAAA,GAAG,CAAC,cAAgBC,CAAAA,CAAAA,SAAS,CAACL,GAAKC,EAAAA,MAAAA,CAAAA;AAExD,IAAA,OAAOK,SAAM,OAAS,EAAA;AAAE,QAAA,GAAGL,QAAQM,MAAM;AAAE,QAAA,GAAGL,MAAMM;KAASN,EAAAA,KAAAA,CAAAA;AAC/D,CAAA;;;;"}
1
+ {"version":3,"file":"query.js","sources":["../../../../src/services/document-service/transform/query.ts"],"sourcesContent":["import type { UID } from '@strapi/types';\n\nimport { curry, assoc } from 'lodash/fp';\nimport { parseHasPublishedVersion, getHasPublishedVersionCondition } from '../draft-and-publish';\n\nimport { pickAllowedQueryParams } from '../params';\n\nconst transformParamsToQuery = curry((uid: UID.Schema, params: any) => {\n const allowlisted = pickAllowedQueryParams(params ?? {});\n const query = strapi.get('query-params').transform(uid, allowlisted);\n\n // Parse and validate hasPublishedVersion if provided (from allowlisted params only)\n const hasPublishedVersion = parseHasPublishedVersion(allowlisted?.hasPublishedVersion);\n\n // If hasPublishedVersion is set, wrap the existing filters function to also\n // apply the hasPublishedVersion condition. This ensures the condition is\n // applied to both root and nested (populate) queries.\n if (hasPublishedVersion !== undefined) {\n const existingFilters = query.filters;\n\n query.filters = ({ meta, ...rest }: { meta: { uid: UID.Schema } }) => {\n // Get the existing filters result (from status param)\n let existingResult = {};\n if (typeof existingFilters === 'function') {\n existingResult = existingFilters({ meta, ...rest }) || {};\n } else if (existingFilters) {\n existingResult = existingFilters;\n }\n\n // Get the hasPublishedVersion condition for this specific model\n const hasPublishedCondition = getHasPublishedVersionCondition(meta.uid, hasPublishedVersion);\n\n // Merge both conditions\n if (hasPublishedCondition) {\n const conditions = [existingResult, hasPublishedCondition].filter(\n (c) => Object.keys(c).length\n );\n return { $and: conditions };\n }\n\n return existingResult;\n };\n }\n\n return assoc('where', { ...params?.lookup, ...query.where }, query);\n});\n\nexport { transformParamsToQuery };\n"],"names":["transformParamsToQuery","curry","uid","params","allowlisted","pickAllowedQueryParams","query","strapi","get","transform","hasPublishedVersion","parseHasPublishedVersion","undefined","existingFilters","filters","meta","rest","existingResult","hasPublishedCondition","getHasPublishedVersionCondition","conditions","filter","c","Object","keys","length","$and","assoc","lookup","where"],"mappings":";;;;;;AAOMA,MAAAA,sBAAAA,GAAyBC,QAAM,CAAA,CAACC,GAAiBC,EAAAA,QAAAA,GAAAA;IACrD,MAAMC,WAAAA,GAAcC,6BAAuBF,CAAAA,QAAAA,IAAU,EAAC,CAAA;AACtD,IAAA,MAAMG,QAAQC,MAAOC,CAAAA,GAAG,CAAC,cAAgBC,CAAAA,CAAAA,SAAS,CAACP,GAAKE,EAAAA,WAAAA,CAAAA;;IAGxD,MAAMM,mBAAAA,GAAsBC,yCAAyBP,WAAaM,EAAAA,mBAAAA,CAAAA;;;;AAKlE,IAAA,IAAIA,wBAAwBE,SAAW,EAAA;QACrC,MAAMC,eAAAA,GAAkBP,MAAMQ,OAAO;AAErCR,QAAAA,KAAAA,CAAMQ,OAAO,GAAG,CAAC,EAAEC,IAAI,EAAE,GAAGC,IAAqC,EAAA,GAAA;;AAE/D,YAAA,IAAIC,iBAAiB,EAAC;YACtB,IAAI,OAAOJ,oBAAoB,UAAY,EAAA;AACzCI,gBAAAA,cAAAA,GAAiBJ,eAAgB,CAAA;AAAEE,oBAAAA,IAAAA;AAAM,oBAAA,GAAGC;AAAK,iBAAA,CAAA,IAAM,EAAC;AAC1D,aAAA,MAAO,IAAIH,eAAiB,EAAA;gBAC1BI,cAAiBJ,GAAAA,eAAAA;AACnB;;AAGA,YAAA,MAAMK,qBAAwBC,GAAAA,+CAAAA,CAAgCJ,IAAKb,CAAAA,GAAG,EAAEQ,mBAAAA,CAAAA;;AAGxE,YAAA,IAAIQ,qBAAuB,EAAA;AACzB,gBAAA,MAAME,UAAa,GAAA;AAACH,oBAAAA,cAAAA;AAAgBC,oBAAAA;iBAAsB,CAACG,MAAM,CAC/D,CAACC,CAAAA,GAAMC,OAAOC,IAAI,CAACF,GAAGG,MAAM,CAAA;gBAE9B,OAAO;oBAAEC,IAAMN,EAAAA;AAAW,iBAAA;AAC5B;YAEA,OAAOH,cAAAA;AACT,SAAA;AACF;AAEA,IAAA,OAAOU,SAAM,OAAS,EAAA;AAAE,QAAA,GAAGxB,UAAQyB,MAAM;AAAE,QAAA,GAAGtB,MAAMuB;KAASvB,EAAAA,KAAAA,CAAAA;AAC/D,CAAA;;;;"}
@@ -1,7 +1,43 @@
1
1
  import { curry, assoc } from 'lodash/fp';
2
+ import { parseHasPublishedVersion, getHasPublishedVersionCondition } from '../draft-and-publish.mjs';
3
+ import { pickAllowedQueryParams } from '../params.mjs';
2
4
 
3
5
  const transformParamsToQuery = curry((uid, params)=>{
4
- const query = strapi.get('query-params').transform(uid, params);
6
+ const allowlisted = pickAllowedQueryParams(params ?? {});
7
+ const query = strapi.get('query-params').transform(uid, allowlisted);
8
+ // Parse and validate hasPublishedVersion if provided (from allowlisted params only)
9
+ const hasPublishedVersion = parseHasPublishedVersion(allowlisted?.hasPublishedVersion);
10
+ // If hasPublishedVersion is set, wrap the existing filters function to also
11
+ // apply the hasPublishedVersion condition. This ensures the condition is
12
+ // applied to both root and nested (populate) queries.
13
+ if (hasPublishedVersion !== undefined) {
14
+ const existingFilters = query.filters;
15
+ query.filters = ({ meta, ...rest })=>{
16
+ // Get the existing filters result (from status param)
17
+ let existingResult = {};
18
+ if (typeof existingFilters === 'function') {
19
+ existingResult = existingFilters({
20
+ meta,
21
+ ...rest
22
+ }) || {};
23
+ } else if (existingFilters) {
24
+ existingResult = existingFilters;
25
+ }
26
+ // Get the hasPublishedVersion condition for this specific model
27
+ const hasPublishedCondition = getHasPublishedVersionCondition(meta.uid, hasPublishedVersion);
28
+ // Merge both conditions
29
+ if (hasPublishedCondition) {
30
+ const conditions = [
31
+ existingResult,
32
+ hasPublishedCondition
33
+ ].filter((c)=>Object.keys(c).length);
34
+ return {
35
+ $and: conditions
36
+ };
37
+ }
38
+ return existingResult;
39
+ };
40
+ }
5
41
  return assoc('where', {
6
42
  ...params?.lookup,
7
43
  ...query.where
@@ -1 +1 @@
1
- {"version":3,"file":"query.mjs","sources":["../../../../src/services/document-service/transform/query.ts"],"sourcesContent":["import type { UID } from '@strapi/types';\n\nimport { curry, assoc } from 'lodash/fp';\n\nconst transformParamsToQuery = curry((uid: UID.Schema, params: any) => {\n const query = strapi.get('query-params').transform(uid, params);\n\n return assoc('where', { ...params?.lookup, ...query.where }, query);\n});\n\nexport { transformParamsToQuery };\n"],"names":["transformParamsToQuery","curry","uid","params","query","strapi","get","transform","assoc","lookup","where"],"mappings":";;AAIMA,MAAAA,sBAAAA,GAAyBC,KAAM,CAAA,CAACC,GAAiBC,EAAAA,MAAAA,GAAAA;AACrD,IAAA,MAAMC,QAAQC,MAAOC,CAAAA,GAAG,CAAC,cAAgBC,CAAAA,CAAAA,SAAS,CAACL,GAAKC,EAAAA,MAAAA,CAAAA;AAExD,IAAA,OAAOK,MAAM,OAAS,EAAA;AAAE,QAAA,GAAGL,QAAQM,MAAM;AAAE,QAAA,GAAGL,MAAMM;KAASN,EAAAA,KAAAA,CAAAA;AAC/D,CAAA;;;;"}
1
+ {"version":3,"file":"query.mjs","sources":["../../../../src/services/document-service/transform/query.ts"],"sourcesContent":["import type { UID } from '@strapi/types';\n\nimport { curry, assoc } from 'lodash/fp';\nimport { parseHasPublishedVersion, getHasPublishedVersionCondition } from '../draft-and-publish';\n\nimport { pickAllowedQueryParams } from '../params';\n\nconst transformParamsToQuery = curry((uid: UID.Schema, params: any) => {\n const allowlisted = pickAllowedQueryParams(params ?? {});\n const query = strapi.get('query-params').transform(uid, allowlisted);\n\n // Parse and validate hasPublishedVersion if provided (from allowlisted params only)\n const hasPublishedVersion = parseHasPublishedVersion(allowlisted?.hasPublishedVersion);\n\n // If hasPublishedVersion is set, wrap the existing filters function to also\n // apply the hasPublishedVersion condition. This ensures the condition is\n // applied to both root and nested (populate) queries.\n if (hasPublishedVersion !== undefined) {\n const existingFilters = query.filters;\n\n query.filters = ({ meta, ...rest }: { meta: { uid: UID.Schema } }) => {\n // Get the existing filters result (from status param)\n let existingResult = {};\n if (typeof existingFilters === 'function') {\n existingResult = existingFilters({ meta, ...rest }) || {};\n } else if (existingFilters) {\n existingResult = existingFilters;\n }\n\n // Get the hasPublishedVersion condition for this specific model\n const hasPublishedCondition = getHasPublishedVersionCondition(meta.uid, hasPublishedVersion);\n\n // Merge both conditions\n if (hasPublishedCondition) {\n const conditions = [existingResult, hasPublishedCondition].filter(\n (c) => Object.keys(c).length\n );\n return { $and: conditions };\n }\n\n return existingResult;\n };\n }\n\n return assoc('where', { ...params?.lookup, ...query.where }, query);\n});\n\nexport { transformParamsToQuery };\n"],"names":["transformParamsToQuery","curry","uid","params","allowlisted","pickAllowedQueryParams","query","strapi","get","transform","hasPublishedVersion","parseHasPublishedVersion","undefined","existingFilters","filters","meta","rest","existingResult","hasPublishedCondition","getHasPublishedVersionCondition","conditions","filter","c","Object","keys","length","$and","assoc","lookup","where"],"mappings":";;;;AAOMA,MAAAA,sBAAAA,GAAyBC,KAAM,CAAA,CAACC,GAAiBC,EAAAA,MAAAA,GAAAA;IACrD,MAAMC,WAAAA,GAAcC,sBAAuBF,CAAAA,MAAAA,IAAU,EAAC,CAAA;AACtD,IAAA,MAAMG,QAAQC,MAAOC,CAAAA,GAAG,CAAC,cAAgBC,CAAAA,CAAAA,SAAS,CAACP,GAAKE,EAAAA,WAAAA,CAAAA;;IAGxD,MAAMM,mBAAAA,GAAsBC,yBAAyBP,WAAaM,EAAAA,mBAAAA,CAAAA;;;;AAKlE,IAAA,IAAIA,wBAAwBE,SAAW,EAAA;QACrC,MAAMC,eAAAA,GAAkBP,MAAMQ,OAAO;AAErCR,QAAAA,KAAAA,CAAMQ,OAAO,GAAG,CAAC,EAAEC,IAAI,EAAE,GAAGC,IAAqC,EAAA,GAAA;;AAE/D,YAAA,IAAIC,iBAAiB,EAAC;YACtB,IAAI,OAAOJ,oBAAoB,UAAY,EAAA;AACzCI,gBAAAA,cAAAA,GAAiBJ,eAAgB,CAAA;AAAEE,oBAAAA,IAAAA;AAAM,oBAAA,GAAGC;AAAK,iBAAA,CAAA,IAAM,EAAC;AAC1D,aAAA,MAAO,IAAIH,eAAiB,EAAA;gBAC1BI,cAAiBJ,GAAAA,eAAAA;AACnB;;AAGA,YAAA,MAAMK,qBAAwBC,GAAAA,+BAAAA,CAAgCJ,IAAKb,CAAAA,GAAG,EAAEQ,mBAAAA,CAAAA;;AAGxE,YAAA,IAAIQ,qBAAuB,EAAA;AACzB,gBAAA,MAAME,UAAa,GAAA;AAACH,oBAAAA,cAAAA;AAAgBC,oBAAAA;iBAAsB,CAACG,MAAM,CAC/D,CAACC,CAAAA,GAAMC,OAAOC,IAAI,CAACF,GAAGG,MAAM,CAAA;gBAE9B,OAAO;oBAAEC,IAAMN,EAAAA;AAAW,iBAAA;AAC5B;YAEA,OAAOH,cAAAA;AACT,SAAA;AACF;AAEA,IAAA,OAAOU,MAAM,OAAS,EAAA;AAAE,QAAA,GAAGxB,QAAQyB,MAAM;AAAE,QAAA,GAAGtB,MAAMuB;KAASvB,EAAAA,KAAAA,CAAAA;AAC/D,CAAA;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"validators.d.ts","sourceRoot":"","sources":["../../../src/services/entity-validator/validators.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"validators.d.ts","sourceRoot":"","sources":["../../../src/services/entity-validator/validators.ts"],"names":[],"mappings":"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"}
@@ -4,7 +4,12 @@ var _ = require('lodash');
4
4
  var strapiUtils = require('@strapi/utils');
5
5
  var blocksValidator = require('./blocks-validator.js');
6
6
 
7
- /* Validator utils */ /**
7
+ /* Validator utils */ const toNumberSafe = (value)=>{
8
+ if (value === undefined || value === null) return undefined;
9
+ const num = Number(value);
10
+ return Number.isFinite(num) ? num : undefined;
11
+ };
12
+ /**
8
13
  * Adds minLength validator
9
14
  */ const addMinLengthValidator = (validator, { attr }, { isDraft })=>{
10
15
  return attr.minLength && _.isInteger(attr.minLength) && !isDraft ? validator.min(attr.minLength) : validator;
@@ -18,16 +23,28 @@ var blocksValidator = require('./blocks-validator.js');
18
23
  /**
19
24
  * Adds min integer validator
20
25
  * @returns {NumberSchema}
21
- */ const addMinIntegerValidator = (validator, { attr }, { isDraft })=>_.isNumber(attr.min) && !isDraft ? validator.min(_.toInteger(attr.min)) : validator;
26
+ */ const addMinIntegerValidator = (validator, { attr }, { isDraft })=>{
27
+ const min = toNumberSafe(attr.min);
28
+ return min !== undefined && !isDraft ? validator.min(_.toInteger(min)) : validator;
29
+ };
22
30
  /**
23
31
  * Adds max integer validator
24
- */ const addMaxIntegerValidator = (validator, { attr })=>_.isNumber(attr.max) ? validator.max(_.toInteger(attr.max)) : validator;
32
+ */ const addMaxIntegerValidator = (validator, { attr })=>{
33
+ const max = toNumberSafe(attr.max);
34
+ return max !== undefined ? validator.max(_.toInteger(max)) : validator;
35
+ };
25
36
  /**
26
37
  * Adds min float/decimal validator
27
- */ const addMinFloatValidator = (validator, { attr }, { isDraft })=>_.isNumber(attr.min) && !isDraft ? validator.min(attr.min) : validator;
38
+ */ const addMinFloatValidator = (validator, { attr }, { isDraft })=>{
39
+ const min = toNumberSafe(attr.min);
40
+ return min !== undefined && !isDraft ? validator.min(min) : validator;
41
+ };
28
42
  /**
29
43
  * Adds max float/decimal validator
30
- */ const addMaxFloatValidator = (validator, { attr })=>_.isNumber(attr.max) ? validator.max(attr.max) : validator;
44
+ */ const addMaxFloatValidator = (validator, { attr })=>{
45
+ const max = toNumberSafe(attr.max);
46
+ return max !== undefined ? validator.max(max) : validator;
47
+ };
31
48
  /**
32
49
  * Adds regex validator
33
50
  */ const addStringRegexValidator = (validator, { attr }, { isDraft })=>{
@@ -1 +1 @@
1
- {"version":3,"file":"validators.js","sources":["../../../src/services/entity-validator/validators.ts"],"sourcesContent":["/**\n * Validators check if the entry data meets specific criteria before saving or publishing.\n * (e.g., length, range, format).\n *\n * Drafts have limited validations (mainly max constraints),\n * while published content undergoes full validation.\n *\n * The system also takes locales into account when validating data.\n * E.g, unique fields must be unique within the same locale.\n */\nimport _ from 'lodash';\nimport { yup } from '@strapi/utils';\nimport type { Schema, Struct, Modules } from '@strapi/types';\nimport { blocksValidator } from './blocks-validator';\n\nimport type { ComponentContext } from '.';\n\nexport interface ValidatorMetas<\n TAttribute extends Schema.Attribute.AnyAttribute = Schema.Attribute.AnyAttribute,\n TValue extends Schema.Attribute.Value<TAttribute> = Schema.Attribute.Value<TAttribute>,\n> {\n attr: TAttribute;\n model: Struct.Schema;\n updatedAttribute: {\n name: string;\n value: TValue;\n };\n data: Record<string, unknown>;\n componentContext?: ComponentContext;\n entity?: Modules.EntityValidator.Entity;\n}\n\ninterface ValidatorOptions {\n isDraft: boolean;\n locale?: string;\n}\n\n/* Validator utils */\n\n/**\n * Adds minLength validator\n */\nconst addMinLengthValidator = (\n validator: yup.StringSchema,\n {\n attr,\n }: {\n attr:\n | Schema.Attribute.String\n | Schema.Attribute.Text\n | Schema.Attribute.RichText\n | Schema.Attribute.Password\n | Schema.Attribute.Email\n | Schema.Attribute.UID;\n },\n { isDraft }: ValidatorOptions\n) => {\n return attr.minLength && _.isInteger(attr.minLength) && !isDraft\n ? validator.min(attr.minLength)\n : validator;\n};\n\n/**\n * Adds maxLength validator\n * @returns {StringSchema}\n */\nconst addMaxLengthValidator = (\n validator: yup.StringSchema,\n {\n attr,\n }: {\n attr:\n | Schema.Attribute.String\n | Schema.Attribute.Text\n | Schema.Attribute.RichText\n | Schema.Attribute.Password\n | Schema.Attribute.Email\n | Schema.Attribute.UID;\n }\n) => {\n return attr.maxLength && _.isInteger(attr.maxLength) ? validator.max(attr.maxLength) : validator;\n};\n\n/**\n * Adds min integer validator\n * @returns {NumberSchema}\n */\nconst addMinIntegerValidator = (\n validator: yup.NumberSchema,\n {\n attr,\n }: {\n attr: Schema.Attribute.Integer | Schema.Attribute.BigInteger;\n },\n { isDraft }: ValidatorOptions\n) => (_.isNumber(attr.min) && !isDraft ? validator.min(_.toInteger(attr.min)) : validator);\n\n/**\n * Adds max integer validator\n */\nconst addMaxIntegerValidator = (\n validator: yup.NumberSchema,\n {\n attr,\n }: {\n attr: Schema.Attribute.Integer | Schema.Attribute.BigInteger;\n }\n) => (_.isNumber(attr.max) ? validator.max(_.toInteger(attr.max)) : validator);\n\n/**\n * Adds min float/decimal validator\n */\nconst addMinFloatValidator = (\n validator: yup.NumberSchema,\n {\n attr,\n }: {\n attr: Schema.Attribute.Decimal | Schema.Attribute.Float;\n },\n { isDraft }: ValidatorOptions\n) => (_.isNumber(attr.min) && !isDraft ? validator.min(attr.min) : validator);\n\n/**\n * Adds max float/decimal validator\n */\nconst addMaxFloatValidator = (\n validator: yup.NumberSchema,\n {\n attr,\n }: {\n attr: Schema.Attribute.Decimal | Schema.Attribute.Float;\n }\n) => (_.isNumber(attr.max) ? validator.max(attr.max) : validator);\n\n/**\n * Adds regex validator\n */\nconst addStringRegexValidator = (\n validator: yup.StringSchema,\n {\n attr,\n }: {\n attr:\n | Schema.Attribute.String\n | Schema.Attribute.Text\n | Schema.Attribute.RichText\n | Schema.Attribute.Password\n | Schema.Attribute.Email\n | Schema.Attribute.UID;\n },\n { isDraft }: ValidatorOptions\n) => {\n return 'regex' in attr && !_.isUndefined(attr.regex) && !isDraft\n ? validator.matches(new RegExp(attr.regex), { excludeEmptyString: !attr.required })\n : validator;\n};\n\nconst addUniqueValidator = <T extends yup.AnySchema>(\n validator: T,\n {\n attr,\n model,\n updatedAttribute,\n entity,\n componentContext,\n }: ValidatorMetas<Schema.Attribute.AnyAttribute & Schema.Attribute.UniqueOption>,\n options: ValidatorOptions\n): T => {\n if (attr.type !== 'uid' && !attr.unique) {\n return validator;\n }\n\n const validateUniqueFieldWithinComponent = async (value: any): Promise<boolean> => {\n if (!componentContext) {\n return false;\n }\n\n // If we are validating a unique field within a repeatable component,\n // we first need to ensure that the repeatable in the current entity is\n // valid against itself.\n const hasRepeatableData = componentContext.repeatableData.length > 0;\n if (hasRepeatableData) {\n const { name: updatedName, value: updatedValue } = updatedAttribute;\n // Construct the full path to the unique field within the component.\n const pathToCheck = [...componentContext.pathToComponent.slice(1), updatedName].join('.');\n\n // Extract the values from the repeatable data using the constructed path\n const values = componentContext.repeatableData.map((item) => {\n return pathToCheck.split('.').reduce((acc, key) => acc[key], item as any);\n });\n\n // Check if the value is repeated in the current entity\n const isUpdatedAttributeRepeatedInThisEntity =\n values.filter((value) => value === updatedValue).length > 1;\n\n if (isUpdatedAttributeRepeatedInThisEntity) {\n return false;\n }\n }\n\n /**\n * When `componentContext` is present it means we are dealing with a unique\n * field within a component.\n *\n * The unique validation must consider the specific context of the\n * component, which will always be contained within a parent content type\n * and may also be nested within another component.\n *\n * We construct a query that takes into account the parent's model UID,\n * dimensions (such as draft and publish state/locale) and excludes the current\n * content type entity by its ID if provided.\n */\n const {\n model: parentModel,\n options: parentOptions,\n id: excludeId,\n } = componentContext.parentContent;\n\n const whereConditions: Record<string, any> = {};\n const isParentDraft = parentOptions && parentOptions.isDraft;\n\n whereConditions.publishedAt = isParentDraft ? null : { $notNull: true };\n\n if (parentOptions?.locale) {\n whereConditions.locale = parentOptions.locale;\n }\n\n if (excludeId && !Number.isNaN(excludeId)) {\n whereConditions.id = { $ne: excludeId };\n }\n\n const queryUid = parentModel.uid;\n const queryWhere = {\n ...componentContext.pathToComponent.reduceRight((acc, key) => ({ [key]: acc }), {\n [updatedAttribute.name]: value,\n }),\n\n ...whereConditions,\n };\n\n // The validation should pass if there is no other record found from the query\n return !(await strapi.db.query(queryUid).findOne({ where: queryWhere }));\n };\n\n const validateUniqueFieldWithinDynamicZoneComponent = async (\n startOfPath: string\n ): Promise<boolean> => {\n if (!componentContext) {\n return false;\n }\n\n const targetComponentUID = model.uid;\n // Ensure that the value is unique within the dynamic zone in this entity.\n const countOfValueInThisEntity = (componentContext?.fullDynamicZoneContent ?? []).reduce(\n (acc, component) => {\n if (component.__component !== targetComponentUID) {\n return acc;\n }\n\n const updatedValue = component[updatedAttribute.name];\n return updatedValue === updatedAttribute.value ? acc + 1 : acc;\n },\n 0\n );\n\n if (countOfValueInThisEntity > 1) {\n // If the value is repeated in the current entity, the validation fails.\n return false;\n }\n\n // Build a query for the parent content type to find all entities in the\n // same locale and publication state\n type QueryType = {\n select: string[];\n where: {\n published_at?: { $eq: null } | { $ne: null };\n id?: { $ne: number };\n locale?: string;\n };\n populate: {\n [key: string]: {\n on: {\n [key: string]: {\n select: string[];\n where: { [key: string]: string | number | boolean };\n };\n };\n };\n };\n };\n\n // Populate the dynamic zone for any components that share the same value\n // as the updated attribute.\n const query: QueryType = {\n select: ['id'],\n where: {},\n populate: {\n [startOfPath]: {\n on: {\n [targetComponentUID]: {\n select: ['id'],\n where: { [updatedAttribute.name]: updatedAttribute.value },\n },\n },\n },\n },\n };\n\n const { options, id } = componentContext.parentContent;\n\n if (options?.isDraft !== undefined) {\n query.where.published_at = options.isDraft ? { $eq: null } : { $ne: null };\n }\n\n if (id) {\n query.where.id = { $ne: id };\n }\n\n if (options?.locale) {\n query.where.locale = options.locale;\n }\n\n const parentModelQueryResult = await strapi.db\n .query(componentContext.parentContent.model.uid)\n .findMany(query);\n\n // Filter the results to only include results that have components in the\n // dynamic zone that match the target component type.\n const filteredResults = parentModelQueryResult\n .filter((result) => Array.isArray(result[startOfPath]) && result[startOfPath].length)\n .flatMap((result) => result[startOfPath])\n .filter((dynamicZoneComponent) => dynamicZoneComponent.__component === targetComponentUID);\n\n if (filteredResults.length >= 1) {\n return false;\n }\n\n return true;\n };\n\n return validator.test('unique', 'This attribute must be unique', async (value) => {\n /**\n * If the attribute value is `null` or an empty string we want to skip the unique validation.\n * Otherwise it'll only accept a single entry with that value in the database.\n */\n if (_.isNil(value) || value === '') {\n return true;\n }\n\n /**\n * We don't validate any unique constraint for draft entries.\n */\n if (options.isDraft) {\n return true;\n }\n\n const hasPathToComponent = componentContext && componentContext.pathToComponent.length > 0;\n if (hasPathToComponent) {\n // Detect if we are validating within a dynamiczone by checking if the first\n // path is a dynamiczone attribute in the parent content type.\n const startOfPath = componentContext.pathToComponent[0];\n const testingDZ =\n componentContext.parentContent.model.attributes[startOfPath].type === 'dynamiczone';\n\n if (testingDZ) {\n return validateUniqueFieldWithinDynamicZoneComponent(startOfPath);\n }\n\n return validateUniqueFieldWithinComponent(value);\n }\n\n /**\n * Here we are validating a scalar unique field from the content type's schema.\n * We construct a query to check if the value is unique\n * considering dimensions (e.g. locale, publication state) and excluding the current entity by its ID if available.\n */\n const scalarAttributeWhere: Record<string, any> = {\n [updatedAttribute.name]: value,\n publishedAt: { $notNull: true },\n };\n\n if (options?.locale) {\n scalarAttributeWhere.locale = options.locale;\n }\n\n if (entity?.id) {\n scalarAttributeWhere.id = { $ne: entity.id };\n }\n\n // The validation should pass if there is no other record found from the query\n return !(await strapi.db\n .query(model.uid)\n .findOne({ where: scalarAttributeWhere, select: ['id'] }));\n });\n};\n\n/* Type validators */\n\nconst stringValidator = (\n metas: ValidatorMetas<\n | Schema.Attribute.String\n | Schema.Attribute.Text\n | Schema.Attribute.RichText\n | Schema.Attribute.Password\n | Schema.Attribute.Email\n | Schema.Attribute.UID\n >,\n options: ValidatorOptions\n) => {\n let schema = yup.string().transform((val, originalVal) => originalVal);\n\n schema = addMinLengthValidator(schema, metas, options);\n schema = addMaxLengthValidator(schema, metas);\n schema = addStringRegexValidator(schema, metas, options);\n schema = addUniqueValidator(schema, metas, options);\n\n return schema;\n};\n\nexport const emailValidator = (\n metas: ValidatorMetas<Schema.Attribute.Email>,\n options: ValidatorOptions\n) => {\n const schema = stringValidator(metas, options);\n\n if (options.isDraft) {\n return schema;\n }\n\n return schema.email().min(\n 1,\n // eslint-disable-next-line no-template-curly-in-string\n '${path} cannot be empty'\n );\n};\n\nexport const uidValidator = (\n metas: ValidatorMetas<Schema.Attribute.UID>,\n options: ValidatorOptions\n) => {\n const schema = stringValidator(metas, options);\n\n if (options.isDraft) {\n return schema;\n }\n\n if (metas.attr.regex) {\n return schema.matches(new RegExp(metas.attr.regex));\n }\n\n return schema.matches(/^[A-Za-z0-9-_.~]*$/);\n};\n\nexport const enumerationValidator = ({ attr }: { attr: Schema.Attribute.Enumeration }) => {\n return yup\n .string()\n .oneOf((Array.isArray(attr.enum) ? attr.enum : [attr.enum]).concat(null as any));\n};\n\nexport const integerValidator = (\n metas: ValidatorMetas<Schema.Attribute.Integer | Schema.Attribute.BigInteger>,\n options: ValidatorOptions\n) => {\n let schema = yup.number().integer();\n\n schema = addMinIntegerValidator(schema, metas, options);\n schema = addMaxIntegerValidator(schema, metas);\n schema = addUniqueValidator(schema, metas, options);\n\n return schema;\n};\n\nexport const floatValidator = (\n metas: ValidatorMetas<Schema.Attribute.Decimal | Schema.Attribute.Float>,\n options: ValidatorOptions\n) => {\n let schema = yup.number();\n\n schema = addMinFloatValidator(schema, metas, options);\n schema = addMaxFloatValidator(schema, metas);\n schema = addUniqueValidator(schema, metas, options);\n\n return schema;\n};\n\nexport const bigintegerValidator = (\n metas: ValidatorMetas<Schema.Attribute.BigInteger>,\n options: ValidatorOptions\n) => {\n const schema = yup.mixed();\n return addUniqueValidator(schema, metas, options);\n};\n\nexport const datesValidator = (\n metas: ValidatorMetas<\n | Schema.Attribute.Date\n | Schema.Attribute.DateTime\n | Schema.Attribute.Time\n | Schema.Attribute.Timestamp\n >,\n options: ValidatorOptions\n) => {\n const schema = yup.mixed();\n return addUniqueValidator(schema, metas, options);\n};\n\nexport const Validators = {\n string: stringValidator,\n text: stringValidator,\n richtext: stringValidator,\n password: stringValidator,\n email: emailValidator,\n enumeration: enumerationValidator,\n boolean: () => yup.boolean().nullable(),\n uid: uidValidator,\n json: () => yup.mixed(),\n integer: integerValidator,\n biginteger: bigintegerValidator,\n float: floatValidator,\n decimal: floatValidator,\n date: datesValidator,\n time: datesValidator,\n datetime: datesValidator,\n timestamp: datesValidator,\n blocks: blocksValidator,\n};\n"],"names":["addMinLengthValidator","validator","attr","isDraft","minLength","_","isInteger","min","addMaxLengthValidator","maxLength","max","addMinIntegerValidator","isNumber","toInteger","addMaxIntegerValidator","addMinFloatValidator","addMaxFloatValidator","addStringRegexValidator","isUndefined","regex","matches","RegExp","excludeEmptyString","required","addUniqueValidator","model","updatedAttribute","entity","componentContext","options","type","unique","validateUniqueFieldWithinComponent","value","hasRepeatableData","repeatableData","length","name","updatedName","updatedValue","pathToCheck","pathToComponent","slice","join","values","map","item","split","reduce","acc","key","isUpdatedAttributeRepeatedInThisEntity","filter","parentModel","parentOptions","id","excludeId","parentContent","whereConditions","isParentDraft","publishedAt","$notNull","locale","Number","isNaN","$ne","queryUid","uid","queryWhere","reduceRight","strapi","db","query","findOne","where","validateUniqueFieldWithinDynamicZoneComponent","startOfPath","targetComponentUID","countOfValueInThisEntity","fullDynamicZoneContent","component","__component","select","populate","on","undefined","published_at","$eq","parentModelQueryResult","findMany","filteredResults","result","Array","isArray","flatMap","dynamicZoneComponent","test","isNil","hasPathToComponent","testingDZ","attributes","scalarAttributeWhere","stringValidator","metas","schema","yup","string","transform","val","originalVal","emailValidator","email","uidValidator","enumerationValidator","oneOf","enum","concat","integerValidator","number","integer","floatValidator","bigintegerValidator","mixed","datesValidator","Validators","text","richtext","password","enumeration","boolean","nullable","json","biginteger","float","decimal","date","time","datetime","timestamp","blocks","blocksValidator"],"mappings":";;;;;;AAqCA;;IAKA,MAAMA,qBAAwB,GAAA,CAC5BC,SACA,EAAA,EACEC,IAAI,EASL,EACD,EAAEC,OAAO,EAAoB,GAAA;AAE7B,IAAA,OAAOD,KAAKE,SAAS,IAAIC,CAAEC,CAAAA,SAAS,CAACJ,IAAKE,CAAAA,SAAS,CAAK,IAAA,CAACD,UACrDF,SAAUM,CAAAA,GAAG,CAACL,IAAAA,CAAKE,SAAS,CAC5BH,GAAAA,SAAAA;AACN,CAAA;AAEA;;;AAGC,IACD,MAAMO,qBAAwB,GAAA,CAC5BP,SACA,EAAA,EACEC,IAAI,EASL,GAAA;AAED,IAAA,OAAOA,IAAKO,CAAAA,SAAS,IAAIJ,CAAAA,CAAEC,SAAS,CAACJ,IAAAA,CAAKO,SAAS,CAAA,GAAIR,SAAUS,CAAAA,GAAG,CAACR,IAAAA,CAAKO,SAAS,CAAIR,GAAAA,SAAAA;AACzF,CAAA;AAEA;;;AAGC,IACD,MAAMU,sBAAAA,GAAyB,CAC7BV,SAAAA,EACA,EACEC,IAAI,EAGL,EACD,EAAEC,OAAO,EAAoB,GACzBE,CAAEO,CAAAA,QAAQ,CAACV,IAAAA,CAAKK,GAAG,CAAA,IAAK,CAACJ,OAAAA,GAAUF,SAAUM,CAAAA,GAAG,CAACF,CAAAA,CAAEQ,SAAS,CAACX,IAAKK,CAAAA,GAAG,CAAKN,CAAAA,GAAAA,SAAAA;AAEhF;;IAGA,MAAMa,yBAAyB,CAC7Bb,SAAAA,EACA,EACEC,IAAI,EAGL,GACGG,CAAAA,CAAEO,QAAQ,CAACV,KAAKQ,GAAG,CAAA,GAAIT,UAAUS,GAAG,CAACL,EAAEQ,SAAS,CAACX,IAAKQ,CAAAA,GAAG,CAAKT,CAAAA,GAAAA,SAAAA;AAEpE;;IAGA,MAAMc,oBAAuB,GAAA,CAC3Bd,SACA,EAAA,EACEC,IAAI,EAGL,EACD,EAAEC,OAAO,EAAoB,GACzBE,EAAEO,QAAQ,CAACV,IAAKK,CAAAA,GAAG,CAAK,IAAA,CAACJ,OAAUF,GAAAA,SAAAA,CAAUM,GAAG,CAACL,IAAKK,CAAAA,GAAG,CAAIN,GAAAA,SAAAA;AAEnE;;AAEC,IACD,MAAMe,oBAAuB,GAAA,CAC3Bf,WACA,EACEC,IAAI,EAGL,GACGG,CAAAA,CAAEO,QAAQ,CAACV,IAAAA,CAAKQ,GAAG,CAAIT,GAAAA,SAAAA,CAAUS,GAAG,CAACR,IAAAA,CAAKQ,GAAG,CAAIT,GAAAA,SAAAA;AAEvD;;IAGA,MAAMgB,uBAA0B,GAAA,CAC9BhB,SACA,EAAA,EACEC,IAAI,EASL,EACD,EAAEC,OAAO,EAAoB,GAAA;AAE7B,IAAA,OAAO,WAAWD,IAAQ,IAAA,CAACG,EAAEa,WAAW,CAAChB,KAAKiB,KAAK,CAAA,IAAK,CAAChB,OAAAA,GACrDF,UAAUmB,OAAO,CAAC,IAAIC,MAAOnB,CAAAA,IAAAA,CAAKiB,KAAK,CAAG,EAAA;QAAEG,kBAAoB,EAAA,CAACpB,KAAKqB;KACtEtB,CAAAA,GAAAA,SAAAA;AACN,CAAA;AAEA,MAAMuB,kBAAqB,GAAA,CACzBvB,SACA,EAAA,EACEC,IAAI,EACJuB,KAAK,EACLC,gBAAgB,EAChBC,MAAM,EACNC,gBAAgB,EAC8D,EAChFC,OAAAA,GAAAA;AAEA,IAAA,IAAI3B,KAAK4B,IAAI,KAAK,SAAS,CAAC5B,IAAAA,CAAK6B,MAAM,EAAE;QACvC,OAAO9B,SAAAA;AACT;AAEA,IAAA,MAAM+B,qCAAqC,OAAOC,KAAAA,GAAAA;AAChD,QAAA,IAAI,CAACL,gBAAkB,EAAA;YACrB,OAAO,KAAA;AACT;;;;AAKA,QAAA,MAAMM,iBAAoBN,GAAAA,gBAAAA,CAAiBO,cAAc,CAACC,MAAM,GAAG,CAAA;AACnE,QAAA,IAAIF,iBAAmB,EAAA;AACrB,YAAA,MAAM,EAAEG,IAAMC,EAAAA,WAAW,EAAEL,KAAOM,EAAAA,YAAY,EAAE,GAAGb,gBAAAA;;AAEnD,YAAA,MAAMc,WAAc,GAAA;mBAAIZ,gBAAiBa,CAAAA,eAAe,CAACC,KAAK,CAAC,CAAA,CAAA;AAAIJ,gBAAAA;AAAY,aAAA,CAACK,IAAI,CAAC,GAAA,CAAA;;AAGrF,YAAA,MAAMC,SAAShB,gBAAiBO,CAAAA,cAAc,CAACU,GAAG,CAAC,CAACC,IAAAA,GAAAA;AAClD,gBAAA,OAAON,WAAYO,CAAAA,KAAK,CAAC,GAAA,CAAA,CAAKC,MAAM,CAAC,CAACC,GAAAA,EAAKC,GAAQD,GAAAA,GAAG,CAACC,GAAAA,CAAI,EAAEJ,IAAAA,CAAAA;AAC/D,aAAA,CAAA;;YAGA,MAAMK,sCAAAA,GACJP,OAAOQ,MAAM,CAAC,CAACnB,KAAUA,GAAAA,KAAAA,KAAUM,YAAcH,CAAAA,CAAAA,MAAM,GAAG,CAAA;AAE5D,YAAA,IAAIe,sCAAwC,EAAA;gBAC1C,OAAO,KAAA;AACT;AACF;AAEA;;;;;;;;;;;AAWC,QACD,MAAM,EACJ1B,KAAO4B,EAAAA,WAAW,EAClBxB,OAAAA,EAASyB,aAAa,EACtBC,EAAIC,EAAAA,SAAS,EACd,GAAG5B,iBAAiB6B,aAAa;AAElC,QAAA,MAAMC,kBAAuC,EAAC;QAC9C,MAAMC,aAAAA,GAAgBL,aAAiBA,IAAAA,aAAAA,CAAcnD,OAAO;QAE5DuD,eAAgBE,CAAAA,WAAW,GAAGD,aAAAA,GAAgB,IAAO,GAAA;YAAEE,QAAU,EAAA;AAAK,SAAA;AAEtE,QAAA,IAAIP,eAAeQ,MAAQ,EAAA;YACzBJ,eAAgBI,CAAAA,MAAM,GAAGR,aAAAA,CAAcQ,MAAM;AAC/C;AAEA,QAAA,IAAIN,SAAa,IAAA,CAACO,MAAOC,CAAAA,KAAK,CAACR,SAAY,CAAA,EAAA;AACzCE,YAAAA,eAAAA,CAAgBH,EAAE,GAAG;gBAAEU,GAAKT,EAAAA;AAAU,aAAA;AACxC;QAEA,MAAMU,QAAAA,GAAWb,YAAYc,GAAG;AAChC,QAAA,MAAMC,UAAa,GAAA;YACjB,GAAGxC,gBAAAA,CAAiBa,eAAe,CAAC4B,WAAW,CAAC,CAACpB,GAAAA,EAAKC,OAAS;AAAE,oBAAA,CAACA,MAAMD;AAAI,iBAAA,CAAI,EAAA;gBAC9E,CAACvB,gBAAAA,CAAiBW,IAAI,GAAGJ;aACzB,CAAA;AAEF,YAAA,GAAGyB;AACL,SAAA;;QAGA,OAAO,CAAE,MAAMY,MAAOC,CAAAA,EAAE,CAACC,KAAK,CAACN,QAAUO,CAAAA,CAAAA,OAAO,CAAC;YAAEC,KAAON,EAAAA;AAAW,SAAA,CAAA;AACvE,KAAA;AAEA,IAAA,MAAMO,gDAAgD,OACpDC,WAAAA,GAAAA;AAEA,QAAA,IAAI,CAAChD,gBAAkB,EAAA;YACrB,OAAO,KAAA;AACT;QAEA,MAAMiD,kBAAAA,GAAqBpD,MAAM0C,GAAG;;QAEpC,MAAMW,wBAAAA,GAA2B,CAAClD,gBAAkBmD,EAAAA,sBAAAA,IAA0B,EAAC,EAAG/B,MAAM,CACtF,CAACC,GAAK+B,EAAAA,SAAAA,GAAAA;YACJ,IAAIA,SAAAA,CAAUC,WAAW,KAAKJ,kBAAoB,EAAA;gBAChD,OAAO5B,GAAAA;AACT;AAEA,YAAA,MAAMV,YAAeyC,GAAAA,SAAS,CAACtD,gBAAAA,CAAiBW,IAAI,CAAC;AACrD,YAAA,OAAOE,YAAiBb,KAAAA,gBAAAA,CAAiBO,KAAK,GAAGgB,MAAM,CAAIA,GAAAA,GAAAA;SAE7D,EAAA,CAAA,CAAA;AAGF,QAAA,IAAI6B,2BAA2B,CAAG,EAAA;;YAEhC,OAAO,KAAA;AACT;;;AAyBA,QAAA,MAAMN,KAAmB,GAAA;YACvBU,MAAQ,EAAA;AAAC,gBAAA;AAAK,aAAA;AACdR,YAAAA,KAAAA,EAAO,EAAC;YACRS,QAAU,EAAA;AACR,gBAAA,CAACP,cAAc;oBACbQ,EAAI,EAAA;AACF,wBAAA,CAACP,qBAAqB;4BACpBK,MAAQ,EAAA;AAAC,gCAAA;AAAK,6BAAA;4BACdR,KAAO,EAAA;AAAE,gCAAA,CAAChD,gBAAiBW,CAAAA,IAAI,GAAGX,iBAAiBO;AAAM;AAC3D;AACF;AACF;AACF;AACF,SAAA;AAEA,QAAA,MAAM,EAAEJ,OAAO,EAAE0B,EAAE,EAAE,GAAG3B,iBAAiB6B,aAAa;QAEtD,IAAI5B,OAAAA,EAAS1B,YAAYkF,SAAW,EAAA;AAClCb,YAAAA,KAAAA,CAAME,KAAK,CAACY,YAAY,GAAGzD,OAAAA,CAAQ1B,OAAO,GAAG;gBAAEoF,GAAK,EAAA;aAAS,GAAA;gBAAEtB,GAAK,EAAA;AAAK,aAAA;AAC3E;AAEA,QAAA,IAAIV,EAAI,EAAA;YACNiB,KAAME,CAAAA,KAAK,CAACnB,EAAE,GAAG;gBAAEU,GAAKV,EAAAA;AAAG,aAAA;AAC7B;AAEA,QAAA,IAAI1B,SAASiC,MAAQ,EAAA;AACnBU,YAAAA,KAAAA,CAAME,KAAK,CAACZ,MAAM,GAAGjC,QAAQiC,MAAM;AACrC;AAEA,QAAA,MAAM0B,sBAAyB,GAAA,MAAMlB,MAAOC,CAAAA,EAAE,CAC3CC,KAAK,CAAC5C,gBAAiB6B,CAAAA,aAAa,CAAChC,KAAK,CAAC0C,GAAG,CAAA,CAC9CsB,QAAQ,CAACjB,KAAAA,CAAAA;;;AAIZ,QAAA,MAAMkB,eAAkBF,GAAAA,sBAAAA,CACrBpC,MAAM,CAAC,CAACuC,MAAWC,GAAAA,KAAAA,CAAMC,OAAO,CAACF,MAAM,CAACf,WAAY,CAAA,CAAA,IAAKe,MAAM,CAACf,WAAAA,CAAY,CAACxC,MAAM,CACnF0D,CAAAA,OAAO,CAAC,CAACH,SAAWA,MAAM,CAACf,WAAY,CAAA,CAAA,CACvCxB,MAAM,CAAC,CAAC2C,oBAAyBA,GAAAA,oBAAAA,CAAqBd,WAAW,KAAKJ,kBAAAA,CAAAA;QAEzE,IAAIa,eAAAA,CAAgBtD,MAAM,IAAI,CAAG,EAAA;YAC/B,OAAO,KAAA;AACT;QAEA,OAAO,IAAA;AACT,KAAA;AAEA,IAAA,OAAOnC,SAAU+F,CAAAA,IAAI,CAAC,QAAA,EAAU,iCAAiC,OAAO/D,KAAAA,GAAAA;AACtE;;;AAGC,QACD,IAAI5B,CAAE4F,CAAAA,KAAK,CAAChE,KAAAA,CAAAA,IAAUA,UAAU,EAAI,EAAA;YAClC,OAAO,IAAA;AACT;AAEA;;QAGA,IAAIJ,OAAQ1B,CAAAA,OAAO,EAAE;YACnB,OAAO,IAAA;AACT;AAEA,QAAA,MAAM+F,qBAAqBtE,gBAAoBA,IAAAA,gBAAAA,CAAiBa,eAAe,CAACL,MAAM,GAAG,CAAA;AACzF,QAAA,IAAI8D,kBAAoB,EAAA;;;AAGtB,YAAA,MAAMtB,WAAchD,GAAAA,gBAAAA,CAAiBa,eAAe,CAAC,CAAE,CAAA;YACvD,MAAM0D,SAAAA,GACJvE,gBAAiB6B,CAAAA,aAAa,CAAChC,KAAK,CAAC2E,UAAU,CAACxB,WAAAA,CAAY,CAAC9C,IAAI,KAAK,aAAA;AAExE,YAAA,IAAIqE,SAAW,EAAA;AACb,gBAAA,OAAOxB,6CAA8CC,CAAAA,WAAAA,CAAAA;AACvD;AAEA,YAAA,OAAO5C,kCAAmCC,CAAAA,KAAAA,CAAAA;AAC5C;AAEA;;;;AAIC,QACD,MAAMoE,oBAA4C,GAAA;YAChD,CAAC3E,gBAAAA,CAAiBW,IAAI,GAAGJ,KAAAA;YACzB2B,WAAa,EAAA;gBAAEC,QAAU,EAAA;AAAK;AAChC,SAAA;AAEA,QAAA,IAAIhC,SAASiC,MAAQ,EAAA;YACnBuC,oBAAqBvC,CAAAA,MAAM,GAAGjC,OAAAA,CAAQiC,MAAM;AAC9C;AAEA,QAAA,IAAInC,QAAQ4B,EAAI,EAAA;AACd8C,YAAAA,oBAAAA,CAAqB9C,EAAE,GAAG;AAAEU,gBAAAA,GAAAA,EAAKtC,OAAO4B;AAAG,aAAA;AAC7C;;QAGA,OAAO,CAAE,MAAMe,MAAAA,CAAOC,EAAE,CACrBC,KAAK,CAAC/C,KAAM0C,CAAAA,GAAG,CACfM,CAAAA,OAAO,CAAC;YAAEC,KAAO2B,EAAAA,oBAAAA;YAAsBnB,MAAQ,EAAA;AAAC,gBAAA;AAAK;AAAC,SAAA,CAAA;AAC3D,KAAA,CAAA;AACF,CAAA;AAEA,sBAEA,MAAMoB,eAAkB,GAAA,CACtBC,KAQA1E,EAAAA,OAAAA,GAAAA;IAEA,IAAI2E,MAAAA,GAASC,gBAAIC,MAAM,EAAA,CAAGC,SAAS,CAAC,CAACC,KAAKC,WAAgBA,GAAAA,WAAAA,CAAAA;IAE1DL,MAASxG,GAAAA,qBAAAA,CAAsBwG,QAAQD,KAAO1E,EAAAA,OAAAA,CAAAA;AAC9C2E,IAAAA,MAAAA,GAAShG,sBAAsBgG,MAAQD,EAAAA,KAAAA,CAAAA;IACvCC,MAASvF,GAAAA,uBAAAA,CAAwBuF,QAAQD,KAAO1E,EAAAA,OAAAA,CAAAA;IAChD2E,MAAShF,GAAAA,kBAAAA,CAAmBgF,QAAQD,KAAO1E,EAAAA,OAAAA,CAAAA;IAE3C,OAAO2E,MAAAA;AACT,CAAA;AAEO,MAAMM,cAAiB,GAAA,CAC5BP,KACA1E,EAAAA,OAAAA,GAAAA;IAEA,MAAM2E,MAAAA,GAASF,gBAAgBC,KAAO1E,EAAAA,OAAAA,CAAAA;IAEtC,IAAIA,OAAAA,CAAQ1B,OAAO,EAAE;QACnB,OAAOqG,MAAAA;AACT;AAEA,IAAA,OAAOA,OAAOO,KAAK,EAAA,CAAGxG,GAAG,CACvB;AAEA,IAAA,yBAAA,CAAA;AAEJ;AAEO,MAAMyG,YAAe,GAAA,CAC1BT,KACA1E,EAAAA,OAAAA,GAAAA;IAEA,MAAM2E,MAAAA,GAASF,gBAAgBC,KAAO1E,EAAAA,OAAAA,CAAAA;IAEtC,IAAIA,OAAAA,CAAQ1B,OAAO,EAAE;QACnB,OAAOqG,MAAAA;AACT;AAEA,IAAA,IAAID,KAAMrG,CAAAA,IAAI,CAACiB,KAAK,EAAE;QACpB,OAAOqF,MAAAA,CAAOpF,OAAO,CAAC,IAAIC,OAAOkF,KAAMrG,CAAAA,IAAI,CAACiB,KAAK,CAAA,CAAA;AACnD;IAEA,OAAOqF,MAAAA,CAAOpF,OAAO,CAAC,oBAAA,CAAA;AACxB;AAEa6F,MAAAA,oBAAAA,GAAuB,CAAC,EAAE/G,IAAI,EAA0C,GAAA;AACnF,IAAA,OAAOuG,eACJC,CAAAA,MAAM,EACNQ,CAAAA,KAAK,CAAC,CAACtB,KAAMC,CAAAA,OAAO,CAAC3F,IAAKiH,CAAAA,IAAI,CAAIjH,GAAAA,IAAAA,CAAKiH,IAAI,GAAG;AAACjH,QAAAA,IAAAA,CAAKiH;KAAK,EAAEC,MAAM,CAAC,IAAA,CAAA,CAAA;AACvE;AAEO,MAAMC,gBAAmB,GAAA,CAC9Bd,KACA1E,EAAAA,OAAAA,GAAAA;AAEA,IAAA,IAAI2E,MAASC,GAAAA,eAAAA,CAAIa,MAAM,EAAA,CAAGC,OAAO,EAAA;IAEjCf,MAAS7F,GAAAA,sBAAAA,CAAuB6F,QAAQD,KAAO1E,EAAAA,OAAAA,CAAAA;AAC/C2E,IAAAA,MAAAA,GAAS1F,uBAAuB0F,MAAQD,EAAAA,KAAAA,CAAAA;IACxCC,MAAShF,GAAAA,kBAAAA,CAAmBgF,QAAQD,KAAO1E,EAAAA,OAAAA,CAAAA;IAE3C,OAAO2E,MAAAA;AACT;AAEO,MAAMgB,cAAiB,GAAA,CAC5BjB,KACA1E,EAAAA,OAAAA,GAAAA;IAEA,IAAI2E,MAAAA,GAASC,gBAAIa,MAAM,EAAA;IAEvBd,MAASzF,GAAAA,oBAAAA,CAAqByF,QAAQD,KAAO1E,EAAAA,OAAAA,CAAAA;AAC7C2E,IAAAA,MAAAA,GAASxF,qBAAqBwF,MAAQD,EAAAA,KAAAA,CAAAA;IACtCC,MAAShF,GAAAA,kBAAAA,CAAmBgF,QAAQD,KAAO1E,EAAAA,OAAAA,CAAAA;IAE3C,OAAO2E,MAAAA;AACT;AAEO,MAAMiB,mBAAsB,GAAA,CACjClB,KACA1E,EAAAA,OAAAA,GAAAA;IAEA,MAAM2E,MAAAA,GAASC,gBAAIiB,KAAK,EAAA;IACxB,OAAOlG,kBAAAA,CAAmBgF,QAAQD,KAAO1E,EAAAA,OAAAA,CAAAA;AAC3C;AAEO,MAAM8F,cAAiB,GAAA,CAC5BpB,KAMA1E,EAAAA,OAAAA,GAAAA;IAEA,MAAM2E,MAAAA,GAASC,gBAAIiB,KAAK,EAAA;IACxB,OAAOlG,kBAAAA,CAAmBgF,QAAQD,KAAO1E,EAAAA,OAAAA,CAAAA;AAC3C;MAEa+F,UAAa,GAAA;IACxBlB,MAAQJ,EAAAA,eAAAA;IACRuB,IAAMvB,EAAAA,eAAAA;IACNwB,QAAUxB,EAAAA,eAAAA;IACVyB,QAAUzB,EAAAA,eAAAA;IACVS,KAAOD,EAAAA,cAAAA;IACPkB,WAAaf,EAAAA,oBAAAA;AACbgB,IAAAA,OAAAA,EAAS,IAAMxB,eAAAA,CAAIwB,OAAO,EAAA,CAAGC,QAAQ,EAAA;IACrC/D,GAAK6C,EAAAA,YAAAA;IACLmB,IAAM,EAAA,IAAM1B,gBAAIiB,KAAK,EAAA;IACrBH,OAASF,EAAAA,gBAAAA;IACTe,UAAYX,EAAAA,mBAAAA;IACZY,KAAOb,EAAAA,cAAAA;IACPc,OAASd,EAAAA,cAAAA;IACTe,IAAMZ,EAAAA,cAAAA;IACNa,IAAMb,EAAAA,cAAAA;IACNc,QAAUd,EAAAA,cAAAA;IACVe,SAAWf,EAAAA,cAAAA;IACXgB,MAAQC,EAAAA;AACV;;;;;;;;;;;"}
1
+ {"version":3,"file":"validators.js","sources":["../../../src/services/entity-validator/validators.ts"],"sourcesContent":["/**\n * Validators check if the entry data meets specific criteria before saving or publishing.\n * (e.g., length, range, format).\n *\n * Drafts have limited validations (mainly max constraints),\n * while published content undergoes full validation.\n *\n * The system also takes locales into account when validating data.\n * E.g, unique fields must be unique within the same locale.\n */\nimport _ from 'lodash';\nimport { yup } from '@strapi/utils';\nimport type { Schema, Struct, Modules } from '@strapi/types';\nimport { blocksValidator } from './blocks-validator';\n\nimport type { ComponentContext } from '.';\n\nexport interface ValidatorMetas<\n TAttribute extends Schema.Attribute.AnyAttribute = Schema.Attribute.AnyAttribute,\n TValue extends Schema.Attribute.Value<TAttribute> = Schema.Attribute.Value<TAttribute>,\n> {\n attr: TAttribute;\n model: Struct.Schema;\n updatedAttribute: {\n name: string;\n value: TValue;\n };\n data: Record<string, unknown>;\n componentContext?: ComponentContext;\n entity?: Modules.EntityValidator.Entity;\n}\n\ninterface ValidatorOptions {\n isDraft: boolean;\n locale?: string;\n}\n\n/* Validator utils */\n\nconst toNumberSafe = (value: unknown): number | undefined => {\n if (value === undefined || value === null) return undefined;\n const num = Number(value);\n return Number.isFinite(num) ? num : undefined;\n};\n\n/**\n * Adds minLength validator\n */\nconst addMinLengthValidator = (\n validator: yup.StringSchema,\n {\n attr,\n }: {\n attr:\n | Schema.Attribute.String\n | Schema.Attribute.Text\n | Schema.Attribute.RichText\n | Schema.Attribute.Password\n | Schema.Attribute.Email\n | Schema.Attribute.UID;\n },\n { isDraft }: ValidatorOptions\n) => {\n return attr.minLength && _.isInteger(attr.minLength) && !isDraft\n ? validator.min(attr.minLength)\n : validator;\n};\n\n/**\n * Adds maxLength validator\n * @returns {StringSchema}\n */\nconst addMaxLengthValidator = (\n validator: yup.StringSchema,\n {\n attr,\n }: {\n attr:\n | Schema.Attribute.String\n | Schema.Attribute.Text\n | Schema.Attribute.RichText\n | Schema.Attribute.Password\n | Schema.Attribute.Email\n | Schema.Attribute.UID;\n }\n) => {\n return attr.maxLength && _.isInteger(attr.maxLength) ? validator.max(attr.maxLength) : validator;\n};\n\n/**\n * Adds min integer validator\n * @returns {NumberSchema}\n */\nconst addMinIntegerValidator = (\n validator: yup.NumberSchema,\n {\n attr,\n }: {\n attr: Schema.Attribute.Integer | Schema.Attribute.BigInteger;\n },\n { isDraft }: ValidatorOptions\n) => {\n const min = toNumberSafe(attr.min);\n return min !== undefined && !isDraft ? validator.min(_.toInteger(min)) : validator;\n};\n\n/**\n * Adds max integer validator\n */\nconst addMaxIntegerValidator = (\n validator: yup.NumberSchema,\n {\n attr,\n }: {\n attr: Schema.Attribute.Integer | Schema.Attribute.BigInteger;\n }\n) => {\n const max = toNumberSafe(attr.max);\n return max !== undefined ? validator.max(_.toInteger(max)) : validator;\n};\n\n/**\n * Adds min float/decimal validator\n */\nconst addMinFloatValidator = (\n validator: yup.NumberSchema,\n {\n attr,\n }: {\n attr: Schema.Attribute.Decimal | Schema.Attribute.Float;\n },\n { isDraft }: ValidatorOptions\n) => {\n const min = toNumberSafe(attr.min);\n return min !== undefined && !isDraft ? validator.min(min) : validator;\n};\n\n/**\n * Adds max float/decimal validator\n */\nconst addMaxFloatValidator = (\n validator: yup.NumberSchema,\n {\n attr,\n }: {\n attr: Schema.Attribute.Decimal | Schema.Attribute.Float;\n }\n) => {\n const max = toNumberSafe(attr.max);\n return max !== undefined ? validator.max(max) : validator;\n};\n\n/**\n * Adds regex validator\n */\nconst addStringRegexValidator = (\n validator: yup.StringSchema,\n {\n attr,\n }: {\n attr:\n | Schema.Attribute.String\n | Schema.Attribute.Text\n | Schema.Attribute.RichText\n | Schema.Attribute.Password\n | Schema.Attribute.Email\n | Schema.Attribute.UID;\n },\n { isDraft }: ValidatorOptions\n) => {\n return 'regex' in attr && !_.isUndefined(attr.regex) && !isDraft\n ? validator.matches(new RegExp(attr.regex), { excludeEmptyString: !attr.required })\n : validator;\n};\n\nconst addUniqueValidator = <T extends yup.AnySchema>(\n validator: T,\n {\n attr,\n model,\n updatedAttribute,\n entity,\n componentContext,\n }: ValidatorMetas<Schema.Attribute.AnyAttribute & Schema.Attribute.UniqueOption>,\n options: ValidatorOptions\n): T => {\n if (attr.type !== 'uid' && !attr.unique) {\n return validator;\n }\n\n const validateUniqueFieldWithinComponent = async (value: any): Promise<boolean> => {\n if (!componentContext) {\n return false;\n }\n\n // If we are validating a unique field within a repeatable component,\n // we first need to ensure that the repeatable in the current entity is\n // valid against itself.\n const hasRepeatableData = componentContext.repeatableData.length > 0;\n if (hasRepeatableData) {\n const { name: updatedName, value: updatedValue } = updatedAttribute;\n // Construct the full path to the unique field within the component.\n const pathToCheck = [...componentContext.pathToComponent.slice(1), updatedName].join('.');\n\n // Extract the values from the repeatable data using the constructed path\n const values = componentContext.repeatableData.map((item) => {\n return pathToCheck.split('.').reduce((acc, key) => acc[key], item as any);\n });\n\n // Check if the value is repeated in the current entity\n const isUpdatedAttributeRepeatedInThisEntity =\n values.filter((value) => value === updatedValue).length > 1;\n\n if (isUpdatedAttributeRepeatedInThisEntity) {\n return false;\n }\n }\n\n /**\n * When `componentContext` is present it means we are dealing with a unique\n * field within a component.\n *\n * The unique validation must consider the specific context of the\n * component, which will always be contained within a parent content type\n * and may also be nested within another component.\n *\n * We construct a query that takes into account the parent's model UID,\n * dimensions (such as draft and publish state/locale) and excludes the current\n * content type entity by its ID if provided.\n */\n const {\n model: parentModel,\n options: parentOptions,\n id: excludeId,\n } = componentContext.parentContent;\n\n const whereConditions: Record<string, any> = {};\n const isParentDraft = parentOptions && parentOptions.isDraft;\n\n whereConditions.publishedAt = isParentDraft ? null : { $notNull: true };\n\n if (parentOptions?.locale) {\n whereConditions.locale = parentOptions.locale;\n }\n\n if (excludeId && !Number.isNaN(excludeId)) {\n whereConditions.id = { $ne: excludeId };\n }\n\n const queryUid = parentModel.uid;\n const queryWhere = {\n ...componentContext.pathToComponent.reduceRight((acc, key) => ({ [key]: acc }), {\n [updatedAttribute.name]: value,\n }),\n\n ...whereConditions,\n };\n\n // The validation should pass if there is no other record found from the query\n return !(await strapi.db.query(queryUid).findOne({ where: queryWhere }));\n };\n\n const validateUniqueFieldWithinDynamicZoneComponent = async (\n startOfPath: string\n ): Promise<boolean> => {\n if (!componentContext) {\n return false;\n }\n\n const targetComponentUID = model.uid;\n // Ensure that the value is unique within the dynamic zone in this entity.\n const countOfValueInThisEntity = (componentContext?.fullDynamicZoneContent ?? []).reduce(\n (acc, component) => {\n if (component.__component !== targetComponentUID) {\n return acc;\n }\n\n const updatedValue = component[updatedAttribute.name];\n return updatedValue === updatedAttribute.value ? acc + 1 : acc;\n },\n 0\n );\n\n if (countOfValueInThisEntity > 1) {\n // If the value is repeated in the current entity, the validation fails.\n return false;\n }\n\n // Build a query for the parent content type to find all entities in the\n // same locale and publication state\n type QueryType = {\n select: string[];\n where: {\n published_at?: { $eq: null } | { $ne: null };\n id?: { $ne: number };\n locale?: string;\n };\n populate: {\n [key: string]: {\n on: {\n [key: string]: {\n select: string[];\n where: { [key: string]: string | number | boolean };\n };\n };\n };\n };\n };\n\n // Populate the dynamic zone for any components that share the same value\n // as the updated attribute.\n const query: QueryType = {\n select: ['id'],\n where: {},\n populate: {\n [startOfPath]: {\n on: {\n [targetComponentUID]: {\n select: ['id'],\n where: { [updatedAttribute.name]: updatedAttribute.value },\n },\n },\n },\n },\n };\n\n const { options, id } = componentContext.parentContent;\n\n if (options?.isDraft !== undefined) {\n query.where.published_at = options.isDraft ? { $eq: null } : { $ne: null };\n }\n\n if (id) {\n query.where.id = { $ne: id };\n }\n\n if (options?.locale) {\n query.where.locale = options.locale;\n }\n\n const parentModelQueryResult = await strapi.db\n .query(componentContext.parentContent.model.uid)\n .findMany(query);\n\n // Filter the results to only include results that have components in the\n // dynamic zone that match the target component type.\n const filteredResults = parentModelQueryResult\n .filter((result) => Array.isArray(result[startOfPath]) && result[startOfPath].length)\n .flatMap((result) => result[startOfPath])\n .filter((dynamicZoneComponent) => dynamicZoneComponent.__component === targetComponentUID);\n\n if (filteredResults.length >= 1) {\n return false;\n }\n\n return true;\n };\n\n return validator.test('unique', 'This attribute must be unique', async (value) => {\n /**\n * If the attribute value is `null` or an empty string we want to skip the unique validation.\n * Otherwise it'll only accept a single entry with that value in the database.\n */\n if (_.isNil(value) || value === '') {\n return true;\n }\n\n /**\n * We don't validate any unique constraint for draft entries.\n */\n if (options.isDraft) {\n return true;\n }\n\n const hasPathToComponent = componentContext && componentContext.pathToComponent.length > 0;\n if (hasPathToComponent) {\n // Detect if we are validating within a dynamiczone by checking if the first\n // path is a dynamiczone attribute in the parent content type.\n const startOfPath = componentContext.pathToComponent[0];\n const testingDZ =\n componentContext.parentContent.model.attributes[startOfPath].type === 'dynamiczone';\n\n if (testingDZ) {\n return validateUniqueFieldWithinDynamicZoneComponent(startOfPath);\n }\n\n return validateUniqueFieldWithinComponent(value);\n }\n\n /**\n * Here we are validating a scalar unique field from the content type's schema.\n * We construct a query to check if the value is unique\n * considering dimensions (e.g. locale, publication state) and excluding the current entity by its ID if available.\n */\n const scalarAttributeWhere: Record<string, any> = {\n [updatedAttribute.name]: value,\n publishedAt: { $notNull: true },\n };\n\n if (options?.locale) {\n scalarAttributeWhere.locale = options.locale;\n }\n\n if (entity?.id) {\n scalarAttributeWhere.id = { $ne: entity.id };\n }\n\n // The validation should pass if there is no other record found from the query\n return !(await strapi.db\n .query(model.uid)\n .findOne({ where: scalarAttributeWhere, select: ['id'] }));\n });\n};\n\n/* Type validators */\n\nconst stringValidator = (\n metas: ValidatorMetas<\n | Schema.Attribute.String\n | Schema.Attribute.Text\n | Schema.Attribute.RichText\n | Schema.Attribute.Password\n | Schema.Attribute.Email\n | Schema.Attribute.UID\n >,\n options: ValidatorOptions\n) => {\n let schema = yup.string().transform((val, originalVal) => originalVal);\n\n schema = addMinLengthValidator(schema, metas, options);\n schema = addMaxLengthValidator(schema, metas);\n schema = addStringRegexValidator(schema, metas, options);\n schema = addUniqueValidator(schema, metas, options);\n\n return schema;\n};\n\nexport const emailValidator = (\n metas: ValidatorMetas<Schema.Attribute.Email>,\n options: ValidatorOptions\n) => {\n const schema = stringValidator(metas, options);\n\n if (options.isDraft) {\n return schema;\n }\n\n return schema.email().min(\n 1,\n // eslint-disable-next-line no-template-curly-in-string\n '${path} cannot be empty'\n );\n};\n\nexport const uidValidator = (\n metas: ValidatorMetas<Schema.Attribute.UID>,\n options: ValidatorOptions\n) => {\n const schema = stringValidator(metas, options);\n\n if (options.isDraft) {\n return schema;\n }\n\n if (metas.attr.regex) {\n return schema.matches(new RegExp(metas.attr.regex));\n }\n\n return schema.matches(/^[A-Za-z0-9-_.~]*$/);\n};\n\nexport const enumerationValidator = ({ attr }: { attr: Schema.Attribute.Enumeration }) => {\n return yup\n .string()\n .oneOf((Array.isArray(attr.enum) ? attr.enum : [attr.enum]).concat(null as any));\n};\n\nexport const integerValidator = (\n metas: ValidatorMetas<Schema.Attribute.Integer | Schema.Attribute.BigInteger>,\n options: ValidatorOptions\n) => {\n let schema = yup.number().integer();\n\n schema = addMinIntegerValidator(schema, metas, options);\n schema = addMaxIntegerValidator(schema, metas);\n schema = addUniqueValidator(schema, metas, options);\n\n return schema;\n};\n\nexport const floatValidator = (\n metas: ValidatorMetas<Schema.Attribute.Decimal | Schema.Attribute.Float>,\n options: ValidatorOptions\n) => {\n let schema = yup.number();\n\n schema = addMinFloatValidator(schema, metas, options);\n schema = addMaxFloatValidator(schema, metas);\n schema = addUniqueValidator(schema, metas, options);\n\n return schema;\n};\n\nexport const bigintegerValidator = (\n metas: ValidatorMetas<Schema.Attribute.BigInteger>,\n options: ValidatorOptions\n) => {\n const schema = yup.mixed();\n return addUniqueValidator(schema, metas, options);\n};\n\nexport const datesValidator = (\n metas: ValidatorMetas<\n | Schema.Attribute.Date\n | Schema.Attribute.DateTime\n | Schema.Attribute.Time\n | Schema.Attribute.Timestamp\n >,\n options: ValidatorOptions\n) => {\n const schema = yup.mixed();\n return addUniqueValidator(schema, metas, options);\n};\n\nexport const Validators = {\n string: stringValidator,\n text: stringValidator,\n richtext: stringValidator,\n password: stringValidator,\n email: emailValidator,\n enumeration: enumerationValidator,\n boolean: () => yup.boolean().nullable(),\n uid: uidValidator,\n json: () => yup.mixed(),\n integer: integerValidator,\n biginteger: bigintegerValidator,\n float: floatValidator,\n decimal: floatValidator,\n date: datesValidator,\n time: datesValidator,\n datetime: datesValidator,\n timestamp: datesValidator,\n blocks: blocksValidator,\n};\n"],"names":["toNumberSafe","value","undefined","num","Number","isFinite","addMinLengthValidator","validator","attr","isDraft","minLength","_","isInteger","min","addMaxLengthValidator","maxLength","max","addMinIntegerValidator","toInteger","addMaxIntegerValidator","addMinFloatValidator","addMaxFloatValidator","addStringRegexValidator","isUndefined","regex","matches","RegExp","excludeEmptyString","required","addUniqueValidator","model","updatedAttribute","entity","componentContext","options","type","unique","validateUniqueFieldWithinComponent","hasRepeatableData","repeatableData","length","name","updatedName","updatedValue","pathToCheck","pathToComponent","slice","join","values","map","item","split","reduce","acc","key","isUpdatedAttributeRepeatedInThisEntity","filter","parentModel","parentOptions","id","excludeId","parentContent","whereConditions","isParentDraft","publishedAt","$notNull","locale","isNaN","$ne","queryUid","uid","queryWhere","reduceRight","strapi","db","query","findOne","where","validateUniqueFieldWithinDynamicZoneComponent","startOfPath","targetComponentUID","countOfValueInThisEntity","fullDynamicZoneContent","component","__component","select","populate","on","published_at","$eq","parentModelQueryResult","findMany","filteredResults","result","Array","isArray","flatMap","dynamicZoneComponent","test","isNil","hasPathToComponent","testingDZ","attributes","scalarAttributeWhere","stringValidator","metas","schema","yup","string","transform","val","originalVal","emailValidator","email","uidValidator","enumerationValidator","oneOf","enum","concat","integerValidator","number","integer","floatValidator","bigintegerValidator","mixed","datesValidator","Validators","text","richtext","password","enumeration","boolean","nullable","json","biginteger","float","decimal","date","time","datetime","timestamp","blocks","blocksValidator"],"mappings":";;;;;;AAqCA,sBAEA,MAAMA,YAAAA,GAAe,CAACC,KAAAA,GAAAA;AACpB,IAAA,IAAIA,KAAUC,KAAAA,SAAAA,IAAaD,KAAU,KAAA,IAAA,EAAM,OAAOC,SAAAA;AAClD,IAAA,MAAMC,MAAMC,MAAOH,CAAAA,KAAAA,CAAAA;AACnB,IAAA,OAAOG,MAAOC,CAAAA,QAAQ,CAACF,GAAAA,CAAAA,GAAOA,GAAMD,GAAAA,SAAAA;AACtC,CAAA;AAEA;;IAGA,MAAMI,qBAAwB,GAAA,CAC5BC,SACA,EAAA,EACEC,IAAI,EASL,EACD,EAAEC,OAAO,EAAoB,GAAA;AAE7B,IAAA,OAAOD,KAAKE,SAAS,IAAIC,CAAEC,CAAAA,SAAS,CAACJ,IAAKE,CAAAA,SAAS,CAAK,IAAA,CAACD,UACrDF,SAAUM,CAAAA,GAAG,CAACL,IAAAA,CAAKE,SAAS,CAC5BH,GAAAA,SAAAA;AACN,CAAA;AAEA;;;AAGC,IACD,MAAMO,qBAAwB,GAAA,CAC5BP,SACA,EAAA,EACEC,IAAI,EASL,GAAA;AAED,IAAA,OAAOA,IAAKO,CAAAA,SAAS,IAAIJ,CAAAA,CAAEC,SAAS,CAACJ,IAAAA,CAAKO,SAAS,CAAA,GAAIR,SAAUS,CAAAA,GAAG,CAACR,IAAAA,CAAKO,SAAS,CAAIR,GAAAA,SAAAA;AACzF,CAAA;AAEA;;;IAIA,MAAMU,sBAAyB,GAAA,CAC7BV,SACA,EAAA,EACEC,IAAI,EAGL,EACD,EAAEC,OAAO,EAAoB,GAAA;IAE7B,MAAMI,GAAAA,GAAMb,YAAaQ,CAAAA,IAAAA,CAAKK,GAAG,CAAA;IACjC,OAAOA,GAAAA,KAAQX,SAAa,IAAA,CAACO,OAAUF,GAAAA,SAAAA,CAAUM,GAAG,CAACF,CAAAA,CAAEO,SAAS,CAACL,GAAQN,CAAAA,CAAAA,GAAAA,SAAAA;AAC3E,CAAA;AAEA;;AAEC,IACD,MAAMY,sBAAyB,GAAA,CAC7BZ,SACA,EAAA,EACEC,IAAI,EAGL,GAAA;IAED,MAAMQ,GAAAA,GAAMhB,YAAaQ,CAAAA,IAAAA,CAAKQ,GAAG,CAAA;IACjC,OAAOA,GAAAA,KAAQd,YAAYK,SAAUS,CAAAA,GAAG,CAACL,CAAEO,CAAAA,SAAS,CAACF,GAAQT,CAAAA,CAAAA,GAAAA,SAAAA;AAC/D,CAAA;AAEA;;IAGA,MAAMa,oBAAuB,GAAA,CAC3Bb,SACA,EAAA,EACEC,IAAI,EAGL,EACD,EAAEC,OAAO,EAAoB,GAAA;IAE7B,MAAMI,GAAAA,GAAMb,YAAaQ,CAAAA,IAAAA,CAAKK,GAAG,CAAA;AACjC,IAAA,OAAOA,QAAQX,SAAa,IAAA,CAACO,UAAUF,SAAUM,CAAAA,GAAG,CAACA,GAAON,CAAAA,GAAAA,SAAAA;AAC9D,CAAA;AAEA;;AAEC,IACD,MAAMc,oBAAuB,GAAA,CAC3Bd,SACA,EAAA,EACEC,IAAI,EAGL,GAAA;IAED,MAAMQ,GAAAA,GAAMhB,YAAaQ,CAAAA,IAAAA,CAAKQ,GAAG,CAAA;AACjC,IAAA,OAAOA,GAAQd,KAAAA,SAAAA,GAAYK,SAAUS,CAAAA,GAAG,CAACA,GAAOT,CAAAA,GAAAA,SAAAA;AAClD,CAAA;AAEA;;IAGA,MAAMe,uBAA0B,GAAA,CAC9Bf,SACA,EAAA,EACEC,IAAI,EASL,EACD,EAAEC,OAAO,EAAoB,GAAA;AAE7B,IAAA,OAAO,WAAWD,IAAQ,IAAA,CAACG,EAAEY,WAAW,CAACf,KAAKgB,KAAK,CAAA,IAAK,CAACf,OAAAA,GACrDF,UAAUkB,OAAO,CAAC,IAAIC,MAAOlB,CAAAA,IAAAA,CAAKgB,KAAK,CAAG,EAAA;QAAEG,kBAAoB,EAAA,CAACnB,KAAKoB;KACtErB,CAAAA,GAAAA,SAAAA;AACN,CAAA;AAEA,MAAMsB,kBAAqB,GAAA,CACzBtB,SACA,EAAA,EACEC,IAAI,EACJsB,KAAK,EACLC,gBAAgB,EAChBC,MAAM,EACNC,gBAAgB,EAC8D,EAChFC,OAAAA,GAAAA;AAEA,IAAA,IAAI1B,KAAK2B,IAAI,KAAK,SAAS,CAAC3B,IAAAA,CAAK4B,MAAM,EAAE;QACvC,OAAO7B,SAAAA;AACT;AAEA,IAAA,MAAM8B,qCAAqC,OAAOpC,KAAAA,GAAAA;AAChD,QAAA,IAAI,CAACgC,gBAAkB,EAAA;YACrB,OAAO,KAAA;AACT;;;;AAKA,QAAA,MAAMK,iBAAoBL,GAAAA,gBAAAA,CAAiBM,cAAc,CAACC,MAAM,GAAG,CAAA;AACnE,QAAA,IAAIF,iBAAmB,EAAA;AACrB,YAAA,MAAM,EAAEG,IAAMC,EAAAA,WAAW,EAAEzC,KAAO0C,EAAAA,YAAY,EAAE,GAAGZ,gBAAAA;;AAEnD,YAAA,MAAMa,WAAc,GAAA;mBAAIX,gBAAiBY,CAAAA,eAAe,CAACC,KAAK,CAAC,CAAA,CAAA;AAAIJ,gBAAAA;AAAY,aAAA,CAACK,IAAI,CAAC,GAAA,CAAA;;AAGrF,YAAA,MAAMC,SAASf,gBAAiBM,CAAAA,cAAc,CAACU,GAAG,CAAC,CAACC,IAAAA,GAAAA;AAClD,gBAAA,OAAON,WAAYO,CAAAA,KAAK,CAAC,GAAA,CAAA,CAAKC,MAAM,CAAC,CAACC,GAAAA,EAAKC,GAAQD,GAAAA,GAAG,CAACC,GAAAA,CAAI,EAAEJ,IAAAA,CAAAA;AAC/D,aAAA,CAAA;;YAGA,MAAMK,sCAAAA,GACJP,OAAOQ,MAAM,CAAC,CAACvD,KAAUA,GAAAA,KAAAA,KAAU0C,YAAcH,CAAAA,CAAAA,MAAM,GAAG,CAAA;AAE5D,YAAA,IAAIe,sCAAwC,EAAA;gBAC1C,OAAO,KAAA;AACT;AACF;AAEA;;;;;;;;;;;AAWC,QACD,MAAM,EACJzB,KAAO2B,EAAAA,WAAW,EAClBvB,OAAAA,EAASwB,aAAa,EACtBC,EAAIC,EAAAA,SAAS,EACd,GAAG3B,iBAAiB4B,aAAa;AAElC,QAAA,MAAMC,kBAAuC,EAAC;QAC9C,MAAMC,aAAAA,GAAgBL,aAAiBA,IAAAA,aAAAA,CAAcjD,OAAO;QAE5DqD,eAAgBE,CAAAA,WAAW,GAAGD,aAAAA,GAAgB,IAAO,GAAA;YAAEE,QAAU,EAAA;AAAK,SAAA;AAEtE,QAAA,IAAIP,eAAeQ,MAAQ,EAAA;YACzBJ,eAAgBI,CAAAA,MAAM,GAAGR,aAAAA,CAAcQ,MAAM;AAC/C;AAEA,QAAA,IAAIN,SAAa,IAAA,CAACxD,MAAO+D,CAAAA,KAAK,CAACP,SAAY,CAAA,EAAA;AACzCE,YAAAA,eAAAA,CAAgBH,EAAE,GAAG;gBAAES,GAAKR,EAAAA;AAAU,aAAA;AACxC;QAEA,MAAMS,QAAAA,GAAWZ,YAAYa,GAAG;AAChC,QAAA,MAAMC,UAAa,GAAA;YACjB,GAAGtC,gBAAAA,CAAiBY,eAAe,CAAC2B,WAAW,CAAC,CAACnB,GAAAA,EAAKC,OAAS;AAAE,oBAAA,CAACA,MAAMD;AAAI,iBAAA,CAAI,EAAA;gBAC9E,CAACtB,gBAAAA,CAAiBU,IAAI,GAAGxC;aACzB,CAAA;AAEF,YAAA,GAAG6D;AACL,SAAA;;QAGA,OAAO,CAAE,MAAMW,MAAOC,CAAAA,EAAE,CAACC,KAAK,CAACN,QAAUO,CAAAA,CAAAA,OAAO,CAAC;YAAEC,KAAON,EAAAA;AAAW,SAAA,CAAA;AACvE,KAAA;AAEA,IAAA,MAAMO,gDAAgD,OACpDC,WAAAA,GAAAA;AAEA,QAAA,IAAI,CAAC9C,gBAAkB,EAAA;YACrB,OAAO,KAAA;AACT;QAEA,MAAM+C,kBAAAA,GAAqBlD,MAAMwC,GAAG;;QAEpC,MAAMW,wBAAAA,GAA2B,CAAChD,gBAAkBiD,EAAAA,sBAAAA,IAA0B,EAAC,EAAG9B,MAAM,CACtF,CAACC,GAAK8B,EAAAA,SAAAA,GAAAA;YACJ,IAAIA,SAAAA,CAAUC,WAAW,KAAKJ,kBAAoB,EAAA;gBAChD,OAAO3B,GAAAA;AACT;AAEA,YAAA,MAAMV,YAAewC,GAAAA,SAAS,CAACpD,gBAAAA,CAAiBU,IAAI,CAAC;AACrD,YAAA,OAAOE,YAAiBZ,KAAAA,gBAAAA,CAAiB9B,KAAK,GAAGoD,MAAM,CAAIA,GAAAA,GAAAA;SAE7D,EAAA,CAAA,CAAA;AAGF,QAAA,IAAI4B,2BAA2B,CAAG,EAAA;;YAEhC,OAAO,KAAA;AACT;;;AAyBA,QAAA,MAAMN,KAAmB,GAAA;YACvBU,MAAQ,EAAA;AAAC,gBAAA;AAAK,aAAA;AACdR,YAAAA,KAAAA,EAAO,EAAC;YACRS,QAAU,EAAA;AACR,gBAAA,CAACP,cAAc;oBACbQ,EAAI,EAAA;AACF,wBAAA,CAACP,qBAAqB;4BACpBK,MAAQ,EAAA;AAAC,gCAAA;AAAK,6BAAA;4BACdR,KAAO,EAAA;AAAE,gCAAA,CAAC9C,gBAAiBU,CAAAA,IAAI,GAAGV,iBAAiB9B;AAAM;AAC3D;AACF;AACF;AACF;AACF,SAAA;AAEA,QAAA,MAAM,EAAEiC,OAAO,EAAEyB,EAAE,EAAE,GAAG1B,iBAAiB4B,aAAa;QAEtD,IAAI3B,OAAAA,EAASzB,YAAYP,SAAW,EAAA;AAClCyE,YAAAA,KAAAA,CAAME,KAAK,CAACW,YAAY,GAAGtD,OAAAA,CAAQzB,OAAO,GAAG;gBAAEgF,GAAK,EAAA;aAAS,GAAA;gBAAErB,GAAK,EAAA;AAAK,aAAA;AAC3E;AAEA,QAAA,IAAIT,EAAI,EAAA;YACNgB,KAAME,CAAAA,KAAK,CAAClB,EAAE,GAAG;gBAAES,GAAKT,EAAAA;AAAG,aAAA;AAC7B;AAEA,QAAA,IAAIzB,SAASgC,MAAQ,EAAA;AACnBS,YAAAA,KAAAA,CAAME,KAAK,CAACX,MAAM,GAAGhC,QAAQgC,MAAM;AACrC;AAEA,QAAA,MAAMwB,sBAAyB,GAAA,MAAMjB,MAAOC,CAAAA,EAAE,CAC3CC,KAAK,CAAC1C,gBAAiB4B,CAAAA,aAAa,CAAC/B,KAAK,CAACwC,GAAG,CAAA,CAC9CqB,QAAQ,CAAChB,KAAAA,CAAAA;;;AAIZ,QAAA,MAAMiB,eAAkBF,GAAAA,sBAAAA,CACrBlC,MAAM,CAAC,CAACqC,MAAWC,GAAAA,KAAAA,CAAMC,OAAO,CAACF,MAAM,CAACd,WAAY,CAAA,CAAA,IAAKc,MAAM,CAACd,WAAAA,CAAY,CAACvC,MAAM,CACnFwD,CAAAA,OAAO,CAAC,CAACH,SAAWA,MAAM,CAACd,WAAY,CAAA,CAAA,CACvCvB,MAAM,CAAC,CAACyC,oBAAyBA,GAAAA,oBAAAA,CAAqBb,WAAW,KAAKJ,kBAAAA,CAAAA;QAEzE,IAAIY,eAAAA,CAAgBpD,MAAM,IAAI,CAAG,EAAA;YAC/B,OAAO,KAAA;AACT;QAEA,OAAO,IAAA;AACT,KAAA;AAEA,IAAA,OAAOjC,SAAU2F,CAAAA,IAAI,CAAC,QAAA,EAAU,iCAAiC,OAAOjG,KAAAA,GAAAA;AACtE;;;AAGC,QACD,IAAIU,CAAEwF,CAAAA,KAAK,CAAClG,KAAAA,CAAAA,IAAUA,UAAU,EAAI,EAAA;YAClC,OAAO,IAAA;AACT;AAEA;;QAGA,IAAIiC,OAAQzB,CAAAA,OAAO,EAAE;YACnB,OAAO,IAAA;AACT;AAEA,QAAA,MAAM2F,qBAAqBnE,gBAAoBA,IAAAA,gBAAAA,CAAiBY,eAAe,CAACL,MAAM,GAAG,CAAA;AACzF,QAAA,IAAI4D,kBAAoB,EAAA;;;AAGtB,YAAA,MAAMrB,WAAc9C,GAAAA,gBAAAA,CAAiBY,eAAe,CAAC,CAAE,CAAA;YACvD,MAAMwD,SAAAA,GACJpE,gBAAiB4B,CAAAA,aAAa,CAAC/B,KAAK,CAACwE,UAAU,CAACvB,WAAAA,CAAY,CAAC5C,IAAI,KAAK,aAAA;AAExE,YAAA,IAAIkE,SAAW,EAAA;AACb,gBAAA,OAAOvB,6CAA8CC,CAAAA,WAAAA,CAAAA;AACvD;AAEA,YAAA,OAAO1C,kCAAmCpC,CAAAA,KAAAA,CAAAA;AAC5C;AAEA;;;;AAIC,QACD,MAAMsG,oBAA4C,GAAA;YAChD,CAACxE,gBAAAA,CAAiBU,IAAI,GAAGxC,KAAAA;YACzB+D,WAAa,EAAA;gBAAEC,QAAU,EAAA;AAAK;AAChC,SAAA;AAEA,QAAA,IAAI/B,SAASgC,MAAQ,EAAA;YACnBqC,oBAAqBrC,CAAAA,MAAM,GAAGhC,OAAAA,CAAQgC,MAAM;AAC9C;AAEA,QAAA,IAAIlC,QAAQ2B,EAAI,EAAA;AACd4C,YAAAA,oBAAAA,CAAqB5C,EAAE,GAAG;AAAES,gBAAAA,GAAAA,EAAKpC,OAAO2B;AAAG,aAAA;AAC7C;;QAGA,OAAO,CAAE,MAAMc,MAAAA,CAAOC,EAAE,CACrBC,KAAK,CAAC7C,KAAMwC,CAAAA,GAAG,CACfM,CAAAA,OAAO,CAAC;YAAEC,KAAO0B,EAAAA,oBAAAA;YAAsBlB,MAAQ,EAAA;AAAC,gBAAA;AAAK;AAAC,SAAA,CAAA;AAC3D,KAAA,CAAA;AACF,CAAA;AAEA,sBAEA,MAAMmB,eAAkB,GAAA,CACtBC,KAQAvE,EAAAA,OAAAA,GAAAA;IAEA,IAAIwE,MAAAA,GAASC,gBAAIC,MAAM,EAAA,CAAGC,SAAS,CAAC,CAACC,KAAKC,WAAgBA,GAAAA,WAAAA,CAAAA;IAE1DL,MAASpG,GAAAA,qBAAAA,CAAsBoG,QAAQD,KAAOvE,EAAAA,OAAAA,CAAAA;AAC9CwE,IAAAA,MAAAA,GAAS5F,sBAAsB4F,MAAQD,EAAAA,KAAAA,CAAAA;IACvCC,MAASpF,GAAAA,uBAAAA,CAAwBoF,QAAQD,KAAOvE,EAAAA,OAAAA,CAAAA;IAChDwE,MAAS7E,GAAAA,kBAAAA,CAAmB6E,QAAQD,KAAOvE,EAAAA,OAAAA,CAAAA;IAE3C,OAAOwE,MAAAA;AACT,CAAA;AAEO,MAAMM,cAAiB,GAAA,CAC5BP,KACAvE,EAAAA,OAAAA,GAAAA;IAEA,MAAMwE,MAAAA,GAASF,gBAAgBC,KAAOvE,EAAAA,OAAAA,CAAAA;IAEtC,IAAIA,OAAAA,CAAQzB,OAAO,EAAE;QACnB,OAAOiG,MAAAA;AACT;AAEA,IAAA,OAAOA,OAAOO,KAAK,EAAA,CAAGpG,GAAG,CACvB;AAEA,IAAA,yBAAA,CAAA;AAEJ;AAEO,MAAMqG,YAAe,GAAA,CAC1BT,KACAvE,EAAAA,OAAAA,GAAAA;IAEA,MAAMwE,MAAAA,GAASF,gBAAgBC,KAAOvE,EAAAA,OAAAA,CAAAA;IAEtC,IAAIA,OAAAA,CAAQzB,OAAO,EAAE;QACnB,OAAOiG,MAAAA;AACT;AAEA,IAAA,IAAID,KAAMjG,CAAAA,IAAI,CAACgB,KAAK,EAAE;QACpB,OAAOkF,MAAAA,CAAOjF,OAAO,CAAC,IAAIC,OAAO+E,KAAMjG,CAAAA,IAAI,CAACgB,KAAK,CAAA,CAAA;AACnD;IAEA,OAAOkF,MAAAA,CAAOjF,OAAO,CAAC,oBAAA,CAAA;AACxB;AAEa0F,MAAAA,oBAAAA,GAAuB,CAAC,EAAE3G,IAAI,EAA0C,GAAA;AACnF,IAAA,OAAOmG,eACJC,CAAAA,MAAM,EACNQ,CAAAA,KAAK,CAAC,CAACtB,KAAMC,CAAAA,OAAO,CAACvF,IAAK6G,CAAAA,IAAI,CAAI7G,GAAAA,IAAAA,CAAK6G,IAAI,GAAG;AAAC7G,QAAAA,IAAAA,CAAK6G;KAAK,EAAEC,MAAM,CAAC,IAAA,CAAA,CAAA;AACvE;AAEO,MAAMC,gBAAmB,GAAA,CAC9Bd,KACAvE,EAAAA,OAAAA,GAAAA;AAEA,IAAA,IAAIwE,MAASC,GAAAA,eAAAA,CAAIa,MAAM,EAAA,CAAGC,OAAO,EAAA;IAEjCf,MAASzF,GAAAA,sBAAAA,CAAuByF,QAAQD,KAAOvE,EAAAA,OAAAA,CAAAA;AAC/CwE,IAAAA,MAAAA,GAASvF,uBAAuBuF,MAAQD,EAAAA,KAAAA,CAAAA;IACxCC,MAAS7E,GAAAA,kBAAAA,CAAmB6E,QAAQD,KAAOvE,EAAAA,OAAAA,CAAAA;IAE3C,OAAOwE,MAAAA;AACT;AAEO,MAAMgB,cAAiB,GAAA,CAC5BjB,KACAvE,EAAAA,OAAAA,GAAAA;IAEA,IAAIwE,MAAAA,GAASC,gBAAIa,MAAM,EAAA;IAEvBd,MAAStF,GAAAA,oBAAAA,CAAqBsF,QAAQD,KAAOvE,EAAAA,OAAAA,CAAAA;AAC7CwE,IAAAA,MAAAA,GAASrF,qBAAqBqF,MAAQD,EAAAA,KAAAA,CAAAA;IACtCC,MAAS7E,GAAAA,kBAAAA,CAAmB6E,QAAQD,KAAOvE,EAAAA,OAAAA,CAAAA;IAE3C,OAAOwE,MAAAA;AACT;AAEO,MAAMiB,mBAAsB,GAAA,CACjClB,KACAvE,EAAAA,OAAAA,GAAAA;IAEA,MAAMwE,MAAAA,GAASC,gBAAIiB,KAAK,EAAA;IACxB,OAAO/F,kBAAAA,CAAmB6E,QAAQD,KAAOvE,EAAAA,OAAAA,CAAAA;AAC3C;AAEO,MAAM2F,cAAiB,GAAA,CAC5BpB,KAMAvE,EAAAA,OAAAA,GAAAA;IAEA,MAAMwE,MAAAA,GAASC,gBAAIiB,KAAK,EAAA;IACxB,OAAO/F,kBAAAA,CAAmB6E,QAAQD,KAAOvE,EAAAA,OAAAA,CAAAA;AAC3C;MAEa4F,UAAa,GAAA;IACxBlB,MAAQJ,EAAAA,eAAAA;IACRuB,IAAMvB,EAAAA,eAAAA;IACNwB,QAAUxB,EAAAA,eAAAA;IACVyB,QAAUzB,EAAAA,eAAAA;IACVS,KAAOD,EAAAA,cAAAA;IACPkB,WAAaf,EAAAA,oBAAAA;AACbgB,IAAAA,OAAAA,EAAS,IAAMxB,eAAAA,CAAIwB,OAAO,EAAA,CAAGC,QAAQ,EAAA;IACrC9D,GAAK4C,EAAAA,YAAAA;IACLmB,IAAM,EAAA,IAAM1B,gBAAIiB,KAAK,EAAA;IACrBH,OAASF,EAAAA,gBAAAA;IACTe,UAAYX,EAAAA,mBAAAA;IACZY,KAAOb,EAAAA,cAAAA;IACPc,OAASd,EAAAA,cAAAA;IACTe,IAAMZ,EAAAA,cAAAA;IACNa,IAAMb,EAAAA,cAAAA;IACNc,QAAUd,EAAAA,cAAAA;IACVe,SAAWf,EAAAA,cAAAA;IACXgB,MAAQC,EAAAA;AACV;;;;;;;;;;;"}
@@ -2,7 +2,12 @@ import _ from 'lodash';
2
2
  import { yup } from '@strapi/utils';
3
3
  import { blocksValidator } from './blocks-validator.mjs';
4
4
 
5
- /* Validator utils */ /**
5
+ /* Validator utils */ const toNumberSafe = (value)=>{
6
+ if (value === undefined || value === null) return undefined;
7
+ const num = Number(value);
8
+ return Number.isFinite(num) ? num : undefined;
9
+ };
10
+ /**
6
11
  * Adds minLength validator
7
12
  */ const addMinLengthValidator = (validator, { attr }, { isDraft })=>{
8
13
  return attr.minLength && _.isInteger(attr.minLength) && !isDraft ? validator.min(attr.minLength) : validator;
@@ -16,16 +21,28 @@ import { blocksValidator } from './blocks-validator.mjs';
16
21
  /**
17
22
  * Adds min integer validator
18
23
  * @returns {NumberSchema}
19
- */ const addMinIntegerValidator = (validator, { attr }, { isDraft })=>_.isNumber(attr.min) && !isDraft ? validator.min(_.toInteger(attr.min)) : validator;
24
+ */ const addMinIntegerValidator = (validator, { attr }, { isDraft })=>{
25
+ const min = toNumberSafe(attr.min);
26
+ return min !== undefined && !isDraft ? validator.min(_.toInteger(min)) : validator;
27
+ };
20
28
  /**
21
29
  * Adds max integer validator
22
- */ const addMaxIntegerValidator = (validator, { attr })=>_.isNumber(attr.max) ? validator.max(_.toInteger(attr.max)) : validator;
30
+ */ const addMaxIntegerValidator = (validator, { attr })=>{
31
+ const max = toNumberSafe(attr.max);
32
+ return max !== undefined ? validator.max(_.toInteger(max)) : validator;
33
+ };
23
34
  /**
24
35
  * Adds min float/decimal validator
25
- */ const addMinFloatValidator = (validator, { attr }, { isDraft })=>_.isNumber(attr.min) && !isDraft ? validator.min(attr.min) : validator;
36
+ */ const addMinFloatValidator = (validator, { attr }, { isDraft })=>{
37
+ const min = toNumberSafe(attr.min);
38
+ return min !== undefined && !isDraft ? validator.min(min) : validator;
39
+ };
26
40
  /**
27
41
  * Adds max float/decimal validator
28
- */ const addMaxFloatValidator = (validator, { attr })=>_.isNumber(attr.max) ? validator.max(attr.max) : validator;
42
+ */ const addMaxFloatValidator = (validator, { attr })=>{
43
+ const max = toNumberSafe(attr.max);
44
+ return max !== undefined ? validator.max(max) : validator;
45
+ };
29
46
  /**
30
47
  * Adds regex validator
31
48
  */ const addStringRegexValidator = (validator, { attr }, { isDraft })=>{