@gatanot/qualia_core 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 (297) hide show
  1. package/dist/agent/background.d.ts +6 -0
  2. package/dist/agent/background.d.ts.map +1 -0
  3. package/dist/agent/background.js +58 -0
  4. package/dist/agent/background.js.map +1 -0
  5. package/dist/agent/context-builder.d.ts +23 -0
  6. package/dist/agent/context-builder.d.ts.map +1 -0
  7. package/dist/agent/context-builder.js +102 -0
  8. package/dist/agent/context-builder.js.map +1 -0
  9. package/dist/agent/diary.d.ts +4 -0
  10. package/dist/agent/diary.d.ts.map +1 -0
  11. package/dist/agent/diary.js +67 -0
  12. package/dist/agent/diary.js.map +1 -0
  13. package/dist/agent/index.d.ts +22 -0
  14. package/dist/agent/index.d.ts.map +1 -0
  15. package/dist/agent/index.js +20 -0
  16. package/dist/agent/index.js.map +1 -0
  17. package/dist/agent/logger.d.ts +23 -0
  18. package/dist/agent/logger.d.ts.map +1 -0
  19. package/dist/agent/logger.js +70 -0
  20. package/dist/agent/logger.js.map +1 -0
  21. package/dist/agent/logger.test.d.ts +2 -0
  22. package/dist/agent/logger.test.d.ts.map +1 -0
  23. package/dist/agent/logger.test.js +28 -0
  24. package/dist/agent/logger.test.js.map +1 -0
  25. package/dist/agent/loop.d.ts +52 -0
  26. package/dist/agent/loop.d.ts.map +1 -0
  27. package/dist/agent/loop.js +557 -0
  28. package/dist/agent/loop.js.map +1 -0
  29. package/dist/agent/message-sanitizer.d.ts +13 -0
  30. package/dist/agent/message-sanitizer.d.ts.map +1 -0
  31. package/dist/agent/message-sanitizer.js +138 -0
  32. package/dist/agent/message-sanitizer.js.map +1 -0
  33. package/dist/agent/message-sanitizer.test.d.ts +2 -0
  34. package/dist/agent/message-sanitizer.test.d.ts.map +1 -0
  35. package/dist/agent/message-sanitizer.test.js +110 -0
  36. package/dist/agent/message-sanitizer.test.js.map +1 -0
  37. package/dist/agent/prompts.d.ts +15 -0
  38. package/dist/agent/prompts.d.ts.map +1 -0
  39. package/dist/agent/prompts.js +34 -0
  40. package/dist/agent/prompts.js.map +1 -0
  41. package/dist/agent/summarize-worker.d.ts +6 -0
  42. package/dist/agent/summarize-worker.d.ts.map +1 -0
  43. package/dist/agent/summarize-worker.js +62 -0
  44. package/dist/agent/summarize-worker.js.map +1 -0
  45. package/dist/agent/summarizer.d.ts +10 -0
  46. package/dist/agent/summarizer.d.ts.map +1 -0
  47. package/dist/agent/summarizer.js +133 -0
  48. package/dist/agent/summarizer.js.map +1 -0
  49. package/dist/agent/types.d.ts +135 -0
  50. package/dist/agent/types.d.ts.map +1 -0
  51. package/dist/agent/types.js +21 -0
  52. package/dist/agent/types.js.map +1 -0
  53. package/dist/ai/base.d.ts +19 -0
  54. package/dist/ai/base.d.ts.map +1 -0
  55. package/dist/ai/base.js +2 -0
  56. package/dist/ai/base.js.map +1 -0
  57. package/dist/ai/deepseek.d.ts +15 -0
  58. package/dist/ai/deepseek.d.ts.map +1 -0
  59. package/dist/ai/deepseek.js +24 -0
  60. package/dist/ai/deepseek.js.map +1 -0
  61. package/dist/ai/factory.d.ts +4 -0
  62. package/dist/ai/factory.d.ts.map +1 -0
  63. package/dist/ai/factory.js +53 -0
  64. package/dist/ai/factory.js.map +1 -0
  65. package/dist/ai/index.d.ts +43 -0
  66. package/dist/ai/index.d.ts.map +1 -0
  67. package/dist/ai/index.js +36 -0
  68. package/dist/ai/index.js.map +1 -0
  69. package/dist/ai/models.d.ts +13 -0
  70. package/dist/ai/models.d.ts.map +1 -0
  71. package/dist/ai/models.js +67 -0
  72. package/dist/ai/models.js.map +1 -0
  73. package/dist/ai/ollama.d.ts +13 -0
  74. package/dist/ai/ollama.d.ts.map +1 -0
  75. package/dist/ai/ollama.js +32 -0
  76. package/dist/ai/ollama.js.map +1 -0
  77. package/dist/ai/openai.d.ts +46 -0
  78. package/dist/ai/openai.d.ts.map +1 -0
  79. package/dist/ai/openai.js +90 -0
  80. package/dist/ai/openai.js.map +1 -0
  81. package/dist/ai/types.d.ts +154 -0
  82. package/dist/ai/types.d.ts.map +1 -0
  83. package/dist/ai/types.js +2 -0
  84. package/dist/ai/types.js.map +1 -0
  85. package/dist/ai/utils.d.ts +47 -0
  86. package/dist/ai/utils.d.ts.map +1 -0
  87. package/dist/ai/utils.js +145 -0
  88. package/dist/ai/utils.js.map +1 -0
  89. package/dist/ai/xiaomi.d.ts +15 -0
  90. package/dist/ai/xiaomi.d.ts.map +1 -0
  91. package/dist/ai/xiaomi.js +23 -0
  92. package/dist/ai/xiaomi.js.map +1 -0
  93. package/dist/chat-confirm.d.ts +4 -0
  94. package/dist/chat-confirm.d.ts.map +1 -0
  95. package/dist/chat-confirm.js +2 -0
  96. package/dist/chat-confirm.js.map +1 -0
  97. package/dist/chat-steering.d.ts +6 -0
  98. package/dist/chat-steering.d.ts.map +1 -0
  99. package/dist/chat-steering.js +2 -0
  100. package/dist/chat-steering.js.map +1 -0
  101. package/dist/concurrency/background-worker.d.ts +16 -0
  102. package/dist/concurrency/background-worker.d.ts.map +1 -0
  103. package/dist/concurrency/background-worker.js +62 -0
  104. package/dist/concurrency/background-worker.js.map +1 -0
  105. package/dist/concurrency/background-worker.test.d.ts +2 -0
  106. package/dist/concurrency/background-worker.test.d.ts.map +1 -0
  107. package/dist/concurrency/background-worker.test.js +55 -0
  108. package/dist/concurrency/background-worker.test.js.map +1 -0
  109. package/dist/concurrency/file-mutex.d.ts +8 -0
  110. package/dist/concurrency/file-mutex.d.ts.map +1 -0
  111. package/dist/concurrency/file-mutex.js +41 -0
  112. package/dist/concurrency/file-mutex.js.map +1 -0
  113. package/dist/concurrency/file-mutex.test.d.ts +2 -0
  114. package/dist/concurrency/file-mutex.test.d.ts.map +1 -0
  115. package/dist/concurrency/file-mutex.test.js +50 -0
  116. package/dist/concurrency/file-mutex.test.js.map +1 -0
  117. package/dist/concurrency/index.d.ts +5 -0
  118. package/dist/concurrency/index.d.ts.map +1 -0
  119. package/dist/concurrency/index.js +4 -0
  120. package/dist/concurrency/index.js.map +1 -0
  121. package/dist/concurrency/session-lock.d.ts +8 -0
  122. package/dist/concurrency/session-lock.d.ts.map +1 -0
  123. package/dist/concurrency/session-lock.js +41 -0
  124. package/dist/concurrency/session-lock.js.map +1 -0
  125. package/dist/concurrency/session-lock.test.d.ts +2 -0
  126. package/dist/concurrency/session-lock.test.d.ts.map +1 -0
  127. package/dist/concurrency/session-lock.test.js +51 -0
  128. package/dist/concurrency/session-lock.test.js.map +1 -0
  129. package/dist/config/index.d.ts +12 -0
  130. package/dist/config/index.d.ts.map +1 -0
  131. package/dist/config/index.js +10 -0
  132. package/dist/config/index.js.map +1 -0
  133. package/dist/config/store.d.ts +17 -0
  134. package/dist/config/store.d.ts.map +1 -0
  135. package/dist/config/store.js +214 -0
  136. package/dist/config/store.js.map +1 -0
  137. package/dist/config/types.d.ts +44 -0
  138. package/dist/config/types.d.ts.map +1 -0
  139. package/dist/config/types.js +2 -0
  140. package/dist/config/types.js.map +1 -0
  141. package/dist/gateway/adapters/email.d.ts +23 -0
  142. package/dist/gateway/adapters/email.d.ts.map +1 -0
  143. package/dist/gateway/adapters/email.js +145 -0
  144. package/dist/gateway/adapters/email.js.map +1 -0
  145. package/dist/gateway/adapters/telegram-sessions.d.ts +4 -0
  146. package/dist/gateway/adapters/telegram-sessions.d.ts.map +1 -0
  147. package/dist/gateway/adapters/telegram-sessions.js +39 -0
  148. package/dist/gateway/adapters/telegram-sessions.js.map +1 -0
  149. package/dist/gateway/adapters/telegram.d.ts +22 -0
  150. package/dist/gateway/adapters/telegram.d.ts.map +1 -0
  151. package/dist/gateway/adapters/telegram.js +131 -0
  152. package/dist/gateway/adapters/telegram.js.map +1 -0
  153. package/dist/gateway/dispatcher.d.ts +19 -0
  154. package/dist/gateway/dispatcher.d.ts.map +1 -0
  155. package/dist/gateway/dispatcher.js +81 -0
  156. package/dist/gateway/dispatcher.js.map +1 -0
  157. package/dist/gateway/inbound-handler.d.ts +3 -0
  158. package/dist/gateway/inbound-handler.d.ts.map +1 -0
  159. package/dist/gateway/inbound-handler.js +95 -0
  160. package/dist/gateway/inbound-handler.js.map +1 -0
  161. package/dist/gateway/index.d.ts +9 -0
  162. package/dist/gateway/index.d.ts.map +1 -0
  163. package/dist/gateway/index.js +6 -0
  164. package/dist/gateway/index.js.map +1 -0
  165. package/dist/gateway/lifecycle.d.ts +3 -0
  166. package/dist/gateway/lifecycle.d.ts.map +1 -0
  167. package/dist/gateway/lifecycle.js +38 -0
  168. package/dist/gateway/lifecycle.js.map +1 -0
  169. package/dist/gateway/types.d.ts +32 -0
  170. package/dist/gateway/types.d.ts.map +1 -0
  171. package/dist/gateway/types.js +2 -0
  172. package/dist/gateway/types.js.map +1 -0
  173. package/dist/index.d.ts +23 -0
  174. package/dist/index.d.ts.map +1 -0
  175. package/dist/index.js +14 -0
  176. package/dist/index.js.map +1 -0
  177. package/dist/markdown.d.ts +2 -0
  178. package/dist/markdown.d.ts.map +1 -0
  179. package/dist/markdown.js +94 -0
  180. package/dist/markdown.js.map +1 -0
  181. package/dist/paths.d.ts +5 -0
  182. package/dist/paths.d.ts.map +1 -0
  183. package/dist/paths.js +17 -0
  184. package/dist/paths.js.map +1 -0
  185. package/dist/storage/index.d.ts +10 -0
  186. package/dist/storage/index.d.ts.map +1 -0
  187. package/dist/storage/index.js +18 -0
  188. package/dist/storage/index.js.map +1 -0
  189. package/dist/storage/memory.d.ts +39 -0
  190. package/dist/storage/memory.d.ts.map +1 -0
  191. package/dist/storage/memory.js +252 -0
  192. package/dist/storage/memory.js.map +1 -0
  193. package/dist/storage/sqlite.d.ts +44 -0
  194. package/dist/storage/sqlite.d.ts.map +1 -0
  195. package/dist/storage/sqlite.js +275 -0
  196. package/dist/storage/sqlite.js.map +1 -0
  197. package/dist/storage/types.d.ts +134 -0
  198. package/dist/storage/types.d.ts.map +1 -0
  199. package/dist/storage/types.js +2 -0
  200. package/dist/storage/types.js.map +1 -0
  201. package/dist/storage/utils.d.ts +2 -0
  202. package/dist/storage/utils.d.ts.map +1 -0
  203. package/dist/storage/utils.js +8 -0
  204. package/dist/storage/utils.js.map +1 -0
  205. package/dist/task/executor.d.ts +3 -0
  206. package/dist/task/executor.d.ts.map +1 -0
  207. package/dist/task/executor.js +80 -0
  208. package/dist/task/executor.js.map +1 -0
  209. package/dist/task/index.d.ts +5 -0
  210. package/dist/task/index.d.ts.map +1 -0
  211. package/dist/task/index.js +4 -0
  212. package/dist/task/index.js.map +1 -0
  213. package/dist/task/scheduler.d.ts +5 -0
  214. package/dist/task/scheduler.d.ts.map +1 -0
  215. package/dist/task/scheduler.js +47 -0
  216. package/dist/task/scheduler.js.map +1 -0
  217. package/dist/task/store.d.ts +14 -0
  218. package/dist/task/store.d.ts.map +1 -0
  219. package/dist/task/store.js +156 -0
  220. package/dist/task/store.js.map +1 -0
  221. package/dist/task/types.d.ts +13 -0
  222. package/dist/task/types.d.ts.map +1 -0
  223. package/dist/task/types.js +2 -0
  224. package/dist/task/types.js.map +1 -0
  225. package/dist/tool/env.d.ts +20 -0
  226. package/dist/tool/env.d.ts.map +1 -0
  227. package/dist/tool/env.js +26 -0
  228. package/dist/tool/env.js.map +1 -0
  229. package/dist/tool/env.test.d.ts +2 -0
  230. package/dist/tool/env.test.d.ts.map +1 -0
  231. package/dist/tool/env.test.js +42 -0
  232. package/dist/tool/env.test.js.map +1 -0
  233. package/dist/tool/index.d.ts +42 -0
  234. package/dist/tool/index.d.ts.map +1 -0
  235. package/dist/tool/index.js +53 -0
  236. package/dist/tool/index.js.map +1 -0
  237. package/dist/tool/registry.d.ts +43 -0
  238. package/dist/tool/registry.d.ts.map +1 -0
  239. package/dist/tool/registry.js +79 -0
  240. package/dist/tool/registry.js.map +1 -0
  241. package/dist/tool/safeguard.d.ts +21 -0
  242. package/dist/tool/safeguard.d.ts.map +1 -0
  243. package/dist/tool/safeguard.js +212 -0
  244. package/dist/tool/safeguard.js.map +1 -0
  245. package/dist/tool/tools/delete-file.d.ts +10 -0
  246. package/dist/tool/tools/delete-file.d.ts.map +1 -0
  247. package/dist/tool/tools/delete-file.js +52 -0
  248. package/dist/tool/tools/delete-file.js.map +1 -0
  249. package/dist/tool/tools/edit.d.ts +10 -0
  250. package/dist/tool/tools/edit.d.ts.map +1 -0
  251. package/dist/tool/tools/edit.js +159 -0
  252. package/dist/tool/tools/edit.js.map +1 -0
  253. package/dist/tool/tools/exec.d.ts +12 -0
  254. package/dist/tool/tools/exec.d.ts.map +1 -0
  255. package/dist/tool/tools/exec.js +170 -0
  256. package/dist/tool/tools/exec.js.map +1 -0
  257. package/dist/tool/tools/file-utils.d.ts +13 -0
  258. package/dist/tool/tools/file-utils.d.ts.map +1 -0
  259. package/dist/tool/tools/file-utils.js +65 -0
  260. package/dist/tool/tools/file-utils.js.map +1 -0
  261. package/dist/tool/tools/read-file.d.ts +10 -0
  262. package/dist/tool/tools/read-file.d.ts.map +1 -0
  263. package/dist/tool/tools/read-file.js +116 -0
  264. package/dist/tool/tools/read-file.js.map +1 -0
  265. package/dist/tool/tools/read-memory.d.ts +3 -0
  266. package/dist/tool/tools/read-memory.d.ts.map +1 -0
  267. package/dist/tool/tools/read-memory.js +58 -0
  268. package/dist/tool/tools/read-memory.js.map +1 -0
  269. package/dist/tool/tools/read-tasks.d.ts +3 -0
  270. package/dist/tool/tools/read-tasks.d.ts.map +1 -0
  271. package/dist/tool/tools/read-tasks.js +29 -0
  272. package/dist/tool/tools/read-tasks.js.map +1 -0
  273. package/dist/tool/tools/schedule-task.d.ts +3 -0
  274. package/dist/tool/tools/schedule-task.d.ts.map +1 -0
  275. package/dist/tool/tools/schedule-task.js +50 -0
  276. package/dist/tool/tools/schedule-task.js.map +1 -0
  277. package/dist/tool/tools/search-history.d.ts +4 -0
  278. package/dist/tool/tools/search-history.d.ts.map +1 -0
  279. package/dist/tool/tools/search-history.js +58 -0
  280. package/dist/tool/tools/search-history.js.map +1 -0
  281. package/dist/tool/tools/web-search.d.ts +3 -0
  282. package/dist/tool/tools/web-search.d.ts.map +1 -0
  283. package/dist/tool/tools/web-search.js +89 -0
  284. package/dist/tool/tools/web-search.js.map +1 -0
  285. package/dist/tool/tools/write-file.d.ts +11 -0
  286. package/dist/tool/tools/write-file.d.ts.map +1 -0
  287. package/dist/tool/tools/write-file.js +79 -0
  288. package/dist/tool/tools/write-file.js.map +1 -0
  289. package/dist/tool/tools/write-memory.d.ts +3 -0
  290. package/dist/tool/tools/write-memory.d.ts.map +1 -0
  291. package/dist/tool/tools/write-memory.js +99 -0
  292. package/dist/tool/tools/write-memory.js.map +1 -0
  293. package/dist/tool/types.d.ts +63 -0
  294. package/dist/tool/types.d.ts.map +1 -0
  295. package/dist/tool/types.js +33 -0
  296. package/dist/tool/types.js.map +1 -0
  297. package/package.json +53 -0
