@ecopages/core 0.2.0-alpha.22 → 0.2.0-alpha.24

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 (515) hide show
  1. package/package.json +93 -226
  2. package/src/adapters/abstract/application-adapter.test.ts +172 -0
  3. package/src/adapters/abstract/application-adapter.ts +379 -0
  4. package/src/adapters/abstract/router-adapter.ts +30 -0
  5. package/src/adapters/abstract/server-adapter.ts +79 -0
  6. package/src/adapters/bun/client-bridge.ts +62 -0
  7. package/src/adapters/bun/create-app.ts +180 -0
  8. package/src/adapters/bun/hmr-manager.test.ts +267 -0
  9. package/src/adapters/bun/hmr-manager.ts +406 -0
  10. package/src/adapters/bun/index.ts +2 -0
  11. package/src/adapters/bun/server-adapter.ts +500 -0
  12. package/src/adapters/bun/server-lifecycle.ts +124 -0
  13. package/src/adapters/create-app.test.ts +10 -0
  14. package/src/adapters/create-app.ts +91 -0
  15. package/src/adapters/index.ts +2 -0
  16. package/src/adapters/node/create-app.test.ts +53 -0
  17. package/src/adapters/node/create-app.ts +183 -0
  18. package/src/adapters/node/node-client-bridge.test.ts +198 -0
  19. package/src/adapters/node/node-client-bridge.ts +79 -0
  20. package/src/adapters/node/node-hmr-manager.test.ts +322 -0
  21. package/src/adapters/node/node-hmr-manager.ts +378 -0
  22. package/src/adapters/node/server-adapter.ts +502 -0
  23. package/src/adapters/node/static-content-server.test.ts +60 -0
  24. package/src/adapters/node/static-content-server.ts +239 -0
  25. package/src/adapters/shared/api-response.test.ts +97 -0
  26. package/src/adapters/shared/api-response.ts +104 -0
  27. package/src/adapters/shared/application-adapter.ts +199 -0
  28. package/src/adapters/shared/define-api-handler.ts +66 -0
  29. package/src/adapters/shared/explicit-static-route-matcher.test.ts +381 -0
  30. package/src/adapters/shared/explicit-static-route-matcher.ts +140 -0
  31. package/src/adapters/shared/file-route-middleware-pipeline.test.ts +90 -0
  32. package/src/adapters/shared/file-route-middleware-pipeline.ts +127 -0
  33. package/src/adapters/shared/fs-server-response-factory.test.ts +187 -0
  34. package/src/adapters/shared/fs-server-response-factory.ts +118 -0
  35. package/src/adapters/shared/fs-server-response-matcher.test.ts +285 -0
  36. package/src/adapters/shared/fs-server-response-matcher.ts +189 -0
  37. package/src/adapters/shared/hmr-entrypoint-registrar.ts +149 -0
  38. package/src/adapters/shared/hmr-html-response.ts +52 -0
  39. package/src/adapters/shared/hmr-manager.contract.test.ts +232 -0
  40. package/src/adapters/shared/hmr-manager.dispatch.test.ts +220 -0
  41. package/src/adapters/shared/render-context.test.ts +150 -0
  42. package/src/adapters/shared/render-context.ts +123 -0
  43. package/src/adapters/shared/runtime-bootstrap.ts +79 -0
  44. package/src/adapters/shared/server-adapter.test.ts +77 -0
  45. package/src/adapters/shared/server-adapter.ts +493 -0
  46. package/src/adapters/shared/server-route-handler.test.ts +110 -0
  47. package/src/adapters/shared/server-route-handler.ts +153 -0
  48. package/src/adapters/shared/server-static-builder.test.ts +338 -0
  49. package/src/adapters/shared/server-static-builder.ts +170 -0
  50. package/src/build/build-adapter-serialization.test.ts +281 -0
  51. package/src/build/build-adapter.test.ts +1240 -0
  52. package/src/build/build-adapter.ts +1012 -0
  53. package/src/build/build-manifest.ts +54 -0
  54. package/src/build/build-types.ts +83 -0
  55. package/src/build/dev-build-coordinator.ts +220 -0
  56. package/src/build/esbuild-build-adapter.ts +660 -0
  57. package/src/build/runtime-build-executor.test.ts +81 -0
  58. package/src/build/runtime-build-executor.ts +40 -0
  59. package/src/build/runtime-specifier-alias-plugin.test.ts +67 -0
  60. package/src/build/runtime-specifier-alias-plugin.ts +62 -0
  61. package/src/build/runtime-specifier-aliases.ts +135 -0
  62. package/src/config/config-builder.test.ts +443 -0
  63. package/src/config/config-builder.ts +742 -0
  64. package/src/config/config-builder.typecheck.test.ts +96 -0
  65. package/src/config/{constants.d.ts → constants.ts} +22 -13
  66. package/src/dev/sc-server.ts +143 -0
  67. package/src/eco/eco.browser.test.ts +43 -0
  68. package/src/eco/eco.browser.ts +118 -0
  69. package/src/eco/eco.test.ts +654 -0
  70. package/src/eco/eco.ts +205 -0
  71. package/src/eco/eco.types.ts +221 -0
  72. package/src/eco/eco.utils.test.ts +219 -0
  73. package/src/eco/eco.utils.ts +5 -0
  74. package/src/eco/global-injector-map.test.ts +42 -0
  75. package/src/eco/global-injector-map.ts +112 -0
  76. package/src/eco/lazy-injector-map.test.ts +66 -0
  77. package/src/eco/lazy-injector-map.ts +120 -0
  78. package/src/eco/module-dependencies.test.ts +30 -0
  79. package/src/eco/module-dependencies.ts +75 -0
  80. package/src/errors/http-error.test.ts +134 -0
  81. package/src/errors/http-error.ts +72 -0
  82. package/src/errors/{index.d.ts → index.ts} +2 -2
  83. package/src/errors/locals-access-error.ts +7 -0
  84. package/src/global/app-logger.ts +4 -0
  85. package/src/global/utils.test.ts +12 -0
  86. 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
  87. package/src/hmr/client/__screenshots__/hmr-runtime.test.browser.ts/HMR-Runtime-HMR-Server-Integration-should-load-fixture-app-page-1.png +0 -0
  88. package/src/hmr/client/__screenshots__/hmr-runtime.test.browser.ts/HMR-Runtime-WebSocket-Connection-should-connect-to-correct-HMR-endpoint-1.png +0 -0
  89. package/src/hmr/client/hmr-runtime.ts +160 -0
  90. package/src/hmr/hmr-strategy.test.ts +124 -0
  91. package/src/hmr/hmr-strategy.ts +177 -0
  92. package/src/hmr/hmr.postcss.test.e2e.ts +41 -0
  93. package/src/hmr/hmr.test.e2e.ts +66 -0
  94. package/src/hmr/strategies/default-hmr-strategy.ts +60 -0
  95. package/src/hmr/strategies/js-hmr-strategy.test.ts +335 -0
  96. package/src/hmr/strategies/js-hmr-strategy.ts +320 -0
  97. package/src/index.browser.ts +3 -0
  98. package/src/index.ts +15 -0
  99. package/src/integrations/ghtml/ghtml-renderer.test.ts +253 -0
  100. package/src/integrations/ghtml/ghtml-renderer.ts +97 -0
  101. package/src/integrations/ghtml/ghtml.constants.ts +1 -0
  102. package/src/integrations/ghtml/ghtml.plugin.ts +28 -0
  103. package/src/plugins/alias-resolver-plugin.test.ts +41 -0
  104. package/src/plugins/alias-resolver-plugin.ts +63 -0
  105. package/src/plugins/eco-component-meta-plugin.test.ts +406 -0
  106. package/src/plugins/eco-component-meta-plugin.ts +495 -0
  107. package/src/plugins/foreign-jsx-override-plugin.test.ts +65 -0
  108. package/src/plugins/foreign-jsx-override-plugin.ts +67 -0
  109. package/src/plugins/integration-plugin.test.ts +156 -0
  110. package/src/plugins/integration-plugin.ts +311 -0
  111. package/src/plugins/processor.test.ts +148 -0
  112. package/src/plugins/processor.ts +240 -0
  113. package/src/plugins/{runtime-capability.d.ts → runtime-capability.ts} +8 -3
  114. package/src/plugins/source-transform.test.ts +82 -0
  115. package/src/plugins/source-transform.ts +123 -0
  116. package/src/route-renderer/orchestration/boundary-planning.service.ts +146 -0
  117. package/src/route-renderer/orchestration/component-render-context.ts +318 -0
  118. package/src/route-renderer/orchestration/integration-renderer.test.ts +2088 -0
  119. package/src/route-renderer/orchestration/integration-renderer.ts +1285 -0
  120. package/src/route-renderer/orchestration/page-packaging.service.test.ts +76 -0
  121. package/src/route-renderer/orchestration/page-packaging.service.ts +85 -0
  122. package/src/route-renderer/orchestration/processed-asset-dedupe.ts +25 -0
  123. package/src/route-renderer/orchestration/queued-boundary-runtime.service.test.ts +319 -0
  124. package/src/route-renderer/orchestration/queued-boundary-runtime.service.ts +289 -0
  125. package/src/route-renderer/orchestration/render-execution.service.test.ts +196 -0
  126. package/src/route-renderer/orchestration/render-execution.service.ts +182 -0
  127. package/src/route-renderer/orchestration/render-output.utils.ts +302 -0
  128. package/src/route-renderer/orchestration/render-preparation.service.test.ts +569 -0
  129. package/src/route-renderer/orchestration/render-preparation.service.ts +508 -0
  130. package/src/route-renderer/orchestration/route-shell-composer.service.ts +162 -0
  131. package/src/route-renderer/orchestration/template-serialization.test.ts +110 -0
  132. package/src/route-renderer/orchestration/template-serialization.ts +117 -0
  133. package/src/route-renderer/page-loading/component-dependency-collection.ts +196 -0
  134. package/src/route-renderer/page-loading/declared-asset-collection.ts +156 -0
  135. package/src/route-renderer/page-loading/dependency-resolver.test.ts +665 -0
  136. package/src/route-renderer/page-loading/dependency-resolver.ts +150 -0
  137. package/src/route-renderer/page-loading/ecopages-virtual-imports.ts +75 -0
  138. package/src/route-renderer/page-loading/lazy-entry-collection.ts +167 -0
  139. package/src/route-renderer/page-loading/lazy-trigger-planning.ts +74 -0
  140. package/src/route-renderer/page-loading/module-declaration-aggregation.ts +60 -0
  141. package/src/route-renderer/page-loading/module-declaration-scripts.ts +16 -0
  142. package/src/route-renderer/page-loading/page-dependency-bundling.ts +205 -0
  143. package/src/route-renderer/page-loading/page-module-loader.test.ts +183 -0
  144. package/src/route-renderer/page-loading/page-module-loader.ts +184 -0
  145. package/src/route-renderer/route-renderer.ts +136 -0
  146. package/src/router/client/link-intent.test.browser.ts +51 -0
  147. package/src/router/client/link-intent.ts +92 -0
  148. package/src/router/client/navigation-coordinator.test.ts +237 -0
  149. package/src/router/client/navigation-coordinator.ts +453 -0
  150. package/src/router/server/fs-router-scanner.test.ts +83 -0
  151. package/src/router/server/fs-router-scanner.ts +224 -0
  152. package/src/router/server/fs-router.test.ts +214 -0
  153. package/src/router/server/fs-router.ts +122 -0
  154. package/src/services/assets/asset-processing-service/asset-dependency-keys.ts +66 -0
  155. package/src/services/assets/asset-processing-service/asset-processing.service.test.ts +476 -0
  156. package/src/services/assets/asset-processing-service/asset-processing.service.ts +345 -0
  157. package/src/services/assets/asset-processing-service/asset.factory.test.ts +63 -0
  158. package/src/services/assets/asset-processing-service/asset.factory.ts +105 -0
  159. package/src/services/assets/asset-processing-service/assets.types.ts +125 -0
  160. package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.test.ts +74 -0
  161. package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.ts +96 -0
  162. package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.test.ts +67 -0
  163. package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.ts +78 -0
  164. package/src/services/assets/asset-processing-service/grouped-content-bundles.ts +104 -0
  165. package/src/services/assets/asset-processing-service/index.ts +5 -0
  166. package/src/services/assets/asset-processing-service/{processor.interface.d.ts → processor.interface.ts} +10 -5
  167. package/src/services/assets/asset-processing-service/processor.registry.ts +18 -0
  168. package/src/services/assets/asset-processing-service/processors/base/base-processor.test.ts +59 -0
  169. package/src/services/assets/asset-processing-service/processors/base/base-processor.ts +83 -0
  170. package/src/services/assets/asset-processing-service/processors/base/base-script-processor.ts +174 -0
  171. package/src/services/assets/asset-processing-service/processors/index.ts +5 -0
  172. package/src/services/assets/asset-processing-service/processors/script/content-script.processor.test.ts +192 -0
  173. package/src/services/assets/asset-processing-service/processors/script/content-script.processor.ts +134 -0
  174. package/src/services/assets/asset-processing-service/processors/script/file-script.processor.test.ts +326 -0
  175. package/src/services/assets/asset-processing-service/processors/script/file-script.processor.ts +110 -0
  176. package/src/services/assets/asset-processing-service/processors/script/node-module-script.processor.test.ts +227 -0
  177. package/src/services/assets/asset-processing-service/processors/script/node-module-script.processor.ts +87 -0
  178. package/src/services/assets/asset-processing-service/processors/stylesheet/content-stylesheet.processor.test.ts +261 -0
  179. package/src/services/assets/asset-processing-service/processors/stylesheet/content-stylesheet.processor.ts +71 -0
  180. package/src/services/assets/asset-processing-service/processors/stylesheet/file-stylesheet.processor.ts +81 -0
  181. package/src/services/assets/asset-processing-service/ungrouped-dependency-processing.ts +65 -0
  182. package/src/services/assets/browser-bundle.service.test.ts +66 -0
  183. package/src/services/assets/browser-bundle.service.ts +109 -0
  184. package/src/services/cache/cache.types.ts +126 -0
  185. package/src/services/cache/index.ts +18 -0
  186. package/src/services/cache/memory-cache-store.test.ts +225 -0
  187. package/src/services/cache/memory-cache-store.ts +130 -0
  188. package/src/services/cache/page-cache-service.test.ts +175 -0
  189. package/src/services/cache/page-cache-service.ts +202 -0
  190. package/src/services/cache/page-request-cache-coordinator.service.test.ts +79 -0
  191. package/src/services/cache/page-request-cache-coordinator.service.ts +131 -0
  192. package/src/services/html/html-rewriter-provider.service.test.ts +183 -0
  193. package/src/services/html/html-rewriter-provider.service.ts +104 -0
  194. package/src/services/html/html-transformer.service.test.ts +479 -0
  195. package/src/services/html/html-transformer.service.ts +275 -0
  196. package/src/services/invalidation/development-invalidation.service.test.ts +87 -0
  197. package/src/services/invalidation/development-invalidation.service.ts +262 -0
  198. package/src/services/module-loading/app-module-loader.service.ts +9 -0
  199. package/src/services/module-loading/app-server-module-transpiler.service.test.ts +130 -0
  200. package/src/services/module-loading/app-server-module-transpiler.service.ts +143 -0
  201. package/src/services/module-loading/host-module-loader-registry.ts +15 -0
  202. package/src/services/module-loading/{module-loading-types.d.ts → module-loading-types.ts} +1 -0
  203. package/src/services/module-loading/node-bootstrap-plugin.test.ts +335 -0
  204. package/src/services/module-loading/node-bootstrap-plugin.ts +297 -0
  205. package/src/services/module-loading/page-module-import.service.test.ts +504 -0
  206. package/src/services/module-loading/page-module-import.service.ts +252 -0
  207. package/src/services/module-loading/server-module-transpiler.service.test.ts +243 -0
  208. package/src/services/module-loading/server-module-transpiler.service.ts +104 -0
  209. package/src/services/module-loading/source-module-support.ts +19 -0
  210. package/src/services/runtime-state/dev-graph.service.ts +217 -0
  211. package/src/services/runtime-state/entrypoint-dependency-graph.service.ts +136 -0
  212. package/src/services/runtime-state/runtime-specifier-registry.service.ts +96 -0
  213. package/src/services/runtime-state/server-invalidation-state.service.ts +68 -0
  214. package/src/services/validation/schema-validation-service.test.ts +223 -0
  215. package/src/services/validation/schema-validation-service.ts +204 -0
  216. package/src/services/validation/{standard-schema.types.d.ts → standard-schema.types.ts} +20 -17
  217. package/src/static-site-generator/static-site-generator.test.ts +316 -0
  218. package/src/static-site-generator/static-site-generator.ts +462 -0
  219. package/src/types/internal-types.ts +242 -0
  220. package/src/types/public-types.ts +1443 -0
  221. package/src/utils/deep-merge.test.ts +114 -0
  222. package/src/utils/deep-merge.ts +47 -0
  223. package/src/utils/hash.ts +5 -0
  224. package/src/utils/html-escaping.ts +9 -0
  225. package/src/utils/invariant.test.ts +22 -0
  226. package/src/utils/invariant.ts +15 -0
  227. package/src/utils/locals-utils.ts +37 -0
  228. package/src/utils/parse-cli-args.test.ts +69 -0
  229. package/src/utils/parse-cli-args.ts +105 -0
  230. package/src/utils/path-utils.module.ts +14 -0
  231. package/src/utils/path-utils.test.ts +15 -0
  232. package/src/utils/resolve-work-dir.ts +45 -0
  233. package/src/utils/runtime.ts +44 -0
  234. package/src/utils/server-utils.module.ts +67 -0
  235. package/src/utils/server-utils.test.ts +38 -0
  236. package/src/watchers/project-watcher.integration.test.ts +337 -0
  237. package/src/watchers/project-watcher.test-helpers.ts +41 -0
  238. package/src/watchers/project-watcher.test.ts +768 -0
  239. package/src/watchers/project-watcher.ts +357 -0
  240. package/CHANGELOG.md +0 -51
  241. package/src/adapters/abstract/application-adapter.d.ts +0 -194
  242. package/src/adapters/abstract/application-adapter.js +0 -121
  243. package/src/adapters/abstract/router-adapter.d.ts +0 -26
  244. package/src/adapters/abstract/router-adapter.js +0 -5
  245. package/src/adapters/abstract/server-adapter.d.ts +0 -69
  246. package/src/adapters/abstract/server-adapter.js +0 -15
  247. package/src/adapters/bun/client-bridge.d.ts +0 -34
  248. package/src/adapters/bun/client-bridge.js +0 -48
  249. package/src/adapters/bun/create-app.d.ts +0 -52
  250. package/src/adapters/bun/create-app.js +0 -116
  251. package/src/adapters/bun/hmr-manager.d.ts +0 -143
  252. package/src/adapters/bun/hmr-manager.js +0 -333
  253. package/src/adapters/bun/index.d.ts +0 -2
  254. package/src/adapters/bun/index.js +0 -8
  255. package/src/adapters/bun/server-adapter.d.ts +0 -155
  256. package/src/adapters/bun/server-adapter.js +0 -374
  257. package/src/adapters/bun/server-lifecycle.d.ts +0 -63
  258. package/src/adapters/bun/server-lifecycle.js +0 -92
  259. package/src/adapters/create-app.d.ts +0 -20
  260. package/src/adapters/create-app.js +0 -66
  261. package/src/adapters/index.d.ts +0 -2
  262. package/src/adapters/index.js +0 -8
  263. package/src/adapters/node/create-app.d.ts +0 -18
  264. package/src/adapters/node/create-app.js +0 -149
  265. package/src/adapters/node/node-client-bridge.d.ts +0 -26
  266. package/src/adapters/node/node-client-bridge.js +0 -66
  267. package/src/adapters/node/node-hmr-manager.d.ts +0 -133
  268. package/src/adapters/node/node-hmr-manager.js +0 -311
  269. package/src/adapters/node/server-adapter.d.ts +0 -161
  270. package/src/adapters/node/server-adapter.js +0 -359
  271. package/src/adapters/node/static-content-server.d.ts +0 -60
  272. package/src/adapters/node/static-content-server.js +0 -194
  273. package/src/adapters/shared/api-response.d.ts +0 -52
  274. package/src/adapters/shared/api-response.js +0 -96
  275. package/src/adapters/shared/application-adapter.d.ts +0 -18
  276. package/src/adapters/shared/application-adapter.js +0 -90
  277. package/src/adapters/shared/define-api-handler.d.ts +0 -25
  278. package/src/adapters/shared/define-api-handler.js +0 -15
  279. package/src/adapters/shared/explicit-static-route-matcher.d.ts +0 -38
  280. package/src/adapters/shared/explicit-static-route-matcher.js +0 -103
  281. package/src/adapters/shared/file-route-middleware-pipeline.d.ts +0 -65
  282. package/src/adapters/shared/file-route-middleware-pipeline.js +0 -99
  283. package/src/adapters/shared/fs-server-response-factory.d.ts +0 -19
  284. package/src/adapters/shared/fs-server-response-factory.js +0 -97
  285. package/src/adapters/shared/fs-server-response-matcher.d.ts +0 -67
  286. package/src/adapters/shared/fs-server-response-matcher.js +0 -147
  287. package/src/adapters/shared/hmr-entrypoint-registrar.d.ts +0 -55
  288. package/src/adapters/shared/hmr-entrypoint-registrar.js +0 -87
  289. package/src/adapters/shared/hmr-html-response.d.ts +0 -22
  290. package/src/adapters/shared/hmr-html-response.js +0 -32
  291. package/src/adapters/shared/render-context.d.ts +0 -15
  292. package/src/adapters/shared/render-context.js +0 -72
  293. package/src/adapters/shared/runtime-bootstrap.d.ts +0 -38
  294. package/src/adapters/shared/runtime-bootstrap.js +0 -43
  295. package/src/adapters/shared/server-adapter.d.ts +0 -97
  296. package/src/adapters/shared/server-adapter.js +0 -390
  297. package/src/adapters/shared/server-route-handler.d.ts +0 -89
  298. package/src/adapters/shared/server-route-handler.js +0 -111
  299. package/src/adapters/shared/server-static-builder.d.ts +0 -70
  300. package/src/adapters/shared/server-static-builder.js +0 -100
  301. package/src/build/build-adapter.d.ts +0 -239
  302. package/src/build/build-adapter.js +0 -642
  303. package/src/build/build-manifest.d.ts +0 -27
  304. package/src/build/build-manifest.js +0 -30
  305. package/src/build/build-types.d.ts +0 -57
  306. package/src/build/build-types.js +0 -0
  307. package/src/build/dev-build-coordinator.d.ts +0 -72
  308. package/src/build/dev-build-coordinator.js +0 -154
  309. package/src/build/esbuild-build-adapter.d.ts +0 -78
  310. package/src/build/esbuild-build-adapter.js +0 -505
  311. package/src/build/runtime-build-executor.d.ts +0 -14
  312. package/src/build/runtime-build-executor.js +0 -22
  313. package/src/build/runtime-specifier-alias-plugin.d.ts +0 -15
  314. package/src/build/runtime-specifier-alias-plugin.js +0 -35
  315. package/src/build/runtime-specifier-aliases.d.ts +0 -5
  316. package/src/build/runtime-specifier-aliases.js +0 -95
  317. package/src/config/config-builder.d.ts +0 -252
  318. package/src/config/config-builder.js +0 -603
  319. package/src/config/constants.js +0 -25
  320. package/src/dev/sc-server.d.ts +0 -30
  321. package/src/dev/sc-server.js +0 -111
  322. package/src/eco/eco.browser.d.ts +0 -2
  323. package/src/eco/eco.browser.js +0 -83
  324. package/src/eco/eco.d.ts +0 -9
  325. package/src/eco/eco.js +0 -85
  326. package/src/eco/eco.types.d.ts +0 -178
  327. package/src/eco/eco.types.js +0 -0
  328. package/src/eco/eco.utils.d.ts +0 -1
  329. package/src/eco/eco.utils.js +0 -10
  330. package/src/eco/global-injector-map.d.ts +0 -16
  331. package/src/eco/global-injector-map.js +0 -80
  332. package/src/eco/lazy-injector-map.d.ts +0 -8
  333. package/src/eco/lazy-injector-map.js +0 -70
  334. package/src/eco/module-dependencies.d.ts +0 -18
  335. package/src/eco/module-dependencies.js +0 -49
  336. package/src/errors/http-error.d.ts +0 -31
  337. package/src/errors/http-error.js +0 -50
  338. package/src/errors/index.js +0 -4
  339. package/src/errors/locals-access-error.d.ts +0 -4
  340. package/src/errors/locals-access-error.js +0 -9
  341. package/src/global/app-logger.d.ts +0 -2
  342. package/src/global/app-logger.js +0 -6
  343. package/src/hmr/client/hmr-runtime.d.ts +0 -5
  344. package/src/hmr/client/hmr-runtime.js +0 -109
  345. package/src/hmr/hmr-strategy.d.ts +0 -162
  346. package/src/hmr/hmr-strategy.js +0 -44
  347. package/src/hmr/hmr.postcss.test.e2e.d.ts +0 -1
  348. package/src/hmr/hmr.postcss.test.e2e.js +0 -31
  349. package/src/hmr/hmr.test.e2e.d.ts +0 -1
  350. package/src/hmr/hmr.test.e2e.js +0 -43
  351. package/src/hmr/strategies/default-hmr-strategy.d.ts +0 -43
  352. package/src/hmr/strategies/default-hmr-strategy.js +0 -34
  353. package/src/hmr/strategies/js-hmr-strategy.d.ts +0 -139
  354. package/src/hmr/strategies/js-hmr-strategy.js +0 -178
  355. package/src/index.browser.d.ts +0 -3
  356. package/src/index.browser.js +0 -4
  357. package/src/index.d.ts +0 -6
  358. package/src/index.js +0 -21
  359. package/src/integrations/ghtml/ghtml-renderer.d.ts +0 -20
  360. package/src/integrations/ghtml/ghtml-renderer.js +0 -63
  361. package/src/integrations/ghtml/ghtml.constants.d.ts +0 -1
  362. package/src/integrations/ghtml/ghtml.constants.js +0 -4
  363. package/src/integrations/ghtml/ghtml.plugin.d.ts +0 -16
  364. package/src/integrations/ghtml/ghtml.plugin.js +0 -20
  365. package/src/plugins/alias-resolver-plugin.d.ts +0 -2
  366. package/src/plugins/alias-resolver-plugin.js +0 -53
  367. package/src/plugins/eco-component-meta-plugin.d.ts +0 -108
  368. package/src/plugins/eco-component-meta-plugin.js +0 -163
  369. package/src/plugins/foreign-jsx-override-plugin.d.ts +0 -31
  370. package/src/plugins/foreign-jsx-override-plugin.js +0 -35
  371. package/src/plugins/integration-plugin.d.ts +0 -219
  372. package/src/plugins/integration-plugin.js +0 -196
  373. package/src/plugins/processor.d.ts +0 -95
  374. package/src/plugins/processor.js +0 -136
  375. package/src/plugins/runtime-capability.js +0 -0
  376. package/src/plugins/source-transform.d.ts +0 -46
  377. package/src/plugins/source-transform.js +0 -71
  378. package/src/route-renderer/orchestration/boundary-planning.service.d.ts +0 -25
  379. package/src/route-renderer/orchestration/boundary-planning.service.js +0 -97
  380. package/src/route-renderer/orchestration/component-render-context.d.ts +0 -83
  381. package/src/route-renderer/orchestration/component-render-context.js +0 -147
  382. package/src/route-renderer/orchestration/integration-renderer.d.ts +0 -554
  383. package/src/route-renderer/orchestration/integration-renderer.js +0 -957
  384. package/src/route-renderer/orchestration/queued-boundary-runtime.service.d.ts +0 -89
  385. package/src/route-renderer/orchestration/queued-boundary-runtime.service.js +0 -155
  386. package/src/route-renderer/orchestration/render-execution.service.d.ts +0 -43
  387. package/src/route-renderer/orchestration/render-execution.service.js +0 -106
  388. package/src/route-renderer/orchestration/render-output.utils.d.ts +0 -46
  389. package/src/route-renderer/orchestration/render-output.utils.js +0 -65
  390. package/src/route-renderer/orchestration/render-preparation.service.d.ts +0 -120
  391. package/src/route-renderer/orchestration/render-preparation.service.js +0 -341
  392. package/src/route-renderer/orchestration/route-shell-composer.service.d.ts +0 -50
  393. package/src/route-renderer/orchestration/route-shell-composer.service.js +0 -81
  394. package/src/route-renderer/orchestration/template-serialization.d.ts +0 -38
  395. package/src/route-renderer/orchestration/template-serialization.js +0 -45
  396. package/src/route-renderer/page-loading/dependency-resolver.d.ts +0 -35
  397. package/src/route-renderer/page-loading/dependency-resolver.js +0 -444
  398. package/src/route-renderer/page-loading/page-module-loader.d.ts +0 -90
  399. package/src/route-renderer/page-loading/page-module-loader.js +0 -127
  400. package/src/route-renderer/route-renderer.d.ts +0 -67
  401. package/src/route-renderer/route-renderer.js +0 -103
  402. package/src/router/client/link-intent.js +0 -34
  403. package/src/router/client/link-intent.test.browser.d.ts +0 -1
  404. package/src/router/client/link-intent.test.browser.js +0 -43
  405. package/src/router/client/navigation-coordinator.d.ts +0 -149
  406. package/src/router/client/navigation-coordinator.js +0 -215
  407. package/src/router/server/fs-router-scanner.d.ts +0 -41
  408. package/src/router/server/fs-router-scanner.js +0 -161
  409. package/src/router/server/fs-router.d.ts +0 -26
  410. package/src/router/server/fs-router.js +0 -100
  411. package/src/services/assets/asset-processing-service/asset-processing.service.d.ts +0 -120
  412. package/src/services/assets/asset-processing-service/asset-processing.service.js +0 -331
  413. package/src/services/assets/asset-processing-service/asset.factory.d.ts +0 -17
  414. package/src/services/assets/asset-processing-service/asset.factory.js +0 -82
  415. package/src/services/assets/asset-processing-service/assets.types.d.ts +0 -89
  416. package/src/services/assets/asset-processing-service/assets.types.js +0 -0
  417. package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.d.ts +0 -55
  418. package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.js +0 -48
  419. package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.d.ts +0 -20
  420. package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.js +0 -41
  421. package/src/services/assets/asset-processing-service/index.d.ts +0 -5
  422. package/src/services/assets/asset-processing-service/index.js +0 -5
  423. package/src/services/assets/asset-processing-service/processor.interface.js +0 -6
  424. package/src/services/assets/asset-processing-service/processor.registry.d.ts +0 -8
  425. package/src/services/assets/asset-processing-service/processor.registry.js +0 -15
  426. package/src/services/assets/asset-processing-service/processors/base/base-processor.d.ts +0 -24
  427. package/src/services/assets/asset-processing-service/processors/base/base-processor.js +0 -64
  428. package/src/services/assets/asset-processing-service/processors/base/base-script-processor.d.ts +0 -17
  429. package/src/services/assets/asset-processing-service/processors/base/base-script-processor.js +0 -72
  430. package/src/services/assets/asset-processing-service/processors/index.d.ts +0 -5
  431. package/src/services/assets/asset-processing-service/processors/index.js +0 -5
  432. package/src/services/assets/asset-processing-service/processors/script/content-script.processor.d.ts +0 -5
  433. package/src/services/assets/asset-processing-service/processors/script/content-script.processor.js +0 -57
  434. package/src/services/assets/asset-processing-service/processors/script/file-script.processor.d.ts +0 -9
  435. package/src/services/assets/asset-processing-service/processors/script/file-script.processor.js +0 -88
  436. package/src/services/assets/asset-processing-service/processors/script/node-module-script.processor.d.ts +0 -7
  437. package/src/services/assets/asset-processing-service/processors/script/node-module-script.processor.js +0 -75
  438. package/src/services/assets/asset-processing-service/processors/stylesheet/content-stylesheet.processor.d.ts +0 -5
  439. package/src/services/assets/asset-processing-service/processors/stylesheet/content-stylesheet.processor.js +0 -25
  440. package/src/services/assets/asset-processing-service/processors/stylesheet/file-stylesheet.processor.d.ts +0 -9
  441. package/src/services/assets/asset-processing-service/processors/stylesheet/file-stylesheet.processor.js +0 -66
  442. package/src/services/assets/browser-bundle.service.d.ts +0 -32
  443. package/src/services/assets/browser-bundle.service.js +0 -33
  444. package/src/services/cache/cache.types.d.ts +0 -107
  445. package/src/services/cache/cache.types.js +0 -0
  446. package/src/services/cache/index.d.ts +0 -7
  447. package/src/services/cache/index.js +0 -7
  448. package/src/services/cache/memory-cache-store.d.ts +0 -42
  449. package/src/services/cache/memory-cache-store.js +0 -98
  450. package/src/services/cache/page-cache-service.d.ts +0 -70
  451. package/src/services/cache/page-cache-service.js +0 -152
  452. package/src/services/cache/page-request-cache-coordinator.service.d.ts +0 -75
  453. package/src/services/cache/page-request-cache-coordinator.service.js +0 -109
  454. package/src/services/html/html-rewriter-provider.service.d.ts +0 -37
  455. package/src/services/html/html-rewriter-provider.service.js +0 -68
  456. package/src/services/html/html-transformer.service.d.ts +0 -77
  457. package/src/services/html/html-transformer.service.js +0 -215
  458. package/src/services/invalidation/development-invalidation.service.d.ts +0 -74
  459. package/src/services/invalidation/development-invalidation.service.js +0 -190
  460. package/src/services/module-loading/app-module-loader.service.d.ts +0 -28
  461. package/src/services/module-loading/app-module-loader.service.js +0 -35
  462. package/src/services/module-loading/app-server-module-transpiler.service.d.ts +0 -24
  463. package/src/services/module-loading/app-server-module-transpiler.service.js +0 -109
  464. package/src/services/module-loading/host-module-loader-registry.d.ts +0 -4
  465. package/src/services/module-loading/host-module-loader-registry.js +0 -15
  466. package/src/services/module-loading/module-loading-types.js +0 -0
  467. package/src/services/module-loading/node-bootstrap-plugin.d.ts +0 -42
  468. package/src/services/module-loading/node-bootstrap-plugin.js +0 -204
  469. package/src/services/module-loading/page-module-import.service.d.ts +0 -76
  470. package/src/services/module-loading/page-module-import.service.js +0 -173
  471. package/src/services/module-loading/server-module-transpiler.service.d.ts +0 -72
  472. package/src/services/module-loading/server-module-transpiler.service.js +0 -64
  473. package/src/services/runtime-state/dev-graph.service.d.ts +0 -118
  474. package/src/services/runtime-state/dev-graph.service.js +0 -162
  475. package/src/services/runtime-state/entrypoint-dependency-graph.service.d.ts +0 -41
  476. package/src/services/runtime-state/entrypoint-dependency-graph.service.js +0 -85
  477. package/src/services/runtime-state/runtime-specifier-registry.service.d.ts +0 -69
  478. package/src/services/runtime-state/runtime-specifier-registry.service.js +0 -37
  479. package/src/services/runtime-state/server-invalidation-state.service.d.ts +0 -26
  480. package/src/services/runtime-state/server-invalidation-state.service.js +0 -35
  481. package/src/services/validation/schema-validation-service.d.ts +0 -122
  482. package/src/services/validation/schema-validation-service.js +0 -101
  483. package/src/services/validation/standard-schema.types.js +0 -0
  484. package/src/static-site-generator/static-site-generator.d.ts +0 -104
  485. package/src/static-site-generator/static-site-generator.js +0 -338
  486. package/src/types/internal-types.d.ts +0 -231
  487. package/src/types/internal-types.js +0 -0
  488. package/src/types/public-types.d.ts +0 -1219
  489. package/src/types/public-types.js +0 -0
  490. package/src/utils/deep-merge.d.ts +0 -14
  491. package/src/utils/deep-merge.js +0 -32
  492. package/src/utils/hash.d.ts +0 -1
  493. package/src/utils/hash.js +0 -7
  494. package/src/utils/html-escaping.d.ts +0 -7
  495. package/src/utils/html-escaping.js +0 -6
  496. package/src/utils/html.js +0 -4
  497. package/src/utils/invariant.d.ts +0 -5
  498. package/src/utils/invariant.js +0 -11
  499. package/src/utils/locals-utils.d.ts +0 -15
  500. package/src/utils/locals-utils.js +0 -24
  501. package/src/utils/parse-cli-args.d.ts +0 -27
  502. package/src/utils/parse-cli-args.js +0 -62
  503. package/src/utils/path-utils.module.d.ts +0 -5
  504. package/src/utils/path-utils.module.js +0 -14
  505. package/src/utils/resolve-work-dir.d.ts +0 -11
  506. package/src/utils/resolve-work-dir.js +0 -31
  507. package/src/utils/runtime.d.ts +0 -11
  508. package/src/utils/runtime.js +0 -40
  509. package/src/utils/server-utils.module.d.ts +0 -19
  510. package/src/utils/server-utils.module.js +0 -56
  511. package/src/watchers/project-watcher.d.ts +0 -136
  512. package/src/watchers/project-watcher.js +0 -275
  513. package/src/watchers/project-watcher.test-helpers.d.ts +0 -4
  514. package/src/watchers/project-watcher.test-helpers.js +0 -52
  515. /package/src/utils/{html.d.ts → html.ts} +0 -0
