@aion0/bastion 0.1.7
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/LICENSE +21 -0
- package/README.md +183 -0
- package/README.zh.md +468 -0
- package/config/default.yaml +73 -0
- package/dist/cli/commands/config.d.ts +3 -0
- package/dist/cli/commands/config.d.ts.map +1 -0
- package/dist/cli/commands/config.js +31 -0
- package/dist/cli/commands/config.js.map +1 -0
- package/dist/cli/commands/env.d.ts +3 -0
- package/dist/cli/commands/env.d.ts.map +1 -0
- package/dist/cli/commands/env.js +83 -0
- package/dist/cli/commands/env.js.map +1 -0
- package/dist/cli/commands/health.d.ts +3 -0
- package/dist/cli/commands/health.d.ts.map +1 -0
- package/dist/cli/commands/health.js +45 -0
- package/dist/cli/commands/health.js.map +1 -0
- package/dist/cli/commands/openclaw.d.ts +3 -0
- package/dist/cli/commands/openclaw.d.ts.map +1 -0
- package/dist/cli/commands/openclaw.js +1062 -0
- package/dist/cli/commands/openclaw.js.map +1 -0
- package/dist/cli/commands/proxy.d.ts +8 -0
- package/dist/cli/commands/proxy.d.ts.map +1 -0
- package/dist/cli/commands/proxy.js +433 -0
- package/dist/cli/commands/proxy.js.map +1 -0
- package/dist/cli/commands/start.d.ts +3 -0
- package/dist/cli/commands/start.d.ts.map +1 -0
- package/dist/cli/commands/start.js +62 -0
- package/dist/cli/commands/start.js.map +1 -0
- package/dist/cli/commands/stats.d.ts +3 -0
- package/dist/cli/commands/stats.d.ts.map +1 -0
- package/dist/cli/commands/stats.js +32 -0
- package/dist/cli/commands/stats.js.map +1 -0
- package/dist/cli/commands/stop.d.ts +3 -0
- package/dist/cli/commands/stop.d.ts.map +1 -0
- package/dist/cli/commands/stop.js +28 -0
- package/dist/cli/commands/stop.js.map +1 -0
- package/dist/cli/commands/token.d.ts +3 -0
- package/dist/cli/commands/token.d.ts.map +1 -0
- package/dist/cli/commands/token.js +32 -0
- package/dist/cli/commands/token.js.map +1 -0
- package/dist/cli/commands/trust-ca.d.ts +3 -0
- package/dist/cli/commands/trust-ca.d.ts.map +1 -0
- package/dist/cli/commands/trust-ca.js +44 -0
- package/dist/cli/commands/trust-ca.js.map +1 -0
- package/dist/cli/commands/wrap.d.ts +3 -0
- package/dist/cli/commands/wrap.d.ts.map +1 -0
- package/dist/cli/commands/wrap.js +70 -0
- package/dist/cli/commands/wrap.js.map +1 -0
- package/dist/cli/daemon.d.ts +11 -0
- package/dist/cli/daemon.d.ts.map +1 -0
- package/dist/cli/daemon.js +82 -0
- package/dist/cli/daemon.js.map +1 -0
- package/dist/cli/index.d.ts +3 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +35 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/config/index.d.ts +3 -0
- package/dist/config/index.d.ts.map +1 -0
- package/dist/config/index.js +60 -0
- package/dist/config/index.js.map +1 -0
- package/dist/config/manager.d.ts +12 -0
- package/dist/config/manager.d.ts.map +1 -0
- package/dist/config/manager.js +73 -0
- package/dist/config/manager.js.map +1 -0
- package/dist/config/paths.d.ts +10 -0
- package/dist/config/paths.d.ts.map +1 -0
- package/dist/config/paths.js +16 -0
- package/dist/config/paths.js.map +1 -0
- package/dist/config/schema.d.ts +85 -0
- package/dist/config/schema.d.ts.map +1 -0
- package/dist/config/schema.js +3 -0
- package/dist/config/schema.js.map +1 -0
- package/dist/dashboard/api-routes.d.ts +6 -0
- package/dist/dashboard/api-routes.d.ts.map +1 -0
- package/dist/dashboard/api-routes.js +671 -0
- package/dist/dashboard/api-routes.js.map +1 -0
- package/dist/dashboard/api.d.ts +4 -0
- package/dist/dashboard/api.d.ts.map +1 -0
- package/dist/dashboard/api.js +25 -0
- package/dist/dashboard/api.js.map +1 -0
- package/dist/dashboard/page.d.ts +3 -0
- package/dist/dashboard/page.d.ts.map +1 -0
- package/dist/dashboard/page.js +1622 -0
- package/dist/dashboard/page.js.map +1 -0
- package/dist/dlp/actions.d.ts +13 -0
- package/dist/dlp/actions.d.ts.map +1 -0
- package/dist/dlp/actions.js +3 -0
- package/dist/dlp/actions.js.map +1 -0
- package/dist/dlp/ai-validator.d.ts +28 -0
- package/dist/dlp/ai-validator.d.ts.map +1 -0
- package/dist/dlp/ai-validator.js +214 -0
- package/dist/dlp/ai-validator.js.map +1 -0
- package/dist/dlp/engine.d.ts +34 -0
- package/dist/dlp/engine.d.ts.map +1 -0
- package/dist/dlp/engine.js +342 -0
- package/dist/dlp/engine.js.map +1 -0
- package/dist/dlp/entropy.d.ts +22 -0
- package/dist/dlp/entropy.d.ts.map +1 -0
- package/dist/dlp/entropy.js +43 -0
- package/dist/dlp/entropy.js.map +1 -0
- package/dist/dlp/message-cache.d.ts +45 -0
- package/dist/dlp/message-cache.d.ts.map +1 -0
- package/dist/dlp/message-cache.js +251 -0
- package/dist/dlp/message-cache.js.map +1 -0
- package/dist/dlp/patterns/context-aware.d.ts +4 -0
- package/dist/dlp/patterns/context-aware.d.ts.map +1 -0
- package/dist/dlp/patterns/context-aware.js +45 -0
- package/dist/dlp/patterns/context-aware.js.map +1 -0
- package/dist/dlp/patterns/high-confidence.d.ts +4 -0
- package/dist/dlp/patterns/high-confidence.d.ts.map +1 -0
- package/dist/dlp/patterns/high-confidence.js +140 -0
- package/dist/dlp/patterns/high-confidence.js.map +1 -0
- package/dist/dlp/patterns/prompt-injection.d.ts +4 -0
- package/dist/dlp/patterns/prompt-injection.d.ts.map +1 -0
- package/dist/dlp/patterns/prompt-injection.js +244 -0
- package/dist/dlp/patterns/prompt-injection.js.map +1 -0
- package/dist/dlp/patterns/validated.d.ts +4 -0
- package/dist/dlp/patterns/validated.d.ts.map +1 -0
- package/dist/dlp/patterns/validated.js +21 -0
- package/dist/dlp/patterns/validated.js.map +1 -0
- package/dist/dlp/remote-sync.d.ts +47 -0
- package/dist/dlp/remote-sync.d.ts.map +1 -0
- package/dist/dlp/remote-sync.js +252 -0
- package/dist/dlp/remote-sync.js.map +1 -0
- package/dist/dlp/semantics.d.ts +27 -0
- package/dist/dlp/semantics.d.ts.map +1 -0
- package/dist/dlp/semantics.js +93 -0
- package/dist/dlp/semantics.js.map +1 -0
- package/dist/dlp/structure.d.ts +25 -0
- package/dist/dlp/structure.d.ts.map +1 -0
- package/dist/dlp/structure.js +86 -0
- package/dist/dlp/structure.js.map +1 -0
- package/dist/dlp/validators.d.ts +6 -0
- package/dist/dlp/validators.d.ts.map +1 -0
- package/dist/dlp/validators.js +46 -0
- package/dist/dlp/validators.js.map +1 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +200 -0
- package/dist/index.js.map +1 -0
- package/dist/license/verify.d.ts +18 -0
- package/dist/license/verify.d.ts.map +1 -0
- package/dist/license/verify.js +71 -0
- package/dist/license/verify.js.map +1 -0
- package/dist/metrics/collector.d.ts +11 -0
- package/dist/metrics/collector.d.ts.map +1 -0
- package/dist/metrics/collector.js +17 -0
- package/dist/metrics/collector.js.map +1 -0
- package/dist/metrics/dashboard.d.ts +6 -0
- package/dist/metrics/dashboard.d.ts.map +1 -0
- package/dist/metrics/dashboard.js +66 -0
- package/dist/metrics/dashboard.js.map +1 -0
- package/dist/metrics/pricing.d.ts +10 -0
- package/dist/metrics/pricing.d.ts.map +1 -0
- package/dist/metrics/pricing.js +62 -0
- package/dist/metrics/pricing.js.map +1 -0
- package/dist/optimizer/cache.d.ts +14 -0
- package/dist/optimizer/cache.d.ts.map +1 -0
- package/dist/optimizer/cache.js +58 -0
- package/dist/optimizer/cache.js.map +1 -0
- package/dist/optimizer/estimator.d.ts +6 -0
- package/dist/optimizer/estimator.d.ts.map +1 -0
- package/dist/optimizer/estimator.js +12 -0
- package/dist/optimizer/estimator.js.map +1 -0
- package/dist/optimizer/reorder.d.ts +9 -0
- package/dist/optimizer/reorder.d.ts.map +1 -0
- package/dist/optimizer/reorder.js +27 -0
- package/dist/optimizer/reorder.js.map +1 -0
- package/dist/optimizer/trimmer.d.ts +9 -0
- package/dist/optimizer/trimmer.d.ts.map +1 -0
- package/dist/optimizer/trimmer.js +47 -0
- package/dist/optimizer/trimmer.js.map +1 -0
- package/dist/plugin-api/index.d.ts +3 -0
- package/dist/plugin-api/index.d.ts.map +1 -0
- package/dist/plugin-api/index.js +6 -0
- package/dist/plugin-api/index.js.map +1 -0
- package/dist/plugin-api/types.d.ts +77 -0
- package/dist/plugin-api/types.d.ts.map +1 -0
- package/dist/plugin-api/types.js +6 -0
- package/dist/plugin-api/types.js.map +1 -0
- package/dist/plugins/adapter.d.ts +12 -0
- package/dist/plugins/adapter.d.ts.map +1 -0
- package/dist/plugins/adapter.js +116 -0
- package/dist/plugins/adapter.js.map +1 -0
- package/dist/plugins/builtin/audit-logger.d.ts +9 -0
- package/dist/plugins/builtin/audit-logger.d.ts.map +1 -0
- package/dist/plugins/builtin/audit-logger.js +53 -0
- package/dist/plugins/builtin/audit-logger.js.map +1 -0
- package/dist/plugins/builtin/dlp-scanner.d.ts +19 -0
- package/dist/plugins/builtin/dlp-scanner.d.ts.map +1 -0
- package/dist/plugins/builtin/dlp-scanner.js +284 -0
- package/dist/plugins/builtin/dlp-scanner.js.map +1 -0
- package/dist/plugins/builtin/metrics-collector.d.ts +4 -0
- package/dist/plugins/builtin/metrics-collector.d.ts.map +1 -0
- package/dist/plugins/builtin/metrics-collector.js +111 -0
- package/dist/plugins/builtin/metrics-collector.js.map +1 -0
- package/dist/plugins/builtin/token-optimizer.d.ts +10 -0
- package/dist/plugins/builtin/token-optimizer.d.ts.map +1 -0
- package/dist/plugins/builtin/token-optimizer.js +120 -0
- package/dist/plugins/builtin/token-optimizer.js.map +1 -0
- package/dist/plugins/builtin/tool-guard.d.ts +20 -0
- package/dist/plugins/builtin/tool-guard.d.ts.map +1 -0
- package/dist/plugins/builtin/tool-guard.js +259 -0
- package/dist/plugins/builtin/tool-guard.js.map +1 -0
- package/dist/plugins/context.d.ts +8 -0
- package/dist/plugins/context.d.ts.map +1 -0
- package/dist/plugins/context.js +33 -0
- package/dist/plugins/context.js.map +1 -0
- package/dist/plugins/event-bus.d.ts +9 -0
- package/dist/plugins/event-bus.d.ts.map +1 -0
- package/dist/plugins/event-bus.js +25 -0
- package/dist/plugins/event-bus.js.map +1 -0
- package/dist/plugins/index.d.ts +18 -0
- package/dist/plugins/index.d.ts.map +1 -0
- package/dist/plugins/index.js +148 -0
- package/dist/plugins/index.js.map +1 -0
- package/dist/plugins/loader.d.ts +14 -0
- package/dist/plugins/loader.d.ts.map +1 -0
- package/dist/plugins/loader.js +98 -0
- package/dist/plugins/loader.js.map +1 -0
- package/dist/plugins/types.d.ts +91 -0
- package/dist/plugins/types.d.ts.map +1 -0
- package/dist/plugins/types.js +3 -0
- package/dist/plugins/types.js.map +1 -0
- package/dist/proxy/certs.d.ts +10 -0
- package/dist/proxy/certs.d.ts.map +1 -0
- package/dist/proxy/certs.js +110 -0
- package/dist/proxy/certs.js.map +1 -0
- package/dist/proxy/connect.d.ts +11 -0
- package/dist/proxy/connect.d.ts.map +1 -0
- package/dist/proxy/connect.js +298 -0
- package/dist/proxy/connect.js.map +1 -0
- package/dist/proxy/forwarder.d.ts +14 -0
- package/dist/proxy/forwarder.d.ts.map +1 -0
- package/dist/proxy/forwarder.js +342 -0
- package/dist/proxy/forwarder.js.map +1 -0
- package/dist/proxy/passthrough.d.ts +4 -0
- package/dist/proxy/passthrough.d.ts.map +1 -0
- package/dist/proxy/passthrough.js +68 -0
- package/dist/proxy/passthrough.js.map +1 -0
- package/dist/proxy/providers/anthropic.d.ts +4 -0
- package/dist/proxy/providers/anthropic.d.ts.map +1 -0
- package/dist/proxy/providers/anthropic.js +46 -0
- package/dist/proxy/providers/anthropic.js.map +1 -0
- package/dist/proxy/providers/classify.d.ts +14 -0
- package/dist/proxy/providers/classify.d.ts.map +1 -0
- package/dist/proxy/providers/classify.js +37 -0
- package/dist/proxy/providers/classify.js.map +1 -0
- package/dist/proxy/providers/claude-web.d.ts +8 -0
- package/dist/proxy/providers/claude-web.d.ts.map +1 -0
- package/dist/proxy/providers/claude-web.js +50 -0
- package/dist/proxy/providers/claude-web.js.map +1 -0
- package/dist/proxy/providers/gemini.d.ts +4 -0
- package/dist/proxy/providers/gemini.d.ts.map +1 -0
- package/dist/proxy/providers/gemini.js +38 -0
- package/dist/proxy/providers/gemini.js.map +1 -0
- package/dist/proxy/providers/index.d.ts +27 -0
- package/dist/proxy/providers/index.d.ts.map +1 -0
- package/dist/proxy/providers/index.js +32 -0
- package/dist/proxy/providers/index.js.map +1 -0
- package/dist/proxy/providers/messaging.d.ts +2 -0
- package/dist/proxy/providers/messaging.d.ts.map +1 -0
- package/dist/proxy/providers/messaging.js +53 -0
- package/dist/proxy/providers/messaging.js.map +1 -0
- package/dist/proxy/providers/openai.d.ts +4 -0
- package/dist/proxy/providers/openai.d.ts.map +1 -0
- package/dist/proxy/providers/openai.js +38 -0
- package/dist/proxy/providers/openai.js.map +1 -0
- package/dist/proxy/providers/telegram.d.ts +8 -0
- package/dist/proxy/providers/telegram.d.ts.map +1 -0
- package/dist/proxy/providers/telegram.js +35 -0
- package/dist/proxy/providers/telegram.js.map +1 -0
- package/dist/proxy/router.d.ts +12 -0
- package/dist/proxy/router.d.ts.map +1 -0
- package/dist/proxy/router.js +26 -0
- package/dist/proxy/router.js.map +1 -0
- package/dist/proxy/safety.d.ts +13 -0
- package/dist/proxy/safety.d.ts.map +1 -0
- package/dist/proxy/safety.js +58 -0
- package/dist/proxy/safety.js.map +1 -0
- package/dist/proxy/server.d.ts +8 -0
- package/dist/proxy/server.d.ts.map +1 -0
- package/dist/proxy/server.js +126 -0
- package/dist/proxy/server.js.map +1 -0
- package/dist/proxy/streaming.d.ts +21 -0
- package/dist/proxy/streaming.d.ts.map +1 -0
- package/dist/proxy/streaming.js +70 -0
- package/dist/proxy/streaming.js.map +1 -0
- package/dist/storage/database.d.ts +6 -0
- package/dist/storage/database.d.ts.map +1 -0
- package/dist/storage/database.js +44 -0
- package/dist/storage/database.js.map +1 -0
- package/dist/storage/encryption.d.ts +11 -0
- package/dist/storage/encryption.d.ts.map +1 -0
- package/dist/storage/encryption.js +47 -0
- package/dist/storage/encryption.js.map +1 -0
- package/dist/storage/migrations.d.ts +3 -0
- package/dist/storage/migrations.d.ts.map +1 -0
- package/dist/storage/migrations.js +265 -0
- package/dist/storage/migrations.js.map +1 -0
- package/dist/storage/repositories/audit-log.d.ts +115 -0
- package/dist/storage/repositories/audit-log.d.ts.map +1 -0
- package/dist/storage/repositories/audit-log.js +586 -0
- package/dist/storage/repositories/audit-log.js.map +1 -0
- package/dist/storage/repositories/cache.d.ts +26 -0
- package/dist/storage/repositories/cache.d.ts.map +1 -0
- package/dist/storage/repositories/cache.js +44 -0
- package/dist/storage/repositories/cache.js.map +1 -0
- package/dist/storage/repositories/dlp-config-history.d.ts +17 -0
- package/dist/storage/repositories/dlp-config-history.d.ts.map +1 -0
- package/dist/storage/repositories/dlp-config-history.js +30 -0
- package/dist/storage/repositories/dlp-config-history.js.map +1 -0
- package/dist/storage/repositories/dlp-events.d.ts +35 -0
- package/dist/storage/repositories/dlp-events.d.ts.map +1 -0
- package/dist/storage/repositories/dlp-events.js +57 -0
- package/dist/storage/repositories/dlp-events.js.map +1 -0
- package/dist/storage/repositories/dlp-patterns.d.ts +70 -0
- package/dist/storage/repositories/dlp-patterns.d.ts.map +1 -0
- package/dist/storage/repositories/dlp-patterns.js +187 -0
- package/dist/storage/repositories/dlp-patterns.js.map +1 -0
- package/dist/storage/repositories/optimizer-events.d.ts +28 -0
- package/dist/storage/repositories/optimizer-events.d.ts.map +1 -0
- package/dist/storage/repositories/optimizer-events.js +49 -0
- package/dist/storage/repositories/optimizer-events.js.map +1 -0
- package/dist/storage/repositories/plugin-events.d.ts +34 -0
- package/dist/storage/repositories/plugin-events.d.ts.map +1 -0
- package/dist/storage/repositories/plugin-events.js +64 -0
- package/dist/storage/repositories/plugin-events.js.map +1 -0
- package/dist/storage/repositories/requests.d.ts +68 -0
- package/dist/storage/repositories/requests.d.ts.map +1 -0
- package/dist/storage/repositories/requests.js +113 -0
- package/dist/storage/repositories/requests.js.map +1 -0
- package/dist/storage/repositories/sessions.d.ts +23 -0
- package/dist/storage/repositories/sessions.d.ts.map +1 -0
- package/dist/storage/repositories/sessions.js +42 -0
- package/dist/storage/repositories/sessions.js.map +1 -0
- package/dist/storage/repositories/tool-calls.d.ts +49 -0
- package/dist/storage/repositories/tool-calls.d.ts.map +1 -0
- package/dist/storage/repositories/tool-calls.js +61 -0
- package/dist/storage/repositories/tool-calls.js.map +1 -0
- package/dist/storage/repositories/tool-guard-rules.d.ts +50 -0
- package/dist/storage/repositories/tool-guard-rules.d.ts.map +1 -0
- package/dist/storage/repositories/tool-guard-rules.js +120 -0
- package/dist/storage/repositories/tool-guard-rules.js.map +1 -0
- package/dist/tool-guard/alert.d.ts +30 -0
- package/dist/tool-guard/alert.d.ts.map +1 -0
- package/dist/tool-guard/alert.js +113 -0
- package/dist/tool-guard/alert.js.map +1 -0
- package/dist/tool-guard/extractor.d.ts +10 -0
- package/dist/tool-guard/extractor.d.ts.map +1 -0
- package/dist/tool-guard/extractor.js +309 -0
- package/dist/tool-guard/extractor.js.map +1 -0
- package/dist/tool-guard/rules.d.ts +18 -0
- package/dist/tool-guard/rules.d.ts.map +1 -0
- package/dist/tool-guard/rules.js +255 -0
- package/dist/tool-guard/rules.js.map +1 -0
- package/dist/tool-guard/streaming-guard.d.ts +57 -0
- package/dist/tool-guard/streaming-guard.d.ts.map +1 -0
- package/dist/tool-guard/streaming-guard.js +389 -0
- package/dist/tool-guard/streaming-guard.js.map +1 -0
- package/dist/utils/hash.d.ts +2 -0
- package/dist/utils/hash.d.ts.map +1 -0
- package/dist/utils/hash.js +8 -0
- package/dist/utils/hash.js.map +1 -0
- package/dist/utils/logger.d.ts +11 -0
- package/dist/utils/logger.d.ts.map +1 -0
- package/dist/utils/logger.js +54 -0
- package/dist/utils/logger.js.map +1 -0
- package/dist/utils/timeout.d.ts +5 -0
- package/dist/utils/timeout.d.ts.map +1 -0
- package/dist/utils/timeout.js +26 -0
- package/dist/utils/timeout.js.map +1 -0
- package/dist/version.d.ts +5 -0
- package/dist/version.d.ts.map +1 -0
- package/dist/version.js +23 -0
- package/dist/version.js.map +1 -0
- package/package.json +67 -0
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import type { RuleMatch } from './rules.js';
|
|
2
|
+
export interface AlertConfig {
|
|
3
|
+
/** Minimum severity to trigger alerts: 'critical' | 'high' | 'medium' | 'low' */
|
|
4
|
+
minSeverity: string;
|
|
5
|
+
/** macOS Notification Center */
|
|
6
|
+
desktop: boolean;
|
|
7
|
+
/** Webhook URL for POST alerts (Slack, Discord, etc.) */
|
|
8
|
+
webhookUrl: string;
|
|
9
|
+
}
|
|
10
|
+
export declare function shouldAlert(severity: string, minSeverity: string): boolean;
|
|
11
|
+
export interface AlertPayload {
|
|
12
|
+
toolName: string;
|
|
13
|
+
ruleName: string;
|
|
14
|
+
ruleId: string;
|
|
15
|
+
severity: string;
|
|
16
|
+
category: string;
|
|
17
|
+
matchedText: string;
|
|
18
|
+
requestId: string;
|
|
19
|
+
sessionId?: string;
|
|
20
|
+
timestamp: string;
|
|
21
|
+
}
|
|
22
|
+
export interface AlertEntry extends AlertPayload {
|
|
23
|
+
id: string;
|
|
24
|
+
acknowledged: boolean;
|
|
25
|
+
}
|
|
26
|
+
export declare function getRecentAlerts(): AlertEntry[];
|
|
27
|
+
export declare function getUnacknowledgedCount(): number;
|
|
28
|
+
export declare function acknowledgeAlerts(): void;
|
|
29
|
+
export declare function dispatchAlert(config: AlertConfig, toolName: string, ruleMatch: RuleMatch, requestId: string, sessionId?: string): void;
|
|
30
|
+
//# sourceMappingURL=alert.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"alert.d.ts","sourceRoot":"","sources":["../../src/tool-guard/alert.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC;AAI5C,MAAM,WAAW,WAAW;IAC1B,iFAAiF;IACjF,WAAW,EAAE,MAAM,CAAC;IACpB,gCAAgC;IAChC,OAAO,EAAE,OAAO,CAAC;IACjB,yDAAyD;IACzD,UAAU,EAAE,MAAM,CAAC;CACpB;AASD,wBAAgB,WAAW,CAAC,QAAQ,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,GAAG,OAAO,CAM1E;AAED,MAAM,WAAW,YAAY;IAC3B,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;IACjB,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;IACjB,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,EAAE,MAAM,CAAC;CACnB;AA6DD,MAAM,WAAW,UAAW,SAAQ,YAAY;IAC9C,EAAE,EAAE,MAAM,CAAC;IACX,YAAY,EAAE,OAAO,CAAC;CACvB;AAKD,wBAAgB,eAAe,IAAI,UAAU,EAAE,CAE9C;AAED,wBAAgB,sBAAsB,IAAI,MAAM,CAE/C;AAED,wBAAgB,iBAAiB,IAAI,IAAI,CAExC;AAID,wBAAgB,aAAa,CAC3B,MAAM,EAAE,WAAW,EACnB,QAAQ,EAAE,MAAM,EAChB,SAAS,EAAE,SAAS,EACpB,SAAS,EAAE,MAAM,EACjB,SAAS,CAAC,EAAE,MAAM,GACjB,IAAI,CA4BN"}
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.shouldAlert = shouldAlert;
|
|
4
|
+
exports.getRecentAlerts = getRecentAlerts;
|
|
5
|
+
exports.getUnacknowledgedCount = getUnacknowledgedCount;
|
|
6
|
+
exports.acknowledgeAlerts = acknowledgeAlerts;
|
|
7
|
+
exports.dispatchAlert = dispatchAlert;
|
|
8
|
+
const node_child_process_1 = require("node:child_process");
|
|
9
|
+
const node_os_1 = require("node:os");
|
|
10
|
+
const logger_js_1 = require("../utils/logger.js");
|
|
11
|
+
const log = (0, logger_js_1.createLogger)('tool-guard-alert');
|
|
12
|
+
const SEVERITY_RANK = {
|
|
13
|
+
critical: 4,
|
|
14
|
+
high: 3,
|
|
15
|
+
medium: 2,
|
|
16
|
+
low: 1,
|
|
17
|
+
};
|
|
18
|
+
function shouldAlert(severity, minSeverity) {
|
|
19
|
+
const minRank = SEVERITY_RANK[minSeverity];
|
|
20
|
+
// Unknown minSeverity (empty string, 'none', undefined coerced to string, etc.) →
|
|
21
|
+
// treat as "never block" rather than defaulting to rank 0 which would match everything.
|
|
22
|
+
if (minRank === undefined)
|
|
23
|
+
return false;
|
|
24
|
+
return (SEVERITY_RANK[severity] ?? 0) >= minRank;
|
|
25
|
+
}
|
|
26
|
+
function buildPayload(toolName, ruleMatch, requestId, sessionId) {
|
|
27
|
+
return {
|
|
28
|
+
toolName,
|
|
29
|
+
ruleName: ruleMatch.rule.name,
|
|
30
|
+
ruleId: ruleMatch.rule.id,
|
|
31
|
+
severity: ruleMatch.rule.severity,
|
|
32
|
+
category: ruleMatch.rule.category,
|
|
33
|
+
matchedText: ruleMatch.matchedText,
|
|
34
|
+
requestId,
|
|
35
|
+
sessionId,
|
|
36
|
+
timestamp: new Date().toISOString(),
|
|
37
|
+
};
|
|
38
|
+
}
|
|
39
|
+
// ── Desktop notification (macOS) ──
|
|
40
|
+
function sendDesktopNotification(payload) {
|
|
41
|
+
if ((0, node_os_1.platform)() !== 'darwin')
|
|
42
|
+
return;
|
|
43
|
+
const title = `Bastion: ${payload.severity.toUpperCase()} tool call`;
|
|
44
|
+
const message = `${payload.toolName}: ${payload.ruleName}\\n${payload.matchedText.slice(0, 100)}`;
|
|
45
|
+
(0, node_child_process_1.execFile)('osascript', [
|
|
46
|
+
'-e',
|
|
47
|
+
`display notification "${message}" with title "${title}" sound name "Purr"`,
|
|
48
|
+
], (err) => {
|
|
49
|
+
if (err)
|
|
50
|
+
log.debug('Desktop notification failed', { error: err.message });
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
// ── Webhook ──
|
|
54
|
+
async function sendWebhook(url, payload) {
|
|
55
|
+
try {
|
|
56
|
+
const body = JSON.stringify({
|
|
57
|
+
text: `[Bastion Tool Guard] **${payload.severity.toUpperCase()}**: \`${payload.toolName}\` — ${payload.ruleName}\nMatched: \`${payload.matchedText.slice(0, 200)}\`\nRequest: ${payload.requestId}`,
|
|
58
|
+
...payload,
|
|
59
|
+
});
|
|
60
|
+
const res = await fetch(url, {
|
|
61
|
+
method: 'POST',
|
|
62
|
+
headers: { 'content-type': 'application/json' },
|
|
63
|
+
body,
|
|
64
|
+
signal: AbortSignal.timeout(5000),
|
|
65
|
+
});
|
|
66
|
+
if (!res.ok) {
|
|
67
|
+
log.debug('Webhook response not OK', { status: res.status });
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
catch (err) {
|
|
71
|
+
log.debug('Webhook send failed', { error: err.message });
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
const recentAlerts = [];
|
|
75
|
+
const MAX_ALERTS = 100;
|
|
76
|
+
function getRecentAlerts() {
|
|
77
|
+
return recentAlerts;
|
|
78
|
+
}
|
|
79
|
+
function getUnacknowledgedCount() {
|
|
80
|
+
return recentAlerts.filter(a => !a.acknowledged).length;
|
|
81
|
+
}
|
|
82
|
+
function acknowledgeAlerts() {
|
|
83
|
+
for (const a of recentAlerts)
|
|
84
|
+
a.acknowledged = true;
|
|
85
|
+
}
|
|
86
|
+
// ── Main dispatch ──
|
|
87
|
+
function dispatchAlert(config, toolName, ruleMatch, requestId, sessionId) {
|
|
88
|
+
if (!shouldAlert(ruleMatch.rule.severity, config.minSeverity))
|
|
89
|
+
return;
|
|
90
|
+
const payload = buildPayload(toolName, ruleMatch, requestId, sessionId);
|
|
91
|
+
// Always add to in-memory queue
|
|
92
|
+
recentAlerts.unshift({
|
|
93
|
+
...payload,
|
|
94
|
+
id: crypto.randomUUID(),
|
|
95
|
+
acknowledged: false,
|
|
96
|
+
});
|
|
97
|
+
if (recentAlerts.length > MAX_ALERTS)
|
|
98
|
+
recentAlerts.length = MAX_ALERTS;
|
|
99
|
+
// Desktop notification
|
|
100
|
+
if (config.desktop) {
|
|
101
|
+
sendDesktopNotification(payload);
|
|
102
|
+
}
|
|
103
|
+
// Webhook
|
|
104
|
+
if (config.webhookUrl) {
|
|
105
|
+
sendWebhook(config.webhookUrl, payload).catch(() => { });
|
|
106
|
+
}
|
|
107
|
+
log.info('Alert dispatched', {
|
|
108
|
+
severity: payload.severity,
|
|
109
|
+
toolName: payload.toolName,
|
|
110
|
+
rule: payload.ruleId,
|
|
111
|
+
});
|
|
112
|
+
}
|
|
113
|
+
//# sourceMappingURL=alert.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"alert.js","sourceRoot":"","sources":["../../src/tool-guard/alert.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export interface ExtractedToolCall {
|
|
2
|
+
toolName: string;
|
|
3
|
+
toolInput: Record<string, unknown> | string;
|
|
4
|
+
provider: 'anthropic' | 'openai' | 'gemini' | 'unknown';
|
|
5
|
+
}
|
|
6
|
+
export declare function extractToolCallsFromJSON(body: string): ExtractedToolCall[];
|
|
7
|
+
export declare function extractToolCallsFromSSE(body: string): ExtractedToolCall[];
|
|
8
|
+
export declare function extractToolCallsFromParsedEvents(events: Record<string, unknown>[]): ExtractedToolCall[];
|
|
9
|
+
export declare function extractToolCalls(body: string, isStreaming: boolean): ExtractedToolCall[];
|
|
10
|
+
//# sourceMappingURL=extractor.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"extractor.d.ts","sourceRoot":"","sources":["../../src/tool-guard/extractor.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,iBAAiB;IAChC,QAAQ,EAAE,MAAM,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,MAAM,CAAC;IAC5C,QAAQ,EAAE,WAAW,GAAG,QAAQ,GAAG,QAAQ,GAAG,SAAS,CAAC;CACzD;AAkED,wBAAgB,wBAAwB,CAAC,IAAI,EAAE,MAAM,GAAG,iBAAiB,EAAE,CA0B1E;AAwJD,wBAAgB,uBAAuB,CAAC,IAAI,EAAE,MAAM,GAAG,iBAAiB,EAAE,CAIzE;AA4BD,wBAAgB,gCAAgC,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,GAAG,iBAAiB,EAAE,CAGvG;AAID,wBAAgB,gBAAgB,CAAC,IAAI,EAAE,MAAM,EAAE,WAAW,EAAE,OAAO,GAAG,iBAAiB,EAAE,CAKxF"}
|
|
@@ -0,0 +1,309 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.extractToolCallsFromJSON = extractToolCallsFromJSON;
|
|
4
|
+
exports.extractToolCallsFromSSE = extractToolCallsFromSSE;
|
|
5
|
+
exports.extractToolCallsFromParsedEvents = extractToolCallsFromParsedEvents;
|
|
6
|
+
exports.extractToolCalls = extractToolCalls;
|
|
7
|
+
// ---------- Buffered JSON extraction ----------
|
|
8
|
+
function extractAnthropicJSON(body) {
|
|
9
|
+
const content = body.content;
|
|
10
|
+
if (!Array.isArray(content))
|
|
11
|
+
return [];
|
|
12
|
+
return content
|
|
13
|
+
.filter((b) => b?.type === 'tool_use')
|
|
14
|
+
.map((b) => ({
|
|
15
|
+
toolName: b.name ?? 'unknown',
|
|
16
|
+
toolInput: b.input ?? {},
|
|
17
|
+
provider: 'anthropic',
|
|
18
|
+
}));
|
|
19
|
+
}
|
|
20
|
+
function extractOpenAIJSON(body) {
|
|
21
|
+
const choices = body.choices;
|
|
22
|
+
if (!Array.isArray(choices))
|
|
23
|
+
return [];
|
|
24
|
+
const results = [];
|
|
25
|
+
for (const choice of choices) {
|
|
26
|
+
const msg = choice.message;
|
|
27
|
+
if (!msg)
|
|
28
|
+
continue;
|
|
29
|
+
const toolCalls = msg.tool_calls;
|
|
30
|
+
if (!Array.isArray(toolCalls))
|
|
31
|
+
continue;
|
|
32
|
+
for (const tc of toolCalls) {
|
|
33
|
+
const fn = tc.function;
|
|
34
|
+
if (!fn)
|
|
35
|
+
continue;
|
|
36
|
+
let input = {};
|
|
37
|
+
try {
|
|
38
|
+
input = JSON.parse(fn.arguments ?? '{}');
|
|
39
|
+
}
|
|
40
|
+
catch {
|
|
41
|
+
input = fn.arguments ?? '';
|
|
42
|
+
}
|
|
43
|
+
results.push({
|
|
44
|
+
toolName: fn.name ?? 'unknown',
|
|
45
|
+
toolInput: input,
|
|
46
|
+
provider: 'openai',
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
return results;
|
|
51
|
+
}
|
|
52
|
+
function extractGeminiJSON(body) {
|
|
53
|
+
const candidates = body.candidates;
|
|
54
|
+
if (!Array.isArray(candidates))
|
|
55
|
+
return [];
|
|
56
|
+
const results = [];
|
|
57
|
+
for (const candidate of candidates) {
|
|
58
|
+
const content = candidate.content;
|
|
59
|
+
if (!content)
|
|
60
|
+
continue;
|
|
61
|
+
const parts = content.parts;
|
|
62
|
+
if (!Array.isArray(parts))
|
|
63
|
+
continue;
|
|
64
|
+
for (const part of parts) {
|
|
65
|
+
const fc = part.functionCall;
|
|
66
|
+
if (!fc)
|
|
67
|
+
continue;
|
|
68
|
+
results.push({
|
|
69
|
+
toolName: fc.name ?? 'unknown',
|
|
70
|
+
toolInput: fc.args ?? {},
|
|
71
|
+
provider: 'gemini',
|
|
72
|
+
});
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
return results;
|
|
76
|
+
}
|
|
77
|
+
function extractToolCallsFromJSON(body) {
|
|
78
|
+
try {
|
|
79
|
+
const parsed = JSON.parse(body);
|
|
80
|
+
// Anthropic format: content[].type === 'tool_use'
|
|
81
|
+
if (Array.isArray(parsed.content)) {
|
|
82
|
+
const results = extractAnthropicJSON(parsed);
|
|
83
|
+
if (results.length > 0)
|
|
84
|
+
return results;
|
|
85
|
+
}
|
|
86
|
+
// OpenAI format: choices[].message.tool_calls[]
|
|
87
|
+
if (Array.isArray(parsed.choices)) {
|
|
88
|
+
const results = extractOpenAIJSON(parsed);
|
|
89
|
+
if (results.length > 0)
|
|
90
|
+
return results;
|
|
91
|
+
}
|
|
92
|
+
// Gemini format: candidates[].content.parts[].functionCall
|
|
93
|
+
if (Array.isArray(parsed.candidates)) {
|
|
94
|
+
const results = extractGeminiJSON(parsed);
|
|
95
|
+
if (results.length > 0)
|
|
96
|
+
return results;
|
|
97
|
+
}
|
|
98
|
+
return [];
|
|
99
|
+
}
|
|
100
|
+
catch {
|
|
101
|
+
return [];
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
// ---------- SSE extraction ----------
|
|
105
|
+
function parseSSEEvents(text) {
|
|
106
|
+
const events = [];
|
|
107
|
+
const lines = text.split('\n');
|
|
108
|
+
const curData = [];
|
|
109
|
+
for (const line of lines) {
|
|
110
|
+
if (line.startsWith('data: ')) {
|
|
111
|
+
curData.push(line.slice(6));
|
|
112
|
+
}
|
|
113
|
+
else if (line.trim() === '' && curData.length > 0) {
|
|
114
|
+
const raw = curData.join('\n');
|
|
115
|
+
curData.length = 0;
|
|
116
|
+
if (raw !== '[DONE]') {
|
|
117
|
+
try {
|
|
118
|
+
events.push(JSON.parse(raw));
|
|
119
|
+
}
|
|
120
|
+
catch { /* skip */ }
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
if (curData.length > 0) {
|
|
125
|
+
const raw = curData.join('\n');
|
|
126
|
+
if (raw !== '[DONE]') {
|
|
127
|
+
try {
|
|
128
|
+
events.push(JSON.parse(raw));
|
|
129
|
+
}
|
|
130
|
+
catch { /* skip */ }
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
return events;
|
|
134
|
+
}
|
|
135
|
+
function extractAnthropicSSE(events) {
|
|
136
|
+
const results = [];
|
|
137
|
+
let curToolName = '';
|
|
138
|
+
let curToolInput = '';
|
|
139
|
+
for (const d of events) {
|
|
140
|
+
if (d.type === 'content_block_start') {
|
|
141
|
+
const cb = d.content_block;
|
|
142
|
+
if (cb?.type === 'tool_use') {
|
|
143
|
+
curToolName = cb.name ?? '';
|
|
144
|
+
curToolInput = '';
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
if (d.type === 'content_block_delta') {
|
|
148
|
+
const delta = d.delta;
|
|
149
|
+
if (delta?.type === 'input_json_delta') {
|
|
150
|
+
curToolInput += delta.partial_json ?? '';
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
if (d.type === 'content_block_stop') {
|
|
154
|
+
if (curToolName) {
|
|
155
|
+
let input = curToolInput;
|
|
156
|
+
try {
|
|
157
|
+
input = JSON.parse(curToolInput);
|
|
158
|
+
}
|
|
159
|
+
catch { /* keep as string */ }
|
|
160
|
+
results.push({ toolName: curToolName, toolInput: input, provider: 'anthropic' });
|
|
161
|
+
curToolName = '';
|
|
162
|
+
curToolInput = '';
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
return results;
|
|
167
|
+
}
|
|
168
|
+
function extractOpenAISSE(events) {
|
|
169
|
+
// OpenAI streams tool calls as: choices[].delta.tool_calls[].function.{name,arguments}
|
|
170
|
+
// We need to accumulate name + arguments across chunks, keyed by tool call index
|
|
171
|
+
const toolMap = new Map();
|
|
172
|
+
for (const d of events) {
|
|
173
|
+
const choices = d.choices;
|
|
174
|
+
if (!Array.isArray(choices))
|
|
175
|
+
continue;
|
|
176
|
+
for (const choice of choices) {
|
|
177
|
+
const delta = choice.delta;
|
|
178
|
+
if (!delta)
|
|
179
|
+
continue;
|
|
180
|
+
const toolCalls = delta.tool_calls;
|
|
181
|
+
if (!Array.isArray(toolCalls))
|
|
182
|
+
continue;
|
|
183
|
+
for (const tc of toolCalls) {
|
|
184
|
+
const idx = tc.index ?? 0;
|
|
185
|
+
if (!toolMap.has(idx))
|
|
186
|
+
toolMap.set(idx, { name: '', args: '' });
|
|
187
|
+
const entry = toolMap.get(idx);
|
|
188
|
+
const fn = tc.function;
|
|
189
|
+
if (fn?.name)
|
|
190
|
+
entry.name += fn.name;
|
|
191
|
+
if (fn?.arguments)
|
|
192
|
+
entry.args += fn.arguments;
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
const results = [];
|
|
197
|
+
for (const [, entry] of toolMap) {
|
|
198
|
+
if (!entry.name)
|
|
199
|
+
continue;
|
|
200
|
+
let input = entry.args;
|
|
201
|
+
try {
|
|
202
|
+
input = JSON.parse(entry.args);
|
|
203
|
+
}
|
|
204
|
+
catch { /* keep as string */ }
|
|
205
|
+
results.push({ toolName: entry.name, toolInput: input, provider: 'openai' });
|
|
206
|
+
}
|
|
207
|
+
return results;
|
|
208
|
+
}
|
|
209
|
+
/**
|
|
210
|
+
* OpenAI Responses API SSE format (used by chatgpt.com/backend-api/codex/responses):
|
|
211
|
+
* response.output_item.added → item.type === 'function_call', item.name
|
|
212
|
+
* response.function_call_arguments.delta → delta (partial JSON)
|
|
213
|
+
* response.function_call_arguments.done → name, arguments (complete)
|
|
214
|
+
* response.output_item.done → item with complete function call
|
|
215
|
+
*/
|
|
216
|
+
function extractOpenAIResponsesSSE(events) {
|
|
217
|
+
// Strategy: use .done events as ground truth (they have complete name + arguments)
|
|
218
|
+
const results = [];
|
|
219
|
+
for (const d of events) {
|
|
220
|
+
const eventType = d.type;
|
|
221
|
+
// response.function_call_arguments.done has complete data
|
|
222
|
+
if (eventType === 'response.function_call_arguments.done') {
|
|
223
|
+
const name = d.name;
|
|
224
|
+
const args = d.arguments;
|
|
225
|
+
if (name) {
|
|
226
|
+
let input = args ?? '';
|
|
227
|
+
try {
|
|
228
|
+
input = JSON.parse(args ?? '{}');
|
|
229
|
+
}
|
|
230
|
+
catch { /* keep as string */ }
|
|
231
|
+
results.push({ toolName: name, toolInput: input, provider: 'openai' });
|
|
232
|
+
}
|
|
233
|
+
continue;
|
|
234
|
+
}
|
|
235
|
+
// Fallback: response.output_item.done with type=function_call
|
|
236
|
+
if (eventType === 'response.output_item.done') {
|
|
237
|
+
const item = d.item;
|
|
238
|
+
if (item?.type === 'function_call') {
|
|
239
|
+
const name = item.name ?? '';
|
|
240
|
+
const args = item.arguments ?? '';
|
|
241
|
+
if (name) {
|
|
242
|
+
// Check if we already captured this via function_call_arguments.done
|
|
243
|
+
const alreadyCaptured = results.some(r => r.toolName === name);
|
|
244
|
+
if (!alreadyCaptured) {
|
|
245
|
+
let input = args;
|
|
246
|
+
try {
|
|
247
|
+
input = JSON.parse(args);
|
|
248
|
+
}
|
|
249
|
+
catch { /* keep as string */ }
|
|
250
|
+
results.push({ toolName: name, toolInput: input, provider: 'openai' });
|
|
251
|
+
}
|
|
252
|
+
}
|
|
253
|
+
}
|
|
254
|
+
}
|
|
255
|
+
}
|
|
256
|
+
return results;
|
|
257
|
+
}
|
|
258
|
+
function extractGeminiSSE(events) {
|
|
259
|
+
// Each Gemini SSE event has the same candidates[] structure as the JSON response
|
|
260
|
+
const results = [];
|
|
261
|
+
for (const d of events) {
|
|
262
|
+
const extracted = extractGeminiJSON(d);
|
|
263
|
+
results.push(...extracted);
|
|
264
|
+
}
|
|
265
|
+
return results;
|
|
266
|
+
}
|
|
267
|
+
function extractToolCallsFromSSE(body) {
|
|
268
|
+
const events = parseSSEEvents(body);
|
|
269
|
+
if (events.length === 0)
|
|
270
|
+
return [];
|
|
271
|
+
return extractToolCallsFromParsedEventsInternal(events);
|
|
272
|
+
}
|
|
273
|
+
// ---------- Pre-parsed events (skip text parsing) ----------
|
|
274
|
+
/** Shared detection logic for pre-parsed events */
|
|
275
|
+
function extractToolCallsFromParsedEventsInternal(events) {
|
|
276
|
+
// Anthropic: content_block_start / message_start
|
|
277
|
+
const hasAnthropicEvents = events.some(e => e.type === 'content_block_start' || e.type === 'message_start');
|
|
278
|
+
if (hasAnthropicEvents)
|
|
279
|
+
return extractAnthropicSSE(events);
|
|
280
|
+
// OpenAI Chat Completions: choices[]
|
|
281
|
+
const hasOpenAIEvents = events.some(e => Array.isArray(e.choices));
|
|
282
|
+
if (hasOpenAIEvents)
|
|
283
|
+
return extractOpenAISSE(events);
|
|
284
|
+
// OpenAI Responses API: response.output_item.added / response.function_call_arguments.*
|
|
285
|
+
const hasResponsesEvents = events.some(e => {
|
|
286
|
+
const t = e.type;
|
|
287
|
+
return t?.startsWith('response.');
|
|
288
|
+
});
|
|
289
|
+
if (hasResponsesEvents)
|
|
290
|
+
return extractOpenAIResponsesSSE(events);
|
|
291
|
+
// Gemini: candidates[]
|
|
292
|
+
const hasGeminiEvents = events.some(e => Array.isArray(e.candidates));
|
|
293
|
+
if (hasGeminiEvents)
|
|
294
|
+
return extractGeminiSSE(events);
|
|
295
|
+
return [];
|
|
296
|
+
}
|
|
297
|
+
function extractToolCallsFromParsedEvents(events) {
|
|
298
|
+
if (events.length === 0)
|
|
299
|
+
return [];
|
|
300
|
+
return extractToolCallsFromParsedEventsInternal(events);
|
|
301
|
+
}
|
|
302
|
+
// ---------- Auto-detect ----------
|
|
303
|
+
function extractToolCalls(body, isStreaming) {
|
|
304
|
+
if (isStreaming || body.includes('data: ')) {
|
|
305
|
+
return extractToolCallsFromSSE(body);
|
|
306
|
+
}
|
|
307
|
+
return extractToolCallsFromJSON(body);
|
|
308
|
+
}
|
|
309
|
+
//# sourceMappingURL=extractor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"extractor.js","sourceRoot":"","sources":["../../src/tool-guard/extractor.ts"],"names":[],"mappings":";;AAsEA,4DA0BC;AAwJD,0DAIC;AA4BD,4EAGC;AAID,4CAKC;AA9RD,iDAAiD;AAEjD,SAAS,oBAAoB,CAAC,IAA6B;IACzD,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;IAC7B,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC;QAAE,OAAO,EAAE,CAAC;IACvC,OAAO,OAAO;SACX,MAAM,CAAC,CAAC,CAA0B,EAAE,EAAE,CAAC,CAAC,EAAE,IAAI,KAAK,UAAU,CAAC;SAC9D,GAAG,CAAC,CAAC,CAA0B,EAAE,EAAE,CAAC,CAAC;QACpC,QAAQ,EAAG,CAAC,CAAC,IAAe,IAAI,SAAS;QACzC,SAAS,EAAG,CAAC,CAAC,KAAiC,IAAI,EAAE;QACrD,QAAQ,EAAE,WAAoB;KAC/B,CAAC,CAAC,CAAC;AACR,CAAC;AAED,SAAS,iBAAiB,CAAC,IAA6B;IACtD,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;IAC7B,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC;QAAE,OAAO,EAAE,CAAC;IACvC,MAAM,OAAO,GAAwB,EAAE,CAAC;IACxC,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;QAC7B,MAAM,GAAG,GAAI,MAAkC,CAAC,OAA8C,CAAC;QAC/F,IAAI,CAAC,GAAG;YAAE,SAAS;QACnB,MAAM,SAAS,GAAG,GAAG,CAAC,UAAU,CAAC;QACjC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC;YAAE,SAAS;QACxC,KAAK,MAAM,EAAE,IAAI,SAAS,EAAE,CAAC;YAC3B,MAAM,EAAE,GAAI,EAA8B,CAAC,QAA+C,CAAC;YAC3F,IAAI,CAAC,EAAE;gBAAE,SAAS;YAClB,IAAI,KAAK,GAAqC,EAAE,CAAC;YACjD,IAAI,CAAC;gBACH,KAAK,GAAG,IAAI,CAAC,KAAK,CAAE,EAAE,CAAC,SAAoB,IAAI,IAAI,CAAC,CAAC;YACvD,CAAC;YAAC,MAAM,CAAC;gBACP,KAAK,GAAI,EAAE,CAAC,SAAoB,IAAI,EAAE,CAAC;YACzC,CAAC;YACD,OAAO,CAAC,IAAI,CAAC;gBACX,QAAQ,EAAG,EAAE,CAAC,IAAe,IAAI,SAAS;gBAC1C,SAAS,EAAE,KAAK;gBAChB,QAAQ,EAAE,QAAiB;aAC5B,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IACD,OAAO,OAAO,CAAC;AACjB,CAAC;AAED,SAAS,iBAAiB,CAAC,IAA6B;IACtD,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC;IACnC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC;QAAE,OAAO,EAAE,CAAC;IAC1C,MAAM,OAAO,GAAwB,EAAE,CAAC;IACxC,KAAK,MAAM,SAAS,IAAI,UAAU,EAAE,CAAC;QACnC,MAAM,OAAO,GAAI,SAAqC,CAAC,OAA8C,CAAC;QACtG,IAAI,CAAC,OAAO;YAAE,SAAS;QACvB,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC;QAC5B,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC;YAAE,SAAS;QACpC,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;YACzB,MAAM,EAAE,GAAI,IAAgC,CAAC,YAAmD,CAAC;YACjG,IAAI,CAAC,EAAE;gBAAE,SAAS;YAClB,OAAO,CAAC,IAAI,CAAC;gBACX,QAAQ,EAAG,EAAE,CAAC,IAAe,IAAI,SAAS;gBAC1C,SAAS,EAAG,EAAE,CAAC,IAAgC,IAAI,EAAE;gBACrD,QAAQ,EAAE,QAAiB;aAC5B,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IACD,OAAO,OAAO,CAAC;AACjB,CAAC;AAED,SAAgB,wBAAwB,CAAC,IAAY;IACnD,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAA4B,CAAC;QAE3D,kDAAkD;QAClD,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC;YAClC,MAAM,OAAO,GAAG,oBAAoB,CAAC,MAAM,CAAC,CAAC;YAC7C,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC;gBAAE,OAAO,OAAO,CAAC;QACzC,CAAC;QAED,gDAAgD;QAChD,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC;YAClC,MAAM,OAAO,GAAG,iBAAiB,CAAC,MAAM,CAAC,CAAC;YAC1C,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC;gBAAE,OAAO,OAAO,CAAC;QACzC,CAAC;QAED,2DAA2D;QAC3D,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,UAAU,CAAC,EAAE,CAAC;YACrC,MAAM,OAAO,GAAG,iBAAiB,CAAC,MAAM,CAAC,CAAC;YAC1C,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC;gBAAE,OAAO,OAAO,CAAC;QACzC,CAAC;QAED,OAAO,EAAE,CAAC;IACZ,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,EAAE,CAAC;IACZ,CAAC;AACH,CAAC;AAED,uCAAuC;AAEvC,SAAS,cAAc,CAAC,IAAY;IAClC,MAAM,MAAM,GAA8B,EAAE,CAAC;IAC7C,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IAC/B,MAAM,OAAO,GAAa,EAAE,CAAC;IAC7B,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;QACzB,IAAI,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC;YAC9B,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;QAC9B,CAAC;aAAM,IAAI,IAAI,CAAC,IAAI,EAAE,KAAK,EAAE,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACpD,MAAM,GAAG,GAAG,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAC/B,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC;YACnB,IAAI,GAAG,KAAK,QAAQ,EAAE,CAAC;gBACrB,IAAI,CAAC;oBAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC;gBAAC,CAAC;gBAAC,MAAM,CAAC,CAAC,UAAU,CAAC,CAAC;YAC5D,CAAC;QACH,CAAC;IACH,CAAC;IACD,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACvB,MAAM,GAAG,GAAG,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC/B,IAAI,GAAG,KAAK,QAAQ,EAAE,CAAC;YACrB,IAAI,CAAC;gBAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC;YAAC,CAAC;YAAC,MAAM,CAAC,CAAC,UAAU,CAAC,CAAC;QAC5D,CAAC;IACH,CAAC;IACD,OAAO,MAAM,CAAC;AAChB,CAAC;AAED,SAAS,mBAAmB,CAAC,MAAiC;IAC5D,MAAM,OAAO,GAAwB,EAAE,CAAC;IACxC,IAAI,WAAW,GAAG,EAAE,CAAC;IACrB,IAAI,YAAY,GAAG,EAAE,CAAC;IAEtB,KAAK,MAAM,CAAC,IAAI,MAAM,EAAE,CAAC;QACvB,IAAI,CAAC,CAAC,IAAI,KAAK,qBAAqB,EAAE,CAAC;YACrC,MAAM,EAAE,GAAG,CAAC,CAAC,aAAoD,CAAC;YAClE,IAAI,EAAE,EAAE,IAAI,KAAK,UAAU,EAAE,CAAC;gBAC5B,WAAW,GAAI,EAAE,CAAC,IAAe,IAAI,EAAE,CAAC;gBACxC,YAAY,GAAG,EAAE,CAAC;YACpB,CAAC;QACH,CAAC;QACD,IAAI,CAAC,CAAC,IAAI,KAAK,qBAAqB,EAAE,CAAC;YACrC,MAAM,KAAK,GAAG,CAAC,CAAC,KAA4C,CAAC;YAC7D,IAAI,KAAK,EAAE,IAAI,KAAK,kBAAkB,EAAE,CAAC;gBACvC,YAAY,IAAK,KAAK,CAAC,YAAuB,IAAI,EAAE,CAAC;YACvD,CAAC;QACH,CAAC;QACD,IAAI,CAAC,CAAC,IAAI,KAAK,oBAAoB,EAAE,CAAC;YACpC,IAAI,WAAW,EAAE,CAAC;gBAChB,IAAI,KAAK,GAAqC,YAAY,CAAC;gBAC3D,IAAI,CAAC;oBAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;gBAAC,CAAC;gBAAC,MAAM,CAAC,CAAC,oBAAoB,CAAC,CAAC;gBACxE,OAAO,CAAC,IAAI,CAAC,EAAE,QAAQ,EAAE,WAAW,EAAE,SAAS,EAAE,KAAK,EAAE,QAAQ,EAAE,WAAW,EAAE,CAAC,CAAC;gBACjF,WAAW,GAAG,EAAE,CAAC;gBACjB,YAAY,GAAG,EAAE,CAAC;YACpB,CAAC;QACH,CAAC;IACH,CAAC;IACD,OAAO,OAAO,CAAC;AACjB,CAAC;AAED,SAAS,gBAAgB,CAAC,MAAiC;IACzD,uFAAuF;IACvF,iFAAiF;IACjF,MAAM,OAAO,GAAG,IAAI,GAAG,EAA0C,CAAC;IAElE,KAAK,MAAM,CAAC,IAAI,MAAM,EAAE,CAAC;QACvB,MAAM,OAAO,GAAG,CAAC,CAAC,OAAqD,CAAC;QACxE,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC;YAAE,SAAS;QACtC,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;YAC7B,MAAM,KAAK,GAAG,MAAM,CAAC,KAA4C,CAAC;YAClE,IAAI,CAAC,KAAK;gBAAE,SAAS;YACrB,MAAM,SAAS,GAAG,KAAK,CAAC,UAAwD,CAAC;YACjF,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC;gBAAE,SAAS;YACxC,KAAK,MAAM,EAAE,IAAI,SAAS,EAAE,CAAC;gBAC3B,MAAM,GAAG,GAAI,EAAE,CAAC,KAAgB,IAAI,CAAC,CAAC;gBACtC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC;oBAAE,OAAO,CAAC,GAAG,CAAC,GAAG,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,CAAC;gBAChE,MAAM,KAAK,GAAG,OAAO,CAAC,GAAG,CAAC,GAAG,CAAE,CAAC;gBAChC,MAAM,EAAE,GAAG,EAAE,CAAC,QAA+C,CAAC;gBAC9D,IAAI,EAAE,EAAE,IAAI;oBAAE,KAAK,CAAC,IAAI,IAAI,EAAE,CAAC,IAAc,CAAC;gBAC9C,IAAI,EAAE,EAAE,SAAS;oBAAE,KAAK,CAAC,IAAI,IAAI,EAAE,CAAC,SAAmB,CAAC;YAC1D,CAAC;QACH,CAAC;IACH,CAAC;IAED,MAAM,OAAO,GAAwB,EAAE,CAAC;IACxC,KAAK,MAAM,CAAC,EAAE,KAAK,CAAC,IAAI,OAAO,EAAE,CAAC;QAChC,IAAI,CAAC,KAAK,CAAC,IAAI;YAAE,SAAS;QAC1B,IAAI,KAAK,GAAqC,KAAK,CAAC,IAAI,CAAC;QACzD,IAAI,CAAC;YAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAAC,CAAC;QAAC,MAAM,CAAC,CAAC,oBAAoB,CAAC,CAAC;QACtE,OAAO,CAAC,IAAI,CAAC,EAAE,QAAQ,EAAE,KAAK,CAAC,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC,CAAC;IAC/E,CAAC;IACD,OAAO,OAAO,CAAC;AACjB,CAAC;AAED;;;;;;GAMG;AACH,SAAS,yBAAyB,CAAC,MAAiC;IAClE,mFAAmF;IACnF,MAAM,OAAO,GAAwB,EAAE,CAAC;IAExC,KAAK,MAAM,CAAC,IAAI,MAAM,EAAE,CAAC;QACvB,MAAM,SAAS,GAAG,CAAC,CAAC,IAA0B,CAAC;QAE/C,0DAA0D;QAC1D,IAAI,SAAS,KAAK,uCAAuC,EAAE,CAAC;YAC1D,MAAM,IAAI,GAAG,CAAC,CAAC,IAA0B,CAAC;YAC1C,MAAM,IAAI,GAAG,CAAC,CAAC,SAA+B,CAAC;YAC/C,IAAI,IAAI,EAAE,CAAC;gBACT,IAAI,KAAK,GAAqC,IAAI,IAAI,EAAE,CAAC;gBACzD,IAAI,CAAC;oBAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,IAAI,IAAI,CAAC,CAAC;gBAAC,CAAC;gBAAC,MAAM,CAAC,CAAC,oBAAoB,CAAC,CAAC;gBACxE,OAAO,CAAC,IAAI,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC,CAAC;YACzE,CAAC;YACD,SAAS;QACX,CAAC;QAED,8DAA8D;QAC9D,IAAI,SAAS,KAAK,2BAA2B,EAAE,CAAC;YAC9C,MAAM,IAAI,GAAG,CAAC,CAAC,IAA2C,CAAC;YAC3D,IAAI,IAAI,EAAE,IAAI,KAAK,eAAe,EAAE,CAAC;gBACnC,MAAM,IAAI,GAAI,IAAI,CAAC,IAAe,IAAI,EAAE,CAAC;gBACzC,MAAM,IAAI,GAAI,IAAI,CAAC,SAAoB,IAAI,EAAE,CAAC;gBAC9C,IAAI,IAAI,EAAE,CAAC;oBACT,qEAAqE;oBACrE,MAAM,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,IAAI,CAAC,CAAC;oBAC/D,IAAI,CAAC,eAAe,EAAE,CAAC;wBACrB,IAAI,KAAK,GAAqC,IAAI,CAAC;wBACnD,IAAI,CAAC;4BAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;wBAAC,CAAC;wBAAC,MAAM,CAAC,CAAC,oBAAoB,CAAC,CAAC;wBAChE,OAAO,CAAC,IAAI,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC,CAAC;oBACzE,CAAC;gBACH,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;IAED,OAAO,OAAO,CAAC;AACjB,CAAC;AAED,SAAS,gBAAgB,CAAC,MAAiC;IACzD,iFAAiF;IACjF,MAAM,OAAO,GAAwB,EAAE,CAAC;IACxC,KAAK,MAAM,CAAC,IAAI,MAAM,EAAE,CAAC;QACvB,MAAM,SAAS,GAAG,iBAAiB,CAAC,CAAC,CAAC,CAAC;QACvC,OAAO,CAAC,IAAI,CAAC,GAAG,SAAS,CAAC,CAAC;IAC7B,CAAC;IACD,OAAO,OAAO,CAAC;AACjB,CAAC;AAED,SAAgB,uBAAuB,CAAC,IAAY;IAClD,MAAM,MAAM,GAAG,cAAc,CAAC,IAAI,CAAC,CAAC;IACpC,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,EAAE,CAAC;IACnC,OAAO,wCAAwC,CAAC,MAAM,CAAC,CAAC;AAC1D,CAAC;AAED,8DAA8D;AAE9D,mDAAmD;AACnD,SAAS,wCAAwC,CAAC,MAAiC;IACjF,iDAAiD;IACjD,MAAM,kBAAkB,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,qBAAqB,IAAI,CAAC,CAAC,IAAI,KAAK,eAAe,CAAC,CAAC;IAC5G,IAAI,kBAAkB;QAAE,OAAO,mBAAmB,CAAC,MAAM,CAAC,CAAC;IAE3D,qCAAqC;IACrC,MAAM,eAAe,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,OAAO,CAAE,CAA6B,CAAC,OAAO,CAAC,CAAC,CAAC;IAChG,IAAI,eAAe;QAAE,OAAO,gBAAgB,CAAC,MAAM,CAAC,CAAC;IAErD,wFAAwF;IACxF,MAAM,kBAAkB,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE;QACzC,MAAM,CAAC,GAAG,CAAC,CAAC,IAA0B,CAAC;QACvC,OAAO,CAAC,EAAE,UAAU,CAAC,WAAW,CAAC,CAAC;IACpC,CAAC,CAAC,CAAC;IACH,IAAI,kBAAkB;QAAE,OAAO,yBAAyB,CAAC,MAAM,CAAC,CAAC;IAEjE,uBAAuB;IACvB,MAAM,eAAe,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,OAAO,CAAE,CAA6B,CAAC,UAAU,CAAC,CAAC,CAAC;IACnG,IAAI,eAAe;QAAE,OAAO,gBAAgB,CAAC,MAAM,CAAC,CAAC;IAErD,OAAO,EAAE,CAAC;AACZ,CAAC;AAED,SAAgB,gCAAgC,CAAC,MAAiC;IAChF,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,EAAE,CAAC;IACnC,OAAO,wCAAwC,CAAC,MAAM,CAAC,CAAC;AAC1D,CAAC;AAED,oCAAoC;AAEpC,SAAgB,gBAAgB,CAAC,IAAY,EAAE,WAAoB;IACjE,IAAI,WAAW,IAAI,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,CAAC;QAC3C,OAAO,uBAAuB,CAAC,IAAI,CAAC,CAAC;IACvC,CAAC;IACD,OAAO,wBAAwB,CAAC,IAAI,CAAC,CAAC;AACxC,CAAC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
export interface ToolGuardRule {
|
|
2
|
+
id: string;
|
|
3
|
+
name: string;
|
|
4
|
+
description: string;
|
|
5
|
+
severity: 'critical' | 'high' | 'medium' | 'low';
|
|
6
|
+
category: string;
|
|
7
|
+
match: {
|
|
8
|
+
toolName?: RegExp;
|
|
9
|
+
inputPattern?: RegExp;
|
|
10
|
+
};
|
|
11
|
+
}
|
|
12
|
+
export declare const BUILTIN_RULES: ToolGuardRule[];
|
|
13
|
+
export interface RuleMatch {
|
|
14
|
+
rule: ToolGuardRule;
|
|
15
|
+
matchedText: string;
|
|
16
|
+
}
|
|
17
|
+
export declare function matchRules(toolName: string, toolInput: Record<string, unknown> | string, rules?: ToolGuardRule[]): RuleMatch | null;
|
|
18
|
+
//# sourceMappingURL=rules.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rules.d.ts","sourceRoot":"","sources":["../../src/tool-guard/rules.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,aAAa;IAC5B,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,EAAE,UAAU,GAAG,MAAM,GAAG,QAAQ,GAAG,KAAK,CAAC;IACjD,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,EAAE;QACL,QAAQ,CAAC,EAAE,MAAM,CAAC;QAClB,YAAY,CAAC,EAAE,MAAM,CAAC;KACvB,CAAC;CACH;AAeD,eAAO,MAAM,aAAa,EAAE,aAAa,EAqOxC,CAAC;AAEF,MAAM,WAAW,SAAS;IACxB,IAAI,EAAE,aAAa,CAAC;IACpB,WAAW,EAAE,MAAM,CAAC;CACrB;AAED,wBAAgB,UAAU,CACxB,QAAQ,EAAE,MAAM,EAChB,SAAS,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,MAAM,EAC3C,KAAK,GAAE,aAAa,EAAkB,GACrC,SAAS,GAAG,IAAI,CAiBlB"}
|