agentdev 0.1.7 → 0.1.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/BasicAgent-UWXLSZP2.js +13 -0
- package/dist/ExplorerAgent-LCM3JQS4.js +13 -0
- package/dist/{chunk-LQTEETML.js → chunk-5T4C2XRT.js} +12 -7
- package/dist/chunk-5T4C2XRT.js.map +1 -0
- package/dist/{chunk-OBOU27DM.js → chunk-A354ZCZF.js} +6735 -1822
- package/dist/chunk-A354ZCZF.js.map +1 -0
- package/dist/{chunk-TSASFMRF.js → chunk-BAP2GCYH.js} +1 -1
- package/dist/chunk-BAP2GCYH.js.map +1 -0
- package/dist/{chunk-3BPSNNK3.js → chunk-EECW6PYP.js} +11 -9
- package/dist/chunk-EECW6PYP.js.map +1 -0
- package/dist/chunk-G5ECPY4K.js +551 -0
- package/dist/chunk-G5ECPY4K.js.map +1 -0
- package/dist/{chunk-LLV3W326.js → chunk-NORTAQIL.js} +67 -20
- package/dist/chunk-NORTAQIL.js.map +1 -0
- package/dist/{chunk-F3PR7UTL.js → chunk-QFHPUAUQ.js} +5 -3
- package/dist/{chunk-F3PR7UTL.js.map → chunk-QFHPUAUQ.js.map} +1 -1
- package/dist/cli/server.js +2 -2
- package/dist/cli/viewer.js +2 -2
- package/dist/create-feature-cli.cmd +2 -0
- package/dist/create-feature-cli.js +292 -0
- package/dist/features/shell/templates/bash.render.d.ts +1 -1
- package/dist/features/websearch/templates/web-fetch.render.d.ts +1 -1
- package/dist/index.d.ts +1733 -500
- package/dist/index.js +30 -8
- package/dist/index.js.map +1 -1
- package/dist/{notification-3VEAP7YF.js → notification-NWVOS2WR.js} +3 -3
- package/dist/tools-LDR3LIJP.js +14 -0
- package/dist/tools-LDR3LIJP.js.map +1 -0
- package/dist/{types-DUKIIntb.d.ts → types-CF5UsxD9.d.ts} +3 -0
- package/node_modules/@sliverp/qqbot/LICENSE +21 -0
- package/node_modules/@sliverp/qqbot/README.md +427 -0
- package/node_modules/@sliverp/qqbot/README.standalone.zh.md +77 -0
- package/node_modules/@sliverp/qqbot/README.zh.md +423 -0
- package/node_modules/@sliverp/qqbot/bin/qqbot-cli.js +227 -0
- package/node_modules/@sliverp/qqbot/clawdbot.plugin.json +16 -0
- package/node_modules/@sliverp/qqbot/dist/index.d.ts +20 -0
- package/node_modules/@sliverp/qqbot/dist/index.js +25 -0
- package/node_modules/@sliverp/qqbot/dist/src/agent.d.ts +76 -0
- package/node_modules/@sliverp/qqbot/dist/src/agent.js +36 -0
- package/node_modules/@sliverp/qqbot/dist/src/api.d.ts +138 -0
- package/node_modules/@sliverp/qqbot/dist/src/api.js +523 -0
- package/node_modules/@sliverp/qqbot/dist/src/channel.d.ts +3 -0
- package/node_modules/@sliverp/qqbot/dist/src/channel.js +349 -0
- package/node_modules/@sliverp/qqbot/dist/src/config.d.ts +25 -0
- package/node_modules/@sliverp/qqbot/dist/src/config.js +156 -0
- package/node_modules/@sliverp/qqbot/dist/src/demo-standalone.d.ts +1 -0
- package/node_modules/@sliverp/qqbot/dist/src/demo-standalone.js +125 -0
- package/node_modules/@sliverp/qqbot/dist/src/gateway.d.ts +20 -0
- package/node_modules/@sliverp/qqbot/dist/src/gateway.js +2156 -0
- package/node_modules/@sliverp/qqbot/dist/src/image-server.d.ts +62 -0
- package/node_modules/@sliverp/qqbot/dist/src/image-server.js +401 -0
- package/node_modules/@sliverp/qqbot/dist/src/known-users.d.ts +100 -0
- package/node_modules/@sliverp/qqbot/dist/src/known-users.js +263 -0
- package/node_modules/@sliverp/qqbot/dist/src/onboarding.d.ts +10 -0
- package/node_modules/@sliverp/qqbot/dist/src/onboarding.js +203 -0
- package/node_modules/@sliverp/qqbot/dist/src/openclaw-agent-adapter.d.ts +2 -0
- package/node_modules/@sliverp/qqbot/dist/src/openclaw-agent-adapter.js +155 -0
- package/node_modules/@sliverp/qqbot/dist/src/outbound.d.ts +150 -0
- package/node_modules/@sliverp/qqbot/dist/src/outbound.js +1175 -0
- package/node_modules/@sliverp/qqbot/dist/src/proactive.d.ts +170 -0
- package/node_modules/@sliverp/qqbot/dist/src/proactive.js +399 -0
- package/node_modules/@sliverp/qqbot/dist/src/runtime.d.ts +5 -0
- package/node_modules/@sliverp/qqbot/dist/src/runtime.js +16 -0
- package/node_modules/@sliverp/qqbot/dist/src/session-store.d.ts +52 -0
- package/node_modules/@sliverp/qqbot/dist/src/session-store.js +254 -0
- package/node_modules/@sliverp/qqbot/dist/src/types.d.ts +145 -0
- package/node_modules/@sliverp/qqbot/dist/src/types.js +1 -0
- package/node_modules/@sliverp/qqbot/dist/src/utils/audio-convert.d.ts +73 -0
- package/node_modules/@sliverp/qqbot/dist/src/utils/audio-convert.js +645 -0
- package/node_modules/@sliverp/qqbot/dist/src/utils/file-utils.d.ts +46 -0
- package/node_modules/@sliverp/qqbot/dist/src/utils/file-utils.js +107 -0
- package/node_modules/@sliverp/qqbot/dist/src/utils/image-size.d.ts +51 -0
- package/node_modules/@sliverp/qqbot/dist/src/utils/image-size.js +234 -0
- package/node_modules/@sliverp/qqbot/dist/src/utils/media-tags.d.ts +14 -0
- package/node_modules/@sliverp/qqbot/dist/src/utils/media-tags.js +120 -0
- package/node_modules/@sliverp/qqbot/dist/src/utils/payload.d.ts +112 -0
- package/node_modules/@sliverp/qqbot/dist/src/utils/payload.js +186 -0
- package/node_modules/@sliverp/qqbot/dist/src/utils/platform.d.ts +126 -0
- package/node_modules/@sliverp/qqbot/dist/src/utils/platform.js +358 -0
- package/node_modules/@sliverp/qqbot/dist/src/utils/upload-cache.d.ts +34 -0
- package/node_modules/@sliverp/qqbot/dist/src/utils/upload-cache.js +93 -0
- package/node_modules/@sliverp/qqbot/dist/standalone.d.ts +6 -0
- package/node_modules/@sliverp/qqbot/dist/standalone.js +6 -0
- package/node_modules/@sliverp/qqbot/index.ts +30 -0
- package/node_modules/@sliverp/qqbot/moltbot.plugin.json +16 -0
- package/node_modules/@sliverp/qqbot/node_modules/@eshaz/web-worker/LICENSE +201 -0
- package/node_modules/@sliverp/qqbot/node_modules/@eshaz/web-worker/README.md +134 -0
- package/node_modules/@sliverp/qqbot/node_modules/@eshaz/web-worker/browser.js +17 -0
- package/node_modules/@sliverp/qqbot/node_modules/@eshaz/web-worker/cjs/browser.js +16 -0
- package/node_modules/@sliverp/qqbot/node_modules/@eshaz/web-worker/cjs/node.js +219 -0
- package/node_modules/@sliverp/qqbot/node_modules/@eshaz/web-worker/index.d.ts +4 -0
- package/node_modules/@sliverp/qqbot/node_modules/@eshaz/web-worker/node.js +223 -0
- package/node_modules/@sliverp/qqbot/node_modules/@eshaz/web-worker/package.json +54 -0
- package/node_modules/@sliverp/qqbot/node_modules/@wasm-audio-decoders/common/index.js +5 -0
- package/node_modules/@sliverp/qqbot/node_modules/@wasm-audio-decoders/common/package.json +36 -0
- package/node_modules/@sliverp/qqbot/node_modules/@wasm-audio-decoders/common/src/WASMAudioDecoderCommon.js +231 -0
- package/node_modules/@sliverp/qqbot/node_modules/@wasm-audio-decoders/common/src/WASMAudioDecoderWorker.js +129 -0
- package/node_modules/@sliverp/qqbot/node_modules/@wasm-audio-decoders/common/src/puff/README +67 -0
- package/node_modules/@sliverp/qqbot/node_modules/@wasm-audio-decoders/common/src/puff/build_puff.js +31 -0
- package/node_modules/@sliverp/qqbot/node_modules/@wasm-audio-decoders/common/src/puff/puff.c +863 -0
- package/node_modules/@sliverp/qqbot/node_modules/@wasm-audio-decoders/common/src/puff/puff.h +35 -0
- package/node_modules/@sliverp/qqbot/node_modules/@wasm-audio-decoders/common/src/utilities.js +3 -0
- package/node_modules/@sliverp/qqbot/node_modules/@wasm-audio-decoders/common/types.d.ts +7 -0
- package/node_modules/@sliverp/qqbot/node_modules/mpg123-decoder/README.md +265 -0
- package/node_modules/@sliverp/qqbot/node_modules/mpg123-decoder/dist/mpg123-decoder.min.js +185 -0
- package/node_modules/@sliverp/qqbot/node_modules/mpg123-decoder/dist/mpg123-decoder.min.js.map +1 -0
- package/node_modules/@sliverp/qqbot/node_modules/mpg123-decoder/index.js +8 -0
- package/node_modules/@sliverp/qqbot/node_modules/mpg123-decoder/package.json +58 -0
- package/node_modules/@sliverp/qqbot/node_modules/mpg123-decoder/src/EmscriptenWasm.js +464 -0
- package/node_modules/@sliverp/qqbot/node_modules/mpg123-decoder/src/MPEGDecoder.js +200 -0
- package/node_modules/@sliverp/qqbot/node_modules/mpg123-decoder/src/MPEGDecoderWebWorker.js +21 -0
- package/node_modules/@sliverp/qqbot/node_modules/mpg123-decoder/types.d.ts +30 -0
- package/node_modules/@sliverp/qqbot/node_modules/silk-wasm/LICENSE +21 -0
- package/node_modules/@sliverp/qqbot/node_modules/silk-wasm/README.md +85 -0
- package/node_modules/@sliverp/qqbot/node_modules/silk-wasm/lib/index.cjs +16 -0
- package/node_modules/@sliverp/qqbot/node_modules/silk-wasm/lib/index.d.ts +70 -0
- package/node_modules/@sliverp/qqbot/node_modules/silk-wasm/lib/index.mjs +16 -0
- package/node_modules/@sliverp/qqbot/node_modules/silk-wasm/lib/silk.wasm +0 -0
- package/node_modules/@sliverp/qqbot/node_modules/silk-wasm/lib/utils.d.ts +4 -0
- package/node_modules/@sliverp/qqbot/node_modules/silk-wasm/package.json +39 -0
- package/node_modules/@sliverp/qqbot/node_modules/simple-yenc/.github/FUNDING.yml +1 -0
- package/node_modules/@sliverp/qqbot/node_modules/simple-yenc/.prettierignore +1 -0
- package/node_modules/@sliverp/qqbot/node_modules/simple-yenc/LICENSE +7 -0
- package/node_modules/@sliverp/qqbot/node_modules/simple-yenc/README.md +163 -0
- package/node_modules/@sliverp/qqbot/node_modules/simple-yenc/dist/esm.js +1 -0
- package/node_modules/@sliverp/qqbot/node_modules/simple-yenc/dist/index.js +1 -0
- package/node_modules/@sliverp/qqbot/node_modules/simple-yenc/package.json +50 -0
- package/node_modules/@sliverp/qqbot/node_modules/simple-yenc/rollup.config.js +27 -0
- package/node_modules/@sliverp/qqbot/node_modules/simple-yenc/src/simple-yenc.js +302 -0
- package/node_modules/@sliverp/qqbot/node_modules/ws/LICENSE +20 -0
- package/node_modules/@sliverp/qqbot/node_modules/ws/README.md +548 -0
- package/node_modules/@sliverp/qqbot/node_modules/ws/browser.js +8 -0
- package/node_modules/@sliverp/qqbot/node_modules/ws/index.js +13 -0
- package/node_modules/@sliverp/qqbot/node_modules/ws/lib/buffer-util.js +131 -0
- package/node_modules/@sliverp/qqbot/node_modules/ws/lib/constants.js +19 -0
- package/node_modules/@sliverp/qqbot/node_modules/ws/lib/event-target.js +292 -0
- package/node_modules/@sliverp/qqbot/node_modules/ws/lib/extension.js +203 -0
- package/node_modules/@sliverp/qqbot/node_modules/ws/lib/limiter.js +55 -0
- package/node_modules/@sliverp/qqbot/node_modules/ws/lib/permessage-deflate.js +528 -0
- package/node_modules/@sliverp/qqbot/node_modules/ws/lib/receiver.js +706 -0
- package/node_modules/@sliverp/qqbot/node_modules/ws/lib/sender.js +602 -0
- package/node_modules/@sliverp/qqbot/node_modules/ws/lib/stream.js +161 -0
- package/node_modules/@sliverp/qqbot/node_modules/ws/lib/subprotocol.js +62 -0
- package/node_modules/@sliverp/qqbot/node_modules/ws/lib/validation.js +152 -0
- package/node_modules/@sliverp/qqbot/node_modules/ws/lib/websocket-server.js +554 -0
- package/node_modules/@sliverp/qqbot/node_modules/ws/lib/websocket.js +1393 -0
- package/node_modules/@sliverp/qqbot/node_modules/ws/package.json +69 -0
- package/node_modules/@sliverp/qqbot/node_modules/ws/wrapper.mjs +8 -0
- package/node_modules/@sliverp/qqbot/openclaw.plugin.json +16 -0
- package/node_modules/@sliverp/qqbot/package.json +81 -0
- package/node_modules/@sliverp/qqbot/skills/qqbot-cron/SKILL.md +513 -0
- package/node_modules/@sliverp/qqbot/skills/qqbot-media/SKILL.md +194 -0
- package/node_modules/@sliverp/qqbot/src/agent.ts +133 -0
- package/node_modules/@sliverp/qqbot/src/api.ts +704 -0
- package/node_modules/@sliverp/qqbot/src/channel.ts +380 -0
- package/node_modules/@sliverp/qqbot/src/config.ts +182 -0
- package/node_modules/@sliverp/qqbot/src/demo-standalone.ts +144 -0
- package/node_modules/@sliverp/qqbot/src/gateway.ts +2285 -0
- package/node_modules/@sliverp/qqbot/src/image-server.ts +474 -0
- package/node_modules/@sliverp/qqbot/src/known-users.ts +353 -0
- package/node_modules/@sliverp/qqbot/src/onboarding.ts +274 -0
- package/node_modules/@sliverp/qqbot/src/openclaw-agent-adapter.ts +168 -0
- package/node_modules/@sliverp/qqbot/src/openclaw-plugin-sdk.d.ts +483 -0
- package/node_modules/@sliverp/qqbot/src/outbound.ts +1301 -0
- package/node_modules/@sliverp/qqbot/src/proactive.ts +530 -0
- package/node_modules/@sliverp/qqbot/src/runtime.ts +22 -0
- package/node_modules/@sliverp/qqbot/src/session-store.ts +303 -0
- package/node_modules/@sliverp/qqbot/src/types.ts +153 -0
- package/node_modules/@sliverp/qqbot/src/utils/audio-convert.ts +738 -0
- package/node_modules/@sliverp/qqbot/src/utils/file-utils.ts +122 -0
- package/node_modules/@sliverp/qqbot/src/utils/image-size.ts +266 -0
- package/node_modules/@sliverp/qqbot/src/utils/media-tags.ts +134 -0
- package/node_modules/@sliverp/qqbot/src/utils/payload.ts +265 -0
- package/node_modules/@sliverp/qqbot/src/utils/platform.ts +404 -0
- package/node_modules/@sliverp/qqbot/src/utils/upload-cache.ts +128 -0
- package/node_modules/@sliverp/qqbot/standalone.ts +6 -0
- package/node_modules/@sliverp/qqbot/tsconfig.json +16 -0
- package/package.json +12 -3
- package/dist/BasicAgent-QWEYCLV5.js +0 -12
- package/dist/ExplorerAgent-4IT22VB7.js +0 -12
- package/dist/chunk-3BPSNNK3.js.map +0 -1
- package/dist/chunk-LLV3W326.js.map +0 -1
- package/dist/chunk-LQTEETML.js.map +0 -1
- package/dist/chunk-OBOU27DM.js.map +0 -1
- package/dist/chunk-TSASFMRF.js.map +0 -1
- /package/dist/{BasicAgent-QWEYCLV5.js.map → BasicAgent-UWXLSZP2.js.map} +0 -0
- /package/dist/{ExplorerAgent-4IT22VB7.js.map → ExplorerAgent-LCM3JQS4.js.map} +0 -0
- /package/dist/{notification-3VEAP7YF.js.map → notification-NWVOS2WR.js.map} +0 -0
|
@@ -0,0 +1,128 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* file_info 缓存 — 借鉴 Telegram file_id 机制
|
|
3
|
+
*
|
|
4
|
+
* QQ Bot API 上传文件后返回 file_info + ttl,在 TTL 内相同文件可直接复用 file_info
|
|
5
|
+
* 避免重复上传同一文件,节省带宽和时间。
|
|
6
|
+
*
|
|
7
|
+
* 缓存 key = md5(fileContent) + targetType(c2c/group) + targetId + fileType
|
|
8
|
+
*/
|
|
9
|
+
|
|
10
|
+
import * as crypto from "node:crypto";
|
|
11
|
+
import * as fs from "node:fs";
|
|
12
|
+
|
|
13
|
+
interface CacheEntry {
|
|
14
|
+
fileInfo: string;
|
|
15
|
+
fileUuid: string;
|
|
16
|
+
/** 过期时间戳(ms),比 API 返回的 TTL 提前 60 秒失效 */
|
|
17
|
+
expiresAt: number;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
// 内存缓存,key 格式:`${contentHash}:${scope}:${targetId}:${fileType}`
|
|
21
|
+
const cache = new Map<string, CacheEntry>();
|
|
22
|
+
|
|
23
|
+
// 最大缓存条目数,防止内存泄漏
|
|
24
|
+
const MAX_CACHE_SIZE = 500;
|
|
25
|
+
|
|
26
|
+
/**
|
|
27
|
+
* 计算文件内容的 MD5 hash(用于缓存 key)
|
|
28
|
+
* 对于 Base64 数据直接 hash,对于文件路径读取后 hash
|
|
29
|
+
*/
|
|
30
|
+
export function computeFileHash(data: string | Buffer): string {
|
|
31
|
+
const content = typeof data === "string" ? data : data;
|
|
32
|
+
return crypto.createHash("md5").update(content).digest("hex");
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
/**
|
|
36
|
+
* 构建缓存 key
|
|
37
|
+
* @param contentHash - 文件内容 hash
|
|
38
|
+
* @param scope - "c2c" | "group"
|
|
39
|
+
* @param targetId - 用户 openid 或群 openid
|
|
40
|
+
* @param fileType - 1=IMAGE, 2=VIDEO, 3=VOICE, 4=FILE
|
|
41
|
+
*/
|
|
42
|
+
function buildCacheKey(contentHash: string, scope: string, targetId: string, fileType: number): string {
|
|
43
|
+
return `${contentHash}:${scope}:${targetId}:${fileType}`;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
/**
|
|
47
|
+
* 从缓存获取 file_info
|
|
48
|
+
* @returns file_info 字符串,未命中或已过期返回 null
|
|
49
|
+
*/
|
|
50
|
+
export function getCachedFileInfo(
|
|
51
|
+
contentHash: string,
|
|
52
|
+
scope: "c2c" | "group",
|
|
53
|
+
targetId: string,
|
|
54
|
+
fileType: number,
|
|
55
|
+
): string | null {
|
|
56
|
+
const key = buildCacheKey(contentHash, scope, targetId, fileType);
|
|
57
|
+
const entry = cache.get(key);
|
|
58
|
+
|
|
59
|
+
if (!entry) return null;
|
|
60
|
+
|
|
61
|
+
// 检查是否过期
|
|
62
|
+
if (Date.now() >= entry.expiresAt) {
|
|
63
|
+
cache.delete(key);
|
|
64
|
+
return null;
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
console.log(`[upload-cache] Cache HIT: key=${key.slice(0, 40)}..., fileUuid=${entry.fileUuid}`);
|
|
68
|
+
return entry.fileInfo;
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
/**
|
|
72
|
+
* 将上传结果写入缓存
|
|
73
|
+
* @param ttl - API 返回的 TTL(秒),缓存会提前 60 秒失效
|
|
74
|
+
*/
|
|
75
|
+
export function setCachedFileInfo(
|
|
76
|
+
contentHash: string,
|
|
77
|
+
scope: "c2c" | "group",
|
|
78
|
+
targetId: string,
|
|
79
|
+
fileType: number,
|
|
80
|
+
fileInfo: string,
|
|
81
|
+
fileUuid: string,
|
|
82
|
+
ttl: number,
|
|
83
|
+
): void {
|
|
84
|
+
// 清理过期条目(惰性清理)
|
|
85
|
+
if (cache.size >= MAX_CACHE_SIZE) {
|
|
86
|
+
const now = Date.now();
|
|
87
|
+
for (const [k, v] of cache) {
|
|
88
|
+
if (now >= v.expiresAt) {
|
|
89
|
+
cache.delete(k);
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
// 如果清理后仍然超限,删除最早的一半
|
|
93
|
+
if (cache.size >= MAX_CACHE_SIZE) {
|
|
94
|
+
const keys = Array.from(cache.keys());
|
|
95
|
+
for (let i = 0; i < keys.length / 2; i++) {
|
|
96
|
+
cache.delete(keys[i]!);
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
const key = buildCacheKey(contentHash, scope, targetId, fileType);
|
|
102
|
+
// 提前 60 秒失效,避免临界点过期
|
|
103
|
+
const safetyMargin = 60;
|
|
104
|
+
const effectiveTtl = Math.max(ttl - safetyMargin, 10);
|
|
105
|
+
|
|
106
|
+
cache.set(key, {
|
|
107
|
+
fileInfo,
|
|
108
|
+
fileUuid,
|
|
109
|
+
expiresAt: Date.now() + effectiveTtl * 1000,
|
|
110
|
+
});
|
|
111
|
+
|
|
112
|
+
console.log(`[upload-cache] Cache SET: key=${key.slice(0, 40)}..., ttl=${effectiveTtl}s, uuid=${fileUuid}`);
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
/**
|
|
116
|
+
* 获取缓存统计
|
|
117
|
+
*/
|
|
118
|
+
export function getUploadCacheStats(): { size: number; maxSize: number } {
|
|
119
|
+
return { size: cache.size, maxSize: MAX_CACHE_SIZE };
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
/**
|
|
123
|
+
* 清除所有缓存
|
|
124
|
+
*/
|
|
125
|
+
export function clearUploadCache(): void {
|
|
126
|
+
cache.clear();
|
|
127
|
+
console.log(`[upload-cache] Cache cleared`);
|
|
128
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
{
|
|
2
|
+
"compilerOptions": {
|
|
3
|
+
"target": "ES2022",
|
|
4
|
+
"module": "NodeNext",
|
|
5
|
+
"moduleResolution": "NodeNext",
|
|
6
|
+
"declaration": true,
|
|
7
|
+
"outDir": "./dist",
|
|
8
|
+
"rootDir": ".",
|
|
9
|
+
"strict": true,
|
|
10
|
+
"esModuleInterop": true,
|
|
11
|
+
"skipLibCheck": true,
|
|
12
|
+
"resolveJsonModule": true
|
|
13
|
+
},
|
|
14
|
+
"include": ["index.ts", "standalone.ts", "src/**/*.ts"],
|
|
15
|
+
"exclude": ["node_modules", "dist"]
|
|
16
|
+
}
|
package/package.json
CHANGED
|
@@ -1,24 +1,28 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "agentdev",
|
|
3
|
-
"version": "0.1.
|
|
3
|
+
"version": "0.1.9",
|
|
4
4
|
"description": "A lightweight, decoupled AI agent framework with built-in debugger",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"main": "dist/index.js",
|
|
7
7
|
"types": "dist/index.d.ts",
|
|
8
8
|
"bin": {
|
|
9
9
|
"agentdev-viewer": "dist/cli/viewer.cmd",
|
|
10
|
-
"agentdev-server": "dist/cli/server.cmd"
|
|
10
|
+
"agentdev-server": "dist/cli/server.cmd",
|
|
11
|
+
"agentdev-create-feature": "dist/create-feature-cli.cmd"
|
|
11
12
|
},
|
|
12
13
|
"files": [
|
|
13
14
|
"dist",
|
|
14
15
|
"README.md",
|
|
15
16
|
"LICENSE"
|
|
16
17
|
],
|
|
18
|
+
"bundleDependencies": [
|
|
19
|
+
"@sliverp/qqbot"
|
|
20
|
+
],
|
|
17
21
|
"scripts": {
|
|
18
22
|
"build": "tsup && node scripts/generate-bin-cmds.mjs",
|
|
19
23
|
"dev": "tsup --watch",
|
|
20
24
|
"prepublishOnly": "npm run build",
|
|
21
|
-
"create-feature": "node
|
|
25
|
+
"create-feature": "node dist/create-feature-cli.js",
|
|
22
26
|
"copy-example": "node scripts/copy-example-feature.mjs",
|
|
23
27
|
"server": "node dist/cli/server.js"
|
|
24
28
|
},
|
|
@@ -37,14 +41,19 @@
|
|
|
37
41
|
"dependencies": {
|
|
38
42
|
"@modelcontextprotocol/sdk": "^1.26.0",
|
|
39
43
|
"@openai/agents": "^0.4.6",
|
|
44
|
+
"@sliverp/qqbot": "1.5.5",
|
|
45
|
+
"better-sqlite3": "^12.8.0",
|
|
40
46
|
"diff": "^8.0.3",
|
|
41
47
|
"glob": "^13.0.6",
|
|
42
48
|
"js-yaml": "^4.1.0",
|
|
43
49
|
"open": "^11.0.0",
|
|
44
50
|
"openai": "^4.73.0",
|
|
51
|
+
"sharp": "^0.33.5",
|
|
52
|
+
"sound-play": "^1.1.0",
|
|
45
53
|
"zod": "^4.1.5"
|
|
46
54
|
},
|
|
47
55
|
"devDependencies": {
|
|
56
|
+
"@types/better-sqlite3": "^7.6.13",
|
|
48
57
|
"@types/node": "^20.11.0",
|
|
49
58
|
"tsup": "^8.3.5",
|
|
50
59
|
"tsx": "^4.7.0",
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
BasicAgent
|
|
3
|
-
} from "./chunk-LQTEETML.js";
|
|
4
|
-
import "./chunk-OBOU27DM.js";
|
|
5
|
-
import "./chunk-BVF7RUXV.js";
|
|
6
|
-
import "./chunk-3BPSNNK3.js";
|
|
7
|
-
import "./chunk-TSASFMRF.js";
|
|
8
|
-
import "./chunk-BDS2QGZ5.js";
|
|
9
|
-
export {
|
|
10
|
-
BasicAgent
|
|
11
|
-
};
|
|
12
|
-
//# sourceMappingURL=BasicAgent-QWEYCLV5.js.map
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
ExplorerAgent
|
|
3
|
-
} from "./chunk-F3PR7UTL.js";
|
|
4
|
-
import "./chunk-OBOU27DM.js";
|
|
5
|
-
import "./chunk-BVF7RUXV.js";
|
|
6
|
-
import "./chunk-3BPSNNK3.js";
|
|
7
|
-
import "./chunk-TSASFMRF.js";
|
|
8
|
-
import "./chunk-BDS2QGZ5.js";
|
|
9
|
-
export {
|
|
10
|
-
ExplorerAgent
|
|
11
|
-
};
|
|
12
|
-
//# sourceMappingURL=ExplorerAgent-4IT22VB7.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/core/debug-transport.ts","../src/core/debug-capabilities.ts","../src/core/debug-hub.ts","../src/core/claw-debug-client.ts"],"sourcesContent":["export type DebugTransportMode = 'viewer-worker' | 'claw';\n\nexport function resolveDebugTransportMode(): DebugTransportMode {\n return process.env.AGENTDEV_DEBUG_TRANSPORT === 'claw' ? 'claw' : 'viewer-worker';\n}\n\nexport function getClawRuntimeUrl(): string {\n return process.env.AGENTDEV_CLAW_RUNTIME_URL || 'http://127.0.0.1:3030';\n}\n","import { getClawRuntimeUrl, resolveDebugTransportMode, type DebugTransportMode } from './debug-transport.js';\n\nexport interface DebugCapabilities {\n transportMode: DebugTransportMode;\n interactiveInput: boolean;\n runtimeUrl: string | null;\n viewerCompatibleApi: boolean;\n debuggerMcpMetadata: boolean;\n}\n\nexport function getDebugCapabilities(): DebugCapabilities {\n const transportMode = resolveDebugTransportMode();\n const isClaw = transportMode === 'claw';\n\n return {\n transportMode,\n interactiveInput: true,\n runtimeUrl: isClaw ? getClawRuntimeUrl() : null,\n viewerCompatibleApi: isClaw,\n debuggerMcpMetadata: isClaw,\n };\n}\n","/**\r\n * DebugHub - 全局多 Agent 调试中心\r\n *\r\n * 职责:\r\n * - 管理所有 Agent 的注册和注销\r\n * - 连接到独立的 Viewer Worker UDS 服务器\r\n * - 路由 Agent 消息到 Worker\r\n *\r\n * 设计原则:\r\n * - 单例模式,全局唯一\r\n * - 轻量:只做路由,不存储消息\r\n * - 直观:API 简单明了\r\n */\r\n\r\nimport { connect, Socket } from 'net';\r\nimport {\r\n getDefaultUDSPath,\r\n type Message,\r\n type Tool,\r\n type AgentInfo,\r\n type DebugHubIPCMessage,\r\n type Notification,\r\n type RequestInputMsg,\r\n type HookInspectorSnapshot,\r\n type AgentOverviewSnapshot,\r\n type UserInputRequest,\r\n type UserInputResponse,\r\n type UserInputAction,\r\n} from './types.js';\r\nimport { ClawDebugClient } from './claw-debug-client.js';\r\nimport { getClawRuntimeUrl, resolveDebugTransportMode } from './debug-transport.js';\r\nimport { getDebugCapabilities, type DebugCapabilities } from './debug-capabilities.js';\r\n\r\n// 前向声明 Agent 类型(避免循环依赖)\r\ntype Agent = any;\r\n\r\n/**\r\n * Hub 内部存储的 Agent 数据\r\n */\r\ninterface AgentData {\r\n info: AgentInfo;\r\n agent: Agent;\r\n}\r\n\r\nexport class DebugHub {\r\n private static instance: DebugHub;\r\n private readonly transportMode: 'viewer-worker' | 'claw';\r\n private readonly clawClient?: ClawDebugClient;\r\n\r\n // ========== 状态 ==========\r\n private agents: Map<string, AgentData> = new Map();\r\n private currentAgentId: string | null = null;\r\n private nextId: number = 1;\r\n private readonly processId: string; // 进程唯一标识\r\n\r\n // 输入请求回调映射:requestId → resolver\r\n private pendingInputRequests = new Map<string, (response: UserInputResponse) => void>();\r\n\r\n // 活跃的输入请求元数据(用于重连恢复):agentId → requestInfo\r\n private activeInputRequests = new Map<string, {\r\n requestId: string;\r\n prompt: string;\r\n placeholder?: string;\r\n initialValue?: string;\r\n actions?: UserInputAction[];\r\n timestamp: number;\r\n }>();\r\n\r\n // UDS 客户端连接\r\n private udsClient?: Socket;\r\n private udsPath: string;\r\n private workerPort: number | null = null;\r\n private clientReady: boolean = false;\r\n\r\n // 注册锁(防止并发竞争)\r\n private registrationLock: boolean = false;\r\n\r\n // 待发送的消息队列(连接建立前)\r\n private messageQueue: DebugHubIPCMessage[] = [];\r\n\r\n // 重连机制\r\n private reconnectTimer?: NodeJS.Timeout;\r\n private reconnectAttempts: number = 0;\r\n private readonly MAX_RECONNECT_ATTEMPTS = 10;\r\n private readonly RECONNECT_DELAY = 2000;\r\n\r\n // 缓存每个 Agent 的 featureTemplates(用于重连后重新注册)\r\n private agentFeatureTemplates: Map<string, Record<string, string>> = new Map();\r\n\r\n // ========== 单例 ==========\r\n private constructor() {\r\n this.udsPath = process.env.AGENTDEV_UDS_PATH || getDefaultUDSPath();\r\n // 使用进程 PID 作为唯一标识,确保多进程环境下 Agent ID 不冲突\r\n this.processId = String(process.pid);\r\n this.transportMode = resolveDebugTransportMode();\r\n if (this.transportMode === 'claw') {\r\n this.clawClient = new ClawDebugClient({\r\n processId: this.processId,\r\n projectRoot: process.cwd(),\r\n });\r\n }\r\n }\r\n\r\n static getInstance(): DebugHub {\r\n if (!DebugHub.instance) {\r\n DebugHub.instance = new DebugHub();\r\n }\r\n return DebugHub.instance;\r\n }\r\n\r\n // ========== 公开 API ==========\r\n\r\n /**\r\n * 启动调试服务器\r\n * @param port HTTP 端口(默认 2026,仅用于显示)\r\n * @param openBrowser 是否自动打开浏览器(默认 true,已废弃参数)\r\n */\r\n async start(port: number = 2026, openBrowser: boolean = true): Promise<void> {\r\n if (this.transportMode === 'claw') {\r\n this.workerPort = port;\r\n try {\r\n await this.clawClient?.ping();\r\n this.clientReady = true;\r\n console.log(`[DebugHub] 已连接到 Claw runtime: ${getClawRuntimeUrl()}`);\r\n } catch (err) {\r\n console.warn(`[DebugHub] 无法连接到 Claw runtime: ${(err as Error).message}`);\r\n console.warn('[DebugHub] 调试功能将被禁用。请先启动 AgentDevClaw runtime。');\r\n this.clientReady = false;\r\n }\r\n return;\r\n }\r\n\r\n if (this.udsClient) {\r\n console.log(`[DebugHub] 已连接到 ViewerWorker`);\r\n return;\r\n }\r\n\r\n this.workerPort = port; // 保留用于信息显示\r\n this.openBrowser = openBrowser; // 保存浏览器打开设置\r\n \r\n try {\r\n await this.connectToWorker();\r\n console.log(`[DebugHub] 调试服务器已连接: http://localhost:${port}`);\r\n } catch (err) {\r\n // 连接失败,尝试自动启动 ViewerWorker\r\n console.log(`[DebugHub] ViewerWorker 未运行,正在自动启动...`);\r\n try {\r\n await this.spawnViewerWorker();\r\n // 等待服务器启动\r\n await new Promise(resolve => setTimeout(resolve, 1000));\r\n // 再次尝试连接\r\n await this.connectToWorker();\r\n console.log(`[DebugHub] 调试服务器已连接: http://localhost:${port}`);\r\n } catch (spawnErr) {\r\n console.warn(`[DebugHub] 无法启动 ViewerWorker: ${(spawnErr as Error).message}`);\r\n console.warn(`[DebugHub] 调试功能将被禁用。请手动运行 'agentdev-viewer' 启动调试服务器。`);\r\n this.clientReady = false;\r\n }\r\n }\r\n }\r\n\r\n /**\r\n * 自动启动 ViewerWorker 进程\r\n */\r\n private openBrowser: boolean = true;\r\n private viewerWorkerProcess?: ReturnType<typeof import('child_process').spawn>;\r\n\r\n private async spawnViewerWorker(): Promise<void> {\r\n const { spawn } = await import('child_process');\r\n const { existsSync } = await import('fs');\r\n const { fileURLToPath } = await import('url');\r\n const { dirname, join } = await import('path');\r\n\r\n // 查找 viewer.js 的路径\r\n let viewerPath: string;\r\n\r\n // 方式1: 优先使用 require.resolve(最可靠)\r\n try {\r\n const agentdevPath = require.resolve('agentdev/package.json');\r\n viewerPath = join(dirname(agentdevPath), 'dist', 'cli', 'viewer.js');\r\n } catch {\r\n // 方式2: 从当前模块解析\r\n try {\r\n const currentDir = dirname(fileURLToPath(import.meta.url));\r\n viewerPath = join(currentDir, '..', 'cli', 'viewer.js');\r\n } catch {\r\n // 方式3: 使用 bin 命令\r\n viewerPath = 'agentdev-viewer';\r\n }\r\n }\r\n\r\n // 验证文件存在\r\n if (viewerPath !== 'agentdev-viewer' && !existsSync(viewerPath)) {\r\n // 回退到 bin 命令\r\n viewerPath = 'agentdev-viewer';\r\n }\r\n\r\n return new Promise((resolve, reject) => {\r\n try {\r\n // 设置环境变量\r\n const env = {\r\n ...process.env,\r\n AGENTDEV_PORT: String(this.workerPort || 2026),\r\n AGENTDEV_OPEN_BROWSER: this.openBrowser ? 'true' : 'false',\r\n AGENTDEV_UDS_PATH: this.udsPath,\r\n };\r\n\r\n console.log(`[DebugHub] 启动 ViewerWorker: ${viewerPath}`);\r\n\r\n // 如果是 bin 命令,直接运行命令;否则用 node 执行\r\n const isBinCommand = viewerPath === 'agentdev-viewer' || viewerPath === 'agentdev-server';\r\n const command = isBinCommand ? viewerPath : 'node';\r\n const args = isBinCommand ? [] : [viewerPath];\r\n\r\n this.viewerWorkerProcess = spawn(command, args, {\r\n env,\r\n stdio: ['ignore', 'pipe', 'pipe'],\r\n detached: false,\r\n shell: isBinCommand, // bin 命令需要 shell 来解析\r\n });\r\n\r\n this.viewerWorkerProcess.on('error', (err: Error) => {\r\n console.error('[DebugHub] ViewerWorker 进程错误:', err.message);\r\n reject(err);\r\n });\r\n\r\n // 输出 ViewerWorker 的日志\r\n this.viewerWorkerProcess.stdout?.on('data', (data: Buffer) => {\r\n const lines = data.toString().trim().split('\\n');\r\n for (const line of lines) {\r\n console.log(`[ViewerWorker] ${line}`);\r\n }\r\n });\r\n\r\n this.viewerWorkerProcess.stderr?.on('data', (data: Buffer) => {\r\n const lines = data.toString().trim().split('\\n');\r\n for (const line of lines) {\r\n console.error(`[ViewerWorker] ${line}`);\r\n }\r\n });\r\n\r\n // 给进程一点时间启动\r\n setTimeout(() => {\r\n if (this.viewerWorkerProcess && !this.viewerWorkerProcess.killed) {\r\n resolve();\r\n } else {\r\n reject(new Error('ViewerWorker 进程启动失败'));\r\n }\r\n }, 500);\r\n } catch (err) {\r\n reject(err);\r\n }\r\n });\r\n }\r\n\r\n /**\r\n * 停止调试服务器\r\n */\r\n stop(): void {\r\n if (this.transportMode === 'claw') {\r\n this.clientReady = false;\r\n return;\r\n }\r\n\r\n // 停止重连定时器\r\n if (this.reconnectTimer) {\r\n clearTimeout(this.reconnectTimer);\r\n this.reconnectTimer = undefined;\r\n }\r\n\r\n if (this.udsClient) {\r\n this.sendToWorker({ type: 'stop' });\r\n this.udsClient.end();\r\n this.udsClient = undefined;\r\n this.clientReady = false;\r\n }\r\n }\r\n\r\n /**\r\n * 手动重连(可选)\r\n * 如果已经连接,则不执行任何操作\r\n */\r\n async reconnect(): Promise<void> {\r\n if (this.transportMode === 'claw') {\r\n await this.start(this.workerPort ?? 2026, false);\r\n if (!this.clientReady) {\r\n throw new Error('Claw runtime reconnect failed');\r\n }\r\n return;\r\n }\r\n\r\n if (this.clientReady && this.udsClient) {\r\n console.log('[DebugHub] 已经连接,无需重连');\r\n return;\r\n }\r\n\r\n // 重置重连状态\r\n this.reconnectAttempts = 0;\r\n if (this.reconnectTimer) {\r\n clearTimeout(this.reconnectTimer);\r\n this.reconnectTimer = undefined;\r\n }\r\n\r\n try {\r\n await this.connectToWorker();\r\n console.log('[DebugHub] ✅ 手动重连成功');\r\n } catch (error) {\r\n console.error(`[DebugHub] 手动重连失败: ${(error as Error).message}`);\r\n throw error;\r\n }\r\n }\r\n\r\n /**\r\n * 注册 Agent\r\n * @param agent Agent 实例\r\n * @param name 显示名称(可选,默认使用类名)\r\n * @param featureTemplates Feature 模板路径映射(可选)\r\n * @returns 分配的 agentId\r\n */\r\n registerAgent(\r\n agent: Agent,\r\n name?: string,\r\n featureTemplates?: Record<string, string>,\r\n hookInspector?: HookInspectorSnapshot,\r\n overview?: AgentOverviewSnapshot\r\n ): string {\r\n // 等待注册锁\r\n while (this.registrationLock) {\r\n // 简单的忙等待(实际场景中竞争很少)\r\n }\r\n this.registrationLock = true;\r\n\r\n try {\r\n const id = `agent-${this.nextId++}-${this.processId}`;\r\n const info: AgentInfo = {\r\n id,\r\n name: name || agent.constructor.name,\r\n registeredAt: Date.now(),\r\n };\r\n\r\n this.agents.set(id, { info, agent });\r\n\r\n // 缓存 featureTemplates(用于重连后重新注册)\r\n if (featureTemplates) {\r\n this.agentFeatureTemplates.set(id, featureTemplates);\r\n }\r\n\r\n // 首个注册的 Agent 自动成为当前 Agent\r\n if (this.agents.size === 1) {\r\n this.currentAgentId = id;\r\n }\r\n\r\n // 通知 Worker\r\n if (this.transportMode === 'claw') {\r\n void this.clawClient?.registerAgent({\r\n agentId: id,\r\n name: info.name,\r\n projectRoot: process.cwd(),\r\n featureTemplates,\r\n hookInspector,\r\n overview,\r\n }).catch(error => {\r\n console.error(`[DebugHub] Claw registerAgent 失败: ${(error as Error).message}`);\r\n });\r\n } else {\r\n this.sendToWorker({\r\n type: 'register-agent',\r\n agentId: id,\r\n name: info.name,\r\n createdAt: info.registeredAt,\r\n projectRoot: process.cwd(), // 传递项目根目录,用于模板文件加载\r\n featureTemplates, // 传递 Feature 模板路径映射\r\n hookInspector,\r\n overview,\r\n });\r\n }\r\n\r\n console.log(`[DebugHub] Agent 已注册: ${id} (${info.name})`);\r\n return id;\r\n } finally {\r\n this.registrationLock = false;\r\n }\r\n }\r\n\r\n /**\r\n * 注销 Agent\r\n * @param agentId Agent ID\r\n */\r\n unregisterAgent(agentId: string): void {\r\n const deleted = this.agents.delete(agentId);\r\n if (deleted) {\r\n if (this.transportMode === 'claw') {\r\n void this.clawClient?.unregisterAgent(agentId).catch(error => {\r\n console.error(`[DebugHub] Claw unregisterAgent 失败: ${(error as Error).message}`);\r\n });\r\n } else {\r\n this.sendToWorker({ type: 'unregister-agent', agentId });\r\n }\r\n console.log(`[DebugHub] Agent 已注销: ${agentId}`);\r\n\r\n // 如果注销的是当前 Agent,切换到另一个\r\n if (this.currentAgentId === agentId) {\r\n const remaining = Array.from(this.agents.keys());\r\n this.currentAgentId = remaining.length > 0 ? remaining[0] : null;\r\n if (this.currentAgentId) {\r\n if (this.transportMode === 'claw') {\r\n void this.clawClient?.selectAgent(this.currentAgentId).catch(error => {\r\n console.error(`[DebugHub] Claw selectAgent 失败: ${(error as Error).message}`);\r\n });\r\n } else if (this.transportMode === 'viewer-worker') {\r\n this.sendToWorker({\r\n type: 'set-current-agent',\r\n agentId: this.currentAgentId,\r\n });\r\n }\r\n }\r\n }\r\n }\r\n }\r\n\r\n /**\r\n * 切换当前选中的 Agent\r\n * @param agentId Agent ID\r\n * @returns 是否成功\r\n */\r\n selectAgent(agentId: string): boolean {\r\n if (!this.agents.has(agentId)) {\r\n return false;\r\n }\r\n this.currentAgentId = agentId;\r\n if (this.transportMode === 'claw') {\r\n void this.clawClient?.selectAgent(agentId).catch(error => {\r\n console.error(`[DebugHub] Claw selectAgent 失败: ${(error as Error).message}`);\r\n });\r\n console.log(`[DebugHub] 当前 Agent 已切换: ${agentId}`);\r\n return true;\r\n }\r\n if (this.transportMode === 'viewer-worker') {\r\n this.sendToWorker({\r\n type: 'set-current-agent',\r\n agentId,\r\n });\r\n }\r\n console.log(`[DebugHub] 当前 Agent 已切换: ${agentId}`);\r\n return true;\r\n }\r\n\r\n /**\r\n * 推送 Agent 消息\r\n * @param agentId Agent ID\r\n * @param messages 消息数组\r\n */\r\n pushMessages(agentId: string, messages: Message[]): void {\r\n if (this.transportMode === 'claw') {\r\n void this.clawClient?.pushMessages(agentId, messages).catch(error => {\r\n console.error(`[DebugHub] Claw pushMessages 失败: ${(error as Error).message}`);\r\n });\r\n return;\r\n }\r\n\r\n this.sendToWorker({\r\n type: 'push-messages',\r\n agentId,\r\n messages,\r\n });\r\n }\r\n\r\n /**\r\n * 注册 Agent 工具\r\n * @param agentId Agent ID\r\n * @param tools 工具数组\r\n */\r\n registerAgentTools(agentId: string, tools: Tool[]): void {\r\n if (this.transportMode === 'claw') {\r\n void this.clawClient?.registerTools(agentId, tools).catch(error => {\r\n console.error(`[DebugHub] Claw registerTools 失败: ${(error as Error).message}`);\r\n });\r\n return;\r\n }\r\n\r\n this.sendToWorker({\r\n type: 'register-tools',\r\n agentId,\r\n tools,\r\n });\r\n }\r\n\r\n updateAgentInspector(agentId: string, hookInspector: HookInspectorSnapshot): void {\r\n if (this.transportMode === 'claw') {\r\n void this.clawClient?.updateInspector(agentId, hookInspector).catch(error => {\r\n console.error(`[DebugHub] Claw updateInspector 失败: ${(error as Error).message}`);\r\n });\r\n return;\r\n }\r\n\r\n this.sendToWorker({\r\n type: 'update-agent-inspector',\r\n agentId,\r\n hookInspector,\r\n });\r\n }\r\n\r\n updateAgentOverview(agentId: string, overview: AgentOverviewSnapshot): void {\r\n if (this.transportMode === 'claw') {\r\n void this.clawClient?.updateOverview(agentId, overview).catch(error => {\r\n console.error(`[DebugHub] Claw updateOverview 失败: ${(error as Error).message}`);\r\n });\r\n return;\r\n }\r\n\r\n this.sendToWorker({\r\n type: 'update-agent-overview',\r\n agentId,\r\n overview,\r\n });\r\n }\r\n\r\n /**\r\n * 获取所有已注册的 Agent 信息\r\n */\r\n getAgentList(): AgentInfo[] {\r\n return Array.from(this.agents.values()).map(v => v.info);\r\n }\r\n\r\n /**\r\n * 获取当前选中的 Agent ID\r\n */\r\n getCurrentAgentId(): string | null {\r\n return this.currentAgentId;\r\n }\r\n\r\n getTransportMode(): 'viewer-worker' | 'claw' {\r\n return this.transportMode;\r\n }\r\n\r\n getCapabilities(): DebugCapabilities {\r\n return getDebugCapabilities();\r\n }\r\n\r\n /**\r\n * 根据 Agent 实例获取其 ID\r\n */\r\n getAgentId(agent: Agent): string | undefined {\r\n for (const [id, data] of this.agents) {\r\n if (data.agent === agent) {\r\n return id;\r\n }\r\n }\r\n return undefined;\r\n }\r\n\r\n /**\r\n * 获取 Worker 端口\r\n */\r\n getPort(): number | null {\r\n return this.workerPort;\r\n }\r\n\r\n /**\r\n * 检查是否已连接到 ViewerWorker\r\n */\r\n isConnected(): boolean {\r\n if (this.transportMode === 'claw') {\r\n return this.clientReady;\r\n }\r\n return this.clientReady && !!this.udsClient;\r\n }\r\n\r\n /**\r\n * 推送通知\r\n * @param agentId Agent ID\r\n * @param notification 通知对象\r\n */\r\n pushNotification(agentId: string, notification: Notification): void {\r\n if (this.transportMode === 'claw') {\r\n void this.clawClient?.pushNotification(agentId, notification).catch(error => {\r\n console.error(`[DebugHub] Claw pushNotification 失败: ${(error as Error).message}`);\r\n });\r\n return;\r\n }\r\n\r\n this.sendToWorker({\r\n type: 'push-notification',\r\n agentId,\r\n notification,\r\n });\r\n }\r\n\r\n /**\r\n * 请求用户输入\r\n * @param agentId Agent ID\r\n * @param prompt 提示信息\r\n * @param timeout 超时时间(毫秒),默认 Infinity(无限等待)\r\n * @returns Promise<string> 用户输入内容\r\n */\r\n requestUserInput(agentId: string, prompt: string, timeout: number = Infinity): Promise<string> {\r\n return this.requestUserInputEvent(agentId, { prompt }, timeout).then((response) => {\r\n if (response.kind !== 'text') {\r\n throw new Error(`Expected text user input but received action '${response.actionId ?? 'unknown'}'`);\r\n }\r\n return response.text ?? '';\r\n });\r\n }\r\n\r\n requestUserInputEvent(\r\n agentId: string,\r\n request: UserInputRequest,\r\n timeout: number = Infinity,\r\n ): Promise<UserInputResponse> {\r\n if (this.transportMode === 'claw') {\r\n return this.clawClient?.requestUserInput(agentId, request, timeout)\r\n ?? Promise.reject(new Error('Claw client is not available'));\r\n }\r\n\r\n const requestId = `input-${agentId}-${Date.now()}-${Math.random().toString(36).slice(2)}`;\r\n\r\n return new Promise((resolve, reject) => {\r\n // 设置超时定时器(仅在 timeout 为有限数值时)\r\n let timer: NodeJS.Timeout | undefined;\r\n if (timeout !== Infinity) {\r\n timer = setTimeout(() => {\r\n this.pendingInputRequests.delete(requestId);\r\n this.activeInputRequests.delete(agentId); // 清除活跃请求记录\r\n reject(new Error(`User input timeout after ${timeout}ms`));\r\n }, timeout);\r\n }\r\n\r\n // 存储 resolve 函数\r\n this.pendingInputRequests.set(requestId, (response: UserInputResponse) => {\r\n if (timer) clearTimeout(timer);\r\n this.activeInputRequests.delete(agentId); // 清除活跃请求记录\r\n resolve(response);\r\n });\r\n\r\n // 记录活跃请求(用于重连恢复)\r\n this.activeInputRequests.set(agentId, {\r\n requestId,\r\n prompt: request.prompt,\r\n placeholder: request.placeholder,\r\n initialValue: request.initialValue,\r\n actions: request.actions,\r\n timestamp: Date.now(),\r\n });\r\n\r\n // 发送请求到 ViewerWorker\r\n this.sendToWorker({\r\n type: 'request-input',\r\n agentId,\r\n requestId,\r\n prompt: request.prompt,\r\n placeholder: request.placeholder,\r\n initialValue: request.initialValue,\r\n actions: request.actions,\r\n timeout,\r\n } as RequestInputMsg);\r\n });\r\n }\r\n\r\n // ========== 内部方法 ==========\r\n\r\n /**\r\n * 连接到 UDS 服务器\r\n */\r\n private async connectToWorker(): Promise<void> {\r\n return new Promise((resolve, reject) => {\r\n this.udsClient = connect(this.udsPath);\r\n\r\n this.udsClient.on('connect', () => {\r\n this.clientReady = true;\r\n this.reconnectAttempts = 0; // 重置重连计数\r\n console.log(`[DebugHub] 已连接到 ViewerWorker: ${this.udsPath}`);\r\n\r\n // 发送队列中的消息\r\n for (const msg of this.messageQueue) {\r\n this.sendViaUDS(msg);\r\n }\r\n this.messageQueue = [];\r\n\r\n // 关键:重新注册所有 Agent(用于重连后恢复状态)\r\n this.reregisterAllAgents();\r\n\r\n // 设置当前 Agent\r\n if (this.currentAgentId) {\r\n this.sendToWorker({\r\n type: 'set-current-agent',\r\n agentId: this.currentAgentId,\r\n });\r\n }\r\n\r\n resolve();\r\n });\r\n\r\n this.udsClient.on('data', (data: Buffer) => {\r\n const lines = data.toString().split('\\n');\r\n for (const line of lines) {\r\n if (!line.trim()) continue;\r\n try {\r\n const msg = JSON.parse(line);\r\n this.handleWorkerMessage(msg);\r\n } catch (err) {\r\n console.error('[DebugHub] Worker 消息解析失败:', err);\r\n }\r\n }\r\n });\r\n\r\n this.udsClient.on('error', (err: Error) => {\r\n reject(new Error(`连接 ViewerWorker 失败 (${this.udsPath}): ${err.message}\\n请先启动 ViewerWorker 服务器`));\r\n });\r\n\r\n this.udsClient.on('close', () => {\r\n this.clientReady = false;\r\n console.warn('[DebugHub] 与 ViewerWorker 的连接已断开');\r\n\r\n // 自动重连\r\n this.scheduleReconnect();\r\n });\r\n });\r\n }\r\n\r\n /**\r\n * 处理来自 Worker 的消息\r\n */\r\n private handleWorkerMessage(msg: any): void {\r\n switch (msg.type) {\r\n case 'agent-switched':\r\n console.log(`[DebugHub] 当前 Agent 已切换: ${msg.agentId}`);\r\n break;\r\n\r\n // 处理用户输入响应\r\n case 'input-response':\r\n const resolver = this.pendingInputRequests.get(msg.requestId);\r\n if (resolver) {\r\n resolver(msg.response ?? {\r\n kind: 'text',\r\n text: msg.input,\r\n });\r\n this.pendingInputRequests.delete(msg.requestId);\r\n } else {\r\n console.warn(`[DebugHub] 未知输入响应: ${msg.requestId}`);\r\n }\r\n break;\r\n }\r\n }\r\n\r\n /**\r\n * 重新注册所有 Agent(重连后调用)\r\n * 确保 ViewerWorker 能够恢复所有 Agent 的注册信息\r\n */\r\n private reregisterAllAgents(): void {\r\n if (this.transportMode === 'claw') {\r\n for (const [id, data] of this.agents) {\r\n const hookInspector = (data.agent as any).buildHookInspectorSnapshot?.()\r\n || (data.agent as any).hookInspector;\r\n const overview = (data.agent as any).buildOverviewSnapshot?.();\r\n const featureTemplates = this.agentFeatureTemplates.get(id) || {};\r\n\r\n void this.clawClient?.registerAgent({\r\n agentId: id,\r\n name: data.info.name,\r\n projectRoot: process.cwd(),\r\n featureTemplates,\r\n hookInspector,\r\n overview,\r\n }).then(async () => {\r\n const tools = (data.agent as any).tools;\r\n if (tools && typeof tools.getEntries === 'function') {\r\n const entries = tools.getEntries();\r\n const toolList = entries.map((e: any) => e.tool);\r\n if (toolList.length > 0) {\r\n await this.clawClient?.registerTools(id, toolList);\r\n }\r\n }\r\n\r\n const context = (data.agent as any).getContext?.();\r\n if (context && typeof context.getAll === 'function') {\r\n const messages = context.getAll();\r\n if (messages.length > 0) {\r\n await this.clawClient?.pushMessages(id, messages);\r\n }\r\n }\r\n }).catch(error => {\r\n console.error(`[DebugHub] Claw re-register 失败: ${(error as Error).message}`);\r\n });\r\n }\r\n return;\r\n }\r\n\r\n if (this.agents.size === 0) {\r\n return;\r\n }\r\n\r\n console.log(`[DebugHub] 重新注册 ${this.agents.size} 个 Agent...`);\r\n\r\n for (const [id, data] of this.agents) {\r\n // 获取最新的 hookInspector\r\n const hookInspector = (data.agent as any).buildHookInspectorSnapshot?.()\r\n || (data.agent as any).hookInspector;\r\n const overview = (data.agent as any).buildOverviewSnapshot?.();\r\n\r\n // 获取缓存的 featureTemplates\r\n const featureTemplates = this.agentFeatureTemplates.get(id) || {};\r\n\r\n // 获取活跃的输入请求(用于恢复输入框)\r\n const activeInputRequest = this.activeInputRequests.get(id);\r\n if (activeInputRequest) {\r\n console.log(`[DebugHub] 发现活跃输入请求: ${activeInputRequest.requestId}`);\r\n }\r\n\r\n this.sendToWorker({\r\n type: 'register-agent' as const,\r\n agentId: id,\r\n name: data.info.name,\r\n createdAt: data.info.registeredAt,\r\n projectRoot: process.cwd(),\r\n featureTemplates,\r\n hookInspector,\r\n overview,\r\n activeInputRequest, // 携带活跃输入请求\r\n });\r\n\r\n // 重新注册工具(如果有)\r\n const tools = (data.agent as any).tools;\r\n if (tools && typeof tools.getEntries === 'function') {\r\n const entries = tools.getEntries();\r\n const toolList = entries.map((e: any) => e.tool);\r\n if (toolList.length > 0) {\r\n this.sendToWorker({\r\n type: 'register-tools',\r\n agentId: id,\r\n tools: toolList,\r\n });\r\n }\r\n }\r\n\r\n // 重新发送对话记录(用于重连后恢复消息历史)\r\n const context = (data.agent as any).getContext?.();\r\n if (context && typeof context.getAll === 'function') {\r\n const messages = context.getAll();\r\n if (messages.length > 0) {\r\n this.sendToWorker({\r\n type: 'push-messages',\r\n agentId: id,\r\n messages,\r\n });\r\n console.log(`[DebugHub] 恢复 Agent ${id} 的 ${messages.length} 条消息`);\r\n }\r\n }\r\n }\r\n\r\n console.log(`[DebugHub] ✅ 重新注册完成`);\r\n }\r\n\r\n /**\r\n * 安排重连(指数退避)\r\n */\r\n private scheduleReconnect(): void {\r\n // 清除现有的定时器\r\n if (this.reconnectTimer) {\r\n clearTimeout(this.reconnectTimer);\r\n }\r\n\r\n // 检查是否达到最大重连次数\r\n if (this.reconnectAttempts >= this.MAX_RECONNECT_ATTEMPTS) {\r\n console.error(`[DebugHub] 达到最大重连次数 (${this.MAX_RECONNECT_ATTEMPTS}),停止重连`);\r\n return;\r\n }\r\n\r\n this.reconnectAttempts++;\r\n\r\n // 计算延迟时间(指数退避,最大 30 秒)\r\n const delay = Math.min(\r\n this.RECONNECT_DELAY * Math.pow(2, this.reconnectAttempts - 1),\r\n 30000\r\n );\r\n\r\n console.log(`[DebugHub] ${delay}ms 后尝试第 ${this.reconnectAttempts} 次重连...`);\r\n\r\n this.reconnectTimer = setTimeout(async () => {\r\n try {\r\n await this.connectToWorker();\r\n console.log('[DebugHub] ✅ 重连成功,调试功能已恢复');\r\n } catch (error) {\r\n console.error(`[DebugHub] 重连失败: ${(error as Error).message}`);\r\n // 继续尝试重连\r\n this.scheduleReconnect();\r\n }\r\n }, delay);\r\n }\r\n\r\n /**\r\n * 通过 UDS 发送消息\r\n */\r\n private sendViaUDS(msg: DebugHubIPCMessage): void {\r\n if (this.udsClient && this.clientReady) {\r\n this.udsClient.write(JSON.stringify(msg) + '\\n');\r\n }\r\n // 未连接时丢弃消息,不再队列(避免内存泄漏)\r\n }\r\n\r\n /**\r\n * 发送消息到 Worker\r\n */\r\n private sendToWorker(msg: DebugHubIPCMessage): void {\r\n if (!this.udsClient) {\r\n return;\r\n }\r\n this.sendViaUDS(msg);\r\n }\r\n}\r\n","import type {\n AgentOverviewSnapshot,\n HookInspectorSnapshot,\n Message,\n Notification,\n Tool,\n UserInputRequest,\n UserInputResponse,\n} from './types.js';\nimport { getClawRuntimeUrl } from './debug-transport.js';\n\ntype ClawEventKind =\n | 'message'\n | 'notification'\n | 'snapshot'\n | 'lifecycle'\n | 'tools'\n | 'input';\n\ninterface ClawSessionRegistration {\n sessionId: string;\n runtime: 'agentdev';\n agentName: string;\n projectRoot: string | null;\n metadata: Record<string, unknown>;\n state?: Record<string, unknown>;\n}\n\ninterface ClawEventInput {\n sessionId: string;\n kind: ClawEventKind;\n payload: Record<string, unknown>;\n}\n\nexport interface RegisterClawAgentInput {\n agentId: string;\n name: string;\n projectRoot?: string;\n featureTemplates?: Record<string, string>;\n hookInspector?: HookInspectorSnapshot;\n overview?: AgentOverviewSnapshot;\n}\n\nexport class ClawDebugClient {\n private readonly runtimeUrl: string;\n private readonly processId: string;\n private readonly projectRoot: string;\n private readonly sessionByAgentId = new Map<string, string>();\n private readonly pendingSessionByAgentId = new Map<string, Promise<string>>();\n\n constructor(options: { runtimeUrl?: string; processId?: string; projectRoot?: string } = {}) {\n this.runtimeUrl = (options.runtimeUrl ?? getClawRuntimeUrl()).replace(/\\/$/, '');\n this.processId = options.processId ?? String(process.pid);\n this.projectRoot = options.projectRoot ?? process.cwd();\n }\n\n async ping(): Promise<void> {\n await this.requestJson('/health');\n }\n\n async registerAgent(input: RegisterClawAgentInput): Promise<string> {\n const sessionId = `${this.processId}:${input.agentId}`;\n const existing = this.pendingSessionByAgentId.get(input.agentId);\n if (existing) {\n return existing;\n }\n\n const pending = (async () => {\n const registration: ClawSessionRegistration = {\n sessionId,\n runtime: 'agentdev',\n agentName: input.name,\n projectRoot: input.projectRoot ?? this.projectRoot,\n metadata: {\n adapter: 'agentdev-debug-hub',\n agentId: input.agentId,\n featureTemplates: input.featureTemplates ?? {},\n },\n state: {\n hookInspector: input.hookInspector ?? null,\n overview: input.overview ?? null,\n },\n };\n\n await this.requestJson('/api/sessions/register', {\n method: 'POST',\n body: JSON.stringify(registration),\n });\n\n this.sessionByAgentId.set(input.agentId, sessionId);\n\n await this.pushLifecycle(input.agentId, {\n phase: 'agent-registered',\n agentId: input.agentId,\n name: input.name,\n });\n\n return sessionId;\n })();\n\n this.pendingSessionByAgentId.set(input.agentId, pending);\n\n try {\n return await pending;\n } finally {\n this.pendingSessionByAgentId.delete(input.agentId);\n }\n }\n\n async unregisterAgent(agentId: string): Promise<void> {\n await this.pushLifecycle(agentId, {\n phase: 'agent-unregistered',\n agentId,\n });\n }\n\n async selectAgent(agentId: string): Promise<void> {\n const sessionId = await this.requireSessionId(agentId);\n await this.requestJson('/api/agents/current', {\n method: 'PUT',\n body: JSON.stringify({ agentId: sessionId }),\n });\n }\n\n async pushMessages(agentId: string, messages: Message[]): Promise<void> {\n await this.pushEvent(agentId, 'message', { messages });\n }\n\n async registerTools(agentId: string, tools: Tool[]): Promise<void> {\n await this.pushEvent(agentId, 'tools', { tools });\n }\n\n async updateInspector(agentId: string, hookInspector: HookInspectorSnapshot): Promise<void> {\n await this.pushEvent(agentId, 'snapshot', {\n scope: 'hookInspector',\n hookInspector,\n });\n }\n\n async updateOverview(agentId: string, overview: AgentOverviewSnapshot): Promise<void> {\n await this.pushEvent(agentId, 'snapshot', {\n scope: 'overview',\n overview,\n });\n }\n\n async pushNotification(agentId: string, notification: Notification): Promise<void> {\n await this.pushEvent(agentId, 'notification', { notification });\n }\n\n async requestUserInput(_agentId: string, request: UserInputRequest, timeout: number): Promise<UserInputResponse> {\n const agentId = _agentId;\n const requestId = `input-${agentId}-${Date.now()}-${Math.random().toString(36).slice(2)}`;\n await this.pushEvent(agentId, 'input', {\n requestId,\n request,\n timeout,\n status: 'pending',\n });\n\n const sessionId = await this.requireSessionId(agentId);\n const startedAt = Date.now();\n const pollIntervalMs = 400;\n\n while (true) {\n if (timeout !== Infinity && Date.now() - startedAt > timeout) {\n throw new Error(`User input timeout after ${timeout}ms`);\n }\n\n let response: Response;\n try {\n response = await fetch(\n `${this.runtimeUrl}/api/agents/${encodeURIComponent(sessionId)}/input-response?requestId=${encodeURIComponent(requestId)}`\n );\n } catch (error) {\n const message = error instanceof Error ? error.message : String(error);\n throw new Error(`Unable to reach Claw runtime at ${this.runtimeUrl} while waiting for user input: ${message}`);\n }\n\n if (response.ok) {\n const body = await response.json();\n return body.response;\n }\n\n if (response.status !== 404) {\n const text = await response.text();\n throw new Error(`Input bridge request failed: ${response.status} ${response.statusText} ${text}`);\n }\n\n await new Promise(resolve => setTimeout(resolve, pollIntervalMs));\n }\n }\n\n private async pushLifecycle(agentId: string, payload: Record<string, unknown>): Promise<void> {\n await this.pushEvent(agentId, 'lifecycle', payload);\n }\n\n private async pushEvent(agentId: string, kind: ClawEventKind, payload: Record<string, unknown>): Promise<void> {\n const sessionId = await this.requireSessionId(agentId);\n const event: ClawEventInput = {\n sessionId,\n kind,\n payload,\n };\n\n await this.requestJson('/api/events', {\n method: 'POST',\n body: JSON.stringify(event),\n });\n }\n\n private async requireSessionId(agentId: string): Promise<string> {\n const sessionId = this.sessionByAgentId.get(agentId);\n if (!sessionId) {\n const pending = this.pendingSessionByAgentId.get(agentId);\n if (pending) {\n return pending;\n }\n throw new Error(`No Claw session registered for agentId '${agentId}'`);\n }\n return sessionId;\n }\n\n private async requestJson(path: string, init?: RequestInit): Promise<any> {\n let response: Response;\n try {\n response = await fetch(`${this.runtimeUrl}${path}`, {\n ...init,\n headers: {\n 'content-type': 'application/json',\n ...(init?.headers ?? {}),\n },\n });\n } catch (error) {\n const message = error instanceof Error ? error.message : String(error);\n throw new Error(`Unable to reach Claw runtime at ${this.runtimeUrl}: ${message}`);\n }\n\n if (!response.ok) {\n const body = await response.text();\n throw new Error(`Claw runtime request failed: ${response.status} ${response.statusText} ${body}`);\n }\n\n if (response.status === 204) {\n return null;\n }\n\n return response.json();\n }\n}\n"],"mappings":"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","names":[]}
|