@strapi/core 5.9.0 → 5.10.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (678) hide show
  1. package/dist/configuration/index.d.ts.map +1 -1
  2. package/dist/index.js +9954 -27
  3. package/dist/index.js.map +1 -1
  4. package/dist/index.mjs +9932 -29
  5. package/dist/index.mjs.map +1 -1
  6. package/dist/middlewares/body.d.ts.map +1 -1
  7. package/dist/migrations/draft-publish.d.ts +1 -1
  8. package/dist/migrations/draft-publish.d.ts.map +1 -1
  9. package/dist/services/document-service/draft-and-publish.d.ts +1 -1
  10. package/dist/services/document-service/draft-and-publish.d.ts.map +1 -1
  11. package/dist/services/document-service/events.d.ts +1 -1
  12. package/dist/services/document-service/events.d.ts.map +1 -1
  13. package/dist/services/document-service/transform/id-map.d.ts +1 -1
  14. package/dist/services/document-service/transform/id-map.d.ts.map +1 -1
  15. package/dist/services/document-service/transform/id-transform.d.ts +1 -1
  16. package/dist/services/document-service/transform/id-transform.d.ts.map +1 -1
  17. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts +1 -1
  18. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts.map +1 -1
  19. package/dist/services/document-service/transform/relations/utils/dp.d.ts +1 -1
  20. package/dist/services/document-service/transform/relations/utils/dp.d.ts.map +1 -1
  21. package/dist/services/document-service/transform/relations/utils/i18n.d.ts +1 -1
  22. package/dist/services/document-service/transform/relations/utils/i18n.d.ts.map +1 -1
  23. package/dist/services/document-service/utils/populate.d.ts +1 -1
  24. package/dist/services/document-service/utils/populate.d.ts.map +1 -1
  25. package/dist/services/document-service/utils/unidirectional-relations.d.ts +1 -1
  26. package/dist/services/document-service/utils/unidirectional-relations.d.ts.map +1 -1
  27. package/dist/services/entity-validator/index.d.ts +1 -1
  28. package/dist/services/entity-validator/index.d.ts.map +1 -1
  29. package/dist/utils/update-notifier/index.d.ts.map +1 -1
  30. package/package.json +22 -22
  31. package/dist/Strapi.js +0 -437
  32. package/dist/Strapi.js.map +0 -1
  33. package/dist/Strapi.mjs +0 -416
  34. package/dist/Strapi.mjs.map +0 -1
  35. package/dist/compile.js +0 -18
  36. package/dist/compile.js.map +0 -1
  37. package/dist/compile.mjs +0 -17
  38. package/dist/compile.mjs.map +0 -1
  39. package/dist/configuration/config-loader.js +0 -105
  40. package/dist/configuration/config-loader.js.map +0 -1
  41. package/dist/configuration/config-loader.mjs +0 -103
  42. package/dist/configuration/config-loader.mjs.map +0 -1
  43. package/dist/configuration/get-dirs.js +0 -31
  44. package/dist/configuration/get-dirs.js.map +0 -1
  45. package/dist/configuration/get-dirs.mjs +0 -31
  46. package/dist/configuration/get-dirs.mjs.map +0 -1
  47. package/dist/configuration/index.js +0 -85
  48. package/dist/configuration/index.js.map +0 -1
  49. package/dist/configuration/index.mjs +0 -80
  50. package/dist/configuration/index.mjs.map +0 -1
  51. package/dist/configuration/urls.js +0 -68
  52. package/dist/configuration/urls.js.map +0 -1
  53. package/dist/configuration/urls.mjs +0 -66
  54. package/dist/configuration/urls.mjs.map +0 -1
  55. package/dist/container.js +0 -30
  56. package/dist/container.js.map +0 -1
  57. package/dist/container.mjs +0 -30
  58. package/dist/container.mjs.map +0 -1
  59. package/dist/core-api/controller/collection-type.js +0 -84
  60. package/dist/core-api/controller/collection-type.js.map +0 -1
  61. package/dist/core-api/controller/collection-type.mjs +0 -84
  62. package/dist/core-api/controller/collection-type.mjs.map +0 -1
  63. package/dist/core-api/controller/index.js +0 -52
  64. package/dist/core-api/controller/index.js.map +0 -1
  65. package/dist/core-api/controller/index.mjs +0 -52
  66. package/dist/core-api/controller/index.mjs.map +0 -1
  67. package/dist/core-api/controller/single-type.js +0 -46
  68. package/dist/core-api/controller/single-type.js.map +0 -1
  69. package/dist/core-api/controller/single-type.mjs +0 -46
  70. package/dist/core-api/controller/single-type.mjs.map +0 -1
  71. package/dist/core-api/controller/transform.js +0 -76
  72. package/dist/core-api/controller/transform.js.map +0 -1
  73. package/dist/core-api/controller/transform.mjs +0 -76
  74. package/dist/core-api/controller/transform.mjs.map +0 -1
  75. package/dist/core-api/routes/index.js +0 -67
  76. package/dist/core-api/routes/index.js.map +0 -1
  77. package/dist/core-api/routes/index.mjs +0 -67
  78. package/dist/core-api/routes/index.mjs.map +0 -1
  79. package/dist/core-api/service/collection-type.js +0 -67
  80. package/dist/core-api/service/collection-type.js.map +0 -1
  81. package/dist/core-api/service/collection-type.mjs +0 -67
  82. package/dist/core-api/service/collection-type.mjs.map +0 -1
  83. package/dist/core-api/service/core-service.js +0 -12
  84. package/dist/core-api/service/core-service.js.map +0 -1
  85. package/dist/core-api/service/core-service.mjs +0 -12
  86. package/dist/core-api/service/core-service.mjs.map +0 -1
  87. package/dist/core-api/service/index.js +0 -16
  88. package/dist/core-api/service/index.js.map +0 -1
  89. package/dist/core-api/service/index.mjs +0 -16
  90. package/dist/core-api/service/index.mjs.map +0 -1
  91. package/dist/core-api/service/pagination.js +0 -52
  92. package/dist/core-api/service/pagination.js.map +0 -1
  93. package/dist/core-api/service/pagination.mjs +0 -52
  94. package/dist/core-api/service/pagination.mjs.map +0 -1
  95. package/dist/core-api/service/single-type.js +0 -45
  96. package/dist/core-api/service/single-type.js.map +0 -1
  97. package/dist/core-api/service/single-type.mjs +0 -45
  98. package/dist/core-api/service/single-type.mjs.map +0 -1
  99. package/dist/domain/content-type/index.js +0 -111
  100. package/dist/domain/content-type/index.js.map +0 -1
  101. package/dist/domain/content-type/index.mjs +0 -109
  102. package/dist/domain/content-type/index.mjs.map +0 -1
  103. package/dist/domain/content-type/validator.js +0 -77
  104. package/dist/domain/content-type/validator.js.map +0 -1
  105. package/dist/domain/content-type/validator.mjs +0 -75
  106. package/dist/domain/content-type/validator.mjs.map +0 -1
  107. package/dist/domain/module/index.js +0 -107
  108. package/dist/domain/module/index.js.map +0 -1
  109. package/dist/domain/module/index.mjs +0 -105
  110. package/dist/domain/module/index.mjs.map +0 -1
  111. package/dist/domain/module/validation.js +0 -25
  112. package/dist/domain/module/validation.js.map +0 -1
  113. package/dist/domain/module/validation.mjs +0 -25
  114. package/dist/domain/module/validation.mjs.map +0 -1
  115. package/dist/ee/index.js +0 -158
  116. package/dist/ee/index.js.map +0 -1
  117. package/dist/ee/index.mjs +0 -159
  118. package/dist/ee/index.mjs.map +0 -1
  119. package/dist/ee/license.js +0 -91
  120. package/dist/ee/license.js.map +0 -1
  121. package/dist/ee/license.mjs +0 -88
  122. package/dist/ee/license.mjs.map +0 -1
  123. package/dist/factories.js +0 -80
  124. package/dist/factories.js.map +0 -1
  125. package/dist/factories.mjs +0 -80
  126. package/dist/factories.mjs.map +0 -1
  127. package/dist/loaders/admin.js +0 -26
  128. package/dist/loaders/admin.js.map +0 -1
  129. package/dist/loaders/admin.mjs +0 -25
  130. package/dist/loaders/admin.mjs.map +0 -1
  131. package/dist/loaders/apis.js +0 -137
  132. package/dist/loaders/apis.js.map +0 -1
  133. package/dist/loaders/apis.mjs +0 -135
  134. package/dist/loaders/apis.mjs.map +0 -1
  135. package/dist/loaders/components.js +0 -38
  136. package/dist/loaders/components.js.map +0 -1
  137. package/dist/loaders/components.mjs +0 -37
  138. package/dist/loaders/components.mjs.map +0 -1
  139. package/dist/loaders/index.js +0 -24
  140. package/dist/loaders/index.js.map +0 -1
  141. package/dist/loaders/index.mjs +0 -24
  142. package/dist/loaders/index.mjs.map +0 -1
  143. package/dist/loaders/middlewares.js +0 -31
  144. package/dist/loaders/middlewares.js.map +0 -1
  145. package/dist/loaders/middlewares.mjs +0 -30
  146. package/dist/loaders/middlewares.mjs.map +0 -1
  147. package/dist/loaders/plugins/get-enabled-plugins.js +0 -141
  148. package/dist/loaders/plugins/get-enabled-plugins.js.map +0 -1
  149. package/dist/loaders/plugins/get-enabled-plugins.mjs +0 -117
  150. package/dist/loaders/plugins/get-enabled-plugins.mjs.map +0 -1
  151. package/dist/loaders/plugins/get-user-plugins-config.js +0 -27
  152. package/dist/loaders/plugins/get-user-plugins-config.js.map +0 -1
  153. package/dist/loaders/plugins/get-user-plugins-config.mjs +0 -25
  154. package/dist/loaders/plugins/get-user-plugins-config.mjs.map +0 -1
  155. package/dist/loaders/plugins/index.js +0 -144
  156. package/dist/loaders/plugins/index.js.map +0 -1
  157. package/dist/loaders/plugins/index.mjs +0 -125
  158. package/dist/loaders/plugins/index.mjs.map +0 -1
  159. package/dist/loaders/policies.js +0 -25
  160. package/dist/loaders/policies.js.map +0 -1
  161. package/dist/loaders/policies.mjs +0 -24
  162. package/dist/loaders/policies.mjs.map +0 -1
  163. package/dist/loaders/sanitizers.js +0 -6
  164. package/dist/loaders/sanitizers.js.map +0 -1
  165. package/dist/loaders/sanitizers.mjs +0 -7
  166. package/dist/loaders/sanitizers.mjs.map +0 -1
  167. package/dist/loaders/src-index.js +0 -33
  168. package/dist/loaders/src-index.js.map +0 -1
  169. package/dist/loaders/src-index.mjs +0 -34
  170. package/dist/loaders/src-index.mjs.map +0 -1
  171. package/dist/loaders/validators.js +0 -6
  172. package/dist/loaders/validators.js.map +0 -1
  173. package/dist/loaders/validators.mjs +0 -7
  174. package/dist/loaders/validators.mjs.map +0 -1
  175. package/dist/middlewares/body.js +0 -65
  176. package/dist/middlewares/body.js.map +0 -1
  177. package/dist/middlewares/body.mjs +0 -61
  178. package/dist/middlewares/body.mjs.map +0 -1
  179. package/dist/middlewares/compression.js +0 -8
  180. package/dist/middlewares/compression.js.map +0 -1
  181. package/dist/middlewares/compression.mjs +0 -6
  182. package/dist/middlewares/compression.mjs.map +0 -1
  183. package/dist/middlewares/cors.js +0 -53
  184. package/dist/middlewares/cors.js.map +0 -1
  185. package/dist/middlewares/cors.mjs +0 -51
  186. package/dist/middlewares/cors.mjs.map +0 -1
  187. package/dist/middlewares/errors.js +0 -33
  188. package/dist/middlewares/errors.js.map +0 -1
  189. package/dist/middlewares/errors.mjs +0 -33
  190. package/dist/middlewares/errors.mjs.map +0 -1
  191. package/dist/middlewares/favicon.js +0 -22
  192. package/dist/middlewares/favicon.js.map +0 -1
  193. package/dist/middlewares/favicon.mjs +0 -20
  194. package/dist/middlewares/favicon.mjs.map +0 -1
  195. package/dist/middlewares/index.js +0 -34
  196. package/dist/middlewares/index.js.map +0 -1
  197. package/dist/middlewares/index.mjs +0 -34
  198. package/dist/middlewares/index.mjs.map +0 -1
  199. package/dist/middlewares/ip.js +0 -8
  200. package/dist/middlewares/ip.js.map +0 -1
  201. package/dist/middlewares/ip.mjs +0 -6
  202. package/dist/middlewares/ip.mjs.map +0 -1
  203. package/dist/middlewares/logger.js +0 -12
  204. package/dist/middlewares/logger.js.map +0 -1
  205. package/dist/middlewares/logger.mjs +0 -12
  206. package/dist/middlewares/logger.mjs.map +0 -1
  207. package/dist/middlewares/powered-by.js +0 -14
  208. package/dist/middlewares/powered-by.js.map +0 -1
  209. package/dist/middlewares/powered-by.mjs +0 -14
  210. package/dist/middlewares/powered-by.mjs.map +0 -1
  211. package/dist/middlewares/public.js +0 -34
  212. package/dist/middlewares/public.js.map +0 -1
  213. package/dist/middlewares/public.mjs +0 -32
  214. package/dist/middlewares/public.mjs.map +0 -1
  215. package/dist/middlewares/query.js +0 -40
  216. package/dist/middlewares/query.js.map +0 -1
  217. package/dist/middlewares/query.mjs +0 -38
  218. package/dist/middlewares/query.mjs.map +0 -1
  219. package/dist/middlewares/response-time.js +0 -12
  220. package/dist/middlewares/response-time.js.map +0 -1
  221. package/dist/middlewares/response-time.mjs +0 -12
  222. package/dist/middlewares/response-time.mjs.map +0 -1
  223. package/dist/middlewares/responses.js +0 -15
  224. package/dist/middlewares/responses.js.map +0 -1
  225. package/dist/middlewares/responses.mjs +0 -15
  226. package/dist/middlewares/responses.mjs.map +0 -1
  227. package/dist/middlewares/security.js +0 -78
  228. package/dist/middlewares/security.js.map +0 -1
  229. package/dist/middlewares/security.mjs +0 -76
  230. package/dist/middlewares/security.mjs.map +0 -1
  231. package/dist/middlewares/session.js +0 -30
  232. package/dist/middlewares/session.js.map +0 -1
  233. package/dist/middlewares/session.mjs +0 -28
  234. package/dist/middlewares/session.mjs.map +0 -1
  235. package/dist/migrations/database/5.0.0-discard-drafts.js +0 -109
  236. package/dist/migrations/database/5.0.0-discard-drafts.js.map +0 -1
  237. package/dist/migrations/database/5.0.0-discard-drafts.mjs +0 -109
  238. package/dist/migrations/database/5.0.0-discard-drafts.mjs.map +0 -1
  239. package/dist/migrations/draft-publish.js +0 -42
  240. package/dist/migrations/draft-publish.js.map +0 -1
  241. package/dist/migrations/draft-publish.mjs +0 -42
  242. package/dist/migrations/draft-publish.mjs.map +0 -1
  243. package/dist/migrations/i18n.js +0 -54
  244. package/dist/migrations/i18n.js.map +0 -1
  245. package/dist/migrations/i18n.mjs +0 -54
  246. package/dist/migrations/i18n.mjs.map +0 -1
  247. package/dist/migrations/index.js +0 -15
  248. package/dist/migrations/index.js.map +0 -1
  249. package/dist/migrations/index.mjs +0 -15
  250. package/dist/migrations/index.mjs.map +0 -1
  251. package/dist/providers/admin.js +0 -20
  252. package/dist/providers/admin.js.map +0 -1
  253. package/dist/providers/admin.mjs +0 -21
  254. package/dist/providers/admin.mjs.map +0 -1
  255. package/dist/providers/coreStore.js +0 -11
  256. package/dist/providers/coreStore.js.map +0 -1
  257. package/dist/providers/coreStore.mjs +0 -12
  258. package/dist/providers/coreStore.mjs.map +0 -1
  259. package/dist/providers/cron.js +0 -20
  260. package/dist/providers/cron.js.map +0 -1
  261. package/dist/providers/cron.mjs +0 -21
  262. package/dist/providers/cron.mjs.map +0 -1
  263. package/dist/providers/index.js +0 -11
  264. package/dist/providers/index.js.map +0 -1
  265. package/dist/providers/index.mjs +0 -11
  266. package/dist/providers/index.mjs.map +0 -1
  267. package/dist/providers/provider.js +0 -5
  268. package/dist/providers/provider.js.map +0 -1
  269. package/dist/providers/provider.mjs +0 -5
  270. package/dist/providers/provider.mjs.map +0 -1
  271. package/dist/providers/registries.js +0 -35
  272. package/dist/providers/registries.js.map +0 -1
  273. package/dist/providers/registries.mjs +0 -36
  274. package/dist/providers/registries.mjs.map +0 -1
  275. package/dist/providers/telemetry.js +0 -19
  276. package/dist/providers/telemetry.js.map +0 -1
  277. package/dist/providers/telemetry.mjs +0 -20
  278. package/dist/providers/telemetry.mjs.map +0 -1
  279. package/dist/providers/webhooks.js +0 -30
  280. package/dist/providers/webhooks.js.map +0 -1
  281. package/dist/providers/webhooks.mjs +0 -31
  282. package/dist/providers/webhooks.mjs.map +0 -1
  283. package/dist/registries/apis.js +0 -23
  284. package/dist/registries/apis.js.map +0 -1
  285. package/dist/registries/apis.mjs +0 -24
  286. package/dist/registries/apis.mjs.map +0 -1
  287. package/dist/registries/components.js +0 -45
  288. package/dist/registries/components.js.map +0 -1
  289. package/dist/registries/components.mjs +0 -46
  290. package/dist/registries/components.mjs.map +0 -1
  291. package/dist/registries/content-types.js +0 -70
  292. package/dist/registries/content-types.js.map +0 -1
  293. package/dist/registries/content-types.mjs +0 -71
  294. package/dist/registries/content-types.mjs.map +0 -1
  295. package/dist/registries/controllers.js +0 -80
  296. package/dist/registries/controllers.js.map +0 -1
  297. package/dist/registries/controllers.mjs +0 -81
  298. package/dist/registries/controllers.mjs.map +0 -1
  299. package/dist/registries/custom-fields.js +0 -71
  300. package/dist/registries/custom-fields.js.map +0 -1
  301. package/dist/registries/custom-fields.mjs +0 -72
  302. package/dist/registries/custom-fields.mjs.map +0 -1
  303. package/dist/registries/hooks.js +0 -58
  304. package/dist/registries/hooks.js.map +0 -1
  305. package/dist/registries/hooks.mjs +0 -59
  306. package/dist/registries/hooks.mjs.map +0 -1
  307. package/dist/registries/middlewares.js +0 -60
  308. package/dist/registries/middlewares.js.map +0 -1
  309. package/dist/registries/middlewares.mjs +0 -61
  310. package/dist/registries/middlewares.mjs.map +0 -1
  311. package/dist/registries/models.js +0 -16
  312. package/dist/registries/models.js.map +0 -1
  313. package/dist/registries/models.mjs +0 -16
  314. package/dist/registries/models.mjs.map +0 -1
  315. package/dist/registries/modules.js +0 -39
  316. package/dist/registries/modules.js.map +0 -1
  317. package/dist/registries/modules.mjs +0 -40
  318. package/dist/registries/modules.mjs.map +0 -1
  319. package/dist/registries/namespace.js +0 -27
  320. package/dist/registries/namespace.js.map +0 -1
  321. package/dist/registries/namespace.mjs +0 -27
  322. package/dist/registries/namespace.mjs.map +0 -1
  323. package/dist/registries/plugins.js +0 -23
  324. package/dist/registries/plugins.js.map +0 -1
  325. package/dist/registries/plugins.mjs +0 -24
  326. package/dist/registries/plugins.mjs.map +0 -1
  327. package/dist/registries/policies.js +0 -108
  328. package/dist/registries/policies.js.map +0 -1
  329. package/dist/registries/policies.mjs +0 -109
  330. package/dist/registries/policies.mjs.map +0 -1
  331. package/dist/registries/sanitizers.js +0 -25
  332. package/dist/registries/sanitizers.js.map +0 -1
  333. package/dist/registries/sanitizers.mjs +0 -24
  334. package/dist/registries/sanitizers.mjs.map +0 -1
  335. package/dist/registries/services.js +0 -80
  336. package/dist/registries/services.js.map +0 -1
  337. package/dist/registries/services.mjs +0 -81
  338. package/dist/registries/services.mjs.map +0 -1
  339. package/dist/registries/validators.js +0 -25
  340. package/dist/registries/validators.js.map +0 -1
  341. package/dist/registries/validators.mjs +0 -24
  342. package/dist/registries/validators.mjs.map +0 -1
  343. package/dist/services/auth/index.js +0 -81
  344. package/dist/services/auth/index.js.map +0 -1
  345. package/dist/services/auth/index.mjs +0 -80
  346. package/dist/services/auth/index.mjs.map +0 -1
  347. package/dist/services/config.js +0 -47
  348. package/dist/services/config.js.map +0 -1
  349. package/dist/services/config.mjs +0 -47
  350. package/dist/services/config.mjs.map +0 -1
  351. package/dist/services/content-api/index.js +0 -85
  352. package/dist/services/content-api/index.js.map +0 -1
  353. package/dist/services/content-api/index.mjs +0 -84
  354. package/dist/services/content-api/index.mjs.map +0 -1
  355. package/dist/services/content-api/permissions/engine.js +0 -7
  356. package/dist/services/content-api/permissions/engine.js.map +0 -1
  357. package/dist/services/content-api/permissions/engine.mjs +0 -6
  358. package/dist/services/content-api/permissions/engine.mjs.map +0 -1
  359. package/dist/services/content-api/permissions/index.js +0 -87
  360. package/dist/services/content-api/permissions/index.js.map +0 -1
  361. package/dist/services/content-api/permissions/index.mjs +0 -86
  362. package/dist/services/content-api/permissions/index.mjs.map +0 -1
  363. package/dist/services/content-api/permissions/providers/action.js +0 -16
  364. package/dist/services/content-api/permissions/providers/action.js.map +0 -1
  365. package/dist/services/content-api/permissions/providers/action.mjs +0 -17
  366. package/dist/services/content-api/permissions/providers/action.mjs.map +0 -1
  367. package/dist/services/content-api/permissions/providers/condition.js +0 -16
  368. package/dist/services/content-api/permissions/providers/condition.js.map +0 -1
  369. package/dist/services/content-api/permissions/providers/condition.mjs +0 -17
  370. package/dist/services/content-api/permissions/providers/condition.mjs.map +0 -1
  371. package/dist/services/core-store.js +0 -107
  372. package/dist/services/core-store.js.map +0 -1
  373. package/dist/services/core-store.mjs +0 -107
  374. package/dist/services/core-store.mjs.map +0 -1
  375. package/dist/services/cron.js +0 -67
  376. package/dist/services/cron.js.map +0 -1
  377. package/dist/services/cron.mjs +0 -68
  378. package/dist/services/cron.mjs.map +0 -1
  379. package/dist/services/custom-fields.js +0 -10
  380. package/dist/services/custom-fields.js.map +0 -1
  381. package/dist/services/custom-fields.mjs +0 -11
  382. package/dist/services/custom-fields.mjs.map +0 -1
  383. package/dist/services/document-service/attributes/index.js +0 -22
  384. package/dist/services/document-service/attributes/index.js.map +0 -1
  385. package/dist/services/document-service/attributes/index.mjs +0 -22
  386. package/dist/services/document-service/attributes/index.mjs.map +0 -1
  387. package/dist/services/document-service/attributes/transforms.js +0 -20
  388. package/dist/services/document-service/attributes/transforms.js.map +0 -1
  389. package/dist/services/document-service/attributes/transforms.mjs +0 -19
  390. package/dist/services/document-service/attributes/transforms.mjs.map +0 -1
  391. package/dist/services/document-service/common.js +0 -7
  392. package/dist/services/document-service/common.js.map +0 -1
  393. package/dist/services/document-service/common.mjs +0 -7
  394. package/dist/services/document-service/common.mjs.map +0 -1
  395. package/dist/services/document-service/components.js +0 -288
  396. package/dist/services/document-service/components.js.map +0 -1
  397. package/dist/services/document-service/components.mjs +0 -286
  398. package/dist/services/document-service/components.mjs.map +0 -1
  399. package/dist/services/document-service/draft-and-publish.js +0 -69
  400. package/dist/services/document-service/draft-and-publish.js.map +0 -1
  401. package/dist/services/document-service/draft-and-publish.mjs +0 -69
  402. package/dist/services/document-service/draft-and-publish.mjs.map +0 -1
  403. package/dist/services/document-service/entries.js +0 -95
  404. package/dist/services/document-service/entries.js.map +0 -1
  405. package/dist/services/document-service/entries.mjs +0 -95
  406. package/dist/services/document-service/entries.mjs.map +0 -1
  407. package/dist/services/document-service/events.js +0 -47
  408. package/dist/services/document-service/events.js.map +0 -1
  409. package/dist/services/document-service/events.mjs +0 -47
  410. package/dist/services/document-service/events.mjs.map +0 -1
  411. package/dist/services/document-service/index.js +0 -36
  412. package/dist/services/document-service/index.js.map +0 -1
  413. package/dist/services/document-service/index.mjs +0 -36
  414. package/dist/services/document-service/index.mjs.map +0 -1
  415. package/dist/services/document-service/internationalization.js +0 -63
  416. package/dist/services/document-service/internationalization.js.map +0 -1
  417. package/dist/services/document-service/internationalization.mjs +0 -63
  418. package/dist/services/document-service/internationalization.mjs.map +0 -1
  419. package/dist/services/document-service/middlewares/errors.js +0 -25
  420. package/dist/services/document-service/middlewares/errors.js.map +0 -1
  421. package/dist/services/document-service/middlewares/errors.mjs +0 -25
  422. package/dist/services/document-service/middlewares/errors.mjs.map +0 -1
  423. package/dist/services/document-service/middlewares/middleware-manager.js +0 -49
  424. package/dist/services/document-service/middlewares/middleware-manager.js.map +0 -1
  425. package/dist/services/document-service/middlewares/middleware-manager.mjs +0 -49
  426. package/dist/services/document-service/middlewares/middleware-manager.mjs.map +0 -1
  427. package/dist/services/document-service/params.js +0 -8
  428. package/dist/services/document-service/params.js.map +0 -1
  429. package/dist/services/document-service/params.mjs +0 -8
  430. package/dist/services/document-service/params.mjs.map +0 -1
  431. package/dist/services/document-service/repository.js +0 -332
  432. package/dist/services/document-service/repository.js.map +0 -1
  433. package/dist/services/document-service/repository.mjs +0 -332
  434. package/dist/services/document-service/repository.mjs.map +0 -1
  435. package/dist/services/document-service/transform/data.js +0 -15
  436. package/dist/services/document-service/transform/data.js.map +0 -1
  437. package/dist/services/document-service/transform/data.mjs +0 -15
  438. package/dist/services/document-service/transform/data.mjs.map +0 -1
  439. package/dist/services/document-service/transform/fields.js +0 -24
  440. package/dist/services/document-service/transform/fields.js.map +0 -1
  441. package/dist/services/document-service/transform/fields.mjs +0 -24
  442. package/dist/services/document-service/transform/fields.mjs.map +0 -1
  443. package/dist/services/document-service/transform/id-map.js +0 -85
  444. package/dist/services/document-service/transform/id-map.js.map +0 -1
  445. package/dist/services/document-service/transform/id-map.mjs +0 -85
  446. package/dist/services/document-service/transform/id-map.mjs.map +0 -1
  447. package/dist/services/document-service/transform/id-transform.js +0 -33
  448. package/dist/services/document-service/transform/id-transform.js.map +0 -1
  449. package/dist/services/document-service/transform/id-transform.mjs +0 -33
  450. package/dist/services/document-service/transform/id-transform.mjs.map +0 -1
  451. package/dist/services/document-service/transform/populate.js +0 -21
  452. package/dist/services/document-service/transform/populate.js.map +0 -1
  453. package/dist/services/document-service/transform/populate.mjs +0 -21
  454. package/dist/services/document-service/transform/populate.mjs.map +0 -1
  455. package/dist/services/document-service/transform/query.js +0 -9
  456. package/dist/services/document-service/transform/query.js.map +0 -1
  457. package/dist/services/document-service/transform/query.mjs +0 -9
  458. package/dist/services/document-service/transform/query.mjs.map +0 -1
  459. package/dist/services/document-service/transform/relations/extract/data-ids.js +0 -64
  460. package/dist/services/document-service/transform/relations/extract/data-ids.js.map +0 -1
  461. package/dist/services/document-service/transform/relations/extract/data-ids.mjs +0 -64
  462. package/dist/services/document-service/transform/relations/extract/data-ids.mjs.map +0 -1
  463. package/dist/services/document-service/transform/relations/transform/data-ids.js +0 -85
  464. package/dist/services/document-service/transform/relations/transform/data-ids.js.map +0 -1
  465. package/dist/services/document-service/transform/relations/transform/data-ids.mjs +0 -85
  466. package/dist/services/document-service/transform/relations/transform/data-ids.mjs.map +0 -1
  467. package/dist/services/document-service/transform/relations/transform/default-locale.js +0 -32
  468. package/dist/services/document-service/transform/relations/transform/default-locale.js.map +0 -1
  469. package/dist/services/document-service/transform/relations/transform/default-locale.mjs +0 -32
  470. package/dist/services/document-service/transform/relations/transform/default-locale.mjs.map +0 -1
  471. package/dist/services/document-service/transform/relations/utils/dp.js +0 -30
  472. package/dist/services/document-service/transform/relations/utils/dp.js.map +0 -1
  473. package/dist/services/document-service/transform/relations/utils/dp.mjs +0 -30
  474. package/dist/services/document-service/transform/relations/utils/dp.mjs.map +0 -1
  475. package/dist/services/document-service/transform/relations/utils/i18n.js +0 -25
  476. package/dist/services/document-service/transform/relations/utils/i18n.js.map +0 -1
  477. package/dist/services/document-service/transform/relations/utils/i18n.mjs +0 -25
  478. package/dist/services/document-service/transform/relations/utils/i18n.mjs.map +0 -1
  479. package/dist/services/document-service/transform/relations/utils/map-relation.js +0 -84
  480. package/dist/services/document-service/transform/relations/utils/map-relation.js.map +0 -1
  481. package/dist/services/document-service/transform/relations/utils/map-relation.mjs +0 -84
  482. package/dist/services/document-service/transform/relations/utils/map-relation.mjs.map +0 -1
  483. package/dist/services/document-service/utils/populate.js +0 -47
  484. package/dist/services/document-service/utils/populate.js.map +0 -1
  485. package/dist/services/document-service/utils/populate.mjs +0 -47
  486. package/dist/services/document-service/utils/populate.mjs.map +0 -1
  487. package/dist/services/document-service/utils/unidirectional-relations.js +0 -68
  488. package/dist/services/document-service/utils/unidirectional-relations.js.map +0 -1
  489. package/dist/services/document-service/utils/unidirectional-relations.mjs +0 -68
  490. package/dist/services/document-service/utils/unidirectional-relations.mjs.map +0 -1
  491. package/dist/services/entity-service/index.js +0 -169
  492. package/dist/services/entity-service/index.js.map +0 -1
  493. package/dist/services/entity-service/index.mjs +0 -167
  494. package/dist/services/entity-service/index.mjs.map +0 -1
  495. package/dist/services/entity-validator/blocks-validator.js +0 -128
  496. package/dist/services/entity-validator/blocks-validator.js.map +0 -1
  497. package/dist/services/entity-validator/blocks-validator.mjs +0 -128
  498. package/dist/services/entity-validator/blocks-validator.mjs.map +0 -1
  499. package/dist/services/entity-validator/index.js +0 -389
  500. package/dist/services/entity-validator/index.js.map +0 -1
  501. package/dist/services/entity-validator/index.mjs +0 -388
  502. package/dist/services/entity-validator/index.mjs.map +0 -1
  503. package/dist/services/entity-validator/validators.js +0 -241
  504. package/dist/services/entity-validator/validators.js.map +0 -1
  505. package/dist/services/entity-validator/validators.mjs +0 -239
  506. package/dist/services/entity-validator/validators.mjs.map +0 -1
  507. package/dist/services/errors.js +0 -76
  508. package/dist/services/errors.js.map +0 -1
  509. package/dist/services/errors.mjs +0 -74
  510. package/dist/services/errors.mjs.map +0 -1
  511. package/dist/services/event-hub.js +0 -72
  512. package/dist/services/event-hub.js.map +0 -1
  513. package/dist/services/event-hub.mjs +0 -73
  514. package/dist/services/event-hub.mjs.map +0 -1
  515. package/dist/services/features.js +0 -17
  516. package/dist/services/features.js.map +0 -1
  517. package/dist/services/features.mjs +0 -17
  518. package/dist/services/features.mjs.map +0 -1
  519. package/dist/services/fs.js +0 -51
  520. package/dist/services/fs.js.map +0 -1
  521. package/dist/services/fs.mjs +0 -49
  522. package/dist/services/fs.mjs.map +0 -1
  523. package/dist/services/metrics/admin-user-hash.js +0 -14
  524. package/dist/services/metrics/admin-user-hash.js.map +0 -1
  525. package/dist/services/metrics/admin-user-hash.mjs +0 -12
  526. package/dist/services/metrics/admin-user-hash.mjs.map +0 -1
  527. package/dist/services/metrics/index.js +0 -44
  528. package/dist/services/metrics/index.js.map +0 -1
  529. package/dist/services/metrics/index.mjs +0 -45
  530. package/dist/services/metrics/index.mjs.map +0 -1
  531. package/dist/services/metrics/is-truthy.js +0 -9
  532. package/dist/services/metrics/is-truthy.js.map +0 -1
  533. package/dist/services/metrics/is-truthy.mjs +0 -8
  534. package/dist/services/metrics/is-truthy.mjs.map +0 -1
  535. package/dist/services/metrics/middleware.js +0 -27
  536. package/dist/services/metrics/middleware.js.map +0 -1
  537. package/dist/services/metrics/middleware.mjs +0 -28
  538. package/dist/services/metrics/middleware.mjs.map +0 -1
  539. package/dist/services/metrics/rate-limiter.js +0 -24
  540. package/dist/services/metrics/rate-limiter.js.map +0 -1
  541. package/dist/services/metrics/rate-limiter.mjs +0 -25
  542. package/dist/services/metrics/rate-limiter.mjs.map +0 -1
  543. package/dist/services/metrics/sender.js +0 -76
  544. package/dist/services/metrics/sender.js.map +0 -1
  545. package/dist/services/metrics/sender.mjs +0 -70
  546. package/dist/services/metrics/sender.mjs.map +0 -1
  547. package/dist/services/query-params.js +0 -12
  548. package/dist/services/query-params.js.map +0 -1
  549. package/dist/services/query-params.mjs +0 -13
  550. package/dist/services/query-params.mjs.map +0 -1
  551. package/dist/services/reloader.js +0 -36
  552. package/dist/services/reloader.js.map +0 -1
  553. package/dist/services/reloader.mjs +0 -36
  554. package/dist/services/reloader.mjs.map +0 -1
  555. package/dist/services/request-context.js +0 -13
  556. package/dist/services/request-context.js.map +0 -1
  557. package/dist/services/request-context.mjs +0 -14
  558. package/dist/services/request-context.mjs.map +0 -1
  559. package/dist/services/server/admin-api.js +0 -13
  560. package/dist/services/server/admin-api.js.map +0 -1
  561. package/dist/services/server/admin-api.mjs +0 -13
  562. package/dist/services/server/admin-api.mjs.map +0 -1
  563. package/dist/services/server/api.js +0 -30
  564. package/dist/services/server/api.js.map +0 -1
  565. package/dist/services/server/api.mjs +0 -28
  566. package/dist/services/server/api.mjs.map +0 -1
  567. package/dist/services/server/compose-endpoint.js +0 -117
  568. package/dist/services/server/compose-endpoint.js.map +0 -1
  569. package/dist/services/server/compose-endpoint.mjs +0 -116
  570. package/dist/services/server/compose-endpoint.mjs.map +0 -1
  571. package/dist/services/server/content-api.js +0 -12
  572. package/dist/services/server/content-api.js.map +0 -1
  573. package/dist/services/server/content-api.mjs +0 -12
  574. package/dist/services/server/content-api.mjs.map +0 -1
  575. package/dist/services/server/http-server.js +0 -50
  576. package/dist/services/server/http-server.js.map +0 -1
  577. package/dist/services/server/http-server.mjs +0 -48
  578. package/dist/services/server/http-server.mjs.map +0 -1
  579. package/dist/services/server/index.js +0 -87
  580. package/dist/services/server/index.js.map +0 -1
  581. package/dist/services/server/index.mjs +0 -85
  582. package/dist/services/server/index.mjs.map +0 -1
  583. package/dist/services/server/koa.js +0 -52
  584. package/dist/services/server/koa.js.map +0 -1
  585. package/dist/services/server/koa.mjs +0 -48
  586. package/dist/services/server/koa.mjs.map +0 -1
  587. package/dist/services/server/middleware.js +0 -92
  588. package/dist/services/server/middleware.js.map +0 -1
  589. package/dist/services/server/middleware.mjs +0 -90
  590. package/dist/services/server/middleware.mjs.map +0 -1
  591. package/dist/services/server/policy.js +0 -20
  592. package/dist/services/server/policy.js.map +0 -1
  593. package/dist/services/server/policy.mjs +0 -20
  594. package/dist/services/server/policy.mjs.map +0 -1
  595. package/dist/services/server/register-middlewares.js +0 -72
  596. package/dist/services/server/register-middlewares.js.map +0 -1
  597. package/dist/services/server/register-middlewares.mjs +0 -73
  598. package/dist/services/server/register-middlewares.mjs.map +0 -1
  599. package/dist/services/server/register-routes.js +0 -76
  600. package/dist/services/server/register-routes.js.map +0 -1
  601. package/dist/services/server/register-routes.mjs +0 -75
  602. package/dist/services/server/register-routes.mjs.map +0 -1
  603. package/dist/services/server/routing.js +0 -91
  604. package/dist/services/server/routing.js.map +0 -1
  605. package/dist/services/server/routing.mjs +0 -89
  606. package/dist/services/server/routing.mjs.map +0 -1
  607. package/dist/services/utils/dynamic-zones.js +0 -17
  608. package/dist/services/utils/dynamic-zones.js.map +0 -1
  609. package/dist/services/utils/dynamic-zones.mjs +0 -18
  610. package/dist/services/utils/dynamic-zones.mjs.map +0 -1
  611. package/dist/services/webhook-runner.js +0 -133
  612. package/dist/services/webhook-runner.js.map +0 -1
  613. package/dist/services/webhook-runner.mjs +0 -131
  614. package/dist/services/webhook-runner.mjs.map +0 -1
  615. package/dist/services/webhook-store.js +0 -110
  616. package/dist/services/webhook-store.js.map +0 -1
  617. package/dist/services/webhook-store.mjs +0 -110
  618. package/dist/services/webhook-store.mjs.map +0 -1
  619. package/dist/services/worker-queue.js +0 -56
  620. package/dist/services/worker-queue.js.map +0 -1
  621. package/dist/services/worker-queue.mjs +0 -55
  622. package/dist/services/worker-queue.mjs.map +0 -1
  623. package/dist/utils/convert-custom-field-type.js +0 -24
  624. package/dist/utils/convert-custom-field-type.js.map +0 -1
  625. package/dist/utils/convert-custom-field-type.mjs +0 -24
  626. package/dist/utils/convert-custom-field-type.mjs.map +0 -1
  627. package/dist/utils/cron.js +0 -38
  628. package/dist/utils/cron.js.map +0 -1
  629. package/dist/utils/cron.mjs +0 -38
  630. package/dist/utils/cron.mjs.map +0 -1
  631. package/dist/utils/fetch.js +0 -21
  632. package/dist/utils/fetch.js.map +0 -1
  633. package/dist/utils/fetch.mjs +0 -21
  634. package/dist/utils/fetch.mjs.map +0 -1
  635. package/dist/utils/filepath-to-prop-path.js +0 -33
  636. package/dist/utils/filepath-to-prop-path.js.map +0 -1
  637. package/dist/utils/filepath-to-prop-path.mjs +0 -30
  638. package/dist/utils/filepath-to-prop-path.mjs.map +0 -1
  639. package/dist/utils/is-initialized.js +0 -16
  640. package/dist/utils/is-initialized.js.map +0 -1
  641. package/dist/utils/is-initialized.mjs +0 -16
  642. package/dist/utils/is-initialized.mjs.map +0 -1
  643. package/dist/utils/lifecycles.js +0 -9
  644. package/dist/utils/lifecycles.js.map +0 -1
  645. package/dist/utils/lifecycles.mjs +0 -9
  646. package/dist/utils/lifecycles.mjs.map +0 -1
  647. package/dist/utils/load-config-file.js +0 -45
  648. package/dist/utils/load-config-file.js.map +0 -1
  649. package/dist/utils/load-config-file.mjs +0 -42
  650. package/dist/utils/load-config-file.mjs.map +0 -1
  651. package/dist/utils/load-files.js +0 -38
  652. package/dist/utils/load-files.js.map +0 -1
  653. package/dist/utils/load-files.mjs +0 -34
  654. package/dist/utils/load-files.mjs.map +0 -1
  655. package/dist/utils/open-browser.js +0 -11
  656. package/dist/utils/open-browser.js.map +0 -1
  657. package/dist/utils/open-browser.mjs +0 -9
  658. package/dist/utils/open-browser.mjs.map +0 -1
  659. package/dist/utils/resolve-working-dirs.js +0 -13
  660. package/dist/utils/resolve-working-dirs.js.map +0 -1
  661. package/dist/utils/resolve-working-dirs.mjs +0 -11
  662. package/dist/utils/resolve-working-dirs.mjs.map +0 -1
  663. package/dist/utils/signals.js +0 -17
  664. package/dist/utils/signals.js.map +0 -1
  665. package/dist/utils/signals.mjs +0 -17
  666. package/dist/utils/signals.mjs.map +0 -1
  667. package/dist/utils/startup-logger.js +0 -86
  668. package/dist/utils/startup-logger.js.map +0 -1
  669. package/dist/utils/startup-logger.mjs +0 -82
  670. package/dist/utils/startup-logger.mjs.map +0 -1
  671. package/dist/utils/transform-content-types-to-models.js +0 -288
  672. package/dist/utils/transform-content-types-to-models.js.map +0 -1
  673. package/dist/utils/transform-content-types-to-models.mjs +0 -285
  674. package/dist/utils/transform-content-types-to-models.mjs.map +0 -1
  675. package/dist/utils/update-notifier/index.js +0 -85
  676. package/dist/utils/update-notifier/index.js.map +0 -1
  677. package/dist/utils/update-notifier/index.mjs +0 -78
  678. package/dist/utils/update-notifier/index.mjs.map +0 -1
