@ecopages/core 0.2.0-alpha.3 → 0.2.0-alpha.31

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 (436) hide show
  1. package/CHANGELOG.md +66 -66
  2. package/README.md +268 -14
  3. package/package.json +72 -108
  4. package/src/adapters/README.md +39 -0
  5. package/src/adapters/abstract/application-adapter.d.ts +28 -2
  6. package/src/adapters/abstract/application-adapter.js +14 -2
  7. package/src/adapters/abstract/router-adapter.d.ts +1 -1
  8. package/src/adapters/abstract/server-adapter.d.ts +2 -2
  9. package/src/adapters/bun/client-bridge.d.ts +1 -1
  10. package/src/adapters/bun/create-app.d.ts +5 -12
  11. package/src/adapters/bun/create-app.js +43 -7
  12. package/src/adapters/bun/hmr-manager.d.ts +72 -26
  13. package/src/adapters/bun/hmr-manager.js +153 -81
  14. package/src/adapters/bun/index.d.ts +2 -3
  15. package/src/adapters/bun/index.js +3 -3
  16. package/src/adapters/bun/server-adapter.d.ts +5 -5
  17. package/src/adapters/bun/server-adapter.js +63 -38
  18. package/src/adapters/bun/server-lifecycle.d.ts +28 -17
  19. package/src/adapters/bun/server-lifecycle.js +34 -62
  20. package/src/{create-app.d.ts → adapters/create-app.d.ts} +9 -6
  21. package/src/{create-app.js → adapters/create-app.js} +4 -4
  22. package/src/adapters/index.d.ts +2 -6
  23. package/src/adapters/index.js +2 -8
  24. package/src/adapters/node/create-app.d.ts +6 -9
  25. package/src/adapters/node/create-app.js +12 -6
  26. package/src/adapters/node/node-client-bridge.d.ts +1 -1
  27. package/src/adapters/node/node-hmr-manager.d.ts +79 -21
  28. package/src/adapters/node/node-hmr-manager.js +167 -114
  29. package/src/adapters/node/server-adapter.d.ts +7 -35
  30. package/src/adapters/node/server-adapter.js +55 -107
  31. package/src/adapters/node/static-content-server.d.ts +37 -1
  32. package/src/adapters/node/static-content-server.js +29 -1
  33. package/src/adapters/shared/application-adapter.d.ts +1 -1
  34. package/src/{define-api-handler.d.ts → adapters/shared/define-api-handler.d.ts} +1 -1
  35. package/src/adapters/shared/explicit-static-render-preparation.d.ts +25 -0
  36. package/src/adapters/shared/explicit-static-render-preparation.js +26 -0
  37. package/src/adapters/shared/explicit-static-route-matcher.d.ts +7 -4
  38. package/src/adapters/shared/explicit-static-route-matcher.js +14 -13
  39. package/src/adapters/shared/file-route-middleware-pipeline.d.ts +7 -10
  40. package/src/adapters/shared/file-route-middleware-pipeline.js +3 -11
  41. package/src/adapters/shared/fs-server-response-factory.d.ts +14 -10
  42. package/src/adapters/shared/fs-server-response-factory.js +11 -27
  43. package/src/adapters/shared/fs-server-response-matcher.d.ts +20 -16
  44. package/src/adapters/shared/fs-server-response-matcher.js +76 -45
  45. package/src/adapters/shared/hmr-entrypoint-registrar.d.ts +55 -0
  46. package/src/adapters/shared/hmr-entrypoint-registrar.js +87 -0
  47. package/src/adapters/shared/hmr-html-response.d.ts +22 -0
  48. package/src/adapters/shared/hmr-html-response.js +32 -0
  49. package/src/adapters/shared/render-context.d.ts +4 -3
  50. package/src/adapters/shared/render-context.js +6 -3
  51. package/src/adapters/shared/runtime-bootstrap.d.ts +38 -0
  52. package/src/adapters/shared/runtime-bootstrap.js +43 -0
  53. package/src/adapters/shared/server-adapter.d.ts +33 -12
  54. package/src/adapters/shared/server-adapter.js +208 -132
  55. package/src/adapters/shared/server-route-handler.d.ts +5 -5
  56. package/src/adapters/shared/server-route-handler.js +7 -16
  57. package/src/adapters/shared/server-static-builder.d.ts +41 -8
  58. package/src/adapters/shared/server-static-builder.js +65 -11
  59. package/src/build/README.md +107 -0
  60. package/src/build/build-adapter.d.ts +168 -3
  61. package/src/build/build-adapter.js +604 -16
  62. package/src/build/build-manifest.d.ts +27 -0
  63. package/src/build/build-manifest.js +30 -0
  64. package/src/build/dev-build-coordinator.d.ts +72 -0
  65. package/src/build/dev-build-coordinator.js +154 -0
  66. package/src/build/esbuild-build-adapter.d.ts +15 -6
  67. package/src/build/esbuild-build-adapter.js +189 -74
  68. package/src/build/runtime-build-executor.d.ts +14 -0
  69. package/src/build/runtime-build-executor.js +22 -0
  70. package/src/build/runtime-specifier-alias-plugin.d.ts +15 -0
  71. package/src/build/runtime-specifier-alias-plugin.js +35 -0
  72. package/src/build/runtime-specifier-aliases.d.ts +5 -0
  73. package/src/build/runtime-specifier-aliases.js +95 -0
  74. package/src/config/README.md +36 -0
  75. package/src/config/config-builder.d.ts +54 -29
  76. package/src/config/config-builder.js +255 -49
  77. package/src/{constants.d.ts → config/constants.d.ts} +13 -0
  78. package/src/{constants.js → config/constants.js} +4 -0
  79. package/src/declarations.d.ts +19 -14
  80. package/src/dev/host-runtime.d.ts +10 -0
  81. package/src/dev/host-runtime.js +24 -0
  82. package/src/dev/sc-server.d.ts +1 -1
  83. package/src/dev/sc-server.js +1 -1
  84. package/src/eco/README.md +70 -16
  85. package/src/eco/eco.browser.d.ts +2 -0
  86. package/src/eco/eco.browser.js +83 -0
  87. package/src/eco/eco.js +32 -57
  88. package/src/eco/eco.types.d.ts +14 -6
  89. package/src/eco/eco.utils.d.ts +1 -40
  90. package/src/eco/eco.utils.js +5 -35
  91. package/src/eco/global-injector-map.d.ts +3 -3
  92. package/src/eco/global-injector-map.js +2 -2
  93. package/src/eco/lazy-injector-map.d.ts +2 -2
  94. package/src/errors/index.d.ts +1 -0
  95. package/src/errors/index.js +3 -1
  96. package/src/hmr/README.md +26 -0
  97. package/src/hmr/client/hmr-runtime.d.ts +1 -6
  98. package/src/hmr/client/hmr-runtime.js +38 -7
  99. package/src/hmr/hmr-strategy.d.ts +16 -13
  100. package/src/hmr/hmr-strategy.js +22 -7
  101. package/src/hmr/hmr.postcss.test.e2e.d.ts +1 -0
  102. package/src/hmr/hmr.postcss.test.e2e.js +31 -0
  103. package/src/hmr/hmr.test.e2e.js +26 -33
  104. package/src/hmr/strategies/default-hmr-strategy.d.ts +2 -2
  105. package/src/hmr/strategies/default-hmr-strategy.js +1 -1
  106. package/src/hmr/strategies/js-hmr-strategy.d.ts +46 -48
  107. package/src/hmr/strategies/js-hmr-strategy.js +64 -74
  108. package/src/index.browser.d.ts +2 -2
  109. package/src/index.browser.js +1 -1
  110. package/src/index.d.ts +4 -3
  111. package/src/index.js +16 -5
  112. package/src/integrations/ghtml/ghtml-renderer.d.ts +3 -2
  113. package/src/integrations/ghtml/ghtml-renderer.js +27 -30
  114. package/src/integrations/ghtml/ghtml.constants.d.ts +1 -0
  115. package/src/integrations/ghtml/ghtml.constants.js +4 -0
  116. package/src/integrations/ghtml/ghtml.plugin.d.ts +2 -6
  117. package/src/integrations/ghtml/ghtml.plugin.js +3 -4
  118. package/src/plugins/README.md +35 -0
  119. package/src/plugins/alias-resolver-plugin.js +17 -3
  120. package/src/plugins/eco-component-meta-plugin.d.ts +14 -1
  121. package/src/plugins/eco-component-meta-plugin.js +27 -22
  122. package/src/plugins/foreign-jsx-override-plugin.d.ts +31 -0
  123. package/src/plugins/foreign-jsx-override-plugin.js +35 -0
  124. package/src/plugins/integration-plugin.d.ts +142 -29
  125. package/src/plugins/integration-plugin.js +103 -14
  126. package/src/plugins/processor.d.ts +17 -2
  127. package/src/plugins/processor.js +22 -3
  128. package/src/plugins/runtime-capability.d.ts +9 -0
  129. package/src/plugins/source-transform.d.ts +46 -0
  130. package/src/plugins/source-transform.js +71 -0
  131. package/src/route-renderer/GRAPH.md +83 -325
  132. package/src/route-renderer/README.md +73 -90
  133. package/src/route-renderer/orchestration/component-render-context.d.ts +89 -0
  134. package/src/route-renderer/orchestration/component-render-context.js +147 -0
  135. package/src/route-renderer/orchestration/declared-ownership-graph.d.ts +18 -0
  136. package/src/route-renderer/orchestration/declared-ownership-graph.js +34 -0
  137. package/src/route-renderer/orchestration/foreign-subtree-execution.service.d.ts +108 -0
  138. package/src/route-renderer/orchestration/foreign-subtree-execution.service.js +206 -0
  139. package/src/route-renderer/orchestration/integration-renderer.d.ts +516 -0
  140. package/src/route-renderer/orchestration/integration-renderer.js +909 -0
  141. package/src/route-renderer/orchestration/ownership-planning.service.d.ts +24 -0
  142. package/src/route-renderer/orchestration/ownership-planning.service.js +63 -0
  143. package/src/route-renderer/orchestration/ownership-validation.service.d.ts +29 -0
  144. package/src/route-renderer/orchestration/ownership-validation.service.js +53 -0
  145. package/src/route-renderer/orchestration/processed-asset-dedupe.d.ts +2 -0
  146. package/src/route-renderer/orchestration/processed-asset-dedupe.js +23 -0
  147. package/src/route-renderer/orchestration/queued-foreign-subtree-resolution.service.d.ts +90 -0
  148. package/src/route-renderer/orchestration/queued-foreign-subtree-resolution.service.js +158 -0
  149. package/src/route-renderer/orchestration/render-output.utils.d.ts +66 -0
  150. package/src/route-renderer/orchestration/render-output.utils.js +171 -0
  151. package/src/route-renderer/orchestration/route-render-orchestrator.d.ts +120 -0
  152. package/src/route-renderer/orchestration/route-render-orchestrator.js +388 -0
  153. package/src/route-renderer/orchestration/template-serialization.d.ts +38 -0
  154. package/src/route-renderer/orchestration/template-serialization.js +45 -0
  155. package/src/route-renderer/page-loading/component-dependency-collection.d.ts +37 -0
  156. package/src/route-renderer/page-loading/component-dependency-collection.js +132 -0
  157. package/src/route-renderer/page-loading/declared-asset-collection.d.ts +24 -0
  158. package/src/route-renderer/page-loading/declared-asset-collection.js +106 -0
  159. package/src/route-renderer/{dependency-resolver.d.ts → page-loading/dependency-resolver.d.ts} +15 -4
  160. package/src/route-renderer/page-loading/dependency-resolver.js +115 -0
  161. package/src/route-renderer/page-loading/ecopages-virtual-imports.d.ts +11 -0
  162. package/src/route-renderer/page-loading/ecopages-virtual-imports.js +57 -0
  163. package/src/route-renderer/page-loading/lazy-entry-collection.d.ts +45 -0
  164. package/src/route-renderer/page-loading/lazy-entry-collection.js +105 -0
  165. package/src/route-renderer/page-loading/lazy-trigger-planning.d.ts +19 -0
  166. package/src/route-renderer/page-loading/lazy-trigger-planning.js +40 -0
  167. package/src/route-renderer/page-loading/module-declaration-aggregation.d.ts +5 -0
  168. package/src/route-renderer/page-loading/module-declaration-aggregation.js +33 -0
  169. package/src/route-renderer/page-loading/module-declaration-scripts.d.ts +3 -0
  170. package/src/route-renderer/page-loading/module-declaration-scripts.js +18 -0
  171. package/src/route-renderer/page-loading/page-dependency-bundling.d.ts +13 -0
  172. package/src/route-renderer/page-loading/page-dependency-bundling.js +137 -0
  173. package/src/route-renderer/page-loading/page-module-loader.d.ts +90 -0
  174. package/src/route-renderer/{page-module-loader.js → page-loading/page-module-loader.js} +39 -14
  175. package/src/route-renderer/route-renderer.d.ts +57 -14
  176. package/src/route-renderer/route-renderer.js +30 -18
  177. package/src/router/README.md +94 -0
  178. package/src/router/client/link-intent.d.ts +53 -0
  179. package/src/router/client/link-intent.js +34 -0
  180. package/src/router/client/link-intent.test.browser.d.ts +1 -0
  181. package/src/router/client/link-intent.test.browser.js +43 -0
  182. package/src/router/client/navigation-coordinator.d.ts +169 -0
  183. package/src/router/client/navigation-coordinator.js +215 -0
  184. package/src/router/server/route-registry.d.ts +78 -0
  185. package/src/router/server/route-registry.js +262 -0
  186. package/src/services/README.md +28 -0
  187. package/src/services/assets/asset-processing-service/asset-dependency-keys.d.ts +3 -0
  188. package/src/services/assets/asset-processing-service/asset-dependency-keys.js +56 -0
  189. package/src/services/assets/asset-processing-service/asset-processing.service.d.ts +103 -0
  190. package/src/services/{asset-processing-service → assets/asset-processing-service}/asset-processing.service.js +124 -89
  191. package/src/services/{asset-processing-service → assets/asset-processing-service}/asset.factory.d.ts +1 -1
  192. package/src/services/{asset-processing-service → assets/asset-processing-service}/asset.factory.js +2 -2
  193. package/src/services/{asset-processing-service → assets/asset-processing-service}/assets.types.d.ts +16 -1
  194. package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.d.ts +55 -0
  195. package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.js +49 -0
  196. package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.d.ts +20 -0
  197. package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.js +41 -0
  198. package/src/services/assets/asset-processing-service/grouped-content-bundles.d.ts +30 -0
  199. package/src/services/assets/asset-processing-service/grouped-content-bundles.js +65 -0
  200. package/src/services/assets/asset-processing-service/index.d.ts +6 -0
  201. package/src/services/assets/asset-processing-service/index.js +6 -0
  202. package/src/services/assets/asset-processing-service/page-package.d.ts +3 -0
  203. package/src/services/assets/asset-processing-service/page-package.js +74 -0
  204. package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.interface.d.ts +2 -2
  205. package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.registry.d.ts +2 -2
  206. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/base/base-processor.d.ts +1 -1
  207. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/base/base-processor.js +11 -5
  208. package/src/services/assets/asset-processing-service/processors/base/base-script-processor.d.ts +22 -0
  209. package/src/services/assets/asset-processing-service/processors/base/base-script-processor.js +136 -0
  210. package/src/services/assets/asset-processing-service/processors/index.d.ts +5 -0
  211. package/src/services/assets/asset-processing-service/processors/index.js +5 -0
  212. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/content-script.processor.d.ts +3 -2
  213. package/src/services/assets/asset-processing-service/processors/script/content-script.processor.js +119 -0
  214. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/file-script.processor.d.ts +4 -3
  215. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/file-script.processor.js +28 -7
  216. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/node-module-script.processor.d.ts +3 -3
  217. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/node-module-script.processor.js +12 -7
  218. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/content-stylesheet.processor.d.ts +5 -2
  219. package/src/services/assets/asset-processing-service/processors/stylesheet/content-stylesheet.processor.js +59 -0
  220. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/file-stylesheet.processor.d.ts +2 -2
  221. package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/file-stylesheet.processor.js +9 -3
  222. package/src/services/assets/asset-processing-service/ungrouped-dependency-processing.d.ts +18 -0
  223. package/src/services/assets/asset-processing-service/ungrouped-dependency-processing.js +45 -0
  224. package/src/services/assets/browser-bundle.service.d.ts +73 -0
  225. package/src/services/assets/browser-bundle.service.js +41 -0
  226. package/src/services/{page-request-cache-coordinator.service.d.ts → cache/page-request-cache-coordinator.service.d.ts} +2 -2
  227. package/src/services/{page-request-cache-coordinator.service.js → cache/page-request-cache-coordinator.service.js} +3 -1
  228. package/src/services/html/html-rewriter-provider.service.d.ts +37 -0
  229. package/src/services/html/html-rewriter-provider.service.js +68 -0
  230. package/src/services/html/html-transformer.service.d.ts +87 -0
  231. package/src/services/html/html-transformer.service.js +216 -0
  232. package/src/services/invalidation/development-invalidation.service.d.ts +74 -0
  233. package/src/services/invalidation/development-invalidation.service.js +190 -0
  234. package/src/services/module-loading/app-module-loader.service.d.ts +7 -0
  235. package/src/services/module-loading/app-server-module-transpiler.service.d.ts +24 -0
  236. package/src/services/module-loading/app-server-module-transpiler.service.js +115 -0
  237. package/src/services/module-loading/host-module-loader-registry.d.ts +4 -0
  238. package/src/services/module-loading/host-module-loader-registry.js +15 -0
  239. package/src/services/module-loading/module-loading-types.d.ts +2 -0
  240. package/src/services/module-loading/module-loading-types.js +0 -0
  241. package/src/services/module-loading/node-bootstrap-plugin.d.ts +42 -0
  242. package/src/services/module-loading/node-bootstrap-plugin.js +216 -0
  243. package/src/services/module-loading/page-module-import.service.d.ts +76 -0
  244. package/src/services/module-loading/page-module-import.service.js +170 -0
  245. package/src/services/module-loading/server-module-transpiler.service.d.ts +63 -0
  246. package/src/services/module-loading/server-module-transpiler.service.js +64 -0
  247. package/src/services/module-loading/source-module-support.d.ts +5 -0
  248. package/src/services/module-loading/source-module-support.js +8 -0
  249. package/src/services/runtime-state/dev-graph.service.d.ts +118 -0
  250. package/src/services/runtime-state/dev-graph.service.js +162 -0
  251. package/src/services/runtime-state/entrypoint-dependency-graph.service.d.ts +41 -0
  252. package/src/services/runtime-state/entrypoint-dependency-graph.service.js +85 -0
  253. package/src/services/runtime-state/server-invalidation-state.service.d.ts +26 -0
  254. package/src/services/runtime-state/server-invalidation-state.service.js +35 -0
  255. package/src/services/{schema-validation-service.d.ts → validation/schema-validation-service.d.ts} +1 -1
  256. package/src/static-site-generator/README.md +26 -0
  257. package/src/static-site-generator/static-site-generator.d.ts +67 -20
  258. package/src/static-site-generator/static-site-generator.js +182 -138
  259. package/src/{internal-types.d.ts → types/internal-types.d.ts} +62 -30
  260. package/src/types/internal-types.js +0 -0
  261. package/src/{public-types.d.ts → types/public-types.d.ts} +201 -32
  262. package/src/types/public-types.js +0 -0
  263. package/src/utils/html-escaping.d.ts +7 -0
  264. package/src/utils/html-escaping.js +6 -0
  265. package/src/utils/locals-utils.d.ts +1 -1
  266. package/src/utils/parse-cli-args.d.ts +4 -1
  267. package/src/utils/parse-cli-args.js +16 -1
  268. package/src/utils/resolve-work-dir.d.ts +11 -0
  269. package/src/utils/resolve-work-dir.js +31 -0
  270. package/src/watchers/project-watcher.d.ts +40 -29
  271. package/src/watchers/project-watcher.js +126 -116
  272. package/src/watchers/project-watcher.test-helpers.d.ts +2 -2
  273. package/src/watchers/project-watcher.test-helpers.js +6 -6
  274. package/src/adapters/abstract/application-adapter.ts +0 -337
  275. package/src/adapters/abstract/router-adapter.ts +0 -30
  276. package/src/adapters/abstract/server-adapter.ts +0 -79
  277. package/src/adapters/bun/client-bridge.ts +0 -62
  278. package/src/adapters/bun/create-app.ts +0 -189
  279. package/src/adapters/bun/define-api-handler.d.ts +0 -61
  280. package/src/adapters/bun/define-api-handler.ts +0 -114
  281. package/src/adapters/bun/hmr-manager.ts +0 -296
  282. package/src/adapters/bun/index.ts +0 -3
  283. package/src/adapters/bun/server-adapter.ts +0 -492
  284. package/src/adapters/bun/server-lifecycle.ts +0 -154
  285. package/src/adapters/index.ts +0 -6
  286. package/src/adapters/node/create-app.ts +0 -179
  287. package/src/adapters/node/index.d.ts +0 -4
  288. package/src/adapters/node/index.js +0 -8
  289. package/src/adapters/node/index.ts +0 -9
  290. package/src/adapters/node/node-client-bridge.ts +0 -79
  291. package/src/adapters/node/node-hmr-manager.ts +0 -289
  292. package/src/adapters/node/server-adapter.ts +0 -561
  293. package/src/adapters/node/static-content-server.ts +0 -203
  294. package/src/adapters/shared/api-response.ts +0 -104
  295. package/src/adapters/shared/application-adapter.ts +0 -199
  296. package/src/adapters/shared/explicit-static-route-matcher.ts +0 -134
  297. package/src/adapters/shared/file-route-middleware-pipeline.ts +0 -123
  298. package/src/adapters/shared/fs-server-response-factory.ts +0 -118
  299. package/src/adapters/shared/fs-server-response-matcher.ts +0 -198
  300. package/src/adapters/shared/render-context.ts +0 -105
  301. package/src/adapters/shared/server-adapter.ts +0 -442
  302. package/src/adapters/shared/server-route-handler.ts +0 -166
  303. package/src/adapters/shared/server-static-builder.ts +0 -82
  304. package/src/build/build-adapter.ts +0 -132
  305. package/src/build/build-types.ts +0 -83
  306. package/src/build/esbuild-build-adapter.ts +0 -510
  307. package/src/config/config-builder.ts +0 -474
  308. package/src/constants.ts +0 -39
  309. package/src/create-app.ts +0 -87
  310. package/src/define-api-handler.js +0 -15
  311. package/src/define-api-handler.ts +0 -66
  312. package/src/dev/sc-server.ts +0 -143
  313. package/src/eco/component-render-context.d.ts +0 -105
  314. package/src/eco/component-render-context.js +0 -77
  315. package/src/eco/component-render-context.ts +0 -202
  316. package/src/eco/eco.ts +0 -221
  317. package/src/eco/eco.types.ts +0 -202
  318. package/src/eco/eco.utils.ts +0 -89
  319. package/src/eco/global-injector-map.ts +0 -112
  320. package/src/eco/lazy-injector-map.ts +0 -120
  321. package/src/eco/module-dependencies.ts +0 -75
  322. package/src/errors/http-error.ts +0 -72
  323. package/src/errors/index.ts +0 -2
  324. package/src/errors/locals-access-error.ts +0 -7
  325. package/src/global/app-logger.ts +0 -4
  326. 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
  327. package/src/hmr/client/__screenshots__/hmr-runtime.test.browser.ts/HMR-Runtime-HMR-Server-Integration-should-load-fixture-app-page-1.png +0 -0
  328. package/src/hmr/client/__screenshots__/hmr-runtime.test.browser.ts/HMR-Runtime-WebSocket-Connection-should-connect-to-correct-HMR-endpoint-1.png +0 -0
  329. package/src/hmr/client/hmr-runtime.ts +0 -121
  330. package/src/hmr/hmr-strategy.ts +0 -172
  331. package/src/hmr/hmr.test.e2e.ts +0 -75
  332. package/src/hmr/strategies/default-hmr-strategy.ts +0 -60
  333. package/src/hmr/strategies/js-hmr-strategy.ts +0 -320
  334. package/src/index.browser.ts +0 -3
  335. package/src/index.ts +0 -5
  336. package/src/integrations/ghtml/ghtml-renderer.ts +0 -93
  337. package/src/integrations/ghtml/ghtml.plugin.ts +0 -32
  338. package/src/internal-types.ts +0 -212
  339. package/src/plugins/alias-resolver-plugin.ts +0 -45
  340. package/src/plugins/eco-component-meta-plugin.ts +0 -474
  341. package/src/plugins/integration-plugin.ts +0 -184
  342. package/src/plugins/processor.ts +0 -220
  343. package/src/public-types.ts +0 -1260
  344. package/src/route-renderer/component-graph-executor.d.ts +0 -32
  345. package/src/route-renderer/component-graph-executor.js +0 -31
  346. package/src/route-renderer/component-graph-executor.ts +0 -84
  347. package/src/route-renderer/component-graph.d.ts +0 -42
  348. package/src/route-renderer/component-graph.js +0 -72
  349. package/src/route-renderer/component-graph.ts +0 -159
  350. package/src/route-renderer/component-marker.d.ts +0 -52
  351. package/src/route-renderer/component-marker.js +0 -46
  352. package/src/route-renderer/component-marker.ts +0 -117
  353. package/src/route-renderer/dependency-resolver.js +0 -428
  354. package/src/route-renderer/dependency-resolver.ts +0 -596
  355. package/src/route-renderer/html-post-processing.service.d.ts +0 -40
  356. package/src/route-renderer/html-post-processing.service.js +0 -86
  357. package/src/route-renderer/html-post-processing.service.ts +0 -103
  358. package/src/route-renderer/integration-renderer.d.ts +0 -339
  359. package/src/route-renderer/integration-renderer.js +0 -526
  360. package/src/route-renderer/integration-renderer.ts +0 -696
  361. package/src/route-renderer/marker-graph-resolver.d.ts +0 -76
  362. package/src/route-renderer/marker-graph-resolver.js +0 -93
  363. package/src/route-renderer/marker-graph-resolver.ts +0 -153
  364. package/src/route-renderer/page-module-loader.d.ts +0 -61
  365. package/src/route-renderer/page-module-loader.ts +0 -153
  366. package/src/route-renderer/render-execution.service.d.ts +0 -69
  367. package/src/route-renderer/render-execution.service.js +0 -91
  368. package/src/route-renderer/render-execution.service.ts +0 -158
  369. package/src/route-renderer/render-preparation.service.d.ts +0 -112
  370. package/src/route-renderer/render-preparation.service.js +0 -243
  371. package/src/route-renderer/render-preparation.service.ts +0 -358
  372. package/src/route-renderer/route-renderer.ts +0 -80
  373. package/src/router/fs-router-scanner.d.ts +0 -41
  374. package/src/router/fs-router-scanner.js +0 -155
  375. package/src/router/fs-router-scanner.ts +0 -217
  376. package/src/router/fs-router.d.ts +0 -26
  377. package/src/router/fs-router.js +0 -100
  378. package/src/router/fs-router.ts +0 -122
  379. package/src/services/asset-processing-service/asset-processing.service.d.ts +0 -41
  380. package/src/services/asset-processing-service/asset-processing.service.ts +0 -306
  381. package/src/services/asset-processing-service/asset.factory.ts +0 -105
  382. package/src/services/asset-processing-service/assets.types.ts +0 -112
  383. package/src/services/asset-processing-service/index.d.ts +0 -3
  384. package/src/services/asset-processing-service/index.js +0 -3
  385. package/src/services/asset-processing-service/index.ts +0 -3
  386. package/src/services/asset-processing-service/processor.interface.ts +0 -27
  387. package/src/services/asset-processing-service/processor.registry.ts +0 -18
  388. package/src/services/asset-processing-service/processors/base/base-processor.ts +0 -76
  389. package/src/services/asset-processing-service/processors/base/base-script-processor.d.ts +0 -16
  390. package/src/services/asset-processing-service/processors/base/base-script-processor.js +0 -80
  391. package/src/services/asset-processing-service/processors/base/base-script-processor.ts +0 -105
  392. package/src/services/asset-processing-service/processors/index.d.ts +0 -5
  393. package/src/services/asset-processing-service/processors/index.js +0 -5
  394. package/src/services/asset-processing-service/processors/index.ts +0 -5
  395. package/src/services/asset-processing-service/processors/script/content-script.processor.js +0 -57
  396. package/src/services/asset-processing-service/processors/script/content-script.processor.ts +0 -66
  397. package/src/services/asset-processing-service/processors/script/file-script.processor.ts +0 -88
  398. package/src/services/asset-processing-service/processors/script/node-module-script.processor.ts +0 -84
  399. package/src/services/asset-processing-service/processors/stylesheet/content-stylesheet.processor.js +0 -25
  400. package/src/services/asset-processing-service/processors/stylesheet/content-stylesheet.processor.ts +0 -27
  401. package/src/services/asset-processing-service/processors/stylesheet/file-stylesheet.processor.ts +0 -77
  402. package/src/services/cache/cache.types.ts +0 -126
  403. package/src/services/cache/index.ts +0 -18
  404. package/src/services/cache/memory-cache-store.ts +0 -130
  405. package/src/services/cache/page-cache-service.ts +0 -202
  406. package/src/services/html-transformer.service.d.ts +0 -50
  407. package/src/services/html-transformer.service.js +0 -163
  408. package/src/services/html-transformer.service.ts +0 -217
  409. package/src/services/page-module-import.service.d.ts +0 -37
  410. package/src/services/page-module-import.service.js +0 -88
  411. package/src/services/page-module-import.service.ts +0 -129
  412. package/src/services/page-request-cache-coordinator.service.ts +0 -128
  413. package/src/services/schema-validation-service.ts +0 -204
  414. package/src/services/validation/standard-schema.types.ts +0 -68
  415. package/src/static-site-generator/static-site-generator.ts +0 -359
  416. package/src/utils/css.d.ts +0 -1
  417. package/src/utils/css.js +0 -7
  418. package/src/utils/css.ts +0 -5
  419. package/src/utils/deep-merge.ts +0 -47
  420. package/src/utils/hash.ts +0 -5
  421. package/src/utils/html.ts +0 -1
  422. package/src/utils/invariant.ts +0 -15
  423. package/src/utils/locals-utils.ts +0 -37
  424. package/src/utils/parse-cli-args.ts +0 -83
  425. package/src/utils/path-utils.module.ts +0 -14
  426. package/src/utils/runtime.ts +0 -44
  427. package/src/utils/server-utils.module.ts +0 -67
  428. package/src/watchers/project-watcher.test-helpers.ts +0 -41
  429. package/src/watchers/project-watcher.ts +0 -344
  430. /package/src/adapters/{bun → shared}/define-api-handler.js +0 -0
  431. /package/src/{internal-types.js → plugins/runtime-capability.js} +0 -0
  432. /package/src/services/{asset-processing-service → assets/asset-processing-service}/assets.types.js +0 -0
  433. /package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.interface.js +0 -0
  434. /package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.registry.js +0 -0
  435. /package/src/{public-types.js → services/module-loading/app-module-loader.service.js} +0 -0
  436. /package/src/services/{schema-validation-service.js → validation/schema-validation-service.js} +0 -0
