@strapi/core 0.0.0-experimental.fc1ac2acd58c8a5a858679956b6d102ac5ee4011 → 0.0.0-experimental.fca58d9b01ba89012d84a58a20556a6fd716cb92

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 (1014) hide show
  1. package/LICENSE +18 -3
  2. package/dist/Strapi.d.ts +52 -59
  3. package/dist/Strapi.d.ts.map +1 -1
  4. package/dist/Strapi.js +436 -431
  5. package/dist/Strapi.js.map +1 -1
  6. package/dist/Strapi.mjs +427 -442
  7. package/dist/Strapi.mjs.map +1 -1
  8. package/dist/compile.js +23 -14
  9. package/dist/compile.js.map +1 -1
  10. package/dist/compile.mjs +22 -14
  11. package/dist/compile.mjs.map +1 -1
  12. package/dist/configuration/config-loader.d.ts.map +1 -1
  13. package/dist/configuration/config-loader.js +110 -93
  14. package/dist/configuration/config-loader.js.map +1 -1
  15. package/dist/configuration/config-loader.mjs +109 -92
  16. package/dist/configuration/config-loader.mjs.map +1 -1
  17. package/dist/configuration/get-dirs.d.ts +10 -0
  18. package/dist/configuration/get-dirs.d.ts.map +1 -0
  19. package/dist/configuration/get-dirs.js +33 -0
  20. package/dist/configuration/get-dirs.js.map +1 -0
  21. package/dist/configuration/get-dirs.mjs +31 -0
  22. package/dist/configuration/get-dirs.mjs.map +1 -0
  23. package/dist/configuration/index.d.ts +5 -7
  24. package/dist/configuration/index.d.ts.map +1 -1
  25. package/dist/configuration/index.js +86 -72
  26. package/dist/configuration/index.js.map +1 -1
  27. package/dist/configuration/index.mjs +84 -68
  28. package/dist/configuration/index.mjs.map +1 -1
  29. package/dist/configuration/urls.d.ts.map +1 -1
  30. package/dist/configuration/urls.js +74 -61
  31. package/dist/configuration/urls.js.map +1 -1
  32. package/dist/configuration/urls.mjs +73 -62
  33. package/dist/configuration/urls.mjs.map +1 -1
  34. package/dist/container.d.ts +2 -2
  35. package/dist/container.d.ts.map +1 -1
  36. package/dist/container.js +27 -23
  37. package/dist/container.js.map +1 -1
  38. package/dist/container.mjs +26 -24
  39. package/dist/container.mjs.map +1 -1
  40. package/dist/core-api/controller/collection-type.d.ts +3 -3
  41. package/dist/core-api/controller/collection-type.d.ts.map +1 -1
  42. package/dist/core-api/controller/collection-type.js +77 -73
  43. package/dist/core-api/controller/collection-type.js.map +1 -1
  44. package/dist/core-api/controller/collection-type.mjs +76 -74
  45. package/dist/core-api/controller/collection-type.mjs.map +1 -1
  46. package/dist/core-api/controller/index.d.ts +3 -3
  47. package/dist/core-api/controller/index.d.ts.map +1 -1
  48. package/dist/core-api/controller/index.js +63 -48
  49. package/dist/core-api/controller/index.js.map +1 -1
  50. package/dist/core-api/controller/index.mjs +62 -49
  51. package/dist/core-api/controller/index.mjs.map +1 -1
  52. package/dist/core-api/controller/single-type.d.ts +3 -3
  53. package/dist/core-api/controller/single-type.d.ts.map +1 -1
  54. package/dist/core-api/controller/single-type.js +41 -39
  55. package/dist/core-api/controller/single-type.js.map +1 -1
  56. package/dist/core-api/controller/single-type.mjs +40 -40
  57. package/dist/core-api/controller/single-type.mjs.map +1 -1
  58. package/dist/core-api/controller/transform.d.ts +2 -2
  59. package/dist/core-api/controller/transform.d.ts.map +1 -1
  60. package/dist/core-api/controller/transform.js +72 -66
  61. package/dist/core-api/controller/transform.js.map +1 -1
  62. package/dist/core-api/controller/transform.mjs +71 -67
  63. package/dist/core-api/controller/transform.mjs.map +1 -1
  64. package/dist/core-api/routes/index.d.ts.map +1 -1
  65. package/dist/core-api/routes/index.js +64 -62
  66. package/dist/core-api/routes/index.js.map +1 -1
  67. package/dist/core-api/routes/index.mjs +62 -62
  68. package/dist/core-api/routes/index.mjs.map +1 -1
  69. package/dist/core-api/service/collection-type.d.ts +11 -17
  70. package/dist/core-api/service/collection-type.d.ts.map +1 -1
  71. package/dist/core-api/service/collection-type.js +73 -49
  72. package/dist/core-api/service/collection-type.js.map +1 -1
  73. package/dist/core-api/service/collection-type.mjs +72 -51
  74. package/dist/core-api/service/collection-type.mjs.map +1 -1
  75. package/dist/core-api/service/core-service.js +9 -8
  76. package/dist/core-api/service/core-service.js.map +1 -1
  77. package/dist/core-api/service/core-service.mjs +8 -9
  78. package/dist/core-api/service/core-service.mjs.map +1 -1
  79. package/dist/core-api/service/index.d.ts +3 -3
  80. package/dist/core-api/service/index.d.ts.map +1 -1
  81. package/dist/core-api/service/index.js +13 -13
  82. package/dist/core-api/service/index.js.map +1 -1
  83. package/dist/core-api/service/index.mjs +12 -14
  84. package/dist/core-api/service/index.mjs.map +1 -1
  85. package/dist/core-api/service/pagination.d.ts +4 -11
  86. package/dist/core-api/service/pagination.d.ts.map +1 -1
  87. package/dist/core-api/service/pagination.js +68 -68
  88. package/dist/core-api/service/pagination.js.map +1 -1
  89. package/dist/core-api/service/pagination.mjs +66 -71
  90. package/dist/core-api/service/pagination.mjs.map +1 -1
  91. package/dist/core-api/service/single-type.d.ts +4 -4
  92. package/dist/core-api/service/single-type.d.ts.map +1 -1
  93. package/dist/core-api/service/single-type.js +43 -32
  94. package/dist/core-api/service/single-type.js.map +1 -1
  95. package/dist/core-api/service/single-type.mjs +42 -34
  96. package/dist/core-api/service/single-type.mjs.map +1 -1
  97. package/dist/domain/content-type/index.d.ts +1 -1
  98. package/dist/domain/content-type/index.d.ts.map +1 -1
  99. package/dist/domain/content-type/index.js +95 -100
  100. package/dist/domain/content-type/index.js.map +1 -1
  101. package/dist/domain/content-type/index.mjs +94 -100
  102. package/dist/domain/content-type/index.mjs.map +1 -1
  103. package/dist/domain/content-type/validator.js +84 -69
  104. package/dist/domain/content-type/validator.js.map +1 -1
  105. package/dist/domain/content-type/validator.mjs +83 -68
  106. package/dist/domain/content-type/validator.mjs.map +1 -1
  107. package/dist/domain/module/index.d.ts +24 -23
  108. package/dist/domain/module/index.d.ts.map +1 -1
  109. package/dist/domain/module/index.js +109 -99
  110. package/dist/domain/module/index.js.map +1 -1
  111. package/dist/domain/module/index.mjs +108 -98
  112. package/dist/domain/module/index.mjs.map +1 -1
  113. package/dist/domain/module/validation.js +25 -20
  114. package/dist/domain/module/validation.js.map +1 -1
  115. package/dist/domain/module/validation.mjs +24 -21
  116. package/dist/domain/module/validation.mjs.map +1 -1
  117. package/dist/ee/index.d.ts +5 -2
  118. package/dist/ee/index.d.ts.map +1 -1
  119. package/dist/ee/index.js +171 -132
  120. package/dist/ee/index.js.map +1 -1
  121. package/dist/ee/index.mjs +170 -134
  122. package/dist/ee/index.mjs.map +1 -1
  123. package/dist/ee/license.d.ts +2 -2
  124. package/dist/ee/license.d.ts.map +1 -1
  125. package/dist/ee/license.js +100 -74
  126. package/dist/ee/license.js.map +1 -1
  127. package/dist/ee/license.mjs +99 -75
  128. package/dist/ee/license.mjs.map +1 -1
  129. package/dist/factories.d.ts +10 -10
  130. package/dist/factories.d.ts.map +1 -1
  131. package/dist/factories.js +72 -63
  132. package/dist/factories.js.map +1 -1
  133. package/dist/factories.mjs +71 -67
  134. package/dist/factories.mjs.map +1 -1
  135. package/dist/index.d.ts +18 -2
  136. package/dist/index.d.ts.map +1 -1
  137. package/dist/index.js +32 -5
  138. package/dist/index.js.map +1 -1
  139. package/dist/index.mjs +29 -5
  140. package/dist/index.mjs.map +1 -1
  141. package/dist/loaders/admin.d.ts +2 -2
  142. package/dist/loaders/admin.d.ts.map +1 -1
  143. package/dist/loaders/admin.js +21 -21
  144. package/dist/loaders/admin.js.map +1 -1
  145. package/dist/loaders/admin.mjs +20 -21
  146. package/dist/loaders/admin.mjs.map +1 -1
  147. package/dist/loaders/apis.d.ts +2 -2
  148. package/dist/loaders/apis.d.ts.map +1 -1
  149. package/dist/loaders/apis.js +143 -120
  150. package/dist/loaders/apis.js.map +1 -1
  151. package/dist/loaders/apis.mjs +142 -119
  152. package/dist/loaders/apis.mjs.map +1 -1
  153. package/dist/loaders/components.d.ts +2 -2
  154. package/dist/loaders/components.d.ts.map +1 -1
  155. package/dist/loaders/components.js +33 -34
  156. package/dist/loaders/components.js.map +1 -1
  157. package/dist/loaders/components.mjs +32 -34
  158. package/dist/loaders/components.mjs.map +1 -1
  159. package/dist/loaders/index.d.ts +2 -2
  160. package/dist/loaders/index.d.ts.map +1 -1
  161. package/dist/loaders/index.js +22 -22
  162. package/dist/loaders/index.js.map +1 -1
  163. package/dist/loaders/index.mjs +21 -23
  164. package/dist/loaders/index.mjs.map +1 -1
  165. package/dist/loaders/middlewares.d.ts +2 -2
  166. package/dist/loaders/middlewares.d.ts.map +1 -1
  167. package/dist/loaders/middlewares.js +29 -25
  168. package/dist/loaders/middlewares.js.map +1 -1
  169. package/dist/loaders/middlewares.mjs +28 -25
  170. package/dist/loaders/middlewares.mjs.map +1 -1
  171. package/dist/loaders/plugins/get-enabled-plugins.d.ts +2 -2
  172. package/dist/loaders/plugins/get-enabled-plugins.d.ts.map +1 -1
  173. package/dist/loaders/plugins/get-enabled-plugins.js +125 -100
  174. package/dist/loaders/plugins/get-enabled-plugins.js.map +1 -1
  175. package/dist/loaders/plugins/get-enabled-plugins.mjs +124 -99
  176. package/dist/loaders/plugins/get-enabled-plugins.mjs.map +1 -1
  177. package/dist/loaders/plugins/get-user-plugins-config.js +25 -24
  178. package/dist/loaders/plugins/get-user-plugins-config.js.map +1 -1
  179. package/dist/loaders/plugins/get-user-plugins-config.mjs +24 -23
  180. package/dist/loaders/plugins/get-user-plugins-config.mjs.map +1 -1
  181. package/dist/loaders/plugins/index.d.ts +2 -2
  182. package/dist/loaders/plugins/index.d.ts.map +1 -1
  183. package/dist/loaders/plugins/index.js +141 -104
  184. package/dist/loaders/plugins/index.js.map +1 -1
  185. package/dist/loaders/plugins/index.mjs +121 -104
  186. package/dist/loaders/plugins/index.mjs.map +1 -1
  187. package/dist/loaders/policies.d.ts +2 -2
  188. package/dist/loaders/policies.d.ts.map +1 -1
  189. package/dist/loaders/policies.js +24 -20
  190. package/dist/loaders/policies.js.map +1 -1
  191. package/dist/loaders/policies.mjs +23 -20
  192. package/dist/loaders/policies.mjs.map +1 -1
  193. package/dist/loaders/sanitizers.d.ts +2 -2
  194. package/dist/loaders/sanitizers.d.ts.map +1 -1
  195. package/dist/loaders/sanitizers.js +10 -4
  196. package/dist/loaders/sanitizers.js.map +1 -1
  197. package/dist/loaders/sanitizers.mjs +9 -6
  198. package/dist/loaders/sanitizers.mjs.map +1 -1
  199. package/dist/loaders/src-index.d.ts +2 -2
  200. package/dist/loaders/src-index.d.ts.map +1 -1
  201. package/dist/loaders/src-index.js +35 -27
  202. package/dist/loaders/src-index.js.map +1 -1
  203. package/dist/loaders/src-index.mjs +34 -29
  204. package/dist/loaders/src-index.mjs.map +1 -1
  205. package/dist/loaders/validators.d.ts +2 -2
  206. package/dist/loaders/validators.d.ts.map +1 -1
  207. package/dist/loaders/validators.js +9 -4
  208. package/dist/loaders/validators.js.map +1 -1
  209. package/dist/loaders/validators.mjs +8 -6
  210. package/dist/loaders/validators.mjs.map +1 -1
  211. package/dist/middlewares/body.d.ts +4 -4
  212. package/dist/middlewares/body.d.ts.map +1 -1
  213. package/dist/middlewares/body.js +58 -54
  214. package/dist/middlewares/body.js.map +1 -1
  215. package/dist/middlewares/body.mjs +57 -51
  216. package/dist/middlewares/body.mjs.map +1 -1
  217. package/dist/middlewares/compression.d.ts +2 -2
  218. package/dist/middlewares/compression.d.ts.map +1 -1
  219. package/dist/middlewares/compression.js +6 -6
  220. package/dist/middlewares/compression.js.map +1 -1
  221. package/dist/middlewares/compression.mjs +5 -5
  222. package/dist/middlewares/compression.mjs.map +1 -1
  223. package/dist/middlewares/cors.d.ts +2 -2
  224. package/dist/middlewares/cors.d.ts.map +1 -1
  225. package/dist/middlewares/cors.js +59 -46
  226. package/dist/middlewares/cors.js.map +1 -1
  227. package/dist/middlewares/cors.mjs +58 -45
  228. package/dist/middlewares/cors.mjs.map +1 -1
  229. package/dist/middlewares/errors.d.ts +2 -2
  230. package/dist/middlewares/errors.d.ts.map +1 -1
  231. package/dist/middlewares/errors.js +32 -30
  232. package/dist/middlewares/errors.js.map +1 -1
  233. package/dist/middlewares/errors.mjs +31 -31
  234. package/dist/middlewares/errors.mjs.map +1 -1
  235. package/dist/middlewares/favicon.d.ts +2 -2
  236. package/dist/middlewares/favicon.d.ts.map +1 -1
  237. package/dist/middlewares/favicon.js +27 -17
  238. package/dist/middlewares/favicon.js.map +1 -1
  239. package/dist/middlewares/favicon.mjs +26 -16
  240. package/dist/middlewares/favicon.mjs.map +1 -1
  241. package/dist/middlewares/index.d.ts +2 -2
  242. package/dist/middlewares/index.d.ts.map +1 -1
  243. package/dist/middlewares/index.js +32 -30
  244. package/dist/middlewares/index.js.map +1 -1
  245. package/dist/middlewares/index.mjs +31 -31
  246. package/dist/middlewares/index.mjs.map +1 -1
  247. package/dist/middlewares/ip.d.ts +2 -2
  248. package/dist/middlewares/ip.d.ts.map +1 -1
  249. package/dist/middlewares/ip.js +6 -6
  250. package/dist/middlewares/ip.js.map +1 -1
  251. package/dist/middlewares/ip.mjs +5 -5
  252. package/dist/middlewares/ip.mjs.map +1 -1
  253. package/dist/middlewares/logger.d.ts +2 -2
  254. package/dist/middlewares/logger.d.ts.map +1 -1
  255. package/dist/middlewares/logger.js +10 -9
  256. package/dist/middlewares/logger.js.map +1 -1
  257. package/dist/middlewares/logger.mjs +9 -10
  258. package/dist/middlewares/logger.mjs.map +1 -1
  259. package/dist/middlewares/powered-by.d.ts +2 -2
  260. package/dist/middlewares/powered-by.d.ts.map +1 -1
  261. package/dist/middlewares/powered-by.js +13 -9
  262. package/dist/middlewares/powered-by.js.map +1 -1
  263. package/dist/middlewares/powered-by.mjs +12 -10
  264. package/dist/middlewares/powered-by.mjs.map +1 -1
  265. package/dist/middlewares/public.d.ts +2 -2
  266. package/dist/middlewares/public.d.ts.map +1 -1
  267. package/dist/middlewares/public.js +33 -29
  268. package/dist/middlewares/public.js.map +1 -1
  269. package/dist/middlewares/public.mjs +32 -28
  270. package/dist/middlewares/public.mjs.map +1 -1
  271. package/dist/middlewares/query.d.ts +2 -2
  272. package/dist/middlewares/query.d.ts.map +1 -1
  273. package/dist/middlewares/query.js +35 -32
  274. package/dist/middlewares/query.js.map +1 -1
  275. package/dist/middlewares/query.mjs +34 -31
  276. package/dist/middlewares/query.mjs.map +1 -1
  277. package/dist/middlewares/response-time.d.ts +2 -2
  278. package/dist/middlewares/response-time.d.ts.map +1 -1
  279. package/dist/middlewares/response-time.js +10 -9
  280. package/dist/middlewares/response-time.js.map +1 -1
  281. package/dist/middlewares/response-time.mjs +9 -10
  282. package/dist/middlewares/response-time.mjs.map +1 -1
  283. package/dist/middlewares/responses.d.ts +3 -3
  284. package/dist/middlewares/responses.d.ts.map +1 -1
  285. package/dist/middlewares/responses.js +14 -12
  286. package/dist/middlewares/responses.js.map +1 -1
  287. package/dist/middlewares/responses.mjs +13 -13
  288. package/dist/middlewares/responses.mjs.map +1 -1
  289. package/dist/middlewares/security.d.ts +2 -2
  290. package/dist/middlewares/security.d.ts.map +1 -1
  291. package/dist/middlewares/security.js +110 -65
  292. package/dist/middlewares/security.js.map +1 -1
  293. package/dist/middlewares/security.mjs +108 -63
  294. package/dist/middlewares/security.mjs.map +1 -1
  295. package/dist/middlewares/session.d.ts +2 -2
  296. package/dist/middlewares/session.d.ts.map +1 -1
  297. package/dist/middlewares/session.js +26 -25
  298. package/dist/middlewares/session.js.map +1 -1
  299. package/dist/middlewares/session.mjs +25 -24
  300. package/dist/middlewares/session.mjs.map +1 -1
  301. package/dist/migrations/database/5.0.0-discard-drafts.d.ts +33 -0
  302. package/dist/migrations/database/5.0.0-discard-drafts.d.ts.map +1 -0
  303. package/dist/migrations/database/5.0.0-discard-drafts.js +168 -0
  304. package/dist/migrations/database/5.0.0-discard-drafts.js.map +1 -0
  305. package/dist/migrations/database/5.0.0-discard-drafts.mjs +165 -0
  306. package/dist/migrations/database/5.0.0-discard-drafts.mjs.map +1 -0
  307. package/dist/migrations/draft-publish.d.ts +2 -2
  308. package/dist/migrations/draft-publish.d.ts.map +1 -1
  309. package/dist/migrations/draft-publish.js +59 -49
  310. package/dist/migrations/draft-publish.js.map +1 -1
  311. package/dist/migrations/draft-publish.mjs +58 -51
  312. package/dist/migrations/draft-publish.mjs.map +1 -1
  313. package/dist/migrations/i18n.d.ts +5 -0
  314. package/dist/migrations/i18n.d.ts.map +1 -0
  315. package/dist/migrations/i18n.js +71 -0
  316. package/dist/migrations/i18n.js.map +1 -0
  317. package/dist/migrations/i18n.mjs +68 -0
  318. package/dist/migrations/i18n.mjs.map +1 -0
  319. package/dist/migrations/index.d.ts +5 -0
  320. package/dist/migrations/index.d.ts.map +1 -0
  321. package/dist/migrations/index.js +29 -0
  322. package/dist/migrations/index.js.map +1 -0
  323. package/dist/migrations/index.mjs +26 -0
  324. package/dist/migrations/index.mjs.map +1 -0
  325. package/dist/package.json.js +182 -0
  326. package/dist/package.json.js.map +1 -0
  327. package/dist/package.json.mjs +159 -0
  328. package/dist/package.json.mjs.map +1 -0
  329. package/dist/providers/admin.d.ts +3 -0
  330. package/dist/providers/admin.d.ts.map +1 -0
  331. package/dist/providers/admin.js +30 -0
  332. package/dist/providers/admin.js.map +1 -0
  333. package/dist/providers/admin.mjs +28 -0
  334. package/dist/providers/admin.mjs.map +1 -0
  335. package/dist/providers/coreStore.d.ts +3 -0
  336. package/dist/providers/coreStore.d.ts.map +1 -0
  337. package/dist/providers/coreStore.js +16 -0
  338. package/dist/providers/coreStore.js.map +1 -0
  339. package/dist/providers/coreStore.mjs +14 -0
  340. package/dist/providers/coreStore.mjs.map +1 -0
  341. package/dist/providers/cron.d.ts +3 -0
  342. package/dist/providers/cron.d.ts.map +1 -0
  343. package/dist/providers/cron.js +23 -0
  344. package/dist/providers/cron.js.map +1 -0
  345. package/dist/providers/cron.mjs +21 -0
  346. package/dist/providers/cron.mjs.map +1 -0
  347. package/dist/providers/index.d.ts +3 -0
  348. package/dist/providers/index.d.ts.map +1 -0
  349. package/dist/providers/index.js +20 -0
  350. package/dist/providers/index.js.map +1 -0
  351. package/dist/providers/index.mjs +18 -0
  352. package/dist/providers/index.mjs.map +1 -0
  353. package/dist/providers/provider.d.ts +9 -0
  354. package/dist/providers/provider.d.ts.map +1 -0
  355. package/dist/providers/provider.js +6 -0
  356. package/dist/providers/provider.js.map +1 -0
  357. package/dist/providers/provider.mjs +4 -0
  358. package/dist/providers/provider.mjs.map +1 -0
  359. package/dist/providers/registries.d.ts +3 -0
  360. package/dist/providers/registries.d.ts.map +1 -0
  361. package/dist/providers/registries.js +40 -0
  362. package/dist/providers/registries.js.map +1 -0
  363. package/dist/providers/registries.mjs +38 -0
  364. package/dist/providers/registries.mjs.map +1 -0
  365. package/dist/providers/telemetry.d.ts +3 -0
  366. package/dist/providers/telemetry.d.ts.map +1 -0
  367. package/dist/providers/telemetry.js +22 -0
  368. package/dist/providers/telemetry.js.map +1 -0
  369. package/dist/providers/telemetry.mjs +20 -0
  370. package/dist/providers/telemetry.mjs.map +1 -0
  371. package/dist/providers/webhooks.d.ts +3 -0
  372. package/dist/providers/webhooks.d.ts.map +1 -0
  373. package/dist/providers/webhooks.js +32 -0
  374. package/dist/providers/webhooks.js.map +1 -0
  375. package/dist/providers/webhooks.mjs +30 -0
  376. package/dist/providers/webhooks.mjs.map +1 -0
  377. package/dist/registries/apis.d.ts +2 -2
  378. package/dist/registries/apis.d.ts.map +1 -1
  379. package/dist/registries/apis.js +23 -20
  380. package/dist/registries/apis.js.map +1 -1
  381. package/dist/registries/apis.mjs +22 -22
  382. package/dist/registries/apis.mjs.map +1 -1
  383. package/dist/registries/components.d.ts +6 -6
  384. package/dist/registries/components.d.ts.map +1 -1
  385. package/dist/registries/components.js +35 -37
  386. package/dist/registries/components.js.map +1 -1
  387. package/dist/registries/components.mjs +34 -39
  388. package/dist/registries/components.mjs.map +1 -1
  389. package/dist/registries/content-types.d.ts +5 -5
  390. package/dist/registries/content-types.d.ts.map +1 -1
  391. package/dist/registries/content-types.js +54 -59
  392. package/dist/registries/content-types.js.map +1 -1
  393. package/dist/registries/content-types.mjs +53 -61
  394. package/dist/registries/content-types.mjs.map +1 -1
  395. package/dist/registries/controllers.d.ts +10 -10
  396. package/dist/registries/controllers.d.ts.map +1 -1
  397. package/dist/registries/controllers.js +70 -71
  398. package/dist/registries/controllers.js.map +1 -1
  399. package/dist/registries/controllers.mjs +69 -73
  400. package/dist/registries/controllers.mjs.map +1 -1
  401. package/dist/registries/custom-fields.d.ts +3 -3
  402. package/dist/registries/custom-fields.d.ts.map +1 -1
  403. package/dist/registries/custom-fields.js +75 -65
  404. package/dist/registries/custom-fields.js.map +1 -1
  405. package/dist/registries/custom-fields.mjs +74 -67
  406. package/dist/registries/custom-fields.mjs.map +1 -1
  407. package/dist/registries/hooks.js +46 -49
  408. package/dist/registries/hooks.js.map +1 -1
  409. package/dist/registries/hooks.mjs +45 -51
  410. package/dist/registries/hooks.mjs.map +1 -1
  411. package/dist/registries/index.d.ts +0 -1
  412. package/dist/registries/index.d.ts.map +1 -1
  413. package/dist/registries/middlewares.d.ts +6 -6
  414. package/dist/registries/middlewares.d.ts.map +1 -1
  415. package/dist/registries/middlewares.js +49 -51
  416. package/dist/registries/middlewares.js.map +1 -1
  417. package/dist/registries/middlewares.mjs +48 -53
  418. package/dist/registries/middlewares.mjs.map +1 -1
  419. package/dist/registries/models.js +14 -13
  420. package/dist/registries/models.js.map +1 -1
  421. package/dist/registries/models.mjs +13 -14
  422. package/dist/registries/models.mjs.map +1 -1
  423. package/dist/registries/modules.d.ts +2 -2
  424. package/dist/registries/modules.d.ts.map +1 -1
  425. package/dist/registries/modules.js +39 -36
  426. package/dist/registries/modules.js.map +1 -1
  427. package/dist/registries/modules.mjs +38 -38
  428. package/dist/registries/modules.mjs.map +1 -1
  429. package/dist/registries/namespace.js +21 -20
  430. package/dist/registries/namespace.js.map +1 -1
  431. package/dist/registries/namespace.mjs +20 -23
  432. package/dist/registries/namespace.mjs.map +1 -1
  433. package/dist/registries/plugins.d.ts +5 -5
  434. package/dist/registries/plugins.d.ts.map +1 -1
  435. package/dist/registries/plugins.js +23 -20
  436. package/dist/registries/plugins.js.map +1 -1
  437. package/dist/registries/plugins.mjs +22 -22
  438. package/dist/registries/plugins.mjs.map +1 -1
  439. package/dist/registries/policies.d.ts +22 -10
  440. package/dist/registries/policies.d.ts.map +1 -1
  441. package/dist/registries/policies.js +107 -54
  442. package/dist/registries/policies.js.map +1 -1
  443. package/dist/registries/policies.mjs +106 -56
  444. package/dist/registries/policies.mjs.map +1 -1
  445. package/dist/registries/sanitizers.js +23 -22
  446. package/dist/registries/sanitizers.js.map +1 -1
  447. package/dist/registries/sanitizers.mjs +22 -22
  448. package/dist/registries/sanitizers.mjs.map +1 -1
  449. package/dist/registries/services.d.ts +8 -8
  450. package/dist/registries/services.d.ts.map +1 -1
  451. package/dist/registries/services.js +71 -71
  452. package/dist/registries/services.js.map +1 -1
  453. package/dist/registries/services.mjs +70 -73
  454. package/dist/registries/services.mjs.map +1 -1
  455. package/dist/registries/validators.js +23 -22
  456. package/dist/registries/validators.js.map +1 -1
  457. package/dist/registries/validators.mjs +22 -22
  458. package/dist/registries/validators.mjs.map +1 -1
  459. package/dist/services/auth/index.d.ts +4 -4
  460. package/dist/services/auth/index.d.ts.map +1 -1
  461. package/dist/services/auth/index.js +74 -74
  462. package/dist/services/auth/index.js.map +1 -1
  463. package/dist/services/auth/index.mjs +73 -74
  464. package/dist/services/auth/index.mjs.map +1 -1
  465. package/dist/services/config.d.ts +3 -0
  466. package/dist/services/config.d.ts.map +1 -0
  467. package/dist/services/config.js +51 -0
  468. package/dist/services/config.js.map +1 -0
  469. package/dist/services/config.mjs +49 -0
  470. package/dist/services/config.mjs.map +1 -0
  471. package/dist/services/content-api/index.d.ts +31 -15
  472. package/dist/services/content-api/index.d.ts.map +1 -1
  473. package/dist/services/content-api/index.js +80 -53
  474. package/dist/services/content-api/index.js.map +1 -1
  475. package/dist/services/content-api/index.mjs +79 -53
  476. package/dist/services/content-api/index.mjs.map +1 -1
  477. package/dist/services/content-api/permissions/engine.js +8 -5
  478. package/dist/services/content-api/permissions/engine.js.map +1 -1
  479. package/dist/services/content-api/permissions/engine.mjs +7 -5
  480. package/dist/services/content-api/permissions/engine.mjs.map +1 -1
  481. package/dist/services/content-api/permissions/index.d.ts +13 -15
  482. package/dist/services/content-api/permissions/index.d.ts.map +1 -1
  483. package/dist/services/content-api/permissions/index.js +101 -81
  484. package/dist/services/content-api/permissions/index.js.map +1 -1
  485. package/dist/services/content-api/permissions/index.mjs +100 -81
  486. package/dist/services/content-api/permissions/index.mjs.map +1 -1
  487. package/dist/services/content-api/permissions/providers/action.d.ts +5 -6
  488. package/dist/services/content-api/permissions/providers/action.d.ts.map +1 -1
  489. package/dist/services/content-api/permissions/providers/action.js +17 -14
  490. package/dist/services/content-api/permissions/providers/action.js.map +1 -1
  491. package/dist/services/content-api/permissions/providers/action.mjs +16 -16
  492. package/dist/services/content-api/permissions/providers/action.mjs.map +1 -1
  493. package/dist/services/content-api/permissions/providers/condition.d.ts +5 -6
  494. package/dist/services/content-api/permissions/providers/condition.d.ts.map +1 -1
  495. package/dist/services/content-api/permissions/providers/condition.js +17 -14
  496. package/dist/services/content-api/permissions/providers/condition.js.map +1 -1
  497. package/dist/services/content-api/permissions/providers/condition.mjs +16 -16
  498. package/dist/services/content-api/permissions/providers/condition.mjs.map +1 -1
  499. package/dist/services/core-store.d.ts.map +1 -1
  500. package/dist/services/core-store.js +115 -95
  501. package/dist/services/core-store.js.map +1 -1
  502. package/dist/services/core-store.mjs +114 -97
  503. package/dist/services/core-store.mjs.map +1 -1
  504. package/dist/services/cron.d.ts +5 -5
  505. package/dist/services/cron.d.ts.map +1 -1
  506. package/dist/services/cron.js +74 -60
  507. package/dist/services/cron.js.map +1 -1
  508. package/dist/services/cron.mjs +73 -62
  509. package/dist/services/cron.mjs.map +1 -1
  510. package/dist/services/custom-fields.d.ts +2 -2
  511. package/dist/services/custom-fields.d.ts.map +1 -1
  512. package/dist/services/custom-fields.js +9 -7
  513. package/dist/services/custom-fields.js.map +1 -1
  514. package/dist/services/custom-fields.mjs +8 -9
  515. package/dist/services/custom-fields.mjs.map +1 -1
  516. package/dist/services/document-service/attributes/index.d.ts +6 -0
  517. package/dist/services/document-service/attributes/index.d.ts.map +1 -0
  518. package/dist/services/document-service/attributes/index.js +27 -0
  519. package/dist/services/document-service/attributes/index.js.map +1 -0
  520. package/dist/services/document-service/attributes/index.mjs +25 -0
  521. package/dist/services/document-service/attributes/index.mjs.map +1 -0
  522. package/dist/services/document-service/attributes/transforms.d.ts +10 -0
  523. package/dist/services/document-service/attributes/transforms.d.ts.map +1 -0
  524. package/dist/services/document-service/attributes/transforms.js +21 -0
  525. package/dist/services/document-service/attributes/transforms.js.map +1 -0
  526. package/dist/services/document-service/attributes/transforms.mjs +19 -0
  527. package/dist/services/document-service/attributes/transforms.mjs.map +1 -0
  528. package/dist/services/document-service/common.d.ts +2 -2
  529. package/dist/services/document-service/common.d.ts.map +1 -1
  530. package/dist/services/document-service/common.js +5 -4
  531. package/dist/services/document-service/common.js.map +1 -1
  532. package/dist/services/document-service/common.mjs +4 -5
  533. package/dist/services/document-service/common.mjs.map +1 -1
  534. package/dist/services/document-service/components.d.ts +25 -1
  535. package/dist/services/document-service/components.d.ts.map +1 -1
  536. package/dist/services/document-service/components.js +286 -0
  537. package/dist/services/document-service/components.js.map +1 -0
  538. package/dist/services/document-service/components.mjs +278 -0
  539. package/dist/services/document-service/components.mjs.map +1 -0
  540. package/dist/services/document-service/draft-and-publish.d.ts +7 -7
  541. package/dist/services/document-service/draft-and-publish.d.ts.map +1 -1
  542. package/dist/services/document-service/draft-and-publish.js +94 -54
  543. package/dist/services/document-service/draft-and-publish.js.map +1 -1
  544. package/dist/services/document-service/draft-and-publish.mjs +87 -54
  545. package/dist/services/document-service/draft-and-publish.mjs.map +1 -1
  546. package/dist/services/document-service/entries.d.ts +10 -0
  547. package/dist/services/document-service/entries.d.ts.map +1 -0
  548. package/dist/services/document-service/entries.js +113 -0
  549. package/dist/services/document-service/entries.js.map +1 -0
  550. package/dist/services/document-service/entries.mjs +111 -0
  551. package/dist/services/document-service/entries.mjs.map +1 -0
  552. package/dist/services/document-service/events.d.ts +25 -0
  553. package/dist/services/document-service/events.d.ts.map +1 -0
  554. package/dist/services/document-service/events.js +59 -0
  555. package/dist/services/document-service/events.js.map +1 -0
  556. package/dist/services/document-service/events.mjs +57 -0
  557. package/dist/services/document-service/events.mjs.map +1 -0
  558. package/dist/services/document-service/index.d.ts +3 -4
  559. package/dist/services/document-service/index.d.ts.map +1 -1
  560. package/dist/services/document-service/index.js +53 -19
  561. package/dist/services/document-service/index.js.map +1 -1
  562. package/dist/services/document-service/index.mjs +52 -20
  563. package/dist/services/document-service/index.mjs.map +1 -1
  564. package/dist/services/document-service/internationalization.d.ts +5 -5
  565. package/dist/services/document-service/internationalization.d.ts.map +1 -1
  566. package/dist/services/document-service/internationalization.js +66 -41
  567. package/dist/services/document-service/internationalization.js.map +1 -1
  568. package/dist/services/document-service/internationalization.mjs +61 -41
  569. package/dist/services/document-service/internationalization.mjs.map +1 -1
  570. package/dist/services/document-service/middlewares/errors.d.ts +6 -0
  571. package/dist/services/document-service/middlewares/errors.d.ts.map +1 -0
  572. package/dist/services/document-service/middlewares/errors.js +29 -0
  573. package/dist/services/document-service/middlewares/errors.js.map +1 -0
  574. package/dist/services/document-service/middlewares/errors.mjs +27 -0
  575. package/dist/services/document-service/middlewares/errors.mjs.map +1 -0
  576. package/dist/services/document-service/middlewares/index.d.ts +3 -0
  577. package/dist/services/document-service/middlewares/index.d.ts.map +1 -0
  578. package/dist/services/document-service/middlewares/middleware-manager.d.ts +10 -0
  579. package/dist/services/document-service/middlewares/middleware-manager.d.ts.map +1 -0
  580. package/dist/services/document-service/middlewares/middleware-manager.js +51 -0
  581. package/dist/services/document-service/middlewares/middleware-manager.js.map +1 -0
  582. package/dist/services/document-service/middlewares/middleware-manager.mjs +49 -0
  583. package/dist/services/document-service/middlewares/middleware-manager.mjs.map +1 -0
  584. package/dist/services/document-service/params.d.ts +3 -1
  585. package/dist/services/document-service/params.d.ts.map +1 -1
  586. package/dist/services/document-service/params.js +14 -0
  587. package/dist/services/document-service/params.js.map +1 -0
  588. package/dist/services/document-service/params.mjs +12 -0
  589. package/dist/services/document-service/params.mjs.map +1 -0
  590. package/dist/services/document-service/repository.d.ts.map +1 -1
  591. package/dist/services/document-service/repository.js +353 -293
  592. package/dist/services/document-service/repository.js.map +1 -1
  593. package/dist/services/document-service/repository.mjs +352 -294
  594. package/dist/services/document-service/repository.mjs.map +1 -1
  595. package/dist/services/document-service/transform/data.d.ts.map +1 -1
  596. package/dist/services/document-service/transform/data.js +22 -10
  597. package/dist/services/document-service/transform/data.js.map +1 -1
  598. package/dist/services/document-service/transform/data.mjs +21 -11
  599. package/dist/services/document-service/transform/data.mjs.map +1 -1
  600. package/dist/services/document-service/transform/fields.d.ts +2 -2
  601. package/dist/services/document-service/transform/fields.d.ts.map +1 -1
  602. package/dist/services/document-service/transform/fields.js +26 -17
  603. package/dist/services/document-service/transform/fields.js.map +1 -1
  604. package/dist/services/document-service/transform/fields.mjs +25 -18
  605. package/dist/services/document-service/transform/fields.mjs.map +1 -1
  606. package/dist/services/document-service/transform/id-map.d.ts +3 -3
  607. package/dist/services/document-service/transform/id-map.d.ts.map +1 -1
  608. package/dist/services/document-service/transform/id-map.js +116 -69
  609. package/dist/services/document-service/transform/id-map.js.map +1 -1
  610. package/dist/services/document-service/transform/id-map.mjs +115 -70
  611. package/dist/services/document-service/transform/id-map.mjs.map +1 -1
  612. package/dist/services/document-service/transform/id-transform.d.ts +2 -2
  613. package/dist/services/document-service/transform/id-transform.d.ts.map +1 -1
  614. package/dist/services/document-service/transform/id-transform.js +38 -30
  615. package/dist/services/document-service/transform/id-transform.js.map +1 -1
  616. package/dist/services/document-service/transform/id-transform.mjs +36 -30
  617. package/dist/services/document-service/transform/id-transform.mjs.map +1 -1
  618. package/dist/services/document-service/transform/populate.d.ts +2 -2
  619. package/dist/services/document-service/transform/populate.d.ts.map +1 -1
  620. package/dist/services/document-service/transform/populate.js +23 -18
  621. package/dist/services/document-service/transform/populate.js.map +1 -1
  622. package/dist/services/document-service/transform/populate.mjs +22 -19
  623. package/dist/services/document-service/transform/populate.mjs.map +1 -1
  624. package/dist/services/document-service/transform/query.d.ts +5 -0
  625. package/dist/services/document-service/transform/query.d.ts.map +1 -0
  626. package/dist/services/document-service/transform/query.js +14 -0
  627. package/dist/services/document-service/transform/query.js.map +1 -0
  628. package/dist/services/document-service/transform/query.mjs +12 -0
  629. package/dist/services/document-service/transform/query.mjs.map +1 -0
  630. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts +8 -7
  631. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts.map +1 -1
  632. package/dist/services/document-service/transform/relations/extract/data-ids.js +75 -85
  633. package/dist/services/document-service/transform/relations/extract/data-ids.js.map +1 -1
  634. package/dist/services/document-service/transform/relations/extract/data-ids.mjs +74 -86
  635. package/dist/services/document-service/transform/relations/extract/data-ids.mjs.map +1 -1
  636. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts +8 -4
  637. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts.map +1 -1
  638. package/dist/services/document-service/transform/relations/transform/data-ids.js +103 -134
  639. package/dist/services/document-service/transform/relations/transform/data-ids.js.map +1 -1
  640. package/dist/services/document-service/transform/relations/transform/data-ids.mjs +102 -135
  641. package/dist/services/document-service/transform/relations/transform/data-ids.mjs.map +1 -1
  642. package/dist/services/document-service/transform/relations/transform/default-locale.d.ts +9 -0
  643. package/dist/services/document-service/transform/relations/transform/default-locale.d.ts.map +1 -0
  644. package/dist/services/document-service/transform/relations/transform/default-locale.js +50 -0
  645. package/dist/services/document-service/transform/relations/transform/default-locale.js.map +1 -0
  646. package/dist/services/document-service/transform/relations/transform/default-locale.mjs +48 -0
  647. package/dist/services/document-service/transform/relations/transform/default-locale.mjs.map +1 -0
  648. package/dist/services/document-service/transform/relations/utils/dp.d.ts +3 -3
  649. package/dist/services/document-service/transform/relations/utils/dp.d.ts.map +1 -1
  650. package/dist/services/document-service/transform/relations/utils/dp.js +53 -22
  651. package/dist/services/document-service/transform/relations/utils/dp.js.map +1 -1
  652. package/dist/services/document-service/transform/relations/utils/dp.mjs +52 -23
  653. package/dist/services/document-service/transform/relations/utils/dp.mjs.map +1 -1
  654. package/dist/services/document-service/transform/relations/utils/i18n.d.ts +6 -6
  655. package/dist/services/document-service/transform/relations/utils/i18n.d.ts.map +1 -1
  656. package/dist/services/document-service/transform/relations/utils/i18n.js +19 -23
  657. package/dist/services/document-service/transform/relations/utils/i18n.js.map +1 -1
  658. package/dist/services/document-service/transform/relations/utils/i18n.mjs +18 -26
  659. package/dist/services/document-service/transform/relations/utils/i18n.mjs.map +1 -1
  660. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts +6 -0
  661. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts.map +1 -0
  662. package/dist/services/document-service/transform/relations/utils/map-relation.js +130 -0
  663. package/dist/services/document-service/transform/relations/utils/map-relation.js.map +1 -0
  664. package/dist/services/document-service/transform/relations/utils/map-relation.mjs +127 -0
  665. package/dist/services/document-service/transform/relations/utils/map-relation.mjs.map +1 -0
  666. package/dist/services/document-service/transform/relations/utils/types.d.ts +6 -0
  667. package/dist/services/document-service/transform/relations/utils/types.d.ts.map +1 -1
  668. package/dist/services/document-service/transform/types.d.ts +3 -3
  669. package/dist/services/document-service/transform/types.d.ts.map +1 -1
  670. package/dist/services/document-service/utils/bidirectional-relations.d.ts +95 -0
  671. package/dist/services/document-service/utils/bidirectional-relations.d.ts.map +1 -0
  672. package/dist/services/document-service/utils/bidirectional-relations.js +148 -0
  673. package/dist/services/document-service/utils/bidirectional-relations.js.map +1 -0
  674. package/dist/services/document-service/utils/bidirectional-relations.mjs +145 -0
  675. package/dist/services/document-service/utils/bidirectional-relations.mjs.map +1 -0
  676. package/dist/services/document-service/utils/populate.d.ts +9 -2
  677. package/dist/services/document-service/utils/populate.d.ts.map +1 -1
  678. package/dist/services/document-service/utils/populate.js +67 -37
  679. package/dist/services/document-service/utils/populate.js.map +1 -1
  680. package/dist/services/document-service/utils/populate.mjs +66 -38
  681. package/dist/services/document-service/utils/populate.mjs.map +1 -1
  682. package/dist/services/document-service/utils/unidirectional-relations.d.ts +36 -0
  683. package/dist/services/document-service/utils/unidirectional-relations.d.ts.map +1 -0
  684. package/dist/services/document-service/utils/unidirectional-relations.js +116 -0
  685. package/dist/services/document-service/utils/unidirectional-relations.js.map +1 -0
  686. package/dist/services/document-service/utils/unidirectional-relations.mjs +113 -0
  687. package/dist/services/document-service/utils/unidirectional-relations.mjs.map +1 -0
  688. package/dist/services/entity-service/index.d.ts +4 -6
  689. package/dist/services/entity-service/index.d.ts.map +1 -1
  690. package/dist/services/entity-service/index.js +229 -319
  691. package/dist/services/entity-service/index.js.map +1 -1
  692. package/dist/services/entity-service/index.mjs +228 -318
  693. package/dist/services/entity-service/index.mjs.map +1 -1
  694. package/dist/services/entity-validator/blocks-validator.d.ts +1 -2
  695. package/dist/services/entity-validator/blocks-validator.d.ts.map +1 -1
  696. package/dist/services/entity-validator/blocks-validator.js +137 -104
  697. package/dist/services/entity-validator/blocks-validator.js.map +1 -1
  698. package/dist/services/entity-validator/blocks-validator.mjs +135 -105
  699. package/dist/services/entity-validator/blocks-validator.mjs.map +1 -1
  700. package/dist/services/entity-validator/index.d.ts +16 -2
  701. package/dist/services/entity-validator/index.d.ts.map +1 -1
  702. package/dist/services/entity-validator/index.js +362 -300
  703. package/dist/services/entity-validator/index.js.map +1 -1
  704. package/dist/services/entity-validator/index.mjs +358 -297
  705. package/dist/services/entity-validator/index.mjs.map +1 -1
  706. package/dist/services/entity-validator/validators.d.ts +36 -25
  707. package/dist/services/entity-validator/validators.d.ts.map +1 -1
  708. package/dist/services/entity-validator/validators.js +283 -105
  709. package/dist/services/entity-validator/validators.js.map +1 -1
  710. package/dist/services/entity-validator/validators.mjs +274 -103
  711. package/dist/services/entity-validator/validators.mjs.map +1 -1
  712. package/dist/services/errors.js +65 -65
  713. package/dist/services/errors.js.map +1 -1
  714. package/dist/services/errors.mjs +64 -66
  715. package/dist/services/errors.mjs.map +1 -1
  716. package/dist/services/event-hub.d.ts +1 -0
  717. package/dist/services/event-hub.d.ts.map +1 -1
  718. package/dist/services/event-hub.js +82 -64
  719. package/dist/services/event-hub.js.map +1 -1
  720. package/dist/services/event-hub.mjs +81 -66
  721. package/dist/services/event-hub.mjs.map +1 -1
  722. package/dist/services/features.d.ts +3 -3
  723. package/dist/services/features.d.ts.map +1 -1
  724. package/dist/services/features.js +19 -14
  725. package/dist/services/features.js.map +1 -1
  726. package/dist/services/features.mjs +18 -15
  727. package/dist/services/features.mjs.map +1 -1
  728. package/dist/services/fs.d.ts +2 -2
  729. package/dist/services/fs.d.ts.map +1 -1
  730. package/dist/services/fs.js +41 -40
  731. package/dist/services/fs.js.map +1 -1
  732. package/dist/services/fs.mjs +40 -39
  733. package/dist/services/fs.mjs.map +1 -1
  734. package/dist/services/metrics/admin-user-hash.d.ts +2 -2
  735. package/dist/services/metrics/admin-user-hash.d.ts.map +1 -1
  736. package/dist/services/metrics/admin-user-hash.js +13 -11
  737. package/dist/services/metrics/admin-user-hash.js.map +1 -1
  738. package/dist/services/metrics/admin-user-hash.mjs +12 -10
  739. package/dist/services/metrics/admin-user-hash.mjs.map +1 -1
  740. package/dist/services/metrics/index.d.ts +2 -2
  741. package/dist/services/metrics/index.d.ts.map +1 -1
  742. package/dist/services/metrics/index.js +46 -40
  743. package/dist/services/metrics/index.js.map +1 -1
  744. package/dist/services/metrics/index.mjs +45 -42
  745. package/dist/services/metrics/index.mjs.map +1 -1
  746. package/dist/services/metrics/is-truthy.js +13 -6
  747. package/dist/services/metrics/is-truthy.js.map +1 -1
  748. package/dist/services/metrics/is-truthy.mjs +12 -6
  749. package/dist/services/metrics/is-truthy.mjs.map +1 -1
  750. package/dist/services/metrics/middleware.d.ts +2 -2
  751. package/dist/services/metrics/middleware.d.ts.map +1 -1
  752. package/dist/services/metrics/middleware.js +37 -22
  753. package/dist/services/metrics/middleware.js.map +1 -1
  754. package/dist/services/metrics/middleware.mjs +36 -24
  755. package/dist/services/metrics/middleware.mjs.map +1 -1
  756. package/dist/services/metrics/rate-limiter.d.ts.map +1 -1
  757. package/dist/services/metrics/rate-limiter.js +24 -19
  758. package/dist/services/metrics/rate-limiter.js.map +1 -1
  759. package/dist/services/metrics/rate-limiter.mjs +23 -21
  760. package/dist/services/metrics/rate-limiter.mjs.map +1 -1
  761. package/dist/services/metrics/sender.d.ts +3 -3
  762. package/dist/services/metrics/sender.d.ts.map +1 -1
  763. package/dist/services/metrics/sender.js +78 -69
  764. package/dist/services/metrics/sender.js.map +1 -1
  765. package/dist/services/metrics/sender.mjs +77 -64
  766. package/dist/services/metrics/sender.mjs.map +1 -1
  767. package/dist/services/query-params.d.ts +7 -0
  768. package/dist/services/query-params.d.ts.map +1 -0
  769. package/dist/services/query-params.js +15 -0
  770. package/dist/services/query-params.js.map +1 -0
  771. package/dist/services/query-params.mjs +13 -0
  772. package/dist/services/query-params.mjs.map +1 -0
  773. package/dist/services/reloader.d.ts +7 -0
  774. package/dist/services/reloader.d.ts.map +1 -0
  775. package/dist/services/reloader.js +39 -0
  776. package/dist/services/reloader.js.map +1 -0
  777. package/dist/services/reloader.mjs +37 -0
  778. package/dist/services/reloader.mjs.map +1 -0
  779. package/dist/services/request-context.js +11 -8
  780. package/dist/services/request-context.js.map +1 -1
  781. package/dist/services/request-context.mjs +10 -10
  782. package/dist/services/request-context.mjs.map +1 -1
  783. package/dist/services/server/admin-api.d.ts +3 -3
  784. package/dist/services/server/admin-api.d.ts.map +1 -1
  785. package/dist/services/server/admin-api.js +11 -10
  786. package/dist/services/server/admin-api.js.map +1 -1
  787. package/dist/services/server/admin-api.mjs +10 -11
  788. package/dist/services/server/admin-api.mjs.map +1 -1
  789. package/dist/services/server/api.d.ts +3 -3
  790. package/dist/services/server/api.d.ts.map +1 -1
  791. package/dist/services/server/api.js +33 -27
  792. package/dist/services/server/api.js.map +1 -1
  793. package/dist/services/server/api.mjs +32 -26
  794. package/dist/services/server/api.mjs.map +1 -1
  795. package/dist/services/server/compose-endpoint.d.ts +2 -2
  796. package/dist/services/server/compose-endpoint.d.ts.map +1 -1
  797. package/dist/services/server/compose-endpoint.js +116 -106
  798. package/dist/services/server/compose-endpoint.js.map +1 -1
  799. package/dist/services/server/compose-endpoint.mjs +115 -106
  800. package/dist/services/server/compose-endpoint.mjs.map +1 -1
  801. package/dist/services/server/content-api.d.ts +3 -3
  802. package/dist/services/server/content-api.d.ts.map +1 -1
  803. package/dist/services/server/content-api.js +11 -9
  804. package/dist/services/server/content-api.js.map +1 -1
  805. package/dist/services/server/content-api.mjs +10 -10
  806. package/dist/services/server/content-api.mjs.map +1 -1
  807. package/dist/services/server/http-server.d.ts +2 -2
  808. package/dist/services/server/http-server.d.ts.map +1 -1
  809. package/dist/services/server/http-server.js +48 -44
  810. package/dist/services/server/http-server.js.map +1 -1
  811. package/dist/services/server/http-server.mjs +47 -43
  812. package/dist/services/server/http-server.mjs.map +1 -1
  813. package/dist/services/server/index.d.ts +2 -2
  814. package/dist/services/server/index.d.ts.map +1 -1
  815. package/dist/services/server/index.js +85 -83
  816. package/dist/services/server/index.js.map +1 -1
  817. package/dist/services/server/index.mjs +84 -82
  818. package/dist/services/server/index.mjs.map +1 -1
  819. package/dist/services/server/koa.d.ts.map +1 -1
  820. package/dist/services/server/koa.js +49 -47
  821. package/dist/services/server/koa.js.map +1 -1
  822. package/dist/services/server/koa.mjs +48 -44
  823. package/dist/services/server/koa.mjs.map +1 -1
  824. package/dist/services/server/middleware.d.ts +4 -4
  825. package/dist/services/server/middleware.d.ts.map +1 -1
  826. package/dist/services/server/middleware.js +86 -82
  827. package/dist/services/server/middleware.js.map +1 -1
  828. package/dist/services/server/middleware.mjs +85 -82
  829. package/dist/services/server/middleware.mjs.map +1 -1
  830. package/dist/services/server/policy.d.ts +3 -3
  831. package/dist/services/server/policy.d.ts.map +1 -1
  832. package/dist/services/server/policy.js +25 -18
  833. package/dist/services/server/policy.js.map +1 -1
  834. package/dist/services/server/policy.mjs +23 -18
  835. package/dist/services/server/policy.mjs.map +1 -1
  836. package/dist/services/server/register-middlewares.d.ts +2 -2
  837. package/dist/services/server/register-middlewares.d.ts.map +1 -1
  838. package/dist/services/server/register-middlewares.js +68 -61
  839. package/dist/services/server/register-middlewares.js.map +1 -1
  840. package/dist/services/server/register-middlewares.mjs +67 -63
  841. package/dist/services/server/register-middlewares.mjs.map +1 -1
  842. package/dist/services/server/register-routes.d.ts +2 -2
  843. package/dist/services/server/register-routes.d.ts.map +1 -1
  844. package/dist/services/server/register-routes.js +90 -67
  845. package/dist/services/server/register-routes.js.map +1 -1
  846. package/dist/services/server/register-routes.mjs +89 -67
  847. package/dist/services/server/register-routes.mjs.map +1 -1
  848. package/dist/services/server/routing.d.ts +5 -5
  849. package/dist/services/server/routing.d.ts.map +1 -1
  850. package/dist/services/server/routing.js +94 -81
  851. package/dist/services/server/routing.js.map +1 -1
  852. package/dist/services/server/routing.mjs +93 -81
  853. package/dist/services/server/routing.mjs.map +1 -1
  854. package/dist/services/utils/dynamic-zones.d.ts.map +1 -1
  855. package/dist/services/utils/dynamic-zones.js +13 -13
  856. package/dist/services/utils/dynamic-zones.js.map +1 -1
  857. package/dist/services/utils/dynamic-zones.mjs +12 -15
  858. package/dist/services/utils/dynamic-zones.mjs.map +1 -1
  859. package/dist/services/webhook-runner.d.ts +2 -1
  860. package/dist/services/webhook-runner.d.ts.map +1 -1
  861. package/dist/services/webhook-runner.js +124 -122
  862. package/dist/services/webhook-runner.js.map +1 -1
  863. package/dist/services/webhook-runner.mjs +123 -121
  864. package/dist/services/webhook-runner.mjs.map +1 -1
  865. package/dist/services/webhook-store.d.ts +2 -8
  866. package/dist/services/webhook-store.d.ts.map +1 -1
  867. package/dist/services/webhook-store.js +132 -93
  868. package/dist/services/webhook-store.js.map +1 -1
  869. package/dist/services/webhook-store.mjs +131 -95
  870. package/dist/services/webhook-store.mjs.map +1 -1
  871. package/dist/services/worker-queue.js +44 -49
  872. package/dist/services/worker-queue.js.map +1 -1
  873. package/dist/services/worker-queue.mjs +43 -49
  874. package/dist/services/worker-queue.mjs.map +1 -1
  875. package/dist/utils/convert-custom-field-type.d.ts +2 -2
  876. package/dist/utils/convert-custom-field-type.d.ts.map +1 -1
  877. package/dist/utils/convert-custom-field-type.js +17 -20
  878. package/dist/utils/convert-custom-field-type.js.map +1 -1
  879. package/dist/utils/convert-custom-field-type.mjs +16 -21
  880. package/dist/utils/convert-custom-field-type.mjs.map +1 -1
  881. package/dist/utils/cron.js +64 -30
  882. package/dist/utils/cron.js.map +1 -1
  883. package/dist/utils/cron.mjs +63 -31
  884. package/dist/utils/cron.mjs.map +1 -1
  885. package/dist/utils/fetch.d.ts +3 -3
  886. package/dist/utils/fetch.d.ts.map +1 -1
  887. package/dist/utils/fetch.js +24 -17
  888. package/dist/utils/fetch.js.map +1 -1
  889. package/dist/utils/fetch.mjs +23 -18
  890. package/dist/utils/fetch.mjs.map +1 -1
  891. package/dist/utils/filepath-to-prop-path.d.ts +1 -1
  892. package/dist/utils/filepath-to-prop-path.d.ts.map +1 -1
  893. package/dist/utils/filepath-to-prop-path.js +22 -9
  894. package/dist/utils/filepath-to-prop-path.js.map +1 -1
  895. package/dist/utils/filepath-to-prop-path.mjs +20 -7
  896. package/dist/utils/filepath-to-prop-path.mjs.map +1 -1
  897. package/dist/utils/index.d.ts +2 -1
  898. package/dist/utils/index.d.ts.map +1 -1
  899. package/dist/utils/is-initialized.d.ts +2 -2
  900. package/dist/utils/is-initialized.d.ts.map +1 -1
  901. package/dist/utils/is-initialized.js +21 -12
  902. package/dist/utils/is-initialized.js.map +1 -1
  903. package/dist/utils/is-initialized.mjs +20 -13
  904. package/dist/utils/is-initialized.mjs.map +1 -1
  905. package/dist/utils/lifecycles.js +6 -5
  906. package/dist/utils/lifecycles.js.map +1 -1
  907. package/dist/utils/lifecycles.mjs +5 -6
  908. package/dist/utils/lifecycles.mjs.map +1 -1
  909. package/dist/utils/load-config-file.js +40 -38
  910. package/dist/utils/load-config-file.js.map +1 -1
  911. package/dist/utils/load-config-file.mjs +39 -36
  912. package/dist/utils/load-config-file.mjs.map +1 -1
  913. package/dist/utils/load-files.d.ts.map +1 -1
  914. package/dist/utils/load-files.js +40 -35
  915. package/dist/utils/load-files.js.map +1 -1
  916. package/dist/utils/load-files.mjs +39 -32
  917. package/dist/utils/load-files.mjs.map +1 -1
  918. package/dist/utils/open-browser.d.ts +2 -2
  919. package/dist/utils/open-browser.d.ts.map +1 -1
  920. package/dist/utils/open-browser.js +8 -8
  921. package/dist/utils/open-browser.js.map +1 -1
  922. package/dist/utils/open-browser.mjs +7 -7
  923. package/dist/utils/open-browser.mjs.map +1 -1
  924. package/dist/utils/resolve-working-dirs.d.ts +19 -0
  925. package/dist/utils/resolve-working-dirs.d.ts.map +1 -0
  926. package/dist/utils/resolve-working-dirs.js +26 -0
  927. package/dist/utils/resolve-working-dirs.js.map +1 -0
  928. package/dist/utils/resolve-working-dirs.mjs +24 -0
  929. package/dist/utils/resolve-working-dirs.mjs.map +1 -0
  930. package/dist/utils/signals.d.ts +2 -2
  931. package/dist/utils/signals.d.ts.map +1 -1
  932. package/dist/utils/signals.js +20 -14
  933. package/dist/utils/signals.js.map +1 -1
  934. package/dist/utils/signals.mjs +19 -15
  935. package/dist/utils/signals.mjs.map +1 -1
  936. package/dist/utils/startup-logger.d.ts +2 -2
  937. package/dist/utils/startup-logger.d.ts.map +1 -1
  938. package/dist/utils/startup-logger.js +107 -78
  939. package/dist/utils/startup-logger.js.map +1 -1
  940. package/dist/utils/startup-logger.mjs +106 -75
  941. package/dist/utils/startup-logger.mjs.map +1 -1
  942. package/dist/utils/transform-content-types-to-models.d.ts +377 -90
  943. package/dist/utils/transform-content-types-to-models.d.ts.map +1 -1
  944. package/dist/utils/transform-content-types-to-models.js +357 -217
  945. package/dist/utils/transform-content-types-to-models.js.map +1 -1
  946. package/dist/utils/transform-content-types-to-models.mjs +351 -220
  947. package/dist/utils/transform-content-types-to-models.mjs.map +1 -1
  948. package/dist/utils/update-notifier/index.d.ts +2 -7
  949. package/dist/utils/update-notifier/index.d.ts.map +1 -1
  950. package/dist/utils/update-notifier/index.js +66 -74
  951. package/dist/utils/update-notifier/index.js.map +1 -1
  952. package/dist/utils/update-notifier/index.mjs +65 -68
  953. package/dist/utils/update-notifier/index.mjs.map +1 -1
  954. package/package.json +43 -40
  955. package/dist/registries/config.d.ts +0 -4
  956. package/dist/registries/config.d.ts.map +0 -1
  957. package/dist/registries/config.js +0 -31
  958. package/dist/registries/config.js.map +0 -1
  959. package/dist/registries/config.mjs +0 -32
  960. package/dist/registries/config.mjs.map +0 -1
  961. package/dist/services/document-service/middlewares.d.ts +0 -8
  962. package/dist/services/document-service/middlewares.d.ts.map +0 -1
  963. package/dist/services/document-service/middlewares.js +0 -46
  964. package/dist/services/document-service/middlewares.js.map +0 -1
  965. package/dist/services/document-service/middlewares.mjs +0 -46
  966. package/dist/services/document-service/middlewares.mjs.map +0 -1
  967. package/dist/services/document-service/transform/filters.d.ts +0 -3
  968. package/dist/services/document-service/transform/filters.d.ts.map +0 -1
  969. package/dist/services/document-service/transform/relations/transform/output-ids.d.ts +0 -4
  970. package/dist/services/document-service/transform/relations/transform/output-ids.d.ts.map +0 -1
  971. package/dist/services/document-service/transform/relations/utils/data.js +0 -12
  972. package/dist/services/document-service/transform/relations/utils/data.js.map +0 -1
  973. package/dist/services/document-service/transform/relations/utils/data.mjs +0 -12
  974. package/dist/services/document-service/transform/relations/utils/data.mjs.map +0 -1
  975. package/dist/services/document-service/transform/sort.d.ts +0 -5
  976. package/dist/services/document-service/transform/sort.d.ts.map +0 -1
  977. package/dist/services/document-service/transform/utils.d.ts +0 -9
  978. package/dist/services/document-service/transform/utils.d.ts.map +0 -1
  979. package/dist/services/entity-service/attributes/index.d.ts +0 -6
  980. package/dist/services/entity-service/attributes/index.d.ts.map +0 -1
  981. package/dist/services/entity-service/attributes/index.js +0 -22
  982. package/dist/services/entity-service/attributes/index.js.map +0 -1
  983. package/dist/services/entity-service/attributes/index.mjs +0 -22
  984. package/dist/services/entity-service/attributes/index.mjs.map +0 -1
  985. package/dist/services/entity-service/attributes/transforms.d.ts +0 -10
  986. package/dist/services/entity-service/attributes/transforms.d.ts.map +0 -1
  987. package/dist/services/entity-service/attributes/transforms.js +0 -20
  988. package/dist/services/entity-service/attributes/transforms.js.map +0 -1
  989. package/dist/services/entity-service/attributes/transforms.mjs +0 -19
  990. package/dist/services/entity-service/attributes/transforms.mjs.map +0 -1
  991. package/dist/services/entity-service/components.d.ts +0 -23
  992. package/dist/services/entity-service/components.d.ts.map +0 -1
  993. package/dist/services/entity-service/components.js +0 -384
  994. package/dist/services/entity-service/components.js.map +0 -1
  995. package/dist/services/entity-service/components.mjs +0 -382
  996. package/dist/services/entity-service/components.mjs.map +0 -1
  997. package/dist/services/entity-service/params.d.ts +0 -8
  998. package/dist/services/entity-service/params.d.ts.map +0 -1
  999. package/dist/services/entity-service/params.js +0 -8
  1000. package/dist/services/entity-service/params.js.map +0 -1
  1001. package/dist/services/entity-service/params.mjs +0 -8
  1002. package/dist/services/entity-service/params.mjs.map +0 -1
  1003. package/dist/services/utils/upload-files.d.ts +0 -8
  1004. package/dist/services/utils/upload-files.d.ts.map +0 -1
  1005. package/dist/services/utils/upload-files.js +0 -64
  1006. package/dist/services/utils/upload-files.js.map +0 -1
  1007. package/dist/services/utils/upload-files.mjs +0 -63
  1008. package/dist/services/utils/upload-files.mjs.map +0 -1
  1009. package/dist/utils/get-dirs.d.ts +0 -9
  1010. package/dist/utils/get-dirs.d.ts.map +0 -1
  1011. package/dist/utils/get-dirs.js +0 -30
  1012. package/dist/utils/get-dirs.js.map +0 -1
  1013. package/dist/utils/get-dirs.mjs +0 -30
  1014. package/dist/utils/get-dirs.mjs.map +0 -1
