@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.
Files changed (83) hide show
  1. package/README.md +297 -0
  2. package/dist/index.d.ts +10 -0
  3. package/dist/index.d.ts.map +1 -0
  4. package/dist/index.js +30 -0
  5. package/dist/index.js.map +1 -0
  6. package/dist/src/audit-redactor.d.ts +3 -0
  7. package/dist/src/audit-redactor.d.ts.map +1 -0
  8. package/dist/src/audit-redactor.js +68 -0
  9. package/dist/src/audit-redactor.js.map +1 -0
  10. package/dist/src/audit-trail.d.ts +27 -0
  11. package/dist/src/audit-trail.d.ts.map +1 -0
  12. package/dist/src/audit-trail.js +192 -0
  13. package/dist/src/audit-trail.js.map +1 -0
  14. package/dist/src/builtin-policies.d.ts +3 -0
  15. package/dist/src/builtin-policies.d.ts.map +1 -0
  16. package/dist/src/builtin-policies.js +152 -0
  17. package/dist/src/builtin-policies.js.map +1 -0
  18. package/dist/src/conditions/context.d.ts +3 -0
  19. package/dist/src/conditions/context.d.ts.map +1 -0
  20. package/dist/src/conditions/context.js +60 -0
  21. package/dist/src/conditions/context.js.map +1 -0
  22. package/dist/src/conditions/index.d.ts +4 -0
  23. package/dist/src/conditions/index.d.ts.map +1 -0
  24. package/dist/src/conditions/index.js +28 -0
  25. package/dist/src/conditions/index.js.map +1 -0
  26. package/dist/src/conditions/simple.d.ts +10 -0
  27. package/dist/src/conditions/simple.d.ts.map +1 -0
  28. package/dist/src/conditions/simple.js +94 -0
  29. package/dist/src/conditions/simple.js.map +1 -0
  30. package/dist/src/conditions/time.d.ts +3 -0
  31. package/dist/src/conditions/time.d.ts.map +1 -0
  32. package/dist/src/conditions/time.js +48 -0
  33. package/dist/src/conditions/time.js.map +1 -0
  34. package/dist/src/conditions/tool.d.ts +3 -0
  35. package/dist/src/conditions/tool.d.ts.map +1 -0
  36. package/dist/src/conditions/tool.js +57 -0
  37. package/dist/src/conditions/tool.js.map +1 -0
  38. package/dist/src/config.d.ts +3 -0
  39. package/dist/src/config.d.ts.map +1 -0
  40. package/dist/src/config.js +80 -0
  41. package/dist/src/config.js.map +1 -0
  42. package/dist/src/cross-agent.d.ts +23 -0
  43. package/dist/src/cross-agent.d.ts.map +1 -0
  44. package/dist/src/cross-agent.js +142 -0
  45. package/dist/src/cross-agent.js.map +1 -0
  46. package/dist/src/engine.d.ts +29 -0
  47. package/dist/src/engine.d.ts.map +1 -0
  48. package/dist/src/engine.js +195 -0
  49. package/dist/src/engine.js.map +1 -0
  50. package/dist/src/frequency-tracker.d.ts +12 -0
  51. package/dist/src/frequency-tracker.d.ts.map +1 -0
  52. package/dist/src/frequency-tracker.js +44 -0
  53. package/dist/src/frequency-tracker.js.map +1 -0
  54. package/dist/src/hooks.d.ts +4 -0
  55. package/dist/src/hooks.d.ts.map +1 -0
  56. package/dist/src/hooks.js +198 -0
  57. package/dist/src/hooks.js.map +1 -0
  58. package/dist/src/policy-evaluator.d.ts +16 -0
  59. package/dist/src/policy-evaluator.d.ts.map +1 -0
  60. package/dist/src/policy-evaluator.js +99 -0
  61. package/dist/src/policy-evaluator.js.map +1 -0
  62. package/dist/src/policy-loader.d.ts +8 -0
  63. package/dist/src/policy-loader.d.ts.map +1 -0
  64. package/dist/src/policy-loader.js +105 -0
  65. package/dist/src/policy-loader.js.map +1 -0
  66. package/dist/src/risk-assessor.d.ts +8 -0
  67. package/dist/src/risk-assessor.d.ts.map +1 -0
  68. package/dist/src/risk-assessor.js +80 -0
  69. package/dist/src/risk-assessor.js.map +1 -0
  70. package/dist/src/trust-manager.d.ts +29 -0
  71. package/dist/src/trust-manager.d.ts.map +1 -0
  72. package/dist/src/trust-manager.js +219 -0
  73. package/dist/src/trust-manager.js.map +1 -0
  74. package/dist/src/types.d.ts +438 -0
  75. package/dist/src/types.d.ts.map +1 -0
  76. package/dist/src/types.js +3 -0
  77. package/dist/src/types.js.map +1 -0
  78. package/dist/src/util.d.ts +28 -0
  79. package/dist/src/util.d.ts.map +1 -0
  80. package/dist/src/util.js +125 -0
  81. package/dist/src/util.js.map +1 -0
  82. package/openclaw.plugin.json +87 -0
  83. 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":"AAOA,OAAO,EAAE,KAAK,EAAE,MAAM,WAAW,CAAC;AAElC,MAAM,iBAAiB,GAA2B;IAChD,OAAO,EAAE,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,QAAQ,EAAE,EAAE;IACnC,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,IAAI,EAAE,EAAE;IAC7B,cAAc,EAAE,EAAE,EAAE,aAAa,EAAE,EAAE;IACrC,OAAO,EAAE,EAAE,EAAE,OAAO,EAAE,EAAE;IACxB,IAAI,EAAE,EAAE,EAAE,aAAa,EAAE,CAAC,EAAE,UAAU,EAAE,CAAC;IACzC,UAAU,EAAE,EAAE,EAAE,SAAS,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE;CACrD,CAAC;AAEF,SAAS,cAAc,CACrB,QAA4B,EAC5B,SAAiC;IAEjC,IAAI,CAAC,QAAQ;QAAE,OAAO,EAAE,CAAC;IACzB,MAAM,QAAQ,GAAG,SAAS,CAAC,QAAQ,CAAC,CAAC;IACrC,IAAI,QAAQ,KAAK,SAAS;QAAE,OAAO,QAAQ,CAAC;IAC5C,OAAO,iBAAiB,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;AAC3C,CAAC;AAED,SAAS,gBAAgB,CAAC,GAAsB;IAC9C,IAAI,GAAG,CAAC,SAAS;QAAE,OAAO,IAAI,CAAC;IAC/B,IAAI,CAAC,GAAG,CAAC,UAAU;QAAE,OAAO,KAAK,CAAC;IAClC,MAAM,IAAI,GAAG,GAAG,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;IACpC,IAAI,OAAO,IAAI,KAAK,QAAQ,IAAI,IAAI,KAAK,SAAS;QAAE,OAAO,IAAI,CAAC;IAChE,OAAO,GAAG,CAAC,UAAU,CAAC,UAAU,CAAC,KAAK,IAAI,CAAC;AAC7C,CAAC;AAED,SAAS,gBAAgB,CAAC,KAAa;IACrC,IAAI,KAAK,IAAI,EAAE;QAAE,OAAO,KAAK,CAAC;IAC9B,IAAI,KAAK,IAAI,EAAE;QAAE,OAAO,QAAQ,CAAC;IACjC,IAAI,KAAK,IAAI,EAAE;QAAE,OAAO,MAAM,CAAC;IAC/B,OAAO,UAAU,CAAC;AACpB,CAAC;AAED,MAAM,OAAO,YAAY;IACN,SAAS,CAAyB;IAEnD,YAAY,iBAAyC;QACnD,IAAI,CAAC,SAAS,GAAG,iBAAiB,CAAC;IACrC,CAAC;IAED,MAAM,CACJ,GAAsB,EACtB,gBAAkC;QAElC,MAAM,OAAO,GAAG,IAAI,CAAC,cAAc,CAAC,GAAG,EAAE,gBAAgB,CAAC,CAAC;QAC3D,MAAM,KAAK,GAAG,KAAK,CACjB,OAAO,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,GAAG,CACrD,CAAC;QACF,OAAO,EAAE,KAAK,EAAE,gBAAgB,CAAC,KAAK,CAAC,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC;IAC/E,CAAC;IAEO,cAAc,CACpB,GAAsB,EACtB,gBAAkC;QAElC,MAAM,OAAO,GAAG,cAAc,CAAC,GAAG,CAAC,QAAQ,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;QAC7D,MAAM,KAAK,GAAG,GAAG,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC,IAAI,GAAG,CAAC,IAAI,CAAC,IAAI,IAAI,EAAE,CAAC;QACvD,MAAM,WAAW,GAAG,gBAAgB,CAAC,KAAK,CACxC,EAAE,EAAE,OAAO,EAAE,GAAG,CAAC,OAAO,EAAE,GAAG,CAAC,UAAU,CACzC,CAAC;QAEF,OAAO;YACL;gBACE,IAAI,EAAE,kBAAkB,EAAE,MAAM,EAAE,EAAE;gBACpC,KAAK,EAAE,CAAC,OAAO,GAAG,GAAG,CAAC,GAAG,EAAE;gBAC3B,WAAW,EAAE,QAAQ,GAAG,CAAC,QAAQ,IAAI,SAAS,SAAS,OAAO,EAAE;aACjE;YACD;gBACE,IAAI,EAAE,aAAa,EAAE,MAAM,EAAE,EAAE;gBAC/B,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;gBACrB,WAAW,EAAE,KAAK,CAAC,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,gBAAgB;aAC9D;YACD;gBACE,IAAI,EAAE,eAAe,EAAE,MAAM,EAAE,EAAE;gBACjC,KAAK,EAAE,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,GAAG,CAAC,GAAG,EAAE;gBAC3C,WAAW,EAAE,eAAe,GAAG,CAAC,KAAK,CAAC,KAAK,MAAM;aAClD;YACD;gBACE,IAAI,EAAE,WAAW,EAAE,MAAM,EAAE,EAAE;gBAC7B,KAAK,EAAE,IAAI,CAAC,GAAG,CAAC,WAAW,GAAG,EAAE,EAAE,CAAC,CAAC,GAAG,EAAE;gBACzC,WAAW,EAAE,GAAG,WAAW,sBAAsB;aAClD;YACD;gBACE,IAAI,EAAE,cAAc,EAAE,MAAM,EAAE,EAAE;gBAChC,KAAK,EAAE,gBAAgB,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;gBACrC,WAAW,EAAE,gBAAgB,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,iBAAiB;aAC3E;SACF,CAAC;IACJ,CAAC;CACF"}
@@ -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"}