@webiny/api-headless-cms 0.0.0-ee-vpcs.549378cf03

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 (435) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +73 -0
  3. package/context.d.ts +3 -0
  4. package/context.js +60 -0
  5. package/context.js.map +1 -0
  6. package/crud/contentEntry/afterDelete.d.ts +8 -0
  7. package/crud/contentEntry/afterDelete.js +41 -0
  8. package/crud/contentEntry/afterDelete.js.map +1 -0
  9. package/crud/contentEntry/beforeCreate.d.ts +8 -0
  10. package/crud/contentEntry/beforeCreate.js +28 -0
  11. package/crud/contentEntry/beforeCreate.js.map +1 -0
  12. package/crud/contentEntry/beforeUpdate.d.ts +8 -0
  13. package/crud/contentEntry/beforeUpdate.js +28 -0
  14. package/crud/contentEntry/beforeUpdate.js.map +1 -0
  15. package/crud/contentEntry/entryDataValidation.d.ts +10 -0
  16. package/crud/contentEntry/entryDataValidation.js +200 -0
  17. package/crud/contentEntry/entryDataValidation.js.map +1 -0
  18. package/crud/contentEntry/markLockedFields.d.ts +13 -0
  19. package/crud/contentEntry/markLockedFields.js +116 -0
  20. package/crud/contentEntry/markLockedFields.js.map +1 -0
  21. package/crud/contentEntry/referenceFieldsMapping.d.ts +13 -0
  22. package/crud/contentEntry/referenceFieldsMapping.js +292 -0
  23. package/crud/contentEntry/referenceFieldsMapping.js.map +1 -0
  24. package/crud/contentEntry/searchableFields.d.ts +9 -0
  25. package/crud/contentEntry/searchableFields.js +83 -0
  26. package/crud/contentEntry/searchableFields.js.map +1 -0
  27. package/crud/contentEntry.crud.d.ts +13 -0
  28. package/crud/contentEntry.crud.js +1277 -0
  29. package/crud/contentEntry.crud.js.map +1 -0
  30. package/crud/contentModel/afterCreate.d.ts +8 -0
  31. package/crud/contentModel/afterCreate.js +18 -0
  32. package/crud/contentModel/afterCreate.js.map +1 -0
  33. package/crud/contentModel/afterCreateFrom.d.ts +8 -0
  34. package/crud/contentModel/afterCreateFrom.js +18 -0
  35. package/crud/contentModel/afterCreateFrom.js.map +1 -0
  36. package/crud/contentModel/afterDelete.d.ts +8 -0
  37. package/crud/contentModel/afterDelete.js +18 -0
  38. package/crud/contentModel/afterDelete.js.map +1 -0
  39. package/crud/contentModel/afterUpdate.d.ts +8 -0
  40. package/crud/contentModel/afterUpdate.js +18 -0
  41. package/crud/contentModel/afterUpdate.js.map +1 -0
  42. package/crud/contentModel/beforeCreate.d.ts +15 -0
  43. package/crud/contentModel/beforeCreate.js +194 -0
  44. package/crud/contentModel/beforeCreate.js.map +1 -0
  45. package/crud/contentModel/beforeDelete.d.ts +10 -0
  46. package/crud/contentModel/beforeDelete.js +60 -0
  47. package/crud/contentModel/beforeDelete.js.map +1 -0
  48. package/crud/contentModel/beforeUpdate.d.ts +10 -0
  49. package/crud/contentModel/beforeUpdate.js +37 -0
  50. package/crud/contentModel/beforeUpdate.js.map +1 -0
  51. package/crud/contentModel/contentModelManagerFactory.d.ts +2 -0
  52. package/crud/contentModel/contentModelManagerFactory.js +29 -0
  53. package/crud/contentModel/contentModelManagerFactory.js.map +1 -0
  54. package/crud/contentModel/createFieldModels.d.ts +2 -0
  55. package/crud/contentModel/createFieldModels.js +26 -0
  56. package/crud/contentModel/createFieldModels.js.map +1 -0
  57. package/crud/contentModel/createFieldStorageId.d.ts +2 -0
  58. package/crud/contentModel/createFieldStorageId.js +20 -0
  59. package/crud/contentModel/createFieldStorageId.js.map +1 -0
  60. package/crud/contentModel/fieldIdValidation.d.ts +1 -0
  61. package/crud/contentModel/fieldIdValidation.js +25 -0
  62. package/crud/contentModel/fieldIdValidation.js.map +1 -0
  63. package/crud/contentModel/idValidation.d.ts +1 -0
  64. package/crud/contentModel/idValidation.js +22 -0
  65. package/crud/contentModel/idValidation.js.map +1 -0
  66. package/crud/contentModel/models.d.ts +4 -0
  67. package/crud/contentModel/models.js +192 -0
  68. package/crud/contentModel/models.js.map +1 -0
  69. package/crud/contentModel/systemFields.d.ts +1 -0
  70. package/crud/contentModel/systemFields.js +8 -0
  71. package/crud/contentModel/systemFields.js.map +1 -0
  72. package/crud/contentModel/validateLayout.d.ts +2 -0
  73. package/crud/contentModel/validateLayout.js +36 -0
  74. package/crud/contentModel/validateLayout.js.map +1 -0
  75. package/crud/contentModel/validateModel.d.ts +9 -0
  76. package/crud/contentModel/validateModel.js +32 -0
  77. package/crud/contentModel/validateModel.js.map +1 -0
  78. package/crud/contentModel/validateModelFields.d.ts +9 -0
  79. package/crud/contentModel/validateModelFields.js +371 -0
  80. package/crud/contentModel/validateModelFields.js.map +1 -0
  81. package/crud/contentModel.crud.d.ts +12 -0
  82. package/crud/contentModel.crud.js +650 -0
  83. package/crud/contentModel.crud.js.map +1 -0
  84. package/crud/contentModelGroup/beforeCreate.d.ts +10 -0
  85. package/crud/contentModelGroup/beforeCreate.js +66 -0
  86. package/crud/contentModelGroup/beforeCreate.js.map +1 -0
  87. package/crud/contentModelGroup/beforeDelete.d.ts +10 -0
  88. package/crud/contentModelGroup/beforeDelete.js +48 -0
  89. package/crud/contentModelGroup/beforeDelete.js.map +1 -0
  90. package/crud/contentModelGroup/beforeUpdate.d.ts +9 -0
  91. package/crud/contentModelGroup/beforeUpdate.js +28 -0
  92. package/crud/contentModelGroup/beforeUpdate.js.map +1 -0
  93. package/crud/contentModelGroup.crud.d.ts +12 -0
  94. package/crud/contentModelGroup.crud.js +396 -0
  95. package/crud/contentModelGroup.crud.js.map +1 -0
  96. package/crud/index.d.ts +6 -0
  97. package/crud/index.js +85 -0
  98. package/crud/index.js.map +1 -0
  99. package/crud/settings.crud.d.ts +10 -0
  100. package/crud/settings.crud.js +83 -0
  101. package/crud/settings.crud.js.map +1 -0
  102. package/crud/system.crud.d.ts +13 -0
  103. package/crud/system.crud.js +221 -0
  104. package/crud/system.crud.js.map +1 -0
  105. package/fieldConverters/CmsModelDefaultFieldConverterPlugin.d.ts +7 -0
  106. package/fieldConverters/CmsModelDefaultFieldConverterPlugin.js +66 -0
  107. package/fieldConverters/CmsModelDefaultFieldConverterPlugin.js.map +1 -0
  108. package/fieldConverters/CmsModelDynamicZoneFieldConverterPlugin.d.ts +11 -0
  109. package/fieldConverters/CmsModelDynamicZoneFieldConverterPlugin.js +239 -0
  110. package/fieldConverters/CmsModelDynamicZoneFieldConverterPlugin.js.map +1 -0
  111. package/fieldConverters/CmsModelObjectFieldConverterPlugin.d.ts +11 -0
  112. package/fieldConverters/CmsModelObjectFieldConverterPlugin.js +304 -0
  113. package/fieldConverters/CmsModelObjectFieldConverterPlugin.js.map +1 -0
  114. package/fieldConverters/index.d.ts +4 -0
  115. package/fieldConverters/index.js +18 -0
  116. package/fieldConverters/index.js.map +1 -0
  117. package/graphql/buildSchemaPlugins.d.ts +6 -0
  118. package/graphql/buildSchemaPlugins.js +27 -0
  119. package/graphql/buildSchemaPlugins.js.map +1 -0
  120. package/graphql/graphQLHandlerFactory.d.ts +5 -0
  121. package/graphql/graphQLHandlerFactory.js +202 -0
  122. package/graphql/graphQLHandlerFactory.js.map +1 -0
  123. package/graphql/index.d.ts +5 -0
  124. package/graphql/index.js +57 -0
  125. package/graphql/index.js.map +1 -0
  126. package/graphql/schema/baseContentSchema.d.ts +3 -0
  127. package/graphql/schema/baseContentSchema.js +76 -0
  128. package/graphql/schema/baseContentSchema.js.map +1 -0
  129. package/graphql/schema/contentEntries.d.ts +3 -0
  130. package/graphql/schema/contentEntries.js +351 -0
  131. package/graphql/schema/contentEntries.js.map +1 -0
  132. package/graphql/schema/contentModelGroups.d.ts +3 -0
  133. package/graphql/schema/contentModelGroups.js +172 -0
  134. package/graphql/schema/contentModelGroups.js.map +1 -0
  135. package/graphql/schema/contentModels.d.ts +3 -0
  136. package/graphql/schema/contentModels.js +300 -0
  137. package/graphql/schema/contentModels.js.map +1 -0
  138. package/graphql/schema/createFieldResolvers.d.ts +20 -0
  139. package/graphql/schema/createFieldResolvers.js +121 -0
  140. package/graphql/schema/createFieldResolvers.js.map +1 -0
  141. package/graphql/schema/createManageResolvers.d.ts +12 -0
  142. package/graphql/schema/createManageResolvers.js +137 -0
  143. package/graphql/schema/createManageResolvers.js.map +1 -0
  144. package/graphql/schema/createManageSDL.d.ts +10 -0
  145. package/graphql/schema/createManageSDL.js +161 -0
  146. package/graphql/schema/createManageSDL.js.map +1 -0
  147. package/graphql/schema/createPreviewResolvers.d.ts +12 -0
  148. package/graphql/schema/createPreviewResolvers.js +58 -0
  149. package/graphql/schema/createPreviewResolvers.js.map +1 -0
  150. package/graphql/schema/createReadResolvers.d.ts +12 -0
  151. package/graphql/schema/createReadResolvers.js +58 -0
  152. package/graphql/schema/createReadResolvers.js.map +1 -0
  153. package/graphql/schema/createReadSDL.d.ts +10 -0
  154. package/graphql/schema/createReadSDL.js +104 -0
  155. package/graphql/schema/createReadSDL.js.map +1 -0
  156. package/graphql/schema/resolvers/commonFieldResolvers.d.ts +6 -0
  157. package/graphql/schema/resolvers/commonFieldResolvers.js +14 -0
  158. package/graphql/schema/resolvers/commonFieldResolvers.js.map +1 -0
  159. package/graphql/schema/resolvers/manage/resolveCreate.d.ts +7 -0
  160. package/graphql/schema/resolvers/manage/resolveCreate.js +21 -0
  161. package/graphql/schema/resolvers/manage/resolveCreate.js.map +1 -0
  162. package/graphql/schema/resolvers/manage/resolveCreateFrom.d.ts +8 -0
  163. package/graphql/schema/resolvers/manage/resolveCreateFrom.js +21 -0
  164. package/graphql/schema/resolvers/manage/resolveCreateFrom.js.map +1 -0
  165. package/graphql/schema/resolvers/manage/resolveDelete.d.ts +7 -0
  166. package/graphql/schema/resolvers/manage/resolveDelete.js +32 -0
  167. package/graphql/schema/resolvers/manage/resolveDelete.js.map +1 -0
  168. package/graphql/schema/resolvers/manage/resolveGet.d.ts +7 -0
  169. package/graphql/schema/resolvers/manage/resolveGet.js +79 -0
  170. package/graphql/schema/resolvers/manage/resolveGet.js.map +1 -0
  171. package/graphql/schema/resolvers/manage/resolveGetByIds.d.ts +7 -0
  172. package/graphql/schema/resolvers/manage/resolveGetByIds.js +21 -0
  173. package/graphql/schema/resolvers/manage/resolveGetByIds.js.map +1 -0
  174. package/graphql/schema/resolvers/manage/resolveGetRevisions.d.ts +7 -0
  175. package/graphql/schema/resolvers/manage/resolveGetRevisions.js +21 -0
  176. package/graphql/schema/resolvers/manage/resolveGetRevisions.js.map +1 -0
  177. package/graphql/schema/resolvers/manage/resolveList.d.ts +4 -0
  178. package/graphql/schema/resolvers/manage/resolveList.js +21 -0
  179. package/graphql/schema/resolvers/manage/resolveList.js.map +1 -0
  180. package/graphql/schema/resolvers/manage/resolvePublish.d.ts +7 -0
  181. package/graphql/schema/resolvers/manage/resolvePublish.js +21 -0
  182. package/graphql/schema/resolvers/manage/resolvePublish.js.map +1 -0
  183. package/graphql/schema/resolvers/manage/resolveRepublish.d.ts +7 -0
  184. package/graphql/schema/resolvers/manage/resolveRepublish.js +21 -0
  185. package/graphql/schema/resolvers/manage/resolveRepublish.js.map +1 -0
  186. package/graphql/schema/resolvers/manage/resolveUnpublish.d.ts +7 -0
  187. package/graphql/schema/resolvers/manage/resolveUnpublish.js +21 -0
  188. package/graphql/schema/resolvers/manage/resolveUnpublish.js.map +1 -0
  189. package/graphql/schema/resolvers/manage/resolveUpdate.d.ts +8 -0
  190. package/graphql/schema/resolvers/manage/resolveUpdate.js +21 -0
  191. package/graphql/schema/resolvers/manage/resolveUpdate.js.map +1 -0
  192. package/graphql/schema/resolvers/preview/resolveGet.d.ts +4 -0
  193. package/graphql/schema/resolvers/preview/resolveGet.js +34 -0
  194. package/graphql/schema/resolvers/preview/resolveGet.js.map +1 -0
  195. package/graphql/schema/resolvers/preview/resolveList.d.ts +4 -0
  196. package/graphql/schema/resolvers/preview/resolveList.js +21 -0
  197. package/graphql/schema/resolvers/preview/resolveList.js.map +1 -0
  198. package/graphql/schema/resolvers/read/resolveGet.d.ts +4 -0
  199. package/graphql/schema/resolvers/read/resolveGet.js +34 -0
  200. package/graphql/schema/resolvers/read/resolveGet.js.map +1 -0
  201. package/graphql/schema/resolvers/read/resolveList.d.ts +4 -0
  202. package/graphql/schema/resolvers/read/resolveList.js +21 -0
  203. package/graphql/schema/resolvers/read/resolveList.js.map +1 -0
  204. package/graphql/schema/schemaPlugins.d.ts +3 -0
  205. package/graphql/schema/schemaPlugins.js +111 -0
  206. package/graphql/schema/schemaPlugins.js.map +1 -0
  207. package/graphql/system.d.ts +6 -0
  208. package/graphql/system.js +119 -0
  209. package/graphql/system.js.map +1 -0
  210. package/graphqlFields/boolean.d.ts +2 -0
  211. package/graphqlFields/boolean.js +69 -0
  212. package/graphqlFields/boolean.js.map +1 -0
  213. package/graphqlFields/datetime.d.ts +2 -0
  214. package/graphqlFields/datetime.js +95 -0
  215. package/graphqlFields/datetime.js.map +1 -0
  216. package/graphqlFields/dynamicZone/dynamicZoneField.d.ts +2 -0
  217. package/graphqlFields/dynamicZone/dynamicZoneField.js +234 -0
  218. package/graphqlFields/dynamicZone/dynamicZoneField.js.map +1 -0
  219. package/graphqlFields/dynamicZone/dynamicZoneStorage.d.ts +3 -0
  220. package/graphqlFields/dynamicZone/dynamicZoneStorage.js +79 -0
  221. package/graphqlFields/dynamicZone/dynamicZoneStorage.js.map +1 -0
  222. package/graphqlFields/dynamicZone/index.d.ts +2 -0
  223. package/graphqlFields/dynamicZone/index.js +21 -0
  224. package/graphqlFields/dynamicZone/index.js.map +1 -0
  225. package/graphqlFields/file.d.ts +2 -0
  226. package/graphqlFields/file.js +50 -0
  227. package/graphqlFields/file.js.map +1 -0
  228. package/graphqlFields/helpers.d.ts +6 -0
  229. package/graphqlFields/helpers.js +49 -0
  230. package/graphqlFields/helpers.js.map +1 -0
  231. package/graphqlFields/index.d.ts +2 -0
  232. package/graphqlFields/index.js +30 -0
  233. package/graphqlFields/index.js.map +1 -0
  234. package/graphqlFields/longText.d.ts +2 -0
  235. package/graphqlFields/longText.js +63 -0
  236. package/graphqlFields/longText.js.map +1 -0
  237. package/graphqlFields/number.d.ts +2 -0
  238. package/graphqlFields/number.js +79 -0
  239. package/graphqlFields/number.js.map +1 -0
  240. package/graphqlFields/object.d.ts +2 -0
  241. package/graphqlFields/object.js +275 -0
  242. package/graphqlFields/object.js.map +1 -0
  243. package/graphqlFields/ref.d.ts +2 -0
  244. package/graphqlFields/ref.js +257 -0
  245. package/graphqlFields/ref.js.map +1 -0
  246. package/graphqlFields/richText.d.ts +2 -0
  247. package/graphqlFields/richText.js +56 -0
  248. package/graphqlFields/richText.js.map +1 -0
  249. package/graphqlFields/text.d.ts +2 -0
  250. package/graphqlFields/text.js +73 -0
  251. package/graphqlFields/text.js.map +1 -0
  252. package/index.d.ts +10 -0
  253. package/index.js +111 -0
  254. package/index.js.map +1 -0
  255. package/modelManager/DefaultCmsModelManager.d.ts +14 -0
  256. package/modelManager/DefaultCmsModelManager.js +64 -0
  257. package/modelManager/DefaultCmsModelManager.js.map +1 -0
  258. package/modelManager/index.d.ts +2 -0
  259. package/modelManager/index.js +20 -0
  260. package/modelManager/index.js.map +1 -0
  261. package/package.json +81 -0
  262. package/parameters/context.d.ts +2 -0
  263. package/parameters/context.js +22 -0
  264. package/parameters/context.js.map +1 -0
  265. package/parameters/header.d.ts +2 -0
  266. package/parameters/header.js +55 -0
  267. package/parameters/header.js.map +1 -0
  268. package/parameters/index.d.ts +4 -0
  269. package/parameters/index.js +57 -0
  270. package/parameters/index.js.map +1 -0
  271. package/parameters/manual.d.ts +6 -0
  272. package/parameters/manual.js +44 -0
  273. package/parameters/manual.js.map +1 -0
  274. package/parameters/path.d.ts +2 -0
  275. package/parameters/path.js +51 -0
  276. package/parameters/path.js.map +1 -0
  277. package/plugins/CmsGroupPlugin.d.ts +13 -0
  278. package/plugins/CmsGroupPlugin.js +30 -0
  279. package/plugins/CmsGroupPlugin.js.map +1 -0
  280. package/plugins/CmsModelFieldConverterPlugin.d.ts +14 -0
  281. package/plugins/CmsModelFieldConverterPlugin.js +17 -0
  282. package/plugins/CmsModelFieldConverterPlugin.js.map +1 -0
  283. package/plugins/CmsModelPlugin.d.ts +45 -0
  284. package/plugins/CmsModelPlugin.js +194 -0
  285. package/plugins/CmsModelPlugin.js.map +1 -0
  286. package/plugins/CmsParametersPlugin.d.ts +20 -0
  287. package/plugins/CmsParametersPlugin.js +28 -0
  288. package/plugins/CmsParametersPlugin.js.map +1 -0
  289. package/plugins/StorageTransformPlugin.d.ts +31 -0
  290. package/plugins/StorageTransformPlugin.js +37 -0
  291. package/plugins/StorageTransformPlugin.js.map +1 -0
  292. package/plugins/index.d.ts +5 -0
  293. package/plugins/index.js +70 -0
  294. package/plugins/index.js.map +1 -0
  295. package/storage/default.d.ts +2 -0
  296. package/storage/default.js +27 -0
  297. package/storage/default.js.map +1 -0
  298. package/storage/object.d.ts +2 -0
  299. package/storage/object.js +127 -0
  300. package/storage/object.js.map +1 -0
  301. package/types.d.ts +2600 -0
  302. package/types.js +459 -0
  303. package/types.js.map +1 -0
  304. package/upgrades/5.33.0/index.d.ts +3 -0
  305. package/upgrades/5.33.0/index.js +182 -0
  306. package/upgrades/5.33.0/index.js.map +1 -0
  307. package/upgrades/index.d.ts +1 -0
  308. package/upgrades/index.js +12 -0
  309. package/upgrades/index.js.map +1 -0
  310. package/utils/access.d.ts +8 -0
  311. package/utils/access.js +90 -0
  312. package/utils/access.js.map +1 -0
  313. package/utils/converters/Converter.d.ts +27 -0
  314. package/utils/converters/Converter.js +71 -0
  315. package/utils/converters/Converter.js.map +1 -0
  316. package/utils/converters/ConverterCollection.d.ts +31 -0
  317. package/utils/converters/ConverterCollection.js +143 -0
  318. package/utils/converters/ConverterCollection.js.map +1 -0
  319. package/utils/converters/valueKeyStorageConverter.d.ts +18 -0
  320. package/utils/converters/valueKeyStorageConverter.js +148 -0
  321. package/utils/converters/valueKeyStorageConverter.js.map +1 -0
  322. package/utils/createTypeFromFields.d.ts +15 -0
  323. package/utils/createTypeFromFields.js +75 -0
  324. package/utils/createTypeFromFields.js.map +1 -0
  325. package/utils/createTypeName.d.ts +3 -0
  326. package/utils/createTypeName.js +30 -0
  327. package/utils/createTypeName.js.map +1 -0
  328. package/utils/entryStorage.d.ts +17 -0
  329. package/utils/entryStorage.js +120 -0
  330. package/utils/entryStorage.js.map +1 -0
  331. package/utils/filterAsync.d.ts +1 -0
  332. package/utils/filterAsync.js +23 -0
  333. package/utils/filterAsync.js.map +1 -0
  334. package/utils/filterModelFields.d.ts +16 -0
  335. package/utils/filterModelFields.js +77 -0
  336. package/utils/filterModelFields.js.map +1 -0
  337. package/utils/getBaseFieldType.d.ts +4 -0
  338. package/utils/getBaseFieldType.js +12 -0
  339. package/utils/getBaseFieldType.js.map +1 -0
  340. package/utils/getEntryTitle.d.ts +2 -0
  341. package/utils/getEntryTitle.js +43 -0
  342. package/utils/getEntryTitle.js.map +1 -0
  343. package/utils/getSchemaFromFieldPlugins.d.ts +12 -0
  344. package/utils/getSchemaFromFieldPlugins.js +35 -0
  345. package/utils/getSchemaFromFieldPlugins.js.map +1 -0
  346. package/utils/ownership.d.ts +8 -0
  347. package/utils/ownership.js +41 -0
  348. package/utils/ownership.js.map +1 -0
  349. package/utils/permissions.d.ts +7 -0
  350. package/utils/permissions.js +106 -0
  351. package/utils/permissions.js.map +1 -0
  352. package/utils/pluralizedTypeName.d.ts +1 -0
  353. package/utils/pluralizedTypeName.js +26 -0
  354. package/utils/pluralizedTypeName.js.map +1 -0
  355. package/utils/renderFields.d.ts +15 -0
  356. package/utils/renderFields.js +55 -0
  357. package/utils/renderFields.js.map +1 -0
  358. package/utils/renderGetFilterFields.d.ts +10 -0
  359. package/utils/renderGetFilterFields.js +61 -0
  360. package/utils/renderGetFilterFields.js.map +1 -0
  361. package/utils/renderInputFields.d.ts +14 -0
  362. package/utils/renderInputFields.js +55 -0
  363. package/utils/renderInputFields.js.map +1 -0
  364. package/utils/renderListFilterFields.d.ts +11 -0
  365. package/utils/renderListFilterFields.js +62 -0
  366. package/utils/renderListFilterFields.js.map +1 -0
  367. package/utils/renderSortEnum.d.ts +9 -0
  368. package/utils/renderSortEnum.js +34 -0
  369. package/utils/renderSortEnum.js.map +1 -0
  370. package/utils/toSlug.d.ts +1 -0
  371. package/utils/toSlug.js +20 -0
  372. package/utils/toSlug.js.map +1 -0
  373. package/validators/dateGte.d.ts +2 -0
  374. package/validators/dateGte.js +37 -0
  375. package/validators/dateGte.js.map +1 -0
  376. package/validators/dateLte.d.ts +2 -0
  377. package/validators/dateLte.js +37 -0
  378. package/validators/dateLte.js.map +1 -0
  379. package/validators/dynamicZone.d.ts +2 -0
  380. package/validators/dynamicZone.js +24 -0
  381. package/validators/dynamicZone.js.map +1 -0
  382. package/validators/gte.d.ts +2 -0
  383. package/validators/gte.js +36 -0
  384. package/validators/gte.js.map +1 -0
  385. package/validators/in.d.ts +2 -0
  386. package/validators/in.js +36 -0
  387. package/validators/in.js.map +1 -0
  388. package/validators/index.d.ts +1 -0
  389. package/validators/index.js +38 -0
  390. package/validators/index.js.map +1 -0
  391. package/validators/lte.d.ts +2 -0
  392. package/validators/lte.js +36 -0
  393. package/validators/lte.js.map +1 -0
  394. package/validators/maxLength.d.ts +2 -0
  395. package/validators/maxLength.js +36 -0
  396. package/validators/maxLength.js.map +1 -0
  397. package/validators/minLength.d.ts +2 -0
  398. package/validators/minLength.js +36 -0
  399. package/validators/minLength.js.map +1 -0
  400. package/validators/pattern.d.ts +2 -0
  401. package/validators/pattern.js +50 -0
  402. package/validators/pattern.js.map +1 -0
  403. package/validators/patternPlugins/email.d.ts +2 -0
  404. package/validators/patternPlugins/email.js +20 -0
  405. package/validators/patternPlugins/email.js.map +1 -0
  406. package/validators/patternPlugins/index.d.ts +2 -0
  407. package/validators/patternPlugins/index.js +24 -0
  408. package/validators/patternPlugins/index.js.map +1 -0
  409. package/validators/patternPlugins/lowerCase.d.ts +2 -0
  410. package/validators/patternPlugins/lowerCase.js +20 -0
  411. package/validators/patternPlugins/lowerCase.js.map +1 -0
  412. package/validators/patternPlugins/lowerCaseSpace.d.ts +2 -0
  413. package/validators/patternPlugins/lowerCaseSpace.js +20 -0
  414. package/validators/patternPlugins/lowerCaseSpace.js.map +1 -0
  415. package/validators/patternPlugins/upperCase.d.ts +2 -0
  416. package/validators/patternPlugins/upperCase.js +20 -0
  417. package/validators/patternPlugins/upperCase.js.map +1 -0
  418. package/validators/patternPlugins/upperCaseSpace.d.ts +2 -0
  419. package/validators/patternPlugins/upperCaseSpace.js +20 -0
  420. package/validators/patternPlugins/upperCaseSpace.js.map +1 -0
  421. package/validators/patternPlugins/url.d.ts +2 -0
  422. package/validators/patternPlugins/url.js +20 -0
  423. package/validators/patternPlugins/url.js.map +1 -0
  424. package/validators/required.d.ts +2 -0
  425. package/validators/required.js +27 -0
  426. package/validators/required.js.map +1 -0
  427. package/validators/timeGte.d.ts +2 -0
  428. package/validators/timeGte.js +34 -0
  429. package/validators/timeGte.js.map +1 -0
  430. package/validators/timeLte.d.ts +2 -0
  431. package/validators/timeLte.js +34 -0
  432. package/validators/timeLte.js.map +1 -0
  433. package/validators/unique.d.ts +6 -0
  434. package/validators/unique.js +63 -0
  435. package/validators/unique.js.map +1 -0
