@onesclawkolor/onesclaw 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +65 -0
- package/dist/agent/conversation.d.ts +34 -0
- package/dist/agent/conversation.js +61 -0
- package/dist/agent/conversation.js.map +1 -0
- package/dist/agent/loop.d.ts +40 -0
- package/dist/agent/loop.js +213 -0
- package/dist/agent/loop.js.map +1 -0
- package/dist/agent/session.d.ts +73 -0
- package/dist/agent/session.js +225 -0
- package/dist/agent/session.js.map +1 -0
- package/dist/audit/file-sink.d.ts +6 -0
- package/dist/audit/file-sink.js +21 -0
- package/dist/audit/file-sink.js.map +1 -0
- package/dist/audit/ids.d.ts +3 -0
- package/dist/audit/ids.js +15 -0
- package/dist/audit/ids.js.map +1 -0
- package/dist/audit/types.d.ts +13 -0
- package/dist/audit/types.js +2 -0
- package/dist/audit/types.js.map +1 -0
- package/dist/cli/commands.d.ts +31 -0
- package/dist/cli/commands.js +433 -0
- package/dist/cli/commands.js.map +1 -0
- package/dist/cli/logger.d.ts +57 -0
- package/dist/cli/logger.js +79 -0
- package/dist/cli/logger.js.map +1 -0
- package/dist/cli/output.d.ts +59 -0
- package/dist/cli/output.js +306 -0
- package/dist/cli/output.js.map +1 -0
- package/dist/cli/prompt.d.ts +29 -0
- package/dist/cli/prompt.js +197 -0
- package/dist/cli/prompt.js.map +1 -0
- package/dist/cli/repl.d.ts +4 -0
- package/dist/cli/repl.js +486 -0
- package/dist/cli/repl.js.map +1 -0
- package/dist/commands/init.d.ts +4 -0
- package/dist/commands/init.js +84 -0
- package/dist/commands/init.js.map +1 -0
- package/dist/commands/model.d.ts +3 -0
- package/dist/commands/model.js +178 -0
- package/dist/commands/model.js.map +1 -0
- package/dist/commands/plugin-init.d.ts +23 -0
- package/dist/commands/plugin-init.js +303 -0
- package/dist/commands/plugin-init.js.map +1 -0
- package/dist/commands/provider-auth.d.ts +14 -0
- package/dist/commands/provider-auth.js +153 -0
- package/dist/commands/provider-auth.js.map +1 -0
- package/dist/config/manager.d.ts +71 -0
- package/dist/config/manager.js +201 -0
- package/dist/config/manager.js.map +1 -0
- package/dist/config/types.d.ts +43 -0
- package/dist/config/types.js +2 -0
- package/dist/config/types.js.map +1 -0
- package/dist/errors.d.ts +37 -0
- package/dist/errors.js +55 -0
- package/dist/errors.js.map +1 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.js +207 -0
- package/dist/index.js.map +1 -0
- package/dist/llm/anthropic.d.ts +83 -0
- package/dist/llm/anthropic.js +190 -0
- package/dist/llm/anthropic.js.map +1 -0
- package/dist/llm/factory.d.ts +105 -0
- package/dist/llm/factory.js +164 -0
- package/dist/llm/factory.js.map +1 -0
- package/dist/llm/openai-codex.d.ts +102 -0
- package/dist/llm/openai-codex.js +445 -0
- package/dist/llm/openai-codex.js.map +1 -0
- package/dist/llm/openai.d.ts +71 -0
- package/dist/llm/openai.js +289 -0
- package/dist/llm/openai.js.map +1 -0
- package/dist/llm/provider.d.ts +1 -0
- package/dist/llm/provider.js +2 -0
- package/dist/llm/provider.js.map +1 -0
- package/dist/llm/types.d.ts +72 -0
- package/dist/llm/types.js +2 -0
- package/dist/llm/types.js.map +1 -0
- package/dist/mcp/bridge.d.ts +17 -0
- package/dist/mcp/bridge.js +74 -0
- package/dist/mcp/bridge.js.map +1 -0
- package/dist/mcp/config.d.ts +10 -0
- package/dist/mcp/config.js +27 -0
- package/dist/mcp/config.js.map +1 -0
- package/dist/mcp/manager.d.ts +67 -0
- package/dist/mcp/manager.js +207 -0
- package/dist/mcp/manager.js.map +1 -0
- package/dist/memory/scope.d.ts +4 -0
- package/dist/memory/scope.js +14 -0
- package/dist/memory/scope.js.map +1 -0
- package/dist/memory/store.d.ts +28 -0
- package/dist/memory/store.js +126 -0
- package/dist/memory/store.js.map +1 -0
- package/dist/prompts/system.d.ts +4 -0
- package/dist/prompts/system.js +197 -0
- package/dist/prompts/system.js.map +1 -0
- package/dist/skills/loader.d.ts +25 -0
- package/dist/skills/loader.js +98 -0
- package/dist/skills/loader.js.map +1 -0
- package/dist/skills/registry.d.ts +57 -0
- package/dist/skills/registry.js +132 -0
- package/dist/skills/registry.js.map +1 -0
- package/dist/skills/sync.d.ts +33 -0
- package/dist/skills/sync.js +180 -0
- package/dist/skills/sync.js.map +1 -0
- package/dist/skills/types.d.ts +1 -0
- package/dist/skills/types.js +2 -0
- package/dist/skills/types.js.map +1 -0
- package/dist/tools/ask.d.ts +30 -0
- package/dist/tools/ask.js +60 -0
- package/dist/tools/ask.js.map +1 -0
- package/dist/tools/confirmation.d.ts +12 -0
- package/dist/tools/confirmation.js +75 -0
- package/dist/tools/confirmation.js.map +1 -0
- package/dist/tools/plugin-init.d.ts +29 -0
- package/dist/tools/plugin-init.js +47 -0
- package/dist/tools/plugin-init.js.map +1 -0
- package/dist/tools/registry.d.ts +56 -0
- package/dist/tools/registry.js +123 -0
- package/dist/tools/registry.js.map +1 -0
- package/dist/tools/safety.d.ts +2 -0
- package/dist/tools/safety.js +30 -0
- package/dist/tools/safety.js.map +1 -0
- package/dist/tools/server.d.ts +91 -0
- package/dist/tools/server.js +149 -0
- package/dist/tools/server.js.map +1 -0
- package/dist/tools/shell.d.ts +11 -0
- package/dist/tools/shell.js +174 -0
- package/dist/tools/shell.js.map +1 -0
- package/dist/tools/skills-sync.d.ts +19 -0
- package/dist/tools/skills-sync.js +29 -0
- package/dist/tools/skills-sync.js.map +1 -0
- package/dist/tools/ssh.d.ts +62 -0
- package/dist/tools/ssh.js +343 -0
- package/dist/tools/ssh.js.map +1 -0
- package/dist/tools/types.d.ts +10 -0
- package/dist/tools/types.js +2 -0
- package/dist/tools/types.js.map +1 -0
- package/dist/utils/retry.d.ts +7 -0
- package/dist/utils/retry.js +34 -0
- package/dist/utils/retry.js.map +1 -0
- package/install.sh +171 -0
- package/package.json +49 -0
|
@@ -0,0 +1,225 @@
|
|
|
1
|
+
import { logger } from '../cli/logger.js';
|
|
2
|
+
const MAX_RECENT_DECISIONS = 20;
|
|
3
|
+
function parseRecentDecisions(raw) {
|
|
4
|
+
if (!raw) {
|
|
5
|
+
return [];
|
|
6
|
+
}
|
|
7
|
+
try {
|
|
8
|
+
const parsed = JSON.parse(raw);
|
|
9
|
+
if (!Array.isArray(parsed)) {
|
|
10
|
+
return [];
|
|
11
|
+
}
|
|
12
|
+
return parsed
|
|
13
|
+
.filter((item) => typeof item === 'string' && item.trim().length > 0)
|
|
14
|
+
.slice(-MAX_RECENT_DECISIONS);
|
|
15
|
+
}
|
|
16
|
+
catch {
|
|
17
|
+
return [];
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
/**
|
|
21
|
+
* 会话级别状态管理。
|
|
22
|
+
*
|
|
23
|
+
* 在同一会话内记忆上下文信息(SSH 连接、Skill 执行状态等),
|
|
24
|
+
* 并将关键状态持久化到 SQLite,跨重启可恢复。
|
|
25
|
+
*/
|
|
26
|
+
export class SessionState {
|
|
27
|
+
/** 用户身份(不可变,来自 MCP who_am_i) */
|
|
28
|
+
user;
|
|
29
|
+
/** 预配置的 SSH 服务器列表 */
|
|
30
|
+
servers;
|
|
31
|
+
/** 持久化存储 */
|
|
32
|
+
memoryStore;
|
|
33
|
+
scopeKey;
|
|
34
|
+
/** 匹配到服务器名称时注入的 prompt 段落 */
|
|
35
|
+
sshServersHint = null;
|
|
36
|
+
/** 最近使用的 SSH host */
|
|
37
|
+
currentHost = null;
|
|
38
|
+
/** 当前活跃的 SSH 连接 */
|
|
39
|
+
activeConnections = new Set();
|
|
40
|
+
/** 当前正在执行的 Skill name */
|
|
41
|
+
activeSkill = null;
|
|
42
|
+
/** 当前 Skill 执行阶段 */
|
|
43
|
+
skillPhase = null;
|
|
44
|
+
/** 最近确认/偏好 */
|
|
45
|
+
recentDecisions = [];
|
|
46
|
+
/** 对话轮数 */
|
|
47
|
+
conversationTurns = 0;
|
|
48
|
+
/** 最后活动时间 */
|
|
49
|
+
lastActivity = new Date();
|
|
50
|
+
constructor(user, servers = [], options = {}) {
|
|
51
|
+
this.user = user;
|
|
52
|
+
this.servers = servers;
|
|
53
|
+
this.memoryStore = options.memoryStore || null;
|
|
54
|
+
this.scopeKey = options.scopeKey || null;
|
|
55
|
+
}
|
|
56
|
+
static async create(options) {
|
|
57
|
+
const session = new SessionState(options.user || null, options.servers || [], {
|
|
58
|
+
memoryStore: options.memoryStore || null,
|
|
59
|
+
scopeKey: options.scopeKey || null,
|
|
60
|
+
});
|
|
61
|
+
await session.hydrateFromMemory();
|
|
62
|
+
return session;
|
|
63
|
+
}
|
|
64
|
+
async hydrateFromMemory() {
|
|
65
|
+
if (!this.memoryStore || !this.scopeKey) {
|
|
66
|
+
return;
|
|
67
|
+
}
|
|
68
|
+
try {
|
|
69
|
+
const memory = await this.memoryStore.get(this.scopeKey);
|
|
70
|
+
if (!memory) {
|
|
71
|
+
return;
|
|
72
|
+
}
|
|
73
|
+
this.currentHost = memory.last_host;
|
|
74
|
+
this.activeSkill = memory.active_skill;
|
|
75
|
+
this.skillPhase = memory.skill_phase;
|
|
76
|
+
this.recentDecisions = parseRecentDecisions(memory.recent_decisions_json);
|
|
77
|
+
if (this.currentHost) {
|
|
78
|
+
this.activeConnections.add(this.currentHost);
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
catch (error) {
|
|
82
|
+
logger.error('memory', `加载记忆失败: ${error instanceof Error ? error.message : String(error)}`);
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
persistToMemory() {
|
|
86
|
+
if (!this.memoryStore || !this.scopeKey) {
|
|
87
|
+
return;
|
|
88
|
+
}
|
|
89
|
+
const payload = {
|
|
90
|
+
lastHost: this.currentHost,
|
|
91
|
+
activeSkill: this.activeSkill,
|
|
92
|
+
skillPhase: this.skillPhase,
|
|
93
|
+
recentDecisionsJson: JSON.stringify(this.recentDecisions.slice(-MAX_RECENT_DECISIONS)),
|
|
94
|
+
};
|
|
95
|
+
void this.memoryStore.upsert(this.scopeKey, payload).catch((error) => {
|
|
96
|
+
logger.error('memory', `写入记忆失败: ${error instanceof Error ? error.message : String(error)}`);
|
|
97
|
+
});
|
|
98
|
+
}
|
|
99
|
+
/**
|
|
100
|
+
* 每轮用户输入时调用
|
|
101
|
+
*/
|
|
102
|
+
incrementTurn() {
|
|
103
|
+
this.conversationTurns++;
|
|
104
|
+
this.lastActivity = new Date();
|
|
105
|
+
}
|
|
106
|
+
/** SSH 相关关键词,匹配到任一即注入服务器列表 */
|
|
107
|
+
static SSH_KEYWORDS = ['连接', '服务器', 'ssh', '远程', '登录'];
|
|
108
|
+
/**
|
|
109
|
+
* 检查用户输入是否涉及 SSH 操作
|
|
110
|
+
* 匹配服务器名称或 SSH 关键词时,注入服务器列表到 system prompt
|
|
111
|
+
*/
|
|
112
|
+
checkUserInput(input) {
|
|
113
|
+
if (this.servers.length === 0)
|
|
114
|
+
return;
|
|
115
|
+
const lowerInput = input.toLowerCase();
|
|
116
|
+
const matchedByName = this.servers.some((s) => lowerInput.includes(s.name.toLowerCase()));
|
|
117
|
+
const matchedByKeyword = SessionState.SSH_KEYWORDS.some((kw) => lowerInput.includes(kw));
|
|
118
|
+
if (matchedByName || matchedByKeyword) {
|
|
119
|
+
const rows = this.servers.map((s) => `| ${s.name} | ${s.host} | ${s.description || '-'} |`);
|
|
120
|
+
this.sshServersHint = [
|
|
121
|
+
'## 可用 SSH 服务器',
|
|
122
|
+
'',
|
|
123
|
+
'当用户提到连接服务器或在服务器上执行命令时,使用 ssh_execute 工具,将 host 参数设置为下表中的服务器名称(必须精确匹配)。',
|
|
124
|
+
'',
|
|
125
|
+
'| 名称 | 地址 | 说明 |',
|
|
126
|
+
'|------|------|------|',
|
|
127
|
+
...rows,
|
|
128
|
+
].join('\n');
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
pushDecision(text) {
|
|
132
|
+
if (!text || !text.trim()) {
|
|
133
|
+
return;
|
|
134
|
+
}
|
|
135
|
+
const normalized = text.trim().slice(0, 200);
|
|
136
|
+
this.recentDecisions.push(normalized);
|
|
137
|
+
this.recentDecisions = this.recentDecisions.slice(-MAX_RECENT_DECISIONS);
|
|
138
|
+
}
|
|
139
|
+
/**
|
|
140
|
+
* 观察工具执行结果,自动更新会话状态。
|
|
141
|
+
*/
|
|
142
|
+
observe(toolName, args, result) {
|
|
143
|
+
this.lastActivity = new Date();
|
|
144
|
+
// SSH host 记忆:成功执行 ssh_execute 后记录 host
|
|
145
|
+
if (toolName === 'ssh_execute' && !result.isError) {
|
|
146
|
+
const host = args.host;
|
|
147
|
+
if (host) {
|
|
148
|
+
this.currentHost = host;
|
|
149
|
+
this.activeConnections.add(host);
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
// Skill 加载追踪:load_skill 成功后记录 skill 名称
|
|
153
|
+
if (toolName === 'load_skill' && !result.isError) {
|
|
154
|
+
const skillName = args.name;
|
|
155
|
+
if (skillName) {
|
|
156
|
+
this.activeSkill = skillName;
|
|
157
|
+
this.skillPhase = 'loaded';
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
// ask_user 的结果记为用户决策摘要
|
|
161
|
+
if (toolName === 'ask_user' && !result.isError) {
|
|
162
|
+
const answer = typeof result.content === 'string' ? result.content.trim() : '';
|
|
163
|
+
if (answer) {
|
|
164
|
+
this.pushDecision(`用户确认: ${answer}`);
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
// 高危命令确认痕迹
|
|
168
|
+
if ((toolName === 'execute_command' || toolName === 'ssh_execute') && args.confirmed === true) {
|
|
169
|
+
const command = typeof args.command === 'string' ? args.command.trim() : '';
|
|
170
|
+
if (command) {
|
|
171
|
+
this.pushDecision(`高危命令已确认: ${command.slice(0, 140)}`);
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
this.persistToMemory();
|
|
175
|
+
}
|
|
176
|
+
/**
|
|
177
|
+
* /clear 时清理会话上下文,并删除当前 scope 的持久化记忆。
|
|
178
|
+
*/
|
|
179
|
+
clearConversation() {
|
|
180
|
+
this.currentHost = null;
|
|
181
|
+
this.activeConnections.clear();
|
|
182
|
+
this.activeSkill = null;
|
|
183
|
+
this.skillPhase = null;
|
|
184
|
+
this.recentDecisions = [];
|
|
185
|
+
this.conversationTurns = 0;
|
|
186
|
+
if (this.memoryStore && this.scopeKey) {
|
|
187
|
+
void this.memoryStore.clear(this.scopeKey).catch((error) => {
|
|
188
|
+
logger.error('memory', `清理记忆失败: ${error instanceof Error ? error.message : String(error)}`);
|
|
189
|
+
});
|
|
190
|
+
}
|
|
191
|
+
}
|
|
192
|
+
/**
|
|
193
|
+
* 生成 system prompt 注入段落。
|
|
194
|
+
*/
|
|
195
|
+
toPromptSection() {
|
|
196
|
+
const lines = [];
|
|
197
|
+
if (this.currentHost) {
|
|
198
|
+
lines.push(`当前 SSH 主机:${this.currentHost}`);
|
|
199
|
+
if (this.activeConnections.size > 1) {
|
|
200
|
+
const hosts = Array.from(this.activeConnections).join(', ');
|
|
201
|
+
lines.push(`活跃连接:${hosts}`);
|
|
202
|
+
}
|
|
203
|
+
lines.push('用户后续的 SSH 命令如果没有指定 host,应默认使用当前主机。');
|
|
204
|
+
}
|
|
205
|
+
if (this.activeSkill) {
|
|
206
|
+
lines.push(`当前正在执行 Skill:${this.activeSkill}`);
|
|
207
|
+
if (this.skillPhase) {
|
|
208
|
+
lines.push(`执行阶段:${this.skillPhase}`);
|
|
209
|
+
}
|
|
210
|
+
}
|
|
211
|
+
if (this.recentDecisions.length > 0) {
|
|
212
|
+
lines.push('最近确认/偏好:');
|
|
213
|
+
for (const decision of this.recentDecisions.slice(-5)) {
|
|
214
|
+
lines.push(`- ${decision}`);
|
|
215
|
+
}
|
|
216
|
+
}
|
|
217
|
+
if (this.sshServersHint) {
|
|
218
|
+
lines.push(this.sshServersHint);
|
|
219
|
+
}
|
|
220
|
+
if (lines.length === 0)
|
|
221
|
+
return '';
|
|
222
|
+
return '## 当前会话上下文\n\n' + lines.join('\n');
|
|
223
|
+
}
|
|
224
|
+
}
|
|
225
|
+
//# sourceMappingURL=session.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"session.js","sourceRoot":"","sources":["../../src/agent/session.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
// @ts-nocheck
|
|
2
|
+
import { appendFileSync, mkdirSync } from 'node:fs';
|
|
3
|
+
import { join } from 'node:path';
|
|
4
|
+
export class FileAuditSink {
|
|
5
|
+
logDir;
|
|
6
|
+
constructor(logDir) {
|
|
7
|
+
this.logDir = logDir;
|
|
8
|
+
}
|
|
9
|
+
write(entry) {
|
|
10
|
+
try {
|
|
11
|
+
mkdirSync(this.logDir, { recursive: true });
|
|
12
|
+
const date = entry.time.slice(0, 10);
|
|
13
|
+
const logPath = join(this.logDir, `${date}.log`);
|
|
14
|
+
appendFileSync(logPath, JSON.stringify(entry) + '\n', 'utf-8');
|
|
15
|
+
}
|
|
16
|
+
catch {
|
|
17
|
+
// 审计写入失败不阻塞主流程
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=file-sink.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"file-sink.js","sourceRoot":"","sources":["../../src/audit/file-sink.ts"],"names":[],"mappings":"AAAA,cAAc;AACd,OAAO,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AACpD,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAGjC,MAAM,OAAO,aAAa;IAChB,MAAM,CAAS;IAEvB,YAAY,MAAc;QACxB,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;IACvB,CAAC;IAED,KAAK,CAAC,KAAiB;QACrB,IAAI,CAAC;YACH,SAAS,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;YAC5C,MAAM,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;YACrC,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,IAAI,MAAM,CAAC,CAAC;YACjD,cAAc,CAAC,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,GAAG,IAAI,EAAE,OAAO,CAAC,CAAC;QACjE,CAAC;QAAC,MAAM,CAAC;YACP,eAAe;QACjB,CAAC;IACH,CAAC;CACF"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
// @ts-nocheck
|
|
2
|
+
import { randomUUID } from 'node:crypto';
|
|
3
|
+
const SESSION_ID = `sess_${randomUUID()}`;
|
|
4
|
+
let commandSeq = 0;
|
|
5
|
+
export function getSessionId() {
|
|
6
|
+
return SESSION_ID;
|
|
7
|
+
}
|
|
8
|
+
export function nextCommandId(prefix = 'cmd') {
|
|
9
|
+
commandSeq += 1;
|
|
10
|
+
return `${prefix}_${String(commandSeq).padStart(6, '0')}`;
|
|
11
|
+
}
|
|
12
|
+
export function nextTraceId() {
|
|
13
|
+
return `trace_${randomUUID()}`;
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=ids.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ids.js","sourceRoot":"","sources":["../../src/audit/ids.ts"],"names":[],"mappings":"AAAA,cAAc;AACd,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAEzC,MAAM,UAAU,GAAG,QAAQ,UAAU,EAAE,EAAE,CAAC;AAC1C,IAAI,UAAU,GAAG,CAAC,CAAC;AAEnB,MAAM,UAAU,YAAY;IAC1B,OAAO,UAAU,CAAC;AACpB,CAAC;AAED,MAAM,UAAU,aAAa,CAAC,MAAM,GAAG,KAAK;IAC1C,UAAU,IAAI,CAAC,CAAC;IAChB,OAAO,GAAG,MAAM,IAAI,MAAM,CAAC,UAAU,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC;AAC5D,CAAC;AAED,MAAM,UAAU,WAAW;IACzB,OAAO,SAAS,UAAU,EAAE,EAAE,CAAC;AACjC,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export interface AuditEntry {
|
|
2
|
+
time: string;
|
|
3
|
+
level: 'debug' | 'info' | 'error';
|
|
4
|
+
category: string;
|
|
5
|
+
message: string;
|
|
6
|
+
session_id?: string;
|
|
7
|
+
trace_id?: string;
|
|
8
|
+
command_id?: string;
|
|
9
|
+
data?: unknown;
|
|
10
|
+
}
|
|
11
|
+
export interface AuditSink {
|
|
12
|
+
write(entry: AuditEntry): void;
|
|
13
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/audit/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
export declare const COMMAND_TREE: ({
|
|
2
|
+
name: string;
|
|
3
|
+
description: string;
|
|
4
|
+
subCommands: {
|
|
5
|
+
name: string;
|
|
6
|
+
description: string;
|
|
7
|
+
}[];
|
|
8
|
+
} | {
|
|
9
|
+
name: string;
|
|
10
|
+
description: string;
|
|
11
|
+
subCommands?: undefined;
|
|
12
|
+
})[];
|
|
13
|
+
/**
|
|
14
|
+
* 根据当前输入计算候选列表
|
|
15
|
+
* @param input 当前输入(含 /),保留尾部空格用于触发子命令候选
|
|
16
|
+
*/
|
|
17
|
+
export declare function getCommandCandidates(input: any): {
|
|
18
|
+
text: string;
|
|
19
|
+
description: string;
|
|
20
|
+
}[];
|
|
21
|
+
/**
|
|
22
|
+
* 判断输入是否为斜杠命令
|
|
23
|
+
* 仅当 "/" 后的第一个词匹配已知命令名时才返回 true,
|
|
24
|
+
* 避免将文件路径(如 /tmp/...)误判为斜杠命令。
|
|
25
|
+
*/
|
|
26
|
+
export declare function isSlashCommand(input: any): boolean;
|
|
27
|
+
/**
|
|
28
|
+
* 处理斜杠命令
|
|
29
|
+
* @returns false 表示应退出 REPL 循环
|
|
30
|
+
*/
|
|
31
|
+
export declare function handleSlashCommand(input: any, context: any): Promise<boolean>;
|