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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (644) hide show
  1. package/context.d.ts +6 -0
  2. package/context.js +94 -0
  3. package/context.js.map +1 -0
  4. package/crud/contentEntry/afterDelete.d.ts +8 -0
  5. package/{content/plugins/crud → crud}/contentEntry/afterDelete.js +2 -7
  6. package/crud/contentEntry/afterDelete.js.map +1 -0
  7. package/crud/contentEntry/beforeCreate.d.ts +8 -0
  8. package/{content/plugins/crud → crud}/contentEntry/beforeCreate.js +2 -5
  9. package/crud/contentEntry/beforeCreate.js.map +1 -0
  10. package/crud/contentEntry/beforeUpdate.d.ts +8 -0
  11. package/{content/plugins/crud → crud}/contentEntry/beforeUpdate.js +2 -5
  12. package/crud/contentEntry/beforeUpdate.js.map +1 -0
  13. package/crud/contentEntry/entryDataValidation.d.ts +10 -0
  14. package/{content/plugins/crud → crud}/contentEntry/entryDataValidation.js +22 -49
  15. package/crud/contentEntry/entryDataValidation.js.map +1 -0
  16. package/{content/plugins/crud → crud}/contentEntry/markLockedFields.d.ts +3 -2
  17. package/{content/plugins/crud → crud}/contentEntry/markLockedFields.js +29 -43
  18. package/crud/contentEntry/markLockedFields.js.map +1 -0
  19. package/crud/contentEntry/referenceFieldsMapping.d.ts +13 -0
  20. package/crud/contentEntry/referenceFieldsMapping.js +236 -0
  21. package/crud/contentEntry/referenceFieldsMapping.js.map +1 -0
  22. package/crud/contentEntry/searchableFields.d.ts +9 -0
  23. package/crud/contentEntry/searchableFields.js +72 -0
  24. package/crud/contentEntry/searchableFields.js.map +1 -0
  25. package/{content/plugins/crud → crud}/contentEntry.crud.d.ts +6 -9
  26. package/crud/contentEntry.crud.js +1202 -0
  27. package/crud/contentEntry.crud.js.map +1 -0
  28. package/crud/contentModel/afterCreate.d.ts +8 -0
  29. package/crud/contentModel/afterCreate.js +16 -0
  30. package/crud/contentModel/afterCreate.js.map +1 -0
  31. package/crud/contentModel/afterCreateFrom.d.ts +8 -0
  32. package/crud/contentModel/afterCreateFrom.js +16 -0
  33. package/crud/contentModel/afterCreateFrom.js.map +1 -0
  34. package/crud/contentModel/afterDelete.d.ts +8 -0
  35. package/crud/contentModel/afterDelete.js +16 -0
  36. package/crud/contentModel/afterDelete.js.map +1 -0
  37. package/crud/contentModel/afterUpdate.d.ts +8 -0
  38. package/crud/contentModel/afterUpdate.js +16 -0
  39. package/crud/contentModel/afterUpdate.js.map +1 -0
  40. package/crud/contentModel/beforeCreate.d.ts +14 -0
  41. package/{content/plugins/crud → crud}/contentModel/beforeCreate.js +62 -39
  42. package/crud/contentModel/beforeCreate.js.map +1 -0
  43. package/crud/contentModel/beforeDelete.d.ts +10 -0
  44. package/{content/plugins/crud → crud}/contentModel/beforeDelete.js +13 -19
  45. package/crud/contentModel/beforeDelete.js.map +1 -0
  46. package/crud/contentModel/beforeUpdate.d.ts +8 -0
  47. package/crud/contentModel/beforeUpdate.js +36 -0
  48. package/crud/contentModel/beforeUpdate.js.map +1 -0
  49. package/crud/contentModel/compatibility/modelApiName.d.ts +3 -0
  50. package/crud/contentModel/compatibility/modelApiName.js +24 -0
  51. package/crud/contentModel/compatibility/modelApiName.js.map +1 -0
  52. package/crud/contentModel/contentModelManagerFactory.d.ts +2 -0
  53. package/{content/plugins/crud → crud}/contentModel/contentModelManagerFactory.js +0 -7
  54. package/crud/contentModel/contentModelManagerFactory.js.map +1 -0
  55. package/crud/contentModel/createFieldModels.d.ts +2 -0
  56. package/{content/plugins/crud → crud}/contentModel/createFieldModels.js +6 -2
  57. package/crud/contentModel/createFieldModels.js.map +1 -0
  58. package/crud/contentModel/createFieldStorageId.d.ts +2 -0
  59. package/crud/contentModel/createFieldStorageId.js +17 -0
  60. package/crud/contentModel/createFieldStorageId.js.map +1 -0
  61. package/crud/contentModel/defaultFields.d.ts +5 -0
  62. package/crud/contentModel/defaultFields.js +58 -0
  63. package/crud/contentModel/defaultFields.js.map +1 -0
  64. package/crud/contentModel/fieldIdValidation.d.ts +1 -0
  65. package/crud/contentModel/fieldIdValidation.js +25 -0
  66. package/crud/contentModel/fieldIdValidation.js.map +1 -0
  67. package/crud/contentModel/fields/descriptionField.d.ts +2 -0
  68. package/crud/contentModel/fields/descriptionField.js +42 -0
  69. package/crud/contentModel/fields/descriptionField.js.map +1 -0
  70. package/crud/contentModel/fields/imageField.d.ts +2 -0
  71. package/crud/contentModel/fields/imageField.js +46 -0
  72. package/crud/contentModel/fields/imageField.js.map +1 -0
  73. package/crud/contentModel/fields/titleField.d.ts +2 -0
  74. package/crud/contentModel/fields/titleField.js +58 -0
  75. package/crud/contentModel/fields/titleField.js.map +1 -0
  76. package/crud/contentModel/idValidation.d.ts +1 -0
  77. package/{content/plugins/crud → crud}/contentModel/idValidation.js +3 -3
  78. package/crud/contentModel/idValidation.js.map +1 -0
  79. package/{content/plugins/crud → crud}/contentModel/models.d.ts +2 -1
  80. package/{content/plugins/crud → crud}/contentModel/models.js +76 -25
  81. package/crud/contentModel/models.js.map +1 -0
  82. package/crud/contentModel/systemFields.d.ts +1 -0
  83. package/crud/contentModel/systemFields.js +8 -0
  84. package/crud/contentModel/systemFields.js.map +1 -0
  85. package/crud/contentModel/validateLayout.d.ts +2 -0
  86. package/{content/plugins/crud → crud}/contentModel/validateLayout.js +1 -11
  87. package/crud/contentModel/validateLayout.js.map +1 -0
  88. package/crud/contentModel/validateModel.d.ts +9 -0
  89. package/crud/contentModel/validateModel.js +27 -0
  90. package/crud/contentModel/validateModel.js.map +1 -0
  91. package/crud/contentModel/validateModelFields.d.ts +9 -0
  92. package/crud/contentModel/validateModelFields.js +343 -0
  93. package/crud/contentModel/validateModelFields.js.map +1 -0
  94. package/crud/contentModel/validation.d.ts +519 -0
  95. package/crud/contentModel/validation.js +145 -0
  96. package/crud/contentModel/validation.js.map +1 -0
  97. package/{content/plugins/crud → crud}/contentModel.crud.d.ts +3 -3
  98. package/crud/contentModel.crud.js +578 -0
  99. package/crud/contentModel.crud.js.map +1 -0
  100. package/crud/contentModelGroup/beforeCreate.d.ts +10 -0
  101. package/{content/plugins/crud → crud}/contentModelGroup/beforeCreate.js +8 -20
  102. package/crud/contentModelGroup/beforeCreate.js.map +1 -0
  103. package/crud/contentModelGroup/beforeDelete.d.ts +10 -0
  104. package/{content/plugins/crud → crud}/contentModelGroup/beforeDelete.js +4 -12
  105. package/crud/contentModelGroup/beforeDelete.js.map +1 -0
  106. package/crud/contentModelGroup/beforeUpdate.d.ts +9 -0
  107. package/{content/plugins/crud → crud}/contentModelGroup/beforeUpdate.js +3 -8
  108. package/crud/contentModelGroup/beforeUpdate.js.map +1 -0
  109. package/crud/contentModelGroup/validation.d.ts +30 -0
  110. package/crud/contentModelGroup/validation.js +34 -0
  111. package/crud/contentModelGroup/validation.js.map +1 -0
  112. package/{content/plugins/crud → crud}/contentModelGroup.crud.d.ts +3 -3
  113. package/crud/contentModelGroup.crud.js +324 -0
  114. package/crud/contentModelGroup.crud.js.map +1 -0
  115. package/{plugins/crud → crud}/settings.crud.d.ts +3 -3
  116. package/crud/settings.crud.js +71 -0
  117. package/crud/settings.crud.js.map +1 -0
  118. package/{plugins/crud → crud}/system.crud.d.ts +6 -3
  119. package/crud/system.crud.js +126 -0
  120. package/crud/system.crud.js.map +1 -0
  121. package/fieldConverters/CmsModelDefaultFieldConverterPlugin.d.ts +7 -0
  122. package/fieldConverters/CmsModelDefaultFieldConverterPlugin.js +53 -0
  123. package/fieldConverters/CmsModelDefaultFieldConverterPlugin.js.map +1 -0
  124. package/fieldConverters/CmsModelDynamicZoneFieldConverterPlugin.d.ts +11 -0
  125. package/fieldConverters/CmsModelDynamicZoneFieldConverterPlugin.js +203 -0
  126. package/fieldConverters/CmsModelDynamicZoneFieldConverterPlugin.js.map +1 -0
  127. package/fieldConverters/CmsModelObjectFieldConverterPlugin.d.ts +11 -0
  128. package/fieldConverters/CmsModelObjectFieldConverterPlugin.js +251 -0
  129. package/fieldConverters/CmsModelObjectFieldConverterPlugin.js.map +1 -0
  130. package/fieldConverters/index.d.ts +4 -0
  131. package/fieldConverters/index.js +13 -0
  132. package/fieldConverters/index.js.map +1 -0
  133. package/graphql/buildSchemaPlugins.d.ts +11 -0
  134. package/graphql/buildSchemaPlugins.js +19 -0
  135. package/graphql/buildSchemaPlugins.js.map +1 -0
  136. package/graphql/createExecutableSchema.d.ts +7 -0
  137. package/graphql/createExecutableSchema.js +29 -0
  138. package/graphql/createExecutableSchema.js.map +1 -0
  139. package/graphql/generateSchema.d.ts +8 -0
  140. package/graphql/generateSchema.js +31 -0
  141. package/graphql/generateSchema.js.map +1 -0
  142. package/graphql/graphQLHandlerFactory.d.ts +5 -0
  143. package/graphql/graphQLHandlerFactory.js +179 -0
  144. package/graphql/graphQLHandlerFactory.js.map +1 -0
  145. package/graphql/index.d.ts +3 -0
  146. package/graphql/index.js +13 -0
  147. package/graphql/index.js.map +1 -0
  148. package/graphql/schema/baseContentSchema.d.ts +7 -0
  149. package/graphql/schema/baseContentSchema.js +66 -0
  150. package/graphql/schema/baseContentSchema.js.map +1 -0
  151. package/graphql/schema/baseSchema.d.ts +3 -0
  152. package/graphql/schema/baseSchema.js +53 -0
  153. package/graphql/schema/baseSchema.js.map +1 -0
  154. package/graphql/schema/contentEntries.d.ts +7 -0
  155. package/graphql/schema/contentEntries.js +362 -0
  156. package/graphql/schema/contentEntries.js.map +1 -0
  157. package/graphql/schema/contentModelGroups.d.ts +7 -0
  158. package/{content/plugins → graphql}/schema/contentModelGroups.js +39 -33
  159. package/graphql/schema/contentModelGroups.js.map +1 -0
  160. package/graphql/schema/contentModels.d.ts +7 -0
  161. package/{content/plugins → graphql}/schema/contentModels.js +121 -29
  162. package/graphql/schema/contentModels.js.map +1 -0
  163. package/graphql/schema/createFieldResolvers.d.ts +20 -0
  164. package/graphql/schema/createFieldResolvers.js +110 -0
  165. package/graphql/schema/createFieldResolvers.js.map +1 -0
  166. package/graphql/schema/createManageResolvers.d.ts +12 -0
  167. package/graphql/schema/createManageResolvers.js +127 -0
  168. package/graphql/schema/createManageResolvers.js.map +1 -0
  169. package/graphql/schema/createManageSDL.d.ts +13 -0
  170. package/graphql/schema/createManageSDL.js +157 -0
  171. package/graphql/schema/createManageSDL.js.map +1 -0
  172. package/graphql/schema/createPreviewResolvers.d.ts +12 -0
  173. package/graphql/schema/createPreviewResolvers.js +44 -0
  174. package/graphql/schema/createPreviewResolvers.js.map +1 -0
  175. package/graphql/schema/createReadResolvers.d.ts +12 -0
  176. package/graphql/schema/createReadResolvers.js +49 -0
  177. package/graphql/schema/createReadResolvers.js.map +1 -0
  178. package/graphql/schema/createReadSDL.d.ts +13 -0
  179. package/graphql/schema/createReadSDL.js +100 -0
  180. package/graphql/schema/createReadSDL.js.map +1 -0
  181. package/graphql/schema/resolvers/commonFieldResolvers.d.ts +7 -0
  182. package/{content/plugins → graphql}/schema/resolvers/commonFieldResolvers.js +2 -3
  183. package/graphql/schema/resolvers/commonFieldResolvers.js.map +1 -0
  184. package/graphql/schema/resolvers/manage/resolveCreate.d.ts +7 -0
  185. package/{content/plugins → graphql}/schema/resolvers/manage/resolveCreate.js +2 -7
  186. package/graphql/schema/resolvers/manage/resolveCreate.js.map +1 -0
  187. package/graphql/schema/resolvers/manage/resolveCreateFrom.d.ts +8 -0
  188. package/{content/plugins → graphql}/schema/resolvers/manage/resolveCreateFrom.js +2 -7
  189. package/graphql/schema/resolvers/manage/resolveCreateFrom.js.map +1 -0
  190. package/graphql/schema/resolvers/manage/resolveDelete.d.ts +7 -0
  191. package/{content/plugins → graphql}/schema/resolvers/manage/resolveDelete.js +8 -12
  192. package/graphql/schema/resolvers/manage/resolveDelete.js.map +1 -0
  193. package/graphql/schema/resolvers/manage/resolveGet.d.ts +7 -0
  194. package/graphql/schema/resolvers/manage/resolveGet.js +63 -0
  195. package/graphql/schema/resolvers/manage/resolveGet.js.map +1 -0
  196. package/graphql/schema/resolvers/manage/resolveGetByIds.d.ts +7 -0
  197. package/{content/plugins → graphql}/schema/resolvers/manage/resolveGetByIds.js +2 -7
  198. package/graphql/schema/resolvers/manage/resolveGetByIds.js.map +1 -0
  199. package/graphql/schema/resolvers/manage/resolveGetRevisions.d.ts +7 -0
  200. package/{content/plugins → graphql}/schema/resolvers/manage/resolveGetRevisions.js +2 -7
  201. package/graphql/schema/resolvers/manage/resolveGetRevisions.js.map +1 -0
  202. package/graphql/schema/resolvers/manage/resolveList.d.ts +4 -0
  203. package/{content/plugins/schema/resolvers/preview → graphql/schema/resolvers/manage}/resolveList.js +2 -7
  204. package/graphql/schema/resolvers/manage/resolveList.js.map +1 -0
  205. package/graphql/schema/resolvers/manage/resolvePublish.d.ts +7 -0
  206. package/{content/plugins → graphql}/schema/resolvers/manage/resolvePublish.js +0 -3
  207. package/graphql/schema/resolvers/manage/resolvePublish.js.map +1 -0
  208. package/graphql/schema/resolvers/manage/resolveRepublish.d.ts +7 -0
  209. package/{content/plugins/schema/resolvers/manage/resolveGet.js → graphql/schema/resolvers/manage/resolveRepublish.js} +4 -7
  210. package/graphql/schema/resolvers/manage/resolveRepublish.js.map +1 -0
  211. package/graphql/schema/resolvers/manage/resolveUnpublish.d.ts +7 -0
  212. package/{content/plugins → graphql}/schema/resolvers/manage/resolveUnpublish.js +0 -3
  213. package/graphql/schema/resolvers/manage/resolveUnpublish.js.map +1 -0
  214. package/graphql/schema/resolvers/manage/resolveUpdate.d.ts +8 -0
  215. package/{content/plugins → graphql}/schema/resolvers/manage/resolveUpdate.js +2 -7
  216. package/graphql/schema/resolvers/manage/resolveUpdate.js.map +1 -0
  217. package/graphql/schema/resolvers/preview/resolveGet.d.ts +4 -0
  218. package/graphql/schema/resolvers/preview/resolveGet.js +26 -0
  219. package/graphql/schema/resolvers/preview/resolveGet.js.map +1 -0
  220. package/graphql/schema/resolvers/preview/resolveList.d.ts +4 -0
  221. package/{content/plugins/schema/resolvers/manage → graphql/schema/resolvers/preview}/resolveList.js +2 -7
  222. package/graphql/schema/resolvers/preview/resolveList.js.map +1 -0
  223. package/graphql/schema/resolvers/read/resolveGet.d.ts +4 -0
  224. package/graphql/schema/resolvers/read/resolveGet.js +26 -0
  225. package/graphql/schema/resolvers/read/resolveGet.js.map +1 -0
  226. package/graphql/schema/resolvers/read/resolveList.d.ts +4 -0
  227. package/{content/plugins → graphql}/schema/resolvers/read/resolveList.js +2 -7
  228. package/graphql/schema/resolvers/read/resolveList.js.map +1 -0
  229. package/graphql/schema/schemaPlugins.d.ts +8 -0
  230. package/graphql/schema/schemaPlugins.js +109 -0
  231. package/graphql/schema/schemaPlugins.js.map +1 -0
  232. package/graphql/system.d.ts +6 -0
  233. package/{plugins/graphql → graphql}/system.js +39 -24
  234. package/graphql/system.js.map +1 -0
  235. package/graphqlFields/boolean.d.ts +2 -0
  236. package/graphqlFields/boolean.js +57 -0
  237. package/graphqlFields/boolean.js.map +1 -0
  238. package/graphqlFields/datetime.d.ts +2 -0
  239. package/graphqlFields/datetime.js +78 -0
  240. package/graphqlFields/datetime.js.map +1 -0
  241. package/graphqlFields/dynamicZone/dynamicZoneField.d.ts +2 -0
  242. package/graphqlFields/dynamicZone/dynamicZoneField.js +216 -0
  243. package/graphqlFields/dynamicZone/dynamicZoneField.js.map +1 -0
  244. package/graphqlFields/dynamicZone/dynamicZoneStorage.d.ts +3 -0
  245. package/graphqlFields/dynamicZone/dynamicZoneStorage.js +63 -0
  246. package/graphqlFields/dynamicZone/dynamicZoneStorage.js.map +1 -0
  247. package/graphqlFields/dynamicZone/index.d.ts +2 -0
  248. package/graphqlFields/dynamicZone/index.js +19 -0
  249. package/graphqlFields/dynamicZone/index.js.map +1 -0
  250. package/graphqlFields/file.d.ts +2 -0
  251. package/graphqlFields/file.js +42 -0
  252. package/graphqlFields/file.js.map +1 -0
  253. package/graphqlFields/helpers.d.ts +6 -0
  254. package/graphqlFields/helpers.js +39 -0
  255. package/graphqlFields/helpers.js.map +1 -0
  256. package/graphqlFields/index.d.ts +2 -0
  257. package/graphqlFields/index.js +18 -0
  258. package/graphqlFields/index.js.map +1 -0
  259. package/graphqlFields/longText.d.ts +2 -0
  260. package/graphqlFields/longText.js +53 -0
  261. package/graphqlFields/longText.js.map +1 -0
  262. package/graphqlFields/number.d.ts +2 -0
  263. package/graphqlFields/number.js +67 -0
  264. package/graphqlFields/number.js.map +1 -0
  265. package/graphqlFields/object.d.ts +2 -0
  266. package/graphqlFields/object.js +245 -0
  267. package/graphqlFields/object.js.map +1 -0
  268. package/graphqlFields/ref.d.ts +2 -0
  269. package/graphqlFields/ref.js +255 -0
  270. package/graphqlFields/ref.js.map +1 -0
  271. package/graphqlFields/richText.d.ts +2 -0
  272. package/graphqlFields/richText.js +47 -0
  273. package/graphqlFields/richText.js.map +1 -0
  274. package/graphqlFields/text.d.ts +2 -0
  275. package/graphqlFields/text.js +62 -0
  276. package/graphqlFields/text.js.map +1 -0
  277. package/index.d.ts +10 -12
  278. package/index.js +74 -55
  279. package/index.js.map +1 -0
  280. package/modelManager/DefaultCmsModelManager.d.ts +14 -0
  281. package/{content/plugins/modelManager → modelManager}/DefaultCmsModelManager.js +10 -24
  282. package/modelManager/DefaultCmsModelManager.js.map +1 -0
  283. package/modelManager/index.d.ts +2 -0
  284. package/{content/plugins/modelManager → modelManager}/index.js +3 -7
  285. package/modelManager/index.js.map +1 -0
  286. package/package.json +37 -38
  287. package/parameters/context.d.ts +2 -0
  288. package/parameters/context.js +18 -0
  289. package/parameters/context.js.map +1 -0
  290. package/parameters/header.d.ts +2 -0
  291. package/parameters/header.js +44 -0
  292. package/parameters/header.js.map +1 -0
  293. package/parameters/index.d.ts +4 -0
  294. package/parameters/index.js +49 -0
  295. package/parameters/index.js.map +1 -0
  296. package/parameters/manual.d.ts +6 -0
  297. package/parameters/manual.js +37 -0
  298. package/parameters/manual.js.map +1 -0
  299. package/parameters/path.d.ts +2 -0
  300. package/parameters/path.js +40 -0
  301. package/parameters/path.js.map +1 -0
  302. package/plugins/CmsGraphQLSchemaPlugin.d.ts +5 -0
  303. package/plugins/CmsGraphQLSchemaPlugin.js +12 -0
  304. package/plugins/CmsGraphQLSchemaPlugin.js.map +1 -0
  305. package/plugins/CmsGraphQLSchemaSorterPlugin.d.ts +20 -0
  306. package/plugins/CmsGraphQLSchemaSorterPlugin.js +28 -0
  307. package/plugins/CmsGraphQLSchemaSorterPlugin.js.map +1 -0
  308. package/plugins/CmsGroupPlugin.d.ts +13 -0
  309. package/{content/plugins → plugins}/CmsGroupPlugin.js +7 -9
  310. package/plugins/CmsGroupPlugin.js.map +1 -0
  311. package/plugins/CmsModelFieldConverterPlugin.d.ts +14 -0
  312. package/plugins/CmsModelFieldConverterPlugin.js +12 -0
  313. package/plugins/CmsModelFieldConverterPlugin.js.map +1 -0
  314. package/plugins/CmsModelPlugin.d.ts +55 -0
  315. package/plugins/CmsModelPlugin.js +169 -0
  316. package/plugins/CmsModelPlugin.js.map +1 -0
  317. package/plugins/CmsParametersPlugin.d.ts +20 -0
  318. package/plugins/CmsParametersPlugin.js +21 -0
  319. package/plugins/CmsParametersPlugin.js.map +1 -0
  320. package/plugins/StorageTransformPlugin.d.ts +31 -0
  321. package/{content/plugins/storage → plugins}/StorageTransformPlugin.js +2 -10
  322. package/plugins/StorageTransformPlugin.js.map +1 -0
  323. package/plugins/index.d.ts +7 -0
  324. package/plugins/index.js +82 -0
  325. package/plugins/index.js.map +1 -0
  326. package/storage/default.d.ts +2 -0
  327. package/storage/default.js +24 -0
  328. package/storage/default.js.map +1 -0
  329. package/storage/object.d.ts +2 -0
  330. package/storage/object.js +108 -0
  331. package/storage/object.js.map +1 -0
  332. package/types.d.ts +951 -405
  333. package/types.js +105 -62
  334. package/types.js.map +1 -0
  335. package/upgrades/5.33.0/index.d.ts +3 -0
  336. package/upgrades/5.33.0/index.js +182 -0
  337. package/upgrades/5.33.0/index.js.map +1 -0
  338. package/upgrades/index.d.ts +1 -0
  339. package/upgrades/index.js +12 -0
  340. package/upgrades/index.js.map +1 -0
  341. package/utils/access.d.ts +8 -0
  342. package/utils/access.js +76 -0
  343. package/utils/access.js.map +1 -0
  344. package/utils/converters/Converter.d.ts +27 -0
  345. package/utils/converters/Converter.js +58 -0
  346. package/utils/converters/Converter.js.map +1 -0
  347. package/utils/converters/ConverterCollection.d.ts +31 -0
  348. package/utils/converters/ConverterCollection.js +119 -0
  349. package/utils/converters/ConverterCollection.js.map +1 -0
  350. package/utils/converters/valueKeyStorageConverter.d.ts +18 -0
  351. package/utils/converters/valueKeyStorageConverter.js +123 -0
  352. package/utils/converters/valueKeyStorageConverter.js.map +1 -0
  353. package/utils/createTypeFromFields.d.ts +16 -0
  354. package/utils/createTypeFromFields.js +67 -0
  355. package/utils/createTypeFromFields.js.map +1 -0
  356. package/{content/plugins/utils → utils}/createTypeName.d.ts +3 -3
  357. package/{content/plugins/utils → utils}/createTypeName.js +3 -10
  358. package/utils/createTypeName.js.map +1 -0
  359. package/{content/plugins/utils → utils}/entryStorage.d.ts +3 -3
  360. package/{content/plugins/utils → utils}/entryStorage.js +26 -47
  361. package/utils/entryStorage.js.map +1 -0
  362. package/utils/filterAsync.d.ts +1 -0
  363. package/utils/filterAsync.js +18 -0
  364. package/utils/filterAsync.js.map +1 -0
  365. package/utils/getBaseFieldType.d.ts +4 -0
  366. package/utils/getBaseFieldType.js +10 -0
  367. package/utils/getBaseFieldType.js.map +1 -0
  368. package/utils/getEntryDescription.d.ts +2 -0
  369. package/utils/getEntryDescription.js +17 -0
  370. package/utils/getEntryDescription.js.map +1 -0
  371. package/utils/getEntryImage.d.ts +2 -0
  372. package/utils/getEntryImage.js +17 -0
  373. package/utils/getEntryImage.js.map +1 -0
  374. package/utils/getEntryTitle.d.ts +2 -0
  375. package/{content/plugins/utils → utils}/getEntryTitle.js +7 -15
  376. package/utils/getEntryTitle.js.map +1 -0
  377. package/utils/getSchemaFromFieldPlugins.d.ts +9 -0
  378. package/utils/getSchemaFromFieldPlugins.js +39 -0
  379. package/utils/getSchemaFromFieldPlugins.js.map +1 -0
  380. package/utils/ownership.d.ts +8 -0
  381. package/utils/ownership.js +33 -0
  382. package/utils/ownership.js.map +1 -0
  383. package/utils/permissions.d.ts +7 -0
  384. package/utils/permissions.js +91 -0
  385. package/utils/permissions.js.map +1 -0
  386. package/utils/pluralizedTypeName.d.ts +1 -0
  387. package/{content/plugins/utils → utils}/pluralizedTypeName.js +1 -1
  388. package/utils/pluralizedTypeName.js.map +1 -0
  389. package/utils/removeNullValues.d.ts +1 -0
  390. package/utils/removeNullValues.js +17 -0
  391. package/utils/removeNullValues.js.map +1 -0
  392. package/utils/removeUndefinedValues.d.ts +1 -0
  393. package/utils/removeUndefinedValues.js +17 -0
  394. package/utils/removeUndefinedValues.js.map +1 -0
  395. package/utils/renderFields.d.ts +16 -0
  396. package/{content/plugins/utils → utils}/renderFields.js +14 -12
  397. package/utils/renderFields.js.map +1 -0
  398. package/utils/renderGetFilterFields.d.ts +10 -0
  399. package/utils/renderGetFilterFields.js +48 -0
  400. package/utils/renderGetFilterFields.js.map +1 -0
  401. package/utils/renderInputFields.d.ts +15 -0
  402. package/{content/plugins/utils → utils}/renderInputFields.js +7 -10
  403. package/utils/renderInputFields.js.map +1 -0
  404. package/utils/renderListFilterFields.d.ts +11 -0
  405. package/{content/plugins/utils → utils}/renderListFilterFields.js +36 -22
  406. package/utils/renderListFilterFields.js.map +1 -0
  407. package/utils/renderSortEnum.d.ts +12 -0
  408. package/utils/renderSortEnum.js +42 -0
  409. package/utils/renderSortEnum.js.map +1 -0
  410. package/utils/toSlug.d.ts +1 -0
  411. package/utils/toSlug.js +16 -0
  412. package/utils/toSlug.js.map +1 -0
  413. package/validators/dateGte.d.ts +2 -0
  414. package/{content/plugins/validators → validators}/dateGte.js +4 -11
  415. package/validators/dateGte.js.map +1 -0
  416. package/validators/dateLte.d.ts +2 -0
  417. package/{content/plugins/validators → validators}/dateLte.js +4 -11
  418. package/validators/dateLte.js.map +1 -0
  419. package/validators/dynamicZone.d.ts +2 -0
  420. package/validators/dynamicZone.js +20 -0
  421. package/validators/dynamicZone.js.map +1 -0
  422. package/validators/gte.d.ts +2 -0
  423. package/validators/gte.js +28 -0
  424. package/validators/gte.js.map +1 -0
  425. package/validators/in.d.ts +2 -0
  426. package/validators/in.js +28 -0
  427. package/validators/in.js.map +1 -0
  428. package/validators/index.d.ts +1 -0
  429. package/validators/index.js +22 -0
  430. package/validators/index.js.map +1 -0
  431. package/validators/lte.d.ts +2 -0
  432. package/validators/lte.js +28 -0
  433. package/validators/lte.js.map +1 -0
  434. package/validators/maxLength.d.ts +2 -0
  435. package/validators/maxLength.js +28 -0
  436. package/validators/maxLength.js.map +1 -0
  437. package/validators/minLength.d.ts +2 -0
  438. package/validators/minLength.js +28 -0
  439. package/validators/minLength.js.map +1 -0
  440. package/validators/pattern.d.ts +2 -0
  441. package/validators/pattern.js +41 -0
  442. package/validators/pattern.js.map +1 -0
  443. package/validators/patternPlugins/email.d.ts +2 -0
  444. package/validators/patternPlugins/email.js +18 -0
  445. package/validators/patternPlugins/email.js.map +1 -0
  446. package/validators/patternPlugins/index.d.ts +2 -0
  447. package/validators/patternPlugins/index.js +16 -0
  448. package/validators/patternPlugins/index.js.map +1 -0
  449. package/validators/patternPlugins/lowerCase.d.ts +2 -0
  450. package/validators/patternPlugins/lowerCase.js +18 -0
  451. package/validators/patternPlugins/lowerCase.js.map +1 -0
  452. package/validators/patternPlugins/lowerCaseSpace.d.ts +2 -0
  453. package/validators/patternPlugins/lowerCaseSpace.js +18 -0
  454. package/validators/patternPlugins/lowerCaseSpace.js.map +1 -0
  455. package/validators/patternPlugins/upperCase.d.ts +2 -0
  456. package/validators/patternPlugins/upperCase.js +18 -0
  457. package/validators/patternPlugins/upperCase.js.map +1 -0
  458. package/validators/patternPlugins/upperCaseSpace.d.ts +2 -0
  459. package/validators/patternPlugins/upperCaseSpace.js +18 -0
  460. package/validators/patternPlugins/upperCaseSpace.js.map +1 -0
  461. package/validators/patternPlugins/url.d.ts +2 -0
  462. package/validators/patternPlugins/url.js +18 -0
  463. package/validators/patternPlugins/url.js.map +1 -0
  464. package/validators/required.d.ts +2 -0
  465. package/validators/required.js +22 -0
  466. package/validators/required.js.map +1 -0
  467. package/validators/timeGte.d.ts +2 -0
  468. package/{content/plugins/validators → validators}/timeGte.js +5 -11
  469. package/validators/timeGte.js.map +1 -0
  470. package/validators/timeLte.d.ts +2 -0
  471. package/{content/plugins/validators → validators}/timeLte.js +5 -11
  472. package/validators/timeLte.js.map +1 -0
  473. package/validators/unique.d.ts +6 -0
  474. package/validators/unique.js +56 -0
  475. package/validators/unique.js.map +1 -0
  476. package/content/contextSetup.d.ts +0 -4
  477. package/content/contextSetup.js +0 -65
  478. package/content/graphQLHandlerFactory.d.ts +0 -5
  479. package/content/graphQLHandlerFactory.js +0 -173
  480. package/content/plugins/CmsGroupPlugin.d.ts +0 -11
  481. package/content/plugins/CmsModelPlugin.d.ts +0 -11
  482. package/content/plugins/CmsModelPlugin.js +0 -24
  483. package/content/plugins/buildSchemaPlugins.d.ts +0 -7
  484. package/content/plugins/buildSchemaPlugins.js +0 -29
  485. package/content/plugins/crud/contentEntry/afterDelete.d.ts +0 -7
  486. package/content/plugins/crud/contentEntry/beforeCreate.d.ts +0 -7
  487. package/content/plugins/crud/contentEntry/beforeUpdate.d.ts +0 -7
  488. package/content/plugins/crud/contentEntry/entryDataValidation.d.ts +0 -4
  489. package/content/plugins/crud/contentEntry.crud.js +0 -931
  490. package/content/plugins/crud/contentModel/afterCreate.d.ts +0 -7
  491. package/content/plugins/crud/contentModel/afterCreate.js +0 -18
  492. package/content/plugins/crud/contentModel/afterDelete.d.ts +0 -7
  493. package/content/plugins/crud/contentModel/afterDelete.js +0 -18
  494. package/content/plugins/crud/contentModel/afterUpdate.d.ts +0 -7
  495. package/content/plugins/crud/contentModel/afterUpdate.js +0 -18
  496. package/content/plugins/crud/contentModel/beforeCreate.d.ts +0 -9
  497. package/content/plugins/crud/contentModel/beforeDelete.d.ts +0 -9
  498. package/content/plugins/crud/contentModel/beforeUpdate.d.ts +0 -9
  499. package/content/plugins/crud/contentModel/beforeUpdate.js +0 -128
  500. package/content/plugins/crud/contentModel/contentModelManagerFactory.d.ts +0 -2
  501. package/content/plugins/crud/contentModel/createFieldModels.d.ts +0 -2
  502. package/content/plugins/crud/contentModel/idValidation.d.ts +0 -2
  503. package/content/plugins/crud/contentModel/validateLayout.d.ts +0 -2
  504. package/content/plugins/crud/contentModel.crud.js +0 -425
  505. package/content/plugins/crud/contentModelGroup/beforeCreate.d.ts +0 -9
  506. package/content/plugins/crud/contentModelGroup/beforeDelete.d.ts +0 -9
  507. package/content/plugins/crud/contentModelGroup/beforeUpdate.d.ts +0 -8
  508. package/content/plugins/crud/contentModelGroup.crud.js +0 -351
  509. package/content/plugins/crud/index.d.ts +0 -6
  510. package/content/plugins/crud/index.js +0 -100
  511. package/content/plugins/graphqlFields/boolean.d.ts +0 -3
  512. package/content/plugins/graphqlFields/boolean.js +0 -69
  513. package/content/plugins/graphqlFields/datetime.d.ts +0 -3
  514. package/content/plugins/graphqlFields/datetime.js +0 -83
  515. package/content/plugins/graphqlFields/file.d.ts +0 -3
  516. package/content/plugins/graphqlFields/file.js +0 -49
  517. package/content/plugins/graphqlFields/index.d.ts +0 -2
  518. package/content/plugins/graphqlFields/index.js +0 -30
  519. package/content/plugins/graphqlFields/longText.d.ts +0 -3
  520. package/content/plugins/graphqlFields/longText.js +0 -62
  521. package/content/plugins/graphqlFields/number.d.ts +0 -3
  522. package/content/plugins/graphqlFields/number.js +0 -75
  523. package/content/plugins/graphqlFields/object.d.ts +0 -3
  524. package/content/plugins/graphqlFields/object.js +0 -180
  525. package/content/plugins/graphqlFields/ref.d.ts +0 -3
  526. package/content/plugins/graphqlFields/ref.js +0 -205
  527. package/content/plugins/graphqlFields/richText.d.ts +0 -3
  528. package/content/plugins/graphqlFields/richText.js +0 -55
  529. package/content/plugins/graphqlFields/text.d.ts +0 -3
  530. package/content/plugins/graphqlFields/text.js +0 -72
  531. package/content/plugins/internalSecurity/InternalAuthenticationPlugin.d.ts +0 -8
  532. package/content/plugins/internalSecurity/InternalAuthenticationPlugin.js +0 -54
  533. package/content/plugins/internalSecurity/InternalAuthorizationPlugin.d.ts +0 -7
  534. package/content/plugins/internalSecurity/InternalAuthorizationPlugin.js +0 -35
  535. package/content/plugins/modelManager/DefaultCmsModelManager.d.ts +0 -15
  536. package/content/plugins/modelManager/index.d.ts +0 -3
  537. package/content/plugins/schema/baseSchema.d.ts +0 -4
  538. package/content/plugins/schema/baseSchema.js +0 -98
  539. package/content/plugins/schema/contentEntries.d.ts +0 -4
  540. package/content/plugins/schema/contentEntries.js +0 -166
  541. package/content/plugins/schema/contentModelGroups.d.ts +0 -4
  542. package/content/plugins/schema/contentModels.d.ts +0 -4
  543. package/content/plugins/schema/createFieldResolvers.d.ts +0 -19
  544. package/content/plugins/schema/createFieldResolvers.js +0 -92
  545. package/content/plugins/schema/createManageResolvers.d.ts +0 -11
  546. package/content/plugins/schema/createManageResolvers.js +0 -135
  547. package/content/plugins/schema/createManageSDL.d.ts +0 -9
  548. package/content/plugins/schema/createManageSDL.js +0 -153
  549. package/content/plugins/schema/createPreviewResolvers.d.ts +0 -10
  550. package/content/plugins/schema/createPreviewResolvers.js +0 -55
  551. package/content/plugins/schema/createReadResolvers.d.ts +0 -10
  552. package/content/plugins/schema/createReadResolvers.js +0 -55
  553. package/content/plugins/schema/createReadSDL.d.ts +0 -9
  554. package/content/plugins/schema/createReadSDL.js +0 -96
  555. package/content/plugins/schema/resolvers/commonFieldResolvers.d.ts +0 -6
  556. package/content/plugins/schema/resolvers/manage/resolveCreate.d.ts +0 -6
  557. package/content/plugins/schema/resolvers/manage/resolveCreateFrom.d.ts +0 -7
  558. package/content/plugins/schema/resolvers/manage/resolveDelete.d.ts +0 -2
  559. package/content/plugins/schema/resolvers/manage/resolveGet.d.ts +0 -2
  560. package/content/plugins/schema/resolvers/manage/resolveGetByIds.d.ts +0 -2
  561. package/content/plugins/schema/resolvers/manage/resolveGetRevisions.d.ts +0 -2
  562. package/content/plugins/schema/resolvers/manage/resolveList.d.ts +0 -2
  563. package/content/plugins/schema/resolvers/manage/resolvePublish.d.ts +0 -2
  564. package/content/plugins/schema/resolvers/manage/resolveRequestChanges.d.ts +0 -6
  565. package/content/plugins/schema/resolvers/manage/resolveRequestChanges.js +0 -23
  566. package/content/plugins/schema/resolvers/manage/resolveRequestReview.d.ts +0 -6
  567. package/content/plugins/schema/resolvers/manage/resolveRequestReview.js +0 -23
  568. package/content/plugins/schema/resolvers/manage/resolveUnpublish.d.ts +0 -2
  569. package/content/plugins/schema/resolvers/manage/resolveUpdate.d.ts +0 -7
  570. package/content/plugins/schema/resolvers/preview/resolveGet.d.ts +0 -2
  571. package/content/plugins/schema/resolvers/preview/resolveGet.js +0 -38
  572. package/content/plugins/schema/resolvers/preview/resolveList.d.ts +0 -2
  573. package/content/plugins/schema/resolvers/read/resolveGet.d.ts +0 -2
  574. package/content/plugins/schema/resolvers/read/resolveGet.js +0 -38
  575. package/content/plugins/schema/resolvers/read/resolveList.d.ts +0 -2
  576. package/content/plugins/schema/schemaPlugins.d.ts +0 -3
  577. package/content/plugins/schema/schemaPlugins.js +0 -92
  578. package/content/plugins/storage/StorageTransformPlugin.d.ts +0 -30
  579. package/content/plugins/storage/default.d.ts +0 -3
  580. package/content/plugins/storage/default.js +0 -28
  581. package/content/plugins/storage/object.d.ts +0 -3
  582. package/content/plugins/storage/object.js +0 -119
  583. package/content/plugins/utils/getEntryTitle.d.ts +0 -2
  584. package/content/plugins/utils/getSchemaFromFieldPlugins.d.ts +0 -11
  585. package/content/plugins/utils/getSchemaFromFieldPlugins.js +0 -30
  586. package/content/plugins/utils/pluralizedTypeName.d.ts +0 -1
  587. package/content/plugins/utils/renderFields.d.ts +0 -16
  588. package/content/plugins/utils/renderGetFilterFields.d.ts +0 -9
  589. package/content/plugins/utils/renderGetFilterFields.js +0 -41
  590. package/content/plugins/utils/renderInputFields.d.ts +0 -14
  591. package/content/plugins/utils/renderListFilterFields.d.ts +0 -10
  592. package/content/plugins/utils/renderSortEnum.d.ts +0 -9
  593. package/content/plugins/utils/renderSortEnum.js +0 -32
  594. package/content/plugins/validators/dateGte.d.ts +0 -3
  595. package/content/plugins/validators/dateLte.d.ts +0 -3
  596. package/content/plugins/validators/gte.d.ts +0 -3
  597. package/content/plugins/validators/gte.js +0 -32
  598. package/content/plugins/validators/in.d.ts +0 -3
  599. package/content/plugins/validators/in.js +0 -32
  600. package/content/plugins/validators/index.d.ts +0 -2
  601. package/content/plugins/validators/index.js +0 -36
  602. package/content/plugins/validators/lte.d.ts +0 -3
  603. package/content/plugins/validators/lte.js +0 -32
  604. package/content/plugins/validators/maxLength.d.ts +0 -3
  605. package/content/plugins/validators/maxLength.js +0 -32
  606. package/content/plugins/validators/minLength.d.ts +0 -3
  607. package/content/plugins/validators/minLength.js +0 -32
  608. package/content/plugins/validators/pattern.d.ts +0 -3
  609. package/content/plugins/validators/pattern.js +0 -47
  610. package/content/plugins/validators/patternPlugins/email.d.ts +0 -3
  611. package/content/plugins/validators/patternPlugins/email.js +0 -17
  612. package/content/plugins/validators/patternPlugins/index.d.ts +0 -2
  613. package/content/plugins/validators/patternPlugins/index.js +0 -19
  614. package/content/plugins/validators/patternPlugins/lowerCase.d.ts +0 -3
  615. package/content/plugins/validators/patternPlugins/lowerCase.js +0 -17
  616. package/content/plugins/validators/patternPlugins/upperCase.d.ts +0 -3
  617. package/content/plugins/validators/patternPlugins/upperCase.js +0 -17
  618. package/content/plugins/validators/patternPlugins/url.d.ts +0 -3
  619. package/content/plugins/validators/patternPlugins/url.js +0 -17
  620. package/content/plugins/validators/required.d.ts +0 -3
  621. package/content/plugins/validators/required.js +0 -25
  622. package/content/plugins/validators/timeGte.d.ts +0 -3
  623. package/content/plugins/validators/timeLte.d.ts +0 -3
  624. package/migrateCMSPermissions.d.ts +0 -17
  625. package/migrateCMSPermissions.js +0 -193
  626. package/plugins/context.d.ts +0 -4
  627. package/plugins/context.js +0 -34
  628. package/plugins/crud/index.d.ts +0 -6
  629. package/plugins/crud/index.js +0 -100
  630. package/plugins/crud/settings.crud.js +0 -93
  631. package/plugins/crud/system.crud.js +0 -182
  632. package/plugins/graphql/system.d.ts +0 -17
  633. package/plugins/graphql.d.ts +0 -2
  634. package/plugins/graphql.js +0 -79
  635. package/plugins/upgrades/index.d.ts +0 -2
  636. package/plugins/upgrades/index.js +0 -14
  637. package/plugins/upgrades/v5.5.0/helpers.d.ts +0 -6
  638. package/plugins/upgrades/v5.5.0/helpers.js +0 -10
  639. package/plugins/upgrades/v5.5.0/index.d.ts +0 -4
  640. package/plugins/upgrades/v5.5.0/index.js +0 -129
  641. package/transformers.d.ts +0 -2
  642. package/transformers.js +0 -25
  643. package/utils.d.ts +0 -25
  644. package/utils.js +0 -251
