@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.
- package/dist/agent/background.d.ts +6 -0
- package/dist/agent/background.d.ts.map +1 -0
- package/dist/agent/background.js +58 -0
- package/dist/agent/background.js.map +1 -0
- package/dist/agent/context-builder.d.ts +23 -0
- package/dist/agent/context-builder.d.ts.map +1 -0
- package/dist/agent/context-builder.js +102 -0
- package/dist/agent/context-builder.js.map +1 -0
- package/dist/agent/diary.d.ts +4 -0
- package/dist/agent/diary.d.ts.map +1 -0
- package/dist/agent/diary.js +67 -0
- package/dist/agent/diary.js.map +1 -0
- package/dist/agent/index.d.ts +22 -0
- package/dist/agent/index.d.ts.map +1 -0
- package/dist/agent/index.js +20 -0
- package/dist/agent/index.js.map +1 -0
- package/dist/agent/logger.d.ts +23 -0
- package/dist/agent/logger.d.ts.map +1 -0
- package/dist/agent/logger.js +70 -0
- package/dist/agent/logger.js.map +1 -0
- package/dist/agent/logger.test.d.ts +2 -0
- package/dist/agent/logger.test.d.ts.map +1 -0
- package/dist/agent/logger.test.js +28 -0
- package/dist/agent/logger.test.js.map +1 -0
- package/dist/agent/loop.d.ts +52 -0
- package/dist/agent/loop.d.ts.map +1 -0
- package/dist/agent/loop.js +557 -0
- package/dist/agent/loop.js.map +1 -0
- package/dist/agent/message-sanitizer.d.ts +13 -0
- package/dist/agent/message-sanitizer.d.ts.map +1 -0
- package/dist/agent/message-sanitizer.js +138 -0
- package/dist/agent/message-sanitizer.js.map +1 -0
- package/dist/agent/message-sanitizer.test.d.ts +2 -0
- package/dist/agent/message-sanitizer.test.d.ts.map +1 -0
- package/dist/agent/message-sanitizer.test.js +110 -0
- package/dist/agent/message-sanitizer.test.js.map +1 -0
- package/dist/agent/prompts.d.ts +15 -0
- package/dist/agent/prompts.d.ts.map +1 -0
- package/dist/agent/prompts.js +34 -0
- package/dist/agent/prompts.js.map +1 -0
- package/dist/agent/summarize-worker.d.ts +6 -0
- package/dist/agent/summarize-worker.d.ts.map +1 -0
- package/dist/agent/summarize-worker.js +62 -0
- package/dist/agent/summarize-worker.js.map +1 -0
- package/dist/agent/summarizer.d.ts +10 -0
- package/dist/agent/summarizer.d.ts.map +1 -0
- package/dist/agent/summarizer.js +133 -0
- package/dist/agent/summarizer.js.map +1 -0
- package/dist/agent/types.d.ts +135 -0
- package/dist/agent/types.d.ts.map +1 -0
- package/dist/agent/types.js +21 -0
- package/dist/agent/types.js.map +1 -0
- package/dist/ai/base.d.ts +19 -0
- package/dist/ai/base.d.ts.map +1 -0
- package/dist/ai/base.js +2 -0
- package/dist/ai/base.js.map +1 -0
- package/dist/ai/deepseek.d.ts +15 -0
- package/dist/ai/deepseek.d.ts.map +1 -0
- package/dist/ai/deepseek.js +24 -0
- package/dist/ai/deepseek.js.map +1 -0
- package/dist/ai/factory.d.ts +4 -0
- package/dist/ai/factory.d.ts.map +1 -0
- package/dist/ai/factory.js +53 -0
- package/dist/ai/factory.js.map +1 -0
- package/dist/ai/index.d.ts +43 -0
- package/dist/ai/index.d.ts.map +1 -0
- package/dist/ai/index.js +36 -0
- package/dist/ai/index.js.map +1 -0
- package/dist/ai/models.d.ts +13 -0
- package/dist/ai/models.d.ts.map +1 -0
- package/dist/ai/models.js +67 -0
- package/dist/ai/models.js.map +1 -0
- package/dist/ai/ollama.d.ts +13 -0
- package/dist/ai/ollama.d.ts.map +1 -0
- package/dist/ai/ollama.js +32 -0
- package/dist/ai/ollama.js.map +1 -0
- package/dist/ai/openai.d.ts +46 -0
- package/dist/ai/openai.d.ts.map +1 -0
- package/dist/ai/openai.js +90 -0
- package/dist/ai/openai.js.map +1 -0
- package/dist/ai/types.d.ts +154 -0
- package/dist/ai/types.d.ts.map +1 -0
- package/dist/ai/types.js +2 -0
- package/dist/ai/types.js.map +1 -0
- package/dist/ai/utils.d.ts +47 -0
- package/dist/ai/utils.d.ts.map +1 -0
- package/dist/ai/utils.js +145 -0
- package/dist/ai/utils.js.map +1 -0
- package/dist/ai/xiaomi.d.ts +15 -0
- package/dist/ai/xiaomi.d.ts.map +1 -0
- package/dist/ai/xiaomi.js +23 -0
- package/dist/ai/xiaomi.js.map +1 -0
- package/dist/chat-confirm.d.ts +4 -0
- package/dist/chat-confirm.d.ts.map +1 -0
- package/dist/chat-confirm.js +2 -0
- package/dist/chat-confirm.js.map +1 -0
- package/dist/chat-steering.d.ts +6 -0
- package/dist/chat-steering.d.ts.map +1 -0
- package/dist/chat-steering.js +2 -0
- package/dist/chat-steering.js.map +1 -0
- package/dist/concurrency/background-worker.d.ts +16 -0
- package/dist/concurrency/background-worker.d.ts.map +1 -0
- package/dist/concurrency/background-worker.js +62 -0
- package/dist/concurrency/background-worker.js.map +1 -0
- package/dist/concurrency/background-worker.test.d.ts +2 -0
- package/dist/concurrency/background-worker.test.d.ts.map +1 -0
- package/dist/concurrency/background-worker.test.js +55 -0
- package/dist/concurrency/background-worker.test.js.map +1 -0
- package/dist/concurrency/file-mutex.d.ts +8 -0
- package/dist/concurrency/file-mutex.d.ts.map +1 -0
- package/dist/concurrency/file-mutex.js +41 -0
- package/dist/concurrency/file-mutex.js.map +1 -0
- package/dist/concurrency/file-mutex.test.d.ts +2 -0
- package/dist/concurrency/file-mutex.test.d.ts.map +1 -0
- package/dist/concurrency/file-mutex.test.js +50 -0
- package/dist/concurrency/file-mutex.test.js.map +1 -0
- package/dist/concurrency/index.d.ts +5 -0
- package/dist/concurrency/index.d.ts.map +1 -0
- package/dist/concurrency/index.js +4 -0
- package/dist/concurrency/index.js.map +1 -0
- package/dist/concurrency/session-lock.d.ts +8 -0
- package/dist/concurrency/session-lock.d.ts.map +1 -0
- package/dist/concurrency/session-lock.js +41 -0
- package/dist/concurrency/session-lock.js.map +1 -0
- package/dist/concurrency/session-lock.test.d.ts +2 -0
- package/dist/concurrency/session-lock.test.d.ts.map +1 -0
- package/dist/concurrency/session-lock.test.js +51 -0
- package/dist/concurrency/session-lock.test.js.map +1 -0
- package/dist/config/index.d.ts +12 -0
- package/dist/config/index.d.ts.map +1 -0
- package/dist/config/index.js +10 -0
- package/dist/config/index.js.map +1 -0
- package/dist/config/store.d.ts +17 -0
- package/dist/config/store.d.ts.map +1 -0
- package/dist/config/store.js +214 -0
- package/dist/config/store.js.map +1 -0
- package/dist/config/types.d.ts +44 -0
- package/dist/config/types.d.ts.map +1 -0
- package/dist/config/types.js +2 -0
- package/dist/config/types.js.map +1 -0
- package/dist/gateway/adapters/email.d.ts +23 -0
- package/dist/gateway/adapters/email.d.ts.map +1 -0
- package/dist/gateway/adapters/email.js +145 -0
- package/dist/gateway/adapters/email.js.map +1 -0
- package/dist/gateway/adapters/telegram-sessions.d.ts +4 -0
- package/dist/gateway/adapters/telegram-sessions.d.ts.map +1 -0
- package/dist/gateway/adapters/telegram-sessions.js +39 -0
- package/dist/gateway/adapters/telegram-sessions.js.map +1 -0
- package/dist/gateway/adapters/telegram.d.ts +22 -0
- package/dist/gateway/adapters/telegram.d.ts.map +1 -0
- package/dist/gateway/adapters/telegram.js +131 -0
- package/dist/gateway/adapters/telegram.js.map +1 -0
- package/dist/gateway/dispatcher.d.ts +19 -0
- package/dist/gateway/dispatcher.d.ts.map +1 -0
- package/dist/gateway/dispatcher.js +81 -0
- package/dist/gateway/dispatcher.js.map +1 -0
- package/dist/gateway/inbound-handler.d.ts +3 -0
- package/dist/gateway/inbound-handler.d.ts.map +1 -0
- package/dist/gateway/inbound-handler.js +95 -0
- package/dist/gateway/inbound-handler.js.map +1 -0
- package/dist/gateway/index.d.ts +9 -0
- package/dist/gateway/index.d.ts.map +1 -0
- package/dist/gateway/index.js +6 -0
- package/dist/gateway/index.js.map +1 -0
- package/dist/gateway/lifecycle.d.ts +3 -0
- package/dist/gateway/lifecycle.d.ts.map +1 -0
- package/dist/gateway/lifecycle.js +38 -0
- package/dist/gateway/lifecycle.js.map +1 -0
- package/dist/gateway/types.d.ts +32 -0
- package/dist/gateway/types.d.ts.map +1 -0
- package/dist/gateway/types.js +2 -0
- package/dist/gateway/types.js.map +1 -0
- package/dist/index.d.ts +23 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +14 -0
- package/dist/index.js.map +1 -0
- package/dist/markdown.d.ts +2 -0
- package/dist/markdown.d.ts.map +1 -0
- package/dist/markdown.js +94 -0
- package/dist/markdown.js.map +1 -0
- package/dist/paths.d.ts +5 -0
- package/dist/paths.d.ts.map +1 -0
- package/dist/paths.js +17 -0
- package/dist/paths.js.map +1 -0
- package/dist/storage/index.d.ts +10 -0
- package/dist/storage/index.d.ts.map +1 -0
- package/dist/storage/index.js +18 -0
- package/dist/storage/index.js.map +1 -0
- package/dist/storage/memory.d.ts +39 -0
- package/dist/storage/memory.d.ts.map +1 -0
- package/dist/storage/memory.js +252 -0
- package/dist/storage/memory.js.map +1 -0
- package/dist/storage/sqlite.d.ts +44 -0
- package/dist/storage/sqlite.d.ts.map +1 -0
- package/dist/storage/sqlite.js +275 -0
- package/dist/storage/sqlite.js.map +1 -0
- package/dist/storage/types.d.ts +134 -0
- package/dist/storage/types.d.ts.map +1 -0
- package/dist/storage/types.js +2 -0
- package/dist/storage/types.js.map +1 -0
- package/dist/storage/utils.d.ts +2 -0
- package/dist/storage/utils.d.ts.map +1 -0
- package/dist/storage/utils.js +8 -0
- package/dist/storage/utils.js.map +1 -0
- package/dist/task/executor.d.ts +3 -0
- package/dist/task/executor.d.ts.map +1 -0
- package/dist/task/executor.js +80 -0
- package/dist/task/executor.js.map +1 -0
- package/dist/task/index.d.ts +5 -0
- package/dist/task/index.d.ts.map +1 -0
- package/dist/task/index.js +4 -0
- package/dist/task/index.js.map +1 -0
- package/dist/task/scheduler.d.ts +5 -0
- package/dist/task/scheduler.d.ts.map +1 -0
- package/dist/task/scheduler.js +47 -0
- package/dist/task/scheduler.js.map +1 -0
- package/dist/task/store.d.ts +14 -0
- package/dist/task/store.d.ts.map +1 -0
- package/dist/task/store.js +156 -0
- package/dist/task/store.js.map +1 -0
- package/dist/task/types.d.ts +13 -0
- package/dist/task/types.d.ts.map +1 -0
- package/dist/task/types.js +2 -0
- package/dist/task/types.js.map +1 -0
- package/dist/tool/env.d.ts +20 -0
- package/dist/tool/env.d.ts.map +1 -0
- package/dist/tool/env.js +26 -0
- package/dist/tool/env.js.map +1 -0
- package/dist/tool/env.test.d.ts +2 -0
- package/dist/tool/env.test.d.ts.map +1 -0
- package/dist/tool/env.test.js +42 -0
- package/dist/tool/env.test.js.map +1 -0
- package/dist/tool/index.d.ts +42 -0
- package/dist/tool/index.d.ts.map +1 -0
- package/dist/tool/index.js +53 -0
- package/dist/tool/index.js.map +1 -0
- package/dist/tool/registry.d.ts +43 -0
- package/dist/tool/registry.d.ts.map +1 -0
- package/dist/tool/registry.js +79 -0
- package/dist/tool/registry.js.map +1 -0
- package/dist/tool/safeguard.d.ts +21 -0
- package/dist/tool/safeguard.d.ts.map +1 -0
- package/dist/tool/safeguard.js +212 -0
- package/dist/tool/safeguard.js.map +1 -0
- package/dist/tool/tools/delete-file.d.ts +10 -0
- package/dist/tool/tools/delete-file.d.ts.map +1 -0
- package/dist/tool/tools/delete-file.js +52 -0
- package/dist/tool/tools/delete-file.js.map +1 -0
- package/dist/tool/tools/edit.d.ts +10 -0
- package/dist/tool/tools/edit.d.ts.map +1 -0
- package/dist/tool/tools/edit.js +159 -0
- package/dist/tool/tools/edit.js.map +1 -0
- package/dist/tool/tools/exec.d.ts +12 -0
- package/dist/tool/tools/exec.d.ts.map +1 -0
- package/dist/tool/tools/exec.js +170 -0
- package/dist/tool/tools/exec.js.map +1 -0
- package/dist/tool/tools/file-utils.d.ts +13 -0
- package/dist/tool/tools/file-utils.d.ts.map +1 -0
- package/dist/tool/tools/file-utils.js +65 -0
- package/dist/tool/tools/file-utils.js.map +1 -0
- package/dist/tool/tools/read-file.d.ts +10 -0
- package/dist/tool/tools/read-file.d.ts.map +1 -0
- package/dist/tool/tools/read-file.js +116 -0
- package/dist/tool/tools/read-file.js.map +1 -0
- package/dist/tool/tools/read-memory.d.ts +3 -0
- package/dist/tool/tools/read-memory.d.ts.map +1 -0
- package/dist/tool/tools/read-memory.js +58 -0
- package/dist/tool/tools/read-memory.js.map +1 -0
- package/dist/tool/tools/read-tasks.d.ts +3 -0
- package/dist/tool/tools/read-tasks.d.ts.map +1 -0
- package/dist/tool/tools/read-tasks.js +29 -0
- package/dist/tool/tools/read-tasks.js.map +1 -0
- package/dist/tool/tools/schedule-task.d.ts +3 -0
- package/dist/tool/tools/schedule-task.d.ts.map +1 -0
- package/dist/tool/tools/schedule-task.js +50 -0
- package/dist/tool/tools/schedule-task.js.map +1 -0
- package/dist/tool/tools/search-history.d.ts +4 -0
- package/dist/tool/tools/search-history.d.ts.map +1 -0
- package/dist/tool/tools/search-history.js +58 -0
- package/dist/tool/tools/search-history.js.map +1 -0
- package/dist/tool/tools/web-search.d.ts +3 -0
- package/dist/tool/tools/web-search.d.ts.map +1 -0
- package/dist/tool/tools/web-search.js +89 -0
- package/dist/tool/tools/web-search.js.map +1 -0
- package/dist/tool/tools/write-file.d.ts +11 -0
- package/dist/tool/tools/write-file.d.ts.map +1 -0
- package/dist/tool/tools/write-file.js +79 -0
- package/dist/tool/tools/write-file.js.map +1 -0
- package/dist/tool/tools/write-memory.d.ts +3 -0
- package/dist/tool/tools/write-memory.d.ts.map +1 -0
- package/dist/tool/tools/write-memory.js +99 -0
- package/dist/tool/tools/write-memory.js.map +1 -0
- package/dist/tool/types.d.ts +63 -0
- package/dist/tool/types.d.ts.map +1 -0
- package/dist/tool/types.js +33 -0
- package/dist/tool/types.js.map +1 -0
- 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 @@
|
|
|
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"}
|