@strapi/core 0.0.0-experimental.f9cac24ba3b2f6acb12d0fb5669106e5a134174e → 0.0.0-experimental.fa3ec797cdee7109d96b9f1616c32accf946e251

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (719) hide show
  1. package/dist/Strapi.d.ts.map +1 -1
  2. package/dist/Strapi.js +427 -403
  3. package/dist/Strapi.js.map +1 -1
  4. package/dist/Strapi.mjs +426 -402
  5. package/dist/Strapi.mjs.map +1 -1
  6. package/dist/compile.js +23 -14
  7. package/dist/compile.js.map +1 -1
  8. package/dist/compile.mjs +22 -14
  9. package/dist/compile.mjs.map +1 -1
  10. package/dist/configuration/config-loader.js +110 -97
  11. package/dist/configuration/config-loader.js.map +1 -1
  12. package/dist/configuration/config-loader.mjs +109 -96
  13. package/dist/configuration/config-loader.mjs.map +1 -1
  14. package/dist/configuration/get-dirs.js +31 -29
  15. package/dist/configuration/get-dirs.js.map +1 -1
  16. package/dist/configuration/get-dirs.mjs +30 -30
  17. package/dist/configuration/get-dirs.mjs.map +1 -1
  18. package/dist/configuration/index.d.ts +1 -0
  19. package/dist/configuration/index.d.ts.map +1 -1
  20. package/dist/configuration/index.js +85 -73
  21. package/dist/configuration/index.js.map +1 -1
  22. package/dist/configuration/index.mjs +84 -69
  23. package/dist/configuration/index.mjs.map +1 -1
  24. package/dist/configuration/urls.d.ts.map +1 -1
  25. package/dist/configuration/urls.js +74 -61
  26. package/dist/configuration/urls.js.map +1 -1
  27. package/dist/configuration/urls.mjs +73 -62
  28. package/dist/configuration/urls.mjs.map +1 -1
  29. package/dist/container.js +27 -23
  30. package/dist/container.js.map +1 -1
  31. package/dist/container.mjs +26 -24
  32. package/dist/container.mjs.map +1 -1
  33. package/dist/core-api/controller/collection-type.js +77 -76
  34. package/dist/core-api/controller/collection-type.js.map +1 -1
  35. package/dist/core-api/controller/collection-type.mjs +76 -77
  36. package/dist/core-api/controller/collection-type.mjs.map +1 -1
  37. package/dist/core-api/controller/index.js +63 -48
  38. package/dist/core-api/controller/index.js.map +1 -1
  39. package/dist/core-api/controller/index.mjs +62 -49
  40. package/dist/core-api/controller/index.mjs.map +1 -1
  41. package/dist/core-api/controller/single-type.js +41 -40
  42. package/dist/core-api/controller/single-type.js.map +1 -1
  43. package/dist/core-api/controller/single-type.mjs +40 -41
  44. package/dist/core-api/controller/single-type.mjs.map +1 -1
  45. package/dist/core-api/controller/transform.js +72 -63
  46. package/dist/core-api/controller/transform.js.map +1 -1
  47. package/dist/core-api/controller/transform.mjs +71 -64
  48. package/dist/core-api/controller/transform.mjs.map +1 -1
  49. package/dist/core-api/routes/index.js +64 -62
  50. package/dist/core-api/routes/index.js.map +1 -1
  51. package/dist/core-api/routes/index.mjs +62 -62
  52. package/dist/core-api/routes/index.mjs.map +1 -1
  53. package/dist/core-api/service/collection-type.js +73 -60
  54. package/dist/core-api/service/collection-type.js.map +1 -1
  55. package/dist/core-api/service/collection-type.mjs +72 -62
  56. package/dist/core-api/service/collection-type.mjs.map +1 -1
  57. package/dist/core-api/service/core-service.js +9 -8
  58. package/dist/core-api/service/core-service.js.map +1 -1
  59. package/dist/core-api/service/core-service.mjs +8 -9
  60. package/dist/core-api/service/core-service.mjs.map +1 -1
  61. package/dist/core-api/service/index.js +13 -13
  62. package/dist/core-api/service/index.js.map +1 -1
  63. package/dist/core-api/service/index.mjs +12 -14
  64. package/dist/core-api/service/index.mjs.map +1 -1
  65. package/dist/core-api/service/pagination.js +69 -43
  66. package/dist/core-api/service/pagination.js.map +1 -1
  67. package/dist/core-api/service/pagination.mjs +68 -47
  68. package/dist/core-api/service/pagination.mjs.map +1 -1
  69. package/dist/core-api/service/single-type.js +43 -39
  70. package/dist/core-api/service/single-type.js.map +1 -1
  71. package/dist/core-api/service/single-type.mjs +42 -41
  72. package/dist/core-api/service/single-type.mjs.map +1 -1
  73. package/dist/domain/content-type/index.js +95 -100
  74. package/dist/domain/content-type/index.js.map +1 -1
  75. package/dist/domain/content-type/index.mjs +94 -100
  76. package/dist/domain/content-type/index.mjs.map +1 -1
  77. package/dist/domain/content-type/validator.js +84 -69
  78. package/dist/domain/content-type/validator.js.map +1 -1
  79. package/dist/domain/content-type/validator.mjs +83 -68
  80. package/dist/domain/content-type/validator.mjs.map +1 -1
  81. package/dist/domain/module/index.js +109 -100
  82. package/dist/domain/module/index.js.map +1 -1
  83. package/dist/domain/module/index.mjs +108 -99
  84. package/dist/domain/module/index.mjs.map +1 -1
  85. package/dist/domain/module/validation.js +25 -20
  86. package/dist/domain/module/validation.js.map +1 -1
  87. package/dist/domain/module/validation.mjs +24 -21
  88. package/dist/domain/module/validation.mjs.map +1 -1
  89. package/dist/ee/index.d.ts +7 -0
  90. package/dist/ee/index.d.ts.map +1 -1
  91. package/dist/ee/index.js +197 -137
  92. package/dist/ee/index.js.map +1 -1
  93. package/dist/ee/index.mjs +196 -139
  94. package/dist/ee/index.mjs.map +1 -1
  95. package/dist/ee/license.d.ts +3 -1
  96. package/dist/ee/license.d.ts.map +1 -1
  97. package/dist/ee/license.js +105 -75
  98. package/dist/ee/license.js.map +1 -1
  99. package/dist/ee/license.mjs +103 -76
  100. package/dist/ee/license.mjs.map +1 -1
  101. package/dist/factories.js +72 -67
  102. package/dist/factories.js.map +1 -1
  103. package/dist/factories.mjs +71 -71
  104. package/dist/factories.mjs.map +1 -1
  105. package/dist/index.js +29 -26
  106. package/dist/index.js.map +1 -1
  107. package/dist/index.mjs +29 -29
  108. package/dist/index.mjs.map +1 -1
  109. package/dist/loaders/admin.d.ts.map +1 -1
  110. package/dist/loaders/admin.js +21 -20
  111. package/dist/loaders/admin.js.map +1 -1
  112. package/dist/loaders/admin.mjs +20 -20
  113. package/dist/loaders/admin.mjs.map +1 -1
  114. package/dist/loaders/apis.js +143 -120
  115. package/dist/loaders/apis.js.map +1 -1
  116. package/dist/loaders/apis.mjs +142 -119
  117. package/dist/loaders/apis.mjs.map +1 -1
  118. package/dist/loaders/components.js +33 -34
  119. package/dist/loaders/components.js.map +1 -1
  120. package/dist/loaders/components.mjs +32 -34
  121. package/dist/loaders/components.mjs.map +1 -1
  122. package/dist/loaders/index.js +22 -20
  123. package/dist/loaders/index.js.map +1 -1
  124. package/dist/loaders/index.mjs +21 -21
  125. package/dist/loaders/index.mjs.map +1 -1
  126. package/dist/loaders/middlewares.js +29 -25
  127. package/dist/loaders/middlewares.js.map +1 -1
  128. package/dist/loaders/middlewares.mjs +28 -25
  129. package/dist/loaders/middlewares.mjs.map +1 -1
  130. package/dist/loaders/plugins/get-enabled-plugins.js +126 -131
  131. package/dist/loaders/plugins/get-enabled-plugins.js.map +1 -1
  132. package/dist/loaders/plugins/get-enabled-plugins.mjs +125 -108
  133. package/dist/loaders/plugins/get-enabled-plugins.mjs.map +1 -1
  134. package/dist/loaders/plugins/get-user-plugins-config.js +25 -24
  135. package/dist/loaders/plugins/get-user-plugins-config.js.map +1 -1
  136. package/dist/loaders/plugins/get-user-plugins-config.mjs +24 -23
  137. package/dist/loaders/plugins/get-user-plugins-config.mjs.map +1 -1
  138. package/dist/loaders/plugins/index.js +132 -122
  139. package/dist/loaders/plugins/index.js.map +1 -1
  140. package/dist/loaders/plugins/index.mjs +121 -112
  141. package/dist/loaders/plugins/index.mjs.map +1 -1
  142. package/dist/loaders/policies.js +24 -20
  143. package/dist/loaders/policies.js.map +1 -1
  144. package/dist/loaders/policies.mjs +23 -20
  145. package/dist/loaders/policies.mjs.map +1 -1
  146. package/dist/loaders/sanitizers.js +10 -4
  147. package/dist/loaders/sanitizers.js.map +1 -1
  148. package/dist/loaders/sanitizers.mjs +9 -6
  149. package/dist/loaders/sanitizers.mjs.map +1 -1
  150. package/dist/loaders/src-index.js +35 -27
  151. package/dist/loaders/src-index.js.map +1 -1
  152. package/dist/loaders/src-index.mjs +34 -29
  153. package/dist/loaders/src-index.mjs.map +1 -1
  154. package/dist/loaders/validators.js +9 -4
  155. package/dist/loaders/validators.js.map +1 -1
  156. package/dist/loaders/validators.mjs +8 -6
  157. package/dist/loaders/validators.mjs.map +1 -1
  158. package/dist/middlewares/body.d.ts.map +1 -1
  159. package/dist/middlewares/body.js +58 -54
  160. package/dist/middlewares/body.js.map +1 -1
  161. package/dist/middlewares/body.mjs +57 -51
  162. package/dist/middlewares/body.mjs.map +1 -1
  163. package/dist/middlewares/compression.js +6 -6
  164. package/dist/middlewares/compression.js.map +1 -1
  165. package/dist/middlewares/compression.mjs +5 -5
  166. package/dist/middlewares/compression.mjs.map +1 -1
  167. package/dist/middlewares/cors.js +59 -48
  168. package/dist/middlewares/cors.js.map +1 -1
  169. package/dist/middlewares/cors.mjs +58 -47
  170. package/dist/middlewares/cors.mjs.map +1 -1
  171. package/dist/middlewares/errors.js +32 -30
  172. package/dist/middlewares/errors.js.map +1 -1
  173. package/dist/middlewares/errors.mjs +31 -31
  174. package/dist/middlewares/errors.mjs.map +1 -1
  175. package/dist/middlewares/favicon.js +27 -17
  176. package/dist/middlewares/favicon.js.map +1 -1
  177. package/dist/middlewares/favicon.mjs +26 -16
  178. package/dist/middlewares/favicon.mjs.map +1 -1
  179. package/dist/middlewares/index.js +32 -30
  180. package/dist/middlewares/index.js.map +1 -1
  181. package/dist/middlewares/index.mjs +31 -31
  182. package/dist/middlewares/index.mjs.map +1 -1
  183. package/dist/middlewares/ip.js +6 -6
  184. package/dist/middlewares/ip.js.map +1 -1
  185. package/dist/middlewares/ip.mjs +5 -5
  186. package/dist/middlewares/ip.mjs.map +1 -1
  187. package/dist/middlewares/logger.js +10 -9
  188. package/dist/middlewares/logger.js.map +1 -1
  189. package/dist/middlewares/logger.mjs +9 -10
  190. package/dist/middlewares/logger.mjs.map +1 -1
  191. package/dist/middlewares/powered-by.js +13 -9
  192. package/dist/middlewares/powered-by.js.map +1 -1
  193. package/dist/middlewares/powered-by.mjs +12 -10
  194. package/dist/middlewares/powered-by.mjs.map +1 -1
  195. package/dist/middlewares/public.js +33 -29
  196. package/dist/middlewares/public.js.map +1 -1
  197. package/dist/middlewares/public.mjs +32 -28
  198. package/dist/middlewares/public.mjs.map +1 -1
  199. package/dist/middlewares/query.js +35 -32
  200. package/dist/middlewares/query.js.map +1 -1
  201. package/dist/middlewares/query.mjs +34 -31
  202. package/dist/middlewares/query.mjs.map +1 -1
  203. package/dist/middlewares/response-time.js +10 -9
  204. package/dist/middlewares/response-time.js.map +1 -1
  205. package/dist/middlewares/response-time.mjs +9 -10
  206. package/dist/middlewares/response-time.mjs.map +1 -1
  207. package/dist/middlewares/responses.js +14 -12
  208. package/dist/middlewares/responses.js.map +1 -1
  209. package/dist/middlewares/responses.mjs +13 -13
  210. package/dist/middlewares/responses.mjs.map +1 -1
  211. package/dist/middlewares/security.js +109 -71
  212. package/dist/middlewares/security.js.map +1 -1
  213. package/dist/middlewares/security.mjs +108 -70
  214. package/dist/middlewares/security.mjs.map +1 -1
  215. package/dist/middlewares/session.js +26 -25
  216. package/dist/middlewares/session.js.map +1 -1
  217. package/dist/middlewares/session.mjs +25 -24
  218. package/dist/middlewares/session.mjs.map +1 -1
  219. package/dist/migrations/database/5.0.0-discard-drafts.d.ts +2 -2
  220. package/dist/migrations/database/5.0.0-discard-drafts.d.ts.map +1 -1
  221. package/dist/migrations/database/5.0.0-discard-drafts.js +154 -80
  222. package/dist/migrations/database/5.0.0-discard-drafts.js.map +1 -1
  223. package/dist/migrations/database/5.0.0-discard-drafts.mjs +153 -82
  224. package/dist/migrations/database/5.0.0-discard-drafts.mjs.map +1 -1
  225. package/dist/migrations/draft-publish.d.ts +1 -1
  226. package/dist/migrations/draft-publish.d.ts.map +1 -1
  227. package/dist/migrations/draft-publish.js +61 -34
  228. package/dist/migrations/draft-publish.js.map +1 -1
  229. package/dist/migrations/draft-publish.mjs +60 -36
  230. package/dist/migrations/draft-publish.mjs.map +1 -1
  231. package/dist/migrations/i18n.js +62 -45
  232. package/dist/migrations/i18n.js.map +1 -1
  233. package/dist/migrations/i18n.mjs +61 -47
  234. package/dist/migrations/i18n.mjs.map +1 -1
  235. package/dist/migrations/index.js +24 -10
  236. package/dist/migrations/index.js.map +1 -1
  237. package/dist/migrations/index.mjs +23 -12
  238. package/dist/migrations/index.mjs.map +1 -1
  239. package/dist/package.json.js +182 -0
  240. package/dist/package.json.js.map +1 -0
  241. package/dist/package.json.mjs +159 -0
  242. package/dist/package.json.mjs.map +1 -0
  243. package/dist/providers/admin.js +27 -17
  244. package/dist/providers/admin.js.map +1 -1
  245. package/dist/providers/admin.mjs +26 -19
  246. package/dist/providers/admin.mjs.map +1 -1
  247. package/dist/providers/coreStore.js +13 -8
  248. package/dist/providers/coreStore.js.map +1 -1
  249. package/dist/providers/coreStore.mjs +12 -10
  250. package/dist/providers/coreStore.mjs.map +1 -1
  251. package/dist/providers/cron.js +19 -16
  252. package/dist/providers/cron.js.map +1 -1
  253. package/dist/providers/cron.mjs +18 -18
  254. package/dist/providers/cron.mjs.map +1 -1
  255. package/dist/providers/index.js +18 -9
  256. package/dist/providers/index.js.map +1 -1
  257. package/dist/providers/index.mjs +17 -10
  258. package/dist/providers/index.mjs.map +1 -1
  259. package/dist/providers/provider.js +4 -3
  260. package/dist/providers/provider.js.map +1 -1
  261. package/dist/providers/provider.mjs +3 -4
  262. package/dist/providers/provider.mjs.map +1 -1
  263. package/dist/providers/registries.js +37 -32
  264. package/dist/providers/registries.js.map +1 -1
  265. package/dist/providers/registries.mjs +36 -34
  266. package/dist/providers/registries.mjs.map +1 -1
  267. package/dist/providers/telemetry.js +19 -16
  268. package/dist/providers/telemetry.js.map +1 -1
  269. package/dist/providers/telemetry.mjs +18 -18
  270. package/dist/providers/telemetry.mjs.map +1 -1
  271. package/dist/providers/webhooks.js +28 -26
  272. package/dist/providers/webhooks.js.map +1 -1
  273. package/dist/providers/webhooks.mjs +27 -28
  274. package/dist/providers/webhooks.mjs.map +1 -1
  275. package/dist/registries/apis.js +23 -20
  276. package/dist/registries/apis.js.map +1 -1
  277. package/dist/registries/apis.mjs +22 -22
  278. package/dist/registries/apis.mjs.map +1 -1
  279. package/dist/registries/components.js +35 -37
  280. package/dist/registries/components.js.map +1 -1
  281. package/dist/registries/components.mjs +34 -39
  282. package/dist/registries/components.mjs.map +1 -1
  283. package/dist/registries/content-types.js +54 -59
  284. package/dist/registries/content-types.js.map +1 -1
  285. package/dist/registries/content-types.mjs +53 -61
  286. package/dist/registries/content-types.mjs.map +1 -1
  287. package/dist/registries/controllers.js +70 -71
  288. package/dist/registries/controllers.js.map +1 -1
  289. package/dist/registries/controllers.mjs +69 -73
  290. package/dist/registries/controllers.mjs.map +1 -1
  291. package/dist/registries/custom-fields.js +75 -65
  292. package/dist/registries/custom-fields.js.map +1 -1
  293. package/dist/registries/custom-fields.mjs +74 -67
  294. package/dist/registries/custom-fields.mjs.map +1 -1
  295. package/dist/registries/hooks.js +46 -49
  296. package/dist/registries/hooks.js.map +1 -1
  297. package/dist/registries/hooks.mjs +45 -51
  298. package/dist/registries/hooks.mjs.map +1 -1
  299. package/dist/registries/middlewares.js +49 -51
  300. package/dist/registries/middlewares.js.map +1 -1
  301. package/dist/registries/middlewares.mjs +48 -53
  302. package/dist/registries/middlewares.mjs.map +1 -1
  303. package/dist/registries/models.js +14 -13
  304. package/dist/registries/models.js.map +1 -1
  305. package/dist/registries/models.mjs +13 -14
  306. package/dist/registries/models.mjs.map +1 -1
  307. package/dist/registries/modules.js +39 -36
  308. package/dist/registries/modules.js.map +1 -1
  309. package/dist/registries/modules.mjs +38 -38
  310. package/dist/registries/modules.mjs.map +1 -1
  311. package/dist/registries/namespace.js +21 -20
  312. package/dist/registries/namespace.js.map +1 -1
  313. package/dist/registries/namespace.mjs +20 -23
  314. package/dist/registries/namespace.mjs.map +1 -1
  315. package/dist/registries/plugins.js +23 -20
  316. package/dist/registries/plugins.js.map +1 -1
  317. package/dist/registries/plugins.mjs +22 -22
  318. package/dist/registries/plugins.mjs.map +1 -1
  319. package/dist/registries/policies.js +103 -96
  320. package/dist/registries/policies.js.map +1 -1
  321. package/dist/registries/policies.mjs +102 -98
  322. package/dist/registries/policies.mjs.map +1 -1
  323. package/dist/registries/sanitizers.js +23 -22
  324. package/dist/registries/sanitizers.js.map +1 -1
  325. package/dist/registries/sanitizers.mjs +22 -22
  326. package/dist/registries/sanitizers.mjs.map +1 -1
  327. package/dist/registries/services.js +71 -71
  328. package/dist/registries/services.js.map +1 -1
  329. package/dist/registries/services.mjs +70 -73
  330. package/dist/registries/services.mjs.map +1 -1
  331. package/dist/registries/validators.js +23 -22
  332. package/dist/registries/validators.js.map +1 -1
  333. package/dist/registries/validators.mjs +22 -22
  334. package/dist/registries/validators.mjs.map +1 -1
  335. package/dist/services/auth/index.js +74 -74
  336. package/dist/services/auth/index.js.map +1 -1
  337. package/dist/services/auth/index.mjs +73 -74
  338. package/dist/services/auth/index.mjs.map +1 -1
  339. package/dist/services/config.js +47 -43
  340. package/dist/services/config.js.map +1 -1
  341. package/dist/services/config.mjs +46 -44
  342. package/dist/services/config.mjs.map +1 -1
  343. package/dist/services/content-api/index.js +80 -79
  344. package/dist/services/content-api/index.js.map +1 -1
  345. package/dist/services/content-api/index.mjs +79 -79
  346. package/dist/services/content-api/index.mjs.map +1 -1
  347. package/dist/services/content-api/permissions/engine.js +8 -5
  348. package/dist/services/content-api/permissions/engine.js.map +1 -1
  349. package/dist/services/content-api/permissions/engine.mjs +7 -5
  350. package/dist/services/content-api/permissions/engine.mjs.map +1 -1
  351. package/dist/services/content-api/permissions/index.js +101 -81
  352. package/dist/services/content-api/permissions/index.js.map +1 -1
  353. package/dist/services/content-api/permissions/index.mjs +100 -81
  354. package/dist/services/content-api/permissions/index.mjs.map +1 -1
  355. package/dist/services/content-api/permissions/providers/action.js +17 -14
  356. package/dist/services/content-api/permissions/providers/action.js.map +1 -1
  357. package/dist/services/content-api/permissions/providers/action.mjs +16 -16
  358. package/dist/services/content-api/permissions/providers/action.mjs.map +1 -1
  359. package/dist/services/content-api/permissions/providers/condition.js +17 -14
  360. package/dist/services/content-api/permissions/providers/condition.js.map +1 -1
  361. package/dist/services/content-api/permissions/providers/condition.mjs +16 -16
  362. package/dist/services/content-api/permissions/providers/condition.mjs.map +1 -1
  363. package/dist/services/core-store.d.ts +2 -2
  364. package/dist/services/core-store.d.ts.map +1 -1
  365. package/dist/services/core-store.js +115 -95
  366. package/dist/services/core-store.js.map +1 -1
  367. package/dist/services/core-store.mjs +114 -97
  368. package/dist/services/core-store.mjs.map +1 -1
  369. package/dist/services/cron.js +74 -60
  370. package/dist/services/cron.js.map +1 -1
  371. package/dist/services/cron.mjs +73 -62
  372. package/dist/services/cron.mjs.map +1 -1
  373. package/dist/services/custom-fields.js +9 -7
  374. package/dist/services/custom-fields.js.map +1 -1
  375. package/dist/services/custom-fields.mjs +8 -9
  376. package/dist/services/custom-fields.mjs.map +1 -1
  377. package/dist/services/document-service/attributes/index.js +23 -18
  378. package/dist/services/document-service/attributes/index.js.map +1 -1
  379. package/dist/services/document-service/attributes/index.mjs +22 -19
  380. package/dist/services/document-service/attributes/index.mjs.map +1 -1
  381. package/dist/services/document-service/attributes/transforms.js +16 -15
  382. package/dist/services/document-service/attributes/transforms.js.map +1 -1
  383. package/dist/services/document-service/attributes/transforms.mjs +15 -15
  384. package/dist/services/document-service/attributes/transforms.mjs.map +1 -1
  385. package/dist/services/document-service/common.d.ts +1 -1
  386. package/dist/services/document-service/common.d.ts.map +1 -1
  387. package/dist/services/document-service/common.js +5 -4
  388. package/dist/services/document-service/common.js.map +1 -1
  389. package/dist/services/document-service/common.mjs +4 -5
  390. package/dist/services/document-service/common.mjs.map +1 -1
  391. package/dist/services/document-service/components.d.ts.map +1 -1
  392. package/dist/services/document-service/components.js +255 -257
  393. package/dist/services/document-service/components.js.map +1 -1
  394. package/dist/services/document-service/components.mjs +254 -262
  395. package/dist/services/document-service/components.mjs.map +1 -1
  396. package/dist/services/document-service/draft-and-publish.d.ts +1 -1
  397. package/dist/services/document-service/draft-and-publish.d.ts.map +1 -1
  398. package/dist/services/document-service/draft-and-publish.js +88 -48
  399. package/dist/services/document-service/draft-and-publish.js.map +1 -1
  400. package/dist/services/document-service/draft-and-publish.mjs +87 -54
  401. package/dist/services/document-service/draft-and-publish.mjs.map +1 -1
  402. package/dist/services/document-service/entries.d.ts +2 -2
  403. package/dist/services/document-service/entries.d.ts.map +1 -1
  404. package/dist/services/document-service/entries.js +151 -92
  405. package/dist/services/document-service/entries.js.map +1 -1
  406. package/dist/services/document-service/entries.mjs +150 -93
  407. package/dist/services/document-service/entries.mjs.map +1 -1
  408. package/dist/services/document-service/events.d.ts +1 -1
  409. package/dist/services/document-service/events.d.ts.map +1 -1
  410. package/dist/services/document-service/events.js +52 -40
  411. package/dist/services/document-service/events.js.map +1 -1
  412. package/dist/services/document-service/events.mjs +51 -41
  413. package/dist/services/document-service/events.mjs.map +1 -1
  414. package/dist/services/document-service/index.d.ts +2 -1
  415. package/dist/services/document-service/index.d.ts.map +1 -1
  416. package/dist/services/document-service/index.js +53 -32
  417. package/dist/services/document-service/index.js.map +1 -1
  418. package/dist/services/document-service/index.mjs +52 -33
  419. package/dist/services/document-service/index.mjs.map +1 -1
  420. package/dist/services/document-service/internationalization.js +62 -46
  421. package/dist/services/document-service/internationalization.js.map +1 -1
  422. package/dist/services/document-service/internationalization.mjs +61 -50
  423. package/dist/services/document-service/internationalization.mjs.map +1 -1
  424. package/dist/services/document-service/middlewares/errors.js +23 -19
  425. package/dist/services/document-service/middlewares/errors.js.map +1 -1
  426. package/dist/services/document-service/middlewares/errors.mjs +22 -20
  427. package/dist/services/document-service/middlewares/errors.mjs.map +1 -1
  428. package/dist/services/document-service/middlewares/middleware-manager.js +46 -44
  429. package/dist/services/document-service/middlewares/middleware-manager.js.map +1 -1
  430. package/dist/services/document-service/middlewares/middleware-manager.mjs +45 -45
  431. package/dist/services/document-service/middlewares/middleware-manager.mjs.map +1 -1
  432. package/dist/services/document-service/params.js +11 -5
  433. package/dist/services/document-service/params.js.map +1 -1
  434. package/dist/services/document-service/params.mjs +10 -6
  435. package/dist/services/document-service/params.mjs.map +1 -1
  436. package/dist/services/document-service/repository.d.ts.map +1 -1
  437. package/dist/services/document-service/repository.js +354 -304
  438. package/dist/services/document-service/repository.js.map +1 -1
  439. package/dist/services/document-service/repository.mjs +353 -305
  440. package/dist/services/document-service/repository.mjs.map +1 -1
  441. package/dist/services/document-service/transform/data.js +22 -12
  442. package/dist/services/document-service/transform/data.js.map +1 -1
  443. package/dist/services/document-service/transform/data.mjs +21 -13
  444. package/dist/services/document-service/transform/data.mjs.map +1 -1
  445. package/dist/services/document-service/transform/fields.js +26 -17
  446. package/dist/services/document-service/transform/fields.js.map +1 -1
  447. package/dist/services/document-service/transform/fields.mjs +25 -18
  448. package/dist/services/document-service/transform/fields.mjs.map +1 -1
  449. package/dist/services/document-service/transform/id-map.d.ts +1 -1
  450. package/dist/services/document-service/transform/id-map.d.ts.map +1 -1
  451. package/dist/services/document-service/transform/id-map.js +116 -69
  452. package/dist/services/document-service/transform/id-map.js.map +1 -1
  453. package/dist/services/document-service/transform/id-map.mjs +115 -70
  454. package/dist/services/document-service/transform/id-map.mjs.map +1 -1
  455. package/dist/services/document-service/transform/id-transform.d.ts +1 -1
  456. package/dist/services/document-service/transform/id-transform.d.ts.map +1 -1
  457. package/dist/services/document-service/transform/id-transform.js +37 -29
  458. package/dist/services/document-service/transform/id-transform.js.map +1 -1
  459. package/dist/services/document-service/transform/id-transform.mjs +36 -30
  460. package/dist/services/document-service/transform/id-transform.mjs.map +1 -1
  461. package/dist/services/document-service/transform/populate.js +23 -18
  462. package/dist/services/document-service/transform/populate.js.map +1 -1
  463. package/dist/services/document-service/transform/populate.mjs +22 -19
  464. package/dist/services/document-service/transform/populate.mjs.map +1 -1
  465. package/dist/services/document-service/transform/query.js +11 -6
  466. package/dist/services/document-service/transform/query.js.map +1 -1
  467. package/dist/services/document-service/transform/query.mjs +10 -7
  468. package/dist/services/document-service/transform/query.mjs.map +1 -1
  469. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts +1 -1
  470. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts.map +1 -1
  471. package/dist/services/document-service/transform/relations/extract/data-ids.js +71 -48
  472. package/dist/services/document-service/transform/relations/extract/data-ids.js.map +1 -1
  473. package/dist/services/document-service/transform/relations/extract/data-ids.mjs +70 -49
  474. package/dist/services/document-service/transform/relations/extract/data-ids.mjs.map +1 -1
  475. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts.map +1 -1
  476. package/dist/services/document-service/transform/relations/transform/data-ids.js +97 -63
  477. package/dist/services/document-service/transform/relations/transform/data-ids.js.map +1 -1
  478. package/dist/services/document-service/transform/relations/transform/data-ids.mjs +96 -64
  479. package/dist/services/document-service/transform/relations/transform/data-ids.mjs.map +1 -1
  480. package/dist/services/document-service/transform/relations/transform/default-locale.js +47 -29
  481. package/dist/services/document-service/transform/relations/transform/default-locale.js.map +1 -1
  482. package/dist/services/document-service/transform/relations/transform/default-locale.mjs +46 -30
  483. package/dist/services/document-service/transform/relations/transform/default-locale.mjs.map +1 -1
  484. package/dist/services/document-service/transform/relations/utils/dp.d.ts +1 -1
  485. package/dist/services/document-service/transform/relations/utils/dp.d.ts.map +1 -1
  486. package/dist/services/document-service/transform/relations/utils/dp.js +52 -26
  487. package/dist/services/document-service/transform/relations/utils/dp.js.map +1 -1
  488. package/dist/services/document-service/transform/relations/utils/dp.mjs +51 -27
  489. package/dist/services/document-service/transform/relations/utils/dp.mjs.map +1 -1
  490. package/dist/services/document-service/transform/relations/utils/i18n.d.ts +1 -1
  491. package/dist/services/document-service/transform/relations/utils/i18n.d.ts.map +1 -1
  492. package/dist/services/document-service/transform/relations/utils/i18n.js +20 -18
  493. package/dist/services/document-service/transform/relations/utils/i18n.js.map +1 -1
  494. package/dist/services/document-service/transform/relations/utils/i18n.mjs +19 -21
  495. package/dist/services/document-service/transform/relations/utils/i18n.mjs.map +1 -1
  496. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts.map +1 -1
  497. package/dist/services/document-service/transform/relations/utils/map-relation.js +116 -77
  498. package/dist/services/document-service/transform/relations/utils/map-relation.js.map +1 -1
  499. package/dist/services/document-service/transform/relations/utils/map-relation.mjs +115 -79
  500. package/dist/services/document-service/transform/relations/utils/map-relation.mjs.map +1 -1
  501. package/dist/services/document-service/utils/bidirectional-relations.d.ts +95 -0
  502. package/dist/services/document-service/utils/bidirectional-relations.d.ts.map +1 -0
  503. package/dist/services/document-service/utils/bidirectional-relations.js +148 -0
  504. package/dist/services/document-service/utils/bidirectional-relations.js.map +1 -0
  505. package/dist/services/document-service/utils/bidirectional-relations.mjs +145 -0
  506. package/dist/services/document-service/utils/bidirectional-relations.mjs.map +1 -0
  507. package/dist/services/document-service/utils/populate.d.ts +1 -1
  508. package/dist/services/document-service/utils/populate.d.ts.map +1 -1
  509. package/dist/services/document-service/utils/populate.js +66 -42
  510. package/dist/services/document-service/utils/populate.js.map +1 -1
  511. package/dist/services/document-service/utils/populate.mjs +65 -43
  512. package/dist/services/document-service/utils/populate.mjs.map +1 -1
  513. package/dist/services/document-service/utils/unidirectional-relations.d.ts +12 -9
  514. package/dist/services/document-service/utils/unidirectional-relations.d.ts.map +1 -1
  515. package/dist/services/document-service/utils/unidirectional-relations.js +110 -51
  516. package/dist/services/document-service/utils/unidirectional-relations.js.map +1 -1
  517. package/dist/services/document-service/utils/unidirectional-relations.mjs +109 -53
  518. package/dist/services/document-service/utils/unidirectional-relations.mjs.map +1 -1
  519. package/dist/services/entity-service/index.js +230 -161
  520. package/dist/services/entity-service/index.js.map +1 -1
  521. package/dist/services/entity-service/index.mjs +229 -160
  522. package/dist/services/entity-service/index.mjs.map +1 -1
  523. package/dist/services/entity-validator/blocks-validator.js +135 -103
  524. package/dist/services/entity-validator/blocks-validator.js.map +1 -1
  525. package/dist/services/entity-validator/blocks-validator.mjs +134 -104
  526. package/dist/services/entity-validator/blocks-validator.mjs.map +1 -1
  527. package/dist/services/entity-validator/index.d.ts +1 -1
  528. package/dist/services/entity-validator/index.d.ts.map +1 -1
  529. package/dist/services/entity-validator/index.js +362 -367
  530. package/dist/services/entity-validator/index.js.map +1 -1
  531. package/dist/services/entity-validator/index.mjs +358 -364
  532. package/dist/services/entity-validator/index.mjs.map +1 -1
  533. package/dist/services/entity-validator/validators.js +268 -210
  534. package/dist/services/entity-validator/validators.js.map +1 -1
  535. package/dist/services/entity-validator/validators.mjs +267 -216
  536. package/dist/services/entity-validator/validators.mjs.map +1 -1
  537. package/dist/services/errors.js +65 -65
  538. package/dist/services/errors.js.map +1 -1
  539. package/dist/services/errors.mjs +64 -66
  540. package/dist/services/errors.mjs.map +1 -1
  541. package/dist/services/event-hub.js +82 -69
  542. package/dist/services/event-hub.js.map +1 -1
  543. package/dist/services/event-hub.mjs +81 -71
  544. package/dist/services/event-hub.mjs.map +1 -1
  545. package/dist/services/features.js +19 -14
  546. package/dist/services/features.js.map +1 -1
  547. package/dist/services/features.mjs +18 -15
  548. package/dist/services/features.mjs.map +1 -1
  549. package/dist/services/fs.js +41 -40
  550. package/dist/services/fs.js.map +1 -1
  551. package/dist/services/fs.mjs +40 -39
  552. package/dist/services/fs.mjs.map +1 -1
  553. package/dist/services/metrics/admin-user-hash.d.ts.map +1 -1
  554. package/dist/services/metrics/admin-user-hash.js +13 -11
  555. package/dist/services/metrics/admin-user-hash.js.map +1 -1
  556. package/dist/services/metrics/admin-user-hash.mjs +12 -10
  557. package/dist/services/metrics/admin-user-hash.mjs.map +1 -1
  558. package/dist/services/metrics/index.js +46 -40
  559. package/dist/services/metrics/index.js.map +1 -1
  560. package/dist/services/metrics/index.mjs +45 -42
  561. package/dist/services/metrics/index.mjs.map +1 -1
  562. package/dist/services/metrics/is-truthy.js +13 -6
  563. package/dist/services/metrics/is-truthy.js.map +1 -1
  564. package/dist/services/metrics/is-truthy.mjs +12 -6
  565. package/dist/services/metrics/is-truthy.mjs.map +1 -1
  566. package/dist/services/metrics/middleware.d.ts.map +1 -1
  567. package/dist/services/metrics/middleware.js +37 -22
  568. package/dist/services/metrics/middleware.js.map +1 -1
  569. package/dist/services/metrics/middleware.mjs +36 -24
  570. package/dist/services/metrics/middleware.mjs.map +1 -1
  571. package/dist/services/metrics/rate-limiter.d.ts.map +1 -1
  572. package/dist/services/metrics/rate-limiter.js +24 -19
  573. package/dist/services/metrics/rate-limiter.js.map +1 -1
  574. package/dist/services/metrics/rate-limiter.mjs +23 -21
  575. package/dist/services/metrics/rate-limiter.mjs.map +1 -1
  576. package/dist/services/metrics/sender.d.ts.map +1 -1
  577. package/dist/services/metrics/sender.js +78 -69
  578. package/dist/services/metrics/sender.js.map +1 -1
  579. package/dist/services/metrics/sender.mjs +77 -64
  580. package/dist/services/metrics/sender.mjs.map +1 -1
  581. package/dist/services/query-params.js +13 -10
  582. package/dist/services/query-params.js.map +1 -1
  583. package/dist/services/query-params.mjs +12 -12
  584. package/dist/services/query-params.mjs.map +1 -1
  585. package/dist/services/reloader.js +35 -32
  586. package/dist/services/reloader.js.map +1 -1
  587. package/dist/services/reloader.mjs +34 -33
  588. package/dist/services/reloader.mjs.map +1 -1
  589. package/dist/services/request-context.js +11 -8
  590. package/dist/services/request-context.js.map +1 -1
  591. package/dist/services/request-context.mjs +10 -10
  592. package/dist/services/request-context.mjs.map +1 -1
  593. package/dist/services/server/admin-api.js +11 -10
  594. package/dist/services/server/admin-api.js.map +1 -1
  595. package/dist/services/server/admin-api.mjs +10 -11
  596. package/dist/services/server/admin-api.mjs.map +1 -1
  597. package/dist/services/server/api.js +33 -27
  598. package/dist/services/server/api.js.map +1 -1
  599. package/dist/services/server/api.mjs +32 -26
  600. package/dist/services/server/api.mjs.map +1 -1
  601. package/dist/services/server/compose-endpoint.js +116 -105
  602. package/dist/services/server/compose-endpoint.js.map +1 -1
  603. package/dist/services/server/compose-endpoint.mjs +115 -105
  604. package/dist/services/server/compose-endpoint.mjs.map +1 -1
  605. package/dist/services/server/content-api.js +11 -9
  606. package/dist/services/server/content-api.js.map +1 -1
  607. package/dist/services/server/content-api.mjs +10 -10
  608. package/dist/services/server/content-api.mjs.map +1 -1
  609. package/dist/services/server/http-server.js +48 -44
  610. package/dist/services/server/http-server.js.map +1 -1
  611. package/dist/services/server/http-server.mjs +47 -43
  612. package/dist/services/server/http-server.mjs.map +1 -1
  613. package/dist/services/server/index.js +85 -82
  614. package/dist/services/server/index.js.map +1 -1
  615. package/dist/services/server/index.mjs +84 -81
  616. package/dist/services/server/index.mjs.map +1 -1
  617. package/dist/services/server/koa.js +49 -47
  618. package/dist/services/server/koa.js.map +1 -1
  619. package/dist/services/server/koa.mjs +48 -44
  620. package/dist/services/server/koa.mjs.map +1 -1
  621. package/dist/services/server/middleware.js +86 -82
  622. package/dist/services/server/middleware.js.map +1 -1
  623. package/dist/services/server/middleware.mjs +85 -82
  624. package/dist/services/server/middleware.mjs.map +1 -1
  625. package/dist/services/server/policy.js +24 -17
  626. package/dist/services/server/policy.js.map +1 -1
  627. package/dist/services/server/policy.mjs +23 -18
  628. package/dist/services/server/policy.mjs.map +1 -1
  629. package/dist/services/server/register-middlewares.js +68 -61
  630. package/dist/services/server/register-middlewares.js.map +1 -1
  631. package/dist/services/server/register-middlewares.mjs +67 -63
  632. package/dist/services/server/register-middlewares.mjs.map +1 -1
  633. package/dist/services/server/register-routes.js +90 -67
  634. package/dist/services/server/register-routes.js.map +1 -1
  635. package/dist/services/server/register-routes.mjs +89 -67
  636. package/dist/services/server/register-routes.mjs.map +1 -1
  637. package/dist/services/server/routing.js +94 -81
  638. package/dist/services/server/routing.js.map +1 -1
  639. package/dist/services/server/routing.mjs +93 -81
  640. package/dist/services/server/routing.mjs.map +1 -1
  641. package/dist/services/utils/dynamic-zones.js +13 -14
  642. package/dist/services/utils/dynamic-zones.js.map +1 -1
  643. package/dist/services/utils/dynamic-zones.mjs +12 -16
  644. package/dist/services/utils/dynamic-zones.mjs.map +1 -1
  645. package/dist/services/webhook-runner.js +124 -122
  646. package/dist/services/webhook-runner.js.map +1 -1
  647. package/dist/services/webhook-runner.mjs +123 -121
  648. package/dist/services/webhook-runner.mjs.map +1 -1
  649. package/dist/services/webhook-store.js +132 -99
  650. package/dist/services/webhook-store.js.map +1 -1
  651. package/dist/services/webhook-store.mjs +131 -101
  652. package/dist/services/webhook-store.mjs.map +1 -1
  653. package/dist/services/worker-queue.js +44 -49
  654. package/dist/services/worker-queue.js.map +1 -1
  655. package/dist/services/worker-queue.mjs +43 -49
  656. package/dist/services/worker-queue.mjs.map +1 -1
  657. package/dist/utils/convert-custom-field-type.js +17 -20
  658. package/dist/utils/convert-custom-field-type.js.map +1 -1
  659. package/dist/utils/convert-custom-field-type.mjs +16 -21
  660. package/dist/utils/convert-custom-field-type.mjs.map +1 -1
  661. package/dist/utils/cron.js +64 -30
  662. package/dist/utils/cron.js.map +1 -1
  663. package/dist/utils/cron.mjs +63 -31
  664. package/dist/utils/cron.mjs.map +1 -1
  665. package/dist/utils/fetch.d.ts +5 -1
  666. package/dist/utils/fetch.d.ts.map +1 -1
  667. package/dist/utils/fetch.js +28 -18
  668. package/dist/utils/fetch.js.map +1 -1
  669. package/dist/utils/fetch.mjs +27 -19
  670. package/dist/utils/fetch.mjs.map +1 -1
  671. package/dist/utils/filepath-to-prop-path.js +20 -28
  672. package/dist/utils/filepath-to-prop-path.js.map +1 -1
  673. package/dist/utils/filepath-to-prop-path.mjs +19 -26
  674. package/dist/utils/filepath-to-prop-path.mjs.map +1 -1
  675. package/dist/utils/is-initialized.js +21 -12
  676. package/dist/utils/is-initialized.js.map +1 -1
  677. package/dist/utils/is-initialized.mjs +20 -13
  678. package/dist/utils/is-initialized.mjs.map +1 -1
  679. package/dist/utils/lifecycles.js +6 -5
  680. package/dist/utils/lifecycles.js.map +1 -1
  681. package/dist/utils/lifecycles.mjs +5 -6
  682. package/dist/utils/lifecycles.mjs.map +1 -1
  683. package/dist/utils/load-config-file.js +40 -38
  684. package/dist/utils/load-config-file.js.map +1 -1
  685. package/dist/utils/load-config-file.mjs +39 -36
  686. package/dist/utils/load-config-file.mjs.map +1 -1
  687. package/dist/utils/load-files.js +40 -35
  688. package/dist/utils/load-files.js.map +1 -1
  689. package/dist/utils/load-files.mjs +39 -32
  690. package/dist/utils/load-files.mjs.map +1 -1
  691. package/dist/utils/open-browser.js +8 -8
  692. package/dist/utils/open-browser.js.map +1 -1
  693. package/dist/utils/open-browser.mjs +7 -7
  694. package/dist/utils/open-browser.mjs.map +1 -1
  695. package/dist/utils/resolve-working-dirs.js +23 -10
  696. package/dist/utils/resolve-working-dirs.js.map +1 -1
  697. package/dist/utils/resolve-working-dirs.mjs +22 -9
  698. package/dist/utils/resolve-working-dirs.mjs.map +1 -1
  699. package/dist/utils/signals.js +20 -14
  700. package/dist/utils/signals.js.map +1 -1
  701. package/dist/utils/signals.mjs +19 -15
  702. package/dist/utils/signals.mjs.map +1 -1
  703. package/dist/utils/startup-logger.d.ts.map +1 -1
  704. package/dist/utils/startup-logger.js +107 -78
  705. package/dist/utils/startup-logger.js.map +1 -1
  706. package/dist/utils/startup-logger.mjs +106 -75
  707. package/dist/utils/startup-logger.mjs.map +1 -1
  708. package/dist/utils/transform-content-types-to-models.d.ts +353 -21
  709. package/dist/utils/transform-content-types-to-models.d.ts.map +1 -1
  710. package/dist/utils/transform-content-types-to-models.js +350 -261
  711. package/dist/utils/transform-content-types-to-models.js.map +1 -1
  712. package/dist/utils/transform-content-types-to-models.mjs +349 -269
  713. package/dist/utils/transform-content-types-to-models.mjs.map +1 -1
  714. package/dist/utils/update-notifier/index.d.ts.map +1 -1
  715. package/dist/utils/update-notifier/index.js +68 -73
  716. package/dist/utils/update-notifier/index.js.map +1 -1
  717. package/dist/utils/update-notifier/index.mjs +67 -67
  718. package/dist/utils/update-notifier/index.mjs.map +1 -1
  719. package/package.json +26 -27
