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

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 (454) hide show
  1. package/README.md +268 -14
  2. package/package.json +92 -110
  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 -68
  12. package/src/adapters/bun/hmr-manager.js +30 -212
  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 -49
  31. package/src/adapters/node/node-hmr-manager.js +31 -219
  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 +99 -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/build-adapter.d.ts +176 -3
  74. package/src/build/build-adapter.js +619 -16
  75. package/src/build/build-manifest.d.ts +27 -0
  76. package/src/build/build-manifest.js +30 -0
  77. package/src/build/dev-build-coordinator.d.ts +72 -0
  78. package/src/build/dev-build-coordinator.js +154 -0
  79. package/src/build/esbuild-build-adapter.d.ts +16 -6
  80. package/src/build/esbuild-build-adapter.js +202 -74
  81. package/src/build/runtime-build-executor.d.ts +14 -0
  82. package/src/build/runtime-build-executor.js +22 -0
  83. package/src/build/runtime-specifier-alias-plugin.d.ts +15 -0
  84. package/src/build/runtime-specifier-alias-plugin.js +35 -0
  85. package/src/build/runtime-specifier-aliases.d.ts +5 -0
  86. package/src/build/runtime-specifier-aliases.js +95 -0
  87. package/src/config/README.md +36 -0
  88. package/src/config/config-builder.d.ts +54 -29
  89. package/src/config/config-builder.js +256 -50
  90. package/src/{constants.d.ts → config/constants.d.ts} +13 -0
  91. package/src/{constants.js → config/constants.js} +4 -0
  92. package/src/declarations.d.ts +19 -14
  93. package/src/dev/host-runtime.d.ts +10 -0
  94. package/src/dev/host-runtime.js +24 -0
  95. package/src/dev/sc-server.d.ts +1 -1
  96. package/src/dev/sc-server.js +1 -1
  97. package/src/eco/README.md +70 -16
  98. package/src/eco/eco.browser.d.ts +2 -0
  99. package/src/eco/eco.browser.js +88 -0
  100. package/src/eco/eco.js +63 -54
  101. package/src/eco/eco.types.d.ts +69 -6
  102. package/src/eco/eco.utils.d.ts +1 -40
  103. package/src/eco/eco.utils.js +5 -35
  104. package/src/eco/global-injector-map.d.ts +3 -3
  105. package/src/eco/global-injector-map.js +2 -2
  106. package/src/eco/lazy-injector-map.d.ts +2 -2
  107. package/src/errors/index.d.ts +1 -0
  108. package/src/errors/index.js +3 -1
  109. package/src/hmr/README.md +26 -0
  110. package/src/hmr/client/hmr-runtime.d.ts +1 -6
  111. package/src/hmr/client/hmr-runtime.js +38 -7
  112. package/src/hmr/hmr-strategy.d.ts +16 -13
  113. package/src/hmr/hmr-strategy.js +22 -7
  114. package/src/hmr/hmr.postcss.test.e2e.d.ts +1 -0
  115. package/src/hmr/hmr.postcss.test.e2e.js +31 -0
  116. package/src/hmr/hmr.test.e2e.js +26 -33
  117. package/src/hmr/strategies/default-hmr-strategy.d.ts +2 -2
  118. package/src/hmr/strategies/default-hmr-strategy.js +1 -1
  119. package/src/hmr/strategies/js-hmr-strategy.d.ts +46 -48
  120. package/src/hmr/strategies/js-hmr-strategy.js +60 -75
  121. package/src/index.browser.d.ts +2 -2
  122. package/src/index.browser.js +1 -1
  123. package/src/index.d.ts +4 -3
  124. package/src/index.js +16 -5
  125. package/src/integrations/ghtml/ghtml-renderer.d.ts +3 -2
  126. package/src/integrations/ghtml/ghtml-renderer.js +27 -30
  127. package/src/integrations/ghtml/ghtml.constants.d.ts +1 -0
  128. package/src/integrations/ghtml/ghtml.constants.js +4 -0
  129. package/src/integrations/ghtml/ghtml.plugin.d.ts +2 -6
  130. package/src/integrations/ghtml/ghtml.plugin.js +3 -4
  131. package/src/plugins/README.md +35 -0
  132. package/src/plugins/alias-resolver-plugin.d.ts +1 -0
  133. package/src/plugins/alias-resolver-plugin.js +27 -5
  134. package/src/plugins/eco-component-meta-plugin.d.ts +14 -1
  135. package/src/plugins/eco-component-meta-plugin.js +42 -24
  136. package/src/plugins/foreign-jsx-override-plugin.d.ts +33 -0
  137. package/src/plugins/foreign-jsx-override-plugin.js +41 -0
  138. package/src/plugins/integration-plugin.d.ts +147 -29
  139. package/src/plugins/integration-plugin.js +103 -14
  140. package/src/plugins/processor.d.ts +17 -2
  141. package/src/plugins/processor.js +22 -3
  142. package/src/plugins/runtime-capability.d.ts +9 -0
  143. package/src/plugins/source-transform.d.ts +46 -0
  144. package/src/plugins/source-transform.js +71 -0
  145. package/src/route-renderer/GRAPH.md +83 -325
  146. package/src/route-renderer/README.md +73 -90
  147. package/src/route-renderer/orchestration/component-render-context.d.ts +97 -0
  148. package/src/route-renderer/orchestration/component-render-context.js +147 -0
  149. package/src/route-renderer/orchestration/declared-ownership-graph.d.ts +18 -0
  150. package/src/route-renderer/orchestration/declared-ownership-graph.js +34 -0
  151. package/src/route-renderer/orchestration/foreign-subtree-execution.service.d.ts +110 -0
  152. package/src/route-renderer/orchestration/foreign-subtree-execution.service.js +233 -0
  153. package/src/route-renderer/orchestration/integration-renderer.d.ts +534 -0
  154. package/src/route-renderer/orchestration/integration-renderer.js +986 -0
  155. package/src/route-renderer/orchestration/ownership-planning.service.d.ts +24 -0
  156. package/src/route-renderer/orchestration/ownership-planning.service.js +63 -0
  157. package/src/route-renderer/orchestration/ownership-validation.service.d.ts +29 -0
  158. package/src/route-renderer/orchestration/ownership-validation.service.js +53 -0
  159. package/src/route-renderer/orchestration/processed-asset-dedupe.d.ts +3 -0
  160. package/src/route-renderer/orchestration/processed-asset-dedupe.js +27 -0
  161. package/src/route-renderer/orchestration/queued-foreign-subtree-resolution.service.d.ts +91 -0
  162. package/src/route-renderer/orchestration/queued-foreign-subtree-resolution.service.js +170 -0
  163. package/src/route-renderer/orchestration/render-output.utils.d.ts +66 -0
  164. package/src/route-renderer/orchestration/render-output.utils.js +171 -0
  165. package/src/route-renderer/orchestration/route-render-orchestrator.d.ts +134 -0
  166. package/src/route-renderer/orchestration/route-render-orchestrator.js +442 -0
  167. package/src/route-renderer/orchestration/template-serialization.d.ts +38 -0
  168. package/src/route-renderer/orchestration/template-serialization.js +45 -0
  169. package/src/route-renderer/page-loading/component-dependency-collection.d.ts +37 -0
  170. package/src/route-renderer/page-loading/component-dependency-collection.js +132 -0
  171. package/src/route-renderer/page-loading/declared-asset-collection.d.ts +24 -0
  172. package/src/route-renderer/page-loading/declared-asset-collection.js +106 -0
  173. package/src/route-renderer/{dependency-resolver.d.ts → page-loading/dependency-resolver.d.ts} +15 -4
  174. package/src/route-renderer/page-loading/dependency-resolver.js +115 -0
  175. package/src/route-renderer/page-loading/ecopages-virtual-imports.d.ts +11 -0
  176. package/src/route-renderer/page-loading/ecopages-virtual-imports.js +57 -0
  177. package/src/route-renderer/page-loading/lazy-entry-collection.d.ts +45 -0
  178. package/src/route-renderer/page-loading/lazy-entry-collection.js +105 -0
  179. package/src/route-renderer/page-loading/lazy-trigger-planning.d.ts +19 -0
  180. package/src/route-renderer/page-loading/lazy-trigger-planning.js +40 -0
  181. package/src/route-renderer/page-loading/module-declaration-aggregation.d.ts +5 -0
  182. package/src/route-renderer/page-loading/module-declaration-aggregation.js +33 -0
  183. package/src/route-renderer/page-loading/module-declaration-scripts.d.ts +3 -0
  184. package/src/route-renderer/page-loading/module-declaration-scripts.js +18 -0
  185. package/src/route-renderer/page-loading/page-dependency-bundling.d.ts +13 -0
  186. package/src/route-renderer/page-loading/page-dependency-bundling.js +137 -0
  187. package/src/route-renderer/page-loading/page-module-loader.d.ts +90 -0
  188. package/src/route-renderer/{page-module-loader.js → page-loading/page-module-loader.js} +39 -14
  189. package/src/route-renderer/route-renderer.d.ts +57 -14
  190. package/src/route-renderer/route-renderer.js +30 -18
  191. package/src/router/README.md +94 -0
  192. package/src/router/client/link-intent.d.ts +53 -0
  193. package/src/router/client/link-intent.js +34 -0
  194. package/src/router/client/link-intent.test.browser.d.ts +1 -0
  195. package/src/router/client/link-intent.test.browser.js +43 -0
  196. package/src/router/client/navigation-coordinator.d.ts +169 -0
  197. package/src/router/client/navigation-coordinator.js +215 -0
  198. package/src/router/server/route-registry.d.ts +78 -0
  199. package/src/router/server/route-registry.js +262 -0
  200. package/src/services/README.md +28 -0
  201. package/src/services/assets/asset-processing-service/asset-dependency-keys.d.ts +3 -0
  202. package/src/services/assets/asset-processing-service/asset-dependency-keys.js +56 -0
  203. package/src/services/assets/asset-processing-service/asset-processing.service.d.ts +103 -0
  204. package/src/services/{asset-processing-service → assets/asset-processing-service}/asset-processing.service.js +124 -89
  205. package/src/services/{asset-processing-service → assets/asset-processing-service}/asset.factory.d.ts +1 -1
  206. package/src/services/{asset-processing-service → assets/asset-processing-service}/asset.factory.js +2 -2
  207. package/src/services/{asset-processing-service → assets/asset-processing-service}/assets.types.d.ts +16 -1
  208. package/src/services/assets/asset-processing-service/assets.types.js +0 -0
  209. package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.d.ts +55 -0
  210. package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.js +49 -0
  211. package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.d.ts +20 -0
  212. package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.js +41 -0
  213. package/src/services/assets/asset-processing-service/grouped-content-bundles.d.ts +30 -0
  214. package/src/services/assets/asset-processing-service/grouped-content-bundles.js +65 -0
  215. package/src/services/assets/asset-processing-service/index.d.ts +6 -0
  216. package/src/services/assets/asset-processing-service/index.js +6 -0
  217. package/src/services/assets/asset-processing-service/page-package.d.ts +6 -0
  218. package/src/services/assets/asset-processing-service/page-package.js +80 -0
  219. package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.interface.d.ts +2 -2
  220. package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.registry.d.ts +2 -2
  221. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/base/base-processor.d.ts +1 -1
  222. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/base/base-processor.js +11 -5
  223. package/src/services/assets/asset-processing-service/processors/base/base-script-processor.d.ts +22 -0
  224. package/src/services/assets/asset-processing-service/processors/base/base-script-processor.js +136 -0
  225. package/src/services/assets/asset-processing-service/processors/index.d.ts +5 -0
  226. package/src/services/assets/asset-processing-service/processors/index.js +5 -0
  227. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/content-script.processor.d.ts +3 -2
  228. package/src/services/assets/asset-processing-service/processors/script/content-script.processor.js +119 -0
  229. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/file-script.processor.d.ts +4 -3
  230. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/file-script.processor.js +28 -7
  231. package/src/services/assets/asset-processing-service/processors/script/node-module-script.processor.d.ts +42 -0
  232. package/src/services/assets/asset-processing-service/processors/script/node-module-script.processor.js +126 -0
  233. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/content-stylesheet.processor.d.ts +5 -2
  234. package/src/services/assets/asset-processing-service/processors/stylesheet/content-stylesheet.processor.js +59 -0
  235. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/file-stylesheet.processor.d.ts +2 -2
  236. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/file-stylesheet.processor.js +9 -3
  237. package/src/services/assets/asset-processing-service/ungrouped-dependency-processing.d.ts +18 -0
  238. package/src/services/assets/asset-processing-service/ungrouped-dependency-processing.js +45 -0
  239. package/src/services/assets/browser-bundle.service.d.ts +73 -0
  240. package/src/services/assets/browser-bundle.service.js +41 -0
  241. package/src/services/{page-request-cache-coordinator.service.d.ts → cache/page-request-cache-coordinator.service.d.ts} +2 -2
  242. package/src/services/{page-request-cache-coordinator.service.js → cache/page-request-cache-coordinator.service.js} +3 -1
  243. package/src/services/html/html-rewriter-provider.service.d.ts +40 -0
  244. package/src/services/html/html-rewriter-provider.service.js +68 -0
  245. package/src/services/html/html-transformer.service.d.ts +96 -0
  246. package/src/services/html/html-transformer.service.js +287 -0
  247. package/src/services/invalidation/development-invalidation.service.d.ts +74 -0
  248. package/src/services/invalidation/development-invalidation.service.js +190 -0
  249. package/src/services/module-loading/app-module-loader.service.d.ts +7 -0
  250. package/src/services/module-loading/app-module-loader.service.js +0 -0
  251. package/src/services/module-loading/app-server-module-transpiler.service.d.ts +24 -0
  252. package/src/services/module-loading/app-server-module-transpiler.service.js +151 -0
  253. package/src/services/module-loading/host-module-loader-registry.d.ts +4 -0
  254. package/src/services/module-loading/host-module-loader-registry.js +15 -0
  255. package/src/services/module-loading/module-loading-types.d.ts +2 -0
  256. package/src/services/module-loading/module-loading-types.js +0 -0
  257. package/src/services/module-loading/node-bootstrap-plugin.d.ts +42 -0
  258. package/src/services/module-loading/node-bootstrap-plugin.js +297 -0
  259. package/src/services/module-loading/page-module-import.service.d.ts +95 -0
  260. package/src/services/module-loading/page-module-import.service.js +191 -0
  261. package/src/services/module-loading/server-module-transpiler.service.d.ts +63 -0
  262. package/src/services/module-loading/server-module-transpiler.service.js +64 -0
  263. package/src/services/module-loading/source-module-support.d.ts +5 -0
  264. package/src/services/module-loading/source-module-support.js +8 -0
  265. package/src/services/runtime-state/dev-graph.service.d.ts +118 -0
  266. package/src/services/runtime-state/dev-graph.service.js +162 -0
  267. package/src/services/runtime-state/entrypoint-dependency-graph.service.d.ts +41 -0
  268. package/src/services/runtime-state/entrypoint-dependency-graph.service.js +85 -0
  269. package/src/services/runtime-state/server-invalidation-state.service.d.ts +26 -0
  270. package/src/services/runtime-state/server-invalidation-state.service.js +35 -0
  271. package/src/services/{schema-validation-service.d.ts → validation/schema-validation-service.d.ts} +1 -1
  272. package/src/static-site-generator/README.md +26 -0
  273. package/src/static-site-generator/static-site-generator.d.ts +67 -20
  274. package/src/static-site-generator/static-site-generator.js +182 -138
  275. package/src/{internal-types.d.ts → types/internal-types.d.ts} +62 -30
  276. package/src/types/internal-types.js +0 -0
  277. package/src/{public-types.d.ts → types/public-types.d.ts} +239 -35
  278. package/src/types/public-types.js +0 -0
  279. package/src/utils/html-escaping.d.ts +7 -0
  280. package/src/utils/html-escaping.js +6 -0
  281. package/src/utils/locals-utils.d.ts +1 -1
  282. package/src/utils/parse-cli-args.d.ts +4 -1
  283. package/src/utils/parse-cli-args.js +16 -1
  284. package/src/utils/resolve-work-dir.d.ts +11 -0
  285. package/src/utils/resolve-work-dir.js +31 -0
  286. package/src/watchers/project-watcher.d.ts +40 -29
  287. package/src/watchers/project-watcher.js +126 -116
  288. package/src/watchers/project-watcher.test-helpers.d.ts +2 -2
  289. package/src/watchers/project-watcher.test-helpers.js +6 -6
  290. package/CHANGELOG.md +0 -91
  291. package/src/adapters/abstract/application-adapter.ts +0 -337
  292. package/src/adapters/abstract/router-adapter.ts +0 -30
  293. package/src/adapters/abstract/server-adapter.ts +0 -79
  294. package/src/adapters/bun/client-bridge.ts +0 -62
  295. package/src/adapters/bun/create-app.ts +0 -189
  296. package/src/adapters/bun/define-api-handler.d.ts +0 -61
  297. package/src/adapters/bun/define-api-handler.ts +0 -114
  298. package/src/adapters/bun/hmr-manager.ts +0 -296
  299. package/src/adapters/bun/index.ts +0 -3
  300. package/src/adapters/bun/server-adapter.ts +0 -492
  301. package/src/adapters/bun/server-lifecycle.d.ts +0 -52
  302. package/src/adapters/bun/server-lifecycle.js +0 -120
  303. package/src/adapters/bun/server-lifecycle.ts +0 -154
  304. package/src/adapters/index.ts +0 -6
  305. package/src/adapters/node/create-app.ts +0 -179
  306. package/src/adapters/node/index.d.ts +0 -4
  307. package/src/adapters/node/index.js +0 -8
  308. package/src/adapters/node/index.ts +0 -9
  309. package/src/adapters/node/node-client-bridge.ts +0 -79
  310. package/src/adapters/node/node-hmr-manager.ts +0 -289
  311. package/src/adapters/node/server-adapter.ts +0 -561
  312. package/src/adapters/node/static-content-server.ts +0 -203
  313. package/src/adapters/shared/api-response.ts +0 -104
  314. package/src/adapters/shared/application-adapter.ts +0 -199
  315. package/src/adapters/shared/explicit-static-route-matcher.ts +0 -134
  316. package/src/adapters/shared/file-route-middleware-pipeline.ts +0 -123
  317. package/src/adapters/shared/fs-server-response-factory.ts +0 -118
  318. package/src/adapters/shared/fs-server-response-matcher.ts +0 -198
  319. package/src/adapters/shared/render-context.ts +0 -105
  320. package/src/adapters/shared/server-adapter.ts +0 -442
  321. package/src/adapters/shared/server-route-handler.ts +0 -166
  322. package/src/adapters/shared/server-static-builder.ts +0 -82
  323. package/src/build/build-adapter.ts +0 -132
  324. package/src/build/build-types.ts +0 -83
  325. package/src/build/esbuild-build-adapter.ts +0 -510
  326. package/src/config/config-builder.ts +0 -474
  327. package/src/constants.ts +0 -39
  328. package/src/create-app.ts +0 -87
  329. package/src/define-api-handler.js +0 -15
  330. package/src/define-api-handler.ts +0 -66
  331. package/src/dev/sc-server.ts +0 -143
  332. package/src/eco/component-render-context.d.ts +0 -105
  333. package/src/eco/component-render-context.js +0 -77
  334. package/src/eco/component-render-context.ts +0 -202
  335. package/src/eco/eco.ts +0 -221
  336. package/src/eco/eco.types.ts +0 -202
  337. package/src/eco/eco.utils.ts +0 -89
  338. package/src/eco/global-injector-map.ts +0 -112
  339. package/src/eco/lazy-injector-map.ts +0 -120
  340. package/src/eco/module-dependencies.ts +0 -75
  341. package/src/errors/http-error.ts +0 -72
  342. package/src/errors/index.ts +0 -2
  343. package/src/errors/locals-access-error.ts +0 -7
  344. package/src/global/app-logger.ts +0 -4
  345. package/src/hmr/client/hmr-runtime.ts +0 -121
  346. package/src/hmr/hmr-strategy.ts +0 -172
  347. package/src/hmr/hmr.test.e2e.ts +0 -75
  348. package/src/hmr/strategies/default-hmr-strategy.ts +0 -60
  349. package/src/hmr/strategies/js-hmr-strategy.ts +0 -320
  350. package/src/index.browser.ts +0 -3
  351. package/src/index.ts +0 -5
  352. package/src/integrations/ghtml/ghtml-renderer.ts +0 -93
  353. package/src/integrations/ghtml/ghtml.plugin.ts +0 -32
  354. package/src/internal-types.ts +0 -212
  355. package/src/plugins/alias-resolver-plugin.ts +0 -45
  356. package/src/plugins/eco-component-meta-plugin.ts +0 -474
  357. package/src/plugins/integration-plugin.ts +0 -184
  358. package/src/plugins/processor.ts +0 -220
  359. package/src/public-types.ts +0 -1260
  360. package/src/route-renderer/component-graph-executor.d.ts +0 -32
  361. package/src/route-renderer/component-graph-executor.js +0 -31
  362. package/src/route-renderer/component-graph-executor.ts +0 -84
  363. package/src/route-renderer/component-graph.d.ts +0 -42
  364. package/src/route-renderer/component-graph.js +0 -72
  365. package/src/route-renderer/component-graph.ts +0 -159
  366. package/src/route-renderer/component-marker.d.ts +0 -52
  367. package/src/route-renderer/component-marker.js +0 -46
  368. package/src/route-renderer/component-marker.ts +0 -117
  369. package/src/route-renderer/dependency-resolver.js +0 -428
  370. package/src/route-renderer/dependency-resolver.ts +0 -596
  371. package/src/route-renderer/html-post-processing.service.d.ts +0 -40
  372. package/src/route-renderer/html-post-processing.service.js +0 -86
  373. package/src/route-renderer/html-post-processing.service.ts +0 -103
  374. package/src/route-renderer/integration-renderer.d.ts +0 -339
  375. package/src/route-renderer/integration-renderer.js +0 -526
  376. package/src/route-renderer/integration-renderer.ts +0 -696
  377. package/src/route-renderer/marker-graph-resolver.d.ts +0 -76
  378. package/src/route-renderer/marker-graph-resolver.js +0 -93
  379. package/src/route-renderer/marker-graph-resolver.ts +0 -153
  380. package/src/route-renderer/page-module-loader.d.ts +0 -61
  381. package/src/route-renderer/page-module-loader.ts +0 -153
  382. package/src/route-renderer/render-execution.service.d.ts +0 -69
  383. package/src/route-renderer/render-execution.service.js +0 -91
  384. package/src/route-renderer/render-execution.service.ts +0 -158
  385. package/src/route-renderer/render-preparation.service.d.ts +0 -112
  386. package/src/route-renderer/render-preparation.service.js +0 -243
  387. package/src/route-renderer/render-preparation.service.ts +0 -358
  388. package/src/route-renderer/route-renderer.ts +0 -80
  389. package/src/router/fs-router-scanner.d.ts +0 -41
  390. package/src/router/fs-router-scanner.js +0 -155
  391. package/src/router/fs-router-scanner.ts +0 -217
  392. package/src/router/fs-router.d.ts +0 -26
  393. package/src/router/fs-router.js +0 -100
  394. package/src/router/fs-router.ts +0 -122
  395. package/src/services/asset-processing-service/asset-processing.service.d.ts +0 -41
  396. package/src/services/asset-processing-service/asset-processing.service.ts +0 -306
  397. package/src/services/asset-processing-service/asset.factory.ts +0 -105
  398. package/src/services/asset-processing-service/assets.types.ts +0 -112
  399. package/src/services/asset-processing-service/index.d.ts +0 -3
  400. package/src/services/asset-processing-service/index.js +0 -3
  401. package/src/services/asset-processing-service/index.ts +0 -3
  402. package/src/services/asset-processing-service/processor.interface.ts +0 -27
  403. package/src/services/asset-processing-service/processor.registry.ts +0 -18
  404. package/src/services/asset-processing-service/processors/base/base-processor.ts +0 -76
  405. package/src/services/asset-processing-service/processors/base/base-script-processor.d.ts +0 -16
  406. package/src/services/asset-processing-service/processors/base/base-script-processor.js +0 -80
  407. package/src/services/asset-processing-service/processors/base/base-script-processor.ts +0 -105
  408. package/src/services/asset-processing-service/processors/index.d.ts +0 -5
  409. package/src/services/asset-processing-service/processors/index.js +0 -5
  410. package/src/services/asset-processing-service/processors/index.ts +0 -5
  411. package/src/services/asset-processing-service/processors/script/content-script.processor.js +0 -57
  412. package/src/services/asset-processing-service/processors/script/content-script.processor.ts +0 -66
  413. package/src/services/asset-processing-service/processors/script/file-script.processor.ts +0 -88
  414. package/src/services/asset-processing-service/processors/script/node-module-script.processor.d.ts +0 -7
  415. package/src/services/asset-processing-service/processors/script/node-module-script.processor.js +0 -74
  416. package/src/services/asset-processing-service/processors/script/node-module-script.processor.ts +0 -84
  417. package/src/services/asset-processing-service/processors/stylesheet/content-stylesheet.processor.js +0 -25
  418. package/src/services/asset-processing-service/processors/stylesheet/content-stylesheet.processor.ts +0 -27
  419. package/src/services/asset-processing-service/processors/stylesheet/file-stylesheet.processor.ts +0 -77
  420. package/src/services/cache/cache.types.ts +0 -126
  421. package/src/services/cache/index.ts +0 -18
  422. package/src/services/cache/memory-cache-store.ts +0 -130
  423. package/src/services/cache/page-cache-service.ts +0 -202
  424. package/src/services/html-transformer.service.d.ts +0 -50
  425. package/src/services/html-transformer.service.js +0 -163
  426. package/src/services/html-transformer.service.ts +0 -217
  427. package/src/services/page-module-import.service.d.ts +0 -37
  428. package/src/services/page-module-import.service.js +0 -88
  429. package/src/services/page-module-import.service.ts +0 -129
  430. package/src/services/page-request-cache-coordinator.service.ts +0 -128
  431. package/src/services/schema-validation-service.ts +0 -204
  432. package/src/services/validation/standard-schema.types.ts +0 -68
  433. package/src/static-site-generator/static-site-generator.ts +0 -359
  434. package/src/utils/css.d.ts +0 -1
  435. package/src/utils/css.js +0 -7
  436. package/src/utils/css.ts +0 -5
  437. package/src/utils/deep-merge.ts +0 -47
  438. package/src/utils/hash.ts +0 -5
  439. package/src/utils/html.ts +0 -1
  440. package/src/utils/invariant.ts +0 -15
  441. package/src/utils/locals-utils.ts +0 -37
  442. package/src/utils/parse-cli-args.ts +0 -83
  443. package/src/utils/path-utils.module.ts +0 -14
  444. package/src/utils/runtime.ts +0 -44
  445. package/src/utils/server-utils.module.ts +0 -67
  446. package/src/watchers/project-watcher.test-helpers.ts +0 -41
  447. package/src/watchers/project-watcher.ts +0 -344
  448. /package/src/adapters/{bun → shared}/define-api-handler.js +0 -0
  449. /package/src/{internal-types.js → adapters/shared/runtime-host.js} +0 -0
  450. /package/src/{public-types.js → adapters/shared/static-preview-host.js} +0 -0
  451. /package/src/{services/asset-processing-service/assets.types.js → plugins/runtime-capability.js} +0 -0
  452. /package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.interface.js +0 -0
  453. /package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.registry.js +0 -0
  454. /package/src/services/{schema-validation-service.js → validation/schema-validation-service.js} +0 -0
