@webiny/api-headless-cms 0.0.0-mt-3 → 0.0.0-unstable.085ff6572f

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