@@ -1,23 +1,26 @@
1
- "use strict";
2
- const _ = require("lodash/fp");
3
- const pluginsRegistry = (strapi) => {
4
- const plugins = {};
5
- return {
6
- get(name) {
7
- return plugins[name];
8
- },
9
- getAll() {
10
- return plugins;
11
- },
12
- add(name, pluginConfig) {
13
- if (_.has(name, plugins)) {
14
- throw new Error(`Plugin ${name} has already been registered.`);
15
- }
16
- const pluginModule = strapi.get("modules").add(`plugin::${name}`, pluginConfig);
17
- plugins[name] = pluginModule;
18
- return plugins[name];
19
- }
20
- };
1
+ 'use strict';
2
+
3
+ var fp = require('lodash/fp');
4
+
5
+ const pluginsRegistry = (strapi)=>{
6
+ const plugins = {};
7
+ return {
8
+ get (name) {
9
+ return plugins[name];
10
+ },
11
+ getAll () {
12
+ return plugins;
13
+ },
14
+ add (name, pluginConfig) {
15
+ if (fp.has(name, plugins)) {
16
+ throw new Error(`Plugin ${name} has already been registered.`);
17
+ }
18
+ const pluginModule = strapi.get('modules').add(`plugin::${name}`, pluginConfig);
19
+ plugins[name] = pluginModule;
20
+ return plugins[name];
21
+ }
22
+ };
21
23
  };
24
+
22
25
  module.exports = pluginsRegistry;
23
26
  //# sourceMappingURL=plugins.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"plugins.js","sources":["../../src/registries/plugins.ts"],"sourcesContent":["import { has } from 'lodash/fp';\n\nimport type { Strapi, Common } from '@strapi/types';\n\ntype PluginMap = Record<string, Common.Plugin>;\n\nconst pluginsRegistry = (strapi: Strapi) => {\n const plugins: PluginMap = {};\n\n return {\n get(name: string) {\n return plugins[name];\n },\n getAll() {\n return plugins;\n },\n add(name: string, pluginConfig: Common.Plugin) {\n if (has(name, plugins)) {\n throw new Error(`Plugin ${name} has already been registered.`);\n }\n\n const pluginModule = strapi.get('modules').add(`plugin::${name}`, pluginConfig);\n plugins[name] = pluginModule;\n\n return plugins[name];\n },\n };\n};\n\nexport default pluginsRegistry;\n"],"names":["has"],"mappings":";;AAMM,MAAA,kBAAkB,CAAC,WAAmB;AAC1C,QAAM,UAAqB,CAAA;AAEpB,SAAA;AAAA,IACL,IAAI,MAAc;AAChB,aAAO,QAAQ,IAAI;AAAA,IACrB;AAAA,IACA,SAAS;AACA,aAAA;AAAA,IACT;AAAA,IACA,IAAI,MAAc,cAA6B;AACzC,UAAAA,EAAA,IAAI,MAAM,OAAO,GAAG;AACtB,cAAM,IAAI,MAAM,UAAU,IAAI,+BAA+B;AAAA,MAC/D;AAEM,YAAA,eAAe,OAAO,IAAI,SAAS,EAAE,IAAI,WAAW,IAAI,IAAI,YAAY;AAC9E,cAAQ,IAAI,IAAI;AAEhB,aAAO,QAAQ,IAAI;AAAA,IACrB;AAAA,EAAA;AAEJ;;"}
1
+ {"version":3,"file":"plugins.js","sources":["../../src/registries/plugins.ts"],"sourcesContent":["import { has } from 'lodash/fp';\n\nimport type { Core } from '@strapi/types';\n\ntype PluginMap = Record<string, Core.Plugin>;\n\nconst pluginsRegistry = (strapi: Core.Strapi) => {\n const plugins: PluginMap = {};\n\n return {\n get(name: string) {\n return plugins[name];\n },\n getAll() {\n return plugins;\n },\n add(name: string, pluginConfig: Core.Plugin) {\n if (has(name, plugins)) {\n throw new Error(`Plugin ${name} has already been registered.`);\n }\n\n const pluginModule = strapi.get('modules').add(`plugin::${name}`, pluginConfig);\n plugins[name] = pluginModule;\n\n return plugins[name];\n },\n };\n};\n\nexport default pluginsRegistry;\n"],"names":["pluginsRegistry","strapi","plugins","get","name","getAll","add","pluginConfig","has","Error","pluginModule"],"mappings":";;;;AAMA,MAAMA,kBAAkB,CAACC,MAAAA,GAAAA;AACvB,IAAA,MAAMC,UAAqB,EAAC;IAE5B,OAAO;AACLC,QAAAA,GAAAA,CAAAA,CAAIC,IAAY,EAAA;YACd,OAAOF,OAAO,CAACE,IAAK,CAAA;AACtB,SAAA;AACAC,QAAAA,MAAAA,CAAAA,GAAAA;YACE,OAAOH,OAAAA;AACT,SAAA;QACAI,GAAIF,CAAAA,CAAAA,IAAY,EAAEG,YAAyB,EAAA;YACzC,IAAIC,MAAAA,CAAIJ,MAAMF,OAAU,CAAA,EAAA;AACtB,gBAAA,MAAM,IAAIO,KAAM,CAAA,CAAC,OAAO,EAAEL,IAAAA,CAAK,6BAA6B,CAAC,CAAA;AAC/D;AAEA,YAAA,MAAMM,YAAeT,GAAAA,MAAAA,CAAOE,GAAG,CAAC,SAAWG,CAAAA,CAAAA,GAAG,CAAC,CAAC,QAAQ,EAAEF,IAAK,CAAA,CAAC,EAAEG,YAAAA,CAAAA;YAClEL,OAAO,CAACE,KAAK,GAAGM,YAAAA;YAEhB,OAAOR,OAAO,CAACE,IAAK,CAAA;AACtB;AACF,KAAA;AACF;;;;"}
@@ -1,24 +1,24 @@
1
- import { has } from "lodash/fp";
2
- const pluginsRegistry = (strapi) => {
3
- const plugins = {};
4
- return {
5
- get(name) {
6
- return plugins[name];
7
- },
8
- getAll() {
9
- return plugins;
10
- },
11
- add(name, pluginConfig) {
12
- if (has(name, plugins)) {
13
- throw new Error(`Plugin ${name} has already been registered.`);
14
- }
15
- const pluginModule = strapi.get("modules").add(`plugin::${name}`, pluginConfig);
16
- plugins[name] = pluginModule;
17
- return plugins[name];
18
- }
19
- };
20
- };
21
- export {
22
- pluginsRegistry as default
1
+ import { has } from 'lodash/fp';
2
+
3
+ const pluginsRegistry = (strapi)=>{
4
+ const plugins = {};
5
+ return {
6
+ get (name) {
7
+ return plugins[name];
8
+ },
9
+ getAll () {
10
+ return plugins;
11
+ },
12
+ add (name, pluginConfig) {
13
+ if (has(name, plugins)) {
14
+ throw new Error(`Plugin ${name} has already been registered.`);
15
+ }
16
+ const pluginModule = strapi.get('modules').add(`plugin::${name}`, pluginConfig);
17
+ plugins[name] = pluginModule;
18
+ return plugins[name];
19
+ }
20
+ };
23
21
  };
22
+
23
+ export { pluginsRegistry as default };
24
24
  //# sourceMappingURL=plugins.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"plugins.mjs","sources":["../../src/registries/plugins.ts"],"sourcesContent":["import { has } from 'lodash/fp';\n\nimport type { Strapi, Common } from '@strapi/types';\n\ntype PluginMap = Record<string, Common.Plugin>;\n\nconst pluginsRegistry = (strapi: Strapi) => {\n const plugins: PluginMap = {};\n\n return {\n get(name: string) {\n return plugins[name];\n },\n getAll() {\n return plugins;\n },\n add(name: string, pluginConfig: Common.Plugin) {\n if (has(name, plugins)) {\n throw new Error(`Plugin ${name} has already been registered.`);\n }\n\n const pluginModule = strapi.get('modules').add(`plugin::${name}`, pluginConfig);\n plugins[name] = pluginModule;\n\n return plugins[name];\n },\n };\n};\n\nexport default pluginsRegistry;\n"],"names":[],"mappings":";AAMM,MAAA,kBAAkB,CAAC,WAAmB;AAC1C,QAAM,UAAqB,CAAA;AAEpB,SAAA;AAAA,IACL,IAAI,MAAc;AAChB,aAAO,QAAQ,IAAI;AAAA,IACrB;AAAA,IACA,SAAS;AACA,aAAA;AAAA,IACT;AAAA,IACA,IAAI,MAAc,cAA6B;AACzC,UAAA,IAAI,MAAM,OAAO,GAAG;AACtB,cAAM,IAAI,MAAM,UAAU,IAAI,+BAA+B;AAAA,MAC/D;AAEM,YAAA,eAAe,OAAO,IAAI,SAAS,EAAE,IAAI,WAAW,IAAI,IAAI,YAAY;AAC9E,cAAQ,IAAI,IAAI;AAEhB,aAAO,QAAQ,IAAI;AAAA,IACrB;AAAA,EAAA;AAEJ;"}
1
+ {"version":3,"file":"plugins.mjs","sources":["../../src/registries/plugins.ts"],"sourcesContent":["import { has } from 'lodash/fp';\n\nimport type { Core } from '@strapi/types';\n\ntype PluginMap = Record<string, Core.Plugin>;\n\nconst pluginsRegistry = (strapi: Core.Strapi) => {\n const plugins: PluginMap = {};\n\n return {\n get(name: string) {\n return plugins[name];\n },\n getAll() {\n return plugins;\n },\n add(name: string, pluginConfig: Core.Plugin) {\n if (has(name, plugins)) {\n throw new Error(`Plugin ${name} has already been registered.`);\n }\n\n const pluginModule = strapi.get('modules').add(`plugin::${name}`, pluginConfig);\n plugins[name] = pluginModule;\n\n return plugins[name];\n },\n };\n};\n\nexport default pluginsRegistry;\n"],"names":["pluginsRegistry","strapi","plugins","get","name","getAll","add","pluginConfig","has","Error","pluginModule"],"mappings":";;AAMA,MAAMA,kBAAkB,CAACC,MAAAA,GAAAA;AACvB,IAAA,MAAMC,UAAqB,EAAC;IAE5B,OAAO;AACLC,QAAAA,GAAAA,CAAAA,CAAIC,IAAY,EAAA;YACd,OAAOF,OAAO,CAACE,IAAK,CAAA;AACtB,SAAA;AACAC,QAAAA,MAAAA,CAAAA,GAAAA;YACE,OAAOH,OAAAA;AACT,SAAA;QACAI,GAAIF,CAAAA,CAAAA,IAAY,EAAEG,YAAyB,EAAA;YACzC,IAAIC,GAAAA,CAAIJ,MAAMF,OAAU,CAAA,EAAA;AACtB,gBAAA,MAAM,IAAIO,KAAM,CAAA,CAAC,OAAO,EAAEL,IAAAA,CAAK,6BAA6B,CAAC,CAAA;AAC/D;AAEA,YAAA,MAAMM,YAAeT,GAAAA,MAAAA,CAAOE,GAAG,CAAC,SAAWG,CAAAA,CAAAA,GAAG,CAAC,CAAC,QAAQ,EAAEF,IAAK,CAAA,CAAC,EAAEG,YAAAA,CAAAA;YAClEL,OAAO,CAACE,KAAK,GAAGM,YAAAA;YAEhB,OAAOR,OAAO,CAACE,IAAK,CAAA;AACtB;AACF,KAAA;AACF;;;;"}
@@ -1,7 +1,14 @@
1
1
  /// <reference types="lodash" />
2
- import type { Common } from '@strapi/types';
3
- type PolicyExtendFn = (policy: Common.Policy) => Common.Policy;
4
- type PolicyMap = Record<string, Common.Policy>;
2
+ import type { Core } from '@strapi/types';
3
+ interface PolicyInfo {
4
+ name: string;
5
+ config: unknown;
6
+ }
7
+ type PolicyConfig = string | PolicyInfo;
8
+ interface NamespaceInfo {
9
+ pluginName?: string;
10
+ apiName?: string;
11
+ }
5
12
  declare const policiesRegistry: () => {
6
13
  /**
7
14
  * Returns this list of registered policies uids
@@ -10,7 +17,11 @@ declare const policiesRegistry: () => {
10
17
  /**
11
18
  * Returns the instance of a policy. Instantiate the policy if not already done
12
19
  */
13
- get(uid: Common.UID.Policy): Common.Policy<unknown>;
20
+ get(name: string, namespaceInfo?: NamespaceInfo): Core.Policy<unknown> | undefined;
21
+ /**
22
+ * Checks if a policy is registered
23
+ */
24
+ has(name: string, namespaceInfo?: NamespaceInfo): boolean;
14
25
  /**
15
26
  * Returns a map with all the policies in a namespace
16
27
  */
@@ -18,17 +29,18 @@ declare const policiesRegistry: () => {
18
29
  /**
19
30
  * Registers a policy
20
31
  */
21
- set(uid: string, policy: Common.Policy): any;
32
+ set(uid: string, policy: Core.Policy): any;
22
33
  /**
23
34
  * Registers a map of policies for a specific namespace
24
35
  */
25
- add(namespace: string, newPolicies: PolicyMap): void;
36
+ add(namespace: string, newPolicies: Record<string, Core.Policy>): void;
26
37
  /**
27
- * Wraps a policy to extend it
28
- * @param {string} uid
29
- * @param {(policy: Policy) => Policy} extendFn
38
+ * Resolves a list of policies
30
39
  */
31
- extend(uid: Common.UID.Policy, extendFn: PolicyExtendFn): any;
40
+ resolve(config: PolicyConfig | PolicyConfig[], namespaceInfo?: NamespaceInfo): {
41
+ handler: Core.Policy<unknown>;
42
+ config: {};
43
+ }[];
32
44
  };
33
45
  export default policiesRegistry;
34
46
  //# sourceMappingURL=policies.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"policies.d.ts","sourceRoot":"","sources":["../../src/registries/policies.ts"],"names":[],"mappings":";AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAG5C,KAAK,cAAc,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,KAAK,MAAM,CAAC,MAAM,CAAC;AAC/D,KAAK,SAAS,GAAG,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC;AAG/C,QAAA,MAAM,gBAAgB;IAIlB;;OAEG;;IAKH;;OAEG;aACM,OAAO,GAAG,CAAC,MAAM;IAI1B;;OAEG;sBACe,MAAM;IAIxB;;OAEG;aACM,MAAM,UAAU,OAAO,MAAM;IAKtC;;OAEG;mBACY,MAAM,eAAe,SAAS;IAY7C;;;;OAIG;gBACS,OAAO,GAAG,CAAC,MAAM,YAAY,cAAc;CAa1D,CAAC;AAEF,eAAe,gBAAgB,CAAC"}
1
+ {"version":3,"file":"policies.d.ts","sourceRoot":"","sources":["../../src/registries/policies.ts"],"names":[],"mappings":";AACA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAM1C,UAAU,UAAU;IAClB,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,OAAO,CAAC;CACjB;AAED,KAAK,YAAY,GAAG,MAAM,GAAG,UAAU,CAAC;AAExC,UAAU,aAAa;IACrB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB;AAWD,QAAA,MAAM,gBAAgB;IAyDlB;;OAEG;;IAMH;;OAEG;cACO,MAAM,kBAAkB,aAAa;IAG/C;;OAEG;cACO,MAAM,kBAAkB,aAAa;IAK/C;;OAEG;sBACe,MAAM;IAIxB;;OAEG;aACM,MAAM,UAAU,KAAK,MAAM;IAKpC;;OAEG;mBACY,MAAM,eAAe,OAAO,MAAM,EAAE,KAAK,MAAM,CAAC;IAa/D;;OAEG;oBACa,YAAY,GAAG,YAAY,EAAE,kBAAkB,aAAa;;;;CAW/E,CAAC;AAEF,eAAe,gBAAgB,CAAC"}
@@ -1,62 +1,115 @@
1
- "use strict";
2
- const _ = require("lodash/fp");
3
- const namespace = require("./namespace.js");
4
- const policiesRegistry = () => {
5
- const policies = {};
6
- return {
7
- /**
1
+ 'use strict';
2
+
3
+ var fp = require('lodash/fp');
4
+ var namespace = require('./namespace.js');
5
+
6
+ const PLUGIN_PREFIX = 'plugin::';
7
+ const API_PREFIX = 'api::';
8
+ const parsePolicy = (policy)=>{
9
+ if (typeof policy === 'string') {
10
+ return {
11
+ policyName: policy,
12
+ config: {}
13
+ };
14
+ }
15
+ const { name, config } = policy;
16
+ return {
17
+ policyName: name,
18
+ config
19
+ };
20
+ };
21
+ const policiesRegistry = ()=>{
22
+ const policies = new Map();
23
+ const find = (name, namespaceInfo)=>{
24
+ const { pluginName, apiName } = namespaceInfo ?? {};
25
+ // try to resolve a full name to avoid extra prefixing
26
+ const policy = policies.get(name);
27
+ if (policy) {
28
+ return policy;
29
+ }
30
+ if (pluginName) {
31
+ return policies.get(`${PLUGIN_PREFIX}${pluginName}.${name}`);
32
+ }
33
+ if (apiName) {
34
+ return policies.get(`${API_PREFIX}${apiName}.${name}`);
35
+ }
36
+ };
37
+ function resolveHandler(policyConfig, namespaceInfo) {
38
+ if (Array.isArray(policyConfig)) {
39
+ return policyConfig.map((config)=>{
40
+ return resolveHandler(config, namespaceInfo);
41
+ });
42
+ }
43
+ const { policyName, config } = parsePolicy(policyConfig);
44
+ const policy = find(policyName, namespaceInfo);
45
+ if (!policy) {
46
+ throw new Error(`Policy ${policyName} not found.`);
47
+ }
48
+ if (typeof policy === 'function') {
49
+ return policy;
50
+ }
51
+ if (policy.validator) {
52
+ policy.validator(config);
53
+ }
54
+ return policy.handler;
55
+ }
56
+ return {
57
+ /**
8
58
  * Returns this list of registered policies uids
9
- */
10
- keys() {
11
- return Object.keys(policies);
12
- },
13
- /**
59
+ */ keys () {
60
+ // Return an array so format stays the same as controllers, services, etc
61
+ return Array.from(policies.keys());
62
+ },
63
+ /**
14
64
  * Returns the instance of a policy. Instantiate the policy if not already done
15
- */
16
- get(uid) {
17
- return policies[uid];
18
- },
19
- /**
65
+ */ get (name, namespaceInfo) {
66
+ return find(name, namespaceInfo);
67
+ },
68
+ /**
69
+ * Checks if a policy is registered
70
+ */ has (name, namespaceInfo) {
71
+ const res = find(name, namespaceInfo);
72
+ return !!res;
73
+ },
74
+ /**
20
75
  * Returns a map with all the policies in a namespace
21
- */
22
- getAll(namespace$1) {
23
- return _.pickBy((_2, uid) => namespace.hasNamespace(uid, namespace$1))(policies);
24
- },
25
- /**
76
+ */ getAll (namespace$1) {
77
+ return fp.pickBy((_, uid)=>namespace.hasNamespace(uid, namespace$1))(Object.fromEntries(policies));
78
+ },
79
+ /**
26
80
  * Registers a policy
27
- */
28
- set(uid, policy) {
29
- policies[uid] = policy;
30
- return this;
31
- },
32
- /**
81
+ */ set (uid, policy) {
82
+ policies.set(uid, policy);
83
+ return this;
84
+ },
85
+ /**
33
86
  * Registers a map of policies for a specific namespace
34
- */
35
- add(namespace$1, newPolicies) {
36
- for (const policyName of Object.keys(newPolicies)) {
37
- const policy = newPolicies[policyName];
38
- const uid = namespace.addNamespace(policyName, namespace$1);
39
- if (_.has(uid, policies)) {
40
- throw new Error(`Policy ${uid} has already been registered.`);
41
- }
42
- policies[uid] = policy;
43
- }
44
- },
45
- /**
46
- * Wraps a policy to extend it
47
- * @param {string} uid
48
- * @param {(policy: Policy) => Policy} extendFn
49
- */
50
- extend(uid, extendFn) {
51
- const currentPolicy = this.get(uid);
52
- if (!currentPolicy) {
53
- throw new Error(`Policy ${uid} doesn't exist`);
54
- }
55
- const newPolicy = extendFn(currentPolicy);
56
- policies[uid] = newPolicy;
57
- return this;
58
- }
59
- };
87
+ */ add (namespace$1, newPolicies) {
88
+ for (const policyName of Object.keys(newPolicies)){
89
+ const policy = newPolicies[policyName];
90
+ const uid = namespace.addNamespace(policyName, namespace$1);
91
+ if (fp.has(uid, policies)) {
92
+ throw new Error(`Policy ${uid} has already been registered.`);
93
+ }
94
+ policies.set(uid, policy);
95
+ }
96
+ },
97
+ /**
98
+ * Resolves a list of policies
99
+ */ resolve (config, namespaceInfo) {
100
+ const { pluginName, apiName } = namespaceInfo ?? {};
101
+ return fp.castArray(config).map((policyConfig)=>{
102
+ return {
103
+ handler: resolveHandler(policyConfig, {
104
+ pluginName,
105
+ apiName
106
+ }),
107
+ config: typeof policyConfig === 'object' && policyConfig.config || {}
108
+ };
109
+ });
110
+ }
111
+ };
60
112
  };
113
+
61
114
  module.exports = policiesRegistry;
62
115
  //# sourceMappingURL=policies.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"policies.js","sources":["../../src/registries/policies.ts"],"sourcesContent":["import { pickBy, has } from 'lodash/fp';\nimport type { Common } from '@strapi/types';\nimport { addNamespace, hasNamespace } from './namespace';\n\ntype PolicyExtendFn = (policy: Common.Policy) => Common.Policy;\ntype PolicyMap = Record<string, Common.Policy>;\n\n// TODO: move instantiation part here instead of in the policy utils\nconst policiesRegistry = () => {\n const policies: PolicyMap = {};\n\n return {\n /**\n * Returns this list of registered policies uids\n */\n keys() {\n return Object.keys(policies);\n },\n\n /**\n * Returns the instance of a policy. Instantiate the policy if not already done\n */\n get(uid: Common.UID.Policy) {\n return policies[uid];\n },\n\n /**\n * Returns a map with all the policies in a namespace\n */\n getAll(namespace: string) {\n return pickBy((_, uid) => hasNamespace(uid, namespace))(policies);\n },\n\n /**\n * Registers a policy\n */\n set(uid: string, policy: Common.Policy) {\n policies[uid] = policy;\n return this;\n },\n\n /**\n * Registers a map of policies for a specific namespace\n */\n add(namespace: string, newPolicies: PolicyMap) {\n for (const policyName of Object.keys(newPolicies)) {\n const policy = newPolicies[policyName];\n const uid = addNamespace(policyName, namespace);\n\n if (has(uid, policies)) {\n throw new Error(`Policy ${uid} has already been registered.`);\n }\n policies[uid] = policy;\n }\n },\n\n /**\n * Wraps a policy to extend it\n * @param {string} uid\n * @param {(policy: Policy) => Policy} extendFn\n */\n extend(uid: Common.UID.Policy, extendFn: PolicyExtendFn) {\n const currentPolicy = this.get(uid);\n\n if (!currentPolicy) {\n throw new Error(`Policy ${uid} doesn't exist`);\n }\n\n const newPolicy = extendFn(currentPolicy);\n policies[uid] = newPolicy;\n\n return this;\n },\n };\n};\n\nexport default policiesRegistry;\n"],"names":["namespace","pickBy","_","hasNamespace","addNamespace","has"],"mappings":";;;AAQA,MAAM,mBAAmB,MAAM;AAC7B,QAAM,WAAsB,CAAA;AAErB,SAAA;AAAA;AAAA;AAAA;AAAA,IAIL,OAAO;AACE,aAAA,OAAO,KAAK,QAAQ;AAAA,IAC7B;AAAA;AAAA;AAAA;AAAA,IAKA,IAAI,KAAwB;AAC1B,aAAO,SAAS,GAAG;AAAA,IACrB;AAAA;AAAA;AAAA;AAAA,IAKA,OAAOA,aAAmB;AACjB,aAAAC,EAAA,OAAO,CAACC,IAAG,QAAQC,UAAAA,aAAa,KAAKH,WAAS,CAAC,EAAE,QAAQ;AAAA,IAClE;AAAA;AAAA;AAAA;AAAA,IAKA,IAAI,KAAa,QAAuB;AACtC,eAAS,GAAG,IAAI;AACT,aAAA;AAAA,IACT;AAAA;AAAA;AAAA;AAAA,IAKA,IAAIA,aAAmB,aAAwB;AAC7C,iBAAW,cAAc,OAAO,KAAK,WAAW,GAAG;AAC3C,cAAA,SAAS,YAAY,UAAU;AAC/B,cAAA,MAAMI,UAAAA,aAAa,YAAYJ,WAAS;AAE1C,YAAAK,EAAA,IAAI,KAAK,QAAQ,GAAG;AACtB,gBAAM,IAAI,MAAM,UAAU,GAAG,+BAA+B;AAAA,QAC9D;AACA,iBAAS,GAAG,IAAI;AAAA,MAClB;AAAA,IACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOA,OAAO,KAAwB,UAA0B;AACjD,YAAA,gBAAgB,KAAK,IAAI,GAAG;AAElC,UAAI,CAAC,eAAe;AAClB,cAAM,IAAI,MAAM,UAAU,GAAG,gBAAgB;AAAA,MAC/C;AAEM,YAAA,YAAY,SAAS,aAAa;AACxC,eAAS,GAAG,IAAI;AAET,aAAA;AAAA,IACT;AAAA,EAAA;AAEJ;;"}
1
+ {"version":3,"file":"policies.js","sources":["../../src/registries/policies.ts"],"sourcesContent":["import { pickBy, has, castArray } from 'lodash/fp';\nimport type { Core } from '@strapi/types';\nimport { addNamespace, hasNamespace } from './namespace';\n\nconst PLUGIN_PREFIX = 'plugin::';\nconst API_PREFIX = 'api::';\n\ninterface PolicyInfo {\n name: string;\n config: unknown;\n}\n\ntype PolicyConfig = string | PolicyInfo;\n\ninterface NamespaceInfo {\n pluginName?: string;\n apiName?: string;\n}\n\nconst parsePolicy = (policy: string | PolicyInfo) => {\n if (typeof policy === 'string') {\n return { policyName: policy, config: {} };\n }\n\n const { name, config } = policy;\n return { policyName: name, config };\n};\n\nconst policiesRegistry = () => {\n const policies = new Map<string, Core.Policy>();\n\n const find = (name: string, namespaceInfo?: NamespaceInfo) => {\n const { pluginName, apiName } = namespaceInfo ?? {};\n\n // try to resolve a full name to avoid extra prefixing\n const policy = policies.get(name);\n\n if (policy) {\n return policy;\n }\n\n if (pluginName) {\n return policies.get(`${PLUGIN_PREFIX}${pluginName}.${name}`);\n }\n\n if (apiName) {\n return policies.get(`${API_PREFIX}${apiName}.${name}`);\n }\n };\n\n function resolveHandler(policyConfig: PolicyConfig, namespaceInfo?: NamespaceInfo): Core.Policy;\n function resolveHandler(\n policyConfig: PolicyConfig[],\n namespaceInfo?: NamespaceInfo\n ): Core.Policy[];\n function resolveHandler(\n policyConfig: PolicyConfig | PolicyConfig[],\n namespaceInfo?: NamespaceInfo\n ): Core.Policy | Core.Policy[] {\n if (Array.isArray(policyConfig)) {\n return policyConfig.map((config) => {\n return resolveHandler(config, namespaceInfo);\n });\n }\n\n const { policyName, config } = parsePolicy(policyConfig);\n\n const policy = find(policyName, namespaceInfo);\n\n if (!policy) {\n throw new Error(`Policy ${policyName} not found.`);\n }\n\n if (typeof policy === 'function') {\n return policy;\n }\n\n if (policy.validator) {\n policy.validator(config);\n }\n\n return policy.handler;\n }\n\n return {\n /**\n * Returns this list of registered policies uids\n */\n keys() {\n // Return an array so format stays the same as controllers, services, etc\n return Array.from(policies.keys());\n },\n\n /**\n * Returns the instance of a policy. Instantiate the policy if not already done\n */\n get(name: string, namespaceInfo?: NamespaceInfo) {\n return find(name, namespaceInfo);\n },\n /**\n * Checks if a policy is registered\n */\n has(name: string, namespaceInfo?: NamespaceInfo) {\n const res = find(name, namespaceInfo);\n return !!res;\n },\n\n /**\n * Returns a map with all the policies in a namespace\n */\n getAll(namespace: string) {\n return pickBy((_, uid) => hasNamespace(uid, namespace))(Object.fromEntries(policies));\n },\n\n /**\n * Registers a policy\n */\n set(uid: string, policy: Core.Policy) {\n policies.set(uid, policy);\n return this;\n },\n\n /**\n * Registers a map of policies for a specific namespace\n */\n add(namespace: string, newPolicies: Record<string, Core.Policy>) {\n for (const policyName of Object.keys(newPolicies)) {\n const policy = newPolicies[policyName];\n const uid = addNamespace(policyName, namespace);\n\n if (has(uid, policies)) {\n throw new Error(`Policy ${uid} has already been registered.`);\n }\n\n policies.set(uid, policy);\n }\n },\n\n /**\n * Resolves a list of policies\n */\n resolve(config: PolicyConfig | PolicyConfig[], namespaceInfo?: NamespaceInfo) {\n const { pluginName, apiName } = namespaceInfo ?? {};\n\n return castArray(config).map((policyConfig) => {\n return {\n handler: resolveHandler(policyConfig, { pluginName, apiName }),\n config: (typeof policyConfig === 'object' && policyConfig.config) || {},\n };\n });\n },\n };\n};\n\nexport default policiesRegistry;\n"],"names":["PLUGIN_PREFIX","API_PREFIX","parsePolicy","policy","policyName","config","name","policiesRegistry","policies","Map","find","namespaceInfo","pluginName","apiName","get","resolveHandler","policyConfig","Array","isArray","map","Error","validator","handler","keys","from","has","res","getAll","namespace","pickBy","_","uid","hasNamespace","Object","fromEntries","set","add","newPolicies","addNamespace","resolve","castArray"],"mappings":"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"}
@@ -1,63 +1,113 @@
1
- import { pickBy, has } from "lodash/fp";
2
- import { hasNamespace, addNamespace } from "./namespace.mjs";
3
- const policiesRegistry = () => {
4
- const policies = {};
5
- return {
6
- /**
1
+ import { pickBy, has, castArray } from 'lodash/fp';
2
+ import { hasNamespace, addNamespace } from './namespace.mjs';
3
+
4
+ const PLUGIN_PREFIX = 'plugin::';
5
+ const API_PREFIX = 'api::';
6
+ const parsePolicy = (policy)=>{
7
+ if (typeof policy === 'string') {
8
+ return {
9
+ policyName: policy,
10
+ config: {}
11
+ };
12
+ }
13
+ const { name, config } = policy;
14
+ return {
15
+ policyName: name,
16
+ config
17
+ };
18
+ };
19
+ const policiesRegistry = ()=>{
20
+ const policies = new Map();
21
+ const find = (name, namespaceInfo)=>{
22
+ const { pluginName, apiName } = namespaceInfo ?? {};
23
+ // try to resolve a full name to avoid extra prefixing
24
+ const policy = policies.get(name);
25
+ if (policy) {
26
+ return policy;
27
+ }
28
+ if (pluginName) {
29
+ return policies.get(`${PLUGIN_PREFIX}${pluginName}.${name}`);
30
+ }
31
+ if (apiName) {
32
+ return policies.get(`${API_PREFIX}${apiName}.${name}`);
33
+ }
34
+ };
35
+ function resolveHandler(policyConfig, namespaceInfo) {
36
+ if (Array.isArray(policyConfig)) {
37
+ return policyConfig.map((config)=>{
38
+ return resolveHandler(config, namespaceInfo);
39
+ });
40
+ }
41
+ const { policyName, config } = parsePolicy(policyConfig);
42
+ const policy = find(policyName, namespaceInfo);
43
+ if (!policy) {
44
+ throw new Error(`Policy ${policyName} not found.`);
45
+ }
46
+ if (typeof policy === 'function') {
47
+ return policy;
48
+ }
49
+ if (policy.validator) {
50
+ policy.validator(config);
51
+ }
52
+ return policy.handler;
53
+ }
54
+ return {
55
+ /**
7
56
  * Returns this list of registered policies uids
8
- */
9
- keys() {
10
- return Object.keys(policies);
11
- },
12
- /**
57
+ */ keys () {
58
+ // Return an array so format stays the same as controllers, services, etc
59
+ return Array.from(policies.keys());
60
+ },
61
+ /**
13
62
  * Returns the instance of a policy. Instantiate the policy if not already done
14
- */
15
- get(uid) {
16
- return policies[uid];
17
- },
18
- /**
63
+ */ get (name, namespaceInfo) {
64
+ return find(name, namespaceInfo);
65
+ },
66
+ /**
67
+ * Checks if a policy is registered
68
+ */ has (name, namespaceInfo) {
69
+ const res = find(name, namespaceInfo);
70
+ return !!res;
71
+ },
72
+ /**
19
73
  * Returns a map with all the policies in a namespace
20
- */
21
- getAll(namespace) {
22
- return pickBy((_, uid) => hasNamespace(uid, namespace))(policies);
23
- },
24
- /**
74
+ */ getAll (namespace) {
75
+ return pickBy((_, uid)=>hasNamespace(uid, namespace))(Object.fromEntries(policies));
76
+ },
77
+ /**
25
78
  * Registers a policy
26
- */
27
- set(uid, policy) {
28
- policies[uid] = policy;
29
- return this;
30
- },
31
- /**
79
+ */ set (uid, policy) {
80
+ policies.set(uid, policy);
81
+ return this;
82
+ },
83
+ /**
32
84
  * Registers a map of policies for a specific namespace
33
- */
34
- add(namespace, newPolicies) {
35
- for (const policyName of Object.keys(newPolicies)) {
36
- const policy = newPolicies[policyName];
37
- const uid = addNamespace(policyName, namespace);
38
- if (has(uid, policies)) {
39
- throw new Error(`Policy ${uid} has already been registered.`);
40
- }
41
- policies[uid] = policy;
42
- }
43
- },
44
- /**
45
- * Wraps a policy to extend it
46
- * @param {string} uid
47
- * @param {(policy: Policy) => Policy} extendFn
48
- */
49
- extend(uid, extendFn) {
50
- const currentPolicy = this.get(uid);
51
- if (!currentPolicy) {
52
- throw new Error(`Policy ${uid} doesn't exist`);
53
- }
54
- const newPolicy = extendFn(currentPolicy);
55
- policies[uid] = newPolicy;
56
- return this;
57
- }
58
- };
59
- };
60
- export {
61
- policiesRegistry as default
85
+ */ add (namespace, newPolicies) {
86
+ for (const policyName of Object.keys(newPolicies)){
87
+ const policy = newPolicies[policyName];
88
+ const uid = addNamespace(policyName, namespace);
89
+ if (has(uid, policies)) {
90
+ throw new Error(`Policy ${uid} has already been registered.`);
91
+ }
92
+ policies.set(uid, policy);
93
+ }
94
+ },
95
+ /**
96
+ * Resolves a list of policies
97
+ */ resolve (config, namespaceInfo) {
98
+ const { pluginName, apiName } = namespaceInfo ?? {};
99
+ return castArray(config).map((policyConfig)=>{
100
+ return {
101
+ handler: resolveHandler(policyConfig, {
102
+ pluginName,
103
+ apiName
104
+ }),
105
+ config: typeof policyConfig === 'object' && policyConfig.config || {}
106
+ };
107
+ });
108
+ }
109
+ };
62
110
  };
111
+
112
+ export { policiesRegistry as default };
63
113
  //# sourceMappingURL=policies.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"policies.mjs","sources":["../../src/registries/policies.ts"],"sourcesContent":["import { pickBy, has } from 'lodash/fp';\nimport type { Common } from '@strapi/types';\nimport { addNamespace, hasNamespace } from './namespace';\n\ntype PolicyExtendFn = (policy: Common.Policy) => Common.Policy;\ntype PolicyMap = Record<string, Common.Policy>;\n\n// TODO: move instantiation part here instead of in the policy utils\nconst policiesRegistry = () => {\n const policies: PolicyMap = {};\n\n return {\n /**\n * Returns this list of registered policies uids\n */\n keys() {\n return Object.keys(policies);\n },\n\n /**\n * Returns the instance of a policy. Instantiate the policy if not already done\n */\n get(uid: Common.UID.Policy) {\n return policies[uid];\n },\n\n /**\n * Returns a map with all the policies in a namespace\n */\n getAll(namespace: string) {\n return pickBy((_, uid) => hasNamespace(uid, namespace))(policies);\n },\n\n /**\n * Registers a policy\n */\n set(uid: string, policy: Common.Policy) {\n policies[uid] = policy;\n return this;\n },\n\n /**\n * Registers a map of policies for a specific namespace\n */\n add(namespace: string, newPolicies: PolicyMap) {\n for (const policyName of Object.keys(newPolicies)) {\n const policy = newPolicies[policyName];\n const uid = addNamespace(policyName, namespace);\n\n if (has(uid, policies)) {\n throw new Error(`Policy ${uid} has already been registered.`);\n }\n policies[uid] = policy;\n }\n },\n\n /**\n * Wraps a policy to extend it\n * @param {string} uid\n * @param {(policy: Policy) => Policy} extendFn\n */\n extend(uid: Common.UID.Policy, extendFn: PolicyExtendFn) {\n const currentPolicy = this.get(uid);\n\n if (!currentPolicy) {\n throw new Error(`Policy ${uid} doesn't exist`);\n }\n\n const newPolicy = extendFn(currentPolicy);\n policies[uid] = newPolicy;\n\n return this;\n },\n };\n};\n\nexport default policiesRegistry;\n"],"names":[],"mappings":";;AAQA,MAAM,mBAAmB,MAAM;AAC7B,QAAM,WAAsB,CAAA;AAErB,SAAA;AAAA;AAAA;AAAA;AAAA,IAIL,OAAO;AACE,aAAA,OAAO,KAAK,QAAQ;AAAA,IAC7B;AAAA;AAAA;AAAA;AAAA,IAKA,IAAI,KAAwB;AAC1B,aAAO,SAAS,GAAG;AAAA,IACrB;AAAA;AAAA;AAAA;AAAA,IAKA,OAAO,WAAmB;AACjB,aAAA,OAAO,CAAC,GAAG,QAAQ,aAAa,KAAK,SAAS,CAAC,EAAE,QAAQ;AAAA,IAClE;AAAA;AAAA;AAAA;AAAA,IAKA,IAAI,KAAa,QAAuB;AACtC,eAAS,GAAG,IAAI;AACT,aAAA;AAAA,IACT;AAAA;AAAA;AAAA;AAAA,IAKA,IAAI,WAAmB,aAAwB;AAC7C,iBAAW,cAAc,OAAO,KAAK,WAAW,GAAG;AAC3C,cAAA,SAAS,YAAY,UAAU;AAC/B,cAAA,MAAM,aAAa,YAAY,SAAS;AAE1C,YAAA,IAAI,KAAK,QAAQ,GAAG;AACtB,gBAAM,IAAI,MAAM,UAAU,GAAG,+BAA+B;AAAA,QAC9D;AACA,iBAAS,GAAG,IAAI;AAAA,MAClB;AAAA,IACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOA,OAAO,KAAwB,UAA0B;AACjD,YAAA,gBAAgB,KAAK,IAAI,GAAG;AAElC,UAAI,CAAC,eAAe;AAClB,cAAM,IAAI,MAAM,UAAU,GAAG,gBAAgB;AAAA,MAC/C;AAEM,YAAA,YAAY,SAAS,aAAa;AACxC,eAAS,GAAG,IAAI;AAET,aAAA;AAAA,IACT;AAAA,EAAA;AAEJ;"}
1
+ {"version":3,"file":"policies.mjs","sources":["../../src/registries/policies.ts"],"sourcesContent":["import { pickBy, has, castArray } from 'lodash/fp';\nimport type { Core } from '@strapi/types';\nimport { addNamespace, hasNamespace } from './namespace';\n\nconst PLUGIN_PREFIX = 'plugin::';\nconst API_PREFIX = 'api::';\n\ninterface PolicyInfo {\n name: string;\n config: unknown;\n}\n\ntype PolicyConfig = string | PolicyInfo;\n\ninterface NamespaceInfo {\n pluginName?: string;\n apiName?: string;\n}\n\nconst parsePolicy = (policy: string | PolicyInfo) => {\n if (typeof policy === 'string') {\n return { policyName: policy, config: {} };\n }\n\n const { name, config } = policy;\n return { policyName: name, config };\n};\n\nconst policiesRegistry = () => {\n const policies = new Map<string, Core.Policy>();\n\n const find = (name: string, namespaceInfo?: NamespaceInfo) => {\n const { pluginName, apiName } = namespaceInfo ?? {};\n\n // try to resolve a full name to avoid extra prefixing\n const policy = policies.get(name);\n\n if (policy) {\n return policy;\n }\n\n if (pluginName) {\n return policies.get(`${PLUGIN_PREFIX}${pluginName}.${name}`);\n }\n\n if (apiName) {\n return policies.get(`${API_PREFIX}${apiName}.${name}`);\n }\n };\n\n function resolveHandler(policyConfig: PolicyConfig, namespaceInfo?: NamespaceInfo): Core.Policy;\n function resolveHandler(\n policyConfig: PolicyConfig[],\n namespaceInfo?: NamespaceInfo\n ): Core.Policy[];\n function resolveHandler(\n policyConfig: PolicyConfig | PolicyConfig[],\n namespaceInfo?: NamespaceInfo\n ): Core.Policy | Core.Policy[] {\n if (Array.isArray(policyConfig)) {\n return policyConfig.map((config) => {\n return resolveHandler(config, namespaceInfo);\n });\n }\n\n const { policyName, config } = parsePolicy(policyConfig);\n\n const policy = find(policyName, namespaceInfo);\n\n if (!policy) {\n throw new Error(`Policy ${policyName} not found.`);\n }\n\n if (typeof policy === 'function') {\n return policy;\n }\n\n if (policy.validator) {\n policy.validator(config);\n }\n\n return policy.handler;\n }\n\n return {\n /**\n * Returns this list of registered policies uids\n */\n keys() {\n // Return an array so format stays the same as controllers, services, etc\n return Array.from(policies.keys());\n },\n\n /**\n * Returns the instance of a policy. Instantiate the policy if not already done\n */\n get(name: string, namespaceInfo?: NamespaceInfo) {\n return find(name, namespaceInfo);\n },\n /**\n * Checks if a policy is registered\n */\n has(name: string, namespaceInfo?: NamespaceInfo) {\n const res = find(name, namespaceInfo);\n return !!res;\n },\n\n /**\n * Returns a map with all the policies in a namespace\n */\n getAll(namespace: string) {\n return pickBy((_, uid) => hasNamespace(uid, namespace))(Object.fromEntries(policies));\n },\n\n /**\n * Registers a policy\n */\n set(uid: string, policy: Core.Policy) {\n policies.set(uid, policy);\n return this;\n },\n\n /**\n * Registers a map of policies for a specific namespace\n */\n add(namespace: string, newPolicies: Record<string, Core.Policy>) {\n for (const policyName of Object.keys(newPolicies)) {\n const policy = newPolicies[policyName];\n const uid = addNamespace(policyName, namespace);\n\n if (has(uid, policies)) {\n throw new Error(`Policy ${uid} has already been registered.`);\n }\n\n policies.set(uid, policy);\n }\n },\n\n /**\n * Resolves a list of policies\n */\n resolve(config: PolicyConfig | PolicyConfig[], namespaceInfo?: NamespaceInfo) {\n const { pluginName, apiName } = namespaceInfo ?? {};\n\n return castArray(config).map((policyConfig) => {\n return {\n handler: resolveHandler(policyConfig, { pluginName, apiName }),\n config: (typeof policyConfig === 'object' && policyConfig.config) || {},\n };\n });\n },\n };\n};\n\nexport default policiesRegistry;\n"],"names":["PLUGIN_PREFIX","API_PREFIX","parsePolicy","policy","policyName","config","name","policiesRegistry","policies","Map","find","namespaceInfo","pluginName","apiName","get","resolveHandler","policyConfig","Array","isArray","map","Error","validator","handler","keys","from","has","res","getAll","namespace","pickBy","_","uid","hasNamespace","Object","fromEntries","set","add","newPolicies","addNamespace","resolve","castArray"],"mappings":"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"}