@strapi/content-manager 0.0.0-experimental.cb311d9fcfbd8e441f790aea232f0a39bdd90e16 → 0.0.0-experimental.cfda358b7f27015e34e739b8742a2962ae2e7aee
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-DL1MHO8i.js → ComponentConfigurationPage-BTR_hQow.js} +5 -6
- package/dist/_chunks/{ComponentConfigurationPage-DL1MHO8i.js.map → ComponentConfigurationPage-BTR_hQow.js.map} +1 -1
- package/dist/_chunks/{ComponentConfigurationPage-D0dyDTwq.mjs → ComponentConfigurationPage-bLQr82ce.mjs} +4 -4
- package/dist/_chunks/{ComponentConfigurationPage-D0dyDTwq.mjs.map → ComponentConfigurationPage-bLQr82ce.mjs.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-13b7S5Cq.mjs → EditConfigurationPage-BhRSnUsL.mjs} +4 -4
- package/dist/_chunks/{EditConfigurationPage-13b7S5Cq.mjs.map → EditConfigurationPage-BhRSnUsL.mjs.map} +1 -1
- package/dist/_chunks/{EditConfigurationPage-CMaOf-A-.js → EditConfigurationPage-z39Wv3E6.js} +5 -6
- package/dist/_chunks/{EditConfigurationPage-CMaOf-A-.js.map → EditConfigurationPage-z39Wv3E6.js.map} +1 -1
- package/dist/_chunks/{EditViewPage-C3tIZ8F5.mjs → EditViewPage-BCjNxNlY.mjs} +63 -12
- package/dist/_chunks/EditViewPage-BCjNxNlY.mjs.map +1 -0
- package/dist/_chunks/{EditViewPage-BSVmMpRd.js → EditViewPage-wujOq90c.js} +63 -13
- package/dist/_chunks/EditViewPage-wujOq90c.js.map +1 -0
- package/dist/_chunks/{Field-DUCVth4C.js → Field-B5QXnctJ.js} +320 -169
- package/dist/_chunks/Field-B5QXnctJ.js.map +1 -0
- package/dist/_chunks/{Field-BvuT8cGL.mjs → Field-Byr3mPTl.mjs} +316 -165
- package/dist/_chunks/Field-Byr3mPTl.mjs.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-BZmDNVr9.mjs → Form-BZgvE8C8.mjs} +37 -18
- package/dist/_chunks/Form-BZgvE8C8.mjs.map +1 -0
- package/dist/_chunks/{Form-Cpl4W1ak.js → Form-D7mexvm3.js} +39 -21
- package/dist/_chunks/Form-D7mexvm3.js.map +1 -0
- package/dist/_chunks/{History-Cq_Hrzuu.mjs → History-CqNgxkqK.mjs} +43 -100
- package/dist/_chunks/History-CqNgxkqK.mjs.map +1 -0
- package/dist/_chunks/{History-D4U2YISB.js → History-DYl2A8Z_.js} +42 -100
- package/dist/_chunks/History-DYl2A8Z_.js.map +1 -0
- package/dist/_chunks/{ListConfigurationPage-Bny6CdWe.js → ListConfigurationPage-BXnu_OoY.js} +19 -9
- package/dist/_chunks/ListConfigurationPage-BXnu_OoY.js.map +1 -0
- package/dist/_chunks/{ListConfigurationPage-W-KQHmBv.mjs → ListConfigurationPage-BbQjzKkQ.mjs} +19 -8
- package/dist/_chunks/ListConfigurationPage-BbQjzKkQ.mjs.map +1 -0
- package/dist/_chunks/{ListViewPage-O8F1pBJo.js → ListViewPage-BtSi8C1l.js} +103 -77
- package/dist/_chunks/ListViewPage-BtSi8C1l.js.map +1 -0
- package/dist/_chunks/{ListViewPage-HBBnJa8K.mjs → ListViewPage-D4ofkbjR.mjs} +99 -72
- package/dist/_chunks/ListViewPage-D4ofkbjR.mjs.map +1 -0
- package/dist/_chunks/{NoContentTypePage-CQWChGPw.js → NoContentTypePage-CitJeOq4.js} +2 -2
- package/dist/_chunks/{NoContentTypePage-CQWChGPw.js.map → NoContentTypePage-CitJeOq4.js.map} +1 -1
- package/dist/_chunks/{NoContentTypePage-B-gIhHWM.mjs → NoContentTypePage-DyUx5mXh.mjs} +2 -2
- package/dist/_chunks/{NoContentTypePage-B-gIhHWM.mjs.map → NoContentTypePage-DyUx5mXh.mjs.map} +1 -1
- package/dist/_chunks/{NoPermissionsPage-XhOPl8wx.mjs → NoPermissionsPage-DhIiyWkk.mjs} +2 -2
- package/dist/_chunks/{NoPermissionsPage-XhOPl8wx.mjs.map → NoPermissionsPage-DhIiyWkk.mjs.map} +1 -1
- package/dist/_chunks/{NoPermissionsPage-CY46zxnM.js → NoPermissionsPage-DzgWz0M-.js} +2 -2
- package/dist/_chunks/{NoPermissionsPage-CY46zxnM.js.map → NoPermissionsPage-DzgWz0M-.js.map} +1 -1
- package/dist/_chunks/Preview-BaYGJ0nb.mjs +293 -0
- package/dist/_chunks/Preview-BaYGJ0nb.mjs.map +1 -0
- package/dist/_chunks/Preview-DfNx8Ke-.js +311 -0
- package/dist/_chunks/Preview-DfNx8Ke-.js.map +1 -0
- package/dist/_chunks/{Relations-vFZ6Wasg.mjs → Relations-DM2yUTST.mjs} +76 -42
- package/dist/_chunks/Relations-DM2yUTST.mjs.map +1 -0
- package/dist/_chunks/{Relations-C4gGfZRv.js → Relations-DuKCaXrv.js} +76 -43
- package/dist/_chunks/Relations-DuKCaXrv.js.map +1 -0
- package/dist/_chunks/{en-uOUIxfcQ.js → en-BK8Xyl5I.js} +28 -15
- package/dist/_chunks/{en-uOUIxfcQ.js.map → en-BK8Xyl5I.js.map} +1 -1
- package/dist/_chunks/{en-BrCTWlZv.mjs → en-Dtk_ot79.mjs} +28 -15
- package/dist/_chunks/{en-BrCTWlZv.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-5EMXLEM_.js → index-BUWEmX8m.js} +1320 -996
- package/dist/_chunks/index-BUWEmX8m.js.map +1 -0
- package/dist/_chunks/{index-Dpxg3ctD.mjs → index-DVAIIsOs.mjs} +1338 -1014
- package/dist/_chunks/index-DVAIIsOs.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-C0INpKap.mjs → layout-Bxsv5mP7.mjs} +9 -8
- package/dist/_chunks/layout-Bxsv5mP7.mjs.map +1 -0
- package/dist/_chunks/{layout-P3eKO1Qy.js → layout-C3fN7Ejz.js} +10 -10
- package/dist/_chunks/layout-C3fN7Ejz.js.map +1 -0
- 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-B1y0K6LE.js → relations-BPZKAoEY.js} +6 -7
- package/dist/_chunks/relations-BPZKAoEY.js.map +1 -0
- package/dist/_chunks/{relations-FBRRBWeO.mjs → relations-o3pPhzY4.mjs} +6 -7
- package/dist/_chunks/relations-o3pPhzY4.mjs.map +1 -0
- package/dist/_chunks/{usePrev-B9w_-eYc.js → useDebounce-CtcjDB3L.js} +14 -1
- package/dist/_chunks/useDebounce-CtcjDB3L.js.map +1 -0
- package/dist/_chunks/useDebounce-DmuSJIF3.mjs +29 -0
- package/dist/_chunks/useDebounce-DmuSJIF3.mjs.map +1 -0
- 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 +2 -1
- package/dist/admin/index.js.map +1 -1
- package/dist/admin/index.mjs +5 -4
- package/dist/admin/src/content-manager.d.ts +3 -2
- package/dist/admin/src/exports.d.ts +1 -1
- package/dist/admin/src/history/services/historyVersion.d.ts +1 -1
- package/dist/admin/src/hooks/useDocument.d.ts +32 -1
- package/dist/admin/src/pages/EditView/EditViewPage.d.ts +9 -1
- package/dist/admin/src/pages/EditView/components/DocumentActions.d.ts +1 -1
- package/dist/admin/src/pages/EditView/components/DocumentStatus.d.ts +2 -2
- package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/Blocks/Code.d.ts +7 -0
- package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/Blocks/utils/prismLanguages.d.ts +49 -0
- package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/utils/constants.d.ts +1 -0
- package/dist/admin/src/pages/EditView/components/FormInputs/Wysiwyg/EditorLayout.d.ts +2 -2
- package/dist/admin/src/pages/EditView/components/FormInputs/Wysiwyg/WysiwygFooter.d.ts +2 -2
- package/dist/admin/src/pages/EditView/components/FormInputs/Wysiwyg/WysiwygStyles.d.ts +4 -48
- package/dist/admin/src/pages/EditView/components/Header.d.ts +11 -11
- 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/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/api.d.ts +1 -1
- package/dist/admin/src/services/components.d.ts +2 -2
- package/dist/admin/src/services/contentTypes.d.ts +3 -3
- package/dist/admin/src/services/documents.d.ts +19 -20
- package/dist/admin/src/services/init.d.ts +1 -1
- package/dist/admin/src/services/relations.d.ts +2 -2
- package/dist/admin/src/services/uid.d.ts +3 -3
- package/dist/admin/src/utils/validation.d.ts +4 -1
- package/dist/server/index.js +482 -219
- package/dist/server/index.js.map +1 -1
- package/dist/server/index.mjs +482 -218
- 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 +3 -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/policies/hasPermissions.d.ts.map +1 -1
- 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/permission-checker.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/collection-types.d.ts +3 -1
- package/dist/shared/contracts/collection-types.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 +17 -15
- package/dist/_chunks/EditViewPage-BSVmMpRd.js.map +0 -1
- package/dist/_chunks/EditViewPage-C3tIZ8F5.mjs.map +0 -1
- package/dist/_chunks/Field-BvuT8cGL.mjs.map +0 -1
- package/dist/_chunks/Field-DUCVth4C.js.map +0 -1
- package/dist/_chunks/Form-BZmDNVr9.mjs.map +0 -1
- package/dist/_chunks/Form-Cpl4W1ak.js.map +0 -1
- package/dist/_chunks/History-Cq_Hrzuu.mjs.map +0 -1
- package/dist/_chunks/History-D4U2YISB.js.map +0 -1
- package/dist/_chunks/ListConfigurationPage-Bny6CdWe.js.map +0 -1
- package/dist/_chunks/ListConfigurationPage-W-KQHmBv.mjs.map +0 -1
- package/dist/_chunks/ListViewPage-HBBnJa8K.mjs.map +0 -1
- package/dist/_chunks/ListViewPage-O8F1pBJo.js.map +0 -1
- package/dist/_chunks/Relations-C4gGfZRv.js.map +0 -1
- package/dist/_chunks/Relations-vFZ6Wasg.mjs.map +0 -1
- package/dist/_chunks/index-5EMXLEM_.js.map +0 -1
- package/dist/_chunks/index-Dpxg3ctD.mjs.map +0 -1
- package/dist/_chunks/layout-C0INpKap.mjs.map +0 -1
- package/dist/_chunks/layout-P3eKO1Qy.js.map +0 -1
- package/dist/_chunks/relations-B1y0K6LE.js.map +0 -1
- package/dist/_chunks/relations-FBRRBWeO.mjs.map +0 -1
- package/dist/_chunks/usePrev-B9w_-eYc.js.map +0 -1
- package/dist/_chunks/usePrev-DH6iah0A.mjs +0 -16
- package/dist/_chunks/usePrev-DH6iah0A.mjs.map +0 -1
- package/strapi-server.js +0 -3
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({
|
@@ -199,10 +197,11 @@ const createServiceUtils = ({ strapi: strapi2 }) => {
|
|
199
197
|
return strapi2.db.query("plugin::upload.file").findOne({ where: { id: versionRelationData.id } });
|
200
198
|
};
|
201
199
|
const localesService = strapi2.plugin("i18n")?.service("locales");
|
200
|
+
const i18nContentTypeService = strapi2.plugin("i18n")?.service("content-types");
|
202
201
|
const getDefaultLocale = async () => localesService ? localesService.getDefaultLocale() : null;
|
202
|
+
const isLocalizedContentType = (model) => i18nContentTypeService ? i18nContentTypeService.isLocalizedContentType(model) : false;
|
203
203
|
const getLocaleDictionary = async () => {
|
204
|
-
if (!localesService)
|
205
|
-
return {};
|
204
|
+
if (!localesService) return {};
|
206
205
|
const locales = await localesService.find() || [];
|
207
206
|
return locales.reduce(
|
208
207
|
(acc, locale) => {
|
@@ -226,6 +225,17 @@ const createServiceUtils = ({ strapi: strapi2 }) => {
|
|
226
225
|
const meta = await documentMetadataService.getMetadata(contentTypeUid, document);
|
227
226
|
return documentMetadataService.getStatus(document, meta.availableStatus);
|
228
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
|
+
};
|
229
239
|
const getDeepPopulate2 = (uid2, useDatabaseSyntax = false) => {
|
230
240
|
const model = strapi2.getModel(uid2);
|
231
241
|
const attributes = Object.entries(model.attributes);
|
@@ -249,13 +259,19 @@ const createServiceUtils = ({ strapi: strapi2 }) => {
|
|
249
259
|
}
|
250
260
|
case "component": {
|
251
261
|
const populate = getDeepPopulate2(attribute.component);
|
252
|
-
acc[attributeName] = {
|
262
|
+
acc[attributeName] = {
|
263
|
+
populate,
|
264
|
+
[fieldSelector]: getComponentFields(attribute.component)
|
265
|
+
};
|
253
266
|
break;
|
254
267
|
}
|
255
268
|
case "dynamiczone": {
|
256
269
|
const populatedComponents = (attribute.components || []).reduce(
|
257
270
|
(acc2, componentUID) => {
|
258
|
-
acc2[componentUID] = {
|
271
|
+
acc2[componentUID] = {
|
272
|
+
populate: getDeepPopulate2(componentUID),
|
273
|
+
[fieldSelector]: getComponentFields(componentUID)
|
274
|
+
};
|
259
275
|
return acc2;
|
260
276
|
},
|
261
277
|
{}
|
@@ -317,6 +333,7 @@ const createServiceUtils = ({ strapi: strapi2 }) => {
|
|
317
333
|
getRelationRestoreValue,
|
318
334
|
getMediaRestoreValue,
|
319
335
|
getDefaultLocale,
|
336
|
+
isLocalizedContentType,
|
320
337
|
getLocaleDictionary,
|
321
338
|
getRetentionDays,
|
322
339
|
getVersionStatus,
|
@@ -339,7 +356,13 @@ const createHistoryService = ({ strapi: strapi2 }) => {
|
|
339
356
|
});
|
340
357
|
},
|
341
358
|
async findVersionsPage(params) {
|
342
|
-
const
|
359
|
+
const model = strapi2.getModel(params.query.contentType);
|
360
|
+
const isLocalizedContentType = serviceUtils.isLocalizedContentType(model);
|
361
|
+
const defaultLocale = await serviceUtils.getDefaultLocale();
|
362
|
+
let locale = null;
|
363
|
+
if (isLocalizedContentType) {
|
364
|
+
locale = params.query.locale || defaultLocale;
|
365
|
+
}
|
343
366
|
const [{ results, pagination }, localeDictionary] = await Promise.all([
|
344
367
|
query.findPage({
|
345
368
|
...params.query,
|
@@ -361,7 +384,7 @@ const createHistoryService = ({ strapi: strapi2 }) => {
|
|
361
384
|
const attributeValue = entry.data[attributeKey];
|
362
385
|
const attributeValues = Array.isArray(attributeValue) ? attributeValue : [attributeValue];
|
363
386
|
if (attributeSchema.type === "media") {
|
364
|
-
const permissionChecker2 = getService$
|
387
|
+
const permissionChecker2 = getService$2("permission-checker").create({
|
365
388
|
userAbility: params.state.userAbility,
|
366
389
|
model: "plugin::upload.file"
|
367
390
|
});
|
@@ -384,7 +407,12 @@ const createHistoryService = ({ strapi: strapi2 }) => {
|
|
384
407
|
if (userToPopulate == null) {
|
385
408
|
return null;
|
386
409
|
}
|
387
|
-
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
|
+
});
|
388
416
|
})
|
389
417
|
);
|
390
418
|
return {
|
@@ -397,7 +425,7 @@ const createHistoryService = ({ strapi: strapi2 }) => {
|
|
397
425
|
[attributeKey]: adminUsers
|
398
426
|
};
|
399
427
|
}
|
400
|
-
const permissionChecker2 = getService$
|
428
|
+
const permissionChecker2 = getService$2("permission-checker").create({
|
401
429
|
userAbility: params.state.userAbility,
|
402
430
|
model: attributeSchema.target
|
403
431
|
});
|
@@ -555,11 +583,13 @@ const createLifecyclesService = ({ strapi: strapi2 }) => {
|
|
555
583
|
}
|
556
584
|
const uid2 = context.contentType.uid;
|
557
585
|
const schemas = getSchemas(uid2);
|
586
|
+
const model = strapi2.getModel(uid2);
|
587
|
+
const isLocalizedContentType = serviceUtils.isLocalizedContentType(model);
|
558
588
|
const localeEntries = await strapi2.db.query(uid2).findMany({
|
559
589
|
where: {
|
560
590
|
documentId,
|
561
|
-
locale: { $in: locales },
|
562
|
-
publishedAt: null
|
591
|
+
...isLocalizedContentType ? { locale: { $in: locales } } : {},
|
592
|
+
...strapiUtils.contentTypes.hasDraftAndPublish(strapi2.contentTypes[uid2]) ? { publishedAt: null } : {}
|
563
593
|
},
|
564
594
|
populate: serviceUtils.getDeepPopulate(
|
565
595
|
uid2,
|
@@ -571,7 +601,7 @@ const createLifecyclesService = ({ strapi: strapi2 }) => {
|
|
571
601
|
onCommit(async () => {
|
572
602
|
for (const entry of localeEntries) {
|
573
603
|
const status = await serviceUtils.getVersionStatus(uid2, entry);
|
574
|
-
await getService(strapi2, "history").createVersion({
|
604
|
+
await getService$1(strapi2, "history").createVersion({
|
575
605
|
contentType: uid2,
|
576
606
|
data: fp.omit(FIELDS_TO_IGNORE, entry),
|
577
607
|
relatedDocumentId: documentId,
|
@@ -584,15 +614,19 @@ const createLifecyclesService = ({ strapi: strapi2 }) => {
|
|
584
614
|
});
|
585
615
|
return result;
|
586
616
|
});
|
587
|
-
state.deleteExpiredJob = nodeSchedule.scheduleJob("0 0 * * *", () => {
|
617
|
+
state.deleteExpiredJob = nodeSchedule.scheduleJob("historyDaily", "0 0 * * *", () => {
|
588
618
|
const retentionDaysInMilliseconds = serviceUtils.getRetentionDays() * 24 * 60 * 60 * 1e3;
|
589
619
|
const expirationDate = new Date(Date.now() - retentionDaysInMilliseconds);
|
590
620
|
strapi2.db.query(HISTORY_VERSION_UID).deleteMany({
|
591
621
|
where: {
|
592
622
|
created_at: {
|
593
|
-
$lt: expirationDate
|
623
|
+
$lt: expirationDate
|
594
624
|
}
|
595
625
|
}
|
626
|
+
}).catch((error) => {
|
627
|
+
if (error instanceof Error) {
|
628
|
+
strapi2.log.error("Error deleting expired history versions", error.message);
|
629
|
+
}
|
596
630
|
});
|
597
631
|
});
|
598
632
|
state.isInitialized = true;
|
@@ -604,17 +638,17 @@ const createLifecyclesService = ({ strapi: strapi2 }) => {
|
|
604
638
|
}
|
605
639
|
};
|
606
640
|
};
|
607
|
-
const services$
|
641
|
+
const services$2 = {
|
608
642
|
history: createHistoryService,
|
609
643
|
lifecycles: createLifecyclesService
|
610
644
|
};
|
611
|
-
const info = { pluginName: "content-manager", type: "admin" };
|
645
|
+
const info$1 = { pluginName: "content-manager", type: "admin" };
|
612
646
|
const historyVersionRouter = {
|
613
647
|
type: "admin",
|
614
648
|
routes: [
|
615
649
|
{
|
616
650
|
method: "GET",
|
617
|
-
info,
|
651
|
+
info: info$1,
|
618
652
|
path: "/history-versions",
|
619
653
|
handler: "history-version.findMany",
|
620
654
|
config: {
|
@@ -623,7 +657,7 @@ const historyVersionRouter = {
|
|
623
657
|
},
|
624
658
|
{
|
625
659
|
method: "PUT",
|
626
|
-
info,
|
660
|
+
info: info$1,
|
627
661
|
path: "/history-versions/:versionId/restore",
|
628
662
|
handler: "history-version.restoreVersion",
|
629
663
|
config: {
|
@@ -632,7 +666,7 @@ const historyVersionRouter = {
|
|
632
666
|
}
|
633
667
|
]
|
634
668
|
};
|
635
|
-
const routes$
|
669
|
+
const routes$2 = {
|
636
670
|
"history-version": historyVersionRouter
|
637
671
|
};
|
638
672
|
const historyVersion = {
|
@@ -679,21 +713,21 @@ const historyVersion = {
|
|
679
713
|
}
|
680
714
|
}
|
681
715
|
};
|
682
|
-
const getFeature = () => {
|
716
|
+
const getFeature$1 = () => {
|
683
717
|
if (strapi.ee.features.isEnabled("cms-content-history")) {
|
684
718
|
return {
|
685
719
|
register({ strapi: strapi2 }) {
|
686
720
|
strapi2.get("models").add(historyVersion);
|
687
721
|
},
|
688
722
|
bootstrap({ strapi: strapi2 }) {
|
689
|
-
getService(strapi2, "lifecycles").bootstrap();
|
723
|
+
getService$1(strapi2, "lifecycles").bootstrap();
|
690
724
|
},
|
691
725
|
destroy({ strapi: strapi2 }) {
|
692
|
-
getService(strapi2, "lifecycles").destroy();
|
726
|
+
getService$1(strapi2, "lifecycles").destroy();
|
693
727
|
},
|
694
|
-
controllers: controllers$
|
695
|
-
services: services$
|
696
|
-
routes: routes$
|
728
|
+
controllers: controllers$2,
|
729
|
+
services: services$2,
|
730
|
+
routes: routes$2
|
697
731
|
};
|
698
732
|
}
|
699
733
|
return {
|
@@ -702,9 +736,201 @@ const getFeature = () => {
|
|
702
736
|
}
|
703
737
|
};
|
704
738
|
};
|
705
|
-
const history = getFeature();
|
739
|
+
const history = getFeature$1();
|
740
|
+
const info = { pluginName: "content-manager", type: "admin" };
|
741
|
+
const previewRouter = {
|
742
|
+
type: "admin",
|
743
|
+
routes: [
|
744
|
+
{
|
745
|
+
method: "GET",
|
746
|
+
info,
|
747
|
+
path: "/preview/url/:contentType",
|
748
|
+
handler: "preview.getPreviewUrl",
|
749
|
+
config: {
|
750
|
+
policies: ["admin::isAuthenticatedAdmin"]
|
751
|
+
}
|
752
|
+
}
|
753
|
+
]
|
754
|
+
};
|
755
|
+
const routes$1 = {
|
756
|
+
preview: previewRouter
|
757
|
+
};
|
758
|
+
function getService(strapi2, name) {
|
759
|
+
return strapi2.service(`plugin::content-manager.${name}`);
|
760
|
+
}
|
761
|
+
const getPreviewUrlSchema = yup__namespace.object().shape({
|
762
|
+
// Will be undefined for single types
|
763
|
+
documentId: yup__namespace.string(),
|
764
|
+
locale: yup__namespace.string().nullable(),
|
765
|
+
status: yup__namespace.string()
|
766
|
+
}).required();
|
767
|
+
const validatePreviewUrl = async (strapi2, uid2, params) => {
|
768
|
+
await strapiUtils.validateYupSchema(getPreviewUrlSchema)(params);
|
769
|
+
const newParams = fp.pick(["documentId", "locale", "status"], params);
|
770
|
+
const model = strapi2.getModel(uid2);
|
771
|
+
if (!model || model.modelType !== "contentType") {
|
772
|
+
throw new strapiUtils.errors.ValidationError("Invalid content type");
|
773
|
+
}
|
774
|
+
const isSingleType = model?.kind === "singleType";
|
775
|
+
if (!isSingleType && !params.documentId) {
|
776
|
+
throw new strapiUtils.errors.ValidationError("documentId is required for Collection Types");
|
777
|
+
}
|
778
|
+
if (isSingleType) {
|
779
|
+
const doc = await strapi2.documents(uid2).findFirst();
|
780
|
+
if (!doc) {
|
781
|
+
throw new strapiUtils.errors.NotFoundError("Document not found");
|
782
|
+
}
|
783
|
+
newParams.documentId = doc?.documentId;
|
784
|
+
}
|
785
|
+
if (!newParams.status) {
|
786
|
+
const isDPEnabled = model?.options?.draftAndPublish;
|
787
|
+
newParams.status = isDPEnabled ? "draft" : "published";
|
788
|
+
}
|
789
|
+
return newParams;
|
790
|
+
};
|
791
|
+
const createPreviewController = () => {
|
792
|
+
return {
|
793
|
+
/**
|
794
|
+
* Transforms an entry into a preview URL, so that it can be previewed
|
795
|
+
* in the Content Manager.
|
796
|
+
*/
|
797
|
+
async getPreviewUrl(ctx) {
|
798
|
+
const uid2 = ctx.params.contentType;
|
799
|
+
const query = ctx.request.query;
|
800
|
+
const params = await validatePreviewUrl(strapi, uid2, query);
|
801
|
+
const previewService = getService(strapi, "preview");
|
802
|
+
const url = await previewService.getPreviewUrl(uid2, params);
|
803
|
+
if (!url) {
|
804
|
+
ctx.status = 204;
|
805
|
+
}
|
806
|
+
return {
|
807
|
+
data: { url }
|
808
|
+
};
|
809
|
+
}
|
810
|
+
};
|
811
|
+
};
|
812
|
+
const controllers$1 = {
|
813
|
+
preview: createPreviewController
|
814
|
+
/**
|
815
|
+
* Casting is needed because the types aren't aware that Strapi supports
|
816
|
+
* passing a controller factory as the value, instead of a controller object directly
|
817
|
+
*/
|
818
|
+
};
|
819
|
+
const createPreviewService = ({ strapi: strapi2 }) => {
|
820
|
+
const config = getService(strapi2, "preview-config");
|
821
|
+
return {
|
822
|
+
async getPreviewUrl(uid2, params) {
|
823
|
+
const handler = config.getPreviewHandler();
|
824
|
+
try {
|
825
|
+
return handler(uid2, params);
|
826
|
+
} catch (error) {
|
827
|
+
strapi2.log.error(`Failed to get preview URL: ${error}`);
|
828
|
+
throw new strapiUtils.errors.ApplicationError("Failed to get preview URL");
|
829
|
+
}
|
830
|
+
return;
|
831
|
+
}
|
832
|
+
};
|
833
|
+
};
|
834
|
+
const extendMiddlewareConfiguration = (middleware = { name: "", config: {} }) => {
|
835
|
+
const middlewares = strapi.config.get("middlewares");
|
836
|
+
const configuredMiddlewares = middlewares.map((currentMiddleware) => {
|
837
|
+
if (currentMiddleware === middleware.name) {
|
838
|
+
return middleware;
|
839
|
+
}
|
840
|
+
if (currentMiddleware.name === middleware.name) {
|
841
|
+
return fp.mergeWith(
|
842
|
+
(objValue, srcValue) => {
|
843
|
+
if (Array.isArray(objValue)) {
|
844
|
+
return objValue.concat(srcValue);
|
845
|
+
}
|
846
|
+
return void 0;
|
847
|
+
},
|
848
|
+
currentMiddleware,
|
849
|
+
middleware
|
850
|
+
);
|
851
|
+
}
|
852
|
+
return currentMiddleware;
|
853
|
+
});
|
854
|
+
strapi.config.set("middlewares", configuredMiddlewares);
|
855
|
+
};
|
856
|
+
const createPreviewConfigService = ({ strapi: strapi2 }) => {
|
857
|
+
return {
|
858
|
+
register() {
|
859
|
+
if (!this.isEnabled()) {
|
860
|
+
return;
|
861
|
+
}
|
862
|
+
const config = strapi2.config.get("admin.preview");
|
863
|
+
if (config.config?.allowedOrigins) {
|
864
|
+
extendMiddlewareConfiguration({
|
865
|
+
name: "strapi::security",
|
866
|
+
config: {
|
867
|
+
contentSecurityPolicy: {
|
868
|
+
directives: {
|
869
|
+
"frame-src": config.config.allowedOrigins
|
870
|
+
}
|
871
|
+
}
|
872
|
+
}
|
873
|
+
});
|
874
|
+
}
|
875
|
+
},
|
876
|
+
isEnabled() {
|
877
|
+
const config = strapi2.config.get("admin.preview");
|
878
|
+
if (!config) {
|
879
|
+
return false;
|
880
|
+
}
|
881
|
+
return config?.enabled ?? true;
|
882
|
+
},
|
883
|
+
/**
|
884
|
+
* Validate if the configuration is valid
|
885
|
+
*/
|
886
|
+
validate() {
|
887
|
+
if (!this.isEnabled()) {
|
888
|
+
return;
|
889
|
+
}
|
890
|
+
const handler = this.getPreviewHandler();
|
891
|
+
if (typeof handler !== "function") {
|
892
|
+
throw new strapiUtils.errors.ValidationError(
|
893
|
+
"Preview configuration is invalid. Handler must be a function"
|
894
|
+
);
|
895
|
+
}
|
896
|
+
},
|
897
|
+
/**
|
898
|
+
* Utility to get the preview handler from the configuration
|
899
|
+
*/
|
900
|
+
getPreviewHandler() {
|
901
|
+
const config = strapi2.config.get("admin.preview");
|
902
|
+
const emptyHandler = () => {
|
903
|
+
return void 0;
|
904
|
+
};
|
905
|
+
if (!this.isEnabled()) {
|
906
|
+
return emptyHandler;
|
907
|
+
}
|
908
|
+
return config?.config?.handler || emptyHandler;
|
909
|
+
}
|
910
|
+
};
|
911
|
+
};
|
912
|
+
const services$1 = {
|
913
|
+
preview: createPreviewService,
|
914
|
+
"preview-config": createPreviewConfigService
|
915
|
+
};
|
916
|
+
const getFeature = () => {
|
917
|
+
return {
|
918
|
+
register() {
|
919
|
+
const config = getService(strapi, "preview-config");
|
920
|
+
config.validate();
|
921
|
+
config.register();
|
922
|
+
},
|
923
|
+
bootstrap() {
|
924
|
+
},
|
925
|
+
routes: routes$1,
|
926
|
+
controllers: controllers$1,
|
927
|
+
services: services$1
|
928
|
+
};
|
929
|
+
};
|
930
|
+
const preview = getFeature();
|
706
931
|
const register = async ({ strapi: strapi2 }) => {
|
707
932
|
await history.register?.({ strapi: strapi2 });
|
933
|
+
await preview.register?.({ strapi: strapi2 });
|
708
934
|
};
|
709
935
|
const ALLOWED_WEBHOOK_EVENTS = {
|
710
936
|
ENTRY_PUBLISH: "entry.publish",
|
@@ -714,11 +940,12 @@ const bootstrap = async () => {
|
|
714
940
|
Object.entries(ALLOWED_WEBHOOK_EVENTS).forEach(([key, value]) => {
|
715
941
|
strapi.get("webhookStore").addAllowedEvent(key, value);
|
716
942
|
});
|
717
|
-
getService$
|
718
|
-
await getService$
|
719
|
-
await getService$
|
720
|
-
await getService$
|
943
|
+
getService$2("field-sizes").setCustomFieldInputSizes();
|
944
|
+
await getService$2("components").syncConfigurations();
|
945
|
+
await getService$2("content-types").syncConfigurations();
|
946
|
+
await getService$2("permission").registerPermissions();
|
721
947
|
await history.bootstrap?.({ strapi });
|
948
|
+
await preview.bootstrap?.({ strapi });
|
722
949
|
};
|
723
950
|
const destroy = async ({ strapi: strapi2 }) => {
|
724
951
|
await history.destroy?.({ strapi: strapi2 });
|
@@ -1208,7 +1435,8 @@ const admin = {
|
|
1208
1435
|
};
|
1209
1436
|
const routes = {
|
1210
1437
|
admin,
|
1211
|
-
...history.routes ? history.routes : {}
|
1438
|
+
...history.routes ? history.routes : {},
|
1439
|
+
...preview.routes ? preview.routes : {}
|
1212
1440
|
};
|
1213
1441
|
const hasPermissionsSchema = strapiUtils.yup.object({
|
1214
1442
|
actions: strapiUtils.yup.array().of(strapiUtils.yup.string()),
|
@@ -1219,6 +1447,11 @@ const { createPolicy } = strapiUtils.policy;
|
|
1219
1447
|
const hasPermissions = createPolicy({
|
1220
1448
|
name: "plugin::content-manager.hasPermissions",
|
1221
1449
|
validator: validateHasPermissionsInput,
|
1450
|
+
/**
|
1451
|
+
* NOTE: Action aliases are currently not checked at this level (policy).
|
1452
|
+
* This is currently the intended behavior to avoid changing the behavior of API related permissions.
|
1453
|
+
* If you want to add support for it, please create a dedicated RFC with a list of potential side effect this could have.
|
1454
|
+
*/
|
1222
1455
|
handler(ctx, config = {}) {
|
1223
1456
|
const { actions = [], hasAtLeastOne = false } = config;
|
1224
1457
|
const { userAbility } = ctx.state;
|
@@ -1266,8 +1499,7 @@ const isSortable = (schema, name) => {
|
|
1266
1499
|
if (!___default.default.has(schema.attributes, name)) {
|
1267
1500
|
return false;
|
1268
1501
|
}
|
1269
|
-
if (schema.modelType === "component" && name === "id")
|
1270
|
-
return false;
|
1502
|
+
if (schema.modelType === "component" && name === "id") return false;
|
1271
1503
|
const attribute = schema.attributes[name];
|
1272
1504
|
if (NON_SORTABLES.includes(attribute.type)) {
|
1273
1505
|
return false;
|
@@ -1412,8 +1644,7 @@ const createDefaultSettings = async (schema) => {
|
|
1412
1644
|
};
|
1413
1645
|
};
|
1414
1646
|
const syncSettings = async (configuration, schema) => {
|
1415
|
-
if (fp.isEmpty(configuration.settings))
|
1416
|
-
return createDefaultSettings(schema);
|
1647
|
+
if (fp.isEmpty(configuration.settings)) return createDefaultSettings(schema);
|
1417
1648
|
const defaultField = getDefaultMainField(schema);
|
1418
1649
|
const { mainField = defaultField, defaultSortBy = defaultField } = configuration.settings || {};
|
1419
1650
|
return {
|
@@ -1460,7 +1691,7 @@ const createMetadasSchema = (schema) => {
|
|
1460
1691
|
if (!value) {
|
1461
1692
|
return strapiUtils.yup.string();
|
1462
1693
|
}
|
1463
|
-
const targetSchema = getService$
|
1694
|
+
const targetSchema = getService$2("content-types").findContentType(
|
1464
1695
|
schema.attributes[key].targetModel
|
1465
1696
|
);
|
1466
1697
|
if (!targetSchema) {
|
@@ -1589,8 +1820,7 @@ const excludeNotCreatableFields = (uid2, permissionChecker2) => (body, path = []
|
|
1589
1820
|
}
|
1590
1821
|
switch (attribute.type) {
|
1591
1822
|
case "relation": {
|
1592
|
-
if (canCreate(attributePath))
|
1593
|
-
return body2;
|
1823
|
+
if (canCreate(attributePath)) return body2;
|
1594
1824
|
return fp.set(attributePath, { set: [] }, body2);
|
1595
1825
|
}
|
1596
1826
|
case "component": {
|
@@ -1600,8 +1830,7 @@ const excludeNotCreatableFields = (uid2, permissionChecker2) => (body, path = []
|
|
1600
1830
|
]);
|
1601
1831
|
}
|
1602
1832
|
default: {
|
1603
|
-
if (canCreate(attributePath))
|
1604
|
-
return body2;
|
1833
|
+
if (canCreate(attributePath)) return body2;
|
1605
1834
|
return fp.set(attributePath, null, body2);
|
1606
1835
|
}
|
1607
1836
|
}
|
@@ -1629,7 +1858,7 @@ const getDocumentLocaleAndStatus = async (request, model, opts = { allowMultiple
|
|
1629
1858
|
}
|
1630
1859
|
};
|
1631
1860
|
const formatDocumentWithMetadata = async (permissionChecker2, uid2, document, opts = {}) => {
|
1632
|
-
const documentMetadata2 = getService$
|
1861
|
+
const documentMetadata2 = getService$2("document-metadata");
|
1633
1862
|
const serviceOutput = await documentMetadata2.formatDocumentWithMetadata(uid2, document, opts);
|
1634
1863
|
let {
|
1635
1864
|
meta: { availableLocales, availableStatus }
|
@@ -1655,8 +1884,8 @@ const createDocument = async (ctx, opts) => {
|
|
1655
1884
|
const { userAbility, user } = ctx.state;
|
1656
1885
|
const { model } = ctx.params;
|
1657
1886
|
const { body } = ctx.request;
|
1658
|
-
const documentManager2 = getService$
|
1659
|
-
const permissionChecker2 = getService$
|
1887
|
+
const documentManager2 = getService$2("document-manager");
|
1888
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
1660
1889
|
if (permissionChecker2.cannot.create()) {
|
1661
1890
|
throw new strapiUtils.errors.ForbiddenError();
|
1662
1891
|
}
|
@@ -1676,13 +1905,13 @@ const updateDocument = async (ctx, opts) => {
|
|
1676
1905
|
const { userAbility, user } = ctx.state;
|
1677
1906
|
const { id, model } = ctx.params;
|
1678
1907
|
const { body } = ctx.request;
|
1679
|
-
const documentManager2 = getService$
|
1680
|
-
const permissionChecker2 = getService$
|
1908
|
+
const documentManager2 = getService$2("document-manager");
|
1909
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
1681
1910
|
if (permissionChecker2.cannot.update()) {
|
1682
1911
|
throw new strapiUtils.errors.ForbiddenError();
|
1683
1912
|
}
|
1684
1913
|
const permissionQuery = await permissionChecker2.sanitizedQuery.update(ctx.query);
|
1685
|
-
const populate = await getService$
|
1914
|
+
const populate = await getService$2("populate-builder")(model).populateFromQuery(permissionQuery).build();
|
1686
1915
|
const { locale } = await getDocumentLocaleAndStatus(body, model);
|
1687
1916
|
const [documentVersion, documentExists] = await Promise.all([
|
1688
1917
|
documentManager2.findOne(id, model, { populate, locale, status: "draft" }),
|
@@ -1699,7 +1928,7 @@ const updateDocument = async (ctx, opts) => {
|
|
1699
1928
|
throw new strapiUtils.errors.ForbiddenError();
|
1700
1929
|
}
|
1701
1930
|
const pickPermittedFields = documentVersion ? permissionChecker2.sanitizeUpdateInput(documentVersion) : permissionChecker2.sanitizeCreateInput;
|
1702
|
-
const setCreator = strapiUtils.setCreatorFields({ user, isEdition: true });
|
1931
|
+
const setCreator = documentVersion ? strapiUtils.setCreatorFields({ user, isEdition: true }) : strapiUtils.setCreatorFields({ user });
|
1703
1932
|
const sanitizeFn = strapiUtils.async.pipe(pickPermittedFields, setCreator);
|
1704
1933
|
const sanitizedBody = await sanitizeFn(body);
|
1705
1934
|
return documentManager2.update(documentVersion?.documentId || id, model, {
|
@@ -1713,14 +1942,14 @@ const collectionTypes = {
|
|
1713
1942
|
const { userAbility } = ctx.state;
|
1714
1943
|
const { model } = ctx.params;
|
1715
1944
|
const { query } = ctx.request;
|
1716
|
-
const documentMetadata2 = getService$
|
1717
|
-
const documentManager2 = getService$
|
1718
|
-
const permissionChecker2 = getService$
|
1945
|
+
const documentMetadata2 = getService$2("document-metadata");
|
1946
|
+
const documentManager2 = getService$2("document-manager");
|
1947
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
1719
1948
|
if (permissionChecker2.cannot.read()) {
|
1720
1949
|
return ctx.forbidden();
|
1721
1950
|
}
|
1722
1951
|
const permissionQuery = await permissionChecker2.sanitizedQuery.read(query);
|
1723
|
-
const populate = await getService$
|
1952
|
+
const populate = await getService$2("populate-builder")(model).populateFromQuery(permissionQuery).populateDeep(1).countRelations({ toOne: false, toMany: true }).build();
|
1724
1953
|
const { locale, status } = await getDocumentLocaleAndStatus(query, model);
|
1725
1954
|
const { results: documents, pagination } = await documentManager2.findPage(
|
1726
1955
|
{ ...permissionQuery, populate, locale, status },
|
@@ -1749,13 +1978,13 @@ const collectionTypes = {
|
|
1749
1978
|
async findOne(ctx) {
|
1750
1979
|
const { userAbility } = ctx.state;
|
1751
1980
|
const { model, id } = ctx.params;
|
1752
|
-
const documentManager2 = getService$
|
1753
|
-
const permissionChecker2 = getService$
|
1981
|
+
const documentManager2 = getService$2("document-manager");
|
1982
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
1754
1983
|
if (permissionChecker2.cannot.read()) {
|
1755
1984
|
return ctx.forbidden();
|
1756
1985
|
}
|
1757
1986
|
const permissionQuery = await permissionChecker2.sanitizedQuery.read(ctx.query);
|
1758
|
-
const populate = await getService$
|
1987
|
+
const populate = await getService$2("populate-builder")(model).populateFromQuery(permissionQuery).populateDeep(Infinity).countRelations().build();
|
1759
1988
|
const { locale, status } = await getDocumentLocaleAndStatus(ctx.query, model);
|
1760
1989
|
const version = await documentManager2.findOne(id, model, {
|
1761
1990
|
populate,
|
@@ -1771,7 +2000,7 @@ const collectionTypes = {
|
|
1771
2000
|
permissionChecker2,
|
1772
2001
|
model,
|
1773
2002
|
// @ts-expect-error TODO: fix
|
1774
|
-
{ id, locale, publishedAt: null },
|
2003
|
+
{ documentId: id, locale, publishedAt: null },
|
1775
2004
|
{ availableLocales: true, availableStatus: false }
|
1776
2005
|
);
|
1777
2006
|
ctx.body = { data: {}, meta };
|
@@ -1786,7 +2015,7 @@ const collectionTypes = {
|
|
1786
2015
|
async create(ctx) {
|
1787
2016
|
const { userAbility } = ctx.state;
|
1788
2017
|
const { model } = ctx.params;
|
1789
|
-
const permissionChecker2 = getService$
|
2018
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
1790
2019
|
const [totalEntries, document] = await Promise.all([
|
1791
2020
|
strapi.db.query(model).count(),
|
1792
2021
|
createDocument(ctx)
|
@@ -1807,7 +2036,7 @@ const collectionTypes = {
|
|
1807
2036
|
async update(ctx) {
|
1808
2037
|
const { userAbility } = ctx.state;
|
1809
2038
|
const { model } = ctx.params;
|
1810
|
-
const permissionChecker2 = getService$
|
2039
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
1811
2040
|
const updatedVersion = await updateDocument(ctx);
|
1812
2041
|
const sanitizedVersion = await permissionChecker2.sanitizeOutput(updatedVersion);
|
1813
2042
|
ctx.body = await formatDocumentWithMetadata(permissionChecker2, model, sanitizedVersion);
|
@@ -1816,13 +2045,13 @@ const collectionTypes = {
|
|
1816
2045
|
const { userAbility, user } = ctx.state;
|
1817
2046
|
const { model, sourceId: id } = ctx.params;
|
1818
2047
|
const { body } = ctx.request;
|
1819
|
-
const documentManager2 = getService$
|
1820
|
-
const permissionChecker2 = getService$
|
2048
|
+
const documentManager2 = getService$2("document-manager");
|
2049
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
1821
2050
|
if (permissionChecker2.cannot.create()) {
|
1822
2051
|
return ctx.forbidden();
|
1823
2052
|
}
|
1824
2053
|
const permissionQuery = await permissionChecker2.sanitizedQuery.create(ctx.query);
|
1825
|
-
const populate = await getService$
|
2054
|
+
const populate = await getService$2("populate-builder")(model).populateFromQuery(permissionQuery).build();
|
1826
2055
|
const { locale } = await getDocumentLocaleAndStatus(body, model);
|
1827
2056
|
const document = await documentManager2.findOne(id, model, {
|
1828
2057
|
populate,
|
@@ -1861,13 +2090,13 @@ const collectionTypes = {
|
|
1861
2090
|
async delete(ctx) {
|
1862
2091
|
const { userAbility } = ctx.state;
|
1863
2092
|
const { id, model } = ctx.params;
|
1864
|
-
const documentManager2 = getService$
|
1865
|
-
const permissionChecker2 = getService$
|
2093
|
+
const documentManager2 = getService$2("document-manager");
|
2094
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
1866
2095
|
if (permissionChecker2.cannot.delete()) {
|
1867
2096
|
return ctx.forbidden();
|
1868
2097
|
}
|
1869
2098
|
const permissionQuery = await permissionChecker2.sanitizedQuery.delete(ctx.query);
|
1870
|
-
const populate = await getService$
|
2099
|
+
const populate = await getService$2("populate-builder")(model).populateFromQuery(permissionQuery).build();
|
1871
2100
|
const { locale } = await getDocumentLocaleAndStatus(ctx.query, model);
|
1872
2101
|
const documentLocales = await documentManager2.findLocales(id, model, { populate, locale });
|
1873
2102
|
if (documentLocales.length === 0) {
|
@@ -1889,14 +2118,14 @@ const collectionTypes = {
|
|
1889
2118
|
const { userAbility } = ctx.state;
|
1890
2119
|
const { id, model } = ctx.params;
|
1891
2120
|
const { body } = ctx.request;
|
1892
|
-
const documentManager2 = getService$
|
1893
|
-
const permissionChecker2 = getService$
|
2121
|
+
const documentManager2 = getService$2("document-manager");
|
2122
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
1894
2123
|
if (permissionChecker2.cannot.publish()) {
|
1895
2124
|
return ctx.forbidden();
|
1896
2125
|
}
|
1897
2126
|
const publishedDocument = await strapi.db.transaction(async () => {
|
1898
2127
|
const permissionQuery = await permissionChecker2.sanitizedQuery.publish(ctx.query);
|
1899
|
-
const populate = await getService$
|
2128
|
+
const populate = await getService$2("populate-builder")(model).populateFromQuery(permissionQuery).populateDeep(Infinity).countRelations().build();
|
1900
2129
|
let document;
|
1901
2130
|
const { locale } = await getDocumentLocaleAndStatus(body, model);
|
1902
2131
|
const isCreate = fp.isNil(id);
|
@@ -1908,11 +2137,17 @@ const collectionTypes = {
|
|
1908
2137
|
}
|
1909
2138
|
const isUpdate = !isCreate;
|
1910
2139
|
if (isUpdate) {
|
1911
|
-
|
1912
|
-
if (!
|
2140
|
+
const documentExists = documentManager2.exists(model, id);
|
2141
|
+
if (!documentExists) {
|
1913
2142
|
throw new strapiUtils.errors.NotFoundError("Document not found");
|
1914
2143
|
}
|
1915
|
-
|
2144
|
+
document = await documentManager2.findOne(id, model, { populate, locale });
|
2145
|
+
if (!document) {
|
2146
|
+
if (permissionChecker2.cannot.create({ locale }) || permissionChecker2.cannot.publish({ locale })) {
|
2147
|
+
throw new strapiUtils.errors.ForbiddenError();
|
2148
|
+
}
|
2149
|
+
document = await updateDocument(ctx);
|
2150
|
+
} else if (permissionChecker2.can.update(document)) {
|
1916
2151
|
await updateDocument(ctx);
|
1917
2152
|
}
|
1918
2153
|
}
|
@@ -1938,13 +2173,13 @@ const collectionTypes = {
|
|
1938
2173
|
const { body } = ctx.request;
|
1939
2174
|
const { documentIds } = body;
|
1940
2175
|
await validateBulkActionInput(body);
|
1941
|
-
const documentManager2 = getService$
|
1942
|
-
const permissionChecker2 = getService$
|
2176
|
+
const documentManager2 = getService$2("document-manager");
|
2177
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
1943
2178
|
if (permissionChecker2.cannot.publish()) {
|
1944
2179
|
return ctx.forbidden();
|
1945
2180
|
}
|
1946
2181
|
const permissionQuery = await permissionChecker2.sanitizedQuery.publish(ctx.query);
|
1947
|
-
const populate = await getService$
|
2182
|
+
const populate = await getService$2("populate-builder")(model).populateFromQuery(permissionQuery).populateDeep(Infinity).countRelations().build();
|
1948
2183
|
const { locale } = await getDocumentLocaleAndStatus(body, model, {
|
1949
2184
|
allowMultipleLocales: true
|
1950
2185
|
});
|
@@ -1969,12 +2204,14 @@ const collectionTypes = {
|
|
1969
2204
|
const { body } = ctx.request;
|
1970
2205
|
const { documentIds } = body;
|
1971
2206
|
await validateBulkActionInput(body);
|
1972
|
-
const documentManager2 = getService$
|
1973
|
-
const permissionChecker2 = getService$
|
2207
|
+
const documentManager2 = getService$2("document-manager");
|
2208
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
1974
2209
|
if (permissionChecker2.cannot.unpublish()) {
|
1975
2210
|
return ctx.forbidden();
|
1976
2211
|
}
|
1977
|
-
const { locale } = await getDocumentLocaleAndStatus(body, model
|
2212
|
+
const { locale } = await getDocumentLocaleAndStatus(body, model, {
|
2213
|
+
allowMultipleLocales: true
|
2214
|
+
});
|
1978
2215
|
const entityPromises = documentIds.map(
|
1979
2216
|
(documentId) => documentManager2.findLocales(documentId, model, { locale, isPublished: true })
|
1980
2217
|
);
|
@@ -1997,8 +2234,8 @@ const collectionTypes = {
|
|
1997
2234
|
const {
|
1998
2235
|
body: { discardDraft, ...body }
|
1999
2236
|
} = ctx.request;
|
2000
|
-
const documentManager2 = getService$
|
2001
|
-
const permissionChecker2 = getService$
|
2237
|
+
const documentManager2 = getService$2("document-manager");
|
2238
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
2002
2239
|
if (permissionChecker2.cannot.unpublish()) {
|
2003
2240
|
return ctx.forbidden();
|
2004
2241
|
}
|
@@ -2006,7 +2243,7 @@ const collectionTypes = {
|
|
2006
2243
|
return ctx.forbidden();
|
2007
2244
|
}
|
2008
2245
|
const permissionQuery = await permissionChecker2.sanitizedQuery.unpublish(ctx.query);
|
2009
|
-
const populate = await getService$
|
2246
|
+
const populate = await getService$2("populate-builder")(model).populateFromQuery(permissionQuery).build();
|
2010
2247
|
const { locale } = await getDocumentLocaleAndStatus(body, model);
|
2011
2248
|
const document = await documentManager2.findOne(id, model, {
|
2012
2249
|
populate,
|
@@ -2037,13 +2274,13 @@ const collectionTypes = {
|
|
2037
2274
|
const { userAbility } = ctx.state;
|
2038
2275
|
const { id, model } = ctx.params;
|
2039
2276
|
const { body } = ctx.request;
|
2040
|
-
const documentManager2 = getService$
|
2041
|
-
const permissionChecker2 = getService$
|
2277
|
+
const documentManager2 = getService$2("document-manager");
|
2278
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
2042
2279
|
if (permissionChecker2.cannot.discard()) {
|
2043
2280
|
return ctx.forbidden();
|
2044
2281
|
}
|
2045
2282
|
const permissionQuery = await permissionChecker2.sanitizedQuery.discard(ctx.query);
|
2046
|
-
const populate = await getService$
|
2283
|
+
const populate = await getService$2("populate-builder")(model).populateFromQuery(permissionQuery).build();
|
2047
2284
|
const { locale } = await getDocumentLocaleAndStatus(body, model);
|
2048
2285
|
const document = await documentManager2.findOne(id, model, {
|
2049
2286
|
populate,
|
@@ -2068,13 +2305,13 @@ const collectionTypes = {
|
|
2068
2305
|
const { query, body } = ctx.request;
|
2069
2306
|
const { documentIds } = body;
|
2070
2307
|
await validateBulkActionInput(body);
|
2071
|
-
const documentManager2 = getService$
|
2072
|
-
const permissionChecker2 = getService$
|
2308
|
+
const documentManager2 = getService$2("document-manager");
|
2309
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
2073
2310
|
if (permissionChecker2.cannot.delete()) {
|
2074
2311
|
return ctx.forbidden();
|
2075
2312
|
}
|
2076
2313
|
const permissionQuery = await permissionChecker2.sanitizedQuery.delete(query);
|
2077
|
-
const populate = await getService$
|
2314
|
+
const populate = await getService$2("populate-builder")(model).populateFromQuery(permissionQuery).build();
|
2078
2315
|
const { locale } = await getDocumentLocaleAndStatus(body, model);
|
2079
2316
|
const documentLocales = await documentManager2.findLocales(documentIds, model, {
|
2080
2317
|
populate,
|
@@ -2095,13 +2332,13 @@ const collectionTypes = {
|
|
2095
2332
|
async countDraftRelations(ctx) {
|
2096
2333
|
const { userAbility } = ctx.state;
|
2097
2334
|
const { model, id } = ctx.params;
|
2098
|
-
const documentManager2 = getService$
|
2099
|
-
const permissionChecker2 = getService$
|
2335
|
+
const documentManager2 = getService$2("document-manager");
|
2336
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
2100
2337
|
if (permissionChecker2.cannot.read()) {
|
2101
2338
|
return ctx.forbidden();
|
2102
2339
|
}
|
2103
2340
|
const permissionQuery = await permissionChecker2.sanitizedQuery.read(ctx.query);
|
2104
|
-
const populate = await getService$
|
2341
|
+
const populate = await getService$2("populate-builder")(model).populateFromQuery(permissionQuery).build();
|
2105
2342
|
const { locale, status } = await getDocumentLocaleAndStatus(ctx.query, model);
|
2106
2343
|
const entity = await documentManager2.findOne(id, model, { populate, locale, status });
|
2107
2344
|
if (!entity) {
|
@@ -2120,8 +2357,8 @@ const collectionTypes = {
|
|
2120
2357
|
const ids = ctx.request.query.documentIds;
|
2121
2358
|
const locale = ctx.request.query.locale;
|
2122
2359
|
const { model } = ctx.params;
|
2123
|
-
const documentManager2 = getService$
|
2124
|
-
const permissionChecker2 = getService$
|
2360
|
+
const documentManager2 = getService$2("document-manager");
|
2361
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
2125
2362
|
if (permissionChecker2.cannot.read()) {
|
2126
2363
|
return ctx.forbidden();
|
2127
2364
|
}
|
@@ -2145,13 +2382,13 @@ const collectionTypes = {
|
|
2145
2382
|
};
|
2146
2383
|
const components$1 = {
|
2147
2384
|
findComponents(ctx) {
|
2148
|
-
const components2 = getService$
|
2149
|
-
const { toDto } = getService$
|
2385
|
+
const components2 = getService$2("components").findAllComponents();
|
2386
|
+
const { toDto } = getService$2("data-mapper");
|
2150
2387
|
ctx.body = { data: components2.map(toDto) };
|
2151
2388
|
},
|
2152
2389
|
async findComponentConfiguration(ctx) {
|
2153
2390
|
const { uid: uid2 } = ctx.params;
|
2154
|
-
const componentService = getService$
|
2391
|
+
const componentService = getService$2("components");
|
2155
2392
|
const component = componentService.findComponent(uid2);
|
2156
2393
|
if (!component) {
|
2157
2394
|
return ctx.notFound("component.notFound");
|
@@ -2168,7 +2405,7 @@ const components$1 = {
|
|
2168
2405
|
async updateComponentConfiguration(ctx) {
|
2169
2406
|
const { uid: uid2 } = ctx.params;
|
2170
2407
|
const { body } = ctx.request;
|
2171
|
-
const componentService = getService$
|
2408
|
+
const componentService = getService$2("components");
|
2172
2409
|
const component = componentService.findComponent(uid2);
|
2173
2410
|
if (!component) {
|
2174
2411
|
return ctx.notFound("component.notFound");
|
@@ -2202,12 +2439,12 @@ const contentTypes = {
|
|
2202
2439
|
} catch (error) {
|
2203
2440
|
return ctx.send({ error }, 400);
|
2204
2441
|
}
|
2205
|
-
const contentTypes2 = getService$
|
2206
|
-
const { toDto } = getService$
|
2442
|
+
const contentTypes2 = getService$2("content-types").findContentTypesByKind(kind);
|
2443
|
+
const { toDto } = getService$2("data-mapper");
|
2207
2444
|
ctx.body = { data: contentTypes2.map(toDto) };
|
2208
2445
|
},
|
2209
2446
|
async findContentTypesSettings(ctx) {
|
2210
|
-
const { findAllContentTypes, findConfiguration } = getService$
|
2447
|
+
const { findAllContentTypes, findConfiguration } = getService$2("content-types");
|
2211
2448
|
const contentTypes2 = await findAllContentTypes();
|
2212
2449
|
const configurations = await Promise.all(
|
2213
2450
|
contentTypes2.map(async (contentType) => {
|
@@ -2221,7 +2458,7 @@ const contentTypes = {
|
|
2221
2458
|
},
|
2222
2459
|
async findContentTypeConfiguration(ctx) {
|
2223
2460
|
const { uid: uid2 } = ctx.params;
|
2224
|
-
const contentTypeService = getService$
|
2461
|
+
const contentTypeService = getService$2("content-types");
|
2225
2462
|
const contentType = await contentTypeService.findContentType(uid2);
|
2226
2463
|
if (!contentType) {
|
2227
2464
|
return ctx.notFound("contentType.notFound");
|
@@ -2243,13 +2480,13 @@ const contentTypes = {
|
|
2243
2480
|
const { userAbility } = ctx.state;
|
2244
2481
|
const { uid: uid2 } = ctx.params;
|
2245
2482
|
const { body } = ctx.request;
|
2246
|
-
const contentTypeService = getService$
|
2247
|
-
const metricsService = getService$
|
2483
|
+
const contentTypeService = getService$2("content-types");
|
2484
|
+
const metricsService = getService$2("metrics");
|
2248
2485
|
const contentType = await contentTypeService.findContentType(uid2);
|
2249
2486
|
if (!contentType) {
|
2250
2487
|
return ctx.notFound("contentType.notFound");
|
2251
2488
|
}
|
2252
|
-
if (!getService$
|
2489
|
+
if (!getService$2("permission").canConfigureContentType({ userAbility, contentType })) {
|
2253
2490
|
return ctx.forbidden();
|
2254
2491
|
}
|
2255
2492
|
let input;
|
@@ -2282,10 +2519,10 @@ const contentTypes = {
|
|
2282
2519
|
};
|
2283
2520
|
const init = {
|
2284
2521
|
getInitData(ctx) {
|
2285
|
-
const { toDto } = getService$
|
2286
|
-
const { findAllComponents } = getService$
|
2287
|
-
const { getAllFieldSizes } = getService$
|
2288
|
-
const { findAllContentTypes } = getService$
|
2522
|
+
const { toDto } = getService$2("data-mapper");
|
2523
|
+
const { findAllComponents } = getService$2("components");
|
2524
|
+
const { getAllFieldSizes } = getService$2("field-sizes");
|
2525
|
+
const { findAllContentTypes } = getService$2("content-types");
|
2289
2526
|
ctx.body = {
|
2290
2527
|
data: {
|
2291
2528
|
fieldSizes: getAllFieldSizes(),
|
@@ -2321,36 +2558,41 @@ const addFiltersClause = (params, filtersClause) => {
|
|
2321
2558
|
params.filters.$and.push(filtersClause);
|
2322
2559
|
};
|
2323
2560
|
const sanitizeMainField = (model, mainField, userAbility) => {
|
2324
|
-
const permissionChecker2 = getService$
|
2561
|
+
const permissionChecker2 = getService$2("permission-checker").create({
|
2325
2562
|
userAbility,
|
2326
2563
|
model: model.uid
|
2327
2564
|
});
|
2328
|
-
|
2565
|
+
const isMainFieldListable = isListable(model, mainField);
|
2566
|
+
const canReadMainField = permissionChecker2.can.read(null, mainField);
|
2567
|
+
if (!isMainFieldListable || !canReadMainField) {
|
2329
2568
|
return "id";
|
2330
2569
|
}
|
2331
|
-
if (
|
2332
|
-
|
2333
|
-
const userPermissionChecker = getService$1("permission-checker").create({
|
2334
|
-
userAbility,
|
2335
|
-
model: "plugin::users-permissions.user"
|
2336
|
-
});
|
2337
|
-
if (userPermissionChecker.can.read()) {
|
2338
|
-
return "name";
|
2339
|
-
}
|
2340
|
-
}
|
2341
|
-
return "id";
|
2570
|
+
if (model.uid === "plugin::users-permissions.role") {
|
2571
|
+
return "name";
|
2342
2572
|
}
|
2343
2573
|
return mainField;
|
2344
2574
|
};
|
2345
|
-
const addStatusToRelations = async (
|
2346
|
-
if (!strapiUtils.contentTypes.hasDraftAndPublish(strapi.
|
2575
|
+
const addStatusToRelations = async (targetUid, relations2) => {
|
2576
|
+
if (!strapiUtils.contentTypes.hasDraftAndPublish(strapi.getModel(targetUid))) {
|
2347
2577
|
return relations2;
|
2348
2578
|
}
|
2349
|
-
const documentMetadata2 = getService$
|
2350
|
-
|
2579
|
+
const documentMetadata2 = getService$2("document-metadata");
|
2580
|
+
if (!relations2.length) {
|
2581
|
+
return relations2;
|
2582
|
+
}
|
2583
|
+
const firstRelation = relations2[0];
|
2584
|
+
const filters = {
|
2585
|
+
documentId: { $in: relations2.map((r) => r.documentId) },
|
2586
|
+
// NOTE: find the "opposite" status
|
2587
|
+
publishedAt: firstRelation.publishedAt !== null ? { $null: true } : { $notNull: true }
|
2588
|
+
};
|
2589
|
+
const availableStatus = await strapi.query(targetUid).findMany({
|
2590
|
+
select: ["id", "documentId", "locale", "updatedAt", "createdAt", "publishedAt"],
|
2591
|
+
filters
|
2592
|
+
});
|
2351
2593
|
return relations2.map((relation) => {
|
2352
|
-
const availableStatuses =
|
2353
|
-
(availableDocument) => availableDocument.documentId === relation.documentId
|
2594
|
+
const availableStatuses = availableStatus.filter(
|
2595
|
+
(availableDocument) => availableDocument.documentId === relation.documentId && (relation.locale ? availableDocument.locale === relation.locale : true)
|
2354
2596
|
);
|
2355
2597
|
return {
|
2356
2598
|
...relation,
|
@@ -2371,11 +2613,8 @@ const validateLocale = (sourceUid, targetUid, locale) => {
|
|
2371
2613
|
const isLocalized = strapi.plugin("i18n").service("content-types").isLocalizedContentType;
|
2372
2614
|
const isSourceLocalized = isLocalized(sourceModel);
|
2373
2615
|
const isTargetLocalized = isLocalized(targetModel);
|
2374
|
-
let validatedLocale = locale;
|
2375
|
-
if (!targetModel || !isTargetLocalized)
|
2376
|
-
validatedLocale = void 0;
|
2377
2616
|
return {
|
2378
|
-
locale
|
2617
|
+
locale,
|
2379
2618
|
isSourceLocalized,
|
2380
2619
|
isTargetLocalized
|
2381
2620
|
};
|
@@ -2384,8 +2623,7 @@ const validateStatus = (sourceUid, status) => {
|
|
2384
2623
|
const sourceModel = strapi.getModel(sourceUid);
|
2385
2624
|
const isDP = strapiUtils.contentTypes.hasDraftAndPublish;
|
2386
2625
|
const isSourceDP = isDP(sourceModel);
|
2387
|
-
if (!isSourceDP)
|
2388
|
-
return { status: void 0 };
|
2626
|
+
if (!isSourceDP) return { status: void 0 };
|
2389
2627
|
switch (status) {
|
2390
2628
|
case "published":
|
2391
2629
|
return { status: "published" };
|
@@ -2415,7 +2653,7 @@ const relations = {
|
|
2415
2653
|
ctx.request?.query?.locale
|
2416
2654
|
);
|
2417
2655
|
const { status } = validateStatus(sourceUid, ctx.request?.query?.status);
|
2418
|
-
const permissionChecker2 = getService$
|
2656
|
+
const permissionChecker2 = getService$2("permission-checker").create({
|
2419
2657
|
userAbility,
|
2420
2658
|
model
|
2421
2659
|
});
|
@@ -2440,7 +2678,7 @@ const relations = {
|
|
2440
2678
|
where.id = id;
|
2441
2679
|
}
|
2442
2680
|
const permissionQuery = await permissionChecker2.sanitizedQuery.read(ctx.query);
|
2443
|
-
const populate = await getService$
|
2681
|
+
const populate = await getService$2("populate-builder")(model).populateFromQuery(permissionQuery).build();
|
2444
2682
|
const currentEntity = await strapi.db.query(model).findOne({
|
2445
2683
|
where,
|
2446
2684
|
populate
|
@@ -2455,7 +2693,7 @@ const relations = {
|
|
2455
2693
|
}
|
2456
2694
|
entryId = currentEntity.id;
|
2457
2695
|
}
|
2458
|
-
const modelConfig = isComponent2 ? await getService$
|
2696
|
+
const modelConfig = isComponent2 ? await getService$2("components").findConfiguration(sourceSchema) : await getService$2("content-types").findConfiguration(sourceSchema);
|
2459
2697
|
const targetSchema = strapi.getModel(targetUid);
|
2460
2698
|
const mainField = fp.flow(
|
2461
2699
|
fp.prop(`metadatas.${targetField}.edit.mainField`),
|
@@ -2478,7 +2716,7 @@ const relations = {
|
|
2478
2716
|
attribute,
|
2479
2717
|
fieldsToSelect,
|
2480
2718
|
mainField,
|
2481
|
-
source: { schema: sourceSchema },
|
2719
|
+
source: { schema: sourceSchema, isLocalized: isSourceLocalized },
|
2482
2720
|
target: { schema: targetSchema, isLocalized: isTargetLocalized },
|
2483
2721
|
sourceSchema,
|
2484
2722
|
targetSchema,
|
@@ -2500,7 +2738,8 @@ const relations = {
|
|
2500
2738
|
fieldsToSelect,
|
2501
2739
|
mainField,
|
2502
2740
|
source: {
|
2503
|
-
schema: { uid: sourceUid, modelType: sourceModelType }
|
2741
|
+
schema: { uid: sourceUid, modelType: sourceModelType },
|
2742
|
+
isLocalized: isSourceLocalized
|
2504
2743
|
},
|
2505
2744
|
target: {
|
2506
2745
|
schema: { uid: targetUid },
|
@@ -2508,7 +2747,7 @@ const relations = {
|
|
2508
2747
|
}
|
2509
2748
|
} = await this.extractAndValidateRequestInfo(ctx, id);
|
2510
2749
|
const { idsToOmit, idsToInclude, _q, ...query } = ctx.request.query;
|
2511
|
-
const permissionChecker2 = getService$
|
2750
|
+
const permissionChecker2 = getService$2("permission-checker").create({
|
2512
2751
|
userAbility: ctx.state.userAbility,
|
2513
2752
|
model: targetUid
|
2514
2753
|
});
|
@@ -2538,12 +2777,16 @@ const relations = {
|
|
2538
2777
|
} else {
|
2539
2778
|
where.id = id;
|
2540
2779
|
}
|
2541
|
-
|
2542
|
-
|
2780
|
+
const publishedAt = getPublishedAtClause(status, targetUid);
|
2781
|
+
if (!fp.isEmpty(publishedAt)) {
|
2782
|
+
where[`${alias}.published_at`] = publishedAt;
|
2543
2783
|
}
|
2544
|
-
if (
|
2784
|
+
if (isTargetLocalized && locale) {
|
2545
2785
|
where[`${alias}.locale`] = locale;
|
2546
2786
|
}
|
2787
|
+
if (isSourceLocalized && locale) {
|
2788
|
+
where.locale = locale;
|
2789
|
+
}
|
2547
2790
|
if ((idsToInclude?.length ?? 0) !== 0) {
|
2548
2791
|
where[`${alias}.id`].$notIn = idsToInclude;
|
2549
2792
|
}
|
@@ -2561,7 +2804,8 @@ const relations = {
|
|
2561
2804
|
id: { $notIn: fp.uniq(idsToOmit) }
|
2562
2805
|
});
|
2563
2806
|
}
|
2564
|
-
const
|
2807
|
+
const dbQuery = strapi.get("query-params").transform(targetUid, queryParams);
|
2808
|
+
const res = await strapi.db.query(targetUid).findPage(dbQuery);
|
2565
2809
|
ctx.body = {
|
2566
2810
|
...res,
|
2567
2811
|
results: await addStatusToRelations(targetUid, res.results)
|
@@ -2576,29 +2820,39 @@ const relations = {
|
|
2576
2820
|
attribute,
|
2577
2821
|
targetField,
|
2578
2822
|
fieldsToSelect,
|
2579
|
-
|
2580
|
-
|
2581
|
-
}
|
2582
|
-
target: {
|
2583
|
-
schema: { uid: targetUid }
|
2584
|
-
}
|
2823
|
+
status,
|
2824
|
+
source: { schema: sourceSchema },
|
2825
|
+
target: { schema: targetSchema }
|
2585
2826
|
} = await this.extractAndValidateRequestInfo(ctx, id);
|
2586
|
-
const
|
2827
|
+
const { uid: sourceUid } = sourceSchema;
|
2828
|
+
const { uid: targetUid } = targetSchema;
|
2829
|
+
const permissionQuery = await getService$2("permission-checker").create({ userAbility, model: targetUid }).sanitizedQuery.read({ fields: fieldsToSelect });
|
2587
2830
|
const dbQuery = strapi.db.query(sourceUid);
|
2588
2831
|
const loadRelations = strapiUtils.relations.isAnyToMany(attribute) ? (...args) => dbQuery.loadPages(...args) : (...args) => dbQuery.load(...args).then((res2) => ({ results: res2 ? [res2] : [] }));
|
2832
|
+
const filters = {};
|
2833
|
+
if (sourceSchema?.options?.draftAndPublish) {
|
2834
|
+
if (targetSchema?.options?.draftAndPublish) {
|
2835
|
+
if (status === "published") {
|
2836
|
+
filters.publishedAt = { $notNull: true };
|
2837
|
+
} else {
|
2838
|
+
filters.publishedAt = { $null: true };
|
2839
|
+
}
|
2840
|
+
}
|
2841
|
+
} else if (targetSchema?.options?.draftAndPublish) {
|
2842
|
+
filters.publishedAt = { $null: true };
|
2843
|
+
}
|
2589
2844
|
const res = await loadRelations({ id: entryId }, targetField, {
|
2590
|
-
select: ["id", "documentId", "locale", "publishedAt"],
|
2845
|
+
select: ["id", "documentId", "locale", "publishedAt", "updatedAt"],
|
2591
2846
|
ordering: "desc",
|
2592
2847
|
page: ctx.request.query.page,
|
2593
|
-
pageSize: ctx.request.query.pageSize
|
2848
|
+
pageSize: ctx.request.query.pageSize,
|
2849
|
+
filters
|
2594
2850
|
});
|
2595
2851
|
const loadedIds = res.results.map((item) => item.id);
|
2596
2852
|
addFiltersClause(permissionQuery, { id: { $in: loadedIds } });
|
2597
2853
|
const sanitizedRes = await loadRelations({ id: entryId }, targetField, {
|
2598
2854
|
...strapi.get("query-params").transform(targetUid, permissionQuery),
|
2599
|
-
ordering: "desc"
|
2600
|
-
page: ctx.request.query.page,
|
2601
|
-
pageSize: ctx.request.query.pageSize
|
2855
|
+
ordering: "desc"
|
2602
2856
|
});
|
2603
2857
|
const relationsUnion = fp.uniqBy("id", fp.concat(sanitizedRes.results, res.results));
|
2604
2858
|
ctx.body = {
|
@@ -2613,10 +2867,10 @@ const relations = {
|
|
2613
2867
|
}
|
2614
2868
|
};
|
2615
2869
|
const buildPopulateFromQuery = async (query, model) => {
|
2616
|
-
return getService$
|
2870
|
+
return getService$2("populate-builder")(model).populateFromQuery(query).populateDeep(Infinity).countRelations().build();
|
2617
2871
|
};
|
2618
2872
|
const findDocument = async (query, uid2, opts = {}) => {
|
2619
|
-
const documentManager2 = getService$
|
2873
|
+
const documentManager2 = getService$2("document-manager");
|
2620
2874
|
const populate = await buildPopulateFromQuery(query, uid2);
|
2621
2875
|
return documentManager2.findMany({ ...opts, populate }, uid2).then((documents) => documents[0]);
|
2622
2876
|
};
|
@@ -2624,8 +2878,8 @@ const createOrUpdateDocument = async (ctx, opts) => {
|
|
2624
2878
|
const { user, userAbility } = ctx.state;
|
2625
2879
|
const { model } = ctx.params;
|
2626
2880
|
const { body, query } = ctx.request;
|
2627
|
-
const documentManager2 = getService$
|
2628
|
-
const permissionChecker2 = getService$
|
2881
|
+
const documentManager2 = getService$2("document-manager");
|
2882
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
2629
2883
|
if (permissionChecker2.cannot.create() && permissionChecker2.cannot.update()) {
|
2630
2884
|
throw new strapiUtils.errors.ForbiddenError();
|
2631
2885
|
}
|
@@ -2666,7 +2920,7 @@ const singleTypes = {
|
|
2666
2920
|
const { userAbility } = ctx.state;
|
2667
2921
|
const { model } = ctx.params;
|
2668
2922
|
const { query = {} } = ctx.request;
|
2669
|
-
const permissionChecker2 = getService$
|
2923
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
2670
2924
|
if (permissionChecker2.cannot.read()) {
|
2671
2925
|
return ctx.forbidden();
|
2672
2926
|
}
|
@@ -2685,7 +2939,7 @@ const singleTypes = {
|
|
2685
2939
|
permissionChecker2,
|
2686
2940
|
model,
|
2687
2941
|
// @ts-expect-error - fix types
|
2688
|
-
{
|
2942
|
+
{ documentId: document.documentId, locale, publishedAt: null },
|
2689
2943
|
{ availableLocales: true, availableStatus: false }
|
2690
2944
|
);
|
2691
2945
|
ctx.body = { data: {}, meta };
|
@@ -2700,7 +2954,7 @@ const singleTypes = {
|
|
2700
2954
|
async createOrUpdate(ctx) {
|
2701
2955
|
const { userAbility } = ctx.state;
|
2702
2956
|
const { model } = ctx.params;
|
2703
|
-
const permissionChecker2 = getService$
|
2957
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
2704
2958
|
const document = await createOrUpdateDocument(ctx);
|
2705
2959
|
const sanitizedDocument = await permissionChecker2.sanitizeOutput(document);
|
2706
2960
|
ctx.body = await formatDocumentWithMetadata(permissionChecker2, model, sanitizedDocument);
|
@@ -2709,8 +2963,8 @@ const singleTypes = {
|
|
2709
2963
|
const { userAbility } = ctx.state;
|
2710
2964
|
const { model } = ctx.params;
|
2711
2965
|
const { query = {} } = ctx.request;
|
2712
|
-
const documentManager2 = getService$
|
2713
|
-
const permissionChecker2 = getService$
|
2966
|
+
const documentManager2 = getService$2("document-manager");
|
2967
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
2714
2968
|
if (permissionChecker2.cannot.delete()) {
|
2715
2969
|
return ctx.forbidden();
|
2716
2970
|
}
|
@@ -2738,8 +2992,8 @@ const singleTypes = {
|
|
2738
2992
|
const { userAbility } = ctx.state;
|
2739
2993
|
const { model } = ctx.params;
|
2740
2994
|
const { query = {} } = ctx.request;
|
2741
|
-
const documentManager2 = getService$
|
2742
|
-
const permissionChecker2 = getService$
|
2995
|
+
const documentManager2 = getService$2("document-manager");
|
2996
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
2743
2997
|
if (permissionChecker2.cannot.publish()) {
|
2744
2998
|
return ctx.forbidden();
|
2745
2999
|
}
|
@@ -2767,8 +3021,8 @@ const singleTypes = {
|
|
2767
3021
|
body: { discardDraft, ...body },
|
2768
3022
|
query = {}
|
2769
3023
|
} = ctx.request;
|
2770
|
-
const documentManager2 = getService$
|
2771
|
-
const permissionChecker2 = getService$
|
3024
|
+
const documentManager2 = getService$2("document-manager");
|
3025
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
2772
3026
|
if (permissionChecker2.cannot.unpublish()) {
|
2773
3027
|
return ctx.forbidden();
|
2774
3028
|
}
|
@@ -2802,8 +3056,8 @@ const singleTypes = {
|
|
2802
3056
|
const { userAbility } = ctx.state;
|
2803
3057
|
const { model } = ctx.params;
|
2804
3058
|
const { body, query = {} } = ctx.request;
|
2805
|
-
const documentManager2 = getService$
|
2806
|
-
const permissionChecker2 = getService$
|
3059
|
+
const documentManager2 = getService$2("document-manager");
|
3060
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
2807
3061
|
if (permissionChecker2.cannot.discard()) {
|
2808
3062
|
return ctx.forbidden();
|
2809
3063
|
}
|
@@ -2826,8 +3080,8 @@ const singleTypes = {
|
|
2826
3080
|
const { userAbility } = ctx.state;
|
2827
3081
|
const { model } = ctx.params;
|
2828
3082
|
const { query } = ctx.request;
|
2829
|
-
const documentManager2 = getService$
|
2830
|
-
const permissionChecker2 = getService$
|
3083
|
+
const documentManager2 = getService$2("document-manager");
|
3084
|
+
const permissionChecker2 = getService$2("permission-checker").create({ userAbility, model });
|
2831
3085
|
const { locale } = await getDocumentLocaleAndStatus(query, model);
|
2832
3086
|
if (permissionChecker2.cannot.read()) {
|
2833
3087
|
return ctx.forbidden();
|
@@ -2851,7 +3105,7 @@ const uid$1 = {
|
|
2851
3105
|
const { query = {} } = ctx.request;
|
2852
3106
|
const { locale } = await getDocumentLocaleAndStatus(query, contentTypeUID);
|
2853
3107
|
await validateUIDField(contentTypeUID, field);
|
2854
|
-
const uidService = getService$
|
3108
|
+
const uidService = getService$2("uid");
|
2855
3109
|
ctx.body = {
|
2856
3110
|
data: await uidService.generateUIDField({ contentTypeUID, field, data, locale })
|
2857
3111
|
};
|
@@ -2863,7 +3117,7 @@ const uid$1 = {
|
|
2863
3117
|
const { query = {} } = ctx.request;
|
2864
3118
|
const { locale } = await getDocumentLocaleAndStatus(query, contentTypeUID);
|
2865
3119
|
await validateUIDField(contentTypeUID, field);
|
2866
|
-
const uidService = getService$
|
3120
|
+
const uidService = getService$2("uid");
|
2867
3121
|
const isAvailable = await uidService.checkUIDAvailability({
|
2868
3122
|
contentTypeUID,
|
2869
3123
|
field,
|
@@ -2884,7 +3138,8 @@ const controllers = {
|
|
2884
3138
|
relations,
|
2885
3139
|
"single-types": singleTypes,
|
2886
3140
|
uid: uid$1,
|
2887
|
-
...history.controllers ? history.controllers : {}
|
3141
|
+
...history.controllers ? history.controllers : {},
|
3142
|
+
...preview.controllers ? preview.controllers : {}
|
2888
3143
|
};
|
2889
3144
|
const keys = {
|
2890
3145
|
CONFIGURATION: "configuration"
|
@@ -3013,18 +3268,15 @@ async function syncMetadatas(configuration, schema) {
|
|
3013
3268
|
___default.default.set(updatedMeta, ["list", "searchable"], false);
|
3014
3269
|
___default.default.set(acc, [key], updatedMeta);
|
3015
3270
|
}
|
3016
|
-
if (!___default.default.has(edit, "mainField"))
|
3017
|
-
return acc;
|
3271
|
+
if (!___default.default.has(edit, "mainField")) return acc;
|
3018
3272
|
if (!isRelation$1(attr)) {
|
3019
3273
|
___default.default.set(updatedMeta, "edit", ___default.default.omit(edit, ["mainField"]));
|
3020
3274
|
___default.default.set(acc, [key], updatedMeta);
|
3021
3275
|
return acc;
|
3022
3276
|
}
|
3023
|
-
if (edit.mainField === "id")
|
3024
|
-
return acc;
|
3277
|
+
if (edit.mainField === "id") return acc;
|
3025
3278
|
const targetSchema = getTargetSchema(attr.targetModel);
|
3026
|
-
if (!targetSchema)
|
3027
|
-
return acc;
|
3279
|
+
if (!targetSchema) return acc;
|
3028
3280
|
if (!isSortable(targetSchema, edit.mainField) && !isListable(targetSchema, edit.mainField)) {
|
3029
3281
|
___default.default.set(updatedMeta, ["edit", "mainField"], getDefaultMainField(targetSchema));
|
3030
3282
|
___default.default.set(acc, [key], updatedMeta);
|
@@ -3035,12 +3287,12 @@ async function syncMetadatas(configuration, schema) {
|
|
3035
3287
|
return ___default.default.assign(metasWithDefaults, updatedMetas);
|
3036
3288
|
}
|
3037
3289
|
const getTargetSchema = (targetModel) => {
|
3038
|
-
return getService$
|
3290
|
+
return getService$2("content-types").findContentType(targetModel);
|
3039
3291
|
};
|
3040
3292
|
const DEFAULT_LIST_LENGTH = 4;
|
3041
3293
|
const MAX_ROW_SIZE = 12;
|
3042
3294
|
const isAllowedFieldSize = (type, size) => {
|
3043
|
-
const { getFieldSize } = getService$
|
3295
|
+
const { getFieldSize } = getService$2("field-sizes");
|
3044
3296
|
const fieldSize = getFieldSize(type);
|
3045
3297
|
if (!fieldSize.isResizable && size !== fieldSize.default) {
|
3046
3298
|
return false;
|
@@ -3048,7 +3300,7 @@ const isAllowedFieldSize = (type, size) => {
|
|
3048
3300
|
return size <= MAX_ROW_SIZE;
|
3049
3301
|
};
|
3050
3302
|
const getDefaultFieldSize = (attribute) => {
|
3051
|
-
const { hasFieldSize, getFieldSize } = getService$
|
3303
|
+
const { hasFieldSize, getFieldSize } = getService$2("field-sizes");
|
3052
3304
|
return getFieldSize(hasFieldSize(attribute.customField) ? attribute.customField : attribute.type).default;
|
3053
3305
|
};
|
3054
3306
|
async function createDefaultLayouts(schema) {
|
@@ -3069,8 +3321,7 @@ function createDefaultEditLayout(schema) {
|
|
3069
3321
|
return appendToEditLayout([], keys2, schema);
|
3070
3322
|
}
|
3071
3323
|
function syncLayouts(configuration, schema) {
|
3072
|
-
if (___default.default.isEmpty(configuration.layouts))
|
3073
|
-
return createDefaultLayouts(schema);
|
3324
|
+
if (___default.default.isEmpty(configuration.layouts)) return createDefaultLayouts(schema);
|
3074
3325
|
const { list = [], editRelations = [], edit = [] } = configuration.layouts || {};
|
3075
3326
|
let cleanList = list.filter((attr) => isListable(schema, attr));
|
3076
3327
|
const cleanEditRelations = editRelations.filter(
|
@@ -3081,9 +3332,8 @@ function syncLayouts(configuration, schema) {
|
|
3081
3332
|
for (const row of edit) {
|
3082
3333
|
const newRow = [];
|
3083
3334
|
for (const el of row) {
|
3084
|
-
if (!hasEditableAttribute(schema, el.name))
|
3085
|
-
|
3086
|
-
const { hasFieldSize } = getService$1("field-sizes");
|
3335
|
+
if (!hasEditableAttribute(schema, el.name)) continue;
|
3336
|
+
const { hasFieldSize } = getService$2("field-sizes");
|
3087
3337
|
const fieldType = hasFieldSize(schema.attributes[el.name].customField) ? schema.attributes[el.name].customField : schema.attributes[el.name].type;
|
3088
3338
|
if (!isAllowedFieldSize(fieldType, el.size)) {
|
3089
3339
|
elementsToReAppend.push(el.name);
|
@@ -3113,8 +3363,7 @@ function syncLayouts(configuration, schema) {
|
|
3113
3363
|
};
|
3114
3364
|
}
|
3115
3365
|
const appendToEditLayout = (layout = [], keysToAppend, schema) => {
|
3116
|
-
if (keysToAppend.length === 0)
|
3117
|
-
return layout;
|
3366
|
+
if (keysToAppend.length === 0) return layout;
|
3118
3367
|
let currentRowIndex = Math.max(layout.length - 1, 0);
|
3119
3368
|
if (!layout[currentRowIndex]) {
|
3120
3369
|
layout[currentRowIndex] = [];
|
@@ -3223,17 +3472,17 @@ const configurationService$1 = createConfigurationService({
|
|
3223
3472
|
isComponent: true,
|
3224
3473
|
prefix: STORE_KEY_PREFIX,
|
3225
3474
|
getModels() {
|
3226
|
-
const { toContentManagerModel } = getService$
|
3475
|
+
const { toContentManagerModel } = getService$2("data-mapper");
|
3227
3476
|
return fp.mapValues(toContentManagerModel, strapi.components);
|
3228
3477
|
}
|
3229
3478
|
});
|
3230
3479
|
const components = ({ strapi: strapi2 }) => ({
|
3231
3480
|
findAllComponents() {
|
3232
|
-
const { toContentManagerModel } = getService$
|
3481
|
+
const { toContentManagerModel } = getService$2("data-mapper");
|
3233
3482
|
return Object.values(strapi2.components).map(toContentManagerModel);
|
3234
3483
|
},
|
3235
3484
|
findComponent(uid2) {
|
3236
|
-
const { toContentManagerModel } = getService$
|
3485
|
+
const { toContentManagerModel } = getService$2("data-mapper");
|
3237
3486
|
const component = strapi2.components[uid2];
|
3238
3487
|
return fp.isNil(component) ? component : toContentManagerModel(component);
|
3239
3488
|
},
|
@@ -3284,17 +3533,17 @@ const configurationService = createConfigurationService({
|
|
3284
3533
|
storeUtils,
|
3285
3534
|
prefix: "content_types",
|
3286
3535
|
getModels() {
|
3287
|
-
const { toContentManagerModel } = getService$
|
3536
|
+
const { toContentManagerModel } = getService$2("data-mapper");
|
3288
3537
|
return fp.mapValues(toContentManagerModel, strapi.contentTypes);
|
3289
3538
|
}
|
3290
3539
|
});
|
3291
3540
|
const service = ({ strapi: strapi2 }) => ({
|
3292
3541
|
findAllContentTypes() {
|
3293
|
-
const { toContentManagerModel } = getService$
|
3542
|
+
const { toContentManagerModel } = getService$2("data-mapper");
|
3294
3543
|
return Object.values(strapi2.contentTypes).map(toContentManagerModel);
|
3295
3544
|
},
|
3296
3545
|
findContentType(uid2) {
|
3297
|
-
const { toContentManagerModel } = getService$
|
3546
|
+
const { toContentManagerModel } = getService$2("data-mapper");
|
3298
3547
|
const contentType = strapi2.contentTypes[uid2];
|
3299
3548
|
return fp.isNil(contentType) ? contentType : toContentManagerModel(contentType);
|
3300
3549
|
},
|
@@ -3323,7 +3572,7 @@ const service = ({ strapi: strapi2 }) => ({
|
|
3323
3572
|
return this.findConfiguration(contentType);
|
3324
3573
|
},
|
3325
3574
|
findComponentsConfigurations(contentType) {
|
3326
|
-
return getService$
|
3575
|
+
return getService$2("components").findComponentsConfigurations(contentType);
|
3327
3576
|
},
|
3328
3577
|
syncConfigurations() {
|
3329
3578
|
return configurationService.syncConfigurations();
|
@@ -3504,12 +3753,27 @@ const createPermissionChecker = (strapi2) => ({ userAbility, model }) => {
|
|
3504
3753
|
ability: userAbility,
|
3505
3754
|
model
|
3506
3755
|
});
|
3507
|
-
const
|
3756
|
+
const { actionProvider } = strapi2.service("admin::permission");
|
3757
|
+
const toSubject = (entity) => {
|
3758
|
+
return entity ? permissionsManager.toSubject(entity, model) : model;
|
3759
|
+
};
|
3508
3760
|
const can = (action, entity, field) => {
|
3509
|
-
|
3761
|
+
const subject = toSubject(entity);
|
3762
|
+
const aliases = actionProvider.unstable_aliases(action, model);
|
3763
|
+
return (
|
3764
|
+
// Test the original action to see if it passes
|
3765
|
+
userAbility.can(action, subject, field) || // Else try every known alias if at least one of them succeed, then the user "can"
|
3766
|
+
aliases.some((alias) => userAbility.can(alias, subject, field))
|
3767
|
+
);
|
3510
3768
|
};
|
3511
3769
|
const cannot = (action, entity, field) => {
|
3512
|
-
|
3770
|
+
const subject = toSubject(entity);
|
3771
|
+
const aliases = actionProvider.unstable_aliases(action, model);
|
3772
|
+
return (
|
3773
|
+
// Test both the original action
|
3774
|
+
userAbility.cannot(action, subject, field) && // and every known alias, if all of them fail (cannot), then the user truly "cannot"
|
3775
|
+
aliases.every((alias) => userAbility.cannot(alias, subject, field))
|
3776
|
+
);
|
3513
3777
|
};
|
3514
3778
|
const sanitizeOutput = (data, { action = ACTIONS.read } = {}) => {
|
3515
3779
|
return permissionsManager.sanitizeOutput(data, { subject: toSubject(data), action });
|
@@ -3580,7 +3844,7 @@ const permission = ({ strapi: strapi2 }) => ({
|
|
3580
3844
|
return userAbility.can(action);
|
3581
3845
|
},
|
3582
3846
|
async registerPermissions() {
|
3583
|
-
const displayedContentTypes = getService$
|
3847
|
+
const displayedContentTypes = getService$2("content-types").findDisplayedContentTypes();
|
3584
3848
|
const contentTypesUids = displayedContentTypes.map(fp.prop("uid"));
|
3585
3849
|
const actions = [
|
3586
3850
|
{
|
@@ -3856,7 +4120,7 @@ const getQueryPopulate = async (uid2, query) => {
|
|
3856
4120
|
return populateQuery;
|
3857
4121
|
};
|
3858
4122
|
const buildDeepPopulate = (uid2) => {
|
3859
|
-
return getService$
|
4123
|
+
return getService$2("populate-builder")(uid2).populateDeep(Infinity).countRelations().build();
|
3860
4124
|
};
|
3861
4125
|
const populateBuilder = (uid2) => {
|
3862
4126
|
let getInitialPopulate = async () => {
|
@@ -4041,7 +4305,9 @@ const documentMetadata = ({ strapi: strapi2 }) => ({
|
|
4041
4305
|
*/
|
4042
4306
|
async getAvailableLocales(uid2, version, allVersions, validatableFields = []) {
|
4043
4307
|
const versionsByLocale = fp.groupBy("locale", allVersions);
|
4044
|
-
|
4308
|
+
if (version.locale) {
|
4309
|
+
delete versionsByLocale[version.locale];
|
4310
|
+
}
|
4045
4311
|
const model = strapi2.getModel(uid2);
|
4046
4312
|
const keysToKeep = [...AVAILABLE_LOCALES_FIELDS, ...validatableFields];
|
4047
4313
|
const traversalFunction = async (localeVersion) => strapiUtils.traverseEntity(
|
@@ -4088,8 +4354,7 @@ const documentMetadata = ({ strapi: strapi2 }) => ({
|
|
4088
4354
|
const matchStatus = status === "published" ? v.publishedAt !== null : v.publishedAt === null;
|
4089
4355
|
return matchLocale && matchStatus;
|
4090
4356
|
});
|
4091
|
-
if (!availableStatus)
|
4092
|
-
return availableStatus;
|
4357
|
+
if (!availableStatus) return availableStatus;
|
4093
4358
|
return fp.pick(AVAILABLE_STATUS_FIELDS, availableStatus);
|
4094
4359
|
},
|
4095
4360
|
/**
|
@@ -4099,8 +4364,7 @@ const documentMetadata = ({ strapi: strapi2 }) => ({
|
|
4099
4364
|
* @returns
|
4100
4365
|
*/
|
4101
4366
|
async getManyAvailableStatus(uid2, documents) {
|
4102
|
-
if (!documents.length)
|
4103
|
-
return [];
|
4367
|
+
if (!documents.length) return [];
|
4104
4368
|
const status = documents[0].publishedAt !== null ? "published" : "draft";
|
4105
4369
|
const locale = documents[0]?.locale;
|
4106
4370
|
const otherStatus = status === "published" ? "draft" : "published";
|
@@ -4127,10 +4391,8 @@ const documentMetadata = ({ strapi: strapi2 }) => ({
|
|
4127
4391
|
} else if (otherVersion) {
|
4128
4392
|
draftVersion = otherVersion;
|
4129
4393
|
}
|
4130
|
-
if (!draftVersion)
|
4131
|
-
|
4132
|
-
if (!publishedVersion)
|
4133
|
-
return CONTENT_MANAGER_STATUS.DRAFT;
|
4394
|
+
if (!draftVersion) return CONTENT_MANAGER_STATUS.PUBLISHED;
|
4395
|
+
if (!publishedVersion) return CONTENT_MANAGER_STATUS.DRAFT;
|
4134
4396
|
const isDraftModified = getIsVersionLatestModification(draftVersion, publishedVersion);
|
4135
4397
|
return isDraftModified ? CONTENT_MANAGER_STATUS.MODIFIED : CONTENT_MANAGER_STATUS.PUBLISHED;
|
4136
4398
|
},
|
@@ -4397,7 +4659,8 @@ const services = {
|
|
4397
4659
|
permission,
|
4398
4660
|
"populate-builder": populateBuilder$1,
|
4399
4661
|
uid,
|
4400
|
-
...history.services ? history.services : {}
|
4662
|
+
...history.services ? history.services : {},
|
4663
|
+
...preview.services ? preview.services : {}
|
4401
4664
|
};
|
4402
4665
|
const index = () => {
|
4403
4666
|
return {
|