@strapi/strapi 4.14.5 → 4.15.0

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 (697) hide show
  1. package/README.md +1 -0
  2. package/bin/strapi.js +1 -6
  3. package/dist/Strapi.js +454 -532
  4. package/dist/Strapi.js.map +1 -1
  5. package/dist/Strapi.mjs +464 -0
  6. package/dist/Strapi.mjs.map +1 -0
  7. package/dist/cli.d.ts +2 -0
  8. package/dist/cli.d.ts.map +1 -0
  9. package/dist/cli.js +4 -0
  10. package/dist/cli.js.map +1 -0
  11. package/dist/commands/actions/admin/create-user/action.js +75 -94
  12. package/dist/commands/actions/admin/create-user/action.js.map +1 -1
  13. package/dist/commands/actions/admin/create-user/command.d.ts.map +1 -1
  14. package/dist/commands/actions/admin/create-user/command.js +6 -17
  15. package/dist/commands/actions/admin/create-user/command.js.map +1 -1
  16. package/dist/commands/actions/admin/reset-user-password/action.js +33 -36
  17. package/dist/commands/actions/admin/reset-user-password/action.js.map +1 -1
  18. package/dist/commands/actions/admin/reset-user-password/command.d.ts.map +1 -1
  19. package/dist/commands/actions/admin/reset-user-password/command.js +6 -15
  20. package/dist/commands/actions/admin/reset-user-password/command.js.map +1 -1
  21. package/dist/commands/actions/build-command/action.js +15 -18
  22. package/dist/commands/actions/build-command/action.js.map +1 -1
  23. package/dist/commands/actions/build-command/command.d.ts.map +1 -1
  24. package/dist/commands/actions/build-command/command.js +6 -13
  25. package/dist/commands/actions/build-command/command.js.map +1 -1
  26. package/dist/commands/actions/components/list/action.js +18 -18
  27. package/dist/commands/actions/components/list/action.js.map +1 -1
  28. package/dist/commands/actions/components/list/command.d.ts.map +1 -1
  29. package/dist/commands/actions/components/list/command.js +6 -12
  30. package/dist/commands/actions/components/list/command.js.map +1 -1
  31. package/dist/commands/actions/configuration/dump/action.js +33 -43
  32. package/dist/commands/actions/configuration/dump/action.js.map +1 -1
  33. package/dist/commands/actions/configuration/dump/command.d.ts.map +1 -1
  34. package/dist/commands/actions/configuration/dump/command.js +6 -15
  35. package/dist/commands/actions/configuration/dump/command.js.map +1 -1
  36. package/dist/commands/actions/configuration/restore/action.js +122 -139
  37. package/dist/commands/actions/configuration/restore/action.js.map +1 -1
  38. package/dist/commands/actions/configuration/restore/command.d.ts.map +1 -1
  39. package/dist/commands/actions/configuration/restore/command.js +6 -15
  40. package/dist/commands/actions/configuration/restore/command.js.map +1 -1
  41. package/dist/commands/actions/console/action.js +19 -23
  42. package/dist/commands/actions/console/action.js.map +1 -1
  43. package/dist/commands/actions/console/command.d.ts.map +1 -1
  44. package/dist/commands/actions/console/command.js +6 -12
  45. package/dist/commands/actions/console/command.js.map +1 -1
  46. package/dist/commands/actions/content-types/list/action.js +18 -18
  47. package/dist/commands/actions/content-types/list/action.js.map +1 -1
  48. package/dist/commands/actions/content-types/list/command.d.ts.map +1 -1
  49. package/dist/commands/actions/content-types/list/command.js +6 -12
  50. package/dist/commands/actions/content-types/list/command.js.map +1 -1
  51. package/dist/commands/actions/controllers/list/action.js +18 -18
  52. package/dist/commands/actions/controllers/list/action.js.map +1 -1
  53. package/dist/commands/actions/controllers/list/command.d.ts.map +1 -1
  54. package/dist/commands/actions/controllers/list/command.js +6 -12
  55. package/dist/commands/actions/controllers/list/command.js.map +1 -1
  56. package/dist/commands/actions/develop/action.d.ts +1 -75
  57. package/dist/commands/actions/develop/action.d.ts.map +1 -1
  58. package/dist/commands/actions/develop/action.js +184 -177
  59. package/dist/commands/actions/develop/action.js.map +1 -1
  60. package/dist/commands/actions/develop/command.d.ts.map +1 -1
  61. package/dist/commands/actions/develop/command.js +6 -17
  62. package/dist/commands/actions/develop/command.js.map +1 -1
  63. package/dist/commands/actions/generate/command.js +30 -16
  64. package/dist/commands/actions/generate/command.js.map +1 -1
  65. package/dist/commands/actions/hooks/list/action.js +18 -18
  66. package/dist/commands/actions/hooks/list/action.js.map +1 -1
  67. package/dist/commands/actions/hooks/list/command.d.ts.map +1 -1
  68. package/dist/commands/actions/hooks/list/command.js +6 -12
  69. package/dist/commands/actions/hooks/list/command.js.map +1 -1
  70. package/dist/commands/actions/install/action.js +41 -45
  71. package/dist/commands/actions/install/action.js.map +1 -1
  72. package/dist/commands/actions/install/command.d.ts.map +1 -1
  73. package/dist/commands/actions/install/command.js +6 -12
  74. package/dist/commands/actions/install/command.js.map +1 -1
  75. package/dist/commands/actions/middlewares/list/action.js +18 -18
  76. package/dist/commands/actions/middlewares/list/action.js.map +1 -1
  77. package/dist/commands/actions/middlewares/list/command.d.ts.map +1 -1
  78. package/dist/commands/actions/middlewares/list/command.js +6 -12
  79. package/dist/commands/actions/middlewares/list/command.js.map +1 -1
  80. package/dist/commands/actions/new/action.js +5 -10
  81. package/dist/commands/actions/new/action.js.map +1 -1
  82. package/dist/commands/actions/new/command.js +14 -33
  83. package/dist/commands/actions/new/command.js.map +1 -1
  84. package/dist/commands/actions/plugin/build-command/action.js +80 -79
  85. package/dist/commands/actions/plugin/build-command/action.js.map +1 -1
  86. package/dist/commands/actions/plugin/build-command/command.d.ts.map +1 -1
  87. package/dist/commands/actions/plugin/build-command/command.js +7 -18
  88. package/dist/commands/actions/plugin/build-command/command.js.map +1 -1
  89. package/dist/commands/actions/plugin/watch/action.d.ts +7 -0
  90. package/dist/commands/actions/plugin/watch/action.d.ts.map +1 -0
  91. package/dist/commands/actions/plugin/watch/action.js +85 -0
  92. package/dist/commands/actions/plugin/watch/action.js.map +1 -0
  93. package/dist/commands/actions/plugin/watch/command.d.ts +7 -0
  94. package/dist/commands/actions/plugin/watch/command.d.ts.map +1 -0
  95. package/dist/commands/actions/plugin/watch/command.js +8 -0
  96. package/dist/commands/actions/plugin/watch/command.js.map +1 -0
  97. package/dist/commands/actions/policies/list/action.js +18 -18
  98. package/dist/commands/actions/policies/list/action.js.map +1 -1
  99. package/dist/commands/actions/policies/list/command.d.ts.map +1 -1
  100. package/dist/commands/actions/policies/list/command.js +6 -12
  101. package/dist/commands/actions/policies/list/command.js.map +1 -1
  102. package/dist/commands/actions/report/action.js +22 -25
  103. package/dist/commands/actions/report/action.js.map +1 -1
  104. package/dist/commands/actions/report/command.d.ts.map +1 -1
  105. package/dist/commands/actions/report/command.js +6 -15
  106. package/dist/commands/actions/report/command.js.map +1 -1
  107. package/dist/commands/actions/routes/list/action.js +22 -24
  108. package/dist/commands/actions/routes/list/action.js.map +1 -1
  109. package/dist/commands/actions/routes/list/command.d.ts.map +1 -1
  110. package/dist/commands/actions/routes/list/command.js +6 -12
  111. package/dist/commands/actions/routes/list/command.js.map +1 -1
  112. package/dist/commands/actions/services/list/action.js +18 -18
  113. package/dist/commands/actions/services/list/action.js.map +1 -1
  114. package/dist/commands/actions/services/list/command.d.ts.map +1 -1
  115. package/dist/commands/actions/services/list/command.js +6 -12
  116. package/dist/commands/actions/services/list/command.js.map +1 -1
  117. package/dist/commands/actions/start/action.d.ts +1 -74
  118. package/dist/commands/actions/start/action.d.ts.map +1 -1
  119. package/dist/commands/actions/start/action.js +19 -20
  120. package/dist/commands/actions/start/action.js.map +1 -1
  121. package/dist/commands/actions/start/command.d.ts.map +1 -1
  122. package/dist/commands/actions/start/command.js +6 -12
  123. package/dist/commands/actions/start/command.js.map +1 -1
  124. package/dist/commands/actions/telemetry/disable/action.js +72 -72
  125. package/dist/commands/actions/telemetry/disable/action.js.map +1 -1
  126. package/dist/commands/actions/telemetry/disable/command.d.ts.map +1 -1
  127. package/dist/commands/actions/telemetry/disable/command.js +6 -12
  128. package/dist/commands/actions/telemetry/disable/command.js.map +1 -1
  129. package/dist/commands/actions/telemetry/enable/action.js +87 -88
  130. package/dist/commands/actions/telemetry/enable/action.js.map +1 -1
  131. package/dist/commands/actions/telemetry/enable/command.d.ts.map +1 -1
  132. package/dist/commands/actions/telemetry/enable/command.js +6 -12
  133. package/dist/commands/actions/telemetry/enable/command.js.map +1 -1
  134. package/dist/commands/actions/templates/generate/action.js +59 -73
  135. package/dist/commands/actions/templates/generate/action.js.map +1 -1
  136. package/dist/commands/actions/templates/generate/command.d.ts.map +1 -1
  137. package/dist/commands/actions/templates/generate/command.js +6 -12
  138. package/dist/commands/actions/templates/generate/command.js.map +1 -1
  139. package/dist/commands/actions/ts/generate-types/action.js +25 -26
  140. package/dist/commands/actions/ts/generate-types/action.js.map +1 -1
  141. package/dist/commands/actions/ts/generate-types/command.d.ts.map +1 -1
  142. package/dist/commands/actions/ts/generate-types/command.js +9 -16
  143. package/dist/commands/actions/ts/generate-types/command.js.map +1 -1
  144. package/dist/commands/actions/uninstall/action.js +60 -62
  145. package/dist/commands/actions/uninstall/action.js.map +1 -1
  146. package/dist/commands/actions/uninstall/command.d.ts.map +1 -1
  147. package/dist/commands/actions/uninstall/command.js +6 -13
  148. package/dist/commands/actions/uninstall/command.js.map +1 -1
  149. package/dist/commands/actions/version/command.js +10 -17
  150. package/dist/commands/actions/version/command.js.map +1 -1
  151. package/dist/commands/actions/watch-admin/action.js +33 -34
  152. package/dist/commands/actions/watch-admin/action.js.map +1 -1
  153. package/dist/commands/actions/watch-admin/command.d.ts.map +1 -1
  154. package/dist/commands/actions/watch-admin/command.js +6 -13
  155. package/dist/commands/actions/watch-admin/command.js.map +1 -1
  156. package/dist/commands/builders/admin.js +46 -50
  157. package/dist/commands/builders/admin.js.map +1 -1
  158. package/dist/commands/builders/typescript.js +28 -25
  159. package/dist/commands/builders/typescript.js.map +1 -1
  160. package/dist/commands/index.d.ts +1 -0
  161. package/dist/commands/index.d.ts.map +1 -1
  162. package/dist/commands/index.js +102 -91
  163. package/dist/commands/index.js.map +1 -1
  164. package/dist/commands/utils/commander.js +11 -136
  165. package/dist/commands/utils/commander.js.map +1 -1
  166. package/dist/commands/utils/helpers.d.ts +4 -6
  167. package/dist/commands/utils/helpers.d.ts.map +1 -1
  168. package/dist/commands/utils/helpers.js +57 -155
  169. package/dist/commands/utils/helpers.js.map +1 -1
  170. package/dist/commands/utils/logger.js +59 -49
  171. package/dist/commands/utils/logger.js.map +1 -1
  172. package/dist/commands/utils/pkg.js +98 -107
  173. package/dist/commands/utils/pkg.js.map +1 -1
  174. package/dist/compile.js +15 -17
  175. package/dist/compile.js.map +1 -1
  176. package/dist/compile.mjs +17 -0
  177. package/dist/compile.mjs.map +1 -0
  178. package/dist/container.js +32 -35
  179. package/dist/container.js.map +1 -1
  180. package/dist/container.mjs +36 -0
  181. package/dist/container.mjs.map +1 -0
  182. package/dist/core/app-configuration/config-loader.js +17 -20
  183. package/dist/core/app-configuration/config-loader.js.map +1 -1
  184. package/dist/core/app-configuration/config-loader.mjs +17 -0
  185. package/dist/core/app-configuration/config-loader.mjs.map +1 -0
  186. package/dist/core/app-configuration/index.js +51 -50
  187. package/dist/core/app-configuration/index.js.map +1 -1
  188. package/dist/core/app-configuration/index.mjs +51 -0
  189. package/dist/core/app-configuration/index.mjs.map +1 -0
  190. package/dist/core/app-configuration/load-config-file.js +34 -38
  191. package/dist/core/app-configuration/load-config-file.js.map +1 -1
  192. package/dist/core/app-configuration/load-config-file.mjs +42 -0
  193. package/dist/core/app-configuration/load-config-file.mjs.map +1 -0
  194. package/dist/core/bootstrap.js +25 -24
  195. package/dist/core/bootstrap.js.map +1 -1
  196. package/dist/core/bootstrap.mjs +27 -0
  197. package/dist/core/bootstrap.mjs.map +1 -0
  198. package/dist/core/domain/content-type/index.js +108 -104
  199. package/dist/core/domain/content-type/index.js.map +1 -1
  200. package/dist/core/domain/content-type/index.mjs +119 -0
  201. package/dist/core/domain/content-type/index.mjs.map +1 -0
  202. package/dist/core/domain/content-type/validator.js +69 -83
  203. package/dist/core/domain/content-type/validator.js.map +1 -1
  204. package/dist/core/domain/content-type/validator.mjs +75 -0
  205. package/dist/core/domain/content-type/validator.mjs.map +1 -0
  206. package/dist/core/domain/module/index.js +97 -100
  207. package/dist/core/domain/module/index.js.map +1 -1
  208. package/dist/core/domain/module/index.mjs +105 -0
  209. package/dist/core/domain/module/index.mjs.map +1 -0
  210. package/dist/core/domain/module/validation.js +21 -25
  211. package/dist/core/domain/module/validation.js.map +1 -1
  212. package/dist/core/domain/module/validation.mjs +25 -0
  213. package/dist/core/domain/module/validation.mjs.map +1 -0
  214. package/dist/core/loaders/admin.js +13 -15
  215. package/dist/core/loaders/admin.js.map +1 -1
  216. package/dist/core/loaders/admin.mjs +15 -0
  217. package/dist/core/loaders/admin.mjs.map +1 -0
  218. package/dist/core/loaders/apis.js +109 -135
  219. package/dist/core/loaders/apis.js.map +1 -1
  220. package/dist/core/loaders/apis.mjs +128 -0
  221. package/dist/core/loaders/apis.mjs.map +1 -0
  222. package/dist/core/loaders/components.js +34 -34
  223. package/dist/core/loaders/components.js.map +1 -1
  224. package/dist/core/loaders/components.mjs +36 -0
  225. package/dist/core/loaders/components.mjs.map +1 -0
  226. package/dist/core/loaders/index.js +21 -24
  227. package/dist/core/loaders/index.js.map +1 -1
  228. package/dist/core/loaders/index.mjs +24 -0
  229. package/dist/core/loaders/index.mjs.map +1 -0
  230. package/dist/core/loaders/middlewares.js +25 -28
  231. package/dist/core/loaders/middlewares.js.map +1 -1
  232. package/dist/core/loaders/middlewares.mjs +30 -0
  233. package/dist/core/loaders/middlewares.mjs.map +1 -0
  234. package/dist/core/loaders/plugins/get-enabled-plugins.js +96 -99
  235. package/dist/core/loaders/plugins/get-enabled-plugins.js.map +1 -1
  236. package/dist/core/loaders/plugins/get-enabled-plugins.mjs +108 -0
  237. package/dist/core/loaders/plugins/get-enabled-plugins.mjs.map +1 -0
  238. package/dist/core/loaders/plugins/get-user-plugins-config.js +23 -27
  239. package/dist/core/loaders/plugins/get-user-plugins-config.js.map +1 -1
  240. package/dist/core/loaders/plugins/get-user-plugins-config.mjs +25 -0
  241. package/dist/core/loaders/plugins/get-user-plugins-config.mjs.map +1 -0
  242. package/dist/core/loaders/plugins/index.js +92 -96
  243. package/dist/core/loaders/plugins/index.js.map +1 -1
  244. package/dist/core/loaders/plugins/index.mjs +104 -0
  245. package/dist/core/loaders/plugins/index.mjs.map +1 -0
  246. package/dist/core/loaders/policies.js +21 -24
  247. package/dist/core/loaders/policies.js.map +1 -1
  248. package/dist/core/loaders/policies.mjs +24 -0
  249. package/dist/core/loaders/policies.mjs.map +1 -0
  250. package/dist/core/loaders/sanitizers.js +4 -4
  251. package/dist/core/loaders/sanitizers.js.map +1 -1
  252. package/dist/core/loaders/sanitizers.mjs +7 -0
  253. package/dist/core/loaders/sanitizers.mjs.map +1 -0
  254. package/dist/core/loaders/src-index.js +28 -32
  255. package/dist/core/loaders/src-index.js.map +1 -1
  256. package/dist/core/loaders/src-index.mjs +34 -0
  257. package/dist/core/loaders/src-index.mjs.map +1 -0
  258. package/dist/core/loaders/validators.js +4 -4
  259. package/dist/core/loaders/validators.js.map +1 -1
  260. package/dist/core/loaders/validators.mjs +7 -0
  261. package/dist/core/loaders/validators.mjs.map +1 -0
  262. package/dist/core/registries/apis.js +20 -21
  263. package/dist/core/registries/apis.js.map +1 -1
  264. package/dist/core/registries/apis.mjs +24 -0
  265. package/dist/core/registries/apis.mjs.map +1 -0
  266. package/dist/core/registries/config.js +21 -21
  267. package/dist/core/registries/config.js.map +1 -1
  268. package/dist/core/registries/config.mjs +22 -0
  269. package/dist/core/registries/config.mjs.map +1 -0
  270. package/dist/core/registries/content-types.js +65 -64
  271. package/dist/core/registries/content-types.js.map +1 -1
  272. package/dist/core/registries/content-types.mjs +72 -0
  273. package/dist/core/registries/content-types.mjs.map +1 -0
  274. package/dist/core/registries/controllers.js +77 -78
  275. package/dist/core/registries/controllers.js.map +1 -1
  276. package/dist/core/registries/controllers.mjs +81 -0
  277. package/dist/core/registries/controllers.mjs.map +1 -0
  278. package/dist/core/registries/custom-fields.js +66 -69
  279. package/dist/core/registries/custom-fields.js.map +1 -1
  280. package/dist/core/registries/custom-fields.mjs +72 -0
  281. package/dist/core/registries/custom-fields.mjs.map +1 -0
  282. package/dist/core/registries/hooks.js +55 -56
  283. package/dist/core/registries/hooks.js.map +1 -1
  284. package/dist/core/registries/hooks.mjs +59 -0
  285. package/dist/core/registries/hooks.mjs.map +1 -0
  286. package/dist/core/registries/middlewares.js +57 -59
  287. package/dist/core/registries/middlewares.js.map +1 -1
  288. package/dist/core/registries/middlewares.mjs +61 -0
  289. package/dist/core/registries/middlewares.mjs.map +1 -0
  290. package/dist/core/registries/modules.js +36 -37
  291. package/dist/core/registries/modules.js.map +1 -1
  292. package/dist/core/registries/modules.mjs +40 -0
  293. package/dist/core/registries/modules.mjs.map +1 -0
  294. package/dist/core/registries/plugins.js +20 -21
  295. package/dist/core/registries/plugins.js.map +1 -1
  296. package/dist/core/registries/plugins.mjs +24 -0
  297. package/dist/core/registries/plugins.mjs.map +1 -0
  298. package/dist/core/registries/policies.js +59 -61
  299. package/dist/core/registries/policies.js.map +1 -1
  300. package/dist/core/registries/policies.mjs +63 -0
  301. package/dist/core/registries/policies.mjs.map +1 -0
  302. package/dist/core/registries/sanitizers.js +22 -24
  303. package/dist/core/registries/sanitizers.js.map +1 -1
  304. package/dist/core/registries/sanitizers.mjs +24 -0
  305. package/dist/core/registries/sanitizers.mjs.map +1 -0
  306. package/dist/core/registries/services.js +77 -79
  307. package/dist/core/registries/services.js.map +1 -1
  308. package/dist/core/registries/services.mjs +81 -0
  309. package/dist/core/registries/services.mjs.map +1 -0
  310. package/dist/core/registries/validators.js +22 -24
  311. package/dist/core/registries/validators.js.map +1 -1
  312. package/dist/core/registries/validators.mjs +24 -0
  313. package/dist/core/registries/validators.mjs.map +1 -0
  314. package/dist/core/utils.js +19 -20
  315. package/dist/core/utils.js.map +1 -1
  316. package/dist/core/utils.mjs +27 -0
  317. package/dist/core/utils.mjs.map +1 -0
  318. package/dist/core-api/controller/collection-type.js +90 -93
  319. package/dist/core-api/controller/collection-type.js.map +1 -1
  320. package/dist/core-api/controller/collection-type.mjs +93 -0
  321. package/dist/core-api/controller/collection-type.mjs.map +1 -0
  322. package/dist/core-api/controller/index.js +43 -46
  323. package/dist/core-api/controller/index.js.map +1 -1
  324. package/dist/core-api/controller/index.mjs +47 -0
  325. package/dist/core-api/controller/index.mjs.map +1 -0
  326. package/dist/core-api/controller/single-type.js +48 -50
  327. package/dist/core-api/controller/single-type.js.map +1 -1
  328. package/dist/core-api/controller/single-type.mjs +51 -0
  329. package/dist/core-api/controller/single-type.mjs.map +1 -0
  330. package/dist/core-api/controller/transform.js +70 -72
  331. package/dist/core-api/controller/transform.js.map +1 -1
  332. package/dist/core-api/controller/transform.mjs +84 -0
  333. package/dist/core-api/controller/transform.mjs.map +1 -0
  334. package/dist/core-api/routes/index.js +60 -61
  335. package/dist/core-api/routes/index.js.map +1 -1
  336. package/dist/core-api/routes/index.mjs +67 -0
  337. package/dist/core-api/routes/index.mjs.map +1 -0
  338. package/dist/core-api/service/collection-type.js +57 -57
  339. package/dist/core-api/service/collection-type.js.map +1 -1
  340. package/dist/core-api/service/collection-type.mjs +62 -0
  341. package/dist/core-api/service/collection-type.mjs.map +1 -0
  342. package/dist/core-api/service/get-fetch-params.js +10 -12
  343. package/dist/core-api/service/get-fetch-params.js.map +1 -1
  344. package/dist/core-api/service/get-fetch-params.mjs +14 -0
  345. package/dist/core-api/service/get-fetch-params.mjs.map +1 -0
  346. package/dist/core-api/service/index.js +13 -15
  347. package/dist/core-api/service/index.js.map +1 -1
  348. package/dist/core-api/service/index.mjs +16 -0
  349. package/dist/core-api/service/index.mjs.map +1 -0
  350. package/dist/core-api/service/pagination.js +71 -79
  351. package/dist/core-api/service/pagination.js.map +1 -1
  352. package/dist/core-api/service/pagination.mjs +89 -0
  353. package/dist/core-api/service/pagination.mjs.map +1 -0
  354. package/dist/core-api/service/single-type.js +53 -53
  355. package/dist/core-api/service/single-type.js.map +1 -1
  356. package/dist/core-api/service/single-type.mjs +58 -0
  357. package/dist/core-api/service/single-type.mjs.map +1 -0
  358. package/dist/ee/index.js +128 -160
  359. package/dist/ee/index.js.map +1 -1
  360. package/dist/ee/index.mjs +154 -0
  361. package/dist/ee/index.mjs.map +1 -0
  362. package/dist/ee/license.js +72 -77
  363. package/dist/ee/license.js.map +1 -1
  364. package/dist/ee/license.mjs +86 -0
  365. package/dist/ee/license.mjs.map +1 -0
  366. package/dist/factories.js +62 -61
  367. package/dist/factories.js.map +1 -1
  368. package/dist/factories.mjs +71 -0
  369. package/dist/factories.mjs.map +1 -0
  370. package/dist/index.d.ts +0 -1
  371. package/dist/index.d.ts.map +1 -1
  372. package/dist/index.js +7 -34
  373. package/dist/index.js.map +1 -1
  374. package/dist/index.mjs +8 -0
  375. package/dist/index.mjs.map +1 -0
  376. package/dist/load/filepath-to-prop-path.js +9 -19
  377. package/dist/load/filepath-to-prop-path.js.map +1 -1
  378. package/dist/load/filepath-to-prop-path.mjs +10 -0
  379. package/dist/load/filepath-to-prop-path.mjs.map +1 -0
  380. package/dist/load/glob.js +11 -16
  381. package/dist/load/glob.js.map +1 -1
  382. package/dist/load/glob.mjs +14 -0
  383. package/dist/load/glob.mjs.map +1 -0
  384. package/dist/load/load-files.js +35 -43
  385. package/dist/load/load-files.js.map +1 -1
  386. package/dist/load/load-files.mjs +35 -0
  387. package/dist/load/load-files.mjs.map +1 -0
  388. package/dist/load/package-path.js +6 -10
  389. package/dist/load/package-path.js.map +1 -1
  390. package/dist/middlewares/body.js +53 -66
  391. package/dist/middlewares/body.js.map +1 -1
  392. package/dist/middlewares/body.mjs +61 -0
  393. package/dist/middlewares/body.mjs.map +1 -0
  394. package/dist/middlewares/compression.js +6 -8
  395. package/dist/middlewares/compression.js.map +1 -1
  396. package/dist/middlewares/compression.mjs +6 -0
  397. package/dist/middlewares/compression.mjs.map +1 -0
  398. package/dist/middlewares/cors.js +45 -48
  399. package/dist/middlewares/cors.js.map +1 -1
  400. package/dist/middlewares/cors.mjs +49 -0
  401. package/dist/middlewares/cors.mjs.map +1 -0
  402. package/dist/middlewares/errors.js +30 -32
  403. package/dist/middlewares/errors.js.map +1 -1
  404. package/dist/middlewares/errors.mjs +33 -0
  405. package/dist/middlewares/errors.mjs.map +1 -0
  406. package/dist/middlewares/favicon.js +16 -24
  407. package/dist/middlewares/favicon.js.map +1 -1
  408. package/dist/middlewares/favicon.mjs +20 -0
  409. package/dist/middlewares/favicon.mjs.map +1 -0
  410. package/dist/middlewares/index.js +32 -32
  411. package/dist/middlewares/index.js.map +1 -1
  412. package/dist/middlewares/index.mjs +34 -0
  413. package/dist/middlewares/index.mjs.map +1 -0
  414. package/dist/middlewares/ip.js +6 -8
  415. package/dist/middlewares/ip.js.map +1 -1
  416. package/dist/middlewares/ip.mjs +6 -0
  417. package/dist/middlewares/ip.mjs.map +1 -0
  418. package/dist/middlewares/logger.js +8 -9
  419. package/dist/middlewares/logger.js.map +1 -1
  420. package/dist/middlewares/logger.mjs +12 -0
  421. package/dist/middlewares/logger.mjs.map +1 -0
  422. package/dist/middlewares/powered-by.js +8 -9
  423. package/dist/middlewares/powered-by.js.map +1 -1
  424. package/dist/middlewares/powered-by.mjs +14 -0
  425. package/dist/middlewares/powered-by.mjs.map +1 -0
  426. package/dist/middlewares/public/index.js +85 -106
  427. package/dist/middlewares/public/index.js.map +1 -1
  428. package/dist/middlewares/public/index.mjs +85 -0
  429. package/dist/middlewares/public/index.mjs.map +1 -0
  430. package/dist/middlewares/public/serve-static.js +20 -23
  431. package/dist/middlewares/public/serve-static.js.map +1 -1
  432. package/dist/middlewares/public/serve-static.mjs +21 -0
  433. package/dist/middlewares/public/serve-static.mjs.map +1 -0
  434. package/dist/middlewares/query.js +32 -37
  435. package/dist/middlewares/query.js.map +1 -1
  436. package/dist/middlewares/query.mjs +38 -0
  437. package/dist/middlewares/query.mjs.map +1 -0
  438. package/dist/middlewares/response-time.js +8 -9
  439. package/dist/middlewares/response-time.js.map +1 -1
  440. package/dist/middlewares/response-time.mjs +12 -0
  441. package/dist/middlewares/response-time.mjs.map +1 -0
  442. package/dist/middlewares/responses.js +11 -12
  443. package/dist/middlewares/responses.js.map +1 -1
  444. package/dist/middlewares/responses.mjs +15 -0
  445. package/dist/middlewares/responses.mjs.map +1 -0
  446. package/dist/middlewares/security.js +44 -46
  447. package/dist/middlewares/security.js.map +1 -1
  448. package/dist/middlewares/security.mjs +48 -0
  449. package/dist/middlewares/security.mjs.map +1 -0
  450. package/dist/middlewares/session.js +24 -24
  451. package/dist/middlewares/session.js.map +1 -1
  452. package/dist/middlewares/session.mjs +28 -0
  453. package/dist/middlewares/session.mjs.map +1 -0
  454. package/dist/migrations/draft-publish.js +27 -36
  455. package/dist/migrations/draft-publish.js.map +1 -1
  456. package/dist/migrations/draft-publish.mjs +37 -0
  457. package/dist/migrations/draft-publish.mjs.map +1 -0
  458. package/dist/services/auth/index.js +74 -77
  459. package/dist/services/auth/index.js.map +1 -1
  460. package/dist/services/auth/index.mjs +80 -0
  461. package/dist/services/auth/index.mjs.map +1 -0
  462. package/dist/services/content-api/index.js +54 -57
  463. package/dist/services/content-api/index.js.map +1 -1
  464. package/dist/services/content-api/index.mjs +58 -0
  465. package/dist/services/content-api/index.mjs.map +1 -0
  466. package/dist/services/content-api/permissions/engine.js +6 -7
  467. package/dist/services/content-api/permissions/engine.js.map +1 -1
  468. package/dist/services/content-api/permissions/engine.mjs +6 -0
  469. package/dist/services/content-api/permissions/engine.mjs.map +1 -0
  470. package/dist/services/content-api/permissions/index.js +79 -102
  471. package/dist/services/content-api/permissions/index.js.map +1 -1
  472. package/dist/services/content-api/permissions/index.mjs +86 -0
  473. package/dist/services/content-api/permissions/index.mjs.map +1 -0
  474. package/dist/services/content-api/permissions/providers/action.js +14 -14
  475. package/dist/services/content-api/permissions/providers/action.js.map +1 -1
  476. package/dist/services/content-api/permissions/providers/action.mjs +17 -0
  477. package/dist/services/content-api/permissions/providers/action.mjs.map +1 -0
  478. package/dist/services/content-api/permissions/providers/condition.js +14 -14
  479. package/dist/services/content-api/permissions/providers/condition.js.map +1 -1
  480. package/dist/services/content-api/permissions/providers/condition.mjs +17 -0
  481. package/dist/services/content-api/permissions/providers/condition.mjs.map +1 -0
  482. package/dist/services/core-store.js +91 -111
  483. package/dist/services/core-store.js.map +1 -1
  484. package/dist/services/core-store.mjs +103 -0
  485. package/dist/services/core-store.mjs.map +1 -0
  486. package/dist/services/cron.js +60 -66
  487. package/dist/services/cron.js.map +1 -1
  488. package/dist/services/cron.mjs +64 -0
  489. package/dist/services/cron.mjs.map +1 -0
  490. package/dist/services/custom-fields.js +7 -8
  491. package/dist/services/custom-fields.js.map +1 -1
  492. package/dist/services/custom-fields.mjs +11 -0
  493. package/dist/services/custom-fields.mjs.map +1 -0
  494. package/dist/services/entity-service/attributes/index.js +17 -21
  495. package/dist/services/entity-service/attributes/index.js.map +1 -1
  496. package/dist/services/entity-service/attributes/index.mjs +22 -0
  497. package/dist/services/entity-service/attributes/index.mjs.map +1 -0
  498. package/dist/services/entity-service/attributes/transforms.js +17 -19
  499. package/dist/services/entity-service/attributes/transforms.js.map +1 -1
  500. package/dist/services/entity-service/attributes/transforms.mjs +19 -0
  501. package/dist/services/entity-service/attributes/transforms.mjs.map +1 -0
  502. package/dist/services/entity-service/components.js +336 -333
  503. package/dist/services/entity-service/components.js.map +1 -1
  504. package/dist/services/entity-service/components.mjs +382 -0
  505. package/dist/services/entity-service/components.mjs.map +1 -0
  506. package/dist/services/entity-service/index.js +314 -297
  507. package/dist/services/entity-service/index.js.map +1 -1
  508. package/dist/services/entity-service/index.mjs +326 -0
  509. package/dist/services/entity-service/index.mjs.map +1 -0
  510. package/dist/services/entity-service/params.js +4 -5
  511. package/dist/services/entity-service/params.js.map +1 -1
  512. package/dist/services/entity-service/params.mjs +8 -0
  513. package/dist/services/entity-service/params.mjs.map +1 -0
  514. package/dist/services/entity-validator/blocks-validator.js +95 -116
  515. package/dist/services/entity-validator/blocks-validator.js.map +1 -1
  516. package/dist/services/entity-validator/blocks-validator.mjs +108 -0
  517. package/dist/services/entity-validator/blocks-validator.mjs.map +1 -0
  518. package/dist/services/entity-validator/index.js +284 -297
  519. package/dist/services/entity-validator/index.js.map +1 -1
  520. package/dist/services/entity-validator/index.mjs +318 -0
  521. package/dist/services/entity-validator/index.mjs.map +1 -0
  522. package/dist/services/entity-validator/validators.js +92 -124
  523. package/dist/services/entity-validator/validators.js.map +1 -1
  524. package/dist/services/entity-validator/validators.mjs +115 -0
  525. package/dist/services/entity-validator/validators.mjs.map +1 -0
  526. package/dist/services/errors.js +64 -66
  527. package/dist/services/errors.js.map +1 -1
  528. package/dist/services/errors.mjs +74 -0
  529. package/dist/services/errors.mjs.map +1 -0
  530. package/dist/services/event-hub.js +64 -74
  531. package/dist/services/event-hub.js.map +1 -1
  532. package/dist/services/event-hub.mjs +68 -0
  533. package/dist/services/event-hub.mjs.map +1 -0
  534. package/dist/services/fs.js +48 -51
  535. package/dist/services/fs.js.map +1 -1
  536. package/dist/services/fs.mjs +49 -0
  537. package/dist/services/fs.mjs.map +1 -0
  538. package/dist/services/metrics/admin-user-hash.js +10 -15
  539. package/dist/services/metrics/admin-user-hash.js.map +1 -1
  540. package/dist/services/metrics/admin-user-hash.mjs +12 -0
  541. package/dist/services/metrics/admin-user-hash.mjs.map +1 -0
  542. package/dist/services/metrics/index.js +40 -48
  543. package/dist/services/metrics/index.js.map +1 -1
  544. package/dist/services/metrics/index.mjs +46 -0
  545. package/dist/services/metrics/index.mjs.map +1 -0
  546. package/dist/services/metrics/is-truthy.js +6 -8
  547. package/dist/services/metrics/is-truthy.js.map +1 -1
  548. package/dist/services/metrics/is-truthy.mjs +8 -0
  549. package/dist/services/metrics/is-truthy.mjs.map +1 -0
  550. package/dist/services/metrics/middleware.js +22 -25
  551. package/dist/services/metrics/middleware.js.map +1 -1
  552. package/dist/services/metrics/middleware.mjs +26 -0
  553. package/dist/services/metrics/middleware.mjs.map +1 -0
  554. package/dist/services/metrics/rate-limiter.js +19 -19
  555. package/dist/services/metrics/rate-limiter.js.map +1 -1
  556. package/dist/services/metrics/rate-limiter.mjs +22 -0
  557. package/dist/services/metrics/rate-limiter.mjs.map +1 -0
  558. package/dist/services/metrics/sender.js +69 -72
  559. package/dist/services/metrics/sender.js.map +1 -1
  560. package/dist/services/metrics/sender.mjs +71 -0
  561. package/dist/services/metrics/sender.mjs.map +1 -0
  562. package/dist/services/request-context.js +10 -11
  563. package/dist/services/request-context.js.map +1 -1
  564. package/dist/services/request-context.mjs +14 -0
  565. package/dist/services/request-context.mjs.map +1 -0
  566. package/dist/services/server/admin-api.js +9 -9
  567. package/dist/services/server/admin-api.js.map +1 -1
  568. package/dist/services/server/admin-api.mjs +13 -0
  569. package/dist/services/server/admin-api.mjs.map +1 -0
  570. package/dist/services/server/api.js +26 -28
  571. package/dist/services/server/api.js.map +1 -1
  572. package/dist/services/server/api.mjs +28 -0
  573. package/dist/services/server/api.mjs.map +1 -0
  574. package/dist/services/server/compose-endpoint.js +94 -100
  575. package/dist/services/server/compose-endpoint.js.map +1 -1
  576. package/dist/services/server/compose-endpoint.mjs +114 -0
  577. package/dist/services/server/compose-endpoint.mjs.map +1 -0
  578. package/dist/services/server/content-api.js +8 -9
  579. package/dist/services/server/content-api.js.map +1 -1
  580. package/dist/services/server/content-api.mjs +12 -0
  581. package/dist/services/server/content-api.mjs.map +1 -0
  582. package/dist/services/server/http-server.js +42 -47
  583. package/dist/services/server/http-server.js.map +1 -1
  584. package/dist/services/server/http-server.mjs +47 -0
  585. package/dist/services/server/http-server.mjs.map +1 -0
  586. package/dist/services/server/index.js +82 -85
  587. package/dist/services/server/index.js.map +1 -1
  588. package/dist/services/server/index.mjs +86 -0
  589. package/dist/services/server/index.mjs.map +1 -0
  590. package/dist/services/server/koa.js +46 -50
  591. package/dist/services/server/koa.js.map +1 -1
  592. package/dist/services/server/koa.mjs +48 -0
  593. package/dist/services/server/koa.mjs.map +1 -0
  594. package/dist/services/server/middleware.js +80 -91
  595. package/dist/services/server/middleware.js.map +1 -1
  596. package/dist/services/server/middleware.mjs +90 -0
  597. package/dist/services/server/middleware.mjs.map +1 -0
  598. package/dist/services/server/policy.js +16 -17
  599. package/dist/services/server/policy.js.map +1 -1
  600. package/dist/services/server/policy.mjs +20 -0
  601. package/dist/services/server/policy.mjs.map +1 -0
  602. package/dist/services/server/register-middlewares.js +58 -68
  603. package/dist/services/server/register-middlewares.js.map +1 -1
  604. package/dist/services/server/register-middlewares.mjs +73 -0
  605. package/dist/services/server/register-middlewares.mjs.map +1 -0
  606. package/dist/services/server/register-routes.js +64 -82
  607. package/dist/services/server/register-routes.js.map +1 -1
  608. package/dist/services/server/register-routes.mjs +75 -0
  609. package/dist/services/server/register-routes.mjs.map +1 -0
  610. package/dist/services/server/routing.js +80 -94
  611. package/dist/services/server/routing.js.map +1 -1
  612. package/dist/services/server/routing.mjs +89 -0
  613. package/dist/services/server/routing.mjs.map +1 -0
  614. package/dist/services/utils/dynamic-zones.js +13 -10
  615. package/dist/services/utils/dynamic-zones.js.map +1 -1
  616. package/dist/services/utils/dynamic-zones.mjs +17 -0
  617. package/dist/services/utils/dynamic-zones.mjs.map +1 -0
  618. package/dist/services/utils/upload-files.js +59 -68
  619. package/dist/services/utils/upload-files.js.map +1 -1
  620. package/dist/services/utils/upload-files.mjs +63 -0
  621. package/dist/services/utils/upload-files.mjs.map +1 -0
  622. package/dist/services/webhook-runner.js +122 -130
  623. package/dist/services/webhook-runner.js.map +1 -1
  624. package/dist/services/webhook-runner.mjs +131 -0
  625. package/dist/services/webhook-runner.mjs.map +1 -0
  626. package/dist/services/webhook-store.js +87 -93
  627. package/dist/services/webhook-store.js.map +1 -1
  628. package/dist/services/webhook-store.mjs +100 -0
  629. package/dist/services/webhook-store.mjs.map +1 -0
  630. package/dist/services/worker-queue.js +49 -57
  631. package/dist/services/worker-queue.js.map +1 -1
  632. package/dist/services/worker-queue.mjs +55 -0
  633. package/dist/services/worker-queue.mjs.map +1 -0
  634. package/dist/utils/addSlash.js +13 -13
  635. package/dist/utils/addSlash.js.map +1 -1
  636. package/dist/utils/convert-custom-field-type.js +19 -16
  637. package/dist/utils/convert-custom-field-type.js.map +1 -1
  638. package/dist/utils/convert-custom-field-type.mjs +24 -0
  639. package/dist/utils/convert-custom-field-type.mjs.map +1 -0
  640. package/dist/utils/cron.js +29 -47
  641. package/dist/utils/cron.js.map +1 -1
  642. package/dist/utils/cron.mjs +38 -0
  643. package/dist/utils/cron.mjs.map +1 -0
  644. package/dist/utils/ee.js +3 -7
  645. package/dist/utils/ee.js.map +1 -1
  646. package/dist/utils/ee.mjs +5 -0
  647. package/dist/utils/ee.mjs.map +1 -0
  648. package/dist/utils/fetch.js +17 -19
  649. package/dist/utils/fetch.js.map +1 -1
  650. package/dist/utils/fetch.mjs +19 -0
  651. package/dist/utils/fetch.mjs.map +1 -0
  652. package/dist/utils/get-dirs.js +26 -27
  653. package/dist/utils/get-dirs.js.map +1 -1
  654. package/dist/utils/get-dirs.mjs +30 -0
  655. package/dist/utils/get-dirs.mjs.map +1 -0
  656. package/dist/utils/is-initialized.js +11 -17
  657. package/dist/utils/is-initialized.js.map +1 -1
  658. package/dist/utils/is-initialized.mjs +16 -0
  659. package/dist/utils/is-initialized.mjs.map +1 -0
  660. package/dist/utils/lifecycles.js +7 -7
  661. package/dist/utils/lifecycles.js.map +1 -1
  662. package/dist/utils/lifecycles.mjs +9 -0
  663. package/dist/utils/lifecycles.mjs.map +1 -0
  664. package/dist/utils/machine-id.js +12 -13
  665. package/dist/utils/machine-id.js.map +1 -1
  666. package/dist/utils/machine-id.mjs +15 -0
  667. package/dist/utils/machine-id.mjs.map +1 -0
  668. package/dist/utils/open-browser.js +8 -10
  669. package/dist/utils/open-browser.js.map +1 -1
  670. package/dist/utils/open-browser.mjs +10 -0
  671. package/dist/utils/open-browser.mjs.map +1 -0
  672. package/dist/utils/signals.js +13 -16
  673. package/dist/utils/signals.js.map +1 -1
  674. package/dist/utils/signals.mjs +17 -0
  675. package/dist/utils/signals.mjs.map +1 -0
  676. package/dist/utils/startup-logger.js +73 -66
  677. package/dist/utils/startup-logger.js.map +1 -1
  678. package/dist/utils/startup-logger.mjs +72 -0
  679. package/dist/utils/startup-logger.mjs.map +1 -0
  680. package/dist/utils/update-notifier/index.js +69 -72
  681. package/dist/utils/update-notifier/index.js.map +1 -1
  682. package/dist/utils/update-notifier/index.mjs +76 -0
  683. package/dist/utils/update-notifier/index.mjs.map +1 -0
  684. package/package.json +26 -25
  685. package/dist/commands/builders/index.js +0 -11
  686. package/dist/commands/builders/index.js.map +0 -1
  687. package/dist/commands/types.js +0 -3
  688. package/dist/commands/types.js.map +0 -1
  689. package/dist/load/index.js +0 -11
  690. package/dist/load/index.js.map +0 -1
  691. package/dist/services/content-api/permissions/providers/index.js +0 -11
  692. package/dist/services/content-api/permissions/providers/index.js.map +0 -1
  693. package/dist/utils/index.js +0 -13
  694. package/dist/utils/index.js.map +0 -1
  695. package/dist/utils/postinstall.js +0 -32
  696. package/dist/utils/postinstall.js.map +0 -1
  697. package/index.js +0 -5
