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

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 (810) 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 +195 -214
  5. package/dist/Strapi.js.map +1 -1
  6. package/dist/Strapi.mjs +165 -204
  7. package/dist/Strapi.mjs.map +1 -1
  8. package/dist/configuration/config-loader.d.ts.map +1 -1
  9. package/dist/configuration/config-loader.js +9 -5
  10. package/dist/configuration/config-loader.js.map +1 -1
  11. package/dist/configuration/config-loader.mjs +9 -5
  12. package/dist/configuration/config-loader.mjs.map +1 -1
  13. package/dist/configuration/get-dirs.d.ts +10 -0
  14. package/dist/configuration/get-dirs.d.ts.map +1 -0
  15. package/dist/{utils → configuration}/get-dirs.js +3 -2
  16. package/dist/configuration/get-dirs.js.map +1 -0
  17. package/dist/{utils → configuration}/get-dirs.mjs +3 -2
  18. package/dist/configuration/get-dirs.mjs.map +1 -0
  19. package/dist/configuration/index.d.ts +4 -7
  20. package/dist/configuration/index.d.ts.map +1 -1
  21. package/dist/configuration/index.js +8 -6
  22. package/dist/configuration/index.js.map +1 -1
  23. package/dist/configuration/index.mjs +5 -4
  24. package/dist/configuration/index.mjs.map +1 -1
  25. package/dist/container.d.ts +2 -2
  26. package/dist/container.d.ts.map +1 -1
  27. package/dist/container.js.map +1 -1
  28. package/dist/container.mjs.map +1 -1
  29. package/dist/core-api/controller/collection-type.d.ts +3 -3
  30. package/dist/core-api/controller/collection-type.d.ts.map +1 -1
  31. package/dist/core-api/controller/collection-type.js +6 -3
  32. package/dist/core-api/controller/collection-type.js.map +1 -1
  33. package/dist/core-api/controller/collection-type.mjs +3 -0
  34. package/dist/core-api/controller/collection-type.mjs.map +1 -1
  35. package/dist/core-api/controller/index.d.ts +3 -3
  36. package/dist/core-api/controller/index.d.ts.map +1 -1
  37. package/dist/core-api/controller/index.js +7 -7
  38. package/dist/core-api/controller/index.js.map +1 -1
  39. package/dist/core-api/controller/index.mjs +6 -6
  40. package/dist/core-api/controller/index.mjs.map +1 -1
  41. package/dist/core-api/controller/single-type.d.ts +3 -3
  42. package/dist/core-api/controller/single-type.d.ts.map +1 -1
  43. package/dist/core-api/controller/single-type.js +3 -2
  44. package/dist/core-api/controller/single-type.js.map +1 -1
  45. package/dist/core-api/controller/single-type.mjs +1 -0
  46. package/dist/core-api/controller/single-type.mjs.map +1 -1
  47. package/dist/core-api/controller/transform.d.ts +2 -2
  48. package/dist/core-api/controller/transform.d.ts.map +1 -1
  49. package/dist/core-api/controller/transform.js +10 -13
  50. package/dist/core-api/controller/transform.js.map +1 -1
  51. package/dist/core-api/controller/transform.mjs +2 -5
  52. package/dist/core-api/controller/transform.mjs.map +1 -1
  53. package/dist/core-api/routes/index.d.ts.map +1 -1
  54. package/dist/core-api/service/collection-type.d.ts +11 -17
  55. package/dist/core-api/service/collection-type.d.ts.map +1 -1
  56. package/dist/core-api/service/collection-type.js +18 -7
  57. package/dist/core-api/service/collection-type.js.map +1 -1
  58. package/dist/core-api/service/collection-type.mjs +19 -8
  59. package/dist/core-api/service/collection-type.mjs.map +1 -1
  60. package/dist/core-api/service/index.d.ts +3 -3
  61. package/dist/core-api/service/index.d.ts.map +1 -1
  62. package/dist/core-api/service/index.js.map +1 -1
  63. package/dist/core-api/service/index.mjs.map +1 -1
  64. package/dist/core-api/service/pagination.d.ts +4 -11
  65. package/dist/core-api/service/pagination.d.ts.map +1 -1
  66. package/dist/core-api/service/pagination.js +18 -44
  67. package/dist/core-api/service/pagination.js.map +1 -1
  68. package/dist/core-api/service/pagination.mjs +16 -42
  69. package/dist/core-api/service/pagination.mjs.map +1 -1
  70. package/dist/core-api/service/single-type.d.ts +4 -4
  71. package/dist/core-api/service/single-type.d.ts.map +1 -1
  72. package/dist/core-api/service/single-type.js +9 -2
  73. package/dist/core-api/service/single-type.js.map +1 -1
  74. package/dist/core-api/service/single-type.mjs +9 -2
  75. package/dist/core-api/service/single-type.mjs.map +1 -1
  76. package/dist/domain/content-type/index.d.ts +1 -1
  77. package/dist/domain/content-type/index.d.ts.map +1 -1
  78. package/dist/domain/content-type/index.js +4 -4
  79. package/dist/domain/content-type/index.js.map +1 -1
  80. package/dist/domain/module/index.d.ts +24 -23
  81. package/dist/domain/module/index.d.ts.map +1 -1
  82. package/dist/domain/module/index.js +2 -1
  83. package/dist/domain/module/index.js.map +1 -1
  84. package/dist/domain/module/index.mjs +3 -2
  85. package/dist/domain/module/index.mjs.map +1 -1
  86. package/dist/ee/index.d.ts +4 -2
  87. package/dist/ee/index.d.ts.map +1 -1
  88. package/dist/ee/index.js +9 -4
  89. package/dist/ee/index.js.map +1 -1
  90. package/dist/ee/index.mjs +6 -1
  91. package/dist/ee/index.mjs.map +1 -1
  92. package/dist/ee/license.d.ts +2 -2
  93. package/dist/ee/license.d.ts.map +1 -1
  94. package/dist/ee/license.js +2 -1
  95. package/dist/ee/license.js.map +1 -1
  96. package/dist/ee/license.mjs +2 -1
  97. package/dist/ee/license.mjs.map +1 -1
  98. package/dist/factories.d.ts +10 -10
  99. package/dist/factories.d.ts.map +1 -1
  100. package/dist/factories.js +10 -6
  101. package/dist/factories.js.map +1 -1
  102. package/dist/factories.mjs +6 -2
  103. package/dist/factories.mjs.map +1 -1
  104. package/dist/index.d.ts +18 -2
  105. package/dist/index.d.ts.map +1 -1
  106. package/dist/index.js +25 -1
  107. package/dist/index.js.map +1 -1
  108. package/dist/index.mjs +27 -3
  109. package/dist/index.mjs.map +1 -1
  110. package/dist/loaders/admin.d.ts +2 -2
  111. package/dist/loaders/admin.d.ts.map +1 -1
  112. package/dist/loaders/admin.js +0 -1
  113. package/dist/loaders/admin.js.map +1 -1
  114. package/dist/loaders/admin.mjs +0 -1
  115. package/dist/loaders/admin.mjs.map +1 -1
  116. package/dist/loaders/apis.d.ts +2 -2
  117. package/dist/loaders/apis.d.ts.map +1 -1
  118. package/dist/loaders/apis.js +12 -12
  119. package/dist/loaders/apis.js.map +1 -1
  120. package/dist/loaders/apis.mjs +10 -10
  121. package/dist/loaders/apis.mjs.map +1 -1
  122. package/dist/loaders/components.d.ts +2 -2
  123. package/dist/loaders/components.d.ts.map +1 -1
  124. package/dist/loaders/components.js.map +1 -1
  125. package/dist/loaders/components.mjs.map +1 -1
  126. package/dist/loaders/index.d.ts +2 -2
  127. package/dist/loaders/index.d.ts.map +1 -1
  128. package/dist/loaders/index.js +0 -2
  129. package/dist/loaders/index.js.map +1 -1
  130. package/dist/loaders/index.mjs +0 -2
  131. package/dist/loaders/index.mjs.map +1 -1
  132. package/dist/loaders/middlewares.d.ts +2 -2
  133. package/dist/loaders/middlewares.d.ts.map +1 -1
  134. package/dist/loaders/middlewares.js.map +1 -1
  135. package/dist/loaders/middlewares.mjs.map +1 -1
  136. package/dist/loaders/plugins/get-enabled-plugins.d.ts +2 -2
  137. package/dist/loaders/plugins/get-enabled-plugins.d.ts.map +1 -1
  138. package/dist/loaders/plugins/get-enabled-plugins.js +46 -16
  139. package/dist/loaders/plugins/get-enabled-plugins.js.map +1 -1
  140. package/dist/loaders/plugins/get-enabled-plugins.mjs +16 -8
  141. package/dist/loaders/plugins/get-enabled-plugins.mjs.map +1 -1
  142. package/dist/loaders/plugins/get-user-plugins-config.js +2 -2
  143. package/dist/loaders/plugins/get-user-plugins-config.js.map +1 -1
  144. package/dist/loaders/plugins/index.d.ts +2 -2
  145. package/dist/loaders/plugins/index.d.ts.map +1 -1
  146. package/dist/loaders/plugins/index.js +34 -7
  147. package/dist/loaders/plugins/index.js.map +1 -1
  148. package/dist/loaders/plugins/index.mjs +9 -1
  149. package/dist/loaders/plugins/index.mjs.map +1 -1
  150. package/dist/loaders/policies.d.ts +2 -2
  151. package/dist/loaders/policies.d.ts.map +1 -1
  152. package/dist/loaders/policies.js.map +1 -1
  153. package/dist/loaders/policies.mjs.map +1 -1
  154. package/dist/loaders/sanitizers.d.ts +2 -2
  155. package/dist/loaders/sanitizers.d.ts.map +1 -1
  156. package/dist/loaders/sanitizers.js.map +1 -1
  157. package/dist/loaders/sanitizers.mjs.map +1 -1
  158. package/dist/loaders/src-index.d.ts +2 -2
  159. package/dist/loaders/src-index.d.ts.map +1 -1
  160. package/dist/loaders/src-index.js.map +1 -1
  161. package/dist/loaders/src-index.mjs.map +1 -1
  162. package/dist/loaders/validators.d.ts +2 -2
  163. package/dist/loaders/validators.d.ts.map +1 -1
  164. package/dist/loaders/validators.js.map +1 -1
  165. package/dist/loaders/validators.mjs.map +1 -1
  166. package/dist/middlewares/body.d.ts +4 -4
  167. package/dist/middlewares/body.d.ts.map +1 -1
  168. package/dist/middlewares/body.js +6 -6
  169. package/dist/middlewares/body.js.map +1 -1
  170. package/dist/middlewares/body.mjs +4 -4
  171. package/dist/middlewares/body.mjs.map +1 -1
  172. package/dist/middlewares/compression.d.ts +2 -2
  173. package/dist/middlewares/compression.d.ts.map +1 -1
  174. package/dist/middlewares/compression.js.map +1 -1
  175. package/dist/middlewares/compression.mjs.map +1 -1
  176. package/dist/middlewares/cors.d.ts +2 -2
  177. package/dist/middlewares/cors.d.ts.map +1 -1
  178. package/dist/middlewares/cors.js +9 -7
  179. package/dist/middlewares/cors.js.map +1 -1
  180. package/dist/middlewares/cors.mjs +9 -7
  181. package/dist/middlewares/cors.mjs.map +1 -1
  182. package/dist/middlewares/errors.d.ts +2 -2
  183. package/dist/middlewares/errors.d.ts.map +1 -1
  184. package/dist/middlewares/errors.js.map +1 -1
  185. package/dist/middlewares/errors.mjs.map +1 -1
  186. package/dist/middlewares/favicon.d.ts +2 -2
  187. package/dist/middlewares/favicon.d.ts.map +1 -1
  188. package/dist/middlewares/favicon.js.map +1 -1
  189. package/dist/middlewares/favicon.mjs.map +1 -1
  190. package/dist/middlewares/index.d.ts +2 -2
  191. package/dist/middlewares/index.d.ts.map +1 -1
  192. package/dist/middlewares/index.js.map +1 -1
  193. package/dist/middlewares/index.mjs.map +1 -1
  194. package/dist/middlewares/ip.d.ts +2 -2
  195. package/dist/middlewares/ip.d.ts.map +1 -1
  196. package/dist/middlewares/ip.js.map +1 -1
  197. package/dist/middlewares/ip.mjs.map +1 -1
  198. package/dist/middlewares/logger.d.ts +2 -2
  199. package/dist/middlewares/logger.d.ts.map +1 -1
  200. package/dist/middlewares/logger.js.map +1 -1
  201. package/dist/middlewares/logger.mjs.map +1 -1
  202. package/dist/middlewares/powered-by.d.ts +2 -2
  203. package/dist/middlewares/powered-by.d.ts.map +1 -1
  204. package/dist/middlewares/powered-by.js.map +1 -1
  205. package/dist/middlewares/powered-by.mjs.map +1 -1
  206. package/dist/middlewares/public.d.ts +2 -2
  207. package/dist/middlewares/public.d.ts.map +1 -1
  208. package/dist/middlewares/public.js +3 -3
  209. package/dist/middlewares/public.js.map +1 -1
  210. package/dist/middlewares/public.mjs +1 -1
  211. package/dist/middlewares/public.mjs.map +1 -1
  212. package/dist/middlewares/query.d.ts +2 -2
  213. package/dist/middlewares/query.d.ts.map +1 -1
  214. package/dist/middlewares/query.js.map +1 -1
  215. package/dist/middlewares/query.mjs.map +1 -1
  216. package/dist/middlewares/response-time.d.ts +2 -2
  217. package/dist/middlewares/response-time.d.ts.map +1 -1
  218. package/dist/middlewares/response-time.js.map +1 -1
  219. package/dist/middlewares/response-time.mjs.map +1 -1
  220. package/dist/middlewares/responses.d.ts +3 -3
  221. package/dist/middlewares/responses.d.ts.map +1 -1
  222. package/dist/middlewares/responses.js +2 -2
  223. package/dist/middlewares/responses.js.map +1 -1
  224. package/dist/middlewares/responses.mjs.map +1 -1
  225. package/dist/middlewares/security.d.ts +2 -2
  226. package/dist/middlewares/security.d.ts.map +1 -1
  227. package/dist/middlewares/security.js +13 -6
  228. package/dist/middlewares/security.js.map +1 -1
  229. package/dist/middlewares/security.mjs +12 -5
  230. package/dist/middlewares/security.mjs.map +1 -1
  231. package/dist/middlewares/session.d.ts +2 -2
  232. package/dist/middlewares/session.d.ts.map +1 -1
  233. package/dist/middlewares/session.js +2 -2
  234. package/dist/middlewares/session.js.map +1 -1
  235. package/dist/middlewares/session.mjs.map +1 -1
  236. package/dist/migrations/database/5.0.0-discard-drafts.d.ts +33 -0
  237. package/dist/migrations/database/5.0.0-discard-drafts.d.ts.map +1 -0
  238. package/dist/migrations/database/5.0.0-discard-drafts.js +94 -0
  239. package/dist/migrations/database/5.0.0-discard-drafts.js.map +1 -0
  240. package/dist/migrations/database/5.0.0-discard-drafts.mjs +94 -0
  241. package/dist/migrations/database/5.0.0-discard-drafts.mjs.map +1 -0
  242. package/dist/migrations/draft-publish.d.ts +1 -1
  243. package/dist/migrations/draft-publish.d.ts.map +1 -1
  244. package/dist/migrations/draft-publish.js +14 -31
  245. package/dist/migrations/draft-publish.js.map +1 -1
  246. package/dist/migrations/draft-publish.mjs +15 -32
  247. package/dist/migrations/draft-publish.mjs.map +1 -1
  248. package/dist/migrations/i18n.d.ts +5 -0
  249. package/dist/migrations/i18n.d.ts.map +1 -0
  250. package/dist/migrations/i18n.js +54 -0
  251. package/dist/migrations/i18n.js.map +1 -0
  252. package/dist/migrations/i18n.mjs +54 -0
  253. package/dist/migrations/i18n.mjs.map +1 -0
  254. package/dist/migrations/index.d.ts +5 -0
  255. package/dist/migrations/index.d.ts.map +1 -0
  256. package/dist/migrations/index.js +15 -0
  257. package/dist/migrations/index.js.map +1 -0
  258. package/dist/migrations/index.mjs +15 -0
  259. package/dist/migrations/index.mjs.map +1 -0
  260. package/dist/providers/admin.d.ts +3 -0
  261. package/dist/providers/admin.d.ts.map +1 -0
  262. package/dist/providers/admin.js +20 -0
  263. package/dist/providers/admin.js.map +1 -0
  264. package/dist/providers/admin.mjs +21 -0
  265. package/dist/providers/admin.mjs.map +1 -0
  266. package/dist/providers/coreStore.d.ts +3 -0
  267. package/dist/providers/coreStore.d.ts.map +1 -0
  268. package/dist/providers/coreStore.js +11 -0
  269. package/dist/providers/coreStore.js.map +1 -0
  270. package/dist/providers/coreStore.mjs +12 -0
  271. package/dist/providers/coreStore.mjs.map +1 -0
  272. package/dist/providers/cron.d.ts +3 -0
  273. package/dist/providers/cron.d.ts.map +1 -0
  274. package/dist/providers/cron.js +20 -0
  275. package/dist/providers/cron.js.map +1 -0
  276. package/dist/providers/cron.mjs +21 -0
  277. package/dist/providers/cron.mjs.map +1 -0
  278. package/dist/providers/index.d.ts +3 -0
  279. package/dist/providers/index.d.ts.map +1 -0
  280. package/dist/providers/index.js +11 -0
  281. package/dist/providers/index.js.map +1 -0
  282. package/dist/providers/index.mjs +11 -0
  283. package/dist/providers/index.mjs.map +1 -0
  284. package/dist/providers/provider.d.ts +9 -0
  285. package/dist/providers/provider.d.ts.map +1 -0
  286. package/dist/providers/provider.js +5 -0
  287. package/dist/providers/provider.js.map +1 -0
  288. package/dist/providers/provider.mjs +5 -0
  289. package/dist/providers/provider.mjs.map +1 -0
  290. package/dist/providers/registries.d.ts +3 -0
  291. package/dist/providers/registries.d.ts.map +1 -0
  292. package/dist/providers/registries.js +35 -0
  293. package/dist/providers/registries.js.map +1 -0
  294. package/dist/providers/registries.mjs +36 -0
  295. package/dist/providers/registries.mjs.map +1 -0
  296. package/dist/providers/telemetry.d.ts +3 -0
  297. package/dist/providers/telemetry.d.ts.map +1 -0
  298. package/dist/providers/telemetry.js +19 -0
  299. package/dist/providers/telemetry.js.map +1 -0
  300. package/dist/providers/telemetry.mjs +20 -0
  301. package/dist/providers/telemetry.mjs.map +1 -0
  302. package/dist/providers/webhooks.d.ts +3 -0
  303. package/dist/providers/webhooks.d.ts.map +1 -0
  304. package/dist/providers/webhooks.js +30 -0
  305. package/dist/providers/webhooks.js.map +1 -0
  306. package/dist/providers/webhooks.mjs +31 -0
  307. package/dist/providers/webhooks.mjs.map +1 -0
  308. package/dist/registries/apis.d.ts +2 -2
  309. package/dist/registries/apis.d.ts.map +1 -1
  310. package/dist/registries/apis.js +2 -2
  311. package/dist/registries/apis.js.map +1 -1
  312. package/dist/registries/apis.mjs.map +1 -1
  313. package/dist/registries/components.d.ts +6 -6
  314. package/dist/registries/components.d.ts.map +1 -1
  315. package/dist/registries/components.js +2 -2
  316. package/dist/registries/components.js.map +1 -1
  317. package/dist/registries/components.mjs.map +1 -1
  318. package/dist/registries/content-types.d.ts +5 -5
  319. package/dist/registries/content-types.d.ts.map +1 -1
  320. package/dist/registries/content-types.js +3 -3
  321. package/dist/registries/content-types.js.map +1 -1
  322. package/dist/registries/content-types.mjs.map +1 -1
  323. package/dist/registries/controllers.d.ts +10 -10
  324. package/dist/registries/controllers.d.ts.map +1 -1
  325. package/dist/registries/controllers.js +3 -3
  326. package/dist/registries/controllers.js.map +1 -1
  327. package/dist/registries/controllers.mjs.map +1 -1
  328. package/dist/registries/custom-fields.d.ts +3 -3
  329. package/dist/registries/custom-fields.d.ts.map +1 -1
  330. package/dist/registries/custom-fields.js +4 -4
  331. package/dist/registries/custom-fields.js.map +1 -1
  332. package/dist/registries/custom-fields.mjs.map +1 -1
  333. package/dist/registries/hooks.js +2 -2
  334. package/dist/registries/hooks.js.map +1 -1
  335. package/dist/registries/index.d.ts +0 -1
  336. package/dist/registries/index.d.ts.map +1 -1
  337. package/dist/registries/middlewares.d.ts +6 -6
  338. package/dist/registries/middlewares.d.ts.map +1 -1
  339. package/dist/registries/middlewares.js +3 -3
  340. package/dist/registries/middlewares.js.map +1 -1
  341. package/dist/registries/middlewares.mjs.map +1 -1
  342. package/dist/registries/modules.d.ts +2 -2
  343. package/dist/registries/modules.d.ts.map +1 -1
  344. package/dist/registries/modules.js +3 -3
  345. package/dist/registries/modules.js.map +1 -1
  346. package/dist/registries/modules.mjs.map +1 -1
  347. package/dist/registries/plugins.d.ts +5 -5
  348. package/dist/registries/plugins.d.ts.map +1 -1
  349. package/dist/registries/plugins.js +2 -2
  350. package/dist/registries/plugins.js.map +1 -1
  351. package/dist/registries/plugins.mjs.map +1 -1
  352. package/dist/registries/policies.d.ts +22 -10
  353. package/dist/registries/policies.d.ts.map +1 -1
  354. package/dist/registries/policies.js +66 -20
  355. package/dist/registries/policies.js.map +1 -1
  356. package/dist/registries/policies.mjs +65 -19
  357. package/dist/registries/policies.mjs.map +1 -1
  358. package/dist/registries/services.d.ts +8 -8
  359. package/dist/registries/services.d.ts.map +1 -1
  360. package/dist/registries/services.js +3 -3
  361. package/dist/registries/services.js.map +1 -1
  362. package/dist/registries/services.mjs.map +1 -1
  363. package/dist/services/auth/index.d.ts +4 -4
  364. package/dist/services/auth/index.d.ts.map +1 -1
  365. package/dist/services/auth/index.js +3 -3
  366. package/dist/services/auth/index.js.map +1 -1
  367. package/dist/services/auth/index.mjs.map +1 -1
  368. package/dist/services/config.d.ts +3 -0
  369. package/dist/services/config.d.ts.map +1 -0
  370. package/dist/services/config.js +47 -0
  371. package/dist/services/config.js.map +1 -0
  372. package/dist/services/config.mjs +47 -0
  373. package/dist/services/config.mjs.map +1 -0
  374. package/dist/services/content-api/index.d.ts +31 -15
  375. package/dist/services/content-api/index.d.ts.map +1 -1
  376. package/dist/services/content-api/index.js +28 -2
  377. package/dist/services/content-api/index.js.map +1 -1
  378. package/dist/services/content-api/index.mjs +28 -2
  379. package/dist/services/content-api/index.mjs.map +1 -1
  380. package/dist/services/content-api/permissions/index.d.ts +13 -15
  381. package/dist/services/content-api/permissions/index.d.ts.map +1 -1
  382. package/dist/services/content-api/permissions/index.js +1 -1
  383. package/dist/services/content-api/permissions/index.js.map +1 -1
  384. package/dist/services/content-api/permissions/index.mjs +1 -1
  385. package/dist/services/content-api/permissions/index.mjs.map +1 -1
  386. package/dist/services/content-api/permissions/providers/action.d.ts +5 -6
  387. package/dist/services/content-api/permissions/providers/action.d.ts.map +1 -1
  388. package/dist/services/content-api/permissions/providers/condition.d.ts +5 -6
  389. package/dist/services/content-api/permissions/providers/condition.d.ts.map +1 -1
  390. package/dist/services/core-store.d.ts.map +1 -1
  391. package/dist/services/core-store.js +3 -3
  392. package/dist/services/core-store.js.map +1 -1
  393. package/dist/services/cron.d.ts +5 -5
  394. package/dist/services/cron.d.ts.map +1 -1
  395. package/dist/services/cron.js +3 -3
  396. package/dist/services/cron.js.map +1 -1
  397. package/dist/services/cron.mjs.map +1 -1
  398. package/dist/services/custom-fields.d.ts +2 -2
  399. package/dist/services/custom-fields.d.ts.map +1 -1
  400. package/dist/services/custom-fields.js.map +1 -1
  401. package/dist/services/custom-fields.mjs.map +1 -1
  402. package/dist/services/document-service/attributes/index.d.ts +6 -0
  403. package/dist/services/document-service/attributes/index.d.ts.map +1 -0
  404. package/dist/services/{entity-service → document-service}/attributes/index.js +5 -5
  405. package/dist/services/document-service/attributes/index.js.map +1 -0
  406. package/dist/services/{entity-service → document-service}/attributes/index.mjs +5 -5
  407. package/dist/services/document-service/attributes/index.mjs.map +1 -0
  408. package/dist/services/document-service/attributes/transforms.d.ts +10 -0
  409. package/dist/services/document-service/attributes/transforms.d.ts.map +1 -0
  410. package/dist/services/{entity-service → document-service}/attributes/transforms.js +3 -3
  411. package/dist/services/document-service/attributes/transforms.js.map +1 -0
  412. package/dist/services/document-service/attributes/transforms.mjs.map +1 -0
  413. package/dist/services/document-service/common.d.ts +2 -2
  414. package/dist/services/document-service/common.d.ts.map +1 -1
  415. package/dist/services/document-service/common.js.map +1 -1
  416. package/dist/services/document-service/common.mjs.map +1 -1
  417. package/dist/services/document-service/components.d.ts +25 -1
  418. package/dist/services/document-service/components.d.ts.map +1 -1
  419. package/dist/services/{entity-service → document-service}/components.js +52 -148
  420. package/dist/services/document-service/components.js.map +1 -0
  421. package/dist/services/{entity-service → document-service}/components.mjs +42 -138
  422. package/dist/services/document-service/components.mjs.map +1 -0
  423. package/dist/services/document-service/draft-and-publish.d.ts +7 -7
  424. package/dist/services/document-service/draft-and-publish.d.ts.map +1 -1
  425. package/dist/services/document-service/draft-and-publish.js +16 -16
  426. package/dist/services/document-service/draft-and-publish.js.map +1 -1
  427. package/dist/services/document-service/draft-and-publish.mjs.map +1 -1
  428. package/dist/services/document-service/entries.d.ts +10 -0
  429. package/dist/services/document-service/entries.d.ts.map +1 -0
  430. package/dist/services/document-service/entries.js +96 -0
  431. package/dist/services/document-service/entries.js.map +1 -0
  432. package/dist/services/document-service/entries.mjs +96 -0
  433. package/dist/services/document-service/entries.mjs.map +1 -0
  434. package/dist/services/document-service/events.d.ts +25 -0
  435. package/dist/services/document-service/events.d.ts.map +1 -0
  436. package/dist/services/document-service/events.js +47 -0
  437. package/dist/services/document-service/events.js.map +1 -0
  438. package/dist/services/document-service/events.mjs +47 -0
  439. package/dist/services/document-service/events.mjs.map +1 -0
  440. package/dist/services/document-service/index.d.ts +2 -4
  441. package/dist/services/document-service/index.d.ts.map +1 -1
  442. package/dist/services/document-service/index.js +18 -5
  443. package/dist/services/document-service/index.js.map +1 -1
  444. package/dist/services/document-service/index.mjs +16 -3
  445. package/dist/services/document-service/index.mjs.map +1 -1
  446. package/dist/services/document-service/internationalization.d.ts +5 -5
  447. package/dist/services/document-service/internationalization.d.ts.map +1 -1
  448. package/dist/services/document-service/internationalization.js +21 -12
  449. package/dist/services/document-service/internationalization.js.map +1 -1
  450. package/dist/services/document-service/internationalization.mjs +14 -5
  451. package/dist/services/document-service/internationalization.mjs.map +1 -1
  452. package/dist/services/document-service/middlewares/errors.d.ts +6 -0
  453. package/dist/services/document-service/middlewares/errors.d.ts.map +1 -0
  454. package/dist/services/document-service/middlewares/errors.js +25 -0
  455. package/dist/services/document-service/middlewares/errors.js.map +1 -0
  456. package/dist/services/document-service/middlewares/errors.mjs +25 -0
  457. package/dist/services/document-service/middlewares/errors.mjs.map +1 -0
  458. package/dist/services/document-service/middlewares/index.d.ts +3 -0
  459. package/dist/services/document-service/middlewares/index.d.ts.map +1 -0
  460. package/dist/services/document-service/middlewares/middleware-manager.d.ts +10 -0
  461. package/dist/services/document-service/middlewares/middleware-manager.d.ts.map +1 -0
  462. package/dist/services/document-service/{middlewares.js → middlewares/middleware-manager.js} +9 -6
  463. package/dist/services/document-service/middlewares/middleware-manager.js.map +1 -0
  464. package/dist/services/document-service/{middlewares.mjs → middlewares/middleware-manager.mjs} +9 -6
  465. package/dist/services/document-service/middlewares/middleware-manager.mjs.map +1 -0
  466. package/dist/services/document-service/params.d.ts +3 -1
  467. package/dist/services/document-service/params.d.ts.map +1 -1
  468. package/dist/services/{entity-service → document-service}/params.js +2 -2
  469. package/dist/services/document-service/params.js.map +1 -0
  470. package/dist/services/document-service/params.mjs.map +1 -0
  471. package/dist/services/document-service/repository.d.ts.map +1 -1
  472. package/dist/services/document-service/repository.js +207 -183
  473. package/dist/services/document-service/repository.js.map +1 -1
  474. package/dist/services/document-service/repository.mjs +187 -163
  475. package/dist/services/document-service/repository.mjs.map +1 -1
  476. package/dist/services/document-service/transform/data.d.ts.map +1 -1
  477. package/dist/services/document-service/transform/data.js +4 -2
  478. package/dist/services/document-service/transform/data.js.map +1 -1
  479. package/dist/services/document-service/transform/data.mjs +4 -2
  480. package/dist/services/document-service/transform/data.mjs.map +1 -1
  481. package/dist/services/document-service/transform/fields.d.ts +2 -2
  482. package/dist/services/document-service/transform/fields.d.ts.map +1 -1
  483. package/dist/services/document-service/transform/fields.js.map +1 -1
  484. package/dist/services/document-service/transform/fields.mjs.map +1 -1
  485. package/dist/services/document-service/transform/id-map.d.ts +3 -3
  486. package/dist/services/document-service/transform/id-map.d.ts.map +1 -1
  487. package/dist/services/document-service/transform/id-map.js.map +1 -1
  488. package/dist/services/document-service/transform/id-map.mjs.map +1 -1
  489. package/dist/services/document-service/transform/id-transform.d.ts +2 -2
  490. package/dist/services/document-service/transform/id-transform.d.ts.map +1 -1
  491. package/dist/services/document-service/transform/id-transform.js +2 -2
  492. package/dist/services/document-service/transform/id-transform.js.map +1 -1
  493. package/dist/services/document-service/transform/id-transform.mjs.map +1 -1
  494. package/dist/services/document-service/transform/populate.d.ts +2 -2
  495. package/dist/services/document-service/transform/populate.d.ts.map +1 -1
  496. package/dist/services/document-service/transform/populate.js +1 -1
  497. package/dist/services/document-service/transform/populate.js.map +1 -1
  498. package/dist/services/document-service/transform/populate.mjs +1 -1
  499. package/dist/services/document-service/transform/populate.mjs.map +1 -1
  500. package/dist/services/document-service/transform/query.d.ts +5 -0
  501. package/dist/services/document-service/transform/query.d.ts.map +1 -0
  502. package/dist/services/document-service/transform/query.js +9 -0
  503. package/dist/services/document-service/transform/query.js.map +1 -0
  504. package/dist/services/document-service/transform/query.mjs +9 -0
  505. package/dist/services/document-service/transform/query.mjs.map +1 -0
  506. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts +8 -7
  507. package/dist/services/document-service/transform/relations/extract/data-ids.d.ts.map +1 -1
  508. package/dist/services/document-service/transform/relations/extract/data-ids.js +45 -78
  509. package/dist/services/document-service/transform/relations/extract/data-ids.js.map +1 -1
  510. package/dist/services/document-service/transform/relations/extract/data-ids.mjs +44 -77
  511. package/dist/services/document-service/transform/relations/extract/data-ids.mjs.map +1 -1
  512. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts +8 -4
  513. package/dist/services/document-service/transform/relations/transform/data-ids.d.ts.map +1 -1
  514. package/dist/services/document-service/transform/relations/transform/data-ids.js +61 -126
  515. package/dist/services/document-service/transform/relations/transform/data-ids.js.map +1 -1
  516. package/dist/services/document-service/transform/relations/transform/data-ids.mjs +61 -126
  517. package/dist/services/document-service/transform/relations/transform/data-ids.mjs.map +1 -1
  518. package/dist/services/document-service/transform/relations/transform/default-locale.d.ts +9 -0
  519. package/dist/services/document-service/transform/relations/transform/default-locale.d.ts.map +1 -0
  520. package/dist/services/document-service/transform/relations/transform/default-locale.js +32 -0
  521. package/dist/services/document-service/transform/relations/transform/default-locale.js.map +1 -0
  522. package/dist/services/document-service/transform/relations/transform/default-locale.mjs +32 -0
  523. package/dist/services/document-service/transform/relations/transform/default-locale.mjs.map +1 -0
  524. package/dist/services/document-service/transform/relations/utils/dp.d.ts +3 -3
  525. package/dist/services/document-service/transform/relations/utils/dp.d.ts.map +1 -1
  526. package/dist/services/document-service/transform/relations/utils/dp.js +10 -5
  527. package/dist/services/document-service/transform/relations/utils/dp.js.map +1 -1
  528. package/dist/services/document-service/transform/relations/utils/dp.mjs +9 -4
  529. package/dist/services/document-service/transform/relations/utils/dp.mjs.map +1 -1
  530. package/dist/services/document-service/transform/relations/utils/i18n.d.ts +6 -6
  531. package/dist/services/document-service/transform/relations/utils/i18n.d.ts.map +1 -1
  532. package/dist/services/document-service/transform/relations/utils/i18n.js +3 -9
  533. package/dist/services/document-service/transform/relations/utils/i18n.js.map +1 -1
  534. package/dist/services/document-service/transform/relations/utils/i18n.mjs +3 -9
  535. package/dist/services/document-service/transform/relations/utils/i18n.mjs.map +1 -1
  536. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts +6 -0
  537. package/dist/services/document-service/transform/relations/utils/map-relation.d.ts.map +1 -0
  538. package/dist/services/document-service/transform/relations/utils/map-relation.js +91 -0
  539. package/dist/services/document-service/transform/relations/utils/map-relation.js.map +1 -0
  540. package/dist/services/document-service/transform/relations/utils/map-relation.mjs +91 -0
  541. package/dist/services/document-service/transform/relations/utils/map-relation.mjs.map +1 -0
  542. package/dist/services/document-service/transform/relations/utils/types.d.ts +6 -0
  543. package/dist/services/document-service/transform/relations/utils/types.d.ts.map +1 -1
  544. package/dist/services/document-service/transform/types.d.ts +3 -3
  545. package/dist/services/document-service/transform/types.d.ts.map +1 -1
  546. package/dist/services/document-service/utils/populate.d.ts +9 -2
  547. package/dist/services/document-service/utils/populate.d.ts.map +1 -1
  548. package/dist/services/document-service/utils/populate.js +11 -5
  549. package/dist/services/document-service/utils/populate.js.map +1 -1
  550. package/dist/services/document-service/utils/populate.mjs +11 -5
  551. package/dist/services/document-service/utils/populate.mjs.map +1 -1
  552. package/dist/services/document-service/utils/unidirectional-relations.d.ts +36 -0
  553. package/dist/services/document-service/utils/unidirectional-relations.d.ts.map +1 -0
  554. package/dist/services/document-service/utils/unidirectional-relations.js +69 -0
  555. package/dist/services/document-service/utils/unidirectional-relations.js.map +1 -0
  556. package/dist/services/document-service/utils/unidirectional-relations.mjs +69 -0
  557. package/dist/services/document-service/utils/unidirectional-relations.mjs.map +1 -0
  558. package/dist/services/entity-service/index.d.ts +4 -6
  559. package/dist/services/entity-service/index.d.ts.map +1 -1
  560. package/dist/services/entity-service/index.js +44 -203
  561. package/dist/services/entity-service/index.js.map +1 -1
  562. package/dist/services/entity-service/index.mjs +38 -197
  563. package/dist/services/entity-service/index.mjs.map +1 -1
  564. package/dist/services/entity-validator/blocks-validator.d.ts +1 -2
  565. package/dist/services/entity-validator/blocks-validator.d.ts.map +1 -1
  566. package/dist/services/entity-validator/blocks-validator.js +4 -3
  567. package/dist/services/entity-validator/blocks-validator.js.map +1 -1
  568. package/dist/services/entity-validator/blocks-validator.mjs +3 -3
  569. package/dist/services/entity-validator/blocks-validator.mjs.map +1 -1
  570. package/dist/services/entity-validator/index.d.ts +16 -2
  571. package/dist/services/entity-validator/index.d.ts.map +1 -1
  572. package/dist/services/entity-validator/index.js +197 -130
  573. package/dist/services/entity-validator/index.js.map +1 -1
  574. package/dist/services/entity-validator/index.mjs +192 -125
  575. package/dist/services/entity-validator/index.mjs.map +1 -1
  576. package/dist/services/entity-validator/validators.d.ts +36 -25
  577. package/dist/services/entity-validator/validators.d.ts.map +1 -1
  578. package/dist/services/entity-validator/validators.js +153 -33
  579. package/dist/services/entity-validator/validators.js.map +1 -1
  580. package/dist/services/entity-validator/validators.mjs +145 -25
  581. package/dist/services/entity-validator/validators.mjs.map +1 -1
  582. package/dist/services/event-hub.d.ts +1 -0
  583. package/dist/services/event-hub.d.ts.map +1 -1
  584. package/dist/services/event-hub.js +9 -4
  585. package/dist/services/event-hub.js.map +1 -1
  586. package/dist/services/event-hub.mjs +9 -4
  587. package/dist/services/event-hub.mjs.map +1 -1
  588. package/dist/services/features.d.ts +3 -3
  589. package/dist/services/features.d.ts.map +1 -1
  590. package/dist/services/features.js.map +1 -1
  591. package/dist/services/features.mjs.map +1 -1
  592. package/dist/services/fs.d.ts +2 -2
  593. package/dist/services/fs.d.ts.map +1 -1
  594. package/dist/services/fs.js.map +1 -1
  595. package/dist/services/fs.mjs.map +1 -1
  596. package/dist/services/metrics/admin-user-hash.d.ts +2 -2
  597. package/dist/services/metrics/admin-user-hash.d.ts.map +1 -1
  598. package/dist/services/metrics/admin-user-hash.js.map +1 -1
  599. package/dist/services/metrics/admin-user-hash.mjs.map +1 -1
  600. package/dist/services/metrics/index.d.ts +2 -2
  601. package/dist/services/metrics/index.d.ts.map +1 -1
  602. package/dist/services/metrics/index.js.map +1 -1
  603. package/dist/services/metrics/index.mjs.map +1 -1
  604. package/dist/services/metrics/middleware.d.ts +2 -2
  605. package/dist/services/metrics/middleware.d.ts.map +1 -1
  606. package/dist/services/metrics/middleware.js.map +1 -1
  607. package/dist/services/metrics/middleware.mjs.map +1 -1
  608. package/dist/services/metrics/rate-limiter.d.ts.map +1 -1
  609. package/dist/services/metrics/rate-limiter.js.map +1 -1
  610. package/dist/services/metrics/rate-limiter.mjs.map +1 -1
  611. package/dist/services/metrics/sender.d.ts +3 -3
  612. package/dist/services/metrics/sender.d.ts.map +1 -1
  613. package/dist/services/metrics/sender.js.map +1 -1
  614. package/dist/services/metrics/sender.mjs.map +1 -1
  615. package/dist/services/query-params.d.ts +7 -0
  616. package/dist/services/query-params.d.ts.map +1 -0
  617. package/dist/services/query-params.js +12 -0
  618. package/dist/services/query-params.js.map +1 -0
  619. package/dist/services/query-params.mjs +13 -0
  620. package/dist/services/query-params.mjs.map +1 -0
  621. package/dist/services/reloader.d.ts +7 -0
  622. package/dist/services/reloader.d.ts.map +1 -0
  623. package/dist/services/reloader.js +36 -0
  624. package/dist/services/reloader.js.map +1 -0
  625. package/dist/services/reloader.mjs +36 -0
  626. package/dist/services/reloader.mjs.map +1 -0
  627. package/dist/services/server/admin-api.d.ts +3 -3
  628. package/dist/services/server/admin-api.d.ts.map +1 -1
  629. package/dist/services/server/admin-api.js.map +1 -1
  630. package/dist/services/server/admin-api.mjs.map +1 -1
  631. package/dist/services/server/api.d.ts +3 -3
  632. package/dist/services/server/api.d.ts.map +1 -1
  633. package/dist/services/server/api.js.map +1 -1
  634. package/dist/services/server/api.mjs.map +1 -1
  635. package/dist/services/server/compose-endpoint.d.ts +2 -2
  636. package/dist/services/server/compose-endpoint.d.ts.map +1 -1
  637. package/dist/services/server/compose-endpoint.js +8 -9
  638. package/dist/services/server/compose-endpoint.js.map +1 -1
  639. package/dist/services/server/compose-endpoint.mjs +2 -3
  640. package/dist/services/server/compose-endpoint.mjs.map +1 -1
  641. package/dist/services/server/content-api.d.ts +3 -3
  642. package/dist/services/server/content-api.d.ts.map +1 -1
  643. package/dist/services/server/content-api.js.map +1 -1
  644. package/dist/services/server/content-api.mjs.map +1 -1
  645. package/dist/services/server/http-server.d.ts +2 -2
  646. package/dist/services/server/http-server.d.ts.map +1 -1
  647. package/dist/services/server/http-server.js.map +1 -1
  648. package/dist/services/server/http-server.mjs.map +1 -1
  649. package/dist/services/server/index.d.ts +2 -2
  650. package/dist/services/server/index.d.ts.map +1 -1
  651. package/dist/services/server/index.js +2 -3
  652. package/dist/services/server/index.js.map +1 -1
  653. package/dist/services/server/index.mjs +2 -3
  654. package/dist/services/server/index.mjs.map +1 -1
  655. package/dist/services/server/koa.d.ts.map +1 -1
  656. package/dist/services/server/koa.js +4 -4
  657. package/dist/services/server/koa.js.map +1 -1
  658. package/dist/services/server/koa.mjs +1 -1
  659. package/dist/services/server/koa.mjs.map +1 -1
  660. package/dist/services/server/middleware.d.ts +4 -4
  661. package/dist/services/server/middleware.d.ts.map +1 -1
  662. package/dist/services/server/middleware.js +3 -3
  663. package/dist/services/server/middleware.js.map +1 -1
  664. package/dist/services/server/middleware.mjs.map +1 -1
  665. package/dist/services/server/policy.d.ts +3 -3
  666. package/dist/services/server/policy.d.ts.map +1 -1
  667. package/dist/services/server/policy.js +4 -4
  668. package/dist/services/server/policy.js.map +1 -1
  669. package/dist/services/server/policy.mjs +4 -4
  670. package/dist/services/server/policy.mjs.map +1 -1
  671. package/dist/services/server/register-middlewares.d.ts +2 -2
  672. package/dist/services/server/register-middlewares.d.ts.map +1 -1
  673. package/dist/services/server/register-middlewares.js.map +1 -1
  674. package/dist/services/server/register-middlewares.mjs.map +1 -1
  675. package/dist/services/server/register-routes.d.ts +2 -2
  676. package/dist/services/server/register-routes.d.ts.map +1 -1
  677. package/dist/services/server/register-routes.js +3 -3
  678. package/dist/services/server/register-routes.js.map +1 -1
  679. package/dist/services/server/register-routes.mjs +3 -3
  680. package/dist/services/server/register-routes.mjs.map +1 -1
  681. package/dist/services/server/routing.d.ts +5 -5
  682. package/dist/services/server/routing.d.ts.map +1 -1
  683. package/dist/services/server/routing.js +2 -2
  684. package/dist/services/server/routing.js.map +1 -1
  685. package/dist/services/server/routing.mjs.map +1 -1
  686. package/dist/services/utils/dynamic-zones.d.ts.map +1 -1
  687. package/dist/services/utils/dynamic-zones.js +7 -6
  688. package/dist/services/utils/dynamic-zones.js.map +1 -1
  689. package/dist/services/utils/dynamic-zones.mjs +2 -1
  690. package/dist/services/utils/dynamic-zones.mjs.map +1 -1
  691. package/dist/services/webhook-runner.d.ts +2 -1
  692. package/dist/services/webhook-runner.d.ts.map +1 -1
  693. package/dist/services/webhook-runner.js.map +1 -1
  694. package/dist/services/webhook-runner.mjs.map +1 -1
  695. package/dist/services/webhook-store.d.ts +2 -8
  696. package/dist/services/webhook-store.d.ts.map +1 -1
  697. package/dist/services/webhook-store.js +14 -8
  698. package/dist/services/webhook-store.js.map +1 -1
  699. package/dist/services/webhook-store.mjs +14 -8
  700. package/dist/services/webhook-store.mjs.map +1 -1
  701. package/dist/utils/convert-custom-field-type.d.ts +2 -2
  702. package/dist/utils/convert-custom-field-type.d.ts.map +1 -1
  703. package/dist/utils/convert-custom-field-type.js.map +1 -1
  704. package/dist/utils/convert-custom-field-type.mjs.map +1 -1
  705. package/dist/utils/cron.js +3 -3
  706. package/dist/utils/cron.js.map +1 -1
  707. package/dist/utils/fetch.d.ts +3 -3
  708. package/dist/utils/fetch.d.ts.map +1 -1
  709. package/dist/utils/fetch.js +4 -3
  710. package/dist/utils/fetch.js.map +1 -1
  711. package/dist/utils/fetch.mjs +4 -3
  712. package/dist/utils/fetch.mjs.map +1 -1
  713. package/dist/utils/filepath-to-prop-path.d.ts +1 -1
  714. package/dist/utils/filepath-to-prop-path.d.ts.map +1 -1
  715. package/dist/utils/filepath-to-prop-path.js +27 -6
  716. package/dist/utils/filepath-to-prop-path.js.map +1 -1
  717. package/dist/utils/filepath-to-prop-path.mjs +25 -5
  718. package/dist/utils/filepath-to-prop-path.mjs.map +1 -1
  719. package/dist/utils/index.d.ts +2 -1
  720. package/dist/utils/index.d.ts.map +1 -1
  721. package/dist/utils/is-initialized.d.ts +2 -2
  722. package/dist/utils/is-initialized.d.ts.map +1 -1
  723. package/dist/utils/is-initialized.js +4 -4
  724. package/dist/utils/is-initialized.js.map +1 -1
  725. package/dist/utils/is-initialized.mjs +1 -1
  726. package/dist/utils/is-initialized.mjs.map +1 -1
  727. package/dist/utils/load-files.d.ts.map +1 -1
  728. package/dist/utils/open-browser.d.ts +2 -2
  729. package/dist/utils/open-browser.d.ts.map +1 -1
  730. package/dist/utils/open-browser.js.map +1 -1
  731. package/dist/utils/open-browser.mjs.map +1 -1
  732. package/dist/utils/resolve-working-dirs.d.ts +19 -0
  733. package/dist/utils/resolve-working-dirs.d.ts.map +1 -0
  734. package/dist/utils/resolve-working-dirs.js +13 -0
  735. package/dist/utils/resolve-working-dirs.js.map +1 -0
  736. package/dist/utils/resolve-working-dirs.mjs +11 -0
  737. package/dist/utils/resolve-working-dirs.mjs.map +1 -0
  738. package/dist/utils/signals.d.ts +2 -2
  739. package/dist/utils/signals.d.ts.map +1 -1
  740. package/dist/utils/signals.js.map +1 -1
  741. package/dist/utils/signals.mjs.map +1 -1
  742. package/dist/utils/startup-logger.d.ts +2 -2
  743. package/dist/utils/startup-logger.d.ts.map +1 -1
  744. package/dist/utils/startup-logger.js +4 -4
  745. package/dist/utils/startup-logger.js.map +1 -1
  746. package/dist/utils/startup-logger.mjs +3 -3
  747. package/dist/utils/startup-logger.mjs.map +1 -1
  748. package/dist/utils/transform-content-types-to-models.d.ts +54 -99
  749. package/dist/utils/transform-content-types-to-models.d.ts.map +1 -1
  750. package/dist/utils/transform-content-types-to-models.js +112 -61
  751. package/dist/utils/transform-content-types-to-models.js.map +1 -1
  752. package/dist/utils/transform-content-types-to-models.mjs +111 -60
  753. package/dist/utils/transform-content-types-to-models.mjs.map +1 -1
  754. package/dist/utils/update-notifier/index.d.ts +2 -7
  755. package/dist/utils/update-notifier/index.d.ts.map +1 -1
  756. package/dist/utils/update-notifier/index.js +11 -14
  757. package/dist/utils/update-notifier/index.js.map +1 -1
  758. package/dist/utils/update-notifier/index.mjs +11 -14
  759. package/dist/utils/update-notifier/index.mjs.map +1 -1
  760. package/package.json +35 -31
  761. package/dist/registries/config.d.ts +0 -4
  762. package/dist/registries/config.d.ts.map +0 -1
  763. package/dist/registries/config.js +0 -31
  764. package/dist/registries/config.js.map +0 -1
  765. package/dist/registries/config.mjs +0 -32
  766. package/dist/registries/config.mjs.map +0 -1
  767. package/dist/services/document-service/middlewares.d.ts +0 -8
  768. package/dist/services/document-service/middlewares.d.ts.map +0 -1
  769. package/dist/services/document-service/middlewares.js.map +0 -1
  770. package/dist/services/document-service/middlewares.mjs.map +0 -1
  771. package/dist/services/document-service/transform/filters.d.ts +0 -3
  772. package/dist/services/document-service/transform/filters.d.ts.map +0 -1
  773. package/dist/services/document-service/transform/relations/transform/output-ids.d.ts +0 -4
  774. package/dist/services/document-service/transform/relations/transform/output-ids.d.ts.map +0 -1
  775. package/dist/services/document-service/transform/relations/utils/data.js +0 -12
  776. package/dist/services/document-service/transform/relations/utils/data.js.map +0 -1
  777. package/dist/services/document-service/transform/relations/utils/data.mjs +0 -12
  778. package/dist/services/document-service/transform/relations/utils/data.mjs.map +0 -1
  779. package/dist/services/document-service/transform/sort.d.ts +0 -5
  780. package/dist/services/document-service/transform/sort.d.ts.map +0 -1
  781. package/dist/services/document-service/transform/utils.d.ts +0 -9
  782. package/dist/services/document-service/transform/utils.d.ts.map +0 -1
  783. package/dist/services/entity-service/attributes/index.d.ts +0 -6
  784. package/dist/services/entity-service/attributes/index.d.ts.map +0 -1
  785. package/dist/services/entity-service/attributes/index.js.map +0 -1
  786. package/dist/services/entity-service/attributes/index.mjs.map +0 -1
  787. package/dist/services/entity-service/attributes/transforms.d.ts +0 -10
  788. package/dist/services/entity-service/attributes/transforms.d.ts.map +0 -1
  789. package/dist/services/entity-service/attributes/transforms.js.map +0 -1
  790. package/dist/services/entity-service/attributes/transforms.mjs.map +0 -1
  791. package/dist/services/entity-service/components.d.ts +0 -23
  792. package/dist/services/entity-service/components.d.ts.map +0 -1
  793. package/dist/services/entity-service/components.js.map +0 -1
  794. package/dist/services/entity-service/components.mjs.map +0 -1
  795. package/dist/services/entity-service/params.d.ts +0 -8
  796. package/dist/services/entity-service/params.d.ts.map +0 -1
  797. package/dist/services/entity-service/params.js.map +0 -1
  798. package/dist/services/entity-service/params.mjs.map +0 -1
  799. package/dist/services/utils/upload-files.d.ts +0 -8
  800. package/dist/services/utils/upload-files.d.ts.map +0 -1
  801. package/dist/services/utils/upload-files.js +0 -64
  802. package/dist/services/utils/upload-files.js.map +0 -1
  803. package/dist/services/utils/upload-files.mjs +0 -63
  804. package/dist/services/utils/upload-files.mjs.map +0 -1
  805. package/dist/utils/get-dirs.d.ts +0 -9
  806. package/dist/utils/get-dirs.d.ts.map +0 -1
  807. package/dist/utils/get-dirs.js.map +0 -1
  808. package/dist/utils/get-dirs.mjs.map +0 -1
  809. /package/dist/services/{entity-service → document-service}/attributes/transforms.mjs +0 -0
  810. /package/dist/services/{entity-service → document-service}/params.mjs +0 -0