@@ -0,0 +1,42 @@
1
+ import { describe, it, expect } from 'vitest';
2
+ import { ToolContext } from './env.js';
3
+ describe('ToolContext', () => {
4
+ describe('resolvePath', () => {
5
+ it('resolves relative path within workspace', () => {
6
+ const ctx = new ToolContext('/home/user/project');
7
+ const result = ctx.resolvePath('src/app.ts');
8
+ expect(result.classification).toBe('safe');
9
+ });
10
+ it('classifies system paths as reject', () => {
11
+ const ctx = new ToolContext('/home/user/project');
12
+ const result = ctx.resolvePath('C:\\Windows\\System32\\kernel32.dll');
13
+ expect(result.classification).toBe('reject');
14
+ });
15
+ it('resolves absolute path', () => {
16
+ const ctx = new ToolContext('/home/user/project');
17
+ const result = ctx.resolvePath('/home/user/project/src/app.ts');
18
+ expect(result.path).toContain('src');
19
+ });
20
+ });
21
+ describe('classifyCommand', () => {
22
+ it('classifies safe commands', () => {
23
+ const ctx = new ToolContext('/home/user/project');
24
+ expect(ctx.classifyCommand('ls -la')).toBe('safe');
25
+ });
26
+ it('classifies dangerous commands as confirm', () => {
27
+ const ctx = new ToolContext('/home/user/project');
28
+ expect(ctx.classifyCommand('rm -rf /tmp/test')).toBe('confirm');
29
+ });
30
+ it('classifies system-dangerous commands as reject', () => {
31
+ const ctx = new ToolContext('/home/user/project');
32
+ expect(ctx.classifyCommand('format C:')).toBe('reject');
33
+ });
34
+ });
35
+ describe('root', () => {
36
+ it('exposes root path', () => {
37
+ const ctx = new ToolContext('/home/user/project');
38
+ expect(ctx.root).toBe('/home/user/project');
39
+ });
40
+ });
41
+ });
42
+ //# sourceMappingURL=env.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"env.test.js","sourceRoot":"","sources":["../../src/tool/env.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAEvC,QAAQ,CAAC,aAAa,EAAE,GAAG,EAAE;IAC5B,QAAQ,CAAC,aAAa,EAAE,GAAG,EAAE;QAC5B,EAAE,CAAC,yCAAyC,EAAE,GAAG,EAAE;YAClD,MAAM,GAAG,GAAG,IAAI,WAAW,CAAC,oBAAoB,CAAC,CAAC;YAClD,MAAM,MAAM,GAAG,GAAG,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC;YAC7C,MAAM,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAC5C,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,mCAAmC,EAAE,GAAG,EAAE;YAC5C,MAAM,GAAG,GAAG,IAAI,WAAW,CAAC,oBAAoB,CAAC,CAAC;YAClD,MAAM,MAAM,GAAG,GAAG,CAAC,WAAW,CAAC,qCAAqC,CAAC,CAAC;YACtE,MAAM,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC9C,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,wBAAwB,EAAE,GAAG,EAAE;YACjC,MAAM,GAAG,GAAG,IAAI,WAAW,CAAC,oBAAoB,CAAC,CAAC;YAClD,MAAM,MAAM,GAAG,GAAG,CAAC,WAAW,CAAC,+BAA+B,CAAC,CAAC;YAChE,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QACtC,CAAC,CAAC,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,iBAAiB,EAAE,GAAG,EAAE;QAChC,EAAE,CAAC,0BAA0B,EAAE,GAAG,EAAE;YACnC,MAAM,GAAG,GAAG,IAAI,WAAW,CAAC,oBAAoB,CAAC,CAAC;YAClD,MAAM,CAAC,GAAG,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACpD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,0CAA0C,EAAE,GAAG,EAAE;YACnD,MAAM,GAAG,GAAG,IAAI,WAAW,CAAC,oBAAoB,CAAC,CAAC;YAClD,MAAM,CAAC,GAAG,CAAC,eAAe,CAAC,kBAAkB,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACjE,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,gDAAgD,EAAE,GAAG,EAAE;YACzD,MAAM,GAAG,GAAG,IAAI,WAAW,CAAC,oBAAoB,CAAC,CAAC;YAClD,MAAM,CAAC,GAAG,CAAC,eAAe,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACzD,CAAC,CAAC,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,MAAM,EAAE,GAAG,EAAE;QACrB,EAAE,CAAC,mBAAmB,EAAE,GAAG,EAAE;YAC5B,MAAM,GAAG,GAAG,IAAI,WAAW,CAAC,oBAAoB,CAAC,CAAC;YAClD,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;QAC7C,CAAC,CAAC,CAAC;IACJ,CAAC,CAAC,CAAC;AACJ,CAAC,CAAC,CAAC"}
@@ -0,0 +1,42 @@
1
+ /**
2
+ * Tool System 模块
3
+ *
4
+ * 可插拔的工具注册与执行框架,用于 LLM function calling。
5
+ * 包含安全判定引擎,对危险操作实施确认或拒绝策略。
6
+ *
7
+ * 工具集数组(CORE_TOOLS / SCHEDULING_TOOLS)用于快速装配 ToolRegistry,
8
+ * 避免在多个入口重复列清单。添加新工具时只需更新对应数组,无需修改调用方。
9
+ *
10
+ * @module tool
11
+ *
12
+ * @example
13
+ * ```ts
14
+ * import { ToolRegistry, CORE_TOOLS } from './index.js';
15
+ *
16
+ * const registry = new ToolRegistry();
17
+ * for (const t of CORE_TOOLS) registry.register(t);
18
+ * ```
19
+ */
20
+ export { ToolRegistry } from './registry.js';
21
+ export { PendingConfirmation } from './types.js';
22
+ export type { ToolDef, ToolResult, CommandClassification } from './types.js';
23
+ export { classifyCommand, classifyFilePath } from './safeguard.js';
24
+ export { ToolContext } from './env.js';
25
+ import { readFileTool } from './tools/read-file.js';
26
+ import { writeFileTool } from './tools/write-file.js';
27
+ import { deleteFileTool } from './tools/delete-file.js';
28
+ import { editTool } from './tools/edit.js';
29
+ import { execTool } from './tools/exec.js';
30
+ import { webSearchTool } from './tools/web-search.js';
31
+ import { readMemoryTool } from './tools/read-memory.js';
32
+ import { writeMemoryTool } from './tools/write-memory.js';
33
+ import { scheduleTaskTool } from './tools/schedule-task.js';
34
+ import { readTasksTool } from './tools/read-tasks.js';
35
+ export { readFileTool, writeFileTool, deleteFileTool, editTool, execTool, webSearchTool, readMemoryTool, writeMemoryTool, scheduleTaskTool, readTasksTool };
36
+ export { createSearchHistoryTool } from './tools/search-history.js';
37
+ import type { ToolDef } from './types.js';
38
+ /** 核心工具集:文件操作 + 搜索 + 记忆(Chat / Gateway 使用,再拼接 SCHEDULING_TOOLS 即为全量) */
39
+ export declare const CORE_TOOLS: ToolDef[];
40
+ /** 调度工具集 */
41
+ export declare const SCHEDULING_TOOLS: ToolDef[];
42
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/tool/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;GAkBG;AAEH,OAAO,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAC7C,OAAO,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;AACjD,YAAY,EAAE,OAAO,EAAE,UAAU,EAAE,qBAAqB,EAAE,MAAM,YAAY,CAAC;AAC7E,OAAO,EAAE,eAAe,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AACnE,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAGvC,OAAO,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AACpD,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AACtD,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AACxD,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAC3C,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAC3C,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AACtD,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AACxD,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAC1D,OAAO,EAAE,gBAAgB,EAAE,MAAM,0BAA0B,CAAC;AAC5D,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AAEtD,OAAO,EAAE,YAAY,EAAE,aAAa,EAAE,cAAc,EAAE,QAAQ,EAAE,QAAQ,EAAE,aAAa,EAAE,cAAc,EAAE,eAAe,EAAE,gBAAgB,EAAE,aAAa,EAAE,CAAC;AAC5J,OAAO,EAAE,uBAAuB,EAAE,MAAM,2BAA2B,CAAC;AAEpE,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,YAAY,CAAC;AAE1C,wEAAwE;AACxE,eAAO,MAAM,UAAU,EAAE,OAAO,EAS/B,CAAC;AAEF,YAAY;AACZ,eAAO,MAAM,gBAAgB,EAAE,OAAO,EAGrC,CAAC"}
@@ -0,0 +1,53 @@
1
+ /**
2
+ * Tool System 模块
3
+ *
4
+ * 可插拔的工具注册与执行框架,用于 LLM function calling。
5
+ * 包含安全判定引擎,对危险操作实施确认或拒绝策略。
6
+ *
7
+ * 工具集数组(CORE_TOOLS / SCHEDULING_TOOLS)用于快速装配 ToolRegistry,
8
+ * 避免在多个入口重复列清单。添加新工具时只需更新对应数组,无需修改调用方。
9
+ *
10
+ * @module tool
11
+ *
12
+ * @example
13
+ * ```ts
14
+ * import { ToolRegistry, CORE_TOOLS } from './index.js';
15
+ *
16
+ * const registry = new ToolRegistry();
17
+ * for (const t of CORE_TOOLS) registry.register(t);
18
+ * ```
19
+ */
20
+ export { ToolRegistry } from './registry.js';
21
+ export { PendingConfirmation } from './types.js';
22
+ export { classifyCommand, classifyFilePath } from './safeguard.js';
23
+ export { ToolContext } from './env.js';
24
+ // 工具定义
25
+ import { readFileTool } from './tools/read-file.js';
26
+ import { writeFileTool } from './tools/write-file.js';
27
+ import { deleteFileTool } from './tools/delete-file.js';
28
+ import { editTool } from './tools/edit.js';
29
+ import { execTool } from './tools/exec.js';
30
+ import { webSearchTool } from './tools/web-search.js';
31
+ import { readMemoryTool } from './tools/read-memory.js';
32
+ import { writeMemoryTool } from './tools/write-memory.js';
33
+ import { scheduleTaskTool } from './tools/schedule-task.js';
34
+ import { readTasksTool } from './tools/read-tasks.js';
35
+ export { readFileTool, writeFileTool, deleteFileTool, editTool, execTool, webSearchTool, readMemoryTool, writeMemoryTool, scheduleTaskTool, readTasksTool };
36
+ export { createSearchHistoryTool } from './tools/search-history.js';
37
+ /** 核心工具集:文件操作 + 搜索 + 记忆(Chat / Gateway 使用,再拼接 SCHEDULING_TOOLS 即为全量) */
38
+ export const CORE_TOOLS = [
39
+ readFileTool,
40
+ writeFileTool,
41
+ deleteFileTool,
42
+ editTool,
43
+ execTool,
44
+ webSearchTool,
45
+ readMemoryTool,
46
+ writeMemoryTool,
47
+ ];
48
+ /** 调度工具集 */
49
+ export const SCHEDULING_TOOLS = [
50
+ scheduleTaskTool,
51
+ readTasksTool,
52
+ ];
53
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/tool/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;GAkBG;AAEH,OAAO,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAC7C,OAAO,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;AAEjD,OAAO,EAAE,eAAe,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AACnE,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAEvC,OAAO;AACP,OAAO,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AACpD,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AACtD,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AACxD,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAC3C,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAC3C,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AACtD,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AACxD,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAC1D,OAAO,EAAE,gBAAgB,EAAE,MAAM,0BAA0B,CAAC;AAC5D,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AAEtD,OAAO,EAAE,YAAY,EAAE,aAAa,EAAE,cAAc,EAAE,QAAQ,EAAE,QAAQ,EAAE,aAAa,EAAE,cAAc,EAAE,eAAe,EAAE,gBAAgB,EAAE,aAAa,EAAE,CAAC;AAC5J,OAAO,EAAE,uBAAuB,EAAE,MAAM,2BAA2B,CAAC;AAIpE,wEAAwE;AACxE,MAAM,CAAC,MAAM,UAAU,GAAc;IACpC,YAAY;IACZ,aAAa;IACb,cAAc;IACd,QAAQ;IACR,QAAQ;IACR,aAAa;IACb,cAAc;IACd,eAAe;CACf,CAAC;AAEF,YAAY;AACZ,MAAM,CAAC,MAAM,gBAAgB,GAAc;IAC1C,gBAAgB;IAChB,aAAa;CACb,CAAC"}
@@ -0,0 +1,43 @@
1
+ /**
2
+ * 工具注册表
3
+ *
4
+ * 管理工具的注册、查询和调度。
5
+ * 提供 getDefinitions() 将已注册工具转为 OpenAI function calling 格式。
6
+ * 支持 sourceId 追踪,可按来源批量卸载(为 extension 系统提供基础)。
7
+ */
8
+ import type { ToolDef, ToolResult } from './types.js';
9
+ import type { Tool } from '../ai/index.js';
10
+ import { ToolContext } from './env.js';
11
+ export declare class ToolRegistry {
12
+ private tools;
13
+ private sources;
14
+ /**
15
+ * 注册一个工具
16
+ * @param tool - 工具定义
17
+ * @param sourceId - 来源标识,默认为 'builtin'。用于批量卸载时按来源清理。
18
+ */
19
+ register(tool: ToolDef, sourceId?: string): void;
20
+ /** 注销一个工具 */
21
+ unregister(name: string): boolean;
22
+ /**
23
+ * 按来源批量注销工具
24
+ * @param sourceId - 来源标识
25
+ * @returns 被注销的工具数量
26
+ */
27
+ unregisterSource(sourceId: string): number;
28
+ /** 按名称获取工具 */
29
+ get(name: string): ToolDef | undefined;
30
+ /** 获取 OpenAI function calling 格式的工具定义列表 */
31
+ getDefinitions(): Tool[];
32
+ /**
33
+ * 按名称执行工具
34
+ *
35
+ * @param name - 工具名称
36
+ * @param args - 调用参数,支持 __confirmed 标记跳过确认流程
37
+ * @param ctx - 工具执行上下文
38
+ * @returns 执行结果
39
+ * @throws PendingConfirmation 需要用户确认时
40
+ */
41
+ execute(name: string, args: Record<string, unknown>, ctx: ToolContext): Promise<ToolResult>;
42
+ }
43
+ //# sourceMappingURL=registry.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"registry.d.ts","sourceRoot":"","sources":["../../src/tool/registry.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,KAAK,EAAE,OAAO,EAAE,UAAU,EAAE,MAAM,YAAY,CAAC;AACtD,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAEvC,qBAAa,YAAY;IACxB,OAAO,CAAC,KAAK,CAA8B;IAC3C,OAAO,CAAC,OAAO,CAAkC;IAEjD;;;;OAIG;IACH,QAAQ,CAAC,IAAI,EAAE,OAAO,EAAE,QAAQ,SAAY,GAAG,IAAI;IAQnD,aAAa;IACb,UAAU,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO;IAOjC;;;;OAIG;IACH,gBAAgB,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM;IAW1C,cAAc;IACd,GAAG,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,GAAG,SAAS;IAItC,2CAA2C;IAC3C,cAAc,IAAI,IAAI,EAAE;IAWxB;;;;;;;;OAQG;IACG,OAAO,CACZ,IAAI,EAAE,MAAM,EACZ,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAC7B,GAAG,EAAE,WAAW,GACd,OAAO,CAAC,UAAU,CAAC;CAOtB"}
@@ -0,0 +1,79 @@
1
+ /**
2
+ * 工具注册表
3
+ *
4
+ * 管理工具的注册、查询和调度。
5
+ * 提供 getDefinitions() 将已注册工具转为 OpenAI function calling 格式。
6
+ * 支持 sourceId 追踪,可按来源批量卸载(为 extension 系统提供基础)。
7
+ */
8
+ export class ToolRegistry {
9
+ tools = new Map();
10
+ sources = new Map();
11
+ /**
12
+ * 注册一个工具
13
+ * @param tool - 工具定义
14
+ * @param sourceId - 来源标识,默认为 'builtin'。用于批量卸载时按来源清理。
15
+ */
16
+ register(tool, sourceId = 'builtin') {
17
+ this.tools.set(tool.name, tool);
18
+ if (!this.sources.has(sourceId)) {
19
+ this.sources.set(sourceId, new Set());
20
+ }
21
+ this.sources.get(sourceId).add(tool.name);
22
+ }
23
+ /** 注销一个工具 */
24
+ unregister(name) {
25
+ for (const [, names] of this.sources) {
26
+ names.delete(name);
27
+ }
28
+ return this.tools.delete(name);
29
+ }
30
+ /**
31
+ * 按来源批量注销工具
32
+ * @param sourceId - 来源标识
33
+ * @returns 被注销的工具数量
34
+ */
35
+ unregisterSource(sourceId) {
36
+ const names = this.sources.get(sourceId);
37
+ if (!names)
38
+ return 0;
39
+ let count = 0;
40
+ for (const name of names) {
41
+ if (this.tools.delete(name))
42
+ count++;
43
+ }
44
+ this.sources.delete(sourceId);
45
+ return count;
46
+ }
47
+ /** 按名称获取工具 */
48
+ get(name) {
49
+ return this.tools.get(name);
50
+ }
51
+ /** 获取 OpenAI function calling 格式的工具定义列表 */
52
+ getDefinitions() {
53
+ return Array.from(this.tools.values()).map((tool) => ({
54
+ type: 'function',
55
+ function: {
56
+ name: tool.name,
57
+ description: tool.description,
58
+ parameters: tool.parameters
59
+ }
60
+ }));
61
+ }
62
+ /**
63
+ * 按名称执行工具
64
+ *
65
+ * @param name - 工具名称
66
+ * @param args - 调用参数,支持 __confirmed 标记跳过确认流程
67
+ * @param ctx - 工具执行上下文
68
+ * @returns 执行结果
69
+ * @throws PendingConfirmation 需要用户确认时
70
+ */
71
+ async execute(name, args, ctx) {
72
+ const tool = this.tools.get(name);
73
+ if (!tool) {
74
+ return { success: false, output: '', error: `未知工具: ${name}` };
75
+ }
76
+ return tool.execute(args, ctx);
77
+ }
78
+ }
79
+ //# sourceMappingURL=registry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"registry.js","sourceRoot":"","sources":["../../src/tool/registry.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAMH,MAAM,OAAO,YAAY;IAChB,KAAK,GAAG,IAAI,GAAG,EAAmB,CAAC;IACnC,OAAO,GAAG,IAAI,GAAG,EAAuB,CAAC;IAEjD;;;;OAIG;IACH,QAAQ,CAAC,IAAa,EAAE,QAAQ,GAAG,SAAS;QAC3C,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;QAChC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC;YACjC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE,IAAI,GAAG,EAAE,CAAC,CAAC;QACvC,CAAC;QACD,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAE,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC5C,CAAC;IAED,aAAa;IACb,UAAU,CAAC,IAAY;QACtB,KAAK,MAAM,CAAC,EAAE,KAAK,CAAC,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACtC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QACpB,CAAC;QACD,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAChC,CAAC;IAED;;;;OAIG;IACH,gBAAgB,CAAC,QAAgB;QAChC,MAAM,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QACzC,IAAI,CAAC,KAAK;YAAE,OAAO,CAAC,CAAC;QACrB,IAAI,KAAK,GAAG,CAAC,CAAC;QACd,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;YAC1B,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC;gBAAE,KAAK,EAAE,CAAC;QACtC,CAAC;QACD,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;QAC9B,OAAO,KAAK,CAAC;IACd,CAAC;IAED,cAAc;IACd,GAAG,CAAC,IAAY;QACf,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IAC7B,CAAC;IAED,2CAA2C;IAC3C,cAAc;QACb,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;YACrD,IAAI,EAAE,UAAmB;YACzB,QAAQ,EAAE;gBACT,IAAI,EAAE,IAAI,CAAC,IAAI;gBACf,WAAW,EAAE,IAAI,CAAC,WAAW;gBAC7B,UAAU,EAAE,IAAI,CAAC,UAAU;aAC3B;SACD,CAAC,CAAC,CAAC;IACL,CAAC;IAED;;;;;;;;OAQG;IACH,KAAK,CAAC,OAAO,CACZ,IAAY,EACZ,IAA6B,EAC7B,GAAgB;QAEhB,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAClC,IAAI,CAAC,IAAI,EAAE,CAAC;YACX,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,EAAE,EAAE,KAAK,EAAE,SAAS,IAAI,EAAE,EAAE,CAAC;QAC/D,CAAC;QACD,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;IAChC,CAAC;CACD"}
@@ -0,0 +1,21 @@
1
+ import type { CommandClassification } from './types.js';
2
+ /**
3
+ * 分类命令的安全性
4
+ *
5
+ * 判定顺序:
6
+ * 1. reject — 明确禁止(format, diskpart)
7
+ * 2. confirm — 命中危险模式(删除、系统修改、管道注入等)
8
+ * 3. safe — 只读命令,无需后续路径检查
9
+ * 4. confirm — 路径在工作区外或系统目录
10
+ * 5. safe — 其余放行
11
+ *
12
+ * @returns 'safe' 可直接执行 / 'confirm' 需用户确认 / 'reject' 拒绝执行
13
+ */
14
+ export declare function classifyCommand(command: string, workspaceRoot: string): CommandClassification;
15
+ /**
16
+ * 分类文件路径的安全性
17
+ *
18
+ * @returns 'safe' 可直接操作 / 'confirm' 需用户确认
19
+ */
20
+ export declare function classifyFilePath(targetPath: string, workspaceRoot: string): CommandClassification;
21
+ //# sourceMappingURL=safeguard.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"safeguard.d.ts","sourceRoot":"","sources":["../../src/tool/safeguard.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,YAAY,CAAC;AA4KxD;;;;;;;;;;;GAWG;AACH,wBAAgB,eAAe,CAC9B,OAAO,EAAE,MAAM,EACf,aAAa,EAAE,MAAM,GACnB,qBAAqB,CAwBvB;AAED;;;;GAIG;AACF,wBAAgB,gBAAgB,CAChC,UAAU,EAAE,MAAM,EAClB,aAAa,EAAE,MAAM,GACnB,qBAAqB,CAYvB"}
@@ -0,0 +1,212 @@
1
+ import { resolve, isAbsolute, sep } from 'node:path';
2
+ const READONLY_PATTERNS = [
3
+ // PowerShell read-only cmdlets & aliases
4
+ /^\s*(?:Get-ChildItem|dir|ls|Get-Content|cat|type|Get-Process|ps|Get-Service|Get-Location|pwd|gl|Get-Item|gi|Get-ItemProperty|gp|Get-Date|Get-Host|Get-Variable|gv|Get-Command|gcm|Get-Member|gm|Get-Alias|gal|Get-History|history|ghy|Select-String|sls|findstr|Test-Path|Measure-Object|measure|Sort-Object|sort|Group-Object|group|Select-Object|select|Format-List|fl|Format-Table|ft|Format-Wide|fw|Format-Hex|Write-Output|echo|write|Compare-Object|diff|compare|Where-Object|Join-Path|Split-Path|Resolve-Path|ConvertFrom-Json|ConvertFrom-Csv)\b/i,
5
+ // Unix read-only
6
+ /^\s*(?:head|tail|less|more|grep|egrep|fgrep|rg|find|wc|sort|uniq|cut|tr|file|stat|df|du|which|whereis|command|whoami|id|groups|printf|uname|hostname|basename|dirname|readlink|realpath)\b/i,
7
+ // Git read-only
8
+ /^\s*git\s+(?:status|log|diff|show|branch|tag|stash\s+list|remote\s+(?:-v|show)|config\s+(?:--list|--get\b)|ls-files|rev-parse|rev-list|describe|shortlog|blame|grep|notes\s+list|reflog|cherry|for-each-ref|name-rev)\b/i,
9
+ // npm read-only
10
+ /^\s*npm\s+(?:ls|list|view|info|outdated|version|config\s+list)\b/i
11
+ ];
12
+ const DANGEROUS_PATTERNS = [
13
+ // Windows: delete operations (all forms — confirm before any deletion)
14
+ /^\s*del\b/i,
15
+ /^\s*rmdir\b/i,
16
+ /^\s*Remove-Item\b/i,
17
+ // Windows: system modification
18
+ /\bformat\b/i,
19
+ /\bdiskpart\b/i,
20
+ /reg\s+(delete|add)/i,
21
+ /Set-ExecutionPolicy/i,
22
+ // Windows: shutdown / service
23
+ /\bshutdown\b/i,
24
+ /Restart-Computer\b/i,
25
+ /Stop-Process\s+.*(svchost|winlogon|lsass|csrss)/i,
26
+ /Stop-Service\b/i,
27
+ // Windows: pipe to execution
28
+ /\|\s*iex\b/i,
29
+ /\|\s*Invoke-Expression\b/i,
30
+ /\|\s*cmd\b/i,
31
+ // Windows: redirect to system paths
32
+ />\s*%SystemRoot%/i,
33
+ />\s*C:\\Windows/i,
34
+ // Unix: recursive force delete
35
+ /\brm\s+-rf?\b/,
36
+ /\bfind\b.*\bdelete\b/,
37
+ // Unix: system modification
38
+ /\bdd\s+if=/,
39
+ /\bmkfs\./,
40
+ /\bchmod\s+777\s+\//,
41
+ // Unix: shutdown
42
+ /\bshutdown\b/,
43
+ /\breboot\b/,
44
+ /\binit\s+[06]/,
45
+ // Unix: redirect to system paths
46
+ />\s*\/etc\//,
47
+ />\s*\/bin\//,
48
+ />\s*\/boot\//,
49
+ // Unix: pipe to shell
50
+ /\|\s*(ba)?sh\b/,
51
+ /\|\s*zsh\b/,
52
+ // Cross-platform: dangerous patterns
53
+ /\bdrop\s+table\b/i,
54
+ /\bdrop\s+database\b/i,
55
+ /\bgit\s+push\s+--force\b/i,
56
+ /\bgit\s+reset\s+--hard\b/i
57
+ ];
58
+ const SYSTEM_DIRS = [
59
+ 'C:\\Windows',
60
+ 'C:\\Program Files',
61
+ 'C:\\Program Files (x86)',
62
+ '/etc',
63
+ '/bin',
64
+ '/sbin',
65
+ '/usr/bin',
66
+ '/usr/sbin',
67
+ '/boot',
68
+ '/sys',
69
+ '/dev',
70
+ '/proc'
71
+ ];
72
+ function isDangerousCommand(command) {
73
+ if (DANGEROUS_PATTERNS.some((pattern) => pattern.test(command))) {
74
+ return true;
75
+ }
76
+ for (const segment of command.split('|')) {
77
+ if (DANGEROUS_PATTERNS.some((pattern) => pattern.test(segment))) {
78
+ return true;
79
+ }
80
+ }
81
+ return false;
82
+ }
83
+ function isReadonlyCommand(command) {
84
+ for (const segment of command.split('|')) {
85
+ if (!READONLY_PATTERNS.some((pattern) => pattern.test(segment))) {
86
+ return false;
87
+ }
88
+ }
89
+ return true;
90
+ }
91
+ function isPathInWorkspace(targetPath, workspaceRoot) {
92
+ const resolved = normalizePath(targetPath, workspaceRoot);
93
+ const normalizedRoot = resolve(workspaceRoot).toLowerCase();
94
+ const normalizedTarget = resolve(resolved).toLowerCase();
95
+ return normalizedTarget.startsWith(normalizedRoot + sep);
96
+ }
97
+ function isSystemPath(targetPath, workspaceRoot) {
98
+ const resolved = normalizePath(targetPath, workspaceRoot);
99
+ const normalized = resolve(resolved).toLowerCase();
100
+ return SYSTEM_DIRS.some((sysDir) => normalized.startsWith(sysDir.toLowerCase()));
101
+ }
102
+ function expandEnvVars(command) {
103
+ let result = command.replace(/%(\w+)%/g, (_, name) => {
104
+ return process.env[name] ?? `%${name}%`;
105
+ });
106
+ result = result.replace(/\$\{(\w+)\}/g, (_, name) => {
107
+ return process.env[name] ?? `\$\{${name}\}`;
108
+ });
109
+ result = result.replace(/\$([A-Za-z_]\w*)/g, (_, name) => {
110
+ return process.env[name] ?? `$${name}`;
111
+ });
112
+ return result;
113
+ }
114
+ function collectPaths(source, paths) {
115
+ const winAbsRe = /[A-Za-z]:\\(?:[^\\/:*?"<>|\r\n]+\\)*[^\\/:*?"<>|\r\n]*/g;
116
+ let match;
117
+ while ((match = winAbsRe.exec(source)) !== null) {
118
+ paths.push(match[0]);
119
+ }
120
+ const unixAbsRe = /(?<!\w)\/(?:[^\s'"]+)/g;
121
+ while ((match = unixAbsRe.exec(source)) !== null) {
122
+ const p = match[0];
123
+ if (p.length > 1 && !/^\/\d/.test(p) && !/\/$/.test(p)) {
124
+ paths.push(p);
125
+ }
126
+ }
127
+ const tildeRe = /(?<!\w)~\/(?:[^\s'"]+)/g;
128
+ while ((match = tildeRe.exec(source)) !== null) {
129
+ paths.push(match[0]);
130
+ }
131
+ }
132
+ function extractPaths(command) {
133
+ const paths = [];
134
+ collectPaths(command, paths);
135
+ const expanded = expandEnvVars(command);
136
+ if (expanded !== command) {
137
+ collectPaths(expanded, paths);
138
+ }
139
+ const winRelRe = /(?:\.\.\\)+(?:[^\s'"]+)/g;
140
+ let match;
141
+ while ((match = winRelRe.exec(command)) !== null) {
142
+ paths.push(match[0]);
143
+ }
144
+ const unixRelRe = /(?<!\w)(?:\.\.\/)+(?:[^\s'"]+)/g;
145
+ while ((match = unixRelRe.exec(command)) !== null) {
146
+ const p = match[0];
147
+ if (p.length > 1 && !/\/$/.test(p)) {
148
+ paths.push(p);
149
+ }
150
+ }
151
+ return paths;
152
+ }
153
+ /**
154
+ * 分类命令的安全性
155
+ *
156
+ * 判定顺序:
157
+ * 1. reject — 明确禁止(format, diskpart)
158
+ * 2. confirm — 命中危险模式(删除、系统修改、管道注入等)
159
+ * 3. safe — 只读命令,无需后续路径检查
160
+ * 4. confirm — 路径在工作区外或系统目录
161
+ * 5. safe — 其余放行
162
+ *
163
+ * @returns 'safe' 可直接执行 / 'confirm' 需用户确认 / 'reject' 拒绝执行
164
+ */
165
+ export function classifyCommand(command, workspaceRoot) {
166
+ if (/^\s*(format|diskpart)\b/i.test(command.trim())) {
167
+ return 'reject';
168
+ }
169
+ if (isDangerousCommand(command)) {
170
+ return 'confirm';
171
+ }
172
+ if (isReadonlyCommand(command)) {
173
+ return 'safe';
174
+ }
175
+ const paths = extractPaths(command);
176
+ for (const p of paths) {
177
+ if (isSystemPath(p, workspaceRoot)) {
178
+ return 'confirm';
179
+ }
180
+ if (!isPathInWorkspace(p, workspaceRoot)) {
181
+ return 'confirm';
182
+ }
183
+ }
184
+ return 'safe';
185
+ }
186
+ /**
187
+ * 分类文件路径的安全性
188
+ *
189
+ * @returns 'safe' 可直接操作 / 'confirm' 需用户确认
190
+ */
191
+ export function classifyFilePath(targetPath, workspaceRoot) {
192
+ const normalized = normalizePath(targetPath, workspaceRoot);
193
+ if (isSystemPath(normalized, workspaceRoot)) {
194
+ return 'reject';
195
+ }
196
+ if (!isPathInWorkspace(normalized, workspaceRoot)) {
197
+ return 'confirm';
198
+ }
199
+ return 'safe';
200
+ }
201
+ function normalizePath(targetPath, workspaceRoot) {
202
+ let resolved = targetPath;
203
+ if (resolved.startsWith('~')) {
204
+ const home = process.env.HOME || process.env.USERPROFILE || '';
205
+ resolved = resolved.replace(/^~/, home);
206
+ }
207
+ if (isAbsolute(resolved)) {
208
+ return resolved;
209
+ }
210
+ return resolve(workspaceRoot, resolved);
211
+ }
212
+ //# sourceMappingURL=safeguard.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"safeguard.js","sourceRoot":"","sources":["../../src/tool/safeguard.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,10 @@
1
+ import type { ToolDef } from '../types.js';
2
+ /**
3
+ * delete_file — 删除文件
4
+ *
5
+ * 删除操作始终需要用户确认(不可逆)。
6
+ * 仅支持删除文件,不支持删除目录。
7
+ * 系统路径始终拒绝。
8
+ */
9
+ export declare const deleteFileTool: ToolDef;
10
+ //# sourceMappingURL=delete-file.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"delete-file.d.ts","sourceRoot":"","sources":["../../../src/tool/tools/delete-file.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,OAAO,EAAc,MAAM,aAAa,CAAC;AAIvD;;;;;;GAMG;AACH,eAAO,MAAM,cAAc,EAAE,OAmD5B,CAAC"}
@@ -0,0 +1,52 @@
1
+ import { rm, stat } from 'node:fs/promises';
2
+ import { PendingConfirmation } from '../types.js';
3
+ /**
4
+ * delete_file — 删除文件
5
+ *
6
+ * 删除操作始终需要用户确认(不可逆)。
7
+ * 仅支持删除文件,不支持删除目录。
8
+ * 系统路径始终拒绝。
9
+ */
10
+ export const deleteFileTool = {
11
+ name: 'delete_file',
12
+ description: 'Delete a file. Always requires user confirmation.',
13
+ parameters: {
14
+ type: 'object',
15
+ properties: {
16
+ path: {
17
+ type: 'string',
18
+ description: 'File path (relative to workspace or absolute)'
19
+ }
20
+ },
21
+ required: ['path']
22
+ },
23
+ async execute(args, ctx) {
24
+ const userPath = args.path;
25
+ if (!userPath) {
26
+ return { success: false, output: '', error: '缺少参数: path' };
27
+ }
28
+ const resolved = ctx.resolvePath(userPath);
29
+ const { path: filePath, classification } = resolved;
30
+ if (!args.__confirmed) {
31
+ throw new PendingConfirmation('delete_file', { path: userPath }, `确认删除 "${userPath}"?此操作不可恢复。`);
32
+ }
33
+ if (classification === 'reject') {
34
+ return { success: false, output: '', error: `拒绝删除系统路径: ${userPath}` };
35
+ }
36
+ try {
37
+ const info = await stat(filePath);
38
+ if (info.isDirectory()) {
39
+ return { success: false, output: '', error: `目标是目录而非文件: ${userPath}` };
40
+ }
41
+ await rm(filePath);
42
+ return { success: true, output: `已删除文件: ${userPath}` };
43
+ }
44
+ catch (error) {
45
+ if (error.code === 'ENOENT') {
46
+ return { success: false, output: '', error: `路径不存在: ${userPath}` };
47
+ }
48
+ return { success: false, output: '', error: `删除失败: ${error.message}` };
49
+ }
50
+ }
51
+ };
52
+ //# sourceMappingURL=delete-file.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"delete-file.js","sourceRoot":"","sources":["../../../src/tool/tools/delete-file.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAE,IAAI,EAAE,MAAM,kBAAkB,CAAC;AAG5C,OAAO,EAAE,mBAAmB,EAAE,MAAM,aAAa,CAAC;AAElD;;;;;;GAMG;AACH,MAAM,CAAC,MAAM,cAAc,GAAY;IACtC,IAAI,EAAE,aAAa;IACnB,WAAW,EAAE,mDAAmD;IAChE,UAAU,EAAE;QACX,IAAI,EAAE,QAAQ;QACd,UAAU,EAAE;YACX,IAAI,EAAE;gBACL,IAAI,EAAE,QAAQ;gBACd,WAAW,EAAE,+CAA+C;aAC5D;SACD;QACD,QAAQ,EAAE,CAAC,MAAM,CAAC;KAClB;IAED,KAAK,CAAC,OAAO,CAAC,IAA6B,EAAE,GAAgB;QAC5D,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAc,CAAC;QACrC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACf,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,EAAE,EAAE,KAAK,EAAE,YAAY,EAAE,CAAC;QAC5D,CAAC;QAED,MAAM,QAAQ,GAAG,GAAG,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;QAC3C,MAAM,EAAE,IAAI,EAAE,QAAQ,EAAE,cAAc,EAAE,GAAG,QAAQ,CAAC;QAEpD,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;YACvB,MAAM,IAAI,mBAAmB,CAC5B,aAAa,EACb,EAAE,IAAI,EAAE,QAAQ,EAAE,EAClB,SAAS,QAAQ,YAAY,CAC7B,CAAC;QACH,CAAC;QAED,IAAI,cAAc,KAAK,QAAQ,EAAE,CAAC;YACjC,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,EAAE,EAAE,KAAK,EAAE,aAAa,QAAQ,EAAE,EAAE,CAAC;QACvE,CAAC;QAED,IAAI,CAAC;YACJ,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,CAAC;YAElC,IAAI,IAAI,CAAC,WAAW,EAAE,EAAE,CAAC;gBACxB,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,EAAE,EAAE,KAAK,EAAE,cAAc,QAAQ,EAAE,EAAE,CAAC;YACxE,CAAC;YAED,MAAM,EAAE,CAAC,QAAQ,CAAC,CAAC;YACnB,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,UAAU,QAAQ,EAAE,EAAE,CAAC;QACxD,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YAChB,IAAK,KAA+B,CAAC,IAAI,KAAK,QAAQ,EAAE,CAAC;gBACxD,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,EAAE,EAAE,KAAK,EAAE,UAAU,QAAQ,EAAE,EAAE,CAAC;YACpE,CAAC;YACD,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,EAAE,EAAE,KAAK,EAAE,SAAU,KAAe,CAAC,OAAO,EAAE,EAAE,CAAC;QACnF,CAAC;IACF,CAAC;CACD,CAAC"}
@@ -0,0 +1,10 @@
1
+ import type { ToolDef } from '../types.js';
2
+ /**
3
+ * edit — 精确字符串替换编辑文件
4
+ *
5
+ * 在文件中查找 oldString 并替换为 newString。
6
+ * 使用原子写入,自动保留原文件的 BOM 和行尾格式。
7
+ * 非 replaceAll 模式下,oldString 必须在文件中恰好出现一次。
8
+ */
9
+ export declare const editTool: ToolDef;
10
+ //# sourceMappingURL=edit.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"edit.d.ts","sourceRoot":"","sources":["../../../src/tool/tools/edit.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,OAAO,EAAc,MAAM,aAAa,CAAC;AA0BvD;;;;;;GAMG;AACH,eAAO,MAAM,QAAQ,EAAE,OAgJtB,CAAC"}