@adonisjs/core 6.1.5-1 → 6.1.5-3

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 (309) hide show
  1. package/build/commands/build.d.ts +3 -0
  2. package/build/commands/build.d.ts.map +1 -0
  3. package/build/commands/build.js +22 -2
  4. package/build/commands/commands.json +1 -1
  5. package/build/commands/configure.d.ts +1 -0
  6. package/build/commands/configure.d.ts.map +1 -0
  7. package/build/commands/configure.js +2 -1
  8. package/build/commands/eject.d.ts +1 -0
  9. package/build/commands/eject.d.ts.map +1 -0
  10. package/build/commands/eject.js +2 -1
  11. package/build/commands/generate_key.d.ts +1 -0
  12. package/build/commands/generate_key.d.ts.map +1 -0
  13. package/build/commands/generate_key.js +2 -1
  14. package/build/commands/inspect_rcfile.d.ts +7 -0
  15. package/build/commands/inspect_rcfile.d.ts.map +1 -0
  16. package/build/commands/inspect_rcfile.js +10 -0
  17. package/build/commands/list/routes.d.ts +14 -0
  18. package/build/commands/list/routes.d.ts.map +1 -0
  19. package/build/commands/list/routes.js +79 -0
  20. package/build/commands/make/_base.d.ts +23 -1
  21. package/build/commands/make/_base.d.ts.map +1 -0
  22. package/build/commands/make/_base.js +11 -2
  23. package/build/commands/make/command.d.ts +1 -0
  24. package/build/commands/make/command.d.ts.map +1 -0
  25. package/build/commands/make/command.js +2 -1
  26. package/build/commands/make/controller.d.ts +1 -0
  27. package/build/commands/make/controller.d.ts.map +1 -0
  28. package/build/commands/make/controller.js +2 -1
  29. package/build/commands/make/event.d.ts +1 -0
  30. package/build/commands/make/event.d.ts.map +1 -0
  31. package/build/commands/make/event.js +2 -1
  32. package/build/commands/make/listener.d.ts +1 -0
  33. package/build/commands/make/listener.d.ts.map +1 -0
  34. package/build/commands/make/listener.js +2 -1
  35. package/build/commands/make/middleware.d.ts +1 -0
  36. package/build/commands/make/middleware.d.ts.map +1 -0
  37. package/build/commands/make/middleware.js +2 -1
  38. package/build/commands/make/prldfile.d.ts +9 -0
  39. package/build/commands/make/prldfile.d.ts.map +1 -0
  40. package/build/commands/make/prldfile.js +28 -0
  41. package/build/commands/make/provider.d.ts +1 -0
  42. package/build/commands/make/provider.d.ts.map +1 -0
  43. package/build/commands/make/provider.js +5 -2
  44. package/build/commands/make/service.d.ts +9 -0
  45. package/build/commands/make/service.d.ts.map +1 -0
  46. package/build/commands/make/service.js +26 -0
  47. package/build/commands/make/test.d.ts +1 -0
  48. package/build/commands/make/test.d.ts.map +1 -0
  49. package/build/commands/make/test.js +2 -1
  50. package/build/commands/serve.d.ts +3 -0
  51. package/build/commands/serve.d.ts.map +1 -0
  52. package/build/commands/serve.js +21 -1
  53. package/build/commands/test.d.ts +21 -0
  54. package/build/commands/test.d.ts.map +1 -0
  55. package/build/commands/test.js +156 -0
  56. package/build/factories/app.d.ts +1 -0
  57. package/build/factories/app.d.ts.map +1 -0
  58. package/build/factories/bodyparser.d.ts +1 -0
  59. package/build/factories/bodyparser.d.ts.map +1 -0
  60. package/build/factories/core/ace.d.ts +1 -0
  61. package/build/factories/core/ace.d.ts.map +1 -0
  62. package/build/factories/core/ignitor.d.ts +1 -0
  63. package/build/factories/core/ignitor.d.ts.map +1 -0
  64. package/build/factories/core/main.d.ts +1 -0
  65. package/build/factories/core/main.d.ts.map +1 -0
  66. package/build/factories/core/test_utils.d.ts +1 -0
  67. package/build/factories/core/test_utils.d.ts.map +1 -0
  68. package/build/factories/encryption.d.ts +1 -0
  69. package/build/factories/encryption.d.ts.map +1 -0
  70. package/build/factories/events.d.ts +1 -0
  71. package/build/factories/events.d.ts.map +1 -0
  72. package/build/factories/hash.d.ts +1 -0
  73. package/build/factories/hash.d.ts.map +1 -0
  74. package/build/factories/http.d.ts +1 -0
  75. package/build/factories/http.d.ts.map +1 -0
  76. package/build/factories/logger.d.ts +1 -0
  77. package/build/factories/logger.d.ts.map +1 -0
  78. package/build/factories/stubs.d.ts +1 -0
  79. package/build/factories/stubs.d.ts.map +1 -0
  80. package/build/index.d.ts +1 -0
  81. package/build/index.d.ts.map +1 -0
  82. package/build/legacy/validator.d.ts +1 -0
  83. package/build/legacy/validator.d.ts.map +1 -0
  84. package/build/modules/ace/commands.d.ts +1 -0
  85. package/build/modules/ace/commands.d.ts.map +1 -0
  86. package/build/modules/ace/commands.js +4 -2
  87. package/build/modules/ace/create_kernel.d.ts +1 -0
  88. package/build/modules/ace/create_kernel.d.ts.map +1 -0
  89. package/build/modules/ace/kernel.d.ts +1 -0
  90. package/build/modules/ace/kernel.d.ts.map +1 -0
  91. package/build/modules/ace/main.d.ts +2 -1
  92. package/build/modules/ace/main.d.ts.map +1 -0
  93. package/build/modules/ace/main.js +1 -1
  94. package/build/modules/ace/shell.d.ts +1 -0
  95. package/build/modules/ace/shell.d.ts.map +1 -0
  96. package/build/modules/app.d.ts +1 -0
  97. package/build/modules/app.d.ts.map +1 -0
  98. package/build/modules/bodyparser/bodyparser_middleware.d.ts +1 -0
  99. package/build/modules/bodyparser/bodyparser_middleware.d.ts.map +1 -0
  100. package/build/modules/bodyparser/main.d.ts +1 -0
  101. package/build/modules/bodyparser/main.d.ts.map +1 -0
  102. package/build/modules/config.d.ts +1 -0
  103. package/build/modules/config.d.ts.map +1 -0
  104. package/build/modules/container.d.ts +1 -0
  105. package/build/modules/container.d.ts.map +1 -0
  106. package/build/modules/encryption.d.ts +1 -0
  107. package/build/modules/encryption.d.ts.map +1 -0
  108. package/build/modules/env.d.ts +1 -0
  109. package/build/modules/env.d.ts.map +1 -0
  110. package/build/modules/events.d.ts +1 -0
  111. package/build/modules/events.d.ts.map +1 -0
  112. package/build/modules/hash/define_config.d.ts +1 -0
  113. package/build/modules/hash/define_config.d.ts.map +1 -0
  114. package/build/modules/hash/drivers_collection.d.ts +4 -4
  115. package/build/modules/hash/drivers_collection.d.ts.map +1 -0
  116. package/build/modules/hash/drivers_collection.js +2 -8
  117. package/build/modules/hash/main.d.ts +2 -0
  118. package/build/modules/hash/main.d.ts.map +1 -0
  119. package/build/modules/hash/main.js +1 -0
  120. package/build/modules/http.d.ts +1 -0
  121. package/build/modules/http.d.ts.map +1 -0
  122. package/build/modules/logger.d.ts +1 -0
  123. package/build/modules/logger.d.ts.map +1 -0
  124. package/build/providers/app_provider.d.ts +1 -0
  125. package/build/providers/app_provider.d.ts.map +1 -0
  126. package/build/providers/app_provider.js +5 -7
  127. package/build/providers/hash_provider.d.ts +1 -0
  128. package/build/providers/hash_provider.d.ts.map +1 -0
  129. package/build/providers/hash_provider.js +7 -6
  130. package/build/providers/http_provider.d.ts +1 -0
  131. package/build/providers/http_provider.d.ts.map +1 -0
  132. package/build/services/ace.d.ts +1 -0
  133. package/build/services/ace.d.ts.map +1 -0
  134. package/build/services/app.d.ts +1 -0
  135. package/build/services/app.d.ts.map +1 -0
  136. package/build/services/config.d.ts +1 -0
  137. package/build/services/config.d.ts.map +1 -0
  138. package/build/services/emitter.d.ts +1 -0
  139. package/build/services/emitter.d.ts.map +1 -0
  140. package/build/services/emitter.js +1 -2
  141. package/build/services/encryption.d.ts +1 -0
  142. package/build/services/encryption.d.ts.map +1 -0
  143. package/build/services/encryption.js +1 -2
  144. package/build/services/hash.d.ts +1 -0
  145. package/build/services/hash.d.ts.map +1 -0
  146. package/build/services/hash.js +1 -2
  147. package/build/services/logger.d.ts +1 -0
  148. package/build/services/logger.d.ts.map +1 -0
  149. package/build/services/logger.js +1 -2
  150. package/build/services/router.d.ts +1 -0
  151. package/build/services/router.d.ts.map +1 -0
  152. package/build/services/router.js +1 -2
  153. package/build/services/server.d.ts +1 -0
  154. package/build/services/server.d.ts.map +1 -0
  155. package/build/services/server.js +1 -2
  156. package/build/services/test_utils.d.ts +1 -0
  157. package/build/services/test_utils.d.ts.map +1 -0
  158. package/build/src/cli_formatters/routes_list.d.ts +41 -0
  159. package/build/src/cli_formatters/routes_list.d.ts.map +1 -0
  160. package/build/src/cli_formatters/routes_list.js +258 -0
  161. package/build/src/debug.d.ts +1 -0
  162. package/build/src/debug.d.ts.map +1 -0
  163. package/build/src/helpers/is.d.ts +1 -0
  164. package/build/src/helpers/is.d.ts.map +1 -0
  165. package/build/src/helpers/main.d.ts +3 -0
  166. package/build/src/helpers/main.d.ts.map +1 -0
  167. package/build/src/helpers/main.js +2 -0
  168. package/build/src/helpers/parse_binding_reference.d.ts +6 -0
  169. package/build/src/helpers/parse_binding_reference.d.ts.map +1 -0
  170. package/build/src/helpers/parse_binding_reference.js +23 -0
  171. package/build/src/helpers/string.d.ts +3 -0
  172. package/build/src/helpers/string.d.ts.map +1 -0
  173. package/build/src/helpers/string.js +4 -0
  174. package/build/src/helpers/types.d.ts +1 -0
  175. package/build/src/helpers/types.d.ts.map +1 -0
  176. package/build/src/ignitor/ace.d.ts +1 -0
  177. package/build/src/ignitor/ace.d.ts.map +1 -0
  178. package/build/src/ignitor/http.d.ts +1 -0
  179. package/build/src/ignitor/http.d.ts.map +1 -0
  180. package/build/src/ignitor/main.d.ts +1 -0
  181. package/build/src/ignitor/main.d.ts.map +1 -0
  182. package/build/src/ignitor/test.d.ts +1 -0
  183. package/build/src/ignitor/test.d.ts.map +1 -0
  184. package/build/src/internal_helpers.d.ts +1 -0
  185. package/build/src/internal_helpers.d.ts.map +1 -0
  186. package/build/src/internal_helpers.js +3 -3
  187. package/build/src/test_utils/http.d.ts +1 -0
  188. package/build/src/test_utils/http.d.ts.map +1 -0
  189. package/build/src/test_utils/main.d.ts +2 -1
  190. package/build/src/test_utils/main.d.ts.map +1 -0
  191. package/build/src/types.d.ts +3 -2
  192. package/build/src/types.d.ts.map +1 -0
  193. package/build/stubs/index.d.ts +1 -0
  194. package/build/stubs/index.d.ts.map +1 -0
  195. package/build/stubs/make/preload_file/main.stub +4 -0
  196. package/build/stubs/make/service/main.stub +4 -0
  197. package/build/toolkit/commands/index_commands.d.ts +1 -0
  198. package/build/toolkit/commands/index_commands.d.ts.map +1 -0
  199. package/build/toolkit/commands/index_commands.js +2 -1
  200. package/build/toolkit/main.d.ts +1 -0
  201. package/build/toolkit/main.d.ts.map +1 -0
  202. package/build/types/ace.d.ts +1 -0
  203. package/build/types/ace.d.ts.map +1 -0
  204. package/build/types/app.d.ts +1 -0
  205. package/build/types/app.d.ts.map +1 -0
  206. package/build/types/bodyparser.d.ts +1 -0
  207. package/build/types/bodyparser.d.ts.map +1 -0
  208. package/build/types/container.d.ts +1 -0
  209. package/build/types/container.d.ts.map +1 -0
  210. package/build/types/encryption.d.ts +1 -0
  211. package/build/types/encryption.d.ts.map +1 -0
  212. package/build/types/events.d.ts +1 -0
  213. package/build/types/events.d.ts.map +1 -0
  214. package/build/types/hash.d.ts +1 -0
  215. package/build/types/hash.d.ts.map +1 -0
  216. package/build/types/http.d.ts +1 -0
  217. package/build/types/http.d.ts.map +1 -0
  218. package/build/types/logger.d.ts +1 -0
  219. package/build/types/logger.d.ts.map +1 -0
  220. package/commands/build.ts +122 -0
  221. package/commands/configure.ts +179 -0
  222. package/commands/eject.ts +39 -0
  223. package/commands/generate_key.ts +53 -0
  224. package/commands/inspect_rcfile.ts +23 -0
  225. package/commands/list/routes.ts +121 -0
  226. package/commands/make/_base.ts +55 -0
  227. package/commands/make/command.ts +33 -0
  228. package/commands/make/controller.ts +77 -0
  229. package/commands/make/event.ts +33 -0
  230. package/commands/make/listener.ts +63 -0
  231. package/commands/make/middleware.ts +34 -0
  232. package/commands/make/prldfile.ts +40 -0
  233. package/commands/make/provider.ts +40 -0
  234. package/commands/make/service.ts +33 -0
  235. package/commands/make/test.ts +115 -0
  236. package/commands/serve.ts +146 -0
  237. package/commands/test.ts +189 -0
  238. package/factories/app.ts +10 -0
  239. package/factories/bodyparser.ts +10 -0
  240. package/factories/core/ace.ts +38 -0
  241. package/factories/core/ignitor.ts +132 -0
  242. package/factories/core/main.ts +13 -0
  243. package/factories/core/test_utils.ts +34 -0
  244. package/factories/encryption.ts +10 -0
  245. package/factories/events.ts +10 -0
  246. package/factories/hash.ts +10 -0
  247. package/factories/http.ts +10 -0
  248. package/factories/logger.ts +10 -0
  249. package/factories/stubs.ts +53 -0
  250. package/index.ts +39 -0
  251. package/legacy/validator.ts +10 -0
  252. package/modules/ace/commands.ts +152 -0
  253. package/modules/ace/create_kernel.ts +73 -0
  254. package/modules/ace/kernel.ts +28 -0
  255. package/modules/ace/main.ts +22 -0
  256. package/modules/ace/shell.ts +49 -0
  257. package/modules/app.ts +10 -0
  258. package/modules/bodyparser/bodyparser_middleware.ts +16 -0
  259. package/modules/bodyparser/main.ts +10 -0
  260. package/modules/config.ts +10 -0
  261. package/modules/container.ts +10 -0
  262. package/modules/encryption.ts +10 -0
  263. package/modules/env.ts +10 -0
  264. package/modules/events.ts +10 -0
  265. package/modules/hash/define_config.ts +64 -0
  266. package/modules/hash/drivers_collection.ts +61 -0
  267. package/modules/hash/main.ts +12 -0
  268. package/modules/http.ts +10 -0
  269. package/modules/logger.ts +10 -0
  270. package/package.json +43 -36
  271. package/providers/app_provider.ts +125 -0
  272. package/providers/hash_provider.ts +58 -0
  273. package/providers/http_provider.ts +66 -0
  274. package/services/ace.ts +26 -0
  275. package/services/app.ts +26 -0
  276. package/services/config.ts +22 -0
  277. package/services/emitter.ts +23 -0
  278. package/services/encryption.ts +23 -0
  279. package/services/hash.ts +23 -0
  280. package/services/logger.ts +23 -0
  281. package/services/router.ts +23 -0
  282. package/services/server.ts +23 -0
  283. package/services/test_utils.ts +26 -0
  284. package/src/cli_formatters/routes_list.ts +480 -0
  285. package/src/debug.ts +12 -0
  286. package/src/helpers/is.ts +11 -0
  287. package/src/helpers/main.ts +13 -0
  288. package/src/helpers/parse_binding_reference.ts +93 -0
  289. package/src/helpers/string.ts +89 -0
  290. package/src/helpers/types.ts +46 -0
  291. package/src/ignitor/ace.ts +90 -0
  292. package/src/ignitor/http.ts +167 -0
  293. package/src/ignitor/main.ts +118 -0
  294. package/src/ignitor/test.ts +51 -0
  295. package/src/internal_helpers.ts +59 -0
  296. package/src/test_utils/http.ts +79 -0
  297. package/src/test_utils/main.ts +69 -0
  298. package/src/types.ts +136 -0
  299. package/types/ace.ts +15 -0
  300. package/types/app.ts +10 -0
  301. package/types/bodyparser.ts +10 -0
  302. package/types/container.ts +10 -0
  303. package/types/encryption.ts +10 -0
  304. package/types/events.ts +10 -0
  305. package/types/hash.ts +10 -0
  306. package/types/http.ts +10 -0
  307. package/types/logger.ts +10 -0
  308. package/build/src/helpers/string_builder.d.ts +0 -23
  309. package/build/src/helpers/string_builder.js +0 -86
