@ecopages/core 0.2.0-alpha.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (342) hide show
  1. package/CHANGELOG.md +89 -0
  2. package/LICENSE +21 -0
  3. package/README.md +32 -0
  4. package/package.json +279 -0
  5. package/src/adapters/abstract/application-adapter.d.ts +168 -0
  6. package/src/adapters/abstract/application-adapter.js +109 -0
  7. package/src/adapters/abstract/application-adapter.ts +337 -0
  8. package/src/adapters/abstract/router-adapter.d.ts +26 -0
  9. package/src/adapters/abstract/router-adapter.js +5 -0
  10. package/src/adapters/abstract/router-adapter.ts +30 -0
  11. package/src/adapters/abstract/server-adapter.d.ts +69 -0
  12. package/src/adapters/abstract/server-adapter.js +15 -0
  13. package/src/adapters/abstract/server-adapter.ts +79 -0
  14. package/src/adapters/bun/client-bridge.d.ts +34 -0
  15. package/src/adapters/bun/client-bridge.js +48 -0
  16. package/src/adapters/bun/client-bridge.ts +62 -0
  17. package/src/adapters/bun/create-app.d.ts +60 -0
  18. package/src/adapters/bun/create-app.js +117 -0
  19. package/src/adapters/bun/create-app.ts +189 -0
  20. package/src/adapters/bun/define-api-handler.d.ts +61 -0
  21. package/src/adapters/bun/define-api-handler.js +15 -0
  22. package/src/adapters/bun/define-api-handler.ts +114 -0
  23. package/src/adapters/bun/hmr-manager.d.ts +84 -0
  24. package/src/adapters/bun/hmr-manager.js +227 -0
  25. package/src/adapters/bun/hmr-manager.ts +281 -0
  26. package/src/adapters/bun/index.d.ts +3 -0
  27. package/src/adapters/bun/index.js +8 -0
  28. package/src/adapters/bun/index.ts +3 -0
  29. package/src/adapters/bun/server-adapter.d.ts +155 -0
  30. package/src/adapters/bun/server-adapter.js +368 -0
  31. package/src/adapters/bun/server-adapter.ts +492 -0
  32. package/src/adapters/bun/server-lifecycle.d.ts +52 -0
  33. package/src/adapters/bun/server-lifecycle.js +120 -0
  34. package/src/adapters/bun/server-lifecycle.ts +154 -0
  35. package/src/adapters/index.d.ts +6 -0
  36. package/src/adapters/index.js +14 -0
  37. package/src/adapters/index.ts +6 -0
  38. package/src/adapters/node/create-app.d.ts +21 -0
  39. package/src/adapters/node/create-app.js +143 -0
  40. package/src/adapters/node/create-app.ts +179 -0
  41. package/src/adapters/node/index.d.ts +4 -0
  42. package/src/adapters/node/index.js +8 -0
  43. package/src/adapters/node/index.ts +9 -0
  44. package/src/adapters/node/node-client-bridge.d.ts +26 -0
  45. package/src/adapters/node/node-client-bridge.js +66 -0
  46. package/src/adapters/node/node-client-bridge.ts +79 -0
  47. package/src/adapters/node/node-hmr-manager.d.ts +62 -0
  48. package/src/adapters/node/node-hmr-manager.js +221 -0
  49. package/src/adapters/node/node-hmr-manager.ts +271 -0
  50. package/src/adapters/node/server-adapter.d.ts +190 -0
  51. package/src/adapters/node/server-adapter.js +420 -0
  52. package/src/adapters/node/server-adapter.ts +561 -0
  53. package/src/adapters/node/static-content-server.d.ts +24 -0
  54. package/src/adapters/node/static-content-server.js +166 -0
  55. package/src/adapters/node/static-content-server.ts +203 -0
  56. package/src/adapters/shared/api-response.d.ts +52 -0
  57. package/src/adapters/shared/api-response.js +96 -0
  58. package/src/adapters/shared/api-response.ts +104 -0
  59. package/src/adapters/shared/application-adapter.d.ts +18 -0
  60. package/src/adapters/shared/application-adapter.js +90 -0
  61. package/src/adapters/shared/application-adapter.ts +199 -0
  62. package/src/adapters/shared/explicit-static-route-matcher.d.ts +38 -0
  63. package/src/adapters/shared/explicit-static-route-matcher.js +100 -0
  64. package/src/adapters/shared/explicit-static-route-matcher.ts +134 -0
  65. package/src/adapters/shared/file-route-middleware-pipeline.d.ts +65 -0
  66. package/src/adapters/shared/file-route-middleware-pipeline.js +98 -0
  67. package/src/adapters/shared/file-route-middleware-pipeline.ts +123 -0
  68. package/src/adapters/shared/fs-server-response-factory.d.ts +19 -0
  69. package/src/adapters/shared/fs-server-response-factory.js +97 -0
  70. package/src/adapters/shared/fs-server-response-factory.ts +118 -0
  71. package/src/adapters/shared/fs-server-response-matcher.d.ts +71 -0
  72. package/src/adapters/shared/fs-server-response-matcher.js +155 -0
  73. package/src/adapters/shared/fs-server-response-matcher.ts +198 -0
  74. package/src/adapters/shared/render-context.d.ts +14 -0
  75. package/src/adapters/shared/render-context.js +69 -0
  76. package/src/adapters/shared/render-context.ts +105 -0
  77. package/src/adapters/shared/server-adapter.d.ts +87 -0
  78. package/src/adapters/shared/server-adapter.js +353 -0
  79. package/src/adapters/shared/server-adapter.ts +442 -0
  80. package/src/adapters/shared/server-route-handler.d.ts +89 -0
  81. package/src/adapters/shared/server-route-handler.js +120 -0
  82. package/src/adapters/shared/server-route-handler.ts +166 -0
  83. package/src/adapters/shared/server-static-builder.d.ts +38 -0
  84. package/src/adapters/shared/server-static-builder.js +46 -0
  85. package/src/adapters/shared/server-static-builder.ts +82 -0
  86. package/src/build/build-adapter.d.ts +74 -0
  87. package/src/build/build-adapter.js +54 -0
  88. package/src/build/build-adapter.ts +132 -0
  89. package/src/build/build-types.d.ts +57 -0
  90. package/src/build/build-types.js +0 -0
  91. package/src/build/build-types.ts +83 -0
  92. package/src/build/esbuild-build-adapter.d.ts +69 -0
  93. package/src/build/esbuild-build-adapter.js +390 -0
  94. package/src/build/esbuild-build-adapter.ts +510 -0
  95. package/src/config/config-builder.d.ts +227 -0
  96. package/src/config/config-builder.js +392 -0
  97. package/src/config/config-builder.ts +474 -0
  98. package/src/constants.d.ts +32 -0
  99. package/src/constants.js +21 -0
  100. package/src/constants.ts +39 -0
  101. package/src/create-app.d.ts +17 -0
  102. package/src/create-app.js +66 -0
  103. package/src/create-app.ts +87 -0
  104. package/src/declarations.d.ts +26 -0
  105. package/src/define-api-handler.d.ts +25 -0
  106. package/src/define-api-handler.js +15 -0
  107. package/src/define-api-handler.ts +66 -0
  108. package/src/dev/sc-server.d.ts +30 -0
  109. package/src/dev/sc-server.js +111 -0
  110. package/src/dev/sc-server.ts +143 -0
  111. package/src/eco/README.md +636 -0
  112. package/src/eco/component-render-context.d.ts +105 -0
  113. package/src/eco/component-render-context.js +77 -0
  114. package/src/eco/component-render-context.ts +202 -0
  115. package/src/eco/eco.d.ts +9 -0
  116. package/src/eco/eco.js +110 -0
  117. package/src/eco/eco.ts +221 -0
  118. package/src/eco/eco.types.d.ts +170 -0
  119. package/src/eco/eco.types.js +0 -0
  120. package/src/eco/eco.types.ts +202 -0
  121. package/src/eco/eco.utils.d.ts +40 -0
  122. package/src/eco/eco.utils.js +40 -0
  123. package/src/eco/eco.utils.ts +89 -0
  124. package/src/eco/global-injector-map.d.ts +16 -0
  125. package/src/eco/global-injector-map.js +80 -0
  126. package/src/eco/global-injector-map.ts +112 -0
  127. package/src/eco/lazy-injector-map.d.ts +8 -0
  128. package/src/eco/lazy-injector-map.js +70 -0
  129. package/src/eco/lazy-injector-map.ts +120 -0
  130. package/src/eco/module-dependencies.d.ts +18 -0
  131. package/src/eco/module-dependencies.js +49 -0
  132. package/src/eco/module-dependencies.ts +75 -0
  133. package/src/env.d.ts +20 -0
  134. package/src/errors/http-error.d.ts +31 -0
  135. package/src/errors/http-error.js +50 -0
  136. package/src/errors/http-error.ts +72 -0
  137. package/src/errors/index.d.ts +2 -0
  138. package/src/errors/index.js +4 -0
  139. package/src/errors/index.ts +2 -0
  140. package/src/errors/locals-access-error.d.ts +4 -0
  141. package/src/errors/locals-access-error.js +9 -0
  142. package/src/errors/locals-access-error.ts +7 -0
  143. package/src/global/app-logger.d.ts +2 -0
  144. package/src/global/app-logger.js +6 -0
  145. package/src/global/app-logger.ts +4 -0
  146. 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
  147. package/src/hmr/client/__screenshots__/hmr-runtime.test.browser.ts/HMR-Runtime-HMR-Server-Integration-should-load-fixture-app-page-1.png +0 -0
  148. package/src/hmr/client/__screenshots__/hmr-runtime.test.browser.ts/HMR-Runtime-WebSocket-Connection-should-connect-to-correct-HMR-endpoint-1.png +0 -0
  149. package/src/hmr/client/hmr-runtime.d.ts +10 -0
  150. package/src/hmr/client/hmr-runtime.js +86 -0
  151. package/src/hmr/client/hmr-runtime.ts +121 -0
  152. package/src/hmr/hmr-strategy.d.ts +159 -0
  153. package/src/hmr/hmr-strategy.js +29 -0
  154. package/src/hmr/hmr-strategy.ts +172 -0
  155. package/src/hmr/hmr.test.e2e.d.ts +1 -0
  156. package/src/hmr/hmr.test.e2e.js +50 -0
  157. package/src/hmr/hmr.test.e2e.ts +75 -0
  158. package/src/hmr/strategies/default-hmr-strategy.d.ts +43 -0
  159. package/src/hmr/strategies/default-hmr-strategy.js +34 -0
  160. package/src/hmr/strategies/default-hmr-strategy.ts +60 -0
  161. package/src/hmr/strategies/js-hmr-strategy.d.ts +136 -0
  162. package/src/hmr/strategies/js-hmr-strategy.js +179 -0
  163. package/src/hmr/strategies/js-hmr-strategy.ts +308 -0
  164. package/src/index.browser.d.ts +3 -0
  165. package/src/index.browser.js +4 -0
  166. package/src/index.browser.ts +3 -0
  167. package/src/index.d.ts +5 -0
  168. package/src/index.js +10 -0
  169. package/src/index.ts +5 -0
  170. package/src/integrations/ghtml/ghtml-renderer.d.ts +15 -0
  171. package/src/integrations/ghtml/ghtml-renderer.js +60 -0
  172. package/src/integrations/ghtml/ghtml-renderer.ts +93 -0
  173. package/src/integrations/ghtml/ghtml.plugin.d.ts +20 -0
  174. package/src/integrations/ghtml/ghtml.plugin.js +21 -0
  175. package/src/integrations/ghtml/ghtml.plugin.ts +32 -0
  176. package/src/internal-types.d.ts +200 -0
  177. package/src/internal-types.js +0 -0
  178. package/src/internal-types.ts +212 -0
  179. package/src/plugins/alias-resolver-plugin.d.ts +2 -0
  180. package/src/plugins/alias-resolver-plugin.js +39 -0
  181. package/src/plugins/alias-resolver-plugin.ts +45 -0
  182. package/src/plugins/eco-component-meta-plugin.d.ts +95 -0
  183. package/src/plugins/eco-component-meta-plugin.js +157 -0
  184. package/src/plugins/eco-component-meta-plugin.ts +474 -0
  185. package/src/plugins/integration-plugin.d.ts +102 -0
  186. package/src/plugins/integration-plugin.js +100 -0
  187. package/src/plugins/integration-plugin.ts +184 -0
  188. package/src/plugins/processor.d.ts +82 -0
  189. package/src/plugins/processor.js +122 -0
  190. package/src/plugins/processor.ts +220 -0
  191. package/src/public-types.d.ts +1094 -0
  192. package/src/public-types.js +0 -0
  193. package/src/public-types.ts +1255 -0
  194. package/src/route-renderer/GRAPH.md +387 -0
  195. package/src/route-renderer/README.md +135 -0
  196. package/src/route-renderer/component-graph-executor.d.ts +32 -0
  197. package/src/route-renderer/component-graph-executor.js +31 -0
  198. package/src/route-renderer/component-graph-executor.ts +84 -0
  199. package/src/route-renderer/component-graph.d.ts +42 -0
  200. package/src/route-renderer/component-graph.js +72 -0
  201. package/src/route-renderer/component-graph.ts +159 -0
  202. package/src/route-renderer/component-marker.d.ts +52 -0
  203. package/src/route-renderer/component-marker.js +46 -0
  204. package/src/route-renderer/component-marker.ts +117 -0
  205. package/src/route-renderer/dependency-resolver.d.ts +24 -0
  206. package/src/route-renderer/dependency-resolver.js +428 -0
  207. package/src/route-renderer/dependency-resolver.ts +596 -0
  208. package/src/route-renderer/html-post-processing.service.d.ts +40 -0
  209. package/src/route-renderer/html-post-processing.service.js +86 -0
  210. package/src/route-renderer/html-post-processing.service.ts +103 -0
  211. package/src/route-renderer/integration-renderer.d.ts +339 -0
  212. package/src/route-renderer/integration-renderer.js +526 -0
  213. package/src/route-renderer/integration-renderer.ts +696 -0
  214. package/src/route-renderer/marker-graph-resolver.d.ts +76 -0
  215. package/src/route-renderer/marker-graph-resolver.js +93 -0
  216. package/src/route-renderer/marker-graph-resolver.ts +153 -0
  217. package/src/route-renderer/page-module-loader.d.ts +61 -0
  218. package/src/route-renderer/page-module-loader.js +102 -0
  219. package/src/route-renderer/page-module-loader.ts +153 -0
  220. package/src/route-renderer/render-execution.service.d.ts +69 -0
  221. package/src/route-renderer/render-execution.service.js +91 -0
  222. package/src/route-renderer/render-execution.service.ts +158 -0
  223. package/src/route-renderer/render-preparation.service.d.ts +112 -0
  224. package/src/route-renderer/render-preparation.service.js +243 -0
  225. package/src/route-renderer/render-preparation.service.ts +358 -0
  226. package/src/route-renderer/route-renderer.d.ts +26 -0
  227. package/src/route-renderer/route-renderer.js +68 -0
  228. package/src/route-renderer/route-renderer.ts +80 -0
  229. package/src/router/fs-router-scanner.d.ts +41 -0
  230. package/src/router/fs-router-scanner.js +155 -0
  231. package/src/router/fs-router-scanner.ts +217 -0
  232. package/src/router/fs-router.d.ts +26 -0
  233. package/src/router/fs-router.js +100 -0
  234. package/src/router/fs-router.ts +122 -0
  235. package/src/services/asset-processing-service/asset-processing.service.d.ts +41 -0
  236. package/src/services/asset-processing-service/asset-processing.service.js +250 -0
  237. package/src/services/asset-processing-service/asset-processing.service.ts +306 -0
  238. package/src/services/asset-processing-service/asset.factory.d.ts +17 -0
  239. package/src/services/asset-processing-service/asset.factory.js +82 -0
  240. package/src/services/asset-processing-service/asset.factory.ts +105 -0
  241. package/src/services/asset-processing-service/assets.types.d.ts +88 -0
  242. package/src/services/asset-processing-service/assets.types.js +0 -0
  243. package/src/services/asset-processing-service/assets.types.ts +112 -0
  244. package/src/services/asset-processing-service/index.d.ts +3 -0
  245. package/src/services/asset-processing-service/index.js +3 -0
  246. package/src/services/asset-processing-service/index.ts +3 -0
  247. package/src/services/asset-processing-service/processor.interface.d.ts +22 -0
  248. package/src/services/asset-processing-service/processor.interface.js +6 -0
  249. package/src/services/asset-processing-service/processor.interface.ts +27 -0
  250. package/src/services/asset-processing-service/processor.registry.d.ts +8 -0
  251. package/src/services/asset-processing-service/processor.registry.js +15 -0
  252. package/src/services/asset-processing-service/processor.registry.ts +18 -0
  253. package/src/services/asset-processing-service/processors/base/base-processor.d.ts +24 -0
  254. package/src/services/asset-processing-service/processors/base/base-processor.js +59 -0
  255. package/src/services/asset-processing-service/processors/base/base-processor.ts +76 -0
  256. package/src/services/asset-processing-service/processors/base/base-script-processor.d.ts +16 -0
  257. package/src/services/asset-processing-service/processors/base/base-script-processor.js +80 -0
  258. package/src/services/asset-processing-service/processors/base/base-script-processor.ts +105 -0
  259. package/src/services/asset-processing-service/processors/index.d.ts +5 -0
  260. package/src/services/asset-processing-service/processors/index.js +5 -0
  261. package/src/services/asset-processing-service/processors/index.ts +5 -0
  262. package/src/services/asset-processing-service/processors/script/content-script.processor.d.ts +5 -0
  263. package/src/services/asset-processing-service/processors/script/content-script.processor.js +57 -0
  264. package/src/services/asset-processing-service/processors/script/content-script.processor.ts +66 -0
  265. package/src/services/asset-processing-service/processors/script/file-script.processor.d.ts +8 -0
  266. package/src/services/asset-processing-service/processors/script/file-script.processor.js +76 -0
  267. package/src/services/asset-processing-service/processors/script/file-script.processor.ts +88 -0
  268. package/src/services/asset-processing-service/processors/script/node-module-script.processor.d.ts +7 -0
  269. package/src/services/asset-processing-service/processors/script/node-module-script.processor.js +74 -0
  270. package/src/services/asset-processing-service/processors/script/node-module-script.processor.ts +84 -0
  271. package/src/services/asset-processing-service/processors/stylesheet/content-stylesheet.processor.d.ts +5 -0
  272. package/src/services/asset-processing-service/processors/stylesheet/content-stylesheet.processor.js +25 -0
  273. package/src/services/asset-processing-service/processors/stylesheet/content-stylesheet.processor.ts +27 -0
  274. package/src/services/asset-processing-service/processors/stylesheet/file-stylesheet.processor.d.ts +9 -0
  275. package/src/services/asset-processing-service/processors/stylesheet/file-stylesheet.processor.js +63 -0
  276. package/src/services/asset-processing-service/processors/stylesheet/file-stylesheet.processor.ts +77 -0
  277. package/src/services/cache/cache.types.d.ts +107 -0
  278. package/src/services/cache/cache.types.js +0 -0
  279. package/src/services/cache/cache.types.ts +126 -0
  280. package/src/services/cache/index.d.ts +7 -0
  281. package/src/services/cache/index.js +7 -0
  282. package/src/services/cache/index.ts +18 -0
  283. package/src/services/cache/memory-cache-store.d.ts +42 -0
  284. package/src/services/cache/memory-cache-store.js +98 -0
  285. package/src/services/cache/memory-cache-store.ts +130 -0
  286. package/src/services/cache/page-cache-service.d.ts +70 -0
  287. package/src/services/cache/page-cache-service.js +152 -0
  288. package/src/services/cache/page-cache-service.ts +202 -0
  289. package/src/services/html-transformer.service.d.ts +50 -0
  290. package/src/services/html-transformer.service.js +163 -0
  291. package/src/services/html-transformer.service.ts +217 -0
  292. package/src/services/page-module-import.service.d.ts +37 -0
  293. package/src/services/page-module-import.service.js +88 -0
  294. package/src/services/page-module-import.service.ts +129 -0
  295. package/src/services/page-request-cache-coordinator.service.d.ts +75 -0
  296. package/src/services/page-request-cache-coordinator.service.js +107 -0
  297. package/src/services/page-request-cache-coordinator.service.ts +128 -0
  298. package/src/services/schema-validation-service.d.ts +122 -0
  299. package/src/services/schema-validation-service.js +101 -0
  300. package/src/services/schema-validation-service.ts +204 -0
  301. package/src/services/validation/standard-schema.types.d.ts +65 -0
  302. package/src/services/validation/standard-schema.types.js +0 -0
  303. package/src/services/validation/standard-schema.types.ts +68 -0
  304. package/src/static-site-generator/static-site-generator.d.ts +57 -0
  305. package/src/static-site-generator/static-site-generator.js +272 -0
  306. package/src/static-site-generator/static-site-generator.ts +359 -0
  307. package/src/utils/css.d.ts +1 -0
  308. package/src/utils/css.js +7 -0
  309. package/src/utils/css.ts +5 -0
  310. package/src/utils/deep-merge.d.ts +14 -0
  311. package/src/utils/deep-merge.js +32 -0
  312. package/src/utils/deep-merge.ts +47 -0
  313. package/src/utils/hash.d.ts +1 -0
  314. package/src/utils/hash.js +7 -0
  315. package/src/utils/hash.ts +5 -0
  316. package/src/utils/html.d.ts +1 -0
  317. package/src/utils/html.js +4 -0
  318. package/src/utils/html.ts +1 -0
  319. package/src/utils/invariant.d.ts +5 -0
  320. package/src/utils/invariant.js +11 -0
  321. package/src/utils/invariant.ts +15 -0
  322. package/src/utils/locals-utils.d.ts +15 -0
  323. package/src/utils/locals-utils.js +24 -0
  324. package/src/utils/locals-utils.ts +37 -0
  325. package/src/utils/parse-cli-args.d.ts +24 -0
  326. package/src/utils/parse-cli-args.js +47 -0
  327. package/src/utils/parse-cli-args.ts +83 -0
  328. package/src/utils/path-utils.module.d.ts +5 -0
  329. package/src/utils/path-utils.module.js +14 -0
  330. package/src/utils/path-utils.module.ts +14 -0
  331. package/src/utils/runtime.d.ts +11 -0
  332. package/src/utils/runtime.js +40 -0
  333. package/src/utils/runtime.ts +44 -0
  334. package/src/utils/server-utils.module.d.ts +19 -0
  335. package/src/utils/server-utils.module.js +56 -0
  336. package/src/utils/server-utils.module.ts +67 -0
  337. package/src/watchers/project-watcher.d.ts +120 -0
  338. package/src/watchers/project-watcher.js +238 -0
  339. package/src/watchers/project-watcher.test-helpers.d.ts +4 -0
  340. package/src/watchers/project-watcher.test-helpers.js +51 -0
  341. package/src/watchers/project-watcher.test-helpers.ts +40 -0
  342. package/src/watchers/project-watcher.ts +306 -0
