@webiny/api-headless-cms 0.0.0-unstable.e3f4727c56 → 0.0.0-unstable.eb196ccd2f

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