@@ -1,37 +1,58 @@
1
1
  import { createServer } from "node:http";
2
2
  import path from "node:path";
3
+ import { WebSocketServer } from "ws";
3
4
  import { fileSystem } from "@ecopages/file-system";
4
- import { RESOLVED_ASSETS_DIR } from "../../constants.js";
5
- import { defaultBuildAdapter } from "../../build/build-adapter.js";
5
+ import { getAppBrowserBuildPlugins, setupAppRuntimePlugins } from "../../build/build-adapter.js";
6
+ import { installAppRuntimeBuildExecutor } from "../../build/runtime-build-executor.js";
7
+ import { RESOLVED_ASSETS_DIR } from "../../config/constants.js";
6
8
  import { appLogger } from "../../global/app-logger.js";
7
- import { ProjectWatcher } from "../../watchers/project-watcher.js";
8
9
  import { NodeClientBridge } from "./node-client-bridge.js";
9
10
  import { NodeHmrManager } from "./node-hmr-manager.js";
11
+ import { ProjectWatcher } from "../../watchers/project-watcher.js";
10
12
  import { StaticSiteGenerator } from "../../static-site-generator/static-site-generator.js";
11
13
  import { SharedServerAdapter } from "../shared/server-adapter.js";
12
14
  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
- }
15
+ import { DEFAULT_ECOPAGES_HOSTNAME, DEFAULT_ECOPAGES_PORT } from "../../config/constants.js";
16
+ import {
17
+ injectHmrRuntimeIntoHtmlResponse,
18
+ isHtmlResponse,
19
+ shouldInjectHmrHtmlResponse
20
+ } from "../shared/hmr-html-response.js";
21
+ import { resolveServeRuntimeOrigin } from "../shared/runtime-app-bootstrap.js";
22
+ import { NodeClientAbortError, NodeHttpRequestBridge } from "./http-request-bridge.js";
23
+ import { NodeStaticPreviewHost } from "./static-preview-host.js";
24
+ import { DefaultNodeServerDevRuntimeFactory } from "./server-adapter-dependencies.js";
20
25
  class NodeServerAdapter extends SharedServerAdapter {
21
26
  serverInstance = null;
22
27
  initialized = false;
23
28
  apiHandlers;
24
29
  staticRoutes;
25
30
  errorHandler;
26
- previewServer = null;
27
31
  bridge = null;
28
32
  hmrManager = null;
29
- processorBuildPlugins = [];
33
+ previewHost;
34
+ requestBridge;
35
+ devRuntimeFactory;
36
+ shouldInjectHmrScript() {
37
+ return shouldInjectHmrHtmlResponse(this.options?.watch === true, this.hmrManager ?? void 0);
38
+ }
39
+ isHtmlResponse(response) {
40
+ return isHtmlResponse(response);
41
+ }
42
+ async maybeInjectHmrScript(response) {
43
+ if (this.shouldInjectHmrScript() && this.isHtmlResponse(response)) {
44
+ return injectHmrRuntimeIntoHtmlResponse(response);
45
+ }
46
+ return response;
47
+ }
30
48
  constructor(options) {
31
49
  super(options);
32
50
  this.apiHandlers = options.apiHandlers || [];
33
51
  this.staticRoutes = options.staticRoutes || [];
34
52
  this.errorHandler = options.errorHandler;
53
+ this.previewHost = options.previewHost;
54
+ this.requestBridge = options.requestBridge;
55
+ this.devRuntimeFactory = options.devRuntimeFactory;
35
56
  }
36
57
  /**
37
58
  * Prepares the adapter for use.
@@ -47,85 +68,35 @@ class NodeServerAdapter extends SharedServerAdapter {
47
68
  * processors during their `setup()` calls.
48
69
  */
49
70
  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);
