@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.
Files changed (212) hide show
  1. package/dist/_chunks/CardDragPreview-C0QyJgRA.js.map +1 -1
  2. package/dist/_chunks/CardDragPreview-DOxamsuj.mjs.map +1 -1
  3. package/dist/_chunks/{ComponentConfigurationPage-DL1MHO8i.js → ComponentConfigurationPage-BTR_hQow.js} +5 -6
  4. package/dist/_chunks/{ComponentConfigurationPage-DL1MHO8i.js.map → ComponentConfigurationPage-BTR_hQow.js.map} +1 -1
  5. package/dist/_chunks/{ComponentConfigurationPage-D0dyDTwq.mjs → ComponentConfigurationPage-bLQr82ce.mjs} +4 -4
  6. package/dist/_chunks/{ComponentConfigurationPage-D0dyDTwq.mjs.map → ComponentConfigurationPage-bLQr82ce.mjs.map} +1 -1
  7. package/dist/_chunks/{ComponentIcon-BXdiCGQp.js → ComponentIcon-CRbtQEUV.js} +2 -3
  8. package/dist/_chunks/{ComponentIcon-BXdiCGQp.js.map → ComponentIcon-CRbtQEUV.js.map} +1 -1
  9. package/dist/_chunks/ComponentIcon-u4bIXTFY.mjs.map +1 -1
  10. package/dist/_chunks/{EditConfigurationPage-13b7S5Cq.mjs → EditConfigurationPage-BhRSnUsL.mjs} +4 -4
  11. package/dist/_chunks/{EditConfigurationPage-13b7S5Cq.mjs.map → EditConfigurationPage-BhRSnUsL.mjs.map} +1 -1
  12. package/dist/_chunks/{EditConfigurationPage-CMaOf-A-.js → EditConfigurationPage-z39Wv3E6.js} +5 -6
  13. package/dist/_chunks/{EditConfigurationPage-CMaOf-A-.js.map → EditConfigurationPage-z39Wv3E6.js.map} +1 -1
  14. package/dist/_chunks/{EditViewPage-C3tIZ8F5.mjs → EditViewPage-BCjNxNlY.mjs} +63 -12
  15. package/dist/_chunks/EditViewPage-BCjNxNlY.mjs.map +1 -0
  16. package/dist/_chunks/{EditViewPage-BSVmMpRd.js → EditViewPage-wujOq90c.js} +63 -13
  17. package/dist/_chunks/EditViewPage-wujOq90c.js.map +1 -0
  18. package/dist/_chunks/{Field-DUCVth4C.js → Field-B5QXnctJ.js} +320 -169
  19. package/dist/_chunks/Field-B5QXnctJ.js.map +1 -0
  20. package/dist/_chunks/{Field-BvuT8cGL.mjs → Field-Byr3mPTl.mjs} +316 -165
  21. package/dist/_chunks/Field-Byr3mPTl.mjs.map +1 -0
  22. package/dist/_chunks/FieldTypeIcon-CMlNO8PE.mjs.map +1 -1
  23. package/dist/_chunks/FieldTypeIcon-Dnwq_IRF.js.map +1 -1
  24. package/dist/_chunks/{Form-BZmDNVr9.mjs → Form-BZgvE8C8.mjs} +37 -18
  25. package/dist/_chunks/Form-BZgvE8C8.mjs.map +1 -0
  26. package/dist/_chunks/{Form-Cpl4W1ak.js → Form-D7mexvm3.js} +39 -21
  27. package/dist/_chunks/Form-D7mexvm3.js.map +1 -0
  28. package/dist/_chunks/{History-Cq_Hrzuu.mjs → History-CqNgxkqK.mjs} +43 -100
  29. package/dist/_chunks/History-CqNgxkqK.mjs.map +1 -0
  30. package/dist/_chunks/{History-D4U2YISB.js → History-DYl2A8Z_.js} +42 -100
  31. package/dist/_chunks/History-DYl2A8Z_.js.map +1 -0
  32. package/dist/_chunks/{ListConfigurationPage-Bny6CdWe.js → ListConfigurationPage-BXnu_OoY.js} +19 -9
  33. package/dist/_chunks/ListConfigurationPage-BXnu_OoY.js.map +1 -0
  34. package/dist/_chunks/{ListConfigurationPage-W-KQHmBv.mjs → ListConfigurationPage-BbQjzKkQ.mjs} +19 -8
  35. package/dist/_chunks/ListConfigurationPage-BbQjzKkQ.mjs.map +1 -0
  36. package/dist/_chunks/{ListViewPage-O8F1pBJo.js → ListViewPage-BtSi8C1l.js} +103 -77
  37. package/dist/_chunks/ListViewPage-BtSi8C1l.js.map +1 -0
  38. package/dist/_chunks/{ListViewPage-HBBnJa8K.mjs → ListViewPage-D4ofkbjR.mjs} +99 -72
  39. package/dist/_chunks/ListViewPage-D4ofkbjR.mjs.map +1 -0
  40. package/dist/_chunks/{NoContentTypePage-CQWChGPw.js → NoContentTypePage-CitJeOq4.js} +2 -2
  41. package/dist/_chunks/{NoContentTypePage-CQWChGPw.js.map → NoContentTypePage-CitJeOq4.js.map} +1 -1
  42. package/dist/_chunks/{NoContentTypePage-B-gIhHWM.mjs → NoContentTypePage-DyUx5mXh.mjs} +2 -2
  43. package/dist/_chunks/{NoContentTypePage-B-gIhHWM.mjs.map → NoContentTypePage-DyUx5mXh.mjs.map} +1 -1
  44. package/dist/_chunks/{NoPermissionsPage-XhOPl8wx.mjs → NoPermissionsPage-DhIiyWkk.mjs} +2 -2
  45. package/dist/_chunks/{NoPermissionsPage-XhOPl8wx.mjs.map → NoPermissionsPage-DhIiyWkk.mjs.map} +1 -1
  46. package/dist/_chunks/{NoPermissionsPage-CY46zxnM.js → NoPermissionsPage-DzgWz0M-.js} +2 -2
  47. package/dist/_chunks/{NoPermissionsPage-CY46zxnM.js.map → NoPermissionsPage-DzgWz0M-.js.map} +1 -1
  48. package/dist/_chunks/Preview-BaYGJ0nb.mjs +293 -0
  49. package/dist/_chunks/Preview-BaYGJ0nb.mjs.map +1 -0
  50. package/dist/_chunks/Preview-DfNx8Ke-.js +311 -0
  51. package/dist/_chunks/Preview-DfNx8Ke-.js.map +1 -0
  52. package/dist/_chunks/{Relations-vFZ6Wasg.mjs → Relations-DM2yUTST.mjs} +76 -42
  53. package/dist/_chunks/Relations-DM2yUTST.mjs.map +1 -0
  54. package/dist/_chunks/{Relations-C4gGfZRv.js → Relations-DuKCaXrv.js} +76 -43
  55. package/dist/_chunks/Relations-DuKCaXrv.js.map +1 -0
  56. package/dist/_chunks/{en-uOUIxfcQ.js → en-BK8Xyl5I.js} +28 -15
  57. package/dist/_chunks/{en-uOUIxfcQ.js.map → en-BK8Xyl5I.js.map} +1 -1
  58. package/dist/_chunks/{en-BrCTWlZv.mjs → en-Dtk_ot79.mjs} +28 -15
  59. package/dist/_chunks/{en-BrCTWlZv.mjs.map → en-Dtk_ot79.mjs.map} +1 -1
  60. package/dist/_chunks/{es-EUonQTon.js → es-9K52xZIr.js} +2 -2
  61. package/dist/_chunks/{ja-CcFe8diO.js.map → es-9K52xZIr.js.map} +1 -1
  62. package/dist/_chunks/{es-CeXiYflN.mjs → es-D34tqjMw.mjs} +2 -2
  63. package/dist/_chunks/{es-CeXiYflN.mjs.map → es-D34tqjMw.mjs.map} +1 -1
  64. package/dist/_chunks/{fr-CD9VFbPM.mjs → fr--pg5jUbt.mjs} +13 -3
  65. package/dist/_chunks/{fr-CD9VFbPM.mjs.map → fr--pg5jUbt.mjs.map} +1 -1
  66. package/dist/_chunks/{fr-B7kGGg3E.js → fr-B2Kyv8Z9.js} +13 -3
  67. package/dist/_chunks/{fr-B7kGGg3E.js.map → fr-B2Kyv8Z9.js.map} +1 -1
  68. package/dist/_chunks/hooks-BAaaKPS_.js.map +1 -1
  69. package/dist/_chunks/{index-5EMXLEM_.js → index-BUWEmX8m.js} +1320 -996
  70. package/dist/_chunks/index-BUWEmX8m.js.map +1 -0
  71. package/dist/_chunks/{index-Dpxg3ctD.mjs → index-DVAIIsOs.mjs} +1338 -1014
  72. package/dist/_chunks/index-DVAIIsOs.mjs.map +1 -0
  73. package/dist/_chunks/{ja-CcFe8diO.js → ja-7sfIbjxE.js} +2 -2
  74. package/dist/_chunks/{es-EUonQTon.js.map → ja-7sfIbjxE.js.map} +1 -1
  75. package/dist/_chunks/{ja-CtsUxOvk.mjs → ja-BHqhDq4V.mjs} +2 -2
  76. package/dist/_chunks/{ja-CtsUxOvk.mjs.map → ja-BHqhDq4V.mjs.map} +1 -1
  77. package/dist/_chunks/{layout-C0INpKap.mjs → layout-Bxsv5mP7.mjs} +9 -8
  78. package/dist/_chunks/layout-Bxsv5mP7.mjs.map +1 -0
  79. package/dist/_chunks/{layout-P3eKO1Qy.js → layout-C3fN7Ejz.js} +10 -10
  80. package/dist/_chunks/layout-C3fN7Ejz.js.map +1 -0
  81. package/dist/_chunks/{objects-gigeqt7s.js → objects-BcXOv6_9.js} +2 -4
  82. package/dist/_chunks/{objects-gigeqt7s.js.map → objects-BcXOv6_9.js.map} +1 -1
  83. package/dist/_chunks/{objects-mKMAmfec.mjs → objects-D6yBsdmx.mjs} +2 -4
  84. package/dist/_chunks/{objects-mKMAmfec.mjs.map → objects-D6yBsdmx.mjs.map} +1 -1
  85. package/dist/_chunks/{relations-B1y0K6LE.js → relations-BPZKAoEY.js} +6 -7
  86. package/dist/_chunks/relations-BPZKAoEY.js.map +1 -0
  87. package/dist/_chunks/{relations-FBRRBWeO.mjs → relations-o3pPhzY4.mjs} +6 -7
  88. package/dist/_chunks/relations-o3pPhzY4.mjs.map +1 -0
  89. package/dist/_chunks/{usePrev-B9w_-eYc.js → useDebounce-CtcjDB3L.js} +14 -1
  90. package/dist/_chunks/useDebounce-CtcjDB3L.js.map +1 -0
  91. package/dist/_chunks/useDebounce-DmuSJIF3.mjs +29 -0
  92. package/dist/_chunks/useDebounce-DmuSJIF3.mjs.map +1 -0
  93. package/dist/_chunks/{useDragAndDrop-J0TUUbR6.js → useDragAndDrop-BMtgCYzL.js} +5 -9
  94. package/dist/_chunks/{useDragAndDrop-J0TUUbR6.js.map → useDragAndDrop-BMtgCYzL.js.map} +1 -1
  95. package/dist/_chunks/{useDragAndDrop-DdHgKsqq.mjs → useDragAndDrop-DJ6jqvZN.mjs} +4 -7
  96. package/dist/_chunks/{useDragAndDrop-DdHgKsqq.mjs.map → useDragAndDrop-DJ6jqvZN.mjs.map} +1 -1
  97. package/dist/admin/index.js +2 -1
  98. package/dist/admin/index.js.map +1 -1
  99. package/dist/admin/index.mjs +5 -4
  100. package/dist/admin/src/content-manager.d.ts +3 -2
  101. package/dist/admin/src/exports.d.ts +1 -1
  102. package/dist/admin/src/history/services/historyVersion.d.ts +1 -1
  103. package/dist/admin/src/hooks/useDocument.d.ts +32 -1
  104. package/dist/admin/src/pages/EditView/EditViewPage.d.ts +9 -1
  105. package/dist/admin/src/pages/EditView/components/DocumentActions.d.ts +1 -1
  106. package/dist/admin/src/pages/EditView/components/DocumentStatus.d.ts +2 -2
  107. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/Blocks/Code.d.ts +7 -0
  108. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/Blocks/utils/prismLanguages.d.ts +49 -0
  109. package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/utils/constants.d.ts +1 -0
  110. package/dist/admin/src/pages/EditView/components/FormInputs/Wysiwyg/EditorLayout.d.ts +2 -2
  111. package/dist/admin/src/pages/EditView/components/FormInputs/Wysiwyg/WysiwygFooter.d.ts +2 -2
  112. package/dist/admin/src/pages/EditView/components/FormInputs/Wysiwyg/WysiwygStyles.d.ts +4 -48
  113. package/dist/admin/src/pages/EditView/components/Header.d.ts +11 -11
  114. package/dist/admin/src/preview/components/PreviewContent.d.ts +2 -0
  115. package/dist/admin/src/preview/components/PreviewHeader.d.ts +2 -0
  116. package/dist/admin/src/preview/components/PreviewSidePanel.d.ts +3 -0
  117. package/dist/admin/src/preview/index.d.ts +4 -0
  118. package/dist/admin/src/preview/pages/Preview.d.ts +11 -0
  119. package/dist/admin/src/preview/routes.d.ts +3 -0
  120. package/dist/admin/src/preview/services/preview.d.ts +3 -0
  121. package/dist/admin/src/router.d.ts +1 -1
  122. package/dist/admin/src/services/api.d.ts +1 -1
  123. package/dist/admin/src/services/components.d.ts +2 -2
  124. package/dist/admin/src/services/contentTypes.d.ts +3 -3
  125. package/dist/admin/src/services/documents.d.ts +19 -20
  126. package/dist/admin/src/services/init.d.ts +1 -1
  127. package/dist/admin/src/services/relations.d.ts +2 -2
  128. package/dist/admin/src/services/uid.d.ts +3 -3
  129. package/dist/admin/src/utils/validation.d.ts +4 -1
  130. package/dist/server/index.js +482 -219
  131. package/dist/server/index.js.map +1 -1
  132. package/dist/server/index.mjs +482 -218
  133. package/dist/server/index.mjs.map +1 -1
  134. package/dist/server/src/bootstrap.d.ts.map +1 -1
  135. package/dist/server/src/controllers/collection-types.d.ts.map +1 -1
  136. package/dist/server/src/controllers/index.d.ts.map +1 -1
  137. package/dist/server/src/controllers/relations.d.ts.map +1 -1
  138. package/dist/server/src/controllers/utils/metadata.d.ts +15 -1
  139. package/dist/server/src/controllers/utils/metadata.d.ts.map +1 -1
  140. package/dist/server/src/history/services/history.d.ts.map +1 -1
  141. package/dist/server/src/history/services/lifecycles.d.ts.map +1 -1
  142. package/dist/server/src/history/services/utils.d.ts +3 -3
  143. package/dist/server/src/history/services/utils.d.ts.map +1 -1
  144. package/dist/server/src/index.d.ts +4 -4
  145. package/dist/server/src/policies/hasPermissions.d.ts.map +1 -1
  146. package/dist/server/src/preview/controllers/index.d.ts +2 -0
  147. package/dist/server/src/preview/controllers/index.d.ts.map +1 -0
  148. package/dist/server/src/preview/controllers/preview.d.ts +13 -0
  149. package/dist/server/src/preview/controllers/preview.d.ts.map +1 -0
  150. package/dist/server/src/preview/controllers/validation/preview.d.ts +6 -0
  151. package/dist/server/src/preview/controllers/validation/preview.d.ts.map +1 -0
  152. package/dist/server/src/preview/index.d.ts +4 -0
  153. package/dist/server/src/preview/index.d.ts.map +1 -0
  154. package/dist/server/src/preview/routes/index.d.ts +8 -0
  155. package/dist/server/src/preview/routes/index.d.ts.map +1 -0
  156. package/dist/server/src/preview/routes/preview.d.ts +4 -0
  157. package/dist/server/src/preview/routes/preview.d.ts.map +1 -0
  158. package/dist/server/src/preview/services/index.d.ts +16 -0
  159. package/dist/server/src/preview/services/index.d.ts.map +1 -0
  160. package/dist/server/src/preview/services/preview-config.d.ts +32 -0
  161. package/dist/server/src/preview/services/preview-config.d.ts.map +1 -0
  162. package/dist/server/src/preview/services/preview.d.ts +12 -0
  163. package/dist/server/src/preview/services/preview.d.ts.map +1 -0
  164. package/dist/server/src/preview/utils.d.ts +19 -0
  165. package/dist/server/src/preview/utils.d.ts.map +1 -0
  166. package/dist/server/src/register.d.ts.map +1 -1
  167. package/dist/server/src/routes/index.d.ts.map +1 -1
  168. package/dist/server/src/services/document-manager.d.ts.map +1 -1
  169. package/dist/server/src/services/document-metadata.d.ts +8 -8
  170. package/dist/server/src/services/document-metadata.d.ts.map +1 -1
  171. package/dist/server/src/services/index.d.ts +4 -4
  172. package/dist/server/src/services/index.d.ts.map +1 -1
  173. package/dist/server/src/services/permission-checker.d.ts.map +1 -1
  174. package/dist/server/src/services/utils/configuration/index.d.ts +2 -2
  175. package/dist/server/src/services/utils/configuration/layouts.d.ts +2 -2
  176. package/dist/server/src/utils/index.d.ts +2 -0
  177. package/dist/server/src/utils/index.d.ts.map +1 -1
  178. package/dist/shared/contracts/collection-types.d.ts +3 -1
  179. package/dist/shared/contracts/collection-types.d.ts.map +1 -1
  180. package/dist/shared/contracts/index.d.ts +1 -0
  181. package/dist/shared/contracts/index.d.ts.map +1 -1
  182. package/dist/shared/contracts/preview.d.ts +27 -0
  183. package/dist/shared/contracts/preview.d.ts.map +1 -0
  184. package/dist/shared/index.js +4 -0
  185. package/dist/shared/index.js.map +1 -1
  186. package/dist/shared/index.mjs +4 -0
  187. package/dist/shared/index.mjs.map +1 -1
  188. package/package.json +17 -15
  189. package/dist/_chunks/EditViewPage-BSVmMpRd.js.map +0 -1
  190. package/dist/_chunks/EditViewPage-C3tIZ8F5.mjs.map +0 -1
  191. package/dist/_chunks/Field-BvuT8cGL.mjs.map +0 -1
  192. package/dist/_chunks/Field-DUCVth4C.js.map +0 -1
  193. package/dist/_chunks/Form-BZmDNVr9.mjs.map +0 -1
  194. package/dist/_chunks/Form-Cpl4W1ak.js.map +0 -1
  195. package/dist/_chunks/History-Cq_Hrzuu.mjs.map +0 -1
  196. package/dist/_chunks/History-D4U2YISB.js.map +0 -1
  197. package/dist/_chunks/ListConfigurationPage-Bny6CdWe.js.map +0 -1
  198. package/dist/_chunks/ListConfigurationPage-W-KQHmBv.mjs.map +0 -1
  199. package/dist/_chunks/ListViewPage-HBBnJa8K.mjs.map +0 -1
  200. package/dist/_chunks/ListViewPage-O8F1pBJo.js.map +0 -1
  201. package/dist/_chunks/Relations-C4gGfZRv.js.map +0 -1
  202. package/dist/_chunks/Relations-vFZ6Wasg.mjs.map +0 -1
  203. package/dist/_chunks/index-5EMXLEM_.js.map +0 -1
  204. package/dist/_chunks/index-Dpxg3ctD.mjs.map +0 -1
  205. package/dist/_chunks/layout-C0INpKap.mjs.map +0 -1
  206. package/dist/_chunks/layout-P3eKO1Qy.js.map +0 -1
  207. package/dist/_chunks/relations-B1y0K6LE.js.map +0 -1
  208. package/dist/_chunks/relations-FBRRBWeO.mjs.map +0 -1
  209. package/dist/_chunks/usePrev-B9w_-eYc.js.map +0 -1
  210. package/dist/_chunks/usePrev-DH6iah0A.mjs +0 -16
  211. package/dist/_chunks/usePrev-DH6iah0A.mjs.map +0 -1
  212. package/strapi-server.js +0 -3
