@ecopages/core 0.2.0-alpha.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 +89 -0
- package/LICENSE +21 -0
- package/README.md +32 -0
- package/package.json +279 -0
- package/src/adapters/abstract/application-adapter.d.ts +168 -0
- package/src/adapters/abstract/application-adapter.js +109 -0
- package/src/adapters/abstract/application-adapter.ts +337 -0
- package/src/adapters/abstract/router-adapter.d.ts +26 -0
- package/src/adapters/abstract/router-adapter.js +5 -0
- package/src/adapters/abstract/router-adapter.ts +30 -0
- package/src/adapters/abstract/server-adapter.d.ts +69 -0
- package/src/adapters/abstract/server-adapter.js +15 -0
- package/src/adapters/abstract/server-adapter.ts +79 -0
- package/src/adapters/bun/client-bridge.d.ts +34 -0
- package/src/adapters/bun/client-bridge.js +48 -0
- package/src/adapters/bun/client-bridge.ts +62 -0
- package/src/adapters/bun/create-app.d.ts +60 -0
- package/src/adapters/bun/create-app.js +117 -0
- package/src/adapters/bun/create-app.ts +189 -0
- package/src/adapters/bun/define-api-handler.d.ts +61 -0
- package/src/adapters/bun/define-api-handler.js +15 -0
- package/src/adapters/bun/define-api-handler.ts +114 -0
- package/src/adapters/bun/hmr-manager.d.ts +84 -0
- package/src/adapters/bun/hmr-manager.js +227 -0
- package/src/adapters/bun/hmr-manager.ts +281 -0
- package/src/adapters/bun/index.d.ts +3 -0
- package/src/adapters/bun/index.js +8 -0
- package/src/adapters/bun/index.ts +3 -0
- package/src/adapters/bun/server-adapter.d.ts +155 -0
- package/src/adapters/bun/server-adapter.js +368 -0
- package/src/adapters/bun/server-adapter.ts +492 -0
- package/src/adapters/bun/server-lifecycle.d.ts +52 -0
- package/src/adapters/bun/server-lifecycle.js +120 -0
- package/src/adapters/bun/server-lifecycle.ts +154 -0
- package/src/adapters/index.d.ts +6 -0
- package/src/adapters/index.js +14 -0
- package/src/adapters/index.ts +6 -0
- package/src/adapters/node/create-app.d.ts +21 -0
- package/src/adapters/node/create-app.js +143 -0
- package/src/adapters/node/create-app.ts +179 -0
- package/src/adapters/node/index.d.ts +4 -0
- package/src/adapters/node/index.js +8 -0
- package/src/adapters/node/index.ts +9 -0
- package/src/adapters/node/node-client-bridge.d.ts +26 -0
- package/src/adapters/node/node-client-bridge.js +66 -0
- package/src/adapters/node/node-client-bridge.ts +79 -0
- package/src/adapters/node/node-hmr-manager.d.ts +62 -0
- package/src/adapters/node/node-hmr-manager.js +221 -0
- package/src/adapters/node/node-hmr-manager.ts +271 -0
- package/src/adapters/node/server-adapter.d.ts +190 -0
- package/src/adapters/node/server-adapter.js +420 -0
- package/src/adapters/node/server-adapter.ts +561 -0
- package/src/adapters/node/static-content-server.d.ts +24 -0
- package/src/adapters/node/static-content-server.js +166 -0
- package/src/adapters/node/static-content-server.ts +203 -0
- package/src/adapters/shared/api-response.d.ts +52 -0
- package/src/adapters/shared/api-response.js +96 -0
- package/src/adapters/shared/api-response.ts +104 -0
- package/src/adapters/shared/application-adapter.d.ts +18 -0
- package/src/adapters/shared/application-adapter.js +90 -0
- package/src/adapters/shared/application-adapter.ts +199 -0
- package/src/adapters/shared/explicit-static-route-matcher.d.ts +38 -0
- package/src/adapters/shared/explicit-static-route-matcher.js +100 -0
- package/src/adapters/shared/explicit-static-route-matcher.ts +134 -0
- package/src/adapters/shared/file-route-middleware-pipeline.d.ts +65 -0
- package/src/adapters/shared/file-route-middleware-pipeline.js +98 -0
- package/src/adapters/shared/file-route-middleware-pipeline.ts +123 -0
- package/src/adapters/shared/fs-server-response-factory.d.ts +19 -0
- package/src/adapters/shared/fs-server-response-factory.js +97 -0
- package/src/adapters/shared/fs-server-response-factory.ts +118 -0
- package/src/adapters/shared/fs-server-response-matcher.d.ts +71 -0
- package/src/adapters/shared/fs-server-response-matcher.js +155 -0
- package/src/adapters/shared/fs-server-response-matcher.ts +198 -0
- package/src/adapters/shared/render-context.d.ts +14 -0
- package/src/adapters/shared/render-context.js +69 -0
- package/src/adapters/shared/render-context.ts +105 -0
- package/src/adapters/shared/server-adapter.d.ts +87 -0
- package/src/adapters/shared/server-adapter.js +353 -0
- package/src/adapters/shared/server-adapter.ts +442 -0
- package/src/adapters/shared/server-route-handler.d.ts +89 -0
- package/src/adapters/shared/server-route-handler.js +120 -0
- package/src/adapters/shared/server-route-handler.ts +166 -0
- package/src/adapters/shared/server-static-builder.d.ts +38 -0
- package/src/adapters/shared/server-static-builder.js +46 -0
- package/src/adapters/shared/server-static-builder.ts +82 -0
- package/src/build/build-adapter.d.ts +74 -0
- package/src/build/build-adapter.js +54 -0
- package/src/build/build-adapter.ts +132 -0
- package/src/build/build-types.d.ts +57 -0
- package/src/build/build-types.js +0 -0
- package/src/build/build-types.ts +83 -0
- package/src/build/esbuild-build-adapter.d.ts +69 -0
- package/src/build/esbuild-build-adapter.js +390 -0
- package/src/build/esbuild-build-adapter.ts +510 -0
- package/src/config/config-builder.d.ts +227 -0
- package/src/config/config-builder.js +392 -0
- package/src/config/config-builder.ts +474 -0
- package/src/constants.d.ts +32 -0
- package/src/constants.js +21 -0
- package/src/constants.ts +39 -0
- package/src/create-app.d.ts +17 -0
- package/src/create-app.js +66 -0
- package/src/create-app.ts +87 -0
- package/src/declarations.d.ts +26 -0
- package/src/define-api-handler.d.ts +25 -0
- package/src/define-api-handler.js +15 -0
- package/src/define-api-handler.ts +66 -0
- package/src/dev/sc-server.d.ts +30 -0
- package/src/dev/sc-server.js +111 -0
- package/src/dev/sc-server.ts +143 -0
- package/src/eco/README.md +636 -0
- package/src/eco/component-render-context.d.ts +105 -0
- package/src/eco/component-render-context.js +77 -0
- package/src/eco/component-render-context.ts +202 -0
- package/src/eco/eco.d.ts +9 -0
- package/src/eco/eco.js +110 -0
- package/src/eco/eco.ts +221 -0
- package/src/eco/eco.types.d.ts +170 -0
- package/src/eco/eco.types.js +0 -0
- package/src/eco/eco.types.ts +202 -0
- package/src/eco/eco.utils.d.ts +40 -0
- package/src/eco/eco.utils.js +40 -0
- package/src/eco/eco.utils.ts +89 -0
- package/src/eco/global-injector-map.d.ts +16 -0
- package/src/eco/global-injector-map.js +80 -0
- package/src/eco/global-injector-map.ts +112 -0
- package/src/eco/lazy-injector-map.d.ts +8 -0
- package/src/eco/lazy-injector-map.js +70 -0
- package/src/eco/lazy-injector-map.ts +120 -0
- package/src/eco/module-dependencies.d.ts +18 -0
- package/src/eco/module-dependencies.js +49 -0
- package/src/eco/module-dependencies.ts +75 -0
- package/src/env.d.ts +20 -0
- package/src/errors/http-error.d.ts +31 -0
- package/src/errors/http-error.js +50 -0
- package/src/errors/http-error.ts +72 -0
- package/src/errors/index.d.ts +2 -0
- package/src/errors/index.js +4 -0
- package/src/errors/index.ts +2 -0
- package/src/errors/locals-access-error.d.ts +4 -0
- package/src/errors/locals-access-error.js +9 -0
- package/src/errors/locals-access-error.ts +7 -0
- package/src/global/app-logger.d.ts +2 -0
- package/src/global/app-logger.js +6 -0
- package/src/global/app-logger.ts +4 -0
- 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.d.ts +10 -0
- package/src/hmr/client/hmr-runtime.js +86 -0
- package/src/hmr/client/hmr-runtime.ts +121 -0
- package/src/hmr/hmr-strategy.d.ts +159 -0
- package/src/hmr/hmr-strategy.js +29 -0
- package/src/hmr/hmr-strategy.ts +172 -0
- package/src/hmr/hmr.test.e2e.d.ts +1 -0
- package/src/hmr/hmr.test.e2e.js +50 -0
- package/src/hmr/hmr.test.e2e.ts +75 -0
- package/src/hmr/strategies/default-hmr-strategy.d.ts +43 -0
- package/src/hmr/strategies/default-hmr-strategy.js +34 -0
- package/src/hmr/strategies/default-hmr-strategy.ts +60 -0
- package/src/hmr/strategies/js-hmr-strategy.d.ts +136 -0
- package/src/hmr/strategies/js-hmr-strategy.js +179 -0
- package/src/hmr/strategies/js-hmr-strategy.ts +308 -0
- package/src/index.browser.d.ts +3 -0
- package/src/index.browser.js +4 -0
- package/src/index.browser.ts +3 -0
- package/src/index.d.ts +5 -0
- package/src/index.js +10 -0
- package/src/index.ts +5 -0
- package/src/integrations/ghtml/ghtml-renderer.d.ts +15 -0
- package/src/integrations/ghtml/ghtml-renderer.js +60 -0
- package/src/integrations/ghtml/ghtml-renderer.ts +93 -0
- package/src/integrations/ghtml/ghtml.plugin.d.ts +20 -0
- package/src/integrations/ghtml/ghtml.plugin.js +21 -0
- package/src/integrations/ghtml/ghtml.plugin.ts +32 -0
- package/src/internal-types.d.ts +200 -0
- package/src/internal-types.js +0 -0
- package/src/internal-types.ts +212 -0
- package/src/plugins/alias-resolver-plugin.d.ts +2 -0
- package/src/plugins/alias-resolver-plugin.js +39 -0
- package/src/plugins/alias-resolver-plugin.ts +45 -0
- package/src/plugins/eco-component-meta-plugin.d.ts +95 -0
- package/src/plugins/eco-component-meta-plugin.js +157 -0
- package/src/plugins/eco-component-meta-plugin.ts +474 -0
- package/src/plugins/integration-plugin.d.ts +102 -0
- package/src/plugins/integration-plugin.js +100 -0
- package/src/plugins/integration-plugin.ts +184 -0
- package/src/plugins/processor.d.ts +82 -0
- package/src/plugins/processor.js +122 -0
- package/src/plugins/processor.ts +220 -0
- package/src/public-types.d.ts +1094 -0
- package/src/public-types.js +0 -0
- package/src/public-types.ts +1255 -0
- package/src/route-renderer/GRAPH.md +387 -0
- package/src/route-renderer/README.md +135 -0
- package/src/route-renderer/component-graph-executor.d.ts +32 -0
- package/src/route-renderer/component-graph-executor.js +31 -0
- package/src/route-renderer/component-graph-executor.ts +84 -0
- package/src/route-renderer/component-graph.d.ts +42 -0
- package/src/route-renderer/component-graph.js +72 -0
- package/src/route-renderer/component-graph.ts +159 -0
- package/src/route-renderer/component-marker.d.ts +52 -0
- package/src/route-renderer/component-marker.js +46 -0
- package/src/route-renderer/component-marker.ts +117 -0
- package/src/route-renderer/dependency-resolver.d.ts +24 -0
- package/src/route-renderer/dependency-resolver.js +428 -0
- package/src/route-renderer/dependency-resolver.ts +596 -0
- package/src/route-renderer/html-post-processing.service.d.ts +40 -0
- package/src/route-renderer/html-post-processing.service.js +86 -0
- package/src/route-renderer/html-post-processing.service.ts +103 -0
- package/src/route-renderer/integration-renderer.d.ts +339 -0
- package/src/route-renderer/integration-renderer.js +526 -0
- package/src/route-renderer/integration-renderer.ts +696 -0
- package/src/route-renderer/marker-graph-resolver.d.ts +76 -0
- package/src/route-renderer/marker-graph-resolver.js +93 -0
- package/src/route-renderer/marker-graph-resolver.ts +153 -0
- package/src/route-renderer/page-module-loader.d.ts +61 -0
- package/src/route-renderer/page-module-loader.js +102 -0
- package/src/route-renderer/page-module-loader.ts +153 -0
- package/src/route-renderer/render-execution.service.d.ts +69 -0
- package/src/route-renderer/render-execution.service.js +91 -0
- package/src/route-renderer/render-execution.service.ts +158 -0
- package/src/route-renderer/render-preparation.service.d.ts +112 -0
- package/src/route-renderer/render-preparation.service.js +243 -0
- package/src/route-renderer/render-preparation.service.ts +358 -0
- package/src/route-renderer/route-renderer.d.ts +26 -0
- package/src/route-renderer/route-renderer.js +68 -0
- package/src/route-renderer/route-renderer.ts +80 -0
- package/src/router/fs-router-scanner.d.ts +41 -0
- package/src/router/fs-router-scanner.js +155 -0
- package/src/router/fs-router-scanner.ts +217 -0
- package/src/router/fs-router.d.ts +26 -0
- package/src/router/fs-router.js +100 -0
- package/src/router/fs-router.ts +122 -0
- package/src/services/asset-processing-service/asset-processing.service.d.ts +41 -0
- package/src/services/asset-processing-service/asset-processing.service.js +250 -0
- package/src/services/asset-processing-service/asset-processing.service.ts +306 -0
- package/src/services/asset-processing-service/asset.factory.d.ts +17 -0
- package/src/services/asset-processing-service/asset.factory.js +82 -0
- package/src/services/asset-processing-service/asset.factory.ts +105 -0
- package/src/services/asset-processing-service/assets.types.d.ts +88 -0
- package/src/services/asset-processing-service/assets.types.js +0 -0
- package/src/services/asset-processing-service/assets.types.ts +112 -0
- package/src/services/asset-processing-service/index.d.ts +3 -0
- package/src/services/asset-processing-service/index.js +3 -0
- package/src/services/asset-processing-service/index.ts +3 -0
- package/src/services/asset-processing-service/processor.interface.d.ts +22 -0
- package/src/services/asset-processing-service/processor.interface.js +6 -0
- package/src/services/asset-processing-service/processor.interface.ts +27 -0
- package/src/services/asset-processing-service/processor.registry.d.ts +8 -0
- package/src/services/asset-processing-service/processor.registry.js +15 -0
- package/src/services/asset-processing-service/processor.registry.ts +18 -0
- package/src/services/asset-processing-service/processors/base/base-processor.d.ts +24 -0
- package/src/services/asset-processing-service/processors/base/base-processor.js +59 -0
- package/src/services/asset-processing-service/processors/base/base-processor.ts +76 -0
- package/src/services/asset-processing-service/processors/base/base-script-processor.d.ts +16 -0
- package/src/services/asset-processing-service/processors/base/base-script-processor.js +80 -0
- package/src/services/asset-processing-service/processors/base/base-script-processor.ts +105 -0
- package/src/services/asset-processing-service/processors/index.d.ts +5 -0
- package/src/services/asset-processing-service/processors/index.js +5 -0
- package/src/services/asset-processing-service/processors/index.ts +5 -0
- package/src/services/asset-processing-service/processors/script/content-script.processor.d.ts +5 -0
- package/src/services/asset-processing-service/processors/script/content-script.processor.js +57 -0
- package/src/services/asset-processing-service/processors/script/content-script.processor.ts +66 -0
- package/src/services/asset-processing-service/processors/script/file-script.processor.d.ts +8 -0
- package/src/services/asset-processing-service/processors/script/file-script.processor.js +76 -0
- package/src/services/asset-processing-service/processors/script/file-script.processor.ts +88 -0
- package/src/services/asset-processing-service/processors/script/node-module-script.processor.d.ts +7 -0
- package/src/services/asset-processing-service/processors/script/node-module-script.processor.js +74 -0
- package/src/services/asset-processing-service/processors/script/node-module-script.processor.ts +84 -0
- package/src/services/asset-processing-service/processors/stylesheet/content-stylesheet.processor.d.ts +5 -0
- package/src/services/asset-processing-service/processors/stylesheet/content-stylesheet.processor.js +25 -0
- package/src/services/asset-processing-service/processors/stylesheet/content-stylesheet.processor.ts +27 -0
- package/src/services/asset-processing-service/processors/stylesheet/file-stylesheet.processor.d.ts +9 -0
- package/src/services/asset-processing-service/processors/stylesheet/file-stylesheet.processor.js +63 -0
- package/src/services/asset-processing-service/processors/stylesheet/file-stylesheet.processor.ts +77 -0
- package/src/services/cache/cache.types.d.ts +107 -0
- package/src/services/cache/cache.types.js +0 -0
- package/src/services/cache/cache.types.ts +126 -0
- package/src/services/cache/index.d.ts +7 -0
- package/src/services/cache/index.js +7 -0
- package/src/services/cache/index.ts +18 -0
- package/src/services/cache/memory-cache-store.d.ts +42 -0
- package/src/services/cache/memory-cache-store.js +98 -0
- package/src/services/cache/memory-cache-store.ts +130 -0
- package/src/services/cache/page-cache-service.d.ts +70 -0
- package/src/services/cache/page-cache-service.js +152 -0
- package/src/services/cache/page-cache-service.ts +202 -0
- package/src/services/html-transformer.service.d.ts +50 -0
- package/src/services/html-transformer.service.js +163 -0
- package/src/services/html-transformer.service.ts +217 -0
- package/src/services/page-module-import.service.d.ts +37 -0
- package/src/services/page-module-import.service.js +88 -0
- package/src/services/page-module-import.service.ts +129 -0
- package/src/services/page-request-cache-coordinator.service.d.ts +75 -0
- package/src/services/page-request-cache-coordinator.service.js +107 -0
- package/src/services/page-request-cache-coordinator.service.ts +128 -0
- package/src/services/schema-validation-service.d.ts +122 -0
- package/src/services/schema-validation-service.js +101 -0
- package/src/services/schema-validation-service.ts +204 -0
- package/src/services/validation/standard-schema.types.d.ts +65 -0
- package/src/services/validation/standard-schema.types.js +0 -0
- package/src/services/validation/standard-schema.types.ts +68 -0
- package/src/static-site-generator/static-site-generator.d.ts +57 -0
- package/src/static-site-generator/static-site-generator.js +272 -0
- package/src/static-site-generator/static-site-generator.ts +359 -0
- package/src/utils/css.d.ts +1 -0
- package/src/utils/css.js +7 -0
- package/src/utils/css.ts +5 -0
- package/src/utils/deep-merge.d.ts +14 -0
- package/src/utils/deep-merge.js +32 -0
- package/src/utils/deep-merge.ts +47 -0
- package/src/utils/hash.d.ts +1 -0
- package/src/utils/hash.js +7 -0
- package/src/utils/hash.ts +5 -0
- package/src/utils/html.d.ts +1 -0
- package/src/utils/html.js +4 -0
- package/src/utils/html.ts +1 -0
- package/src/utils/invariant.d.ts +5 -0
- package/src/utils/invariant.js +11 -0
- package/src/utils/invariant.ts +15 -0
- package/src/utils/locals-utils.d.ts +15 -0
- package/src/utils/locals-utils.js +24 -0
- package/src/utils/locals-utils.ts +37 -0
- package/src/utils/parse-cli-args.d.ts +24 -0
- package/src/utils/parse-cli-args.js +47 -0
- package/src/utils/parse-cli-args.ts +83 -0
- package/src/utils/path-utils.module.d.ts +5 -0
- package/src/utils/path-utils.module.js +14 -0
- package/src/utils/path-utils.module.ts +14 -0
- package/src/utils/runtime.d.ts +11 -0
- package/src/utils/runtime.js +40 -0
- package/src/utils/runtime.ts +44 -0
- package/src/utils/server-utils.module.d.ts +19 -0
- package/src/utils/server-utils.module.js +56 -0
- package/src/utils/server-utils.module.ts +67 -0
- package/src/watchers/project-watcher.d.ts +120 -0
- package/src/watchers/project-watcher.js +238 -0
- package/src/watchers/project-watcher.test-helpers.d.ts +4 -0
- package/src/watchers/project-watcher.test-helpers.js +51 -0
- package/src/watchers/project-watcher.test-helpers.ts +40 -0
- package/src/watchers/project-watcher.ts +306 -0
|
@@ -0,0 +1,109 @@
|
|
|
1
|
+
import { appLogger } from "../../global/app-logger.js";
|
|
2
|
+
import { invariant } from "../../utils/invariant.js";
|
|
3
|
+
import { fileSystem } from "@ecopages/file-system";
|
|
4
|
+
import { parseCliArgs } from "../../utils/parse-cli-args.js";
|
|
5
|
+
class AbstractApplicationAdapter {
|
|
6
|
+
appConfig;
|
|
7
|
+
serverOptions;
|
|
8
|
+
cliArgs;
|
|
9
|
+
apiHandlers = [];
|
|
10
|
+
staticRoutes = [];
|
|
11
|
+
errorHandler;
|
|
12
|
+
constructor(options) {
|
|
13
|
+
this.appConfig = options.appConfig;
|
|
14
|
+
this.serverOptions = options.serverOptions || {};
|
|
15
|
+
this.cliArgs = parseCliArgs();
|
|
16
|
+
if (options.clearOutput) {
|
|
17
|
+
this.clearDistFolder().catch((error) => {
|
|
18
|
+
appLogger.error("Error clearing dist folder", error);
|
|
19
|
+
});
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
async clearDistFolder(_filter = []) {
|
|
23
|
+
const distPath = this.appConfig.absolutePaths.distDir;
|
|
24
|
+
const distExists = fileSystem.exists(distPath);
|
|
25
|
+
if (!distExists) return;
|
|
26
|
+
try {
|
|
27
|
+
await fileSystem.removeAsync(distPath);
|
|
28
|
+
appLogger.debug(`Cleared dist folder: ${distPath}`);
|
|
29
|
+
} catch (error) {
|
|
30
|
+
appLogger.error(`Error clearing dist folder: ${distPath}`, error);
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* Internal method to add route handlers to the API handlers array
|
|
35
|
+
*/
|
|
36
|
+
addRouteHandler(path, method, handler, middleware, schema) {
|
|
37
|
+
invariant(
|
|
38
|
+
typeof path === "string",
|
|
39
|
+
`Invalid route path for ${method}: expected a string path starting with "/" but received ${Object.prototype.toString.call(path)}. If you're passing a prebuilt ApiHandler, use app.add(handler).`
|
|
40
|
+
);
|
|
41
|
+
invariant(
|
|
42
|
+
path.startsWith("/"),
|
|
43
|
+
`Invalid route path for ${method}: "${path}". Route paths must start with '/'.`
|
|
44
|
+
);
|
|
45
|
+
this.apiHandlers.push({
|
|
46
|
+
path,
|
|
47
|
+
method,
|
|
48
|
+
handler,
|
|
49
|
+
middleware,
|
|
50
|
+
schema
|
|
51
|
+
});
|
|
52
|
+
return this;
|
|
53
|
+
}
|
|
54
|
+
/**
|
|
55
|
+
* Get all registered API handlers
|
|
56
|
+
*/
|
|
57
|
+
getApiHandlers() {
|
|
58
|
+
return this.apiHandlers;
|
|
59
|
+
}
|
|
60
|
+
/**
|
|
61
|
+
* Register a view for static generation at build time.
|
|
62
|
+
* The view must have staticPaths defined for dynamic routes.
|
|
63
|
+
*
|
|
64
|
+
* Uses a loader function to enable HMR in development.
|
|
65
|
+
*
|
|
66
|
+
* @param path - URL path pattern (e.g., '/posts/:slug')
|
|
67
|
+
* @param loader - A function that dynamically imports the eco.page view module
|
|
68
|
+
* @example
|
|
69
|
+
* ```typescript
|
|
70
|
+
* app.static('/login', () => import('./src/views/login.kita'))
|
|
71
|
+
* app.static('/posts/:slug', () => import('./src/views/post-view.kita'))
|
|
72
|
+
* ```
|
|
73
|
+
*/
|
|
74
|
+
static(path, loader) {
|
|
75
|
+
this.staticRoutes.push({ path, loader });
|
|
76
|
+
return this;
|
|
77
|
+
}
|
|
78
|
+
/**
|
|
79
|
+
* Get all registered static routes
|
|
80
|
+
*/
|
|
81
|
+
getStaticRoutes() {
|
|
82
|
+
return this.staticRoutes;
|
|
83
|
+
}
|
|
84
|
+
/**
|
|
85
|
+
* Register a global error handler for all routes.
|
|
86
|
+
* Useful for logging, monitoring integration, and custom error formatting.
|
|
87
|
+
*
|
|
88
|
+
* @example
|
|
89
|
+
* ```typescript
|
|
90
|
+
* app.onError(async (error, ctx) => {
|
|
91
|
+
* logger.error(error);
|
|
92
|
+
* return ctx.response.status(500).json({ error: 'Something went wrong' });
|
|
93
|
+
* });
|
|
94
|
+
* ```
|
|
95
|
+
*/
|
|
96
|
+
onError(handler) {
|
|
97
|
+
this.errorHandler = handler;
|
|
98
|
+
return this;
|
|
99
|
+
}
|
|
100
|
+
/**
|
|
101
|
+
* Get the registered error handler
|
|
102
|
+
*/
|
|
103
|
+
getErrorHandler() {
|
|
104
|
+
return this.errorHandler;
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
export {
|
|
108
|
+
AbstractApplicationAdapter
|
|
109
|
+
};
|
|
@@ -0,0 +1,337 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* This file defines the abstract class for application adapters in EcoPages.
|
|
3
|
+
* It provides a common interface for different runtimes (e.g., Node.js, Deno) to implement.
|
|
4
|
+
* The class includes methods for handling HTTP requests and managing application state.
|
|
5
|
+
* It also includes a method for parsing command-line arguments.
|
|
6
|
+
*
|
|
7
|
+
* @module ApplicationAdapter
|
|
8
|
+
*/
|
|
9
|
+
|
|
10
|
+
import { appLogger } from '../../global/app-logger.ts';
|
|
11
|
+
import type { EcoPagesAppConfig } from '../../internal-types.ts';
|
|
12
|
+
import { invariant } from '../../utils/invariant.ts';
|
|
13
|
+
import type {
|
|
14
|
+
ApiHandler,
|
|
15
|
+
ApiHandlerContext,
|
|
16
|
+
ErrorHandler,
|
|
17
|
+
Middleware,
|
|
18
|
+
RouteOptions,
|
|
19
|
+
StaticRoute,
|
|
20
|
+
ViewLoader,
|
|
21
|
+
} from '../../public-types.ts';
|
|
22
|
+
import { fileSystem } from '@ecopages/file-system';
|
|
23
|
+
import { parseCliArgs, type ReturnParseCliArgs } from '../../utils/parse-cli-args.ts';
|
|
24
|
+
|
|
25
|
+
/**
|
|
26
|
+
* Configuration options for application adapters
|
|
27
|
+
*/
|
|
28
|
+
export interface ApplicationAdapterOptions {
|
|
29
|
+
appConfig: EcoPagesAppConfig;
|
|
30
|
+
serverOptions?: Record<string, any>;
|
|
31
|
+
/**
|
|
32
|
+
* Options for clearing the output directory before starting the server
|
|
33
|
+
* @default false
|
|
34
|
+
*/
|
|
35
|
+
clearOutput?: boolean;
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
/**
|
|
39
|
+
* Common interface for application adapters
|
|
40
|
+
*/
|
|
41
|
+
export interface ApplicationAdapter<T = any> {
|
|
42
|
+
start(): Promise<T | void>;
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
/**
|
|
46
|
+
* Handler function type for route handlers
|
|
47
|
+
*/
|
|
48
|
+
export type RouteHandler<
|
|
49
|
+
TRequest extends Request = Request,
|
|
50
|
+
TServer = any,
|
|
51
|
+
TContext extends ApiHandlerContext<TRequest, TServer> = ApiHandlerContext<TRequest, TServer>,
|
|
52
|
+
> = (context: TContext) => Promise<Response> | Response;
|
|
53
|
+
|
|
54
|
+
export type RouteGroupDefinition<TRequest extends Request = Request, TServer = any> = {
|
|
55
|
+
prefix: string;
|
|
56
|
+
middleware?: readonly Middleware<TRequest, TServer, any>[];
|
|
57
|
+
routes: readonly ApiHandler<string, TRequest, TServer>[];
|
|
58
|
+
};
|
|
59
|
+
|
|
60
|
+
/**
|
|
61
|
+
* Abstract base class for application adapters across different runtimes
|
|
62
|
+
*/
|
|
63
|
+
export abstract class AbstractApplicationAdapter<
|
|
64
|
+
TOptions extends ApplicationAdapterOptions = ApplicationAdapterOptions,
|
|
65
|
+
TServer = any,
|
|
66
|
+
TRequest extends Request = any,
|
|
67
|
+
> implements ApplicationAdapter<TServer> {
|
|
68
|
+
protected appConfig: EcoPagesAppConfig;
|
|
69
|
+
protected serverOptions: Record<string, any>;
|
|
70
|
+
protected cliArgs: ReturnParseCliArgs;
|
|
71
|
+
protected apiHandlers: ApiHandler[] = [];
|
|
72
|
+
protected staticRoutes: StaticRoute[] = [];
|
|
73
|
+
protected errorHandler?: ErrorHandler;
|
|
74
|
+
|
|
75
|
+
constructor(options: TOptions) {
|
|
76
|
+
this.appConfig = options.appConfig;
|
|
77
|
+
this.serverOptions = options.serverOptions || {};
|
|
78
|
+
this.cliArgs = parseCliArgs();
|
|
79
|
+
|
|
80
|
+
if (options.clearOutput) {
|
|
81
|
+
this.clearDistFolder().catch((error) => {
|
|
82
|
+
appLogger.error('Error clearing dist folder', error as Error);
|
|
83
|
+
});
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
private async clearDistFolder(_filter: string[] = []): Promise<void> {
|
|
88
|
+
const distPath = this.appConfig.absolutePaths.distDir;
|
|
89
|
+
const distExists = fileSystem.exists(distPath);
|
|
90
|
+
|
|
91
|
+
if (!distExists) return;
|
|
92
|
+
|
|
93
|
+
try {
|
|
94
|
+
await fileSystem.removeAsync(distPath);
|
|
95
|
+
appLogger.debug(`Cleared dist folder: ${distPath}`);
|
|
96
|
+
} catch (error) {
|
|
97
|
+
appLogger.error(`Error clearing dist folder: ${distPath}`, error as Error);
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
/**
|
|
102
|
+
* Register a GET route handler.
|
|
103
|
+
*
|
|
104
|
+
* Use verb methods for inline route definitions.
|
|
105
|
+
* For dynamic HTTP method registration, use `route(...)`.
|
|
106
|
+
*/
|
|
107
|
+
abstract get<
|
|
108
|
+
P extends string,
|
|
109
|
+
TContext extends ApiHandlerContext<TRequest, TServer> = ApiHandlerContext<TRequest, TServer>,
|
|
110
|
+
>(
|
|
111
|
+
path: P,
|
|
112
|
+
handler: RouteHandler<TRequest, TServer, TContext>,
|
|
113
|
+
options?: RouteOptions<TRequest, TServer, TContext>,
|
|
114
|
+
): this;
|
|
115
|
+
|
|
116
|
+
/**
|
|
117
|
+
* Register a POST route handler
|
|
118
|
+
*/
|
|
119
|
+
abstract post<
|
|
120
|
+
P extends string,
|
|
121
|
+
TContext extends ApiHandlerContext<TRequest, TServer> = ApiHandlerContext<TRequest, TServer>,
|
|
122
|
+
>(
|
|
123
|
+
path: P,
|
|
124
|
+
handler: RouteHandler<TRequest, TServer, TContext>,
|
|
125
|
+
options?: RouteOptions<TRequest, TServer, TContext>,
|
|
126
|
+
): this;
|
|
127
|
+
|
|
128
|
+
/**
|
|
129
|
+
* Register a PUT route handler
|
|
130
|
+
*/
|
|
131
|
+
abstract put<
|
|
132
|
+
P extends string,
|
|
133
|
+
TContext extends ApiHandlerContext<TRequest, TServer> = ApiHandlerContext<TRequest, TServer>,
|
|
134
|
+
>(
|
|
135
|
+
path: P,
|
|
136
|
+
handler: RouteHandler<TRequest, TServer, TContext>,
|
|
137
|
+
options?: RouteOptions<TRequest, TServer, TContext>,
|
|
138
|
+
): this;
|
|
139
|
+
|
|
140
|
+
/**
|
|
141
|
+
* Register a DELETE route handler
|
|
142
|
+
*/
|
|
143
|
+
abstract delete<
|
|
144
|
+
P extends string,
|
|
145
|
+
TContext extends ApiHandlerContext<TRequest, TServer> = ApiHandlerContext<TRequest, TServer>,
|
|
146
|
+
>(
|
|
147
|
+
path: P,
|
|
148
|
+
handler: RouteHandler<TRequest, TServer, TContext>,
|
|
149
|
+
options?: RouteOptions<TRequest, TServer, TContext>,
|
|
150
|
+
): this;
|
|
151
|
+
|
|
152
|
+
/**
|
|
153
|
+
* Register a PATCH route handler
|
|
154
|
+
*/
|
|
155
|
+
abstract patch<
|
|
156
|
+
P extends string,
|
|
157
|
+
TContext extends ApiHandlerContext<TRequest, TServer> = ApiHandlerContext<TRequest, TServer>,
|
|
158
|
+
>(
|
|
159
|
+
path: P,
|
|
160
|
+
handler: RouteHandler<TRequest, TServer, TContext>,
|
|
161
|
+
options?: RouteOptions<TRequest, TServer, TContext>,
|
|
162
|
+
): this;
|
|
163
|
+
|
|
164
|
+
/**
|
|
165
|
+
* Register an OPTIONS route handler
|
|
166
|
+
*/
|
|
167
|
+
abstract options<
|
|
168
|
+
P extends string,
|
|
169
|
+
TContext extends ApiHandlerContext<TRequest, TServer> = ApiHandlerContext<TRequest, TServer>,
|
|
170
|
+
>(
|
|
171
|
+
path: P,
|
|
172
|
+
handler: RouteHandler<TRequest, TServer, TContext>,
|
|
173
|
+
options?: RouteOptions<TRequest, TServer, TContext>,
|
|
174
|
+
): this;
|
|
175
|
+
|
|
176
|
+
/**
|
|
177
|
+
* Register a HEAD route handler
|
|
178
|
+
*/
|
|
179
|
+
abstract head<
|
|
180
|
+
P extends string,
|
|
181
|
+
TContext extends ApiHandlerContext<TRequest, TServer> = ApiHandlerContext<TRequest, TServer>,
|
|
182
|
+
>(
|
|
183
|
+
path: P,
|
|
184
|
+
handler: RouteHandler<TRequest, TServer, TContext>,
|
|
185
|
+
options?: RouteOptions<TRequest, TServer, TContext>,
|
|
186
|
+
): this;
|
|
187
|
+
|
|
188
|
+
/**
|
|
189
|
+
* Register a route with an explicit HTTP method.
|
|
190
|
+
*
|
|
191
|
+
* This is useful when the method is determined programmatically, or when
|
|
192
|
+
* registering a pre-built route declaration object by forwarding its
|
|
193
|
+
* `path`, `method`, and `handler` fields.
|
|
194
|
+
*/
|
|
195
|
+
abstract route<P extends string>(
|
|
196
|
+
path: P,
|
|
197
|
+
method: ApiHandler['method'],
|
|
198
|
+
handler: RouteHandler<TRequest, TServer>,
|
|
199
|
+
options?: RouteOptions<TRequest, TServer>,
|
|
200
|
+
): this;
|
|
201
|
+
|
|
202
|
+
/**
|
|
203
|
+
* Register a pre-built API handler declaration.
|
|
204
|
+
*/
|
|
205
|
+
abstract add(handler: ApiHandler<string, TRequest, TServer>): this;
|
|
206
|
+
|
|
207
|
+
/**
|
|
208
|
+
* Internal method to add route handlers to the API handlers array
|
|
209
|
+
*/
|
|
210
|
+
protected addRouteHandler<
|
|
211
|
+
P extends string,
|
|
212
|
+
TSpecRequest extends TRequest = TRequest,
|
|
213
|
+
TSpecServer extends TServer = TServer,
|
|
214
|
+
TContext extends ApiHandlerContext<TSpecRequest, TSpecServer> = ApiHandlerContext<TSpecRequest, TSpecServer>,
|
|
215
|
+
>(
|
|
216
|
+
path: P,
|
|
217
|
+
method: ApiHandler['method'],
|
|
218
|
+
handler: RouteHandler<TSpecRequest, TSpecServer, TContext>,
|
|
219
|
+
middleware?: Middleware<TSpecRequest, TSpecServer, TContext>[],
|
|
220
|
+
schema?: ApiHandler['schema'],
|
|
221
|
+
): this {
|
|
222
|
+
invariant(
|
|
223
|
+
typeof path === 'string',
|
|
224
|
+
`Invalid route path for ${method}: expected a string path starting with "/" but received ${Object.prototype.toString.call(path)}. If you're passing a prebuilt ApiHandler, use app.add(handler).`,
|
|
225
|
+
);
|
|
226
|
+
|
|
227
|
+
invariant(
|
|
228
|
+
path.startsWith('/'),
|
|
229
|
+
`Invalid route path for ${method}: "${path}". Route paths must start with '/'.`,
|
|
230
|
+
);
|
|
231
|
+
|
|
232
|
+
this.apiHandlers.push({
|
|
233
|
+
path,
|
|
234
|
+
method,
|
|
235
|
+
handler: handler as ApiHandler['handler'],
|
|
236
|
+
middleware: middleware as ApiHandler['middleware'],
|
|
237
|
+
schema,
|
|
238
|
+
});
|
|
239
|
+
return this;
|
|
240
|
+
}
|
|
241
|
+
|
|
242
|
+
/**
|
|
243
|
+
* Create a route group with shared prefix and middleware.
|
|
244
|
+
* Routes defined within the group inherit the prefix and middleware.
|
|
245
|
+
*
|
|
246
|
+
* Each adapter implements this with its own builder type to support
|
|
247
|
+
* runtime-specific features (e.g., Bun's path parameter inference).
|
|
248
|
+
* Implementations may also support passing a pre-built group object.
|
|
249
|
+
*
|
|
250
|
+
* @param prefix - URL prefix for all routes in the group (e.g., '/api/v1')
|
|
251
|
+
* @param callback - Function that receives a builder to define routes
|
|
252
|
+
* @param options - Optional group-level middleware
|
|
253
|
+
*/
|
|
254
|
+
abstract group(
|
|
255
|
+
prefix: string,
|
|
256
|
+
callback: (builder: unknown) => void,
|
|
257
|
+
options?: {
|
|
258
|
+
middleware?: readonly Middleware<TRequest, TServer, any>[];
|
|
259
|
+
},
|
|
260
|
+
): this;
|
|
261
|
+
|
|
262
|
+
abstract group(group: RouteGroupDefinition<TRequest, TServer>): this;
|
|
263
|
+
|
|
264
|
+
/**
|
|
265
|
+
* Get all registered API handlers
|
|
266
|
+
*/
|
|
267
|
+
getApiHandlers(): ApiHandler[] {
|
|
268
|
+
return this.apiHandlers;
|
|
269
|
+
}
|
|
270
|
+
|
|
271
|
+
/**
|
|
272
|
+
* Register a view for static generation at build time.
|
|
273
|
+
* The view must have staticPaths defined for dynamic routes.
|
|
274
|
+
*
|
|
275
|
+
* Uses a loader function to enable HMR in development.
|
|
276
|
+
*
|
|
277
|
+
* @param path - URL path pattern (e.g., '/posts/:slug')
|
|
278
|
+
* @param loader - A function that dynamically imports the eco.page view module
|
|
279
|
+
* @example
|
|
280
|
+
* ```typescript
|
|
281
|
+
* app.static('/login', () => import('./src/views/login.kita'))
|
|
282
|
+
* app.static('/posts/:slug', () => import('./src/views/post-view.kita'))
|
|
283
|
+
* ```
|
|
284
|
+
*/
|
|
285
|
+
static<P>(path: string, loader: ViewLoader<P>): this {
|
|
286
|
+
this.staticRoutes.push({ path, loader });
|
|
287
|
+
return this;
|
|
288
|
+
}
|
|
289
|
+
|
|
290
|
+
/**
|
|
291
|
+
* Get all registered static routes
|
|
292
|
+
*/
|
|
293
|
+
getStaticRoutes(): StaticRoute[] {
|
|
294
|
+
return this.staticRoutes;
|
|
295
|
+
}
|
|
296
|
+
|
|
297
|
+
/**
|
|
298
|
+
* Register a global error handler for all routes.
|
|
299
|
+
* Useful for logging, monitoring integration, and custom error formatting.
|
|
300
|
+
*
|
|
301
|
+
* @example
|
|
302
|
+
* ```typescript
|
|
303
|
+
* app.onError(async (error, ctx) => {
|
|
304
|
+
* logger.error(error);
|
|
305
|
+
* return ctx.response.status(500).json({ error: 'Something went wrong' });
|
|
306
|
+
* });
|
|
307
|
+
* ```
|
|
308
|
+
*/
|
|
309
|
+
onError(handler: ErrorHandler<TRequest, TServer>): this {
|
|
310
|
+
this.errorHandler = handler as unknown as ErrorHandler;
|
|
311
|
+
return this;
|
|
312
|
+
}
|
|
313
|
+
|
|
314
|
+
/**
|
|
315
|
+
* Get the registered error handler
|
|
316
|
+
*/
|
|
317
|
+
getErrorHandler(): ErrorHandler | undefined {
|
|
318
|
+
return this.errorHandler;
|
|
319
|
+
}
|
|
320
|
+
|
|
321
|
+
/**
|
|
322
|
+
* Initialize the server adapter based on the runtime
|
|
323
|
+
*/
|
|
324
|
+
protected abstract initializeServerAdapter(): Promise<any>;
|
|
325
|
+
|
|
326
|
+
/**
|
|
327
|
+
* Start the application server
|
|
328
|
+
*/
|
|
329
|
+
public abstract start(): Promise<TServer | void>;
|
|
330
|
+
|
|
331
|
+
/**
|
|
332
|
+
* Handles a standard Web request without requiring a bound network server.
|
|
333
|
+
* This is the primary interoperability surface for embedding Ecopages inside
|
|
334
|
+
* other runtimes and frameworks.
|
|
335
|
+
*/
|
|
336
|
+
public abstract fetch(request: TRequest): Promise<Response>;
|
|
337
|
+
}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* This file contains the abstract router adapter class and its methods.
|
|
3
|
+
* It is designed to be extended by specific router adapters for different runtimes.
|
|
4
|
+
* The class provides methods for converting paths, creating route handlers,
|
|
5
|
+
* and adapting routes to the expected format of the runtime.
|
|
6
|
+
*
|
|
7
|
+
* @module RouterAdapter
|
|
8
|
+
*/
|
|
9
|
+
import type { Routes } from '../../internal-types.js';
|
|
10
|
+
/**
|
|
11
|
+
* Abstract base class for router adapters across different runtimes
|
|
12
|
+
*/
|
|
13
|
+
export declare abstract class AbstractRouterAdapter<TRouteFormat = any> {
|
|
14
|
+
/**
|
|
15
|
+
* Convert a route path to the format expected by the runtime
|
|
16
|
+
*/
|
|
17
|
+
protected abstract convertPath(pathname: string): string;
|
|
18
|
+
/**
|
|
19
|
+
* Create a route handler compatible with the runtime
|
|
20
|
+
*/
|
|
21
|
+
protected abstract createRouteHandler(route: any): any;
|
|
22
|
+
/**
|
|
23
|
+
* Adapt framework routes to the format expected by the runtime
|
|
24
|
+
*/
|
|
25
|
+
abstract adaptRoutes(routes: Routes): TRouteFormat;
|
|
26
|
+
}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* This file contains the abstract router adapter class and its methods.
|
|
3
|
+
* It is designed to be extended by specific router adapters for different runtimes.
|
|
4
|
+
* The class provides methods for converting paths, creating route handlers,
|
|
5
|
+
* and adapting routes to the expected format of the runtime.
|
|
6
|
+
*
|
|
7
|
+
* @module RouterAdapter
|
|
8
|
+
*/
|
|
9
|
+
|
|
10
|
+
import type { Routes } from '../../internal-types.ts';
|
|
11
|
+
|
|
12
|
+
/**
|
|
13
|
+
* Abstract base class for router adapters across different runtimes
|
|
14
|
+
*/
|
|
15
|
+
export abstract class AbstractRouterAdapter<TRouteFormat = any> {
|
|
16
|
+
/**
|
|
17
|
+
* Convert a route path to the format expected by the runtime
|
|
18
|
+
*/
|
|
19
|
+
protected abstract convertPath(pathname: string): string;
|
|
20
|
+
|
|
21
|
+
/**
|
|
22
|
+
* Create a route handler compatible with the runtime
|
|
23
|
+
*/
|
|
24
|
+
protected abstract createRouteHandler(route: any): any;
|
|
25
|
+
|
|
26
|
+
/**
|
|
27
|
+
* Adapt framework routes to the format expected by the runtime
|
|
28
|
+
*/
|
|
29
|
+
public abstract adaptRoutes(routes: Routes): TRouteFormat;
|
|
30
|
+
}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* This file contains the abstract server adapter class and its related types.
|
|
3
|
+
* It is designed to be extended by specific server adapters for different runtimes.
|
|
4
|
+
* The class provides methods for initializing the server, creating server options,
|
|
5
|
+
* building static files, and handling HTTP requests.
|
|
6
|
+
*
|
|
7
|
+
* @module ServerAdapter
|
|
8
|
+
*/
|
|
9
|
+
import type { EcoPagesAppConfig } from '../../internal-types.js';
|
|
10
|
+
import type { ApiHandler } from '../../public-types.js';
|
|
11
|
+
/**
|
|
12
|
+
* Configuration options for all server adapters
|
|
13
|
+
*/
|
|
14
|
+
export interface ServerAdapterOptions {
|
|
15
|
+
appConfig: EcoPagesAppConfig;
|
|
16
|
+
apiHandlers?: ApiHandler<string, any>[];
|
|
17
|
+
options?: {
|
|
18
|
+
watch?: boolean;
|
|
19
|
+
[key: string]: any;
|
|
20
|
+
};
|
|
21
|
+
serveOptions?: Record<string, any>;
|
|
22
|
+
runtimeOrigin: string;
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* Base adapter result containing common functionalities
|
|
26
|
+
* across different runtime implementations
|
|
27
|
+
*/
|
|
28
|
+
export interface ServerAdapterResult {
|
|
29
|
+
getServerOptions: (options?: {
|
|
30
|
+
enableHmr?: boolean;
|
|
31
|
+
}) => any;
|
|
32
|
+
buildStatic: (options?: {
|
|
33
|
+
preview?: boolean;
|
|
34
|
+
}) => Promise<void>;
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* Abstract base class for server adapters across different runtimes
|
|
38
|
+
*/
|
|
39
|
+
export declare abstract class AbstractServerAdapter<TOptions extends ServerAdapterOptions = ServerAdapterOptions, TResult extends ServerAdapterResult = ServerAdapterResult> {
|
|
40
|
+
protected appConfig: EcoPagesAppConfig;
|
|
41
|
+
protected options: TOptions['options'];
|
|
42
|
+
protected serveOptions: TOptions['serveOptions'];
|
|
43
|
+
protected runtimeOrigin: string;
|
|
44
|
+
constructor(options: TOptions);
|
|
45
|
+
/**
|
|
46
|
+
* Initialize the server adapter
|
|
47
|
+
*/
|
|
48
|
+
abstract initialize(): Promise<void>;
|
|
49
|
+
/**
|
|
50
|
+
* Create server options specific to the runtime
|
|
51
|
+
*/
|
|
52
|
+
abstract getServerOptions(options?: {
|
|
53
|
+
enableHmr?: boolean;
|
|
54
|
+
}): any;
|
|
55
|
+
/**
|
|
56
|
+
* Build static files for the application
|
|
57
|
+
*/
|
|
58
|
+
abstract buildStatic(options?: {
|
|
59
|
+
preview?: boolean;
|
|
60
|
+
}): Promise<void>;
|
|
61
|
+
/**
|
|
62
|
+
* Factory method to create a server adapter with runtime-specific functionality
|
|
63
|
+
*/
|
|
64
|
+
abstract createAdapter(): Promise<TResult>;
|
|
65
|
+
/**
|
|
66
|
+
* Handle HTTP requests
|
|
67
|
+
*/
|
|
68
|
+
abstract handleRequest(request: Request): Promise<Response>;
|
|
69
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
class AbstractServerAdapter {
|
|
2
|
+
appConfig;
|
|
3
|
+
options;
|
|
4
|
+
serveOptions;
|
|
5
|
+
runtimeOrigin;
|
|
6
|
+
constructor(options) {
|
|
7
|
+
this.appConfig = options.appConfig;
|
|
8
|
+
this.options = options.options || {};
|
|
9
|
+
this.serveOptions = options.serveOptions || {};
|
|
10
|
+
this.runtimeOrigin = options.runtimeOrigin;
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
export {
|
|
14
|
+
AbstractServerAdapter
|
|
15
|
+
};
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* This file contains the abstract server adapter class and its related types.
|
|
3
|
+
* It is designed to be extended by specific server adapters for different runtimes.
|
|
4
|
+
* The class provides methods for initializing the server, creating server options,
|
|
5
|
+
* building static files, and handling HTTP requests.
|
|
6
|
+
*
|
|
7
|
+
* @module ServerAdapter
|
|
8
|
+
*/
|
|
9
|
+
|
|
10
|
+
import type { EcoPagesAppConfig } from '../../internal-types.ts';
|
|
11
|
+
import type { ApiHandler } from '../../public-types.ts';
|
|
12
|
+
|
|
13
|
+
/**
|
|
14
|
+
* Configuration options for all server adapters
|
|
15
|
+
*/
|
|
16
|
+
export interface ServerAdapterOptions {
|
|
17
|
+
appConfig: EcoPagesAppConfig;
|
|
18
|
+
apiHandlers?: ApiHandler<string, any>[];
|
|
19
|
+
options?: {
|
|
20
|
+
watch?: boolean;
|
|
21
|
+
[key: string]: any;
|
|
22
|
+
};
|
|
23
|
+
serveOptions?: Record<string, any>;
|
|
24
|
+
runtimeOrigin: string;
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
/**
|
|
28
|
+
* Base adapter result containing common functionalities
|
|
29
|
+
* across different runtime implementations
|
|
30
|
+
*/
|
|
31
|
+
export interface ServerAdapterResult {
|
|
32
|
+
getServerOptions: (options?: { enableHmr?: boolean }) => any;
|
|
33
|
+
buildStatic: (options?: { preview?: boolean }) => Promise<void>;
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
/**
|
|
37
|
+
* Abstract base class for server adapters across different runtimes
|
|
38
|
+
*/
|
|
39
|
+
export abstract class AbstractServerAdapter<
|
|
40
|
+
TOptions extends ServerAdapterOptions = ServerAdapterOptions,
|
|
41
|
+
TResult extends ServerAdapterResult = ServerAdapterResult,
|
|
42
|
+
> {
|
|
43
|
+
protected appConfig: EcoPagesAppConfig;
|
|
44
|
+
protected options: TOptions['options'];
|
|
45
|
+
protected serveOptions: TOptions['serveOptions'];
|
|
46
|
+
protected runtimeOrigin: string;
|
|
47
|
+
|
|
48
|
+
constructor(options: TOptions) {
|
|
49
|
+
this.appConfig = options.appConfig;
|
|
50
|
+
this.options = options.options || {};
|
|
51
|
+
this.serveOptions = options.serveOptions || {};
|
|
52
|
+
this.runtimeOrigin = options.runtimeOrigin;
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
/**
|
|
56
|
+
* Initialize the server adapter
|
|
57
|
+
*/
|
|
58
|
+
public abstract initialize(): Promise<void>;
|
|
59
|
+
|
|
60
|
+
/**
|
|
61
|
+
* Create server options specific to the runtime
|
|
62
|
+
*/
|
|
63
|
+
public abstract getServerOptions(options?: { enableHmr?: boolean }): any;
|
|
64
|
+
|
|
65
|
+
/**
|
|
66
|
+
* Build static files for the application
|
|
67
|
+
*/
|
|
68
|
+
public abstract buildStatic(options?: { preview?: boolean }): Promise<void>;
|
|
69
|
+
|
|
70
|
+
/**
|
|
71
|
+
* Factory method to create a server adapter with runtime-specific functionality
|
|
72
|
+
*/
|
|
73
|
+
public abstract createAdapter(): Promise<TResult>;
|
|
74
|
+
|
|
75
|
+
/**
|
|
76
|
+
* Handle HTTP requests
|
|
77
|
+
*/
|
|
78
|
+
public abstract handleRequest(request: Request): Promise<Response>;
|
|
79
|
+
}
|