@strapi/core 0.0.0-experimental.6dbac0c205b0f8495781db5706c18cac1a62e62b → 0.0.0-experimental.727a0f9b729da91886ca93e88ec1d6d811d1beba

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


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

Files changed (1305) hide show
  1. package/LICENSE +18 -3
  2. package/dist/Strapi.d.ts +53 -57
  3. package/dist/Strapi.d.ts.map +1 -1
  4. package/dist/Strapi.js +212 -217
  5. package/dist/Strapi.js.map +1 -1
  6. package/dist/Strapi.mjs +185 -209
  7. package/dist/Strapi.mjs.map +1 -1
  8. package/dist/configuration/config-loader.d.ts.map +1 -0
  9. package/dist/configuration/config-loader.js +106 -0
  10. package/dist/configuration/config-loader.js.map +1 -0
  11. package/dist/configuration/config-loader.mjs +104 -0
  12. package/dist/configuration/config-loader.mjs.map +1 -0
  13. package/dist/configuration/get-dirs.d.ts +10 -0
  14. package/dist/configuration/get-dirs.d.ts.map +1 -0
  15. package/dist/configuration/get-dirs.js +31 -0
  16. package/dist/configuration/get-dirs.js.map +1 -0
  17. package/dist/configuration/get-dirs.mjs +31 -0
  18. package/dist/configuration/get-dirs.mjs.map +1 -0
  19. package/dist/configuration/index.d.ts +48 -0
  20. package/dist/configuration/index.d.ts.map +1 -0
  21. package/dist/configuration/index.js +80 -0
  22. package/dist/configuration/index.js.map +1 -0
  23. package/dist/configuration/index.mjs +75 -0
  24. package/dist/configuration/index.mjs.map +1 -0
  25. package/dist/configuration/urls.d.ts +8 -0
  26. package/dist/configuration/urls.d.ts.map +1 -0
  27. package/dist/configuration/urls.js +68 -0
  28. package/dist/configuration/urls.js.map +1 -0
  29. package/dist/configuration/urls.mjs +66 -0
  30. package/dist/configuration/urls.mjs.map +1 -0
  31. package/dist/container.d.ts +2 -2
  32. package/dist/container.d.ts.map +1 -1
  33. package/dist/container.js.map +1 -1
  34. package/dist/container.mjs.map +1 -1
  35. package/dist/core-api/controller/collection-type.d.ts +4 -4
  36. package/dist/core-api/controller/collection-type.d.ts.map +1 -1
  37. package/dist/core-api/controller/collection-type.js +15 -23
  38. package/dist/core-api/controller/collection-type.js.map +1 -1
  39. package/dist/core-api/controller/collection-type.mjs +11 -20
  40. package/dist/core-api/controller/collection-type.mjs.map +1 -1
  41. package/dist/core-api/controller/index.d.ts +3 -3
  42. package/dist/core-api/controller/index.d.ts.map +1 -1
  43. package/dist/core-api/controller/index.js +15 -10
  44. package/dist/core-api/controller/index.js.map +1 -1
  45. package/dist/core-api/controller/index.mjs +14 -9
  46. package/dist/core-api/controller/index.mjs.map +1 -1
  47. package/dist/core-api/controller/single-type.d.ts +4 -4
  48. package/dist/core-api/controller/single-type.d.ts.map +1 -1
  49. package/dist/core-api/controller/single-type.js +9 -13
  50. package/dist/core-api/controller/single-type.js.map +1 -1
  51. package/dist/core-api/controller/single-type.mjs +6 -11
  52. package/dist/core-api/controller/single-type.mjs.map +1 -1
  53. package/dist/core-api/controller/transform.d.ts +10 -18
  54. package/dist/core-api/controller/transform.d.ts.map +1 -1
  55. package/dist/core-api/controller/transform.js +17 -25
  56. package/dist/core-api/controller/transform.js.map +1 -1
  57. package/dist/core-api/controller/transform.mjs +10 -18
  58. package/dist/core-api/controller/transform.mjs.map +1 -1
  59. package/dist/core-api/routes/index.d.ts.map +1 -1
  60. package/dist/core-api/service/collection-type.d.ts +22 -5
  61. package/dist/core-api/service/collection-type.d.ts.map +1 -1
  62. package/dist/core-api/service/collection-type.js +58 -49
  63. package/dist/core-api/service/collection-type.js.map +1 -1
  64. package/dist/core-api/service/collection-type.mjs +58 -50
  65. package/dist/core-api/service/collection-type.mjs.map +1 -1
  66. package/dist/core-api/service/core-service.d.ts +4 -0
  67. package/dist/core-api/service/core-service.d.ts.map +1 -0
  68. package/dist/core-api/service/core-service.js +12 -0
  69. package/dist/core-api/service/core-service.js.map +1 -0
  70. package/dist/core-api/service/core-service.mjs +12 -0
  71. package/dist/core-api/service/core-service.mjs.map +1 -0
  72. package/dist/core-api/service/index.d.ts +3 -3
  73. package/dist/core-api/service/index.d.ts.map +1 -1
  74. package/dist/core-api/service/index.js +2 -2
  75. package/dist/core-api/service/index.js.map +1 -1
  76. package/dist/core-api/service/index.mjs +4 -4
  77. package/dist/core-api/service/index.mjs.map +1 -1
  78. package/dist/core-api/service/pagination.d.ts +4 -15
  79. package/dist/core-api/service/pagination.d.ts.map +1 -1
  80. package/dist/core-api/service/pagination.js +18 -55
  81. package/dist/core-api/service/pagination.js.map +1 -1
  82. package/dist/core-api/service/pagination.mjs +16 -53
  83. package/dist/core-api/service/pagination.mjs.map +1 -1
  84. package/dist/core-api/service/single-type.d.ts +14 -8
  85. package/dist/core-api/service/single-type.d.ts.map +1 -1
  86. package/dist/core-api/service/single-type.js +42 -50
  87. package/dist/core-api/service/single-type.js.map +1 -1
  88. package/dist/core-api/service/single-type.mjs +41 -50
  89. package/dist/core-api/service/single-type.mjs.map +1 -1
  90. package/dist/domain/content-type/index.d.ts +10 -0
  91. package/dist/domain/content-type/index.d.ts.map +1 -0
  92. package/dist/domain/content-type/index.js +111 -0
  93. package/dist/domain/content-type/index.js.map +1 -0
  94. package/dist/domain/content-type/index.mjs +109 -0
  95. package/dist/domain/content-type/index.mjs.map +1 -0
  96. package/dist/domain/content-type/validator.d.ts.map +1 -0
  97. package/dist/domain/content-type/validator.js +77 -0
  98. package/dist/domain/content-type/validator.js.map +1 -0
  99. package/dist/domain/content-type/validator.mjs +75 -0
  100. package/dist/domain/content-type/validator.mjs.map +1 -0
  101. package/dist/domain/module/index.d.ts +40 -0
  102. package/dist/domain/module/index.d.ts.map +1 -0
  103. package/dist/domain/module/index.js +107 -0
  104. package/dist/domain/module/index.js.map +1 -0
  105. package/dist/domain/module/index.mjs +105 -0
  106. package/dist/domain/module/index.mjs.map +1 -0
  107. package/dist/domain/module/validation.d.ts.map +1 -0
  108. package/dist/domain/module/validation.js.map +1 -0
  109. package/dist/domain/module/validation.mjs.map +1 -0
  110. package/dist/ee/index.d.ts +4 -2
  111. package/dist/ee/index.d.ts.map +1 -1
  112. package/dist/ee/index.js +5 -5
  113. package/dist/ee/index.js.map +1 -1
  114. package/dist/ee/index.mjs +2 -2
  115. package/dist/ee/index.mjs.map +1 -1
  116. package/dist/ee/license.d.ts +2 -2
  117. package/dist/ee/license.d.ts.map +1 -1
  118. package/dist/ee/license.js +3 -1
  119. package/dist/ee/license.js.map +1 -1
  120. package/dist/ee/license.mjs +3 -1
  121. package/dist/ee/license.mjs.map +1 -1
  122. package/dist/factories.d.ts +11 -10
  123. package/dist/factories.d.ts.map +1 -1
  124. package/dist/factories.js +26 -17
  125. package/dist/factories.js.map +1 -1
  126. package/dist/factories.mjs +23 -14
  127. package/dist/factories.mjs.map +1 -1
  128. package/dist/index.d.ts +19 -2
  129. package/dist/index.d.ts.map +1 -1
  130. package/dist/index.js +27 -1
  131. package/dist/index.js.map +1 -1
  132. package/dist/index.mjs +28 -2
  133. package/dist/index.mjs.map +1 -1
  134. package/dist/loaders/admin.d.ts +3 -0
  135. package/dist/loaders/admin.d.ts.map +1 -0
  136. package/dist/loaders/admin.js +26 -0
  137. package/dist/loaders/admin.js.map +1 -0
  138. package/dist/loaders/admin.mjs +25 -0
  139. package/dist/loaders/admin.mjs.map +1 -0
  140. package/dist/loaders/apis.d.ts +3 -0
  141. package/dist/loaders/apis.d.ts.map +1 -0
  142. package/dist/loaders/apis.js +137 -0
  143. package/dist/loaders/apis.js.map +1 -0
  144. package/dist/loaders/apis.mjs +135 -0
  145. package/dist/loaders/apis.mjs.map +1 -0
  146. package/dist/loaders/components.d.ts +3 -0
  147. package/dist/loaders/components.d.ts.map +1 -0
  148. package/dist/loaders/components.js +38 -0
  149. package/dist/loaders/components.js.map +1 -0
  150. package/dist/loaders/components.mjs +37 -0
  151. package/dist/loaders/components.mjs.map +1 -0
  152. package/dist/loaders/index.d.ts +3 -0
  153. package/dist/loaders/index.d.ts.map +1 -0
  154. package/dist/loaders/index.js +24 -0
  155. package/dist/loaders/index.js.map +1 -0
  156. package/dist/loaders/index.mjs +24 -0
  157. package/dist/loaders/index.mjs.map +1 -0
  158. package/dist/loaders/middlewares.d.ts +3 -0
  159. package/dist/loaders/middlewares.d.ts.map +1 -0
  160. package/dist/loaders/middlewares.js +31 -0
  161. package/dist/loaders/middlewares.js.map +1 -0
  162. package/dist/loaders/middlewares.mjs +30 -0
  163. package/dist/loaders/middlewares.mjs.map +1 -0
  164. package/dist/loaders/plugins/get-enabled-plugins.d.ts +5 -0
  165. package/dist/loaders/plugins/get-enabled-plugins.d.ts.map +1 -0
  166. package/dist/loaders/plugins/get-enabled-plugins.js +141 -0
  167. package/dist/loaders/plugins/get-enabled-plugins.js.map +1 -0
  168. package/dist/loaders/plugins/get-enabled-plugins.mjs +117 -0
  169. package/dist/loaders/plugins/get-enabled-plugins.mjs.map +1 -0
  170. package/dist/loaders/plugins/get-user-plugins-config.d.ts.map +1 -0
  171. package/dist/loaders/plugins/get-user-plugins-config.js +27 -0
  172. package/dist/loaders/plugins/get-user-plugins-config.js.map +1 -0
  173. package/dist/loaders/plugins/get-user-plugins-config.mjs +25 -0
  174. package/dist/loaders/plugins/get-user-plugins-config.mjs.map +1 -0
  175. package/dist/loaders/plugins/index.d.ts +3 -0
  176. package/dist/loaders/plugins/index.d.ts.map +1 -0
  177. package/dist/loaders/plugins/index.js +145 -0
  178. package/dist/loaders/plugins/index.js.map +1 -0
  179. package/dist/loaders/plugins/index.mjs +125 -0
  180. package/dist/loaders/plugins/index.mjs.map +1 -0
  181. package/dist/loaders/policies.d.ts +3 -0
  182. package/dist/loaders/policies.d.ts.map +1 -0
  183. package/dist/loaders/policies.js.map +1 -0
  184. package/dist/loaders/policies.mjs.map +1 -0
  185. package/dist/loaders/sanitizers.d.ts +4 -0
  186. package/dist/loaders/sanitizers.d.ts.map +1 -0
  187. package/dist/loaders/sanitizers.js.map +1 -0
  188. package/dist/loaders/sanitizers.mjs.map +1 -0
  189. package/dist/loaders/src-index.d.ts +4 -0
  190. package/dist/loaders/src-index.d.ts.map +1 -0
  191. package/dist/loaders/src-index.js.map +1 -0
  192. package/dist/loaders/src-index.mjs.map +1 -0
  193. package/dist/loaders/validators.d.ts +4 -0
  194. package/dist/loaders/validators.d.ts.map +1 -0
  195. package/dist/loaders/validators.js.map +1 -0
  196. package/dist/loaders/validators.mjs.map +1 -0
  197. package/dist/middlewares/body.d.ts +4 -4
  198. package/dist/middlewares/body.d.ts.map +1 -1
  199. package/dist/middlewares/body.js +6 -6
  200. package/dist/middlewares/body.js.map +1 -1
  201. package/dist/middlewares/body.mjs +4 -4
  202. package/dist/middlewares/body.mjs.map +1 -1
  203. package/dist/middlewares/compression.d.ts +2 -2
  204. package/dist/middlewares/compression.d.ts.map +1 -1
  205. package/dist/middlewares/compression.js.map +1 -1
  206. package/dist/middlewares/compression.mjs.map +1 -1
  207. package/dist/middlewares/cors.d.ts +2 -2
  208. package/dist/middlewares/cors.d.ts.map +1 -1
  209. package/dist/middlewares/cors.js +9 -7
  210. package/dist/middlewares/cors.js.map +1 -1
  211. package/dist/middlewares/cors.mjs +9 -7
  212. package/dist/middlewares/cors.mjs.map +1 -1
  213. package/dist/middlewares/errors.d.ts +2 -2
  214. package/dist/middlewares/errors.d.ts.map +1 -1
  215. package/dist/middlewares/errors.js.map +1 -1
  216. package/dist/middlewares/errors.mjs.map +1 -1
  217. package/dist/middlewares/favicon.d.ts +3 -2
  218. package/dist/middlewares/favicon.d.ts.map +1 -1
  219. package/dist/middlewares/favicon.js.map +1 -1
  220. package/dist/middlewares/favicon.mjs.map +1 -1
  221. package/dist/middlewares/index.d.ts +2 -2
  222. package/dist/middlewares/index.d.ts.map +1 -1
  223. package/dist/middlewares/index.js +2 -2
  224. package/dist/middlewares/index.js.map +1 -1
  225. package/dist/middlewares/index.mjs +1 -1
  226. package/dist/middlewares/index.mjs.map +1 -1
  227. package/dist/middlewares/ip.d.ts +2 -2
  228. package/dist/middlewares/ip.d.ts.map +1 -1
  229. package/dist/middlewares/ip.js.map +1 -1
  230. package/dist/middlewares/ip.mjs.map +1 -1
  231. package/dist/middlewares/logger.d.ts +2 -2
  232. package/dist/middlewares/logger.d.ts.map +1 -1
  233. package/dist/middlewares/logger.js.map +1 -1
  234. package/dist/middlewares/logger.mjs.map +1 -1
  235. package/dist/middlewares/powered-by.d.ts +2 -2
  236. package/dist/middlewares/powered-by.d.ts.map +1 -1
  237. package/dist/middlewares/powered-by.js.map +1 -1
  238. package/dist/middlewares/powered-by.mjs.map +1 -1
  239. package/dist/middlewares/public.d.ts +3 -0
  240. package/dist/middlewares/public.d.ts.map +1 -0
  241. package/dist/middlewares/public.js +34 -0
  242. package/dist/middlewares/public.js.map +1 -0
  243. package/dist/middlewares/public.mjs +32 -0
  244. package/dist/middlewares/public.mjs.map +1 -0
  245. package/dist/middlewares/query.d.ts +2 -2
  246. package/dist/middlewares/query.d.ts.map +1 -1
  247. package/dist/middlewares/query.js.map +1 -1
  248. package/dist/middlewares/query.mjs.map +1 -1
  249. package/dist/middlewares/response-time.d.ts +2 -2
  250. package/dist/middlewares/response-time.d.ts.map +1 -1
  251. package/dist/middlewares/response-time.js.map +1 -1
  252. package/dist/middlewares/response-time.mjs.map +1 -1
  253. package/dist/middlewares/responses.d.ts +3 -3
  254. package/dist/middlewares/responses.d.ts.map +1 -1
  255. package/dist/middlewares/responses.js +2 -2
  256. package/dist/middlewares/responses.js.map +1 -1
  257. package/dist/middlewares/responses.mjs.map +1 -1
  258. package/dist/middlewares/security.d.ts +2 -2
  259. package/dist/middlewares/security.d.ts.map +1 -1
  260. package/dist/middlewares/security.js +34 -6
  261. package/dist/middlewares/security.js.map +1 -1
  262. package/dist/middlewares/security.mjs +33 -5
  263. package/dist/middlewares/security.mjs.map +1 -1
  264. package/dist/middlewares/session.d.ts +2 -2
  265. package/dist/middlewares/session.d.ts.map +1 -1
  266. package/dist/middlewares/session.js +2 -2
  267. package/dist/middlewares/session.js.map +1 -1
  268. package/dist/middlewares/session.mjs.map +1 -1
  269. package/dist/migrations/database/5.0.0-discard-drafts.d.ts +33 -0
  270. package/dist/migrations/database/5.0.0-discard-drafts.d.ts.map +1 -0
  271. package/dist/migrations/database/5.0.0-discard-drafts.js +94 -0
  272. package/dist/migrations/database/5.0.0-discard-drafts.js.map +1 -0
  273. package/dist/migrations/database/5.0.0-discard-drafts.mjs +94 -0
  274. package/dist/migrations/database/5.0.0-discard-drafts.mjs.map +1 -0
  275. package/dist/migrations/draft-publish.d.ts +17 -0
  276. package/dist/migrations/draft-publish.d.ts.map +1 -0
  277. package/dist/migrations/draft-publish.js +42 -0
  278. package/dist/migrations/draft-publish.js.map +1 -0
  279. package/dist/migrations/draft-publish.mjs +42 -0
  280. package/dist/migrations/draft-publish.mjs.map +1 -0
  281. package/dist/migrations/i18n.d.ts +5 -0
  282. package/dist/migrations/i18n.d.ts.map +1 -0
  283. package/dist/migrations/i18n.js +54 -0
  284. package/dist/migrations/i18n.js.map +1 -0
  285. package/dist/migrations/i18n.mjs +54 -0
  286. package/dist/migrations/i18n.mjs.map +1 -0
  287. package/dist/migrations/index.d.ts +5 -0
  288. package/dist/migrations/index.d.ts.map +1 -0
  289. package/dist/migrations/index.js +15 -0
  290. package/dist/migrations/index.js.map +1 -0
  291. package/dist/migrations/index.mjs +15 -0
  292. package/dist/migrations/index.mjs.map +1 -0
  293. package/dist/providers/admin.d.ts +3 -0
  294. package/dist/providers/admin.d.ts.map +1 -0
  295. package/dist/providers/admin.js +20 -0
  296. package/dist/providers/admin.js.map +1 -0
  297. package/dist/providers/admin.mjs +21 -0
  298. package/dist/providers/admin.mjs.map +1 -0
  299. package/dist/providers/coreStore.d.ts +3 -0
  300. package/dist/providers/coreStore.d.ts.map +1 -0
  301. package/dist/providers/coreStore.js +11 -0
  302. package/dist/providers/coreStore.js.map +1 -0
  303. package/dist/providers/coreStore.mjs +12 -0
  304. package/dist/providers/coreStore.mjs.map +1 -0
  305. package/dist/providers/cron.d.ts +3 -0
  306. package/dist/providers/cron.d.ts.map +1 -0
  307. package/dist/providers/cron.js +20 -0
  308. package/dist/providers/cron.js.map +1 -0
  309. package/dist/providers/cron.mjs +21 -0
  310. package/dist/providers/cron.mjs.map +1 -0
  311. package/dist/providers/index.d.ts +3 -0
  312. package/dist/providers/index.d.ts.map +1 -0
  313. package/dist/providers/index.js +11 -0
  314. package/dist/providers/index.js.map +1 -0
  315. package/dist/providers/index.mjs +11 -0
  316. package/dist/providers/index.mjs.map +1 -0
  317. package/dist/providers/provider.d.ts +9 -0
  318. package/dist/providers/provider.d.ts.map +1 -0
  319. package/dist/providers/provider.js +5 -0
  320. package/dist/providers/provider.js.map +1 -0
  321. package/dist/providers/provider.mjs +5 -0
  322. package/dist/providers/provider.mjs.map +1 -0
  323. package/dist/providers/registries.d.ts +3 -0
  324. package/dist/providers/registries.d.ts.map +1 -0
  325. package/dist/providers/registries.js +35 -0
  326. package/dist/providers/registries.js.map +1 -0
  327. package/dist/providers/registries.mjs +36 -0
  328. package/dist/providers/registries.mjs.map +1 -0
  329. package/dist/providers/telemetry.d.ts +3 -0
  330. package/dist/providers/telemetry.d.ts.map +1 -0
  331. package/dist/providers/telemetry.js +19 -0
  332. package/dist/providers/telemetry.js.map +1 -0
  333. package/dist/providers/telemetry.mjs +20 -0
  334. package/dist/providers/telemetry.mjs.map +1 -0
  335. package/dist/providers/webhooks.d.ts +3 -0
  336. package/dist/providers/webhooks.d.ts.map +1 -0
  337. package/dist/providers/webhooks.js +30 -0
  338. package/dist/providers/webhooks.js.map +1 -0
  339. package/dist/providers/webhooks.mjs +31 -0
  340. package/dist/providers/webhooks.mjs.map +1 -0
  341. package/dist/registries/apis.d.ts +8 -0
  342. package/dist/registries/apis.d.ts.map +1 -0
  343. package/dist/registries/apis.js +23 -0
  344. package/dist/registries/apis.js.map +1 -0
  345. package/dist/registries/apis.mjs.map +1 -0
  346. package/dist/registries/components.d.ts +25 -0
  347. package/dist/registries/components.d.ts.map +1 -0
  348. package/dist/registries/components.js +45 -0
  349. package/dist/registries/components.js.map +1 -0
  350. package/dist/registries/components.mjs.map +1 -0
  351. package/dist/registries/content-types.d.ts +33 -0
  352. package/dist/registries/content-types.d.ts.map +1 -0
  353. package/dist/registries/content-types.js +70 -0
  354. package/dist/registries/content-types.js.map +1 -0
  355. package/dist/registries/content-types.mjs +71 -0
  356. package/dist/registries/content-types.mjs.map +1 -0
  357. package/dist/registries/controllers.d.ts +35 -0
  358. package/dist/registries/controllers.d.ts.map +1 -0
  359. package/dist/registries/controllers.js +80 -0
  360. package/dist/registries/controllers.js.map +1 -0
  361. package/dist/registries/controllers.mjs +81 -0
  362. package/dist/registries/controllers.mjs.map +1 -0
  363. package/dist/registries/custom-fields.d.ts +8 -0
  364. package/dist/registries/custom-fields.d.ts.map +1 -0
  365. package/dist/registries/custom-fields.js +71 -0
  366. package/dist/registries/custom-fields.js.map +1 -0
  367. package/dist/registries/custom-fields.mjs.map +1 -0
  368. package/dist/registries/hooks.d.ts.map +1 -0
  369. package/dist/registries/hooks.js +58 -0
  370. package/dist/registries/hooks.js.map +1 -0
  371. package/dist/registries/hooks.mjs +59 -0
  372. package/dist/registries/hooks.mjs.map +1 -0
  373. package/dist/registries/index.d.ts +15 -0
  374. package/dist/registries/index.d.ts.map +1 -0
  375. package/dist/registries/middlewares.d.ts +31 -0
  376. package/dist/registries/middlewares.d.ts.map +1 -0
  377. package/dist/registries/middlewares.js +60 -0
  378. package/dist/registries/middlewares.js.map +1 -0
  379. package/dist/registries/middlewares.mjs +61 -0
  380. package/dist/registries/middlewares.mjs.map +1 -0
  381. package/dist/registries/models.d.ts +6 -0
  382. package/dist/registries/models.d.ts.map +1 -0
  383. package/dist/registries/models.js +16 -0
  384. package/dist/registries/models.js.map +1 -0
  385. package/dist/registries/models.mjs +16 -0
  386. package/dist/registries/models.mjs.map +1 -0
  387. package/dist/registries/modules.d.ts +15 -0
  388. package/dist/registries/modules.d.ts.map +1 -0
  389. package/dist/registries/modules.js +39 -0
  390. package/dist/registries/modules.js.map +1 -0
  391. package/dist/registries/modules.mjs.map +1 -0
  392. package/dist/registries/namespace.d.ts +5 -0
  393. package/dist/registries/namespace.d.ts.map +1 -0
  394. package/dist/registries/namespace.js +27 -0
  395. package/dist/registries/namespace.js.map +1 -0
  396. package/dist/registries/namespace.mjs +27 -0
  397. package/dist/registries/namespace.mjs.map +1 -0
  398. package/dist/registries/plugins.d.ts +9 -0
  399. package/dist/registries/plugins.d.ts.map +1 -0
  400. package/dist/registries/plugins.js +23 -0
  401. package/dist/registries/plugins.js.map +1 -0
  402. package/dist/registries/plugins.mjs.map +1 -0
  403. package/dist/registries/policies.d.ts +46 -0
  404. package/dist/registries/policies.d.ts.map +1 -0
  405. package/dist/registries/policies.js +108 -0
  406. package/dist/registries/policies.js.map +1 -0
  407. package/dist/registries/policies.mjs +109 -0
  408. package/dist/registries/policies.mjs.map +1 -0
  409. package/dist/registries/sanitizers.d.ts.map +1 -0
  410. package/dist/registries/sanitizers.js.map +1 -0
  411. package/dist/registries/sanitizers.mjs.map +1 -0
  412. package/dist/registries/services.d.ts +35 -0
  413. package/dist/registries/services.d.ts.map +1 -0
  414. package/dist/registries/services.js +80 -0
  415. package/dist/registries/services.js.map +1 -0
  416. package/dist/registries/services.mjs +81 -0
  417. package/dist/registries/services.mjs.map +1 -0
  418. package/dist/registries/validators.d.ts.map +1 -0
  419. package/dist/registries/validators.js.map +1 -0
  420. package/dist/registries/validators.mjs.map +1 -0
  421. package/dist/services/auth/index.d.ts +4 -4
  422. package/dist/services/auth/index.d.ts.map +1 -1
  423. package/dist/services/auth/index.js +3 -3
  424. package/dist/services/auth/index.js.map +1 -1
  425. package/dist/services/auth/index.mjs.map +1 -1
  426. package/dist/services/config.d.ts +3 -0
  427. package/dist/services/config.d.ts.map +1 -0
  428. package/dist/services/config.js +47 -0
  429. package/dist/services/config.js.map +1 -0
  430. package/dist/services/config.mjs +47 -0
  431. package/dist/services/config.mjs.map +1 -0
  432. package/dist/services/content-api/index.d.ts +31 -15
  433. package/dist/services/content-api/index.d.ts.map +1 -1
  434. package/dist/services/content-api/index.js +28 -2
  435. package/dist/services/content-api/index.js.map +1 -1
  436. package/dist/services/content-api/index.mjs +28 -2
  437. package/dist/services/content-api/index.mjs.map +1 -1
  438. package/dist/services/content-api/permissions/index.d.ts +13 -15
  439. package/dist/services/content-api/permissions/index.d.ts.map +1 -1
  440. package/dist/services/content-api/permissions/index.js +1 -1
  441. package/dist/services/content-api/permissions/index.js.map +1 -1
  442. package/dist/services/content-api/permissions/index.mjs +1 -1
  443. package/dist/services/content-api/permissions/index.mjs.map +1 -1
  444. package/dist/services/content-api/permissions/providers/action.d.ts +5 -6
  445. package/dist/services/content-api/permissions/providers/action.d.ts.map +1 -1
  446. package/dist/services/content-api/permissions/providers/condition.d.ts +5 -6
  447. package/dist/services/content-api/permissions/providers/condition.d.ts.map +1 -1
  448. package/dist/services/core-store.d.ts +2 -22
  449. package/dist/services/core-store.d.ts.map +1 -1
  450. package/dist/services/core-store.js +8 -4
  451. package/dist/services/core-store.js.map +1 -1
  452. package/dist/services/core-store.mjs +5 -1
  453. package/dist/services/core-store.mjs.map +1 -1
  454. package/dist/services/cron.d.ts +5 -5
  455. package/dist/services/cron.d.ts.map +1 -1
  456. package/dist/services/cron.js +3 -3
  457. package/dist/services/cron.js.map +1 -1
  458. package/dist/services/cron.mjs.map +1 -1
  459. package/dist/services/custom-fields.d.ts +2 -2
  460. package/dist/services/custom-fields.d.ts.map +1 -1
  461. package/dist/services/custom-fields.js.map +1 -1
  462. package/dist/services/custom-fields.mjs.map +1 -1
  463. package/dist/services/document-service/attributes/index.d.ts +6 -0
  464. package/dist/services/document-service/attributes/index.d.ts.map +1 -0
  465. package/dist/services/document-service/attributes/index.js +22 -0
  466. package/dist/services/document-service/attributes/index.js.map +1 -0
  467. package/dist/services/document-service/attributes/index.mjs +22 -0
  468. package/dist/services/document-service/attributes/index.mjs.map +1 -0
  469. package/dist/services/document-service/attributes/transforms.d.ts +10 -0
  470. package/dist/services/document-service/attributes/transforms.d.ts.map +1 -0
  471. package/dist/services/document-service/attributes/transforms.js +20 -0
  472. package/dist/services/document-service/attributes/transforms.js.map +1 -0
  473. package/dist/services/document-service/attributes/transforms.mjs.map +1 -0
  474. package/dist/services/document-service/common.d.ts +4 -0
  475. package/dist/services/document-service/common.d.ts.map +1 -0
  476. package/dist/services/document-service/common.js +7 -0
  477. package/dist/services/document-service/common.js.map +1 -0
  478. package/dist/services/document-service/common.mjs +7 -0
  479. package/dist/services/document-service/common.mjs.map +1 -0
  480. package/dist/services/document-service/components.d.ts +25 -1
  481. package/dist/services/document-service/components.d.ts.map +1 -1
  482. package/dist/services/document-service/components.js +288 -0
  483. package/dist/services/document-service/components.js.map +1 -0
  484. package/dist/services/document-service/components.mjs +286 -0
  485. package/dist/services/document-service/components.mjs.map +1 -0
  486. package/dist/services/document-service/draft-and-publish.d.ts +10 -0
  487. package/dist/services/document-service/draft-and-publish.d.ts.map +1 -0
  488. package/dist/services/document-service/draft-and-publish.js +69 -0
  489. package/dist/services/document-service/draft-and-publish.js.map +1 -0
  490. package/dist/services/document-service/draft-and-publish.mjs +69 -0
  491. package/dist/services/document-service/draft-and-publish.mjs.map +1 -0
  492. package/dist/services/document-service/entries.d.ts +10 -0
  493. package/dist/services/document-service/entries.d.ts.map +1 -0
  494. package/dist/services/document-service/entries.js +96 -0
  495. package/dist/services/document-service/entries.js.map +1 -0
  496. package/dist/services/document-service/entries.mjs +96 -0
  497. package/dist/services/document-service/entries.mjs.map +1 -0
  498. package/dist/services/document-service/events.d.ts +25 -0
  499. package/dist/services/document-service/events.d.ts.map +1 -0
  500. package/dist/services/document-service/events.js +47 -0
  501. package/dist/services/document-service/events.js.map +1 -0
  502. package/dist/services/document-service/events.mjs +47 -0
  503. package/dist/services/document-service/events.mjs.map +1 -0
  504. package/dist/services/document-service/index.d.ts +16 -7
  505. package/dist/services/document-service/index.d.ts.map +1 -1
  506. package/dist/services/document-service/index.js +28 -187
  507. package/dist/services/document-service/index.js.map +1 -1
  508. package/dist/services/document-service/index.mjs +27 -187
  509. package/dist/services/document-service/index.mjs.map +1 -1
  510. package/dist/services/document-service/internationalization.d.ts +8 -0
  511. package/dist/services/document-service/internationalization.d.ts.map +1 -0
  512. package/dist/services/document-service/internationalization.js +63 -0
  513. package/dist/services/document-service/internationalization.js.map +1 -0
  514. package/dist/services/document-service/internationalization.mjs +63 -0
  515. package/dist/services/document-service/internationalization.mjs.map +1 -0
  516. package/dist/services/document-service/middlewares/errors.d.ts +6 -0
  517. package/dist/services/document-service/middlewares/errors.d.ts.map +1 -0
  518. package/dist/services/document-service/middlewares/errors.js +25 -0
  519. package/dist/services/document-service/middlewares/errors.js.map +1 -0
  520. package/dist/services/document-service/middlewares/errors.mjs +25 -0
  521. package/dist/services/document-service/middlewares/errors.mjs.map +1 -0
  522. package/dist/services/document-service/middlewares/index.d.ts +2 -10
  523. package/dist/services/document-service/middlewares/index.d.ts.map +1 -1
  524. package/dist/services/document-service/middlewares/middleware-manager.d.ts +10 -0
  525. package/dist/services/document-service/middlewares/middleware-manager.d.ts.map +1 -0
  526. package/dist/services/document-service/middlewares/middleware-manager.js +49 -0
  527. package/dist/services/document-service/middlewares/middleware-manager.js.map +1 -0
  528. package/dist/services/document-service/middlewares/middleware-manager.mjs +49 -0
  529. package/dist/services/document-service/middlewares/middleware-manager.mjs.map +1 -0
  530. package/dist/services/document-service/params.d.ts +3 -1
  531. package/dist/services/document-service/params.d.ts.map +1 -1
  532. package/dist/services/document-service/params.js +8 -0
  533. package/dist/services/document-service/params.js.map +1 -0
  534. package/dist/services/document-service/params.mjs +8 -0
  535. package/dist/services/document-service/params.mjs.map +1 -0
  536. package/dist/services/document-service/repository.d.ts +3 -0
  537. package/dist/services/document-service/repository.d.ts.map +1 -0
  538. package/dist/services/document-service/repository.js +314 -0
  539. package/dist/services/document-service/repository.js.map +1 -0
  540. package/dist/services/document-service/repository.mjs +314 -0
  541. package/dist/services/document-service/repository.mjs.map +1 -0
  542. package/dist/services/document-service/transform/data.d.ts +5 -0
  543. package/dist/services/document-service/transform/data.d.ts.map +1 -0
  544. package/dist/services/document-service/transform/data.js +15 -0
  545. package/dist/services/document-service/transform/data.js.map +1 -0
  546. package/dist/services/document-service/transform/data.mjs +15 -0
  547. package/dist/services/document-service/transform/data.mjs.map +1 -0
  548. package/dist/services/document-service/transform/fields.d.ts +5 -0
  549. package/dist/services/document-service/transform/fields.d.ts.map +1 -0
  550. package/dist/services/document-service/transform/fields.js +24 -0
  551. package/dist/services/document-service/transform/fields.js.map +1 -0
  552. package/dist/services/document-service/transform/fields.mjs +24 -0
  553. package/dist/services/document-service/transform/fields.mjs.map +1 -0
  554. package/dist/services/document-service/transform/id-map.d.ts +23 -0
  555. package/dist/services/document-service/transform/id-map.d.ts.map +1 -0
  556. package/dist/services/document-service/transform/id-map.js +78 -0
  557. package/dist/services/document-service/transform/id-map.js.map +1 -0
  558. package/dist/services/document-service/transform/id-map.mjs +78 -0
  559. package/dist/services/document-service/transform/id-map.mjs.map +1 -0
  560. package/dist/services/document-service/transform/id-transform.d.ts +5 -0
  561. package/dist/services/document-service/transform/id-transform.d.ts.map +1 -0
  562. package/dist/services/document-service/transform/id-transform.js +33 -0
  563. package/dist/services/document-service/transform/id-transform.js.map +1 -0
  564. package/dist/services/document-service/transform/id-transform.mjs +33 -0
  565. package/dist/services/document-service/transform/id-transform.mjs.map +1 -0
  566. package/dist/services/document-service/transform/populate.d.ts +6 -0
  567. package/dist/services/document-service/transform/populate.d.ts.map +1 -0
  568. package/dist/services/document-service/transform/populate.js +21 -0
  569. package/dist/services/document-service/transform/populate.js.map +1 -0
  570. package/dist/services/document-service/transform/populate.mjs +21 -0
  571. package/dist/services/document-service/transform/populate.mjs.map +1 -0
  572. package/dist/services/document-service/transform/query.d.ts +5 -0
  573. package/dist/services/document-service/transform/query.d.ts.map +1 -0
  574. package/dist/services/document-service/transform/query.js +9 -0
  575. package/dist/services/document-service/transform/query.js.map +1 -0
  576. package/dist/services/document-service/transform/query.mjs +9 -0
  577. package/dist/services/document-service/transform/query.mjs.map +1 -0
  578. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts +14 -0
  579. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts.map +1 -0
  580. package/dist/services/document-service/transform/relations/extract/data-ids.js +57 -0
  581. package/dist/services/document-service/transform/relations/extract/data-ids.js.map +1 -0
  582. package/dist/services/document-service/transform/relations/extract/data-ids.mjs +57 -0
  583. package/dist/services/document-service/transform/relations/extract/data-ids.mjs.map +1 -0
  584. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts +14 -0
  585. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts.map +1 -0
  586. package/dist/services/document-service/transform/relations/transform/data-ids.js +76 -0
  587. package/dist/services/document-service/transform/relations/transform/data-ids.js.map +1 -0
  588. package/dist/services/document-service/transform/relations/transform/data-ids.mjs +76 -0
  589. package/dist/services/document-service/transform/relations/transform/data-ids.mjs.map +1 -0
  590. package/dist/services/document-service/transform/relations/transform/default-locale.d.ts +9 -0
  591. package/dist/services/document-service/transform/relations/transform/default-locale.d.ts.map +1 -0
  592. package/dist/services/document-service/transform/relations/transform/default-locale.js +32 -0
  593. package/dist/services/document-service/transform/relations/transform/default-locale.js.map +1 -0
  594. package/dist/services/document-service/transform/relations/transform/default-locale.mjs +32 -0
  595. package/dist/services/document-service/transform/relations/transform/default-locale.mjs.map +1 -0
  596. package/dist/services/document-service/transform/relations/utils/data.d.ts +4 -0
  597. package/dist/services/document-service/transform/relations/utils/data.d.ts.map +1 -0
  598. package/dist/services/document-service/transform/relations/utils/dp.d.ts +10 -0
  599. package/dist/services/document-service/transform/relations/utils/dp.d.ts.map +1 -0
  600. package/dist/services/document-service/transform/relations/utils/dp.js +30 -0
  601. package/dist/services/document-service/transform/relations/utils/dp.js.map +1 -0
  602. package/dist/services/document-service/transform/relations/utils/dp.mjs +30 -0
  603. package/dist/services/document-service/transform/relations/utils/dp.mjs.map +1 -0
  604. package/dist/services/document-service/transform/relations/utils/i18n.d.ts +10 -0
  605. package/dist/services/document-service/transform/relations/utils/i18n.d.ts.map +1 -0
  606. package/dist/services/document-service/transform/relations/utils/i18n.js +25 -0
  607. package/dist/services/document-service/transform/relations/utils/i18n.js.map +1 -0
  608. package/dist/services/document-service/transform/relations/utils/i18n.mjs +25 -0
  609. package/dist/services/document-service/transform/relations/utils/i18n.mjs.map +1 -0
  610. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts +6 -0
  611. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts.map +1 -0
  612. package/dist/services/document-service/transform/relations/utils/map-relation.js +91 -0
  613. package/dist/services/document-service/transform/relations/utils/map-relation.js.map +1 -0
  614. package/dist/services/document-service/transform/relations/utils/map-relation.mjs +91 -0
  615. package/dist/services/document-service/transform/relations/utils/map-relation.mjs.map +1 -0
  616. package/dist/services/document-service/transform/relations/utils/types.d.ts +21 -0
  617. package/dist/services/document-service/transform/relations/utils/types.d.ts.map +1 -0
  618. package/dist/services/document-service/transform/types.d.ts +13 -0
  619. package/dist/services/document-service/transform/types.d.ts.map +1 -0
  620. package/dist/services/document-service/utils/populate.d.ts +10 -0
  621. package/dist/services/document-service/utils/populate.d.ts.map +1 -0
  622. package/dist/services/document-service/utils/populate.js +47 -0
  623. package/dist/services/document-service/utils/populate.js.map +1 -0
  624. package/dist/services/document-service/utils/populate.mjs +47 -0
  625. package/dist/services/document-service/utils/populate.mjs.map +1 -0
  626. package/dist/services/document-service/utils/unidirectional-relations.d.ts +33 -0
  627. package/dist/services/document-service/utils/unidirectional-relations.d.ts.map +1 -0
  628. package/dist/services/document-service/utils/unidirectional-relations.js +58 -0
  629. package/dist/services/document-service/utils/unidirectional-relations.js.map +1 -0
  630. package/dist/services/document-service/utils/unidirectional-relations.mjs +58 -0
  631. package/dist/services/document-service/utils/unidirectional-relations.mjs.map +1 -0
  632. package/dist/services/entity-service/index.d.ts +4 -6
  633. package/dist/services/entity-service/index.d.ts.map +1 -1
  634. package/dist/services/entity-service/index.js +44 -203
  635. package/dist/services/entity-service/index.js.map +1 -1
  636. package/dist/services/entity-service/index.mjs +38 -197
  637. package/dist/services/entity-service/index.mjs.map +1 -1
  638. package/dist/services/entity-validator/blocks-validator.d.ts +1 -2
  639. package/dist/services/entity-validator/blocks-validator.d.ts.map +1 -1
  640. package/dist/services/entity-validator/blocks-validator.js +26 -5
  641. package/dist/services/entity-validator/blocks-validator.js.map +1 -1
  642. package/dist/services/entity-validator/blocks-validator.mjs +25 -5
  643. package/dist/services/entity-validator/blocks-validator.mjs.map +1 -1
  644. package/dist/services/entity-validator/index.d.ts +16 -2
  645. package/dist/services/entity-validator/index.d.ts.map +1 -1
  646. package/dist/services/entity-validator/index.js +201 -131
  647. package/dist/services/entity-validator/index.js.map +1 -1
  648. package/dist/services/entity-validator/index.mjs +196 -126
  649. package/dist/services/entity-validator/index.mjs.map +1 -1
  650. package/dist/services/entity-validator/validators.d.ts +37 -25
  651. package/dist/services/entity-validator/validators.d.ts.map +1 -1
  652. package/dist/services/entity-validator/validators.js +163 -39
  653. package/dist/services/entity-validator/validators.js.map +1 -1
  654. package/dist/services/entity-validator/validators.mjs +155 -31
  655. package/dist/services/entity-validator/validators.mjs.map +1 -1
  656. package/dist/services/event-hub.d.ts +1 -0
  657. package/dist/services/event-hub.d.ts.map +1 -1
  658. package/dist/services/event-hub.js +9 -4
  659. package/dist/services/event-hub.js.map +1 -1
  660. package/dist/services/event-hub.mjs +9 -4
  661. package/dist/services/event-hub.mjs.map +1 -1
  662. package/dist/services/features.d.ts +10 -0
  663. package/dist/services/features.d.ts.map +1 -0
  664. package/dist/services/features.js +17 -0
  665. package/dist/services/features.js.map +1 -0
  666. package/dist/services/features.mjs +17 -0
  667. package/dist/services/features.mjs.map +1 -0
  668. package/dist/services/fs.d.ts +2 -2
  669. package/dist/services/fs.d.ts.map +1 -1
  670. package/dist/services/fs.js.map +1 -1
  671. package/dist/services/fs.mjs.map +1 -1
  672. package/dist/services/metrics/admin-user-hash.d.ts +2 -2
  673. package/dist/services/metrics/admin-user-hash.d.ts.map +1 -1
  674. package/dist/services/metrics/admin-user-hash.js.map +1 -1
  675. package/dist/services/metrics/admin-user-hash.mjs.map +1 -1
  676. package/dist/services/metrics/index.d.ts +2 -2
  677. package/dist/services/metrics/index.d.ts.map +1 -1
  678. package/dist/services/metrics/index.js.map +1 -1
  679. package/dist/services/metrics/index.mjs.map +1 -1
  680. package/dist/services/metrics/middleware.d.ts +2 -2
  681. package/dist/services/metrics/middleware.d.ts.map +1 -1
  682. package/dist/services/metrics/middleware.js.map +1 -1
  683. package/dist/services/metrics/middleware.mjs.map +1 -1
  684. package/dist/services/metrics/rate-limiter.d.ts.map +1 -1
  685. package/dist/services/metrics/rate-limiter.js.map +1 -1
  686. package/dist/services/metrics/rate-limiter.mjs.map +1 -1
  687. package/dist/services/metrics/sender.d.ts +3 -3
  688. package/dist/services/metrics/sender.d.ts.map +1 -1
  689. package/dist/services/metrics/sender.js.map +1 -1
  690. package/dist/services/metrics/sender.mjs.map +1 -1
  691. package/dist/services/query-params.d.ts +7 -0
  692. package/dist/services/query-params.d.ts.map +1 -0
  693. package/dist/services/query-params.js +12 -0
  694. package/dist/services/query-params.js.map +1 -0
  695. package/dist/services/query-params.mjs +13 -0
  696. package/dist/services/query-params.mjs.map +1 -0
  697. package/dist/services/reloader.d.ts +7 -0
  698. package/dist/services/reloader.d.ts.map +1 -0
  699. package/dist/services/reloader.js +36 -0
  700. package/dist/services/reloader.js.map +1 -0
  701. package/dist/services/reloader.mjs +36 -0
  702. package/dist/services/reloader.mjs.map +1 -0
  703. package/dist/services/server/admin-api.d.ts +3 -3
  704. package/dist/services/server/admin-api.d.ts.map +1 -1
  705. package/dist/services/server/admin-api.js.map +1 -1
  706. package/dist/services/server/admin-api.mjs.map +1 -1
  707. package/dist/services/server/api.d.ts +3 -3
  708. package/dist/services/server/api.d.ts.map +1 -1
  709. package/dist/services/server/api.js.map +1 -1
  710. package/dist/services/server/api.mjs.map +1 -1
  711. package/dist/services/server/compose-endpoint.d.ts +2 -2
  712. package/dist/services/server/compose-endpoint.d.ts.map +1 -1
  713. package/dist/services/server/compose-endpoint.js +11 -9
  714. package/dist/services/server/compose-endpoint.js.map +1 -1
  715. package/dist/services/server/compose-endpoint.mjs +5 -3
  716. package/dist/services/server/compose-endpoint.mjs.map +1 -1
  717. package/dist/services/server/content-api.d.ts +3 -3
  718. package/dist/services/server/content-api.d.ts.map +1 -1
  719. package/dist/services/server/content-api.js.map +1 -1
  720. package/dist/services/server/content-api.mjs.map +1 -1
  721. package/dist/services/server/http-server.d.ts +2 -2
  722. package/dist/services/server/http-server.d.ts.map +1 -1
  723. package/dist/services/server/http-server.js.map +1 -1
  724. package/dist/services/server/http-server.mjs.map +1 -1
  725. package/dist/services/server/index.d.ts +2 -2
  726. package/dist/services/server/index.d.ts.map +1 -1
  727. package/dist/services/server/index.js +2 -3
  728. package/dist/services/server/index.js.map +1 -1
  729. package/dist/services/server/index.mjs +2 -3
  730. package/dist/services/server/index.mjs.map +1 -1
  731. package/dist/services/server/koa.d.ts.map +1 -1
  732. package/dist/services/server/koa.js +4 -4
  733. package/dist/services/server/koa.js.map +1 -1
  734. package/dist/services/server/koa.mjs +1 -1
  735. package/dist/services/server/koa.mjs.map +1 -1
  736. package/dist/services/server/middleware.d.ts +4 -8
  737. package/dist/services/server/middleware.d.ts.map +1 -1
  738. package/dist/services/server/middleware.js +3 -3
  739. package/dist/services/server/middleware.js.map +1 -1
  740. package/dist/services/server/middleware.mjs.map +1 -1
  741. package/dist/services/server/policy.d.ts +3 -3
  742. package/dist/services/server/policy.d.ts.map +1 -1
  743. package/dist/services/server/policy.js +4 -4
  744. package/dist/services/server/policy.js.map +1 -1
  745. package/dist/services/server/policy.mjs +4 -4
  746. package/dist/services/server/policy.mjs.map +1 -1
  747. package/dist/services/server/register-middlewares.d.ts +2 -2
  748. package/dist/services/server/register-middlewares.d.ts.map +1 -1
  749. package/dist/services/server/register-middlewares.js +1 -1
  750. package/dist/services/server/register-middlewares.js.map +1 -1
  751. package/dist/services/server/register-middlewares.mjs +1 -1
  752. package/dist/services/server/register-middlewares.mjs.map +1 -1
  753. package/dist/services/server/register-routes.d.ts +2 -2
  754. package/dist/services/server/register-routes.d.ts.map +1 -1
  755. package/dist/services/server/register-routes.js +3 -3
  756. package/dist/services/server/register-routes.js.map +1 -1
  757. package/dist/services/server/register-routes.mjs +3 -3
  758. package/dist/services/server/register-routes.mjs.map +1 -1
  759. package/dist/services/server/routing.d.ts +5 -5
  760. package/dist/services/server/routing.d.ts.map +1 -1
  761. package/dist/services/server/routing.js +2 -2
  762. package/dist/services/server/routing.js.map +1 -1
  763. package/dist/services/server/routing.mjs.map +1 -1
  764. package/dist/services/utils/dynamic-zones.d.ts.map +1 -1
  765. package/dist/services/utils/dynamic-zones.js +7 -6
  766. package/dist/services/utils/dynamic-zones.js.map +1 -1
  767. package/dist/services/utils/dynamic-zones.mjs +2 -1
  768. package/dist/services/utils/dynamic-zones.mjs.map +1 -1
  769. package/dist/services/webhook-runner.d.ts +12 -2
  770. package/dist/services/webhook-runner.d.ts.map +1 -1
  771. package/dist/services/webhook-runner.js.map +1 -1
  772. package/dist/services/webhook-runner.mjs.map +1 -1
  773. package/dist/services/webhook-store.d.ts +4 -30
  774. package/dist/services/webhook-store.d.ts.map +1 -1
  775. package/dist/services/webhook-store.js +20 -10
  776. package/dist/services/webhook-store.js.map +1 -1
  777. package/dist/services/webhook-store.mjs +20 -10
  778. package/dist/services/webhook-store.mjs.map +1 -1
  779. package/dist/utils/convert-custom-field-type.d.ts +2 -3
  780. package/dist/utils/convert-custom-field-type.d.ts.map +1 -1
  781. package/dist/utils/convert-custom-field-type.js +2 -1
  782. package/dist/utils/convert-custom-field-type.js.map +1 -1
  783. package/dist/utils/convert-custom-field-type.mjs +1 -1
  784. package/dist/utils/convert-custom-field-type.mjs.map +1 -1
  785. package/dist/utils/cron.js +3 -3
  786. package/dist/utils/cron.js.map +1 -1
  787. package/dist/utils/ee.d.ts +1 -2
  788. package/dist/utils/ee.d.ts.map +1 -1
  789. package/dist/utils/fetch.d.ts +3 -2
  790. package/dist/utils/fetch.d.ts.map +1 -1
  791. package/dist/utils/fetch.js +6 -5
  792. package/dist/utils/fetch.js.map +1 -1
  793. package/dist/utils/fetch.mjs +6 -5
  794. package/dist/utils/fetch.mjs.map +1 -1
  795. package/dist/utils/filepath-to-prop-path.d.ts +5 -0
  796. package/dist/utils/filepath-to-prop-path.d.ts.map +1 -0
  797. package/dist/utils/filepath-to-prop-path.js +33 -0
  798. package/dist/utils/filepath-to-prop-path.js.map +1 -0
  799. package/dist/utils/filepath-to-prop-path.mjs +30 -0
  800. package/dist/utils/filepath-to-prop-path.mjs.map +1 -0
  801. package/dist/utils/index.d.ts +12 -4
  802. package/dist/utils/index.d.ts.map +1 -1
  803. package/dist/utils/is-initialized.d.ts +2 -2
  804. package/dist/utils/is-initialized.d.ts.map +1 -1
  805. package/dist/utils/is-initialized.js +8 -7
  806. package/dist/utils/is-initialized.js.map +1 -1
  807. package/dist/utils/is-initialized.mjs +4 -4
  808. package/dist/utils/is-initialized.mjs.map +1 -1
  809. package/dist/utils/load-config-file.d.ts +2 -0
  810. package/dist/utils/load-config-file.d.ts.map +1 -0
  811. package/dist/utils/load-config-file.js +45 -0
  812. package/dist/utils/load-config-file.js.map +1 -0
  813. package/dist/utils/load-config-file.mjs +42 -0
  814. package/dist/utils/load-config-file.mjs.map +1 -0
  815. package/dist/utils/load-files.d.ts +11 -0
  816. package/dist/utils/load-files.d.ts.map +1 -0
  817. package/dist/utils/load-files.js +39 -0
  818. package/dist/utils/load-files.js.map +1 -0
  819. package/dist/utils/load-files.mjs +35 -0
  820. package/dist/utils/load-files.mjs.map +1 -0
  821. package/dist/utils/open-browser.d.ts +2 -3
  822. package/dist/utils/open-browser.d.ts.map +1 -1
  823. package/dist/utils/open-browser.js +5 -5
  824. package/dist/utils/open-browser.js.map +1 -1
  825. package/dist/utils/open-browser.mjs +4 -5
  826. package/dist/utils/open-browser.mjs.map +1 -1
  827. package/dist/utils/resolve-working-dirs.d.ts +19 -0
  828. package/dist/utils/resolve-working-dirs.d.ts.map +1 -0
  829. package/dist/utils/resolve-working-dirs.js +13 -0
  830. package/dist/utils/resolve-working-dirs.js.map +1 -0
  831. package/dist/utils/resolve-working-dirs.mjs +11 -0
  832. package/dist/utils/resolve-working-dirs.mjs.map +1 -0
  833. package/dist/utils/signals.d.ts +2 -2
  834. package/dist/utils/signals.d.ts.map +1 -1
  835. package/dist/utils/signals.js.map +1 -1
  836. package/dist/utils/signals.mjs.map +1 -1
  837. package/dist/utils/startup-logger.d.ts +2 -3
  838. package/dist/utils/startup-logger.d.ts.map +1 -1
  839. package/dist/utils/startup-logger.js +23 -17
  840. package/dist/utils/startup-logger.js.map +1 -1
  841. package/dist/utils/startup-logger.mjs +21 -16
  842. package/dist/utils/startup-logger.mjs.map +1 -1
  843. package/dist/utils/transform-content-types-to-models.d.ts +129 -3
  844. package/dist/utils/transform-content-types-to-models.d.ts.map +1 -1
  845. package/dist/utils/transform-content-types-to-models.js +254 -16
  846. package/dist/utils/transform-content-types-to-models.js.map +1 -1
  847. package/dist/utils/transform-content-types-to-models.mjs +251 -16
  848. package/dist/utils/transform-content-types-to-models.mjs.map +1 -1
  849. package/dist/utils/update-notifier/index.d.ts +2 -8
  850. package/dist/utils/update-notifier/index.d.ts.map +1 -1
  851. package/dist/utils/update-notifier/index.js +13 -10
  852. package/dist/utils/update-notifier/index.js.map +1 -1
  853. package/dist/utils/update-notifier/index.mjs +12 -10
  854. package/dist/utils/update-notifier/index.mjs.map +1 -1
  855. package/package.json +37 -41
  856. package/bin/strapi.js +0 -2
  857. package/dist/admin.d.ts +0 -5
  858. package/dist/admin.d.ts.map +0 -1
  859. package/dist/cli.d.ts +0 -2
  860. package/dist/cli.d.ts.map +0 -1
  861. package/dist/commands/actions/admin/create-user/action.d.ts +0 -12
  862. package/dist/commands/actions/admin/create-user/action.d.ts.map +0 -1
  863. package/dist/commands/actions/admin/create-user/command.d.ts +0 -7
  864. package/dist/commands/actions/admin/create-user/command.d.ts.map +0 -1
  865. package/dist/commands/actions/admin/reset-user-password/action.d.ts +0 -10
  866. package/dist/commands/actions/admin/reset-user-password/action.d.ts.map +0 -1
  867. package/dist/commands/actions/admin/reset-user-password/command.d.ts +0 -7
  868. package/dist/commands/actions/admin/reset-user-password/command.d.ts.map +0 -1
  869. package/dist/commands/actions/components/list/action.d.ts +0 -3
  870. package/dist/commands/actions/components/list/action.d.ts.map +0 -1
  871. package/dist/commands/actions/components/list/command.d.ts +0 -7
  872. package/dist/commands/actions/components/list/command.d.ts.map +0 -1
  873. package/dist/commands/actions/configuration/dump/action.d.ts +0 -11
  874. package/dist/commands/actions/configuration/dump/action.d.ts.map +0 -1
  875. package/dist/commands/actions/configuration/dump/command.d.ts +0 -7
  876. package/dist/commands/actions/configuration/dump/command.d.ts.map +0 -1
  877. package/dist/commands/actions/configuration/restore/action.d.ts +0 -11
  878. package/dist/commands/actions/configuration/restore/action.d.ts.map +0 -1
  879. package/dist/commands/actions/configuration/restore/command.d.ts +0 -7
  880. package/dist/commands/actions/configuration/restore/command.d.ts.map +0 -1
  881. package/dist/commands/actions/console/action.d.ts +0 -6
  882. package/dist/commands/actions/console/action.d.ts.map +0 -1
  883. package/dist/commands/actions/console/command.d.ts +0 -7
  884. package/dist/commands/actions/console/command.d.ts.map +0 -1
  885. package/dist/commands/actions/content-types/list/action.d.ts +0 -3
  886. package/dist/commands/actions/content-types/list/action.d.ts.map +0 -1
  887. package/dist/commands/actions/content-types/list/command.d.ts +0 -7
  888. package/dist/commands/actions/content-types/list/command.d.ts.map +0 -1
  889. package/dist/commands/actions/controllers/list/action.d.ts +0 -3
  890. package/dist/commands/actions/controllers/list/action.d.ts.map +0 -1
  891. package/dist/commands/actions/controllers/list/command.d.ts +0 -7
  892. package/dist/commands/actions/controllers/list/command.d.ts.map +0 -1
  893. package/dist/commands/actions/generate/command.d.ts +0 -7
  894. package/dist/commands/actions/generate/command.d.ts.map +0 -1
  895. package/dist/commands/actions/hooks/list/action.d.ts +0 -3
  896. package/dist/commands/actions/hooks/list/action.d.ts.map +0 -1
  897. package/dist/commands/actions/hooks/list/command.d.ts +0 -7
  898. package/dist/commands/actions/hooks/list/command.d.ts.map +0 -1
  899. package/dist/commands/actions/install/action.d.ts +0 -3
  900. package/dist/commands/actions/install/action.d.ts.map +0 -1
  901. package/dist/commands/actions/install/command.d.ts +0 -7
  902. package/dist/commands/actions/install/command.d.ts.map +0 -1
  903. package/dist/commands/actions/middlewares/list/action.d.ts +0 -3
  904. package/dist/commands/actions/middlewares/list/action.d.ts.map +0 -1
  905. package/dist/commands/actions/middlewares/list/command.d.ts +0 -7
  906. package/dist/commands/actions/middlewares/list/command.d.ts.map +0 -1
  907. package/dist/commands/actions/new/action.d.ts +0 -8
  908. package/dist/commands/actions/new/action.d.ts.map +0 -1
  909. package/dist/commands/actions/new/command.d.ts +0 -7
  910. package/dist/commands/actions/new/command.d.ts.map +0 -1
  911. package/dist/commands/actions/plugin/build-command/action.d.ts +0 -7
  912. package/dist/commands/actions/plugin/build-command/action.d.ts.map +0 -1
  913. package/dist/commands/actions/plugin/build-command/command.d.ts +0 -7
  914. package/dist/commands/actions/plugin/build-command/command.d.ts.map +0 -1
  915. package/dist/commands/actions/plugin/watch/action.d.ts +0 -7
  916. package/dist/commands/actions/plugin/watch/action.d.ts.map +0 -1
  917. package/dist/commands/actions/plugin/watch/command.d.ts +0 -7
  918. package/dist/commands/actions/plugin/watch/command.d.ts.map +0 -1
  919. package/dist/commands/actions/policies/list/action.d.ts +0 -3
  920. package/dist/commands/actions/policies/list/action.d.ts.map +0 -1
  921. package/dist/commands/actions/policies/list/command.d.ts +0 -7
  922. package/dist/commands/actions/policies/list/command.d.ts.map +0 -1
  923. package/dist/commands/actions/report/action.d.ts +0 -8
  924. package/dist/commands/actions/report/action.d.ts.map +0 -1
  925. package/dist/commands/actions/report/command.d.ts +0 -7
  926. package/dist/commands/actions/report/command.d.ts.map +0 -1
  927. package/dist/commands/actions/routes/list/action.d.ts +0 -3
  928. package/dist/commands/actions/routes/list/action.d.ts.map +0 -1
  929. package/dist/commands/actions/routes/list/command.d.ts +0 -7
  930. package/dist/commands/actions/routes/list/command.d.ts.map +0 -1
  931. package/dist/commands/actions/services/list/action.d.ts +0 -3
  932. package/dist/commands/actions/services/list/action.d.ts.map +0 -1
  933. package/dist/commands/actions/services/list/command.d.ts +0 -7
  934. package/dist/commands/actions/services/list/command.d.ts.map +0 -1
  935. package/dist/commands/actions/start/action.d.ts +0 -6
  936. package/dist/commands/actions/start/action.d.ts.map +0 -1
  937. package/dist/commands/actions/start/command.d.ts +0 -7
  938. package/dist/commands/actions/start/command.d.ts.map +0 -1
  939. package/dist/commands/actions/telemetry/disable/action.d.ts +0 -2
  940. package/dist/commands/actions/telemetry/disable/action.d.ts.map +0 -1
  941. package/dist/commands/actions/telemetry/disable/command.d.ts +0 -7
  942. package/dist/commands/actions/telemetry/disable/command.d.ts.map +0 -1
  943. package/dist/commands/actions/telemetry/enable/action.d.ts +0 -3
  944. package/dist/commands/actions/telemetry/enable/action.d.ts.map +0 -1
  945. package/dist/commands/actions/telemetry/enable/command.d.ts +0 -7
  946. package/dist/commands/actions/telemetry/enable/command.d.ts.map +0 -1
  947. package/dist/commands/actions/templates/generate/action.d.ts +0 -2
  948. package/dist/commands/actions/templates/generate/action.d.ts.map +0 -1
  949. package/dist/commands/actions/templates/generate/command.d.ts +0 -7
  950. package/dist/commands/actions/templates/generate/command.d.ts.map +0 -1
  951. package/dist/commands/actions/ts/generate-types/action.d.ts +0 -9
  952. package/dist/commands/actions/ts/generate-types/action.d.ts.map +0 -1
  953. package/dist/commands/actions/ts/generate-types/command.d.ts +0 -7
  954. package/dist/commands/actions/ts/generate-types/command.d.ts.map +0 -1
  955. package/dist/commands/actions/uninstall/action.d.ts +0 -6
  956. package/dist/commands/actions/uninstall/action.d.ts.map +0 -1
  957. package/dist/commands/actions/uninstall/command.d.ts +0 -7
  958. package/dist/commands/actions/uninstall/command.d.ts.map +0 -1
  959. package/dist/commands/actions/version/command.d.ts +0 -7
  960. package/dist/commands/actions/version/command.d.ts.map +0 -1
  961. package/dist/commands/actions/watch-admin/action.d.ts +0 -7
  962. package/dist/commands/actions/watch-admin/action.d.ts.map +0 -1
  963. package/dist/commands/actions/watch-admin/command.d.ts +0 -7
  964. package/dist/commands/actions/watch-admin/command.d.ts.map +0 -1
  965. package/dist/commands/index.d.ts +0 -37
  966. package/dist/commands/index.d.ts.map +0 -1
  967. package/dist/commands/types.d.ts +0 -14
  968. package/dist/commands/types.d.ts.map +0 -1
  969. package/dist/commands/utils/commander.d.ts +0 -36
  970. package/dist/commands/utils/commander.d.ts.map +0 -1
  971. package/dist/commands/utils/helpers.d.ts +0 -49
  972. package/dist/commands/utils/helpers.d.ts.map +0 -1
  973. package/dist/commands/utils/logger.d.ts +0 -19
  974. package/dist/commands/utils/logger.d.ts.map +0 -1
  975. package/dist/commands/utils/pkg.d.ts +0 -119
  976. package/dist/commands/utils/pkg.d.ts.map +0 -1
  977. package/dist/commands/utils/tsconfig.d.ts +0 -19
  978. package/dist/commands/utils/tsconfig.d.ts.map +0 -1
  979. package/dist/core/app-configuration/config-loader.d.ts.map +0 -1
  980. package/dist/core/app-configuration/config-loader.js +0 -19
  981. package/dist/core/app-configuration/config-loader.js.map +0 -1
  982. package/dist/core/app-configuration/config-loader.mjs +0 -17
  983. package/dist/core/app-configuration/config-loader.mjs.map +0 -1
  984. package/dist/core/app-configuration/index.d.ts +0 -36
  985. package/dist/core/app-configuration/index.d.ts.map +0 -1
  986. package/dist/core/app-configuration/index.js +0 -55
  987. package/dist/core/app-configuration/index.js.map +0 -1
  988. package/dist/core/app-configuration/index.mjs +0 -51
  989. package/dist/core/app-configuration/index.mjs.map +0 -1
  990. package/dist/core/app-configuration/load-config-file.d.ts +0 -2
  991. package/dist/core/app-configuration/load-config-file.d.ts.map +0 -1
  992. package/dist/core/app-configuration/load-config-file.js +0 -45
  993. package/dist/core/app-configuration/load-config-file.js.map +0 -1
  994. package/dist/core/app-configuration/load-config-file.mjs +0 -42
  995. package/dist/core/app-configuration/load-config-file.mjs.map +0 -1
  996. package/dist/core/bootstrap.d.ts +0 -5
  997. package/dist/core/bootstrap.d.ts.map +0 -1
  998. package/dist/core/bootstrap.js +0 -28
  999. package/dist/core/bootstrap.js.map +0 -1
  1000. package/dist/core/bootstrap.mjs +0 -27
  1001. package/dist/core/bootstrap.mjs.map +0 -1
  1002. package/dist/core/domain/content-type/index.d.ts +0 -9
  1003. package/dist/core/domain/content-type/index.d.ts.map +0 -1
  1004. package/dist/core/domain/content-type/index.js +0 -122
  1005. package/dist/core/domain/content-type/index.js.map +0 -1
  1006. package/dist/core/domain/content-type/index.mjs +0 -120
  1007. package/dist/core/domain/content-type/index.mjs.map +0 -1
  1008. package/dist/core/domain/content-type/validator.d.ts.map +0 -1
  1009. package/dist/core/domain/content-type/validator.js +0 -77
  1010. package/dist/core/domain/content-type/validator.js.map +0 -1
  1011. package/dist/core/domain/content-type/validator.mjs +0 -75
  1012. package/dist/core/domain/content-type/validator.mjs.map +0 -1
  1013. package/dist/core/domain/module/index.d.ts +0 -39
  1014. package/dist/core/domain/module/index.d.ts.map +0 -1
  1015. package/dist/core/domain/module/index.js +0 -107
  1016. package/dist/core/domain/module/index.js.map +0 -1
  1017. package/dist/core/domain/module/index.mjs +0 -105
  1018. package/dist/core/domain/module/index.mjs.map +0 -1
  1019. package/dist/core/domain/module/validation.d.ts.map +0 -1
  1020. package/dist/core/domain/module/validation.js.map +0 -1
  1021. package/dist/core/domain/module/validation.mjs.map +0 -1
  1022. package/dist/core/loaders/admin.d.ts +0 -3
  1023. package/dist/core/loaders/admin.d.ts.map +0 -1
  1024. package/dist/core/loaders/admin.js +0 -16
  1025. package/dist/core/loaders/admin.js.map +0 -1
  1026. package/dist/core/loaders/admin.mjs +0 -15
  1027. package/dist/core/loaders/admin.mjs.map +0 -1
  1028. package/dist/core/loaders/apis.d.ts +0 -3
  1029. package/dist/core/loaders/apis.d.ts.map +0 -1
  1030. package/dist/core/loaders/apis.js +0 -130
  1031. package/dist/core/loaders/apis.js.map +0 -1
  1032. package/dist/core/loaders/apis.mjs +0 -128
  1033. package/dist/core/loaders/apis.mjs.map +0 -1
  1034. package/dist/core/loaders/components.d.ts +0 -3
  1035. package/dist/core/loaders/components.d.ts.map +0 -1
  1036. package/dist/core/loaders/components.js +0 -38
  1037. package/dist/core/loaders/components.js.map +0 -1
  1038. package/dist/core/loaders/components.mjs +0 -37
  1039. package/dist/core/loaders/components.mjs.map +0 -1
  1040. package/dist/core/loaders/index.d.ts +0 -3
  1041. package/dist/core/loaders/index.d.ts.map +0 -1
  1042. package/dist/core/loaders/index.js +0 -26
  1043. package/dist/core/loaders/index.js.map +0 -1
  1044. package/dist/core/loaders/index.mjs +0 -26
  1045. package/dist/core/loaders/index.mjs.map +0 -1
  1046. package/dist/core/loaders/middlewares.d.ts +0 -3
  1047. package/dist/core/loaders/middlewares.d.ts.map +0 -1
  1048. package/dist/core/loaders/middlewares.js +0 -31
  1049. package/dist/core/loaders/middlewares.js.map +0 -1
  1050. package/dist/core/loaders/middlewares.mjs +0 -30
  1051. package/dist/core/loaders/middlewares.mjs.map +0 -1
  1052. package/dist/core/loaders/plugins/get-enabled-plugins.d.ts +0 -5
  1053. package/dist/core/loaders/plugins/get-enabled-plugins.d.ts.map +0 -1
  1054. package/dist/core/loaders/plugins/get-enabled-plugins.js +0 -110
  1055. package/dist/core/loaders/plugins/get-enabled-plugins.js.map +0 -1
  1056. package/dist/core/loaders/plugins/get-enabled-plugins.mjs +0 -108
  1057. package/dist/core/loaders/plugins/get-enabled-plugins.mjs.map +0 -1
  1058. package/dist/core/loaders/plugins/get-user-plugins-config.d.ts.map +0 -1
  1059. package/dist/core/loaders/plugins/get-user-plugins-config.js +0 -27
  1060. package/dist/core/loaders/plugins/get-user-plugins-config.js.map +0 -1
  1061. package/dist/core/loaders/plugins/get-user-plugins-config.mjs +0 -25
  1062. package/dist/core/loaders/plugins/get-user-plugins-config.mjs.map +0 -1
  1063. package/dist/core/loaders/plugins/index.d.ts +0 -3
  1064. package/dist/core/loaders/plugins/index.d.ts.map +0 -1
  1065. package/dist/core/loaders/plugins/index.js +0 -105
  1066. package/dist/core/loaders/plugins/index.js.map +0 -1
  1067. package/dist/core/loaders/plugins/index.mjs +0 -104
  1068. package/dist/core/loaders/plugins/index.mjs.map +0 -1
  1069. package/dist/core/loaders/policies.d.ts +0 -3
  1070. package/dist/core/loaders/policies.d.ts.map +0 -1
  1071. package/dist/core/loaders/policies.js.map +0 -1
  1072. package/dist/core/loaders/policies.mjs.map +0 -1
  1073. package/dist/core/loaders/sanitizers.d.ts +0 -4
  1074. package/dist/core/loaders/sanitizers.d.ts.map +0 -1
  1075. package/dist/core/loaders/sanitizers.js.map +0 -1
  1076. package/dist/core/loaders/sanitizers.mjs.map +0 -1
  1077. package/dist/core/loaders/src-index.d.ts +0 -4
  1078. package/dist/core/loaders/src-index.d.ts.map +0 -1
  1079. package/dist/core/loaders/src-index.js.map +0 -1
  1080. package/dist/core/loaders/src-index.mjs.map +0 -1
  1081. package/dist/core/loaders/validators.d.ts +0 -4
  1082. package/dist/core/loaders/validators.d.ts.map +0 -1
  1083. package/dist/core/loaders/validators.js.map +0 -1
  1084. package/dist/core/loaders/validators.mjs.map +0 -1
  1085. package/dist/core/registries/apis.d.ts +0 -8
  1086. package/dist/core/registries/apis.d.ts.map +0 -1
  1087. package/dist/core/registries/apis.js +0 -23
  1088. package/dist/core/registries/apis.js.map +0 -1
  1089. package/dist/core/registries/apis.mjs.map +0 -1
  1090. package/dist/core/registries/components.d.ts +0 -25
  1091. package/dist/core/registries/components.d.ts.map +0 -1
  1092. package/dist/core/registries/components.js +0 -45
  1093. package/dist/core/registries/components.js.map +0 -1
  1094. package/dist/core/registries/components.mjs.map +0 -1
  1095. package/dist/core/registries/config.d.ts +0 -4
  1096. package/dist/core/registries/config.d.ts.map +0 -1
  1097. package/dist/core/registries/config.js +0 -23
  1098. package/dist/core/registries/config.js.map +0 -1
  1099. package/dist/core/registries/config.mjs +0 -22
  1100. package/dist/core/registries/config.mjs.map +0 -1
  1101. package/dist/core/registries/content-types.d.ts +0 -33
  1102. package/dist/core/registries/content-types.d.ts.map +0 -1
  1103. package/dist/core/registries/content-types.js +0 -71
  1104. package/dist/core/registries/content-types.js.map +0 -1
  1105. package/dist/core/registries/content-types.mjs +0 -72
  1106. package/dist/core/registries/content-types.mjs.map +0 -1
  1107. package/dist/core/registries/controllers.d.ts +0 -35
  1108. package/dist/core/registries/controllers.d.ts.map +0 -1
  1109. package/dist/core/registries/controllers.js +0 -80
  1110. package/dist/core/registries/controllers.js.map +0 -1
  1111. package/dist/core/registries/controllers.mjs +0 -81
  1112. package/dist/core/registries/controllers.mjs.map +0 -1
  1113. package/dist/core/registries/custom-fields.d.ts +0 -8
  1114. package/dist/core/registries/custom-fields.d.ts.map +0 -1
  1115. package/dist/core/registries/custom-fields.js +0 -71
  1116. package/dist/core/registries/custom-fields.js.map +0 -1
  1117. package/dist/core/registries/custom-fields.mjs.map +0 -1
  1118. package/dist/core/registries/hooks.d.ts.map +0 -1
  1119. package/dist/core/registries/hooks.js +0 -58
  1120. package/dist/core/registries/hooks.js.map +0 -1
  1121. package/dist/core/registries/hooks.mjs +0 -59
  1122. package/dist/core/registries/hooks.mjs.map +0 -1
  1123. package/dist/core/registries/index.d.ts +0 -15
  1124. package/dist/core/registries/index.d.ts.map +0 -1
  1125. package/dist/core/registries/middlewares.d.ts +0 -31
  1126. package/dist/core/registries/middlewares.d.ts.map +0 -1
  1127. package/dist/core/registries/middlewares.js +0 -60
  1128. package/dist/core/registries/middlewares.js.map +0 -1
  1129. package/dist/core/registries/middlewares.mjs +0 -61
  1130. package/dist/core/registries/middlewares.mjs.map +0 -1
  1131. package/dist/core/registries/modules.d.ts +0 -15
  1132. package/dist/core/registries/modules.d.ts.map +0 -1
  1133. package/dist/core/registries/modules.js +0 -39
  1134. package/dist/core/registries/modules.js.map +0 -1
  1135. package/dist/core/registries/modules.mjs.map +0 -1
  1136. package/dist/core/registries/plugins.d.ts +0 -9
  1137. package/dist/core/registries/plugins.d.ts.map +0 -1
  1138. package/dist/core/registries/plugins.js +0 -23
  1139. package/dist/core/registries/plugins.js.map +0 -1
  1140. package/dist/core/registries/plugins.mjs.map +0 -1
  1141. package/dist/core/registries/policies.d.ts +0 -34
  1142. package/dist/core/registries/policies.d.ts.map +0 -1
  1143. package/dist/core/registries/policies.js +0 -62
  1144. package/dist/core/registries/policies.js.map +0 -1
  1145. package/dist/core/registries/policies.mjs +0 -63
  1146. package/dist/core/registries/policies.mjs.map +0 -1
  1147. package/dist/core/registries/sanitizers.d.ts.map +0 -1
  1148. package/dist/core/registries/sanitizers.js.map +0 -1
  1149. package/dist/core/registries/sanitizers.mjs.map +0 -1
  1150. package/dist/core/registries/services.d.ts +0 -35
  1151. package/dist/core/registries/services.d.ts.map +0 -1
  1152. package/dist/core/registries/services.js +0 -80
  1153. package/dist/core/registries/services.js.map +0 -1
  1154. package/dist/core/registries/services.mjs +0 -81
  1155. package/dist/core/registries/services.mjs.map +0 -1
  1156. package/dist/core/registries/validators.d.ts.map +0 -1
  1157. package/dist/core/registries/validators.js.map +0 -1
  1158. package/dist/core/registries/validators.mjs.map +0 -1
  1159. package/dist/core/utils.d.ts +0 -5
  1160. package/dist/core/utils.d.ts.map +0 -1
  1161. package/dist/core/utils.js +0 -27
  1162. package/dist/core/utils.js.map +0 -1
  1163. package/dist/core/utils.mjs +0 -27
  1164. package/dist/core/utils.mjs.map +0 -1
  1165. package/dist/core-api/service/get-fetch-params.d.ts +0 -7
  1166. package/dist/core-api/service/get-fetch-params.d.ts.map +0 -1
  1167. package/dist/core-api/service/get-fetch-params.js +0 -14
  1168. package/dist/core-api/service/get-fetch-params.js.map +0 -1
  1169. package/dist/core-api/service/get-fetch-params.mjs +0 -14
  1170. package/dist/core-api/service/get-fetch-params.mjs.map +0 -1
  1171. package/dist/load/filepath-to-prop-path.d.ts +0 -6
  1172. package/dist/load/filepath-to-prop-path.d.ts.map +0 -1
  1173. package/dist/load/filepath-to-prop-path.js +0 -11
  1174. package/dist/load/filepath-to-prop-path.js.map +0 -1
  1175. package/dist/load/filepath-to-prop-path.mjs +0 -10
  1176. package/dist/load/filepath-to-prop-path.mjs.map +0 -1
  1177. package/dist/load/glob.d.ts +0 -7
  1178. package/dist/load/glob.d.ts.map +0 -1
  1179. package/dist/load/glob.js +0 -15
  1180. package/dist/load/glob.js.map +0 -1
  1181. package/dist/load/glob.mjs +0 -14
  1182. package/dist/load/glob.mjs.map +0 -1
  1183. package/dist/load/index.d.ts +0 -3
  1184. package/dist/load/index.d.ts.map +0 -1
  1185. package/dist/load/load-files.d.ts +0 -11
  1186. package/dist/load/load-files.d.ts.map +0 -1
  1187. package/dist/load/load-files.js +0 -38
  1188. package/dist/load/load-files.js.map +0 -1
  1189. package/dist/load/load-files.mjs +0 -35
  1190. package/dist/load/load-files.mjs.map +0 -1
  1191. package/dist/load/package-path.d.ts +0 -6
  1192. package/dist/load/package-path.d.ts.map +0 -1
  1193. package/dist/middlewares/public/assets/images/group_people_1.png +0 -0
  1194. package/dist/middlewares/public/assets/images/group_people_2.png +0 -0
  1195. package/dist/middlewares/public/assets/images/group_people_3.png +0 -0
  1196. package/dist/middlewares/public/assets/images/logo_login.png +0 -0
  1197. package/dist/middlewares/public/index.d.ts +0 -3
  1198. package/dist/middlewares/public/index.d.ts.map +0 -1
  1199. package/dist/middlewares/public/index.html +0 -66
  1200. package/dist/middlewares/public/index.js +0 -91
  1201. package/dist/middlewares/public/index.js.map +0 -1
  1202. package/dist/middlewares/public/index.mjs +0 -85
  1203. package/dist/middlewares/public/index.mjs.map +0 -1
  1204. package/dist/middlewares/public/serve-static.d.ts +0 -4
  1205. package/dist/middlewares/public/serve-static.d.ts.map +0 -1
  1206. package/dist/middlewares/public/serve-static.js +0 -24
  1207. package/dist/middlewares/public/serve-static.js.map +0 -1
  1208. package/dist/middlewares/public/serve-static.mjs +0 -21
  1209. package/dist/middlewares/public/serve-static.mjs.map +0 -1
  1210. package/dist/services/document-service/document-repository.d.ts +0 -21
  1211. package/dist/services/document-service/document-repository.d.ts.map +0 -1
  1212. package/dist/services/document-service/document-repository.js +0 -132
  1213. package/dist/services/document-service/document-repository.js.map +0 -1
  1214. package/dist/services/document-service/document-repository.mjs +0 -132
  1215. package/dist/services/document-service/document-repository.mjs.map +0 -1
  1216. package/dist/services/document-service/middlewares/defaults/draft-and-publish.d.ts +0 -26
  1217. package/dist/services/document-service/middlewares/defaults/draft-and-publish.d.ts.map +0 -1
  1218. package/dist/services/document-service/middlewares/defaults/draft-and-publish.js +0 -58
  1219. package/dist/services/document-service/middlewares/defaults/draft-and-publish.js.map +0 -1
  1220. package/dist/services/document-service/middlewares/defaults/draft-and-publish.mjs +0 -58
  1221. package/dist/services/document-service/middlewares/defaults/draft-and-publish.mjs.map +0 -1
  1222. package/dist/services/document-service/middlewares/defaults/index.d.ts +0 -3
  1223. package/dist/services/document-service/middlewares/defaults/index.d.ts.map +0 -1
  1224. package/dist/services/document-service/middlewares/defaults/index.js +0 -82
  1225. package/dist/services/document-service/middlewares/defaults/index.js.map +0 -1
  1226. package/dist/services/document-service/middlewares/defaults/index.mjs +0 -82
  1227. package/dist/services/document-service/middlewares/defaults/index.mjs.map +0 -1
  1228. package/dist/services/document-service/middlewares/defaults/locales.d.ts +0 -18
  1229. package/dist/services/document-service/middlewares/defaults/locales.d.ts.map +0 -1
  1230. package/dist/services/document-service/middlewares/defaults/locales.js +0 -40
  1231. package/dist/services/document-service/middlewares/defaults/locales.js.map +0 -1
  1232. package/dist/services/document-service/middlewares/defaults/locales.mjs +0 -40
  1233. package/dist/services/document-service/middlewares/defaults/locales.mjs.map +0 -1
  1234. package/dist/services/document-service/middlewares/index.js +0 -59
  1235. package/dist/services/document-service/middlewares/index.js.map +0 -1
  1236. package/dist/services/document-service/middlewares/index.mjs +0 -59
  1237. package/dist/services/document-service/middlewares/index.mjs.map +0 -1
  1238. package/dist/services/entity-service/attributes/index.d.ts +0 -6
  1239. package/dist/services/entity-service/attributes/index.d.ts.map +0 -1
  1240. package/dist/services/entity-service/attributes/index.js +0 -22
  1241. package/dist/services/entity-service/attributes/index.js.map +0 -1
  1242. package/dist/services/entity-service/attributes/index.mjs +0 -22
  1243. package/dist/services/entity-service/attributes/index.mjs.map +0 -1
  1244. package/dist/services/entity-service/attributes/transforms.d.ts +0 -10
  1245. package/dist/services/entity-service/attributes/transforms.d.ts.map +0 -1
  1246. package/dist/services/entity-service/attributes/transforms.js +0 -20
  1247. package/dist/services/entity-service/attributes/transforms.js.map +0 -1
  1248. package/dist/services/entity-service/attributes/transforms.mjs.map +0 -1
  1249. package/dist/services/entity-service/components.d.ts +0 -23
  1250. package/dist/services/entity-service/components.d.ts.map +0 -1
  1251. package/dist/services/entity-service/components.js +0 -384
  1252. package/dist/services/entity-service/components.js.map +0 -1
  1253. package/dist/services/entity-service/components.mjs +0 -382
  1254. package/dist/services/entity-service/components.mjs.map +0 -1
  1255. package/dist/services/entity-service/params.d.ts +0 -8
  1256. package/dist/services/entity-service/params.d.ts.map +0 -1
  1257. package/dist/services/entity-service/params.js +0 -8
  1258. package/dist/services/entity-service/params.js.map +0 -1
  1259. package/dist/services/entity-service/params.mjs +0 -8
  1260. package/dist/services/entity-service/params.mjs.map +0 -1
  1261. package/dist/services/utils/upload-files.d.ts +0 -8
  1262. package/dist/services/utils/upload-files.d.ts.map +0 -1
  1263. package/dist/services/utils/upload-files.js +0 -64
  1264. package/dist/services/utils/upload-files.js.map +0 -1
  1265. package/dist/services/utils/upload-files.mjs +0 -63
  1266. package/dist/services/utils/upload-files.mjs.map +0 -1
  1267. package/dist/utils/addSlash.d.ts +0 -3
  1268. package/dist/utils/addSlash.d.ts.map +0 -1
  1269. package/dist/utils/ee.js +0 -4
  1270. package/dist/utils/ee.js.map +0 -1
  1271. package/dist/utils/ee.mjs +0 -5
  1272. package/dist/utils/ee.mjs.map +0 -1
  1273. package/dist/utils/get-dirs.d.ts +0 -10
  1274. package/dist/utils/get-dirs.d.ts.map +0 -1
  1275. package/dist/utils/get-dirs.js +0 -29
  1276. package/dist/utils/get-dirs.js.map +0 -1
  1277. package/dist/utils/get-dirs.mjs +0 -30
  1278. package/dist/utils/get-dirs.mjs.map +0 -1
  1279. /package/dist/{core/app-configuration → configuration}/config-loader.d.ts +0 -0
  1280. /package/dist/{core/domain → domain}/content-type/validator.d.ts +0 -0
  1281. /package/dist/{core/domain → domain}/module/validation.d.ts +0 -0
  1282. /package/dist/{core/domain → domain}/module/validation.js +0 -0
  1283. /package/dist/{core/domain → domain}/module/validation.mjs +0 -0
  1284. /package/dist/{core/loaders → loaders}/plugins/get-user-plugins-config.d.ts +0 -0
  1285. /package/dist/{core/loaders → loaders}/policies.js +0 -0
  1286. /package/dist/{core/loaders → loaders}/policies.mjs +0 -0
  1287. /package/dist/{core/loaders → loaders}/sanitizers.js +0 -0
  1288. /package/dist/{core/loaders → loaders}/sanitizers.mjs +0 -0
  1289. /package/dist/{core/loaders → loaders}/src-index.js +0 -0
  1290. /package/dist/{core/loaders → loaders}/src-index.mjs +0 -0
  1291. /package/dist/{core/loaders → loaders}/validators.js +0 -0
  1292. /package/dist/{core/loaders → loaders}/validators.mjs +0 -0
  1293. /package/dist/{core/registries → registries}/apis.mjs +0 -0
  1294. /package/dist/{core/registries → registries}/components.mjs +0 -0
  1295. /package/dist/{core/registries → registries}/custom-fields.mjs +0 -0
  1296. /package/dist/{core/registries → registries}/hooks.d.ts +0 -0
  1297. /package/dist/{core/registries → registries}/modules.mjs +0 -0
  1298. /package/dist/{core/registries → registries}/plugins.mjs +0 -0
  1299. /package/dist/{core/registries → registries}/sanitizers.d.ts +0 -0
  1300. /package/dist/{core/registries → registries}/sanitizers.js +0 -0
  1301. /package/dist/{core/registries → registries}/sanitizers.mjs +0 -0
  1302. /package/dist/{core/registries → registries}/validators.d.ts +0 -0
  1303. /package/dist/{core/registries → registries}/validators.js +0 -0
  1304. /package/dist/{core/registries → registries}/validators.mjs +0 -0
  1305. /package/dist/services/{entity-service → document-service}/attributes/transforms.mjs +0 -0