@@ -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$1 = (name) => {
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$1("permission-checker").create({
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$1("permission-checker").create({
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$1 = {
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] = { populate };
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] = { populate: getDeepPopulate2(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 locale = params.query.locale || await serviceUtils.getDefaultLocale();
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$1("permission-checker").create({
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({ where: { id: userToPopulate.id } });
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$1("permission-checker").create({
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.toISOString()
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$1 = {
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$1 = {
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$1,
695
- services: services$1,
696
- routes: routes$1
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$1("field-sizes").setCustomFieldInputSizes();
718
- await getService$1("components").syncConfigurations();
719
- await getService$1("content-types").syncConfigurations();
720
- await getService$1("permission").registerPermissions();
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$1("content-types").findContentType(
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$1("document-metadata");
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$1("document-manager");
1659
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
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$1("document-manager");
1680
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
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$1("populate-builder")(model).populateFromQuery(permissionQuery).build();
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$1("document-metadata");
1717
- const documentManager2 = getService$1("document-manager");
1718
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
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$1("populate-builder")(model).populateFromQuery(permissionQuery).populateDeep(1).countRelations({ toOne: false, toMany: true }).build();
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$1("document-manager");
1753
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
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$1("populate-builder")(model).populateFromQuery(permissionQuery).populateDeep(Infinity).countRelations().build();
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$1("permission-checker").create({ userAbility, model });
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$1("permission-checker").create({ userAbility, model });
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$1("document-manager");
1820
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
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$1("populate-builder")(model).populateFromQuery(permissionQuery).build();
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$1("document-manager");
1865
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
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$1("populate-builder")(model).populateFromQuery(permissionQuery).build();
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$1("document-manager");
1893
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
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$1("populate-builder")(model).populateFromQuery(permissionQuery).populateDeep(Infinity).countRelations().build();
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
- document = await documentManager2.findOne(id, model, { populate, locale });
1912
- if (!document) {
2140
+ const documentExists = documentManager2.exists(model, id);
2141
+ if (!documentExists) {
1913
2142
  throw new strapiUtils.errors.NotFoundError("Document not found");
1914
2143
  }
1915
- if (permissionChecker2.can.update(document)) {
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$1("document-manager");
1942
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
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$1("populate-builder")(model).populateFromQuery(permissionQuery).populateDeep(Infinity).countRelations().build();
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$1("document-manager");
1973
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
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$1("document-manager");
2001
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
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$1("populate-builder")(model).populateFromQuery(permissionQuery).build();
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$1("document-manager");
2041
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
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$1("populate-builder")(model).populateFromQuery(permissionQuery).build();
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$1("document-manager");
2072
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
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$1("populate-builder")(model).populateFromQuery(permissionQuery).build();
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$1("document-manager");
2099
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
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$1("populate-builder")(model).populateFromQuery(permissionQuery).build();
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$1("document-manager");
2124
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
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$1("components").findAllComponents();
2149
- const { toDto } = getService$1("data-mapper");
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$1("components");
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$1("components");
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$1("content-types").findContentTypesByKind(kind);
2206
- const { toDto } = getService$1("data-mapper");
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$1("content-types");
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$1("content-types");
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$1("content-types");
2247
- const metricsService = getService$1("metrics");
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$1("permission").canConfigureContentType({ userAbility, contentType })) {
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$1("data-mapper");
2286
- const { findAllComponents } = getService$1("components");
2287
- const { getAllFieldSizes } = getService$1("field-sizes");
2288
- const { findAllContentTypes } = getService$1("content-types");
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$1("permission-checker").create({
2561
+ const permissionChecker2 = getService$2("permission-checker").create({
2325
2562
  userAbility,
2326
2563
  model: model.uid
2327
2564
  });
2328
- if (!isListable(model, mainField)) {
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 (permissionChecker2.cannot.read(null, mainField)) {
2332
- if (model.uid === "plugin::users-permissions.role") {
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 (uid2, relations2) => {
2346
- if (!strapiUtils.contentTypes.hasDraftAndPublish(strapi.contentTypes[uid2])) {
2575
+ const addStatusToRelations = async (targetUid, relations2) => {
2576
+ if (!strapiUtils.contentTypes.hasDraftAndPublish(strapi.getModel(targetUid))) {
2347
2577
  return relations2;
2348
2578
  }
2349
- const documentMetadata2 = getService$1("document-metadata");
2350
- const documentsAvailableStatus = await documentMetadata2.getManyAvailableStatus(uid2, relations2);
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 = documentsAvailableStatus.filter(
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: validatedLocale,
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$1("permission-checker").create({
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$1("populate-builder")(model).populateFromQuery(permissionQuery).build();
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$1("components").findConfiguration(sourceSchema) : await getService$1("content-types").findConfiguration(sourceSchema);
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$1("permission-checker").create({
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
- if (status) {
2542
- where[`${alias}.published_at`] = getPublishedAtClause(status, targetUid);
2780
+ const publishedAt = getPublishedAtClause(status, targetUid);
2781
+ if (!fp.isEmpty(publishedAt)) {
2782
+ where[`${alias}.published_at`] = publishedAt;
2543
2783
  }
2544
- if (filterByLocale) {
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 res = await strapi.db.query(targetUid).findPage(strapi.get("query-params").transform(targetUid, queryParams));
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
- source: {
2580
- schema: { uid: sourceUid }
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 permissionQuery = await getService$1("permission-checker").create({ userAbility, model: targetUid }).sanitizedQuery.read({ fields: fieldsToSelect });
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$1("populate-builder")(model).populateFromQuery(query).populateDeep(Infinity).countRelations().build();
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$1("document-manager");
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$1("document-manager");
2628
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
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$1("permission-checker").create({ userAbility, model });
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
- { id: document.documentId, locale, publishedAt: null },
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$1("permission-checker").create({ userAbility, model });
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$1("document-manager");
2713
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
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$1("document-manager");
2742
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
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$1("document-manager");
2771
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
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$1("document-manager");
2806
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
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$1("document-manager");
2830
- const permissionChecker2 = getService$1("permission-checker").create({ userAbility, model });
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$1("uid");
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$1("uid");
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$1("content-types").findContentType(targetModel);
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$1("field-sizes");
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$1("field-sizes");
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
- continue;
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$1("data-mapper");
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$1("data-mapper");
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$1("data-mapper");
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$1("data-mapper");
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$1("data-mapper");
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$1("data-mapper");
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$1("components").findComponentsConfigurations(contentType);
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 toSubject = (entity) => entity ? permissionsManager.toSubject(entity, model) : model;
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
- return userAbility.can(action, toSubject(entity), field);
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
- return userAbility.cannot(action, toSubject(entity), field);
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$1("content-types").findDisplayedContentTypes();
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$1("populate-builder")(uid2).populateDeep(Infinity).countRelations().build();
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
- delete versionsByLocale[version.locale];
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
- return CONTENT_MANAGER_STATUS.PUBLISHED;
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 {