@strapi/core 0.0.0-experimental.a9a5a36dd73072c19eadeff5f387e8286b2a4d22 → 0.0.0-experimental.aa7a2469494b789539dfb9508d5dce9526d83b7d

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 (821) hide show
  1. package/LICENSE +18 -3
  2. package/dist/Strapi.d.ts.map +1 -1
  3. package/dist/Strapi.js +430 -403
  4. package/dist/Strapi.js.map +1 -1
  5. package/dist/Strapi.mjs +429 -402
  6. package/dist/Strapi.mjs.map +1 -1
  7. package/dist/compile.js +23 -14
  8. package/dist/compile.js.map +1 -1
  9. package/dist/compile.mjs +22 -14
  10. package/dist/compile.mjs.map +1 -1
  11. package/dist/configuration/config-loader.js +110 -97
  12. package/dist/configuration/config-loader.js.map +1 -1
  13. package/dist/configuration/config-loader.mjs +109 -96
  14. package/dist/configuration/config-loader.mjs.map +1 -1
  15. package/dist/configuration/get-dirs.js +31 -29
  16. package/dist/configuration/get-dirs.js.map +1 -1
  17. package/dist/configuration/get-dirs.mjs +30 -30
  18. package/dist/configuration/get-dirs.mjs.map +1 -1
  19. package/dist/configuration/index.d.ts +4 -0
  20. package/dist/configuration/index.d.ts.map +1 -1
  21. package/dist/configuration/index.js +88 -73
  22. package/dist/configuration/index.js.map +1 -1
  23. package/dist/configuration/index.mjs +87 -69
  24. package/dist/configuration/index.mjs.map +1 -1
  25. package/dist/configuration/urls.d.ts.map +1 -1
  26. package/dist/configuration/urls.js +74 -61
  27. package/dist/configuration/urls.js.map +1 -1
  28. package/dist/configuration/urls.mjs +73 -62
  29. package/dist/configuration/urls.mjs.map +1 -1
  30. package/dist/container.js +27 -23
  31. package/dist/container.js.map +1 -1
  32. package/dist/container.mjs +26 -24
  33. package/dist/container.mjs.map +1 -1
  34. package/dist/core-api/controller/collection-type.d.ts.map +1 -1
  35. package/dist/core-api/controller/collection-type.js +77 -76
  36. package/dist/core-api/controller/collection-type.js.map +1 -1
  37. package/dist/core-api/controller/collection-type.mjs +76 -77
  38. package/dist/core-api/controller/collection-type.mjs.map +1 -1
  39. package/dist/core-api/controller/index.d.ts.map +1 -1
  40. package/dist/core-api/controller/index.js +64 -48
  41. package/dist/core-api/controller/index.js.map +1 -1
  42. package/dist/core-api/controller/index.mjs +63 -49
  43. package/dist/core-api/controller/index.mjs.map +1 -1
  44. package/dist/core-api/controller/single-type.js +41 -40
  45. package/dist/core-api/controller/single-type.js.map +1 -1
  46. package/dist/core-api/controller/single-type.mjs +40 -41
  47. package/dist/core-api/controller/single-type.mjs.map +1 -1
  48. package/dist/core-api/controller/transform.d.ts +3 -2
  49. package/dist/core-api/controller/transform.d.ts.map +1 -1
  50. package/dist/core-api/controller/transform.js +79 -64
  51. package/dist/core-api/controller/transform.js.map +1 -1
  52. package/dist/core-api/controller/transform.mjs +78 -65
  53. package/dist/core-api/controller/transform.mjs.map +1 -1
  54. package/dist/core-api/routes/index.d.ts +4 -22
  55. package/dist/core-api/routes/index.d.ts.map +1 -1
  56. package/dist/core-api/routes/index.js +205 -61
  57. package/dist/core-api/routes/index.js.map +1 -1
  58. package/dist/core-api/routes/index.mjs +185 -62
  59. package/dist/core-api/routes/index.mjs.map +1 -1
  60. package/dist/core-api/routes/validation/attributes.d.ts +244 -0
  61. package/dist/core-api/routes/validation/attributes.d.ts.map +1 -0
  62. package/dist/core-api/routes/validation/attributes.js +560 -0
  63. package/dist/core-api/routes/validation/attributes.js.map +1 -0
  64. package/dist/core-api/routes/validation/attributes.mjs +521 -0
  65. package/dist/core-api/routes/validation/attributes.mjs.map +1 -0
  66. package/dist/core-api/routes/validation/common.d.ts +105 -0
  67. package/dist/core-api/routes/validation/common.d.ts.map +1 -0
  68. package/dist/core-api/routes/validation/common.js +116 -0
  69. package/dist/core-api/routes/validation/common.js.map +1 -0
  70. package/dist/core-api/routes/validation/common.mjs +95 -0
  71. package/dist/core-api/routes/validation/common.mjs.map +1 -0
  72. package/dist/core-api/routes/validation/component.d.ts +34 -0
  73. package/dist/core-api/routes/validation/component.d.ts.map +1 -0
  74. package/dist/core-api/routes/validation/component.js +45 -0
  75. package/dist/core-api/routes/validation/component.js.map +1 -0
  76. package/dist/core-api/routes/validation/component.mjs +43 -0
  77. package/dist/core-api/routes/validation/component.mjs.map +1 -0
  78. package/dist/core-api/routes/validation/constants.d.ts +8 -0
  79. package/dist/core-api/routes/validation/constants.d.ts.map +1 -0
  80. package/dist/core-api/routes/validation/constants.js +18 -0
  81. package/dist/core-api/routes/validation/constants.js.map +1 -0
  82. package/dist/core-api/routes/validation/constants.mjs +16 -0
  83. package/dist/core-api/routes/validation/constants.mjs.map +1 -0
  84. package/dist/core-api/routes/validation/content-type.d.ts +128 -0
  85. package/dist/core-api/routes/validation/content-type.d.ts.map +1 -0
  86. package/dist/core-api/routes/validation/content-type.js +201 -0
  87. package/dist/core-api/routes/validation/content-type.js.map +1 -0
  88. package/dist/core-api/routes/validation/content-type.mjs +180 -0
  89. package/dist/core-api/routes/validation/content-type.mjs.map +1 -0
  90. package/dist/core-api/routes/validation/index.d.ts +5 -0
  91. package/dist/core-api/routes/validation/index.d.ts.map +1 -0
  92. package/dist/core-api/routes/validation/mappers.d.ts +105 -0
  93. package/dist/core-api/routes/validation/mappers.d.ts.map +1 -0
  94. package/dist/core-api/routes/validation/mappers.js +238 -0
  95. package/dist/core-api/routes/validation/mappers.js.map +1 -0
  96. package/dist/core-api/routes/validation/mappers.mjs +214 -0
  97. package/dist/core-api/routes/validation/mappers.mjs.map +1 -0
  98. package/dist/core-api/routes/validation/utils.d.ts +47 -0
  99. package/dist/core-api/routes/validation/utils.d.ts.map +1 -0
  100. package/dist/core-api/routes/validation/utils.js +112 -0
  101. package/dist/core-api/routes/validation/utils.js.map +1 -0
  102. package/dist/core-api/routes/validation/utils.mjs +90 -0
  103. package/dist/core-api/routes/validation/utils.mjs.map +1 -0
  104. package/dist/core-api/service/collection-type.d.ts +2 -2
  105. package/dist/core-api/service/collection-type.js +73 -60
  106. package/dist/core-api/service/collection-type.js.map +1 -1
  107. package/dist/core-api/service/collection-type.mjs +72 -62
  108. package/dist/core-api/service/collection-type.mjs.map +1 -1
  109. package/dist/core-api/service/core-service.js +9 -8
  110. package/dist/core-api/service/core-service.js.map +1 -1
  111. package/dist/core-api/service/core-service.mjs +8 -9
  112. package/dist/core-api/service/core-service.mjs.map +1 -1
  113. package/dist/core-api/service/index.js +13 -13
  114. package/dist/core-api/service/index.js.map +1 -1
  115. package/dist/core-api/service/index.mjs +12 -14
  116. package/dist/core-api/service/index.mjs.map +1 -1
  117. package/dist/core-api/service/pagination.js +69 -43
  118. package/dist/core-api/service/pagination.js.map +1 -1
  119. package/dist/core-api/service/pagination.mjs +68 -47
  120. package/dist/core-api/service/pagination.mjs.map +1 -1
  121. package/dist/core-api/service/single-type.js +43 -39
  122. package/dist/core-api/service/single-type.js.map +1 -1
  123. package/dist/core-api/service/single-type.mjs +42 -41
  124. package/dist/core-api/service/single-type.mjs.map +1 -1
  125. package/dist/domain/content-type/index.js +95 -100
  126. package/dist/domain/content-type/index.js.map +1 -1
  127. package/dist/domain/content-type/index.mjs +94 -100
  128. package/dist/domain/content-type/index.mjs.map +1 -1
  129. package/dist/domain/content-type/validator.js +84 -69
  130. package/dist/domain/content-type/validator.js.map +1 -1
  131. package/dist/domain/content-type/validator.mjs +83 -68
  132. package/dist/domain/content-type/validator.mjs.map +1 -1
  133. package/dist/domain/module/index.d.ts.map +1 -1
  134. package/dist/domain/module/index.js +112 -100
  135. package/dist/domain/module/index.js.map +1 -1
  136. package/dist/domain/module/index.mjs +111 -99
  137. package/dist/domain/module/index.mjs.map +1 -1
  138. package/dist/domain/module/validation.js +25 -20
  139. package/dist/domain/module/validation.js.map +1 -1
  140. package/dist/domain/module/validation.mjs +24 -21
  141. package/dist/domain/module/validation.mjs.map +1 -1
  142. package/dist/ee/index.d.ts +7 -0
  143. package/dist/ee/index.d.ts.map +1 -1
  144. package/dist/ee/index.js +197 -132
  145. package/dist/ee/index.js.map +1 -1
  146. package/dist/ee/index.mjs +196 -134
  147. package/dist/ee/index.mjs.map +1 -1
  148. package/dist/ee/license.d.ts +3 -1
  149. package/dist/ee/license.d.ts.map +1 -1
  150. package/dist/ee/license.js +105 -75
  151. package/dist/ee/license.js.map +1 -1
  152. package/dist/ee/license.mjs +103 -76
  153. package/dist/ee/license.mjs.map +1 -1
  154. package/dist/factories.d.ts +3 -1
  155. package/dist/factories.d.ts.map +1 -1
  156. package/dist/factories.js +80 -67
  157. package/dist/factories.js.map +1 -1
  158. package/dist/factories.mjs +77 -70
  159. package/dist/factories.mjs.map +1 -1
  160. package/dist/index.d.ts +14 -0
  161. package/dist/index.d.ts.map +1 -1
  162. package/dist/index.js +29 -26
  163. package/dist/index.js.map +1 -1
  164. package/dist/index.mjs +29 -29
  165. package/dist/index.mjs.map +1 -1
  166. package/dist/loaders/admin.d.ts.map +1 -1
  167. package/dist/loaders/admin.js +21 -20
  168. package/dist/loaders/admin.js.map +1 -1
  169. package/dist/loaders/admin.mjs +20 -20
  170. package/dist/loaders/admin.mjs.map +1 -1
  171. package/dist/loaders/apis.js +143 -120
  172. package/dist/loaders/apis.js.map +1 -1
  173. package/dist/loaders/apis.mjs +142 -119
  174. package/dist/loaders/apis.mjs.map +1 -1
  175. package/dist/loaders/components.js +33 -34
  176. package/dist/loaders/components.js.map +1 -1
  177. package/dist/loaders/components.mjs +32 -34
  178. package/dist/loaders/components.mjs.map +1 -1
  179. package/dist/loaders/index.js +22 -20
  180. package/dist/loaders/index.js.map +1 -1
  181. package/dist/loaders/index.mjs +21 -21
  182. package/dist/loaders/index.mjs.map +1 -1
  183. package/dist/loaders/middlewares.js +29 -25
  184. package/dist/loaders/middlewares.js.map +1 -1
  185. package/dist/loaders/middlewares.mjs +28 -25
  186. package/dist/loaders/middlewares.mjs.map +1 -1
  187. package/dist/loaders/plugins/get-enabled-plugins.d.ts.map +1 -1
  188. package/dist/loaders/plugins/get-enabled-plugins.js +125 -102
  189. package/dist/loaders/plugins/get-enabled-plugins.js.map +1 -1
  190. package/dist/loaders/plugins/get-enabled-plugins.mjs +124 -101
  191. package/dist/loaders/plugins/get-enabled-plugins.mjs.map +1 -1
  192. package/dist/loaders/plugins/get-user-plugins-config.js +25 -24
  193. package/dist/loaders/plugins/get-user-plugins-config.js.map +1 -1
  194. package/dist/loaders/plugins/get-user-plugins-config.mjs +24 -23
  195. package/dist/loaders/plugins/get-user-plugins-config.mjs.map +1 -1
  196. package/dist/loaders/plugins/index.d.ts.map +1 -1
  197. package/dist/loaders/plugins/index.js +141 -104
  198. package/dist/loaders/plugins/index.js.map +1 -1
  199. package/dist/loaders/plugins/index.mjs +121 -104
  200. package/dist/loaders/plugins/index.mjs.map +1 -1
  201. package/dist/loaders/policies.js +24 -20
  202. package/dist/loaders/policies.js.map +1 -1
  203. package/dist/loaders/policies.mjs +23 -20
  204. package/dist/loaders/policies.mjs.map +1 -1
  205. package/dist/loaders/sanitizers.js +10 -4
  206. package/dist/loaders/sanitizers.js.map +1 -1
  207. package/dist/loaders/sanitizers.mjs +9 -6
  208. package/dist/loaders/sanitizers.mjs.map +1 -1
  209. package/dist/loaders/src-index.js +35 -27
  210. package/dist/loaders/src-index.js.map +1 -1
  211. package/dist/loaders/src-index.mjs +34 -29
  212. package/dist/loaders/src-index.mjs.map +1 -1
  213. package/dist/loaders/validators.js +9 -4
  214. package/dist/loaders/validators.js.map +1 -1
  215. package/dist/loaders/validators.mjs +8 -6
  216. package/dist/loaders/validators.mjs.map +1 -1
  217. package/dist/middlewares/body.d.ts.map +1 -1
  218. package/dist/middlewares/body.js +58 -54
  219. package/dist/middlewares/body.js.map +1 -1
  220. package/dist/middlewares/body.mjs +57 -51
  221. package/dist/middlewares/body.mjs.map +1 -1
  222. package/dist/middlewares/compression.js +6 -6
  223. package/dist/middlewares/compression.js.map +1 -1
  224. package/dist/middlewares/compression.mjs +5 -5
  225. package/dist/middlewares/compression.mjs.map +1 -1
  226. package/dist/middlewares/cors.d.ts +9 -1
  227. package/dist/middlewares/cors.d.ts.map +1 -1
  228. package/dist/middlewares/cors.js +81 -44
  229. package/dist/middlewares/cors.js.map +1 -1
  230. package/dist/middlewares/cors.mjs +78 -42
  231. package/dist/middlewares/cors.mjs.map +1 -1
  232. package/dist/middlewares/errors.js +32 -30
  233. package/dist/middlewares/errors.js.map +1 -1
  234. package/dist/middlewares/errors.mjs +31 -31
  235. package/dist/middlewares/errors.mjs.map +1 -1
  236. package/dist/middlewares/favicon.js +27 -17
  237. package/dist/middlewares/favicon.js.map +1 -1
  238. package/dist/middlewares/favicon.mjs +26 -16
  239. package/dist/middlewares/favicon.mjs.map +1 -1
  240. package/dist/middlewares/index.js +32 -30
  241. package/dist/middlewares/index.js.map +1 -1
  242. package/dist/middlewares/index.mjs +31 -31
  243. package/dist/middlewares/index.mjs.map +1 -1
  244. package/dist/middlewares/ip.js +6 -6
  245. package/dist/middlewares/ip.js.map +1 -1
  246. package/dist/middlewares/ip.mjs +5 -5
  247. package/dist/middlewares/ip.mjs.map +1 -1
  248. package/dist/middlewares/logger.js +10 -9
  249. package/dist/middlewares/logger.js.map +1 -1
  250. package/dist/middlewares/logger.mjs +9 -10
  251. package/dist/middlewares/logger.mjs.map +1 -1
  252. package/dist/middlewares/powered-by.js +13 -9
  253. package/dist/middlewares/powered-by.js.map +1 -1
  254. package/dist/middlewares/powered-by.mjs +12 -10
  255. package/dist/middlewares/powered-by.mjs.map +1 -1
  256. package/dist/middlewares/public.js +33 -29
  257. package/dist/middlewares/public.js.map +1 -1
  258. package/dist/middlewares/public.mjs +32 -28
  259. package/dist/middlewares/public.mjs.map +1 -1
  260. package/dist/middlewares/query.d.ts.map +1 -1
  261. package/dist/middlewares/query.js +35 -32
  262. package/dist/middlewares/query.js.map +1 -1
  263. package/dist/middlewares/query.mjs +34 -31
  264. package/dist/middlewares/query.mjs.map +1 -1
  265. package/dist/middlewares/response-time.js +10 -9
  266. package/dist/middlewares/response-time.js.map +1 -1
  267. package/dist/middlewares/response-time.mjs +9 -10
  268. package/dist/middlewares/response-time.mjs.map +1 -1
  269. package/dist/middlewares/responses.js +14 -12
  270. package/dist/middlewares/responses.js.map +1 -1
  271. package/dist/middlewares/responses.mjs +13 -13
  272. package/dist/middlewares/responses.mjs.map +1 -1
  273. package/dist/middlewares/security.d.ts.map +1 -1
  274. package/dist/middlewares/security.js +109 -71
  275. package/dist/middlewares/security.js.map +1 -1
  276. package/dist/middlewares/security.mjs +108 -70
  277. package/dist/middlewares/security.mjs.map +1 -1
  278. package/dist/middlewares/session.js +26 -25
  279. package/dist/middlewares/session.js.map +1 -1
  280. package/dist/middlewares/session.mjs +25 -24
  281. package/dist/middlewares/session.mjs.map +1 -1
  282. package/dist/migrations/database/5.0.0-discard-drafts.d.ts +14 -11
  283. package/dist/migrations/database/5.0.0-discard-drafts.d.ts.map +1 -1
  284. package/dist/migrations/database/5.0.0-discard-drafts.js +153 -35
  285. package/dist/migrations/database/5.0.0-discard-drafts.js.map +1 -1
  286. package/dist/migrations/database/5.0.0-discard-drafts.mjs +152 -37
  287. package/dist/migrations/database/5.0.0-discard-drafts.mjs.map +1 -1
  288. package/dist/migrations/draft-publish.d.ts +2 -2
  289. package/dist/migrations/draft-publish.d.ts.map +1 -1
  290. package/dist/migrations/draft-publish.js +61 -34
  291. package/dist/migrations/draft-publish.js.map +1 -1
  292. package/dist/migrations/draft-publish.mjs +60 -36
  293. package/dist/migrations/draft-publish.mjs.map +1 -1
  294. package/dist/migrations/i18n.d.ts +5 -0
  295. package/dist/migrations/i18n.d.ts.map +1 -0
  296. package/dist/migrations/i18n.js +71 -0
  297. package/dist/migrations/i18n.js.map +1 -0
  298. package/dist/migrations/i18n.mjs +68 -0
  299. package/dist/migrations/i18n.mjs.map +1 -0
  300. package/dist/migrations/index.d.ts +5 -0
  301. package/dist/migrations/index.d.ts.map +1 -0
  302. package/dist/migrations/index.js +29 -0
  303. package/dist/migrations/index.js.map +1 -0
  304. package/dist/migrations/index.mjs +26 -0
  305. package/dist/migrations/index.mjs.map +1 -0
  306. package/dist/package.json.js +186 -0
  307. package/dist/package.json.js.map +1 -0
  308. package/dist/package.json.mjs +163 -0
  309. package/dist/package.json.mjs.map +1 -0
  310. package/dist/providers/admin.d.ts.map +1 -1
  311. package/dist/providers/admin.js +27 -17
  312. package/dist/providers/admin.js.map +1 -1
  313. package/dist/providers/admin.mjs +26 -19
  314. package/dist/providers/admin.mjs.map +1 -1
  315. package/dist/providers/coreStore.js +13 -8
  316. package/dist/providers/coreStore.js.map +1 -1
  317. package/dist/providers/coreStore.mjs +12 -10
  318. package/dist/providers/coreStore.mjs.map +1 -1
  319. package/dist/providers/cron.js +19 -16
  320. package/dist/providers/cron.js.map +1 -1
  321. package/dist/providers/cron.mjs +18 -18
  322. package/dist/providers/cron.mjs.map +1 -1
  323. package/dist/providers/index.js +18 -9
  324. package/dist/providers/index.js.map +1 -1
  325. package/dist/providers/index.mjs +17 -10
  326. package/dist/providers/index.mjs.map +1 -1
  327. package/dist/providers/provider.js +4 -3
  328. package/dist/providers/provider.js.map +1 -1
  329. package/dist/providers/provider.mjs +3 -4
  330. package/dist/providers/provider.mjs.map +1 -1
  331. package/dist/providers/registries.js +37 -32
  332. package/dist/providers/registries.js.map +1 -1
  333. package/dist/providers/registries.mjs +36 -34
  334. package/dist/providers/registries.mjs.map +1 -1
  335. package/dist/providers/telemetry.js +19 -16
  336. package/dist/providers/telemetry.js.map +1 -1
  337. package/dist/providers/telemetry.mjs +18 -18
  338. package/dist/providers/telemetry.mjs.map +1 -1
  339. package/dist/providers/webhooks.js +28 -26
  340. package/dist/providers/webhooks.js.map +1 -1
  341. package/dist/providers/webhooks.mjs +27 -28
  342. package/dist/providers/webhooks.mjs.map +1 -1
  343. package/dist/registries/apis.js +23 -20
  344. package/dist/registries/apis.js.map +1 -1
  345. package/dist/registries/apis.mjs +22 -22
  346. package/dist/registries/apis.mjs.map +1 -1
  347. package/dist/registries/components.js +35 -37
  348. package/dist/registries/components.js.map +1 -1
  349. package/dist/registries/components.mjs +34 -39
  350. package/dist/registries/components.mjs.map +1 -1
  351. package/dist/registries/content-types.js +54 -59
  352. package/dist/registries/content-types.js.map +1 -1
  353. package/dist/registries/content-types.mjs +53 -61
  354. package/dist/registries/content-types.mjs.map +1 -1
  355. package/dist/registries/controllers.js +70 -71
  356. package/dist/registries/controllers.js.map +1 -1
  357. package/dist/registries/controllers.mjs +69 -73
  358. package/dist/registries/controllers.mjs.map +1 -1
  359. package/dist/registries/custom-fields.js +75 -65
  360. package/dist/registries/custom-fields.js.map +1 -1
  361. package/dist/registries/custom-fields.mjs +74 -67
  362. package/dist/registries/custom-fields.mjs.map +1 -1
  363. package/dist/registries/hooks.js +46 -49
  364. package/dist/registries/hooks.js.map +1 -1
  365. package/dist/registries/hooks.mjs +45 -51
  366. package/dist/registries/hooks.mjs.map +1 -1
  367. package/dist/registries/middlewares.js +49 -51
  368. package/dist/registries/middlewares.js.map +1 -1
  369. package/dist/registries/middlewares.mjs +48 -53
  370. package/dist/registries/middlewares.mjs.map +1 -1
  371. package/dist/registries/models.js +14 -13
  372. package/dist/registries/models.js.map +1 -1
  373. package/dist/registries/models.mjs +13 -14
  374. package/dist/registries/models.mjs.map +1 -1
  375. package/dist/registries/modules.js +39 -36
  376. package/dist/registries/modules.js.map +1 -1
  377. package/dist/registries/modules.mjs +38 -38
  378. package/dist/registries/modules.mjs.map +1 -1
  379. package/dist/registries/namespace.js +21 -20
  380. package/dist/registries/namespace.js.map +1 -1
  381. package/dist/registries/namespace.mjs +20 -23
  382. package/dist/registries/namespace.mjs.map +1 -1
  383. package/dist/registries/plugins.js +23 -20
  384. package/dist/registries/plugins.js.map +1 -1
  385. package/dist/registries/plugins.mjs +22 -22
  386. package/dist/registries/plugins.mjs.map +1 -1
  387. package/dist/registries/policies.d.ts +1 -1
  388. package/dist/registries/policies.d.ts.map +1 -1
  389. package/dist/registries/policies.js +103 -96
  390. package/dist/registries/policies.js.map +1 -1
  391. package/dist/registries/policies.mjs +102 -98
  392. package/dist/registries/policies.mjs.map +1 -1
  393. package/dist/registries/sanitizers.js +23 -22
  394. package/dist/registries/sanitizers.js.map +1 -1
  395. package/dist/registries/sanitizers.mjs +22 -22
  396. package/dist/registries/sanitizers.mjs.map +1 -1
  397. package/dist/registries/services.js +71 -71
  398. package/dist/registries/services.js.map +1 -1
  399. package/dist/registries/services.mjs +70 -73
  400. package/dist/registries/services.mjs.map +1 -1
  401. package/dist/registries/validators.js +23 -22
  402. package/dist/registries/validators.js.map +1 -1
  403. package/dist/registries/validators.mjs +22 -22
  404. package/dist/registries/validators.mjs.map +1 -1
  405. package/dist/services/auth/index.js +74 -74
  406. package/dist/services/auth/index.js.map +1 -1
  407. package/dist/services/auth/index.mjs +73 -74
  408. package/dist/services/auth/index.mjs.map +1 -1
  409. package/dist/services/config.js +47 -43
  410. package/dist/services/config.js.map +1 -1
  411. package/dist/services/config.mjs +46 -44
  412. package/dist/services/config.mjs.map +1 -1
  413. package/dist/services/content-api/index.d.ts +10 -12
  414. package/dist/services/content-api/index.d.ts.map +1 -1
  415. package/dist/services/content-api/index.js +80 -79
  416. package/dist/services/content-api/index.js.map +1 -1
  417. package/dist/services/content-api/index.mjs +79 -79
  418. package/dist/services/content-api/index.mjs.map +1 -1
  419. package/dist/services/content-api/permissions/engine.js +8 -5
  420. package/dist/services/content-api/permissions/engine.js.map +1 -1
  421. package/dist/services/content-api/permissions/engine.mjs +7 -5
  422. package/dist/services/content-api/permissions/engine.mjs.map +1 -1
  423. package/dist/services/content-api/permissions/index.d.ts +10 -12
  424. package/dist/services/content-api/permissions/index.d.ts.map +1 -1
  425. package/dist/services/content-api/permissions/index.js +101 -81
  426. package/dist/services/content-api/permissions/index.js.map +1 -1
  427. package/dist/services/content-api/permissions/index.mjs +100 -81
  428. package/dist/services/content-api/permissions/index.mjs.map +1 -1
  429. package/dist/services/content-api/permissions/providers/action.d.ts +5 -6
  430. package/dist/services/content-api/permissions/providers/action.d.ts.map +1 -1
  431. package/dist/services/content-api/permissions/providers/action.js +17 -14
  432. package/dist/services/content-api/permissions/providers/action.js.map +1 -1
  433. package/dist/services/content-api/permissions/providers/action.mjs +16 -16
  434. package/dist/services/content-api/permissions/providers/action.mjs.map +1 -1
  435. package/dist/services/content-api/permissions/providers/condition.d.ts +5 -6
  436. package/dist/services/content-api/permissions/providers/condition.d.ts.map +1 -1
  437. package/dist/services/content-api/permissions/providers/condition.js +17 -14
  438. package/dist/services/content-api/permissions/providers/condition.js.map +1 -1
  439. package/dist/services/content-api/permissions/providers/condition.mjs +16 -16
  440. package/dist/services/content-api/permissions/providers/condition.mjs.map +1 -1
  441. package/dist/services/content-source-maps.d.ts +8 -0
  442. package/dist/services/content-source-maps.d.ts.map +1 -0
  443. package/dist/services/content-source-maps.js +119 -0
  444. package/dist/services/content-source-maps.js.map +1 -0
  445. package/dist/services/content-source-maps.mjs +117 -0
  446. package/dist/services/content-source-maps.mjs.map +1 -0
  447. package/dist/services/core-store.d.ts +2 -2
  448. package/dist/services/core-store.d.ts.map +1 -1
  449. package/dist/services/core-store.js +115 -95
  450. package/dist/services/core-store.js.map +1 -1
  451. package/dist/services/core-store.mjs +114 -97
  452. package/dist/services/core-store.mjs.map +1 -1
  453. package/dist/services/cron.d.ts +3 -3
  454. package/dist/services/cron.d.ts.map +1 -1
  455. package/dist/services/cron.js +74 -60
  456. package/dist/services/cron.js.map +1 -1
  457. package/dist/services/cron.mjs +73 -62
  458. package/dist/services/cron.mjs.map +1 -1
  459. package/dist/services/custom-fields.js +9 -7
  460. package/dist/services/custom-fields.js.map +1 -1
  461. package/dist/services/custom-fields.mjs +8 -9
  462. package/dist/services/custom-fields.mjs.map +1 -1
  463. package/dist/services/document-service/attributes/index.js +23 -18
  464. package/dist/services/document-service/attributes/index.js.map +1 -1
  465. package/dist/services/document-service/attributes/index.mjs +22 -19
  466. package/dist/services/document-service/attributes/index.mjs.map +1 -1
  467. package/dist/services/document-service/attributes/transforms.js +16 -15
  468. package/dist/services/document-service/attributes/transforms.js.map +1 -1
  469. package/dist/services/document-service/attributes/transforms.mjs +15 -15
  470. package/dist/services/document-service/attributes/transforms.mjs.map +1 -1
  471. package/dist/services/document-service/common.d.ts +1 -1
  472. package/dist/services/document-service/common.d.ts.map +1 -1
  473. package/dist/services/document-service/common.js +5 -4
  474. package/dist/services/document-service/common.js.map +1 -1
  475. package/dist/services/document-service/common.mjs +4 -5
  476. package/dist/services/document-service/common.mjs.map +1 -1
  477. package/dist/services/document-service/components.d.ts.map +1 -1
  478. package/dist/services/document-service/components.js +255 -257
  479. package/dist/services/document-service/components.js.map +1 -1
  480. package/dist/services/document-service/components.mjs +254 -262
  481. package/dist/services/document-service/components.mjs.map +1 -1
  482. package/dist/services/document-service/draft-and-publish.d.ts +1 -1
  483. package/dist/services/document-service/draft-and-publish.d.ts.map +1 -1
  484. package/dist/services/document-service/draft-and-publish.js +88 -48
  485. package/dist/services/document-service/draft-and-publish.js.map +1 -1
  486. package/dist/services/document-service/draft-and-publish.mjs +87 -54
  487. package/dist/services/document-service/draft-and-publish.mjs.map +1 -1
  488. package/dist/services/document-service/entries.d.ts +2 -2
  489. package/dist/services/document-service/entries.d.ts.map +1 -1
  490. package/dist/services/document-service/entries.js +151 -92
  491. package/dist/services/document-service/entries.js.map +1 -1
  492. package/dist/services/document-service/entries.mjs +150 -93
  493. package/dist/services/document-service/entries.mjs.map +1 -1
  494. package/dist/services/document-service/events.d.ts +1 -1
  495. package/dist/services/document-service/events.d.ts.map +1 -1
  496. package/dist/services/document-service/events.js +52 -40
  497. package/dist/services/document-service/events.js.map +1 -1
  498. package/dist/services/document-service/events.mjs +51 -41
  499. package/dist/services/document-service/events.mjs.map +1 -1
  500. package/dist/services/document-service/index.d.ts +2 -1
  501. package/dist/services/document-service/index.d.ts.map +1 -1
  502. package/dist/services/document-service/index.js +53 -32
  503. package/dist/services/document-service/index.js.map +1 -1
  504. package/dist/services/document-service/index.mjs +52 -33
  505. package/dist/services/document-service/index.mjs.map +1 -1
  506. package/dist/services/document-service/internationalization.d.ts +6 -1
  507. package/dist/services/document-service/internationalization.d.ts.map +1 -1
  508. package/dist/services/document-service/internationalization.js +94 -46
  509. package/dist/services/document-service/internationalization.js.map +1 -1
  510. package/dist/services/document-service/internationalization.mjs +92 -50
  511. package/dist/services/document-service/internationalization.mjs.map +1 -1
  512. package/dist/services/document-service/middlewares/errors.js +23 -19
  513. package/dist/services/document-service/middlewares/errors.js.map +1 -1
  514. package/dist/services/document-service/middlewares/errors.mjs +22 -20
  515. package/dist/services/document-service/middlewares/errors.mjs.map +1 -1
  516. package/dist/services/document-service/middlewares/middleware-manager.js +46 -44
  517. package/dist/services/document-service/middlewares/middleware-manager.js.map +1 -1
  518. package/dist/services/document-service/middlewares/middleware-manager.mjs +45 -45
  519. package/dist/services/document-service/middlewares/middleware-manager.mjs.map +1 -1
  520. package/dist/services/document-service/params.js +11 -5
  521. package/dist/services/document-service/params.js.map +1 -1
  522. package/dist/services/document-service/params.mjs +10 -6
  523. package/dist/services/document-service/params.mjs.map +1 -1
  524. package/dist/services/document-service/repository.d.ts.map +1 -1
  525. package/dist/services/document-service/repository.js +356 -269
  526. package/dist/services/document-service/repository.js.map +1 -1
  527. package/dist/services/document-service/repository.mjs +355 -270
  528. package/dist/services/document-service/repository.mjs.map +1 -1
  529. package/dist/services/document-service/transform/data.js +22 -12
  530. package/dist/services/document-service/transform/data.js.map +1 -1
  531. package/dist/services/document-service/transform/data.mjs +21 -13
  532. package/dist/services/document-service/transform/data.mjs.map +1 -1
  533. package/dist/services/document-service/transform/fields.js +26 -17
  534. package/dist/services/document-service/transform/fields.js.map +1 -1
  535. package/dist/services/document-service/transform/fields.mjs +25 -18
  536. package/dist/services/document-service/transform/fields.mjs.map +1 -1
  537. package/dist/services/document-service/transform/id-map.d.ts +1 -1
  538. package/dist/services/document-service/transform/id-map.d.ts.map +1 -1
  539. package/dist/services/document-service/transform/id-map.js +116 -69
  540. package/dist/services/document-service/transform/id-map.js.map +1 -1
  541. package/dist/services/document-service/transform/id-map.mjs +115 -70
  542. package/dist/services/document-service/transform/id-map.mjs.map +1 -1
  543. package/dist/services/document-service/transform/id-transform.d.ts +1 -1
  544. package/dist/services/document-service/transform/id-transform.d.ts.map +1 -1
  545. package/dist/services/document-service/transform/id-transform.js +37 -29
  546. package/dist/services/document-service/transform/id-transform.js.map +1 -1
  547. package/dist/services/document-service/transform/id-transform.mjs +36 -30
  548. package/dist/services/document-service/transform/id-transform.mjs.map +1 -1
  549. package/dist/services/document-service/transform/populate.js +23 -18
  550. package/dist/services/document-service/transform/populate.js.map +1 -1
  551. package/dist/services/document-service/transform/populate.mjs +22 -19
  552. package/dist/services/document-service/transform/populate.mjs.map +1 -1
  553. package/dist/services/document-service/transform/query.js +11 -6
  554. package/dist/services/document-service/transform/query.js.map +1 -1
  555. package/dist/services/document-service/transform/query.mjs +10 -7
  556. package/dist/services/document-service/transform/query.mjs.map +1 -1
  557. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts +1 -1
  558. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts.map +1 -1
  559. package/dist/services/document-service/transform/relations/extract/data-ids.js +71 -48
  560. package/dist/services/document-service/transform/relations/extract/data-ids.js.map +1 -1
  561. package/dist/services/document-service/transform/relations/extract/data-ids.mjs +70 -49
  562. package/dist/services/document-service/transform/relations/extract/data-ids.mjs.map +1 -1
  563. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts.map +1 -1
  564. package/dist/services/document-service/transform/relations/transform/data-ids.js +97 -63
  565. package/dist/services/document-service/transform/relations/transform/data-ids.js.map +1 -1
  566. package/dist/services/document-service/transform/relations/transform/data-ids.mjs +96 -64
  567. package/dist/services/document-service/transform/relations/transform/data-ids.mjs.map +1 -1
  568. package/dist/services/document-service/transform/relations/transform/default-locale.js +47 -29
  569. package/dist/services/document-service/transform/relations/transform/default-locale.js.map +1 -1
  570. package/dist/services/document-service/transform/relations/transform/default-locale.mjs +46 -30
  571. package/dist/services/document-service/transform/relations/transform/default-locale.mjs.map +1 -1
  572. package/dist/services/document-service/transform/relations/utils/dp.d.ts +1 -1
  573. package/dist/services/document-service/transform/relations/utils/dp.d.ts.map +1 -1
  574. package/dist/services/document-service/transform/relations/utils/dp.js +52 -26
  575. package/dist/services/document-service/transform/relations/utils/dp.js.map +1 -1
  576. package/dist/services/document-service/transform/relations/utils/dp.mjs +51 -27
  577. package/dist/services/document-service/transform/relations/utils/dp.mjs.map +1 -1
  578. package/dist/services/document-service/transform/relations/utils/i18n.d.ts +1 -1
  579. package/dist/services/document-service/transform/relations/utils/i18n.d.ts.map +1 -1
  580. package/dist/services/document-service/transform/relations/utils/i18n.js +20 -18
  581. package/dist/services/document-service/transform/relations/utils/i18n.js.map +1 -1
  582. package/dist/services/document-service/transform/relations/utils/i18n.mjs +19 -21
  583. package/dist/services/document-service/transform/relations/utils/i18n.mjs.map +1 -1
  584. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts.map +1 -1
  585. package/dist/services/document-service/transform/relations/utils/map-relation.js +116 -77
  586. package/dist/services/document-service/transform/relations/utils/map-relation.js.map +1 -1
  587. package/dist/services/document-service/transform/relations/utils/map-relation.mjs +115 -79
  588. package/dist/services/document-service/transform/relations/utils/map-relation.mjs.map +1 -1
  589. package/dist/services/document-service/utils/bidirectional-relations.d.ts +95 -0
  590. package/dist/services/document-service/utils/bidirectional-relations.d.ts.map +1 -0
  591. package/dist/services/document-service/utils/bidirectional-relations.js +148 -0
  592. package/dist/services/document-service/utils/bidirectional-relations.js.map +1 -0
  593. package/dist/services/document-service/utils/bidirectional-relations.mjs +145 -0
  594. package/dist/services/document-service/utils/bidirectional-relations.mjs.map +1 -0
  595. package/dist/services/document-service/utils/populate.d.ts +1 -1
  596. package/dist/services/document-service/utils/populate.d.ts.map +1 -1
  597. package/dist/services/document-service/utils/populate.js +67 -41
  598. package/dist/services/document-service/utils/populate.js.map +1 -1
  599. package/dist/services/document-service/utils/populate.mjs +66 -42
  600. package/dist/services/document-service/utils/populate.mjs.map +1 -1
  601. package/dist/services/document-service/utils/unidirectional-relations.d.ts +36 -0
  602. package/dist/services/document-service/utils/unidirectional-relations.d.ts.map +1 -0
  603. package/dist/services/document-service/utils/unidirectional-relations.js +116 -0
  604. package/dist/services/document-service/utils/unidirectional-relations.js.map +1 -0
  605. package/dist/services/document-service/utils/unidirectional-relations.mjs +113 -0
  606. package/dist/services/document-service/utils/unidirectional-relations.mjs.map +1 -0
  607. package/dist/services/entity-service/index.js +230 -161
  608. package/dist/services/entity-service/index.js.map +1 -1
  609. package/dist/services/entity-service/index.mjs +229 -160
  610. package/dist/services/entity-service/index.mjs.map +1 -1
  611. package/dist/services/entity-validator/blocks-validator.d.ts +1 -2
  612. package/dist/services/entity-validator/blocks-validator.d.ts.map +1 -1
  613. package/dist/services/entity-validator/blocks-validator.js +137 -104
  614. package/dist/services/entity-validator/blocks-validator.js.map +1 -1
  615. package/dist/services/entity-validator/blocks-validator.mjs +135 -105
  616. package/dist/services/entity-validator/blocks-validator.mjs.map +1 -1
  617. package/dist/services/entity-validator/index.d.ts +2 -1
  618. package/dist/services/entity-validator/index.d.ts.map +1 -1
  619. package/dist/services/entity-validator/index.js +370 -367
  620. package/dist/services/entity-validator/index.js.map +1 -1
  621. package/dist/services/entity-validator/index.mjs +366 -364
  622. package/dist/services/entity-validator/index.mjs.map +1 -1
  623. package/dist/services/entity-validator/validators.d.ts +33 -23
  624. package/dist/services/entity-validator/validators.d.ts.map +1 -1
  625. package/dist/services/entity-validator/validators.js +285 -150
  626. package/dist/services/entity-validator/validators.js.map +1 -1
  627. package/dist/services/entity-validator/validators.mjs +276 -149
  628. package/dist/services/entity-validator/validators.mjs.map +1 -1
  629. package/dist/services/errors.js +65 -65
  630. package/dist/services/errors.js.map +1 -1
  631. package/dist/services/errors.mjs +64 -66
  632. package/dist/services/errors.mjs.map +1 -1
  633. package/dist/services/event-hub.js +82 -69
  634. package/dist/services/event-hub.js.map +1 -1
  635. package/dist/services/event-hub.mjs +81 -71
  636. package/dist/services/event-hub.mjs.map +1 -1
  637. package/dist/services/features.js +19 -14
  638. package/dist/services/features.js.map +1 -1
  639. package/dist/services/features.mjs +18 -15
  640. package/dist/services/features.mjs.map +1 -1
  641. package/dist/services/fs.js +41 -40
  642. package/dist/services/fs.js.map +1 -1
  643. package/dist/services/fs.mjs +40 -39
  644. package/dist/services/fs.mjs.map +1 -1
  645. package/dist/services/metrics/admin-user-hash.d.ts.map +1 -1
  646. package/dist/services/metrics/admin-user-hash.js +13 -11
  647. package/dist/services/metrics/admin-user-hash.js.map +1 -1
  648. package/dist/services/metrics/admin-user-hash.mjs +12 -10
  649. package/dist/services/metrics/admin-user-hash.mjs.map +1 -1
  650. package/dist/services/metrics/index.d.ts +1 -1
  651. package/dist/services/metrics/index.d.ts.map +1 -1
  652. package/dist/services/metrics/index.js +47 -40
  653. package/dist/services/metrics/index.js.map +1 -1
  654. package/dist/services/metrics/index.mjs +46 -42
  655. package/dist/services/metrics/index.mjs.map +1 -1
  656. package/dist/services/metrics/is-truthy.js +13 -6
  657. package/dist/services/metrics/is-truthy.js.map +1 -1
  658. package/dist/services/metrics/is-truthy.mjs +12 -6
  659. package/dist/services/metrics/is-truthy.mjs.map +1 -1
  660. package/dist/services/metrics/middleware.d.ts.map +1 -1
  661. package/dist/services/metrics/middleware.js +37 -22
  662. package/dist/services/metrics/middleware.js.map +1 -1
  663. package/dist/services/metrics/middleware.mjs +36 -24
  664. package/dist/services/metrics/middleware.mjs.map +1 -1
  665. package/dist/services/metrics/rate-limiter.d.ts.map +1 -1
  666. package/dist/services/metrics/rate-limiter.js +24 -19
  667. package/dist/services/metrics/rate-limiter.js.map +1 -1
  668. package/dist/services/metrics/rate-limiter.mjs +23 -21
  669. package/dist/services/metrics/rate-limiter.mjs.map +1 -1
  670. package/dist/services/metrics/sender.d.ts.map +1 -1
  671. package/dist/services/metrics/sender.js +78 -69
  672. package/dist/services/metrics/sender.js.map +1 -1
  673. package/dist/services/metrics/sender.mjs +77 -64
  674. package/dist/services/metrics/sender.mjs.map +1 -1
  675. package/dist/services/query-params.js +13 -10
  676. package/dist/services/query-params.js.map +1 -1
  677. package/dist/services/query-params.mjs +12 -12
  678. package/dist/services/query-params.mjs.map +1 -1
  679. package/dist/services/reloader.js +35 -32
  680. package/dist/services/reloader.js.map +1 -1
  681. package/dist/services/reloader.mjs +34 -33
  682. package/dist/services/reloader.mjs.map +1 -1
  683. package/dist/services/request-context.js +11 -8
  684. package/dist/services/request-context.js.map +1 -1
  685. package/dist/services/request-context.mjs +10 -10
  686. package/dist/services/request-context.mjs.map +1 -1
  687. package/dist/services/server/admin-api.js +11 -10
  688. package/dist/services/server/admin-api.js.map +1 -1
  689. package/dist/services/server/admin-api.mjs +10 -11
  690. package/dist/services/server/admin-api.mjs.map +1 -1
  691. package/dist/services/server/api.js +33 -27
  692. package/dist/services/server/api.js.map +1 -1
  693. package/dist/services/server/api.mjs +32 -26
  694. package/dist/services/server/api.mjs.map +1 -1
  695. package/dist/services/server/compose-endpoint.js +116 -105
  696. package/dist/services/server/compose-endpoint.js.map +1 -1
  697. package/dist/services/server/compose-endpoint.mjs +115 -105
  698. package/dist/services/server/compose-endpoint.mjs.map +1 -1
  699. package/dist/services/server/content-api.js +11 -9
  700. package/dist/services/server/content-api.js.map +1 -1
  701. package/dist/services/server/content-api.mjs +10 -10
  702. package/dist/services/server/content-api.mjs.map +1 -1
  703. package/dist/services/server/http-server.js +48 -44
  704. package/dist/services/server/http-server.js.map +1 -1
  705. package/dist/services/server/http-server.mjs +47 -43
  706. package/dist/services/server/http-server.mjs.map +1 -1
  707. package/dist/services/server/index.js +85 -82
  708. package/dist/services/server/index.js.map +1 -1
  709. package/dist/services/server/index.mjs +84 -81
  710. package/dist/services/server/index.mjs.map +1 -1
  711. package/dist/services/server/koa.js +49 -47
  712. package/dist/services/server/koa.js.map +1 -1
  713. package/dist/services/server/koa.mjs +48 -44
  714. package/dist/services/server/koa.mjs.map +1 -1
  715. package/dist/services/server/middleware.js +86 -82
  716. package/dist/services/server/middleware.js.map +1 -1
  717. package/dist/services/server/middleware.mjs +85 -82
  718. package/dist/services/server/middleware.mjs.map +1 -1
  719. package/dist/services/server/policy.js +24 -17
  720. package/dist/services/server/policy.js.map +1 -1
  721. package/dist/services/server/policy.mjs +23 -18
  722. package/dist/services/server/policy.mjs.map +1 -1
  723. package/dist/services/server/register-middlewares.js +68 -61
  724. package/dist/services/server/register-middlewares.js.map +1 -1
  725. package/dist/services/server/register-middlewares.mjs +67 -63
  726. package/dist/services/server/register-middlewares.mjs.map +1 -1
  727. package/dist/services/server/register-routes.js +109 -66
  728. package/dist/services/server/register-routes.js.map +1 -1
  729. package/dist/services/server/register-routes.mjs +108 -66
  730. package/dist/services/server/register-routes.mjs.map +1 -1
  731. package/dist/services/server/routing.d.ts +10 -0
  732. package/dist/services/server/routing.d.ts.map +1 -1
  733. package/dist/services/server/routing.js +100 -81
  734. package/dist/services/server/routing.js.map +1 -1
  735. package/dist/services/server/routing.mjs +99 -81
  736. package/dist/services/server/routing.mjs.map +1 -1
  737. package/dist/services/utils/conditional-fields.d.ts +3 -0
  738. package/dist/services/utils/conditional-fields.d.ts.map +1 -0
  739. package/dist/services/utils/conditional-fields.js +22 -0
  740. package/dist/services/utils/conditional-fields.js.map +1 -0
  741. package/dist/services/utils/conditional-fields.mjs +20 -0
  742. package/dist/services/utils/conditional-fields.mjs.map +1 -0
  743. package/dist/services/utils/dynamic-zones.js +13 -14
  744. package/dist/services/utils/dynamic-zones.js.map +1 -1
  745. package/dist/services/utils/dynamic-zones.mjs +12 -16
  746. package/dist/services/utils/dynamic-zones.mjs.map +1 -1
  747. package/dist/services/webhook-runner.js +124 -122
  748. package/dist/services/webhook-runner.js.map +1 -1
  749. package/dist/services/webhook-runner.mjs +123 -121
  750. package/dist/services/webhook-runner.mjs.map +1 -1
  751. package/dist/services/webhook-store.js +132 -99
  752. package/dist/services/webhook-store.js.map +1 -1
  753. package/dist/services/webhook-store.mjs +131 -101
  754. package/dist/services/webhook-store.mjs.map +1 -1
  755. package/dist/services/worker-queue.js +44 -49
  756. package/dist/services/worker-queue.js.map +1 -1
  757. package/dist/services/worker-queue.mjs +43 -49
  758. package/dist/services/worker-queue.mjs.map +1 -1
  759. package/dist/utils/convert-custom-field-type.js +17 -20
  760. package/dist/utils/convert-custom-field-type.js.map +1 -1
  761. package/dist/utils/convert-custom-field-type.mjs +16 -21
  762. package/dist/utils/convert-custom-field-type.mjs.map +1 -1
  763. package/dist/utils/cron.js +64 -30
  764. package/dist/utils/cron.js.map +1 -1
  765. package/dist/utils/cron.mjs +63 -31
  766. package/dist/utils/cron.mjs.map +1 -1
  767. package/dist/utils/fetch.d.ts +5 -1
  768. package/dist/utils/fetch.d.ts.map +1 -1
  769. package/dist/utils/fetch.js +28 -18
  770. package/dist/utils/fetch.js.map +1 -1
  771. package/dist/utils/fetch.mjs +27 -19
  772. package/dist/utils/fetch.mjs.map +1 -1
  773. package/dist/utils/filepath-to-prop-path.js +20 -28
  774. package/dist/utils/filepath-to-prop-path.js.map +1 -1
  775. package/dist/utils/filepath-to-prop-path.mjs +19 -26
  776. package/dist/utils/filepath-to-prop-path.mjs.map +1 -1
  777. package/dist/utils/is-initialized.js +21 -12
  778. package/dist/utils/is-initialized.js.map +1 -1
  779. package/dist/utils/is-initialized.mjs +20 -13
  780. package/dist/utils/is-initialized.mjs.map +1 -1
  781. package/dist/utils/lifecycles.js +6 -5
  782. package/dist/utils/lifecycles.js.map +1 -1
  783. package/dist/utils/lifecycles.mjs +5 -6
  784. package/dist/utils/lifecycles.mjs.map +1 -1
  785. package/dist/utils/load-config-file.js +40 -38
  786. package/dist/utils/load-config-file.js.map +1 -1
  787. package/dist/utils/load-config-file.mjs +39 -36
  788. package/dist/utils/load-config-file.mjs.map +1 -1
  789. package/dist/utils/load-files.js +40 -35
  790. package/dist/utils/load-files.js.map +1 -1
  791. package/dist/utils/load-files.mjs +39 -32
  792. package/dist/utils/load-files.mjs.map +1 -1
  793. package/dist/utils/open-browser.js +8 -8
  794. package/dist/utils/open-browser.js.map +1 -1
  795. package/dist/utils/open-browser.mjs +7 -7
  796. package/dist/utils/open-browser.mjs.map +1 -1
  797. package/dist/utils/resolve-working-dirs.js +23 -10
  798. package/dist/utils/resolve-working-dirs.js.map +1 -1
  799. package/dist/utils/resolve-working-dirs.mjs +22 -9
  800. package/dist/utils/resolve-working-dirs.mjs.map +1 -1
  801. package/dist/utils/signals.js +20 -14
  802. package/dist/utils/signals.js.map +1 -1
  803. package/dist/utils/signals.mjs +19 -15
  804. package/dist/utils/signals.mjs.map +1 -1
  805. package/dist/utils/startup-logger.d.ts.map +1 -1
  806. package/dist/utils/startup-logger.js +107 -78
  807. package/dist/utils/startup-logger.js.map +1 -1
  808. package/dist/utils/startup-logger.mjs +106 -75
  809. package/dist/utils/startup-logger.mjs.map +1 -1
  810. package/dist/utils/transform-content-types-to-models.d.ts +552 -23
  811. package/dist/utils/transform-content-types-to-models.d.ts.map +1 -1
  812. package/dist/utils/transform-content-types-to-models.js +350 -260
  813. package/dist/utils/transform-content-types-to-models.js.map +1 -1
  814. package/dist/utils/transform-content-types-to-models.mjs +349 -268
  815. package/dist/utils/transform-content-types-to-models.mjs.map +1 -1
  816. package/dist/utils/update-notifier/index.d.ts.map +1 -1
  817. package/dist/utils/update-notifier/index.js +68 -73
  818. package/dist/utils/update-notifier/index.js.map +1 -1
  819. package/dist/utils/update-notifier/index.mjs +67 -67
  820. package/dist/utils/update-notifier/index.mjs.map +1 -1
  821. package/package.json +35 -32
