@congzhen/changewayguard 6.8.12
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 +270 -0
- package/dashboard-dist/api/104.index.js +1420 -0
- package/dashboard-dist/api/104.index.js.map +1 -0
- package/dashboard-dist/api/113.index.js +496 -0
- package/dashboard-dist/api/113.index.js.map +1 -0
- package/dashboard-dist/api/18.index.js +67 -0
- package/dashboard-dist/api/18.index.js.map +1 -0
- package/dashboard-dist/api/217.index.js +44 -0
- package/dashboard-dist/api/217.index.js.map +1 -0
- package/dashboard-dist/api/222.index.js +90 -0
- package/dashboard-dist/api/222.index.js.map +1 -0
- package/dashboard-dist/api/25.index.js +3562 -0
- package/dashboard-dist/api/25.index.js.map +1 -0
- package/dashboard-dist/api/280.index.js +206 -0
- package/dashboard-dist/api/280.index.js.map +1 -0
- package/dashboard-dist/api/369.index.js +115 -0
- package/dashboard-dist/api/369.index.js.map +1 -0
- package/dashboard-dist/api/377.index.js +1176 -0
- package/dashboard-dist/api/377.index.js.map +1 -0
- package/dashboard-dist/api/411.index.js +4250 -0
- package/dashboard-dist/api/411.index.js.map +1 -0
- package/dashboard-dist/api/424.index.js +135 -0
- package/dashboard-dist/api/424.index.js.map +1 -0
- package/dashboard-dist/api/573.index.js +806 -0
- package/dashboard-dist/api/573.index.js.map +1 -0
- package/dashboard-dist/api/598.index.js +328 -0
- package/dashboard-dist/api/598.index.js.map +1 -0
- package/dashboard-dist/api/62.index.js +4151 -0
- package/dashboard-dist/api/62.index.js.map +1 -0
- package/dashboard-dist/api/67.index.js +23383 -0
- package/dashboard-dist/api/67.index.js.map +1 -0
- package/dashboard-dist/api/678.index.js +2734 -0
- package/dashboard-dist/api/678.index.js.map +1 -0
- package/dashboard-dist/api/698.index.js +1896 -0
- package/dashboard-dist/api/698.index.js.map +1 -0
- package/dashboard-dist/api/720.index.js +98 -0
- package/dashboard-dist/api/720.index.js.map +1 -0
- package/dashboard-dist/api/830.index.js +95 -0
- package/dashboard-dist/api/830.index.js.map +1 -0
- package/dashboard-dist/api/831.index.js +99 -0
- package/dashboard-dist/api/831.index.js.map +1 -0
- package/dashboard-dist/api/84.index.js +64 -0
- package/dashboard-dist/api/84.index.js.map +1 -0
- package/dashboard-dist/api/900.index.js +65 -0
- package/dashboard-dist/api/900.index.js.map +1 -0
- package/dashboard-dist/api/917.index.js +88 -0
- package/dashboard-dist/api/917.index.js.map +1 -0
- package/dashboard-dist/api/948.index.js +64 -0
- package/dashboard-dist/api/948.index.js.map +1 -0
- package/dashboard-dist/api/953.index.js +67 -0
- package/dashboard-dist/api/953.index.js.map +1 -0
- package/dashboard-dist/api/975.index.js +374 -0
- package/dashboard-dist/api/975.index.js.map +1 -0
- package/dashboard-dist/api/drizzle/sqlite/0000_short_captain_stacy.sql +70 -0
- package/dashboard-dist/api/drizzle/sqlite/0001_closed_magus.sql +10 -0
- package/dashboard-dist/api/drizzle/sqlite/0002_agent_capability_observation.sql +38 -0
- package/dashboard-dist/api/drizzle/sqlite/0003_auth_magic_link.sql +28 -0
- package/dashboard-dist/api/drizzle/sqlite/0004_static_scan_fields.sql +8 -0
- package/dashboard-dist/api/drizzle/sqlite/0005_gateway_activity.sql +24 -0
- package/dashboard-dist/api/drizzle/sqlite/0006_sour_marauders.sql +41 -0
- package/dashboard-dist/api/drizzle/sqlite/meta/0000_snapshot.json +460 -0
- package/dashboard-dist/api/drizzle/sqlite/meta/0001_snapshot.json +536 -0
- package/dashboard-dist/api/drizzle/sqlite/meta/0006_snapshot.json +1249 -0
- package/dashboard-dist/api/drizzle/sqlite/meta/_journal.json +55 -0
- package/dashboard-dist/api/index.js +27340 -0
- package/dashboard-dist/api/index.js.map +1 -0
- package/dashboard-dist/api/package.json +16 -0
- package/dashboard-dist/api/sourcemap-register.cjs +1 -0
- package/dashboard-dist/web/assets/index-CqWIeBTD.js +158 -0
- package/dashboard-dist/web/assets/index-Dw7--9q4.css +1 -0
- package/dashboard-dist/web/changeway-logo.png +0 -0
- package/dashboard-dist/web/favicon.svg +29 -0
- package/dashboard-dist/web/index.html +14 -0
- package/dashboard-dist/web/logo.svg +16 -0
- package/dist/agent/auth.d.ts +37 -0
- package/dist/agent/auth.d.ts.map +1 -0
- package/dist/agent/auth.js +151 -0
- package/dist/agent/auth.js.map +1 -0
- package/dist/agent/behavior-detector.d.ts +150 -0
- package/dist/agent/behavior-detector.d.ts.map +1 -0
- package/dist/agent/behavior-detector.js +573 -0
- package/dist/agent/behavior-detector.js.map +1 -0
- package/dist/agent/business-reporter.d.ts +114 -0
- package/dist/agent/business-reporter.d.ts.map +1 -0
- package/dist/agent/business-reporter.js +359 -0
- package/dist/agent/business-reporter.js.map +1 -0
- package/dist/agent/config-sync.d.ts +70 -0
- package/dist/agent/config-sync.d.ts.map +1 -0
- package/dist/agent/config-sync.js +133 -0
- package/dist/agent/config-sync.js.map +1 -0
- package/dist/agent/config.d.ts +97 -0
- package/dist/agent/config.d.ts.map +1 -0
- package/dist/agent/config.js +359 -0
- package/dist/agent/config.js.map +1 -0
- package/dist/agent/content-injection-scanner.d.ts +35 -0
- package/dist/agent/content-injection-scanner.d.ts.map +1 -0
- package/dist/agent/content-injection-scanner.js +270 -0
- package/dist/agent/content-injection-scanner.js.map +1 -0
- package/dist/agent/engine-log-writer.d.ts +6 -0
- package/dist/agent/engine-log-writer.d.ts.map +1 -0
- package/dist/agent/engine-log-writer.js +18 -0
- package/dist/agent/engine-log-writer.js.map +1 -0
- package/dist/agent/env.d.ts +19 -0
- package/dist/agent/env.d.ts.map +1 -0
- package/dist/agent/env.js +43 -0
- package/dist/agent/env.js.map +1 -0
- package/dist/agent/event-reporter.d.ts +87 -0
- package/dist/agent/event-reporter.d.ts.map +1 -0
- package/dist/agent/event-reporter.js +315 -0
- package/dist/agent/event-reporter.js.map +1 -0
- package/dist/agent/file-watcher.d.ts +50 -0
- package/dist/agent/file-watcher.d.ts.map +1 -0
- package/dist/agent/file-watcher.js +135 -0
- package/dist/agent/file-watcher.js.map +1 -0
- package/dist/agent/fs-utils.d.ts +22 -0
- package/dist/agent/fs-utils.d.ts.map +1 -0
- package/dist/agent/fs-utils.js +41 -0
- package/dist/agent/fs-utils.js.map +1 -0
- package/dist/agent/gateway-manager.d.ts +59 -0
- package/dist/agent/gateway-manager.d.ts.map +1 -0
- package/dist/agent/gateway-manager.js +583 -0
- package/dist/agent/gateway-manager.js.map +1 -0
- package/dist/agent/hook-types.d.ts +276 -0
- package/dist/agent/hook-types.d.ts.map +1 -0
- package/dist/agent/hook-types.js +51 -0
- package/dist/agent/hook-types.js.map +1 -0
- package/dist/agent/index.d.ts +8 -0
- package/dist/agent/index.d.ts.map +1 -0
- package/dist/agent/index.js +8 -0
- package/dist/agent/index.js.map +1 -0
- package/dist/agent/prompt-gate.d.ts +13 -0
- package/dist/agent/prompt-gate.d.ts.map +1 -0
- package/dist/agent/prompt-gate.js +28 -0
- package/dist/agent/prompt-gate.js.map +1 -0
- package/dist/agent/prompt-input.d.ts +9 -0
- package/dist/agent/prompt-input.d.ts.map +1 -0
- package/dist/agent/prompt-input.js +158 -0
- package/dist/agent/prompt-input.js.map +1 -0
- package/dist/agent/prompt-output.d.ts +4 -0
- package/dist/agent/prompt-output.d.ts.map +1 -0
- package/dist/agent/prompt-output.js +19 -0
- package/dist/agent/prompt-output.js.map +1 -0
- package/dist/agent/runner.d.ts +23 -0
- package/dist/agent/runner.d.ts.map +1 -0
- package/dist/agent/runner.js +154 -0
- package/dist/agent/runner.js.map +1 -0
- package/dist/agent/sanitizer.d.ts +10 -0
- package/dist/agent/sanitizer.d.ts.map +1 -0
- package/dist/agent/sanitizer.js +175 -0
- package/dist/agent/sanitizer.js.map +1 -0
- package/dist/agent/scan-activity.d.ts +18 -0
- package/dist/agent/scan-activity.d.ts.map +1 -0
- package/dist/agent/scan-activity.js +32 -0
- package/dist/agent/scan-activity.js.map +1 -0
- package/dist/agent/types.d.ts +177 -0
- package/dist/agent/types.d.ts.map +1 -0
- package/dist/agent/types.js +5 -0
- package/dist/agent/types.js.map +1 -0
- package/dist/agent/workspace-scanner.d.ts +35 -0
- package/dist/agent/workspace-scanner.d.ts.map +1 -0
- package/dist/agent/workspace-scanner.js +137 -0
- package/dist/agent/workspace-scanner.js.map +1 -0
- package/dist/dashboard-launcher.d.ts +52 -0
- package/dist/dashboard-launcher.d.ts.map +1 -0
- package/dist/dashboard-launcher.js +363 -0
- package/dist/dashboard-launcher.js.map +1 -0
- package/dist/gateway/activity.d.ts +52 -0
- package/dist/gateway/activity.d.ts.map +1 -0
- package/dist/gateway/activity.js +111 -0
- package/dist/gateway/activity.js.map +1 -0
- package/dist/gateway/config.d.ts +50 -0
- package/dist/gateway/config.d.ts.map +1 -0
- package/dist/gateway/config.js +200 -0
- package/dist/gateway/config.js.map +1 -0
- package/dist/gateway/gateway/activity.d.ts +52 -0
- package/dist/gateway/gateway/activity.d.ts.map +1 -0
- package/dist/gateway/gateway/activity.js +111 -0
- package/dist/gateway/gateway/activity.js.map +1 -0
- package/dist/gateway/gateway/config.d.ts +50 -0
- package/dist/gateway/gateway/config.d.ts.map +1 -0
- package/dist/gateway/gateway/config.js +200 -0
- package/dist/gateway/gateway/config.js.map +1 -0
- package/dist/gateway/gateway/handlers/anthropic.d.ts +12 -0
- package/dist/gateway/gateway/handlers/anthropic.d.ts.map +1 -0
- package/dist/gateway/gateway/handlers/anthropic.js +254 -0
- package/dist/gateway/gateway/handlers/anthropic.js.map +1 -0
- package/dist/gateway/gateway/handlers/gemini.d.ts +12 -0
- package/dist/gateway/gateway/handlers/gemini.d.ts.map +1 -0
- package/dist/gateway/gateway/handlers/gemini.js +101 -0
- package/dist/gateway/gateway/handlers/gemini.js.map +1 -0
- package/dist/gateway/gateway/handlers/models.d.ts +4 -0
- package/dist/gateway/gateway/handlers/models.d.ts.map +1 -0
- package/dist/gateway/gateway/handlers/models.js +36 -0
- package/dist/gateway/gateway/handlers/models.js.map +1 -0
- package/dist/gateway/gateway/handlers/openai.d.ts +16 -0
- package/dist/gateway/gateway/handlers/openai.d.ts.map +1 -0
- package/dist/gateway/gateway/handlers/openai.js +254 -0
- package/dist/gateway/gateway/handlers/openai.js.map +1 -0
- package/dist/gateway/gateway/index.d.ts +27 -0
- package/dist/gateway/gateway/index.d.ts.map +1 -0
- package/dist/gateway/gateway/index.js +293 -0
- package/dist/gateway/gateway/index.js.map +1 -0
- package/dist/gateway/gateway/mapping-store.d.ts +38 -0
- package/dist/gateway/gateway/mapping-store.d.ts.map +1 -0
- package/dist/gateway/gateway/mapping-store.js +74 -0
- package/dist/gateway/gateway/mapping-store.js.map +1 -0
- package/dist/gateway/gateway/restorer.d.ts +63 -0
- package/dist/gateway/gateway/restorer.d.ts.map +1 -0
- package/dist/gateway/gateway/restorer.js +284 -0
- package/dist/gateway/gateway/restorer.js.map +1 -0
- package/dist/gateway/gateway/sanitizer.d.ts +17 -0
- package/dist/gateway/gateway/sanitizer.d.ts.map +1 -0
- package/dist/gateway/gateway/sanitizer.js +228 -0
- package/dist/gateway/gateway/sanitizer.js.map +1 -0
- package/dist/gateway/gateway/types.d.ts +53 -0
- package/dist/gateway/gateway/types.d.ts.map +1 -0
- package/dist/gateway/gateway/types.js +5 -0
- package/dist/gateway/gateway/types.js.map +1 -0
- package/dist/gateway/handlers/anthropic.d.ts +12 -0
- package/dist/gateway/handlers/anthropic.d.ts.map +1 -0
- package/dist/gateway/handlers/anthropic.js +254 -0
- package/dist/gateway/handlers/anthropic.js.map +1 -0
- package/dist/gateway/handlers/gemini.d.ts +12 -0
- package/dist/gateway/handlers/gemini.d.ts.map +1 -0
- package/dist/gateway/handlers/gemini.js +101 -0
- package/dist/gateway/handlers/gemini.js.map +1 -0
- package/dist/gateway/handlers/models.d.ts +4 -0
- package/dist/gateway/handlers/models.d.ts.map +1 -0
- package/dist/gateway/handlers/models.js +36 -0
- package/dist/gateway/handlers/models.js.map +1 -0
- package/dist/gateway/handlers/openai.d.ts +16 -0
- package/dist/gateway/handlers/openai.d.ts.map +1 -0
- package/dist/gateway/handlers/openai.js +254 -0
- package/dist/gateway/handlers/openai.js.map +1 -0
- package/dist/gateway/index.d.ts +27 -0
- package/dist/gateway/index.d.ts.map +1 -0
- package/dist/gateway/index.js +293 -0
- package/dist/gateway/index.js.map +1 -0
- package/dist/gateway/mapping-store.d.ts +38 -0
- package/dist/gateway/mapping-store.d.ts.map +1 -0
- package/dist/gateway/mapping-store.js +74 -0
- package/dist/gateway/mapping-store.js.map +1 -0
- package/dist/gateway/restorer.d.ts +63 -0
- package/dist/gateway/restorer.d.ts.map +1 -0
- package/dist/gateway/restorer.js +284 -0
- package/dist/gateway/restorer.js.map +1 -0
- package/dist/gateway/sanitizer.d.ts +17 -0
- package/dist/gateway/sanitizer.d.ts.map +1 -0
- package/dist/gateway/sanitizer.js +228 -0
- package/dist/gateway/sanitizer.js.map +1 -0
- package/dist/gateway/types.d.ts +53 -0
- package/dist/gateway/types.d.ts.map +1 -0
- package/dist/gateway/types.js +5 -0
- package/dist/gateway/types.js.map +1 -0
- package/dist/index.d.ts +19 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +2084 -0
- package/dist/index.js.map +1 -0
- package/dist/memory/index.d.ts +5 -0
- package/dist/memory/index.d.ts.map +1 -0
- package/dist/memory/index.js +5 -0
- package/dist/memory/index.js.map +1 -0
- package/dist/memory/store.d.ts +82 -0
- package/dist/memory/store.d.ts.map +1 -0
- package/dist/memory/store.js +194 -0
- package/dist/memory/store.js.map +1 -0
- package/dist/platform-client/index.d.ts +63 -0
- package/dist/platform-client/index.d.ts.map +1 -0
- package/dist/platform-client/index.js +294 -0
- package/dist/platform-client/index.js.map +1 -0
- package/dist/platform-client/types.d.ts +109 -0
- package/dist/platform-client/types.d.ts.map +1 -0
- package/dist/platform-client/types.js +3 -0
- package/dist/platform-client/types.js.map +1 -0
- package/gateway/activity.d.ts +52 -0
- package/gateway/activity.d.ts.map +1 -0
- package/gateway/activity.js +111 -0
- package/gateway/activity.js.map +1 -0
- package/gateway/config.d.ts +50 -0
- package/gateway/config.d.ts.map +1 -0
- package/gateway/config.js +200 -0
- package/gateway/config.js.map +1 -0
- package/gateway/handlers/anthropic.d.ts +12 -0
- package/gateway/handlers/anthropic.d.ts.map +1 -0
- package/gateway/handlers/anthropic.js +254 -0
- package/gateway/handlers/anthropic.js.map +1 -0
- package/gateway/handlers/gemini.d.ts +12 -0
- package/gateway/handlers/gemini.d.ts.map +1 -0
- package/gateway/handlers/gemini.js +101 -0
- package/gateway/handlers/gemini.js.map +1 -0
- package/gateway/handlers/models.d.ts +4 -0
- package/gateway/handlers/models.d.ts.map +1 -0
- package/gateway/handlers/models.js +36 -0
- package/gateway/handlers/models.js.map +1 -0
- package/gateway/handlers/openai.d.ts +16 -0
- package/gateway/handlers/openai.d.ts.map +1 -0
- package/gateway/handlers/openai.js +254 -0
- package/gateway/handlers/openai.js.map +1 -0
- package/gateway/index.d.ts +27 -0
- package/gateway/index.d.ts.map +1 -0
- package/gateway/index.js +293 -0
- package/gateway/index.js.map +1 -0
- package/gateway/mapping-store.d.ts +38 -0
- package/gateway/mapping-store.d.ts.map +1 -0
- package/gateway/mapping-store.js +74 -0
- package/gateway/mapping-store.js.map +1 -0
- package/gateway/restorer.d.ts +63 -0
- package/gateway/restorer.d.ts.map +1 -0
- package/gateway/restorer.js +284 -0
- package/gateway/restorer.js.map +1 -0
- package/gateway/sanitizer.d.ts +17 -0
- package/gateway/sanitizer.d.ts.map +1 -0
- package/gateway/sanitizer.js +228 -0
- package/gateway/sanitizer.js.map +1 -0
- package/gateway/types.d.ts +53 -0
- package/gateway/types.d.ts.map +1 -0
- package/gateway/types.js +5 -0
- package/gateway/types.js.map +1 -0
- package/openclaw.plugin.json +86 -0
- package/package.json +74 -0
- package/samples/Untitled +1 -0
- package/samples/clean-email.txt +20 -0
- package/samples/test-document.md +53 -0
- package/samples/test-email-popup.txt +44 -0
- package/samples/test-email.txt +32 -0
- package/samples/test-webpage.html +51 -0
- package/scripts/enterprise-enroll.sh +89 -0
- package/scripts/enterprise-unenroll.sh +75 -0
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Agent Runner - Multi-backend analysis
|
|
3
|
+
*
|
|
4
|
+
* Supports two detection backends:
|
|
5
|
+
* 1. Dashboard (preferred) - Routes through local/remote dashboard → core
|
|
6
|
+
* 2. OpenGuardrails API (fallback) - Direct API call
|
|
7
|
+
*
|
|
8
|
+
* Content is always sanitized locally before being sent to any API.
|
|
9
|
+
*/
|
|
10
|
+
import type { AnalysisTarget, AnalysisVerdict, Logger, OpenGuardrailsApiResponse } from "./types.js";
|
|
11
|
+
export type RunnerConfig = {
|
|
12
|
+
apiKey: string;
|
|
13
|
+
timeoutMs: number;
|
|
14
|
+
autoRegister: boolean;
|
|
15
|
+
coreUrl: string;
|
|
16
|
+
/** Dashboard URL - when set, uses dashboard for detection */
|
|
17
|
+
dashboardUrl?: string;
|
|
18
|
+
/** Dashboard session token */
|
|
19
|
+
dashboardSessionToken?: string;
|
|
20
|
+
};
|
|
21
|
+
export declare function mapApiResponseToVerdict(apiResponse: OpenGuardrailsApiResponse): AnalysisVerdict;
|
|
22
|
+
export declare function runGuardAgent(target: AnalysisTarget, config: RunnerConfig, log: Logger): Promise<AnalysisVerdict>;
|
|
23
|
+
//# sourceMappingURL=runner.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"runner.d.ts","sourceRoot":"","sources":["../../agent/runner.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,OAAO,KAAK,EACV,cAAc,EACd,eAAe,EAEf,MAAM,EACN,yBAAyB,EAC1B,MAAM,YAAY,CAAC;AASpB,MAAM,MAAM,YAAY,GAAG;IACzB,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,MAAM,CAAC;IAClB,YAAY,EAAE,OAAO,CAAC;IACtB,OAAO,EAAE,MAAM,CAAC;IAChB,6DAA6D;IAC7D,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,8BAA8B;IAC9B,qBAAqB,CAAC,EAAE,MAAM,CAAC;CAChC,CAAC;AAyFF,wBAAgB,uBAAuB,CAAC,WAAW,EAAE,yBAAyB,GAAG,eAAe,CAgB/F;AAiDD,wBAAsB,aAAa,CACjC,MAAM,EAAE,cAAc,EACtB,MAAM,EAAE,YAAY,EACpB,GAAG,EAAE,MAAM,GACV,OAAO,CAAC,eAAe,CAAC,CAuC1B"}
|
|
@@ -0,0 +1,154 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Agent Runner - Multi-backend analysis
|
|
3
|
+
*
|
|
4
|
+
* Supports two detection backends:
|
|
5
|
+
* 1. Dashboard (preferred) - Routes through local/remote dashboard → core
|
|
6
|
+
* 2. OpenGuardrails API (fallback) - Direct API call
|
|
7
|
+
*
|
|
8
|
+
* Content is always sanitized locally before being sent to any API.
|
|
9
|
+
*/
|
|
10
|
+
import { DEFAULT_CORE_URL } from "./config.js";
|
|
11
|
+
import { buildSignedAuthHeadersForUrl, withChangewayOpenPrefix } from "./auth.js";
|
|
12
|
+
import { sanitizeContent } from "./sanitizer.js";
|
|
13
|
+
async function runViaDashboard(sanitizedContent, config, log) {
|
|
14
|
+
const controller = new AbortController();
|
|
15
|
+
const timeoutId = setTimeout(() => controller.abort(), config.timeoutMs);
|
|
16
|
+
const url = withChangewayOpenPrefix(`${config.dashboardUrl}/api/detect`);
|
|
17
|
+
const requestBody = {
|
|
18
|
+
messages: [{ role: "user", content: sanitizedContent }],
|
|
19
|
+
};
|
|
20
|
+
try {
|
|
21
|
+
const headers = {
|
|
22
|
+
"Content-Type": "application/json",
|
|
23
|
+
...buildSignedAuthHeadersForUrl({
|
|
24
|
+
method: "POST",
|
|
25
|
+
url,
|
|
26
|
+
body: requestBody,
|
|
27
|
+
authorization: config.dashboardSessionToken
|
|
28
|
+
? `Bearer ${config.dashboardSessionToken}`
|
|
29
|
+
: null,
|
|
30
|
+
}),
|
|
31
|
+
};
|
|
32
|
+
const response = await fetch(url, {
|
|
33
|
+
method: "POST",
|
|
34
|
+
headers,
|
|
35
|
+
body: JSON.stringify(requestBody),
|
|
36
|
+
signal: controller.signal,
|
|
37
|
+
});
|
|
38
|
+
if (!response.ok) {
|
|
39
|
+
const text = await response.text();
|
|
40
|
+
throw new Error(`Dashboard API error: ${response.status} ${text}`);
|
|
41
|
+
}
|
|
42
|
+
const result = (await response.json());
|
|
43
|
+
if (!result.success || !result.data) {
|
|
44
|
+
throw new Error(`Dashboard error: ${result.error ?? "unknown"}`);
|
|
45
|
+
}
|
|
46
|
+
const data = result.data;
|
|
47
|
+
const findings = data.findings.map((f) => ({
|
|
48
|
+
suspiciousContent: f.name,
|
|
49
|
+
reason: f.description,
|
|
50
|
+
confidence: data.sensitivity_score,
|
|
51
|
+
}));
|
|
52
|
+
return {
|
|
53
|
+
isInjection: !data.safe,
|
|
54
|
+
confidence: data.sensitivity_score,
|
|
55
|
+
reason: data.safe ? "No issues detected" : `Detected: ${data.categories.join(", ")}`,
|
|
56
|
+
findings,
|
|
57
|
+
chunksAnalyzed: 1,
|
|
58
|
+
};
|
|
59
|
+
}
|
|
60
|
+
finally {
|
|
61
|
+
clearTimeout(timeoutId);
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
// =============================================================================
|
|
65
|
+
// OpenGuardrails API Detection (Fallback)
|
|
66
|
+
// =============================================================================
|
|
67
|
+
export function mapApiResponseToVerdict(apiResponse) {
|
|
68
|
+
const verdict = apiResponse.verdict;
|
|
69
|
+
const findings = (verdict.findings ?? []).map((f) => ({
|
|
70
|
+
suspiciousContent: f.suspiciousContent,
|
|
71
|
+
reason: f.reason,
|
|
72
|
+
confidence: f.confidence,
|
|
73
|
+
}));
|
|
74
|
+
return {
|
|
75
|
+
isInjection: verdict.isInjection,
|
|
76
|
+
confidence: verdict.confidence,
|
|
77
|
+
reason: verdict.reason,
|
|
78
|
+
findings,
|
|
79
|
+
chunksAnalyzed: 1,
|
|
80
|
+
};
|
|
81
|
+
}
|
|
82
|
+
async function runViaApi(sanitizedContent, config, _log) {
|
|
83
|
+
const baseUrl = config.coreUrl || DEFAULT_CORE_URL;
|
|
84
|
+
const url = withChangewayOpenPrefix(`${baseUrl}/api/check/tool-call`);
|
|
85
|
+
const requestBody = { content: sanitizedContent, async: false };
|
|
86
|
+
const controller = new AbortController();
|
|
87
|
+
const timeoutId = setTimeout(() => controller.abort(), config.timeoutMs);
|
|
88
|
+
try {
|
|
89
|
+
const response = await fetch(url, {
|
|
90
|
+
method: "POST",
|
|
91
|
+
headers: {
|
|
92
|
+
"Content-Type": "application/json",
|
|
93
|
+
...buildSignedAuthHeadersForUrl({
|
|
94
|
+
method: "POST",
|
|
95
|
+
url,
|
|
96
|
+
body: requestBody,
|
|
97
|
+
}),
|
|
98
|
+
},
|
|
99
|
+
body: JSON.stringify(requestBody),
|
|
100
|
+
signal: controller.signal,
|
|
101
|
+
});
|
|
102
|
+
if (!response.ok) {
|
|
103
|
+
throw new Error(`changewayGuard API error: ${response.status} ${response.statusText}`);
|
|
104
|
+
}
|
|
105
|
+
const apiResponse = (await response.json());
|
|
106
|
+
if (!apiResponse.ok) {
|
|
107
|
+
throw new Error(`changewayGuard API returned error: ${apiResponse.error ?? "unknown"}`);
|
|
108
|
+
}
|
|
109
|
+
return mapApiResponseToVerdict(apiResponse);
|
|
110
|
+
}
|
|
111
|
+
finally {
|
|
112
|
+
clearTimeout(timeoutId);
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
// =============================================================================
|
|
116
|
+
// Main Analysis Function
|
|
117
|
+
// =============================================================================
|
|
118
|
+
export async function runGuardAgent(target, config, log) {
|
|
119
|
+
const startTime = Date.now();
|
|
120
|
+
log.info(`Analyzing content: ${target.content.length} chars`);
|
|
121
|
+
// Always sanitize locally first
|
|
122
|
+
const { sanitized, redactions, totalRedactions } = sanitizeContent(target.content);
|
|
123
|
+
if (totalRedactions > 0) {
|
|
124
|
+
log.info(`Sanitized ${totalRedactions} sensitive items: ${Object.entries(redactions).map(([k, v]) => `${v} ${k}`).join(", ")}`);
|
|
125
|
+
}
|
|
126
|
+
try {
|
|
127
|
+
let verdict;
|
|
128
|
+
// Route to dashboard if configured, otherwise fall back to API
|
|
129
|
+
if (config.dashboardUrl) {
|
|
130
|
+
log.info("Using dashboard for detection");
|
|
131
|
+
verdict = await runViaDashboard(sanitized, config, log);
|
|
132
|
+
}
|
|
133
|
+
else {
|
|
134
|
+
verdict = await runViaApi(sanitized, config, log);
|
|
135
|
+
}
|
|
136
|
+
const durationMs = Date.now() - startTime;
|
|
137
|
+
log.info(`Analysis complete in ${durationMs}ms: ${verdict.isInjection ? "INJECTION DETECTED" : "SAFE"}`);
|
|
138
|
+
return verdict;
|
|
139
|
+
}
|
|
140
|
+
catch (error) {
|
|
141
|
+
if (error.name === "AbortError") {
|
|
142
|
+
log.warn("Analysis timed out");
|
|
143
|
+
return {
|
|
144
|
+
isInjection: false,
|
|
145
|
+
confidence: 0,
|
|
146
|
+
reason: "Timeout",
|
|
147
|
+
findings: [],
|
|
148
|
+
chunksAnalyzed: 0,
|
|
149
|
+
};
|
|
150
|
+
}
|
|
151
|
+
throw error;
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
//# sourceMappingURL=runner.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"runner.js","sourceRoot":"","sources":["../../agent/runner.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Local content sanitizer — strips PII and secrets before sending to API.
|
|
3
|
+
*
|
|
4
|
+
* Inspired by n8n's guardrails implementation (MIT).
|
|
5
|
+
* Replaces sensitive data with category placeholders while preserving
|
|
6
|
+
* the structure and context needed for injection detection.
|
|
7
|
+
*/
|
|
8
|
+
import type { SanitizeResult } from "./types.js";
|
|
9
|
+
export declare function sanitizeContent(content: string): SanitizeResult;
|
|
10
|
+
//# sourceMappingURL=sanitizer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sanitizer.d.ts","sourceRoot":"","sources":["../../agent/sanitizer.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AA6KjD,wBAAgB,eAAe,CAAC,OAAO,EAAE,MAAM,GAAG,cAAc,CAqC/D"}
|
|
@@ -0,0 +1,175 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Local content sanitizer — strips PII and secrets before sending to API.
|
|
3
|
+
*
|
|
4
|
+
* Inspired by n8n's guardrails implementation (MIT).
|
|
5
|
+
* Replaces sensitive data with category placeholders while preserving
|
|
6
|
+
* the structure and context needed for injection detection.
|
|
7
|
+
*/
|
|
8
|
+
const ENTITIES = [
|
|
9
|
+
// URLs (must come before email to avoid partial matches on domain parts)
|
|
10
|
+
{
|
|
11
|
+
category: "URL",
|
|
12
|
+
placeholder: "<URL>",
|
|
13
|
+
pattern: /https?:\/\/[^\s<>"{}|\\^`\[\]]+/g,
|
|
14
|
+
},
|
|
15
|
+
// Email
|
|
16
|
+
{
|
|
17
|
+
category: "EMAIL",
|
|
18
|
+
placeholder: "<EMAIL>",
|
|
19
|
+
pattern: /[A-Za-z0-9._%+\-]+@[A-Za-z0-9.\-]+\.[A-Za-z]{2,}/g,
|
|
20
|
+
},
|
|
21
|
+
// Credit Card (4 groups of 4 digits)
|
|
22
|
+
{
|
|
23
|
+
category: "CREDIT_CARD",
|
|
24
|
+
placeholder: "<CREDIT_CARD>",
|
|
25
|
+
pattern: /\b\d{4}[-\s]?\d{4}[-\s]?\d{4}[-\s]?\d{4}\b/g,
|
|
26
|
+
},
|
|
27
|
+
// SSN (###-##-####)
|
|
28
|
+
{
|
|
29
|
+
category: "SSN",
|
|
30
|
+
placeholder: "<SSN>",
|
|
31
|
+
pattern: /\b\d{3}-\d{2}-\d{4}\b/g,
|
|
32
|
+
},
|
|
33
|
+
// IBAN
|
|
34
|
+
{
|
|
35
|
+
category: "IBAN",
|
|
36
|
+
placeholder: "<IBAN>",
|
|
37
|
+
pattern: /\b[A-Z]{2}\d{2}[A-Z0-9]{4}\d{7}[A-Z0-9]{0,16}\b/g,
|
|
38
|
+
},
|
|
39
|
+
// IP Address
|
|
40
|
+
{
|
|
41
|
+
category: "IP_ADDRESS",
|
|
42
|
+
placeholder: "<IP_ADDRESS>",
|
|
43
|
+
pattern: /\b(?:[0-9]{1,3}\.){3}[0-9]{1,3}\b/g,
|
|
44
|
+
},
|
|
45
|
+
// Phone numbers (US/intl formats)
|
|
46
|
+
{
|
|
47
|
+
category: "PHONE",
|
|
48
|
+
placeholder: "<PHONE>",
|
|
49
|
+
pattern: /[+]?[(]?[0-9]{3}[)]?[-\s.][0-9]{3}[-\s.][0-9]{4,6}\b/g,
|
|
50
|
+
},
|
|
51
|
+
];
|
|
52
|
+
// Known secret prefixes
|
|
53
|
+
const SECRET_PREFIXES = [
|
|
54
|
+
"sk-",
|
|
55
|
+
"sk_",
|
|
56
|
+
"pk_",
|
|
57
|
+
"ghp_",
|
|
58
|
+
"AKIA",
|
|
59
|
+
"xox",
|
|
60
|
+
"SG.",
|
|
61
|
+
"hf_",
|
|
62
|
+
"api-",
|
|
63
|
+
"token-",
|
|
64
|
+
"secret-",
|
|
65
|
+
];
|
|
66
|
+
const BEARER_PATTERN = /Bearer\s+[A-Za-z0-9\-_.~+/]+=*/g;
|
|
67
|
+
// Secret-like tokens: known prefix followed by alphanumeric/special chars
|
|
68
|
+
const SECRET_PREFIX_PATTERN = new RegExp(`(?:${SECRET_PREFIXES.map((p) => p.replace(/[.*+?^${}()|[\]\\]/g, "\\$&")).join("|")})[A-Za-z0-9\\-_.~+/]{8,}=*`, "g");
|
|
69
|
+
// =============================================================================
|
|
70
|
+
// Shannon Entropy
|
|
71
|
+
// =============================================================================
|
|
72
|
+
function shannonEntropy(s) {
|
|
73
|
+
if (s.length === 0)
|
|
74
|
+
return 0;
|
|
75
|
+
const freq = new Map();
|
|
76
|
+
for (const ch of s) {
|
|
77
|
+
freq.set(ch, (freq.get(ch) ?? 0) + 1);
|
|
78
|
+
}
|
|
79
|
+
let entropy = 0;
|
|
80
|
+
for (const count of freq.values()) {
|
|
81
|
+
const p = count / s.length;
|
|
82
|
+
entropy -= p * Math.log2(p);
|
|
83
|
+
}
|
|
84
|
+
return entropy;
|
|
85
|
+
}
|
|
86
|
+
function collectMatches(content) {
|
|
87
|
+
const matches = [];
|
|
88
|
+
// Regex-based entities
|
|
89
|
+
for (const entity of ENTITIES) {
|
|
90
|
+
// Reset lastIndex for global regexes
|
|
91
|
+
entity.pattern.lastIndex = 0;
|
|
92
|
+
let m;
|
|
93
|
+
while ((m = entity.pattern.exec(content)) !== null) {
|
|
94
|
+
matches.push({
|
|
95
|
+
text: m[0],
|
|
96
|
+
category: entity.category,
|
|
97
|
+
placeholder: entity.placeholder,
|
|
98
|
+
});
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
// Secret prefixes
|
|
102
|
+
SECRET_PREFIX_PATTERN.lastIndex = 0;
|
|
103
|
+
let m;
|
|
104
|
+
while ((m = SECRET_PREFIX_PATTERN.exec(content)) !== null) {
|
|
105
|
+
matches.push({
|
|
106
|
+
text: m[0],
|
|
107
|
+
category: "SECRET",
|
|
108
|
+
placeholder: "<SECRET>",
|
|
109
|
+
});
|
|
110
|
+
}
|
|
111
|
+
// Bearer tokens
|
|
112
|
+
BEARER_PATTERN.lastIndex = 0;
|
|
113
|
+
while ((m = BEARER_PATTERN.exec(content)) !== null) {
|
|
114
|
+
matches.push({
|
|
115
|
+
text: m[0],
|
|
116
|
+
category: "SECRET",
|
|
117
|
+
placeholder: "<SECRET>",
|
|
118
|
+
});
|
|
119
|
+
}
|
|
120
|
+
// High-entropy tokens (catch API keys/secrets that don't have known prefixes)
|
|
121
|
+
// Look for standalone tokens that look like secrets: 20+ chars, high entropy
|
|
122
|
+
const tokenPattern = /\b[A-Za-z0-9\-_.~+/]{20,}={0,3}\b/g;
|
|
123
|
+
tokenPattern.lastIndex = 0;
|
|
124
|
+
while ((m = tokenPattern.exec(content)) !== null) {
|
|
125
|
+
const token = m[0];
|
|
126
|
+
// Skip if already matched by another pattern
|
|
127
|
+
if (matches.some((existing) => existing.text === token))
|
|
128
|
+
continue;
|
|
129
|
+
// Skip if it looks like a normal word (all lowercase alpha, no digits/special)
|
|
130
|
+
if (/^[a-z]+$/.test(token))
|
|
131
|
+
continue;
|
|
132
|
+
// High entropy threshold (typical for random keys/tokens)
|
|
133
|
+
if (shannonEntropy(token) >= 4.0) {
|
|
134
|
+
matches.push({
|
|
135
|
+
text: token,
|
|
136
|
+
category: "SECRET",
|
|
137
|
+
placeholder: "<SECRET>",
|
|
138
|
+
});
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
return matches;
|
|
142
|
+
}
|
|
143
|
+
// =============================================================================
|
|
144
|
+
// Main Sanitizer
|
|
145
|
+
// =============================================================================
|
|
146
|
+
export function sanitizeContent(content) {
|
|
147
|
+
const matches = collectMatches(content);
|
|
148
|
+
if (matches.length === 0) {
|
|
149
|
+
return { sanitized: content, redactions: {}, totalRedactions: 0 };
|
|
150
|
+
}
|
|
151
|
+
// Deduplicate matches by text
|
|
152
|
+
const unique = new Map();
|
|
153
|
+
for (const match of matches) {
|
|
154
|
+
// Keep the first match for each text (preserves priority from entity order)
|
|
155
|
+
if (!unique.has(match.text)) {
|
|
156
|
+
unique.set(match.text, match);
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
// Sort by length descending — prevents partial matches corrupting longer ones
|
|
160
|
+
const sorted = [...unique.values()].sort((a, b) => b.text.length - a.text.length);
|
|
161
|
+
// Replace using split/join — safe against regex special chars in matched text
|
|
162
|
+
let sanitized = content;
|
|
163
|
+
const redactions = {};
|
|
164
|
+
for (const match of sorted) {
|
|
165
|
+
const parts = sanitized.split(match.text);
|
|
166
|
+
const count = parts.length - 1;
|
|
167
|
+
if (count > 0) {
|
|
168
|
+
sanitized = parts.join(match.placeholder);
|
|
169
|
+
redactions[match.category] = (redactions[match.category] ?? 0) + count;
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
const totalRedactions = Object.values(redactions).reduce((a, b) => a + b, 0);
|
|
173
|
+
return { sanitized, redactions, totalRedactions };
|
|
174
|
+
}
|
|
175
|
+
//# sourceMappingURL=sanitizer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sanitizer.js","sourceRoot":"","sources":["../../agent/sanitizer.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import type { ToolCallObservationRequest } from "../platform-client/types.js";
|
|
2
|
+
type ScanSource = "prompt" | "content";
|
|
3
|
+
type ScanAction = "allow" | "alert" | "block" | string | undefined;
|
|
4
|
+
export type ScanActivityInput = {
|
|
5
|
+
source: ScanSource;
|
|
6
|
+
action: ScanAction;
|
|
7
|
+
agentId: string;
|
|
8
|
+
sessionKey?: string;
|
|
9
|
+
riskLevel?: string;
|
|
10
|
+
confidence?: number;
|
|
11
|
+
categories?: string[];
|
|
12
|
+
explanation?: string;
|
|
13
|
+
latencyMs?: number;
|
|
14
|
+
scannedToolName?: string;
|
|
15
|
+
};
|
|
16
|
+
export declare function buildScanActivityObservation(input: ScanActivityInput): ToolCallObservationRequest | null;
|
|
17
|
+
export {};
|
|
18
|
+
//# sourceMappingURL=scan-activity.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scan-activity.d.ts","sourceRoot":"","sources":["../../agent/scan-activity.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,0BAA0B,EAAE,MAAM,6BAA6B,CAAC;AAE9E,KAAK,UAAU,GAAG,QAAQ,GAAG,SAAS,CAAC;AACvC,KAAK,UAAU,GAAG,OAAO,GAAG,OAAO,GAAG,OAAO,GAAG,MAAM,GAAG,SAAS,CAAC;AAEnE,MAAM,MAAM,iBAAiB,GAAG;IAC9B,MAAM,EAAE,UAAU,CAAC;IACnB,MAAM,EAAE,UAAU,CAAC;IACnB,OAAO,EAAE,MAAM,CAAC;IAChB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,UAAU,CAAC,EAAE,MAAM,EAAE,CAAC;IACtB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,eAAe,CAAC,EAAE,MAAM,CAAC;CAC1B,CAAC;AAEF,wBAAgB,4BAA4B,CAAC,KAAK,EAAE,iBAAiB,GAAG,0BAA0B,GAAG,IAAI,CAiCxG"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
export function buildScanActivityObservation(input) {
|
|
2
|
+
if (input.action !== "block" && input.action !== "alert") {
|
|
3
|
+
return null;
|
|
4
|
+
}
|
|
5
|
+
const confidencePercent = typeof input.confidence === "number"
|
|
6
|
+
? `${Math.round(input.confidence * 100)}%`
|
|
7
|
+
: null;
|
|
8
|
+
const reasonParts = [
|
|
9
|
+
`${input.source}_scan`,
|
|
10
|
+
`action=${input.action}`,
|
|
11
|
+
input.riskLevel ? `risk=${input.riskLevel}` : null,
|
|
12
|
+
confidencePercent ? `confidence=${confidencePercent}` : null,
|
|
13
|
+
input.explanation ? `reason=${input.explanation}` : null,
|
|
14
|
+
].filter((part) => !!part);
|
|
15
|
+
return {
|
|
16
|
+
agentId: input.agentId,
|
|
17
|
+
sessionKey: input.sessionKey,
|
|
18
|
+
toolName: input.source === "prompt" ? "security_prompt_scan" : "security_content_scan",
|
|
19
|
+
params: {
|
|
20
|
+
source: input.source,
|
|
21
|
+
scanAction: input.action,
|
|
22
|
+
riskLevel: input.riskLevel ?? null,
|
|
23
|
+
categories: input.categories ?? [],
|
|
24
|
+
...(input.scannedToolName ? { scannedToolName: input.scannedToolName } : {}),
|
|
25
|
+
},
|
|
26
|
+
phase: "after",
|
|
27
|
+
blocked: true,
|
|
28
|
+
blockReason: reasonParts.join(" | "),
|
|
29
|
+
durationMs: input.latencyMs,
|
|
30
|
+
};
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=scan-activity.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scan-activity.js","sourceRoot":"","sources":["../../agent/scan-activity.ts"],"names":[],"mappings":"AAkBA,MAAM,UAAU,4BAA4B,CAAC,KAAwB;IACnE,IAAI,KAAK,CAAC,MAAM,KAAK,OAAO,IAAI,KAAK,CAAC,MAAM,KAAK,OAAO,EAAE,CAAC;QACzD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,MAAM,iBAAiB,GAAG,OAAO,KAAK,CAAC,UAAU,KAAK,QAAQ;QAC5D,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,UAAU,GAAG,GAAG,CAAC,GAAG;QAC1C,CAAC,CAAC,IAAI,CAAC;IAET,MAAM,WAAW,GAAG;QAClB,GAAG,KAAK,CAAC,MAAM,OAAO;QACtB,UAAU,KAAK,CAAC,MAAM,EAAE;QACxB,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,QAAQ,KAAK,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,IAAI;QAClD,iBAAiB,CAAC,CAAC,CAAC,cAAc,iBAAiB,EAAE,CAAC,CAAC,CAAC,IAAI;QAC5D,KAAK,CAAC,WAAW,CAAC,CAAC,CAAC,UAAU,KAAK,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,IAAI;KACzD,CAAC,MAAM,CAAC,CAAC,IAAI,EAAkB,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;IAE3C,OAAO;QACL,OAAO,EAAE,KAAK,CAAC,OAAO;QACtB,UAAU,EAAE,KAAK,CAAC,UAAU;QAC5B,QAAQ,EAAE,KAAK,CAAC,MAAM,KAAK,QAAQ,CAAC,CAAC,CAAC,sBAAsB,CAAC,CAAC,CAAC,uBAAuB;QACtF,MAAM,EAAE;YACN,MAAM,EAAE,KAAK,CAAC,MAAM;YACpB,UAAU,EAAE,KAAK,CAAC,MAAM;YACxB,SAAS,EAAE,KAAK,CAAC,SAAS,IAAI,IAAI;YAClC,UAAU,EAAE,KAAK,CAAC,UAAU,IAAI,EAAE;YAClC,GAAG,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC,CAAC,EAAE,eAAe,EAAE,KAAK,CAAC,eAAe,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;SAC7E;QACD,KAAK,EAAE,OAAO;QACd,OAAO,EAAE,IAAI;QACb,WAAW,EAAE,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC;QACpC,UAAU,EAAE,KAAK,CAAC,SAAS;KAC5B,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,177 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Type definitions for OpenGuardrails Plugin
|
|
3
|
+
*/
|
|
4
|
+
export type OpenClawGuardConfig = {
|
|
5
|
+
enabled?: boolean;
|
|
6
|
+
blockOnRisk?: boolean;
|
|
7
|
+
/** Optional API key override for configured Core endpoint. */
|
|
8
|
+
apiKey?: string;
|
|
9
|
+
timeoutMs?: number;
|
|
10
|
+
/** Core API URL (behavior detection).
|
|
11
|
+
* Default: http://10.16.148.67:53666 */
|
|
12
|
+
coreUrl?: string;
|
|
13
|
+
/** Agent name for dashboard metadata */
|
|
14
|
+
agentName?: string;
|
|
15
|
+
/** Deployment plan. Set to "enterprise" for self-hosted enterprise deployment.
|
|
16
|
+
* When "enterprise", coreUrl must point to the enterprise Core instance.
|
|
17
|
+
* Core API calls go to the enterprise coreUrl; dashboard reports to both
|
|
18
|
+
* local and enterprise Core for centralized security management. */
|
|
19
|
+
plan?: "enterprise";
|
|
20
|
+
};
|
|
21
|
+
export type AnalysisTarget = {
|
|
22
|
+
type: "message" | "tool_call" | "tool_result";
|
|
23
|
+
content: string;
|
|
24
|
+
toolName?: string;
|
|
25
|
+
toolParams?: Record<string, unknown>;
|
|
26
|
+
metadata?: Record<string, unknown>;
|
|
27
|
+
};
|
|
28
|
+
export type Finding = {
|
|
29
|
+
suspiciousContent: string;
|
|
30
|
+
reason: string;
|
|
31
|
+
confidence: number;
|
|
32
|
+
location?: {
|
|
33
|
+
start: number;
|
|
34
|
+
end: number;
|
|
35
|
+
};
|
|
36
|
+
};
|
|
37
|
+
export type AnalysisVerdict = {
|
|
38
|
+
isInjection: boolean;
|
|
39
|
+
confidence: number;
|
|
40
|
+
reason: string;
|
|
41
|
+
findings: Finding[];
|
|
42
|
+
chunksAnalyzed: number;
|
|
43
|
+
};
|
|
44
|
+
export type OpenGuardrailsApiResponse = {
|
|
45
|
+
ok: boolean;
|
|
46
|
+
verdict: {
|
|
47
|
+
isInjection: boolean;
|
|
48
|
+
confidence: number;
|
|
49
|
+
reason: string;
|
|
50
|
+
findings: Array<{
|
|
51
|
+
suspiciousContent: string;
|
|
52
|
+
reason: string;
|
|
53
|
+
confidence: number;
|
|
54
|
+
}>;
|
|
55
|
+
};
|
|
56
|
+
error?: string;
|
|
57
|
+
};
|
|
58
|
+
export type AnalysisLogEntry = {
|
|
59
|
+
id: number;
|
|
60
|
+
timestamp: string;
|
|
61
|
+
targetType: string;
|
|
62
|
+
contentLength: number;
|
|
63
|
+
chunksAnalyzed: number;
|
|
64
|
+
verdict: AnalysisVerdict;
|
|
65
|
+
durationMs: number;
|
|
66
|
+
blocked: boolean;
|
|
67
|
+
};
|
|
68
|
+
export type Logger = {
|
|
69
|
+
info: (msg: string) => void;
|
|
70
|
+
warn: (msg: string) => void;
|
|
71
|
+
error: (msg: string) => void;
|
|
72
|
+
debug?: (msg: string) => void;
|
|
73
|
+
};
|
|
74
|
+
export type SanitizeResult = {
|
|
75
|
+
sanitized: string;
|
|
76
|
+
redactions: Record<string, number>;
|
|
77
|
+
totalRedactions: number;
|
|
78
|
+
};
|
|
79
|
+
export type RiskLevel = "no_risk" | "low" | "medium" | "high" | "critical";
|
|
80
|
+
export type AssessAction = "allow" | "alert" | "block";
|
|
81
|
+
export type DetectionRiskType = "PROMPT_INJECTION" | "DATA_EXFILTRATION" | "COMMAND_EXECUTION";
|
|
82
|
+
export type DetectionFinding = {
|
|
83
|
+
riskLevel: RiskLevel;
|
|
84
|
+
riskType: DetectionRiskType;
|
|
85
|
+
riskContent: string;
|
|
86
|
+
reason: string;
|
|
87
|
+
};
|
|
88
|
+
export type ToolChainEntry = {
|
|
89
|
+
seq: number;
|
|
90
|
+
toolName: string;
|
|
91
|
+
sanitizedParams: Record<string, string>;
|
|
92
|
+
outcome: "success" | "error" | "timeout";
|
|
93
|
+
durationMs: number;
|
|
94
|
+
resultCategory: "text_small" | "text_large" | "binary" | "empty" | "error";
|
|
95
|
+
resultSizeBytes: number;
|
|
96
|
+
dataFlowFrom?: string;
|
|
97
|
+
};
|
|
98
|
+
export type PendingToolCall = {
|
|
99
|
+
toolName: string;
|
|
100
|
+
params: Record<string, string>;
|
|
101
|
+
};
|
|
102
|
+
export type ContentInjectionFinding = {
|
|
103
|
+
category: string;
|
|
104
|
+
confidence: "high" | "medium";
|
|
105
|
+
matchedText: string;
|
|
106
|
+
pattern: string;
|
|
107
|
+
};
|
|
108
|
+
export type BehaviorAssessRequest = {
|
|
109
|
+
agentId: string;
|
|
110
|
+
sessionKey: string;
|
|
111
|
+
runId: string;
|
|
112
|
+
userIntent: string;
|
|
113
|
+
toolChain: ToolChainEntry[];
|
|
114
|
+
/** The tool call about to execute — Core classifies and evaluates it. */
|
|
115
|
+
pendingTool?: PendingToolCall;
|
|
116
|
+
/** Content injection findings from local regex scanner. */
|
|
117
|
+
contentFindings?: ContentInjectionFinding[];
|
|
118
|
+
context: {
|
|
119
|
+
messageHistoryLength: number;
|
|
120
|
+
recentUserMessages: string[];
|
|
121
|
+
};
|
|
122
|
+
/**
|
|
123
|
+
* Client-supplied metadata for server-side correlation.
|
|
124
|
+
* Server merges these with its own fields (sourceIp, apiKey ref, serverTimestamp)
|
|
125
|
+
* before storing in behavior_events and surfacing in the dashboard.
|
|
126
|
+
*/
|
|
127
|
+
meta: {
|
|
128
|
+
pluginVersion: string;
|
|
129
|
+
clientTimestamp: string;
|
|
130
|
+
};
|
|
131
|
+
};
|
|
132
|
+
export type BehaviorAssessResponse = {
|
|
133
|
+
behaviorId: string;
|
|
134
|
+
riskLevel: RiskLevel;
|
|
135
|
+
anomalyTypes: string[];
|
|
136
|
+
confidence: number;
|
|
137
|
+
action: AssessAction;
|
|
138
|
+
explanation: string;
|
|
139
|
+
affectedTools: number[];
|
|
140
|
+
findings?: DetectionFinding[];
|
|
141
|
+
};
|
|
142
|
+
export type PromptScanRequest = {
|
|
143
|
+
agentId: string;
|
|
144
|
+
sessionKey: string;
|
|
145
|
+
runId: string;
|
|
146
|
+
prompt: string;
|
|
147
|
+
role: "user";
|
|
148
|
+
source: "message_received";
|
|
149
|
+
context: {
|
|
150
|
+
messageHistoryLength: number;
|
|
151
|
+
recentUserMessages: string[];
|
|
152
|
+
userIntent: string;
|
|
153
|
+
};
|
|
154
|
+
meta: {
|
|
155
|
+
pluginVersion: string;
|
|
156
|
+
clientTimestamp: string;
|
|
157
|
+
};
|
|
158
|
+
};
|
|
159
|
+
export type PromptScanFinding = {
|
|
160
|
+
riskType: DetectionRiskType | string;
|
|
161
|
+
reason: string;
|
|
162
|
+
matchedText?: string;
|
|
163
|
+
confidence?: "high" | "medium" | "low" | number;
|
|
164
|
+
};
|
|
165
|
+
export type PromptScanResponse = {
|
|
166
|
+
promptId: string;
|
|
167
|
+
riskLevel: RiskLevel;
|
|
168
|
+
action: AssessAction;
|
|
169
|
+
confidence: number;
|
|
170
|
+
categories: string[];
|
|
171
|
+
findings?: PromptScanFinding[];
|
|
172
|
+
explanation: string;
|
|
173
|
+
latency_ms: number;
|
|
174
|
+
};
|
|
175
|
+
export type { HookType, HookEvent, HookEventData, EventStreamRequest, EventStreamResponse, BeforeAgentStartData, AgentEndData, SessionStartData, SessionEndData, MessageReceivedData, MessageSendingData, MessageSentData, BeforeMessageWriteData, BeforeModelResolveData, BeforePromptBuildData, LlmInputData, LlmOutputData, BeforeToolCallData, AfterToolCallData, ToolResultPersistData, BeforeCompactionData, AfterCompactionData, BeforeResetData, SubagentSpawningData, SubagentDeliveryTargetData, SubagentSpawnedData, SubagentEndedData, GatewayStartData, GatewayStopData, } from "./hook-types.js";
|
|
176
|
+
export { isBlockingHook, BLOCKING_HOOKS } from "./hook-types.js";
|
|
177
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../agent/types.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../agent/types.ts"],"names":[],"mappings":"AAAA;;GAEG;AAiQH,OAAO,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC"}
|