@ecopages/core 0.2.0-alpha.9 → 0.2.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +18 -11
- package/README.md +23 -26
- package/package.json +76 -58
- package/src/adapters/README.md +2 -2
- package/src/adapters/abstract/application-adapter.d.ts +28 -2
- package/src/adapters/abstract/application-adapter.js +14 -2
- package/src/adapters/abstract/router-adapter.d.ts +1 -1
- package/src/adapters/abstract/server-adapter.d.ts +2 -2
- package/src/adapters/bun/client-bridge.d.ts +1 -1
- package/src/adapters/bun/create-app.d.ts +4 -12
- package/src/adapters/bun/create-app.js +4 -5
- package/src/adapters/bun/hmr-manager.d.ts +4 -4
- package/src/adapters/bun/hmr-manager.js +8 -8
- package/src/adapters/bun/index.d.ts +1 -1
- package/src/adapters/bun/index.js +2 -2
- package/src/adapters/bun/server-adapter.d.ts +5 -5
- package/src/adapters/bun/server-adapter.js +6 -5
- package/src/adapters/bun/server-lifecycle.d.ts +4 -4
- package/src/adapters/bun/server-lifecycle.js +2 -2
- 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 +1 -5
- package/src/adapters/index.js +1 -7
- 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 +2 -2
- package/src/adapters/node/node-hmr-manager.js +3 -3
- package/src/adapters/node/server-adapter.d.ts +4 -4
- package/src/adapters/node/server-adapter.js +13 -12
- package/src/adapters/node/static-content-server.d.ts +1 -1
- package/src/adapters/node/static-content-server.js +1 -1
- package/src/adapters/shared/application-adapter.d.ts +1 -1
- package/src/adapters/shared/define-api-handler.d.ts +1 -1
- package/src/adapters/shared/explicit-static-route-matcher.d.ts +2 -2
- package/src/adapters/shared/file-route-middleware-pipeline.d.ts +1 -1
- package/src/adapters/shared/fs-server-response-factory.d.ts +2 -2
- package/src/adapters/shared/fs-server-response-factory.js +1 -1
- package/src/adapters/shared/fs-server-response-matcher.d.ts +1 -1
- package/src/adapters/shared/hmr-entrypoint-registrar.js +1 -1
- package/src/adapters/shared/hmr-html-response.d.ts +1 -1
- package/src/adapters/shared/render-context.d.ts +2 -1
- package/src/adapters/shared/render-context.js +3 -1
- package/src/adapters/shared/runtime-bootstrap.d.ts +1 -1
- package/src/adapters/shared/runtime-bootstrap.js +1 -1
- package/src/adapters/shared/server-adapter.d.ts +1 -1
- package/src/adapters/shared/server-adapter.js +5 -1
- package/src/adapters/shared/server-route-handler.d.ts +4 -4
- package/src/adapters/shared/server-route-handler.js +3 -3
- package/src/adapters/shared/server-static-builder.d.ts +5 -5
- package/src/adapters/shared/server-static-builder.js +5 -4
- package/src/build/README.md +19 -13
- package/src/build/build-adapter.d.ts +67 -20
- package/src/build/build-adapter.js +420 -19
- package/src/build/dev-build-coordinator.d.ts +10 -12
- package/src/build/dev-build-coordinator.js +8 -15
- package/src/build/esbuild-build-adapter.d.ts +6 -0
- package/src/build/esbuild-build-adapter.js +94 -11
- package/src/build/runtime-build-executor.d.ts +5 -4
- package/src/build/runtime-build-executor.js +5 -3
- package/src/build/runtime-specifier-alias-plugin.js +19 -15
- package/src/build/runtime-specifier-aliases.d.ts +5 -0
- package/src/build/runtime-specifier-aliases.js +95 -0
- package/src/config/README.md +5 -2
- package/src/config/config-builder.d.ts +25 -2
- package/src/config/config-builder.js +44 -7
- package/src/declarations.d.ts +1 -1
- package/src/dev/sc-server.d.ts +1 -1
- package/src/dev/sc-server.js +1 -1
- package/src/eco/eco.browser.d.ts +2 -0
- package/src/eco/eco.browser.js +83 -0
- package/src/eco/eco.js +19 -48
- package/src/eco/eco.types.d.ts +1 -1
- 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 +1 -1
- package/src/eco/lazy-injector-map.d.ts +1 -1
- package/src/hmr/hmr-strategy.d.ts +16 -13
- package/src/hmr/hmr-strategy.js +22 -7
- 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 +2 -2
- package/src/hmr/strategies/js-hmr-strategy.js +2 -2
- package/src/index.browser.d.ts +2 -2
- package/src/index.browser.js +1 -1
- package/src/index.d.ts +3 -2
- package/src/index.js +15 -4
- package/src/integrations/ghtml/ghtml-renderer.d.ts +6 -1
- package/src/integrations/ghtml/ghtml-renderer.js +29 -28
- package/src/integrations/ghtml/ghtml.plugin.d.ts +2 -2
- package/src/integrations/ghtml/ghtml.plugin.js +2 -2
- package/src/plugins/README.md +1 -0
- package/src/plugins/eco-component-meta-plugin.d.ts +12 -1
- package/src/plugins/eco-component-meta-plugin.js +26 -20
- 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 +99 -33
- package/src/plugins/integration-plugin.js +68 -21
- package/src/plugins/processor.d.ts +2 -2
- package/src/plugins/processor.js +2 -2
- package/src/plugins/source-transform.d.ts +46 -0
- package/src/plugins/source-transform.js +71 -0
- package/src/route-renderer/GRAPH.md +54 -84
- package/src/route-renderer/README.md +14 -20
- package/src/route-renderer/orchestration/component-render-context.d.ts +83 -0
- package/src/route-renderer/orchestration/component-render-context.js +147 -0
- package/src/route-renderer/orchestration/integration-renderer.d.ts +233 -76
- package/src/route-renderer/orchestration/integration-renderer.js +500 -143
- package/src/route-renderer/orchestration/queued-boundary-runtime.service.d.ts +93 -0
- package/src/route-renderer/orchestration/queued-boundary-runtime.service.js +155 -0
- package/src/route-renderer/orchestration/render-execution.service.d.ts +11 -71
- package/src/route-renderer/orchestration/render-execution.service.js +65 -80
- package/src/{eco/eco.utils.ts → route-renderer/orchestration/render-output.utils.d.ts} +10 -53
- package/src/route-renderer/orchestration/render-output.utils.js +65 -0
- package/src/route-renderer/orchestration/render-preparation.service.d.ts +2 -8
- package/src/route-renderer/orchestration/render-preparation.service.js +10 -17
- 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/dependency-resolver.d.ts +2 -2
- package/src/route-renderer/page-loading/dependency-resolver.js +10 -8
- package/src/route-renderer/page-loading/page-module-loader.d.ts +6 -4
- package/src/route-renderer/page-loading/page-module-loader.js +7 -5
- package/src/route-renderer/route-renderer.d.ts +5 -3
- package/src/route-renderer/route-renderer.js +13 -3
- package/src/router/README.md +79 -8
- package/src/router/client/navigation-coordinator.js +2 -2
- package/src/router/server/fs-router-scanner.d.ts +1 -1
- package/src/router/server/fs-router-scanner.js +6 -1
- package/src/router/server/fs-router.d.ts +1 -1
- package/src/services/assets/asset-processing-service/asset-processing.service.d.ts +3 -3
- package/src/services/assets/asset-processing-service/asset-processing.service.js +6 -6
- package/src/services/assets/asset-processing-service/asset.factory.d.ts +1 -1
- package/src/services/assets/asset-processing-service/asset.factory.js +2 -2
- package/src/services/assets/asset-processing-service/index.d.ts +5 -5
- package/src/services/assets/asset-processing-service/index.js +5 -5
- package/src/services/assets/asset-processing-service/processor.interface.d.ts +2 -2
- package/src/services/assets/asset-processing-service/processor.registry.d.ts +2 -2
- package/src/services/assets/asset-processing-service/processors/base/base-processor.d.ts +1 -1
- package/src/services/assets/asset-processing-service/processors/base/base-processor.js +1 -1
- package/src/services/assets/asset-processing-service/processors/base/base-script-processor.d.ts +3 -3
- package/src/services/assets/asset-processing-service/processors/base/base-script-processor.js +2 -2
- package/src/services/assets/asset-processing-service/processors/index.d.ts +5 -5
- package/src/services/assets/asset-processing-service/processors/index.js +5 -5
- package/src/services/assets/asset-processing-service/processors/script/content-script.processor.d.ts +2 -2
- package/src/services/assets/asset-processing-service/processors/script/content-script.processor.js +1 -1
- package/src/services/assets/asset-processing-service/processors/script/file-script.processor.d.ts +4 -3
- package/src/services/assets/asset-processing-service/processors/script/file-script.processor.js +15 -3
- package/src/services/assets/asset-processing-service/processors/script/node-module-script.processor.d.ts +3 -3
- package/src/services/assets/asset-processing-service/processors/script/node-module-script.processor.js +1 -1
- package/src/services/assets/asset-processing-service/processors/stylesheet/content-stylesheet.processor.d.ts +2 -2
- package/src/services/assets/asset-processing-service/processors/stylesheet/content-stylesheet.processor.js +1 -1
- package/src/services/assets/asset-processing-service/processors/stylesheet/file-stylesheet.processor.d.ts +2 -2
- package/src/services/assets/asset-processing-service/processors/stylesheet/file-stylesheet.processor.js +1 -1
- package/src/services/assets/browser-bundle.service.d.ts +1 -1
- package/src/services/assets/browser-bundle.service.js +2 -2
- package/src/services/html/html-rewriter-provider.service.js +4 -1
- package/src/services/html/html-transformer.service.d.ts +2 -2
- package/src/services/html/html-transformer.service.js +4 -10
- package/src/services/invalidation/development-invalidation.service.d.ts +1 -1
- package/src/services/invalidation/development-invalidation.service.js +1 -0
- package/src/services/module-loading/app-module-loader.service.d.ts +25 -0
- package/src/services/module-loading/app-module-loader.service.js +31 -0
- package/src/services/module-loading/app-server-module-transpiler.service.d.ts +9 -1
- package/src/services/module-loading/app-server-module-transpiler.service.js +77 -2
- 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/{adapters/node/bootstrap-dependency-resolver.d.ts → services/module-loading/node-bootstrap-plugin.d.ts} +2 -24
- package/src/{adapters/node/bootstrap-dependency-resolver.js → services/module-loading/node-bootstrap-plugin.js} +42 -22
- package/src/services/module-loading/page-module-import.service.d.ts +4 -0
- package/src/services/module-loading/page-module-import.service.js +38 -9
- package/src/services/module-loading/server-module-transpiler.service.d.ts +3 -0
- package/src/services/module-loading/server-module-transpiler.service.js +4 -1
- package/src/services/runtime-state/dev-graph.service.d.ts +6 -6
- package/src/services/runtime-state/dev-graph.service.js +10 -10
- package/src/services/runtime-state/entrypoint-dependency-graph.service.d.ts +1 -1
- package/src/services/runtime-state/runtime-specifier-registry.service.d.ts +1 -1
- package/src/services/runtime-state/server-invalidation-state.service.d.ts +1 -1
- package/src/static-site-generator/static-site-generator.d.ts +2 -2
- package/src/static-site-generator/static-site-generator.js +1 -1
- package/src/{internal-types.d.ts → types/internal-types.d.ts} +24 -14
- package/src/{public-types.d.ts → types/public-types.d.ts} +30 -14
- 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.js +1 -1
- package/src/watchers/project-watcher.d.ts +4 -4
- package/src/watchers/project-watcher.js +4 -10
- package/src/watchers/project-watcher.test-helpers.d.ts +2 -2
- 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/hmr-manager.ts +0 -409
- package/src/adapters/bun/index.ts +0 -2
- package/src/adapters/bun/server-adapter.ts +0 -499
- package/src/adapters/bun/server-lifecycle.ts +0 -124
- package/src/adapters/index.ts +0 -6
- package/src/adapters/node/bootstrap-dependency-resolver.ts +0 -301
- package/src/adapters/node/create-app.ts +0 -179
- package/src/adapters/node/index.d.ts +0 -6
- package/src/adapters/node/index.js +0 -11
- package/src/adapters/node/index.ts +0 -16
- package/src/adapters/node/node-client-bridge.ts +0 -79
- package/src/adapters/node/node-hmr-manager.ts +0 -381
- package/src/adapters/node/runtime-adapter.d.ts +0 -46
- package/src/adapters/node/runtime-adapter.js +0 -306
- package/src/adapters/node/runtime-adapter.ts +0 -439
- package/src/adapters/node/server-adapter.ts +0 -488
- package/src/adapters/node/static-content-server.ts +0 -239
- package/src/adapters/node/write-runtime-manifest.d.ts +0 -26
- package/src/adapters/node/write-runtime-manifest.js +0 -12
- package/src/adapters/node/write-runtime-manifest.ts +0 -38
- package/src/adapters/shared/api-response.ts +0 -104
- package/src/adapters/shared/application-adapter.ts +0 -199
- package/src/adapters/shared/define-api-handler.ts +0 -66
- package/src/adapters/shared/explicit-static-route-matcher.ts +0 -140
- package/src/adapters/shared/file-route-middleware-pipeline.ts +0 -127
- package/src/adapters/shared/fs-server-response-factory.ts +0 -118
- package/src/adapters/shared/fs-server-response-matcher.ts +0 -205
- package/src/adapters/shared/hmr-entrypoint-registrar.ts +0 -149
- package/src/adapters/shared/hmr-html-response.ts +0 -52
- package/src/adapters/shared/render-context.ts +0 -120
- package/src/adapters/shared/runtime-bootstrap.ts +0 -79
- package/src/adapters/shared/server-adapter.ts +0 -489
- package/src/adapters/shared/server-route-handler.ts +0 -153
- package/src/adapters/shared/server-static-builder.ts +0 -166
- package/src/build/build-adapter.ts +0 -361
- package/src/build/build-manifest.ts +0 -54
- package/src/build/build-types.ts +0 -83
- package/src/build/dev-build-coordinator.ts +0 -221
- package/src/build/esbuild-build-adapter.ts +0 -559
- package/src/build/runtime-build-executor.ts +0 -34
- package/src/build/runtime-specifier-alias-plugin.ts +0 -58
- package/src/config/config-builder.ts +0 -706
- package/src/constants.ts +0 -54
- package/src/create-app.ts +0 -87
- 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 -87
- package/src/eco/component-render-context.ts +0 -224
- package/src/eco/eco.ts +0 -242
- package/src/eco/eco.types.ts +0 -221
- 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 -152
- package/src/hmr/hmr-strategy.ts +0 -172
- package/src/hmr/hmr.postcss.test.e2e.ts +0 -41
- package/src/hmr/hmr.test.e2e.ts +0 -66
- 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 -96
- package/src/integrations/ghtml/ghtml.plugin.ts +0 -32
- package/src/internal-types.ts +0 -232
- package/src/plugins/alias-resolver-plugin.ts +0 -63
- package/src/plugins/eco-component-meta-plugin.ts +0 -481
- package/src/plugins/integration-plugin.ts +0 -226
- package/src/plugins/processor.ts +0 -240
- package/src/plugins/runtime-capability.ts +0 -14
- package/src/public-types.ts +0 -1317
- package/src/route-renderer/component-graph/component-graph-executor.d.ts +0 -32
- package/src/route-renderer/component-graph/component-graph-executor.js +0 -31
- package/src/route-renderer/component-graph/component-graph-executor.ts +0 -84
- package/src/route-renderer/component-graph/component-graph.d.ts +0 -42
- package/src/route-renderer/component-graph/component-graph.js +0 -72
- package/src/route-renderer/component-graph/component-graph.ts +0 -159
- package/src/route-renderer/component-graph/component-marker.d.ts +0 -52
- package/src/route-renderer/component-graph/component-marker.js +0 -46
- package/src/route-renderer/component-graph/component-marker.ts +0 -117
- package/src/route-renderer/component-graph/component-reference.d.ts +0 -10
- package/src/route-renderer/component-graph/component-reference.js +0 -19
- package/src/route-renderer/component-graph/component-reference.ts +0 -29
- package/src/route-renderer/component-graph/marker-graph-resolver.d.ts +0 -77
- package/src/route-renderer/component-graph/marker-graph-resolver.js +0 -95
- package/src/route-renderer/component-graph/marker-graph-resolver.ts +0 -155
- package/src/route-renderer/orchestration/integration-renderer.ts +0 -790
- package/src/route-renderer/orchestration/render-execution.service.ts +0 -230
- package/src/route-renderer/orchestration/render-preparation.service.ts +0 -476
- package/src/route-renderer/page-loading/dependency-resolver.ts +0 -612
- package/src/route-renderer/page-loading/page-module-loader.ts +0 -181
- package/src/route-renderer/route-renderer.ts +0 -115
- package/src/router/client/link-intent.test.browser.ts +0 -51
- package/src/router/client/link-intent.ts +0 -92
- package/src/router/client/navigation-coordinator.ts +0 -433
- package/src/router/server/fs-router-scanner.ts +0 -219
- package/src/router/server/fs-router.ts +0 -122
- package/src/services/assets/asset-processing-service/asset-processing.service.ts +0 -401
- package/src/services/assets/asset-processing-service/asset.factory.ts +0 -105
- package/src/services/assets/asset-processing-service/assets.types.ts +0 -113
- package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.ts +0 -95
- package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.ts +0 -78
- package/src/services/assets/asset-processing-service/index.ts +0 -5
- package/src/services/assets/asset-processing-service/processor.interface.ts +0 -27
- package/src/services/assets/asset-processing-service/processor.registry.ts +0 -18
- package/src/services/assets/asset-processing-service/processors/base/base-processor.ts +0 -82
- package/src/services/assets/asset-processing-service/processors/base/base-script-processor.ts +0 -95
- package/src/services/assets/asset-processing-service/processors/index.ts +0 -5
- package/src/services/assets/asset-processing-service/processors/script/content-script.processor.ts +0 -66
- package/src/services/assets/asset-processing-service/processors/script/file-script.processor.ts +0 -88
- package/src/services/assets/asset-processing-service/processors/script/node-module-script.processor.ts +0 -85
- package/src/services/assets/asset-processing-service/processors/stylesheet/content-stylesheet.processor.ts +0 -27
- package/src/services/assets/asset-processing-service/processors/stylesheet/file-stylesheet.processor.ts +0 -80
- package/src/services/assets/browser-bundle.service.ts +0 -53
- 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/cache/page-request-cache-coordinator.service.ts +0 -131
- package/src/services/html/html-rewriter-provider.service.ts +0 -103
- package/src/services/html/html-transformer.service.ts +0 -279
- package/src/services/invalidation/development-invalidation.service.ts +0 -261
- package/src/services/module-loading/app-server-module-transpiler.service.ts +0 -52
- package/src/services/module-loading/page-module-import.service.ts +0 -200
- package/src/services/module-loading/server-loader.service.d.ts +0 -96
- package/src/services/module-loading/server-loader.service.js +0 -32
- package/src/services/module-loading/server-loader.service.ts +0 -130
- package/src/services/module-loading/server-module-transpiler.service.ts +0 -105
- package/src/services/runtime-manifest/node-runtime-manifest.service.d.ts +0 -35
- package/src/services/runtime-manifest/node-runtime-manifest.service.js +0 -60
- package/src/services/runtime-manifest/node-runtime-manifest.service.ts +0 -101
- package/src/services/runtime-state/dev-graph.service.ts +0 -217
- package/src/services/runtime-state/entrypoint-dependency-graph.service.ts +0 -136
- package/src/services/runtime-state/runtime-specifier-registry.service.ts +0 -96
- package/src/services/runtime-state/server-invalidation-state.service.ts +0 -68
- package/src/services/validation/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 -462
- 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/resolve-work-dir.ts +0 -45
- 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 -363
- /package/src/{constants.d.ts → config/constants.d.ts} +0 -0
- /package/src/{constants.js → config/constants.js} +0 -0
- /package/src/{internal-types.js → services/module-loading/module-loading-types.js} +0 -0
- /package/src/{public-types.js → types/internal-types.js} +0 -0
|
@@ -1,202 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Page cache service with ISR (Incremental Static Regeneration) support.
|
|
3
|
-
* Handles stale-while-revalidate semantics and background regeneration.
|
|
4
|
-
* @module
|
|
5
|
-
*/
|
|
6
|
-
|
|
7
|
-
import { appLogger } from '../../global/app-logger.js';
|
|
8
|
-
import type { CacheEntry, CacheResult, CacheStore, CacheStrategy, RenderResult } from './cache.types.js';
|
|
9
|
-
import { MemoryCacheStore } from './memory-cache-store.js';
|
|
10
|
-
|
|
11
|
-
export interface PageCacheServiceOptions {
|
|
12
|
-
store?: CacheStore;
|
|
13
|
-
enabled?: boolean;
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
/**
|
|
17
|
-
* Core page caching service with ISR support.
|
|
18
|
-
*/
|
|
19
|
-
export class PageCacheService {
|
|
20
|
-
private store: CacheStore;
|
|
21
|
-
private enabled: boolean;
|
|
22
|
-
private regenerationPromises = new Map<string, Promise<string>>();
|
|
23
|
-
|
|
24
|
-
constructor(options: PageCacheServiceOptions = {}) {
|
|
25
|
-
this.store = options.store ?? new MemoryCacheStore();
|
|
26
|
-
this.enabled = options.enabled ?? true;
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
/**
|
|
30
|
-
* Generate a cache key from URL and optional params.
|
|
31
|
-
* Uses full URL (path + query) as the key.
|
|
32
|
-
*/
|
|
33
|
-
generateCacheKey(url: string): string {
|
|
34
|
-
return url;
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
/**
|
|
38
|
-
* Check if an entry is stale (past its revalidation time).
|
|
39
|
-
*/
|
|
40
|
-
private isStale(entry: CacheEntry): boolean {
|
|
41
|
-
if (entry.revalidateAfter === null) return false;
|
|
42
|
-
return Date.now() > entry.revalidateAfter;
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
/**
|
|
46
|
-
* Create a cache entry from rendered HTML.
|
|
47
|
-
*/
|
|
48
|
-
private createEntry(html: string, strategy: CacheStrategy): CacheEntry {
|
|
49
|
-
const now = Date.now();
|
|
50
|
-
|
|
51
|
-
let revalidateAfter: number | null = null;
|
|
52
|
-
let tags: string[] = [];
|
|
53
|
-
|
|
54
|
-
if (strategy === 'static') {
|
|
55
|
-
revalidateAfter = null;
|
|
56
|
-
} else if (strategy === 'dynamic') {
|
|
57
|
-
revalidateAfter = 0;
|
|
58
|
-
} else if (typeof strategy === 'object') {
|
|
59
|
-
revalidateAfter = now + strategy.revalidate * 1000;
|
|
60
|
-
tags = strategy.tags ?? [];
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
return {
|
|
64
|
-
html,
|
|
65
|
-
createdAt: now,
|
|
66
|
-
revalidateAfter,
|
|
67
|
-
tags,
|
|
68
|
-
strategy,
|
|
69
|
-
};
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
/**
|
|
73
|
-
* Get cached content or create new content with stale-while-revalidate semantics.
|
|
74
|
-
* @param key - Cache key (URL path + query)
|
|
75
|
-
* @param defaultStrategy - Default strategy if page doesn't specify one
|
|
76
|
-
* @param renderFn - Function that renders the page and returns HTML + strategy
|
|
77
|
-
*/
|
|
78
|
-
async getOrCreate(
|
|
79
|
-
key: string,
|
|
80
|
-
defaultStrategy: CacheStrategy,
|
|
81
|
-
renderFn: () => Promise<RenderResult>,
|
|
82
|
-
): Promise<CacheResult> {
|
|
83
|
-
if (!this.enabled) {
|
|
84
|
-
const { html, strategy } = await renderFn();
|
|
85
|
-
return { html, status: 'miss', strategy };
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
const entry = await this.store.get(key);
|
|
89
|
-
|
|
90
|
-
if (!entry) {
|
|
91
|
-
const { html, strategy } = await renderFn();
|
|
92
|
-
const effectiveStrategy = strategy ?? defaultStrategy;
|
|
93
|
-
|
|
94
|
-
if (effectiveStrategy === 'dynamic') {
|
|
95
|
-
return { html, status: 'miss', strategy: effectiveStrategy };
|
|
96
|
-
}
|
|
97
|
-
|
|
98
|
-
const newEntry = this.createEntry(html, effectiveStrategy);
|
|
99
|
-
await this.store.set(key, newEntry);
|
|
100
|
-
return { html, status: 'miss', strategy: effectiveStrategy };
|
|
101
|
-
}
|
|
102
|
-
|
|
103
|
-
if (!this.isStale(entry)) {
|
|
104
|
-
return { html: entry.html, status: 'hit', strategy: entry.strategy };
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
this.regenerateInBackground(key, entry.strategy, renderFn);
|
|
108
|
-
return { html: entry.html, status: 'stale', strategy: entry.strategy };
|
|
109
|
-
}
|
|
110
|
-
|
|
111
|
-
/**
|
|
112
|
-
* Regenerate content in the background without blocking the response.
|
|
113
|
-
* Uses promise deduplication to prevent multiple concurrent regenerations.
|
|
114
|
-
*/
|
|
115
|
-
private regenerateInBackground(
|
|
116
|
-
key: string,
|
|
117
|
-
fallbackStrategy: CacheStrategy,
|
|
118
|
-
renderFn: () => Promise<{ html: string; strategy: CacheStrategy }>,
|
|
119
|
-
): void {
|
|
120
|
-
if (this.regenerationPromises.has(key)) {
|
|
121
|
-
return;
|
|
122
|
-
}
|
|
123
|
-
|
|
124
|
-
const regeneratePromise = (async () => {
|
|
125
|
-
try {
|
|
126
|
-
const { html, strategy } = await renderFn();
|
|
127
|
-
const effectiveStrategy = strategy ?? fallbackStrategy;
|
|
128
|
-
const newEntry = this.createEntry(html, effectiveStrategy);
|
|
129
|
-
await this.store.set(key, newEntry);
|
|
130
|
-
return html;
|
|
131
|
-
} finally {
|
|
132
|
-
this.regenerationPromises.delete(key);
|
|
133
|
-
}
|
|
134
|
-
})();
|
|
135
|
-
|
|
136
|
-
this.regenerationPromises.set(key, regeneratePromise);
|
|
137
|
-
|
|
138
|
-
queueMicrotask(() => {
|
|
139
|
-
regeneratePromise.catch((error) => {
|
|
140
|
-
appLogger.error(`[PageCacheService] Failed to regenerate: ${key}`, error);
|
|
141
|
-
});
|
|
142
|
-
});
|
|
143
|
-
}
|
|
144
|
-
|
|
145
|
-
/**
|
|
146
|
-
* Invalidate cache entries by tags.
|
|
147
|
-
*/
|
|
148
|
-
async invalidateByTags(tags: string[]): Promise<number> {
|
|
149
|
-
return this.store.invalidateByTags(tags);
|
|
150
|
-
}
|
|
151
|
-
|
|
152
|
-
/**
|
|
153
|
-
* Invalidate cache entries by paths.
|
|
154
|
-
*/
|
|
155
|
-
async invalidateByPaths(paths: string[]): Promise<number> {
|
|
156
|
-
return this.store.invalidateByPaths(paths);
|
|
157
|
-
}
|
|
158
|
-
|
|
159
|
-
/**
|
|
160
|
-
* Clear all cached entries.
|
|
161
|
-
*/
|
|
162
|
-
async clear(): Promise<void> {
|
|
163
|
-
return this.store.clear();
|
|
164
|
-
}
|
|
165
|
-
|
|
166
|
-
/**
|
|
167
|
-
* Get cache statistics.
|
|
168
|
-
*/
|
|
169
|
-
async stats() {
|
|
170
|
-
return this.store.stats?.() ?? { entries: 0 };
|
|
171
|
-
}
|
|
172
|
-
|
|
173
|
-
/**
|
|
174
|
-
* Get the underlying cache store.
|
|
175
|
-
*/
|
|
176
|
-
getStore(): CacheStore {
|
|
177
|
-
return this.store;
|
|
178
|
-
}
|
|
179
|
-
}
|
|
180
|
-
|
|
181
|
-
/**
|
|
182
|
-
* Generate Cache-Control header value from cache strategy.
|
|
183
|
-
*/
|
|
184
|
-
export function getCacheControlHeader(strategy: CacheStrategy | 'disabled'): string {
|
|
185
|
-
if (strategy === 'disabled') {
|
|
186
|
-
return 'no-store, must-revalidate';
|
|
187
|
-
}
|
|
188
|
-
if (strategy === 'static') {
|
|
189
|
-
return 'public, max-age=31536000, immutable';
|
|
190
|
-
}
|
|
191
|
-
|
|
192
|
-
if (strategy === 'dynamic') {
|
|
193
|
-
return 'no-store, must-revalidate';
|
|
194
|
-
}
|
|
195
|
-
|
|
196
|
-
if (typeof strategy === 'object') {
|
|
197
|
-
const swr = strategy.revalidate * 2;
|
|
198
|
-
return `public, max-age=${strategy.revalidate}, stale-while-revalidate=${swr}`;
|
|
199
|
-
}
|
|
200
|
-
|
|
201
|
-
return 'no-store';
|
|
202
|
-
}
|
|
@@ -1,131 +0,0 @@
|
|
|
1
|
-
import { getCacheControlHeader, type PageCacheService } from './page-cache-service.js';
|
|
2
|
-
import type { CacheStrategy, RenderResult } from './cache.types.js';
|
|
3
|
-
|
|
4
|
-
type CacheStatus = 'hit' | 'miss' | 'stale' | 'expired' | 'disabled';
|
|
5
|
-
|
|
6
|
-
/**
|
|
7
|
-
* Coordinates request-time page caching concerns around one render invocation.
|
|
8
|
-
*
|
|
9
|
-
* This service keeps `FileSystemResponseMatcher` from owning low-level cache
|
|
10
|
-
* policy mechanics such as cache key construction, `dynamic` bypass behavior,
|
|
11
|
-
* body normalization for cache storage, and final cache header generation.
|
|
12
|
-
*/
|
|
13
|
-
export class PageRequestCacheCoordinator {
|
|
14
|
-
private cacheService: PageCacheService | null;
|
|
15
|
-
private defaultCacheStrategy: CacheStrategy;
|
|
16
|
-
|
|
17
|
-
constructor(cacheService: PageCacheService | null, defaultCacheStrategy: CacheStrategy) {
|
|
18
|
-
this.cacheService = cacheService;
|
|
19
|
-
this.defaultCacheStrategy = defaultCacheStrategy;
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
/**
|
|
23
|
-
* Builds the cache key used for page lookups.
|
|
24
|
-
*
|
|
25
|
-
* Query parameters are part of the key so two requests that hit the same
|
|
26
|
-
* pathname but differ by search params do not share the same rendered entry.
|
|
27
|
-
*
|
|
28
|
-
* @param input Pathname plus optional query record.
|
|
29
|
-
* @returns Stable cache key for the request.
|
|
30
|
-
*/
|
|
31
|
-
buildCacheKey(input: { pathname: string; query?: Record<string, string> }): string {
|
|
32
|
-
let key = input.pathname;
|
|
33
|
-
if (input.query && Object.keys(input.query).length > 0) {
|
|
34
|
-
const queryString = new URLSearchParams(input.query).toString();
|
|
35
|
-
key += `?${queryString}`;
|
|
36
|
-
}
|
|
37
|
-
return key;
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
/**
|
|
41
|
-
* Resolves a render request through the configured cache policy.
|
|
42
|
-
*
|
|
43
|
-
* Pages using `dynamic` rendering, or applications without a cache service,
|
|
44
|
-
* bypass cache lookup entirely and still receive the same response header
|
|
45
|
-
* contract as cached pages.
|
|
46
|
-
*
|
|
47
|
-
* @param options Cache coordination inputs for one page request.
|
|
48
|
-
* @returns HTTP response with cache headers applied.
|
|
49
|
-
*/
|
|
50
|
-
async render(options: {
|
|
51
|
-
cacheKey: string;
|
|
52
|
-
pageCacheStrategy: CacheStrategy;
|
|
53
|
-
renderFn: () => Promise<RenderResult>;
|
|
54
|
-
}): Promise<Response> {
|
|
55
|
-
if (!this.cacheService || options.pageCacheStrategy === 'dynamic') {
|
|
56
|
-
const { html, strategy } = await options.renderFn();
|
|
57
|
-
return this.createCachedResponse(html, strategy, 'disabled');
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
const result = await this.cacheService.getOrCreate(
|
|
61
|
-
options.cacheKey,
|
|
62
|
-
options.pageCacheStrategy,
|
|
63
|
-
options.renderFn,
|
|
64
|
-
);
|
|
65
|
-
|
|
66
|
-
return this.createCachedResponse(result.html, result.strategy, result.status);
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
/**
|
|
70
|
-
* Exposes the underlying cache service for invalidation and adapter plumbing.
|
|
71
|
-
*
|
|
72
|
-
* @returns Configured cache service or `null` when caching is disabled.
|
|
73
|
-
*/
|
|
74
|
-
getCacheService(): PageCacheService | null {
|
|
75
|
-
return this.cacheService;
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
/**
|
|
79
|
-
* Returns the default render strategy used when a page does not declare one.
|
|
80
|
-
*
|
|
81
|
-
* @returns Application-level fallback cache strategy.
|
|
82
|
-
*/
|
|
83
|
-
getDefaultCacheStrategy(): CacheStrategy {
|
|
84
|
-
return this.defaultCacheStrategy;
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
/**
|
|
88
|
-
* Normalizes various route render body shapes into a cacheable string.
|
|
89
|
-
*
|
|
90
|
-
* Page rendering may produce strings, buffers, byte arrays, or streams. The
|
|
91
|
-
* matcher needs a single representation before passing HTML through the cache
|
|
92
|
-
* layer, so this method centralizes the conversion rules.
|
|
93
|
-
*
|
|
94
|
-
* @param body Render output body in any supported form.
|
|
95
|
-
* @returns HTML string representation.
|
|
96
|
-
*/
|
|
97
|
-
async bodyToString(body: unknown): Promise<string> {
|
|
98
|
-
if (typeof body === 'string') {
|
|
99
|
-
return body;
|
|
100
|
-
}
|
|
101
|
-
if (Buffer.isBuffer(body)) {
|
|
102
|
-
return body.toString('utf-8');
|
|
103
|
-
}
|
|
104
|
-
if (body instanceof ReadableStream) {
|
|
105
|
-
return new Response(body).text();
|
|
106
|
-
}
|
|
107
|
-
if (body instanceof Uint8Array) {
|
|
108
|
-
return new TextDecoder().decode(body);
|
|
109
|
-
}
|
|
110
|
-
return String(body);
|
|
111
|
-
}
|
|
112
|
-
|
|
113
|
-
/**
|
|
114
|
-
* Creates the final HTML response with the current cache semantics encoded in
|
|
115
|
-
* response headers.
|
|
116
|
-
*
|
|
117
|
-
* @param html Rendered page HTML.
|
|
118
|
-
* @param strategy Effective cache strategy for the response.
|
|
119
|
-
* @param cacheStatus Status used for `X-Cache` and `Cache-Control` generation.
|
|
120
|
-
* @returns HTTP response ready to send to the client.
|
|
121
|
-
*/
|
|
122
|
-
private createCachedResponse(html: string, strategy: CacheStrategy, cacheStatus: CacheStatus): Response {
|
|
123
|
-
const headers: HeadersInit = {
|
|
124
|
-
'Content-Type': 'text/html',
|
|
125
|
-
'Cache-Control': getCacheControlHeader(cacheStatus === 'disabled' ? 'disabled' : strategy),
|
|
126
|
-
'X-Cache': cacheStatus.toUpperCase(),
|
|
127
|
-
};
|
|
128
|
-
|
|
129
|
-
return new Response(html, { headers });
|
|
130
|
-
}
|
|
131
|
-
}
|
|
@@ -1,103 +0,0 @@
|
|
|
1
|
-
import { appLogger } from '../../global/app-logger.js';
|
|
2
|
-
|
|
3
|
-
export type HtmlRewriterElement = {
|
|
4
|
-
append(content: string, options?: { html?: boolean }): void;
|
|
5
|
-
};
|
|
6
|
-
|
|
7
|
-
export type HtmlRewriterRuntime = {
|
|
8
|
-
on(selector: 'head' | 'body', handler: { element: (element: HtmlRewriterElement) => void }): HtmlRewriterRuntime;
|
|
9
|
-
transform(response: Response): Response;
|
|
10
|
-
};
|
|
11
|
-
|
|
12
|
-
export type HtmlRewriterConstructor = new () => HtmlRewriterRuntime;
|
|
13
|
-
|
|
14
|
-
export type HtmlRewriterMode = 'auto' | 'native' | 'worker-tools' | 'fallback';
|
|
15
|
-
|
|
16
|
-
export interface HtmlRewriterProvider {
|
|
17
|
-
createHtmlRewriter(): Promise<HtmlRewriterRuntime | null>;
|
|
18
|
-
setMode(mode: HtmlRewriterMode): void;
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
export interface HtmlRewriterLogger {
|
|
22
|
-
warn(message: string): void;
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
export interface DefaultHtmlRewriterProviderOptions {
|
|
26
|
-
mode?: HtmlRewriterMode;
|
|
27
|
-
logger?: HtmlRewriterLogger;
|
|
28
|
-
getNativeHtmlRewriter?: () => HtmlRewriterConstructor | undefined;
|
|
29
|
-
loadWorkerToolsHtmlRewriter?: () => Promise<HtmlRewriterConstructor | null>;
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
export class DefaultHtmlRewriterProvider implements HtmlRewriterProvider {
|
|
33
|
-
private htmlRewriterConstructorPromise?: Promise<HtmlRewriterConstructor | null>;
|
|
34
|
-
private htmlRewriterMode: HtmlRewriterMode;
|
|
35
|
-
private logger: HtmlRewriterLogger;
|
|
36
|
-
private getNativeHtmlRewriter: () => HtmlRewriterConstructor | undefined;
|
|
37
|
-
private loadWorkerToolsHtmlRewriter: () => Promise<HtmlRewriterConstructor | null>;
|
|
38
|
-
|
|
39
|
-
constructor(options: DefaultHtmlRewriterProviderOptions = {}) {
|
|
40
|
-
this.htmlRewriterMode = options.mode ?? 'auto';
|
|
41
|
-
this.logger = options.logger ?? appLogger;
|
|
42
|
-
this.getNativeHtmlRewriter =
|
|
43
|
-
options.getNativeHtmlRewriter ??
|
|
44
|
-
(() => (globalThis as { HTMLRewriter?: HtmlRewriterConstructor }).HTMLRewriter);
|
|
45
|
-
this.loadWorkerToolsHtmlRewriter = options.loadWorkerToolsHtmlRewriter ?? loadWorkerToolsHtmlRewriter;
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
setMode(mode: HtmlRewriterMode) {
|
|
49
|
-
this.htmlRewriterMode = mode;
|
|
50
|
-
this.htmlRewriterConstructorPromise = undefined;
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
async createHtmlRewriter(): Promise<HtmlRewriterRuntime | null> {
|
|
54
|
-
const RuntimeHtmlRewriter = await this.resolveHtmlRewriterConstructor();
|
|
55
|
-
return RuntimeHtmlRewriter ? new RuntimeHtmlRewriter() : null;
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
private async resolveHtmlRewriterConstructor(): Promise<HtmlRewriterConstructor | null> {
|
|
59
|
-
if (!this.htmlRewriterConstructorPromise) {
|
|
60
|
-
const mode = this.htmlRewriterMode;
|
|
61
|
-
const RuntimeHtmlRewriter = this.getNativeHtmlRewriter();
|
|
62
|
-
|
|
63
|
-
if (mode === 'fallback') {
|
|
64
|
-
this.htmlRewriterConstructorPromise = Promise.resolve(null);
|
|
65
|
-
} else if (mode === 'native') {
|
|
66
|
-
if (RuntimeHtmlRewriter) {
|
|
67
|
-
this.htmlRewriterConstructorPromise = Promise.resolve(RuntimeHtmlRewriter);
|
|
68
|
-
} else {
|
|
69
|
-
this.logger.warn(
|
|
70
|
-
'[HtmlTransformerService] Native HTMLRewriter was forced but is unavailable, falling back to string injection.',
|
|
71
|
-
);
|
|
72
|
-
this.htmlRewriterConstructorPromise = Promise.resolve(null);
|
|
73
|
-
}
|
|
74
|
-
} else if (mode === 'auto' && RuntimeHtmlRewriter) {
|
|
75
|
-
this.htmlRewriterConstructorPromise = Promise.resolve(RuntimeHtmlRewriter);
|
|
76
|
-
} else {
|
|
77
|
-
this.htmlRewriterConstructorPromise = this.loadWorkerToolsHtmlRewriter();
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
return this.htmlRewriterConstructorPromise;
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
async function loadWorkerToolsHtmlRewriter(): Promise<HtmlRewriterConstructor | null> {
|
|
86
|
-
try {
|
|
87
|
-
const module = await import('@worker-tools/html-rewriter/base64');
|
|
88
|
-
return module.HTMLRewriter as HtmlRewriterConstructor;
|
|
89
|
-
} catch (primaryError) {
|
|
90
|
-
try {
|
|
91
|
-
const runtimeLocalModule = await import(
|
|
92
|
-
new URL('../node_modules/@worker-tools/html-rewriter/base64.js', import.meta.url).href
|
|
93
|
-
);
|
|
94
|
-
return runtimeLocalModule.HTMLRewriter as HtmlRewriterConstructor;
|
|
95
|
-
} catch {
|
|
96
|
-
const message = primaryError instanceof Error ? primaryError.message : String(primaryError);
|
|
97
|
-
appLogger.warn(
|
|
98
|
-
`[HtmlTransformerService] Failed to load @worker-tools/html-rewriter/base64, falling back to string injection: ${message}`,
|
|
99
|
-
);
|
|
100
|
-
return null;
|
|
101
|
-
}
|
|
102
|
-
}
|
|
103
|
-
}
|