@strapi/core 0.0.0-experimental.1bca8e0e074de8b0775bcddc7656fbc9e9f1393b → 0.0.0-experimental.1d1bb7782aff2a3dab6c460d8a4b24062f767bce

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.

Potentially problematic release.


This version of @strapi/core might be problematic. Click here for more details.

Files changed (744) hide show
  1. package/dist/Strapi.d.ts.map +1 -1
  2. package/dist/Strapi.js +427 -403
  3. package/dist/Strapi.js.map +1 -1
  4. package/dist/Strapi.mjs +426 -402
  5. package/dist/Strapi.mjs.map +1 -1
  6. package/dist/compile.js +23 -14
  7. package/dist/compile.js.map +1 -1
  8. package/dist/compile.mjs +22 -14
  9. package/dist/compile.mjs.map +1 -1
  10. package/dist/configuration/config-loader.js +110 -97
  11. package/dist/configuration/config-loader.js.map +1 -1
  12. package/dist/configuration/config-loader.mjs +109 -96
  13. package/dist/configuration/config-loader.mjs.map +1 -1
  14. package/dist/configuration/get-dirs.js +31 -29
  15. package/dist/configuration/get-dirs.js.map +1 -1
  16. package/dist/configuration/get-dirs.mjs +30 -30
  17. package/dist/configuration/get-dirs.mjs.map +1 -1
  18. package/dist/configuration/index.d.ts +1 -0
  19. package/dist/configuration/index.d.ts.map +1 -1
  20. package/dist/configuration/index.js +85 -73
  21. package/dist/configuration/index.js.map +1 -1
  22. package/dist/configuration/index.mjs +84 -69
  23. package/dist/configuration/index.mjs.map +1 -1
  24. package/dist/configuration/urls.d.ts.map +1 -1
  25. package/dist/configuration/urls.js +74 -61
  26. package/dist/configuration/urls.js.map +1 -1
  27. package/dist/configuration/urls.mjs +73 -62
  28. package/dist/configuration/urls.mjs.map +1 -1
  29. package/dist/container.js +27 -23
  30. package/dist/container.js.map +1 -1
  31. package/dist/container.mjs +26 -24
  32. package/dist/container.mjs.map +1 -1
  33. package/dist/core-api/controller/collection-type.js +77 -76
  34. package/dist/core-api/controller/collection-type.js.map +1 -1
  35. package/dist/core-api/controller/collection-type.mjs +76 -77
  36. package/dist/core-api/controller/collection-type.mjs.map +1 -1
  37. package/dist/core-api/controller/index.js +63 -48
  38. package/dist/core-api/controller/index.js.map +1 -1
  39. package/dist/core-api/controller/index.mjs +62 -49
  40. package/dist/core-api/controller/index.mjs.map +1 -1
  41. package/dist/core-api/controller/single-type.js +41 -40
  42. package/dist/core-api/controller/single-type.js.map +1 -1
  43. package/dist/core-api/controller/single-type.mjs +40 -41
  44. package/dist/core-api/controller/single-type.mjs.map +1 -1
  45. package/dist/core-api/controller/transform.js +72 -63
  46. package/dist/core-api/controller/transform.js.map +1 -1
  47. package/dist/core-api/controller/transform.mjs +71 -64
  48. package/dist/core-api/controller/transform.mjs.map +1 -1
  49. package/dist/core-api/routes/index.js +64 -62
  50. package/dist/core-api/routes/index.js.map +1 -1
  51. package/dist/core-api/routes/index.mjs +62 -62
  52. package/dist/core-api/routes/index.mjs.map +1 -1
  53. package/dist/core-api/service/collection-type.d.ts +2 -2
  54. package/dist/core-api/service/collection-type.js +73 -60
  55. package/dist/core-api/service/collection-type.js.map +1 -1
  56. package/dist/core-api/service/collection-type.mjs +72 -62
  57. package/dist/core-api/service/collection-type.mjs.map +1 -1
  58. package/dist/core-api/service/core-service.js +9 -8
  59. package/dist/core-api/service/core-service.js.map +1 -1
  60. package/dist/core-api/service/core-service.mjs +8 -9
  61. package/dist/core-api/service/core-service.mjs.map +1 -1
  62. package/dist/core-api/service/index.js +13 -13
  63. package/dist/core-api/service/index.js.map +1 -1
  64. package/dist/core-api/service/index.mjs +12 -14
  65. package/dist/core-api/service/index.mjs.map +1 -1
  66. package/dist/core-api/service/pagination.js +69 -43
  67. package/dist/core-api/service/pagination.js.map +1 -1
  68. package/dist/core-api/service/pagination.mjs +68 -47
  69. package/dist/core-api/service/pagination.mjs.map +1 -1
  70. package/dist/core-api/service/single-type.js +43 -39
  71. package/dist/core-api/service/single-type.js.map +1 -1
  72. package/dist/core-api/service/single-type.mjs +42 -41
  73. package/dist/core-api/service/single-type.mjs.map +1 -1
  74. package/dist/domain/content-type/index.js +95 -100
  75. package/dist/domain/content-type/index.js.map +1 -1
  76. package/dist/domain/content-type/index.mjs +94 -100
  77. package/dist/domain/content-type/index.mjs.map +1 -1
  78. package/dist/domain/content-type/validator.js +84 -69
  79. package/dist/domain/content-type/validator.js.map +1 -1
  80. package/dist/domain/content-type/validator.mjs +83 -68
  81. package/dist/domain/content-type/validator.mjs.map +1 -1
  82. package/dist/domain/module/index.js +109 -100
  83. package/dist/domain/module/index.js.map +1 -1
  84. package/dist/domain/module/index.mjs +108 -99
  85. package/dist/domain/module/index.mjs.map +1 -1
  86. package/dist/domain/module/validation.js +25 -20
  87. package/dist/domain/module/validation.js.map +1 -1
  88. package/dist/domain/module/validation.mjs +24 -21
  89. package/dist/domain/module/validation.mjs.map +1 -1
  90. package/dist/ee/index.d.ts +7 -0
  91. package/dist/ee/index.d.ts.map +1 -1
  92. package/dist/ee/index.js +197 -132
  93. package/dist/ee/index.js.map +1 -1
  94. package/dist/ee/index.mjs +196 -134
  95. package/dist/ee/index.mjs.map +1 -1
  96. package/dist/ee/license.d.ts +3 -1
  97. package/dist/ee/license.d.ts.map +1 -1
  98. package/dist/ee/license.js +105 -75
  99. package/dist/ee/license.js.map +1 -1
  100. package/dist/ee/license.mjs +103 -76
  101. package/dist/ee/license.mjs.map +1 -1
  102. package/dist/factories.js +72 -67
  103. package/dist/factories.js.map +1 -1
  104. package/dist/factories.mjs +71 -71
  105. package/dist/factories.mjs.map +1 -1
  106. package/dist/index.js +29 -26
  107. package/dist/index.js.map +1 -1
  108. package/dist/index.mjs +29 -29
  109. package/dist/index.mjs.map +1 -1
  110. package/dist/loaders/admin.d.ts.map +1 -1
  111. package/dist/loaders/admin.js +21 -20
  112. package/dist/loaders/admin.js.map +1 -1
  113. package/dist/loaders/admin.mjs +20 -20
  114. package/dist/loaders/admin.mjs.map +1 -1
  115. package/dist/loaders/apis.js +143 -120
  116. package/dist/loaders/apis.js.map +1 -1
  117. package/dist/loaders/apis.mjs +142 -119
  118. package/dist/loaders/apis.mjs.map +1 -1
  119. package/dist/loaders/components.js +33 -34
  120. package/dist/loaders/components.js.map +1 -1
  121. package/dist/loaders/components.mjs +32 -34
  122. package/dist/loaders/components.mjs.map +1 -1
  123. package/dist/loaders/index.js +22 -20
  124. package/dist/loaders/index.js.map +1 -1
  125. package/dist/loaders/index.mjs +21 -21
  126. package/dist/loaders/index.mjs.map +1 -1
  127. package/dist/loaders/middlewares.js +29 -25
  128. package/dist/loaders/middlewares.js.map +1 -1
  129. package/dist/loaders/middlewares.mjs +28 -25
  130. package/dist/loaders/middlewares.mjs.map +1 -1
  131. package/dist/loaders/plugins/get-enabled-plugins.d.ts.map +1 -1
  132. package/dist/loaders/plugins/get-enabled-plugins.js +125 -102
  133. package/dist/loaders/plugins/get-enabled-plugins.js.map +1 -1
  134. package/dist/loaders/plugins/get-enabled-plugins.mjs +124 -101
  135. package/dist/loaders/plugins/get-enabled-plugins.mjs.map +1 -1
  136. package/dist/loaders/plugins/get-user-plugins-config.js +25 -24
  137. package/dist/loaders/plugins/get-user-plugins-config.js.map +1 -1
  138. package/dist/loaders/plugins/get-user-plugins-config.mjs +24 -23
  139. package/dist/loaders/plugins/get-user-plugins-config.mjs.map +1 -1
  140. package/dist/loaders/plugins/index.d.ts.map +1 -1
  141. package/dist/loaders/plugins/index.js +141 -104
  142. package/dist/loaders/plugins/index.js.map +1 -1
  143. package/dist/loaders/plugins/index.mjs +121 -104
  144. package/dist/loaders/plugins/index.mjs.map +1 -1
  145. package/dist/loaders/policies.js +24 -20
  146. package/dist/loaders/policies.js.map +1 -1
  147. package/dist/loaders/policies.mjs +23 -20
  148. package/dist/loaders/policies.mjs.map +1 -1
  149. package/dist/loaders/sanitizers.js +10 -4
  150. package/dist/loaders/sanitizers.js.map +1 -1
  151. package/dist/loaders/sanitizers.mjs +9 -6
  152. package/dist/loaders/sanitizers.mjs.map +1 -1
  153. package/dist/loaders/src-index.js +35 -27
  154. package/dist/loaders/src-index.js.map +1 -1
  155. package/dist/loaders/src-index.mjs +34 -29
  156. package/dist/loaders/src-index.mjs.map +1 -1
  157. package/dist/loaders/validators.js +9 -4
  158. package/dist/loaders/validators.js.map +1 -1
  159. package/dist/loaders/validators.mjs +8 -6
  160. package/dist/loaders/validators.mjs.map +1 -1
  161. package/dist/middlewares/body.d.ts.map +1 -1
  162. package/dist/middlewares/body.js +58 -54
  163. package/dist/middlewares/body.js.map +1 -1
  164. package/dist/middlewares/body.mjs +57 -51
  165. package/dist/middlewares/body.mjs.map +1 -1
  166. package/dist/middlewares/compression.js +6 -6
  167. package/dist/middlewares/compression.js.map +1 -1
  168. package/dist/middlewares/compression.mjs +5 -5
  169. package/dist/middlewares/compression.mjs.map +1 -1
  170. package/dist/middlewares/cors.js +59 -48
  171. package/dist/middlewares/cors.js.map +1 -1
  172. package/dist/middlewares/cors.mjs +58 -47
  173. package/dist/middlewares/cors.mjs.map +1 -1
  174. package/dist/middlewares/errors.js +32 -30
  175. package/dist/middlewares/errors.js.map +1 -1
  176. package/dist/middlewares/errors.mjs +31 -31
  177. package/dist/middlewares/errors.mjs.map +1 -1
  178. package/dist/middlewares/favicon.js +27 -17
  179. package/dist/middlewares/favicon.js.map +1 -1
  180. package/dist/middlewares/favicon.mjs +26 -16
  181. package/dist/middlewares/favicon.mjs.map +1 -1
  182. package/dist/middlewares/index.js +32 -30
  183. package/dist/middlewares/index.js.map +1 -1
  184. package/dist/middlewares/index.mjs +31 -31
  185. package/dist/middlewares/index.mjs.map +1 -1
  186. package/dist/middlewares/ip.js +6 -6
  187. package/dist/middlewares/ip.js.map +1 -1
  188. package/dist/middlewares/ip.mjs +5 -5
  189. package/dist/middlewares/ip.mjs.map +1 -1
  190. package/dist/middlewares/logger.js +10 -9
  191. package/dist/middlewares/logger.js.map +1 -1
  192. package/dist/middlewares/logger.mjs +9 -10
  193. package/dist/middlewares/logger.mjs.map +1 -1
  194. package/dist/middlewares/powered-by.js +13 -9
  195. package/dist/middlewares/powered-by.js.map +1 -1
  196. package/dist/middlewares/powered-by.mjs +12 -10
  197. package/dist/middlewares/powered-by.mjs.map +1 -1
  198. package/dist/middlewares/public.js +33 -29
  199. package/dist/middlewares/public.js.map +1 -1
  200. package/dist/middlewares/public.mjs +32 -28
  201. package/dist/middlewares/public.mjs.map +1 -1
  202. package/dist/middlewares/query.js +35 -32
  203. package/dist/middlewares/query.js.map +1 -1
  204. package/dist/middlewares/query.mjs +34 -31
  205. package/dist/middlewares/query.mjs.map +1 -1
  206. package/dist/middlewares/response-time.js +10 -9
  207. package/dist/middlewares/response-time.js.map +1 -1
  208. package/dist/middlewares/response-time.mjs +9 -10
  209. package/dist/middlewares/response-time.mjs.map +1 -1
  210. package/dist/middlewares/responses.js +14 -12
  211. package/dist/middlewares/responses.js.map +1 -1
  212. package/dist/middlewares/responses.mjs +13 -13
  213. package/dist/middlewares/responses.mjs.map +1 -1
  214. package/dist/middlewares/security.d.ts.map +1 -1
  215. package/dist/middlewares/security.js +109 -71
  216. package/dist/middlewares/security.js.map +1 -1
  217. package/dist/middlewares/security.mjs +108 -70
  218. package/dist/middlewares/security.mjs.map +1 -1
  219. package/dist/middlewares/session.js +26 -25
  220. package/dist/middlewares/session.js.map +1 -1
  221. package/dist/middlewares/session.mjs +25 -24
  222. package/dist/middlewares/session.mjs.map +1 -1
  223. package/dist/migrations/database/5.0.0-discard-drafts.d.ts +14 -11
  224. package/dist/migrations/database/5.0.0-discard-drafts.d.ts.map +1 -1
  225. package/dist/migrations/database/5.0.0-discard-drafts.js +153 -35
  226. package/dist/migrations/database/5.0.0-discard-drafts.js.map +1 -1
  227. package/dist/migrations/database/5.0.0-discard-drafts.mjs +152 -37
  228. package/dist/migrations/database/5.0.0-discard-drafts.mjs.map +1 -1
  229. package/dist/migrations/draft-publish.d.ts +2 -2
  230. package/dist/migrations/draft-publish.d.ts.map +1 -1
  231. package/dist/migrations/draft-publish.js +61 -34
  232. package/dist/migrations/draft-publish.js.map +1 -1
  233. package/dist/migrations/draft-publish.mjs +60 -36
  234. package/dist/migrations/draft-publish.mjs.map +1 -1
  235. package/dist/migrations/i18n.d.ts +5 -0
  236. package/dist/migrations/i18n.d.ts.map +1 -0
  237. package/dist/migrations/i18n.js +71 -0
  238. package/dist/migrations/i18n.js.map +1 -0
  239. package/dist/migrations/i18n.mjs +68 -0
  240. package/dist/migrations/i18n.mjs.map +1 -0
  241. package/dist/migrations/index.d.ts +5 -0
  242. package/dist/migrations/index.d.ts.map +1 -0
  243. package/dist/migrations/index.js +29 -0
  244. package/dist/migrations/index.js.map +1 -0
  245. package/dist/migrations/index.mjs +26 -0
  246. package/dist/migrations/index.mjs.map +1 -0
  247. package/dist/package.json.js +184 -0
  248. package/dist/package.json.js.map +1 -0
  249. package/dist/package.json.mjs +161 -0
  250. package/dist/package.json.mjs.map +1 -0
  251. package/dist/providers/admin.d.ts.map +1 -1
  252. package/dist/providers/admin.js +27 -17
  253. package/dist/providers/admin.js.map +1 -1
  254. package/dist/providers/admin.mjs +26 -19
  255. package/dist/providers/admin.mjs.map +1 -1
  256. package/dist/providers/coreStore.js +13 -8
  257. package/dist/providers/coreStore.js.map +1 -1
  258. package/dist/providers/coreStore.mjs +12 -10
  259. package/dist/providers/coreStore.mjs.map +1 -1
  260. package/dist/providers/cron.js +19 -16
  261. package/dist/providers/cron.js.map +1 -1
  262. package/dist/providers/cron.mjs +18 -18
  263. package/dist/providers/cron.mjs.map +1 -1
  264. package/dist/providers/index.js +18 -9
  265. package/dist/providers/index.js.map +1 -1
  266. package/dist/providers/index.mjs +17 -10
  267. package/dist/providers/index.mjs.map +1 -1
  268. package/dist/providers/provider.js +4 -3
  269. package/dist/providers/provider.js.map +1 -1
  270. package/dist/providers/provider.mjs +3 -4
  271. package/dist/providers/provider.mjs.map +1 -1
  272. package/dist/providers/registries.js +37 -32
  273. package/dist/providers/registries.js.map +1 -1
  274. package/dist/providers/registries.mjs +36 -34
  275. package/dist/providers/registries.mjs.map +1 -1
  276. package/dist/providers/telemetry.js +19 -16
  277. package/dist/providers/telemetry.js.map +1 -1
  278. package/dist/providers/telemetry.mjs +18 -18
  279. package/dist/providers/telemetry.mjs.map +1 -1
  280. package/dist/providers/webhooks.js +28 -26
  281. package/dist/providers/webhooks.js.map +1 -1
  282. package/dist/providers/webhooks.mjs +27 -28
  283. package/dist/providers/webhooks.mjs.map +1 -1
  284. package/dist/registries/apis.js +23 -20
  285. package/dist/registries/apis.js.map +1 -1
  286. package/dist/registries/apis.mjs +22 -22
  287. package/dist/registries/apis.mjs.map +1 -1
  288. package/dist/registries/components.js +35 -37
  289. package/dist/registries/components.js.map +1 -1
  290. package/dist/registries/components.mjs +34 -39
  291. package/dist/registries/components.mjs.map +1 -1
  292. package/dist/registries/content-types.js +54 -59
  293. package/dist/registries/content-types.js.map +1 -1
  294. package/dist/registries/content-types.mjs +53 -61
  295. package/dist/registries/content-types.mjs.map +1 -1
  296. package/dist/registries/controllers.js +70 -71
  297. package/dist/registries/controllers.js.map +1 -1
  298. package/dist/registries/controllers.mjs +69 -73
  299. package/dist/registries/controllers.mjs.map +1 -1
  300. package/dist/registries/custom-fields.js +75 -65
  301. package/dist/registries/custom-fields.js.map +1 -1
  302. package/dist/registries/custom-fields.mjs +74 -67
  303. package/dist/registries/custom-fields.mjs.map +1 -1
  304. package/dist/registries/hooks.js +46 -49
  305. package/dist/registries/hooks.js.map +1 -1
  306. package/dist/registries/hooks.mjs +45 -51
  307. package/dist/registries/hooks.mjs.map +1 -1
  308. package/dist/registries/middlewares.js +49 -51
  309. package/dist/registries/middlewares.js.map +1 -1
  310. package/dist/registries/middlewares.mjs +48 -53
  311. package/dist/registries/middlewares.mjs.map +1 -1
  312. package/dist/registries/models.js +14 -13
  313. package/dist/registries/models.js.map +1 -1
  314. package/dist/registries/models.mjs +13 -14
  315. package/dist/registries/models.mjs.map +1 -1
  316. package/dist/registries/modules.js +39 -36
  317. package/dist/registries/modules.js.map +1 -1
  318. package/dist/registries/modules.mjs +38 -38
  319. package/dist/registries/modules.mjs.map +1 -1
  320. package/dist/registries/namespace.js +21 -20
  321. package/dist/registries/namespace.js.map +1 -1
  322. package/dist/registries/namespace.mjs +20 -23
  323. package/dist/registries/namespace.mjs.map +1 -1
  324. package/dist/registries/plugins.js +23 -20
  325. package/dist/registries/plugins.js.map +1 -1
  326. package/dist/registries/plugins.mjs +22 -22
  327. package/dist/registries/plugins.mjs.map +1 -1
  328. package/dist/registries/policies.d.ts +1 -1
  329. package/dist/registries/policies.d.ts.map +1 -1
  330. package/dist/registries/policies.js +103 -96
  331. package/dist/registries/policies.js.map +1 -1
  332. package/dist/registries/policies.mjs +102 -98
  333. package/dist/registries/policies.mjs.map +1 -1
  334. package/dist/registries/sanitizers.js +23 -22
  335. package/dist/registries/sanitizers.js.map +1 -1
  336. package/dist/registries/sanitizers.mjs +22 -22
  337. package/dist/registries/sanitizers.mjs.map +1 -1
  338. package/dist/registries/services.js +71 -71
  339. package/dist/registries/services.js.map +1 -1
  340. package/dist/registries/services.mjs +70 -73
  341. package/dist/registries/services.mjs.map +1 -1
  342. package/dist/registries/validators.js +23 -22
  343. package/dist/registries/validators.js.map +1 -1
  344. package/dist/registries/validators.mjs +22 -22
  345. package/dist/registries/validators.mjs.map +1 -1
  346. package/dist/services/auth/index.js +74 -74
  347. package/dist/services/auth/index.js.map +1 -1
  348. package/dist/services/auth/index.mjs +73 -74
  349. package/dist/services/auth/index.mjs.map +1 -1
  350. package/dist/services/config.js +47 -43
  351. package/dist/services/config.js.map +1 -1
  352. package/dist/services/config.mjs +46 -44
  353. package/dist/services/config.mjs.map +1 -1
  354. package/dist/services/content-api/index.d.ts +10 -12
  355. package/dist/services/content-api/index.d.ts.map +1 -1
  356. package/dist/services/content-api/index.js +80 -79
  357. package/dist/services/content-api/index.js.map +1 -1
  358. package/dist/services/content-api/index.mjs +79 -79
  359. package/dist/services/content-api/index.mjs.map +1 -1
  360. package/dist/services/content-api/permissions/engine.js +8 -5
  361. package/dist/services/content-api/permissions/engine.js.map +1 -1
  362. package/dist/services/content-api/permissions/engine.mjs +7 -5
  363. package/dist/services/content-api/permissions/engine.mjs.map +1 -1
  364. package/dist/services/content-api/permissions/index.d.ts +10 -12
  365. package/dist/services/content-api/permissions/index.d.ts.map +1 -1
  366. package/dist/services/content-api/permissions/index.js +101 -81
  367. package/dist/services/content-api/permissions/index.js.map +1 -1
  368. package/dist/services/content-api/permissions/index.mjs +100 -81
  369. package/dist/services/content-api/permissions/index.mjs.map +1 -1
  370. package/dist/services/content-api/permissions/providers/action.d.ts +5 -6
  371. package/dist/services/content-api/permissions/providers/action.d.ts.map +1 -1
  372. package/dist/services/content-api/permissions/providers/action.js +17 -14
  373. package/dist/services/content-api/permissions/providers/action.js.map +1 -1
  374. package/dist/services/content-api/permissions/providers/action.mjs +16 -16
  375. package/dist/services/content-api/permissions/providers/action.mjs.map +1 -1
  376. package/dist/services/content-api/permissions/providers/condition.d.ts +5 -6
  377. package/dist/services/content-api/permissions/providers/condition.d.ts.map +1 -1
  378. package/dist/services/content-api/permissions/providers/condition.js +17 -14
  379. package/dist/services/content-api/permissions/providers/condition.js.map +1 -1
  380. package/dist/services/content-api/permissions/providers/condition.mjs +16 -16
  381. package/dist/services/content-api/permissions/providers/condition.mjs.map +1 -1
  382. package/dist/services/core-store.d.ts +2 -2
  383. package/dist/services/core-store.d.ts.map +1 -1
  384. package/dist/services/core-store.js +115 -95
  385. package/dist/services/core-store.js.map +1 -1
  386. package/dist/services/core-store.mjs +114 -97
  387. package/dist/services/core-store.mjs.map +1 -1
  388. package/dist/services/cron.d.ts +3 -3
  389. package/dist/services/cron.d.ts.map +1 -1
  390. package/dist/services/cron.js +74 -60
  391. package/dist/services/cron.js.map +1 -1
  392. package/dist/services/cron.mjs +73 -62
  393. package/dist/services/cron.mjs.map +1 -1
  394. package/dist/services/custom-fields.js +9 -7
  395. package/dist/services/custom-fields.js.map +1 -1
  396. package/dist/services/custom-fields.mjs +8 -9
  397. package/dist/services/custom-fields.mjs.map +1 -1
  398. package/dist/services/document-service/attributes/index.js +23 -18
  399. package/dist/services/document-service/attributes/index.js.map +1 -1
  400. package/dist/services/document-service/attributes/index.mjs +22 -19
  401. package/dist/services/document-service/attributes/index.mjs.map +1 -1
  402. package/dist/services/document-service/attributes/transforms.js +16 -15
  403. package/dist/services/document-service/attributes/transforms.js.map +1 -1
  404. package/dist/services/document-service/attributes/transforms.mjs +15 -15
  405. package/dist/services/document-service/attributes/transforms.mjs.map +1 -1
  406. package/dist/services/document-service/common.d.ts +1 -1
  407. package/dist/services/document-service/common.d.ts.map +1 -1
  408. package/dist/services/document-service/common.js +5 -4
  409. package/dist/services/document-service/common.js.map +1 -1
  410. package/dist/services/document-service/common.mjs +4 -5
  411. package/dist/services/document-service/common.mjs.map +1 -1
  412. package/dist/services/document-service/components.d.ts.map +1 -1
  413. package/dist/services/document-service/components.js +255 -257
  414. package/dist/services/document-service/components.js.map +1 -1
  415. package/dist/services/document-service/components.mjs +254 -262
  416. package/dist/services/document-service/components.mjs.map +1 -1
  417. package/dist/services/document-service/draft-and-publish.d.ts +1 -1
  418. package/dist/services/document-service/draft-and-publish.d.ts.map +1 -1
  419. package/dist/services/document-service/draft-and-publish.js +88 -48
  420. package/dist/services/document-service/draft-and-publish.js.map +1 -1
  421. package/dist/services/document-service/draft-and-publish.mjs +87 -54
  422. package/dist/services/document-service/draft-and-publish.mjs.map +1 -1
  423. package/dist/services/document-service/entries.d.ts +2 -2
  424. package/dist/services/document-service/entries.d.ts.map +1 -1
  425. package/dist/services/document-service/entries.js +151 -92
  426. package/dist/services/document-service/entries.js.map +1 -1
  427. package/dist/services/document-service/entries.mjs +150 -93
  428. package/dist/services/document-service/entries.mjs.map +1 -1
  429. package/dist/services/document-service/events.d.ts +1 -1
  430. package/dist/services/document-service/events.d.ts.map +1 -1
  431. package/dist/services/document-service/events.js +52 -40
  432. package/dist/services/document-service/events.js.map +1 -1
  433. package/dist/services/document-service/events.mjs +51 -41
  434. package/dist/services/document-service/events.mjs.map +1 -1
  435. package/dist/services/document-service/index.d.ts +2 -1
  436. package/dist/services/document-service/index.d.ts.map +1 -1
  437. package/dist/services/document-service/index.js +53 -32
  438. package/dist/services/document-service/index.js.map +1 -1
  439. package/dist/services/document-service/index.mjs +52 -33
  440. package/dist/services/document-service/index.mjs.map +1 -1
  441. package/dist/services/document-service/internationalization.js +62 -46
  442. package/dist/services/document-service/internationalization.js.map +1 -1
  443. package/dist/services/document-service/internationalization.mjs +61 -50
  444. package/dist/services/document-service/internationalization.mjs.map +1 -1
  445. package/dist/services/document-service/middlewares/errors.js +23 -19
  446. package/dist/services/document-service/middlewares/errors.js.map +1 -1
  447. package/dist/services/document-service/middlewares/errors.mjs +22 -20
  448. package/dist/services/document-service/middlewares/errors.mjs.map +1 -1
  449. package/dist/services/document-service/middlewares/middleware-manager.js +46 -44
  450. package/dist/services/document-service/middlewares/middleware-manager.js.map +1 -1
  451. package/dist/services/document-service/middlewares/middleware-manager.mjs +45 -45
  452. package/dist/services/document-service/middlewares/middleware-manager.mjs.map +1 -1
  453. package/dist/services/document-service/params.js +11 -5
  454. package/dist/services/document-service/params.js.map +1 -1
  455. package/dist/services/document-service/params.mjs +10 -6
  456. package/dist/services/document-service/params.mjs.map +1 -1
  457. package/dist/services/document-service/repository.d.ts.map +1 -1
  458. package/dist/services/document-service/repository.js +355 -269
  459. package/dist/services/document-service/repository.js.map +1 -1
  460. package/dist/services/document-service/repository.mjs +354 -270
  461. package/dist/services/document-service/repository.mjs.map +1 -1
  462. package/dist/services/document-service/transform/data.js +22 -12
  463. package/dist/services/document-service/transform/data.js.map +1 -1
  464. package/dist/services/document-service/transform/data.mjs +21 -13
  465. package/dist/services/document-service/transform/data.mjs.map +1 -1
  466. package/dist/services/document-service/transform/fields.js +26 -17
  467. package/dist/services/document-service/transform/fields.js.map +1 -1
  468. package/dist/services/document-service/transform/fields.mjs +25 -18
  469. package/dist/services/document-service/transform/fields.mjs.map +1 -1
  470. package/dist/services/document-service/transform/id-map.d.ts +1 -1
  471. package/dist/services/document-service/transform/id-map.d.ts.map +1 -1
  472. package/dist/services/document-service/transform/id-map.js +116 -69
  473. package/dist/services/document-service/transform/id-map.js.map +1 -1
  474. package/dist/services/document-service/transform/id-map.mjs +115 -70
  475. package/dist/services/document-service/transform/id-map.mjs.map +1 -1
  476. package/dist/services/document-service/transform/id-transform.d.ts +1 -1
  477. package/dist/services/document-service/transform/id-transform.d.ts.map +1 -1
  478. package/dist/services/document-service/transform/id-transform.js +37 -29
  479. package/dist/services/document-service/transform/id-transform.js.map +1 -1
  480. package/dist/services/document-service/transform/id-transform.mjs +36 -30
  481. package/dist/services/document-service/transform/id-transform.mjs.map +1 -1
  482. package/dist/services/document-service/transform/populate.js +23 -18
  483. package/dist/services/document-service/transform/populate.js.map +1 -1
  484. package/dist/services/document-service/transform/populate.mjs +22 -19
  485. package/dist/services/document-service/transform/populate.mjs.map +1 -1
  486. package/dist/services/document-service/transform/query.js +11 -6
  487. package/dist/services/document-service/transform/query.js.map +1 -1
  488. package/dist/services/document-service/transform/query.mjs +10 -7
  489. package/dist/services/document-service/transform/query.mjs.map +1 -1
  490. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts +1 -1
  491. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts.map +1 -1
  492. package/dist/services/document-service/transform/relations/extract/data-ids.js +71 -48
  493. package/dist/services/document-service/transform/relations/extract/data-ids.js.map +1 -1
  494. package/dist/services/document-service/transform/relations/extract/data-ids.mjs +70 -49
  495. package/dist/services/document-service/transform/relations/extract/data-ids.mjs.map +1 -1
  496. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts.map +1 -1
  497. package/dist/services/document-service/transform/relations/transform/data-ids.js +97 -63
  498. package/dist/services/document-service/transform/relations/transform/data-ids.js.map +1 -1
  499. package/dist/services/document-service/transform/relations/transform/data-ids.mjs +96 -64
  500. package/dist/services/document-service/transform/relations/transform/data-ids.mjs.map +1 -1
  501. package/dist/services/document-service/transform/relations/transform/default-locale.js +47 -29
  502. package/dist/services/document-service/transform/relations/transform/default-locale.js.map +1 -1
  503. package/dist/services/document-service/transform/relations/transform/default-locale.mjs +46 -30
  504. package/dist/services/document-service/transform/relations/transform/default-locale.mjs.map +1 -1
  505. package/dist/services/document-service/transform/relations/utils/dp.d.ts +1 -1
  506. package/dist/services/document-service/transform/relations/utils/dp.d.ts.map +1 -1
  507. package/dist/services/document-service/transform/relations/utils/dp.js +52 -26
  508. package/dist/services/document-service/transform/relations/utils/dp.js.map +1 -1
  509. package/dist/services/document-service/transform/relations/utils/dp.mjs +51 -27
  510. package/dist/services/document-service/transform/relations/utils/dp.mjs.map +1 -1
  511. package/dist/services/document-service/transform/relations/utils/i18n.d.ts +1 -1
  512. package/dist/services/document-service/transform/relations/utils/i18n.d.ts.map +1 -1
  513. package/dist/services/document-service/transform/relations/utils/i18n.js +20 -18
  514. package/dist/services/document-service/transform/relations/utils/i18n.js.map +1 -1
  515. package/dist/services/document-service/transform/relations/utils/i18n.mjs +19 -21
  516. package/dist/services/document-service/transform/relations/utils/i18n.mjs.map +1 -1
  517. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts.map +1 -1
  518. package/dist/services/document-service/transform/relations/utils/map-relation.js +116 -77
  519. package/dist/services/document-service/transform/relations/utils/map-relation.js.map +1 -1
  520. package/dist/services/document-service/transform/relations/utils/map-relation.mjs +115 -79
  521. package/dist/services/document-service/transform/relations/utils/map-relation.mjs.map +1 -1
  522. package/dist/services/document-service/utils/bidirectional-relations.d.ts +95 -0
  523. package/dist/services/document-service/utils/bidirectional-relations.d.ts.map +1 -0
  524. package/dist/services/document-service/utils/bidirectional-relations.js +148 -0
  525. package/dist/services/document-service/utils/bidirectional-relations.js.map +1 -0
  526. package/dist/services/document-service/utils/bidirectional-relations.mjs +145 -0
  527. package/dist/services/document-service/utils/bidirectional-relations.mjs.map +1 -0
  528. package/dist/services/document-service/utils/populate.d.ts +1 -1
  529. package/dist/services/document-service/utils/populate.d.ts.map +1 -1
  530. package/dist/services/document-service/utils/populate.js +67 -41
  531. package/dist/services/document-service/utils/populate.js.map +1 -1
  532. package/dist/services/document-service/utils/populate.mjs +66 -42
  533. package/dist/services/document-service/utils/populate.mjs.map +1 -1
  534. package/dist/services/document-service/utils/unidirectional-relations.d.ts +36 -0
  535. package/dist/services/document-service/utils/unidirectional-relations.d.ts.map +1 -0
  536. package/dist/services/document-service/utils/unidirectional-relations.js +116 -0
  537. package/dist/services/document-service/utils/unidirectional-relations.js.map +1 -0
  538. package/dist/services/document-service/utils/unidirectional-relations.mjs +113 -0
  539. package/dist/services/document-service/utils/unidirectional-relations.mjs.map +1 -0
  540. package/dist/services/entity-service/index.js +230 -161
  541. package/dist/services/entity-service/index.js.map +1 -1
  542. package/dist/services/entity-service/index.mjs +229 -160
  543. package/dist/services/entity-service/index.mjs.map +1 -1
  544. package/dist/services/entity-validator/blocks-validator.d.ts +1 -2
  545. package/dist/services/entity-validator/blocks-validator.d.ts.map +1 -1
  546. package/dist/services/entity-validator/blocks-validator.js +137 -104
  547. package/dist/services/entity-validator/blocks-validator.js.map +1 -1
  548. package/dist/services/entity-validator/blocks-validator.mjs +135 -105
  549. package/dist/services/entity-validator/blocks-validator.mjs.map +1 -1
  550. package/dist/services/entity-validator/index.d.ts +2 -1
  551. package/dist/services/entity-validator/index.d.ts.map +1 -1
  552. package/dist/services/entity-validator/index.js +370 -367
  553. package/dist/services/entity-validator/index.js.map +1 -1
  554. package/dist/services/entity-validator/index.mjs +366 -364
  555. package/dist/services/entity-validator/index.mjs.map +1 -1
  556. package/dist/services/entity-validator/validators.d.ts +33 -23
  557. package/dist/services/entity-validator/validators.d.ts.map +1 -1
  558. package/dist/services/entity-validator/validators.js +285 -151
  559. package/dist/services/entity-validator/validators.js.map +1 -1
  560. package/dist/services/entity-validator/validators.mjs +276 -150
  561. package/dist/services/entity-validator/validators.mjs.map +1 -1
  562. package/dist/services/errors.js +65 -65
  563. package/dist/services/errors.js.map +1 -1
  564. package/dist/services/errors.mjs +64 -66
  565. package/dist/services/errors.mjs.map +1 -1
  566. package/dist/services/event-hub.js +82 -69
  567. package/dist/services/event-hub.js.map +1 -1
  568. package/dist/services/event-hub.mjs +81 -71
  569. package/dist/services/event-hub.mjs.map +1 -1
  570. package/dist/services/features.js +19 -14
  571. package/dist/services/features.js.map +1 -1
  572. package/dist/services/features.mjs +18 -15
  573. package/dist/services/features.mjs.map +1 -1
  574. package/dist/services/fs.js +41 -40
  575. package/dist/services/fs.js.map +1 -1
  576. package/dist/services/fs.mjs +40 -39
  577. package/dist/services/fs.mjs.map +1 -1
  578. package/dist/services/metrics/admin-user-hash.d.ts.map +1 -1
  579. package/dist/services/metrics/admin-user-hash.js +13 -11
  580. package/dist/services/metrics/admin-user-hash.js.map +1 -1
  581. package/dist/services/metrics/admin-user-hash.mjs +12 -10
  582. package/dist/services/metrics/admin-user-hash.mjs.map +1 -1
  583. package/dist/services/metrics/index.js +46 -40
  584. package/dist/services/metrics/index.js.map +1 -1
  585. package/dist/services/metrics/index.mjs +45 -42
  586. package/dist/services/metrics/index.mjs.map +1 -1
  587. package/dist/services/metrics/is-truthy.js +13 -6
  588. package/dist/services/metrics/is-truthy.js.map +1 -1
  589. package/dist/services/metrics/is-truthy.mjs +12 -6
  590. package/dist/services/metrics/is-truthy.mjs.map +1 -1
  591. package/dist/services/metrics/middleware.d.ts.map +1 -1
  592. package/dist/services/metrics/middleware.js +37 -22
  593. package/dist/services/metrics/middleware.js.map +1 -1
  594. package/dist/services/metrics/middleware.mjs +36 -24
  595. package/dist/services/metrics/middleware.mjs.map +1 -1
  596. package/dist/services/metrics/rate-limiter.d.ts.map +1 -1
  597. package/dist/services/metrics/rate-limiter.js +24 -19
  598. package/dist/services/metrics/rate-limiter.js.map +1 -1
  599. package/dist/services/metrics/rate-limiter.mjs +23 -21
  600. package/dist/services/metrics/rate-limiter.mjs.map +1 -1
  601. package/dist/services/metrics/sender.d.ts.map +1 -1
  602. package/dist/services/metrics/sender.js +78 -69
  603. package/dist/services/metrics/sender.js.map +1 -1
  604. package/dist/services/metrics/sender.mjs +77 -64
  605. package/dist/services/metrics/sender.mjs.map +1 -1
  606. package/dist/services/query-params.js +13 -10
  607. package/dist/services/query-params.js.map +1 -1
  608. package/dist/services/query-params.mjs +12 -12
  609. package/dist/services/query-params.mjs.map +1 -1
  610. package/dist/services/reloader.js +35 -32
  611. package/dist/services/reloader.js.map +1 -1
  612. package/dist/services/reloader.mjs +34 -33
  613. package/dist/services/reloader.mjs.map +1 -1
  614. package/dist/services/request-context.js +11 -8
  615. package/dist/services/request-context.js.map +1 -1
  616. package/dist/services/request-context.mjs +10 -10
  617. package/dist/services/request-context.mjs.map +1 -1
  618. package/dist/services/server/admin-api.js +11 -10
  619. package/dist/services/server/admin-api.js.map +1 -1
  620. package/dist/services/server/admin-api.mjs +10 -11
  621. package/dist/services/server/admin-api.mjs.map +1 -1
  622. package/dist/services/server/api.js +33 -27
  623. package/dist/services/server/api.js.map +1 -1
  624. package/dist/services/server/api.mjs +32 -26
  625. package/dist/services/server/api.mjs.map +1 -1
  626. package/dist/services/server/compose-endpoint.js +116 -105
  627. package/dist/services/server/compose-endpoint.js.map +1 -1
  628. package/dist/services/server/compose-endpoint.mjs +115 -105
  629. package/dist/services/server/compose-endpoint.mjs.map +1 -1
  630. package/dist/services/server/content-api.js +11 -9
  631. package/dist/services/server/content-api.js.map +1 -1
  632. package/dist/services/server/content-api.mjs +10 -10
  633. package/dist/services/server/content-api.mjs.map +1 -1
  634. package/dist/services/server/http-server.js +48 -44
  635. package/dist/services/server/http-server.js.map +1 -1
  636. package/dist/services/server/http-server.mjs +47 -43
  637. package/dist/services/server/http-server.mjs.map +1 -1
  638. package/dist/services/server/index.js +85 -82
  639. package/dist/services/server/index.js.map +1 -1
  640. package/dist/services/server/index.mjs +84 -81
  641. package/dist/services/server/index.mjs.map +1 -1
  642. package/dist/services/server/koa.js +49 -47
  643. package/dist/services/server/koa.js.map +1 -1
  644. package/dist/services/server/koa.mjs +48 -44
  645. package/dist/services/server/koa.mjs.map +1 -1
  646. package/dist/services/server/middleware.js +86 -82
  647. package/dist/services/server/middleware.js.map +1 -1
  648. package/dist/services/server/middleware.mjs +85 -82
  649. package/dist/services/server/middleware.mjs.map +1 -1
  650. package/dist/services/server/policy.js +24 -17
  651. package/dist/services/server/policy.js.map +1 -1
  652. package/dist/services/server/policy.mjs +23 -18
  653. package/dist/services/server/policy.mjs.map +1 -1
  654. package/dist/services/server/register-middlewares.js +68 -61
  655. package/dist/services/server/register-middlewares.js.map +1 -1
  656. package/dist/services/server/register-middlewares.mjs +67 -63
  657. package/dist/services/server/register-middlewares.mjs.map +1 -1
  658. package/dist/services/server/register-routes.js +90 -67
  659. package/dist/services/server/register-routes.js.map +1 -1
  660. package/dist/services/server/register-routes.mjs +89 -67
  661. package/dist/services/server/register-routes.mjs.map +1 -1
  662. package/dist/services/server/routing.js +94 -81
  663. package/dist/services/server/routing.js.map +1 -1
  664. package/dist/services/server/routing.mjs +93 -81
  665. package/dist/services/server/routing.mjs.map +1 -1
  666. package/dist/services/utils/dynamic-zones.js +13 -14
  667. package/dist/services/utils/dynamic-zones.js.map +1 -1
  668. package/dist/services/utils/dynamic-zones.mjs +12 -16
  669. package/dist/services/utils/dynamic-zones.mjs.map +1 -1
  670. package/dist/services/webhook-runner.js +124 -122
  671. package/dist/services/webhook-runner.js.map +1 -1
  672. package/dist/services/webhook-runner.mjs +123 -121
  673. package/dist/services/webhook-runner.mjs.map +1 -1
  674. package/dist/services/webhook-store.js +132 -99
  675. package/dist/services/webhook-store.js.map +1 -1
  676. package/dist/services/webhook-store.mjs +131 -101
  677. package/dist/services/webhook-store.mjs.map +1 -1
  678. package/dist/services/worker-queue.js +44 -49
  679. package/dist/services/worker-queue.js.map +1 -1
  680. package/dist/services/worker-queue.mjs +43 -49
  681. package/dist/services/worker-queue.mjs.map +1 -1
  682. package/dist/utils/convert-custom-field-type.js +17 -20
  683. package/dist/utils/convert-custom-field-type.js.map +1 -1
  684. package/dist/utils/convert-custom-field-type.mjs +16 -21
  685. package/dist/utils/convert-custom-field-type.mjs.map +1 -1
  686. package/dist/utils/cron.js +64 -30
  687. package/dist/utils/cron.js.map +1 -1
  688. package/dist/utils/cron.mjs +63 -31
  689. package/dist/utils/cron.mjs.map +1 -1
  690. package/dist/utils/fetch.d.ts +5 -1
  691. package/dist/utils/fetch.d.ts.map +1 -1
  692. package/dist/utils/fetch.js +28 -18
  693. package/dist/utils/fetch.js.map +1 -1
  694. package/dist/utils/fetch.mjs +27 -19
  695. package/dist/utils/fetch.mjs.map +1 -1
  696. package/dist/utils/filepath-to-prop-path.js +20 -28
  697. package/dist/utils/filepath-to-prop-path.js.map +1 -1
  698. package/dist/utils/filepath-to-prop-path.mjs +19 -26
  699. package/dist/utils/filepath-to-prop-path.mjs.map +1 -1
  700. package/dist/utils/is-initialized.js +21 -12
  701. package/dist/utils/is-initialized.js.map +1 -1
  702. package/dist/utils/is-initialized.mjs +20 -13
  703. package/dist/utils/is-initialized.mjs.map +1 -1
  704. package/dist/utils/lifecycles.js +6 -5
  705. package/dist/utils/lifecycles.js.map +1 -1
  706. package/dist/utils/lifecycles.mjs +5 -6
  707. package/dist/utils/lifecycles.mjs.map +1 -1
  708. package/dist/utils/load-config-file.js +40 -38
  709. package/dist/utils/load-config-file.js.map +1 -1
  710. package/dist/utils/load-config-file.mjs +39 -36
  711. package/dist/utils/load-config-file.mjs.map +1 -1
  712. package/dist/utils/load-files.js +40 -35
  713. package/dist/utils/load-files.js.map +1 -1
  714. package/dist/utils/load-files.mjs +39 -32
  715. package/dist/utils/load-files.mjs.map +1 -1
  716. package/dist/utils/open-browser.js +8 -8
  717. package/dist/utils/open-browser.js.map +1 -1
  718. package/dist/utils/open-browser.mjs +7 -7
  719. package/dist/utils/open-browser.mjs.map +1 -1
  720. package/dist/utils/resolve-working-dirs.js +23 -10
  721. package/dist/utils/resolve-working-dirs.js.map +1 -1
  722. package/dist/utils/resolve-working-dirs.mjs +22 -9
  723. package/dist/utils/resolve-working-dirs.mjs.map +1 -1
  724. package/dist/utils/signals.js +20 -14
  725. package/dist/utils/signals.js.map +1 -1
  726. package/dist/utils/signals.mjs +19 -15
  727. package/dist/utils/signals.mjs.map +1 -1
  728. package/dist/utils/startup-logger.d.ts.map +1 -1
  729. package/dist/utils/startup-logger.js +107 -78
  730. package/dist/utils/startup-logger.js.map +1 -1
  731. package/dist/utils/startup-logger.mjs +106 -75
  732. package/dist/utils/startup-logger.mjs.map +1 -1
  733. package/dist/utils/transform-content-types-to-models.d.ts +552 -23
  734. package/dist/utils/transform-content-types-to-models.d.ts.map +1 -1
  735. package/dist/utils/transform-content-types-to-models.js +350 -260
  736. package/dist/utils/transform-content-types-to-models.js.map +1 -1
  737. package/dist/utils/transform-content-types-to-models.mjs +349 -268
  738. package/dist/utils/transform-content-types-to-models.mjs.map +1 -1
  739. package/dist/utils/update-notifier/index.d.ts.map +1 -1
  740. package/dist/utils/update-notifier/index.js +68 -73
  741. package/dist/utils/update-notifier/index.js.map +1 -1
  742. package/dist/utils/update-notifier/index.mjs +67 -67
  743. package/dist/utils/update-notifier/index.mjs.map +1 -1
  744. package/package.json +32 -31
