@ecopages/core 0.2.0-alpha.3 → 0.2.0-alpha.31
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 +66 -66
- package/README.md +268 -14
- package/package.json +72 -108
- 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 +5 -12
- package/src/adapters/bun/create-app.js +43 -7
- package/src/adapters/bun/hmr-manager.d.ts +72 -26
- package/src/adapters/bun/hmr-manager.js +153 -81
- 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 +63 -38
- 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 +79 -21
- package/src/adapters/node/node-hmr-manager.js +167 -114
- package/src/adapters/node/server-adapter.d.ts +7 -35
- package/src/adapters/node/server-adapter.js +55 -107
- 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-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 +32 -0
- package/src/adapters/shared/render-context.d.ts +4 -3
- 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 +33 -12
- package/src/adapters/shared/server-adapter.js +208 -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/build/README.md +107 -0
- package/src/build/build-adapter.d.ts +168 -3
- package/src/build/build-adapter.js +604 -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 +54 -29
- package/src/config/config-builder.js +255 -49
- 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 +83 -0
- package/src/eco/eco.js +32 -57
- package/src/eco/eco.types.d.ts +14 -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 +64 -74
- 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.js +17 -3
- package/src/plugins/eco-component-meta-plugin.d.ts +14 -1
- package/src/plugins/eco-component-meta-plugin.js +27 -22
- package/src/plugins/foreign-jsx-override-plugin.d.ts +31 -0
- package/src/plugins/foreign-jsx-override-plugin.js +35 -0
- package/src/plugins/integration-plugin.d.ts +142 -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 +89 -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 +108 -0
- package/src/route-renderer/orchestration/foreign-subtree-execution.service.js +206 -0
- package/src/route-renderer/orchestration/integration-renderer.d.ts +516 -0
- package/src/route-renderer/orchestration/integration-renderer.js +909 -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 +2 -0
- package/src/route-renderer/orchestration/processed-asset-dedupe.js +23 -0
- package/src/route-renderer/orchestration/queued-foreign-subtree-resolution.service.d.ts +90 -0
- package/src/route-renderer/orchestration/queued-foreign-subtree-resolution.service.js +158 -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 +120 -0
- package/src/route-renderer/orchestration/route-render-orchestrator.js +388 -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/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 +3 -0
- package/src/services/assets/asset-processing-service/page-package.js +74 -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/{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 +12 -7
- 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 +37 -0
- package/src/services/html/html-rewriter-provider.service.js +68 -0
- package/src/services/html/html-transformer.service.d.ts +87 -0
- package/src/services/html/html-transformer.service.js +216 -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-server-module-transpiler.service.d.ts +24 -0
- package/src/services/module-loading/app-server-module-transpiler.service.js +115 -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 +216 -0
- package/src/services/module-loading/page-module-import.service.d.ts +76 -0
- package/src/services/module-loading/page-module-import.service.js +170 -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} +201 -32
- 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/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.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/__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 -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.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 → plugins/runtime-capability.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/app-module-loader.service.js} +0 -0
- /package/src/services/{schema-validation-service.js → validation/schema-validation-service.js} +0 -0
|
@@ -1,19 +1,23 @@
|
|
|
1
|
-
import type {
|
|
2
|
-
import type { RouteRendererBody } from '../../public-types.js';
|
|
3
|
-
|
|
1
|
+
import type { FileSystemServerOptions } from '../../types/internal-types.js';
|
|
2
|
+
import type { RouteRendererBody } from '../../types/public-types.js';
|
|
3
|
+
/**
|
|
4
|
+
* Builds HTTP responses for static files and shared file-system fallbacks.
|
|
5
|
+
*/
|
|
4
6
|
export declare class FileSystemServerResponseFactory {
|
|
5
|
-
private appConfig;
|
|
6
|
-
private routeRendererFactory;
|
|
7
7
|
private options;
|
|
8
|
-
constructor({
|
|
9
|
-
appConfig: EcoPagesAppConfig;
|
|
10
|
-
routeRendererFactory: RouteRendererFactory;
|
|
8
|
+
constructor({ options }: {
|
|
11
9
|
options: FileSystemServerOptions;
|
|
12
10
|
});
|
|
13
11
|
isHtml(contentType: string): contentType is "text/html";
|
|
14
12
|
shouldEnableGzip(contentType: string): boolean;
|
|
15
13
|
createResponseWithBody(body: RouteRendererBody, init?: ResponseInit): Promise<Response>;
|
|
16
14
|
createDefaultNotFoundResponse(): Promise<Response>;
|
|
17
|
-
|
|
18
|
-
|
|
15
|
+
/**
|
|
16
|
+
* Wraps already-rendered HTML in a 404 response envelope.
|
|
17
|
+
*/
|
|
18
|
+
createHtmlNotFoundResponse(body: RouteRendererBody): Promise<Response>;
|
|
19
|
+
/**
|
|
20
|
+
* Reads a static file response, returning `null` when the file is missing.
|
|
21
|
+
*/
|
|
22
|
+
createFileResponse(filePath: string, contentType: string): Promise<Response | null>;
|
|
19
23
|
}
|
|
@@ -1,17 +1,9 @@
|
|
|
1
|
-
import { STATUS_MESSAGE } from "../../constants.js";
|
|
1
|
+
import { STATUS_MESSAGE } from "../../config/constants.js";
|
|
2
2
|
import { appLogger } from "../../global/app-logger.js";
|
|
3
3
|
import { fileSystem } from "@ecopages/file-system";
|
|
4
4
|
class FileSystemServerResponseFactory {
|
|
5
|
-
appConfig;
|
|
6
|
-
routeRendererFactory;
|
|
7
5
|
options;
|
|
8
|
-
constructor({
|
|
9
|
-
appConfig,
|
|
10
|
-
routeRendererFactory,
|
|
11
|
-
options
|
|
12
|
-
}) {
|
|
13
|
-
this.appConfig = appConfig;
|
|
14
|
-
this.routeRendererFactory = routeRendererFactory;
|
|
6
|
+
constructor({ options }) {
|
|
15
7
|
this.options = options;
|
|
16
8
|
}
|
|
17
9
|
isHtml(contentType) {
|
|
@@ -34,22 +26,11 @@ class FileSystemServerResponseFactory {
|
|
|
34
26
|
status: 404
|
|
35
27
|
});
|
|
36
28
|
}
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
appLogger.debug(
|
|
43
|
-
"Custom 404 template not found, falling back to default 404 response",
|
|
44
|
-
error404TemplatePath
|
|
45
|
-
);
|
|
46
|
-
return this.createDefaultNotFoundResponse();
|
|
47
|
-
}
|
|
48
|
-
const routeRenderer = this.routeRendererFactory.createRenderer(error404TemplatePath);
|
|
49
|
-
const result = await routeRenderer.createRoute({
|
|
50
|
-
file: error404TemplatePath
|
|
51
|
-
});
|
|
52
|
-
return await this.createResponseWithBody(result.body, {
|
|
29
|
+
/**
|
|
30
|
+
* Wraps already-rendered HTML in a 404 response envelope.
|
|
31
|
+
*/
|
|
32
|
+
async createHtmlNotFoundResponse(body) {
|
|
33
|
+
return await this.createResponseWithBody(body, {
|
|
53
34
|
status: 404,
|
|
54
35
|
statusText: STATUS_MESSAGE[404],
|
|
55
36
|
headers: {
|
|
@@ -57,6 +38,9 @@ class FileSystemServerResponseFactory {
|
|
|
57
38
|
}
|
|
58
39
|
});
|
|
59
40
|
}
|
|
41
|
+
/**
|
|
42
|
+
* Reads a static file response, returning `null` when the file is missing.
|
|
43
|
+
*/
|
|
60
44
|
async createFileResponse(filePath, contentType) {
|
|
61
45
|
try {
|
|
62
46
|
let file;
|
|
@@ -88,7 +72,7 @@ class FileSystemServerResponseFactory {
|
|
|
88
72
|
} else {
|
|
89
73
|
appLogger.error("Error reading file", filePath, err);
|
|
90
74
|
}
|
|
91
|
-
return
|
|
75
|
+
return null;
|
|
92
76
|
}
|
|
93
77
|
}
|
|
94
78
|
}
|
|
@@ -1,16 +1,14 @@
|
|
|
1
|
-
import type { MatchResult } from '../../internal-types.js';
|
|
2
|
-
import type {
|
|
3
|
-
import type {
|
|
1
|
+
import type { EcoPagesAppConfig, MatchResult } from '../../types/internal-types.js';
|
|
2
|
+
import type { PageRendererResolver } from '../../route-renderer/route-renderer.js';
|
|
3
|
+
import type { RouteRegistry } from '../../router/server/route-registry.js';
|
|
4
4
|
import type { PageCacheService } from '../../services/cache/page-cache-service.js';
|
|
5
5
|
import type { CacheStrategy } from '../../services/cache/cache.types.js';
|
|
6
6
|
import type { FileSystemServerResponseFactory } from './fs-server-response-factory.js';
|
|
7
|
-
export declare const FILE_SYSTEM_RESPONSE_MATCHER_ERRORS: {
|
|
8
|
-
readonly transpilePageModuleFailed: (details: string) => string;
|
|
9
|
-
readonly noTranspiledOutputForPageModule: (filePath: string) => string;
|
|
10
|
-
};
|
|
11
7
|
export interface FileSystemResponseMatcherOptions {
|
|
12
|
-
|
|
13
|
-
|
|
8
|
+
appConfig: EcoPagesAppConfig;
|
|
9
|
+
assetPrefix: string;
|
|
10
|
+
router: RouteRegistry;
|
|
11
|
+
routeRendererFactory: PageRendererResolver;
|
|
14
12
|
fileSystemResponseFactory: FileSystemServerResponseFactory;
|
|
15
13
|
/** Optional cache service. When null, caching is disabled. */
|
|
16
14
|
cacheService?: PageCacheService | null;
|
|
@@ -20,23 +18,22 @@ export interface FileSystemResponseMatcherOptions {
|
|
|
20
18
|
/**
|
|
21
19
|
* Matches file-system routes to rendered HTML responses.
|
|
22
20
|
*
|
|
23
|
-
* This
|
|
24
|
-
* render pipeline. It coordinates page module inspection, request-local policy,
|
|
21
|
+
* This render pipeline coordinates page module inspection, request-local policy,
|
|
25
22
|
* renderer invocation, middleware execution, cache integration, and fallback
|
|
26
23
|
* error translation.
|
|
27
24
|
*/
|
|
28
25
|
export declare class FileSystemResponseMatcher {
|
|
26
|
+
private appConfig;
|
|
27
|
+
private assetPrefix;
|
|
29
28
|
private router;
|
|
30
29
|
private routeRendererFactory;
|
|
31
30
|
private fileSystemResponseFactory;
|
|
32
|
-
private pageModuleImportService;
|
|
33
31
|
private pageRequestCacheCoordinator;
|
|
34
32
|
private fileRouteMiddlewarePipeline;
|
|
35
|
-
constructor({ router, routeRendererFactory, fileSystemResponseFactory, cacheService, defaultCacheStrategy, }: FileSystemResponseMatcherOptions);
|
|
33
|
+
constructor({ appConfig, assetPrefix, router, routeRendererFactory, fileSystemResponseFactory, cacheService, defaultCacheStrategy, }: FileSystemResponseMatcherOptions);
|
|
36
34
|
/**
|
|
37
35
|
* Resolves unmatched paths either as static asset requests or as the custom
|
|
38
36
|
* not-found page.
|
|
39
|
-
*
|
|
40
37
|
* @param requestUrl Incoming pathname.
|
|
41
38
|
* @returns Static file response or rendered 404 response.
|
|
42
39
|
*/
|
|
@@ -53,12 +50,19 @@ export declare class FileSystemResponseMatcher {
|
|
|
53
50
|
* @returns Final response for the matched route.
|
|
54
51
|
*/
|
|
55
52
|
handleMatch(match: MatchResult, request?: Request): Promise<Response>;
|
|
53
|
+
/**
|
|
54
|
+
* Renders the app-owned custom 404 page, falling back to the default text 404
|
|
55
|
+
* when the page template cannot be resolved.
|
|
56
|
+
*/
|
|
57
|
+
private renderCustomNotFoundResponse;
|
|
58
|
+
private createExecutionPlan;
|
|
56
59
|
/**
|
|
57
60
|
* Loads the matched page module for request-time inspection.
|
|
58
61
|
*
|
|
59
62
|
* The matcher needs access to page-level metadata such as `cache` and
|
|
60
|
-
* `middleware` before full rendering starts, so it
|
|
61
|
-
*
|
|
63
|
+
* `middleware` before full rendering starts, so it asks the owning route
|
|
64
|
+
* renderer to load the page module. That preserves integration-specific page
|
|
65
|
+
* import setup for request-time inspection as well as for full rendering.
|
|
62
66
|
*
|
|
63
67
|
* @param filePath Absolute page module path.
|
|
64
68
|
* @returns Imported page module.
|
|
@@ -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,32 @@
|
|
|
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
|
+
if (html.includes(HMR_RUNTIME_IMPORT)) {
|
|
13
|
+
return new Response(html, {
|
|
14
|
+
status: response.status,
|
|
15
|
+
statusText: response.statusText,
|
|
16
|
+
headers: response.headers
|
|
17
|
+
});
|
|
18
|
+
}
|
|
19
|
+
const updatedHtml = html.replace(/<\/html>/i, `${HMR_RUNTIME_SCRIPT}</html>`);
|
|
20
|
+
const headers = new Headers(response.headers);
|
|
21
|
+
headers.delete("Content-Length");
|
|
22
|
+
return new Response(updatedHtml, {
|
|
23
|
+
status: response.status,
|
|
24
|
+
statusText: response.statusText,
|
|
25
|
+
headers
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
export {
|
|
29
|
+
injectHmrRuntimeIntoHtmlResponse,
|
|
30
|
+
isHtmlResponse,
|
|
31
|
+
shouldInjectHmrHtmlResponse
|
|
32
|
+
};
|
|
@@ -1,7 +1,8 @@
|
|
|
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;
|
|
5
6
|
}
|
|
6
7
|
/**
|
|
7
8
|
* Creates a render context for route handlers.
|
|
@@ -15,12 +15,14 @@ function createRenderContext(options) {
|
|
|
15
15
|
);
|
|
16
16
|
const integration = integrations.find((i) => i.name === integrationName);
|
|
17
17
|
invariant(!!integration, `No integration found for: ${integrationName}`);
|
|
18
|
-
return integration.initializeRenderer(
|
|
18
|
+
return integration.initializeRenderer({
|
|
19
|
+
rendererModules: options.rendererModules
|
|
20
|
+
});
|
|
19
21
|
};
|
|
20
|
-
|
|
22
|
+
const renderContext = {
|
|
21
23
|
async render(view, props, renderOptions) {
|
|
22
24
|
const locals = this?.locals;
|
|
23
|
-
const mergedProps = mergePropsWithLocals(props, locals);
|
|
25
|
+
const mergedProps = mergePropsWithLocals(props ?? {}, locals);
|
|
24
26
|
const renderer = getRendererForView(view);
|
|
25
27
|
const ctx = {
|
|
26
28
|
partial: false,
|
|
@@ -63,6 +65,7 @@ function createRenderContext(options) {
|
|
|
63
65
|
});
|
|
64
66
|
}
|
|
65
67
|
};
|
|
68
|
+
return renderContext;
|
|
66
69
|
}
|
|
67
70
|
export {
|
|
68
71
|
createRenderContext
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { type BuildExecutor } from '../../build/build-adapter.js';
|
|
2
|
+
import type { EcoBuildPlugin } from '../../build/build-types.js';
|
|
3
|
+
import type { EcoPagesAppConfig, IClientBridge, IHmrManager } from '../../types/internal-types.js';
|
|
4
|
+
/**
|
|
5
|
+
* Installs and returns the app-owned runtime build executor used by adapter
|
|
6
|
+
* startup and follow-up runtime work.
|
|
7
|
+
*/
|
|
8
|
+
export declare function installSharedRuntimeBuildExecutor(appConfig: EcoPagesAppConfig, options: {
|
|
9
|
+
development: boolean;
|
|
10
|
+
}): BuildExecutor;
|
|
11
|
+
/**
|
|
12
|
+
* Copies app public assets into dist and ensures the resolved assets directory
|
|
13
|
+
* exists before request handling begins.
|
|
14
|
+
*/
|
|
15
|
+
export declare function prepareSharedRuntimePublicDir(appConfig: EcoPagesAppConfig): void;
|
|
16
|
+
/**
|
|
17
|
+
* Runs runtime plugin setup against app-owned config/runtime state and optional
|
|
18
|
+
* host plugin registration hooks.
|
|
19
|
+
*/
|
|
20
|
+
export declare function initializeSharedRuntimePlugins(options: {
|
|
21
|
+
appConfig: EcoPagesAppConfig;
|
|
22
|
+
runtimeOrigin: string;
|
|
23
|
+
hmrManager?: IHmrManager;
|
|
24
|
+
onRuntimePlugin?: (plugin: unknown) => void;
|
|
25
|
+
}): Promise<void>;
|
|
26
|
+
/**
|
|
27
|
+
* Starts shared project watching for runtime adapters.
|
|
28
|
+
*/
|
|
29
|
+
export declare function startSharedProjectWatching(options: {
|
|
30
|
+
appConfig: EcoPagesAppConfig;
|
|
31
|
+
refreshRouterRoutesCallback: () => Promise<void>;
|
|
32
|
+
hmrManager: IHmrManager;
|
|
33
|
+
bridge: IClientBridge;
|
|
34
|
+
}): Promise<void>;
|
|
35
|
+
/**
|
|
36
|
+
* Binds a runtime HMR manager to app-owned plugin and integration state.
|
|
37
|
+
*/
|
|
38
|
+
export declare function bindSharedRuntimeHmrManager(appConfig: EcoPagesAppConfig, hmrManager: IHmrManager): EcoBuildPlugin[];
|