@strapi/content-manager 5.44.0 → 5.45.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.
- package/dist/admin/index.js.map +1 -1
- package/dist/admin/index.mjs.map +1 -1
- package/dist/admin/pages/EditView/utils/data.js +8 -0
- package/dist/admin/pages/EditView/utils/data.js.map +1 -1
- package/dist/admin/pages/EditView/utils/data.mjs +8 -0
- package/dist/admin/pages/EditView/utils/data.mjs.map +1 -1
- package/dist/admin/pages/ListView/ListViewPage.js +17 -2
- package/dist/admin/pages/ListView/ListViewPage.js.map +1 -1
- package/dist/admin/pages/ListView/ListViewPage.mjs +17 -2
- package/dist/admin/pages/ListView/ListViewPage.mjs.map +1 -1
- package/dist/admin/src/index.d.ts +2 -1
- package/dist/server/controllers/collection-types.js +78 -1
- package/dist/server/controllers/collection-types.js.map +1 -1
- package/dist/server/controllers/collection-types.mjs +78 -1
- package/dist/server/controllers/collection-types.mjs.map +1 -1
- package/dist/server/controllers/validation/dimensions.js +17 -18
- package/dist/server/controllers/validation/dimensions.js.map +1 -1
- package/dist/server/controllers/validation/dimensions.mjs +18 -19
- package/dist/server/controllers/validation/dimensions.mjs.map +1 -1
- package/dist/server/controllers/validation/index.js +25 -23
- package/dist/server/controllers/validation/index.js.map +1 -1
- package/dist/server/controllers/validation/index.mjs +26 -24
- package/dist/server/controllers/validation/index.mjs.map +1 -1
- package/dist/server/controllers/validation/relations.js +21 -24
- package/dist/server/controllers/validation/relations.js.map +1 -1
- package/dist/server/controllers/validation/relations.mjs +22 -25
- package/dist/server/controllers/validation/relations.mjs.map +1 -1
- package/dist/server/history/controllers/validation/history-version.js +4 -24
- package/dist/server/history/controllers/validation/history-version.js.map +1 -1
- package/dist/server/history/controllers/validation/history-version.mjs +5 -6
- package/dist/server/history/controllers/validation/history-version.mjs.map +1 -1
- package/dist/server/history/services/lifecycles.js +1 -1
- package/dist/server/history/services/lifecycles.js.map +1 -1
- package/dist/server/history/services/lifecycles.mjs +1 -1
- package/dist/server/history/services/lifecycles.mjs.map +1 -1
- package/dist/server/homepage/controllers/homepage.js +6 -26
- package/dist/server/homepage/controllers/homepage.js.map +1 -1
- package/dist/server/homepage/controllers/homepage.mjs +7 -8
- package/dist/server/homepage/controllers/homepage.mjs.map +1 -1
- package/dist/server/preview/controllers/validation/preview.js +6 -26
- package/dist/server/preview/controllers/validation/preview.js.map +1 -1
- package/dist/server/preview/controllers/validation/preview.mjs +7 -8
- package/dist/server/preview/controllers/validation/preview.mjs.map +1 -1
- package/dist/server/src/controllers/collection-types.d.ts.map +1 -1
- package/dist/server/src/controllers/validation/dimensions.d.ts.map +1 -1
- package/dist/server/src/controllers/validation/index.d.ts +16 -15
- package/dist/server/src/controllers/validation/index.d.ts.map +1 -1
- package/dist/server/src/controllers/validation/relations.d.ts +17 -2
- package/dist/server/src/controllers/validation/relations.d.ts.map +1 -1
- package/dist/server/src/history/controllers/validation/history-version.d.ts +3 -1
- package/dist/server/src/history/controllers/validation/history-version.d.ts.map +1 -1
- package/dist/server/src/homepage/controllers/homepage.d.ts.map +1 -1
- package/dist/server/src/preview/controllers/validation/preview.d.ts.map +1 -1
- package/dist/server/src/validation/policies/hasPermissions.d.ts +4 -1
- package/dist/server/src/validation/policies/hasPermissions.d.ts.map +1 -1
- package/dist/server/src/validation/zod.d.ts +34 -0
- package/dist/server/src/validation/zod.d.ts.map +1 -0
- package/dist/server/validation/policies/hasPermissions.js +4 -4
- package/dist/server/validation/policies/hasPermissions.js.map +1 -1
- package/dist/server/validation/policies/hasPermissions.mjs +5 -5
- package/dist/server/validation/policies/hasPermissions.mjs.map +1 -1
- package/dist/server/validation/zod.js +60 -0
- package/dist/server/validation/zod.js.map +1 -0
- package/dist/server/validation/zod.mjs +56 -0
- package/dist/server/validation/zod.mjs.map +1 -0
- package/package.json +5 -5
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"collection-types.mjs","sources":["../../../server/src/controllers/collection-types.ts"],"sourcesContent":["import { isNil, omit } from 'lodash/fp';\n\nimport { setCreatorFields, async, contentTypes, errors } from '@strapi/utils';\nimport type { Modules, UID } from '@strapi/types';\n\nimport { getService } from '../utils';\nimport { validateBulkActionInput } from './validation';\nimport { getProhibitedCloningFields, excludeNotCreatableFields } from './utils/clone';\nimport { getDocumentLocaleAndStatus } from './validation/dimensions';\nimport { formatDocumentWithMetadata } from './utils/metadata';\nimport { indexByDocumentId } from './utils/document-status';\nimport { getPopulateForLocalizations, buildDeepPopulate } from '../services/utils/populate';\n\n/**\n * Returns documentIds for (documentId, locale) that have both draft and published,\n * optionally filtered by whether the draft is newer than the published row.\n * Uses strapi.documents only.\n */\nconst getDocumentIdsByDraftPublishRelation = async (\n uid: UID.ContentType,\n opts: {\n locale?: string | string[] | null;\n type: 'modified' | 'unmodified';\n }\n): Promise<string[]> => {\n const schema = strapi.getModel(uid);\n if (!contentTypes.hasDraftAndPublish(schema)) {\n return [];\n }\n\n const baseParams = {\n fields: ['documentId', 'locale', 'updatedAt'],\n page: 1,\n pageSize: 10000,\n ...(opts.locale != null &&\n opts.locale !== '*' && {\n locale: opts.locale as string,\n }),\n };\n\n const [drafts, published] = await Promise.all([\n strapi.documents(uid).findMany({ ...baseParams, status: 'draft' }),\n strapi.documents(uid).findMany({ ...baseParams, status: 'published' }),\n ]);\n\n const publishedByKey = new Map<string, { updatedAt: string }>();\n for (const p of published) {\n const key = `${p.documentId}\\t${String(p?.locale ?? '')}`;\n publishedByKey.set(key, { updatedAt: p.updatedAt as string });\n }\n\n const ids: string[] = [];\n const wantModified = opts.type === 'modified';\n for (const d of drafts) {\n const key = `${d.documentId}\\t${String(d?.locale ?? '')}`;\n const pub = publishedByKey.get(key);\n if (pub) {\n const dUpdated = d?.updatedAt ? new Date(d.updatedAt as string).getTime() : 0;\n const pUpdated = pub?.updatedAt ? new Date(pub.updatedAt).getTime() : 0;\n const isModified = dUpdated > pUpdated;\n if (isModified === wantModified) {\n ids.push(d.documentId as string);\n }\n }\n }\n return [...new Set(ids)];\n};\n\n/** Map from __status filter value to top-level query fields (mirrors client STATUS_PARAMS). */\nconst STATUS_QUERY_FROM_FILTER: Record<string, Record<string, string>> = {\n draft: { status: 'draft', hasPublishedVersion: 'false' },\n published: { status: 'published' },\n 'published-modified': { publicationStatusFilter: 'published-modified' },\n 'published-unmodified': { publicationStatusFilter: 'published-unmodified' },\n};\n\n/**\n * Extracts __status from query.filters.$and into top-level status, hasPublishedVersion,\n * and publicationStatusFilter so list works with either transformed params or raw filter params.\n */\nconst normalizeStatusFromFilters = (query: Record<string, unknown>): void => {\n const filters = query.filters as Record<string, unknown> | undefined;\n if (!filters?.$and || !Array.isArray(filters.$and)) return;\n\n const remainingFilters: unknown[] = [];\n const statusValues: string[] = [];\n\n for (const filter of filters.$and as Record<string, unknown>[]) {\n const eq = (filter?.__status as Record<string, unknown>)?.$eq;\n if (eq != null) {\n statusValues.push(String(eq));\n } else {\n remainingFilters.push(filter);\n }\n }\n\n if (statusValues.length === 0) return;\n\n const q = query as Record<string, unknown>;\n for (const value of statusValues) {\n const toApply = STATUS_QUERY_FROM_FILTER[value];\n if (toApply) Object.assign(q, toApply);\n }\n\n if (remainingFilters.length > 0) {\n (filters as Record<string, unknown>).$and = remainingFilters;\n } else {\n delete q.filters;\n }\n};\n\n/** Returns filters object that merges existing $and with a documentId $in filter. */\nconst mergeDocumentIdFilter = (\n existingFilters: Record<string, unknown> | undefined,\n documentIds: string[]\n): Record<string, unknown> => {\n const documentIdFilter = {\n documentId: documentIds.length > 0 ? { $in: documentIds } : { $in: [] },\n };\n let existingAnd: unknown[];\n if (existingFilters?.$and && Array.isArray(existingFilters.$and)) {\n existingAnd = existingFilters.$and;\n } else if (existingFilters && Object.keys(existingFilters).length > 0) {\n existingAnd = [existingFilters];\n } else {\n existingAnd = [];\n }\n return { $and: [...existingAnd, documentIdFilter] };\n};\n\ntype Options = Modules.Documents.Params.Pick<UID.ContentType, 'populate:object'>;\n\n/**\n * Create a new document.\n *\n * @param ctx - Koa context\n * @param opts - Options\n * @param opts.populate - Populate options of the returned document.\n * By default documentManager will populate all relations.\n */\nconst createDocument = async (ctx: any, opts?: Options) => {\n const { userAbility, user } = ctx.state;\n const { model } = ctx.params;\n const { body } = ctx.request;\n\n const documentManager = getService('document-manager');\n const permissionChecker = getService('permission-checker').create({ userAbility, model });\n\n if (permissionChecker.cannot.create()) {\n throw new errors.ForbiddenError();\n }\n\n const pickPermittedFields = permissionChecker.sanitizeCreateInput;\n const setCreator = setCreatorFields({ user });\n const sanitizeFn = async.pipe(pickPermittedFields, setCreator as any);\n const sanitizedBody = await sanitizeFn(body);\n\n const { locale, status } = await getDocumentLocaleAndStatus(body, model);\n\n return documentManager.create(model, {\n data: sanitizedBody as any,\n locale,\n status,\n populate: opts?.populate,\n });\n\n // TODO: Revert the creation if create permission conditions are not met\n // if (permissionChecker.cannot.create(document)) {\n // throw new errors.ForbiddenError();\n // }\n};\n\n/**\n * Update a document version.\n * - If the document version exists, it will be updated.\n * - If the document version does not exist, a new document locale will be created.\n * By default documentManager will populate all relations.\n *\n * @param ctx - Koa context\n * @param opts - Options\n * @param opts.populate - Populate options of the returned document\n */\nconst updateDocument = async (ctx: any, opts?: Options) => {\n const { userAbility, user } = ctx.state;\n const { id, model } = ctx.params;\n const { body } = ctx.request;\n\n const documentManager = getService('document-manager');\n const permissionChecker = getService('permission-checker').create({ userAbility, model });\n\n if (permissionChecker.cannot.update()) {\n throw new errors.ForbiddenError();\n }\n\n // Populate necessary fields to check permissions\n const permissionQuery = await permissionChecker.sanitizedQuery.update(ctx.query);\n const populate = await getService('populate-builder')(model)\n .populateFromQuery(permissionQuery)\n .build();\n\n const { locale } = await getDocumentLocaleAndStatus(body, model);\n\n // Load document version to update\n const [documentVersion, documentExists] = await Promise.all([\n documentManager.findOne(id, model, { populate, locale, status: 'draft' }),\n documentManager.exists(model, id),\n ]);\n\n if (!documentExists) {\n throw new errors.NotFoundError();\n }\n\n // If version is not found, but document exists,\n // the intent is to create a new document locale\n if (documentVersion) {\n if (permissionChecker.cannot.update(documentVersion)) {\n throw new errors.ForbiddenError();\n }\n } else if (permissionChecker.cannot.create()) {\n throw new errors.ForbiddenError();\n }\n\n const pickPermittedFields = documentVersion\n ? permissionChecker.sanitizeUpdateInput(documentVersion)\n : permissionChecker.sanitizeCreateInput;\n const setCreator = documentVersion\n ? setCreatorFields({ user, isEdition: true })\n : setCreatorFields({ user });\n const sanitizeFn = async.pipe(pickPermittedFields, setCreator as any);\n const sanitizedBody = await sanitizeFn(body);\n\n const updatedDocument = await documentManager.update(documentVersion?.documentId || id, model, {\n data: sanitizedBody as any,\n populate: opts?.populate,\n locale,\n });\n\n return updatedDocument;\n};\n\nexport default {\n async find(ctx: any) {\n const { userAbility } = ctx.state;\n const { model } = ctx.params;\n const { query } = ctx.request;\n\n // Normalize so status/publicationStatusFilter are set from filters.$and.__status when present\n normalizeStatusFromFilters(query as Record<string, unknown>);\n\n const documentMetadata = getService('document-metadata');\n const documentManager = getService('document-manager');\n const permissionChecker = getService('permission-checker').create({ userAbility, model });\n\n if (permissionChecker.cannot.read()) {\n return ctx.forbidden();\n }\n\n const permissionQuery = await permissionChecker.sanitizedQuery.read(query);\n\n const populate = await getService('populate-builder')(model)\n .populateFromQuery(permissionQuery)\n .populateDeep(1)\n .countRelations({ toOne: false, toMany: true })\n .withPopulateOverride(getPopulateForLocalizations(model))\n .build();\n\n // \"Modified\" is a UI-only filter; not a real document status. Read and strip it\n // so we never pass it to validation or the document service.\n const publicationStatusFilter = query.publicationStatusFilter;\n const queryForValidation = { ...query };\n delete queryForValidation.publicationStatusFilter;\n\n const { locale, status } = await getDocumentLocaleAndStatus(queryForValidation, model);\n\n const paramsForDocumentService = omit(['publicationStatusFilter'], permissionQuery) as Record<\n string,\n unknown\n >;\n let findPageParams: Record<string, unknown> = {\n ...paramsForDocumentService,\n populate,\n locale,\n status,\n };\n\n // Pass through hasPublishedVersion so \"Draft\" filter returns only drafts with no published version\n if (query.hasPublishedVersion !== undefined) {\n findPageParams.hasPublishedVersion = query.hasPublishedVersion;\n }\n\n if (\n publicationStatusFilter === 'published-modified' ||\n publicationStatusFilter === 'published-unmodified'\n ) {\n const type = publicationStatusFilter === 'published-modified' ? 'modified' : 'unmodified';\n const documentIds = await getDocumentIdsByDraftPublishRelation(model, { locale, type });\n findPageParams = {\n ...findPageParams,\n status: 'published',\n filters: mergeDocumentIdFilter(\n paramsForDocumentService.filters as Record<string, unknown> | undefined,\n documentIds\n ),\n };\n }\n\n const { results: documents, pagination } = await documentManager.findPage(\n findPageParams as Parameters<typeof documentManager.findPage>[0],\n model\n );\n\n const hasDraftAndPublish = contentTypes.hasDraftAndPublish(strapi.getModel(model));\n\n const statusByDocumentId = hasDraftAndPublish\n ? indexByDocumentId(await documentMetadata.getManyAvailableStatus(model, documents))\n : new Map();\n\n const setStatus = (document: any) => {\n // Available status of document\n const availableStatuses = statusByDocumentId.get(document.documentId) || [];\n // Compute document version status\n document.status = documentMetadata.getStatus(document, availableStatuses);\n return document;\n };\n\n const results = await async.map(\n documents,\n async.pipe(permissionChecker.sanitizeOutput, setStatus)\n );\n\n ctx.body = {\n results,\n pagination,\n };\n },\n\n async findOne(ctx: any) {\n const { userAbility } = ctx.state;\n const { model, id } = ctx.params;\n\n const documentManager = getService('document-manager');\n const permissionChecker = getService('permission-checker').create({ userAbility, model });\n\n if (permissionChecker.cannot.read()) {\n return ctx.forbidden();\n }\n\n const permissionQuery = await permissionChecker.sanitizedQuery.read(ctx.query);\n\n const populate = await getService('populate-builder')(model)\n .populateFromQuery(permissionQuery)\n .populateDeep(Infinity)\n .countRelations()\n .withPopulateOverride(getPopulateForLocalizations(model))\n .build();\n\n const { locale, status } = await getDocumentLocaleAndStatus(ctx.query, model);\n\n const version = await documentManager.findOne(id, model, {\n populate,\n locale,\n status,\n });\n\n if (!version) {\n // Check if document exists\n const exists = await documentManager.exists(model, id);\n if (!exists) {\n return ctx.notFound();\n }\n\n // If the requested locale doesn't exist, return an empty response\n const { meta } = await formatDocumentWithMetadata(\n permissionChecker,\n model,\n // @ts-expect-error TODO: fix\n { documentId: id, locale, publishedAt: null },\n { availableLocales: true, availableStatus: false }\n );\n\n ctx.body = { data: {}, meta };\n\n return;\n }\n\n // if the user has condition that needs populated content, it's not applied because entity don't have relations populated\n if (permissionChecker.cannot.read(version)) {\n return ctx.forbidden();\n }\n\n // TODO: Count populated relations by permissions\n const sanitizedDocument = await permissionChecker.sanitizeOutput(version);\n ctx.body = await formatDocumentWithMetadata(permissionChecker, model, sanitizedDocument);\n },\n\n async create(ctx: any) {\n const { userAbility } = ctx.state;\n const { model } = ctx.params;\n\n const permissionChecker = getService('permission-checker').create({ userAbility, model });\n\n const [totalEntries, document] = await Promise.all([\n strapi.db.query(model).count(),\n createDocument(ctx),\n ]);\n\n const sanitizedDocument = await permissionChecker.sanitizeOutput(document);\n ctx.status = 201;\n ctx.body = await formatDocumentWithMetadata(permissionChecker, model, sanitizedDocument, {\n // Empty metadata as it's not relevant for a new document\n availableLocales: false,\n availableStatus: false,\n });\n\n if (totalEntries === 0) {\n strapi.telemetry.send('didCreateFirstContentTypeEntry', {\n eventProperties: { model },\n });\n }\n },\n\n async update(ctx: any) {\n const { userAbility } = ctx.state;\n const { model } = ctx.params;\n\n const permissionChecker = getService('permission-checker').create({ userAbility, model });\n\n const updatedVersion = await updateDocument(ctx);\n\n const sanitizedVersion = await permissionChecker.sanitizeOutput(updatedVersion);\n ctx.body = await formatDocumentWithMetadata(permissionChecker, model, sanitizedVersion);\n },\n\n async clone(ctx: any) {\n const { userAbility, user } = ctx.state;\n const { model, sourceId: id } = ctx.params;\n const { body } = ctx.request;\n\n const documentManager = getService('document-manager');\n const permissionChecker = getService('permission-checker').create({ userAbility, model });\n\n if (permissionChecker.cannot.create()) {\n return ctx.forbidden();\n }\n\n const permissionQuery = await permissionChecker.sanitizedQuery.create(ctx.query);\n const populate = await getService('populate-builder')(model)\n .populateFromQuery(permissionQuery)\n .build();\n\n const { locale } = await getDocumentLocaleAndStatus(body, model);\n const document = await documentManager.findOne(id, model, {\n populate,\n locale,\n status: 'draft',\n });\n\n if (!document) {\n return ctx.notFound();\n }\n\n const pickPermittedFields = permissionChecker.sanitizeCreateInput;\n const setCreator = setCreatorFields({ user });\n const excludeNotCreatable = excludeNotCreatableFields(model, permissionChecker);\n const sanitizeFn = async.pipe(pickPermittedFields, setCreator as any, excludeNotCreatable);\n const sanitizedBody = await sanitizeFn(body);\n\n const clonedDocument = await documentManager.clone(document.documentId, sanitizedBody, model);\n\n const sanitizedDocument = await permissionChecker.sanitizeOutput(clonedDocument);\n ctx.body = await formatDocumentWithMetadata(permissionChecker, model, sanitizedDocument, {\n // Empty metadata as it's not relevant for a new document\n availableLocales: false,\n availableStatus: false,\n });\n },\n\n async autoClone(ctx: any) {\n const { model } = ctx.params;\n\n // Check if the model has fields that prevent auto cloning\n const prohibitedFields = getProhibitedCloningFields(model);\n\n if (prohibitedFields.length > 0) {\n return ctx.badRequest(\n 'Entity could not be cloned as it has unique and/or relational fields. ' +\n 'Please edit those fields manually and save to complete the cloning.',\n {\n prohibitedFields,\n }\n );\n }\n\n await this.clone(ctx);\n },\n\n async delete(ctx: any) {\n const { userAbility } = ctx.state;\n const { id, model } = ctx.params;\n\n const documentManager = getService('document-manager');\n const permissionChecker = getService('permission-checker').create({ userAbility, model });\n\n if (permissionChecker.cannot.delete()) {\n return ctx.forbidden();\n }\n\n const permissionQuery = await permissionChecker.sanitizedQuery.delete(ctx.query);\n const populate = await getService('populate-builder')(model)\n .populateFromQuery(permissionQuery)\n .build();\n\n const { locale } = await getDocumentLocaleAndStatus(ctx.query, model);\n\n // Find locales to delete\n const documentLocales = await documentManager.findLocales(id, model, { populate, locale });\n\n if (documentLocales.length === 0) {\n return ctx.notFound();\n }\n\n for (const document of documentLocales) {\n if (permissionChecker.cannot.delete(document)) {\n return ctx.forbidden();\n }\n }\n\n const result = await documentManager.delete(id, model, { locale });\n\n ctx.body = await permissionChecker.sanitizeOutput(result);\n },\n\n /**\n * Publish a document version.\n * Supports creating/saving a document and publishing it in one request.\n */\n async publish(ctx: any) {\n const { userAbility } = ctx.state;\n // If id does not exist, the document has to be created\n const { id, model } = ctx.params;\n const { body } = ctx.request;\n\n const documentManager = getService('document-manager');\n const permissionChecker = getService('permission-checker').create({ userAbility, model });\n\n if (permissionChecker.cannot.publish()) {\n return ctx.forbidden();\n }\n\n const publishedDocument = await strapi.db.transaction(async () => {\n // Create or update document\n const permissionQuery = await permissionChecker.sanitizedQuery.publish(ctx.query);\n\n const populate = await getService('populate-builder')(model)\n .populateFromQuery(permissionQuery)\n .populateDeep(Infinity)\n .countRelations()\n .withPopulateOverride(getPopulateForLocalizations(model))\n .build();\n\n let document: any;\n\n const { locale } = await getDocumentLocaleAndStatus(body, model);\n\n /**\n * Publish can be called on two scenarios:\n * 1. Create a new document and publish it in one request\n * 2. Update an existing document and publish it in one request\n *\n * Based on user permissions:\n * 1. User cannot create a document, but can publish\n * Action will be forbidden as user cannot create a document\n * 2. User can update and publish a document\n * Action will be allowed, but document will not be updated, only published with the latest draft\n */\n const isCreate = isNil(id);\n if (isCreate) {\n if (permissionChecker.cannot.create()) {\n throw new errors.ForbiddenError();\n }\n\n document = await createDocument(ctx, { populate });\n }\n\n const isUpdate = !isCreate;\n if (isUpdate) {\n // check if the document exists\n const documentExists = await documentManager.exists(model, id);\n\n if (!documentExists) {\n throw new errors.NotFoundError('Document not found');\n }\n\n // check the document version\n document = await documentManager.findOne(id!, model, { populate, locale });\n\n if (!document) {\n // update and publish the new version\n if (\n permissionChecker.cannot.create({ locale }) ||\n permissionChecker.cannot.publish({ locale })\n ) {\n throw new errors.ForbiddenError();\n }\n document = await updateDocument(ctx);\n } else if (permissionChecker.can.update(document)) {\n await updateDocument(ctx);\n }\n }\n\n if (permissionChecker.cannot.publish(document)) {\n throw new errors.ForbiddenError();\n }\n\n const publishResult = await documentManager.publish(document.documentId, model, {\n locale,\n // TODO: Allow setting creator fields on publish\n // data: setCreatorFields({ user, isEdition: true })({}),\n });\n\n if (!publishResult || publishResult.length === 0) {\n throw new errors.NotFoundError('Document not found or already published.');\n }\n\n return publishResult[0];\n });\n\n const sanitizedDocument = await permissionChecker.sanitizeOutput(publishedDocument);\n ctx.body = await formatDocumentWithMetadata(permissionChecker, model, sanitizedDocument);\n },\n\n async bulkFindForValidation(ctx: any) {\n const { userAbility } = ctx.state;\n const { model } = ctx.params;\n const { documentIds, locale, sort } = ctx.request.body;\n\n await validateBulkActionInput(ctx.request.body);\n\n const permissionChecker = getService('permission-checker').create({ userAbility, model });\n\n if (permissionChecker.cannot.read()) {\n return ctx.forbidden();\n }\n\n const populate = await buildDeepPopulate(model as UID.CollectionType);\n\n const documents = await strapi.documents(model as UID.CollectionType).findMany({\n populate,\n filters: { documentId: { $in: documentIds } } as any,\n locale,\n sort,\n status: 'draft',\n });\n\n const results = await Promise.all(documents.map(permissionChecker.sanitizeOutput));\n\n ctx.body = { results };\n },\n\n async bulkPublish(ctx: any) {\n const { userAbility } = ctx.state;\n const { model } = ctx.params;\n const { body } = ctx.request;\n const { documentIds } = body;\n\n await validateBulkActionInput(body);\n\n const documentManager = getService('document-manager');\n const permissionChecker = getService('permission-checker').create({ userAbility, model });\n\n if (permissionChecker.cannot.publish()) {\n return ctx.forbidden();\n }\n\n const permissionQuery = await permissionChecker.sanitizedQuery.publish(ctx.query);\n const populate = await getService('populate-builder')(model)\n .populateFromQuery(permissionQuery)\n .populateDeep(Infinity)\n .countRelations()\n .build();\n\n const { locale } = await getDocumentLocaleAndStatus(body, model, {\n allowMultipleLocales: true,\n });\n\n const entities = await documentManager.findLocales(documentIds, model, {\n populate,\n locale,\n isPublished: false,\n });\n\n for (const entity of entities) {\n if (!entity) {\n return ctx.notFound();\n }\n\n if (permissionChecker.cannot.publish(entity)) {\n return ctx.forbidden();\n }\n }\n\n const count = await documentManager.publishMany(model, documentIds, locale);\n ctx.body = { count };\n },\n\n async bulkUnpublish(ctx: any) {\n const { userAbility } = ctx.state;\n const { model } = ctx.params;\n const { body } = ctx.request;\n const { documentIds } = body;\n\n await validateBulkActionInput(body);\n\n const documentManager = getService('document-manager');\n const permissionChecker = getService('permission-checker').create({ userAbility, model });\n\n if (permissionChecker.cannot.unpublish()) {\n return ctx.forbidden();\n }\n\n const { locale } = await getDocumentLocaleAndStatus(body, model, {\n allowMultipleLocales: true,\n });\n\n const entities = await documentManager.findLocales(documentIds, model, {\n locale,\n isPublished: true,\n });\n\n for (const entity of entities) {\n if (!entity) {\n return ctx.notFound();\n }\n\n if (permissionChecker.cannot.publish(entity)) {\n return ctx.forbidden();\n }\n }\n\n const entitiesIds = entities.map((document) => document.documentId);\n\n const { count } = await documentManager.unpublishMany(entitiesIds, model, { locale });\n\n ctx.body = { count };\n },\n\n async unpublish(ctx: any) {\n const { userAbility } = ctx.state;\n const { id, model } = ctx.params;\n const {\n body: { discardDraft, ...body },\n } = ctx.request;\n\n const documentManager = getService('document-manager');\n const permissionChecker = getService('permission-checker').create({ userAbility, model });\n\n if (permissionChecker.cannot.unpublish()) {\n return ctx.forbidden();\n }\n\n if (discardDraft && permissionChecker.cannot.discard()) {\n return ctx.forbidden();\n }\n\n const permissionQuery = await permissionChecker.sanitizedQuery.unpublish(ctx.query);\n\n const populate = await getService('populate-builder')(model)\n .populateFromQuery(permissionQuery)\n .build();\n\n // TODO allow multiple locales for bulk locale unpublish\n const { locale } = await getDocumentLocaleAndStatus(body, model);\n const document = await documentManager.findOne(id, model, {\n populate,\n locale,\n status: 'published',\n });\n\n if (!document) {\n throw new errors.NotFoundError();\n }\n\n if (permissionChecker.cannot.unpublish(document)) {\n throw new errors.ForbiddenError();\n }\n\n if (discardDraft && permissionChecker.cannot.discard(document)) {\n throw new errors.ForbiddenError();\n }\n\n await strapi.db.transaction(async () => {\n if (discardDraft) {\n await documentManager.discardDraft(document.documentId, model, { locale });\n }\n\n ctx.body = await async.pipe(\n (document) => documentManager.unpublish(document.documentId, model, { locale }),\n permissionChecker.sanitizeOutput,\n (document) => formatDocumentWithMetadata(permissionChecker, model, document)\n )(document);\n });\n },\n\n async discard(ctx: any) {\n const { userAbility } = ctx.state;\n const { id, model } = ctx.params;\n const { body } = ctx.request;\n\n const documentManager = getService('document-manager');\n const permissionChecker = getService('permission-checker').create({ userAbility, model });\n\n if (permissionChecker.cannot.discard()) {\n return ctx.forbidden();\n }\n\n const permissionQuery = await permissionChecker.sanitizedQuery.discard(ctx.query);\n const populate = await getService('populate-builder')(model)\n .populateFromQuery(permissionQuery)\n .build();\n\n const { locale } = await getDocumentLocaleAndStatus(body, model);\n const document = await documentManager.findOne(id, model, {\n populate,\n locale,\n status: 'published',\n });\n\n // Can not discard a document that is not published\n if (!document) {\n return ctx.notFound();\n }\n\n if (permissionChecker.cannot.discard(document)) {\n return ctx.forbidden();\n }\n\n ctx.body = await async.pipe(\n (document) => documentManager.discardDraft(document.documentId, model, { locale }),\n permissionChecker.sanitizeOutput,\n (document) => formatDocumentWithMetadata(permissionChecker, model, document)\n )(document);\n },\n\n async bulkDelete(ctx: any) {\n const { userAbility } = ctx.state;\n const { model } = ctx.params;\n const { query, body } = ctx.request;\n const { documentIds } = body;\n\n await validateBulkActionInput(body);\n\n const documentManager = getService('document-manager');\n const permissionChecker = getService('permission-checker').create({ userAbility, model });\n\n if (permissionChecker.cannot.delete()) {\n return ctx.forbidden();\n }\n\n const permissionQuery = await permissionChecker.sanitizedQuery.delete(query);\n const populate = await getService('populate-builder')(model)\n .populateFromQuery(permissionQuery)\n .build();\n\n const { locale } = await getDocumentLocaleAndStatus(body, model);\n\n const documentLocales = await documentManager.findLocales(documentIds, model, {\n populate,\n locale,\n });\n\n if (documentLocales.length === 0) {\n return ctx.notFound();\n }\n\n for (const document of documentLocales) {\n if (permissionChecker.cannot.delete(document)) {\n return ctx.forbidden();\n }\n }\n\n // We filter out documentsIds that maybe doesn't exist in a specific locale\n const localeDocumentsIds = documentLocales.map((document) => document.documentId);\n\n const { count } = await documentManager.deleteMany(localeDocumentsIds, model, { locale });\n\n ctx.body = { count };\n },\n\n async countDraftRelations(ctx: any) {\n const { userAbility } = ctx.state;\n const { model, id } = ctx.params;\n\n const documentManager = getService('document-manager');\n const permissionChecker = getService('permission-checker').create({ userAbility, model });\n\n if (permissionChecker.cannot.read()) {\n return ctx.forbidden();\n }\n\n const { locale, status } = await getDocumentLocaleAndStatus(ctx.query, model);\n\n if (permissionChecker.requiresEntity.read()) {\n // Only load what we need for access checks\n const permissionQuery = await permissionChecker.sanitizedQuery.read(ctx.query);\n\n const populate = await getService('populate-builder')(model)\n .populateFromQuery(permissionQuery)\n .build();\n\n const entity = await documentManager.findOne(id, model, {\n locale,\n status,\n populate,\n });\n\n if (!entity) {\n return ctx.notFound();\n }\n\n if (permissionChecker.cannot.read(entity)) {\n return ctx.forbidden();\n }\n }\n\n const number = await documentManager.countDraftRelations(id, model, locale);\n\n return {\n data: number,\n };\n },\n\n async countManyEntriesDraftRelations(ctx: any) {\n const { userAbility } = ctx.state;\n const ids = ctx.request.query.documentIds as string[];\n const locale = ctx.request.query.locale as string[];\n const { model } = ctx.params;\n\n const documentManager = getService('document-manager');\n const permissionChecker = getService('permission-checker').create({ userAbility, model });\n\n if (permissionChecker.cannot.read()) {\n return ctx.forbidden();\n }\n\n const count = await strapi.db.query(model).count({\n where: { documentId: ids },\n });\n\n if (count === 0) {\n return ctx.notFound();\n }\n\n const number = await documentManager.countManyEntriesDraftRelations(ids, model, locale);\n\n return {\n data: number,\n };\n },\n};\n"],"names":["getDocumentIdsByDraftPublishRelation","uid","opts","schema","strapi","getModel","contentTypes","hasDraftAndPublish","baseParams","fields","page","pageSize","locale","drafts","published","Promise","all","documents","findMany","status","publishedByKey","Map","p","key","documentId","String","set","updatedAt","ids","wantModified","type","d","pub","get","dUpdated","Date","getTime","pUpdated","isModified","push","Set","STATUS_QUERY_FROM_FILTER","draft","hasPublishedVersion","publicationStatusFilter","normalizeStatusFromFilters","query","filters","$and","Array","isArray","remainingFilters","statusValues","filter","eq","__status","$eq","length","q","value","toApply","Object","assign","mergeDocumentIdFilter","existingFilters","documentIds","documentIdFilter","$in","existingAnd","keys","createDocument","ctx","userAbility","user","state","model","params","body","request","documentManager","getService","permissionChecker","create","cannot","errors","ForbiddenError","pickPermittedFields","sanitizeCreateInput","setCreator","setCreatorFields","sanitizeFn","async","pipe","sanitizedBody","getDocumentLocaleAndStatus","data","populate","updateDocument","id","update","permissionQuery","sanitizedQuery","populateFromQuery","build","documentVersion","documentExists","findOne","exists","NotFoundError","sanitizeUpdateInput","isEdition","updatedDocument","find","documentMetadata","read","forbidden","populateDeep","countRelations","toOne","toMany","withPopulateOverride","getPopulateForLocalizations","queryForValidation","paramsForDocumentService","omit","findPageParams","undefined","results","pagination","findPage","statusByDocumentId","indexByDocumentId","getManyAvailableStatus","setStatus","document","availableStatuses","getStatus","map","sanitizeOutput","Infinity","version","notFound","meta","formatDocumentWithMetadata","publishedAt","availableLocales","availableStatus","sanitizedDocument","totalEntries","db","count","telemetry","send","eventProperties","updatedVersion","sanitizedVersion","clone","sourceId","excludeNotCreatable","excludeNotCreatableFields","clonedDocument","autoClone","prohibitedFields","getProhibitedCloningFields","badRequest","delete","documentLocales","findLocales","result","publish","publishedDocument","transaction","isCreate","isNil","isUpdate","can","publishResult","bulkFindForValidation","sort","validateBulkActionInput","buildDeepPopulate","bulkPublish","allowMultipleLocales","entities","isPublished","entity","publishMany","bulkUnpublish","unpublish","entitiesIds","unpublishMany","discardDraft","discard","bulkDelete","localeDocumentsIds","deleteMany","countDraftRelations","requiresEntity","number","countManyEntriesDraftRelations","where"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"collection-types.mjs","sources":["../../../server/src/controllers/collection-types.ts"],"sourcesContent":["import { isNil, omit } from 'lodash/fp';\n\nimport { setCreatorFields, async, contentTypes, errors } from '@strapi/utils';\nimport type { Modules, UID } from '@strapi/types';\n\nimport { getService } from '../utils';\nimport { validateBulkActionInput } from './validation';\nimport { getProhibitedCloningFields, excludeNotCreatableFields } from './utils/clone';\nimport { getDocumentLocaleAndStatus } from './validation/dimensions';\nimport { formatDocumentWithMetadata } from './utils/metadata';\nimport { indexByDocumentId } from './utils/document-status';\nimport { getPopulateForLocalizations, buildDeepPopulate } from '../services/utils/populate';\n\n/**\n * Returns documentIds for (documentId, locale) that have both draft and published,\n * optionally filtered by whether the draft is newer than the published row.\n * Uses strapi.documents only.\n */\nconst getDocumentIdsByDraftPublishRelation = async (\n uid: UID.ContentType,\n opts: {\n locale?: string | string[] | null;\n type: 'modified' | 'unmodified';\n }\n): Promise<string[]> => {\n const schema = strapi.getModel(uid);\n if (!contentTypes.hasDraftAndPublish(schema)) {\n return [];\n }\n\n const baseParams = {\n fields: ['documentId', 'locale', 'updatedAt'],\n page: 1,\n pageSize: 10000,\n ...(opts.locale != null &&\n opts.locale !== '*' && {\n locale: opts.locale as string,\n }),\n };\n\n const [drafts, published] = await Promise.all([\n strapi.documents(uid).findMany({ ...baseParams, status: 'draft' }),\n strapi.documents(uid).findMany({ ...baseParams, status: 'published' }),\n ]);\n\n const publishedByKey = new Map<string, { updatedAt: string }>();\n for (const p of published) {\n const key = `${p.documentId}\\t${String(p?.locale ?? '')}`;\n publishedByKey.set(key, { updatedAt: p.updatedAt as string });\n }\n\n const ids: string[] = [];\n const wantModified = opts.type === 'modified';\n for (const d of drafts) {\n const key = `${d.documentId}\\t${String(d?.locale ?? '')}`;\n const pub = publishedByKey.get(key);\n if (pub) {\n const dUpdated = d?.updatedAt ? new Date(d.updatedAt as string).getTime() : 0;\n const pUpdated = pub?.updatedAt ? new Date(pub.updatedAt).getTime() : 0;\n const isModified = dUpdated > pUpdated;\n if (isModified === wantModified) {\n ids.push(d.documentId as string);\n }\n }\n }\n return [...new Set(ids)];\n};\n\n/** Map from __status filter value to top-level query fields (mirrors client STATUS_PARAMS). */\nconst STATUS_QUERY_FROM_FILTER: Record<string, Record<string, string>> = {\n draft: { status: 'draft', hasPublishedVersion: 'false' },\n published: { status: 'published' },\n 'published-modified': { publicationStatusFilter: 'published-modified' },\n 'published-unmodified': { publicationStatusFilter: 'published-unmodified' },\n};\n\n/**\n * Extracts __status from query.filters.$and into top-level status, hasPublishedVersion,\n * and publicationStatusFilter so list works with either transformed params or raw filter params.\n */\nconst normalizeStatusFromFilters = (query: Record<string, unknown>): void => {\n const filters = query.filters as Record<string, unknown> | undefined;\n if (!filters?.$and || !Array.isArray(filters.$and)) return;\n\n const remainingFilters: unknown[] = [];\n const statusValues: string[] = [];\n\n for (const filter of filters.$and as Record<string, unknown>[]) {\n const eq = (filter?.__status as Record<string, unknown>)?.$eq;\n if (eq != null) {\n statusValues.push(String(eq));\n } else {\n remainingFilters.push(filter);\n }\n }\n\n if (statusValues.length === 0) return;\n\n const q = query as Record<string, unknown>;\n for (const value of statusValues) {\n const toApply = STATUS_QUERY_FROM_FILTER[value];\n if (toApply) Object.assign(q, toApply);\n }\n\n if (remainingFilters.length > 0) {\n (filters as Record<string, unknown>).$and = remainingFilters;\n } else {\n delete q.filters;\n }\n};\n\n/** Returns filters object that merges existing $and with a documentId $in filter. */\nconst mergeDocumentIdFilter = (\n existingFilters: Record<string, unknown> | undefined,\n documentIds: string[]\n): Record<string, unknown> => {\n const documentIdFilter = {\n documentId: documentIds.length > 0 ? { $in: documentIds } : { $in: [] },\n };\n let existingAnd: unknown[];\n if (existingFilters?.$and && Array.isArray(existingFilters.$and)) {\n existingAnd = existingFilters.$and;\n } else if (existingFilters && Object.keys(existingFilters).length > 0) {\n existingAnd = [existingFilters];\n } else {\n existingAnd = [];\n }\n return { $and: [...existingAnd, documentIdFilter] };\n};\n\ntype Options = Modules.Documents.Params.Pick<UID.ContentType, 'populate:object'>;\n\n/**\n * Extracts the sort direction for the 'status' field from a sort parameter.\n * Returns 'ASC', 'DESC', or null if status is not being sorted.\n *\n * The sort param can be a string ('status:ASC'), an array (['status:ASC']),\n * or an object ({ status: 'ASC' }).\n */\nconst extractStatusSortOrder = (sort: unknown): 'ASC' | 'DESC' | null => {\n if (!sort) return null;\n\n if (typeof sort === 'string') {\n const match = sort.match(/(?:^|,)\\s*status:(ASC|DESC)\\s*(?:,|$)/i);\n return match ? (match[1].toUpperCase() as 'ASC' | 'DESC') : null;\n }\n\n if (Array.isArray(sort)) {\n for (const item of sort) {\n const result = extractStatusSortOrder(item);\n if (result) return result;\n }\n return null;\n }\n\n if (typeof sort === 'object' && sort !== null && 'status' in sort) {\n const dir = String((sort as Record<string, unknown>).status).toUpperCase();\n return dir === 'ASC' || dir === 'DESC' ? dir : null;\n }\n\n return null;\n};\n\n/**\n * Removes the 'status' field from a sort parameter, returning the remainder\n * (or undefined if status was the only sort field).\n */\nconst removeStatusFromSort = (sort: unknown): unknown => {\n if (!sort) return sort;\n\n if (typeof sort === 'string') {\n const cleaned = sort\n .split(',')\n .map((s) => s.trim())\n .filter((s) => !/^status:(ASC|DESC)$/i.test(s))\n .join(',');\n return cleaned || undefined;\n }\n\n if (Array.isArray(sort)) {\n const cleaned = sort.filter((item) => extractStatusSortOrder(item) === null);\n return cleaned.length ? cleaned : undefined;\n }\n\n if (typeof sort === 'object' && sort !== null) {\n const { status: _removed, ...rest } = sort as Record<string, unknown>;\n return Object.keys(rest).length ? rest : undefined;\n }\n\n return sort;\n};\n\n/**\n * Create a new document.\n *\n * @param ctx - Koa context\n * @param opts - Options\n * @param opts.populate - Populate options of the returned document.\n * By default documentManager will populate all relations.\n */\nconst createDocument = async (ctx: any, opts?: Options) => {\n const { userAbility, user } = ctx.state;\n const { model } = ctx.params;\n const { body } = ctx.request;\n\n const documentManager = getService('document-manager');\n const permissionChecker = getService('permission-checker').create({ userAbility, model });\n\n if (permissionChecker.cannot.create()) {\n throw new errors.ForbiddenError();\n }\n\n const pickPermittedFields = permissionChecker.sanitizeCreateInput;\n const setCreator = setCreatorFields({ user });\n const sanitizeFn = async.pipe(pickPermittedFields, setCreator as any);\n const sanitizedBody = await sanitizeFn(body);\n\n const { locale, status } = await getDocumentLocaleAndStatus(body, model);\n\n return documentManager.create(model, {\n data: sanitizedBody as any,\n locale,\n status,\n populate: opts?.populate,\n });\n\n // TODO: Revert the creation if create permission conditions are not met\n // if (permissionChecker.cannot.create(document)) {\n // throw new errors.ForbiddenError();\n // }\n};\n\n/**\n * Update a document version.\n * - If the document version exists, it will be updated.\n * - If the document version does not exist, a new document locale will be created.\n * By default documentManager will populate all relations.\n *\n * @param ctx - Koa context\n * @param opts - Options\n * @param opts.populate - Populate options of the returned document\n */\nconst updateDocument = async (ctx: any, opts?: Options) => {\n const { userAbility, user } = ctx.state;\n const { id, model } = ctx.params;\n const { body } = ctx.request;\n\n const documentManager = getService('document-manager');\n const permissionChecker = getService('permission-checker').create({ userAbility, model });\n\n if (permissionChecker.cannot.update()) {\n throw new errors.ForbiddenError();\n }\n\n // Populate necessary fields to check permissions\n const permissionQuery = await permissionChecker.sanitizedQuery.update(ctx.query);\n const populate = await getService('populate-builder')(model)\n .populateFromQuery(permissionQuery)\n .build();\n\n const { locale } = await getDocumentLocaleAndStatus(body, model);\n\n // Load document version to update\n const [documentVersion, documentExists] = await Promise.all([\n documentManager.findOne(id, model, { populate, locale, status: 'draft' }),\n documentManager.exists(model, id),\n ]);\n\n if (!documentExists) {\n throw new errors.NotFoundError();\n }\n\n // If version is not found, but document exists,\n // the intent is to create a new document locale\n if (documentVersion) {\n if (permissionChecker.cannot.update(documentVersion)) {\n throw new errors.ForbiddenError();\n }\n } else if (permissionChecker.cannot.create()) {\n throw new errors.ForbiddenError();\n }\n\n const pickPermittedFields = documentVersion\n ? permissionChecker.sanitizeUpdateInput(documentVersion)\n : permissionChecker.sanitizeCreateInput;\n const setCreator = documentVersion\n ? setCreatorFields({ user, isEdition: true })\n : setCreatorFields({ user });\n const sanitizeFn = async.pipe(pickPermittedFields, setCreator as any);\n const sanitizedBody = await sanitizeFn(body);\n\n const updatedDocument = await documentManager.update(documentVersion?.documentId || id, model, {\n data: sanitizedBody as any,\n populate: opts?.populate,\n locale,\n });\n\n return updatedDocument;\n};\n\nexport default {\n async find(ctx: any) {\n const { userAbility } = ctx.state;\n const { model } = ctx.params;\n const { query } = ctx.request;\n\n // Normalize so status/publicationStatusFilter are set from filters.$and.__status when present\n normalizeStatusFromFilters(query as Record<string, unknown>);\n\n const documentMetadata = getService('document-metadata');\n const documentManager = getService('document-manager');\n const permissionChecker = getService('permission-checker').create({ userAbility, model });\n\n if (permissionChecker.cannot.read()) {\n return ctx.forbidden();\n }\n\n // Extract and remove 'status' sort before sanitization/validation, since status\n // is not a real schema attribute and would be rejected by the permission checker.\n // It is re-added after sanitization so the DB layer can handle it via a CASE expression.\n const hasPublicationStatusFilter =\n query.status !== undefined ||\n query.hasPublishedVersion !== undefined ||\n query.publicationStatusFilter !== undefined;\n const rawStatusSortOrder = extractStatusSortOrder(query.sort);\n // Disable status sort when a publication status filter is active — all results share the\n // same status, making the sort a no-op.\n const statusSortOrder = hasPublicationStatusFilter ? null : rawStatusSortOrder;\n // Always strip 'status' from the sort before passing to the document service / permission\n // checker — it is not a real schema attribute and would be rejected by validation.\n const queryWithoutStatusSort = rawStatusSortOrder\n ? { ...query, sort: removeStatusFromSort(query.sort) }\n : query;\n\n const permissionQuery = await permissionChecker.sanitizedQuery.read(queryWithoutStatusSort);\n\n const populate = await getService('populate-builder')(model)\n .populateFromQuery(permissionQuery)\n .populateDeep(1)\n .countRelations({ toOne: false, toMany: true })\n .withPopulateOverride(getPopulateForLocalizations(model))\n .build();\n\n // \"Modified\" is a UI-only filter; not a real document status. Read and strip it\n // so we never pass it to validation or the document service.\n const publicationStatusFilter = query.publicationStatusFilter;\n const queryForValidation = { ...query };\n delete queryForValidation.publicationStatusFilter;\n\n const { locale, status } = await getDocumentLocaleAndStatus(queryForValidation, model);\n\n const paramsForDocumentService = omit(['publicationStatusFilter'], permissionQuery) as Record<\n string,\n unknown\n >;\n let findPageParams: Record<string, unknown> = {\n ...paramsForDocumentService,\n populate,\n locale,\n status,\n };\n\n // Pass through hasPublishedVersion so \"Draft\" filter returns only drafts with no published version\n if (query.hasPublishedVersion !== undefined) {\n findPageParams.hasPublishedVersion = query.hasPublishedVersion;\n }\n\n if (\n publicationStatusFilter === 'published-modified' ||\n publicationStatusFilter === 'published-unmodified'\n ) {\n const type = publicationStatusFilter === 'published-modified' ? 'modified' : 'unmodified';\n const documentIds = await getDocumentIdsByDraftPublishRelation(model, { locale, type });\n findPageParams = {\n ...findPageParams,\n status: 'published',\n filters: mergeDocumentIdFilter(\n paramsForDocumentService.filters as Record<string, unknown> | undefined,\n documentIds\n ),\n };\n }\n\n if (statusSortOrder) {\n const s = findPageParams.sort;\n const statusSort = `status:${statusSortOrder}`;\n if (!s) {\n findPageParams.sort = statusSort;\n } else if (Array.isArray(s)) {\n findPageParams.sort = [...s, statusSort];\n } else if (typeof s === 'string') {\n findPageParams.sort = `${s},${statusSort}`;\n } else {\n findPageParams.sort = { ...(s as object), status: statusSortOrder };\n }\n }\n\n const { results: documents, pagination } = await documentManager.findPage(\n findPageParams as Parameters<typeof documentManager.findPage>[0],\n model\n );\n\n const hasDraftAndPublish = contentTypes.hasDraftAndPublish(strapi.getModel(model));\n\n const statusByDocumentId = hasDraftAndPublish\n ? indexByDocumentId(await documentMetadata.getManyAvailableStatus(model, documents))\n : new Map();\n\n const setStatus = (document: any) => {\n // Available status of document\n const availableStatuses = statusByDocumentId.get(document.documentId) || [];\n // Compute document version status\n document.status = documentMetadata.getStatus(document, availableStatuses);\n return document;\n };\n\n const results = await async.map(\n documents,\n async.pipe(permissionChecker.sanitizeOutput, setStatus)\n );\n\n ctx.body = {\n results,\n pagination,\n };\n },\n\n async findOne(ctx: any) {\n const { userAbility } = ctx.state;\n const { model, id } = ctx.params;\n\n const documentManager = getService('document-manager');\n const permissionChecker = getService('permission-checker').create({ userAbility, model });\n\n if (permissionChecker.cannot.read()) {\n return ctx.forbidden();\n }\n\n const permissionQuery = await permissionChecker.sanitizedQuery.read(ctx.query);\n\n const populate = await getService('populate-builder')(model)\n .populateFromQuery(permissionQuery)\n .populateDeep(Infinity)\n .countRelations()\n .withPopulateOverride(getPopulateForLocalizations(model))\n .build();\n\n const { locale, status } = await getDocumentLocaleAndStatus(ctx.query, model);\n\n const version = await documentManager.findOne(id, model, {\n populate,\n locale,\n status,\n });\n\n if (!version) {\n // Check if document exists\n const exists = await documentManager.exists(model, id);\n if (!exists) {\n return ctx.notFound();\n }\n\n // If the requested locale doesn't exist, return an empty response\n const { meta } = await formatDocumentWithMetadata(\n permissionChecker,\n model,\n // @ts-expect-error TODO: fix\n { documentId: id, locale, publishedAt: null },\n { availableLocales: true, availableStatus: false }\n );\n\n ctx.body = { data: {}, meta };\n\n return;\n }\n\n // if the user has condition that needs populated content, it's not applied because entity don't have relations populated\n if (permissionChecker.cannot.read(version)) {\n return ctx.forbidden();\n }\n\n // TODO: Count populated relations by permissions\n const sanitizedDocument = await permissionChecker.sanitizeOutput(version);\n ctx.body = await formatDocumentWithMetadata(permissionChecker, model, sanitizedDocument);\n },\n\n async create(ctx: any) {\n const { userAbility } = ctx.state;\n const { model } = ctx.params;\n\n const permissionChecker = getService('permission-checker').create({ userAbility, model });\n\n const [totalEntries, document] = await Promise.all([\n strapi.db.query(model).count(),\n createDocument(ctx),\n ]);\n\n const sanitizedDocument = await permissionChecker.sanitizeOutput(document);\n ctx.status = 201;\n ctx.body = await formatDocumentWithMetadata(permissionChecker, model, sanitizedDocument, {\n // Empty metadata as it's not relevant for a new document\n availableLocales: false,\n availableStatus: false,\n });\n\n if (totalEntries === 0) {\n strapi.telemetry.send('didCreateFirstContentTypeEntry', {\n eventProperties: { model },\n });\n }\n },\n\n async update(ctx: any) {\n const { userAbility } = ctx.state;\n const { model } = ctx.params;\n\n const permissionChecker = getService('permission-checker').create({ userAbility, model });\n\n const updatedVersion = await updateDocument(ctx);\n\n const sanitizedVersion = await permissionChecker.sanitizeOutput(updatedVersion);\n ctx.body = await formatDocumentWithMetadata(permissionChecker, model, sanitizedVersion);\n },\n\n async clone(ctx: any) {\n const { userAbility, user } = ctx.state;\n const { model, sourceId: id } = ctx.params;\n const { body } = ctx.request;\n\n const documentManager = getService('document-manager');\n const permissionChecker = getService('permission-checker').create({ userAbility, model });\n\n if (permissionChecker.cannot.create()) {\n return ctx.forbidden();\n }\n\n const permissionQuery = await permissionChecker.sanitizedQuery.create(ctx.query);\n const populate = await getService('populate-builder')(model)\n .populateFromQuery(permissionQuery)\n .build();\n\n const { locale } = await getDocumentLocaleAndStatus(body, model);\n const document = await documentManager.findOne(id, model, {\n populate,\n locale,\n status: 'draft',\n });\n\n if (!document) {\n return ctx.notFound();\n }\n\n const pickPermittedFields = permissionChecker.sanitizeCreateInput;\n const setCreator = setCreatorFields({ user });\n const excludeNotCreatable = excludeNotCreatableFields(model, permissionChecker);\n const sanitizeFn = async.pipe(pickPermittedFields, setCreator as any, excludeNotCreatable);\n const sanitizedBody = await sanitizeFn(body);\n\n const clonedDocument = await documentManager.clone(document.documentId, sanitizedBody, model);\n\n const sanitizedDocument = await permissionChecker.sanitizeOutput(clonedDocument);\n ctx.body = await formatDocumentWithMetadata(permissionChecker, model, sanitizedDocument, {\n // Empty metadata as it's not relevant for a new document\n availableLocales: false,\n availableStatus: false,\n });\n },\n\n async autoClone(ctx: any) {\n const { model } = ctx.params;\n\n // Check if the model has fields that prevent auto cloning\n const prohibitedFields = getProhibitedCloningFields(model);\n\n if (prohibitedFields.length > 0) {\n return ctx.badRequest(\n 'Entity could not be cloned as it has unique and/or relational fields. ' +\n 'Please edit those fields manually and save to complete the cloning.',\n {\n prohibitedFields,\n }\n );\n }\n\n await this.clone(ctx);\n },\n\n async delete(ctx: any) {\n const { userAbility } = ctx.state;\n const { id, model } = ctx.params;\n\n const documentManager = getService('document-manager');\n const permissionChecker = getService('permission-checker').create({ userAbility, model });\n\n if (permissionChecker.cannot.delete()) {\n return ctx.forbidden();\n }\n\n const permissionQuery = await permissionChecker.sanitizedQuery.delete(ctx.query);\n const populate = await getService('populate-builder')(model)\n .populateFromQuery(permissionQuery)\n .build();\n\n const { locale } = await getDocumentLocaleAndStatus(ctx.query, model);\n\n // Find locales to delete\n const documentLocales = await documentManager.findLocales(id, model, { populate, locale });\n\n if (documentLocales.length === 0) {\n return ctx.notFound();\n }\n\n for (const document of documentLocales) {\n if (permissionChecker.cannot.delete(document)) {\n return ctx.forbidden();\n }\n }\n\n const result = await documentManager.delete(id, model, { locale });\n\n ctx.body = await permissionChecker.sanitizeOutput(result);\n },\n\n /**\n * Publish a document version.\n * Supports creating/saving a document and publishing it in one request.\n */\n async publish(ctx: any) {\n const { userAbility } = ctx.state;\n // If id does not exist, the document has to be created\n const { id, model } = ctx.params;\n const { body } = ctx.request;\n\n const documentManager = getService('document-manager');\n const permissionChecker = getService('permission-checker').create({ userAbility, model });\n\n if (permissionChecker.cannot.publish()) {\n return ctx.forbidden();\n }\n\n const publishedDocument = await strapi.db.transaction(async () => {\n // Create or update document\n const permissionQuery = await permissionChecker.sanitizedQuery.publish(ctx.query);\n\n const populate = await getService('populate-builder')(model)\n .populateFromQuery(permissionQuery)\n .populateDeep(Infinity)\n .countRelations()\n .withPopulateOverride(getPopulateForLocalizations(model))\n .build();\n\n let document: any;\n\n const { locale } = await getDocumentLocaleAndStatus(body, model);\n\n /**\n * Publish can be called on two scenarios:\n * 1. Create a new document and publish it in one request\n * 2. Update an existing document and publish it in one request\n *\n * Based on user permissions:\n * 1. User cannot create a document, but can publish\n * Action will be forbidden as user cannot create a document\n * 2. User can update and publish a document\n * Action will be allowed, but document will not be updated, only published with the latest draft\n */\n const isCreate = isNil(id);\n if (isCreate) {\n if (permissionChecker.cannot.create()) {\n throw new errors.ForbiddenError();\n }\n\n document = await createDocument(ctx, { populate });\n }\n\n const isUpdate = !isCreate;\n if (isUpdate) {\n // check if the document exists\n const documentExists = await documentManager.exists(model, id);\n\n if (!documentExists) {\n throw new errors.NotFoundError('Document not found');\n }\n\n // check the document version\n document = await documentManager.findOne(id!, model, { populate, locale });\n\n if (!document) {\n // update and publish the new version\n if (\n permissionChecker.cannot.create({ locale }) ||\n permissionChecker.cannot.publish({ locale })\n ) {\n throw new errors.ForbiddenError();\n }\n document = await updateDocument(ctx);\n } else if (permissionChecker.can.update(document)) {\n await updateDocument(ctx);\n }\n }\n\n if (permissionChecker.cannot.publish(document)) {\n throw new errors.ForbiddenError();\n }\n\n const publishResult = await documentManager.publish(document.documentId, model, {\n locale,\n // TODO: Allow setting creator fields on publish\n // data: setCreatorFields({ user, isEdition: true })({}),\n });\n\n if (!publishResult || publishResult.length === 0) {\n throw new errors.NotFoundError('Document not found or already published.');\n }\n\n return publishResult[0];\n });\n\n const sanitizedDocument = await permissionChecker.sanitizeOutput(publishedDocument);\n ctx.body = await formatDocumentWithMetadata(permissionChecker, model, sanitizedDocument);\n },\n\n async bulkFindForValidation(ctx: any) {\n const { userAbility } = ctx.state;\n const { model } = ctx.params;\n const { documentIds, locale, sort } = ctx.request.body;\n\n await validateBulkActionInput(ctx.request.body);\n\n const permissionChecker = getService('permission-checker').create({ userAbility, model });\n\n if (permissionChecker.cannot.read()) {\n return ctx.forbidden();\n }\n\n const populate = await buildDeepPopulate(model as UID.CollectionType);\n\n const documents = await strapi.documents(model as UID.CollectionType).findMany({\n populate,\n filters: { documentId: { $in: documentIds } } as any,\n locale,\n sort,\n status: 'draft',\n });\n\n const results = await Promise.all(documents.map(permissionChecker.sanitizeOutput));\n\n ctx.body = { results };\n },\n\n async bulkPublish(ctx: any) {\n const { userAbility } = ctx.state;\n const { model } = ctx.params;\n const { body } = ctx.request;\n const { documentIds } = body;\n\n await validateBulkActionInput(body);\n\n const documentManager = getService('document-manager');\n const permissionChecker = getService('permission-checker').create({ userAbility, model });\n\n if (permissionChecker.cannot.publish()) {\n return ctx.forbidden();\n }\n\n const permissionQuery = await permissionChecker.sanitizedQuery.publish(ctx.query);\n const populate = await getService('populate-builder')(model)\n .populateFromQuery(permissionQuery)\n .populateDeep(Infinity)\n .countRelations()\n .build();\n\n const { locale } = await getDocumentLocaleAndStatus(body, model, {\n allowMultipleLocales: true,\n });\n\n const entities = await documentManager.findLocales(documentIds, model, {\n populate,\n locale,\n isPublished: false,\n });\n\n for (const entity of entities) {\n if (!entity) {\n return ctx.notFound();\n }\n\n if (permissionChecker.cannot.publish(entity)) {\n return ctx.forbidden();\n }\n }\n\n const count = await documentManager.publishMany(model, documentIds, locale);\n ctx.body = { count };\n },\n\n async bulkUnpublish(ctx: any) {\n const { userAbility } = ctx.state;\n const { model } = ctx.params;\n const { body } = ctx.request;\n const { documentIds } = body;\n\n await validateBulkActionInput(body);\n\n const documentManager = getService('document-manager');\n const permissionChecker = getService('permission-checker').create({ userAbility, model });\n\n if (permissionChecker.cannot.unpublish()) {\n return ctx.forbidden();\n }\n\n const { locale } = await getDocumentLocaleAndStatus(body, model, {\n allowMultipleLocales: true,\n });\n\n const entities = await documentManager.findLocales(documentIds, model, {\n locale,\n isPublished: true,\n });\n\n for (const entity of entities) {\n if (!entity) {\n return ctx.notFound();\n }\n\n if (permissionChecker.cannot.publish(entity)) {\n return ctx.forbidden();\n }\n }\n\n const entitiesIds = entities.map((document) => document.documentId);\n\n const { count } = await documentManager.unpublishMany(entitiesIds, model, { locale });\n\n ctx.body = { count };\n },\n\n async unpublish(ctx: any) {\n const { userAbility } = ctx.state;\n const { id, model } = ctx.params;\n const {\n body: { discardDraft, ...body },\n } = ctx.request;\n\n const documentManager = getService('document-manager');\n const permissionChecker = getService('permission-checker').create({ userAbility, model });\n\n if (permissionChecker.cannot.unpublish()) {\n return ctx.forbidden();\n }\n\n if (discardDraft && permissionChecker.cannot.discard()) {\n return ctx.forbidden();\n }\n\n const permissionQuery = await permissionChecker.sanitizedQuery.unpublish(ctx.query);\n\n const populate = await getService('populate-builder')(model)\n .populateFromQuery(permissionQuery)\n .build();\n\n // TODO allow multiple locales for bulk locale unpublish\n const { locale } = await getDocumentLocaleAndStatus(body, model);\n const document = await documentManager.findOne(id, model, {\n populate,\n locale,\n status: 'published',\n });\n\n if (!document) {\n throw new errors.NotFoundError();\n }\n\n if (permissionChecker.cannot.unpublish(document)) {\n throw new errors.ForbiddenError();\n }\n\n if (discardDraft && permissionChecker.cannot.discard(document)) {\n throw new errors.ForbiddenError();\n }\n\n await strapi.db.transaction(async () => {\n if (discardDraft) {\n await documentManager.discardDraft(document.documentId, model, { locale });\n }\n\n ctx.body = await async.pipe(\n (document) => documentManager.unpublish(document.documentId, model, { locale }),\n permissionChecker.sanitizeOutput,\n (document) => formatDocumentWithMetadata(permissionChecker, model, document)\n )(document);\n });\n },\n\n async discard(ctx: any) {\n const { userAbility } = ctx.state;\n const { id, model } = ctx.params;\n const { body } = ctx.request;\n\n const documentManager = getService('document-manager');\n const permissionChecker = getService('permission-checker').create({ userAbility, model });\n\n if (permissionChecker.cannot.discard()) {\n return ctx.forbidden();\n }\n\n const permissionQuery = await permissionChecker.sanitizedQuery.discard(ctx.query);\n const populate = await getService('populate-builder')(model)\n .populateFromQuery(permissionQuery)\n .build();\n\n const { locale } = await getDocumentLocaleAndStatus(body, model);\n const document = await documentManager.findOne(id, model, {\n populate,\n locale,\n status: 'published',\n });\n\n // Can not discard a document that is not published\n if (!document) {\n return ctx.notFound();\n }\n\n if (permissionChecker.cannot.discard(document)) {\n return ctx.forbidden();\n }\n\n ctx.body = await async.pipe(\n (document) => documentManager.discardDraft(document.documentId, model, { locale }),\n permissionChecker.sanitizeOutput,\n (document) => formatDocumentWithMetadata(permissionChecker, model, document)\n )(document);\n },\n\n async bulkDelete(ctx: any) {\n const { userAbility } = ctx.state;\n const { model } = ctx.params;\n const { query, body } = ctx.request;\n const { documentIds } = body;\n\n await validateBulkActionInput(body);\n\n const documentManager = getService('document-manager');\n const permissionChecker = getService('permission-checker').create({ userAbility, model });\n\n if (permissionChecker.cannot.delete()) {\n return ctx.forbidden();\n }\n\n const permissionQuery = await permissionChecker.sanitizedQuery.delete(query);\n const populate = await getService('populate-builder')(model)\n .populateFromQuery(permissionQuery)\n .build();\n\n const { locale } = await getDocumentLocaleAndStatus(body, model);\n\n const documentLocales = await documentManager.findLocales(documentIds, model, {\n populate,\n locale,\n });\n\n if (documentLocales.length === 0) {\n return ctx.notFound();\n }\n\n for (const document of documentLocales) {\n if (permissionChecker.cannot.delete(document)) {\n return ctx.forbidden();\n }\n }\n\n // We filter out documentsIds that maybe doesn't exist in a specific locale\n const localeDocumentsIds = documentLocales.map((document) => document.documentId);\n\n const { count } = await documentManager.deleteMany(localeDocumentsIds, model, { locale });\n\n ctx.body = { count };\n },\n\n async countDraftRelations(ctx: any) {\n const { userAbility } = ctx.state;\n const { model, id } = ctx.params;\n\n const documentManager = getService('document-manager');\n const permissionChecker = getService('permission-checker').create({ userAbility, model });\n\n if (permissionChecker.cannot.read()) {\n return ctx.forbidden();\n }\n\n const { locale, status } = await getDocumentLocaleAndStatus(ctx.query, model);\n\n if (permissionChecker.requiresEntity.read()) {\n // Only load what we need for access checks\n const permissionQuery = await permissionChecker.sanitizedQuery.read(ctx.query);\n\n const populate = await getService('populate-builder')(model)\n .populateFromQuery(permissionQuery)\n .build();\n\n const entity = await documentManager.findOne(id, model, {\n locale,\n status,\n populate,\n });\n\n if (!entity) {\n return ctx.notFound();\n }\n\n if (permissionChecker.cannot.read(entity)) {\n return ctx.forbidden();\n }\n }\n\n const number = await documentManager.countDraftRelations(id, model, locale);\n\n return {\n data: number,\n };\n },\n\n async countManyEntriesDraftRelations(ctx: any) {\n const { userAbility } = ctx.state;\n const ids = ctx.request.query.documentIds as string[];\n const locale = ctx.request.query.locale as string[];\n const { model } = ctx.params;\n\n const documentManager = getService('document-manager');\n const permissionChecker = getService('permission-checker').create({ userAbility, model });\n\n if (permissionChecker.cannot.read()) {\n return ctx.forbidden();\n }\n\n const count = await strapi.db.query(model).count({\n where: { documentId: ids },\n });\n\n if (count === 0) {\n return ctx.notFound();\n }\n\n const number = await documentManager.countManyEntriesDraftRelations(ids, model, locale);\n\n return {\n data: number,\n };\n },\n};\n"],"names":["getDocumentIdsByDraftPublishRelation","uid","opts","schema","strapi","getModel","contentTypes","hasDraftAndPublish","baseParams","fields","page","pageSize","locale","drafts","published","Promise","all","documents","findMany","status","publishedByKey","Map","p","key","documentId","String","set","updatedAt","ids","wantModified","type","d","pub","get","dUpdated","Date","getTime","pUpdated","isModified","push","Set","STATUS_QUERY_FROM_FILTER","draft","hasPublishedVersion","publicationStatusFilter","normalizeStatusFromFilters","query","filters","$and","Array","isArray","remainingFilters","statusValues","filter","eq","__status","$eq","length","q","value","toApply","Object","assign","mergeDocumentIdFilter","existingFilters","documentIds","documentIdFilter","$in","existingAnd","keys","extractStatusSortOrder","sort","match","toUpperCase","item","result","dir","removeStatusFromSort","cleaned","split","map","s","trim","test","join","undefined","_removed","rest","createDocument","ctx","userAbility","user","state","model","params","body","request","documentManager","getService","permissionChecker","create","cannot","errors","ForbiddenError","pickPermittedFields","sanitizeCreateInput","setCreator","setCreatorFields","sanitizeFn","async","pipe","sanitizedBody","getDocumentLocaleAndStatus","data","populate","updateDocument","id","update","permissionQuery","sanitizedQuery","populateFromQuery","build","documentVersion","documentExists","findOne","exists","NotFoundError","sanitizeUpdateInput","isEdition","updatedDocument","find","documentMetadata","read","forbidden","hasPublicationStatusFilter","rawStatusSortOrder","statusSortOrder","queryWithoutStatusSort","populateDeep","countRelations","toOne","toMany","withPopulateOverride","getPopulateForLocalizations","queryForValidation","paramsForDocumentService","omit","findPageParams","statusSort","results","pagination","findPage","statusByDocumentId","indexByDocumentId","getManyAvailableStatus","setStatus","document","availableStatuses","getStatus","sanitizeOutput","Infinity","version","notFound","meta","formatDocumentWithMetadata","publishedAt","availableLocales","availableStatus","sanitizedDocument","totalEntries","db","count","telemetry","send","eventProperties","updatedVersion","sanitizedVersion","clone","sourceId","excludeNotCreatable","excludeNotCreatableFields","clonedDocument","autoClone","prohibitedFields","getProhibitedCloningFields","badRequest","delete","documentLocales","findLocales","publish","publishedDocument","transaction","isCreate","isNil","isUpdate","can","publishResult","bulkFindForValidation","validateBulkActionInput","buildDeepPopulate","bulkPublish","allowMultipleLocales","entities","isPublished","entity","publishMany","bulkUnpublish","unpublish","entitiesIds","unpublishMany","discardDraft","discard","bulkDelete","localeDocumentsIds","deleteMany","countDraftRelations","requiresEntity","number","countManyEntriesDraftRelations","where"],"mappings":"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"}
|
|
@@ -1,13 +1,19 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
3
|
var strapiUtils = require('@strapi/utils');
|
|
4
|
+
var zod = require('../../validation/zod.js');
|
|
4
5
|
|
|
5
|
-
const singleLocaleSchema = strapiUtils.
|
|
6
|
-
const multipleLocaleSchema = strapiUtils.
|
|
7
|
-
|
|
6
|
+
const singleLocaleSchema = strapiUtils.z.string().nullable().optional();
|
|
7
|
+
const multipleLocaleSchema = strapiUtils.z.union([
|
|
8
|
+
strapiUtils.z.array(strapiUtils.z.string()),
|
|
9
|
+
strapiUtils.z.string().nullable()
|
|
10
|
+
]).optional();
|
|
11
|
+
const statusSchema = strapiUtils.z.enum([
|
|
8
12
|
'draft',
|
|
9
13
|
'published'
|
|
10
|
-
],
|
|
14
|
+
], {
|
|
15
|
+
error: 'Invalid status'
|
|
16
|
+
}).optional();
|
|
11
17
|
/**
|
|
12
18
|
* From a request or query object, validates and returns the locale and status of the document.
|
|
13
19
|
* If the status is not provided and Draft & Publish is disabled, it defaults to 'published'.
|
|
@@ -18,23 +24,16 @@ const statusSchema = strapiUtils.yup.mixed().oneOf([
|
|
|
18
24
|
const { locale, status: providedStatus, ...rest } = request || {};
|
|
19
25
|
const defaultStatus = strapiUtils.contentTypes.hasDraftAndPublish(strapi.getModel(model)) ? undefined : 'published';
|
|
20
26
|
const status = providedStatus !== undefined ? providedStatus : defaultStatus;
|
|
21
|
-
const schema = strapiUtils.
|
|
27
|
+
const schema = strapiUtils.z.object({
|
|
22
28
|
locale: allowMultipleLocales ? multipleLocaleSchema : singleLocaleSchema,
|
|
23
29
|
status: statusSchema
|
|
24
30
|
});
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
locale,
|
|
32
|
-
status,
|
|
33
|
-
...rest
|
|
34
|
-
};
|
|
35
|
-
} catch (error) {
|
|
36
|
-
throw new strapiUtils.errors.ValidationError(`Validation error: ${error.message}`);
|
|
37
|
-
}
|
|
31
|
+
await zod.validateZodAsync(schema)(request);
|
|
32
|
+
return {
|
|
33
|
+
locale,
|
|
34
|
+
status,
|
|
35
|
+
...rest
|
|
36
|
+
};
|
|
38
37
|
};
|
|
39
38
|
|
|
40
39
|
exports.getDocumentLocaleAndStatus = getDocumentLocaleAndStatus;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"dimensions.js","sources":["../../../../server/src/controllers/validation/dimensions.ts"],"sourcesContent":["import {
|
|
1
|
+
{"version":3,"file":"dimensions.js","sources":["../../../../server/src/controllers/validation/dimensions.ts"],"sourcesContent":["import { z, contentTypes } from '@strapi/utils';\nimport type { UID } from '@strapi/types';\nimport { validateZodAsync } from '../../validation/zod';\n\ninterface Options {\n allowMultipleLocales?: boolean;\n}\n\nconst singleLocaleSchema = z.string().nullable().optional();\n\nconst multipleLocaleSchema = z.union([z.array(z.string()), z.string().nullable()]).optional();\n\nconst statusSchema = z.enum(['draft', 'published'], { error: 'Invalid status' }).optional();\n\n/**\n * From a request or query object, validates and returns the locale and status of the document.\n * If the status is not provided and Draft & Publish is disabled, it defaults to 'published'.\n */\nexport const getDocumentLocaleAndStatus = async (\n request: any,\n model: UID.Schema,\n opts: Options = { allowMultipleLocales: false }\n) => {\n const { allowMultipleLocales } = opts;\n const { locale, status: providedStatus, ...rest } = request || {};\n\n const defaultStatus = contentTypes.hasDraftAndPublish(strapi.getModel(model))\n ? undefined\n : 'published';\n const status = providedStatus !== undefined ? providedStatus : defaultStatus;\n\n const schema = z.object({\n locale: allowMultipleLocales ? multipleLocaleSchema : singleLocaleSchema,\n status: statusSchema,\n });\n\n await validateZodAsync(schema)(request);\n\n return { locale, status, ...rest };\n};\n"],"names":["singleLocaleSchema","z","string","nullable","optional","multipleLocaleSchema","union","array","statusSchema","enum","error","getDocumentLocaleAndStatus","request","model","opts","allowMultipleLocales","locale","status","providedStatus","rest","defaultStatus","contentTypes","hasDraftAndPublish","strapi","getModel","undefined","schema","object","validateZodAsync"],"mappings":";;;;;AAQA,MAAMA,qBAAqBC,aAAAA,CAAEC,MAAM,EAAA,CAAGC,QAAQ,GAAGC,QAAQ,EAAA;AAEzD,MAAMC,oBAAAA,GAAuBJ,aAAAA,CAAEK,KAAK,CAAC;IAACL,aAAAA,CAAEM,KAAK,CAACN,aAAAA,CAAEC,MAAM,EAAA,CAAA;IAAKD,aAAAA,CAAEC,MAAM,GAAGC,QAAQ;AAAG,CAAA,CAAA,CAAEC,QAAQ,EAAA;AAE3F,MAAMI,YAAAA,GAAeP,aAAAA,CAAEQ,IAAI,CAAC;AAAC,IAAA,OAAA;AAAS,IAAA;CAAY,EAAE;IAAEC,KAAAA,EAAO;AAAiB,CAAA,CAAA,CAAGN,QAAQ,EAAA;AAEzF;;;AAGC,IACM,MAAMO,0BAAAA,GAA6B,OACxCC,OAAAA,EACAC,OACAC,IAAAA,GAAgB;IAAEC,oBAAAA,EAAsB;AAAM,CAAC,GAAA;IAE/C,MAAM,EAAEA,oBAAoB,EAAE,GAAGD,IAAAA;IACjC,MAAM,EAAEE,MAAM,EAAEC,MAAAA,EAAQC,cAAc,EAAE,GAAGC,IAAAA,EAAM,GAAGP,OAAAA,IAAW,EAAC;IAEhE,MAAMQ,aAAAA,GAAgBC,yBAAaC,kBAAkB,CAACC,OAAOC,QAAQ,CAACX,UAClEY,SAAAA,GACA,WAAA;IACJ,MAAMR,MAAAA,GAASC,cAAAA,KAAmBO,SAAAA,GAAYP,cAAAA,GAAiBE,aAAAA;IAE/D,MAAMM,MAAAA,GAASzB,aAAAA,CAAE0B,MAAM,CAAC;AACtBX,QAAAA,MAAAA,EAAQD,uBAAuBV,oBAAAA,GAAuBL,kBAAAA;QACtDiB,MAAAA,EAAQT;AACV,KAAA,CAAA;AAEA,IAAA,MAAMoB,qBAAiBF,MAAAA,CAAAA,CAAQd,OAAAA,CAAAA;IAE/B,OAAO;AAAEI,QAAAA,MAAAA;AAAQC,QAAAA,MAAAA;AAAQ,QAAA,GAAGE;AAAK,KAAA;AACnC;;;;"}
|
|
@@ -1,11 +1,17 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { z, contentTypes } from '@strapi/utils';
|
|
2
|
+
import { validateZodAsync } from '../../validation/zod.mjs';
|
|
2
3
|
|
|
3
|
-
const singleLocaleSchema =
|
|
4
|
-
const multipleLocaleSchema =
|
|
5
|
-
|
|
4
|
+
const singleLocaleSchema = z.string().nullable().optional();
|
|
5
|
+
const multipleLocaleSchema = z.union([
|
|
6
|
+
z.array(z.string()),
|
|
7
|
+
z.string().nullable()
|
|
8
|
+
]).optional();
|
|
9
|
+
const statusSchema = z.enum([
|
|
6
10
|
'draft',
|
|
7
11
|
'published'
|
|
8
|
-
],
|
|
12
|
+
], {
|
|
13
|
+
error: 'Invalid status'
|
|
14
|
+
}).optional();
|
|
9
15
|
/**
|
|
10
16
|
* From a request or query object, validates and returns the locale and status of the document.
|
|
11
17
|
* If the status is not provided and Draft & Publish is disabled, it defaults to 'published'.
|
|
@@ -16,23 +22,16 @@ const statusSchema = yup.mixed().oneOf([
|
|
|
16
22
|
const { locale, status: providedStatus, ...rest } = request || {};
|
|
17
23
|
const defaultStatus = contentTypes.hasDraftAndPublish(strapi.getModel(model)) ? undefined : 'published';
|
|
18
24
|
const status = providedStatus !== undefined ? providedStatus : defaultStatus;
|
|
19
|
-
const schema =
|
|
25
|
+
const schema = z.object({
|
|
20
26
|
locale: allowMultipleLocales ? multipleLocaleSchema : singleLocaleSchema,
|
|
21
27
|
status: statusSchema
|
|
22
28
|
});
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
locale,
|
|
30
|
-
status,
|
|
31
|
-
...rest
|
|
32
|
-
};
|
|
33
|
-
} catch (error) {
|
|
34
|
-
throw new errors.ValidationError(`Validation error: ${error.message}`);
|
|
35
|
-
}
|
|
29
|
+
await validateZodAsync(schema)(request);
|
|
30
|
+
return {
|
|
31
|
+
locale,
|
|
32
|
+
status,
|
|
33
|
+
...rest
|
|
34
|
+
};
|
|
36
35
|
};
|
|
37
36
|
|
|
38
37
|
export { getDocumentLocaleAndStatus };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"dimensions.mjs","sources":["../../../../server/src/controllers/validation/dimensions.ts"],"sourcesContent":["import {
|
|
1
|
+
{"version":3,"file":"dimensions.mjs","sources":["../../../../server/src/controllers/validation/dimensions.ts"],"sourcesContent":["import { z, contentTypes } from '@strapi/utils';\nimport type { UID } from '@strapi/types';\nimport { validateZodAsync } from '../../validation/zod';\n\ninterface Options {\n allowMultipleLocales?: boolean;\n}\n\nconst singleLocaleSchema = z.string().nullable().optional();\n\nconst multipleLocaleSchema = z.union([z.array(z.string()), z.string().nullable()]).optional();\n\nconst statusSchema = z.enum(['draft', 'published'], { error: 'Invalid status' }).optional();\n\n/**\n * From a request or query object, validates and returns the locale and status of the document.\n * If the status is not provided and Draft & Publish is disabled, it defaults to 'published'.\n */\nexport const getDocumentLocaleAndStatus = async (\n request: any,\n model: UID.Schema,\n opts: Options = { allowMultipleLocales: false }\n) => {\n const { allowMultipleLocales } = opts;\n const { locale, status: providedStatus, ...rest } = request || {};\n\n const defaultStatus = contentTypes.hasDraftAndPublish(strapi.getModel(model))\n ? undefined\n : 'published';\n const status = providedStatus !== undefined ? providedStatus : defaultStatus;\n\n const schema = z.object({\n locale: allowMultipleLocales ? multipleLocaleSchema : singleLocaleSchema,\n status: statusSchema,\n });\n\n await validateZodAsync(schema)(request);\n\n return { locale, status, ...rest };\n};\n"],"names":["singleLocaleSchema","z","string","nullable","optional","multipleLocaleSchema","union","array","statusSchema","enum","error","getDocumentLocaleAndStatus","request","model","opts","allowMultipleLocales","locale","status","providedStatus","rest","defaultStatus","contentTypes","hasDraftAndPublish","strapi","getModel","undefined","schema","object","validateZodAsync"],"mappings":";;;AAQA,MAAMA,qBAAqBC,CAAAA,CAAEC,MAAM,EAAA,CAAGC,QAAQ,GAAGC,QAAQ,EAAA;AAEzD,MAAMC,oBAAAA,GAAuBJ,CAAAA,CAAEK,KAAK,CAAC;IAACL,CAAAA,CAAEM,KAAK,CAACN,CAAAA,CAAEC,MAAM,EAAA,CAAA;IAAKD,CAAAA,CAAEC,MAAM,GAAGC,QAAQ;AAAG,CAAA,CAAA,CAAEC,QAAQ,EAAA;AAE3F,MAAMI,YAAAA,GAAeP,CAAAA,CAAEQ,IAAI,CAAC;AAAC,IAAA,OAAA;AAAS,IAAA;CAAY,EAAE;IAAEC,KAAAA,EAAO;AAAiB,CAAA,CAAA,CAAGN,QAAQ,EAAA;AAEzF;;;AAGC,IACM,MAAMO,0BAAAA,GAA6B,OACxCC,OAAAA,EACAC,OACAC,IAAAA,GAAgB;IAAEC,oBAAAA,EAAsB;AAAM,CAAC,GAAA;IAE/C,MAAM,EAAEA,oBAAoB,EAAE,GAAGD,IAAAA;IACjC,MAAM,EAAEE,MAAM,EAAEC,MAAAA,EAAQC,cAAc,EAAE,GAAGC,IAAAA,EAAM,GAAGP,OAAAA,IAAW,EAAC;IAEhE,MAAMQ,aAAAA,GAAgBC,aAAaC,kBAAkB,CAACC,OAAOC,QAAQ,CAACX,UAClEY,SAAAA,GACA,WAAA;IACJ,MAAMR,MAAAA,GAASC,cAAAA,KAAmBO,SAAAA,GAAYP,cAAAA,GAAiBE,aAAAA;IAE/D,MAAMM,MAAAA,GAASzB,CAAAA,CAAE0B,MAAM,CAAC;AACtBX,QAAAA,MAAAA,EAAQD,uBAAuBV,oBAAAA,GAAuBL,kBAAAA;QACtDiB,MAAAA,EAAQT;AACV,KAAA,CAAA;AAEA,IAAA,MAAMoB,iBAAiBF,MAAAA,CAAAA,CAAQd,OAAAA,CAAAA;IAE/B,OAAO;AAAEI,QAAAA,MAAAA;AAAQC,QAAAA,MAAAA;AAAQ,QAAA,GAAGE;AAAK,KAAA;AACnC;;;;"}
|
|
@@ -2,6 +2,7 @@
|
|
|
2
2
|
|
|
3
3
|
var _ = require('lodash');
|
|
4
4
|
var strapiUtils = require('@strapi/utils');
|
|
5
|
+
var zod = require('../../validation/zod.js');
|
|
5
6
|
require('@strapi/types');
|
|
6
7
|
require('../../services/utils/configuration/attributes.js');
|
|
7
8
|
require('../../services/utils/configuration/settings.js');
|
|
@@ -13,22 +14,25 @@ const TYPES = [
|
|
|
13
14
|
];
|
|
14
15
|
/**
|
|
15
16
|
* Validates type kind
|
|
16
|
-
*/ const kindSchema = strapiUtils.
|
|
17
|
-
const bulkActionInputSchema = strapiUtils.
|
|
18
|
-
documentIds: strapiUtils.
|
|
19
|
-
}).required();
|
|
20
|
-
const generateUIDInputSchema = strapiUtils.yup.object({
|
|
21
|
-
contentTypeUID: strapiUtils.yup.string().required(),
|
|
22
|
-
field: strapiUtils.yup.string().required(),
|
|
23
|
-
data: strapiUtils.yup.object().required()
|
|
17
|
+
*/ const kindSchema = strapiUtils.z.enum(TYPES).nullable().optional();
|
|
18
|
+
const bulkActionInputSchema = strapiUtils.z.object({
|
|
19
|
+
documentIds: strapiUtils.z.array(zod.strapiID).min(1)
|
|
24
20
|
});
|
|
25
|
-
const
|
|
26
|
-
contentTypeUID: strapiUtils.
|
|
27
|
-
field: strapiUtils.
|
|
28
|
-
|
|
29
|
-
return value === '' || (context.options.context?.regex ? new RegExp(context.options?.context.regex).test(value) : /^[A-Za-z0-9-_.~]*$/.test(value));
|
|
30
|
-
})
|
|
21
|
+
const generateUIDInputSchema = strapiUtils.z.object({
|
|
22
|
+
contentTypeUID: strapiUtils.z.string(),
|
|
23
|
+
field: strapiUtils.z.string(),
|
|
24
|
+
data: strapiUtils.z.looseObject({})
|
|
31
25
|
});
|
|
26
|
+
const createCheckUIDAvailabilityInputSchema = (regex)=>{
|
|
27
|
+
const pattern = regex ? new RegExp(regex) : /^[A-Za-z0-9-_.~]*$/;
|
|
28
|
+
return strapiUtils.z.object({
|
|
29
|
+
contentTypeUID: strapiUtils.z.string(),
|
|
30
|
+
field: strapiUtils.z.string(),
|
|
31
|
+
value: strapiUtils.z.string().refine((value)=>value === '' || pattern.test(value), {
|
|
32
|
+
error: `Must match the custom regex or the default one "/^[A-Za-z0-9-_.~]*$/"`
|
|
33
|
+
})
|
|
34
|
+
});
|
|
35
|
+
};
|
|
32
36
|
const validateUIDField = (contentTypeUID, field)=>{
|
|
33
37
|
const model = strapi.contentTypes[contentTypeUID];
|
|
34
38
|
if (!model) {
|
|
@@ -45,19 +49,17 @@ const validateUIDField = (contentTypeUID, field)=>{
|
|
|
45
49
|
throw new ValidationError(`${field} must be a valid \`uid\` attribute`);
|
|
46
50
|
}
|
|
47
51
|
};
|
|
48
|
-
const validateKind =
|
|
49
|
-
const validateBulkActionInput =
|
|
50
|
-
const validateGenerateUIDInput =
|
|
52
|
+
const validateKind = zod.validateZodAsync(kindSchema);
|
|
53
|
+
const validateBulkActionInput = zod.validateZodAsync(bulkActionInputSchema);
|
|
54
|
+
const validateGenerateUIDInput = zod.validateZodAsync(generateUIDInputSchema);
|
|
51
55
|
const validateCheckUIDAvailabilityInput = (body)=>{
|
|
52
|
-
|
|
56
|
+
let regex;
|
|
53
57
|
const contentType = body.contentTypeUID in strapi.contentTypes ? strapi.contentTypes[body.contentTypeUID] : null;
|
|
54
58
|
if (contentType?.attributes[body.field] && `regex` in contentType.attributes[body.field] && contentType.attributes[body.field].regex) {
|
|
55
|
-
|
|
56
|
-
regex: (contentType?.attributes[body.field]).regex
|
|
57
|
-
};
|
|
59
|
+
regex = (contentType?.attributes[body.field]).regex;
|
|
58
60
|
}
|
|
59
|
-
const
|
|
60
|
-
return
|
|
61
|
+
const schema = createCheckUIDAvailabilityInputSchema(regex);
|
|
62
|
+
return zod.validateZodAsync(schema)(body);
|
|
61
63
|
};
|
|
62
64
|
|
|
63
65
|
exports.validateBulkActionInput = validateBulkActionInput;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":["../../../../server/src/controllers/validation/index.ts"],"sourcesContent":["import _ from 'lodash';\nimport { Schema, UID } from '@strapi/types';\nimport {
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../../../server/src/controllers/validation/index.ts"],"sourcesContent":["import _ from 'lodash';\nimport { Schema, UID } from '@strapi/types';\nimport { z, errors } from '@strapi/utils';\nimport { validateZodAsync, strapiID } from '../../validation/zod';\nimport createModelConfigurationSchema from './model-configuration';\n\nconst { PaginationError, ValidationError } = errors;\nconst TYPES = ['singleType', 'collectionType'] as const;\n\n/**\n * Validates type kind\n */\nconst kindSchema = z.enum(TYPES).nullable().optional();\n\nconst bulkActionInputSchema = z.object({\n documentIds: z.array(strapiID).min(1),\n});\n\nconst generateUIDInputSchema = z.object({\n contentTypeUID: z.string(),\n field: z.string(),\n data: z.looseObject({}),\n});\n\nconst createCheckUIDAvailabilityInputSchema = (regex?: string) => {\n const pattern = regex ? new RegExp(regex) : /^[A-Za-z0-9-_.~]*$/;\n return z.object({\n contentTypeUID: z.string(),\n field: z.string(),\n value: z.string().refine((value) => value === '' || pattern.test(value), {\n error: `Must match the custom regex or the default one \"/^[A-Za-z0-9-_.~]*$/\"`,\n }),\n });\n};\n\nconst validateUIDField = (contentTypeUID: any, field: any) => {\n const model = strapi.contentTypes[contentTypeUID];\n\n if (!model) {\n throw new ValidationError('ContentType not found');\n }\n\n if (\n !_.has(model, ['attributes', field]) ||\n _.get(model, ['attributes', field, 'type']) !== 'uid'\n ) {\n throw new ValidationError(`${field} must be a valid \\`uid\\` attribute`);\n }\n};\n\nconst validatePagination = ({ page, pageSize }: any) => {\n const pageNumber = parseInt(page, 10);\n const pageSizeNumber = parseInt(pageSize, 10);\n\n if (Number.isNaN(pageNumber) || pageNumber < 1) {\n throw new PaginationError('invalid pageNumber param');\n }\n if (Number.isNaN(pageSizeNumber) || pageSizeNumber < 1) {\n throw new PaginationError('invalid pageSize param');\n }\n};\n\nconst validateKind = validateZodAsync(kindSchema);\nconst validateBulkActionInput = validateZodAsync(bulkActionInputSchema);\nconst validateGenerateUIDInput = validateZodAsync(generateUIDInputSchema);\nconst validateCheckUIDAvailabilityInput = (body: {\n contentTypeUID: UID.ContentType;\n field: string;\n value: string;\n}) => {\n let regex: string | undefined;\n\n const contentType =\n body.contentTypeUID in strapi.contentTypes ? strapi.contentTypes[body.contentTypeUID] : null;\n\n if (\n contentType?.attributes[body.field] &&\n `regex` in contentType.attributes[body.field] &&\n (contentType.attributes[body.field] as Schema.Attribute.UID).regex\n ) {\n regex = (contentType?.attributes[body.field] as Schema.Attribute.UID).regex;\n }\n\n const schema = createCheckUIDAvailabilityInputSchema(regex);\n return validateZodAsync(schema)(body);\n};\n\nexport {\n createModelConfigurationSchema,\n validateUIDField,\n validatePagination,\n validateKind,\n validateBulkActionInput,\n validateGenerateUIDInput,\n validateCheckUIDAvailabilityInput,\n};\n"],"names":["PaginationError","ValidationError","errors","TYPES","kindSchema","z","enum","nullable","optional","bulkActionInputSchema","object","documentIds","array","strapiID","min","generateUIDInputSchema","contentTypeUID","string","field","data","looseObject","createCheckUIDAvailabilityInputSchema","regex","pattern","RegExp","value","refine","test","error","validateUIDField","model","strapi","contentTypes","_","has","get","validateKind","validateZodAsync","validateBulkActionInput","validateGenerateUIDInput","validateCheckUIDAvailabilityInput","body","contentType","attributes","schema"],"mappings":"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"}
|