@ecopages/core 0.2.0-alpha.4 → 0.2.0-alpha.41
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/README.md +268 -14
- package/package.json +92 -110
- 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 +12 -12
- package/src/adapters/bun/create-app.js +64 -41
- package/src/adapters/bun/hmr-manager.d.ts +30 -68
- package/src/adapters/bun/hmr-manager.js +30 -212
- package/src/adapters/bun/index.d.ts +2 -3
- package/src/adapters/bun/index.js +3 -3
- package/src/adapters/bun/runtime-host.d.ts +52 -0
- package/src/adapters/bun/runtime-host.js +56 -0
- package/src/adapters/bun/server-adapter.d.ts +93 -32
- package/src/adapters/bun/server-adapter.js +166 -89
- package/src/adapters/bun/static-preview-host.d.ts +28 -0
- package/src/adapters/bun/static-preview-host.js +45 -0
- 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 +15 -12
- package/src/adapters/node/create-app.js +34 -85
- package/src/adapters/node/http-request-bridge.d.ts +57 -0
- package/src/adapters/node/http-request-bridge.js +118 -0
- package/src/adapters/node/node-client-bridge.d.ts +1 -1
- package/src/adapters/node/node-hmr-manager.d.ts +38 -49
- package/src/adapters/node/node-hmr-manager.js +31 -219
- package/src/adapters/node/runtime-host.d.ts +57 -0
- package/src/adapters/node/runtime-host.js +92 -0
- package/src/adapters/node/server-adapter-dependencies.d.ts +19 -0
- package/src/adapters/node/server-adapter-dependencies.js +18 -0
- package/src/adapters/node/server-adapter.d.ts +20 -72
- package/src/adapters/node/server-adapter.js +99 -203
- package/src/adapters/node/static-content-server.d.ts +37 -1
- package/src/adapters/node/static-content-server.js +29 -1
- package/src/adapters/node/static-preview-host.d.ts +55 -0
- package/src/adapters/node/static-preview-host.js +68 -0
- 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-render-preparation.d.ts +25 -0
- package/src/adapters/shared/explicit-static-render-preparation.js +26 -0
- package/src/adapters/shared/explicit-static-route-matcher.d.ts +7 -4
- package/src/adapters/shared/explicit-static-route-matcher.js +14 -13
- package/src/adapters/shared/file-route-middleware-pipeline.d.ts +7 -10
- package/src/adapters/shared/file-route-middleware-pipeline.js +3 -11
- package/src/adapters/shared/fs-server-response-factory.d.ts +14 -10
- package/src/adapters/shared/fs-server-response-factory.js +11 -27
- package/src/adapters/shared/fs-server-response-matcher.d.ts +20 -16
- package/src/adapters/shared/fs-server-response-matcher.js +76 -45
- 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 +33 -0
- package/src/adapters/shared/render-context.d.ts +5 -3
- package/src/adapters/shared/render-context.js +27 -3
- package/src/adapters/shared/runtime-app-bootstrap.d.ts +26 -0
- package/src/adapters/shared/runtime-app-bootstrap.js +46 -0
- package/src/adapters/shared/runtime-host.d.ts +12 -0
- package/src/adapters/shared/server-adapter.d.ts +33 -12
- package/src/adapters/shared/server-adapter.js +215 -132
- package/src/adapters/shared/server-route-handler.d.ts +5 -5
- package/src/adapters/shared/server-route-handler.js +7 -16
- package/src/adapters/shared/server-static-builder.d.ts +41 -8
- package/src/adapters/shared/server-static-builder.js +65 -11
- package/src/adapters/shared/shared-hmr-manager.d.ts +59 -0
- package/src/adapters/shared/shared-hmr-manager.js +240 -0
- package/src/adapters/shared/static-preview-host.d.ts +10 -0
- package/src/build/README.md +107 -0
- package/src/build/build-adapter.d.ts +176 -3
- package/src/build/build-adapter.js +619 -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 +16 -6
- package/src/build/esbuild-build-adapter.js +202 -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 +54 -29
- package/src/config/config-builder.js +256 -50
- 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/host-runtime.d.ts +10 -0
- package/src/dev/host-runtime.js +24 -0
- 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/eco.browser.d.ts +2 -0
- package/src/eco/eco.browser.js +88 -0
- package/src/eco/eco.js +63 -54
- package/src/eco/eco.types.d.ts +69 -6
- package/src/eco/eco.utils.d.ts +1 -40
- package/src/eco/eco.utils.js +5 -35
- package/src/eco/global-injector-map.d.ts +3 -3
- package/src/eco/global-injector-map.js +2 -2
- package/src/eco/lazy-injector-map.d.ts +2 -2
- package/src/errors/index.d.ts +1 -0
- package/src/errors/index.js +3 -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 +38 -7
- package/src/hmr/hmr-strategy.d.ts +16 -13
- 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 -48
- package/src/hmr/strategies/js-hmr-strategy.js +60 -75
- 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 +3 -2
- package/src/integrations/ghtml/ghtml-renderer.js +27 -30
- package/src/integrations/ghtml/ghtml.constants.d.ts +1 -0
- package/src/integrations/ghtml/ghtml.constants.js +4 -0
- package/src/integrations/ghtml/ghtml.plugin.d.ts +2 -6
- package/src/integrations/ghtml/ghtml.plugin.js +3 -4
- package/src/plugins/README.md +35 -0
- package/src/plugins/alias-resolver-plugin.d.ts +1 -0
- package/src/plugins/alias-resolver-plugin.js +27 -5
- package/src/plugins/eco-component-meta-plugin.d.ts +14 -1
- package/src/plugins/eco-component-meta-plugin.js +42 -24
- package/src/plugins/foreign-jsx-override-plugin.d.ts +33 -0
- package/src/plugins/foreign-jsx-override-plugin.js +41 -0
- package/src/plugins/integration-plugin.d.ts +147 -29
- package/src/plugins/integration-plugin.js +103 -14
- package/src/plugins/processor.d.ts +17 -2
- package/src/plugins/processor.js +22 -3
- 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 +83 -325
- package/src/route-renderer/README.md +73 -90
- package/src/route-renderer/orchestration/component-render-context.d.ts +97 -0
- package/src/route-renderer/orchestration/component-render-context.js +147 -0
- package/src/route-renderer/orchestration/declared-ownership-graph.d.ts +18 -0
- package/src/route-renderer/orchestration/declared-ownership-graph.js +34 -0
- package/src/route-renderer/orchestration/foreign-subtree-execution.service.d.ts +110 -0
- package/src/route-renderer/orchestration/foreign-subtree-execution.service.js +233 -0
- package/src/route-renderer/orchestration/integration-renderer.d.ts +534 -0
- package/src/route-renderer/orchestration/integration-renderer.js +986 -0
- package/src/route-renderer/orchestration/ownership-planning.service.d.ts +24 -0
- package/src/route-renderer/orchestration/ownership-planning.service.js +63 -0
- package/src/route-renderer/orchestration/ownership-validation.service.d.ts +29 -0
- package/src/route-renderer/orchestration/ownership-validation.service.js +53 -0
- package/src/route-renderer/orchestration/processed-asset-dedupe.d.ts +3 -0
- package/src/route-renderer/orchestration/processed-asset-dedupe.js +27 -0
- package/src/route-renderer/orchestration/queued-foreign-subtree-resolution.service.d.ts +91 -0
- package/src/route-renderer/orchestration/queued-foreign-subtree-resolution.service.js +170 -0
- package/src/route-renderer/orchestration/render-output.utils.d.ts +66 -0
- package/src/route-renderer/orchestration/render-output.utils.js +171 -0
- package/src/route-renderer/orchestration/route-render-orchestrator.d.ts +134 -0
- package/src/route-renderer/orchestration/route-render-orchestrator.js +442 -0
- package/src/route-renderer/orchestration/template-serialization.d.ts +38 -0
- package/src/route-renderer/orchestration/template-serialization.js +45 -0
- package/src/route-renderer/page-loading/component-dependency-collection.d.ts +37 -0
- package/src/route-renderer/page-loading/component-dependency-collection.js +132 -0
- package/src/route-renderer/page-loading/declared-asset-collection.d.ts +24 -0
- package/src/route-renderer/page-loading/declared-asset-collection.js +106 -0
- package/src/route-renderer/{dependency-resolver.d.ts → page-loading/dependency-resolver.d.ts} +15 -4
- package/src/route-renderer/page-loading/dependency-resolver.js +115 -0
- package/src/route-renderer/page-loading/ecopages-virtual-imports.d.ts +11 -0
- package/src/route-renderer/page-loading/ecopages-virtual-imports.js +57 -0
- package/src/route-renderer/page-loading/lazy-entry-collection.d.ts +45 -0
- package/src/route-renderer/page-loading/lazy-entry-collection.js +105 -0
- package/src/route-renderer/page-loading/lazy-trigger-planning.d.ts +19 -0
- package/src/route-renderer/page-loading/lazy-trigger-planning.js +40 -0
- package/src/route-renderer/page-loading/module-declaration-aggregation.d.ts +5 -0
- package/src/route-renderer/page-loading/module-declaration-aggregation.js +33 -0
- package/src/route-renderer/page-loading/module-declaration-scripts.d.ts +3 -0
- package/src/route-renderer/page-loading/module-declaration-scripts.js +18 -0
- package/src/route-renderer/page-loading/page-dependency-bundling.d.ts +13 -0
- package/src/route-renderer/page-loading/page-dependency-bundling.js +137 -0
- package/src/route-renderer/page-loading/page-module-loader.d.ts +90 -0
- package/src/route-renderer/{page-module-loader.js → page-loading/page-module-loader.js} +39 -14
- package/src/route-renderer/route-renderer.d.ts +57 -14
- package/src/route-renderer/route-renderer.js +30 -18
- package/src/router/README.md +94 -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 +169 -0
- package/src/router/client/navigation-coordinator.js +215 -0
- package/src/router/server/route-registry.d.ts +78 -0
- package/src/router/server/route-registry.js +262 -0
- package/src/services/README.md +28 -0
- package/src/services/assets/asset-processing-service/asset-dependency-keys.d.ts +3 -0
- package/src/services/assets/asset-processing-service/asset-dependency-keys.js +56 -0
- package/src/services/assets/asset-processing-service/asset-processing.service.d.ts +103 -0
- package/src/services/{asset-processing-service → assets/asset-processing-service}/asset-processing.service.js +124 -89
- 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 +16 -1
- package/src/services/assets/asset-processing-service/assets.types.js +0 -0
- 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 +49 -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/grouped-content-bundles.d.ts +30 -0
- package/src/services/assets/asset-processing-service/grouped-content-bundles.js +65 -0
- package/src/services/assets/asset-processing-service/index.d.ts +6 -0
- package/src/services/assets/asset-processing-service/index.js +6 -0
- package/src/services/assets/asset-processing-service/page-package.d.ts +6 -0
- package/src/services/assets/asset-processing-service/page-package.js +80 -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 +11 -5
- package/src/services/assets/asset-processing-service/processors/base/base-script-processor.d.ts +22 -0
- package/src/services/assets/asset-processing-service/processors/base/base-script-processor.js +136 -0
- 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 +3 -2
- package/src/services/assets/asset-processing-service/processors/script/content-script.processor.js +119 -0
- 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 +28 -7
- package/src/services/assets/asset-processing-service/processors/script/node-module-script.processor.d.ts +42 -0
- package/src/services/assets/asset-processing-service/processors/script/node-module-script.processor.js +126 -0
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/content-stylesheet.processor.d.ts +5 -2
- package/src/services/assets/asset-processing-service/processors/stylesheet/content-stylesheet.processor.js +59 -0
- 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 +9 -3
- package/src/services/assets/asset-processing-service/ungrouped-dependency-processing.d.ts +18 -0
- package/src/services/assets/asset-processing-service/ungrouped-dependency-processing.js +45 -0
- package/src/services/assets/browser-bundle.service.d.ts +73 -0
- package/src/services/assets/browser-bundle.service.js +41 -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 +40 -0
- package/src/services/html/html-rewriter-provider.service.js +68 -0
- package/src/services/html/html-transformer.service.d.ts +96 -0
- package/src/services/html/html-transformer.service.js +287 -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 +7 -0
- package/src/services/module-loading/app-module-loader.service.js +0 -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 +151 -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/module-loading-types.js +0 -0
- package/src/services/module-loading/node-bootstrap-plugin.d.ts +42 -0
- package/src/services/module-loading/node-bootstrap-plugin.js +297 -0
- package/src/services/module-loading/page-module-import.service.d.ts +95 -0
- package/src/services/module-loading/page-module-import.service.js +191 -0
- package/src/services/module-loading/server-module-transpiler.service.d.ts +63 -0
- package/src/services/module-loading/server-module-transpiler.service.js +64 -0
- package/src/services/module-loading/source-module-support.d.ts +5 -0
- package/src/services/module-loading/source-module-support.js +8 -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/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 +67 -20
- package/src/static-site-generator/static-site-generator.js +182 -138
- package/src/{internal-types.d.ts → types/internal-types.d.ts} +62 -30
- package/src/types/internal-types.js +0 -0
- package/src/{public-types.d.ts → types/public-types.d.ts} +239 -35
- package/src/types/public-types.js +0 -0
- package/src/utils/html-escaping.d.ts +7 -0
- package/src/utils/html-escaping.js +6 -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 -29
- package/src/watchers/project-watcher.js +126 -116
- package/src/watchers/project-watcher.test-helpers.d.ts +2 -2
- package/src/watchers/project-watcher.test-helpers.js +6 -6
- package/CHANGELOG.md +0 -91
- 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 -296
- package/src/adapters/bun/index.ts +0 -3
- package/src/adapters/bun/server-adapter.ts +0 -492
- package/src/adapters/bun/server-lifecycle.d.ts +0 -52
- package/src/adapters/bun/server-lifecycle.js +0 -120
- 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 -289
- 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.d.ts +0 -105
- package/src/eco/component-render-context.js +0 -77
- 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/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 -320
- 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 -1260
- package/src/route-renderer/component-graph-executor.d.ts +0 -32
- package/src/route-renderer/component-graph-executor.js +0 -31
- package/src/route-renderer/component-graph-executor.ts +0 -84
- package/src/route-renderer/component-graph.d.ts +0 -42
- package/src/route-renderer/component-graph.js +0 -72
- package/src/route-renderer/component-graph.ts +0 -159
- package/src/route-renderer/component-marker.d.ts +0 -52
- package/src/route-renderer/component-marker.js +0 -46
- package/src/route-renderer/component-marker.ts +0 -117
- package/src/route-renderer/dependency-resolver.js +0 -428
- 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.d.ts +0 -339
- package/src/route-renderer/integration-renderer.js +0 -526
- package/src/route-renderer/integration-renderer.ts +0 -696
- package/src/route-renderer/marker-graph-resolver.d.ts +0 -76
- package/src/route-renderer/marker-graph-resolver.js +0 -93
- 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.d.ts +0 -69
- 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.d.ts +0 -112
- package/src/route-renderer/render-preparation.service.js +0 -243
- 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.d.ts +0 -41
- package/src/router/fs-router-scanner.js +0 -155
- package/src/router/fs-router-scanner.ts +0 -217
- package/src/router/fs-router.d.ts +0 -26
- package/src/router/fs-router.js +0 -100
- 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.d.ts +0 -16
- package/src/services/asset-processing-service/processors/base/base-script-processor.js +0 -80
- 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.js +0 -57
- 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.d.ts +0 -7
- package/src/services/asset-processing-service/processors/script/node-module-script.processor.js +0 -74
- 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.js +0 -25
- 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 -41
- package/src/watchers/project-watcher.ts +0 -344
- /package/src/adapters/{bun → shared}/define-api-handler.js +0 -0
- /package/src/{internal-types.js → adapters/shared/runtime-host.js} +0 -0
- /package/src/{public-types.js → adapters/shared/static-preview-host.js} +0 -0
- /package/src/{services/asset-processing-service/assets.types.js → plugins/runtime-capability.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/services/{schema-validation-service.js → validation/schema-validation-service.js} +0 -0
|
@@ -1,52 +1,51 @@
|
|
|
1
1
|
import path from "node:path";
|
|
2
2
|
import { appLogger } from "../../global/app-logger.js";
|
|
3
|
-
import {
|
|
4
|
-
import { PageRequestCacheCoordinator } from "../../services/page-request-cache-coordinator.service.js";
|
|
3
|
+
import { PageRequestCacheCoordinator } from "../../services/cache/page-request-cache-coordinator.service.js";
|
|
5
4
|
import { ServerUtils } from "../../utils/server-utils.module.js";
|
|
6
5
|
import { FileRouteMiddlewarePipeline } from "./file-route-middleware-pipeline.js";
|
|
7
6
|
import { LocalsAccessError } from "../../errors/locals-access-error.js";
|
|
8
7
|
import { isDevelopmentRuntime } from "../../utils/runtime.js";
|
|
9
|
-
const FILE_SYSTEM_RESPONSE_MATCHER_ERRORS = {
|
|
10
|
-
transpilePageModuleFailed: (details) => `Error transpiling page module: ${details}`,
|
|
11
|
-
noTranspiledOutputForPageModule: (filePath) => `No transpiled output generated for page module: ${filePath}`
|
|
12
|
-
};
|
|
13
8
|
class FileSystemResponseMatcher {
|
|
9
|
+
appConfig;
|
|
10
|
+
assetPrefix;
|
|
14
11
|
router;
|
|
15
12
|
routeRendererFactory;
|
|
16
13
|
fileSystemResponseFactory;
|
|
17
|
-
pageModuleImportService;
|
|
18
14
|
pageRequestCacheCoordinator;
|
|
19
15
|
fileRouteMiddlewarePipeline;
|
|
20
16
|
constructor({
|
|
17
|
+
appConfig,
|
|
18
|
+
assetPrefix,
|
|
21
19
|
router,
|
|
22
20
|
routeRendererFactory,
|
|
23
21
|
fileSystemResponseFactory,
|
|
24
22
|
cacheService = null,
|
|
25
23
|
defaultCacheStrategy = "static"
|
|
26
24
|
}) {
|
|
25
|
+
this.appConfig = appConfig;
|
|
26
|
+
this.assetPrefix = assetPrefix;
|
|
27
27
|
this.router = router;
|
|
28
28
|
this.routeRendererFactory = routeRendererFactory;
|
|
29
29
|
this.fileSystemResponseFactory = fileSystemResponseFactory;
|
|
30
|
-
this.pageModuleImportService = new PageModuleImportService();
|
|
31
30
|
this.pageRequestCacheCoordinator = new PageRequestCacheCoordinator(cacheService, defaultCacheStrategy);
|
|
32
31
|
this.fileRouteMiddlewarePipeline = new FileRouteMiddlewarePipeline(cacheService);
|
|
33
32
|
}
|
|
34
33
|
/**
|
|
35
34
|
* Resolves unmatched paths either as static asset requests or as the custom
|
|
36
35
|
* not-found page.
|
|
37
|
-
*
|
|
38
36
|
* @param requestUrl Incoming pathname.
|
|
39
37
|
* @returns Static file response or rendered 404 response.
|
|
40
38
|
*/
|
|
41
39
|
async handleNoMatch(requestUrl) {
|
|
42
40
|
const isStaticFileRequest = ServerUtils.hasKnownExtension(requestUrl);
|
|
43
41
|
if (!isStaticFileRequest) {
|
|
44
|
-
return this.
|
|
42
|
+
return this.renderCustomNotFoundResponse();
|
|
45
43
|
}
|
|
46
44
|
const relativeUrl = requestUrl.startsWith("/") ? requestUrl.slice(1) : requestUrl;
|
|
47
|
-
const filePath = path.join(this.
|
|
45
|
+
const filePath = path.join(this.assetPrefix, relativeUrl);
|
|
48
46
|
const contentType = ServerUtils.getContentType(filePath);
|
|
49
|
-
|
|
47
|
+
const response = await this.fileSystemResponseFactory.createFileResponse(filePath, contentType);
|
|
48
|
+
return response ?? this.renderCustomNotFoundResponse();
|
|
50
49
|
}
|
|
51
50
|
/**
|
|
52
51
|
* Handles a matched file-system page route.
|
|
@@ -60,34 +59,25 @@ class FileSystemResponseMatcher {
|
|
|
60
59
|
* @returns Final response for the matched route.
|
|
61
60
|
*/
|
|
62
61
|
async handleMatch(match, request) {
|
|
63
|
-
const cacheKey = this.pageRequestCacheCoordinator.buildCacheKey(match);
|
|
64
62
|
try {
|
|
65
|
-
const
|
|
66
|
-
method: "GET"
|
|
67
|
-
});
|
|
68
|
-
const localsStore = {};
|
|
69
|
-
const pageModule = await this.importPageModule(match.filePath);
|
|
70
|
-
const Page = pageModule?.default;
|
|
71
|
-
const pageMiddleware = Page?.middleware ?? [];
|
|
72
|
-
const pageCacheStrategy = Page?.cache ?? this.pageRequestCacheCoordinator.getDefaultCacheStrategy();
|
|
73
|
-
const localsForRender = pageCacheStrategy === "dynamic" ? localsStore : void 0;
|
|
63
|
+
const executionPlan = await this.createExecutionPlan(match, request);
|
|
74
64
|
this.fileRouteMiddlewarePipeline.assertValidConfiguration({
|
|
75
|
-
middleware: pageMiddleware,
|
|
76
|
-
pageCacheStrategy,
|
|
77
|
-
filePath:
|
|
65
|
+
middleware: executionPlan.pageMiddleware,
|
|
66
|
+
pageCacheStrategy: executionPlan.pageCacheStrategy,
|
|
67
|
+
filePath: executionPlan.pageFilePath
|
|
78
68
|
});
|
|
79
|
-
const routeRenderer = this.routeRendererFactory.
|
|
69
|
+
const routeRenderer = this.routeRendererFactory.getPageRenderer(executionPlan.pageFilePath);
|
|
80
70
|
const middlewareContext = this.fileRouteMiddlewarePipeline.createContext({
|
|
81
|
-
request:
|
|
71
|
+
request: executionPlan.request,
|
|
82
72
|
params: match.params,
|
|
83
|
-
locals: localsStore
|
|
73
|
+
locals: executionPlan.localsStore
|
|
84
74
|
});
|
|
85
75
|
const renderFn = async () => {
|
|
86
|
-
const result = await routeRenderer.
|
|
87
|
-
file:
|
|
76
|
+
const result = await routeRenderer.execute({
|
|
77
|
+
file: executionPlan.pageFilePath,
|
|
88
78
|
params: match.params,
|
|
89
79
|
query: match.query,
|
|
90
|
-
locals: localsForRender
|
|
80
|
+
locals: executionPlan.localsForRender
|
|
91
81
|
});
|
|
92
82
|
const html = await this.pageRequestCacheCoordinator.bodyToString(result.body);
|
|
93
83
|
const strategy = result.cacheStrategy ?? this.pageRequestCacheCoordinator.getDefaultCacheStrategy();
|
|
@@ -95,13 +85,13 @@ class FileSystemResponseMatcher {
|
|
|
95
85
|
};
|
|
96
86
|
const renderResponse = async () => {
|
|
97
87
|
return this.pageRequestCacheCoordinator.render({
|
|
98
|
-
cacheKey,
|
|
99
|
-
pageCacheStrategy,
|
|
88
|
+
cacheKey: executionPlan.cacheKey,
|
|
89
|
+
pageCacheStrategy: executionPlan.pageCacheStrategy,
|
|
100
90
|
renderFn
|
|
101
91
|
});
|
|
102
92
|
};
|
|
103
93
|
return await this.fileRouteMiddlewarePipeline.run({
|
|
104
|
-
middleware: pageMiddleware,
|
|
94
|
+
middleware: executionPlan.pageMiddleware,
|
|
105
95
|
context: middlewareContext,
|
|
106
96
|
renderResponse
|
|
107
97
|
});
|
|
@@ -117,29 +107,71 @@ class FileSystemResponseMatcher {
|
|
|
117
107
|
}
|
|
118
108
|
if (error instanceof Error) {
|
|
119
109
|
if (isDevelopmentRuntime() || appLogger.isDebugEnabled()) {
|
|
120
|
-
appLogger.error(`[FileSystemResponseMatcher] ${error.message} at ${match.
|
|
110
|
+
appLogger.error(`[FileSystemResponseMatcher] ${error.message} at ${match.requestedPathname}`);
|
|
121
111
|
}
|
|
122
112
|
}
|
|
123
|
-
return this.
|
|
113
|
+
return this.renderCustomNotFoundResponse();
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
/**
|
|
117
|
+
* Renders the app-owned custom 404 page, falling back to the default text 404
|
|
118
|
+
* when the page template cannot be resolved.
|
|
119
|
+
*/
|
|
120
|
+
async renderCustomNotFoundResponse() {
|
|
121
|
+
const error404TemplatePath = this.appConfig.absolutePaths.error404TemplatePath;
|
|
122
|
+
try {
|
|
123
|
+
const routeRenderer = this.routeRendererFactory.getPageRenderer(error404TemplatePath);
|
|
124
|
+
const result = await routeRenderer.execute({
|
|
125
|
+
file: error404TemplatePath
|
|
126
|
+
});
|
|
127
|
+
return this.fileSystemResponseFactory.createHtmlNotFoundResponse(result.body);
|
|
128
|
+
} catch {
|
|
129
|
+
appLogger.debug(
|
|
130
|
+
"Custom 404 template not found, falling back to default 404 response",
|
|
131
|
+
error404TemplatePath
|
|
132
|
+
);
|
|
133
|
+
return this.fileSystemResponseFactory.createDefaultNotFoundResponse();
|
|
124
134
|
}
|
|
125
135
|
}
|
|
136
|
+
async createExecutionPlan(match, request) {
|
|
137
|
+
const cacheKey = this.pageRequestCacheCoordinator.buildCacheKey({
|
|
138
|
+
pathname: match.requestedPathname,
|
|
139
|
+
query: match.query
|
|
140
|
+
});
|
|
141
|
+
const resolvedRequest = request ?? new Request(new URL(cacheKey, this.router.origin).toString(), {
|
|
142
|
+
method: "GET"
|
|
143
|
+
});
|
|
144
|
+
const localsStore = {};
|
|
145
|
+
const pageFilePath = match.templateRoute.filePath;
|
|
146
|
+
const pageModule = await this.importPageModule(pageFilePath);
|
|
147
|
+
const Page = pageModule?.default;
|
|
148
|
+
const pageMiddleware = Page?.middleware ?? [];
|
|
149
|
+
const pageCacheStrategy = Page?.cache ?? this.pageRequestCacheCoordinator.getDefaultCacheStrategy();
|
|
150
|
+
return {
|
|
151
|
+
cacheKey,
|
|
152
|
+
request: resolvedRequest,
|
|
153
|
+
pageFilePath,
|
|
154
|
+
pageMiddleware,
|
|
155
|
+
pageCacheStrategy,
|
|
156
|
+
localsStore,
|
|
157
|
+
localsForRender: pageCacheStrategy === "dynamic" ? localsStore : void 0
|
|
158
|
+
};
|
|
159
|
+
}
|
|
126
160
|
/**
|
|
127
161
|
* Loads the matched page module for request-time inspection.
|
|
128
162
|
*
|
|
129
163
|
* The matcher needs access to page-level metadata such as `cache` and
|
|
130
|
-
* `middleware` before full rendering starts, so it
|
|
131
|
-
*
|
|
164
|
+
* `middleware` before full rendering starts, so it asks the owning route
|
|
165
|
+
* renderer to load the page module. That preserves integration-specific page
|
|
166
|
+
* import setup for request-time inspection as well as for full rendering.
|
|
132
167
|
*
|
|
133
168
|
* @param filePath Absolute page module path.
|
|
134
169
|
* @returns Imported page module.
|
|
135
170
|
*/
|
|
136
171
|
async importPageModule(filePath) {
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
outdir: path.join(this.router.assetPrefix, ".server-modules-meta"),
|
|
141
|
-
transpileErrorMessage: FILE_SYSTEM_RESPONSE_MATCHER_ERRORS.transpilePageModuleFailed,
|
|
142
|
-
noOutputMessage: FILE_SYSTEM_RESPONSE_MATCHER_ERRORS.noTranspiledOutputForPageModule
|
|
172
|
+
const routeRenderer = this.routeRendererFactory.getPageRenderer(filePath);
|
|
173
|
+
return routeRenderer.loadPageModule(filePath, {
|
|
174
|
+
cacheScope: "request-metadata"
|
|
143
175
|
});
|
|
144
176
|
}
|
|
145
177
|
/**
|
|
@@ -150,6 +182,5 @@ class FileSystemResponseMatcher {
|
|
|
150
182
|
}
|
|
151
183
|
}
|
|
152
184
|
export {
|
|
153
|
-
FILE_SYSTEM_RESPONSE_MATCHER_ERRORS,
|
|
154
185
|
FileSystemResponseMatcher
|
|
155
186
|
};
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Shared runtime state used while registering HMR-owned entrypoints.
|
|
3
|
+
*/
|
|
4
|
+
export interface HmrEntrypointRegistrarOptions {
|
|
5
|
+
/** Absolute source directory used to derive the emitted HMR path. */
|
|
6
|
+
srcDir: string;
|
|
7
|
+
/** Absolute distribution directory where HMR outputs are written. */
|
|
8
|
+
distDir: string;
|
|
9
|
+
/** In-flight registrations keyed by normalized absolute entrypoint path. */
|
|
10
|
+
entrypointRegistrations: Map<string, Promise<string>>;
|
|
11
|
+
/** Stable entrypoint-to-output mapping retained once an entrypoint is registered. */
|
|
12
|
+
watchedFiles: Map<string, string>;
|
|
13
|
+
/** Runtime-specific cleanup invoked when an entrypoint registration fails. */
|
|
14
|
+
clearFailedRegistration?: (entrypointPath: string) => void;
|
|
15
|
+
/** Development-only guardrail for integrations that never finish producing output. */
|
|
16
|
+
registrationTimeoutMs: number;
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Runtime-specific hooks required to materialize a single HMR entrypoint.
|
|
20
|
+
*/
|
|
21
|
+
export interface HmrEntrypointRegistrationOptions {
|
|
22
|
+
/**
|
|
23
|
+
* Emits the browser-consumable HMR artifact for an entrypoint.
|
|
24
|
+
*/
|
|
25
|
+
emit(entrypointPath: string, outputPath: string): Promise<void>;
|
|
26
|
+
/**
|
|
27
|
+
* Creates the runtime-specific error raised when the emit hook completes without producing output.
|
|
28
|
+
*/
|
|
29
|
+
getMissingOutputError(entrypointPath: string, outputPath: string): Error;
|
|
30
|
+
}
|
|
31
|
+
/**
|
|
32
|
+
* Coordinates the shared HMR entrypoint registration lifecycle for both Node and Bun managers.
|
|
33
|
+
*
|
|
34
|
+
* The registrar owns the cross-runtime policy: normalize entrypoint identities, dedupe concurrent
|
|
35
|
+
* registrations, derive the emitted `_hmr` output path, clear stale output before rebuilding, and
|
|
36
|
+
* apply the development timeout that prevents unresolved registrations from hanging navigation.
|
|
37
|
+
* Runtime-specific managers remain responsible for the actual emit step and any cleanup outside
|
|
38
|
+
* this shared registration flow.
|
|
39
|
+
*/
|
|
40
|
+
export declare class HmrEntrypointRegistrar {
|
|
41
|
+
private readonly options;
|
|
42
|
+
constructor(options: HmrEntrypointRegistrarOptions);
|
|
43
|
+
/**
|
|
44
|
+
* Registers a single source entrypoint and returns the browser URL for its emitted HMR module.
|
|
45
|
+
*
|
|
46
|
+
* Concurrent requests for the same normalized entrypoint share the same in-flight promise so the
|
|
47
|
+
* integration only builds once per registration cycle.
|
|
48
|
+
*/
|
|
49
|
+
registerEntrypoint(entrypointPath: string, registrationOptions: HmrEntrypointRegistrationOptions): Promise<string>;
|
|
50
|
+
private registerEntrypointInternal;
|
|
51
|
+
private awaitEntrypointRegistration;
|
|
52
|
+
private getEntrypointOutput;
|
|
53
|
+
private removeStaleEntrypointOutput;
|
|
54
|
+
private encodeDynamicSegments;
|
|
55
|
+
}
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
import path from "node:path";
|
|
2
|
+
import { fileSystem } from "@ecopages/file-system";
|
|
3
|
+
import { appLogger } from "../../global/app-logger.js";
|
|
4
|
+
import { RESOLVED_ASSETS_DIR } from "../../config/constants.js";
|
|
5
|
+
class HmrEntrypointRegistrar {
|
|
6
|
+
options;
|
|
7
|
+
constructor(options) {
|
|
8
|
+
this.options = options;
|
|
9
|
+
}
|
|
10
|
+
/**
|
|
11
|
+
* Registers a single source entrypoint and returns the browser URL for its emitted HMR module.
|
|
12
|
+
*
|
|
13
|
+
* Concurrent requests for the same normalized entrypoint share the same in-flight promise so the
|
|
14
|
+
* integration only builds once per registration cycle.
|
|
15
|
+
*/
|
|
16
|
+
async registerEntrypoint(entrypointPath, registrationOptions) {
|
|
17
|
+
const normalizedEntrypoint = path.resolve(entrypointPath);
|
|
18
|
+
const existingRegistration = this.options.entrypointRegistrations.get(normalizedEntrypoint);
|
|
19
|
+
if (existingRegistration) {
|
|
20
|
+
return await this.awaitEntrypointRegistration(existingRegistration, normalizedEntrypoint);
|
|
21
|
+
}
|
|
22
|
+
const registration = this.registerEntrypointInternal(normalizedEntrypoint, registrationOptions);
|
|
23
|
+
this.options.entrypointRegistrations.set(normalizedEntrypoint, registration);
|
|
24
|
+
try {
|
|
25
|
+
return await this.awaitEntrypointRegistration(registration, normalizedEntrypoint);
|
|
26
|
+
} catch (error) {
|
|
27
|
+
this.options.clearFailedRegistration?.(normalizedEntrypoint);
|
|
28
|
+
throw error;
|
|
29
|
+
} finally {
|
|
30
|
+
this.options.entrypointRegistrations.delete(normalizedEntrypoint);
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
async registerEntrypointInternal(entrypointPath, registrationOptions) {
|
|
34
|
+
if (this.options.watchedFiles.has(entrypointPath)) {
|
|
35
|
+
return this.options.watchedFiles.get(entrypointPath);
|
|
36
|
+
}
|
|
37
|
+
const { outputPath, outputUrl } = this.getEntrypointOutput(entrypointPath);
|
|
38
|
+
this.options.watchedFiles.set(entrypointPath, outputUrl);
|
|
39
|
+
this.removeStaleEntrypointOutput(outputPath);
|
|
40
|
+
await registrationOptions.emit(entrypointPath, outputPath);
|
|
41
|
+
if (!fileSystem.exists(outputPath)) {
|
|
42
|
+
throw registrationOptions.getMissingOutputError(entrypointPath, outputPath);
|
|
43
|
+
}
|
|
44
|
+
return outputUrl;
|
|
45
|
+
}
|
|
46
|
+
async awaitEntrypointRegistration(registration, entrypointPath) {
|
|
47
|
+
if (process.env.NODE_ENV !== "development") {
|
|
48
|
+
return await registration;
|
|
49
|
+
}
|
|
50
|
+
return await Promise.race([
|
|
51
|
+
registration,
|
|
52
|
+
new Promise((_, reject) => {
|
|
53
|
+
setTimeout(() => {
|
|
54
|
+
reject(new Error(`[HMR] Timed out registering entrypoint: ${entrypointPath}`));
|
|
55
|
+
}, this.options.registrationTimeoutMs);
|
|
56
|
+
})
|
|
57
|
+
]);
|
|
58
|
+
}
|
|
59
|
+
getEntrypointOutput(entrypointPath) {
|
|
60
|
+
const relativePath = path.relative(this.options.srcDir, entrypointPath);
|
|
61
|
+
const relativePathJs = relativePath.replace(/\.(tsx?|jsx?|mdx?)$/, ".js");
|
|
62
|
+
const encodedPathJs = this.encodeDynamicSegments(relativePathJs);
|
|
63
|
+
const urlPath = encodedPathJs.split(path.sep).join("/");
|
|
64
|
+
return {
|
|
65
|
+
outputUrl: `/${path.join(RESOLVED_ASSETS_DIR, "_hmr", urlPath)}`,
|
|
66
|
+
outputPath: path.join(this.options.distDir, urlPath)
|
|
67
|
+
};
|
|
68
|
+
}
|
|
69
|
+
removeStaleEntrypointOutput(outputPath) {
|
|
70
|
+
if (!fileSystem.exists(outputPath)) {
|
|
71
|
+
return;
|
|
72
|
+
}
|
|
73
|
+
try {
|
|
74
|
+
fileSystem.remove(outputPath);
|
|
75
|
+
} catch (error) {
|
|
76
|
+
appLogger.warn(
|
|
77
|
+
`[HMR] Failed to remove stale entrypoint output ${outputPath}: ${error instanceof Error ? error.message : String(error)}`
|
|
78
|
+
);
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
encodeDynamicSegments(filepath) {
|
|
82
|
+
return filepath.replace(/\[([^\]]+)\]/g, "_$1_");
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
export {
|
|
86
|
+
HmrEntrypointRegistrar
|
|
87
|
+
};
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import type { IHmrManager } from '../../types/public-types.js';
|
|
2
|
+
/**
|
|
3
|
+
* Returns whether a response is HTML and therefore eligible for development HMR
|
|
4
|
+
* runtime injection.
|
|
5
|
+
*/
|
|
6
|
+
export declare function isHtmlResponse(response: Response): boolean;
|
|
7
|
+
/**
|
|
8
|
+
* Returns whether HTML responses should receive the HMR runtime bootstrap.
|
|
9
|
+
*
|
|
10
|
+
* This is shared because filesystem page responses and adapter-level HTML
|
|
11
|
+
* responses flow through different layers, but both need identical injection
|
|
12
|
+
* behavior in watch mode.
|
|
13
|
+
*/
|
|
14
|
+
export declare function shouldInjectHmrHtmlResponse(watch: boolean, hmrManager?: Pick<IHmrManager, 'isEnabled'>): boolean;
|
|
15
|
+
/**
|
|
16
|
+
* Injects the development HMR runtime script into an HTML response if it is not
|
|
17
|
+
* already present.
|
|
18
|
+
*
|
|
19
|
+
* The check is intentionally idempotent because an HTML response can pass
|
|
20
|
+
* through more than one development-layer wrapper before reaching the client.
|
|
21
|
+
*/
|
|
22
|
+
export declare function injectHmrRuntimeIntoHtmlResponse(response: Response): Promise<Response>;
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
const HMR_RUNTIME_IMPORT = "import '/_hmr_runtime.js'";
|
|
2
|
+
const HMR_RUNTIME_SCRIPT = `<script type="module">${HMR_RUNTIME_IMPORT};<\/script>`;
|
|
3
|
+
function isHtmlResponse(response) {
|
|
4
|
+
const contentType = response.headers.get("Content-Type");
|
|
5
|
+
return contentType !== null && contentType.startsWith("text/html");
|
|
6
|
+
}
|
|
7
|
+
function shouldInjectHmrHtmlResponse(watch, hmrManager) {
|
|
8
|
+
return watch && hmrManager?.isEnabled() === true;
|
|
9
|
+
}
|
|
10
|
+
async function injectHmrRuntimeIntoHtmlResponse(response) {
|
|
11
|
+
const html = await response.text();
|
|
12
|
+
const headers = new Headers(response.headers);
|
|
13
|
+
headers.set("Cache-Control", "no-store, must-revalidate");
|
|
14
|
+
headers.delete("Content-Length");
|
|
15
|
+
if (html.includes(HMR_RUNTIME_IMPORT)) {
|
|
16
|
+
return new Response(html, {
|
|
17
|
+
status: response.status,
|
|
18
|
+
statusText: response.statusText,
|
|
19
|
+
headers
|
|
20
|
+
});
|
|
21
|
+
}
|
|
22
|
+
const updatedHtml = html.replace(/<\/html>/i, `${HMR_RUNTIME_SCRIPT}</html>`);
|
|
23
|
+
return new Response(updatedHtml, {
|
|
24
|
+
status: response.status,
|
|
25
|
+
statusText: response.statusText,
|
|
26
|
+
headers
|
|
27
|
+
});
|
|
28
|
+
}
|
|
29
|
+
export {
|
|
30
|
+
injectHmrRuntimeIntoHtmlResponse,
|
|
31
|
+
isHtmlResponse,
|
|
32
|
+
shouldInjectHmrHtmlResponse
|
|
33
|
+
};
|
|
@@ -1,7 +1,9 @@
|
|
|
1
|
-
import type { RenderContext } from '../../public-types.js';
|
|
2
|
-
import type {
|
|
1
|
+
import type { RenderContext } from '../../types/public-types.js';
|
|
2
|
+
import type { AnyIntegrationPlugin } from '../../plugins/integration-plugin.js';
|
|
3
3
|
export interface CreateRenderContextOptions {
|
|
4
|
-
integrations:
|
|
4
|
+
integrations: AnyIntegrationPlugin[];
|
|
5
|
+
rendererModules?: unknown;
|
|
6
|
+
importServerModule?: (filePath: string) => Promise<unknown>;
|
|
5
7
|
}
|
|
6
8
|
/**
|
|
7
9
|
* Creates a render context for route handlers.
|
|
@@ -1,4 +1,8 @@
|
|
|
1
|
+
import { fileURLToPath } from "node:url";
|
|
1
2
|
import { invariant } from "../../utils/invariant.js";
|
|
3
|
+
function resolveServerModulePath(filePath) {
|
|
4
|
+
return filePath instanceof URL ? fileURLToPath(filePath) : filePath;
|
|
5
|
+
}
|
|
2
6
|
function mergePropsWithLocals(props, locals) {
|
|
3
7
|
if (!locals || typeof props !== "object" || props === null) {
|
|
4
8
|
return props;
|
|
@@ -15,12 +19,31 @@ function createRenderContext(options) {
|
|
|
15
19
|
);
|
|
16
20
|
const integration = integrations.find((i) => i.name === integrationName);
|
|
17
21
|
invariant(!!integration, `No integration found for: ${integrationName}`);
|
|
18
|
-
return integration.initializeRenderer(
|
|
22
|
+
return integration.initializeRenderer({
|
|
23
|
+
rendererModules: options.rendererModules
|
|
24
|
+
});
|
|
19
25
|
};
|
|
20
|
-
|
|
26
|
+
const renderContext = {
|
|
27
|
+
importServerModule: async (filePath) => {
|
|
28
|
+
invariant(!!options.importServerModule, "Server module importing is not available in this render context.");
|
|
29
|
+
return await options.importServerModule(resolveServerModulePath(filePath));
|
|
30
|
+
},
|
|
31
|
+
async renderServerModule(filePath, props, renderOptions) {
|
|
32
|
+
const module = await renderContext.importServerModule(filePath);
|
|
33
|
+
const view = module.default;
|
|
34
|
+
const locals = this?.locals;
|
|
35
|
+
const mergedProps = mergePropsWithLocals(props ?? {}, locals);
|
|
36
|
+
const renderer = getRendererForView(view);
|
|
37
|
+
const ctx = {
|
|
38
|
+
partial: false,
|
|
39
|
+
status: renderOptions?.status,
|
|
40
|
+
headers: renderOptions?.headers
|
|
41
|
+
};
|
|
42
|
+
return await renderer.renderToResponse(view, mergedProps, ctx);
|
|
43
|
+
},
|
|
21
44
|
async render(view, props, renderOptions) {
|
|
22
45
|
const locals = this?.locals;
|
|
23
|
-
const mergedProps = mergePropsWithLocals(props, locals);
|
|
46
|
+
const mergedProps = mergePropsWithLocals(props ?? {}, locals);
|
|
24
47
|
const renderer = getRendererForView(view);
|
|
25
48
|
const ctx = {
|
|
26
49
|
partial: false,
|
|
@@ -63,6 +86,7 @@ function createRenderContext(options) {
|
|
|
63
86
|
});
|
|
64
87
|
}
|
|
65
88
|
};
|
|
89
|
+
return renderContext;
|
|
66
90
|
}
|
|
67
91
|
export {
|
|
68
92
|
createRenderContext
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import type { ReturnParseCliArgs } from '../../utils/parse-cli-args.js';
|
|
2
|
+
import type { EcoPagesAppConfig } from '../../types/internal-types.js';
|
|
3
|
+
export type RuntimeBinding = {
|
|
4
|
+
preferredPort: number;
|
|
5
|
+
preferredHostname: string;
|
|
6
|
+
runtimeOrigin: string;
|
|
7
|
+
serveOptions: Record<string, unknown>;
|
|
8
|
+
watch: boolean;
|
|
9
|
+
};
|
|
10
|
+
export type StaticRuntimeMode = {
|
|
11
|
+
requiresFetchRuntime: boolean;
|
|
12
|
+
canBuildWithoutRuntimeServer: boolean;
|
|
13
|
+
};
|
|
14
|
+
export declare function resolveServeRuntimeOrigin(serveOptions: {
|
|
15
|
+
hostname?: string;
|
|
16
|
+
port?: number | string;
|
|
17
|
+
}): string;
|
|
18
|
+
export declare function resolveRuntimeBinding(options: {
|
|
19
|
+
cliArgs: ReturnParseCliArgs;
|
|
20
|
+
serverOptions?: Record<string, unknown>;
|
|
21
|
+
env?: NodeJS.ProcessEnv;
|
|
22
|
+
}): RuntimeBinding;
|
|
23
|
+
export declare function resolveStaticRuntimeMode(options: {
|
|
24
|
+
appConfig: EcoPagesAppConfig;
|
|
25
|
+
cliArgs: ReturnParseCliArgs;
|
|
26
|
+
}): StaticRuntimeMode;
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { DEFAULT_ECOPAGES_HOSTNAME, DEFAULT_ECOPAGES_PORT } from "../../config/constants.js";
|
|
2
|
+
function normalizeOriginHostname(hostname) {
|
|
3
|
+
if (hostname.includes(":") && !hostname.startsWith("[") && !hostname.endsWith("]")) {
|
|
4
|
+
return `[${hostname}]`;
|
|
5
|
+
}
|
|
6
|
+
return hostname;
|
|
7
|
+
}
|
|
8
|
+
function resolveServeRuntimeOrigin(serveOptions) {
|
|
9
|
+
const hostname = normalizeOriginHostname(String(serveOptions.hostname ?? DEFAULT_ECOPAGES_HOSTNAME));
|
|
10
|
+
const port = Number(serveOptions.port ?? DEFAULT_ECOPAGES_PORT);
|
|
11
|
+
return `http://${hostname}:${port}`;
|
|
12
|
+
}
|
|
13
|
+
function resolveRuntimeBinding(options) {
|
|
14
|
+
const env = options.env ?? process.env;
|
|
15
|
+
const preferredPort = options.cliArgs.port ?? (env.ECOPAGES_PORT ? Number(env.ECOPAGES_PORT) : void 0) ?? DEFAULT_ECOPAGES_PORT;
|
|
16
|
+
const preferredHostname = options.cliArgs.hostname ?? env.ECOPAGES_HOSTNAME ?? DEFAULT_ECOPAGES_HOSTNAME;
|
|
17
|
+
return {
|
|
18
|
+
preferredPort,
|
|
19
|
+
preferredHostname,
|
|
20
|
+
runtimeOrigin: resolveServeRuntimeOrigin({
|
|
21
|
+
hostname: preferredHostname,
|
|
22
|
+
port: preferredPort
|
|
23
|
+
}),
|
|
24
|
+
serveOptions: {
|
|
25
|
+
port: preferredPort,
|
|
26
|
+
hostname: preferredHostname,
|
|
27
|
+
...options.serverOptions ?? {}
|
|
28
|
+
},
|
|
29
|
+
watch: options.cliArgs.dev
|
|
30
|
+
};
|
|
31
|
+
}
|
|
32
|
+
function resolveStaticRuntimeMode(options) {
|
|
33
|
+
const requiresFetchRuntime = options.appConfig.integrations.some(
|
|
34
|
+
(integration) => integration.staticBuildStep === "fetch"
|
|
35
|
+
);
|
|
36
|
+
const canBuildWithoutRuntimeServer = (options.cliArgs.build || options.cliArgs.preview) && !requiresFetchRuntime;
|
|
37
|
+
return {
|
|
38
|
+
requiresFetchRuntime,
|
|
39
|
+
canBuildWithoutRuntimeServer
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
export {
|
|
43
|
+
resolveRuntimeBinding,
|
|
44
|
+
resolveServeRuntimeOrigin,
|
|
45
|
+
resolveStaticRuntimeMode
|
|
46
|
+
};
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export interface RuntimeHost<TServer, TServeOptions> {
|
|
2
|
+
start(options: RuntimeHostStartOptions<TServeOptions>): Promise<TServer>;
|
|
3
|
+
stop(server: TServer, options?: {
|
|
4
|
+
force?: boolean;
|
|
5
|
+
}): Promise<void>;
|
|
6
|
+
getOrigin(server: TServer, fallbackServeOptions: TServeOptions): string;
|
|
7
|
+
}
|
|
8
|
+
export interface RuntimeHostStartOptions<TServeOptions> {
|
|
9
|
+
serveOptions: TServeOptions;
|
|
10
|
+
handleRequest(request: Request): Promise<Response>;
|
|
11
|
+
onError(error: Error): Promise<void> | void;
|
|
12
|
+
}
|
|
@@ -1,30 +1,47 @@
|
|
|
1
1
|
import { AbstractServerAdapter } from '../abstract/server-adapter.js';
|
|
2
2
|
import type { ServerAdapterOptions, ServerAdapterResult } from '../abstract/server-adapter.js';
|
|
3
3
|
import { RouteRendererFactory } from '../../route-renderer/route-renderer.js';
|
|
4
|
-
import {
|
|
5
|
-
import { SchemaValidationService } from '../../services/schema-validation-service.js';
|
|
4
|
+
import { RouteRegistry } from '../../router/server/route-registry.js';
|
|
5
|
+
import { SchemaValidationService } from '../../services/validation/schema-validation-service.js';
|
|
6
6
|
import { StaticSiteGenerator } from '../../static-site-generator/static-site-generator.js';
|
|
7
7
|
import { ServerStaticBuilder } from './server-static-builder.js';
|
|
8
8
|
import { FileSystemResponseMatcher } from './fs-server-response-matcher.js';
|
|
9
9
|
import { ServerRouteHandler } from './server-route-handler.js';
|
|
10
|
-
import type { ApiHandler, CacheInvalidator, ErrorHandler, RenderContext, StaticRoute } from '../../public-types.js';
|
|
10
|
+
import type { ApiHandler, CacheInvalidator, ErrorHandler, RenderContext, StaticRoute } from '../../types/public-types.js';
|
|
11
|
+
type SharedRequestContext = {
|
|
12
|
+
apiHandlers: ApiHandler[];
|
|
13
|
+
errorHandler?: ErrorHandler;
|
|
14
|
+
serverInstance?: any;
|
|
15
|
+
hmrManager?: any;
|
|
16
|
+
};
|
|
11
17
|
export declare abstract class SharedServerAdapter<TOptions extends ServerAdapterOptions, TResult extends ServerAdapterResult> extends AbstractServerAdapter<TOptions, TResult> {
|
|
12
|
-
protected router:
|
|
18
|
+
protected router: RouteRegistry;
|
|
13
19
|
protected fileSystemResponseMatcher: FileSystemResponseMatcher;
|
|
14
20
|
protected routeRendererFactory: RouteRendererFactory;
|
|
15
21
|
protected routeHandler: ServerRouteHandler;
|
|
16
22
|
protected staticSiteGenerator: StaticSiteGenerator;
|
|
17
23
|
protected staticBuilder: ServerStaticBuilder;
|
|
18
24
|
protected readonly schemaValidator: SchemaValidationService;
|
|
25
|
+
protected initializeSharedRouteHandling(options: {
|
|
26
|
+
staticRoutes: StaticRoute[];
|
|
27
|
+
hmrManager?: any;
|
|
28
|
+
}): Promise<void>;
|
|
29
|
+
protected createSharedWatchRefreshCallback(options: {
|
|
30
|
+
staticRoutes: StaticRoute[];
|
|
31
|
+
hmrManager?: any;
|
|
32
|
+
onRoutesReady?: () => Promise<void> | void;
|
|
33
|
+
onError?: (error: Error) => Promise<void> | void;
|
|
34
|
+
}): () => Promise<void>;
|
|
19
35
|
/**
|
|
20
|
-
* Scans the filesystem and dynamically constructs the
|
|
36
|
+
* Scans the filesystem and dynamically constructs the Route Registry.
|
|
21
37
|
*
|
|
22
38
|
* This process runs identically across both Bun and Node wrappers. It analyzes the configured pages
|
|
23
39
|
* directory, building a map of all available UI routes and API endpoints.
|
|
24
|
-
* The resulting `
|
|
40
|
+
* The resulting `RouteRegistry` instance becomes the central nervous system for mapping WinterCG incoming
|
|
25
41
|
* Web Requests (`Request`) to their corresponding internal execution paths.
|
|
26
42
|
*/
|
|
27
43
|
protected initSharedRouter(): Promise<void>;
|
|
44
|
+
private createRouteRegistryPageModuleAdapter;
|
|
28
45
|
/**
|
|
29
46
|
* Sets up the unified rendering pipeline and response matching chain.
|
|
30
47
|
*
|
|
@@ -40,6 +57,8 @@ export declare abstract class SharedServerAdapter<TOptions extends ServerAdapter
|
|
|
40
57
|
* @param hmrManager - The runtime-specific Hot Module Replacement orchestrator (if watching).
|
|
41
58
|
*/
|
|
42
59
|
protected configureSharedResponseHandlers(staticRoutes: StaticRoute[], hmrManager?: any): void;
|
|
60
|
+
private createSharedResponseHandlerDependencies;
|
|
61
|
+
private createSharedPageCacheService;
|
|
43
62
|
protected getCacheService(): CacheInvalidator | null;
|
|
44
63
|
protected getRenderContext(): RenderContext;
|
|
45
64
|
/**
|
|
@@ -60,6 +79,10 @@ export declare abstract class SharedServerAdapter<TOptions extends ServerAdapter
|
|
|
60
79
|
* @returns The resulting Web standard `Response` constructed by the user's handler.
|
|
61
80
|
*/
|
|
62
81
|
protected executeApiHandler(request: Request, params: Record<string, string | string[]>, routeConfig: ApiHandler, serverInstance: any, errorHandler?: ErrorHandler): Promise<Response>;
|
|
82
|
+
private createApiHandlerContext;
|
|
83
|
+
private normalizeApiParams;
|
|
84
|
+
private applyApiRequestSchema;
|
|
85
|
+
private runApiMiddlewareChain;
|
|
63
86
|
private normalizePath;
|
|
64
87
|
private matchApiPath;
|
|
65
88
|
private getApiPathScore;
|
|
@@ -67,6 +90,8 @@ export declare abstract class SharedServerAdapter<TOptions extends ServerAdapter
|
|
|
67
90
|
routeConfig: ApiHandler;
|
|
68
91
|
params: Record<string, string | string[]>;
|
|
69
92
|
} | null;
|
|
93
|
+
private tryHandleSharedHmrRequest;
|
|
94
|
+
private tryHandleSharedApiRequest;
|
|
70
95
|
/**
|
|
71
96
|
* Universally processes an incoming WinterCG Web standard Request.
|
|
72
97
|
*
|
|
@@ -78,10 +103,6 @@ export declare abstract class SharedServerAdapter<TOptions extends ServerAdapter
|
|
|
78
103
|
* Both Bun and Node bindings fall back to this exact function once they have mapped their
|
|
79
104
|
* native HTTP objects into Web Standard Requests.
|
|
80
105
|
*/
|
|
81
|
-
handleSharedRequest(request: Request, context:
|
|
82
|
-
apiHandlers: ApiHandler[];
|
|
83
|
-
errorHandler?: ErrorHandler;
|
|
84
|
-
serverInstance?: any;
|
|
85
|
-
hmrManager?: any;
|
|
86
|
-
}): Promise<Response>;
|
|
106
|
+
handleSharedRequest(request: Request, context: SharedRequestContext): Promise<Response>;
|
|
87
107
|
}
|
|
108
|
+
export {};
|