@zhin.js/agent 0.0.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 (142) hide show
  1. package/LICENSE +21 -0
  2. package/lib/agent.d.ts +130 -0
  3. package/lib/agent.d.ts.map +1 -0
  4. package/lib/agent.js +702 -0
  5. package/lib/agent.js.map +1 -0
  6. package/lib/bootstrap.d.ts +91 -0
  7. package/lib/bootstrap.d.ts.map +1 -0
  8. package/lib/bootstrap.js +243 -0
  9. package/lib/bootstrap.js.map +1 -0
  10. package/lib/builtin-tools.d.ts +59 -0
  11. package/lib/builtin-tools.d.ts.map +1 -0
  12. package/lib/builtin-tools.js +777 -0
  13. package/lib/builtin-tools.js.map +1 -0
  14. package/lib/compaction.d.ts +132 -0
  15. package/lib/compaction.d.ts.map +1 -0
  16. package/lib/compaction.js +370 -0
  17. package/lib/compaction.js.map +1 -0
  18. package/lib/context-manager.d.ts +213 -0
  19. package/lib/context-manager.d.ts.map +1 -0
  20. package/lib/context-manager.js +313 -0
  21. package/lib/context-manager.js.map +1 -0
  22. package/lib/conversation-memory.d.ts +181 -0
  23. package/lib/conversation-memory.d.ts.map +1 -0
  24. package/lib/conversation-memory.js +581 -0
  25. package/lib/conversation-memory.js.map +1 -0
  26. package/lib/cron-engine.d.ts +91 -0
  27. package/lib/cron-engine.d.ts.map +1 -0
  28. package/lib/cron-engine.js +277 -0
  29. package/lib/cron-engine.js.map +1 -0
  30. package/lib/follow-up.d.ts +131 -0
  31. package/lib/follow-up.d.ts.map +1 -0
  32. package/lib/follow-up.js +265 -0
  33. package/lib/follow-up.js.map +1 -0
  34. package/lib/hooks.d.ts +143 -0
  35. package/lib/hooks.d.ts.map +1 -0
  36. package/lib/hooks.js +108 -0
  37. package/lib/hooks.js.map +1 -0
  38. package/lib/index.d.ts +43 -0
  39. package/lib/index.d.ts.map +1 -0
  40. package/lib/index.js +28 -0
  41. package/lib/index.js.map +1 -0
  42. package/lib/init.d.ts +30 -0
  43. package/lib/init.d.ts.map +1 -0
  44. package/lib/init.js +684 -0
  45. package/lib/init.js.map +1 -0
  46. package/lib/output.d.ts +93 -0
  47. package/lib/output.d.ts.map +1 -0
  48. package/lib/output.js +176 -0
  49. package/lib/output.js.map +1 -0
  50. package/lib/rate-limiter.d.ts +38 -0
  51. package/lib/rate-limiter.d.ts.map +1 -0
  52. package/lib/rate-limiter.js +86 -0
  53. package/lib/rate-limiter.js.map +1 -0
  54. package/lib/service.d.ts +86 -0
  55. package/lib/service.d.ts.map +1 -0
  56. package/lib/service.js +285 -0
  57. package/lib/service.js.map +1 -0
  58. package/lib/session.d.ts +186 -0
  59. package/lib/session.d.ts.map +1 -0
  60. package/lib/session.js +443 -0
  61. package/lib/session.js.map +1 -0
  62. package/lib/subagent.d.ts +50 -0
  63. package/lib/subagent.d.ts.map +1 -0
  64. package/lib/subagent.js +144 -0
  65. package/lib/subagent.js.map +1 -0
  66. package/lib/tone-detector.d.ts +19 -0
  67. package/lib/tone-detector.d.ts.map +1 -0
  68. package/lib/tone-detector.js +72 -0
  69. package/lib/tone-detector.js.map +1 -0
  70. package/lib/tools.d.ts +45 -0
  71. package/lib/tools.d.ts.map +1 -0
  72. package/lib/tools.js +206 -0
  73. package/lib/tools.js.map +1 -0
  74. package/lib/user-profile.d.ts +56 -0
  75. package/lib/user-profile.d.ts.map +1 -0
  76. package/lib/user-profile.js +130 -0
  77. package/lib/user-profile.js.map +1 -0
  78. package/lib/zhin-agent/builtin-tools.d.ts +17 -0
  79. package/lib/zhin-agent/builtin-tools.d.ts.map +1 -0
  80. package/lib/zhin-agent/builtin-tools.js +220 -0
  81. package/lib/zhin-agent/builtin-tools.js.map +1 -0
  82. package/lib/zhin-agent/config.d.ts +54 -0
  83. package/lib/zhin-agent/config.d.ts.map +1 -0
  84. package/lib/zhin-agent/config.js +76 -0
  85. package/lib/zhin-agent/config.js.map +1 -0
  86. package/lib/zhin-agent/exec-policy.d.ts +20 -0
  87. package/lib/zhin-agent/exec-policy.d.ts.map +1 -0
  88. package/lib/zhin-agent/exec-policy.js +71 -0
  89. package/lib/zhin-agent/exec-policy.js.map +1 -0
  90. package/lib/zhin-agent/index.d.ts +68 -0
  91. package/lib/zhin-agent/index.d.ts.map +1 -0
  92. package/lib/zhin-agent/index.js +404 -0
  93. package/lib/zhin-agent/index.js.map +1 -0
  94. package/lib/zhin-agent/prompt.d.ts +21 -0
  95. package/lib/zhin-agent/prompt.d.ts.map +1 -0
  96. package/lib/zhin-agent/prompt.js +111 -0
  97. package/lib/zhin-agent/prompt.js.map +1 -0
  98. package/lib/zhin-agent/tool-collector.d.ts +21 -0
  99. package/lib/zhin-agent/tool-collector.d.ts.map +1 -0
  100. package/lib/zhin-agent/tool-collector.js +218 -0
  101. package/lib/zhin-agent/tool-collector.js.map +1 -0
  102. package/package.json +37 -0
  103. package/src/agent.ts +831 -0
  104. package/src/bootstrap.ts +309 -0
  105. package/src/builtin-tools.ts +849 -0
  106. package/src/compaction.ts +529 -0
  107. package/src/context-manager.ts +440 -0
  108. package/src/conversation-memory.ts +774 -0
  109. package/src/cron-engine.ts +336 -0
  110. package/src/follow-up.ts +357 -0
  111. package/src/hooks.ts +223 -0
  112. package/src/index.ts +169 -0
  113. package/src/init.ts +750 -0
  114. package/src/output.ts +261 -0
  115. package/src/rate-limiter.ts +129 -0
  116. package/src/service.ts +329 -0
  117. package/src/session.ts +544 -0
  118. package/src/subagent.ts +209 -0
  119. package/src/tone-detector.ts +89 -0
  120. package/src/tools.ts +217 -0
  121. package/src/user-profile.ts +181 -0
  122. package/src/zhin-agent/builtin-tools.ts +247 -0
  123. package/src/zhin-agent/config.ts +113 -0
  124. package/src/zhin-agent/exec-policy.ts +78 -0
  125. package/src/zhin-agent/index.ts +505 -0
  126. package/src/zhin-agent/prompt.ts +131 -0
  127. package/src/zhin-agent/tool-collector.ts +242 -0
  128. package/tests/ai/agent.test.ts +565 -0
  129. package/tests/ai/context-manager.test.ts +413 -0
  130. package/tests/ai/conversation-memory.test.ts +128 -0
  131. package/tests/ai/follow-up.test.ts +175 -0
  132. package/tests/ai/integration.test.ts +582 -0
  133. package/tests/ai/output.test.ts +128 -0
  134. package/tests/ai/rate-limiter.test.ts +108 -0
  135. package/tests/ai/session.test.ts +334 -0
  136. package/tests/ai/setup.ts +250 -0
  137. package/tests/ai/subagent.test.ts +270 -0
  138. package/tests/ai/tone-detector.test.ts +80 -0
  139. package/tests/ai/tools-builtin.test.ts +310 -0
  140. package/tests/ai/user-profile.test.ts +73 -0
  141. package/tests/ai/zhin-agent.test.ts +177 -0
  142. package/tsconfig.json +22 -0