@@ -1,32 +1,80 @@
1
1
  "use strict";
2
- const _ = require("lodash/fp");
2
+ const fp = require("lodash/fp");
3
3
  const namespace = require("./namespace.js");
4
+ const PLUGIN_PREFIX = "plugin::";
5
+ const API_PREFIX = "api::";
6
+ const parsePolicy = (policy) => {
7
+ if (typeof policy === "string") {
8
+ return { policyName: policy, config: {} };
9
+ }
10
+ const { name, config } = policy;
11
+ return { policyName: name, config };
12
+ };
4
13
  const policiesRegistry = () => {
5
- const policies = {};
14
+ const policies = /* @__PURE__ */ new Map();
15
+ const find = (name, namespaceInfo) => {
16
+ const { pluginName, apiName } = namespaceInfo ?? {};
17
+ const policy = policies.get(name);
18
+ if (policy) {
19
+ return policy;
20
+ }
21
+ if (pluginName) {
22
+ return policies.get(`${PLUGIN_PREFIX}${pluginName}.${name}`);
23
+ }
24
+ if (apiName) {
25
+ return policies.get(`${API_PREFIX}${apiName}.${name}`);
26
+ }
27
+ };
28
+ function resolveHandler(policyConfig, namespaceInfo) {
29
+ if (Array.isArray(policyConfig)) {
30
+ return policyConfig.map((config2) => {
31
+ return resolveHandler(config2, namespaceInfo);
32
+ });
33
+ }
34
+ const { policyName, config } = parsePolicy(policyConfig);
35
+ const policy = find(policyName, namespaceInfo);
36
+ if (!policy) {
37
+ throw new Error(`Policy ${policyName} not found.`);
38
+ }
39
+ if (typeof policy === "function") {
40
+ return policy;
41
+ }
42
+ if (policy.validator) {
43
+ policy.validator(config);
44
+ }
45
+ return policy.handler;
46
+ }
6
47
  return {
7
48
  /**
8
49
  * Returns this list of registered policies uids
9
50
  */
10
51
  keys() {
11
- return Object.keys(policies);
52
+ return Array.from(policies.keys());
12
53
  },
13
54
  /**
14
55
  * Returns the instance of a policy. Instantiate the policy if not already done
15
56
  */
16
- get(uid) {
17
- return policies[uid];
57
+ get(name, namespaceInfo) {
58
+ return find(name, namespaceInfo);
59
+ },
60
+ /**
61
+ * Checks if a policy is registered
62
+ */
63
+ has(name, namespaceInfo) {
64
+ const res = find(name, namespaceInfo);
65
+ return !!res;
18
66
  },
19
67
  /**
20
68
  * Returns a map with all the policies in a namespace
21
69
  */
22
70
  getAll(namespace$1) {
23
- return _.pickBy((_2, uid) => namespace.hasNamespace(uid, namespace$1))(policies);
71
+ return fp.pickBy((_, uid) => namespace.hasNamespace(uid, namespace$1))(Object.fromEntries(policies));
24
72
  },
25
73
  /**
26
74
  * Registers a policy
27
75
  */
28
76
  set(uid, policy) {
29
- policies[uid] = policy;
77
+ policies.set(uid, policy);
30
78
  return this;
31
79
  },
32
80
  /**
@@ -36,25 +84,23 @@ const policiesRegistry = () => {
36
84
  for (const policyName of Object.keys(newPolicies)) {
37
85
  const policy = newPolicies[policyName];
38
86
  const uid = namespace.addNamespace(policyName, namespace$1);
39
- if (_.has(uid, policies)) {
87
+ if (fp.has(uid, policies)) {
40
88
  throw new Error(`Policy ${uid} has already been registered.`);
41
89
  }
42
- policies[uid] = policy;
90
+ policies.set(uid, policy);
43
91
  }
44
92
  },
45
93
  /**
46
- * Wraps a policy to extend it
47
- * @param {string} uid
48
- * @param {(policy: Policy) => Policy} extendFn
94
+ * Resolves a list of policies
49
95
  */
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;
96
+ resolve(config, namespaceInfo) {
97
+ const { pluginName, apiName } = namespaceInfo ?? {};
98
+ return fp.castArray(config).map((policyConfig) => {
99
+ return {
100
+ handler: resolveHandler(policyConfig, { pluginName, apiName }),
101
+ config: typeof policyConfig === "object" && policyConfig.config || {}
102
+ };
103
+ });
58
104
  }
59
105
  };
60
106
  };
@@ -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":["config","namespace","pickBy","hasNamespace","addNamespace","has","castArray"],"mappings":";;;AAIA,MAAM,gBAAgB;AACtB,MAAM,aAAa;AAcnB,MAAM,cAAc,CAAC,WAAgC;AAC/C,MAAA,OAAO,WAAW,UAAU;AAC9B,WAAO,EAAE,YAAY,QAAQ,QAAQ,CAAG,EAAA;AAAA,EAC1C;AAEM,QAAA,EAAE,MAAM,OAAW,IAAA;AAClB,SAAA,EAAE,YAAY,MAAM;AAC7B;AAEA,MAAM,mBAAmB,MAAM;AACvB,QAAA,+BAAe;AAEf,QAAA,OAAO,CAAC,MAAc,kBAAkC;AAC5D,UAAM,EAAE,YAAY,YAAY,iBAAiB,CAAA;AAG3C,UAAA,SAAS,SAAS,IAAI,IAAI;AAEhC,QAAI,QAAQ;AACH,aAAA;AAAA,IACT;AAEA,QAAI,YAAY;AACP,aAAA,SAAS,IAAI,GAAG,aAAa,GAAG,UAAU,IAAI,IAAI,EAAE;AAAA,IAC7D;AAEA,QAAI,SAAS;AACJ,aAAA,SAAS,IAAI,GAAG,UAAU,GAAG,OAAO,IAAI,IAAI,EAAE;AAAA,IACvD;AAAA,EAAA;AAQO,WAAA,eACP,cACA,eAC6B;AACzB,QAAA,MAAM,QAAQ,YAAY,GAAG;AACxB,aAAA,aAAa,IAAI,CAACA,YAAW;AAC3B,eAAA,eAAeA,SAAQ,aAAa;AAAA,MAAA,CAC5C;AAAA,IACH;AAEA,UAAM,EAAE,YAAY,OAAO,IAAI,YAAY,YAAY;AAEjD,UAAA,SAAS,KAAK,YAAY,aAAa;AAE7C,QAAI,CAAC,QAAQ;AACX,YAAM,IAAI,MAAM,UAAU,UAAU,aAAa;AAAA,IACnD;AAEI,QAAA,OAAO,WAAW,YAAY;AACzB,aAAA;AAAA,IACT;AAEA,QAAI,OAAO,WAAW;AACpB,aAAO,UAAU,MAAM;AAAA,IACzB;AAEA,WAAO,OAAO;AAAA,EAChB;AAEO,SAAA;AAAA;AAAA;AAAA;AAAA,IAIL,OAAO;AAEL,aAAO,MAAM,KAAK,SAAS,KAAM,CAAA;AAAA,IACnC;AAAA;AAAA;AAAA;AAAA,IAKA,IAAI,MAAc,eAA+B;AACxC,aAAA,KAAK,MAAM,aAAa;AAAA,IACjC;AAAA;AAAA;AAAA;AAAA,IAIA,IAAI,MAAc,eAA+B;AACzC,YAAA,MAAM,KAAK,MAAM,aAAa;AACpC,aAAO,CAAC,CAAC;AAAA,IACX;AAAA;AAAA;AAAA;AAAA,IAKA,OAAOC,aAAmB;AACxB,aAAOC,UAAO,CAAC,GAAG,QAAQC,UAAAA,aAAa,KAAKF,WAAS,CAAC,EAAE,OAAO,YAAY,QAAQ,CAAC;AAAA,IACtF;AAAA;AAAA;AAAA;AAAA,IAKA,IAAI,KAAa,QAAqB;AAC3B,eAAA,IAAI,KAAK,MAAM;AACjB,aAAA;AAAA,IACT;AAAA;AAAA;AAAA;AAAA,IAKA,IAAIA,aAAmB,aAA0C;AAC/D,iBAAW,cAAc,OAAO,KAAK,WAAW,GAAG;AAC3C,cAAA,SAAS,YAAY,UAAU;AAC/B,cAAA,MAAMG,UAAAA,aAAa,YAAYH,WAAS;AAE1C,YAAAI,GAAA,IAAI,KAAK,QAAQ,GAAG;AACtB,gBAAM,IAAI,MAAM,UAAU,GAAG,+BAA+B;AAAA,QAC9D;AAES,iBAAA,IAAI,KAAK,MAAM;AAAA,MAC1B;AAAA,IACF;AAAA;AAAA;AAAA;AAAA,IAKA,QAAQ,QAAuC,eAA+B;AAC5E,YAAM,EAAE,YAAY,YAAY,iBAAiB,CAAA;AAEjD,aAAOC,GAAU,UAAA,MAAM,EAAE,IAAI,CAAC,iBAAiB;AACtC,eAAA;AAAA,UACL,SAAS,eAAe,cAAc,EAAE,YAAY,SAAS;AAAA,UAC7D,QAAS,OAAO,iBAAiB,YAAY,aAAa,UAAW,CAAC;AAAA,QAAA;AAAA,MACxE,CACD;AAAA,IACH;AAAA,EAAA;AAEJ;;"}
@@ -1,31 +1,79 @@
1
- import { pickBy, has } from "lodash/fp";
1
+ import { pickBy, has, castArray } from "lodash/fp";
2
2
  import { hasNamespace, addNamespace } from "./namespace.mjs";
3
+ const PLUGIN_PREFIX = "plugin::";
4
+ const API_PREFIX = "api::";
5
+ const parsePolicy = (policy) => {
6
+ if (typeof policy === "string") {
7
+ return { policyName: policy, config: {} };
8
+ }
9
+ const { name, config } = policy;
10
+ return { policyName: name, config };
11
+ };
3
12
  const policiesRegistry = () => {
4
- const policies = {};
13
+ const policies = /* @__PURE__ */ new Map();
14
+ const find = (name, namespaceInfo) => {
15
+ const { pluginName, apiName } = namespaceInfo ?? {};
16
+ const policy = policies.get(name);
17
+ if (policy) {
18
+ return policy;
19
+ }
20
+ if (pluginName) {
21
+ return policies.get(`${PLUGIN_PREFIX}${pluginName}.${name}`);
22
+ }
23
+ if (apiName) {
24
+ return policies.get(`${API_PREFIX}${apiName}.${name}`);
25
+ }
26
+ };
27
+ function resolveHandler(policyConfig, namespaceInfo) {
28
+ if (Array.isArray(policyConfig)) {
29
+ return policyConfig.map((config2) => {
30
+ return resolveHandler(config2, namespaceInfo);
31
+ });
32
+ }
33
+ const { policyName, config } = parsePolicy(policyConfig);
34
+ const policy = find(policyName, namespaceInfo);
35
+ if (!policy) {
36
+ throw new Error(`Policy ${policyName} not found.`);
37
+ }
38
+ if (typeof policy === "function") {
39
+ return policy;
40
+ }
41
+ if (policy.validator) {
42
+ policy.validator(config);
43
+ }
44
+ return policy.handler;
45
+ }
5
46
  return {
6
47
  /**
7
48
  * Returns this list of registered policies uids
8
49
  */
9
50
  keys() {
10
- return Object.keys(policies);
51
+ return Array.from(policies.keys());
11
52
  },
12
53
  /**
13
54
  * Returns the instance of a policy. Instantiate the policy if not already done
14
55
  */
15
- get(uid) {
16
- return policies[uid];
56
+ get(name, namespaceInfo) {
57
+ return find(name, namespaceInfo);
58
+ },
59
+ /**
60
+ * Checks if a policy is registered
61
+ */
62
+ has(name, namespaceInfo) {
63
+ const res = find(name, namespaceInfo);
64
+ return !!res;
17
65
  },
18
66
  /**
19
67
  * Returns a map with all the policies in a namespace
20
68
  */
21
69
  getAll(namespace) {
22
- return pickBy((_, uid) => hasNamespace(uid, namespace))(policies);
70
+ return pickBy((_, uid) => hasNamespace(uid, namespace))(Object.fromEntries(policies));
23
71
  },
24
72
  /**
25
73
  * Registers a policy
26
74
  */
27
75
  set(uid, policy) {
28
- policies[uid] = policy;
76
+ policies.set(uid, policy);
29
77
  return this;
30
78
  },
31
79
  /**
@@ -38,22 +86,20 @@ const policiesRegistry = () => {
38
86
  if (has(uid, policies)) {
39
87
  throw new Error(`Policy ${uid} has already been registered.`);
40
88
  }
41
- policies[uid] = policy;
89
+ policies.set(uid, policy);
42
90
  }
43
91
  },
44
92
  /**
45
- * Wraps a policy to extend it
46
- * @param {string} uid
47
- * @param {(policy: Policy) => Policy} extendFn
93
+ * Resolves a list of policies
48
94
  */
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;
95
+ resolve(config, namespaceInfo) {
96
+ const { pluginName, apiName } = namespaceInfo ?? {};
97
+ return castArray(config).map((policyConfig) => {
98
+ return {
99
+ handler: resolveHandler(policyConfig, { pluginName, apiName }),
100
+ config: typeof policyConfig === "object" && policyConfig.config || {}
101
+ };
102
+ });
57
103
  }
58
104
  };
59
105
  };
@@ -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":["config"],"mappings":";;AAIA,MAAM,gBAAgB;AACtB,MAAM,aAAa;AAcnB,MAAM,cAAc,CAAC,WAAgC;AAC/C,MAAA,OAAO,WAAW,UAAU;AAC9B,WAAO,EAAE,YAAY,QAAQ,QAAQ,CAAG,EAAA;AAAA,EAC1C;AAEM,QAAA,EAAE,MAAM,OAAW,IAAA;AAClB,SAAA,EAAE,YAAY,MAAM;AAC7B;AAEA,MAAM,mBAAmB,MAAM;AACvB,QAAA,+BAAe;AAEf,QAAA,OAAO,CAAC,MAAc,kBAAkC;AAC5D,UAAM,EAAE,YAAY,YAAY,iBAAiB,CAAA;AAG3C,UAAA,SAAS,SAAS,IAAI,IAAI;AAEhC,QAAI,QAAQ;AACH,aAAA;AAAA,IACT;AAEA,QAAI,YAAY;AACP,aAAA,SAAS,IAAI,GAAG,aAAa,GAAG,UAAU,IAAI,IAAI,EAAE;AAAA,IAC7D;AAEA,QAAI,SAAS;AACJ,aAAA,SAAS,IAAI,GAAG,UAAU,GAAG,OAAO,IAAI,IAAI,EAAE;AAAA,IACvD;AAAA,EAAA;AAQO,WAAA,eACP,cACA,eAC6B;AACzB,QAAA,MAAM,QAAQ,YAAY,GAAG;AACxB,aAAA,aAAa,IAAI,CAACA,YAAW;AAC3B,eAAA,eAAeA,SAAQ,aAAa;AAAA,MAAA,CAC5C;AAAA,IACH;AAEA,UAAM,EAAE,YAAY,OAAO,IAAI,YAAY,YAAY;AAEjD,UAAA,SAAS,KAAK,YAAY,aAAa;AAE7C,QAAI,CAAC,QAAQ;AACX,YAAM,IAAI,MAAM,UAAU,UAAU,aAAa;AAAA,IACnD;AAEI,QAAA,OAAO,WAAW,YAAY;AACzB,aAAA;AAAA,IACT;AAEA,QAAI,OAAO,WAAW;AACpB,aAAO,UAAU,MAAM;AAAA,IACzB;AAEA,WAAO,OAAO;AAAA,EAChB;AAEO,SAAA;AAAA;AAAA;AAAA;AAAA,IAIL,OAAO;AAEL,aAAO,MAAM,KAAK,SAAS,KAAM,CAAA;AAAA,IACnC;AAAA;AAAA;AAAA;AAAA,IAKA,IAAI,MAAc,eAA+B;AACxC,aAAA,KAAK,MAAM,aAAa;AAAA,IACjC;AAAA;AAAA;AAAA;AAAA,IAIA,IAAI,MAAc,eAA+B;AACzC,YAAA,MAAM,KAAK,MAAM,aAAa;AACpC,aAAO,CAAC,CAAC;AAAA,IACX;AAAA;AAAA;AAAA;AAAA,IAKA,OAAO,WAAmB;AACxB,aAAO,OAAO,CAAC,GAAG,QAAQ,aAAa,KAAK,SAAS,CAAC,EAAE,OAAO,YAAY,QAAQ,CAAC;AAAA,IACtF;AAAA;AAAA;AAAA;AAAA,IAKA,IAAI,KAAa,QAAqB;AAC3B,eAAA,IAAI,KAAK,MAAM;AACjB,aAAA;AAAA,IACT;AAAA;AAAA;AAAA;AAAA,IAKA,IAAI,WAAmB,aAA0C;AAC/D,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;AAES,iBAAA,IAAI,KAAK,MAAM;AAAA,MAC1B;AAAA,IACF;AAAA;AAAA;AAAA;AAAA,IAKA,QAAQ,QAAuC,eAA+B;AAC5E,YAAM,EAAE,YAAY,YAAY,iBAAiB,CAAA;AAEjD,aAAO,UAAU,MAAM,EAAE,IAAI,CAAC,iBAAiB;AACtC,eAAA;AAAA,UACL,SAAS,eAAe,cAAc,EAAE,YAAY,SAAS;AAAA,UAC7D,QAAS,OAAO,iBAAiB,YAAY,aAAa,UAAW,CAAC;AAAA,QAAA;AAAA,MACxE,CACD;AAAA,IACH;AAAA,EAAA;AAEJ;"}
@@ -1,11 +1,11 @@
1
- import type { Strapi, Common } from '@strapi/types';
1
+ import type { Core, UID } from '@strapi/types';
2
2
  export type ServiceFactory = (params: {
3
- strapi: Strapi;
4
- }) => Common.Service | Common.Service;
3
+ strapi: Core.Strapi;
4
+ }) => Core.Service | Core.Service;
5
5
  export type ServiceFactoryMap = Record<string, ServiceFactory>;