@@ -1,167 +1,302 @@
1
- "use strict";
2
- const _ = require("lodash");
3
- const strapiUtils = require("@strapi/utils");
4
- const blocksValidator = require("./blocks-validator.js");
5
- const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
6
- const ___default = /* @__PURE__ */ _interopDefault(_);
7
- const addMinLengthValidator = (validator, {
8
- attr
9
- }, { isDraft }) => {
10
- return attr.minLength && ___default.default.isInteger(attr.minLength) && !isDraft ? validator.min(attr.minLength) : validator;
1
+ 'use strict';
2
+
3
+ var _ = require('lodash');
4
+ var strapiUtils = require('@strapi/utils');
5
+ var blocksValidator = require('./blocks-validator.js');
6
+
7
+ /* Validator utils */ /**
8
+ * Adds minLength validator
9
+ */ const addMinLengthValidator = (validator, { attr }, { isDraft })=>{
10
+ return attr.minLength && _.isInteger(attr.minLength) && !isDraft ? validator.min(attr.minLength) : validator;
11
11
  };
12
- const addMaxLengthValidator = (validator, {
13
- attr
14
- }) => {
15
- return attr.maxLength && ___default.default.isInteger(attr.maxLength) ? validator.max(attr.maxLength) : validator;
12
+ /**
13
+ * Adds maxLength validator
14
+ * @returns {StringSchema}
15
+ */ const addMaxLengthValidator = (validator, { attr })=>{
16
+ return attr.maxLength && _.isInteger(attr.maxLength) ? validator.max(attr.maxLength) : validator;
16
17
  };
17
- const addMinIntegerValidator = (validator, {
18
- attr
19
- }) => ___default.default.isNumber(attr.min) ? validator.min(___default.default.toInteger(attr.min)) : validator;
20
- const addMaxIntegerValidator = (validator, {
21
- attr
22
- }) => ___default.default.isNumber(attr.max) ? validator.max(___default.default.toInteger(attr.max)) : validator;
23
- const addMinFloatValidator = (validator, {
24
- attr
25
- }) => ___default.default.isNumber(attr.min) ? validator.min(attr.min) : validator;
26
- const addMaxFloatValidator = (validator, {
27
- attr
28
- }) => ___default.default.isNumber(attr.max) ? validator.max(attr.max) : validator;
29
- const addStringRegexValidator = (validator, {
30
- attr
31
- }) => {
32
- return "regex" in attr && !___default.default.isUndefined(attr.regex) ? validator.matches(new RegExp(attr.regex), { excludeEmptyString: !attr.required }) : validator;
18
+ /**
19
+ * Adds min integer validator
20
+ * @returns {NumberSchema}
21
+ */ const addMinIntegerValidator = (validator, { attr }, { isDraft })=>_.isNumber(attr.min) && !isDraft ? validator.min(_.toInteger(attr.min)) : validator;
22
+ /**
23
+ * Adds max integer validator
24
+ */ const addMaxIntegerValidator = (validator, { attr })=>_.isNumber(attr.max) ? validator.max(_.toInteger(attr.max)) : validator;
25
+ /**
26
+ * Adds min float/decimal validator
27
+ */ const addMinFloatValidator = (validator, { attr }, { isDraft })=>_.isNumber(attr.min) && !isDraft ? validator.min(attr.min) : validator;
28
+ /**
29
+ * Adds max float/decimal validator
30
+ */ const addMaxFloatValidator = (validator, { attr })=>_.isNumber(attr.max) ? validator.max(attr.max) : validator;
31
+ /**
32
+ * Adds regex validator
33
+ */ const addStringRegexValidator = (validator, { attr }, { isDraft })=>{
34
+ return 'regex' in attr && !_.isUndefined(attr.regex) && !isDraft ? validator.matches(new RegExp(attr.regex), {
35
+ excludeEmptyString: !attr.required
36
+ }) : validator;
33
37
  };
34
- const addUniqueValidator = (validator, {
35
- attr,
36
- model,
37
- updatedAttribute,
38
- entity,
39
- componentContext
40
- }, options) => {
41
- if (attr.type !== "uid" && !attr.unique) {
42
- return validator;
43
- }
44
- return validator.test("unique", "This attribute must be unique", async (value) => {
45
- const isPublish = options.isDraft === false;
46
- if (___default.default.isNil(value)) {
47
- return true;
38
+ const addUniqueValidator = (validator, { attr, model, updatedAttribute, entity, componentContext }, options)=>{
39
+ if (attr.type !== 'uid' && !attr.unique) {
40
+ return validator;
48
41
  }
49
- if (!isPublish && value === entity?.[updatedAttribute.name]) {
50
- return true;
51
- }
52
- let queryUid;
53
- let queryWhere = {};
54
- if (componentContext) {
55
- const hasRepeatableData = componentContext.repeatableData.length > 0;
56
- if (hasRepeatableData) {
57
- const { name: updatedName, value: updatedValue } = updatedAttribute;
58
- const pathToCheck = [...componentContext.pathToComponent.slice(1), updatedName].join(".");
59
- const values = componentContext.repeatableData.map((item) => {
60
- return pathToCheck.split(".").reduce((acc, key) => acc[key], item);
42
+ const validateUniqueFieldWithinComponent = async (value)=>{
43
+ if (!componentContext) {
44
+ return false;
45
+ }
46
+ // If we are validating a unique field within a repeatable component,
47
+ // we first need to ensure that the repeatable in the current entity is
48
+ // valid against itself.
49
+ const hasRepeatableData = componentContext.repeatableData.length > 0;
50
+ if (hasRepeatableData) {
51
+ const { name: updatedName, value: updatedValue } = updatedAttribute;
52
+ // Construct the full path to the unique field within the component.
53
+ const pathToCheck = [
54
+ ...componentContext.pathToComponent.slice(1),
55
+ updatedName
56
+ ].join('.');
57
+ // Extract the values from the repeatable data using the constructed path
58
+ const values = componentContext.repeatableData.map((item)=>{
59
+ return pathToCheck.split('.').reduce((acc, key)=>acc[key], item);
60
+ });
61
+ // Check if the value is repeated in the current entity
62
+ const isUpdatedAttributeRepeatedInThisEntity = values.filter((value)=>value === updatedValue).length > 1;
63
+ if (isUpdatedAttributeRepeatedInThisEntity) {
64
+ return false;
65
+ }
66
+ }
67
+ /**
68
+ * When `componentContext` is present it means we are dealing with a unique
69
+ * field within a component.
70
+ *
71
+ * The unique validation must consider the specific context of the
72
+ * component, which will always be contained within a parent content type
73
+ * and may also be nested within another component.
74
+ *
75
+ * We construct a query that takes into account the parent's model UID,
76
+ * dimensions (such as draft and publish state/locale) and excludes the current
77
+ * content type entity by its ID if provided.
78
+ */ const { model: parentModel, options: parentOptions, id: excludeId } = componentContext.parentContent;
79
+ const whereConditions = {};
80
+ const isParentDraft = parentOptions && parentOptions.isDraft;
81
+ whereConditions.publishedAt = isParentDraft ? null : {
82
+ $notNull: true
83
+ };
84
+ if (parentOptions?.locale) {
85
+ whereConditions.locale = parentOptions.locale;
86
+ }
87
+ if (excludeId && !Number.isNaN(excludeId)) {
88
+ whereConditions.id = {
89
+ $ne: excludeId
90
+ };
91
+ }
92
+ const queryUid = parentModel.uid;
93
+ const queryWhere = {
94
+ ...componentContext.pathToComponent.reduceRight((acc, key)=>({
95
+ [key]: acc
96
+ }), {
97
+ [updatedAttribute.name]: value
98
+ }),
99
+ ...whereConditions
100
+ };
101
+ // The validation should pass if there is no other record found from the query
102
+ return !await strapi.db.query(queryUid).findOne({
103
+ where: queryWhere
61
104
  });
62
- const isUpdatedAttributeRepeatedInThisEntity = values.filter((value2) => value2 === updatedValue).length > 1;
63
- if (isUpdatedAttributeRepeatedInThisEntity) {
64
- return false;
105
+ };
106
+ const validateUniqueFieldWithinDynamicZoneComponent = async (startOfPath)=>{
107
+ if (!componentContext) {
108
+ return false;
65
109
  }
66
- }
67
- const {
68
- model: parentModel,
69
- options: parentOptions,
70
- id: excludeId
71
- } = componentContext.parentContent;
72
- queryUid = parentModel.uid;
73
- const whereConditions = {};
74
- const isParentDraft = parentOptions && parentOptions.isDraft;
75
- whereConditions.publishedAt = isParentDraft ? null : { $notNull: true };
76
- if (parentOptions?.locale) {
77
- whereConditions.locale = parentOptions.locale;
78
- }
79
- if (excludeId && !Number.isNaN(excludeId)) {
80
- whereConditions.id = { $ne: excludeId };
81
- }
82
- queryWhere = {
83
- ...componentContext.pathToComponent.reduceRight((acc, key) => ({ [key]: acc }), {
84
- [updatedAttribute.name]: value
85
- }),
86
- ...whereConditions
87
- };
88
- } else {
89
- queryUid = model.uid;
90
- const scalarAttributeWhere = {
91
- [updatedAttribute.name]: value
92
- };
93
- scalarAttributeWhere.publishedAt = options.isDraft ? null : { $notNull: true };
94
- if (options?.locale) {
95
- scalarAttributeWhere.locale = options.locale;
96
- }
97
- if (entity?.id) {
98
- scalarAttributeWhere.id = { $ne: entity.id };
99
- }
100
- queryWhere = scalarAttributeWhere;
101
- }
102
- return !await strapi.db.query(queryUid).findOne({ where: queryWhere });
103
- });
110
+ const targetComponentUID = model.uid;
111
+ // Ensure that the value is unique within the dynamic zone in this entity.
112
+ const countOfValueInThisEntity = (componentContext?.fullDynamicZoneContent ?? []).reduce((acc, component)=>{
113
+ if (component.__component !== targetComponentUID) {
114
+ return acc;
115
+ }
116
+ const updatedValue = component[updatedAttribute.name];
117
+ return updatedValue === updatedAttribute.value ? acc + 1 : acc;
118
+ }, 0);
119
+ if (countOfValueInThisEntity > 1) {
120
+ // If the value is repeated in the current entity, the validation fails.
121
+ return false;
122
+ }
123
+ // Populate the dynamic zone for any components that share the same value
124
+ // as the updated attribute.
125
+ const query = {
126
+ select: [
127
+ 'id'
128
+ ],
129
+ where: {},
130
+ populate: {
131
+ [startOfPath]: {
132
+ on: {
133
+ [targetComponentUID]: {
134
+ select: [
135
+ 'id'
136
+ ],
137
+ where: {
138
+ [updatedAttribute.name]: updatedAttribute.value
139
+ }
140
+ }
141
+ }
142
+ }
143
+ }
144
+ };
145
+ const { options, id } = componentContext.parentContent;
146
+ if (options?.isDraft !== undefined) {
147
+ query.where.published_at = options.isDraft ? {
148
+ $eq: null
149
+ } : {
150
+ $ne: null
151
+ };
152
+ }
153
+ if (id) {
154
+ query.where.id = {
155
+ $ne: id
156
+ };
157
+ }
158
+ if (options?.locale) {
159
+ query.where.locale = options.locale;
160
+ }
161
+ const parentModelQueryResult = await strapi.db.query(componentContext.parentContent.model.uid).findMany(query);
162
+ // Filter the results to only include results that have components in the
163
+ // dynamic zone that match the target component type.
164
+ const filteredResults = parentModelQueryResult.filter((result)=>Array.isArray(result[startOfPath]) && result[startOfPath].length).flatMap((result)=>result[startOfPath]).filter((dynamicZoneComponent)=>dynamicZoneComponent.__component === targetComponentUID);
165
+ if (filteredResults.length >= 1) {
166
+ return false;
167
+ }
168
+ return true;
169
+ };
170
+ return validator.test('unique', 'This attribute must be unique', async (value)=>{
171
+ /**
172
+ * If the attribute value is `null` or an empty string we want to skip the unique validation.
173
+ * Otherwise it'll only accept a single entry with that value in the database.
174
+ */ if (_.isNil(value) || value === '') {
175
+ return true;
176
+ }
177
+ /**
178
+ * We don't validate any unique constraint for draft entries.
179
+ */ if (options.isDraft) {
180
+ return true;
181
+ }
182
+ const hasPathToComponent = componentContext && componentContext.pathToComponent.length > 0;
183
+ if (hasPathToComponent) {
184
+ // Detect if we are validating within a dynamiczone by checking if the first
185
+ // path is a dynamiczone attribute in the parent content type.
186
+ const startOfPath = componentContext.pathToComponent[0];
187
+ const testingDZ = componentContext.parentContent.model.attributes[startOfPath].type === 'dynamiczone';
188
+ if (testingDZ) {
189
+ return validateUniqueFieldWithinDynamicZoneComponent(startOfPath);
190
+ }
191
+ return validateUniqueFieldWithinComponent(value);
192
+ }
193
+ /**
194
+ * Here we are validating a scalar unique field from the content type's schema.
195
+ * We construct a query to check if the value is unique
196
+ * considering dimensions (e.g. locale, publication state) and excluding the current entity by its ID if available.
197
+ */ const scalarAttributeWhere = {
198
+ [updatedAttribute.name]: value,
199
+ publishedAt: {
200
+ $notNull: true
201
+ }
202
+ };
203
+ if (options?.locale) {
204
+ scalarAttributeWhere.locale = options.locale;
205
+ }
206
+ if (entity?.id) {
207
+ scalarAttributeWhere.id = {
208
+ $ne: entity.id
209
+ };
210
+ }
211
+ // The validation should pass if there is no other record found from the query
212
+ return !await strapi.db.query(model.uid).findOne({
213
+ where: scalarAttributeWhere,
214
+ select: [
215
+ 'id'
216
+ ]
217
+ });
218
+ });
104
219
  };
105
- const stringValidator = (metas, options) => {
106
- let schema = strapiUtils.yup.string().transform((val, originalVal) => originalVal);
107
- schema = addMinLengthValidator(schema, metas, options);
108
- schema = addMaxLengthValidator(schema, metas);
109
- schema = addStringRegexValidator(schema, metas);
110
- schema = addUniqueValidator(schema, metas, options);
111
- return schema;
220
+ /* Type validators */ const stringValidator = (metas, options)=>{
221
+ let schema = strapiUtils.yup.string().transform((val, originalVal)=>originalVal);
222
+ schema = addMinLengthValidator(schema, metas, options);
223
+ schema = addMaxLengthValidator(schema, metas);
224
+ schema = addStringRegexValidator(schema, metas, options);
225
+ schema = addUniqueValidator(schema, metas, options);
226
+ return schema;
112
227
  };
113
- const emailValidator = (metas, options) => {
114
- const schema = stringValidator(metas, options);
115
- return schema.email().min(1, "${path} cannot be empty");
228
+ const emailValidator = (metas, options)=>{
229
+ const schema = stringValidator(metas, options);
230
+ if (options.isDraft) {
231
+ return schema;
232
+ }
233
+ return schema.email().min(1, // eslint-disable-next-line no-template-curly-in-string
234
+ '${path} cannot be empty');
116
235
  };
117
- const uidValidator = (metas, options) => {
118
- const schema = stringValidator(metas, options);
119
- return schema.matches(/^[A-Za-z0-9-_.~]*$/);
236
+ const uidValidator = (metas, options)=>{
237
+ const schema = stringValidator(metas, options);
238
+ if (options.isDraft) {
239
+ return schema;
240
+ }
241
+ if (metas.attr.regex) {
242
+ return schema.matches(new RegExp(metas.attr.regex));
243
+ }
244
+ return schema.matches(/^[A-Za-z0-9-_.~]*$/);
120
245
  };
121
- const enumerationValidator = ({ attr }) => {
122
- return strapiUtils.yup.string().oneOf((Array.isArray(attr.enum) ? attr.enum : [attr.enum]).concat(null));
246
+ const enumerationValidator = ({ attr })=>{
247
+ return strapiUtils.yup.string().oneOf((Array.isArray(attr.enum) ? attr.enum : [
248
+ attr.enum
249
+ ]).concat(null));
123
250
  };
124
- const integerValidator = (metas, options) => {
125
- let schema = strapiUtils.yup.number().integer();
126
- schema = addMinIntegerValidator(schema, metas);
127
- schema = addMaxIntegerValidator(schema, metas);
128
- schema = addUniqueValidator(schema, metas, options);
129
- return schema;
251
+ const integerValidator = (metas, options)=>{
252
+ let schema = strapiUtils.yup.number().integer();
253
+ schema = addMinIntegerValidator(schema, metas, options);
254
+ schema = addMaxIntegerValidator(schema, metas);
255
+ schema = addUniqueValidator(schema, metas, options);
256
+ return schema;
130
257
  };
131
- const floatValidator = (metas, options) => {
132
- let schema = strapiUtils.yup.number();
133
- schema = addMinFloatValidator(schema, metas);
134
- schema = addMaxFloatValidator(schema, metas);
135
- schema = addUniqueValidator(schema, metas, options);
136
- return schema;
258
+ const floatValidator = (metas, options)=>{
259
+ let schema = strapiUtils.yup.number();
260
+ schema = addMinFloatValidator(schema, metas, options);
261
+ schema = addMaxFloatValidator(schema, metas);
262
+ schema = addUniqueValidator(schema, metas, options);
263
+ return schema;
137
264
  };
138
- const bigintegerValidator = (metas, options) => {
139
- const schema = strapiUtils.yup.mixed();
140
- return addUniqueValidator(schema, metas, options);
265
+ const bigintegerValidator = (metas, options)=>{
266
+ const schema = strapiUtils.yup.mixed();
267
+ return addUniqueValidator(schema, metas, options);
141
268
  };
142
- const datesValidator = (metas, options) => {
143
- const schema = strapiUtils.yup.mixed();
144
- return addUniqueValidator(schema, metas, options);
269
+ const datesValidator = (metas, options)=>{
270
+ const schema = strapiUtils.yup.mixed();
271
+ return addUniqueValidator(schema, metas, options);
145
272
  };
146
- const validators = {
147
- string: stringValidator,
148
- text: stringValidator,
149
- richtext: stringValidator,
150
- password: stringValidator,
151
- email: emailValidator,
152
- enumeration: enumerationValidator,
153
- boolean: () => strapiUtils.yup.boolean(),
154
- uid: uidValidator,
155
- json: () => strapiUtils.yup.mixed(),
156
- integer: integerValidator,
157
- biginteger: bigintegerValidator,
158
- float: floatValidator,
159
- decimal: floatValidator,
160
- date: datesValidator,
161
- time: datesValidator,
162
- datetime: datesValidator,
163
- timestamp: datesValidator,
164
- blocks: blocksValidator
273
+ const Validators = {
274
+ string: stringValidator,
275
+ text: stringValidator,
276
+ richtext: stringValidator,
277
+ password: stringValidator,
278
+ email: emailValidator,
279
+ enumeration: enumerationValidator,
280
+ boolean: ()=>strapiUtils.yup.boolean(),
281
+ uid: uidValidator,
282
+ json: ()=>strapiUtils.yup.mixed(),
283
+ integer: integerValidator,
284
+ biginteger: bigintegerValidator,
285
+ float: floatValidator,
286
+ decimal: floatValidator,
287
+ date: datesValidator,
288
+ time: datesValidator,
289
+ datetime: datesValidator,
290
+ timestamp: datesValidator,
291
+ blocks: blocksValidator.blocksValidator
165
292
  };
166
- module.exports = validators;
293
+
294
+ exports.Validators = Validators;
295
+ exports.bigintegerValidator = bigintegerValidator;
296
+ exports.datesValidator = datesValidator;
297
+ exports.emailValidator = emailValidator;
298
+ exports.enumerationValidator = enumerationValidator;
299
+ exports.floatValidator = floatValidator;
300
+ exports.integerValidator = integerValidator;
301
+ exports.uidValidator = uidValidator;
167
302
  //# sourceMappingURL=validators.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"validators.js","sources":["../../../src/services/entity-validator/validators.ts"],"sourcesContent":["import _ from 'lodash';\nimport { yup } from '@strapi/utils';\nimport type { Schema, Struct, Modules } from '@strapi/types';\nimport blocksValidator from './blocks-validator';\n\nimport type { ComponentContext } from '.';\n\ninterface ValidatorMetas<TAttribute extends Schema.Attribute.AnyAttribute> {\n attr: TAttribute;\n model: Struct.ContentTypeSchema;\n updatedAttribute: { name: string; value: unknown };\n entity: Modules.EntityValidator.Entity;\n componentContext: ComponentContext;\n}\n\ninterface ValidatorOptions {\n isDraft: boolean;\n locale?: string;\n}\n\n/* Validator utils */\n\n/**\n * Adds minLength validator\n */\nconst addMinLengthValidator = (\n validator: yup.StringSchema,\n {\n attr,\n }: {\n attr:\n | Schema.Attribute.String\n | Schema.Attribute.Text\n | Schema.Attribute.RichText\n | Schema.Attribute.Password\n | Schema.Attribute.Email\n | Schema.Attribute.UID;\n },\n { isDraft }: ValidatorOptions\n) => {\n return attr.minLength && _.isInteger(attr.minLength) && !isDraft\n ? validator.min(attr.minLength)\n : validator;\n};\n\n/**\n * Adds maxLength validator\n * @returns {StringSchema}\n */\nconst addMaxLengthValidator = (\n validator: yup.StringSchema,\n {\n attr,\n }: {\n attr:\n | Schema.Attribute.String\n | Schema.Attribute.Text\n | Schema.Attribute.RichText\n | Schema.Attribute.Password\n | Schema.Attribute.Email\n | Schema.Attribute.UID;\n }\n) => {\n return attr.maxLength && _.isInteger(attr.maxLength) ? validator.max(attr.maxLength) : validator;\n};\n\n/**\n * Adds min integer validator\n * @returns {NumberSchema}\n */\nconst addMinIntegerValidator = (\n validator: yup.NumberSchema,\n {\n attr,\n }: {\n attr: Schema.Attribute.Integer | Schema.Attribute.BigInteger;\n }\n) => (_.isNumber(attr.min) ? validator.min(_.toInteger(attr.min)) : validator);\n\n/**\n * Adds max integer validator\n */\nconst addMaxIntegerValidator = (\n validator: yup.NumberSchema,\n {\n attr,\n }: {\n attr: Schema.Attribute.Integer | Schema.Attribute.BigInteger;\n }\n) => (_.isNumber(attr.max) ? validator.max(_.toInteger(attr.max)) : validator);\n\n/**\n * Adds min float/decimal validator\n */\nconst addMinFloatValidator = (\n validator: yup.NumberSchema,\n {\n attr,\n }: {\n attr: Schema.Attribute.Decimal | Schema.Attribute.Float;\n }\n) => (_.isNumber(attr.min) ? validator.min(attr.min) : validator);\n\n/**\n * Adds max float/decimal validator\n */\nconst addMaxFloatValidator = (\n validator: yup.NumberSchema,\n {\n attr,\n }: {\n attr: Schema.Attribute.Decimal | Schema.Attribute.Float;\n }\n) => (_.isNumber(attr.max) ? validator.max(attr.max) : validator);\n\n/**\n * Adds regex validator\n */\nconst addStringRegexValidator = (\n validator: yup.StringSchema,\n {\n attr,\n }: {\n attr:\n | Schema.Attribute.String\n | Schema.Attribute.Text\n | Schema.Attribute.RichText\n | Schema.Attribute.Password\n | Schema.Attribute.Email\n | Schema.Attribute.UID;\n }\n) => {\n return 'regex' in attr && !_.isUndefined(attr.regex)\n ? validator.matches(new RegExp(attr.regex), { excludeEmptyString: !attr.required })\n : validator;\n};\n\n/**\n * Adds unique validator\n */\nconst addUniqueValidator = <T extends yup.AnySchema>(\n validator: T,\n {\n attr,\n model,\n updatedAttribute,\n entity,\n componentContext,\n }: ValidatorMetas<Schema.Attribute.AnyAttribute & Schema.Attribute.UniqueOption>,\n options: ValidatorOptions\n): T => {\n if (attr.type !== 'uid' && !attr.unique) {\n return validator;\n }\n\n return validator.test('unique', 'This attribute must be unique', async (value) => {\n const isPublish = options.isDraft === false;\n\n /**\n * If the attribute value is `null` we want to skip the unique validation.\n * Otherwise it'll only accept a single `null` entry in the database.\n */\n if (_.isNil(value)) {\n return true;\n }\n\n /**\n * If we are updating a draft and the value is unchanged we skip the unique verification. This will\n * prevent the validator to be triggered in case the user activated the\n * unique constraint after already creating multiple entries with\n * the same attribute value for that field.\n */\n if (!isPublish && value === entity?.[updatedAttribute.name]) {\n return true;\n }\n\n let queryUid: string;\n let queryWhere: Record<string, any> = {};\n\n if (componentContext) {\n const hasRepeatableData = componentContext.repeatableData.length > 0;\n if (hasRepeatableData) {\n // If we are validating a unique field within a repeatable component,\n // we first need to ensure that the repeatable in the current entity is\n // valid against itself.\n\n const { name: updatedName, value: updatedValue } = updatedAttribute;\n // Construct the full path to the unique field within the component.\n const pathToCheck = [...componentContext.pathToComponent.slice(1), updatedName].join('.');\n\n // Extract the values from the repeatable data using the constructed path\n const values = componentContext.repeatableData.map((item) => {\n return pathToCheck.split('.').reduce((acc, key) => acc[key], item as any);\n });\n\n // Check if the value is repeated in the current entity\n const isUpdatedAttributeRepeatedInThisEntity =\n values.filter((value) => value === updatedValue).length > 1;\n\n if (isUpdatedAttributeRepeatedInThisEntity) {\n return false;\n }\n }\n\n /**\n * When `componentContext` is present it means we are dealing with a unique\n * field within a component.\n *\n * The unique validation must consider the specific context of the\n * component, which will always be contained within a parent content type\n * and may also be nested within another component.\n *\n * We construct a query that takes into account the parent's model UID,\n * dimensions (such as draft and publish state/locale) and excludes the current\n * content type entity by its ID if provided.\n */\n const {\n model: parentModel,\n options: parentOptions,\n id: excludeId,\n } = componentContext.parentContent;\n queryUid = parentModel.uid;\n\n const whereConditions: Record<string, any> = {};\n const isParentDraft = parentOptions && parentOptions.isDraft;\n\n whereConditions.publishedAt = isParentDraft ? null : { $notNull: true };\n\n if (parentOptions?.locale) {\n whereConditions.locale = parentOptions.locale;\n }\n\n if (excludeId && !Number.isNaN(excludeId)) {\n whereConditions.id = { $ne: excludeId };\n }\n\n queryWhere = {\n ...componentContext.pathToComponent.reduceRight((acc, key) => ({ [key]: acc }), {\n [updatedAttribute.name]: value,\n }),\n\n ...whereConditions,\n };\n } else {\n /**\n * Here we are validating a scalar unique field from the content type's schema.\n * We construct a query to check if the value is unique\n * considering dimensions (e.g. locale, publication state) and excluding the current entity by its ID if available.\n */\n queryUid = model.uid;\n const scalarAttributeWhere: Record<string, any> = {\n [updatedAttribute.name]: value,\n };\n\n scalarAttributeWhere.publishedAt = options.isDraft ? null : { $notNull: true };\n\n if (options?.locale) {\n scalarAttributeWhere.locale = options.locale;\n }\n\n if (entity?.id) {\n scalarAttributeWhere.id = { $ne: entity.id };\n }\n\n queryWhere = scalarAttributeWhere;\n }\n\n // The validation should pass if there is no other record found from the query\n // TODO query not working for dynamic zones (type === relation)\n return !(await strapi.db.query(queryUid).findOne({ where: queryWhere }));\n });\n};\n\n/* Type validators */\n\nconst stringValidator = (\n metas: ValidatorMetas<\n | Schema.Attribute.String\n | Schema.Attribute.Text\n | Schema.Attribute.RichText\n | Schema.Attribute.Password\n | Schema.Attribute.Email\n | Schema.Attribute.UID\n >,\n options: ValidatorOptions\n) => {\n let schema = yup.string().transform((val, originalVal) => originalVal);\n\n schema = addMinLengthValidator(schema, metas, options);\n schema = addMaxLengthValidator(schema, metas);\n schema = addStringRegexValidator(schema, metas);\n schema = addUniqueValidator(schema, metas, options);\n\n return schema;\n};\n\nconst emailValidator = (\n metas: ValidatorMetas<Schema.Attribute.Email>,\n options: ValidatorOptions\n) => {\n const schema = stringValidator(metas, options);\n return schema.email().min(1, '${path} cannot be empty');\n};\n\nconst uidValidator = (metas: ValidatorMetas<Schema.Attribute.UID>, options: ValidatorOptions) => {\n const schema = stringValidator(metas, options);\n\n return schema.matches(/^[A-Za-z0-9-_.~]*$/);\n};\n\nconst enumerationValidator = ({ attr }: { attr: Schema.Attribute.Enumeration }) => {\n return yup\n .string()\n .oneOf((Array.isArray(attr.enum) ? attr.enum : [attr.enum]).concat(null as any));\n};\n\nconst integerValidator = (\n metas: ValidatorMetas<Schema.Attribute.Integer | Schema.Attribute.BigInteger>,\n options: ValidatorOptions\n) => {\n let schema = yup.number().integer();\n\n schema = addMinIntegerValidator(schema, metas);\n schema = addMaxIntegerValidator(schema, metas);\n schema = addUniqueValidator(schema, metas, options);\n\n return schema;\n};\n\nconst floatValidator = (\n metas: ValidatorMetas<Schema.Attribute.Decimal | Schema.Attribute.Float>,\n options: ValidatorOptions\n) => {\n let schema = yup.number();\n schema = addMinFloatValidator(schema, metas);\n schema = addMaxFloatValidator(schema, metas);\n schema = addUniqueValidator(schema, metas, options);\n\n return schema;\n};\n\nconst bigintegerValidator = (\n metas: ValidatorMetas<Schema.Attribute.BigInteger>,\n options: ValidatorOptions\n) => {\n const schema = yup.mixed();\n return addUniqueValidator(schema, metas, options);\n};\n\nconst datesValidator = (\n metas: ValidatorMetas<\n | Schema.Attribute.Date\n | Schema.Attribute.DateTime\n | Schema.Attribute.Time\n | Schema.Attribute.Timestamp\n >,\n options: ValidatorOptions\n) => {\n const schema = yup.mixed();\n return addUniqueValidator(schema, metas, options);\n};\n\nexport default {\n string: stringValidator,\n text: stringValidator,\n richtext: stringValidator,\n password: stringValidator,\n email: emailValidator,\n enumeration: enumerationValidator,\n boolean: () => yup.boolean(),\n uid: uidValidator,\n json: () => yup.mixed(),\n integer: integerValidator,\n biginteger: bigintegerValidator,\n float: floatValidator,\n decimal: floatValidator,\n date: datesValidator,\n time: datesValidator,\n datetime: datesValidator,\n timestamp: datesValidator,\n blocks: blocksValidator,\n};\n"],"names":["_","value","yup"],"mappings":"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"}
1
+ {"version":3,"file":"validators.js","sources":["../../../src/services/entity-validator/validators.ts"],"sourcesContent":["/**\n * Validators check if the entry data meets specific criteria before saving or publishing.\n * (e.g., length, range, format).\n *\n * Drafts have limited validations (mainly max constraints),\n * while published content undergoes full validation.\n *\n * The system also takes locales into account when validating data.\n * E.g, unique fields must be unique within the same locale.\n */\nimport _ from 'lodash';\nimport { yup } from '@strapi/utils';\nimport type { Schema, Struct, Modules } from '@strapi/types';\nimport { blocksValidator } from './blocks-validator';\n\nimport type { ComponentContext } from '.';\n\nexport interface ValidatorMetas<\n TAttribute extends Schema.Attribute.AnyAttribute = Schema.Attribute.AnyAttribute,\n TValue extends Schema.Attribute.Value<TAttribute> = Schema.Attribute.Value<TAttribute>,\n> {\n attr: TAttribute;\n model: Struct.Schema;\n updatedAttribute: {\n name: string;\n value: TValue;\n };\n data: Record<string, unknown>;\n componentContext?: ComponentContext;\n entity?: Modules.EntityValidator.Entity;\n}\n\ninterface ValidatorOptions {\n isDraft: boolean;\n locale?: string;\n}\n\n/* Validator utils */\n\n/**\n * Adds minLength validator\n */\nconst addMinLengthValidator = (\n validator: yup.StringSchema,\n {\n attr,\n }: {\n attr:\n | Schema.Attribute.String\n | Schema.Attribute.Text\n | Schema.Attribute.RichText\n | Schema.Attribute.Password\n | Schema.Attribute.Email\n | Schema.Attribute.UID;\n },\n { isDraft }: ValidatorOptions\n) => {\n return attr.minLength && _.isInteger(attr.minLength) && !isDraft\n ? validator.min(attr.minLength)\n : validator;\n};\n\n/**\n * Adds maxLength validator\n * @returns {StringSchema}\n */\nconst addMaxLengthValidator = (\n validator: yup.StringSchema,\n {\n attr,\n }: {\n attr:\n | Schema.Attribute.String\n | Schema.Attribute.Text\n | Schema.Attribute.RichText\n | Schema.Attribute.Password\n | Schema.Attribute.Email\n | Schema.Attribute.UID;\n }\n) => {\n return attr.maxLength && _.isInteger(attr.maxLength) ? validator.max(attr.maxLength) : validator;\n};\n\n/**\n * Adds min integer validator\n * @returns {NumberSchema}\n */\nconst addMinIntegerValidator = (\n validator: yup.NumberSchema,\n {\n attr,\n }: {\n attr: Schema.Attribute.Integer | Schema.Attribute.BigInteger;\n },\n { isDraft }: ValidatorOptions\n) => (_.isNumber(attr.min) && !isDraft ? validator.min(_.toInteger(attr.min)) : validator);\n\n/**\n * Adds max integer validator\n */\nconst addMaxIntegerValidator = (\n validator: yup.NumberSchema,\n {\n attr,\n }: {\n attr: Schema.Attribute.Integer | Schema.Attribute.BigInteger;\n }\n) => (_.isNumber(attr.max) ? validator.max(_.toInteger(attr.max)) : validator);\n\n/**\n * Adds min float/decimal validator\n */\nconst addMinFloatValidator = (\n validator: yup.NumberSchema,\n {\n attr,\n }: {\n attr: Schema.Attribute.Decimal | Schema.Attribute.Float;\n },\n { isDraft }: ValidatorOptions\n) => (_.isNumber(attr.min) && !isDraft ? validator.min(attr.min) : validator);\n\n/**\n * Adds max float/decimal validator\n */\nconst addMaxFloatValidator = (\n validator: yup.NumberSchema,\n {\n attr,\n }: {\n attr: Schema.Attribute.Decimal | Schema.Attribute.Float;\n }\n) => (_.isNumber(attr.max) ? validator.max(attr.max) : validator);\n\n/**\n * Adds regex validator\n */\nconst addStringRegexValidator = (\n validator: yup.StringSchema,\n {\n attr,\n }: {\n attr:\n | Schema.Attribute.String\n | Schema.Attribute.Text\n | Schema.Attribute.RichText\n | Schema.Attribute.Password\n | Schema.Attribute.Email\n | Schema.Attribute.UID;\n },\n { isDraft }: ValidatorOptions\n) => {\n return 'regex' in attr && !_.isUndefined(attr.regex) && !isDraft\n ? validator.matches(new RegExp(attr.regex), { excludeEmptyString: !attr.required })\n : validator;\n};\n\nconst addUniqueValidator = <T extends yup.AnySchema>(\n validator: T,\n {\n attr,\n model,\n updatedAttribute,\n entity,\n componentContext,\n }: ValidatorMetas<Schema.Attribute.AnyAttribute & Schema.Attribute.UniqueOption>,\n options: ValidatorOptions\n): T => {\n if (attr.type !== 'uid' && !attr.unique) {\n return validator;\n }\n\n const validateUniqueFieldWithinComponent = async (value: any): Promise<boolean> => {\n if (!componentContext) {\n return false;\n }\n\n // If we are validating a unique field within a repeatable component,\n // we first need to ensure that the repeatable in the current entity is\n // valid against itself.\n const hasRepeatableData = componentContext.repeatableData.length > 0;\n if (hasRepeatableData) {\n const { name: updatedName, value: updatedValue } = updatedAttribute;\n // Construct the full path to the unique field within the component.\n const pathToCheck = [...componentContext.pathToComponent.slice(1), updatedName].join('.');\n\n // Extract the values from the repeatable data using the constructed path\n const values = componentContext.repeatableData.map((item) => {\n return pathToCheck.split('.').reduce((acc, key) => acc[key], item as any);\n });\n\n // Check if the value is repeated in the current entity\n const isUpdatedAttributeRepeatedInThisEntity =\n values.filter((value) => value === updatedValue).length > 1;\n\n if (isUpdatedAttributeRepeatedInThisEntity) {\n return false;\n }\n }\n\n /**\n * When `componentContext` is present it means we are dealing with a unique\n * field within a component.\n *\n * The unique validation must consider the specific context of the\n * component, which will always be contained within a parent content type\n * and may also be nested within another component.\n *\n * We construct a query that takes into account the parent's model UID,\n * dimensions (such as draft and publish state/locale) and excludes the current\n * content type entity by its ID if provided.\n */\n const {\n model: parentModel,\n options: parentOptions,\n id: excludeId,\n } = componentContext.parentContent;\n\n const whereConditions: Record<string, any> = {};\n const isParentDraft = parentOptions && parentOptions.isDraft;\n\n whereConditions.publishedAt = isParentDraft ? null : { $notNull: true };\n\n if (parentOptions?.locale) {\n whereConditions.locale = parentOptions.locale;\n }\n\n if (excludeId && !Number.isNaN(excludeId)) {\n whereConditions.id = { $ne: excludeId };\n }\n\n const queryUid = parentModel.uid;\n const queryWhere = {\n ...componentContext.pathToComponent.reduceRight((acc, key) => ({ [key]: acc }), {\n [updatedAttribute.name]: value,\n }),\n\n ...whereConditions,\n };\n\n // The validation should pass if there is no other record found from the query\n return !(await strapi.db.query(queryUid).findOne({ where: queryWhere }));\n };\n\n const validateUniqueFieldWithinDynamicZoneComponent = async (\n startOfPath: string\n ): Promise<boolean> => {\n if (!componentContext) {\n return false;\n }\n\n const targetComponentUID = model.uid;\n // Ensure that the value is unique within the dynamic zone in this entity.\n const countOfValueInThisEntity = (componentContext?.fullDynamicZoneContent ?? []).reduce(\n (acc, component) => {\n if (component.__component !== targetComponentUID) {\n return acc;\n }\n\n const updatedValue = component[updatedAttribute.name];\n return updatedValue === updatedAttribute.value ? acc + 1 : acc;\n },\n 0\n );\n\n if (countOfValueInThisEntity > 1) {\n // If the value is repeated in the current entity, the validation fails.\n return false;\n }\n\n // Build a query for the parent content type to find all entities in the\n // same locale and publication state\n type QueryType = {\n select: string[];\n where: {\n published_at?: { $eq: null } | { $ne: null };\n id?: { $ne: number };\n locale?: string;\n };\n populate: {\n [key: string]: {\n on: {\n [key: string]: {\n select: string[];\n where: { [key: string]: string | number | boolean };\n };\n };\n };\n };\n };\n\n // Populate the dynamic zone for any components that share the same value\n // as the updated attribute.\n const query: QueryType = {\n select: ['id'],\n where: {},\n populate: {\n [startOfPath]: {\n on: {\n [targetComponentUID]: {\n select: ['id'],\n where: { [updatedAttribute.name]: updatedAttribute.value },\n },\n },\n },\n },\n };\n\n const { options, id } = componentContext.parentContent;\n\n if (options?.isDraft !== undefined) {\n query.where.published_at = options.isDraft ? { $eq: null } : { $ne: null };\n }\n\n if (id) {\n query.where.id = { $ne: id };\n }\n\n if (options?.locale) {\n query.where.locale = options.locale;\n }\n\n const parentModelQueryResult = await strapi.db\n .query(componentContext.parentContent.model.uid)\n .findMany(query);\n\n // Filter the results to only include results that have components in the\n // dynamic zone that match the target component type.\n const filteredResults = parentModelQueryResult\n .filter((result) => Array.isArray(result[startOfPath]) && result[startOfPath].length)\n .flatMap((result) => result[startOfPath])\n .filter((dynamicZoneComponent) => dynamicZoneComponent.__component === targetComponentUID);\n\n if (filteredResults.length >= 1) {\n return false;\n }\n\n return true;\n };\n\n return validator.test('unique', 'This attribute must be unique', async (value) => {\n /**\n * If the attribute value is `null` or an empty string we want to skip the unique validation.\n * Otherwise it'll only accept a single entry with that value in the database.\n */\n if (_.isNil(value) || value === '') {\n return true;\n }\n\n /**\n * We don't validate any unique constraint for draft entries.\n */\n if (options.isDraft) {\n return true;\n }\n\n const hasPathToComponent = componentContext && componentContext.pathToComponent.length > 0;\n if (hasPathToComponent) {\n // Detect if we are validating within a dynamiczone by checking if the first\n // path is a dynamiczone attribute in the parent content type.\n const startOfPath = componentContext.pathToComponent[0];\n const testingDZ =\n componentContext.parentContent.model.attributes[startOfPath].type === 'dynamiczone';\n\n if (testingDZ) {\n return validateUniqueFieldWithinDynamicZoneComponent(startOfPath);\n }\n\n return validateUniqueFieldWithinComponent(value);\n }\n\n /**\n * Here we are validating a scalar unique field from the content type's schema.\n * We construct a query to check if the value is unique\n * considering dimensions (e.g. locale, publication state) and excluding the current entity by its ID if available.\n */\n const scalarAttributeWhere: Record<string, any> = {\n [updatedAttribute.name]: value,\n publishedAt: { $notNull: true },\n };\n\n if (options?.locale) {\n scalarAttributeWhere.locale = options.locale;\n }\n\n if (entity?.id) {\n scalarAttributeWhere.id = { $ne: entity.id };\n }\n\n // The validation should pass if there is no other record found from the query\n return !(await strapi.db\n .query(model.uid)\n .findOne({ where: scalarAttributeWhere, select: ['id'] }));\n });\n};\n\n/* Type validators */\n\nconst stringValidator = (\n metas: ValidatorMetas<\n | Schema.Attribute.String\n | Schema.Attribute.Text\n | Schema.Attribute.RichText\n | Schema.Attribute.Password\n | Schema.Attribute.Email\n | Schema.Attribute.UID\n >,\n options: ValidatorOptions\n) => {\n let schema = yup.string().transform((val, originalVal) => originalVal);\n\n schema = addMinLengthValidator(schema, metas, options);\n schema = addMaxLengthValidator(schema, metas);\n schema = addStringRegexValidator(schema, metas, options);\n schema = addUniqueValidator(schema, metas, options);\n\n return schema;\n};\n\nexport const emailValidator = (\n metas: ValidatorMetas<Schema.Attribute.Email>,\n options: ValidatorOptions\n) => {\n const schema = stringValidator(metas, options);\n\n if (options.isDraft) {\n return schema;\n }\n\n return schema.email().min(\n 1,\n // eslint-disable-next-line no-template-curly-in-string\n '${path} cannot be empty'\n );\n};\n\nexport const uidValidator = (\n metas: ValidatorMetas<Schema.Attribute.UID>,\n options: ValidatorOptions\n) => {\n const schema = stringValidator(metas, options);\n\n if (options.isDraft) {\n return schema;\n }\n\n if (metas.attr.regex) {\n return schema.matches(new RegExp(metas.attr.regex));\n }\n\n return schema.matches(/^[A-Za-z0-9-_.~]*$/);\n};\n\nexport const enumerationValidator = ({ attr }: { attr: Schema.Attribute.Enumeration }) => {\n return yup\n .string()\n .oneOf((Array.isArray(attr.enum) ? attr.enum : [attr.enum]).concat(null as any));\n};\n\nexport const integerValidator = (\n metas: ValidatorMetas<Schema.Attribute.Integer | Schema.Attribute.BigInteger>,\n options: ValidatorOptions\n) => {\n let schema = yup.number().integer();\n\n schema = addMinIntegerValidator(schema, metas, options);\n schema = addMaxIntegerValidator(schema, metas);\n schema = addUniqueValidator(schema, metas, options);\n\n return schema;\n};\n\nexport const floatValidator = (\n metas: ValidatorMetas<Schema.Attribute.Decimal | Schema.Attribute.Float>,\n options: ValidatorOptions\n) => {\n let schema = yup.number();\n\n schema = addMinFloatValidator(schema, metas, options);\n schema = addMaxFloatValidator(schema, metas);\n schema = addUniqueValidator(schema, metas, options);\n\n return schema;\n};\n\nexport const bigintegerValidator = (\n metas: ValidatorMetas<Schema.Attribute.BigInteger>,\n options: ValidatorOptions\n) => {\n const schema = yup.mixed();\n return addUniqueValidator(schema, metas, options);\n};\n\nexport const datesValidator = (\n metas: ValidatorMetas<\n | Schema.Attribute.Date\n | Schema.Attribute.DateTime\n | Schema.Attribute.Time\n | Schema.Attribute.Timestamp\n >,\n options: ValidatorOptions\n) => {\n const schema = yup.mixed();\n return addUniqueValidator(schema, metas, options);\n};\n\nexport const Validators = {\n string: stringValidator,\n text: stringValidator,\n richtext: stringValidator,\n password: stringValidator,\n email: emailValidator,\n enumeration: enumerationValidator,\n boolean: () => yup.boolean(),\n uid: uidValidator,\n json: () => yup.mixed(),\n integer: integerValidator,\n biginteger: bigintegerValidator,\n float: floatValidator,\n decimal: floatValidator,\n date: datesValidator,\n time: datesValidator,\n datetime: datesValidator,\n timestamp: datesValidator,\n blocks: blocksValidator,\n};\n"],"names":["addMinLengthValidator","validator","attr","isDraft","minLength","_","isInteger","min","addMaxLengthValidator","maxLength","max","addMinIntegerValidator","isNumber","toInteger","addMaxIntegerValidator","addMinFloatValidator","addMaxFloatValidator","addStringRegexValidator","isUndefined","regex","matches","RegExp","excludeEmptyString","required","addUniqueValidator","model","updatedAttribute","entity","componentContext","options","type","unique","validateUniqueFieldWithinComponent","value","hasRepeatableData","repeatableData","length","name","updatedName","updatedValue","pathToCheck","pathToComponent","slice","join","values","map","item","split","reduce","acc","key","isUpdatedAttributeRepeatedInThisEntity","filter","parentModel","parentOptions","id","excludeId","parentContent","whereConditions","isParentDraft","publishedAt","$notNull","locale","Number","isNaN","$ne","queryUid","uid","queryWhere","reduceRight","strapi","db","query","findOne","where","validateUniqueFieldWithinDynamicZoneComponent","startOfPath","targetComponentUID","countOfValueInThisEntity","fullDynamicZoneContent","component","__component","select","populate","on","undefined","published_at","$eq","parentModelQueryResult","findMany","filteredResults","result","Array","isArray","flatMap","dynamicZoneComponent","test","isNil","hasPathToComponent","testingDZ","attributes","scalarAttributeWhere","stringValidator","metas","schema","yup","string","transform","val","originalVal","emailValidator","email","uidValidator","enumerationValidator","oneOf","enum","concat","integerValidator","number","integer","floatValidator","bigintegerValidator","mixed","datesValidator","Validators","text","richtext","password","enumeration","boolean","json","biginteger","float","decimal","date","time","datetime","timestamp","blocks","blocksValidator"],"mappings":"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"}