@@ -0,0 +1,114 @@
1
+ import { prop, castArray, trim, toLower, isNil } from "lodash/fp";
2
+ import { errors } from "@strapi/utils";
3
+ import compose from "koa-compose";
4
+ import { resolveRouteMiddlewares } from "./middleware.mjs";
5
+ import { resolvePolicies } from "./policy.mjs";
6
+ const getMethod = (route) => {
7
+ return trim(toLower(route.method));
8
+ };
9
+ const getPath = (route) => trim(route.path);
10
+ const createRouteInfoMiddleware = (routeInfo) => (ctx, next) => {
11
+ const route = {
12
+ ...routeInfo,
13
+ config: routeInfo.config || {}
14
+ };
15
+ ctx.state.route = route;
16
+ return next();
17
+ };
18
+ const getAuthConfig = prop("config.auth");
19
+ const createAuthorizeMiddleware = (strapi) => async (ctx, next) => {
20
+ const { auth, route } = ctx.state;
21
+ const authService = strapi.container.get("auth");
22
+ try {
23
+ await authService.verify(auth, getAuthConfig(route));
24
+ return await next();
25
+ } catch (error) {
26
+ if (error instanceof errors.UnauthorizedError) {
27
+ return ctx.unauthorized();
28
+ }
29
+ if (error instanceof errors.ForbiddenError) {
30
+ return ctx.forbidden();
31
+ }
32
+ throw error;
33
+ }
34
+ };
35
+ const createAuthenticateMiddleware = (strapi) => async (ctx, next) => {
36
+ return strapi.container.get("auth").authenticate(ctx, next);
37
+ };
38
+ const returnBodyMiddleware = async (ctx, next) => {
39
+ const values = await next();
40
+ if (isNil(ctx.body) && !isNil(values)) {
41
+ ctx.body = values;
42
+ }
43
+ };
44
+ const createEndpointComposer = (strapi) => {
45
+ const authenticate = createAuthenticateMiddleware(strapi);
46
+ const authorize = createAuthorizeMiddleware(strapi);
47
+ return (route, { router }) => {
48
+ try {
49
+ const method = getMethod(route);
50
+ const path = getPath(route);
51
+ const middlewares = resolveRouteMiddlewares(route, strapi);
52
+ const policies = resolvePolicies(route);
53
+ const action = getAction(route, strapi);
54
+ const routeHandler = compose([
55
+ createRouteInfoMiddleware(route),
56
+ authenticate,
57
+ authorize,
58
+ ...policies,
59
+ ...middlewares,
60
+ returnBodyMiddleware,
61
+ ...castArray(action)
62
+ ]);
63
+ router[method](path, routeHandler);
64
+ } catch (error) {
65
+ if (error instanceof Error) {
66
+ error.message = `Error creating endpoint ${route.method} ${route.path}: ${error.message}`;
67
+ }
68
+ throw error;
69
+ }
70
+ };
71
+ };
72
+ const getController = (name, { pluginName, apiName }, strapi) => {
73
+ let ctrl;
74
+ if (pluginName) {
75
+ if (pluginName === "admin") {
76
+ ctrl = strapi.controller(`admin::${name}`);
77
+ } else {
78
+ ctrl = strapi.plugin(pluginName).controller(name);
79
+ }
80
+ } else if (apiName) {
81
+ ctrl = strapi.controller(`api::${apiName}.${name}`);
82
+ }
83
+ if (!ctrl) {
84
+ return strapi.controller(name);
85
+ }
86
+ return ctrl;
87
+ };
88
+ const extractHandlerParts = (name) => {
89
+ const controllerName = name.slice(0, name.lastIndexOf("."));
90
+ const actionName = name.slice(name.lastIndexOf(".") + 1);
91
+ return { controllerName, actionName };
92
+ };
93
+ const getAction = (route, strapi) => {
94
+ const { handler, info } = route;
95
+ const { pluginName, apiName, type } = info ?? {};
96
+ if (Array.isArray(handler) || typeof handler === "function") {
97
+ return handler;
98
+ }
99
+ const { controllerName, actionName } = extractHandlerParts(trim(handler));
100
+ const controller = getController(controllerName, { pluginName, apiName, type }, strapi);
101
+ if (typeof controller[actionName] !== "function") {
102
+ throw new Error(`Handler not found "${handler}"`);
103
+ }
104
+ if (Symbol.for("__type__") in controller[actionName]) {
105
+ controller[actionName][Symbol.for("__type__")].push(type);
106
+ } else {
107
+ controller[actionName][Symbol.for("__type__")] = [type];
108
+ }
109
+ return controller[actionName].bind(controller);
110
+ };
111
+ export {
112
+ createEndpointComposer as default
113
+ };
114
+ //# sourceMappingURL=compose-endpoint.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"compose-endpoint.mjs","sources":["../../../src/services/server/compose-endpoint.ts"],"sourcesContent":["import { toLower, castArray, trim, prop, isNil } from 'lodash/fp';\nimport type { Strapi, Common } from '@strapi/types';\nimport { errors } from '@strapi/utils';\nimport Router from '@koa/router';\n\nimport compose from 'koa-compose';\nimport { resolveRouteMiddlewares } from './middleware';\nimport { resolvePolicies } from './policy';\n\nconst getMethod = (route: Common.Route) => {\n return trim(toLower(route.method)) as Lowercase<Common.Route['method']>;\n};\n\nconst getPath = (route: Common.Route) => trim(route.path);\n\nconst createRouteInfoMiddleware =\n (routeInfo: Common.Route): Common.MiddlewareHandler =>\n (ctx, next) => {\n const route = {\n ...routeInfo,\n config: routeInfo.config || {},\n };\n\n ctx.state.route = route;\n return next();\n };\n\nconst getAuthConfig = prop('config.auth');\n\nconst createAuthorizeMiddleware =\n (strapi: Strapi): Common.MiddlewareHandler =>\n async (ctx, next) => {\n const { auth, route } = ctx.state;\n\n const authService = strapi.container.get('auth');\n\n try {\n await authService.verify(auth, getAuthConfig(route));\n\n return await next();\n } catch (error) {\n if (error instanceof errors.UnauthorizedError) {\n return ctx.unauthorized();\n }\n\n if (error instanceof errors.ForbiddenError) {\n return ctx.forbidden();\n }\n\n throw error;\n }\n };\n\nconst createAuthenticateMiddleware =\n (strapi: Strapi): Common.MiddlewareHandler =>\n async (ctx, next) => {\n return strapi.container.get('auth').authenticate(ctx, next);\n };\n\nconst returnBodyMiddleware: Common.MiddlewareHandler = async (ctx, next) => {\n const values = await next();\n\n if (isNil(ctx.body) && !isNil(values)) {\n ctx.body = values;\n }\n};\n\nexport default (strapi: Strapi) => {\n const authenticate = createAuthenticateMiddleware(strapi);\n const authorize = createAuthorizeMiddleware(strapi);\n\n return (route: Common.Route, { router }: { router: Router }) => {\n try {\n const method = getMethod(route);\n const path = getPath(route);\n\n const middlewares = resolveRouteMiddlewares(route, strapi);\n const policies = resolvePolicies(route);\n\n const action = getAction(route, strapi);\n\n const routeHandler = compose([\n createRouteInfoMiddleware(route),\n authenticate,\n authorize,\n ...policies,\n ...middlewares,\n returnBodyMiddleware,\n ...castArray(action),\n ]);\n\n router[method](path, routeHandler);\n } catch (error) {\n if (error instanceof Error) {\n error.message = `Error creating endpoint ${route.method} ${route.path}: ${error.message}`;\n }\n\n throw error;\n }\n };\n};\n\nconst getController = (name: string, { pluginName, apiName }: Common.RouteInfo, strapi: Strapi) => {\n let ctrl: Common.Controller | undefined;\n\n if (pluginName) {\n if (pluginName === 'admin') {\n ctrl = strapi.controller(`admin::${name}`);\n } else {\n ctrl = strapi.plugin(pluginName).controller(name);\n }\n } else if (apiName) {\n ctrl = strapi.controller(`api::${apiName}.${name}`);\n }\n\n if (!ctrl) {\n return strapi.controller(name as Common.UID.Controller);\n }\n\n return ctrl;\n};\n\nconst extractHandlerParts = (name: string) => {\n const controllerName = name.slice(0, name.lastIndexOf('.'));\n const actionName = name.slice(name.lastIndexOf('.') + 1);\n\n return { controllerName, actionName };\n};\n\nconst getAction = (route: Common.Route, strapi: Strapi) => {\n const { handler, info } = route;\n const { pluginName, apiName, type } = info ?? {};\n\n if (Array.isArray(handler) || typeof handler === 'function') {\n return handler;\n }\n\n const { controllerName, actionName } = extractHandlerParts(trim(handler));\n\n const controller = getController(controllerName, { pluginName, apiName, type }, strapi);\n\n if (typeof controller[actionName] !== 'function') {\n throw new Error(`Handler not found \"${handler}\"`);\n }\n\n if (Symbol.for('__type__') in controller[actionName]) {\n (controller[actionName] as any)[Symbol.for('__type__')].push(type);\n } else {\n (controller[actionName] as any)[Symbol.for('__type__')] = [type];\n }\n\n return controller[actionName].bind(controller);\n};\n"],"names":[],"mappings":"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"}
@@ -1,13 +1,12 @@
1
1
  "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.createContentAPI = void 0;
