@strapi/content-manager 5.15.1 → 5.16.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/hooks/useDocumentActions.js +7 -3
- package/dist/admin/hooks/useDocumentActions.js.map +1 -1
- package/dist/admin/hooks/useDocumentActions.mjs +7 -3
- package/dist/admin/hooks/useDocumentActions.mjs.map +1 -1
- package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksContent.js +12 -15
- package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksContent.js.map +1 -1
- package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksContent.mjs +12 -15
- package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksContent.mjs.map +1 -1
- package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksEditor.js +54 -14
- package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksEditor.js.map +1 -1
- package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksEditor.mjs +55 -15
- package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksEditor.mjs.map +1 -1
- package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksToolbar.js +2 -2
- package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksToolbar.js.map +1 -1
- package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksToolbar.mjs +2 -2
- package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksToolbar.mjs.map +1 -1
- package/dist/admin/pages/EditView/components/FormInputs/UID.js +4 -2
- package/dist/admin/pages/EditView/components/FormInputs/UID.js.map +1 -1
- package/dist/admin/pages/EditView/components/FormInputs/UID.mjs +4 -2
- package/dist/admin/pages/EditView/components/FormInputs/UID.mjs.map +1 -1
- package/dist/admin/pages/EditView/components/FormInputs/Wysiwyg/Editor.js +1 -1
- package/dist/admin/pages/EditView/components/FormInputs/Wysiwyg/Editor.js.map +1 -1
- package/dist/admin/pages/EditView/components/FormInputs/Wysiwyg/Editor.mjs +1 -1
- package/dist/admin/pages/EditView/components/FormInputs/Wysiwyg/Editor.mjs.map +1 -1
- package/dist/admin/pages/ListView/components/Filters.js +1 -0
- package/dist/admin/pages/ListView/components/Filters.js.map +1 -1
- package/dist/admin/pages/ListView/components/Filters.mjs +1 -0
- package/dist/admin/pages/ListView/components/Filters.mjs.map +1 -1
- package/dist/admin/pages/ListView/components/TableActions.js +13 -3
- package/dist/admin/pages/ListView/components/TableActions.js.map +1 -1
- package/dist/admin/pages/ListView/components/TableActions.mjs +13 -3
- package/dist/admin/pages/ListView/components/TableActions.mjs.map +1 -1
- package/dist/admin/services/documents.js +2 -2
- package/dist/admin/services/documents.js.map +1 -1
- package/dist/admin/services/documents.mjs +2 -2
- package/dist/admin/services/documents.mjs.map +1 -1
- package/dist/admin/src/hooks/useDocumentActions.d.ts +1 -0
- package/dist/admin/src/pages/EditView/components/FormInputs/UID.d.ts +1 -0
- package/dist/admin/src/services/documents.d.ts +7 -1
- package/dist/admin/utils/validation.js +1 -1
- package/dist/admin/utils/validation.js.map +1 -1
- package/dist/admin/utils/validation.mjs +1 -1
- package/dist/admin/utils/validation.mjs.map +1 -1
- package/dist/server/controllers/content-types.js +11 -1
- package/dist/server/controllers/content-types.js.map +1 -1
- package/dist/server/controllers/content-types.mjs +11 -1
- package/dist/server/controllers/content-types.mjs.map +1 -1
- package/dist/server/controllers/validation/index.js +14 -2
- package/dist/server/controllers/validation/index.js.map +1 -1
- package/dist/server/controllers/validation/index.mjs +14 -2
- package/dist/server/controllers/validation/index.mjs.map +1 -1
- package/dist/server/services/data-mapper.js +4 -1
- package/dist/server/services/data-mapper.js.map +1 -1
- package/dist/server/services/data-mapper.mjs +4 -1
- package/dist/server/services/data-mapper.mjs.map +1 -1
- package/dist/server/services/document-manager.js +8 -1
- package/dist/server/services/document-manager.js.map +1 -1
- package/dist/server/services/document-manager.mjs +8 -1
- package/dist/server/services/document-manager.mjs.map +1 -1
- package/dist/server/services/document-metadata.js +2 -0
- package/dist/server/services/document-metadata.js.map +1 -1
- package/dist/server/services/document-metadata.mjs +2 -0
- package/dist/server/services/document-metadata.mjs.map +1 -1
- package/dist/server/services/utils/configuration/attributes.js +1 -1
- package/dist/server/services/utils/configuration/attributes.js.map +1 -1
- package/dist/server/services/utils/configuration/attributes.mjs +1 -1
- package/dist/server/services/utils/configuration/attributes.mjs.map +1 -1
- package/dist/server/services/utils/configuration/layouts.js +1 -1
- package/dist/server/services/utils/configuration/layouts.js.map +1 -1
- package/dist/server/services/utils/configuration/layouts.mjs +1 -1
- package/dist/server/services/utils/configuration/layouts.mjs.map +1 -1
- package/dist/server/services/utils/configuration/metadatas.js +8 -0
- package/dist/server/services/utils/configuration/metadatas.js.map +1 -1
- package/dist/server/services/utils/configuration/metadatas.mjs +8 -0
- package/dist/server/services/utils/configuration/metadatas.mjs.map +1 -1
- package/dist/server/services/utils/populate.js +11 -0
- package/dist/server/services/utils/populate.js.map +1 -1
- package/dist/server/services/utils/populate.mjs +11 -0
- package/dist/server/services/utils/populate.mjs.map +1 -1
- package/dist/server/src/controllers/content-types.d.ts.map +1 -1
- package/dist/server/src/controllers/validation/index.d.ts +6 -1
- package/dist/server/src/controllers/validation/index.d.ts.map +1 -1
- package/dist/server/src/services/data-mapper.d.ts.map +1 -1
- package/dist/server/src/services/document-manager.d.ts.map +1 -1
- package/dist/server/src/services/document-metadata.d.ts.map +1 -1
- package/dist/server/src/services/utils/configuration/metadatas.d.ts.map +1 -1
- package/dist/server/src/services/utils/populate.d.ts.map +1 -1
- package/dist/shared/contracts/collection-types.d.ts +0 -1
- package/dist/shared/contracts/collection-types.d.ts.map +1 -1
- package/package.json +7 -7
|
@@ -49,7 +49,17 @@ var contentTypes = {
|
|
|
49
49
|
const configuration = await contentTypeService.findConfiguration(contentType);
|
|
50
50
|
const confWithUpdatedMetadata = {
|
|
51
51
|
...configuration,
|
|
52
|
-
metadatas:
|
|
52
|
+
metadatas: {
|
|
53
|
+
...fp.mapValues(assocMainField, configuration.metadatas),
|
|
54
|
+
documentId: {
|
|
55
|
+
edit: {},
|
|
56
|
+
list: {
|
|
57
|
+
label: 'documentId',
|
|
58
|
+
searchable: true,
|
|
59
|
+
sortable: true
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
}
|
|
53
63
|
};
|
|
54
64
|
const components = await contentTypeService.findComponentsConfigurations(contentType);
|
|
55
65
|
ctx.body = {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"content-types.js","sources":["../../../server/src/controllers/content-types.ts"],"sourcesContent":["import { has, assoc, mapValues, prop } from 'lodash/fp';\nimport { getService } from '../utils';\nimport { createModelConfigurationSchema, validateKind } from './validation';\n\nconst hasEditMainField = has('edit.mainField');\nconst getEditMainField = prop('edit.mainField');\nconst assocListMainField = assoc('list.mainField');\n\nconst assocMainField = (metadata: any) =>\n hasEditMainField(metadata) ? assocListMainField(getEditMainField(metadata), metadata) : metadata;\n\nexport default {\n async findContentTypes(ctx: any) {\n const { kind } = ctx.query;\n\n try {\n await validateKind(kind);\n } catch (error) {\n return ctx.send({ error }, 400);\n }\n\n const contentTypes = getService('content-types').findContentTypesByKind(kind);\n const { toDto } = getService('data-mapper');\n\n ctx.body = { data: contentTypes.map(toDto) };\n },\n\n async findContentTypesSettings(ctx: any) {\n const { findAllContentTypes, findConfiguration } = getService('content-types');\n\n const contentTypes = await findAllContentTypes();\n const configurations = await Promise.all(\n contentTypes.map(async (contentType: any) => {\n const { uid, settings } = await findConfiguration(contentType);\n return { uid, settings };\n })\n );\n\n ctx.body = {\n data: configurations,\n };\n },\n\n async findContentTypeConfiguration(ctx: any) {\n const { uid } = ctx.params;\n\n const contentTypeService = getService('content-types');\n\n const contentType = await contentTypeService.findContentType(uid);\n\n if (!contentType) {\n return ctx.notFound('contentType.notFound');\n }\n\n const configuration = await contentTypeService.findConfiguration(contentType);\n\n const confWithUpdatedMetadata = {\n ...configuration,\n metadatas: mapValues(assocMainField, configuration.metadatas),\n };\n\n const components = await contentTypeService.findComponentsConfigurations(contentType);\n\n ctx.body = {\n data: {\n contentType: confWithUpdatedMetadata,\n components,\n },\n };\n },\n\n async updateContentTypeConfiguration(ctx: any) {\n const { userAbility } = ctx.state;\n const { uid } = ctx.params;\n const { body } = ctx.request;\n\n const contentTypeService = getService('content-types');\n const metricsService = getService('metrics');\n\n const contentType = await contentTypeService.findContentType(uid);\n\n if (!contentType) {\n return ctx.notFound('contentType.notFound');\n }\n\n if (!getService('permission').canConfigureContentType({ userAbility, contentType })) {\n return ctx.forbidden();\n }\n\n let input;\n try {\n input = await createModelConfigurationSchema(contentType).validate(body, {\n abortEarly: false,\n stripUnknown: true,\n strict: true,\n });\n } catch (error: any) {\n return ctx.badRequest(null, {\n name: 'validationError',\n errors: error.errors,\n });\n }\n\n const newConfiguration = await contentTypeService.updateConfiguration(contentType, input);\n\n await metricsService.sendDidConfigureListView(contentType, newConfiguration);\n\n const confWithUpdatedMetadata = {\n ...newConfiguration,\n metadatas: mapValues(assocMainField, newConfiguration.metadatas),\n };\n\n const components = await contentTypeService.findComponentsConfigurations(contentType);\n\n ctx.body = {\n data: {\n contentType: confWithUpdatedMetadata,\n components,\n },\n };\n },\n};\n"],"names":["hasEditMainField","has","getEditMainField","prop","assocListMainField","assoc","assocMainField","metadata","findContentTypes","ctx","kind","query","validateKind","error","send","contentTypes","getService","findContentTypesByKind","toDto","body","data","map","findContentTypesSettings","findAllContentTypes","findConfiguration","configurations","Promise","all","contentType","uid","settings","findContentTypeConfiguration","params","contentTypeService","findContentType","notFound","configuration","confWithUpdatedMetadata","metadatas","mapValues","components","findComponentsConfigurations","updateContentTypeConfiguration","userAbility","state","request","metricsService","canConfigureContentType","forbidden","input","createModelConfigurationSchema","validate","abortEarly","stripUnknown","strict","badRequest","name","errors","newConfiguration","updateConfiguration","sendDidConfigureListView"],"mappings":";;;;;;;AAIA,MAAMA,mBAAmBC,MAAI,CAAA,gBAAA,CAAA;AAC7B,MAAMC,mBAAmBC,OAAK,CAAA,gBAAA,CAAA;AAC9B,MAAMC,qBAAqBC,QAAM,CAAA,gBAAA,CAAA;AAEjC,MAAMC,cAAAA,GAAiB,CAACC,QACtBP,GAAAA,gBAAAA,CAAiBO,YAAYH,kBAAmBF,CAAAA,gBAAAA,CAAiBK,WAAWA,QAAYA,CAAAA,GAAAA,QAAAA;AAE1F,mBAAe;AACb,IAAA,MAAMC,kBAAiBC,GAAQ,EAAA;AAC7B,QAAA,MAAM,EAAEC,IAAI,EAAE,GAAGD,IAAIE,KAAK;QAE1B,IAAI;AACF,YAAA,MAAMC,kBAAaF,CAAAA,IAAAA,CAAAA;AACrB,SAAA,CAAE,OAAOG,KAAO,EAAA;YACd,OAAOJ,GAAAA,CAAIK,IAAI,CAAC;AAAED,gBAAAA;aAAS,EAAA,GAAA,CAAA;AAC7B;AAEA,QAAA,MAAME,YAAeC,GAAAA,kBAAAA,CAAW,eAAiBC,CAAAA,CAAAA,sBAAsB,CAACP,IAAAA,CAAAA;AACxE,QAAA,MAAM,EAAEQ,KAAK,EAAE,GAAGF,kBAAW,CAAA,aAAA,CAAA;AAE7BP,QAAAA,GAAAA,CAAIU,IAAI,GAAG;YAAEC,IAAML,EAAAA,YAAAA,CAAaM,GAAG,CAACH,KAAAA;AAAO,SAAA;AAC7C,KAAA;AAEA,IAAA,MAAMI,0BAAyBb,GAAQ,EAAA;AACrC,QAAA,MAAM,EAAEc,mBAAmB,EAAEC,iBAAiB,EAAE,GAAGR,kBAAW,CAAA,eAAA,CAAA;AAE9D,QAAA,MAAMD,eAAe,MAAMQ,mBAAAA,EAAAA;QAC3B,MAAME,cAAAA,GAAiB,MAAMC,OAAQC,CAAAA,GAAG,CACtCZ,YAAaM,CAAAA,GAAG,CAAC,OAAOO,WAAAA,GAAAA;AACtB,YAAA,MAAM,EAAEC,GAAG,EAAEC,QAAQ,EAAE,GAAG,MAAMN,iBAAkBI,CAAAA,WAAAA,CAAAA;YAClD,OAAO;AAAEC,gBAAAA,GAAAA;AAAKC,gBAAAA;AAAS,aAAA;AACzB,SAAA,CAAA,CAAA;AAGFrB,QAAAA,GAAAA,CAAIU,IAAI,GAAG;YACTC,IAAMK,EAAAA;AACR,SAAA;AACF,KAAA;AAEA,IAAA,MAAMM,8BAA6BtB,GAAQ,EAAA;AACzC,QAAA,MAAM,EAAEoB,GAAG,EAAE,GAAGpB,IAAIuB,MAAM;AAE1B,QAAA,MAAMC,qBAAqBjB,kBAAW,CAAA,eAAA,CAAA;AAEtC,QAAA,MAAMY,WAAc,GAAA,MAAMK,kBAAmBC,CAAAA,eAAe,CAACL,GAAAA,CAAAA;AAE7D,QAAA,IAAI,CAACD,WAAa,EAAA;YAChB,OAAOnB,GAAAA,CAAI0B,QAAQ,CAAC,sBAAA,CAAA;AACtB;AAEA,QAAA,MAAMC,aAAgB,GAAA,MAAMH,kBAAmBT,CAAAA,iBAAiB,CAACI,WAAAA,CAAAA;AAEjE,QAAA,MAAMS,uBAA0B,GAAA;AAC9B,YAAA,GAAGD,aAAa;YAChBE,
|
|
1
|
+
{"version":3,"file":"content-types.js","sources":["../../../server/src/controllers/content-types.ts"],"sourcesContent":["import { has, assoc, mapValues, prop } from 'lodash/fp';\nimport { getService } from '../utils';\nimport { createModelConfigurationSchema, validateKind } from './validation';\n\nconst hasEditMainField = has('edit.mainField');\nconst getEditMainField = prop('edit.mainField');\nconst assocListMainField = assoc('list.mainField');\n\nconst assocMainField = (metadata: any) =>\n hasEditMainField(metadata) ? assocListMainField(getEditMainField(metadata), metadata) : metadata;\n\nexport default {\n async findContentTypes(ctx: any) {\n const { kind } = ctx.query;\n\n try {\n await validateKind(kind);\n } catch (error) {\n return ctx.send({ error }, 400);\n }\n\n const contentTypes = getService('content-types').findContentTypesByKind(kind);\n const { toDto } = getService('data-mapper');\n\n ctx.body = { data: contentTypes.map(toDto) };\n },\n\n async findContentTypesSettings(ctx: any) {\n const { findAllContentTypes, findConfiguration } = getService('content-types');\n\n const contentTypes = await findAllContentTypes();\n const configurations = await Promise.all(\n contentTypes.map(async (contentType: any) => {\n const { uid, settings } = await findConfiguration(contentType);\n return { uid, settings };\n })\n );\n\n ctx.body = {\n data: configurations,\n };\n },\n\n async findContentTypeConfiguration(ctx: any) {\n const { uid } = ctx.params;\n\n const contentTypeService = getService('content-types');\n\n const contentType = await contentTypeService.findContentType(uid);\n\n if (!contentType) {\n return ctx.notFound('contentType.notFound');\n }\n\n const configuration = await contentTypeService.findConfiguration(contentType);\n\n const confWithUpdatedMetadata = {\n ...configuration,\n metadatas: {\n ...mapValues(assocMainField, configuration.metadatas),\n documentId: {\n edit: {},\n list: {\n label: 'documentId',\n searchable: true,\n sortable: true,\n },\n },\n },\n };\n\n const components = await contentTypeService.findComponentsConfigurations(contentType);\n\n ctx.body = {\n data: {\n contentType: confWithUpdatedMetadata,\n components,\n },\n };\n },\n\n async updateContentTypeConfiguration(ctx: any) {\n const { userAbility } = ctx.state;\n const { uid } = ctx.params;\n const { body } = ctx.request;\n\n const contentTypeService = getService('content-types');\n const metricsService = getService('metrics');\n\n const contentType = await contentTypeService.findContentType(uid);\n\n if (!contentType) {\n return ctx.notFound('contentType.notFound');\n }\n\n if (!getService('permission').canConfigureContentType({ userAbility, contentType })) {\n return ctx.forbidden();\n }\n\n let input;\n try {\n input = await createModelConfigurationSchema(contentType).validate(body, {\n abortEarly: false,\n stripUnknown: true,\n strict: true,\n });\n } catch (error: any) {\n return ctx.badRequest(null, {\n name: 'validationError',\n errors: error.errors,\n });\n }\n\n const newConfiguration = await contentTypeService.updateConfiguration(contentType, input);\n\n await metricsService.sendDidConfigureListView(contentType, newConfiguration);\n\n const confWithUpdatedMetadata = {\n ...newConfiguration,\n metadatas: mapValues(assocMainField, newConfiguration.metadatas),\n };\n\n const components = await contentTypeService.findComponentsConfigurations(contentType);\n\n ctx.body = {\n data: {\n contentType: confWithUpdatedMetadata,\n components,\n },\n };\n },\n};\n"],"names":["hasEditMainField","has","getEditMainField","prop","assocListMainField","assoc","assocMainField","metadata","findContentTypes","ctx","kind","query","validateKind","error","send","contentTypes","getService","findContentTypesByKind","toDto","body","data","map","findContentTypesSettings","findAllContentTypes","findConfiguration","configurations","Promise","all","contentType","uid","settings","findContentTypeConfiguration","params","contentTypeService","findContentType","notFound","configuration","confWithUpdatedMetadata","metadatas","mapValues","documentId","edit","list","label","searchable","sortable","components","findComponentsConfigurations","updateContentTypeConfiguration","userAbility","state","request","metricsService","canConfigureContentType","forbidden","input","createModelConfigurationSchema","validate","abortEarly","stripUnknown","strict","badRequest","name","errors","newConfiguration","updateConfiguration","sendDidConfigureListView"],"mappings":"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"}
|
|
@@ -47,7 +47,17 @@ var contentTypes = {
|
|
|
47
47
|
const configuration = await contentTypeService.findConfiguration(contentType);
|
|
48
48
|
const confWithUpdatedMetadata = {
|
|
49
49
|
...configuration,
|
|
50
|
-
metadatas:
|
|
50
|
+
metadatas: {
|
|
51
|
+
...mapValues(assocMainField, configuration.metadatas),
|
|
52
|
+
documentId: {
|
|
53
|
+
edit: {},
|
|
54
|
+
list: {
|
|
55
|
+
label: 'documentId',
|
|
56
|
+
searchable: true,
|
|
57
|
+
sortable: true
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
}
|
|
51
61
|
};
|
|
52
62
|
const components = await contentTypeService.findComponentsConfigurations(contentType);
|
|
53
63
|
ctx.body = {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"content-types.mjs","sources":["../../../server/src/controllers/content-types.ts"],"sourcesContent":["import { has, assoc, mapValues, prop } from 'lodash/fp';\nimport { getService } from '../utils';\nimport { createModelConfigurationSchema, validateKind } from './validation';\n\nconst hasEditMainField = has('edit.mainField');\nconst getEditMainField = prop('edit.mainField');\nconst assocListMainField = assoc('list.mainField');\n\nconst assocMainField = (metadata: any) =>\n hasEditMainField(metadata) ? assocListMainField(getEditMainField(metadata), metadata) : metadata;\n\nexport default {\n async findContentTypes(ctx: any) {\n const { kind } = ctx.query;\n\n try {\n await validateKind(kind);\n } catch (error) {\n return ctx.send({ error }, 400);\n }\n\n const contentTypes = getService('content-types').findContentTypesByKind(kind);\n const { toDto } = getService('data-mapper');\n\n ctx.body = { data: contentTypes.map(toDto) };\n },\n\n async findContentTypesSettings(ctx: any) {\n const { findAllContentTypes, findConfiguration } = getService('content-types');\n\n const contentTypes = await findAllContentTypes();\n const configurations = await Promise.all(\n contentTypes.map(async (contentType: any) => {\n const { uid, settings } = await findConfiguration(contentType);\n return { uid, settings };\n })\n );\n\n ctx.body = {\n data: configurations,\n };\n },\n\n async findContentTypeConfiguration(ctx: any) {\n const { uid } = ctx.params;\n\n const contentTypeService = getService('content-types');\n\n const contentType = await contentTypeService.findContentType(uid);\n\n if (!contentType) {\n return ctx.notFound('contentType.notFound');\n }\n\n const configuration = await contentTypeService.findConfiguration(contentType);\n\n const confWithUpdatedMetadata = {\n ...configuration,\n metadatas: mapValues(assocMainField, configuration.metadatas),\n };\n\n const components = await contentTypeService.findComponentsConfigurations(contentType);\n\n ctx.body = {\n data: {\n contentType: confWithUpdatedMetadata,\n components,\n },\n };\n },\n\n async updateContentTypeConfiguration(ctx: any) {\n const { userAbility } = ctx.state;\n const { uid } = ctx.params;\n const { body } = ctx.request;\n\n const contentTypeService = getService('content-types');\n const metricsService = getService('metrics');\n\n const contentType = await contentTypeService.findContentType(uid);\n\n if (!contentType) {\n return ctx.notFound('contentType.notFound');\n }\n\n if (!getService('permission').canConfigureContentType({ userAbility, contentType })) {\n return ctx.forbidden();\n }\n\n let input;\n try {\n input = await createModelConfigurationSchema(contentType).validate(body, {\n abortEarly: false,\n stripUnknown: true,\n strict: true,\n });\n } catch (error: any) {\n return ctx.badRequest(null, {\n name: 'validationError',\n errors: error.errors,\n });\n }\n\n const newConfiguration = await contentTypeService.updateConfiguration(contentType, input);\n\n await metricsService.sendDidConfigureListView(contentType, newConfiguration);\n\n const confWithUpdatedMetadata = {\n ...newConfiguration,\n metadatas: mapValues(assocMainField, newConfiguration.metadatas),\n };\n\n const components = await contentTypeService.findComponentsConfigurations(contentType);\n\n ctx.body = {\n data: {\n contentType: confWithUpdatedMetadata,\n components,\n },\n };\n },\n};\n"],"names":["hasEditMainField","has","getEditMainField","prop","assocListMainField","assoc","assocMainField","metadata","findContentTypes","ctx","kind","query","validateKind","error","send","contentTypes","getService","findContentTypesByKind","toDto","body","data","map","findContentTypesSettings","findAllContentTypes","findConfiguration","configurations","Promise","all","contentType","uid","settings","findContentTypeConfiguration","params","contentTypeService","findContentType","notFound","configuration","confWithUpdatedMetadata","metadatas","mapValues","components","findComponentsConfigurations","updateContentTypeConfiguration","userAbility","state","request","metricsService","canConfigureContentType","forbidden","input","createModelConfigurationSchema","validate","abortEarly","stripUnknown","strict","badRequest","name","errors","newConfiguration","updateConfiguration","sendDidConfigureListView"],"mappings":";;;;;AAIA,MAAMA,mBAAmBC,GAAI,CAAA,gBAAA,CAAA;AAC7B,MAAMC,mBAAmBC,IAAK,CAAA,gBAAA,CAAA;AAC9B,MAAMC,qBAAqBC,KAAM,CAAA,gBAAA,CAAA;AAEjC,MAAMC,cAAAA,GAAiB,CAACC,QACtBP,GAAAA,gBAAAA,CAAiBO,YAAYH,kBAAmBF,CAAAA,gBAAAA,CAAiBK,WAAWA,QAAYA,CAAAA,GAAAA,QAAAA;AAE1F,mBAAe;AACb,IAAA,MAAMC,kBAAiBC,GAAQ,EAAA;AAC7B,QAAA,MAAM,EAAEC,IAAI,EAAE,GAAGD,IAAIE,KAAK;QAE1B,IAAI;AACF,YAAA,MAAMC,YAAaF,CAAAA,IAAAA,CAAAA;AACrB,SAAA,CAAE,OAAOG,KAAO,EAAA;YACd,OAAOJ,GAAAA,CAAIK,IAAI,CAAC;AAAED,gBAAAA;aAAS,EAAA,GAAA,CAAA;AAC7B;AAEA,QAAA,MAAME,YAAeC,GAAAA,UAAAA,CAAW,eAAiBC,CAAAA,CAAAA,sBAAsB,CAACP,IAAAA,CAAAA;AACxE,QAAA,MAAM,EAAEQ,KAAK,EAAE,GAAGF,UAAW,CAAA,aAAA,CAAA;AAE7BP,QAAAA,GAAAA,CAAIU,IAAI,GAAG;YAAEC,IAAML,EAAAA,YAAAA,CAAaM,GAAG,CAACH,KAAAA;AAAO,SAAA;AAC7C,KAAA;AAEA,IAAA,MAAMI,0BAAyBb,GAAQ,EAAA;AACrC,QAAA,MAAM,EAAEc,mBAAmB,EAAEC,iBAAiB,EAAE,GAAGR,UAAW,CAAA,eAAA,CAAA;AAE9D,QAAA,MAAMD,eAAe,MAAMQ,mBAAAA,EAAAA;QAC3B,MAAME,cAAAA,GAAiB,MAAMC,OAAQC,CAAAA,GAAG,CACtCZ,YAAaM,CAAAA,GAAG,CAAC,OAAOO,WAAAA,GAAAA;AACtB,YAAA,MAAM,EAAEC,GAAG,EAAEC,QAAQ,EAAE,GAAG,MAAMN,iBAAkBI,CAAAA,WAAAA,CAAAA;YAClD,OAAO;AAAEC,gBAAAA,GAAAA;AAAKC,gBAAAA;AAAS,aAAA;AACzB,SAAA,CAAA,CAAA;AAGFrB,QAAAA,GAAAA,CAAIU,IAAI,GAAG;YACTC,IAAMK,EAAAA;AACR,SAAA;AACF,KAAA;AAEA,IAAA,MAAMM,8BAA6BtB,GAAQ,EAAA;AACzC,QAAA,MAAM,EAAEoB,GAAG,EAAE,GAAGpB,IAAIuB,MAAM;AAE1B,QAAA,MAAMC,qBAAqBjB,UAAW,CAAA,eAAA,CAAA;AAEtC,QAAA,MAAMY,WAAc,GAAA,MAAMK,kBAAmBC,CAAAA,eAAe,CAACL,GAAAA,CAAAA;AAE7D,QAAA,IAAI,CAACD,WAAa,EAAA;YAChB,OAAOnB,GAAAA,CAAI0B,QAAQ,CAAC,sBAAA,CAAA;AACtB;AAEA,QAAA,MAAMC,aAAgB,GAAA,MAAMH,kBAAmBT,CAAAA,iBAAiB,CAACI,WAAAA,CAAAA;AAEjE,QAAA,MAAMS,uBAA0B,GAAA;AAC9B,YAAA,GAAGD,aAAa;YAChBE,
|
|
1
|
+
{"version":3,"file":"content-types.mjs","sources":["../../../server/src/controllers/content-types.ts"],"sourcesContent":["import { has, assoc, mapValues, prop } from 'lodash/fp';\nimport { getService } from '../utils';\nimport { createModelConfigurationSchema, validateKind } from './validation';\n\nconst hasEditMainField = has('edit.mainField');\nconst getEditMainField = prop('edit.mainField');\nconst assocListMainField = assoc('list.mainField');\n\nconst assocMainField = (metadata: any) =>\n hasEditMainField(metadata) ? assocListMainField(getEditMainField(metadata), metadata) : metadata;\n\nexport default {\n async findContentTypes(ctx: any) {\n const { kind } = ctx.query;\n\n try {\n await validateKind(kind);\n } catch (error) {\n return ctx.send({ error }, 400);\n }\n\n const contentTypes = getService('content-types').findContentTypesByKind(kind);\n const { toDto } = getService('data-mapper');\n\n ctx.body = { data: contentTypes.map(toDto) };\n },\n\n async findContentTypesSettings(ctx: any) {\n const { findAllContentTypes, findConfiguration } = getService('content-types');\n\n const contentTypes = await findAllContentTypes();\n const configurations = await Promise.all(\n contentTypes.map(async (contentType: any) => {\n const { uid, settings } = await findConfiguration(contentType);\n return { uid, settings };\n })\n );\n\n ctx.body = {\n data: configurations,\n };\n },\n\n async findContentTypeConfiguration(ctx: any) {\n const { uid } = ctx.params;\n\n const contentTypeService = getService('content-types');\n\n const contentType = await contentTypeService.findContentType(uid);\n\n if (!contentType) {\n return ctx.notFound('contentType.notFound');\n }\n\n const configuration = await contentTypeService.findConfiguration(contentType);\n\n const confWithUpdatedMetadata = {\n ...configuration,\n metadatas: {\n ...mapValues(assocMainField, configuration.metadatas),\n documentId: {\n edit: {},\n list: {\n label: 'documentId',\n searchable: true,\n sortable: true,\n },\n },\n },\n };\n\n const components = await contentTypeService.findComponentsConfigurations(contentType);\n\n ctx.body = {\n data: {\n contentType: confWithUpdatedMetadata,\n components,\n },\n };\n },\n\n async updateContentTypeConfiguration(ctx: any) {\n const { userAbility } = ctx.state;\n const { uid } = ctx.params;\n const { body } = ctx.request;\n\n const contentTypeService = getService('content-types');\n const metricsService = getService('metrics');\n\n const contentType = await contentTypeService.findContentType(uid);\n\n if (!contentType) {\n return ctx.notFound('contentType.notFound');\n }\n\n if (!getService('permission').canConfigureContentType({ userAbility, contentType })) {\n return ctx.forbidden();\n }\n\n let input;\n try {\n input = await createModelConfigurationSchema(contentType).validate(body, {\n abortEarly: false,\n stripUnknown: true,\n strict: true,\n });\n } catch (error: any) {\n return ctx.badRequest(null, {\n name: 'validationError',\n errors: error.errors,\n });\n }\n\n const newConfiguration = await contentTypeService.updateConfiguration(contentType, input);\n\n await metricsService.sendDidConfigureListView(contentType, newConfiguration);\n\n const confWithUpdatedMetadata = {\n ...newConfiguration,\n metadatas: mapValues(assocMainField, newConfiguration.metadatas),\n };\n\n const components = await contentTypeService.findComponentsConfigurations(contentType);\n\n ctx.body = {\n data: {\n contentType: confWithUpdatedMetadata,\n components,\n },\n };\n },\n};\n"],"names":["hasEditMainField","has","getEditMainField","prop","assocListMainField","assoc","assocMainField","metadata","findContentTypes","ctx","kind","query","validateKind","error","send","contentTypes","getService","findContentTypesByKind","toDto","body","data","map","findContentTypesSettings","findAllContentTypes","findConfiguration","configurations","Promise","all","contentType","uid","settings","findContentTypeConfiguration","params","contentTypeService","findContentType","notFound","configuration","confWithUpdatedMetadata","metadatas","mapValues","documentId","edit","list","label","searchable","sortable","components","findComponentsConfigurations","updateContentTypeConfiguration","userAbility","state","request","metricsService","canConfigureContentType","forbidden","input","createModelConfigurationSchema","validate","abortEarly","stripUnknown","strict","badRequest","name","errors","newConfiguration","updateConfiguration","sendDidConfigureListView"],"mappings":"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"}
|
|
@@ -25,7 +25,9 @@ const generateUIDInputSchema = strapiUtils.yup.object({
|
|
|
25
25
|
const checkUIDAvailabilityInputSchema = strapiUtils.yup.object({
|
|
26
26
|
contentTypeUID: strapiUtils.yup.string().required(),
|
|
27
27
|
field: strapiUtils.yup.string().required(),
|
|
28
|
-
value: strapiUtils.yup.string().
|
|
28
|
+
value: strapiUtils.yup.string().required().test('isValueMatchingRegex', `\${path} must match the custom regex or the default one "/^[A-Za-z0-9-_.~]*$/"`, function(value, context) {
|
|
29
|
+
return value === '' || (context.options.context?.regex ? new RegExp(context.options?.context.regex).test(value) : /^[A-Za-z0-9-_.~]*$/.test(value));
|
|
30
|
+
})
|
|
29
31
|
});
|
|
30
32
|
const validateUIDField = (contentTypeUID, field)=>{
|
|
31
33
|
const model = strapi.contentTypes[contentTypeUID];
|
|
@@ -46,7 +48,17 @@ const validateUIDField = (contentTypeUID, field)=>{
|
|
|
46
48
|
const validateKind = strapiUtils.validateYupSchema(kindSchema);
|
|
47
49
|
const validateBulkActionInput = strapiUtils.validateYupSchema(bulkActionInputSchema);
|
|
48
50
|
const validateGenerateUIDInput = strapiUtils.validateYupSchema(generateUIDInputSchema);
|
|
49
|
-
const validateCheckUIDAvailabilityInput =
|
|
51
|
+
const validateCheckUIDAvailabilityInput = (body)=>{
|
|
52
|
+
const options = {};
|
|
53
|
+
const contentType = body.contentTypeUID in strapi.contentTypes ? strapi.contentTypes[body.contentTypeUID] : null;
|
|
54
|
+
if (contentType?.attributes[body.field] && `regex` in contentType.attributes[body.field] && contentType.attributes[body.field].regex) {
|
|
55
|
+
options.context = {
|
|
56
|
+
regex: (contentType?.attributes[body.field]).regex
|
|
57
|
+
};
|
|
58
|
+
}
|
|
59
|
+
const validator = strapiUtils.validateYupSchema(checkUIDAvailabilityInputSchema, options);
|
|
60
|
+
return validator(body);
|
|
61
|
+
};
|
|
50
62
|
|
|
51
63
|
exports.validateBulkActionInput = validateBulkActionInput;
|
|
52
64
|
exports.validateCheckUIDAvailabilityInput = validateCheckUIDAvailabilityInput;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":["../../../../server/src/controllers/validation/index.ts"],"sourcesContent":["import _ from 'lodash';\nimport { yup, validateYupSchema, errors } from '@strapi/utils';\nimport createModelConfigurationSchema from './model-configuration';\n\nconst { PaginationError, ValidationError } = errors;\nconst TYPES = ['singleType', 'collectionType'];\n\n/**\n * Validates type kind\n */\nconst kindSchema = yup.string().oneOf(TYPES).nullable();\n\nconst bulkActionInputSchema = yup\n .object({\n documentIds: yup.array().of(yup.strapiID()).min(1).required(),\n })\n .required();\n\nconst generateUIDInputSchema = yup.object({\n contentTypeUID: yup.string().required(),\n field: yup.string().required(),\n data: yup.object().required(),\n});\n\nconst checkUIDAvailabilityInputSchema = yup.object({\n contentTypeUID: yup.string().required(),\n field: yup.string().required(),\n value: yup\n .string()\n .
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../../../server/src/controllers/validation/index.ts"],"sourcesContent":["import _ from 'lodash';\nimport { Schema, UID } from '@strapi/types';\nimport { yup, validateYupSchema, errors } from '@strapi/utils';\nimport { ValidateOptions } from 'yup/lib/types';\nimport { TestContext } from 'yup';\nimport createModelConfigurationSchema from './model-configuration';\n\nconst { PaginationError, ValidationError } = errors;\nconst TYPES = ['singleType', 'collectionType'];\n\n/**\n * Validates type kind\n */\nconst kindSchema = yup.string().oneOf(TYPES).nullable();\n\nconst bulkActionInputSchema = yup\n .object({\n documentIds: yup.array().of(yup.strapiID()).min(1).required(),\n })\n .required();\n\nconst generateUIDInputSchema = yup.object({\n contentTypeUID: yup.string().required(),\n field: yup.string().required(),\n data: yup.object().required(),\n});\n\nconst checkUIDAvailabilityInputSchema = yup.object({\n contentTypeUID: yup.string().required(),\n field: yup.string().required(),\n value: yup\n .string()\n .required()\n .test(\n 'isValueMatchingRegex',\n `\\${path} must match the custom regex or the default one \"/^[A-Za-z0-9-_.~]*$/\"`,\n function (value, context: TestContext<{ regex?: string }>) {\n return (\n value === '' ||\n (context.options.context?.regex\n ? new RegExp(context.options?.context.regex).test(value as string)\n : /^[A-Za-z0-9-_.~]*$/.test(value as string))\n );\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 = validateYupSchema(kindSchema);\nconst validateBulkActionInput = validateYupSchema(bulkActionInputSchema);\nconst validateGenerateUIDInput = validateYupSchema(generateUIDInputSchema);\nconst validateCheckUIDAvailabilityInput = (body: {\n contentTypeUID: UID.ContentType;\n field: string;\n value: string;\n}) => {\n const options: ValidateOptions<{ regex?: string }> = {};\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 options.context = {\n regex: (contentType?.attributes[body.field] as Schema.Attribute.UID).regex,\n };\n }\n\n const validator = validateYupSchema(checkUIDAvailabilityInputSchema, options);\n\n return validator(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","yup","string","oneOf","nullable","bulkActionInputSchema","object","documentIds","array","of","strapiID","min","required","generateUIDInputSchema","contentTypeUID","field","data","checkUIDAvailabilityInputSchema","value","test","context","options","regex","RegExp","validateUIDField","model","strapi","contentTypes","_","has","get","validateKind","validateYupSchema","validateBulkActionInput","validateGenerateUIDInput","validateCheckUIDAvailabilityInput","body","contentType","attributes","validator"],"mappings":"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"}
|
|
@@ -23,7 +23,9 @@ const generateUIDInputSchema = yup.object({
|
|
|
23
23
|
const checkUIDAvailabilityInputSchema = yup.object({
|
|
24
24
|
contentTypeUID: yup.string().required(),
|
|
25
25
|
field: yup.string().required(),
|
|
26
|
-
value: yup.string().
|
|
26
|
+
value: yup.string().required().test('isValueMatchingRegex', `\${path} must match the custom regex or the default one "/^[A-Za-z0-9-_.~]*$/"`, function(value, context) {
|
|
27
|
+
return value === '' || (context.options.context?.regex ? new RegExp(context.options?.context.regex).test(value) : /^[A-Za-z0-9-_.~]*$/.test(value));
|
|
28
|
+
})
|
|
27
29
|
});
|
|
28
30
|
const validateUIDField = (contentTypeUID, field)=>{
|
|
29
31
|
const model = strapi.contentTypes[contentTypeUID];
|
|
@@ -44,7 +46,17 @@ const validateUIDField = (contentTypeUID, field)=>{
|
|
|
44
46
|
const validateKind = validateYupSchema(kindSchema);
|
|
45
47
|
const validateBulkActionInput = validateYupSchema(bulkActionInputSchema);
|
|
46
48
|
const validateGenerateUIDInput = validateYupSchema(generateUIDInputSchema);
|
|
47
|
-
const validateCheckUIDAvailabilityInput =
|
|
49
|
+
const validateCheckUIDAvailabilityInput = (body)=>{
|
|
50
|
+
const options = {};
|
|
51
|
+
const contentType = body.contentTypeUID in strapi.contentTypes ? strapi.contentTypes[body.contentTypeUID] : null;
|
|
52
|
+
if (contentType?.attributes[body.field] && `regex` in contentType.attributes[body.field] && contentType.attributes[body.field].regex) {
|
|
53
|
+
options.context = {
|
|
54
|
+
regex: (contentType?.attributes[body.field]).regex
|
|
55
|
+
};
|
|
56
|
+
}
|
|
57
|
+
const validator = validateYupSchema(checkUIDAvailabilityInputSchema, options);
|
|
58
|
+
return validator(body);
|
|
59
|
+
};
|
|
48
60
|
|
|
49
61
|
export { validateBulkActionInput, validateCheckUIDAvailabilityInput, validateGenerateUIDInput, validateKind, validateUIDField };
|
|
50
62
|
//# sourceMappingURL=index.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.mjs","sources":["../../../../server/src/controllers/validation/index.ts"],"sourcesContent":["import _ from 'lodash';\nimport { yup, validateYupSchema, errors } from '@strapi/utils';\nimport createModelConfigurationSchema from './model-configuration';\n\nconst { PaginationError, ValidationError } = errors;\nconst TYPES = ['singleType', 'collectionType'];\n\n/**\n * Validates type kind\n */\nconst kindSchema = yup.string().oneOf(TYPES).nullable();\n\nconst bulkActionInputSchema = yup\n .object({\n documentIds: yup.array().of(yup.strapiID()).min(1).required(),\n })\n .required();\n\nconst generateUIDInputSchema = yup.object({\n contentTypeUID: yup.string().required(),\n field: yup.string().required(),\n data: yup.object().required(),\n});\n\nconst checkUIDAvailabilityInputSchema = yup.object({\n contentTypeUID: yup.string().required(),\n field: yup.string().required(),\n value: yup\n .string()\n .
|
|
1
|
+
{"version":3,"file":"index.mjs","sources":["../../../../server/src/controllers/validation/index.ts"],"sourcesContent":["import _ from 'lodash';\nimport { Schema, UID } from '@strapi/types';\nimport { yup, validateYupSchema, errors } from '@strapi/utils';\nimport { ValidateOptions } from 'yup/lib/types';\nimport { TestContext } from 'yup';\nimport createModelConfigurationSchema from './model-configuration';\n\nconst { PaginationError, ValidationError } = errors;\nconst TYPES = ['singleType', 'collectionType'];\n\n/**\n * Validates type kind\n */\nconst kindSchema = yup.string().oneOf(TYPES).nullable();\n\nconst bulkActionInputSchema = yup\n .object({\n documentIds: yup.array().of(yup.strapiID()).min(1).required(),\n })\n .required();\n\nconst generateUIDInputSchema = yup.object({\n contentTypeUID: yup.string().required(),\n field: yup.string().required(),\n data: yup.object().required(),\n});\n\nconst checkUIDAvailabilityInputSchema = yup.object({\n contentTypeUID: yup.string().required(),\n field: yup.string().required(),\n value: yup\n .string()\n .required()\n .test(\n 'isValueMatchingRegex',\n `\\${path} must match the custom regex or the default one \"/^[A-Za-z0-9-_.~]*$/\"`,\n function (value, context: TestContext<{ regex?: string }>) {\n return (\n value === '' ||\n (context.options.context?.regex\n ? new RegExp(context.options?.context.regex).test(value as string)\n : /^[A-Za-z0-9-_.~]*$/.test(value as string))\n );\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 = validateYupSchema(kindSchema);\nconst validateBulkActionInput = validateYupSchema(bulkActionInputSchema);\nconst validateGenerateUIDInput = validateYupSchema(generateUIDInputSchema);\nconst validateCheckUIDAvailabilityInput = (body: {\n contentTypeUID: UID.ContentType;\n field: string;\n value: string;\n}) => {\n const options: ValidateOptions<{ regex?: string }> = {};\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 options.context = {\n regex: (contentType?.attributes[body.field] as Schema.Attribute.UID).regex,\n };\n }\n\n const validator = validateYupSchema(checkUIDAvailabilityInputSchema, options);\n\n return validator(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","yup","string","oneOf","nullable","bulkActionInputSchema","object","documentIds","array","of","strapiID","min","required","generateUIDInputSchema","contentTypeUID","field","data","checkUIDAvailabilityInputSchema","value","test","context","options","regex","RegExp","validateUIDField","model","strapi","contentTypes","_","has","get","validateKind","validateYupSchema","validateBulkActionInput","validateGenerateUIDInput","validateCheckUIDAvailabilityInput","body","contentType","attributes","validator"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"data-mapper.js","sources":["../../../server/src/services/data-mapper.ts"],"sourcesContent":["import { pick, getOr } from 'lodash/fp';\nimport { contentTypes as contentTypesUtils } from '@strapi/utils';\n\nimport type { Schema, Struct } from '@strapi/types';\n\nconst dtoFields = [\n 'uid',\n 'isDisplayed',\n 'apiID',\n 'kind',\n 'category',\n 'info',\n 'options',\n 'pluginOptions',\n 'attributes',\n 'pluginOptions',\n];\n\nexport default () => ({\n toContentManagerModel(contentType: Struct.ComponentSchema) {\n return {\n ...contentType,\n apiID: contentType.modelName,\n isDisplayed: isVisible(contentType),\n attributes: {\n id: {\n type: 'integer',\n },\n ...formatAttributes(contentType),\n },\n };\n },\n\n toDto: pick(dtoFields),\n});\n\nconst formatAttributes = (contentType: Struct.ComponentSchema) => {\n const { getVisibleAttributes, getTimestamps, getCreatorFields } = contentTypesUtils;\n\n // only get attributes that can be seen in the auto generated Edit view or List view\n return getVisibleAttributes(contentType)\n .concat(getTimestamps(contentType))\n .concat(getCreatorFields(contentType))\n .reduce((acc: any, key: string) => {\n const attribute = contentType.attributes[key];\n\n // ignore morph until they are handled in the front\n if (attribute.type === 'relation' && attribute.relation.toLowerCase().includes('morph')) {\n return acc;\n }\n\n acc[key] = formatAttribute(key, attribute);\n return acc;\n }, {});\n};\n\n// FIXME: not needed\nconst formatAttribute = (key: any, attribute: Schema.Attribute.AnyAttribute) => {\n if (attribute.type === 'relation') {\n return toRelation(attribute);\n }\n\n return attribute;\n};\n\n// FIXME: not needed\nconst toRelation = (attribute: Schema.Attribute.Relation) => {\n return {\n ...attribute,\n type: 'relation',\n targetModel: 'target' in attribute ? attribute.target : undefined,\n relationType: attribute.relation,\n };\n};\n\nconst isVisible = (model: Struct.ComponentSchema): boolean =>\n getOr(true, 'pluginOptions.content-manager.visible', model) === true;\n"],"names":["dtoFields","toContentManagerModel","contentType","apiID","modelName","isDisplayed","isVisible","attributes","id","type","formatAttributes","toDto","pick","getVisibleAttributes","getTimestamps","getCreatorFields","contentTypesUtils","concat","reduce","acc","key","attribute","relation","toLowerCase","includes","formatAttribute","toRelation","targetModel","target","undefined","relationType","model","getOr"],"mappings":";;;;;AAKA,MAAMA,SAAY,GAAA;AAChB,IAAA,KAAA;AACA,IAAA,aAAA;AACA,IAAA,OAAA;AACA,IAAA,MAAA;AACA,IAAA,UAAA;AACA,IAAA,MAAA;AACA,IAAA,SAAA;AACA,IAAA,eAAA;AACA,IAAA,YAAA;AACA,IAAA;AACD,CAAA;AAED,iBAAe,CAAA,KAAO;AACpBC,QAAAA,qBAAAA,CAAAA,CAAsBC,WAAmC,EAAA;YACvD,OAAO;AACL,gBAAA,GAAGA,WAAW;AACdC,gBAAAA,KAAAA,EAAOD,YAAYE,SAAS;AAC5BC,gBAAAA,WAAAA,EAAaC,SAAUJ,CAAAA,WAAAA,CAAAA;gBACvBK,UAAY,EAAA;oBACVC,EAAI,EAAA;wBACFC,IAAM,EAAA;AACR,qBAAA;AACA,oBAAA,GAAGC,iBAAiBR,WAAY;
|
|
1
|
+
{"version":3,"file":"data-mapper.js","sources":["../../../server/src/services/data-mapper.ts"],"sourcesContent":["import { pick, getOr } from 'lodash/fp';\nimport { contentTypes as contentTypesUtils } from '@strapi/utils';\n\nimport type { Schema, Struct } from '@strapi/types';\n\nconst dtoFields = [\n 'uid',\n 'isDisplayed',\n 'apiID',\n 'kind',\n 'category',\n 'info',\n 'options',\n 'pluginOptions',\n 'attributes',\n 'pluginOptions',\n];\n\nexport default () => ({\n toContentManagerModel(contentType: Struct.ComponentSchema) {\n return {\n ...contentType,\n apiID: contentType.modelName,\n isDisplayed: isVisible(contentType),\n attributes: {\n id: {\n type: 'integer',\n },\n ...formatAttributes(contentType),\n documentId: {\n type: 'string',\n },\n },\n };\n },\n\n toDto: pick(dtoFields),\n});\n\nconst formatAttributes = (contentType: Struct.ComponentSchema) => {\n const { getVisibleAttributes, getTimestamps, getCreatorFields } = contentTypesUtils;\n\n // only get attributes that can be seen in the auto generated Edit view or List view\n return getVisibleAttributes(contentType)\n .concat(getTimestamps(contentType))\n .concat(getCreatorFields(contentType))\n .reduce((acc: any, key: string) => {\n const attribute = contentType.attributes[key];\n\n // ignore morph until they are handled in the front\n if (attribute.type === 'relation' && attribute.relation.toLowerCase().includes('morph')) {\n return acc;\n }\n\n acc[key] = formatAttribute(key, attribute);\n return acc;\n }, {});\n};\n\n// FIXME: not needed\nconst formatAttribute = (key: any, attribute: Schema.Attribute.AnyAttribute) => {\n if (attribute.type === 'relation') {\n return toRelation(attribute);\n }\n\n return attribute;\n};\n\n// FIXME: not needed\nconst toRelation = (attribute: Schema.Attribute.Relation) => {\n return {\n ...attribute,\n type: 'relation',\n targetModel: 'target' in attribute ? attribute.target : undefined,\n relationType: attribute.relation,\n };\n};\n\nconst isVisible = (model: Struct.ComponentSchema): boolean =>\n getOr(true, 'pluginOptions.content-manager.visible', model) === true;\n"],"names":["dtoFields","toContentManagerModel","contentType","apiID","modelName","isDisplayed","isVisible","attributes","id","type","formatAttributes","documentId","toDto","pick","getVisibleAttributes","getTimestamps","getCreatorFields","contentTypesUtils","concat","reduce","acc","key","attribute","relation","toLowerCase","includes","formatAttribute","toRelation","targetModel","target","undefined","relationType","model","getOr"],"mappings":";;;;;AAKA,MAAMA,SAAY,GAAA;AAChB,IAAA,KAAA;AACA,IAAA,aAAA;AACA,IAAA,OAAA;AACA,IAAA,MAAA;AACA,IAAA,UAAA;AACA,IAAA,MAAA;AACA,IAAA,SAAA;AACA,IAAA,eAAA;AACA,IAAA,YAAA;AACA,IAAA;AACD,CAAA;AAED,iBAAe,CAAA,KAAO;AACpBC,QAAAA,qBAAAA,CAAAA,CAAsBC,WAAmC,EAAA;YACvD,OAAO;AACL,gBAAA,GAAGA,WAAW;AACdC,gBAAAA,KAAAA,EAAOD,YAAYE,SAAS;AAC5BC,gBAAAA,WAAAA,EAAaC,SAAUJ,CAAAA,WAAAA,CAAAA;gBACvBK,UAAY,EAAA;oBACVC,EAAI,EAAA;wBACFC,IAAM,EAAA;AACR,qBAAA;AACA,oBAAA,GAAGC,iBAAiBR,WAAY,CAAA;oBAChCS,UAAY,EAAA;wBACVF,IAAM,EAAA;AACR;AACF;AACF,aAAA;AACF,SAAA;AAEAG,QAAAA,KAAAA,EAAOC,OAAKb,CAAAA,SAAAA;AACd,KAAA,CAAC;AAED,MAAMU,mBAAmB,CAACR,WAAAA,GAAAA;AACxB,IAAA,MAAM,EAAEY,oBAAoB,EAAEC,aAAa,EAAEC,gBAAgB,EAAE,GAAGC,wBAAAA;;AAGlE,IAAA,OAAOH,oBAAqBZ,CAAAA,WAAAA,CAAAA,CACzBgB,MAAM,CAACH,aAAcb,CAAAA,WAAAA,CAAAA,CAAAA,CACrBgB,MAAM,CAACF,gBAAiBd,CAAAA,WAAAA,CAAAA,CAAAA,CACxBiB,MAAM,CAAC,CAACC,GAAUC,EAAAA,GAAAA,GAAAA;AACjB,QAAA,MAAMC,SAAYpB,GAAAA,WAAAA,CAAYK,UAAU,CAACc,GAAI,CAAA;;QAG7C,IAAIC,SAAAA,CAAUb,IAAI,KAAK,UAAca,IAAAA,SAAAA,CAAUC,QAAQ,CAACC,WAAW,EAAA,CAAGC,QAAQ,CAAC,OAAU,CAAA,EAAA;YACvF,OAAOL,GAAAA;AACT;AAEAA,QAAAA,GAAG,CAACC,GAAAA,CAAI,GAAGK,eAAAA,CAAgBL,GAAKC,EAAAA,SAAAA,CAAAA;QAChC,OAAOF,GAAAA;AACT,KAAA,EAAG,EAAC,CAAA;AACR,CAAA;AAEA;AACA,MAAMM,eAAAA,GAAkB,CAACL,GAAUC,EAAAA,SAAAA,GAAAA;IACjC,IAAIA,SAAAA,CAAUb,IAAI,KAAK,UAAY,EAAA;AACjC,QAAA,OAAOkB,UAAWL,CAAAA,SAAAA,CAAAA;AACpB;IAEA,OAAOA,SAAAA;AACT,CAAA;AAEA;AACA,MAAMK,aAAa,CAACL,SAAAA,GAAAA;IAClB,OAAO;AACL,QAAA,GAAGA,SAAS;QACZb,IAAM,EAAA,UAAA;AACNmB,QAAAA,WAAAA,EAAa,QAAYN,IAAAA,SAAAA,GAAYA,SAAUO,CAAAA,MAAM,GAAGC,SAAAA;AACxDC,QAAAA,YAAAA,EAAcT,UAAUC;AAC1B,KAAA;AACF,CAAA;AAEA,MAAMjB,YAAY,CAAC0B,KAAAA,GACjBC,QAAM,CAAA,IAAA,EAAM,yCAAyCD,KAAW,CAAA,KAAA,IAAA;;;;"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"data-mapper.mjs","sources":["../../../server/src/services/data-mapper.ts"],"sourcesContent":["import { pick, getOr } from 'lodash/fp';\nimport { contentTypes as contentTypesUtils } from '@strapi/utils';\n\nimport type { Schema, Struct } from '@strapi/types';\n\nconst dtoFields = [\n 'uid',\n 'isDisplayed',\n 'apiID',\n 'kind',\n 'category',\n 'info',\n 'options',\n 'pluginOptions',\n 'attributes',\n 'pluginOptions',\n];\n\nexport default () => ({\n toContentManagerModel(contentType: Struct.ComponentSchema) {\n return {\n ...contentType,\n apiID: contentType.modelName,\n isDisplayed: isVisible(contentType),\n attributes: {\n id: {\n type: 'integer',\n },\n ...formatAttributes(contentType),\n },\n };\n },\n\n toDto: pick(dtoFields),\n});\n\nconst formatAttributes = (contentType: Struct.ComponentSchema) => {\n const { getVisibleAttributes, getTimestamps, getCreatorFields } = contentTypesUtils;\n\n // only get attributes that can be seen in the auto generated Edit view or List view\n return getVisibleAttributes(contentType)\n .concat(getTimestamps(contentType))\n .concat(getCreatorFields(contentType))\n .reduce((acc: any, key: string) => {\n const attribute = contentType.attributes[key];\n\n // ignore morph until they are handled in the front\n if (attribute.type === 'relation' && attribute.relation.toLowerCase().includes('morph')) {\n return acc;\n }\n\n acc[key] = formatAttribute(key, attribute);\n return acc;\n }, {});\n};\n\n// FIXME: not needed\nconst formatAttribute = (key: any, attribute: Schema.Attribute.AnyAttribute) => {\n if (attribute.type === 'relation') {\n return toRelation(attribute);\n }\n\n return attribute;\n};\n\n// FIXME: not needed\nconst toRelation = (attribute: Schema.Attribute.Relation) => {\n return {\n ...attribute,\n type: 'relation',\n targetModel: 'target' in attribute ? attribute.target : undefined,\n relationType: attribute.relation,\n };\n};\n\nconst isVisible = (model: Struct.ComponentSchema): boolean =>\n getOr(true, 'pluginOptions.content-manager.visible', model) === true;\n"],"names":["dtoFields","toContentManagerModel","contentType","apiID","modelName","isDisplayed","isVisible","attributes","id","type","formatAttributes","toDto","pick","getVisibleAttributes","getTimestamps","getCreatorFields","contentTypesUtils","concat","reduce","acc","key","attribute","relation","toLowerCase","includes","formatAttribute","toRelation","targetModel","target","undefined","relationType","model","getOr"],"mappings":";;;AAKA,MAAMA,SAAY,GAAA;AAChB,IAAA,KAAA;AACA,IAAA,aAAA;AACA,IAAA,OAAA;AACA,IAAA,MAAA;AACA,IAAA,UAAA;AACA,IAAA,MAAA;AACA,IAAA,SAAA;AACA,IAAA,eAAA;AACA,IAAA,YAAA;AACA,IAAA;AACD,CAAA;AAED,iBAAe,CAAA,KAAO;AACpBC,QAAAA,qBAAAA,CAAAA,CAAsBC,WAAmC,EAAA;YACvD,OAAO;AACL,gBAAA,GAAGA,WAAW;AACdC,gBAAAA,KAAAA,EAAOD,YAAYE,SAAS;AAC5BC,gBAAAA,WAAAA,EAAaC,SAAUJ,CAAAA,WAAAA,CAAAA;gBACvBK,UAAY,EAAA;oBACVC,EAAI,EAAA;wBACFC,IAAM,EAAA;AACR,qBAAA;AACA,oBAAA,GAAGC,iBAAiBR,WAAY;
|
|
1
|
+
{"version":3,"file":"data-mapper.mjs","sources":["../../../server/src/services/data-mapper.ts"],"sourcesContent":["import { pick, getOr } from 'lodash/fp';\nimport { contentTypes as contentTypesUtils } from '@strapi/utils';\n\nimport type { Schema, Struct } from '@strapi/types';\n\nconst dtoFields = [\n 'uid',\n 'isDisplayed',\n 'apiID',\n 'kind',\n 'category',\n 'info',\n 'options',\n 'pluginOptions',\n 'attributes',\n 'pluginOptions',\n];\n\nexport default () => ({\n toContentManagerModel(contentType: Struct.ComponentSchema) {\n return {\n ...contentType,\n apiID: contentType.modelName,\n isDisplayed: isVisible(contentType),\n attributes: {\n id: {\n type: 'integer',\n },\n ...formatAttributes(contentType),\n documentId: {\n type: 'string',\n },\n },\n };\n },\n\n toDto: pick(dtoFields),\n});\n\nconst formatAttributes = (contentType: Struct.ComponentSchema) => {\n const { getVisibleAttributes, getTimestamps, getCreatorFields } = contentTypesUtils;\n\n // only get attributes that can be seen in the auto generated Edit view or List view\n return getVisibleAttributes(contentType)\n .concat(getTimestamps(contentType))\n .concat(getCreatorFields(contentType))\n .reduce((acc: any, key: string) => {\n const attribute = contentType.attributes[key];\n\n // ignore morph until they are handled in the front\n if (attribute.type === 'relation' && attribute.relation.toLowerCase().includes('morph')) {\n return acc;\n }\n\n acc[key] = formatAttribute(key, attribute);\n return acc;\n }, {});\n};\n\n// FIXME: not needed\nconst formatAttribute = (key: any, attribute: Schema.Attribute.AnyAttribute) => {\n if (attribute.type === 'relation') {\n return toRelation(attribute);\n }\n\n return attribute;\n};\n\n// FIXME: not needed\nconst toRelation = (attribute: Schema.Attribute.Relation) => {\n return {\n ...attribute,\n type: 'relation',\n targetModel: 'target' in attribute ? attribute.target : undefined,\n relationType: attribute.relation,\n };\n};\n\nconst isVisible = (model: Struct.ComponentSchema): boolean =>\n getOr(true, 'pluginOptions.content-manager.visible', model) === true;\n"],"names":["dtoFields","toContentManagerModel","contentType","apiID","modelName","isDisplayed","isVisible","attributes","id","type","formatAttributes","documentId","toDto","pick","getVisibleAttributes","getTimestamps","getCreatorFields","contentTypesUtils","concat","reduce","acc","key","attribute","relation","toLowerCase","includes","formatAttribute","toRelation","targetModel","target","undefined","relationType","model","getOr"],"mappings":";;;AAKA,MAAMA,SAAY,GAAA;AAChB,IAAA,KAAA;AACA,IAAA,aAAA;AACA,IAAA,OAAA;AACA,IAAA,MAAA;AACA,IAAA,UAAA;AACA,IAAA,MAAA;AACA,IAAA,SAAA;AACA,IAAA,eAAA;AACA,IAAA,YAAA;AACA,IAAA;AACD,CAAA;AAED,iBAAe,CAAA,KAAO;AACpBC,QAAAA,qBAAAA,CAAAA,CAAsBC,WAAmC,EAAA;YACvD,OAAO;AACL,gBAAA,GAAGA,WAAW;AACdC,gBAAAA,KAAAA,EAAOD,YAAYE,SAAS;AAC5BC,gBAAAA,WAAAA,EAAaC,SAAUJ,CAAAA,WAAAA,CAAAA;gBACvBK,UAAY,EAAA;oBACVC,EAAI,EAAA;wBACFC,IAAM,EAAA;AACR,qBAAA;AACA,oBAAA,GAAGC,iBAAiBR,WAAY,CAAA;oBAChCS,UAAY,EAAA;wBACVF,IAAM,EAAA;AACR;AACF;AACF,aAAA;AACF,SAAA;AAEAG,QAAAA,KAAAA,EAAOC,IAAKb,CAAAA,SAAAA;AACd,KAAA,CAAC;AAED,MAAMU,mBAAmB,CAACR,WAAAA,GAAAA;AACxB,IAAA,MAAM,EAAEY,oBAAoB,EAAEC,aAAa,EAAEC,gBAAgB,EAAE,GAAGC,YAAAA;;AAGlE,IAAA,OAAOH,oBAAqBZ,CAAAA,WAAAA,CAAAA,CACzBgB,MAAM,CAACH,aAAcb,CAAAA,WAAAA,CAAAA,CAAAA,CACrBgB,MAAM,CAACF,gBAAiBd,CAAAA,WAAAA,CAAAA,CAAAA,CACxBiB,MAAM,CAAC,CAACC,GAAUC,EAAAA,GAAAA,GAAAA;AACjB,QAAA,MAAMC,SAAYpB,GAAAA,WAAAA,CAAYK,UAAU,CAACc,GAAI,CAAA;;QAG7C,IAAIC,SAAAA,CAAUb,IAAI,KAAK,UAAca,IAAAA,SAAAA,CAAUC,QAAQ,CAACC,WAAW,EAAA,CAAGC,QAAQ,CAAC,OAAU,CAAA,EAAA;YACvF,OAAOL,GAAAA;AACT;AAEAA,QAAAA,GAAG,CAACC,GAAAA,CAAI,GAAGK,eAAAA,CAAgBL,GAAKC,EAAAA,SAAAA,CAAAA;QAChC,OAAOF,GAAAA;AACT,KAAA,EAAG,EAAC,CAAA;AACR,CAAA;AAEA;AACA,MAAMM,eAAAA,GAAkB,CAACL,GAAUC,EAAAA,SAAAA,GAAAA;IACjC,IAAIA,SAAAA,CAAUb,IAAI,KAAK,UAAY,EAAA;AACjC,QAAA,OAAOkB,UAAWL,CAAAA,SAAAA,CAAAA;AACpB;IAEA,OAAOA,SAAAA;AACT,CAAA;AAEA;AACA,MAAMK,aAAa,CAACL,SAAAA,GAAAA;IAClB,OAAO;AACL,QAAA,GAAGA,SAAS;QACZb,IAAM,EAAA,UAAA;AACNmB,QAAAA,WAAAA,EAAa,QAAYN,IAAAA,SAAAA,GAAYA,SAAUO,CAAAA,MAAM,GAAGC,SAAAA;AACxDC,QAAAA,YAAAA,EAAcT,UAAUC;AAC1B,KAAA;AACF,CAAA;AAEA,MAAMjB,YAAY,CAAC0B,KAAAA,GACjBC,KAAM,CAAA,IAAA,EAAM,yCAAyCD,KAAW,CAAA,KAAA,IAAA;;;;"}
|
|
@@ -91,8 +91,15 @@ const documentManager = ({ strapi })=>{
|
|
|
91
91
|
},
|
|
92
92
|
async clone (id, body, uid) {
|
|
93
93
|
const populate$1 = await populate.buildDeepPopulate(uid);
|
|
94
|
+
// Extract the locale to pass it as a plain param
|
|
95
|
+
const locale = body?.locale;
|
|
94
96
|
const params = {
|
|
95
|
-
|
|
97
|
+
// Ensure id and documentId are not copied to the clone
|
|
98
|
+
data: fp.omit([
|
|
99
|
+
'id',
|
|
100
|
+
'documentId'
|
|
101
|
+
], body),
|
|
102
|
+
locale,
|
|
96
103
|
populate: populate$1
|
|
97
104
|
};
|
|
98
105
|
return strapi.documents(uid).clone({
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"document-manager.js","sources":["../../../server/src/services/document-manager.ts"],"sourcesContent":["import { omit, pipe } from 'lodash/fp';\n\nimport { contentTypes, errors, pagination } from '@strapi/utils';\nimport type { Core, Modules, UID } from '@strapi/types';\n\nimport { buildDeepPopulate, getDeepPopulate, getDeepPopulateDraftCount } from './utils/populate';\nimport { sumDraftCounts } from './utils/draft';\n\ntype DocService = Modules.Documents.ServiceInstance;\ntype DocServiceParams<TAction extends keyof DocService> = Parameters<DocService[TAction]>[0];\nexport type Document = Modules.Documents.Result<UID.ContentType>;\n\nconst { ApplicationError } = errors;\nconst { PUBLISHED_AT_ATTRIBUTE } = contentTypes.constants;\n\nconst omitPublishedAtField = omit(PUBLISHED_AT_ATTRIBUTE);\nconst omitIdField = omit('id');\n\nconst documentManager = ({ strapi }: { strapi: Core.Strapi }) => {\n return {\n async findOne(\n id: string,\n uid: UID.CollectionType,\n opts: Omit<DocServiceParams<'findOne'>, 'documentId'> = {}\n ) {\n return strapi.documents(uid).findOne({ ...opts, documentId: id });\n },\n\n /**\n * Find multiple (or all) locales for a document\n */\n async findLocales(\n id: string | string[] | undefined,\n uid: UID.CollectionType,\n opts: {\n populate?: Modules.Documents.Params.Pick<any, 'populate'>;\n locale?: string | string[] | '*';\n isPublished?: boolean;\n }\n ) {\n // Will look for a specific locale by default\n const where: any = {};\n\n // Might not have an id if querying a single type\n if (id) {\n where.documentId = id;\n }\n\n // Search in array of locales\n if (Array.isArray(opts.locale)) {\n where.locale = { $in: opts.locale };\n } else if (opts.locale && opts.locale !== '*') {\n // Look for a specific locale, ignore if looking for all locales\n where.locale = opts.locale;\n }\n\n // Published is passed, so we filter on it, otherwise we don't filter\n if (typeof opts.isPublished === 'boolean') {\n where.publishedAt = { $notNull: opts.isPublished };\n }\n\n return strapi.db.query(uid).findMany({ populate: opts.populate, where });\n },\n\n async findMany(opts: DocServiceParams<'findMany'>, uid: UID.CollectionType) {\n const params = { ...opts, populate: getDeepPopulate(uid) } as typeof opts;\n return strapi.documents(uid).findMany(params);\n },\n\n async findPage(opts: DocServiceParams<'findMany'>, uid: UID.CollectionType) {\n const params = pagination.withDefaultPagination(opts || {}, {\n maxLimit: 1000,\n });\n\n const [documents, total = 0] = await Promise.all([\n strapi.documents(uid).findMany(params),\n strapi.documents(uid).count(params),\n ]);\n\n return {\n results: documents,\n pagination: pagination.transformPagedPaginationInfo(params, total),\n };\n },\n\n async create(uid: UID.CollectionType, opts: DocServiceParams<'create'> = {} as any) {\n const populate = opts.populate ?? (await buildDeepPopulate(uid));\n const params = { ...opts, status: 'draft' as const, populate };\n\n return strapi.documents(uid).create(params);\n },\n\n async update(\n id: Modules.Documents.ID,\n uid: UID.CollectionType,\n opts: Omit<DocServiceParams<'update'>, 'documentId'> = {} as any\n ) {\n const publishData = pipe(omitPublishedAtField, omitIdField)(opts.data || {});\n const populate = opts.populate ?? (await buildDeepPopulate(uid));\n const params = { ...opts, data: publishData, populate, status: 'draft' };\n\n return strapi.documents(uid).update({ ...params, documentId: id });\n },\n\n async clone(\n id: Modules.Documents.ID,\n body: Partial<Modules.Documents.Params.Data.Input<UID.CollectionType>>,\n uid: UID.CollectionType\n ) {\n const populate = await buildDeepPopulate(uid);\n const params = {\n data: omitIdField(body),\n populate,\n };\n\n return strapi\n .documents(uid)\n .clone({ ...params, documentId: id })\n .then((result) => result?.entries.at(0));\n },\n\n /**\n * Check if a document exists\n */\n async exists(uid: UID.CollectionType, id?: string) {\n // Collection type\n if (id) {\n const count = await strapi.db.query(uid).count({ where: { documentId: id } });\n return count > 0;\n }\n\n // Single type\n const count = await strapi.db.query(uid).count();\n return count > 0;\n },\n\n async delete(\n id: Modules.Documents.ID,\n uid: UID.CollectionType,\n opts: Omit<DocServiceParams<'delete'>, 'documentId'> = {} as any\n ) {\n const populate = await buildDeepPopulate(uid);\n\n await strapi.documents(uid).delete({\n ...opts,\n documentId: id,\n populate,\n });\n return {};\n },\n\n // FIXME: handle relations\n async deleteMany(\n documentIds: Modules.Documents.ID[],\n uid: UID.CollectionType,\n opts: DocServiceParams<'findMany'> & { locale?: string } = {}\n ) {\n const deletedEntries = await strapi.db.transaction(async () => {\n return Promise.all(documentIds.map(async (id) => this.delete(id, uid, opts)));\n });\n\n return { count: deletedEntries.length };\n },\n\n async publish(\n id: Modules.Documents.ID,\n uid: UID.CollectionType,\n opts: Omit<DocServiceParams<'publish'>, 'documentId'> = {} as any\n ) {\n const populate = await buildDeepPopulate(uid);\n const params = { ...opts, populate };\n\n return strapi\n .documents(uid)\n .publish({ ...params, documentId: id })\n .then((result) => result?.entries);\n },\n\n async publishMany(uid: UID.ContentType, documentIds: string[], locale?: string | string[]) {\n return strapi.db.transaction(async () => {\n const results = await Promise.all(\n documentIds.map((documentId) => this.publish(documentId, uid, { locale }))\n );\n\n const publishedEntitiesCount = results.flat().filter(Boolean).length;\n return publishedEntitiesCount;\n });\n },\n\n async unpublishMany(\n documentIds: Modules.Documents.ID[],\n uid: UID.CollectionType,\n opts: Omit<DocServiceParams<'unpublish'>, 'documentId'> = {} as any\n ) {\n const unpublishedEntries = await strapi.db.transaction(async () => {\n return Promise.all(\n documentIds.map((id) =>\n strapi\n .documents(uid)\n .unpublish({ ...opts, documentId: id })\n .then((result) => result?.entries)\n )\n );\n });\n\n const unpublishedEntitiesCount = unpublishedEntries.flat().filter(Boolean).length;\n\n // Return the number of unpublished entities\n return { count: unpublishedEntitiesCount };\n },\n\n async unpublish(\n id: Modules.Documents.ID,\n uid: UID.CollectionType,\n opts: Omit<DocServiceParams<'unpublish'>, 'documentId'> = {} as any\n ) {\n const populate = await buildDeepPopulate(uid);\n const params = { ...opts, populate };\n\n return strapi\n .documents(uid)\n .unpublish({ ...params, documentId: id })\n .then((result) => result?.entries.at(0));\n },\n\n async discardDraft(\n id: Modules.Documents.ID,\n uid: UID.CollectionType,\n opts: Omit<DocServiceParams<'discardDraft'>, 'documentId'> = {} as any\n ) {\n const populate = await buildDeepPopulate(uid);\n const params = { ...opts, populate };\n\n return strapi\n .documents(uid)\n .discardDraft({ ...params, documentId: id })\n .then((result) => result?.entries.at(0));\n },\n\n async countDraftRelations(id: string, uid: UID.ContentType, locale: string) {\n const { populate, hasRelations } = getDeepPopulateDraftCount(uid);\n\n if (!hasRelations) {\n return 0;\n }\n\n const document = await strapi.documents(uid).findOne({ documentId: id, populate, locale });\n if (!document) {\n throw new ApplicationError(\n `Unable to count draft relations, document with id ${id} and locale ${locale} not found`\n );\n }\n\n return sumDraftCounts(document, uid);\n },\n\n async countManyEntriesDraftRelations(\n documentIds: Modules.Documents.ID[],\n uid: UID.CollectionType,\n locale: string | string[]\n ) {\n const { populate, hasRelations } = getDeepPopulateDraftCount(uid);\n\n if (!hasRelations) {\n return 0;\n }\n\n let localeFilter = {};\n if (locale) {\n localeFilter = Array.isArray(locale) ? { locale: { $in: locale } } : { locale };\n }\n\n const entities = await strapi.db.query(uid).findMany({\n populate,\n where: {\n documentId: { $in: documentIds },\n ...localeFilter,\n },\n });\n\n const totalNumberDraftRelations: number = entities!.reduce(\n (count: number, entity: Document) => sumDraftCounts(entity, uid) + count,\n 0\n );\n\n return totalNumberDraftRelations;\n },\n };\n};\n\nexport type DocumentManagerService = typeof documentManager;\n\nexport default documentManager;\n"],"names":["ApplicationError","errors","PUBLISHED_AT_ATTRIBUTE","contentTypes","constants","omitPublishedAtField","omit","omitIdField","documentManager","strapi","findOne","id","uid","opts","documents","documentId","findLocales","where","Array","isArray","locale","$in","isPublished","publishedAt","$notNull","db","query","findMany","populate","params","getDeepPopulate","findPage","pagination","withDefaultPagination","maxLimit","total","Promise","all","count","results","transformPagedPaginationInfo","create","buildDeepPopulate","status","update","publishData","pipe","data","clone","body","then","result","entries","at","exists","delete","deleteMany","documentIds","deletedEntries","transaction","map","length","publish","publishMany","publishedEntitiesCount","flat","filter","Boolean","unpublishMany","unpublishedEntries","unpublish","unpublishedEntitiesCount","discardDraft","countDraftRelations","hasRelations","getDeepPopulateDraftCount","document","sumDraftCounts","countManyEntriesDraftRelations","localeFilter","entities","totalNumberDraftRelations","reduce","entity"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"document-manager.js","sources":["../../../server/src/services/document-manager.ts"],"sourcesContent":["import { omit, pipe } from 'lodash/fp';\n\nimport { contentTypes, errors, pagination } from '@strapi/utils';\nimport type { Core, Modules, UID } from '@strapi/types';\n\nimport { buildDeepPopulate, getDeepPopulate, getDeepPopulateDraftCount } from './utils/populate';\nimport { sumDraftCounts } from './utils/draft';\n\ntype DocService = Modules.Documents.ServiceInstance;\ntype DocServiceParams<TAction extends keyof DocService> = Parameters<DocService[TAction]>[0];\nexport type Document = Modules.Documents.Result<UID.ContentType>;\n\nconst { ApplicationError } = errors;\nconst { PUBLISHED_AT_ATTRIBUTE } = contentTypes.constants;\n\nconst omitPublishedAtField = omit(PUBLISHED_AT_ATTRIBUTE);\nconst omitIdField = omit('id');\n\nconst documentManager = ({ strapi }: { strapi: Core.Strapi }) => {\n return {\n async findOne(\n id: string,\n uid: UID.CollectionType,\n opts: Omit<DocServiceParams<'findOne'>, 'documentId'> = {}\n ) {\n return strapi.documents(uid).findOne({ ...opts, documentId: id });\n },\n\n /**\n * Find multiple (or all) locales for a document\n */\n async findLocales(\n id: string | string[] | undefined,\n uid: UID.CollectionType,\n opts: {\n populate?: Modules.Documents.Params.Pick<any, 'populate'>;\n locale?: string | string[] | '*';\n isPublished?: boolean;\n }\n ) {\n // Will look for a specific locale by default\n const where: any = {};\n\n // Might not have an id if querying a single type\n if (id) {\n where.documentId = id;\n }\n\n // Search in array of locales\n if (Array.isArray(opts.locale)) {\n where.locale = { $in: opts.locale };\n } else if (opts.locale && opts.locale !== '*') {\n // Look for a specific locale, ignore if looking for all locales\n where.locale = opts.locale;\n }\n\n // Published is passed, so we filter on it, otherwise we don't filter\n if (typeof opts.isPublished === 'boolean') {\n where.publishedAt = { $notNull: opts.isPublished };\n }\n\n return strapi.db.query(uid).findMany({ populate: opts.populate, where });\n },\n\n async findMany(opts: DocServiceParams<'findMany'>, uid: UID.CollectionType) {\n const params = { ...opts, populate: getDeepPopulate(uid) } as typeof opts;\n return strapi.documents(uid).findMany(params);\n },\n\n async findPage(opts: DocServiceParams<'findMany'>, uid: UID.CollectionType) {\n const params = pagination.withDefaultPagination(opts || {}, {\n maxLimit: 1000,\n });\n\n const [documents, total = 0] = await Promise.all([\n strapi.documents(uid).findMany(params),\n strapi.documents(uid).count(params),\n ]);\n\n return {\n results: documents,\n pagination: pagination.transformPagedPaginationInfo(params, total),\n };\n },\n\n async create(uid: UID.CollectionType, opts: DocServiceParams<'create'> = {} as any) {\n const populate = opts.populate ?? (await buildDeepPopulate(uid));\n const params = { ...opts, status: 'draft' as const, populate };\n\n return strapi.documents(uid).create(params);\n },\n\n async update(\n id: Modules.Documents.ID,\n uid: UID.CollectionType,\n opts: Omit<DocServiceParams<'update'>, 'documentId'> = {} as any\n ) {\n const publishData = pipe(omitPublishedAtField, omitIdField)(opts.data || {});\n const populate = opts.populate ?? (await buildDeepPopulate(uid));\n const params = { ...opts, data: publishData, populate, status: 'draft' };\n\n return strapi.documents(uid).update({ ...params, documentId: id });\n },\n\n async clone(\n id: Modules.Documents.ID,\n body: Partial<Modules.Documents.Params.Data.Input<UID.CollectionType>>,\n uid: UID.CollectionType\n ) {\n const populate = await buildDeepPopulate(uid);\n\n // Extract the locale to pass it as a plain param\n const locale = body?.locale;\n const params = {\n // Ensure id and documentId are not copied to the clone\n data: omit(['id', 'documentId'], body),\n locale,\n populate,\n };\n\n return strapi\n .documents(uid)\n .clone({ ...params, documentId: id })\n .then((result) => result?.entries.at(0));\n },\n\n /**\n * Check if a document exists\n */\n async exists(uid: UID.CollectionType, id?: string) {\n // Collection type\n if (id) {\n const count = await strapi.db.query(uid).count({ where: { documentId: id } });\n return count > 0;\n }\n\n // Single type\n const count = await strapi.db.query(uid).count();\n return count > 0;\n },\n\n async delete(\n id: Modules.Documents.ID,\n uid: UID.CollectionType,\n opts: Omit<DocServiceParams<'delete'>, 'documentId'> = {} as any\n ) {\n const populate = await buildDeepPopulate(uid);\n\n await strapi.documents(uid).delete({\n ...opts,\n documentId: id,\n populate,\n });\n return {};\n },\n\n // FIXME: handle relations\n async deleteMany(\n documentIds: Modules.Documents.ID[],\n uid: UID.CollectionType,\n opts: DocServiceParams<'findMany'> & { locale?: string } = {}\n ) {\n const deletedEntries = await strapi.db.transaction(async () => {\n return Promise.all(documentIds.map(async (id) => this.delete(id, uid, opts)));\n });\n\n return { count: deletedEntries.length };\n },\n\n async publish(\n id: Modules.Documents.ID,\n uid: UID.CollectionType,\n opts: Omit<DocServiceParams<'publish'>, 'documentId'> = {} as any\n ) {\n const populate = await buildDeepPopulate(uid);\n const params = { ...opts, populate };\n\n return strapi\n .documents(uid)\n .publish({ ...params, documentId: id })\n .then((result) => result?.entries);\n },\n\n async publishMany(uid: UID.ContentType, documentIds: string[], locale?: string | string[]) {\n return strapi.db.transaction(async () => {\n const results = await Promise.all(\n documentIds.map((documentId) => this.publish(documentId, uid, { locale }))\n );\n\n const publishedEntitiesCount = results.flat().filter(Boolean).length;\n return publishedEntitiesCount;\n });\n },\n\n async unpublishMany(\n documentIds: Modules.Documents.ID[],\n uid: UID.CollectionType,\n opts: Omit<DocServiceParams<'unpublish'>, 'documentId'> = {} as any\n ) {\n const unpublishedEntries = await strapi.db.transaction(async () => {\n return Promise.all(\n documentIds.map((id) =>\n strapi\n .documents(uid)\n .unpublish({ ...opts, documentId: id })\n .then((result) => result?.entries)\n )\n );\n });\n\n const unpublishedEntitiesCount = unpublishedEntries.flat().filter(Boolean).length;\n\n // Return the number of unpublished entities\n return { count: unpublishedEntitiesCount };\n },\n\n async unpublish(\n id: Modules.Documents.ID,\n uid: UID.CollectionType,\n opts: Omit<DocServiceParams<'unpublish'>, 'documentId'> = {} as any\n ) {\n const populate = await buildDeepPopulate(uid);\n const params = { ...opts, populate };\n\n return strapi\n .documents(uid)\n .unpublish({ ...params, documentId: id })\n .then((result) => result?.entries.at(0));\n },\n\n async discardDraft(\n id: Modules.Documents.ID,\n uid: UID.CollectionType,\n opts: Omit<DocServiceParams<'discardDraft'>, 'documentId'> = {} as any\n ) {\n const populate = await buildDeepPopulate(uid);\n const params = { ...opts, populate };\n\n return strapi\n .documents(uid)\n .discardDraft({ ...params, documentId: id })\n .then((result) => result?.entries.at(0));\n },\n\n async countDraftRelations(id: string, uid: UID.ContentType, locale: string) {\n const { populate, hasRelations } = getDeepPopulateDraftCount(uid);\n\n if (!hasRelations) {\n return 0;\n }\n\n const document = await strapi.documents(uid).findOne({ documentId: id, populate, locale });\n if (!document) {\n throw new ApplicationError(\n `Unable to count draft relations, document with id ${id} and locale ${locale} not found`\n );\n }\n\n return sumDraftCounts(document, uid);\n },\n\n async countManyEntriesDraftRelations(\n documentIds: Modules.Documents.ID[],\n uid: UID.CollectionType,\n locale: string | string[]\n ) {\n const { populate, hasRelations } = getDeepPopulateDraftCount(uid);\n\n if (!hasRelations) {\n return 0;\n }\n\n let localeFilter = {};\n if (locale) {\n localeFilter = Array.isArray(locale) ? { locale: { $in: locale } } : { locale };\n }\n\n const entities = await strapi.db.query(uid).findMany({\n populate,\n where: {\n documentId: { $in: documentIds },\n ...localeFilter,\n },\n });\n\n const totalNumberDraftRelations: number = entities!.reduce(\n (count: number, entity: Document) => sumDraftCounts(entity, uid) + count,\n 0\n );\n\n return totalNumberDraftRelations;\n },\n };\n};\n\nexport type DocumentManagerService = typeof documentManager;\n\nexport default documentManager;\n"],"names":["ApplicationError","errors","PUBLISHED_AT_ATTRIBUTE","contentTypes","constants","omitPublishedAtField","omit","omitIdField","documentManager","strapi","findOne","id","uid","opts","documents","documentId","findLocales","where","Array","isArray","locale","$in","isPublished","publishedAt","$notNull","db","query","findMany","populate","params","getDeepPopulate","findPage","pagination","withDefaultPagination","maxLimit","total","Promise","all","count","results","transformPagedPaginationInfo","create","buildDeepPopulate","status","update","publishData","pipe","data","clone","body","then","result","entries","at","exists","delete","deleteMany","documentIds","deletedEntries","transaction","map","length","publish","publishMany","publishedEntitiesCount","flat","filter","Boolean","unpublishMany","unpublishedEntries","unpublish","unpublishedEntitiesCount","discardDraft","countDraftRelations","hasRelations","getDeepPopulateDraftCount","document","sumDraftCounts","countManyEntriesDraftRelations","localeFilter","entities","totalNumberDraftRelations","reduce","entity"],"mappings":"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"}
|
|
@@ -89,8 +89,15 @@ const documentManager = ({ strapi })=>{
|
|
|
89
89
|
},
|
|
90
90
|
async clone (id, body, uid) {
|
|
91
91
|
const populate = await buildDeepPopulate(uid);
|
|
92
|
+
// Extract the locale to pass it as a plain param
|
|
93
|
+
const locale = body?.locale;
|
|
92
94
|
const params = {
|
|
93
|
-
|
|
95
|
+
// Ensure id and documentId are not copied to the clone
|
|
96
|
+
data: omit([
|
|
97
|
+
'id',
|
|
98
|
+
'documentId'
|
|
99
|
+
], body),
|
|
100
|
+
locale,
|
|
94
101
|
populate
|
|
95
102
|
};
|
|
96
103
|
return strapi.documents(uid).clone({
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"document-manager.mjs","sources":["../../../server/src/services/document-manager.ts"],"sourcesContent":["import { omit, pipe } from 'lodash/fp';\n\nimport { contentTypes, errors, pagination } from '@strapi/utils';\nimport type { Core, Modules, UID } from '@strapi/types';\n\nimport { buildDeepPopulate, getDeepPopulate, getDeepPopulateDraftCount } from './utils/populate';\nimport { sumDraftCounts } from './utils/draft';\n\ntype DocService = Modules.Documents.ServiceInstance;\ntype DocServiceParams<TAction extends keyof DocService> = Parameters<DocService[TAction]>[0];\nexport type Document = Modules.Documents.Result<UID.ContentType>;\n\nconst { ApplicationError } = errors;\nconst { PUBLISHED_AT_ATTRIBUTE } = contentTypes.constants;\n\nconst omitPublishedAtField = omit(PUBLISHED_AT_ATTRIBUTE);\nconst omitIdField = omit('id');\n\nconst documentManager = ({ strapi }: { strapi: Core.Strapi }) => {\n return {\n async findOne(\n id: string,\n uid: UID.CollectionType,\n opts: Omit<DocServiceParams<'findOne'>, 'documentId'> = {}\n ) {\n return strapi.documents(uid).findOne({ ...opts, documentId: id });\n },\n\n /**\n * Find multiple (or all) locales for a document\n */\n async findLocales(\n id: string | string[] | undefined,\n uid: UID.CollectionType,\n opts: {\n populate?: Modules.Documents.Params.Pick<any, 'populate'>;\n locale?: string | string[] | '*';\n isPublished?: boolean;\n }\n ) {\n // Will look for a specific locale by default\n const where: any = {};\n\n // Might not have an id if querying a single type\n if (id) {\n where.documentId = id;\n }\n\n // Search in array of locales\n if (Array.isArray(opts.locale)) {\n where.locale = { $in: opts.locale };\n } else if (opts.locale && opts.locale !== '*') {\n // Look for a specific locale, ignore if looking for all locales\n where.locale = opts.locale;\n }\n\n // Published is passed, so we filter on it, otherwise we don't filter\n if (typeof opts.isPublished === 'boolean') {\n where.publishedAt = { $notNull: opts.isPublished };\n }\n\n return strapi.db.query(uid).findMany({ populate: opts.populate, where });\n },\n\n async findMany(opts: DocServiceParams<'findMany'>, uid: UID.CollectionType) {\n const params = { ...opts, populate: getDeepPopulate(uid) } as typeof opts;\n return strapi.documents(uid).findMany(params);\n },\n\n async findPage(opts: DocServiceParams<'findMany'>, uid: UID.CollectionType) {\n const params = pagination.withDefaultPagination(opts || {}, {\n maxLimit: 1000,\n });\n\n const [documents, total = 0] = await Promise.all([\n strapi.documents(uid).findMany(params),\n strapi.documents(uid).count(params),\n ]);\n\n return {\n results: documents,\n pagination: pagination.transformPagedPaginationInfo(params, total),\n };\n },\n\n async create(uid: UID.CollectionType, opts: DocServiceParams<'create'> = {} as any) {\n const populate = opts.populate ?? (await buildDeepPopulate(uid));\n const params = { ...opts, status: 'draft' as const, populate };\n\n return strapi.documents(uid).create(params);\n },\n\n async update(\n id: Modules.Documents.ID,\n uid: UID.CollectionType,\n opts: Omit<DocServiceParams<'update'>, 'documentId'> = {} as any\n ) {\n const publishData = pipe(omitPublishedAtField, omitIdField)(opts.data || {});\n const populate = opts.populate ?? (await buildDeepPopulate(uid));\n const params = { ...opts, data: publishData, populate, status: 'draft' };\n\n return strapi.documents(uid).update({ ...params, documentId: id });\n },\n\n async clone(\n id: Modules.Documents.ID,\n body: Partial<Modules.Documents.Params.Data.Input<UID.CollectionType>>,\n uid: UID.CollectionType\n ) {\n const populate = await buildDeepPopulate(uid);\n const params = {\n data: omitIdField(body),\n populate,\n };\n\n return strapi\n .documents(uid)\n .clone({ ...params, documentId: id })\n .then((result) => result?.entries.at(0));\n },\n\n /**\n * Check if a document exists\n */\n async exists(uid: UID.CollectionType, id?: string) {\n // Collection type\n if (id) {\n const count = await strapi.db.query(uid).count({ where: { documentId: id } });\n return count > 0;\n }\n\n // Single type\n const count = await strapi.db.query(uid).count();\n return count > 0;\n },\n\n async delete(\n id: Modules.Documents.ID,\n uid: UID.CollectionType,\n opts: Omit<DocServiceParams<'delete'>, 'documentId'> = {} as any\n ) {\n const populate = await buildDeepPopulate(uid);\n\n await strapi.documents(uid).delete({\n ...opts,\n documentId: id,\n populate,\n });\n return {};\n },\n\n // FIXME: handle relations\n async deleteMany(\n documentIds: Modules.Documents.ID[],\n uid: UID.CollectionType,\n opts: DocServiceParams<'findMany'> & { locale?: string } = {}\n ) {\n const deletedEntries = await strapi.db.transaction(async () => {\n return Promise.all(documentIds.map(async (id) => this.delete(id, uid, opts)));\n });\n\n return { count: deletedEntries.length };\n },\n\n async publish(\n id: Modules.Documents.ID,\n uid: UID.CollectionType,\n opts: Omit<DocServiceParams<'publish'>, 'documentId'> = {} as any\n ) {\n const populate = await buildDeepPopulate(uid);\n const params = { ...opts, populate };\n\n return strapi\n .documents(uid)\n .publish({ ...params, documentId: id })\n .then((result) => result?.entries);\n },\n\n async publishMany(uid: UID.ContentType, documentIds: string[], locale?: string | string[]) {\n return strapi.db.transaction(async () => {\n const results = await Promise.all(\n documentIds.map((documentId) => this.publish(documentId, uid, { locale }))\n );\n\n const publishedEntitiesCount = results.flat().filter(Boolean).length;\n return publishedEntitiesCount;\n });\n },\n\n async unpublishMany(\n documentIds: Modules.Documents.ID[],\n uid: UID.CollectionType,\n opts: Omit<DocServiceParams<'unpublish'>, 'documentId'> = {} as any\n ) {\n const unpublishedEntries = await strapi.db.transaction(async () => {\n return Promise.all(\n documentIds.map((id) =>\n strapi\n .documents(uid)\n .unpublish({ ...opts, documentId: id })\n .then((result) => result?.entries)\n )\n );\n });\n\n const unpublishedEntitiesCount = unpublishedEntries.flat().filter(Boolean).length;\n\n // Return the number of unpublished entities\n return { count: unpublishedEntitiesCount };\n },\n\n async unpublish(\n id: Modules.Documents.ID,\n uid: UID.CollectionType,\n opts: Omit<DocServiceParams<'unpublish'>, 'documentId'> = {} as any\n ) {\n const populate = await buildDeepPopulate(uid);\n const params = { ...opts, populate };\n\n return strapi\n .documents(uid)\n .unpublish({ ...params, documentId: id })\n .then((result) => result?.entries.at(0));\n },\n\n async discardDraft(\n id: Modules.Documents.ID,\n uid: UID.CollectionType,\n opts: Omit<DocServiceParams<'discardDraft'>, 'documentId'> = {} as any\n ) {\n const populate = await buildDeepPopulate(uid);\n const params = { ...opts, populate };\n\n return strapi\n .documents(uid)\n .discardDraft({ ...params, documentId: id })\n .then((result) => result?.entries.at(0));\n },\n\n async countDraftRelations(id: string, uid: UID.ContentType, locale: string) {\n const { populate, hasRelations } = getDeepPopulateDraftCount(uid);\n\n if (!hasRelations) {\n return 0;\n }\n\n const document = await strapi.documents(uid).findOne({ documentId: id, populate, locale });\n if (!document) {\n throw new ApplicationError(\n `Unable to count draft relations, document with id ${id} and locale ${locale} not found`\n );\n }\n\n return sumDraftCounts(document, uid);\n },\n\n async countManyEntriesDraftRelations(\n documentIds: Modules.Documents.ID[],\n uid: UID.CollectionType,\n locale: string | string[]\n ) {\n const { populate, hasRelations } = getDeepPopulateDraftCount(uid);\n\n if (!hasRelations) {\n return 0;\n }\n\n let localeFilter = {};\n if (locale) {\n localeFilter = Array.isArray(locale) ? { locale: { $in: locale } } : { locale };\n }\n\n const entities = await strapi.db.query(uid).findMany({\n populate,\n where: {\n documentId: { $in: documentIds },\n ...localeFilter,\n },\n });\n\n const totalNumberDraftRelations: number = entities!.reduce(\n (count: number, entity: Document) => sumDraftCounts(entity, uid) + count,\n 0\n );\n\n return totalNumberDraftRelations;\n },\n };\n};\n\nexport type DocumentManagerService = typeof documentManager;\n\nexport default documentManager;\n"],"names":["ApplicationError","errors","PUBLISHED_AT_ATTRIBUTE","contentTypes","constants","omitPublishedAtField","omit","omitIdField","documentManager","strapi","findOne","id","uid","opts","documents","documentId","findLocales","where","Array","isArray","locale","$in","isPublished","publishedAt","$notNull","db","query","findMany","populate","params","getDeepPopulate","findPage","pagination","withDefaultPagination","maxLimit","total","Promise","all","count","results","transformPagedPaginationInfo","create","buildDeepPopulate","status","update","publishData","pipe","data","clone","body","then","result","entries","at","exists","delete","deleteMany","documentIds","deletedEntries","transaction","map","length","publish","publishMany","publishedEntitiesCount","flat","filter","Boolean","unpublishMany","unpublishedEntries","unpublish","unpublishedEntitiesCount","discardDraft","countDraftRelations","hasRelations","getDeepPopulateDraftCount","document","sumDraftCounts","countManyEntriesDraftRelations","localeFilter","entities","totalNumberDraftRelations","reduce","entity"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"document-manager.mjs","sources":["../../../server/src/services/document-manager.ts"],"sourcesContent":["import { omit, pipe } from 'lodash/fp';\n\nimport { contentTypes, errors, pagination } from '@strapi/utils';\nimport type { Core, Modules, UID } from '@strapi/types';\n\nimport { buildDeepPopulate, getDeepPopulate, getDeepPopulateDraftCount } from './utils/populate';\nimport { sumDraftCounts } from './utils/draft';\n\ntype DocService = Modules.Documents.ServiceInstance;\ntype DocServiceParams<TAction extends keyof DocService> = Parameters<DocService[TAction]>[0];\nexport type Document = Modules.Documents.Result<UID.ContentType>;\n\nconst { ApplicationError } = errors;\nconst { PUBLISHED_AT_ATTRIBUTE } = contentTypes.constants;\n\nconst omitPublishedAtField = omit(PUBLISHED_AT_ATTRIBUTE);\nconst omitIdField = omit('id');\n\nconst documentManager = ({ strapi }: { strapi: Core.Strapi }) => {\n return {\n async findOne(\n id: string,\n uid: UID.CollectionType,\n opts: Omit<DocServiceParams<'findOne'>, 'documentId'> = {}\n ) {\n return strapi.documents(uid).findOne({ ...opts, documentId: id });\n },\n\n /**\n * Find multiple (or all) locales for a document\n */\n async findLocales(\n id: string | string[] | undefined,\n uid: UID.CollectionType,\n opts: {\n populate?: Modules.Documents.Params.Pick<any, 'populate'>;\n locale?: string | string[] | '*';\n isPublished?: boolean;\n }\n ) {\n // Will look for a specific locale by default\n const where: any = {};\n\n // Might not have an id if querying a single type\n if (id) {\n where.documentId = id;\n }\n\n // Search in array of locales\n if (Array.isArray(opts.locale)) {\n where.locale = { $in: opts.locale };\n } else if (opts.locale && opts.locale !== '*') {\n // Look for a specific locale, ignore if looking for all locales\n where.locale = opts.locale;\n }\n\n // Published is passed, so we filter on it, otherwise we don't filter\n if (typeof opts.isPublished === 'boolean') {\n where.publishedAt = { $notNull: opts.isPublished };\n }\n\n return strapi.db.query(uid).findMany({ populate: opts.populate, where });\n },\n\n async findMany(opts: DocServiceParams<'findMany'>, uid: UID.CollectionType) {\n const params = { ...opts, populate: getDeepPopulate(uid) } as typeof opts;\n return strapi.documents(uid).findMany(params);\n },\n\n async findPage(opts: DocServiceParams<'findMany'>, uid: UID.CollectionType) {\n const params = pagination.withDefaultPagination(opts || {}, {\n maxLimit: 1000,\n });\n\n const [documents, total = 0] = await Promise.all([\n strapi.documents(uid).findMany(params),\n strapi.documents(uid).count(params),\n ]);\n\n return {\n results: documents,\n pagination: pagination.transformPagedPaginationInfo(params, total),\n };\n },\n\n async create(uid: UID.CollectionType, opts: DocServiceParams<'create'> = {} as any) {\n const populate = opts.populate ?? (await buildDeepPopulate(uid));\n const params = { ...opts, status: 'draft' as const, populate };\n\n return strapi.documents(uid).create(params);\n },\n\n async update(\n id: Modules.Documents.ID,\n uid: UID.CollectionType,\n opts: Omit<DocServiceParams<'update'>, 'documentId'> = {} as any\n ) {\n const publishData = pipe(omitPublishedAtField, omitIdField)(opts.data || {});\n const populate = opts.populate ?? (await buildDeepPopulate(uid));\n const params = { ...opts, data: publishData, populate, status: 'draft' };\n\n return strapi.documents(uid).update({ ...params, documentId: id });\n },\n\n async clone(\n id: Modules.Documents.ID,\n body: Partial<Modules.Documents.Params.Data.Input<UID.CollectionType>>,\n uid: UID.CollectionType\n ) {\n const populate = await buildDeepPopulate(uid);\n\n // Extract the locale to pass it as a plain param\n const locale = body?.locale;\n const params = {\n // Ensure id and documentId are not copied to the clone\n data: omit(['id', 'documentId'], body),\n locale,\n populate,\n };\n\n return strapi\n .documents(uid)\n .clone({ ...params, documentId: id })\n .then((result) => result?.entries.at(0));\n },\n\n /**\n * Check if a document exists\n */\n async exists(uid: UID.CollectionType, id?: string) {\n // Collection type\n if (id) {\n const count = await strapi.db.query(uid).count({ where: { documentId: id } });\n return count > 0;\n }\n\n // Single type\n const count = await strapi.db.query(uid).count();\n return count > 0;\n },\n\n async delete(\n id: Modules.Documents.ID,\n uid: UID.CollectionType,\n opts: Omit<DocServiceParams<'delete'>, 'documentId'> = {} as any\n ) {\n const populate = await buildDeepPopulate(uid);\n\n await strapi.documents(uid).delete({\n ...opts,\n documentId: id,\n populate,\n });\n return {};\n },\n\n // FIXME: handle relations\n async deleteMany(\n documentIds: Modules.Documents.ID[],\n uid: UID.CollectionType,\n opts: DocServiceParams<'findMany'> & { locale?: string } = {}\n ) {\n const deletedEntries = await strapi.db.transaction(async () => {\n return Promise.all(documentIds.map(async (id) => this.delete(id, uid, opts)));\n });\n\n return { count: deletedEntries.length };\n },\n\n async publish(\n id: Modules.Documents.ID,\n uid: UID.CollectionType,\n opts: Omit<DocServiceParams<'publish'>, 'documentId'> = {} as any\n ) {\n const populate = await buildDeepPopulate(uid);\n const params = { ...opts, populate };\n\n return strapi\n .documents(uid)\n .publish({ ...params, documentId: id })\n .then((result) => result?.entries);\n },\n\n async publishMany(uid: UID.ContentType, documentIds: string[], locale?: string | string[]) {\n return strapi.db.transaction(async () => {\n const results = await Promise.all(\n documentIds.map((documentId) => this.publish(documentId, uid, { locale }))\n );\n\n const publishedEntitiesCount = results.flat().filter(Boolean).length;\n return publishedEntitiesCount;\n });\n },\n\n async unpublishMany(\n documentIds: Modules.Documents.ID[],\n uid: UID.CollectionType,\n opts: Omit<DocServiceParams<'unpublish'>, 'documentId'> = {} as any\n ) {\n const unpublishedEntries = await strapi.db.transaction(async () => {\n return Promise.all(\n documentIds.map((id) =>\n strapi\n .documents(uid)\n .unpublish({ ...opts, documentId: id })\n .then((result) => result?.entries)\n )\n );\n });\n\n const unpublishedEntitiesCount = unpublishedEntries.flat().filter(Boolean).length;\n\n // Return the number of unpublished entities\n return { count: unpublishedEntitiesCount };\n },\n\n async unpublish(\n id: Modules.Documents.ID,\n uid: UID.CollectionType,\n opts: Omit<DocServiceParams<'unpublish'>, 'documentId'> = {} as any\n ) {\n const populate = await buildDeepPopulate(uid);\n const params = { ...opts, populate };\n\n return strapi\n .documents(uid)\n .unpublish({ ...params, documentId: id })\n .then((result) => result?.entries.at(0));\n },\n\n async discardDraft(\n id: Modules.Documents.ID,\n uid: UID.CollectionType,\n opts: Omit<DocServiceParams<'discardDraft'>, 'documentId'> = {} as any\n ) {\n const populate = await buildDeepPopulate(uid);\n const params = { ...opts, populate };\n\n return strapi\n .documents(uid)\n .discardDraft({ ...params, documentId: id })\n .then((result) => result?.entries.at(0));\n },\n\n async countDraftRelations(id: string, uid: UID.ContentType, locale: string) {\n const { populate, hasRelations } = getDeepPopulateDraftCount(uid);\n\n if (!hasRelations) {\n return 0;\n }\n\n const document = await strapi.documents(uid).findOne({ documentId: id, populate, locale });\n if (!document) {\n throw new ApplicationError(\n `Unable to count draft relations, document with id ${id} and locale ${locale} not found`\n );\n }\n\n return sumDraftCounts(document, uid);\n },\n\n async countManyEntriesDraftRelations(\n documentIds: Modules.Documents.ID[],\n uid: UID.CollectionType,\n locale: string | string[]\n ) {\n const { populate, hasRelations } = getDeepPopulateDraftCount(uid);\n\n if (!hasRelations) {\n return 0;\n }\n\n let localeFilter = {};\n if (locale) {\n localeFilter = Array.isArray(locale) ? { locale: { $in: locale } } : { locale };\n }\n\n const entities = await strapi.db.query(uid).findMany({\n populate,\n where: {\n documentId: { $in: documentIds },\n ...localeFilter,\n },\n });\n\n const totalNumberDraftRelations: number = entities!.reduce(\n (count: number, entity: Document) => sumDraftCounts(entity, uid) + count,\n 0\n );\n\n return totalNumberDraftRelations;\n },\n };\n};\n\nexport type DocumentManagerService = typeof documentManager;\n\nexport default documentManager;\n"],"names":["ApplicationError","errors","PUBLISHED_AT_ATTRIBUTE","contentTypes","constants","omitPublishedAtField","omit","omitIdField","documentManager","strapi","findOne","id","uid","opts","documents","documentId","findLocales","where","Array","isArray","locale","$in","isPublished","publishedAt","$notNull","db","query","findMany","populate","params","getDeepPopulate","findPage","pagination","withDefaultPagination","maxLimit","total","Promise","all","count","results","transformPagedPaginationInfo","create","buildDeepPopulate","status","update","publishData","pipe","data","clone","body","then","result","entries","at","exists","delete","deleteMany","documentIds","deletedEntries","transaction","map","length","publish","publishMany","publishedEntitiesCount","flat","filter","Boolean","unpublishMany","unpublishedEntries","unpublish","unpublishedEntitiesCount","discardDraft","countDraftRelations","hasRelations","getDeepPopulateDraftCount","document","sumDraftCounts","countManyEntriesDraftRelations","localeFilter","entities","totalNumberDraftRelations","reduce","entity"],"mappings":"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"}
|
|
@@ -6,6 +6,7 @@ var populate = require('./utils/populate.js');
|
|
|
6
6
|
|
|
7
7
|
const AVAILABLE_STATUS_FIELDS = [
|
|
8
8
|
'id',
|
|
9
|
+
'documentId',
|
|
9
10
|
'locale',
|
|
10
11
|
'updatedAt',
|
|
11
12
|
'createdAt',
|
|
@@ -16,6 +17,7 @@ const AVAILABLE_STATUS_FIELDS = [
|
|
|
16
17
|
];
|
|
17
18
|
const AVAILABLE_LOCALES_FIELDS = [
|
|
18
19
|
'id',
|
|
20
|
+
'documentId',
|
|
19
21
|
'locale',
|
|
20
22
|
'updatedAt',
|
|
21
23
|
'createdAt',
|