@webiny/api-headless-cms 0.0.0-mt-3 → 0.0.0-unstable.3386f66516

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