@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.
Files changed (141) hide show
  1. package/README.md +65 -0
  2. package/dist/agent/conversation.d.ts +34 -0
  3. package/dist/agent/conversation.js +61 -0
  4. package/dist/agent/conversation.js.map +1 -0
  5. package/dist/agent/loop.d.ts +40 -0
  6. package/dist/agent/loop.js +213 -0
  7. package/dist/agent/loop.js.map +1 -0
  8. package/dist/agent/session.d.ts +73 -0
  9. package/dist/agent/session.js +225 -0
  10. package/dist/agent/session.js.map +1 -0
  11. package/dist/audit/file-sink.d.ts +6 -0
  12. package/dist/audit/file-sink.js +21 -0
  13. package/dist/audit/file-sink.js.map +1 -0
  14. package/dist/audit/ids.d.ts +3 -0
  15. package/dist/audit/ids.js +15 -0
  16. package/dist/audit/ids.js.map +1 -0
  17. package/dist/audit/types.d.ts +13 -0
  18. package/dist/audit/types.js +2 -0
  19. package/dist/audit/types.js.map +1 -0
  20. package/dist/cli/commands.d.ts +31 -0
  21. package/dist/cli/commands.js +433 -0
  22. package/dist/cli/commands.js.map +1 -0
  23. package/dist/cli/logger.d.ts +57 -0
  24. package/dist/cli/logger.js +79 -0
  25. package/dist/cli/logger.js.map +1 -0
  26. package/dist/cli/output.d.ts +59 -0
  27. package/dist/cli/output.js +306 -0
  28. package/dist/cli/output.js.map +1 -0
  29. package/dist/cli/prompt.d.ts +29 -0
  30. package/dist/cli/prompt.js +197 -0
  31. package/dist/cli/prompt.js.map +1 -0
  32. package/dist/cli/repl.d.ts +4 -0
  33. package/dist/cli/repl.js +486 -0
  34. package/dist/cli/repl.js.map +1 -0
  35. package/dist/commands/init.d.ts +4 -0
  36. package/dist/commands/init.js +84 -0
  37. package/dist/commands/init.js.map +1 -0
  38. package/dist/commands/model.d.ts +3 -0
  39. package/dist/commands/model.js +178 -0
  40. package/dist/commands/model.js.map +1 -0
  41. package/dist/commands/plugin-init.d.ts +23 -0
  42. package/dist/commands/plugin-init.js +303 -0
  43. package/dist/commands/plugin-init.js.map +1 -0
  44. package/dist/commands/provider-auth.d.ts +14 -0
  45. package/dist/commands/provider-auth.js +153 -0
  46. package/dist/commands/provider-auth.js.map +1 -0
  47. package/dist/config/manager.d.ts +71 -0
  48. package/dist/config/manager.js +201 -0
  49. package/dist/config/manager.js.map +1 -0
  50. package/dist/config/types.d.ts +43 -0
  51. package/dist/config/types.js +2 -0
  52. package/dist/config/types.js.map +1 -0
  53. package/dist/errors.d.ts +37 -0
  54. package/dist/errors.js +55 -0
  55. package/dist/errors.js.map +1 -0
  56. package/dist/index.d.ts +2 -0
  57. package/dist/index.js +207 -0
  58. package/dist/index.js.map +1 -0
  59. package/dist/llm/anthropic.d.ts +83 -0
  60. package/dist/llm/anthropic.js +190 -0
  61. package/dist/llm/anthropic.js.map +1 -0
  62. package/dist/llm/factory.d.ts +105 -0
  63. package/dist/llm/factory.js +164 -0
  64. package/dist/llm/factory.js.map +1 -0
  65. package/dist/llm/openai-codex.d.ts +102 -0
  66. package/dist/llm/openai-codex.js +445 -0
  67. package/dist/llm/openai-codex.js.map +1 -0
  68. package/dist/llm/openai.d.ts +71 -0
  69. package/dist/llm/openai.js +289 -0
  70. package/dist/llm/openai.js.map +1 -0
  71. package/dist/llm/provider.d.ts +1 -0
  72. package/dist/llm/provider.js +2 -0
  73. package/dist/llm/provider.js.map +1 -0
  74. package/dist/llm/types.d.ts +72 -0
  75. package/dist/llm/types.js +2 -0
  76. package/dist/llm/types.js.map +1 -0
  77. package/dist/mcp/bridge.d.ts +17 -0
  78. package/dist/mcp/bridge.js +74 -0
  79. package/dist/mcp/bridge.js.map +1 -0
  80. package/dist/mcp/config.d.ts +10 -0
  81. package/dist/mcp/config.js +27 -0
  82. package/dist/mcp/config.js.map +1 -0
  83. package/dist/mcp/manager.d.ts +67 -0
  84. package/dist/mcp/manager.js +207 -0
  85. package/dist/mcp/manager.js.map +1 -0
  86. package/dist/memory/scope.d.ts +4 -0
  87. package/dist/memory/scope.js +14 -0
  88. package/dist/memory/scope.js.map +1 -0
  89. package/dist/memory/store.d.ts +28 -0
  90. package/dist/memory/store.js +126 -0
  91. package/dist/memory/store.js.map +1 -0
  92. package/dist/prompts/system.d.ts +4 -0
  93. package/dist/prompts/system.js +197 -0
  94. package/dist/prompts/system.js.map +1 -0
  95. package/dist/skills/loader.d.ts +25 -0
  96. package/dist/skills/loader.js +98 -0
  97. package/dist/skills/loader.js.map +1 -0
  98. package/dist/skills/registry.d.ts +57 -0
  99. package/dist/skills/registry.js +132 -0
  100. package/dist/skills/registry.js.map +1 -0
  101. package/dist/skills/sync.d.ts +33 -0
  102. package/dist/skills/sync.js +180 -0
  103. package/dist/skills/sync.js.map +1 -0
  104. package/dist/skills/types.d.ts +1 -0
  105. package/dist/skills/types.js +2 -0
  106. package/dist/skills/types.js.map +1 -0
  107. package/dist/tools/ask.d.ts +30 -0
  108. package/dist/tools/ask.js +60 -0
  109. package/dist/tools/ask.js.map +1 -0
  110. package/dist/tools/confirmation.d.ts +12 -0
  111. package/dist/tools/confirmation.js +75 -0
  112. package/dist/tools/confirmation.js.map +1 -0
  113. package/dist/tools/plugin-init.d.ts +29 -0
  114. package/dist/tools/plugin-init.js +47 -0
  115. package/dist/tools/plugin-init.js.map +1 -0
  116. package/dist/tools/registry.d.ts +56 -0
  117. package/dist/tools/registry.js +123 -0
  118. package/dist/tools/registry.js.map +1 -0
  119. package/dist/tools/safety.d.ts +2 -0
  120. package/dist/tools/safety.js +30 -0
  121. package/dist/tools/safety.js.map +1 -0
  122. package/dist/tools/server.d.ts +91 -0
  123. package/dist/tools/server.js +149 -0
  124. package/dist/tools/server.js.map +1 -0
  125. package/dist/tools/shell.d.ts +11 -0
  126. package/dist/tools/shell.js +174 -0
  127. package/dist/tools/shell.js.map +1 -0
  128. package/dist/tools/skills-sync.d.ts +19 -0
  129. package/dist/tools/skills-sync.js +29 -0
  130. package/dist/tools/skills-sync.js.map +1 -0
  131. package/dist/tools/ssh.d.ts +62 -0
  132. package/dist/tools/ssh.js +343 -0
  133. package/dist/tools/ssh.js.map +1 -0
  134. package/dist/tools/types.d.ts +10 -0
  135. package/dist/tools/types.js +2 -0
  136. package/dist/tools/types.js.map +1 -0
  137. package/dist/utils/retry.d.ts +7 -0
  138. package/dist/utils/retry.js +34 -0
  139. package/dist/utils/retry.js.map +1 -0
  140. package/install.sh +171 -0
  141. 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,6 @@
1
+ import type { AuditEntry, AuditSink } from './types.js';
2
+ export declare class FileAuditSink implements AuditSink {
3
+ private logDir;
4
+ constructor(logDir: string);
5
+ write(entry: AuditEntry): void;
6
+ }
@@ -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,3 @@
1
+ export declare function getSessionId(): string;
2
+ export declare function nextCommandId(prefix?: string): string;
3
+ export declare function nextTraceId(): string;
@@ -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,2 @@
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
@@ -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>;