yuangs 2.29.0 → 2.30.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +290 -0
- package/dist/agent/index.d.ts +2 -0
- package/dist/agent/index.js +2 -0
- package/dist/agent/index.js.map +1 -1
- package/dist/agent/policy/engine.d.ts +14 -0
- package/dist/agent/policy/engine.js +76 -0
- package/dist/agent/policy/engine.js.map +1 -0
- package/dist/agent/policy/index.d.ts +3 -0
- package/dist/agent/policy/index.js +20 -0
- package/dist/agent/policy/index.js.map +1 -0
- package/dist/agent/policy/policies/noDangerousShell.d.ts +7 -0
- package/dist/agent/policy/policies/noDangerousShell.js +45 -0
- package/dist/agent/policy/policies/noDangerousShell.js.map +1 -0
- package/dist/agent/policy/types.d.ts +23 -0
- package/dist/agent/policy/types.js +3 -0
- package/dist/agent/policy/types.js.map +1 -0
- package/dist/agent/replay/events.d.ts +21 -0
- package/dist/agent/replay/events.js +3 -0
- package/dist/agent/replay/events.js.map +1 -0
- package/dist/agent/replay/index.d.ts +3 -0
- package/dist/agent/replay/index.js +20 -0
- package/dist/agent/replay/index.js.map +1 -0
- package/dist/agent/replay/recorder.d.ts +11 -0
- package/dist/agent/replay/recorder.js +51 -0
- package/dist/agent/replay/recorder.js.map +1 -0
- package/dist/agent/replay/replayer.d.ts +21 -0
- package/dist/agent/replay/replayer.js +65 -0
- package/dist/agent/replay/replayer.js.map +1 -0
- package/dist/agent/skills.d.ts +5 -0
- package/dist/agent/skills.js +7 -3
- package/dist/agent/skills.js.map +1 -1
- package/dist/api/index.d.ts +1 -0
- package/dist/api/index.js +18 -0
- package/dist/api/index.js.map +1 -0
- package/dist/api/registryAPI.d.ts +22 -0
- package/dist/api/registryAPI.js +66 -0
- package/dist/api/registryAPI.js.map +1 -0
- package/dist/audit/index.d.ts +1 -0
- package/dist/audit/index.js +18 -0
- package/dist/audit/index.js.map +1 -0
- package/dist/audit/timeline.d.ts +75 -0
- package/dist/audit/timeline.js +254 -0
- package/dist/audit/timeline.js.map +1 -0
- package/dist/cli.js +10 -1
- package/dist/cli.js.map +1 -1
- package/dist/commands/explainCommands.d.ts +2 -0
- package/dist/commands/explainCommands.js +36 -0
- package/dist/commands/explainCommands.js.map +1 -0
- package/dist/commands/registryCommands.d.ts +2 -0
- package/dist/commands/registryCommands.js +243 -0
- package/dist/commands/registryCommands.js.map +1 -0
- package/dist/commands/replayCommands.d.ts +2 -0
- package/dist/commands/replayCommands.js +75 -0
- package/dist/commands/replayCommands.js.map +1 -0
- package/dist/commands/skillsCommands.d.ts +2 -0
- package/dist/commands/skillsCommands.js +114 -0
- package/dist/commands/skillsCommands.js.map +1 -0
- package/dist/core/executionRecord.d.ts +8 -0
- package/dist/core/executionRecord.js +2 -0
- package/dist/core/executionRecord.js.map +1 -1
- package/dist/core/explain.d.ts +8 -0
- package/dist/core/explain.js +84 -0
- package/dist/core/explain.js.map +1 -0
- package/dist/core/replayDiff.d.ts +55 -0
- package/dist/core/replayDiff.js +205 -0
- package/dist/core/replayDiff.js.map +1 -0
- package/dist/core/replayEngine.d.ts +3 -0
- package/dist/core/replayEngine.js +23 -1
- package/dist/core/replayEngine.js.map +1 -1
- package/dist/registry/errors.d.ts +21 -0
- package/dist/registry/errors.js +35 -0
- package/dist/registry/errors.js.map +1 -0
- package/dist/registry/index.d.ts +3 -0
- package/dist/registry/index.js +20 -0
- package/dist/registry/index.js.map +1 -0
- package/dist/registry/manifest.d.ts +43 -0
- package/dist/registry/manifest.js +32 -0
- package/dist/registry/manifest.js.map +1 -0
- package/dist/registry/registry.d.ts +20 -0
- package/dist/registry/registry.js +201 -0
- package/dist/registry/registry.js.map +1 -0
- package/dist/risk/explainer.d.ts +39 -0
- package/dist/risk/explainer.js +214 -0
- package/dist/risk/explainer.js.map +1 -0
- package/dist/risk/index.d.ts +1 -0
- package/dist/risk/index.js +18 -0
- package/dist/risk/index.js.map +1 -0
- package/package.json +1 -1
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.registerSkillsCommands = registerSkillsCommands;
|
|
7
|
+
const chalk_1 = __importDefault(require("chalk"));
|
|
8
|
+
const skills_1 = require("../agent/skills");
|
|
9
|
+
const fs_1 = __importDefault(require("fs"));
|
|
10
|
+
const path_1 = __importDefault(require("path"));
|
|
11
|
+
const os_1 = __importDefault(require("os"));
|
|
12
|
+
const SKILLS_FILE = path_1.default.join(os_1.default.homedir(), '.yuangs_skills.json');
|
|
13
|
+
function loadSkills() {
|
|
14
|
+
if (fs_1.default.existsSync(SKILLS_FILE)) {
|
|
15
|
+
try {
|
|
16
|
+
const data = fs_1.default.readFileSync(SKILLS_FILE, 'utf-8');
|
|
17
|
+
return JSON.parse(data);
|
|
18
|
+
}
|
|
19
|
+
catch (e) {
|
|
20
|
+
return [];
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
return [];
|
|
24
|
+
}
|
|
25
|
+
function saveSkills(skills) {
|
|
26
|
+
try {
|
|
27
|
+
fs_1.default.writeFileSync(SKILLS_FILE, JSON.stringify(skills, null, 2));
|
|
28
|
+
}
|
|
29
|
+
catch (e) {
|
|
30
|
+
console.error(chalk_1.default.red(`Failed to save skills to ${SKILLS_FILE}`));
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
function registerSkillsCommands(program) {
|
|
34
|
+
const skillsProgram = program.command('skills').description('Skill management commands');
|
|
35
|
+
skillsProgram
|
|
36
|
+
.command('list')
|
|
37
|
+
.description('List all skills')
|
|
38
|
+
.action(() => {
|
|
39
|
+
const skills = (0, skills_1.getAllSkills)();
|
|
40
|
+
const now = Date.now();
|
|
41
|
+
if (skills.length === 0) {
|
|
42
|
+
console.log(chalk_1.default.gray('📭 No skills found\n'));
|
|
43
|
+
return;
|
|
44
|
+
}
|
|
45
|
+
console.log(chalk_1.default.bold.cyan(`\n📦 Skills (${skills.length})\n`));
|
|
46
|
+
skills.forEach((skill) => {
|
|
47
|
+
const status = skill.enabled ? chalk_1.default.green('✔') : chalk_1.default.gray('⊘');
|
|
48
|
+
const score = (0, skills_1.computeSkillScore)(skill, now);
|
|
49
|
+
const daysAgo = Math.floor((now - skill.lastUsed) / (1000 * 60 * 60 * 24));
|
|
50
|
+
console.log(`${status} ${chalk_1.default.bold(skill.name)}`);
|
|
51
|
+
console.log(chalk_1.default.gray(` Confidence: ${(score * 100).toFixed(0)}%`));
|
|
52
|
+
console.log(chalk_1.default.gray(` Success: ${skill.successCount} / Failure: ${skill.failureCount}`));
|
|
53
|
+
console.log(chalk_1.default.gray(` Last used: ${daysAgo === 0 ? 'today' : `${daysAgo} days ago`}\n`));
|
|
54
|
+
});
|
|
55
|
+
});
|
|
56
|
+
skillsProgram
|
|
57
|
+
.command('explain <name>')
|
|
58
|
+
.description('Explain a specific skill')
|
|
59
|
+
.action((name) => {
|
|
60
|
+
const skills = (0, skills_1.getAllSkills)();
|
|
61
|
+
const skill = skills.find(s => s.name === name || s.id === name);
|
|
62
|
+
if (!skill) {
|
|
63
|
+
console.log(chalk_1.default.red(`❌ Skill "${name}" not found\n`));
|
|
64
|
+
return;
|
|
65
|
+
}
|
|
66
|
+
console.log(chalk_1.default.bold.cyan(`\n📖 Skill Details: ${skill.name}\n`));
|
|
67
|
+
console.log(chalk_1.default.white(`Description: ${skill.description}`));
|
|
68
|
+
console.log(chalk_1.default.gray(`\nWhen to use:`));
|
|
69
|
+
console.log(chalk_1.default.white(` ${skill.whenToUse}`));
|
|
70
|
+
console.log(chalk_1.default.gray(`\nMetrics:`));
|
|
71
|
+
console.log(chalk_1.default.white(` Success: ${skill.successCount} / Failure: ${skill.failureCount}`));
|
|
72
|
+
console.log(chalk_1.default.white(` Confidence: ${(skill.confidence * 100).toFixed(0)}%`));
|
|
73
|
+
console.log(chalk_1.default.white(` Enabled: ${skill.enabled ? 'Yes' : 'No'}`));
|
|
74
|
+
console.log(chalk_1.default.gray(`\nCreated: ${new Date(skill.createdAt).toLocaleString()}`));
|
|
75
|
+
console.log(chalk_1.default.gray(`Last used: ${new Date(skill.lastUsed).toLocaleString()}\n`));
|
|
76
|
+
});
|
|
77
|
+
skillsProgram
|
|
78
|
+
.command('disable <name>')
|
|
79
|
+
.description('Disable a skill')
|
|
80
|
+
.action((name) => {
|
|
81
|
+
const skills = loadSkills();
|
|
82
|
+
const skillIndex = skills.findIndex(s => s.name === name || s.id === name);
|
|
83
|
+
if (skillIndex === -1) {
|
|
84
|
+
console.log(chalk_1.default.red(`❌ Skill "${name}" not found\n`));
|
|
85
|
+
return;
|
|
86
|
+
}
|
|
87
|
+
if (!skills[skillIndex].enabled) {
|
|
88
|
+
console.log(chalk_1.default.yellow(`ℹ️ Skill "${name}" is already disabled\n`));
|
|
89
|
+
return;
|
|
90
|
+
}
|
|
91
|
+
skills[skillIndex].enabled = false;
|
|
92
|
+
saveSkills(skills);
|
|
93
|
+
console.log(chalk_1.default.green(`✓ Skill "${name}" has been disabled\n`));
|
|
94
|
+
});
|
|
95
|
+
skillsProgram
|
|
96
|
+
.command('enable <name>')
|
|
97
|
+
.description('Enable a skill')
|
|
98
|
+
.action((name) => {
|
|
99
|
+
const skills = loadSkills();
|
|
100
|
+
const skillIndex = skills.findIndex(s => s.name === name || s.id === name);
|
|
101
|
+
if (skillIndex === -1) {
|
|
102
|
+
console.log(chalk_1.default.red(`❌ Skill "${name}" not found\n`));
|
|
103
|
+
return;
|
|
104
|
+
}
|
|
105
|
+
if (skills[skillIndex].enabled) {
|
|
106
|
+
console.log(chalk_1.default.yellow(`ℹ️ Skill "${name}" is already enabled\n`));
|
|
107
|
+
return;
|
|
108
|
+
}
|
|
109
|
+
skills[skillIndex].enabled = true;
|
|
110
|
+
saveSkills(skills);
|
|
111
|
+
console.log(chalk_1.default.green(`✓ Skill "${name}" has been enabled\n`));
|
|
112
|
+
});
|
|
113
|
+
}
|
|
114
|
+
//# sourceMappingURL=skillsCommands.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"skillsCommands.js","sourceRoot":"","sources":["../../src/commands/skillsCommands.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,11 +1,16 @@
|
|
|
1
1
|
import { MergedConfig } from './configMerge';
|
|
2
2
|
import { ModelCapabilities, CapabilityMatchExplanation } from './modelMatcher';
|
|
3
3
|
import { CapabilityRequirement } from './modelMatcher';
|
|
4
|
+
import { Skill } from '../agent/skills';
|
|
4
5
|
export interface ExecutionMeta {
|
|
5
6
|
commandName: string;
|
|
6
7
|
timestamp: string;
|
|
7
8
|
toolVersion: string;
|
|
8
9
|
projectPath: string;
|
|
10
|
+
args?: any;
|
|
11
|
+
rawInput?: string;
|
|
12
|
+
replayable?: boolean;
|
|
13
|
+
version?: string;
|
|
9
14
|
}
|
|
10
15
|
export interface CapabilityIntent {
|
|
11
16
|
required: string[];
|
|
@@ -17,6 +22,9 @@ export interface ModelDecision {
|
|
|
17
22
|
selectedModel: ModelCapabilities | null;
|
|
18
23
|
usedFallback: boolean;
|
|
19
24
|
fallbackReason?: string;
|
|
25
|
+
strategy?: string;
|
|
26
|
+
reason?: string;
|
|
27
|
+
skills?: Skill[];
|
|
20
28
|
}
|
|
21
29
|
export interface ExecutionOutcome {
|
|
22
30
|
success: boolean;
|
|
@@ -16,6 +16,8 @@ function createExecutionRecord(commandName, requirement, config, matchResult, ou
|
|
|
16
16
|
timestamp: new Date().toISOString(),
|
|
17
17
|
toolVersion: version,
|
|
18
18
|
projectPath: process.cwd(),
|
|
19
|
+
version,
|
|
20
|
+
replayable: true,
|
|
19
21
|
},
|
|
20
22
|
intent: {
|
|
21
23
|
required: requirement.required.map(String),
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"executionRecord.js","sourceRoot":"","sources":["../../src/core/executionRecord.ts"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"executionRecord.js","sourceRoot":"","sources":["../../src/core/executionRecord.ts"],"names":[],"mappings":";;AAiDA,8CAEC;AAED,sDAqCC;AAED,4DAEC;AAED,gEAEC;AAjDD,SAAgB,iBAAiB;IAC/B,OAAO,QAAQ,IAAI,CAAC,GAAG,EAAE,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC;AACzE,CAAC;AAED,SAAgB,qBAAqB,CACnC,WAAmB,EACnB,WAAkC,EAClC,MAAoB,EACpB,WAAgB,EAChB,UAAqC,EAAE,EACvC,OAAgB;IAEhB,MAAM,OAAO,GAAG,OAAO,CAAC,oBAAoB,CAAC,CAAC,OAAO,CAAC;IAEtD,OAAO;QACL,EAAE,EAAE,iBAAiB,EAAE;QACvB,IAAI,EAAE;YACJ,WAAW;YACX,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;YACnC,WAAW,EAAE,OAAO;YACpB,WAAW,EAAE,OAAO,CAAC,GAAG,EAAE;YAC1B,OAAO;YACP,UAAU,EAAE,IAAI;SACjB;QACD,MAAM,EAAE;YACN,QAAQ,EAAE,WAAW,CAAC,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC;YAC1C,SAAS,EAAE,WAAW,CAAC,SAAS,CAAC,GAAG,CAAC,MAAM,CAAC;YAC5C,iBAAiB,EAAE,OAAO,CAAC,gBAAgB,CAAC,CAAC,kBAAkB;SAChE;QACD,cAAc,EAAE,MAAM;QACtB,QAAQ,EAAE;YACR,eAAe,EAAE,WAAW,CAAC,UAAU,IAAI,EAAE;YAC7C,aAAa,EAAE,WAAW,CAAC,QAAQ;YACnC,YAAY,EAAE,WAAW,CAAC,gBAAgB;SAC3C;QACD,OAAO,EAAE;YACP,OAAO,EAAE,OAAO,CAAC,OAAO,IAAI,KAAK;YACjC,GAAG,OAAO;SACX;QACD,OAAO;KACR,CAAC;AACJ,CAAC;AAED,SAAgB,wBAAwB,CAAC,MAAuB;IAC9D,OAAO,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;AACzC,CAAC;AAED,SAAgB,0BAA0B,CAAC,IAAY;IACrD,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAoB,CAAC;AAC7C,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { ExecutionRecord } from './executionRecord';
|
|
2
|
+
/**
|
|
3
|
+
* Explain Output Spec v1
|
|
4
|
+
* - Stable, human-readable, diff-friendly
|
|
5
|
+
* - No side effects
|
|
6
|
+
* - Do NOT change without bumping spec version
|
|
7
|
+
*/
|
|
8
|
+
export declare function explainExecution(record: ExecutionRecord): string;
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.explainExecution = explainExecution;
|
|
4
|
+
const skills_1 = require("../agent/skills");
|
|
5
|
+
/**
|
|
6
|
+
* Explain Output Spec v1
|
|
7
|
+
* - Stable, human-readable, diff-friendly
|
|
8
|
+
* - No side effects
|
|
9
|
+
* - Do NOT change without bumping spec version
|
|
10
|
+
*/
|
|
11
|
+
function explainExecution(record) {
|
|
12
|
+
const lines = [];
|
|
13
|
+
lines.push('=== Execution Explanation ===');
|
|
14
|
+
/* =========================
|
|
15
|
+
* [1] Command
|
|
16
|
+
* ========================= */
|
|
17
|
+
lines.push('[1] Command');
|
|
18
|
+
lines.push(`- Name: ${record.meta.commandName ?? 'N/A'}`);
|
|
19
|
+
if (record.command) {
|
|
20
|
+
lines.push(`- Args: ${record.command}`);
|
|
21
|
+
}
|
|
22
|
+
if (record.meta.rawInput) {
|
|
23
|
+
lines.push(`- Raw: ${record.meta.rawInput}`);
|
|
24
|
+
}
|
|
25
|
+
lines.push('');
|
|
26
|
+
/* =========================
|
|
27
|
+
* [2] Decision
|
|
28
|
+
* ========================= */
|
|
29
|
+
const decision = record.decision ?? {};
|
|
30
|
+
lines.push('[2] Decision');
|
|
31
|
+
lines.push(`- Strategy: ${decision.strategy ?? 'capability-match'}`);
|
|
32
|
+
lines.push(`- Selected Model: ${decision.selectedModel?.name ?? 'N/A'}`);
|
|
33
|
+
lines.push(`- Reason: ${decision.reason ?? 'Capability-based selection with fallback support'}`);
|
|
34
|
+
lines.push('');
|
|
35
|
+
/* =========================
|
|
36
|
+
* [3] Model
|
|
37
|
+
* ========================= */
|
|
38
|
+
const model = decision.selectedModel;
|
|
39
|
+
lines.push('[3] Model');
|
|
40
|
+
lines.push(`- Name: ${model?.name ?? 'N/A'}`);
|
|
41
|
+
lines.push(`- Provider: ${model?.provider ?? 'N/A'}`);
|
|
42
|
+
lines.push(`- Context Window: ${model?.contextWindow ?? 'default'}`);
|
|
43
|
+
lines.push(`- Cost Profile: ${model?.costProfile ?? 'default'}`);
|
|
44
|
+
lines.push('');
|
|
45
|
+
/* =========================
|
|
46
|
+
* [4] Skills
|
|
47
|
+
* ========================= */
|
|
48
|
+
lines.push('[4] Skills');
|
|
49
|
+
const skills = decision.skills ?? [];
|
|
50
|
+
const now = Date.now();
|
|
51
|
+
if (skills.length === 0) {
|
|
52
|
+
lines.push('- (none)');
|
|
53
|
+
}
|
|
54
|
+
else {
|
|
55
|
+
const scored = skills
|
|
56
|
+
.map(skill => ({
|
|
57
|
+
skill,
|
|
58
|
+
score: (0, skills_1.computeSkillScore)(skill, now),
|
|
59
|
+
}))
|
|
60
|
+
.sort((a, b) => b.score - a.score);
|
|
61
|
+
for (const { skill, score } of scored) {
|
|
62
|
+
const totalUses = skill.successCount + skill.failureCount;
|
|
63
|
+
const successRate = totalUses === 0 ? 0.5 : skill.successCount / totalUses;
|
|
64
|
+
lines.push(`- ${skill.name}`);
|
|
65
|
+
lines.push(` score: ${score.toFixed(3)}`);
|
|
66
|
+
lines.push(` confidence: ${skill.confidence.toFixed(3)}`);
|
|
67
|
+
lines.push(` successRate: ${successRate.toFixed(3)}`);
|
|
68
|
+
lines.push(` enabled: ${skill.enabled}`);
|
|
69
|
+
lines.push(` lastUsed: ${new Date(skill.lastUsed).toISOString()}`);
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
lines.push('');
|
|
73
|
+
/* =========================
|
|
74
|
+
* [5] Meta
|
|
75
|
+
* ========================= */
|
|
76
|
+
lines.push('[5] Meta');
|
|
77
|
+
lines.push(`- Execution ID: ${record.id}`);
|
|
78
|
+
lines.push(`- Timestamp: ${new Date(record.meta.timestamp).toISOString()}`);
|
|
79
|
+
lines.push(`- Replayable: ${record.meta.replayable ?? true}`);
|
|
80
|
+
lines.push(`- Version: ${record.meta.version ?? 'unknown'}`);
|
|
81
|
+
lines.push('=============================');
|
|
82
|
+
return lines.join('\n');
|
|
83
|
+
}
|
|
84
|
+
//# sourceMappingURL=explain.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"explain.js","sourceRoot":"","sources":["../../src/core/explain.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { ExecutionRecord } from './executionRecord';
|
|
2
|
+
export interface ReplayDiffResult {
|
|
3
|
+
decisionDiff: DecisionDiff;
|
|
4
|
+
modelDiff: ModelDiff;
|
|
5
|
+
skillsDiff: SkillsDiff;
|
|
6
|
+
}
|
|
7
|
+
interface DecisionDiff {
|
|
8
|
+
changed: boolean;
|
|
9
|
+
strategyChanged: boolean;
|
|
10
|
+
modelChanged: boolean;
|
|
11
|
+
reasonChanged: boolean;
|
|
12
|
+
before?: {
|
|
13
|
+
strategy: string;
|
|
14
|
+
selectedModel: string;
|
|
15
|
+
reason: string;
|
|
16
|
+
};
|
|
17
|
+
after?: {
|
|
18
|
+
strategy: string;
|
|
19
|
+
selectedModel: string;
|
|
20
|
+
reason: string;
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
interface ModelDiff {
|
|
24
|
+
changed: boolean;
|
|
25
|
+
nameChanged: boolean;
|
|
26
|
+
providerChanged: boolean;
|
|
27
|
+
before?: {
|
|
28
|
+
name: string;
|
|
29
|
+
provider: string;
|
|
30
|
+
contextWindow: number | string;
|
|
31
|
+
costProfile: string;
|
|
32
|
+
};
|
|
33
|
+
after?: {
|
|
34
|
+
name: string;
|
|
35
|
+
provider: string;
|
|
36
|
+
contextWindow: number | string;
|
|
37
|
+
costProfile: string;
|
|
38
|
+
};
|
|
39
|
+
}
|
|
40
|
+
interface SkillsDiff {
|
|
41
|
+
added: SkillChange[];
|
|
42
|
+
removed: SkillChange[];
|
|
43
|
+
changed: SkillChange[];
|
|
44
|
+
}
|
|
45
|
+
interface SkillChange {
|
|
46
|
+
name: string;
|
|
47
|
+
score?: number;
|
|
48
|
+
enabled?: boolean;
|
|
49
|
+
confidence?: number;
|
|
50
|
+
successRate?: number;
|
|
51
|
+
lastUsed?: string;
|
|
52
|
+
}
|
|
53
|
+
export declare function diffExecution(original: ExecutionRecord, current: ExecutionRecord): ReplayDiffResult;
|
|
54
|
+
export declare function formatReplayDiff(diff: ReplayDiffResult): string;
|
|
55
|
+
export {};
|
|
@@ -0,0 +1,205 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.diffExecution = diffExecution;
|
|
4
|
+
exports.formatReplayDiff = formatReplayDiff;
|
|
5
|
+
const skills_1 = require("../agent/skills");
|
|
6
|
+
function diffExecution(original, current) {
|
|
7
|
+
return {
|
|
8
|
+
decisionDiff: diffDecision(original, current),
|
|
9
|
+
modelDiff: diffModel(original, current),
|
|
10
|
+
skillsDiff: diffSkills(original, current),
|
|
11
|
+
};
|
|
12
|
+
}
|
|
13
|
+
function diffDecision(original, current) {
|
|
14
|
+
const origDecision = original.decision;
|
|
15
|
+
const currDecision = current.decision;
|
|
16
|
+
const strategyChanged = origDecision?.strategy !== currDecision?.strategy;
|
|
17
|
+
const modelChanged = origDecision?.selectedModel?.name !== currDecision?.selectedModel?.name;
|
|
18
|
+
const reasonChanged = origDecision?.reason !== currDecision?.reason;
|
|
19
|
+
return {
|
|
20
|
+
changed: strategyChanged || modelChanged || reasonChanged,
|
|
21
|
+
strategyChanged,
|
|
22
|
+
modelChanged,
|
|
23
|
+
reasonChanged,
|
|
24
|
+
before: {
|
|
25
|
+
strategy: origDecision?.strategy ?? 'N/A',
|
|
26
|
+
selectedModel: origDecision?.selectedModel?.name ?? 'N/A',
|
|
27
|
+
reason: origDecision?.reason ?? 'N/A',
|
|
28
|
+
},
|
|
29
|
+
after: {
|
|
30
|
+
strategy: currDecision?.strategy ?? 'N/A',
|
|
31
|
+
selectedModel: currDecision?.selectedModel?.name ?? 'N/A',
|
|
32
|
+
reason: currDecision?.reason ?? 'N/A',
|
|
33
|
+
},
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
function diffModel(original, current) {
|
|
37
|
+
const origModel = original.decision.selectedModel;
|
|
38
|
+
const currModel = current.decision.selectedModel;
|
|
39
|
+
if (!origModel || !currModel) {
|
|
40
|
+
return {
|
|
41
|
+
changed: true,
|
|
42
|
+
nameChanged: true,
|
|
43
|
+
providerChanged: true,
|
|
44
|
+
before: origModel ? {
|
|
45
|
+
name: origModel.name,
|
|
46
|
+
provider: origModel.provider,
|
|
47
|
+
contextWindow: origModel.contextWindow ?? 'default',
|
|
48
|
+
costProfile: origModel.costProfile ?? 'default',
|
|
49
|
+
} : undefined,
|
|
50
|
+
after: currModel ? {
|
|
51
|
+
name: currModel.name,
|
|
52
|
+
provider: currModel.provider,
|
|
53
|
+
contextWindow: currModel.contextWindow ?? 'default',
|
|
54
|
+
costProfile: currModel.costProfile ?? 'default',
|
|
55
|
+
} : undefined,
|
|
56
|
+
};
|
|
57
|
+
}
|
|
58
|
+
const nameChanged = origModel.name !== currModel.name;
|
|
59
|
+
const providerChanged = origModel.provider !== currModel.provider;
|
|
60
|
+
return {
|
|
61
|
+
changed: nameChanged || providerChanged,
|
|
62
|
+
nameChanged,
|
|
63
|
+
providerChanged,
|
|
64
|
+
before: {
|
|
65
|
+
name: origModel.name,
|
|
66
|
+
provider: origModel.provider,
|
|
67
|
+
contextWindow: origModel.contextWindow ?? 'default',
|
|
68
|
+
costProfile: origModel.costProfile ?? 'default',
|
|
69
|
+
},
|
|
70
|
+
after: {
|
|
71
|
+
name: currModel.name,
|
|
72
|
+
provider: currModel.provider,
|
|
73
|
+
contextWindow: currModel.contextWindow ?? 'default',
|
|
74
|
+
costProfile: currModel.costProfile ?? 'default',
|
|
75
|
+
},
|
|
76
|
+
};
|
|
77
|
+
}
|
|
78
|
+
function diffSkills(original, current) {
|
|
79
|
+
const origSkills = original.decision.skills ?? [];
|
|
80
|
+
const currSkills = current.decision.skills ?? [];
|
|
81
|
+
const origSkillMap = new Map(origSkills.map(s => [s.name, s]));
|
|
82
|
+
const currSkillMap = new Map(currSkills.map(s => [s.name, s]));
|
|
83
|
+
const added = [];
|
|
84
|
+
const removed = [];
|
|
85
|
+
const changed = [];
|
|
86
|
+
const now = Date.now();
|
|
87
|
+
// Find added and changed skills
|
|
88
|
+
for (const skill of currSkills) {
|
|
89
|
+
const origSkill = origSkillMap.get(skill.name);
|
|
90
|
+
if (!origSkill) {
|
|
91
|
+
// Added
|
|
92
|
+
const score = (0, skills_1.computeSkillScore)(skill, now);
|
|
93
|
+
const totalUses = skill.successCount + skill.failureCount;
|
|
94
|
+
const successRate = totalUses === 0 ? 0.5 : skill.successCount / totalUses;
|
|
95
|
+
added.push({
|
|
96
|
+
name: skill.name,
|
|
97
|
+
score,
|
|
98
|
+
enabled: skill.enabled,
|
|
99
|
+
confidence: skill.confidence,
|
|
100
|
+
successRate,
|
|
101
|
+
lastUsed: new Date(skill.lastUsed).toISOString(),
|
|
102
|
+
});
|
|
103
|
+
}
|
|
104
|
+
else {
|
|
105
|
+
// Check if changed
|
|
106
|
+
const origScore = (0, skills_1.computeSkillScore)(origSkill, now);
|
|
107
|
+
const currScore = (0, skills_1.computeSkillScore)(skill, now);
|
|
108
|
+
const origTotalUses = origSkill.successCount + origSkill.failureCount;
|
|
109
|
+
const currTotalUses = skill.successCount + skill.failureCount;
|
|
110
|
+
const origSuccessRate = origTotalUses === 0 ? 0.5 : origSkill.successCount / origTotalUses;
|
|
111
|
+
const currSuccessRate = currTotalUses === 0 ? 0.5 : skill.successCount / currTotalUses;
|
|
112
|
+
if (Math.abs(origScore - currScore) > 0.001 ||
|
|
113
|
+
origSkill.enabled !== skill.enabled ||
|
|
114
|
+
Math.abs(origSuccessRate - currSuccessRate) > 0.001) {
|
|
115
|
+
changed.push({
|
|
116
|
+
name: skill.name,
|
|
117
|
+
score: currScore,
|
|
118
|
+
enabled: skill.enabled,
|
|
119
|
+
confidence: skill.confidence,
|
|
120
|
+
successRate: currSuccessRate,
|
|
121
|
+
lastUsed: new Date(skill.lastUsed).toISOString(),
|
|
122
|
+
});
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
// Find removed skills
|
|
127
|
+
for (const skill of origSkills) {
|
|
128
|
+
if (!currSkillMap.has(skill.name)) {
|
|
129
|
+
const score = (0, skills_1.computeSkillScore)(skill, now);
|
|
130
|
+
const totalUses = skill.successCount + skill.failureCount;
|
|
131
|
+
const successRate = totalUses === 0 ? 0.5 : skill.successCount / totalUses;
|
|
132
|
+
removed.push({
|
|
133
|
+
name: skill.name,
|
|
134
|
+
score,
|
|
135
|
+
enabled: skill.enabled,
|
|
136
|
+
confidence: skill.confidence,
|
|
137
|
+
successRate,
|
|
138
|
+
lastUsed: new Date(skill.lastUsed).toISOString(),
|
|
139
|
+
});
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
return {
|
|
143
|
+
added,
|
|
144
|
+
removed,
|
|
145
|
+
changed,
|
|
146
|
+
};
|
|
147
|
+
}
|
|
148
|
+
function formatReplayDiff(diff) {
|
|
149
|
+
const lines = [];
|
|
150
|
+
lines.push('=== Replay Diff ===');
|
|
151
|
+
// [Decision]
|
|
152
|
+
lines.push('[Decision]');
|
|
153
|
+
if (!diff.decisionDiff.changed) {
|
|
154
|
+
lines.push('- no change');
|
|
155
|
+
}
|
|
156
|
+
else {
|
|
157
|
+
if (diff.decisionDiff.strategyChanged) {
|
|
158
|
+
lines.push(`- strategy: ${diff.decisionDiff.before?.strategy} → ${diff.decisionDiff.after?.strategy}`);
|
|
159
|
+
}
|
|
160
|
+
if (diff.decisionDiff.modelChanged) {
|
|
161
|
+
lines.push(`- selectedModel: ${diff.decisionDiff.before?.selectedModel} → ${diff.decisionDiff.after?.selectedModel}`);
|
|
162
|
+
}
|
|
163
|
+
if (diff.decisionDiff.reasonChanged) {
|
|
164
|
+
lines.push(`- reason:`);
|
|
165
|
+
lines.push(` before: "${diff.decisionDiff.before?.reason}"`);
|
|
166
|
+
lines.push(` after: "${diff.decisionDiff.after?.reason}"`);
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
lines.push('');
|
|
170
|
+
// [Model]
|
|
171
|
+
lines.push('[Model]');
|
|
172
|
+
if (!diff.modelDiff.changed) {
|
|
173
|
+
lines.push('- no change');
|
|
174
|
+
}
|
|
175
|
+
else {
|
|
176
|
+
if (diff.modelDiff.nameChanged) {
|
|
177
|
+
lines.push(`- name: ${diff.modelDiff.before?.name} → ${diff.modelDiff.after?.name}`);
|
|
178
|
+
}
|
|
179
|
+
if (diff.modelDiff.providerChanged) {
|
|
180
|
+
lines.push(`- provider: ${diff.modelDiff.before?.provider} → ${diff.modelDiff.after?.provider}`);
|
|
181
|
+
}
|
|
182
|
+
}
|
|
183
|
+
lines.push('');
|
|
184
|
+
// [Skills]
|
|
185
|
+
lines.push('[Skills]');
|
|
186
|
+
if (diff.skillsDiff.added.length === 0 &&
|
|
187
|
+
diff.skillsDiff.removed.length === 0 &&
|
|
188
|
+
diff.skillsDiff.changed.length === 0) {
|
|
189
|
+
lines.push('- no change');
|
|
190
|
+
}
|
|
191
|
+
else {
|
|
192
|
+
for (const skill of diff.skillsDiff.added) {
|
|
193
|
+
lines.push(`+ added: ${skill.name} (score=${skill.score?.toFixed(3)})`);
|
|
194
|
+
}
|
|
195
|
+
for (const skill of diff.skillsDiff.removed) {
|
|
196
|
+
lines.push(`- removed: ${skill.name}`);
|
|
197
|
+
}
|
|
198
|
+
for (const skill of diff.skillsDiff.changed) {
|
|
199
|
+
lines.push(`~ changed: ${skill.name} (score=${skill.score?.toFixed(3)}, enabled=${skill.enabled})`);
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
lines.push('===================');
|
|
203
|
+
return lines.join('\n');
|
|
204
|
+
}
|
|
205
|
+
//# sourceMappingURL=replayDiff.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"replayDiff.js","sourceRoot":"","sources":["../../src/core/replayDiff.ts"],"names":[],"mappings":"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"}
|
|
@@ -6,6 +6,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
6
6
|
exports.replayEngine = exports.ReplayEngine = void 0;
|
|
7
7
|
const chalk_1 = __importDefault(require("chalk"));
|
|
8
8
|
const executionStore_1 = require("./executionStore");
|
|
9
|
+
const explain_1 = require("./explain");
|
|
9
10
|
class ReplayEngine {
|
|
10
11
|
async replay(recordId, options = { mode: 'strict' }) {
|
|
11
12
|
const record = (0, executionStore_1.loadExecutionRecord)(recordId);
|
|
@@ -15,6 +16,20 @@ class ReplayEngine {
|
|
|
15
16
|
message: `Execution record ${recordId} not found`,
|
|
16
17
|
};
|
|
17
18
|
}
|
|
19
|
+
// NOTE: --diff implicitly enables --explain
|
|
20
|
+
if (options.diff) {
|
|
21
|
+
options.explain = true;
|
|
22
|
+
}
|
|
23
|
+
if (options.explain) {
|
|
24
|
+
console.log((0, explain_1.explainExecution)(record));
|
|
25
|
+
console.log('');
|
|
26
|
+
if (options.dry) {
|
|
27
|
+
return {
|
|
28
|
+
success: true,
|
|
29
|
+
message: '[Explain + Dry] Explanation shown, no execution',
|
|
30
|
+
};
|
|
31
|
+
}
|
|
32
|
+
}
|
|
18
33
|
if (options.mode === 'strict') {
|
|
19
34
|
return this.strictReplay(record, options);
|
|
20
35
|
}
|
|
@@ -25,13 +40,20 @@ class ReplayEngine {
|
|
|
25
40
|
}
|
|
26
41
|
async strictReplay(record, options) {
|
|
27
42
|
const selectedModel = record.decision.selectedModel;
|
|
28
|
-
if (options.verbose) {
|
|
43
|
+
if (options.verbose || options.dry) {
|
|
29
44
|
console.log(chalk_1.default.cyan('[Strict Replay]'));
|
|
30
45
|
console.log(chalk_1.default.gray(` Original Model: ${selectedModel?.name || 'N/A'}`));
|
|
31
46
|
console.log(chalk_1.default.gray(` Original Provider: ${selectedModel?.provider || 'N/A'}`));
|
|
32
47
|
console.log(chalk_1.default.gray(` Original Timestamp: ${record.meta.timestamp}`));
|
|
33
48
|
console.log(chalk_1.default.gray(` Original Command: ${record.meta.commandName}`));
|
|
34
49
|
}
|
|
50
|
+
if (options.dry) {
|
|
51
|
+
return {
|
|
52
|
+
success: true,
|
|
53
|
+
message: '[Dry Replay] Command not executed',
|
|
54
|
+
executedModel: selectedModel?.name ?? undefined,
|
|
55
|
+
};
|
|
56
|
+
}
|
|
35
57
|
if (options.skipAI) {
|
|
36
58
|
return {
|
|
37
59
|
success: true,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"replayEngine.js","sourceRoot":"","sources":["../../src/core/replayEngine.ts"],"names":[],"mappings":";;;;;;AAAA,kDAA0B;AAE1B,qDAAuD;
|
|
1
|
+
{"version":3,"file":"replayEngine.js","sourceRoot":"","sources":["../../src/core/replayEngine.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
export declare enum RegistryErrorCode {
|
|
2
|
+
INIT_FAILED = "INIT_FAILED",
|
|
3
|
+
INVALID_MANIFEST = "INVALID_MANIFEST",
|
|
4
|
+
CHECKSUM_MISMATCH = "CHECKSUM_MISMATCH",
|
|
5
|
+
NOT_FOUND = "NOT_FOUND",
|
|
6
|
+
INVALID_STATE = "INVALID_STATE",
|
|
7
|
+
CAPABILITY_DENIED = "CAPABILITY_DENIED",
|
|
8
|
+
DEPENDENCY_CYCLE = "DEPENDENCY_CYCLE",
|
|
9
|
+
VERSION_CONFLICT = "VERSION_CONFLICT"
|
|
10
|
+
}
|
|
11
|
+
export declare class RegistryError extends Error {
|
|
12
|
+
readonly code: RegistryErrorCode;
|
|
13
|
+
readonly details?: any;
|
|
14
|
+
constructor(code: RegistryErrorCode, message: string, details?: any);
|
|
15
|
+
toJSON(): {
|
|
16
|
+
name: string;
|
|
17
|
+
code: RegistryErrorCode;
|
|
18
|
+
message: string;
|
|
19
|
+
details: any;
|
|
20
|
+
};
|
|
21
|
+
}
|