@portel/photon 1.4.1 → 1.6.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +326 -1177
- package/dist/auto-ui/beam.d.ts +14 -0
- package/dist/auto-ui/beam.d.ts.map +1 -0
- package/dist/auto-ui/beam.js +3057 -0
- package/dist/auto-ui/beam.js.map +1 -0
- package/dist/auto-ui/bridge/index.d.ts +37 -0
- package/dist/auto-ui/bridge/index.d.ts.map +1 -0
- package/dist/auto-ui/bridge/index.js +555 -0
- package/dist/auto-ui/bridge/index.js.map +1 -0
- package/dist/auto-ui/bridge/openai-shim.d.ts +20 -0
- package/dist/auto-ui/bridge/openai-shim.d.ts.map +1 -0
- package/dist/auto-ui/bridge/openai-shim.js +231 -0
- package/dist/auto-ui/bridge/openai-shim.js.map +1 -0
- package/dist/auto-ui/bridge/photon-app.d.ts +162 -0
- package/dist/auto-ui/bridge/photon-app.d.ts.map +1 -0
- package/dist/auto-ui/bridge/photon-app.js +460 -0
- package/dist/auto-ui/bridge/photon-app.js.map +1 -0
- package/dist/auto-ui/bridge/types.d.ts +128 -0
- package/dist/auto-ui/bridge/types.d.ts.map +1 -0
- package/dist/auto-ui/bridge/types.js +7 -0
- package/dist/auto-ui/bridge/types.js.map +1 -0
- package/dist/auto-ui/components/card.d.ts +13 -0
- package/dist/auto-ui/components/card.d.ts.map +1 -0
- package/dist/auto-ui/components/card.js +64 -0
- package/dist/auto-ui/components/card.js.map +1 -0
- package/dist/auto-ui/components/form.d.ts +15 -0
- package/dist/auto-ui/components/form.d.ts.map +1 -0
- package/dist/auto-ui/components/form.js +72 -0
- package/dist/auto-ui/components/form.js.map +1 -0
- package/dist/auto-ui/components/list.d.ts +13 -0
- package/dist/auto-ui/components/list.d.ts.map +1 -0
- package/dist/auto-ui/components/list.js +58 -0
- package/dist/auto-ui/components/list.js.map +1 -0
- package/dist/auto-ui/components/progress.d.ts +18 -0
- package/dist/auto-ui/components/progress.d.ts.map +1 -0
- package/dist/auto-ui/components/progress.js +125 -0
- package/dist/auto-ui/components/progress.js.map +1 -0
- package/dist/auto-ui/components/table.d.ts +13 -0
- package/dist/auto-ui/components/table.d.ts.map +1 -0
- package/dist/auto-ui/components/table.js +82 -0
- package/dist/auto-ui/components/table.js.map +1 -0
- package/dist/auto-ui/components/tree.d.ts +13 -0
- package/dist/auto-ui/components/tree.d.ts.map +1 -0
- package/dist/auto-ui/components/tree.js +61 -0
- package/dist/auto-ui/components/tree.js.map +1 -0
- package/dist/auto-ui/daemon-tools.d.ts +45 -0
- package/dist/auto-ui/daemon-tools.d.ts.map +1 -0
- package/dist/auto-ui/daemon-tools.js +580 -0
- package/dist/auto-ui/daemon-tools.js.map +1 -0
- package/dist/auto-ui/design-system/index.d.ts +21 -0
- package/dist/auto-ui/design-system/index.d.ts.map +1 -0
- package/dist/auto-ui/design-system/index.js +27 -0
- package/dist/auto-ui/design-system/index.js.map +1 -0
- package/dist/auto-ui/design-system/tokens.d.ts +9 -0
- package/dist/auto-ui/design-system/tokens.d.ts.map +1 -0
- package/dist/auto-ui/design-system/tokens.js +27 -0
- package/dist/auto-ui/design-system/tokens.js.map +1 -0
- package/dist/auto-ui/design-system/transaction-ui.d.ts +70 -0
- package/dist/auto-ui/design-system/transaction-ui.d.ts.map +1 -0
- package/dist/auto-ui/design-system/transaction-ui.js +982 -0
- package/dist/auto-ui/design-system/transaction-ui.js.map +1 -0
- package/dist/auto-ui/frontend/index.html +84 -0
- package/dist/auto-ui/index.d.ts +23 -0
- package/dist/auto-ui/index.d.ts.map +1 -0
- package/dist/auto-ui/index.js +28 -0
- package/dist/auto-ui/index.js.map +1 -0
- package/dist/auto-ui/openapi-generator.d.ts +71 -0
- package/dist/auto-ui/openapi-generator.d.ts.map +1 -0
- package/dist/auto-ui/openapi-generator.js +223 -0
- package/dist/auto-ui/openapi-generator.js.map +1 -0
- package/dist/auto-ui/photon-bridge.d.ts +159 -0
- package/dist/auto-ui/photon-bridge.d.ts.map +1 -0
- package/dist/auto-ui/photon-bridge.js +262 -0
- package/dist/auto-ui/photon-bridge.js.map +1 -0
- package/dist/auto-ui/photon-host.d.ts +113 -0
- package/dist/auto-ui/photon-host.d.ts.map +1 -0
- package/dist/auto-ui/photon-host.js +284 -0
- package/dist/auto-ui/photon-host.js.map +1 -0
- package/dist/auto-ui/platform-compat.d.ts +71 -0
- package/dist/auto-ui/platform-compat.d.ts.map +1 -0
- package/dist/auto-ui/platform-compat.js +628 -0
- package/dist/auto-ui/platform-compat.js.map +1 -0
- package/dist/auto-ui/playground-html.d.ts +15 -0
- package/dist/auto-ui/playground-html.d.ts.map +1 -0
- package/dist/auto-ui/playground-html.js +1113 -0
- package/dist/auto-ui/playground-html.js.map +1 -0
- package/dist/auto-ui/playground-server.d.ts +7 -0
- package/dist/auto-ui/playground-server.d.ts.map +1 -0
- package/dist/auto-ui/playground-server.js +840 -0
- package/dist/auto-ui/playground-server.js.map +1 -0
- package/dist/auto-ui/registry.d.ts +13 -0
- package/dist/auto-ui/registry.d.ts.map +1 -0
- package/dist/auto-ui/registry.js +62 -0
- package/dist/auto-ui/registry.js.map +1 -0
- package/dist/auto-ui/renderer.d.ts +14 -0
- package/dist/auto-ui/renderer.d.ts.map +1 -0
- package/dist/auto-ui/renderer.js +88 -0
- package/dist/auto-ui/renderer.js.map +1 -0
- package/dist/auto-ui/rendering/components.d.ts +29 -0
- package/dist/auto-ui/rendering/components.d.ts.map +1 -0
- package/dist/auto-ui/rendering/components.js +773 -0
- package/dist/auto-ui/rendering/components.js.map +1 -0
- package/dist/auto-ui/rendering/field-analyzer.d.ts +48 -0
- package/dist/auto-ui/rendering/field-analyzer.d.ts.map +1 -0
- package/dist/auto-ui/rendering/field-analyzer.js +270 -0
- package/dist/auto-ui/rendering/field-analyzer.js.map +1 -0
- package/dist/auto-ui/rendering/field-renderers.d.ts +64 -0
- package/dist/auto-ui/rendering/field-renderers.d.ts.map +1 -0
- package/dist/auto-ui/rendering/field-renderers.js +317 -0
- package/dist/auto-ui/rendering/field-renderers.js.map +1 -0
- package/dist/auto-ui/rendering/index.d.ts +28 -0
- package/dist/auto-ui/rendering/index.d.ts.map +1 -0
- package/dist/auto-ui/rendering/index.js +60 -0
- package/dist/auto-ui/rendering/index.js.map +1 -0
- package/dist/auto-ui/rendering/layout-selector.d.ts +48 -0
- package/dist/auto-ui/rendering/layout-selector.d.ts.map +1 -0
- package/dist/auto-ui/rendering/layout-selector.js +352 -0
- package/dist/auto-ui/rendering/layout-selector.js.map +1 -0
- package/dist/auto-ui/rendering/template-engine.d.ts +41 -0
- package/dist/auto-ui/rendering/template-engine.d.ts.map +1 -0
- package/dist/auto-ui/rendering/template-engine.js +238 -0
- package/dist/auto-ui/rendering/template-engine.js.map +1 -0
- package/dist/auto-ui/streamable-http-transport.d.ts +103 -0
- package/dist/auto-ui/streamable-http-transport.d.ts.map +1 -0
- package/dist/auto-ui/streamable-http-transport.js +1875 -0
- package/dist/auto-ui/streamable-http-transport.js.map +1 -0
- package/dist/auto-ui/types.d.ts +384 -0
- package/dist/auto-ui/types.d.ts.map +1 -0
- package/dist/auto-ui/types.js +92 -0
- package/dist/auto-ui/types.js.map +1 -0
- package/dist/beam.bundle.js +63137 -0
- package/dist/beam.bundle.js.map +7 -0
- package/dist/claude-code-plugin.d.ts.map +1 -1
- package/dist/claude-code-plugin.js +30 -30
- package/dist/claude-code-plugin.js.map +1 -1
- package/dist/cli/commands/info.d.ts +11 -0
- package/dist/cli/commands/info.d.ts.map +1 -0
- package/dist/cli/commands/info.js +313 -0
- package/dist/cli/commands/info.js.map +1 -0
- package/dist/cli/commands/marketplace.d.ts +11 -0
- package/dist/cli/commands/marketplace.d.ts.map +1 -0
- package/dist/cli/commands/marketplace.js +198 -0
- package/dist/cli/commands/marketplace.js.map +1 -0
- package/dist/cli/commands/package-app.d.ts +9 -0
- package/dist/cli/commands/package-app.d.ts.map +1 -0
- package/dist/cli/commands/package-app.js +191 -0
- package/dist/cli/commands/package-app.js.map +1 -0
- package/dist/cli/commands/package.d.ts +11 -0
- package/dist/cli/commands/package.d.ts.map +1 -0
- package/dist/cli/commands/package.js +573 -0
- package/dist/cli/commands/package.js.map +1 -0
- package/dist/cli-alias.d.ts.map +1 -1
- package/dist/cli-alias.js +30 -28
- package/dist/cli-alias.js.map +1 -1
- package/dist/cli-formatter.d.ts +8 -24
- package/dist/cli-formatter.d.ts.map +1 -1
- package/dist/cli-formatter.js +8 -325
- package/dist/cli-formatter.js.map +1 -1
- package/dist/cli.d.ts +15 -1
- package/dist/cli.d.ts.map +1 -1
- package/dist/cli.js +1166 -1131
- package/dist/cli.js.map +1 -1
- package/dist/daemon/client.d.ts +84 -3
- package/dist/daemon/client.d.ts.map +1 -1
- package/dist/daemon/client.js +561 -11
- package/dist/daemon/client.js.map +1 -1
- package/dist/daemon/manager.d.ts +51 -12
- package/dist/daemon/manager.d.ts.map +1 -1
- package/dist/daemon/manager.js +122 -61
- package/dist/daemon/manager.js.map +1 -1
- package/dist/daemon/protocol.d.ts +62 -6
- package/dist/daemon/protocol.d.ts.map +1 -1
- package/dist/daemon/protocol.js +76 -1
- package/dist/daemon/protocol.js.map +1 -1
- package/dist/daemon/server.d.ts +6 -6
- package/dist/daemon/server.js +743 -133
- package/dist/daemon/server.js.map +1 -1
- package/dist/daemon/session-manager.d.ts +8 -1
- package/dist/daemon/session-manager.d.ts.map +1 -1
- package/dist/daemon/session-manager.js +32 -9
- package/dist/daemon/session-manager.js.map +1 -1
- package/dist/deploy/cloudflare.d.ts +12 -0
- package/dist/deploy/cloudflare.d.ts.map +1 -0
- package/dist/deploy/cloudflare.js +216 -0
- package/dist/deploy/cloudflare.js.map +1 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +3 -0
- package/dist/index.js.map +1 -1
- package/dist/loader.d.ts +191 -21
- package/dist/loader.d.ts.map +1 -1
- package/dist/loader.js +1186 -319
- package/dist/loader.js.map +1 -1
- package/dist/markdown-utils.d.ts +8 -0
- package/dist/markdown-utils.d.ts.map +1 -0
- package/dist/markdown-utils.js +63 -0
- package/dist/markdown-utils.js.map +1 -0
- package/dist/marketplace-manager.d.ts +10 -0
- package/dist/marketplace-manager.d.ts.map +1 -1
- package/dist/marketplace-manager.js +112 -28
- package/dist/marketplace-manager.js.map +1 -1
- package/dist/mcp-client.d.ts +9 -0
- package/dist/mcp-client.d.ts.map +1 -0
- package/dist/mcp-client.js +11 -0
- package/dist/mcp-client.js.map +1 -0
- package/dist/mcp-elicitation.d.ts +32 -0
- package/dist/mcp-elicitation.d.ts.map +1 -0
- package/dist/mcp-elicitation.js +26 -0
- package/dist/mcp-elicitation.js.map +1 -0
- package/dist/path-resolver.d.ts +9 -12
- package/dist/path-resolver.d.ts.map +1 -1
- package/dist/path-resolver.js +13 -43
- package/dist/path-resolver.js.map +1 -1
- package/dist/photon-cli-runner.d.ts.map +1 -1
- package/dist/photon-cli-runner.js +204 -77
- package/dist/photon-cli-runner.js.map +1 -1
- package/dist/photon-doc-extractor.d.ts +89 -0
- package/dist/photon-doc-extractor.d.ts.map +1 -1
- package/dist/photon-doc-extractor.js +560 -32
- package/dist/photon-doc-extractor.js.map +1 -1
- package/dist/photons/maker.photon.d.ts +182 -0
- package/dist/photons/maker.photon.d.ts.map +1 -0
- package/dist/photons/maker.photon.js +504 -0
- package/dist/photons/maker.photon.js.map +1 -0
- package/dist/photons/maker.photon.ts +626 -0
- package/dist/photons/marketplace.photon.d.ts +110 -0
- package/dist/photons/marketplace.photon.d.ts.map +1 -0
- package/dist/photons/marketplace.photon.js +260 -0
- package/dist/photons/marketplace.photon.js.map +1 -0
- package/dist/photons/marketplace.photon.ts +378 -0
- package/dist/photons/tunnel.photon.d.ts +80 -0
- package/dist/photons/tunnel.photon.d.ts.map +1 -0
- package/dist/photons/tunnel.photon.js +269 -0
- package/dist/photons/tunnel.photon.js.map +1 -0
- package/dist/photons/tunnel.photon.ts +345 -0
- package/dist/security-scanner.d.ts.map +1 -1
- package/dist/security-scanner.js +18 -15
- package/dist/security-scanner.js.map +1 -1
- package/dist/serv/auth/jwt.d.ts +89 -0
- package/dist/serv/auth/jwt.d.ts.map +1 -0
- package/dist/serv/auth/jwt.js +239 -0
- package/dist/serv/auth/jwt.js.map +1 -0
- package/dist/serv/auth/oauth.d.ts +117 -0
- package/dist/serv/auth/oauth.d.ts.map +1 -0
- package/dist/serv/auth/oauth.js +395 -0
- package/dist/serv/auth/oauth.js.map +1 -0
- package/dist/serv/auth/well-known.d.ts +60 -0
- package/dist/serv/auth/well-known.d.ts.map +1 -0
- package/dist/serv/auth/well-known.js +154 -0
- package/dist/serv/auth/well-known.js.map +1 -0
- package/dist/serv/db/d1-client.d.ts +65 -0
- package/dist/serv/db/d1-client.d.ts.map +1 -0
- package/dist/serv/db/d1-client.js +137 -0
- package/dist/serv/db/d1-client.js.map +1 -0
- package/dist/serv/db/d1-stores.d.ts +62 -0
- package/dist/serv/db/d1-stores.d.ts.map +1 -0
- package/dist/serv/db/d1-stores.js +307 -0
- package/dist/serv/db/d1-stores.js.map +1 -0
- package/dist/serv/index.d.ts +114 -0
- package/dist/serv/index.d.ts.map +1 -0
- package/dist/serv/index.js +172 -0
- package/dist/serv/index.js.map +1 -0
- package/dist/serv/local.d.ts +118 -0
- package/dist/serv/local.d.ts.map +1 -0
- package/dist/serv/local.js +392 -0
- package/dist/serv/local.js.map +1 -0
- package/dist/serv/middleware/auth.d.ts +66 -0
- package/dist/serv/middleware/auth.d.ts.map +1 -0
- package/dist/serv/middleware/auth.js +178 -0
- package/dist/serv/middleware/auth.js.map +1 -0
- package/dist/serv/middleware/tenant.d.ts +94 -0
- package/dist/serv/middleware/tenant.d.ts.map +1 -0
- package/dist/serv/middleware/tenant.js +152 -0
- package/dist/serv/middleware/tenant.js.map +1 -0
- package/dist/serv/runtime/executor.d.ts +76 -0
- package/dist/serv/runtime/executor.d.ts.map +1 -0
- package/dist/serv/runtime/executor.js +105 -0
- package/dist/serv/runtime/executor.js.map +1 -0
- package/dist/serv/runtime/index.d.ts +8 -0
- package/dist/serv/runtime/index.d.ts.map +1 -0
- package/dist/serv/runtime/index.js +10 -0
- package/dist/serv/runtime/index.js.map +1 -0
- package/dist/serv/runtime/oauth-context.d.ts +121 -0
- package/dist/serv/runtime/oauth-context.d.ts.map +1 -0
- package/dist/serv/runtime/oauth-context.js +153 -0
- package/dist/serv/runtime/oauth-context.js.map +1 -0
- package/dist/serv/session/kv-store.d.ts +54 -0
- package/dist/serv/session/kv-store.d.ts.map +1 -0
- package/dist/serv/session/kv-store.js +149 -0
- package/dist/serv/session/kv-store.js.map +1 -0
- package/dist/serv/session/store.d.ts +113 -0
- package/dist/serv/session/store.d.ts.map +1 -0
- package/dist/serv/session/store.js +284 -0
- package/dist/serv/session/store.js.map +1 -0
- package/dist/serv/types/index.d.ts +147 -0
- package/dist/serv/types/index.d.ts.map +1 -0
- package/dist/serv/types/index.js +8 -0
- package/dist/serv/types/index.js.map +1 -0
- package/dist/serv/vault/token-vault.d.ts +102 -0
- package/dist/serv/vault/token-vault.d.ts.map +1 -0
- package/dist/serv/vault/token-vault.js +177 -0
- package/dist/serv/vault/token-vault.js.map +1 -0
- package/dist/server.d.ts +184 -0
- package/dist/server.d.ts.map +1 -1
- package/dist/server.js +1995 -86
- package/dist/server.js.map +1 -1
- package/dist/shared/cli-sections.d.ts +6 -0
- package/dist/shared/cli-sections.d.ts.map +1 -0
- package/dist/shared/cli-sections.js +16 -0
- package/dist/shared/cli-sections.js.map +1 -0
- package/dist/shared/cli-utils.d.ts +81 -0
- package/dist/shared/cli-utils.d.ts.map +1 -0
- package/dist/shared/cli-utils.js +174 -0
- package/dist/shared/cli-utils.js.map +1 -0
- package/dist/shared/config-docs.d.ts +6 -0
- package/dist/shared/config-docs.d.ts.map +1 -0
- package/dist/shared/config-docs.js +6 -0
- package/dist/shared/config-docs.js.map +1 -0
- package/dist/shared/error-handler.d.ts +128 -0
- package/dist/shared/error-handler.d.ts.map +1 -0
- package/dist/shared/error-handler.js +342 -0
- package/dist/shared/error-handler.js.map +1 -0
- package/dist/shared/logger.d.ts +42 -0
- package/dist/shared/logger.d.ts.map +1 -0
- package/dist/shared/logger.js +123 -0
- package/dist/shared/logger.js.map +1 -0
- package/dist/shared/performance.d.ts +65 -0
- package/dist/shared/performance.d.ts.map +1 -0
- package/dist/shared/performance.js +136 -0
- package/dist/shared/performance.js.map +1 -0
- package/dist/shared/task-runner.d.ts +2 -0
- package/dist/shared/task-runner.d.ts.map +1 -0
- package/dist/shared/task-runner.js +16 -0
- package/dist/shared/task-runner.js.map +1 -0
- package/dist/shared/validation.d.ts +6 -0
- package/dist/shared/validation.d.ts.map +1 -0
- package/dist/shared/validation.js +6 -0
- package/dist/shared/validation.js.map +1 -0
- package/dist/shared-utils.d.ts +63 -0
- package/dist/shared-utils.d.ts.map +1 -0
- package/dist/shared-utils.js +123 -0
- package/dist/shared-utils.js.map +1 -0
- package/dist/template-manager.d.ts +23 -2
- package/dist/template-manager.d.ts.map +1 -1
- package/dist/template-manager.js +176 -87
- package/dist/template-manager.js.map +1 -1
- package/dist/test-client.d.ts.map +1 -1
- package/dist/test-client.js +10 -8
- package/dist/test-client.js.map +1 -1
- package/dist/test-runner.d.ts +52 -0
- package/dist/test-runner.d.ts.map +1 -0
- package/dist/test-runner.js +785 -0
- package/dist/test-runner.js.map +1 -0
- package/dist/testing.d.ts +103 -0
- package/dist/testing.d.ts.map +1 -0
- package/dist/testing.js +163 -0
- package/dist/testing.js.map +1 -0
- package/dist/version-checker.d.ts.map +1 -1
- package/dist/version-checker.js +2 -2
- package/dist/version-checker.js.map +1 -1
- package/dist/version.d.ts +10 -0
- package/dist/version.d.ts.map +1 -0
- package/dist/version.js +21 -0
- package/dist/version.js.map +1 -0
- package/dist/watcher.d.ts +6 -3
- package/dist/watcher.d.ts.map +1 -1
- package/dist/watcher.js +49 -10
- package/dist/watcher.js.map +1 -1
- package/package.json +57 -7
- package/templates/cloudflare/worker.ts.template +381 -0
- package/templates/cloudflare/wrangler.toml.template +9 -0
- package/dist/base.d.ts +0 -58
- package/dist/base.d.ts.map +0 -1
- package/dist/base.js +0 -92
- package/dist/base.js.map +0 -1
- package/dist/dependency-manager.d.ts +0 -49
- package/dist/dependency-manager.d.ts.map +0 -1
- package/dist/dependency-manager.js +0 -165
- package/dist/dependency-manager.js.map +0 -1
- package/dist/registry-manager.d.ts +0 -76
- package/dist/registry-manager.d.ts.map +0 -1
- package/dist/registry-manager.js +0 -220
- package/dist/registry-manager.js.map +0 -1
- package/dist/schema-extractor.d.ts +0 -110
- package/dist/schema-extractor.d.ts.map +0 -1
- package/dist/schema-extractor.js +0 -727
- package/dist/schema-extractor.js.map +0 -1
- package/dist/test-marketplace-sources.d.ts +0 -5
- package/dist/test-marketplace-sources.d.ts.map +0 -1
- package/dist/test-marketplace-sources.js +0 -53
- package/dist/test-marketplace-sources.js.map +0 -1
- package/dist/types.d.ts +0 -109
- package/dist/types.d.ts.map +0 -1
- package/dist/types.js +0 -12
- package/dist/types.js.map +0 -1
|
@@ -0,0 +1,392 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* SERV Local Development Mode
|
|
3
|
+
*
|
|
4
|
+
* Zero external dependencies - everything runs in-memory.
|
|
5
|
+
* Perfect for local testing before deploying to Cloudflare.
|
|
6
|
+
*/
|
|
7
|
+
import { randomUUID } from 'crypto';
|
|
8
|
+
import { MemorySessionStore } from './session/store.js';
|
|
9
|
+
import { MemoryTenantStore } from './middleware/tenant.js';
|
|
10
|
+
import { MemoryElicitationStore, MemoryGrantStore, OAuthProviderRegistry, OAuthFlowHandler, } from './auth/oauth.js';
|
|
11
|
+
import { LocalTokenVault } from './vault/token-vault.js';
|
|
12
|
+
import { JwtService } from './auth/jwt.js';
|
|
13
|
+
import { TenantResolver } from './middleware/tenant.js';
|
|
14
|
+
import { AuthMiddleware } from './middleware/auth.js';
|
|
15
|
+
import { handleProtectedResourceRequest, handleAuthServerRequest, } from './auth/well-known.js';
|
|
16
|
+
// ============================================================================
|
|
17
|
+
// Local User Store (In-Memory)
|
|
18
|
+
// ============================================================================
|
|
19
|
+
export class LocalUserStore {
|
|
20
|
+
users = new Map();
|
|
21
|
+
emailIndex = new Map();
|
|
22
|
+
async findById(id) {
|
|
23
|
+
return this.users.get(id) ?? null;
|
|
24
|
+
}
|
|
25
|
+
async findByEmail(email) {
|
|
26
|
+
const id = this.emailIndex.get(email.toLowerCase());
|
|
27
|
+
return id ? (this.users.get(id) ?? null) : null;
|
|
28
|
+
}
|
|
29
|
+
async create(data) {
|
|
30
|
+
const user = {
|
|
31
|
+
id: randomUUID(),
|
|
32
|
+
...data,
|
|
33
|
+
createdAt: new Date(),
|
|
34
|
+
};
|
|
35
|
+
this.users.set(user.id, user);
|
|
36
|
+
this.emailIndex.set(user.email.toLowerCase(), user.id);
|
|
37
|
+
return user;
|
|
38
|
+
}
|
|
39
|
+
add(user) {
|
|
40
|
+
this.users.set(user.id, user);
|
|
41
|
+
this.emailIndex.set(user.email.toLowerCase(), user.id);
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
// ============================================================================
|
|
45
|
+
// Local Membership Store (In-Memory)
|
|
46
|
+
// ============================================================================
|
|
47
|
+
export class LocalMembershipStore {
|
|
48
|
+
memberships = new Map();
|
|
49
|
+
key(tenantId, userId) {
|
|
50
|
+
return `${tenantId}:${userId}`;
|
|
51
|
+
}
|
|
52
|
+
async find(tenantId, userId) {
|
|
53
|
+
return this.memberships.get(this.key(tenantId, userId)) ?? null;
|
|
54
|
+
}
|
|
55
|
+
async findByUser(userId) {
|
|
56
|
+
return Array.from(this.memberships.values()).filter((m) => m.userId === userId);
|
|
57
|
+
}
|
|
58
|
+
async create(data) {
|
|
59
|
+
const membership = {
|
|
60
|
+
...data,
|
|
61
|
+
joinedAt: new Date(),
|
|
62
|
+
};
|
|
63
|
+
this.memberships.set(this.key(data.tenantId, data.userId), membership);
|
|
64
|
+
return membership;
|
|
65
|
+
}
|
|
66
|
+
add(membership) {
|
|
67
|
+
this.memberships.set(this.key(membership.tenantId, membership.userId), membership);
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
// ============================================================================
|
|
71
|
+
// Local SERV Instance
|
|
72
|
+
// ============================================================================
|
|
73
|
+
export class LocalServ {
|
|
74
|
+
port;
|
|
75
|
+
baseUrl;
|
|
76
|
+
debug;
|
|
77
|
+
// Stores
|
|
78
|
+
sessions;
|
|
79
|
+
tenants;
|
|
80
|
+
users;
|
|
81
|
+
memberships;
|
|
82
|
+
elicitations;
|
|
83
|
+
grants;
|
|
84
|
+
vault;
|
|
85
|
+
// Services
|
|
86
|
+
jwt;
|
|
87
|
+
tenantResolver;
|
|
88
|
+
auth;
|
|
89
|
+
oauthProviders;
|
|
90
|
+
oauthFlow;
|
|
91
|
+
// Secrets (auto-generated for local dev)
|
|
92
|
+
secrets;
|
|
93
|
+
constructor(config = {}) {
|
|
94
|
+
this.port = config.port ?? 3000;
|
|
95
|
+
this.baseUrl = config.baseUrl ?? `http://localhost:${this.port}`;
|
|
96
|
+
this.debug = config.debug ?? false;
|
|
97
|
+
// Generate random secrets for local dev
|
|
98
|
+
this.secrets = {
|
|
99
|
+
jwt: `local-jwt-${randomUUID()}`,
|
|
100
|
+
encryption: `local-enc-${randomUUID()}`,
|
|
101
|
+
state: `local-state-${randomUUID()}`,
|
|
102
|
+
};
|
|
103
|
+
// Initialize stores
|
|
104
|
+
this.sessions = new MemorySessionStore();
|
|
105
|
+
this.tenants = new MemoryTenantStore();
|
|
106
|
+
this.users = new LocalUserStore();
|
|
107
|
+
this.memberships = new LocalMembershipStore();
|
|
108
|
+
this.elicitations = new MemoryElicitationStore();
|
|
109
|
+
this.grants = new MemoryGrantStore();
|
|
110
|
+
this.vault = new LocalTokenVault({ masterKey: this.secrets.encryption });
|
|
111
|
+
// Initialize JWT service
|
|
112
|
+
this.jwt = new JwtService({
|
|
113
|
+
secret: this.secrets.jwt,
|
|
114
|
+
issuer: this.baseUrl,
|
|
115
|
+
});
|
|
116
|
+
// Initialize tenant resolver
|
|
117
|
+
this.tenantResolver = new TenantResolver({
|
|
118
|
+
baseDomain: 'localhost',
|
|
119
|
+
store: this.tenants,
|
|
120
|
+
});
|
|
121
|
+
// Initialize auth middleware
|
|
122
|
+
this.auth = new AuthMiddleware({
|
|
123
|
+
jwtService: this.jwt,
|
|
124
|
+
sessionStore: this.sessions,
|
|
125
|
+
userStore: this.users,
|
|
126
|
+
membershipStore: this.memberships,
|
|
127
|
+
});
|
|
128
|
+
// Initialize OAuth
|
|
129
|
+
this.oauthProviders = new OAuthProviderRegistry();
|
|
130
|
+
this.oauthFlow = new OAuthFlowHandler({
|
|
131
|
+
baseUrl: this.baseUrl,
|
|
132
|
+
stateSecret: this.secrets.state,
|
|
133
|
+
providers: this.oauthProviders,
|
|
134
|
+
elicitationStore: this.elicitations,
|
|
135
|
+
grantStore: this.grants,
|
|
136
|
+
tokenVault: this.vault,
|
|
137
|
+
});
|
|
138
|
+
this.log('LocalServ initialized', { port: this.port, baseUrl: this.baseUrl });
|
|
139
|
+
}
|
|
140
|
+
// ===========================================================================
|
|
141
|
+
// Setup Helpers
|
|
142
|
+
// ===========================================================================
|
|
143
|
+
/**
|
|
144
|
+
* Create a tenant for local testing
|
|
145
|
+
*/
|
|
146
|
+
createTenant(options) {
|
|
147
|
+
const tenant = {
|
|
148
|
+
id: randomUUID(),
|
|
149
|
+
name: options.name,
|
|
150
|
+
slug: options.slug,
|
|
151
|
+
region: 'local',
|
|
152
|
+
plan: options.plan ?? 'free',
|
|
153
|
+
encryptionKeyId: 'local-key',
|
|
154
|
+
settings: {
|
|
155
|
+
allowAnonymousUsers: true,
|
|
156
|
+
sponsoredPhotons: [],
|
|
157
|
+
},
|
|
158
|
+
createdAt: new Date(),
|
|
159
|
+
};
|
|
160
|
+
this.tenants.add(tenant);
|
|
161
|
+
this.log('Created tenant', { slug: tenant.slug, id: tenant.id });
|
|
162
|
+
return tenant;
|
|
163
|
+
}
|
|
164
|
+
/**
|
|
165
|
+
* Create a user for local testing
|
|
166
|
+
*/
|
|
167
|
+
createUser(options) {
|
|
168
|
+
const user = {
|
|
169
|
+
id: randomUUID(),
|
|
170
|
+
email: options.email,
|
|
171
|
+
emailVerified: options.verified ?? true,
|
|
172
|
+
createdAt: new Date(),
|
|
173
|
+
};
|
|
174
|
+
this.users.add(user);
|
|
175
|
+
this.log('Created user', { email: user.email, id: user.id });
|
|
176
|
+
return user;
|
|
177
|
+
}
|
|
178
|
+
/**
|
|
179
|
+
* Add a user to a tenant
|
|
180
|
+
*/
|
|
181
|
+
addMembership(options) {
|
|
182
|
+
const membership = {
|
|
183
|
+
tenantId: options.tenant.id,
|
|
184
|
+
userId: options.user.id,
|
|
185
|
+
role: options.role ?? 'member',
|
|
186
|
+
status: 'active',
|
|
187
|
+
joinedAt: new Date(),
|
|
188
|
+
};
|
|
189
|
+
this.memberships.add(membership);
|
|
190
|
+
this.log('Added membership', {
|
|
191
|
+
user: options.user.email,
|
|
192
|
+
tenant: options.tenant.slug,
|
|
193
|
+
role: membership.role,
|
|
194
|
+
});
|
|
195
|
+
return membership;
|
|
196
|
+
}
|
|
197
|
+
/**
|
|
198
|
+
* Register an OAuth provider for testing
|
|
199
|
+
*/
|
|
200
|
+
registerOAuthProvider(providerId, clientId, clientSecret) {
|
|
201
|
+
this.oauthProviders.register(providerId, clientId, clientSecret);
|
|
202
|
+
this.log('Registered OAuth provider', { providerId });
|
|
203
|
+
}
|
|
204
|
+
// ===========================================================================
|
|
205
|
+
// Session Management
|
|
206
|
+
// ===========================================================================
|
|
207
|
+
/**
|
|
208
|
+
* Create a session for a user in a tenant
|
|
209
|
+
*/
|
|
210
|
+
async createSession(tenant, user) {
|
|
211
|
+
const session = await this.sessions.create({
|
|
212
|
+
tenantId: tenant.id,
|
|
213
|
+
userId: user?.id,
|
|
214
|
+
clientId: 'local-dev',
|
|
215
|
+
});
|
|
216
|
+
const token = this.jwt.generateSessionToken(session, tenant, user, user ? ((await this.memberships.find(tenant.id, user.id)) ?? undefined) : undefined);
|
|
217
|
+
this.log('Created session', {
|
|
218
|
+
sessionId: session.id,
|
|
219
|
+
tenant: tenant.slug,
|
|
220
|
+
user: user?.email ?? 'anonymous',
|
|
221
|
+
});
|
|
222
|
+
return { session, token };
|
|
223
|
+
}
|
|
224
|
+
// ===========================================================================
|
|
225
|
+
// Request Handling
|
|
226
|
+
// ===========================================================================
|
|
227
|
+
/**
|
|
228
|
+
* Handle an HTTP request (for use with Node.js http server)
|
|
229
|
+
*/
|
|
230
|
+
async handleRequest(method, url, headers, body) {
|
|
231
|
+
const parsedUrl = new URL(url, this.baseUrl);
|
|
232
|
+
const path = parsedUrl.pathname;
|
|
233
|
+
this.log('Request', { method, path });
|
|
234
|
+
try {
|
|
235
|
+
// Well-known endpoints
|
|
236
|
+
if (path === '/.well-known/oauth-protected-resource') {
|
|
237
|
+
const tenant = await this.resolveTenant(headers);
|
|
238
|
+
if (!tenant)
|
|
239
|
+
return this.notFound('Tenant not found');
|
|
240
|
+
return handleProtectedResourceRequest({ baseUrl: this.baseUrl }, tenant);
|
|
241
|
+
}
|
|
242
|
+
if (path === '/.well-known/oauth-authorization-server') {
|
|
243
|
+
const tenant = await this.resolveTenant(headers);
|
|
244
|
+
if (!tenant)
|
|
245
|
+
return this.notFound('Tenant not found');
|
|
246
|
+
return handleAuthServerRequest({ baseUrl: this.baseUrl }, tenant);
|
|
247
|
+
}
|
|
248
|
+
// OAuth callback
|
|
249
|
+
if (path === '/auth/oauth/callback') {
|
|
250
|
+
const code = parsedUrl.searchParams.get('code');
|
|
251
|
+
const state = parsedUrl.searchParams.get('state');
|
|
252
|
+
if (!code || !state) {
|
|
253
|
+
return this.badRequest('Missing code or state');
|
|
254
|
+
}
|
|
255
|
+
const tenant = await this.resolveTenant(headers);
|
|
256
|
+
if (!tenant)
|
|
257
|
+
return this.notFound('Tenant not found');
|
|
258
|
+
const result = await this.oauthFlow.handleCallback(code, state, tenant.id);
|
|
259
|
+
if (!result.success) {
|
|
260
|
+
return this.badRequest(result.error ?? 'OAuth callback failed');
|
|
261
|
+
}
|
|
262
|
+
return {
|
|
263
|
+
status: 200,
|
|
264
|
+
headers: { 'Content-Type': 'text/html' },
|
|
265
|
+
body: `
|
|
266
|
+
<!DOCTYPE html>
|
|
267
|
+
<html>
|
|
268
|
+
<head><title>Authorization Complete</title></head>
|
|
269
|
+
<body>
|
|
270
|
+
<h1>Authorization Successful</h1>
|
|
271
|
+
<p>You can close this window and retry your request.</p>
|
|
272
|
+
<script>window.close();</script>
|
|
273
|
+
</body>
|
|
274
|
+
</html>
|
|
275
|
+
`,
|
|
276
|
+
};
|
|
277
|
+
}
|
|
278
|
+
// MCP endpoint (placeholder)
|
|
279
|
+
if (path.endsWith('/mcp')) {
|
|
280
|
+
const tenant = await this.resolveTenant(headers);
|
|
281
|
+
if (!tenant)
|
|
282
|
+
return this.notFound('Tenant not found');
|
|
283
|
+
const authResult = await this.auth.authenticate(tenant, headers['authorization']);
|
|
284
|
+
if (!authResult.success) {
|
|
285
|
+
return {
|
|
286
|
+
status: authResult.error.code,
|
|
287
|
+
headers: {
|
|
288
|
+
'Content-Type': 'application/json',
|
|
289
|
+
...(authResult.error.wwwAuthenticate
|
|
290
|
+
? { 'WWW-Authenticate': authResult.error.wwwAuthenticate }
|
|
291
|
+
: {}),
|
|
292
|
+
},
|
|
293
|
+
body: JSON.stringify({ error: authResult.error.message }),
|
|
294
|
+
};
|
|
295
|
+
}
|
|
296
|
+
// MCP endpoint status - actual MCP protocol handled via SSE transport
|
|
297
|
+
return {
|
|
298
|
+
status: 200,
|
|
299
|
+
headers: { 'Content-Type': 'application/json' },
|
|
300
|
+
body: JSON.stringify({
|
|
301
|
+
message: 'MCP endpoint ready',
|
|
302
|
+
tenant: tenant.slug,
|
|
303
|
+
session: authResult.context?.session?.id,
|
|
304
|
+
}),
|
|
305
|
+
};
|
|
306
|
+
}
|
|
307
|
+
return this.notFound('Not found');
|
|
308
|
+
}
|
|
309
|
+
catch (err) {
|
|
310
|
+
this.log('Error', { error: err instanceof Error ? err.message : String(err) });
|
|
311
|
+
return {
|
|
312
|
+
status: 500,
|
|
313
|
+
headers: { 'Content-Type': 'application/json' },
|
|
314
|
+
body: JSON.stringify({ error: 'Internal server error' }),
|
|
315
|
+
};
|
|
316
|
+
}
|
|
317
|
+
}
|
|
318
|
+
// ===========================================================================
|
|
319
|
+
// Helpers
|
|
320
|
+
// ===========================================================================
|
|
321
|
+
async resolveTenant(headers) {
|
|
322
|
+
// For local dev, try to find from path or default to first tenant
|
|
323
|
+
const host = headers['host'] ?? 'localhost';
|
|
324
|
+
// Try subdomain
|
|
325
|
+
const tenant = await this.tenantResolver.resolve({ host, headers: { host } });
|
|
326
|
+
if (tenant)
|
|
327
|
+
return tenant;
|
|
328
|
+
// For local dev, return first tenant if only one exists
|
|
329
|
+
// (This is a convenience for testing)
|
|
330
|
+
return null;
|
|
331
|
+
}
|
|
332
|
+
notFound(message) {
|
|
333
|
+
return {
|
|
334
|
+
status: 404,
|
|
335
|
+
headers: { 'Content-Type': 'application/json' },
|
|
336
|
+
body: JSON.stringify({ error: message }),
|
|
337
|
+
};
|
|
338
|
+
}
|
|
339
|
+
badRequest(message) {
|
|
340
|
+
return {
|
|
341
|
+
status: 400,
|
|
342
|
+
headers: { 'Content-Type': 'application/json' },
|
|
343
|
+
body: JSON.stringify({ error: message }),
|
|
344
|
+
};
|
|
345
|
+
}
|
|
346
|
+
log(message, data) {
|
|
347
|
+
if (this.debug) {
|
|
348
|
+
console.log(`[LocalServ] ${message}`, data ? JSON.stringify(data) : '');
|
|
349
|
+
}
|
|
350
|
+
}
|
|
351
|
+
// ===========================================================================
|
|
352
|
+
// Shutdown
|
|
353
|
+
// ===========================================================================
|
|
354
|
+
async shutdown() {
|
|
355
|
+
await this.sessions.close();
|
|
356
|
+
this.log('Shutdown complete');
|
|
357
|
+
}
|
|
358
|
+
}
|
|
359
|
+
// ============================================================================
|
|
360
|
+
// Quick Start
|
|
361
|
+
// ============================================================================
|
|
362
|
+
/**
|
|
363
|
+
* Create a LocalServ instance with a default tenant and user
|
|
364
|
+
*/
|
|
365
|
+
export function createLocalServ(config) {
|
|
366
|
+
const serv = new LocalServ(config);
|
|
367
|
+
// Create default tenant
|
|
368
|
+
const tenant = serv.createTenant({
|
|
369
|
+
name: 'Local Dev',
|
|
370
|
+
slug: 'local',
|
|
371
|
+
});
|
|
372
|
+
// Create default user
|
|
373
|
+
const user = serv.createUser({
|
|
374
|
+
email: 'dev@localhost',
|
|
375
|
+
verified: true,
|
|
376
|
+
});
|
|
377
|
+
// Add user to tenant
|
|
378
|
+
const membership = serv.addMembership({
|
|
379
|
+
tenant,
|
|
380
|
+
user,
|
|
381
|
+
role: 'owner',
|
|
382
|
+
});
|
|
383
|
+
return { serv, tenant, user, membership };
|
|
384
|
+
}
|
|
385
|
+
/**
|
|
386
|
+
* Quick session token for testing
|
|
387
|
+
*/
|
|
388
|
+
export async function getTestToken(serv, tenant, user) {
|
|
389
|
+
const { token } = await serv.createSession(tenant, user);
|
|
390
|
+
return token;
|
|
391
|
+
}
|
|
392
|
+
//# sourceMappingURL=local.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"local.js","sourceRoot":"","sources":["../../src/serv/local.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Authentication Middleware
|
|
3
|
+
*
|
|
4
|
+
* Validates Bearer tokens and attaches session to request context
|
|
5
|
+
*/
|
|
6
|
+
import type { User, Membership, RequestContext, Tenant } from '../types/index.js';
|
|
7
|
+
import type { SessionStore } from '../session/store.js';
|
|
8
|
+
import type { JwtService } from '../auth/jwt.js';
|
|
9
|
+
export interface UserStore {
|
|
10
|
+
findById(id: string): Promise<User | null>;
|
|
11
|
+
findByEmail(email: string): Promise<User | null>;
|
|
12
|
+
}
|
|
13
|
+
export interface MembershipStore {
|
|
14
|
+
find(tenantId: string, userId: string): Promise<Membership | null>;
|
|
15
|
+
}
|
|
16
|
+
export interface AuthMiddlewareConfig {
|
|
17
|
+
jwtService: JwtService;
|
|
18
|
+
sessionStore: SessionStore;
|
|
19
|
+
userStore?: UserStore;
|
|
20
|
+
membershipStore?: MembershipStore;
|
|
21
|
+
/** Whether to allow anonymous access (no token) */
|
|
22
|
+
allowAnonymous?: boolean;
|
|
23
|
+
/** Required role(s) for access */
|
|
24
|
+
requiredRoles?: string[];
|
|
25
|
+
}
|
|
26
|
+
export interface AuthResult {
|
|
27
|
+
success: boolean;
|
|
28
|
+
context?: RequestContext;
|
|
29
|
+
error?: {
|
|
30
|
+
code: number;
|
|
31
|
+
message: string;
|
|
32
|
+
wwwAuthenticate?: string;
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
export declare class AuthMiddleware {
|
|
36
|
+
private config;
|
|
37
|
+
constructor(config: AuthMiddlewareConfig);
|
|
38
|
+
/**
|
|
39
|
+
* Authenticate a request
|
|
40
|
+
*/
|
|
41
|
+
authenticate(tenant: Tenant, authHeader?: string): Promise<AuthResult>;
|
|
42
|
+
/**
|
|
43
|
+
* Extract Bearer token from Authorization header
|
|
44
|
+
*/
|
|
45
|
+
private extractBearerToken;
|
|
46
|
+
/**
|
|
47
|
+
* Build WWW-Authenticate header value
|
|
48
|
+
*/
|
|
49
|
+
private buildWwwAuthenticate;
|
|
50
|
+
}
|
|
51
|
+
/**
|
|
52
|
+
* Check if a role has required permission
|
|
53
|
+
*/
|
|
54
|
+
export declare function hasPermission(role: string, requiredRoles: string[]): boolean;
|
|
55
|
+
/**
|
|
56
|
+
* Parse Mcp-Session-Id header
|
|
57
|
+
*/
|
|
58
|
+
export declare function parseMcpSessionId(header?: string): string | null;
|
|
59
|
+
/**
|
|
60
|
+
* Generate client fingerprint from request
|
|
61
|
+
*/
|
|
62
|
+
export declare function generateClientFingerprint(request: {
|
|
63
|
+
headers?: Record<string, string>;
|
|
64
|
+
ip?: string;
|
|
65
|
+
}): string;
|
|
66
|
+
//# sourceMappingURL=auth.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth.d.ts","sourceRoot":"","sources":["../../../src/serv/middleware/auth.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAGV,IAAI,EACJ,UAAU,EACV,cAAc,EACd,MAAM,EACP,MAAM,mBAAmB,CAAC;AAC3B,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACxD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAMjD,MAAM,WAAW,SAAS;IACxB,QAAQ,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,GAAG,IAAI,CAAC,CAAC;IAC3C,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,GAAG,IAAI,CAAC,CAAC;CAClD;AAED,MAAM,WAAW,eAAe;IAC9B,IAAI,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,GAAG,IAAI,CAAC,CAAC;CACpE;AAMD,MAAM,WAAW,oBAAoB;IACnC,UAAU,EAAE,UAAU,CAAC;IACvB,YAAY,EAAE,YAAY,CAAC;IAC3B,SAAS,CAAC,EAAE,SAAS,CAAC;IACtB,eAAe,CAAC,EAAE,eAAe,CAAC;IAClC,mDAAmD;IACnD,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,kCAAkC;IAClC,aAAa,CAAC,EAAE,MAAM,EAAE,CAAC;CAC1B;AAMD,MAAM,WAAW,UAAU;IACzB,OAAO,EAAE,OAAO,CAAC;IACjB,OAAO,CAAC,EAAE,cAAc,CAAC;IACzB,KAAK,CAAC,EAAE;QACN,IAAI,EAAE,MAAM,CAAC;QACb,OAAO,EAAE,MAAM,CAAC;QAChB,eAAe,CAAC,EAAE,MAAM,CAAC;KAC1B,CAAC;CACH;AAMD,qBAAa,cAAc;IACzB,OAAO,CAAC,MAAM,CAAuB;gBAEzB,MAAM,EAAE,oBAAoB;IAIxC;;OAEG;IACG,YAAY,CAAC,MAAM,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,CAAC;IAwG5E;;OAEG;IACH,OAAO,CAAC,kBAAkB;IAO1B;;OAEG;IACH,OAAO,CAAC,oBAAoB;CAa7B;AAMD;;GAEG;AACH,wBAAgB,aAAa,CAAC,IAAI,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,EAAE,GAAG,OAAO,CAa5E;AAED;;GAEG;AACH,wBAAgB,iBAAiB,CAAC,MAAM,CAAC,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI,CAGhE;AAED;;GAEG;AACH,wBAAgB,yBAAyB,CAAC,OAAO,EAAE;IACjD,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACjC,EAAE,CAAC,EAAE,MAAM,CAAC;CACb,GAAG,MAAM,CAiBT"}
|
|
@@ -0,0 +1,178 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Authentication Middleware
|
|
3
|
+
*
|
|
4
|
+
* Validates Bearer tokens and attaches session to request context
|
|
5
|
+
*/
|
|
6
|
+
// ============================================================================
|
|
7
|
+
// Auth Middleware
|
|
8
|
+
// ============================================================================
|
|
9
|
+
export class AuthMiddleware {
|
|
10
|
+
config;
|
|
11
|
+
constructor(config) {
|
|
12
|
+
this.config = config;
|
|
13
|
+
}
|
|
14
|
+
/**
|
|
15
|
+
* Authenticate a request
|
|
16
|
+
*/
|
|
17
|
+
async authenticate(tenant, authHeader) {
|
|
18
|
+
// Extract token from Authorization header
|
|
19
|
+
const token = this.extractBearerToken(authHeader);
|
|
20
|
+
// No token - check if anonymous is allowed
|
|
21
|
+
if (!token) {
|
|
22
|
+
if (this.config.allowAnonymous) {
|
|
23
|
+
return {
|
|
24
|
+
success: true,
|
|
25
|
+
context: { tenant },
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
return {
|
|
29
|
+
success: false,
|
|
30
|
+
error: {
|
|
31
|
+
code: 401,
|
|
32
|
+
message: 'Authorization required',
|
|
33
|
+
wwwAuthenticate: this.buildWwwAuthenticate(tenant),
|
|
34
|
+
},
|
|
35
|
+
};
|
|
36
|
+
}
|
|
37
|
+
// Verify JWT
|
|
38
|
+
const payload = this.config.jwtService.verifySessionToken(token);
|
|
39
|
+
if (!payload) {
|
|
40
|
+
return {
|
|
41
|
+
success: false,
|
|
42
|
+
error: {
|
|
43
|
+
code: 401,
|
|
44
|
+
message: 'Invalid or expired token',
|
|
45
|
+
wwwAuthenticate: this.buildWwwAuthenticate(tenant, 'invalid_token'),
|
|
46
|
+
},
|
|
47
|
+
};
|
|
48
|
+
}
|
|
49
|
+
// Verify tenant matches
|
|
50
|
+
if (payload.tenant_id !== tenant.id) {
|
|
51
|
+
return {
|
|
52
|
+
success: false,
|
|
53
|
+
error: {
|
|
54
|
+
code: 403,
|
|
55
|
+
message: 'Token not valid for this tenant',
|
|
56
|
+
},
|
|
57
|
+
};
|
|
58
|
+
}
|
|
59
|
+
// Get session from store
|
|
60
|
+
const session = await this.config.sessionStore.get(payload.mcp_session_id);
|
|
61
|
+
if (!session) {
|
|
62
|
+
return {
|
|
63
|
+
success: false,
|
|
64
|
+
error: {
|
|
65
|
+
code: 401,
|
|
66
|
+
message: 'Session expired or invalid',
|
|
67
|
+
wwwAuthenticate: this.buildWwwAuthenticate(tenant, 'invalid_token'),
|
|
68
|
+
},
|
|
69
|
+
};
|
|
70
|
+
}
|
|
71
|
+
// Touch session for sliding expiration
|
|
72
|
+
await this.config.sessionStore.touch(session.id);
|
|
73
|
+
// Build context
|
|
74
|
+
const context = {
|
|
75
|
+
tenant,
|
|
76
|
+
session,
|
|
77
|
+
};
|
|
78
|
+
// Load user if available
|
|
79
|
+
if (payload.user_id && this.config.userStore) {
|
|
80
|
+
const user = await this.config.userStore.findById(payload.user_id);
|
|
81
|
+
if (user) {
|
|
82
|
+
context.user = user;
|
|
83
|
+
// Load membership
|
|
84
|
+
if (this.config.membershipStore) {
|
|
85
|
+
const membership = await this.config.membershipStore.find(tenant.id, user.id);
|
|
86
|
+
if (membership) {
|
|
87
|
+
context.membership = membership;
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
// Check required roles
|
|
93
|
+
if (this.config.requiredRoles && this.config.requiredRoles.length > 0) {
|
|
94
|
+
if (!context.membership || !this.config.requiredRoles.includes(context.membership.role)) {
|
|
95
|
+
return {
|
|
96
|
+
success: false,
|
|
97
|
+
error: {
|
|
98
|
+
code: 403,
|
|
99
|
+
message: 'Insufficient permissions',
|
|
100
|
+
},
|
|
101
|
+
};
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
return {
|
|
105
|
+
success: true,
|
|
106
|
+
context,
|
|
107
|
+
};
|
|
108
|
+
}
|
|
109
|
+
/**
|
|
110
|
+
* Extract Bearer token from Authorization header
|
|
111
|
+
*/
|
|
112
|
+
extractBearerToken(header) {
|
|
113
|
+
if (!header)
|
|
114
|
+
return null;
|
|
115
|
+
const match = header.match(/^Bearer\s+(.+)$/i);
|
|
116
|
+
return match ? match[1] : null;
|
|
117
|
+
}
|
|
118
|
+
/**
|
|
119
|
+
* Build WWW-Authenticate header value
|
|
120
|
+
*/
|
|
121
|
+
buildWwwAuthenticate(tenant, error) {
|
|
122
|
+
const parts = [
|
|
123
|
+
'Bearer',
|
|
124
|
+
`realm="${tenant.slug}"`,
|
|
125
|
+
'resource_metadata="/.well-known/oauth-protected-resource"',
|
|
126
|
+
];
|
|
127
|
+
if (error) {
|
|
128
|
+
parts.push(`error="${error}"`);
|
|
129
|
+
}
|
|
130
|
+
return parts.join(', ');
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
// ============================================================================
|
|
134
|
+
// Helper Functions
|
|
135
|
+
// ============================================================================
|
|
136
|
+
/**
|
|
137
|
+
* Check if a role has required permission
|
|
138
|
+
*/
|
|
139
|
+
export function hasPermission(role, requiredRoles) {
|
|
140
|
+
// Role hierarchy: owner > admin > member > viewer
|
|
141
|
+
const hierarchy = {
|
|
142
|
+
owner: 4,
|
|
143
|
+
admin: 3,
|
|
144
|
+
member: 2,
|
|
145
|
+
viewer: 1,
|
|
146
|
+
};
|
|
147
|
+
const userLevel = hierarchy[role] ?? 0;
|
|
148
|
+
const minRequired = Math.min(...requiredRoles.map((r) => hierarchy[r] ?? 999));
|
|
149
|
+
return userLevel >= minRequired;
|
|
150
|
+
}
|
|
151
|
+
/**
|
|
152
|
+
* Parse Mcp-Session-Id header
|
|
153
|
+
*/
|
|
154
|
+
export function parseMcpSessionId(header) {
|
|
155
|
+
if (!header)
|
|
156
|
+
return null;
|
|
157
|
+
return header.trim() || null;
|
|
158
|
+
}
|
|
159
|
+
/**
|
|
160
|
+
* Generate client fingerprint from request
|
|
161
|
+
*/
|
|
162
|
+
export function generateClientFingerprint(request) {
|
|
163
|
+
const parts = [
|
|
164
|
+
request.headers?.['user-agent'] ?? '',
|
|
165
|
+
request.headers?.['accept-language'] ?? '',
|
|
166
|
+
request.ip ?? '',
|
|
167
|
+
];
|
|
168
|
+
// Simple hash of concatenated parts
|
|
169
|
+
let hash = 0;
|
|
170
|
+
const str = parts.join('|');
|
|
171
|
+
for (let i = 0; i < str.length; i++) {
|
|
172
|
+
const char = str.charCodeAt(i);
|
|
173
|
+
hash = (hash << 5) - hash + char;
|
|
174
|
+
hash = hash & hash;
|
|
175
|
+
}
|
|
176
|
+
return Math.abs(hash).toString(36);
|
|
177
|
+
}
|
|
178
|
+
//# sourceMappingURL=auth.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth.js","sourceRoot":"","sources":["../../../src/serv/middleware/auth.ts"],"names":[],"mappings":"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"}
|