@@ -0,0 +1,34 @@
1
+ import type { ServerWebSocket } from 'bun';
2
+ import type { ClientBridgeEvent, IClientBridge } from '../../public-types';
3
+ type BunSocket = ServerWebSocket<unknown>;
4
+ /**
5
+ * Manages WebSocket subscribers and broadcasts development events.
6
+ * Bridges the gap between the server and the development client.
7
+ */
8
+ export declare class ClientBridge implements IClientBridge {
9
+ private subscribers;
10
+ subscribe(ws: BunSocket): void;
11
+ unsubscribe(ws: BunSocket): void;
12
+ /**
13
+ * Broadcast a raw event to all connected clients.
14
+ */
15
+ broadcast(event: ClientBridgeEvent): void;
16
+ /**
17
+ * Trigger a full page reload on all connected clients.
18
+ */
19
+ reload(): void;
20
+ /**
21
+ * Broadcast a CSS update for hot stylesheet reload.
22
+ */
23
+ cssUpdate(path: string): void;
24
+ /**
25
+ * Broadcast a JS module update for hot module replacement.
26
+ */
27
+ update(path: string): void;
28
+ /**
29
+ * Broadcast an error message to connected clients.
30
+ */
31
+ error(message: string): void;
32
+ get subscriberCount(): number;
33
+ }
34
+ export {};
@@ -0,0 +1,48 @@
1
+ class ClientBridge {
2
+ subscribers = /* @__PURE__ */ new Set();
3
+ subscribe(ws) {
4
+ this.subscribers.add(ws);
5
+ }
6
+ unsubscribe(ws) {
7
+ this.subscribers.delete(ws);
8
+ }
9
+ /**
10
+ * Broadcast a raw event to all connected clients.
11
+ */
12
+ broadcast(event) {
13
+ const payload = JSON.stringify(event);
14
+ for (const ws of this.subscribers) {
15
+ ws.send(payload);
16
+ }
17
+ }
18
+ /**
19
+ * Trigger a full page reload on all connected clients.
20
+ */
21
+ reload() {
22
+ this.broadcast({ type: "reload" });
23
+ }
24
+ /**
25
+ * Broadcast a CSS update for hot stylesheet reload.
26
+ */
27
+ cssUpdate(path) {
28
+ this.broadcast({ type: "css-update", path, timestamp: Date.now() });
29
+ }
30
+ /**
31
+ * Broadcast a JS module update for hot module replacement.
32
+ */
33
+ update(path) {
34
+ this.broadcast({ type: "update", path, timestamp: Date.now() });
35
+ }
36
+ /**
37
+ * Broadcast an error message to connected clients.
38
+ */
39
+ error(message) {
40
+ this.broadcast({ type: "error", message });
41
+ }
42
+ get subscriberCount() {
43
+ return this.subscribers.size;
44
+ }
45
+ }
46
+ export {
47
+ ClientBridge
48
+ };
@@ -0,0 +1,62 @@
1
+ import type { ServerWebSocket } from 'bun';
2
+ import type { ClientBridgeEvent, IClientBridge } from '../../public-types';
3
+
4
+ type BunSocket = ServerWebSocket<unknown>;
5
+
6
+ /**
7
+ * Manages WebSocket subscribers and broadcasts development events.
8
+ * Bridges the gap between the server and the development client.
9
+ */
10
+ export class ClientBridge implements IClientBridge {
11
+ private subscribers = new Set<BunSocket>();
12
+
13
+ subscribe(ws: BunSocket): void {
14
+ this.subscribers.add(ws);
15
+ }
16
+
17
+ unsubscribe(ws: BunSocket): void {
18
+ this.subscribers.delete(ws);
19
+ }
20
+
21
+ /**
22
+ * Broadcast a raw event to all connected clients.
23
+ */
24
+ broadcast(event: ClientBridgeEvent): void {
25
+ const payload = JSON.stringify(event);
26
+ for (const ws of this.subscribers) {
27
+ ws.send(payload);
28
+ }
29
+ }
30
+
31
+ /**
32
+ * Trigger a full page reload on all connected clients.
33
+ */
34
+ reload(): void {
35
+ this.broadcast({ type: 'reload' });
36
+ }
37
+
38
+ /**
39
+ * Broadcast a CSS update for hot stylesheet reload.
40
+ */
41
+ cssUpdate(path: string): void {
42
+ this.broadcast({ type: 'css-update', path, timestamp: Date.now() });
43
+ }
44
+
45
+ /**
46
+ * Broadcast a JS module update for hot module replacement.
47
+ */
48
+ update(path: string): void {
49
+ this.broadcast({ type: 'update', path, timestamp: Date.now() });
50
+ }
51
+
52
+ /**
53
+ * Broadcast an error message to connected clients.
54
+ */
55
+ error(message: string): void {
56
+ this.broadcast({ type: 'error', message });
57
+ }
58
+
59
+ get subscriberCount(): number {
60
+ return this.subscribers.size;
61
+ }
62
+ }
@@ -0,0 +1,60 @@
1
+ /**
2
+ * This file contains the implementation of the Bun application adapter for EcoPages.
3
+ * It extends the AbstractApplicationAdapter class and provides methods for handling
4
+ * HTTP requests, initializing the server adapter, and starting the Bun application server.
5
+ * The adapter is designed to work with the Bun runtime and provides a way to create
6
+ * EcoPages applications using Bun's features.
7
+ *
8
+ * @module EcopagesApp
9
+ */
10
+ import type { Server } from 'bun';
11
+ import type { EcoPagesAppConfig } from '../../internal-types.js';
12
+ import type { ApiHandlerContext, RouteGroupBuilder } from '../../public-types.js';
13
+ import { type ApplicationAdapterOptions } from '../abstract/application-adapter.js';
14
+ import { SharedApplicationAdapter } from '../shared/application-adapter.js';
15
+ import { type BunServerAdapterResult } from './server-adapter.js';
16
+ /**
17
+ * Configuration options for the Bun application adapter
18
+ */
19
+ export interface EcopagesAppOptions extends ApplicationAdapterOptions {
20
+ appConfig: EcoPagesAppConfig;
21
+ serverOptions?: Record<string, any>;
22
+ }
23
+ /**
24
+ * Bun-specific route group builder that properly infers route params from path patterns.
25
+ * When you define a route like `/posts/:slug`, the handler context will have
26
+ * `ctx.params.slug` typed as `string`.
27
+ *
28
+ * @typeParam WebSocketData - WebSocket data type for the server
29
+ * @typeParam TContext - Extended context type from middleware (e.g., `{ user: User }`)
30
+ */
31
+ export type BunRouteGroupBuilder<WebSocketData = undefined, TContext extends ApiHandlerContext<Request, Server<WebSocketData>> = ApiHandlerContext<Request, Server<WebSocketData>>> = RouteGroupBuilder<Request, Server<WebSocketData>, TContext>;
32
+ /**
33
+ * Bun-specific application adapter implementation
34
+ * This class extends the {@link AbstractApplicationAdapter}
35
+ * and provides methods for handling HTTP requests and managing the server.
36
+ */
37
+ export declare class EcopagesApp<WebSocketData = undefined> extends SharedApplicationAdapter<EcopagesAppOptions, Server<WebSocketData>, Request> {
38
+ serverAdapter: BunServerAdapterResult | undefined;
39
+ private server;
40
+ fetch(request: Request): Promise<Response>;
41
+ /**
42
+ * Complete the initialization of the server adapter by processing dynamic routes
43
+ * @param server The Bun server instance
44
+ */
45
+ completeInitialization(server: Server<WebSocketData>): Promise<void>;
46
+ /**
47
+ * Initialize the Bun server adapter
48
+ */
49
+ protected initializeServerAdapter(): Promise<BunServerAdapterResult>;
50
+ /**
51
+ * Start the Bun application server
52
+ * @param options Optional settings
53
+ * @param options.autoCompleteInitialization Whether to automatically complete initialization with dynamic routes after server start (defaults to true)
54
+ */
55
+ start(): Promise<Server<WebSocketData> | void>;
56
+ }
57
+ /**
58
+ * Factory function to create a Bun application
59
+ */
60
+ export declare function createApp<WebSocketData = undefined>(options: EcopagesAppOptions): Promise<EcopagesApp<WebSocketData>>;
@@ -0,0 +1,117 @@
1
+ import { DEFAULT_ECOPAGES_HOSTNAME, DEFAULT_ECOPAGES_PORT } from "../../constants.js";
2
+ import { appLogger } from "../../global/app-logger.js";
3
+ import { getBunRuntime } from "../../utils/runtime.js";
4
+ import {} from "../abstract/application-adapter.js";
5
+ import { SharedApplicationAdapter } from "../shared/application-adapter.js";
6
+ import { createBunServerAdapter } from "./server-adapter.js";
7
+ class EcopagesApp extends SharedApplicationAdapter {
8
+ serverAdapter;
9
+ server = null;
10
+ async fetch(request) {
11
+ if (!this.serverAdapter) {
12
+ this.serverAdapter = await this.initializeServerAdapter();
13
+ }
14
+ await this.serverAdapter.completeInitialization(this.server);
15
+ return this.serverAdapter.handleRequest(request);
16
+ }
17
+ /**
18
+ * Complete the initialization of the server adapter by processing dynamic routes
19
+ * @param server The Bun server instance
20
+ */
21
+ async completeInitialization(server) {
22
+ if (!this.serverAdapter) {
23
+ throw new Error("Server adapter not initialized. Call start() first.");
24
+ }
25
+ await this.serverAdapter.completeInitialization(server);
26
+ }
27
+ /**
28
+ * Initialize the Bun server adapter
29
+ */
30
+ async initializeServerAdapter() {
31
+ const { dev } = this.cliArgs;
32
+ const { port: cliPort, hostname: cliHostname } = this.cliArgs;
33
+ const envPort = process.env.ECOPAGES_PORT ? process.env.ECOPAGES_PORT : void 0;
34
+ const envHostname = process.env.ECOPAGES_HOSTNAME;
35
+ const preferredPort = cliPort ?? envPort ?? DEFAULT_ECOPAGES_PORT;
36
+ const preferredHostname = cliHostname ?? envHostname ?? DEFAULT_ECOPAGES_HOSTNAME;
37
+ appLogger.debug("initializeServerAdapter", {
38
+ dev,
39
+ cliPort,
40
+ cliHostname,
41
+ envPort,
42
+ envHostname,
43
+ preferredPort,
44
+ preferredHostname,
45
+ composedUrl: `http://${preferredHostname}:${preferredPort}`
46
+ });
47
+ return await createBunServerAdapter({
48
+ runtimeOrigin: `http://${preferredHostname}:${preferredPort}`,
49
+ appConfig: this.appConfig,
50
+ apiHandlers: this.apiHandlers,
51
+ staticRoutes: this.staticRoutes,
52
+ errorHandler: this.errorHandler,
53
+ options: { watch: dev },
54
+ serveOptions: {
55
+ port: preferredPort,
56
+ hostname: preferredHostname,
57
+ ...this.serverOptions
58
+ }
59
+ });
60
+ }
61
+ /**
62
+ * Start the Bun application server
63
+ * @param options Optional settings
64
+ * @param options.autoCompleteInitialization Whether to automatically complete initialization with dynamic routes after server start (defaults to true)
65
+ */
66
+ async start() {
67
+ if (!this.serverAdapter) {
68
+ this.serverAdapter = await this.initializeServerAdapter();
69
+ }
70
+ const { dev, preview, build } = this.cliArgs;
71
+ const requiresFetchRuntime = this.appConfig.integrations.some(
72
+ (integration) => integration.staticBuildStep === "fetch"
73
+ );
74
+ const canBuildWithoutRuntimeServer = (build || preview) && !requiresFetchRuntime;
75
+ if (canBuildWithoutRuntimeServer) {
76
+ appLogger.debugTime("Building static pages");
77
+ await this.serverAdapter.buildStatic({ preview });
78
+ appLogger.debugTimeEnd("Building static pages");
79
+ if (build) {
80
+ process.exit(0);
81
+ }
82
+ return;
83
+ }
84
+ const enableHmr = dev || !preview && !build;
85
+ const serverOptions = this.serverAdapter.getServerOptions({ enableHmr });
86
+ const bun = getBunRuntime();
87
+ if (!bun) {
88
+ throw new Error("Bun runtime is required for the Bun adapter");
89
+ }
90
+ const bunServer = bun.serve(serverOptions);
91
+ this.server = bunServer;
92
+ await this.serverAdapter.completeInitialization(this.server).catch((error) => {
93
+ appLogger.error(`Failed to complete initialization: ${error}`);
94
+ });
95
+ if (!this.server) {
96
+ throw new Error("Server failed to start");
97
+ }
98
+ appLogger.info(`Server running at http://${this.server.hostname}:${this.server.port}`);
99
+ if (build || preview) {
100
+ appLogger.debugTime("Building static pages");
101
+ await this.serverAdapter.buildStatic({ preview });
102
+ this.server.stop(true);
103
+ appLogger.debugTimeEnd("Building static pages");
104
+ if (build) {
105
+ process.exit(0);
106
+ }
107
+ }
108
+ return this.server;
109
+ }
110
+ }
111
+ async function createApp(options) {
112
+ return new EcopagesApp(options);
113
+ }
114
+ export {
115
+ EcopagesApp,
116
+ createApp
117
+ };
@@ -0,0 +1,189 @@
1
+ /**
2
+ * This file contains the implementation of the Bun application adapter for EcoPages.
3
+ * It extends the AbstractApplicationAdapter class and provides methods for handling
4
+ * HTTP requests, initializing the server adapter, and starting the Bun application server.
5
+ * The adapter is designed to work with the Bun runtime and provides a way to create
6
+ * EcoPages applications using Bun's features.
7
+ *
8
+ * @module EcopagesApp
9
+ */
10
+
11
+ import type { Server } from 'bun';
12
+ import { DEFAULT_ECOPAGES_HOSTNAME, DEFAULT_ECOPAGES_PORT } from '../../constants.ts';
13
+ import { appLogger } from '../../global/app-logger.ts';
14
+ import type { EcoPagesAppConfig } from '../../internal-types.ts';
15
+ import { getBunRuntime } from '../../utils/runtime.ts';
16
+ import type { ApiHandlerContext, RouteGroupBuilder } from '../../public-types.ts';
17
+ import { type ApplicationAdapterOptions } from '../abstract/application-adapter.ts';
18
+ import { SharedApplicationAdapter } from '../shared/application-adapter.ts';
19
+ import { type BunServerAdapterResult, createBunServerAdapter } from './server-adapter.ts';
20
+
21
+ /**
22
+ * Configuration options for the Bun application adapter
23
+ */
24
+ export interface EcopagesAppOptions extends ApplicationAdapterOptions {
25
+ appConfig: EcoPagesAppConfig;
26
+ serverOptions?: Record<string, any>;
27
+ }
28
+
29
+ /**
30
+ * Bun-specific route group builder that properly infers route params from path patterns.
31
+ * When you define a route like `/posts/:slug`, the handler context will have
32
+ * `ctx.params.slug` typed as `string`.
33
+ *
34
+ * @typeParam WebSocketData - WebSocket data type for the server
35
+ * @typeParam TContext - Extended context type from middleware (e.g., `{ user: User }`)
36
+ */
37
+ export type BunRouteGroupBuilder<
38
+ WebSocketData = undefined,
39
+ TContext extends ApiHandlerContext<Request, Server<WebSocketData>> = ApiHandlerContext<
40
+ Request,
41
+ Server<WebSocketData>
42
+ >,
43
+ > = RouteGroupBuilder<Request, Server<WebSocketData>, TContext>;
44
+
45
+ /**
46
+ * Bun-specific application adapter implementation
47
+ * This class extends the {@link AbstractApplicationAdapter}
48
+ * and provides methods for handling HTTP requests and managing the server.
49
+ */
50
+
51
+ export class EcopagesApp<WebSocketData = undefined> extends SharedApplicationAdapter<
52
+ EcopagesAppOptions,
53
+ Server<WebSocketData>,
54
+ Request
55
+ > {
56
+ serverAdapter: BunServerAdapterResult | undefined;
57
+ private server: Server<WebSocketData> | null = null;
58
+
59
+ public async fetch(request: Request): Promise<Response> {
60
+ if (!this.serverAdapter) {
61
+ this.serverAdapter = await this.initializeServerAdapter();
62
+ }
63
+
64
+ await this.serverAdapter.completeInitialization(this.server);
65
+ return this.serverAdapter.handleRequest(request);
66
+ }
67
+
68
+ /**
69
+ * Complete the initialization of the server adapter by processing dynamic routes
70
+ * @param server The Bun server instance
71
+ */
72
+ public async completeInitialization(server: Server<WebSocketData>): Promise<void> {
73
+ if (!this.serverAdapter) {
74
+ throw new Error('Server adapter not initialized. Call start() first.');
75
+ }
76
+
77
+ await this.serverAdapter.completeInitialization(server);
78
+ }
79
+
80
+ /**
81
+ * Initialize the Bun server adapter
82
+ */
83
+ protected async initializeServerAdapter(): Promise<BunServerAdapterResult> {
84
+ const { dev } = this.cliArgs;
85
+ const { port: cliPort, hostname: cliHostname } = this.cliArgs;
86
+
87
+ const envPort = process.env.ECOPAGES_PORT ? process.env.ECOPAGES_PORT : undefined;
88
+ const envHostname = process.env.ECOPAGES_HOSTNAME;
89
+
90
+ const preferredPort = cliPort ?? envPort ?? DEFAULT_ECOPAGES_PORT;
91
+ const preferredHostname = cliHostname ?? envHostname ?? DEFAULT_ECOPAGES_HOSTNAME;
92
+
93
+ appLogger.debug('initializeServerAdapter', {
94
+ dev,
95
+ cliPort,
96
+ cliHostname,
97
+ envPort,
98
+ envHostname,
99
+ preferredPort,
100
+ preferredHostname,
101
+ composedUrl: `http://${preferredHostname}:${preferredPort}`,
102
+ });
103
+
104
+ return await createBunServerAdapter({
105
+ runtimeOrigin: `http://${preferredHostname}:${preferredPort}`,
106
+ appConfig: this.appConfig,
107
+ apiHandlers: this.apiHandlers,
108
+ staticRoutes: this.staticRoutes,
109
+ errorHandler: this.errorHandler,
110
+ options: { watch: dev },
111
+ serveOptions: {
112
+ port: preferredPort,
113
+ hostname: preferredHostname,
114
+ ...this.serverOptions,
115
+ },
116
+ });
117
+ }
118
+
119
+ /**
120
+ * Start the Bun application server
121
+ * @param options Optional settings
122
+ * @param options.autoCompleteInitialization Whether to automatically complete initialization with dynamic routes after server start (defaults to true)
123
+ */
124
+ public async start(): Promise<Server<WebSocketData> | void> {
125
+ if (!this.serverAdapter) {
126
+ this.serverAdapter = await this.initializeServerAdapter();
127
+ }
128
+
129
+ const { dev, preview, build } = this.cliArgs;
130
+ const requiresFetchRuntime = this.appConfig.integrations.some(
131
+ (integration) => integration.staticBuildStep === 'fetch',
132
+ );
133
+ const canBuildWithoutRuntimeServer = (build || preview) && !requiresFetchRuntime;
134
+
135
+ if (canBuildWithoutRuntimeServer) {
136
+ appLogger.debugTime('Building static pages');
137
+ await this.serverAdapter.buildStatic({ preview });
138
+ appLogger.debugTimeEnd('Building static pages');
139
+
140
+ if (build) {
141
+ process.exit(0);
142
+ }
143
+
144
+ return;
145
+ }
146
+
147
+ const enableHmr = dev || (!preview && !build);
148
+ const serverOptions = this.serverAdapter.getServerOptions({ enableHmr });
149
+
150
+ const bun = getBunRuntime();
151
+ if (!bun) {
152
+ throw new Error('Bun runtime is required for the Bun adapter');
153
+ }
154
+
155
+ const bunServer = bun.serve(serverOptions as Bun.Serve.Options<WebSocketData>);
156
+ this.server = bunServer as Server<WebSocketData>;
157
+
158
+ await this.serverAdapter.completeInitialization(this.server).catch((error: Error) => {
159
+ appLogger.error(`Failed to complete initialization: ${error}`);
160
+ });
161
+
162
+ if (!this.server) {
163
+ throw new Error('Server failed to start');
164
+ }
165
+ appLogger.info(`Server running at http://${this.server.hostname}:${this.server.port}`);
166
+
167
+ if (build || preview) {
168
+ appLogger.debugTime('Building static pages');
169
+ await this.serverAdapter.buildStatic({ preview });
170
+ this.server.stop(true);
171
+ appLogger.debugTimeEnd('Building static pages');
172
+
173
+ if (build) {
174
+ process.exit(0);
175
+ }
176
+ }
177
+
178
+ return this.server;
179
+ }
180
+ }
181
+
182
+ /**
183
+ * Factory function to create a Bun application
184
+ */
185
+ export async function createApp<WebSocketData = undefined>(
186
+ options: EcopagesAppOptions,
187
+ ): Promise<EcopagesApp<WebSocketData>> {
188
+ return new EcopagesApp(options);
189
+ }
@@ -0,0 +1,61 @@
1
+ import type { Server } from 'bun';
2
+ import type { ApiHandler, ApiHandlerContext, Middleware, RouteSchema, TypedGroupHandlerContext } from '../../public-types';
3
+ type BunSchemaHandlerContext<TSchema extends RouteSchema | undefined, WebSocketData, TContext extends ApiHandlerContext<Request, Server<WebSocketData>>> = TSchema extends RouteSchema ? TypedGroupHandlerContext<TSchema, TContext> : TContext;
4
+ /**
5
+ * Helper function specifically for Bun to define an API handler with
6
+ * automatically inferred path type for BunRequest.
7
+ *
8
+ * This returns a self-describing route declaration (`path`, `method`, `handler`,
9
+ * optional `middleware`, optional `schema`) that can be registered on the app.
10
+ *
11
+ * @template TPath The literal string type of the path, inferred from the 'path' property.
12
+ * @param handler The API handler configuration object using BunRequest.
13
+ * @returns The same handler object, strongly typed for Bun.
14
+ */
15
+ export declare function defineApiHandler<TSchema extends RouteSchema | undefined = undefined, WebSocketData = undefined, TContext extends ApiHandlerContext<Request, Server<WebSocketData>> = ApiHandlerContext<Request, Server<WebSocketData>>>(handler: Omit<ApiHandler<string, Request, Server<WebSocketData>>, 'handler' | 'middleware' | 'schema'> & {
16
+ handler: (context: BunSchemaHandlerContext<TSchema, WebSocketData, TContext>) => Promise<Response> | Response;
17
+ middleware?: Middleware<Request, Server<WebSocketData>, TContext>[];
18
+ schema?: TSchema;
19
+ }): ApiHandler<string, Request, Server<WebSocketData>>;
20
+ /**
21
+ * Configuration for a group of related API handlers with shared prefix and middleware.
22
+ */
23
+ export interface GroupHandler<TPrefix extends string = string, WebSocketData = undefined> {
24
+ prefix: TPrefix;
25
+ middleware?: readonly Middleware<Request, Server<WebSocketData>, any>[];
26
+ routes: readonly ApiHandler<string, Request, Server<WebSocketData>>[];
27
+ }
28
+ type GroupDefineHandler<WebSocketData, TContext extends ApiHandlerContext<Request, Server<WebSocketData>>> = <const TPath extends string, TSchema extends RouteSchema | undefined = undefined>(handler: Omit<ApiHandler<TPath, Request, Server<WebSocketData>>, 'handler' | 'middleware' | 'schema'> & {
29
+ path: TPath;
30
+ handler: (context: TSchema extends RouteSchema ? TypedGroupHandlerContext<TSchema, TContext> : TContext) => Promise<Response> | Response;
31
+ middleware?: Middleware<Request, Server<WebSocketData>, TContext>[];
32
+ schema?: TSchema;
33
+ }) => ApiHandler<TPath, Request, Server<WebSocketData>>;
34
+ /**
35
+ * Helper function to define a group of API handlers with shared prefix and middleware.
36
+ * The group middleware context is inferred and passed to all route handlers.
37
+ *
38
+ * @example
39
+ * ```typescript
40
+ * const adminGroup = defineGroupHandler({
41
+ * prefix: '/admin',
42
+ * middleware: [authMiddleware],
43
+ * routes: (define) => [
44
+ * define({ path: '/', method: 'GET', handler: (ctx) => ctx.render(List, {}) }),
45
+ * define({ path: '/posts/:id', method: 'GET', handler: (ctx) => {
46
+ * // ctx.session is typed from authMiddleware!
47
+ * // ctx.params.id is typed from path!
48
+ * return ctx.render(Post, { id: ctx.params.id });
49
+ * }}),
50
+ * ],
51
+ * });
52
+ *
53
+ * app.group(adminGroup);
54
+ * ```
55
+ */
56
+ export declare function defineGroupHandler<TPrefix extends string, WebSocketData = undefined, TMiddleware extends readonly Middleware<Request, Server<WebSocketData>, any>[] = [], TContext extends ApiHandlerContext<Request, Server<WebSocketData>> = TMiddleware extends readonly Middleware<Request, Server<WebSocketData>, infer TGroupContext>[] ? TGroupContext : ApiHandlerContext<Request, Server<WebSocketData>>>(config: {
57
+ prefix: TPrefix;
58
+ middleware?: TMiddleware;
59
+ routes: (define: GroupDefineHandler<WebSocketData, TContext>) => readonly ApiHandler<string, Request, Server<WebSocketData>>[];
60
+ }): GroupHandler<TPrefix, WebSocketData>;
61
+ export {};
@@ -0,0 +1,15 @@
1
+ function defineApiHandler(handler) {
2
+ return handler;
3
+ }
4
+ function defineGroupHandler(config) {
5
+ const define = ((handler) => handler);
6
+ return {
7
+ prefix: config.prefix,
8
+ middleware: config.middleware,
9
+ routes: config.routes(define)
10
+ };
11
+ }
12
+ export {
13
+ defineApiHandler,
14
+ defineGroupHandler
15
+ };