@@ -0,0 +1,26 @@
1
+ /*
2
+ * @adonisjs/core
3
+ *
4
+ * (c) AdonisJS
5
+ *
6
+ * For the full copyright and license information, please view the LICENSE
7
+ * file that was distributed with this source code.
8
+ */
9
+
10
+ import type { ApplicationService } from '../src/types.js'
11
+
12
+ let app: ApplicationService
13
+
14
+ /**
15
+ * Set the application instance the app service should
16
+ * be using. Other services relies on the same app
17
+ * instance as well.
18
+ *
19
+ * app service is an instance of the "Application" exported from
20
+ * the "modules/app.ts" file.
21
+ */
22
+ export function setApp(appService: ApplicationService) {
23
+ app = appService
24
+ }
25
+
26
+ export { app as default }
@@ -0,0 +1,22 @@
1
+ /*
2
+ * @adonisjs/core
3
+ *
4
+ * (c) AdonisJS
5
+ *
6
+ * For the full copyright and license information, please view the LICENSE
7
+ * file that was distributed with this source code.
8
+ */
9
+
10
+ import app from './app.js'
11
+ import type { ApplicationService } from '../src/types.js'
12
+
13
+ let config: ApplicationService['config']
14
+
15
+ /**
16
+ * The config service uses the config instance from the app service
17
+ */
18
+ await app.booted(() => {
19
+ config = app.config
20
+ })
21
+
22
+ export { config as default }
@@ -0,0 +1,23 @@
1
+ /*
2
+ * @adonisjs/core
3
+ *
4
+ * (c) AdonisJS
5
+ *
6
+ * For the full copyright and license information, please view the LICENSE
7
+ * file that was distributed with this source code.
8
+ */
9
+
10
+ import app from './app.js'
11
+ import type { EmitterService } from '../src/types.js'
12
+
13
+ let emitter: EmitterService
14
+
15
+ /**
16
+ * Returns a singleton instance of the emitter class
17
+ * from the container
18
+ */
19
+ await app.booted(async () => {
20
+ emitter = await app.container.make('emitter')
21
+ })
22
+
23
+ export { emitter as default }
@@ -0,0 +1,23 @@
1
+ /*
2
+ * @adonisjs/core
3
+ *
4
+ * (c) AdonisJS
5
+ *
6
+ * For the full copyright and license information, please view the LICENSE
7
+ * file that was distributed with this source code.
8
+ */
9
+
10
+ import app from './app.js'
11
+ import type { EncryptionService } from '../src/types.js'
12
+
13
+ let encryption: EncryptionService
14
+
15
+ /**
16
+ * Returns a singleton instance of the encryption class
17
+ * from the container
18
+ */
19
+ await app.booted(async () => {
20
+ encryption = await app.container.make('encryption')
21
+ })
22
+
23
+ export { encryption as default }
@@ -0,0 +1,23 @@
1
+ /*
2
+ * @adonisjs/core
3
+ *
4
+ * (c) AdonisJS
5
+ *
6
+ * For the full copyright and license information, please view the LICENSE
7
+ * file that was distributed with this source code.
8
+ */
9
+
10
+ import app from './app.js'
11
+ import type { HashService } from '../src/types.js'
12
+
13
+ let hash: HashService
14
+
15
+ /**
16
+ * Returns a singleton instance of the Hash manager from the
17
+ * container
18
+ */
19
+ await app.booted(async () => {
20
+ hash = await app.container.make('hash')
21
+ })
22
+
23
+ export { hash as default }
@@ -0,0 +1,23 @@
1
+ /*
2
+ * @adonisjs/core
3
+ *
4
+ * (c) AdonisJS
5
+ *
6
+ * For the full copyright and license information, please view the LICENSE
7
+ * file that was distributed with this source code.
8
+ */
9
+
10
+ import app from './app.js'
11
+ import type { LoggerService } from '../src/types.js'
12
+
13
+ let logger: LoggerService
14
+
15
+ /**
16
+ * Returns a singleton instance of the logger class
17
+ * from the container
18
+ */
19
+ await app.booted(async () => {
20
+ logger = await app.container.make('logger')
21
+ })
22
+
23
+ export { logger as default }
@@ -0,0 +1,23 @@
1
+ /*
2
+ * @adonisjs/core
3
+ *
4
+ * (c) AdonisJS
5
+ *
6
+ * For the full copyright and license information, please view the LICENSE
7
+ * file that was distributed with this source code.
8
+ */
9
+
10
+ import app from './app.js'
11
+ import type { HttpRouterService } from '../src/types.js'
12
+
13
+ let router: HttpRouterService
14
+
15
+ /**
16
+ * Returns a singleton instance of the router class from
17
+ * the container
18
+ */
19
+ await app.booted(async () => {
20
+ router = await app.container.make('router')
21
+ })
22
+
23
+ export { router as default }
@@ -0,0 +1,23 @@
1
+ /*
2
+ * @adonisjs/core
3
+ *
4
+ * (c) AdonisJS
5
+ *
6
+ * For the full copyright and license information, please view the LICENSE
7
+ * file that was distributed with this source code.
8
+ */
9
+
10
+ import app from './app.js'
11
+ import type { HttpServerService } from '../src/types.js'
12
+
13
+ let server: HttpServerService
14
+
15
+ /**
16
+ * Returns a singleton instance of the HTTP server
17
+ * from the container
18
+ */
19
+ await app.booted(async () => {
20
+ server = await app.container.make('server')
21
+ })
22
+
23
+ export { server as default }
@@ -0,0 +1,26 @@
1
+ /*
2
+ * @adonisjs/core
3
+ *
4
+ * (c) AdonisJS
5
+ *
6
+ * For the full copyright and license information, please view the LICENSE
7
+ * file that was distributed with this source code.
8
+ */
9
+
10
+ import app from './app.js'
11
+ import type { TestUtils } from '../src/test_utils/main.js'
12
+
13
+ let testUtils: TestUtils
14
+
15
+ /**
16
+ * Returns a singleton instance of the TestUtils class
17
+ * from the container.
18
+ *
19
+ * testUtils service is an instance of the "TestUtils" exported from
20
+ * the "src/test_utils/main.ts" file.
21
+ */
22
+ await app.booted(async () => {
23
+ testUtils = await app.container.make('testUtils')
24
+ })
25
+
26
+ export { testUtils as default }
@@ -0,0 +1,480 @@
1
+ /*
2
+ * @adonisjs/core
3
+ *
4
+ * (c) AdonisJS
5
+ *
6
+ * For the full copyright and license information, please view the LICENSE
7
+ * file that was distributed with this source code.
8
+ */
9
+
10
+ import stringWidth from 'string-width'
11
+ import { type Router } from '../../modules/http.js'
12
+ import type { RouteJSON } from '../../types/http.js'
13
+ import type { UIPrimitives } from '../../types/ace.js'
14
+ import { cliHelpers } from '../../modules/ace/main.js'
15
+ import { parseBindingReference } from '../../src/helpers/main.js'
16
+
17
+ /**
18
+ * Shape of the serialized route specific to the formatter
19
+ */
20
+ type SerializedRoute = {
21
+ name: string
22
+ pattern: string
23
+ methods: string[]
24
+ middleware: string[]
25
+ handler:
26
+ | { type: 'closure'; name: string }
27
+ | { type: 'controller'; moduleNameOrPath: string; method: string }
28
+ }
29
+
30
+ /**
31
+ * Routes list formatter is used to format the routes to JSON or an ANSI string
32
+ * with pretty output.
33
+ *
34
+ * The decisions of colors, padding, alignment are all handled by the lists formatter
35
+ */
36
+ export class RoutesListFormatter {
37
+ #router: Router
38
+ #colors: UIPrimitives['colors']
39
+ #table: UIPrimitives['table']
40
+
41
+ /**
42
+ * Options for printing routes
43
+ */
44
+ #options: {
45
+ displayHeadRoutes?: boolean
46
+ maxPrettyPrintWidth?: number
47
+ }
48
+
49
+ /**
50
+ * Filters to apply when finding routes
51
+ */
52
+ #filters: {
53
+ match?: string
54
+ middleware?: string[]
55
+ ignoreMiddleware?: string[]
56
+ }
57
+
58
+ constructor(
59
+ router: Router,
60
+ ui: UIPrimitives,
61
+ options: {
62
+ displayHeadRoutes?: boolean
63
+ maxPrettyPrintWidth?: number
64
+ },
65
+ filters: {
66
+ match?: string
67
+ middleware?: string[]
68
+ ignoreMiddleware?: string[]
69
+ }
70
+ ) {
71
+ this.#router = router
72
+ this.#colors = ui.colors
73
+ this.#table = ui.table
74
+ this.#filters = filters
75
+ this.#options = options
76
+ this.#router.commit()
77
+ }
78
+
79
+ /**
80
+ * Test if a route clears the applied filters
81
+ */
82
+ #isAllowedByFilters(route: SerializedRoute) {
83
+ let allowRoute = true
84
+
85
+ /**
86
+ * Check if the route is allowed by applying the middleware
87
+ * filter
88
+ */
89
+ if (this.#filters.middleware) {
90
+ allowRoute = this.#filters.middleware.every((name) => {
91
+ if (name === '*') {
92
+ return route.middleware.length > 0
93
+ }
94
+
95
+ return route.middleware.includes(name)
96
+ })
97
+ }
98
+
99
+ /**
100
+ * Check if the route has any or the ignored middleware. If yes, do not
101
+ * display the route
102
+ */
103
+ if (allowRoute && this.#filters.ignoreMiddleware) {
104
+ allowRoute = this.#filters.ignoreMiddleware.every((name) => {
105
+ if (name === '*') {
106
+ return route.middleware.length === 0
107
+ }
108
+
109
+ return !route.middleware.includes(name)
110
+ })
111
+ }
112
+
113
+ /**
114
+ * No more filters to be applied
115
+ */
116
+ if (!this.#filters.match) {
117
+ return allowRoute
118
+ }
119
+
120
+ /**
121
+ * Check if the route name has the match keyword
122
+ */
123
+ if (route.name.includes(this.#filters.match)) {
124
+ return true
125
+ }
126
+
127
+ /**
128
+ * Check if the route pattern has the match keyword
129
+ */
130
+ if (route.pattern.includes(this.#filters.match)) {
131
+ return true
132
+ }
133
+
134
+ /**
135
+ * Check if the route handler has the match keyword
136
+ */
137
+ if (
138
+ route.handler.type === 'controller'
139
+ ? route.handler.moduleNameOrPath.includes(this.#filters.match)
140
+ : route.handler.name.includes(this.#filters.match)
141
+ ) {
142
+ return true
143
+ }
144
+
145
+ /**
146
+ * Disallow route
147
+ */
148
+ return false
149
+ }
150
+
151
+ /**
152
+ * Serialize route middleware to an array of names
153
+ */
154
+ #serializeMiddleware(middleware: RouteJSON['middleware']): string[] {
155
+ return [...middleware.all()].reduce<string[]>((result, one) => {
156
+ if (typeof one === 'function') {
157
+ result.push(one.name || 'closure')
158
+ return result
159
+ }
160
+
161
+ if ('name' in one && one.name) {
162
+ result.push(one.name)
163
+ }
164
+
165
+ return result
166
+ }, [])
167
+ }
168
+
169
+ /**
170
+ * Serialize route handler reference to display object
171
+ */
172
+ async #serializeHandler(handler: RouteJSON['handler']): Promise<SerializedRoute['handler']> {
173
+ /**
174
+ * Value is a controller reference
175
+ */
176
+ if ('reference' in handler) {
177
+ return {
178
+ type: 'controller' as const,
179
+ ...(await parseBindingReference(handler.reference)),
180
+ }
181
+ }
182
+
183
+ /**
184
+ * Value is an inline closure
185
+ */
186
+ return {
187
+ type: 'closure' as const,
188
+ name: handler.name || 'closure',
189
+ }
190
+ }
191
+
192
+ /**
193
+ * Serializes routes JSON to an object that can be used for pretty printing
194
+ */
195
+ async #serializeRoute(route: RouteJSON): Promise<SerializedRoute> {
196
+ let methods = route.methods
197
+ if (!this.#options.displayHeadRoutes) {
198
+ methods = methods.filter((method) => method !== 'HEAD')
199
+ }
200
+
201
+ return {
202
+ name: route.name || '',
203
+ pattern: route.pattern,
204
+ methods: methods,
205
+ handler: await this.#serializeHandler(route.handler),
206
+ middleware: this.#serializeMiddleware(route.middleware),
207
+ }
208
+ }
209
+
210
+ /**
211
+ * Formats the route method for the ansi list and table
212
+ */
213
+ #formatRouteMethod(method: string) {
214
+ return this.#colors.dim(method)
215
+ }
216
+
217
+ /**
218
+ * Formats route pattern for the ansi list and table
219
+ */
220
+ #formatRoutePattern(route: SerializedRoute) {
221
+ const pattern = this.#router
222
+ .parsePattern(route.pattern)
223
+ .map((token) => {
224
+ if (token.type === 1) {
225
+ return this.#colors.yellow(`:${token.val}`)
226
+ }
227
+
228
+ if (token.type === 3) {
229
+ return this.#colors.yellow(`:${token.val}?`)
230
+ }
231
+
232
+ if (token.type === 2) {
233
+ return this.#colors.red(token.val)
234
+ }
235
+
236
+ return token.val
237
+ })
238
+ .join('/')
239
+
240
+ return `${pattern === '/' ? pattern : `/${pattern}`}${
241
+ route.name ? ` ${this.#colors.dim(`(${route.name})`)}` : ''
242
+ } `
243
+ }
244
+
245
+ /**
246
+ * Formats controller name for the ansi list and table
247
+ */
248
+ #formatControllerName(route: SerializedRoute) {
249
+ return route.handler.type === 'controller' ? ` ${route.handler.moduleNameOrPath}.` : ''
250
+ }
251
+
252
+ /**
253
+ * Formats action name for the ansi list and table
254
+ */
255
+ #formatAction(route: SerializedRoute) {
256
+ return route.handler.type === 'controller'
257
+ ? `${this.#colors.cyan(route.handler.method)}`
258
+ : ` ${this.#colors.cyan(route.handler.name)}`
259
+ }
260
+
261
+ /**
262
+ * Formats route middleware for the ansi list and table
263
+ */
264
+ #formatMiddleware(route: SerializedRoute, mode: 'normal' | 'compact' = 'normal') {
265
+ if (mode === 'compact' && route.middleware.length > 3) {
266
+ const firstMiddleware = route.middleware[0]
267
+ const secondMiddleware = route.middleware[1]
268
+ const diff = route.middleware.length - 2
269
+ return this.#colors.dim(`${firstMiddleware}, ${secondMiddleware}, and ${diff} more`)
270
+ }
271
+
272
+ return this.#colors.dim(`${route.middleware.filter((one) => one).join(', ')}`)
273
+ }
274
+
275
+ /**
276
+ * Formatting the domain headling to be in green color with
277
+ * dots around it
278
+ */
279
+ #formatDomainHeadline(domain: string) {
280
+ if (domain !== 'root') {
281
+ return cliHelpers.justify([`${this.#colors.dim('..')} ${this.#colors.green(domain)} `], {
282
+ maxWidth: this.#options.maxPrettyPrintWidth || cliHelpers.TERMINAL_SIZE,
283
+ paddingChar: this.#colors.dim('.'),
284
+ })[0]
285
+ }
286
+ return ''
287
+ }
288
+
289
+ /**
290
+ * Justify the ansi list
291
+ */
292
+ #justifyListTables(tables: { heading: string; rows: [string, string, string, string][] }[]) {
293
+ return tables.map((table) => {
294
+ /**
295
+ * Formatting methods
296
+ */
297
+ const methods = table.rows.map((columns) => columns[0])
298
+ const largestMethodsLength = Math.max(...methods.map((method) => stringWidth(method)))
299
+ const formattedMethods = cliHelpers.justify(methods, {
300
+ maxWidth: largestMethodsLength,
301
+ })
302
+
303
+ /**
304
+ * Formatting patterns
305
+ */
306
+ const patterns = table.rows.map((columns) => columns[1])
307
+ const largestPatternLength = Math.max(...patterns.map((pattern) => stringWidth(pattern)))
308
+ const formattedPatterns = cliHelpers.justify(patterns, {
309
+ maxWidth: largestPatternLength,
310
+ paddingChar: this.#colors.dim('.'),
311
+ })
312
+
313
+ /**
314
+ * Formatting middleware to be right aligned
315
+ */
316
+ const middleware = table.rows.map((columns) => columns[3])
317
+ const largestMiddlewareLength = Math.max(...middleware.map((one) => stringWidth(one)))
318
+ const formattedMiddleware = cliHelpers.justify(middleware, {
319
+ maxWidth: largestMiddlewareLength,
320
+ align: 'right',
321
+ paddingChar: ' ',
322
+ })
323
+
324
+ /**
325
+ * Formatting controllers to be right aligned and take all the remaining
326
+ * space after printing route method, pattern and middleware.
327
+ */
328
+ const controllers = table.rows.map((columns) => columns[2])
329
+ const largestControllerLength =
330
+ (this.#options.maxPrettyPrintWidth || cliHelpers.TERMINAL_SIZE) -
331
+ (largestPatternLength + largestMethodsLength + largestMiddlewareLength)
332
+
333
+ const formattedControllers = cliHelpers.truncate(
334
+ cliHelpers.justify(controllers, {
335
+ maxWidth: largestControllerLength,
336
+ align: 'right',
337
+ paddingChar: this.#colors.dim('.'),
338
+ }),
339
+ {
340
+ maxWidth: largestControllerLength,
341
+ }
342
+ )
343
+
344
+ return {
345
+ heading: table.heading,
346
+ rows: formattedMethods.reduce<string[]>((result, method, index) => {
347
+ result.push(
348
+ `${method}${formattedPatterns[index]}${formattedControllers[index]}${formattedMiddleware[index]}`
349
+ )
350
+ return result
351
+ }, []),
352
+ }
353
+ })
354
+ }
355
+
356
+ /**
357
+ * Formats routes as an array of objects. Routes are grouped by
358
+ * domain.
359
+ */
360
+ async formatAsJSON() {
361
+ const routes = this.#router.toJSON()
362
+ const domains = Object.keys(routes)
363
+ let routesJSON: { domain: string; routes: SerializedRoute[] }[] = []
364
+
365
+ for (let domain of domains) {
366
+ const domainRoutes = await Promise.all(
367
+ routes[domain].map((route) => this.#serializeRoute(route))
368
+ )
369
+
370
+ routesJSON.push({
371
+ domain,
372
+ routes: domainRoutes.filter((route) => this.#isAllowedByFilters(route)),
373
+ })
374
+ }
375
+
376
+ return routesJSON
377
+ }
378
+
379
+ /**
380
+ * Format routes to ansi list of tables. Each domain has its own table
381
+ * with heading and rows. Each row has colums with colors and spacing
382
+ * around them.
383
+ */
384
+ async formatAsAnsiList() {
385
+ const routes = this.#router.toJSON()
386
+ const domains = Object.keys(routes)
387
+ const tables: { heading: string; rows: [string, string, string, string][] }[] = []
388
+
389
+ for (let domain of domains) {
390
+ const list: (typeof tables)[number] = {
391
+ heading: this.#formatDomainHeadline(domain),
392
+ rows: [
393
+ [
394
+ this.#colors.dim('METHOD'),
395
+ ` ${this.#colors.dim('ROUTE')} `,
396
+ ` ${this.#colors.dim('HANDLER')}`,
397
+ ` ${this.#colors.dim('MIDDLEWARE')}`,
398
+ ],
399
+ ],
400
+ }
401
+
402
+ /**
403
+ * Computing table rows. Each route+method will have its
404
+ * own row
405
+ */
406
+ for (let route of routes[domain]) {
407
+ const serializedRoute = await this.#serializeRoute(route)
408
+ if (this.#isAllowedByFilters(serializedRoute)) {
409
+ serializedRoute.methods.forEach((method) => {
410
+ list.rows.push([
411
+ this.#formatRouteMethod(method),
412
+ ` ${this.#formatRoutePattern(serializedRoute)}`,
413
+ `${this.#formatControllerName(serializedRoute)}${this.#formatAction(
414
+ serializedRoute
415
+ )}`,
416
+ ` ${this.#formatMiddleware(serializedRoute, 'compact')}`,
417
+ ])
418
+ })
419
+ }
420
+ }
421
+
422
+ tables.push(list)
423
+ }
424
+
425
+ return this.#justifyListTables(tables)
426
+ }
427
+
428
+ /**
429
+ * Format routes to ansi tables. Each domain has its own table
430
+ * with heading and rows. Each row has colums with colors and spacing
431
+ * around them.
432
+ */
433
+ async formatAsAnsiTable() {
434
+ const routes = this.#router.toJSON()
435
+ const domains = Object.keys(routes)
436
+ const tables: { heading: string; table: ReturnType<UIPrimitives['table']> }[] = []
437
+
438
+ for (let domain of domains) {
439
+ const list: (typeof tables)[number] = {
440
+ heading: this.#formatDomainHeadline(domain),
441
+ table: this.#table()
442
+ .fullWidth()
443
+ .fluidColumnIndex(2)
444
+ .head([
445
+ this.#colors.dim('METHOD'),
446
+ this.#colors.dim('ROUTE'),
447
+ { hAlign: 'right', content: this.#colors.dim('HANDLER') },
448
+ { content: this.#colors.dim('MIDDLEWARE'), hAlign: 'right' },
449
+ ]),
450
+ }
451
+
452
+ /**
453
+ * Computing table rows. Each route+method will have its
454
+ * own row
455
+ */
456
+ for (let route of routes[domain]) {
457
+ const serializedRoute = await this.#serializeRoute(route)
458
+ if (this.#isAllowedByFilters(serializedRoute)) {
459
+ serializedRoute.methods.forEach((method) => {
460
+ list.table.row([
461
+ this.#formatRouteMethod(method),
462
+ this.#formatRoutePattern(serializedRoute),
463
+ {
464
+ content: `${this.#formatControllerName(serializedRoute)}${this.#formatAction(
465
+ serializedRoute
466
+ )}`,
467
+ hAlign: 'right',
468
+ },
469
+ { content: this.#formatMiddleware(serializedRoute), hAlign: 'right' },
470
+ ])
471
+ })
472
+ }
473
+ }
474
+
475
+ tables.push(list)
476
+ }
477
+
478
+ return tables
479
+ }
480
+ }