@ytinnovation/harness-core 0.0.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 +17 -0
- package/dist/assets/fetch-published-by-name.d.ts +16 -0
- package/dist/assets/fetch-published-by-name.d.ts.map +1 -0
- package/dist/assets/fetch-published-by-name.js +40 -0
- package/dist/assets/fetch-published-by-name.js.map +1 -0
- package/dist/assets/install-content.d.ts +7 -0
- package/dist/assets/install-content.d.ts.map +1 -0
- package/dist/assets/install-content.js +24 -0
- package/dist/assets/install-content.js.map +1 -0
- package/dist/assets/install-from.d.ts +6 -0
- package/dist/assets/install-from.d.ts.map +1 -0
- package/dist/assets/install-from.js +13 -0
- package/dist/assets/install-from.js.map +1 -0
- package/dist/assets/install.d.ts +36 -0
- package/dist/assets/install.d.ts.map +1 -0
- package/dist/assets/install.js +199 -0
- package/dist/assets/install.js.map +1 -0
- package/dist/assets/mcp-config-format.d.ts +11 -0
- package/dist/assets/mcp-config-format.d.ts.map +1 -0
- package/dist/assets/mcp-config-format.js +101 -0
- package/dist/assets/mcp-config-format.js.map +1 -0
- package/dist/assets/metadata.d.ts +65 -0
- package/dist/assets/metadata.d.ts.map +1 -0
- package/dist/assets/metadata.js +164 -0
- package/dist/assets/metadata.js.map +1 -0
- package/dist/assets/project-manifest.d.ts +80 -0
- package/dist/assets/project-manifest.d.ts.map +1 -0
- package/dist/assets/project-manifest.js +556 -0
- package/dist/assets/project-manifest.js.map +1 -0
- package/dist/assets/published-content.d.ts +28 -0
- package/dist/assets/published-content.d.ts.map +1 -0
- package/dist/assets/published-content.js +137 -0
- package/dist/assets/published-content.js.map +1 -0
- package/dist/assets/registry-entry.d.ts +9 -0
- package/dist/assets/registry-entry.d.ts.map +1 -0
- package/dist/assets/registry-entry.js +72 -0
- package/dist/assets/registry-entry.js.map +1 -0
- package/dist/assets/remote-list.d.ts +15 -0
- package/dist/assets/remote-list.d.ts.map +1 -0
- package/dist/assets/remote-list.js +36 -0
- package/dist/assets/remote-list.js.map +1 -0
- package/dist/cli-output/clipboard.d.ts +9 -0
- package/dist/cli-output/clipboard.d.ts.map +1 -0
- package/dist/cli-output/clipboard.js +56 -0
- package/dist/cli-output/clipboard.js.map +1 -0
- package/dist/cli-output/renderers.d.ts +99 -0
- package/dist/cli-output/renderers.d.ts.map +1 -0
- package/dist/cli-output/renderers.js +267 -0
- package/dist/cli-output/renderers.js.map +1 -0
- package/dist/cloud/enterprise-asset-client.d.ts +32 -0
- package/dist/cloud/enterprise-asset-client.d.ts.map +1 -0
- package/dist/cloud/enterprise-asset-client.js +179 -0
- package/dist/cloud/enterprise-asset-client.js.map +1 -0
- package/dist/cloud/enterprise-asset-types.d.ts +74 -0
- package/dist/cloud/enterprise-asset-types.d.ts.map +1 -0
- package/dist/cloud/enterprise-asset-types.js +2 -0
- package/dist/cloud/enterprise-asset-types.js.map +1 -0
- package/dist/cloud/harness-service-url.d.ts +3 -0
- package/dist/cloud/harness-service-url.d.ts.map +1 -0
- package/dist/cloud/harness-service-url.js +13 -0
- package/dist/cloud/harness-service-url.js.map +1 -0
- package/dist/cloud/rag-client.d.ts +18 -0
- package/dist/cloud/rag-client.d.ts.map +1 -0
- package/dist/cloud/rag-client.js +57 -0
- package/dist/cloud/rag-client.js.map +1 -0
- package/dist/cloud/redaction.d.ts +2 -0
- package/dist/cloud/redaction.d.ts.map +1 -0
- package/dist/cloud/redaction.js +53 -0
- package/dist/cloud/redaction.js.map +1 -0
- package/dist/cloud/telemetry-client.d.ts +21 -0
- package/dist/cloud/telemetry-client.d.ts.map +1 -0
- package/dist/cloud/telemetry-client.js +39 -0
- package/dist/cloud/telemetry-client.js.map +1 -0
- package/dist/contracts/config.d.ts +9 -0
- package/dist/contracts/config.d.ts.map +1 -0
- package/dist/contracts/config.defaults.d.ts +5 -0
- package/dist/contracts/config.defaults.d.ts.map +1 -0
- package/dist/contracts/config.defaults.js +5 -0
- package/dist/contracts/config.defaults.js.map +1 -0
- package/dist/contracts/config.js +5 -0
- package/dist/contracts/config.js.map +1 -0
- package/dist/contracts/config.loader.d.ts +3 -0
- package/dist/contracts/config.loader.d.ts.map +1 -0
- package/dist/contracts/config.loader.js +38 -0
- package/dist/contracts/config.loader.js.map +1 -0
- package/dist/contracts/errors.d.ts +8 -0
- package/dist/contracts/errors.d.ts.map +1 -0
- package/dist/contracts/errors.js +10 -0
- package/dist/contracts/errors.js.map +1 -0
- package/dist/cursor-acp-demo/index.d.ts +2 -0
- package/dist/cursor-acp-demo/index.d.ts.map +1 -0
- package/dist/cursor-acp-demo/index.js +63 -0
- package/dist/cursor-acp-demo/index.js.map +1 -0
- package/dist/dashboard/command.d.ts +15 -0
- package/dist/dashboard/command.d.ts.map +1 -0
- package/dist/dashboard/command.js +283 -0
- package/dist/dashboard/command.js.map +1 -0
- package/dist/dashboard/http-api.d.ts +3 -0
- package/dist/dashboard/http-api.d.ts.map +1 -0
- package/dist/dashboard/http-api.js +376 -0
- package/dist/dashboard/http-api.js.map +1 -0
- package/dist/dashboard/telemetry-snapshot.d.ts +11 -0
- package/dist/dashboard/telemetry-snapshot.d.ts.map +1 -0
- package/dist/dashboard/telemetry-snapshot.js +27 -0
- package/dist/dashboard/telemetry-snapshot.js.map +1 -0
- package/dist/dashboard-assets/assets/index-BNx5sFKx.css +1 -0
- package/dist/dashboard-assets/assets/index-ruRt5sDA.js +40 -0
- package/dist/dashboard-assets/index.html +13 -0
- package/dist/gateway/auth.d.ts +44 -0
- package/dist/gateway/auth.d.ts.map +1 -0
- package/dist/gateway/auth.js +2 -0
- package/dist/gateway/auth.js.map +1 -0
- package/dist/gateway/client.d.ts +65 -0
- package/dist/gateway/client.d.ts.map +1 -0
- package/dist/gateway/client.js +133 -0
- package/dist/gateway/client.js.map +1 -0
- package/dist/gateway/command.d.ts +4 -0
- package/dist/gateway/command.d.ts.map +1 -0
- package/dist/gateway/command.js +213 -0
- package/dist/gateway/command.js.map +1 -0
- package/dist/gateway/service-http-exchange.d.ts +17 -0
- package/dist/gateway/service-http-exchange.d.ts.map +1 -0
- package/dist/gateway/service-http-exchange.js +183 -0
- package/dist/gateway/service-http-exchange.js.map +1 -0
- package/dist/gateway/token-exchange.d.ts +10 -0
- package/dist/gateway/token-exchange.d.ts.map +1 -0
- package/dist/gateway/token-exchange.js +8 -0
- package/dist/gateway/token-exchange.js.map +1 -0
- package/dist/index.d.ts +111 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +62 -0
- package/dist/index.js.map +1 -0
- package/dist/init/cloud-asset-client.d.ts +74 -0
- package/dist/init/cloud-asset-client.d.ts.map +1 -0
- package/dist/init/cloud-asset-client.js +399 -0
- package/dist/init/cloud-asset-client.js.map +1 -0
- package/dist/init/cloud-auto.d.ts +16 -0
- package/dist/init/cloud-auto.d.ts.map +1 -0
- package/dist/init/cloud-auto.js +61 -0
- package/dist/init/cloud-auto.js.map +1 -0
- package/dist/init/command.d.ts +17 -0
- package/dist/init/command.d.ts.map +1 -0
- package/dist/init/command.js +783 -0
- package/dist/init/command.js.map +1 -0
- package/dist/init/cursor-adapter.d.ts +24 -0
- package/dist/init/cursor-adapter.d.ts.map +1 -0
- package/dist/init/cursor-adapter.js +71 -0
- package/dist/init/cursor-adapter.js.map +1 -0
- package/dist/init/fingerprint.d.ts +6 -0
- package/dist/init/fingerprint.d.ts.map +1 -0
- package/dist/init/fingerprint.js +157 -0
- package/dist/init/fingerprint.js.map +1 -0
- package/dist/init/git-identity-catalog.d.ts +17 -0
- package/dist/init/git-identity-catalog.d.ts.map +1 -0
- package/dist/init/git-identity-catalog.js +48 -0
- package/dist/init/git-identity-catalog.js.map +1 -0
- package/dist/init/local-fallback-config-packs.d.ts +5 -0
- package/dist/init/local-fallback-config-packs.d.ts.map +1 -0
- package/dist/init/local-fallback-config-packs.js +6 -0
- package/dist/init/local-fallback-config-packs.js.map +1 -0
- package/dist/init/manifest-records.d.ts +34 -0
- package/dist/init/manifest-records.d.ts.map +1 -0
- package/dist/init/manifest-records.js +296 -0
- package/dist/init/manifest-records.js.map +1 -0
- package/dist/init/matched-init.d.ts +64 -0
- package/dist/init/matched-init.d.ts.map +1 -0
- package/dist/init/matched-init.js +263 -0
- package/dist/init/matched-init.js.map +1 -0
- package/dist/init/plan.d.ts +8 -0
- package/dist/init/plan.d.ts.map +1 -0
- package/dist/init/plan.js +165 -0
- package/dist/init/plan.js.map +1 -0
- package/dist/init/project-fingerprint-catalog.d.ts +17 -0
- package/dist/init/project-fingerprint-catalog.d.ts.map +1 -0
- package/dist/init/project-fingerprint-catalog.js +105 -0
- package/dist/init/project-fingerprint-catalog.js.map +1 -0
- package/dist/init/prompt.d.ts +38 -0
- package/dist/init/prompt.d.ts.map +1 -0
- package/dist/init/prompt.js +217 -0
- package/dist/init/prompt.js.map +1 -0
- package/dist/init/questions.d.ts +5 -0
- package/dist/init/questions.d.ts.map +1 -0
- package/dist/init/questions.js +71 -0
- package/dist/init/questions.js.map +1 -0
- package/dist/init/template-match.d.ts +10 -0
- package/dist/init/template-match.d.ts.map +1 -0
- package/dist/init/template-match.js +125 -0
- package/dist/init/template-match.js.map +1 -0
- package/dist/init/types.d.ts +162 -0
- package/dist/init/types.d.ts.map +1 -0
- package/dist/init/types.js +2 -0
- package/dist/init/types.js.map +1 -0
- package/dist/init/write.d.ts +7 -0
- package/dist/init/write.d.ts.map +1 -0
- package/dist/init/write.js +155 -0
- package/dist/init/write.js.map +1 -0
- package/dist/install/command.d.ts +25 -0
- package/dist/install/command.d.ts.map +1 -0
- package/dist/install/command.js +251 -0
- package/dist/install/command.js.map +1 -0
- package/dist/install/prompt.d.ts +21 -0
- package/dist/install/prompt.d.ts.map +1 -0
- package/dist/install/prompt.js +60 -0
- package/dist/install/prompt.js.map +1 -0
- package/dist/kernel/commands/init.d.ts +11 -0
- package/dist/kernel/commands/init.d.ts.map +1 -0
- package/dist/kernel/commands/init.js +144 -0
- package/dist/kernel/commands/init.js.map +1 -0
- package/dist/kernel/create.d.ts +3 -0
- package/dist/kernel/create.d.ts.map +1 -0
- package/dist/kernel/create.js +31 -0
- package/dist/kernel/create.js.map +1 -0
- package/dist/kernel/router.d.ts +14 -0
- package/dist/kernel/router.d.ts.map +1 -0
- package/dist/kernel/router.js +73 -0
- package/dist/kernel/router.js.map +1 -0
- package/dist/kernel/types.d.ts +6 -0
- package/dist/kernel/types.d.ts.map +1 -0
- package/dist/kernel/types.js +2 -0
- package/dist/kernel/types.js.map +1 -0
- package/dist/knowledge/command.d.ts +6 -0
- package/dist/knowledge/command.d.ts.map +1 -0
- package/dist/knowledge/command.js +151 -0
- package/dist/knowledge/command.js.map +1 -0
- package/dist/knowledge/query.d.ts +23 -0
- package/dist/knowledge/query.d.ts.map +1 -0
- package/dist/knowledge/query.js +133 -0
- package/dist/knowledge/query.js.map +1 -0
- package/dist/knowledge/rag.d.ts +74 -0
- package/dist/knowledge/rag.d.ts.map +1 -0
- package/dist/knowledge/rag.js +55 -0
- package/dist/knowledge/rag.js.map +1 -0
- package/dist/knowledge/types.d.ts +40 -0
- package/dist/knowledge/types.d.ts.map +1 -0
- package/dist/knowledge/types.js +13 -0
- package/dist/knowledge/types.js.map +1 -0
- package/dist/mcp/command.d.ts +19 -0
- package/dist/mcp/command.d.ts.map +1 -0
- package/dist/mcp/command.js +359 -0
- package/dist/mcp/command.js.map +1 -0
- package/dist/mcp/server.d.ts +14 -0
- package/dist/mcp/server.d.ts.map +1 -0
- package/dist/mcp/server.js +44 -0
- package/dist/mcp/server.js.map +1 -0
- package/dist/mcp/tool-registry.d.ts +38 -0
- package/dist/mcp/tool-registry.d.ts.map +1 -0
- package/dist/mcp/tool-registry.js +50 -0
- package/dist/mcp/tool-registry.js.map +1 -0
- package/dist/mcp/tools/add-skill.d.ts +29 -0
- package/dist/mcp/tools/add-skill.d.ts.map +1 -0
- package/dist/mcp/tools/add-skill.js +184 -0
- package/dist/mcp/tools/add-skill.js.map +1 -0
- package/dist/mcp/tools/assemble-init-assets.d.ts +26 -0
- package/dist/mcp/tools/assemble-init-assets.d.ts.map +1 -0
- package/dist/mcp/tools/assemble-init-assets.js +136 -0
- package/dist/mcp/tools/assemble-init-assets.js.map +1 -0
- package/dist/mcp/tools/query-knowledge.d.ts +28 -0
- package/dist/mcp/tools/query-knowledge.d.ts.map +1 -0
- package/dist/mcp/tools/query-knowledge.js +92 -0
- package/dist/mcp/tools/query-knowledge.js.map +1 -0
- package/dist/mcp/tools/read-instructions.d.ts +14 -0
- package/dist/mcp/tools/read-instructions.d.ts.map +1 -0
- package/dist/mcp/tools/read-instructions.js +81 -0
- package/dist/mcp/tools/read-instructions.js.map +1 -0
- package/dist/mcp/tools/sync-spec.d.ts +17 -0
- package/dist/mcp/tools/sync-spec.d.ts.map +1 -0
- package/dist/mcp/tools/sync-spec.js +80 -0
- package/dist/mcp/tools/sync-spec.js.map +1 -0
- package/dist/mcp/tools/update-rule.d.ts +49 -0
- package/dist/mcp/tools/update-rule.d.ts.map +1 -0
- package/dist/mcp/tools/update-rule.js +188 -0
- package/dist/mcp/tools/update-rule.js.map +1 -0
- package/dist/mcp/types.d.ts +21 -0
- package/dist/mcp/types.d.ts.map +1 -0
- package/dist/mcp/types.js +8 -0
- package/dist/mcp/types.js.map +1 -0
- package/dist/prompt/command.d.ts +10 -0
- package/dist/prompt/command.d.ts.map +1 -0
- package/dist/prompt/command.js +260 -0
- package/dist/prompt/command.js.map +1 -0
- package/dist/rule/command.d.ts +10 -0
- package/dist/rule/command.d.ts.map +1 -0
- package/dist/rule/command.js +120 -0
- package/dist/rule/command.js.map +1 -0
- package/dist/skills/command.d.ts +23 -0
- package/dist/skills/command.d.ts.map +1 -0
- package/dist/skills/command.js +713 -0
- package/dist/skills/command.js.map +1 -0
- package/dist/skills/default-internal-skill-provider.d.ts +4 -0
- package/dist/skills/default-internal-skill-provider.d.ts.map +1 -0
- package/dist/skills/default-internal-skill-provider.js +23 -0
- package/dist/skills/default-internal-skill-provider.js.map +1 -0
- package/dist/skills/gitlab-skill-publish-client.d.ts +13 -0
- package/dist/skills/gitlab-skill-publish-client.d.ts.map +1 -0
- package/dist/skills/gitlab-skill-publish-client.js +255 -0
- package/dist/skills/gitlab-skill-publish-client.js.map +1 -0
- package/dist/skills/install.d.ts +23 -0
- package/dist/skills/install.d.ts.map +1 -0
- package/dist/skills/install.js +143 -0
- package/dist/skills/install.js.map +1 -0
- package/dist/skills/list-scan.d.ts +29 -0
- package/dist/skills/list-scan.d.ts.map +1 -0
- package/dist/skills/list-scan.js +230 -0
- package/dist/skills/list-scan.js.map +1 -0
- package/dist/skills/metadata.d.ts +5 -0
- package/dist/skills/metadata.d.ts.map +1 -0
- package/dist/skills/metadata.js +44 -0
- package/dist/skills/metadata.js.map +1 -0
- package/dist/skills/providers/harness-service.d.ts +11 -0
- package/dist/skills/providers/harness-service.d.ts.map +1 -0
- package/dist/skills/providers/harness-service.js +111 -0
- package/dist/skills/providers/harness-service.js.map +1 -0
- package/dist/skills/providers/stub.d.ts +4 -0
- package/dist/skills/providers/stub.d.ts.map +1 -0
- package/dist/skills/providers/stub.js +18 -0
- package/dist/skills/providers/stub.js.map +1 -0
- package/dist/skills/publish.d.ts +35 -0
- package/dist/skills/publish.d.ts.map +1 -0
- package/dist/skills/publish.js +115 -0
- package/dist/skills/publish.js.map +1 -0
- package/dist/skills/registry.d.ts +24 -0
- package/dist/skills/registry.d.ts.map +1 -0
- package/dist/skills/registry.js +124 -0
- package/dist/skills/registry.js.map +1 -0
- package/dist/skills/remove.d.ts +14 -0
- package/dist/skills/remove.d.ts.map +1 -0
- package/dist/skills/remove.js +44 -0
- package/dist/skills/remove.js.map +1 -0
- package/dist/skills/search.d.ts +9 -0
- package/dist/skills/search.d.ts.map +1 -0
- package/dist/skills/search.js +65 -0
- package/dist/skills/search.js.map +1 -0
- package/dist/skills/skill-markdown-manifest.d.ts +6 -0
- package/dist/skills/skill-markdown-manifest.d.ts.map +1 -0
- package/dist/skills/skill-markdown-manifest.js +57 -0
- package/dist/skills/skill-markdown-manifest.js.map +1 -0
- package/dist/skills/types.d.ts +138 -0
- package/dist/skills/types.d.ts.map +1 -0
- package/dist/skills/types.js +2 -0
- package/dist/skills/types.js.map +1 -0
- package/dist/skills/update.d.ts +11 -0
- package/dist/skills/update.d.ts.map +1 -0
- package/dist/skills/update.js +55 -0
- package/dist/skills/update.js.map +1 -0
- package/dist/spec/command.d.ts +11 -0
- package/dist/spec/command.d.ts.map +1 -0
- package/dist/spec/command.js +201 -0
- package/dist/spec/command.js.map +1 -0
- package/dist/telemetry/reporter.d.ts +14 -0
- package/dist/telemetry/reporter.d.ts.map +1 -0
- package/dist/telemetry/reporter.js +31 -0
- package/dist/telemetry/reporter.js.map +1 -0
- package/dist/telemetry/sink.d.ts +7 -0
- package/dist/telemetry/sink.d.ts.map +1 -0
- package/dist/telemetry/sink.js +309 -0
- package/dist/telemetry/sink.js.map +1 -0
- package/dist/telemetry/types.d.ts +48 -0
- package/dist/telemetry/types.d.ts.map +1 -0
- package/dist/telemetry/types.js +2 -0
- package/dist/telemetry/types.js.map +1 -0
- package/dist/update/apply.d.ts +11 -0
- package/dist/update/apply.d.ts.map +1 -0
- package/dist/update/apply.js +94 -0
- package/dist/update/apply.js.map +1 -0
- package/dist/update/command.d.ts +43 -0
- package/dist/update/command.d.ts.map +1 -0
- package/dist/update/command.js +524 -0
- package/dist/update/command.js.map +1 -0
- package/dist/update/config-pack-sync.d.ts +11 -0
- package/dist/update/config-pack-sync.d.ts.map +1 -0
- package/dist/update/config-pack-sync.js +88 -0
- package/dist/update/config-pack-sync.js.map +1 -0
- package/dist/update/enterprise-update-provider.d.ts +8 -0
- package/dist/update/enterprise-update-provider.d.ts.map +1 -0
- package/dist/update/enterprise-update-provider.js +76 -0
- package/dist/update/enterprise-update-provider.js.map +1 -0
- package/dist/update/manifest-source.d.ts +33 -0
- package/dist/update/manifest-source.d.ts.map +1 -0
- package/dist/update/manifest-source.js +111 -0
- package/dist/update/manifest-source.js.map +1 -0
- package/dist/update/plan-utils.d.ts +5 -0
- package/dist/update/plan-utils.d.ts.map +1 -0
- package/dist/update/plan-utils.js +13 -0
- package/dist/update/plan-utils.js.map +1 -0
- package/dist/update/prompt.d.ts +19 -0
- package/dist/update/prompt.d.ts.map +1 -0
- package/dist/update/prompt.js +72 -0
- package/dist/update/prompt.js.map +1 -0
- package/dist/update/resolve-action.d.ts +7 -0
- package/dist/update/resolve-action.d.ts.map +1 -0
- package/dist/update/resolve-action.js +14 -0
- package/dist/update/resolve-action.js.map +1 -0
- package/dist/update/types.d.ts +33 -0
- package/dist/update/types.d.ts.map +1 -0
- package/dist/update/types.js +2 -0
- package/dist/update/types.js.map +1 -0
- package/package.json +42 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth.js","sourceRoot":"","sources":["../../src/gateway/auth.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
import type { GatewayAuthError, GatewayRequestContext, GatewayTokenProvider } from './auth.js';
|
|
2
|
+
export interface GatewayRequestMetadata {
|
|
3
|
+
targetModel: string;
|
|
4
|
+
operation: string;
|
|
5
|
+
requestSizeBytes?: number;
|
|
6
|
+
}
|
|
7
|
+
export interface GatewayPreparedRequest {
|
|
8
|
+
context: GatewayRequestContext;
|
|
9
|
+
metadata: GatewayRequestMetadata;
|
|
10
|
+
accessToken: string;
|
|
11
|
+
authHeader: string;
|
|
12
|
+
}
|
|
13
|
+
export interface GatewayAuditSuccessSummary {
|
|
14
|
+
status: 'success';
|
|
15
|
+
tokenExpiresAt: string;
|
|
16
|
+
scopeCount: number;
|
|
17
|
+
}
|
|
18
|
+
export interface GatewayAuditAuthFailureSummary {
|
|
19
|
+
status: 'auth_failure';
|
|
20
|
+
failureType: GatewayAuthError['failureType'];
|
|
21
|
+
code: GatewayAuthError['code'];
|
|
22
|
+
message: string;
|
|
23
|
+
}
|
|
24
|
+
export type GatewayAuditResultSummary = GatewayAuditSuccessSummary | GatewayAuditAuthFailureSummary;
|
|
25
|
+
export interface GatewayAuditRecord {
|
|
26
|
+
requestId: string;
|
|
27
|
+
actorId: string;
|
|
28
|
+
userId: string;
|
|
29
|
+
projectId: string;
|
|
30
|
+
projectName: string;
|
|
31
|
+
workspaceRoot: string;
|
|
32
|
+
commandName?: string;
|
|
33
|
+
toolName?: string;
|
|
34
|
+
occurredAt: string;
|
|
35
|
+
requestTime: string;
|
|
36
|
+
targetModel: string;
|
|
37
|
+
resultStatus: GatewayAuditResultSummary['status'];
|
|
38
|
+
errorSummary?: string;
|
|
39
|
+
result: GatewayAuditResultSummary;
|
|
40
|
+
}
|
|
41
|
+
export interface GatewayAuditRecorder {
|
|
42
|
+
record(entry: GatewayAuditRecord): Promise<void> | void;
|
|
43
|
+
}
|
|
44
|
+
export interface GatewayPrepareRequestSuccess {
|
|
45
|
+
status: 'success';
|
|
46
|
+
request: GatewayPreparedRequest;
|
|
47
|
+
audit: GatewayAuditRecord;
|
|
48
|
+
}
|
|
49
|
+
export interface GatewayPrepareRequestFailure {
|
|
50
|
+
status: 'error';
|
|
51
|
+
error: GatewayAuthError;
|
|
52
|
+
audit: GatewayAuditRecord;
|
|
53
|
+
}
|
|
54
|
+
export type GatewayPrepareRequestResult = GatewayPrepareRequestSuccess | GatewayPrepareRequestFailure;
|
|
55
|
+
export interface GatewayClient {
|
|
56
|
+
prepareRequest(context: GatewayRequestContext, metadata: GatewayRequestMetadata): Promise<GatewayPrepareRequestResult>;
|
|
57
|
+
}
|
|
58
|
+
export interface CreateGatewayClientOptions {
|
|
59
|
+
tokenProvider: GatewayTokenProvider;
|
|
60
|
+
auditRecorder?: GatewayAuditRecorder;
|
|
61
|
+
onAuditSinkError?: (error: unknown, entry: GatewayAuditRecord) => void;
|
|
62
|
+
now?: () => Date;
|
|
63
|
+
}
|
|
64
|
+
export declare function createGatewayClient(options: CreateGatewayClientOptions): GatewayClient;
|
|
65
|
+
//# sourceMappingURL=client.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../../src/gateway/client.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,qBAAqB,EAAE,oBAAoB,EAAE,MAAM,WAAW,CAAC;AAG/F,MAAM,WAAW,sBAAsB;IACrC,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,EAAE,MAAM,CAAC;IAClB,gBAAgB,CAAC,EAAE,MAAM,CAAC;CAC3B;AAED,MAAM,WAAW,sBAAsB;IACrC,OAAO,EAAE,qBAAqB,CAAC;IAC/B,QAAQ,EAAE,sBAAsB,CAAC;IACjC,WAAW,EAAE,MAAM,CAAC;IACpB,UAAU,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,0BAA0B;IACzC,MAAM,EAAE,SAAS,CAAC;IAClB,cAAc,EAAE,MAAM,CAAC;IACvB,UAAU,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,8BAA8B;IAC7C,MAAM,EAAE,cAAc,CAAC;IACvB,WAAW,EAAE,gBAAgB,CAAC,aAAa,CAAC,CAAC;IAC7C,IAAI,EAAE,gBAAgB,CAAC,MAAM,CAAC,CAAC;IAC/B,OAAO,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,MAAM,yBAAyB,GACjC,0BAA0B,GAC1B,8BAA8B,CAAC;AAEnC,MAAM,WAAW,kBAAkB;IACjC,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,MAAM,CAAC;IAClB,WAAW,EAAE,MAAM,CAAC;IACpB,aAAa,EAAE,MAAM,CAAC;IACtB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,UAAU,EAAE,MAAM,CAAC;IACnB,WAAW,EAAE,MAAM,CAAC;IACpB,WAAW,EAAE,MAAM,CAAC;IACpB,YAAY,EAAE,yBAAyB,CAAC,QAAQ,CAAC,CAAC;IAClD,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,MAAM,EAAE,yBAAyB,CAAC;CACnC;AAED,MAAM,WAAW,oBAAoB;IACnC,MAAM,CAAC,KAAK,EAAE,kBAAkB,GAAG,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;CACzD;AAED,MAAM,WAAW,4BAA4B;IAC3C,MAAM,EAAE,SAAS,CAAC;IAClB,OAAO,EAAE,sBAAsB,CAAC;IAChC,KAAK,EAAE,kBAAkB,CAAC;CAC3B;AAED,MAAM,WAAW,4BAA4B;IAC3C,MAAM,EAAE,OAAO,CAAC;IAChB,KAAK,EAAE,gBAAgB,CAAC;IACxB,KAAK,EAAE,kBAAkB,CAAC;CAC3B;AAED,MAAM,MAAM,2BAA2B,GAAG,4BAA4B,GAAG,4BAA4B,CAAC;AAEtG,MAAM,WAAW,aAAa;IAC5B,cAAc,CACZ,OAAO,EAAE,qBAAqB,EAC9B,QAAQ,EAAE,sBAAsB,GAC/B,OAAO,CAAC,2BAA2B,CAAC,CAAC;CACzC;AAED,MAAM,WAAW,0BAA0B;IACzC,aAAa,EAAE,oBAAoB,CAAC;IACpC,aAAa,CAAC,EAAE,oBAAoB,CAAC;IACrC,gBAAgB,CAAC,EAAE,CAAC,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,kBAAkB,KAAK,IAAI,CAAC;IACvE,GAAG,CAAC,EAAE,MAAM,IAAI,CAAC;CAClB;AAoCD,wBAAgB,mBAAmB,CAAC,OAAO,EAAE,0BAA0B,GAAG,aAAa,CAiHtF"}
|
|
@@ -0,0 +1,133 @@
|
|
|
1
|
+
import { basename } from 'node:path';
|
|
2
|
+
function createExpiredCredentialFailure() {
|
|
3
|
+
return {
|
|
4
|
+
status: 'error',
|
|
5
|
+
failureType: 'refreshable',
|
|
6
|
+
code: 'GATEWAY_AUTH_EXPIRED',
|
|
7
|
+
message: 'Short-lived gateway credential is already expired.',
|
|
8
|
+
action: 'refresh-token',
|
|
9
|
+
guidance: 'Refresh your SSO token with `harness auth refresh` and retry.',
|
|
10
|
+
};
|
|
11
|
+
}
|
|
12
|
+
async function emitAudit(recorder, onAuditSinkError, entry) {
|
|
13
|
+
if (!recorder) {
|
|
14
|
+
return;
|
|
15
|
+
}
|
|
16
|
+
try {
|
|
17
|
+
await recorder.record(entry);
|
|
18
|
+
}
|
|
19
|
+
catch (error) {
|
|
20
|
+
onAuditSinkError?.(error, entry);
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
function deriveProjectIdentity(context) {
|
|
24
|
+
const fallbackName = basename(context.workspaceRoot) || context.workspaceRoot;
|
|
25
|
+
return {
|
|
26
|
+
projectId: context.projectId?.trim() || fallbackName,
|
|
27
|
+
projectName: context.projectName?.trim() || fallbackName,
|
|
28
|
+
};
|
|
29
|
+
}
|
|
30
|
+
export function createGatewayClient(options) {
|
|
31
|
+
const now = options.now ?? (() => new Date());
|
|
32
|
+
return {
|
|
33
|
+
async prepareRequest(context, metadata) {
|
|
34
|
+
const occurredAt = now().toISOString();
|
|
35
|
+
const tokenResult = await options.tokenProvider.resolveToken(context);
|
|
36
|
+
if (tokenResult.status === 'error') {
|
|
37
|
+
const project = deriveProjectIdentity(context);
|
|
38
|
+
const audit = {
|
|
39
|
+
requestId: context.requestId,
|
|
40
|
+
actorId: context.actorId,
|
|
41
|
+
userId: context.actorId,
|
|
42
|
+
projectId: project.projectId,
|
|
43
|
+
projectName: project.projectName,
|
|
44
|
+
workspaceRoot: context.workspaceRoot,
|
|
45
|
+
commandName: context.commandName,
|
|
46
|
+
toolName: context.toolName,
|
|
47
|
+
occurredAt,
|
|
48
|
+
requestTime: occurredAt,
|
|
49
|
+
targetModel: metadata.targetModel,
|
|
50
|
+
resultStatus: 'auth_failure',
|
|
51
|
+
errorSummary: `${tokenResult.code}: ${tokenResult.message}`,
|
|
52
|
+
result: {
|
|
53
|
+
status: 'auth_failure',
|
|
54
|
+
failureType: tokenResult.failureType,
|
|
55
|
+
code: tokenResult.code,
|
|
56
|
+
message: tokenResult.message,
|
|
57
|
+
},
|
|
58
|
+
};
|
|
59
|
+
await emitAudit(options.auditRecorder, options.onAuditSinkError, audit);
|
|
60
|
+
return {
|
|
61
|
+
status: 'error',
|
|
62
|
+
error: tokenResult,
|
|
63
|
+
audit,
|
|
64
|
+
};
|
|
65
|
+
}
|
|
66
|
+
const tokenExpiry = Date.parse(tokenResult.token.expiresAt);
|
|
67
|
+
if (!Number.isFinite(tokenExpiry) || tokenExpiry <= Date.parse(occurredAt)) {
|
|
68
|
+
const expiredError = createExpiredCredentialFailure();
|
|
69
|
+
const project = deriveProjectIdentity(context);
|
|
70
|
+
const audit = {
|
|
71
|
+
requestId: context.requestId,
|
|
72
|
+
actorId: context.actorId,
|
|
73
|
+
userId: context.actorId,
|
|
74
|
+
projectId: project.projectId,
|
|
75
|
+
projectName: project.projectName,
|
|
76
|
+
workspaceRoot: context.workspaceRoot,
|
|
77
|
+
commandName: context.commandName,
|
|
78
|
+
toolName: context.toolName,
|
|
79
|
+
occurredAt,
|
|
80
|
+
requestTime: occurredAt,
|
|
81
|
+
targetModel: metadata.targetModel,
|
|
82
|
+
resultStatus: 'auth_failure',
|
|
83
|
+
errorSummary: `${expiredError.code}: ${expiredError.message}`,
|
|
84
|
+
result: {
|
|
85
|
+
status: 'auth_failure',
|
|
86
|
+
failureType: expiredError.failureType,
|
|
87
|
+
code: expiredError.code,
|
|
88
|
+
message: expiredError.message,
|
|
89
|
+
},
|
|
90
|
+
};
|
|
91
|
+
await emitAudit(options.auditRecorder, options.onAuditSinkError, audit);
|
|
92
|
+
return {
|
|
93
|
+
status: 'error',
|
|
94
|
+
error: expiredError,
|
|
95
|
+
audit,
|
|
96
|
+
};
|
|
97
|
+
}
|
|
98
|
+
const request = {
|
|
99
|
+
context,
|
|
100
|
+
metadata,
|
|
101
|
+
accessToken: tokenResult.token.value,
|
|
102
|
+
authHeader: `Bearer ${tokenResult.token.value}`,
|
|
103
|
+
};
|
|
104
|
+
const project = deriveProjectIdentity(context);
|
|
105
|
+
const audit = {
|
|
106
|
+
requestId: context.requestId,
|
|
107
|
+
actorId: context.actorId,
|
|
108
|
+
userId: context.actorId,
|
|
109
|
+
projectId: project.projectId,
|
|
110
|
+
projectName: project.projectName,
|
|
111
|
+
workspaceRoot: context.workspaceRoot,
|
|
112
|
+
commandName: context.commandName,
|
|
113
|
+
toolName: context.toolName,
|
|
114
|
+
occurredAt,
|
|
115
|
+
requestTime: occurredAt,
|
|
116
|
+
targetModel: metadata.targetModel,
|
|
117
|
+
resultStatus: 'success',
|
|
118
|
+
result: {
|
|
119
|
+
status: 'success',
|
|
120
|
+
tokenExpiresAt: tokenResult.token.expiresAt,
|
|
121
|
+
scopeCount: tokenResult.token.scopes.length,
|
|
122
|
+
},
|
|
123
|
+
};
|
|
124
|
+
await emitAudit(options.auditRecorder, options.onAuditSinkError, audit);
|
|
125
|
+
return {
|
|
126
|
+
status: 'success',
|
|
127
|
+
request,
|
|
128
|
+
audit,
|
|
129
|
+
};
|
|
130
|
+
},
|
|
131
|
+
};
|
|
132
|
+
}
|
|
133
|
+
//# sourceMappingURL=client.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"client.js","sourceRoot":"","sources":["../../src/gateway/client.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"command.d.ts","sourceRoot":"","sources":["../../src/gateway/command.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAiIzD,wBAAsB,iBAAiB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC,CAmGvE;AAED,wBAAgB,sBAAsB,CAAC,MAAM,EAAE,aAAa,GAAG,IAAI,CAElE"}
|
|
@@ -0,0 +1,213 @@
|
|
|
1
|
+
import { randomUUID } from 'node:crypto';
|
|
2
|
+
import { userInfo } from 'node:os';
|
|
3
|
+
import { basename, resolve } from 'node:path';
|
|
4
|
+
import { HarnessError } from '../contracts/errors.js';
|
|
5
|
+
import { resolveHarnessServiceBaseUrl } from '../cloud/harness-service-url.js';
|
|
6
|
+
import { createHarnessServiceGatewayHttpExchange } from './service-http-exchange.js';
|
|
7
|
+
import { renderErrorBlock, renderJson, renderSuccessBlock } from '../cli-output/renderers.js';
|
|
8
|
+
function renderGatewayHelp(programName = 'harness') {
|
|
9
|
+
return [
|
|
10
|
+
'与 harness-service LLM Gateway 契约交互。',
|
|
11
|
+
'',
|
|
12
|
+
'用法:',
|
|
13
|
+
` ${programName} gateway token [--cwd <path>] [--actor-id <id>] [--project-id <id>] [--session-id <id>] [--json]`,
|
|
14
|
+
'',
|
|
15
|
+
'选项:',
|
|
16
|
+
' --cwd <path> 工作区根目录,默认当前目录。',
|
|
17
|
+
' --actor-id <id> 调用方身份,默认 HARNESS_ACTOR_ID 或系统用户名。',
|
|
18
|
+
' --project-id <id> 可选项目标识。',
|
|
19
|
+
' --session-id <id> 可选会话标识。',
|
|
20
|
+
' --show-token 成功时显示原始 token,避免写入日志或截图。',
|
|
21
|
+
' --json 输出机器可读 JSON。',
|
|
22
|
+
' -h, --help 查看帮助。',
|
|
23
|
+
'',
|
|
24
|
+
'环境变量:',
|
|
25
|
+
' 服务地址:HARNESS_SERVICE_URL 优先,其次 HARNESS_CLOUD_BASE_URL。',
|
|
26
|
+
' 可选鉴权:HARNESS_SERVICE_BEARER_TOKEN。',
|
|
27
|
+
'',
|
|
28
|
+
'退出码:',
|
|
29
|
+
' 0:获取短期凭证成功。',
|
|
30
|
+
' 1:缺少配置、网络/鉴权失败,或首期 GATEWAY_NOT_CONFIGURED 响应。',
|
|
31
|
+
].join('\n');
|
|
32
|
+
}
|
|
33
|
+
function parseGatewayTokenArgs(args) {
|
|
34
|
+
let cwd = process.cwd();
|
|
35
|
+
let actorId = '';
|
|
36
|
+
let projectId;
|
|
37
|
+
let sessionId;
|
|
38
|
+
let showToken = false;
|
|
39
|
+
let json = false;
|
|
40
|
+
let help = false;
|
|
41
|
+
for (let index = 0; index < args.length; index += 1) {
|
|
42
|
+
const arg = args[index];
|
|
43
|
+
if (arg === '--help' || arg === '-h') {
|
|
44
|
+
help = true;
|
|
45
|
+
continue;
|
|
46
|
+
}
|
|
47
|
+
if (arg === '--show-token') {
|
|
48
|
+
showToken = true;
|
|
49
|
+
continue;
|
|
50
|
+
}
|
|
51
|
+
if (arg === '--json') {
|
|
52
|
+
json = true;
|
|
53
|
+
continue;
|
|
54
|
+
}
|
|
55
|
+
if (arg === '--cwd') {
|
|
56
|
+
const value = args[index + 1];
|
|
57
|
+
if (!value || value.startsWith('--')) {
|
|
58
|
+
throw new HarnessError('GATEWAY_CLI_INVALID_ARGS', 'Missing value for --cwd.');
|
|
59
|
+
}
|
|
60
|
+
cwd = resolve(value);
|
|
61
|
+
index += 1;
|
|
62
|
+
continue;
|
|
63
|
+
}
|
|
64
|
+
if (arg === '--actor-id') {
|
|
65
|
+
const value = args[index + 1];
|
|
66
|
+
if (!value || value.startsWith('--')) {
|
|
67
|
+
throw new HarnessError('GATEWAY_CLI_INVALID_ARGS', 'Missing value for --actor-id.');
|
|
68
|
+
}
|
|
69
|
+
actorId = value.trim();
|
|
70
|
+
index += 1;
|
|
71
|
+
continue;
|
|
72
|
+
}
|
|
73
|
+
if (arg === '--project-id') {
|
|
74
|
+
const value = args[index + 1];
|
|
75
|
+
if (!value || value.startsWith('--')) {
|
|
76
|
+
throw new HarnessError('GATEWAY_CLI_INVALID_ARGS', 'Missing value for --project-id.');
|
|
77
|
+
}
|
|
78
|
+
projectId = value.trim();
|
|
79
|
+
index += 1;
|
|
80
|
+
continue;
|
|
81
|
+
}
|
|
82
|
+
if (arg === '--session-id') {
|
|
83
|
+
const value = args[index + 1];
|
|
84
|
+
if (!value || value.startsWith('--')) {
|
|
85
|
+
throw new HarnessError('GATEWAY_CLI_INVALID_ARGS', 'Missing value for --session-id.');
|
|
86
|
+
}
|
|
87
|
+
sessionId = value.trim();
|
|
88
|
+
index += 1;
|
|
89
|
+
continue;
|
|
90
|
+
}
|
|
91
|
+
throw new HarnessError('GATEWAY_CLI_INVALID_ARGS', `Unknown gateway token option: ${arg}`);
|
|
92
|
+
}
|
|
93
|
+
return {
|
|
94
|
+
cwd,
|
|
95
|
+
actorId,
|
|
96
|
+
projectId,
|
|
97
|
+
sessionId,
|
|
98
|
+
showToken,
|
|
99
|
+
json,
|
|
100
|
+
help,
|
|
101
|
+
};
|
|
102
|
+
}
|
|
103
|
+
function resolveDefaultActorId(parsed) {
|
|
104
|
+
const trimmed = parsed.actorId.trim();
|
|
105
|
+
if (trimmed.length > 0) {
|
|
106
|
+
return trimmed;
|
|
107
|
+
}
|
|
108
|
+
const envActor = process.env.HARNESS_ACTOR_ID?.trim();
|
|
109
|
+
if (envActor) {
|
|
110
|
+
return envActor;
|
|
111
|
+
}
|
|
112
|
+
try {
|
|
113
|
+
return userInfo().username || 'harness-cli';
|
|
114
|
+
}
|
|
115
|
+
catch {
|
|
116
|
+
return 'harness-cli';
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
export async function runGatewayCommand(args) {
|
|
120
|
+
if (args.length === 0 || args[0] === '--help' || args[0] === '-h') {
|
|
121
|
+
console.log(renderGatewayHelp());
|
|
122
|
+
return 0;
|
|
123
|
+
}
|
|
124
|
+
const subcommand = args[0];
|
|
125
|
+
if (subcommand !== 'token') {
|
|
126
|
+
console.error(`Unknown gateway subcommand: ${subcommand}\n\n${renderGatewayHelp()}`);
|
|
127
|
+
return 1;
|
|
128
|
+
}
|
|
129
|
+
const options = parseGatewayTokenArgs(args.slice(1));
|
|
130
|
+
if (options.help) {
|
|
131
|
+
console.log(renderGatewayHelp());
|
|
132
|
+
return 0;
|
|
133
|
+
}
|
|
134
|
+
const baseUrl = resolveHarnessServiceBaseUrl();
|
|
135
|
+
if (!baseUrl) {
|
|
136
|
+
const payload = {
|
|
137
|
+
status: 'error',
|
|
138
|
+
errorCode: 'HARNESS_SERVICE_URL_MISSING',
|
|
139
|
+
message: 'HARNESS_SERVICE_URL is not configured (HARNESS_CLOUD_BASE_URL fallback also empty). Export one before gateway exchange.',
|
|
140
|
+
actionableHints: [
|
|
141
|
+
'Example: export HARNESS_SERVICE_URL=https://harness-service.example.com',
|
|
142
|
+
'Local flows never persist static provider API keys in Harness files — keep secrets in your shell or secret manager.',
|
|
143
|
+
],
|
|
144
|
+
};
|
|
145
|
+
console.log(options.json ? renderJson(payload) : renderErrorBlock({
|
|
146
|
+
title: 'Gateway Token 获取失败',
|
|
147
|
+
message: '未配置 HARNESS_SERVICE_URL,且 HARNESS_CLOUD_BASE_URL 也为空。',
|
|
148
|
+
code: payload.errorCode,
|
|
149
|
+
suggestions: ['export HARNESS_SERVICE_URL=https://harness-service.example.com'],
|
|
150
|
+
}));
|
|
151
|
+
return 1;
|
|
152
|
+
}
|
|
153
|
+
const actorId = resolveDefaultActorId(options);
|
|
154
|
+
const resolvedProjectId = options.projectId?.trim() || process.env.HARNESS_PROJECT_ID?.trim() || basename(options.cwd);
|
|
155
|
+
const resolvedSessionId = options.sessionId?.trim() ||
|
|
156
|
+
process.env.HARNESS_GATEWAY_SESSION_ID?.trim() ||
|
|
157
|
+
process.env.HARNESS_SESSION_ID?.trim();
|
|
158
|
+
const exchange = createHarnessServiceGatewayHttpExchange({
|
|
159
|
+
baseUrl,
|
|
160
|
+
authorizationBearer: process.env.HARNESS_SERVICE_BEARER_TOKEN?.trim(),
|
|
161
|
+
});
|
|
162
|
+
const result = await exchange.exchange({
|
|
163
|
+
workspaceRoot: options.cwd,
|
|
164
|
+
actorId,
|
|
165
|
+
requestId: randomUUID(),
|
|
166
|
+
projectId: resolvedProjectId,
|
|
167
|
+
...(resolvedSessionId ? { sessionId: resolvedSessionId } : {}),
|
|
168
|
+
commandName: 'harness gateway token',
|
|
169
|
+
});
|
|
170
|
+
if (result.status === 'success') {
|
|
171
|
+
const payload = {
|
|
172
|
+
status: 'success',
|
|
173
|
+
serviceUrl: baseUrl,
|
|
174
|
+
expiresAt: result.token.expiresAt,
|
|
175
|
+
scopes: result.token.scopes,
|
|
176
|
+
};
|
|
177
|
+
if (options.showToken) {
|
|
178
|
+
payload.accessToken = result.token.value;
|
|
179
|
+
}
|
|
180
|
+
else {
|
|
181
|
+
payload.accessTokenRedacted = true;
|
|
182
|
+
payload.accessTokenPreview =
|
|
183
|
+
result.token.value.length <= 8 ? '***' : `${result.token.value.slice(0, 4)}…${result.token.value.slice(-4)}`;
|
|
184
|
+
}
|
|
185
|
+
console.log(options.json ? renderJson(payload) : renderSuccessBlock('Gateway Token 获取成功', [
|
|
186
|
+
['服务地址', baseUrl],
|
|
187
|
+
['过期时间', result.token.expiresAt],
|
|
188
|
+
['Scopes', result.token.scopes.join(', ')],
|
|
189
|
+
['Token', options.showToken ? result.token.value : String(payload.accessTokenPreview)],
|
|
190
|
+
]));
|
|
191
|
+
return 0;
|
|
192
|
+
}
|
|
193
|
+
const payload = {
|
|
194
|
+
status: 'error',
|
|
195
|
+
serviceUrl: baseUrl,
|
|
196
|
+
failureType: result.failureType,
|
|
197
|
+
errorCode: result.code,
|
|
198
|
+
message: result.message,
|
|
199
|
+
recommendedAction: result.action,
|
|
200
|
+
guidance: result.guidance,
|
|
201
|
+
};
|
|
202
|
+
console.log(options.json ? renderJson(payload) : renderErrorBlock({
|
|
203
|
+
title: 'Gateway Token 获取失败',
|
|
204
|
+
message: result.message,
|
|
205
|
+
code: result.code,
|
|
206
|
+
suggestions: [result.action, ...result.guidance],
|
|
207
|
+
}));
|
|
208
|
+
return 1;
|
|
209
|
+
}
|
|
210
|
+
export function registerGatewayCommand(router) {
|
|
211
|
+
router.register('gateway', runGatewayCommand);
|
|
212
|
+
}
|
|
213
|
+
//# sourceMappingURL=command.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"command.js","sourceRoot":"","sources":["../../src/gateway/command.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import type { GatewayTokenExchangeClient } from './token-exchange.js';
|
|
2
|
+
export interface CreateHarnessServiceGatewayHttpExchangeOptions {
|
|
3
|
+
baseUrl: string;
|
|
4
|
+
fetchImpl?: typeof fetch;
|
|
5
|
+
/**
|
|
6
|
+
* Optional bearer token for the current shell session (e.g. refreshed SSO access token).
|
|
7
|
+
* Prefer environment injection over committing secrets; phase-1 gateway stubs ignore this header.
|
|
8
|
+
*/
|
|
9
|
+
authorizationBearer?: string;
|
|
10
|
+
defaultScopes?: string[];
|
|
11
|
+
}
|
|
12
|
+
/**
|
|
13
|
+
* Calls harness-service `POST /gateway/token` and maps responses into {@link GatewayTokenExchangeResult}.
|
|
14
|
+
* Phase-1 services return `GATEWAY_NOT_CONFIGURED`; enabled gateways may return a short-lived credential.
|
|
15
|
+
*/
|
|
16
|
+
export declare function createHarnessServiceGatewayHttpExchange(options: CreateHarnessServiceGatewayHttpExchangeOptions): GatewayTokenExchangeClient;
|
|
17
|
+
//# sourceMappingURL=service-http-exchange.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"service-http-exchange.d.ts","sourceRoot":"","sources":["../../src/gateway/service-http-exchange.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,0BAA0B,EAA2D,MAAM,qBAAqB,CAAC;AAE/H,MAAM,WAAW,8CAA8C;IAC7D,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,CAAC,EAAE,OAAO,KAAK,CAAC;IACzB;;;OAGG;IACH,mBAAmB,CAAC,EAAE,MAAM,CAAC;IAC7B,aAAa,CAAC,EAAE,MAAM,EAAE,CAAC;CAC1B;AAkBD;;;GAGG;AACH,wBAAgB,uCAAuC,CACrD,OAAO,EAAE,8CAA8C,GACtD,0BAA0B,CAyL5B"}
|
|
@@ -0,0 +1,183 @@
|
|
|
1
|
+
function isRecord(value) {
|
|
2
|
+
return !!value && typeof value === 'object' && !Array.isArray(value);
|
|
3
|
+
}
|
|
4
|
+
async function readJson(response) {
|
|
5
|
+
const text = await response.text();
|
|
6
|
+
if (!text.trim()) {
|
|
7
|
+
return {};
|
|
8
|
+
}
|
|
9
|
+
try {
|
|
10
|
+
return JSON.parse(text);
|
|
11
|
+
}
|
|
12
|
+
catch {
|
|
13
|
+
return {};
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* Calls harness-service `POST /gateway/token` and maps responses into {@link GatewayTokenExchangeResult}.
|
|
18
|
+
* Phase-1 services return `GATEWAY_NOT_CONFIGURED`; enabled gateways may return a short-lived credential.
|
|
19
|
+
*/
|
|
20
|
+
export function createHarnessServiceGatewayHttpExchange(options) {
|
|
21
|
+
const fetchFn = options.fetchImpl ?? globalThis.fetch;
|
|
22
|
+
const base = options.baseUrl.replace(/\/$/, '');
|
|
23
|
+
const defaultScopes = options.defaultScopes ?? ['gateway:invoke'];
|
|
24
|
+
return {
|
|
25
|
+
async exchange(context) {
|
|
26
|
+
const url = `${base}/gateway/token`;
|
|
27
|
+
const headers = {
|
|
28
|
+
'Content-Type': 'application/json',
|
|
29
|
+
};
|
|
30
|
+
const bearer = options.authorizationBearer?.trim();
|
|
31
|
+
if (bearer) {
|
|
32
|
+
headers.Authorization = bearer.startsWith('Bearer ') ? bearer : `Bearer ${bearer}`;
|
|
33
|
+
}
|
|
34
|
+
const body = {
|
|
35
|
+
actorId: context.actorId,
|
|
36
|
+
scopes: defaultScopes,
|
|
37
|
+
};
|
|
38
|
+
const projectId = context.projectId?.trim();
|
|
39
|
+
if (projectId) {
|
|
40
|
+
body.projectId = projectId;
|
|
41
|
+
}
|
|
42
|
+
const sessionId = context.sessionId?.trim();
|
|
43
|
+
if (sessionId) {
|
|
44
|
+
body.sessionId = sessionId;
|
|
45
|
+
}
|
|
46
|
+
let response;
|
|
47
|
+
try {
|
|
48
|
+
response = await fetchFn(url, {
|
|
49
|
+
method: 'POST',
|
|
50
|
+
headers,
|
|
51
|
+
body: JSON.stringify(body),
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
catch (error) {
|
|
55
|
+
const detail = error instanceof Error ? error.message : String(error);
|
|
56
|
+
return {
|
|
57
|
+
status: 'error',
|
|
58
|
+
failureType: 'refreshable',
|
|
59
|
+
code: 'GATEWAY_AUTH_UNAVAILABLE',
|
|
60
|
+
message: `Cannot reach harness-service gateway: ${detail}`,
|
|
61
|
+
action: 'retry-later',
|
|
62
|
+
guidance: 'Verify HARNESS_SERVICE_URL / network. Fix VPN or TLS requirements if your operator requires them, then retry.',
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
const payload = await readJson(response);
|
|
66
|
+
if (response.status === 401) {
|
|
67
|
+
return {
|
|
68
|
+
status: 'error',
|
|
69
|
+
failureType: 'refreshable',
|
|
70
|
+
code: 'GATEWAY_AUTH_UNAVAILABLE',
|
|
71
|
+
message: isRecord(payload) && typeof payload.message === 'string'
|
|
72
|
+
? payload.message
|
|
73
|
+
: 'Gateway token exchange rejected credentials (HTTP 401).',
|
|
74
|
+
action: 'refresh-token',
|
|
75
|
+
guidance: 'Refresh your enterprise session token or re-authenticate, then retry. Optional: export HARNESS_SERVICE_BEARER_TOKEN only for the current shell (never commit it).',
|
|
76
|
+
};
|
|
77
|
+
}
|
|
78
|
+
if (response.status === 403) {
|
|
79
|
+
return {
|
|
80
|
+
status: 'error',
|
|
81
|
+
failureType: 'authorization',
|
|
82
|
+
code: 'GATEWAY_AUTH_FORBIDDEN',
|
|
83
|
+
message: isRecord(payload) && typeof payload.message === 'string'
|
|
84
|
+
? payload.message
|
|
85
|
+
: 'Gateway token exchange forbidden (HTTP 403).',
|
|
86
|
+
action: 'request-access',
|
|
87
|
+
guidance: 'Request gateway invoke permission from your platform administrator.',
|
|
88
|
+
};
|
|
89
|
+
}
|
|
90
|
+
if (!response.ok) {
|
|
91
|
+
const errorCode = isRecord(payload) && typeof payload.errorCode === 'string' ? payload.errorCode : 'GATEWAY_REQUEST_FAILED';
|
|
92
|
+
const message = isRecord(payload) && typeof payload.message === 'string'
|
|
93
|
+
? payload.message
|
|
94
|
+
: `harness-service returned HTTP ${response.status}`;
|
|
95
|
+
return {
|
|
96
|
+
status: 'error',
|
|
97
|
+
failureType: 'refreshable',
|
|
98
|
+
code: 'GATEWAY_AUTH_UNAVAILABLE',
|
|
99
|
+
message,
|
|
100
|
+
action: 'retry-later',
|
|
101
|
+
guidance: errorCode === 'GATEWAY_REQUEST_INVALID'
|
|
102
|
+
? 'Fix actorId / scopes parameters and retry.'
|
|
103
|
+
: 'Inspect harness-service logs or retry later.',
|
|
104
|
+
};
|
|
105
|
+
}
|
|
106
|
+
if (!isRecord(payload)) {
|
|
107
|
+
return {
|
|
108
|
+
status: 'error',
|
|
109
|
+
failureType: 'refreshable',
|
|
110
|
+
code: 'GATEWAY_AUTH_UNAVAILABLE',
|
|
111
|
+
message: 'Gateway token exchange returned a non-object JSON body.',
|
|
112
|
+
action: 'retry-later',
|
|
113
|
+
guidance: 'Upgrade CLI and harness-service to compatible gateway contract versions.',
|
|
114
|
+
};
|
|
115
|
+
}
|
|
116
|
+
if (payload.enabled === true) {
|
|
117
|
+
const tokenValue = typeof payload.accessToken === 'string'
|
|
118
|
+
? payload.accessToken
|
|
119
|
+
: typeof payload.token === 'string'
|
|
120
|
+
? payload.token
|
|
121
|
+
: '';
|
|
122
|
+
const expiresAt = typeof payload.expiresAt === 'string'
|
|
123
|
+
? payload.expiresAt
|
|
124
|
+
: typeof payload.tokenExpiresAt === 'string'
|
|
125
|
+
? payload.tokenExpiresAt
|
|
126
|
+
: '';
|
|
127
|
+
const scopeList = Array.isArray(payload.scopes)
|
|
128
|
+
? payload.scopes.filter((scope) => typeof scope === 'string')
|
|
129
|
+
: defaultScopes;
|
|
130
|
+
const expiryMs = Date.parse(expiresAt);
|
|
131
|
+
if (!tokenValue || !Number.isFinite(expiryMs) || expiryMs <= Date.now()) {
|
|
132
|
+
return {
|
|
133
|
+
status: 'error',
|
|
134
|
+
failureType: 'refreshable',
|
|
135
|
+
code: 'GATEWAY_AUTH_UNAVAILABLE',
|
|
136
|
+
message: 'Gateway enabled response did not include a usable short-lived credential.',
|
|
137
|
+
action: 'retry-later',
|
|
138
|
+
guidance: 'Contact operators — forwarding may be partially configured.',
|
|
139
|
+
};
|
|
140
|
+
}
|
|
141
|
+
return {
|
|
142
|
+
status: 'success',
|
|
143
|
+
token: {
|
|
144
|
+
value: tokenValue,
|
|
145
|
+
expiresAt,
|
|
146
|
+
scopes: scopeList.length > 0 ? scopeList : defaultScopes,
|
|
147
|
+
},
|
|
148
|
+
};
|
|
149
|
+
}
|
|
150
|
+
if (payload.errorCode === 'GATEWAY_NOT_CONFIGURED') {
|
|
151
|
+
const hints = Array.isArray(payload.actionableHints)
|
|
152
|
+
? payload.actionableHints.filter((hint) => typeof hint === 'string')
|
|
153
|
+
: [];
|
|
154
|
+
const hintText = hints.length > 0 ? hints.join(' ') : '';
|
|
155
|
+
const message = typeof payload.message === 'string'
|
|
156
|
+
? payload.message
|
|
157
|
+
: 'LLM gateway is not configured on this harness-service instance.';
|
|
158
|
+
return {
|
|
159
|
+
status: 'error',
|
|
160
|
+
failureType: 'refreshable',
|
|
161
|
+
code: 'GATEWAY_AUTH_UNAVAILABLE',
|
|
162
|
+
message,
|
|
163
|
+
action: 'retry-later',
|
|
164
|
+
guidance: [
|
|
165
|
+
hintText,
|
|
166
|
+
'until forwarding ships on harness-service (HARNESS_GATEWAY_* variables). MCP stays local-only unless HARNESS_GATEWAY_TOKEN_ENFORCE=true.',
|
|
167
|
+
]
|
|
168
|
+
.filter(Boolean)
|
|
169
|
+
.join(' '),
|
|
170
|
+
};
|
|
171
|
+
}
|
|
172
|
+
return {
|
|
173
|
+
status: 'error',
|
|
174
|
+
failureType: 'refreshable',
|
|
175
|
+
code: 'GATEWAY_AUTH_UNAVAILABLE',
|
|
176
|
+
message: typeof payload.message === 'string' ? payload.message : 'Unexpected gateway token exchange response shape.',
|
|
177
|
+
action: 'retry-later',
|
|
178
|
+
guidance: 'Inspect harness-service gateway logs for malformed payloads.',
|
|
179
|
+
};
|
|
180
|
+
},
|
|
181
|
+
};
|
|
182
|
+
}
|
|
183
|
+
//# sourceMappingURL=service-http-exchange.js.map
|