@@ -1,390 +1,393 @@
1
- "use strict";
2
- const _ = require("lodash");
3
- const fp = require("lodash/fp");
4
- const strapiUtils = require("@strapi/utils");
5
- const validators = require("./validators.js");
6
- const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
7
- const strapiUtils__default = /* @__PURE__ */ _interopDefault(strapiUtils);
8
- const { yup, validateYupSchema } = strapiUtils__default.default;
9
- const { isMediaAttribute, isScalarAttribute, getWritableAttributes } = strapiUtils__default.default.contentTypes;
10
- const { ValidationError } = strapiUtils__default.default.errors;
11
- const isInteger = (value) => Number.isInteger(value);
12
- const addMinMax = (validator, {
13
- attr,
14
- updatedAttribute
15
- }) => {
16
- let nextValidator = validator;
17
- if (isInteger(attr.min) && ("required" in attr && attr.required || Array.isArray(updatedAttribute.value) && updatedAttribute.value.length > 0)) {
18
- nextValidator = nextValidator.min(attr.min);
19
- }
20
- if (isInteger(attr.max)) {
21
- nextValidator = nextValidator.max(attr.max);
22
- }
23
- return nextValidator;
24
- };
25
- const addRequiredValidation = (createOrUpdate) => {
26
- return (validator, {
27
- attr: { required }
28
- }) => {
1
+ 'use strict';
2
+
3
+ var _ = require('lodash');
4
+ var fp = require('lodash/fp');
5
+ var jsonLogic = require('json-logic-js');
6
+ var strapiUtils = require('@strapi/utils');
7
+ var validators = require('./validators.js');
8
+
9
+ const { yup, validateYupSchema } = strapiUtils;
10
+ const { isMediaAttribute, isScalarAttribute, getWritableAttributes } = strapiUtils.contentTypes;
11
+ const { ValidationError } = strapiUtils.errors;
12
+ const isInteger = (value)=>Number.isInteger(value);
13
+ const addMinMax = (validator, { attr, updatedAttribute })=>{
29
14
  let nextValidator = validator;
30
- if (required) {
31
- if (createOrUpdate === "creation") {
32
- nextValidator = nextValidator.notNil();
33
- } else if (createOrUpdate === "update") {
34
- nextValidator = nextValidator.notNull();
35
- }
36
- } else {
37
- nextValidator = nextValidator.nullable();
15
+ if (isInteger(attr.min) && ('required' in attr && attr.required || Array.isArray(updatedAttribute.value) && updatedAttribute.value.length > 0)) {
16
+ nextValidator = nextValidator.min(attr.min);
38
17
  }
39
- return nextValidator;
40
- };
41
- };
42
- const addDefault = (createOrUpdate) => {
43
- return (validator, { attr }) => {
44
- let nextValidator = validator;
45
- if (createOrUpdate === "creation") {
46
- if ((attr.type === "component" && attr.repeatable || attr.type === "dynamiczone") && !attr.required) {
47
- nextValidator = nextValidator.default([]);
48
- } else {
49
- nextValidator = nextValidator.default(attr.default);
50
- }
51
- } else {
52
- nextValidator = nextValidator.default(void 0);
18
+ if (isInteger(attr.max)) {
19
+ nextValidator = nextValidator.max(attr.max);
53
20
  }
54
21
  return nextValidator;
55
- };
56
- };
57
- const preventCast = (validator) => validator.transform((val, originalVal) => originalVal);
58
- const createComponentValidator = (createOrUpdate) => ({
59
- attr,
60
- updatedAttribute,
61
- componentContext
62
- }, { isDraft }) => {
63
- const model = strapi.getModel(attr.component);
64
- if (!model) {
65
- throw new Error("Validation failed: Model not found");
66
- }
67
- if (attr?.repeatable) {
68
- let validator2 = yup.array().of(
69
- yup.lazy(
70
- (item) => createModelValidator(createOrUpdate)(
71
- { componentContext, model, data: item },
72
- { isDraft }
73
- ).notNull()
74
- )
75
- );
76
- validator2 = addRequiredValidation(createOrUpdate)(validator2, {
77
- attr: { required: true },
78
- updatedAttribute
79
- });
80
- validator2 = addMinMax(validator2, { attr, updatedAttribute });
81
- return validator2;
82
- }
83
- let validator = createModelValidator(createOrUpdate)(
84
- {
85
- model,
86
- data: updatedAttribute.value,
87
- componentContext
88
- },
89
- { isDraft }
90
- );
91
- validator = addRequiredValidation(createOrUpdate)(validator, {
92
- attr: { required: !isDraft && attr.required },
93
- updatedAttribute
94
- });
95
- return validator;
96
22
  };
97
- const createDzValidator = (createOrUpdate) => ({ attr, updatedAttribute, componentContext }, { isDraft }) => {
98
- let validator;
99
- validator = yup.array().of(
100
- yup.lazy((item) => {
101
- const model = strapi.getModel(fp.prop("__component", item));
102
- const schema = yup.object().shape({
103
- __component: yup.string().required().oneOf(Object.keys(strapi.components))
104
- }).notNull();
105
- return model ? schema.concat(
106
- createModelValidator(createOrUpdate)(
107
- { model, data: item, componentContext },
108
- { isDraft }
109
- )
110
- ) : schema;
111
- })
112
- // FIXME: yup v1
113
- );
114
- validator = addRequiredValidation(createOrUpdate)(validator, {
115
- attr: { required: true },
116
- updatedAttribute
117
- });
118
- validator = addMinMax(validator, { attr, updatedAttribute });
119
- return validator;
120
- };
121
- const createRelationValidator = ({
122
- updatedAttribute
123
- }) => {
124
- let validator;
125
- if (Array.isArray(updatedAttribute.value)) {
126
- validator = yup.array().of(yup.mixed());
127
- } else {
128
- validator = yup.mixed();
129
- }
130
- return validator;
131
- };
132
- const createScalarAttributeValidator = (createOrUpdate) => (metas, options) => {
133
- let validator;
134
- if (fp.has(metas.attr.type, validators)) {
135
- validator = validators[metas.attr.type](metas, options);
136
- } else {
137
- validator = yup.mixed();
138
- }
139
- validator = addRequiredValidation(createOrUpdate)(validator, {
140
- attr: { required: !options.isDraft && metas.attr.required },
141
- updatedAttribute: metas.updatedAttribute
142
- });
143
- return validator;
144
- };
145
- const createAttributeValidator = (createOrUpdate) => (metas, options) => {
146
- let validator = yup.mixed();
147
- if (isMediaAttribute(metas.attr)) {
148
- validator = yup.mixed();
149
- } else if (isScalarAttribute(metas.attr)) {
150
- validator = createScalarAttributeValidator(createOrUpdate)(metas, options);
151
- } else {
152
- if (metas.attr.type === "component") {
153
- const pathToComponent = [
154
- ...metas?.componentContext?.pathToComponent ?? [],
155
- metas.updatedAttribute.name
156
- ];
157
- const repeatableData = metas.attr.repeatable && pathToComponent.length === 1 ? metas.updatedAttribute.value : metas.componentContext?.repeatableData;
158
- const newComponentContext = {
159
- ...metas?.componentContext ?? {},
160
- pathToComponent,
161
- repeatableData
162
- };
163
- validator = createComponentValidator(createOrUpdate)(
164
- {
165
- componentContext: newComponentContext,
166
- attr: metas.attr,
167
- updatedAttribute: metas.updatedAttribute
168
- },
169
- options
170
- );
171
- } else if (metas.attr.type === "dynamiczone") {
172
- const pathToComponent = [
173
- ...metas?.componentContext?.pathToComponent ?? [],
174
- metas.updatedAttribute.name
175
- ];
176
- const newComponentContext = {
177
- ...metas?.componentContext ?? {},
178
- pathToComponent
179
- };
180
- validator = createDzValidator(createOrUpdate)(
181
- { ...metas, componentContext: newComponentContext },
182
- options
183
- );
184
- } else if (metas.attr.type === "relation") {
185
- validator = createRelationValidator({
186
- attr: metas.attr,
187
- updatedAttribute: metas.updatedAttribute
188
- });
189
- }
190
- validator = preventCast(validator);
191
- }
192
- validator = addDefault(createOrUpdate)(validator, metas);
193
- return validator;
23
+ const addRequiredValidation = (createOrUpdate)=>{
24
+ return (validator, { attr: { required } })=>{
25
+ let nextValidator = validator;
26
+ if (required) {
27
+ if (createOrUpdate === 'creation') {
28
+ nextValidator = nextValidator.notNil();
29
+ } else if (createOrUpdate === 'update') {
30
+ nextValidator = nextValidator.notNull();
31
+ }
32
+ } else {
33
+ nextValidator = nextValidator.nullable();
34
+ }
35
+ return nextValidator;
36
+ };
194
37
  };
195
- const createModelValidator = (createOrUpdate) => ({ componentContext, model, data, entity }, options) => {
196
- const writableAttributes = model ? getWritableAttributes(model) : [];
197
- const schema = writableAttributes.reduce(
198
- (validators2, attributeName) => {
199
- const metas = {
200
- attr: model.attributes[attributeName],
201
- updatedAttribute: { name: attributeName, value: fp.prop(attributeName, data) },
202
- model,
203
- entity,
204
- componentContext
205
- };
206
- const validator = createAttributeValidator(createOrUpdate)(metas, options);
207
- validators2[attributeName] = validator;
208
- return validators2;
209
- },
210
- {}
211
- );
212
- return yup.object().shape(schema);
38
+ const addDefault = (createOrUpdate)=>{
39
+ return (validator, { attr })=>{
40
+ let nextValidator = validator;
41
+ if (createOrUpdate === 'creation') {
42
+ if ((attr.type === 'component' && attr.repeatable || attr.type === 'dynamiczone') && !attr.required) {
43
+ nextValidator = nextValidator.default([]);
44
+ } else {
45
+ nextValidator = nextValidator.default(attr.default);
46
+ }
47
+ } else {
48
+ nextValidator = nextValidator.default(undefined);
49
+ }
50
+ return nextValidator;
51
+ };
213
52
  };
214
- const createValidateEntity = (createOrUpdate) => {
215
- return async (model, data, options, entity) => {
216
- if (!fp.isObject(data)) {
217
- const { displayName } = model.info;
218
- throw new ValidationError(
219
- `Invalid payload submitted for the ${createOrUpdate} of an entity of type ${displayName}. Expected an object, but got ${typeof data}`
220
- );
221
- }
222
- const validator = createModelValidator(createOrUpdate)(
223
- {
224
- model,
225
- data,
226
- entity,
227
- componentContext: {
228
- // Set up the initial component context.
229
- // Keeping track of parent content type context in which a component will be used.
230
- // This is necessary to validate component field constraints such as uniqueness.
231
- parentContent: {
232
- id: entity?.id,
233
- model,
234
- options
235
- },
236
- pathToComponent: [],
237
- repeatableData: []
53
+ const preventCast = (validator)=>validator.transform((val, originalVal)=>originalVal);
54
+ const createComponentValidator = (createOrUpdate)=>({ attr, updatedAttribute, componentContext }, { isDraft })=>{
55
+ const model = strapi.getModel(attr.component);
56
+ if (!model) {
57
+ throw new Error('Validation failed: Model not found');
58
+ }
59
+ if (attr?.repeatable) {
60
+ // FIXME: yup v1
61
+ let validator = yup.array().of(yup.lazy((item)=>createModelValidator(createOrUpdate)({
62
+ componentContext,
63
+ model,
64
+ data: item
65
+ }, {
66
+ isDraft
67
+ }).notNull()));
68
+ validator = addRequiredValidation(createOrUpdate)(validator, {
69
+ attr: {
70
+ required: true
71
+ },
72
+ updatedAttribute
73
+ });
74
+ if (!isDraft) {
75
+ validator = addMinMax(validator, {
76
+ attr,
77
+ updatedAttribute
78
+ });
79
+ }
80
+ return validator;
238
81
  }
239
- },
240
- {
241
- isDraft: options?.isDraft ?? false,
242
- locale: options?.locale ?? null
243
- }
244
- ).test(
245
- "relations-test",
246
- "check that all relations exist",
247
- async function relationsValidation(data2) {
248
- try {
249
- await checkRelationsExist(buildRelationsStore({ uid: model.uid, data: data2 }));
250
- } catch (e) {
251
- return this.createError({
252
- path: this.path,
253
- message: e instanceof ValidationError && e.message || "Invalid relations"
254
- });
82
+ let validator = createModelValidator(createOrUpdate)({
83
+ model,
84
+ data: updatedAttribute.value,
85
+ componentContext
86
+ }, {
87
+ isDraft
88
+ });
89
+ validator = addRequiredValidation(createOrUpdate)(validator, {
90
+ attr: {
91
+ required: !isDraft && attr.required
92
+ },
93
+ updatedAttribute
94
+ });
95
+ return validator;
96
+ };
97
+ const createDzValidator = (createOrUpdate)=>({ attr, updatedAttribute, componentContext }, { isDraft })=>{
98
+ let validator;
99
+ validator = yup.array().of(yup.lazy((item)=>{
100
+ const model = strapi.getModel(fp.prop('__component', item));
101
+ const schema = yup.object().shape({
102
+ __component: yup.string().required().oneOf(Object.keys(strapi.components))
103
+ }).notNull();
104
+ return model ? schema.concat(createModelValidator(createOrUpdate)({
105
+ model,
106
+ data: item,
107
+ componentContext
108
+ }, {
109
+ isDraft
110
+ })) : schema;
111
+ }));
112
+ validator = addRequiredValidation(createOrUpdate)(validator, {
113
+ attr: {
114
+ required: true
115
+ },
116
+ updatedAttribute
117
+ });
118
+ if (!isDraft) {
119
+ validator = addMinMax(validator, {
120
+ attr,
121
+ updatedAttribute
122
+ });
255
123
  }
256
- return true;
257
- }
258
- ).required();
259
- return validateYupSchema(validator, {
260
- strict: false,
261
- abortEarly: false
262
- })(data);
263
- };
124
+ return validator;
125
+ };
126
+ const createRelationValidator = ({ updatedAttribute })=>{
127
+ let validator;
128
+ if (Array.isArray(updatedAttribute.value)) {
129
+ validator = yup.array().of(yup.mixed());
130
+ } else {
131
+ validator = yup.mixed();
132
+ }
133
+ return validator;
264
134
  };
265
- const buildRelationsStore = ({
266
- uid,
267
- data
268
- }) => {
269
- if (!uid) {
270
- throw new ValidationError(`Cannot build relations store: "uid" is undefined`);
271
- }
272
- if (fp.isEmpty(data)) {
273
- return {};
274
- }
275
- const currentModel = strapi.getModel(uid);
276
- return Object.keys(currentModel.attributes).reduce(
277
- (result, attributeName) => {
278
- const attribute = currentModel.attributes[attributeName];
279
- const value = data[attributeName];
280
- if (_.isNil(value)) {
281
- return result;
282
- }
283
- switch (attribute.type) {
284
- case "relation":
285
- case "media": {
286
- if (attribute.type === "relation" && (attribute.relation === "morphToMany" || attribute.relation === "morphToOne")) {
287
- break;
288
- }
289
- const target = (
290
- // eslint-disable-next-line no-nested-ternary
291
- attribute.type === "media" ? "plugin::upload.file" : attribute.target
292
- );
293
- let source;
294
- if (Array.isArray(value)) {
295
- source = value;
296
- } else if (fp.isObject(value)) {
297
- if ("connect" in value && !_.isNil(value.connect)) {
298
- source = value.connect;
299
- } else if ("set" in value && !_.isNil(value.set)) {
300
- source = value.set;
301
- } else {
302
- source = [];
135
+ const createScalarAttributeValidator = (createOrUpdate)=>(metas, options)=>{
136
+ let validator;
137
+ if (fp.has(metas.attr.type, validators.Validators)) {
138
+ validator = validators.Validators[metas.attr.type](metas, options);
139
+ } else {
140
+ // No validators specified - fall back to mixed
141
+ validator = yup.mixed();
142
+ }
143
+ validator = addRequiredValidation(createOrUpdate)(validator, {
144
+ attr: {
145
+ required: !options.isDraft && metas.attr.required
146
+ },
147
+ updatedAttribute: metas.updatedAttribute
148
+ });
149
+ return validator;
150
+ };
151
+ const createAttributeValidator = (createOrUpdate)=>(metas, options)=>{
152
+ let validator = yup.mixed();
153
+ // If field is conditionally invisible, skip all validation for it
154
+ if (metas.attr.conditions?.visible) {
155
+ const isVisible = jsonLogic.apply(metas.attr.conditions.visible, metas.data);
156
+ if (!isVisible) {
157
+ return yup.mixed().notRequired(); // Completely skip validation
303
158
  }
304
- } else {
305
- source = _.castArray(value);
306
- }
307
- const idArray = source.map((v) => ({
308
- id: typeof v === "object" ? v.id : v
309
- }));
310
- result[target] = result[target] || [];
311
- result[target].push(...idArray);
312
- break;
313
159
  }
314
- case "component": {
315
- return _.castArray(value).reduce((relationsStore, componentValue) => {
316
- if (!attribute.component) {
317
- throw new ValidationError(
318
- `Cannot build relations store from component, component identifier is undefined`
319
- );
160
+ if (isMediaAttribute(metas.attr)) {
161
+ validator = yup.mixed();
162
+ } else if (isScalarAttribute(metas.attr)) {
163
+ validator = createScalarAttributeValidator(createOrUpdate)(metas, options);
164
+ } else {
165
+ if (metas.attr.type === 'component' && metas.componentContext) {
166
+ // Build the path to the component within the parent content type schema.
167
+ const pathToComponent = [
168
+ ...metas?.componentContext?.pathToComponent ?? [],
169
+ metas.updatedAttribute.name
170
+ ];
171
+ // If working with a repeatable component, determine the repeatable data
172
+ // based on the component's path.
173
+ // In order to validate the repeatable within this entity we need
174
+ // access to the full repeatable data. In case we are validating a
175
+ // nested component within a repeatable.
176
+ // Hence why we set this up when the path to the component is only one level deep.
177
+ const repeatableData = metas.attr.repeatable && pathToComponent.length === 1 ? metas.updatedAttribute.value : metas.componentContext?.repeatableData;
178
+ const newComponentContext = {
179
+ ...metas.componentContext,
180
+ pathToComponent,
181
+ repeatableData
182
+ };
183
+ validator = createComponentValidator(createOrUpdate)({
184
+ componentContext: newComponentContext,
185
+ attr: metas.attr,
186
+ updatedAttribute: metas.updatedAttribute
187
+ }, options);
188
+ } else if (metas.attr.type === 'dynamiczone' && metas.componentContext) {
189
+ const newComponentContext = {
190
+ ...metas.componentContext,
191
+ fullDynamicZoneContent: metas.updatedAttribute.value,
192
+ pathToComponent: [
193
+ ...metas.componentContext.pathToComponent,
194
+ metas.updatedAttribute.name
195
+ ]
196
+ };
197
+ Object.assign(metas, {
198
+ componentContext: newComponentContext
199
+ });
200
+ validator = createDzValidator(createOrUpdate)(metas, options);
201
+ } else if (metas.attr.type === 'relation') {
202
+ validator = createRelationValidator({
203
+ attr: metas.attr,
204
+ updatedAttribute: metas.updatedAttribute
205
+ });
320
206
  }
321
- return _.mergeWith(
322
- relationsStore,
323
- buildRelationsStore({
324
- uid: attribute.component,
325
- data: componentValue
326
- }),
327
- (objValue, srcValue) => {
328
- if (_.isArray(objValue)) {
329
- return objValue.concat(srcValue);
330
- }
331
- }
332
- );
333
- }, result);
207
+ validator = preventCast(validator);
334
208
  }
335
- case "dynamiczone": {
336
- return _.castArray(value).reduce((relationsStore, dzValue) => {
337
- const value2 = dzValue;
338
- if (!value2.__component) {
339
- throw new ValidationError(
340
- `Cannot build relations store from dynamiczone, component identifier is undefined`
341
- );
209
+ validator = addDefault(createOrUpdate)(validator, metas);
210
+ return validator;
211
+ };
212
+ const createModelValidator = (createOrUpdate)=>({ componentContext, model, data, entity }, options)=>{
213
+ const writableAttributes = model ? getWritableAttributes(model) : [];
214
+ const schema = writableAttributes.reduce((validators, attributeName)=>{
215
+ const metas = {
216
+ attr: model.attributes[attributeName],
217
+ updatedAttribute: {
218
+ name: attributeName,
219
+ value: fp.prop(attributeName, data)
220
+ },
221
+ data,
222
+ model,
223
+ entity,
224
+ componentContext
225
+ };
226
+ const validator = createAttributeValidator(createOrUpdate)(metas, options);
227
+ validators[attributeName] = validator;
228
+ return validators;
229
+ }, {});
230
+ return yup.object().shape(schema);
231
+ };
232
+ const createValidateEntity = (createOrUpdate)=>{
233
+ return async (model, data, options, entity)=>{
234
+ if (!fp.isObject(data)) {
235
+ const { displayName } = model.info;
236
+ throw new ValidationError(`Invalid payload submitted for the ${createOrUpdate} of an entity of type ${displayName}. Expected an object, but got ${typeof data}`);
237
+ }
238
+ const validator = createModelValidator(createOrUpdate)({
239
+ model,
240
+ data,
241
+ entity,
242
+ componentContext: {
243
+ // Set up the initial component context.
244
+ // Keeping track of parent content type context in which a component will be used.
245
+ // This is necessary to validate component field constraints such as uniqueness.
246
+ parentContent: {
247
+ id: entity?.id,
248
+ model,
249
+ options
250
+ },
251
+ pathToComponent: [],
252
+ repeatableData: []
253
+ }
254
+ }, {
255
+ isDraft: options?.isDraft ?? false,
256
+ locale: options?.locale ?? null
257
+ }).test('relations-test', 'check that all relations exist', async function relationsValidation(data) {
258
+ try {
259
+ await checkRelationsExist(buildRelationsStore({
260
+ uid: model.uid,
261
+ data
262
+ }));
263
+ } catch (e) {
264
+ return this.createError({
265
+ path: this.path,
266
+ message: e instanceof ValidationError && e.message || 'Invalid relations'
267
+ });
342
268
  }
343
- return _.mergeWith(
344
- relationsStore,
345
- buildRelationsStore({
346
- uid: value2.__component,
347
- data: value2
348
- }),
349
- (objValue, srcValue) => {
350
- if (_.isArray(objValue)) {
351
- return objValue.concat(srcValue);
269
+ return true;
270
+ }).required();
271
+ return validateYupSchema(validator, {
272
+ strict: false,
273
+ abortEarly: false
274
+ })(data);
275
+ };
276
+ };
277
+ /**
278
+ * Builds an object containing all the media and relations being associated with an entity
279
+ */ const buildRelationsStore = ({ uid, data })=>{
280
+ if (!uid) {
281
+ throw new ValidationError(`Cannot build relations store: "uid" is undefined`);
282
+ }
283
+ if (fp.isEmpty(data)) {
284
+ return {};
285
+ }
286
+ const currentModel = strapi.getModel(uid);
287
+ return Object.keys(currentModel.attributes).reduce((result, attributeName)=>{
288
+ const attribute = currentModel.attributes[attributeName];
289
+ const value = data[attributeName];
290
+ if (_.isNil(value)) {
291
+ return result;
292
+ }
293
+ switch(attribute.type){
294
+ case 'relation':
295
+ case 'media':
296
+ {
297
+ if (attribute.type === 'relation' && (attribute.relation === 'morphToMany' || attribute.relation === 'morphToOne')) {
298
+ break;
299
+ }
300
+ const target = // eslint-disable-next-line no-nested-ternary
301
+ attribute.type === 'media' ? 'plugin::upload.file' : attribute.target;
302
+ // As there are multiple formats supported for associating relations
303
+ // with an entity, the value here can be an: array, object or number.
304
+ let source;
305
+ if (Array.isArray(value)) {
306
+ source = value;
307
+ } else if (fp.isObject(value)) {
308
+ if ('connect' in value && !_.isNil(value.connect)) {
309
+ source = value.connect;
310
+ } else if ('set' in value && !_.isNil(value.set)) {
311
+ source = value.set;
312
+ } else {
313
+ source = [];
314
+ }
315
+ } else {
316
+ source = _.castArray(value);
317
+ }
318
+ const idArray = source.map((v)=>({
319
+ id: typeof v === 'object' ? v.id : v
320
+ }));
321
+ // Update the relationStore to keep track of all associations being made
322
+ // with relations and media.
323
+ result[target] = result[target] || [];
324
+ result[target].push(...idArray);
325
+ break;
326
+ }
327
+ case 'component':
328
+ {
329
+ return _.castArray(value).reduce((relationsStore, componentValue)=>{
330
+ if (!attribute.component) {
331
+ throw new ValidationError(`Cannot build relations store from component, component identifier is undefined`);
332
+ }
333
+ return _.mergeWith(relationsStore, buildRelationsStore({
334
+ uid: attribute.component,
335
+ data: componentValue
336
+ }), (objValue, srcValue)=>{
337
+ if (_.isArray(objValue)) {
338
+ return objValue.concat(srcValue);
339
+ }
340
+ });
341
+ }, result);
342
+ }
343
+ case 'dynamiczone':
344
+ {
345
+ return _.castArray(value).reduce((relationsStore, dzValue)=>{
346
+ const value = dzValue;
347
+ if (!value.__component) {
348
+ throw new ValidationError(`Cannot build relations store from dynamiczone, component identifier is undefined`);
349
+ }
350
+ return _.mergeWith(relationsStore, buildRelationsStore({
351
+ uid: value.__component,
352
+ data: value
353
+ }), (objValue, srcValue)=>{
354
+ if (_.isArray(objValue)) {
355
+ return objValue.concat(srcValue);
356
+ }
357
+ });
358
+ }, result);
352
359
  }
353
- }
354
- );
355
- }, result);
356
360
  }
357
- }
358
- return result;
359
- },
360
- {}
361
- );
361
+ return result;
362
+ }, {});
362
363
  };
363
- const checkRelationsExist = async (relationsStore = {}) => {
364
- const promises = [];
365
- for (const [key, value] of Object.entries(relationsStore)) {
366
- const evaluate = async () => {
367
- const uniqueValues = _.uniqBy(value, `id`);
368
- const count = await strapi.db.query(key).count({
369
- where: {
370
- id: {
371
- $in: uniqueValues.map((v) => v.id)
372
- }
373
- }
374
- });
375
- if (count !== uniqueValues.length) {
376
- throw new ValidationError(
377
- `${uniqueValues.length - count} relation(s) of type ${key} associated with this entity do not exist`
378
- );
379
- }
380
- };
381
- promises.push(evaluate());
382
- }
383
- return Promise.all(promises);
364
+ /**
365
+ * Iterate through the relations store and validates that every relation or media
366
+ * mentioned exists
367
+ */ const checkRelationsExist = async (relationsStore = {})=>{
368
+ const promises = [];
369
+ for (const [key, value] of Object.entries(relationsStore)){
370
+ const evaluate = async ()=>{
371
+ const uniqueValues = _.uniqBy(value, `id`);
372
+ const count = await strapi.db.query(key).count({
373
+ where: {
374
+ id: {
375
+ $in: uniqueValues.map((v)=>v.id)
376
+ }
377
+ }
378
+ });
379
+ if (count !== uniqueValues.length) {
380
+ throw new ValidationError(`${uniqueValues.length - count} relation(s) of type ${key} associated with this entity do not exist`);
381
+ }
382
+ };
383
+ promises.push(evaluate());
384
+ }
385
+ return Promise.all(promises);
384
386
  };
385
387
  const entityValidator = {
386
- validateEntityCreation: createValidateEntity("creation"),
387
- validateEntityUpdate: createValidateEntity("update")
388
+ validateEntityCreation: createValidateEntity('creation'),
389
+ validateEntityUpdate: createValidateEntity('update')
388
390
  };
391
+
389
392
  module.exports = entityValidator;
390
393
  //# sourceMappingURL=index.js.map