tryassay 0.22.0 → 0.22.2
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/demo/css/style.css +495 -836
- package/demo/index.html +40 -184
- package/demo/js/chat.js +385 -142
- package/demo/js/preview.js +456 -0
- package/demo/js/sse-client.js +262 -135
- package/demo/js/state.js +11 -1
- package/demo/js/timeline.js +57 -371
- package/dist/api/server.d.ts +2 -0
- package/dist/api/server.js +63 -19
- package/dist/api/server.js.map +1 -1
- package/dist/cli.js +2 -0
- package/dist/cli.js.map +1 -1
- package/dist/commands/assess.d.ts +2 -0
- package/dist/commands/assess.js +132 -164
- package/dist/commands/assess.js.map +1 -1
- package/dist/commands/demo.js +259 -9
- package/dist/commands/demo.js.map +1 -1
- package/dist/lib/__tests__/arithmetic-quick-test.d.ts +6 -0
- package/dist/lib/__tests__/arithmetic-quick-test.js +197 -0
- package/dist/lib/__tests__/arithmetic-quick-test.js.map +1 -0
- package/dist/lib/__tests__/arithmetic-real-llm-test.d.ts +13 -0
- package/dist/lib/__tests__/arithmetic-real-llm-test.js +284 -0
- package/dist/lib/__tests__/arithmetic-real-llm-test.js.map +1 -0
- package/dist/lib/__tests__/arithmetic-value-demo.d.ts +10 -0
- package/dist/lib/__tests__/arithmetic-value-demo.js +193 -0
- package/dist/lib/__tests__/arithmetic-value-demo.js.map +1 -0
- package/dist/lib/__tests__/flow-to-claims.test.d.ts +1 -0
- package/dist/lib/__tests__/flow-to-claims.test.js +91 -0
- package/dist/lib/__tests__/flow-to-claims.test.js.map +1 -0
- package/dist/lib/__tests__/formal-verifier-api-misuse.test.d.ts +9 -0
- package/dist/lib/__tests__/formal-verifier-api-misuse.test.js +391 -0
- package/dist/lib/__tests__/formal-verifier-api-misuse.test.js.map +1 -0
- package/dist/lib/__tests__/formal-verifier-arithmetic.test.d.ts +7 -0
- package/dist/lib/__tests__/formal-verifier-arithmetic.test.js +318 -0
- package/dist/lib/__tests__/formal-verifier-arithmetic.test.js.map +1 -0
- package/dist/lib/__tests__/intent-extractor.test.d.ts +1 -0
- package/dist/lib/__tests__/intent-extractor.test.js +97 -0
- package/dist/lib/__tests__/intent-extractor.test.js.map +1 -0
- package/dist/lib/__tests__/intent-reviewer.test.d.ts +1 -0
- package/dist/lib/__tests__/intent-reviewer.test.js +55 -0
- package/dist/lib/__tests__/intent-reviewer.test.js.map +1 -0
- package/dist/lib/__tests__/mr-gsm8k-benchmark.d.ts +11 -0
- package/dist/lib/__tests__/mr-gsm8k-benchmark.js +224 -0
- package/dist/lib/__tests__/mr-gsm8k-benchmark.js.map +1 -0
- package/dist/lib/anthropic.js +25 -33
- package/dist/lib/anthropic.js.map +1 -1
- package/dist/lib/assessment-reporter.js +9 -13
- package/dist/lib/assessment-reporter.js.map +1 -1
- package/dist/lib/claim-extractor.js +10 -19
- package/dist/lib/claim-extractor.js.map +1 -1
- package/dist/lib/code-verifier.js +16 -36
- package/dist/lib/code-verifier.js.map +1 -1
- package/dist/lib/constraint-engine.js +10 -19
- package/dist/lib/constraint-engine.js.map +1 -1
- package/dist/lib/formal-verifier.d.ts +1 -1
- package/dist/lib/formal-verifier.js +454 -0
- package/dist/lib/formal-verifier.js.map +1 -1
- package/dist/lib/guided-generator.js +19 -37
- package/dist/lib/guided-generator.js.map +1 -1
- package/dist/lib/intent-extractor.d.ts +47 -0
- package/dist/lib/intent-extractor.js +432 -0
- package/dist/lib/intent-extractor.js.map +1 -0
- package/dist/lib/intent-reviewer.d.ts +14 -0
- package/dist/lib/intent-reviewer.js +148 -0
- package/dist/lib/intent-reviewer.js.map +1 -0
- package/dist/lib/intent-types.d.ts +89 -0
- package/dist/lib/intent-types.js +5 -0
- package/dist/lib/intent-types.js.map +1 -0
- package/dist/lib/inventory-extractor.js +9 -22
- package/dist/lib/inventory-extractor.js.map +1 -1
- package/dist/lib/llm-provider.d.ts +23 -0
- package/dist/lib/llm-provider.js +130 -0
- package/dist/lib/llm-provider.js.map +1 -0
- package/dist/lib/remediator.js +20 -28
- package/dist/lib/remediator.js.map +1 -1
- package/dist/lib/requirements-generator.js +14 -19
- package/dist/lib/requirements-generator.js.map +1 -1
- package/dist/lib/spec-synthesizer.js +10 -19
- package/dist/lib/spec-synthesizer.js.map +1 -1
- package/dist/runtime/app-create-orchestrator.d.ts +5 -1
- package/dist/runtime/app-create-orchestrator.js +114 -39
- package/dist/runtime/app-create-orchestrator.js.map +1 -1
- package/dist/runtime/check-catalog.js +5 -3
- package/dist/runtime/check-catalog.js.map +1 -1
- package/dist/runtime/check-definitions.d.ts +10 -0
- package/dist/runtime/check-definitions.js +52 -2
- package/dist/runtime/check-definitions.js.map +1 -1
- package/dist/runtime/composition-verifier.js +8 -12
- package/dist/runtime/composition-verifier.js.map +1 -1
- package/dist/runtime/gap-detector.js +8 -10
- package/dist/runtime/gap-detector.js.map +1 -1
- package/dist/runtime/input-validator.d.ts +7 -0
- package/dist/runtime/input-validator.js +162 -0
- package/dist/runtime/input-validator.js.map +1 -0
- package/dist/runtime/model-router.d.ts +10 -0
- package/dist/runtime/model-router.js +42 -0
- package/dist/runtime/model-router.js.map +1 -0
- package/dist/runtime/pattern-extractor.js +8 -10
- package/dist/runtime/pattern-extractor.js.map +1 -1
- package/dist/runtime/planner.js +11 -16
- package/dist/runtime/planner.js.map +1 -1
- package/dist/runtime/prompt-guard.d.ts +2 -0
- package/dist/runtime/prompt-guard.js +180 -0
- package/dist/runtime/prompt-guard.js.map +1 -0
- package/dist/runtime/prompt-safety-analyzer.js +8 -13
- package/dist/runtime/prompt-safety-analyzer.js.map +1 -1
- package/dist/runtime/reasoner.js +19 -33
- package/dist/runtime/reasoner.js.map +1 -1
- package/dist/runtime/rule-meta-verifier.js +9 -11
- package/dist/runtime/rule-meta-verifier.js.map +1 -1
- package/dist/runtime/safe-executor.d.ts +23 -0
- package/dist/runtime/safe-executor.js +151 -0
- package/dist/runtime/safe-executor.js.map +1 -0
- package/dist/runtime/specialized-agent.js +10 -14
- package/dist/runtime/specialized-agent.js.map +1 -1
- package/dist/runtime/strategy-library.js +8 -10
- package/dist/runtime/strategy-library.js.map +1 -1
- package/dist/runtime/supabase-experience-store.js.map +1 -1
- package/dist/runtime/supabase-provisioner.d.ts +35 -0
- package/dist/runtime/supabase-provisioner.js +192 -0
- package/dist/runtime/supabase-provisioner.js.map +1 -0
- package/dist/runtime/types.d.ts +88 -0
- package/dist/sdk/forward-verify.js +16 -33
- package/dist/sdk/forward-verify.js.map +1 -1
- package/package.json +1 -1
- package/demo/data/demo-events.json +0 -103
- package/demo/js/demo-mode.js +0 -107
- package/demo/js/orb.js +0 -634
- package/demo/js/question-cards.js +0 -207
- package/demo/js/voice.js +0 -154
|
@@ -0,0 +1,162 @@
|
|
|
1
|
+
// ============================================================
|
|
2
|
+
// Input Validator — Runtime validation at the API trust boundary
|
|
3
|
+
// TypeScript types define the compile-time contract.
|
|
4
|
+
// This module enforces it at runtime on untrusted JSON input.
|
|
5
|
+
// ============================================================
|
|
6
|
+
// ── Allowed enums ────────────────────────────────────────────
|
|
7
|
+
const ALLOWED_LANGUAGES = new Set(['typescript', 'python']);
|
|
8
|
+
const ALLOWED_FRAMEWORKS = new Set(['next.js', 'express', 'sveltekit', 'electron']);
|
|
9
|
+
const ALLOWED_DATABASES = new Set(['supabase', 'postgresql', 'sqlite']);
|
|
10
|
+
const ALLOWED_AUTH_PROVIDERS = new Set(['supabase', 'nextauth', 'custom']);
|
|
11
|
+
// ── Limits ───────────────────────────────────────────────────
|
|
12
|
+
const NAME_MAX = 80;
|
|
13
|
+
const DESCRIPTION_MAX = 5_000;
|
|
14
|
+
const FEATURE_MAX = 500;
|
|
15
|
+
const MAX_FEATURES = 30;
|
|
16
|
+
const MAX_CONSTRAINTS = 20;
|
|
17
|
+
const MAX_AUTH_METHODS = 10;
|
|
18
|
+
const MAX_AUTH_ROLES = 20;
|
|
19
|
+
// ── Control character stripping ──────────────────────────────
|
|
20
|
+
const CONTROL_CHAR_RE = /[\x00-\x08\x0B\x0C\x0E-\x1F\x7F]/g;
|
|
21
|
+
function stripControlChars(s) {
|
|
22
|
+
return s.replace(CONTROL_CHAR_RE, '');
|
|
23
|
+
}
|
|
24
|
+
// ── Validators ───────────────────────────────────────────────
|
|
25
|
+
function validateString(value, field, minLen, maxLen, errors) {
|
|
26
|
+
if (typeof value !== 'string') {
|
|
27
|
+
errors.push({ field, message: `must be a string`, value });
|
|
28
|
+
return null;
|
|
29
|
+
}
|
|
30
|
+
const cleaned = stripControlChars(value).trim();
|
|
31
|
+
if (cleaned.length < minLen) {
|
|
32
|
+
errors.push({ field, message: `must be at least ${minLen} character(s)`, value: cleaned });
|
|
33
|
+
return null;
|
|
34
|
+
}
|
|
35
|
+
if (cleaned.length > maxLen) {
|
|
36
|
+
errors.push({ field, message: `must be at most ${maxLen} characters (got ${cleaned.length})`, value: `${cleaned.slice(0, 50)}...` });
|
|
37
|
+
return null;
|
|
38
|
+
}
|
|
39
|
+
return cleaned;
|
|
40
|
+
}
|
|
41
|
+
function validateEnum(value, field, allowed, errors) {
|
|
42
|
+
if (typeof value !== 'string') {
|
|
43
|
+
errors.push({ field, message: `must be a string`, value });
|
|
44
|
+
return null;
|
|
45
|
+
}
|
|
46
|
+
if (!allowed.has(value)) {
|
|
47
|
+
errors.push({ field, message: `must be one of: ${[...allowed].join(', ')}`, value });
|
|
48
|
+
return null;
|
|
49
|
+
}
|
|
50
|
+
return value;
|
|
51
|
+
}
|
|
52
|
+
function validateStringArray(value, field, minItems, maxItems, maxItemLen, errors) {
|
|
53
|
+
if (!Array.isArray(value)) {
|
|
54
|
+
errors.push({ field, message: `must be an array`, value });
|
|
55
|
+
return null;
|
|
56
|
+
}
|
|
57
|
+
if (value.length < minItems) {
|
|
58
|
+
errors.push({ field, message: `must have at least ${minItems} item(s)`, value: value.length });
|
|
59
|
+
return null;
|
|
60
|
+
}
|
|
61
|
+
if (value.length > maxItems) {
|
|
62
|
+
errors.push({ field, message: `must have at most ${maxItems} items (got ${value.length})` });
|
|
63
|
+
return null;
|
|
64
|
+
}
|
|
65
|
+
const result = [];
|
|
66
|
+
for (let i = 0; i < value.length; i++) {
|
|
67
|
+
const item = validateString(value[i], `${field}[${i}]`, 1, maxItemLen, errors);
|
|
68
|
+
if (item !== null)
|
|
69
|
+
result.push(item);
|
|
70
|
+
}
|
|
71
|
+
return errors.length > 0 ? null : result;
|
|
72
|
+
}
|
|
73
|
+
function validateTechStack(value, errors) {
|
|
74
|
+
if (typeof value !== 'object' || value === null) {
|
|
75
|
+
errors.push({ field: 'techStack', message: 'must be an object' });
|
|
76
|
+
return null;
|
|
77
|
+
}
|
|
78
|
+
const ts = value;
|
|
79
|
+
const language = validateEnum(ts.language, 'techStack.language', ALLOWED_LANGUAGES, errors);
|
|
80
|
+
const framework = validateEnum(ts.framework, 'techStack.framework', ALLOWED_FRAMEWORKS, errors);
|
|
81
|
+
const database = validateEnum(ts.database, 'techStack.database', ALLOWED_DATABASES, errors);
|
|
82
|
+
if (!language || !framework || !database)
|
|
83
|
+
return null;
|
|
84
|
+
const result = { language, framework, database };
|
|
85
|
+
// Optional string fields
|
|
86
|
+
if (ts.styling !== undefined) {
|
|
87
|
+
const styling = validateString(ts.styling, 'techStack.styling', 1, 100, errors);
|
|
88
|
+
if (styling)
|
|
89
|
+
return { ...result, styling };
|
|
90
|
+
}
|
|
91
|
+
if (ts.deployment !== undefined) {
|
|
92
|
+
const deployment = validateString(ts.deployment, 'techStack.deployment', 1, 100, errors);
|
|
93
|
+
if (deployment)
|
|
94
|
+
return { ...result, deployment };
|
|
95
|
+
}
|
|
96
|
+
return result;
|
|
97
|
+
}
|
|
98
|
+
function validateAuthModel(value, errors) {
|
|
99
|
+
if (typeof value !== 'object' || value === null) {
|
|
100
|
+
errors.push({ field: 'authModel', message: 'must be an object' });
|
|
101
|
+
return null;
|
|
102
|
+
}
|
|
103
|
+
const am = value;
|
|
104
|
+
const provider = validateEnum(am.provider, 'authModel.provider', ALLOWED_AUTH_PROVIDERS, errors);
|
|
105
|
+
const methods = validateStringArray(am.methods, 'authModel.methods', 1, MAX_AUTH_METHODS, 100, errors);
|
|
106
|
+
if (!provider || !methods)
|
|
107
|
+
return null;
|
|
108
|
+
const result = { provider, methods };
|
|
109
|
+
if (am.roles !== undefined) {
|
|
110
|
+
const roles = validateStringArray(am.roles, 'authModel.roles', 0, MAX_AUTH_ROLES, 100, errors);
|
|
111
|
+
if (roles)
|
|
112
|
+
return { ...result, roles };
|
|
113
|
+
}
|
|
114
|
+
return result;
|
|
115
|
+
}
|
|
116
|
+
// ── Main validator ───────────────────────────────────────────
|
|
117
|
+
export function validateAppDescription(input) {
|
|
118
|
+
const errors = [];
|
|
119
|
+
if (typeof input !== 'object' || input === null) {
|
|
120
|
+
return { valid: false, errors: [{ field: 'root', message: 'must be an object' }], sanitized: null };
|
|
121
|
+
}
|
|
122
|
+
const obj = input;
|
|
123
|
+
const name = validateString(obj.name, 'name', 1, NAME_MAX, errors);
|
|
124
|
+
const description = validateString(obj.description, 'description', 1, DESCRIPTION_MAX, errors);
|
|
125
|
+
const techStack = validateTechStack(obj.techStack, errors);
|
|
126
|
+
const features = validateStringArray(obj.features, 'features', 1, MAX_FEATURES, FEATURE_MAX, errors);
|
|
127
|
+
if (errors.length > 0) {
|
|
128
|
+
return { valid: false, errors, sanitized: null };
|
|
129
|
+
}
|
|
130
|
+
const sanitized = {
|
|
131
|
+
name: name,
|
|
132
|
+
description: description,
|
|
133
|
+
techStack: techStack,
|
|
134
|
+
features: features,
|
|
135
|
+
};
|
|
136
|
+
// Optional fields
|
|
137
|
+
if (obj.constraints !== undefined) {
|
|
138
|
+
const constraints = validateStringArray(obj.constraints, 'constraints', 0, MAX_CONSTRAINTS, FEATURE_MAX, errors);
|
|
139
|
+
if (errors.length > 0)
|
|
140
|
+
return { valid: false, errors, sanitized: null };
|
|
141
|
+
if (constraints && constraints.length > 0) {
|
|
142
|
+
return { valid: true, errors: [], sanitized: { ...sanitized, constraints } };
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
if (obj.authModel !== undefined) {
|
|
146
|
+
const authModel = validateAuthModel(obj.authModel, errors);
|
|
147
|
+
if (errors.length > 0)
|
|
148
|
+
return { valid: false, errors, sanitized: null };
|
|
149
|
+
if (authModel) {
|
|
150
|
+
return { valid: true, errors: [], sanitized: { ...sanitized, authModel } };
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
return { valid: true, errors: [], sanitized };
|
|
154
|
+
}
|
|
155
|
+
/**
|
|
156
|
+
* Strip control characters from text intended for prompt inclusion.
|
|
157
|
+
* Does NOT neutralize injection — that's the prompt guard's job.
|
|
158
|
+
*/
|
|
159
|
+
export function sanitizeForPrompt(text) {
|
|
160
|
+
return stripControlChars(text).replace(/\s+/g, ' ').trim();
|
|
161
|
+
}
|
|
162
|
+
//# sourceMappingURL=input-validator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"input-validator.js","sourceRoot":"","sources":["../../src/runtime/input-validator.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { TaskCategory, AgentSpecialization } from './types.js';
|
|
2
|
+
export declare class ModelRouter {
|
|
3
|
+
private readonly userOverrides;
|
|
4
|
+
constructor(userOverrides?: Partial<Record<AgentSpecialization, string>>);
|
|
5
|
+
/**
|
|
6
|
+
* Select the model for a given task category and optional agent specialization.
|
|
7
|
+
* Override precedence: options.models[agent] > default routing table.
|
|
8
|
+
*/
|
|
9
|
+
selectModel(category: TaskCategory, agent?: AgentSpecialization): string;
|
|
10
|
+
}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
// ============================================================
|
|
2
|
+
// Model Router — Task-to-model routing
|
|
3
|
+
// Maps task categories to model tiers. User overrides win.
|
|
4
|
+
// Routes by task semantics: scaffolding is templated work,
|
|
5
|
+
// planning needs deep reasoning, verification needs analysis.
|
|
6
|
+
// ============================================================
|
|
7
|
+
// ── Model IDs ────────────────────────────────────────────────
|
|
8
|
+
const TIER_MODELS = {
|
|
9
|
+
fast: 'claude-haiku-4-5-20251001',
|
|
10
|
+
standard: 'claude-sonnet-4-6',
|
|
11
|
+
advanced: 'claude-sonnet-4-6', // Upgrade to opus for complex apps later
|
|
12
|
+
};
|
|
13
|
+
// ── Default routing table ────────────────────────────────────
|
|
14
|
+
const DEFAULT_ROUTING = {
|
|
15
|
+
scaffolding: 'fast',
|
|
16
|
+
code_generation: 'standard',
|
|
17
|
+
verification: 'standard',
|
|
18
|
+
planning: 'standard',
|
|
19
|
+
repair: 'standard',
|
|
20
|
+
testing: 'fast',
|
|
21
|
+
};
|
|
22
|
+
// ── Router ───────────────────────────────────────────────────
|
|
23
|
+
export class ModelRouter {
|
|
24
|
+
userOverrides;
|
|
25
|
+
constructor(userOverrides) {
|
|
26
|
+
this.userOverrides = userOverrides ?? {};
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* Select the model for a given task category and optional agent specialization.
|
|
30
|
+
* Override precedence: options.models[agent] > default routing table.
|
|
31
|
+
*/
|
|
32
|
+
selectModel(category, agent) {
|
|
33
|
+
// User override for this specific agent wins
|
|
34
|
+
if (agent && this.userOverrides[agent]) {
|
|
35
|
+
return this.userOverrides[agent];
|
|
36
|
+
}
|
|
37
|
+
// Default routing by task category
|
|
38
|
+
const tier = DEFAULT_ROUTING[category];
|
|
39
|
+
return TIER_MODELS[tier];
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
//# sourceMappingURL=model-router.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"model-router.js","sourceRoot":"","sources":["../../src/runtime/model-router.ts"],"names":[],"mappings":"AAAA,+DAA+D;AAC/D,uCAAuC;AACvC,2DAA2D;AAC3D,2DAA2D;AAC3D,8DAA8D;AAC9D,+DAA+D;AAI/D,gEAAgE;AAEhE,MAAM,WAAW,GAA8B;IAC7C,IAAI,EAAE,2BAA2B;IACjC,QAAQ,EAAE,mBAAmB;IAC7B,QAAQ,EAAE,mBAAmB,EAAE,yCAAyC;CACzE,CAAC;AAEF,gEAAgE;AAEhE,MAAM,eAAe,GAAoC;IACvD,WAAW,EAAE,MAAM;IACnB,eAAe,EAAE,UAAU;IAC3B,YAAY,EAAE,UAAU;IACxB,QAAQ,EAAE,UAAU;IACpB,MAAM,EAAE,UAAU;IAClB,OAAO,EAAE,MAAM;CAChB,CAAC;AAEF,gEAAgE;AAEhE,MAAM,OAAO,WAAW;IACL,aAAa,CAA+C;IAE7E,YAAY,aAA4D;QACtE,IAAI,CAAC,aAAa,GAAG,aAAa,IAAI,EAAE,CAAC;IAC3C,CAAC;IAED;;;OAGG;IACH,WAAW,CAAC,QAAsB,EAAE,KAA2B;QAC7D,6CAA6C;QAC7C,IAAI,KAAK,IAAI,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,EAAE,CAAC;YACvC,OAAO,IAAI,CAAC,aAAa,CAAC,KAAK,CAAE,CAAC;QACpC,CAAC;QAED,mCAAmC;QACnC,MAAM,IAAI,GAAG,eAAe,CAAC,QAAQ,CAAC,CAAC;QACvC,OAAO,WAAW,CAAC,IAAI,CAAC,CAAC;IAC3B,CAAC;CACF"}
|
|
@@ -3,7 +3,8 @@
|
|
|
3
3
|
// Processes experience clusters into structured learning artifacts.
|
|
4
4
|
// ============================================================
|
|
5
5
|
import { randomUUID } from 'node:crypto';
|
|
6
|
-
import {
|
|
6
|
+
import { getProvider } from '../lib/llm-provider.js';
|
|
7
|
+
import { MODEL } from '../lib/anthropic.js';
|
|
7
8
|
export class PatternExtractor {
|
|
8
9
|
async extract(experiences, filter) {
|
|
9
10
|
let filtered = experiences;
|
|
@@ -64,15 +65,13 @@ export class PatternExtractor {
|
|
|
64
65
|
planSteps: e.plan.steps.map(s => s.description).slice(0, 5),
|
|
65
66
|
verificationFails: e.verification.failedClaims,
|
|
66
67
|
}));
|
|
67
|
-
const
|
|
68
|
-
const
|
|
68
|
+
const provider = getProvider();
|
|
69
|
+
const result = await provider.complete({
|
|
69
70
|
model: MODEL,
|
|
70
|
-
|
|
71
|
-
|
|
71
|
+
maxTokens: 4096,
|
|
72
|
+
systemPrompt: `You analyze agent experience data to extract reusable patterns and anti-patterns.
|
|
72
73
|
Respond with ONLY a JSON object. No markdown fences, no explanation.`,
|
|
73
|
-
|
|
74
|
-
role: 'user',
|
|
75
|
-
content: `Analyze these ${experiences.length} experiences in the "${domain}" domain.
|
|
74
|
+
userPrompt: `Analyze these ${experiences.length} experiences in the "${domain}" domain.
|
|
76
75
|
|
|
77
76
|
EXPERIENCES:
|
|
78
77
|
${JSON.stringify(summaries, null, 2)}
|
|
@@ -100,9 +99,8 @@ Respond with JSON:
|
|
|
100
99
|
}
|
|
101
100
|
]
|
|
102
101
|
}`,
|
|
103
|
-
}],
|
|
104
102
|
});
|
|
105
|
-
const text =
|
|
103
|
+
const text = result.content;
|
|
106
104
|
try {
|
|
107
105
|
let cleaned = text.trim();
|
|
108
106
|
if (cleaned.startsWith('```')) {
|
|
@@ -1 +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,
|
|
1
|
+
{"version":3,"file":"pattern-extractor.js","sourceRoot":"","sources":["../../src/runtime/pattern-extractor.ts"],"names":[],"mappings":"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"}
|
package/dist/runtime/planner.js
CHANGED
|
@@ -3,7 +3,8 @@
|
|
|
3
3
|
// Decomposes a Decision into concrete, verifiable ActionSteps
|
|
4
4
|
// ============================================================
|
|
5
5
|
import { randomUUID } from 'node:crypto';
|
|
6
|
-
import {
|
|
6
|
+
import { getProvider } from '../lib/llm-provider.js';
|
|
7
|
+
import { MODEL } from '../lib/anthropic.js';
|
|
7
8
|
// ── Approval level ranking (for comparison) ─────────────────
|
|
8
9
|
const APPROVAL_RANK = {
|
|
9
10
|
auto: 0,
|
|
@@ -212,25 +213,19 @@ function parseRawStep(raw) {
|
|
|
212
213
|
export class Planner {
|
|
213
214
|
async plan(decision, config, planningContext) {
|
|
214
215
|
const planId = randomUUID();
|
|
215
|
-
const
|
|
216
|
+
const provider = getProvider();
|
|
216
217
|
const systemPrompt = buildSystemPrompt(config);
|
|
217
218
|
const userPrompt = buildUserPrompt(decision, planningContext);
|
|
218
|
-
//
|
|
219
|
-
|
|
220
|
-
let inputTokens = 0;
|
|
221
|
-
let outputTokens = 0;
|
|
222
|
-
const stream = client.messages.stream({
|
|
219
|
+
// Call the LLM provider and collect content
|
|
220
|
+
const result = await provider.complete({
|
|
223
221
|
model: config.modelId || MODEL,
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
222
|
+
systemPrompt,
|
|
223
|
+
userPrompt,
|
|
224
|
+
maxTokens: 8_000,
|
|
227
225
|
});
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
const finalMessage = await stream.finalMessage();
|
|
232
|
-
inputTokens = finalMessage.usage.input_tokens;
|
|
233
|
-
outputTokens = finalMessage.usage.output_tokens;
|
|
226
|
+
const content = result.content;
|
|
227
|
+
const inputTokens = result.inputTokens ?? 0;
|
|
228
|
+
const outputTokens = result.outputTokens ?? 0;
|
|
234
229
|
// Parse the response into steps
|
|
235
230
|
let rawSteps;
|
|
236
231
|
try {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"planner.js","sourceRoot":"","sources":["../../src/runtime/planner.ts"],"names":[],"mappings":"AAAA,+DAA+D;AAC/D,yCAAyC;AACzC,8DAA8D;AAC9D,+DAA+D;AAE/D,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AACzC,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"planner.js","sourceRoot":"","sources":["../../src/runtime/planner.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,180 @@
|
|
|
1
|
+
// ============================================================
|
|
2
|
+
// Prompt Guard — Injection pattern detection for LLM inputs
|
|
3
|
+
// Score-based, not binary. Multiple high-severity matches
|
|
4
|
+
// accumulate; a single low-severity match just logs.
|
|
5
|
+
// No LLM calls — pure regex pattern matching.
|
|
6
|
+
// ============================================================
|
|
7
|
+
const PATTERNS = [
|
|
8
|
+
// instruction_override — high severity
|
|
9
|
+
{
|
|
10
|
+
category: 'instruction_override',
|
|
11
|
+
pattern: /ignore\s+(all\s+)?(previous|prior|above|earlier)\s+(instructions?|rules?|guidelines?|constraints?|directives?)/i,
|
|
12
|
+
severity: 'high',
|
|
13
|
+
weight: 0.4,
|
|
14
|
+
},
|
|
15
|
+
{
|
|
16
|
+
category: 'instruction_override',
|
|
17
|
+
pattern: /disregard\s+(all\s+)?(previous|prior|your|the)\s+(instructions?|rules?|guidelines?|constraints?)/i,
|
|
18
|
+
severity: 'high',
|
|
19
|
+
weight: 0.4,
|
|
20
|
+
},
|
|
21
|
+
{
|
|
22
|
+
category: 'instruction_override',
|
|
23
|
+
pattern: /forget\s+(all\s+)?(previous|prior|your|the)\s+(instructions?|rules?|context)/i,
|
|
24
|
+
severity: 'high',
|
|
25
|
+
weight: 0.4,
|
|
26
|
+
},
|
|
27
|
+
{
|
|
28
|
+
category: 'instruction_override',
|
|
29
|
+
pattern: /override\s+(all\s+)?(safety|security|previous|your)\s+(measures?|filters?|instructions?|rules?)/i,
|
|
30
|
+
severity: 'high',
|
|
31
|
+
weight: 0.4,
|
|
32
|
+
},
|
|
33
|
+
{
|
|
34
|
+
category: 'instruction_override',
|
|
35
|
+
pattern: /do\s+not\s+follow\s+(your|the|any)\s+(instructions?|rules?|guidelines?)/i,
|
|
36
|
+
severity: 'high',
|
|
37
|
+
weight: 0.4,
|
|
38
|
+
},
|
|
39
|
+
// system_impersonation — high severity
|
|
40
|
+
{
|
|
41
|
+
category: 'system_impersonation',
|
|
42
|
+
pattern: /^(system|admin|root|assistant|developer)\s*:/im,
|
|
43
|
+
severity: 'high',
|
|
44
|
+
weight: 0.4,
|
|
45
|
+
},
|
|
46
|
+
{
|
|
47
|
+
category: 'system_impersonation',
|
|
48
|
+
pattern: /^\[(system|admin|root|internal)\]/im,
|
|
49
|
+
severity: 'high',
|
|
50
|
+
weight: 0.4,
|
|
51
|
+
},
|
|
52
|
+
{
|
|
53
|
+
category: 'system_impersonation',
|
|
54
|
+
pattern: /<<\s*(system|sys|admin)\s*>>/i,
|
|
55
|
+
severity: 'high',
|
|
56
|
+
weight: 0.4,
|
|
57
|
+
},
|
|
58
|
+
{
|
|
59
|
+
category: 'system_impersonation',
|
|
60
|
+
pattern: /new\s+system\s+prompt/i,
|
|
61
|
+
severity: 'high',
|
|
62
|
+
weight: 0.4,
|
|
63
|
+
},
|
|
64
|
+
{
|
|
65
|
+
category: 'system_impersonation',
|
|
66
|
+
pattern: /output\s+(the|your)\s+system\s+prompt/i,
|
|
67
|
+
severity: 'high',
|
|
68
|
+
weight: 0.4,
|
|
69
|
+
},
|
|
70
|
+
// role_override — medium severity
|
|
71
|
+
{
|
|
72
|
+
category: 'role_override',
|
|
73
|
+
pattern: /you\s+are\s+now\s+(a|an|the)\s/i,
|
|
74
|
+
severity: 'medium',
|
|
75
|
+
weight: 0.3,
|
|
76
|
+
},
|
|
77
|
+
{
|
|
78
|
+
category: 'role_override',
|
|
79
|
+
pattern: /pretend\s+(to\s+be|you\s+are|you're)/i,
|
|
80
|
+
severity: 'medium',
|
|
81
|
+
weight: 0.3,
|
|
82
|
+
},
|
|
83
|
+
{
|
|
84
|
+
category: 'role_override',
|
|
85
|
+
pattern: /act\s+as\s+(a|an|the|if)\s/i,
|
|
86
|
+
severity: 'medium',
|
|
87
|
+
weight: 0.3,
|
|
88
|
+
},
|
|
89
|
+
{
|
|
90
|
+
category: 'role_override',
|
|
91
|
+
pattern: /switch\s+to\s+(\w+)\s+mode/i,
|
|
92
|
+
severity: 'medium',
|
|
93
|
+
weight: 0.3,
|
|
94
|
+
},
|
|
95
|
+
{
|
|
96
|
+
category: 'role_override',
|
|
97
|
+
pattern: /enter\s+(jailbreak|unrestricted|developer|god)\s+mode/i,
|
|
98
|
+
severity: 'medium',
|
|
99
|
+
weight: 0.3,
|
|
100
|
+
},
|
|
101
|
+
// delimiter_escape — medium severity
|
|
102
|
+
{
|
|
103
|
+
category: 'delimiter_escape',
|
|
104
|
+
pattern: /<\/?(system|user|assistant|user_description|instructions?|prompt)\s*>/i,
|
|
105
|
+
severity: 'medium',
|
|
106
|
+
weight: 0.3,
|
|
107
|
+
},
|
|
108
|
+
{
|
|
109
|
+
category: 'delimiter_escape',
|
|
110
|
+
pattern: /```\s*(system|prompt|instructions)/i,
|
|
111
|
+
severity: 'medium',
|
|
112
|
+
weight: 0.3,
|
|
113
|
+
},
|
|
114
|
+
{
|
|
115
|
+
category: 'delimiter_escape',
|
|
116
|
+
pattern: /---\s*(BEGIN|END)\s+(SYSTEM|PROMPT|INSTRUCTIONS)\s*---/i,
|
|
117
|
+
severity: 'medium',
|
|
118
|
+
weight: 0.3,
|
|
119
|
+
},
|
|
120
|
+
// encoding_evasion — low severity
|
|
121
|
+
{
|
|
122
|
+
category: 'encoding_evasion',
|
|
123
|
+
pattern: /[A-Za-z0-9+/]{40,}={0,2}/, // Long base64 blocks
|
|
124
|
+
severity: 'low',
|
|
125
|
+
weight: 0.15,
|
|
126
|
+
},
|
|
127
|
+
{
|
|
128
|
+
category: 'encoding_evasion',
|
|
129
|
+
pattern: /\\u[0-9a-fA-F]{4}(\\u[0-9a-fA-F]{4}){3,}/, // Excessive unicode escapes
|
|
130
|
+
severity: 'low',
|
|
131
|
+
weight: 0.15,
|
|
132
|
+
},
|
|
133
|
+
{
|
|
134
|
+
category: 'encoding_evasion',
|
|
135
|
+
pattern: /%[0-9a-fA-F]{2}(%[0-9a-fA-F]{2}){5,}/, // Excessive URL encoding
|
|
136
|
+
severity: 'low',
|
|
137
|
+
weight: 0.15,
|
|
138
|
+
},
|
|
139
|
+
];
|
|
140
|
+
// ── Scanner ──────────────────────────────────────────────────
|
|
141
|
+
export function scanForInjection(text) {
|
|
142
|
+
const findings = [];
|
|
143
|
+
const seenCategories = new Set();
|
|
144
|
+
let score = 0;
|
|
145
|
+
for (const def of PATTERNS) {
|
|
146
|
+
const match = text.match(def.pattern);
|
|
147
|
+
if (match) {
|
|
148
|
+
findings.push({
|
|
149
|
+
category: def.category,
|
|
150
|
+
pattern: def.pattern.source,
|
|
151
|
+
match: match[0].slice(0, 100),
|
|
152
|
+
severity: def.severity,
|
|
153
|
+
weight: def.weight,
|
|
154
|
+
});
|
|
155
|
+
// Each category contributes its weight at most once to the score
|
|
156
|
+
if (!seenCategories.has(def.category)) {
|
|
157
|
+
seenCategories.add(def.category);
|
|
158
|
+
score += def.weight;
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
score = Math.min(score, 1.0);
|
|
163
|
+
let action;
|
|
164
|
+
if (score >= 0.8) {
|
|
165
|
+
action = 'block';
|
|
166
|
+
}
|
|
167
|
+
else if (score >= 0.3) {
|
|
168
|
+
action = 'warn';
|
|
169
|
+
}
|
|
170
|
+
else {
|
|
171
|
+
action = 'allow';
|
|
172
|
+
}
|
|
173
|
+
return {
|
|
174
|
+
clean: findings.length === 0,
|
|
175
|
+
score,
|
|
176
|
+
findings,
|
|
177
|
+
action,
|
|
178
|
+
};
|
|
179
|
+
}
|
|
180
|
+
//# sourceMappingURL=prompt-guard.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"prompt-guard.js","sourceRoot":"","sources":["../../src/runtime/prompt-guard.ts"],"names":[],"mappings":"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"}
|