71
+ installAppRuntimeBuildExecutor(this.appConfig, {
72
+ development: this.options?.watch === true
73
+ });
74
+ this.prepareRuntimePublicDir();
75
+ await setupAppRuntimePlugins({
76
+ appConfig: this.appConfig,
77
+ runtimeOrigin: this.runtimeOrigin,
78
+ hmrManager: this.hmrManager ?? void 0
79
+ });
80
+ await this.initializeSharedRouteHandling({
81
+ staticRoutes: this.staticRoutes,
82
+ hmrManager: this.hmrManager ?? void 0
83
+ });
55
84
  this.staticSiteGenerator = new StaticSiteGenerator({ appConfig: this.appConfig });
56
85
  this.staticBuilder = new ServerStaticBuilder({
57
86
  appConfig: this.appConfig,
58
87
  staticSiteGenerator: this.staticSiteGenerator,
59
- serveOptions: this.serveOptions
88
+ serveOptions: this.serveOptions,
89
+ apiHandlers: this.apiHandlers
60
90
  });
61
91
  this.initialized = true;
62
92
  }
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() {
93
+ prepareRuntimePublicDir() {
78
94
  const srcPublicDir = path.join(this.appConfig.rootDir, this.appConfig.srcDir, this.appConfig.publicDir);
79
95
  if (fileSystem.exists(srcPublicDir)) {
80
96
  fileSystem.copyDir(srcPublicDir, path.join(this.appConfig.rootDir, this.appConfig.distDir));
81
97
  }
82
98
  fileSystem.ensureDir(path.join(this.appConfig.absolutePaths.distDir, RESOLVED_ASSETS_DIR));
83
99
  }
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
100
  getServerOptions() {
130
101
  return {
131
102
  ...this.serveOptions
@@ -136,9 +107,10 @@ class NodeServerAdapter extends SharedServerAdapter {
136
107
  await this.initialize();
137
108
  }
138
109
  const buildServer = await this.startBuildRuntimeServer();
110
+ const buildRuntimeOrigin = this.getListeningServerOrigin(buildServer);
139
111
  try {
140
112
  await this.staticBuilder.build(
141
- { preview: false },
113
+ { preview: false, baseUrl: buildRuntimeOrigin },
142
114
  {
143
115
  router: this.router,
144
116
  routeRendererFactory: this.routeRendererFactory,
@@ -151,117 +123,27 @@ class NodeServerAdapter extends SharedServerAdapter {
151
123
  if (!options?.preview) {
152
124
  return;
153
125
  }
154
- if (this.previewServer) {
155
- await this.previewServer.stop();
156
- }
157
- this.previewServer = new NodeStaticContentServer({
126
+ await this.previewHost.start({
158
127
  appConfig: this.appConfig,
159
- options: {
160
- hostname: this.serveOptions.hostname,
161
- port: Number(this.serveOptions.port || 3e3)
162
- }
128
+ hostname: String(this.serveOptions.hostname || DEFAULT_ECOPAGES_HOSTNAME),
129
+ port: Number(this.serveOptions.port || DEFAULT_ECOPAGES_PORT)
163
130
  });
164
- await this.previewServer.start();
165
- const previewHostname = this.serveOptions.hostname || "localhost";
166
- const previewPort = this.serveOptions.port || 3e3;
131
+ const previewHostname = this.serveOptions.hostname || DEFAULT_ECOPAGES_HOSTNAME;
132
+ const previewPort = this.serveOptions.port || DEFAULT_ECOPAGES_PORT;
167
133
  appLogger.info(`Preview running at http://${previewHostname}:${previewPort}`);
168
134
  }
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
135
  async startBuildRuntimeServer() {
257
- const hostname = String(this.serveOptions.hostname || "localhost");
258
- const port = Number(this.serveOptions.port || 3e3);
136
+ const hostname = String(this.serveOptions.hostname || DEFAULT_ECOPAGES_HOSTNAME);
137
+ const port = 0;
259
138
  const server = createServer(async (req, res) => {
260
139
  try {
261
- const webRequest = this.createWebRequest(req);
140
+ const webRequest = this.requestBridge.createWebRequest(req, this.runtimeOrigin);
262
141
  const response = await this.handleRequest(webRequest);
263
- await this.sendNodeResponse(res, response);
142
+ await this.requestBridge.sendNodeResponse(res, response);
264
143
  } catch (error) {
144
+ if (error instanceof NodeClientAbortError) {
145
+ return;
146
+ }
265
147
  appLogger.error("Node static build runtime request failed", error);
266
148
  res.statusCode = 500;
267
149
  res.end("Internal Server Error");
@@ -275,9 +157,17 @@ class NodeServerAdapter extends SharedServerAdapter {
275
157
  });
276
158
  });
277
159
  this.serverInstance = server;
278
- appLogger.info(`Server running at http://${hostname}:${port}`);
160
+ appLogger.info(`Server running at ${this.getListeningServerOrigin(server)}`);
279
161
  return server;
280
162
  }
163
+ getListeningServerOrigin(server) {
164
+ const address = server.address();
165
+ const hostname = String(this.serveOptions.hostname || DEFAULT_ECOPAGES_HOSTNAME);
166
+ if (!address || typeof address === "string") {
167
+ throw new Error("Build runtime server did not expose a numeric listening port");
168
+ }
169
+ return `http://${hostname}:${address.port}`;
170
+ }
281
171
  /**
282
172
  * Gracefully shuts down the ephemeral build runtime server.
283
173
  *
@@ -325,19 +215,20 @@ class NodeServerAdapter extends SharedServerAdapter {
325
215
  * underlying socket closes early — into a 499 response so it does not
326
216
  * incorrectly surface as a 500 in application logs.
327
217
  */
328
- async handleRequest(_request) {
218
+ async handleRequest(request) {
329
219
  if (!this.initialized) {
330
220
  throw new Error("Node server adapter is not initialized. Call createAdapter() first.");
331
221
  }
332
222
  try {
333
- return await this.handleSharedRequest(_request, {
223
+ const response = await this.handleSharedRequest(request, {
334
224
  apiHandlers: this.apiHandlers,
335
225
  errorHandler: this.errorHandler,
336
226
  serverInstance: this.serverInstance,
337
227
  hmrManager: this.hmrManager
338
228
  });
229
+ return await this.maybeInjectHmrScript(response);
339
230
  } catch (error) {
340
- if (error instanceof ClientAbortError) {
231
+ if (error instanceof NodeClientAbortError) {
341
232
  return new Response(null, { status: 499 });
342
233
  }
343
234
  throw error;
@@ -353,22 +244,22 @@ class NodeServerAdapter extends SharedServerAdapter {
353
244
  * broadcast + heartbeat cleanup.
354
245
  * - `NodeHmrManager` watches the filesystem and triggers incremental esbuild
355
246
  * 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.
247
+ * - Shared watcher bootstrapping listens for route-level file changes and
248
+ * refreshes the router and response handlers when pages are added or removed.
358
249
  *
359
250
  * WebSocket upgrade requests that do not target `/_hmr` are rejected with an
360
251
  * immediate socket destroy to prevent unhandled upgrade leaks.
361
252
  */
362
- async completeInitialization(_server) {
363
- this.serverInstance = _server;
253
+ async completeInitialization(server) {
254
+ this.serverInstance = server;
364
255
  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 });
256
+ const devRuntime = this.devRuntimeFactory.create({ appConfig: this.appConfig });
257
+ const wss = devRuntime.websocketServer;
258
+ this.bridge = devRuntime.bridge;
259
+ this.hmrManager = devRuntime.hmrManager;
369
260
  this.hmrManager.setEnabled(true);
370
261
  await this.hmrManager.buildRuntime();
371
- _server.on("upgrade", (req, socket, head) => {
262
+ server.on("upgrade", (req, socket, head) => {
372
263
  const url = new URL(req.url ?? "/", this.runtimeOrigin);
373
264
  if (url.pathname === "/_hmr") {
374
265
  wss.handleUpgrade(req, socket, head, (ws) => {
@@ -380,19 +271,18 @@ class NodeServerAdapter extends SharedServerAdapter {
380
271
  socket.destroy();
381
272
  }
382
273
  });
383
- const loaderPlugins = Array.from(this.appConfig.loaders.values());
384
- const hmrBuildPlugins = [...loaderPlugins, ...this.processorBuildPlugins];
385
- this.hmrManager.setPlugins(hmrBuildPlugins);
274
+ const browserBuildPlugins = getAppBrowserBuildPlugins(this.appConfig);
275
+ this.hmrManager.setPlugins(browserBuildPlugins);
386
276
  for (const integration of this.appConfig.integrations) {
387
277
  integration.setHmrManager(this.hmrManager);
388
278
  }
389
279
  this.configureSharedResponseHandlers(this.staticRoutes, this.hmrManager);
390
280
  const watcher = new ProjectWatcher({
391
281
  config: this.appConfig,
392
- refreshRouterRoutesCallback: async () => {
393
- await this.initSharedRouter();
394
- this.configureSharedResponseHandlers(this.staticRoutes, this.hmrManager);
395
- },
282
+ refreshRouterRoutesCallback: this.createSharedWatchRefreshCallback({
283
+ staticRoutes: this.staticRoutes,
284
+ hmrManager: this.hmrManager
285
+ }),
396
286
  hmrManager: this.hmrManager,
397
287
  bridge: this.bridge
398
288
  });
@@ -407,10 +297,16 @@ class NodeServerAdapter extends SharedServerAdapter {
407
297
  }
408
298
  }
409
299
  async function createNodeServerAdapter(params) {
410
- const runtimeOrigin = params.runtimeOrigin ?? `http://${params.serveOptions.hostname || "localhost"}:${params.serveOptions.port || 3e3}`;
300
+ const runtimeOrigin = params.runtimeOrigin ?? resolveServeRuntimeOrigin(params.serveOptions);
301
+ const previewHost = params.previewHost ?? new NodeStaticPreviewHost();
302
+ const requestBridge = params.requestBridge ?? new NodeHttpRequestBridge();
303
+ const devRuntimeFactory = params.devRuntimeFactory ?? new DefaultNodeServerDevRuntimeFactory();
411
304
  const adapter = new NodeServerAdapter({
412
305
  ...params,
413
- runtimeOrigin
306
+ runtimeOrigin,
307
+ previewHost,
308
+ requestBridge,
309
+ devRuntimeFactory
414
310
  });
415
311
  return adapter.createAdapter();
416
312
  }
@@ -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 {};