skyloom 1.6.0 → 1.8.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 (44) hide show
  1. package/dist/core/agent.d.ts.map +1 -1
  2. package/dist/core/agent.js +44 -1
  3. package/dist/core/agent.js.map +1 -1
  4. package/dist/core/arbitrate.d.ts +32 -0
  5. package/dist/core/arbitrate.d.ts.map +1 -0
  6. package/dist/core/arbitrate.js +136 -0
  7. package/dist/core/arbitrate.js.map +1 -0
  8. package/dist/core/estimate.d.ts +30 -0
  9. package/dist/core/estimate.d.ts.map +1 -0
  10. package/dist/core/estimate.js +94 -0
  11. package/dist/core/estimate.js.map +1 -0
  12. package/dist/core/evolve.d.ts +43 -0
  13. package/dist/core/evolve.d.ts.map +1 -0
  14. package/dist/core/evolve.js +201 -0
  15. package/dist/core/evolve.js.map +1 -0
  16. package/dist/core/filter.d.ts +16 -0
  17. package/dist/core/filter.d.ts.map +1 -0
  18. package/dist/core/filter.js +91 -0
  19. package/dist/core/filter.js.map +1 -0
  20. package/dist/core/index.d.ts +7 -1
  21. package/dist/core/index.d.ts.map +1 -1
  22. package/dist/core/index.js +13 -2
  23. package/dist/core/index.js.map +1 -1
  24. package/dist/core/longdoc.d.ts +41 -0
  25. package/dist/core/longdoc.d.ts.map +1 -0
  26. package/dist/core/longdoc.js +128 -0
  27. package/dist/core/longdoc.js.map +1 -0
  28. package/dist/core/sandbox.d.ts +24 -0
  29. package/dist/core/sandbox.d.ts.map +1 -0
  30. package/dist/core/sandbox.js +158 -0
  31. package/dist/core/sandbox.js.map +1 -0
  32. package/dist/tools/builtin.d.ts.map +1 -1
  33. package/dist/tools/builtin.js +3 -3
  34. package/dist/tools/builtin.js.map +1 -1
  35. package/package.json +1 -1
  36. package/src/core/agent.ts +33 -1
  37. package/src/core/arbitrate.ts +162 -0
  38. package/src/core/estimate.ts +104 -0
  39. package/src/core/evolve.ts +191 -0
  40. package/src/core/filter.ts +103 -0
  41. package/src/core/index.ts +8 -2
  42. package/src/core/longdoc.ts +155 -0
  43. package/src/core/sandbox.ts +142 -0
  44. package/src/tools/builtin.ts +4 -6