@@ -1,7 +1,6 @@
1
1
  import _ from "lodash";
2
- import strapiUtils from "@strapi/utils";
3
- import blocksValidator from "./blocks-validator.mjs";
4
- const { yup } = strapiUtils;
2
+ import { yup } from "@strapi/utils";
3
+ import { blocksValidator } from "./blocks-validator.mjs";
5
4
  const addMinLengthValidator = (validator, {
6
5
  attr
7
6
  }, { isDraft }) => {
@@ -14,82 +13,200 @@ const addMaxLengthValidator = (validator, {
14
13
  };
15
14
  const addMinIntegerValidator = (validator, {
16
15
  attr
17
- }) => _.isNumber(attr.min) ? validator.min(_.toInteger(attr.min)) : validator;
16
+ }, { isDraft }) => _.isNumber(attr.min) && !isDraft ? validator.min(_.toInteger(attr.min)) : validator;
18
17
  const addMaxIntegerValidator = (validator, {
19
18
  attr
20
19
  }) => _.isNumber(attr.max) ? validator.max(_.toInteger(attr.max)) : validator;
21
20
  const addMinFloatValidator = (validator, {
22
21
  attr
23
- }) => _.isNumber(attr.min) ? validator.min(attr.min) : validator;
22
+ }, { isDraft }) => _.isNumber(attr.min) && !isDraft ? validator.min(attr.min) : validator;
24
23
  const addMaxFloatValidator = (validator, {
25
24
  attr
26
25
  }) => _.isNumber(attr.max) ? validator.max(attr.max) : validator;
