@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.
- package/CHANGELOG.md +89 -0
- package/LICENSE +21 -0
- package/README.md +32 -0
- package/package.json +279 -0
- package/src/adapters/abstract/application-adapter.d.ts +168 -0
- package/src/adapters/abstract/application-adapter.js +109 -0
- package/src/adapters/abstract/application-adapter.ts +337 -0
- package/src/adapters/abstract/router-adapter.d.ts +26 -0
- package/src/adapters/abstract/router-adapter.js +5 -0
- package/src/adapters/abstract/router-adapter.ts +30 -0
- package/src/adapters/abstract/server-adapter.d.ts +69 -0
- package/src/adapters/abstract/server-adapter.js +15 -0
- package/src/adapters/abstract/server-adapter.ts +79 -0
- package/src/adapters/bun/client-bridge.d.ts +34 -0
- package/src/adapters/bun/client-bridge.js +48 -0
- package/src/adapters/bun/client-bridge.ts +62 -0
- package/src/adapters/bun/create-app.d.ts +60 -0
- package/src/adapters/bun/create-app.js +117 -0
- package/src/adapters/bun/create-app.ts +189 -0
- package/src/adapters/bun/define-api-handler.d.ts +61 -0
- package/src/adapters/bun/define-api-handler.js +15 -0
- package/src/adapters/bun/define-api-handler.ts +114 -0
- package/src/adapters/bun/hmr-manager.d.ts +84 -0
- package/src/adapters/bun/hmr-manager.js +227 -0
- package/src/adapters/bun/hmr-manager.ts +281 -0
- package/src/adapters/bun/index.d.ts +3 -0
- package/src/adapters/bun/index.js +8 -0
- package/src/adapters/bun/index.ts +3 -0
- package/src/adapters/bun/server-adapter.d.ts +155 -0
- package/src/adapters/bun/server-adapter.js +368 -0
- package/src/adapters/bun/server-adapter.ts +492 -0
- package/src/adapters/bun/server-lifecycle.d.ts +52 -0
- package/src/adapters/bun/server-lifecycle.js +120 -0
- package/src/adapters/bun/server-lifecycle.ts +154 -0
- package/src/adapters/index.d.ts +6 -0
- package/src/adapters/index.js +14 -0
- package/src/adapters/index.ts +6 -0
- package/src/adapters/node/create-app.d.ts +21 -0
- package/src/adapters/node/create-app.js +143 -0
- package/src/adapters/node/create-app.ts +179 -0
- package/src/adapters/node/index.d.ts +4 -0
- package/src/adapters/node/index.js +8 -0
- package/src/adapters/node/index.ts +9 -0
- package/src/adapters/node/node-client-bridge.d.ts +26 -0
- package/src/adapters/node/node-client-bridge.js +66 -0
- package/src/adapters/node/node-client-bridge.ts +79 -0
- package/src/adapters/node/node-hmr-manager.d.ts +62 -0
- package/src/adapters/node/node-hmr-manager.js +221 -0
- package/src/adapters/node/node-hmr-manager.ts +271 -0
- package/src/adapters/node/server-adapter.d.ts +190 -0
- package/src/adapters/node/server-adapter.js +420 -0
- package/src/adapters/node/server-adapter.ts +561 -0
- package/src/adapters/node/static-content-server.d.ts +24 -0
- package/src/adapters/node/static-content-server.js +166 -0
- package/src/adapters/node/static-content-server.ts +203 -0
- package/src/adapters/shared/api-response.d.ts +52 -0
- package/src/adapters/shared/api-response.js +96 -0
- package/src/adapters/shared/api-response.ts +104 -0
- package/src/adapters/shared/application-adapter.d.ts +18 -0
- package/src/adapters/shared/application-adapter.js +90 -0
- package/src/adapters/shared/application-adapter.ts +199 -0
- package/src/adapters/shared/explicit-static-route-matcher.d.ts +38 -0
- package/src/adapters/shared/explicit-static-route-matcher.js +100 -0
- package/src/adapters/shared/explicit-static-route-matcher.ts +134 -0
- package/src/adapters/shared/file-route-middleware-pipeline.d.ts +65 -0
- package/src/adapters/shared/file-route-middleware-pipeline.js +98 -0
- package/src/adapters/shared/file-route-middleware-pipeline.ts +123 -0
- package/src/adapters/shared/fs-server-response-factory.d.ts +19 -0
- package/src/adapters/shared/fs-server-response-factory.js +97 -0
- package/src/adapters/shared/fs-server-response-factory.ts +118 -0
- package/src/adapters/shared/fs-server-response-matcher.d.ts +71 -0
- package/src/adapters/shared/fs-server-response-matcher.js +155 -0
- package/src/adapters/shared/fs-server-response-matcher.ts +198 -0
- package/src/adapters/shared/render-context.d.ts +14 -0
- package/src/adapters/shared/render-context.js +69 -0
- package/src/adapters/shared/render-context.ts +105 -0
- package/src/adapters/shared/server-adapter.d.ts +87 -0
- package/src/adapters/shared/server-adapter.js +353 -0
- package/src/adapters/shared/server-adapter.ts +442 -0
- package/src/adapters/shared/server-route-handler.d.ts +89 -0
- package/src/adapters/shared/server-route-handler.js +120 -0
- package/src/adapters/shared/server-route-handler.ts +166 -0
- package/src/adapters/shared/server-static-builder.d.ts +38 -0
- package/src/adapters/shared/server-static-builder.js +46 -0
- package/src/adapters/shared/server-static-builder.ts +82 -0
- package/src/build/build-adapter.d.ts +74 -0
- package/src/build/build-adapter.js +54 -0
- package/src/build/build-adapter.ts +132 -0
- package/src/build/build-types.d.ts +57 -0
- package/src/build/build-types.js +0 -0
- package/src/build/build-types.ts +83 -0
- package/src/build/esbuild-build-adapter.d.ts +69 -0
- package/src/build/esbuild-build-adapter.js +390 -0
- package/src/build/esbuild-build-adapter.ts +510 -0
- package/src/config/config-builder.d.ts +227 -0
- package/src/config/config-builder.js +392 -0
- package/src/config/config-builder.ts +474 -0
- package/src/constants.d.ts +32 -0
- package/src/constants.js +21 -0
- package/src/constants.ts +39 -0
- package/src/create-app.d.ts +17 -0
- package/src/create-app.js +66 -0
- package/src/create-app.ts +87 -0
- package/src/declarations.d.ts +26 -0
- package/src/define-api-handler.d.ts +25 -0
- package/src/define-api-handler.js +15 -0
- package/src/define-api-handler.ts +66 -0
- package/src/dev/sc-server.d.ts +30 -0
- package/src/dev/sc-server.js +111 -0
- package/src/dev/sc-server.ts +143 -0
- package/src/eco/README.md +636 -0
- package/src/eco/component-render-context.d.ts +105 -0
- package/src/eco/component-render-context.js +77 -0
- package/src/eco/component-render-context.ts +202 -0
- package/src/eco/eco.d.ts +9 -0
- package/src/eco/eco.js +110 -0
- package/src/eco/eco.ts +221 -0
- package/src/eco/eco.types.d.ts +170 -0
- package/src/eco/eco.types.js +0 -0
- package/src/eco/eco.types.ts +202 -0
- package/src/eco/eco.utils.d.ts +40 -0
- package/src/eco/eco.utils.js +40 -0
- package/src/eco/eco.utils.ts +89 -0
- package/src/eco/global-injector-map.d.ts +16 -0
- package/src/eco/global-injector-map.js +80 -0
- package/src/eco/global-injector-map.ts +112 -0
- package/src/eco/lazy-injector-map.d.ts +8 -0
- package/src/eco/lazy-injector-map.js +70 -0
- package/src/eco/lazy-injector-map.ts +120 -0
- package/src/eco/module-dependencies.d.ts +18 -0
- package/src/eco/module-dependencies.js +49 -0
- package/src/eco/module-dependencies.ts +75 -0
- package/src/env.d.ts +20 -0
- package/src/errors/http-error.d.ts +31 -0
- package/src/errors/http-error.js +50 -0
- package/src/errors/http-error.ts +72 -0
- package/src/errors/index.d.ts +2 -0
- package/src/errors/index.js +4 -0
- package/src/errors/index.ts +2 -0
- package/src/errors/locals-access-error.d.ts +4 -0
- package/src/errors/locals-access-error.js +9 -0
- package/src/errors/locals-access-error.ts +7 -0
- package/src/global/app-logger.d.ts +2 -0
- package/src/global/app-logger.js +6 -0
- package/src/global/app-logger.ts +4 -0
- 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
- package/src/hmr/client/__screenshots__/hmr-runtime.test.browser.ts/HMR-Runtime-HMR-Server-Integration-should-load-fixture-app-page-1.png +0 -0
- package/src/hmr/client/__screenshots__/hmr-runtime.test.browser.ts/HMR-Runtime-WebSocket-Connection-should-connect-to-correct-HMR-endpoint-1.png +0 -0
- package/src/hmr/client/hmr-runtime.d.ts +10 -0
- package/src/hmr/client/hmr-runtime.js +86 -0
- package/src/hmr/client/hmr-runtime.ts +121 -0
- package/src/hmr/hmr-strategy.d.ts +159 -0
- package/src/hmr/hmr-strategy.js +29 -0
- package/src/hmr/hmr-strategy.ts +172 -0
- package/src/hmr/hmr.test.e2e.d.ts +1 -0
- package/src/hmr/hmr.test.e2e.js +50 -0
- package/src/hmr/hmr.test.e2e.ts +75 -0
- package/src/hmr/strategies/default-hmr-strategy.d.ts +43 -0
- package/src/hmr/strategies/default-hmr-strategy.js +34 -0
- package/src/hmr/strategies/default-hmr-strategy.ts +60 -0
- package/src/hmr/strategies/js-hmr-strategy.d.ts +136 -0
- package/src/hmr/strategies/js-hmr-strategy.js +179 -0
- package/src/hmr/strategies/js-hmr-strategy.ts +308 -0
- package/src/index.browser.d.ts +3 -0
- package/src/index.browser.js +4 -0
- package/src/index.browser.ts +3 -0
- package/src/index.d.ts +5 -0
- package/src/index.js +10 -0
- package/src/index.ts +5 -0
- package/src/integrations/ghtml/ghtml-renderer.d.ts +15 -0
- package/src/integrations/ghtml/ghtml-renderer.js +60 -0
- package/src/integrations/ghtml/ghtml-renderer.ts +93 -0
- package/src/integrations/ghtml/ghtml.plugin.d.ts +20 -0
- package/src/integrations/ghtml/ghtml.plugin.js +21 -0
- package/src/integrations/ghtml/ghtml.plugin.ts +32 -0
- package/src/internal-types.d.ts +200 -0
- package/src/internal-types.js +0 -0
- package/src/internal-types.ts +212 -0
- package/src/plugins/alias-resolver-plugin.d.ts +2 -0
- package/src/plugins/alias-resolver-plugin.js +39 -0
- package/src/plugins/alias-resolver-plugin.ts +45 -0
- package/src/plugins/eco-component-meta-plugin.d.ts +95 -0
- package/src/plugins/eco-component-meta-plugin.js +157 -0
- package/src/plugins/eco-component-meta-plugin.ts +474 -0
- package/src/plugins/integration-plugin.d.ts +102 -0
- package/src/plugins/integration-plugin.js +100 -0
- package/src/plugins/integration-plugin.ts +184 -0
- package/src/plugins/processor.d.ts +82 -0
- package/src/plugins/processor.js +122 -0
- package/src/plugins/processor.ts +220 -0
- package/src/public-types.d.ts +1094 -0
- package/src/public-types.js +0 -0
- package/src/public-types.ts +1255 -0
- package/src/route-renderer/GRAPH.md +387 -0
- package/src/route-renderer/README.md +135 -0
- package/src/route-renderer/component-graph-executor.d.ts +32 -0
- package/src/route-renderer/component-graph-executor.js +31 -0
- package/src/route-renderer/component-graph-executor.ts +84 -0
- package/src/route-renderer/component-graph.d.ts +42 -0
- package/src/route-renderer/component-graph.js +72 -0
- package/src/route-renderer/component-graph.ts +159 -0
- package/src/route-renderer/component-marker.d.ts +52 -0
- package/src/route-renderer/component-marker.js +46 -0
- package/src/route-renderer/component-marker.ts +117 -0
- package/src/route-renderer/dependency-resolver.d.ts +24 -0
- package/src/route-renderer/dependency-resolver.js +428 -0
- package/src/route-renderer/dependency-resolver.ts +596 -0
- package/src/route-renderer/html-post-processing.service.d.ts +40 -0
- package/src/route-renderer/html-post-processing.service.js +86 -0
- package/src/route-renderer/html-post-processing.service.ts +103 -0
- package/src/route-renderer/integration-renderer.d.ts +339 -0
- package/src/route-renderer/integration-renderer.js +526 -0
- package/src/route-renderer/integration-renderer.ts +696 -0
- package/src/route-renderer/marker-graph-resolver.d.ts +76 -0
- package/src/route-renderer/marker-graph-resolver.js +93 -0
- package/src/route-renderer/marker-graph-resolver.ts +153 -0
- package/src/route-renderer/page-module-loader.d.ts +61 -0
- package/src/route-renderer/page-module-loader.js +102 -0
- package/src/route-renderer/page-module-loader.ts +153 -0
- package/src/route-renderer/render-execution.service.d.ts +69 -0
- package/src/route-renderer/render-execution.service.js +91 -0
- package/src/route-renderer/render-execution.service.ts +158 -0
- package/src/route-renderer/render-preparation.service.d.ts +112 -0
- package/src/route-renderer/render-preparation.service.js +243 -0
- package/src/route-renderer/render-preparation.service.ts +358 -0
- package/src/route-renderer/route-renderer.d.ts +26 -0
- package/src/route-renderer/route-renderer.js +68 -0
- package/src/route-renderer/route-renderer.ts +80 -0
- package/src/router/fs-router-scanner.d.ts +41 -0
- package/src/router/fs-router-scanner.js +155 -0
- package/src/router/fs-router-scanner.ts +217 -0
- package/src/router/fs-router.d.ts +26 -0
- package/src/router/fs-router.js +100 -0
- package/src/router/fs-router.ts +122 -0
- package/src/services/asset-processing-service/asset-processing.service.d.ts +41 -0
- package/src/services/asset-processing-service/asset-processing.service.js +250 -0
- package/src/services/asset-processing-service/asset-processing.service.ts +306 -0
- package/src/services/asset-processing-service/asset.factory.d.ts +17 -0
- package/src/services/asset-processing-service/asset.factory.js +82 -0
- package/src/services/asset-processing-service/asset.factory.ts +105 -0
- package/src/services/asset-processing-service/assets.types.d.ts +88 -0
- package/src/services/asset-processing-service/assets.types.js +0 -0
- package/src/services/asset-processing-service/assets.types.ts +112 -0
- package/src/services/asset-processing-service/index.d.ts +3 -0
- package/src/services/asset-processing-service/index.js +3 -0
- package/src/services/asset-processing-service/index.ts +3 -0
- package/src/services/asset-processing-service/processor.interface.d.ts +22 -0
- package/src/services/asset-processing-service/processor.interface.js +6 -0
- package/src/services/asset-processing-service/processor.interface.ts +27 -0
- package/src/services/asset-processing-service/processor.registry.d.ts +8 -0
- package/src/services/asset-processing-service/processor.registry.js +15 -0
- package/src/services/asset-processing-service/processor.registry.ts +18 -0
- package/src/services/asset-processing-service/processors/base/base-processor.d.ts +24 -0
- package/src/services/asset-processing-service/processors/base/base-processor.js +59 -0
- package/src/services/asset-processing-service/processors/base/base-processor.ts +76 -0
- package/src/services/asset-processing-service/processors/base/base-script-processor.d.ts +16 -0
- package/src/services/asset-processing-service/processors/base/base-script-processor.js +80 -0
- package/src/services/asset-processing-service/processors/base/base-script-processor.ts +105 -0
- package/src/services/asset-processing-service/processors/index.d.ts +5 -0
- package/src/services/asset-processing-service/processors/index.js +5 -0
- package/src/services/asset-processing-service/processors/index.ts +5 -0
- package/src/services/asset-processing-service/processors/script/content-script.processor.d.ts +5 -0
- package/src/services/asset-processing-service/processors/script/content-script.processor.js +57 -0
- package/src/services/asset-processing-service/processors/script/content-script.processor.ts +66 -0
- package/src/services/asset-processing-service/processors/script/file-script.processor.d.ts +8 -0
- package/src/services/asset-processing-service/processors/script/file-script.processor.js +76 -0
- package/src/services/asset-processing-service/processors/script/file-script.processor.ts +88 -0
- package/src/services/asset-processing-service/processors/script/node-module-script.processor.d.ts +7 -0
- package/src/services/asset-processing-service/processors/script/node-module-script.processor.js +74 -0
- package/src/services/asset-processing-service/processors/script/node-module-script.processor.ts +84 -0
- package/src/services/asset-processing-service/processors/stylesheet/content-stylesheet.processor.d.ts +5 -0
- package/src/services/asset-processing-service/processors/stylesheet/content-stylesheet.processor.js +25 -0
- package/src/services/asset-processing-service/processors/stylesheet/content-stylesheet.processor.ts +27 -0
- package/src/services/asset-processing-service/processors/stylesheet/file-stylesheet.processor.d.ts +9 -0
- package/src/services/asset-processing-service/processors/stylesheet/file-stylesheet.processor.js +63 -0
- package/src/services/asset-processing-service/processors/stylesheet/file-stylesheet.processor.ts +77 -0
- package/src/services/cache/cache.types.d.ts +107 -0
- package/src/services/cache/cache.types.js +0 -0
- package/src/services/cache/cache.types.ts +126 -0
- package/src/services/cache/index.d.ts +7 -0
- package/src/services/cache/index.js +7 -0
- package/src/services/cache/index.ts +18 -0
- package/src/services/cache/memory-cache-store.d.ts +42 -0
- package/src/services/cache/memory-cache-store.js +98 -0
- package/src/services/cache/memory-cache-store.ts +130 -0
- package/src/services/cache/page-cache-service.d.ts +70 -0
- package/src/services/cache/page-cache-service.js +152 -0
- package/src/services/cache/page-cache-service.ts +202 -0
- package/src/services/html-transformer.service.d.ts +50 -0
- package/src/services/html-transformer.service.js +163 -0
- package/src/services/html-transformer.service.ts +217 -0
- package/src/services/page-module-import.service.d.ts +37 -0
- package/src/services/page-module-import.service.js +88 -0
- package/src/services/page-module-import.service.ts +129 -0
- package/src/services/page-request-cache-coordinator.service.d.ts +75 -0
- package/src/services/page-request-cache-coordinator.service.js +107 -0
- package/src/services/page-request-cache-coordinator.service.ts +128 -0
- package/src/services/schema-validation-service.d.ts +122 -0
- package/src/services/schema-validation-service.js +101 -0
- package/src/services/schema-validation-service.ts +204 -0
- package/src/services/validation/standard-schema.types.d.ts +65 -0
- package/src/services/validation/standard-schema.types.js +0 -0
- package/src/services/validation/standard-schema.types.ts +68 -0
- package/src/static-site-generator/static-site-generator.d.ts +57 -0
- package/src/static-site-generator/static-site-generator.js +272 -0
- package/src/static-site-generator/static-site-generator.ts +359 -0
- package/src/utils/css.d.ts +1 -0
- package/src/utils/css.js +7 -0
- package/src/utils/css.ts +5 -0
- package/src/utils/deep-merge.d.ts +14 -0
- package/src/utils/deep-merge.js +32 -0
- package/src/utils/deep-merge.ts +47 -0
- package/src/utils/hash.d.ts +1 -0
- package/src/utils/hash.js +7 -0
- package/src/utils/hash.ts +5 -0
- package/src/utils/html.d.ts +1 -0
- package/src/utils/html.js +4 -0
- package/src/utils/html.ts +1 -0
- package/src/utils/invariant.d.ts +5 -0
- package/src/utils/invariant.js +11 -0
- package/src/utils/invariant.ts +15 -0
- package/src/utils/locals-utils.d.ts +15 -0
- package/src/utils/locals-utils.js +24 -0
- package/src/utils/locals-utils.ts +37 -0
- package/src/utils/parse-cli-args.d.ts +24 -0
- package/src/utils/parse-cli-args.js +47 -0
- package/src/utils/parse-cli-args.ts +83 -0
- package/src/utils/path-utils.module.d.ts +5 -0
- package/src/utils/path-utils.module.js +14 -0
- package/src/utils/path-utils.module.ts +14 -0
- package/src/utils/runtime.d.ts +11 -0
- package/src/utils/runtime.js +40 -0
- package/src/utils/runtime.ts +44 -0
- package/src/utils/server-utils.module.d.ts +19 -0
- package/src/utils/server-utils.module.js +56 -0
- package/src/utils/server-utils.module.ts +67 -0
- package/src/watchers/project-watcher.d.ts +120 -0
- package/src/watchers/project-watcher.js +238 -0
- package/src/watchers/project-watcher.test-helpers.d.ts +4 -0
- package/src/watchers/project-watcher.test-helpers.js +51 -0
- package/src/watchers/project-watcher.test-helpers.ts +40 -0
- 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
|
+
};
|