@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,198 @@
|
|
|
1
|
+
import path from 'node:path';
|
|
2
|
+
import { appLogger } from '../../global/app-logger.ts';
|
|
3
|
+
import type { MatchResult } from '../../internal-types.ts';
|
|
4
|
+
import type { RouteRendererFactory } from '../../route-renderer/route-renderer.ts';
|
|
5
|
+
import type { FSRouter } from '../../router/fs-router.ts';
|
|
6
|
+
import type { PageCacheService } from '../../services/cache/page-cache-service.ts';
|
|
7
|
+
import type { CacheStrategy, RenderResult } from '../../services/cache/cache.types.ts';
|
|
8
|
+
import { PageModuleImportService } from '../../services/page-module-import.service.ts';
|
|
9
|
+
import { PageRequestCacheCoordinator } from '../../services/page-request-cache-coordinator.service.ts';
|
|
10
|
+
import { ServerUtils } from '../../utils/server-utils.module.ts';
|
|
11
|
+
import type { Middleware, RequestLocals } from '../../public-types.ts';
|
|
12
|
+
import { FileRouteMiddlewarePipeline } from './file-route-middleware-pipeline.ts';
|
|
13
|
+
import { LocalsAccessError } from '../../errors/locals-access-error.ts';
|
|
14
|
+
import { isDevelopmentRuntime } from '../../utils/runtime.ts';
|
|
15
|
+
import type { FileSystemServerResponseFactory } from './fs-server-response-factory.ts';
|
|
16
|
+
|
|
17
|
+
export const FILE_SYSTEM_RESPONSE_MATCHER_ERRORS = {
|
|
18
|
+
transpilePageModuleFailed: (details: string) => `Error transpiling page module: ${details}`,
|
|
19
|
+
noTranspiledOutputForPageModule: (filePath: string) =>
|
|
20
|
+
`No transpiled output generated for page module: ${filePath}`,
|
|
21
|
+
} as const;
|
|
22
|
+
|
|
23
|
+
export interface FileSystemResponseMatcherOptions {
|
|
24
|
+
router: FSRouter;
|
|
25
|
+
routeRendererFactory: RouteRendererFactory;
|
|
26
|
+
fileSystemResponseFactory: FileSystemServerResponseFactory;
|
|
27
|
+
/** Optional cache service. When null, caching is disabled. */
|
|
28
|
+
cacheService?: PageCacheService | null;
|
|
29
|
+
/** Default cache strategy when caching is enabled. @default 'static' */
|
|
30
|
+
defaultCacheStrategy?: CacheStrategy;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
/**
|
|
34
|
+
* Matches file-system routes to rendered HTML responses.
|
|
35
|
+
*
|
|
36
|
+
* This class sits at the request-time boundary between router matches and the
|
|
37
|
+
* render pipeline. It coordinates page module inspection, request-local policy,
|
|
38
|
+
* renderer invocation, middleware execution, cache integration, and fallback
|
|
39
|
+
* error translation.
|
|
40
|
+
*/
|
|
41
|
+
export class FileSystemResponseMatcher {
|
|
42
|
+
private router: FSRouter;
|
|
43
|
+
private routeRendererFactory: RouteRendererFactory;
|
|
44
|
+
private fileSystemResponseFactory: FileSystemServerResponseFactory;
|
|
45
|
+
private pageModuleImportService: PageModuleImportService;
|
|
46
|
+
private pageRequestCacheCoordinator: PageRequestCacheCoordinator;
|
|
47
|
+
private fileRouteMiddlewarePipeline: FileRouteMiddlewarePipeline;
|
|
48
|
+
|
|
49
|
+
constructor({
|
|
50
|
+
router,
|
|
51
|
+
routeRendererFactory,
|
|
52
|
+
fileSystemResponseFactory,
|
|
53
|
+
cacheService = null,
|
|
54
|
+
defaultCacheStrategy = 'static',
|
|
55
|
+
}: FileSystemResponseMatcherOptions) {
|
|
56
|
+
this.router = router;
|
|
57
|
+
this.routeRendererFactory = routeRendererFactory;
|
|
58
|
+
this.fileSystemResponseFactory = fileSystemResponseFactory;
|
|
59
|
+
this.pageModuleImportService = new PageModuleImportService();
|
|
60
|
+
this.pageRequestCacheCoordinator = new PageRequestCacheCoordinator(cacheService, defaultCacheStrategy);
|
|
61
|
+
this.fileRouteMiddlewarePipeline = new FileRouteMiddlewarePipeline(cacheService);
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
/**
|
|
65
|
+
* Resolves unmatched paths either as static asset requests or as the custom
|
|
66
|
+
* not-found page.
|
|
67
|
+
*
|
|
68
|
+
* @param requestUrl Incoming pathname.
|
|
69
|
+
* @returns Static file response or rendered 404 response.
|
|
70
|
+
*/
|
|
71
|
+
async handleNoMatch(requestUrl: string): Promise<Response> {
|
|
72
|
+
const isStaticFileRequest = ServerUtils.hasKnownExtension(requestUrl);
|
|
73
|
+
|
|
74
|
+
if (!isStaticFileRequest) {
|
|
75
|
+
return this.fileSystemResponseFactory.createCustomNotFoundResponse();
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
const relativeUrl = requestUrl.startsWith('/') ? requestUrl.slice(1) : requestUrl;
|
|
79
|
+
const filePath = path.join(this.router.assetPrefix, relativeUrl);
|
|
80
|
+
const contentType = ServerUtils.getContentType(filePath);
|
|
81
|
+
|
|
82
|
+
return this.fileSystemResponseFactory.createFileResponse(filePath, contentType);
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
/**
|
|
86
|
+
* Handles a matched file-system page route.
|
|
87
|
+
*
|
|
88
|
+
* The method inspects page metadata needed for request-time execution,
|
|
89
|
+
* prepares the renderer invocation, validates middleware/cache constraints,
|
|
90
|
+
* and delegates caching plus middleware execution to dedicated collaborators.
|
|
91
|
+
*
|
|
92
|
+
* @param match Router match result.
|
|
93
|
+
* @param request Optional incoming request. A synthetic GET request is created when omitted.
|
|
94
|
+
* @returns Final response for the matched route.
|
|
95
|
+
*/
|
|
96
|
+
async handleMatch(match: MatchResult, request?: Request): Promise<Response> {
|
|
97
|
+
const cacheKey = this.pageRequestCacheCoordinator.buildCacheKey(match);
|
|
98
|
+
|
|
99
|
+
try {
|
|
100
|
+
const resolvedRequest =
|
|
101
|
+
request ??
|
|
102
|
+
new Request(new URL(cacheKey, this.router.origin).toString(), {
|
|
103
|
+
method: 'GET',
|
|
104
|
+
});
|
|
105
|
+
|
|
106
|
+
const localsStore: RequestLocals = {};
|
|
107
|
+
const pageModule = await this.importPageModule(match.filePath);
|
|
108
|
+
const Page = (pageModule as any)?.default;
|
|
109
|
+
const pageMiddleware = (Page?.middleware ?? []) as Middleware[];
|
|
110
|
+
const pageCacheStrategy =
|
|
111
|
+
(Page?.cache as CacheStrategy | undefined) ??
|
|
112
|
+
this.pageRequestCacheCoordinator.getDefaultCacheStrategy();
|
|
113
|
+
const localsForRender: RequestLocals | undefined =
|
|
114
|
+
pageCacheStrategy === 'dynamic' ? localsStore : undefined;
|
|
115
|
+
|
|
116
|
+
this.fileRouteMiddlewarePipeline.assertValidConfiguration({
|
|
117
|
+
middleware: pageMiddleware,
|
|
118
|
+
pageCacheStrategy,
|
|
119
|
+
filePath: match.filePath,
|
|
120
|
+
});
|
|
121
|
+
|
|
122
|
+
const routeRenderer = this.routeRendererFactory.createRenderer(match.filePath);
|
|
123
|
+
const middlewareContext = this.fileRouteMiddlewarePipeline.createContext({
|
|
124
|
+
request: resolvedRequest,
|
|
125
|
+
params: match.params as Record<string, string>,
|
|
126
|
+
locals: localsStore,
|
|
127
|
+
});
|
|
128
|
+
|
|
129
|
+
const renderFn = async (): Promise<RenderResult> => {
|
|
130
|
+
const result = await routeRenderer.createRoute({
|
|
131
|
+
file: match.filePath,
|
|
132
|
+
params: match.params,
|
|
133
|
+
query: match.query,
|
|
134
|
+
locals: localsForRender,
|
|
135
|
+
});
|
|
136
|
+
const html = await this.pageRequestCacheCoordinator.bodyToString(result.body);
|
|
137
|
+
const strategy = result.cacheStrategy ?? this.pageRequestCacheCoordinator.getDefaultCacheStrategy();
|
|
138
|
+
return { html, strategy };
|
|
139
|
+
};
|
|
140
|
+
const renderResponse = async (): Promise<Response> => {
|
|
141
|
+
return this.pageRequestCacheCoordinator.render({
|
|
142
|
+
cacheKey,
|
|
143
|
+
pageCacheStrategy,
|
|
144
|
+
renderFn,
|
|
145
|
+
});
|
|
146
|
+
};
|
|
147
|
+
|
|
148
|
+
return await this.fileRouteMiddlewarePipeline.run({
|
|
149
|
+
middleware: pageMiddleware,
|
|
150
|
+
context: middlewareContext,
|
|
151
|
+
renderResponse,
|
|
152
|
+
});
|
|
153
|
+
} catch (error) {
|
|
154
|
+
if (error instanceof Response) {
|
|
155
|
+
return error;
|
|
156
|
+
}
|
|
157
|
+
if (error instanceof LocalsAccessError) {
|
|
158
|
+
return new Response(error.message, {
|
|
159
|
+
status: 500,
|
|
160
|
+
headers: { 'Content-Type': 'text/plain; charset=utf-8' },
|
|
161
|
+
});
|
|
162
|
+
}
|
|
163
|
+
if (error instanceof Error) {
|
|
164
|
+
if (isDevelopmentRuntime() || appLogger.isDebugEnabled()) {
|
|
165
|
+
appLogger.error(`[FileSystemResponseMatcher] ${error.message} at ${match.pathname}`);
|
|
166
|
+
}
|
|
167
|
+
}
|
|
168
|
+
return this.fileSystemResponseFactory.createCustomNotFoundResponse();
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
|
|
172
|
+
/**
|
|
173
|
+
* Loads the matched page module for request-time inspection.
|
|
174
|
+
*
|
|
175
|
+
* The matcher needs access to page-level metadata such as `cache` and
|
|
176
|
+
* `middleware` before full rendering starts, so it uses the shared module
|
|
177
|
+
* import service directly rather than going through route rendering.
|
|
178
|
+
*
|
|
179
|
+
* @param filePath Absolute page module path.
|
|
180
|
+
* @returns Imported page module.
|
|
181
|
+
*/
|
|
182
|
+
private async importPageModule(filePath: string): Promise<unknown> {
|
|
183
|
+
return this.pageModuleImportService.importModule({
|
|
184
|
+
filePath,
|
|
185
|
+
rootDir: path.dirname(this.router.assetPrefix),
|
|
186
|
+
outdir: path.join(this.router.assetPrefix, '.server-modules-meta'),
|
|
187
|
+
transpileErrorMessage: FILE_SYSTEM_RESPONSE_MATCHER_ERRORS.transpilePageModuleFailed,
|
|
188
|
+
noOutputMessage: FILE_SYSTEM_RESPONSE_MATCHER_ERRORS.noTranspiledOutputForPageModule,
|
|
189
|
+
});
|
|
190
|
+
}
|
|
191
|
+
|
|
192
|
+
/**
|
|
193
|
+
* Get the underlying cache service for external invalidation.
|
|
194
|
+
*/
|
|
195
|
+
getCacheService(): PageCacheService | null {
|
|
196
|
+
return this.pageRequestCacheCoordinator.getCacheService();
|
|
197
|
+
}
|
|
198
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { RenderContext } from '../../public-types.js';
|
|
2
|
+
import type { IntegrationPlugin } from '../../plugins/integration-plugin.js';
|
|
3
|
+
export interface CreateRenderContextOptions {
|
|
4
|
+
integrations: IntegrationPlugin[];
|
|
5
|
+
}
|
|
6
|
+
/**
|
|
7
|
+
* Creates a render context for route handlers.
|
|
8
|
+
* Provides render(), renderPartial(), json(), and html() methods that can be used
|
|
9
|
+
* within route handlers to generate responses.
|
|
10
|
+
*
|
|
11
|
+
* @param options - Configuration options including available integrations
|
|
12
|
+
* @returns A RenderContext object with methods for rendering views and creating responses
|
|
13
|
+
*/
|
|
14
|
+
export declare function createRenderContext(options: CreateRenderContextOptions): RenderContext;
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
import { invariant } from "../../utils/invariant.js";
|
|
2
|
+
function mergePropsWithLocals(props, locals) {
|
|
3
|
+
if (!locals || typeof props !== "object" || props === null) {
|
|
4
|
+
return props;
|
|
5
|
+
}
|
|
6
|
+
return { ...props, locals };
|
|
7
|
+
}
|
|
8
|
+
function createRenderContext(options) {
|
|
9
|
+
const { integrations } = options;
|
|
10
|
+
const getRendererForView = (view) => {
|
|
11
|
+
const integrationName = view.config?.integration ?? view.config?.__eco?.integration;
|
|
12
|
+
invariant(
|
|
13
|
+
!!integrationName,
|
|
14
|
+
"Cannot determine integration for view. Set view.config.integration explicitly or ensure the view is defined with eco.page() in a file with a recognized extension."
|
|
15
|
+
);
|
|
16
|
+
const integration = integrations.find((i) => i.name === integrationName);
|
|
17
|
+
invariant(!!integration, `No integration found for: ${integrationName}`);
|
|
18
|
+
return integration.initializeRenderer();
|
|
19
|
+
};
|
|
20
|
+
return {
|
|
21
|
+
async render(view, props, renderOptions) {
|
|
22
|
+
const locals = this?.locals;
|
|
23
|
+
const mergedProps = mergePropsWithLocals(props, locals);
|
|
24
|
+
const renderer = getRendererForView(view);
|
|
25
|
+
const ctx = {
|
|
26
|
+
partial: false,
|
|
27
|
+
status: renderOptions?.status,
|
|
28
|
+
headers: renderOptions?.headers
|
|
29
|
+
};
|
|
30
|
+
return renderer.renderToResponse(view, mergedProps, ctx);
|
|
31
|
+
},
|
|
32
|
+
async renderPartial(view, props, renderOptions) {
|
|
33
|
+
const locals = this?.locals;
|
|
34
|
+
const mergedProps = mergePropsWithLocals(props, locals);
|
|
35
|
+
const renderer = getRendererForView(view);
|
|
36
|
+
const ctx = {
|
|
37
|
+
partial: true,
|
|
38
|
+
status: renderOptions?.status,
|
|
39
|
+
headers: renderOptions?.headers
|
|
40
|
+
};
|
|
41
|
+
return renderer.renderToResponse(view, mergedProps, ctx);
|
|
42
|
+
},
|
|
43
|
+
json(data, responseOptions) {
|
|
44
|
+
const headers = new Headers({ "Content-Type": "application/json; charset=utf-8" });
|
|
45
|
+
if (responseOptions?.headers) {
|
|
46
|
+
const incomingHeaders = new Headers(responseOptions.headers);
|
|
47
|
+
incomingHeaders.forEach((value, key) => headers.set(key, value));
|
|
48
|
+
}
|
|
49
|
+
return new Response(JSON.stringify(data), {
|
|
50
|
+
status: responseOptions?.status ?? 200,
|
|
51
|
+
headers
|
|
52
|
+
});
|
|
53
|
+
},
|
|
54
|
+
html(content, responseOptions) {
|
|
55
|
+
const headers = new Headers({ "Content-Type": "text/html; charset=utf-8" });
|
|
56
|
+
if (responseOptions?.headers) {
|
|
57
|
+
const incomingHeaders = new Headers(responseOptions.headers);
|
|
58
|
+
incomingHeaders.forEach((value, key) => headers.set(key, value));
|
|
59
|
+
}
|
|
60
|
+
return new Response(content, {
|
|
61
|
+
status: responseOptions?.status ?? 200,
|
|
62
|
+
headers
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
};
|
|
66
|
+
}
|
|
67
|
+
export {
|
|
68
|
+
createRenderContext
|
|
69
|
+
};
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
import type { EcoComponent, RenderContext, RenderOptions, ResponseOptions } from '../../public-types.ts';
|
|
2
|
+
import type { IntegrationRenderer, RenderToResponseContext } from '../../route-renderer/integration-renderer.ts';
|
|
3
|
+
import type { IntegrationPlugin } from '../../plugins/integration-plugin.ts';
|
|
4
|
+
import { invariant } from '../../utils/invariant.ts';
|
|
5
|
+
|
|
6
|
+
export interface CreateRenderContextOptions {
|
|
7
|
+
integrations: IntegrationPlugin[];
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* Merges request locals into component props as a dedicated 'locals' property.
|
|
12
|
+
* This prevents naming conflicts and maintains type safety by keeping locals
|
|
13
|
+
* separate from other props.
|
|
14
|
+
*
|
|
15
|
+
* @param props - The original component props
|
|
16
|
+
* @param locals - Optional request-scoped locals from middleware
|
|
17
|
+
* @returns Props with locals merged in, or original props if no locals provided
|
|
18
|
+
*/
|
|
19
|
+
function mergePropsWithLocals<P>(props: P, locals: Record<string, unknown> | undefined): P {
|
|
20
|
+
if (!locals || typeof props !== 'object' || props === null) {
|
|
21
|
+
return props;
|
|
22
|
+
}
|
|
23
|
+
return { ...(props as Record<string, unknown>), locals } as P;
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
/**
|
|
27
|
+
* Creates a render context for route handlers.
|
|
28
|
+
* Provides render(), renderPartial(), json(), and html() methods that can be used
|
|
29
|
+
* within route handlers to generate responses.
|
|
30
|
+
*
|
|
31
|
+
* @param options - Configuration options including available integrations
|
|
32
|
+
* @returns A RenderContext object with methods for rendering views and creating responses
|
|
33
|
+
*/
|
|
34
|
+
export function createRenderContext(options: CreateRenderContextOptions): RenderContext {
|
|
35
|
+
const { integrations } = options;
|
|
36
|
+
|
|
37
|
+
/**
|
|
38
|
+
* Resolves the appropriate renderer for a given view component based on its integration.
|
|
39
|
+
* Throws an error if the integration cannot be determined or is not found.
|
|
40
|
+
*/
|
|
41
|
+
const getRendererForView = <P>(view: EcoComponent<P>): IntegrationRenderer => {
|
|
42
|
+
const integrationName = view.config?.integration ?? view.config?.__eco?.integration;
|
|
43
|
+
invariant(
|
|
44
|
+
!!integrationName,
|
|
45
|
+
'Cannot determine integration for view. Set view.config.integration explicitly or ensure the view is defined with eco.page() in a file with a recognized extension.',
|
|
46
|
+
);
|
|
47
|
+
|
|
48
|
+
const integration = integrations.find((i) => i.name === integrationName);
|
|
49
|
+
invariant(!!integration, `No integration found for: ${integrationName}`);
|
|
50
|
+
|
|
51
|
+
return integration.initializeRenderer();
|
|
52
|
+
};
|
|
53
|
+
|
|
54
|
+
return {
|
|
55
|
+
async render<P>(view: EcoComponent<P>, props: P, renderOptions?: RenderOptions): Promise<Response> {
|
|
56
|
+
const locals = (this as { locals?: Record<string, unknown> } | undefined)?.locals;
|
|
57
|
+
const mergedProps = mergePropsWithLocals(props, locals);
|
|
58
|
+
|
|
59
|
+
const renderer = getRendererForView(view);
|
|
60
|
+
const ctx: RenderToResponseContext = {
|
|
61
|
+
partial: false,
|
|
62
|
+
status: renderOptions?.status,
|
|
63
|
+
headers: renderOptions?.headers,
|
|
64
|
+
};
|
|
65
|
+
return renderer.renderToResponse(view, mergedProps, ctx);
|
|
66
|
+
},
|
|
67
|
+
|
|
68
|
+
async renderPartial<P>(view: EcoComponent<P>, props: P, renderOptions?: RenderOptions): Promise<Response> {
|
|
69
|
+
const locals = (this as { locals?: Record<string, unknown> } | undefined)?.locals;
|
|
70
|
+
const mergedProps = mergePropsWithLocals(props, locals);
|
|
71
|
+
|
|
72
|
+
const renderer = getRendererForView(view);
|
|
73
|
+
const ctx: RenderToResponseContext = {
|
|
74
|
+
partial: true,
|
|
75
|
+
status: renderOptions?.status,
|
|
76
|
+
headers: renderOptions?.headers,
|
|
77
|
+
};
|
|
78
|
+
return renderer.renderToResponse(view, mergedProps, ctx);
|
|
79
|
+
},
|
|
80
|
+
|
|
81
|
+
json(data: unknown, responseOptions?: ResponseOptions): Response {
|
|
82
|
+
const headers = new Headers({ 'Content-Type': 'application/json; charset=utf-8' });
|
|
83
|
+
if (responseOptions?.headers) {
|
|
84
|
+
const incomingHeaders = new Headers(responseOptions.headers);
|
|
85
|
+
incomingHeaders.forEach((value, key) => headers.set(key, value));
|
|
86
|
+
}
|
|
87
|
+
return new Response(JSON.stringify(data), {
|
|
88
|
+
status: responseOptions?.status ?? 200,
|
|
89
|
+
headers,
|
|
90
|
+
});
|
|
91
|
+
},
|
|
92
|
+
|
|
93
|
+
html(content: string, responseOptions?: ResponseOptions): Response {
|
|
94
|
+
const headers = new Headers({ 'Content-Type': 'text/html; charset=utf-8' });
|
|
95
|
+
if (responseOptions?.headers) {
|
|
96
|
+
const incomingHeaders = new Headers(responseOptions.headers);
|
|
97
|
+
incomingHeaders.forEach((value, key) => headers.set(key, value));
|
|
98
|
+
}
|
|
99
|
+
return new Response(content, {
|
|
100
|
+
status: responseOptions?.status ?? 200,
|
|
101
|
+
headers,
|
|
102
|
+
});
|
|
103
|
+
},
|
|
104
|
+
};
|
|
105
|
+
}
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
import { AbstractServerAdapter } from '../abstract/server-adapter.js';
|
|
2
|
+
import type { ServerAdapterOptions, ServerAdapterResult } from '../abstract/server-adapter.js';
|
|
3
|
+
import { RouteRendererFactory } from '../../route-renderer/route-renderer.js';
|
|
4
|
+
import { FSRouter } from '../../router/fs-router.js';
|
|
5
|
+
import { SchemaValidationService } from '../../services/schema-validation-service.js';
|
|
6
|
+
import { StaticSiteGenerator } from '../../static-site-generator/static-site-generator.js';
|
|
7
|
+
import { ServerStaticBuilder } from './server-static-builder.js';
|
|
8
|
+
import { FileSystemResponseMatcher } from './fs-server-response-matcher.js';
|
|
9
|
+
import { ServerRouteHandler } from './server-route-handler.js';
|
|
10
|
+
import type { ApiHandler, CacheInvalidator, ErrorHandler, RenderContext, StaticRoute } from '../../public-types.js';
|
|
11
|
+
export declare abstract class SharedServerAdapter<TOptions extends ServerAdapterOptions, TResult extends ServerAdapterResult> extends AbstractServerAdapter<TOptions, TResult> {
|
|
12
|
+
protected router: FSRouter;
|
|
13
|
+
protected fileSystemResponseMatcher: FileSystemResponseMatcher;
|
|
14
|
+
protected routeRendererFactory: RouteRendererFactory;
|
|
15
|
+
protected routeHandler: ServerRouteHandler;
|
|
16
|
+
protected staticSiteGenerator: StaticSiteGenerator;
|
|
17
|
+
protected staticBuilder: ServerStaticBuilder;
|
|
18
|
+
protected readonly schemaValidator: SchemaValidationService;
|
|
19
|
+
/**
|
|
20
|
+
* Scans the filesystem and dynamically constructs the universal router map.
|
|
21
|
+
*
|
|
22
|
+
* This process runs identically across both Bun and Node wrappers. It analyzes the configured pages
|
|
23
|
+
* directory, building a map of all available UI routes and API endpoints.
|
|
24
|
+
* The resulting `FSRouter` instance becomes the central nervous system for mapping WinterCG incoming
|
|
25
|
+
* Web Requests (`Request`) to their corresponding internal execution paths.
|
|
26
|
+
*/
|
|
27
|
+
protected initSharedRouter(): Promise<void>;
|
|
28
|
+
/**
|
|
29
|
+
* Sets up the unified rendering pipeline and response matching chain.
|
|
30
|
+
*
|
|
31
|
+
* It bridges several sub-systems together so that when an incoming request is received, the adapter knows:
|
|
32
|
+
* 1. How to render React/Lit pages via `RouteRendererFactory`
|
|
33
|
+
* 2. How to match logical routes to physical filesystem artifacts via `FileSystemResponseMatcher`
|
|
34
|
+
* 3. Whether to serve the response from the embedded `PageCacheService` or generate it fresh on the fly.
|
|
35
|
+
*
|
|
36
|
+
* Because `HmrManager` implementations rely heavily on runtime-specific WebSocket APIs (e.g. Bun.serve Websockets vs Node WS),
|
|
37
|
+
* we leave it untyped (`any`) here at the common denominator core.
|
|
38
|
+
*
|
|
39
|
+
* @param staticRoutes - A map of explicitly served static assets.
|
|
40
|
+
* @param hmrManager - The runtime-specific Hot Module Replacement orchestrator (if watching).
|
|
41
|
+
*/
|
|
42
|
+
protected configureSharedResponseHandlers(staticRoutes: StaticRoute[], hmrManager?: any): void;
|
|
43
|
+
protected getCacheService(): CacheInvalidator | null;
|
|
44
|
+
protected getRenderContext(): RenderContext;
|
|
45
|
+
/**
|
|
46
|
+
* Executes an Application Programming Interface (API) handler in an environment-agnostic manner.
|
|
47
|
+
*
|
|
48
|
+
* API routes in Ecopages are universally written using standard WinterCG `Request` and `Response` objects.
|
|
49
|
+
* This execution pipeline takes the raw `Request`, extracts its dynamic segments, runs our high-speed JSON schema
|
|
50
|
+
* validator against the body/query/headers, and triggers the developer's middleware chain sequentially.
|
|
51
|
+
*
|
|
52
|
+
* If the execution throws an error, it is gracefully caught, logged, and mutated into a standardized Http error payload,
|
|
53
|
+
* ensuring the consuming client receives a parsable response even upon internal catastrophic failure.
|
|
54
|
+
*
|
|
55
|
+
* @param request - The incoming Web standard `Request`.
|
|
56
|
+
* @param params - The extracted dynamic URL parameters (e.g., `{ id: '123' }`).
|
|
57
|
+
* @param routeConfig - The user-defined API handler object containing their business logic (`handler`) and `middleware`.
|
|
58
|
+
* @param serverInstance - Untyped reference to the underlying native server instance (BunServer/NodeServer) for potential escape hatches.
|
|
59
|
+
* @param errorHandler - Optional global error trap defined in project configuration.
|
|
60
|
+
* @returns The resulting Web standard `Response` constructed by the user's handler.
|
|
61
|
+
*/
|
|
62
|
+
protected executeApiHandler(request: Request, params: Record<string, string | string[]>, routeConfig: ApiHandler, serverInstance: any, errorHandler?: ErrorHandler): Promise<Response>;
|
|
63
|
+
private normalizePath;
|
|
64
|
+
private matchApiPath;
|
|
65
|
+
private getApiPathScore;
|
|
66
|
+
protected matchApiHandler(request: Request, apiHandlers: ApiHandler[]): {
|
|
67
|
+
routeConfig: ApiHandler;
|
|
68
|
+
params: Record<string, string | string[]>;
|
|
69
|
+
} | null;
|
|
70
|
+
/**
|
|
71
|
+
* Universally processes an incoming WinterCG Web standard Request.
|
|
72
|
+
*
|
|
73
|
+
* 1. Resolves static Hot Module Replacement runtime blobs if development.
|
|
74
|
+
* 2. Checks if the incoming request matches any parsed API route schemas.
|
|
75
|
+
* - Routes through `executeApiHandler` which performs strict validation.
|
|
76
|
+
* 3. Falls through to standard `ServerRouteHandler` for React/Lit filesystem pages.
|
|
77
|
+
*
|
|
78
|
+
* Both Bun and Node bindings fall back to this exact function once they have mapped their
|
|
79
|
+
* native HTTP objects into Web Standard Requests.
|
|
80
|
+
*/
|
|
81
|
+
handleSharedRequest(request: Request, context: {
|
|
82
|
+
apiHandlers: ApiHandler[];
|
|
83
|
+
errorHandler?: ErrorHandler;
|
|
84
|
+
serverInstance?: any;
|
|
85
|
+
hmrManager?: any;
|
|
86
|
+
}): Promise<Response>;
|
|
87
|
+
}
|