@webiny/api-headless-cms 0.0.0-unstable.fcdad0bc61 → 0.0.0-unstable.fdd9228b5d

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 (988) hide show
  1. package/constants.d.ts +44 -0
  2. package/constants.js +70 -0
  3. package/constants.js.map +1 -0
  4. package/context.d.ts +5 -2
  5. package/context.js +134 -30
  6. package/context.js.map +1 -1
  7. package/crud/AccessControl/AccessControl.d.ts +98 -0
  8. package/crud/AccessControl/AccessControl.js +542 -0
  9. package/crud/AccessControl/AccessControl.js.map +1 -0
  10. package/crud/AccessControl/README.md +47 -0
  11. package/crud/AccessControl/groups-own.png +0 -0
  12. package/crud/AccessControl/models-own.png +0 -0
  13. package/crud/contentEntry/abstractions/IDeleteEntry.d.ts +4 -0
  14. package/crud/contentEntry/abstractions/IDeleteEntry.js +7 -0
  15. package/crud/contentEntry/abstractions/IDeleteEntry.js.map +1 -0
  16. package/crud/contentEntry/abstractions/IDeleteEntryOperation.d.ts +4 -0
  17. package/crud/contentEntry/abstractions/IDeleteEntryOperation.js +7 -0
  18. package/crud/contentEntry/abstractions/IDeleteEntryOperation.js.map +1 -0
  19. package/crud/contentEntry/abstractions/IGetEntriesByIds.d.ts +4 -0
  20. package/crud/contentEntry/abstractions/IGetEntriesByIds.js +7 -0
  21. package/crud/contentEntry/abstractions/IGetEntriesByIds.js.map +1 -0
  22. package/crud/contentEntry/abstractions/IGetEntry.d.ts +4 -0
  23. package/crud/contentEntry/abstractions/IGetEntry.js +7 -0
  24. package/crud/contentEntry/abstractions/IGetEntry.js.map +1 -0
  25. package/crud/contentEntry/abstractions/IGetLatestEntriesByIds.d.ts +4 -0
  26. package/crud/contentEntry/abstractions/IGetLatestEntriesByIds.js +7 -0
  27. package/crud/contentEntry/abstractions/IGetLatestEntriesByIds.js.map +1 -0
  28. package/crud/contentEntry/abstractions/IGetLatestRevisionByEntryId.d.ts +4 -0
  29. package/crud/contentEntry/abstractions/IGetLatestRevisionByEntryId.js +7 -0
  30. package/crud/contentEntry/abstractions/IGetLatestRevisionByEntryId.js.map +1 -0
  31. package/crud/contentEntry/abstractions/IGetPreviousRevisionByEntryId.d.ts +4 -0
  32. package/crud/contentEntry/abstractions/IGetPreviousRevisionByEntryId.js +7 -0
  33. package/crud/contentEntry/abstractions/IGetPreviousRevisionByEntryId.js.map +1 -0
  34. package/crud/contentEntry/abstractions/IGetPublishedEntriesByIds.d.ts +4 -0
  35. package/crud/contentEntry/abstractions/IGetPublishedEntriesByIds.js +7 -0
  36. package/crud/contentEntry/abstractions/IGetPublishedEntriesByIds.js.map +1 -0
  37. package/crud/contentEntry/abstractions/IGetPublishedRevisionByEntryId.d.ts +4 -0
  38. package/crud/contentEntry/abstractions/IGetPublishedRevisionByEntryId.js +7 -0
  39. package/crud/contentEntry/abstractions/IGetPublishedRevisionByEntryId.js.map +1 -0
  40. package/crud/contentEntry/abstractions/IGetRevisionById.d.ts +4 -0
  41. package/crud/contentEntry/abstractions/IGetRevisionById.js +7 -0
  42. package/crud/contentEntry/abstractions/IGetRevisionById.js.map +1 -0
  43. package/crud/contentEntry/abstractions/IGetRevisionsByEntryId.d.ts +4 -0
  44. package/crud/contentEntry/abstractions/IGetRevisionsByEntryId.js +7 -0
  45. package/crud/contentEntry/abstractions/IGetRevisionsByEntryId.js.map +1 -0
  46. package/crud/contentEntry/abstractions/IListEntries.d.ts +4 -0
  47. package/crud/contentEntry/abstractions/IListEntries.js +7 -0
  48. package/crud/contentEntry/abstractions/IListEntries.js.map +1 -0
  49. package/crud/contentEntry/abstractions/IListEntriesOperation.d.ts +4 -0
  50. package/crud/contentEntry/abstractions/IListEntriesOperation.js +7 -0
  51. package/crud/contentEntry/abstractions/IListEntriesOperation.js.map +1 -0
  52. package/crud/contentEntry/abstractions/IMoveEntryToBinOperation.d.ts +4 -0
  53. package/crud/contentEntry/abstractions/IMoveEntryToBinOperation.js +7 -0
  54. package/crud/contentEntry/abstractions/IMoveEntryToBinOperation.js.map +1 -0
  55. package/crud/contentEntry/abstractions/IRestoreEntryFromBin.d.ts +4 -0
  56. package/crud/contentEntry/abstractions/IRestoreEntryFromBin.js +7 -0
  57. package/crud/contentEntry/abstractions/IRestoreEntryFromBin.js.map +1 -0
  58. package/crud/contentEntry/abstractions/IRestoreEntryFromBinOperation.d.ts +4 -0
  59. package/crud/contentEntry/abstractions/IRestoreEntryFromBinOperation.js +7 -0
  60. package/crud/contentEntry/abstractions/IRestoreEntryFromBinOperation.js.map +1 -0
  61. package/crud/contentEntry/abstractions/index.d.ts +16 -0
  62. package/crud/contentEntry/abstractions/index.js +183 -0
  63. package/crud/contentEntry/abstractions/index.js.map +1 -0
  64. package/crud/contentEntry/afterDelete.d.ts +6 -2
  65. package/crud/contentEntry/afterDelete.js +16 -5
  66. package/crud/contentEntry/afterDelete.js.map +1 -1
  67. package/crud/contentEntry/beforeCreate.d.ts +2 -2
  68. package/crud/contentEntry/beforeCreate.js +2 -3
  69. package/crud/contentEntry/beforeCreate.js.map +1 -1
  70. package/crud/contentEntry/beforeUpdate.d.ts +2 -2
  71. package/crud/contentEntry/beforeUpdate.js +2 -3
  72. package/crud/contentEntry/beforeUpdate.js.map +1 -1
  73. package/crud/contentEntry/entryDataFactories/createEntryData.d.ts +20 -0
  74. package/crud/contentEntry/entryDataFactories/createEntryData.js +254 -0
  75. package/crud/contentEntry/entryDataFactories/createEntryData.js.map +1 -0
  76. package/crud/contentEntry/entryDataFactories/createEntryRevisionFromData.d.ts +23 -0
  77. package/crud/contentEntry/entryDataFactories/createEntryRevisionFromData.js +157 -0
  78. package/crud/contentEntry/entryDataFactories/createEntryRevisionFromData.js.map +1 -0
  79. package/crud/contentEntry/entryDataFactories/createPublishEntryData.d.ts +13 -0
  80. package/crud/contentEntry/entryDataFactories/createPublishEntryData.js +63 -0
  81. package/crud/contentEntry/entryDataFactories/createPublishEntryData.js.map +1 -0
  82. package/crud/contentEntry/entryDataFactories/createRepublishEntryData.d.ts +12 -0
  83. package/crud/contentEntry/entryDataFactories/createRepublishEntryData.js +59 -0
  84. package/crud/contentEntry/entryDataFactories/createRepublishEntryData.js.map +1 -0
  85. package/crud/contentEntry/entryDataFactories/createUnpublishEntryData.d.ts +12 -0
  86. package/crud/contentEntry/entryDataFactories/createUnpublishEntryData.js +40 -0
  87. package/crud/contentEntry/entryDataFactories/createUnpublishEntryData.js.map +1 -0
  88. package/crud/contentEntry/entryDataFactories/createUpdateEntryData.d.ts +20 -0
  89. package/crud/contentEntry/entryDataFactories/createUpdateEntryData.js +130 -0
  90. package/crud/contentEntry/entryDataFactories/createUpdateEntryData.js.map +1 -0
  91. package/crud/contentEntry/entryDataFactories/index.d.ts +8 -0
  92. package/crud/contentEntry/entryDataFactories/index.js +95 -0
  93. package/crud/contentEntry/entryDataFactories/index.js.map +1 -0
  94. package/crud/contentEntry/entryDataFactories/mapAndCleanUpdatedInputData.d.ts +5 -0
  95. package/crud/contentEntry/entryDataFactories/mapAndCleanUpdatedInputData.js +36 -0
  96. package/crud/contentEntry/entryDataFactories/mapAndCleanUpdatedInputData.js.map +1 -0
  97. package/crud/contentEntry/entryDataFactories/statuses.d.ts +4 -0
  98. package/crud/contentEntry/entryDataFactories/statuses.js +12 -0
  99. package/crud/contentEntry/entryDataFactories/statuses.js.map +1 -0
  100. package/crud/contentEntry/entryDataValidation.d.ts +5 -3
  101. package/crud/contentEntry/entryDataValidation.js +222 -83
  102. package/crud/contentEntry/entryDataValidation.js.map +1 -1
  103. package/crud/contentEntry/markLockedFields.d.ts +1 -1
  104. package/crud/contentEntry/markLockedFields.js +34 -37
  105. package/crud/contentEntry/markLockedFields.js.map +1 -1
  106. package/crud/contentEntry/referenceFieldsMapping.d.ts +7 -1
  107. package/crud/contentEntry/referenceFieldsMapping.js +146 -146
  108. package/crud/contentEntry/referenceFieldsMapping.js.map +1 -1
  109. package/crud/contentEntry/searchableFields.d.ts +9 -0
  110. package/crud/contentEntry/searchableFields.js +73 -0
  111. package/crud/contentEntry/searchableFields.js.map +1 -0
  112. package/crud/contentEntry/useCases/DeleteEntry/DeleteEntry.d.ts +10 -0
  113. package/crud/contentEntry/useCases/DeleteEntry/DeleteEntry.js +58 -0
  114. package/crud/contentEntry/useCases/DeleteEntry/DeleteEntry.js.map +1 -0
  115. package/crud/contentEntry/useCases/DeleteEntry/DeleteEntryOperation.d.ts +7 -0
  116. package/crud/contentEntry/useCases/DeleteEntry/DeleteEntryOperation.js +17 -0
  117. package/crud/contentEntry/useCases/DeleteEntry/DeleteEntryOperation.js.map +1 -0
  118. package/crud/contentEntry/useCases/DeleteEntry/DeleteEntryOperationWithEvents.d.ts +9 -0
  119. package/crud/contentEntry/useCases/DeleteEntry/DeleteEntryOperationWithEvents.js +45 -0
  120. package/crud/contentEntry/useCases/DeleteEntry/DeleteEntryOperationWithEvents.js.map +1 -0
  121. package/crud/contentEntry/useCases/DeleteEntry/DeleteEntrySecure.d.ts +9 -0
  122. package/crud/contentEntry/useCases/DeleteEntry/DeleteEntrySecure.js +22 -0
  123. package/crud/contentEntry/useCases/DeleteEntry/DeleteEntrySecure.js.map +1 -0
  124. package/crud/contentEntry/useCases/DeleteEntry/MoveEntryToBin.d.ts +10 -0
  125. package/crud/contentEntry/useCases/DeleteEntry/MoveEntryToBin.js +33 -0
  126. package/crud/contentEntry/useCases/DeleteEntry/MoveEntryToBin.js.map +1 -0
  127. package/crud/contentEntry/useCases/DeleteEntry/MoveEntryToBinOperation.d.ts +7 -0
  128. package/crud/contentEntry/useCases/DeleteEntry/MoveEntryToBinOperation.js +17 -0
  129. package/crud/contentEntry/useCases/DeleteEntry/MoveEntryToBinOperation.js.map +1 -0
  130. package/crud/contentEntry/useCases/DeleteEntry/MoveEntryToBinOperationWithEvents.d.ts +9 -0
  131. package/crud/contentEntry/useCases/DeleteEntry/MoveEntryToBinOperationWithEvents.js +45 -0
  132. package/crud/contentEntry/useCases/DeleteEntry/MoveEntryToBinOperationWithEvents.js.map +1 -0
  133. package/crud/contentEntry/useCases/DeleteEntry/TransformEntryDelete.d.ts +6 -0
  134. package/crud/contentEntry/useCases/DeleteEntry/TransformEntryDelete.js +21 -0
  135. package/crud/contentEntry/useCases/DeleteEntry/TransformEntryDelete.js.map +1 -0
  136. package/crud/contentEntry/useCases/DeleteEntry/TransformEntryMoveToBin.d.ts +9 -0
  137. package/crud/contentEntry/useCases/DeleteEntry/TransformEntryMoveToBin.js +54 -0
  138. package/crud/contentEntry/useCases/DeleteEntry/TransformEntryMoveToBin.js.map +1 -0
  139. package/crud/contentEntry/useCases/DeleteEntry/index.d.ts +28 -0
  140. package/crud/contentEntry/useCases/DeleteEntry/index.js +42 -0
  141. package/crud/contentEntry/useCases/DeleteEntry/index.js.map +1 -0
  142. package/crud/contentEntry/useCases/GetEntriesByIds/GetEntriesByIds.d.ts +9 -0
  143. package/crud/contentEntry/useCases/GetEntriesByIds/GetEntriesByIds.js +21 -0
  144. package/crud/contentEntry/useCases/GetEntriesByIds/GetEntriesByIds.js.map +1 -0
  145. package/crud/contentEntry/useCases/GetEntriesByIds/GetEntriesByIdsNotDeleted.d.ts +7 -0
  146. package/crud/contentEntry/useCases/GetEntriesByIds/GetEntriesByIdsNotDeleted.js +18 -0
  147. package/crud/contentEntry/useCases/GetEntriesByIds/GetEntriesByIdsNotDeleted.js.map +1 -0
  148. package/crud/contentEntry/useCases/GetEntriesByIds/GetEntriesByIdsSecure.d.ts +9 -0
  149. package/crud/contentEntry/useCases/GetEntriesByIds/GetEntriesByIdsSecure.js +28 -0
  150. package/crud/contentEntry/useCases/GetEntriesByIds/GetEntriesByIdsSecure.js.map +1 -0
  151. package/crud/contentEntry/useCases/GetEntriesByIds/index.d.ts +13 -0
  152. package/crud/contentEntry/useCases/GetEntriesByIds/index.js +20 -0
  153. package/crud/contentEntry/useCases/GetEntriesByIds/index.js.map +1 -0
  154. package/crud/contentEntry/useCases/GetLatestEntriesByIds/GetLatestEntriesByIds.d.ts +9 -0
  155. package/crud/contentEntry/useCases/GetLatestEntriesByIds/GetLatestEntriesByIds.js +21 -0
  156. package/crud/contentEntry/useCases/GetLatestEntriesByIds/GetLatestEntriesByIds.js.map +1 -0
  157. package/crud/contentEntry/useCases/GetLatestEntriesByIds/GetLatestEntriesByIdsNotDeleted.d.ts +7 -0
  158. package/crud/contentEntry/useCases/GetLatestEntriesByIds/GetLatestEntriesByIdsNotDeleted.js +18 -0
  159. package/crud/contentEntry/useCases/GetLatestEntriesByIds/GetLatestEntriesByIdsNotDeleted.js.map +1 -0
  160. package/crud/contentEntry/useCases/GetLatestEntriesByIds/GetLatestEntriesByIdsSecure.d.ts +9 -0
  161. package/crud/contentEntry/useCases/GetLatestEntriesByIds/GetLatestEntriesByIdsSecure.js +28 -0
  162. package/crud/contentEntry/useCases/GetLatestEntriesByIds/GetLatestEntriesByIdsSecure.js.map +1 -0
  163. package/crud/contentEntry/useCases/GetLatestEntriesByIds/index.d.ts +13 -0
  164. package/crud/contentEntry/useCases/GetLatestEntriesByIds/index.js +20 -0
  165. package/crud/contentEntry/useCases/GetLatestEntriesByIds/index.js.map +1 -0
  166. package/crud/contentEntry/useCases/GetLatestRevisionByEntryId/GetLatestRevisionByEntryId.d.ts +9 -0
  167. package/crud/contentEntry/useCases/GetLatestRevisionByEntryId/GetLatestRevisionByEntryId.js +22 -0
  168. package/crud/contentEntry/useCases/GetLatestRevisionByEntryId/GetLatestRevisionByEntryId.js.map +1 -0
  169. package/crud/contentEntry/useCases/GetLatestRevisionByEntryId/GetLatestRevisionByEntryIdDeleted.d.ts +7 -0
  170. package/crud/contentEntry/useCases/GetLatestRevisionByEntryId/GetLatestRevisionByEntryIdDeleted.js +21 -0
  171. package/crud/contentEntry/useCases/GetLatestRevisionByEntryId/GetLatestRevisionByEntryIdDeleted.js.map +1 -0
  172. package/crud/contentEntry/useCases/GetLatestRevisionByEntryId/GetLatestRevisionByEntryIdNotDeleted.d.ts +7 -0
  173. package/crud/contentEntry/useCases/GetLatestRevisionByEntryId/GetLatestRevisionByEntryIdNotDeleted.js +21 -0
  174. package/crud/contentEntry/useCases/GetLatestRevisionByEntryId/GetLatestRevisionByEntryIdNotDeleted.js.map +1 -0
  175. package/crud/contentEntry/useCases/GetLatestRevisionByEntryId/index.d.ts +15 -0
  176. package/crud/contentEntry/useCases/GetLatestRevisionByEntryId/index.js +22 -0
  177. package/crud/contentEntry/useCases/GetLatestRevisionByEntryId/index.js.map +1 -0
  178. package/crud/contentEntry/useCases/GetPreviousRevisionByEntryId/GetPreviousRevisionByEntryId.d.ts +9 -0
  179. package/crud/contentEntry/useCases/GetPreviousRevisionByEntryId/GetPreviousRevisionByEntryId.js +22 -0
  180. package/crud/contentEntry/useCases/GetPreviousRevisionByEntryId/GetPreviousRevisionByEntryId.js.map +1 -0
  181. package/crud/contentEntry/useCases/GetPreviousRevisionByEntryId/GetPreviousRevisionByEntryIdNotDeleted.d.ts +7 -0
  182. package/crud/contentEntry/useCases/GetPreviousRevisionByEntryId/GetPreviousRevisionByEntryIdNotDeleted.js +21 -0
  183. package/crud/contentEntry/useCases/GetPreviousRevisionByEntryId/GetPreviousRevisionByEntryIdNotDeleted.js.map +1 -0
  184. package/crud/contentEntry/useCases/GetPreviousRevisionByEntryId/index.d.ts +11 -0
  185. package/crud/contentEntry/useCases/GetPreviousRevisionByEntryId/index.js +18 -0
  186. package/crud/contentEntry/useCases/GetPreviousRevisionByEntryId/index.js.map +1 -0
  187. package/crud/contentEntry/useCases/GetPublishedEntriesByIds/GetPublishedEntriesByIds.d.ts +9 -0
  188. package/crud/contentEntry/useCases/GetPublishedEntriesByIds/GetPublishedEntriesByIds.js +21 -0
  189. package/crud/contentEntry/useCases/GetPublishedEntriesByIds/GetPublishedEntriesByIds.js.map +1 -0
  190. package/crud/contentEntry/useCases/GetPublishedEntriesByIds/GetPublishedEntriesByIdsNotDeleted.d.ts +7 -0
  191. package/crud/contentEntry/useCases/GetPublishedEntriesByIds/GetPublishedEntriesByIdsNotDeleted.js +18 -0
  192. package/crud/contentEntry/useCases/GetPublishedEntriesByIds/GetPublishedEntriesByIdsNotDeleted.js.map +1 -0
  193. package/crud/contentEntry/useCases/GetPublishedEntriesByIds/GetPublishedEntriesByIdsSecure.d.ts +9 -0
  194. package/crud/contentEntry/useCases/GetPublishedEntriesByIds/GetPublishedEntriesByIdsSecure.js +28 -0
  195. package/crud/contentEntry/useCases/GetPublishedEntriesByIds/GetPublishedEntriesByIdsSecure.js.map +1 -0
  196. package/crud/contentEntry/useCases/GetPublishedEntriesByIds/index.d.ts +13 -0
  197. package/crud/contentEntry/useCases/GetPublishedEntriesByIds/index.js +20 -0
  198. package/crud/contentEntry/useCases/GetPublishedEntriesByIds/index.js.map +1 -0
  199. package/crud/contentEntry/useCases/GetPublishedRevisionByEntryId/GetPublishedRevisionByEntryId.d.ts +9 -0
  200. package/crud/contentEntry/useCases/GetPublishedRevisionByEntryId/GetPublishedRevisionByEntryId.js +22 -0
  201. package/crud/contentEntry/useCases/GetPublishedRevisionByEntryId/GetPublishedRevisionByEntryId.js.map +1 -0
  202. package/crud/contentEntry/useCases/GetPublishedRevisionByEntryId/GetPublishedRevisionByEntryIdNotDeleted.d.ts +7 -0
  203. package/crud/contentEntry/useCases/GetPublishedRevisionByEntryId/GetPublishedRevisionByEntryIdNotDeleted.js +21 -0
  204. package/crud/contentEntry/useCases/GetPublishedRevisionByEntryId/GetPublishedRevisionByEntryIdNotDeleted.js.map +1 -0
  205. package/crud/contentEntry/useCases/GetPublishedRevisionByEntryId/index.d.ts +11 -0
  206. package/crud/contentEntry/useCases/GetPublishedRevisionByEntryId/index.js +18 -0
  207. package/crud/contentEntry/useCases/GetPublishedRevisionByEntryId/index.js.map +1 -0
  208. package/crud/contentEntry/useCases/GetRevisionById/GetRevisionById.d.ts +9 -0
  209. package/crud/contentEntry/useCases/GetRevisionById/GetRevisionById.js +22 -0
  210. package/crud/contentEntry/useCases/GetRevisionById/GetRevisionById.js.map +1 -0
  211. package/crud/contentEntry/useCases/GetRevisionById/GetRevisionByIdNotDeleted.d.ts +7 -0
  212. package/crud/contentEntry/useCases/GetRevisionById/GetRevisionByIdNotDeleted.js +21 -0
  213. package/crud/contentEntry/useCases/GetRevisionById/GetRevisionByIdNotDeleted.js.map +1 -0
  214. package/crud/contentEntry/useCases/GetRevisionById/index.d.ts +11 -0
  215. package/crud/contentEntry/useCases/GetRevisionById/index.js +18 -0
  216. package/crud/contentEntry/useCases/GetRevisionById/index.js.map +1 -0
  217. package/crud/contentEntry/useCases/GetRevisionsByEntryId/GetRevisionsByEntryId.d.ts +9 -0
  218. package/crud/contentEntry/useCases/GetRevisionsByEntryId/GetRevisionsByEntryId.js +21 -0
  219. package/crud/contentEntry/useCases/GetRevisionsByEntryId/GetRevisionsByEntryId.js.map +1 -0
  220. package/crud/contentEntry/useCases/GetRevisionsByEntryId/GetRevisionsByEntryIdNotDeleted.d.ts +7 -0
  221. package/crud/contentEntry/useCases/GetRevisionsByEntryId/GetRevisionsByEntryIdNotDeleted.js +18 -0
  222. package/crud/contentEntry/useCases/GetRevisionsByEntryId/GetRevisionsByEntryIdNotDeleted.js.map +1 -0
  223. package/crud/contentEntry/useCases/GetRevisionsByEntryId/index.d.ts +13 -0
  224. package/crud/contentEntry/useCases/GetRevisionsByEntryId/index.js +18 -0
  225. package/crud/contentEntry/useCases/GetRevisionsByEntryId/index.js.map +1 -0
  226. package/crud/contentEntry/useCases/ListEntries/GetEntry.d.ts +7 -0
  227. package/crud/contentEntry/useCases/ListEntries/GetEntry.js +29 -0
  228. package/crud/contentEntry/useCases/ListEntries/GetEntry.js.map +1 -0
  229. package/crud/contentEntry/useCases/ListEntries/GetEntrySecure.d.ts +11 -0
  230. package/crud/contentEntry/useCases/ListEntries/GetEntrySecure.js +38 -0
  231. package/crud/contentEntry/useCases/ListEntries/GetEntrySecure.js.map +1 -0
  232. package/crud/contentEntry/useCases/ListEntries/ListEntries.d.ts +7 -0
  233. package/crud/contentEntry/useCases/ListEntries/ListEntries.js +62 -0
  234. package/crud/contentEntry/useCases/ListEntries/ListEntries.js.map +1 -0
  235. package/crud/contentEntry/useCases/ListEntries/ListEntriesOperation.d.ts +14 -0
  236. package/crud/contentEntry/useCases/ListEntries/ListEntriesOperation.js +24 -0
  237. package/crud/contentEntry/useCases/ListEntries/ListEntriesOperation.js.map +1 -0
  238. package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationDeleted.d.ts +7 -0
  239. package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationDeleted.js +24 -0
  240. package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationDeleted.js.map +1 -0
  241. package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationLatest.d.ts +7 -0
  242. package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationLatest.js +25 -0
  243. package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationLatest.js.map +1 -0
  244. package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationNotDeleted.d.ts +7 -0
  245. package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationNotDeleted.js +24 -0
  246. package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationNotDeleted.js.map +1 -0
  247. package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationPublished.d.ts +7 -0
  248. package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationPublished.js +24 -0
  249. package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationPublished.js.map +1 -0
  250. package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationWithEvents.d.ts +9 -0
  251. package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationWithEvents.js +22 -0
  252. package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationWithEvents.js.map +1 -0
  253. package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationWithSearchableFields.d.ts +8 -0
  254. package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationWithSearchableFields.js +27 -0
  255. package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationWithSearchableFields.js.map +1 -0
  256. package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationWithSort.d.ts +8 -0
  257. package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationWithSort.js +26 -0
  258. package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationWithSort.js.map +1 -0
  259. package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationWithStatusCheck.d.ts +7 -0
  260. package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationWithStatusCheck.js +36 -0
  261. package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationWithStatusCheck.js.map +1 -0
  262. package/crud/contentEntry/useCases/ListEntries/ListEntriesSecure.d.ts +11 -0
  263. package/crud/contentEntry/useCases/ListEntries/ListEntriesSecure.js +41 -0
  264. package/crud/contentEntry/useCases/ListEntries/ListEntriesSecure.js.map +1 -0
  265. package/crud/contentEntry/useCases/ListEntries/index.d.ts +26 -0
  266. package/crud/contentEntry/useCases/ListEntries/index.js +61 -0
  267. package/crud/contentEntry/useCases/ListEntries/index.js.map +1 -0
  268. package/crud/contentEntry/useCases/RestoreEntryFromBin/RestoreEntryFromBin.d.ts +10 -0
  269. package/crud/contentEntry/useCases/RestoreEntryFromBin/RestoreEntryFromBin.js +37 -0
  270. package/crud/contentEntry/useCases/RestoreEntryFromBin/RestoreEntryFromBin.js.map +1 -0
  271. package/crud/contentEntry/useCases/RestoreEntryFromBin/RestoreEntryFromBinOperation.d.ts +9 -0
  272. package/crud/contentEntry/useCases/RestoreEntryFromBin/RestoreEntryFromBinOperation.js +19 -0
  273. package/crud/contentEntry/useCases/RestoreEntryFromBin/RestoreEntryFromBinOperation.js.map +1 -0
  274. package/crud/contentEntry/useCases/RestoreEntryFromBin/RestoreEntryFromBinOperationWithEvents.d.ts +9 -0
  275. package/crud/contentEntry/useCases/RestoreEntryFromBin/RestoreEntryFromBinOperationWithEvents.js +42 -0
  276. package/crud/contentEntry/useCases/RestoreEntryFromBin/RestoreEntryFromBinOperationWithEvents.js.map +1 -0
  277. package/crud/contentEntry/useCases/RestoreEntryFromBin/RestoreEntryFromBinSecure.d.ts +9 -0
  278. package/crud/contentEntry/useCases/RestoreEntryFromBin/RestoreEntryFromBinSecure.js +22 -0
  279. package/crud/contentEntry/useCases/RestoreEntryFromBin/RestoreEntryFromBinSecure.js.map +1 -0
  280. package/crud/contentEntry/useCases/RestoreEntryFromBin/TransformEntryRestoreFromBin.d.ts +9 -0
  281. package/crud/contentEntry/useCases/RestoreEntryFromBin/TransformEntryRestoreFromBin.js +53 -0
  282. package/crud/contentEntry/useCases/RestoreEntryFromBin/TransformEntryRestoreFromBin.js.map +1 -0
  283. package/crud/contentEntry/useCases/RestoreEntryFromBin/index.d.ts +25 -0
  284. package/crud/contentEntry/useCases/RestoreEntryFromBin/index.js +24 -0
  285. package/crud/contentEntry/useCases/RestoreEntryFromBin/index.js.map +1 -0
  286. package/crud/contentEntry/useCases/index.d.ts +11 -0
  287. package/crud/contentEntry/useCases/index.js +128 -0
  288. package/crud/contentEntry/useCases/index.js.map +1 -0
  289. package/crud/contentEntry.crud.d.ts +9 -7
  290. package/crud/contentEntry.crud.js +1092 -1094
  291. package/crud/contentEntry.crud.js.map +1 -1
  292. package/crud/contentModel/beforeCreate.d.ts +3 -4
  293. package/crud/contentModel/beforeCreate.js +53 -117
  294. package/crud/contentModel/beforeCreate.js.map +1 -1
  295. package/crud/contentModel/beforeDelete.d.ts +3 -5
  296. package/crud/contentModel/beforeDelete.js +51 -29
  297. package/crud/contentModel/beforeDelete.js.map +1 -1
  298. package/crud/contentModel/beforeUpdate.d.ts +3 -5
  299. package/crud/contentModel/beforeUpdate.js +32 -12
  300. package/crud/contentModel/beforeUpdate.js.map +1 -1
  301. package/crud/contentModel/compatibility/modelApiName.d.ts +3 -0
  302. package/crud/contentModel/compatibility/modelApiName.js +26 -0
  303. package/crud/contentModel/compatibility/modelApiName.js.map +1 -0
  304. package/crud/contentModel/contentModelManagerFactory.d.ts +2 -2
  305. package/crud/contentModel/contentModelManagerFactory.js +2 -7
  306. package/crud/contentModel/contentModelManagerFactory.js.map +1 -1
  307. package/crud/contentModel/createFieldStorageId.d.ts +1 -1
  308. package/crud/contentModel/createFieldStorageId.js +6 -3
  309. package/crud/contentModel/createFieldStorageId.js.map +1 -1
  310. package/crud/contentModel/defaultFields.d.ts +5 -0
  311. package/crud/contentModel/defaultFields.js +60 -0
  312. package/crud/contentModel/defaultFields.js.map +1 -0
  313. package/crud/contentModel/ensureTypeTag.d.ts +5 -0
  314. package/crud/contentModel/ensureTypeTag.js +21 -0
  315. package/crud/contentModel/ensureTypeTag.js.map +1 -0
  316. package/crud/contentModel/fields/descriptionField.d.ts +6 -0
  317. package/crud/contentModel/fields/descriptionField.js +30 -0
  318. package/crud/contentModel/fields/descriptionField.js.map +1 -0
  319. package/crud/contentModel/fields/getApplicableFieldById.d.ts +2 -0
  320. package/crud/contentModel/fields/getApplicableFieldById.js +15 -0
  321. package/crud/contentModel/fields/getApplicableFieldById.js.map +1 -0
  322. package/crud/contentModel/fields/imageField.d.ts +2 -0
  323. package/crud/contentModel/fields/imageField.js +25 -0
  324. package/crud/contentModel/fields/imageField.js.map +1 -0
  325. package/crud/contentModel/fields/titleField.d.ts +6 -0
  326. package/crud/contentModel/fields/titleField.js +31 -0
  327. package/crud/contentModel/fields/titleField.js.map +1 -0
  328. package/crud/contentModel/listModelsFromDatabase.d.ts +10 -0
  329. package/crud/contentModel/listModelsFromDatabase.js +38 -0
  330. package/crud/contentModel/listModelsFromDatabase.js.map +1 -0
  331. package/crud/contentModel/validate/endingAllowed.d.ts +6 -0
  332. package/crud/contentModel/validate/endingAllowed.js +28 -0
  333. package/crud/contentModel/validate/endingAllowed.js.map +1 -0
  334. package/crud/contentModel/validate/isModelEndingAllowed.d.ts +6 -0
  335. package/crud/contentModel/validate/isModelEndingAllowed.js +25 -0
  336. package/crud/contentModel/validate/isModelEndingAllowed.js.map +1 -0
  337. package/crud/contentModel/validate/modelId.d.ts +11 -0
  338. package/crud/contentModel/validate/modelId.js +38 -0
  339. package/crud/contentModel/validate/modelId.js.map +1 -0
  340. package/crud/contentModel/validate/pluralApiName.d.ts +7 -0
  341. package/crud/contentModel/validate/pluralApiName.js +26 -0
  342. package/crud/contentModel/validate/pluralApiName.js.map +1 -0
  343. package/crud/contentModel/validate/singularApiName.d.ts +7 -0
  344. package/crud/contentModel/validate/singularApiName.js +26 -0
  345. package/crud/contentModel/validate/singularApiName.js.map +1 -0
  346. package/crud/contentModel/validateModel.d.ts +4 -4
  347. package/crud/contentModel/validateModel.js +8 -11
  348. package/crud/contentModel/validateModel.js.map +1 -1
  349. package/crud/contentModel/validateModelFields.d.ts +4 -4
  350. package/crud/contentModel/validateModelFields.js +136 -152
  351. package/crud/contentModel/validateModelFields.js.map +1 -1
  352. package/crud/contentModel/validateStorageId.d.ts +1 -0
  353. package/crud/contentModel/validateStorageId.js +19 -0
  354. package/crud/contentModel/validateStorageId.js.map +1 -0
  355. package/crud/contentModel/validation.d.ts +893 -0
  356. package/crud/contentModel/validation.js +205 -0
  357. package/crud/contentModel/validation.js.map +1 -0
  358. package/crud/contentModel.crud.d.ts +6 -4
  359. package/crud/contentModel.crud.js +475 -460
  360. package/crud/contentModel.crud.js.map +1 -1
  361. package/crud/contentModelGroup/beforeCreate.d.ts +3 -3
  362. package/crud/contentModelGroup/beforeCreate.js +14 -12
  363. package/crud/contentModelGroup/beforeCreate.js.map +1 -1
  364. package/crud/contentModelGroup/beforeDelete.d.ts +3 -3
  365. package/crud/contentModelGroup/beforeDelete.js +2 -8
  366. package/crud/contentModelGroup/beforeDelete.js.map +1 -1
  367. package/crud/contentModelGroup/beforeUpdate.d.ts +3 -3
  368. package/crud/contentModelGroup/beforeUpdate.js +2 -5
  369. package/crud/contentModelGroup/beforeUpdate.js.map +1 -1
  370. package/crud/contentModelGroup/listGroupsFromDatabase.d.ts +8 -0
  371. package/crud/contentModelGroup/listGroupsFromDatabase.js +22 -0
  372. package/crud/contentModelGroup/listGroupsFromDatabase.js.map +1 -0
  373. package/crud/contentModelGroup/validation.d.ts +33 -0
  374. package/crud/contentModelGroup/validation.js +37 -0
  375. package/crud/contentModelGroup/validation.js.map +1 -0
  376. package/crud/contentModelGroup.crud.d.ts +6 -4
  377. package/crud/contentModelGroup.crud.js +280 -289
  378. package/crud/contentModelGroup.crud.js.map +1 -1
  379. package/crud/system.crud.d.ts +4 -4
  380. package/crud/system.crud.js +18 -106
  381. package/crud/system.crud.js.map +1 -1
  382. package/export/crud/exporting.d.ts +3 -0
  383. package/export/crud/exporting.js +49 -0
  384. package/export/crud/exporting.js.map +1 -0
  385. package/export/crud/importing.d.ts +3 -0
  386. package/export/crud/importing.js +79 -0
  387. package/export/crud/importing.js.map +1 -0
  388. package/export/crud/imports/importData.d.ts +14 -0
  389. package/export/crud/imports/importData.js +52 -0
  390. package/export/crud/imports/importData.js.map +1 -0
  391. package/export/crud/imports/importGroups.d.ts +8 -0
  392. package/export/crud/imports/importGroups.js +104 -0
  393. package/export/crud/imports/importGroups.js.map +1 -0
  394. package/export/crud/imports/importModels.d.ts +8 -0
  395. package/export/crud/imports/importModels.js +136 -0
  396. package/export/crud/imports/importModels.js.map +1 -0
  397. package/export/crud/imports/validateGroups.d.ts +8 -0
  398. package/export/crud/imports/validateGroups.js +112 -0
  399. package/export/crud/imports/validateGroups.js.map +1 -0
  400. package/export/crud/imports/validateInput.d.ts +19 -0
  401. package/export/crud/imports/validateInput.js +55 -0
  402. package/export/crud/imports/validateInput.js.map +1 -0
  403. package/export/crud/imports/validateModels.d.ts +12 -0
  404. package/export/crud/imports/validateModels.js +203 -0
  405. package/export/crud/imports/validateModels.js.map +1 -0
  406. package/export/crud/index.d.ts +4 -0
  407. package/export/crud/index.js +15 -0
  408. package/export/crud/index.js.map +1 -0
  409. package/export/crud/sanitize.d.ts +4 -0
  410. package/export/crud/sanitize.js +36 -0
  411. package/export/crud/sanitize.js.map +1 -0
  412. package/export/graphql/index.d.ts +3 -0
  413. package/export/graphql/index.js +188 -0
  414. package/export/graphql/index.js.map +1 -0
  415. package/export/index.d.ts +2 -0
  416. package/export/index.js +29 -0
  417. package/export/index.js.map +1 -0
  418. package/export/types.d.ts +113 -0
  419. package/export/types.js +21 -0
  420. package/export/types.js.map +1 -0
  421. package/fieldConverters/CmsModelDefaultFieldConverterPlugin.d.ts +5 -3
  422. package/fieldConverters/CmsModelDefaultFieldConverterPlugin.js +3 -19
  423. package/fieldConverters/CmsModelDefaultFieldConverterPlugin.js.map +1 -1
  424. package/fieldConverters/CmsModelDynamicZoneFieldConverterPlugin.d.ts +12 -0
  425. package/fieldConverters/CmsModelDynamicZoneFieldConverterPlugin.js +158 -0
  426. package/fieldConverters/CmsModelDynamicZoneFieldConverterPlugin.js.map +1 -0
  427. package/fieldConverters/CmsModelObjectFieldConverterPlugin.d.ts +3 -2
  428. package/fieldConverters/CmsModelObjectFieldConverterPlugin.js +48 -92
  429. package/fieldConverters/CmsModelObjectFieldConverterPlugin.js.map +1 -1
  430. package/fieldConverters/index.d.ts +5 -1
  431. package/fieldConverters/index.js +7 -4
  432. package/fieldConverters/index.js.map +1 -1
  433. package/graphql/buildSchemaPlugins.d.ts +8 -3
  434. package/graphql/buildSchemaPlugins.js +9 -11
  435. package/graphql/buildSchemaPlugins.js.map +1 -1
  436. package/graphql/checkEndpointAccess.d.ts +2 -0
  437. package/graphql/checkEndpointAccess.js +20 -0
  438. package/graphql/checkEndpointAccess.js.map +1 -0
  439. package/graphql/createExecutableSchema.d.ts +6 -0
  440. package/graphql/createExecutableSchema.js +38 -0
  441. package/graphql/createExecutableSchema.js.map +1 -0
  442. package/graphql/createRequestBody.d.ts +2 -0
  443. package/graphql/createRequestBody.js +16 -0
  444. package/graphql/createRequestBody.js.map +1 -0
  445. package/graphql/formatErrorPayload.d.ts +1 -0
  446. package/graphql/formatErrorPayload.js +27 -0
  447. package/graphql/formatErrorPayload.js.map +1 -0
  448. package/graphql/generateSchema.d.ts +8 -0
  449. package/graphql/generateSchema.js +38 -0
  450. package/graphql/generateSchema.js.map +1 -0
  451. package/graphql/getSchema/generateCacheId.d.ts +10 -0
  452. package/graphql/getSchema/generateCacheId.js +17 -0
  453. package/graphql/getSchema/generateCacheId.js.map +1 -0
  454. package/graphql/getSchema/generateCacheKey.d.ts +10 -0
  455. package/graphql/getSchema/generateCacheKey.js +34 -0
  456. package/graphql/getSchema/generateCacheKey.js.map +1 -0
  457. package/graphql/getSchema.d.ts +16 -0
  458. package/graphql/getSchema.js +81 -0
  459. package/graphql/getSchema.js.map +1 -0
  460. package/graphql/graphQLHandlerFactory.d.ts +2 -2
  461. package/graphql/graphQLHandlerFactory.js +8 -129
  462. package/graphql/graphQLHandlerFactory.js.map +1 -1
  463. package/graphql/handleRequest.d.ts +11 -0
  464. package/graphql/handleRequest.js +86 -0
  465. package/graphql/handleRequest.js.map +1 -0
  466. package/graphql/index.d.ts +4 -5
  467. package/graphql/index.js +4 -46
  468. package/graphql/index.js.map +1 -1
  469. package/graphql/scalars/RevisionId.d.ts +2 -0
  470. package/graphql/scalars/RevisionId.js +26 -0
  471. package/graphql/scalars/RevisionId.js.map +1 -0
  472. package/graphql/scalars/RevisionIdScalarPlugin.d.ts +2 -0
  473. package/graphql/scalars/RevisionIdScalarPlugin.js +18 -0
  474. package/graphql/scalars/RevisionIdScalarPlugin.js.map +1 -0
  475. package/graphql/schema/baseContentSchema.d.ts +7 -3
  476. package/graphql/schema/baseContentSchema.js +17 -32
  477. package/graphql/schema/baseContentSchema.js.map +1 -1
  478. package/graphql/schema/baseSchema.d.ts +2 -0
  479. package/graphql/schema/baseSchema.js +153 -0
  480. package/graphql/schema/baseSchema.js.map +1 -0
  481. package/graphql/schema/contentEntries.d.ts +7 -3
  482. package/graphql/schema/contentEntries.js +159 -111
  483. package/graphql/schema/contentEntries.js.map +1 -1
  484. package/graphql/schema/contentModelGroups.d.ts +7 -3
  485. package/graphql/schema/contentModelGroups.js +20 -30
  486. package/graphql/schema/contentModelGroups.js.map +1 -1
  487. package/graphql/schema/contentModels.d.ts +6 -3
  488. package/graphql/schema/contentModels.js +86 -34
  489. package/graphql/schema/contentModels.js.map +1 -1
  490. package/graphql/schema/createFieldResolvers.d.ts +3 -3
  491. package/graphql/schema/createFieldResolvers.js +28 -41
  492. package/graphql/schema/createFieldResolvers.js.map +1 -1
  493. package/graphql/schema/createFieldTypePluginRecords.d.ts +3 -0
  494. package/graphql/schema/createFieldTypePluginRecords.js +15 -0
  495. package/graphql/schema/createFieldTypePluginRecords.js.map +1 -0
  496. package/graphql/schema/createManageResolvers.d.ts +1 -2
  497. package/graphql/schema/createManageResolvers.js +62 -80
  498. package/graphql/schema/createManageResolvers.js.map +1 -1
  499. package/graphql/schema/createManageSDL.d.ts +4 -1
  500. package/graphql/schema/createManageSDL.js +128 -81
  501. package/graphql/schema/createManageSDL.js.map +1 -1
  502. package/graphql/schema/createPreviewResolvers.d.ts +1 -2
  503. package/graphql/schema/createPreviewResolvers.js +13 -29
  504. package/graphql/schema/createPreviewResolvers.js.map +1 -1
  505. package/graphql/schema/createReadResolvers.d.ts +1 -2
  506. package/graphql/schema/createReadResolvers.js +18 -29
  507. package/graphql/schema/createReadResolvers.js.map +1 -1
  508. package/graphql/schema/createReadSDL.d.ts +4 -1
  509. package/graphql/schema/createReadSDL.js +56 -48
  510. package/graphql/schema/createReadSDL.js.map +1 -1
  511. package/graphql/schema/createSingularResolvers.d.ts +12 -0
  512. package/graphql/schema/createSingularResolvers.js +56 -0
  513. package/graphql/schema/createSingularResolvers.js.map +1 -0
  514. package/graphql/schema/createSingularSDL.d.ts +12 -0
  515. package/graphql/schema/createSingularSDL.js +95 -0
  516. package/graphql/schema/createSingularSDL.js.map +1 -0
  517. package/graphql/schema/resolvers/manage/normalizeGraphQlInput.d.ts +7 -0
  518. package/graphql/schema/resolvers/manage/normalizeGraphQlInput.js +59 -0
  519. package/graphql/schema/resolvers/manage/normalizeGraphQlInput.js.map +1 -0
  520. package/graphql/schema/resolvers/manage/resolveCreate.d.ts +3 -2
  521. package/graphql/schema/resolvers/manage/resolveCreate.js +3 -4
  522. package/graphql/schema/resolvers/manage/resolveCreate.js.map +1 -1
  523. package/graphql/schema/resolvers/manage/resolveCreateFrom.d.ts +3 -2
  524. package/graphql/schema/resolvers/manage/resolveCreateFrom.js +3 -4
  525. package/graphql/schema/resolvers/manage/resolveCreateFrom.js.map +1 -1
  526. package/graphql/schema/resolvers/manage/resolveDelete.d.ts +3 -2
  527. package/graphql/schema/resolvers/manage/resolveDelete.js +16 -9
  528. package/graphql/schema/resolvers/manage/resolveDelete.js.map +1 -1
  529. package/graphql/schema/resolvers/manage/resolveDeleteMultiple.d.ts +7 -0
  530. package/graphql/schema/resolvers/manage/resolveDeleteMultiple.js +22 -0
  531. package/graphql/schema/resolvers/manage/resolveDeleteMultiple.js.map +1 -0
  532. package/graphql/schema/resolvers/manage/resolveGet.d.ts +2 -2
  533. package/graphql/schema/resolvers/manage/resolveGet.js +11 -20
  534. package/graphql/schema/resolvers/manage/resolveGet.js.map +1 -1
  535. package/graphql/schema/resolvers/manage/resolveGetByIds.d.ts +2 -2
  536. package/graphql/schema/resolvers/manage/resolveGetByIds.js +2 -3
  537. package/graphql/schema/resolvers/manage/resolveGetByIds.js.map +1 -1
  538. package/graphql/schema/resolvers/manage/resolveGetRevisions.d.ts +2 -2
  539. package/graphql/schema/resolvers/manage/resolveGetRevisions.js +2 -3
  540. package/graphql/schema/resolvers/manage/resolveGetRevisions.js.map +1 -1
  541. package/graphql/schema/resolvers/manage/resolveGetUniqueFieldValues.d.ts +4 -0
  542. package/graphql/schema/resolvers/manage/resolveGetUniqueFieldValues.js +20 -0
  543. package/graphql/schema/resolvers/manage/resolveGetUniqueFieldValues.js.map +1 -0
  544. package/graphql/schema/resolvers/manage/resolveList.d.ts +2 -2
  545. package/graphql/schema/resolvers/manage/resolveList.js +2 -3
  546. package/graphql/schema/resolvers/manage/resolveList.js.map +1 -1
  547. package/graphql/schema/resolvers/manage/resolveListDeleted.d.ts +4 -0
  548. package/graphql/schema/resolvers/manage/resolveListDeleted.js +20 -0
  549. package/graphql/schema/resolvers/manage/resolveListDeleted.js.map +1 -0
  550. package/graphql/schema/resolvers/manage/resolveMove.d.ts +8 -0
  551. package/graphql/schema/resolvers/manage/resolveMove.js +27 -0
  552. package/graphql/schema/resolvers/manage/resolveMove.js.map +1 -0
  553. package/graphql/schema/resolvers/manage/resolvePublish.d.ts +2 -2
  554. package/graphql/schema/resolvers/manage/resolvePublish.js +2 -3
  555. package/graphql/schema/resolvers/manage/resolvePublish.js.map +1 -1
  556. package/graphql/schema/resolvers/manage/resolveRepublish.d.ts +2 -2
  557. package/graphql/schema/resolvers/manage/resolveRepublish.js +2 -3
  558. package/graphql/schema/resolvers/manage/resolveRepublish.js.map +1 -1
  559. package/graphql/schema/resolvers/manage/resolveRestoreFromBin.d.ts +7 -0
  560. package/graphql/schema/resolvers/manage/resolveRestoreFromBin.js +20 -0
  561. package/graphql/schema/resolvers/manage/resolveRestoreFromBin.js.map +1 -0
  562. package/graphql/schema/resolvers/manage/resolveUnpublish.d.ts +2 -2
  563. package/graphql/schema/resolvers/manage/resolveUnpublish.js +2 -3
  564. package/graphql/schema/resolvers/manage/resolveUnpublish.js.map +1 -1
  565. package/graphql/schema/resolvers/manage/resolveUpdate.d.ts +3 -2
  566. package/graphql/schema/resolvers/manage/resolveUpdate.js +3 -4
  567. package/graphql/schema/resolvers/manage/resolveUpdate.js.map +1 -1
  568. package/graphql/schema/resolvers/manage/resolveValidate.d.ts +8 -0
  569. package/graphql/schema/resolvers/manage/{resolveRequestChanges.js → resolveValidate.js} +5 -6
  570. package/graphql/schema/resolvers/manage/resolveValidate.js.map +1 -0
  571. package/graphql/schema/resolvers/preview/resolveGet.d.ts +2 -2
  572. package/graphql/schema/resolvers/preview/resolveGet.js +5 -12
  573. package/graphql/schema/resolvers/preview/resolveGet.js.map +1 -1
  574. package/graphql/schema/resolvers/preview/resolveList.d.ts +2 -2
  575. package/graphql/schema/resolvers/preview/resolveList.js +2 -3
  576. package/graphql/schema/resolvers/preview/resolveList.js.map +1 -1
  577. package/graphql/schema/resolvers/read/resolveGet.d.ts +2 -2
  578. package/graphql/schema/resolvers/read/resolveGet.js +5 -12
  579. package/graphql/schema/resolvers/read/resolveGet.js.map +1 -1
  580. package/graphql/schema/resolvers/read/resolveList.d.ts +2 -2
  581. package/graphql/schema/resolvers/read/resolveList.js +2 -3
  582. package/graphql/schema/resolvers/read/resolveList.js.map +1 -1
  583. package/graphql/schema/resolvers/singular/resolveGet.d.ts +7 -0
  584. package/graphql/schema/resolvers/singular/resolveGet.js +21 -0
  585. package/graphql/schema/resolvers/singular/resolveGet.js.map +1 -0
  586. package/graphql/schema/resolvers/singular/resolveUpdate.d.ts +8 -0
  587. package/graphql/schema/resolvers/{manage/resolveRequestReview.js → singular/resolveUpdate.js} +6 -6
  588. package/graphql/schema/resolvers/singular/resolveUpdate.js.map +1 -0
  589. package/graphql/schema/schemaPlugins.d.ts +8 -3
  590. package/graphql/schema/schemaPlugins.js +81 -69
  591. package/graphql/schema/schemaPlugins.js.map +1 -1
  592. package/graphql/system.d.ts +3 -6
  593. package/graphql/system.js +59 -98
  594. package/graphql/system.js.map +1 -1
  595. package/graphqlFields/boolean.d.ts +1 -1
  596. package/graphqlFields/boolean.js +2 -12
  597. package/graphqlFields/boolean.js.map +1 -1
  598. package/graphqlFields/datetime.d.ts +1 -1
  599. package/graphqlFields/datetime.js +4 -21
  600. package/graphqlFields/datetime.js.map +1 -1
  601. package/graphqlFields/dynamicZone/dynamicZoneField.d.ts +2 -0
  602. package/graphqlFields/dynamicZone/dynamicZoneField.js +320 -0
  603. package/graphqlFields/dynamicZone/dynamicZoneField.js.map +1 -0
  604. package/graphqlFields/dynamicZone/index.d.ts +1 -0
  605. package/graphqlFields/dynamicZone/index.js +14 -0
  606. package/graphqlFields/dynamicZone/index.js.map +1 -0
  607. package/graphqlFields/file.d.ts +1 -1
  608. package/graphqlFields/file.js +2 -8
  609. package/graphqlFields/file.js.map +1 -1
  610. package/graphqlFields/helpers.d.ts +1 -2
  611. package/graphqlFields/helpers.js +5 -27
  612. package/graphqlFields/helpers.js.map +1 -1
  613. package/graphqlFields/index.d.ts +2 -2
  614. package/graphqlFields/index.js +6 -12
  615. package/graphqlFields/index.js.map +1 -1
  616. package/graphqlFields/json.d.ts +2 -0
  617. package/graphqlFields/json.js +49 -0
  618. package/graphqlFields/json.js.map +1 -0
  619. package/graphqlFields/longText.d.ts +1 -1
  620. package/graphqlFields/longText.js +13 -12
  621. package/graphqlFields/longText.js.map +1 -1
  622. package/graphqlFields/number.d.ts +1 -1
  623. package/graphqlFields/number.js +7 -12
  624. package/graphqlFields/number.js.map +1 -1
  625. package/graphqlFields/object.d.ts +2 -2
  626. package/graphqlFields/object.js +128 -101
  627. package/graphqlFields/object.js.map +1 -1
  628. package/graphqlFields/ref.d.ts +1 -1
  629. package/graphqlFields/ref.js +111 -119
  630. package/graphqlFields/ref.js.map +1 -1
  631. package/graphqlFields/richText/RichTextPluginsProcessor.d.ts +6 -0
  632. package/graphqlFields/richText/RichTextPluginsProcessor.js +34 -0
  633. package/graphqlFields/richText/RichTextPluginsProcessor.js.map +1 -0
  634. package/graphqlFields/richText/richTextResolver.d.ts +7 -0
  635. package/graphqlFields/richText/richTextResolver.js +24 -0
  636. package/graphqlFields/richText/richTextResolver.js.map +1 -0
  637. package/graphqlFields/richText.d.ts +1 -1
  638. package/graphqlFields/richText.js +10 -11
  639. package/graphqlFields/richText.js.map +1 -1
  640. package/graphqlFields/searchableJson.d.ts +2 -0
  641. package/graphqlFields/searchableJson.js +60 -0
  642. package/graphqlFields/searchableJson.js.map +1 -0
  643. package/graphqlFields/text.d.ts +1 -1
  644. package/graphqlFields/text.js +4 -11
  645. package/graphqlFields/text.js.map +1 -1
  646. package/htmlRenderer/LexicalRenderer.d.ts +5 -0
  647. package/htmlRenderer/LexicalRenderer.js +28 -0
  648. package/htmlRenderer/LexicalRenderer.js.map +1 -0
  649. package/htmlRenderer/createLexicalHTMLRenderer.d.ts +2 -0
  650. package/htmlRenderer/createLexicalHTMLRenderer.js +31 -0
  651. package/htmlRenderer/createLexicalHTMLRenderer.js.map +1 -0
  652. package/index.d.ts +15 -6
  653. package/index.js +105 -30
  654. package/index.js.map +1 -1
  655. package/modelManager/DefaultCmsModelManager.d.ts +11 -10
  656. package/modelManager/DefaultCmsModelManager.js +18 -33
  657. package/modelManager/DefaultCmsModelManager.js.map +1 -1
  658. package/modelManager/SingletonModelManager.d.ts +12 -0
  659. package/modelManager/SingletonModelManager.js +48 -0
  660. package/modelManager/SingletonModelManager.js.map +1 -0
  661. package/modelManager/index.d.ts +2 -1
  662. package/modelManager/index.js +18 -5
  663. package/modelManager/index.js.map +1 -1
  664. package/package.json +40 -45
  665. package/parameters/context.js +3 -5
  666. package/parameters/context.js.map +1 -1
  667. package/parameters/header.js +6 -16
  668. package/parameters/header.js.map +1 -1
  669. package/parameters/index.js +3 -9
  670. package/parameters/index.js.map +1 -1
  671. package/parameters/manual.d.ts +2 -1
  672. package/parameters/manual.js +9 -11
  673. package/parameters/manual.js.map +1 -1
  674. package/parameters/path.js +3 -13
  675. package/parameters/path.js.map +1 -1
  676. package/plugins/CmsGraphQLSchemaPlugin/CmsGraphQLSchemaPlugin.d.ts +9 -0
  677. package/plugins/CmsGraphQLSchemaPlugin/CmsGraphQLSchemaPlugin.js +17 -0
  678. package/plugins/CmsGraphQLSchemaPlugin/CmsGraphQLSchemaPlugin.js.map +1 -0
  679. package/plugins/CmsGraphQLSchemaPlugin/index.d.ts +1 -0
  680. package/plugins/CmsGraphQLSchemaPlugin/index.js +18 -0
  681. package/plugins/CmsGraphQLSchemaPlugin/index.js.map +1 -0
  682. package/plugins/CmsGraphQLSchemaSorterPlugin.d.ts +20 -0
  683. package/plugins/CmsGraphQLSchemaSorterPlugin.js +27 -0
  684. package/plugins/CmsGraphQLSchemaSorterPlugin.js.map +1 -0
  685. package/plugins/CmsGroupPlugin.d.ts +15 -4
  686. package/plugins/CmsGroupPlugin.js +23 -13
  687. package/plugins/CmsGroupPlugin.js.map +1 -1
  688. package/plugins/CmsModelFieldConverterPlugin.d.ts +7 -4
  689. package/plugins/CmsModelFieldConverterPlugin.js +8 -8
  690. package/plugins/CmsModelFieldConverterPlugin.js.map +1 -1
  691. package/plugins/CmsModelPlugin.d.ts +47 -7
  692. package/plugins/CmsModelPlugin.js +169 -68
  693. package/plugins/CmsModelPlugin.js.map +1 -1
  694. package/plugins/CmsParametersPlugin.d.ts +3 -3
  695. package/plugins/CmsParametersPlugin.js +6 -10
  696. package/plugins/CmsParametersPlugin.js.map +1 -1
  697. package/plugins/CmsRichTextRendererPlugin.d.ts +24 -0
  698. package/plugins/CmsRichTextRendererPlugin.js +28 -0
  699. package/plugins/CmsRichTextRendererPlugin.js.map +1 -0
  700. package/plugins/StorageOperationsCmsModelPlugin.d.ts +23 -0
  701. package/plugins/StorageOperationsCmsModelPlugin.js +41 -0
  702. package/plugins/StorageOperationsCmsModelPlugin.js.map +1 -0
  703. package/plugins/StorageTransformPlugin.d.ts +18 -14
  704. package/plugins/StorageTransformPlugin.js +11 -13
  705. package/plugins/StorageTransformPlugin.js.map +1 -1
  706. package/plugins/index.d.ts +4 -0
  707. package/plugins/index.js +47 -11
  708. package/plugins/index.js.map +1 -1
  709. package/storage/date.d.ts +3 -0
  710. package/storage/date.js +119 -0
  711. package/storage/date.js.map +1 -0
  712. package/storage/default.js +2 -3
  713. package/storage/default.js.map +1 -1
  714. package/storage/dynamicZone.d.ts +2 -0
  715. package/storage/dynamicZone.js +157 -0
  716. package/storage/dynamicZone.js.map +1 -0
  717. package/storage/index.d.ts +1 -0
  718. package/storage/index.js +21 -0
  719. package/storage/index.js.map +1 -0
  720. package/storage/json.d.ts +2 -0
  721. package/storage/json.js +56 -0
  722. package/storage/json.js.map +1 -0
  723. package/storage/object.js +27 -39
  724. package/storage/object.js.map +1 -1
  725. package/types/context.d.ts +146 -0
  726. package/types/context.js +7 -0
  727. package/types/context.js.map +1 -0
  728. package/types/fields/dynamicZoneField.d.ts +23 -0
  729. package/types/fields/dynamicZoneField.js +7 -0
  730. package/types/fields/dynamicZoneField.js.map +1 -0
  731. package/types/fields/objectField.d.ts +13 -0
  732. package/types/fields/objectField.js +7 -0
  733. package/types/fields/objectField.js.map +1 -0
  734. package/types/identity.d.ts +19 -0
  735. package/types/identity.js +7 -0
  736. package/types/identity.js.map +1 -0
  737. package/types/index.d.ts +10 -0
  738. package/types/index.js +117 -0
  739. package/types/index.js.map +1 -0
  740. package/types/model.d.ts +199 -0
  741. package/types/model.js +7 -0
  742. package/types/model.js.map +1 -0
  743. package/types/modelAst.d.ts +39 -0
  744. package/types/modelAst.js +7 -0
  745. package/types/modelAst.js.map +1 -0
  746. package/types/modelField.d.ts +330 -0
  747. package/types/modelField.js +7 -0
  748. package/types/modelField.js.map +1 -0
  749. package/types/modelGroup.d.ts +77 -0
  750. package/types/modelGroup.js +7 -0
  751. package/types/modelGroup.js.map +1 -0
  752. package/types/plugins.d.ts +365 -0
  753. package/types/plugins.js +7 -0
  754. package/types/plugins.js.map +1 -0
  755. package/types/types.d.ts +1897 -0
  756. package/{types.js → types/types.js} +79 -187
  757. package/types/types.js.map +1 -0
  758. package/utils/RichTextRenderer.d.ts +10 -0
  759. package/utils/RichTextRenderer.js +33 -0
  760. package/utils/RichTextRenderer.js.map +1 -0
  761. package/utils/caching/Cache.d.ts +5 -0
  762. package/utils/caching/Cache.js +48 -0
  763. package/utils/caching/Cache.js.map +1 -0
  764. package/utils/caching/CacheKey.d.ts +3 -0
  765. package/utils/caching/CacheKey.js +28 -0
  766. package/utils/caching/CacheKey.js.map +1 -0
  767. package/utils/caching/index.d.ts +2 -0
  768. package/utils/caching/index.js +29 -0
  769. package/utils/caching/index.js.map +1 -0
  770. package/utils/caching/types.d.ts +13 -0
  771. package/utils/caching/types.js +14 -0
  772. package/utils/caching/types.js.map +1 -0
  773. package/utils/contentEntryTraverser/ContentEntryTraverser.d.ts +13 -0
  774. package/utils/contentEntryTraverser/ContentEntryTraverser.js +97 -0
  775. package/utils/contentEntryTraverser/ContentEntryTraverser.js.map +1 -0
  776. package/utils/contentModelAst/CmsModelFieldToAstConverterFromPlugins.d.ts +6 -0
  777. package/utils/contentModelAst/CmsModelFieldToAstConverterFromPlugins.js +23 -0
  778. package/utils/contentModelAst/CmsModelFieldToAstConverterFromPlugins.js.map +1 -0
  779. package/utils/contentModelAst/CmsModelFieldToAstFromPlugin.d.ts +7 -0
  780. package/utils/contentModelAst/CmsModelFieldToAstFromPlugin.js +22 -0
  781. package/utils/contentModelAst/CmsModelFieldToAstFromPlugin.js.map +1 -0
  782. package/utils/contentModelAst/CmsModelToAstConverter.d.ts +11 -0
  783. package/utils/contentModelAst/CmsModelToAstConverter.js +28 -0
  784. package/utils/contentModelAst/CmsModelToAstConverter.js.map +1 -0
  785. package/utils/contentModelAst/index.d.ts +3 -0
  786. package/utils/contentModelAst/index.js +40 -0
  787. package/utils/contentModelAst/index.js.map +1 -0
  788. package/utils/converters/Converter.d.ts +3 -3
  789. package/utils/converters/Converter.js +3 -17
  790. package/utils/converters/Converter.js.map +1 -1
  791. package/utils/converters/ConverterCollection.d.ts +2 -2
  792. package/utils/converters/ConverterCollection.js +26 -40
  793. package/utils/converters/ConverterCollection.js.map +1 -1
  794. package/utils/converters/valueKeyStorageConverter.d.ts +4 -8
  795. package/utils/converters/valueKeyStorageConverter.js +32 -45
  796. package/utils/converters/valueKeyStorageConverter.js.map +1 -1
  797. package/utils/createModelField.d.ts +7 -0
  798. package/utils/createModelField.js +51 -0
  799. package/utils/createModelField.js.map +1 -0
  800. package/utils/createTypeFromFields.d.ts +16 -0
  801. package/utils/createTypeFromFields.js +71 -0
  802. package/utils/createTypeFromFields.js.map +1 -0
  803. package/utils/createTypeName.d.ts +0 -2
  804. package/utils/createTypeName.js +4 -17
  805. package/utils/createTypeName.js.map +1 -1
  806. package/utils/date.d.ts +10 -0
  807. package/utils/date.js +36 -0
  808. package/utils/date.js.map +1 -0
  809. package/utils/entryStorage.d.ts +16 -4
  810. package/utils/entryStorage.js +62 -39
  811. package/utils/entryStorage.js.map +1 -1
  812. package/utils/filterAsync.js +8 -12
  813. package/utils/filterAsync.js.map +1 -1
  814. package/utils/getBaseFieldType.d.ts +2 -0
  815. package/utils/getBaseFieldType.js +12 -0
  816. package/utils/getBaseFieldType.js.map +1 -0
  817. package/utils/getEntryDescription.d.ts +2 -0
  818. package/utils/getEntryDescription.js +19 -0
  819. package/utils/getEntryDescription.js.map +1 -0
  820. package/utils/getEntryImage.d.ts +2 -0
  821. package/utils/getEntryImage.js +19 -0
  822. package/utils/getEntryImage.js.map +1 -0
  823. package/utils/getEntryTitle.d.ts +2 -2
  824. package/utils/getEntryTitle.js +3 -10
  825. package/utils/getEntryTitle.js.map +1 -1
  826. package/utils/getSchemaFromFieldPlugins.d.ts +15 -7
  827. package/utils/getSchemaFromFieldPlugins.js +40 -17
  828. package/utils/getSchemaFromFieldPlugins.js.map +1 -1
  829. package/utils/identity.d.ts +2 -0
  830. package/utils/identity.js +20 -0
  831. package/utils/identity.js.map +1 -0
  832. package/utils/incrementEntryIdVersion.d.ts +5 -0
  833. package/utils/incrementEntryIdVersion.js +31 -0
  834. package/utils/incrementEntryIdVersion.js.map +1 -0
  835. package/utils/index.d.ts +2 -0
  836. package/utils/index.js +29 -0
  837. package/utils/index.js.map +1 -0
  838. package/utils/isHeadlessCmsReady.d.ts +2 -0
  839. package/utils/isHeadlessCmsReady.js +23 -0
  840. package/utils/isHeadlessCmsReady.js.map +1 -0
  841. package/utils/modelFieldTraverser/ModelFieldTraverser.d.ts +16 -0
  842. package/utils/modelFieldTraverser/ModelFieldTraverser.js +41 -0
  843. package/utils/modelFieldTraverser/ModelFieldTraverser.js.map +1 -0
  844. package/utils/modelFieldTraverser/index.d.ts +1 -0
  845. package/utils/modelFieldTraverser/index.js +18 -0
  846. package/utils/modelFieldTraverser/index.js.map +1 -0
  847. package/utils/renderFields.d.ts +5 -3
  848. package/utils/renderFields.js +16 -11
  849. package/utils/renderFields.js.map +1 -1
  850. package/utils/renderGetFilterFields.d.ts +2 -2
  851. package/utils/renderGetFilterFields.js +10 -30
  852. package/utils/renderGetFilterFields.js.map +1 -1
  853. package/utils/renderInputFields.d.ts +5 -3
  854. package/utils/renderInputFields.js +21 -14
  855. package/utils/renderInputFields.js.map +1 -1
  856. package/utils/renderListFilterFields.d.ts +3 -1
  857. package/utils/renderListFilterFields.js +27 -30
  858. package/utils/renderListFilterFields.js.map +1 -1
  859. package/utils/renderSortEnum.d.ts +9 -5
  860. package/utils/renderSortEnum.js +29 -12
  861. package/utils/renderSortEnum.js.map +1 -1
  862. package/utils/toSlug.js +2 -4
  863. package/utils/toSlug.js.map +1 -1
  864. package/validators/dateGte.d.ts +1 -1
  865. package/validators/dateGte.js +2 -7
  866. package/validators/dateGte.js.map +1 -1
  867. package/validators/dateLte.d.ts +1 -1
  868. package/validators/dateLte.js +2 -7
  869. package/validators/dateLte.js.map +1 -1
  870. package/validators/gte.d.ts +1 -1
  871. package/validators/gte.js +3 -10
  872. package/validators/gte.js.map +1 -1
  873. package/validators/in.d.ts +1 -1
  874. package/validators/in.js +3 -10
  875. package/validators/in.js.map +1 -1
  876. package/validators/index.js +2 -15
  877. package/validators/index.js.map +1 -1
  878. package/validators/lte.d.ts +1 -1
  879. package/validators/lte.js +3 -10
  880. package/validators/lte.js.map +1 -1
  881. package/validators/maxLength.d.ts +1 -1
  882. package/validators/maxLength.js +3 -10
  883. package/validators/maxLength.js.map +1 -1
  884. package/validators/minLength.d.ts +1 -1
  885. package/validators/minLength.js +3 -10
  886. package/validators/minLength.js.map +1 -1
  887. package/validators/pattern.d.ts +1 -1
  888. package/validators/pattern.js +4 -11
  889. package/validators/pattern.js.map +1 -1
  890. package/validators/patternPlugins/email.d.ts +1 -1
  891. package/validators/patternPlugins/email.js +3 -3
  892. package/validators/patternPlugins/email.js.map +1 -1
  893. package/validators/patternPlugins/index.d.ts +1 -1
  894. package/validators/patternPlugins/index.js +2 -8
  895. package/validators/patternPlugins/index.js.map +1 -1
  896. package/validators/patternPlugins/lowerCase.d.ts +1 -1
  897. package/validators/patternPlugins/lowerCase.js +2 -2
  898. package/validators/patternPlugins/lowerCase.js.map +1 -1
  899. package/validators/patternPlugins/lowerCaseSpace.d.ts +1 -1
  900. package/validators/patternPlugins/lowerCaseSpace.js +2 -2
  901. package/validators/patternPlugins/lowerCaseSpace.js.map +1 -1
  902. package/validators/patternPlugins/upperCase.d.ts +1 -1
  903. package/validators/patternPlugins/upperCase.js +2 -2
  904. package/validators/patternPlugins/upperCase.js.map +1 -1
  905. package/validators/patternPlugins/upperCaseSpace.d.ts +1 -1
  906. package/validators/patternPlugins/upperCaseSpace.js +2 -2
  907. package/validators/patternPlugins/upperCaseSpace.js.map +1 -1
  908. package/validators/patternPlugins/url.d.ts +1 -1
  909. package/validators/patternPlugins/url.js +2 -2
  910. package/validators/patternPlugins/url.js.map +1 -1
  911. package/validators/required.d.ts +1 -1
  912. package/validators/required.js +2 -5
  913. package/validators/required.js.map +1 -1
  914. package/validators/timeGte.d.ts +1 -1
  915. package/validators/timeGte.js +3 -10
  916. package/validators/timeGte.js.map +1 -1
  917. package/validators/timeLte.d.ts +1 -1
  918. package/validators/timeLte.js +3 -10
  919. package/validators/timeLte.js.map +1 -1
  920. package/validators/unique.d.ts +1 -1
  921. package/validators/unique.js +3 -8
  922. package/validators/unique.js.map +1 -1
  923. package/crud/contentModel/afterCreate.d.ts +0 -8
  924. package/crud/contentModel/afterCreate.js +0 -18
  925. package/crud/contentModel/afterCreate.js.map +0 -1
  926. package/crud/contentModel/afterCreateFrom.d.ts +0 -8
  927. package/crud/contentModel/afterCreateFrom.js +0 -18
  928. package/crud/contentModel/afterCreateFrom.js.map +0 -1
  929. package/crud/contentModel/afterDelete.d.ts +0 -8
  930. package/crud/contentModel/afterDelete.js +0 -18
  931. package/crud/contentModel/afterDelete.js.map +0 -1
  932. package/crud/contentModel/afterUpdate.d.ts +0 -8
  933. package/crud/contentModel/afterUpdate.js +0 -18
  934. package/crud/contentModel/afterUpdate.js.map +0 -1
  935. package/crud/contentModel/createFieldModels.d.ts +0 -2
  936. package/crud/contentModel/createFieldModels.js +0 -26
  937. package/crud/contentModel/createFieldModels.js.map +0 -1
  938. package/crud/contentModel/fieldIdValidation.d.ts +0 -1
  939. package/crud/contentModel/fieldIdValidation.js +0 -25
  940. package/crud/contentModel/fieldIdValidation.js.map +0 -1
  941. package/crud/contentModel/idValidation.d.ts +0 -1
  942. package/crud/contentModel/idValidation.js +0 -22
  943. package/crud/contentModel/idValidation.js.map +0 -1
  944. package/crud/contentModel/models.d.ts +0 -4
  945. package/crud/contentModel/models.js +0 -180
  946. package/crud/contentModel/models.js.map +0 -1
  947. package/crud/contentModel/systemFields.d.ts +0 -1
  948. package/crud/contentModel/systemFields.js +0 -8
  949. package/crud/contentModel/systemFields.js.map +0 -1
  950. package/crud/contentModel/validateLayout.d.ts +0 -2
  951. package/crud/contentModel/validateLayout.js +0 -36
  952. package/crud/contentModel/validateLayout.js.map +0 -1
  953. package/crud/index.d.ts +0 -6
  954. package/crud/index.js +0 -85
  955. package/crud/index.js.map +0 -1
  956. package/crud/settings.crud.d.ts +0 -10
  957. package/crud/settings.crud.js +0 -83
  958. package/crud/settings.crud.js.map +0 -1
  959. package/graphql/schema/resolvers/commonFieldResolvers.d.ts +0 -6
  960. package/graphql/schema/resolvers/commonFieldResolvers.js +0 -14
  961. package/graphql/schema/resolvers/commonFieldResolvers.js.map +0 -1
  962. package/graphql/schema/resolvers/manage/resolveRequestChanges.d.ts +0 -7
  963. package/graphql/schema/resolvers/manage/resolveRequestChanges.js.map +0 -1
  964. package/graphql/schema/resolvers/manage/resolveRequestReview.d.ts +0 -7
  965. package/graphql/schema/resolvers/manage/resolveRequestReview.js.map +0 -1
  966. package/types.d.ts +0 -2457
  967. package/types.js.map +0 -1
  968. package/upgrades/5.33.0/index.d.ts +0 -3
  969. package/upgrades/5.33.0/index.js +0 -182
  970. package/upgrades/5.33.0/index.js.map +0 -1
  971. package/upgrades/index.d.ts +0 -1
  972. package/upgrades/index.js +0 -12
  973. package/upgrades/index.js.map +0 -1
  974. package/utils/access.d.ts +0 -8
  975. package/utils/access.js +0 -90
  976. package/utils/access.js.map +0 -1
  977. package/utils/filterModelFields.d.ts +0 -16
  978. package/utils/filterModelFields.js +0 -77
  979. package/utils/filterModelFields.js.map +0 -1
  980. package/utils/ownership.d.ts +0 -8
  981. package/utils/ownership.js +0 -41
  982. package/utils/ownership.js.map +0 -1
  983. package/utils/permissions.d.ts +0 -7
  984. package/utils/permissions.js +0 -106
  985. package/utils/permissions.js.map +0 -1
  986. package/utils/pluralizedTypeName.d.ts +0 -1
  987. package/utils/pluralizedTypeName.js +0 -26
  988. package/utils/pluralizedTypeName.js.map +0 -1