@@ -1 +0,0 @@
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 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 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":["_","value","options","yup","blocksValidator"],"mappings":"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"}
@@ -1,239 +0,0 @@
1
- import _ from "lodash";
2
- import { yup } from "@strapi/utils";
3
- import { blocksValidator } from "./blocks-validator.mjs";
4
- const addMinLengthValidator = (validator, {
5
- attr
6
- }, { isDraft }) => {
7
- return attr.minLength && _.isInteger(attr.minLength) && !isDraft ? validator.min(attr.minLength) : validator;
8
- };
9
- const addMaxLengthValidator = (validator, {
10
- attr
11
- }) => {
12
- return attr.maxLength && _.isInteger(attr.maxLength) ? validator.max(attr.maxLength) : validator;
13
- };
14
- const addMinIntegerValidator = (validator, {
15
- attr
16
- }, { isDraft }) => _.isNumber(attr.min) && !isDraft ? validator.min(_.toInteger(attr.min)) : validator;
17
- const addMaxIntegerValidator = (validator, {
18
- attr
19
- }) => _.isNumber(attr.max) ? validator.max(_.toInteger(attr.max)) : validator;
20
- const addMinFloatValidator = (validator, {
21
- attr
22
- }, { isDraft }) => _.isNumber(attr.min) && !isDraft ? validator.min(attr.min) : validator;
23
- const addMaxFloatValidator = (validator, {
24
- attr
25
- }) => _.isNumber(attr.max) ? validator.max(attr.max) : validator;
26
- const addStringRegexValidator = (validator, {
27
- attr
28
- }, { isDraft }) => {
29
- return "regex" in attr && !_.isUndefined(attr.regex) && !isDraft ? validator.matches(new RegExp(attr.regex), { excludeEmptyString: !attr.required }) : validator;
30
- };
31
- const addUniqueValidator = (validator, {
32
- attr,
33
- model,
34
- updatedAttribute,
35
- entity,
36
- componentContext
37
- }, options) => {
38
- if (attr.type !== "uid" && !attr.unique) {
39
- return validator;
40
- }
41
- const validateUniqueFieldWithinComponent = async (value) => {
42
- if (!componentContext) {
43
- return false;
44
- }
45
- const hasRepeatableData = componentContext.repeatableData.length > 0;
46
- if (hasRepeatableData) {
47
- const { name: updatedName, value: updatedValue } = updatedAttribute;
48
- const pathToCheck = [...componentContext.pathToComponent.slice(1), updatedName].join(".");
49
- const values = componentContext.repeatableData.map((item) => {
50
- return pathToCheck.split(".").reduce((acc, key) => acc[key], item);
51
- });
52
- const isUpdatedAttributeRepeatedInThisEntity = values.filter((value2) => value2 === updatedValue).length > 1;
53
- if (isUpdatedAttributeRepeatedInThisEntity) {
54
- return false;
55
- }
56
- }
57
- const {
58
- model: parentModel,
59
- options: parentOptions,
60
- id: excludeId
61
- } = componentContext.parentContent;
62
- const whereConditions = {};
63
- const isParentDraft = parentOptions && parentOptions.isDraft;
64
- whereConditions.publishedAt = isParentDraft ? null : { $notNull: true };
65
- if (parentOptions?.locale) {
66
- whereConditions.locale = parentOptions.locale;
67
- }
68
- if (excludeId && !Number.isNaN(excludeId)) {
69
- whereConditions.id = { $ne: excludeId };
70
- }
71
- const queryUid = parentModel.uid;
72
- const queryWhere = {
73
- ...componentContext.pathToComponent.reduceRight((acc, key) => ({ [key]: acc }), {
74
- [updatedAttribute.name]: value
75
- }),
76
- ...whereConditions
77
- };
78
- return !await strapi.db.query(queryUid).findOne({ where: queryWhere });
79
- };
80
- const validateUniqueFieldWithinDynamicZoneComponent = async (startOfPath) => {
81
- if (!componentContext) {
82
- return false;
83
- }
84
- const targetComponentUID = model.uid;
85
- const countOfValueInThisEntity = (componentContext?.fullDynamicZoneContent ?? []).reduce(
86
- (acc, component) => {
87
- if (component.__component !== targetComponentUID) {
88
- return acc;
89
- }
90
- const updatedValue = component[updatedAttribute.name];
91
- return updatedValue === updatedAttribute.value ? acc + 1 : acc;
92
- },
93
- 0
94
- );
95
- if (countOfValueInThisEntity > 1) {
96
- return false;
97
- }
98
- const query = {
99
- select: ["id"],
100
- where: {},
101
- populate: {
102
- [startOfPath]: {
103
- on: {
104
- [targetComponentUID]: {
105
- select: ["id"],
106
- where: { [updatedAttribute.name]: updatedAttribute.value }
107
- }
108
- }
109
- }
110
- }
111
- };
112
- const { options: options2, id } = componentContext.parentContent;
113
- if (options2?.isDraft !== void 0) {
114
- query.where.published_at = options2.isDraft ? { $eq: null } : { $ne: null };
115
- }
116
- if (id) {
117
- query.where.id = { $ne: id };
118
- }
119
- if (options2?.locale) {
120
- query.where.locale = options2.locale;
121
- }
122
- const parentModelQueryResult = await strapi.db.query(componentContext.parentContent.model.uid).findMany(query);
123
- const filteredResults = parentModelQueryResult.filter((result) => Array.isArray(result[startOfPath]) && result[startOfPath].length).flatMap((result) => result[startOfPath]).filter((dynamicZoneComponent) => dynamicZoneComponent.__component === targetComponentUID);
124
- if (filteredResults.length >= 1) {
125
- return false;
126
- }
127
- return true;
128
- };
129
- return validator.test("unique", "This attribute must be unique", async (value) => {
130
- if (_.isNil(value) || value === "") {
131
- return true;
132
- }
133
- if (options.isDraft) {
134
- return true;
135
- }
136
- const hasPathToComponent = componentContext && componentContext.pathToComponent.length > 0;
137
- if (hasPathToComponent) {
138
- const startOfPath = componentContext.pathToComponent[0];
139
- const testingDZ = componentContext.parentContent.model.attributes[startOfPath].type === "dynamiczone";
140
- if (testingDZ) {
141
- return validateUniqueFieldWithinDynamicZoneComponent(startOfPath);
142
- }
143
- return validateUniqueFieldWithinComponent(value);
144
- }
145
- const scalarAttributeWhere = {
146
- [updatedAttribute.name]: value,
147
- publishedAt: { $notNull: true }
148
- };
149
- if (options?.locale) {
150
- scalarAttributeWhere.locale = options.locale;
151
- }
152
- if (entity?.id) {
153
- scalarAttributeWhere.id = { $ne: entity.id };
154
- }
155
- return !await strapi.db.query(model.uid).findOne({ where: scalarAttributeWhere, select: ["id"] });
156
- });
157
- };
158
- const stringValidator = (metas, options) => {
159
- let schema = yup.string().transform((val, originalVal) => originalVal);
160
- schema = addMinLengthValidator(schema, metas, options);
161
- schema = addMaxLengthValidator(schema, metas);
162
- schema = addStringRegexValidator(schema, metas, options);
163
- schema = addUniqueValidator(schema, metas, options);
164
- return schema;
165
- };
166
- const emailValidator = (metas, options) => {
167
- const schema = stringValidator(metas, options);
168
- if (options.isDraft) {
169
- return schema;
170
- }
171
- return schema.email().min(
172
- 1,
173
- // eslint-disable-next-line no-template-curly-in-string
174
- "${path} cannot be empty"
175
- );
176
- };
177
- const uidValidator = (metas, options) => {
178
- const schema = stringValidator(metas, options);
179
- if (options.isDraft) {
180
- return schema;
181
- }
182
- return schema.matches(/^[A-Za-z0-9-_.~]*$/);
183
- };
184
- const enumerationValidator = ({ attr }) => {
185
- return yup.string().oneOf((Array.isArray(attr.enum) ? attr.enum : [attr.enum]).concat(null));
186
- };
187
- const integerValidator = (metas, options) => {
188
- let schema = yup.number().integer();
189
- schema = addMinIntegerValidator(schema, metas, options);
190
- schema = addMaxIntegerValidator(schema, metas);
191
- schema = addUniqueValidator(schema, metas, options);
192
- return schema;
193
- };
194
- const floatValidator = (metas, options) => {
195
- let schema = yup.number();
196
- schema = addMinFloatValidator(schema, metas, options);
197
- schema = addMaxFloatValidator(schema, metas);
198
- schema = addUniqueValidator(schema, metas, options);
199
- return schema;
200
- };
201
- const bigintegerValidator = (metas, options) => {
202
- const schema = yup.mixed();
203
- return addUniqueValidator(schema, metas, options);
204
- };
205
- const datesValidator = (metas, options) => {
206
- const schema = yup.mixed();
207
- return addUniqueValidator(schema, metas, options);
208
- };
209
- const Validators = {
210
- string: stringValidator,
211
- text: stringValidator,
212
- richtext: stringValidator,
213
- password: stringValidator,
214
- email: emailValidator,
215
- enumeration: enumerationValidator,
216
- boolean: () => yup.boolean(),
217
- uid: uidValidator,
218
- json: () => yup.mixed(),
219
- integer: integerValidator,
220
- biginteger: bigintegerValidator,
221
- float: floatValidator,
222
- decimal: floatValidator,
223
- date: datesValidator,
224
- time: datesValidator,
225
- datetime: datesValidator,
226
- timestamp: datesValidator,
227
- blocks: blocksValidator
228
- };
229
- export {
230
- Validators,
231
- bigintegerValidator,
232
- datesValidator,
233
- emailValidator,
234
- enumerationValidator,
235
- floatValidator,
236
- integerValidator,
237
- uidValidator
238
- };
239
- //# sourceMappingURL=validators.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"validators.mjs","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 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 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":["value","options"],"mappings":"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"}
@@ -1,76 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const createError = require("http-errors");
4
- const strapiUtils = require("@strapi/utils");
5
- const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
6
- const createError__default = /* @__PURE__ */ _interopDefault(createError);
7
- const mapErrorsAndStatus = [
8
- {
9
- classError: strapiUtils.errors.UnauthorizedError,
10
- status: 401
11
- },
12
- {
13
- classError: strapiUtils.errors.ForbiddenError,
14
- status: 403
15
- },
16
- {
17
- classError: strapiUtils.errors.NotFoundError,
18
- status: 404
19
- },
20
- {
21
- classError: strapiUtils.errors.PayloadTooLargeError,
22
- status: 413
23
- },
24
- {
25
- classError: strapiUtils.errors.RateLimitError,
26
- status: 429
27
- },
28
- {
29
- classError: strapiUtils.errors.NotImplementedError,
30
- status: 501
31
- }
32
- ];
33
- const formatApplicationError = (error) => {
34
- const errorAndStatus = mapErrorsAndStatus.find((pair) => error instanceof pair.classError);
35
- const status = errorAndStatus ? errorAndStatus.status : 400;
36
- return {
37
- status,
38
- body: {
39
- data: null,
40
- error: {
41
- status,
42
- name: error.name,
43
- message: error.message,
44
- details: error.details
45
- }
46
- }
47
- };
48
- };
49
- const formatHttpError = (error) => {
50
- return {
51
- status: error.status,
52
- body: {
53
- data: null,
54
- error: {
55
- status: error.status,
56
- name: error.name,
57
- message: error.message,
58
- details: error.details
59
- }
60
- }
61
- };
62
- };
63
- const formatInternalError = (error) => {
64
- if (!(error instanceof Error)) {
65
- return formatHttpError(createError__default.default(500));
66
- }
67
- const httpError = createError__default.default(error);
68
- if (httpError.expose) {
69
- return formatHttpError(httpError);
70
- }
71
- return formatHttpError(createError__default.default(httpError.status || 500));
72
- };
73
- exports.formatApplicationError = formatApplicationError;
74
- exports.formatHttpError = formatHttpError;
75
- exports.formatInternalError = formatInternalError;
76
- //# sourceMappingURL=errors.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"errors.js","sources":["../../src/services/errors.ts"],"sourcesContent":["import createError from 'http-errors';\nimport { errors } from '@strapi/utils';\n\nconst mapErrorsAndStatus = [\n {\n classError: errors.UnauthorizedError,\n status: 401,\n },\n {\n classError: errors.ForbiddenError,\n status: 403,\n },\n {\n classError: errors.NotFoundError,\n status: 404,\n },\n {\n classError: errors.PayloadTooLargeError,\n status: 413,\n },\n {\n classError: errors.RateLimitError,\n status: 429,\n },\n {\n classError: errors.NotImplementedError,\n status: 501,\n },\n];\n\nconst formatApplicationError = (error: InstanceType<typeof errors.ApplicationError>) => {\n const errorAndStatus = mapErrorsAndStatus.find((pair) => error instanceof pair.classError);\n const status = errorAndStatus ? errorAndStatus.status : 400;\n\n return {\n status,\n body: {\n data: null,\n error: {\n status,\n name: error.name,\n message: error.message,\n details: error.details,\n },\n },\n };\n};\n\nconst formatHttpError = (error: createError.HttpError) => {\n return {\n status: error.status,\n body: {\n data: null,\n error: {\n status: error.status,\n name: error.name,\n message: error.message,\n details: error.details,\n },\n },\n };\n};\n\nconst formatInternalError = (error: unknown) => {\n if (!(error instanceof Error)) {\n return formatHttpError(createError(500));\n }\n\n const httpError = createError(error);\n\n if (httpError.expose) {\n return formatHttpError(httpError);\n }\n\n return formatHttpError(createError(httpError.status || 500));\n};\n\nexport { formatApplicationError, formatHttpError, formatInternalError };\n"],"names":["errors","createError"],"mappings":";;;;;;AAGA,MAAM,qBAAqB;AAAA,EACzB;AAAA,IACE,YAAYA,YAAO,OAAA;AAAA,IACnB,QAAQ;AAAA,EACV;AAAA,EACA;AAAA,IACE,YAAYA,YAAO,OAAA;AAAA,IACnB,QAAQ;AAAA,EACV;AAAA,EACA;AAAA,IACE,YAAYA,YAAO,OAAA;AAAA,IACnB,QAAQ;AAAA,EACV;AAAA,EACA;AAAA,IACE,YAAYA,YAAO,OAAA;AAAA,IACnB,QAAQ;AAAA,EACV;AAAA,EACA;AAAA,IACE,YAAYA,YAAO,OAAA;AAAA,IACnB,QAAQ;AAAA,EACV;AAAA,EACA;AAAA,IACE,YAAYA,YAAO,OAAA;AAAA,IACnB,QAAQ;AAAA,EAAA;AAEZ;AAEM,MAAA,yBAAyB,CAAC,UAAwD;AACtF,QAAM,iBAAiB,mBAAmB,KAAK,CAAC,SAAS,iBAAiB,KAAK,UAAU;AACnF,QAAA,SAAS,iBAAiB,eAAe,SAAS;AAEjD,SAAA;AAAA,IACL;AAAA,IACA,MAAM;AAAA,MACJ,MAAM;AAAA,MACN,OAAO;AAAA,QACL;AAAA,QACA,MAAM,MAAM;AAAA,QACZ,SAAS,MAAM;AAAA,QACf,SAAS,MAAM;AAAA,MAAA;AAAA,IACjB;AAAA,EAEJ;AACF;AAEM,MAAA,kBAAkB,CAAC,UAAiC;AACjD,SAAA;AAAA,IACL,QAAQ,MAAM;AAAA,IACd,MAAM;AAAA,MACJ,MAAM;AAAA,MACN,OAAO;AAAA,QACL,QAAQ,MAAM;AAAA,QACd,MAAM,MAAM;AAAA,QACZ,SAAS,MAAM;AAAA,QACf,SAAS,MAAM;AAAA,MAAA;AAAA,IACjB;AAAA,EAEJ;AACF;AAEM,MAAA,sBAAsB,CAAC,UAAmB;AAC1C,MAAA,EAAE,iBAAiB,QAAQ;AACtB,WAAA,gBAAgBC,6BAAY,GAAG,CAAC;AAAA,EAAA;AAGnC,QAAA,YAAYA,6BAAY,KAAK;AAEnC,MAAI,UAAU,QAAQ;AACpB,WAAO,gBAAgB,SAAS;AAAA,EAAA;AAGlC,SAAO,gBAAgBA,qBAAA,QAAY,UAAU,UAAU,GAAG,CAAC;AAC7D;;;;"}
@@ -1,74 +0,0 @@
1
- import createError from "http-errors";
2
- import { errors } from "@strapi/utils";
3
- const mapErrorsAndStatus = [
4
- {
5
- classError: errors.UnauthorizedError,
6
- status: 401
7
- },
8
- {
9
- classError: errors.ForbiddenError,
10
- status: 403
11
- },
12
- {
13
- classError: errors.NotFoundError,
14
- status: 404
15
- },
16
- {
17
- classError: errors.PayloadTooLargeError,
18
- status: 413
19
- },
20
- {
21
- classError: errors.RateLimitError,
22
- status: 429
23
- },
24
- {
25
- classError: errors.NotImplementedError,
26
- status: 501
27
- }
28
- ];
29
- const formatApplicationError = (error) => {
30
- const errorAndStatus = mapErrorsAndStatus.find((pair) => error instanceof pair.classError);
31
- const status = errorAndStatus ? errorAndStatus.status : 400;
32
- return {
33
- status,
34
- body: {
35
- data: null,
36
- error: {
37
- status,
38
- name: error.name,
39
- message: error.message,
40
- details: error.details
41
- }
42
- }
43
- };
44
- };
45
- const formatHttpError = (error) => {
46
- return {
47
- status: error.status,
48
- body: {
49
- data: null,
50
- error: {
51
- status: error.status,
52
- name: error.name,
53
- message: error.message,
54
- details: error.details
55
- }
56
- }
57
- };
58
- };
59
- const formatInternalError = (error) => {
60
- if (!(error instanceof Error)) {
61
- return formatHttpError(createError(500));
62
- }
63
- const httpError = createError(error);
64
- if (httpError.expose) {
65
- return formatHttpError(httpError);
66
- }
67
- return formatHttpError(createError(httpError.status || 500));
68
- };
69
- export {
70
- formatApplicationError,
71
- formatHttpError,
72
- formatInternalError
73
- };
74
- //# sourceMappingURL=errors.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"errors.mjs","sources":["../../src/services/errors.ts"],"sourcesContent":["import createError from 'http-errors';\nimport { errors } from '@strapi/utils';\n\nconst mapErrorsAndStatus = [\n {\n classError: errors.UnauthorizedError,\n status: 401,\n },\n {\n classError: errors.ForbiddenError,\n status: 403,\n },\n {\n classError: errors.NotFoundError,\n status: 404,\n },\n {\n classError: errors.PayloadTooLargeError,\n status: 413,\n },\n {\n classError: errors.RateLimitError,\n status: 429,\n },\n {\n classError: errors.NotImplementedError,\n status: 501,\n },\n];\n\nconst formatApplicationError = (error: InstanceType<typeof errors.ApplicationError>) => {\n const errorAndStatus = mapErrorsAndStatus.find((pair) => error instanceof pair.classError);\n const status = errorAndStatus ? errorAndStatus.status : 400;\n\n return {\n status,\n body: {\n data: null,\n error: {\n status,\n name: error.name,\n message: error.message,\n details: error.details,\n },\n },\n };\n};\n\nconst formatHttpError = (error: createError.HttpError) => {\n return {\n status: error.status,\n body: {\n data: null,\n error: {\n status: error.status,\n name: error.name,\n message: error.message,\n details: error.details,\n },\n },\n };\n};\n\nconst formatInternalError = (error: unknown) => {\n if (!(error instanceof Error)) {\n return formatHttpError(createError(500));\n }\n\n const httpError = createError(error);\n\n if (httpError.expose) {\n return formatHttpError(httpError);\n }\n\n return formatHttpError(createError(httpError.status || 500));\n};\n\nexport { formatApplicationError, formatHttpError, formatInternalError };\n"],"names":[],"mappings":";;AAGA,MAAM,qBAAqB;AAAA,EACzB;AAAA,IACE,YAAY,OAAO;AAAA,IACnB,QAAQ;AAAA,EACV;AAAA,EACA;AAAA,IACE,YAAY,OAAO;AAAA,IACnB,QAAQ;AAAA,EACV;AAAA,EACA;AAAA,IACE,YAAY,OAAO;AAAA,IACnB,QAAQ;AAAA,EACV;AAAA,EACA;AAAA,IACE,YAAY,OAAO;AAAA,IACnB,QAAQ;AAAA,EACV;AAAA,EACA;AAAA,IACE,YAAY,OAAO;AAAA,IACnB,QAAQ;AAAA,EACV;AAAA,EACA;AAAA,IACE,YAAY,OAAO;AAAA,IACnB,QAAQ;AAAA,EAAA;AAEZ;AAEM,MAAA,yBAAyB,CAAC,UAAwD;AACtF,QAAM,iBAAiB,mBAAmB,KAAK,CAAC,SAAS,iBAAiB,KAAK,UAAU;AACnF,QAAA,SAAS,iBAAiB,eAAe,SAAS;AAEjD,SAAA;AAAA,IACL;AAAA,IACA,MAAM;AAAA,MACJ,MAAM;AAAA,MACN,OAAO;AAAA,QACL;AAAA,QACA,MAAM,MAAM;AAAA,QACZ,SAAS,MAAM;AAAA,QACf,SAAS,MAAM;AAAA,MAAA;AAAA,IACjB;AAAA,EAEJ;AACF;AAEM,MAAA,kBAAkB,CAAC,UAAiC;AACjD,SAAA;AAAA,IACL,QAAQ,MAAM;AAAA,IACd,MAAM;AAAA,MACJ,MAAM;AAAA,MACN,OAAO;AAAA,QACL,QAAQ,MAAM;AAAA,QACd,MAAM,MAAM;AAAA,QACZ,SAAS,MAAM;AAAA,QACf,SAAS,MAAM;AAAA,MAAA;AAAA,IACjB;AAAA,EAEJ;AACF;AAEM,MAAA,sBAAsB,CAAC,UAAmB;AAC1C,MAAA,EAAE,iBAAiB,QAAQ;AACtB,WAAA,gBAAgB,YAAY,GAAG,CAAC;AAAA,EAAA;AAGnC,QAAA,YAAY,YAAY,KAAK;AAEnC,MAAI,UAAU,QAAQ;AACpB,WAAO,gBAAgB,SAAS;AAAA,EAAA;AAGlC,SAAO,gBAAgB,YAAY,UAAU,UAAU,GAAG,CAAC;AAC7D;"}
@@ -1,72 +0,0 @@
1
- "use strict";
2
- function createEventHub() {
3
- const listeners = /* @__PURE__ */ new Map();
4
- const defaultSubscriber = async (eventName, ...args) => {
5
- if (listeners.has(eventName)) {
6
- for (const listener of listeners.get(eventName)) {
7
- await listener(...args);
8
- }
9
- }
10
- };
11
- const subscribers = [defaultSubscriber];
12
- const eventHub = {
13
- async emit(eventName, ...args) {
14
- for (const subscriber of subscribers) {
15
- await subscriber(eventName, ...args);
16
- }
17
- },
18
- subscribe(subscriber) {
19
- subscribers.push(subscriber);
20
- return () => {
21
- eventHub.unsubscribe(subscriber);
22
- };
23
- },
24
- unsubscribe(subscriber) {
25
- const subscriberIndex = subscribers.indexOf(subscriber);
26
- if (subscriberIndex >= 0) {
27
- subscribers.splice(subscriberIndex, 1);
28
- }
29
- },
30
- on(eventName, listener) {
31
- if (!listeners.has(eventName)) {
32
- listeners.set(eventName, [listener]);
33
- } else {
34
- listeners.get(eventName).push(listener);
35
- }
36
- return () => {
37
- eventHub.off(eventName, listener);
38
- };
39
- },
40
- off(eventName, listener) {
41
- listeners.get(eventName)?.splice(listeners.get(eventName).indexOf(listener), 1);
42
- },
43
- once(eventName, listener) {
44
- return eventHub.on(eventName, async (...args) => {
45
- eventHub.off(eventName, listener);
46
- return listener(...args);
47
- });
48
- },
49
- destroy() {
50
- this.removeAllListeners();
51
- this.removeAllSubscribers();
52
- return this;
53
- },
54
- removeListener(eventName, listener) {
55
- return eventHub.off(eventName, listener);
56
- },
57
- removeAllListeners() {
58
- listeners.clear();
59
- return this;
60
- },
61
- removeAllSubscribers() {
62
- subscribers.length = 0;
63
- return this;
64
- },
65
- addListener(eventName, listener) {
66
- return eventHub.on(eventName, listener);
67
- }
68
- };
69
- return eventHub;
70
- }
71
- module.exports = createEventHub;
72
- //# sourceMappingURL=event-hub.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"event-hub.js","sources":["../../src/services/event-hub.ts"],"sourcesContent":["export type Subscriber = (eventName: string, ...args: any[]) => Promise<void>;\nexport type Listener = (...args: any[]) => Promise<void>;\n\nexport interface EventHub {\n emit(eventName: string, ...args: unknown[]): Promise<void>;\n subscribe(subscriber: Subscriber): () => void;\n unsubscribe(subscriber: Subscriber): void;\n on(eventName: string, listener: Listener): () => void;\n off(eventName: string, listener: Listener): void;\n once(eventName: string, listener: Listener): () => void;\n destroy(): EventHub;\n removeListener(eventName: string, listener: Listener): void;\n removeAllListeners(): EventHub;\n removeAllSubscribers(): EventHub;\n addListener(eventName: string, listener: Listener): () => void;\n}\n\n/**\n * The event hub is Strapi's event control center.\n */\nexport default function createEventHub(): EventHub {\n const listeners = new Map();\n\n // Default subscriber to easily add listeners with the on() method\n const defaultSubscriber = async (eventName: string, ...args: unknown[]) => {\n if (listeners.has(eventName)) {\n for (const listener of listeners.get(eventName)) {\n await listener(...args);\n }\n }\n };\n\n // Store of subscribers that will be called when an event is emitted\n const subscribers = [defaultSubscriber];\n\n const eventHub: EventHub = {\n async emit(eventName, ...args) {\n for (const subscriber of subscribers) {\n await subscriber(eventName, ...args);\n }\n },\n\n subscribe(subscriber) {\n subscribers.push(subscriber);\n\n // Return a function to remove the subscriber\n return () => {\n eventHub.unsubscribe(subscriber);\n };\n },\n\n unsubscribe(subscriber) {\n const subscriberIndex = subscribers.indexOf(subscriber);\n\n // Only remove the subscriber if it exists\n if (subscriberIndex >= 0) {\n subscribers.splice(subscriberIndex, 1);\n }\n },\n\n on(eventName, listener) {\n if (!listeners.has(eventName)) {\n listeners.set(eventName, [listener]);\n } else {\n listeners.get(eventName).push(listener);\n }\n\n // Return a function to remove the listener\n return () => {\n eventHub.off(eventName, listener);\n };\n },\n\n off(eventName, listener) {\n listeners.get(eventName)?.splice(listeners.get(eventName).indexOf(listener), 1);\n },\n\n once(eventName, listener) {\n return eventHub.on(eventName, async (...args) => {\n eventHub.off(eventName, listener);\n return listener(...args);\n });\n },\n\n destroy() {\n this.removeAllListeners();\n this.removeAllSubscribers();\n return this;\n },\n\n removeListener(eventName, listener) {\n return eventHub.off(eventName, listener);\n },\n\n removeAllListeners() {\n listeners.clear();\n return this;\n },\n\n removeAllSubscribers() {\n subscribers.length = 0;\n return this;\n },\n\n addListener(eventName, listener) {\n return eventHub.on(eventName, listener);\n },\n };\n\n return eventHub;\n}\n"],"names":[],"mappings":";AAoBA,SAAwB,iBAA2B;AAC3C,QAAA,gCAAgB,IAAI;AAGpB,QAAA,oBAAoB,OAAO,cAAsB,SAAoB;AACrE,QAAA,UAAU,IAAI,SAAS,GAAG;AAC5B,iBAAW,YAAY,UAAU,IAAI,SAAS,GAAG;AACzC,cAAA,SAAS,GAAG,IAAI;AAAA,MAAA;AAAA,IACxB;AAAA,EAEJ;AAGM,QAAA,cAAc,CAAC,iBAAiB;AAEtC,QAAM,WAAqB;AAAA,IACzB,MAAM,KAAK,cAAc,MAAM;AAC7B,iBAAW,cAAc,aAAa;AAC9B,cAAA,WAAW,WAAW,GAAG,IAAI;AAAA,MAAA;AAAA,IAEvC;AAAA,IAEA,UAAU,YAAY;AACpB,kBAAY,KAAK,UAAU;AAG3B,aAAO,MAAM;AACX,iBAAS,YAAY,UAAU;AAAA,MACjC;AAAA,IACF;AAAA,IAEA,YAAY,YAAY;AAChB,YAAA,kBAAkB,YAAY,QAAQ,UAAU;AAGtD,UAAI,mBAAmB,GAAG;AACZ,oBAAA,OAAO,iBAAiB,CAAC;AAAA,MAAA;AAAA,IAEzC;AAAA,IAEA,GAAG,WAAW,UAAU;AACtB,UAAI,CAAC,UAAU,IAAI,SAAS,GAAG;AAC7B,kBAAU,IAAI,WAAW,CAAC,QAAQ,CAAC;AAAA,MAAA,OAC9B;AACL,kBAAU,IAAI,SAAS,EAAE,KAAK,QAAQ;AAAA,MAAA;AAIxC,aAAO,MAAM;AACF,iBAAA,IAAI,WAAW,QAAQ;AAAA,MAClC;AAAA,IACF;AAAA,IAEA,IAAI,WAAW,UAAU;AACb,gBAAA,IAAI,SAAS,GAAG,OAAO,UAAU,IAAI,SAAS,EAAE,QAAQ,QAAQ,GAAG,CAAC;AAAA,IAChF;AAAA,IAEA,KAAK,WAAW,UAAU;AACxB,aAAO,SAAS,GAAG,WAAW,UAAU,SAAS;AACtC,iBAAA,IAAI,WAAW,QAAQ;AACzB,eAAA,SAAS,GAAG,IAAI;AAAA,MAAA,CACxB;AAAA,IACH;AAAA,IAEA,UAAU;AACR,WAAK,mBAAmB;AACxB,WAAK,qBAAqB;AACnB,aAAA;AAAA,IACT;AAAA,IAEA,eAAe,WAAW,UAAU;AAC3B,aAAA,SAAS,IAAI,WAAW,QAAQ;AAAA,IACzC;AAAA,IAEA,qBAAqB;AACnB,gBAAU,MAAM;AACT,aAAA;AAAA,IACT;AAAA,IAEA,uBAAuB;AACrB,kBAAY,SAAS;AACd,aAAA;AAAA,IACT;AAAA,IAEA,YAAY,WAAW,UAAU;AACxB,aAAA,SAAS,GAAG,WAAW,QAAQ;AAAA,IAAA;AAAA,EAE1C;AAEO,SAAA;AACT;;"}
@@ -1,73 +0,0 @@
1
- function createEventHub() {
2
- const listeners = /* @__PURE__ */ new Map();
3
- const defaultSubscriber = async (eventName, ...args) => {
4
- if (listeners.has(eventName)) {
5
- for (const listener of listeners.get(eventName)) {
6
- await listener(...args);
7
- }
8
- }
9
- };
10
- const subscribers = [defaultSubscriber];
11
- const eventHub = {
12
- async emit(eventName, ...args) {
13
- for (const subscriber of subscribers) {
14
- await subscriber(eventName, ...args);
15
- }
16
- },
17
- subscribe(subscriber) {
18
- subscribers.push(subscriber);
19
- return () => {
20
- eventHub.unsubscribe(subscriber);
21
- };
22
- },
23
- unsubscribe(subscriber) {
24
- const subscriberIndex = subscribers.indexOf(subscriber);
25
- if (subscriberIndex >= 0) {
26
- subscribers.splice(subscriberIndex, 1);
27
- }
28
- },
29
- on(eventName, listener) {
30
- if (!listeners.has(eventName)) {
31
- listeners.set(eventName, [listener]);
32
- } else {
33
- listeners.get(eventName).push(listener);
34
- }
35
- return () => {
36
- eventHub.off(eventName, listener);
37
- };
38
- },
39
- off(eventName, listener) {
40
- listeners.get(eventName)?.splice(listeners.get(eventName).indexOf(listener), 1);
41
- },
42
- once(eventName, listener) {
43
- return eventHub.on(eventName, async (...args) => {
44
- eventHub.off(eventName, listener);
45
- return listener(...args);
46
- });
47
- },
48
- destroy() {
49
- this.removeAllListeners();
50
- this.removeAllSubscribers();
51
- return this;
52
- },
53
- removeListener(eventName, listener) {
54
- return eventHub.off(eventName, listener);
55
- },
56
- removeAllListeners() {
57
- listeners.clear();
58
- return this;
59
- },
60
- removeAllSubscribers() {
61
- subscribers.length = 0;
62
- return this;
63
- },
64
- addListener(eventName, listener) {
65
- return eventHub.on(eventName, listener);
66
- }
67
- };
68
- return eventHub;
69
- }
70
- export {
71
- createEventHub as default
72
- };
73
- //# sourceMappingURL=event-hub.mjs.map