@ecopages/core 0.2.0-alpha.2 → 0.2.0-alpha.21

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 (391) hide show
  1. package/CHANGELOG.md +26 -64
  2. package/README.md +212 -14
  3. package/package.json +116 -66
  4. package/src/adapters/README.md +39 -0
  5. package/src/adapters/abstract/application-adapter.d.ts +28 -2
  6. package/src/adapters/abstract/application-adapter.js +14 -2
  7. package/src/adapters/abstract/router-adapter.d.ts +1 -1
  8. package/src/adapters/abstract/server-adapter.d.ts +2 -2
  9. package/src/adapters/bun/client-bridge.d.ts +1 -1
  10. package/src/adapters/bun/create-app.d.ts +4 -12
  11. package/src/adapters/bun/create-app.js +4 -5
  12. package/src/adapters/bun/hmr-manager.d.ts +80 -21
  13. package/src/adapters/bun/hmr-manager.js +168 -62
  14. package/src/adapters/bun/index.d.ts +2 -3
  15. package/src/adapters/bun/index.js +3 -3
  16. package/src/adapters/bun/server-adapter.d.ts +5 -5
  17. package/src/adapters/bun/server-adapter.js +40 -34
  18. package/src/adapters/bun/server-lifecycle.d.ts +28 -17
  19. package/src/adapters/bun/server-lifecycle.js +34 -62
  20. package/src/{create-app.d.ts → adapters/create-app.d.ts} +9 -6
  21. package/src/{create-app.js → adapters/create-app.js} +4 -4
  22. package/src/adapters/index.d.ts +2 -6
  23. package/src/adapters/index.js +2 -8
  24. package/src/adapters/node/create-app.d.ts +6 -9
  25. package/src/adapters/node/create-app.js +12 -6
  26. package/src/adapters/node/node-client-bridge.d.ts +1 -1
  27. package/src/adapters/node/node-hmr-manager.d.ts +89 -18
  28. package/src/adapters/node/node-hmr-manager.js +185 -95
  29. package/src/adapters/node/server-adapter.d.ts +6 -35
  30. package/src/adapters/node/server-adapter.js +44 -105
  31. package/src/adapters/node/static-content-server.d.ts +37 -1
  32. package/src/adapters/node/static-content-server.js +29 -1
  33. package/src/adapters/shared/application-adapter.d.ts +1 -1
  34. package/src/{define-api-handler.d.ts → adapters/shared/define-api-handler.d.ts} +1 -1
  35. package/src/adapters/shared/explicit-static-route-matcher.d.ts +2 -2
  36. package/src/adapters/shared/explicit-static-route-matcher.js +4 -1
  37. package/src/adapters/shared/file-route-middleware-pipeline.d.ts +1 -1
  38. package/src/adapters/shared/file-route-middleware-pipeline.js +1 -0
  39. package/src/adapters/shared/fs-server-response-factory.d.ts +2 -2
  40. package/src/adapters/shared/fs-server-response-factory.js +1 -1
  41. package/src/adapters/shared/fs-server-response-matcher.d.ts +8 -12
  42. package/src/adapters/shared/fs-server-response-matcher.js +10 -18
  43. package/src/adapters/shared/hmr-entrypoint-registrar.d.ts +55 -0
  44. package/src/adapters/shared/hmr-entrypoint-registrar.js +87 -0
  45. package/src/adapters/shared/hmr-html-response.d.ts +22 -0
  46. package/src/adapters/shared/hmr-html-response.js +32 -0
  47. package/src/adapters/shared/render-context.d.ts +2 -1
  48. package/src/adapters/shared/render-context.js +6 -3
  49. package/src/adapters/shared/runtime-bootstrap.d.ts +38 -0
  50. package/src/adapters/shared/runtime-bootstrap.js +43 -0
  51. package/src/adapters/shared/server-adapter.d.ts +13 -3
  52. package/src/adapters/shared/server-adapter.js +42 -5
  53. package/src/adapters/shared/server-route-handler.d.ts +4 -4
  54. package/src/adapters/shared/server-route-handler.js +6 -15
  55. package/src/adapters/shared/server-static-builder.d.ts +38 -6
  56. package/src/adapters/shared/server-static-builder.js +64 -10
  57. package/src/build/README.md +107 -0
  58. package/src/build/build-adapter.d.ts +168 -3
  59. package/src/build/build-adapter.js +604 -16
  60. package/src/build/build-manifest.d.ts +27 -0
  61. package/src/build/build-manifest.js +30 -0
  62. package/src/build/dev-build-coordinator.d.ts +72 -0
  63. package/src/build/dev-build-coordinator.js +154 -0
  64. package/src/build/esbuild-build-adapter.d.ts +15 -6
  65. package/src/build/esbuild-build-adapter.js +189 -74
  66. package/src/build/runtime-build-executor.d.ts +14 -0
  67. package/src/build/runtime-build-executor.js +22 -0
  68. package/src/build/runtime-specifier-alias-plugin.d.ts +15 -0
  69. package/src/build/runtime-specifier-alias-plugin.js +35 -0
  70. package/src/build/runtime-specifier-aliases.d.ts +5 -0
  71. package/src/build/runtime-specifier-aliases.js +95 -0
  72. package/src/config/README.md +36 -0
  73. package/src/config/config-builder.d.ts +52 -27
  74. package/src/config/config-builder.js +260 -49
  75. package/src/{constants.d.ts → config/constants.d.ts} +13 -0
  76. package/src/{constants.js → config/constants.js} +4 -0
  77. package/src/declarations.d.ts +19 -14
  78. package/src/dev/sc-server.d.ts +1 -1
  79. package/src/dev/sc-server.js +1 -1
  80. package/src/eco/README.md +70 -16
  81. package/src/eco/eco.browser.d.ts +2 -0
  82. package/src/eco/eco.browser.js +83 -0
  83. package/src/eco/eco.js +32 -57
  84. package/src/eco/eco.types.d.ts +12 -4
  85. package/src/eco/eco.utils.d.ts +1 -40
  86. package/src/eco/eco.utils.js +5 -35
  87. package/src/eco/global-injector-map.d.ts +1 -1
  88. package/src/eco/lazy-injector-map.d.ts +1 -1
  89. package/src/hmr/README.md +26 -0
  90. package/src/hmr/client/hmr-runtime.d.ts +1 -6
  91. package/src/hmr/client/hmr-runtime.js +30 -7
  92. package/src/hmr/hmr-strategy.d.ts +16 -13
  93. package/src/hmr/hmr-strategy.js +22 -7
  94. package/src/hmr/hmr.postcss.test.e2e.d.ts +1 -0
  95. package/src/hmr/hmr.postcss.test.e2e.js +31 -0
  96. package/src/hmr/hmr.test.e2e.js +26 -33
  97. package/src/hmr/strategies/default-hmr-strategy.d.ts +2 -2
  98. package/src/hmr/strategies/default-hmr-strategy.js +1 -1
  99. package/src/hmr/strategies/js-hmr-strategy.d.ts +46 -43
  100. package/src/hmr/strategies/js-hmr-strategy.js +72 -73
  101. package/src/index.browser.d.ts +2 -2
  102. package/src/index.browser.js +1 -1
  103. package/src/index.d.ts +4 -3
  104. package/src/index.js +16 -5
  105. package/src/integrations/ghtml/ghtml-renderer.d.ts +7 -2
  106. package/src/integrations/ghtml/ghtml-renderer.js +33 -30
  107. package/src/integrations/ghtml/ghtml.constants.d.ts +1 -0
  108. package/src/integrations/ghtml/ghtml.constants.js +4 -0
  109. package/src/integrations/ghtml/ghtml.plugin.d.ts +2 -6
  110. package/src/integrations/ghtml/ghtml.plugin.js +3 -4
  111. package/src/plugins/README.md +35 -0
  112. package/src/plugins/alias-resolver-plugin.js +17 -3
  113. package/src/plugins/eco-component-meta-plugin.d.ts +14 -1
  114. package/src/plugins/eco-component-meta-plugin.js +27 -21
  115. package/src/plugins/foreign-jsx-override-plugin.d.ts +31 -0
  116. package/src/plugins/foreign-jsx-override-plugin.js +35 -0
  117. package/src/plugins/integration-plugin.d.ts +145 -28
  118. package/src/plugins/integration-plugin.js +109 -13
  119. package/src/plugins/processor.d.ts +15 -2
  120. package/src/plugins/processor.js +16 -2
  121. package/src/plugins/runtime-capability.d.ts +9 -0
  122. package/src/plugins/source-transform.d.ts +46 -0
  123. package/src/plugins/source-transform.js +71 -0
  124. package/src/route-renderer/GRAPH.md +64 -98
  125. package/src/route-renderer/README.md +67 -46
  126. package/src/route-renderer/orchestration/boundary-planning.service.d.ts +25 -0
  127. package/src/route-renderer/orchestration/boundary-planning.service.js +97 -0
  128. package/src/route-renderer/orchestration/component-render-context.d.ts +83 -0
  129. package/src/route-renderer/orchestration/component-render-context.js +147 -0
  130. package/src/route-renderer/orchestration/integration-renderer.d.ts +554 -0
  131. package/src/route-renderer/orchestration/integration-renderer.js +957 -0
  132. package/src/route-renderer/orchestration/queued-boundary-runtime.service.d.ts +89 -0
  133. package/src/route-renderer/orchestration/queued-boundary-runtime.service.js +155 -0
  134. package/src/route-renderer/orchestration/render-execution.service.d.ts +43 -0
  135. package/src/route-renderer/orchestration/render-execution.service.js +106 -0
  136. package/src/{eco/eco.utils.ts → route-renderer/orchestration/render-output.utils.d.ts} +10 -53
  137. package/src/route-renderer/orchestration/render-output.utils.js +65 -0
  138. package/src/route-renderer/{render-preparation.service.d.ts → orchestration/render-preparation.service.d.ts} +18 -10
  139. package/src/route-renderer/{render-preparation.service.js → orchestration/render-preparation.service.js} +115 -17
  140. package/src/route-renderer/orchestration/route-shell-composer.service.d.ts +50 -0
  141. package/src/route-renderer/orchestration/route-shell-composer.service.js +81 -0
  142. package/src/route-renderer/orchestration/template-serialization.d.ts +38 -0
  143. package/src/route-renderer/orchestration/template-serialization.js +45 -0
  144. package/src/route-renderer/{dependency-resolver.d.ts → page-loading/dependency-resolver.d.ts} +15 -4
  145. package/src/route-renderer/{dependency-resolver.js → page-loading/dependency-resolver.js} +28 -12
  146. package/src/route-renderer/page-loading/page-module-loader.d.ts +90 -0
  147. package/src/route-renderer/{page-module-loader.js → page-loading/page-module-loader.js} +39 -14
  148. package/src/route-renderer/route-renderer.d.ts +45 -4
  149. package/src/route-renderer/route-renderer.js +38 -3
  150. package/src/router/README.md +97 -0
  151. package/src/router/client/link-intent.d.ts +53 -0
  152. package/src/router/client/link-intent.js +34 -0
  153. package/src/router/client/link-intent.test.browser.d.ts +1 -0
  154. package/src/router/client/link-intent.test.browser.js +43 -0
  155. package/src/router/client/navigation-coordinator.d.ts +149 -0
  156. package/src/router/client/navigation-coordinator.js +215 -0
  157. package/src/router/{fs-router-scanner.d.ts → server/fs-router-scanner.d.ts} +3 -3
  158. package/src/router/{fs-router-scanner.js → server/fs-router-scanner.js} +14 -8
  159. package/src/router/{fs-router.d.ts → server/fs-router.d.ts} +1 -1
  160. package/src/router/{fs-router.js → server/fs-router.js} +1 -1
  161. package/src/services/README.md +29 -0
  162. package/src/services/assets/asset-processing-service/asset-processing.service.d.ts +120 -0
  163. package/src/services/{asset-processing-service → assets/asset-processing-service}/asset-processing.service.js +91 -10
  164. package/src/services/{asset-processing-service → assets/asset-processing-service}/asset.factory.d.ts +1 -1
  165. package/src/services/{asset-processing-service → assets/asset-processing-service}/asset.factory.js +2 -2
  166. package/src/services/{asset-processing-service → assets/asset-processing-service}/assets.types.d.ts +2 -1
  167. package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.d.ts +55 -0
  168. package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.js +48 -0
  169. package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.d.ts +20 -0
  170. package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.js +41 -0
  171. package/src/services/assets/asset-processing-service/index.d.ts +5 -0
  172. package/src/services/assets/asset-processing-service/index.js +5 -0
  173. package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.interface.d.ts +2 -2
  174. package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.registry.d.ts +2 -2
  175. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/base/base-processor.d.ts +1 -1
  176. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/base/base-processor.js +9 -4
  177. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/base/base-script-processor.d.ts +5 -4
  178. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/base/base-script-processor.js +15 -23
  179. package/src/services/assets/asset-processing-service/processors/index.d.ts +5 -0
  180. package/src/services/assets/asset-processing-service/processors/index.js +5 -0
  181. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/content-script.processor.d.ts +2 -2
  182. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/content-script.processor.js +1 -1
  183. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/file-script.processor.d.ts +4 -3
  184. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/file-script.processor.js +16 -4
  185. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/node-module-script.processor.d.ts +3 -3
  186. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/node-module-script.processor.js +6 -5
  187. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/content-stylesheet.processor.d.ts +2 -2
  188. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/content-stylesheet.processor.js +1 -1
  189. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/file-stylesheet.processor.d.ts +2 -2
  190. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/file-stylesheet.processor.js +5 -2
  191. package/src/services/assets/browser-bundle.service.d.ts +32 -0
  192. package/src/services/assets/browser-bundle.service.js +33 -0
  193. package/src/services/{page-request-cache-coordinator.service.d.ts → cache/page-request-cache-coordinator.service.d.ts} +2 -2
  194. package/src/services/{page-request-cache-coordinator.service.js → cache/page-request-cache-coordinator.service.js} +3 -1
  195. package/src/services/html/html-rewriter-provider.service.d.ts +37 -0
  196. package/src/services/html/html-rewriter-provider.service.js +68 -0
  197. package/src/services/html/html-transformer.service.d.ts +77 -0
  198. package/src/services/html/html-transformer.service.js +215 -0
  199. package/src/services/invalidation/development-invalidation.service.d.ts +74 -0
  200. package/src/services/invalidation/development-invalidation.service.js +190 -0
  201. package/src/services/module-loading/app-module-loader.service.d.ts +28 -0
  202. package/src/services/module-loading/app-module-loader.service.js +35 -0
  203. package/src/services/module-loading/app-server-module-transpiler.service.d.ts +24 -0
  204. package/src/services/module-loading/app-server-module-transpiler.service.js +109 -0
  205. package/src/services/module-loading/host-module-loader-registry.d.ts +4 -0
  206. package/src/services/module-loading/host-module-loader-registry.js +15 -0
  207. package/src/services/module-loading/module-loading-types.d.ts +2 -0
  208. package/src/services/module-loading/node-bootstrap-plugin.d.ts +42 -0
  209. package/src/services/module-loading/node-bootstrap-plugin.js +204 -0
  210. package/src/services/module-loading/page-module-import.service.d.ts +76 -0
  211. package/src/services/module-loading/page-module-import.service.js +173 -0
  212. package/src/services/module-loading/server-module-transpiler.service.d.ts +72 -0
  213. package/src/services/module-loading/server-module-transpiler.service.js +64 -0
  214. package/src/services/runtime-state/dev-graph.service.d.ts +118 -0
  215. package/src/services/runtime-state/dev-graph.service.js +162 -0
  216. package/src/services/runtime-state/entrypoint-dependency-graph.service.d.ts +41 -0
  217. package/src/services/runtime-state/entrypoint-dependency-graph.service.js +85 -0
  218. package/src/services/runtime-state/runtime-specifier-registry.service.d.ts +69 -0
  219. package/src/services/runtime-state/runtime-specifier-registry.service.js +37 -0
  220. package/src/services/runtime-state/server-invalidation-state.service.d.ts +26 -0
  221. package/src/services/runtime-state/server-invalidation-state.service.js +35 -0
  222. package/src/services/{schema-validation-service.d.ts → validation/schema-validation-service.d.ts} +1 -1
  223. package/src/static-site-generator/README.md +26 -0
  224. package/src/static-site-generator/static-site-generator.d.ts +50 -3
  225. package/src/static-site-generator/static-site-generator.js +71 -5
  226. package/src/{internal-types.d.ts → types/internal-types.d.ts} +53 -22
  227. package/src/types/internal-types.js +0 -0
  228. package/src/{public-types.d.ts → types/public-types.d.ts} +146 -21
  229. package/src/types/public-types.js +0 -0
  230. package/src/utils/html-escaping.d.ts +7 -0
  231. package/src/utils/html-escaping.js +6 -0
  232. package/src/utils/locals-utils.d.ts +1 -1
  233. package/src/utils/parse-cli-args.d.ts +4 -1
  234. package/src/utils/parse-cli-args.js +16 -1
  235. package/src/utils/resolve-work-dir.d.ts +11 -0
  236. package/src/utils/resolve-work-dir.js +31 -0
  237. package/src/watchers/project-watcher.d.ts +40 -24
  238. package/src/watchers/project-watcher.js +129 -92
  239. package/src/watchers/project-watcher.test-helpers.d.ts +2 -2
  240. package/src/watchers/project-watcher.test-helpers.js +1 -0
  241. package/src/adapters/abstract/application-adapter.ts +0 -337
  242. package/src/adapters/abstract/router-adapter.ts +0 -30
  243. package/src/adapters/abstract/server-adapter.ts +0 -79
  244. package/src/adapters/bun/client-bridge.ts +0 -62
  245. package/src/adapters/bun/create-app.ts +0 -189
  246. package/src/adapters/bun/define-api-handler.d.ts +0 -61
  247. package/src/adapters/bun/define-api-handler.ts +0 -114
  248. package/src/adapters/bun/hmr-manager.ts +0 -281
  249. package/src/adapters/bun/index.ts +0 -3
  250. package/src/adapters/bun/server-adapter.ts +0 -492
  251. package/src/adapters/bun/server-lifecycle.ts +0 -154
  252. package/src/adapters/index.ts +0 -6
  253. package/src/adapters/node/create-app.ts +0 -179
  254. package/src/adapters/node/index.d.ts +0 -4
  255. package/src/adapters/node/index.js +0 -8
  256. package/src/adapters/node/index.ts +0 -9
  257. package/src/adapters/node/node-client-bridge.ts +0 -79
  258. package/src/adapters/node/node-hmr-manager.ts +0 -271
  259. package/src/adapters/node/server-adapter.ts +0 -561
  260. package/src/adapters/node/static-content-server.ts +0 -203
  261. package/src/adapters/shared/api-response.ts +0 -104
  262. package/src/adapters/shared/application-adapter.ts +0 -199
  263. package/src/adapters/shared/explicit-static-route-matcher.ts +0 -134
  264. package/src/adapters/shared/file-route-middleware-pipeline.ts +0 -123
  265. package/src/adapters/shared/fs-server-response-factory.ts +0 -118
  266. package/src/adapters/shared/fs-server-response-matcher.ts +0 -198
  267. package/src/adapters/shared/render-context.ts +0 -105
  268. package/src/adapters/shared/server-adapter.ts +0 -442
  269. package/src/adapters/shared/server-route-handler.ts +0 -166
  270. package/src/adapters/shared/server-static-builder.ts +0 -82
  271. package/src/build/build-adapter.ts +0 -132
  272. package/src/build/build-types.ts +0 -83
  273. package/src/build/esbuild-build-adapter.ts +0 -510
  274. package/src/config/config-builder.ts +0 -474
  275. package/src/constants.ts +0 -39
  276. package/src/create-app.ts +0 -87
  277. package/src/define-api-handler.js +0 -15
  278. package/src/define-api-handler.ts +0 -66
  279. package/src/dev/sc-server.ts +0 -143
  280. package/src/eco/component-render-context.d.ts +0 -105
  281. package/src/eco/component-render-context.js +0 -77
  282. package/src/eco/component-render-context.ts +0 -202
  283. package/src/eco/eco.ts +0 -221
  284. package/src/eco/eco.types.ts +0 -202
  285. package/src/eco/global-injector-map.ts +0 -112
  286. package/src/eco/lazy-injector-map.ts +0 -120
  287. package/src/eco/module-dependencies.ts +0 -75
  288. package/src/errors/http-error.ts +0 -72
  289. package/src/errors/index.ts +0 -2
  290. package/src/errors/locals-access-error.ts +0 -7
  291. package/src/global/app-logger.ts +0 -4
  292. package/src/hmr/client/__screenshots__/hmr-runtime.test.browser.ts/HMR-Runtime-HMR-Server-Integration-should-have-HMR-script-injected-in-page-1.png +0 -0
  293. package/src/hmr/client/__screenshots__/hmr-runtime.test.browser.ts/HMR-Runtime-HMR-Server-Integration-should-load-fixture-app-page-1.png +0 -0
  294. package/src/hmr/client/__screenshots__/hmr-runtime.test.browser.ts/HMR-Runtime-WebSocket-Connection-should-connect-to-correct-HMR-endpoint-1.png +0 -0
  295. package/src/hmr/client/hmr-runtime.ts +0 -121
  296. package/src/hmr/hmr-strategy.ts +0 -172
  297. package/src/hmr/hmr.test.e2e.ts +0 -75
  298. package/src/hmr/strategies/default-hmr-strategy.ts +0 -60
  299. package/src/hmr/strategies/js-hmr-strategy.ts +0 -308
  300. package/src/index.browser.ts +0 -3
  301. package/src/index.ts +0 -5
  302. package/src/integrations/ghtml/ghtml-renderer.ts +0 -93
  303. package/src/integrations/ghtml/ghtml.plugin.ts +0 -32
  304. package/src/internal-types.ts +0 -212
  305. package/src/plugins/alias-resolver-plugin.ts +0 -45
  306. package/src/plugins/eco-component-meta-plugin.ts +0 -474
  307. package/src/plugins/integration-plugin.ts +0 -184
  308. package/src/plugins/processor.ts +0 -220
  309. package/src/public-types.ts +0 -1255
  310. package/src/route-renderer/component-graph-executor.d.ts +0 -32
  311. package/src/route-renderer/component-graph-executor.js +0 -31
  312. package/src/route-renderer/component-graph-executor.ts +0 -84
  313. package/src/route-renderer/component-graph.d.ts +0 -42
  314. package/src/route-renderer/component-graph.js +0 -72
  315. package/src/route-renderer/component-graph.ts +0 -159
  316. package/src/route-renderer/component-marker.d.ts +0 -52
  317. package/src/route-renderer/component-marker.js +0 -46
  318. package/src/route-renderer/component-marker.ts +0 -117
  319. package/src/route-renderer/dependency-resolver.ts +0 -596
  320. package/src/route-renderer/html-post-processing.service.d.ts +0 -40
  321. package/src/route-renderer/html-post-processing.service.js +0 -86
  322. package/src/route-renderer/html-post-processing.service.ts +0 -103
  323. package/src/route-renderer/integration-renderer.d.ts +0 -339
  324. package/src/route-renderer/integration-renderer.js +0 -526
  325. package/src/route-renderer/integration-renderer.ts +0 -696
  326. package/src/route-renderer/marker-graph-resolver.d.ts +0 -76
  327. package/src/route-renderer/marker-graph-resolver.js +0 -93
  328. package/src/route-renderer/marker-graph-resolver.ts +0 -153
  329. package/src/route-renderer/page-module-loader.d.ts +0 -61
  330. package/src/route-renderer/page-module-loader.ts +0 -153
  331. package/src/route-renderer/render-execution.service.d.ts +0 -69
  332. package/src/route-renderer/render-execution.service.js +0 -91
  333. package/src/route-renderer/render-execution.service.ts +0 -158
  334. package/src/route-renderer/render-preparation.service.ts +0 -358
  335. package/src/route-renderer/route-renderer.ts +0 -80
  336. package/src/router/fs-router-scanner.ts +0 -217
  337. package/src/router/fs-router.ts +0 -122
  338. package/src/services/asset-processing-service/asset-processing.service.d.ts +0 -41
  339. package/src/services/asset-processing-service/asset-processing.service.ts +0 -306
  340. package/src/services/asset-processing-service/asset.factory.ts +0 -105
  341. package/src/services/asset-processing-service/assets.types.ts +0 -112
  342. package/src/services/asset-processing-service/index.d.ts +0 -3
  343. package/src/services/asset-processing-service/index.js +0 -3
  344. package/src/services/asset-processing-service/index.ts +0 -3
  345. package/src/services/asset-processing-service/processor.interface.ts +0 -27
  346. package/src/services/asset-processing-service/processor.registry.ts +0 -18
  347. package/src/services/asset-processing-service/processors/base/base-processor.ts +0 -76
  348. package/src/services/asset-processing-service/processors/base/base-script-processor.ts +0 -105
  349. package/src/services/asset-processing-service/processors/index.d.ts +0 -5
  350. package/src/services/asset-processing-service/processors/index.js +0 -5
  351. package/src/services/asset-processing-service/processors/index.ts +0 -5
  352. package/src/services/asset-processing-service/processors/script/content-script.processor.ts +0 -66
  353. package/src/services/asset-processing-service/processors/script/file-script.processor.ts +0 -88
  354. package/src/services/asset-processing-service/processors/script/node-module-script.processor.ts +0 -84
  355. package/src/services/asset-processing-service/processors/stylesheet/content-stylesheet.processor.ts +0 -27
  356. package/src/services/asset-processing-service/processors/stylesheet/file-stylesheet.processor.ts +0 -77
  357. package/src/services/cache/cache.types.ts +0 -126
  358. package/src/services/cache/index.ts +0 -18
  359. package/src/services/cache/memory-cache-store.ts +0 -130
  360. package/src/services/cache/page-cache-service.ts +0 -202
  361. package/src/services/html-transformer.service.d.ts +0 -50
  362. package/src/services/html-transformer.service.js +0 -163
  363. package/src/services/html-transformer.service.ts +0 -217
  364. package/src/services/page-module-import.service.d.ts +0 -37
  365. package/src/services/page-module-import.service.js +0 -88
  366. package/src/services/page-module-import.service.ts +0 -129
  367. package/src/services/page-request-cache-coordinator.service.ts +0 -128
  368. package/src/services/schema-validation-service.ts +0 -204
  369. package/src/services/validation/standard-schema.types.ts +0 -68
  370. package/src/static-site-generator/static-site-generator.ts +0 -359
  371. package/src/utils/css.d.ts +0 -1
  372. package/src/utils/css.js +0 -7
  373. package/src/utils/css.ts +0 -5
  374. package/src/utils/deep-merge.ts +0 -47
  375. package/src/utils/hash.ts +0 -5
  376. package/src/utils/html.ts +0 -1
  377. package/src/utils/invariant.ts +0 -15
  378. package/src/utils/locals-utils.ts +0 -37
  379. package/src/utils/parse-cli-args.ts +0 -83
  380. package/src/utils/path-utils.module.ts +0 -14
  381. package/src/utils/runtime.ts +0 -44
  382. package/src/utils/server-utils.module.ts +0 -67
  383. package/src/watchers/project-watcher.test-helpers.ts +0 -40
  384. package/src/watchers/project-watcher.ts +0 -306
  385. /package/src/adapters/{bun → shared}/define-api-handler.js +0 -0
  386. /package/src/{internal-types.js → plugins/runtime-capability.js} +0 -0
  387. /package/src/services/{asset-processing-service → assets/asset-processing-service}/assets.types.js +0 -0
  388. /package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.interface.js +0 -0
  389. /package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.registry.js +0 -0
  390. /package/src/{public-types.js → services/module-loading/module-loading-types.js} +0 -0
  391. /package/src/services/{schema-validation-service.js → validation/schema-validation-service.js} +0 -0