@@ -1,41 +1,31 @@
1
1
  "use strict";
2
2
 
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
3
  Object.defineProperty(exports, "__esModule", {
6
4
  value: true
7
5
  });
8
- exports.UpdateContentModelModel = exports.CreateContentModelModel = exports.ContentModelFieldModel = void 0;
6
+ exports.UpdateContentModelModel = exports.CreateContentModelModelFrom = exports.CreateContentModelModel = exports.ContentModelFieldModel = void 0;
9
7
 
10
8
  var _validation = require("@webiny/validation");
11
9
 
12
- var _flow = _interopRequireDefault(require("lodash/flow"));
13
-
14
10
  var _commodoFieldsObject = require("commodo-fields-object");
15
11
 
16
12
  var _fields = require("@commodo/fields");
17
13
 
18
- var _idValidation = _interopRequireDefault(require("./idValidation"));
14
+ var _fieldIdValidation = require("./fieldIdValidation");
15
+
16
+ /**
17
+ * Package commodo-fields-object does not have types
18
+ */
19
+ // @ts-ignore
19
20
 
21
+ /**
22
+ * Package commodo-fields does not have object.
23
+ */
24
+ // @ts-ignore
20
25
  const requiredShortString = _validation.validation.create("required,maxLength:255");
21
26
 
