@strapi/content-manager 0.0.0-experimental.c592deb623aed3f74ef7fdacfad9757ed59d34f7 → 0.0.0-experimental.cb74730ce5154c26404d4dccca14976a22319002
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/_chunks/CardDragPreview-C0QyJgRA.js.map +1 -1
- package/dist/_chunks/CardDragPreview-DOxamsuj.mjs.map +1 -1
- package/dist/_chunks/{ComponentConfigurationPage-7-qB29e7.mjs → ComponentConfigurationPage-BgCLcjXO.mjs} +4 -4
- package/dist/_chunks/{ComponentConfigurationPage-7-qB29e7.mjs.map → ComponentConfigurationPage-BgCLcjXO.mjs.map} +1 -1
- package/dist/_chunks/{ComponentConfigurationPage-DP7AC0UU.js → ComponentConfigurationPage-DywpTZeV.js} +5 -6
- package/dist/_chunks/{ComponentConfigurationPage-DP7AC0UU.js.map → ComponentConfigurationPage-DywpTZeV.js.map} +1 -1
- package/dist/_chunks/{ComponentIcon-BXdiCGQp.js → ComponentIcon-CRbtQEUV.js} +2 -3
- package/dist/_chunks/{ComponentIcon-BXdiCGQp.js.map → ComponentIcon-CRbtQEUV.js.map} +1 -1
- package/dist/_chunks/ComponentIcon-u4bIXTFY.mjs.map +1 -1
- package/dist/_chunks/{EditConfigurationPage-CI4XoymK.mjs → EditConfigurationPage-BNjOAHNS.mjs} +4 -4
- package/dist/_chunks/{EditConfigurationPage-CI4XoymK.mjs.map → EditConfigurationPage-BNjOAHNS.mjs.map} +1 -1
- package/dist/_chunks/{EditConfigurationPage-DITVliEI.js → EditConfigurationPage-CxRlP5if.js} +5 -6
- package/dist/_chunks/{EditConfigurationPage-DITVliEI.js.map → EditConfigurationPage-CxRlP5if.js.map} +1 -1
- package/dist/_chunks/{EditViewPage-CUS2EAhB.js → EditViewPage-BRewdTqE.js} +45 -10
- package/dist/_chunks/EditViewPage-BRewdTqE.js.map +1 -0
- package/dist/_chunks/{EditViewPage-Dzpno8xI.mjs → EditViewPage-CD_hqc1J.mjs} +45 -9
- package/dist/_chunks/EditViewPage-CD_hqc1J.mjs.map +1 -0
- package/dist/_chunks/{Field-B_jG_EV9.mjs → Field-BPkQ-3Ku.mjs} +102 -70
- package/dist/_chunks/Field-BPkQ-3Ku.mjs.map +1 -0
- package/dist/_chunks/{Field-CtUU1Fg8.js → Field-DwvmENVf.js} +103 -72
- package/dist/_chunks/Field-DwvmENVf.js.map +1 -0
- package/dist/_chunks/FieldTypeIcon-CMlNO8PE.mjs.map +1 -1
- package/dist/_chunks/FieldTypeIcon-Dnwq_IRF.js.map +1 -1
- package/dist/_chunks/{Form-DTqO0ymI.js → Form-C_Gwv8P_.js} +6 -7
- package/dist/_chunks/Form-C_Gwv8P_.js.map +1 -0
- package/dist/_chunks/{Form-BXHao2mZ.mjs → Form-Czi0cf_2.mjs} +4 -4
- package/dist/_chunks/Form-Czi0cf_2.mjs.map +1 -0
- package/dist/_chunks/{History-C_uSGzO5.js → History-C1TKAig-.js} +42 -100
- package/dist/_chunks/History-C1TKAig-.js.map +1 -0
- package/dist/_chunks/{History-2Ah2CQ4T.mjs → History-CIQHyi4T.mjs} +43 -100
- package/dist/_chunks/History-CIQHyi4T.mjs.map +1 -0
- package/dist/_chunks/{ListConfigurationPage-nyuP7OSy.js → ListConfigurationPage-D-NGRLYu.js} +7 -7
- package/dist/_chunks/ListConfigurationPage-D-NGRLYu.js.map +1 -0
- package/dist/_chunks/{ListConfigurationPage-BjSJlaoC.mjs → ListConfigurationPage-DcZsfyEL.mjs} +7 -6
- package/dist/_chunks/ListConfigurationPage-DcZsfyEL.mjs.map +1 -0
- package/dist/_chunks/{ListViewPage-B75x3nz2.mjs → ListViewPage-C10McTK1.mjs} +62 -39
- package/dist/_chunks/ListViewPage-C10McTK1.mjs.map +1 -0
- package/dist/_chunks/{ListViewPage-DHgHD8Xg.js → ListViewPage-xv5IQoZp.js} +63 -41
- package/dist/_chunks/ListViewPage-xv5IQoZp.js.map +1 -0
- package/dist/_chunks/{NoContentTypePage-DUacQSyF.mjs → NoContentTypePage-CPc0Cd3S.mjs} +2 -2
- package/dist/_chunks/{NoContentTypePage-DUacQSyF.mjs.map → NoContentTypePage-CPc0Cd3S.mjs.map} +1 -1
- package/dist/_chunks/{NoContentTypePage-CDUKdZ7d.js → NoContentTypePage-Dzw5Yj5u.js} +2 -2
- package/dist/_chunks/{NoContentTypePage-CDUKdZ7d.js.map → NoContentTypePage-Dzw5Yj5u.js.map} +1 -1
- package/dist/_chunks/{NoPermissionsPage-zwIZydDI.js → NoPermissionsPage-DAe5CDCC.js} +2 -2
- package/dist/_chunks/{NoPermissionsPage-zwIZydDI.js.map → NoPermissionsPage-DAe5CDCC.js.map} +1 -1
- package/dist/_chunks/{NoPermissionsPage-SFllMekk.mjs → NoPermissionsPage-wfPBh2_0.mjs} +2 -2
- package/dist/_chunks/{NoPermissionsPage-SFllMekk.mjs.map → NoPermissionsPage-wfPBh2_0.mjs.map} +1 -1
- package/dist/_chunks/Preview-B7LyGT_b.js +290 -0
- package/dist/_chunks/Preview-B7LyGT_b.js.map +1 -0
- package/dist/_chunks/Preview-BVFFm7uB.mjs +272 -0
- package/dist/_chunks/Preview-BVFFm7uB.mjs.map +1 -0
- package/dist/_chunks/{Relations-NFLaRNPr.js → Relations-BmYR1AjY.js} +68 -39
- package/dist/_chunks/Relations-BmYR1AjY.js.map +1 -0
- package/dist/_chunks/{Relations-D2NRW8fC.mjs → Relations-JPhWxk-s.mjs} +68 -38
- package/dist/_chunks/Relations-JPhWxk-s.mjs.map +1 -0
- package/dist/_chunks/{en-BlhnxQfj.js → en-BK8Xyl5I.js} +22 -10
- package/dist/_chunks/{en-BlhnxQfj.js.map → en-BK8Xyl5I.js.map} +1 -1
- package/dist/_chunks/{en-C8YBvRrK.mjs → en-Dtk_ot79.mjs} +22 -10
- package/dist/_chunks/{en-C8YBvRrK.mjs.map → en-Dtk_ot79.mjs.map} +1 -1
- package/dist/_chunks/{es-EUonQTon.js → es-9K52xZIr.js} +2 -2
- package/dist/_chunks/{ja-CcFe8diO.js.map → es-9K52xZIr.js.map} +1 -1
- package/dist/_chunks/{es-CeXiYflN.mjs → es-D34tqjMw.mjs} +2 -2
- package/dist/_chunks/{es-CeXiYflN.mjs.map → es-D34tqjMw.mjs.map} +1 -1
- package/dist/_chunks/{fr-CD9VFbPM.mjs → fr--pg5jUbt.mjs} +13 -3
- package/dist/_chunks/{fr-CD9VFbPM.mjs.map → fr--pg5jUbt.mjs.map} +1 -1
- package/dist/_chunks/{fr-B7kGGg3E.js → fr-B2Kyv8Z9.js} +13 -3
- package/dist/_chunks/{fr-B7kGGg3E.js.map → fr-B2Kyv8Z9.js.map} +1 -1
- package/dist/_chunks/hooks-BAaaKPS_.js.map +1 -1
- package/dist/_chunks/{index-ovJRE1FM.js → index-C2Q_PLWj.js} +294 -167
- package/dist/_chunks/index-C2Q_PLWj.js.map +1 -0
- package/dist/_chunks/{index-C9HxCo5R.mjs → index-DLIkNVnQ.mjs} +297 -170
- package/dist/_chunks/index-DLIkNVnQ.mjs.map +1 -0
- package/dist/_chunks/{ja-CcFe8diO.js → ja-7sfIbjxE.js} +2 -2
- package/dist/_chunks/{es-EUonQTon.js.map → ja-7sfIbjxE.js.map} +1 -1
- package/dist/_chunks/{ja-CtsUxOvk.mjs → ja-BHqhDq4V.mjs} +2 -2
- package/dist/_chunks/{ja-CtsUxOvk.mjs.map → ja-BHqhDq4V.mjs.map} +1 -1
- package/dist/_chunks/{layout-UNWstw_s.js → layout-7AsWJzZJ.js} +5 -6
- package/dist/_chunks/{layout-UNWstw_s.js.map → layout-7AsWJzZJ.js.map} +1 -1
- package/dist/_chunks/{layout-DaUjDiWQ.mjs → layout-qE8qkNH_.mjs} +4 -4
- package/dist/_chunks/{layout-DaUjDiWQ.mjs.map → layout-qE8qkNH_.mjs.map} +1 -1
- package/dist/_chunks/{objects-gigeqt7s.js → objects-BcXOv6_9.js} +2 -4
- package/dist/_chunks/{objects-gigeqt7s.js.map → objects-BcXOv6_9.js.map} +1 -1
- package/dist/_chunks/{objects-mKMAmfec.mjs → objects-D6yBsdmx.mjs} +2 -4
- package/dist/_chunks/{objects-mKMAmfec.mjs.map → objects-D6yBsdmx.mjs.map} +1 -1
- package/dist/_chunks/{relations-D8iFAeRu.mjs → relations-BjHH_1Am.mjs} +6 -7
- package/dist/_chunks/relations-BjHH_1Am.mjs.map +1 -0
- package/dist/_chunks/{relations-NN3coOG5.js → relations-EifVzf_2.js} +6 -7
- package/dist/_chunks/relations-EifVzf_2.js.map +1 -0
- package/dist/_chunks/useDebounce-CtcjDB3L.js.map +1 -1
- package/dist/_chunks/useDebounce-DmuSJIF3.mjs.map +1 -1
- package/dist/_chunks/{useDragAndDrop-J0TUUbR6.js → useDragAndDrop-BMtgCYzL.js} +5 -9
- package/dist/_chunks/{useDragAndDrop-J0TUUbR6.js.map → useDragAndDrop-BMtgCYzL.js.map} +1 -1
- package/dist/_chunks/{useDragAndDrop-DdHgKsqq.mjs → useDragAndDrop-DJ6jqvZN.mjs} +4 -7
- package/dist/_chunks/{useDragAndDrop-DdHgKsqq.mjs.map → useDragAndDrop-DJ6jqvZN.mjs.map} +1 -1
- package/dist/admin/index.js +1 -1
- package/dist/admin/index.mjs +4 -4
- package/dist/admin/src/pages/EditView/EditViewPage.d.ts +9 -1
- package/dist/admin/src/pages/EditView/components/DocumentStatus.d.ts +2 -2
- package/dist/admin/src/preview/components/PreviewContent.d.ts +2 -0
- package/dist/admin/src/preview/components/PreviewHeader.d.ts +2 -0
- package/dist/admin/src/preview/components/PreviewSidePanel.d.ts +3 -0
- package/dist/admin/src/preview/constants.d.ts +1 -0
- package/dist/admin/src/preview/index.d.ts +4 -0
- package/dist/admin/src/preview/pages/Preview.d.ts +11 -0
- package/dist/admin/src/preview/routes.d.ts +3 -0
- package/dist/admin/src/preview/services/preview.d.ts +3 -0
- package/dist/admin/src/router.d.ts +1 -1
- package/dist/admin/src/services/documents.d.ts +0 -3
- package/dist/server/index.js +426 -190
- package/dist/server/index.js.map +1 -1
- package/dist/server/index.mjs +426 -189
- package/dist/server/index.mjs.map +1 -1
- package/dist/server/src/bootstrap.d.ts.map +1 -1
- package/dist/server/src/controllers/collection-types.d.ts.map +1 -1
- package/dist/server/src/controllers/index.d.ts.map +1 -1
- package/dist/server/src/controllers/relations.d.ts.map +1 -1
- package/dist/server/src/controllers/utils/metadata.d.ts +15 -1
- package/dist/server/src/controllers/utils/metadata.d.ts.map +1 -1
- package/dist/server/src/history/services/history.d.ts.map +1 -1
- package/dist/server/src/history/services/lifecycles.d.ts.map +1 -1
- package/dist/server/src/history/services/utils.d.ts +2 -3
- package/dist/server/src/history/services/utils.d.ts.map +1 -1
- package/dist/server/src/index.d.ts +4 -4
- package/dist/server/src/preview/constants.d.ts +2 -0
- package/dist/server/src/preview/constants.d.ts.map +1 -0
- package/dist/server/src/preview/controllers/index.d.ts +2 -0
- package/dist/server/src/preview/controllers/index.d.ts.map +1 -0
- package/dist/server/src/preview/controllers/preview.d.ts +13 -0
- package/dist/server/src/preview/controllers/preview.d.ts.map +1 -0
- package/dist/server/src/preview/controllers/validation/preview.d.ts +6 -0
- package/dist/server/src/preview/controllers/validation/preview.d.ts.map +1 -0
- package/dist/server/src/preview/index.d.ts +4 -0
- package/dist/server/src/preview/index.d.ts.map +1 -0
- package/dist/server/src/preview/routes/index.d.ts +8 -0
- package/dist/server/src/preview/routes/index.d.ts.map +1 -0
- package/dist/server/src/preview/routes/preview.d.ts +4 -0
- package/dist/server/src/preview/routes/preview.d.ts.map +1 -0
- package/dist/server/src/preview/services/index.d.ts +16 -0
- package/dist/server/src/preview/services/index.d.ts.map +1 -0
- package/dist/server/src/preview/services/preview-config.d.ts +32 -0
- package/dist/server/src/preview/services/preview-config.d.ts.map +1 -0
- package/dist/server/src/preview/services/preview.d.ts +12 -0
- package/dist/server/src/preview/services/preview.d.ts.map +1 -0
- package/dist/server/src/preview/utils.d.ts +19 -0
- package/dist/server/src/preview/utils.d.ts.map +1 -0
- package/dist/server/src/register.d.ts.map +1 -1
- package/dist/server/src/routes/index.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 +8 -8
- package/dist/server/src/services/document-metadata.d.ts.map +1 -1
- package/dist/server/src/services/index.d.ts +4 -4
- package/dist/server/src/services/index.d.ts.map +1 -1
- package/dist/server/src/services/utils/configuration/index.d.ts +2 -2
- package/dist/server/src/services/utils/configuration/layouts.d.ts +2 -2
- package/dist/server/src/utils/index.d.ts +2 -0
- package/dist/server/src/utils/index.d.ts.map +1 -1
- package/dist/shared/contracts/index.d.ts +1 -0
- package/dist/shared/contracts/index.d.ts.map +1 -1
- package/dist/shared/contracts/preview.d.ts +27 -0
- package/dist/shared/contracts/preview.d.ts.map +1 -0
- package/dist/shared/index.js +4 -0
- package/dist/shared/index.js.map +1 -1
- package/dist/shared/index.mjs +4 -0
- package/dist/shared/index.mjs.map +1 -1
- package/package.json +12 -12
- package/dist/_chunks/EditViewPage-CUS2EAhB.js.map +0 -1
- package/dist/_chunks/EditViewPage-Dzpno8xI.mjs.map +0 -1
- package/dist/_chunks/Field-B_jG_EV9.mjs.map +0 -1
- package/dist/_chunks/Field-CtUU1Fg8.js.map +0 -1
- package/dist/_chunks/Form-BXHao2mZ.mjs.map +0 -1
- package/dist/_chunks/Form-DTqO0ymI.js.map +0 -1
- package/dist/_chunks/History-2Ah2CQ4T.mjs.map +0 -1
- package/dist/_chunks/History-C_uSGzO5.js.map +0 -1
- package/dist/_chunks/ListConfigurationPage-BjSJlaoC.mjs.map +0 -1
- package/dist/_chunks/ListConfigurationPage-nyuP7OSy.js.map +0 -1
- package/dist/_chunks/ListViewPage-B75x3nz2.mjs.map +0 -1
- package/dist/_chunks/ListViewPage-DHgHD8Xg.js.map +0 -1
- package/dist/_chunks/Relations-D2NRW8fC.mjs.map +0 -1
- package/dist/_chunks/Relations-NFLaRNPr.js.map +0 -1
- package/dist/_chunks/index-C9HxCo5R.mjs.map +0 -1
- package/dist/_chunks/index-ovJRE1FM.js.map +0 -1
- package/dist/_chunks/relations-D8iFAeRu.mjs.map +0 -1
- package/dist/_chunks/relations-NN3coOG5.js.map +0 -1
package/dist/server/index.js
CHANGED
@@ -10,8 +10,7 @@ const qs = require("qs");
|
|
10
10
|
const slugify = require("@sindresorhus/slugify");
|
11
11
|
const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
|
12
12
|
function _interopNamespace(e) {
|
13
|
-
if (e && e.__esModule)
|
14
|
-
return e;
|
13
|
+
if (e && e.__esModule) return e;
|
15
14
|
const n = Object.create(null, { [Symbol.toStringTag]: { value: "Module" } });
|
16
15
|
if (e) {
|
17
16
|
for (const k in e) {
|
@@ -33,10 +32,10 @@ const isNil__default = /* @__PURE__ */ _interopDefault(isNil);
|
|
33
32
|
const ___default = /* @__PURE__ */ _interopDefault(_);
|
34
33
|
const qs__default = /* @__PURE__ */ _interopDefault(qs);
|
35
34
|
const slugify__default = /* @__PURE__ */ _interopDefault(slugify);
|
36
|
-
const getService$
|
35
|
+
const getService$2 = (name) => {
|
37
36
|
return strapi.plugin("content-manager").service(name);
|
38
37
|
};
|
39
|
-
function getService(strapi2, name) {
|
38
|
+
function getService$1(strapi2, name) {
|
40
39
|
return strapi2.service(`plugin::content-manager.${name}`);
|
41
40
|
}
|
42
41
|
const historyRestoreVersionSchema = yup__namespace.object().shape({
|
@@ -72,7 +71,7 @@ const createHistoryVersionController = ({ strapi: strapi2 }) => {
|
|
72
71
|
if (!isSingleType && (!contentTypeUid || !ctx.query.documentId)) {
|
73
72
|
throw new strapiUtils.errors.ForbiddenError("contentType and documentId are required");
|
74
73
|
}
|
75
|
-
const permissionChecker2 = getService$
|
74
|
+
const permissionChecker2 = getService$2("permission-checker").create({
|
76
75
|
userAbility: ctx.state.userAbility,
|
77
76
|
model: ctx.query.contentType
|
78
77
|
});
|
@@ -80,7 +79,7 @@ const createHistoryVersionController = ({ strapi: strapi2 }) => {
|
|
80
79
|
return ctx.forbidden();
|
81
80
|
}
|
82
81
|
const query = await permissionChecker2.sanitizeQuery(ctx.query);
|
83
|
-
const { results, pagination } = await getService(strapi2, "history").findVersionsPage({
|
82
|
+
const { results, pagination } = await getService$1(strapi2, "history").findVersionsPage({
|
84
83
|
query: {
|
85
84
|
...query,
|
86
85
|
...getValidPagination({ page: query.page, pageSize: query.pageSize })
|
@@ -105,14 +104,14 @@ const createHistoryVersionController = ({ strapi: strapi2 }) => {
|
|
105
104
|
async restoreVersion(ctx) {
|
106
105
|
const request = ctx.request;
|
107
106
|
await validateRestoreVersion(request.body, "contentType is required");
|
108
|
-
const permissionChecker2 = getService$
|
107
|
+
const permissionChecker2 = getService$2("permission-checker").create({
|
109
108
|
userAbility: ctx.state.userAbility,
|
110
109
|
model: request.body.contentType
|
111
110
|
});
|
112
111
|
if (permissionChecker2.cannot.update()) {
|
113
112
|
throw new strapiUtils.errors.ForbiddenError();
|
114
113
|
}
|
115
|
-
const restoredDocument = await getService(strapi2, "history").restoreVersion(
|
114
|
+
const restoredDocument = await getService$1(strapi2, "history").restoreVersion(
|
116
115
|
request.params.versionId
|
117
116
|
);
|
118
117
|
return {
|
@@ -121,7 +120,7 @@ const createHistoryVersionController = ({ strapi: strapi2 }) => {
|
|
121
120
|
}
|
122
121
|
};
|
123
122
|
};
|
124
|
-
const controllers$
|
123
|
+
const controllers$2 = {
|
125
124
|
"history-version": createHistoryVersionController
|
126
125
|
/**
|
127
126
|
* Casting is needed because the types aren't aware that Strapi supports
|
@@ -167,8 +166,7 @@ const createServiceUtils = ({ strapi: strapi2 }) => {
|
|
167
166
|
};
|
168
167
|
const getRelationRestoreValue = async (versionRelationData, attribute) => {
|
169
168
|
if (Array.isArray(versionRelationData)) {
|
170
|
-
if (versionRelationData.length === 0)
|
171
|
-
return versionRelationData;
|
169
|
+
if (versionRelationData.length === 0) return versionRelationData;
|
172
170
|
const existingAndMissingRelations = await Promise.all(
|
173
171
|
versionRelationData.map((relation) => {
|
174
172
|
return strapi2.documents(attribute.target).findOne({
|
@@ -203,8 +201,7 @@ const createServiceUtils = ({ strapi: strapi2 }) => {
|
|
203
201
|
const getDefaultLocale = async () => localesService ? localesService.getDefaultLocale() : null;
|
204
202
|
const isLocalizedContentType = (model) => i18nContentTypeService ? i18nContentTypeService.isLocalizedContentType(model) : false;
|
205
203
|
const getLocaleDictionary = async () => {
|
206
|
-
if (!localesService)
|
207
|
-
return {};
|
204
|
+
if (!localesService) return {};
|
208
205
|
const locales = await localesService.find() || [];
|
209
206
|
return locales.reduce(
|
210
207
|
(acc, locale) => {
|
@@ -228,6 +225,17 @@ const createServiceUtils = ({ strapi: strapi2 }) => {
|
|
228
225
|
const meta = await documentMetadataService.getMetadata(contentTypeUid, document);
|
229
226
|
return documentMetadataService.getStatus(document, meta.availableStatus);
|
230
227
|
};
|
228
|
+
const getComponentFields = (componentUID) => {
|
229
|
+
return Object.entries(strapi2.getModel(componentUID).attributes).reduce(
|
230
|
+
(fieldsAcc, [key, attribute]) => {
|
231
|
+
if (!["relation", "media", "component", "dynamiczone"].includes(attribute.type)) {
|
232
|
+
fieldsAcc.push(key);
|
233
|
+
}
|
234
|
+
return fieldsAcc;
|
235
|
+
},
|
236
|
+
[]
|
237
|
+
);
|
238
|
+
};
|
231
239
|
const getDeepPopulate2 = (uid2, useDatabaseSyntax = false) => {
|
232
240
|
const model = strapi2.getModel(uid2);
|
233
241
|
const attributes = Object.entries(model.attributes);
|
@@ -251,13 +259,19 @@ const createServiceUtils = ({ strapi: strapi2 }) => {
|
|
251
259
|
}
|
252
260
|
case "component": {
|
253
261
|
const populate = getDeepPopulate2(attribute.component);
|
254
|
-
acc[attributeName] = {
|
262
|
+
acc[attributeName] = {
|
263
|
+
populate,
|
264
|
+
[fieldSelector]: getComponentFields(attribute.component)
|
265
|
+
};
|
255
266
|
break;
|
256
267
|
}
|
257
268
|
case "dynamiczone": {
|
258
269
|
const populatedComponents = (attribute.components || []).reduce(
|
259
270
|
(acc2, componentUID) => {
|
260
|
-
acc2[componentUID] = {
|
271
|
+
acc2[componentUID] = {
|
272
|
+
populate: getDeepPopulate2(componentUID),
|
273
|
+
[fieldSelector]: getComponentFields(componentUID)
|
274
|
+
};
|
261
275
|
return acc2;
|
262
276
|
},
|
263
277
|
{}
|
@@ -370,7 +384,7 @@ const createHistoryService = ({ strapi: strapi2 }) => {
|
|
370
384
|
const attributeValue = entry.data[attributeKey];
|
371
385
|
const attributeValues = Array.isArray(attributeValue) ? attributeValue : [attributeValue];
|
372
386
|
if (attributeSchema.type === "media") {
|
373
|
-
const permissionChecker2 = getService$
|
387
|
+
const permissionChecker2 = getService$2("permission-checker").create({
|
374
388
|
userAbility: params.state.userAbility,
|
375
389
|
model: "plugin::upload.file"
|
376
390
|
});
|
@@ -393,7 +407,12 @@ const createHistoryService = ({ strapi: strapi2 }) => {
|
|
393
407
|
if (userToPopulate == null) {
|
394
408
|
return null;
|
395
409
|
}
|
396
|
-
return strapi2.query("admin::user").findOne({
|
410
|
+
return strapi2.query("admin::user").findOne({
|
411
|
+
where: {
|
412
|
+
...userToPopulate.id ? { id: userToPopulate.id } : {},
|
413
|
+
...userToPopulate.documentId ? { documentId: userToPopulate.documentId } : {}
|
414
|
+
}
|
415
|
+
});
|
397
416
|
})
|
398
417
|
);
|
399
418
|
return {
|
@@ -406,7 +425,7 @@ const createHistoryService = ({ strapi: strapi2 }) => {
|
|
406
425
|
[attributeKey]: adminUsers
|
407
426
|
};
|
408
427
|
}
|
409
|
-
const permissionChecker2 = getService$
|
428
|
+
const permissionChecker2 = getService$2("permission-checker").create({
|
410
429
|
userAbility: params.state.userAbility,
|
411
430
|
model: attributeSchema.target
|
412
431
|
});
|
@@ -582,7 +601,7 @@ const createLifecyclesService = ({ strapi: strapi2 }) => {
|
|
582
601
|
onCommit(async () => {
|
583
602
|
for (const entry of localeEntries) {
|
584
603
|
const status = await serviceUtils.getVersionStatus(uid2, entry);
|
585
|
-
await getService(strapi2, "history").createVersion({
|
604
|
+
await getService$1(strapi2, "history").createVersion({
|
586
605
|
contentType: uid2,
|
587
606
|
data: fp.omit(FIELDS_TO_IGNORE, entry),
|
588
607
|
relatedDocumentId: documentId,
|
@@ -595,15 +614,19 @@ const createLifecyclesService = ({ strapi: strapi2 }) => {
|
|
595
614
|
});
|
596
615
|
return result;
|
597
616
|
});
|
598
|
-
state.deleteExpiredJob = nodeSchedule.scheduleJob("0 0 * * *", () => {
|
617
|
+
state.deleteExpiredJob = nodeSchedule.scheduleJob("historyDaily", "0 0 * * *", () => {
|
599
618
|
const retentionDaysInMilliseconds = serviceUtils.getRetentionDays() * 24 * 60 * 60 * 1e3;
|
600
619
|
const expirationDate = new Date(Date.now() - retentionDaysInMilliseconds);
|
601
620
|
strapi2.db.query(HISTORY_VERSION_UID).deleteMany({
|
602
621
|
where: {
|
603
622
|
created_at: {
|
604
|
-
$lt: expirationDate
|
623
|
+
$lt: expirationDate
|
605
624
|
}
|
606
625
|
}
|
626
|
+
}).catch((error) => {
|
627
|
+
if (error instanceof Error) {
|
628
|
+
strapi2.log.error("Error deleting expired history versions", error.message);
|
629
|
+
}
|
607
630
|
});
|
608
631
|
});
|
609
632
|
state.isInitialized = true;
|
@@ -615,17 +638,17 @@ const createLifecyclesService = ({ strapi: strapi2 }) => {
|
|
615
638
|
}
|
616
639
|
};
|
617
640
|
};
|
618
|
-
const services$
|
641
|
+
const services$2 = {
|
619
642
|
history: createHistoryService,
|
620
643
|
lifecycles: createLifecyclesService
|
621
644
|
};
|
622
|
-
const info = { pluginName: "content-manager", type: "admin" };
|
645
|
+
const info$1 = { pluginName: "content-manager", type: "admin" };
|
623
646
|
const historyVersionRouter = {
|
624
647
|
type: "admin",
|
625
648
|
routes: [
|
626
649
|
{
|
627
650
|
method: "GET",
|
628
|
-
info,
|
651
|
+
info: info$1,
|
629
652
|
path: "/history-versions",
|
630
653
|
handler: "history-version.findMany",
|
631
654
|
config: {
|
@@ -634,7 +657,7 @@ const historyVersionRouter = {
|
|
634
657
|
},
|
635
658
|
{
|
636
659
|
method: "PUT",
|
637
|
-
info,
|
660
|
+
info: info$1,
|
638
661
|
path: "/history-versions/:versionId/restore",
|
639
662
|
handler: "history-version.restoreVersion",
|
640
663
|
config: {
|
@@ -643,7 +666,7 @@ const historyVersionRouter = {
|
|
643
666
|
}
|
644
667
|
]
|
645
668
|
};
|
646
|
-
const routes$
|
669
|
+
const routes$2 = {
|
647
670
|
"history-version": historyVersionRouter
|
648
671
|
};
|
649
672
|
const historyVersion = {
|
@@ -690,21 +713,21 @@ const historyVersion = {
|
|
690
713
|
}
|
691
714
|
}
|
692
715
|
};
|
693
|
-
const getFeature = () => {
|
716
|
+
const getFeature$1 = () => {
|
694
717
|
if (strapi.ee.features.isEnabled("cms-content-history")) {
|
695
718
|
return {
|
696
719
|
register({ strapi: strapi2 }) {
|
697
720
|
strapi2.get("models").add(historyVersion);
|
698
721
|
},
|
699
722
|
bootstrap({ strapi: strapi2 }) {
|
700
|
-
getService(strapi2, "lifecycles").bootstrap();
|
723
|
+
getService$1(strapi2, "lifecycles").bootstrap();
|
701
724
|
},
|
702
725
|
destroy({ strapi: strapi2 }) {
|
703
|
-
getService(strapi2, "lifecycles").destroy();
|
726
|
+
getService$1(strapi2, "lifecycles").destroy();
|
704
727
|
},
|
705
|
-
controllers: controllers$
|
706
|
-
services: services$
|
707
|
-
routes: routes$
|
728
|
+
controllers: controllers$2,
|
729
|
+
services: services$2,
|
730
|
+
routes: routes$2
|
708
731
|
};
|
709
732
|
}
|
710
733
|
return {
|
@@ -713,9 +736,205 @@ const getFeature = () => {
|
|
713
736
|
}
|
714
737
|
};
|
715
738
|
};
|
716
|
-
const history = getFeature();
|
739
|
+
const history = getFeature$1();
|
740
|
+
const FEATURE_ID = "preview";
|
741
|
+
const info = { pluginName: "content-manager", type: "admin" };
|
742
|
+
const previewRouter = {
|
743
|
+
type: "admin",
|
744
|
+
routes: [
|
745
|
+
{
|
746
|
+
method: "GET",
|
747
|
+
info,
|
748
|
+
path: "/preview/url/:contentType",
|
749
|
+
handler: "preview.getPreviewUrl",
|
750
|
+
config: {
|
751
|
+
policies: ["admin::isAuthenticatedAdmin"]
|
752
|
+
}
|
753
|
+
}
|
754
|
+
]
|
755
|
+
};
|
756
|
+
const routes$1 = {
|
757
|
+
preview: previewRouter
|
758
|
+
};
|
759
|
+
function getService(strapi2, name) {
|
760
|
+
return strapi2.service(`plugin::content-manager.${name}`);
|
761
|
+
}
|
762
|
+
const getPreviewUrlSchema = yup__namespace.object().shape({
|
763
|
+
// Will be undefined for single types
|
764
|
+
documentId: yup__namespace.string(),
|
765
|
+
locale: yup__namespace.string().nullable(),
|
766
|
+
status: yup__namespace.string()
|
767
|
+
}).required();
|
768
|
+
const validatePreviewUrl = async (strapi2, uid2, params) => {
|
769
|
+
await strapiUtils.validateYupSchema(getPreviewUrlSchema)(params);
|
770
|
+
const newParams = fp.pick(["documentId", "locale", "status"], params);
|
771
|
+
const model = strapi2.getModel(uid2);
|
772
|
+
if (!model || model.modelType !== "contentType") {
|
773
|
+
throw new strapiUtils.errors.ValidationError("Invalid content type");
|
774
|
+
}
|
775
|
+
const isSingleType = model?.kind === "singleType";
|
776
|
+
if (!isSingleType && !params.documentId) {
|
777
|
+
throw new strapiUtils.errors.ValidationError("documentId is required for Collection Types");
|
778
|
+
}
|
779
|
+
if (isSingleType) {
|
780
|
+
const doc = await strapi2.documents(uid2).findFirst();
|
781
|
+
if (!doc) {
|
782
|
+
throw new strapiUtils.errors.NotFoundError("Document not found");
|
783
|
+
}
|
784
|
+
newParams.documentId = doc?.documentId;
|
785
|
+
}
|
786
|
+
if (!newParams.status) {
|
787
|
+
const isDPEnabled = model?.options?.draftAndPublish;
|
788
|
+
newParams.status = isDPEnabled ? "draft" : "published";
|
789
|
+
}
|
790
|
+
return newParams;
|
791
|
+
};
|
792
|
+
const createPreviewController = () => {
|
793
|
+
return {
|
794
|
+
/**
|
795
|
+
* Transforms an entry into a preview URL, so that it can be previewed
|
796
|
+
* in the Content Manager.
|
797
|
+
*/
|
798
|
+
async getPreviewUrl(ctx) {
|
799
|
+
const uid2 = ctx.params.contentType;
|
800
|
+
const query = ctx.request.query;
|
801
|
+
const params = await validatePreviewUrl(strapi, uid2, query);
|
802
|
+
const previewService = getService(strapi, "preview");
|
803
|
+
const url = await previewService.getPreviewUrl(uid2, params);
|
804
|
+
if (!url) {
|
805
|
+
ctx.status = 204;
|
806
|
+
}
|
807
|
+
return {
|
808
|
+
data: { url }
|
809
|
+
};
|
810
|
+
}
|
811
|
+
};
|
812
|
+
};
|
813
|
+
const controllers$1 = {
|
814
|
+
preview: createPreviewController
|
815
|
+
/**
|
816
|
+
* Casting is needed because the types aren't aware that Strapi supports
|
817
|
+
* passing a controller factory as the value, instead of a controller object directly
|
818
|
+
*/
|
819
|
+
};
|
820
|
+
const createPreviewService = ({ strapi: strapi2 }) => {
|
821
|
+
const config = getService(strapi2, "preview-config");
|
822
|
+
return {
|
823
|
+
async getPreviewUrl(uid2, params) {
|
824
|
+
const handler = config.getPreviewHandler();
|
825
|
+
try {
|
826
|
+
return handler(uid2, params);
|
827
|
+
} catch (error) {
|
828
|
+
strapi2.log.error(`Failed to get preview URL: ${error}`);
|
829
|
+
throw new strapiUtils.errors.ApplicationError("Failed to get preview URL");
|
830
|
+
}
|
831
|
+
return;
|
832
|
+
}
|
833
|
+
};
|
834
|
+
};
|
835
|
+
const extendMiddlewareConfiguration = (middleware = { name: "", config: {} }) => {
|
836
|
+
const middlewares = strapi.config.get("middlewares");
|
837
|
+
const configuredMiddlewares = middlewares.map((currentMiddleware) => {
|
838
|
+
if (currentMiddleware === middleware.name) {
|
839
|
+
return middleware;
|
840
|
+
}
|
841
|
+
if (currentMiddleware.name === middleware.name) {
|
842
|
+
return fp.mergeWith(
|
843
|
+
(objValue, srcValue) => {
|
844
|
+
if (Array.isArray(objValue)) {
|
845
|
+
return objValue.concat(srcValue);
|
846
|
+
}
|
847
|
+
return void 0;
|
848
|
+
},
|
849
|
+
currentMiddleware,
|
850
|
+
middleware
|
851
|
+
);
|
852
|
+
}
|
853
|
+
return currentMiddleware;
|
854
|
+
});
|
855
|
+
strapi.config.set("middlewares", configuredMiddlewares);
|
856
|
+
};
|
857
|
+
const createPreviewConfigService = ({ strapi: strapi2 }) => {
|
858
|
+
return {
|
859
|
+
register() {
|
860
|
+
if (!this.isEnabled()) {
|
861
|
+
return;
|
862
|
+
}
|
863
|
+
const config = strapi2.config.get("admin.preview");
|
864
|
+
if (config.config?.allowedOrigins) {
|
865
|
+
extendMiddlewareConfiguration({
|
866
|
+
name: "strapi::security",
|
867
|
+
config: {
|
868
|
+
contentSecurityPolicy: {
|
869
|
+
directives: {
|
870
|
+
"frame-src": config.config.allowedOrigins
|
871
|
+
}
|
872
|
+
}
|
873
|
+
}
|
874
|
+
});
|
875
|
+
}
|
876
|
+
},
|
877
|
+
isEnabled() {
|
878
|
+
const config = strapi2.config.get("admin.preview");
|
879
|
+
if (!config) {
|
880
|
+
return false;
|
881
|
+
}
|
882
|
+
return config?.enabled ?? true;
|
883
|
+
},
|
884
|
+
/**
|
885
|
+
* Validate if the configuration is valid
|
886
|
+
*/
|
887
|
+
validate() {
|
888
|
+
if (!this.isEnabled()) {
|
889
|
+
return;
|
890
|
+
}
|
891
|
+
const handler = this.getPreviewHandler();
|
892
|
+
if (typeof handler !== "function") {
|
893
|
+
throw new strapiUtils.errors.ValidationError(
|
894
|
+
"Preview configuration is invalid. Handler must be a function"
|
895
|
+
);
|
896
|
+
}
|
897
|
+
},
|
898
|
+
/**
|
899
|
+
* Utility to get the preview handler from the configuration
|
900
|
+
*/
|
901
|
+
getPreviewHandler() {
|
902
|
+
const config = strapi2.config.get("admin.preview");
|
903
|
+
const emptyHandler = () => {
|
904
|
+
return void 0;
|
905
|
+
};
|
906
|
+
if (!this.isEnabled()) {
|
907
|
+
return emptyHandler;
|
908
|
+
}
|
909
|
+
return config?.config?.handler || emptyHandler;
|
910
|
+
}
|
911
|
+
};
|
912
|
+
};
|
913
|
+
const services$1 = {
|
914
|
+
preview: createPreviewService,
|
915
|
+
"preview-config": createPreviewConfigService
|
916
|
+
};
|
917
|
+
const getFeature = () => {
|
918
|
+
if (!strapi.features.future.isEnabled(FEATURE_ID)) {
|
919
|
+
return {};
|
920
|
+
}
|
921
|
+
return {
|
922
|
+
register() {
|
923
|
+
const config = getService(strapi, "preview-config");
|
924
|
+
config.validate();
|
925
|
+
config.register();
|
926
|
+
},
|
927
|
+
bootstrap() {
|
928
|
+
},
|
929
|
+
routes: routes$1,
|
930
|
+
controllers: controllers$1,
|
931
|
+
services: services$1
|
932
|
+
};
|
933
|
+
};
|
934
|
+
const preview = getFeature();
|
717
935
|
const register = async ({ strapi: strapi2 }) => {
|
718
936
|
await history.register?.({ strapi: strapi2 });
|
937
|
+
await preview.register?.({ strapi: strapi2 });
|
719
938
|
};
|
720
939
|
const ALLOWED_WEBHOOK_EVENTS = {
|
721
940
|
ENTRY_PUBLISH: "entry.publish",
|
@@ -725,11 +944,12 @@ const bootstrap = async () => {
|
|
725
944
|
Object.entries(ALLOWED_WEBHOOK_EVENTS).forEach(([key, value]) => {
|
726
945
|
strapi.get("webhookStore").addAllowedEvent(key, value);
|
727
946
|
});
|
728
|
-
getService$
|
729
|
-
await getService$
|
730
|
-
await getService$
|
731
|
-
await getService$
|
947
|
+
getService$2("field-sizes").setCustomFieldInputSizes();
|
948
|
+
await getService$2("components").syncConfigurations();
|
949
|
+
await getService$2("content-types").syncConfigurations();
|
950
|
+
await getService$2("permission").registerPermissions();
|
732
951
|
await history.bootstrap?.({ strapi });
|
952
|
+
await preview.bootstrap?.({ strapi });
|
733
953
|
};
|
734
954
|
const destroy = async ({ strapi: strapi2 }) => {
|
735
955
|
await history.destroy?.({ strapi: strapi2 });
|
@@ -1219,7 +1439,8 @@ const admin = {
|
|
1219
1439
|
};
|
1220
1440
|
const routes = {
|
1221
1441
|
admin,
|
1222
|
-
...history.routes ? history.routes : {}
|
1442
|
+
...history.routes ? history.routes : {},
|
1443
|
+
...preview.routes ? preview.routes : {}
|
1223
1444
|
};
|
1224
1445
|
const hasPermissionsSchema = strapiUtils.yup.object({
|
1225
1446
|
actions: strapiUtils.yup.array().of(strapiUtils.yup.string()),
|
@@ -1282,8 +1503,7 @@ const isSortable = (schema, name) => {
|
|
1282
1503
|
if (!___default.default.has(schema.attributes, name)) {
|
1283
1504
|
return false;
|
1284
1505
|
}
|
1285
|
-
if (schema.modelType === "component" && name === "id")
|
1286
|
-
return false;
|
1506
|
+
if (schema.modelType === "component" && name === "id") return false;
|
1287
1507
|
const attribute = schema.attributes[name];
|
1288
1508
|
if (NON_SORTABLES.includes(attribute.type)) {
|
1289
1509
|
return false;
|
@@ -1428,8 +1648,7 @@ const createDefaultSettings = async (schema) => {
|
|
1428
1648
|
};
|
1429
1649
|
};
|
1430
1650
|
const syncSettings = async (configuration, schema) => {
|
1431
|
-
if (fp.isEmpty(configuration.settings))
|
1432
|
-
return createDefaultSettings(schema);
|
1651
|
+
if (fp.isEmpty(configuration.settings)) return createDefaultSettings(schema);
|
1433
1652
|
const defaultField = getDefaultMainField(schema);
|
1434
1653
|
const { mainField = defaultField, defaultSortBy = defaultField } = configuration.settings || {};
|
1435
1654
|
return {
|
@@ -1476,7 +1695,7 @@ const createMetadasSchema = (schema) => {
|
|
1476
1695
|
if (!value) {
|
1477
1696
|
return strapiUtils.yup.string();
|
1478
1697
|
}
|
1479
|
-
const targetSchema = getService$
|
1698
|
+
const targetSchema = getService$2("content-types").findContentType(
|
1480
1699
|
schema.attributes[key].targetModel
|
1481
1700
|
);
|
1482
1701
|
if (!targetSchema) {
|
@@ -1605,8 +1824,7 @@ const excludeNotCreatableFields = (uid2, permissionChecker2) => (body, path = []
|
|
1605
1824
|
}
|
1606
1825
|
switch (attribute.type) {
|
1607
1826
|
case "relation": {
|
1608
|
-
if (canCreate(attributePath))
|
1609
|
-
return body2;
|
1827
|
+
if (canCreate(attributePath)) return body2;
|
1610
1828
|
return fp.set(attributePath, { set: [] }, body2);
|
1611
1829
|
}
|
1612
1830
|
case "component": {
|
@@ -1616,8 +1834,7 @@ const excludeNotCreatableFields = (uid2, permissionChecker2) => (body, path = []
|
|
1616
1834
|
]);
|
1617
1835
|
}
|
1618
1836
|
default: {
|
1619
|
-
if (canCreate(attributePath))
|
1620
|
-
return body2;
|
1837
|
+
if (canCreate(attributePath)) return body2;
|
1621
1838
|
return fp.set(attributePath, null, body2);
|
1622
1839
|
}
|
1623
1840
|
}
|
@@ -1645,7 +1862,7 @@ const getDocumentLocaleAndStatus = async (request, model, opts = { allowMultiple
|
|
1645
1862
|
}
|
1646
1863
|
};
|
1647
1864
|
const formatDocumentWithMetadata = async (permissionChecker2, uid2, document, opts = {}) => {
|
1648
|
-
const documentMetadata2 = getService$
|
1865
|
+
const documentMetadata2 = getService$2("document-metadata");
|
1649
1866
|
const serviceOutput = await documentMetadata2.formatDocumentWithMetadata(uid2, document, opts);
|
1650
1867
|
let {
|
1651
1868
|
meta: { availableLocales, availableStatus }
|
@@ -1671,8 +1888,8 @@ const createDocument = async (ctx, opts) => {
|
|
1671
1888
|
const { userAbility, user } = ctx.state;
|
1672
1889
|
const { model } = ctx.params;
|
1673
1890
|
const { body } = ctx.request;
|
1674
|
-
const documentManager2 = getService$
|
1675
|
-
const permissionChecker2 = getService$
|
1891
|
+
const documentManager2 = getService$2("document-manager");
|
1892
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
1676
1893
|
if (permissionChecker2.cannot.create()) {
|
1677
1894
|
throw new strapiUtils.errors.ForbiddenError();
|
1678
1895
|
}
|
@@ -1692,13 +1909,13 @@ const updateDocument = async (ctx, opts) => {
|
|
1692
1909
|
const { userAbility, user } = ctx.state;
|
1693
1910
|
const { id, model } = ctx.params;
|
1694
1911
|
const { body } = ctx.request;
|
1695
|
-
const documentManager2 = getService$
|
1696
|
-
const permissionChecker2 = getService$
|
1912
|
+
const documentManager2 = getService$2("document-manager");
|
1913
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
1697
1914
|
if (permissionChecker2.cannot.update()) {
|
1698
1915
|
throw new strapiUtils.errors.ForbiddenError();
|
1699
1916
|
}
|
1700
1917
|
const permissionQuery = await permissionChecker2.sanitizedQuery.update(ctx.query);
|
1701
|
-
const populate = await getService$
|
1918
|
+
const populate = await getService$2("populate-builder")(model).populateFromQuery(permissionQuery).build();
|
1702
1919
|
const { locale } = await getDocumentLocaleAndStatus(body, model);
|
1703
1920
|
const [documentVersion, documentExists] = await Promise.all([
|
1704
1921
|
documentManager2.findOne(id, model, { populate, locale, status: "draft" }),
|
@@ -1715,7 +1932,7 @@ const updateDocument = async (ctx, opts) => {
|
|
1715
1932
|
throw new strapiUtils.errors.ForbiddenError();
|
1716
1933
|
}
|
1717
1934
|
const pickPermittedFields = documentVersion ? permissionChecker2.sanitizeUpdateInput(documentVersion) : permissionChecker2.sanitizeCreateInput;
|
1718
|
-
const setCreator = strapiUtils.setCreatorFields({ user, isEdition: true });
|
1935
|
+
const setCreator = documentVersion ? strapiUtils.setCreatorFields({ user, isEdition: true }) : strapiUtils.setCreatorFields({ user });
|
1719
1936
|
const sanitizeFn = strapiUtils.async.pipe(pickPermittedFields, setCreator);
|
1720
1937
|
const sanitizedBody = await sanitizeFn(body);
|
1721
1938
|
return documentManager2.update(documentVersion?.documentId || id, model, {
|
@@ -1729,14 +1946,14 @@ const collectionTypes = {
|
|
1729
1946
|
const { userAbility } = ctx.state;
|
1730
1947
|
const { model } = ctx.params;
|
1731
1948
|
const { query } = ctx.request;
|
1732
|
-
const documentMetadata2 = getService$
|
1733
|
-
const documentManager2 = getService$
|
1734
|
-
const permissionChecker2 = getService$
|
1949
|
+
const documentMetadata2 = getService$2("document-metadata");
|
1950
|
+
const documentManager2 = getService$2("document-manager");
|
1951
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
1735
1952
|
if (permissionChecker2.cannot.read()) {
|
1736
1953
|
return ctx.forbidden();
|
1737
1954
|
}
|
1738
1955
|
const permissionQuery = await permissionChecker2.sanitizedQuery.read(query);
|
1739
|
-
const populate = await getService$
|
1956
|
+
const populate = await getService$2("populate-builder")(model).populateFromQuery(permissionQuery).populateDeep(1).countRelations({ toOne: false, toMany: true }).build();
|
1740
1957
|
const { locale, status } = await getDocumentLocaleAndStatus(query, model);
|
1741
1958
|
const { results: documents, pagination } = await documentManager2.findPage(
|
1742
1959
|
{ ...permissionQuery, populate, locale, status },
|
@@ -1765,13 +1982,13 @@ const collectionTypes = {
|
|
1765
1982
|
async findOne(ctx) {
|
1766
1983
|
const { userAbility } = ctx.state;
|
1767
1984
|
const { model, id } = ctx.params;
|
1768
|
-
const documentManager2 = getService$
|
1769
|
-
const permissionChecker2 = getService$
|
1985
|
+
const documentManager2 = getService$2("document-manager");
|
1986
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
1770
1987
|
if (permissionChecker2.cannot.read()) {
|
1771
1988
|
return ctx.forbidden();
|
1772
1989
|
}
|
1773
1990
|
const permissionQuery = await permissionChecker2.sanitizedQuery.read(ctx.query);
|
1774
|
-
const populate = await getService$
|
1991
|
+
const populate = await getService$2("populate-builder")(model).populateFromQuery(permissionQuery).populateDeep(Infinity).countRelations().build();
|
1775
1992
|
const { locale, status } = await getDocumentLocaleAndStatus(ctx.query, model);
|
1776
1993
|
const version = await documentManager2.findOne(id, model, {
|
1777
1994
|
populate,
|
@@ -1802,7 +2019,7 @@ const collectionTypes = {
|
|
1802
2019
|
async create(ctx) {
|
1803
2020
|
const { userAbility } = ctx.state;
|
1804
2021
|
const { model } = ctx.params;
|
1805
|
-
const permissionChecker2 = getService$
|
2022
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
1806
2023
|
const [totalEntries, document] = await Promise.all([
|
1807
2024
|
strapi.db.query(model).count(),
|
1808
2025
|
createDocument(ctx)
|
@@ -1823,7 +2040,7 @@ const collectionTypes = {
|
|
1823
2040
|
async update(ctx) {
|
1824
2041
|
const { userAbility } = ctx.state;
|
1825
2042
|
const { model } = ctx.params;
|
1826
|
-
const permissionChecker2 = getService$
|
2043
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
1827
2044
|
const updatedVersion = await updateDocument(ctx);
|
1828
2045
|
const sanitizedVersion = await permissionChecker2.sanitizeOutput(updatedVersion);
|
1829
2046
|
ctx.body = await formatDocumentWithMetadata(permissionChecker2, model, sanitizedVersion);
|
@@ -1832,13 +2049,13 @@ const collectionTypes = {
|
|
1832
2049
|
const { userAbility, user } = ctx.state;
|
1833
2050
|
const { model, sourceId: id } = ctx.params;
|
1834
2051
|
const { body } = ctx.request;
|
1835
|
-
const documentManager2 = getService$
|
1836
|
-
const permissionChecker2 = getService$
|
2052
|
+
const documentManager2 = getService$2("document-manager");
|
2053
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
1837
2054
|
if (permissionChecker2.cannot.create()) {
|
1838
2055
|
return ctx.forbidden();
|
1839
2056
|
}
|
1840
2057
|
const permissionQuery = await permissionChecker2.sanitizedQuery.create(ctx.query);
|
1841
|
-
const populate = await getService$
|
2058
|
+
const populate = await getService$2("populate-builder")(model).populateFromQuery(permissionQuery).build();
|
1842
2059
|
const { locale } = await getDocumentLocaleAndStatus(body, model);
|
1843
2060
|
const document = await documentManager2.findOne(id, model, {
|
1844
2061
|
populate,
|
@@ -1877,13 +2094,13 @@ const collectionTypes = {
|
|
1877
2094
|
async delete(ctx) {
|
1878
2095
|
const { userAbility } = ctx.state;
|
1879
2096
|
const { id, model } = ctx.params;
|
1880
|
-
const documentManager2 = getService$
|
1881
|
-
const permissionChecker2 = getService$
|
2097
|
+
const documentManager2 = getService$2("document-manager");
|
2098
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
1882
2099
|
if (permissionChecker2.cannot.delete()) {
|
1883
2100
|
return ctx.forbidden();
|
1884
2101
|
}
|
1885
2102
|
const permissionQuery = await permissionChecker2.sanitizedQuery.delete(ctx.query);
|
1886
|
-
const populate = await getService$
|
2103
|
+
const populate = await getService$2("populate-builder")(model).populateFromQuery(permissionQuery).build();
|
1887
2104
|
const { locale } = await getDocumentLocaleAndStatus(ctx.query, model);
|
1888
2105
|
const documentLocales = await documentManager2.findLocales(id, model, { populate, locale });
|
1889
2106
|
if (documentLocales.length === 0) {
|
@@ -1905,14 +2122,14 @@ const collectionTypes = {
|
|
1905
2122
|
const { userAbility } = ctx.state;
|
1906
2123
|
const { id, model } = ctx.params;
|
1907
2124
|
const { body } = ctx.request;
|
1908
|
-
const documentManager2 = getService$
|
1909
|
-
const permissionChecker2 = getService$
|
2125
|
+
const documentManager2 = getService$2("document-manager");
|
2126
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
1910
2127
|
if (permissionChecker2.cannot.publish()) {
|
1911
2128
|
return ctx.forbidden();
|
1912
2129
|
}
|
1913
2130
|
const publishedDocument = await strapi.db.transaction(async () => {
|
1914
2131
|
const permissionQuery = await permissionChecker2.sanitizedQuery.publish(ctx.query);
|
1915
|
-
const populate = await getService$
|
2132
|
+
const populate = await getService$2("populate-builder")(model).populateFromQuery(permissionQuery).populateDeep(Infinity).countRelations().build();
|
1916
2133
|
let document;
|
1917
2134
|
const { locale } = await getDocumentLocaleAndStatus(body, model);
|
1918
2135
|
const isCreate = fp.isNil(id);
|
@@ -1960,13 +2177,13 @@ const collectionTypes = {
|
|
1960
2177
|
const { body } = ctx.request;
|
1961
2178
|
const { documentIds } = body;
|
1962
2179
|
await validateBulkActionInput(body);
|
1963
|
-
const documentManager2 = getService$
|
1964
|
-
const permissionChecker2 = getService$
|
2180
|
+
const documentManager2 = getService$2("document-manager");
|
2181
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
1965
2182
|
if (permissionChecker2.cannot.publish()) {
|
1966
2183
|
return ctx.forbidden();
|
1967
2184
|
}
|
1968
2185
|
const permissionQuery = await permissionChecker2.sanitizedQuery.publish(ctx.query);
|
1969
|
-
const populate = await getService$
|
2186
|
+
const populate = await getService$2("populate-builder")(model).populateFromQuery(permissionQuery).populateDeep(Infinity).countRelations().build();
|
1970
2187
|
const { locale } = await getDocumentLocaleAndStatus(body, model, {
|
1971
2188
|
allowMultipleLocales: true
|
1972
2189
|
});
|
@@ -1991,8 +2208,8 @@ const collectionTypes = {
|
|
1991
2208
|
const { body } = ctx.request;
|
1992
2209
|
const { documentIds } = body;
|
1993
2210
|
await validateBulkActionInput(body);
|
1994
|
-
const documentManager2 = getService$
|
1995
|
-
const permissionChecker2 = getService$
|
2211
|
+
const documentManager2 = getService$2("document-manager");
|
2212
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
1996
2213
|
if (permissionChecker2.cannot.unpublish()) {
|
1997
2214
|
return ctx.forbidden();
|
1998
2215
|
}
|
@@ -2021,8 +2238,8 @@ const collectionTypes = {
|
|
2021
2238
|
const {
|
2022
2239
|
body: { discardDraft, ...body }
|
2023
2240
|
} = ctx.request;
|
2024
|
-
const documentManager2 = getService$
|
2025
|
-
const permissionChecker2 = getService$
|
2241
|
+
const documentManager2 = getService$2("document-manager");
|
2242
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
2026
2243
|
if (permissionChecker2.cannot.unpublish()) {
|
2027
2244
|
return ctx.forbidden();
|
2028
2245
|
}
|
@@ -2030,7 +2247,7 @@ const collectionTypes = {
|
|
2030
2247
|
return ctx.forbidden();
|
2031
2248
|
}
|
2032
2249
|
const permissionQuery = await permissionChecker2.sanitizedQuery.unpublish(ctx.query);
|
2033
|
-
const populate = await getService$
|
2250
|
+
const populate = await getService$2("populate-builder")(model).populateFromQuery(permissionQuery).build();
|
2034
2251
|
const { locale } = await getDocumentLocaleAndStatus(body, model);
|
2035
2252
|
const document = await documentManager2.findOne(id, model, {
|
2036
2253
|
populate,
|
@@ -2061,13 +2278,13 @@ const collectionTypes = {
|
|
2061
2278
|
const { userAbility } = ctx.state;
|
2062
2279
|
const { id, model } = ctx.params;
|
2063
2280
|
const { body } = ctx.request;
|
2064
|
-
const documentManager2 = getService$
|
2065
|
-
const permissionChecker2 = getService$
|
2281
|
+
const documentManager2 = getService$2("document-manager");
|
2282
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
2066
2283
|
if (permissionChecker2.cannot.discard()) {
|
2067
2284
|
return ctx.forbidden();
|
2068
2285
|
}
|
2069
2286
|
const permissionQuery = await permissionChecker2.sanitizedQuery.discard(ctx.query);
|
2070
|
-
const populate = await getService$
|
2287
|
+
const populate = await getService$2("populate-builder")(model).populateFromQuery(permissionQuery).build();
|
2071
2288
|
const { locale } = await getDocumentLocaleAndStatus(body, model);
|
2072
2289
|
const document = await documentManager2.findOne(id, model, {
|
2073
2290
|
populate,
|
@@ -2092,13 +2309,13 @@ const collectionTypes = {
|
|
2092
2309
|
const { query, body } = ctx.request;
|
2093
2310
|
const { documentIds } = body;
|
2094
2311
|
await validateBulkActionInput(body);
|
2095
|
-
const documentManager2 = getService$
|
2096
|
-
const permissionChecker2 = getService$
|
2312
|
+
const documentManager2 = getService$2("document-manager");
|
2313
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
2097
2314
|
if (permissionChecker2.cannot.delete()) {
|
2098
2315
|
return ctx.forbidden();
|
2099
2316
|
}
|
2100
2317
|
const permissionQuery = await permissionChecker2.sanitizedQuery.delete(query);
|
2101
|
-
const populate = await getService$
|
2318
|
+
const populate = await getService$2("populate-builder")(model).populateFromQuery(permissionQuery).build();
|
2102
2319
|
const { locale } = await getDocumentLocaleAndStatus(body, model);
|
2103
2320
|
const documentLocales = await documentManager2.findLocales(documentIds, model, {
|
2104
2321
|
populate,
|
@@ -2119,13 +2336,13 @@ const collectionTypes = {
|
|
2119
2336
|
async countDraftRelations(ctx) {
|
2120
2337
|
const { userAbility } = ctx.state;
|
2121
2338
|
const { model, id } = ctx.params;
|
2122
|
-
const documentManager2 = getService$
|
2123
|
-
const permissionChecker2 = getService$
|
2339
|
+
const documentManager2 = getService$2("document-manager");
|
2340
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
2124
2341
|
if (permissionChecker2.cannot.read()) {
|
2125
2342
|
return ctx.forbidden();
|
2126
2343
|
}
|
2127
2344
|
const permissionQuery = await permissionChecker2.sanitizedQuery.read(ctx.query);
|
2128
|
-
const populate = await getService$
|
2345
|
+
const populate = await getService$2("populate-builder")(model).populateFromQuery(permissionQuery).build();
|
2129
2346
|
const { locale, status } = await getDocumentLocaleAndStatus(ctx.query, model);
|
2130
2347
|
const entity = await documentManager2.findOne(id, model, { populate, locale, status });
|
2131
2348
|
if (!entity) {
|
@@ -2144,8 +2361,8 @@ const collectionTypes = {
|
|
2144
2361
|
const ids = ctx.request.query.documentIds;
|
2145
2362
|
const locale = ctx.request.query.locale;
|
2146
2363
|
const { model } = ctx.params;
|
2147
|
-
const documentManager2 = getService$
|
2148
|
-
const permissionChecker2 = getService$
|
2364
|
+
const documentManager2 = getService$2("document-manager");
|
2365
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
2149
2366
|
if (permissionChecker2.cannot.read()) {
|
2150
2367
|
return ctx.forbidden();
|
2151
2368
|
}
|
@@ -2169,13 +2386,13 @@ const collectionTypes = {
|
|
2169
2386
|
};
|
2170
2387
|
const components$1 = {
|
2171
2388
|
findComponents(ctx) {
|
2172
|
-
const components2 = getService$
|
2173
|
-
const { toDto } = getService$
|
2389
|
+
const components2 = getService$2("components").findAllComponents();
|
2390
|
+
const { toDto } = getService$2("data-mapper");
|
2174
2391
|
ctx.body = { data: components2.map(toDto) };
|
2175
2392
|
},
|
2176
2393
|
async findComponentConfiguration(ctx) {
|
2177
2394
|
const { uid: uid2 } = ctx.params;
|
2178
|
-
const componentService = getService$
|
2395
|
+
const componentService = getService$2("components");
|
2179
2396
|
const component = componentService.findComponent(uid2);
|
2180
2397
|
if (!component) {
|
2181
2398
|
return ctx.notFound("component.notFound");
|
@@ -2192,7 +2409,7 @@ const components$1 = {
|
|
2192
2409
|
async updateComponentConfiguration(ctx) {
|
2193
2410
|
const { uid: uid2 } = ctx.params;
|
2194
2411
|
const { body } = ctx.request;
|
2195
|
-
const componentService = getService$
|
2412
|
+
const componentService = getService$2("components");
|
2196
2413
|
const component = componentService.findComponent(uid2);
|
2197
2414
|
if (!component) {
|
2198
2415
|
return ctx.notFound("component.notFound");
|
@@ -2226,12 +2443,12 @@ const contentTypes = {
|
|
2226
2443
|
} catch (error) {
|
2227
2444
|
return ctx.send({ error }, 400);
|
2228
2445
|
}
|
2229
|
-
const contentTypes2 = getService$
|
2230
|
-
const { toDto } = getService$
|
2446
|
+
const contentTypes2 = getService$2("content-types").findContentTypesByKind(kind);
|
2447
|
+
const { toDto } = getService$2("data-mapper");
|
2231
2448
|
ctx.body = { data: contentTypes2.map(toDto) };
|
2232
2449
|
},
|
2233
2450
|
async findContentTypesSettings(ctx) {
|
2234
|
-
const { findAllContentTypes, findConfiguration } = getService$
|
2451
|
+
const { findAllContentTypes, findConfiguration } = getService$2("content-types");
|
2235
2452
|
const contentTypes2 = await findAllContentTypes();
|
2236
2453
|
const configurations = await Promise.all(
|
2237
2454
|
contentTypes2.map(async (contentType) => {
|
@@ -2245,7 +2462,7 @@ const contentTypes = {
|
|
2245
2462
|
},
|
2246
2463
|
async findContentTypeConfiguration(ctx) {
|
2247
2464
|
const { uid: uid2 } = ctx.params;
|
2248
|
-
const contentTypeService = getService$
|
2465
|
+
const contentTypeService = getService$2("content-types");
|
2249
2466
|
const contentType = await contentTypeService.findContentType(uid2);
|
2250
2467
|
if (!contentType) {
|
2251
2468
|
return ctx.notFound("contentType.notFound");
|
@@ -2267,13 +2484,13 @@ const contentTypes = {
|
|
2267
2484
|
const { userAbility } = ctx.state;
|
2268
2485
|
const { uid: uid2 } = ctx.params;
|
2269
2486
|
const { body } = ctx.request;
|
2270
|
-
const contentTypeService = getService$
|
2271
|
-
const metricsService = getService$
|
2487
|
+
const contentTypeService = getService$2("content-types");
|
2488
|
+
const metricsService = getService$2("metrics");
|
2272
2489
|
const contentType = await contentTypeService.findContentType(uid2);
|
2273
2490
|
if (!contentType) {
|
2274
2491
|
return ctx.notFound("contentType.notFound");
|
2275
2492
|
}
|
2276
|
-
if (!getService$
|
2493
|
+
if (!getService$2("permission").canConfigureContentType({ userAbility, contentType })) {
|
2277
2494
|
return ctx.forbidden();
|
2278
2495
|
}
|
2279
2496
|
let input;
|
@@ -2306,10 +2523,10 @@ const contentTypes = {
|
|
2306
2523
|
};
|
2307
2524
|
const init = {
|
2308
2525
|
getInitData(ctx) {
|
2309
|
-
const { toDto } = getService$
|
2310
|
-
const { findAllComponents } = getService$
|
2311
|
-
const { getAllFieldSizes } = getService$
|
2312
|
-
const { findAllContentTypes } = getService$
|
2526
|
+
const { toDto } = getService$2("data-mapper");
|
2527
|
+
const { findAllComponents } = getService$2("components");
|
2528
|
+
const { getAllFieldSizes } = getService$2("field-sizes");
|
2529
|
+
const { findAllContentTypes } = getService$2("content-types");
|
2313
2530
|
ctx.body = {
|
2314
2531
|
data: {
|
2315
2532
|
fieldSizes: getAllFieldSizes(),
|
@@ -2345,7 +2562,7 @@ const addFiltersClause = (params, filtersClause) => {
|
|
2345
2562
|
params.filters.$and.push(filtersClause);
|
2346
2563
|
};
|
2347
2564
|
const sanitizeMainField = (model, mainField, userAbility) => {
|
2348
|
-
const permissionChecker2 = getService$
|
2565
|
+
const permissionChecker2 = getService$2("permission-checker").create({
|
2349
2566
|
userAbility,
|
2350
2567
|
model: model.uid
|
2351
2568
|
});
|
@@ -2359,15 +2576,27 @@ const sanitizeMainField = (model, mainField, userAbility) => {
|
|
2359
2576
|
}
|
2360
2577
|
return mainField;
|
2361
2578
|
};
|
2362
|
-
const addStatusToRelations = async (
|
2363
|
-
if (!strapiUtils.contentTypes.hasDraftAndPublish(strapi.
|
2579
|
+
const addStatusToRelations = async (targetUid, relations2) => {
|
2580
|
+
if (!strapiUtils.contentTypes.hasDraftAndPublish(strapi.getModel(targetUid))) {
|
2581
|
+
return relations2;
|
2582
|
+
}
|
2583
|
+
const documentMetadata2 = getService$2("document-metadata");
|
2584
|
+
if (!relations2.length) {
|
2364
2585
|
return relations2;
|
2365
2586
|
}
|
2366
|
-
const
|
2367
|
-
const
|
2587
|
+
const firstRelation = relations2[0];
|
2588
|
+
const filters = {
|
2589
|
+
documentId: { $in: relations2.map((r) => r.documentId) },
|
2590
|
+
// NOTE: find the "opposite" status
|
2591
|
+
publishedAt: firstRelation.publishedAt !== null ? { $null: true } : { $notNull: true }
|
2592
|
+
};
|
2593
|
+
const availableStatus = await strapi.query(targetUid).findMany({
|
2594
|
+
select: ["id", "documentId", "locale", "updatedAt", "createdAt", "publishedAt"],
|
2595
|
+
filters
|
2596
|
+
});
|
2368
2597
|
return relations2.map((relation) => {
|
2369
|
-
const availableStatuses =
|
2370
|
-
(availableDocument) => availableDocument.documentId === relation.documentId
|
2598
|
+
const availableStatuses = availableStatus.filter(
|
2599
|
+
(availableDocument) => availableDocument.documentId === relation.documentId && (relation.locale ? availableDocument.locale === relation.locale : true)
|
2371
2600
|
);
|
2372
2601
|
return {
|
2373
2602
|
...relation,
|
@@ -2388,11 +2617,8 @@ const validateLocale = (sourceUid, targetUid, locale) => {
|
|
2388
2617
|
const isLocalized = strapi.plugin("i18n").service("content-types").isLocalizedContentType;
|
2389
2618
|
const isSourceLocalized = isLocalized(sourceModel);
|
2390
2619
|
const isTargetLocalized = isLocalized(targetModel);
|
2391
|
-
let validatedLocale = locale;
|
2392
|
-
if (!targetModel || !isTargetLocalized)
|
2393
|
-
validatedLocale = void 0;
|
2394
2620
|
return {
|
2395
|
-
locale
|
2621
|
+
locale,
|
2396
2622
|
isSourceLocalized,
|
2397
2623
|
isTargetLocalized
|
2398
2624
|
};
|
@@ -2401,8 +2627,7 @@ const validateStatus = (sourceUid, status) => {
|
|
2401
2627
|
const sourceModel = strapi.getModel(sourceUid);
|
2402
2628
|
const isDP = strapiUtils.contentTypes.hasDraftAndPublish;
|
2403
2629
|
const isSourceDP = isDP(sourceModel);
|
2404
|
-
if (!isSourceDP)
|
2405
|
-
return { status: void 0 };
|
2630
|
+
if (!isSourceDP) return { status: void 0 };
|
2406
2631
|
switch (status) {
|
2407
2632
|
case "published":
|
2408
2633
|
return { status: "published" };
|
@@ -2432,7 +2657,7 @@ const relations = {
|
|
2432
2657
|
ctx.request?.query?.locale
|
2433
2658
|
);
|
2434
2659
|
const { status } = validateStatus(sourceUid, ctx.request?.query?.status);
|
2435
|
-
const permissionChecker2 = getService$
|
2660
|
+
const permissionChecker2 = getService$2("permission-checker").create({
|
2436
2661
|
userAbility,
|
2437
2662
|
model
|
2438
2663
|
});
|
@@ -2457,7 +2682,7 @@ const relations = {
|
|
2457
2682
|
where.id = id;
|
2458
2683
|
}
|
2459
2684
|
const permissionQuery = await permissionChecker2.sanitizedQuery.read(ctx.query);
|
2460
|
-
const populate = await getService$
|
2685
|
+
const populate = await getService$2("populate-builder")(model).populateFromQuery(permissionQuery).build();
|
2461
2686
|
const currentEntity = await strapi.db.query(model).findOne({
|
2462
2687
|
where,
|
2463
2688
|
populate
|
@@ -2472,7 +2697,7 @@ const relations = {
|
|
2472
2697
|
}
|
2473
2698
|
entryId = currentEntity.id;
|
2474
2699
|
}
|
2475
|
-
const modelConfig = isComponent2 ? await getService$
|
2700
|
+
const modelConfig = isComponent2 ? await getService$2("components").findConfiguration(sourceSchema) : await getService$2("content-types").findConfiguration(sourceSchema);
|
2476
2701
|
const targetSchema = strapi.getModel(targetUid);
|
2477
2702
|
const mainField = fp.flow(
|
2478
2703
|
fp.prop(`metadatas.${targetField}.edit.mainField`),
|
@@ -2495,7 +2720,7 @@ const relations = {
|
|
2495
2720
|
attribute,
|
2496
2721
|
fieldsToSelect,
|
2497
2722
|
mainField,
|
2498
|
-
source: { schema: sourceSchema },
|
2723
|
+
source: { schema: sourceSchema, isLocalized: isSourceLocalized },
|
2499
2724
|
target: { schema: targetSchema, isLocalized: isTargetLocalized },
|
2500
2725
|
sourceSchema,
|
2501
2726
|
targetSchema,
|
@@ -2517,7 +2742,8 @@ const relations = {
|
|
2517
2742
|
fieldsToSelect,
|
2518
2743
|
mainField,
|
2519
2744
|
source: {
|
2520
|
-
schema: { uid: sourceUid, modelType: sourceModelType }
|
2745
|
+
schema: { uid: sourceUid, modelType: sourceModelType },
|
2746
|
+
isLocalized: isSourceLocalized
|
2521
2747
|
},
|
2522
2748
|
target: {
|
2523
2749
|
schema: { uid: targetUid },
|
@@ -2525,7 +2751,7 @@ const relations = {
|
|
2525
2751
|
}
|
2526
2752
|
} = await this.extractAndValidateRequestInfo(ctx, id);
|
2527
2753
|
const { idsToOmit, idsToInclude, _q, ...query } = ctx.request.query;
|
2528
|
-
const permissionChecker2 = getService$
|
2754
|
+
const permissionChecker2 = getService$2("permission-checker").create({
|
2529
2755
|
userAbility: ctx.state.userAbility,
|
2530
2756
|
model: targetUid
|
2531
2757
|
});
|
@@ -2559,9 +2785,12 @@ const relations = {
|
|
2559
2785
|
if (!fp.isEmpty(publishedAt)) {
|
2560
2786
|
where[`${alias}.published_at`] = publishedAt;
|
2561
2787
|
}
|
2562
|
-
if (
|
2788
|
+
if (isTargetLocalized && locale) {
|
2563
2789
|
where[`${alias}.locale`] = locale;
|
2564
2790
|
}
|
2791
|
+
if (isSourceLocalized && locale) {
|
2792
|
+
where.locale = locale;
|
2793
|
+
}
|
2565
2794
|
if ((idsToInclude?.length ?? 0) !== 0) {
|
2566
2795
|
where[`${alias}.id`].$notIn = idsToInclude;
|
2567
2796
|
}
|
@@ -2579,7 +2808,8 @@ const relations = {
|
|
2579
2808
|
id: { $notIn: fp.uniq(idsToOmit) }
|
2580
2809
|
});
|
2581
2810
|
}
|
2582
|
-
const
|
2811
|
+
const dbQuery = strapi.get("query-params").transform(targetUid, queryParams);
|
2812
|
+
const res = await strapi.db.query(targetUid).findPage(dbQuery);
|
2583
2813
|
ctx.body = {
|
2584
2814
|
...res,
|
2585
2815
|
results: await addStatusToRelations(targetUid, res.results)
|
@@ -2594,21 +2824,33 @@ const relations = {
|
|
2594
2824
|
attribute,
|
2595
2825
|
targetField,
|
2596
2826
|
fieldsToSelect,
|
2597
|
-
|
2598
|
-
|
2599
|
-
}
|
2600
|
-
target: {
|
2601
|
-
schema: { uid: targetUid }
|
2602
|
-
}
|
2827
|
+
status,
|
2828
|
+
source: { schema: sourceSchema },
|
2829
|
+
target: { schema: targetSchema }
|
2603
2830
|
} = await this.extractAndValidateRequestInfo(ctx, id);
|
2604
|
-
const
|
2831
|
+
const { uid: sourceUid } = sourceSchema;
|
2832
|
+
const { uid: targetUid } = targetSchema;
|
2833
|
+
const permissionQuery = await getService$2("permission-checker").create({ userAbility, model: targetUid }).sanitizedQuery.read({ fields: fieldsToSelect });
|
2605
2834
|
const dbQuery = strapi.db.query(sourceUid);
|
2606
2835
|
const loadRelations = strapiUtils.relations.isAnyToMany(attribute) ? (...args) => dbQuery.loadPages(...args) : (...args) => dbQuery.load(...args).then((res2) => ({ results: res2 ? [res2] : [] }));
|
2836
|
+
const filters = {};
|
2837
|
+
if (sourceSchema?.options?.draftAndPublish) {
|
2838
|
+
if (targetSchema?.options?.draftAndPublish) {
|
2839
|
+
if (status === "published") {
|
2840
|
+
filters.publishedAt = { $notNull: true };
|
2841
|
+
} else {
|
2842
|
+
filters.publishedAt = { $null: true };
|
2843
|
+
}
|
2844
|
+
}
|
2845
|
+
} else if (targetSchema?.options?.draftAndPublish) {
|
2846
|
+
filters.publishedAt = { $null: true };
|
2847
|
+
}
|
2607
2848
|
const res = await loadRelations({ id: entryId }, targetField, {
|
2608
|
-
select: ["id", "documentId", "locale", "publishedAt"],
|
2849
|
+
select: ["id", "documentId", "locale", "publishedAt", "updatedAt"],
|
2609
2850
|
ordering: "desc",
|
2610
2851
|
page: ctx.request.query.page,
|
2611
|
-
pageSize: ctx.request.query.pageSize
|
2852
|
+
pageSize: ctx.request.query.pageSize,
|
2853
|
+
filters
|
2612
2854
|
});
|
2613
2855
|
const loadedIds = res.results.map((item) => item.id);
|
2614
2856
|
addFiltersClause(permissionQuery, { id: { $in: loadedIds } });
|
@@ -2629,10 +2871,10 @@ const relations = {
|
|
2629
2871
|
}
|
2630
2872
|
};
|
2631
2873
|
const buildPopulateFromQuery = async (query, model) => {
|
2632
|
-
return getService$
|
2874
|
+
return getService$2("populate-builder")(model).populateFromQuery(query).populateDeep(Infinity).countRelations().build();
|
2633
2875
|
};
|
2634
2876
|
const findDocument = async (query, uid2, opts = {}) => {
|
2635
|
-
const documentManager2 = getService$
|
2877
|
+
const documentManager2 = getService$2("document-manager");
|
2636
2878
|
const populate = await buildPopulateFromQuery(query, uid2);
|
2637
2879
|
return documentManager2.findMany({ ...opts, populate }, uid2).then((documents) => documents[0]);
|
2638
2880
|
};
|
@@ -2640,8 +2882,8 @@ const createOrUpdateDocument = async (ctx, opts) => {
|
|
2640
2882
|
const { user, userAbility } = ctx.state;
|
2641
2883
|
const { model } = ctx.params;
|
2642
2884
|
const { body, query } = ctx.request;
|
2643
|
-
const documentManager2 = getService$
|
2644
|
-
const permissionChecker2 = getService$
|
2885
|
+
const documentManager2 = getService$2("document-manager");
|
2886
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
2645
2887
|
if (permissionChecker2.cannot.create() && permissionChecker2.cannot.update()) {
|
2646
2888
|
throw new strapiUtils.errors.ForbiddenError();
|
2647
2889
|
}
|
@@ -2682,7 +2924,7 @@ const singleTypes = {
|
|
2682
2924
|
const { userAbility } = ctx.state;
|
2683
2925
|
const { model } = ctx.params;
|
2684
2926
|
const { query = {} } = ctx.request;
|
2685
|
-
const permissionChecker2 = getService$
|
2927
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
2686
2928
|
if (permissionChecker2.cannot.read()) {
|
2687
2929
|
return ctx.forbidden();
|
2688
2930
|
}
|
@@ -2716,7 +2958,7 @@ const singleTypes = {
|
|
2716
2958
|
async createOrUpdate(ctx) {
|
2717
2959
|
const { userAbility } = ctx.state;
|
2718
2960
|
const { model } = ctx.params;
|
2719
|
-
const permissionChecker2 = getService$
|
2961
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
2720
2962
|
const document = await createOrUpdateDocument(ctx);
|
2721
2963
|
const sanitizedDocument = await permissionChecker2.sanitizeOutput(document);
|
2722
2964
|
ctx.body = await formatDocumentWithMetadata(permissionChecker2, model, sanitizedDocument);
|
@@ -2725,8 +2967,8 @@ const singleTypes = {
|
|
2725
2967
|
const { userAbility } = ctx.state;
|
2726
2968
|
const { model } = ctx.params;
|
2727
2969
|
const { query = {} } = ctx.request;
|
2728
|
-
const documentManager2 = getService$
|
2729
|
-
const permissionChecker2 = getService$
|
2970
|
+
const documentManager2 = getService$2("document-manager");
|
2971
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
2730
2972
|
if (permissionChecker2.cannot.delete()) {
|
2731
2973
|
return ctx.forbidden();
|
2732
2974
|
}
|
@@ -2754,8 +2996,8 @@ const singleTypes = {
|
|
2754
2996
|
const { userAbility } = ctx.state;
|
2755
2997
|
const { model } = ctx.params;
|
2756
2998
|
const { query = {} } = ctx.request;
|
2757
|
-
const documentManager2 = getService$
|
2758
|
-
const permissionChecker2 = getService$
|
2999
|
+
const documentManager2 = getService$2("document-manager");
|
3000
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
2759
3001
|
if (permissionChecker2.cannot.publish()) {
|
2760
3002
|
return ctx.forbidden();
|
2761
3003
|
}
|
@@ -2783,8 +3025,8 @@ const singleTypes = {
|
|
2783
3025
|
body: { discardDraft, ...body },
|
2784
3026
|
query = {}
|
2785
3027
|
} = ctx.request;
|
2786
|
-
const documentManager2 = getService$
|
2787
|
-
const permissionChecker2 = getService$
|
3028
|
+
const documentManager2 = getService$2("document-manager");
|
3029
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
2788
3030
|
if (permissionChecker2.cannot.unpublish()) {
|
2789
3031
|
return ctx.forbidden();
|
2790
3032
|
}
|
@@ -2818,8 +3060,8 @@ const singleTypes = {
|
|
2818
3060
|
const { userAbility } = ctx.state;
|
2819
3061
|
const { model } = ctx.params;
|
2820
3062
|
const { body, query = {} } = ctx.request;
|
2821
|
-
const documentManager2 = getService$
|
2822
|
-
const permissionChecker2 = getService$
|
3063
|
+
const documentManager2 = getService$2("document-manager");
|
3064
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
2823
3065
|
if (permissionChecker2.cannot.discard()) {
|
2824
3066
|
return ctx.forbidden();
|
2825
3067
|
}
|
@@ -2842,8 +3084,8 @@ const singleTypes = {
|
|
2842
3084
|
const { userAbility } = ctx.state;
|
2843
3085
|
const { model } = ctx.params;
|
2844
3086
|
const { query } = ctx.request;
|
2845
|
-
const documentManager2 = getService$
|
2846
|
-
const permissionChecker2 = getService$
|
3087
|
+
const documentManager2 = getService$2("document-manager");
|
3088
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
2847
3089
|
const { locale } = await getDocumentLocaleAndStatus(query, model);
|
2848
3090
|
if (permissionChecker2.cannot.read()) {
|
2849
3091
|
return ctx.forbidden();
|
@@ -2867,7 +3109,7 @@ const uid$1 = {
|
|
2867
3109
|
const { query = {} } = ctx.request;
|
2868
3110
|
const { locale } = await getDocumentLocaleAndStatus(query, contentTypeUID);
|
2869
3111
|
await validateUIDField(contentTypeUID, field);
|
2870
|
-
const uidService = getService$
|
3112
|
+
const uidService = getService$2("uid");
|
2871
3113
|
ctx.body = {
|
2872
3114
|
data: await uidService.generateUIDField({ contentTypeUID, field, data, locale })
|
2873
3115
|
};
|
@@ -2879,7 +3121,7 @@ const uid$1 = {
|
|
2879
3121
|
const { query = {} } = ctx.request;
|
2880
3122
|
const { locale } = await getDocumentLocaleAndStatus(query, contentTypeUID);
|
2881
3123
|
await validateUIDField(contentTypeUID, field);
|
2882
|
-
const uidService = getService$
|
3124
|
+
const uidService = getService$2("uid");
|
2883
3125
|
const isAvailable = await uidService.checkUIDAvailability({
|
2884
3126
|
contentTypeUID,
|
2885
3127
|
field,
|
@@ -2900,7 +3142,8 @@ const controllers = {
|
|
2900
3142
|
relations,
|
2901
3143
|
"single-types": singleTypes,
|
2902
3144
|
uid: uid$1,
|
2903
|
-
...history.controllers ? history.controllers : {}
|
3145
|
+
...history.controllers ? history.controllers : {},
|
3146
|
+
...preview.controllers ? preview.controllers : {}
|
2904
3147
|
};
|
2905
3148
|
const keys = {
|
2906
3149
|
CONFIGURATION: "configuration"
|
@@ -3029,18 +3272,15 @@ async function syncMetadatas(configuration, schema) {
|
|
3029
3272
|
___default.default.set(updatedMeta, ["list", "searchable"], false);
|
3030
3273
|
___default.default.set(acc, [key], updatedMeta);
|
3031
3274
|
}
|
3032
|
-
if (!___default.default.has(edit, "mainField"))
|
3033
|
-
return acc;
|
3275
|
+
if (!___default.default.has(edit, "mainField")) return acc;
|
3034
3276
|
if (!isRelation$1(attr)) {
|
3035
3277
|
___default.default.set(updatedMeta, "edit", ___default.default.omit(edit, ["mainField"]));
|
3036
3278
|
___default.default.set(acc, [key], updatedMeta);
|
3037
3279
|
return acc;
|
3038
3280
|
}
|
3039
|
-
if (edit.mainField === "id")
|
3040
|
-
return acc;
|
3281
|
+
if (edit.mainField === "id") return acc;
|
3041
3282
|
const targetSchema = getTargetSchema(attr.targetModel);
|
3042
|
-
if (!targetSchema)
|
3043
|
-
return acc;
|
3283
|
+
if (!targetSchema) return acc;
|
3044
3284
|
if (!isSortable(targetSchema, edit.mainField) && !isListable(targetSchema, edit.mainField)) {
|
3045
3285
|
___default.default.set(updatedMeta, ["edit", "mainField"], getDefaultMainField(targetSchema));
|
3046
3286
|
___default.default.set(acc, [key], updatedMeta);
|
@@ -3051,12 +3291,12 @@ async function syncMetadatas(configuration, schema) {
|
|
3051
3291
|
return ___default.default.assign(metasWithDefaults, updatedMetas);
|
3052
3292
|
}
|
3053
3293
|
const getTargetSchema = (targetModel) => {
|
3054
|
-
return getService$
|
3294
|
+
return getService$2("content-types").findContentType(targetModel);
|
3055
3295
|
};
|
3056
3296
|
const DEFAULT_LIST_LENGTH = 4;
|
3057
3297
|
const MAX_ROW_SIZE = 12;
|
3058
3298
|
const isAllowedFieldSize = (type, size) => {
|
3059
|
-
const { getFieldSize } = getService$
|
3299
|
+
const { getFieldSize } = getService$2("field-sizes");
|
3060
3300
|
const fieldSize = getFieldSize(type);
|
3061
3301
|
if (!fieldSize.isResizable && size !== fieldSize.default) {
|
3062
3302
|
return false;
|
@@ -3064,7 +3304,7 @@ const isAllowedFieldSize = (type, size) => {
|
|
3064
3304
|
return size <= MAX_ROW_SIZE;
|
3065
3305
|
};
|
3066
3306
|
const getDefaultFieldSize = (attribute) => {
|
3067
|
-
const { hasFieldSize, getFieldSize } = getService$
|
3307
|
+
const { hasFieldSize, getFieldSize } = getService$2("field-sizes");
|
3068
3308
|
return getFieldSize(hasFieldSize(attribute.customField) ? attribute.customField : attribute.type).default;
|
3069
3309
|
};
|
3070
3310
|
async function createDefaultLayouts(schema) {
|
@@ -3085,8 +3325,7 @@ function createDefaultEditLayout(schema) {
|
|
3085
3325
|
return appendToEditLayout([], keys2, schema);
|
3086
3326
|
}
|
3087
3327
|
function syncLayouts(configuration, schema) {
|
3088
|
-
if (___default.default.isEmpty(configuration.layouts))
|
3089
|
-
return createDefaultLayouts(schema);
|
3328
|
+
if (___default.default.isEmpty(configuration.layouts)) return createDefaultLayouts(schema);
|
3090
3329
|
const { list = [], editRelations = [], edit = [] } = configuration.layouts || {};
|
3091
3330
|
let cleanList = list.filter((attr) => isListable(schema, attr));
|
3092
3331
|
const cleanEditRelations = editRelations.filter(
|
@@ -3097,9 +3336,8 @@ function syncLayouts(configuration, schema) {
|
|
3097
3336
|
for (const row of edit) {
|
3098
3337
|
const newRow = [];
|
3099
3338
|
for (const el of row) {
|
3100
|
-
if (!hasEditableAttribute(schema, el.name))
|
3101
|
-
|
3102
|
-
const { hasFieldSize } = getService$1("field-sizes");
|
3339
|
+
if (!hasEditableAttribute(schema, el.name)) continue;
|
3340
|
+
const { hasFieldSize } = getService$2("field-sizes");
|
3103
3341
|
const fieldType = hasFieldSize(schema.attributes[el.name].customField) ? schema.attributes[el.name].customField : schema.attributes[el.name].type;
|
3104
3342
|
if (!isAllowedFieldSize(fieldType, el.size)) {
|
3105
3343
|
elementsToReAppend.push(el.name);
|
@@ -3129,8 +3367,7 @@ function syncLayouts(configuration, schema) {
|
|
3129
3367
|
};
|
3130
3368
|
}
|
3131
3369
|
const appendToEditLayout = (layout = [], keysToAppend, schema) => {
|
3132
|
-
if (keysToAppend.length === 0)
|
3133
|
-
return layout;
|
3370
|
+
if (keysToAppend.length === 0) return layout;
|
3134
3371
|
let currentRowIndex = Math.max(layout.length - 1, 0);
|
3135
3372
|
if (!layout[currentRowIndex]) {
|
3136
3373
|
layout[currentRowIndex] = [];
|
@@ -3239,17 +3476,17 @@ const configurationService$1 = createConfigurationService({
|
|
3239
3476
|
isComponent: true,
|
3240
3477
|
prefix: STORE_KEY_PREFIX,
|
3241
3478
|
getModels() {
|
3242
|
-
const { toContentManagerModel } = getService$
|
3479
|
+
const { toContentManagerModel } = getService$2("data-mapper");
|
3243
3480
|
return fp.mapValues(toContentManagerModel, strapi.components);
|
3244
3481
|
}
|
3245
3482
|
});
|
3246
3483
|
const components = ({ strapi: strapi2 }) => ({
|
3247
3484
|
findAllComponents() {
|
3248
|
-
const { toContentManagerModel } = getService$
|
3485
|
+
const { toContentManagerModel } = getService$2("data-mapper");
|
3249
3486
|
return Object.values(strapi2.components).map(toContentManagerModel);
|
3250
3487
|
},
|
3251
3488
|
findComponent(uid2) {
|
3252
|
-
const { toContentManagerModel } = getService$
|
3489
|
+
const { toContentManagerModel } = getService$2("data-mapper");
|
3253
3490
|
const component = strapi2.components[uid2];
|
3254
3491
|
return fp.isNil(component) ? component : toContentManagerModel(component);
|
3255
3492
|
},
|
@@ -3300,17 +3537,17 @@ const configurationService = createConfigurationService({
|
|
3300
3537
|
storeUtils,
|
3301
3538
|
prefix: "content_types",
|
3302
3539
|
getModels() {
|
3303
|
-
const { toContentManagerModel } = getService$
|
3540
|
+
const { toContentManagerModel } = getService$2("data-mapper");
|
3304
3541
|
return fp.mapValues(toContentManagerModel, strapi.contentTypes);
|
3305
3542
|
}
|
3306
3543
|
});
|
3307
3544
|
const service = ({ strapi: strapi2 }) => ({
|
3308
3545
|
findAllContentTypes() {
|
3309
|
-
const { toContentManagerModel } = getService$
|
3546
|
+
const { toContentManagerModel } = getService$2("data-mapper");
|
3310
3547
|
return Object.values(strapi2.contentTypes).map(toContentManagerModel);
|
3311
3548
|
},
|
3312
3549
|
findContentType(uid2) {
|
3313
|
-
const { toContentManagerModel } = getService$
|
3550
|
+
const { toContentManagerModel } = getService$2("data-mapper");
|
3314
3551
|
const contentType = strapi2.contentTypes[uid2];
|
3315
3552
|
return fp.isNil(contentType) ? contentType : toContentManagerModel(contentType);
|
3316
3553
|
},
|
@@ -3339,7 +3576,7 @@ const service = ({ strapi: strapi2 }) => ({
|
|
3339
3576
|
return this.findConfiguration(contentType);
|
3340
3577
|
},
|
3341
3578
|
findComponentsConfigurations(contentType) {
|
3342
|
-
return getService$
|
3579
|
+
return getService$2("components").findComponentsConfigurations(contentType);
|
3343
3580
|
},
|
3344
3581
|
syncConfigurations() {
|
3345
3582
|
return configurationService.syncConfigurations();
|
@@ -3611,7 +3848,7 @@ const permission = ({ strapi: strapi2 }) => ({
|
|
3611
3848
|
return userAbility.can(action);
|
3612
3849
|
},
|
3613
3850
|
async registerPermissions() {
|
3614
|
-
const displayedContentTypes = getService$
|
3851
|
+
const displayedContentTypes = getService$2("content-types").findDisplayedContentTypes();
|
3615
3852
|
const contentTypesUids = displayedContentTypes.map(fp.prop("uid"));
|
3616
3853
|
const actions = [
|
3617
3854
|
{
|
@@ -3887,7 +4124,7 @@ const getQueryPopulate = async (uid2, query) => {
|
|
3887
4124
|
return populateQuery;
|
3888
4125
|
};
|
3889
4126
|
const buildDeepPopulate = (uid2) => {
|
3890
|
-
return getService$
|
4127
|
+
return getService$2("populate-builder")(uid2).populateDeep(Infinity).countRelations().build();
|
3891
4128
|
};
|
3892
4129
|
const populateBuilder = (uid2) => {
|
3893
4130
|
let getInitialPopulate = async () => {
|
@@ -4072,7 +4309,9 @@ const documentMetadata = ({ strapi: strapi2 }) => ({
|
|
4072
4309
|
*/
|
4073
4310
|
async getAvailableLocales(uid2, version, allVersions, validatableFields = []) {
|
4074
4311
|
const versionsByLocale = fp.groupBy("locale", allVersions);
|
4075
|
-
|
4312
|
+
if (version.locale) {
|
4313
|
+
delete versionsByLocale[version.locale];
|
4314
|
+
}
|
4076
4315
|
const model = strapi2.getModel(uid2);
|
4077
4316
|
const keysToKeep = [...AVAILABLE_LOCALES_FIELDS, ...validatableFields];
|
4078
4317
|
const traversalFunction = async (localeVersion) => strapiUtils.traverseEntity(
|
@@ -4119,8 +4358,7 @@ const documentMetadata = ({ strapi: strapi2 }) => ({
|
|
4119
4358
|
const matchStatus = status === "published" ? v.publishedAt !== null : v.publishedAt === null;
|
4120
4359
|
return matchLocale && matchStatus;
|
4121
4360
|
});
|
4122
|
-
if (!availableStatus)
|
4123
|
-
return availableStatus;
|
4361
|
+
if (!availableStatus) return availableStatus;
|
4124
4362
|
return fp.pick(AVAILABLE_STATUS_FIELDS, availableStatus);
|
4125
4363
|
},
|
4126
4364
|
/**
|
@@ -4130,8 +4368,7 @@ const documentMetadata = ({ strapi: strapi2 }) => ({
|
|
4130
4368
|
* @returns
|
4131
4369
|
*/
|
4132
4370
|
async getManyAvailableStatus(uid2, documents) {
|
4133
|
-
if (!documents.length)
|
4134
|
-
return [];
|
4371
|
+
if (!documents.length) return [];
|
4135
4372
|
const status = documents[0].publishedAt !== null ? "published" : "draft";
|
4136
4373
|
const locale = documents[0]?.locale;
|
4137
4374
|
const otherStatus = status === "published" ? "draft" : "published";
|
@@ -4158,10 +4395,8 @@ const documentMetadata = ({ strapi: strapi2 }) => ({
|
|
4158
4395
|
} else if (otherVersion) {
|
4159
4396
|
draftVersion = otherVersion;
|
4160
4397
|
}
|
4161
|
-
if (!draftVersion)
|
4162
|
-
|
4163
|
-
if (!publishedVersion)
|
4164
|
-
return CONTENT_MANAGER_STATUS.DRAFT;
|
4398
|
+
if (!draftVersion) return CONTENT_MANAGER_STATUS.PUBLISHED;
|
4399
|
+
if (!publishedVersion) return CONTENT_MANAGER_STATUS.DRAFT;
|
4165
4400
|
const isDraftModified = getIsVersionLatestModification(draftVersion, publishedVersion);
|
4166
4401
|
return isDraftModified ? CONTENT_MANAGER_STATUS.MODIFIED : CONTENT_MANAGER_STATUS.PUBLISHED;
|
4167
4402
|
},
|
@@ -4428,7 +4663,8 @@ const services = {
|
|
4428
4663
|
permission,
|
4429
4664
|
"populate-builder": populateBuilder$1,
|
4430
4665
|
uid,
|
4431
|
-
...history.services ? history.services : {}
|
4666
|
+
...history.services ? history.services : {},
|
4667
|
+
...preview.services ? preview.services : {}
|
4432
4668
|
};
|
4433
4669
|
const index = () => {
|
4434
4670
|
return {
|