tryassay 0.3.0 → 0.11.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 (150) hide show
  1. package/dist/api/pricing-enforcer.d.ts +45 -0
  2. package/dist/api/pricing-enforcer.js +144 -0
  3. package/dist/api/pricing-enforcer.js.map +1 -0
  4. package/dist/api/server.d.ts +28 -0
  5. package/dist/api/server.js +265 -0
  6. package/dist/api/server.js.map +1 -0
  7. package/dist/api/team-session.d.ts +59 -0
  8. package/dist/api/team-session.js +240 -0
  9. package/dist/api/team-session.js.map +1 -0
  10. package/dist/cli.js +142 -2
  11. package/dist/cli.js.map +1 -1
  12. package/dist/commands/api.d.ts +4 -0
  13. package/dist/commands/api.js +50 -0
  14. package/dist/commands/api.js.map +1 -0
  15. package/dist/commands/runtime.d.ts +69 -0
  16. package/dist/commands/runtime.js +673 -0
  17. package/dist/commands/runtime.js.map +1 -1
  18. package/dist/runtime/agent-loop.d.ts +6 -0
  19. package/dist/runtime/agent-loop.js +87 -5
  20. package/dist/runtime/agent-loop.js.map +1 -1
  21. package/dist/runtime/agent-spawner.d.ts +56 -0
  22. package/dist/runtime/agent-spawner.js +217 -0
  23. package/dist/runtime/agent-spawner.js.map +1 -0
  24. package/dist/runtime/agents/code-agent.d.ts +11 -0
  25. package/dist/runtime/agents/code-agent.js +90 -0
  26. package/dist/runtime/agents/code-agent.js.map +1 -0
  27. package/dist/runtime/agents/coordinator-agent.d.ts +20 -0
  28. package/dist/runtime/agents/coordinator-agent.js +182 -0
  29. package/dist/runtime/agents/coordinator-agent.js.map +1 -0
  30. package/dist/runtime/agents/ops-agent.d.ts +11 -0
  31. package/dist/runtime/agents/ops-agent.js +113 -0
  32. package/dist/runtime/agents/ops-agent.js.map +1 -0
  33. package/dist/runtime/agents/research-agent.d.ts +11 -0
  34. package/dist/runtime/agents/research-agent.js +114 -0
  35. package/dist/runtime/agents/research-agent.js.map +1 -0
  36. package/dist/runtime/agents/review-agent.d.ts +11 -0
  37. package/dist/runtime/agents/review-agent.js +96 -0
  38. package/dist/runtime/agents/review-agent.js.map +1 -0
  39. package/dist/runtime/agents/test-agent.d.ts +11 -0
  40. package/dist/runtime/agents/test-agent.js +114 -0
  41. package/dist/runtime/agents/test-agent.js.map +1 -0
  42. package/dist/runtime/capability-registry.d.ts +62 -0
  43. package/dist/runtime/capability-registry.js +191 -0
  44. package/dist/runtime/capability-registry.js.map +1 -0
  45. package/dist/runtime/collusion-detector.d.ts +35 -0
  46. package/dist/runtime/collusion-detector.js +97 -0
  47. package/dist/runtime/collusion-detector.js.map +1 -0
  48. package/dist/runtime/composition-verifier.d.ts +22 -0
  49. package/dist/runtime/composition-verifier.js +265 -0
  50. package/dist/runtime/composition-verifier.js.map +1 -0
  51. package/dist/runtime/confidence-calibrator.d.ts +10 -0
  52. package/dist/runtime/confidence-calibrator.js +95 -0
  53. package/dist/runtime/confidence-calibrator.js.map +1 -0
  54. package/dist/runtime/domain-coverage-analyzer.d.ts +24 -0
  55. package/dist/runtime/domain-coverage-analyzer.js +178 -0
  56. package/dist/runtime/domain-coverage-analyzer.js.map +1 -0
  57. package/dist/runtime/enriched-prompt-builder.d.ts +25 -0
  58. package/dist/runtime/enriched-prompt-builder.js +173 -0
  59. package/dist/runtime/enriched-prompt-builder.js.map +1 -0
  60. package/dist/runtime/gap-detector.d.ts +6 -0
  61. package/dist/runtime/gap-detector.js +111 -0
  62. package/dist/runtime/gap-detector.js.map +1 -0
  63. package/dist/runtime/human-escalation.d.ts +41 -0
  64. package/dist/runtime/human-escalation.js +122 -0
  65. package/dist/runtime/human-escalation.js.map +1 -0
  66. package/dist/runtime/kill-switch.d.ts +51 -0
  67. package/dist/runtime/kill-switch.js +185 -0
  68. package/dist/runtime/kill-switch.js.map +1 -0
  69. package/dist/runtime/layer2-guardian.d.ts +81 -0
  70. package/dist/runtime/layer2-guardian.js +263 -0
  71. package/dist/runtime/layer2-guardian.js.map +1 -0
  72. package/dist/runtime/message-bus.d.ts +57 -0
  73. package/dist/runtime/message-bus.js +115 -0
  74. package/dist/runtime/message-bus.js.map +1 -0
  75. package/dist/runtime/multi-agent-loop.d.ts +37 -0
  76. package/dist/runtime/multi-agent-loop.js +411 -0
  77. package/dist/runtime/multi-agent-loop.js.map +1 -0
  78. package/dist/runtime/pattern-extractor.d.ts +20 -0
  79. package/dist/runtime/pattern-extractor.js +257 -0
  80. package/dist/runtime/pattern-extractor.js.map +1 -0
  81. package/dist/runtime/planner.d.ts +2 -2
  82. package/dist/runtime/planner.js +10 -7
  83. package/dist/runtime/planner.js.map +1 -1
  84. package/dist/runtime/prompt-safety-analyzer.d.ts +17 -0
  85. package/dist/runtime/prompt-safety-analyzer.js +230 -0
  86. package/dist/runtime/prompt-safety-analyzer.js.map +1 -0
  87. package/dist/runtime/reasoner.d.ts +2 -2
  88. package/dist/runtime/reasoner.js +9 -5
  89. package/dist/runtime/reasoner.js.map +1 -1
  90. package/dist/runtime/reflector.d.ts +7 -1
  91. package/dist/runtime/reflector.js.map +1 -1
  92. package/dist/runtime/rollback-manager.d.ts +50 -0
  93. package/dist/runtime/rollback-manager.js +157 -0
  94. package/dist/runtime/rollback-manager.js.map +1 -0
  95. package/dist/runtime/rule-canary-deployer.d.ts +69 -0
  96. package/dist/runtime/rule-canary-deployer.js +289 -0
  97. package/dist/runtime/rule-canary-deployer.js.map +1 -0
  98. package/dist/runtime/rule-conflict-detector.d.ts +48 -0
  99. package/dist/runtime/rule-conflict-detector.js +214 -0
  100. package/dist/runtime/rule-conflict-detector.js.map +1 -0
  101. package/dist/runtime/rule-meta-verifier.d.ts +18 -0
  102. package/dist/runtime/rule-meta-verifier.js +275 -0
  103. package/dist/runtime/rule-meta-verifier.js.map +1 -0
  104. package/dist/runtime/rule-proposal-manager.d.ts +95 -0
  105. package/dist/runtime/rule-proposal-manager.js +190 -0
  106. package/dist/runtime/rule-proposal-manager.js.map +1 -0
  107. package/dist/runtime/safety-enforcer.d.ts +35 -0
  108. package/dist/runtime/safety-enforcer.js +165 -0
  109. package/dist/runtime/safety-enforcer.js.map +1 -0
  110. package/dist/runtime/safety-status.d.ts +48 -0
  111. package/dist/runtime/safety-status.js +119 -0
  112. package/dist/runtime/safety-status.js.map +1 -0
  113. package/dist/runtime/shadow-runner.d.ts +14 -0
  114. package/dist/runtime/shadow-runner.js +190 -0
  115. package/dist/runtime/shadow-runner.js.map +1 -0
  116. package/dist/runtime/shared-memory.d.ts +47 -0
  117. package/dist/runtime/shared-memory.js +151 -0
  118. package/dist/runtime/shared-memory.js.map +1 -0
  119. package/dist/runtime/specialized-agent.d.ts +72 -0
  120. package/dist/runtime/specialized-agent.js +123 -0
  121. package/dist/runtime/specialized-agent.js.map +1 -0
  122. package/dist/runtime/stall-detector.d.ts +13 -0
  123. package/dist/runtime/stall-detector.js +121 -0
  124. package/dist/runtime/stall-detector.js.map +1 -0
  125. package/dist/runtime/strategy-library.d.ts +11 -0
  126. package/dist/runtime/strategy-library.js +142 -0
  127. package/dist/runtime/strategy-library.js.map +1 -0
  128. package/dist/runtime/supabase-experience-store.d.ts +19 -0
  129. package/dist/runtime/supabase-experience-store.js +215 -0
  130. package/dist/runtime/supabase-experience-store.js.map +1 -0
  131. package/dist/runtime/tool-approval.d.ts +51 -0
  132. package/dist/runtime/tool-approval.js +148 -0
  133. package/dist/runtime/tool-approval.js.map +1 -0
  134. package/dist/runtime/tool-sandbox.d.ts +43 -0
  135. package/dist/runtime/tool-sandbox.js +394 -0
  136. package/dist/runtime/tool-sandbox.js.map +1 -0
  137. package/dist/runtime/tool-verifier.d.ts +18 -0
  138. package/dist/runtime/tool-verifier.js +323 -0
  139. package/dist/runtime/tool-verifier.js.map +1 -0
  140. package/dist/runtime/trust-manager.d.ts +63 -0
  141. package/dist/runtime/trust-manager.js +212 -0
  142. package/dist/runtime/trust-manager.js.map +1 -0
  143. package/dist/runtime/two-agent-loop.d.ts +35 -0
  144. package/dist/runtime/two-agent-loop.js +208 -0
  145. package/dist/runtime/two-agent-loop.js.map +1 -0
  146. package/dist/runtime/types.d.ts +939 -1
  147. package/dist/runtime/verification-intensity.d.ts +34 -0
  148. package/dist/runtime/verification-intensity.js +104 -0
  149. package/dist/runtime/verification-intensity.js.map +1 -0
  150. package/package.json +1 -1
