@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,37 +1,57 @@
1
1
  import { createServer } from "node:http";
2
2
  import path from "node:path";
3
3
  import { fileSystem } from "@ecopages/file-system";
4
- import { RESOLVED_ASSETS_DIR } from "../../constants.js";
5
- import { defaultBuildAdapter } from "../../build/build-adapter.js";
4
+ import { getAppBrowserBuildPlugins, setupAppRuntimePlugins } from "../../build/build-adapter.js";
5
+ import { installAppRuntimeBuildExecutor } from "../../build/runtime-build-executor.js";
6
+ import { RESOLVED_ASSETS_DIR } from "../../config/constants.js";
6
7
  import { appLogger } from "../../global/app-logger.js";
7
- import { ProjectWatcher } from "../../watchers/project-watcher.js";
8
8
  import { NodeClientBridge } from "./node-client-bridge.js";
9
9
  import { NodeHmrManager } from "./node-hmr-manager.js";
10
+ import { ProjectWatcher } from "../../watchers/project-watcher.js";
10
11
  import { StaticSiteGenerator } from "../../static-site-generator/static-site-generator.js";
11
12
  import { SharedServerAdapter } from "../shared/server-adapter.js";
12
13
  import { ServerStaticBuilder } from "../shared/server-static-builder.js";