package/lib/session.js ADDED
@@ -0,0 +1,443 @@
1
+ /**
2
+ * @zhin.js/ai - Session Manager
3
+ * 会话管理器,支持上下文记忆和数据库持久化
4
+ *
5
+ * 特性:
6
+ * - 数据库持久化存储(使用 Zhin 的数据库服务)
7
+ * - 内存缓存加速读取
8
+ * - 自动过期清理
9
+ * - 更长的上下文记忆能力
10
+ */
11
+ import { Logger } from '@zhin.js/logger';
12
+ const logger = new Logger(null, 'AI-Session');
13
+ /**
14
+ * 数据库模型定义
15
+ */
16
+ export const AI_SESSION_MODEL = {
17
+ session_id: { type: 'text', nullable: false },
18
+ messages: { type: 'json', default: [] },
19
+ config: { type: 'json', default: {} },
20
+ created_at: { type: 'integer', default: 0 },
21
+ updated_at: { type: 'integer', default: 0 },
22
+ };
23
+ /**
24
+ * 内存会话管理器(回退方案)
25
+ */
26
+ export class MemorySessionManager {
27
+ sessions = new Map();
28
+ config;
29
+ cleanupTimer;
30
+ constructor(config = {}) {
31
+ this.config = {
32
+ maxHistory: config.maxHistory ?? 100,
33
+ expireMs: config.expireMs ?? 24 * 60 * 60 * 1000, // 24 小时
34
+ };
35
+ // 定期清理过期会话
36
+ this.cleanupTimer = setInterval(() => this.cleanup(), 5 * 60 * 1000);
37
+ }
38
+ get(sessionId, config) {
39
+ let session = this.sessions.get(sessionId);
40
+ if (!session) {
41
+ session = {
42
+ id: sessionId,
43
+ config: config || { provider: 'openai' },
44
+ messages: [],
45
+ createdAt: Date.now(),
46
+ updatedAt: Date.now(),
47
+ };
48
+ this.sessions.set(sessionId, session);
49
+ }
50
+ else {
51
+ session.updatedAt = Date.now();
52
+ }
53
+ return session;
54
+ }
55
+ has(sessionId) {
56
+ return this.sessions.has(sessionId);
57
+ }
58
+ addMessage(sessionId, message) {
59
+ const session = this.get(sessionId);
60
+ session.messages.push(message);
61
+ session.updatedAt = Date.now();
62
+ this.trimMessages(session);
63
+ }
64
+ trimMessages(session) {
65
+ const maxHistory = session.config.maxHistory ?? this.config.maxHistory;
66
+ if (session.messages.length > maxHistory) {
67
+ const systemMessages = session.messages.filter((m) => m.role === 'system');
68
+ const otherMessages = session.messages.filter((m) => m.role !== 'system');
69
+ const keepCount = maxHistory - systemMessages.length;
70
+ session.messages = [...systemMessages, ...otherMessages.slice(-keepCount)];
71
+ }
72
+ }
73
+ getMessages(sessionId) {
74
+ return this.sessions.get(sessionId)?.messages || [];
75
+ }
76
+ setSystemPrompt(sessionId, prompt) {
77
+ const session = this.get(sessionId);
78
+ session.messages = session.messages.filter((m) => m.role !== 'system');
79
+ session.messages.unshift({ role: 'system', content: prompt });
80
+ session.updatedAt = Date.now();
81
+ }
82
+ clear(sessionId) {
83
+ return this.sessions.delete(sessionId);
84
+ }
85
+ reset(sessionId) {
86
+ const session = this.sessions.get(sessionId);
87
+ if (session) {
88
+ const systemMessages = session.messages.filter((m) => m.role === 'system');
89
+ session.messages = systemMessages;
90
+ session.updatedAt = Date.now();
91
+ }
92
+ }
93
+ listSessions() {
94
+ return Array.from(this.sessions.keys());
95
+ }
96
+ getStats() {
97
+ const now = Date.now();
98
+ let active = 0;
99
+ let expired = 0;
100
+ for (const session of this.sessions.values()) {
101
+ if (now - session.updatedAt > this.config.expireMs) {
102
+ expired++;
103
+ }
104
+ else {
105
+ active++;
106
+ }
107
+ }
108
+ return { total: this.sessions.size, active, expired };
109
+ }
110
+ cleanup() {
111
+ const now = Date.now();
112
+ let cleaned = 0;
113
+ for (const [id, session] of this.sessions) {
114
+ const expireMs = session.config.expireMs ?? this.config.expireMs;
115
+ if (now - session.updatedAt > expireMs) {
116
+ this.sessions.delete(id);
117
+ cleaned++;
118
+ }
119
+ }
120
+ return cleaned;
121
+ }
122
+ dispose() {
123
+ if (this.cleanupTimer) {
124
+ clearInterval(this.cleanupTimer);
125
+ this.cleanupTimer = undefined;
126
+ }
127
+ this.sessions.clear();
128
+ }
129
+ }
130
+ /**
131
+ * 数据库会话管理器
132
+ * 使用 Zhin 的数据库服务进行持久化存储
133
+ */
134
+ export class DatabaseSessionManager {
135
+ cache = new Map();
136
+ config;
137
+ cleanupTimer;
138
+ saveQueue = new Map();
139
+ saveTimer;
140
+ model; // 数据库模型
141
+ constructor(model, config = {}) {
142
+ this.model = model;
143
+ this.config = {
144
+ maxHistory: config.maxHistory ?? 200, // 数据库支持更长的历史
145
+ expireMs: config.expireMs ?? 7 * 24 * 60 * 60 * 1000, // 7 天过期
146
+ };
147
+ // 定期清理过期会话(每小时)
148
+ this.cleanupTimer = setInterval(() => this.cleanup(), 60 * 60 * 1000);
149
+ }
150
+ /**
151
+ * 从数据库加载会话
152
+ */
153
+ async loadSession(sessionId) {
154
+ try {
155
+ const records = await this.model.select().where({ session_id: sessionId });
156
+ if (records && records.length > 0) {
157
+ const record = records[0];
158
+ // SQLite 中 json 类型存储为 TEXT,读回时需要解析
159
+ const messages = typeof record.messages === 'string'
160
+ ? JSON.parse(record.messages)
161
+ : (record.messages || []);
162
+ const config = typeof record.config === 'string'
163
+ ? JSON.parse(record.config)
164
+ : (record.config || { provider: 'openai' });
165
+ return {
166
+ id: record.session_id,
167
+ config: Array.isArray(config) ? { provider: 'openai' } : config,
168
+ messages: Array.isArray(messages) ? messages : [],
169
+ createdAt: record.created_at,
170
+ updatedAt: record.updated_at,
171
+ };
172
+ }
173
+ }
174
+ catch (error) {
175
+ logger.debug('加载会话失败:', error);
176
+ }
177
+ return null;
178
+ }
179
+ /**
180
+ * 保存会话到数据库(防抖)
181
+ */
182
+ schedulesSave(session) {
183
+ this.saveQueue.set(session.id, session);
184
+ if (!this.saveTimer) {
185
+ this.saveTimer = setTimeout(() => this.flushSaveQueue(), 1000);
186
+ }
187
+ }
188
+ /**
189
+ * 批量保存队列中的会话
190
+ */
191
+ async flushSaveQueue() {
192
+ this.saveTimer = undefined;
193
+ const sessions = Array.from(this.saveQueue.values());
194
+ this.saveQueue.clear();
195
+ for (const session of sessions) {
196
+ try {
197
+ const existing = await this.model.select().where({ session_id: session.id });
198
+ const record = {
199
+ session_id: session.id,
200
+ messages: session.messages,
201
+ config: session.config,
202
+ updated_at: session.updatedAt,
203
+ };
204
+ if (existing && existing.length > 0) {
205
+ await this.model.update(record).where({ session_id: session.id });
206
+ }
207
+ else {
208
+ record.created_at = session.createdAt;
209
+ await this.model.create(record);
210
+ }
211
+ }
212
+ catch (error) {
213
+ logger.debug(`保存会话 ${session.id} 失败:`, error);
214
+ }
215
+ }
216
+ }
217
+ async get(sessionId, config) {
218
+ // 先检查缓存
219
+ let session = this.cache.get(sessionId);
220
+ if (!session) {
221
+ // 从数据库加载
222
+ session = await this.loadSession(sessionId) ?? undefined;
223
+ if (!session) {
224
+ // 创建新会话
225
+ session = {
226
+ id: sessionId,
227
+ config: config || { provider: 'openai' },
228
+ messages: [],
229
+ createdAt: Date.now(),
230
+ updatedAt: Date.now(),
231
+ };
232
+ }
233
+ this.cache.set(sessionId, session);
234
+ }
235
+ session.updatedAt = Date.now();
236
+ this.schedulesSave(session);
237
+ return session;
238
+ }
239
+ async has(sessionId) {
240
+ if (this.cache.has(sessionId)) {
241
+ return true;
242
+ }
243
+ try {
244
+ const records = await this.model.select().where({ session_id: sessionId });
245
+ return records && records.length > 0;
246
+ }
247
+ catch {
248
+ return false;
249
+ }
250
+ }
251
+ async addMessage(sessionId, message) {
252
+ const session = await this.get(sessionId);
253
+ session.messages.push(message);
254
+ session.updatedAt = Date.now();
255
+ this.trimMessages(session);
256
+ this.schedulesSave(session);
257
+ }
258
+ trimMessages(session) {
259
+ const maxHistory = session.config.maxHistory ?? this.config.maxHistory;
260
+ if (session.messages.length > maxHistory) {
261
+ const systemMessages = session.messages.filter((m) => m.role === 'system');
262
+ const otherMessages = session.messages.filter((m) => m.role !== 'system');
263
+ const keepCount = maxHistory - systemMessages.length;
264
+ session.messages = [...systemMessages, ...otherMessages.slice(-keepCount)];
265
+ }
266
+ }
267
+ async getMessages(sessionId) {
268
+ const session = await this.get(sessionId);
269
+ return session.messages;
270
+ }
271
+ async setSystemPrompt(sessionId, prompt) {
272
+ const session = await this.get(sessionId);
273
+ session.messages = session.messages.filter((m) => m.role !== 'system');
274
+ session.messages.unshift({ role: 'system', content: prompt });
275
+ session.updatedAt = Date.now();
276
+ this.schedulesSave(session);
277
+ }
278
+ async clear(sessionId) {
279
+ this.cache.delete(sessionId);
280
+ this.saveQueue.delete(sessionId);
281
+ try {
282
+ await this.model.delete({ session_id: sessionId });
283
+ return true;
284
+ }
285
+ catch (error) {
286
+ logger.debug(`删除会话 ${sessionId} 失败:`, error);
287
+ return false;
288
+ }
289
+ }
290
+ async reset(sessionId) {
291
+ const session = await this.get(sessionId);
292
+ const systemMessages = session.messages.filter((m) => m.role === 'system');
293
+ session.messages = systemMessages;
294
+ session.updatedAt = Date.now();
295
+ this.schedulesSave(session);
296
+ }
297
+ async listSessions() {
298
+ try {
299
+ const records = await this.model.select();
300
+ return records.map(r => r.session_id);
301
+ }
302
+ catch (error) {
303
+ logger.debug('列出会话失败:', error);
304
+ return Array.from(this.cache.keys());
305
+ }
306
+ }
307
+ async getStats() {
308
+ const now = Date.now();
309
+ let total = 0;
310
+ let active = 0;
311
+ let expired = 0;
312
+ try {
313
+ const records = await this.model.select();
314
+ total = records.length;
315
+ for (const record of records) {
316
+ const expireMs = record.config?.expireMs ?? this.config.expireMs;
317
+ if (now - record.updated_at > expireMs) {
318
+ expired++;
319
+ }
320
+ else {
321
+ active++;
322
+ }
323
+ }
324
+ }
325
+ catch (error) {
326
+ logger.debug('获取统计失败:', error);
327
+ // 回退到缓存统计
328
+ total = this.cache.size;
329
+ for (const session of this.cache.values()) {
330
+ if (now - session.updatedAt > this.config.expireMs) {
331
+ expired++;
332
+ }
333
+ else {
334
+ active++;
335
+ }
336
+ }
337
+ }
338
+ return { total, active, expired };
339
+ }
340
+ async cleanup() {
341
+ const now = Date.now();
342
+ let cleaned = 0;
343
+ try {
344
+ const records = await this.model.select();
345
+ for (const record of records) {
346
+ const expireMs = record.config?.expireMs ?? this.config.expireMs;
347
+ if (now - record.updated_at > expireMs) {
348
+ await this.model.delete({ session_id: record.session_id });
349
+ this.cache.delete(record.session_id);
350
+ cleaned++;
351
+ }
352
+ }
353
+ }
354
+ catch (error) {
355
+ logger.debug('清理会话失败:', error);
356
+ }
357
+ return cleaned;
358
+ }
359
+ async dispose() {
360
+ // 保存所有待保存的会话
361
+ if (this.saveTimer) {
362
+ clearTimeout(this.saveTimer);
363
+ this.saveTimer = undefined;
364
+ }
365
+ await this.flushSaveQueue();
366
+ if (this.cleanupTimer) {
367
+ clearInterval(this.cleanupTimer);
368
+ this.cleanupTimer = undefined;
369
+ }
370
+ this.cache.clear();
371
+ }
372
+ }
373
+ /**
374
+ * 会话管理器包装器
375
+ * 支持同步和异步接口的统一使用
376
+ */
377
+ export class SessionManager {
378
+ manager;
379
+ constructor(manager) {
380
+ this.manager = manager;
381
+ }
382
+ /**
383
+ * 生成会话 ID
384
+ */
385
+ static generateId(platform, userId, channelId) {
386
+ return channelId
387
+ ? `${platform}:${channelId}:${userId}`
388
+ : `${platform}:${userId}`;
389
+ }
390
+ get(sessionId, config) {
391
+ return this.manager.get(sessionId, config);
392
+ }
393
+ has(sessionId) {
394
+ return this.manager.has(sessionId);
395
+ }
396
+ addMessage(sessionId, message) {
397
+ return this.manager.addMessage(sessionId, message);
398
+ }
399
+ getMessages(sessionId) {
400
+ return this.manager.getMessages(sessionId);
401
+ }
402
+ setSystemPrompt(sessionId, prompt) {
403
+ return this.manager.setSystemPrompt(sessionId, prompt);
404
+ }
405
+ clear(sessionId) {
406
+ return this.manager.clear(sessionId);
407
+ }
408
+ reset(sessionId) {
409
+ return this.manager.reset(sessionId);
410
+ }
411
+ listSessions() {
412
+ return this.manager.listSessions();
413
+ }
414
+ getStats() {
415
+ return this.manager.getStats();
416
+ }
417
+ cleanup() {
418
+ return this.manager.cleanup();
419
+ }
420
+ dispose() {
421
+ return this.manager.dispose();
422
+ }
423
+ }
424
+ /**
425
+ * 创建内存会话管理器(回退方案)
426
+ */
427
+ export function createMemorySessionManager(config) {
428
+ return new SessionManager(new MemorySessionManager(config));
429
+ }
430
+ /**
431
+ * 创建数据库会话管理器
432
+ */
433
+ export function createDatabaseSessionManager(model, config) {
434
+ return new SessionManager(new DatabaseSessionManager(model, config));
435
+ }
436
+ /**
437
+ * 创建会话管理器(向后兼容)
438
+ * @deprecated 使用 createMemorySessionManager 或 createDatabaseSessionManager
439
+ */
440
+ export function createSessionManager(config) {
441
+ return createMemorySessionManager(config);
442
+ }
443
+ //# sourceMappingURL=session.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"session.js","sourceRoot":"","sources":["../src/session.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAEH,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAGzC,MAAM,MAAM,GAAG,IAAI,MAAM,CAAC,IAAI,EAAE,YAAY,CAAC,CAAC;AAE9C;;GAEG;AACH,MAAM,CAAC,MAAM,gBAAgB,GAAG;IAC9B,UAAU,EAAE,EAAE,IAAI,EAAE,MAAe,EAAE,QAAQ,EAAE,KAAK,EAAE;IACtD,QAAQ,EAAE,EAAE,IAAI,EAAE,MAAe,EAAE,OAAO,EAAE,EAAE,EAAE;IAChD,MAAM,EAAE,EAAE,IAAI,EAAE,MAAe,EAAE,OAAO,EAAE,EAAE,EAAE;IAC9C,UAAU,EAAE,EAAE,IAAI,EAAE,SAAkB,EAAE,OAAO,EAAE,CAAC,EAAE;IACpD,UAAU,EAAE,EAAE,IAAI,EAAE,SAAkB,EAAE,OAAO,EAAE,CAAC,EAAE;CACrD,CAAC;AA+BF;;GAEG;AACH,MAAM,OAAO,oBAAoB;IACvB,QAAQ,GAAyB,IAAI,GAAG,EAAE,CAAC;IAC3C,MAAM,CAA2D;IACjE,YAAY,CAAkC;IAEtD,YAAY,SAAqD,EAAE;QACjE,IAAI,CAAC,MAAM,GAAG;YACZ,UAAU,EAAE,MAAM,CAAC,UAAU,IAAI,GAAG;YACpC,QAAQ,EAAE,MAAM,CAAC,QAAQ,IAAI,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,EAAE,QAAQ;SAC3D,CAAC;QAEF,WAAW;QACX,IAAI,CAAC,YAAY,GAAG,WAAW,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,CAAC;IACvE,CAAC;IAED,GAAG,CAAC,SAAiB,EAAE,MAAsB;QAC3C,IAAI,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QAE3C,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,OAAO,GAAG;gBACR,EAAE,EAAE,SAAS;gBACb,MAAM,EAAE,MAAM,IAAI,EAAE,QAAQ,EAAE,QAAQ,EAAE;gBACxC,QAAQ,EAAE,EAAE;gBACZ,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;gBACrB,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;aACtB,CAAC;YACF,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;QACxC,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QACjC,CAAC;QAED,OAAO,OAAO,CAAC;IACjB,CAAC;IAED,GAAG,CAAC,SAAiB;QACnB,OAAO,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;IACtC,CAAC;IAED,UAAU,CAAC,SAAiB,EAAE,OAAoB;QAChD,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QACpC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAC/B,OAAO,CAAC,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAC/B,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;IAC7B,CAAC;IAEO,YAAY,CAAC,OAAgB;QACnC,MAAM,UAAU,GAAG,OAAO,CAAC,MAAM,CAAC,UAAU,IAAI,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC;QACvE,IAAI,OAAO,CAAC,QAAQ,CAAC,MAAM,GAAG,UAAU,EAAE,CAAC;YACzC,MAAM,cAAc,GAAG,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAc,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC;YACxF,MAAM,aAAa,GAAG,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAc,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC;YACvF,MAAM,SAAS,GAAG,UAAU,GAAG,cAAc,CAAC,MAAM,CAAC;YACrD,OAAO,CAAC,QAAQ,GAAG,CAAC,GAAG,cAAc,EAAE,GAAG,aAAa,CAAC,KAAK,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;QAC7E,CAAC;IACH,CAAC;IAED,WAAW,CAAC,SAAiB;QAC3B,OAAO,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,QAAQ,IAAI,EAAE,CAAC;IACtD,CAAC;IAED,eAAe,CAAC,SAAiB,EAAE,MAAc;QAC/C,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QACpC,OAAO,CAAC,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAc,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC;QACpF,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,EAAE,CAAC,CAAC;QAC9D,OAAO,CAAC,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;IACjC,CAAC;IAED,KAAK,CAAC,SAAiB;QACrB,OAAO,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;IACzC,CAAC;IAED,KAAK,CAAC,SAAiB;QACrB,MAAM,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QAC7C,IAAI,OAAO,EAAE,CAAC;YACZ,MAAM,cAAc,GAAG,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAc,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC;YACxF,OAAO,CAAC,QAAQ,GAAG,cAAc,CAAC;YAClC,OAAO,CAAC,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QACjC,CAAC;IACH,CAAC;IAED,YAAY;QACV,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC,CAAC;IAC1C,CAAC;IAED,QAAQ;QACN,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QACvB,IAAI,MAAM,GAAG,CAAC,CAAC;QACf,IAAI,OAAO,GAAG,CAAC,CAAC;QAEhB,KAAK,MAAM,OAAO,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,EAAE,CAAC;YAC7C,IAAI,GAAG,GAAG,OAAO,CAAC,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;gBACnD,OAAO,EAAE,CAAC;YACZ,CAAC;iBAAM,CAAC;gBACN,MAAM,EAAE,CAAC;YACX,CAAC;QACH,CAAC;QAED,OAAO,EAAE,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,CAAC;IACxD,CAAC;IAED,OAAO;QACL,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QACvB,IAAI,OAAO,GAAG,CAAC,CAAC;QAEhB,KAAK,MAAM,CAAC,EAAE,EAAE,OAAO,CAAC,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAC1C,MAAM,QAAQ,GAAG,OAAO,CAAC,MAAM,CAAC,QAAQ,IAAI,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC;YACjE,IAAI,GAAG,GAAG,OAAO,CAAC,SAAS,GAAG,QAAQ,EAAE,CAAC;gBACvC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;gBACzB,OAAO,EAAE,CAAC;YACZ,CAAC;QACH,CAAC;QAED,OAAO,OAAO,CAAC;IACjB,CAAC;IAED,OAAO;QACL,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACtB,aAAa,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YACjC,IAAI,CAAC,YAAY,GAAG,SAAS,CAAC;QAChC,CAAC;QACD,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC;IACxB,CAAC;CACF;AAED;;;GAGG;AACH,MAAM,OAAO,sBAAsB;IACzB,KAAK,GAAyB,IAAI,GAAG,EAAE,CAAC;IACxC,MAAM,CAA2D;IACjE,YAAY,CAAkC;IAC9C,SAAS,GAAyB,IAAI,GAAG,EAAE,CAAC;IAC5C,SAAS,CAAiC;IAC1C,KAAK,CAAM,CAAC,QAAQ;IAE5B,YACE,KAAU,EACV,SAAqD,EAAE;QAEvD,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,MAAM,GAAG;YACZ,UAAU,EAAE,MAAM,CAAC,UAAU,IAAI,GAAG,EAAE,aAAa;YACnD,QAAQ,EAAE,MAAM,CAAC,QAAQ,IAAI,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,EAAE,QAAQ;SAC/D,CAAC;QAEF,gBAAgB;QAChB,IAAI,CAAC,YAAY,GAAG,WAAW,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,IAAI,CAAC,CAAC;IACxE,CAAC;IAED;;OAEG;IACK,KAAK,CAAC,WAAW,CAAC,SAAiB;QACzC,IAAI,CAAC;YACH,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,KAAK,CAAC,EAAE,UAAU,EAAE,SAAS,EAAE,CAAC,CAAC;YAC3E,IAAI,OAAO,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBAClC,MAAM,MAAM,GAAG,OAAO,CAAC,CAAC,CAAkB,CAAC;gBAC3C,mCAAmC;gBACnC,MAAM,QAAQ,GAAG,OAAO,MAAM,CAAC,QAAQ,KAAK,QAAQ;oBAClD,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,QAAQ,CAAC;oBAC7B,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,IAAI,EAAE,CAAC,CAAC;gBAC5B,MAAM,MAAM,GAAG,OAAO,MAAM,CAAC,MAAM,KAAK,QAAQ;oBAC9C,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC;oBAC3B,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,IAAI,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC,CAAC;gBAC9C,OAAO;oBACL,EAAE,EAAE,MAAM,CAAC,UAAU;oBACrB,MAAM,EAAE,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC,CAAC,CAAC,MAAM;oBAC/D,QAAQ,EAAE,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE;oBACjD,SAAS,EAAE,MAAM,CAAC,UAAU;oBAC5B,SAAS,EAAE,MAAM,CAAC,UAAU;iBAC7B,CAAC;YACJ,CAAC;QACH,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,CAAC,KAAK,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC;QACjC,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;OAEG;IACK,aAAa,CAAC,OAAgB;QACpC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,EAAE,OAAO,CAAC,CAAC;QAExC,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC;YACpB,IAAI,CAAC,SAAS,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,cAAc,EAAE,EAAE,IAAI,CAAC,CAAC;QACjE,CAAC;IACH,CAAC;IAED;;OAEG;IACK,KAAK,CAAC,cAAc;QAC1B,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAE3B,MAAM,QAAQ,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,CAAC;QACrD,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC;QAEvB,KAAK,MAAM,OAAO,IAAI,QAAQ,EAAE,CAAC;YAC/B,IAAI,CAAC;gBACH,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,KAAK,CAAC,EAAE,UAAU,EAAE,OAAO,CAAC,EAAE,EAAE,CAAC,CAAC;gBAC7E,MAAM,MAAM,GAA2B;oBACrC,UAAU,EAAE,OAAO,CAAC,EAAE;oBACtB,QAAQ,EAAE,OAAO,CAAC,QAAQ;oBAC1B,MAAM,EAAE,OAAO,CAAC,MAAM;oBACtB,UAAU,EAAE,OAAO,CAAC,SAAS;iBAC9B,CAAC;gBAEF,IAAI,QAAQ,IAAI,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;oBACpC,MAAM,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,KAAK,CAAC,EAAE,UAAU,EAAE,OAAO,CAAC,EAAE,EAAE,CAAC,CAAC;gBACpE,CAAC;qBAAM,CAAC;oBACN,MAAM,CAAC,UAAU,GAAG,OAAO,CAAC,SAAS,CAAC;oBACtC,MAAM,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;gBAClC,CAAC;YACH,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACf,MAAM,CAAC,KAAK,CAAC,QAAQ,OAAO,CAAC,EAAE,MAAM,EAAE,KAAK,CAAC,CAAC;YAChD,CAAC;QACH,CAAC;IACH,CAAC;IAED,KAAK,CAAC,GAAG,CAAC,SAAiB,EAAE,MAAsB;QACjD,QAAQ;QACR,IAAI,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QAExC,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,SAAS;YACT,OAAO,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,IAAI,SAAS,CAAC;YAEzD,IAAI,CAAC,OAAO,EAAE,CAAC;gBACb,QAAQ;gBACR,OAAO,GAAG;oBACR,EAAE,EAAE,SAAS;oBACb,MAAM,EAAE,MAAM,IAAI,EAAE,QAAQ,EAAE,QAAQ,EAAE;oBACxC,QAAQ,EAAE,EAAE;oBACZ,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;oBACrB,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;iBACtB,CAAC;YACJ,CAAC;YAED,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;QACrC,CAAC;QAED,OAAO,CAAC,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAC/B,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;QAE5B,OAAO,OAAO,CAAC;IACjB,CAAC;IAED,KAAK,CAAC,GAAG,CAAC,SAAiB;QACzB,IAAI,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,CAAC;YAC9B,OAAO,IAAI,CAAC;QACd,CAAC;QAED,IAAI,CAAC;YACH,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,KAAK,CAAC,EAAE,UAAU,EAAE,SAAS,EAAE,CAAC,CAAC;YAC3E,OAAO,OAAO,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC;QACvC,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;IAED,KAAK,CAAC,UAAU,CAAC,SAAiB,EAAE,OAAoB;QACtD,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QAC1C,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAC/B,OAAO,CAAC,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAC/B,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;QAC3B,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;IAC9B,CAAC;IAEO,YAAY,CAAC,OAAgB;QACnC,MAAM,UAAU,GAAG,OAAO,CAAC,MAAM,CAAC,UAAU,IAAI,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC;QACvE,IAAI,OAAO,CAAC,QAAQ,CAAC,MAAM,GAAG,UAAU,EAAE,CAAC;YACzC,MAAM,cAAc,GAAG,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAc,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC;YACxF,MAAM,aAAa,GAAG,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAc,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC;YACvF,MAAM,SAAS,GAAG,UAAU,GAAG,cAAc,CAAC,MAAM,CAAC;YACrD,OAAO,CAAC,QAAQ,GAAG,CAAC,GAAG,cAAc,EAAE,GAAG,aAAa,CAAC,KAAK,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;QAC7E,CAAC;IACH,CAAC;IAED,KAAK,CAAC,WAAW,CAAC,SAAiB;QACjC,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QAC1C,OAAO,OAAO,CAAC,QAAQ,CAAC;IAC1B,CAAC;IAED,KAAK,CAAC,eAAe,CAAC,SAAiB,EAAE,MAAc;QACrD,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QAC1C,OAAO,CAAC,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAc,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC;QACpF,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,EAAE,CAAC,CAAC;QAC9D,OAAO,CAAC,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAC/B,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;IAC9B,CAAC;IAED,KAAK,CAAC,KAAK,CAAC,SAAiB;QAC3B,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;QAC7B,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;QAEjC,IAAI,CAAC;YACH,MAAM,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,UAAU,EAAE,SAAS,EAAE,CAAC,CAAC;YACnD,OAAO,IAAI,CAAC;QACd,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,CAAC,KAAK,CAAC,QAAQ,SAAS,MAAM,EAAE,KAAK,CAAC,CAAC;YAC7C,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;IAED,KAAK,CAAC,KAAK,CAAC,SAAiB;QAC3B,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QAC1C,MAAM,cAAc,GAAG,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAc,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC;QACxF,OAAO,CAAC,QAAQ,GAAG,cAAc,CAAC;QAClC,OAAO,CAAC,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAC/B,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;IAC9B,CAAC;IAED,KAAK,CAAC,YAAY;QAChB,IAAI,CAAC;YACH,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC;YAC1C,OAAQ,OAA2B,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC;QAC7D,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,CAAC,KAAK,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC;YAC/B,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC,CAAC;QACvC,CAAC;IACH,CAAC;IAED,KAAK,CAAC,QAAQ;QACZ,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QACvB,IAAI,KAAK,GAAG,CAAC,CAAC;QACd,IAAI,MAAM,GAAG,CAAC,CAAC;QACf,IAAI,OAAO,GAAG,CAAC,CAAC;QAEhB,IAAI,CAAC;YACH,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,MAAM,EAAqB,CAAC;YAC7D,KAAK,GAAG,OAAO,CAAC,MAAM,CAAC;YAEvB,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;gBAC7B,MAAM,QAAQ,GAAG,MAAM,CAAC,MAAM,EAAE,QAAQ,IAAI,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC;gBACjE,IAAI,GAAG,GAAG,MAAM,CAAC,UAAU,GAAG,QAAQ,EAAE,CAAC;oBACvC,OAAO,EAAE,CAAC;gBACZ,CAAC;qBAAM,CAAC;oBACN,MAAM,EAAE,CAAC;gBACX,CAAC;YACH,CAAC;QACH,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,CAAC,KAAK,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC;YAC/B,UAAU;YACV,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC;YACxB,KAAK,MAAM,OAAO,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,EAAE,CAAC;gBAC1C,IAAI,GAAG,GAAG,OAAO,CAAC,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;oBACnD,OAAO,EAAE,CAAC;gBACZ,CAAC;qBAAM,CAAC;oBACN,MAAM,EAAE,CAAC;gBACX,CAAC;YACH,CAAC;QACH,CAAC;QAED,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,CAAC;IACpC,CAAC;IAED,KAAK,CAAC,OAAO;QACX,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QACvB,IAAI,OAAO,GAAG,CAAC,CAAC;QAEhB,IAAI,CAAC;YACH,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,MAAM,EAAqB,CAAC;YAE7D,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;gBAC7B,MAAM,QAAQ,GAAG,MAAM,CAAC,MAAM,EAAE,QAAQ,IAAI,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC;gBACjE,IAAI,GAAG,GAAG,MAAM,CAAC,UAAU,GAAG,QAAQ,EAAE,CAAC;oBACvC,MAAM,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,UAAU,EAAE,MAAM,CAAC,UAAU,EAAE,CAAC,CAAC;oBAC3D,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;oBACrC,OAAO,EAAE,CAAC;gBACZ,CAAC;YACH,CAAC;QACH,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,CAAC,KAAK,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC;QACjC,CAAC;QAED,OAAO,OAAO,CAAC;IACjB,CAAC;IAED,KAAK,CAAC,OAAO;QACX,aAAa;QACb,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;YAC7B,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC7B,CAAC;QACD,MAAM,IAAI,CAAC,cAAc,EAAE,CAAC;QAE5B,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACtB,aAAa,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YACjC,IAAI,CAAC,YAAY,GAAG,SAAS,CAAC;QAChC,CAAC;QAED,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC;IACrB,CAAC;CACF;AAED;;;GAGG;AACH,MAAM,OAAO,cAAc;IACjB,OAAO,CAAkB;IAEjC,YAAY,OAAwB;QAClC,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;IACzB,CAAC;IAED;;OAEG;IACH,MAAM,CAAC,UAAU,CAAC,QAAgB,EAAE,MAAc,EAAE,SAAkB;QACpE,OAAO,SAAS;YACd,CAAC,CAAC,GAAG,QAAQ,IAAI,SAAS,IAAI,MAAM,EAAE;YACtC,CAAC,CAAC,GAAG,QAAQ,IAAI,MAAM,EAAE,CAAC;IAC9B,CAAC;IAED,GAAG,CAAC,SAAiB,EAAE,MAAsB;QAC3C,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;IAC7C,CAAC;IAED,GAAG,CAAC,SAAiB;QACnB,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;IACrC,CAAC;IAED,UAAU,CAAC,SAAiB,EAAE,OAAoB;QAChD,OAAO,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;IACrD,CAAC;IAED,WAAW,CAAC,SAAiB;QAC3B,OAAO,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC;IAC7C,CAAC;IAED,eAAe,CAAC,SAAiB,EAAE,MAAc;QAC/C,OAAO,IAAI,CAAC,OAAO,CAAC,eAAe,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;IACzD,CAAC;IAED,KAAK,CAAC,SAAiB;QACrB,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;IACvC,CAAC;IAED,KAAK,CAAC,SAAiB;QACrB,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;IACvC,CAAC;IAED,YAAY;QACV,OAAO,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE,CAAC;IACrC,CAAC;IAED,QAAQ;QACN,OAAO,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;IACjC,CAAC;IAED,OAAO;QACL,OAAO,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;IAChC,CAAC;IAED,OAAO;QACL,OAAO,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;IAChC,CAAC;CACF;AAED;;GAEG;AACH,MAAM,UAAU,0BAA0B,CAAC,MAAmD;IAC5F,OAAO,IAAI,cAAc,CAAC,IAAI,oBAAoB,CAAC,MAAM,CAAC,CAAC,CAAC;AAC9D,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,4BAA4B,CAC1C,KAAU,EACV,MAAmD;IAEnD,OAAO,IAAI,cAAc,CAAC,IAAI,sBAAsB,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC,CAAC;AACvE,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,oBAAoB,CAAC,MAAmD;IACtF,OAAO,0BAA0B,CAAC,MAAM,CAAC,CAAC;AAC5C,CAAC"}
@@ -0,0 +1,50 @@
1
+ /**
2
+ * SubagentManager — 后台子任务执行管理器
3
+ *
4
+ * 职责:
5
+ * 1. 接收主 agent 发起的 spawn 请求,创建后台子 agent
6
+ * 2. 为子 agent 配备受限工具集(文件/Shell/网络,不含消息/spawn/技能)
7
+ * 3. 管理子 agent 生命周期(运行跟踪、完成/失败回告)
8
+ * 4. 完成后将结果投递回主流程,由主 agent 摘要后发送到原始频道
9
+ */
10
+ import type { AIProvider, AgentTool } from '@zhin.js/core';
11
+ import type { ZhinAgentConfig } from './zhin-agent/config.js';
12
+ export interface SubagentOrigin {
13
+ platform: string;
14
+ botId: string;
15
+ sceneId: string;
16
+ senderId: string;
17
+ sceneType: string;
18
+ }
19
+ export interface SpawnOptions {
20
+ task: string;
21
+ label?: string;
22
+ origin: SubagentOrigin;
23
+ }
24
+ export type SubagentResultSender = (origin: SubagentOrigin, content: string) => Promise<void>;
25
+ export interface SubagentManagerOptions {
26
+ provider: AIProvider;
27
+ workspace: string;
28
+ createTools: () => AgentTool[];
29
+ maxIterations?: number;
30
+ /** Exec policy config to enforce on subagent bash tools */
31
+ execPolicyConfig?: Required<ZhinAgentConfig>;
32
+ }
33
+ export declare class SubagentManager {
34
+ private provider;
35
+ private workspace;
36
+ private createTools;
37
+ private maxIterations;
38
+ private execPolicyConfig;
39
+ private runningTasks;
40
+ private resultSender;
41
+ constructor(options: SubagentManagerOptions);
42
+ setSender(sender: SubagentResultSender): void;
43
+ spawn(options: SpawnOptions): Promise<string>;
44
+ getRunningCount(): number;
45
+ private runSubagent;
46
+ private announceResult;
47
+ private buildSubagentPrompt;
48
+ dispose(): void;
49
+ }
50
+ //# sourceMappingURL=subagent.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"subagent.d.ts","sourceRoot":"","sources":["../src/subagent.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAIH,OAAO,KAAK,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAE3D,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAS9D,MAAM,WAAW,cAAc;IAC7B,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,MAAM,CAAC;IAChB,QAAQ,EAAE,MAAM,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,WAAW,YAAY;IAC3B,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,cAAc,CAAC;CACxB;AAED,MAAM,MAAM,oBAAoB,GAAG,CAAC,MAAM,EAAE,cAAc,EAAE,OAAO,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;AAE9F,MAAM,WAAW,sBAAsB;IACrC,QAAQ,EAAE,UAAU,CAAC;IACrB,SAAS,EAAE,MAAM,CAAC;IAClB,WAAW,EAAE,MAAM,SAAS,EAAE,CAAC;IAC/B,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,2DAA2D;IAC3D,gBAAgB,CAAC,EAAE,QAAQ,CAAC,eAAe,CAAC,CAAC;CAC9C;AAsBD,qBAAa,eAAe;IAC1B,OAAO,CAAC,QAAQ,CAAa;IAC7B,OAAO,CAAC,SAAS,CAAS;IAC1B,OAAO,CAAC,WAAW,CAAoB;IACvC,OAAO,CAAC,aAAa,CAAS;IAC9B,OAAO,CAAC,gBAAgB,CAAmC;IAC3D,OAAO,CAAC,YAAY,CAA2C;IAC/D,OAAO,CAAC,YAAY,CAAqC;gBAE7C,OAAO,EAAE,sBAAsB;IAQ3C,SAAS,CAAC,MAAM,EAAE,oBAAoB,GAAG,IAAI;IAIvC,KAAK,CAAC,OAAO,EAAE,YAAY,GAAG,OAAO,CAAC,MAAM,CAAC;IAqBnD,eAAe,IAAI,MAAM;YAMX,WAAW;YAkCX,cAAc;IAwB5B,OAAO,CAAC,mBAAmB;IA+B3B,OAAO,IAAI,IAAI;CAGhB"}
@@ -0,0 +1,144 @@
1
+ /**
2
+ * SubagentManager — 后台子任务执行管理器
3
+ *
4
+ * 职责:
5
+ * 1. 接收主 agent 发起的 spawn 请求,创建后台子 agent
6
+ * 2. 为子 agent 配备受限工具集(文件/Shell/网络,不含消息/spawn/技能)
7
+ * 3. 管理子 agent 生命周期(运行跟踪、完成/失败回告)
8
+ * 4. 完成后将结果投递回主流程,由主 agent 摘要后发送到原始频道
9
+ */
10
+ import { randomUUID } from 'crypto';
11
+ import { Logger } from '@zhin.js/logger';
12
+ import { createAgent } from './agent.js';
13
+ import { applyExecPolicyToTools } from './zhin-agent/exec-policy.js';
14
+ const logger = new Logger(null, 'Subagent');
15
+ // ============================================================================
16
+ // 子 agent 允许使用的工具名单
17
+ // ============================================================================
18
+ const SUBAGENT_ALLOWED_TOOLS = new Set([
19
+ 'read_file',
20
+ 'write_file',
21
+ 'edit_file',
22
+ 'list_dir',
23
+ 'glob',
24
+ 'grep',
25
+ 'bash',
26
+ 'web_search',
27
+ 'web_fetch',
28
+ ]);
29
+ // ============================================================================
30
+ // SubagentManager
31
+ // ============================================================================
32
+ export class SubagentManager {
33
+ provider;
34
+ workspace;
35
+ createTools;
36
+ maxIterations;
37
+ execPolicyConfig;
38
+ runningTasks = new Map();
39
+ resultSender = null;
40
+ constructor(options) {
41
+ this.provider = options.provider;
42
+ this.workspace = options.workspace;
43
+ this.createTools = options.createTools;
44
+ this.maxIterations = options.maxIterations ?? 15;
45
+ this.execPolicyConfig = options.execPolicyConfig ?? null;
46
+ }
47
+ setSender(sender) {
48
+ this.resultSender = sender;
49
+ }
50
+ async spawn(options) {
51
+ const taskId = randomUUID().slice(0, 8);
52
+ const displayLabel = options.label ||
53
+ options.task.slice(0, 30) + (options.task.length > 30 ? '...' : '');
54
+ const abortController = new AbortController();
55
+ this.runningTasks.set(taskId, abortController);
56
+ this.runSubagent(taskId, options.task, displayLabel, options.origin)
57
+ .catch((error) => {
58
+ logger.error({ error, taskId }, 'Subagent failed');
59
+ })
60
+ .finally(() => {
61
+ this.runningTasks.delete(taskId);
62
+ });
63
+ logger.info({ taskId, label: displayLabel }, 'Spawned subagent');
64
+ return `子任务 [${displayLabel}] 已启动 (id: ${taskId}),完成后会自动通知你。`;
65
+ }
66
+ getRunningCount() {
67
+ return this.runningTasks.size;
68
+ }
69
+ // ── 内部方法 ──────────────────────────────────────────────────────
70
+ async runSubagent(taskId, task, label, origin) {
71
+ logger.info({ taskId, label }, 'Subagent starting task');
72
+ try {
73
+ const allTools = this.createTools();
74
+ let tools = allTools.filter(t => SUBAGENT_ALLOWED_TOOLS.has(t.name));
75
+ if (this.execPolicyConfig) {
76
+ tools = applyExecPolicyToTools(this.execPolicyConfig, tools);
77
+ }
78
+ const systemPrompt = this.buildSubagentPrompt(task);
79
+ const agent = createAgent(this.provider, {
80
+ systemPrompt,
81
+ tools,
82
+ maxIterations: this.maxIterations,
83
+ });
84
+ const result = await agent.run(task);
85
+ const finalResult = result.content || '任务已完成,但未生成最终响应。';
86
+ logger.info({ taskId }, 'Subagent completed successfully');
87
+ await this.announceResult(taskId, label, task, finalResult, origin, 'ok');
88
+ }
89
+ catch (error) {
90
+ const errorMsg = `Error: ${error}`;
91
+ logger.error({ taskId, error }, 'Subagent failed');
92
+ await this.announceResult(taskId, label, task, errorMsg, origin, 'error');
93
+ }
94
+ }
95
+ async announceResult(taskId, label, task, result, origin, status) {
96
+ if (!this.resultSender) {
97
+ logger.warn({ taskId }, 'No result sender configured, discarding subagent result');
98
+ return;
99
+ }
100
+ const statusText = status === 'ok' ? '已完成' : '执行失败';
101
+ const announceContent = `[后台任务 '${label}' ${statusText}]\n\n任务: ${task}\n\n结果:\n${result}`;
102
+ try {
103
+ await this.resultSender(origin, announceContent);
104
+ logger.debug({ taskId, origin }, 'Subagent announced result');
105
+ }
106
+ catch (e) {
107
+ logger.error({ taskId, error: e }, 'Failed to announce subagent result');
108
+ }
109
+ }
110
+ buildSubagentPrompt(task) {
111
+ return `# 子任务 Agent
112
+
113
+ 你是一个被主 agent 派生出来执行特定任务的子 agent。
114
+
115
+ ## 你的任务
116
+ ${task}
117
+
118
+ ## 规则
119
+ 1. 专注完成分配的任务,不做其他事情
120
+ 2. 你的最终回复会被报告给主 agent,并转达给用户
121
+ 3. 不要发起对话或承担额外任务
122
+ 4. 回复要简洁但信息充分
123
+
124
+ ## 你可以做的
125
+ - 读写工作区内的文件
126
+ - 执行 Shell 命令
127
+ - 搜索和抓取网页
128
+ - 彻底完成任务
129
+
130
+ ## 你不能做的
131
+ - 直接向用户发送消息
132
+ - 派生其他子任务
133
+ - 访问主 agent 的对话历史
134
+
135
+ ## 工作区
136
+ 你的工作区路径: ${this.workspace}
137
+
138
+ 完成任务后,请提供清晰的发现或操作摘要。`;
139
+ }
140
+ dispose() {
141
+ this.runningTasks.clear();
142
+ }
143
+ }
144
+ //# sourceMappingURL=subagent.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"subagent.js","sourceRoot":"","sources":["../src/subagent.ts"],"names":[],"mappings":"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"}