@@ -0,0 +1,257 @@
1
+ // ============================================================
2
+ // Assay Verified Agent Runtime — Pattern Extractor
3
+ // Processes experience clusters into structured learning artifacts.
4
+ // ============================================================
5
+ import { randomUUID } from 'node:crypto';
6
+ import { getClient, MODEL } from '../lib/anthropic.js';
7
+ export class PatternExtractor {
8
+ async extract(experiences, filter) {
9
+ let filtered = experiences;
10
+ if (filter?.domain) {
11
+ filtered = filtered.filter(e => e.domain === filter.domain);
12
+ }
13
+ if (filter?.since) {
14
+ const since = new Date(filter.since).getTime();
15
+ filtered = filtered.filter(e => new Date(e.timestamp).getTime() >= since);
16
+ }
17
+ if (filtered.length === 0) {
18
+ return {
19
+ patterns: [],
20
+ antiPatterns: [],
21
+ skillProfiles: [],
22
+ verificationHotspots: [],
23
+ extractedAt: new Date().toISOString(),
24
+ };
25
+ }
26
+ // Group by domain for parallel extraction
27
+ const byDomain = new Map();
28
+ for (const exp of filtered) {
29
+ const group = byDomain.get(exp.domain) ?? [];
30
+ group.push(exp);
31
+ byDomain.set(exp.domain, group);
32
+ }
33
+ const allPatterns = [];
34
+ const allAntiPatterns = [];
35
+ const allProfiles = [];
36
+ const allHotspots = [];
37
+ for (const [domain, domainExps] of byDomain) {
38
+ // Extract patterns and anti-patterns via Claude
39
+ const { patterns, antiPatterns } = await this.extractPatternsFromCluster(domain, domainExps);
40
+ allPatterns.push(...patterns);
41
+ allAntiPatterns.push(...antiPatterns);
42
+ // Compute skill profile directly from data
43
+ allProfiles.push(this.computeSkillProfile(domain, domainExps));
44
+ // Compute verification hotspots from claim data
45
+ const hotspots = this.computeHotspots(domainExps);
46
+ allHotspots.push(...hotspots);
47
+ }
48
+ return {
49
+ patterns: allPatterns,
50
+ antiPatterns: allAntiPatterns,
51
+ skillProfiles: allProfiles,
52
+ verificationHotspots: this.deduplicateHotspots(allHotspots),
53
+ extractedAt: new Date().toISOString(),
54
+ };
55
+ }
56
+ async extractPatternsFromCluster(domain, experiences) {
57
+ const successes = experiences.filter(e => e.outcome === 'success');
58
+ const failures = experiences.filter(e => e.outcome === 'failure' || e.outcome === 'partial_success');
59
+ const summaries = experiences.map(e => ({
60
+ id: e.id,
61
+ outcome: e.outcome,
62
+ lessons: e.lessons,
63
+ delta: e.delta,
64
+ planSteps: e.plan.steps.map(s => s.description).slice(0, 5),
65
+ verificationFails: e.verification.failedClaims,
66
+ }));
67
+ const client = getClient();
68
+ const response = await client.messages.create({
69
+ model: MODEL,
70
+ max_tokens: 4096,
71
+ system: `You analyze agent experience data to extract reusable patterns and anti-patterns.
72
+ Respond with ONLY a JSON object. No markdown fences, no explanation.`,
73
+ messages: [{
74
+ role: 'user',
75
+ content: `Analyze these ${experiences.length} experiences in the "${domain}" domain.
76
+
77
+ EXPERIENCES:
78
+ ${JSON.stringify(summaries, null, 2)}
79
+
80
+ Extract:
81
+ 1. PATTERNS: Approaches that led to success (from the ${successes.length} successful experiences)
82
+ 2. ANTI-PATTERNS: Approaches that led to failure (from the ${failures.length} failed experiences)
83
+
84
+ Respond with JSON:
85
+ {
86
+ "patterns": [
87
+ {
88
+ "description": "what works and why",
89
+ "codeExample": "brief code showing the pattern (or empty string if not applicable)",
90
+ "language": "typescript"
91
+ }
92
+ ],
93
+ "antiPatterns": [
94
+ {
95
+ "description": "what fails and why",
96
+ "badExample": "code showing the anti-pattern",
97
+ "fixedExample": "code showing the fix",
98
+ "language": "typescript",
99
+ "claimCategory": "which claim category this relates to (e.g., error-handling, security)"
100
+ }
101
+ ]
102
+ }`,
103
+ }],
104
+ });
105
+ const text = response.content[0].type === 'text' ? response.content[0].text : '';
106
+ try {
107
+ let cleaned = text.trim();
108
+ if (cleaned.startsWith('```')) {
109
+ cleaned = cleaned.replace(/^```(?:json)?\s*/, '').replace(/\s*```$/, '');
110
+ }
111
+ const parsed = JSON.parse(cleaned);
112
+ const sourceIds = experiences.map(e => e.id);
113
+ const patterns = (parsed.patterns ?? []).map(p => ({
114
+ id: randomUUID(),
115
+ domain,
116
+ description: p.description,
117
+ codeExample: p.codeExample ?? '',
118
+ language: p.language ?? 'typescript',
119
+ verificationCount: successes.length,
120
+ lastVerified: new Date().toISOString(),
121
+ formallyVerified: false,
122
+ }));
123
+ const antiPatterns = (parsed.antiPatterns ?? []).map(ap => ({
124
+ id: randomUUID(),
125
+ domain,
126
+ description: ap.description,
127
+ badExample: ap.badExample ?? '',
128
+ fixedExample: ap.fixedExample ?? '',
129
+ language: ap.language ?? 'typescript',
130
+ claimCategory: ap.claimCategory ?? 'general',
131
+ occurrenceCount: failures.length,
132
+ lastSeen: new Date().toISOString(),
133
+ }));
134
+ return { patterns, antiPatterns };
135
+ }
136
+ catch {
137
+ return { patterns: [], antiPatterns: [] };
138
+ }
139
+ }
140
+ computeSkillProfile(domain, experiences) {
141
+ const total = experiences.length;
142
+ const successes = experiences.filter(e => e.outcome === 'success').length;
143
+ const firstPass = experiences.filter(e => e.verification.blockedSteps.length === 0 &&
144
+ e.verification.escalatedSteps.length === 0 &&
145
+ e.verification.failedClaims === 0).length;
146
+ const successLessons = experiences
147
+ .filter(e => e.outcome === 'success')
148
+ .flatMap(e => e.lessons);
149
+ const failureLessons = experiences
150
+ .filter(e => e.outcome !== 'success')
151
+ .flatMap(e => e.lessons);
152
+ return {
153
+ domain,
154
+ totalExperiences: total,
155
+ successRate: total > 0 ? successes / total : 0,
156
+ firstPassRate: total > 0 ? firstPass / total : 0,
157
+ commonPatterns: this.topN(successLessons, 3),
158
+ commonAntiPatterns: this.topN(failureLessons, 3),
159
+ lastUpdated: new Date().toISOString(),
160
+ };
161
+ }
162
+ computeHotspots(experiences) {
163
+ // Aggregate claim-level data from verification results
164
+ const categoryStats = new Map();
165
+ for (const exp of experiences) {
166
+ for (const sv of exp.verification.stepVerifications) {
167
+ for (const claim of sv.claims) {
168
+ // Extract category from claim text heuristically
169
+ const category = this.inferClaimCategory(claim.text);
170
+ const stats = categoryStats.get(category) ?? {
171
+ total: 0, failed: 0, formal: 0, failReasons: [],
172
+ };
173
+ stats.total++;
174
+ if (claim.verdict === 'FAIL') {
175
+ stats.failed++;
176
+ stats.failReasons.push(claim.text.slice(0, 100));
177
+ }
178
+ if (claim.method === 'formal') {
179
+ stats.formal++;
180
+ }
181
+ categoryStats.set(category, stats);
182
+ }
183
+ }
184
+ }
185
+ const hotspots = [];
186
+ for (const [category, stats] of categoryStats) {
187
+ if (stats.total < 3)
188
+ continue; // skip noisy small samples
189
+ const failRate = stats.failed / stats.total;
190
+ const formalCoverage = stats.formal / stats.total;
191
+ hotspots.push({
192
+ claimCategory: category,
193
+ failRate,
194
+ totalClaims: stats.total,
195
+ failedClaims: stats.failed,
196
+ formalCoverage,
197
+ topFailureReasons: this.topN(stats.failReasons, 3),
198
+ candidateForFormalRule: failRate > 0.2 && formalCoverage < 0.1 && stats.total >= 10,
199
+ });
200
+ }
201
+ return hotspots;
202
+ }
203
+ inferClaimCategory(claimText) {
204
+ const lower = claimText.toLowerCase();
205
+ if (lower.includes('error') || lower.includes('exception') || lower.includes('throw'))
206
+ return 'error-handling';
207
+ if (lower.includes('null') || lower.includes('undefined') || lower.includes('optional'))
208
+ return 'null-safety';
209
+ if (lower.includes('sql') || lower.includes('inject') || lower.includes('xss') || lower.includes('auth'))
210
+ return 'security';
211
+ if (lower.includes('type') || lower.includes('cast') || lower.includes('assertion'))
212
+ return 'type-safety';
213
+ if (lower.includes('valid') || lower.includes('input') || lower.includes('sanitiz'))
214
+ return 'input-validation';
215
+ if (lower.includes('return') || lower.includes('output') || lower.includes('correct'))
216
+ return 'correctness';
217
+ if (lower.includes('edge') || lower.includes('boundar') || lower.includes('empty'))
218
+ return 'edge-cases';
219
+ if (lower.includes('perform') || lower.includes('timeout') || lower.includes('latency'))
220
+ return 'performance';
221
+ return 'general';
222
+ }
223
+ deduplicateHotspots(hotspots) {
224
+ const merged = new Map();
225
+ for (const h of hotspots) {
226
+ const existing = merged.get(h.claimCategory);
227
+ if (!existing) {
228
+ merged.set(h.claimCategory, h);
229
+ }
230
+ else {
231
+ // Merge stats
232
+ const total = existing.totalClaims + h.totalClaims;
233
+ const failed = existing.failedClaims + h.failedClaims;
234
+ merged.set(h.claimCategory, {
235
+ ...existing,
236
+ totalClaims: total,
237
+ failedClaims: failed,
238
+ failRate: total > 0 ? failed / total : 0,
239
+ topFailureReasons: [...existing.topFailureReasons, ...h.topFailureReasons].slice(0, 5),
240
+ candidateForFormalRule: (failed / total) > 0.2 && existing.formalCoverage < 0.1 && total >= 10,
241
+ });
242
+ }
243
+ }
244
+ return Array.from(merged.values());
245
+ }
246
+ topN(items, n) {
247
+ const counts = new Map();
248
+ for (const item of items) {
249
+ counts.set(item, (counts.get(item) ?? 0) + 1);
250
+ }
251
+ return Array.from(counts.entries())
252
+ .sort((a, b) => b[1] - a[1])
253
+ .slice(0, n)
254
+ .map(([text]) => text);
255
+ }
256
+ }
257
+ //# sourceMappingURL=pattern-extractor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pattern-extractor.js","sourceRoot":"","sources":["../../src/runtime/pattern-extractor.ts"],"names":[],"mappings":"AAAA,+DAA+D;AAC/D,mDAAmD;AACnD,oEAAoE;AACpE,+DAA+D;AAE/D,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AACzC,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,qBAAqB,CAAC;AAiBvD,MAAM,OAAO,gBAAgB;IAC3B,KAAK,CAAC,OAAO,CACX,WAAyB,EACzB,MAA4C;QAE5C,IAAI,QAAQ,GAAG,WAAW,CAAC;QAE3B,IAAI,MAAM,EAAE,MAAM,EAAE,CAAC;YACnB,QAAQ,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,MAAM,CAAC,MAAM,CAAC,CAAC;QAC9D,CAAC;QACD,IAAI,MAAM,EAAE,KAAK,EAAE,CAAC;YAClB,MAAM,KAAK,GAAG,IAAI,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,OAAO,EAAE,CAAC;YAC/C,QAAQ,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,OAAO,EAAE,IAAI,KAAK,CAAC,CAAC;QAC5E,CAAC;QAED,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC1B,OAAO;gBACL,QAAQ,EAAE,EAAE;gBACZ,YAAY,EAAE,EAAE;gBAChB,aAAa,EAAE,EAAE;gBACjB,oBAAoB,EAAE,EAAE;gBACxB,WAAW,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;aACtC,CAAC;QACJ,CAAC;QAED,0CAA0C;QAC1C,MAAM,QAAQ,GAAG,IAAI,GAAG,EAAwB,CAAC;QACjD,KAAK,MAAM,GAAG,IAAI,QAAQ,EAAE,CAAC;YAC3B,MAAM,KAAK,GAAG,QAAQ,CAAC,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;YAC7C,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAChB,QAAQ,CAAC,GAAG,CAAC,GAAG,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;QAClC,CAAC;QAED,MAAM,WAAW,GAAmB,EAAE,CAAC;QACvC,MAAM,eAAe,GAAuB,EAAE,CAAC;QAC/C,MAAM,WAAW,GAAmB,EAAE,CAAC;QACvC,MAAM,WAAW,GAA0B,EAAE,CAAC;QAE9C,KAAK,MAAM,CAAC,MAAM,EAAE,UAAU,CAAC,IAAI,QAAQ,EAAE,CAAC;YAC5C,gDAAgD;YAChD,MAAM,EAAE,QAAQ,EAAE,YAAY,EAAE,GAAG,MAAM,IAAI,CAAC,0BAA0B,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC;YAC7F,WAAW,CAAC,IAAI,CAAC,GAAG,QAAQ,CAAC,CAAC;YAC9B,eAAe,CAAC,IAAI,CAAC,GAAG,YAAY,CAAC,CAAC;YAEtC,2CAA2C;YAC3C,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,mBAAmB,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC,CAAC;YAE/D,gDAAgD;YAChD,MAAM,QAAQ,GAAG,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC;YAClD,WAAW,CAAC,IAAI,CAAC,GAAG,QAAQ,CAAC,CAAC;QAChC,CAAC;QAED,OAAO;YACL,QAAQ,EAAE,WAAW;YACrB,YAAY,EAAE,eAAe;YAC7B,aAAa,EAAE,WAAW;YAC1B,oBAAoB,EAAE,IAAI,CAAC,mBAAmB,CAAC,WAAW,CAAC;YAC3D,WAAW,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;SACtC,CAAC;IACJ,CAAC;IAEO,KAAK,CAAC,0BAA0B,CACtC,MAAc,EACd,WAAyB;QAEzB,MAAM,SAAS,GAAG,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,KAAK,SAAS,CAAC,CAAC;QACnE,MAAM,QAAQ,GAAG,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,KAAK,SAAS,IAAI,CAAC,CAAC,OAAO,KAAK,iBAAiB,CAAC,CAAC;QAErG,MAAM,SAAS,GAAG,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;YACtC,EAAE,EAAE,CAAC,CAAC,EAAE;YACR,OAAO,EAAE,CAAC,CAAC,OAAO;YAClB,OAAO,EAAE,CAAC,CAAC,OAAO;YAClB,KAAK,EAAE,CAAC,CAAC,KAAK;YACd,SAAS,EAAE,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC;YAC3D,iBAAiB,EAAE,CAAC,CAAC,YAAY,CAAC,YAAY;SAC/C,CAAC,CAAC,CAAC;QAEJ,MAAM,MAAM,GAAG,SAAS,EAAE,CAAC;QAC3B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC;YAC5C,KAAK,EAAE,KAAK;YACZ,UAAU,EAAE,IAAI;YAChB,MAAM,EAAE;qEACuD;YAC/D,QAAQ,EAAE,CAAC;oBACT,IAAI,EAAE,MAAM;oBACZ,OAAO,EAAE,iBAAiB,WAAW,CAAC,MAAM,wBAAwB,MAAM;;;EAGhF,IAAI,CAAC,SAAS,CAAC,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;;;wDAGoB,SAAS,CAAC,MAAM;6DACX,QAAQ,CAAC,MAAM;;;;;;;;;;;;;;;;;;;;EAoB1E;iBACK,CAAC;SACH,CAAC,CAAC;QAEH,MAAM,IAAI,GAAG,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,KAAK,MAAM,CAAC,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC;QAEjF,IAAI,CAAC;YACH,IAAI,OAAO,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC;YAC1B,IAAI,OAAO,CAAC,UAAU,CAAC,KAAK,CAAC,EAAE,CAAC;gBAC9B,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC,kBAAkB,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC;YAC3E,CAAC;YACD,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAShC,CAAC;YAEF,MAAM,SAAS,GAAG,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;YAE7C,MAAM,QAAQ,GAAmB,CAAC,MAAM,CAAC,QAAQ,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;gBACjE,EAAE,EAAE,UAAU,EAAE;gBAChB,MAAM;gBACN,WAAW,EAAE,CAAC,CAAC,WAAW;gBAC1B,WAAW,EAAE,CAAC,CAAC,WAAW,IAAI,EAAE;gBAChC,QAAQ,EAAE,CAAC,CAAC,QAAQ,IAAI,YAAY;gBACpC,iBAAiB,EAAE,SAAS,CAAC,MAAM;gBACnC,YAAY,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;gBACtC,gBAAgB,EAAE,KAAK;aACxB,CAAC,CAAC,CAAC;YAEJ,MAAM,YAAY,GAAuB,CAAC,MAAM,CAAC,YAAY,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;gBAC9E,EAAE,EAAE,UAAU,EAAE;gBAChB,MAAM;gBACN,WAAW,EAAE,EAAE,CAAC,WAAW;gBAC3B,UAAU,EAAE,EAAE,CAAC,UAAU,IAAI,EAAE;gBAC/B,YAAY,EAAE,EAAE,CAAC,YAAY,IAAI,EAAE;gBACnC,QAAQ,EAAE,EAAE,CAAC,QAAQ,IAAI,YAAY;gBACrC,aAAa,EAAE,EAAE,CAAC,aAAa,IAAI,SAAS;gBAC5C,eAAe,EAAE,QAAQ,CAAC,MAAM;gBAChC,QAAQ,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;aACnC,CAAC,CAAC,CAAC;YAEJ,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,CAAC;QACpC,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,YAAY,EAAE,EAAE,EAAE,CAAC;QAC5C,CAAC;IACH,CAAC;IAEO,mBAAmB,CAAC,MAAc,EAAE,WAAyB;QACnE,MAAM,KAAK,GAAG,WAAW,CAAC,MAAM,CAAC;QACjC,MAAM,SAAS,GAAG,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,KAAK,SAAS,CAAC,CAAC,MAAM,CAAC;QAC1E,MAAM,SAAS,GAAG,WAAW,CAAC,MAAM,CAClC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,YAAY,CAAC,YAAY,CAAC,MAAM,KAAK,CAAC;YACxC,CAAC,CAAC,YAAY,CAAC,cAAc,CAAC,MAAM,KAAK,CAAC;YAC1C,CAAC,CAAC,YAAY,CAAC,YAAY,KAAK,CAAC,CACvC,CAAC,MAAM,CAAC;QAET,MAAM,cAAc,GAAG,WAAW;aAC/B,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,KAAK,SAAS,CAAC;aACpC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC;QAC3B,MAAM,cAAc,GAAG,WAAW;aAC/B,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,KAAK,SAAS,CAAC;aACpC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC;QAE3B,OAAO;YACL,MAAM;YACN,gBAAgB,EAAE,KAAK;YACvB,WAAW,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;YAC9C,aAAa,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;YAChD,cAAc,EAAE,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC,CAAC;YAC5C,kBAAkB,EAAE,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC,CAAC;YAChD,WAAW,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;SACtC,CAAC;IACJ,CAAC;IAEO,eAAe,CAAC,WAAyB;QAC/C,uDAAuD;QACvD,MAAM,aAAa,GAAG,IAAI,GAAG,EAKzB,CAAC;QAEL,KAAK,MAAM,GAAG,IAAI,WAAW,EAAE,CAAC;YAC9B,KAAK,MAAM,EAAE,IAAI,GAAG,CAAC,YAAY,CAAC,iBAAiB,EAAE,CAAC;gBACpD,KAAK,MAAM,KAAK,IAAI,EAAE,CAAC,MAAM,EAAE,CAAC;oBAC9B,iDAAiD;oBACjD,MAAM,QAAQ,GAAG,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;oBACrD,MAAM,KAAK,GAAG,aAAa,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI;wBAC3C,KAAK,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,WAAW,EAAE,EAAE;qBAChD,CAAC;oBAEF,KAAK,CAAC,KAAK,EAAE,CAAC;oBACd,IAAI,KAAK,CAAC,OAAO,KAAK,MAAM,EAAE,CAAC;wBAC7B,KAAK,CAAC,MAAM,EAAE,CAAC;wBACf,KAAK,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC;oBACnD,CAAC;oBACD,IAAI,KAAK,CAAC,MAAM,KAAK,QAAQ,EAAE,CAAC;wBAC9B,KAAK,CAAC,MAAM,EAAE,CAAC;oBACjB,CAAC;oBACD,aAAa,CAAC,GAAG,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;gBACrC,CAAC;YACH,CAAC;QACH,CAAC;QAED,MAAM,QAAQ,GAA0B,EAAE,CAAC;QAC3C,KAAK,MAAM,CAAC,QAAQ,EAAE,KAAK,CAAC,IAAI,aAAa,EAAE,CAAC;YAC9C,IAAI,KAAK,CAAC,KAAK,GAAG,CAAC;gBAAE,SAAS,CAAC,2BAA2B;YAE1D,MAAM,QAAQ,GAAG,KAAK,CAAC,MAAM,GAAG,KAAK,CAAC,KAAK,CAAC;YAC5C,MAAM,cAAc,GAAG,KAAK,CAAC,MAAM,GAAG,KAAK,CAAC,KAAK,CAAC;YAElD,QAAQ,CAAC,IAAI,CAAC;gBACZ,aAAa,EAAE,QAAQ;gBACvB,QAAQ;gBACR,WAAW,EAAE,KAAK,CAAC,KAAK;gBACxB,YAAY,EAAE,KAAK,CAAC,MAAM;gBAC1B,cAAc;gBACd,iBAAiB,EAAE,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC,CAAC;gBAClD,sBAAsB,EAAE,QAAQ,GAAG,GAAG,IAAI,cAAc,GAAG,GAAG,IAAI,KAAK,CAAC,KAAK,IAAI,EAAE;aACpF,CAAC,CAAC;QACL,CAAC;QAED,OAAO,QAAQ,CAAC;IAClB,CAAC;IAEO,kBAAkB,CAAC,SAAiB;QAC1C,MAAM,KAAK,GAAG,SAAS,CAAC,WAAW,EAAE,CAAC;QACtC,IAAI,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC;YAAE,OAAO,gBAAgB,CAAC;QAC/G,IAAI,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,UAAU,CAAC;YAAE,OAAO,aAAa,CAAC;QAC9G,IAAI,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC;YAAE,OAAO,UAAU,CAAC;QAC5H,IAAI,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,WAAW,CAAC;YAAE,OAAO,aAAa,CAAC;QAC1G,IAAI,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,SAAS,CAAC;YAAE,OAAO,kBAAkB,CAAC;QAC/G,IAAI,KAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,SAAS,CAAC;YAAE,OAAO,aAAa,CAAC;QAC5G,IAAI,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC;YAAE,OAAO,YAAY,CAAC;QACxG,IAAI,KAAK,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,SAAS,CAAC;YAAE,OAAO,aAAa,CAAC;QAC9G,OAAO,SAAS,CAAC;IACnB,CAAC;IAEO,mBAAmB,CAAC,QAA+B;QACzD,MAAM,MAAM,GAAG,IAAI,GAAG,EAA+B,CAAC;QACtD,KAAK,MAAM,CAAC,IAAI,QAAQ,EAAE,CAAC;YACzB,MAAM,QAAQ,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC;YAC7C,IAAI,CAAC,QAAQ,EAAE,CAAC;gBACd,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC;YACjC,CAAC;iBAAM,CAAC;gBACN,cAAc;gBACd,MAAM,KAAK,GAAG,QAAQ,CAAC,WAAW,GAAG,CAAC,CAAC,WAAW,CAAC;gBACnD,MAAM,MAAM,GAAG,QAAQ,CAAC,YAAY,GAAG,CAAC,CAAC,YAAY,CAAC;gBACtD,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,aAAa,EAAE;oBAC1B,GAAG,QAAQ;oBACX,WAAW,EAAE,KAAK;oBAClB,YAAY,EAAE,MAAM;oBACpB,QAAQ,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;oBACxC,iBAAiB,EAAE,CAAC,GAAG,QAAQ,CAAC,iBAAiB,EAAE,GAAG,CAAC,CAAC,iBAAiB,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC;oBACtF,sBAAsB,EAAE,CAAC,MAAM,GAAG,KAAK,CAAC,GAAG,GAAG,IAAI,QAAQ,CAAC,cAAc,GAAG,GAAG,IAAI,KAAK,IAAI,EAAE;iBAC/F,CAAC,CAAC;YACL,CAAC;QACH,CAAC;QACD,OAAO,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,CAAC;IACrC,CAAC;IAEO,IAAI,CAAC,KAAe,EAAE,CAAS;QACrC,MAAM,MAAM,GAAG,IAAI,GAAG,EAAkB,CAAC;QACzC,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;YACzB,MAAM,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QAChD,CAAC;QACD,OAAO,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;aAChC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;aAC3B,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC;aACX,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC;IAC3B,CAAC;CACF"}
@@ -1,4 +1,4 @@
1
- import type { Decision, AgentConfig, ActionPlan } from './types.js';
1
+ import type { Decision, AgentConfig, ActionPlan, PlanningContext } from './types.js';
2
2
  export declare class Planner {
3
- plan(decision: Decision, config: AgentConfig): Promise<ActionPlan>;
3
+ plan(decision: Decision, config: AgentConfig, planningContext?: PlanningContext): Promise<ActionPlan>;
4
4
  }
