@ecopages/core 0.2.0-alpha.4 → 0.2.0-alpha.6

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