@@ -1 +1 @@
1
- {"version":3,"file":"content-types.js","sources":["../../src/registries/content-types.ts"],"sourcesContent":["import { pickBy, has } from 'lodash/fp';\nimport type { UID, Struct } from '@strapi/types';\nimport { createContentType, ContentTypeDefinition } from '../domain/content-type';\nimport { addNamespace, hasNamespace } from './namespace';\n\ntype ContentTypesInput = Record<string, ContentTypeDefinition>;\ntype ContentTypeExtendFn = (contentType: Struct.ContentTypeSchema) => Struct.ContentTypeSchema;\n\nconst validateKeySameToSingularName = (contentTypes: ContentTypesInput) => {\n for (const ctName of Object.keys(contentTypes)) {\n const contentType = contentTypes[ctName];\n\n if (ctName !== contentType.schema.info.singularName) {\n throw new Error(\n `The key of the content-type should be the same as its singularName. Found ${ctName} and ${contentType.schema.info.singularName}.`\n );\n }\n }\n};\n\nconst contentTypesRegistry = () => {\n const contentTypes: Record<string, Struct.ContentTypeSchema> = {};\n\n return {\n /**\n * Returns this list of registered contentTypes uids\n */\n keys() {\n return Object.keys(contentTypes);\n },\n\n /**\n * Returns the instance of a contentType. Instantiate the contentType if not already done\n */\n get(uid: UID.ContentType) {\n return contentTypes[uid];\n },\n\n /**\n * Returns a map with all the contentTypes in a namespace\n */\n getAll(namespace: string) {\n return pickBy((_, uid) => hasNamespace(uid, namespace))(contentTypes);\n },\n\n /**\n * Registers a contentType\n */\n set(uid: UID.ContentType, contentType: Struct.ContentTypeSchema) {\n contentTypes[uid] = contentType;\n return this;\n },\n\n /**\n * Registers a map of contentTypes for a specific namespace\n */\n add(namespace: string, newContentTypes: ContentTypesInput) {\n validateKeySameToSingularName(newContentTypes);\n\n for (const rawCtName of Object.keys(newContentTypes)) {\n const uid = addNamespace(rawCtName, namespace);\n\n if (has(uid, contentTypes)) {\n throw new Error(`Content-type ${uid} has already been registered.`);\n }\n\n contentTypes[uid] = createContentType(uid, newContentTypes[rawCtName]);\n }\n },\n\n /**\n * Wraps a contentType to extend it\n */\n extend(ctUID: UID.ContentType, extendFn: ContentTypeExtendFn) {\n const currentContentType = this.get(ctUID);\n\n if (!currentContentType) {\n throw new Error(`Content-Type ${ctUID} doesn't exist`);\n }\n\n extendFn(currentContentType);\n\n return this;\n },\n };\n};\n\nexport default contentTypesRegistry;\n"],"names":["namespace","pickBy","hasNamespace","addNamespace","has","createContentType"],"mappings":";;;;AAQA,MAAM,gCAAgC,CAAC,iBAAoC;AACzE,aAAW,UAAU,OAAO,KAAK,YAAY,GAAG;AACxC,UAAA,cAAc,aAAa,MAAM;AAEvC,QAAI,WAAW,YAAY,OAAO,KAAK,cAAc;AACnD,YAAM,IAAI;AAAA,QACR,6EAA6E,MAAM,QAAQ,YAAY,OAAO,KAAK,YAAY;AAAA,MAAA;AAAA,IAEnI;AAAA,EACF;AACF;AAEA,MAAM,uBAAuB,MAAM;AACjC,QAAM,eAAyD,CAAA;AAExD,SAAA;AAAA;AAAA;AAAA;AAAA,IAIL,OAAO;AACE,aAAA,OAAO,KAAK,YAAY;AAAA,IACjC;AAAA;AAAA;AAAA;AAAA,IAKA,IAAI,KAAsB;AACxB,aAAO,aAAa,GAAG;AAAA,IACzB;AAAA;AAAA;AAAA;AAAA,IAKA,OAAOA,aAAmB;AACjB,aAAAC,GAAA,OAAO,CAAC,GAAG,QAAQC,UAAAA,aAAa,KAAKF,WAAS,CAAC,EAAE,YAAY;AAAA,IACtE;AAAA;AAAA;AAAA;AAAA,IAKA,IAAI,KAAsB,aAAuC;AAC/D,mBAAa,GAAG,IAAI;AACb,aAAA;AAAA,IACT;AAAA;AAAA;AAAA;AAAA,IAKA,IAAIA,aAAmB,iBAAoC;AACzD,oCAA8B,eAAe;AAE7C,iBAAW,aAAa,OAAO,KAAK,eAAe,GAAG;AAC9C,cAAA,MAAMG,UAAAA,aAAa,WAAWH,WAAS;AAEzC,YAAAI,GAAA,IAAI,KAAK,YAAY,GAAG;AAC1B,gBAAM,IAAI,MAAM,gBAAgB,GAAG,+BAA+B;AAAA,QACpE;AAEA,qBAAa,GAAG,IAAIC,MAAA,kBAAkB,KAAK,gBAAgB,SAAS,CAAC;AAAA,MACvE;AAAA,IACF;AAAA;AAAA;AAAA;AAAA,IAKA,OAAO,OAAwB,UAA+B;AACtD,YAAA,qBAAqB,KAAK,IAAI,KAAK;AAEzC,UAAI,CAAC,oBAAoB;AACvB,cAAM,IAAI,MAAM,gBAAgB,KAAK,gBAAgB;AAAA,MACvD;AAEA,eAAS,kBAAkB;AAEpB,aAAA;AAAA,IACT;AAAA,EAAA;AAEJ;;"}
1
+ {"version":3,"file":"content-types.js","sources":["../../src/registries/content-types.ts"],"sourcesContent":["import { pickBy, has } from 'lodash/fp';\nimport type { UID, Struct } from '@strapi/types';\nimport { createContentType, ContentTypeDefinition } from '../domain/content-type';\nimport { addNamespace, hasNamespace } from './namespace';\n\ntype ContentTypesInput = Record<string, ContentTypeDefinition>;\ntype ContentTypeExtendFn = (contentType: Struct.ContentTypeSchema) => Struct.ContentTypeSchema;\n\nconst validateKeySameToSingularName = (contentTypes: ContentTypesInput) => {\n for (const ctName of Object.keys(contentTypes)) {\n const contentType = contentTypes[ctName];\n\n if (ctName !== contentType.schema.info.singularName) {\n throw new Error(\n `The key of the content-type should be the same as its singularName. Found ${ctName} and ${contentType.schema.info.singularName}.`\n );\n }\n }\n};\n\nconst contentTypesRegistry = () => {\n const contentTypes: Record<string, Struct.ContentTypeSchema> = {};\n\n return {\n /**\n * Returns this list of registered contentTypes uids\n */\n keys() {\n return Object.keys(contentTypes);\n },\n\n /**\n * Returns the instance of a contentType. Instantiate the contentType if not already done\n */\n get(uid: UID.ContentType) {\n return contentTypes[uid];\n },\n\n /**\n * Returns a map with all the contentTypes in a namespace\n */\n getAll(namespace: string) {\n return pickBy((_, uid) => hasNamespace(uid, namespace))(contentTypes);\n },\n\n /**\n * Registers a contentType\n */\n set(uid: UID.ContentType, contentType: Struct.ContentTypeSchema) {\n contentTypes[uid] = contentType;\n return this;\n },\n\n /**\n * Registers a map of contentTypes for a specific namespace\n */\n add(namespace: string, newContentTypes: ContentTypesInput) {\n validateKeySameToSingularName(newContentTypes);\n\n for (const rawCtName of Object.keys(newContentTypes)) {\n const uid = addNamespace(rawCtName, namespace);\n\n if (has(uid, contentTypes)) {\n throw new Error(`Content-type ${uid} has already been registered.`);\n }\n\n contentTypes[uid] = createContentType(uid, newContentTypes[rawCtName]);\n }\n },\n\n /**\n * Wraps a contentType to extend it\n */\n extend(ctUID: UID.ContentType, extendFn: ContentTypeExtendFn) {\n const currentContentType = this.get(ctUID);\n\n if (!currentContentType) {\n throw new Error(`Content-Type ${ctUID} doesn't exist`);\n }\n\n extendFn(currentContentType);\n\n return this;\n },\n };\n};\n\nexport default contentTypesRegistry;\n"],"names":["validateKeySameToSingularName","contentTypes","ctName","Object","keys","contentType","schema","info","singularName","Error","contentTypesRegistry","get","uid","getAll","namespace","pickBy","_","hasNamespace","set","add","newContentTypes","rawCtName","addNamespace","has","createContentType","extend","ctUID","extendFn","currentContentType"],"mappings":";;;;;;AAQA,MAAMA,gCAAgC,CAACC,YAAAA,GAAAA;AACrC,IAAA,KAAK,MAAMC,MAAAA,IAAUC,MAAOC,CAAAA,IAAI,CAACH,YAAe,CAAA,CAAA;QAC9C,MAAMI,WAAAA,GAAcJ,YAAY,CAACC,MAAO,CAAA;AAExC,QAAA,IAAIA,WAAWG,WAAYC,CAAAA,MAAM,CAACC,IAAI,CAACC,YAAY,EAAE;AACnD,YAAA,MAAM,IAAIC,KACR,CAAA,CAAC,0EAA0E,EAAEP,OAAO,KAAK,EAAEG,WAAYC,CAAAA,MAAM,CAACC,IAAI,CAACC,YAAY,CAAC,CAAC,CAAC,CAAA;AAEtI;AACF;AACF,CAAA;AAEA,MAAME,oBAAuB,GAAA,IAAA;AAC3B,IAAA,MAAMT,eAAyD,EAAC;IAEhE,OAAO;AACL;;QAGAG,IAAAA,CAAAA,GAAAA;YACE,OAAOD,MAAAA,CAAOC,IAAI,CAACH,YAAAA,CAAAA;AACrB,SAAA;AAEA;;AAEC,QACDU,KAAIC,GAAoB,EAAA;YACtB,OAAOX,YAAY,CAACW,GAAI,CAAA;AAC1B,SAAA;AAEA;;AAEC,QACDC,QAAOC,WAAiB,EAAA;AACtB,YAAA,OAAOC,UAAO,CAACC,CAAAA,EAAGJ,GAAQK,GAAAA,sBAAAA,CAAaL,KAAKE,WAAYb,CAAAA,CAAAA,CAAAA,YAAAA,CAAAA;AAC1D,SAAA;AAEA;;QAGAiB,GAAAA,CAAAA,CAAIN,GAAoB,EAAEP,WAAqC,EAAA;YAC7DJ,YAAY,CAACW,IAAI,GAAGP,WAAAA;AACpB,YAAA,OAAO,IAAI;AACb,SAAA;AAEA;;QAGAc,GAAAA,CAAAA,CAAIL,WAAiB,EAAEM,eAAkC,EAAA;YACvDpB,6BAA8BoB,CAAAA,eAAAA,CAAAA;AAE9B,YAAA,KAAK,MAAMC,SAAAA,IAAalB,MAAOC,CAAAA,IAAI,CAACgB,eAAkB,CAAA,CAAA;gBACpD,MAAMR,GAAAA,GAAMU,uBAAaD,SAAWP,EAAAA,WAAAA,CAAAA;gBAEpC,IAAIS,MAAAA,CAAIX,KAAKX,YAAe,CAAA,EAAA;AAC1B,oBAAA,MAAM,IAAIQ,KAAM,CAAA,CAAC,aAAa,EAAEG,GAAAA,CAAI,6BAA6B,CAAC,CAAA;AACpE;AAEAX,gBAAAA,YAAY,CAACW,GAAI,CAAA,GAAGY,wBAAkBZ,GAAKQ,EAAAA,eAAe,CAACC,SAAU,CAAA,CAAA;AACvE;AACF,SAAA;AAEA;;QAGAI,MAAAA,CAAAA,CAAOC,KAAsB,EAAEC,QAA6B,EAAA;AAC1D,YAAA,MAAMC,kBAAqB,GAAA,IAAI,CAACjB,GAAG,CAACe,KAAAA,CAAAA;AAEpC,YAAA,IAAI,CAACE,kBAAoB,EAAA;AACvB,gBAAA,MAAM,IAAInB,KAAM,CAAA,CAAC,aAAa,EAAEiB,KAAAA,CAAM,cAAc,CAAC,CAAA;AACvD;YAEAC,QAASC,CAAAA,kBAAAA,CAAAA;AAET,YAAA,OAAO,IAAI;AACb;AACF,KAAA;AACF;;;;"}
@@ -1,71 +1,63 @@
1
- import { pickBy, has } from "lodash/fp";
2
- import { createContentType } from "../domain/content-type/index.mjs";
3
- import { hasNamespace, addNamespace } from "./namespace.mjs";
4
- const validateKeySameToSingularName = (contentTypes) => {
5
- for (const ctName of Object.keys(contentTypes)) {
6
- const contentType = contentTypes[ctName];
7
- if (ctName !== contentType.schema.info.singularName) {
8
- throw new Error(
9
- `The key of the content-type should be the same as its singularName. Found ${ctName} and ${contentType.schema.info.singularName}.`
10
- );
1
+ import { pickBy, has } from 'lodash/fp';
2
+ import { createContentType } from '../domain/content-type/index.mjs';
3
+ import { hasNamespace, addNamespace } from './namespace.mjs';
4
+
5
+ const validateKeySameToSingularName = (contentTypes)=>{
6
+ for (const ctName of Object.keys(contentTypes)){
7
+ const contentType = contentTypes[ctName];
8
+ if (ctName !== contentType.schema.info.singularName) {
9
+ throw new Error(`The key of the content-type should be the same as its singularName. Found ${ctName} and ${contentType.schema.info.singularName}.`);
10
+ }
11
11
  }
12
- }
13
12
  };
14
- const contentTypesRegistry = () => {
15
- const contentTypes = {};
16
- return {
17
- /**
13
+ const contentTypesRegistry = ()=>{
14
+ const contentTypes = {};
15
+ return {
16
+ /**
18
17
  * Returns this list of registered contentTypes uids
19
- */
20
- keys() {
21
- return Object.keys(contentTypes);
22
- },
23
- /**
18
+ */ keys () {
19
+ return Object.keys(contentTypes);
20
+ },
21
+ /**
24
22
  * Returns the instance of a contentType. Instantiate the contentType if not already done
25
- */
26
- get(uid) {
27
- return contentTypes[uid];
28
- },
29
- /**
23
+ */ get (uid) {
24
+ return contentTypes[uid];
25
+ },
26
+ /**
30
27
  * Returns a map with all the contentTypes in a namespace
31
- */
32
- getAll(namespace) {
33
- return pickBy((_, uid) => hasNamespace(uid, namespace))(contentTypes);
34
- },
35
- /**
28
+ */ getAll (namespace) {
29
+ return pickBy((_, uid)=>hasNamespace(uid, namespace))(contentTypes);
30
+ },
31
+ /**
36
32
  * Registers a contentType
37
- */
38
- set(uid, contentType) {
39
- contentTypes[uid] = contentType;
40
- return this;
41
- },
42
- /**
33
+ */ set (uid, contentType) {
34
+ contentTypes[uid] = contentType;
35
+ return this;
36
+ },
37
+ /**
43
38
  * Registers a map of contentTypes for a specific namespace
44
- */
45
- add(namespace, newContentTypes) {
46
- validateKeySameToSingularName(newContentTypes);
47
- for (const rawCtName of Object.keys(newContentTypes)) {
48
- const uid = addNamespace(rawCtName, namespace);
49
- if (has(uid, contentTypes)) {
50
- throw new Error(`Content-type ${uid} has already been registered.`);
51
- }
52
- contentTypes[uid] = createContentType(uid, newContentTypes[rawCtName]);
53
- }
54
- },
55
- /**
39
+ */ add (namespace, newContentTypes) {
40
+ validateKeySameToSingularName(newContentTypes);
41
+ for (const rawCtName of Object.keys(newContentTypes)){
42
+ const uid = addNamespace(rawCtName, namespace);
43
+ if (has(uid, contentTypes)) {
44
+ throw new Error(`Content-type ${uid} has already been registered.`);
45
+ }
46
+ contentTypes[uid] = createContentType(uid, newContentTypes[rawCtName]);
47
+ }
48
+ },
49
+ /**
56
50
  * Wraps a contentType to extend it
57
- */
58
- extend(ctUID, extendFn) {
59
- const currentContentType = this.get(ctUID);
60
- if (!currentContentType) {
61
- throw new Error(`Content-Type ${ctUID} doesn't exist`);
62
- }
63
- extendFn(currentContentType);
64
- return this;
65
- }
66
- };
67
- };
68
- export {
69
- contentTypesRegistry as default
51
+ */ extend (ctUID, extendFn) {
52
+ const currentContentType = this.get(ctUID);
53
+ if (!currentContentType) {
54
+ throw new Error(`Content-Type ${ctUID} doesn't exist`);
55
+ }
56
+ extendFn(currentContentType);
57
+ return this;
58
+ }
59
+ };
70
60
  };
61
+
62
+ export { contentTypesRegistry as default };
71
63
  //# sourceMappingURL=content-types.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"content-types.mjs","sources":["../../src/registries/content-types.ts"],"sourcesContent":["import { pickBy, has } from 'lodash/fp';\nimport type { UID, Struct } from '@strapi/types';\nimport { createContentType, ContentTypeDefinition } from '../domain/content-type';\nimport { addNamespace, hasNamespace } from './namespace';\n\ntype ContentTypesInput = Record<string, ContentTypeDefinition>;\ntype ContentTypeExtendFn = (contentType: Struct.ContentTypeSchema) => Struct.ContentTypeSchema;\n\nconst validateKeySameToSingularName = (contentTypes: ContentTypesInput) => {\n for (const ctName of Object.keys(contentTypes)) {\n const contentType = contentTypes[ctName];\n\n if (ctName !== contentType.schema.info.singularName) {\n throw new Error(\n `The key of the content-type should be the same as its singularName. Found ${ctName} and ${contentType.schema.info.singularName}.`\n );\n }\n }\n};\n\nconst contentTypesRegistry = () => {\n const contentTypes: Record<string, Struct.ContentTypeSchema> = {};\n\n return {\n /**\n * Returns this list of registered contentTypes uids\n */\n keys() {\n return Object.keys(contentTypes);\n },\n\n /**\n * Returns the instance of a contentType. Instantiate the contentType if not already done\n */\n get(uid: UID.ContentType) {\n return contentTypes[uid];\n },\n\n /**\n * Returns a map with all the contentTypes in a namespace\n */\n getAll(namespace: string) {\n return pickBy((_, uid) => hasNamespace(uid, namespace))(contentTypes);\n },\n\n /**\n * Registers a contentType\n */\n set(uid: UID.ContentType, contentType: Struct.ContentTypeSchema) {\n contentTypes[uid] = contentType;\n return this;\n },\n\n /**\n * Registers a map of contentTypes for a specific namespace\n */\n add(namespace: string, newContentTypes: ContentTypesInput) {\n validateKeySameToSingularName(newContentTypes);\n\n for (const rawCtName of Object.keys(newContentTypes)) {\n const uid = addNamespace(rawCtName, namespace);\n\n if (has(uid, contentTypes)) {\n throw new Error(`Content-type ${uid} has already been registered.`);\n }\n\n contentTypes[uid] = createContentType(uid, newContentTypes[rawCtName]);\n }\n },\n\n /**\n * Wraps a contentType to extend it\n */\n extend(ctUID: UID.ContentType, extendFn: ContentTypeExtendFn) {\n const currentContentType = this.get(ctUID);\n\n if (!currentContentType) {\n throw new Error(`Content-Type ${ctUID} doesn't exist`);\n }\n\n extendFn(currentContentType);\n\n return this;\n },\n };\n};\n\nexport default contentTypesRegistry;\n"],"names":[],"mappings":";;;AAQA,MAAM,gCAAgC,CAAC,iBAAoC;AACzE,aAAW,UAAU,OAAO,KAAK,YAAY,GAAG;AACxC,UAAA,cAAc,aAAa,MAAM;AAEvC,QAAI,WAAW,YAAY,OAAO,KAAK,cAAc;AACnD,YAAM,IAAI;AAAA,QACR,6EAA6E,MAAM,QAAQ,YAAY,OAAO,KAAK,YAAY;AAAA,MAAA;AAAA,IAEnI;AAAA,EACF;AACF;AAEA,MAAM,uBAAuB,MAAM;AACjC,QAAM,eAAyD,CAAA;AAExD,SAAA;AAAA;AAAA;AAAA;AAAA,IAIL,OAAO;AACE,aAAA,OAAO,KAAK,YAAY;AAAA,IACjC;AAAA;AAAA;AAAA;AAAA,IAKA,IAAI,KAAsB;AACxB,aAAO,aAAa,GAAG;AAAA,IACzB;AAAA;AAAA;AAAA;AAAA,IAKA,OAAO,WAAmB;AACjB,aAAA,OAAO,CAAC,GAAG,QAAQ,aAAa,KAAK,SAAS,CAAC,EAAE,YAAY;AAAA,IACtE;AAAA;AAAA;AAAA;AAAA,IAKA,IAAI,KAAsB,aAAuC;AAC/D,mBAAa,GAAG,IAAI;AACb,aAAA;AAAA,IACT;AAAA;AAAA;AAAA;AAAA,IAKA,IAAI,WAAmB,iBAAoC;AACzD,oCAA8B,eAAe;AAE7C,iBAAW,aAAa,OAAO,KAAK,eAAe,GAAG;AAC9C,cAAA,MAAM,aAAa,WAAW,SAAS;AAEzC,YAAA,IAAI,KAAK,YAAY,GAAG;AAC1B,gBAAM,IAAI,MAAM,gBAAgB,GAAG,+BAA+B;AAAA,QACpE;AAEA,qBAAa,GAAG,IAAI,kBAAkB,KAAK,gBAAgB,SAAS,CAAC;AAAA,MACvE;AAAA,IACF;AAAA;AAAA;AAAA;AAAA,IAKA,OAAO,OAAwB,UAA+B;AACtD,YAAA,qBAAqB,KAAK,IAAI,KAAK;AAEzC,UAAI,CAAC,oBAAoB;AACvB,cAAM,IAAI,MAAM,gBAAgB,KAAK,gBAAgB;AAAA,MACvD;AAEA,eAAS,kBAAkB;AAEpB,aAAA;AAAA,IACT;AAAA,EAAA;AAEJ;"}
1
+ {"version":3,"file":"content-types.mjs","sources":["../../src/registries/content-types.ts"],"sourcesContent":["import { pickBy, has } from 'lodash/fp';\nimport type { UID, Struct } from '@strapi/types';\nimport { createContentType, ContentTypeDefinition } from '../domain/content-type';\nimport { addNamespace, hasNamespace } from './namespace';\n\ntype ContentTypesInput = Record<string, ContentTypeDefinition>;\ntype ContentTypeExtendFn = (contentType: Struct.ContentTypeSchema) => Struct.ContentTypeSchema;\n\nconst validateKeySameToSingularName = (contentTypes: ContentTypesInput) => {\n for (const ctName of Object.keys(contentTypes)) {\n const contentType = contentTypes[ctName];\n\n if (ctName !== contentType.schema.info.singularName) {\n throw new Error(\n `The key of the content-type should be the same as its singularName. Found ${ctName} and ${contentType.schema.info.singularName}.`\n );\n }\n }\n};\n\nconst contentTypesRegistry = () => {\n const contentTypes: Record<string, Struct.ContentTypeSchema> = {};\n\n return {\n /**\n * Returns this list of registered contentTypes uids\n */\n keys() {\n return Object.keys(contentTypes);\n },\n\n /**\n * Returns the instance of a contentType. Instantiate the contentType if not already done\n */\n get(uid: UID.ContentType) {\n return contentTypes[uid];\n },\n\n /**\n * Returns a map with all the contentTypes in a namespace\n */\n getAll(namespace: string) {\n return pickBy((_, uid) => hasNamespace(uid, namespace))(contentTypes);\n },\n\n /**\n * Registers a contentType\n */\n set(uid: UID.ContentType, contentType: Struct.ContentTypeSchema) {\n contentTypes[uid] = contentType;\n return this;\n },\n\n /**\n * Registers a map of contentTypes for a specific namespace\n */\n add(namespace: string, newContentTypes: ContentTypesInput) {\n validateKeySameToSingularName(newContentTypes);\n\n for (const rawCtName of Object.keys(newContentTypes)) {\n const uid = addNamespace(rawCtName, namespace);\n\n if (has(uid, contentTypes)) {\n throw new Error(`Content-type ${uid} has already been registered.`);\n }\n\n contentTypes[uid] = createContentType(uid, newContentTypes[rawCtName]);\n }\n },\n\n /**\n * Wraps a contentType to extend it\n */\n extend(ctUID: UID.ContentType, extendFn: ContentTypeExtendFn) {\n const currentContentType = this.get(ctUID);\n\n if (!currentContentType) {\n throw new Error(`Content-Type ${ctUID} doesn't exist`);\n }\n\n extendFn(currentContentType);\n\n return this;\n },\n };\n};\n\nexport default contentTypesRegistry;\n"],"names":["validateKeySameToSingularName","contentTypes","ctName","Object","keys","contentType","schema","info","singularName","Error","contentTypesRegistry","get","uid","getAll","namespace","pickBy","_","hasNamespace","set","add","newContentTypes","rawCtName","addNamespace","has","createContentType","extend","ctUID","extendFn","currentContentType"],"mappings":";;;;AAQA,MAAMA,gCAAgC,CAACC,YAAAA,GAAAA;AACrC,IAAA,KAAK,MAAMC,MAAAA,IAAUC,MAAOC,CAAAA,IAAI,CAACH,YAAe,CAAA,CAAA;QAC9C,MAAMI,WAAAA,GAAcJ,YAAY,CAACC,MAAO,CAAA;AAExC,QAAA,IAAIA,WAAWG,WAAYC,CAAAA,MAAM,CAACC,IAAI,CAACC,YAAY,EAAE;AACnD,YAAA,MAAM,IAAIC,KACR,CAAA,CAAC,0EAA0E,EAAEP,OAAO,KAAK,EAAEG,WAAYC,CAAAA,MAAM,CAACC,IAAI,CAACC,YAAY,CAAC,CAAC,CAAC,CAAA;AAEtI;AACF;AACF,CAAA;AAEA,MAAME,oBAAuB,GAAA,IAAA;AAC3B,IAAA,MAAMT,eAAyD,EAAC;IAEhE,OAAO;AACL;;QAGAG,IAAAA,CAAAA,GAAAA;YACE,OAAOD,MAAAA,CAAOC,IAAI,CAACH,YAAAA,CAAAA;AACrB,SAAA;AAEA;;AAEC,QACDU,KAAIC,GAAoB,EAAA;YACtB,OAAOX,YAAY,CAACW,GAAI,CAAA;AAC1B,SAAA;AAEA;;AAEC,QACDC,QAAOC,SAAiB,EAAA;AACtB,YAAA,OAAOC,OAAO,CAACC,CAAAA,EAAGJ,GAAQK,GAAAA,YAAAA,CAAaL,KAAKE,SAAYb,CAAAA,CAAAA,CAAAA,YAAAA,CAAAA;AAC1D,SAAA;AAEA;;QAGAiB,GAAAA,CAAAA,CAAIN,GAAoB,EAAEP,WAAqC,EAAA;YAC7DJ,YAAY,CAACW,IAAI,GAAGP,WAAAA;AACpB,YAAA,OAAO,IAAI;AACb,SAAA;AAEA;;QAGAc,GAAAA,CAAAA,CAAIL,SAAiB,EAAEM,eAAkC,EAAA;YACvDpB,6BAA8BoB,CAAAA,eAAAA,CAAAA;AAE9B,YAAA,KAAK,MAAMC,SAAAA,IAAalB,MAAOC,CAAAA,IAAI,CAACgB,eAAkB,CAAA,CAAA;gBACpD,MAAMR,GAAAA,GAAMU,aAAaD,SAAWP,EAAAA,SAAAA,CAAAA;gBAEpC,IAAIS,GAAAA,CAAIX,KAAKX,YAAe,CAAA,EAAA;AAC1B,oBAAA,MAAM,IAAIQ,KAAM,CAAA,CAAC,aAAa,EAAEG,GAAAA,CAAI,6BAA6B,CAAC,CAAA;AACpE;AAEAX,gBAAAA,YAAY,CAACW,GAAI,CAAA,GAAGY,kBAAkBZ,GAAKQ,EAAAA,eAAe,CAACC,SAAU,CAAA,CAAA;AACvE;AACF,SAAA;AAEA;;QAGAI,MAAAA,CAAAA,CAAOC,KAAsB,EAAEC,QAA6B,EAAA;AAC1D,YAAA,MAAMC,kBAAqB,GAAA,IAAI,CAACjB,GAAG,CAACe,KAAAA,CAAAA;AAEpC,YAAA,IAAI,CAACE,kBAAoB,EAAA;AACvB,gBAAA,MAAM,IAAInB,KAAM,CAAA,CAAC,aAAa,EAAEiB,KAAAA,CAAM,cAAc,CAAC,CAAA;AACvD;YAEAC,QAASC,CAAAA,kBAAAA,CAAAA;AAET,YAAA,OAAO,IAAI;AACb;AACF,KAAA;AACF;;;;"}
@@ -1,80 +1,79 @@
1
- "use strict";
2
- const fp = require("lodash/fp");
3
- const namespace = require("./namespace.js");
4
- const controllersRegistry = (strapi) => {
5
- const controllers = {};
6
- const instances = {};
7
- return {
8
- /**
1
+ 'use strict';
2
+
3
+ var fp = require('lodash/fp');
4
+ var namespace = require('./namespace.js');
5
+
6
+ const controllersRegistry = (strapi)=>{
7
+ const controllers = {};
8
+ const instances = {};
9
+ return {
10
+ /**
9
11
  * Returns this list of registered controllers uids
10
- */
11
- keys() {
12
- return Object.keys(controllers);
13
- },
14
- /**
12
+ */ keys () {
13
+ return Object.keys(controllers);
14
+ },
15
+ /**
15
16
  * Returns the instance of a controller. Instantiate the controller if not already done
16
- */
17
- get(uid) {
18
- if (instances[uid]) {
19
- return instances[uid];
20
- }
21
- const controller = controllers[uid];
22
- if (controller) {
23
- instances[uid] = typeof controller === "function" ? controller({ strapi }) : controller;
24
- return instances[uid];
25
- }
26
- },
27
- /**
17
+ */ get (uid) {
18
+ if (instances[uid]) {
19
+ return instances[uid];
20
+ }
21
+ const controller = controllers[uid];
22
+ if (controller) {
23
+ instances[uid] = typeof controller === 'function' ? controller({
24
+ strapi
25
+ }) : controller;
26
+ return instances[uid];
27
+ }
28
+ },
29
+ /**
28
30
  * Returns a map with all the controller in a namespace
29
- */
30
- getAll(namespace$1) {
31
- const filteredControllers = fp.pickBy((_, uid) => namespace.hasNamespace(uid, namespace$1))(controllers);
32
- const map = {};
33
- for (const uid of Object.keys(filteredControllers)) {
34
- Object.defineProperty(map, uid, {
35
- enumerable: true,
36
- get: () => {
37
- return this.get(uid);
38
- }
39
- });
40
- }
41
- return map;
42
- },
43
- /**
31
+ */ getAll (namespace$1) {
32
+ const filteredControllers = fp.pickBy((_, uid)=>namespace.hasNamespace(uid, namespace$1))(controllers);
33
+ const map = {};
34
+ for (const uid of Object.keys(filteredControllers)){
35
+ Object.defineProperty(map, uid, {
36
+ enumerable: true,
37
+ get: ()=>{
38
+ return this.get(uid);
39
+ }
40
+ });
41
+ }
42
+ return map;
43
+ },
44
+ /**
44
45
  * Registers a controller
45
- */
46
- set(uid, value) {
47
- controllers[uid] = value;
48
- delete instances[uid];
49
- return this;
50
- },
51
- /**
46
+ */ set (uid, value) {
47
+ controllers[uid] = value;
48
+ delete instances[uid];
49
+ return this;
50
+ },
51
+ /**
52
52
  * Registers a map of controllers for a specific namespace
53
- */
54
- add(namespace$1, newControllers) {
55
- for (const controllerName of Object.keys(newControllers)) {
56
- const controller = newControllers[controllerName];
57
- const uid = namespace.addNamespace(controllerName, namespace$1);
58
- if (fp.has(uid, controllers)) {
59
- throw new Error(`Controller ${uid} has already been registered.`);
60
- }
61
- controllers[uid] = controller;
62
- }
63
- return this;
64
- },
65
- /**
53
+ */ add (namespace$1, newControllers) {
54
+ for (const controllerName of Object.keys(newControllers)){
55
+ const controller = newControllers[controllerName];
56
+ const uid = namespace.addNamespace(controllerName, namespace$1);
57
+ if (fp.has(uid, controllers)) {
58
+ throw new Error(`Controller ${uid} has already been registered.`);
59
+ }
60
+ controllers[uid] = controller;
61
+ }
62
+ return this;
63
+ },
64
+ /**
66
65
  * Wraps a controller to extend it
67
- */
68
- extend(controllerUID, extendFn) {
69
- const currentController = this.get(controllerUID);
70
- if (!currentController) {
71
- throw new Error(`Controller ${controllerUID} doesn't exist`);
72
- }
73
- const newController = extendFn(currentController);
74
- instances[controllerUID] = newController;
75
- return this;
76
- }
77
- };
66
+ */ extend (controllerUID, extendFn) {
67
+ const currentController = this.get(controllerUID);
68
+ if (!currentController) {
69
+ throw new Error(`Controller ${controllerUID} doesn't exist`);
70
+ }
71
+ const newController = extendFn(currentController);
72
+ instances[controllerUID] = newController;
73
+ return this;
74
+ }
75
+ };
78
76
  };