27
26
  const addStringRegexValidator = (validator, {
28
27
  attr
29
- }) => {
30
- return "regex" in attr && !_.isUndefined(attr.regex) ? validator.matches(new RegExp(attr.regex), { excludeEmptyString: !attr.required }) : validator;
28
+ }, { isDraft }) => {
29
+ return "regex" in attr && !_.isUndefined(attr.regex) && !isDraft ? validator.matches(new RegExp(attr.regex), { excludeEmptyString: !attr.required }) : validator;
31
30
  };
32
- const addUniqueValidator = (validator, { attr, model, updatedAttribute, entity }) => {
31
+ const addUniqueValidator = (validator, {
32
+ attr,
33
+ model,
34
+ updatedAttribute,
35
+ entity,
36
+ componentContext
37
+ }, options) => {
33
38
  if (attr.type !== "uid" && !attr.unique) {
34
39
  return validator;
35
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
+ };
36
129
  return validator.test("unique", "This attribute must be unique", async (value) => {
37
- if (_.isNil(updatedAttribute.value)) {
130
+ if (_.isNil(value) || value === "") {
38
131
  return true;
39
132
  }
40
- if (entity && updatedAttribute.value === entity[updatedAttribute.name]) {
133
+ if (options.isDraft) {
41
134
  return true;
42
135
  }
43
- const whereParams = entity ? { $and: [{ [updatedAttribute.name]: value }, { $not: { id: entity.id } }] } : { [updatedAttribute.name]: value };
44
- const record = await strapi.query(model.uid).findOne({
45
- select: ["id"],
46
- where: whereParams
47
- });
48
- return !record;
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"] });
49
156
  });
50
157
  };
51
158
  const stringValidator = (metas, options) => {
52
159
  let schema = yup.string().transform((val, originalVal) => originalVal);
53
160
  schema = addMinLengthValidator(schema, metas, options);
54
161
  schema = addMaxLengthValidator(schema, metas);
55
- schema = addStringRegexValidator(schema, metas);
56
- schema = addUniqueValidator(schema, metas);
162
+ schema = addStringRegexValidator(schema, metas, options);
163
+ schema = addUniqueValidator(schema, metas, options);
57
164
  return schema;
58
165
  };
59
166
  const emailValidator = (metas, options) => {
60
167
  const schema = stringValidator(metas, options);
61
- return schema.email().min(1, "${path} cannot be empty");
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
+ );
62
176
  };
63
177
  const uidValidator = (metas, options) => {
64
178
  const schema = stringValidator(metas, options);
179
+ if (options.isDraft) {
180
+ return schema;
181
+ }
65
182
  return schema.matches(/^[A-Za-z0-9-_.~]*$/);
66
183
  };
67
184
  const enumerationValidator = ({ attr }) => {
68
185
  return yup.string().oneOf((Array.isArray(attr.enum) ? attr.enum : [attr.enum]).concat(null));
69
186
  };
70
- const integerValidator = (metas) => {
187
+ const integerValidator = (metas, options) => {
71
188
  let schema = yup.number().integer();
72
- schema = addMinIntegerValidator(schema, metas);
189
+ schema = addMinIntegerValidator(schema, metas, options);
73
190
  schema = addMaxIntegerValidator(schema, metas);
74
- schema = addUniqueValidator(schema, metas);
191
+ schema = addUniqueValidator(schema, metas, options);
75
192
  return schema;
76
193
  };
77
- const floatValidator = (metas) => {
194
+ const floatValidator = (metas, options) => {
78
195
  let schema = yup.number();
79
- schema = addMinFloatValidator(schema, metas);
196
+ schema = addMinFloatValidator(schema, metas, options);
80
197
  schema = addMaxFloatValidator(schema, metas);
81
- schema = addUniqueValidator(schema, metas);
198
+ schema = addUniqueValidator(schema, metas, options);
82
199
  return schema;
83
200
  };
84
- const bigintegerValidator = (metas) => {
201
+ const bigintegerValidator = (metas, options) => {
85
202
  const schema = yup.mixed();
86
- return addUniqueValidator(schema, metas);
203
+ return addUniqueValidator(schema, metas, options);
87
204
  };
88
- const datesValidator = (metas) => {
205
+ const datesValidator = (metas, options) => {
89
206
  const schema = yup.mixed();
90
- return addUniqueValidator(schema, metas);
207
+ return addUniqueValidator(schema, metas, options);
91
208
  };
92
- const validators = {
209
+ const Validators = {
93
210
  string: stringValidator,
94
211
  text: stringValidator,
95
212
  richtext: stringValidator,
@@ -110,6 +227,13 @@ const validators = {
110
227
  blocks: blocksValidator
111
228
  };
112
229
  export {
113
- validators as default
230
+ Validators,
231
+ bigintegerValidator,
232
+ datesValidator,
233
+ emailValidator,
234
+ enumerationValidator,
235
+ floatValidator,
236
+ integerValidator,
237
+ uidValidator
114
238
  };
115
239
  //# sourceMappingURL=validators.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"validators.mjs","sources":["../../../src/services/entity-validator/validators.ts"],"sourcesContent":["import _ from 'lodash';\nimport strapiUtils from '@strapi/utils';\nimport type { Attribute, Schema } from '@strapi/types';\nimport blocksValidator from './blocks-validator';\n\nconst { yup } = strapiUtils;\n\ninterface ValidatorMetas<TAttribute extends Attribute.Any> {\n attr: TAttribute;\n model: Schema.ContentType;\n updatedAttribute: { name: string; value: unknown };\n entity: Record<string, unknown> | null;\n}\n\ninterface ValidatorOptions {\n isDraft: boolean;\n}\n\n/* Validator utils */\n\n/**\n * Adds minLength validator\n */\nconst addMinLengthValidator = (\n validator: strapiUtils.yup.StringSchema,\n {\n attr,\n }: {\n attr:\n | Attribute.String\n | Attribute.Text\n | Attribute.RichText\n | Attribute.Password\n | Attribute.Email\n | Attribute.UID;\n },\n { isDraft }: { isDraft: boolean }\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: strapiUtils.yup.StringSchema,\n {\n attr,\n }: {\n attr:\n | Attribute.String\n | Attribute.Text\n | Attribute.RichText\n | Attribute.Password\n | Attribute.Email\n | 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: strapiUtils.yup.NumberSchema,\n {\n attr,\n }: {\n attr: Attribute.Integer | Attribute.BigInteger;\n }\n) => (_.isNumber(attr.min) ? validator.min(_.toInteger(attr.min)) : validator);\n\n/**\n * Adds max integer validator\n */\nconst addMaxIntegerValidator = (\n validator: strapiUtils.yup.NumberSchema,\n {\n attr,\n }: {\n attr: Attribute.Integer | 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: strapiUtils.yup.NumberSchema,\n {\n attr,\n }: {\n attr: Attribute.Decimal | Attribute.Float;\n }\n) => (_.isNumber(attr.min) ? validator.min(attr.min) : validator);\n\n/**\n * Adds max float/decimal validator\n */\nconst addMaxFloatValidator = (\n validator: strapiUtils.yup.NumberSchema,\n {\n attr,\n }: {\n attr: Attribute.Decimal | Attribute.Float;\n }\n) => (_.isNumber(attr.max) ? validator.max(attr.max) : validator);\n\n/**\n * Adds regex validator\n */\nconst addStringRegexValidator = (\n validator: strapiUtils.yup.StringSchema,\n {\n attr,\n }: {\n attr:\n | Attribute.String\n | Attribute.Text\n | Attribute.RichText\n | Attribute.Password\n | Attribute.Email\n | Attribute.UID;\n }\n) => {\n return 'regex' in attr && !_.isUndefined(attr.regex)\n ? validator.matches(new RegExp(attr.regex), { excludeEmptyString: !attr.required })\n : validator;\n};\n\n/**\n * Adds unique validator\n */\nconst addUniqueValidator = <T extends strapiUtils.yup.AnySchema>(\n validator: T,\n { attr, model, updatedAttribute, entity }: ValidatorMetas<Attribute.Any & Attribute.UniqueOption>\n): T => {\n if (attr.type !== 'uid' && !attr.unique) {\n return validator;\n }\n\n return validator.test('unique', 'This attribute must be unique', async (value) => {\n /**\n * If the attribute value is `null` we want to skip the unique validation.\n * Otherwise it'll only accept a single `null` entry in the database.\n */\n if (_.isNil(updatedAttribute.value)) {\n return true;\n }\n\n /**\n * If the attribute is unchanged we skip the unique verification. This will\n * prevent the validator to be triggered in case the user activated the\n * unique constraint after already creating multiple entries with\n * the same attribute value for that field.\n */\n if (entity && updatedAttribute.value === entity[updatedAttribute.name]) {\n return true;\n }\n\n const whereParams = entity\n ? { $and: [{ [updatedAttribute.name]: value }, { $not: { id: entity.id } }] }\n : { [updatedAttribute.name]: value };\n\n const record = await strapi.query(model.uid).findOne({\n select: ['id'],\n where: whereParams,\n });\n\n return !record;\n });\n};\n\n/* Type validators */\n\nconst stringValidator = (\n metas: ValidatorMetas<\n | Attribute.String\n | Attribute.Text\n | Attribute.RichText\n | Attribute.Password\n | Attribute.Email\n | Attribute.UID\n >,\n options: ValidatorOptions\n) => {\n let schema = yup.string().transform((val, originalVal) => originalVal);\n\n schema = addMinLengthValidator(schema, metas, options);\n schema = addMaxLengthValidator(schema, metas);\n schema = addStringRegexValidator(schema, metas);\n schema = addUniqueValidator(schema, metas);\n\n return schema;\n};\n\nconst emailValidator = (metas: ValidatorMetas<Attribute.Email>, options: ValidatorOptions) => {\n const schema = stringValidator(metas, options);\n return schema.email().min(1, '${path} cannot be empty');\n};\n\nconst uidValidator = (metas: ValidatorMetas<Attribute.UID>, options: ValidatorOptions) => {\n const schema = stringValidator(metas, options);\n\n return schema.matches(/^[A-Za-z0-9-_.~]*$/);\n};\n\nconst enumerationValidator = ({ attr }: { attr: Attribute.Enumeration }) => {\n return yup\n .string()\n .oneOf((Array.isArray(attr.enum) ? attr.enum : [attr.enum]).concat(null as any));\n};\n\nconst integerValidator = (metas: ValidatorMetas<Attribute.Integer | Attribute.BigInteger>) => {\n let schema = yup.number().integer();\n\n schema = addMinIntegerValidator(schema, metas);\n schema = addMaxIntegerValidator(schema, metas);\n schema = addUniqueValidator(schema, metas);\n\n return schema;\n};\n\nconst floatValidator = (metas: ValidatorMetas<Attribute.Decimal | Attribute.Float>) => {\n let schema = yup.number();\n schema = addMinFloatValidator(schema, metas);\n schema = addMaxFloatValidator(schema, metas);\n schema = addUniqueValidator(schema, metas);\n\n return schema;\n};\n\nconst bigintegerValidator = (metas: ValidatorMetas<Attribute.BigInteger>) => {\n const schema = yup.mixed();\n return addUniqueValidator(schema, metas);\n};\n\nconst datesValidator = (\n metas: ValidatorMetas<Attribute.Date | Attribute.DateTime | Attribute.Time | Attribute.Timestamp>\n) => {\n const schema = yup.mixed();\n return addUniqueValidator(schema, metas);\n};\n\nexport default {\n string: stringValidator,\n text: stringValidator,\n richtext: stringValidator,\n password: stringValidator,\n email: emailValidator,\n enumeration: enumerationValidator,\n boolean: () => yup.boolean(),\n uid: uidValidator,\n json: () => yup.mixed(),\n integer: integerValidator,\n biginteger: bigintegerValidator,\n float: floatValidator,\n decimal: floatValidator,\n date: datesValidator,\n time: datesValidator,\n datetime: datesValidator,\n timestamp: datesValidator,\n blocks: blocksValidator,\n};\n"],"names":[],"mappings":"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"}
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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"}
@@ -10,6 +10,7 @@ export interface EventHub {
10
10
  destroy(): EventHub;
11
11
  removeListener(eventName: string, listener: Listener): void;
12
12
  removeAllListeners(): EventHub;
13
+ removeAllSubscribers(): EventHub;
13
14
  addListener(eventName: string, listener: Listener): () => void;
14
15
  }
15
16
  /**
@@ -1 +1 @@
1
- {"version":3,"file":"event-hub.d.ts","sourceRoot":"","sources":["../../src/services/event-hub.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,UAAU,GAAG,CAAC,SAAS,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;AAC9E,MAAM,MAAM,QAAQ,GAAG,CAAC,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;AAEzD,MAAM,WAAW,QAAQ;IACvB,IAAI,CAAC,SAAS,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAC3D,SAAS,CAAC,UAAU,EAAE,UAAU,GAAG,MAAM,IAAI,CAAC;IAC9C,WAAW,CAAC,UAAU,EAAE,UAAU,GAAG,IAAI,CAAC;IAC1C,EAAE,CAAC,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,GAAG,MAAM,IAAI,CAAC;IACtD,GAAG,CAAC,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,GAAG,IAAI,CAAC;IACjD,IAAI,CAAC,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,GAAG,MAAM,IAAI,CAAC;IACxD,OAAO,IAAI,QAAQ,CAAC;IACpB,cAAc,CAAC,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,GAAG,IAAI,CAAC;IAC5D,kBAAkB,IAAI,QAAQ,CAAC;IAC/B,WAAW,CAAC,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,GAAG,MAAM,IAAI,CAAC;CAChE;AAED;;GAEG;AACH,MAAM,CAAC,OAAO,UAAU,cAAc,IAAI,QAAQ,CAoFjD"}
1
+ {"version":3,"file":"event-hub.d.ts","sourceRoot":"","sources":["../../src/services/event-hub.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,UAAU,GAAG,CAAC,SAAS,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;AAC9E,MAAM,MAAM,QAAQ,GAAG,CAAC,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;AAEzD,MAAM,WAAW,QAAQ;IACvB,IAAI,CAAC,SAAS,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAC3D,SAAS,CAAC,UAAU,EAAE,UAAU,GAAG,MAAM,IAAI,CAAC;IAC9C,WAAW,CAAC,UAAU,EAAE,UAAU,GAAG,IAAI,CAAC;IAC1C,EAAE,CAAC,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,GAAG,MAAM,IAAI,CAAC;IACtD,GAAG,CAAC,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,GAAG,IAAI,CAAC;IACjD,IAAI,CAAC,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,GAAG,MAAM,IAAI,CAAC;IACxD,OAAO,IAAI,QAAQ,CAAC;IACpB,cAAc,CAAC,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,GAAG,IAAI,CAAC;IAC5D,kBAAkB,IAAI,QAAQ,CAAC;IAC/B,oBAAoB,IAAI,QAAQ,CAAC;IACjC,WAAW,CAAC,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,GAAG,MAAM,IAAI,CAAC;CAChE;AAED;;GAEG;AACH,MAAM,CAAC,OAAO,UAAU,cAAc,IAAI,QAAQ,CA0FjD"}
@@ -38,7 +38,7 @@ function createEventHub() {
38
38
  };
39
39
  },
40
40
  off(eventName, listener) {
41
- listeners.get(eventName).splice(listeners.get(eventName).indexOf(listener), 1);
41
+ listeners.get(eventName)?.splice(listeners.get(eventName).indexOf(listener), 1);
42
42
  },
43
43
  once(eventName, listener) {
44
44
  return eventHub.on(eventName, async (...args) => {
@@ -47,15 +47,20 @@ function createEventHub() {
47
47
  });
48
48
  },
49
49
  destroy() {
50
- listeners.clear();
51
- subscribers.length = 0;
50
+ this.removeAllListeners();
51
+ this.removeAllSubscribers();
52
52
  return this;
53
53
  },
54
54
  removeListener(eventName, listener) {
55
55
  return eventHub.off(eventName, listener);
56
56
  },
57
57
  removeAllListeners() {
58
- return eventHub.destroy();
58
+ listeners.clear();
59
+ return this;
60
+ },
61
+ removeAllSubscribers() {
62
+ subscribers.length = 0;
63
+ return this;
59
64
  },
60
65
  addListener(eventName, listener) {
61
66
  return eventHub.on(eventName, listener);
@@ -1 +1 @@
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 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 listeners.clear();\n subscribers.length = 0;\n return this;\n },\n\n removeListener(eventName, listener) {\n return eventHub.off(eventName, listener);\n },\n\n removeAllListeners() {\n return eventHub.destroy();\n },\n\n addListener(eventName, listener) {\n return eventHub.on(eventName, listener);\n },\n };\n\n return eventHub;\n}\n"],"names":[],"mappings":";AAmBA,SAAwB,iBAA2B;AAC3C,QAAA,gCAAgB;AAGhB,QAAA,oBAAoB,OAAO,cAAsB,SAAoB;AACrE,QAAA,UAAU,IAAI,SAAS,GAAG;AAC5B,iBAAW,YAAY,UAAU,IAAI,SAAS,GAAG;AACzC,cAAA,SAAS,GAAG,IAAI;AAAA,MACxB;AAAA,IACF;AAAA,EAAA;AAII,QAAA,cAAc,CAAC,iBAAiB;AAEtC,QAAM,WAAqB;AAAA,IACzB,MAAM,KAAK,cAAc,MAAM;AAC7B,iBAAW,cAAc,aAAa;AAC9B,cAAA,WAAW,WAAW,GAAG,IAAI;AAAA,MACrC;AAAA,IACF;AAAA,IAEA,UAAU,YAAY;AACpB,kBAAY,KAAK,UAAU;AAG3B,aAAO,MAAM;AACX,iBAAS,YAAY,UAAU;AAAA,MAAA;AAAA,IAEnC;AAAA,IAEA,YAAY,YAAY;AAChB,YAAA,kBAAkB,YAAY,QAAQ,UAAU;AAGtD,UAAI,mBAAmB,GAAG;AACZ,oBAAA,OAAO,iBAAiB,CAAC;AAAA,MACvC;AAAA,IACF;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,MACxC;AAGA,aAAO,MAAM;AACF,iBAAA,IAAI,WAAW,QAAQ;AAAA,MAAA;AAAA,IAEpC;AAAA,IAEA,IAAI,WAAW,UAAU;AACb,gBAAA,IAAI,SAAS,EAAE,OAAO,UAAU,IAAI,SAAS,EAAE,QAAQ,QAAQ,GAAG,CAAC;AAAA,IAC/E;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,gBAAU,MAAM;AAChB,kBAAY,SAAS;AACd,aAAA;AAAA,IACT;AAAA,IAEA,eAAe,WAAW,UAAU;AAC3B,aAAA,SAAS,IAAI,WAAW,QAAQ;AAAA,IACzC;AAAA,IAEA,qBAAqB;AACnB,aAAO,SAAS;IAClB;AAAA,IAEA,YAAY,WAAW,UAAU;AACxB,aAAA,SAAS,GAAG,WAAW,QAAQ;AAAA,IACxC;AAAA,EAAA;AAGK,SAAA;AACT;;"}
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;AAGhB,QAAA,oBAAoB,OAAO,cAAsB,SAAoB;AACrE,QAAA,UAAU,IAAI,SAAS,GAAG;AAC5B,iBAAW,YAAY,UAAU,IAAI,SAAS,GAAG;AACzC,cAAA,SAAS,GAAG,IAAI;AAAA,MACxB;AAAA,IACF;AAAA,EAAA;AAII,QAAA,cAAc,CAAC,iBAAiB;AAEtC,QAAM,WAAqB;AAAA,IACzB,MAAM,KAAK,cAAc,MAAM;AAC7B,iBAAW,cAAc,aAAa;AAC9B,cAAA,WAAW,WAAW,GAAG,IAAI;AAAA,MACrC;AAAA,IACF;AAAA,IAEA,UAAU,YAAY;AACpB,kBAAY,KAAK,UAAU;AAG3B,aAAO,MAAM;AACX,iBAAS,YAAY,UAAU;AAAA,MAAA;AAAA,IAEnC;AAAA,IAEA,YAAY,YAAY;AAChB,YAAA,kBAAkB,YAAY,QAAQ,UAAU;AAGtD,UAAI,mBAAmB,GAAG;AACZ,oBAAA,OAAO,iBAAiB,CAAC;AAAA,MACvC;AAAA,IACF;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,MACxC;AAGA,aAAO,MAAM;AACF,iBAAA,IAAI,WAAW,QAAQ;AAAA,MAAA;AAAA,IAEpC;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,IACxC;AAAA,EAAA;AAGK,SAAA;AACT;;"}
@@ -37,7 +37,7 @@ function createEventHub() {
37
37
  };
38
38
  },
39
39
  off(eventName, listener) {
40
- listeners.get(eventName).splice(listeners.get(eventName).indexOf(listener), 1);
40
+ listeners.get(eventName)?.splice(listeners.get(eventName).indexOf(listener), 1);
41
41
  },
42
42
  once(eventName, listener) {
43
43
  return eventHub.on(eventName, async (...args) => {
@@ -46,15 +46,20 @@ function createEventHub() {
46
46
  });
47
47
  },
48
48
  destroy() {
49
- listeners.clear();
50
- subscribers.length = 0;
49
+ this.removeAllListeners();
50
+ this.removeAllSubscribers();
51
51
  return this;
52
52
  },
53
53
  removeListener(eventName, listener) {
54
54
  return eventHub.off(eventName, listener);
55
55
  },
56
56
  removeAllListeners() {
57
- return eventHub.destroy();
57
+ listeners.clear();
58
+ return this;
59
+ },
60
+ removeAllSubscribers() {
61
+ subscribers.length = 0;
62
+ return this;
58
63
  },
59
64
  addListener(eventName, listener) {
60
65
  return eventHub.on(eventName, listener);
@@ -1 +1 @@
1
- {"version":3,"file":"event-hub.mjs","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 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 listeners.clear();\n subscribers.length = 0;\n return this;\n },\n\n removeListener(eventName, listener) {\n return eventHub.off(eventName, listener);\n },\n\n removeAllListeners() {\n return eventHub.destroy();\n },\n\n addListener(eventName, listener) {\n return eventHub.on(eventName, listener);\n },\n };\n\n return eventHub;\n}\n"],"names":[],"mappings":"AAmBA,SAAwB,iBAA2B;AAC3C,QAAA,gCAAgB;AAGhB,QAAA,oBAAoB,OAAO,cAAsB,SAAoB;AACrE,QAAA,UAAU,IAAI,SAAS,GAAG;AAC5B,iBAAW,YAAY,UAAU,IAAI,SAAS,GAAG;AACzC,cAAA,SAAS,GAAG,IAAI;AAAA,MACxB;AAAA,IACF;AAAA,EAAA;AAII,QAAA,cAAc,CAAC,iBAAiB;AAEtC,QAAM,WAAqB;AAAA,IACzB,MAAM,KAAK,cAAc,MAAM;AAC7B,iBAAW,cAAc,aAAa;AAC9B,cAAA,WAAW,WAAW,GAAG,IAAI;AAAA,MACrC;AAAA,IACF;AAAA,IAEA,UAAU,YAAY;AACpB,kBAAY,KAAK,UAAU;AAG3B,aAAO,MAAM;AACX,iBAAS,YAAY,UAAU;AAAA,MAAA;AAAA,IAEnC;AAAA,IAEA,YAAY,YAAY;AAChB,YAAA,kBAAkB,YAAY,QAAQ,UAAU;AAGtD,UAAI,mBAAmB,GAAG;AACZ,oBAAA,OAAO,iBAAiB,CAAC;AAAA,MACvC;AAAA,IACF;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,MACxC;AAGA,aAAO,MAAM;AACF,iBAAA,IAAI,WAAW,QAAQ;AAAA,MAAA;AAAA,IAEpC;AAAA,IAEA,IAAI,WAAW,UAAU;AACb,gBAAA,IAAI,SAAS,EAAE,OAAO,UAAU,IAAI,SAAS,EAAE,QAAQ,QAAQ,GAAG,CAAC;AAAA,IAC/E;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,gBAAU,MAAM;AAChB,kBAAY,SAAS;AACd,aAAA;AAAA,IACT;AAAA,IAEA,eAAe,WAAW,UAAU;AAC3B,aAAA,SAAS,IAAI,WAAW,QAAQ;AAAA,IACzC;AAAA,IAEA,qBAAqB;AACnB,aAAO,SAAS;IAClB;AAAA,IAEA,YAAY,WAAW,UAAU;AACxB,aAAA,SAAS,GAAG,WAAW,QAAQ;AAAA,IACxC;AAAA,EAAA;AAGK,SAAA;AACT;"}
1
+ {"version":3,"file":"event-hub.mjs","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;AAGhB,QAAA,oBAAoB,OAAO,cAAsB,SAAoB;AACrE,QAAA,UAAU,IAAI,SAAS,GAAG;AAC5B,iBAAW,YAAY,UAAU,IAAI,SAAS,GAAG;AACzC,cAAA,SAAS,GAAG,IAAI;AAAA,MACxB;AAAA,IACF;AAAA,EAAA;AAII,QAAA,cAAc,CAAC,iBAAiB;AAEtC,QAAM,WAAqB;AAAA,IACzB,MAAM,KAAK,cAAc,MAAM;AAC7B,iBAAW,cAAc,aAAa;AAC9B,cAAA,WAAW,WAAW,GAAG,IAAI;AAAA,MACrC;AAAA,IACF;AAAA,IAEA,UAAU,YAAY;AACpB,kBAAY,KAAK,UAAU;AAG3B,aAAO,MAAM;AACX,iBAAS,YAAY,UAAU;AAAA,MAAA;AAAA,IAEnC;AAAA,IAEA,YAAY,YAAY;AAChB,YAAA,kBAAkB,YAAY,QAAQ,UAAU;AAGtD,UAAI,mBAAmB,GAAG;AACZ,oBAAA,OAAO,iBAAiB,CAAC;AAAA,MACvC;AAAA,IACF;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,MACxC;AAGA,aAAO,MAAM;AACF,iBAAA,IAAI,WAAW,QAAQ;AAAA,MAAA;AAAA,IAEpC;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,IACxC;AAAA,EAAA;AAGK,SAAA;AACT;"}
@@ -0,0 +1,10 @@
1
+ /**
2
+ * The features service is responsible for managing features within strapi,
3
+ * including interacting with the feature configuration file to know
4
+ * which are enabled and disabled.
5
+ */
6
+ import type { Core, Modules } from '@strapi/types';
7
+ declare const createFeaturesService: (strapi: Core.Strapi) => Modules.Features.FeaturesService;
8
+ export { createFeaturesService };
9
+ export type FeaturesService = Modules.Features.FeaturesService;
10
+ //# sourceMappingURL=features.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"features.d.ts","sourceRoot":"","sources":["../../src/services/features.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AAInD,QAAA,MAAM,qBAAqB,WAAY,KAAK,MAAM,KAAG,QAAQ,QAAQ,gBAapE,CAAC;AAEF,OAAO,EAAE,qBAAqB,EAAE,CAAC;AACjC,MAAM,MAAM,eAAe,GAAG,OAAO,CAAC,QAAQ,CAAC,eAAe,CAAC"}
@@ -0,0 +1,17 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const createFeaturesService = (strapi) => {
4
+ const service = {
5
+ get config() {
6
+ return strapi.config.get("features");
7
+ },
8
+ future: {
9
+ isEnabled(futureFlagName) {
10
+ return service.config?.future?.[futureFlagName] === true;
11
+ }
12
+ }
13
+ };
14
+ return service;
15
+ };
16
+ exports.createFeaturesService = createFeaturesService;
17
+ //# sourceMappingURL=features.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"features.js","sources":["../../src/services/features.ts"],"sourcesContent":["/**\n * The features service is responsible for managing features within strapi,\n * including interacting with the feature configuration file to know\n * which are enabled and disabled.\n */\n\nimport type { Core, Modules } from '@strapi/types';\n\ntype FeatureName = keyof Modules.Features.FeaturesConfig['future'];\n\nconst createFeaturesService = (strapi: Core.Strapi): Modules.Features.FeaturesService => {\n const service: Modules.Features.FeaturesService = {\n get config() {\n return strapi.config.get<Modules.Features.FeaturesService['config']>('features');\n },\n future: {\n isEnabled(futureFlagName: string): boolean {\n return service.config?.future?.[futureFlagName as FeatureName] === true;\n },\n },\n };\n\n return service;\n};\n\nexport { createFeaturesService };\nexport type FeaturesService = Modules.Features.FeaturesService;\n"],"names":[],"mappings":";;AAUM,MAAA,wBAAwB,CAAC,WAA0D;AACvF,QAAM,UAA4C;AAAA,IAChD,IAAI,SAAS;AACJ,aAAA,OAAO,OAAO,IAAgD,UAAU;AAAA,IACjF;AAAA,IACA,QAAQ;AAAA,MACN,UAAU,gBAAiC;AACzC,eAAO,QAAQ,QAAQ,SAAS,cAA6B,MAAM;AAAA,MACrE;AAAA,IACF;AAAA,EAAA;AAGK,SAAA;AACT;;"}
@@ -0,0 +1,17 @@
1
+ const createFeaturesService = (strapi) => {
2
+ const service = {
3
+ get config() {
4
+ return strapi.config.get("features");
5
+ },
6
+ future: {
7
+ isEnabled(futureFlagName) {
8
+ return service.config?.future?.[futureFlagName] === true;
9
+ }
10
+ }
11
+ };
12
+ return service;
13
+ };
14
+ export {
15
+ createFeaturesService
16
+ };
17
+ //# sourceMappingURL=features.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"features.mjs","sources":["../../src/services/features.ts"],"sourcesContent":["/**\n * The features service is responsible for managing features within strapi,\n * including interacting with the feature configuration file to know\n * which are enabled and disabled.\n */\n\nimport type { Core, Modules } from '@strapi/types';\n\ntype FeatureName = keyof Modules.Features.FeaturesConfig['future'];\n\nconst createFeaturesService = (strapi: Core.Strapi): Modules.Features.FeaturesService => {\n const service: Modules.Features.FeaturesService = {\n get config() {\n return strapi.config.get<Modules.Features.FeaturesService['config']>('features');\n },\n future: {\n isEnabled(futureFlagName: string): boolean {\n return service.config?.future?.[futureFlagName as FeatureName] === true;\n },\n },\n };\n\n return service;\n};\n\nexport { createFeaturesService };\nexport type FeaturesService = Modules.Features.FeaturesService;\n"],"names":[],"mappings":"AAUM,MAAA,wBAAwB,CAAC,WAA0D;AACvF,QAAM,UAA4C;AAAA,IAChD,IAAI,SAAS;AACJ,aAAA,OAAO,OAAO,IAAgD,UAAU;AAAA,IACjF;AAAA,IACA,QAAQ;AAAA,MACN,UAAU,gBAAiC;AACzC,eAAO,QAAQ,QAAQ,SAAS,cAA6B,MAAM;AAAA,MACrE;AAAA,IACF;AAAA,EAAA;AAGK,SAAA;AACT;"}
@@ -1,4 +1,4 @@
1
- import type { Strapi } from '@strapi/types';
1
+ import type { Core } from '@strapi/types';
2
2
  interface StrapiFS {
3
3
  writeAppFile(optPath: string | string[], data: string): Promise<void>;
4
4
  writePluginFile(plugin: string, optPath: string | string[], data: string): Promise<void>;
@@ -8,6 +8,6 @@ interface StrapiFS {
8
8
  /**
9
9
  * create strapi fs layer
10
10
  */
11
- declare const _default: (strapi: Strapi) => StrapiFS;
11
+ declare const _default: (strapi: Core.Strapi) => StrapiFS;
12
12
  export default _default;
13
13
  //# sourceMappingURL=fs.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"fs.d.ts","sourceRoot":"","sources":["../../src/services/fs.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAE5C,UAAU,QAAQ;IAChB,YAAY,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,EAAE,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACtE,eAAe,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,MAAM,EAAE,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACzF,aAAa,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACzD,UAAU,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,EAAE,EAAE,IAAI,EAAE,MAAM,GAAG,IAAI,CAAC;CAC5D;AAED;;GAEG;iCACqB,MAAM;AAA9B,wBAiDE"}
1
+ {"version":3,"file":"fs.d.ts","sourceRoot":"","sources":["../../src/services/fs.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAE1C,UAAU,QAAQ;IAChB,YAAY,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,EAAE,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACtE,eAAe,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,MAAM,EAAE,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACzF,aAAa,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACzD,UAAU,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,EAAE,EAAE,IAAI,EAAE,MAAM,GAAG,IAAI,CAAC;CAC5D;AAED;;GAEG;iCACqB,KAAK,MAAM;AAAnC,wBAiDE"}
@@ -1 +1 @@
1
- {"version":3,"file":"fs.js","sources":["../../src/services/fs.ts"],"sourcesContent":["import path from 'path';\nimport fse from 'fs-extra';\n\nimport type { Strapi } from '@strapi/types';\n\ninterface StrapiFS {\n writeAppFile(optPath: string | string[], data: string): Promise<void>;\n writePluginFile(plugin: string, optPath: string | string[], data: string): Promise<void>;\n removeAppFile(optPath: string | string[]): Promise<void>;\n appendFile(optPath: string | string[], data: string): void;\n}\n\n/**\n * create strapi fs layer\n */\nexport default (strapi: Strapi) => {\n function normalizePath(optPath: string | string[]) {\n const filePath = Array.isArray(optPath) ? optPath.join('/') : optPath;\n\n const normalizedPath = path.normalize(filePath).replace(/^\\/?(\\.\\/|\\.\\.\\/)+/, '');\n\n return path.resolve(strapi.dirs.app.root, normalizedPath);\n }\n\n const strapiFS: StrapiFS = {\n /**\n * Writes a file in a strapi app\n * @param {Array|string} optPath - file path\n * @param {string} data - content\n */\n writeAppFile(optPath, data) {\n const writePath = normalizePath(optPath);\n return fse.ensureFile(writePath).then(() => fse.writeFile(writePath, data));\n },\n\n /**\n * Writes a file in a plugin extensions folder\n * @param {string} plugin - plugin name\n * @param {Array|string} optPath - path to file\n * @param {string} data - content\n */\n writePluginFile(plugin, optPath, data) {\n const newPath = ['extensions', plugin].concat(optPath).join('/');\n return strapiFS.writeAppFile(newPath, data);\n },\n\n /**\n * Removes a file in strapi app\n */\n removeAppFile(optPath) {\n const removePath = normalizePath(optPath);\n return fse.remove(removePath);\n },\n\n /**\n * Appends a file in strapi app\n */\n appendFile(optPath, data) {\n const writePath = normalizePath(optPath);\n return fse.appendFileSync(writePath, data);\n },\n };\n\n return strapiFS;\n};\n"],"names":["path","fse"],"mappings":";;;;;;AAeA,MAAe,iBAAA,CAAC,WAAmB;AACjC,WAAS,cAAc,SAA4B;AAC3C,UAAA,WAAW,MAAM,QAAQ,OAAO,IAAI,QAAQ,KAAK,GAAG,IAAI;AAE9D,UAAM,iBAAiBA,cAAK,QAAA,UAAU,QAAQ,EAAE,QAAQ,sBAAsB,EAAE;AAEhF,WAAOA,cAAAA,QAAK,QAAQ,OAAO,KAAK,IAAI,MAAM,cAAc;AAAA,EAC1D;AAEA,QAAM,WAAqB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAMzB,aAAa,SAAS,MAAM;AACpB,YAAA,YAAY,cAAc,OAAO;AAChC,aAAAC,qBAAI,WAAW,SAAS,EAAE,KAAK,MAAMA,aAAI,QAAA,UAAU,WAAW,IAAI,CAAC;AAAA,IAC5E;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAQA,gBAAgB,QAAQ,SAAS,MAAM;AAC/B,YAAA,UAAU,CAAC,cAAc,MAAM,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG;AACxD,aAAA,SAAS,aAAa,SAAS,IAAI;AAAA,IAC5C;AAAA;AAAA;AAAA;AAAA,IAKA,cAAc,SAAS;AACf,YAAA,aAAa,cAAc,OAAO;AACjC,aAAAA,aAAA,QAAI,OAAO,UAAU;AAAA,IAC9B;AAAA;AAAA;AAAA;AAAA,IAKA,WAAW,SAAS,MAAM;AAClB,YAAA,YAAY,cAAc,OAAO;AAChC,aAAAA,qBAAI,eAAe,WAAW,IAAI;AAAA,IAC3C;AAAA,EAAA;AAGK,SAAA;AACT;;"}
1
+ {"version":3,"file":"fs.js","sources":["../../src/services/fs.ts"],"sourcesContent":["import path from 'path';\nimport fse from 'fs-extra';\n\nimport type { Core } from '@strapi/types';\n\ninterface StrapiFS {\n writeAppFile(optPath: string | string[], data: string): Promise<void>;\n writePluginFile(plugin: string, optPath: string | string[], data: string): Promise<void>;\n removeAppFile(optPath: string | string[]): Promise<void>;\n appendFile(optPath: string | string[], data: string): void;\n}\n\n/**\n * create strapi fs layer\n */\nexport default (strapi: Core.Strapi) => {\n function normalizePath(optPath: string | string[]) {\n const filePath = Array.isArray(optPath) ? optPath.join('/') : optPath;\n\n const normalizedPath = path.normalize(filePath).replace(/^\\/?(\\.\\/|\\.\\.\\/)+/, '');\n\n return path.resolve(strapi.dirs.app.root, normalizedPath);\n }\n\n const strapiFS: StrapiFS = {\n /**\n * Writes a file in a strapi app\n * @param {Array|string} optPath - file path\n * @param {string} data - content\n */\n writeAppFile(optPath, data) {\n const writePath = normalizePath(optPath);\n return fse.ensureFile(writePath).then(() => fse.writeFile(writePath, data));\n },\n\n /**\n * Writes a file in a plugin extensions folder\n * @param {string} plugin - plugin name\n * @param {Array|string} optPath - path to file\n * @param {string} data - content\n */\n writePluginFile(plugin, optPath, data) {\n const newPath = ['extensions', plugin].concat(optPath).join('/');\n return strapiFS.writeAppFile(newPath, data);\n },\n\n /**\n * Removes a file in strapi app\n */\n removeAppFile(optPath) {\n const removePath = normalizePath(optPath);\n return fse.remove(removePath);\n },\n\n /**\n * Appends a file in strapi app\n */\n appendFile(optPath, data) {\n const writePath = normalizePath(optPath);\n return fse.appendFileSync(writePath, data);\n },\n };\n\n return strapiFS;\n};\n"],"names":["path","fse"],"mappings":";;;;;;AAeA,MAAe,iBAAA,CAAC,WAAwB;AACtC,WAAS,cAAc,SAA4B;AAC3C,UAAA,WAAW,MAAM,QAAQ,OAAO,IAAI,QAAQ,KAAK,GAAG,IAAI;AAE9D,UAAM,iBAAiBA,cAAK,QAAA,UAAU,QAAQ,EAAE,QAAQ,sBAAsB,EAAE;AAEhF,WAAOA,cAAAA,QAAK,QAAQ,OAAO,KAAK,IAAI,MAAM,cAAc;AAAA,EAC1D;AAEA,QAAM,WAAqB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAMzB,aAAa,SAAS,MAAM;AACpB,YAAA,YAAY,cAAc,OAAO;AAChC,aAAAC,qBAAI,WAAW,SAAS,EAAE,KAAK,MAAMA,aAAI,QAAA,UAAU,WAAW,IAAI,CAAC;AAAA,IAC5E;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAQA,gBAAgB,QAAQ,SAAS,MAAM;AAC/B,YAAA,UAAU,CAAC,cAAc,MAAM,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG;AACxD,aAAA,SAAS,aAAa,SAAS,IAAI;AAAA,IAC5C;AAAA;AAAA;AAAA;AAAA,IAKA,cAAc,SAAS;AACf,YAAA,aAAa,cAAc,OAAO;AACjC,aAAAA,aAAA,QAAI,OAAO,UAAU;AAAA,IAC9B;AAAA;AAAA;AAAA;AAAA,IAKA,WAAW,SAAS,MAAM;AAClB,YAAA,YAAY,cAAc,OAAO;AAChC,aAAAA,qBAAI,eAAe,WAAW,IAAI;AAAA,IAC3C;AAAA,EAAA;AAGK,SAAA;AACT;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"fs.mjs","sources":["../../src/services/fs.ts"],"sourcesContent":["import path from 'path';\nimport fse from 'fs-extra';\n\nimport type { Strapi } from '@strapi/types';\n\ninterface StrapiFS {\n writeAppFile(optPath: string | string[], data: string): Promise<void>;\n writePluginFile(plugin: string, optPath: string | string[], data: string): Promise<void>;\n removeAppFile(optPath: string | string[]): Promise<void>;\n appendFile(optPath: string | string[], data: string): void;\n}\n\n/**\n * create strapi fs layer\n */\nexport default (strapi: Strapi) => {\n function normalizePath(optPath: string | string[]) {\n const filePath = Array.isArray(optPath) ? optPath.join('/') : optPath;\n\n const normalizedPath = path.normalize(filePath).replace(/^\\/?(\\.\\/|\\.\\.\\/)+/, '');\n\n return path.resolve(strapi.dirs.app.root, normalizedPath);\n }\n\n const strapiFS: StrapiFS = {\n /**\n * Writes a file in a strapi app\n * @param {Array|string} optPath - file path\n * @param {string} data - content\n */\n writeAppFile(optPath, data) {\n const writePath = normalizePath(optPath);\n return fse.ensureFile(writePath).then(() => fse.writeFile(writePath, data));\n },\n\n /**\n * Writes a file in a plugin extensions folder\n * @param {string} plugin - plugin name\n * @param {Array|string} optPath - path to file\n * @param {string} data - content\n */\n writePluginFile(plugin, optPath, data) {\n const newPath = ['extensions', plugin].concat(optPath).join('/');\n return strapiFS.writeAppFile(newPath, data);\n },\n\n /**\n * Removes a file in strapi app\n */\n removeAppFile(optPath) {\n const removePath = normalizePath(optPath);\n return fse.remove(removePath);\n },\n\n /**\n * Appends a file in strapi app\n */\n appendFile(optPath, data) {\n const writePath = normalizePath(optPath);\n return fse.appendFileSync(writePath, data);\n },\n };\n\n return strapiFS;\n};\n"],"names":[],"mappings":";;AAeA,MAAe,iBAAA,CAAC,WAAmB;AACjC,WAAS,cAAc,SAA4B;AAC3C,UAAA,WAAW,MAAM,QAAQ,OAAO,IAAI,QAAQ,KAAK,GAAG,IAAI;AAE9D,UAAM,iBAAiB,KAAK,UAAU,QAAQ,EAAE,QAAQ,sBAAsB,EAAE;AAEhF,WAAO,KAAK,QAAQ,OAAO,KAAK,IAAI,MAAM,cAAc;AAAA,EAC1D;AAEA,QAAM,WAAqB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAMzB,aAAa,SAAS,MAAM;AACpB,YAAA,YAAY,cAAc,OAAO;AAChC,aAAA,IAAI,WAAW,SAAS,EAAE,KAAK,MAAM,IAAI,UAAU,WAAW,IAAI,CAAC;AAAA,IAC5E;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAQA,gBAAgB,QAAQ,SAAS,MAAM;AAC/B,YAAA,UAAU,CAAC,cAAc,MAAM,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG;AACxD,aAAA,SAAS,aAAa,SAAS,IAAI;AAAA,IAC5C;AAAA;AAAA;AAAA;AAAA,IAKA,cAAc,SAAS;AACf,YAAA,aAAa,cAAc,OAAO;AACjC,aAAA,IAAI,OAAO,UAAU;AAAA,IAC9B;AAAA;AAAA;AAAA;AAAA,IAKA,WAAW,SAAS,MAAM;AAClB,YAAA,YAAY,cAAc,OAAO;AAChC,aAAA,IAAI,eAAe,WAAW,IAAI;AAAA,IAC3C;AAAA,EAAA;AAGK,SAAA;AACT;"}
1
+ {"version":3,"file":"fs.mjs","sources":["../../src/services/fs.ts"],"sourcesContent":["import path from 'path';\nimport fse from 'fs-extra';\n\nimport type { Core } from '@strapi/types';\n\ninterface StrapiFS {\n writeAppFile(optPath: string | string[], data: string): Promise<void>;\n writePluginFile(plugin: string, optPath: string | string[], data: string): Promise<void>;\n removeAppFile(optPath: string | string[]): Promise<void>;\n appendFile(optPath: string | string[], data: string): void;\n}\n\n/**\n * create strapi fs layer\n */\nexport default (strapi: Core.Strapi) => {\n function normalizePath(optPath: string | string[]) {\n const filePath = Array.isArray(optPath) ? optPath.join('/') : optPath;\n\n const normalizedPath = path.normalize(filePath).replace(/^\\/?(\\.\\/|\\.\\.\\/)+/, '');\n\n return path.resolve(strapi.dirs.app.root, normalizedPath);\n }\n\n const strapiFS: StrapiFS = {\n /**\n * Writes a file in a strapi app\n * @param {Array|string} optPath - file path\n * @param {string} data - content\n */\n writeAppFile(optPath, data) {\n const writePath = normalizePath(optPath);\n return fse.ensureFile(writePath).then(() => fse.writeFile(writePath, data));\n },\n\n /**\n * Writes a file in a plugin extensions folder\n * @param {string} plugin - plugin name\n * @param {Array|string} optPath - path to file\n * @param {string} data - content\n */\n writePluginFile(plugin, optPath, data) {\n const newPath = ['extensions', plugin].concat(optPath).join('/');\n return strapiFS.writeAppFile(newPath, data);\n },\n\n /**\n * Removes a file in strapi app\n */\n removeAppFile(optPath) {\n const removePath = normalizePath(optPath);\n return fse.remove(removePath);\n },\n\n /**\n * Appends a file in strapi app\n */\n appendFile(optPath, data) {\n const writePath = normalizePath(optPath);\n return fse.appendFileSync(writePath, data);\n },\n };\n\n return strapiFS;\n};\n"],"names":[],"mappings":";;AAeA,MAAe,iBAAA,CAAC,WAAwB;AACtC,WAAS,cAAc,SAA4B;AAC3C,UAAA,WAAW,MAAM,QAAQ,OAAO,IAAI,QAAQ,KAAK,GAAG,IAAI;AAE9D,UAAM,iBAAiB,KAAK,UAAU,QAAQ,EAAE,QAAQ,sBAAsB,EAAE;AAEhF,WAAO,KAAK,QAAQ,OAAO,KAAK,IAAI,MAAM,cAAc;AAAA,EAC1D;AAEA,QAAM,WAAqB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAMzB,aAAa,SAAS,MAAM;AACpB,YAAA,YAAY,cAAc,OAAO;AAChC,aAAA,IAAI,WAAW,SAAS,EAAE,KAAK,MAAM,IAAI,UAAU,WAAW,IAAI,CAAC;AAAA,IAC5E;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAQA,gBAAgB,QAAQ,SAAS,MAAM;AAC/B,YAAA,UAAU,CAAC,cAAc,MAAM,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG;AACxD,aAAA,SAAS,aAAa,SAAS,IAAI;AAAA,IAC5C;AAAA;AAAA;AAAA;AAAA,IAKA,cAAc,SAAS;AACf,YAAA,aAAa,cAAc,OAAO;AACjC,aAAA,IAAI,OAAO,UAAU;AAAA,IAC9B;AAAA;AAAA;AAAA;AAAA,IAKA,WAAW,SAAS,MAAM;AAClB,YAAA,YAAY,cAAc,OAAO;AAChC,aAAA,IAAI,eAAe,WAAW,IAAI;AAAA,IAC3C;AAAA,EAAA;AAGK,SAAA;AACT;"}
@@ -1,7 +1,7 @@
1
- import type { Strapi } from '@strapi/types';
1
+ import type { Core } from '@strapi/types';
2
2
  /**
3
3
  * Generate an admin user hash
4
4
  */
5
- declare const generateAdminUserHash: (strapi: Strapi) => string;
5
+ declare const generateAdminUserHash: (strapi: Core.Strapi) => string;
6
6
  export { generateAdminUserHash };
7
7
  //# sourceMappingURL=admin-user-hash.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"admin-user-hash.d.ts","sourceRoot":"","sources":["../../../src/services/metrics/admin-user-hash.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAE5C;;GAEG;AACH,QAAA,MAAM,qBAAqB,WAAY,MAAM,WAM5C,CAAC;AAEF,OAAO,EAAE,qBAAqB,EAAE,CAAC"}
1
+ {"version":3,"file":"admin-user-hash.d.ts","sourceRoot":"","sources":["../../../src/services/metrics/admin-user-hash.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAE1C;;GAEG;AACH,QAAA,MAAM,qBAAqB,WAAY,KAAK,MAAM,WAMjD,CAAC;AAEF,OAAO,EAAE,qBAAqB,EAAE,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"admin-user-hash.js","sources":["../../../src/services/metrics/admin-user-hash.ts"],"sourcesContent":["import crypto from 'crypto';\nimport type { Strapi } from '@strapi/types';\n\n/**\n * Generate an admin user hash\n */\nconst generateAdminUserHash = (strapi: Strapi) => {\n const ctx = strapi?.requestContext?.get();\n if (!ctx?.state?.user?.email) {\n return '';\n }\n return crypto.createHash('sha256').update(ctx.state.user.email).digest('hex');\n};\n\nexport { generateAdminUserHash };\n"],"names":["crypto"],"mappings":";;;;;AAMM,MAAA,wBAAwB,CAAC,WAAmB;AAC1C,QAAA,MAAM,QAAQ,gBAAgB,IAAI;AACxC,MAAI,CAAC,KAAK,OAAO,MAAM,OAAO;AACrB,WAAA;AAAA,EACT;AACO,SAAAA,wBAAO,WAAW,QAAQ,EAAE,OAAO,IAAI,MAAM,KAAK,KAAK,EAAE,OAAO,KAAK;AAC9E;;"}
1
+ {"version":3,"file":"admin-user-hash.js","sources":["../../../src/services/metrics/admin-user-hash.ts"],"sourcesContent":["import crypto from 'crypto';\nimport type { Core } from '@strapi/types';\n\n/**\n * Generate an admin user hash\n */\nconst generateAdminUserHash = (strapi: Core.Strapi) => {\n const ctx = strapi?.requestContext?.get();\n if (!ctx?.state?.user?.email) {\n return '';\n }\n return crypto.createHash('sha256').update(ctx.state.user.email).digest('hex');\n};\n\nexport { generateAdminUserHash };\n"],"names":["crypto"],"mappings":";;;;;AAMM,MAAA,wBAAwB,CAAC,WAAwB;AAC/C,QAAA,MAAM,QAAQ,gBAAgB,IAAI;AACxC,MAAI,CAAC,KAAK,OAAO,MAAM,OAAO;AACrB,WAAA;AAAA,EACT;AACO,SAAAA,wBAAO,WAAW,QAAQ,EAAE,OAAO,IAAI,MAAM,KAAK,KAAK,EAAE,OAAO,KAAK;AAC9E;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"admin-user-hash.mjs","sources":["../../../src/services/metrics/admin-user-hash.ts"],"sourcesContent":["import crypto from 'crypto';\nimport type { Strapi } from '@strapi/types';\n\n/**\n * Generate an admin user hash\n */\nconst generateAdminUserHash = (strapi: Strapi) => {\n const ctx = strapi?.requestContext?.get();\n if (!ctx?.state?.user?.email) {\n return '';\n }\n return crypto.createHash('sha256').update(ctx.state.user.email).digest('hex');\n};\n\nexport { generateAdminUserHash };\n"],"names":[],"mappings":";AAMM,MAAA,wBAAwB,CAAC,WAAmB;AAC1C,QAAA,MAAM,QAAQ,gBAAgB,IAAI;AACxC,MAAI,CAAC,KAAK,OAAO,MAAM,OAAO;AACrB,WAAA;AAAA,EACT;AACO,SAAA,OAAO,WAAW,QAAQ,EAAE,OAAO,IAAI,MAAM,KAAK,KAAK,EAAE,OAAO,KAAK;AAC9E;"}
1
+ {"version":3,"file":"admin-user-hash.mjs","sources":["../../../src/services/metrics/admin-user-hash.ts"],"sourcesContent":["import crypto from 'crypto';\nimport type { Core } from '@strapi/types';\n\n/**\n * Generate an admin user hash\n */\nconst generateAdminUserHash = (strapi: Core.Strapi) => {\n const ctx = strapi?.requestContext?.get();\n if (!ctx?.state?.user?.email) {\n return '';\n }\n return crypto.createHash('sha256').update(ctx.state.user.email).digest('hex');\n};\n\nexport { generateAdminUserHash };\n"],"names":[],"mappings":";AAMM,MAAA,wBAAwB,CAAC,WAAwB;AAC/C,QAAA,MAAM,QAAQ,gBAAgB,IAAI;AACxC,MAAI,CAAC,KAAK,OAAO,MAAM,OAAO;AACrB,WAAA;AAAA,EACT;AACO,SAAA,OAAO,WAAW,QAAQ,EAAE,OAAO,IAAI,MAAM,KAAK,KAAK,EAAE,OAAO,KAAK;AAC9E;"}
@@ -2,8 +2,8 @@
2
2
  * Strapi telemetry package.
3
3
  * You can learn more at https://docs.strapi.io/developer-docs/latest/getting-started/usage-information.html
4
4
  */
5
- import type { Strapi } from '@strapi/types';
6
- declare const createTelemetryInstance: (strapi: Strapi) => {
5
+ import type { Core } from '@strapi/types';
6
+ declare const createTelemetryInstance: (strapi: Core.Strapi) => {
7
7
  readonly isDisabled: boolean;
8
8
  register(): void;
9
9
  bootstrap(): void;