@strapi/core 0.0.0-experimental.c592deb623aed3f74ef7fdacfad9757ed59d34f7 → 0.0.0-experimental.c72b48da735f44a3ccafb7a6dc9ba5213f3844db

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