77
+
79
78
  module.exports = controllersRegistry;
80
79
  //# sourceMappingURL=controllers.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"controllers.js","sources":["../../src/registries/controllers.ts"],"sourcesContent":["import { pickBy, has } from 'lodash/fp';\nimport type { Core, UID } from '@strapi/types';\nimport { addNamespace, hasNamespace } from './namespace';\n\nexport type ControllerFactory =\n | ((params: { strapi: Core.Strapi }) => Core.Controller)\n | Core.Controller;\nexport type ControllerFactoryMap = Record<UID.Controller, ControllerFactory>;\nexport type ControllerMap = Record<UID.Controller, Core.Controller>;\nexport type ControllerExtendFn = (service: Core.Controller) => Core.Controller;\n\nconst controllersRegistry = (strapi: Core.Strapi) => {\n const controllers: ControllerFactoryMap = {};\n const instances: ControllerMap = {};\n\n return {\n /**\n * Returns this list of registered controllers uids\n */\n keys() {\n return Object.keys(controllers);\n },\n\n /**\n * Returns the instance of a controller. Instantiate the controller if not already done\n */\n get(uid: UID.Controller) {\n if (instances[uid]) {\n return instances[uid];\n }\n\n const controller = controllers[uid];\n\n if (controller) {\n instances[uid] = typeof controller === 'function' ? controller({ strapi }) : controller;\n return instances[uid];\n }\n },\n\n /**\n * Returns a map with all the controller in a namespace\n */\n getAll(namespace: string) {\n const filteredControllers = pickBy((_, uid) => hasNamespace(uid, namespace))(controllers);\n\n const map = {};\n for (const uid of Object.keys(filteredControllers) as UID.Controller[]) {\n Object.defineProperty(map, uid, {\n enumerable: true,\n get: () => {\n return this.get(uid);\n },\n });\n }\n\n return map;\n },\n\n /**\n * Registers a controller\n */\n set(uid: UID.Controller, value: ControllerFactory) {\n controllers[uid] = value;\n delete instances[uid];\n return this;\n },\n\n /**\n * Registers a map of controllers for a specific namespace\n */\n add(namespace: string, newControllers: ControllerFactoryMap) {\n for (const controllerName of Object.keys(newControllers) as UID.Controller[]) {\n const controller = newControllers[controllerName];\n const uid = addNamespace(controllerName, namespace) as UID.Controller;\n\n if (has(uid, controllers)) {\n throw new Error(`Controller ${uid} has already been registered.`);\n }\n\n controllers[uid] = controller;\n }\n\n return this;\n },\n\n /**\n * Wraps a controller to extend it\n */\n extend(controllerUID: UID.Controller, extendFn: ControllerExtendFn) {\n const currentController = this.get(controllerUID);\n\n if (!currentController) {\n throw new Error(`Controller ${controllerUID} doesn't exist`);\n }\n\n const newController = extendFn(currentController);\n instances[controllerUID] = newController;\n\n return this;\n },\n };\n};\n\nexport default controllersRegistry;\n"],"names":["namespace","pickBy","hasNamespace","addNamespace","has"],"mappings":";;;AAWM,MAAA,sBAAsB,CAAC,WAAwB;AACnD,QAAM,cAAoC,CAAA;AAC1C,QAAM,YAA2B,CAAA;AAE1B,SAAA;AAAA;AAAA;AAAA;AAAA,IAIL,OAAO;AACE,aAAA,OAAO,KAAK,WAAW;AAAA,IAChC;AAAA;AAAA;AAAA;AAAA,IAKA,IAAI,KAAqB;AACnB,UAAA,UAAU,GAAG,GAAG;AAClB,eAAO,UAAU,GAAG;AAAA,MACtB;AAEM,YAAA,aAAa,YAAY,GAAG;AAElC,UAAI,YAAY;AACJ,kBAAA,GAAG,IAAI,OAAO,eAAe,aAAa,WAAW,EAAE,QAAQ,IAAI;AAC7E,eAAO,UAAU,GAAG;AAAA,MACtB;AAAA,IACF;AAAA;AAAA;AAAA;AAAA,IAKA,OAAOA,aAAmB;AAClB,YAAA,sBAAsBC,GAAAA,OAAO,CAAC,GAAG,QAAQC,uBAAa,KAAKF,WAAS,CAAC,EAAE,WAAW;AAExF,YAAM,MAAM,CAAA;AACZ,iBAAW,OAAO,OAAO,KAAK,mBAAmB,GAAuB;AAC/D,eAAA,eAAe,KAAK,KAAK;AAAA,UAC9B,YAAY;AAAA,UACZ,KAAK,MAAM;AACF,mBAAA,KAAK,IAAI,GAAG;AAAA,UACrB;AAAA,QAAA,CACD;AAAA,MACH;AAEO,aAAA;AAAA,IACT;AAAA;AAAA;AAAA;AAAA,IAKA,IAAI,KAAqB,OAA0B;AACjD,kBAAY,GAAG,IAAI;AACnB,aAAO,UAAU,GAAG;AACb,aAAA;AAAA,IACT;AAAA;AAAA;AAAA;AAAA,IAKA,IAAIA,aAAmB,gBAAsC;AAC3D,iBAAW,kBAAkB,OAAO,KAAK,cAAc,GAAuB;AACtE,cAAA,aAAa,eAAe,cAAc;AAC1C,cAAA,MAAMG,UAAAA,aAAa,gBAAgBH,WAAS;AAE9C,YAAAI,GAAA,IAAI,KAAK,WAAW,GAAG;AACzB,gBAAM,IAAI,MAAM,cAAc,GAAG,+BAA+B;AAAA,QAClE;AAEA,oBAAY,GAAG,IAAI;AAAA,MACrB;AAEO,aAAA;AAAA,IACT;AAAA;AAAA;AAAA;AAAA,IAKA,OAAO,eAA+B,UAA8B;AAC5D,YAAA,oBAAoB,KAAK,IAAI,aAAa;AAEhD,UAAI,CAAC,mBAAmB;AACtB,cAAM,IAAI,MAAM,cAAc,aAAa,gBAAgB;AAAA,MAC7D;AAEM,YAAA,gBAAgB,SAAS,iBAAiB;AAChD,gBAAU,aAAa,IAAI;AAEpB,aAAA;AAAA,IACT;AAAA,EAAA;AAEJ;;"}