@@ -1,303 +1,124 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
-
5
4
  Object.defineProperty(exports, "__esModule", {
6
5
  value: true
7
6
  });
8
- exports.createContentEntryCrud = exports.STATUS_UNPUBLISHED = exports.STATUS_PUBLISHED = exports.STATUS_DRAFT = void 0;
9
-
10
- var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
11
-
12
- var _mdbid = _interopRequireDefault(require("mdbid"));
13
-
7
+ exports.createContentEntryCrud = void 0;
8
+ var _utils = require("@webiny/utils");
9
+ var _error = _interopRequireDefault(require("@webiny/error"));
14
10
  var _handlerGraphql = require("@webiny/handler-graphql");
15
-
16
11
  var _entryDataValidation = require("./contentEntry/entryDataValidation");
17
-
18
- var _error = _interopRequireDefault(require("@webiny/error"));
19
-
20
12
  var _pubsub = require("@webiny/pubsub");
21
-
22
13
  var _beforeCreate = require("./contentEntry/beforeCreate");
23
-
24
14
  var _beforeUpdate = require("./contentEntry/beforeUpdate");
25
-
26
- var _utils = require("@webiny/utils");
27
-
28
15
  var _afterDelete = require("./contentEntry/afterDelete");
29
-
30
- var _referenceFieldsMapping = require("./contentEntry/referenceFieldsMapping");
31
-
32
- var _merge = _interopRequireDefault(require("lodash/merge"));
33
-
34
- var _permissions = require("../utils/permissions");
35
-
36
- var _access = require("../utils/access");
37
-
38
- var _ownership = require("../utils/ownership");
39
-
40
16
  var _entryStorage = require("../utils/entryStorage");
