@ecopages/core 0.2.0-alpha.1 → 0.2.0-alpha.11
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 +16 -64
- package/README.md +210 -13
- package/package.json +88 -62
- package/src/adapters/README.md +39 -0
- package/src/adapters/abstract/application-adapter.d.ts +28 -2
- package/src/adapters/abstract/application-adapter.js +14 -2
- package/src/adapters/abstract/router-adapter.d.ts +1 -1
- package/src/adapters/abstract/server-adapter.d.ts +2 -2
- package/src/adapters/bun/client-bridge.d.ts +1 -1
- package/src/adapters/bun/create-app.d.ts +4 -12
- package/src/adapters/bun/create-app.js +4 -5
- package/src/adapters/bun/hmr-manager.d.ts +80 -21
- package/src/adapters/bun/hmr-manager.js +163 -56
- package/src/adapters/bun/index.d.ts +2 -3
- package/src/adapters/bun/index.js +3 -3
- package/src/adapters/bun/server-adapter.d.ts +5 -5
- package/src/adapters/bun/server-adapter.js +40 -34
- package/src/adapters/bun/server-lifecycle.d.ts +28 -17
- package/src/adapters/bun/server-lifecycle.js +34 -62
- package/src/{create-app.d.ts → adapters/create-app.d.ts} +9 -6
- package/src/{create-app.js → adapters/create-app.js} +4 -4
- package/src/adapters/index.d.ts +2 -6
- package/src/adapters/index.js +2 -8
- package/src/adapters/node/create-app.d.ts +6 -9
- package/src/adapters/node/create-app.js +12 -6
- package/src/adapters/node/node-client-bridge.d.ts +1 -1
- package/src/adapters/node/node-hmr-manager.d.ts +89 -18
- package/src/adapters/node/node-hmr-manager.js +180 -89
- package/src/adapters/node/server-adapter.d.ts +4 -33
- package/src/adapters/node/server-adapter.js +39 -100
- package/src/adapters/node/static-content-server.d.ts +37 -1
- package/src/adapters/node/static-content-server.js +29 -1
- package/src/adapters/shared/application-adapter.d.ts +1 -1
- package/src/{define-api-handler.d.ts → adapters/shared/define-api-handler.d.ts} +1 -1
- package/src/adapters/shared/explicit-static-route-matcher.d.ts +2 -2
- package/src/adapters/shared/explicit-static-route-matcher.js +4 -1
- package/src/adapters/shared/file-route-middleware-pipeline.d.ts +1 -1
- package/src/adapters/shared/file-route-middleware-pipeline.js +1 -0
- package/src/adapters/shared/fs-server-response-factory.d.ts +2 -2
- package/src/adapters/shared/fs-server-response-factory.js +1 -1
- package/src/adapters/shared/fs-server-response-matcher.d.ts +9 -5
- package/src/adapters/shared/fs-server-response-matcher.js +13 -8
- package/src/adapters/shared/hmr-entrypoint-registrar.d.ts +55 -0
- package/src/adapters/shared/hmr-entrypoint-registrar.js +87 -0
- package/src/adapters/shared/hmr-html-response.d.ts +22 -0
- package/src/adapters/shared/hmr-html-response.js +32 -0
- package/src/adapters/shared/render-context.d.ts +2 -1
- package/src/adapters/shared/render-context.js +6 -3
- package/src/adapters/shared/runtime-bootstrap.d.ts +38 -0
- package/src/adapters/shared/runtime-bootstrap.js +43 -0
- package/src/adapters/shared/server-adapter.d.ts +13 -3
- package/src/adapters/shared/server-adapter.js +42 -5
- package/src/adapters/shared/server-route-handler.d.ts +4 -4
- package/src/adapters/shared/server-route-handler.js +6 -15
- package/src/adapters/shared/server-static-builder.d.ts +38 -6
- package/src/adapters/shared/server-static-builder.js +64 -10
- package/src/build/README.md +107 -0
- package/src/build/build-adapter.d.ts +160 -3
- package/src/build/build-adapter.js +494 -16
- package/src/build/build-manifest.d.ts +27 -0
- package/src/build/build-manifest.js +30 -0
- package/src/build/dev-build-coordinator.d.ts +72 -0
- package/src/build/dev-build-coordinator.js +154 -0
- package/src/build/esbuild-build-adapter.d.ts +15 -6
- package/src/build/esbuild-build-adapter.js +189 -74
- package/src/build/runtime-build-executor.d.ts +14 -0
- package/src/build/runtime-build-executor.js +22 -0
- package/src/build/runtime-specifier-alias-plugin.d.ts +15 -0
- package/src/build/runtime-specifier-alias-plugin.js +35 -0
- package/src/build/runtime-specifier-aliases.d.ts +5 -0
- package/src/build/runtime-specifier-aliases.js +95 -0
- package/src/config/README.md +36 -0
- package/src/config/config-builder.d.ts +52 -18
- package/src/config/config-builder.js +258 -48
- package/src/{constants.d.ts → config/constants.d.ts} +13 -0
- package/src/{constants.js → config/constants.js} +4 -0
- package/src/declarations.d.ts +19 -14
- package/src/dev/sc-server.d.ts +1 -1
- package/src/dev/sc-server.js +1 -1
- package/src/eco/README.md +70 -16
- package/src/eco/component-render-context.d.ts +2 -2
- package/src/eco/component-render-context.js +33 -16
- package/src/eco/eco.browser.d.ts +2 -0
- package/src/eco/eco.browser.js +83 -0
- package/src/eco/eco.js +91 -16
- package/src/eco/eco.types.d.ts +12 -4
- package/src/eco/eco.utils.d.ts +1 -1
- package/src/eco/global-injector-map.d.ts +1 -1
- package/src/eco/lazy-injector-map.d.ts +1 -1
- package/src/hmr/README.md +26 -0
- package/src/hmr/client/hmr-runtime.d.ts +1 -6
- package/src/hmr/client/hmr-runtime.js +30 -7
- package/src/hmr/hmr-strategy.d.ts +8 -7
- package/src/hmr/hmr-strategy.js +22 -7
- package/src/hmr/hmr.postcss.test.e2e.d.ts +1 -0
- package/src/hmr/hmr.postcss.test.e2e.js +31 -0
- package/src/hmr/hmr.test.e2e.js +26 -33
- package/src/hmr/strategies/default-hmr-strategy.d.ts +2 -2
- package/src/hmr/strategies/default-hmr-strategy.js +1 -1
- package/src/hmr/strategies/js-hmr-strategy.d.ts +46 -43
- package/src/hmr/strategies/js-hmr-strategy.js +72 -73
- package/src/index.browser.d.ts +2 -2
- package/src/index.browser.js +1 -1
- package/src/index.d.ts +4 -3
- package/src/index.js +16 -5
- package/src/integrations/ghtml/ghtml-renderer.d.ts +2 -2
- package/src/integrations/ghtml/ghtml-renderer.js +3 -1
- package/src/integrations/ghtml/ghtml.plugin.d.ts +2 -2
- package/src/integrations/ghtml/ghtml.plugin.js +2 -2
- package/src/plugins/README.md +35 -0
- package/src/plugins/alias-resolver-plugin.js +17 -3
- package/src/plugins/eco-component-meta-plugin.d.ts +14 -1
- package/src/plugins/eco-component-meta-plugin.js +27 -21
- package/src/plugins/integration-plugin.d.ts +48 -9
- package/src/plugins/integration-plugin.js +39 -2
- package/src/plugins/processor.d.ts +15 -2
- package/src/plugins/processor.js +16 -2
- package/src/plugins/runtime-capability.d.ts +9 -0
- package/src/plugins/source-transform.d.ts +46 -0
- package/src/plugins/source-transform.js +71 -0
- package/src/route-renderer/GRAPH.md +18 -22
- package/src/route-renderer/README.md +15 -26
- package/src/route-renderer/{component-graph-executor.d.ts → component-graph/component-graph-executor.d.ts} +3 -2
- package/src/route-renderer/{component-graph-executor.js → component-graph/component-graph-executor.js} +2 -3
- package/src/route-renderer/{component-graph.d.ts → component-graph/component-graph.d.ts} +13 -2
- package/src/route-renderer/{component-graph.js → component-graph/component-graph.js} +26 -4
- package/src/route-renderer/component-graph/component-reference.d.ts +11 -0
- package/src/route-renderer/component-graph/component-reference.js +39 -0
- package/src/route-renderer/{marker-graph-resolver.d.ts → component-graph/marker-graph-resolver.d.ts} +9 -6
- package/src/route-renderer/{marker-graph-resolver.js → component-graph/marker-graph-resolver.js} +36 -12
- package/src/route-renderer/{integration-renderer.d.ts → orchestration/integration-renderer.d.ts} +65 -13
- package/src/route-renderer/{integration-renderer.js → orchestration/integration-renderer.js} +206 -30
- package/src/route-renderer/{render-execution.service.d.ts → orchestration/render-execution.service.d.ts} +42 -6
- package/src/route-renderer/orchestration/render-execution.service.js +191 -0
- package/src/route-renderer/{render-preparation.service.d.ts → orchestration/render-preparation.service.d.ts} +13 -4
- package/src/route-renderer/{render-preparation.service.js → orchestration/render-preparation.service.js} +95 -5
- package/src/route-renderer/{dependency-resolver.d.ts → page-loading/dependency-resolver.d.ts} +15 -4
- package/src/route-renderer/{dependency-resolver.js → page-loading/dependency-resolver.js} +18 -4
- package/src/route-renderer/page-loading/page-module-loader.d.ts +89 -0
- package/src/route-renderer/{page-module-loader.js → page-loading/page-module-loader.js} +38 -14
- package/src/route-renderer/route-renderer.d.ts +41 -4
- package/src/route-renderer/route-renderer.js +32 -3
- package/src/router/README.md +97 -0
- package/src/router/client/link-intent.d.ts +53 -0
- package/src/router/client/link-intent.js +34 -0
- package/src/router/client/link-intent.test.browser.d.ts +1 -0
- package/src/router/client/link-intent.test.browser.js +43 -0
- package/src/router/client/navigation-coordinator.d.ts +149 -0
- package/src/router/client/navigation-coordinator.js +215 -0
- package/src/router/{fs-router-scanner.d.ts → server/fs-router-scanner.d.ts} +3 -3
- package/src/router/{fs-router-scanner.js → server/fs-router-scanner.js} +8 -7
- package/src/router/{fs-router.d.ts → server/fs-router.d.ts} +1 -1
- package/src/router/{fs-router.js → server/fs-router.js} +1 -1
- package/src/services/README.md +29 -0
- package/src/services/assets/asset-processing-service/asset-processing.service.d.ts +120 -0
- package/src/services/{asset-processing-service → assets/asset-processing-service}/asset-processing.service.js +91 -10
- package/src/services/{asset-processing-service → assets/asset-processing-service}/asset.factory.d.ts +1 -1
- package/src/services/{asset-processing-service → assets/asset-processing-service}/asset.factory.js +2 -2
- package/src/services/{asset-processing-service → assets/asset-processing-service}/assets.types.d.ts +2 -1
- package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.d.ts +55 -0
- package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.js +48 -0
- package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.d.ts +20 -0
- package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.js +41 -0
- package/src/services/assets/asset-processing-service/index.d.ts +5 -0
- package/src/services/assets/asset-processing-service/index.js +5 -0
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.interface.d.ts +2 -2
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.registry.d.ts +2 -2
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/base/base-processor.d.ts +1 -1
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/base/base-processor.js +9 -4
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/base/base-script-processor.d.ts +5 -4
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/base/base-script-processor.js +15 -23
- package/src/services/assets/asset-processing-service/processors/index.d.ts +5 -0
- package/src/services/assets/asset-processing-service/processors/index.js +5 -0
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/content-script.processor.d.ts +2 -2
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/content-script.processor.js +1 -1
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/file-script.processor.d.ts +4 -3
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/file-script.processor.js +16 -4
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/node-module-script.processor.d.ts +3 -3
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/node-module-script.processor.js +6 -5
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/content-stylesheet.processor.d.ts +2 -2
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/content-stylesheet.processor.js +1 -1
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/file-stylesheet.processor.d.ts +2 -2
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/file-stylesheet.processor.js +5 -2
- package/src/services/assets/browser-bundle.service.d.ts +32 -0
- package/src/services/assets/browser-bundle.service.js +33 -0
- package/src/services/{page-request-cache-coordinator.service.d.ts → cache/page-request-cache-coordinator.service.d.ts} +2 -2
- package/src/services/{page-request-cache-coordinator.service.js → cache/page-request-cache-coordinator.service.js} +3 -1
- package/src/services/html/html-rewriter-provider.service.d.ts +37 -0
- package/src/services/html/html-rewriter-provider.service.js +68 -0
- package/src/services/html/html-transformer.service.d.ts +77 -0
- package/src/services/html/html-transformer.service.js +215 -0
- package/src/services/invalidation/development-invalidation.service.d.ts +74 -0
- package/src/services/invalidation/development-invalidation.service.js +190 -0
- package/src/services/module-loading/app-module-loader.service.d.ts +25 -0
- package/src/services/module-loading/app-module-loader.service.js +31 -0
- package/src/services/module-loading/app-server-module-transpiler.service.d.ts +24 -0
- package/src/services/module-loading/app-server-module-transpiler.service.js +109 -0
- package/src/services/module-loading/host-module-loader-registry.d.ts +4 -0
- package/src/services/module-loading/host-module-loader-registry.js +15 -0
- package/src/services/module-loading/module-loading-types.d.ts +2 -0
- package/src/services/module-loading/node-bootstrap-plugin.d.ts +22 -0
- package/src/services/module-loading/node-bootstrap-plugin.js +179 -0
- package/src/services/module-loading/page-module-import.service.d.ts +75 -0
- package/src/services/module-loading/page-module-import.service.js +161 -0
- package/src/services/module-loading/server-module-transpiler.service.d.ts +72 -0
- package/src/services/module-loading/server-module-transpiler.service.js +64 -0
- package/src/services/runtime-state/dev-graph.service.d.ts +118 -0
- package/src/services/runtime-state/dev-graph.service.js +162 -0
- package/src/services/runtime-state/entrypoint-dependency-graph.service.d.ts +41 -0
- package/src/services/runtime-state/entrypoint-dependency-graph.service.js +85 -0
- package/src/services/runtime-state/runtime-specifier-registry.service.d.ts +69 -0
- package/src/services/runtime-state/runtime-specifier-registry.service.js +37 -0
- package/src/services/runtime-state/server-invalidation-state.service.d.ts +26 -0
- package/src/services/runtime-state/server-invalidation-state.service.js +35 -0
- package/src/services/{schema-validation-service.d.ts → validation/schema-validation-service.d.ts} +1 -1
- package/src/static-site-generator/README.md +26 -0
- package/src/static-site-generator/static-site-generator.d.ts +55 -3
- package/src/static-site-generator/static-site-generator.js +86 -5
- package/src/{internal-types.d.ts → types/internal-types.d.ts} +53 -22
- package/src/types/internal-types.js +0 -0
- package/src/{public-types.d.ts → types/public-types.d.ts} +73 -17
- package/src/types/public-types.js +0 -0
- package/src/utils/locals-utils.d.ts +1 -1
- package/src/utils/parse-cli-args.d.ts +4 -1
- package/src/utils/parse-cli-args.js +16 -1
- package/src/utils/resolve-work-dir.d.ts +11 -0
- package/src/utils/resolve-work-dir.js +31 -0
- package/src/watchers/project-watcher.d.ts +40 -24
- package/src/watchers/project-watcher.js +105 -68
- package/src/watchers/project-watcher.test-helpers.d.ts +2 -2
- package/src/watchers/project-watcher.test-helpers.js +1 -0
- package/src/adapters/abstract/application-adapter.ts +0 -337
- package/src/adapters/abstract/router-adapter.ts +0 -30
- package/src/adapters/abstract/server-adapter.ts +0 -79
- package/src/adapters/bun/client-bridge.ts +0 -62
- package/src/adapters/bun/create-app.ts +0 -189
- package/src/adapters/bun/define-api-handler.d.ts +0 -61
- package/src/adapters/bun/define-api-handler.ts +0 -114
- package/src/adapters/bun/hmr-manager.ts +0 -281
- package/src/adapters/bun/index.ts +0 -3
- package/src/adapters/bun/server-adapter.ts +0 -492
- package/src/adapters/bun/server-lifecycle.ts +0 -154
- package/src/adapters/index.ts +0 -6
- package/src/adapters/node/create-app.ts +0 -179
- package/src/adapters/node/index.d.ts +0 -4
- package/src/adapters/node/index.js +0 -8
- package/src/adapters/node/index.ts +0 -9
- package/src/adapters/node/node-client-bridge.ts +0 -79
- package/src/adapters/node/node-hmr-manager.ts +0 -271
- package/src/adapters/node/server-adapter.ts +0 -561
- package/src/adapters/node/static-content-server.ts +0 -203
- package/src/adapters/shared/api-response.ts +0 -104
- package/src/adapters/shared/application-adapter.ts +0 -199
- package/src/adapters/shared/explicit-static-route-matcher.ts +0 -134
- package/src/adapters/shared/file-route-middleware-pipeline.ts +0 -123
- package/src/adapters/shared/fs-server-response-factory.ts +0 -118
- package/src/adapters/shared/fs-server-response-matcher.ts +0 -198
- package/src/adapters/shared/render-context.ts +0 -105
- package/src/adapters/shared/server-adapter.ts +0 -442
- package/src/adapters/shared/server-route-handler.ts +0 -166
- package/src/adapters/shared/server-static-builder.ts +0 -82
- package/src/build/build-adapter.ts +0 -132
- package/src/build/build-types.ts +0 -83
- package/src/build/esbuild-build-adapter.ts +0 -510
- package/src/config/config-builder.ts +0 -474
- package/src/constants.ts +0 -39
- package/src/create-app.ts +0 -87
- package/src/define-api-handler.js +0 -15
- package/src/define-api-handler.ts +0 -66
- package/src/dev/sc-server.ts +0 -143
- package/src/eco/component-render-context.ts +0 -202
- package/src/eco/eco.ts +0 -221
- package/src/eco/eco.types.ts +0 -202
- package/src/eco/eco.utils.ts +0 -89
- package/src/eco/global-injector-map.ts +0 -112
- package/src/eco/lazy-injector-map.ts +0 -120
- package/src/eco/module-dependencies.ts +0 -75
- package/src/errors/http-error.ts +0 -72
- package/src/errors/index.ts +0 -2
- package/src/errors/locals-access-error.ts +0 -7
- package/src/global/app-logger.ts +0 -4
- 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.ts +0 -121
- package/src/hmr/hmr-strategy.ts +0 -172
- package/src/hmr/hmr.test.e2e.ts +0 -75
- package/src/hmr/strategies/default-hmr-strategy.ts +0 -60
- package/src/hmr/strategies/js-hmr-strategy.ts +0 -308
- package/src/index.browser.ts +0 -3
- package/src/index.ts +0 -5
- package/src/integrations/ghtml/ghtml-renderer.ts +0 -93
- package/src/integrations/ghtml/ghtml.plugin.ts +0 -32
- package/src/internal-types.ts +0 -212
- package/src/plugins/alias-resolver-plugin.ts +0 -45
- package/src/plugins/eco-component-meta-plugin.ts +0 -474
- package/src/plugins/integration-plugin.ts +0 -184
- package/src/plugins/processor.ts +0 -220
- package/src/public-types.ts +0 -1255
- package/src/route-renderer/component-graph-executor.ts +0 -84
- package/src/route-renderer/component-graph.ts +0 -159
- package/src/route-renderer/component-marker.ts +0 -117
- package/src/route-renderer/dependency-resolver.ts +0 -596
- package/src/route-renderer/html-post-processing.service.d.ts +0 -40
- package/src/route-renderer/html-post-processing.service.js +0 -86
- package/src/route-renderer/html-post-processing.service.ts +0 -103
- package/src/route-renderer/integration-renderer.ts +0 -696
- package/src/route-renderer/marker-graph-resolver.ts +0 -153
- package/src/route-renderer/page-module-loader.d.ts +0 -61
- package/src/route-renderer/page-module-loader.ts +0 -153
- package/src/route-renderer/render-execution.service.js +0 -91
- package/src/route-renderer/render-execution.service.ts +0 -158
- package/src/route-renderer/render-preparation.service.ts +0 -358
- package/src/route-renderer/route-renderer.ts +0 -80
- package/src/router/fs-router-scanner.ts +0 -217
- package/src/router/fs-router.ts +0 -122
- package/src/services/asset-processing-service/asset-processing.service.d.ts +0 -41
- package/src/services/asset-processing-service/asset-processing.service.ts +0 -306
- package/src/services/asset-processing-service/asset.factory.ts +0 -105
- package/src/services/asset-processing-service/assets.types.ts +0 -112
- package/src/services/asset-processing-service/index.d.ts +0 -3
- package/src/services/asset-processing-service/index.js +0 -3
- package/src/services/asset-processing-service/index.ts +0 -3
- package/src/services/asset-processing-service/processor.interface.ts +0 -27
- package/src/services/asset-processing-service/processor.registry.ts +0 -18
- package/src/services/asset-processing-service/processors/base/base-processor.ts +0 -76
- package/src/services/asset-processing-service/processors/base/base-script-processor.ts +0 -105
- package/src/services/asset-processing-service/processors/index.d.ts +0 -5
- package/src/services/asset-processing-service/processors/index.js +0 -5
- package/src/services/asset-processing-service/processors/index.ts +0 -5
- package/src/services/asset-processing-service/processors/script/content-script.processor.ts +0 -66
- package/src/services/asset-processing-service/processors/script/file-script.processor.ts +0 -88
- package/src/services/asset-processing-service/processors/script/node-module-script.processor.ts +0 -84
- package/src/services/asset-processing-service/processors/stylesheet/content-stylesheet.processor.ts +0 -27
- package/src/services/asset-processing-service/processors/stylesheet/file-stylesheet.processor.ts +0 -77
- package/src/services/cache/cache.types.ts +0 -126
- package/src/services/cache/index.ts +0 -18
- package/src/services/cache/memory-cache-store.ts +0 -130
- package/src/services/cache/page-cache-service.ts +0 -202
- package/src/services/html-transformer.service.d.ts +0 -50
- package/src/services/html-transformer.service.js +0 -163
- package/src/services/html-transformer.service.ts +0 -217
- package/src/services/page-module-import.service.d.ts +0 -37
- package/src/services/page-module-import.service.js +0 -88
- package/src/services/page-module-import.service.ts +0 -129
- package/src/services/page-request-cache-coordinator.service.ts +0 -128
- package/src/services/schema-validation-service.ts +0 -204
- package/src/services/validation/standard-schema.types.ts +0 -68
- package/src/static-site-generator/static-site-generator.ts +0 -359
- package/src/utils/css.d.ts +0 -1
- package/src/utils/css.js +0 -7
- package/src/utils/css.ts +0 -5
- package/src/utils/deep-merge.ts +0 -47
- package/src/utils/hash.ts +0 -5
- package/src/utils/html.ts +0 -1
- package/src/utils/invariant.ts +0 -15
- package/src/utils/locals-utils.ts +0 -37
- package/src/utils/parse-cli-args.ts +0 -83
- package/src/utils/path-utils.module.ts +0 -14
- package/src/utils/runtime.ts +0 -44
- package/src/utils/server-utils.module.ts +0 -67
- package/src/watchers/project-watcher.test-helpers.ts +0 -40
- package/src/watchers/project-watcher.ts +0 -306
- /package/src/adapters/{bun → shared}/define-api-handler.js +0 -0
- /package/src/{internal-types.js → plugins/runtime-capability.js} +0 -0
- /package/src/route-renderer/{component-marker.d.ts → component-graph/component-marker.d.ts} +0 -0
- /package/src/route-renderer/{component-marker.js → component-graph/component-marker.js} +0 -0
- /package/src/services/{asset-processing-service → assets/asset-processing-service}/assets.types.js +0 -0
- /package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.interface.js +0 -0
- /package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.registry.js +0 -0
- /package/src/{public-types.js → services/module-loading/module-loading-types.js} +0 -0
- /package/src/services/{schema-validation-service.js → validation/schema-validation-service.js} +0 -0
|
@@ -1,203 +0,0 @@
|
|
|
1
|
-
import { createServer, type IncomingMessage, type Server as NodeHttpServer, type ServerResponse } from 'node:http';
|
|
2
|
-
import { extname, join, normalize, sep } from 'node:path';
|
|
3
|
-
import { DEFAULT_ECOPAGES_HOSTNAME, DEFAULT_ECOPAGES_PORT, STATUS_MESSAGE } from '../../constants.ts';
|
|
4
|
-
import { fileSystem } from '@ecopages/file-system';
|
|
5
|
-
import type { EcoPagesAppConfig } from '../../internal-types.ts';
|
|
6
|
-
import { ServerUtils } from '../../utils/server-utils.module.ts';
|
|
7
|
-
|
|
8
|
-
type NodeStaticContentServerOptions = {
|
|
9
|
-
hostname?: string;
|
|
10
|
-
port?: number;
|
|
11
|
-
};
|
|
12
|
-
|
|
13
|
-
export class NodeStaticContentServer {
|
|
14
|
-
private readonly appConfig: EcoPagesAppConfig;
|
|
15
|
-
private readonly options: NodeStaticContentServerOptions;
|
|
16
|
-
private server: NodeHttpServer | null = null;
|
|
17
|
-
|
|
18
|
-
constructor({ appConfig, options }: { appConfig: EcoPagesAppConfig; options?: NodeStaticContentServerOptions }) {
|
|
19
|
-
this.appConfig = appConfig;
|
|
20
|
-
this.options = {
|
|
21
|
-
hostname: options?.hostname ?? DEFAULT_ECOPAGES_HOSTNAME,
|
|
22
|
-
port: options?.port ?? DEFAULT_ECOPAGES_PORT,
|
|
23
|
-
};
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
private shouldServeGzip(contentType: string): boolean {
|
|
27
|
-
return ['text/javascript', 'text/css'].includes(contentType);
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
private sanitizePath(pathname: string): string | null {
|
|
31
|
-
const withoutLeadingSlash = pathname.replace(/^\/+/, '');
|
|
32
|
-
const normalizedPath = normalize(withoutLeadingSlash);
|
|
33
|
-
|
|
34
|
-
if (normalizedPath.startsWith('..') || normalizedPath.includes(`..${sep}`)) {
|
|
35
|
-
return null;
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
return normalizedPath;
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
private sendResponse(res: ServerResponse, status: number, headers: Record<string, string>, body?: Buffer): void {
|
|
42
|
-
res.statusCode = status;
|
|
43
|
-
for (const [key, value] of Object.entries(headers)) {
|
|
44
|
-
res.setHeader(key, value);
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
if (!body) {
|
|
48
|
-
res.end();
|
|
49
|
-
return;
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
res.end(body);
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
private sendNotFoundPage(req: IncomingMessage, res: ServerResponse): void {
|
|
56
|
-
const error404TemplatePath = join(this.appConfig.absolutePaths.distDir, '404.html');
|
|
57
|
-
const isHead = (req.method ?? 'GET').toUpperCase() === 'HEAD';
|
|
58
|
-
|
|
59
|
-
if (!fileSystem.exists(error404TemplatePath)) {
|
|
60
|
-
this.sendResponse(
|
|
61
|
-
res,
|
|
62
|
-
404,
|
|
63
|
-
{ 'Content-Type': 'text/plain' },
|
|
64
|
-
isHead ? undefined : Buffer.from(STATUS_MESSAGE[404]),
|
|
65
|
-
);
|
|
66
|
-
return;
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
const file = fileSystem.readFileAsBuffer(error404TemplatePath);
|
|
70
|
-
this.sendResponse(res, 404, { 'Content-Type': 'text/html' }, isHead ? undefined : file);
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
private serveFile(req: IncomingMessage, res: ServerResponse, filePath: string, status = 200): void {
|
|
74
|
-
const contentType = ServerUtils.getContentType(extname(filePath));
|
|
75
|
-
const acceptsGzip = req.headers['accept-encoding']?.includes('gzip');
|
|
76
|
-
const isHead = (req.method ?? 'GET').toUpperCase() === 'HEAD';
|
|
77
|
-
|
|
78
|
-
if (acceptsGzip && this.shouldServeGzip(contentType)) {
|
|
79
|
-
const gzipPath = `${filePath}.gz`;
|
|
80
|
-
if (fileSystem.exists(gzipPath)) {
|
|
81
|
-
const file = fileSystem.readFileAsBuffer(gzipPath);
|
|
82
|
-
this.sendResponse(
|
|
83
|
-
res,
|
|
84
|
-
status,
|
|
85
|
-
{
|
|
86
|
-
'Content-Type': contentType,
|
|
87
|
-
'Content-Encoding': 'gzip',
|
|
88
|
-
Vary: 'Accept-Encoding',
|
|
89
|
-
},
|
|
90
|
-
isHead ? undefined : file,
|
|
91
|
-
);
|
|
92
|
-
return;
|
|
93
|
-
}
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
if (!fileSystem.exists(filePath)) {
|
|
97
|
-
this.sendNotFoundPage(req, res);
|
|
98
|
-
return;
|
|
99
|
-
}
|
|
100
|
-
|
|
101
|
-
const file = fileSystem.readFileAsBuffer(filePath);
|
|
102
|
-
this.sendResponse(res, status, { 'Content-Type': contentType }, isHead ? undefined : file);
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
private handleRequest(req: IncomingMessage, res: ServerResponse): void {
|
|
106
|
-
const method = (req.method ?? 'GET').toUpperCase();
|
|
107
|
-
const isHead = method === 'HEAD';
|
|
108
|
-
if (method !== 'GET' && method !== 'HEAD') {
|
|
109
|
-
this.sendResponse(
|
|
110
|
-
res,
|
|
111
|
-
405,
|
|
112
|
-
{ Allow: 'GET, HEAD', 'Content-Type': 'text/plain' },
|
|
113
|
-
isHead ? undefined : Buffer.from('Method Not Allowed'),
|
|
114
|
-
);
|
|
115
|
-
return;
|
|
116
|
-
}
|
|
117
|
-
|
|
118
|
-
const url = new URL(req.url ?? '/', 'http://localhost');
|
|
119
|
-
let decodedPathname = '/';
|
|
120
|
-
try {
|
|
121
|
-
decodedPathname = decodeURIComponent(url.pathname);
|
|
122
|
-
} catch {
|
|
123
|
-
this.sendResponse(
|
|
124
|
-
res,
|
|
125
|
-
400,
|
|
126
|
-
{ 'Content-Type': 'text/plain' },
|
|
127
|
-
isHead ? undefined : Buffer.from('Invalid path'),
|
|
128
|
-
);
|
|
129
|
-
return;
|
|
130
|
-
}
|
|
131
|
-
|
|
132
|
-
const pathname = decodedPathname === '/' ? '/index.html' : decodedPathname;
|
|
133
|
-
const relativePath = this.sanitizePath(pathname);
|
|
134
|
-
|
|
135
|
-
if (!relativePath) {
|
|
136
|
-
this.sendResponse(
|
|
137
|
-
res,
|
|
138
|
-
400,
|
|
139
|
-
{ 'Content-Type': 'text/plain' },
|
|
140
|
-
isHead ? undefined : Buffer.from('Invalid path'),
|
|
141
|
-
);
|
|
142
|
-
return;
|
|
143
|
-
}
|
|
144
|
-
|
|
145
|
-
const basePath = join(this.appConfig.absolutePaths.distDir, relativePath);
|
|
146
|
-
|
|
147
|
-
if (pathname.includes('.')) {
|
|
148
|
-
this.serveFile(req, res, basePath);
|
|
149
|
-
return;
|
|
150
|
-
}
|
|
151
|
-
|
|
152
|
-
const htmlCandidates = [`${basePath}.html`, join(basePath, 'index.html')];
|
|
153
|
-
|
|
154
|
-
for (const candidate of htmlCandidates) {
|
|
155
|
-
if (fileSystem.exists(candidate)) {
|
|
156
|
-
this.serveFile(req, res, candidate);
|
|
157
|
-
return;
|
|
158
|
-
}
|
|
159
|
-
}
|
|
160
|
-
|
|
161
|
-
this.sendNotFoundPage(req, res);
|
|
162
|
-
}
|
|
163
|
-
|
|
164
|
-
public async start(): Promise<NodeHttpServer> {
|
|
165
|
-
if (this.server) {
|
|
166
|
-
return this.server;
|
|
167
|
-
}
|
|
168
|
-
|
|
169
|
-
this.server = createServer(this.handleRequest.bind(this));
|
|
170
|
-
const hostname = this.options.hostname ?? DEFAULT_ECOPAGES_HOSTNAME;
|
|
171
|
-
const port = this.options.port ?? DEFAULT_ECOPAGES_PORT;
|
|
172
|
-
|
|
173
|
-
await new Promise<void>((resolve) => {
|
|
174
|
-
this.server!.listen(port, hostname, () => resolve());
|
|
175
|
-
});
|
|
176
|
-
|
|
177
|
-
return this.server;
|
|
178
|
-
}
|
|
179
|
-
|
|
180
|
-
public async stop(force = true): Promise<void> {
|
|
181
|
-
if (!this.server) {
|
|
182
|
-
return;
|
|
183
|
-
}
|
|
184
|
-
|
|
185
|
-
const activeServer = this.server;
|
|
186
|
-
this.server = null;
|
|
187
|
-
|
|
188
|
-
await new Promise<void>((resolve, reject) => {
|
|
189
|
-
activeServer.close((error) => {
|
|
190
|
-
if (error) {
|
|
191
|
-
reject(error);
|
|
192
|
-
return;
|
|
193
|
-
}
|
|
194
|
-
|
|
195
|
-
resolve();
|
|
196
|
-
});
|
|
197
|
-
|
|
198
|
-
if (force) {
|
|
199
|
-
activeServer.closeAllConnections();
|
|
200
|
-
}
|
|
201
|
-
});
|
|
202
|
-
}
|
|
203
|
-
}
|
|
@@ -1,104 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* A builder class for creating Response objects fluently.
|
|
3
|
-
*/
|
|
4
|
-
export class ApiResponseBuilder {
|
|
5
|
-
private _status: Response['status'] = 200;
|
|
6
|
-
private _headers: Headers = new Headers();
|
|
7
|
-
|
|
8
|
-
/**
|
|
9
|
-
* Sets the HTTP status code for the response.
|
|
10
|
-
* @param code - The HTTP status code.
|
|
11
|
-
* @returns The builder instance for chaining.
|
|
12
|
-
*/
|
|
13
|
-
status(code: Response['status']): this {
|
|
14
|
-
this._status = code;
|
|
15
|
-
return this;
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
/**
|
|
19
|
-
* Adds or merges headers for the response.
|
|
20
|
-
* @param headersInit - Headers to add or merge.
|
|
21
|
-
* @returns The builder instance for chaining.
|
|
22
|
-
*/
|
|
23
|
-
headers(headersInit: HeadersInit): this {
|
|
24
|
-
const inputHeaders = new Headers(headersInit);
|
|
25
|
-
inputHeaders.forEach((value, key) => {
|
|
26
|
-
this._headers.set(key, value);
|
|
27
|
-
});
|
|
28
|
-
return this;
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
/**
|
|
32
|
-
* Creates a JSON response using the configured status and headers.
|
|
33
|
-
* @param data - The data to serialize.
|
|
34
|
-
* @returns A Response object.
|
|
35
|
-
*/
|
|
36
|
-
json(data: any): Response {
|
|
37
|
-
if (!this._headers.has('Content-Type')) {
|
|
38
|
-
this._headers.set('Content-Type', 'application/json; charset=utf-8');
|
|
39
|
-
}
|
|
40
|
-
return new Response(JSON.stringify(data), { status: this._status, headers: this._headers });
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
/**
|
|
44
|
-
* Creates a plain text response using the configured status and headers.
|
|
45
|
-
* @param data - The text content.
|
|
46
|
-
* @returns A Response object.
|
|
47
|
-
*/
|
|
48
|
-
text(data: string): Response {
|
|
49
|
-
if (!this._headers.has('Content-Type')) {
|
|
50
|
-
this._headers.set('Content-Type', 'text/plain; charset=utf-8');
|
|
51
|
-
}
|
|
52
|
-
return new Response(data, { status: this._status, headers: this._headers });
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
/**
|
|
56
|
-
* Creates an HTML response using the configured status and headers.
|
|
57
|
-
* @param data - The HTML content.
|
|
58
|
-
* @returns A Response object.
|
|
59
|
-
*/
|
|
60
|
-
html(data: string): Response {
|
|
61
|
-
if (!this._headers.has('Content-Type')) {
|
|
62
|
-
this._headers.set('Content-Type', 'text/html; charset=utf-8');
|
|
63
|
-
}
|
|
64
|
-
return new Response(data, { status: this._status, headers: this._headers });
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
/**
|
|
68
|
-
* Creates a redirect response.
|
|
69
|
-
* @param url - The URL to redirect to.
|
|
70
|
-
* @param explicitStatus - Optional explicit status code (overrides status() if provided). Defaults to 302 if not set via status().
|
|
71
|
-
* @returns A Response object.
|
|
72
|
-
*/
|
|
73
|
-
redirect(url: string, explicitStatus?: Response['status']): Response {
|
|
74
|
-
const redirectStatus = explicitStatus ?? (this._status === 200 ? 302 : this._status); // Default to 302 if status wasn't explicitly set
|
|
75
|
-
this._headers.set('Location', url);
|
|
76
|
-
return new Response(null, { status: redirectStatus, headers: this._headers });
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
/**
|
|
80
|
-
* Creates an error response using the configured status and headers.
|
|
81
|
-
* If data is an object, it's treated as JSON, otherwise as text.
|
|
82
|
-
* @param data - The error data (string or object).
|
|
83
|
-
* @param explicitStatus - Optional explicit status code (overrides status() if provided). Defaults to 500 if not set via status().
|
|
84
|
-
* @returns A Response object.
|
|
85
|
-
*/
|
|
86
|
-
error(data: string | object, explicitStatus?: Response['status']): Response {
|
|
87
|
-
const errorStatus = explicitStatus ?? (this._status === 200 ? 500 : this._status); // Default to 500 if status wasn't explicitly set
|
|
88
|
-
this.status(errorStatus);
|
|
89
|
-
|
|
90
|
-
if (typeof data === 'object' && data !== null) {
|
|
91
|
-
if (!this._headers.has('Content-Type')) {
|
|
92
|
-
this._headers.set('Content-Type', 'application/json; charset=utf-8');
|
|
93
|
-
}
|
|
94
|
-
return new Response(JSON.stringify({ error: data }), {
|
|
95
|
-
status: this._status,
|
|
96
|
-
headers: this._headers,
|
|
97
|
-
});
|
|
98
|
-
}
|
|
99
|
-
if (!this._headers.has('Content-Type')) {
|
|
100
|
-
this._headers.set('Content-Type', 'text/plain; charset=utf-8');
|
|
101
|
-
}
|
|
102
|
-
return new Response(String(data), { status: this._status, headers: this._headers });
|
|
103
|
-
}
|
|
104
|
-
}
|
|
@@ -1,199 +0,0 @@
|
|
|
1
|
-
import type {
|
|
2
|
-
ApiHandler,
|
|
3
|
-
ApiHandlerContext,
|
|
4
|
-
Middleware,
|
|
5
|
-
RouteGroupBuilder,
|
|
6
|
-
RouteOptions,
|
|
7
|
-
RouteSchema,
|
|
8
|
-
} from '../../public-types.ts';
|
|
9
|
-
import {
|
|
10
|
-
AbstractApplicationAdapter,
|
|
11
|
-
type ApplicationAdapterOptions,
|
|
12
|
-
type RouteGroupDefinition,
|
|
13
|
-
type RouteHandler,
|
|
14
|
-
} from '../abstract/application-adapter.ts';
|
|
15
|
-
|
|
16
|
-
export abstract class SharedApplicationAdapter<
|
|
17
|
-
TOptions extends ApplicationAdapterOptions = ApplicationAdapterOptions,
|
|
18
|
-
TServer = any,
|
|
19
|
-
TRequest extends Request = Request,
|
|
20
|
-
> extends AbstractApplicationAdapter<TOptions, TServer, TRequest> {
|
|
21
|
-
protected register<
|
|
22
|
-
P extends string,
|
|
23
|
-
TContext extends ApiHandlerContext<TRequest, TServer> = ApiHandlerContext<TRequest, TServer>,
|
|
24
|
-
>(
|
|
25
|
-
path: P,
|
|
26
|
-
method: ApiHandler['method'],
|
|
27
|
-
handler: RouteHandler<TRequest, TServer, TContext>,
|
|
28
|
-
options?: RouteOptions<TRequest, TServer, TContext>,
|
|
29
|
-
): this {
|
|
30
|
-
return this.addRouteHandler(path, method, handler, options?.middleware, options?.schema);
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
get<P extends string, TContext extends ApiHandlerContext<TRequest, TServer> = ApiHandlerContext<TRequest, TServer>>(
|
|
34
|
-
path: P,
|
|
35
|
-
handler: RouteHandler<TRequest, TServer, TContext>,
|
|
36
|
-
options?: RouteOptions<TRequest, TServer, TContext>,
|
|
37
|
-
): this {
|
|
38
|
-
return this.register(path, 'GET', handler, options);
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
post<
|
|
42
|
-
P extends string,
|
|
43
|
-
TContext extends ApiHandlerContext<TRequest, TServer> = ApiHandlerContext<TRequest, TServer>,
|
|
44
|
-
>(
|
|
45
|
-
path: P,
|
|
46
|
-
handler: RouteHandler<TRequest, TServer, TContext>,
|
|
47
|
-
options?: RouteOptions<TRequest, TServer, TContext>,
|
|
48
|
-
): this {
|
|
49
|
-
return this.register(path, 'POST', handler, options);
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
put<P extends string, TContext extends ApiHandlerContext<TRequest, TServer> = ApiHandlerContext<TRequest, TServer>>(
|
|
53
|
-
path: P,
|
|
54
|
-
handler: RouteHandler<TRequest, TServer, TContext>,
|
|
55
|
-
options?: RouteOptions<TRequest, TServer, TContext>,
|
|
56
|
-
): this {
|
|
57
|
-
return this.register(path, 'PUT', handler, options);
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
delete<
|
|
61
|
-
P extends string,
|
|
62
|
-
TContext extends ApiHandlerContext<TRequest, TServer> = ApiHandlerContext<TRequest, TServer>,
|
|
63
|
-
>(
|
|
64
|
-
path: P,
|
|
65
|
-
handler: RouteHandler<TRequest, TServer, TContext>,
|
|
66
|
-
options?: RouteOptions<TRequest, TServer, TContext>,
|
|
67
|
-
): this {
|
|
68
|
-
return this.register(path, 'DELETE', handler, options);
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
patch<
|
|
72
|
-
P extends string,
|
|
73
|
-
TContext extends ApiHandlerContext<TRequest, TServer> = ApiHandlerContext<TRequest, TServer>,
|
|
74
|
-
>(
|
|
75
|
-
path: P,
|
|
76
|
-
handler: RouteHandler<TRequest, TServer, TContext>,
|
|
77
|
-
options?: RouteOptions<TRequest, TServer, TContext>,
|
|
78
|
-
): this {
|
|
79
|
-
return this.register(path, 'PATCH', handler, options);
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
options<
|
|
83
|
-
P extends string,
|
|
84
|
-
TContext extends ApiHandlerContext<TRequest, TServer> = ApiHandlerContext<TRequest, TServer>,
|
|
85
|
-
>(
|
|
86
|
-
path: P,
|
|
87
|
-
handler: RouteHandler<TRequest, TServer, TContext>,
|
|
88
|
-
options?: RouteOptions<TRequest, TServer, TContext>,
|
|
89
|
-
): this {
|
|
90
|
-
return this.register(path, 'OPTIONS', handler, options);
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
head<
|
|
94
|
-
P extends string,
|
|
95
|
-
TContext extends ApiHandlerContext<TRequest, TServer> = ApiHandlerContext<TRequest, TServer>,
|
|
96
|
-
>(
|
|
97
|
-
path: P,
|
|
98
|
-
handler: RouteHandler<TRequest, TServer, TContext>,
|
|
99
|
-
options?: RouteOptions<TRequest, TServer, TContext>,
|
|
100
|
-
): this {
|
|
101
|
-
return this.register(path, 'HEAD', handler, options);
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
route<P extends string>(
|
|
105
|
-
path: P,
|
|
106
|
-
method: ApiHandler['method'],
|
|
107
|
-
handler: RouteHandler<TRequest, TServer>,
|
|
108
|
-
options?: RouteOptions<TRequest, TServer>,
|
|
109
|
-
): this {
|
|
110
|
-
return this.register(path, method, handler, options);
|
|
111
|
-
}
|
|
112
|
-
|
|
113
|
-
add(handler: ApiHandler<string, TRequest, TServer>): this {
|
|
114
|
-
return this.addRouteHandler(handler.path, handler.method, handler.handler, handler.middleware, handler.schema);
|
|
115
|
-
}
|
|
116
|
-
|
|
117
|
-
group<TMiddleware extends readonly Middleware<TRequest, TServer, any>[] = []>(
|
|
118
|
-
prefixOrGroup: string | RouteGroupDefinition<TRequest, TServer>,
|
|
119
|
-
callback?: (
|
|
120
|
-
builder: TMiddleware extends readonly Middleware<TRequest, TServer, infer TContext>[]
|
|
121
|
-
? RouteGroupBuilder<TRequest, TServer, TContext>
|
|
122
|
-
: RouteGroupBuilder<TRequest, TServer>,
|
|
123
|
-
) => void,
|
|
124
|
-
options?: {
|
|
125
|
-
middleware?: TMiddleware;
|
|
126
|
-
},
|
|
127
|
-
): this {
|
|
128
|
-
if (typeof prefixOrGroup === 'object') {
|
|
129
|
-
return this.registerGroup(prefixOrGroup);
|
|
130
|
-
}
|
|
131
|
-
|
|
132
|
-
type TContext = TMiddleware extends readonly Middleware<TRequest, TServer, infer TCtx>[]
|
|
133
|
-
? TCtx
|
|
134
|
-
: ApiHandlerContext<TRequest, TServer>;
|
|
135
|
-
|
|
136
|
-
const normalizedPrefix = prefixOrGroup.endsWith('/') ? prefixOrGroup.slice(0, -1) : prefixOrGroup;
|
|
137
|
-
const groupMiddleware = (options?.middleware ?? []) as Middleware<TRequest, TServer, TContext>[];
|
|
138
|
-
|
|
139
|
-
const createHandler = (
|
|
140
|
-
method: ApiHandler['method'],
|
|
141
|
-
): RouteGroupBuilder<TRequest, TServer, TContext>[Lowercase<typeof method>] => {
|
|
142
|
-
return ((
|
|
143
|
-
path: string,
|
|
144
|
-
handler: (context: TContext) => Promise<Response> | Response,
|
|
145
|
-
routeOptions?: RouteOptions<TRequest, TServer, TContext> & { schema?: RouteSchema },
|
|
146
|
-
) => {
|
|
147
|
-
const combinedMiddleware: Middleware<TRequest, TServer, TContext>[] = [
|
|
148
|
-
...groupMiddleware,
|
|
149
|
-
...(routeOptions?.middleware ?? []),
|
|
150
|
-
];
|
|
151
|
-
const fullPath = path === '/' ? normalizedPrefix : `${normalizedPrefix}${path}`;
|
|
152
|
-
this.addRouteHandler(
|
|
153
|
-
fullPath,
|
|
154
|
-
method,
|
|
155
|
-
handler as RouteHandler<TRequest, TServer, ApiHandlerContext<TRequest, TServer>>,
|
|
156
|
-
combinedMiddleware.length > 0
|
|
157
|
-
? (combinedMiddleware as Middleware<TRequest, TServer, ApiHandlerContext<TRequest, TServer>>[])
|
|
158
|
-
: undefined,
|
|
159
|
-
routeOptions?.schema,
|
|
160
|
-
);
|
|
161
|
-
return builder;
|
|
162
|
-
}) as RouteGroupBuilder<TRequest, TServer, TContext>[Lowercase<typeof method>];
|
|
163
|
-
};
|
|
164
|
-
|
|
165
|
-
const builder: RouteGroupBuilder<TRequest, TServer, TContext> = {
|
|
166
|
-
get: createHandler('GET'),
|
|
167
|
-
post: createHandler('POST'),
|
|
168
|
-
put: createHandler('PUT'),
|
|
169
|
-
delete: createHandler('DELETE'),
|
|
170
|
-
patch: createHandler('PATCH'),
|
|
171
|
-
options: createHandler('OPTIONS'),
|
|
172
|
-
head: createHandler('HEAD'),
|
|
173
|
-
};
|
|
174
|
-
|
|
175
|
-
callback?.(builder as never);
|
|
176
|
-
return this;
|
|
177
|
-
}
|
|
178
|
-
|
|
179
|
-
private registerGroup(group: RouteGroupDefinition<TRequest, TServer>): this {
|
|
180
|
-
const normalizedPrefix = group.prefix.endsWith('/') ? group.prefix.slice(0, -1) : group.prefix;
|
|
181
|
-
const groupMiddleware = group.middleware ?? [];
|
|
182
|
-
|
|
183
|
-
for (const route of group.routes) {
|
|
184
|
-
const normalizedPath = route.path.startsWith('/') ? route.path : `/${route.path}`;
|
|
185
|
-
const fullPath = route.path === '/' ? normalizedPrefix : `${normalizedPrefix}${normalizedPath}`;
|
|
186
|
-
const combinedMiddleware = [...groupMiddleware, ...(route.middleware ?? [])];
|
|
187
|
-
|
|
188
|
-
this.addRouteHandler(
|
|
189
|
-
fullPath,
|
|
190
|
-
route.method,
|
|
191
|
-
route.handler,
|
|
192
|
-
combinedMiddleware.length > 0 ? combinedMiddleware : undefined,
|
|
193
|
-
route.schema,
|
|
194
|
-
);
|
|
195
|
-
}
|
|
196
|
-
|
|
197
|
-
return this;
|
|
198
|
-
}
|
|
199
|
-
}
|
|
@@ -1,134 +0,0 @@
|
|
|
1
|
-
import { appLogger } from '../../global/app-logger.ts';
|
|
2
|
-
import type { EcoPagesAppConfig } from '../../internal-types.ts';
|
|
3
|
-
import type { StaticRoute } from '../../public-types.ts';
|
|
4
|
-
import type { RouteRendererFactory } from '../../route-renderer/route-renderer.ts';
|
|
5
|
-
|
|
6
|
-
export const EXPLICIT_STATIC_ROUTE_MATCHER_ERRORS = {
|
|
7
|
-
missingIntegration: (routePath: string) =>
|
|
8
|
-
`View at ${routePath} is missing __eco.integration. Ensure it's defined with eco.page() and exported as default.`,
|
|
9
|
-
noRendererForIntegration: (integrationName: string) => `No renderer found for integration: ${integrationName}`,
|
|
10
|
-
} as const;
|
|
11
|
-
|
|
12
|
-
export interface ExplicitStaticRouteMatcherOptions {
|
|
13
|
-
appConfig: EcoPagesAppConfig;
|
|
14
|
-
routeRendererFactory: RouteRendererFactory;
|
|
15
|
-
staticRoutes: StaticRoute[];
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
export interface ExplicitRouteMatch {
|
|
19
|
-
route: StaticRoute;
|
|
20
|
-
params: Record<string, string>;
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
export class ExplicitStaticRouteMatcher {
|
|
24
|
-
private readonly appConfig: EcoPagesAppConfig;
|
|
25
|
-
private readonly routeRendererFactory: RouteRendererFactory;
|
|
26
|
-
private readonly staticRoutes: StaticRoute[];
|
|
27
|
-
|
|
28
|
-
constructor({ appConfig, routeRendererFactory, staticRoutes }: ExplicitStaticRouteMatcherOptions) {
|
|
29
|
-
this.appConfig = appConfig;
|
|
30
|
-
this.routeRendererFactory = routeRendererFactory;
|
|
31
|
-
this.staticRoutes = staticRoutes;
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
/**
|
|
35
|
-
* Match a request URL against explicit static routes.
|
|
36
|
-
* Returns the matched route and extracted params, or null if no match.
|
|
37
|
-
*/
|
|
38
|
-
match(url: string): ExplicitRouteMatch | null {
|
|
39
|
-
const pathname = new URL(url).pathname;
|
|
40
|
-
|
|
41
|
-
for (const route of this.staticRoutes) {
|
|
42
|
-
const params = this.matchRoute(route.path, pathname);
|
|
43
|
-
if (params !== null) {
|
|
44
|
-
return { route, params };
|
|
45
|
-
}
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
return null;
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
/**
|
|
52
|
-
* Match a route pattern against a pathname.
|
|
53
|
-
* Supports :param and [param] syntax.
|
|
54
|
-
* Returns extracted params or null if no match.
|
|
55
|
-
*/
|
|
56
|
-
private matchRoute(pattern: string, pathname: string): Record<string, string> | null {
|
|
57
|
-
const patternSegments = pattern.split('/').filter(Boolean);
|
|
58
|
-
const pathSegments = pathname.split('/').filter(Boolean);
|
|
59
|
-
|
|
60
|
-
if (patternSegments.length !== pathSegments.length) {
|
|
61
|
-
const lastPattern = patternSegments[patternSegments.length - 1];
|
|
62
|
-
const isCatchAll = lastPattern?.startsWith('[...') || lastPattern?.startsWith(':...');
|
|
63
|
-
if (!isCatchAll) {
|
|
64
|
-
return null;
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
const params: Record<string, string> = {};
|
|
69
|
-
|
|
70
|
-
for (let i = 0; i < patternSegments.length; i++) {
|
|
71
|
-
const patternPart = patternSegments[i];
|
|
72
|
-
const pathPart = pathSegments[i];
|
|
73
|
-
|
|
74
|
-
if (patternPart.startsWith(':...') || patternPart.startsWith('[...')) {
|
|
75
|
-
const paramName = patternPart.replace(/^(:\.\.\.|\[\.\.\.)/, '').replace(/\]$/, '');
|
|
76
|
-
params[paramName] = pathSegments.slice(i).join('/');
|
|
77
|
-
return params;
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
if (patternPart.startsWith(':')) {
|
|
81
|
-
const paramName = patternPart.slice(1);
|
|
82
|
-
params[paramName] = pathPart;
|
|
83
|
-
} else if (patternPart.startsWith('[') && patternPart.endsWith(']')) {
|
|
84
|
-
const paramName = patternPart.slice(1, -1);
|
|
85
|
-
params[paramName] = pathPart;
|
|
86
|
-
} else if (patternPart !== pathPart) {
|
|
87
|
-
return null;
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
|
|
91
|
-
return params;
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
/**
|
|
95
|
-
* Handle a matched explicit static route.
|
|
96
|
-
* Resolves the loader and renders the view using the appropriate integration renderer.
|
|
97
|
-
*/
|
|
98
|
-
async handleMatch(match: ExplicitRouteMatch): Promise<Response> {
|
|
99
|
-
const { route, params } = match;
|
|
100
|
-
|
|
101
|
-
try {
|
|
102
|
-
const mod = await route.loader();
|
|
103
|
-
const view = mod.default;
|
|
104
|
-
|
|
105
|
-
const integrationName = view.config?.__eco?.integration;
|
|
106
|
-
if (!integrationName) {
|
|
107
|
-
throw new Error(EXPLICIT_STATIC_ROUTE_MATCHER_ERRORS.missingIntegration(route.path));
|
|
108
|
-
}
|
|
109
|
-
|
|
110
|
-
const renderer = this.routeRendererFactory.getRendererByIntegration(integrationName);
|
|
111
|
-
if (!renderer) {
|
|
112
|
-
throw new Error(EXPLICIT_STATIC_ROUTE_MATCHER_ERRORS.noRendererForIntegration(integrationName));
|
|
113
|
-
}
|
|
114
|
-
|
|
115
|
-
const props = view.staticProps
|
|
116
|
-
? (
|
|
117
|
-
await view.staticProps({
|
|
118
|
-
pathname: { params },
|
|
119
|
-
appConfig: this.appConfig,
|
|
120
|
-
runtimeOrigin: this.appConfig.baseUrl,
|
|
121
|
-
})
|
|
122
|
-
).props
|
|
123
|
-
: {};
|
|
124
|
-
|
|
125
|
-
return renderer.renderToResponse(view, props, {});
|
|
126
|
-
} catch (error) {
|
|
127
|
-
appLogger.error(
|
|
128
|
-
`Error rendering explicit static route ${route.path}:`,
|
|
129
|
-
error instanceof Error ? error : String(error),
|
|
130
|
-
);
|
|
131
|
-
throw error;
|
|
132
|
-
}
|
|
133
|
-
}
|
|
134
|
-
}
|