1
+ {"version":3,"file":"controllers.js","sources":["../../src/registries/controllers.ts"],"sourcesContent":["import { pickBy, has } from 'lodash/fp';\nimport type { Core, UID } from '@strapi/types';\nimport { addNamespace, hasNamespace } from './namespace';\n\nexport type ControllerFactory =\n | ((params: { strapi: Core.Strapi }) => Core.Controller)\n | Core.Controller;\nexport type ControllerFactoryMap = Record<UID.Controller, ControllerFactory>;\nexport type ControllerMap = Record<UID.Controller, Core.Controller>;\nexport type ControllerExtendFn = (service: Core.Controller) => Core.Controller;\n\nconst controllersRegistry = (strapi: Core.Strapi) => {\n const controllers: ControllerFactoryMap = {};\n const instances: ControllerMap = {};\n\n return {\n /**\n * Returns this list of registered controllers uids\n */\n keys() {\n return Object.keys(controllers);\n },\n\n /**\n * Returns the instance of a controller. Instantiate the controller if not already done\n */\n get(uid: UID.Controller) {\n if (instances[uid]) {\n return instances[uid];\n }\n\n const controller = controllers[uid];\n\n if (controller) {\n instances[uid] = typeof controller === 'function' ? controller({ strapi }) : controller;\n return instances[uid];\n }\n },\n\n /**\n * Returns a map with all the controller in a namespace\n */\n getAll(namespace: string) {\n const filteredControllers = pickBy((_, uid) => hasNamespace(uid, namespace))(controllers);\n\n const map = {};\n for (const uid of Object.keys(filteredControllers) as UID.Controller[]) {\n Object.defineProperty(map, uid, {\n enumerable: true,\n get: () => {\n return this.get(uid);\n },\n });\n }\n\n return map;\n },\n\n /**\n * Registers a controller\n */\n set(uid: UID.Controller, value: ControllerFactory) {\n controllers[uid] = value;\n delete instances[uid];\n return this;\n },\n\n /**\n * Registers a map of controllers for a specific namespace\n */\n add(namespace: string, newControllers: ControllerFactoryMap) {\n for (const controllerName of Object.keys(newControllers) as UID.Controller[]) {\n const controller = newControllers[controllerName];\n const uid = addNamespace(controllerName, namespace) as UID.Controller;\n\n if (has(uid, controllers)) {\n throw new Error(`Controller ${uid} has already been registered.`);\n }\n\n controllers[uid] = controller;\n }\n\n return this;\n },\n\n /**\n * Wraps a controller to extend it\n */\n extend(controllerUID: UID.Controller, extendFn: ControllerExtendFn) {\n const currentController = this.get(controllerUID);\n\n if (!currentController) {\n throw new Error(`Controller ${controllerUID} doesn't exist`);\n }\n\n const newController = extendFn(currentController);\n instances[controllerUID] = newController;\n\n return this;\n },\n };\n};\n\nexport default controllersRegistry;\n"],"names":["controllersRegistry","strapi","controllers","instances","keys","Object","get","uid","controller","getAll","namespace","filteredControllers","pickBy","_","hasNamespace","map","defineProperty","enumerable","set","value","add","newControllers","controllerName","addNamespace","has","Error","extend","controllerUID","extendFn","currentController","newController"],"mappings":";;;;;AAWA,MAAMA,sBAAsB,CAACC,MAAAA,GAAAA;AAC3B,IAAA,MAAMC,cAAoC,EAAC;AAC3C,IAAA,MAAMC,YAA2B,EAAC;IAElC,OAAO;AACL;;QAGAC,IAAAA,CAAAA,GAAAA;YACE,OAAOC,MAAAA,CAAOD,IAAI,CAACF,WAAAA,CAAAA;AACrB,SAAA;AAEA;;AAEC,QACDI,KAAIC,GAAmB,EAAA;YACrB,IAAIJ,SAAS,CAACI,GAAAA,CAAI,EAAE;gBAClB,OAAOJ,SAAS,CAACI,GAAI,CAAA;AACvB;YAEA,MAAMC,UAAAA,GAAaN,WAAW,CAACK,GAAI,CAAA;AAEnC,YAAA,IAAIC,UAAY,EAAA;AACdL,gBAAAA,SAAS,CAACI,GAAI,CAAA,GAAG,OAAOC,UAAAA,KAAe,aAAaA,UAAW,CAAA;AAAEP,oBAAAA;iBAAYO,CAAAA,GAAAA,UAAAA;gBAC7E,OAAOL,SAAS,CAACI,GAAI,CAAA;AACvB;AACF,SAAA;AAEA;;AAEC,QACDE,QAAOC,WAAiB,EAAA;AACtB,YAAA,MAAMC,sBAAsBC,SAAO,CAAA,CAACC,GAAGN,GAAQO,GAAAA,sBAAAA,CAAaP,KAAKG,WAAYR,CAAAA,CAAAA,CAAAA,WAAAA,CAAAA;AAE7E,YAAA,MAAMa,MAAM,EAAC;AACb,YAAA,KAAK,MAAMR,GAAAA,IAAOF,MAAOD,CAAAA,IAAI,CAACO,mBAA0C,CAAA,CAAA;gBACtEN,MAAOW,CAAAA,cAAc,CAACD,GAAAA,EAAKR,GAAK,EAAA;oBAC9BU,UAAY,EAAA,IAAA;oBACZX,GAAK,EAAA,IAAA;wBACH,OAAO,IAAI,CAACA,GAAG,CAACC,GAAAA,CAAAA;AAClB;AACF,iBAAA,CAAA;AACF;YAEA,OAAOQ,GAAAA;AACT,SAAA;AAEA;;QAGAG,GAAAA,CAAAA,CAAIX,GAAmB,EAAEY,KAAwB,EAAA;YAC/CjB,WAAW,CAACK,IAAI,GAAGY,KAAAA;YACnB,OAAOhB,SAAS,CAACI,GAAI,CAAA;AACrB,YAAA,OAAO,IAAI;AACb,SAAA;AAEA;;QAGAa,GAAAA,CAAAA,CAAIV,WAAiB,EAAEW,cAAoC,EAAA;AACzD,YAAA,KAAK,MAAMC,cAAAA,IAAkBjB,MAAOD,CAAAA,IAAI,CAACiB,cAAqC,CAAA,CAAA;gBAC5E,MAAMb,UAAAA,GAAaa,cAAc,CAACC,cAAe,CAAA;gBACjD,MAAMf,GAAAA,GAAMgB,uBAAaD,cAAgBZ,EAAAA,WAAAA,CAAAA;gBAEzC,IAAIc,MAAAA,CAAIjB,KAAKL,WAAc,CAAA,EAAA;AACzB,oBAAA,MAAM,IAAIuB,KAAM,CAAA,CAAC,WAAW,EAAElB,GAAAA,CAAI,6BAA6B,CAAC,CAAA;AAClE;gBAEAL,WAAW,CAACK,IAAI,GAAGC,UAAAA;AACrB;AAEA,YAAA,OAAO,IAAI;AACb,SAAA;AAEA;;QAGAkB,MAAAA,CAAAA,CAAOC,aAA6B,EAAEC,QAA4B,EAAA;AAChE,YAAA,MAAMC,iBAAoB,GAAA,IAAI,CAACvB,GAAG,CAACqB,aAAAA,CAAAA;AAEnC,YAAA,IAAI,CAACE,iBAAmB,EAAA;AACtB,gBAAA,MAAM,IAAIJ,KAAM,CAAA,CAAC,WAAW,EAAEE,aAAAA,CAAc,cAAc,CAAC,CAAA;AAC7D;AAEA,YAAA,MAAMG,gBAAgBF,QAASC,CAAAA,iBAAAA,CAAAA;YAC/B1B,SAAS,CAACwB,cAAc,GAAGG,aAAAA;AAE3B,YAAA,OAAO,IAAI;AACb;AACF,KAAA;AACF;;;;"}
@@ -1,81 +1,77 @@
1
- import { pickBy, has } from "lodash/fp";
2
- import { hasNamespace, addNamespace } from "./namespace.mjs";
3
- const controllersRegistry = (strapi) => {
4
- const controllers = {};
5
- const instances = {};
6
- return {
7
- /**
1
+ import { pickBy, has } from 'lodash/fp';
2
+ import { hasNamespace, addNamespace } from './namespace.mjs';
3
+
4
+ const controllersRegistry = (strapi)=>{
5
+ const controllers = {};
6
+ const instances = {};
7
+ return {
8
+ /**
8
9
  * Returns this list of registered controllers uids
9
- */
10
- keys() {
11
- return Object.keys(controllers);
12
- },
13
- /**
10
+ */ keys () {
11
+ return Object.keys(controllers);
12
+ },
13
+ /**
14
14
  * Returns the instance of a controller. Instantiate the controller if not already done
15
- */
16
- get(uid) {
17
- if (instances[uid]) {
18
- return instances[uid];
19
- }
20
- const controller = controllers[uid];
21
- if (controller) {
22
- instances[uid] = typeof controller === "function" ? controller({ strapi }) : controller;
23
- return instances[uid];
24
- }
25
- },
26
- /**
15
+ */ get (uid) {
16
+ if (instances[uid]) {
17
+ return instances[uid];
18
+ }
19
+ const controller = controllers[uid];
20
+ if (controller) {
21
+ instances[uid] = typeof controller === 'function' ? controller({
22
+ strapi
23
+ }) : controller;
24
+ return instances[uid];
25
+ }
26
+ },
27
+ /**
27
28
  * Returns a map with all the controller in a namespace
28
- */
29
- getAll(namespace) {
30
- const filteredControllers = pickBy((_, uid) => hasNamespace(uid, namespace))(controllers);
31
- const map = {};
32
- for (const uid of Object.keys(filteredControllers)) {
33
- Object.defineProperty(map, uid, {
34
- enumerable: true,
35
- get: () => {
36
- return this.get(uid);
37
- }
38
- });
39
- }
40
- return map;
41
- },
42
- /**
29
+ */ getAll (namespace) {
30
+ const filteredControllers = pickBy((_, uid)=>hasNamespace(uid, namespace))(controllers);
31
+ const map = {};
32
+ for (const uid of Object.keys(filteredControllers)){
33
+ Object.defineProperty(map, uid, {
34
+ enumerable: true,
35
+ get: ()=>{
36
+ return this.get(uid);
37
+ }
38
+ });
39
+ }
40
+ return map;
41
+ },
42
+ /**
43
43
  * Registers a controller
44
- */
45
- set(uid, value) {
46
- controllers[uid] = value;
47
- delete instances[uid];
48
- return this;
49
- },
50
- /**
44
+ */ set (uid, value) {
45
+ controllers[uid] = value;
46
+ delete instances[uid];
47
+ return this;
48
+ },
49
+ /**
51
50
  * Registers a map of controllers for a specific namespace
52
- */
53
- add(namespace, newControllers) {
54
- for (const controllerName of Object.keys(newControllers)) {
55
- const controller = newControllers[controllerName];
56
- const uid = addNamespace(controllerName, namespace);
57
- if (has(uid, controllers)) {
58
- throw new Error(`Controller ${uid} has already been registered.`);
59
- }
60
- controllers[uid] = controller;
61
- }
62
- return this;
63
- },
64
- /**
51
+ */ add (namespace, newControllers) {
52
+ for (const controllerName of Object.keys(newControllers)){
53
+ const controller = newControllers[controllerName];
54
+ const uid = addNamespace(controllerName, namespace);
55
+ if (has(uid, controllers)) {
56
+ throw new Error(`Controller ${uid} has already been registered.`);
57
+ }
58
+ controllers[uid] = controller;
59
+ }
60
+ return this;
61
+ },
62
+ /**
65
63
  * Wraps a controller to extend it
66
- */
67
- extend(controllerUID, extendFn) {
68
- const currentController = this.get(controllerUID);
69
- if (!currentController) {
70
- throw new Error(`Controller ${controllerUID} doesn't exist`);
71
- }
72
- const newController = extendFn(currentController);
73
- instances[controllerUID] = newController;
74
- return this;
75
- }
76
- };
77
- };
78
- export {
79
- controllersRegistry as default
64
+ */ extend (controllerUID, extendFn) {
65
+ const currentController = this.get(controllerUID);
66
+ if (!currentController) {
67
+ throw new Error(`Controller ${controllerUID} doesn't exist`);
68
+ }
69
+ const newController = extendFn(currentController);
70
+ instances[controllerUID] = newController;
71
+ return this;
72
+ }
73
+ };
80
74
  };