@@ -0,0 +1,650 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.createModelsCrud = void 0;
9
+
10
+ var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
11
+
12
+ var _dataloader = _interopRequireDefault(require("dataloader"));
13
+
14
+ var _handlerGraphql = require("@webiny/handler-graphql");
15
+
16
+ var _contentModelManagerFactory = require("./contentModel/contentModelManagerFactory");
17
+
18
+ var _models = require("./contentModel/models");
19
+
20
+ var _createFieldModels = require("./contentModel/createFieldModels");
21
+
22
+ var _error = _interopRequireDefault(require("@webiny/error"));
23
+
24
+ var _pubsub = require("@webiny/pubsub");
25
+
26
+ var _beforeCreate = require("./contentModel/beforeCreate");
27
+
28
+ var _beforeUpdate = require("./contentModel/beforeUpdate");
29
+
30
+ var _beforeDelete = require("./contentModel/beforeDelete");
31
+
32
+ var _afterCreate = require("./contentModel/afterCreate");
33
+
34
+ var _afterUpdate = require("./contentModel/afterUpdate");
35
+
36
+ var _afterDelete = require("./contentModel/afterDelete");
37
+
38
+ var _afterCreateFrom = require("./contentModel/afterCreateFrom");
39
+
40
+ var _CmsModelPlugin = require("../plugins/CmsModelPlugin");
41
+
42
+ var _permissions = require("../utils/permissions");
43
+
44
+ var _filterAsync = require("../utils/filterAsync");
45
+
46
+ var _ownership = require("../utils/ownership");
47
+
48
+ var _access = require("../utils/access");
49
+
50
+ var _validateModelFields = require("./contentModel/validateModelFields");
51
+
52
+ /**
53
+ * Given a model, return an array of tags ensuring the `type` tag is set.
54
+ */
55
+ const ensureTypeTag = model => {
56
+ // Let's make sure we have a `type` tag assigned.
57
+ // If `type` tag is not set, set it to a default one (`model`).
58
+ const tags = model.tags || [];
59
+
60
+ if (!tags.some(tag => tag.startsWith("type:"))) {
61
+ tags.push("type:model");
62
+ }
63
+
64
+ return tags;
65
+ };
66
+
67
+ const createModelsCrud = params => {
68
+ const {
69
+ getTenant,
70
+ getIdentity,
71
+ getLocale,
72
+ storageOperations,
73
+ context
74
+ } = params;
75
+ const loaders = {
76
+ listModels: new _dataloader.default(async () => {
77
+ const models = await storageOperations.models.list({
78
+ where: {
79
+ tenant: getTenant().id,
80
+ locale: getLocale().code
81
+ }
82
+ });
83
+ return [models.map(model => {
84
+ return (0, _objectSpread2.default)((0, _objectSpread2.default)({}, model), {}, {
85
+ tags: ensureTypeTag(model),
86
+ tenant: model.tenant || getTenant().id,
87
+ locale: model.locale || getLocale().code
88
+ });
89
+ })];
90
+ })
91
+ };
92
+
93
+ const clearModelsCache = () => {
94
+ for (const loader of Object.values(loaders)) {
95
+ loader.clearAll();
96
+ }
97
+ };
98
+
99
+ const managers = new Map();
100
+
101
+ const updateManager = async (context, model) => {
102
+ const manager = await (0, _contentModelManagerFactory.contentModelManagerFactory)(context, model);
103
+ managers.set(model.modelId, manager);
104
+ return manager;
105
+ };
106
+
107
+ const checkModelPermissions = check => {
108
+ return (0, _permissions.checkPermissions)(context, "cms.contentModel", {
109
+ rwd: check
110
+ });
111
+ };
112
+
113
+ const getModelsAsPlugins = () => {
114
+ const tenant = getTenant().id;
115
+ const locale = getLocale().code;
116
+ const models = context.plugins.byType(_CmsModelPlugin.CmsModelPlugin.type)
117
+ /**
118
+ * We need to filter out models that are not for this tenant or locale.
119
+ * If it does not have tenant or locale define, it is for every locale and tenant
120
+ */
121
+ .filter(plugin => {
122
+ const {
123
+ tenant: modelTenant,
124
+ locale: modelLocale
125
+ } = plugin.contentModel;
126
+
127
+ if (modelTenant && modelTenant !== tenant) {
128
+ return false;
129
+ } else if (modelLocale && modelLocale !== locale) {
130
+ return false;
131
+ }
132
+
133
+ return true;
134
+ }).map(plugin => {
135
+ return (0, _objectSpread2.default)((0, _objectSpread2.default)({}, plugin.contentModel), {}, {
136
+ tags: ensureTypeTag(plugin.contentModel),
137
+ tenant,
138
+ locale,
139
+ webinyVersion: context.WEBINY_VERSION
140
+ });
141
+ });
142
+ /**
143
+ * Only point where we can truly validate the user model is in the runtime.
144
+ */
145
+
146
+ for (const model of models) {
147
+ (0, _validateModelFields.validateModelFields)({
148
+ model,
149
+ plugins: context.plugins
150
+ });
151
+ }
152
+
153
+ return models;
154
+ };
155
+
156
+ const modelsGet = async modelId => {
157
+ const pluginModel = getModelsAsPlugins().find(model => model.modelId === modelId);
158
+
159
+ if (pluginModel) {
160
+ return pluginModel;
161
+ }
162
+
163
+ const model = await storageOperations.models.get({
164
+ tenant: getTenant().id,
165
+ locale: getLocale().code,
166
+ modelId
167
+ });
168
+
169
+ if (!model) {
170
+ throw new _handlerGraphql.NotFoundError(`Content model "${modelId}" was not found!`);
171
+ }
172
+
173
+ return (0, _objectSpread2.default)((0, _objectSpread2.default)({}, model), {}, {
174
+ tags: ensureTypeTag(model),
175
+ tenant: model.tenant || getTenant().id,
176
+ locale: model.locale || getLocale().code
177
+ });
178
+ };
179
+
180
+ const modelsList = async () => {
181
+ const databaseModels = await loaders.listModels.load("listModels");
182
+ const pluginsModels = getModelsAsPlugins();
183
+ return databaseModels.concat(pluginsModels);
184
+ };
185
+
186
+ const listModels = async () => {
187
+ const permission = await checkModelPermissions("r");
188
+ const models = await modelsList();
189
+ return (0, _filterAsync.filterAsync)(models, async model => {
190
+ if (!(0, _ownership.validateOwnership)(context, permission, model)) {
191
+ return false;
192
+ }
193
+
194
+ return (0, _access.validateModelAccess)(context, model);
195
+ });
196
+ };
197
+
198
+ const getModel = async modelId => {
199
+ const permission = await checkModelPermissions("r");
200
+ const model = await modelsGet(modelId);
201
+ (0, _ownership.checkOwnership)(context, permission, model);
202
+ await (0, _access.checkModelAccess)(context, model);
203
+ return model;
204
+ };
205
+
206
+ const getModelManager = async target => {
207
+ const modelId = typeof target === "string" ? target : target.modelId;
208
+
209
+ if (managers.has(modelId)) {
210
+ return managers.get(modelId);
211
+ }
212
+
213
+ const models = await modelsList();
214
+ const model = models.find(m => m.modelId === modelId);
215
+
216
+ if (!model) {
217
+ throw new _handlerGraphql.NotFoundError(`There is no content model "${modelId}".`);
218
+ }
219
+
220
+ return await updateManager(context, model);
221
+ };
222
+ /**
223
+ * Create
224
+ */
225
+
226
+
227
+ const onModelBeforeCreate = (0, _pubsub.createTopic)("cms.onModelBeforeCreate");
228
+ const onModelAfterCreate = (0, _pubsub.createTopic)("cms.onModelAfterCreate");
229
+ const onModelCreateError = (0, _pubsub.createTopic)("cms.onModelCreateError");
230
+ /**
231
+ * Create from / clone
232
+ */
233
+
234
+ const onModelBeforeCreateFrom = (0, _pubsub.createTopic)("cms.onModelBeforeCreateFrom");
235
+ const onModelAfterCreateFrom = (0, _pubsub.createTopic)("cms.onModelAfterCreateFrom");
236
+ const onModelCreateFromError = (0, _pubsub.createTopic)("cms.onModelCreateFromError");
237
+ /**
238
+ * Update
239
+ */
240
+
241
+ const onModelBeforeUpdate = (0, _pubsub.createTopic)("cms.onModelBeforeUpdate");
242
+ const onModelAfterUpdate = (0, _pubsub.createTopic)("cms.onModelAfterUpdate");
243
+ const onModelUpdateError = (0, _pubsub.createTopic)("cms.onModelUpdateError");
244
+ /**
245
+ * Delete
246
+ */
247
+
248
+ const onModelBeforeDelete = (0, _pubsub.createTopic)("cms.onModelBeforeDelete");
249
+ const onModelAfterDelete = (0, _pubsub.createTopic)("cms.onModelAfterDelete");
250
+ const onModelDeleteError = (0, _pubsub.createTopic)("cms.onModelDeleteError");
251
+ /**
252
+ * Initialize
253
+ */
254
+
255
+ const onModelInitialize = (0, _pubsub.createTopic)("cms.onModelInitialize");
256
+ /**
257
+ * We need to assign some default behaviors.
258
+ */
259
+
260
+ (0, _beforeCreate.assignModelBeforeCreate)({
261
+ onModelBeforeCreate,
262
+ onModelBeforeCreateFrom,
263
+ plugins: context.plugins,
264
+ storageOperations
265
+ });
266
+ (0, _afterCreate.assignModelAfterCreate)({
267
+ context,
268
+ onModelAfterCreate
269
+ });
270
+ (0, _beforeUpdate.assignModelBeforeUpdate)({
271
+ onModelBeforeUpdate,
272
+ plugins: context.plugins,
273
+ storageOperations
274
+ });
275
+ (0, _afterUpdate.assignModelAfterUpdate)({
276
+ context,
277
+ onModelAfterUpdate
278
+ });
279
+ (0, _afterCreateFrom.assignModelAfterCreateFrom)({
280
+ context,
281
+ onModelAfterCreateFrom
282
+ });
283
+ (0, _beforeDelete.assignModelBeforeDelete)({
284
+ onModelBeforeDelete,
285
+ plugins: context.plugins,
286
+ storageOperations
287
+ });
288
+ (0, _afterDelete.assignModelAfterDelete)({
289
+ context,
290
+ onModelAfterDelete
291
+ });
292
+ return {
293
+ /**
294
+ * Deprecated - will be removed in 5.36.0
295
+ */
296
+ onBeforeModelCreate: onModelBeforeCreate,
297
+ onAfterModelCreate: onModelAfterCreate,
298
+ onBeforeModelCreateFrom: onModelBeforeCreateFrom,
299
+ onAfterModelCreateFrom: onModelAfterCreateFrom,
300
+ onBeforeModelUpdate: onModelBeforeUpdate,
301
+ onAfterModelUpdate: onModelAfterUpdate,
302
+ onBeforeModelDelete: onModelBeforeDelete,
303
+ onAfterModelDelete: onModelAfterDelete,
304
+
305
+ /**
306
+ * Released in 5.34.0
307
+ */
308
+ onModelBeforeCreate,
309
+ onModelAfterCreate,
310
+ onModelCreateError,
311
+ onModelBeforeCreateFrom,
312
+ onModelAfterCreateFrom,
313
+ onModelCreateFromError,
314
+ onModelBeforeUpdate,
315
+ onModelAfterUpdate,
316
+ onModelUpdateError,
317
+ onModelBeforeDelete,
318
+ onModelAfterDelete,
319
+ onModelDeleteError,
320
+ onModelInitialize,
321
+ clearModelsCache,
322
+ getModel,
323
+ listModels,
324
+
325
+ async createModel(inputData) {
326
+ await checkModelPermissions("w");
327
+ const createdData = new _models.CreateContentModelModel().populate(inputData);
328
+ await createdData.validate();
329
+ const input = await createdData.toJSON();
330
+ context.security.disableAuthorization();
331
+ const group = await context.cms.getGroup(input.group);
332
+ context.security.enableAuthorization();
333
+
334
+ if (!group) {
335
+ throw new _handlerGraphql.NotFoundError(`There is no group "${input.group}".`);
336
+ }
337
+
338
+ const fields = await (0, _createFieldModels.createFieldModels)(input.fields);
339
+ const identity = getIdentity();
340
+ const model = {
341
+ name: input.name,
342
+ description: input.description || "",
343
+ modelId: input.modelId || "",
344
+ titleFieldId: "id",
345
+ locale: getLocale().code,
346
+ tenant: getTenant().id,
347
+ group: {
348
+ id: group.id,
349
+ name: group.name
350
+ },
351
+ createdBy: {
352
+ id: identity.id,
353
+ displayName: identity.displayName,
354
+ type: identity.type
355
+ },
356
+ createdOn: new Date().toISOString(),
357
+ savedOn: new Date().toISOString(),
358
+ fields,
359
+ lockedFields: [],
360
+ layout: input.layout || [],
361
+ tags: [...(input.tags || [])],
362
+ webinyVersion: context.WEBINY_VERSION
363
+ };
364
+ model.tags = ensureTypeTag(model);
365
+
366
+ try {
367
+ await onModelBeforeCreate.publish({
368
+ input,
369
+ model
370
+ });
371
+ const createdModel = await storageOperations.models.create({
372
+ model
373
+ });
374
+ loaders.listModels.clearAll();
375
+ await updateManager(context, model);
376
+ await onModelAfterCreate.publish({
377
+ input,
378
+ model: createdModel
379
+ });
380
+ return createdModel;
381
+ } catch (ex) {
382
+ await onModelCreateError.publish({
383
+ input,
384
+ model,
385
+ error: ex
386
+ });
387
+ throw ex;
388
+ }
389
+ },
390
+
391
+ /**
392
+ * Method does not check for permissions or ownership.
393
+ * @internal
394
+ */
395
+ async updateModelDirect(params) {
396
+ const {
397
+ model: initialModel,
398
+ original
399
+ } = params;
400
+ const model = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, initialModel), {}, {
401
+ tenant: initialModel.tenant || getTenant().id,
402
+ locale: initialModel.locale || getLocale().code,
403
+ webinyVersion: context.WEBINY_VERSION
404
+ });
405
+
406
+ try {
407
+ await onModelBeforeUpdate.publish({
408
+ input: {},
409
+ original,
410
+ model
411
+ });
412
+ const resultModel = await storageOperations.models.update({
413
+ model
414
+ });
415
+ await updateManager(context, resultModel);
416
+ loaders.listModels.clearAll();
417
+ await onModelAfterUpdate.publish({
418
+ input: {},
419
+ original,
420
+ model: resultModel
421
+ });
422
+ return resultModel;
423
+ } catch (ex) {
424
+ await onModelUpdateError.publish({
425
+ input: {},
426
+ original,
427
+ model,
428
+ error: ex
429
+ });
430
+ throw ex;
431
+ }
432
+ },
433
+
434
+ async createModelFrom(modelId, data) {
435
+ await checkModelPermissions("w");
436
+ /**
437
+ * Get a model record; this will also perform ownership validation.
438
+ */
439
+
440
+ const original = await getModel(modelId);
441
+ const createdData = new _models.CreateContentModelModelFrom().populate({
442
+ name: data.name,
443
+ modelId: data.modelId,
444
+ description: data.description || original.description,
445
+ group: data.group,
446
+ locale: data.locale
447
+ });
448
+ await createdData.validate();
449
+ const input = await createdData.toJSON();
450
+ const locale = await context.i18n.getLocale(input.locale || original.locale);
451
+
452
+ if (!locale) {
453
+ throw new _handlerGraphql.NotFoundError(`There is no locale "${input.locale}".`);
454
+ }
455
+ /**
456
+ * Use storage operations directly because we cannot get group from different locale via context methods.
457
+ */
458
+
459
+
460
+ const group = await context.cms.storageOperations.groups.get({
461
+ id: input.group,
462
+ tenant: original.tenant,
463
+ locale: locale.code
464
+ });
465
+
466
+ if (!group) {
467
+ throw new _handlerGraphql.NotFoundError(`There is no group "${input.group}".`);
468
+ }
469
+
470
+ const identity = getIdentity();
471
+ const model = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, original), {}, {
472
+ locale: locale.code,
473
+ group: {
474
+ id: group.id,
475
+ name: group.name
476
+ },
477
+ name: input.name,
478
+ modelId: input.modelId || "",
479
+ description: input.description || "",
480
+ createdBy: {
481
+ id: identity.id,
482
+ displayName: identity.displayName,
483
+ type: identity.type
484
+ },
485
+ createdOn: new Date().toISOString(),
486
+ savedOn: new Date().toISOString(),
487
+ lockedFields: [],
488
+ webinyVersion: context.WEBINY_VERSION
489
+ });
490
+
491
+ try {
492
+ await onModelBeforeCreateFrom.publish({
493
+ input,
494
+ model,
495
+ original
496
+ });
497
+ const createdModel = await storageOperations.models.create({
498
+ model
499
+ });
500
+ loaders.listModels.clearAll();
501
+ await updateManager(context, model);
502
+ await onModelAfterCreateFrom.publish({
503
+ input,
504
+ original,
505
+ model: createdModel
506
+ });
507
+ return createdModel;
508
+ } catch (ex) {
509
+ await onModelCreateFromError.publish({
510
+ input,
511
+ original,
512
+ model,
513
+ error: ex
514
+ });
515
+ throw ex;
516
+ }
517
+ },
518
+
519
+ async updateModel(modelId, inputData) {
520
+ await checkModelPermissions("w"); // Get a model record; this will also perform ownership validation.
521
+
522
+ const original = await getModel(modelId);
523
+ const updatedData = new _models.UpdateContentModelModel().populate(inputData);
524
+ await updatedData.validate();
525
+ const input = await updatedData.toJSON({
526
+ onlyDirty: true
527
+ });
528
+
529
+ if (Object.keys(input).length === 0) {
530
+ /**
531
+ * We need to return the original if nothing is to be updated.
532
+ */
533
+ return original;
534
+ }
535
+
536
+ let group = {
537
+ id: original.group.id,
538
+ name: original.group.name
539
+ };
540
+
541
+ if (input.group) {
542
+ context.security.disableAuthorization();
543
+ const groupData = await context.cms.getGroup(input.group);
544
+ context.security.enableAuthorization();
545
+
546
+ if (!groupData) {
547
+ throw new _handlerGraphql.NotFoundError(`There is no group "${input.group}".`);
548
+ }
549
+
550
+ group = {
551
+ id: groupData.id,
552
+ name: groupData.name
553
+ };
554
+ }
555
+
556
+ const fields = await (0, _createFieldModels.createFieldModels)(inputData.fields);
557
+ const model = (0, _objectSpread2.default)((0, _objectSpread2.default)((0, _objectSpread2.default)({}, original), input), {}, {
558
+ group,
559
+ tenant: original.tenant || getTenant().id,
560
+ locale: original.locale || getLocale().code,
561
+ webinyVersion: context.WEBINY_VERSION,
562
+ fields,
563
+ savedOn: new Date().toISOString()
564
+ });
565
+ model.tags = ensureTypeTag(model);
566
+
567
+ try {
568
+ await onModelBeforeUpdate.publish({
569
+ input,
570
+ original,
571
+ model
572
+ });
573
+ const resultModel = await storageOperations.models.update({
574
+ model
575
+ });
576
+ await updateManager(context, resultModel);
577
+ await onModelAfterUpdate.publish({
578
+ input,
579
+ original,
580
+ model: resultModel
581
+ });
582
+ return resultModel;
583
+ } catch (ex) {
584
+ await onModelUpdateError.publish({
585
+ input,
586
+ model,
587
+ original,
588
+ error: ex
589
+ });
590
+ throw ex;
591
+ }
592
+ },
593
+
594
+ async deleteModel(modelId) {
595
+ await checkModelPermissions("d");
596
+ const model = await getModel(modelId);
597
+
598
+ try {
599
+ await onModelBeforeDelete.publish({
600
+ model
601
+ });
602
+
603
+ try {
604
+ await storageOperations.models.delete({
605
+ model
606
+ });
607
+ } catch (ex) {
608
+ throw new _error.default(ex.message || "Could not delete the content model", ex.code || "CONTENT_MODEL_DELETE_ERROR", {
609
+ error: ex,
610
+ modelId: model.modelId
611
+ });
612
+ }
613
+
614
+ await onModelAfterDelete.publish({
615
+ model
616
+ });
617
+ managers.delete(model.modelId);
618
+ } catch (ex) {
619
+ await onModelDeleteError.publish({
620
+ model,
621
+ error: ex
622
+ });
623
+ throw ex;
624
+ }
625
+ },
626
+
627
+ async initializeModel(modelId, data) {
628
+ /**
629
+ * We require that users have write permissions to initialize models.
630
+ * Maybe introduce another permission for it?
631
+ */
632
+ await checkModelPermissions("w");
633
+ const model = await getModel(modelId);
634
+ await onModelInitialize.publish({
635
+ model,
636
+ data
637
+ });
638
+ return true;
639
+ },
640
+
641
+ getModelManager,
642
+ getEntryManager: async model => {
643
+ return getModelManager(model);
644
+ },
645
+ getManagers: () => managers,
646
+ getEntryManagers: () => managers
647
+ };
648
+ };
649
+
650
+ exports.createModelsCrud = createModelsCrud;