@ecopages/core 0.2.0-alpha.5 → 0.2.0-alpha.51

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 (456) hide show
  1. package/README.md +267 -14
  2. package/package.json +98 -108
  3. package/src/adapters/README.md +39 -0
  4. package/src/adapters/abstract/application-adapter.d.ts +28 -2
  5. package/src/adapters/abstract/application-adapter.js +14 -2
  6. package/src/adapters/abstract/router-adapter.d.ts +1 -1
  7. package/src/adapters/abstract/server-adapter.d.ts +2 -2
  8. package/src/adapters/bun/client-bridge.d.ts +1 -1
  9. package/src/adapters/bun/create-app.d.ts +12 -12
  10. package/src/adapters/bun/create-app.js +64 -41
  11. package/src/adapters/bun/hmr-manager.d.ts +30 -62
  12. package/src/adapters/bun/hmr-manager.js +30 -194
  13. package/src/adapters/bun/index.d.ts +2 -3
  14. package/src/adapters/bun/index.js +3 -3
  15. package/src/adapters/bun/runtime-host.d.ts +52 -0
  16. package/src/adapters/bun/runtime-host.js +56 -0
  17. package/src/adapters/bun/server-adapter.d.ts +93 -32
  18. package/src/adapters/bun/server-adapter.js +166 -89
  19. package/src/adapters/bun/static-preview-host.d.ts +28 -0
  20. package/src/adapters/bun/static-preview-host.js +45 -0
  21. package/src/{create-app.d.ts → adapters/create-app.d.ts} +9 -6
  22. package/src/{create-app.js → adapters/create-app.js} +4 -4
  23. package/src/adapters/index.d.ts +2 -6
  24. package/src/adapters/index.js +2 -8
  25. package/src/adapters/node/create-app.d.ts +15 -12
  26. package/src/adapters/node/create-app.js +34 -85
  27. package/src/adapters/node/http-request-bridge.d.ts +57 -0
  28. package/src/adapters/node/http-request-bridge.js +118 -0
  29. package/src/adapters/node/node-client-bridge.d.ts +1 -1
  30. package/src/adapters/node/node-hmr-manager.d.ts +38 -48
  31. package/src/adapters/node/node-hmr-manager.js +31 -203
  32. package/src/adapters/node/runtime-host.d.ts +57 -0
  33. package/src/adapters/node/runtime-host.js +92 -0
  34. package/src/adapters/node/server-adapter-dependencies.d.ts +19 -0
  35. package/src/adapters/node/server-adapter-dependencies.js +18 -0
  36. package/src/adapters/node/server-adapter.d.ts +20 -72
  37. package/src/adapters/node/server-adapter.js +98 -203
  38. package/src/adapters/node/static-content-server.d.ts +37 -1
  39. package/src/adapters/node/static-content-server.js +29 -1
  40. package/src/adapters/node/static-preview-host.d.ts +55 -0
  41. package/src/adapters/node/static-preview-host.js +68 -0
  42. package/src/adapters/shared/application-adapter.d.ts +1 -1
  43. package/src/{define-api-handler.d.ts → adapters/shared/define-api-handler.d.ts} +1 -1
  44. package/src/adapters/shared/explicit-static-render-preparation.d.ts +25 -0
  45. package/src/adapters/shared/explicit-static-render-preparation.js +26 -0
  46. package/src/adapters/shared/explicit-static-route-matcher.d.ts +7 -4
  47. package/src/adapters/shared/explicit-static-route-matcher.js +14 -13
  48. package/src/adapters/shared/file-route-middleware-pipeline.d.ts +7 -10
  49. package/src/adapters/shared/file-route-middleware-pipeline.js +3 -11
  50. package/src/adapters/shared/fs-server-response-factory.d.ts +14 -10
  51. package/src/adapters/shared/fs-server-response-factory.js +11 -27
  52. package/src/adapters/shared/fs-server-response-matcher.d.ts +20 -16
  53. package/src/adapters/shared/fs-server-response-matcher.js +76 -45
  54. package/src/adapters/shared/hmr-entrypoint-registrar.d.ts +55 -0
  55. package/src/adapters/shared/hmr-entrypoint-registrar.js +87 -0
  56. package/src/adapters/shared/hmr-html-response.d.ts +22 -0
  57. package/src/adapters/shared/hmr-html-response.js +33 -0
  58. package/src/adapters/shared/render-context.d.ts +5 -3
  59. package/src/adapters/shared/render-context.js +27 -3
  60. package/src/adapters/shared/runtime-app-bootstrap.d.ts +26 -0
  61. package/src/adapters/shared/runtime-app-bootstrap.js +46 -0
  62. package/src/adapters/shared/runtime-host.d.ts +12 -0
  63. package/src/adapters/shared/server-adapter.d.ts +33 -12
  64. package/src/adapters/shared/server-adapter.js +215 -132
  65. package/src/adapters/shared/server-route-handler.d.ts +5 -5
  66. package/src/adapters/shared/server-route-handler.js +7 -16
  67. package/src/adapters/shared/server-static-builder.d.ts +41 -8
  68. package/src/adapters/shared/server-static-builder.js +65 -11
  69. package/src/adapters/shared/shared-hmr-manager.d.ts +59 -0
  70. package/src/adapters/shared/shared-hmr-manager.js +240 -0
  71. package/src/adapters/shared/static-preview-host.d.ts +10 -0
  72. package/src/build/README.md +107 -0
  73. package/src/build/browser-runtime-import-rewrite-plugin.d.ts +26 -0
  74. package/src/build/browser-runtime-import-rewrite-plugin.js +162 -0
  75. package/src/build/browser-runtime-manifest.d.ts +31 -0
  76. package/src/build/browser-runtime-manifest.js +61 -0
  77. package/src/build/build-adapter.d.ts +175 -3
  78. package/src/build/build-adapter.js +633 -16
  79. package/src/build/build-manifest.d.ts +33 -0
  80. package/src/build/build-manifest.js +52 -0
  81. package/src/build/dev-build-coordinator.d.ts +72 -0
  82. package/src/build/dev-build-coordinator.js +154 -0
  83. package/src/build/esbuild-build-adapter.d.ts +16 -6
  84. package/src/build/esbuild-build-adapter.js +205 -75
  85. package/src/build/runtime-build-executor.d.ts +14 -0
  86. package/src/build/runtime-build-executor.js +22 -0
  87. package/src/build/runtime-specifier-alias-plugin.d.ts +15 -0
  88. package/src/build/runtime-specifier-alias-plugin.js +31 -0
  89. package/src/config/README.md +36 -0
  90. package/src/config/config-builder.d.ts +54 -29
  91. package/src/config/config-builder.js +256 -50
  92. package/src/{constants.d.ts → config/constants.d.ts} +13 -0
  93. package/src/{constants.js → config/constants.js} +4 -0
  94. package/src/declarations.d.ts +19 -14
  95. package/src/dev/host-runtime.d.ts +10 -0
  96. package/src/dev/host-runtime.js +24 -0
  97. package/src/dev/sc-server.d.ts +1 -1
  98. package/src/dev/sc-server.js +1 -1
  99. package/src/eco/README.md +70 -16
  100. package/src/eco/eco.browser.d.ts +2 -0
  101. package/src/eco/eco.browser.js +88 -0
  102. package/src/eco/eco.js +63 -54
  103. package/src/eco/eco.types.d.ts +69 -6
  104. package/src/eco/eco.utils.d.ts +1 -40
  105. package/src/eco/eco.utils.js +5 -35
  106. package/src/eco/global-injector-map.d.ts +3 -3
  107. package/src/eco/global-injector-map.js +2 -2
  108. package/src/eco/lazy-injector-map.d.ts +2 -2
  109. package/src/errors/index.d.ts +1 -0
  110. package/src/errors/index.js +3 -1
  111. package/src/hmr/README.md +26 -0
  112. package/src/hmr/client/hmr-runtime.d.ts +1 -6
  113. package/src/hmr/client/hmr-runtime.js +38 -7
  114. package/src/hmr/hmr-strategy.d.ts +16 -13
  115. package/src/hmr/hmr-strategy.js +22 -7
  116. package/src/hmr/hmr.postcss.test.e2e.d.ts +1 -0
  117. package/src/hmr/hmr.postcss.test.e2e.js +31 -0
  118. package/src/hmr/hmr.test.e2e.js +26 -33
  119. package/src/hmr/strategies/default-hmr-strategy.d.ts +2 -2
  120. package/src/hmr/strategies/default-hmr-strategy.js +1 -1
  121. package/src/hmr/strategies/js-hmr-strategy.d.ts +40 -42
  122. package/src/hmr/strategies/js-hmr-strategy.js +24 -43
  123. package/src/index.browser.d.ts +2 -2
  124. package/src/index.browser.js +1 -1
  125. package/src/index.d.ts +4 -3
  126. package/src/index.js +16 -5
  127. package/src/integrations/ghtml/ghtml-renderer.d.ts +3 -2
  128. package/src/integrations/ghtml/ghtml-renderer.js +27 -30
  129. package/src/integrations/ghtml/ghtml.constants.d.ts +1 -0
  130. package/src/integrations/ghtml/ghtml.constants.js +4 -0
  131. package/src/integrations/ghtml/ghtml.plugin.d.ts +2 -6
  132. package/src/integrations/ghtml/ghtml.plugin.js +3 -4
  133. package/src/plugins/README.md +35 -0
  134. package/src/plugins/alias-resolver-plugin.d.ts +1 -0
  135. package/src/plugins/alias-resolver-plugin.js +27 -5
  136. package/src/plugins/eco-component-meta-plugin.d.ts +14 -1
  137. package/src/plugins/eco-component-meta-plugin.js +42 -24
  138. package/src/plugins/foreign-jsx-override-plugin.d.ts +33 -0
  139. package/src/plugins/foreign-jsx-override-plugin.js +41 -0
  140. package/src/plugins/integration-plugin.d.ts +157 -29
  141. package/src/plugins/integration-plugin.js +115 -14
  142. package/src/plugins/processor.d.ts +17 -2
  143. package/src/plugins/processor.js +22 -3
  144. package/src/plugins/runtime-capability.d.ts +9 -0
  145. package/src/plugins/source-transform.d.ts +46 -0
  146. package/src/plugins/source-transform.js +71 -0
  147. package/src/route-renderer/GRAPH.md +83 -325
  148. package/src/route-renderer/README.md +73 -90
  149. package/src/route-renderer/orchestration/component-render-context.d.ts +97 -0
  150. package/src/route-renderer/orchestration/component-render-context.js +147 -0
  151. package/src/route-renderer/orchestration/declared-ownership-graph.d.ts +18 -0
  152. package/src/route-renderer/orchestration/declared-ownership-graph.js +34 -0
  153. package/src/route-renderer/orchestration/foreign-subtree-execution.service.d.ts +110 -0
  154. package/src/route-renderer/orchestration/foreign-subtree-execution.service.js +233 -0
  155. package/src/route-renderer/orchestration/integration-renderer.d.ts +534 -0
  156. package/src/route-renderer/orchestration/integration-renderer.js +991 -0
  157. package/src/route-renderer/orchestration/ownership-planning.service.d.ts +24 -0
  158. package/src/route-renderer/orchestration/ownership-planning.service.js +63 -0
  159. package/src/route-renderer/orchestration/ownership-validation.service.d.ts +29 -0
  160. package/src/route-renderer/orchestration/ownership-validation.service.js +53 -0
  161. package/src/route-renderer/orchestration/processed-asset-dedupe.d.ts +3 -0
  162. package/src/route-renderer/orchestration/processed-asset-dedupe.js +27 -0
  163. package/src/route-renderer/orchestration/queued-foreign-subtree-resolution.service.d.ts +91 -0
  164. package/src/route-renderer/orchestration/queued-foreign-subtree-resolution.service.js +170 -0
  165. package/src/route-renderer/orchestration/render-output.utils.d.ts +66 -0
  166. package/src/route-renderer/orchestration/render-output.utils.js +171 -0
  167. package/src/route-renderer/orchestration/route-render-orchestrator.d.ts +156 -0
  168. package/src/route-renderer/orchestration/route-render-orchestrator.js +577 -0
  169. package/src/route-renderer/orchestration/template-serialization.d.ts +38 -0
  170. package/src/route-renderer/orchestration/template-serialization.js +45 -0
  171. package/src/route-renderer/page-loading/component-dependency-collection.d.ts +37 -0
  172. package/src/route-renderer/page-loading/component-dependency-collection.js +132 -0
  173. package/src/route-renderer/page-loading/declared-asset-collection.d.ts +24 -0
  174. package/src/route-renderer/page-loading/declared-asset-collection.js +106 -0
  175. package/src/route-renderer/{dependency-resolver.d.ts → page-loading/dependency-resolver.d.ts} +15 -4
  176. package/src/route-renderer/page-loading/dependency-resolver.js +115 -0
  177. package/src/route-renderer/page-loading/ecopages-virtual-imports.d.ts +11 -0
  178. package/src/route-renderer/page-loading/ecopages-virtual-imports.js +57 -0
  179. package/src/route-renderer/page-loading/lazy-entry-collection.d.ts +45 -0
  180. package/src/route-renderer/page-loading/lazy-entry-collection.js +105 -0
  181. package/src/route-renderer/page-loading/lazy-trigger-planning.d.ts +19 -0
  182. package/src/route-renderer/page-loading/lazy-trigger-planning.js +40 -0
  183. package/src/route-renderer/page-loading/module-declaration-aggregation.d.ts +5 -0
  184. package/src/route-renderer/page-loading/module-declaration-aggregation.js +33 -0
  185. package/src/route-renderer/page-loading/module-declaration-scripts.d.ts +3 -0
  186. package/src/route-renderer/page-loading/module-declaration-scripts.js +18 -0
  187. package/src/route-renderer/page-loading/page-dependency-bundling.d.ts +13 -0
  188. package/src/route-renderer/page-loading/page-dependency-bundling.js +137 -0
  189. package/src/route-renderer/page-loading/page-module-loader.d.ts +90 -0
  190. package/src/route-renderer/{page-module-loader.js → page-loading/page-module-loader.js} +39 -14
  191. package/src/route-renderer/route-renderer.d.ts +57 -14
  192. package/src/route-renderer/route-renderer.js +30 -18
  193. package/src/router/README.md +94 -0
  194. package/src/router/client/link-intent.d.ts +53 -0
  195. package/src/router/client/link-intent.js +34 -0
  196. package/src/router/client/link-intent.test.browser.d.ts +1 -0
  197. package/src/router/client/link-intent.test.browser.js +43 -0
  198. package/src/router/client/navigation-coordinator.d.ts +169 -0
  199. package/src/router/client/navigation-coordinator.js +215 -0
  200. package/src/router/server/route-registry.d.ts +78 -0
  201. package/src/router/server/route-registry.js +262 -0
  202. package/src/services/README.md +28 -0
  203. package/src/services/assets/asset-processing-service/asset-dependency-keys.d.ts +3 -0
  204. package/src/services/assets/asset-processing-service/asset-dependency-keys.js +56 -0
  205. package/src/services/assets/asset-processing-service/asset-processing.service.d.ts +103 -0
  206. package/src/services/{asset-processing-service → assets/asset-processing-service}/asset-processing.service.js +124 -89
  207. package/src/services/{asset-processing-service → assets/asset-processing-service}/asset.factory.d.ts +1 -1
  208. package/src/services/{asset-processing-service → assets/asset-processing-service}/asset.factory.js +2 -2
  209. package/src/services/{asset-processing-service → assets/asset-processing-service}/assets.types.d.ts +16 -1
  210. package/src/services/assets/asset-processing-service/assets.types.js +0 -0
  211. package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.d.ts +57 -0
  212. package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.js +49 -0
  213. package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.d.ts +20 -0
  214. package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.js +41 -0
  215. package/src/services/assets/asset-processing-service/grouped-content-bundles.d.ts +30 -0
  216. package/src/services/assets/asset-processing-service/grouped-content-bundles.js +65 -0
  217. package/src/services/assets/asset-processing-service/index.d.ts +6 -0
  218. package/src/services/assets/asset-processing-service/index.js +6 -0
  219. package/src/services/assets/asset-processing-service/page-package.d.ts +6 -0
  220. package/src/services/assets/asset-processing-service/page-package.js +80 -0
  221. package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.interface.d.ts +2 -2
  222. package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.registry.d.ts +2 -2
  223. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/base/base-processor.d.ts +1 -1
  224. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/base/base-processor.js +11 -5
  225. package/src/services/assets/asset-processing-service/processors/base/base-script-processor.d.ts +22 -0
  226. package/src/services/assets/asset-processing-service/processors/base/base-script-processor.js +136 -0
  227. package/src/services/assets/asset-processing-service/processors/index.d.ts +5 -0
  228. package/src/services/assets/asset-processing-service/processors/index.js +5 -0
  229. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/content-script.processor.d.ts +3 -2
  230. package/src/services/assets/asset-processing-service/processors/script/content-script.processor.js +120 -0
  231. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/file-script.processor.d.ts +4 -3
  232. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/file-script.processor.js +28 -7
  233. package/src/services/assets/asset-processing-service/processors/script/node-module-script.processor.d.ts +42 -0
  234. package/src/services/assets/asset-processing-service/processors/script/node-module-script.processor.js +126 -0
  235. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/content-stylesheet.processor.d.ts +5 -2
  236. package/src/services/assets/asset-processing-service/processors/stylesheet/content-stylesheet.processor.js +59 -0
  237. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/file-stylesheet.processor.d.ts +2 -2
  238. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/file-stylesheet.processor.js +9 -3
  239. package/src/services/assets/asset-processing-service/ungrouped-dependency-processing.d.ts +18 -0
  240. package/src/services/assets/asset-processing-service/ungrouped-dependency-processing.js +45 -0
  241. package/src/services/assets/browser-bundle.service.d.ts +73 -0
  242. package/src/services/assets/browser-bundle.service.js +41 -0
  243. package/src/services/{page-request-cache-coordinator.service.d.ts → cache/page-request-cache-coordinator.service.d.ts} +2 -2
  244. package/src/services/{page-request-cache-coordinator.service.js → cache/page-request-cache-coordinator.service.js} +3 -1
  245. package/src/services/html/html-rewriter-provider.service.d.ts +40 -0
  246. package/src/services/html/html-rewriter-provider.service.js +68 -0
  247. package/src/services/html/html-transformer.service.d.ts +96 -0
  248. package/src/services/html/html-transformer.service.js +287 -0
  249. package/src/services/invalidation/development-invalidation.service.d.ts +74 -0
  250. package/src/services/invalidation/development-invalidation.service.js +190 -0
  251. package/src/services/module-loading/app-module-loader.service.d.ts +7 -0
  252. package/src/services/module-loading/app-module-loader.service.js +0 -0
  253. package/src/services/module-loading/app-server-module-transpiler.service.d.ts +24 -0
  254. package/src/services/module-loading/app-server-module-transpiler.service.js +151 -0
  255. package/src/services/module-loading/host-module-loader-registry.d.ts +4 -0
  256. package/src/services/module-loading/host-module-loader-registry.js +15 -0
  257. package/src/services/module-loading/module-loading-types.d.ts +2 -0
  258. package/src/services/module-loading/module-loading-types.js +0 -0
  259. package/src/services/module-loading/node-bootstrap-plugin.d.ts +38 -0
  260. package/src/services/module-loading/node-bootstrap-plugin.js +215 -0
  261. package/src/services/module-loading/page-module-import.service.d.ts +95 -0
  262. package/src/services/module-loading/page-module-import.service.js +191 -0
  263. package/src/services/module-loading/server-module-transpiler.service.d.ts +63 -0
  264. package/src/services/module-loading/server-module-transpiler.service.js +64 -0
  265. package/src/services/module-loading/source-module-support.d.ts +5 -0
  266. package/src/services/module-loading/source-module-support.js +8 -0
  267. package/src/services/runtime-state/dev-graph.service.d.ts +118 -0
  268. package/src/services/runtime-state/dev-graph.service.js +162 -0
  269. package/src/services/runtime-state/entrypoint-dependency-graph.service.d.ts +41 -0
  270. package/src/services/runtime-state/entrypoint-dependency-graph.service.js +85 -0
  271. package/src/services/runtime-state/server-invalidation-state.service.d.ts +26 -0
  272. package/src/services/runtime-state/server-invalidation-state.service.js +35 -0
  273. package/src/services/{schema-validation-service.d.ts → validation/schema-validation-service.d.ts} +1 -1
  274. package/src/static-site-generator/README.md +26 -0
  275. package/src/static-site-generator/static-site-generator.d.ts +67 -20
  276. package/src/static-site-generator/static-site-generator.js +182 -138
  277. package/src/{internal-types.d.ts → types/internal-types.d.ts} +62 -30
  278. package/src/types/internal-types.js +0 -0
  279. package/src/{public-types.d.ts → types/public-types.d.ts} +239 -31
  280. package/src/types/public-types.js +0 -0
  281. package/src/utils/html-escaping.d.ts +7 -0
  282. package/src/utils/html-escaping.js +6 -0
  283. package/src/utils/locals-utils.d.ts +1 -1
  284. package/src/utils/parse-cli-args.d.ts +4 -1
  285. package/src/utils/parse-cli-args.js +16 -1
  286. package/src/utils/resolve-work-dir.d.ts +11 -0
  287. package/src/utils/resolve-work-dir.js +31 -0
  288. package/src/watchers/project-watcher.d.ts +11 -7
  289. package/src/watchers/project-watcher.js +69 -75
  290. package/src/watchers/project-watcher.test-helpers.d.ts +2 -2
  291. package/src/watchers/project-watcher.test-helpers.js +6 -5
  292. package/CHANGELOG.md +0 -94
  293. package/src/adapters/abstract/application-adapter.ts +0 -337
  294. package/src/adapters/abstract/router-adapter.ts +0 -30
  295. package/src/adapters/abstract/server-adapter.ts +0 -79
  296. package/src/adapters/bun/client-bridge.ts +0 -62
  297. package/src/adapters/bun/create-app.ts +0 -189
  298. package/src/adapters/bun/define-api-handler.d.ts +0 -61
  299. package/src/adapters/bun/define-api-handler.ts +0 -114
  300. package/src/adapters/bun/hmr-manager.ts +0 -276
  301. package/src/adapters/bun/index.ts +0 -3
  302. package/src/adapters/bun/server-adapter.ts +0 -492
  303. package/src/adapters/bun/server-lifecycle.d.ts +0 -52
  304. package/src/adapters/bun/server-lifecycle.js +0 -120
  305. package/src/adapters/bun/server-lifecycle.ts +0 -154
  306. package/src/adapters/index.ts +0 -6
  307. package/src/adapters/node/create-app.ts +0 -179
  308. package/src/adapters/node/index.d.ts +0 -4
  309. package/src/adapters/node/index.js +0 -8
  310. package/src/adapters/node/index.ts +0 -9
  311. package/src/adapters/node/node-client-bridge.ts +0 -79
  312. package/src/adapters/node/node-hmr-manager.ts +0 -271
  313. package/src/adapters/node/server-adapter.ts +0 -561
  314. package/src/adapters/node/static-content-server.ts +0 -203
  315. package/src/adapters/shared/api-response.ts +0 -104
  316. package/src/adapters/shared/application-adapter.ts +0 -199
  317. package/src/adapters/shared/explicit-static-route-matcher.ts +0 -134
  318. package/src/adapters/shared/file-route-middleware-pipeline.ts +0 -123
  319. package/src/adapters/shared/fs-server-response-factory.ts +0 -118
  320. package/src/adapters/shared/fs-server-response-matcher.ts +0 -198
  321. package/src/adapters/shared/render-context.ts +0 -105
  322. package/src/adapters/shared/server-adapter.ts +0 -442
  323. package/src/adapters/shared/server-route-handler.ts +0 -166
  324. package/src/adapters/shared/server-static-builder.ts +0 -82
  325. package/src/build/build-adapter.ts +0 -133
  326. package/src/build/build-types.ts +0 -83
  327. package/src/build/esbuild-build-adapter.ts +0 -511
  328. package/src/config/config-builder.ts +0 -474
  329. package/src/constants.ts +0 -39
  330. package/src/create-app.ts +0 -87
  331. package/src/define-api-handler.js +0 -15
  332. package/src/define-api-handler.ts +0 -66
  333. package/src/dev/sc-server.ts +0 -143
  334. package/src/eco/component-render-context.d.ts +0 -105
  335. package/src/eco/component-render-context.js +0 -77
  336. package/src/eco/component-render-context.ts +0 -202
  337. package/src/eco/eco.ts +0 -221
  338. package/src/eco/eco.types.ts +0 -202
  339. package/src/eco/eco.utils.ts +0 -89
  340. package/src/eco/global-injector-map.ts +0 -112
  341. package/src/eco/lazy-injector-map.ts +0 -120
  342. package/src/eco/module-dependencies.ts +0 -75
  343. package/src/errors/http-error.ts +0 -72
  344. package/src/errors/index.ts +0 -2
  345. package/src/errors/locals-access-error.ts +0 -7
  346. package/src/global/app-logger.ts +0 -4
  347. package/src/hmr/client/hmr-runtime.ts +0 -121
  348. package/src/hmr/hmr-strategy.ts +0 -172
  349. package/src/hmr/hmr.test.e2e.ts +0 -75
  350. package/src/hmr/strategies/default-hmr-strategy.ts +0 -60
  351. package/src/hmr/strategies/js-hmr-strategy.ts +0 -327
  352. package/src/index.browser.ts +0 -3
  353. package/src/index.ts +0 -5
  354. package/src/integrations/ghtml/ghtml-renderer.ts +0 -93
  355. package/src/integrations/ghtml/ghtml.plugin.ts +0 -32
  356. package/src/internal-types.ts +0 -212
  357. package/src/plugins/alias-resolver-plugin.ts +0 -45
  358. package/src/plugins/eco-component-meta-plugin.ts +0 -474
  359. package/src/plugins/integration-plugin.ts +0 -184
  360. package/src/plugins/processor.ts +0 -220
  361. package/src/public-types.ts +0 -1255
  362. package/src/route-renderer/component-graph-executor.d.ts +0 -32
  363. package/src/route-renderer/component-graph-executor.js +0 -31
  364. package/src/route-renderer/component-graph-executor.ts +0 -84
  365. package/src/route-renderer/component-graph.d.ts +0 -42
  366. package/src/route-renderer/component-graph.js +0 -72
  367. package/src/route-renderer/component-graph.ts +0 -159
  368. package/src/route-renderer/component-marker.d.ts +0 -52
  369. package/src/route-renderer/component-marker.js +0 -46
  370. package/src/route-renderer/component-marker.ts +0 -117
  371. package/src/route-renderer/dependency-resolver.js +0 -428
  372. package/src/route-renderer/dependency-resolver.ts +0 -596
  373. package/src/route-renderer/html-post-processing.service.d.ts +0 -40
  374. package/src/route-renderer/html-post-processing.service.js +0 -86
  375. package/src/route-renderer/html-post-processing.service.ts +0 -103
  376. package/src/route-renderer/integration-renderer.d.ts +0 -339
  377. package/src/route-renderer/integration-renderer.js +0 -526
  378. package/src/route-renderer/integration-renderer.ts +0 -696
  379. package/src/route-renderer/marker-graph-resolver.d.ts +0 -76
  380. package/src/route-renderer/marker-graph-resolver.js +0 -93
  381. package/src/route-renderer/marker-graph-resolver.ts +0 -153
  382. package/src/route-renderer/page-module-loader.d.ts +0 -61
  383. package/src/route-renderer/page-module-loader.ts +0 -153
  384. package/src/route-renderer/render-execution.service.d.ts +0 -69
  385. package/src/route-renderer/render-execution.service.js +0 -91
  386. package/src/route-renderer/render-execution.service.ts +0 -158
  387. package/src/route-renderer/render-preparation.service.d.ts +0 -112
  388. package/src/route-renderer/render-preparation.service.js +0 -243
  389. package/src/route-renderer/render-preparation.service.ts +0 -358
  390. package/src/route-renderer/route-renderer.ts +0 -80
  391. package/src/router/fs-router-scanner.d.ts +0 -41
  392. package/src/router/fs-router-scanner.js +0 -155
  393. package/src/router/fs-router-scanner.ts +0 -217
  394. package/src/router/fs-router.d.ts +0 -26
  395. package/src/router/fs-router.js +0 -100
  396. package/src/router/fs-router.ts +0 -122
  397. package/src/services/asset-processing-service/asset-processing.service.d.ts +0 -41
  398. package/src/services/asset-processing-service/asset-processing.service.ts +0 -306
  399. package/src/services/asset-processing-service/asset.factory.ts +0 -105
  400. package/src/services/asset-processing-service/assets.types.ts +0 -112
  401. package/src/services/asset-processing-service/index.d.ts +0 -3
  402. package/src/services/asset-processing-service/index.js +0 -3
  403. package/src/services/asset-processing-service/index.ts +0 -3
  404. package/src/services/asset-processing-service/processor.interface.ts +0 -27
  405. package/src/services/asset-processing-service/processor.registry.ts +0 -18
  406. package/src/services/asset-processing-service/processors/base/base-processor.ts +0 -76
  407. package/src/services/asset-processing-service/processors/base/base-script-processor.d.ts +0 -16
  408. package/src/services/asset-processing-service/processors/base/base-script-processor.js +0 -80
  409. package/src/services/asset-processing-service/processors/base/base-script-processor.ts +0 -105
  410. package/src/services/asset-processing-service/processors/index.d.ts +0 -5
  411. package/src/services/asset-processing-service/processors/index.js +0 -5
  412. package/src/services/asset-processing-service/processors/index.ts +0 -5
  413. package/src/services/asset-processing-service/processors/script/content-script.processor.js +0 -57
  414. package/src/services/asset-processing-service/processors/script/content-script.processor.ts +0 -66
  415. package/src/services/asset-processing-service/processors/script/file-script.processor.ts +0 -88
  416. package/src/services/asset-processing-service/processors/script/node-module-script.processor.d.ts +0 -7
  417. package/src/services/asset-processing-service/processors/script/node-module-script.processor.js +0 -74
  418. package/src/services/asset-processing-service/processors/script/node-module-script.processor.ts +0 -84
  419. package/src/services/asset-processing-service/processors/stylesheet/content-stylesheet.processor.js +0 -25
  420. package/src/services/asset-processing-service/processors/stylesheet/content-stylesheet.processor.ts +0 -27
  421. package/src/services/asset-processing-service/processors/stylesheet/file-stylesheet.processor.ts +0 -77
  422. package/src/services/cache/cache.types.ts +0 -126
  423. package/src/services/cache/index.ts +0 -18
  424. package/src/services/cache/memory-cache-store.ts +0 -130
  425. package/src/services/cache/page-cache-service.ts +0 -202
  426. package/src/services/html-transformer.service.d.ts +0 -50
  427. package/src/services/html-transformer.service.js +0 -163
  428. package/src/services/html-transformer.service.ts +0 -217
  429. package/src/services/page-module-import.service.d.ts +0 -37
  430. package/src/services/page-module-import.service.js +0 -88
  431. package/src/services/page-module-import.service.ts +0 -129
  432. package/src/services/page-request-cache-coordinator.service.ts +0 -128
  433. package/src/services/schema-validation-service.ts +0 -204
  434. package/src/services/validation/standard-schema.types.ts +0 -68
  435. package/src/static-site-generator/static-site-generator.ts +0 -359
  436. package/src/utils/css.d.ts +0 -1
  437. package/src/utils/css.js +0 -7
  438. package/src/utils/css.ts +0 -5
  439. package/src/utils/deep-merge.ts +0 -47
  440. package/src/utils/hash.ts +0 -5
  441. package/src/utils/html.ts +0 -1
  442. package/src/utils/invariant.ts +0 -15
  443. package/src/utils/locals-utils.ts +0 -37
  444. package/src/utils/parse-cli-args.ts +0 -83
  445. package/src/utils/path-utils.module.ts +0 -14
  446. package/src/utils/runtime.ts +0 -44
  447. package/src/utils/server-utils.module.ts +0 -67
  448. package/src/watchers/project-watcher.test-helpers.ts +0 -40
  449. package/src/watchers/project-watcher.ts +0 -364
  450. /package/src/adapters/{bun → shared}/define-api-handler.js +0 -0
  451. /package/src/{internal-types.js → adapters/shared/runtime-host.js} +0 -0
  452. /package/src/{public-types.js → adapters/shared/static-preview-host.js} +0 -0
  453. /package/src/{services/asset-processing-service/assets.types.js → plugins/runtime-capability.js} +0 -0
  454. /package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.interface.js +0 -0
  455. /package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.registry.js +0 -0
  456. /package/src/services/{schema-validation-service.js → validation/schema-validation-service.js} +0 -0
