@vainplex/openclaw-governance 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +297 -0
- package/dist/index.d.ts +10 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +30 -0
- package/dist/index.js.map +1 -0
- package/dist/src/audit-redactor.d.ts +3 -0
- package/dist/src/audit-redactor.d.ts.map +1 -0
- package/dist/src/audit-redactor.js +68 -0
- package/dist/src/audit-redactor.js.map +1 -0
- package/dist/src/audit-trail.d.ts +27 -0
- package/dist/src/audit-trail.d.ts.map +1 -0
- package/dist/src/audit-trail.js +192 -0
- package/dist/src/audit-trail.js.map +1 -0
- package/dist/src/builtin-policies.d.ts +3 -0
- package/dist/src/builtin-policies.d.ts.map +1 -0
- package/dist/src/builtin-policies.js +152 -0
- package/dist/src/builtin-policies.js.map +1 -0
- package/dist/src/conditions/context.d.ts +3 -0
- package/dist/src/conditions/context.d.ts.map +1 -0
- package/dist/src/conditions/context.js +60 -0
- package/dist/src/conditions/context.js.map +1 -0
- package/dist/src/conditions/index.d.ts +4 -0
- package/dist/src/conditions/index.d.ts.map +1 -0
- package/dist/src/conditions/index.js +28 -0
- package/dist/src/conditions/index.js.map +1 -0
- package/dist/src/conditions/simple.d.ts +10 -0
- package/dist/src/conditions/simple.d.ts.map +1 -0
- package/dist/src/conditions/simple.js +94 -0
- package/dist/src/conditions/simple.js.map +1 -0
- package/dist/src/conditions/time.d.ts +3 -0
- package/dist/src/conditions/time.d.ts.map +1 -0
- package/dist/src/conditions/time.js +48 -0
- package/dist/src/conditions/time.js.map +1 -0
- package/dist/src/conditions/tool.d.ts +3 -0
- package/dist/src/conditions/tool.d.ts.map +1 -0
- package/dist/src/conditions/tool.js +57 -0
- package/dist/src/conditions/tool.js.map +1 -0
- package/dist/src/config.d.ts +3 -0
- package/dist/src/config.d.ts.map +1 -0
- package/dist/src/config.js +80 -0
- package/dist/src/config.js.map +1 -0
- package/dist/src/cross-agent.d.ts +23 -0
- package/dist/src/cross-agent.d.ts.map +1 -0
- package/dist/src/cross-agent.js +142 -0
- package/dist/src/cross-agent.js.map +1 -0
- package/dist/src/engine.d.ts +29 -0
- package/dist/src/engine.d.ts.map +1 -0
- package/dist/src/engine.js +195 -0
- package/dist/src/engine.js.map +1 -0
- package/dist/src/frequency-tracker.d.ts +12 -0
- package/dist/src/frequency-tracker.d.ts.map +1 -0
- package/dist/src/frequency-tracker.js +44 -0
- package/dist/src/frequency-tracker.js.map +1 -0
- package/dist/src/hooks.d.ts +4 -0
- package/dist/src/hooks.d.ts.map +1 -0
- package/dist/src/hooks.js +198 -0
- package/dist/src/hooks.js.map +1 -0
- package/dist/src/policy-evaluator.d.ts +16 -0
- package/dist/src/policy-evaluator.d.ts.map +1 -0
- package/dist/src/policy-evaluator.js +99 -0
- package/dist/src/policy-evaluator.js.map +1 -0
- package/dist/src/policy-loader.d.ts +8 -0
- package/dist/src/policy-loader.d.ts.map +1 -0
- package/dist/src/policy-loader.js +105 -0
- package/dist/src/policy-loader.js.map +1 -0
- package/dist/src/risk-assessor.d.ts +8 -0
- package/dist/src/risk-assessor.d.ts.map +1 -0
- package/dist/src/risk-assessor.js +80 -0
- package/dist/src/risk-assessor.js.map +1 -0
- package/dist/src/trust-manager.d.ts +29 -0
- package/dist/src/trust-manager.d.ts.map +1 -0
- package/dist/src/trust-manager.js +219 -0
- package/dist/src/trust-manager.js.map +1 -0
- package/dist/src/types.d.ts +438 -0
- package/dist/src/types.d.ts.map +1 -0
- package/dist/src/types.js +3 -0
- package/dist/src/types.js.map +1 -0
- package/dist/src/util.d.ts +28 -0
- package/dist/src/util.d.ts.map +1 -0
- package/dist/src/util.js +125 -0
- package/dist/src/util.js.map +1 -0
- package/openclaw.plugin.json +87 -0
- package/package.json +48 -0
|
@@ -0,0 +1,198 @@
|
|
|
1
|
+
import { extractAgentId, getCurrentTime } from "./util.js";
|
|
2
|
+
function buildToolEvalContext(event, hookCtx, config, engine) {
|
|
3
|
+
const agentId = extractAgentId(hookCtx.sessionKey, hookCtx.agentId);
|
|
4
|
+
const trust = engine.getTrust(agentId);
|
|
5
|
+
const trustData = "score" in trust
|
|
6
|
+
? { score: trust.score, tier: trust.tier }
|
|
7
|
+
: { score: 10, tier: "untrusted" };
|
|
8
|
+
return {
|
|
9
|
+
hook: "before_tool_call",
|
|
10
|
+
agentId,
|
|
11
|
+
sessionKey: hookCtx.sessionKey ?? `agent:${agentId}`,
|
|
12
|
+
toolName: event.toolName,
|
|
13
|
+
toolParams: event.params,
|
|
14
|
+
timestamp: Date.now(),
|
|
15
|
+
time: getCurrentTime(config.timezone),
|
|
16
|
+
trust: trustData,
|
|
17
|
+
};
|
|
18
|
+
}
|
|
19
|
+
function buildMessageEvalContext(event, hookCtx, config, engine) {
|
|
20
|
+
const agentId = "main"; // message context doesn't always have agentId
|
|
21
|
+
const trust = engine.getTrust(agentId);
|
|
22
|
+
const trustData = "score" in trust
|
|
23
|
+
? { score: trust.score, tier: trust.tier }
|
|
24
|
+
: { score: 10, tier: "untrusted" };
|
|
25
|
+
return {
|
|
26
|
+
hook: "message_sending",
|
|
27
|
+
agentId,
|
|
28
|
+
sessionKey: `agent:${agentId}`,
|
|
29
|
+
channel: hookCtx.channelId,
|
|
30
|
+
messageContent: event.content,
|
|
31
|
+
messageTo: event.to,
|
|
32
|
+
timestamp: Date.now(),
|
|
33
|
+
time: getCurrentTime(config.timezone),
|
|
34
|
+
trust: trustData,
|
|
35
|
+
metadata: event.metadata,
|
|
36
|
+
};
|
|
37
|
+
}
|
|
38
|
+
function handleBeforeToolCall(engine, config) {
|
|
39
|
+
return async (event, hookCtx) => {
|
|
40
|
+
try {
|
|
41
|
+
const ev = event;
|
|
42
|
+
const ctx = hookCtx;
|
|
43
|
+
const evalCtx = buildToolEvalContext(ev, ctx, config, engine);
|
|
44
|
+
const verdict = await engine.evaluate(evalCtx);
|
|
45
|
+
if (verdict.action === "deny") {
|
|
46
|
+
return { block: true, blockReason: verdict.reason };
|
|
47
|
+
}
|
|
48
|
+
return undefined;
|
|
49
|
+
}
|
|
50
|
+
catch (e) {
|
|
51
|
+
const msg = e instanceof Error ? e.message : String(e);
|
|
52
|
+
if (config.failMode === "closed") {
|
|
53
|
+
return {
|
|
54
|
+
block: true,
|
|
55
|
+
blockReason: `Governance error (fail-closed): ${msg}`,
|
|
56
|
+
};
|
|
57
|
+
}
|
|
58
|
+
return undefined;
|
|
59
|
+
}
|
|
60
|
+
};
|
|
61
|
+
}
|
|
62
|
+
function handleMessageSending(engine, config) {
|
|
63
|
+
return async (event, hookCtx) => {
|
|
64
|
+
try {
|
|
65
|
+
const ev = event;
|
|
66
|
+
const ctx = hookCtx;
|
|
67
|
+
const evalCtx = buildMessageEvalContext(ev, ctx, config, engine);
|
|
68
|
+
const verdict = await engine.evaluate(evalCtx);
|
|
69
|
+
if (verdict.action === "deny") {
|
|
70
|
+
return { cancel: true };
|
|
71
|
+
}
|
|
72
|
+
return undefined;
|
|
73
|
+
}
|
|
74
|
+
catch {
|
|
75
|
+
return undefined;
|
|
76
|
+
}
|
|
77
|
+
};
|
|
78
|
+
}
|
|
79
|
+
function handleAfterToolCall(engine) {
|
|
80
|
+
return (event, hookCtx) => {
|
|
81
|
+
try {
|
|
82
|
+
const ev = event;
|
|
83
|
+
const ctx = hookCtx;
|
|
84
|
+
const agentId = extractAgentId(ctx.sessionKey, ctx.agentId);
|
|
85
|
+
const success = !ev.error;
|
|
86
|
+
engine.recordOutcome(agentId, ev.toolName, success);
|
|
87
|
+
// Detect sub-agent spawn
|
|
88
|
+
if (ev.toolName === "sessions_spawn" &&
|
|
89
|
+
success &&
|
|
90
|
+
ev.result &&
|
|
91
|
+
typeof ev.result === "object") {
|
|
92
|
+
const result = ev.result;
|
|
93
|
+
const childSessionId = result["sessionId"] ?? result["sessionKey"];
|
|
94
|
+
if (typeof childSessionId === "string" && ctx.sessionKey) {
|
|
95
|
+
engine.registerSubAgent(ctx.sessionKey, childSessionId);
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
catch {
|
|
100
|
+
// Don't break on after_tool_call errors
|
|
101
|
+
}
|
|
102
|
+
};
|
|
103
|
+
}
|
|
104
|
+
function handleBeforeAgentStart(engine, _config) {
|
|
105
|
+
return (_event, hookCtx) => {
|
|
106
|
+
try {
|
|
107
|
+
const ctx = hookCtx;
|
|
108
|
+
const agentId = extractAgentId(ctx.sessionKey, ctx.agentId);
|
|
109
|
+
const trust = engine.getTrust(agentId);
|
|
110
|
+
if (!("score" in trust))
|
|
111
|
+
return undefined;
|
|
112
|
+
const status = engine.getStatus();
|
|
113
|
+
const context = [
|
|
114
|
+
`\n[Governance] Trust: ${trust.tier} (${trust.score}/100)`,
|
|
115
|
+
`Policies: ${status.policyCount} active`,
|
|
116
|
+
status.failMode === "closed" ? "Mode: fail-closed" : "",
|
|
117
|
+
]
|
|
118
|
+
.filter(Boolean)
|
|
119
|
+
.join(" | ");
|
|
120
|
+
return { prependContext: context };
|
|
121
|
+
}
|
|
122
|
+
catch {
|
|
123
|
+
return undefined;
|
|
124
|
+
}
|
|
125
|
+
};
|
|
126
|
+
}
|
|
127
|
+
function handleSessionStart(engine) {
|
|
128
|
+
return (_event, hookCtx) => {
|
|
129
|
+
try {
|
|
130
|
+
const ctx = hookCtx;
|
|
131
|
+
const agentId = extractAgentId(undefined, ctx.agentId);
|
|
132
|
+
// Ensure trust state is initialized for this agent
|
|
133
|
+
engine.getTrust(agentId);
|
|
134
|
+
}
|
|
135
|
+
catch {
|
|
136
|
+
// Don't break on session_start errors
|
|
137
|
+
}
|
|
138
|
+
};
|
|
139
|
+
}
|
|
140
|
+
function handleGatewayStart(engine) {
|
|
141
|
+
return () => {
|
|
142
|
+
// Engine should already be started via service, but this is a safety net
|
|
143
|
+
engine.getStatus();
|
|
144
|
+
};
|
|
145
|
+
}
|
|
146
|
+
function handleGatewayStop(engine) {
|
|
147
|
+
return async () => {
|
|
148
|
+
await engine.stop();
|
|
149
|
+
};
|
|
150
|
+
}
|
|
151
|
+
function registerCommands(api, engine) {
|
|
152
|
+
const commands = [
|
|
153
|
+
{
|
|
154
|
+
name: "governance",
|
|
155
|
+
description: "Show governance engine status",
|
|
156
|
+
handler: () => {
|
|
157
|
+
const status = engine.getStatus();
|
|
158
|
+
return {
|
|
159
|
+
text: [
|
|
160
|
+
"🛡️ **Governance Engine**",
|
|
161
|
+
`Enabled: ${status.enabled}`,
|
|
162
|
+
`Policies: ${status.policyCount}`,
|
|
163
|
+
`Trust: ${status.trustEnabled ? "enabled" : "disabled"}`,
|
|
164
|
+
`Audit: ${status.auditEnabled ? "enabled" : "disabled"}`,
|
|
165
|
+
`Fail mode: ${status.failMode}`,
|
|
166
|
+
`Evaluations: ${status.stats.totalEvaluations} (${status.stats.allowCount} allow, ${status.stats.denyCount} deny, ${status.stats.errorCount} errors)`,
|
|
167
|
+
`Avg latency: ${Math.round(status.stats.avgEvaluationUs)}μs`,
|
|
168
|
+
].join("\n"),
|
|
169
|
+
};
|
|
170
|
+
},
|
|
171
|
+
},
|
|
172
|
+
];
|
|
173
|
+
for (const cmd of commands) {
|
|
174
|
+
api.registerCommand(cmd);
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
export function registerGovernanceHooks(api, engine, config) {
|
|
178
|
+
// Primary enforcement
|
|
179
|
+
api.on("before_tool_call", handleBeforeToolCall(engine, config), {
|
|
180
|
+
priority: 1000,
|
|
181
|
+
});
|
|
182
|
+
api.on("message_sending", handleMessageSending(engine, config), {
|
|
183
|
+
priority: 1000,
|
|
184
|
+
});
|
|
185
|
+
// Trust feedback
|
|
186
|
+
api.on("after_tool_call", handleAfterToolCall(engine), { priority: 900 });
|
|
187
|
+
// Context injection
|
|
188
|
+
api.on("before_agent_start", handleBeforeAgentStart(engine, config), {
|
|
189
|
+
priority: 5,
|
|
190
|
+
});
|
|
191
|
+
// Lifecycle
|
|
192
|
+
api.on("session_start", handleSessionStart(engine), { priority: 1 });
|
|
193
|
+
api.on("gateway_start", handleGatewayStart(engine), { priority: 1 });
|
|
194
|
+
api.on("gateway_stop", handleGatewayStop(engine), { priority: 999 });
|
|
195
|
+
// Commands
|
|
196
|
+
registerCommands(api, engine);
|
|
197
|
+
}
|
|
198
|
+
//# sourceMappingURL=hooks.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hooks.js","sourceRoot":"","sources":["../../src/hooks.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import type { ConditionEvaluatorMap, ConditionDeps, EvaluationContext, MatchedPolicy, Policy, RiskAssessment } from "./types.js";
|
|
2
|
+
type EvalResult = {
|
|
3
|
+
action: "allow" | "deny";
|
|
4
|
+
reason: string;
|
|
5
|
+
matches: MatchedPolicy[];
|
|
6
|
+
};
|
|
7
|
+
export declare class PolicyEvaluator {
|
|
8
|
+
private readonly evaluators;
|
|
9
|
+
constructor(evaluators: ConditionEvaluatorMap);
|
|
10
|
+
evaluate(ctx: EvaluationContext, policies: Policy[], risk: RiskAssessment): EvalResult;
|
|
11
|
+
evaluateWithDeps(ctx: EvaluationContext, policies: Policy[], risk: RiskAssessment, deps: ConditionDeps): EvalResult;
|
|
12
|
+
private evaluateInternal;
|
|
13
|
+
private matchPolicy;
|
|
14
|
+
}
|
|
15
|
+
export {};
|
|
16
|
+
//# sourceMappingURL=policy-evaluator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"policy-evaluator.d.ts","sourceRoot":"","sources":["../../src/policy-evaluator.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,qBAAqB,EACrB,aAAa,EACb,iBAAiB,EACjB,aAAa,EACb,MAAM,EACN,cAAc,EACf,MAAM,YAAY,CAAC;AAIpB,KAAK,UAAU,GAAG;IAChB,MAAM,EAAE,OAAO,GAAG,MAAM,CAAC;IACzB,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,aAAa,EAAE,CAAC;CAC1B,CAAC;AAuDF,qBAAa,eAAe;IAC1B,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAwB;gBAEvC,UAAU,EAAE,qBAAqB;IAI7C,QAAQ,CACN,GAAG,EAAE,iBAAiB,EACtB,QAAQ,EAAE,MAAM,EAAE,EAClB,IAAI,EAAE,cAAc,GACnB,UAAU;IAUb,gBAAgB,CACd,GAAG,EAAE,iBAAiB,EACtB,QAAQ,EAAE,MAAM,EAAE,EAClB,IAAI,EAAE,cAAc,EACpB,IAAI,EAAE,aAAa,GAClB,UAAU;IAIb,OAAO,CAAC,gBAAgB;IAmBxB,OAAO,CAAC,WAAW;CAkBpB"}
|
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
import { evaluateConditions } from "./conditions/index.js";
|
|
2
|
+
import { isTierAtLeast, isTierAtMost } from "./conditions/simple.js";
|
|
3
|
+
function matchesScope(policy, ctx) {
|
|
4
|
+
if (policy.scope.excludeAgents?.includes(ctx.agentId))
|
|
5
|
+
return false;
|
|
6
|
+
if (policy.scope.channels && policy.scope.channels.length > 0) {
|
|
7
|
+
if (!ctx.channel || !policy.scope.channels.includes(ctx.channel)) {
|
|
8
|
+
return false;
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
return true;
|
|
12
|
+
}
|
|
13
|
+
function policySpecificity(policy) {
|
|
14
|
+
let score = 0;
|
|
15
|
+
if (policy.scope.agents && policy.scope.agents.length > 0)
|
|
16
|
+
score += 10;
|
|
17
|
+
if (policy.scope.channels && policy.scope.channels.length > 0)
|
|
18
|
+
score += 5;
|
|
19
|
+
if (policy.scope.hooks && policy.scope.hooks.length > 0)
|
|
20
|
+
score += 3;
|
|
21
|
+
return score;
|
|
22
|
+
}
|
|
23
|
+
function sortPolicies(policies) {
|
|
24
|
+
return [...policies].sort((a, b) => {
|
|
25
|
+
const priDiff = (b.priority ?? 0) - (a.priority ?? 0);
|
|
26
|
+
if (priDiff !== 0)
|
|
27
|
+
return priDiff;
|
|
28
|
+
return policySpecificity(b) - policySpecificity(a);
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
function aggregateMatches(matches) {
|
|
32
|
+
let hasDeny = false;
|
|
33
|
+
let denyReason = "";
|
|
34
|
+
let hasAudit = false;
|
|
35
|
+
for (const m of matches) {
|
|
36
|
+
if (m.effect.action === "deny") {
|
|
37
|
+
hasDeny = true;
|
|
38
|
+
if (!denyReason)
|
|
39
|
+
denyReason = "reason" in m.effect ? m.effect.reason : "";
|
|
40
|
+
}
|
|
41
|
+
else if (m.effect.action === "audit") {
|
|
42
|
+
hasAudit = true;
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
if (hasDeny) {
|
|
46
|
+
return { action: "deny", reason: denyReason || "Denied by governance policy", matches };
|
|
47
|
+
}
|
|
48
|
+
if (hasAudit) {
|
|
49
|
+
return { action: "allow", reason: "Allowed with audit logging", matches };
|
|
50
|
+
}
|
|
51
|
+
return {
|
|
52
|
+
action: "allow",
|
|
53
|
+
reason: matches.length > 0 ? "Allowed by governance policy" : "No matching policies",
|
|
54
|
+
matches,
|
|
55
|
+
};
|
|
56
|
+
}
|
|
57
|
+
export class PolicyEvaluator {
|
|
58
|
+
evaluators;
|
|
59
|
+
constructor(evaluators) {
|
|
60
|
+
this.evaluators = evaluators;
|
|
61
|
+
}
|
|
62
|
+
evaluate(ctx, policies, risk) {
|
|
63
|
+
const stubDeps = {
|
|
64
|
+
regexCache: new Map(),
|
|
65
|
+
timeWindows: {},
|
|
66
|
+
risk,
|
|
67
|
+
frequencyTracker: { record: () => { }, count: () => 0, clear: () => { } },
|
|
68
|
+
};
|
|
69
|
+
return this.evaluateInternal(ctx, policies, risk, stubDeps);
|
|
70
|
+
}
|
|
71
|
+
evaluateWithDeps(ctx, policies, risk, deps) {
|
|
72
|
+
return this.evaluateInternal(ctx, policies, risk, deps);
|
|
73
|
+
}
|
|
74
|
+
evaluateInternal(ctx, policies, risk, deps) {
|
|
75
|
+
const applicable = sortPolicies(policies.filter((p) => matchesScope(p, ctx)));
|
|
76
|
+
const matches = [];
|
|
77
|
+
for (const policy of applicable) {
|
|
78
|
+
const match = this.matchPolicy(policy, ctx, { ...deps, risk });
|
|
79
|
+
if (match)
|
|
80
|
+
matches.push(match);
|
|
81
|
+
}
|
|
82
|
+
return aggregateMatches(matches);
|
|
83
|
+
}
|
|
84
|
+
matchPolicy(policy, ctx, deps) {
|
|
85
|
+
for (const rule of policy.rules) {
|
|
86
|
+
if (rule.minTrust && !isTierAtLeast(ctx.trust.tier, rule.minTrust)) {
|
|
87
|
+
continue;
|
|
88
|
+
}
|
|
89
|
+
if (rule.maxTrust && !isTierAtMost(ctx.trust.tier, rule.maxTrust)) {
|
|
90
|
+
continue;
|
|
91
|
+
}
|
|
92
|
+
if (evaluateConditions(rule.conditions, ctx, deps, this.evaluators)) {
|
|
93
|
+
return { policyId: policy.id, ruleId: rule.id, effect: rule.effect };
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
return null;
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
//# sourceMappingURL=policy-evaluator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"policy-evaluator.js","sourceRoot":"","sources":["../../src/policy-evaluator.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { BuiltinPoliciesConfig, PluginLogger, Policy, PolicyIndex } from "./types.js";
|
|
2
|
+
export declare function validateRegex(pattern: string): {
|
|
3
|
+
valid: boolean;
|
|
4
|
+
error?: string;
|
|
5
|
+
};
|
|
6
|
+
export declare function loadPolicies(policies: Policy[], builtinConfig: BuiltinPoliciesConfig, logger: PluginLogger): Policy[];
|
|
7
|
+
export declare function buildPolicyIndex(policies: Policy[]): PolicyIndex;
|
|
8
|
+
//# sourceMappingURL=policy-loader.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"policy-loader.d.ts","sourceRoot":"","sources":["../../src/policy-loader.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,qBAAqB,EAGrB,YAAY,EACZ,MAAM,EAEN,WAAW,EACZ,MAAM,YAAY,CAAC;AAMpB,wBAAgB,aAAa,CAC3B,OAAO,EAAE,MAAM,GACd;IAAE,KAAK,EAAE,OAAO,CAAC;IAAC,KAAK,CAAC,EAAE,MAAM,CAAA;CAAE,CAcpC;AAwCD,wBAAgB,YAAY,CAC1B,QAAQ,EAAE,MAAM,EAAE,EAClB,aAAa,EAAE,qBAAqB,EACpC,MAAM,EAAE,YAAY,GACnB,MAAM,EAAE,CAWV;AAED,wBAAgB,gBAAgB,CAC9B,QAAQ,EAAE,MAAM,EAAE,GACjB,WAAW,CA2Cb"}
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
import { getBuiltinPolicies } from "./builtin-policies.js";
|
|
2
|
+
const NESTED_QUANTIFIER_RE = /(\+|\*|\{)\)(\+|\*|\{)/;
|
|
3
|
+
const MAX_PATTERN_LENGTH = 500;
|
|
4
|
+
export function validateRegex(pattern) {
|
|
5
|
+
if (pattern.length > MAX_PATTERN_LENGTH) {
|
|
6
|
+
return { valid: false, error: `Pattern exceeds ${MAX_PATTERN_LENGTH} chars` };
|
|
7
|
+
}
|
|
8
|
+
if (NESTED_QUANTIFIER_RE.test(pattern)) {
|
|
9
|
+
return { valid: false, error: "Nested quantifiers detected (ReDoS risk)" };
|
|
10
|
+
}
|
|
11
|
+
try {
|
|
12
|
+
new RegExp(pattern);
|
|
13
|
+
return { valid: true };
|
|
14
|
+
}
|
|
15
|
+
catch (e) {
|
|
16
|
+
const msg = e instanceof Error ? e.message : String(e);
|
|
17
|
+
return { valid: false, error: msg };
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
function collectRegexPatterns(conditions) {
|
|
21
|
+
const patterns = [];
|
|
22
|
+
for (const cond of conditions) {
|
|
23
|
+
if (cond.type === "tool" && cond.params) {
|
|
24
|
+
for (const matcher of Object.values(cond.params)) {
|
|
25
|
+
if (isMatchesMatcher(matcher)) {
|
|
26
|
+
patterns.push(matcher.matches);
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
if (cond.type === "context") {
|
|
31
|
+
const conv = cond.conversationContains;
|
|
32
|
+
if (conv) {
|
|
33
|
+
const arr = Array.isArray(conv) ? conv : [conv];
|
|
34
|
+
patterns.push(...arr);
|
|
35
|
+
}
|
|
36
|
+
const msg = cond.messageContains;
|
|
37
|
+
if (msg) {
|
|
38
|
+
const arr = Array.isArray(msg) ? msg : [msg];
|
|
39
|
+
patterns.push(...arr);
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
if (cond.type === "any") {
|
|
43
|
+
patterns.push(...collectRegexPatterns(cond.conditions));
|
|
44
|
+
}
|
|
45
|
+
if (cond.type === "not") {
|
|
46
|
+
patterns.push(...collectRegexPatterns([cond.condition]));
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
return patterns;
|
|
50
|
+
}
|
|
51
|
+
function isMatchesMatcher(m) {
|
|
52
|
+
return "matches" in m;
|
|
53
|
+
}
|
|
54
|
+
export function loadPolicies(policies, builtinConfig, logger) {
|
|
55
|
+
const builtins = getBuiltinPolicies(builtinConfig);
|
|
56
|
+
const all = [...builtins, ...policies];
|
|
57
|
+
return all.filter((p) => {
|
|
58
|
+
if (p.enabled === false) {
|
|
59
|
+
logger.info(`[governance] Policy "${p.id}" disabled`);
|
|
60
|
+
return false;
|
|
61
|
+
}
|
|
62
|
+
return true;
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
export function buildPolicyIndex(policies) {
|
|
66
|
+
const byHook = new Map();
|
|
67
|
+
const byAgent = new Map();
|
|
68
|
+
const regexCache = new Map();
|
|
69
|
+
const hooks = [
|
|
70
|
+
"before_tool_call",
|
|
71
|
+
"message_sending",
|
|
72
|
+
"before_agent_start",
|
|
73
|
+
"session_start",
|
|
74
|
+
];
|
|
75
|
+
for (const policy of policies) {
|
|
76
|
+
// Index by hook
|
|
77
|
+
const policyHooks = policy.scope.hooks ?? hooks;
|
|
78
|
+
for (const hook of policyHooks) {
|
|
79
|
+
const list = byHook.get(hook) ?? [];
|
|
80
|
+
list.push(policy);
|
|
81
|
+
byHook.set(hook, list);
|
|
82
|
+
}
|
|
83
|
+
// Index by agent
|
|
84
|
+
const agents = policy.scope.agents ?? ["*"];
|
|
85
|
+
for (const agent of agents) {
|
|
86
|
+
const list = byAgent.get(agent) ?? [];
|
|
87
|
+
list.push(policy);
|
|
88
|
+
byAgent.set(agent, list);
|
|
89
|
+
}
|
|
90
|
+
// Collect and compile regex patterns
|
|
91
|
+
for (const rule of policy.rules) {
|
|
92
|
+
const patterns = collectRegexPatterns(rule.conditions);
|
|
93
|
+
for (const pattern of patterns) {
|
|
94
|
+
if (regexCache.has(pattern))
|
|
95
|
+
continue;
|
|
96
|
+
const validation = validateRegex(pattern);
|
|
97
|
+
if (validation.valid) {
|
|
98
|
+
regexCache.set(pattern, new RegExp(pattern));
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
return { byHook, byAgent, regexCache };
|
|
104
|
+
}
|
|
105
|
+
//# sourceMappingURL=policy-loader.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"policy-loader.js","sourceRoot":"","sources":["../../src/policy-loader.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { EvaluationContext, FrequencyTracker, RiskAssessment } from "./types.js";
|
|
2
|
+
export declare class RiskAssessor {
|
|
3
|
+
private readonly overrides;
|
|
4
|
+
constructor(toolRiskOverrides: Record<string, number>);
|
|
5
|
+
assess(ctx: EvaluationContext, frequencyTracker: FrequencyTracker): RiskAssessment;
|
|
6
|
+
private computeFactors;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=risk-assessor.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"risk-assessor.d.ts","sourceRoot":"","sources":["../../src/risk-assessor.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,iBAAiB,EACjB,gBAAgB,EAChB,cAAc,EAGf,MAAM,YAAY,CAAC;AAqCpB,qBAAa,YAAY;IACvB,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAyB;gBAEvC,iBAAiB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC;IAIrD,MAAM,CACJ,GAAG,EAAE,iBAAiB,EACtB,gBAAgB,EAAE,gBAAgB,GACjC,cAAc;IAQjB,OAAO,CAAC,cAAc;CAsCvB"}
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
import { clamp } from "./util.js";
|
|
2
|
+
const DEFAULT_TOOL_RISK = {
|
|
3
|
+
gateway: 95, cron: 90, elevated: 95,
|
|
4
|
+
exec: 70, write: 65, edit: 60,
|
|
5
|
+
sessions_spawn: 45, sessions_send: 50,
|
|
6
|
+
browser: 40, message: 40,
|
|
7
|
+
read: 10, memory_search: 5, memory_get: 5,
|
|
8
|
+
web_search: 15, web_fetch: 20, image: 10, canvas: 15,
|
|
9
|
+
};
|
|
10
|
+
function lookupToolRisk(toolName, overrides) {
|
|
11
|
+
if (!toolName)
|
|
12
|
+
return 30;
|
|
13
|
+
const override = overrides[toolName];
|
|
14
|
+
if (override !== undefined)
|
|
15
|
+
return override;
|
|
16
|
+
return DEFAULT_TOOL_RISK[toolName] ?? 30;
|
|
17
|
+
}
|
|
18
|
+
function isExternalTarget(ctx) {
|
|
19
|
+
if (ctx.messageTo)
|
|
20
|
+
return true;
|
|
21
|
+
if (!ctx.toolParams)
|
|
22
|
+
return false;
|
|
23
|
+
const host = ctx.toolParams["host"];
|
|
24
|
+
if (typeof host === "string" && host !== "sandbox")
|
|
25
|
+
return true;
|
|
26
|
+
return ctx.toolParams["elevated"] === true;
|
|
27
|
+
}
|
|
28
|
+
function scoreToRiskLevel(score) {
|
|
29
|
+
if (score <= 25)
|
|
30
|
+
return "low";
|
|
31
|
+
if (score <= 50)
|
|
32
|
+
return "medium";
|
|
33
|
+
if (score <= 75)
|
|
34
|
+
return "high";
|
|
35
|
+
return "critical";
|
|
36
|
+
}
|
|
37
|
+
export class RiskAssessor {
|
|
38
|
+
overrides;
|
|
39
|
+
constructor(toolRiskOverrides) {
|
|
40
|
+
this.overrides = toolRiskOverrides;
|
|
41
|
+
}
|
|
42
|
+
assess(ctx, frequencyTracker) {
|
|
43
|
+
const factors = this.computeFactors(ctx, frequencyTracker);
|
|
44
|
+
const total = clamp(factors.reduce((sum, f) => sum + f.value, 0), 0, 100);
|
|
45
|
+
return { level: scoreToRiskLevel(total), score: Math.round(total), factors };
|
|
46
|
+
}
|
|
47
|
+
computeFactors(ctx, frequencyTracker) {
|
|
48
|
+
const toolRaw = lookupToolRisk(ctx.toolName, this.overrides);
|
|
49
|
+
const isOff = ctx.time.hour < 8 || ctx.time.hour >= 23;
|
|
50
|
+
const recentCount = frequencyTracker.count(60, "agent", ctx.agentId, ctx.sessionKey);
|
|
51
|
+
return [
|
|
52
|
+
{
|
|
53
|
+
name: "tool_sensitivity", weight: 30,
|
|
54
|
+
value: (toolRaw / 100) * 30,
|
|
55
|
+
description: `Tool ${ctx.toolName ?? "unknown"} risk=${toolRaw}`,
|
|
56
|
+
},
|
|
57
|
+
{
|
|
58
|
+
name: "time_of_day", weight: 15,
|
|
59
|
+
value: isOff ? 15 : 0,
|
|
60
|
+
description: isOff ? "Off-hours operation" : "Business hours",
|
|
61
|
+
},
|
|
62
|
+
{
|
|
63
|
+
name: "trust_deficit", weight: 20,
|
|
64
|
+
value: ((100 - ctx.trust.score) / 100) * 20,
|
|
65
|
+
description: `Trust score ${ctx.trust.score}/100`,
|
|
66
|
+
},
|
|
67
|
+
{
|
|
68
|
+
name: "frequency", weight: 15,
|
|
69
|
+
value: Math.min(recentCount / 20, 1) * 15,
|
|
70
|
+
description: `${recentCount} actions in last 60s`,
|
|
71
|
+
},
|
|
72
|
+
{
|
|
73
|
+
name: "target_scope", weight: 20,
|
|
74
|
+
value: isExternalTarget(ctx) ? 20 : 0,
|
|
75
|
+
description: isExternalTarget(ctx) ? "External target" : "Internal target",
|
|
76
|
+
},
|
|
77
|
+
];
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
//# sourceMappingURL=risk-assessor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"risk-assessor.js","sourceRoot":"","sources":["../../src/risk-assessor.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import type { AgentTrust, PluginLogger, TrustConfig, TrustStore, TrustTier } from "./types.js";
|
|
2
|
+
export declare class TrustManager {
|
|
3
|
+
private readonly config;
|
|
4
|
+
private readonly filePath;
|
|
5
|
+
private readonly logger;
|
|
6
|
+
private readonly weights;
|
|
7
|
+
private store;
|
|
8
|
+
private persistTimer;
|
|
9
|
+
private dirty;
|
|
10
|
+
constructor(config: TrustConfig, workspace: string, logger: PluginLogger);
|
|
11
|
+
load(): void;
|
|
12
|
+
private applyDecay;
|
|
13
|
+
getAgentTrust(agentId: string): AgentTrust;
|
|
14
|
+
private resolveDefault;
|
|
15
|
+
getStore(): TrustStore;
|
|
16
|
+
recordSuccess(agentId: string, reason?: string): void;
|
|
17
|
+
recordViolation(agentId: string, reason?: string): void;
|
|
18
|
+
setScore(agentId: string, score: number): void;
|
|
19
|
+
lockTier(agentId: string, tier: TrustTier): void;
|
|
20
|
+
unlockTier(agentId: string): void;
|
|
21
|
+
setFloor(agentId: string, floor: number): void;
|
|
22
|
+
resetHistory(agentId: string): void;
|
|
23
|
+
private addEvent;
|
|
24
|
+
private recalculate;
|
|
25
|
+
flush(): void;
|
|
26
|
+
startPersistence(): void;
|
|
27
|
+
stopPersistence(): void;
|
|
28
|
+
}
|
|
29
|
+
//# sourceMappingURL=trust-manager.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"trust-manager.d.ts","sourceRoot":"","sources":["../../src/trust-manager.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EACV,UAAU,EACV,YAAY,EACZ,WAAW,EAGX,UAAU,EACV,SAAS,EAEV,MAAM,YAAY,CAAC;AAuDpB,qBAAa,YAAY;IACvB,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAc;IACrC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAS;IAClC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAe;IACtC,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAe;IACvC,OAAO,CAAC,KAAK,CAAa;IAC1B,OAAO,CAAC,YAAY,CAA+C;IACnE,OAAO,CAAC,KAAK,CAAS;gBAEV,MAAM,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,YAAY;IAQxE,IAAI,IAAI,IAAI;IAkBZ,OAAO,CAAC,UAAU;IAmBlB,aAAa,CAAC,OAAO,EAAE,MAAM,GAAG,UAAU;IAW1C,OAAO,CAAC,cAAc;IAQtB,QAAQ,IAAI,UAAU;IAItB,aAAa,CAAC,OAAO,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,GAAG,IAAI;IAQrD,eAAe,CAAC,OAAO,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,GAAG,IAAI;IAQvD,QAAQ,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,IAAI;IAc9C,QAAQ,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,SAAS,GAAG,IAAI;IAOhD,UAAU,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI;IAOjC,QAAQ,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,IAAI;IAU9C,YAAY,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI;IAanC,OAAO,CAAC,QAAQ;IAkBhB,OAAO,CAAC,WAAW;IAanB,KAAK,IAAI,IAAI;IAiBb,gBAAgB,IAAI,IAAI;IASxB,eAAe,IAAI,IAAI;CAOxB"}
|