@ecopages/core 0.2.0-alpha.2 → 0.2.0-alpha.20
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 +26 -64
- package/README.md +212 -14
- package/package.json +116 -66
- package/src/adapters/README.md +39 -0
- package/src/adapters/abstract/application-adapter.d.ts +28 -2
- package/src/adapters/abstract/application-adapter.js +14 -2
- package/src/adapters/abstract/router-adapter.d.ts +1 -1
- package/src/adapters/abstract/server-adapter.d.ts +2 -2
- package/src/adapters/bun/client-bridge.d.ts +1 -1
- package/src/adapters/bun/create-app.d.ts +4 -12
- package/src/adapters/bun/create-app.js +4 -5
- package/src/adapters/bun/hmr-manager.d.ts +80 -21
- package/src/adapters/bun/hmr-manager.js +168 -62
- package/src/adapters/bun/index.d.ts +2 -3
- package/src/adapters/bun/index.js +3 -3
- package/src/adapters/bun/server-adapter.d.ts +5 -5
- package/src/adapters/bun/server-adapter.js +40 -34
- package/src/adapters/bun/server-lifecycle.d.ts +28 -17
- package/src/adapters/bun/server-lifecycle.js +34 -62
- package/src/{create-app.d.ts → adapters/create-app.d.ts} +9 -6
- package/src/{create-app.js → adapters/create-app.js} +4 -4
- package/src/adapters/index.d.ts +2 -6
- package/src/adapters/index.js +2 -8
- package/src/adapters/node/create-app.d.ts +6 -9
- package/src/adapters/node/create-app.js +12 -6
- package/src/adapters/node/node-client-bridge.d.ts +1 -1
- package/src/adapters/node/node-hmr-manager.d.ts +89 -18
- package/src/adapters/node/node-hmr-manager.js +185 -95
- package/src/adapters/node/server-adapter.d.ts +6 -35
- package/src/adapters/node/server-adapter.js +44 -105
- package/src/adapters/node/static-content-server.d.ts +37 -1
- package/src/adapters/node/static-content-server.js +29 -1
- package/src/adapters/shared/application-adapter.d.ts +1 -1
- package/src/{define-api-handler.d.ts → adapters/shared/define-api-handler.d.ts} +1 -1
- package/src/adapters/shared/explicit-static-route-matcher.d.ts +2 -2
- package/src/adapters/shared/explicit-static-route-matcher.js +4 -1
- package/src/adapters/shared/file-route-middleware-pipeline.d.ts +1 -1
- package/src/adapters/shared/file-route-middleware-pipeline.js +1 -0
- package/src/adapters/shared/fs-server-response-factory.d.ts +2 -2
- package/src/adapters/shared/fs-server-response-factory.js +1 -1
- package/src/adapters/shared/fs-server-response-matcher.d.ts +8 -12
- package/src/adapters/shared/fs-server-response-matcher.js +10 -18
- package/src/adapters/shared/hmr-entrypoint-registrar.d.ts +55 -0
- package/src/adapters/shared/hmr-entrypoint-registrar.js +87 -0
- package/src/adapters/shared/hmr-html-response.d.ts +22 -0
- package/src/adapters/shared/hmr-html-response.js +32 -0
- package/src/adapters/shared/render-context.d.ts +2 -1
- package/src/adapters/shared/render-context.js +6 -3
- package/src/adapters/shared/runtime-bootstrap.d.ts +38 -0
- package/src/adapters/shared/runtime-bootstrap.js +43 -0
- package/src/adapters/shared/server-adapter.d.ts +13 -3
- package/src/adapters/shared/server-adapter.js +42 -5
- package/src/adapters/shared/server-route-handler.d.ts +4 -4
- package/src/adapters/shared/server-route-handler.js +6 -15
- package/src/adapters/shared/server-static-builder.d.ts +38 -6
- package/src/adapters/shared/server-static-builder.js +64 -10
- package/src/build/README.md +107 -0
- package/src/build/build-adapter.d.ts +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 +52 -27
- package/src/config/config-builder.js +260 -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/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 +12 -4
- 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/README.md +26 -0
- package/src/hmr/client/hmr-runtime.d.ts +1 -6
- package/src/hmr/client/hmr-runtime.js +30 -7
- package/src/hmr/hmr-strategy.d.ts +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 -43
- package/src/hmr/strategies/js-hmr-strategy.js +72 -73
- package/src/index.browser.d.ts +2 -2
- package/src/index.browser.js +1 -1
- package/src/index.d.ts +4 -3
- package/src/index.js +16 -5
- package/src/integrations/ghtml/ghtml-renderer.d.ts +7 -2
- package/src/integrations/ghtml/ghtml-renderer.js +33 -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 -21
- 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 +145 -28
- package/src/plugins/integration-plugin.js +109 -13
- package/src/plugins/processor.d.ts +15 -2
- package/src/plugins/processor.js +16 -2
- package/src/plugins/runtime-capability.d.ts +9 -0
- package/src/plugins/source-transform.d.ts +46 -0
- package/src/plugins/source-transform.js +71 -0
- package/src/route-renderer/GRAPH.md +64 -98
- package/src/route-renderer/README.md +67 -46
- package/src/route-renderer/orchestration/boundary-planning.service.d.ts +25 -0
- package/src/route-renderer/orchestration/boundary-planning.service.js +97 -0
- 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 +554 -0
- package/src/route-renderer/orchestration/integration-renderer.js +957 -0
- package/src/route-renderer/orchestration/queued-boundary-runtime.service.d.ts +89 -0
- package/src/route-renderer/orchestration/queued-boundary-runtime.service.js +155 -0
- package/src/route-renderer/orchestration/render-execution.service.d.ts +43 -0
- package/src/route-renderer/orchestration/render-execution.service.js +106 -0
- 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/{render-preparation.service.d.ts → orchestration/render-preparation.service.d.ts} +18 -10
- package/src/route-renderer/{render-preparation.service.js → orchestration/render-preparation.service.js} +115 -17
- package/src/route-renderer/orchestration/route-shell-composer.service.d.ts +50 -0
- package/src/route-renderer/orchestration/route-shell-composer.service.js +81 -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/{dependency-resolver.d.ts → page-loading/dependency-resolver.d.ts} +15 -4
- package/src/route-renderer/{dependency-resolver.js → page-loading/dependency-resolver.js} +28 -12
- 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 +45 -4
- package/src/route-renderer/route-renderer.js +38 -3
- package/src/router/README.md +97 -0
- package/src/router/client/link-intent.d.ts +53 -0
- package/src/router/client/link-intent.js +34 -0
- package/src/router/client/link-intent.test.browser.d.ts +1 -0
- package/src/router/client/link-intent.test.browser.js +43 -0
- package/src/router/client/navigation-coordinator.d.ts +149 -0
- package/src/router/client/navigation-coordinator.js +215 -0
- package/src/router/{fs-router-scanner.d.ts → server/fs-router-scanner.d.ts} +3 -3
- package/src/router/{fs-router-scanner.js → server/fs-router-scanner.js} +14 -8
- package/src/router/{fs-router.d.ts → server/fs-router.d.ts} +1 -1
- package/src/router/{fs-router.js → server/fs-router.js} +1 -1
- package/src/services/README.md +29 -0
- package/src/services/assets/asset-processing-service/asset-processing.service.d.ts +120 -0
- package/src/services/{asset-processing-service → assets/asset-processing-service}/asset-processing.service.js +91 -10
- package/src/services/{asset-processing-service → assets/asset-processing-service}/asset.factory.d.ts +1 -1
- package/src/services/{asset-processing-service → assets/asset-processing-service}/asset.factory.js +2 -2
- package/src/services/{asset-processing-service → assets/asset-processing-service}/assets.types.d.ts +2 -1
- package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.d.ts +55 -0
- package/src/services/assets/asset-processing-service/browser-runtime-asset.factory.js +48 -0
- package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.d.ts +20 -0
- package/src/services/assets/asset-processing-service/browser-runtime-entry.factory.js +41 -0
- package/src/services/assets/asset-processing-service/index.d.ts +5 -0
- package/src/services/assets/asset-processing-service/index.js +5 -0
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.interface.d.ts +2 -2
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.registry.d.ts +2 -2
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/base/base-processor.d.ts +1 -1
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/base/base-processor.js +9 -4
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/base/base-script-processor.d.ts +5 -4
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/base/base-script-processor.js +15 -23
- package/src/services/assets/asset-processing-service/processors/index.d.ts +5 -0
- package/src/services/assets/asset-processing-service/processors/index.js +5 -0
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/content-script.processor.d.ts +2 -2
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/content-script.processor.js +1 -1
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/file-script.processor.d.ts +4 -3
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/file-script.processor.js +16 -4
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/node-module-script.processor.d.ts +3 -3
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/script/node-module-script.processor.js +6 -5
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/content-stylesheet.processor.d.ts +2 -2
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/content-stylesheet.processor.js +1 -1
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/file-stylesheet.processor.d.ts +2 -2
- package/src/services/{asset-processing-service → assets/asset-processing-service}/processors/stylesheet/file-stylesheet.processor.js +5 -2
- package/src/services/assets/browser-bundle.service.d.ts +32 -0
- package/src/services/assets/browser-bundle.service.js +33 -0
- package/src/services/{page-request-cache-coordinator.service.d.ts → cache/page-request-cache-coordinator.service.d.ts} +2 -2
- package/src/services/{page-request-cache-coordinator.service.js → cache/page-request-cache-coordinator.service.js} +3 -1
- package/src/services/html/html-rewriter-provider.service.d.ts +37 -0
- package/src/services/html/html-rewriter-provider.service.js +68 -0
- package/src/services/html/html-transformer.service.d.ts +77 -0
- package/src/services/html/html-transformer.service.js +215 -0
- package/src/services/invalidation/development-invalidation.service.d.ts +74 -0
- package/src/services/invalidation/development-invalidation.service.js +190 -0
- package/src/services/module-loading/app-module-loader.service.d.ts +28 -0
- package/src/services/module-loading/app-module-loader.service.js +35 -0
- package/src/services/module-loading/app-server-module-transpiler.service.d.ts +24 -0
- package/src/services/module-loading/app-server-module-transpiler.service.js +109 -0
- package/src/services/module-loading/host-module-loader-registry.d.ts +4 -0
- package/src/services/module-loading/host-module-loader-registry.js +15 -0
- package/src/services/module-loading/module-loading-types.d.ts +2 -0
- package/src/services/module-loading/node-bootstrap-plugin.d.ts +42 -0
- package/src/services/module-loading/node-bootstrap-plugin.js +204 -0
- package/src/services/module-loading/page-module-import.service.d.ts +76 -0
- package/src/services/module-loading/page-module-import.service.js +173 -0
- package/src/services/module-loading/server-module-transpiler.service.d.ts +72 -0
- package/src/services/module-loading/server-module-transpiler.service.js +64 -0
- package/src/services/runtime-state/dev-graph.service.d.ts +118 -0
- package/src/services/runtime-state/dev-graph.service.js +162 -0
- package/src/services/runtime-state/entrypoint-dependency-graph.service.d.ts +41 -0
- package/src/services/runtime-state/entrypoint-dependency-graph.service.js +85 -0
- package/src/services/runtime-state/runtime-specifier-registry.service.d.ts +69 -0
- package/src/services/runtime-state/runtime-specifier-registry.service.js +37 -0
- package/src/services/runtime-state/server-invalidation-state.service.d.ts +26 -0
- package/src/services/runtime-state/server-invalidation-state.service.js +35 -0
- package/src/services/{schema-validation-service.d.ts → validation/schema-validation-service.d.ts} +1 -1
- package/src/static-site-generator/README.md +26 -0
- package/src/static-site-generator/static-site-generator.d.ts +50 -3
- package/src/static-site-generator/static-site-generator.js +71 -5
- package/src/{internal-types.d.ts → types/internal-types.d.ts} +53 -22
- package/src/types/internal-types.js +0 -0
- package/src/{public-types.d.ts → types/public-types.d.ts} +146 -21
- 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 -24
- package/src/watchers/project-watcher.js +129 -92
- package/src/watchers/project-watcher.test-helpers.d.ts +2 -2
- package/src/watchers/project-watcher.test-helpers.js +1 -0
- package/src/adapters/abstract/application-adapter.ts +0 -337
- package/src/adapters/abstract/router-adapter.ts +0 -30
- package/src/adapters/abstract/server-adapter.ts +0 -79
- package/src/adapters/bun/client-bridge.ts +0 -62
- package/src/adapters/bun/create-app.ts +0 -189
- package/src/adapters/bun/define-api-handler.d.ts +0 -61
- package/src/adapters/bun/define-api-handler.ts +0 -114
- package/src/adapters/bun/hmr-manager.ts +0 -281
- package/src/adapters/bun/index.ts +0 -3
- package/src/adapters/bun/server-adapter.ts +0 -492
- package/src/adapters/bun/server-lifecycle.ts +0 -154
- package/src/adapters/index.ts +0 -6
- package/src/adapters/node/create-app.ts +0 -179
- package/src/adapters/node/index.d.ts +0 -4
- package/src/adapters/node/index.js +0 -8
- package/src/adapters/node/index.ts +0 -9
- package/src/adapters/node/node-client-bridge.ts +0 -79
- package/src/adapters/node/node-hmr-manager.ts +0 -271
- package/src/adapters/node/server-adapter.ts +0 -561
- package/src/adapters/node/static-content-server.ts +0 -203
- package/src/adapters/shared/api-response.ts +0 -104
- package/src/adapters/shared/application-adapter.ts +0 -199
- package/src/adapters/shared/explicit-static-route-matcher.ts +0 -134
- package/src/adapters/shared/file-route-middleware-pipeline.ts +0 -123
- package/src/adapters/shared/fs-server-response-factory.ts +0 -118
- package/src/adapters/shared/fs-server-response-matcher.ts +0 -198
- package/src/adapters/shared/render-context.ts +0 -105
- package/src/adapters/shared/server-adapter.ts +0 -442
- package/src/adapters/shared/server-route-handler.ts +0 -166
- package/src/adapters/shared/server-static-builder.ts +0 -82
- package/src/build/build-adapter.ts +0 -132
- package/src/build/build-types.ts +0 -83
- package/src/build/esbuild-build-adapter.ts +0 -510
- package/src/config/config-builder.ts +0 -474
- package/src/constants.ts +0 -39
- package/src/create-app.ts +0 -87
- package/src/define-api-handler.js +0 -15
- package/src/define-api-handler.ts +0 -66
- package/src/dev/sc-server.ts +0 -143
- package/src/eco/component-render-context.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/global-injector-map.ts +0 -112
- package/src/eco/lazy-injector-map.ts +0 -120
- package/src/eco/module-dependencies.ts +0 -75
- package/src/errors/http-error.ts +0 -72
- package/src/errors/index.ts +0 -2
- package/src/errors/locals-access-error.ts +0 -7
- package/src/global/app-logger.ts +0 -4
- package/src/hmr/client/__screenshots__/hmr-runtime.test.browser.ts/HMR-Runtime-HMR-Server-Integration-should-have-HMR-script-injected-in-page-1.png +0 -0
- package/src/hmr/client/__screenshots__/hmr-runtime.test.browser.ts/HMR-Runtime-HMR-Server-Integration-should-load-fixture-app-page-1.png +0 -0
- package/src/hmr/client/__screenshots__/hmr-runtime.test.browser.ts/HMR-Runtime-WebSocket-Connection-should-connect-to-correct-HMR-endpoint-1.png +0 -0
- package/src/hmr/client/hmr-runtime.ts +0 -121
- package/src/hmr/hmr-strategy.ts +0 -172
- package/src/hmr/hmr.test.e2e.ts +0 -75
- package/src/hmr/strategies/default-hmr-strategy.ts +0 -60
- package/src/hmr/strategies/js-hmr-strategy.ts +0 -308
- package/src/index.browser.ts +0 -3
- package/src/index.ts +0 -5
- package/src/integrations/ghtml/ghtml-renderer.ts +0 -93
- package/src/integrations/ghtml/ghtml.plugin.ts +0 -32
- package/src/internal-types.ts +0 -212
- package/src/plugins/alias-resolver-plugin.ts +0 -45
- package/src/plugins/eco-component-meta-plugin.ts +0 -474
- package/src/plugins/integration-plugin.ts +0 -184
- package/src/plugins/processor.ts +0 -220
- package/src/public-types.ts +0 -1255
- package/src/route-renderer/component-graph-executor.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.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.ts +0 -358
- package/src/route-renderer/route-renderer.ts +0 -80
- package/src/router/fs-router-scanner.ts +0 -217
- package/src/router/fs-router.ts +0 -122
- package/src/services/asset-processing-service/asset-processing.service.d.ts +0 -41
- package/src/services/asset-processing-service/asset-processing.service.ts +0 -306
- package/src/services/asset-processing-service/asset.factory.ts +0 -105
- package/src/services/asset-processing-service/assets.types.ts +0 -112
- package/src/services/asset-processing-service/index.d.ts +0 -3
- package/src/services/asset-processing-service/index.js +0 -3
- package/src/services/asset-processing-service/index.ts +0 -3
- package/src/services/asset-processing-service/processor.interface.ts +0 -27
- package/src/services/asset-processing-service/processor.registry.ts +0 -18
- package/src/services/asset-processing-service/processors/base/base-processor.ts +0 -76
- package/src/services/asset-processing-service/processors/base/base-script-processor.ts +0 -105
- package/src/services/asset-processing-service/processors/index.d.ts +0 -5
- package/src/services/asset-processing-service/processors/index.js +0 -5
- package/src/services/asset-processing-service/processors/index.ts +0 -5
- package/src/services/asset-processing-service/processors/script/content-script.processor.ts +0 -66
- package/src/services/asset-processing-service/processors/script/file-script.processor.ts +0 -88
- package/src/services/asset-processing-service/processors/script/node-module-script.processor.ts +0 -84
- package/src/services/asset-processing-service/processors/stylesheet/content-stylesheet.processor.ts +0 -27
- package/src/services/asset-processing-service/processors/stylesheet/file-stylesheet.processor.ts +0 -77
- package/src/services/cache/cache.types.ts +0 -126
- package/src/services/cache/index.ts +0 -18
- package/src/services/cache/memory-cache-store.ts +0 -130
- package/src/services/cache/page-cache-service.ts +0 -202
- package/src/services/html-transformer.service.d.ts +0 -50
- package/src/services/html-transformer.service.js +0 -163
- package/src/services/html-transformer.service.ts +0 -217
- package/src/services/page-module-import.service.d.ts +0 -37
- package/src/services/page-module-import.service.js +0 -88
- package/src/services/page-module-import.service.ts +0 -129
- package/src/services/page-request-cache-coordinator.service.ts +0 -128
- package/src/services/schema-validation-service.ts +0 -204
- package/src/services/validation/standard-schema.types.ts +0 -68
- package/src/static-site-generator/static-site-generator.ts +0 -359
- package/src/utils/css.d.ts +0 -1
- package/src/utils/css.js +0 -7
- package/src/utils/css.ts +0 -5
- package/src/utils/deep-merge.ts +0 -47
- package/src/utils/hash.ts +0 -5
- package/src/utils/html.ts +0 -1
- package/src/utils/invariant.ts +0 -15
- package/src/utils/locals-utils.ts +0 -37
- package/src/utils/parse-cli-args.ts +0 -83
- package/src/utils/path-utils.module.ts +0 -14
- package/src/utils/runtime.ts +0 -44
- package/src/utils/server-utils.module.ts +0 -67
- package/src/watchers/project-watcher.test-helpers.ts +0 -40
- package/src/watchers/project-watcher.ts +0 -306
- /package/src/adapters/{bun → shared}/define-api-handler.js +0 -0
- /package/src/{internal-types.js → plugins/runtime-capability.js} +0 -0
- /package/src/services/{asset-processing-service → assets/asset-processing-service}/assets.types.js +0 -0
- /package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.interface.js +0 -0
- /package/src/services/{asset-processing-service → assets/asset-processing-service}/processor.registry.js +0 -0
- /package/src/{public-types.js → services/module-loading/module-loading-types.js} +0 -0
- /package/src/services/{schema-validation-service.js → validation/schema-validation-service.js} +0 -0
|
@@ -1,217 +0,0 @@
|
|
|
1
|
-
import path from 'node:path';
|
|
2
|
-
import { appLogger } from '../global/app-logger.ts';
|
|
3
|
-
import type { EcoPagesAppConfig, RouteKind, Routes } from '../internal-types.ts';
|
|
4
|
-
import type { EcoPageFile, GetStaticPaths } from '../public-types.ts';
|
|
5
|
-
import { fileSystem } from '@ecopages/file-system';
|
|
6
|
-
import { invariant } from '../utils/invariant.ts';
|
|
7
|
-
import { existsSync } from 'node:fs';
|
|
8
|
-
import { PageModuleImportService } from '../services/page-module-import.service.ts';
|
|
9
|
-
|
|
10
|
-
type CreateRouteArgs = {
|
|
11
|
-
routePath: string;
|
|
12
|
-
filePath: string;
|
|
13
|
-
route: string;
|
|
14
|
-
};
|
|
15
|
-
|
|
16
|
-
type FSRouterScannerOptions = {
|
|
17
|
-
buildMode: boolean;
|
|
18
|
-
};
|
|
19
|
-
|
|
20
|
-
/**
|
|
21
|
-
* @class FSRouterScanner
|
|
22
|
-
* @description
|
|
23
|
-
* This class is responsible for scanning the file system for routes.
|
|
24
|
-
* It uses the glob package to scan the file system for files with the specified file extensions.
|
|
25
|
-
* It then creates a map of the routes with the pathname as the key.
|
|
26
|
-
* The pathname is the route without the file extension.
|
|
27
|
-
* For example, if the file is "index.tsx", the pathname will be "/index".
|
|
28
|
-
* If the file is "blog/[slug].tsx", the pathname will be "/blog/[slug]".
|
|
29
|
-
* If the file is "blog/[...slug].tsx", the pathname will be "/blog/[...slug]".
|
|
30
|
-
*/
|
|
31
|
-
export class FSRouterScanner {
|
|
32
|
-
private dir: string;
|
|
33
|
-
private origin = '';
|
|
34
|
-
private templatesExt: string[];
|
|
35
|
-
private options: FSRouterScannerOptions;
|
|
36
|
-
private appConfig: EcoPagesAppConfig;
|
|
37
|
-
routes: Routes = {};
|
|
38
|
-
private pageModuleImportService = new PageModuleImportService();
|
|
39
|
-
|
|
40
|
-
constructor({
|
|
41
|
-
dir,
|
|
42
|
-
origin,
|
|
43
|
-
templatesExt,
|
|
44
|
-
options,
|
|
45
|
-
appConfig,
|
|
46
|
-
}: {
|
|
47
|
-
dir: string;
|
|
48
|
-
origin: string;
|
|
49
|
-
templatesExt: string[];
|
|
50
|
-
options: FSRouterScannerOptions;
|
|
51
|
-
appConfig: EcoPagesAppConfig;
|
|
52
|
-
}) {
|
|
53
|
-
this.dir = dir;
|
|
54
|
-
this.origin = origin;
|
|
55
|
-
this.templatesExt = templatesExt;
|
|
56
|
-
this.options = options;
|
|
57
|
-
this.appConfig = appConfig;
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
private getRoutePath(path: string): string {
|
|
61
|
-
const cleanedRoute = this.templatesExt
|
|
62
|
-
.reduce((route, ext) => route.replace(ext, ''), path)
|
|
63
|
-
.replace(/\/?index$/, '');
|
|
64
|
-
return `/${cleanedRoute}`;
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
private getDynamicParamsNames(route: string): string[] {
|
|
68
|
-
const matches = route.match(/\[.*?\]/g);
|
|
69
|
-
return matches ? matches.map((match) => match.slice(1, -1)) : [];
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
private async getStaticPathsFromDynamicRoute({
|
|
73
|
-
route,
|
|
74
|
-
filePath,
|
|
75
|
-
getStaticPaths,
|
|
76
|
-
}: {
|
|
77
|
-
route: string;
|
|
78
|
-
filePath: string;
|
|
79
|
-
getStaticPaths: GetStaticPaths;
|
|
80
|
-
}): Promise<string[]> {
|
|
81
|
-
const staticPaths = await getStaticPaths({
|
|
82
|
-
appConfig: this.appConfig,
|
|
83
|
-
runtimeOrigin: this.origin,
|
|
84
|
-
});
|
|
85
|
-
return staticPaths.paths.map((path) => {
|
|
86
|
-
const dynamicParamsNames = this.getDynamicParamsNames(filePath);
|
|
87
|
-
let routeWithParams = route;
|
|
88
|
-
|
|
89
|
-
for (const param of dynamicParamsNames) {
|
|
90
|
-
routeWithParams = routeWithParams.replace(`[${param}]`, (path.params as Record<string, string>)[param]);
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
return routeWithParams;
|
|
94
|
-
});
|
|
95
|
-
}
|
|
96
|
-
|
|
97
|
-
private async createStaticRoutes({
|
|
98
|
-
filePath,
|
|
99
|
-
route,
|
|
100
|
-
routePath,
|
|
101
|
-
getStaticPaths,
|
|
102
|
-
}: CreateRouteArgs & { getStaticPaths: GetStaticPaths }): Promise<void> {
|
|
103
|
-
try {
|
|
104
|
-
const routesWithParams = await this.getStaticPathsFromDynamicRoute({
|
|
105
|
-
route,
|
|
106
|
-
filePath,
|
|
107
|
-
getStaticPaths,
|
|
108
|
-
});
|
|
109
|
-
|
|
110
|
-
for (const routeWithParams of routesWithParams) {
|
|
111
|
-
this.createRoute('dynamic', { filePath, route: routeWithParams, routePath });
|
|
112
|
-
}
|
|
113
|
-
} catch (error) {
|
|
114
|
-
appLogger.error(`[ecopages] Error creating static routes for ${filePath}: ${error}`);
|
|
115
|
-
}
|
|
116
|
-
}
|
|
117
|
-
|
|
118
|
-
private async handleDynamicRouteCreation({ filePath, route, routePath }: CreateRouteArgs): Promise<void> {
|
|
119
|
-
const module = (await this.importPageModule(filePath)) as EcoPageFile;
|
|
120
|
-
const Page = module.default;
|
|
121
|
-
|
|
122
|
-
/**
|
|
123
|
-
* Check for attached static functions (consolidated API) or named exports (legacy)
|
|
124
|
-
*/
|
|
125
|
-
const getStaticPaths = Page?.staticPaths ?? module.getStaticPaths;
|
|
126
|
-
const getStaticProps = Page?.staticProps ?? module.getStaticProps;
|
|
127
|
-
|
|
128
|
-
if (this.options.buildMode) {
|
|
129
|
-
invariant(getStaticProps !== undefined, `[ecopages] Missing getStaticProps in ${filePath}`);
|
|
130
|
-
invariant(getStaticPaths !== undefined, `[ecopages] Missing getStaticPaths in ${filePath}`);
|
|
131
|
-
}
|
|
132
|
-
|
|
133
|
-
if (getStaticPaths) {
|
|
134
|
-
return this.createStaticRoutes({
|
|
135
|
-
filePath,
|
|
136
|
-
route,
|
|
137
|
-
routePath,
|
|
138
|
-
getStaticPaths,
|
|
139
|
-
});
|
|
140
|
-
}
|
|
141
|
-
|
|
142
|
-
return this.createRoute('dynamic', { filePath, route, routePath });
|
|
143
|
-
}
|
|
144
|
-
|
|
145
|
-
private async importPageModule(filePath: string): Promise<unknown> {
|
|
146
|
-
return this.pageModuleImportService.importModule({
|
|
147
|
-
filePath,
|
|
148
|
-
rootDir: this.appConfig.rootDir,
|
|
149
|
-
outdir: path.join(this.appConfig.absolutePaths.distDir, '.server-route-modules'),
|
|
150
|
-
externalPackages: false,
|
|
151
|
-
transpileErrorMessage: (details) => `Error transpiling route module: ${details}`,
|
|
152
|
-
noOutputMessage: (targetFilePath) => `No transpiled output generated for route module: ${targetFilePath}`,
|
|
153
|
-
});
|
|
154
|
-
}
|
|
155
|
-
|
|
156
|
-
private createRoute(kind: RouteKind, { filePath, route, routePath }: CreateRouteArgs): void {
|
|
157
|
-
this.routes[route] = {
|
|
158
|
-
kind,
|
|
159
|
-
pathname: routePath,
|
|
160
|
-
filePath,
|
|
161
|
-
};
|
|
162
|
-
}
|
|
163
|
-
|
|
164
|
-
private getRouteData(file: string): CreateRouteArgs & {
|
|
165
|
-
kind: RouteKind;
|
|
166
|
-
} {
|
|
167
|
-
const routePath = this.getRoutePath(file);
|
|
168
|
-
const route = `${this.origin}${routePath}`;
|
|
169
|
-
const filePath = path.join(this.dir, file);
|
|
170
|
-
const isCatchAll = filePath.includes('[...');
|
|
171
|
-
const isDynamic = !isCatchAll && filePath.includes('[') && filePath.includes(']');
|
|
172
|
-
const kind: RouteKind = isCatchAll ? 'catch-all' : isDynamic ? 'dynamic' : 'exact';
|
|
173
|
-
|
|
174
|
-
return { route, routePath, filePath, kind };
|
|
175
|
-
}
|
|
176
|
-
|
|
177
|
-
async scan(): Promise<Routes> {
|
|
178
|
-
this.routes = {};
|
|
179
|
-
|
|
180
|
-
if (!existsSync(this.dir)) {
|
|
181
|
-
return this.routes;
|
|
182
|
-
}
|
|
183
|
-
|
|
184
|
-
const scannedFiles = await fileSystem.glob(
|
|
185
|
-
this.templatesExt.map((ext) => `**/*${ext}`),
|
|
186
|
-
{ cwd: this.dir },
|
|
187
|
-
);
|
|
188
|
-
|
|
189
|
-
for await (const file of scannedFiles) {
|
|
190
|
-
if (file.includes('.ecopages-node.')) {
|
|
191
|
-
continue;
|
|
192
|
-
}
|
|
193
|
-
|
|
194
|
-
const { kind, ...routeData } = this.getRouteData(file);
|
|
195
|
-
|
|
196
|
-
switch (kind) {
|
|
197
|
-
case 'dynamic':
|
|
198
|
-
await this.handleDynamicRouteCreation(routeData);
|
|
199
|
-
break;
|
|
200
|
-
case 'catch-all':
|
|
201
|
-
if (this.options.buildMode) {
|
|
202
|
-
appLogger.warn(
|
|
203
|
-
'Catch-all routes are not supported in static generation, they will not be included in the bundle\n',
|
|
204
|
-
`➤ ${routeData.filePath}`,
|
|
205
|
-
);
|
|
206
|
-
}
|
|
207
|
-
this.createRoute(kind, routeData);
|
|
208
|
-
break;
|
|
209
|
-
default:
|
|
210
|
-
this.createRoute(kind, routeData);
|
|
211
|
-
break;
|
|
212
|
-
}
|
|
213
|
-
}
|
|
214
|
-
|
|
215
|
-
return this.routes;
|
|
216
|
-
}
|
|
217
|
-
}
|
package/src/router/fs-router.ts
DELETED
|
@@ -1,122 +0,0 @@
|
|
|
1
|
-
import { appLogger } from '../global/app-logger.ts';
|
|
2
|
-
import type { MatchResult, Route, Routes } from '../internal-types.ts';
|
|
3
|
-
import type { FSRouterScanner } from './fs-router-scanner.ts';
|
|
4
|
-
|
|
5
|
-
/**
|
|
6
|
-
* A class that manages the routes of the file system.
|
|
7
|
-
* It scans the file system for files with the specified extensions and creates a map of routes.
|
|
8
|
-
* It also provides a method to match a request to a route.
|
|
9
|
-
* It can be used to reload the routes when the file system changes.
|
|
10
|
-
*/
|
|
11
|
-
export class FSRouter {
|
|
12
|
-
origin: string;
|
|
13
|
-
assetPrefix: string;
|
|
14
|
-
routes: Routes = {};
|
|
15
|
-
scanner: FSRouterScanner;
|
|
16
|
-
onReload?: () => void;
|
|
17
|
-
|
|
18
|
-
constructor({ origin, assetPrefix, scanner }: { origin: string; assetPrefix: string; scanner: FSRouterScanner }) {
|
|
19
|
-
this.origin = origin;
|
|
20
|
-
this.assetPrefix = assetPrefix;
|
|
21
|
-
this.scanner = scanner;
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
async init() {
|
|
25
|
-
this.routes = await this.scanner.scan();
|
|
26
|
-
appLogger.debug('FSRouter initialized', this.routes);
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
getDynamicParams(route: Route, pathname: string): Record<string, string | string[]> {
|
|
30
|
-
const params: Record<string, string | string[]> = {};
|
|
31
|
-
const routeParts = route.pathname.split('/');
|
|
32
|
-
const pathnameParts = pathname.split('/');
|
|
33
|
-
|
|
34
|
-
for (let i = 0; i < routeParts.length; i++) {
|
|
35
|
-
const part = routeParts[i];
|
|
36
|
-
if (part.startsWith('[') && part.endsWith(']')) {
|
|
37
|
-
if (part.startsWith('[...')) {
|
|
38
|
-
const param = part.slice(4, -1);
|
|
39
|
-
params[param] = pathnameParts.slice(i);
|
|
40
|
-
break;
|
|
41
|
-
}
|
|
42
|
-
const param = part.slice(1, -1);
|
|
43
|
-
params[param] = pathnameParts[i];
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
return params;
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
getSearchParams(url: URL): Record<string, string> {
|
|
50
|
-
const query: Record<string, string> = {};
|
|
51
|
-
for (const [key, value] of url.searchParams) {
|
|
52
|
-
query[key] = value;
|
|
53
|
-
}
|
|
54
|
-
return query;
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
match(requestUrl: string): MatchResult | null {
|
|
58
|
-
const url = new URL(requestUrl);
|
|
59
|
-
const pathname = url.pathname.replace(this.origin, '');
|
|
60
|
-
|
|
61
|
-
const routeValues = Object.values(this.routes);
|
|
62
|
-
|
|
63
|
-
for (const route of routeValues) {
|
|
64
|
-
if (route.kind === 'exact' && (pathname === route.pathname || pathname === `${route.pathname}/`)) {
|
|
65
|
-
return {
|
|
66
|
-
filePath: route.filePath,
|
|
67
|
-
kind: 'exact',
|
|
68
|
-
pathname: route.pathname,
|
|
69
|
-
query: this.getSearchParams(url),
|
|
70
|
-
};
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
for (const route of routeValues) {
|
|
75
|
-
const cleanPathname = route.pathname.replace(/\[.*?\]/g, '');
|
|
76
|
-
const isValidDynamicRoute = pathname.includes(cleanPathname);
|
|
77
|
-
|
|
78
|
-
if (route.kind === 'dynamic' && isValidDynamicRoute) {
|
|
79
|
-
const routeParts = route.pathname.split('/');
|
|
80
|
-
const pathnameParts = pathname.split('/');
|
|
81
|
-
|
|
82
|
-
if (routeParts.length === pathnameParts.length) {
|
|
83
|
-
return {
|
|
84
|
-
filePath: route.filePath,
|
|
85
|
-
kind: 'dynamic',
|
|
86
|
-
pathname: pathname,
|
|
87
|
-
query: this.getSearchParams(url),
|
|
88
|
-
params: this.getDynamicParams(route, pathname),
|
|
89
|
-
};
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
for (const route of routeValues) {
|
|
95
|
-
const cleanPathname = route.pathname.replace(/\[.*?\]/g, '');
|
|
96
|
-
const isValidCatchAllRoute = pathname.includes(cleanPathname);
|
|
97
|
-
|
|
98
|
-
if (route.kind === 'catch-all' && isValidCatchAllRoute) {
|
|
99
|
-
return {
|
|
100
|
-
filePath: route.filePath,
|
|
101
|
-
kind: 'catch-all',
|
|
102
|
-
pathname: pathname,
|
|
103
|
-
query: this.getSearchParams(url),
|
|
104
|
-
params: this.getDynamicParams(route, pathname),
|
|
105
|
-
};
|
|
106
|
-
}
|
|
107
|
-
}
|
|
108
|
-
|
|
109
|
-
return null;
|
|
110
|
-
}
|
|
111
|
-
|
|
112
|
-
setOnReload(cb: () => void) {
|
|
113
|
-
this.onReload = cb;
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
reload() {
|
|
117
|
-
this.init();
|
|
118
|
-
if (this.onReload) {
|
|
119
|
-
this.onReload();
|
|
120
|
-
}
|
|
121
|
-
}
|
|
122
|
-
}
|
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
import type { EcoPagesAppConfig, IHmrManager } from '../../internal-types';
|
|
2
|
-
import type { AssetDefinition, AssetKind, AssetSource, ProcessedAsset } from './assets.types';
|
|
3
|
-
import { ProcessorRegistry } from './processor.registry';
|
|
4
|
-
export declare class AssetProcessingService {
|
|
5
|
-
private readonly config;
|
|
6
|
-
static readonly RESOLVED_ASSETS_DIR = "assets";
|
|
7
|
-
private registry;
|
|
8
|
-
private hmrManager?;
|
|
9
|
-
private cache;
|
|
10
|
-
constructor(config: EcoPagesAppConfig);
|
|
11
|
-
/**
|
|
12
|
-
* Set the HMR manager for the asset processing service.
|
|
13
|
-
* @param hmrManager The HMR manager to set.
|
|
14
|
-
*/
|
|
15
|
-
setHmrManager(hmrManager: IHmrManager): void;
|
|
16
|
-
getHmrManager(): IHmrManager | undefined;
|
|
17
|
-
/**
|
|
18
|
-
* Register a processor for a specific asset kind and source.
|
|
19
|
-
* @param kind The asset kind.
|
|
20
|
-
* @param variant The asset source.
|
|
21
|
-
* @param processor The processor to register.
|
|
22
|
-
*/
|
|
23
|
-
registerProcessor(kind: AssetKind, variant: AssetSource, processor: any): void;
|
|
24
|
-
processDependencies(deps: AssetDefinition[], key: string): Promise<ProcessedAsset[]>;
|
|
25
|
-
private deduplicateDependencies;
|
|
26
|
-
private getScriptDependencyBuildSignature;
|
|
27
|
-
private getDependencyKey;
|
|
28
|
-
private generateHash;
|
|
29
|
-
private processDependenciesParallel;
|
|
30
|
-
private groupDependenciesByType;
|
|
31
|
-
private getSrcUrl;
|
|
32
|
-
private resolveProcessedAssetSrcUrl;
|
|
33
|
-
private isFilesystemPath;
|
|
34
|
-
private optimizeDependencies;
|
|
35
|
-
private getCachedAsset;
|
|
36
|
-
private setCachedAsset;
|
|
37
|
-
clearCache(): void;
|
|
38
|
-
invalidateCacheForFile(filepath: string): void;
|
|
39
|
-
static createWithDefaultProcessors(appConfig: EcoPagesAppConfig): AssetProcessingService;
|
|
40
|
-
getRegistry(): ProcessorRegistry;
|
|
41
|
-
}
|
|
@@ -1,306 +0,0 @@
|
|
|
1
|
-
import path from 'node:path';
|
|
2
|
-
import { RESOLVED_ASSETS_DIR } from '../../constants';
|
|
3
|
-
import { appLogger } from '../../global/app-logger';
|
|
4
|
-
import type { EcoPagesAppConfig, IHmrManager } from '../../internal-types';
|
|
5
|
-
import { rapidhash } from '../../utils/hash';
|
|
6
|
-
import { fileSystem } from '@ecopages/file-system';
|
|
7
|
-
import type { AssetDefinition, AssetKind, AssetSource, ProcessedAsset } from './assets.types';
|
|
8
|
-
import { isHmrAware } from './processor.interface';
|
|
9
|
-
import { ProcessorRegistry } from './processor.registry';
|
|
10
|
-
import {
|
|
11
|
-
ContentScriptProcessor,
|
|
12
|
-
ContentStylesheetProcessor,
|
|
13
|
-
FileScriptProcessor,
|
|
14
|
-
FileStylesheetProcessor,
|
|
15
|
-
NodeModuleScriptProcessor,
|
|
16
|
-
} from './processors';
|
|
17
|
-
|
|
18
|
-
export class AssetProcessingService {
|
|
19
|
-
static readonly RESOLVED_ASSETS_DIR = RESOLVED_ASSETS_DIR;
|
|
20
|
-
private registry = new ProcessorRegistry();
|
|
21
|
-
private hmrManager?: IHmrManager;
|
|
22
|
-
private cache = new Map<string, { asset: ProcessedAsset }>();
|
|
23
|
-
|
|
24
|
-
constructor(private readonly config: EcoPagesAppConfig) {}
|
|
25
|
-
|
|
26
|
-
/**
|
|
27
|
-
* Set the HMR manager for the asset processing service.
|
|
28
|
-
* @param hmrManager The HMR manager to set.
|
|
29
|
-
*/
|
|
30
|
-
setHmrManager(hmrManager: IHmrManager) {
|
|
31
|
-
this.hmrManager = hmrManager;
|
|
32
|
-
|
|
33
|
-
for (const processor of this.registry.getAllProcessors().values()) {
|
|
34
|
-
if (isHmrAware(processor)) {
|
|
35
|
-
processor.setHmrManager(hmrManager);
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
getHmrManager(): IHmrManager | undefined {
|
|
41
|
-
return this.hmrManager;
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
/**
|
|
45
|
-
* Register a processor for a specific asset kind and source.
|
|
46
|
-
* @param kind The asset kind.
|
|
47
|
-
* @param variant The asset source.
|
|
48
|
-
* @param processor The processor to register.
|
|
49
|
-
*/
|
|
50
|
-
registerProcessor(kind: AssetKind, variant: AssetSource, processor: any): void {
|
|
51
|
-
if (this.hmrManager && isHmrAware(processor)) {
|
|
52
|
-
processor.setHmrManager(this.hmrManager);
|
|
53
|
-
}
|
|
54
|
-
this.registry.register(kind, variant, processor);
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
async processDependencies(deps: AssetDefinition[], key: string): Promise<ProcessedAsset[]> {
|
|
58
|
-
const depsDir = path.join(this.config.absolutePaths.distDir, RESOLVED_ASSETS_DIR);
|
|
59
|
-
fileSystem.ensureDir(depsDir);
|
|
60
|
-
|
|
61
|
-
const dedupedDeps = this.deduplicateDependencies(deps);
|
|
62
|
-
const results = await this.processDependenciesParallel(dedupedDeps, key);
|
|
63
|
-
|
|
64
|
-
await this.optimizeDependencies(results);
|
|
65
|
-
return results;
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
private deduplicateDependencies(deps: AssetDefinition[]): AssetDefinition[] {
|
|
69
|
-
const seen = new Map<string, AssetDefinition>();
|
|
70
|
-
|
|
71
|
-
for (const dep of deps) {
|
|
72
|
-
const key = this.getDependencyKey(dep);
|
|
73
|
-
if (!seen.has(key)) {
|
|
74
|
-
seen.set(key, dep);
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
return Array.from(seen.values());
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
private getScriptDependencyBuildSignature(dep: AssetDefinition): string | undefined {
|
|
82
|
-
if (dep.kind !== 'script') {
|
|
83
|
-
return undefined;
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
const pluginNames = dep.bundleOptions?.plugins?.map((plugin) => plugin.name) ?? [];
|
|
87
|
-
const signature = {
|
|
88
|
-
bundle: dep.bundle,
|
|
89
|
-
inline: dep.inline,
|
|
90
|
-
excludeFromHtml: dep.excludeFromHtml,
|
|
91
|
-
naming: dep.bundleOptions?.naming,
|
|
92
|
-
external: dep.bundleOptions?.external,
|
|
93
|
-
minify: dep.bundleOptions?.minify,
|
|
94
|
-
plugins: pluginNames,
|
|
95
|
-
};
|
|
96
|
-
|
|
97
|
-
return this.generateHash(JSON.stringify(signature));
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
private getDependencyKey(dep: AssetDefinition): string {
|
|
101
|
-
const parts: string[] = [dep.kind, dep.source];
|
|
102
|
-
|
|
103
|
-
if ('filepath' in dep) {
|
|
104
|
-
parts.push(dep.filepath);
|
|
105
|
-
} else if ('content' in dep) {
|
|
106
|
-
parts.push(`content:${this.generateHash(dep.content)}`);
|
|
107
|
-
} else if ('importPath' in dep) {
|
|
108
|
-
parts.push(dep.importPath);
|
|
109
|
-
}
|
|
110
|
-
|
|
111
|
-
if ('position' in dep && dep.position) {
|
|
112
|
-
parts.push(dep.position);
|
|
113
|
-
}
|
|
114
|
-
|
|
115
|
-
const scriptBuildSignature = this.getScriptDependencyBuildSignature(dep);
|
|
116
|
-
if (scriptBuildSignature) {
|
|
117
|
-
parts.push(`build:${scriptBuildSignature}`);
|
|
118
|
-
}
|
|
119
|
-
|
|
120
|
-
return parts.join(':');
|
|
121
|
-
}
|
|
122
|
-
|
|
123
|
-
private generateHash(content: string): string {
|
|
124
|
-
return rapidhash(content).toString();
|
|
125
|
-
}
|
|
126
|
-
|
|
127
|
-
private async processDependenciesParallel(deps: AssetDefinition[], key: string): Promise<ProcessedAsset[]> {
|
|
128
|
-
const grouped = this.groupDependenciesByType(deps);
|
|
129
|
-
|
|
130
|
-
const groupPromises = Object.entries(grouped).map(async ([, typeDeps]) => {
|
|
131
|
-
const typePromises = typeDeps.map(async (dep) => {
|
|
132
|
-
const depKey = this.getDependencyKey(dep);
|
|
133
|
-
const cached = this.getCachedAsset(dep, depKey);
|
|
134
|
-
|
|
135
|
-
if (cached) {
|
|
136
|
-
return { key, ...cached };
|
|
137
|
-
}
|
|
138
|
-
|
|
139
|
-
const processor = this.registry.getProcessor(dep.kind, dep.source);
|
|
140
|
-
if (!processor) {
|
|
141
|
-
appLogger.error(`No processor found for ${dep.kind}/${dep.source}`);
|
|
142
|
-
return null;
|
|
143
|
-
}
|
|
144
|
-
|
|
145
|
-
if (dep.source === 'file' && 'filepath' in dep) {
|
|
146
|
-
const fileExists = fileSystem.exists(dep.filepath);
|
|
147
|
-
if (!fileExists) {
|
|
148
|
-
appLogger.warn(`Skipping missing ${dep.kind} file: ${dep.filepath}`);
|
|
149
|
-
return null;
|
|
150
|
-
}
|
|
151
|
-
}
|
|
152
|
-
|
|
153
|
-
try {
|
|
154
|
-
const processed = await processor.process(dep);
|
|
155
|
-
const srcUrl = this.resolveProcessedAssetSrcUrl(processed);
|
|
156
|
-
|
|
157
|
-
const processedWithKey = {
|
|
158
|
-
key,
|
|
159
|
-
...processed,
|
|
160
|
-
srcUrl,
|
|
161
|
-
};
|
|
162
|
-
|
|
163
|
-
this.setCachedAsset(dep, depKey, processedWithKey);
|
|
164
|
-
|
|
165
|
-
return processedWithKey as ProcessedAsset;
|
|
166
|
-
} catch (error) {
|
|
167
|
-
appLogger.error(
|
|
168
|
-
`Failed to process dependency: ${
|
|
169
|
-
error instanceof Error ? error.message : String(error)
|
|
170
|
-
} for ${dep.kind}/${dep.source}`,
|
|
171
|
-
);
|
|
172
|
-
appLogger.debug(error as Error);
|
|
173
|
-
return null;
|
|
174
|
-
}
|
|
175
|
-
});
|
|
176
|
-
|
|
177
|
-
const typeResults = await Promise.all(typePromises);
|
|
178
|
-
return typeResults.filter((result) => result !== null);
|
|
179
|
-
});
|
|
180
|
-
|
|
181
|
-
const allTypeResults = await Promise.all(groupPromises);
|
|
182
|
-
return allTypeResults.flat();
|
|
183
|
-
}
|
|
184
|
-
|
|
185
|
-
private groupDependenciesByType(deps: AssetDefinition[]): Record<string, AssetDefinition[]> {
|
|
186
|
-
return deps.reduce(
|
|
187
|
-
(acc, dep) => {
|
|
188
|
-
const key = `${dep.kind}_${dep.source}`;
|
|
189
|
-
if (!acc[key]) acc[key] = [];
|
|
190
|
-
acc[key].push(dep);
|
|
191
|
-
return acc;
|
|
192
|
-
},
|
|
193
|
-
{} as Record<string, AssetDefinition[]>,
|
|
194
|
-
);
|
|
195
|
-
}
|
|
196
|
-
|
|
197
|
-
private getSrcUrl(filepath: string): string | undefined {
|
|
198
|
-
const distDir = this.config.absolutePaths.distDir;
|
|
199
|
-
if (!filepath.startsWith(distDir)) return undefined;
|
|
200
|
-
|
|
201
|
-
const relativePath = filepath.slice(distDir.length);
|
|
202
|
-
const urlPath = relativePath.startsWith('/') ? relativePath : `/${relativePath}`;
|
|
203
|
-
return urlPath.replace(/\\/g, '/');
|
|
204
|
-
}
|
|
205
|
-
|
|
206
|
-
private resolveProcessedAssetSrcUrl(processed: ProcessedAsset): string | undefined {
|
|
207
|
-
if (processed.srcUrl) {
|
|
208
|
-
if (this.isFilesystemPath(processed.srcUrl)) {
|
|
209
|
-
const srcUrlFromPath = this.getSrcUrl(processed.srcUrl);
|
|
210
|
-
if (srcUrlFromPath) return srcUrlFromPath;
|
|
211
|
-
} else {
|
|
212
|
-
return processed.srcUrl;
|
|
213
|
-
}
|
|
214
|
-
}
|
|
215
|
-
|
|
216
|
-
if (processed.filepath) {
|
|
217
|
-
return this.getSrcUrl(processed.filepath);
|
|
218
|
-
}
|
|
219
|
-
|
|
220
|
-
return undefined;
|
|
221
|
-
}
|
|
222
|
-
|
|
223
|
-
private isFilesystemPath(value: string): boolean {
|
|
224
|
-
if (value.startsWith('http://') || value.startsWith('https://') || value.startsWith('//')) {
|
|
225
|
-
return false;
|
|
226
|
-
}
|
|
227
|
-
|
|
228
|
-
if (value.startsWith(this.config.absolutePaths.distDir)) {
|
|
229
|
-
return true;
|
|
230
|
-
}
|
|
231
|
-
|
|
232
|
-
const rootDir = this.config.rootDir;
|
|
233
|
-
if (rootDir && value.startsWith(rootDir)) {
|
|
234
|
-
return true;
|
|
235
|
-
}
|
|
236
|
-
|
|
237
|
-
return /^[A-Za-z]:\\/.test(value);
|
|
238
|
-
}
|
|
239
|
-
|
|
240
|
-
private async optimizeDependencies(processedAssets: ProcessedAsset[]): Promise<void> {
|
|
241
|
-
if (process.env.NODE_ENV !== 'production') {
|
|
242
|
-
return;
|
|
243
|
-
}
|
|
244
|
-
|
|
245
|
-
const filesToGzip = new Set<string>();
|
|
246
|
-
|
|
247
|
-
for (const asset of processedAssets) {
|
|
248
|
-
if (!asset.filepath) {
|
|
249
|
-
continue;
|
|
250
|
-
}
|
|
251
|
-
|
|
252
|
-
if (!asset.filepath.startsWith(this.config.absolutePaths.distDir)) {
|
|
253
|
-
continue;
|
|
254
|
-
}
|
|
255
|
-
|
|
256
|
-
const extension = path.extname(asset.filepath).slice(1);
|
|
257
|
-
if (extension === 'css' || extension === 'js') {
|
|
258
|
-
filesToGzip.add(asset.filepath);
|
|
259
|
-
}
|
|
260
|
-
}
|
|
261
|
-
|
|
262
|
-
for (const filePath of filesToGzip) {
|
|
263
|
-
if (fileSystem.exists(filePath)) {
|
|
264
|
-
fileSystem.gzipFile(filePath);
|
|
265
|
-
}
|
|
266
|
-
}
|
|
267
|
-
}
|
|
268
|
-
|
|
269
|
-
private getCachedAsset(dep: AssetDefinition, depKey: string): ProcessedAsset | null {
|
|
270
|
-
const cached = this.cache.get(depKey);
|
|
271
|
-
return cached?.asset ?? null;
|
|
272
|
-
}
|
|
273
|
-
|
|
274
|
-
private setCachedAsset(dep: AssetDefinition, depKey: string, asset: ProcessedAsset): void {
|
|
275
|
-
this.cache.set(depKey, { asset });
|
|
276
|
-
}
|
|
277
|
-
|
|
278
|
-
clearCache(): void {
|
|
279
|
-
this.cache.clear();
|
|
280
|
-
}
|
|
281
|
-
|
|
282
|
-
invalidateCacheForFile(filepath: string): void {
|
|
283
|
-
for (const [key, value] of this.cache.entries()) {
|
|
284
|
-
if (value.asset.filepath === filepath) {
|
|
285
|
-
this.cache.delete(key);
|
|
286
|
-
}
|
|
287
|
-
}
|
|
288
|
-
}
|
|
289
|
-
|
|
290
|
-
static createWithDefaultProcessors(appConfig: EcoPagesAppConfig): AssetProcessingService {
|
|
291
|
-
const service = new AssetProcessingService(appConfig);
|
|
292
|
-
|
|
293
|
-
service.registerProcessor('script', 'content', new ContentScriptProcessor({ appConfig }));
|
|
294
|
-
service.registerProcessor('script', 'file', new FileScriptProcessor({ appConfig }));
|
|
295
|
-
service.registerProcessor('script', 'node-module', new NodeModuleScriptProcessor({ appConfig }));
|
|
296
|
-
|
|
297
|
-
service.registerProcessor('stylesheet', 'content', new ContentStylesheetProcessor({ appConfig }));
|
|
298
|
-
service.registerProcessor('stylesheet', 'file', new FileStylesheetProcessor({ appConfig }));
|
|
299
|
-
|
|
300
|
-
return service;
|
|
301
|
-
}
|
|
302
|
-
|
|
303
|
-
getRegistry(): ProcessorRegistry {
|
|
304
|
-
return this.registry;
|
|
305
|
-
}
|
|
306
|
-
}
|