@webiny/api-headless-cms 0.0.0-mt-3 → 0.0.0-unstable.1e66d121db

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