workerclaw 0.3.7 → 0.4.1

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 (64) hide show
  1. package/dist/agent/agent-engine.d.ts +28 -2
  2. package/dist/agent/agent-engine.d.ts.map +1 -1
  3. package/dist/agent/agent-engine.js +123 -6
  4. package/dist/agent/agent-engine.js.map +1 -1
  5. package/dist/cli/index.js +24 -1
  6. package/dist/cli/index.js.map +1 -1
  7. package/dist/cli/sections/experience.d.ts +10 -0
  8. package/dist/cli/sections/experience.d.ts.map +1 -0
  9. package/dist/cli/sections/experience.js +148 -0
  10. package/dist/cli/sections/experience.js.map +1 -0
  11. package/dist/core/config.d.ts +2 -0
  12. package/dist/core/config.d.ts.map +1 -1
  13. package/dist/core/config.js.map +1 -1
  14. package/dist/core/events.d.ts +19 -1
  15. package/dist/core/events.d.ts.map +1 -1
  16. package/dist/core/events.js +4 -0
  17. package/dist/core/events.js.map +1 -1
  18. package/dist/core/workerclaw.d.ts +7 -0
  19. package/dist/core/workerclaw.d.ts.map +1 -1
  20. package/dist/core/workerclaw.js +30 -0
  21. package/dist/core/workerclaw.js.map +1 -1
  22. package/dist/experience/encapsulator.d.ts +95 -0
  23. package/dist/experience/encapsulator.d.ts.map +1 -0
  24. package/dist/experience/encapsulator.js +239 -0
  25. package/dist/experience/encapsulator.js.map +1 -0
  26. package/dist/experience/hub-client.d.ts +32 -0
  27. package/dist/experience/hub-client.d.ts.map +1 -0
  28. package/dist/experience/hub-client.js +126 -0
  29. package/dist/experience/hub-client.js.map +1 -0
  30. package/dist/experience/index.d.ts +13 -0
  31. package/dist/experience/index.d.ts.map +1 -0
  32. package/dist/experience/index.js +30 -0
  33. package/dist/experience/index.js.map +1 -0
  34. package/dist/experience/local-store.d.ts +102 -0
  35. package/dist/experience/local-store.d.ts.map +1 -0
  36. package/dist/experience/local-store.js +321 -0
  37. package/dist/experience/local-store.js.map +1 -0
  38. package/dist/experience/manager.d.ts +71 -0
  39. package/dist/experience/manager.d.ts.map +1 -0
  40. package/dist/experience/manager.js +184 -0
  41. package/dist/experience/manager.js.map +1 -0
  42. package/dist/experience/search-engine.d.ts +80 -0
  43. package/dist/experience/search-engine.d.ts.map +1 -0
  44. package/dist/experience/search-engine.js +258 -0
  45. package/dist/experience/search-engine.js.map +1 -0
  46. package/dist/experience/signal-detector.d.ts +33 -0
  47. package/dist/experience/signal-detector.d.ts.map +1 -0
  48. package/dist/experience/signal-detector.js +182 -0
  49. package/dist/experience/signal-detector.js.map +1 -0
  50. package/dist/experience/types.d.ts +189 -0
  51. package/dist/experience/types.d.ts.map +1 -0
  52. package/dist/experience/types.js +7 -0
  53. package/dist/experience/types.js.map +1 -0
  54. package/dist/index.d.ts +3 -1
  55. package/dist/index.d.ts.map +1 -1
  56. package/dist/index.js +3 -1
  57. package/dist/index.js.map +1 -1
  58. package/dist/task/task-manager.d.ts +7 -0
  59. package/dist/task/task-manager.d.ts.map +1 -1
  60. package/dist/task/task-manager.js +50 -1
  61. package/dist/task/task-manager.js.map +1 -1
  62. package/dist/types/task.d.ts +2 -0
  63. package/dist/types/task.d.ts.map +1 -1
  64. package/package.json +1 -1