13
- import { NodeStaticContentServer } from "./static-content-server.js";
14
- class ClientAbortError extends Error {
15
- constructor() {
16
- super("Client closed the request");
17
- this.name = "ClientAbortError";
18
- }
19
- }
14
+ import { DEFAULT_ECOPAGES_HOSTNAME, DEFAULT_ECOPAGES_PORT } from "../../config/constants.js";
15
+ import {
16
+ injectHmrRuntimeIntoHtmlResponse,
17
+ isHtmlResponse,
18
+ shouldInjectHmrHtmlResponse
19
+ } from "../shared/hmr-html-response.js";
20
+ import { resolveServeRuntimeOrigin } from "../shared/runtime-app-bootstrap.js";
21
+ import { NodeClientAbortError, NodeHttpRequestBridge } from "./http-request-bridge.js";
22
+ import { NodeStaticPreviewHost } from "./static-preview-host.js";
23
+ import { DefaultNodeServerDevRuntimeFactory } from "./server-adapter-dependencies.js";
20
24
  class NodeServerAdapter extends SharedServerAdapter {
21
25
  serverInstance = null;
22
26
  initialized = false;
23
27
  apiHandlers;
24
28
  staticRoutes;
25
29
  errorHandler;
26
- previewServer = null;
27
30
  bridge = null;
28
31
  hmrManager = null;
29
- processorBuildPlugins = [];
32
+ previewHost;
33
+ requestBridge;
34
+ devRuntimeFactory;
35
+ shouldInjectHmrScript() {
36
+ return shouldInjectHmrHtmlResponse(this.options?.watch === true, this.hmrManager ?? void 0);
37
+ }
38
+ isHtmlResponse(response) {
39
+ return isHtmlResponse(response);
40
+ }
41
+ async maybeInjectHmrScript(response) {
42
+ if (this.shouldInjectHmrScript() && this.isHtmlResponse(response)) {
43
+ return injectHmrRuntimeIntoHtmlResponse(response);
44
+ }
45
+ return response;
46
+ }
30
47
  constructor(options) {
31
48
  super(options);
32
49
  this.apiHandlers = options.apiHandlers || [];
33
50
  this.staticRoutes = options.staticRoutes || [];
34
51
  this.errorHandler = options.errorHandler;
52
+ this.previewHost = options.previewHost;
53
+ this.requestBridge = options.requestBridge;
54
+ this.devRuntimeFactory = options.devRuntimeFactory;
35
55
  }
36
56
  /**
37
57
  * Prepares the adapter for use.
@@ -47,85 +67,35 @@ class NodeServerAdapter extends SharedServerAdapter {
47
67
  * processors during their `setup()` calls.
48
68
  */
49
69
  async initialize() {
50
- this.setupLoaders();
51
- this.copyPublicDir();
52
- await this.initializePlugins();
53
- await this.initSharedRouter();
54
- this.configureSharedResponseHandlers(this.staticRoutes, this.hmrManager ?? void 0);
70
+ installAppRuntimeBuildExecutor(this.appConfig, {
71
+ development: this.options?.watch === true
72
+ });
73
+ this.prepareRuntimePublicDir();
74
+ await setupAppRuntimePlugins({
75
+ appConfig: this.appConfig,
76
+ runtimeOrigin: this.runtimeOrigin,
77
+ hmrManager: this.hmrManager ?? void 0
78
+ });
79
+ await this.initializeSharedRouteHandling({
80
+ staticRoutes: this.staticRoutes,
81
+ hmrManager: this.hmrManager ?? void 0
82
+ });
55
83
  this.staticSiteGenerator = new StaticSiteGenerator({ appConfig: this.appConfig });
56
84
  this.staticBuilder = new ServerStaticBuilder({
57
85
  appConfig: this.appConfig,
58
86
  staticSiteGenerator: this.staticSiteGenerator,
59
- serveOptions: this.serveOptions
87
+ serveOptions: this.serveOptions,
88
+ apiHandlers: this.apiHandlers
60
89
  });
61
90
  this.initialized = true;
62
91
  }
63
- /**
64
- * Registers every configured file loader as a build plugin on the shared
65
- * `defaultBuildAdapter`.
66
- *
67
- * Loaders are registered on the *shared* adapter (not on a per-build instance)
68
- * because they must be available globally to both the SSR build and any dynamic
69
- * transpile passes that happen outside of a top-level `build()` call (e.g. HMR
70
- * incremental rebuilds).
71
- */
72
- setupLoaders() {
73
- for (const loader of this.appConfig.loaders.values()) {
74
- defaultBuildAdapter.registerPlugin(loader);
75
- }
76
- }
77
- copyPublicDir() {
92
+ prepareRuntimePublicDir() {
78
93
  const srcPublicDir = path.join(this.appConfig.rootDir, this.appConfig.srcDir, this.appConfig.publicDir);
79
94
  if (fileSystem.exists(srcPublicDir)) {
80
95
  fileSystem.copyDir(srcPublicDir, path.join(this.appConfig.rootDir, this.appConfig.distDir));
81
96
  }
82
97
  fileSystem.ensureDir(path.join(this.appConfig.absolutePaths.distDir, RESOLVED_ASSETS_DIR));
83
98
  }
84
- /**
85
- * Sets up all configured processors and integrations in two distinct phases.
86
- *
87
- * **Phase 1 — Processors:**
88
- * Each processor's `setup()` is called first. A processor may expose two
89
- * plugin lists:
90
- * - `plugins` — transform plugins used during SSR rendering (e.g. PostCSS).
91
- * - `buildPlugins` — esbuild plugins used during the client bundle step.
92
- * Both are registered on `defaultBuildAdapter` so later build calls pick them up.
93
- *
94
- * **Phase 2 — Integrations:**
95
- * Integrations receive the fully-resolved app config, the runtime origin, and
96
- * (if already initialised) the HMR manager before their own `setup()` is called.
97
- * This ordering ensures integrations can query config values that processors
98
- * may have mutated during phase 1.
99
- */
100
- async initializePlugins() {
101
- const processorBuildPlugins = [];
102
- for (const processor of this.appConfig.processors.values()) {
103
- await processor.setup();
104
- if (processor.plugins) {
105
- for (const plugin of processor.plugins) {
106
- defaultBuildAdapter.registerPlugin(plugin);
107
- }
108
- }
109
- if (processor.buildPlugins) {
110
- processorBuildPlugins.push(...processor.buildPlugins);
111
- for (const plugin of processor.buildPlugins) {
112
- defaultBuildAdapter.registerPlugin(plugin);
113
- }
114
- }
115
- }
116
- for (const integration of this.appConfig.integrations) {
117
- integration.setConfig(this.appConfig);
118
- integration.setRuntimeOrigin(this.runtimeOrigin);
119
- if (this.hmrManager) {
120
- integration.setHmrManager(this.hmrManager);
121
- }
122
- await integration.setup();
123
- for (const plugin of integration.plugins) {
124
- defaultBuildAdapter.registerPlugin(plugin);
125
- }
126
- }
127
- this.processorBuildPlugins = processorBuildPlugins;
128
- }
129
99
  getServerOptions() {
130
100
  return {
131
101
  ...this.serveOptions
@@ -136,9 +106,10 @@ class NodeServerAdapter extends SharedServerAdapter {
136
106
  await this.initialize();
137
107
  }
138
108
  const buildServer = await this.startBuildRuntimeServer();
109
+ const buildRuntimeOrigin = this.getListeningServerOrigin(buildServer);
139
110
  try {
140
111
  await this.staticBuilder.build(
141
- { preview: false },
112
+ { preview: false, baseUrl: buildRuntimeOrigin },
142
113
  {
143
114
  router: this.router,
144
115
  routeRendererFactory: this.routeRendererFactory,
@@ -151,117 +122,27 @@ class NodeServerAdapter extends SharedServerAdapter {
151
122
  if (!options?.preview) {
152
123
  return;
153
124
  }
154
- if (this.previewServer) {
155
- await this.previewServer.stop();
156
- }
157
- this.previewServer = new NodeStaticContentServer({
125
+ await this.previewHost.start({
158
126
  appConfig: this.appConfig,
159
- options: {
160
- hostname: this.serveOptions.hostname,
161
- port: Number(this.serveOptions.port || 3e3)
162
- }
127
+ hostname: String(this.serveOptions.hostname || DEFAULT_ECOPAGES_HOSTNAME),
128
+ port: Number(this.serveOptions.port || DEFAULT_ECOPAGES_PORT)
163
129
  });
164
- await this.previewServer.start();
165
- const previewHostname = this.serveOptions.hostname || "localhost";
166
- const previewPort = this.serveOptions.port || 3e3;
130
+ const previewHostname = this.serveOptions.hostname || DEFAULT_ECOPAGES_HOSTNAME;
131
+ const previewPort = this.serveOptions.port || DEFAULT_ECOPAGES_PORT;
167
132
  appLogger.info(`Preview running at http://${previewHostname}:${previewPort}`);
168
133
  }
169
- /**
170
- * Converts a Node.js `IncomingMessage` into a Web API `Request`.
171
- *
172
- * Multi-value headers (e.g. `set-cookie`) are appended individually so no
173
- * value is silently dropped.
174
- *
175
- * For methods that carry a body (`POST`, `PUT`, `PATCH`, …), the raw
176
- * `IncomingMessage` stream is wrapped in a `ReadableStream` rather than
177
- * cast directly to `BodyInit`. See the inline doc block inside the `if`
178
- * branch for the rationale (client-abort handling).
179
- *
180
- * `duplex: 'half'` is required by the `fetch` spec when a streaming body is
181
- * provided — without it Node.js 18+ throws a `TypeError`.
182
- */
183
- createWebRequest(req) {
184
- const url = new URL(req.url ?? "/", this.runtimeOrigin);
185
- const headers = new Headers();
186
- for (const [key, value] of Object.entries(req.headers)) {
187
- if (Array.isArray(value)) {
188
- for (const item of value) {
189
- headers.append(key, item);
190
- }
191
- continue;
192
- }
193
- if (value !== void 0) {
194
- headers.set(key, value);
195
- }
196
- }
197
- const method = (req.method ?? "GET").toUpperCase();
198
- const requestInit = {
199
- method,
200
- headers
201
- };
202
- if (method !== "GET" && method !== "HEAD") {
203
- const body = new ReadableStream({
204
- start(controller) {
205
- req.on("data", (chunk) => controller.enqueue(chunk));
206
- req.once("end", () => controller.close());
207
- req.once("aborted", () => {
208
- controller.error(new ClientAbortError());
209
- });
210
- req.once("error", (err) => {
211
- const isClientAbort = err.code === "ECONNRESET";
212
- controller.error(isClientAbort ? new ClientAbortError() : err);
213
- });
214
- },
215
- cancel() {
216
- req.destroy();
217
- }
218
- });
219
- requestInit.body = body;
220
- requestInit.duplex = "half";
221
- }
222
- return new Request(url, requestInit);
223
- }
224
- /**
225
- * Writes a Web `Response` back to a Node.js `ServerResponse`.
226
- *
227
- * The entire body is buffered via `arrayBuffer()` before writing. This is
228
- * intentional for the current use-case (SSR pages and API routes), where
229
- * responses are typically small and fully materialised. Streaming responses
230
- * are not yet supported.
231
- */
232
- async sendNodeResponse(res, response) {
233
- res.statusCode = response.status;
234
- response.headers.forEach((value, key) => {
235
- res.setHeader(key, value);
236
- });
237
- if (!response.body) {
238
- res.end();
239
- return;
240
- }
241
- const body = Buffer.from(await response.arrayBuffer());
242
- res.end(body);
243
- }
244
- /**
245
- * Starts an ephemeral HTTP server used *only* during a static site generation
246
- * run.
247
- *
248
- * Static generation works by having the `StaticSiteGenerator` issue real HTTP
249
- * requests to a live server for each route, capturing the rendered HTML. This
250
- * approach reuses the normal request pipeline (middleware, caching, API
251
- * handlers) without any special-casing for the build path.
252
- *
253
- * The server is torn down immediately after generation completes via
254
- * `stopBuildRuntimeServer`, so it never overlaps with the actual dev/prod server.
255
- */
256
134
  async startBuildRuntimeServer() {
257
- const hostname = String(this.serveOptions.hostname || "localhost");
258
- const port = Number(this.serveOptions.port || 3e3);
135
+ const hostname = String(this.serveOptions.hostname || DEFAULT_ECOPAGES_HOSTNAME);
136
+ const port = 0;
259
137
  const server = createServer(async (req, res) => {
260
138
  try {
261
- const webRequest = this.createWebRequest(req);
139
+ const webRequest = this.requestBridge.createWebRequest(req, this.runtimeOrigin);
262
140
  const response = await this.handleRequest(webRequest);
263
- await this.sendNodeResponse(res, response);
141
+ await this.requestBridge.sendNodeResponse(res, response);
264
142
  } catch (error) {
143
+ if (error instanceof NodeClientAbortError) {
144
+ return;
145
+ }
265
146
  appLogger.error("Node static build runtime request failed", error);
266
147
  res.statusCode = 500;
267
148
  res.end("Internal Server Error");
@@ -275,9 +156,17 @@ class NodeServerAdapter extends SharedServerAdapter {
275
156
  });
276
157
  });
277
158
  this.serverInstance = server;
278
- appLogger.info(`Server running at http://${hostname}:${port}`);
159
+ appLogger.info(`Server running at ${this.getListeningServerOrigin(server)}`);
279
160
  return server;
280
161
  }
162
+ getListeningServerOrigin(server) {
163
+ const address = server.address();
164
+ const hostname = String(this.serveOptions.hostname || DEFAULT_ECOPAGES_HOSTNAME);
165
+ if (!address || typeof address === "string") {
166
+ throw new Error("Build runtime server did not expose a numeric listening port");
167
+ }
168
+ return `http://${hostname}:${address.port}`;
169
+ }
281
170
  /**
282
171
  * Gracefully shuts down the ephemeral build runtime server.
283
172
  *
@@ -325,19 +214,20 @@ class NodeServerAdapter extends SharedServerAdapter {
325
214
  * underlying socket closes early — into a 499 response so it does not
326
215
  * incorrectly surface as a 500 in application logs.
327
216
  */
328
- async handleRequest(_request) {
217
+ async handleRequest(request) {
329
218
  if (!this.initialized) {
330
219
  throw new Error("Node server adapter is not initialized. Call createAdapter() first.");
331
220
  }
332
221
  try {
333
- return await this.handleSharedRequest(_request, {
222
+ const response = await this.handleSharedRequest(request, {
334
223
  apiHandlers: this.apiHandlers,
335
224
  errorHandler: this.errorHandler,
336
225
  serverInstance: this.serverInstance,
337
226
  hmrManager: this.hmrManager
338
227
  });
228
+ return await this.maybeInjectHmrScript(response);
339
229
  } catch (error) {
340
- if (error instanceof ClientAbortError) {
230
+ if (error instanceof NodeClientAbortError) {
341
231
  return new Response(null, { status: 499 });
342
232
  }
343
233
  throw error;
@@ -353,22 +243,22 @@ class NodeServerAdapter extends SharedServerAdapter {
353
243
  * broadcast + heartbeat cleanup.
354
244
  * - `NodeHmrManager` watches the filesystem and triggers incremental esbuild
355
245
  * rebuilds, notifying connected clients via the bridge.
356
- * - `ProjectWatcher` listens for route-level file changes and refreshes the
357
- * router and response handlers when pages are added or removed.
246
+ * - Shared watcher bootstrapping listens for route-level file changes and
247
+ * refreshes the router and response handlers when pages are added or removed.
358
248
  *
359
249
  * WebSocket upgrade requests that do not target `/_hmr` are rejected with an
360
250
  * immediate socket destroy to prevent unhandled upgrade leaks.
361
251
  */
362
- async completeInitialization(_server) {
363
- this.serverInstance = _server;
252
+ async completeInitialization(server) {
253
+ this.serverInstance = server;
364
254
  if (this.options?.watch) {
365
- const { WebSocketServer } = await import("ws");
366
- const wss = new WebSocketServer({ noServer: true });
367
- this.bridge = new NodeClientBridge();
368
- this.hmrManager = new NodeHmrManager({ appConfig: this.appConfig, bridge: this.bridge });
255
+ const devRuntime = this.devRuntimeFactory.create({ appConfig: this.appConfig });
256
+ const wss = devRuntime.websocketServer;
257
+ this.bridge = devRuntime.bridge;
258
+ this.hmrManager = devRuntime.hmrManager;
369
259
  this.hmrManager.setEnabled(true);
370
260
  await this.hmrManager.buildRuntime();
371
- _server.on("upgrade", (req, socket, head) => {
261
+ server.on("upgrade", (req, socket, head) => {
372
262
  const url = new URL(req.url ?? "/", this.runtimeOrigin);
373
263
  if (url.pathname === "/_hmr") {
374
264
  wss.handleUpgrade(req, socket, head, (ws) => {
@@ -380,19 +270,18 @@ class NodeServerAdapter extends SharedServerAdapter {
380
270
  socket.destroy();
381
271
  }
382
272
  });
383
- const loaderPlugins = Array.from(this.appConfig.loaders.values());
384
- const hmrBuildPlugins = [...loaderPlugins, ...this.processorBuildPlugins];
385
- this.hmrManager.setPlugins(hmrBuildPlugins);
273
+ const browserBuildPlugins = getAppBrowserBuildPlugins(this.appConfig);
274
+ this.hmrManager.setPlugins(browserBuildPlugins);
386
275
  for (const integration of this.appConfig.integrations) {
387
276
  integration.setHmrManager(this.hmrManager);
388
277
  }
389
278
  this.configureSharedResponseHandlers(this.staticRoutes, this.hmrManager);
390
279
  const watcher = new ProjectWatcher({
391
280
  config: this.appConfig,
392
- refreshRouterRoutesCallback: async () => {
393
- await this.initSharedRouter();
394
- this.configureSharedResponseHandlers(this.staticRoutes, this.hmrManager);
395
- },
281
+ refreshRouterRoutesCallback: this.createSharedWatchRefreshCallback({
282
+ staticRoutes: this.staticRoutes,
283
+ hmrManager: this.hmrManager
284
+ }),
396
285
  hmrManager: this.hmrManager,
397
286
  bridge: this.bridge
398
287
  });
@@ -407,10 +296,16 @@ class NodeServerAdapter extends SharedServerAdapter {
407
296
  }
408
297
  }
409
298
  async function createNodeServerAdapter(params) {
410
- const runtimeOrigin = params.runtimeOrigin ?? `http://${params.serveOptions.hostname || "localhost"}:${params.serveOptions.port || 3e3}`;
299
+ const runtimeOrigin = params.runtimeOrigin ?? resolveServeRuntimeOrigin(params.serveOptions);
300
+ const previewHost = params.previewHost ?? new NodeStaticPreviewHost();
301
+ const requestBridge = params.requestBridge ?? new NodeHttpRequestBridge();
302
+ const devRuntimeFactory = params.devRuntimeFactory ?? new DefaultNodeServerDevRuntimeFactory();
411
303
  const adapter = new NodeServerAdapter({
412
304
  ...params,
413
- runtimeOrigin
305
+ runtimeOrigin,
306
+ previewHost,
307
+ requestBridge,
308
+ devRuntimeFactory
414
309
  });
415
310
  return adapter.createAdapter();
416
311
  }
@@ -1,24 +1,60 @@
1
1
  import { type Server as NodeHttpServer } from 'node:http';
2
- import type { EcoPagesAppConfig } from '../../internal-types.js';
2
+ import type { EcoPagesAppConfig } from '../../types/internal-types.js';
3
3
  type NodeStaticContentServerOptions = {
4
4
  hostname?: string;
5
5
  port?: number;
6
6
  };
7
+ /**
8
+ * Serves prebuilt static Ecopages output through Node's HTTP server.
9
+ *
10
+ * @remarks
11
+ * This server is used by the Node preview/build path once the app has already
12
+ * emitted its static output. It intentionally stays small: path sanitization,
13
+ * content-type selection, optional gzip serving, and 404 handling.
14
+ */
7
15
  export declare class NodeStaticContentServer {
8
16
  private readonly appConfig;
9
17
  private readonly options;
10
18
  private server;
19
+ /**
20
+ * Creates the Node static-content server for one built app output directory.
21
+ */
11
22
  constructor({ appConfig, options }: {
12
23
  appConfig: EcoPagesAppConfig;
13
24
  options?: NodeStaticContentServerOptions;
14
25
  });
26
+ /**
27
+ * Returns whether the given content type should be served from a pre-gzipped
28
+ * companion file when available.
29
+ */
15
30
  private shouldServeGzip;
31
+ /**
32
+ * Normalizes a request pathname and rejects directory traversal attempts.
33
+ */
16
34
  private sanitizePath;
35
+ /**
36
+ * Writes one HTTP response with the provided headers and optional body.
37
+ */
17
38
  private sendResponse;
39
+ /**
40
+ * Serves the generated 404 page when present, or a plain-text fallback.
41
+ */
18
42
  private sendNotFoundPage;
43
+ /**
44
+ * Serves one concrete file path, honoring gzip and HEAD semantics.
45
+ */
19
46
  private serveFile;
47
+ /**
48
+ * Handles one incoming Node HTTP request against the built static output tree.
49
+ */
20
50
  private handleRequest;
51
+ /**
52
+ * Starts the static preview server.
53
+ */
21
54
  start(): Promise<NodeHttpServer>;
55
+ /**
56
+ * Stops the static preview server and optionally closes active connections.
57
+ */
22
58
  stop(force?: boolean): Promise<void>;
23
59
  }
24
60
  export {};
@@ -1,12 +1,15 @@
1
1
  import { createServer } from "node:http";
2
2
  import { extname, join, normalize, sep } from "node:path";
3
- import { DEFAULT_ECOPAGES_HOSTNAME, DEFAULT_ECOPAGES_PORT, STATUS_MESSAGE } from "../../constants.js";
3
+ import { DEFAULT_ECOPAGES_HOSTNAME, DEFAULT_ECOPAGES_PORT, STATUS_MESSAGE } from "../../config/constants.js";
4
4
  import { fileSystem } from "@ecopages/file-system";
5
5
  import { ServerUtils } from "../../utils/server-utils.module.js";
6
6
  class NodeStaticContentServer {
7
7
  appConfig;
8
8
  options;
9
9
  server = null;
10
+ /**
11
+ * Creates the Node static-content server for one built app output directory.
12
+ */
10
13
  constructor({ appConfig, options }) {
11
14
  this.appConfig = appConfig;
12
15
  this.options = {
@@ -14,9 +17,16 @@ class NodeStaticContentServer {
14
17
  port: options?.port ?? DEFAULT_ECOPAGES_PORT
15
18
  };
16
19
  }
20
+ /**
21
+ * Returns whether the given content type should be served from a pre-gzipped
22
+ * companion file when available.
23
+ */
17
24
  shouldServeGzip(contentType) {
18
25
  return ["text/javascript", "text/css"].includes(contentType);
19
26
  }
27
+ /**
28
+ * Normalizes a request pathname and rejects directory traversal attempts.
29
+ */
20
30
  sanitizePath(pathname) {
21
31
  const withoutLeadingSlash = pathname.replace(/^\/+/, "");
22
32
  const normalizedPath = normalize(withoutLeadingSlash);
@@ -25,6 +35,9 @@ class NodeStaticContentServer {
25
35
  }
26
36
  return normalizedPath;
27
37
  }
38
+ /**
39
+ * Writes one HTTP response with the provided headers and optional body.
40
+ */
28
41
  sendResponse(res, status, headers, body) {
29
42
  res.statusCode = status;
30
43
  for (const [key, value] of Object.entries(headers)) {
@@ -36,6 +49,9 @@ class NodeStaticContentServer {
36
49
  }
37
50
  res.end(body);
38
51
  }
52
+ /**
53
+ * Serves the generated 404 page when present, or a plain-text fallback.
54
+ */
39
55
  sendNotFoundPage(req, res) {
40
56
  const error404TemplatePath = join(this.appConfig.absolutePaths.distDir, "404.html");
41
57
  const isHead = (req.method ?? "GET").toUpperCase() === "HEAD";
@@ -51,6 +67,9 @@ class NodeStaticContentServer {
51
67
  const file = fileSystem.readFileAsBuffer(error404TemplatePath);
52
68
  this.sendResponse(res, 404, { "Content-Type": "text/html" }, isHead ? void 0 : file);
53
69
  }
70
+ /**
71
+ * Serves one concrete file path, honoring gzip and HEAD semantics.
72
+ */
54
73
  serveFile(req, res, filePath, status = 200) {
55
74
  const contentType = ServerUtils.getContentType(extname(filePath));
56
75
  const acceptsGzip = req.headers["accept-encoding"]?.includes("gzip");
@@ -79,6 +98,9 @@ class NodeStaticContentServer {
79
98
  const file = fileSystem.readFileAsBuffer(filePath);
80
99
  this.sendResponse(res, status, { "Content-Type": contentType }, isHead ? void 0 : file);
81
100
  }
101
+ /**
102
+ * Handles one incoming Node HTTP request against the built static output tree.
103
+ */
82
104
  handleRequest(req, res) {
83
105
  const method = (req.method ?? "GET").toUpperCase();
84
106
  const isHead = method === "HEAD";
@@ -129,6 +151,9 @@ class NodeStaticContentServer {
129
151
  }
130
152
  this.sendNotFoundPage(req, res);
131
153
  }
154
+ /**
155
+ * Starts the static preview server.
156
+ */
132
157
  async start() {
133
158
  if (this.server) {
134
159
  return this.server;
@@ -141,6 +166,9 @@ class NodeStaticContentServer {
141
166
  });
142
167
  return this.server;
143
168
  }
169
+ /**
170
+ * Stops the static preview server and optionally closes active connections.
171
+ */
144
172
  async stop(force = true) {
145
173
  if (!this.server) {
146
174
  return;
@@ -0,0 +1,55 @@
1
+ import type { AddressInfo } from 'node:net';
2
+ import type { EcoPagesAppConfig } from '../../types/internal-types.js';
3
+ import type { StaticPreviewHost, StaticPreviewHostStartOptions } from '../shared/static-preview-host.js';
4
+ type NodeStaticPreviewServer = {
5
+ start(): Promise<{
6
+ address(): AddressInfo | string | null;
7
+ }>;
8
+ stop(force?: boolean): Promise<void>;
9
+ };
10
+ type NodeStaticPreviewServerFactory = new (args: {
11
+ appConfig: EcoPagesAppConfig;
12
+ options?: {
13
+ hostname?: string;
14
+ port?: number;
15
+ };
16
+ }) => NodeStaticPreviewServer;
17
+ /**
18
+ * Node preview-host wrapper that manages the lifecycle of the static preview
19
+ * server used after a build.
20
+ *
21
+ * @remarks
22
+ * The host separates preview-server construction from lifecycle control so the
23
+ * Node server adapter can restart preview serving safely across repeated build
24
+ * and preview flows.
25
+ */
26
+ export declare class NodeStaticPreviewHost implements StaticPreviewHost {
27
+ private readonly previewServerFactory;
28
+ private previewServer;
29
+ private stopPromise;
30
+ /**
31
+ * Creates the preview host with an injectable preview-server constructor.
32
+ */
33
+ constructor(previewServerFactory?: NodeStaticPreviewServerFactory);
34
+ /**
35
+ * Starts the Node preview host after fully draining any previous preview server
36
+ * shutdown that may still be in flight.
37
+ *
38
+ * @remarks
39
+ * The host only publishes a new preview server after `start()` succeeds. That
40
+ * keeps failed startup attempts from replacing the last known-good server with a
41
+ * half-initialized instance.
42
+ */
43
+ start(options: StaticPreviewHostStartOptions): Promise<number | null>;
44
+ /**
45
+ * Stops the active preview server and coalesces overlapping stop requests onto
46
+ * the same shutdown promise.
47
+ *
48
+ * @remarks
49
+ * The host keeps the server reference until shutdown succeeds. If shutdown
50
+ * fails, callers can still retry `stop()` or inspect the same live instance
51
+ * instead of losing the handle during a rejected async stop.
52
+ */
53
+ stop(force?: boolean): Promise<void>;
54
+ }
55
+ export {};