4
- const api_1 = require("./api");
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const api = require("./api.js");
5
4
  const createContentAPI = (strapi) => {
6
- const opts = {
7
- prefix: strapi.config.get('api.rest.prefix', '/api'),
8
- type: 'content-api',
9
- };
10
- return (0, api_1.createAPI)(strapi, opts);
5
+ const opts = {
6
+ prefix: strapi.config.get("api.rest.prefix", "/api"),
7
+ type: "content-api"
8
+ };
9
+ return api.createAPI(strapi, opts);
11
10
  };
12
11
  exports.createContentAPI = createContentAPI;
13
- //# sourceMappingURL=content-api.js.map
12
+ //# sourceMappingURL=content-api.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"content-api.js","sourceRoot":"","sources":["../../../src/services/server/content-api.ts"],"names":[],"mappings":";;;AACA,+BAAkC;AAElC,MAAM,gBAAgB,GAAG,CAAC,MAAc,EAAE,EAAE;IAC1C,MAAM,IAAI,GAAG;QACX,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,iBAAiB,EAAE,MAAM,CAAC;QACpD,IAAI,EAAE,aAAa;KACpB,CAAC;IAEF,OAAO,IAAA,eAAS,EAAC,MAAM,EAAE,IAAI,CAAC,CAAC;AACjC,CAAC,CAAC;AAEO,4CAAgB"}
1
+ {"version":3,"file":"content-api.js","sources":["../../../src/services/server/content-api.ts"],"sourcesContent":["import type { Strapi } from '@strapi/types';\nimport { createAPI } from './api';\n\nconst createContentAPI = (strapi: Strapi) => {\n const opts = {\n prefix: strapi.config.get('api.rest.prefix', '/api'),\n type: 'content-api',\n };\n\n return createAPI(strapi, opts);\n};\n\nexport { createContentAPI };\n"],"names":["createAPI"],"mappings":";;;AAGM,MAAA,mBAAmB,CAAC,WAAmB;AAC3C,QAAM,OAAO;AAAA,IACX,QAAQ,OAAO,OAAO,IAAI,mBAAmB,MAAM;AAAA,IACnD,MAAM;AAAA,EAAA;AAGD,SAAAA,IAAA,UAAU,QAAQ,IAAI;AAC/B;;"}
@@ -0,0 +1,12 @@
1
+ import { createAPI } from "./api.mjs";
2
+ const createContentAPI = (strapi) => {
3
+ const opts = {
4
+ prefix: strapi.config.get("api.rest.prefix", "/api"),
5
+ type: "content-api"
6
+ };
7
+ return createAPI(strapi, opts);
8
+ };
9
+ export {
10
+ createContentAPI
11
+ };
12
+ //# sourceMappingURL=content-api.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"content-api.mjs","sources":["../../../src/services/server/content-api.ts"],"sourcesContent":["import type { Strapi } from '@strapi/types';\nimport { createAPI } from './api';\n\nconst createContentAPI = (strapi: Strapi) => {\n const opts = {\n prefix: strapi.config.get('api.rest.prefix', '/api'),\n type: 'content-api',\n };\n\n return createAPI(strapi, opts);\n};\n\nexport { createContentAPI };\n"],"names":[],"mappings":";AAGM,MAAA,mBAAmB,CAAC,WAAmB;AAC3C,QAAM,OAAO;AAAA,IACX,QAAQ,OAAO,OAAO,IAAI,mBAAmB,MAAM;AAAA,IACnD,MAAM;AAAA,EAAA;AAGD,SAAA,UAAU,QAAQ,IAAI;AAC/B;"}
@@ -1,54 +1,49 @@
1
1
  "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.createHTTPServer = void 0;