41
-
42
- var _valueKeyStorageConverter = require("../utils/converters/valueKeyStorageConverter");
43
-
44
- /**
45
- * Package mdbid does not have types.
46
- */
47
- // @ts-ignore
48
- const STATUS_DRAFT = "draft";
49
- exports.STATUS_DRAFT = STATUS_DRAFT;
50
- const STATUS_PUBLISHED = "published";
51
- exports.STATUS_PUBLISHED = STATUS_PUBLISHED;
52
- const STATUS_UNPUBLISHED = "unpublished";
53
- exports.STATUS_UNPUBLISHED = STATUS_UNPUBLISHED;
54
-
55
- /**
56
- * Used for some fields to convert their values.
57
- */
58
- const convertDefaultValue = (field, value) => {
59
- switch (field.type) {
60
- case "boolean":
61
- return Boolean(value);
62
-
63
- case "number":
64
- return Number(value);
65
-
66
- default:
67
- return value;
68
- }
69
- };
70
-
71
- const getDefaultValue = field => {
72
- const {
73
- settings,
74
- multipleValues
75
- } = field;
76
-
77
- if (settings && settings.defaultValue !== undefined) {
78
- return convertDefaultValue(field, settings.defaultValue);
79
- }
80
-
81
- const {
82
- predefinedValues
83
- } = field;
84
-
85
- if (!predefinedValues || !predefinedValues.enabled || Array.isArray(predefinedValues.values) === false) {
86
- return undefined;
87
- }
88
-
89
- if (!multipleValues) {
90
- const selectedValue = predefinedValues.values.find(value => {
91
- return !!value.selected;
92
- });
93
-
94
- if (selectedValue) {
95
- return convertDefaultValue(field, selectedValue.value);
96
- }
97
-
98
- return undefined;
99
- }
100
-
101
- return predefinedValues.values.filter(({
102
- selected
103
- }) => !!selected).map(({
104
- value
105
- }) => {
106
- return convertDefaultValue(field, value);
107
- });
108
- };
109
- /**
110
- * Cleans and adds default values to create input data.
111
- */
112
-
113
-
114
- const mapAndCleanCreateInputData = (model, input) => {
115
- return model.fields.reduce((acc, field) => {
116
- /**
117
- * This should never happen, but let's make it sure.
118
- * The fix would be for the user to add the fieldId on the field definition.
119
- */
120
- if (!field.fieldId) {
121
- throw new _error.default("Field does not have an fieldId.", "MISSING_FIELD_ID", {
122
- field
123
- });
124
- }
125
-
126
- const value = input[field.fieldId];
127
- /**
128
- * We set the default value on create input if value is not defined.
129
- */
130
-
131
- acc[field.fieldId] = value === undefined ? getDefaultValue(field) : value;
132
- return acc;
133
- }, {});
134
- };
135
- /**
136
- * Cleans the update input entry data.
137
- */
138
-
139
-
140
- const mapAndCleanUpdatedInputData = (model, input) => {
141
- return model.fields.reduce((acc, field) => {
142
- /**
143
- * This should never happen, but let's make it sure.
144
- * The fix would be for the user to add the fieldId on the field definition.
145
- */
146
- if (!field.fieldId) {
147
- throw new _error.default("Field does not have an fieldId.", "MISSING_FIELD_ID", {
148
- field
149
- });
150
- }
151
- /**
152
- * We cannot set default value here because user might want to update only certain field values.
153
- */
154
-
155
-
156
- const value = input[field.fieldId];
157
-
158
- if (value === undefined) {
159
- return acc;
160
- }
161
-
162
- acc[field.fieldId] = value;
163
- return acc;
164
- }, {});
165
- };
166
- /**
167
- * This method takes original entry meta and new input.
168
- * When new meta is merged onto the existing one, everything that has undefined or null value is removed.
169
- */
170
-
171
-
172
- const createEntryMeta = (input, original) => {
173
- const meta = (0, _merge.default)(original || {}, input || {});
174
-
175
- for (const key in meta) {
176
- if (meta[key] !== undefined || meta[key] !== null) {
177
- continue;
178
- }
179
-
180
- delete meta[key];
181
- }
182
-
183
- return meta;
184
- };
185
-
186
- const createEntryId = version => {
187
- const entryId = (0, _mdbid.default)();
188
- return {
189
- entryId,
190
- version,
191
- id: (0, _utils.createIdentifier)({
192
- id: entryId,
193
- version
194
- })
195
- };
196
- };
197
-
198
- const increaseEntryIdVersion = id => {
199
- const {
200
- id: entryId,
201
- version
202
- } = (0, _utils.parseIdentifier)(id);
203
-
204
- if (!version) {
205
- throw new _error.default("Cannot increase version on the ID without the version part.", "WRONG_ID", {
206
- id
207
- });
208
- }
209
-
210
- return {
211
- entryId,
212
- version: version + 1,
213
- id: (0, _utils.createIdentifier)({
214
- id: entryId,
215
- version: version + 1
216
- })
217
- };
218
- };
219
-
220
- const getSearchableFields = params => {
221
- const {
222
- plugins,
223
- model,
224
- fields
225
- } = params;
226
- const fieldPluginMap = plugins.byType("cms-model-field-to-graphql").reduce((collection, field) => {
227
- collection[field.fieldType] = field;
228
- return collection;
229
- }, {});
230
- return model.fields.filter(field => {
231
- if (!field.fieldId) {
232
- return false;
233
- }
234
-
235
- const plugin = fieldPluginMap[field.type];
236
-
237
- if (!plugin) {
238
- return false;
239
- } else if (!plugin.fullTextSearch) {
240
- return false;
241
- } else if (!fields || fields.length === 0) {
242
- return true;
243
- }
244
-
245
- return fields.includes(field.fieldId);
246
- }).map(field => field.fieldId);
247
- };
248
-
249
- const allowedEntryStatus = ["draft", "published", "unpublished"];
250
-
251
- const transformEntryStatus = status => {
252
- return allowedEntryStatus.includes(status) ? status : "draft";
253
- };
254
-
17
+ var _searchableFields = require("./contentEntry/searchableFields");
18
+ var _filterAsync = require("../utils/filterAsync");
19
+ var _constants = require("../constants");
20
+ var _entryDataFactories = require("./contentEntry/entryDataFactories");
21
+ var _useCases = require("./contentEntry/useCases");
22
+ var _ContentEntryTraverser = require("../utils/contentEntryTraverser/ContentEntryTraverser");
255
23
  const createContentEntryCrud = params => {
256
24
  const {
257
25
  storageOperations,
26
+ accessControl,
258
27
  context,
259
- getIdentity,
260
- getTenant
28
+ getIdentity: getSecurityIdentity,
29
+ getTenant,
30
+ getLocale
261
31
  } = params;
262
- const {
263
- plugins
264
- } = context; // create
265
32
 
33
+ /**
34
+ * Create
35
+ */
266
36
  const onEntryBeforeCreate = (0, _pubsub.createTopic)("cms.onEntryBeforeCreate");
267
37
  const onEntryAfterCreate = (0, _pubsub.createTopic)("cms.onEntryAfterCreate");
268
- const onEntryCreateError = (0, _pubsub.createTopic)("cms.onEntryCreateError"); // create revision
38
+ const onEntryCreateError = (0, _pubsub.createTopic)("cms.onEntryCreateError");
269
39
 
40
+ /**
41
+ * Create new revision
42
+ */
270
43
  const onEntryBeforeCreateRevision = (0, _pubsub.createTopic)("cms.onEntryBeforeCreateRevision");
271
44
  const onEntryRevisionAfterCreate = (0, _pubsub.createTopic)("cms.onEntryRevisionAfterCreate");
272
- const onEntryCreateRevisionError = (0, _pubsub.createTopic)("cms.onEntryCreateRevisionError"); // update
45
+ const onEntryCreateRevisionError = (0, _pubsub.createTopic)("cms.onEntryCreateRevisionError");
273
46
 
47
+ /**
48
+ * Update
49
+ */
274
50
  const onEntryBeforeUpdate = (0, _pubsub.createTopic)("cms.onEntryBeforeUpdate");
275
51
  const onEntryAfterUpdate = (0, _pubsub.createTopic)("cms.onEntryAfterUpdate");
276
- const onEntryUpdateError = (0, _pubsub.createTopic)("cms.onEntryUpdateError"); // publish
52
+ const onEntryUpdateError = (0, _pubsub.createTopic)("cms.onEntryUpdateError");
53
+
54
+ /**
55
+ * Move
56
+ */
57
+ const onEntryBeforeMove = (0, _pubsub.createTopic)("cms.onEntryBeforeMove");
58
+ const onEntryAfterMove = (0, _pubsub.createTopic)("cms.onEntryAfterMove");
59
+ const onEntryMoveError = (0, _pubsub.createTopic)("cms.onEntryMoveError");
277
60
 
61
+ /**
62
+ * Publish
63
+ */
278
64
  const onEntryBeforePublish = (0, _pubsub.createTopic)("cms.onEntryBeforePublish");
279
- const onEntryAfterPublish = (0, _pubsub.createTopic)("cms.onEntryAfterPublic");
280
- const onEntryPublishError = (0, _pubsub.createTopic)("cms.onEntryPublishError"); // unpublish
65
+ const onEntryAfterPublish = (0, _pubsub.createTopic)("cms.onEntryAfterPublish");
66
+ const onEntryPublishError = (0, _pubsub.createTopic)("cms.onEntryPublishError");
67
+
68
+ /**
69
+ * Republish
70
+ */
71
+ const onEntryBeforeRepublish = (0, _pubsub.createTopic)("cms.onEntryBeforeRepublish");
72
+ const onEntryAfterRepublish = (0, _pubsub.createTopic)("cms.onEntryAfterRepublish");
73
+ const onEntryRepublishError = (0, _pubsub.createTopic)("cms.onEntryRepublishError");
281
74
 
75
+ /**
76
+ * Unpublish
77
+ */
282
78
  const onEntryBeforeUnpublish = (0, _pubsub.createTopic)("cms.onEntryBeforeUnpublish");
283
79
  const onEntryAfterUnpublish = (0, _pubsub.createTopic)("cms.onEntryAfterUnpublish");
284
- const onEntryUnpublishError = (0, _pubsub.createTopic)("cms.onEntryUnpublishError"); // delete
80
+ const onEntryUnpublishError = (0, _pubsub.createTopic)("cms.onEntryUnpublishError");
285
81
 
82
+ /**
83
+ * Delete
84
+ */
286
85
  const onEntryBeforeDelete = (0, _pubsub.createTopic)("cms.onEntryBeforeDelete");
287
86
  const onEntryAfterDelete = (0, _pubsub.createTopic)("cms.onEntryAfterDelete");
288
- const onEntryDeleteError = (0, _pubsub.createTopic)("cms.onEntryDeleteError"); // delete revision
87
+ const onEntryDeleteError = (0, _pubsub.createTopic)("cms.onEntryDeleteError");
88
+
89
+ /**
90
+ * Restore from bin
91
+ */
92
+ const onEntryBeforeRestoreFromBin = (0, _pubsub.createTopic)("cms.onEntryBeforeRestoreFromBin");
93
+ const onEntryAfterRestoreFromBin = (0, _pubsub.createTopic)("cms.onEntryAfterRestoreFromBin");
94
+ const onEntryRestoreFromBinError = (0, _pubsub.createTopic)("cms.onEntryRestoreFromBinError");
289
95
 
96
+ /**
97
+ * Delete revision
98
+ */
290
99
  const onEntryRevisionBeforeDelete = (0, _pubsub.createTopic)("cms.onEntryRevisionBeforeDelete");
291
100
  const onEntryRevisionAfterDelete = (0, _pubsub.createTopic)("cms.onEntryRevisionAfterDelete");
292
- const onEntryRevisionDeleteError = (0, _pubsub.createTopic)("cms.onEntryRevisionDeleteError"); // get
101
+ const onEntryRevisionDeleteError = (0, _pubsub.createTopic)("cms.onEntryRevisionDeleteError");
102
+ /**
103
+ * Delete multiple entries
104
+ */
105
+ const onEntryBeforeDeleteMultiple = (0, _pubsub.createTopic)("cms.onEntryBeforeDeleteMultiple");
106
+ const onEntryAfterDeleteMultiple = (0, _pubsub.createTopic)("cms.onEntryAfterDeleteMultiple");
107
+ const onEntryDeleteMultipleError = (0, _pubsub.createTopic)("cms.onEntryDeleteMultipleError");
293
108
 
294
- const onEntryBeforeGet = (0, _pubsub.createTopic)("cms.onEntryBeforeGet"); // list
109
+ /**
110
+ * Get entry
111
+ */
112
+ const onEntryBeforeGet = (0, _pubsub.createTopic)("cms.onEntryBeforeGet");
295
113
 
114
+ /**
115
+ * List entries
116
+ */
296
117
  const onEntryBeforeList = (0, _pubsub.createTopic)("cms.onEntryBeforeList");
118
+
297
119
  /**
298
120
  * We need to assign some default behaviors.
299
121
  */
300
-
301
122
  (0, _beforeCreate.assignBeforeEntryCreate)({
302
123
  context,
303
124
  onEntryBeforeCreate
@@ -310,946 +131,1123 @@ const createContentEntryCrud = params => {
310
131
  context,
311
132
  onEntryAfterDelete
312
133
  });
134
+ const transformEntryFromStorageCallable = (0, _entryStorage.createTransformEntryCallable)({
135
+ context
136
+ });
137
+ /**
138
+ * List entries
139
+ */
140
+ const {
141
+ listEntriesUseCase,
142
+ listLatestUseCase,
143
+ listDeletedUseCase,
144
+ listPublishedUseCase,
145
+ getEntryUseCase
146
+ } = (0, _useCases.listEntriesUseCases)({
147
+ transform: transformEntryFromStorageCallable,
148
+ operation: storageOperations.entries.list,
149
+ accessControl,
150
+ topics: {
151
+ onEntryBeforeList
152
+ },
153
+ context,
154
+ getIdentity: getSecurityIdentity
155
+ });
156
+
157
+ /**
158
+ * Get entries by ids
159
+ */
160
+ const {
161
+ getEntriesByIdsUseCase
162
+ } = (0, _useCases.getEntriesByIdsUseCases)({
163
+ transform: transformEntryFromStorageCallable,
164
+ operation: storageOperations.entries.getByIds,
165
+ accessControl
166
+ });
167
+
168
+ /**
169
+ * Get latest entries by ids
170
+ */
171
+ const {
172
+ getLatestEntriesByIdsUseCase
173
+ } = (0, _useCases.getLatestEntriesByIdsUseCases)({
174
+ transform: transformEntryFromStorageCallable,
175
+ operation: storageOperations.entries.getLatestByIds,
176
+ accessControl
177
+ });
178
+
179
+ /**
180
+ * Get published entries by ids
181
+ */
182
+ const {
183
+ getPublishedEntriesByIdsUseCase
184
+ } = (0, _useCases.getPublishedEntriesByIdsUseCases)({
185
+ transform: transformEntryFromStorageCallable,
186
+ operation: storageOperations.entries.getPublishedByIds,
187
+ accessControl
188
+ });
189
+
190
+ /**
191
+ * Get revisions by entryId
192
+ */
193
+ const {
194
+ getRevisionsByEntryIdUseCase
195
+ } = (0, _useCases.getRevisionsByEntryIdUseCases)({
196
+ transform: transformEntryFromStorageCallable,
197
+ operation: storageOperations.entries.getRevisions,
198
+ accessControl
199
+ });
200
+
201
+ /**
202
+ * Get revision by id
203
+ */
204
+ const {
205
+ getRevisionByIdUseCase
206
+ } = (0, _useCases.getRevisionByIdUseCases)({
207
+ transform: transformEntryFromStorageCallable,
208
+ operation: storageOperations.entries.getRevisionById
209
+ });
210
+
211
+ /**
212
+ * Get latest revision by entryId
213
+ */
214
+ const {
215
+ getLatestRevisionByEntryIdUseCase,
216
+ getLatestRevisionByEntryIdWithDeletedUseCase,
217
+ getLatestRevisionByEntryIdDeletedUseCase
218
+ } = (0, _useCases.getLatestRevisionByEntryIdUseCases)({
219
+ transform: transformEntryFromStorageCallable,
220
+ operation: storageOperations.entries.getLatestRevisionByEntryId
221
+ });
222
+
223
+ /**
224
+ * Get previous revision by entryId
225
+ */
226
+ const {
227
+ getPreviousRevisionByEntryIdUseCase
228
+ } = (0, _useCases.getPreviousRevisionByEntryIdUseCases)({
229
+ transform: transformEntryFromStorageCallable,
230
+ operation: storageOperations.entries.getPreviousRevision
231
+ });
313
232
 
314
- const checkEntryPermissions = check => {
315
- return (0, _permissions.checkPermissions)(context, "cms.contentEntry", check);
316
- };
317
233
  /**
318
- * A helper to delete the entire entry.
234
+ * Get published revision by entryId
319
235
  */
236
+ const {
237
+ getPublishedRevisionByEntryIdUseCase
238
+ } = (0, _useCases.getPublishedRevisionByEntryIdUseCases)({
239
+ transform: transformEntryFromStorageCallable,
240
+ operation: storageOperations.entries.getPublishedRevisionByEntryId
241
+ });
320
242
 
243
+ /**
244
+ * Delete entry
245
+ */
246
+ const {
247
+ deleteEntryUseCase,
248
+ moveEntryToBinUseCase,
249
+ deleteEntryOperation
250
+ } = (0, _useCases.deleteEntryUseCases)({
251
+ deleteOperation: storageOperations.entries.delete,
252
+ moveToBinOperation: storageOperations.entries.moveToBin,
253
+ getEntry: getLatestRevisionByEntryIdUseCase,
254
+ getEntryWithDeleted: getLatestRevisionByEntryIdWithDeletedUseCase,
255
+ getIdentity: getSecurityIdentity,
256
+ topics: {
257
+ onEntryBeforeDelete,
258
+ onEntryAfterDelete,
259
+ onEntryDeleteError
260
+ },
261
+ accessControl,
262
+ context
263
+ });
321
264
 
322
- const deleteEntry = async params => {
265
+ /**
266
+ * Restore entry from bin
267
+ */
268
+ const {
269
+ restoreEntryFromBinUseCase
270
+ } = (0, _useCases.restoreEntryFromBinUseCases)({
271
+ transform: transformEntryFromStorageCallable,
272
+ getEntry: getLatestRevisionByEntryIdDeletedUseCase,
273
+ getIdentity: getSecurityIdentity,
274
+ restoreOperation: storageOperations.entries.restoreFromBin,
275
+ topics: {
276
+ onEntryBeforeRestoreFromBin,
277
+ onEntryAfterRestoreFromBin,
278
+ onEntryRestoreFromBinError
279
+ },
280
+ accessControl,
281
+ context
282
+ });
283
+ const getEntryById = async (model, id) => {
284
+ const where = {
285
+ id
286
+ };
287
+ await onEntryBeforeGet.publish({
288
+ where,
289
+ model
290
+ });
291
+ const [entry] = await getEntriesByIdsUseCase.execute(model, {
292
+ ids: [id]
293
+ });
294
+ if (!entry) {
295
+ throw new _handlerGraphql.NotFoundError(`Entry by ID "${id}" not found.`);
296
+ }
297
+ // TODO figure out without casting
298
+ return entry;
299
+ };
300
+ const createEntry = async (model, rawInput, options) => {
301
+ await accessControl.ensureCanAccessEntry({
302
+ model,
303
+ rwd: "w"
304
+ });
323
305
  const {
306
+ entry,
307
+ input
308
+ } = await (0, _entryDataFactories.createEntryData)({
309
+ context,
324
310
  model,
325
- entry
326
- } = params;
327
-
311
+ options,
312
+ rawInput,
313
+ getLocale,
314
+ getTenant,
315
+ getIdentity: getSecurityIdentity,
316
+ accessControl
317
+ });
318
+ await accessControl.ensureCanAccessEntry({
319
+ model,
320
+ entry,
321
+ rwd: "w"
322
+ });
323
+ let storageEntry = null;
328
324
  try {
329
- await onEntryBeforeDelete.publish({
325
+ await onEntryBeforeCreate.publish({
330
326
  entry,
327
+ input,
331
328
  model
332
329
  });
333
- await storageOperations.entries.delete(model, {
334
- entry
330
+ storageEntry = await (0, _entryStorage.entryToStorageTransform)(context, model, entry);
331
+ const result = await storageOperations.entries.create(model, {
332
+ entry,
333
+ storageEntry
335
334
  });
336
- await onEntryAfterDelete.publish({
335
+ await onEntryAfterCreate.publish({
337
336
  entry,
338
- model
337
+ storageEntry: result,
338
+ model,
339
+ input
339
340
  });
341
+ return entry;
340
342
  } catch (ex) {
341
- await onEntryDeleteError.publish({
343
+ await onEntryCreateError.publish({
344
+ error: ex,
342
345
  entry,
343
346
  model,
344
- error: ex
347
+ input
345
348
  });
346
- throw new _error.default(ex.message || "Could not delete entry.", ex.code || "DELETE_ERROR", {
347
- entry
349
+ throw new _error.default(ex.message || "Could not create content entry.", ex.code || "CREATE_ENTRY_ERROR", ex.data || {
350
+ error: ex,
351
+ input,
352
+ entry,
353
+ storageEntry
348
354
  });
349
355
  }
350
356
  };
351
- /**
352
- * A helper to get entries by revision IDs
353
- */
354
-
355
-
356
- const getEntriesByIds = async (initialModel, ids) => {
357
- const permission = await checkEntryPermissions({
358
- rwd: "r"
357
+ const createEntryRevisionFrom = async (model, sourceId, rawInput, options) => {
358
+ await accessControl.ensureCanAccessEntry({
359
+ model,
360
+ rwd: "w"
359
361
  });
360
- await (0, _access.checkModelAccess)(context, initialModel);
361
- const model = (0, _valueKeyStorageConverter.attachCmsModelFieldConverters)({
362
- model: initialModel,
363
- plugins
362
+
363
+ /**
364
+ * Entries are identified by a common parent ID + Revision number.
365
+ */
366
+ const {
367
+ id: uniqueId
368
+ } = (0, _utils.parseIdentifier)(sourceId);
369
+ const originalStorageEntry = await getRevisionByIdUseCase.execute(model, {
370
+ id: sourceId
364
371
  });
365
- const entries = await storageOperations.entries.getByIds(model, {
366
- ids
372
+ const latestStorageEntry = await getLatestRevisionByEntryIdUseCase.execute(model, {
373
+ id: uniqueId
367
374
  });
368
- return entries.filter(entry => (0, _ownership.validateOwnership)(context, permission, entry));
369
- };
375
+ if (!originalStorageEntry) {
376
+ throw new _handlerGraphql.NotFoundError(`Entry "${sourceId}" of model "${model.modelId}" was not found.`);
377
+ }
378
+ if (!latestStorageEntry) {
379
+ throw new _handlerGraphql.NotFoundError(`Latest entry "${uniqueId}" of model "${model.modelId}" was not found.`);
380
+ }
370
381
 
371
- return {
372
382
  /**
373
- * Deprecated - will be removed in 5.35.0
383
+ * We need to convert data from DB to its original form before using it further.
374
384
  */
375
- onBeforeEntryCreate: onEntryBeforeCreate,
376
- onAfterEntryCreate: onEntryAfterCreate,
377
- onBeforeEntryCreateRevision: onEntryBeforeCreateRevision,
378
- onAfterEntryCreateRevision: onEntryRevisionAfterCreate,
379
- onBeforeEntryUpdate: onEntryBeforeUpdate,
380
- onAfterEntryUpdate: onEntryAfterUpdate,
381
- onBeforeEntryDelete: onEntryBeforeDelete,
382
- onAfterEntryDelete: onEntryAfterDelete,
383
- onBeforeEntryDeleteRevision: onEntryRevisionBeforeDelete,
384
- onAfterEntryDeleteRevision: onEntryRevisionAfterDelete,
385
- onBeforeEntryPublish: onEntryBeforePublish,
386
- onAfterEntryPublish: onEntryAfterPublish,
387
- onBeforeEntryUnpublish: onEntryBeforeUnpublish,
388
- onAfterEntryUnpublish: onEntryAfterUnpublish,
389
- onBeforeEntryGet: onEntryBeforeGet,
390
- onBeforeEntryList: onEntryBeforeList,
385
+ const originalEntry = await (0, _entryStorage.entryFromStorageTransform)(context, model, originalStorageEntry);
386
+ const {
387
+ entry,
388
+ input
389
+ } = await (0, _entryDataFactories.createEntryRevisionFromData)({
390
+ sourceId,
391
+ model,
392
+ rawInput,
393
+ options,
394
+ context,
395
+ getIdentity: getSecurityIdentity,
396
+ getTenant,
397
+ getLocale,
398
+ originalEntry,
399
+ latestStorageEntry,
400
+ accessControl
401
+ });
402
+ await accessControl.ensureCanAccessEntry({
403
+ model,
404
+ entry,
405
+ rwd: "w"
406
+ });
407
+ let storageEntry = null;
408
+ try {
409
+ await onEntryBeforeCreateRevision.publish({
410
+ input,
411
+ entry,
412
+ original: originalEntry,
413
+ model
414
+ });
415
+ storageEntry = await (0, _entryStorage.entryToStorageTransform)(context, model, entry);
416
+ const result = await storageOperations.entries.createRevisionFrom(model, {
417
+ entry,
418
+ storageEntry
419
+ });
420
+ await onEntryRevisionAfterCreate.publish({
421
+ input,
422
+ entry,
423
+ model,
424
+ original: originalEntry,
425
+ storageEntry: result
426
+ });
427
+ return entry;
428
+ } catch (ex) {
429
+ await onEntryCreateRevisionError.publish({
430
+ entry,
431
+ original: originalEntry,
432
+ model,
433
+ input,
434
+ error: ex
435
+ });
436
+ throw new _error.default(ex.message || "Could not create entry from existing one.", ex.code || "CREATE_FROM_REVISION_ERROR", {
437
+ error: ex,
438
+ entry,
439
+ storageEntry,
440
+ originalEntry,
441
+ originalStorageEntry
442
+ });
443
+ }
444
+ };
445
+ const updateEntry = async (model, id, rawInput, metaInput, options) => {
446
+ await accessControl.ensureCanAccessEntry({
447
+ model,
448
+ rwd: "w"
449
+ });
391
450
 
392
451
  /**
393
- * Released in 5.34.0
452
+ * The entry we are going to update.
394
453
  */
395
- onEntryBeforeCreate,
396
- onEntryAfterCreate,
397
- onEntryCreateError,
398
- onEntryRevisionBeforeCreate: onEntryBeforeCreateRevision,
399
- onEntryRevisionAfterCreate,
400
- onEntryRevisionCreateError: onEntryCreateRevisionError,
401
- onEntryBeforeUpdate,
454
+ const originalStorageEntry = await getRevisionByIdUseCase.execute(model, {
455
+ id
456
+ });
457
+ if (!originalStorageEntry) {
458
+ throw new _handlerGraphql.NotFoundError(`Entry "${id}" of model "${model.modelId}" was not found.`);
459
+ }
460
+ if (originalStorageEntry.locked) {
461
+ throw new _error.default(`Cannot update entry because it's locked.`, "CONTENT_ENTRY_UPDATE_ERROR");
462
+ }
463
+ const originalEntry = await (0, _entryStorage.entryFromStorageTransform)(context, model, originalStorageEntry);
464
+ const {
465
+ entry,
466
+ input
467
+ } = await (0, _entryDataFactories.createUpdateEntryData)({
468
+ model,
469
+ rawInput,
470
+ options,
471
+ context,
472
+ getIdentity: getSecurityIdentity,
473
+ getTenant,
474
+ getLocale,
475
+ originalEntry,
476
+ metaInput
477
+ });
478
+ await accessControl.ensureCanAccessEntry({
479
+ model,
480
+ entry,
481
+ rwd: "w"
482
+ });
483
+ let storageEntry = null;
484
+ try {
485
+ await onEntryBeforeUpdate.publish({
486
+ entry,
487
+ model,
488
+ input,
489
+ original: originalEntry
490
+ });
491
+ storageEntry = await (0, _entryStorage.entryToStorageTransform)(context, model, entry);
492
+ const result = await storageOperations.entries.update(model, {
493
+ entry,
494
+ storageEntry
495
+ });
496
+ await onEntryAfterUpdate.publish({
497
+ entry,
498
+ storageEntry: result,
499
+ model,
500
+ input,
501
+ original: originalEntry
502
+ });
503
+ return entry;
504
+ } catch (ex) {
505
+ await onEntryUpdateError.publish({
506
+ entry,
507
+ model,
508
+ input,
509
+ error: ex
510
+ });
511
+ throw new _error.default(ex.message || "Could not update existing entry.", ex.code || "UPDATE_ERROR", {
512
+ error: ex,
513
+ entry,
514
+ storageEntry,
515
+ originalEntry,
516
+ input
517
+ });
518
+ }
519
+ };
520
+ const validateEntry = async (model, id, inputData) => {
521
+ await accessControl.ensureCanAccessEntry({
522
+ model,
523
+ rwd: "w"
524
+ });
525
+ const input = (0, _entryDataFactories.mapAndCleanUpdatedInputData)(model, inputData || {});
526
+ let originalEntry;
527
+ if (id) {
528
+ /**
529
+ * The entry we are going to update.
530
+ */
531
+ const originalStorageEntry = await getRevisionByIdUseCase.execute(model, {
532
+ id
533
+ });
534
+ if (!originalStorageEntry) {
535
+ throw new _handlerGraphql.NotFoundError(`Entry "${id}" of model "${model.modelId}" was not found.`);
536
+ }
537
+ originalEntry = await (0, _entryStorage.entryFromStorageTransform)(context, model, originalStorageEntry);
538
+ }
539
+ await accessControl.ensureCanAccessEntry({
540
+ model,
541
+ entry: originalEntry,
542
+ rwd: "w"
543
+ });
544
+ const result = await (0, _entryDataValidation.validateModelEntryData)({
545
+ context,
546
+ model,
547
+ data: input,
548
+ entry: originalEntry
549
+ });
550
+ return result.length > 0 ? result : [];
551
+ };
552
+ const moveEntry = async (model, id, folderId) => {
553
+ await accessControl.ensureCanAccessEntry({
554
+ model,
555
+ rwd: "w"
556
+ });
557
+
558
+ /**
559
+ * The entry we are going to move to another folder.
560
+ */
561
+ const originalStorageEntry = await getRevisionByIdUseCase.execute(model, {
562
+ id
563
+ });
564
+ if (!originalStorageEntry) {
565
+ throw new _handlerGraphql.NotFoundError(`Entry "${id}" of model "${model.modelId}" was not found.`);
566
+ }
567
+ const entry = await (0, _entryStorage.entryFromStorageTransform)(context, model, originalStorageEntry);
568
+ await accessControl.ensureCanAccessEntry({
569
+ model,
570
+ entry,
571
+ rwd: "w"
572
+ });
573
+
574
+ /**
575
+ * No need to continue if the entry is already in the requested folder.
576
+ */
577
+ if (entry.location?.folderId === folderId) {
578
+ return entry;
579
+ }
580
+ try {
581
+ await onEntryBeforeMove.publish({
582
+ entry,
583
+ model,
584
+ folderId
585
+ });
586
+ await storageOperations.entries.move(model, id, folderId);
587
+ await onEntryAfterMove.publish({
588
+ entry,
589
+ model,
590
+ folderId
591
+ });
592
+ return entry;
593
+ } catch (ex) {
594
+ await onEntryMoveError.publish({
595
+ entry,
596
+ model,
597
+ folderId,
598
+ error: ex
599
+ });
600
+ throw _error.default.from(ex, {
601
+ message: `Could not move entry "${id}" of model "${model.modelId}".`,
602
+ code: "MOVE_ENTRY_ERROR"
603
+ });
604
+ }
605
+ };
606
+ const republishEntry = async (model, id) => {
607
+ await accessControl.ensureCanAccessEntry({
608
+ model,
609
+ rwd: "w",
610
+ pw: "p"
611
+ });
612
+
613
+ /**
614
+ * Fetch the entry from the storage.
615
+ */
616
+ const originalStorageEntry = await getRevisionByIdUseCase.execute(model, {
617
+ id
618
+ });
619
+ if (!originalStorageEntry) {
620
+ throw new _handlerGraphql.NotFoundError(`Entry "${id}" was not found!`);
621
+ }
622
+ const originalEntry = await (0, _entryStorage.entryFromStorageTransform)(context, model, originalStorageEntry);
623
+ await accessControl.ensureCanAccessEntry({
624
+ model,
625
+ entry: originalEntry,
626
+ rwd: "w",
627
+ pw: "p"
628
+ });
629
+ const {
630
+ entry
631
+ } = await (0, _entryDataFactories.createRepublishEntryData)({
632
+ context,
633
+ model,
634
+ originalEntry,
635
+ getIdentity: getSecurityIdentity
636
+ });
637
+ const storageEntry = await (0, _entryStorage.entryToStorageTransform)(context, model, entry);
638
+ /**
639
+ * First we need to update existing entry.
640
+ */
641
+ try {
642
+ await storageOperations.entries.update(model, {
643
+ entry,
644
+ storageEntry
645
+ });
646
+ } catch (ex) {
647
+ throw new _error.default("Could not update existing entry with new data while re-publishing.", "REPUBLISH_UPDATE_ERROR", {
648
+ entry
649
+ });
650
+ }
651
+ /**
652
+ * Then we move onto publishing it again.
653
+ */
654
+ try {
655
+ await onEntryBeforeRepublish.publish({
656
+ entry,
657
+ model
658
+ });
659
+ const result = await storageOperations.entries.publish(model, {
660
+ entry,
661
+ storageEntry
662
+ });
663
+ await onEntryAfterRepublish.publish({
664
+ entry,
665
+ model,
666
+ storageEntry: result
667
+ });
668
+ return entry;
669
+ } catch (ex) {
670
+ await onEntryRepublishError.publish({
671
+ entry,
672
+ model,
673
+ error: ex
674
+ });
675
+ throw new _error.default("Could not publish existing entry while re-publishing.", "REPUBLISH_PUBLISH_ERROR", {
676
+ entry
677
+ });
678
+ }
679
+ };
680
+ const deleteEntryRevision = async (model, revisionId) => {
681
+ await accessControl.ensureCanAccessEntry({
682
+ model,
683
+ rwd: "d"
684
+ });
685
+ const {
686
+ id: entryId,
687
+ version
688
+ } = (0, _utils.parseIdentifier)(revisionId);
689
+ const storageEntryToDelete = await getRevisionByIdUseCase.execute(model, {
690
+ id: revisionId
691
+ });
692
+ const latestStorageEntry = await getLatestRevisionByEntryIdUseCase.execute(model, {
693
+ id: entryId
694
+ });
695
+ const storagePreviousEntry = await getPreviousRevisionByEntryIdUseCase.execute(model, {
696
+ entryId,
697
+ version: version
698
+ });
699
+ if (!storageEntryToDelete) {
700
+ throw new _handlerGraphql.NotFoundError(`Entry "${revisionId}" was not found!`);
701
+ }
702
+ const latestEntryRevisionId = latestStorageEntry ? latestStorageEntry.id : null;
703
+ const entryToDelete = await (0, _entryStorage.entryFromStorageTransform)(context, model, storageEntryToDelete);
704
+ await accessControl.ensureCanAccessEntry({
705
+ model,
706
+ entry: entryToDelete,
707
+ rwd: "d"
708
+ });
709
+
710
+ /**
711
+ * If targeted record is the latest entry record and there is no previous one, we need
712
+ * to run full delete with hooks. In this case, `deleteRevision` hooks are not fired.
713
+ */
714
+ if (entryToDelete.id === latestEntryRevisionId && !storagePreviousEntry) {
715
+ return await deleteEntryOperation.execute(model, {
716
+ entry: entryToDelete
717
+ });
718
+ }
719
+ /**
720
+ * If targeted record is the latest entry revision, set the previous one as the new latest.
721
+ */
722
+ let entryToSetAsLatest = null;
723
+ let storageEntryToSetAsLatest = null;
724
+ let updatedEntryToSetAsLatest = null;
725
+ let storageUpdatedEntryToSetAsLatest = null;
726
+ if (entryToDelete.id === latestEntryRevisionId && storagePreviousEntry) {
727
+ entryToSetAsLatest = await (0, _entryStorage.entryFromStorageTransform)(context, model, storagePreviousEntry);
728
+ storageEntryToSetAsLatest = storagePreviousEntry;
729
+
730
+ /**
731
+ * Since we're setting a different revision as the latest, we need to update entry-level meta
732
+ * fields. The values are taken from the latest revision we're about to delete. The update of the
733
+ * new latest revision is performed within storage operations.
734
+ */
735
+ const pickedEntryLevelMetaFields = (0, _constants.pickEntryMetaFields)(entryToDelete, _constants.isEntryLevelEntryMetaField);
736
+ updatedEntryToSetAsLatest = {
737
+ ...entryToSetAsLatest,
738
+ ...pickedEntryLevelMetaFields
739
+ };
740
+ storageUpdatedEntryToSetAsLatest = {
741
+ ...storageEntryToSetAsLatest,
742
+ ...pickedEntryLevelMetaFields
743
+ };
744
+ }
745
+ try {
746
+ await onEntryRevisionBeforeDelete.publish({
747
+ entry: entryToDelete,
748
+ model
749
+ });
750
+ await storageOperations.entries.deleteRevision(model, {
751
+ entry: entryToDelete,
752
+ storageEntry: storageEntryToDelete,
753
+ latestEntry: updatedEntryToSetAsLatest,
754
+ latestStorageEntry: storageUpdatedEntryToSetAsLatest
755
+ });
756
+ await onEntryRevisionAfterDelete.publish({
757
+ entry: entryToDelete,
758
+ model
759
+ });
760
+ } catch (ex) {
761
+ await onEntryRevisionDeleteError.publish({
762
+ entry: entryToDelete,
763
+ model,
764
+ error: ex
765
+ });
766
+ throw new _error.default(ex.message, ex.code || "DELETE_REVISION_ERROR", {
767
+ error: ex,
768
+ entry: entryToDelete,
769
+ storageEntry: storageEntryToDelete,
770
+ latestEntry: updatedEntryToSetAsLatest,
771
+ latestStorageEntry: storageUpdatedEntryToSetAsLatest
772
+ });
773
+ }
774
+ };
775
+ const deleteMultipleEntries = async (model, params) => {
776
+ const {
777
+ entries: input
778
+ } = params;
779
+ const maxDeletableEntries = 50;
780
+ const entryIdList = new Set();
781
+ for (const id of input) {
782
+ const {
783
+ id: entryId
784
+ } = (0, _utils.parseIdentifier)(id);
785
+ entryIdList.add(entryId);
786
+ }
787
+ const ids = Array.from(entryIdList);
788
+ if (ids.length > maxDeletableEntries) {
789
+ throw new _error.default("Cannot delete more than 50 entries at once.", "DELETE_ENTRIES_MAX", {
790
+ entries: ids
791
+ });
792
+ }
793
+ await accessControl.ensureCanAccessEntry({
794
+ model,
795
+ rwd: "d"
796
+ });
797
+ const {
798
+ items: entries
799
+ } = await storageOperations.entries.list(model, {
800
+ where: {
801
+ latest: true,
802
+ entryId_in: ids
803
+ },
804
+ limit: maxDeletableEntries + 1
805
+ });
806
+ /**
807
+ * We do not want to allow deleting entries that user does not own or cannot access.
808
+ */
809
+ const items = (await (0, _filterAsync.filterAsync)(entries, async entry => {
810
+ return accessControl.canAccessEntry({
811
+ model,
812
+ entry: entry
813
+ });
814
+ })).map(entry => entry.id);
815
+ try {
816
+ await onEntryBeforeDeleteMultiple.publish({
817
+ entries,
818
+ ids,
819
+ model
820
+ });
821
+ await storageOperations.entries.deleteMultipleEntries(model, {
822
+ entries: items
823
+ });
824
+ await onEntryAfterDeleteMultiple.publish({
825
+ entries,
826
+ ids,
827
+ model
828
+ });
829
+ return items.map(id => {
830
+ return {
831
+ id
832
+ };
833
+ });
834
+ } catch (ex) {
835
+ await onEntryDeleteMultipleError.publish({
836
+ entries,
837
+ ids,
838
+ model,
839
+ error: ex
840
+ });
841
+ throw new _error.default(ex.message, ex.code || "DELETE_ENTRIES_MULTIPLE_ERROR", {
842
+ error: ex,
843
+ entries
844
+ });
845
+ }
846
+ };
847
+ const deleteEntry = async (model, id, options = {}) => {
848
+ const {
849
+ permanently = true
850
+ } = options;
851
+
852
+ /**
853
+ * If the 'permanently' flag is set to false, the entry must be moved to the bin; otherwise, deleted.
854
+ */
855
+ if (!permanently) {
856
+ return await moveEntryToBinUseCase.execute(model, id, options);
857
+ }
858
+ return await deleteEntryUseCase.execute(model, id, options);
859
+ };
860
+ const publishEntry = async (model, id) => {
861
+ await accessControl.ensureCanAccessEntry({
862
+ model,
863
+ pw: "p"
864
+ });
865
+ const originalStorageEntry = await getRevisionByIdUseCase.execute(model, {
866
+ id
867
+ });
868
+ if (!originalStorageEntry) {
869
+ throw new _handlerGraphql.NotFoundError(`Entry "${id}" in the model "${model.modelId}" was not found.`);
870
+ }
871
+ const originalEntry = await (0, _entryStorage.entryFromStorageTransform)(context, model, originalStorageEntry);
872
+ await accessControl.ensureCanAccessEntry({
873
+ model,
874
+ entry: originalEntry,
875
+ pw: "p"
876
+ });
877
+
878
+ // We need the latest entry to get the latest entry-level meta fields.
879
+ const latestStorageEntry = await getLatestRevisionByEntryIdUseCase.execute(model, {
880
+ id: originalEntry.entryId
881
+ });
882
+ if (!latestStorageEntry) {
883
+ throw new _handlerGraphql.NotFoundError(`Entry "${id}" in the model "${model.modelId}" was not found.`);
884
+ }
885
+ const latestEntry = await (0, _entryStorage.entryFromStorageTransform)(context, model, latestStorageEntry);
886
+ const {
887
+ entry
888
+ } = await (0, _entryDataFactories.createPublishEntryData)({
889
+ context,
890
+ model,
891
+ originalEntry,
892
+ latestEntry,
893
+ getIdentity: getSecurityIdentity
894
+ });
895
+ let storageEntry = null;
896
+ try {
897
+ await onEntryBeforePublish.publish({
898
+ original: originalEntry,
899
+ entry,
900
+ model
901
+ });
902
+ storageEntry = await (0, _entryStorage.entryToStorageTransform)(context, model, entry);
903
+ const result = await storageOperations.entries.publish(model, {
904
+ entry,
905
+ storageEntry
906
+ });
907
+ await onEntryAfterPublish.publish({
908
+ original: originalEntry,
909
+ entry,
910
+ storageEntry: result,
911
+ model
912
+ });
913
+ return entry;
914
+ } catch (ex) {
915
+ await onEntryPublishError.publish({
916
+ original: originalEntry,
917
+ entry,
918
+ model,
919
+ error: ex
920
+ });
921
+ throw new _error.default(ex.message || "Could not publish entry.", ex.code || "PUBLISH_ERROR", {
922
+ error: ex,
923
+ entry,
924
+ storageEntry,
925
+ originalEntry,
926
+ originalStorageEntry
927
+ });
928
+ }
929
+ };
930
+ const unpublishEntry = async (model, id) => {
931
+ await accessControl.ensureCanAccessEntry({
932
+ model,
933
+ pw: "u"
934
+ });
935
+ const {
936
+ id: entryId
937
+ } = (0, _utils.parseIdentifier)(id);
938
+ const originalStorageEntry = await getPublishedRevisionByEntryIdUseCase.execute(model, {
939
+ id: entryId
940
+ });
941
+ if (!originalStorageEntry) {
942
+ throw new _handlerGraphql.NotFoundError(`Entry "${id}" of model "${model.modelId}" was not found.`);
943
+ }
944
+ if (originalStorageEntry.id !== id) {
945
+ throw new _error.default(`Entry is not published.`, "UNPUBLISH_ERROR", {
946
+ entry: originalStorageEntry
947
+ });
948
+ }
949
+ const originalEntry = await (0, _entryStorage.entryFromStorageTransform)(context, model, originalStorageEntry);
950
+ await accessControl.ensureCanAccessEntry({
951
+ model,
952
+ entry: originalEntry,
953
+ pw: "u"
954
+ });
955
+ const {
956
+ entry
957
+ } = await (0, _entryDataFactories.createUnpublishEntryData)({
958
+ context,
959
+ model,
960
+ originalEntry,
961
+ getIdentity: getSecurityIdentity
962
+ });
963
+ let storageEntry = null;
964
+ try {
965
+ await onEntryBeforeUnpublish.publish({
966
+ entry,
967
+ model
968
+ });
969
+ storageEntry = await (0, _entryStorage.entryToStorageTransform)(context, model, entry);
970
+ const result = await storageOperations.entries.unpublish(model, {
971
+ entry,
972
+ storageEntry
973
+ });
974
+ await onEntryAfterUnpublish.publish({
975
+ entry,
976
+ storageEntry: result,
977
+ model
978
+ });
979
+ return entry;
980
+ } catch (ex) {
981
+ await onEntryUnpublishError.publish({
982
+ entry,
983
+ model,
984
+ error: ex
985
+ });
986
+ throw new _error.default(ex.message || "Could not unpublish entry.", ex.code || "UNPUBLISH_ERROR", {
987
+ originalEntry,
988
+ originalStorageEntry,
989
+ entry,
990
+ storageEntry
991
+ });
992
+ }
993
+ };
994
+ const getUniqueFieldValues = async (model, params) => {
995
+ await accessControl.ensureCanAccessEntry({
996
+ model
997
+ });
998
+ const {
999
+ where: initialWhere,
1000
+ fieldId
1001
+ } = params;
1002
+ const where = {
1003
+ ...initialWhere
1004
+ };
1005
+ /**
1006
+ * Possibly only get records which are owned by current user.
1007
+ * Or if searching for the owner set that value - in the case that user can see other entries than their own.
1008
+ */
1009
+ if (await accessControl.canAccessOnlyOwnedEntries({
1010
+ model
1011
+ })) {
1012
+ where.createdBy = getSecurityIdentity().id;
1013
+ }
1014
+
1015
+ /**
1016
+ * Where must contain either latest or published keys.
1017
+ * We cannot list entries without one of those
1018
+ */
1019
+ if (where.latest && where.published) {
1020
+ throw new _error.default("Cannot list entries that are both published and latest.", "LIST_ENTRIES_ERROR", {
1021
+ where
1022
+ });
1023
+ } else if (!where.latest && !where.published) {
1024
+ throw new _error.default("Cannot list entries if we do not have latest or published defined.", "LIST_ENTRIES_ERROR", {
1025
+ where
1026
+ });
1027
+ }
1028
+ /**
1029
+ * We need to verify that the field in question is searchable.
1030
+ */
1031
+ const fields = (0, _searchableFields.getSearchableFields)({
1032
+ fields: model.fields,
1033
+ plugins: context.plugins,
1034
+ input: []
1035
+ });
1036
+ if (!fields.includes(fieldId)) {
1037
+ throw new _error.default("Cannot list unique entry field values if the field is not searchable.", "LIST_UNIQUE_ENTRY_VALUES_ERROR", {
1038
+ fieldId
1039
+ });
1040
+ }
1041
+ try {
1042
+ return await storageOperations.entries.getUniqueFieldValues(model, {
1043
+ where,
1044
+ fieldId
1045
+ });
1046
+ } catch (ex) {
1047
+ throw new _error.default("Error while fetching unique entry values from storage.", "LIST_UNIQUE_ENTRY_VALUES_ERROR", {
1048
+ error: {
1049
+ message: ex.message,
1050
+ code: ex.code,
1051
+ data: ex.data
1052
+ },
1053
+ model,
1054
+ where,
1055
+ fieldId
1056
+ });
1057
+ }
1058
+ };
1059
+ const getEntryTraverser = async modelId => {
1060
+ const modelAstConverter = context.cms.getModelToAstConverter();
1061
+ const model = await context.cms.getModel(modelId);
1062
+ if (!model) {
1063
+ throw new Error(`Missing "${modelId}" model!`);
1064
+ }
1065
+ const modelAst = modelAstConverter.toAst(model);
1066
+ return new _ContentEntryTraverser.ContentEntryTraverser(modelAst);
1067
+ };
1068
+ return {
1069
+ getEntryTraverser,
1070
+ onEntryBeforeCreate,
1071
+ onEntryAfterCreate,
1072
+ onEntryCreateError,
1073
+ onEntryRevisionBeforeCreate: onEntryBeforeCreateRevision,
1074
+ onEntryRevisionAfterCreate,
1075
+ onEntryRevisionCreateError: onEntryCreateRevisionError,
1076
+ onEntryBeforeUpdate,
402
1077
  onEntryAfterUpdate,
403
1078
  onEntryUpdateError,
1079
+ onEntryBeforeMove,
1080
+ onEntryAfterMove,
1081
+ onEntryMoveError,
404
1082
  onEntryBeforeDelete,
405
1083
  onEntryAfterDelete,
406
1084
  onEntryDeleteError,
1085
+ onEntryBeforeRestoreFromBin,
1086
+ onEntryAfterRestoreFromBin,
1087
+ onEntryRestoreFromBinError,
407
1088
  onEntryRevisionBeforeDelete,
408
1089
  onEntryRevisionAfterDelete,
409
1090
  onEntryRevisionDeleteError,
410
1091
  onEntryBeforePublish,
411
1092
  onEntryAfterPublish,
412
1093
  onEntryPublishError,
1094
+ onEntryBeforeRepublish,
1095
+ onEntryAfterRepublish,
1096
+ onEntryRepublishError,
413
1097
  onEntryBeforeUnpublish,
414
1098
  onEntryAfterUnpublish,
415
1099
  onEntryUnpublishError,
416
1100
  onEntryBeforeGet,
417
1101
  onEntryBeforeList,
418
-
419
1102
  /**
420
1103
  * Get entries by exact revision IDs from the database.
421
1104
  */
422
- getEntriesByIds: getEntriesByIds,
423
-
1105
+ async getEntriesByIds(model, ids) {
1106
+ return context.benchmark.measure("headlessCms.crud.entries.getEntriesByIds", async () => {
1107
+ return getEntriesByIdsUseCase.execute(model, {
1108
+ ids
1109
+ });
1110
+ });
1111
+ },
424
1112
  /**
425
1113
  * Get a single entry by revision ID from the database.
426
1114
  */
427
- async getEntryById(initialModel, id) {
428
- const where = {
429
- id
430
- };
431
- const model = (0, _valueKeyStorageConverter.attachCmsModelFieldConverters)({
432
- model: initialModel,
433
- plugins
1115
+ async getEntryById(model, id) {
1116
+ return context.benchmark.measure("headlessCms.crud.entries.getEntryById", async () => {
1117
+ return getEntryById(model, id);
434
1118
  });
435
- await onEntryBeforeGet.publish({
436
- where,
437
- model
438
- });
439
- const [entry] = await getEntriesByIds(model, [id]);
440
-
441
- if (!entry) {
442
- throw new _handlerGraphql.NotFoundError(`Entry by ID "${id}" not found.`);
443
- }
444
-
445
- return entry;
446
1119
  },
447
-
448
1120
  /**
449
1121
  * Get published revisions by entry IDs.
450
1122
  */
451
- async getPublishedEntriesByIds(initialModel, ids) {
452
- const permission = await checkEntryPermissions({
453
- rwd: "r"
454
- });
455
- await (0, _access.checkModelAccess)(context, initialModel);
456
- const model = (0, _valueKeyStorageConverter.attachCmsModelFieldConverters)({
457
- model: initialModel,
458
- plugins
459
- });
460
- const entries = await storageOperations.entries.getPublishedByIds(model, {
461
- ids
1123
+ async getPublishedEntriesByIds(model, ids) {
1124
+ return context.benchmark.measure("headlessCms.crud.entries.getPublishedEntriesByIds", async () => {
1125
+ return getPublishedEntriesByIdsUseCase.execute(model, {
1126
+ ids
1127
+ });
462
1128
  });
463
- return entries.filter(entry => (0, _ownership.validateOwnership)(context, permission, entry));
464
1129
  },
465
-
466
1130
  /**
467
- * Get latest revisions by entry IDs.
1131
+ * Get the latest revisions by entry IDs.
468
1132
  */
469
- async getLatestEntriesByIds(initialModel, ids) {
470
- const permission = await checkEntryPermissions({
471
- rwd: "r"
472
- });
473
- await (0, _access.checkModelAccess)(context, initialModel);
474
- const model = (0, _valueKeyStorageConverter.attachCmsModelFieldConverters)({
475
- model: initialModel,
476
- plugins
477
- });
478
- const entries = await storageOperations.entries.getLatestByIds(model, {
479
- ids
1133
+ async getLatestEntriesByIds(model, ids) {
1134
+ return context.benchmark.measure("headlessCms.crud.entries.getLatestEntriesByIds", async () => {
1135
+ return await getLatestEntriesByIdsUseCase.execute(model, {
1136
+ ids
1137
+ });
480
1138
  });
481
- return entries.filter(entry => (0, _ownership.validateOwnership)(context, permission, entry));
482
1139
  },
483
-
484
- async getEntryRevisions(initialModel, entryId) {
485
- const model = (0, _valueKeyStorageConverter.attachCmsModelFieldConverters)({
486
- model: initialModel,
487
- plugins
488
- });
489
- return storageOperations.entries.getRevisions(model, {
490
- id: entryId
1140
+ async getEntryRevisions(model, entryId) {
1141
+ return context.benchmark.measure("headlessCms.crud.entries.getEntryRevisions", async () => {
1142
+ return getRevisionsByEntryIdUseCase.execute(model, {
1143
+ id: entryId
1144
+ });
491
1145
  });
492
1146
  },
493
-
494
1147
  /**
495
- * TODO determine if this method is required at all.
496
- *
497
1148
  * @internal
498
1149
  */
499
- async getEntry(initialModel, params) {
500
- await checkEntryPermissions({
501
- rwd: "r"
502
- });
503
- const model = (0, _valueKeyStorageConverter.attachCmsModelFieldConverters)({
504
- model: initialModel,
505
- plugins
506
- });
507
- const {
508
- where,
509
- sort
510
- } = params;
511
- await onEntryBeforeGet.publish({
512
- where,
513
- model
514
- });
515
- const [items] = await this.listEntries(model, {
516
- where,
517
- sort,
518
- limit: 1
1150
+ async getEntry(model, params) {
1151
+ return context.benchmark.measure("headlessCms.crud.entries.getEntry", async () => {
1152
+ return await getEntryUseCase.execute(model, params);
519
1153
  });
520
-
521
- if (items.length === 0) {
522
- throw new _handlerGraphql.NotFoundError(`Entry not found!`);
523
- }
524
-
525
- return items[0];
526
1154
  },
527
-
528
1155
  /**
529
1156
  * @description Should not be used directly. Internal use only!
530
1157
  *
531
1158
  * @internal
532
1159
  */
533
- async listEntries(initialModel, params) {
534
- const permission = await checkEntryPermissions({
535
- rwd: "r"
536
- });
537
- await (0, _access.checkModelAccess)(context, initialModel);
538
- const model = (0, _valueKeyStorageConverter.attachCmsModelFieldConverters)({
539
- model: initialModel,
540
- plugins
541
- });
542
- const {
543
- where: initialWhere
544
- } = params;
545
- /**
546
- * We always assign tenant and locale because we do not allow one model to have content through multiple tenants.
547
- */
548
-
549
- const where = (0, _objectSpread2.default)({}, initialWhere);
550
- /**
551
- * Possibly only get records which are owned by current user.
552
- * Or if searching for the owner set that value - in the case that user can see other entries than their own.
553
- */
554
-
555
- const ownedBy = permission.own ? getIdentity().id : where.ownedBy;
556
-
557
- if (ownedBy !== undefined) {
558
- where.ownedBy = ownedBy;
559
- }
560
- /**
561
- * Where must contain either latest or published keys.
562
- * We cannot list entries without one of those
563
- */
564
-
565
-
566
- if (where.latest && where.published) {
567
- throw new _error.default("Cannot list entries that are both published and latest.", "LIST_ENTRIES_ERROR", {
568
- where
569
- });
570
- } else if (!where.latest && !where.published) {
571
- throw new _error.default("Cannot list entries if we do not have latest or published defined.", "LIST_ENTRIES_ERROR", {
572
- where
573
- });
574
- }
575
-
576
- const fields = getSearchableFields({
577
- model,
578
- plugins: context.plugins,
579
- fields: params.fields || []
1160
+ async listEntries(model, params) {
1161
+ return context.benchmark.measure("headlessCms.crud.entries.listEntries", async () => {
1162
+ return await listEntriesUseCase.execute(model, params);
580
1163
  });
581
-
582
- try {
583
- await onEntryBeforeList.publish({
584
- where,
585
- model
586
- });
587
- const {
588
- hasMoreItems,
589
- totalCount,
590
- cursor,
591
- items
592
- } = await storageOperations.entries.list(model, (0, _objectSpread2.default)((0, _objectSpread2.default)({}, params), {}, {
593
- where,
594
- fields
595
- }));
596
- const meta = {
597
- hasMoreItems,
598
- totalCount,
599
-
600
- /**
601
- * Cursor should be null if there are no more items to load.
602
- * Just make sure of that, disregarding what is returned from the storageOperations.entries.list method.
603
- */
604
- cursor: hasMoreItems ? cursor : null
605
- };
606
- return [items, meta];
607
- } catch (ex) {
608
- throw new _error.default("Error while fetching entries from storage.", "LIST_ENTRIES_ERROR", {
609
- params,
610
- error: {
611
- message: ex.message,
612
- code: ex.code,
613
- data: ex.data
614
- },
615
- model,
616
- fields
617
- });
618
- }
619
1164
  },
620
-
621
1165
  async listLatestEntries(model, params) {
622
- const where = (params === null || params === void 0 ? void 0 : params.where) || {};
623
- return this.listEntries(model, (0, _objectSpread2.default)((0, _objectSpread2.default)({
624
- sort: ["createdOn_DESC"]
625
- }, params || {}), {}, {
626
- where: (0, _objectSpread2.default)((0, _objectSpread2.default)({}, where), {}, {
627
- latest: true
628
- })
629
- }));
630
- },
631
-
632
- async listPublishedEntries(model, params) {
633
- const where = (params === null || params === void 0 ? void 0 : params.where) || {};
634
- return this.listEntries(model, (0, _objectSpread2.default)((0, _objectSpread2.default)({
635
- sort: ["createdOn_DESC"]
636
- }, params || {}), {}, {
637
- where: (0, _objectSpread2.default)((0, _objectSpread2.default)({}, where), {}, {
638
- published: true
639
- })
640
- }));
641
- },
642
-
643
- async createEntry(initialModel, inputData) {
644
- await checkEntryPermissions({
645
- rwd: "w"
646
- });
647
- await (0, _access.checkModelAccess)(context, initialModel);
648
- const model = (0, _valueKeyStorageConverter.attachCmsModelFieldConverters)({
649
- model: initialModel,
650
- plugins
651
- });
652
- /**
653
- * Make sure we only work with fields that are defined in the model.
654
- */
655
-
656
- const initialInput = mapAndCleanCreateInputData(model, inputData);
657
- await (0, _entryDataValidation.validateModelEntryData)({
658
- context,
659
- model,
660
- data: initialInput
1166
+ return context.benchmark.measure("headlessCms.crud.entries.listLatestEntries", async () => {
1167
+ return await listLatestUseCase.execute(model, params);
661
1168
  });
662
- const input = await (0, _referenceFieldsMapping.referenceFieldsMapping)({
663
- context,
664
- model,
665
- input: initialInput,
666
- validateEntries: true
667
- });
668
- const identity = context.security.getIdentity();
669
- const locale = this.getLocale();
670
- const owner = {
671
- id: identity.id,
672
- displayName: identity.displayName,
673
- type: identity.type
674
- };
675
- const {
676
- id,
677
- entryId,
678
- version
679
- } = createEntryId(1);
680
- const entry = {
681
- webinyVersion: context.WEBINY_VERSION,
682
- tenant: getTenant().id,
683
- entryId,
684
- id,
685
- modelId: model.modelId,
686
- locale: locale.code,
687
- createdOn: new Date().toISOString(),
688
- savedOn: new Date().toISOString(),
689
- createdBy: owner,
690
- ownedBy: owner,
691
- version,
692
- locked: false,
693
- status: STATUS_DRAFT,
694
- values: input
695
- };
696
- let storageEntry = null;
697
-
698
- try {
699
- await onEntryBeforeCreate.publish({
700
- entry,
701
- input,
702
- model
703
- });
704
- storageEntry = await (0, _entryStorage.entryToStorageTransform)(context, model, entry);
705
- const result = await storageOperations.entries.create(model, {
706
- entry,
707
- storageEntry
708
- });
709
- await onEntryAfterCreate.publish({
710
- entry,
711
- storageEntry: result,
712
- model,
713
- input
714
- });
715
- return result;
716
- } catch (ex) {
717
- await onEntryCreateError.publish({
718
- error: ex,
719
- entry,
720
- model,
721
- input
722
- });
723
- throw new _error.default(ex.message || "Could not create content entry.", ex.code || "CREATE_ENTRY_ERROR", ex.data || {
724
- error: ex,
725
- input,
726
- entry,
727
- storageEntry
728
- });
729
- }
730
1169
  },
731
-
732
- async createEntryRevisionFrom(initialModel, sourceId, inputData) {
733
- const permission = await checkEntryPermissions({
734
- rwd: "w"
735
- });
736
- await (0, _access.checkModelAccess)(context, initialModel);
737
- const model = (0, _valueKeyStorageConverter.attachCmsModelFieldConverters)({
738
- model: initialModel,
739
- plugins
740
- });
741
- /**
742
- * Make sure we only work with fields that are defined in the model.
743
- */
744
-
745
- const input = mapAndCleanUpdatedInputData(model, inputData);
746
- /**
747
- * Entries are identified by a common parent ID + Revision number.
748
- */
749
-
750
- const {
751
- id: uniqueId
752
- } = (0, _utils.parseIdentifier)(sourceId);
753
- const originalStorageEntry = await storageOperations.entries.getRevisionById(model, {
754
- id: sourceId
755
- });
756
- const latestStorageEntry = await storageOperations.entries.getLatestRevisionByEntryId(model, {
757
- id: uniqueId
758
- });
759
-
760
- if (!originalStorageEntry) {
761
- throw new _handlerGraphql.NotFoundError(`Entry "${sourceId}" of model "${model.modelId}" was not found.`);
762
- }
763
- /**
764
- * We need to convert data from DB to its original form before using it further.
765
- */
766
-
767
-
768
- const originalEntry = await (0, _entryStorage.entryFromStorageTransform)(context, model, originalStorageEntry);
769
- const initialValues = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, originalEntry.values), input);
770
- await (0, _entryDataValidation.validateModelEntryData)({
771
- context,
772
- model,
773
- data: initialValues,
774
- entry: originalEntry
775
- });
776
- const values = await (0, _referenceFieldsMapping.referenceFieldsMapping)({
777
- context,
778
- model,
779
- input: initialValues,
780
- validateEntries: false
1170
+ async listDeletedEntries(model, params) {
1171
+ return context.benchmark.measure("headlessCms.crud.entries.listDeletedEntries", async () => {
1172
+ return await listDeletedUseCase.execute(model, params);
781
1173
  });
782
- (0, _ownership.checkOwnership)(context, permission, originalEntry);
783
- const identity = context.security.getIdentity();
784
- const latestId = latestStorageEntry ? latestStorageEntry.id : sourceId;
785
- const {
786
- id,
787
- version: nextVersion
788
- } = increaseEntryIdVersion(latestId);
789
- const entry = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, originalEntry), {}, {
790
- id,
791
- version: nextVersion,
792
- savedOn: new Date().toISOString(),
793
- createdOn: new Date().toISOString(),
794
- createdBy: {
795
- id: identity.id,
796
- displayName: identity.displayName,
797
- type: identity.type
798
- },
799
- locked: false,
800
- publishedOn: undefined,
801
- status: STATUS_DRAFT,
802
- values
803
- });
804
- let storageEntry = null;
805
-
806
- try {
807
- await onEntryBeforeCreateRevision.publish({
808
- input,
809
- entry,
810
- original: originalEntry,
811
- model
812
- });
813
- storageEntry = await (0, _entryStorage.entryToStorageTransform)(context, model, entry);
814
- const result = await storageOperations.entries.createRevisionFrom(model, {
815
- entry,
816
- storageEntry
817
- });
818
- await onEntryRevisionAfterCreate.publish({
819
- input,
820
- entry,
821
- model,
822
- original: originalEntry,
823
- storageEntry: result
824
- });
825
- return result;
826
- } catch (ex) {
827
- await onEntryCreateRevisionError.publish({
828
- entry,
829
- model,
830
- input,
831
- error: ex
832
- });
833
- throw new _error.default(ex.message || "Could not create entry from existing one.", ex.code || "CREATE_FROM_REVISION_ERROR", {
834
- error: ex,
835
- entry,
836
- storageEntry,
837
- originalEntry,
838
- originalStorageEntry
839
- });
840
- }
841
1174
  },
842
-
843
- async updateEntry(initialModel, id, inputData, metaInput) {
844
- const permission = await checkEntryPermissions({
845
- rwd: "w"
846
- });
847
- await (0, _access.checkModelAccess)(context, initialModel);
848
- const model = (0, _valueKeyStorageConverter.attachCmsModelFieldConverters)({
849
- model: initialModel,
850
- plugins
851
- });
852
- /**
853
- * Make sure we only work with fields that are defined in the model.
854
- */
855
-
856
- const input = mapAndCleanUpdatedInputData(model, inputData);
857
- /**
858
- * The entry we are going to update.
859
- */
860
-
861
- const originalStorageEntry = await storageOperations.entries.getRevisionById(model, {
862
- id
863
- });
864
-
865
- if (!originalStorageEntry) {
866
- throw new _handlerGraphql.NotFoundError(`Entry "${id}" of model "${model.modelId}" was not found.`);
867
- }
868
-
869
- if (originalStorageEntry.locked) {
870
- throw new _error.default(`Cannot update entry because it's locked.`, "CONTENT_ENTRY_UPDATE_ERROR");
871
- }
872
-
873
- const originalEntry = await (0, _entryStorage.entryFromStorageTransform)(context, model, originalStorageEntry);
874
- await (0, _entryDataValidation.validateModelEntryData)({
875
- context,
876
- model,
877
- data: input,
878
- entry: originalEntry
879
- });
880
- (0, _ownership.checkOwnership)(context, permission, originalEntry);
881
- const initialValues = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, originalEntry.values), input);
882
- const values = await (0, _referenceFieldsMapping.referenceFieldsMapping)({
883
- context,
884
- model,
885
- input: initialValues,
886
- validateEntries: false
887
- });
888
- /**
889
- * If users wants to remove a key from meta values, they need to send meta key with the null value.
890
- */
891
-
892
- const meta = createEntryMeta(metaInput, originalEntry.meta);
893
- /**
894
- * We always send the full entry to the hooks and storage operations update.
895
- */
896
-
897
- const entry = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, originalEntry), {}, {
898
- savedOn: new Date().toISOString(),
899
- values,
900
- meta,
901
- status: transformEntryStatus(originalEntry.status)
1175
+ async listPublishedEntries(model, params) {
1176
+ return context.benchmark.measure("headlessCms.crud.entries.listPublishedEntries", async () => {
1177
+ return await listPublishedUseCase.execute(model, params);
902
1178
  });
903
- let storageEntry = null;
904
-
905
- try {
906
- await onEntryBeforeUpdate.publish({
907
- entry,
908
- model,
909
- input,
910
- original: originalEntry
911
- });
912
- storageEntry = await (0, _entryStorage.entryToStorageTransform)(context, model, entry);
913
- const result = await storageOperations.entries.update(model, {
914
- entry,
915
- storageEntry
916
- });
917
- await onEntryAfterUpdate.publish({
918
- entry,
919
- storageEntry: result,
920
- model,
921
- input,
922
- original: originalEntry
923
- });
924
- return result;
925
- } catch (ex) {
926
- await onEntryUpdateError.publish({
927
- entry,
928
- model,
929
- input,
930
- error: ex
931
- });
932
- throw new _error.default(ex.message || "Could not update existing entry.", ex.code || "UPDATE_ERROR", {
933
- error: ex,
934
- entry,
935
- storageEntry,
936
- originalEntry,
937
- input
938
- });
939
- }
940
1179
  },
941
-
942
- async republishEntry(initialModel, id) {
943
- await checkEntryPermissions({
944
- rwd: "w"
945
- });
946
- await (0, _access.checkModelAccess)(context, initialModel);
947
- const model = (0, _valueKeyStorageConverter.attachCmsModelFieldConverters)({
948
- model: initialModel,
949
- plugins
950
- });
951
- /**
952
- * Fetch the entry from the storage.
953
- */
954
-
955
- const originalStorageEntry = await storageOperations.entries.getRevisionById(model, {
956
- id
957
- });
958
-
959
- if (!originalStorageEntry) {
960
- throw new _handlerGraphql.NotFoundError(`Entry "${id}" was not found!`);
961
- }
962
-
963
- const originalEntry = await (0, _entryStorage.entryFromStorageTransform)(context, model, originalStorageEntry);
964
- /**
965
- * We can only process published entries.
966
- */
967
-
968
- if (originalEntry.status !== "published") {
969
- throw new _error.default("Entry with given ID is not published!", "NOT_PUBLISHED_ERROR", {
970
- id,
971
- original: originalEntry
972
- });
973
- }
974
-
975
- const values = await (0, _referenceFieldsMapping.referenceFieldsMapping)({
976
- context,
977
- model,
978
- input: originalEntry.values,
979
- validateEntries: false
1180
+ async createEntry(model, input, options) {
1181
+ return context.benchmark.measure("headlessCms.crud.entries.createEntry", async () => {
1182
+ return createEntry(model, input, options);
980
1183
  });
981
- const entry = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, originalEntry), {}, {
982
- savedOn: new Date().toISOString(),
983
- webinyVersion: context.WEBINY_VERSION,
984
- values
985
- });
986
- const storageEntry = await (0, _entryStorage.entryToStorageTransform)(context, model, entry);
987
- /**
988
- * First we need to update existing entry.
989
- */
990
-
991
- try {
992
- await storageOperations.entries.update(model, {
993
- entry,
994
- storageEntry
995
- });
996
- } catch (ex) {
997
- throw new _error.default("Could not update existing entry with new data while re-publishing.", "REPUBLISH_UPDATE_ERROR", {
998
- entry
999
- });
1000
- }
1001
- /**
1002
- * Then we move onto publishing it again.
1003
- */
1004
-
1005
-
1006
- try {
1007
- return await storageOperations.entries.publish(model, {
1008
- entry,
1009
- storageEntry
1010
- });
1011
- } catch (ex) {
1012
- throw new _error.default("Could not publish existing entry while re-publishing.", "REPUBLISH_PUBLISH_ERROR", {
1013
- entry
1014
- });
1015
- }
1016
1184
  },
1017
-
1018
- async deleteEntryRevision(initialModel, revisionId) {
1019
- const permission = await checkEntryPermissions({
1020
- rwd: "d"
1021
- });
1022
- await (0, _access.checkModelAccess)(context, initialModel);
1023
- const model = (0, _valueKeyStorageConverter.attachCmsModelFieldConverters)({
1024
- model: initialModel,
1025
- plugins
1026
- });
1027
- const {
1028
- id: entryId,
1029
- version
1030
- } = (0, _utils.parseIdentifier)(revisionId);
1031
- const storageEntryToDelete = await storageOperations.entries.getRevisionById(model, {
1032
- id: revisionId
1185
+ async createEntryRevisionFrom(model, sourceId, input, options) {
1186
+ return context.benchmark.measure("headlessCms.crud.entries.createEntryRevisionFrom", async () => {
1187
+ return createEntryRevisionFrom(model, sourceId, input, options);
1033
1188
  });
1034
- const latestStorageEntry = await storageOperations.entries.getLatestRevisionByEntryId(model, {
1035
- id: entryId
1036
- });
1037
- const previousStorageEntry = await storageOperations.entries.getPreviousRevision(model, {
1038
- entryId,
1039
- version: version
1040
- });
1041
-
1042
- if (!storageEntryToDelete) {
1043
- throw new _handlerGraphql.NotFoundError(`Entry "${revisionId}" was not found!`);
1044
- }
1045
-
1046
- (0, _ownership.checkOwnership)(context, permission, storageEntryToDelete);
1047
- const latestEntryRevisionId = latestStorageEntry ? latestStorageEntry.id : null;
1048
- const entryToDelete = await (0, _entryStorage.entryFromStorageTransform)(context, model, storageEntryToDelete);
1049
- /**
1050
- * If targeted record is the latest entry record and there is no previous one, we need to run full delete with hooks.
1051
- * At this point deleteRevision hooks are not fired.
1052
- */
1053
-
1054
- if (entryToDelete.id === latestEntryRevisionId && !previousStorageEntry) {
1055
- return await deleteEntry({
1056
- model,
1057
- entry: entryToDelete
1058
- });
1059
- }
1060
- /**
1061
- * If targeted record is latest entry revision, set the previous one as the new latest
1062
- */
1063
-
1064
-
1065
- let entryToSetAsLatest = null;
1066
- let storageEntryToSetAsLatest = null;
1067
-
1068
- if (entryToDelete.id === latestEntryRevisionId && previousStorageEntry) {
1069
- entryToSetAsLatest = await (0, _entryStorage.entryFromStorageTransform)(context, model, previousStorageEntry);
1070
- storageEntryToSetAsLatest = previousStorageEntry;
1071
- }
1072
-
1073
- try {
1074
- await onEntryRevisionBeforeDelete.publish({
1075
- entry: entryToDelete,
1076
- model
1077
- });
1078
- await storageOperations.entries.deleteRevision(model, {
1079
- entry: entryToDelete,
1080
- storageEntry: storageEntryToDelete,
1081
- latestEntry: entryToSetAsLatest,
1082
- latestStorageEntry: storageEntryToSetAsLatest
1083
- });
1084
- await onEntryRevisionAfterDelete.publish({
1085
- entry: entryToDelete,
1086
- model
1087
- });
1088
- } catch (ex) {
1089
- await onEntryRevisionDeleteError.publish({
1090
- entry: entryToDelete,
1091
- model,
1092
- error: ex
1093
- });
1094
- throw new _error.default(ex.message, ex.code || "DELETE_REVISION_ERROR", {
1095
- error: ex,
1096
- entry: entryToDelete,
1097
- storageEntry: storageEntryToDelete,
1098
- latestEntry: entryToSetAsLatest,
1099
- latestStorageEntry: storageEntryToSetAsLatest
1100
- });
1101
- }
1102
1189
  },
1103
-
1104
- async deleteEntry(initialModel, entryId) {
1105
- const permission = await checkEntryPermissions({
1106
- rwd: "d"
1190
+ async updateEntry(model, id, input, meta, options) {
1191
+ return context.benchmark.measure("headlessCms.crud.entries.updateEntry", async () => {
1192
+ return updateEntry(model, id, input, meta, options);
1107
1193
  });
1108
- await (0, _access.checkModelAccess)(context, initialModel);
1109
- const model = (0, _valueKeyStorageConverter.attachCmsModelFieldConverters)({
1110
- model: initialModel,
1111
- plugins
1194
+ },
1195
+ async validateEntry(model, id, input) {
1196
+ return context.benchmark.measure("headlessCms.crud.entries.validateEntry", async () => {
1197
+ return validateEntry(model, id, input);
1112
1198
  });
1113
- const storageEntry = await storageOperations.entries.getLatestRevisionByEntryId(model, {
1114
- id: entryId
1199
+ },
1200
+ async moveEntry(model, id, folderId) {
1201
+ return context.benchmark.measure("headlessCms.crud.entries.moveEntry", async () => {
1202
+ return moveEntry(model, id, folderId);
1115
1203
  });
1116
-
1117
- if (!storageEntry) {
1118
- throw new _handlerGraphql.NotFoundError(`Entry "${entryId}" was not found!`);
1119
- }
1120
-
1121
- (0, _ownership.checkOwnership)(context, permission, storageEntry);
1122
- const entry = await (0, _entryStorage.entryFromStorageTransform)(context, model, storageEntry);
1123
- return await deleteEntry({
1124
- model,
1125
- entry
1204
+ },
1205
+ /**
1206
+ * Method used internally. Not documented and should not be used in users systems.
1207
+ * @internal
1208
+ */
1209
+ async republishEntry(model, id) {
1210
+ return context.benchmark.measure("headlessCms.crud.entries.republishEntry", async () => {
1211
+ return republishEntry(model, id);
1126
1212
  });
1127
1213
  },
1128
-
1129
- async publishEntry(initialModel, id) {
1130
- const permission = await checkEntryPermissions({
1131
- pw: "p"
1214
+ async deleteEntryRevision(model, id) {
1215
+ return context.benchmark.measure("headlessCms.crud.entries.deleteEntryRevision", async () => {
1216
+ return deleteEntryRevision(model, id);
1132
1217
  });
1133
- await (0, _access.checkModelAccess)(context, initialModel);
1134
- const model = (0, _valueKeyStorageConverter.attachCmsModelFieldConverters)({
1135
- model: initialModel,
1136
- plugins
1218
+ },
1219
+ async deleteEntry(model, entryId, options) {
1220
+ return context.benchmark.measure("headlessCms.crud.entries.deleteEntry", async () => {
1221
+ return deleteEntry(model, entryId, options);
1137
1222
  });
1138
- const originalStorageEntry = await storageOperations.entries.getRevisionById(model, {
1139
- id
1223
+ },
1224
+ async restoreEntryFromBin(model, entryId) {
1225
+ return context.benchmark.measure("headlessCms.crud.entries.restoreEntryFromBin", async () => {
1226
+ return await restoreEntryFromBinUseCase.execute(model, entryId);
1140
1227
  });
1141
-
1142
- if (!originalStorageEntry) {
1143
- throw new _handlerGraphql.NotFoundError(`Entry "${id}" in the model "${model.modelId}" was not found.`);
1144
- }
1145
-
1146
- (0, _ownership.checkOwnership)(context, permission, originalStorageEntry);
1147
- const originalEntry = await (0, _entryStorage.entryFromStorageTransform)(context, model, originalStorageEntry);
1148
- const currentDate = new Date().toISOString();
1149
- const entry = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, originalEntry), {}, {
1150
- status: STATUS_PUBLISHED,
1151
- locked: true,
1152
- savedOn: currentDate,
1153
- publishedOn: currentDate
1154
- });
1155
- let storageEntry = null;
1156
-
1157
- try {
1158
- await onEntryBeforePublish.publish({
1159
- entry,
1160
- model
1161
- });
1162
- storageEntry = await (0, _entryStorage.entryToStorageTransform)(context, model, entry);
1163
- const result = await storageOperations.entries.publish(model, {
1164
- entry,
1165
- storageEntry
1166
- });
1167
- await onEntryAfterPublish.publish({
1168
- entry,
1169
- storageEntry: result,
1170
- model
1171
- });
1172
- return result;
1173
- } catch (ex) {
1174
- await onEntryPublishError.publish({
1175
- entry,
1176
- model,
1177
- error: ex
1178
- });
1179
- throw new _error.default(ex.message || "Could not publish entry.", ex.code || "PUBLISH_ERROR", {
1180
- error: ex,
1181
- entry,
1182
- storageEntry,
1183
- originalEntry,
1184
- originalStorageEntry
1185
- });
1186
- }
1187
1228
  },
1188
-
1189
- async unpublishEntry(initialModel, id) {
1190
- const permission = await checkEntryPermissions({
1191
- pw: "u"
1229
+ async deleteMultipleEntries(model, ids) {
1230
+ return context.benchmark.measure("headlessCms.crud.entries.deleteMultipleEntries", async () => {
1231
+ return deleteMultipleEntries(model, ids);
1192
1232
  });
1193
- const model = (0, _valueKeyStorageConverter.attachCmsModelFieldConverters)({
1194
- model: initialModel,
1195
- plugins
1233
+ },
1234
+ async publishEntry(model, id) {
1235
+ return context.benchmark.measure("headlessCms.crud.entries.publishEntry", async () => {
1236
+ return publishEntry(model, id);
1196
1237
  });
1197
- const {
1198
- id: entryId
1199
- } = (0, _utils.parseIdentifier)(id);
1200
- const originalStorageEntry = await storageOperations.entries.getPublishedRevisionByEntryId(model, {
1201
- id: entryId
1238
+ },
1239
+ async unpublishEntry(model, id) {
1240
+ return context.benchmark.measure("headlessCms.crud.entries.unpublishEntry", async () => {
1241
+ return unpublishEntry(model, id);
1202
1242
  });
1203
-
1204
- if (!originalStorageEntry) {
1205
- throw new _handlerGraphql.NotFoundError(`Entry "${id}" of model "${model.modelId}" was not found.`);
1206
- }
1207
-
1208
- if (originalStorageEntry.id !== id) {
1209
- throw new _error.default(`Entry is not published.`, "UNPUBLISH_ERROR", {
1210
- entry: originalStorageEntry
1211
- });
1212
- }
1213
-
1214
- (0, _ownership.checkOwnership)(context, permission, originalStorageEntry);
1215
- const originalEntry = await (0, _entryStorage.entryFromStorageTransform)(context, model, originalStorageEntry);
1216
- const entry = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, originalEntry), {}, {
1217
- status: STATUS_UNPUBLISHED
1243
+ },
1244
+ async getUniqueFieldValues(model, params) {
1245
+ return context.benchmark.measure("headlessCms.crud.entries.getUniqueFieldValues", async () => {
1246
+ return getUniqueFieldValues(model, params);
1218
1247
  });
1219
- let storageEntry = null;
1220
-
1221
- try {
1222
- await onEntryBeforeUnpublish.publish({
1223
- entry,
1224
- model
1225
- });
1226
- storageEntry = await (0, _entryStorage.entryToStorageTransform)(context, model, entry);
1227
- const result = await storageOperations.entries.unpublish(model, {
1228
- entry,
1229
- storageEntry
1230
- });
1231
- await onEntryAfterUnpublish.publish({
1232
- entry,
1233
- storageEntry: result,
1234
- model
1235
- });
1236
- return result;
1237
- } catch (ex) {
1238
- await onEntryUnpublishError.publish({
1239
- entry,
1240
- model,
1241
- error: ex
1242
- });
1243
- throw new _error.default(ex.message || "Could not unpublish entry.", ex.code || "UNPUBLISH_ERROR", {
1244
- originalEntry,
1245
- originalStorageEntry,
1246
- entry,
1247
- storageEntry
1248
- });
1249
- }
1250
1248
  }
1251
-
1252
1249
  };
1253
1250
  };
1251
+ exports.createContentEntryCrud = createContentEntryCrud;
1254
1252
 
1255
- exports.createContentEntryCrud = createContentEntryCrud;
1253
+ //# sourceMappingURL=contentEntry.crud.js.map