@@ -0,0 +1,742 @@
1
+ /**
2
+ * This module contains the ConfigBuilder class, which is used to build the EcoPagesAppConfig object.
3
+ * @module
4
+ */
5
+
6
+ import path from 'node:path';
7
+ import {
8
+ DEFAULT_ECOPAGES_DIST_DIR,
9
+ DEFAULT_ECOPAGES_HOSTNAME,
10
+ DEFAULT_ECOPAGES_PORT,
11
+ DEFAULT_ECOPAGES_WORK_DIR,
12
+ } from '../config/constants.ts';
13
+ import {
14
+ collectConfiguredAppBuildManifestContributions,
15
+ createBuildAdapter,
16
+ type BuildOwnership,
17
+ getAppServerBuildPlugins,
18
+ setAppBuildAdapter,
19
+ setAppBuildExecutor,
20
+ updateAppBuildManifest,
21
+ } from '../build/build-adapter.ts';
22
+ import type { EcoBuildPlugin } from '../build/build-types.ts';
23
+ import { createAppBuildExecutor } from '../build/dev-build-coordinator.ts';
24
+ import { GHTML_PLUGIN_NAME } from '../integrations/ghtml/ghtml.constants.ts';
25
+ import { ghtmlPlugin } from '../integrations/ghtml/ghtml.plugin.ts';
26
+ import type { EcoPagesAppConfig, RobotsPreference } from '../types/internal-types.ts';
27
+ import { createEcoComponentMetaPlugin } from '../plugins/eco-component-meta-plugin.ts';
28
+ import { createEcoComponentMetaTransform } from '../plugins/eco-component-meta-plugin.ts';
29
+ import type { IntegrationPlugin } from '../plugins/integration-plugin.ts';
30
+ import type { Processor } from '../plugins/processor.ts';
31
+ import type { EcoSourceTransform } from '../plugins/source-transform.ts';
32
+ import type { RuntimeCapabilityDeclaration, RuntimeCapabilityTag } from '../plugins/runtime-capability.ts';
33
+ import type { PageMetadataProps } from '../types/public-types.ts';
34
+ import type { CacheConfig } from '../services/cache/cache.types.ts';
35
+ import {
36
+ NoopEntrypointDependencyGraph,
37
+ setAppEntrypointDependencyGraph,
38
+ } from '../services/runtime-state/entrypoint-dependency-graph.service.ts';
39
+ import {
40
+ InMemoryRuntimeSpecifierRegistry,
41
+ setAppRuntimeSpecifierRegistry,
42
+ } from '../services/runtime-state/runtime-specifier-registry.service.ts';
43
+ import {
44
+ CounterServerInvalidationState,
45
+ setAppServerInvalidationState,
46
+ } from '../services/runtime-state/server-invalidation-state.service.ts';
47
+ import { invariant } from '../utils/invariant.ts';
48
+ import { appLogger } from '../global/app-logger.ts';
49
+ import { fileSystem } from '@ecopages/file-system';
50
+
51
+ export const CONFIG_BUILDER_ERRORS = {
52
+ DUPLICATE_INTEGRATION_NAMES: 'Integrations names must be unique',
53
+ DUPLICATE_INTEGRATION_EXTENSIONS: 'Integrations extensions must be unique',
54
+ MIXED_JSX_ENGINES:
55
+ 'Both kitajs and react integrations are enabled. Use per-file JSX import source/pragma consistently (e.g. `/** @jsxImportSource react */` for React files and `/** @jsxImportSource @kitajs/html */` for Kita files).',
56
+ duplicateProcessorName: (name: string) => `Processor with name "${name}" already exists`,
57
+ duplicateLoaderName: (name: string) => `Loader with name "${name}" already exists`,
58
+ duplicateSemanticTemplate: (kind: 'html' | '404', matches: string[]) =>
59
+ `Multiple ${kind} templates found: ${matches.join(', ')}`,
60
+ incompatibleRuntimeCapability: (
61
+ kind: 'integration' | 'processor',
62
+ name: string,
63
+ runtime: RuntimeKind,
64
+ reason: string,
65
+ ) => `Cannot enable ${kind} "${name}" on ${runtime}: ${reason}`,
66
+ unsupportedRuntimeVersion: (
67
+ kind: 'integration' | 'processor',
68
+ name: string,
69
+ runtime: RuntimeKind,
70
+ current: string,
71
+ min: string,
72
+ ) => `Cannot enable ${kind} "${name}" on ${runtime} ${current}: requires runtime version ${min} or newer`,
73
+ invalidRuntimeVersion: (kind: 'integration' | 'processor', name: string, version: string) =>
74
+ `Cannot validate ${kind} "${name}" runtimeCapability.minRuntimeVersion "${version}" because it is not a dot-separated numeric version`,
75
+ } as const;
76
+
77
+ type RuntimeKind = 'node' | 'bun';
78
+
79
+ type RuntimeEnvironment = {
80
+ runtime: RuntimeKind;
81
+ version: string;
82
+ supportedTags: Set<RuntimeCapabilityTag>;
83
+ };
84
+
85
+ type RuntimeCapabilityOwner = {
86
+ kind: 'integration' | 'processor';
87
+ name: string;
88
+ runtimeCapability?: RuntimeCapabilityDeclaration;
89
+ };
90
+
91
+ /**
92
+ * A builder class for creating and configuring EcoPages application configuration.
93
+ * Provides a fluent interface for setting various configuration options and managing
94
+ * application settings.
95
+ *
96
+ * @remarks
97
+ * The ConfigBuilder follows the builder pattern and allows for:
98
+ * - Setting directory paths for various components (pages, includes, layouts, etc.)
99
+ * - Configuring templates and includes
100
+ * - Managing integrations and plugins
101
+ * - Setting up processors and loaders
102
+ * - Configuring API handlers
103
+ * - Managing metadata and robots.txt preferences
104
+ *
105
+ * All setter methods return the instance of the builder for method chaining.
106
+ * The configuration is finalized by calling the `build()` method, which performs
107
+ * validation and initialization of the configuration.
108
+ *
109
+ * @throws {Error} When building configuration without required fields (e.g., baseUrl)
110
+ * @throws {Error} When adding duplicate processors or loaders
111
+ */
112
+ export class ConfigBuilder {
113
+ private buildOwnership: BuildOwnership = 'bun-native';
114
+
115
+ public config: EcoPagesAppConfig = {
116
+ baseUrl: '',
117
+ rootDir: '.',
118
+ srcDir: 'src',
119
+ pagesDir: 'pages',
120
+ includesDir: 'includes',
121
+ componentsDir: 'components',
122
+ layoutsDir: 'layouts',
123
+ publicDir: 'public',
124
+ robotsTxt: {
125
+ preferences: {
126
+ '*': [],
127
+ },
128
+ },
129
+ integrations: [],
130
+ integrationsDependencies: [],
131
+ distDir: DEFAULT_ECOPAGES_DIST_DIR,
132
+ defaultMetadata: {
133
+ title: 'Ecopages',
134
+ description: 'This is a static site generated with Ecopages',
135
+ },
136
+ additionalWatchPaths: [],
137
+ templatesExt: [],
138
+ absolutePaths: {
139
+ config: '',
140
+ componentsDir: '',
141
+ distDir: '',
142
+ workDir: '',
143
+ includesDir: '',
144
+ layoutsDir: '',
145
+ pagesDir: '',
146
+ projectDir: '',
147
+ publicDir: '',
148
+ srcDir: '',
149
+ htmlTemplatePath: '',
150
+ error404TemplatePath: '',
151
+ },
152
+ processors: new Map(),
153
+ loaders: new Map(),
154
+ sourceTransforms: new Map(),
155
+ workDir: DEFAULT_ECOPAGES_WORK_DIR,
156
+ };
157
+
158
+ /**
159
+ * Sets the base URL for the application.
160
+ * This URL is used as the root URL for all pages and assets.
161
+ *
162
+ * @param baseUrl - The base URL for the application (e.g., 'https://example.com')
163
+ * @returns The ConfigBuilder instance for method chaining
164
+ */
165
+ setBaseUrl(baseUrl: string): this {
166
+ this.config.baseUrl = baseUrl;
167
+ return this;
168
+ }
169
+
170
+ /**
171
+ * Sets the root directory of the project.
172
+ * This is the base directory from which all other paths are resolved.
173
+ *
174
+ * @param rootDir - The root directory path
175
+ * @returns The ConfigBuilder instance for method chaining
176
+ */
177
+ setRootDir(rootDir: string): this {
178
+ this.config.rootDir = rootDir;
179
+ return this;
180
+ }
181
+
182
+ /**
183
+ * Sets which runtime path owns build execution for the finalized app config.
184
+ *
185
+ * @remarks
186
+ * Bun-native remains the default. Vite-host ownership should be selected only
187
+ * for host-driven compatibility flows where core must not silently fall back to
188
+ * Bun build execution.
189
+ */
190
+ setBuildOwnership(buildOwnership: BuildOwnership): this {
191
+ this.buildOwnership = buildOwnership;
192
+ return this;
193
+ }
194
+
195
+ /**
196
+ * Sets the source directory relative to the root directory.
197
+ * This directory contains all the source files for the application.
198
+ *
199
+ * @param srcDir - The source directory name (default: 'src')
200
+ * @returns The ConfigBuilder instance for method chaining
201
+ */
202
+ setSrcDir(srcDir: string): this {
203
+ this.config.srcDir = srcDir;
204
+ return this;
205
+ }
206
+
207
+ /**
208
+ * Sets the pages directory relative to the source directory.
209
+ * This directory contains all the page files for the application.
210
+ *
211
+ * @param pagesDir - The pages directory name (default: 'pages')
212
+ * @returns The ConfigBuilder instance for method chaining
213
+ */
214
+ setPagesDir(pagesDir: string): this {
215
+ this.config.pagesDir = pagesDir;
216
+ return this;
217
+ }
218
+
219
+ /**
220
+ * Sets the includes directory relative to the source directory.
221
+ * This directory contains template includes and partials.
222
+ *
223
+ * @param includesDir - The includes directory name (default: 'includes')
224
+ * @returns The ConfigBuilder instance for method chaining
225
+ */
226
+ setIncludesDir(includesDir: string): this {
227
+ this.config.includesDir = includesDir;
228
+ return this;
229
+ }
230
+
231
+ /**
232
+ * Sets the components directory relative to the source directory.
233
+ * This directory contains reusable components.
234
+ *
235
+ * @param componentsDir - The components directory name (default: 'components')
236
+ * @returns The ConfigBuilder instance for method chaining
237
+ */
238
+ setComponentsDir(componentsDir: string): this {
239
+ this.config.componentsDir = componentsDir;
240
+ return this;
241
+ }
242
+
243
+ /**
244
+ * Sets the layouts directory relative to the source directory.
245
+ * This directory contains layout templates.
246
+ *
247
+ * @param layoutsDir - The layouts directory name (default: 'layouts')
248
+ * @returns The ConfigBuilder instance for method chaining
249
+ */
250
+ setLayoutsDir(layoutsDir: string): this {
251
+ this.config.layoutsDir = layoutsDir;
252
+ return this;
253
+ }
254
+
255
+ /**
256
+ * Sets the public directory relative to the source directory.
257
+ * This directory contains static assets that should be served as-is.
258
+ *
259
+ * @param publicDir - The public directory name (default: 'public')
260
+ * @returns The ConfigBuilder instance for method chaining
261
+ */
262
+ setPublicDir(publicDir: string): this {
263
+ this.config.publicDir = publicDir;
264
+ return this;
265
+ }
266
+
267
+ /**
268
+ * Sets the robots.txt configuration.
269
+ * This determines which paths are allowed/disallowed for search engines.
270
+ *
271
+ * @param robotsTxt - The robots.txt configuration object
272
+ * @returns The ConfigBuilder instance for method chaining
273
+ */
274
+ setRobotsTxt(robotsTxt: { preferences: RobotsPreference }): this {
275
+ this.config.robotsTxt = robotsTxt;
276
+ return this;
277
+ }
278
+
279
+ /**
280
+ * Sets the integration plugins to use.
281
+ * These plugins provide additional functionality to the application.
282
+ *
283
+ * @param integrations - An array of integration plugins
284
+ * @returns The ConfigBuilder instance for method chaining
285
+ */
286
+ setIntegrations(integrations: IntegrationPlugin<unknown>[]): this {
287
+ this.config.integrations = integrations;
288
+ return this;
289
+ }
290
+
291
+ /**
292
+ * Sets the output directory for the built application.
293
+ *
294
+ * @param distDir - The distribution directory name (default: 'dist')
295
+ * @returns The ConfigBuilder instance for method chaining
296
+ */
297
+ setDistDir(distDir: string): this {
298
+ this.config.distDir = distDir;
299
+ return this;
300
+ }
301
+
302
+ /**
303
+ * Sets the internal work directory for runtime-only artifacts.
304
+ *
305
+ * @remarks
306
+ * Use this when deployable output should stay clean while Ecopages still
307
+ * needs a separate workspace for server transpilation caches, runtime
308
+ * manifests, and other internal build products.
309
+ *
310
+ * @param workDir - The internal work directory name
311
+ * @returns The ConfigBuilder instance for method chaining
312
+ */
313
+ setWorkDir(workDir: string): this {
314
+ this.config.workDir = workDir;
315
+ return this;
316
+ }
317
+
318
+ /**
319
+ * Sets the default metadata for pages.
320
+ * This is used when a page doesn't specify its own metadata.
321
+ *
322
+ * @param defaultMetadata - The default metadata object
323
+ * @returns The ConfigBuilder instance for method chaining
324
+ */
325
+ setDefaultMetadata(defaultMetadata: PageMetadataProps): this {
326
+ this.config.defaultMetadata = {
327
+ ...this.config.defaultMetadata,
328
+ ...defaultMetadata,
329
+ };
330
+ return this;
331
+ }
332
+
333
+ /**
334
+ * Sets additional paths to watch for changes during development.
335
+ *
336
+ * @param additionalWatchPaths - An array of additional paths to watch
337
+ * @returns The ConfigBuilder instance for method chaining
338
+ */
339
+ setAdditionalWatchPaths(additionalWatchPaths: string[]): this {
340
+ this.config.additionalWatchPaths = additionalWatchPaths;
341
+ return this;
342
+ }
343
+
344
+ /**
345
+ * Sets the processors to use for the application.
346
+ * This replaces any existing processors.
347
+ *
348
+ * @param processors - An array of processors
349
+ * @returns The ConfigBuilder instance for method chaining
350
+ */
351
+ setProcessors(processors: Processor<any>[]): this {
352
+ this.config.processors.clear();
353
+ for (const processor of processors) {
354
+ this.addProcessor(processor);
355
+ }
356
+ return this;
357
+ }
358
+
359
+ /**
360
+ * Adds a processor to the application.
361
+ *
362
+ * @param processor - The processor to add
363
+ * @returns The ConfigBuilder instance for method chaining
364
+ * @throws Error if a processor with the same name already exists
365
+ */
366
+ addProcessor(processor: Processor): this {
367
+ if (this.config.processors.has(processor.name)) {
368
+ throw new Error(CONFIG_BUILDER_ERRORS.duplicateProcessorName(processor.name));
369
+ }
370
+ this.config.processors.set(processor.name, processor);
371
+ return this;
372
+ }
373
+
374
+ /**
375
+ * Sets the loaders to use for the application.
376
+ * This replaces any existing loaders.
377
+ *
378
+ * @param loaders - An array of build plugins to use as loaders
379
+ * @returns The ConfigBuilder instance for method chaining
380
+ */
381
+ setLoaders(loaders: EcoBuildPlugin[]): this {
382
+ this.config.loaders.clear();
383
+ for (const loader of loaders) {
384
+ this.addLoader(loader.name, loader);
385
+ }
386
+ return this;
387
+ }
388
+
389
+ /**
390
+ * Sets the source transforms to use for transform-first bundlers such as Vite.
391
+ * This replaces any existing source transforms.
392
+ */
393
+ setSourceTransforms(sourceTransforms: EcoSourceTransform[]): this {
394
+ this.config.sourceTransforms.clear();
395
+ for (const sourceTransform of sourceTransforms) {
396
+ this.addSourceTransform(sourceTransform.name, sourceTransform);
397
+ }
398
+ return this;
399
+ }
400
+
401
+ /**
402
+ * Adds a loader to the application.
403
+ *
404
+ * @param name - The name of the loader
405
+ * @param loader - The build plugin to use as a loader
406
+ * @returns The ConfigBuilder instance for method chaining
407
+ * @throws Error if a loader with the same name already exists
408
+ */
409
+ addLoader(name: string, loader: EcoBuildPlugin): this {
410
+ if (this.config.loaders.has(name)) {
411
+ throw new Error(CONFIG_BUILDER_ERRORS.duplicateLoaderName(name));
412
+ }
413
+ this.config.loaders.set(name, loader);
414
+ return this;
415
+ }
416
+
417
+ /**
418
+ * Adds a source transform to the application.
419
+ *
420
+ * @throws Error if a source transform with the same name already exists.
421
+ */
422
+ addSourceTransform(name: string, sourceTransform: EcoSourceTransform): this {
423
+ if (this.config.sourceTransforms.has(name)) {
424
+ throw new Error(CONFIG_BUILDER_ERRORS.duplicateLoaderName(name));
425
+ }
426
+ this.config.sourceTransforms.set(name, sourceTransform);
427
+ return this;
428
+ }
429
+
430
+ /**
431
+ * Sets the cache configuration for ISR and page caching.
432
+ *
433
+ * @param cacheConfig - The cache configuration object
434
+ * @returns The ConfigBuilder instance for method chaining
435
+ */
436
+ setCacheConfig(cacheConfig: CacheConfig): this {
437
+ this.config.cache = cacheConfig;
438
+ return this;
439
+ }
440
+
441
+ setExperimental(experimental: NonNullable<EcoPagesAppConfig['experimental']>): this {
442
+ this.config.experimental = experimental;
443
+ return this;
444
+ }
445
+
446
+ private createAbsolutePaths(config: EcoPagesAppConfig): this {
447
+ const { srcDir, componentsDir, includesDir, layoutsDir, pagesDir, publicDir, distDir, workDir } = config;
448
+
449
+ const projectDir = config.rootDir;
450
+
451
+ const absoluteSrcDir = path.resolve(projectDir, srcDir);
452
+ const absoluteDistDir = path.resolve(projectDir, distDir);
453
+ const absoluteWorkDir = path.resolve(projectDir, workDir);
454
+
455
+ const absoluteIncludesDir = path.join(absoluteSrcDir, includesDir);
456
+ const absolutePagesDir = path.join(absoluteSrcDir, pagesDir);
457
+
458
+ this.config.absolutePaths = {
459
+ config: path.join(projectDir, 'eco.config.ts'),
460
+ projectDir: projectDir,
461
+ srcDir: absoluteSrcDir,
462
+ distDir: absoluteDistDir,
463
+ workDir: absoluteWorkDir,
464
+ componentsDir: path.join(absoluteSrcDir, componentsDir),
465
+ includesDir: absoluteIncludesDir,
466
+ layoutsDir: path.join(absoluteSrcDir, layoutsDir),
467
+ pagesDir: absolutePagesDir,
468
+ publicDir: path.join(absoluteSrcDir, publicDir),
469
+ htmlTemplatePath: this.resolveSemanticTemplatePath({
470
+ dirPath: absoluteIncludesDir,
471
+ basename: 'html',
472
+ }),
473
+ error404TemplatePath: this.resolveSemanticTemplatePath({
474
+ dirPath: absolutePagesDir,
475
+ basename: '404',
476
+ }),
477
+ };
478
+
479
+ return this;
480
+ }
481
+
482
+ private resolveSemanticTemplatePath({ dirPath, basename }: { dirPath: string; basename: 'html' | '404' }): string {
483
+ const extensions = this.config.templatesExt.length > 0 ? this.config.templatesExt : ['.ghtml.ts'];
484
+ const matches = extensions
485
+ .map((extension) => path.join(dirPath, `${basename}${extension}`))
486
+ .filter((candidate) => fileSystem.exists(candidate));
487
+
488
+ invariant(matches.length <= 1, CONFIG_BUILDER_ERRORS.duplicateSemanticTemplate(basename, matches));
489
+
490
+ if (matches.length === 1) {
491
+ return matches[0]!;
492
+ }
493
+
494
+ return path.join(dirPath, `${basename}${extensions[0]}`);
495
+ }
496
+
497
+ private createIntegrationTemplatesExt(integrations: EcoPagesAppConfig['integrations']) {
498
+ const integrationName = integrations.map((integration) => integration.name);
499
+ const uniqueName = new Set(integrationName);
500
+
501
+ invariant(integrationName.length === uniqueName.size, CONFIG_BUILDER_ERRORS.DUPLICATE_INTEGRATION_NAMES);
502
+
503
+ const hasKitaJs = uniqueName.has('kitajs');
504
+ const hasReact = uniqueName.has('react');
505
+ if (hasKitaJs && hasReact) {
506
+ appLogger.warn(CONFIG_BUILDER_ERRORS.MIXED_JSX_ENGINES);
507
+ }
508
+
509
+ const integrationsExtensions = integrations.flatMap((integration) => integration.extensions);
510
+ const uniqueExtensions = new Set(integrationsExtensions);
511
+
512
+ invariant(
513
+ integrationsExtensions.length === uniqueExtensions.size,
514
+ CONFIG_BUILDER_ERRORS.DUPLICATE_INTEGRATION_EXTENSIONS,
515
+ );
516
+
517
+ this.config.templatesExt = integrationsExtensions;
518
+ }
519
+
520
+ private initializeProcessors(): void {
521
+ for (const processor of this.config.processors.values()) {
522
+ processor.setContext(this.config);
523
+ }
524
+ }
525
+
526
+ private validateRuntimeCapabilities(): void {
527
+ const runtimeEnvironment = this.detectRuntimeEnvironment();
528
+ const contributors: RuntimeCapabilityOwner[] = [
529
+ ...this.config.integrations.map((integration) => ({
530
+ kind: 'integration' as const,
531
+ name: integration.name,
532
+ runtimeCapability: integration.runtimeCapability,
533
+ })),
534
+ ...Array.from(this.config.processors.values(), (processor) => ({
535
+ kind: 'processor' as const,
536
+ name: processor.name,
537
+ runtimeCapability: processor.runtimeCapability,
538
+ })),
539
+ ];
540
+
541
+ for (const contributor of contributors) {
542
+ this.validateRuntimeCapability(contributor, runtimeEnvironment);
543
+ }
544
+ }
545
+
546
+ private validateRuntimeCapability(contributor: RuntimeCapabilityOwner, environment: RuntimeEnvironment): void {
547
+ const declaration = contributor.runtimeCapability;
548
+ if (!declaration) {
549
+ return;
550
+ }
551
+
552
+ for (const tag of declaration.tags) {
553
+ if (environment.supportedTags.has(tag)) {
554
+ continue;
555
+ }
556
+
557
+ throw new Error(
558
+ CONFIG_BUILDER_ERRORS.incompatibleRuntimeCapability(
559
+ contributor.kind,
560
+ contributor.name,
561
+ environment.runtime,
562
+ this.describeUnsupportedRuntimeTag(tag),
563
+ ),
564
+ );
565
+ }
566
+
567
+ if (!declaration.minRuntimeVersion) {
568
+ return;
569
+ }
570
+
571
+ const minVersion = this.parseVersion(declaration.minRuntimeVersion);
572
+ if (!minVersion) {
573
+ throw new Error(
574
+ CONFIG_BUILDER_ERRORS.invalidRuntimeVersion(
575
+ contributor.kind,
576
+ contributor.name,
577
+ declaration.minRuntimeVersion,
578
+ ),
579
+ );
580
+ }
581
+
582
+ const currentVersion = this.parseVersion(environment.version);
583
+ if (!currentVersion) {
584
+ return;
585
+ }
586
+
587
+ if (this.compareVersions(currentVersion, minVersion) >= 0) {
588
+ return;
589
+ }
590
+
591
+ throw new Error(
592
+ CONFIG_BUILDER_ERRORS.unsupportedRuntimeVersion(
593
+ contributor.kind,
594
+ contributor.name,
595
+ environment.runtime,
596
+ environment.version,
597
+ declaration.minRuntimeVersion,
598
+ ),
599
+ );
600
+ }
601
+
602
+ private detectRuntimeEnvironment(): RuntimeEnvironment {
603
+ const bunVersion = this.getBunVersion();
604
+ if (bunVersion) {
605
+ return {
606
+ runtime: 'bun',
607
+ version: bunVersion,
608
+ supportedTags: new Set<RuntimeCapabilityTag>([
609
+ 'bun-only',
610
+ 'node-compatible',
611
+ 'requires-native-bun-api',
612
+ 'requires-node-builtins',
613
+ ]),
614
+ };
615
+ }
616
+
617
+ return {
618
+ runtime: 'node',
619
+ version: process.versions.node,
620
+ supportedTags: new Set<RuntimeCapabilityTag>(['node-compatible', 'requires-node-builtins']),
621
+ };
622
+ }
623
+
624
+ private getBunVersion(): string | undefined {
625
+ const bun = globalThis as typeof globalThis & {
626
+ Bun?: {
627
+ version?: string;
628
+ };
629
+ };
630
+
631
+ return typeof bun.Bun?.version === 'string' ? bun.Bun.version : undefined;
632
+ }
633
+
634
+ private describeUnsupportedRuntimeTag(tag: RuntimeCapabilityTag): string {
635
+ switch (tag) {
636
+ case 'bun-only':
637
+ return 'it is Bun-only';
638
+ case 'requires-native-bun-api':
639
+ return 'it requires the native Bun API';
640
+ case 'requires-node-builtins':
641
+ return 'it requires Node builtins';
642
+ case 'node-compatible':
643
+ return 'it requires a Node-compatible runtime';
644
+ }
645
+ }
646
+
647
+ private parseVersion(version: string): number[] | undefined {
648
+ const normalized = version.trim().replace(/^v/i, '');
649
+ if (!/^\d+(?:\.\d+)*$/.test(normalized)) {
650
+ return undefined;
651
+ }
652
+
653
+ return normalized.split('.').map((segment) => Number(segment));
654
+ }
655
+
656
+ private compareVersions(left: number[], right: number[]): number {
657
+ const maxLength = Math.max(left.length, right.length);
658
+ for (let index = 0; index < maxLength; index += 1) {
659
+ const leftValue = left[index] ?? 0;
660
+ const rightValue = right[index] ?? 0;
661
+
662
+ if (leftValue > rightValue) {
663
+ return 1;
664
+ }
665
+
666
+ if (leftValue < rightValue) {
667
+ return -1;
668
+ }
669
+ }
670
+
671
+ return 0;
672
+ }
673
+
674
+ /**
675
+ * Initializes default loaders that are required for EcoPages to function.
676
+ * This includes the eco-component-meta-plugin which auto-injects __eco metadata into component configs.
677
+ */
678
+ private async initializeDefaultLoaders(): Promise<void> {
679
+ const componentMetaTransform = createEcoComponentMetaTransform({ config: this.config });
680
+ if (!this.config.sourceTransforms.has(componentMetaTransform.name)) {
681
+ this.config.sourceTransforms.set(componentMetaTransform.name, componentMetaTransform);
682
+ }
683
+
684
+ const componentMetaPlugin = createEcoComponentMetaPlugin({ config: this.config });
685
+ if (!this.config.loaders.has(componentMetaPlugin.name)) {
686
+ this.config.loaders.set(componentMetaPlugin.name, componentMetaPlugin);
687
+ }
688
+ }
689
+
690
+ private reviewBaseUrl(baseUrl: string): void {
691
+ if (baseUrl) {
692
+ this.config.baseUrl = baseUrl;
693
+ return;
694
+ }
695
+
696
+ const envBaseUrl = process.env.ECOPAGES_BASE_URL;
697
+
698
+ if (envBaseUrl) {
699
+ this.config.baseUrl = envBaseUrl;
700
+ } else if (!this.config.baseUrl) {
701
+ this.config.baseUrl = `http://${DEFAULT_ECOPAGES_HOSTNAME}:${DEFAULT_ECOPAGES_PORT}`;
702
+ }
703
+ }
704
+
705
+ /**
706
+ * Builds and returns the final configuration object.
707
+ * This performs validation and initialization of the configuration.
708
+ *
709
+ * @returns A promise that resolves to the final EcoPagesAppConfig
710
+ * @throws Error if required configuration is missing (e.g., baseUrl)
711
+ */
712
+ async build(): Promise<EcoPagesAppConfig> {
713
+ this.reviewBaseUrl(this.config.baseUrl);
714
+
715
+ if (!this.config.integrations.some((integration) => integration.name === GHTML_PLUGIN_NAME)) {
716
+ this.config.integrations.push(ghtmlPlugin());
717
+ }
718
+
719
+ this.createIntegrationTemplatesExt(this.config.integrations);
720
+ this.createAbsolutePaths(this.config);
721
+
722
+ await this.initializeDefaultLoaders();
723
+ this.initializeProcessors();
724
+ this.validateRuntimeCapabilities();
725
+ const buildAdapter = createBuildAdapter({ ownership: this.buildOwnership });
726
+ setAppBuildAdapter(this.config, buildAdapter);
727
+ updateAppBuildManifest(this.config, await collectConfiguredAppBuildManifestContributions(this.config));
728
+ setAppServerInvalidationState(this.config, new CounterServerInvalidationState());
729
+ setAppEntrypointDependencyGraph(this.config, new NoopEntrypointDependencyGraph());
730
+ setAppRuntimeSpecifierRegistry(this.config, new InMemoryRuntimeSpecifierRegistry());
731
+ setAppBuildExecutor(
732
+ this.config,
733
+ createAppBuildExecutor({
734
+ development: false,
735
+ adapter: buildAdapter,
736
+ getPlugins: () => getAppServerBuildPlugins(this.config),
737
+ }),
738
+ );
739
+
740
+ return this.config;
741
+ }
742
+ }