@@ -58,11 +58,11 @@ Operation schemas:
58
58
  - message: { type: "message", channel: "console"|"slack"|"email", recipient?: string, subject?: string, content: string }`;
59
59
  }
60
60
  // ── User prompt ─────────────────────────────────────────────
61
- function buildUserPrompt(decision) {
61
+ function buildUserPrompt(decision, planningContext) {
62
62
  const actions = decision.proposedActions
63
63
  .map((a, i) => `${i + 1}. [${a.operationType}] ${a.description}\n Target: ${a.target}\n Details: ${a.details}`)
64
64
  .join('\n');
65
- return `Decompose this decision into concrete action steps.
65
+ let prompt = `Decompose this decision into concrete action steps.
66
66
 
67
67
  ## Decision
68
68
  ID: ${decision.id}
@@ -71,9 +71,12 @@ Confidence: ${decision.confidence}
71
71
  Risks: ${decision.risks.join('; ')}
72
72
 
73
73
  ## Proposed actions
74
- ${actions}
75
-
76
- Produce the JSON array of steps now.`;
74
+ ${actions}`;
75
+ if (planningContext?.promptSection) {
76
+ prompt += '\n\n' + planningContext.promptSection;
77
+ }
78
+ prompt += '\n\nProduce the JSON array of steps now.';
79
+ return prompt;
77
80
  }
78
81
  // ── Parse helpers ───────────────────────────────────────────
79
82
  function extractJsonArray(raw) {
@@ -207,11 +210,11 @@ function parseRawStep(raw) {
207
210
  }
208
211
  // ── Planner ─────────────────────────────────────────────────
209
212
  export class Planner {
210
- async plan(decision, config) {
213
+ async plan(decision, config, planningContext) {
211
214
  const planId = randomUUID();
212
215
  const client = getClient();
213
216
  const systemPrompt = buildSystemPrompt(config);
214
- const userPrompt = buildUserPrompt(decision);
217
+ const userPrompt = buildUserPrompt(decision, planningContext);
215
218
  // Stream the response and collect content
216
219
  let content = '';
217
220
  let inputTokens = 0;
@@ -1 +1 @@
1
- {"version":3,"file":"planner.js","sourceRoot":"","sources":["../../src/runtime/planner.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"planner.js","sourceRoot":"","sources":["../../src/runtime/planner.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,17 @@
1
+ import type { PromptSafetyFinding } from './types.js';
2
+ export declare class PromptSafetyAnalyzer {
3
+ /**
4
+ * Analyze an agent system prompt for safety issues.
5
+ * Uses both deterministic pattern matching (formal) and
6
+ * optional LLM-based semantic analysis.
7
+ */
8
+ analyze(systemPrompt: string, opts?: {
9
+ useLLM?: boolean;
10
+ }): Promise<{
11
+ contains_verification_bypass: boolean;
12
+ contains_privilege_escalation: boolean;
13
+ contains_self_reference: boolean;
14
+ findings: PromptSafetyFinding[];
15
+ }>;
16
+ private llmAnalysis;
17
+ }
@@ -0,0 +1,230 @@
1
+ // ============================================================
2
+ // Assay Verified Agent Runtime — Prompt Safety Analyzer
3
+ // Scans agent system prompts for dangerous patterns:
4
+ // - Verification bypass instructions
5
+ // - Privilege escalation attempts
6
+ // - Self-referential instructions
7
+ // - Unbounded action permissions
8
+ // - Missing safety constraints
9
+ // ============================================================
10
+ import { getClient, MODEL } from '../lib/anthropic.js';
11
+ const PROMPT_PATTERNS = [
12
+ // Verification bypass patterns
13
+ {
14
+ name: 'Skip verification instruction',
15
+ type: 'verification_bypass',
16
+ severity: 'critical',
17
+ patterns: [
18
+ /skip\s+(?:the\s+)?verification/i,
19
+ /bypass\s+(?:the\s+)?verif/i,
20
+ /ignore\s+(?:the\s+)?verif/i,
21
+ /don'?t\s+(?:need\s+to\s+)?verif/i,
22
+ /no\s+(?:need\s+for\s+)?verification/i,
23
+ /verification\s+is\s+(?:not\s+)?(?:needed|required|necessary)/i,
24
+ /auto[- ]?approve/i,
25
+ /always\s+pass/i,
26
+ /mark\s+(?:as\s+)?(?:pass|verified|approved)/i,
27
+ ],
28
+ description: 'Prompt contains instructions to bypass or skip verification',
29
+ },
30
+ {
31
+ name: 'Override formal verifier',
32
+ type: 'verification_bypass',
33
+ severity: 'critical',
34
+ patterns: [
35
+ /override\s+(?:the\s+)?formal/i,
36
+ /ignore\s+(?:the\s+)?formal/i,
37
+ /formal\s+verif\w+\s+(?:is\s+)?(?:wrong|incorrect|outdated)/i,
38
+ /you\s+know\s+better\s+than\s+(?:the\s+)?verif/i,
39
+ ],
40
+ description: 'Prompt attempts to override the formal verification layer',
41
+ },
42
+ // Privilege escalation patterns
43
+ {
44
+ name: 'Trust level manipulation',
45
+ type: 'privilege_escalation',
46
+ severity: 'critical',
47
+ patterns: [
48
+ /(?:increase|raise|elevate|promote)\s+(?:your\s+)?(?:own\s+)?trust/i,
49
+ /(?:set|change)\s+(?:your\s+)?trust\s+(?:level\s+)?(?:to\s+)?(?:elevated|coordinator|admin)/i,
50
+ /you\s+(?:have|are)\s+(?:elevated|coordinator|admin)\s+(?:trust|access|permissions)/i,
51
+ /grant\s+(?:yourself|you)\s+(?:elevated|higher|admin)/i,
52
+ ],
53
+ description: 'Prompt attempts to escalate the agent\'s trust level',
54
+ },
55
+ {
56
+ name: 'Approval framework bypass',
57
+ type: 'privilege_escalation',
58
+ severity: 'critical',
59
+ patterns: [
60
+ /(?:skip|bypass|ignore)\s+(?:the\s+)?(?:human\s+)?approval/i,
61
+ /(?:don'?t|no)\s+(?:need\s+)?(?:human\s+)?approval/i,
62
+ /auto[- ]?approve\s+(?:your\s+own|all)/i,
63
+ /approve\s+(?:your\s+)?own\s+(?:work|output|code)/i,
64
+ ],
65
+ description: 'Prompt attempts to bypass human approval requirements',
66
+ },
67
+ {
68
+ name: 'Spawn higher-trust agent',
69
+ type: 'privilege_escalation',
70
+ severity: 'critical',
71
+ patterns: [
72
+ /spawn\s+(?:a\s+)?(?:coordinator|elevated|high[- ]trust)/i,
73
+ /create\s+(?:a\s+)?(?:coordinator|elevated|high[- ]trust)\s+agent/i,
74
+ ],
75
+ description: 'Prompt instructs spawning an agent with higher trust than itself',
76
+ },
77
+ // Self-reference patterns
78
+ {
79
+ name: 'Access to own internals',
80
+ type: 'self_reference',
81
+ severity: 'medium',
82
+ patterns: [
83
+ /(?:read|access|modify)\s+(?:your\s+)?(?:own\s+)?(?:source|code|prompt|config)/i,
84
+ /(?:look\s+at|examine|inspect)\s+(?:your\s+)?(?:own\s+)?(?:system\s+)?prompt/i,
85
+ /(?:modify|change|update)\s+(?:your\s+)?(?:own\s+)?(?:behavior|instructions)/i,
86
+ ],
87
+ description: 'Prompt references agent\'s own internals or instructs self-modification',
88
+ },
89
+ // Unbounded action patterns
90
+ {
91
+ name: 'Unrestricted filesystem access',
92
+ type: 'unbounded_action',
93
+ severity: 'high',
94
+ patterns: [
95
+ /(?:read|write|delete)\s+(?:any|all)\s+files?/i,
96
+ /full\s+(?:filesystem|disk)\s+access/i,
97
+ /no\s+(?:filesystem|file)\s+restrictions/i,
98
+ ],
99
+ description: 'Prompt grants unrestricted filesystem access',
100
+ },
101
+ {
102
+ name: 'Unrestricted network access',
103
+ type: 'unbounded_action',
104
+ severity: 'high',
105
+ patterns: [
106
+ /(?:call|access|connect\s+to)\s+any\s+(?:URL|API|endpoint|server)/i,
107
+ /no\s+(?:network|URL)\s+restrictions/i,
108
+ /unrestricted\s+(?:network|API)\s+access/i,
109
+ ],
110
+ description: 'Prompt grants unrestricted network access',
111
+ },
112
+ ];
113
+ // Required safety constraints that should appear in any agent prompt
114
+ const REQUIRED_CONSTRAINTS = [
115
+ {
116
+ name: 'Verification acknowledgment',
117
+ pattern: /verif(?:y|ied|ication)/i,
118
+ description: 'Prompt should acknowledge that outputs will be verified',
119
+ },
120
+ {
121
+ name: 'Scope limitation',
122
+ pattern: /(?:scope|domain|limited\s+to|restricted\s+to|only\s+handle)/i,
123
+ description: 'Prompt should define the agent\'s scope or domain limitations',
124
+ },
125
+ {
126
+ name: 'Error handling',
127
+ pattern: /(?:error|fail|exception|unknown|uncertain)/i,
128
+ description: 'Prompt should mention error handling or uncertainty behavior',
129
+ },
130
+ ];
131
+ // ── Prompt Safety Analyzer ─────────────────────────────────
132
+ export class PromptSafetyAnalyzer {
133
+ /**
134
+ * Analyze an agent system prompt for safety issues.
135
+ * Uses both deterministic pattern matching (formal) and
136
+ * optional LLM-based semantic analysis.
137
+ */
138
+ async analyze(systemPrompt, opts) {
139
+ const findings = [];
140
+ // Phase 1: Deterministic pattern matching
141
+ for (const pattern of PROMPT_PATTERNS) {
142
+ for (const regex of pattern.patterns) {
143
+ const match = systemPrompt.match(regex);
144
+ if (match) {
145
+ // Find approximate line number
146
+ const beforeMatch = systemPrompt.slice(0, match.index ?? 0);
147
+ const lineNum = (beforeMatch.match(/\n/g) ?? []).length + 1;
148
+ findings.push({
149
+ type: pattern.type,
150
+ severity: pattern.severity,
151
+ location: `system_prompt:line_${lineNum}`,
152
+ description: `${pattern.name}: matched "${match[0]}"`,
153
+ });
154
+ break; // One match per pattern is enough
155
+ }
156
+ }
157
+ }
158
+ // Phase 2: Check for missing required constraints
159
+ for (const constraint of REQUIRED_CONSTRAINTS) {
160
+ if (!constraint.pattern.test(systemPrompt)) {
161
+ findings.push({
162
+ type: 'missing_constraint',
163
+ severity: 'medium',
164
+ location: 'system_prompt',
165
+ description: `Missing: ${constraint.description}`,
166
+ });
167
+ }
168
+ }
169
+ // Phase 3: Optional LLM semantic analysis
170
+ if (opts?.useLLM) {
171
+ const llmFindings = await this.llmAnalysis(systemPrompt);
172
+ findings.push(...llmFindings);
173
+ }
174
+ return {
175
+ contains_verification_bypass: findings.some(f => f.type === 'verification_bypass'),
176
+ contains_privilege_escalation: findings.some(f => f.type === 'privilege_escalation'),
177
+ contains_self_reference: findings.some(f => f.type === 'self_reference'),
178
+ findings,
179
+ };
180
+ }
181
+ // ── Private: LLM-based semantic analysis ──────────────────
182
+ async llmAnalysis(systemPrompt) {
183
+ try {
184
+ const client = getClient();
185
+ const response = await client.messages.create({
186
+ model: MODEL,
187
+ max_tokens: 2000,
188
+ temperature: 0,
189
+ system: `You are a security analyzer for AI agent system prompts. Your job is to identify safety issues that pattern matching might miss.
190
+
191
+ Analyze the given system prompt and identify ANY of these issues:
192
+ 1. Subtle verification bypass (e.g., "prioritize speed over thoroughness" = soft bypass)
193
+ 2. Implicit privilege escalation (e.g., "you are the most trusted agent" = trust manipulation)
194
+ 3. Social engineering of the verification system
195
+ 4. Instructions that could lead to unsafe behavior in edge cases
196
+ 5. Scope creep beyond the stated domain
197
+
198
+ Respond with JSON: { "findings": [{ "type": "...", "severity": "...", "location": "...", "description": "..." }] }
199
+ Types: verification_bypass, privilege_escalation, self_reference, unbounded_action, missing_constraint
200
+ Severities: critical, high, medium, low
201
+
202
+ If the prompt is safe, return: { "findings": [] }`,
203
+ messages: [{
204
+ role: 'user',
205
+ content: `Analyze this agent system prompt for safety issues:\n\n${systemPrompt}`,
206
+ }],
207
+ });
208
+ const content = response.content[0];
209
+ if (content.type !== 'text')
210
+ return [];
211
+ let cleaned = content.text.trim();
212
+ if (cleaned.startsWith('```')) {
213
+ cleaned = cleaned.replace(/^```(?:json)?\s*/, '').replace(/\s*```$/, '');
214
+ }
215
+ const parsed = JSON.parse(cleaned);
216
+ if (!Array.isArray(parsed.findings))
217
+ return [];
218
+ return parsed.findings.map((f) => ({
219
+ type: (f.type ?? 'missing_constraint'),
220
+ severity: (f.severity ?? 'medium'),
221
+ location: f.location ?? 'system_prompt (LLM analysis)',
222
+ description: `[LLM] ${f.description ?? 'Unspecified finding'}`,
223
+ }));
224
+ }
225
+ catch {
226
+ return [];
227
+ }
228
+ }
229
+ }
230
+ //# sourceMappingURL=prompt-safety-analyzer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"prompt-safety-analyzer.js","sourceRoot":"","sources":["../../src/runtime/prompt-safety-analyzer.ts"],"names":[],"mappings":"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"}
@@ -1,4 +1,4 @@
1
- import type { Observation, AgentConfig, AgentState, Decision, Experience } from './types.js';
1
+ import type { Observation, AgentConfig, AgentState, Decision, Experience, ReasoningContext } from './types.js';
2
2
  export declare class Reasoner {
3
- reason(observation: Observation, agentConfig: AgentConfig, currentState: AgentState, experiences?: Experience[]): Promise<Decision>;
3
+ reason(observation: Observation, agentConfig: AgentConfig, currentState: AgentState, experiences?: Experience[], enrichedContext?: ReasoningContext): Promise<Decision>;
4
4
  }