6
- export type ServiceMap = Record<string, Common.Service>;
7
- export type ServiceExtendFn = (service: Common.Service) => Common.Service;
8
- declare const servicesRegistry: (strapi: Strapi) => {
6
+ export type ServiceMap = Record<string, Core.Service>;
7
+ export type ServiceExtendFn = (service: Core.Service) => Core.Service;
8
+ declare const servicesRegistry: (strapi: Core.Strapi) => {
9
9
  /**
10
10
  * Returns this list of registered services uids
11
11
  */
@@ -13,7 +13,7 @@ declare const servicesRegistry: (strapi: Strapi) => {
13
13
  /**
14
14
  * Returns the instance of a service. Instantiate the service if not already done
15
15
  */
16
- get(uid: Common.UID.Service): Common.Service | undefined;
16
+ get(uid: UID.Service): Core.Service | undefined;
17
17
  /**
18
18
  * Returns a map with all the services in a namespace
19
19
  */
@@ -29,7 +29,7 @@ declare const servicesRegistry: (strapi: Strapi) => {
29
29
  /**
30
30
  * Wraps a service to extend it
31
31
  */
32
- extend(uid: Common.UID.Service, extendFn: ServiceExtendFn): any;
32
+ extend(uid: UID.Service, extendFn: ServiceExtendFn): any;
33
33
  };
34
34
  export default servicesRegistry;
35
35
  //# sourceMappingURL=services.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"services.d.ts","sourceRoot":"","sources":["../../src/registries/services.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAGpD,MAAM,MAAM,cAAc,GAAG,CAAC,MAAM,EAAE;IAAE,MAAM,EAAE,MAAM,CAAA;CAAE,KAAK,MAAM,CAAC,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC;AAC7F,MAAM,MAAM,iBAAiB,GAAG,MAAM,CAAC,MAAM,EAAE,cAAc,CAAC,CAAC;AAC/D,MAAM,MAAM,UAAU,GAAG,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,OAAO,CAAC,CAAC;AACxD,MAAM,MAAM,eAAe,GAAG,CAAC,OAAO,EAAE,MAAM,CAAC,OAAO,KAAK,MAAM,CAAC,OAAO,CAAC;AAE1E,QAAA,MAAM,gBAAgB,WAAY,MAAM;IAKpC;;OAEG;;IAKH;;OAEG;aACM,OAAO,GAAG,CAAC,OAAO;IAY3B;;OAEG;sBACe,MAAM,GAAG,UAAU;IAiBrC;;OAEG;aACM,MAAM,WAAW,cAAc;IAMxC;;OAEG;mBACY,MAAM,eAAe,iBAAiB;IAcrD;;OAEG;gBACS,OAAO,GAAG,CAAC,OAAO,YAAY,eAAe;CAa5D,CAAC;AAEF,eAAe,gBAAgB,CAAC"}
1
+ {"version":3,"file":"services.d.ts","sourceRoot":"","sources":["../../src/registries/services.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,MAAM,eAAe,CAAC;AAG/C,MAAM,MAAM,cAAc,GAAG,CAAC,MAAM,EAAE;IAAE,MAAM,EAAE,IAAI,CAAC,MAAM,CAAA;CAAE,KAAK,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;AAC9F,MAAM,MAAM,iBAAiB,GAAG,MAAM,CAAC,MAAM,EAAE,cAAc,CAAC,CAAC;AAC/D,MAAM,MAAM,UAAU,GAAG,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;AACtD,MAAM,MAAM,eAAe,GAAG,CAAC,OAAO,EAAE,IAAI,CAAC,OAAO,KAAK,IAAI,CAAC,OAAO,CAAC;AAEtE,QAAA,MAAM,gBAAgB,WAAY,KAAK,MAAM;IAKzC;;OAEG;;IAKH;;OAEG;aACM,IAAI,OAAO;IAYpB;;OAEG;sBACe,MAAM,GAAG,UAAU;IAiBrC;;OAEG;aACM,MAAM,WAAW,cAAc;IAMxC;;OAEG;mBACY,MAAM,eAAe,iBAAiB;IAcrD;;OAEG;gBACS,IAAI,OAAO,YAAY,eAAe;CAarD,CAAC;AAEF,eAAe,gBAAgB,CAAC"}
@@ -1,5 +1,5 @@
1
1
  "use strict";
2
- const _ = require("lodash/fp");
2
+ const fp = require("lodash/fp");
3
3
  const namespace = require("./namespace.js");
4
4
  const servicesRegistry = (strapi) => {
5
5
  const services = {};
@@ -28,7 +28,7 @@ const servicesRegistry = (strapi) => {
28
28
  * Returns a map with all the services in a namespace
29
29
  */
30
30
  getAll(namespace$1) {
31
- const filteredServices = _.pickBy((_2, uid) => namespace.hasNamespace(uid, namespace$1))(services);
31
+ const filteredServices = fp.pickBy((_, uid) => namespace.hasNamespace(uid, namespace$1))(services);
32
32
  const map = {};
33
33
  for (const uid of Object.keys(filteredServices)) {
34
34
  Object.defineProperty(map, uid, {
@@ -55,7 +55,7 @@ const servicesRegistry = (strapi) => {
55
55
  for (const serviceName of Object.keys(newServices)) {
56
56
  const service = newServices[serviceName];
57
57
  const uid = namespace.addNamespace(serviceName, namespace$1);
58
- if (_.has(uid, services)) {
58
+ if (fp.has(uid, services)) {
59
59
  throw new Error(`Service ${uid} has already been registered.`);
60
60
  }
61
61
  services[uid] = service;
@@ -1 +1 @@
1
- {"version":3,"file":"services.js","sources":["../../src/registries/services.ts"],"sourcesContent":["import { pickBy, has } from 'lodash/fp';\nimport type { Strapi, Common } from '@strapi/types';\nimport { addNamespace, hasNamespace } from './namespace';\n\nexport type ServiceFactory = (params: { strapi: Strapi }) => Common.Service | Common.Service;\nexport type ServiceFactoryMap = Record<string, ServiceFactory>;\nexport type ServiceMap = Record<string, Common.Service>;\nexport type ServiceExtendFn = (service: Common.Service) => Common.Service;\n\nconst servicesRegistry = (strapi: Strapi) => {\n const services: ServiceFactoryMap = {};\n const instantiatedServices: ServiceMap = {};\n\n return {\n /**\n * Returns this list of registered services uids\n */\n keys() {\n return Object.keys(services);\n },\n\n /**\n * Returns the instance of a service. Instantiate the service if not already done\n */\n get(uid: Common.UID.Service) {\n if (instantiatedServices[uid]) {\n return instantiatedServices[uid];\n }\n\n const service = services[uid];\n if (service) {\n instantiatedServices[uid] = typeof service === 'function' ? service({ strapi }) : service;\n return instantiatedServices[uid];\n }\n },\n\n /**\n * Returns a map with all the services in a namespace\n */\n getAll(namespace: string): ServiceMap {\n const filteredServices = pickBy((_, uid) => hasNamespace(uid, namespace))(services);\n\n // create lazy accessor to avoid instantiating the services;\n const map = {};\n for (const uid of Object.keys(filteredServices)) {\n Object.defineProperty(map, uid, {\n enumerable: true,\n get: () => {\n return this.get(uid as Common.UID.Service);\n },\n });\n }\n\n return map;\n },\n\n /**\n * Registers a service\n */\n set(uid: string, service: ServiceFactory) {\n services[uid] = service;\n delete instantiatedServices[uid];\n return this;\n },\n\n /**\n * Registers a map of services for a specific namespace\n */\n add(namespace: string, newServices: ServiceFactoryMap) {\n for (const serviceName of Object.keys(newServices)) {\n const service = newServices[serviceName];\n const uid = addNamespace(serviceName, namespace);\n\n if (has(uid, services)) {\n throw new Error(`Service ${uid} has already been registered.`);\n }\n services[uid] = service;\n }\n\n return this;\n },\n\n /**\n * Wraps a service to extend it\n */\n extend(uid: Common.UID.Service, extendFn: ServiceExtendFn) {\n const currentService = this.get(uid);\n\n if (!currentService) {\n throw new Error(`Service ${uid} doesn't exist`);\n }\n\n const newService = extendFn(currentService);\n instantiatedServices[uid] = newService;\n\n return this;\n },\n };\n};\n\nexport default servicesRegistry;\n"],"names":["namespace","pickBy","_","hasNamespace","addNamespace","has"],"mappings":";;;AASM,MAAA,mBAAmB,CAAC,WAAmB;AAC3C,QAAM,WAA8B,CAAA;AACpC,QAAM,uBAAmC,CAAA;AAElC,SAAA;AAAA;AAAA;AAAA;AAAA,IAIL,OAAO;AACE,aAAA,OAAO,KAAK,QAAQ;AAAA,IAC7B;AAAA;AAAA;AAAA;AAAA,IAKA,IAAI,KAAyB;AACvB,UAAA,qBAAqB,GAAG,GAAG;AAC7B,eAAO,qBAAqB,GAAG;AAAA,MACjC;AAEM,YAAA,UAAU,SAAS,GAAG;AAC5B,UAAI,SAAS;AACU,6BAAA,GAAG,IAAI,OAAO,YAAY,aAAa,QAAQ,EAAE,QAAQ,IAAI;AAClF,eAAO,qBAAqB,GAAG;AAAA,MACjC;AAAA,IACF;AAAA;AAAA;AAAA;AAAA,IAKA,OAAOA,aAA+B;AAC9B,YAAA,mBAAmBC,EAAAA,OAAO,CAACC,IAAG,QAAQC,uBAAa,KAAKH,WAAS,CAAC,EAAE,QAAQ;AAGlF,YAAM,MAAM,CAAA;AACZ,iBAAW,OAAO,OAAO,KAAK,gBAAgB,GAAG;AACxC,eAAA,eAAe,KAAK,KAAK;AAAA,UAC9B,YAAY;AAAA,UACZ,KAAK,MAAM;AACF,mBAAA,KAAK,IAAI,GAAyB;AAAA,UAC3C;AAAA,QAAA,CACD;AAAA,MACH;AAEO,aAAA;AAAA,IACT;AAAA;AAAA;AAAA;AAAA,IAKA,IAAI,KAAa,SAAyB;AACxC,eAAS,GAAG,IAAI;AAChB,aAAO,qBAAqB,GAAG;AACxB,aAAA;AAAA,IACT;AAAA;AAAA;AAAA;AAAA,IAKA,IAAIA,aAAmB,aAAgC;AACrD,iBAAW,eAAe,OAAO,KAAK,WAAW,GAAG;AAC5C,cAAA,UAAU,YAAY,WAAW;AACjC,cAAA,MAAMI,UAAAA,aAAa,aAAaJ,WAAS;AAE3C,YAAAK,EAAA,IAAI,KAAK,QAAQ,GAAG;AACtB,gBAAM,IAAI,MAAM,WAAW,GAAG,+BAA+B;AAAA,QAC/D;AACA,iBAAS,GAAG,IAAI;AAAA,MAClB;AAEO,aAAA;AAAA,IACT;AAAA;AAAA;AAAA;AAAA,IAKA,OAAO,KAAyB,UAA2B;AACnD,YAAA,iBAAiB,KAAK,IAAI,GAAG;AAEnC,UAAI,CAAC,gBAAgB;AACnB,cAAM,IAAI,MAAM,WAAW,GAAG,gBAAgB;AAAA,MAChD;AAEM,YAAA,aAAa,SAAS,cAAc;AAC1C,2BAAqB,GAAG,IAAI;AAErB,aAAA;AAAA,IACT;AAAA,EAAA;AAEJ;;"}
1
+ {"version":3,"file":"services.js","sources":["../../src/registries/services.ts"],"sourcesContent":["import { pickBy, has } from 'lodash/fp';\nimport type { Core, UID } from '@strapi/types';\nimport { addNamespace, hasNamespace } from './namespace';\n\nexport type ServiceFactory = (params: { strapi: Core.Strapi }) => Core.Service | Core.Service;\nexport type ServiceFactoryMap = Record<string, ServiceFactory>;\nexport type ServiceMap = Record<string, Core.Service>;\nexport type ServiceExtendFn = (service: Core.Service) => Core.Service;\n\nconst servicesRegistry = (strapi: Core.Strapi) => {\n const services: ServiceFactoryMap = {};\n const instantiatedServices: ServiceMap = {};\n\n return {\n /**\n * Returns this list of registered services uids\n */\n keys() {\n return Object.keys(services);\n },\n\n /**\n * Returns the instance of a service. Instantiate the service if not already done\n */\n get(uid: UID.Service) {\n if (instantiatedServices[uid]) {\n return instantiatedServices[uid];\n }\n\n const service = services[uid];\n if (service) {\n instantiatedServices[uid] = typeof service === 'function' ? service({ strapi }) : service;\n return instantiatedServices[uid];\n }\n },\n\n /**\n * Returns a map with all the services in a namespace\n */\n getAll(namespace: string): ServiceMap {\n const filteredServices = pickBy((_, uid) => hasNamespace(uid, namespace))(services);\n\n // create lazy accessor to avoid instantiating the services;\n const map = {};\n for (const uid of Object.keys(filteredServices)) {\n Object.defineProperty(map, uid, {\n enumerable: true,\n get: () => {\n return this.get(uid as UID.Service);\n },\n });\n }\n\n return map;\n },\n\n /**\n * Registers a service\n */\n set(uid: string, service: ServiceFactory) {\n services[uid] = service;\n delete instantiatedServices[uid];\n return this;\n },\n\n /**\n * Registers a map of services for a specific namespace\n */\n add(namespace: string, newServices: ServiceFactoryMap) {\n for (const serviceName of Object.keys(newServices)) {\n const service = newServices[serviceName];\n const uid = addNamespace(serviceName, namespace);\n\n if (has(uid, services)) {\n throw new Error(`Service ${uid} has already been registered.`);\n }\n services[uid] = service;\n }\n\n return this;\n },\n\n /**\n * Wraps a service to extend it\n */\n extend(uid: UID.Service, extendFn: ServiceExtendFn) {\n const currentService = this.get(uid);\n\n if (!currentService) {\n throw new Error(`Service ${uid} doesn't exist`);\n }\n\n const newService = extendFn(currentService);\n instantiatedServices[uid] = newService;\n\n return this;\n },\n };\n};\n\nexport default servicesRegistry;\n"],"names":["namespace","pickBy","hasNamespace","addNamespace","has"],"mappings":";;;AASM,MAAA,mBAAmB,CAAC,WAAwB;AAChD,QAAM,WAA8B,CAAA;AACpC,QAAM,uBAAmC,CAAA;AAElC,SAAA;AAAA;AAAA;AAAA;AAAA,IAIL,OAAO;AACE,aAAA,OAAO,KAAK,QAAQ;AAAA,IAC7B;AAAA;AAAA;AAAA;AAAA,IAKA,IAAI,KAAkB;AAChB,UAAA,qBAAqB,GAAG,GAAG;AAC7B,eAAO,qBAAqB,GAAG;AAAA,MACjC;AAEM,YAAA,UAAU,SAAS,GAAG;AAC5B,UAAI,SAAS;AACU,6BAAA,GAAG,IAAI,OAAO,YAAY,aAAa,QAAQ,EAAE,QAAQ,IAAI;AAClF,eAAO,qBAAqB,GAAG;AAAA,MACjC;AAAA,IACF;AAAA;AAAA;AAAA;AAAA,IAKA,OAAOA,aAA+B;AAC9B,YAAA,mBAAmBC,GAAAA,OAAO,CAAC,GAAG,QAAQC,uBAAa,KAAKF,WAAS,CAAC,EAAE,QAAQ;AAGlF,YAAM,MAAM,CAAA;AACZ,iBAAW,OAAO,OAAO,KAAK,gBAAgB,GAAG;AACxC,eAAA,eAAe,KAAK,KAAK;AAAA,UAC9B,YAAY;AAAA,UACZ,KAAK,MAAM;AACF,mBAAA,KAAK,IAAI,GAAkB;AAAA,UACpC;AAAA,QAAA,CACD;AAAA,MACH;AAEO,aAAA;AAAA,IACT;AAAA;AAAA;AAAA;AAAA,IAKA,IAAI,KAAa,SAAyB;AACxC,eAAS,GAAG,IAAI;AAChB,aAAO,qBAAqB,GAAG;AACxB,aAAA;AAAA,IACT;AAAA;AAAA;AAAA;AAAA,IAKA,IAAIA,aAAmB,aAAgC;AACrD,iBAAW,eAAe,OAAO,KAAK,WAAW,GAAG;AAC5C,cAAA,UAAU,YAAY,WAAW;AACjC,cAAA,MAAMG,UAAAA,aAAa,aAAaH,WAAS;AAE3C,YAAAI,GAAA,IAAI,KAAK,QAAQ,GAAG;AACtB,gBAAM,IAAI,MAAM,WAAW,GAAG,+BAA+B;AAAA,QAC/D;AACA,iBAAS,GAAG,IAAI;AAAA,MAClB;AAEO,aAAA;AAAA,IACT;AAAA;AAAA;AAAA;AAAA,IAKA,OAAO,KAAkB,UAA2B;AAC5C,YAAA,iBAAiB,KAAK,IAAI,GAAG;AAEnC,UAAI,CAAC,gBAAgB;AACnB,cAAM,IAAI,MAAM,WAAW,GAAG,gBAAgB;AAAA,MAChD;AAEM,YAAA,aAAa,SAAS,cAAc;AAC1C,2BAAqB,GAAG,IAAI;AAErB,aAAA;AAAA,IACT;AAAA,EAAA;AAEJ;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"services.mjs","sources":["../../src/registries/services.ts"],"sourcesContent":["import { pickBy, has } from 'lodash/fp';\nimport type { Strapi, Common } from '@strapi/types';\nimport { addNamespace, hasNamespace } from './namespace';\n\nexport type ServiceFactory = (params: { strapi: Strapi }) => Common.Service | Common.Service;\nexport type ServiceFactoryMap = Record<string, ServiceFactory>;\nexport type ServiceMap = Record<string, Common.Service>;\nexport type ServiceExtendFn = (service: Common.Service) => Common.Service;\n\nconst servicesRegistry = (strapi: Strapi) => {\n const services: ServiceFactoryMap = {};\n const instantiatedServices: ServiceMap = {};\n\n return {\n /**\n * Returns this list of registered services uids\n */\n keys() {\n return Object.keys(services);\n },\n\n /**\n * Returns the instance of a service. Instantiate the service if not already done\n */\n get(uid: Common.UID.Service) {\n if (instantiatedServices[uid]) {\n return instantiatedServices[uid];\n }\n\n const service = services[uid];\n if (service) {\n instantiatedServices[uid] = typeof service === 'function' ? service({ strapi }) : service;\n return instantiatedServices[uid];\n }\n },\n\n /**\n * Returns a map with all the services in a namespace\n */\n getAll(namespace: string): ServiceMap {\n const filteredServices = pickBy((_, uid) => hasNamespace(uid, namespace))(services);\n\n // create lazy accessor to avoid instantiating the services;\n const map = {};\n for (const uid of Object.keys(filteredServices)) {\n Object.defineProperty(map, uid, {\n enumerable: true,\n get: () => {\n return this.get(uid as Common.UID.Service);\n },\n });\n }\n\n return map;\n },\n\n /**\n * Registers a service\n */\n set(uid: string, service: ServiceFactory) {\n services[uid] = service;\n delete instantiatedServices[uid];\n return this;\n },\n\n /**\n * Registers a map of services for a specific namespace\n */\n add(namespace: string, newServices: ServiceFactoryMap) {\n for (const serviceName of Object.keys(newServices)) {\n const service = newServices[serviceName];\n const uid = addNamespace(serviceName, namespace);\n\n if (has(uid, services)) {\n throw new Error(`Service ${uid} has already been registered.`);\n }\n services[uid] = service;\n }\n\n return this;\n },\n\n /**\n * Wraps a service to extend it\n */\n extend(uid: Common.UID.Service, extendFn: ServiceExtendFn) {\n const currentService = this.get(uid);\n\n if (!currentService) {\n throw new Error(`Service ${uid} doesn't exist`);\n }\n\n const newService = extendFn(currentService);\n instantiatedServices[uid] = newService;\n\n return this;\n },\n };\n};\n\nexport default servicesRegistry;\n"],"names":[],"mappings":";;AASM,MAAA,mBAAmB,CAAC,WAAmB;AAC3C,QAAM,WAA8B,CAAA;AACpC,QAAM,uBAAmC,CAAA;AAElC,SAAA;AAAA;AAAA;AAAA;AAAA,IAIL,OAAO;AACE,aAAA,OAAO,KAAK,QAAQ;AAAA,IAC7B;AAAA;AAAA;AAAA;AAAA,IAKA,IAAI,KAAyB;AACvB,UAAA,qBAAqB,GAAG,GAAG;AAC7B,eAAO,qBAAqB,GAAG;AAAA,MACjC;AAEM,YAAA,UAAU,SAAS,GAAG;AAC5B,UAAI,SAAS;AACU,6BAAA,GAAG,IAAI,OAAO,YAAY,aAAa,QAAQ,EAAE,QAAQ,IAAI;AAClF,eAAO,qBAAqB,GAAG;AAAA,MACjC;AAAA,IACF;AAAA;AAAA;AAAA;AAAA,IAKA,OAAO,WAA+B;AAC9B,YAAA,mBAAmB,OAAO,CAAC,GAAG,QAAQ,aAAa,KAAK,SAAS,CAAC,EAAE,QAAQ;AAGlF,YAAM,MAAM,CAAA;AACZ,iBAAW,OAAO,OAAO,KAAK,gBAAgB,GAAG;AACxC,eAAA,eAAe,KAAK,KAAK;AAAA,UAC9B,YAAY;AAAA,UACZ,KAAK,MAAM;AACF,mBAAA,KAAK,IAAI,GAAyB;AAAA,UAC3C;AAAA,QAAA,CACD;AAAA,MACH;AAEO,aAAA;AAAA,IACT;AAAA;AAAA;AAAA;AAAA,IAKA,IAAI,KAAa,SAAyB;AACxC,eAAS,GAAG,IAAI;AAChB,aAAO,qBAAqB,GAAG;AACxB,aAAA;AAAA,IACT;AAAA;AAAA;AAAA;AAAA,IAKA,IAAI,WAAmB,aAAgC;AACrD,iBAAW,eAAe,OAAO,KAAK,WAAW,GAAG;AAC5C,cAAA,UAAU,YAAY,WAAW;AACjC,cAAA,MAAM,aAAa,aAAa,SAAS;AAE3C,YAAA,IAAI,KAAK,QAAQ,GAAG;AACtB,gBAAM,IAAI,MAAM,WAAW,GAAG,+BAA+B;AAAA,QAC/D;AACA,iBAAS,GAAG,IAAI;AAAA,MAClB;AAEO,aAAA;AAAA,IACT;AAAA;AAAA;AAAA;AAAA,IAKA,OAAO,KAAyB,UAA2B;AACnD,YAAA,iBAAiB,KAAK,IAAI,GAAG;AAEnC,UAAI,CAAC,gBAAgB;AACnB,cAAM,IAAI,MAAM,WAAW,GAAG,gBAAgB;AAAA,MAChD;AAEM,YAAA,aAAa,SAAS,cAAc;AAC1C,2BAAqB,GAAG,IAAI;AAErB,aAAA;AAAA,IACT;AAAA,EAAA;AAEJ;"}
1
+ {"version":3,"file":"services.mjs","sources":["../../src/registries/services.ts"],"sourcesContent":["import { pickBy, has } from 'lodash/fp';\nimport type { Core, UID } from '@strapi/types';\nimport { addNamespace, hasNamespace } from './namespace';\n\nexport type ServiceFactory = (params: { strapi: Core.Strapi }) => Core.Service | Core.Service;\nexport type ServiceFactoryMap = Record<string, ServiceFactory>;\nexport type ServiceMap = Record<string, Core.Service>;\nexport type ServiceExtendFn = (service: Core.Service) => Core.Service;\n\nconst servicesRegistry = (strapi: Core.Strapi) => {\n const services: ServiceFactoryMap = {};\n const instantiatedServices: ServiceMap = {};\n\n return {\n /**\n * Returns this list of registered services uids\n */\n keys() {\n return Object.keys(services);\n },\n\n /**\n * Returns the instance of a service. Instantiate the service if not already done\n */\n get(uid: UID.Service) {\n if (instantiatedServices[uid]) {\n return instantiatedServices[uid];\n }\n\n const service = services[uid];\n if (service) {\n instantiatedServices[uid] = typeof service === 'function' ? service({ strapi }) : service;\n return instantiatedServices[uid];\n }\n },\n\n /**\n * Returns a map with all the services in a namespace\n */\n getAll(namespace: string): ServiceMap {\n const filteredServices = pickBy((_, uid) => hasNamespace(uid, namespace))(services);\n\n // create lazy accessor to avoid instantiating the services;\n const map = {};\n for (const uid of Object.keys(filteredServices)) {\n Object.defineProperty(map, uid, {\n enumerable: true,\n get: () => {\n return this.get(uid as UID.Service);\n },\n });\n }\n\n return map;\n },\n\n /**\n * Registers a service\n */\n set(uid: string, service: ServiceFactory) {\n services[uid] = service;\n delete instantiatedServices[uid];\n return this;\n },\n\n /**\n * Registers a map of services for a specific namespace\n */\n add(namespace: string, newServices: ServiceFactoryMap) {\n for (const serviceName of Object.keys(newServices)) {\n const service = newServices[serviceName];\n const uid = addNamespace(serviceName, namespace);\n\n if (has(uid, services)) {\n throw new Error(`Service ${uid} has already been registered.`);\n }\n services[uid] = service;\n }\n\n return this;\n },\n\n /**\n * Wraps a service to extend it\n */\n extend(uid: UID.Service, extendFn: ServiceExtendFn) {\n const currentService = this.get(uid);\n\n if (!currentService) {\n throw new Error(`Service ${uid} doesn't exist`);\n }\n\n const newService = extendFn(currentService);\n instantiatedServices[uid] = newService;\n\n return this;\n },\n };\n};\n\nexport default servicesRegistry;\n"],"names":[],"mappings":";;AASM,MAAA,mBAAmB,CAAC,WAAwB;AAChD,QAAM,WAA8B,CAAA;AACpC,QAAM,uBAAmC,CAAA;AAElC,SAAA;AAAA;AAAA;AAAA;AAAA,IAIL,OAAO;AACE,aAAA,OAAO,KAAK,QAAQ;AAAA,IAC7B;AAAA;AAAA;AAAA;AAAA,IAKA,IAAI,KAAkB;AAChB,UAAA,qBAAqB,GAAG,GAAG;AAC7B,eAAO,qBAAqB,GAAG;AAAA,MACjC;AAEM,YAAA,UAAU,SAAS,GAAG;AAC5B,UAAI,SAAS;AACU,6BAAA,GAAG,IAAI,OAAO,YAAY,aAAa,QAAQ,EAAE,QAAQ,IAAI;AAClF,eAAO,qBAAqB,GAAG;AAAA,MACjC;AAAA,IACF;AAAA;AAAA;AAAA;AAAA,IAKA,OAAO,WAA+B;AAC9B,YAAA,mBAAmB,OAAO,CAAC,GAAG,QAAQ,aAAa,KAAK,SAAS,CAAC,EAAE,QAAQ;AAGlF,YAAM,MAAM,CAAA;AACZ,iBAAW,OAAO,OAAO,KAAK,gBAAgB,GAAG;AACxC,eAAA,eAAe,KAAK,KAAK;AAAA,UAC9B,YAAY;AAAA,UACZ,KAAK,MAAM;AACF,mBAAA,KAAK,IAAI,GAAkB;AAAA,UACpC;AAAA,QAAA,CACD;AAAA,MACH;AAEO,aAAA;AAAA,IACT;AAAA;AAAA;AAAA;AAAA,IAKA,IAAI,KAAa,SAAyB;AACxC,eAAS,GAAG,IAAI;AAChB,aAAO,qBAAqB,GAAG;AACxB,aAAA;AAAA,IACT;AAAA;AAAA;AAAA;AAAA,IAKA,IAAI,WAAmB,aAAgC;AACrD,iBAAW,eAAe,OAAO,KAAK,WAAW,GAAG;AAC5C,cAAA,UAAU,YAAY,WAAW;AACjC,cAAA,MAAM,aAAa,aAAa,SAAS;AAE3C,YAAA,IAAI,KAAK,QAAQ,GAAG;AACtB,gBAAM,IAAI,MAAM,WAAW,GAAG,+BAA+B;AAAA,QAC/D;AACA,iBAAS,GAAG,IAAI;AAAA,MAClB;AAEO,aAAA;AAAA,IACT;AAAA;AAAA;AAAA;AAAA,IAKA,OAAO,KAAkB,UAA2B;AAC5C,YAAA,iBAAiB,KAAK,IAAI,GAAG;AAEnC,UAAI,CAAC,gBAAgB;AACnB,cAAM,IAAI,MAAM,WAAW,GAAG,gBAAgB;AAAA,MAChD;AAEM,YAAA,aAAa,SAAS,cAAc;AAC1C,2BAAqB,GAAG,IAAI;AAErB,aAAA;AAAA,IACT;AAAA,EAAA;AAEJ;"}
@@ -1,4 +1,4 @@
1
- import type { Common } from '@strapi/types';
1
+ import type { Core } from '@strapi/types';
2
2
  import type { ParameterizedContext } from 'koa';
3
3
  interface AuthenticationResponse {
4
4
  authenticated?: boolean;
@@ -14,12 +14,12 @@ interface AuthenticationInfo {
14
14
  interface Strategy {
15
15
  name: string;
16
16
  authenticate: (ctx: ParameterizedContext) => Promise<AuthenticationResponse>;
17
- verify?: (auth: AuthenticationInfo, config: Common.RouteConfig['auth']) => Promise<any>;
17
+ verify?: (auth: AuthenticationInfo, config: Core.RouteConfig['auth']) => Promise<any>;
18
18
  }
19
19
  interface Authentication {
20
20
  register: (type: string, strategy: Strategy) => Authentication;
21
- authenticate: Common.MiddlewareHandler;
22
- verify: (auth: AuthenticationInfo, config?: Common.RouteConfig['auth']) => Promise<any>;
21
+ authenticate: Core.MiddlewareHandler;
22
+ verify: (auth: AuthenticationInfo, config?: Core.RouteConfig['auth']) => Promise<any>;
23
23
  }
24
24
  declare const createAuthentication: () => Authentication;
25
25
  export default createAuthentication;
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/services/auth/index.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,KAAK,CAAC;AAEhD,UAAU,sBAAsB;IAC9B,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,KAAK,CAAC,EAAE,KAAK,GAAG,IAAI,CAAC;CACtB;AAED,UAAU,kBAAkB;IAC1B,QAAQ,EAAE,QAAQ,CAAC;IACnB,WAAW,EAAE,OAAO,CAAC;IACrB,OAAO,EAAE,OAAO,CAAC;CAClB;AAED,UAAU,QAAQ;IAChB,IAAI,EAAE,MAAM,CAAC;IACb,YAAY,EAAE,CAAC,GAAG,EAAE,oBAAoB,KAAK,OAAO,CAAC,sBAAsB,CAAC,CAAC;IAC7E,MAAM,CAAC,EAAE,CAAC,IAAI,EAAE,kBAAkB,EAAE,MAAM,EAAE,MAAM,CAAC,WAAW,CAAC,MAAM,CAAC,KAAK,OAAO,CAAC,GAAG,CAAC,CAAC;CACzF;AAED,UAAU,cAAc;IACtB,QAAQ,EAAE,CAAC,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,KAAK,cAAc,CAAC;IAC/D,YAAY,EAAE,MAAM,CAAC,iBAAiB,CAAC;IACvC,MAAM,EAAE,CAAC,IAAI,EAAE,kBAAkB,EAAE,MAAM,CAAC,EAAE,MAAM,CAAC,WAAW,CAAC,MAAM,CAAC,KAAK,OAAO,CAAC,GAAG,CAAC,CAAC;CACzF;AAcD,QAAA,MAAM,oBAAoB,QAAO,cA4FhC,CAAC;AAEF,eAAe,oBAAoB,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/services/auth/index.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAC1C,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,KAAK,CAAC;AAEhD,UAAU,sBAAsB;IAC9B,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,KAAK,CAAC,EAAE,KAAK,GAAG,IAAI,CAAC;CACtB;AAED,UAAU,kBAAkB;IAC1B,QAAQ,EAAE,QAAQ,CAAC;IACnB,WAAW,EAAE,OAAO,CAAC;IACrB,OAAO,EAAE,OAAO,CAAC;CAClB;AAED,UAAU,QAAQ;IAChB,IAAI,EAAE,MAAM,CAAC;IACb,YAAY,EAAE,CAAC,GAAG,EAAE,oBAAoB,KAAK,OAAO,CAAC,sBAAsB,CAAC,CAAC;IAC7E,MAAM,CAAC,EAAE,CAAC,IAAI,EAAE,kBAAkB,EAAE,MAAM,EAAE,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,KAAK,OAAO,CAAC,GAAG,CAAC,CAAC;CACvF;AAED,UAAU,cAAc;IACtB,QAAQ,EAAE,CAAC,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,KAAK,cAAc,CAAC;IAC/D,YAAY,EAAE,IAAI,CAAC,iBAAiB,CAAC;IACrC,MAAM,EAAE,CAAC,IAAI,EAAE,kBAAkB,EAAE,MAAM,CAAC,EAAE,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,KAAK,OAAO,CAAC,GAAG,CAAC,CAAC;CACvF;AAcD,QAAA,MAAM,oBAAoB,QAAO,cA4FhC,CAAC;AAEF,eAAe,oBAAoB,CAAC"}
@@ -1,14 +1,14 @@
1
1
  "use strict";
2
2
  const assert = require("assert/strict");
3
- const _ = require("lodash/fp");
3
+ const fp = require("lodash/fp");
4
4
  const strapiUtils = require("@strapi/utils");
5
5
  const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
6
6
  const assert__default = /* @__PURE__ */ _interopDefault(assert);
7
7
  const INVALID_STRATEGY_MSG = "Invalid auth strategy. Expecting an object with properties {name: string, authenticate: function, verify: function}";
8
8
  const validStrategy = (strategy) => {
9
- assert__default.default(_.has("authenticate", strategy), INVALID_STRATEGY_MSG);
9
+ assert__default.default(fp.has("authenticate", strategy), INVALID_STRATEGY_MSG);
10
10
  assert__default.default(typeof strategy.authenticate === "function", INVALID_STRATEGY_MSG);
11
- if (_.has("verify", strategy)) {
11
+ if (fp.has("verify", strategy)) {
12
12
  assert__default.default(typeof strategy.verify === "function", INVALID_STRATEGY_MSG);
13
13
  }
14
14
  };
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../../src/services/auth/index.ts"],"sourcesContent":["import assert from 'assert/strict';\nimport { has } from 'lodash/fp';\n\nimport { errors } from '@strapi/utils';\nimport type { Common } from '@strapi/types';\nimport type { ParameterizedContext } from 'koa';\n\ninterface AuthenticationResponse {\n authenticated?: boolean;\n credentials?: unknown;\n ability?: unknown;\n error?: Error | null;\n}\n\ninterface AuthenticationInfo {\n strategy: Strategy;\n credentials: unknown;\n ability: unknown;\n}\n\ninterface Strategy {\n name: string;\n authenticate: (ctx: ParameterizedContext) => Promise<AuthenticationResponse>;\n verify?: (auth: AuthenticationInfo, config: Common.RouteConfig['auth']) => Promise<any>;\n}\n\ninterface Authentication {\n register: (type: string, strategy: Strategy) => Authentication;\n authenticate: Common.MiddlewareHandler;\n verify: (auth: AuthenticationInfo, config?: Common.RouteConfig['auth']) => Promise<any>;\n}\n\nconst INVALID_STRATEGY_MSG =\n 'Invalid auth strategy. Expecting an object with properties {name: string, authenticate: function, verify: function}';\n\nconst validStrategy = (strategy: Strategy) => {\n assert(has('authenticate', strategy), INVALID_STRATEGY_MSG);\n assert(typeof strategy.authenticate === 'function', INVALID_STRATEGY_MSG);\n\n if (has('verify', strategy)) {\n assert(typeof strategy.verify === 'function', INVALID_STRATEGY_MSG);\n }\n};\n\nconst createAuthentication = (): Authentication => {\n const strategies: Record<string, Strategy[]> = {};\n\n return {\n register(type, strategy) {\n validStrategy(strategy);\n\n if (!strategies[type]) {\n strategies[type] = [];\n }\n\n strategies[type].push(strategy);\n\n return this;\n },\n\n async authenticate(ctx, next) {\n const route: Common.Route = ctx.state.route;\n\n // use route strategy\n const config = route?.config?.auth;\n\n if (config === false) {\n return next();\n }\n\n const routeStrategies = route.info.type ? strategies[route.info.type] : [];\n const configStrategies = (config?.strategies ?? routeStrategies ?? []) as Array<\n string | Strategy\n >;\n\n const strategiesToUse: Strategy[] = configStrategies.reduce(\n (acc, strategy: string | Strategy) => {\n // Resolve by strategy name\n if (typeof strategy === 'string') {\n const routeStrategy = routeStrategies.find((rs) => rs.name === strategy);\n\n if (routeStrategy) {\n acc.push(routeStrategy);\n }\n }\n\n // Use the given strategy as is\n else if (typeof strategy === 'object') {\n validStrategy(strategy);\n\n acc.push(strategy);\n }\n\n return acc;\n },\n [] as Strategy[]\n );\n\n for (const strategy of strategiesToUse) {\n const result = await strategy.authenticate(ctx);\n\n const { authenticated = false, credentials, ability = null, error = null } = result || {};\n\n if (error !== null) {\n return ctx.unauthorized(error);\n }\n\n if (authenticated) {\n ctx.state.isAuthenticated = true;\n ctx.state.auth = {\n strategy,\n credentials,\n ability,\n };\n\n return next();\n }\n }\n\n return ctx.unauthorized('Missing or invalid credentials');\n },\n\n async verify(auth, config = {}) {\n if (config === false) {\n return;\n }\n\n if (!auth) {\n throw new errors.UnauthorizedError();\n }\n\n if (typeof auth.strategy.verify === 'function') {\n return auth.strategy.verify(auth, config);\n }\n },\n };\n};\n\nexport default createAuthentication;\n"],"names":["assert","has","errors"],"mappings":";;;;;;AAgCA,MAAM,uBACJ;AAEF,MAAM,gBAAgB,CAAC,aAAuB;AAC5CA,kBAAAA,QAAOC,EAAAA,IAAI,gBAAgB,QAAQ,GAAG,oBAAoB;AAC1DD,kBAAAA,QAAO,OAAO,SAAS,iBAAiB,YAAY,oBAAoB;AAEpE,MAAAC,EAAA,IAAI,UAAU,QAAQ,GAAG;AAC3BD,oBAAAA,QAAO,OAAO,SAAS,WAAW,YAAY,oBAAoB;AAAA,EACpE;AACF;AAEA,MAAM,uBAAuB,MAAsB;AACjD,QAAM,aAAyC,CAAA;AAExC,SAAA;AAAA,IACL,SAAS,MAAM,UAAU;AACvB,oBAAc,QAAQ;AAElB,UAAA,CAAC,WAAW,IAAI,GAAG;AACV,mBAAA,IAAI,IAAI;MACrB;AAEW,iBAAA,IAAI,EAAE,KAAK,QAAQ;AAEvB,aAAA;AAAA,IACT;AAAA,IAEA,MAAM,aAAa,KAAK,MAAM;AACtB,YAAA,QAAsB,IAAI,MAAM;AAGhC,YAAA,SAAS,OAAO,QAAQ;AAE9B,UAAI,WAAW,OAAO;AACpB,eAAO,KAAK;AAAA,MACd;AAEM,YAAA,kBAAkB,MAAM,KAAK,OAAO,WAAW,MAAM,KAAK,IAAI,IAAI;AACxE,YAAM,mBAAoB,QAAQ,cAAc,mBAAmB,CAAA;AAInE,YAAM,kBAA8B,iBAAiB;AAAA,QACnD,CAAC,KAAK,aAAgC;AAEhC,cAAA,OAAO,aAAa,UAAU;AAChC,kBAAM,gBAAgB,gBAAgB,KAAK,CAAC,OAAO,GAAG,SAAS,QAAQ;AAEvE,gBAAI,eAAe;AACjB,kBAAI,KAAK,aAAa;AAAA,YACxB;AAAA,UAAA,WAIO,OAAO,aAAa,UAAU;AACrC,0BAAc,QAAQ;AAEtB,gBAAI,KAAK,QAAQ;AAAA,UACnB;AAEO,iBAAA;AAAA,QACT;AAAA,QACA,CAAC;AAAA,MAAA;AAGH,iBAAW,YAAY,iBAAiB;AACtC,cAAM,SAAS,MAAM,SAAS,aAAa,GAAG;AAExC,cAAA,EAAE,gBAAgB,OAAO,aAAa,UAAU,MAAM,QAAQ,KAAA,IAAS,UAAU;AAEvF,YAAI,UAAU,MAAM;AACX,iBAAA,IAAI,aAAa,KAAK;AAAA,QAC/B;AAEA,YAAI,eAAe;AACjB,cAAI,MAAM,kBAAkB;AAC5B,cAAI,MAAM,OAAO;AAAA,YACf;AAAA,YACA;AAAA,YACA;AAAA,UAAA;AAGF,iBAAO,KAAK;AAAA,QACd;AAAA,MACF;AAEO,aAAA,IAAI,aAAa,gCAAgC;AAAA,IAC1D;AAAA,IAEA,MAAM,OAAO,MAAM,SAAS,IAAI;AAC9B,UAAI,WAAW,OAAO;AACpB;AAAA,MACF;AAEA,UAAI,CAAC,MAAM;AACH,cAAA,IAAIE,YAAAA,OAAO;MACnB;AAEA,UAAI,OAAO,KAAK,SAAS,WAAW,YAAY;AAC9C,eAAO,KAAK,SAAS,OAAO,MAAM,MAAM;AAAA,MAC1C;AAAA,IACF;AAAA,EAAA;AAEJ;;"}
1
+ {"version":3,"file":"index.js","sources":["../../../src/services/auth/index.ts"],"sourcesContent":["import assert from 'assert/strict';\nimport { has } from 'lodash/fp';\n\nimport { errors } from '@strapi/utils';\nimport type { Core } from '@strapi/types';\nimport type { ParameterizedContext } from 'koa';\n\ninterface AuthenticationResponse {\n authenticated?: boolean;\n credentials?: unknown;\n ability?: unknown;\n error?: Error | null;\n}\n\ninterface AuthenticationInfo {\n strategy: Strategy;\n credentials: unknown;\n ability: unknown;\n}\n\ninterface Strategy {\n name: string;\n authenticate: (ctx: ParameterizedContext) => Promise<AuthenticationResponse>;\n verify?: (auth: AuthenticationInfo, config: Core.RouteConfig['auth']) => Promise<any>;\n}\n\ninterface Authentication {\n register: (type: string, strategy: Strategy) => Authentication;\n authenticate: Core.MiddlewareHandler;\n verify: (auth: AuthenticationInfo, config?: Core.RouteConfig['auth']) => Promise<any>;\n}\n\nconst INVALID_STRATEGY_MSG =\n 'Invalid auth strategy. Expecting an object with properties {name: string, authenticate: function, verify: function}';\n\nconst validStrategy = (strategy: Strategy) => {\n assert(has('authenticate', strategy), INVALID_STRATEGY_MSG);\n assert(typeof strategy.authenticate === 'function', INVALID_STRATEGY_MSG);\n\n if (has('verify', strategy)) {\n assert(typeof strategy.verify === 'function', INVALID_STRATEGY_MSG);\n }\n};\n\nconst createAuthentication = (): Authentication => {\n const strategies: Record<string, Strategy[]> = {};\n\n return {\n register(type, strategy) {\n validStrategy(strategy);\n\n if (!strategies[type]) {\n strategies[type] = [];\n }\n\n strategies[type].push(strategy);\n\n return this;\n },\n\n async authenticate(ctx, next) {\n const route: Core.Route = ctx.state.route;\n\n // use route strategy\n const config = route?.config?.auth;\n\n if (config === false) {\n return next();\n }\n\n const routeStrategies = route.info.type ? strategies[route.info.type] : [];\n const configStrategies = (config?.strategies ?? routeStrategies ?? []) as Array<\n string | Strategy\n >;\n\n const strategiesToUse: Strategy[] = configStrategies.reduce(\n (acc, strategy: string | Strategy) => {\n // Resolve by strategy name\n if (typeof strategy === 'string') {\n const routeStrategy = routeStrategies.find((rs) => rs.name === strategy);\n\n if (routeStrategy) {\n acc.push(routeStrategy);\n }\n }\n\n // Use the given strategy as is\n else if (typeof strategy === 'object') {\n validStrategy(strategy);\n\n acc.push(strategy);\n }\n\n return acc;\n },\n [] as Strategy[]\n );\n\n for (const strategy of strategiesToUse) {\n const result = await strategy.authenticate(ctx);\n\n const { authenticated = false, credentials, ability = null, error = null } = result || {};\n\n if (error !== null) {\n return ctx.unauthorized(error);\n }\n\n if (authenticated) {\n ctx.state.isAuthenticated = true;\n ctx.state.auth = {\n strategy,\n credentials,\n ability,\n };\n\n return next();\n }\n }\n\n return ctx.unauthorized('Missing or invalid credentials');\n },\n\n async verify(auth, config = {}) {\n if (config === false) {\n return;\n }\n\n if (!auth) {\n throw new errors.UnauthorizedError();\n }\n\n if (typeof auth.strategy.verify === 'function') {\n return auth.strategy.verify(auth, config);\n }\n },\n };\n};\n\nexport default createAuthentication;\n"],"names":["assert","has","errors"],"mappings":";;;;;;AAgCA,MAAM,uBACJ;AAEF,MAAM,gBAAgB,CAAC,aAAuB;AAC5CA,kBAAAA,QAAOC,GAAAA,IAAI,gBAAgB,QAAQ,GAAG,oBAAoB;AAC1DD,kBAAAA,QAAO,OAAO,SAAS,iBAAiB,YAAY,oBAAoB;AAEpE,MAAAC,GAAA,IAAI,UAAU,QAAQ,GAAG;AAC3BD,oBAAAA,QAAO,OAAO,SAAS,WAAW,YAAY,oBAAoB;AAAA,EACpE;AACF;AAEA,MAAM,uBAAuB,MAAsB;AACjD,QAAM,aAAyC,CAAA;AAExC,SAAA;AAAA,IACL,SAAS,MAAM,UAAU;AACvB,oBAAc,QAAQ;AAElB,UAAA,CAAC,WAAW,IAAI,GAAG;AACV,mBAAA,IAAI,IAAI;MACrB;AAEW,iBAAA,IAAI,EAAE,KAAK,QAAQ;AAEvB,aAAA;AAAA,IACT;AAAA,IAEA,MAAM,aAAa,KAAK,MAAM;AACtB,YAAA,QAAoB,IAAI,MAAM;AAG9B,YAAA,SAAS,OAAO,QAAQ;AAE9B,UAAI,WAAW,OAAO;AACpB,eAAO,KAAK;AAAA,MACd;AAEM,YAAA,kBAAkB,MAAM,KAAK,OAAO,WAAW,MAAM,KAAK,IAAI,IAAI;AACxE,YAAM,mBAAoB,QAAQ,cAAc,mBAAmB,CAAA;AAInE,YAAM,kBAA8B,iBAAiB;AAAA,QACnD,CAAC,KAAK,aAAgC;AAEhC,cAAA,OAAO,aAAa,UAAU;AAChC,kBAAM,gBAAgB,gBAAgB,KAAK,CAAC,OAAO,GAAG,SAAS,QAAQ;AAEvE,gBAAI,eAAe;AACjB,kBAAI,KAAK,aAAa;AAAA,YACxB;AAAA,UAAA,WAIO,OAAO,aAAa,UAAU;AACrC,0BAAc,QAAQ;AAEtB,gBAAI,KAAK,QAAQ;AAAA,UACnB;AAEO,iBAAA;AAAA,QACT;AAAA,QACA,CAAC;AAAA,MAAA;AAGH,iBAAW,YAAY,iBAAiB;AACtC,cAAM,SAAS,MAAM,SAAS,aAAa,GAAG;AAExC,cAAA,EAAE,gBAAgB,OAAO,aAAa,UAAU,MAAM,QAAQ,KAAA,IAAS,UAAU;AAEvF,YAAI,UAAU,MAAM;AACX,iBAAA,IAAI,aAAa,KAAK;AAAA,QAC/B;AAEA,YAAI,eAAe;AACjB,cAAI,MAAM,kBAAkB;AAC5B,cAAI,MAAM,OAAO;AAAA,YACf;AAAA,YACA;AAAA,YACA;AAAA,UAAA;AAGF,iBAAO,KAAK;AAAA,QACd;AAAA,MACF;AAEO,aAAA,IAAI,aAAa,gCAAgC;AAAA,IAC1D;AAAA,IAEA,MAAM,OAAO,MAAM,SAAS,IAAI;AAC9B,UAAI,WAAW,OAAO;AACpB;AAAA,MACF;AAEA,UAAI,CAAC,MAAM;AACH,cAAA,IAAIE,YAAAA,OAAO;MACnB;AAEA,UAAI,OAAO,KAAK,SAAS,WAAW,YAAY;AAC9C,eAAO,KAAK,SAAS,OAAO,MAAM,MAAM;AAAA,MAC1C;AAAA,IACF;AAAA,EAAA;AAEJ;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"index.mjs","sources":["../../../src/services/auth/index.ts"],"sourcesContent":["import assert from 'assert/strict';\nimport { has } from 'lodash/fp';\n\nimport { errors } from '@strapi/utils';\nimport type { Common } from '@strapi/types';\nimport type { ParameterizedContext } from 'koa';\n\ninterface AuthenticationResponse {\n authenticated?: boolean;\n credentials?: unknown;\n ability?: unknown;\n error?: Error | null;\n}\n\ninterface AuthenticationInfo {\n strategy: Strategy;\n credentials: unknown;\n ability: unknown;\n}\n\ninterface Strategy {\n name: string;\n authenticate: (ctx: ParameterizedContext) => Promise<AuthenticationResponse>;\n verify?: (auth: AuthenticationInfo, config: Common.RouteConfig['auth']) => Promise<any>;\n}\n\ninterface Authentication {\n register: (type: string, strategy: Strategy) => Authentication;\n authenticate: Common.MiddlewareHandler;\n verify: (auth: AuthenticationInfo, config?: Common.RouteConfig['auth']) => Promise<any>;\n}\n\nconst INVALID_STRATEGY_MSG =\n 'Invalid auth strategy. Expecting an object with properties {name: string, authenticate: function, verify: function}';\n\nconst validStrategy = (strategy: Strategy) => {\n assert(has('authenticate', strategy), INVALID_STRATEGY_MSG);\n assert(typeof strategy.authenticate === 'function', INVALID_STRATEGY_MSG);\n\n if (has('verify', strategy)) {\n assert(typeof strategy.verify === 'function', INVALID_STRATEGY_MSG);\n }\n};\n\nconst createAuthentication = (): Authentication => {\n const strategies: Record<string, Strategy[]> = {};\n\n return {\n register(type, strategy) {\n validStrategy(strategy);\n\n if (!strategies[type]) {\n strategies[type] = [];\n }\n\n strategies[type].push(strategy);\n\n return this;\n },\n\n async authenticate(ctx, next) {\n const route: Common.Route = ctx.state.route;\n\n // use route strategy\n const config = route?.config?.auth;\n\n if (config === false) {\n return next();\n }\n\n const routeStrategies = route.info.type ? strategies[route.info.type] : [];\n const configStrategies = (config?.strategies ?? routeStrategies ?? []) as Array<\n string | Strategy\n >;\n\n const strategiesToUse: Strategy[] = configStrategies.reduce(\n (acc, strategy: string | Strategy) => {\n // Resolve by strategy name\n if (typeof strategy === 'string') {\n const routeStrategy = routeStrategies.find((rs) => rs.name === strategy);\n\n if (routeStrategy) {\n acc.push(routeStrategy);\n }\n }\n\n // Use the given strategy as is\n else if (typeof strategy === 'object') {\n validStrategy(strategy);\n\n acc.push(strategy);\n }\n\n return acc;\n },\n [] as Strategy[]\n );\n\n for (const strategy of strategiesToUse) {\n const result = await strategy.authenticate(ctx);\n\n const { authenticated = false, credentials, ability = null, error = null } = result || {};\n\n if (error !== null) {\n return ctx.unauthorized(error);\n }\n\n if (authenticated) {\n ctx.state.isAuthenticated = true;\n ctx.state.auth = {\n strategy,\n credentials,\n ability,\n };\n\n return next();\n }\n }\n\n return ctx.unauthorized('Missing or invalid credentials');\n },\n\n async verify(auth, config = {}) {\n if (config === false) {\n return;\n }\n\n if (!auth) {\n throw new errors.UnauthorizedError();\n }\n\n if (typeof auth.strategy.verify === 'function') {\n return auth.strategy.verify(auth, config);\n }\n },\n };\n};\n\nexport default createAuthentication;\n"],"names":[],"mappings":";;;AAgCA,MAAM,uBACJ;AAEF,MAAM,gBAAgB,CAAC,aAAuB;AAC5C,SAAO,IAAI,gBAAgB,QAAQ,GAAG,oBAAoB;AAC1D,SAAO,OAAO,SAAS,iBAAiB,YAAY,oBAAoB;AAEpE,MAAA,IAAI,UAAU,QAAQ,GAAG;AAC3B,WAAO,OAAO,SAAS,WAAW,YAAY,oBAAoB;AAAA,EACpE;AACF;AAEA,MAAM,uBAAuB,MAAsB;AACjD,QAAM,aAAyC,CAAA;AAExC,SAAA;AAAA,IACL,SAAS,MAAM,UAAU;AACvB,oBAAc,QAAQ;AAElB,UAAA,CAAC,WAAW,IAAI,GAAG;AACV,mBAAA,IAAI,IAAI;MACrB;AAEW,iBAAA,IAAI,EAAE,KAAK,QAAQ;AAEvB,aAAA;AAAA,IACT;AAAA,IAEA,MAAM,aAAa,KAAK,MAAM;AACtB,YAAA,QAAsB,IAAI,MAAM;AAGhC,YAAA,SAAS,OAAO,QAAQ;AAE9B,UAAI,WAAW,OAAO;AACpB,eAAO,KAAK;AAAA,MACd;AAEM,YAAA,kBAAkB,MAAM,KAAK,OAAO,WAAW,MAAM,KAAK,IAAI,IAAI;AACxE,YAAM,mBAAoB,QAAQ,cAAc,mBAAmB,CAAA;AAInE,YAAM,kBAA8B,iBAAiB;AAAA,QACnD,CAAC,KAAK,aAAgC;AAEhC,cAAA,OAAO,aAAa,UAAU;AAChC,kBAAM,gBAAgB,gBAAgB,KAAK,CAAC,OAAO,GAAG,SAAS,QAAQ;AAEvE,gBAAI,eAAe;AACjB,kBAAI,KAAK,aAAa;AAAA,YACxB;AAAA,UAAA,WAIO,OAAO,aAAa,UAAU;AACrC,0BAAc,QAAQ;AAEtB,gBAAI,KAAK,QAAQ;AAAA,UACnB;AAEO,iBAAA;AAAA,QACT;AAAA,QACA,CAAC;AAAA,MAAA;AAGH,iBAAW,YAAY,iBAAiB;AACtC,cAAM,SAAS,MAAM,SAAS,aAAa,GAAG;AAExC,cAAA,EAAE,gBAAgB,OAAO,aAAa,UAAU,MAAM,QAAQ,KAAA,IAAS,UAAU;AAEvF,YAAI,UAAU,MAAM;AACX,iBAAA,IAAI,aAAa,KAAK;AAAA,QAC/B;AAEA,YAAI,eAAe;AACjB,cAAI,MAAM,kBAAkB;AAC5B,cAAI,MAAM,OAAO;AAAA,YACf;AAAA,YACA;AAAA,YACA;AAAA,UAAA;AAGF,iBAAO,KAAK;AAAA,QACd;AAAA,MACF;AAEO,aAAA,IAAI,aAAa,gCAAgC;AAAA,IAC1D;AAAA,IAEA,MAAM,OAAO,MAAM,SAAS,IAAI;AAC9B,UAAI,WAAW,OAAO;AACpB;AAAA,MACF;AAEA,UAAI,CAAC,MAAM;AACH,cAAA,IAAI,OAAO;MACnB;AAEA,UAAI,OAAO,KAAK,SAAS,WAAW,YAAY;AAC9C,eAAO,KAAK,SAAS,OAAO,MAAM,MAAM;AAAA,MAC1C;AAAA,IACF;AAAA,EAAA;AAEJ;"}
1
+ {"version":3,"file":"index.mjs","sources":["../../../src/services/auth/index.ts"],"sourcesContent":["import assert from 'assert/strict';\nimport { has } from 'lodash/fp';\n\nimport { errors } from '@strapi/utils';\nimport type { Core } from '@strapi/types';\nimport type { ParameterizedContext } from 'koa';\n\ninterface AuthenticationResponse {\n authenticated?: boolean;\n credentials?: unknown;\n ability?: unknown;\n error?: Error | null;\n}\n\ninterface AuthenticationInfo {\n strategy: Strategy;\n credentials: unknown;\n ability: unknown;\n}\n\ninterface Strategy {\n name: string;\n authenticate: (ctx: ParameterizedContext) => Promise<AuthenticationResponse>;\n verify?: (auth: AuthenticationInfo, config: Core.RouteConfig['auth']) => Promise<any>;\n}\n\ninterface Authentication {\n register: (type: string, strategy: Strategy) => Authentication;\n authenticate: Core.MiddlewareHandler;\n verify: (auth: AuthenticationInfo, config?: Core.RouteConfig['auth']) => Promise<any>;\n}\n\nconst INVALID_STRATEGY_MSG =\n 'Invalid auth strategy. Expecting an object with properties {name: string, authenticate: function, verify: function}';\n\nconst validStrategy = (strategy: Strategy) => {\n assert(has('authenticate', strategy), INVALID_STRATEGY_MSG);\n assert(typeof strategy.authenticate === 'function', INVALID_STRATEGY_MSG);\n\n if (has('verify', strategy)) {\n assert(typeof strategy.verify === 'function', INVALID_STRATEGY_MSG);\n }\n};\n\nconst createAuthentication = (): Authentication => {\n const strategies: Record<string, Strategy[]> = {};\n\n return {\n register(type, strategy) {\n validStrategy(strategy);\n\n if (!strategies[type]) {\n strategies[type] = [];\n }\n\n strategies[type].push(strategy);\n\n return this;\n },\n\n async authenticate(ctx, next) {\n const route: Core.Route = ctx.state.route;\n\n // use route strategy\n const config = route?.config?.auth;\n\n if (config === false) {\n return next();\n }\n\n const routeStrategies = route.info.type ? strategies[route.info.type] : [];\n const configStrategies = (config?.strategies ?? routeStrategies ?? []) as Array<\n string | Strategy\n >;\n\n const strategiesToUse: Strategy[] = configStrategies.reduce(\n (acc, strategy: string | Strategy) => {\n // Resolve by strategy name\n if (typeof strategy === 'string') {\n const routeStrategy = routeStrategies.find((rs) => rs.name === strategy);\n\n if (routeStrategy) {\n acc.push(routeStrategy);\n }\n }\n\n // Use the given strategy as is\n else if (typeof strategy === 'object') {\n validStrategy(strategy);\n\n acc.push(strategy);\n }\n\n return acc;\n },\n [] as Strategy[]\n );\n\n for (const strategy of strategiesToUse) {\n const result = await strategy.authenticate(ctx);\n\n const { authenticated = false, credentials, ability = null, error = null } = result || {};\n\n if (error !== null) {\n return ctx.unauthorized(error);\n }\n\n if (authenticated) {\n ctx.state.isAuthenticated = true;\n ctx.state.auth = {\n strategy,\n credentials,\n ability,\n };\n\n return next();\n }\n }\n\n return ctx.unauthorized('Missing or invalid credentials');\n },\n\n async verify(auth, config = {}) {\n if (config === false) {\n return;\n }\n\n if (!auth) {\n throw new errors.UnauthorizedError();\n }\n\n if (typeof auth.strategy.verify === 'function') {\n return auth.strategy.verify(auth, config);\n }\n },\n };\n};\n\nexport default createAuthentication;\n"],"names":[],"mappings":";;;AAgCA,MAAM,uBACJ;AAEF,MAAM,gBAAgB,CAAC,aAAuB;AAC5C,SAAO,IAAI,gBAAgB,QAAQ,GAAG,oBAAoB;AAC1D,SAAO,OAAO,SAAS,iBAAiB,YAAY,oBAAoB;AAEpE,MAAA,IAAI,UAAU,QAAQ,GAAG;AAC3B,WAAO,OAAO,SAAS,WAAW,YAAY,oBAAoB;AAAA,EACpE;AACF;AAEA,MAAM,uBAAuB,MAAsB;AACjD,QAAM,aAAyC,CAAA;AAExC,SAAA;AAAA,IACL,SAAS,MAAM,UAAU;AACvB,oBAAc,QAAQ;AAElB,UAAA,CAAC,WAAW,IAAI,GAAG;AACV,mBAAA,IAAI,IAAI;MACrB;AAEW,iBAAA,IAAI,EAAE,KAAK,QAAQ;AAEvB,aAAA;AAAA,IACT;AAAA,IAEA,MAAM,aAAa,KAAK,MAAM;AACtB,YAAA,QAAoB,IAAI,MAAM;AAG9B,YAAA,SAAS,OAAO,QAAQ;AAE9B,UAAI,WAAW,OAAO;AACpB,eAAO,KAAK;AAAA,MACd;AAEM,YAAA,kBAAkB,MAAM,KAAK,OAAO,WAAW,MAAM,KAAK,IAAI,IAAI;AACxE,YAAM,mBAAoB,QAAQ,cAAc,mBAAmB,CAAA;AAInE,YAAM,kBAA8B,iBAAiB;AAAA,QACnD,CAAC,KAAK,aAAgC;AAEhC,cAAA,OAAO,aAAa,UAAU;AAChC,kBAAM,gBAAgB,gBAAgB,KAAK,CAAC,OAAO,GAAG,SAAS,QAAQ;AAEvE,gBAAI,eAAe;AACjB,kBAAI,KAAK,aAAa;AAAA,YACxB;AAAA,UAAA,WAIO,OAAO,aAAa,UAAU;AACrC,0BAAc,QAAQ;AAEtB,gBAAI,KAAK,QAAQ;AAAA,UACnB;AAEO,iBAAA;AAAA,QACT;AAAA,QACA,CAAC;AAAA,MAAA;AAGH,iBAAW,YAAY,iBAAiB;AACtC,cAAM,SAAS,MAAM,SAAS,aAAa,GAAG;AAExC,cAAA,EAAE,gBAAgB,OAAO,aAAa,UAAU,MAAM,QAAQ,KAAA,IAAS,UAAU;AAEvF,YAAI,UAAU,MAAM;AACX,iBAAA,IAAI,aAAa,KAAK;AAAA,QAC/B;AAEA,YAAI,eAAe;AACjB,cAAI,MAAM,kBAAkB;AAC5B,cAAI,MAAM,OAAO;AAAA,YACf;AAAA,YACA;AAAA,YACA;AAAA,UAAA;AAGF,iBAAO,KAAK;AAAA,QACd;AAAA,MACF;AAEO,aAAA,IAAI,aAAa,gCAAgC;AAAA,IAC1D;AAAA,IAEA,MAAM,OAAO,MAAM,SAAS,IAAI;AAC9B,UAAI,WAAW,OAAO;AACpB;AAAA,MACF;AAEA,UAAI,CAAC,MAAM;AACH,cAAA,IAAI,OAAO;MACnB;AAEA,UAAI,OAAO,KAAK,SAAS,WAAW,YAAY;AAC9C,eAAO,KAAK,SAAS,OAAO,MAAM,MAAM;AAAA,MAC1C;AAAA,IACF;AAAA,EAAA;AAEJ;"}
@@ -0,0 +1,3 @@
1
+ import type { Core } from '@strapi/types';
2
+ export declare const createConfigProvider: (initialConfig?: Record<string, unknown>, strapi?: Core.Strapi) => Core.ConfigProvider;
3
+ //# sourceMappingURL=config.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../../src/services/config.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAS1C,eAAO,MAAM,oBAAoB,mBAChB,OAAO,MAAM,EAAE,OAAO,CAAC,WAC7B,KAAK,MAAM,KACnB,KAAK,cAkDP,CAAC"}
@@ -0,0 +1,47 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const _ = require("lodash");
4
+ const createConfigProvider = (initialConfig = {}, strapi) => {
5
+ const state = {
6
+ config: { ...initialConfig }
7
+ // not deep clone because it would break some config
8
+ };
9
+ const transformPathString = (path) => {
10
+ if (path.startsWith("plugin.")) {
11
+ const newPath = path.replace("plugin.", "plugin::");
12
+ (strapi?.log?.warn ?? console.warn)(
13
+ `Using dot notation for model config namespaces is deprecated, for example "plugin::myplugin" should be used instead of "plugin.myplugin". Modifying requested path ${path} to ${newPath}`
14
+ );
15
+ return newPath;
16
+ }
17
+ return path;
18
+ };
19
+ const transformDeprecatedPaths = (path) => {
20
+ if (_.isString(path)) {
21
+ return transformPathString(path);
22
+ }
23
+ if (_.isArray(path)) {
24
+ if (path.some((part) => !(_.isString(part) || _.isNumber(part)))) {
25
+ return path;
26
+ }
27
+ return transformPathString(path.join("."));
28
+ }
29
+ return path;
30
+ };
31
+ return {
32
+ ...state.config,
33
+ // TODO: to remove
34
+ get(path, defaultValue) {
35
+ return _.get(state.config, transformDeprecatedPaths(path), defaultValue);
36
+ },
37
+ set(path, val) {
38
+ _.set(state.config, transformDeprecatedPaths(path), val);
39
+ return this;
40
+ },
41
+ has(path) {
42
+ return _.has(state.config, transformDeprecatedPaths(path));
43
+ }
44
+ };
45
+ };
46
+ exports.createConfigProvider = createConfigProvider;
47
+ //# sourceMappingURL=config.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"config.js","sources":["../../src/services/config.ts"],"sourcesContent":["import type { Core } from '@strapi/types';\nimport { get, set, has, isString, isNumber, isArray, type PropertyPath } from 'lodash';\n\ntype State = {\n config: Config;\n};\n\ntype Config = Record<string, unknown>;\n\nexport const createConfigProvider = (\n initialConfig: Record<string, unknown> = {},\n strapi?: Core.Strapi\n): Core.ConfigProvider => {\n const state: State = {\n config: { ...initialConfig }, // not deep clone because it would break some config\n };\n\n // Accessing model configs with dot (.) was deprecated between v4->v5, but to avoid a major breaking change\n // we will still support certain namespaces, currently only 'plugin.'\n const transformPathString = (path: string) => {\n if (path.startsWith('plugin.')) {\n const newPath = path.replace('plugin.', 'plugin::');\n\n // strapi logger may not be loaded yet, so fall back to console\n (strapi?.log?.warn ?? console.warn)(\n `Using dot notation for model config namespaces is deprecated, for example \"plugin::myplugin\" should be used instead of \"plugin.myplugin\". Modifying requested path ${path} to ${newPath}`\n );\n return newPath;\n }\n\n return path;\n };\n\n const transformDeprecatedPaths = (path: PropertyPath): PropertyPath => {\n if (isString(path)) {\n return transformPathString(path);\n }\n if (isArray(path)) {\n // if the path is not joinable, we won't apply our deprecation support\n if (path.some((part) => !(isString(part) || isNumber(part)))) {\n return path;\n }\n\n return transformPathString(path.join('.'));\n }\n\n return path;\n };\n\n return {\n ...state.config, // TODO: to remove\n get(path: PropertyPath, defaultValue?: unknown) {\n return get(state.config, transformDeprecatedPaths(path), defaultValue);\n },\n set(path: PropertyPath, val: unknown) {\n set(state.config, transformDeprecatedPaths(path), val);\n return this;\n },\n has(path: PropertyPath) {\n return has(state.config, transformDeprecatedPaths(path));\n },\n };\n};\n"],"names":["isString","isArray","isNumber","get","set","has"],"mappings":";;;AASO,MAAM,uBAAuB,CAClC,gBAAyC,IACzC,WACwB;AACxB,QAAM,QAAe;AAAA,IACnB,QAAQ,EAAE,GAAG,cAAc;AAAA;AAAA,EAAA;AAKvB,QAAA,sBAAsB,CAAC,SAAiB;AACxC,QAAA,KAAK,WAAW,SAAS,GAAG;AAC9B,YAAM,UAAU,KAAK,QAAQ,WAAW,UAAU;AAGjD,OAAA,QAAQ,KAAK,QAAQ,QAAQ;AAAA,QAC5B,sKAAsK,IAAI,OAAO,OAAO;AAAA,MAAA;AAEnL,aAAA;AAAA,IACT;AAEO,WAAA;AAAA,EAAA;AAGH,QAAA,2BAA2B,CAAC,SAAqC;AACjE,QAAAA,EAAAA,SAAS,IAAI,GAAG;AAClB,aAAO,oBAAoB,IAAI;AAAA,IACjC;AACI,QAAAC,EAAAA,QAAQ,IAAI,GAAG;AAEb,UAAA,KAAK,KAAK,CAAC,SAAS,EAAED,EAAAA,SAAS,IAAI,KAAKE,EAAA,SAAS,IAAI,EAAE,GAAG;AACrD,eAAA;AAAA,MACT;AAEA,aAAO,oBAAoB,KAAK,KAAK,GAAG,CAAC;AAAA,IAC3C;AAEO,WAAA;AAAA,EAAA;AAGF,SAAA;AAAA,IACL,GAAG,MAAM;AAAA;AAAA,IACT,IAAI,MAAoB,cAAwB;AAC9C,aAAOC,EAAAA,IAAI,MAAM,QAAQ,yBAAyB,IAAI,GAAG,YAAY;AAAA,IACvE;AAAA,IACA,IAAI,MAAoB,KAAc;AACpCC,QAAA,IAAI,MAAM,QAAQ,yBAAyB,IAAI,GAAG,GAAG;AAC9C,aAAA;AAAA,IACT;AAAA,IACA,IAAI,MAAoB;AACtB,aAAOC,EAAAA,IAAI,MAAM,QAAQ,yBAAyB,IAAI,CAAC;AAAA,IACzD;AAAA,EAAA;AAEJ;;"}