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

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 +84 -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 +239 -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 +437 -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,52 +1,51 @@
1
1
  import path from "node:path";
2
2
  import { appLogger } from "../../global/app-logger.js";
3
- import { PageModuleImportService } from "../../services/page-module-import.service.js";
4
- import { PageRequestCacheCoordinator } from "../../services/page-request-cache-coordinator.service.js";
3
+ import { PageRequestCacheCoordinator } from "../../services/cache/page-request-cache-coordinator.service.js";
5
4
  import { ServerUtils } from "../../utils/server-utils.module.js";
6
5
  import { FileRouteMiddlewarePipeline } from "./file-route-middleware-pipeline.js";
7
6
  import { LocalsAccessError } from "../../errors/locals-access-error.js";
8
7
  import { isDevelopmentRuntime } from "../../utils/runtime.js";
9
- const FILE_SYSTEM_RESPONSE_MATCHER_ERRORS = {
10
- transpilePageModuleFailed: (details) => `Error transpiling page module: ${details}`,
11
- noTranspiledOutputForPageModule: (filePath) => `No transpiled output generated for page module: ${filePath}`
12
- };
13
8
  class FileSystemResponseMatcher {
9
+ appConfig;
10
+ assetPrefix;
14
11
  router;
15
12
  routeRendererFactory;
16
13
  fileSystemResponseFactory;
17
- pageModuleImportService;
18
14
  pageRequestCacheCoordinator;
19
15
  fileRouteMiddlewarePipeline;
20
16
  constructor({
17
+ appConfig,
18
+ assetPrefix,
21
19
  router,
22
20
  routeRendererFactory,
23
21
  fileSystemResponseFactory,
24
22
  cacheService = null,
25
23
  defaultCacheStrategy = "static"
26
24
  }) {
25
+ this.appConfig = appConfig;
26
+ this.assetPrefix = assetPrefix;
27
27
  this.router = router;
28
28
  this.routeRendererFactory = routeRendererFactory;
29
29
  this.fileSystemResponseFactory = fileSystemResponseFactory;
30
- this.pageModuleImportService = new PageModuleImportService();
31
30
  this.pageRequestCacheCoordinator = new PageRequestCacheCoordinator(cacheService, defaultCacheStrategy);
32
31
  this.fileRouteMiddlewarePipeline = new FileRouteMiddlewarePipeline(cacheService);
33
32
  }
34
33
  /**
35
34
  * Resolves unmatched paths either as static asset requests or as the custom
36
35
  * not-found page.
37
- *
38
36
  * @param requestUrl Incoming pathname.
39
37
  * @returns Static file response or rendered 404 response.
40
38
  */
41
39
  async handleNoMatch(requestUrl) {
42
40
  const isStaticFileRequest = ServerUtils.hasKnownExtension(requestUrl);
43
41
  if (!isStaticFileRequest) {
44
- return this.fileSystemResponseFactory.createCustomNotFoundResponse();
42
+ return this.renderCustomNotFoundResponse();
45
43
  }
46
44
  const relativeUrl = requestUrl.startsWith("/") ? requestUrl.slice(1) : requestUrl;
47
- const filePath = path.join(this.router.assetPrefix, relativeUrl);
45
+ const filePath = path.join(this.assetPrefix, relativeUrl);
48
46
  const contentType = ServerUtils.getContentType(filePath);
49
- return this.fileSystemResponseFactory.createFileResponse(filePath, contentType);
47
+ const response = await this.fileSystemResponseFactory.createFileResponse(filePath, contentType);
48
+ return response ?? this.renderCustomNotFoundResponse();
50
49
  }
51
50
  /**
52
51
  * Handles a matched file-system page route.
@@ -60,34 +59,25 @@ class FileSystemResponseMatcher {
60
59
  * @returns Final response for the matched route.
61
60
  */
62
61
  async handleMatch(match, request) {
63
- const cacheKey = this.pageRequestCacheCoordinator.buildCacheKey(match);
64
62
  try {
65
- const resolvedRequest = request ?? new Request(new URL(cacheKey, this.router.origin).toString(), {
66
- method: "GET"
67
- });
68
- const localsStore = {};
69
- const pageModule = await this.importPageModule(match.filePath);
70
- const Page = pageModule?.default;
71
- const pageMiddleware = Page?.middleware ?? [];
72
- const pageCacheStrategy = Page?.cache ?? this.pageRequestCacheCoordinator.getDefaultCacheStrategy();
73
- const localsForRender = pageCacheStrategy === "dynamic" ? localsStore : void 0;
63
+ const executionPlan = await this.createExecutionPlan(match, request);
74
64
  this.fileRouteMiddlewarePipeline.assertValidConfiguration({
75
- middleware: pageMiddleware,
76
- pageCacheStrategy,
77
- filePath: match.filePath
65
+ middleware: executionPlan.pageMiddleware,
66
+ pageCacheStrategy: executionPlan.pageCacheStrategy,
67
+ filePath: executionPlan.pageFilePath
78
68
  });
79
- const routeRenderer = this.routeRendererFactory.createRenderer(match.filePath);
69
+ const routeRenderer = this.routeRendererFactory.getPageRenderer(executionPlan.pageFilePath);
80
70
  const middlewareContext = this.fileRouteMiddlewarePipeline.createContext({
81
- request: resolvedRequest,
71
+ request: executionPlan.request,
82
72
  params: match.params,
83
- locals: localsStore
73
+ locals: executionPlan.localsStore
84
74
  });
85
75
  const renderFn = async () => {
86
- const result = await routeRenderer.createRoute({
87
- file: match.filePath,
76
+ const result = await routeRenderer.execute({
77
+ file: executionPlan.pageFilePath,
88
78
  params: match.params,
89
79
  query: match.query,
90
- locals: localsForRender
80
+ locals: executionPlan.localsForRender
91
81
  });
92
82
  const html = await this.pageRequestCacheCoordinator.bodyToString(result.body);
93
83
  const strategy = result.cacheStrategy ?? this.pageRequestCacheCoordinator.getDefaultCacheStrategy();
@@ -95,13 +85,13 @@ class FileSystemResponseMatcher {
95
85
  };
96
86
  const renderResponse = async () => {
97
87
  return this.pageRequestCacheCoordinator.render({
98
- cacheKey,
99
- pageCacheStrategy,
88
+ cacheKey: executionPlan.cacheKey,
89
+ pageCacheStrategy: executionPlan.pageCacheStrategy,
100
90
  renderFn
101
91
  });
102
92
  };
103
93
  return await this.fileRouteMiddlewarePipeline.run({
104
- middleware: pageMiddleware,
94
+ middleware: executionPlan.pageMiddleware,
105
95
  context: middlewareContext,
106
96
  renderResponse
107
97
  });
@@ -117,29 +107,71 @@ class FileSystemResponseMatcher {
117
107
  }
118
108
  if (error instanceof Error) {
119
109
  if (isDevelopmentRuntime() || appLogger.isDebugEnabled()) {
120
- appLogger.error(`[FileSystemResponseMatcher] ${error.message} at ${match.pathname}`);
110
+ appLogger.error(`[FileSystemResponseMatcher] ${error.message} at ${match.requestedPathname}`);
121
111
  }
122
112
  }
123
- return this.fileSystemResponseFactory.createCustomNotFoundResponse();
113
+ return this.renderCustomNotFoundResponse();
114
+ }
115
+ }
116
+ /**
117
+ * Renders the app-owned custom 404 page, falling back to the default text 404
118
+ * when the page template cannot be resolved.
119
+ */
120
+ async renderCustomNotFoundResponse() {
121
+ const error404TemplatePath = this.appConfig.absolutePaths.error404TemplatePath;
122
+ try {
123
+ const routeRenderer = this.routeRendererFactory.getPageRenderer(error404TemplatePath);
124
+ const result = await routeRenderer.execute({
125
+ file: error404TemplatePath
126
+ });
127
+ return this.fileSystemResponseFactory.createHtmlNotFoundResponse(result.body);
128
+ } catch {
129
+ appLogger.debug(
130
+ "Custom 404 template not found, falling back to default 404 response",
131
+ error404TemplatePath
132
+ );
133
+ return this.fileSystemResponseFactory.createDefaultNotFoundResponse();
124
134
  }
125
135
  }
136
+ async createExecutionPlan(match, request) {
137
+ const cacheKey = this.pageRequestCacheCoordinator.buildCacheKey({
138
+ pathname: match.requestedPathname,
139
+ query: match.query
140
+ });
141
+ const resolvedRequest = request ?? new Request(new URL(cacheKey, this.router.origin).toString(), {
142
+ method: "GET"
143
+ });
144
+ const localsStore = {};
145
+ const pageFilePath = match.templateRoute.filePath;
146
+ const pageModule = await this.importPageModule(pageFilePath);
147
+ const Page = pageModule?.default;
148
+ const pageMiddleware = Page?.middleware ?? [];
149
+ const pageCacheStrategy = Page?.cache ?? this.pageRequestCacheCoordinator.getDefaultCacheStrategy();
150
+ return {
151
+ cacheKey,
152
+ request: resolvedRequest,
153
+ pageFilePath,
154
+ pageMiddleware,
155
+ pageCacheStrategy,
156
+ localsStore,
157
+ localsForRender: pageCacheStrategy === "dynamic" ? localsStore : void 0
158
+ };
159
+ }
126
160
  /**
127
161
  * Loads the matched page module for request-time inspection.
128
162
  *
129
163
  * The matcher needs access to page-level metadata such as `cache` and
130
- * `middleware` before full rendering starts, so it uses the shared module
131
- * import service directly rather than going through route rendering.
164
+ * `middleware` before full rendering starts, so it asks the owning route
165
+ * renderer to load the page module. That preserves integration-specific page
166
+ * import setup for request-time inspection as well as for full rendering.
132
167
  *
133
168
  * @param filePath Absolute page module path.
134
169
  * @returns Imported page module.
135
170
  */
136
171
  async importPageModule(filePath) {
137
- return this.pageModuleImportService.importModule({
138
- filePath,
139
- rootDir: path.dirname(this.router.assetPrefix),
140
- outdir: path.join(this.router.assetPrefix, ".server-modules-meta"),
141
- transpileErrorMessage: FILE_SYSTEM_RESPONSE_MATCHER_ERRORS.transpilePageModuleFailed,
142
- noOutputMessage: FILE_SYSTEM_RESPONSE_MATCHER_ERRORS.noTranspiledOutputForPageModule
172
+ const routeRenderer = this.routeRendererFactory.getPageRenderer(filePath);
173
+ return routeRenderer.loadPageModule(filePath, {
174
+ cacheScope: "request-metadata"
143
175
  });
144
176
  }
145
177
  /**
@@ -150,6 +182,5 @@ class FileSystemResponseMatcher {
150
182
  }
151
183
  }
152
184
  export {
153
- FILE_SYSTEM_RESPONSE_MATCHER_ERRORS,
154
185
  FileSystemResponseMatcher
155
186
  };
@@ -0,0 +1,55 @@
1
+ /**
2
+ * Shared runtime state used while registering HMR-owned entrypoints.
3
+ */
4
+ export interface HmrEntrypointRegistrarOptions {
5
+ /** Absolute source directory used to derive the emitted HMR path. */
6
+ srcDir: string;
7
+ /** Absolute distribution directory where HMR outputs are written. */
8
+ distDir: string;
9
+ /** In-flight registrations keyed by normalized absolute entrypoint path. */
10
+ entrypointRegistrations: Map<string, Promise<string>>;
11
+ /** Stable entrypoint-to-output mapping retained once an entrypoint is registered. */
12
+ watchedFiles: Map<string, string>;
13
+ /** Runtime-specific cleanup invoked when an entrypoint registration fails. */
14
+ clearFailedRegistration?: (entrypointPath: string) => void;
15
+ /** Development-only guardrail for integrations that never finish producing output. */
16
+ registrationTimeoutMs: number;
17
+ }
18
+ /**
19
+ * Runtime-specific hooks required to materialize a single HMR entrypoint.
20
+ */
21
+ export interface HmrEntrypointRegistrationOptions {
22
+ /**
23
+ * Emits the browser-consumable HMR artifact for an entrypoint.
24
+ */
25
+ emit(entrypointPath: string, outputPath: string): Promise<void>;
26
+ /**
27
+ * Creates the runtime-specific error raised when the emit hook completes without producing output.
28
+ */
29
+ getMissingOutputError(entrypointPath: string, outputPath: string): Error;
30
+ }
31
+ /**
32
+ * Coordinates the shared HMR entrypoint registration lifecycle for both Node and Bun managers.
33
+ *
34
+ * The registrar owns the cross-runtime policy: normalize entrypoint identities, dedupe concurrent
35
+ * registrations, derive the emitted `_hmr` output path, clear stale output before rebuilding, and
36
+ * apply the development timeout that prevents unresolved registrations from hanging navigation.
37
+ * Runtime-specific managers remain responsible for the actual emit step and any cleanup outside
38
+ * this shared registration flow.
39
+ */
40
+ export declare class HmrEntrypointRegistrar {
41
+ private readonly options;
42
+ constructor(options: HmrEntrypointRegistrarOptions);
43
+ /**
44
+ * Registers a single source entrypoint and returns the browser URL for its emitted HMR module.
45
+ *
46
+ * Concurrent requests for the same normalized entrypoint share the same in-flight promise so the
47
+ * integration only builds once per registration cycle.
48
+ */
49
+ registerEntrypoint(entrypointPath: string, registrationOptions: HmrEntrypointRegistrationOptions): Promise<string>;
50
+ private registerEntrypointInternal;
51
+ private awaitEntrypointRegistration;
52
+ private getEntrypointOutput;
53
+ private removeStaleEntrypointOutput;
54
+ private encodeDynamicSegments;
55
+ }
@@ -0,0 +1,87 @@
1
+ import path from "node:path";
2
+ import { fileSystem } from "@ecopages/file-system";
3
+ import { appLogger } from "../../global/app-logger.js";
4
+ import { RESOLVED_ASSETS_DIR } from "../../config/constants.js";
5
+ class HmrEntrypointRegistrar {
6
+ options;
7
+ constructor(options) {
8
+ this.options = options;
9
+ }
10
+ /**
11
+ * Registers a single source entrypoint and returns the browser URL for its emitted HMR module.
12
+ *
13
+ * Concurrent requests for the same normalized entrypoint share the same in-flight promise so the
14
+ * integration only builds once per registration cycle.
15
+ */
16
+ async registerEntrypoint(entrypointPath, registrationOptions) {
17
+ const normalizedEntrypoint = path.resolve(entrypointPath);
18
+ const existingRegistration = this.options.entrypointRegistrations.get(normalizedEntrypoint);
19
+ if (existingRegistration) {
20
+ return await this.awaitEntrypointRegistration(existingRegistration, normalizedEntrypoint);
21
+ }
22
+ const registration = this.registerEntrypointInternal(normalizedEntrypoint, registrationOptions);
23
+ this.options.entrypointRegistrations.set(normalizedEntrypoint, registration);
24
+ try {
25
+ return await this.awaitEntrypointRegistration(registration, normalizedEntrypoint);
26
+ } catch (error) {
27
+ this.options.clearFailedRegistration?.(normalizedEntrypoint);
28
+ throw error;
29
+ } finally {
30
+ this.options.entrypointRegistrations.delete(normalizedEntrypoint);
31
+ }
32
+ }
33
+ async registerEntrypointInternal(entrypointPath, registrationOptions) {
34
+ if (this.options.watchedFiles.has(entrypointPath)) {
35
+ return this.options.watchedFiles.get(entrypointPath);
36
+ }
37
+ const { outputPath, outputUrl } = this.getEntrypointOutput(entrypointPath);
38
+ this.options.watchedFiles.set(entrypointPath, outputUrl);
39
+ this.removeStaleEntrypointOutput(outputPath);
40
+ await registrationOptions.emit(entrypointPath, outputPath);
41
+ if (!fileSystem.exists(outputPath)) {
42
+ throw registrationOptions.getMissingOutputError(entrypointPath, outputPath);
43
+ }
44
+ return outputUrl;
45
+ }
46
+ async awaitEntrypointRegistration(registration, entrypointPath) {
47
+ if (process.env.NODE_ENV !== "development") {
48
+ return await registration;
49
+ }
50
+ return await Promise.race([
51
+ registration,
52
+ new Promise((_, reject) => {
53
+ setTimeout(() => {
54
+ reject(new Error(`[HMR] Timed out registering entrypoint: ${entrypointPath}`));
55
+ }, this.options.registrationTimeoutMs);
56
+ })
57
+ ]);
58
+ }
59
+ getEntrypointOutput(entrypointPath) {
60
+ const relativePath = path.relative(this.options.srcDir, entrypointPath);
61
+ const relativePathJs = relativePath.replace(/\.(tsx?|jsx?|mdx?)$/, ".js");
62
+ const encodedPathJs = this.encodeDynamicSegments(relativePathJs);
63
+ const urlPath = encodedPathJs.split(path.sep).join("/");
64
+ return {
65
+ outputUrl: `/${path.join(RESOLVED_ASSETS_DIR, "_hmr", urlPath)}`,
66
+ outputPath: path.join(this.options.distDir, urlPath)
67
+ };
68
+ }
69
+ removeStaleEntrypointOutput(outputPath) {
70
+ if (!fileSystem.exists(outputPath)) {
71
+ return;
72
+ }
73
+ try {
74
+ fileSystem.remove(outputPath);
75
+ } catch (error) {
76
+ appLogger.warn(
77
+ `[HMR] Failed to remove stale entrypoint output ${outputPath}: ${error instanceof Error ? error.message : String(error)}`
78
+ );
79
+ }
80
+ }
81
+ encodeDynamicSegments(filepath) {
82
+ return filepath.replace(/\[([^\]]+)\]/g, "_$1_");
83
+ }
84
+ }
85
+ export {
86
+ HmrEntrypointRegistrar
87
+ };
@@ -0,0 +1,22 @@
1
+ import type { IHmrManager } from '../../types/public-types.js';
2
+ /**
3
+ * Returns whether a response is HTML and therefore eligible for development HMR
4
+ * runtime injection.
5
+ */
6
+ export declare function isHtmlResponse(response: Response): boolean;
7
+ /**
8
+ * Returns whether HTML responses should receive the HMR runtime bootstrap.
9
+ *
10
+ * This is shared because filesystem page responses and adapter-level HTML
11
+ * responses flow through different layers, but both need identical injection
12
+ * behavior in watch mode.
13
+ */
14
+ export declare function shouldInjectHmrHtmlResponse(watch: boolean, hmrManager?: Pick<IHmrManager, 'isEnabled'>): boolean;
15
+ /**
16
+ * Injects the development HMR runtime script into an HTML response if it is not
17
+ * already present.
18
+ *
19
+ * The check is intentionally idempotent because an HTML response can pass
20
+ * through more than one development-layer wrapper before reaching the client.
21
+ */
22
+ export declare function injectHmrRuntimeIntoHtmlResponse(response: Response): Promise<Response>;
@@ -0,0 +1,33 @@
1
+ const HMR_RUNTIME_IMPORT = "import '/_hmr_runtime.js'";
2
+ const HMR_RUNTIME_SCRIPT = `<script type="module">${HMR_RUNTIME_IMPORT};<\/script>`;
3
+ function isHtmlResponse(response) {
4
+ const contentType = response.headers.get("Content-Type");
5
+ return contentType !== null && contentType.startsWith("text/html");
6
+ }
7
+ function shouldInjectHmrHtmlResponse(watch, hmrManager) {
8
+ return watch && hmrManager?.isEnabled() === true;
9
+ }
10
+ async function injectHmrRuntimeIntoHtmlResponse(response) {
11
+ const html = await response.text();
12
+ const headers = new Headers(response.headers);
13
+ headers.set("Cache-Control", "no-store, must-revalidate");
14
+ headers.delete("Content-Length");
15
+ if (html.includes(HMR_RUNTIME_IMPORT)) {
16
+ return new Response(html, {
17
+ status: response.status,
18
+ statusText: response.statusText,
19
+ headers
20
+ });
21
+ }
22
+ const updatedHtml = html.replace(/<\/html>/i, `${HMR_RUNTIME_SCRIPT}</html>`);
23
+ return new Response(updatedHtml, {
24
+ status: response.status,
25
+ statusText: response.statusText,
26
+ headers
27
+ });
28
+ }
29
+ export {
30
+ injectHmrRuntimeIntoHtmlResponse,
31
+ isHtmlResponse,
32
+ shouldInjectHmrHtmlResponse
33
+ };
@@ -1,7 +1,9 @@
1
- import type { RenderContext } from '../../public-types.js';
2
- import type { IntegrationPlugin } from '../../plugins/integration-plugin.js';
1
+ import type { RenderContext } from '../../types/public-types.js';
2
+ import type { AnyIntegrationPlugin } from '../../plugins/integration-plugin.js';
3
3
  export interface CreateRenderContextOptions {
4
- integrations: IntegrationPlugin[];
4
+ integrations: AnyIntegrationPlugin[];
5
+ rendererModules?: unknown;
6
+ importServerModule?: (filePath: string) => Promise<unknown>;
5
7
  }
6
8
  /**
7
9
  * Creates a render context for route handlers.
@@ -1,4 +1,8 @@
1
+ import { fileURLToPath } from "node:url";
1
2
  import { invariant } from "../../utils/invariant.js";
3
+ function resolveServerModulePath(filePath) {
4
+ return filePath instanceof URL ? fileURLToPath(filePath) : filePath;
5
+ }
2
6
  function mergePropsWithLocals(props, locals) {
3
7
  if (!locals || typeof props !== "object" || props === null) {
4
8
  return props;
@@ -15,12 +19,31 @@ function createRenderContext(options) {
15
19
  );
16
20
  const integration = integrations.find((i) => i.name === integrationName);
17
21
  invariant(!!integration, `No integration found for: ${integrationName}`);
18
- return integration.initializeRenderer();
22
+ return integration.initializeRenderer({
23
+ rendererModules: options.rendererModules
24
+ });
19
25
  };
20
- return {
26
+ const renderContext = {
27
+ importServerModule: async (filePath) => {
28
+ invariant(!!options.importServerModule, "Server module importing is not available in this render context.");
29
+ return await options.importServerModule(resolveServerModulePath(filePath));
30
+ },
31
+ async renderServerModule(filePath, props, renderOptions) {
32
+ const module = await renderContext.importServerModule(filePath);
33
+ const view = module.default;
34
+ const locals = this?.locals;
35
+ const mergedProps = mergePropsWithLocals(props ?? {}, locals);
36
+ const renderer = getRendererForView(view);
37
+ const ctx = {
38
+ partial: false,
39
+ status: renderOptions?.status,
40
+ headers: renderOptions?.headers
41
+ };
42
+ return await renderer.renderToResponse(view, mergedProps, ctx);
43
+ },
21
44
  async render(view, props, renderOptions) {
22
45
  const locals = this?.locals;
23
- const mergedProps = mergePropsWithLocals(props, locals);
46
+ const mergedProps = mergePropsWithLocals(props ?? {}, locals);
24
47
  const renderer = getRendererForView(view);
25
48
  const ctx = {
26
49
  partial: false,
@@ -63,6 +86,7 @@ function createRenderContext(options) {
63
86
  });
64
87
  }
65
88
  };
89
+ return renderContext;
66
90
  }
67
91
  export {
68
92
  createRenderContext
@@ -0,0 +1,26 @@
1
+ import type { ReturnParseCliArgs } from '../../utils/parse-cli-args.js';
2
+ import type { EcoPagesAppConfig } from '../../types/internal-types.js';
3
+ export type RuntimeBinding = {
4
+ preferredPort: number;
5
+ preferredHostname: string;
6
+ runtimeOrigin: string;
7
+ serveOptions: Record<string, unknown>;
8
+ watch: boolean;
9
+ };
10
+ export type StaticRuntimeMode = {
11
+ requiresFetchRuntime: boolean;
12
+ canBuildWithoutRuntimeServer: boolean;
13
+ };
14
+ export declare function resolveServeRuntimeOrigin(serveOptions: {
15
+ hostname?: string;
16
+ port?: number | string;
17
+ }): string;
18
+ export declare function resolveRuntimeBinding(options: {
19
+ cliArgs: ReturnParseCliArgs;
20
+ serverOptions?: Record<string, unknown>;
21
+ env?: NodeJS.ProcessEnv;
22
+ }): RuntimeBinding;
23
+ export declare function resolveStaticRuntimeMode(options: {
24
+ appConfig: EcoPagesAppConfig;
25
+ cliArgs: ReturnParseCliArgs;
26
+ }): StaticRuntimeMode;
@@ -0,0 +1,46 @@
1
+ import { DEFAULT_ECOPAGES_HOSTNAME, DEFAULT_ECOPAGES_PORT } from "../../config/constants.js";
2
+ function normalizeOriginHostname(hostname) {
3
+ if (hostname.includes(":") && !hostname.startsWith("[") && !hostname.endsWith("]")) {
4
+ return `[${hostname}]`;
5
+ }
6
+ return hostname;
7
+ }
8
+ function resolveServeRuntimeOrigin(serveOptions) {
9
+ const hostname = normalizeOriginHostname(String(serveOptions.hostname ?? DEFAULT_ECOPAGES_HOSTNAME));
10
+ const port = Number(serveOptions.port ?? DEFAULT_ECOPAGES_PORT);
11
+ return `http://${hostname}:${port}`;
12
+ }
13
+ function resolveRuntimeBinding(options) {
14
+ const env = options.env ?? process.env;
15
+ const preferredPort = options.cliArgs.port ?? (env.ECOPAGES_PORT ? Number(env.ECOPAGES_PORT) : void 0) ?? DEFAULT_ECOPAGES_PORT;
16
+ const preferredHostname = options.cliArgs.hostname ?? env.ECOPAGES_HOSTNAME ?? DEFAULT_ECOPAGES_HOSTNAME;
17
+ return {
18
+ preferredPort,
19
+ preferredHostname,
20
+ runtimeOrigin: resolveServeRuntimeOrigin({
21
+ hostname: preferredHostname,
22
+ port: preferredPort
23
+ }),
24
+ serveOptions: {
25
+ port: preferredPort,
26
+ hostname: preferredHostname,
27
+ ...options.serverOptions ?? {}
28
+ },
29
+ watch: options.cliArgs.dev
30
+ };
31
+ }
32
+ function resolveStaticRuntimeMode(options) {
33
+ const requiresFetchRuntime = options.appConfig.integrations.some(
34
+ (integration) => integration.staticBuildStep === "fetch"
35
+ );
36
+ const canBuildWithoutRuntimeServer = (options.cliArgs.build || options.cliArgs.preview) && !requiresFetchRuntime;
37
+ return {
38
+ requiresFetchRuntime,
39
+ canBuildWithoutRuntimeServer
40
+ };
41
+ }
42
+ export {
43
+ resolveRuntimeBinding,
44
+ resolveServeRuntimeOrigin,
45
+ resolveStaticRuntimeMode
46
+ };
@@ -0,0 +1,12 @@
1
+ export interface RuntimeHost<TServer, TServeOptions> {
2
+ start(options: RuntimeHostStartOptions<TServeOptions>): Promise<TServer>;
3
+ stop(server: TServer, options?: {
4
+ force?: boolean;
5
+ }): Promise<void>;
6
+ getOrigin(server: TServer, fallbackServeOptions: TServeOptions): string;
7
+ }
8
+ export interface RuntimeHostStartOptions<TServeOptions> {
9
+ serveOptions: TServeOptions;
10
+ handleRequest(request: Request): Promise<Response>;
11
+ onError(error: Error): Promise<void> | void;
12
+ }
@@ -1,30 +1,47 @@
1
1
  import { AbstractServerAdapter } from '../abstract/server-adapter.js';
2
2
  import type { ServerAdapterOptions, ServerAdapterResult } from '../abstract/server-adapter.js';
3
3
  import { RouteRendererFactory } from '../../route-renderer/route-renderer.js';
4
- import { FSRouter } from '../../router/fs-router.js';
5
- import { SchemaValidationService } from '../../services/schema-validation-service.js';
4
+ import { RouteRegistry } from '../../router/server/route-registry.js';
5
+ import { SchemaValidationService } from '../../services/validation/schema-validation-service.js';
6
6
  import { StaticSiteGenerator } from '../../static-site-generator/static-site-generator.js';
7
7
  import { ServerStaticBuilder } from './server-static-builder.js';
8
8
  import { FileSystemResponseMatcher } from './fs-server-response-matcher.js';
9
9
  import { ServerRouteHandler } from './server-route-handler.js';
10
- import type { ApiHandler, CacheInvalidator, ErrorHandler, RenderContext, StaticRoute } from '../../public-types.js';
10
+ import type { ApiHandler, CacheInvalidator, ErrorHandler, RenderContext, StaticRoute } from '../../types/public-types.js';
11
+ type SharedRequestContext = {
12
+ apiHandlers: ApiHandler[];
13
+ errorHandler?: ErrorHandler;
14
+ serverInstance?: any;
15
+ hmrManager?: any;
16
+ };
11
17
  export declare abstract class SharedServerAdapter<TOptions extends ServerAdapterOptions, TResult extends ServerAdapterResult> extends AbstractServerAdapter<TOptions, TResult> {
12
- protected router: FSRouter;
18
+ protected router: RouteRegistry;
13
19
  protected fileSystemResponseMatcher: FileSystemResponseMatcher;
14
20
  protected routeRendererFactory: RouteRendererFactory;
15
21
  protected routeHandler: ServerRouteHandler;
16
22
  protected staticSiteGenerator: StaticSiteGenerator;
17
23
  protected staticBuilder: ServerStaticBuilder;
18
24
  protected readonly schemaValidator: SchemaValidationService;
25
+ protected initializeSharedRouteHandling(options: {
26
+ staticRoutes: StaticRoute[];
27
+ hmrManager?: any;
28
+ }): Promise<void>;
29
+ protected createSharedWatchRefreshCallback(options: {
30
+ staticRoutes: StaticRoute[];
31
+ hmrManager?: any;
32
+ onRoutesReady?: () => Promise<void> | void;
33
+ onError?: (error: Error) => Promise<void> | void;
34
+ }): () => Promise<void>;
19
35
  /**
20
- * Scans the filesystem and dynamically constructs the universal router map.
36
+ * Scans the filesystem and dynamically constructs the Route Registry.
21
37
  *
22
38
  * This process runs identically across both Bun and Node wrappers. It analyzes the configured pages
23
39
  * directory, building a map of all available UI routes and API endpoints.
24
- * The resulting `FSRouter` instance becomes the central nervous system for mapping WinterCG incoming
40
+ * The resulting `RouteRegistry` instance becomes the central nervous system for mapping WinterCG incoming
25
41
  * Web Requests (`Request`) to their corresponding internal execution paths.
26
42
  */
27
43
  protected initSharedRouter(): Promise<void>;
44
+ private createRouteRegistryPageModuleAdapter;
28
45
  /**
29
46
  * Sets up the unified rendering pipeline and response matching chain.
30
47
  *
@@ -40,6 +57,8 @@ export declare abstract class SharedServerAdapter<TOptions extends ServerAdapter
40
57
  * @param hmrManager - The runtime-specific Hot Module Replacement orchestrator (if watching).
41
58
  */
42
59
  protected configureSharedResponseHandlers(staticRoutes: StaticRoute[], hmrManager?: any): void;
60
+ private createSharedResponseHandlerDependencies;
61
+ private createSharedPageCacheService;
43
62
  protected getCacheService(): CacheInvalidator | null;
44
63
  protected getRenderContext(): RenderContext;
45
64
  /**
@@ -60,6 +79,10 @@ export declare abstract class SharedServerAdapter<TOptions extends ServerAdapter
60
79
  * @returns The resulting Web standard `Response` constructed by the user's handler.
61
80
  */
62
81
  protected executeApiHandler(request: Request, params: Record<string, string | string[]>, routeConfig: ApiHandler, serverInstance: any, errorHandler?: ErrorHandler): Promise<Response>;
82
+ private createApiHandlerContext;
83
+ private normalizeApiParams;
84
+ private applyApiRequestSchema;
85
+ private runApiMiddlewareChain;
63
86
  private normalizePath;
64
87
  private matchApiPath;
65
88
  private getApiPathScore;
@@ -67,6 +90,8 @@ export declare abstract class SharedServerAdapter<TOptions extends ServerAdapter
67
90
  routeConfig: ApiHandler;
68
91
  params: Record<string, string | string[]>;
69
92
  } | null;
93
+ private tryHandleSharedHmrRequest;
94
+ private tryHandleSharedApiRequest;
70
95
  /**
71
96
  * Universally processes an incoming WinterCG Web standard Request.
72
97
  *
@@ -78,10 +103,6 @@ export declare abstract class SharedServerAdapter<TOptions extends ServerAdapter
78
103
  * Both Bun and Node bindings fall back to this exact function once they have mapped their
79
104
  * native HTTP objects into Web Standard Requests.
80
105
  */
81
- handleSharedRequest(request: Request, context: {
82
- apiHandlers: ApiHandler[];
83
- errorHandler?: ErrorHandler;
84
- serverInstance?: any;
85
- hmrManager?: any;
86
- }): Promise<Response>;
106
+ handleSharedRequest(request: Request, context: SharedRequestContext): Promise<Response>;
87
107
  }
108
+ export {};