@@ -1,16 +1,18 @@
1
1
  import { createServer } from "node:http";
2
- import path from "node:path";
3
- import { fileSystem } from "@ecopages/file-system";
4
- import { RESOLVED_ASSETS_DIR } from "../../constants.js";
5
- import { defaultBuildAdapter } from "../../build/build-adapter.js";
6
2
  import { appLogger } from "../../global/app-logger.js";
7
- import { ProjectWatcher } from "../../watchers/project-watcher.js";
8
3
  import { NodeClientBridge } from "./node-client-bridge.js";
9
- import { NodeHmrManager } from "./node-hmr-manager.js";
10
4
  import { StaticSiteGenerator } from "../../static-site-generator/static-site-generator.js";
11
5
  import { SharedServerAdapter } from "../shared/server-adapter.js";
12
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";
13
14
  import { NodeStaticContentServer } from "./static-content-server.js";
15
+ import { DEFAULT_ECOPAGES_HOSTNAME, DEFAULT_ECOPAGES_PORT } from "../../config/constants.js";
14
16
  class ClientAbortError extends Error {
15
17
  constructor() {
16
18
  super("Client closed the request");
@@ -26,7 +28,6 @@ class NodeServerAdapter extends SharedServerAdapter {
26
28
  previewServer = null;
27
29
  bridge = null;
28
30
  hmrManager = null;
29
- processorBuildPlugins = [];
30
31
  constructor(options) {
31
32
  super(options);
32
33
  this.apiHandlers = options.apiHandlers || [];
@@ -47,85 +48,28 @@ class NodeServerAdapter extends SharedServerAdapter {
47
48
  * processors during their `setup()` calls.
48
49
  */
49
50
  async initialize() {
50
- this.setupLoaders();
51
- this.copyPublicDir();
52
- await this.initializePlugins();
53
- await this.initSharedRouter();
54
- this.configureSharedResponseHandlers(this.staticRoutes, this.hmrManager ?? void 0);
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
+ });
55
64
  this.staticSiteGenerator = new StaticSiteGenerator({ appConfig: this.appConfig });
56
65
  this.staticBuilder = new ServerStaticBuilder({
57
66
  appConfig: this.appConfig,
58
67
  staticSiteGenerator: this.staticSiteGenerator,
59
- serveOptions: this.serveOptions
68
+ serveOptions: this.serveOptions,
69
+ apiHandlers: this.apiHandlers
60
70
  });
61
71
  this.initialized = true;
62
72
  }
63
- /**
64
- * Registers every configured file loader as a build plugin on the shared
65
- * `defaultBuildAdapter`.
66
- *
67
- * Loaders are registered on the *shared* adapter (not on a per-build instance)
68
- * because they must be available globally to both the SSR build and any dynamic
69
- * transpile passes that happen outside of a top-level `build()` call (e.g. HMR
70
- * incremental rebuilds).
71
- */
72
- setupLoaders() {
73
- for (const loader of this.appConfig.loaders.values()) {
74
- defaultBuildAdapter.registerPlugin(loader);
75
- }
76
- }
77
- copyPublicDir() {
78
- const srcPublicDir = path.join(this.appConfig.rootDir, this.appConfig.srcDir, this.appConfig.publicDir);
79
- if (fileSystem.exists(srcPublicDir)) {
80
- fileSystem.copyDir(srcPublicDir, path.join(this.appConfig.rootDir, this.appConfig.distDir));
81
- }
82
- fileSystem.ensureDir(path.join(this.appConfig.absolutePaths.distDir, RESOLVED_ASSETS_DIR));
83
- }
84
- /**
85
- * Sets up all configured processors and integrations in two distinct phases.
86
- *
87
- * **Phase 1 — Processors:**
88
- * Each processor's `setup()` is called first. A processor may expose two
89
- * plugin lists:
90
- * - `plugins` — transform plugins used during SSR rendering (e.g. PostCSS).
91
- * - `buildPlugins` — esbuild plugins used during the client bundle step.
92
- * Both are registered on `defaultBuildAdapter` so later build calls pick them up.
93
- *
94
- * **Phase 2 — Integrations:**
95
- * Integrations receive the fully-resolved app config, the runtime origin, and
96
- * (if already initialised) the HMR manager before their own `setup()` is called.
97
- * This ordering ensures integrations can query config values that processors
98
- * may have mutated during phase 1.
99
- */
100
- async initializePlugins() {
101
- const processorBuildPlugins = [];
102
- for (const processor of this.appConfig.processors.values()) {
103
- await processor.setup();
104
- if (processor.plugins) {
105
- for (const plugin of processor.plugins) {
106
- defaultBuildAdapter.registerPlugin(plugin);
107
- }
108
- }
109
- if (processor.buildPlugins) {
110
- processorBuildPlugins.push(...processor.buildPlugins);
111
- for (const plugin of processor.buildPlugins) {
112
- defaultBuildAdapter.registerPlugin(plugin);
113
- }
114
- }
115
- }
116
- for (const integration of this.appConfig.integrations) {
117
- integration.setConfig(this.appConfig);
118
- integration.setRuntimeOrigin(this.runtimeOrigin);
119
- if (this.hmrManager) {
120
- integration.setHmrManager(this.hmrManager);
121
- }
122
- await integration.setup();
123
- for (const plugin of integration.plugins) {
124
- defaultBuildAdapter.registerPlugin(plugin);
125
- }
126
- }
127
- this.processorBuildPlugins = processorBuildPlugins;
128
- }
129
73
  getServerOptions() {
130
74
  return {
131
75
  ...this.serveOptions
@@ -136,9 +80,10 @@ class NodeServerAdapter extends SharedServerAdapter {
136
80
  await this.initialize();
137
81
  }
138
82
  const buildServer = await this.startBuildRuntimeServer();
83
+ const buildRuntimeOrigin = this.getListeningServerOrigin(buildServer);
139
84
  try {
140
85
  await this.staticBuilder.build(
141
- { preview: false },
86
+ { preview: false, baseUrl: buildRuntimeOrigin },
142
87
  {
143
88
  router: this.router,
144
89
  routeRendererFactory: this.routeRendererFactory,
@@ -158,12 +103,12 @@ class NodeServerAdapter extends SharedServerAdapter {
158
103
  appConfig: this.appConfig,
159
104
  options: {
160
105
  hostname: this.serveOptions.hostname,
161
- port: Number(this.serveOptions.port || 3e3)
106
+ port: Number(this.serveOptions.port || DEFAULT_ECOPAGES_PORT)
162
107
  }
163
108
  });
164
109
  await this.previewServer.start();
165
- const previewHostname = this.serveOptions.hostname || "localhost";
166
- const previewPort = this.serveOptions.port || 3e3;
110
+ const previewHostname = this.serveOptions.hostname || DEFAULT_ECOPAGES_HOSTNAME;
111
+ const previewPort = this.serveOptions.port || DEFAULT_ECOPAGES_PORT;
167
112
  appLogger.info(`Preview running at http://${previewHostname}:${previewPort}`);
168
113
  }
169
114
  /**
@@ -254,8 +199,8 @@ class NodeServerAdapter extends SharedServerAdapter {
254
199
  * `stopBuildRuntimeServer`, so it never overlaps with the actual dev/prod server.
255
200
  */
256
201
  async startBuildRuntimeServer() {
257
- const hostname = String(this.serveOptions.hostname || "localhost");
258
- const port = Number(this.serveOptions.port || 3e3);
202
+ const hostname = String(this.serveOptions.hostname || DEFAULT_ECOPAGES_HOSTNAME);
203
+ const port = 0;
259
204
  const server = createServer(async (req, res) => {
260
205
  try {
261
206
  const webRequest = this.createWebRequest(req);
@@ -275,9 +220,17 @@ class NodeServerAdapter extends SharedServerAdapter {
275
220
  });
276
221
  });
277
222
  this.serverInstance = server;
278
- appLogger.info(`Server running at http://${hostname}:${port}`);
223
+ appLogger.info(`Server running at ${this.getListeningServerOrigin(server)}`);
279
224
  return server;
280
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
+ }
281
234
  /**
282
235
  * Gracefully shuts down the ephemeral build runtime server.
283
236
  *
@@ -325,12 +278,12 @@ class NodeServerAdapter extends SharedServerAdapter {
325
278
  * underlying socket closes early — into a 499 response so it does not
326
279
  * incorrectly surface as a 500 in application logs.
327
280
  */
328
- async handleRequest(_request) {
281
+ async handleRequest(request) {
329
282
  if (!this.initialized) {
330
283
  throw new Error("Node server adapter is not initialized. Call createAdapter() first.");
331
284
  }
332
285
  try {
333
- return await this.handleSharedRequest(_request, {
286
+ return await this.handleSharedRequest(request, {
334
287
  apiHandlers: this.apiHandlers,
335
288
  errorHandler: this.errorHandler,
336
289
  serverInstance: this.serverInstance,
@@ -353,22 +306,23 @@ class NodeServerAdapter extends SharedServerAdapter {
353
306
  * broadcast + heartbeat cleanup.
354
307
  * - `NodeHmrManager` watches the filesystem and triggers incremental esbuild
355
308
  * rebuilds, notifying connected clients via the bridge.
356
- * - `ProjectWatcher` listens for route-level file changes and refreshes the
357
- * router and response handlers when pages are added or removed.
309
+ * - Shared watcher bootstrapping listens for route-level file changes and
310
+ * refreshes the router and response handlers when pages are added or removed.
358
311
  *
359
312
  * WebSocket upgrade requests that do not target `/_hmr` are rejected with an
360
313
  * immediate socket destroy to prevent unhandled upgrade leaks.
361
314
  */
362
- async completeInitialization(_server) {
363
- this.serverInstance = _server;
315
+ async completeInitialization(server) {
316
+ this.serverInstance = server;
364
317
  if (this.options?.watch) {
318
+ const { NodeHmrManager } = await import("./node-hmr-manager.js");
365
319
  const { WebSocketServer } = await import("ws");
366
320
  const wss = new WebSocketServer({ noServer: true });
367
321
  this.bridge = new NodeClientBridge();
368
322
  this.hmrManager = new NodeHmrManager({ appConfig: this.appConfig, bridge: this.bridge });
369
323
  this.hmrManager.setEnabled(true);
370
324
  await this.hmrManager.buildRuntime();
371
- _server.on("upgrade", (req, socket, head) => {
325
+ server.on("upgrade", (req, socket, head) => {
372
326
  const url = new URL(req.url ?? "/", this.runtimeOrigin);
373
327
  if (url.pathname === "/_hmr") {
374
328
  wss.handleUpgrade(req, socket, head, (ws) => {
@@ -380,23 +334,17 @@ class NodeServerAdapter extends SharedServerAdapter {
380
334
  socket.destroy();
381
335
  }
382
336
  });
383
- const loaderPlugins = Array.from(this.appConfig.loaders.values());
384
- const hmrBuildPlugins = [...loaderPlugins, ...this.processorBuildPlugins];
385
- this.hmrManager.setPlugins(hmrBuildPlugins);
386
- for (const integration of this.appConfig.integrations) {
387
- integration.setHmrManager(this.hmrManager);
388
- }
337
+ bindSharedRuntimeHmrManager(this.appConfig, this.hmrManager);
389
338
  this.configureSharedResponseHandlers(this.staticRoutes, this.hmrManager);
390
- const watcher = new ProjectWatcher({
391
- config: this.appConfig,
392
- refreshRouterRoutesCallback: async () => {
393
- await this.initSharedRouter();
394
- this.configureSharedResponseHandlers(this.staticRoutes, this.hmrManager);
395
- },
339
+ await startSharedProjectWatching({
340
+ appConfig: this.appConfig,
341
+ refreshRouterRoutesCallback: this.createSharedWatchRefreshCallback({
342
+ staticRoutes: this.staticRoutes,
343
+ hmrManager: this.hmrManager
344
+ }),
396
345
  hmrManager: this.hmrManager,
397
346
  bridge: this.bridge
398
347
  });
399
- await watcher.createWatcherSubscription();
400
348
  }
401
349
  appLogger.debug("Node server adapter initialization completed", {
402
350
  apiHandlers: this.apiHandlers.length,
@@ -407,7 +355,7 @@ class NodeServerAdapter extends SharedServerAdapter {
407
355
  }
408
356
  }
409
357
  async function createNodeServerAdapter(params) {
410
- const runtimeOrigin = params.runtimeOrigin ?? `http://${params.serveOptions.hostname || "localhost"}:${params.serveOptions.port || 3e3}`;
358
+ const runtimeOrigin = params.runtimeOrigin ?? `http://${params.serveOptions.hostname || DEFAULT_ECOPAGES_HOSTNAME}:${params.serveOptions.port || DEFAULT_ECOPAGES_PORT}`;
411
359
  const adapter = new NodeServerAdapter({
412
360
  ...params,
413
361
  runtimeOrigin
@@ -1,24 +1,60 @@
1
1
  import { type Server as NodeHttpServer } from 'node:http';
2
- import type { EcoPagesAppConfig } from '../../internal-types.js';
2
+ import type { EcoPagesAppConfig } from '../../types/internal-types.js';
3
3
  type NodeStaticContentServerOptions = {
4
4
  hostname?: string;
5
5
  port?: number;
6
6
  };
7
+ /**
8
+ * Serves prebuilt static Ecopages output through Node's HTTP server.
9
+ *
10
+ * @remarks
11
+ * This server is used by the Node preview/build path once the app has already
12
+ * emitted its static output. It intentionally stays small: path sanitization,
13
+ * content-type selection, optional gzip serving, and 404 handling.
14
+ */
7
15
  export declare class NodeStaticContentServer {
8
16
  private readonly appConfig;
9
17
  private readonly options;
10
18
  private server;
19
+ /**
20
+ * Creates the Node static-content server for one built app output directory.
21
+ */
11
22
  constructor({ appConfig, options }: {
12
23
  appConfig: EcoPagesAppConfig;
13
24
  options?: NodeStaticContentServerOptions;
14
25
  });
26
+ /**
27
+ * Returns whether the given content type should be served from a pre-gzipped
28
+ * companion file when available.
29
+ */
15
30
  private shouldServeGzip;
31
+ /**
32
+ * Normalizes a request pathname and rejects directory traversal attempts.
33
+ */
16
34
  private sanitizePath;
35
+ /**
36
+ * Writes one HTTP response with the provided headers and optional body.
37
+ */
17
38
  private sendResponse;
39
+ /**
40
+ * Serves the generated 404 page when present, or a plain-text fallback.
41
+ */
18
42
  private sendNotFoundPage;
43
+ /**
44
+ * Serves one concrete file path, honoring gzip and HEAD semantics.
45
+ */
19
46
  private serveFile;
47
+ /**
48
+ * Handles one incoming Node HTTP request against the built static output tree.
49
+ */
20
50
  private handleRequest;
51
+ /**
52
+ * Starts the static preview server.
53
+ */
21
54
  start(): Promise<NodeHttpServer>;
55
+ /**
56
+ * Stops the static preview server and optionally closes active connections.
57
+ */
22
58
  stop(force?: boolean): Promise<void>;
23
59
  }
24
60
  export {};
@@ -1,12 +1,15 @@
1
1
  import { createServer } from "node:http";
2
2
  import { extname, join, normalize, sep } from "node:path";
3
- import { DEFAULT_ECOPAGES_HOSTNAME, DEFAULT_ECOPAGES_PORT, STATUS_MESSAGE } from "../../constants.js";
3
+ import { DEFAULT_ECOPAGES_HOSTNAME, DEFAULT_ECOPAGES_PORT, STATUS_MESSAGE } from "../../config/constants.js";
4
4
  import { fileSystem } from "@ecopages/file-system";
5
5
  import { ServerUtils } from "../../utils/server-utils.module.js";
6
6
  class NodeStaticContentServer {
7
7
  appConfig;
8
8
  options;
9
9
  server = null;
10
+ /**
11
+ * Creates the Node static-content server for one built app output directory.
12
+ */
10
13
  constructor({ appConfig, options }) {
11
14
  this.appConfig = appConfig;
12
15
  this.options = {
@@ -14,9 +17,16 @@ class NodeStaticContentServer {
14
17
  port: options?.port ?? DEFAULT_ECOPAGES_PORT
15
18
  };
16
19
  }
20
+ /**
21
+ * Returns whether the given content type should be served from a pre-gzipped
22
+ * companion file when available.
23
+ */
17
24
  shouldServeGzip(contentType) {
18
25
  return ["text/javascript", "text/css"].includes(contentType);
19
26
  }
27
+ /**
28
+ * Normalizes a request pathname and rejects directory traversal attempts.
29
+ */
20
30
  sanitizePath(pathname) {
21
31
  const withoutLeadingSlash = pathname.replace(/^\/+/, "");
22
32
  const normalizedPath = normalize(withoutLeadingSlash);
@@ -25,6 +35,9 @@ class NodeStaticContentServer {
25
35
  }
26
36
  return normalizedPath;
27
37
  }
38
+ /**
39
+ * Writes one HTTP response with the provided headers and optional body.
40
+ */
28
41
  sendResponse(res, status, headers, body) {
29
42
  res.statusCode = status;
30
43
  for (const [key, value] of Object.entries(headers)) {
@@ -36,6 +49,9 @@ class NodeStaticContentServer {
36
49
  }
37
50
  res.end(body);
38
51
  }
52
+ /**
53
+ * Serves the generated 404 page when present, or a plain-text fallback.
54
+ */
39
55
  sendNotFoundPage(req, res) {
40
56
  const error404TemplatePath = join(this.appConfig.absolutePaths.distDir, "404.html");
41
57
  const isHead = (req.method ?? "GET").toUpperCase() === "HEAD";
@@ -51,6 +67,9 @@ class NodeStaticContentServer {
51
67
  const file = fileSystem.readFileAsBuffer(error404TemplatePath);
52
68
  this.sendResponse(res, 404, { "Content-Type": "text/html" }, isHead ? void 0 : file);
53
69
  }
70
+ /**
71
+ * Serves one concrete file path, honoring gzip and HEAD semantics.
72
+ */
54
73
  serveFile(req, res, filePath, status = 200) {
55
74
  const contentType = ServerUtils.getContentType(extname(filePath));
56
75
  const acceptsGzip = req.headers["accept-encoding"]?.includes("gzip");
@@ -79,6 +98,9 @@ class NodeStaticContentServer {
79
98
  const file = fileSystem.readFileAsBuffer(filePath);
80
99
  this.sendResponse(res, status, { "Content-Type": contentType }, isHead ? void 0 : file);
81
100
  }
101
+ /**
102
+ * Handles one incoming Node HTTP request against the built static output tree.
103
+ */
82
104
  handleRequest(req, res) {
83
105
  const method = (req.method ?? "GET").toUpperCase();
84
106
  const isHead = method === "HEAD";
@@ -129,6 +151,9 @@ class NodeStaticContentServer {
129
151
  }
130
152
  this.sendNotFoundPage(req, res);
131
153
  }
154
+ /**
155
+ * Starts the static preview server.
156
+ */
132
157
  async start() {
133
158
  if (this.server) {
134
159
  return this.server;
@@ -141,6 +166,9 @@ class NodeStaticContentServer {
141
166
  });
142
167
  return this.server;
143
168
  }
169
+ /**
170
+ * Stops the static preview server and optionally closes active connections.
171
+ */
144
172
  async stop(force = true) {
145
173
  if (!this.server) {
146
174
  return;
@@ -1,4 +1,4 @@
1
- import type { ApiHandler, ApiHandlerContext, Middleware, RouteGroupBuilder, RouteOptions } from '../../public-types.js';
1
+ import type { ApiHandler, ApiHandlerContext, Middleware, RouteGroupBuilder, RouteOptions } from '../../types/public-types.js';
2
2
  import { AbstractApplicationAdapter, type ApplicationAdapterOptions, type RouteGroupDefinition, type RouteHandler } from '../abstract/application-adapter.js';
3
3
  export declare abstract class SharedApplicationAdapter<TOptions extends ApplicationAdapterOptions = ApplicationAdapterOptions, TServer = any, TRequest extends Request = Request> extends AbstractApplicationAdapter<TOptions, TServer, TRequest> {
4
4
  protected register<P extends string, TContext extends ApiHandlerContext<TRequest, TServer> = ApiHandlerContext<TRequest, TServer>>(path: P, method: ApiHandler['method'], handler: RouteHandler<TRequest, TServer, TContext>, options?: RouteOptions<TRequest, TServer, TContext>): this;
@@ -1,4 +1,4 @@
1
- import type { ApiHandler, ApiHandlerContext, Middleware, RouteSchema, TypedGroupHandlerContext } from './public-types.js';
1
+ import type { ApiHandler, ApiHandlerContext, Middleware, RouteSchema, TypedGroupHandlerContext } from '../../types/public-types.js';
2
2
  type UniversalContext = ApiHandlerContext<Request, unknown>;
3
3
  type SchemaHandlerContext<TSchema extends RouteSchema | undefined, TContext extends UniversalContext> = TSchema extends RouteSchema ? TypedGroupHandlerContext<TSchema, TContext> : TContext;
4
4
  export declare function defineApiHandler<TPath extends string, TSchema extends RouteSchema | undefined = undefined, TContext extends UniversalContext = UniversalContext>(handler: Omit<ApiHandler<TPath, Request, unknown>, 'handler' | 'middleware' | 'schema'> & {
@@ -0,0 +1,25 @@
1
+ import type { EcoPagesAppConfig } from '../../types/internal-types.js';
2
+ import type { EcoFunctionComponent, EcoPageComponent } from '../../types/public-types.js';
3
+ import type { ExplicitViewRenderer, ExplicitViewRendererResolver } from '../../route-renderer/route-renderer.js';
4
+ type ExplicitStaticRenderPreparationResult = {
5
+ renderer: ExplicitViewRenderer;
6
+ props: Record<string, unknown>;
7
+ view: EcoFunctionComponent<Record<string, unknown>, any>;
8
+ };
9
+ /**
10
+ * Resolves the renderer and static props needed to render one explicit static
11
+ * view at runtime or during static generation.
12
+ */
13
+ export declare function prepareExplicitStaticRender(input: {
14
+ routePath: string;
15
+ view: EcoPageComponent<any>;
16
+ params: Record<string, string | string[]>;
17
+ appConfig: EcoPagesAppConfig;
18
+ runtimeOrigin: string;
19
+ routeRendererFactory: ExplicitViewRendererResolver;
20
+ errors: {
21
+ missingIntegration(routePath: string): string;
22
+ noRendererForIntegration(integrationName: string): string;
23
+ };
24
+ }): Promise<ExplicitStaticRenderPreparationResult>;
25
+ export {};
@@ -0,0 +1,26 @@
1
+ function getViewIntegrationName(view) {
2
+ return view.config?.integration ?? view.config?.__eco?.integration;
3
+ }
4
+ async function prepareExplicitStaticRender(input) {
5
+ const integrationName = getViewIntegrationName(input.view);
6
+ if (!integrationName) {
7
+ throw new Error(input.errors.missingIntegration(input.routePath));
8
+ }
9
+ const renderer = input.routeRendererFactory.getExplicitViewRenderer(integrationName);
10
+ if (!renderer) {
11
+ throw new Error(input.errors.noRendererForIntegration(integrationName));
12
+ }
13
+ const props = input.view.staticProps ? (await input.view.staticProps({
14
+ pathname: { params: input.params },
15
+ appConfig: input.appConfig,
16
+ runtimeOrigin: input.runtimeOrigin
17
+ })).props : {};
18
+ return {
19
+ renderer,
20
+ props,
21
+ view: input.view
22
+ };
23
+ }
24
+ export {
25
+ prepareExplicitStaticRender
26
+ };
@@ -1,19 +1,22 @@
1
- import type { EcoPagesAppConfig } from '../../internal-types.js';
2
- import type { StaticRoute } from '../../public-types.js';
3
- import type { RouteRendererFactory } from '../../route-renderer/route-renderer.js';
1
+ import type { EcoPagesAppConfig } from '../../types/internal-types.js';
2
+ import type { StaticRoute } from '../../types/public-types.js';
3
+ import type { ExplicitViewRendererResolver } from '../../route-renderer/route-renderer.js';
4
4
  export declare const EXPLICIT_STATIC_ROUTE_MATCHER_ERRORS: {
5
5
  readonly missingIntegration: (routePath: string) => string;
6
6
  readonly noRendererForIntegration: (integrationName: string) => string;
7
7
  };
8
8
  export interface ExplicitStaticRouteMatcherOptions {
9
9
  appConfig: EcoPagesAppConfig;
10
- routeRendererFactory: RouteRendererFactory;
10
+ routeRendererFactory: ExplicitViewRendererResolver;
11
11
  staticRoutes: StaticRoute[];
12
12
  }
13
13
  export interface ExplicitRouteMatch {
14
14
  route: StaticRoute;
15
15
  params: Record<string, string>;
16
16
  }
17
+ /**
18
+ * Matches and renders explicit static routes declared through `app.static()`.
19
+ */
17
20
  export declare class ExplicitStaticRouteMatcher {
18
21
  private readonly appConfig;
19
22
  private readonly routeRendererFactory;
@@ -1,4 +1,5 @@
1
1
  import { appLogger } from "../../global/app-logger.js";
2
+ import { prepareExplicitStaticRender } from "./explicit-static-render-preparation.js";
2
3
  const EXPLICIT_STATIC_ROUTE_MATCHER_ERRORS = {
3
4
  missingIntegration: (routePath) => `View at ${routePath} is missing __eco.integration. Ensure it's defined with eco.page() and exported as default.`,
4
5
  noRendererForIntegration: (integrationName) => `No renderer found for integration: ${integrationName}`
@@ -71,20 +72,20 @@ class ExplicitStaticRouteMatcher {
71
72
  try {
72
73
  const mod = await route.loader();
73
74
  const view = mod.default;
74
- const integrationName = view.config?.__eco?.integration;
75
- if (!integrationName) {
76
- throw new Error(EXPLICIT_STATIC_ROUTE_MATCHER_ERRORS.missingIntegration(route.path));
77
- }
78
- const renderer = this.routeRendererFactory.getRendererByIntegration(integrationName);
79
- if (!renderer) {
80
- throw new Error(EXPLICIT_STATIC_ROUTE_MATCHER_ERRORS.noRendererForIntegration(integrationName));
81
- }
82
- const props = view.staticProps ? (await view.staticProps({
83
- pathname: { params },
75
+ const {
76
+ renderer,
77
+ props,
78
+ view: renderableView
79
+ } = await prepareExplicitStaticRender({
80
+ routePath: route.path,
81
+ view,
82
+ params,
84
83
  appConfig: this.appConfig,
85
- runtimeOrigin: this.appConfig.baseUrl
86
- })).props : {};
87
- return renderer.renderToResponse(view, props, {});
84
+ runtimeOrigin: this.appConfig.baseUrl,
85
+ routeRendererFactory: this.routeRendererFactory,
86
+ errors: EXPLICIT_STATIC_ROUTE_MATCHER_ERRORS
87
+ });
88
+ return renderer.renderToResponse(renderableView, props, {});
88
89
  } catch (error) {
89
90
  appLogger.error(
90
91
  `Error rendering explicit static route ${route.path}:`,
@@ -1,8 +1,6 @@
1
- import type { Middleware, ApiHandlerContext, RequestLocals } from '../../public-types.js';
1
+ import type { FileRouteMiddleware, FileRouteMiddlewareContext, RequestLocals } from '../../types/public-types.js';
2
2
  import type { PageCacheService } from '../../services/cache/page-cache-service.js';
3
3
  export declare const FILE_ROUTE_MIDDLEWARE_PIPELINE_ERRORS: {
4
- readonly CTX_RENDER_UNAVAILABLE: "[ecopages] ctx.render is not available in file-route middleware";
5
- readonly CTX_RENDER_PARTIAL_UNAVAILABLE: "[ecopages] ctx.renderPartial is not available in file-route middleware";
6
4
  readonly middlewareRequiresDynamic: (filePath: string) => string;
7
5
  };
8
6
  /**
@@ -26,7 +24,7 @@ export declare class FileRouteMiddlewarePipeline {
26
24
  * @throws LocalsAccessError When middleware is configured for a non-dynamic page.
27
25
  */
28
26
  assertValidConfiguration(input: {
29
- middleware: Middleware[];
27
+ middleware: FileRouteMiddleware[];
30
28
  pageCacheStrategy: 'static' | 'dynamic' | {
31
29
  revalidate: number;
32
30
  tags?: string[];
@@ -36,9 +34,8 @@ export declare class FileRouteMiddlewarePipeline {
36
34
  /**
37
35
  * Creates the request-scoped middleware context used by page middleware.
38
36
  *
39
- * The context intentionally disables `render()` and `renderPartial()` inside
40
- * file-route middleware because rendering is owned by the page route pipeline,
41
- * not by middleware stages.
37
+ * The context intentionally omits `render()` and `renderPartial()` because
38
+ * rendering is owned by the page route pipeline, not by middleware stages.
42
39
  *
43
40
  * @param input Request details and the mutable locals store.
44
41
  * @returns Middleware execution context.
@@ -47,7 +44,7 @@ export declare class FileRouteMiddlewarePipeline {
47
44
  request: Request;
48
45
  params: Record<string, string>;
49
46
  locals: RequestLocals;
50
- }): ApiHandlerContext;
47
+ }): FileRouteMiddlewareContext;
51
48
  /**
52
49
  * Runs the middleware chain and eventually delegates to the render callback.
53
50
  *
@@ -58,8 +55,8 @@ export declare class FileRouteMiddlewarePipeline {
58
55
  * @returns Response from middleware or final render stage.
59
56
  */
60
57
  run(input: {
61
- middleware: Middleware[];
62
- context: ApiHandlerContext;
58
+ middleware: FileRouteMiddleware[];
59
+ context: FileRouteMiddlewareContext;
63
60
  renderResponse: () => Promise<Response>;
64
61
  }): Promise<Response>;
65
62
  }
@@ -2,11 +2,10 @@ import { createRequire } from "../../utils/locals-utils.js";
2
2
  import { ApiResponseBuilder } from "./api-response.js";
3
3
  import { LocalsAccessError } from "../../errors/locals-access-error.js";
4
4
  const FILE_ROUTE_MIDDLEWARE_PIPELINE_ERRORS = {
5
- CTX_RENDER_UNAVAILABLE: "[ecopages] ctx.render is not available in file-route middleware",
6
- CTX_RENDER_PARTIAL_UNAVAILABLE: "[ecopages] ctx.renderPartial is not available in file-route middleware",
7
5
  middlewareRequiresDynamic: (filePath) => `[ecopages] Page middleware requires cache: 'dynamic'. Page: ${filePath}`
8
6
  };
9
7
  class FileRouteMiddlewarePipeline {
8
+ cacheService;
10
9
  constructor(cacheService) {
11
10
  this.cacheService = cacheService;
12
11
  }
@@ -29,9 +28,8 @@ class FileRouteMiddlewarePipeline {
29
28
  /**
30
29
  * Creates the request-scoped middleware context used by page middleware.
31
30
  *
32
- * The context intentionally disables `render()` and `renderPartial()` inside
33
- * file-route middleware because rendering is owned by the page route pipeline,
34
- * not by middleware stages.
31
+ * The context intentionally omits `render()` and `renderPartial()` because
32
+ * rendering is owned by the page route pipeline, not by middleware stages.
35
33
  *
36
34
  * @param input Request details and the mutable locals store.
37
35
  * @returns Middleware execution context.
@@ -47,12 +45,6 @@ class FileRouteMiddlewarePipeline {
47
45
  },
48
46
  locals: input.locals,
49
47
  require: createRequire(() => context.locals),
50
- render: async () => {
51
- throw new Error(FILE_ROUTE_MIDDLEWARE_PIPELINE_ERRORS.CTX_RENDER_UNAVAILABLE);
52
- },
53
- renderPartial: async () => {
54
- throw new Error(FILE_ROUTE_MIDDLEWARE_PIPELINE_ERRORS.CTX_RENDER_PARTIAL_UNAVAILABLE);
55
- },
56
48
  json: (data, options) => {
57
49
  const builder = new ApiResponseBuilder();
58
50
  if (options?.status) builder.status(options.status);