@webiny/api-headless-cms 0.0.0-mt-2 → 0.0.0-unstable.1145e7667f

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