@@ -0,0 +1,94 @@
1
+ "use strict";
2
+ /**
3
+ * 资源估算模块 — Token & time budget estimation for task planning.
4
+ *
5
+ * Helps Snow and other planning agents estimate the cost of
6
+ * proposed sub-tasks before committing to execution.
7
+ */
8
+ Object.defineProperty(exports, "__esModule", { value: true });
9
+ exports.estimateTokens = estimateTokens;
10
+ exports.estimateTaskCost = estimateTaskCost;
11
+ exports.estimateTaskPlan = estimateTaskPlan;
12
+ exports.formatPlanEstimate = formatPlanEstimate;
13
+ /* ═══════════════════════════════════════
14
+ Token estimation
15
+ ═══════════════════════════════════════ */
16
+ const CJK_REGEX = /[一-鿿぀-ゟ가-힯㐀-䶿]/g;
17
+ /** Estimate tokens for a given text (CJK ~2 each, ASCII ~4 chars each). */
18
+ function estimateTokens(text) {
19
+ const cjk = (text.match(CJK_REGEX) || []).length;
20
+ return cjk * 2 + Math.ceil((text.length - cjk) / 4);
21
+ }
22
+ /* ═══════════════════════════════════════
23
+ Per-task-type cost estimates
24
+ ═══════════════════════════════════════ */
25
+ const TASK_TYPE_PATTERNS = [
26
+ // [pattern, estimated tokens, estimated tools]
27
+ [/read|read_file|grep|search|查|搜索|list/i, 2000, 2],
28
+ [/write|write_file|生成|写|create|implement/i, 4000, 5],
29
+ [/edit|edit_file|改|修改|fix|修复/i, 3000, 3],
30
+ [/delete|delete_file|删|rm/i, 1500, 2],
31
+ [/deploy|部署|publish|发布|release/i, 8000, 8],
32
+ [/review|审查|audit|审计|scan|扫描/i, 5000, 4],
33
+ [/test|测试|run_test|coverage/i, 3000, 3],
34
+ [/research|研究|调研|analyze|分析/i, 6000, 4],
35
+ [/orchestrate|编排|multi-step|多步/i, 12000, 10],
36
+ ];
37
+ /** Estimate cost for a single task description. */
38
+ function estimateTaskCost(description) {
39
+ let tokens = 2000; // base
40
+ let tools = 2; // base
41
+ for (const [pattern, t, tc] of TASK_TYPE_PATTERNS) {
42
+ if (pattern.test(description)) {
43
+ tokens = Math.max(tokens, t);
44
+ tools = Math.max(tools, tc);
45
+ }
46
+ }
47
+ // Time estimate: ~0.5s per tool call + 2s per 1k tokens
48
+ const timeSeconds = (tokens / 1000) * 2 + tools * 0.5 + 2;
49
+ return { tokens, tools, timeSeconds };
50
+ }
51
+ function estimateTaskPlan(tasks) {
52
+ const perTask = [];
53
+ let totalTokens = 500; // system prompt overhead
54
+ let totalTools = 0;
55
+ let totalTime = 5; // init overhead
56
+ const warnings = [];
57
+ for (const t of tasks) {
58
+ const est = estimateTaskCost(t.description);
59
+ perTask.push({ id: t.id, tokens: est.tokens, tools: est.tools, time: est.timeSeconds });
60
+ totalTokens += est.tokens;
61
+ totalTools += est.tools;
62
+ totalTime += est.timeSeconds;
63
+ if (est.timeSeconds > 60)
64
+ warnings.push(`Task ${t.id} may take >${Math.round(est.timeSeconds)}s`);
65
+ if (est.tools > 10)
66
+ warnings.push(`Task ${t.id} uses many tool calls (${est.tools})`);
67
+ }
68
+ if (totalTokens > 64000)
69
+ warnings.push(`Total token estimate (${totalTokens}) exceeds typical context window`);
70
+ if (totalTime > 120)
71
+ warnings.push(`Estimated total time (${Math.round(totalTime)}s) is significant`);
72
+ if (tasks.length > 6)
73
+ warnings.push(`Large number of sub-tasks (${tasks.length}) — consider merging simpler ones`);
74
+ return { totalTokens, totalTools, totalTimeSeconds: Math.round(totalTime), perTask, warnings };
75
+ }
76
+ /* ═══════════════════════════════════════
77
+ Format estimate for display
78
+ ═══════════════════════════════════════ */
79
+ function formatPlanEstimate(est) {
80
+ const lines = [
81
+ `## Plan Estimate`,
82
+ `| Task | Tokens | Tools | Time |`,
83
+ `|------|--------|-------|------|`,
84
+ ...est.perTask.map(t => `| ${t.id} | ${t.tokens} | ${t.tools} | ${t.time.toFixed(0)}s |`),
85
+ `| **Total** | **${est.totalTokens}** | **${est.totalTools}** | **${est.totalTimeSeconds}s** |`,
86
+ ];
87
+ if (est.warnings.length > 0) {
88
+ lines.push("", "### Warnings");
89
+ for (const w of est.warnings)
90
+ lines.push(`- ⚠ ${w}`);
91
+ }
92
+ return lines.join("\n");
93
+ }
94
+ //# sourceMappingURL=estimate.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"estimate.js","sourceRoot":"","sources":["../../src/core/estimate.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,43 @@
1
+ /**
2
+ * 自我进化模块 — Prompt self-optimization via failure analysis.
3
+ *
4
+ * When an agent repeatedly fails at similar tasks, this module analyzes
5
+ * the failure patterns and suggests targeted improvements to the agent's
6
+ * System Prompt. The agent can then apply these suggestions to improve
7
+ * future performance.
8
+ *
9
+ * Architecture:
10
+ * Failure log → Pattern analysis → Prompt diff → Agent.applyDiff()
11
+ */
12
+ export interface PromptDiff {
13
+ id: string;
14
+ ts: string;
15
+ agent: string;
16
+ reason: string;
17
+ before: string;
18
+ after: string;
19
+ applied: boolean;
20
+ improvement?: string;
21
+ }
22
+ export interface FailureAnalysis {
23
+ agent: string;
24
+ period: string;
25
+ totalCalls: number;
26
+ failureCount: number;
27
+ topFailures: Array<{
28
+ pattern: string;
29
+ count: number;
30
+ }>;
31
+ suggestedDiffs: PromptDiff[];
32
+ }
33
+ /** Analyze recent failures from the learning module and suggest prompt improvements. */
34
+ export declare function analyzeFailures(agent: string, experiences: Array<{
35
+ pattern: string;
36
+ solution: string;
37
+ frequency: number;
38
+ lastSeen: string;
39
+ }>, systemPrompt: string): FailureAnalysis;
40
+ export declare function applyPromptDiff(agent: any, diff: PromptDiff): boolean;
41
+ /** Get all applied diffs for an agent. */
42
+ export declare function getAppliedDiffs(agent: string): PromptDiff[];
43
+ //# sourceMappingURL=evolve.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"evolve.d.ts","sourceRoot":"","sources":["../../src/core/evolve.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAYH,MAAM,WAAW,UAAU;IACzB,EAAE,EAAE,MAAM,CAAC;IACX,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,OAAO,CAAC;IACjB,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAKD,MAAM,WAAW,eAAe;IAC9B,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;IACf,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,EAAE,MAAM,CAAC;IACrB,WAAW,EAAE,KAAK,CAAC;QAAE,OAAO,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IACvD,cAAc,EAAE,UAAU,EAAE,CAAC;CAC9B;AAKD,wFAAwF;AACxF,wBAAgB,eAAe,CAC7B,KAAK,EAAE,MAAM,EACb,WAAW,EAAE,KAAK,CAAC;IAAE,OAAO,EAAE,MAAM,CAAC;IAAC,QAAQ,EAAE,MAAM,CAAC;IAAC,SAAS,EAAE,MAAM,CAAC;IAAC,QAAQ,EAAE,MAAM,CAAA;CAAE,CAAC,EAC9F,YAAY,EAAE,MAAM,GACnB,eAAe,CA2FjB;AAKD,wBAAgB,eAAe,CAAC,KAAK,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,GAAG,OAAO,CA4BrE;AAED,0CAA0C;AAC1C,wBAAgB,eAAe,CAAC,KAAK,EAAE,MAAM,GAAG,UAAU,EAAE,CAU3D"}
@@ -0,0 +1,201 @@
1
+ "use strict";
2
+ /**
3
+ * 自我进化模块 — Prompt self-optimization via failure analysis.
4
+ *
5
+ * When an agent repeatedly fails at similar tasks, this module analyzes
6
+ * the failure patterns and suggests targeted improvements to the agent's
7
+ * System Prompt. The agent can then apply these suggestions to improve
8
+ * future performance.
9
+ *
10
+ * Architecture:
11
+ * Failure log → Pattern analysis → Prompt diff → Agent.applyDiff()
12
+ */
13
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
14
+ if (k2 === undefined) k2 = k;
15
+ var desc = Object.getOwnPropertyDescriptor(m, k);
16
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
17
+ desc = { enumerable: true, get: function() { return m[k]; } };
18
+ }
19
+ Object.defineProperty(o, k2, desc);
20
+ }) : (function(o, m, k, k2) {
21
+ if (k2 === undefined) k2 = k;
22
+ o[k2] = m[k];
23
+ }));
24
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
25
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
26
+ }) : function(o, v) {
27
+ o["default"] = v;
28
+ });
29
+ var __importStar = (this && this.__importStar) || (function () {
30
+ var ownKeys = function(o) {
31
+ ownKeys = Object.getOwnPropertyNames || function (o) {
32
+ var ar = [];
33
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
34
+ return ar;
35
+ };
36
+ return ownKeys(o);
37
+ };
38
+ return function (mod) {
39
+ if (mod && mod.__esModule) return mod;
40
+ var result = {};
41
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
42
+ __setModuleDefault(result, mod);
43
+ return result;
44
+ };
45
+ })();
46
+ Object.defineProperty(exports, "__esModule", { value: true });
47
+ exports.analyzeFailures = analyzeFailures;
48
+ exports.applyPromptDiff = applyPromptDiff;
49
+ exports.getAppliedDiffs = getAppliedDiffs;
50
+ const fs = __importStar(require("fs"));
51
+ const path = __importStar(require("path"));
52
+ const config_1 = require("./config");
53
+ const logger_1 = require("./logger");
54
+ const log = (0, logger_1.getLogger)("evolve");
55
+ const evolveDir = path.join(config_1.USER_CONFIG_DIR, "evolve");
56
+ function ensureDir() { if (!fs.existsSync(evolveDir))
57
+ fs.mkdirSync(evolveDir, { recursive: true }); }
58
+ /** Analyze recent failures from the learning module and suggest prompt improvements. */
59
+ function analyzeFailures(agent, experiences, systemPrompt) {
60
+ const recent = experiences.filter(e => {
61
+ try {
62
+ return new Date(e.lastSeen).getTime() > Date.now() - 7 * 86400000;
63
+ }
64
+ catch {
65
+ return false;
66
+ }
67
+ });
68
+ const topFailures = recent
69
+ .sort((a, b) => b.frequency - a.frequency)
70
+ .slice(0, 5)
71
+ .map(e => ({ pattern: e.pattern, count: e.frequency }));
72
+ const suggestedDiffs = [];
73
+ // Rule-based suggestions from failure patterns
74
+ for (const f of topFailures) {
75
+ const lower = f.pattern.toLowerCase();
76
+ // Search storm → add search budget rule
77
+ if ((lower.includes("search") || lower.includes("web_search")) && f.count >= 3) {
78
+ const rule = `- 搜索不超过 5 轮。5 轮后直接基于已有信息综合回答。`;
79
+ if (!systemPrompt.includes("搜索不超过")) {
80
+ suggestedDiffs.push({
81
+ id: Math.random().toString(36).slice(2, 8),
82
+ ts: new Date().toISOString(), agent,
83
+ reason: `搜索风暴 (${f.count} 次重复搜索)`,
84
+ before: "", after: rule, applied: false,
85
+ });
86
+ }
87
+ }
88
+ // Empty response → add deliverable checklist
89
+ if ((lower.includes("empty") || lower.includes("placeholder") || lower.includes("完成了")) && f.count >= 2) {
90
+ const rule = `- 完成任务后,必须输出实际产物(代码/文件路径/数据),禁止只说"完成了"而无产出。`;
91
+ if (!systemPrompt.includes("必须输出实际产物")) {
92
+ suggestedDiffs.push({
93
+ id: Math.random().toString(36).slice(2, 8),
94
+ ts: new Date().toISOString(), agent,
95
+ reason: `空响应/占位 (${f.count} 次)`,
96
+ before: "", after: rule, applied: false,
97
+ });
98
+ }
99
+ }
100
+ // Tool not found → add tool discovery to prompt
101
+ if (lower.includes("does not exist") || lower.includes("tool") && lower.includes("not found")) {
102
+ const rule = `- 使用不熟悉的工具前先调 list_skills 查看可用工具列表。`;
103
+ if (!systemPrompt.includes("list_skills")) {
104
+ suggestedDiffs.push({
105
+ id: Math.random().toString(36).slice(2, 8),
106
+ ts: new Date().toISOString(), agent,
107
+ reason: `工具不存在 (${f.count} 次)`,
108
+ before: "", after: rule, applied: false,
109
+ });
110
+ }
111
+ }
112
+ // File not found → add path verification rule
113
+ if (lower.includes("file not found") || lower.includes("directory not found")) {
114
+ const rule = `- 文件操作前先用 list_directory 或 read_file 确认路径存在。`;
115
+ if (!systemPrompt.includes("确认路径存在")) {
116
+ suggestedDiffs.push({
117
+ id: Math.random().toString(36).slice(2, 8),
118
+ ts: new Date().toISOString(), agent,
119
+ reason: `文件路径错误 (${f.count} 次)`,
120
+ before: "", after: rule, applied: false,
121
+ });
122
+ }
123
+ }
124
+ }
125
+ // General rule: if failure rate > 20%, suggest self-review
126
+ const recentExperiences = recent.filter(e => {
127
+ try {
128
+ return new Date(e.lastSeen).getTime() > Date.now() - 3 * 86400000;
129
+ }
130
+ catch {
131
+ return false;
132
+ }
133
+ });
134
+ // Deduplicate suggestions
135
+ const seen = new Set();
136
+ const uniqueDiffs = suggestedDiffs.filter(d => {
137
+ const key = d.after.slice(0, 30);
138
+ if (seen.has(key))
139
+ return false;
140
+ seen.add(key);
141
+ return true;
142
+ });
143
+ // Max 3 suggestions per analysis
144
+ return {
145
+ agent, period: "last 7 days",
146
+ totalCalls: 0, failureCount: 0,
147
+ topFailures,
148
+ suggestedDiffs: uniqueDiffs.slice(0, 3),
149
+ };
150
+ }
151
+ /* ═══════════════════════════════════════
152
+ Apply prompt diff to agent
153
+ ═══════════════════════════════════════ */
154
+ function applyPromptDiff(agent, diff) {
155
+ try {
156
+ const currentPrompt = agent.systemPrompt;
157
+ if (!diff.after || currentPrompt.includes(diff.after.slice(0, 20)))
158
+ return false;
159
+ // Append the new rule after "## 行为守则" or "## Behavior" section
160
+ const marker = currentPrompt.includes("行为守则") ? "## 行为守则" : "## Behavior";
161
+ const idx = currentPrompt.indexOf(marker);
162
+ if (idx < 0) {
163
+ agent.systemPrompt += "\n" + diff.after;
164
+ }
165
+ else {
166
+ const insertPoint = currentPrompt.indexOf("\n", currentPrompt.indexOf("\n-", idx) + 1);
167
+ agent.systemPrompt = currentPrompt.slice(0, insertPoint) + "\n" + diff.after + "\n" + currentPrompt.slice(insertPoint);
168
+ }
169
+ diff.applied = true;
170
+ diff.improvement = "pending evaluation";
171
+ // Persist the diff
172
+ ensureDir();
173
+ const file = path.join(evolveDir, `${diff.agent}_diffs.jsonl`);
174
+ fs.appendFileSync(file, JSON.stringify(diff) + "\n");
175
+ agent.rebuildSystemPrompt();
176
+ return true;
177
+ }
178
+ catch (e) {
179
+ log.warn("apply_prompt_diff_failed", { agent: diff.agent, error: String(e) });
180
+ return false;
181
+ }
182
+ }
183
+ /** Get all applied diffs for an agent. */
184
+ function getAppliedDiffs(agent) {
185
+ const diffs = [];
186
+ try {
187
+ const file = path.join(evolveDir, `${agent}_diffs.jsonl`);
188
+ if (fs.existsSync(file)) {
189
+ const lines = fs.readFileSync(file, "utf-8").split("\n").filter(Boolean);
190
+ for (const line of lines) {
191
+ try {
192
+ diffs.push(JSON.parse(line));
193
+ }
194
+ catch { }
195
+ }
196
+ }
197
+ }
198
+ catch { /* ignore */ }
199
+ return diffs;
200
+ }
201
+ //# sourceMappingURL=evolve.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"evolve.js","sourceRoot":"","sources":["../../src/core/evolve.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,16 @@
1
+ /**
2
+ * 输出过滤模块 — sensitive information sanitization.
3
+ *
4
+ * Before agent responses reach the user (or are persisted),
5
+ * scan for and redact sensitive patterns like API keys,
6
+ * tokens, passwords, PII, and internal paths.
7
+ */
8
+ export interface FilterResult {
9
+ clean: string;
10
+ redacted: boolean;
11
+ count: number;
12
+ details: string[];
13
+ }
14
+ export declare function filterOutput(text: string): FilterResult;
15
+ export declare function needsFiltering(text: string): boolean;
16
+ //# sourceMappingURL=filter.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"filter.d.ts","sourceRoot":"","sources":["../../src/core/filter.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AA2CH,MAAM,WAAW,YAAY;IAC3B,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,OAAO,CAAC;IAClB,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,MAAM,EAAE,CAAC;CACnB;AAED,wBAAgB,YAAY,CAAC,IAAI,EAAE,MAAM,GAAG,YAAY,CAgCvD;AAKD,wBAAgB,cAAc,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CASpD"}
@@ -0,0 +1,91 @@
1
+ "use strict";
2
+ /**
3
+ * 输出过滤模块 — sensitive information sanitization.
4
+ *
5
+ * Before agent responses reach the user (or are persisted),
6
+ * scan for and redact sensitive patterns like API keys,
7
+ * tokens, passwords, PII, and internal paths.
8
+ */
9
+ Object.defineProperty(exports, "__esModule", { value: true });
10
+ exports.filterOutput = filterOutput;
11
+ exports.needsFiltering = needsFiltering;
12
+ /* ═══════════════════════════════════════
13
+ Detection patterns — compiled once at module load
14
+ ═══════════════════════════════════════ */
15
+ const SENSITIVE_PATTERNS = [
16
+ // API keys & tokens
17
+ [/sk-[a-zA-Z0-9]{32,}/g, "[REDACTED:API_KEY]"],
18
+ [/(?:api_key|apikey|secret_key|access_token|auth_token)\s*[:=]\s*["']?[^\s"']{8,}["']?/gi, "$1: [REDACTED]"],
19
+ [/ghp_[a-zA-Z0-9]{36}/g, "[REDACTED:GITHUB_TOKEN]"],
20
+ [/gho_[a-zA-Z0-9]{36}/g, "[REDACTED:GITHUB_TOKEN]"],
21
+ // AWS credentials
22
+ [/AKIA[0-9A-Z]{16}/g, "[REDACTED:AWS_KEY]"],
23
+ [/(?:aws_access_key_id|aws_secret_access_key)\s*[:=]\s*["']?[^\s"']+/gi, "$1: [REDACTED]"],
24
+ // Passwords
25
+ [/(?:password|passwd|pwd)\s*[:=]\s*["']?[^\s"']{4,}["']?/gi, "$1: [REDACTED]"],
26
+ [/(?:密码|口令)\s*[:=]\s*["']?[^\s"']{2,}["']?/g, "$1: [已脱敏]"],
27
+ // Connection strings
28
+ [/(?:mongodb|postgres|mysql|redis):\/\/[^\s]+/g, "[REDACTED:DB_URI]"],
29
+ [/(?:jdbc|odbc):[^\s]+/g, "[REDACTED:DB_URI]"],
30
+ // Private keys
31
+ [/-----BEGIN (?:RSA |EC |DSA |OPENSSH )?PRIVATE KEY-----[\s\S]*?-----END .*?PRIVATE KEY-----/g, "[REDACTED:PRIVATE_KEY]"],
32
+ // IP addresses (local only)
33
+ [/192\.168\.\d{1,3}\.\d{1,3}/g, "[REDACTED:LAN_IP]"],
34
+ [/10\.\d{1,3}\.\d{1,3}\.\d{1,3}/g, "[REDACTED:LAN_IP]"],
35
+ [/172\.(1[6-9]|2\d|3[01])\.\d{1,3}\.\d{1,3}/g, "[REDACTED:LAN_IP]"],
36
+ // File paths
37
+ [/(?:\/etc\/(?:passwd|shadow|hosts|sudoers))/g, "[REDACTED:SYSTEM_PATH]"],
38
+ ];
39
+ /* Email masking (function-based, handled separately) */
40
+ const EMAIL_RE = /([a-zA-Z0-9._%+-]{3,})@([a-zA-Z0-9.-]+\.[a-zA-Z]{2,})/g;
41
+ function filterOutput(text) {
42
+ if (!text)
43
+ return { clean: "", redacted: false, count: 0, details: [] };
44
+ let clean = text;
45
+ let count = 0;
46
+ const details = [];
47
+ // Email masking (function-based replacement)
48
+ let emailCount = 0;
49
+ clean = clean.replace(EMAIL_RE, (full, user, domain) => {
50
+ emailCount++;
51
+ return user.slice(0, 2) + "***@" + domain;
52
+ });
53
+ if (emailCount > 0) {
54
+ count += emailCount;
55
+ details.push(`Masked ${emailCount}x email addresses`);
56
+ }
57
+ for (const [pattern, replacement] of SENSITIVE_PATTERNS) {
58
+ const matches = clean.match(pattern);
59
+ if (matches) {
60
+ count += matches.length;
61
+ if (typeof replacement === "string") {
62
+ details.push(`Redacted ${matches.length}x ${pattern.source.slice(0, 30)}`);
63
+ }
64
+ else {
65
+ details.push(`Masked ${matches.length}x email addresses`);
66
+ }
67
+ clean = clean.replace(pattern, replacement);
68
+ }
69
+ }
70
+ return { clean, redacted: count > 0, count, details };
71
+ }
72
+ /* ═══════════════════════════════════════
73
+ Quick check — is filtering needed?
74
+ ═══════════════════════════════════════ */
75
+ function needsFiltering(text) {
76
+ if (!text)
77
+ return false;
78
+ // Quick scan with the most common patterns
79
+ if (/sk-[a-zA-Z0-9]{32,}/.test(text))
80
+ return true;
81
+ if (/api_key.*[:=]/.test(text))
82
+ return true;
83
+ if (/password.*[:=]/.test(text))
84
+ return true;
85
+ if (/-----BEGIN.*PRIVATE KEY-----/.test(text))
86
+ return true;
87
+ if (EMAIL_RE.test(text))
88
+ return true;
89
+ return false;
90
+ }
91
+ //# sourceMappingURL=filter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"filter.js","sourceRoot":"","sources":["../../src/core/filter.ts"],"names":[],"mappings":"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"}
@@ -25,5 +25,11 @@ export * from './skill';
25
25
  export * from './router';
26
26
  export * from './agent';
27
27
  export * from './factory';
28
- export declare const VERSION = "1.4.0";
28
+ export * from './security';
29
+ export * from './learn';
30
+ export * from './longdoc';
31
+ export * from './filter';
32
+ export * from './estimate';
33
+ export * from './arbitrate';
34
+ export declare const VERSION: any;
29
35
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/core/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,cAAc,aAAa,CAAC;AAC5B,cAAc,WAAW,CAAC;AAC1B,cAAc,UAAU,CAAC;AACzB,cAAc,UAAU,CAAC;AACzB,cAAc,QAAQ,CAAC;AACvB,cAAc,mBAAmB,CAAC;AAClC,cAAc,OAAO,CAAC;AACtB,cAAc,SAAS,CAAC;AACxB,cAAc,UAAU,CAAC;AACzB,cAAc,cAAc,CAAC;AAC7B,cAAc,OAAO,CAAC;AACtB,cAAc,OAAO,CAAC;AACtB,OAAO,EAAE,aAAa,EAAE,sBAAsB,EAAE,aAAa,EAAE,iBAAiB,EAAE,iBAAiB,EAAE,WAAW,EAAE,eAAe,EAAE,KAAK,QAAQ,EAAE,KAAK,YAAY,EAAE,MAAM,aAAa,CAAC;AACzL,cAAc,YAAY,CAAC;AAC3B,cAAc,SAAS,CAAC;AACxB,cAAc,cAAc,CAAC;AAC7B,cAAc,aAAa,CAAC;AAC5B,cAAc,WAAW,CAAC;AAC1B,cAAc,eAAe,CAAC;AAC9B,cAAc,iBAAiB,CAAC;AAChC,cAAc,SAAS,CAAC;AACxB,cAAc,UAAU,CAAC;AACzB,cAAc,SAAS,CAAC;AACxB,cAAc,WAAW,CAAC;AAG1B,eAAO,MAAM,OAAO,UAAU,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/core/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,cAAc,aAAa,CAAC;AAC5B,cAAc,WAAW,CAAC;AAC1B,cAAc,UAAU,CAAC;AACzB,cAAc,UAAU,CAAC;AACzB,cAAc,QAAQ,CAAC;AACvB,cAAc,mBAAmB,CAAC;AAClC,cAAc,OAAO,CAAC;AACtB,cAAc,SAAS,CAAC;AACxB,cAAc,UAAU,CAAC;AACzB,cAAc,cAAc,CAAC;AAC7B,cAAc,OAAO,CAAC;AACtB,cAAc,OAAO,CAAC;AACtB,OAAO,EAAE,aAAa,EAAE,sBAAsB,EAAE,aAAa,EAAE,iBAAiB,EAAE,iBAAiB,EAAE,WAAW,EAAE,eAAe,EAAE,KAAK,QAAQ,EAAE,KAAK,YAAY,EAAE,MAAM,aAAa,CAAC;AACzL,cAAc,YAAY,CAAC;AAC3B,cAAc,SAAS,CAAC;AACxB,cAAc,cAAc,CAAC;AAC7B,cAAc,aAAa,CAAC;AAC5B,cAAc,WAAW,CAAC;AAC1B,cAAc,eAAe,CAAC;AAC9B,cAAc,iBAAiB,CAAC;AAChC,cAAc,SAAS,CAAC;AACxB,cAAc,UAAU,CAAC;AACzB,cAAc,SAAS,CAAC;AACxB,cAAc,WAAW,CAAC;AAC1B,cAAc,YAAY,CAAC;AAC3B,cAAc,SAAS,CAAC;AACxB,cAAc,WAAW,CAAC;AAC1B,cAAc,UAAU,CAAC;AACzB,cAAc,YAAY,CAAC;AAC3B,cAAc,aAAa,CAAC;AAG5B,eAAO,MAAM,OAAO,KAAgG,CAAC"}
@@ -49,6 +49,17 @@ __exportStar(require("./skill"), exports);
49
49
  __exportStar(require("./router"), exports);
50
50
  __exportStar(require("./agent"), exports);
51
51
  __exportStar(require("./factory"), exports);
52
- // Version
53
- exports.VERSION = '1.4.0';
52
+ __exportStar(require("./security"), exports);
53
+ __exportStar(require("./learn"), exports);
54
+ __exportStar(require("./longdoc"), exports);
55
+ __exportStar(require("./filter"), exports);
56
+ __exportStar(require("./estimate"), exports);
57
+ __exportStar(require("./arbitrate"), exports);
58
+ // Version — read from package.json
59
+ exports.VERSION = (() => { try {
60
+ return require('../../package.json').version;
61
+ }
62
+ catch {
63
+ return '1.6.0';
64
+ } })();
54
65
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/core/index.ts"],"names":[],"mappings":";AAAA;;GAEG;;;;;;;;;;;;;;;;;AAEH,8CAA4B;AAC5B,4CAA0B;AAC1B,2CAAyB;AACzB,2CAAyB;AACzB,yCAAuB;AACvB,oDAAkC;AAClC,wCAAsB;AACtB,0CAAwB;AACxB,2CAAyB;AACzB,+CAA6B;AAC7B,wCAAsB;AACtB,wCAAsB;AACtB,yCAAyL;AAAhL,0GAAA,aAAa,OAAA;AAAE,mHAAA,sBAAsB,OAAA;AAAE,0GAAA,aAAa,OAAA;AAAE,8GAAA,iBAAiB,OAAA;AAAE,8GAAA,iBAAiB,OAAA;AAAE,wGAAA,WAAW,OAAA;AAAE,4GAAA,eAAe,OAAA;AACjI,6CAA2B;AAC3B,0CAAwB;AACxB,+CAA6B;AAC7B,8CAA4B;AAC5B,4CAA0B;AAC1B,gDAA8B;AAC9B,kDAAgC;AAChC,0CAAwB;AACxB,2CAAyB;AACzB,0CAAwB;AACxB,4CAA0B;AAE1B,UAAU;AACG,QAAA,OAAO,GAAG,OAAO,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/core/index.ts"],"names":[],"mappings":";AAAA;;GAEG;;;;;;;;;;;;;;;;;AAEH,8CAA4B;AAC5B,4CAA0B;AAC1B,2CAAyB;AACzB,2CAAyB;AACzB,yCAAuB;AACvB,oDAAkC;AAClC,wCAAsB;AACtB,0CAAwB;AACxB,2CAAyB;AACzB,+CAA6B;AAC7B,wCAAsB;AACtB,wCAAsB;AACtB,yCAAyL;AAAhL,0GAAA,aAAa,OAAA;AAAE,mHAAA,sBAAsB,OAAA;AAAE,0GAAA,aAAa,OAAA;AAAE,8GAAA,iBAAiB,OAAA;AAAE,8GAAA,iBAAiB,OAAA;AAAE,wGAAA,WAAW,OAAA;AAAE,4GAAA,eAAe,OAAA;AACjI,6CAA2B;AAC3B,0CAAwB;AACxB,+CAA6B;AAC7B,8CAA4B;AAC5B,4CAA0B;AAC1B,gDAA8B;AAC9B,kDAAgC;AAChC,0CAAwB;AACxB,2CAAyB;AACzB,0CAAwB;AACxB,4CAA0B;AAC1B,6CAA2B;AAC3B,0CAAwB;AACxB,4CAA0B;AAC1B,2CAAyB;AACzB,6CAA2B;AAC3B,8CAA4B;AAE5B,mCAAmC;AACtB,QAAA,OAAO,GAAG,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC;IAAC,OAAO,OAAO,CAAC,oBAAoB,CAAC,CAAC,OAAO,CAAC;AAAC,CAAC;AAAC,MAAM,CAAC;IAAC,OAAO,OAAO,CAAC;AAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC"}
@@ -0,0 +1,41 @@
1
+ /**
2
+ * 长文档处理策略 — sliding window + summary chain.
3
+ *
4
+ * When an input exceeds the agent's effective context window,
5
+ * split into overlapping chunks, summarize each, then chain
6
+ * summaries into a final digest.
7
+ *
8
+ * Architecture:
9
+ * Input → Chunk(sliding window) → Per-chunk Summary → Chain → Final Digest
10
+ *
11
+ * All summaries are generated by the calling agent's LLM, so quality
12
+ * depends on the model in use. The chunker is pure text processing
13
+ * and works without any LLM call.
14
+ */
15
+ import type { BaseAgent } from "./agent";
16
+ export interface ChunkOptions {
17
+ /** Target chunk size in characters (default 6000) */
18
+ chunkSize?: number;
19
+ /** Overlap between consecutive chunks in characters (default 800) */
20
+ overlap?: number;
21
+ /** Minimum chunk size before we stop splitting (default 500) */
22
+ minChunk?: number;
23
+ }
24
+ export declare function chunkText(text: string, opts?: ChunkOptions): string[];
25
+ export interface SummaryOptions {
26
+ /** Max total chars for the final digest (default 3000) */
27
+ maxDigestChars?: number;
28
+ /** Custom summarization prompt for each chunk */
29
+ chunkPrompt?: string;
30
+ /** Custom chain prompt for combining summaries */
31
+ chainPrompt?: string;
32
+ }
33
+ export declare function summarizeLongDoc(agent: BaseAgent, text: string, opts?: SummaryOptions): Promise<string>;
34
+ export declare function parseStructuredInput(input: string): {
35
+ hasTable: boolean;
36
+ hasJSON: boolean;
37
+ hasCSV: boolean;
38
+ extractedJSON: string | null;
39
+ extractedTable: string[][] | null;
40
+ };
41
+ //# sourceMappingURL=longdoc.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"longdoc.d.ts","sourceRoot":"","sources":["../../src/core/longdoc.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;GAaG;AAEH,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AAKzC,MAAM,WAAW,YAAY;IAC3B,qDAAqD;IACrD,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,qEAAqE;IACrE,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,gEAAgE;IAChE,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,wBAAgB,SAAS,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,YAAY,GAAG,MAAM,EAAE,CAkCrE;AAKD,MAAM,WAAW,cAAc;IAC7B,0DAA0D;IAC1D,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,iDAAiD;IACjD,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,kDAAkD;IAClD,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAWD,wBAAsB,gBAAgB,CACpC,KAAK,EAAE,SAAS,EAChB,IAAI,EAAE,MAAM,EACZ,IAAI,CAAC,EAAE,cAAc,GACpB,OAAO,CAAC,MAAM,CAAC,CAgCjB;AAKD,wBAAgB,oBAAoB,CAAC,KAAK,EAAE,MAAM,GAAG;IACnD,QAAQ,EAAE,OAAO,CAAC;IAAC,OAAO,EAAE,OAAO,CAAC;IAAC,MAAM,EAAE,OAAO,CAAC;IACrD,aAAa,EAAE,MAAM,GAAG,IAAI,CAAC;IAAC,cAAc,EAAE,MAAM,EAAE,EAAE,GAAG,IAAI,CAAC;CACjE,CAwBA"}