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

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