@@ -1,30 +0,0 @@
1
- /**
2
- * This file contains the abstract router adapter class and its methods.
3
- * It is designed to be extended by specific router adapters for different runtimes.
4
- * The class provides methods for converting paths, creating route handlers,
5
- * and adapting routes to the expected format of the runtime.
6
- *
7
- * @module RouterAdapter
8
- */
9
-
10
- import type { Routes } from '../../internal-types.ts';
11
-
12
- /**
13
- * Abstract base class for router adapters across different runtimes
14
- */
15
- export abstract class AbstractRouterAdapter<TRouteFormat = any> {
16
- /**
17
- * Convert a route path to the format expected by the runtime
18
- */
19
- protected abstract convertPath(pathname: string): string;
20
-
21
- /**
22
- * Create a route handler compatible with the runtime
23
- */
24
- protected abstract createRouteHandler(route: any): any;
25
-
26
- /**
27
- * Adapt framework routes to the format expected by the runtime
28
- */
29
- public abstract adaptRoutes(routes: Routes): TRouteFormat;
30
- }
@@ -1,79 +0,0 @@
1
- /**
2
- * This file contains the abstract server adapter class and its related types.
3
- * It is designed to be extended by specific server adapters for different runtimes.
4
- * The class provides methods for initializing the server, creating server options,
5
- * building static files, and handling HTTP requests.
6
- *
7
- * @module ServerAdapter
8
- */
9
-
10
- import type { EcoPagesAppConfig } from '../../internal-types.ts';
11
- import type { ApiHandler } from '../../public-types.ts';
12
-
13
- /**
14
- * Configuration options for all server adapters
15
- */
16
- export interface ServerAdapterOptions {
17
- appConfig: EcoPagesAppConfig;
18
- apiHandlers?: ApiHandler<string, any>[];
19
- options?: {
20
- watch?: boolean;
21
- [key: string]: any;
22
- };
23
- serveOptions?: Record<string, any>;
24
- runtimeOrigin: string;
25
- }
26
-
27
- /**
28
- * Base adapter result containing common functionalities
29
- * across different runtime implementations
30
- */
31
- export interface ServerAdapterResult {
32
- getServerOptions: (options?: { enableHmr?: boolean }) => any;
33
- buildStatic: (options?: { preview?: boolean }) => Promise<void>;
34
- }
35
-
36
- /**
37
- * Abstract base class for server adapters across different runtimes
38
- */
39
- export abstract class AbstractServerAdapter<
40
- TOptions extends ServerAdapterOptions = ServerAdapterOptions,
41
- TResult extends ServerAdapterResult = ServerAdapterResult,
42
- > {
43
- protected appConfig: EcoPagesAppConfig;
44
- protected options: TOptions['options'];
45
- protected serveOptions: TOptions['serveOptions'];
46
- protected runtimeOrigin: string;
47
-
48
- constructor(options: TOptions) {
49
- this.appConfig = options.appConfig;
50
- this.options = options.options || {};
51
- this.serveOptions = options.serveOptions || {};
52
- this.runtimeOrigin = options.runtimeOrigin;
53
- }
54
-
55
- /**
56
- * Initialize the server adapter
57
- */
58
- public abstract initialize(): Promise<void>;
59
-
60
- /**
61
- * Create server options specific to the runtime
62
- */
63
- public abstract getServerOptions(options?: { enableHmr?: boolean }): any;
64
-
65
- /**
66
- * Build static files for the application
67
- */
68
- public abstract buildStatic(options?: { preview?: boolean }): Promise<void>;
69
-
70
- /**
71
- * Factory method to create a server adapter with runtime-specific functionality
72
- */
73
- public abstract createAdapter(): Promise<TResult>;
74
-
75
- /**
76
- * Handle HTTP requests
77
- */
78
- public abstract handleRequest(request: Request): Promise<Response>;
79
- }
@@ -1,62 +0,0 @@
1
- import type { ServerWebSocket } from 'bun';
2
- import type { ClientBridgeEvent, IClientBridge } from '../../public-types';
3
-
4
- type BunSocket = ServerWebSocket<unknown>;
5
-
6
- /**
7
- * Manages WebSocket subscribers and broadcasts development events.
8
- * Bridges the gap between the server and the development client.
9
- */
10
- export class ClientBridge implements IClientBridge {
11
- private subscribers = new Set<BunSocket>();
12
-
13
- subscribe(ws: BunSocket): void {
14
- this.subscribers.add(ws);
15
- }
16
-
17
- unsubscribe(ws: BunSocket): void {
18
- this.subscribers.delete(ws);
19
- }
20
-
21
- /**
22
- * Broadcast a raw event to all connected clients.
23
- */
24
- broadcast(event: ClientBridgeEvent): void {
25
- const payload = JSON.stringify(event);
26
- for (const ws of this.subscribers) {
27
- ws.send(payload);
28
- }
29
- }
30
-
31
- /**
32
- * Trigger a full page reload on all connected clients.
33
- */
34
- reload(): void {
35
- this.broadcast({ type: 'reload' });
36
- }
37
-
38
- /**
39
- * Broadcast a CSS update for hot stylesheet reload.
40
- */
41
- cssUpdate(path: string): void {
42
- this.broadcast({ type: 'css-update', path, timestamp: Date.now() });
43
- }
44
-
45
- /**
46
- * Broadcast a JS module update for hot module replacement.
47
- */
48
- update(path: string): void {
49
- this.broadcast({ type: 'update', path, timestamp: Date.now() });
50
- }
51
-
52
- /**
53
- * Broadcast an error message to connected clients.
54
- */
55
- error(message: string): void {
56
- this.broadcast({ type: 'error', message });
57
- }
58
-
59
- get subscriberCount(): number {
60
- return this.subscribers.size;
61
- }
62
- }
@@ -1,189 +0,0 @@
1
- /**
2
- * This file contains the implementation of the Bun application adapter for EcoPages.
3
- * It extends the AbstractApplicationAdapter class and provides methods for handling
4
- * HTTP requests, initializing the server adapter, and starting the Bun application server.
5
- * The adapter is designed to work with the Bun runtime and provides a way to create
6
- * EcoPages applications using Bun's features.
7
- *
8
- * @module EcopagesApp
9
- */
10
-
11
- import type { Server } from 'bun';
12
- import { DEFAULT_ECOPAGES_HOSTNAME, DEFAULT_ECOPAGES_PORT } from '../../constants.ts';
13
- import { appLogger } from '../../global/app-logger.ts';
14
- import type { EcoPagesAppConfig } from '../../internal-types.ts';
15
- import { getBunRuntime } from '../../utils/runtime.ts';
16
- import type { ApiHandlerContext, RouteGroupBuilder } from '../../public-types.ts';
17
- import { type ApplicationAdapterOptions } from '../abstract/application-adapter.ts';
18
- import { SharedApplicationAdapter } from '../shared/application-adapter.ts';
19
- import { type BunServerAdapterResult, createBunServerAdapter } from './server-adapter.ts';
20
-
21
- /**
22
- * Configuration options for the Bun application adapter
23
- */
24
- export interface EcopagesAppOptions extends ApplicationAdapterOptions {
25
- appConfig: EcoPagesAppConfig;
26
- serverOptions?: Record<string, any>;
27
- }
28
-
29
- /**
30
- * Bun-specific route group builder that properly infers route params from path patterns.
31
- * When you define a route like `/posts/:slug`, the handler context will have
32
- * `ctx.params.slug` typed as `string`.
33
- *
34
- * @typeParam WebSocketData - WebSocket data type for the server
35
- * @typeParam TContext - Extended context type from middleware (e.g., `{ user: User }`)
36
- */
37
- export type BunRouteGroupBuilder<
38
- WebSocketData = undefined,
39
- TContext extends ApiHandlerContext<Request, Server<WebSocketData>> = ApiHandlerContext<
40
- Request,
41
- Server<WebSocketData>
42
- >,
43
- > = RouteGroupBuilder<Request, Server<WebSocketData>, TContext>;
44
-
45
- /**
46
- * Bun-specific application adapter implementation
47
- * This class extends the {@link AbstractApplicationAdapter}
48
- * and provides methods for handling HTTP requests and managing the server.
49
- */
50
-
51
- export class EcopagesApp<WebSocketData = undefined> extends SharedApplicationAdapter<
52
- EcopagesAppOptions,
53
- Server<WebSocketData>,
54
- Request
55
- > {
56
- serverAdapter: BunServerAdapterResult | undefined;
57
- private server: Server<WebSocketData> | null = null;
58
-
59
- public async fetch(request: Request): Promise<Response> {
60
- if (!this.serverAdapter) {
61
- this.serverAdapter = await this.initializeServerAdapter();
62
- }
63
-
64
- await this.serverAdapter.completeInitialization(this.server);
65
- return this.serverAdapter.handleRequest(request);
66
- }
67
-
68
- /**
69
- * Complete the initialization of the server adapter by processing dynamic routes
70
- * @param server The Bun server instance
71
- */
72
- public async completeInitialization(server: Server<WebSocketData>): Promise<void> {
73
- if (!this.serverAdapter) {
74
- throw new Error('Server adapter not initialized. Call start() first.');
75
- }
76
-
77
- await this.serverAdapter.completeInitialization(server);
78
- }
79
-
80
- /**
81
- * Initialize the Bun server adapter
82
- */
83
- protected async initializeServerAdapter(): Promise<BunServerAdapterResult> {
84
- const { dev } = this.cliArgs;
85
- const { port: cliPort, hostname: cliHostname } = this.cliArgs;
86
-
87
- const envPort = process.env.ECOPAGES_PORT ? process.env.ECOPAGES_PORT : undefined;
88
- const envHostname = process.env.ECOPAGES_HOSTNAME;
89
-
90
- const preferredPort = cliPort ?? envPort ?? DEFAULT_ECOPAGES_PORT;
91
- const preferredHostname = cliHostname ?? envHostname ?? DEFAULT_ECOPAGES_HOSTNAME;
92
-
93
- appLogger.debug('initializeServerAdapter', {
94
- dev,
95
- cliPort,
96
- cliHostname,
97
- envPort,
98
- envHostname,
99
- preferredPort,
100
- preferredHostname,
101
- composedUrl: `http://${preferredHostname}:${preferredPort}`,
102
- });
103
-
104
- return await createBunServerAdapter({
105
- runtimeOrigin: `http://${preferredHostname}:${preferredPort}`,
106
- appConfig: this.appConfig,
107
- apiHandlers: this.apiHandlers,
108
- staticRoutes: this.staticRoutes,
109
- errorHandler: this.errorHandler,
110
- options: { watch: dev },
111
- serveOptions: {
112
- port: preferredPort,
113
- hostname: preferredHostname,
114
- ...this.serverOptions,
115
- },
116
- });
117
- }
118
-
119
- /**
120
- * Start the Bun application server
121
- * @param options Optional settings
122
- * @param options.autoCompleteInitialization Whether to automatically complete initialization with dynamic routes after server start (defaults to true)
123
- */
124
- public async start(): Promise<Server<WebSocketData> | void> {
125
- if (!this.serverAdapter) {
126
- this.serverAdapter = await this.initializeServerAdapter();
127
- }
128
-
129
- const { dev, preview, build } = this.cliArgs;
130
- const requiresFetchRuntime = this.appConfig.integrations.some(
131
- (integration) => integration.staticBuildStep === 'fetch',
132
- );
133
- const canBuildWithoutRuntimeServer = (build || preview) && !requiresFetchRuntime;
134
-
135
- if (canBuildWithoutRuntimeServer) {
136
- appLogger.debugTime('Building static pages');
137
- await this.serverAdapter.buildStatic({ preview });
138
- appLogger.debugTimeEnd('Building static pages');
139
-
140
- if (build) {
141
- process.exit(0);
142
- }
143
-
144
- return;
145
- }
146
-
147
- const enableHmr = dev || (!preview && !build);
148
- const serverOptions = this.serverAdapter.getServerOptions({ enableHmr });
149
-
150
- const bun = getBunRuntime();
151
- if (!bun) {
152
- throw new Error('Bun runtime is required for the Bun adapter');
153
- }
154
-
155
- const bunServer = bun.serve(serverOptions as Bun.Serve.Options<WebSocketData>);
156
- this.server = bunServer as Server<WebSocketData>;
157
-
158
- await this.serverAdapter.completeInitialization(this.server).catch((error: Error) => {
159
- appLogger.error(`Failed to complete initialization: ${error}`);
160
- });
161
-
162
- if (!this.server) {
163
- throw new Error('Server failed to start');
164
- }
165
- appLogger.info(`Server running at http://${this.server.hostname}:${this.server.port}`);
166
-
167
- if (build || preview) {
168
- appLogger.debugTime('Building static pages');
169
- await this.serverAdapter.buildStatic({ preview });
170
- this.server.stop(true);
171
- appLogger.debugTimeEnd('Building static pages');
172
-
173
- if (build) {
174
- process.exit(0);
175
- }
176
- }
177
-
178
- return this.server;
179
- }
180
- }
181
-
182
- /**
183
- * Factory function to create a Bun application
184
- */
185
- export async function createApp<WebSocketData = undefined>(
186
- options: EcopagesAppOptions,
187
- ): Promise<EcopagesApp<WebSocketData>> {
188
- return new EcopagesApp(options);
189
- }
@@ -1,61 +0,0 @@
1
- import type { Server } from 'bun';
2
- import type { ApiHandler, ApiHandlerContext, Middleware, RouteSchema, TypedGroupHandlerContext } from '../../public-types';
3
- type BunSchemaHandlerContext<TSchema extends RouteSchema | undefined, WebSocketData, TContext extends ApiHandlerContext<Request, Server<WebSocketData>>> = TSchema extends RouteSchema ? TypedGroupHandlerContext<TSchema, TContext> : TContext;
4
- /**
5
- * Helper function specifically for Bun to define an API handler with
6
- * automatically inferred path type for BunRequest.
7
- *
8
- * This returns a self-describing route declaration (`path`, `method`, `handler`,
9
- * optional `middleware`, optional `schema`) that can be registered on the app.
10
- *
11
- * @template TPath The literal string type of the path, inferred from the 'path' property.
12
- * @param handler The API handler configuration object using BunRequest.
13
- * @returns The same handler object, strongly typed for Bun.
14
- */
15
- export declare function defineApiHandler<TSchema extends RouteSchema | undefined = undefined, WebSocketData = undefined, TContext extends ApiHandlerContext<Request, Server<WebSocketData>> = ApiHandlerContext<Request, Server<WebSocketData>>>(handler: Omit<ApiHandler<string, Request, Server<WebSocketData>>, 'handler' | 'middleware' | 'schema'> & {
16
- handler: (context: BunSchemaHandlerContext<TSchema, WebSocketData, TContext>) => Promise<Response> | Response;
17
- middleware?: Middleware<Request, Server<WebSocketData>, TContext>[];
18
- schema?: TSchema;
19
- }): ApiHandler<string, Request, Server<WebSocketData>>;
20
- /**
21
- * Configuration for a group of related API handlers with shared prefix and middleware.
22
- */
23
- export interface GroupHandler<TPrefix extends string = string, WebSocketData = undefined> {
24
- prefix: TPrefix;
25
- middleware?: readonly Middleware<Request, Server<WebSocketData>, any>[];
26
- routes: readonly ApiHandler<string, Request, Server<WebSocketData>>[];
27
- }
28
- type GroupDefineHandler<WebSocketData, TContext extends ApiHandlerContext<Request, Server<WebSocketData>>> = <const TPath extends string, TSchema extends RouteSchema | undefined = undefined>(handler: Omit<ApiHandler<TPath, Request, Server<WebSocketData>>, 'handler' | 'middleware' | 'schema'> & {
29
- path: TPath;
30
- handler: (context: TSchema extends RouteSchema ? TypedGroupHandlerContext<TSchema, TContext> : TContext) => Promise<Response> | Response;
31
- middleware?: Middleware<Request, Server<WebSocketData>, TContext>[];
32
- schema?: TSchema;
33
- }) => ApiHandler<TPath, Request, Server<WebSocketData>>;
34
- /**
35
- * Helper function to define a group of API handlers with shared prefix and middleware.
36
- * The group middleware context is inferred and passed to all route handlers.
37
- *
38
- * @example
39
- * ```typescript
40
- * const adminGroup = defineGroupHandler({
41
- * prefix: '/admin',
42
- * middleware: [authMiddleware],
43
- * routes: (define) => [
44
- * define({ path: '/', method: 'GET', handler: (ctx) => ctx.render(List, {}) }),
45
- * define({ path: '/posts/:id', method: 'GET', handler: (ctx) => {
46
- * // ctx.session is typed from authMiddleware!
47
- * // ctx.params.id is typed from path!
48
- * return ctx.render(Post, { id: ctx.params.id });
49
- * }}),
50
- * ],
51
- * });
52
- *
53
- * app.group(adminGroup);
54
- * ```
55
- */
56
- export declare function defineGroupHandler<TPrefix extends string, WebSocketData = undefined, TMiddleware extends readonly Middleware<Request, Server<WebSocketData>, any>[] = [], TContext extends ApiHandlerContext<Request, Server<WebSocketData>> = TMiddleware extends readonly Middleware<Request, Server<WebSocketData>, infer TGroupContext>[] ? TGroupContext : ApiHandlerContext<Request, Server<WebSocketData>>>(config: {
57
- prefix: TPrefix;
58
- middleware?: TMiddleware;
59
- routes: (define: GroupDefineHandler<WebSocketData, TContext>) => readonly ApiHandler<string, Request, Server<WebSocketData>>[];
60
- }): GroupHandler<TPrefix, WebSocketData>;
61
- export {};
@@ -1,114 +0,0 @@
1
- import type { Server } from 'bun';
2
- import type {
3
- ApiHandler,
4
- ApiHandlerContext,
5
- Middleware,
6
- RouteSchema,
7
- TypedGroupHandlerContext,
8
- } from '../../public-types';
9
-
10
- type BunSchemaHandlerContext<
11
- TSchema extends RouteSchema | undefined,
12
- WebSocketData,
13
- TContext extends ApiHandlerContext<Request, Server<WebSocketData>>,
14
- > = TSchema extends RouteSchema ? TypedGroupHandlerContext<TSchema, TContext> : TContext;
15
-
16
- /**
17
- * Helper function specifically for Bun to define an API handler with
18
- * automatically inferred path type for BunRequest.
19
- *
20
- * This returns a self-describing route declaration (`path`, `method`, `handler`,
21
- * optional `middleware`, optional `schema`) that can be registered on the app.
22
- *
23
- * @template TPath The literal string type of the path, inferred from the 'path' property.
24
- * @param handler The API handler configuration object using BunRequest.
25
- * @returns The same handler object, strongly typed for Bun.
26
- */
27
- export function defineApiHandler<
28
- TSchema extends RouteSchema | undefined = undefined,
29
- WebSocketData = undefined,
30
- TContext extends ApiHandlerContext<Request, Server<WebSocketData>> = ApiHandlerContext<
31
- Request,
32
- Server<WebSocketData>
33
- >,
34
- >(
35
- handler: Omit<ApiHandler<string, Request, Server<WebSocketData>>, 'handler' | 'middleware' | 'schema'> & {
36
- handler: (context: BunSchemaHandlerContext<TSchema, WebSocketData, TContext>) => Promise<Response> | Response;
37
- middleware?: Middleware<Request, Server<WebSocketData>, TContext>[];
38
- schema?: TSchema;
39
- },
40
- ): ApiHandler<string, Request, Server<WebSocketData>> {
41
- return handler as ApiHandler<string, Request, Server<WebSocketData>>;
42
- }
43
-
44
- /**
45
- * Configuration for a group of related API handlers with shared prefix and middleware.
46
- */
47
- export interface GroupHandler<TPrefix extends string = string, WebSocketData = undefined> {
48
- prefix: TPrefix;
49
- middleware?: readonly Middleware<Request, Server<WebSocketData>, any>[];
50
- routes: readonly ApiHandler<string, Request, Server<WebSocketData>>[];
51
- }
52
-
53
- type GroupDefineHandler<WebSocketData, TContext extends ApiHandlerContext<Request, Server<WebSocketData>>> = <
54
- const TPath extends string,
55
- TSchema extends RouteSchema | undefined = undefined,
56
- >(
57
- handler: Omit<ApiHandler<TPath, Request, Server<WebSocketData>>, 'handler' | 'middleware' | 'schema'> & {
58
- path: TPath;
59
- handler: (
60
- context: TSchema extends RouteSchema ? TypedGroupHandlerContext<TSchema, TContext> : TContext,
61
- ) => Promise<Response> | Response;
62
- middleware?: Middleware<Request, Server<WebSocketData>, TContext>[];
63
- schema?: TSchema;
64
- },
65
- ) => ApiHandler<TPath, Request, Server<WebSocketData>>;
66
-
67
- /**
68
- * Helper function to define a group of API handlers with shared prefix and middleware.
69
- * The group middleware context is inferred and passed to all route handlers.
70
- *
71
- * @example
72
- * ```typescript
73
- * const adminGroup = defineGroupHandler({
74
- * prefix: '/admin',
75
- * middleware: [authMiddleware],
76
- * routes: (define) => [
77
- * define({ path: '/', method: 'GET', handler: (ctx) => ctx.render(List, {}) }),
78
- * define({ path: '/posts/:id', method: 'GET', handler: (ctx) => {
79
- * // ctx.session is typed from authMiddleware!
80
- * // ctx.params.id is typed from path!
81
- * return ctx.render(Post, { id: ctx.params.id });
82
- * }}),
83
- * ],
84
- * });
85
- *
86
- * app.group(adminGroup);
87
- * ```
88
- */
89
- export function defineGroupHandler<
90
- TPrefix extends string,
91
- WebSocketData = undefined,
92
- TMiddleware extends readonly Middleware<Request, Server<WebSocketData>, any>[] = [],
93
- TContext extends ApiHandlerContext<Request, Server<WebSocketData>> = TMiddleware extends readonly Middleware<
94
- Request,
95
- Server<WebSocketData>,
96
- infer TGroupContext
97
- >[]
98
- ? TGroupContext
99
- : ApiHandlerContext<Request, Server<WebSocketData>>,
100
- >(config: {
101
- prefix: TPrefix;
102
- middleware?: TMiddleware;
103
- routes: (
104
- define: GroupDefineHandler<WebSocketData, TContext>,
105
- ) => readonly ApiHandler<string, Request, Server<WebSocketData>>[];
106
- }): GroupHandler<TPrefix, WebSocketData> {
107
- const define = ((handler) => handler) as GroupDefineHandler<WebSocketData, TContext>;
108
-
109
- return {
110
- prefix: config.prefix,
111
- middleware: config.middleware,
112
- routes: config.routes(define),
113
- };
114
- }