@@ -1,561 +0,0 @@
1
- import { createServer, type IncomingMessage, type Server as NodeHttpServer, type ServerResponse } from 'node:http';
2
- import path from 'node:path';
3
- import { fileSystem } from '@ecopages/file-system';
4
- import { RESOLVED_ASSETS_DIR } from '../../constants.ts';
5
- import { defaultBuildAdapter } from '../../build/build-adapter.ts';
6
- import type { EcoBuildPlugin } from '../../build/build-types.ts';
7
- import { appLogger } from '../../global/app-logger.ts';
8
- import type { EcoPagesAppConfig } from '../../internal-types.ts';
9
- import { ProjectWatcher } from '../../watchers/project-watcher.ts';
10
- import { NodeClientBridge } from './node-client-bridge.ts';
11
- import { NodeHmrManager } from './node-hmr-manager.ts';
12
- import type { ApiHandler, ErrorHandler, StaticRoute } from '../../public-types.ts';
13
-
14
- import { StaticSiteGenerator } from '../../static-site-generator/static-site-generator.ts';
15
- import { SharedServerAdapter } from '../shared/server-adapter.ts';
16
- import type { ServerAdapterResult } from '../abstract/server-adapter.ts';
17
- import { ServerStaticBuilder } from '../shared/server-static-builder.ts';
18
-
19
- import { NodeStaticContentServer } from './static-content-server.ts';
20
-
21
- /**
22
- * Sentinel error thrown when the client closes the connection before the
23
- * request body is fully consumed (killed tab, ECONNRESET, cancelled upload).
24
- * Caught by `handleRequest` to return 499 instead of 500.
25
- */
26
- class ClientAbortError extends Error {
27
- constructor() {
28
- super('Client closed the request');
29
- this.name = 'ClientAbortError';
30
- }
31
- }
32
-
33
- export type NodeServerInstance = NodeHttpServer;
34
- export type NodeServeAdapterServerOptions = {
35
- port?: number;
36
- hostname?: string;
37
- [key: string]: unknown;
38
- };
39
-
40
- export interface NodeServerAdapterParams {
41
- appConfig: EcoPagesAppConfig;
42
- runtimeOrigin: string;
43
- serveOptions: NodeServeAdapterServerOptions;
44
- apiHandlers?: ApiHandler[];
45
- staticRoutes?: StaticRoute[];
46
- errorHandler?: ErrorHandler;
47
- options?: {
48
- watch?: boolean;
49
- };
50
- }
51
-
52
- export interface NodeServerAdapterResult extends ServerAdapterResult {
53
- completeInitialization: (server: NodeServerInstance) => Promise<void>;
54
- handleRequest: (request: Request) => Promise<Response>;
55
- }
56
-
57
- /**
58
- * Node.js HTTP server adapter for the Ecopages runtime.
59
- *
60
- * `NodeServerAdapter` bridges the Node.js `http` module and the Ecopages
61
- * `SharedServerAdapter` abstraction, translating between Node's
62
- * `IncomingMessage`/`ServerResponse` API and the platform-agnostic Web
63
- * `Request`/`Response` model.
64
- *
65
- * Lifecycle:
66
- * 1. `createAdapter()` — calls `initialize()` and returns the public adapter result.
67
- * 2. `completeInitialization(server)` — called once the HTTP server is listening.
68
- * Conditionally wires HMR, WebSocket upgrades, and the file watcher when
69
- * `options.watch` is `true`.
70
- * 3. `handleRequest(request)` — delegates to `handleSharedRequest` for routing;
71
- * intercepts `ClientAbortError` to return 499 instead of 500.
72
- * 4. `buildStatic()` — spins up an ephemeral runtime server, generates all static
73
- * pages against it, then tears it down.
74
- *
75
- * @see SharedServerAdapter for routing, caching and response handler logic.
76
- */
77
- export class NodeServerAdapter extends SharedServerAdapter<NodeServerAdapterParams, NodeServerAdapterResult> {
78
- private serverInstance: NodeServerInstance | null = null;
79
- private initialized = false;
80
- private apiHandlers: ApiHandler[];
81
- private staticRoutes: StaticRoute[];
82
- private errorHandler?: ErrorHandler;
83
- private previewServer: NodeStaticContentServer | null = null;
84
- private bridge: NodeClientBridge | null = null;
85
- private hmrManager: NodeHmrManager | null = null;
86
- private processorBuildPlugins: EcoBuildPlugin[] = [];
87
-
88
- constructor(options: NodeServerAdapterParams) {
89
- super(options);
90
- this.apiHandlers = options.apiHandlers || [];
91
- this.staticRoutes = options.staticRoutes || [];
92
- this.errorHandler = options.errorHandler;
93
- }
94
-
95
- /**
96
- * Prepares the adapter for use.
97
- *
98
- * Order is intentional:
99
- * 1. **Loaders** are registered first so processors and integrations can
100
- * reference loader-provided file types in their own plugins.
101
- * 2. **Public dir** is copied before any build so static assets are in `distDir`
102
- * before the first request arrives.
103
- * 3. **Plugins** (processors, then integrations) are set up after the public dir
104
- * is in place so they can safely reference dist-relative paths.
105
- * 4. **Router** is initialised last because it may depend on files written by
106
- * processors during their `setup()` calls.
107
- */
108
- public async initialize(): Promise<void> {
109
- this.setupLoaders();
110
- this.copyPublicDir();
111
- await this.initializePlugins();
112
- await this.initSharedRouter();
113
- this.configureSharedResponseHandlers(this.staticRoutes, this.hmrManager ?? undefined);
114
- this.staticSiteGenerator = new StaticSiteGenerator({ appConfig: this.appConfig });
115
- this.staticBuilder = new ServerStaticBuilder({
116
- appConfig: this.appConfig,
117
- staticSiteGenerator: this.staticSiteGenerator,
118
- serveOptions: this.serveOptions,
119
- });
120
- this.initialized = true;
121
- }
122
-
123
- /**
124
- * Registers every configured file loader as a build plugin on the shared
125
- * `defaultBuildAdapter`.
126
- *
127
- * Loaders are registered on the *shared* adapter (not on a per-build instance)
128
- * because they must be available globally to both the SSR build and any dynamic
129
- * transpile passes that happen outside of a top-level `build()` call (e.g. HMR
130
- * incremental rebuilds).
131
- */
132
- private setupLoaders(): void {
133
- for (const loader of this.appConfig.loaders.values()) {
134
- defaultBuildAdapter.registerPlugin(loader);
135
- }
136
- }
137
-
138
- private copyPublicDir(): void {
139
- const srcPublicDir = path.join(this.appConfig.rootDir, this.appConfig.srcDir, this.appConfig.publicDir);
140
-
141
- if (fileSystem.exists(srcPublicDir)) {
142
- fileSystem.copyDir(srcPublicDir, path.join(this.appConfig.rootDir, this.appConfig.distDir));
143
- }
144
-
145
- fileSystem.ensureDir(path.join(this.appConfig.absolutePaths.distDir, RESOLVED_ASSETS_DIR));
146
- }
147
-
148
- /**
149
- * Sets up all configured processors and integrations in two distinct phases.
150
- *
151
- * **Phase 1 — Processors:**
152
- * Each processor's `setup()` is called first. A processor may expose two
153
- * plugin lists:
154
- * - `plugins` — transform plugins used during SSR rendering (e.g. PostCSS).
155
- * - `buildPlugins` — esbuild plugins used during the client bundle step.
156
- * Both are registered on `defaultBuildAdapter` so later build calls pick them up.
157
- *
158
- * **Phase 2 — Integrations:**
159
- * Integrations receive the fully-resolved app config, the runtime origin, and
160
- * (if already initialised) the HMR manager before their own `setup()` is called.
161
- * This ordering ensures integrations can query config values that processors
162
- * may have mutated during phase 1.
163
- */
164
- private async initializePlugins(): Promise<void> {
165
- const processorBuildPlugins: EcoBuildPlugin[] = [];
166
-
167
- for (const processor of this.appConfig.processors.values()) {
168
- await processor.setup();
169
-
170
- if (processor.plugins) {
171
- for (const plugin of processor.plugins) {
172
- defaultBuildAdapter.registerPlugin(plugin);
173
- }
174
- }
175
- if (processor.buildPlugins) {
176
- processorBuildPlugins.push(...processor.buildPlugins);
177
- for (const plugin of processor.buildPlugins) {
178
- defaultBuildAdapter.registerPlugin(plugin);
179
- }
180
- }
181
- }
182
-
183
- for (const integration of this.appConfig.integrations) {
184
- integration.setConfig(this.appConfig);
185
- integration.setRuntimeOrigin(this.runtimeOrigin);
186
- if (this.hmrManager) {
187
- integration.setHmrManager(this.hmrManager);
188
- }
189
- await integration.setup();
190
-
191
- for (const plugin of integration.plugins) {
192
- defaultBuildAdapter.registerPlugin(plugin);
193
- }
194
- }
195
-
196
- this.processorBuildPlugins = processorBuildPlugins;
197
- }
198
-
199
- public getServerOptions(): NodeServeAdapterServerOptions {
200
- return {
201
- ...this.serveOptions,
202
- };
203
- }
204
-
205
- public async buildStatic(options?: { preview?: boolean }): Promise<void> {
206
- if (!this.initialized) {
207
- await this.initialize();
208
- }
209
-
210
- const buildServer = await this.startBuildRuntimeServer();
211
-
212
- try {
213
- await this.staticBuilder.build(
214
- { preview: false },
215
- {
216
- router: this.router,
217
- routeRendererFactory: this.routeRendererFactory,
218
- staticRoutes: this.staticRoutes,
219
- },
220
- );
221
- } finally {
222
- await this.stopBuildRuntimeServer(buildServer);
223
- }
224
-
225
- if (!options?.preview) {
226
- return;
227
- }
228
-
229
- if (this.previewServer) {
230
- await this.previewServer.stop();
231
- }
232
-
233
- this.previewServer = new NodeStaticContentServer({
234
- appConfig: this.appConfig,
235
- options: {
236
- hostname: this.serveOptions.hostname,
237
- port: Number(this.serveOptions.port || 3000),
238
- },
239
- });
240
-
241
- await this.previewServer.start();
242
- const previewHostname = this.serveOptions.hostname || 'localhost';
243
- const previewPort = this.serveOptions.port || 3000;
244
- appLogger.info(`Preview running at http://${previewHostname}:${previewPort}`);
245
- }
246
-
247
- /**
248
- * Converts a Node.js `IncomingMessage` into a Web API `Request`.
249
- *
250
- * Multi-value headers (e.g. `set-cookie`) are appended individually so no
251
- * value is silently dropped.
252
- *
253
- * For methods that carry a body (`POST`, `PUT`, `PATCH`, …), the raw
254
- * `IncomingMessage` stream is wrapped in a `ReadableStream` rather than
255
- * cast directly to `BodyInit`. See the inline doc block inside the `if`
256
- * branch for the rationale (client-abort handling).
257
- *
258
- * `duplex: 'half'` is required by the `fetch` spec when a streaming body is
259
- * provided — without it Node.js 18+ throws a `TypeError`.
260
- */
261
- private createWebRequest(req: IncomingMessage): Request {
262
- const url = new URL(req.url ?? '/', this.runtimeOrigin);
263
- const headers = new Headers();
264
-
265
- for (const [key, value] of Object.entries(req.headers)) {
266
- if (Array.isArray(value)) {
267
- for (const item of value) {
268
- headers.append(key, item);
269
- }
270
- continue;
271
- }
272
-
273
- if (value !== undefined) {
274
- headers.set(key, value);
275
- }
276
- }
277
-
278
- const method = (req.method ?? 'GET').toUpperCase();
279
- const requestInit: RequestInit & { duplex?: 'half' } = {
280
- method,
281
- headers,
282
- };
283
-
284
- if (method !== 'GET' && method !== 'HEAD') {
285
- /**
286
- * Wrap the IncomingMessage in a ReadableStream so we can intercept
287
- * mid-stream client aborts (killed tab, network drop, cancelled upload).
288
- *
289
- * Without this, Node.js emits 'aborted'/'error' on the raw stream *after*
290
- * the Request body is already being consumed, causing the error to bubble
291
- * up as a generic 500 Internal Server Error with noise in the logs.
292
- *
293
- * The ReadableStream controller.error() triggers a stream-level rejection
294
- * which propagates as a ClientAbortError. The `handleRequest` catch block
295
- * detects it and returns 499 (Client Closed Request) silently instead.
296
- */
297
- const body = new ReadableStream({
298
- start(controller) {
299
- req.on('data', (chunk: Buffer) => controller.enqueue(chunk));
300
- req.once('end', () => controller.close());
301
- req.once('aborted', () => {
302
- controller.error(new ClientAbortError());
303
- });
304
- req.once('error', (err) => {
305
- const isClientAbort = (err as NodeJS.ErrnoException).code === 'ECONNRESET';
306
- controller.error(isClientAbort ? new ClientAbortError() : err);
307
- });
308
- },
309
- cancel() {
310
- /**
311
- * Client cancelled the stream mid-transfer (e.g. back button, fetch abort).
312
- * Destroy the underlying socket so Node.js releases the file descriptor
313
- * immediately rather than waiting for TCP keepalive to time out.
314
- */
315
- req.destroy();
316
- },
317
- });
318
-
319
- requestInit.body = body;
320
- requestInit.duplex = 'half';
321
- }
322
-
323
- return new Request(url, requestInit);
324
- }
325
-
326
- /**
327
- * Writes a Web `Response` back to a Node.js `ServerResponse`.
328
- *
329
- * The entire body is buffered via `arrayBuffer()` before writing. This is
330
- * intentional for the current use-case (SSR pages and API routes), where
331
- * responses are typically small and fully materialised. Streaming responses
332
- * are not yet supported.
333
- */
334
- private async sendNodeResponse(res: ServerResponse, response: Response): Promise<void> {
335
- res.statusCode = response.status;
336
-
337
- response.headers.forEach((value, key) => {
338
- res.setHeader(key, value);
339
- });
340
-
341
- if (!response.body) {
342
- res.end();
343
- return;
344
- }
345
-
346
- const body = Buffer.from(await response.arrayBuffer());
347
- res.end(body);
348
- }
349
-
350
- /**
351
- * Starts an ephemeral HTTP server used *only* during a static site generation
352
- * run.
353
- *
354
- * Static generation works by having the `StaticSiteGenerator` issue real HTTP
355
- * requests to a live server for each route, capturing the rendered HTML. This
356
- * approach reuses the normal request pipeline (middleware, caching, API
357
- * handlers) without any special-casing for the build path.
358
- *
359
- * The server is torn down immediately after generation completes via
360
- * `stopBuildRuntimeServer`, so it never overlaps with the actual dev/prod server.
361
- */
362
- private async startBuildRuntimeServer(): Promise<NodeHttpServer> {
363
- const hostname = String(this.serveOptions.hostname || 'localhost');
364
- const port = Number(this.serveOptions.port || 3000);
365
-
366
- const server = createServer(async (req, res) => {
367
- try {
368
- const webRequest = this.createWebRequest(req);
369
- const response = await this.handleRequest(webRequest);
370
- await this.sendNodeResponse(res, response);
371
- } catch (error) {
372
- appLogger.error('Node static build runtime request failed', error as Error);
373
- res.statusCode = 500;
374
- res.end('Internal Server Error');
375
- }
376
- });
377
-
378
- await new Promise<void>((resolve, reject) => {
379
- server.once('error', reject);
380
- server.listen(port, hostname, () => {
381
- server.off('error', reject);
382
- resolve();
383
- });
384
- });
385
-
386
- this.serverInstance = server;
387
- appLogger.info(`Server running at http://${hostname}:${port}`);
388
-
389
- return server;
390
- }
391
-
392
- /**
393
- * Gracefully shuts down the ephemeral build runtime server.
394
- *
395
- * `closeAllConnections()` is called *before* `close()` because `server.close()`
396
- * only stops accepting new connections — it waits for existing keep-alive
397
- * connections to finish naturally, which can stall the build indefinitely.
398
- * `closeAllConnections()` force-closes any lingering sockets immediately so
399
- * the `close()` callback fires promptly.
400
- *
401
- * The `NodeClientBridge` heartbeat is also destroyed here so its `setInterval`
402
- * does not prevent the Node.js process from exiting cleanly after the build.
403
- */
404
- private async stopBuildRuntimeServer(server: NodeHttpServer): Promise<void> {
405
- await new Promise<void>((resolve, reject) => {
406
- server.close((error) => {
407
- if (error) {
408
- reject(error);
409
- return;
410
- }
411
-
412
- resolve();
413
- });
414
- server.closeAllConnections();
415
- });
416
-
417
- if (this.serverInstance === server) {
418
- this.serverInstance = null;
419
- }
420
-
421
- this.bridge?.destroy();
422
- this.bridge = null;
423
- }
424
-
425
- public async createAdapter(): Promise<NodeServerAdapterResult> {
426
- await this.initialize();
427
-
428
- return {
429
- getServerOptions: this.getServerOptions.bind(this),
430
- buildStatic: this.buildStatic.bind(this),
431
- completeInitialization: this.completeInitialization.bind(this),
432
- handleRequest: this.handleRequest.bind(this),
433
- };
434
- }
435
-
436
- /**
437
- * Handles a single incoming Web `Request` and returns a Web `Response`.
438
- *
439
- * Delegates to `handleSharedRequest` for all routing, caching, and response
440
- * handler logic. The only Node-specific concern here is translating a
441
- * `ClientAbortError` — which the body `ReadableStream` raises when the
442
- * underlying socket closes early — into a 499 response so it does not
443
- * incorrectly surface as a 500 in application logs.
444
- */
445
- public async handleRequest(_request: Request): Promise<Response> {
446
- if (!this.initialized) {
447
- throw new Error('Node server adapter is not initialized. Call createAdapter() first.');
448
- }
449
-
450
- try {
451
- return await this.handleSharedRequest(_request, {
452
- apiHandlers: this.apiHandlers,
453
- errorHandler: this.errorHandler,
454
- serverInstance: this.serverInstance,
455
- hmrManager: this.hmrManager,
456
- });
457
- } catch (error) {
458
- if (error instanceof ClientAbortError) {
459
- /**
460
- * The client disconnected before the response was sent (killed tab,
461
- * network drop, or programmatic abort). This is a normal browser behaviour,
462
- * not a server fault. Return 499 (Client Closed Request) silently so the
463
- * error does not surface in application logs as a 500.
464
- */
465
- return new Response(null, { status: 499 });
466
- }
467
- throw error;
468
- }
469
- }
470
-
471
- /**
472
- * Called once the HTTP server is bound and listening.
473
- *
474
- * When `options.watch` is `true` this method wires the full HMR pipeline:
475
- * - A `WebSocketServer` is attached to the existing HTTP server via the
476
- * `upgrade` event (no separate port needed).
477
- * - `NodeClientBridge` tracks active WebSocket connections and handles
478
- * broadcast + heartbeat cleanup.
479
- * - `NodeHmrManager` watches the filesystem and triggers incremental esbuild
480
- * rebuilds, notifying connected clients via the bridge.
481
- * - `ProjectWatcher` listens for route-level file changes and refreshes the
482
- * router and response handlers when pages are added or removed.
483
- *
484
- * WebSocket upgrade requests that do not target `/_hmr` are rejected with an
485
- * immediate socket destroy to prevent unhandled upgrade leaks.
486
- */
487
- public async completeInitialization(_server: NodeServerInstance): Promise<void> {
488
- this.serverInstance = _server;
489
-
490
- if (this.options?.watch) {
491
- const { WebSocketServer } = await import('ws');
492
- const wss = new WebSocketServer({ noServer: true });
493
- this.bridge = new NodeClientBridge();
494
- this.hmrManager = new NodeHmrManager({ appConfig: this.appConfig, bridge: this.bridge });
495
- this.hmrManager.setEnabled(true);
496
-
497
- await this.hmrManager.buildRuntime();
498
-
499
- _server.on('upgrade', (req, socket, head) => {
500
- const url = new URL(req.url ?? '/', this.runtimeOrigin);
501
- if (url.pathname === '/_hmr') {
502
- wss.handleUpgrade(req, socket, head, (ws) => {
503
- this.bridge!.subscribe(ws);
504
- ws.on('close', () => this.bridge!.unsubscribe(ws));
505
- ws.on('error', (err) => appLogger.error('[HMR] WebSocket error:', err));
506
- });
507
- } else {
508
- socket.destroy();
509
- }
510
- });
511
-
512
- const loaderPlugins = Array.from(this.appConfig.loaders.values());
513
- const hmrBuildPlugins = [...loaderPlugins, ...this.processorBuildPlugins];
514
- this.hmrManager.setPlugins(hmrBuildPlugins);
515
-
516
- for (const integration of this.appConfig.integrations) {
517
- integration.setHmrManager(this.hmrManager);
518
- }
519
-
520
- this.configureSharedResponseHandlers(this.staticRoutes, this.hmrManager);
521
-
522
- const watcher = new ProjectWatcher({
523
- config: this.appConfig,
524
- refreshRouterRoutesCallback: async () => {
525
- await this.initSharedRouter();
526
- this.configureSharedResponseHandlers(this.staticRoutes, this.hmrManager);
527
- },
528
- hmrManager: this.hmrManager,
529
- bridge: this.bridge,
530
- });
531
- await watcher.createWatcherSubscription();
532
- }
533
-
534
- appLogger.debug('Node server adapter initialization completed', {
535
- apiHandlers: this.apiHandlers.length,
536
- staticRoutes: this.staticRoutes.length,
537
- hasErrorHandler: !!this.errorHandler,
538
- hmrEnabled: !!this.hmrManager?.isEnabled(),
539
- });
540
- }
541
- }
542
-
543
- /**
544
- * Factory function that creates and fully initialises a `NodeServerAdapter`.
545
- *
546
- * `runtimeOrigin` is derived from `serveOptions` when not explicitly provided,
547
- * so callers only need to set it when the server is behind a reverse proxy that
548
- * changes the effective host or port.
549
- */
550
- export async function createNodeServerAdapter(params: NodeServerAdapterParams): Promise<NodeServerAdapterResult> {
551
- const runtimeOrigin =
552
- params.runtimeOrigin ??
553
- `http://${params.serveOptions.hostname || 'localhost'}:${params.serveOptions.port || 3000}`;
554
-
555
- const adapter = new NodeServerAdapter({
556
- ...params,
557
- runtimeOrigin,
558
- });
559
-
560
- return adapter.createAdapter();
561
- }