@@ -0,0 +1,126 @@
1
+ /**
2
+ * 虾片 Hub 客户端
3
+ *
4
+ * 与智工坊服务端 /api/experience/* 交互
5
+ */
6
+ import { createLogger } from '../core/logger.js';
7
+ export class ShrimpHubClient {
8
+ logger;
9
+ endpoint;
10
+ botId;
11
+ token;
12
+ constructor(endpoint, botId, token) {
13
+ this.logger = createLogger('ShrimpHub');
14
+ this.endpoint = endpoint.replace(/\/$/, '');
15
+ this.botId = botId;
16
+ this.token = token;
17
+ }
18
+ /**
19
+ * 发布基因到 Hub
20
+ */
21
+ async publishGene(gene, capsule) {
22
+ const url = `${this.endpoint}/api/experience/genes`;
23
+ try {
24
+ const response = await this.request(url, 'POST', {
25
+ gene,
26
+ capsule,
27
+ });
28
+ if (response.ok) {
29
+ this.logger.info(`基因已发布到 Hub [${gene.gene_id.slice(0, 12)}...]`);
30
+ return true;
31
+ }
32
+ else {
33
+ this.logger.warn(`基因发布失败`, { httpStatus: response.status });
34
+ return false;
35
+ }
36
+ }
37
+ catch (err) {
38
+ this.logger.warn(`基因发布异常`, { error: err.message });
39
+ return false;
40
+ }
41
+ }
42
+ /**
43
+ * 按信号搜索 Hub 基因
44
+ */
45
+ async searchGenes(signals, limit = 5) {
46
+ const url = `${this.endpoint}/api/experience/genes/search`;
47
+ try {
48
+ const params = new URLSearchParams({
49
+ signals: signals.join(','),
50
+ limit: String(limit),
51
+ });
52
+ const response = await fetch(`${url}?${params}`, {
53
+ headers: this.getHeaders(),
54
+ });
55
+ if (response.ok) {
56
+ const data = await response.json();
57
+ this.logger.debug(`Hub 搜索返回 ${data.results.length} 条结果`);
58
+ return data;
59
+ }
60
+ else {
61
+ this.logger.warn(`Hub 搜索失败`, { httpStatus: response.status });
62
+ return null;
63
+ }
64
+ }
65
+ catch (err) {
66
+ this.logger.warn(`Hub 搜索异常`, { error: err.message });
67
+ return null;
68
+ }
69
+ }
70
+ /**
71
+ * 提交验证报告
72
+ */
73
+ async submitReport(report) {
74
+ const url = `${this.endpoint}/api/experience/report`;
75
+ try {
76
+ const response = await this.request(url, 'POST', report);
77
+ if (response.ok) {
78
+ this.logger.debug(`验证报告已提交`);
79
+ return true;
80
+ }
81
+ else {
82
+ this.logger.warn(`验证报告提交失败`, { httpStatus: response.status });
83
+ return false;
84
+ }
85
+ }
86
+ catch (err) {
87
+ this.logger.warn(`验证报告提交异常`, { error: err.message });
88
+ return false;
89
+ }
90
+ }
91
+ /**
92
+ * 测试 Hub 连接
93
+ */
94
+ async testConnection() {
95
+ try {
96
+ const url = `${this.endpoint}/api/experience/stats`;
97
+ const response = await fetch(url, {
98
+ headers: this.getHeaders(),
99
+ signal: AbortSignal.timeout(5000),
100
+ });
101
+ return response.ok;
102
+ }
103
+ catch {
104
+ return false;
105
+ }
106
+ }
107
+ // ==================== 内部方法 ====================
108
+ async request(url, method, body) {
109
+ return fetch(url, {
110
+ method,
111
+ headers: {
112
+ ...this.getHeaders(),
113
+ 'Content-Type': 'application/json',
114
+ },
115
+ body: JSON.stringify(body),
116
+ signal: AbortSignal.timeout(10000),
117
+ });
118
+ }
119
+ getHeaders() {
120
+ return {
121
+ 'Authorization': `Bearer ${this.token}`,
122
+ 'X-Bot-Id': this.botId,
123
+ };
124
+ }
125
+ }
126
+ //# sourceMappingURL=hub-client.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hub-client.js","sourceRoot":"","sources":["../../src/experience/hub-client.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,13 @@
1
+ /**
2
+ * 经验基因系统 - 统一导出
3
+ */
4
+ export type { GeneCategory, StrategyStep, ShrimpGene, ShrimpCapsule, ShrimpEvolution, GeneGDIScore, ExperienceSearchResult, ExperienceConfig, HubPublishGeneRequest, HubSearchRequest, HubSearchResponse, HubReportRequest, ExperienceGainedData, ExperienceAppliedData, } from './types.js';
5
+ export { LocalExperienceStore, type LocalStoreStats } from './local-store.js';
6
+ export { SignalDetector, type DetectedSignal } from './signal-detector.js';
7
+ export { ExperienceSearchEngine } from './search-engine.js';
8
+ export { ExperienceEncapsulator, type EvolutionProcess } from './encapsulator.js';
9
+ export { ShrimpHubClient } from './hub-client.js';
10
+ export { ExperienceManager } from './manager.js';
11
+ import type { ExperienceConfig } from './types.js';
12
+ export declare const DEFAULT_EXPERIENCE_CONFIG: ExperienceConfig;
13
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/experience/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAGH,YAAY,EACV,YAAY,EAAE,YAAY,EAC1B,UAAU,EAAE,aAAa,EAAE,eAAe,EAC1C,YAAY,EAAE,sBAAsB,EACpC,gBAAgB,EAChB,qBAAqB,EAAE,gBAAgB,EAAE,iBAAiB,EAAE,gBAAgB,EAC5E,oBAAoB,EAAE,qBAAqB,GAC5C,MAAM,YAAY,CAAC;AAGpB,OAAO,EAAE,oBAAoB,EAAE,KAAK,eAAe,EAAE,MAAM,kBAAkB,CAAC;AAC9E,OAAO,EAAE,cAAc,EAAE,KAAK,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAC3E,OAAO,EAAE,sBAAsB,EAAE,MAAM,oBAAoB,CAAC;AAC5D,OAAO,EAAE,sBAAsB,EAAE,KAAK,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AAClF,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAClD,OAAO,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAC;AAGjD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAInD,eAAO,MAAM,yBAAyB,EAAE,gBAgBvC,CAAC"}
@@ -0,0 +1,30 @@
1
+ /**
2
+ * 经验基因系统 - 统一导出
3
+ */
4
+ // 模块
5
+ export { LocalExperienceStore } from './local-store.js';
6
+ export { SignalDetector } from './signal-detector.js';
7
+ export { ExperienceSearchEngine } from './search-engine.js';
8
+ export { ExperienceEncapsulator } from './encapsulator.js';
9
+ export { ShrimpHubClient } from './hub-client.js';
10
+ export { ExperienceManager } from './manager.js';
11
+ import { join } from 'node:path';
12
+ import { homedir } from 'node:os';
13
+ export const DEFAULT_EXPERIENCE_CONFIG = {
14
+ enabled: true,
15
+ storagePath: join(homedir(), '.workerclaw', 'experience'),
16
+ autoSearch: {
17
+ enabled: true,
18
+ minConfidence: 0.3,
19
+ },
20
+ autoEncapsulate: {
21
+ enabled: true,
22
+ minSteps: 1,
23
+ },
24
+ hub: {
25
+ enabled: false,
26
+ syncIntervalMs: 30 * 60 * 1000,
27
+ endpoint: 'https://www.miniabc.top',
28
+ },
29
+ };
30
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/experience/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAYH,KAAK;AACL,OAAO,EAAE,oBAAoB,EAAwB,MAAM,kBAAkB,CAAC;AAC9E,OAAO,EAAE,cAAc,EAAuB,MAAM,sBAAsB,CAAC;AAC3E,OAAO,EAAE,sBAAsB,EAAE,MAAM,oBAAoB,CAAC;AAC5D,OAAO,EAAE,sBAAsB,EAAyB,MAAM,mBAAmB,CAAC;AAClF,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAClD,OAAO,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAC;AAIjD,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAElC,MAAM,CAAC,MAAM,yBAAyB,GAAqB;IACzD,OAAO,EAAE,IAAI;IACb,WAAW,EAAE,IAAI,CAAC,OAAO,EAAE,EAAE,aAAa,EAAE,YAAY,CAAC;IACzD,UAAU,EAAE;QACV,OAAO,EAAE,IAAI;QACb,aAAa,EAAE,GAAG;KACnB;IACD,eAAe,EAAE;QACf,OAAO,EAAE,IAAI;QACb,QAAQ,EAAE,CAAC;KACZ;IACD,GAAG,EAAE;QACH,OAAO,EAAE,KAAK;QACd,cAAc,EAAE,EAAE,GAAG,EAAE,GAAG,IAAI;QAC9B,QAAQ,EAAE,yBAAyB;KACpC;CACF,CAAC"}
@@ -0,0 +1,102 @@
1
+ /**
2
+ * 本地经验池存储
3
+ *
4
+ * 基于 JSON 文件的轻量存储方案
5
+ * 存储 genes + capsules + events + reports
6
+ */
7
+ import type { ShrimpGene, ShrimpCapsule, ShrimpEvolution, GeneCategory, ExperienceSearchResult, HubReportRequest } from './types.js';
8
+ export interface LocalStoreStats {
9
+ genes: number;
10
+ capsules: number;
11
+ events: number;
12
+ categories: Record<GeneCategory, number>;
13
+ }
14
+ export declare class LocalExperienceStore {
15
+ private logger;
16
+ private storePath;
17
+ private genes;
18
+ private capsules;
19
+ private events;
20
+ private reports;
21
+ private initialized;
22
+ constructor(storagePath: string);
23
+ /**
24
+ * 初始化存储(加载已有数据)
25
+ */
26
+ init(): Promise<void>;
27
+ /**
28
+ * 保存基因
29
+ */
30
+ saveGene(gene: ShrimpGene): Promise<void>;
31
+ /**
32
+ * 获取基因
33
+ */
34
+ getGene(geneId: string): ShrimpGene | undefined;
35
+ /**
36
+ * 获取所有基因
37
+ */
38
+ getAllGenes(): ShrimpGene[];
39
+ /**
40
+ * 按分类获取基因
41
+ */
42
+ getGenesByCategory(category: GeneCategory): ShrimpGene[];
43
+ /**
44
+ * 删除基因(同时删除关联的胶囊)
45
+ */
46
+ deleteGene(geneId: string): Promise<boolean>;
47
+ /**
48
+ * 保存胶囊
49
+ */
50
+ saveCapsule(capsule: ShrimpCapsule): Promise<void>;
51
+ /**
52
+ * 获取胶囊
53
+ */
54
+ getCapsule(capsuleId: string): ShrimpCapsule | undefined;
55
+ /**
56
+ * 获取基因关联的胶囊列表
57
+ */
58
+ getCapsulesByGene(geneId: string): ShrimpCapsule[];
59
+ /**
60
+ * 获取最佳胶囊(按置信度排序)
61
+ */
62
+ getBestCapsule(geneId: string): ShrimpCapsule | undefined;
63
+ /**
64
+ * 记录进化事件
65
+ */
66
+ recordEvent(event: ShrimpEvolution): Promise<void>;
67
+ /**
68
+ * 获取最近的进化事件
69
+ */
70
+ getRecentEvents(limit?: number): ShrimpEvolution[];
71
+ /**
72
+ * 记录验证报告(待同步到 Hub)
73
+ */
74
+ addReport(report: HubReportRequest): Promise<void>;
75
+ /**
76
+ * 获取待同步的报告
77
+ */
78
+ getPendingReports(): HubReportRequest[];
79
+ /**
80
+ * 清除已同步的报告
81
+ */
82
+ clearReports(): Promise<void>;
83
+ /**
84
+ * 按信号搜索(关键词匹配)
85
+ */
86
+ searchBySignals(signals: string[]): ExperienceSearchResult[];
87
+ /**
88
+ * 计算基因与信号的匹配度
89
+ */
90
+ private computeMatchScore;
91
+ getStats(): LocalStoreStats;
92
+ private get filePaths();
93
+ private loadGenes;
94
+ private loadCapsules;
95
+ private loadEvents;
96
+ private loadReports;
97
+ private persistGenes;
98
+ private persistCapsules;
99
+ private persistEvents;
100
+ private persistReports;
101
+ }
102
+ //# sourceMappingURL=local-store.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"local-store.d.ts","sourceRoot":"","sources":["../../src/experience/local-store.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAKH,OAAO,KAAK,EACV,UAAU,EAAE,aAAa,EAAE,eAAe,EAAE,YAAY,EACxD,sBAAsB,EAAE,gBAAgB,EACzC,MAAM,YAAY,CAAC;AAIpB,MAAM,WAAW,eAAe;IAC9B,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,MAAM,CAAC;IACjB,MAAM,EAAE,MAAM,CAAC;IACf,UAAU,EAAE,MAAM,CAAC,YAAY,EAAE,MAAM,CAAC,CAAC;CAC1C;AAID,qBAAa,oBAAoB;IAC/B,OAAO,CAAC,MAAM,CAAS;IACvB,OAAO,CAAC,SAAS,CAAS;IAC1B,OAAO,CAAC,KAAK,CAAsC;IACnD,OAAO,CAAC,QAAQ,CAAyC;IACzD,OAAO,CAAC,MAAM,CAAyB;IACvC,OAAO,CAAC,OAAO,CAA0B;IACzC,OAAO,CAAC,WAAW,CAAS;gBAEhB,WAAW,EAAE,MAAM;IAO/B;;OAEG;IACG,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;IA8B3B;;OAEG;IACG,QAAQ,CAAC,IAAI,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC;IAS/C;;OAEG;IACH,OAAO,CAAC,MAAM,EAAE,MAAM,GAAG,UAAU,GAAG,SAAS;IAI/C;;OAEG;IACH,WAAW,IAAI,UAAU,EAAE;IAI3B;;OAEG;IACH,kBAAkB,CAAC,QAAQ,EAAE,YAAY,GAAG,UAAU,EAAE;IAIxD;;OAEG;IACG,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAkBlD;;OAEG;IACG,WAAW,CAAC,OAAO,EAAE,aAAa,GAAG,OAAO,CAAC,IAAI,CAAC;IAYxD;;OAEG;IACH,UAAU,CAAC,SAAS,EAAE,MAAM,GAAG,aAAa,GAAG,SAAS;IAIxD;;OAEG;IACH,iBAAiB,CAAC,MAAM,EAAE,MAAM,GAAG,aAAa,EAAE;IAIlD;;OAEG;IACH,cAAc,CAAC,MAAM,EAAE,MAAM,GAAG,aAAa,GAAG,SAAS;IAQzD;;OAEG;IACG,WAAW,CAAC,KAAK,EAAE,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC;IASxD;;OAEG;IACH,eAAe,CAAC,KAAK,SAAK,GAAG,eAAe,EAAE;IAM9C;;OAEG;IACG,SAAS,CAAC,MAAM,EAAE,gBAAgB,GAAG,OAAO,CAAC,IAAI,CAAC;IAKxD;;OAEG;IACH,iBAAiB,IAAI,gBAAgB,EAAE;IAIvC;;OAEG;IACG,YAAY,IAAI,OAAO,CAAC,IAAI,CAAC;IAOnC;;OAEG;IACH,eAAe,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,sBAAsB,EAAE;IAyB5D;;OAEG;IACH,OAAO,CAAC,iBAAiB;IAoBzB,QAAQ,IAAI,eAAe;IAmB3B,OAAO,KAAK,SAAS,GAOpB;YAEa,SAAS;YAgBT,YAAY;YAgBZ,UAAU;YAcV,WAAW;YAcX,YAAY;YAMZ,eAAe;YAMf,aAAa;YAKb,cAAc;CAI7B"}
@@ -0,0 +1,321 @@
1
+ /**
2
+ * 本地经验池存储
3
+ *
4
+ * 基于 JSON 文件的轻量存储方案
5
+ * 存储 genes + capsules + events + reports
6
+ */
7
+ import { existsSync, mkdirSync, readFileSync, writeFileSync } from 'node:fs';
8
+ import { join } from 'node:path';
9
+ import { createLogger } from '../core/logger.js';
10
+ // ==================== 本地经验池 ====================
11
+ export class LocalExperienceStore {
12
+ logger;
13
+ storePath;
14
+ genes = new Map();
15
+ capsules = new Map();
16
+ events = [];
17
+ reports = [];
18
+ initialized = false;
19
+ constructor(storagePath) {
20
+ this.logger = createLogger('ExperienceStore');
21
+ this.storePath = storagePath;
22
+ }
23
+ // ==================== 初始化 ====================
24
+ /**
25
+ * 初始化存储(加载已有数据)
26
+ */
27
+ async init() {
28
+ if (this.initialized)
29
+ return;
30
+ try {
31
+ // 确保目录存在
32
+ if (!existsSync(this.storePath)) {
33
+ mkdirSync(this.storePath, { recursive: true });
34
+ }
35
+ // 加载数据
36
+ await this.loadGenes();
37
+ await this.loadCapsules();
38
+ await this.loadEvents();
39
+ await this.loadReports();
40
+ this.initialized = true;
41
+ this.logger.info(`本地经验池已加载`, {
42
+ genes: this.genes.size,
43
+ capsules: this.capsules.size,
44
+ events: this.events.length,
45
+ });
46
+ }
47
+ catch (err) {
48
+ this.logger.error('本地经验池初始化失败', { error: err.message });
49
+ // 失败不阻塞启动,使用空经验池
50
+ this.initialized = true;
51
+ }
52
+ }
53
+ // ==================== 基因操作 ====================
54
+ /**
55
+ * 保存基因
56
+ */
57
+ async saveGene(gene) {
58
+ this.genes.set(gene.gene_id, gene);
59
+ await this.persistGenes();
60
+ this.logger.debug(`基因已保存 [${gene.gene_id.slice(0, 12)}...]`, {
61
+ category: gene.category,
62
+ signals: gene.signals.length,
63
+ });
64
+ }
65
+ /**
66
+ * 获取基因
67
+ */
68
+ getGene(geneId) {
69
+ return this.genes.get(geneId);
70
+ }
71
+ /**
72
+ * 获取所有基因
73
+ */
74
+ getAllGenes() {
75
+ return Array.from(this.genes.values());
76
+ }
77
+ /**
78
+ * 按分类获取基因
79
+ */
80
+ getGenesByCategory(category) {
81
+ return Array.from(this.genes.values()).filter(g => g.category === category);
82
+ }
83
+ /**
84
+ * 删除基因(同时删除关联的胶囊)
85
+ */
86
+ async deleteGene(geneId) {
87
+ const gene = this.genes.get(geneId);
88
+ if (!gene)
89
+ return false;
90
+ // 删除关联胶囊
91
+ for (const [capId, cap] of this.capsules) {
92
+ if (cap.gene_id === geneId) {
93
+ this.capsules.delete(capId);
94
+ }
95
+ }
96
+ this.genes.delete(geneId);
97
+ await Promise.all([this.persistGenes(), this.persistCapsules()]);
98
+ return true;
99
+ }
100
+ // ==================== 胶囊操作 ====================
101
+ /**
102
+ * 保存胶囊
103
+ */
104
+ async saveCapsule(capsule) {
105
+ this.capsules.set(capsule.capsule_id, capsule);
106
+ // 同时确保关联的基因存在
107
+ if (!this.genes.has(capsule.gene_id) && capsule.context) {
108
+ // 胶囊可以独立存在(基因可能来自 Hub)
109
+ }
110
+ await this.persistCapsules();
111
+ this.logger.debug(`胶囊已保存 [${capsule.capsule_id.slice(0, 12)}...]`);
112
+ }
113
+ /**
114
+ * 获取胶囊
115
+ */
116
+ getCapsule(capsuleId) {
117
+ return this.capsules.get(capsuleId);
118
+ }
119
+ /**
120
+ * 获取基因关联的胶囊列表
121
+ */
122
+ getCapsulesByGene(geneId) {
123
+ return Array.from(this.capsules.values()).filter(c => c.gene_id === geneId);
124
+ }
125
+ /**
126
+ * 获取最佳胶囊(按置信度排序)
127
+ */
128
+ getBestCapsule(geneId) {
129
+ const capsules = this.getCapsulesByGene(geneId);
130
+ if (capsules.length === 0)
131
+ return undefined;
132
+ return capsules.sort((a, b) => b.confidence - a.confidence)[0];
133
+ }
134
+ // ==================== 事件操作 ====================
135
+ /**
136
+ * 记录进化事件
137
+ */
138
+ async recordEvent(event) {
139
+ this.events.push(event);
140
+ await this.persistEvents();
141
+ this.logger.debug(`进化事件已记录`, {
142
+ intent: event.intent,
143
+ status: event.outcome.status,
144
+ });
145
+ }
146
+ /**
147
+ * 获取最近的进化事件
148
+ */
149
+ getRecentEvents(limit = 20) {
150
+ return this.events.slice(-limit).reverse();
151
+ }
152
+ // ==================== 报告操作 ====================
153
+ /**
154
+ * 记录验证报告(待同步到 Hub)
155
+ */
156
+ async addReport(report) {
157
+ this.reports.push(report);
158
+ await this.persistReports();
159
+ }
160
+ /**
161
+ * 获取待同步的报告
162
+ */
163
+ getPendingReports() {
164
+ return [...this.reports];
165
+ }
166
+ /**
167
+ * 清除已同步的报告
168
+ */
169
+ async clearReports() {
170
+ this.reports = [];
171
+ await this.persistReports();
172
+ }
173
+ // ==================== 搜索 ====================
174
+ /**
175
+ * 按信号搜索(关键词匹配)
176
+ */
177
+ searchBySignals(signals) {
178
+ const results = [];
179
+ const normalizedSignals = signals.map(s => s.toLowerCase());
180
+ for (const gene of this.genes.values()) {
181
+ // 计算匹配度
182
+ const matchScore = this.computeMatchScore(gene, normalizedSignals);
183
+ if (matchScore < 0.2)
184
+ continue; // 最低匹配阈值
185
+ // 获取最佳胶囊
186
+ const capsule = this.getBestCapsule(gene.gene_id);
187
+ if (!capsule)
188
+ continue;
189
+ results.push({
190
+ gene,
191
+ capsule,
192
+ matchScore,
193
+ source: 'local',
194
+ });
195
+ }
196
+ // 按匹配度排序
197
+ return results.sort((a, b) => b.matchScore - a.matchScore);
198
+ }
199
+ /**
200
+ * 计算基因与信号的匹配度
201
+ */
202
+ computeMatchScore(gene, normalizedSignals) {
203
+ let matched = 0;
204
+ let total = gene.signals.length;
205
+ for (const geneSignal of gene.signals) {
206
+ const normalizedGene = geneSignal.toLowerCase();
207
+ for (const querySignal of normalizedSignals) {
208
+ if (normalizedGene.includes(querySignal) || querySignal.includes(normalizedGene)) {
209
+ matched++;
210
+ break;
211
+ }
212
+ }
213
+ }
214
+ if (total === 0)
215
+ return 0;
216
+ return matched / total;
217
+ }
218
+ // ==================== 统计 ====================
219
+ getStats() {
220
+ const categories = {
221
+ task_fix: 0, env_fix: 0, api_compat: 0, performance: 0, security: 0,
222
+ };
223
+ for (const gene of this.genes.values()) {
224
+ categories[gene.category]++;
225
+ }
226
+ return {
227
+ genes: this.genes.size,
228
+ capsules: this.capsules.size,
229
+ events: this.events.length,
230
+ categories,
231
+ };
232
+ }
233
+ // ==================== 持久化 ====================
234
+ get filePaths() {
235
+ return {
236
+ genes: join(this.storePath, 'genes.json'),
237
+ capsules: join(this.storePath, 'capsules.json'),
238
+ events: join(this.storePath, 'events.json'),
239
+ reports: join(this.storePath, 'reports.json'),
240
+ };
241
+ }
242
+ async loadGenes() {
243
+ const { genes: filePath } = this.filePaths;
244
+ if (!existsSync(filePath))
245
+ return;
246
+ try {
247
+ const data = JSON.parse(readFileSync(filePath, 'utf-8'));
248
+ if (Array.isArray(data)) {
249
+ for (const gene of data) {
250
+ this.genes.set(gene.gene_id, gene);
251
+ }
252
+ }
253
+ }
254
+ catch (err) {
255
+ this.logger.warn('基因数据加载失败,将使用空经验池', { error: err.message });
256
+ }
257
+ }
258
+ async loadCapsules() {
259
+ const { capsules: filePath } = this.filePaths;
260
+ if (!existsSync(filePath))
261
+ return;
262
+ try {
263
+ const data = JSON.parse(readFileSync(filePath, 'utf-8'));
264
+ if (Array.isArray(data)) {
265
+ for (const cap of data) {
266
+ this.capsules.set(cap.capsule_id, cap);
267
+ }
268
+ }
269
+ }
270
+ catch (err) {
271
+ this.logger.warn('胶囊数据加载失败', { error: err.message });
272
+ }
273
+ }
274
+ async loadEvents() {
275
+ const { events: filePath } = this.filePaths;
276
+ if (!existsSync(filePath))
277
+ return;
278
+ try {
279
+ const data = JSON.parse(readFileSync(filePath, 'utf-8'));
280
+ if (Array.isArray(data)) {
281
+ this.events = data;
282
+ }
283
+ }
284
+ catch (err) {
285
+ this.logger.warn('进化事件数据加载失败', { error: err.message });
286
+ }
287
+ }
288
+ async loadReports() {
289
+ const { reports: filePath } = this.filePaths;
290
+ if (!existsSync(filePath))
291
+ return;
292
+ try {
293
+ const data = JSON.parse(readFileSync(filePath, 'utf-8'));
294
+ if (Array.isArray(data)) {
295
+ this.reports = data;
296
+ }
297
+ }
298
+ catch (err) {
299
+ this.logger.warn('报告数据加载失败', { error: err.message });
300
+ }
301
+ }
302
+ async persistGenes() {
303
+ const { genes: filePath } = this.filePaths;
304
+ const data = Array.from(this.genes.values());
305
+ writeFileSync(filePath, JSON.stringify(data, null, 2), 'utf-8');
306
+ }
307
+ async persistCapsules() {
308
+ const { capsules: filePath } = this.filePaths;
309
+ const data = Array.from(this.capsules.values());
310
+ writeFileSync(filePath, JSON.stringify(data, null, 2), 'utf-8');
311
+ }
312
+ async persistEvents() {
313
+ const { events: filePath } = this.filePaths;
314
+ writeFileSync(filePath, JSON.stringify(this.events, null, 2), 'utf-8');
315
+ }
316
+ async persistReports() {
317
+ const { reports: filePath } = this.filePaths;
318
+ writeFileSync(filePath, JSON.stringify(this.reports, null, 2), 'utf-8');
319
+ }
320
+ }
321
+ //# sourceMappingURL=local-store.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"local-store.js","sourceRoot":"","sources":["../../src/experience/local-store.ts"],"names":[],"mappings":"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"}