75
+
76
+ export { controllersRegistry as default };
81
77
  //# sourceMappingURL=controllers.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"controllers.mjs","sources":["../../src/registries/controllers.ts"],"sourcesContent":["import { pickBy, has } from 'lodash/fp';\nimport type { Core, UID } from '@strapi/types';\nimport { addNamespace, hasNamespace } from './namespace';\n\nexport type ControllerFactory =\n | ((params: { strapi: Core.Strapi }) => Core.Controller)\n | Core.Controller;\nexport type ControllerFactoryMap = Record<UID.Controller, ControllerFactory>;\nexport type ControllerMap = Record<UID.Controller, Core.Controller>;\nexport type ControllerExtendFn = (service: Core.Controller) => Core.Controller;\n\nconst controllersRegistry = (strapi: Core.Strapi) => {\n const controllers: ControllerFactoryMap = {};\n const instances: ControllerMap = {};\n\n return {\n /**\n * Returns this list of registered controllers uids\n */\n keys() {\n return Object.keys(controllers);\n },\n\n /**\n * Returns the instance of a controller. Instantiate the controller if not already done\n */\n get(uid: UID.Controller) {\n if (instances[uid]) {\n return instances[uid];\n }\n\n const controller = controllers[uid];\n\n if (controller) {\n instances[uid] = typeof controller === 'function' ? controller({ strapi }) : controller;\n return instances[uid];\n }\n },\n\n /**\n * Returns a map with all the controller in a namespace\n */\n getAll(namespace: string) {\n const filteredControllers = pickBy((_, uid) => hasNamespace(uid, namespace))(controllers);\n\n const map = {};\n for (const uid of Object.keys(filteredControllers) as UID.Controller[]) {\n Object.defineProperty(map, uid, {\n enumerable: true,\n get: () => {\n return this.get(uid);\n },\n });\n }\n\n return map;\n },\n\n /**\n * Registers a controller\n */\n set(uid: UID.Controller, value: ControllerFactory) {\n controllers[uid] = value;\n delete instances[uid];\n return this;\n },\n\n /**\n * Registers a map of controllers for a specific namespace\n */\n add(namespace: string, newControllers: ControllerFactoryMap) {\n for (const controllerName of Object.keys(newControllers) as UID.Controller[]) {\n const controller = newControllers[controllerName];\n const uid = addNamespace(controllerName, namespace) as UID.Controller;\n\n if (has(uid, controllers)) {\n throw new Error(`Controller ${uid} has already been registered.`);\n }\n\n controllers[uid] = controller;\n }\n\n return this;\n },\n\n /**\n * Wraps a controller to extend it\n */\n extend(controllerUID: UID.Controller, extendFn: ControllerExtendFn) {\n const currentController = this.get(controllerUID);\n\n if (!currentController) {\n throw new Error(`Controller ${controllerUID} doesn't exist`);\n }\n\n const newController = extendFn(currentController);\n instances[controllerUID] = newController;\n\n return this;\n },\n };\n};\n\nexport default controllersRegistry;\n"],"names":[],"mappings":";;AAWM,MAAA,sBAAsB,CAAC,WAAwB;AACnD,QAAM,cAAoC,CAAA;AAC1C,QAAM,YAA2B,CAAA;AAE1B,SAAA;AAAA;AAAA;AAAA;AAAA,IAIL,OAAO;AACE,aAAA,OAAO,KAAK,WAAW;AAAA,IAChC;AAAA;AAAA;AAAA;AAAA,IAKA,IAAI,KAAqB;AACnB,UAAA,UAAU,GAAG,GAAG;AAClB,eAAO,UAAU,GAAG;AAAA,MACtB;AAEM,YAAA,aAAa,YAAY,GAAG;AAElC,UAAI,YAAY;AACJ,kBAAA,GAAG,IAAI,OAAO,eAAe,aAAa,WAAW,EAAE,QAAQ,IAAI;AAC7E,eAAO,UAAU,GAAG;AAAA,MACtB;AAAA,IACF;AAAA;AAAA;AAAA;AAAA,IAKA,OAAO,WAAmB;AAClB,YAAA,sBAAsB,OAAO,CAAC,GAAG,QAAQ,aAAa,KAAK,SAAS,CAAC,EAAE,WAAW;AAExF,YAAM,MAAM,CAAA;AACZ,iBAAW,OAAO,OAAO,KAAK,mBAAmB,GAAuB;AAC/D,eAAA,eAAe,KAAK,KAAK;AAAA,UAC9B,YAAY;AAAA,UACZ,KAAK,MAAM;AACF,mBAAA,KAAK,IAAI,GAAG;AAAA,UACrB;AAAA,QAAA,CACD;AAAA,MACH;AAEO,aAAA;AAAA,IACT;AAAA;AAAA;AAAA;AAAA,IAKA,IAAI,KAAqB,OAA0B;AACjD,kBAAY,GAAG,IAAI;AACnB,aAAO,UAAU,GAAG;AACb,aAAA;AAAA,IACT;AAAA;AAAA;AAAA;AAAA,IAKA,IAAI,WAAmB,gBAAsC;AAC3D,iBAAW,kBAAkB,OAAO,KAAK,cAAc,GAAuB;AACtE,cAAA,aAAa,eAAe,cAAc;AAC1C,cAAA,MAAM,aAAa,gBAAgB,SAAS;AAE9C,YAAA,IAAI,KAAK,WAAW,GAAG;AACzB,gBAAM,IAAI,MAAM,cAAc,GAAG,+BAA+B;AAAA,QAClE;AAEA,oBAAY,GAAG,IAAI;AAAA,MACrB;AAEO,aAAA;AAAA,IACT;AAAA;AAAA;AAAA;AAAA,IAKA,OAAO,eAA+B,UAA8B;AAC5D,YAAA,oBAAoB,KAAK,IAAI,aAAa;AAEhD,UAAI,CAAC,mBAAmB;AACtB,cAAM,IAAI,MAAM,cAAc,aAAa,gBAAgB;AAAA,MAC7D;AAEM,YAAA,gBAAgB,SAAS,iBAAiB;AAChD,gBAAU,aAAa,IAAI;AAEpB,aAAA;AAAA,IACT;AAAA,EAAA;AAEJ;"}
