palaryn 0.1.0 → 0.3.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 +243 -588
- package/dist/sdk/typescript/src/client.js +2 -2
- package/dist/sdk/typescript/src/client.js.map +1 -1
- package/dist/src/audit/logger.d.ts +10 -0
- package/dist/src/audit/logger.d.ts.map +1 -1
- package/dist/src/audit/logger.js +52 -38
- package/dist/src/audit/logger.js.map +1 -1
- package/dist/src/auth/routes.js.map +1 -1
- package/dist/src/budget/manager.d.ts +5 -0
- package/dist/src/budget/manager.d.ts.map +1 -1
- package/dist/src/budget/manager.js +32 -0
- package/dist/src/budget/manager.js.map +1 -1
- package/dist/src/budget/model-pricing.d.ts +20 -0
- package/dist/src/budget/model-pricing.d.ts.map +1 -0
- package/dist/src/budget/model-pricing.js +107 -0
- package/dist/src/budget/model-pricing.js.map +1 -0
- package/dist/src/budget/usage-extractor.d.ts +3 -1
- package/dist/src/budget/usage-extractor.d.ts.map +1 -1
- package/dist/src/budget/usage-extractor.js +47 -3
- package/dist/src/budget/usage-extractor.js.map +1 -1
- package/dist/src/config/defaults.d.ts.map +1 -1
- package/dist/src/config/defaults.js +65 -13
- package/dist/src/config/defaults.js.map +1 -1
- package/dist/src/dlp/tool-patterns.d.ts +7 -0
- package/dist/src/dlp/tool-patterns.d.ts.map +1 -0
- package/dist/src/dlp/tool-patterns.js +34 -0
- package/dist/src/dlp/tool-patterns.js.map +1 -0
- package/dist/src/executor/filesystem-executor.d.ts +28 -0
- package/dist/src/executor/filesystem-executor.d.ts.map +1 -0
- package/dist/src/executor/filesystem-executor.js +192 -0
- package/dist/src/executor/filesystem-executor.js.map +1 -0
- package/dist/src/executor/http-executor.d.ts.map +1 -1
- package/dist/src/executor/http-executor.js +4 -0
- package/dist/src/executor/http-executor.js.map +1 -1
- package/dist/src/executor/index.d.ts +4 -0
- package/dist/src/executor/index.d.ts.map +1 -1
- package/dist/src/executor/index.js +9 -1
- package/dist/src/executor/index.js.map +1 -1
- package/dist/src/executor/shell-executor.d.ts +22 -0
- package/dist/src/executor/shell-executor.d.ts.map +1 -0
- package/dist/src/executor/shell-executor.js +119 -0
- package/dist/src/executor/shell-executor.js.map +1 -0
- package/dist/src/executor/sql-executor.d.ts +29 -0
- package/dist/src/executor/sql-executor.d.ts.map +1 -0
- package/dist/src/executor/sql-executor.js +114 -0
- package/dist/src/executor/sql-executor.js.map +1 -0
- package/dist/src/executor/websocket-executor.d.ts +26 -0
- package/dist/src/executor/websocket-executor.d.ts.map +1 -0
- package/dist/src/executor/websocket-executor.js +205 -0
- package/dist/src/executor/websocket-executor.js.map +1 -0
- package/dist/src/interceptor/index.d.ts +2 -0
- package/dist/src/interceptor/index.d.ts.map +1 -0
- package/dist/src/interceptor/index.js +6 -0
- package/dist/src/interceptor/index.js.map +1 -0
- package/dist/src/interceptor/provider-interceptor.d.ts +36 -0
- package/dist/src/interceptor/provider-interceptor.d.ts.map +1 -0
- package/dist/src/interceptor/provider-interceptor.js +302 -0
- package/dist/src/interceptor/provider-interceptor.js.map +1 -0
- package/dist/src/mcp/auth-verifier.d.ts.map +1 -1
- package/dist/src/mcp/auth-verifier.js +3 -2
- package/dist/src/mcp/auth-verifier.js.map +1 -1
- package/dist/src/mcp/bridge.d.ts +14 -10
- package/dist/src/mcp/bridge.d.ts.map +1 -1
- package/dist/src/mcp/bridge.js +51 -227
- package/dist/src/mcp/bridge.js.map +1 -1
- package/dist/src/mcp/http-transport.d.ts.map +1 -1
- package/dist/src/mcp/http-transport.js +101 -65
- package/dist/src/mcp/http-transport.js.map +1 -1
- package/dist/src/mcp/tool-definitions.d.ts +41 -0
- package/dist/src/mcp/tool-definitions.d.ts.map +1 -0
- package/dist/src/mcp/tool-definitions.js +491 -0
- package/dist/src/mcp/tool-definitions.js.map +1 -0
- package/dist/src/middleware/auth.js.map +1 -1
- package/dist/src/middleware/session.js.map +1 -1
- package/dist/src/middleware/validate.d.ts +8 -0
- package/dist/src/middleware/validate.d.ts.map +1 -1
- package/dist/src/middleware/validate.js +45 -0
- package/dist/src/middleware/validate.js.map +1 -1
- package/dist/src/policy/engine.d.ts +4 -0
- package/dist/src/policy/engine.d.ts.map +1 -1
- package/dist/src/policy/engine.js +117 -0
- package/dist/src/policy/engine.js.map +1 -1
- package/dist/src/saas/routes.d.ts.map +1 -1
- package/dist/src/saas/routes.js +327 -10
- package/dist/src/saas/routes.js.map +1 -1
- package/dist/src/server/app.d.ts.map +1 -1
- package/dist/src/server/app.js +19 -2
- package/dist/src/server/app.js.map +1 -1
- package/dist/src/server/gateway.d.ts.map +1 -1
- package/dist/src/server/gateway.js +17 -0
- package/dist/src/server/gateway.js.map +1 -1
- package/dist/src/server/index.d.ts.map +1 -1
- package/dist/src/server/index.js +18 -0
- package/dist/src/server/index.js.map +1 -1
- package/dist/src/storage/interfaces.d.ts +14 -3
- package/dist/src/storage/interfaces.d.ts.map +1 -1
- package/dist/src/storage/memory.d.ts +2 -0
- package/dist/src/storage/memory.d.ts.map +1 -1
- package/dist/src/storage/memory.js +6 -0
- package/dist/src/storage/memory.js.map +1 -1
- package/dist/src/storage/postgres.d.ts +5 -0
- package/dist/src/storage/postgres.d.ts.map +1 -1
- package/dist/src/storage/postgres.js +16 -0
- package/dist/src/storage/postgres.js.map +1 -1
- package/dist/src/storage/redis.d.ts +10 -0
- package/dist/src/storage/redis.d.ts.map +1 -1
- package/dist/src/storage/redis.js +65 -0
- package/dist/src/storage/redis.js.map +1 -1
- package/dist/src/types/budget.d.ts +4 -0
- package/dist/src/types/budget.d.ts.map +1 -1
- package/dist/src/types/config.d.ts +58 -0
- package/dist/src/types/config.d.ts.map +1 -1
- package/dist/src/types/events.d.ts +1 -0
- package/dist/src/types/events.d.ts.map +1 -1
- package/dist/src/types/policy.d.ts +11 -1
- package/dist/src/types/policy.d.ts.map +1 -1
- package/dist/src/types/tool-result.d.ts +11 -0
- package/dist/src/types/tool-result.d.ts.map +1 -1
- package/dist/tests/unit/app-routes.test.d.ts +2 -0
- package/dist/tests/unit/app-routes.test.d.ts.map +1 -0
- package/dist/tests/unit/app-routes.test.js +715 -0
- package/dist/tests/unit/app-routes.test.js.map +1 -0
- package/dist/tests/unit/audit-logger.test.js +105 -0
- package/dist/tests/unit/audit-logger.test.js.map +1 -1
- package/dist/tests/unit/auth-providers.test.d.ts +2 -0
- package/dist/tests/unit/auth-providers.test.d.ts.map +1 -0
- package/dist/tests/unit/auth-providers.test.js +279 -0
- package/dist/tests/unit/auth-providers.test.js.map +1 -0
- package/dist/tests/unit/auth-routes-extended.test.d.ts +2 -0
- package/dist/tests/unit/auth-routes-extended.test.d.ts.map +1 -0
- package/dist/tests/unit/auth-routes-extended.test.js +993 -0
- package/dist/tests/unit/auth-routes-extended.test.js.map +1 -0
- package/dist/tests/unit/auth-verifier.test.d.ts +2 -0
- package/dist/tests/unit/auth-verifier.test.d.ts.map +1 -0
- package/dist/tests/unit/auth-verifier.test.js +505 -0
- package/dist/tests/unit/auth-verifier.test.js.map +1 -0
- package/dist/tests/unit/billing-routes.test.d.ts +2 -0
- package/dist/tests/unit/billing-routes.test.d.ts.map +1 -0
- package/dist/tests/unit/billing-routes.test.js +432 -0
- package/dist/tests/unit/billing-routes.test.js.map +1 -0
- package/dist/tests/unit/config-defaults.test.d.ts +2 -0
- package/dist/tests/unit/config-defaults.test.d.ts.map +1 -0
- package/dist/tests/unit/config-defaults.test.js +119 -0
- package/dist/tests/unit/config-defaults.test.js.map +1 -0
- package/dist/tests/unit/defaults.test.js +0 -10
- package/dist/tests/unit/defaults.test.js.map +1 -1
- package/dist/tests/unit/filesystem-executor.test.d.ts +2 -0
- package/dist/tests/unit/filesystem-executor.test.d.ts.map +1 -0
- package/dist/tests/unit/filesystem-executor.test.js +280 -0
- package/dist/tests/unit/filesystem-executor.test.js.map +1 -0
- package/dist/tests/unit/gateway-branches.test.d.ts +2 -0
- package/dist/tests/unit/gateway-branches.test.d.ts.map +1 -0
- package/dist/tests/unit/gateway-branches.test.js +1039 -0
- package/dist/tests/unit/gateway-branches.test.js.map +1 -0
- package/dist/tests/unit/http-executor-branches.test.d.ts +2 -0
- package/dist/tests/unit/http-executor-branches.test.d.ts.map +1 -0
- package/dist/tests/unit/http-executor-branches.test.js +495 -0
- package/dist/tests/unit/http-executor-branches.test.js.map +1 -0
- package/dist/tests/unit/logger.test.d.ts +2 -0
- package/dist/tests/unit/logger.test.d.ts.map +1 -0
- package/dist/tests/unit/logger.test.js +97 -0
- package/dist/tests/unit/logger.test.js.map +1 -0
- package/dist/tests/unit/metrics.test.js +102 -0
- package/dist/tests/unit/metrics.test.js.map +1 -1
- package/dist/tests/unit/model-pricing.test.d.ts +2 -0
- package/dist/tests/unit/model-pricing.test.d.ts.map +1 -0
- package/dist/tests/unit/model-pricing.test.js +87 -0
- package/dist/tests/unit/model-pricing.test.js.map +1 -0
- package/dist/tests/unit/oauth-stores.test.d.ts +2 -0
- package/dist/tests/unit/oauth-stores.test.d.ts.map +1 -0
- package/dist/tests/unit/oauth-stores.test.js +260 -0
- package/dist/tests/unit/oauth-stores.test.js.map +1 -0
- package/dist/tests/unit/policy-engine.test.js +466 -0
- package/dist/tests/unit/policy-engine.test.js.map +1 -1
- package/dist/tests/unit/provider-interceptor.test.d.ts +2 -0
- package/dist/tests/unit/provider-interceptor.test.d.ts.map +1 -0
- package/dist/tests/unit/provider-interceptor.test.js +472 -0
- package/dist/tests/unit/provider-interceptor.test.js.map +1 -0
- package/dist/tests/unit/saas-routes-branches.test.d.ts +2 -0
- package/dist/tests/unit/saas-routes-branches.test.d.ts.map +1 -0
- package/dist/tests/unit/saas-routes-branches.test.js +2040 -0
- package/dist/tests/unit/saas-routes-branches.test.js.map +1 -0
- package/dist/tests/unit/saas-routes-crud.test.d.ts +2 -0
- package/dist/tests/unit/saas-routes-crud.test.d.ts.map +1 -0
- package/dist/tests/unit/saas-routes-crud.test.js +332 -0
- package/dist/tests/unit/saas-routes-crud.test.js.map +1 -0
- package/dist/tests/unit/saas-routes-data.test.d.ts +2 -0
- package/dist/tests/unit/saas-routes-data.test.d.ts.map +1 -0
- package/dist/tests/unit/saas-routes-data.test.js +405 -0
- package/dist/tests/unit/saas-routes-data.test.js.map +1 -0
- package/dist/tests/unit/saas-routes.test.js +3 -3
- package/dist/tests/unit/saas-routes.test.js.map +1 -1
- package/dist/tests/unit/shell-executor.test.d.ts +2 -0
- package/dist/tests/unit/shell-executor.test.d.ts.map +1 -0
- package/dist/tests/unit/shell-executor.test.js +145 -0
- package/dist/tests/unit/shell-executor.test.js.map +1 -0
- package/dist/tests/unit/sql-executor.test.d.ts +2 -0
- package/dist/tests/unit/sql-executor.test.d.ts.map +1 -0
- package/dist/tests/unit/sql-executor.test.js +177 -0
- package/dist/tests/unit/sql-executor.test.js.map +1 -0
- package/dist/tests/unit/stream-proxy.test.d.ts +2 -0
- package/dist/tests/unit/stream-proxy.test.d.ts.map +1 -0
- package/dist/tests/unit/stream-proxy.test.js +147 -0
- package/dist/tests/unit/stream-proxy.test.js.map +1 -0
- package/dist/tests/unit/tool-definitions.test.d.ts +2 -0
- package/dist/tests/unit/tool-definitions.test.d.ts.map +1 -0
- package/dist/tests/unit/tool-definitions.test.js +184 -0
- package/dist/tests/unit/tool-definitions.test.js.map +1 -0
- package/dist/tests/unit/usage-extractor.test.js +140 -0
- package/dist/tests/unit/usage-extractor.test.js.map +1 -1
- package/dist/tests/unit/webhook-handler.test.d.ts +2 -0
- package/dist/tests/unit/webhook-handler.test.d.ts.map +1 -0
- package/dist/tests/unit/webhook-handler.test.js +453 -0
- package/dist/tests/unit/webhook-handler.test.js.map +1 -0
- package/dist/tests/unit/webhook-routes.test.d.ts +2 -0
- package/dist/tests/unit/webhook-routes.test.d.ts.map +1 -0
- package/dist/tests/unit/webhook-routes.test.js +69 -0
- package/dist/tests/unit/webhook-routes.test.js.map +1 -0
- package/dist/tests/unit/websocket-executor.test.d.ts +2 -0
- package/dist/tests/unit/websocket-executor.test.d.ts.map +1 -0
- package/dist/tests/unit/websocket-executor.test.js +121 -0
- package/dist/tests/unit/websocket-executor.test.js.map +1 -0
- package/package.json +8 -2
- package/policy-packs/demo_fail.yaml +41 -0
- package/policy-packs/full_tools.yaml +136 -0
- package/src/admin/index.ts +1 -0
- package/src/admin/routes.ts +509 -0
- package/src/admin/templates.ts +572 -0
- package/src/anomaly/detector.ts +717 -0
- package/src/anomaly/index.ts +1 -0
- package/src/approval/manager.ts +569 -0
- package/src/approval/webhook.ts +133 -0
- package/src/audit/logger.ts +490 -0
- package/src/auth/index.ts +5 -0
- package/src/auth/password.ts +21 -0
- package/src/auth/pkce.ts +22 -0
- package/src/auth/providers.ts +208 -0
- package/src/auth/routes.ts +521 -0
- package/src/auth/session.ts +84 -0
- package/src/billing/index.ts +6 -0
- package/src/billing/plan-enforcer.ts +135 -0
- package/src/billing/routes.ts +229 -0
- package/src/billing/stripe-client.ts +58 -0
- package/src/billing/webhook-handler.ts +182 -0
- package/src/billing/webhook-routes.ts +28 -0
- package/src/budget/manager.ts +679 -0
- package/src/budget/model-pricing.ts +119 -0
- package/src/budget/usage-extractor.ts +214 -0
- package/src/cli.ts +91 -0
- package/src/config/defaults.ts +261 -0
- package/src/config/validate.ts +88 -0
- package/src/dlp/composite-scanner.ts +213 -0
- package/src/dlp/index.ts +9 -0
- package/src/dlp/interfaces.ts +34 -0
- package/src/dlp/patterns.ts +30 -0
- package/src/dlp/prompt-injection-backend.ts +181 -0
- package/src/dlp/prompt-injection-patterns.ts +302 -0
- package/src/dlp/regex-backend.ts +181 -0
- package/src/dlp/scanner.ts +502 -0
- package/src/dlp/text-normalizer.ts +225 -0
- package/src/dlp/tool-patterns.ts +35 -0
- package/src/dlp/trufflehog-backend.ts +190 -0
- package/src/executor/filesystem-executor.ts +196 -0
- package/src/executor/http-executor.ts +330 -0
- package/src/executor/index.ts +9 -0
- package/src/executor/interfaces.ts +11 -0
- package/src/executor/noop-executor.ts +23 -0
- package/src/executor/registry.ts +64 -0
- package/src/executor/shell-executor.ts +148 -0
- package/src/executor/slack-executor.ts +176 -0
- package/src/executor/sql-executor.ts +146 -0
- package/src/executor/websocket-executor.ts +211 -0
- package/src/index.ts +24 -0
- package/src/interceptor/index.ts +1 -0
- package/src/interceptor/provider-interceptor.ts +315 -0
- package/src/mcp/auth-verifier.ts +152 -0
- package/src/mcp/bridge.ts +703 -0
- package/src/mcp/http-transport.ts +672 -0
- package/src/mcp/index.ts +9 -0
- package/src/mcp/oauth-pages.ts +139 -0
- package/src/mcp/oauth-postgres-stores.ts +278 -0
- package/src/mcp/oauth-provider.ts +536 -0
- package/src/mcp/oauth-stores.ts +202 -0
- package/src/mcp/server.ts +55 -0
- package/src/mcp/tool-definitions.ts +562 -0
- package/src/metrics/collector.ts +357 -0
- package/src/metrics/index.ts +1 -0
- package/src/middleware/auth.ts +814 -0
- package/src/middleware/session.ts +85 -0
- package/src/middleware/validate.ts +130 -0
- package/src/policy/engine.ts +815 -0
- package/src/policy/index.ts +2 -0
- package/src/policy/opa-engine.ts +829 -0
- package/src/proxy/forward-proxy.ts +649 -0
- package/src/proxy/index.ts +1 -0
- package/src/ratelimit/limiter.ts +196 -0
- package/src/replay/engine.ts +142 -0
- package/src/replay/index.ts +1 -0
- package/src/saas/index.ts +1 -0
- package/src/saas/routes.ts +2161 -0
- package/src/server/app.ts +981 -0
- package/src/server/errors.ts +49 -0
- package/src/server/gateway.ts +1130 -0
- package/src/server/index.ts +307 -0
- package/src/server/logger.ts +255 -0
- package/src/server/stream-proxy.ts +202 -0
- package/src/storage/file-persistence.ts +315 -0
- package/src/storage/index.ts +4 -0
- package/src/storage/interfaces.ts +287 -0
- package/src/storage/memory.ts +686 -0
- package/src/storage/postgres.ts +1831 -0
- package/src/storage/redis.ts +835 -0
- package/src/tracing/index.ts +1 -0
- package/src/tracing/provider.ts +100 -0
- package/src/trust/calculator.ts +141 -0
- package/src/trust/index.ts +7 -0
- package/src/types/budget.ts +36 -0
- package/src/types/config.ts +278 -0
- package/src/types/events.ts +41 -0
- package/src/types/express.d.ts +14 -0
- package/src/types/index.ts +7 -0
- package/src/types/policy.ts +83 -0
- package/src/types/stripe-config.ts +11 -0
- package/src/types/subscription.ts +59 -0
- package/src/types/tool-call.ts +47 -0
- package/src/types/tool-result.ts +82 -0
- package/src/types/user.ts +125 -0
- package/tsconfig.json +24 -0
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { ToolCall } from '../types/tool-call';
|
|
2
|
+
import { ToolOutput } from '../types/tool-result';
|
|
3
|
+
import { ToolExecutor } from './interfaces';
|
|
4
|
+
import { WebSocketExecutorConfig } from '../types/config';
|
|
5
|
+
/**
|
|
6
|
+
* WebSocket executor for managed WebSocket connections.
|
|
7
|
+
* Handles tool calls with tool name `ws.*` (e.g., ws.connect, ws.send, ws.close).
|
|
8
|
+
* Manages a connection pool by connection_id with URL allowlisting.
|
|
9
|
+
*/
|
|
10
|
+
export declare class WebSocketExecutor implements ToolExecutor {
|
|
11
|
+
private config;
|
|
12
|
+
private connections;
|
|
13
|
+
constructor(config: WebSocketExecutorConfig);
|
|
14
|
+
execute(toolCall: ToolCall): Promise<ToolOutput>;
|
|
15
|
+
private resolveAction;
|
|
16
|
+
/**
|
|
17
|
+
* Check if a URL matches any of the allowed URL patterns.
|
|
18
|
+
*/
|
|
19
|
+
private isUrlAllowed;
|
|
20
|
+
private connect;
|
|
21
|
+
private send;
|
|
22
|
+
private wsClose;
|
|
23
|
+
/** Close all managed connections. */
|
|
24
|
+
closeAll(): Promise<void>;
|
|
25
|
+
}
|
|
26
|
+
//# sourceMappingURL=websocket-executor.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"websocket-executor.d.ts","sourceRoot":"","sources":["../../../src/executor/websocket-executor.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAC;AAC9C,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAClD,OAAO,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;AAC5C,OAAO,EAAE,uBAAuB,EAAE,MAAM,iBAAiB,CAAC;AAQ1D;;;;GAIG;AACH,qBAAa,iBAAkB,YAAW,YAAY;IACpD,OAAO,CAAC,MAAM,CAA0B;IACxC,OAAO,CAAC,WAAW,CAA6C;gBAEpD,MAAM,EAAE,uBAAuB;IAIrC,OAAO,CAAC,QAAQ,EAAE,QAAQ,GAAG,OAAO,CAAC,UAAU,CAAC;IAetD,OAAO,CAAC,aAAa;IAcrB;;OAEG;IACH,OAAO,CAAC,YAAY;YAiBN,OAAO;YA6CP,IAAI;YA8DJ,OAAO;IAqBrB,qCAAqC;IAC/B,QAAQ,IAAI,OAAO,CAAC,IAAI,CAAC;CAMhC"}
|
|
@@ -0,0 +1,205 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
36
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
37
|
+
};
|
|
38
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
39
|
+
exports.WebSocketExecutor = void 0;
|
|
40
|
+
const ws_1 = __importDefault(require("ws"));
|
|
41
|
+
const crypto = __importStar(require("crypto"));
|
|
42
|
+
/**
|
|
43
|
+
* WebSocket executor for managed WebSocket connections.
|
|
44
|
+
* Handles tool calls with tool name `ws.*` (e.g., ws.connect, ws.send, ws.close).
|
|
45
|
+
* Manages a connection pool by connection_id with URL allowlisting.
|
|
46
|
+
*/
|
|
47
|
+
class WebSocketExecutor {
|
|
48
|
+
constructor(config) {
|
|
49
|
+
this.connections = new Map();
|
|
50
|
+
this.config = config;
|
|
51
|
+
}
|
|
52
|
+
async execute(toolCall) {
|
|
53
|
+
const action = this.resolveAction(toolCall);
|
|
54
|
+
switch (action) {
|
|
55
|
+
case 'connect':
|
|
56
|
+
return this.connect(toolCall);
|
|
57
|
+
case 'send':
|
|
58
|
+
return this.send(toolCall);
|
|
59
|
+
case 'close':
|
|
60
|
+
return this.wsClose(toolCall);
|
|
61
|
+
default:
|
|
62
|
+
throw new Error(`Unsupported WebSocket action: ${action}`);
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
resolveAction(toolCall) {
|
|
66
|
+
if (toolCall.args.action && typeof toolCall.args.action === 'string') {
|
|
67
|
+
return toolCall.args.action;
|
|
68
|
+
}
|
|
69
|
+
const toolName = toolCall.tool.name;
|
|
70
|
+
const dotIndex = toolName.indexOf('.');
|
|
71
|
+
if (dotIndex !== -1) {
|
|
72
|
+
return toolName.substring(dotIndex + 1);
|
|
73
|
+
}
|
|
74
|
+
throw new Error(`Unsupported WebSocket action: ${toolName}`);
|
|
75
|
+
}
|
|
76
|
+
/**
|
|
77
|
+
* Check if a URL matches any of the allowed URL patterns.
|
|
78
|
+
*/
|
|
79
|
+
isUrlAllowed(url) {
|
|
80
|
+
if (!this.config.allowed_urls || this.config.allowed_urls.length === 0) {
|
|
81
|
+
return false;
|
|
82
|
+
}
|
|
83
|
+
for (const pattern of this.config.allowed_urls) {
|
|
84
|
+
// Convert glob-like pattern to regex
|
|
85
|
+
const escaped = pattern.replace(/[.+?^${}()|[\]\\]/g, '\\$&').replace(/\*/g, '.*');
|
|
86
|
+
const regex = new RegExp(`^${escaped}$`);
|
|
87
|
+
if (regex.test(url)) {
|
|
88
|
+
return true;
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
return false;
|
|
92
|
+
}
|
|
93
|
+
async connect(toolCall) {
|
|
94
|
+
const { url, connection_id: providedId } = toolCall.args;
|
|
95
|
+
if (!url || typeof url !== 'string') {
|
|
96
|
+
throw new Error('Missing or invalid "url" argument for ws.connect');
|
|
97
|
+
}
|
|
98
|
+
if (!this.isUrlAllowed(url)) {
|
|
99
|
+
throw new Error(`URL "${url}" is not in the allowed URLs list`);
|
|
100
|
+
}
|
|
101
|
+
const connectionId = (typeof providedId === 'string' ? providedId : null)
|
|
102
|
+
|| crypto.randomUUID();
|
|
103
|
+
return new Promise((resolve, reject) => {
|
|
104
|
+
const timeout = setTimeout(() => {
|
|
105
|
+
ws.close();
|
|
106
|
+
reject(new Error(`WebSocket connection timeout after ${this.config.connect_timeout_ms}ms`));
|
|
107
|
+
}, this.config.connect_timeout_ms);
|
|
108
|
+
const ws = new ws_1.default(url, {
|
|
109
|
+
maxPayload: this.config.max_message_size_bytes,
|
|
110
|
+
});
|
|
111
|
+
ws.on('open', () => {
|
|
112
|
+
clearTimeout(timeout);
|
|
113
|
+
this.connections.set(connectionId, {
|
|
114
|
+
ws,
|
|
115
|
+
url,
|
|
116
|
+
createdAt: Date.now(),
|
|
117
|
+
});
|
|
118
|
+
resolve({
|
|
119
|
+
body: { connected: true, connection_id: connectionId },
|
|
120
|
+
metadata: { url },
|
|
121
|
+
});
|
|
122
|
+
});
|
|
123
|
+
ws.on('error', (err) => {
|
|
124
|
+
clearTimeout(timeout);
|
|
125
|
+
reject(new Error(`WebSocket connection failed: ${err.message}`));
|
|
126
|
+
});
|
|
127
|
+
});
|
|
128
|
+
}
|
|
129
|
+
async send(toolCall) {
|
|
130
|
+
const { connection_id, message, wait_for_response } = toolCall.args;
|
|
131
|
+
if (!connection_id || typeof connection_id !== 'string') {
|
|
132
|
+
throw new Error('Missing or invalid "connection_id" argument for ws.send');
|
|
133
|
+
}
|
|
134
|
+
if (message === undefined || message === null) {
|
|
135
|
+
throw new Error('Missing "message" argument for ws.send');
|
|
136
|
+
}
|
|
137
|
+
const conn = this.connections.get(connection_id);
|
|
138
|
+
if (!conn) {
|
|
139
|
+
throw new Error(`No connection found with id "${connection_id}"`);
|
|
140
|
+
}
|
|
141
|
+
if (conn.ws.readyState !== ws_1.default.OPEN) {
|
|
142
|
+
this.connections.delete(connection_id);
|
|
143
|
+
throw new Error(`Connection "${connection_id}" is no longer open`);
|
|
144
|
+
}
|
|
145
|
+
const data = typeof message === 'string' ? message : JSON.stringify(message);
|
|
146
|
+
if (Buffer.byteLength(data) > this.config.max_message_size_bytes) {
|
|
147
|
+
throw new Error(`Message size exceeds max allowed ${this.config.max_message_size_bytes} bytes`);
|
|
148
|
+
}
|
|
149
|
+
return new Promise((resolve, reject) => {
|
|
150
|
+
if (wait_for_response) {
|
|
151
|
+
const responseTimeout = setTimeout(() => {
|
|
152
|
+
conn.ws.removeAllListeners('message');
|
|
153
|
+
resolve({
|
|
154
|
+
body: null,
|
|
155
|
+
metadata: { connection_id, timeout: true },
|
|
156
|
+
});
|
|
157
|
+
}, this.config.connect_timeout_ms);
|
|
158
|
+
conn.ws.once('message', (responseData) => {
|
|
159
|
+
clearTimeout(responseTimeout);
|
|
160
|
+
resolve({
|
|
161
|
+
body: responseData.toString(),
|
|
162
|
+
metadata: { connection_id },
|
|
163
|
+
});
|
|
164
|
+
});
|
|
165
|
+
}
|
|
166
|
+
conn.ws.send(data, (err) => {
|
|
167
|
+
if (err) {
|
|
168
|
+
reject(new Error(`Failed to send message: ${err.message}`));
|
|
169
|
+
return;
|
|
170
|
+
}
|
|
171
|
+
if (!wait_for_response) {
|
|
172
|
+
resolve({
|
|
173
|
+
body: { sent: true },
|
|
174
|
+
metadata: { connection_id },
|
|
175
|
+
});
|
|
176
|
+
}
|
|
177
|
+
});
|
|
178
|
+
});
|
|
179
|
+
}
|
|
180
|
+
async wsClose(toolCall) {
|
|
181
|
+
const { connection_id } = toolCall.args;
|
|
182
|
+
if (!connection_id || typeof connection_id !== 'string') {
|
|
183
|
+
throw new Error('Missing or invalid "connection_id" argument for ws.close');
|
|
184
|
+
}
|
|
185
|
+
const conn = this.connections.get(connection_id);
|
|
186
|
+
if (!conn) {
|
|
187
|
+
throw new Error(`No connection found with id "${connection_id}"`);
|
|
188
|
+
}
|
|
189
|
+
conn.ws.close();
|
|
190
|
+
this.connections.delete(connection_id);
|
|
191
|
+
return {
|
|
192
|
+
body: { closed: true },
|
|
193
|
+
metadata: { connection_id },
|
|
194
|
+
};
|
|
195
|
+
}
|
|
196
|
+
/** Close all managed connections. */
|
|
197
|
+
async closeAll() {
|
|
198
|
+
for (const [id, conn] of this.connections) {
|
|
199
|
+
conn.ws.close();
|
|
200
|
+
this.connections.delete(id);
|
|
201
|
+
}
|
|
202
|
+
}
|
|
203
|
+
}
|
|
204
|
+
exports.WebSocketExecutor = WebSocketExecutor;
|
|
205
|
+
//# sourceMappingURL=websocket-executor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"websocket-executor.js","sourceRoot":"","sources":["../../../src/executor/websocket-executor.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/interceptor/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ProviderInterceptor = void 0;
|
|
4
|
+
var provider_interceptor_1 = require("./provider-interceptor");
|
|
5
|
+
Object.defineProperty(exports, "ProviderInterceptor", { enumerable: true, get: function () { return provider_interceptor_1.ProviderInterceptor; } });
|
|
6
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/interceptor/index.ts"],"names":[],"mappings":";;;AAAA,+DAAgF;AAAvE,2HAAA,mBAAmB,OAAA"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { ProviderInterceptConfig } from '../types/config';
|
|
2
|
+
export interface ProviderToolBlock {
|
|
3
|
+
provider: 'claude' | 'openai' | 'gemini' | 'unknown';
|
|
4
|
+
tool_name: string;
|
|
5
|
+
tool_type: string;
|
|
6
|
+
inputs: Record<string, unknown>;
|
|
7
|
+
outputs?: unknown;
|
|
8
|
+
block_index: number;
|
|
9
|
+
}
|
|
10
|
+
type Provider = ProviderToolBlock['provider'];
|
|
11
|
+
export declare class ProviderInterceptor {
|
|
12
|
+
private urlPatterns;
|
|
13
|
+
private scanInputs;
|
|
14
|
+
private scanOutputs;
|
|
15
|
+
constructor(config: ProviderInterceptConfig);
|
|
16
|
+
/** Check if a URL matches any provider pattern */
|
|
17
|
+
matchesProvider(url: string): boolean;
|
|
18
|
+
/** Detect which provider a URL belongs to */
|
|
19
|
+
detectProvider(url: string): Provider;
|
|
20
|
+
/** Extract tool blocks from a request body (pre-execution) */
|
|
21
|
+
extractFromRequest(body: unknown, provider: string): ProviderToolBlock[];
|
|
22
|
+
/** Extract tool blocks from a response body (post-execution) */
|
|
23
|
+
extractFromResponse(body: unknown, provider: string): ProviderToolBlock[];
|
|
24
|
+
/** Get all inputs as a flat object for DLP scanning */
|
|
25
|
+
flattenInputsForDLP(blocks: ProviderToolBlock[]): Record<string, unknown>;
|
|
26
|
+
/** Get all outputs as a flat object for DLP scanning */
|
|
27
|
+
flattenOutputsForDLP(blocks: ProviderToolBlock[]): Record<string, unknown>;
|
|
28
|
+
private extractClaudeRequest;
|
|
29
|
+
private extractClaudeResponse;
|
|
30
|
+
private extractOpenAIRequest;
|
|
31
|
+
private extractOpenAIResponse;
|
|
32
|
+
private extractGeminiRequest;
|
|
33
|
+
private extractGeminiResponse;
|
|
34
|
+
}
|
|
35
|
+
export {};
|
|
36
|
+
//# sourceMappingURL=provider-interceptor.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"provider-interceptor.d.ts","sourceRoot":"","sources":["../../../src/interceptor/provider-interceptor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,MAAM,iBAAiB,CAAC;AAE1D,MAAM,WAAW,iBAAiB;IAChC,QAAQ,EAAE,QAAQ,GAAG,QAAQ,GAAG,QAAQ,GAAG,SAAS,CAAC;IACrD,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAChC,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,WAAW,EAAE,MAAM,CAAC;CACrB;AAED,KAAK,QAAQ,GAAG,iBAAiB,CAAC,UAAU,CAAC,CAAC;AAyB9C,qBAAa,mBAAmB;IAC9B,OAAO,CAAC,WAAW,CAAW;IAC9B,OAAO,CAAC,UAAU,CAAU;IAC5B,OAAO,CAAC,WAAW,CAAU;gBAEjB,MAAM,EAAE,uBAAuB;IAS3C,kDAAkD;IAClD,eAAe,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;IAIrC,6CAA6C;IAC7C,cAAc,CAAC,GAAG,EAAE,MAAM,GAAG,QAAQ;IAOrC,8DAA8D;IAC9D,kBAAkB,CAAC,IAAI,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,GAAG,iBAAiB,EAAE;IAcxE,gEAAgE;IAChE,mBAAmB,CAAC,IAAI,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,GAAG,iBAAiB,EAAE;IAczE,uDAAuD;IACvD,mBAAmB,CAAC,MAAM,EAAE,iBAAiB,EAAE,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;IAUzE,wDAAwD;IACxD,oBAAoB,CAAC,MAAM,EAAE,iBAAiB,EAAE,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;IAY1E,OAAO,CAAC,oBAAoB;IAkC5B,OAAO,CAAC,qBAAqB;IAsB7B,OAAO,CAAC,oBAAoB;IAwB5B,OAAO,CAAC,qBAAqB;IA6B7B,OAAO,CAAC,oBAAoB;IAwB5B,OAAO,CAAC,qBAAqB;CAyB9B"}
|
|
@@ -0,0 +1,302 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ProviderInterceptor = void 0;
|
|
4
|
+
const DEFAULT_URL_PATTERNS = [
|
|
5
|
+
'api\\.anthropic\\.com',
|
|
6
|
+
'api\\.openai\\.com',
|
|
7
|
+
'generativelanguage\\.googleapis\\.com',
|
|
8
|
+
];
|
|
9
|
+
const CLAUDE_TOOL_TYPES = {
|
|
10
|
+
computer_20241022: 'computer_use',
|
|
11
|
+
str_replace_editor: 'text_editor',
|
|
12
|
+
bash_20241022: 'bash',
|
|
13
|
+
};
|
|
14
|
+
const OPENAI_TOOL_TYPES = new Set([
|
|
15
|
+
'code_interpreter',
|
|
16
|
+
'file_search',
|
|
17
|
+
'web_search',
|
|
18
|
+
]);
|
|
19
|
+
const GEMINI_TOOL_TYPES = new Set([
|
|
20
|
+
'code_execution',
|
|
21
|
+
'google_search',
|
|
22
|
+
]);
|
|
23
|
+
class ProviderInterceptor {
|
|
24
|
+
constructor(config) {
|
|
25
|
+
const patterns = config.provider_url_patterns?.length
|
|
26
|
+
? config.provider_url_patterns
|
|
27
|
+
: DEFAULT_URL_PATTERNS;
|
|
28
|
+
this.urlPatterns = patterns.map((p) => new RegExp(p));
|
|
29
|
+
this.scanInputs = config.scan_inputs;
|
|
30
|
+
this.scanOutputs = config.scan_outputs;
|
|
31
|
+
}
|
|
32
|
+
/** Check if a URL matches any provider pattern */
|
|
33
|
+
matchesProvider(url) {
|
|
34
|
+
return this.urlPatterns.some((re) => re.test(url));
|
|
35
|
+
}
|
|
36
|
+
/** Detect which provider a URL belongs to */
|
|
37
|
+
detectProvider(url) {
|
|
38
|
+
if (/api\.anthropic\.com/.test(url))
|
|
39
|
+
return 'claude';
|
|
40
|
+
if (/api\.openai\.com/.test(url))
|
|
41
|
+
return 'openai';
|
|
42
|
+
if (/generativelanguage\.googleapis\.com/.test(url))
|
|
43
|
+
return 'gemini';
|
|
44
|
+
return 'unknown';
|
|
45
|
+
}
|
|
46
|
+
/** Extract tool blocks from a request body (pre-execution) */
|
|
47
|
+
extractFromRequest(body, provider) {
|
|
48
|
+
if (!this.scanInputs || !body || typeof body !== 'object')
|
|
49
|
+
return [];
|
|
50
|
+
try {
|
|
51
|
+
switch (provider) {
|
|
52
|
+
case 'claude': return this.extractClaudeRequest(body);
|
|
53
|
+
case 'openai': return this.extractOpenAIRequest(body);
|
|
54
|
+
case 'gemini': return this.extractGeminiRequest(body);
|
|
55
|
+
default: return [];
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
catch {
|
|
59
|
+
return [];
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
/** Extract tool blocks from a response body (post-execution) */
|
|
63
|
+
extractFromResponse(body, provider) {
|
|
64
|
+
if (!this.scanOutputs || !body || typeof body !== 'object')
|
|
65
|
+
return [];
|
|
66
|
+
try {
|
|
67
|
+
switch (provider) {
|
|
68
|
+
case 'claude': return this.extractClaudeResponse(body);
|
|
69
|
+
case 'openai': return this.extractOpenAIResponse(body);
|
|
70
|
+
case 'gemini': return this.extractGeminiResponse(body);
|
|
71
|
+
default: return [];
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
catch {
|
|
75
|
+
return [];
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
/** Get all inputs as a flat object for DLP scanning */
|
|
79
|
+
flattenInputsForDLP(blocks) {
|
|
80
|
+
const result = {};
|
|
81
|
+
for (const block of blocks) {
|
|
82
|
+
for (const [key, value] of Object.entries(block.inputs)) {
|
|
83
|
+
result[`${block.tool_name}.${key}`] = value;
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
return result;
|
|
87
|
+
}
|
|
88
|
+
/** Get all outputs as a flat object for DLP scanning */
|
|
89
|
+
flattenOutputsForDLP(blocks) {
|
|
90
|
+
const result = {};
|
|
91
|
+
for (const block of blocks) {
|
|
92
|
+
if (block.outputs !== undefined) {
|
|
93
|
+
result[`${block.tool_name}.output`] = block.outputs;
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
return result;
|
|
97
|
+
}
|
|
98
|
+
// --- Claude extraction ---
|
|
99
|
+
extractClaudeRequest(body) {
|
|
100
|
+
const blocks = [];
|
|
101
|
+
const messages = getArray(body, 'messages');
|
|
102
|
+
let index = 0;
|
|
103
|
+
for (const msg of messages) {
|
|
104
|
+
const content = getArray(msg, 'content');
|
|
105
|
+
for (const part of content) {
|
|
106
|
+
if (!isObject(part))
|
|
107
|
+
continue;
|
|
108
|
+
const type = getString(part, 'type');
|
|
109
|
+
if (type === 'tool_use') {
|
|
110
|
+
const name = getString(part, 'name') || 'unknown';
|
|
111
|
+
blocks.push({
|
|
112
|
+
provider: 'claude',
|
|
113
|
+
tool_name: name,
|
|
114
|
+
tool_type: resolveClaudeToolType(name),
|
|
115
|
+
inputs: isObject(part.input) ? part.input : {},
|
|
116
|
+
block_index: index++,
|
|
117
|
+
});
|
|
118
|
+
}
|
|
119
|
+
else if (type === 'tool_result') {
|
|
120
|
+
const toolUseId = getString(part, 'tool_use_id') || 'unknown';
|
|
121
|
+
blocks.push({
|
|
122
|
+
provider: 'claude',
|
|
123
|
+
tool_name: `tool_result:${toolUseId}`,
|
|
124
|
+
tool_type: 'tool_result',
|
|
125
|
+
inputs: {},
|
|
126
|
+
outputs: part.content,
|
|
127
|
+
block_index: index++,
|
|
128
|
+
});
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
return blocks;
|
|
133
|
+
}
|
|
134
|
+
extractClaudeResponse(body) {
|
|
135
|
+
const blocks = [];
|
|
136
|
+
const content = getArray(body, 'content');
|
|
137
|
+
let index = 0;
|
|
138
|
+
for (const part of content) {
|
|
139
|
+
if (!isObject(part))
|
|
140
|
+
continue;
|
|
141
|
+
if (getString(part, 'type') === 'tool_use') {
|
|
142
|
+
const name = getString(part, 'name') || 'unknown';
|
|
143
|
+
blocks.push({
|
|
144
|
+
provider: 'claude',
|
|
145
|
+
tool_name: name,
|
|
146
|
+
tool_type: resolveClaudeToolType(name),
|
|
147
|
+
inputs: isObject(part.input) ? part.input : {},
|
|
148
|
+
block_index: index++,
|
|
149
|
+
});
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
return blocks;
|
|
153
|
+
}
|
|
154
|
+
// --- OpenAI extraction ---
|
|
155
|
+
extractOpenAIRequest(body) {
|
|
156
|
+
const blocks = [];
|
|
157
|
+
const messages = getArray(body, 'messages');
|
|
158
|
+
let index = 0;
|
|
159
|
+
for (const msg of messages) {
|
|
160
|
+
const toolCalls = getArray(msg, 'tool_calls');
|
|
161
|
+
for (const tc of toolCalls) {
|
|
162
|
+
if (!isObject(tc))
|
|
163
|
+
continue;
|
|
164
|
+
const fn = isObject(tc.function) ? tc.function : null;
|
|
165
|
+
if (!fn)
|
|
166
|
+
continue;
|
|
167
|
+
const name = getString(fn, 'name') || 'unknown';
|
|
168
|
+
const args = parseJsonString(getString(fn, 'arguments'));
|
|
169
|
+
blocks.push({
|
|
170
|
+
provider: 'openai',
|
|
171
|
+
tool_name: name,
|
|
172
|
+
tool_type: resolveOpenAIToolType(name),
|
|
173
|
+
inputs: args,
|
|
174
|
+
block_index: index++,
|
|
175
|
+
});
|
|
176
|
+
}
|
|
177
|
+
}
|
|
178
|
+
return blocks;
|
|
179
|
+
}
|
|
180
|
+
extractOpenAIResponse(body) {
|
|
181
|
+
const blocks = [];
|
|
182
|
+
const choices = getArray(body, 'choices');
|
|
183
|
+
let index = 0;
|
|
184
|
+
for (const choice of choices) {
|
|
185
|
+
if (!isObject(choice))
|
|
186
|
+
continue;
|
|
187
|
+
const message = isObject(choice.message) ? choice.message : null;
|
|
188
|
+
if (!message)
|
|
189
|
+
continue;
|
|
190
|
+
const toolCalls = getArray(message, 'tool_calls');
|
|
191
|
+
for (const tc of toolCalls) {
|
|
192
|
+
if (!isObject(tc))
|
|
193
|
+
continue;
|
|
194
|
+
const fn = isObject(tc.function) ? tc.function : null;
|
|
195
|
+
if (!fn)
|
|
196
|
+
continue;
|
|
197
|
+
const name = getString(fn, 'name') || 'unknown';
|
|
198
|
+
const args = parseJsonString(getString(fn, 'arguments'));
|
|
199
|
+
blocks.push({
|
|
200
|
+
provider: 'openai',
|
|
201
|
+
tool_name: name,
|
|
202
|
+
tool_type: resolveOpenAIToolType(name),
|
|
203
|
+
inputs: args,
|
|
204
|
+
block_index: index++,
|
|
205
|
+
});
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
return blocks;
|
|
209
|
+
}
|
|
210
|
+
// --- Gemini extraction ---
|
|
211
|
+
extractGeminiRequest(body) {
|
|
212
|
+
const blocks = [];
|
|
213
|
+
const contents = getArray(body, 'contents');
|
|
214
|
+
let index = 0;
|
|
215
|
+
for (const content of contents) {
|
|
216
|
+
if (!isObject(content))
|
|
217
|
+
continue;
|
|
218
|
+
const parts = getArray(content, 'parts');
|
|
219
|
+
for (const part of parts) {
|
|
220
|
+
if (!isObject(part))
|
|
221
|
+
continue;
|
|
222
|
+
const fc = isObject(part.functionCall) ? part.functionCall : null;
|
|
223
|
+
if (!fc)
|
|
224
|
+
continue;
|
|
225
|
+
const name = getString(fc, 'name') || 'unknown';
|
|
226
|
+
blocks.push({
|
|
227
|
+
provider: 'gemini',
|
|
228
|
+
tool_name: name,
|
|
229
|
+
tool_type: resolveGeminiToolType(name),
|
|
230
|
+
inputs: isObject(fc.args) ? fc.args : {},
|
|
231
|
+
block_index: index++,
|
|
232
|
+
});
|
|
233
|
+
}
|
|
234
|
+
}
|
|
235
|
+
return blocks;
|
|
236
|
+
}
|
|
237
|
+
extractGeminiResponse(body) {
|
|
238
|
+
const blocks = [];
|
|
239
|
+
const candidates = getArray(body, 'candidates');
|
|
240
|
+
let index = 0;
|
|
241
|
+
for (const candidate of candidates) {
|
|
242
|
+
if (!isObject(candidate))
|
|
243
|
+
continue;
|
|
244
|
+
const content = isObject(candidate.content) ? candidate.content : null;
|
|
245
|
+
if (!content)
|
|
246
|
+
continue;
|
|
247
|
+
const parts = getArray(content, 'parts');
|
|
248
|
+
for (const part of parts) {
|
|
249
|
+
if (!isObject(part))
|
|
250
|
+
continue;
|
|
251
|
+
const fc = isObject(part.functionCall) ? part.functionCall : null;
|
|
252
|
+
if (!fc)
|
|
253
|
+
continue;
|
|
254
|
+
const name = getString(fc, 'name') || 'unknown';
|
|
255
|
+
blocks.push({
|
|
256
|
+
provider: 'gemini',
|
|
257
|
+
tool_name: name,
|
|
258
|
+
tool_type: resolveGeminiToolType(name),
|
|
259
|
+
inputs: isObject(fc.args) ? fc.args : {},
|
|
260
|
+
block_index: index++,
|
|
261
|
+
});
|
|
262
|
+
}
|
|
263
|
+
}
|
|
264
|
+
return blocks;
|
|
265
|
+
}
|
|
266
|
+
}
|
|
267
|
+
exports.ProviderInterceptor = ProviderInterceptor;
|
|
268
|
+
// --- Helpers ---
|
|
269
|
+
function isObject(val) {
|
|
270
|
+
return val !== null && typeof val === 'object' && !Array.isArray(val);
|
|
271
|
+
}
|
|
272
|
+
function getArray(obj, key) {
|
|
273
|
+
if (!isObject(obj))
|
|
274
|
+
return [];
|
|
275
|
+
const val = obj[key];
|
|
276
|
+
return Array.isArray(val) ? val : [];
|
|
277
|
+
}
|
|
278
|
+
function getString(obj, key) {
|
|
279
|
+
const val = obj[key];
|
|
280
|
+
return typeof val === 'string' ? val : '';
|
|
281
|
+
}
|
|
282
|
+
function parseJsonString(str) {
|
|
283
|
+
if (!str)
|
|
284
|
+
return {};
|
|
285
|
+
try {
|
|
286
|
+
const parsed = JSON.parse(str);
|
|
287
|
+
return isObject(parsed) ? parsed : {};
|
|
288
|
+
}
|
|
289
|
+
catch {
|
|
290
|
+
return {};
|
|
291
|
+
}
|
|
292
|
+
}
|
|
293
|
+
function resolveClaudeToolType(name) {
|
|
294
|
+
return CLAUDE_TOOL_TYPES[name] || 'function';
|
|
295
|
+
}
|
|
296
|
+
function resolveOpenAIToolType(name) {
|
|
297
|
+
return OPENAI_TOOL_TYPES.has(name) ? name : 'function';
|
|
298
|
+
}
|
|
299
|
+
function resolveGeminiToolType(name) {
|
|
300
|
+
return GEMINI_TOOL_TYPES.has(name) ? name : 'function';
|
|
301
|
+
}
|
|
302
|
+
//# sourceMappingURL=provider-interceptor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"provider-interceptor.js","sourceRoot":"","sources":["../../../src/interceptor/provider-interceptor.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"auth-verifier.d.ts","sourceRoot":"","sources":["../../../src/mcp/auth-verifier.ts"],"names":[],"mappings":"AASA,OAAO,EAAE,kBAAkB,EAAE,MAAM,mDAAmD,CAAC;AACvF,OAAO,EAAE,QAAQ,EAAE,MAAM,gDAAgD,CAAC;
|
|
1
|
+
{"version":3,"file":"auth-verifier.d.ts","sourceRoot":"","sources":["../../../src/mcp/auth-verifier.ts"],"names":[],"mappings":"AASA,OAAO,EAAE,kBAAkB,EAAE,MAAM,mDAAmD,CAAC;AACvF,OAAO,EAAE,QAAQ,EAAE,MAAM,gDAAgD,CAAC;AAE1E,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAExD,OAAO,EAAE,oBAAoB,EAAE,MAAM,kBAAkB,CAAC;AAExD,MAAM,WAAW,kBAAkB;IACjC,aAAa,CAAC,EAAE,oBAAoB,CAAC;IACrC,UAAU,EAAE,UAAU,CAAC;IACvB,eAAe,CAAC,EAAE,eAAe,CAAC;CACnC;AAED,qBAAa,mBAAoB,YAAW,kBAAkB;IAC5D,OAAO,CAAC,aAAa,CAAC,CAAuB;IAC7C,OAAO,CAAC,UAAU,CAAa;IAC/B,OAAO,CAAC,eAAe,CAAC,CAAkB;gBAE9B,IAAI,EAAE,kBAAkB;IAMpC;;;OAGG;IACH,OAAO,CAAC,kBAAkB;IAcpB,iBAAiB,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,QAAQ,CAAC;CAmG1D"}
|
|
@@ -43,6 +43,7 @@ exports.HybridTokenVerifier = void 0;
|
|
|
43
43
|
* `--header "Authorization: Bearer <api-key>"` usage still works.
|
|
44
44
|
*/
|
|
45
45
|
const crypto = __importStar(require("crypto"));
|
|
46
|
+
const errors_js_1 = require("@modelcontextprotocol/sdk/server/auth/errors.js");
|
|
46
47
|
const auth_1 = require("../middleware/auth");
|
|
47
48
|
class HybridTokenVerifier {
|
|
48
49
|
constructor(deps) {
|
|
@@ -83,7 +84,7 @@ class HybridTokenVerifier {
|
|
|
83
84
|
if (keyConfig.expires_at) {
|
|
84
85
|
const expiresAt = new Date(keyConfig.expires_at);
|
|
85
86
|
if (expiresAt.getTime() <= Date.now()) {
|
|
86
|
-
throw new
|
|
87
|
+
throw new errors_js_1.InvalidTokenError('API key has expired');
|
|
87
88
|
}
|
|
88
89
|
}
|
|
89
90
|
// Fire-and-forget: update last_used_at
|
|
@@ -155,7 +156,7 @@ class HybridTokenVerifier {
|
|
|
155
156
|
},
|
|
156
157
|
};
|
|
157
158
|
}
|
|
158
|
-
throw new
|
|
159
|
+
throw new errors_js_1.InvalidTokenError('Invalid access token');
|
|
159
160
|
}
|
|
160
161
|
}
|
|
161
162
|
exports.HybridTokenVerifier = HybridTokenVerifier;
|