@webiny/api-headless-cms 0.0.0-mt-2 → 0.0.0-unstable.13771d80a8

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