@ecopages/core 0.2.0-alpha.27 → 0.2.0-alpha.28

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