1
+ {"version":3,"file":"controllers.mjs","sources":["../../src/registries/controllers.ts"],"sourcesContent":["import { pickBy, has } from 'lodash/fp';\nimport type { Core, UID } from '@strapi/types';\nimport { addNamespace, hasNamespace } from './namespace';\n\nexport type ControllerFactory =\n | ((params: { strapi: Core.Strapi }) => Core.Controller)\n | Core.Controller;\nexport type ControllerFactoryMap = Record<UID.Controller, ControllerFactory>;\nexport type ControllerMap = Record<UID.Controller, Core.Controller>;\nexport type ControllerExtendFn = (service: Core.Controller) => Core.Controller;\n\nconst controllersRegistry = (strapi: Core.Strapi) => {\n const controllers: ControllerFactoryMap = {};\n const instances: ControllerMap = {};\n\n return {\n /**\n * Returns this list of registered controllers uids\n */\n keys() {\n return Object.keys(controllers);\n },\n\n /**\n * Returns the instance of a controller. Instantiate the controller if not already done\n */\n get(uid: UID.Controller) {\n if (instances[uid]) {\n return instances[uid];\n }\n\n const controller = controllers[uid];\n\n if (controller) {\n instances[uid] = typeof controller === 'function' ? controller({ strapi }) : controller;\n return instances[uid];\n }\n },\n\n /**\n * Returns a map with all the controller in a namespace\n */\n getAll(namespace: string) {\n const filteredControllers = pickBy((_, uid) => hasNamespace(uid, namespace))(controllers);\n\n const map = {};\n for (const uid of Object.keys(filteredControllers) as UID.Controller[]) {\n Object.defineProperty(map, uid, {\n enumerable: true,\n get: () => {\n return this.get(uid);\n },\n });\n }\n\n return map;\n },\n\n /**\n * Registers a controller\n */\n set(uid: UID.Controller, value: ControllerFactory) {\n controllers[uid] = value;\n delete instances[uid];\n return this;\n },\n\n /**\n * Registers a map of controllers for a specific namespace\n */\n add(namespace: string, newControllers: ControllerFactoryMap) {\n for (const controllerName of Object.keys(newControllers) as UID.Controller[]) {\n const controller = newControllers[controllerName];\n const uid = addNamespace(controllerName, namespace) as UID.Controller;\n\n if (has(uid, controllers)) {\n throw new Error(`Controller ${uid} has already been registered.`);\n }\n\n controllers[uid] = controller;\n }\n\n return this;\n },\n\n /**\n * Wraps a controller to extend it\n */\n extend(controllerUID: UID.Controller, extendFn: ControllerExtendFn) {\n const currentController = this.get(controllerUID);\n\n if (!currentController) {\n throw new Error(`Controller ${controllerUID} doesn't exist`);\n }\n\n const newController = extendFn(currentController);\n instances[controllerUID] = newController;\n\n return this;\n },\n };\n};\n\nexport default controllersRegistry;\n"],"names":["controllersRegistry","strapi","controllers","instances","keys","Object","get","uid","controller","getAll","namespace","filteredControllers","pickBy","_","hasNamespace","map","defineProperty","enumerable","set","value","add","newControllers","controllerName","addNamespace","has","Error","extend","controllerUID","extendFn","currentController","newController"],"mappings":";;;AAWA,MAAMA,sBAAsB,CAACC,MAAAA,GAAAA;AAC3B,IAAA,MAAMC,cAAoC,EAAC;AAC3C,IAAA,MAAMC,YAA2B,EAAC;IAElC,OAAO;AACL;;QAGAC,IAAAA,CAAAA,GAAAA;YACE,OAAOC,MAAAA,CAAOD,IAAI,CAACF,WAAAA,CAAAA;AACrB,SAAA;AAEA;;AAEC,QACDI,KAAIC,GAAmB,EAAA;YACrB,IAAIJ,SAAS,CAACI,GAAAA,CAAI,EAAE;gBAClB,OAAOJ,SAAS,CAACI,GAAI,CAAA;AACvB;YAEA,MAAMC,UAAAA,GAAaN,WAAW,CAACK,GAAI,CAAA;AAEnC,YAAA,IAAIC,UAAY,EAAA;AACdL,gBAAAA,SAAS,CAACI,GAAI,CAAA,GAAG,OAAOC,UAAAA,KAAe,aAAaA,UAAW,CAAA;AAAEP,oBAAAA;iBAAYO,CAAAA,GAAAA,UAAAA;gBAC7E,OAAOL,SAAS,CAACI,GAAI,CAAA;AACvB;AACF,SAAA;AAEA;;AAEC,QACDE,QAAOC,SAAiB,EAAA;AACtB,YAAA,MAAMC,sBAAsBC,MAAO,CAAA,CAACC,GAAGN,GAAQO,GAAAA,YAAAA,CAAaP,KAAKG,SAAYR,CAAAA,CAAAA,CAAAA,WAAAA,CAAAA;AAE7E,YAAA,MAAMa,MAAM,EAAC;AACb,YAAA,KAAK,MAAMR,GAAAA,IAAOF,MAAOD,CAAAA,IAAI,CAACO,mBAA0C,CAAA,CAAA;gBACtEN,MAAOW,CAAAA,cAAc,CAACD,GAAAA,EAAKR,GAAK,EAAA;oBAC9BU,UAAY,EAAA,IAAA;oBACZX,GAAK,EAAA,IAAA;wBACH,OAAO,IAAI,CAACA,GAAG,CAACC,GAAAA,CAAAA;AAClB;AACF,iBAAA,CAAA;AACF;YAEA,OAAOQ,GAAAA;AACT,SAAA;AAEA;;QAGAG,GAAAA,CAAAA,CAAIX,GAAmB,EAAEY,KAAwB,EAAA;YAC/CjB,WAAW,CAACK,IAAI,GAAGY,KAAAA;YACnB,OAAOhB,SAAS,CAACI,GAAI,CAAA;AACrB,YAAA,OAAO,IAAI;AACb,SAAA;AAEA;;QAGAa,GAAAA,CAAAA,CAAIV,SAAiB,EAAEW,cAAoC,EAAA;AACzD,YAAA,KAAK,MAAMC,cAAAA,IAAkBjB,MAAOD,CAAAA,IAAI,CAACiB,cAAqC,CAAA,CAAA;gBAC5E,MAAMb,UAAAA,GAAaa,cAAc,CAACC,cAAe,CAAA;gBACjD,MAAMf,GAAAA,GAAMgB,aAAaD,cAAgBZ,EAAAA,SAAAA,CAAAA;gBAEzC,IAAIc,GAAAA,CAAIjB,KAAKL,WAAc,CAAA,EAAA;AACzB,oBAAA,MAAM,IAAIuB,KAAM,CAAA,CAAC,WAAW,EAAElB,GAAAA,CAAI,6BAA6B,CAAC,CAAA;AAClE;gBAEAL,WAAW,CAACK,IAAI,GAAGC,UAAAA;AACrB;AAEA,YAAA,OAAO,IAAI;AACb,SAAA;AAEA;;QAGAkB,MAAAA,CAAAA,CAAOC,aAA6B,EAAEC,QAA4B,EAAA;AAChE,YAAA,MAAMC,iBAAoB,GAAA,IAAI,CAACvB,GAAG,CAACqB,aAAAA,CAAAA;AAEnC,YAAA,IAAI,CAACE,iBAAmB,EAAA;AACtB,gBAAA,MAAM,IAAIJ,KAAM,CAAA,CAAC,WAAW,EAAEE,aAAAA,CAAc,cAAc,CAAC,CAAA;AAC7D;AAEA,YAAA,MAAMG,gBAAgBF,QAASC,CAAAA,iBAAAA,CAAAA;YAC/B1B,SAAS,CAACwB,cAAc,GAAGG,aAAAA;AAE3B,YAAA,OAAO,IAAI;AACb;AACF,KAAA;AACF;;;;"}