@ecopages/core 0.2.0-alpha.9 → 0.2.1

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