22
27
  const shortString = _validation.validation.create("maxLength:255");
23
28
 
24
- const CreateContentModelModel = (0, _fields.withFields)({
25
- name: (0, _fields.string)({
26
- validation: requiredShortString
27
- }),
28
- modelId: (0, _fields.string)({
29
- validation: shortString
30
- }),
31
- description: (0, _fields.string)({
32
- validation: shortString
33
- }),
34
- group: (0, _fields.string)({
35
- validation: requiredShortString
36
- })
37
- })();
38
- exports.CreateContentModelModel = CreateContentModelModel;
39
29
  const RendererModel = (0, _fields.withFields)({
40
30
  name: (0, _fields.string)({
41
31
  validation: requiredShortString
@@ -45,9 +35,9 @@ const ContentModelFieldModel = (0, _fields.withFields)({
45
35
  id: (0, _fields.string)({
46
36
  validation: requiredShortString
47
37
  }),
48
- fieldId: (0, _flow.default)((0, _fields.onSet)(value => value && value.trim()), (0, _fields.setOnce)())((0, _fields.string)({
49
- validation: _idValidation.default
50
- })),
38
+ fieldId: (0, _fields.string)({
39
+ validation: _fieldIdValidation.validateFieldId
40
+ }),
51
41
  label: (0, _fields.string)({
52
42
  validation: requiredShortString
53
43
  }),
@@ -60,6 +50,10 @@ const ContentModelFieldModel = (0, _fields.withFields)({
60
50
  type: (0, _fields.setOnce)()((0, _fields.string)({
61
51
  validation: requiredShortString
62
52
  })),
53
+ tags: (0, _commodoFieldsObject.object)({
54
+ value: [],
55
+ required: false
56
+ }),
63
57
  multipleValues: (0, _fields.boolean)({
64
58
  value: false
65
59
  }),
@@ -72,7 +66,8 @@ const ContentModelFieldModel = (0, _fields.withFields)({
72
66
  list: true,
73
67
  instanceOf: (0, _fields.withFields)({
74
68
  label: (0, _fields.string)(),
75
- value: (0, _fields.string)()
69
+ value: (0, _fields.string)(),
70
+ selected: (0, _fields.boolean)()
76
71
  })()
77
72
  })
78
73
  })()
@@ -114,8 +109,60 @@ const ContentModelFieldModel = (0, _fields.withFields)({
114
109
  settings: (0, _commodoFieldsObject.object)({
115
110
  value: {}
116
111
  })
112
+ /**
113
+ * By the default, field is not deleted.
114
+ */
115
+ // isDeleted: boolean({ value: false })
116
+
117
117
  })();
118
118
  exports.ContentModelFieldModel = ContentModelFieldModel;
119
+ const CreateContentModelModel = (0, _fields.withFields)({
120
+ name: (0, _fields.string)({
121
+ validation: requiredShortString
122
+ }),
123
+ modelId: (0, _fields.string)({
124
+ validation: shortString
125
+ }),
126
+ description: (0, _fields.string)({
127
+ validation: shortString
128
+ }),
129
+ group: (0, _fields.string)({
130
+ validation: requiredShortString
131
+ }),
132
+ fields: (0, _fields.fields)({
133
+ instanceOf: ContentModelFieldModel,
134
+ value: [],
135
+ list: true,
136
+ required: true
137
+ }),
138
+ layout: (0, _commodoFieldsObject.object)({
139
+ value: [],
140
+ required: true
141
+ }),
142
+ tags: (0, _commodoFieldsObject.object)({
143
+ value: [],
144
+ required: false
145
+ })
146
+ })();
147
+ exports.CreateContentModelModel = CreateContentModelModel;
148
+ const CreateContentModelModelFrom = (0, _fields.withFields)({
149
+ name: (0, _fields.string)({
150
+ validation: requiredShortString
151
+ }),
152
+ modelId: (0, _fields.string)({
153
+ validation: shortString
154
+ }),
155
+ description: (0, _fields.string)({
156
+ validation: shortString
157
+ }),
158
+ group: (0, _fields.string)({
159
+ validation: requiredShortString
160
+ }),
161
+ locale: (0, _fields.string)({
162
+ validation: shortString
163
+ })
164
+ })();
165
+ exports.CreateContentModelModelFrom = CreateContentModelModelFrom;
119
166
  const UpdateContentModelModel = (0, _fields.withFields)({
120
167
  name: (0, _fields.string)({
121
168
  validation: shortString
@@ -136,6 +183,10 @@ const UpdateContentModelModel = (0, _fields.withFields)({
136
183
  layout: (0, _commodoFieldsObject.object)({
137
184
  value: [],
138
185
  required: true
186
+ }),
187
+ tags: (0, _commodoFieldsObject.object)({
188
+ value: [],
189
+ required: false
139
190
  })
140
191
  })();
141
192
  exports.UpdateContentModelModel = UpdateContentModelModel;
@@ -0,0 +1 @@
1
+ {"version":3,"names":["requiredShortString","validation","create","shortString","RendererModel","withFields","name","string","ContentModelFieldModel","id","fieldId","validateFieldId","label","helpText","placeholderText","type","setOnce","tags","object","value","required","multipleValues","boolean","predefinedValues","fields","instanceOf","enabled","values","list","selected","renderer","message","settings","listValidation","CreateContentModelModel","modelId","description","group","layout","CreateContentModelModelFrom","locale","UpdateContentModelModel","titleFieldId"],"sources":["models.ts"],"sourcesContent":["import { validation } from \"@webiny/validation\";\n/**\n * Package commodo-fields-object does not have types\n */\n// @ts-ignore\nimport { object } from \"commodo-fields-object\";\n/**\n * Package commodo-fields does not have object.\n */\n// @ts-ignore\nimport { withFields, string, setOnce, boolean, fields } from \"@commodo/fields\";\nimport { validateFieldId } from \"./fieldIdValidation\";\n\nconst requiredShortString = validation.create(\"required,maxLength:255\");\nconst shortString = validation.create(\"maxLength:255\");\n\nconst RendererModel = withFields({\n name: string({ validation: requiredShortString })\n})();\n\nexport const ContentModelFieldModel = withFields({\n id: string({ validation: requiredShortString }),\n fieldId: string({\n validation: validateFieldId\n }),\n label: string({ validation: requiredShortString }),\n helpText: string({ validation: shortString }),\n placeholderText: string({ validation: shortString }),\n type: setOnce()(string({ validation: requiredShortString })),\n tags: object({ value: [], required: false }),\n multipleValues: boolean({ value: false }),\n predefinedValues: fields({\n value: {},\n instanceOf: withFields({\n enabled: boolean(),\n values: fields({\n value: [],\n list: true,\n instanceOf: withFields({\n label: string(),\n value: string(),\n selected: boolean()\n })()\n })\n })()\n }),\n renderer: fields({ instanceOf: RendererModel, validation: shortString }),\n validation: fields({\n list: true,\n value: [],\n instanceOf: withFields({\n name: string({ validation: requiredShortString }),\n message: string({ validation: shortString }),\n settings: object({ value: {} })\n })()\n }),\n listValidation: fields({\n list: true,\n value: [],\n instanceOf: withFields({\n name: string({ validation: requiredShortString }),\n message: string({ validation: shortString }),\n settings: object({ value: {} })\n })()\n }),\n settings: object({ value: {} })\n /**\n * By the default, field is not deleted.\n */\n // isDeleted: boolean({ value: false })\n})();\n\nexport const CreateContentModelModel = withFields({\n name: string({ validation: requiredShortString }),\n modelId: string({ validation: shortString }),\n description: string({ validation: shortString }),\n group: string({ validation: requiredShortString }),\n fields: fields({ instanceOf: ContentModelFieldModel, value: [], list: true, required: true }),\n layout: object({ value: [], required: true }),\n tags: object({ value: [], required: false })\n})();\n\nexport const CreateContentModelModelFrom = withFields({\n name: string({ validation: requiredShortString }),\n modelId: string({ validation: shortString }),\n description: string({ validation: shortString }),\n group: string({ validation: requiredShortString }),\n locale: string({ validation: shortString })\n})();\n\nexport const UpdateContentModelModel = withFields({\n name: string({ validation: shortString }),\n description: string({ validation: shortString }),\n group: string({ validation: shortString }),\n titleFieldId: string(),\n fields: fields({ instanceOf: ContentModelFieldModel, value: [], list: true, required: true }),\n layout: object({ value: [], required: true }),\n tags: object({ value: [], required: false })\n})();\n"],"mappings":"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"}
@@ -0,0 +1 @@
1
+ export declare const fieldSystemFields: string[];
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.fieldSystemFields = void 0;
7
+ const fieldSystemFields = ["id", "fieldId", "storageId", "label", "helpText", "placeholderText", "type", "multipleValues", "predefinedValues", "renderer", "validation", "listValidation", "settings"];
8
+ exports.fieldSystemFields = fieldSystemFields;
@@ -0,0 +1 @@
1
+ {"version":3,"names":["fieldSystemFields"],"sources":["systemFields.ts"],"sourcesContent":["export const fieldSystemFields: string[] = [\n \"id\",\n \"fieldId\",\n \"storageId\",\n \"label\",\n \"helpText\",\n \"placeholderText\",\n \"type\",\n \"multipleValues\",\n \"predefinedValues\",\n \"renderer\",\n \"validation\",\n \"listValidation\",\n \"settings\"\n];\n"],"mappings":";;;;;;AAAO,MAAMA,iBAA2B,GAAG,CACvC,IADuC,EAEvC,SAFuC,EAGvC,WAHuC,EAIvC,OAJuC,EAKvC,UALuC,EAMvC,iBANuC,EAOvC,MAPuC,EAQvC,gBARuC,EASvC,kBATuC,EAUvC,UAVuC,EAWvC,YAXuC,EAYvC,gBAZuC,EAavC,UAbuC,CAApC"}
@@ -0,0 +1,2 @@
1
+ import { CmsModelField, CmsModel } from "../../types";
2
+ export declare const validateLayout: (layout: CmsModel["layout"], fields?: CmsModelField[]) => void;
@@ -4,35 +4,25 @@ Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
6
  exports.validateLayout = void 0;
7
-
8
- const validateLayout = ({
9
- layout
10
- }, fields) => {
7
+ const validateLayout = (layout, fields = []) => {
11
8
  const flatLayoutIdList = layout.reduce((acc, id) => {
12
9
  return acc.concat(Array.isArray(id) ? id : [id]);
13
10
  }, []);
14
-
15
11
  if (flatLayoutIdList.length !== fields.length) {
16
12
  throw new Error(`There are ${flatLayoutIdList.length} IDs in the layout and ${fields.length} in fields, which cannot be - numbers must be the same.`);
17
13
  }
18
-
19
14
  for (const field of fields) {
20
15
  if (flatLayoutIdList.includes(field.id)) {
21
16
  continue;
22
17
  }
23
-
24
18
  throw new Error(`Field "${field.id}" is not defined in layout.`);
25
19
  }
26
-
27
20
  for (const id of flatLayoutIdList) {
28
21
  const fieldFound = fields.some(f => f.id === id);
29
-
30
22
  if (fieldFound) {
31
23
  continue;
32
24
  }
33
-
34
25
  throw new Error(`Field id "${id}" is in layout but not in fields.`);
35
26
  }
36
27
  };
37
-
38
28
  exports.validateLayout = validateLayout;
@@ -0,0 +1 @@
1
+ {"version":3,"names":["validateLayout","layout","fields","flatLayoutIdList","reduce","acc","id","concat","Array","isArray","length","Error","field","includes","fieldFound","some","f"],"sources":["validateLayout.ts"],"sourcesContent":["import { CmsModelField, CmsModel } from \"~/types\";\n\nexport const validateLayout = (layout: CmsModel[\"layout\"], fields: CmsModelField[] = []): void => {\n const flatLayoutIdList = layout.reduce((acc, id) => {\n return acc.concat(Array.isArray(id) ? id : [id]);\n }, []);\n if (flatLayoutIdList.length !== fields.length) {\n throw new Error(\n `There are ${flatLayoutIdList.length} IDs in the layout and ${fields.length} in fields, which cannot be - numbers must be the same.`\n );\n }\n for (const field of fields) {\n if (flatLayoutIdList.includes(field.id)) {\n continue;\n }\n throw new Error(`Field \"${field.id}\" is not defined in layout.`);\n }\n for (const id of flatLayoutIdList) {\n const fieldFound = fields.some(f => f.id === id);\n if (fieldFound) {\n continue;\n }\n throw new Error(`Field id \"${id}\" is in layout but not in fields.`);\n }\n};\n"],"mappings":";;;;;;AAEO,MAAMA,cAAc,GAAG,CAACC,MAA0B,EAAEC,MAAuB,GAAG,EAAE,KAAW;EAC9F,MAAMC,gBAAgB,GAAGF,MAAM,CAACG,MAAM,CAAC,CAACC,GAAG,EAAEC,EAAE,KAAK;IAChD,OAAOD,GAAG,CAACE,MAAM,CAACC,KAAK,CAACC,OAAO,CAACH,EAAE,CAAC,GAAGA,EAAE,GAAG,CAACA,EAAE,CAAC,CAAC;EACpD,CAAC,EAAE,EAAE,CAAC;EACN,IAAIH,gBAAgB,CAACO,MAAM,KAAKR,MAAM,CAACQ,MAAM,EAAE;IAC3C,MAAM,IAAIC,KAAK,CACV,aAAYR,gBAAgB,CAACO,MAAO,0BAAyBR,MAAM,CAACQ,MAAO,yDAAwD,CACvI;EACL;EACA,KAAK,MAAME,KAAK,IAAIV,MAAM,EAAE;IACxB,IAAIC,gBAAgB,CAACU,QAAQ,CAACD,KAAK,CAACN,EAAE,CAAC,EAAE;MACrC;IACJ;IACA,MAAM,IAAIK,KAAK,CAAE,UAASC,KAAK,CAACN,EAAG,6BAA4B,CAAC;EACpE;EACA,KAAK,MAAMA,EAAE,IAAIH,gBAAgB,EAAE;IAC/B,MAAMW,UAAU,GAAGZ,MAAM,CAACa,IAAI,CAACC,CAAC,IAAIA,CAAC,CAACV,EAAE,KAAKA,EAAE,CAAC;IAChD,IAAIQ,UAAU,EAAE;MACZ;IACJ;IACA,MAAM,IAAIH,KAAK,CAAE,aAAYL,EAAG,mCAAkC,CAAC;EACvE;AACJ,CAAC;AAAC"}
@@ -0,0 +1,9 @@
1
+ import { CmsContext, CmsModel } from "../../types";
2
+ interface ValidateModelParams {
3
+ models: CmsModel[];
4
+ model: CmsModel;
5
+ original?: CmsModel;
6
+ context: CmsContext;
7
+ }
8
+ export declare const validateModel: (params: ValidateModelParams) => Promise<void>;
9
+ export {};
@@ -0,0 +1,27 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.validateModel = void 0;
8
+ var _error = _interopRequireDefault(require("@webiny/error"));
9
+ var _CmsModelPlugin = require("../../plugins/CmsModelPlugin");
10
+ var _validateModelFields = require("./validateModelFields");
11
+ const validateModel = async params => {
12
+ const {
13
+ model,
14
+ context
15
+ } = params;
16
+ const {
17
+ plugins
18
+ } = context;
19
+ const modelPlugin = plugins.byType(_CmsModelPlugin.CmsModelPlugin.type).find(item => item.contentModel.modelId === model.modelId);
20
+ if (modelPlugin) {
21
+ throw new _error.default("Content models defined via plugins cannot be updated.", "CONTENT_MODEL_UPDATE_ERROR", {
22
+ modelId: model.modelId
23
+ });
24
+ }
25
+ await (0, _validateModelFields.validateModelFields)(params);
26
+ };
27
+ exports.validateModel = validateModel;
@@ -0,0 +1 @@
1
+ {"version":3,"names":["validateModel","params","model","context","plugins","modelPlugin","byType","CmsModelPlugin","type","find","item","contentModel","modelId","WebinyError","validateModelFields"],"sources":["validateModel.ts"],"sourcesContent":["import WebinyError from \"@webiny/error\";\nimport { CmsModelPlugin } from \"~/plugins/CmsModelPlugin\";\nimport { CmsContext, CmsModel } from \"~/types\";\nimport { validateModelFields } from \"~/crud/contentModel/validateModelFields\";\n\ninterface ValidateModelParams {\n models: CmsModel[];\n model: CmsModel;\n original?: CmsModel;\n context: CmsContext;\n}\n\nexport const validateModel = async (params: ValidateModelParams): Promise<void> => {\n const { model, context } = params;\n\n const { plugins } = context;\n\n const modelPlugin = plugins\n .byType<CmsModelPlugin>(CmsModelPlugin.type)\n .find(item => item.contentModel.modelId === model.modelId);\n\n if (modelPlugin) {\n throw new WebinyError(\n \"Content models defined via plugins cannot be updated.\",\n \"CONTENT_MODEL_UPDATE_ERROR\",\n {\n modelId: model.modelId\n }\n );\n }\n\n await validateModelFields(params);\n};\n"],"mappings":";;;;;;;AAAA;AACA;AAEA;AASO,MAAMA,aAAa,GAAG,MAAOC,MAA2B,IAAoB;EAC/E,MAAM;IAAEC,KAAK;IAAEC;EAAQ,CAAC,GAAGF,MAAM;EAEjC,MAAM;IAAEG;EAAQ,CAAC,GAAGD,OAAO;EAE3B,MAAME,WAAW,GAAGD,OAAO,CACtBE,MAAM,CAAiBC,8BAAc,CAACC,IAAI,CAAC,CAC3CC,IAAI,CAACC,IAAI,IAAIA,IAAI,CAACC,YAAY,CAACC,OAAO,KAAKV,KAAK,CAACU,OAAO,CAAC;EAE9D,IAAIP,WAAW,EAAE;IACb,MAAM,IAAIQ,cAAW,CACjB,uDAAuD,EACvD,4BAA4B,EAC5B;MACID,OAAO,EAAEV,KAAK,CAACU;IACnB,CAAC,CACJ;EACL;EAEA,MAAM,IAAAE,wCAAmB,EAACb,MAAM,CAAC;AACrC,CAAC;AAAC"}
@@ -0,0 +1,9 @@
1
+ import { CmsModel, CmsContext } from "../../types";
2
+ interface ValidateModelFieldsParams {
3
+ models: CmsModel[];
4
+ model: CmsModel;
5
+ original?: CmsModel;
6
+ context: CmsContext;
7
+ }
8
+ export declare const validateModelFields: (params: ValidateModelFieldsParams) => Promise<void>;
9
+ export {};
@@ -0,0 +1,343 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.validateModelFields = void 0;
8
+ var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
9
+ var _graphqlTag = _interopRequireDefault(require("graphql-tag"));
10
+ var _error = _interopRequireDefault(require("@webiny/error"));
11
+ var _createManageSDL = require("../../graphql/schema/createManageSDL");
12
+ var _createFieldStorageId = require("./createFieldStorageId");
13
+ var _getBaseFieldType = require("../../utils/getBaseFieldType");
14
+ var _titleField = require("./fields/titleField");
15
+ var _descriptionField = require("./fields/descriptionField");
16
+ var _imageField = require("./fields/imageField");
17
+ var _plugins = require("../../plugins");
18
+ var _buildSchemaPlugins = require("../../graphql/buildSchemaPlugins");
19
+ var _createExecutableSchema = require("../../graphql/createExecutableSchema");
20
+ var _handlerGraphql = require("@webiny/handler-graphql");
21
+ var _utils = require("@webiny/utils");
22
+ const extractInvalidField = (model, err) => {
23
+ var _err$source;
24
+ const sdl = ((_err$source = err.source) === null || _err$source === void 0 ? void 0 : _err$source.body) || "";
25
+
26
+ /**
27
+ * Find the invalid type
28
+ */
29
+ const {
30
+ line: lineNumber
31
+ } = err.locations ? err.locations[0] : {
32
+ line: 0
33
+ };
34
+ const sdlLines = sdl.split("\n");
35
+ let sdlLine;
36
+ let gqlType;
37
+ for (let i = lineNumber; i > 0; i--) {
38
+ if (sdlLine && sdlLine.includes("type ")) {
39
+ gqlType = sdlLine.match(/type\s+(.*?)\s+{/);
40
+ break;
41
+ }
42
+ sdlLine = sdlLines[i];
43
+ }
44
+ let invalidField = undefined;
45
+ if (Array.isArray(gqlType)) {
46
+ const fieldRegex = new RegExp(`([^\\s+].*?):\\s+\\[?${gqlType[1]}!?\\]?`);
47
+ const matched = sdl.match(fieldRegex);
48
+ if (matched) {
49
+ invalidField = matched[1];
50
+ }
51
+ }
52
+ let message = `See more details in the browser console.`;
53
+ if (invalidField) {
54
+ message = `Please review the definition of "${invalidField}" field.`;
55
+ }
56
+ return {
57
+ data: {
58
+ modelId: model.modelId,
59
+ sdl,
60
+ invalidField
61
+ },
62
+ code: "INVALID_MODEL_DEFINITION",
63
+ message: [`Model "${model.modelId}" was not saved!`, message].join("\n")
64
+ };
65
+ };
66
+ const createValidateChildFields = plugins => {
67
+ return ({
68
+ fields,
69
+ originalFields
70
+ }) => {
71
+ if (fields.length === 0 && originalFields.length === 0) {
72
+ return;
73
+ }
74
+ validateFields({
75
+ fields,
76
+ originalFields,
77
+ plugins,
78
+ lockedFields: []
79
+ });
80
+ };
81
+ };
82
+ const validateFields = params => {
83
+ const {
84
+ plugins,
85
+ fields,
86
+ originalFields,
87
+ lockedFields
88
+ } = params;
89
+ const idList = [];
90
+ const fieldIdList = [];
91
+ const storageIdList = [];
92
+ for (const field of fields) {
93
+ const baseType = (0, _getBaseFieldType.getBaseFieldType)(field);
94
+ const plugin = plugins.find(plugin => plugin.fieldType === baseType);
95
+ if (!plugin) {
96
+ throw new Error(`Cannot update content model because of the unknown "${baseType}" field.`);
97
+ }
98
+ /**
99
+ * Check the field's id against existing ones.
100
+ * There cannot be two fields with the same id.
101
+ */
102
+ if (idList.includes(field.id)) {
103
+ throw new _error.default(`Cannot update content model because field "${field.storageId || field.fieldId}" has id "${field.id}", which is already used.`);
104
+ }
105
+ idList.push(field.id);
106
+ const originalField = originalFields.find(f => f.id === field.id);
107
+ /**
108
+ * Field MUST have an fieldId defined.
109
+ */
110
+ if (!field.fieldId) {
111
+ throw new _error.default(`Field does not have an "fieldId" defined.`, "MISSING_FIELD_ID", {
112
+ field
113
+ });
114
+ }
115
+ /**
116
+ * If storageId does not match a certain pattern, add that pattern, but only if field is not locked (used) already.
117
+ * This is to avoid errors in the already installed systems.
118
+ *
119
+ * Why are we using the @?
120
+ *
121
+ * It is not part of special characters for the query syntax in the Lucene.
122
+ *
123
+ * Relevant links:
124
+ * https://lucene.apache.org/core/3_4_0/queryparsersyntax.html
125
+ * https://discuss.elastic.co/t/special-characters-in-field-names/10658/3
126
+ * https://discuss.elastic.co/t/illegal-characters-in-elasticsearch-field-names/17196/2
127
+ */
128
+ const isLocked = lockedFields.some(lockedField => {
129
+ return lockedField.fieldId === field.storageId || lockedField.fieldId === field.fieldId;
130
+ });
131
+ if (!field.storageId) {
132
+ /**
133
+ * In case field is locked, we must set the storageId to the fieldId value.
134
+ * This should not happen, because we upgrade all the fields in 5.33.0, but let's have a check just in case of some upgrade miss.
135
+ */
136
+ //
137
+ if (isLocked) {
138
+ field.storageId = field.fieldId;
139
+ }
140
+ /**
141
+ * When having original field, just set the storageId to value from the originalField
142
+ */
143
+ //
144
+ else if (originalField) {
145
+ field.storageId = originalField.storageId;
146
+ }
147
+ /**
148
+ * The last case is when no original field and not locked - so this is a completely new field.
149
+ */
150
+ //
151
+ else {
152
+ field.storageId = (0, _createFieldStorageId.createFieldStorageId)(field);
153
+ }
154
+ }
155
+ /**
156
+ * Check the field's fieldId against existing ones.
157
+ * There cannot be two fields with the same fieldId - outside world identifier.
158
+ */
159
+ if (fieldIdList.includes(field.fieldId)) {
160
+ throw new _error.default(`Cannot update content model because field "${field.storageId}" has fieldId "${field.fieldId}", which is already used.`);
161
+ }
162
+ fieldIdList.push(field.fieldId);
163
+ /**
164
+ * Check the field's storageId against the existing ones.
165
+ * There cannot be two fields with the same storageId.
166
+ */
167
+ if (storageIdList.includes(field.storageId)) {
168
+ throw new _error.default(`Cannot update content model because field "${field.label}" has storageId "${field.storageId}", which is already used.`);
169
+ }
170
+ storageIdList.push(field.storageId);
171
+ /**
172
+ * There might be some plugins which allow child fields.
173
+ * We use this method to validate them as well.
174
+ */
175
+ if (!plugin.validateChildFields) {
176
+ continue;
177
+ }
178
+ const validateChildFields = createValidateChildFields(plugins);
179
+ plugin.validateChildFields({
180
+ field,
181
+ originalField,
182
+ validate: validateChildFields
183
+ });
184
+ }
185
+ };
186
+ const createGraphQLSchema = async params => {
187
+ const {
188
+ context,
189
+ model
190
+ } = params;
191
+ context.security.disableAuthorization();
192
+ const models = (await context.cms.listModels()).filter(model => {
193
+ return !model.isPrivate;
194
+ });
195
+ context.security.enableAuthorization();
196
+ const modelPlugins = await (0, _buildSchemaPlugins.buildSchemaPlugins)({
197
+ context,
198
+ models: models.concat([model])
199
+ });
200
+ const plugins = context.plugins.byType(_handlerGraphql.GraphQLSchemaPlugin.type).reduce((collection, plugin) => {
201
+ const name = plugin.name || `${plugin.type}-${(0, _utils.generateAlphaNumericId)(16)}`;
202
+ collection[name] = plugin;
203
+ return collection;
204
+ }, {});
205
+ for (const plugin of modelPlugins) {
206
+ const name = plugin.name || `${plugin.type}-${(0, _utils.generateAlphaNumericId)(16)}`;
207
+ plugins[name] = plugin;
208
+ }
209
+ return (0, _createExecutableSchema.createExecutableSchema)({
210
+ plugins: Object.values(plugins)
211
+ });
212
+ };
213
+ const extractErrorObject = error => {
214
+ return ["message", "code", "data", "stack"].reduce((output, key) => {
215
+ if (!error[key]) {
216
+ return output;
217
+ }
218
+ output[key] = error[key];
219
+ return output;
220
+ }, {});
221
+ };
222
+ const validateModelFields = async params => {
223
+ const {
224
+ models,
225
+ model,
226
+ original,
227
+ context
228
+ } = params;
229
+ const {
230
+ titleFieldId,
231
+ descriptionFieldId,
232
+ imageFieldId
233
+ } = model;
234
+ const {
235
+ plugins
236
+ } = context;
237
+
238
+ /**
239
+ * There should be fields/locked fields in either model or data to be updated.
240
+ */
241
+ const {
242
+ fields = [],
243
+ lockedFields = []
244
+ } = model;
245
+
246
+ /**
247
+ * Let's inspect the fields of the received content model. We prevent saving of a content model if it
248
+ * contains a field for which a "cms-model-field-to-graphql" plugin does not exist on the backend.
249
+ */
250
+ const fieldTypePlugins = plugins.byType("cms-model-field-to-graphql");
251
+ validateFields({
252
+ fields,
253
+ originalFields: (original === null || original === void 0 ? void 0 : original.fields) || [],
254
+ lockedFields,
255
+ plugins: fieldTypePlugins
256
+ });
257
+ if (fields.length) {
258
+ const sorterPlugins = plugins.byType(_plugins.CmsGraphQLSchemaSorterPlugin.type);
259
+ /**
260
+ * Make sure that this model can be safely converted to a GraphQL SDL
261
+ */
262
+ const schema = (0, _createManageSDL.createManageSDL)({
263
+ models,
264
+ model,
265
+ fieldTypePlugins: fieldTypePlugins.reduce((acc, pl) => (0, _objectSpread2.default)((0, _objectSpread2.default)({}, acc), {}, {
266
+ [pl.fieldType]: pl
267
+ }), {}),
268
+ sorterPlugins
269
+ });
270
+ try {
271
+ (0, _graphqlTag.default)(schema);
272
+ } catch (err) {
273
+ throw new _error.default(extractInvalidField(model, err));
274
+ }
275
+ /**
276
+ *
277
+ */
278
+ try {
279
+ await createGraphQLSchema({
280
+ context,
281
+ model
282
+ });
283
+ } catch (err) {
284
+ throw new _error.default({
285
+ message: "Cannot generate GraphQL schema when testing with the given model. Please check the response for more details.",
286
+ code: "GRAPHQL_SCHEMA_ERROR",
287
+ data: {
288
+ modelId: model.modelId,
289
+ error: extractErrorObject(err)
290
+ }
291
+ });
292
+ }
293
+ }
294
+ model.titleFieldId = (0, _titleField.getContentModelTitleFieldId)(fields, titleFieldId);
295
+ model.descriptionFieldId = (0, _descriptionField.getContentModelDescriptionFieldId)(fields, descriptionFieldId);
296
+ model.imageFieldId = (0, _imageField.getContentModelImageFieldId)(fields, imageFieldId);
297
+ const cmsLockedFieldPlugins = plugins.byType("cms-model-locked-field");
298
+
299
+ /**
300
+ * We must not allow removal or changes in fields that are already in use in content entries.
301
+ * Locked fields still have fieldId (should be storageId) because of the old existing locked fields in the models.
302
+ */
303
+ for (const lockedField of lockedFields) {
304
+ const existingField = fields.find(item => item.storageId === lockedField.fieldId);
305
+
306
+ /**
307
+ * Starting with 5.33.0 fields can be deleted.
308
+ * Our UI gives a warning upon locked field deletion, but if user is managing fields through API directly - we cannot do anything.
309
+ */
310
+ if (!existingField) {
311
+ continue;
312
+ }
313
+ if (lockedField.multipleValues !== existingField.multipleValues) {
314
+ throw new _error.default(`Cannot change "multipleValues" for the "${lockedField.fieldId}" field because it's already in use in created content.`, "ENTRY_FIELD_USED", {
315
+ reason: `"multipleValues" changed`,
316
+ field: existingField
317
+ });
318
+ }
319
+ const fieldType = (0, _getBaseFieldType.getBaseFieldType)(existingField);
320
+ if (lockedField.type !== fieldType) {
321
+ throw new _error.default(`Cannot change field type for the "${lockedField.fieldId}" field because it's already in use in created content.`, "ENTRY_FIELD_USED", {
322
+ reason: `"type" changed`,
323
+ lockedFieldType: lockedField.type,
324
+ existingFieldType: fieldType
325
+ });
326
+ }
327
+
328
+ /**
329
+ * Check `lockedField` invariant for specific field
330
+ */
331
+ const lockedFieldsByType = cmsLockedFieldPlugins.filter(pl => pl.fieldType === (0, _getBaseFieldType.getBaseFieldType)(lockedField));
332
+ for (const plugin of lockedFieldsByType) {
333
+ if (typeof plugin.checkLockedField !== "function") {
334
+ continue;
335
+ }
336
+ plugin.checkLockedField({
337
+ lockedField,
338
+ field: existingField
339
+ });
340
+ }
341
+ }
342
+ };
343
+ exports.validateModelFields = validateModelFields;