7
- const http_1 = __importDefault(require("http"));
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const http = require("http");
4
+ const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
5
+ const http__default = /* @__PURE__ */ _interopDefault(http);
8
6
  const createHTTPServer = (strapi, koaApp) => {
9
- const connections = new Set();
10
- // lazy creation of the request listener
11
- let handler;
12
- const listener = function handleRequest(req, res) {
13
- if (!handler) {
14
- handler = koaApp.callback();
15
- }
16
- return handler(req, res);
17
- };
18
- const server = http_1.default.createServer(listener);
19
- server.on('connection', (connection) => {
20
- connections.add(connection);
21
- connection.on('close', () => {
22
- connections.delete(connection);
23
- });
7
+ const connections = /* @__PURE__ */ new Set();
8
+ let handler;
9
+ const listener = function handleRequest(req, res) {
10
+ if (!handler) {
11
+ handler = koaApp.callback();
12
+ }
13
+ return handler(req, res);
14
+ };
15
+ const server = http__default.default.createServer(listener);
16
+ server.on("connection", (connection) => {
17
+ connections.add(connection);
18
+ connection.on("close", () => {
19
+ connections.delete(connection);
24
20
  });
25
- // handle port in use cleanly
26
- server.on('error', (err) => {
27
- if ('code' in err && 'port' in err && err.code === 'EADDRINUSE') {
28
- return strapi.stopWithError(`The port ${err.port} is already used by another application.`);
21
+ });
22
+ server.on("error", (err) => {
23
+ if ("code" in err && "port" in err && err.code === "EADDRINUSE") {
24
+ return strapi.stopWithError(`The port ${err.port} is already used by another application.`);
25
+ }
26
+ strapi.log.error(err);
27
+ });
28
+ const destroy = async () => {
29
+ for (const connection of connections) {
30
+ connection.destroy();
31
+ connections.delete(connection);
32
+ }
33
+ if (!server.listening) {
34
+ return;
35
+ }
36
+ return new Promise((resolve, reject) => {
37
+ server.close((error) => {
38
+ if (error) {
39
+ reject(error);
40
+ } else {
41
+ resolve();
29
42
  }
30
- strapi.log.error(err);
43
+ });
31
44
  });
32
- const destroy = async () => {
33
- for (const connection of connections) {
34
- connection.destroy();
35
- connections.delete(connection);
36
- }
37
- if (!server.listening) {
38
- return;
39
- }
40
- return new Promise((resolve, reject) => {
41
- server.close((error) => {
42
- if (error) {
43
- reject(error);
44
- }
45
- else {
46
- resolve();
47
- }
48
- });
49
- });
50
- };
51
- return Object.assign(server, { destroy });
45
+ };
46
+ return Object.assign(server, { destroy });
52
47
  };
53
48
  exports.createHTTPServer = createHTTPServer;
54
- //# sourceMappingURL=http-server.js.map
49
+ //# sourceMappingURL=http-server.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"http-server.js","sourceRoot":"","sources":["../../../src/services/server/http-server.ts"],"names":[],"mappings":";;;;;;AAAA,gDAAwB;AASxB,MAAM,gBAAgB,GAAG,CAAC,MAAc,EAAE,MAAW,EAAU,EAAE;IAC/D,MAAM,WAAW,GAAG,IAAI,GAAG,EAAU,CAAC;IAEtC,wCAAwC;IACxC,IAAI,OAA6B,CAAC;IAClC,MAAM,QAAQ,GAAyB,SAAS,aAAa,CAAC,GAAG,EAAE,GAAG;QACpE,IAAI,CAAC,OAAO,EAAE;YACZ,OAAO,GAAG,MAAM,CAAC,QAAQ,EAAE,CAAC;SAC7B;QAED,OAAO,OAAO,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;IAC3B,CAAC,CAAC;IAEF,MAAM,MAAM,GAAgB,cAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;IAExD,MAAM,CAAC,EAAE,CAAC,YAAY,EAAE,CAAC,UAAU,EAAE,EAAE;QACrC,WAAW,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;QAE5B,UAAU,CAAC,EAAE,CAAC,OAAO,EAAE,GAAG,EAAE;YAC1B,WAAW,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;QACjC,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,6BAA6B;IAC7B,MAAM,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,GAAG,EAAE,EAAE;QACzB,IAAI,MAAM,IAAI,GAAG,IAAI,MAAM,IAAI,GAAG,IAAI,GAAG,CAAC,IAAI,KAAK,YAAY,EAAE;YAC/D,OAAO,MAAM,CAAC,aAAa,CAAC,YAAY,GAAG,CAAC,IAAI,0CAA0C,CAAC,CAAC;SAC7F;QAED,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IACxB,CAAC,CAAC,CAAC;IAEH,MAAM,OAAO,GAAG,KAAK,IAAI,EAAE;QACzB,KAAK,MAAM,UAAU,IAAI,WAAW,EAAE;YACpC,UAAU,CAAC,OAAO,EAAE,CAAC;YAErB,WAAW,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;SAChC;QAED,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE;YACrB,OAAO;SACR;QAED,OAAO,IAAI,OAAO,CAAO,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YAC3C,MAAM,CAAC,KAAK,CAAC,CAAC,KAAK,EAAE,EAAE;gBACrB,IAAI,KAAK,EAAE;oBACT,MAAM,CAAC,KAAK,CAAC,CAAC;iBACf;qBAAM;oBACL,OAAO,EAAE,CAAC;iBACX;YACH,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC,CAAC;IAEF,OAAO,MAAM,CAAC,MAAM,CAAC,MAAM,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC;AAC5C,CAAC,CAAC;AAEO,4CAAgB"}
1
+ {"version":3,"file":"http-server.js","sources":["../../../src/services/server/http-server.ts"],"sourcesContent":["import http from 'http';\nimport type { Socket } from 'net';\nimport Koa from 'koa';\nimport type { Strapi } from '@strapi/types';\n\nexport interface Server extends http.Server {\n destroy: () => Promise<void>;\n}\n\nconst createHTTPServer = (strapi: Strapi, koaApp: Koa): Server => {\n const connections = new Set<Socket>();\n\n // lazy creation of the request listener\n let handler: http.RequestListener;\n const listener: http.RequestListener = function handleRequest(req, res) {\n if (!handler) {\n handler = koaApp.callback();\n }\n\n return handler(req, res);\n };\n\n const server: http.Server = http.createServer(listener);\n\n server.on('connection', (connection) => {\n connections.add(connection);\n\n connection.on('close', () => {\n connections.delete(connection);\n });\n });\n\n // handle port in use cleanly\n server.on('error', (err) => {\n if ('code' in err && 'port' in err && err.code === 'EADDRINUSE') {\n return strapi.stopWithError(`The port ${err.port} is already used by another application.`);\n }\n\n strapi.log.error(err);\n });\n\n const destroy = async () => {\n for (const connection of connections) {\n connection.destroy();\n\n connections.delete(connection);\n }\n\n if (!server.listening) {\n return;\n }\n\n return new Promise<void>((resolve, reject) => {\n server.close((error) => {\n if (error) {\n reject(error);\n } else {\n resolve();\n }\n });\n });\n };\n\n return Object.assign(server, { destroy });\n};\n\nexport { createHTTPServer };\n"],"names":["http"],"mappings":";;;;;AASM,MAAA,mBAAmB,CAAC,QAAgB,WAAwB;AAC1D,QAAA,kCAAkB;AAGpB,MAAA;AACJ,QAAM,WAAiC,SAAS,cAAc,KAAK,KAAK;AACtE,QAAI,CAAC,SAAS;AACZ,gBAAU,OAAO;IACnB;AAEO,WAAA,QAAQ,KAAK,GAAG;AAAA,EAAA;AAGnB,QAAA,SAAsBA,cAAAA,QAAK,aAAa,QAAQ;AAE/C,SAAA,GAAG,cAAc,CAAC,eAAe;AACtC,gBAAY,IAAI,UAAU;AAEf,eAAA,GAAG,SAAS,MAAM;AAC3B,kBAAY,OAAO,UAAU;AAAA,IAAA,CAC9B;AAAA,EAAA,CACF;AAGM,SAAA,GAAG,SAAS,CAAC,QAAQ;AAC1B,QAAI,UAAU,OAAO,UAAU,OAAO,IAAI,SAAS,cAAc;AAC/D,aAAO,OAAO,cAAc,YAAY,IAAI,IAAI,0CAA0C;AAAA,IAC5F;AAEO,WAAA,IAAI,MAAM,GAAG;AAAA,EAAA,CACrB;AAED,QAAM,UAAU,YAAY;AAC1B,eAAW,cAAc,aAAa;AACpC,iBAAW,QAAQ;AAEnB,kBAAY,OAAO,UAAU;AAAA,IAC/B;AAEI,QAAA,CAAC,OAAO,WAAW;AACrB;AAAA,IACF;AAEA,WAAO,IAAI,QAAc,CAAC,SAAS,WAAW;AACrC,aAAA,MAAM,CAAC,UAAU;AACtB,YAAI,OAAO;AACT,iBAAO,KAAK;AAAA,QAAA,OACP;AACG;QACV;AAAA,MAAA,CACD;AAAA,IAAA,CACF;AAAA,EAAA;AAGH,SAAO,OAAO,OAAO,QAAQ,EAAE,QAAS,CAAA;AAC1C;;"}
@@ -0,0 +1,47 @@
1
+ import http from "http";
2
+ const createHTTPServer = (strapi, koaApp) => {
3
+ const connections = /* @__PURE__ */ new Set();
4
+ let handler;
5
+ const listener = function handleRequest(req, res) {
6
+ if (!handler) {
7
+ handler = koaApp.callback();
8
+ }
9
+ return handler(req, res);
10
+ };
11
+ const server = http.createServer(listener);
12
+ server.on("connection", (connection) => {
13
+ connections.add(connection);
14
+ connection.on("close", () => {
15
+ connections.delete(connection);
16
+ });
17
+ });
18
+ server.on("error", (err) => {
19
+ if ("code" in err && "port" in err && err.code === "EADDRINUSE") {
20
+ return strapi.stopWithError(`The port ${err.port} is already used by another application.`);
21
+ }
22
+ strapi.log.error(err);
23
+ });
24
+ const destroy = async () => {
25
+ for (const connection of connections) {
26
+ connection.destroy();
27
+ connections.delete(connection);
28
+ }
29
+ if (!server.listening) {
30
+ return;
31
+ }
32
+ return new Promise((resolve, reject) => {
33
+ server.close((error) => {
34
+ if (error) {
35
+ reject(error);
36
+ } else {
37
+ resolve();
38
+ }
39
+ });
40
+ });
41
+ };
42
+ return Object.assign(server, { destroy });
43
+ };
44
+ export {
45
+ createHTTPServer
46
+ };
47
+ //# sourceMappingURL=http-server.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"http-server.mjs","sources":["../../../src/services/server/http-server.ts"],"sourcesContent":["import http from 'http';\nimport type { Socket } from 'net';\nimport Koa from 'koa';\nimport type { Strapi } from '@strapi/types';\n\nexport interface Server extends http.Server {\n destroy: () => Promise<void>;\n}\n\nconst createHTTPServer = (strapi: Strapi, koaApp: Koa): Server => {\n const connections = new Set<Socket>();\n\n // lazy creation of the request listener\n let handler: http.RequestListener;\n const listener: http.RequestListener = function handleRequest(req, res) {\n if (!handler) {\n handler = koaApp.callback();\n }\n\n return handler(req, res);\n };\n\n const server: http.Server = http.createServer(listener);\n\n server.on('connection', (connection) => {\n connections.add(connection);\n\n connection.on('close', () => {\n connections.delete(connection);\n });\n });\n\n // handle port in use cleanly\n server.on('error', (err) => {\n if ('code' in err && 'port' in err && err.code === 'EADDRINUSE') {\n return strapi.stopWithError(`The port ${err.port} is already used by another application.`);\n }\n\n strapi.log.error(err);\n });\n\n const destroy = async () => {\n for (const connection of connections) {\n connection.destroy();\n\n connections.delete(connection);\n }\n\n if (!server.listening) {\n return;\n }\n\n return new Promise<void>((resolve, reject) => {\n server.close((error) => {\n if (error) {\n reject(error);\n } else {\n resolve();\n }\n });\n });\n };\n\n return Object.assign(server, { destroy });\n};\n\nexport { createHTTPServer };\n"],"names":[],"mappings":";AASM,MAAA,mBAAmB,CAAC,QAAgB,WAAwB;AAC1D,QAAA,kCAAkB;AAGpB,MAAA;AACJ,QAAM,WAAiC,SAAS,cAAc,KAAK,KAAK;AACtE,QAAI,CAAC,SAAS;AACZ,gBAAU,OAAO;IACnB;AAEO,WAAA,QAAQ,KAAK,GAAG;AAAA,EAAA;AAGnB,QAAA,SAAsB,KAAK,aAAa,QAAQ;AAE/C,SAAA,GAAG,cAAc,CAAC,eAAe;AACtC,gBAAY,IAAI,UAAU;AAEf,eAAA,GAAG,SAAS,MAAM;AAC3B,kBAAY,OAAO,UAAU;AAAA,IAAA,CAC9B;AAAA,EAAA,CACF;AAGM,SAAA,GAAG,SAAS,CAAC,QAAQ;AAC1B,QAAI,UAAU,OAAO,UAAU,OAAO,IAAI,SAAS,cAAc;AAC/D,aAAO,OAAO,cAAc,YAAY,IAAI,IAAI,0CAA0C;AAAA,IAC5F;AAEO,WAAA,IAAI,MAAM,GAAG;AAAA,EAAA,CACrB;AAED,QAAM,UAAU,YAAY;AAC1B,eAAW,cAAc,aAAa;AACpC,iBAAW,QAAQ;AAEnB,kBAAY,OAAO,UAAU;AAAA,IAC/B;AAEI,QAAA,CAAC,OAAO,WAAW;AACrB;AAAA,IACF;AAEA,WAAO,IAAI,QAAc,CAAC,SAAS,WAAW;AACrC,aAAA,MAAM,CAAC,UAAU;AACtB,YAAI,OAAO;AACT,iBAAO,KAAK;AAAA,QAAA,OACP;AACG;QACV;AAAA,MAAA,CACD;AAAA,IAAA,CACF;AAAA,EAAA;AAGH,SAAO,OAAO,OAAO,QAAQ,EAAE,QAAS,CAAA;AAC1C;"}
@@ -1,91 +1,88 @@
1
1
  "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.createServer = void 0;
7
- const router_1 = __importDefault(require("@koa/router"));
8
- const http_server_1 = require("./http-server");
9
- const routing_1 = require("./routing");
10
- const admin_api_1 = require("./admin-api");
11
- const content_api_1 = require("./content-api");
12
- const register_routes_1 = __importDefault(require("./register-routes"));
13
- const register_middlewares_1 = __importDefault(require("./register-middlewares"));
14
- const koa_1 = __importDefault(require("./koa"));
15
- const request_context_1 = __importDefault(require("../request-context"));
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const Router = require("@koa/router");
4
+ const httpServer = require("./http-server.js");
5
+ const routing = require("./routing.js");
6
+ const adminApi = require("./admin-api.js");
7
+ const contentApi = require("./content-api.js");
8
+ const registerRoutes = require("./register-routes.js");
9
+ const registerMiddlewares = require("./register-middlewares.js");
10
+ const koa = require("./koa.js");
11
+ const requestContext = require("../request-context.js");
12
+ const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
13
+ const Router__default = /* @__PURE__ */ _interopDefault(Router);
16
14
  const healthCheck = async (ctx) => {
17
- ctx.set('strapi', 'You are so French!');
18
- ctx.status = 204;
15
+ ctx.set("strapi", "You are so French!");
16
+ ctx.status = 204;
19
17
  };
20
18
  const createServer = (strapi) => {
21
- const app = (0, koa_1.default)({
22
- proxy: strapi.config.get('server.proxy'),
23
- keys: strapi.config.get('server.app.keys'),
24
- });
25
- app.use((ctx, next) => request_context_1.default.run(ctx, () => next()));
26
- const router = new router_1.default();
27
- const routeManager = (0, routing_1.createRouteManager)(strapi);
28
- const httpServer = (0, http_server_1.createHTTPServer)(strapi, app);
29
- const apis = {
30
- 'content-api': (0, content_api_1.createContentAPI)(strapi),
31
- admin: (0, admin_api_1.createAdminAPI)(strapi),
32
- };
33
- // init health check
34
- router.all('/_health', healthCheck);
35
- const state = {
36
- mounted: false,
37
- };
38
- return {
39
- app,
40
- router,
41
- httpServer,
42
- api(name) {
43
- return apis[name];
44
- },
45
- use(...args) {
46
- app.use(...args);
47
- return this;
48
- },
49
- routes(routes) {
50
- if (!Array.isArray(routes) && routes.type) {
51
- const api = apis[routes.type];
52
- if (!api) {
53
- throw new Error(`API ${routes.type} not found. Possible APIs are ${Object.keys(apis)}`);
54
- }
55
- apis[routes.type].routes(routes);
56
- return this;
57
- }
58
- routeManager.addRoutes(routes, router);
59
- return this;
60
- },
61
- mount() {
62
- state.mounted = true;
63
- Object.values(apis).forEach((api) => api.mount(router));
64
- app.use(router.routes()).use(router.allowedMethods());
65
- return this;
66
- },
67
- initRouting() {
68
- (0, register_routes_1.default)(strapi);
69
- return this;
70
- },
71
- async initMiddlewares() {
72
- await (0, register_middlewares_1.default)(strapi);
73
- return this;
74
- },
75
- listRoutes() {
76
- const allRoutes = [...router.stack];
77
- return allRoutes;
78
- },
79
- listen(...args) {
80
- if (!state.mounted) {
81
- this.mount();
82
- }
83
- return httpServer.listen(...args);
84
- },
85
- async destroy() {
86
- await httpServer.destroy();
87
- },
88
- };
19
+ const app = koa({
20
+ proxy: strapi.config.get("server.proxy"),
21
+ keys: strapi.config.get("server.app.keys")
22
+ });
23
+ app.use((ctx, next) => requestContext.run(ctx, () => next()));
24
+ const router = new Router__default.default();
25
+ const routeManager = routing.createRouteManager(strapi);
26
+ const httpServer$1 = httpServer.createHTTPServer(strapi, app);
27
+ const apis = {
28
+ "content-api": contentApi.createContentAPI(strapi),
29
+ admin: adminApi.createAdminAPI(strapi)
30
+ };
31
+ router.all("/_health", healthCheck);
32
+ const state = {
33
+ mounted: false
34
+ };
35
+ return {
36
+ app,
37
+ router,
38
+ httpServer: httpServer$1,
39
+ api(name) {
40
+ return apis[name];
41
+ },
42
+ use(...args) {
43
+ app.use(...args);
44
+ return this;
45
+ },
46
+ routes(routes) {
47
+ if (!Array.isArray(routes) && routes.type) {
48
+ const api = apis[routes.type];
49
+ if (!api) {
50
+ throw new Error(`API ${routes.type} not found. Possible APIs are ${Object.keys(apis)}`);
51
+ }
52
+ apis[routes.type].routes(routes);
53
+ return this;
54
+ }
55
+ routeManager.addRoutes(routes, router);
56
+ return this;
57
+ },
58
+ mount() {
59
+ state.mounted = true;
60
+ Object.values(apis).forEach((api) => api.mount(router));
61
+ app.use(router.routes()).use(router.allowedMethods());
62
+ return this;
63
+ },
64
+ initRouting() {
65
+ registerRoutes(strapi);
66
+ return this;
67
+ },
68
+ async initMiddlewares() {
69
+ await registerMiddlewares(strapi);
70
+ return this;
71
+ },
72
+ listRoutes() {
73
+ const allRoutes = [...router.stack];
74
+ return allRoutes;
75
+ },
76
+ listen(...args) {
77
+ if (!state.mounted) {
78
+ this.mount();
79
+ }
80
+ return httpServer$1.listen(...args);
81
+ },
82
+ async destroy() {
83
+ await httpServer$1.destroy();
84
+ }
85
+ };
89
86
  };
90
87
  exports.createServer = createServer;
91
- //# sourceMappingURL=index.js.map
88
+ //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/services/server/index.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"index.js","sources":["../../../src/services/server/index.ts"],"sourcesContent":["import Router from '@koa/router';\nimport type { Strapi, Common, Server } from '@strapi/types';\n\nimport { createHTTPServer } from './http-server';\nimport { createRouteManager } from './routing';\nimport { createAdminAPI } from './admin-api';\nimport { createContentAPI } from './content-api';\nimport registerAllRoutes from './register-routes';\nimport registerApplicationMiddlewares from './register-middlewares';\nimport createKoaApp from './koa';\nimport requestCtx from '../request-context';\n\nconst healthCheck: Common.MiddlewareHandler = async (ctx) => {\n ctx.set('strapi', 'You are so French!');\n ctx.status = 204;\n};\n\nconst createServer = (strapi: Strapi): Server => {\n const app = createKoaApp({\n proxy: strapi.config.get('server.proxy'),\n keys: strapi.config.get('server.app.keys'),\n });\n\n app.use((ctx, next) => requestCtx.run(ctx, () => next()));\n\n const router = new Router();\n\n const routeManager = createRouteManager(strapi);\n\n const httpServer = createHTTPServer(strapi, app);\n\n const apis = {\n 'content-api': createContentAPI(strapi),\n admin: createAdminAPI(strapi),\n };\n\n // init health check\n router.all('/_health', healthCheck);\n\n const state = {\n mounted: false,\n };\n\n return {\n app,\n router,\n httpServer,\n\n api(name) {\n return apis[name];\n },\n\n use(...args) {\n app.use(...args);\n return this;\n },\n\n routes(routes: Common.Router | Omit<Common.Route, 'info'>[]) {\n if (!Array.isArray(routes) && routes.type) {\n const api = apis[routes.type];\n if (!api) {\n throw new Error(`API ${routes.type} not found. Possible APIs are ${Object.keys(apis)}`);\n }\n\n apis[routes.type].routes(routes);\n return this;\n }\n\n routeManager.addRoutes(routes, router);\n return this;\n },\n\n mount() {\n state.mounted = true;\n\n Object.values(apis).forEach((api) => api.mount(router));\n app.use(router.routes()).use(router.allowedMethods());\n\n return this;\n },\n\n initRouting() {\n registerAllRoutes(strapi);\n\n return this;\n },\n\n async initMiddlewares() {\n await registerApplicationMiddlewares(strapi);\n\n return this;\n },\n\n listRoutes() {\n const allRoutes = [...router.stack];\n\n return allRoutes;\n },\n\n listen(...args: any[]) {\n if (!state.mounted) {\n this.mount();\n }\n\n return httpServer.listen(...args);\n },\n\n async destroy() {\n await httpServer.destroy();\n },\n };\n};\n\nexport { createServer };\n"],"names":["createKoaApp","requestCtx","Router","createRouteManager","httpServer","createHTTPServer","createContentAPI","createAdminAPI","registerAllRoutes","registerApplicationMiddlewares"],"mappings":";;;;;;;;;;;;;AAYA,MAAM,cAAwC,OAAO,QAAQ;AACvD,MAAA,IAAI,UAAU,oBAAoB;AACtC,MAAI,SAAS;AACf;AAEM,MAAA,eAAe,CAAC,WAA2B;AAC/C,QAAM,MAAMA,IAAa;AAAA,IACvB,OAAO,OAAO,OAAO,IAAI,cAAc;AAAA,IACvC,MAAM,OAAO,OAAO,IAAI,iBAAiB;AAAA,EAAA,CAC1C;AAEG,MAAA,IAAI,CAAC,KAAK,SAASC,eAAW,IAAI,KAAK,MAAM,KAAM,CAAA,CAAC;AAElD,QAAA,SAAS,IAAIC,gBAAAA;AAEb,QAAA,eAAeC,2BAAmB,MAAM;AAExC,QAAAC,eAAaC,WAAAA,iBAAiB,QAAQ,GAAG;AAE/C,QAAM,OAAO;AAAA,IACX,eAAeC,4BAAiB,MAAM;AAAA,IACtC,OAAOC,wBAAe,MAAM;AAAA,EAAA;AAIvB,SAAA,IAAI,YAAY,WAAW;AAElC,QAAM,QAAQ;AAAA,IACZ,SAAS;AAAA,EAAA;AAGJ,SAAA;AAAA,IACL;AAAA,IACA;AAAA,IAAA,YACAH;AAAAA,IAEA,IAAI,MAAM;AACR,aAAO,KAAK,IAAI;AAAA,IAClB;AAAA,IAEA,OAAO,MAAM;AACP,UAAA,IAAI,GAAG,IAAI;AACR,aAAA;AAAA,IACT;AAAA,IAEA,OAAO,QAAsD;AAC3D,UAAI,CAAC,MAAM,QAAQ,MAAM,KAAK,OAAO,MAAM;AACnC,cAAA,MAAM,KAAK,OAAO,IAAI;AAC5B,YAAI,CAAC,KAAK;AACF,gBAAA,IAAI,MAAM,OAAO,OAAO,IAAI,iCAAiC,OAAO,KAAK,IAAI,CAAC,EAAE;AAAA,QACxF;AAEA,aAAK,OAAO,IAAI,EAAE,OAAO,MAAM;AACxB,eAAA;AAAA,MACT;AAEa,mBAAA,UAAU,QAAQ,MAAM;AAC9B,aAAA;AAAA,IACT;AAAA,IAEA,QAAQ;AACN,YAAM,UAAU;AAET,aAAA,OAAO,IAAI,EAAE,QAAQ,CAAC,QAAQ,IAAI,MAAM,MAAM,CAAC;AAClD,UAAA,IAAI,OAAO,OAAO,CAAC,EAAE,IAAI,OAAO,gBAAgB;AAE7C,aAAA;AAAA,IACT;AAAA,IAEA,cAAc;AACZI,qBAAkB,MAAM;AAEjB,aAAA;AAAA,IACT;AAAA,IAEA,MAAM,kBAAkB;AACtB,YAAMC,oBAA+B,MAAM;AAEpC,aAAA;AAAA,IACT;AAAA,IAEA,aAAa;AACX,YAAM,YAAY,CAAC,GAAG,OAAO,KAAK;AAE3B,aAAA;AAAA,IACT;AAAA,IAEA,UAAU,MAAa;AACjB,UAAA,CAAC,MAAM,SAAS;AAClB,aAAK,MAAM;AAAA,MACb;AAEO,aAAAL,aAAW,OAAO,GAAG,IAAI;AAAA,IAClC;AAAA,IAEA,MAAM,UAAU;AACd,YAAMA,aAAW;IACnB;AAAA,EAAA;AAEJ;;"}
@@ -0,0 +1,86 @@
1
+ import Router from "@koa/router";
2
+ import { createHTTPServer } from "./http-server.mjs";
3
+ import { createRouteManager } from "./routing.mjs";
4
+ import { createAdminAPI } from "./admin-api.mjs";
5
+ import { createContentAPI } from "./content-api.mjs";
6
+ import registerAllRoutes from "./register-routes.mjs";
7
+ import registerApplicationMiddlewares from "./register-middlewares.mjs";
8
+ import createKoaApp from "./koa.mjs";
9
+ import requestCtx from "../request-context.mjs";
10
+ const healthCheck = async (ctx) => {
11
+ ctx.set("strapi", "You are so French!");
12
+ ctx.status = 204;
13
+ };
14
+ const createServer = (strapi) => {
15
+ const app = createKoaApp({
16
+ proxy: strapi.config.get("server.proxy"),
17
+ keys: strapi.config.get("server.app.keys")
18
+ });
19
+ app.use((ctx, next) => requestCtx.run(ctx, () => next()));
20
+ const router = new Router();
21
+ const routeManager = createRouteManager(strapi);
22
+ const httpServer = createHTTPServer(strapi, app);
23
+ const apis = {
24
+ "content-api": createContentAPI(strapi),
25
+ admin: createAdminAPI(strapi)
26
+ };
27
+ router.all("/_health", healthCheck);
28
+ const state = {
29
+ mounted: false
30
+ };
31
+ return {
32
+ app,
33
+ router,
34
+ httpServer,
35
+ api(name) {
36
+ return apis[name];
37
+ },
38
+ use(...args) {
39
+ app.use(...args);
40
+ return this;
41
+ },
42
+ routes(routes) {
43
+ if (!Array.isArray(routes) && routes.type) {
44
+ const api = apis[routes.type];
45
+ if (!api) {
46
+ throw new Error(`API ${routes.type} not found. Possible APIs are ${Object.keys(apis)}`);
47
+ }
48
+ apis[routes.type].routes(routes);
49
+ return this;
50
+ }
51
+ routeManager.addRoutes(routes, router);
52
+ return this;
53
+ },
54
+ mount() {
55
+ state.mounted = true;
56
+ Object.values(apis).forEach((api) => api.mount(router));
57
+ app.use(router.routes()).use(router.allowedMethods());
58
+ return this;
59
+ },
60
+ initRouting() {
61
+ registerAllRoutes(strapi);
62
+ return this;
63
+ },
64
+ async initMiddlewares() {
65
+ await registerApplicationMiddlewares(strapi);
66
+ return this;
67
+ },
68
+ listRoutes() {
69
+ const allRoutes = [...router.stack];
70
+ return allRoutes;
71
+ },
72
+ listen(...args) {
73
+ if (!state.mounted) {
74
+ this.mount();
75
+ }
76
+ return httpServer.listen(...args);
77
+ },
78
+ async destroy() {
79
+ await httpServer.destroy();
80
+ }
81
+ };
82
+ };
83
+ export {
84
+ createServer
85
+ };
86
+ //# sourceMappingURL=index.mjs.map