opc-agent 4.2.13 → 5.0.0-rc.1
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/.opc/memory.db +0 -0
- package/.opc/schedules.json +784 -0
- package/.opc/voice-tmp/tts-1776835848670.mp3 +0 -0
- package/.opc/voice-tmp/tts-1776835873696.mp3 +0 -0
- package/README.md +125 -141
- package/README.zh-CN.md +75 -160
- package/TASK.md +34 -0
- package/data/brain.db/deepbrain.sqlite +0 -0
- package/dist/channels/api.d.ts +14 -0
- package/dist/channels/api.d.ts.map +1 -0
- package/dist/channels/api.js +58 -0
- package/dist/channels/api.js.map +1 -0
- package/dist/channels/voice.d.ts +21 -0
- package/dist/channels/voice.d.ts.map +1 -1
- package/dist/channels/voice.js +31 -1
- package/dist/channels/voice.js.map +1 -1
- package/dist/cli/chat.d.ts.map +1 -1
- package/dist/cli/chat.js +104 -0
- package/dist/cli/chat.js.map +1 -1
- package/dist/cli/setup.d.ts +1 -1
- package/dist/cli/setup.d.ts.map +1 -1
- package/dist/cli/setup.js +263 -33
- package/dist/cli/setup.js.map +1 -1
- package/dist/cli.js +201 -116
- package/dist/cli.js.map +1 -1
- package/dist/core/agent-loop.d.ts +3 -0
- package/dist/core/agent-loop.d.ts.map +1 -0
- package/dist/core/agent-loop.js +51 -0
- package/dist/core/agent-loop.js.map +1 -0
- package/dist/core/context-assembler.d.ts +12 -0
- package/dist/core/context-assembler.d.ts.map +1 -0
- package/dist/core/context-assembler.js +81 -0
- package/dist/core/context-assembler.js.map +1 -0
- package/dist/core/guardrails.d.ts +16 -0
- package/dist/core/guardrails.d.ts.map +1 -0
- package/dist/core/guardrails.js +62 -0
- package/dist/core/guardrails.js.map +1 -0
- package/dist/core/index.d.ts +1 -0
- package/dist/core/index.d.ts.map +1 -0
- package/dist/core/index.js +3 -0
- package/dist/core/index.js.map +1 -0
- package/dist/core/iteration-budget.d.ts +12 -0
- package/dist/core/iteration-budget.d.ts.map +1 -0
- package/dist/core/iteration-budget.js +26 -0
- package/dist/core/iteration-budget.js.map +1 -0
- package/dist/core/runtime.js +1 -1
- package/dist/core/runtime.js.map +1 -1
- package/dist/core/types.d.ts +412 -0
- package/dist/core/types.d.ts.map +1 -1
- package/dist/deepbrain/embedding.d.ts +7 -0
- package/dist/deepbrain/embedding.d.ts.map +1 -0
- package/dist/deepbrain/embedding.js +108 -0
- package/dist/deepbrain/embedding.js.map +1 -0
- package/dist/deepbrain/index.d.ts +8 -0
- package/dist/deepbrain/index.d.ts.map +1 -0
- package/dist/deepbrain/index.js +19 -0
- package/dist/deepbrain/index.js.map +1 -0
- package/dist/deepbrain/migrate.d.ts +2 -0
- package/dist/deepbrain/migrate.d.ts.map +1 -0
- package/dist/deepbrain/migrate.js +139 -0
- package/dist/deepbrain/migrate.js.map +1 -0
- package/dist/deepbrain/provider.d.ts +13 -0
- package/dist/deepbrain/provider.d.ts.map +1 -0
- package/dist/deepbrain/provider.js +85 -0
- package/dist/deepbrain/provider.js.map +1 -0
- package/dist/deepbrain/recall.d.ts +9 -0
- package/dist/deepbrain/recall.d.ts.map +1 -0
- package/dist/deepbrain/recall.js +48 -0
- package/dist/deepbrain/recall.js.map +1 -0
- package/dist/deepbrain/store.d.ts +36 -0
- package/dist/deepbrain/store.d.ts.map +1 -0
- package/dist/deepbrain/store.js +342 -0
- package/dist/deepbrain/store.js.map +1 -0
- package/dist/deepbrain/workspace-files.d.ts +5 -0
- package/dist/deepbrain/workspace-files.d.ts.map +1 -0
- package/dist/deepbrain/workspace-files.js +159 -0
- package/dist/deepbrain/workspace-files.js.map +1 -0
- package/dist/evolution/index.d.ts +1 -0
- package/dist/evolution/index.d.ts.map +1 -0
- package/dist/evolution/index.js +3 -0
- package/dist/evolution/index.js.map +1 -0
- package/dist/evolution/l1-experience.d.ts +11 -0
- package/dist/evolution/l1-experience.d.ts.map +1 -0
- package/dist/evolution/l1-experience.js +185 -0
- package/dist/evolution/l1-experience.js.map +1 -0
- package/dist/evolution/l2-consolidation.d.ts +4 -0
- package/dist/evolution/l2-consolidation.d.ts.map +1 -0
- package/dist/evolution/l2-consolidation.js +106 -0
- package/dist/evolution/l2-consolidation.js.map +1 -0
- package/dist/evolution/l2-memskill.d.ts +12 -0
- package/dist/evolution/l2-memskill.d.ts.map +1 -0
- package/dist/evolution/l2-memskill.js +57 -0
- package/dist/evolution/l2-memskill.js.map +1 -0
- package/dist/evolution/l3-skill-discover.d.ts +4 -0
- package/dist/evolution/l3-skill-discover.d.ts.map +1 -0
- package/dist/evolution/l3-skill-discover.js +139 -0
- package/dist/evolution/l3-skill-discover.js.map +1 -0
- package/dist/evolution/l3-skill-verify.d.ts +12 -0
- package/dist/evolution/l3-skill-verify.d.ts.map +1 -0
- package/dist/evolution/l3-skill-verify.js +122 -0
- package/dist/evolution/l3-skill-verify.js.map +1 -0
- package/dist/evolution/l4-desensitize.d.ts +7 -0
- package/dist/evolution/l4-desensitize.d.ts.map +1 -0
- package/dist/evolution/l4-desensitize.js +30 -0
- package/dist/evolution/l4-desensitize.js.map +1 -0
- package/dist/evolution/l4-group-evolve.d.ts +8 -0
- package/dist/evolution/l4-group-evolve.d.ts.map +1 -0
- package/dist/evolution/l4-group-evolve.js +15 -0
- package/dist/evolution/l4-group-evolve.js.map +1 -0
- package/dist/evolution/maturity-scorer.d.ts +11 -0
- package/dist/evolution/maturity-scorer.d.ts.map +1 -0
- package/dist/evolution/maturity-scorer.js +21 -0
- package/dist/evolution/maturity-scorer.js.map +1 -0
- package/dist/index.d.ts +7 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +33 -5
- package/dist/index.js.map +1 -1
- package/dist/providers/agentkits.d.ts +20 -0
- package/dist/providers/agentkits.d.ts.map +1 -0
- package/dist/providers/agentkits.js +173 -0
- package/dist/providers/agentkits.js.map +1 -0
- package/dist/providers/model-provider.d.ts +16 -0
- package/dist/providers/model-provider.d.ts.map +1 -0
- package/dist/providers/model-provider.js +13 -0
- package/dist/providers/model-provider.js.map +1 -0
- package/dist/providers/model-recommender.d.ts +15 -0
- package/dist/providers/model-recommender.d.ts.map +1 -0
- package/dist/providers/model-recommender.js +71 -0
- package/dist/providers/model-recommender.js.map +1 -0
- package/dist/providers/ollama.d.ts +22 -0
- package/dist/providers/ollama.d.ts.map +1 -0
- package/dist/providers/ollama.js +176 -0
- package/dist/providers/ollama.js.map +1 -0
- package/dist/providers/openai-compat.d.ts +23 -0
- package/dist/providers/openai-compat.d.ts.map +1 -0
- package/dist/providers/openai-compat.js +184 -0
- package/dist/providers/openai-compat.js.map +1 -0
- package/dist/providers/router.d.ts +11 -0
- package/dist/providers/router.d.ts.map +1 -0
- package/dist/providers/router.js +48 -0
- package/dist/providers/router.js.map +1 -0
- package/dist/scheduler/cron.d.ts +19 -0
- package/dist/scheduler/cron.d.ts.map +1 -0
- package/dist/scheduler/cron.js +64 -0
- package/dist/scheduler/cron.js.map +1 -0
- package/dist/schema/oad.d.ts +72 -72
- package/dist/skills/loader.d.ts +16 -0
- package/dist/skills/loader.d.ts.map +1 -0
- package/dist/skills/loader.js +114 -0
- package/dist/skills/loader.js.map +1 -0
- package/dist/skills/matcher.d.ts +18 -0
- package/dist/skills/matcher.d.ts.map +1 -0
- package/dist/skills/matcher.js +70 -0
- package/dist/skills/matcher.js.map +1 -0
- package/dist/studio/agent-pool.d.ts +17 -0
- package/dist/studio/agent-pool.d.ts.map +1 -0
- package/dist/studio/agent-pool.js +35 -0
- package/dist/studio/agent-pool.js.map +1 -0
- package/dist/studio/assistant-tools.d.ts +4 -0
- package/dist/studio/assistant-tools.d.ts.map +1 -0
- package/dist/studio/assistant-tools.js +36 -0
- package/dist/studio/assistant-tools.js.map +1 -0
- package/dist/studio/index.d.ts +1 -0
- package/dist/studio/index.d.ts.map +1 -0
- package/dist/studio/index.js +3 -0
- package/dist/studio/index.js.map +1 -0
- package/dist/studio/server.d.ts +3 -0
- package/dist/studio/server.d.ts.map +1 -1
- package/dist/studio/server.js +156 -24
- package/dist/studio/server.js.map +1 -1
- package/dist/templates/index.d.ts +1 -0
- package/dist/templates/index.d.ts.map +1 -0
- package/dist/templates/index.js +3 -0
- package/dist/templates/index.js.map +1 -0
- package/dist/templates/roles/index.d.ts +4 -0
- package/dist/templates/roles/index.d.ts.map +1 -0
- package/dist/templates/roles/index.js +46 -0
- package/dist/templates/roles/index.js.map +1 -0
- package/dist/templates/template-provider.d.ts +16 -0
- package/dist/templates/template-provider.d.ts.map +1 -0
- package/dist/templates/template-provider.js +60 -0
- package/dist/templates/template-provider.js.map +1 -0
- package/dist/tools/builtin/definitions.d.ts +7 -0
- package/dist/tools/builtin/definitions.d.ts.map +1 -0
- package/dist/tools/builtin/definitions.js +60 -0
- package/dist/tools/builtin/definitions.js.map +1 -0
- package/dist/tools/execute-code.d.ts +20 -0
- package/dist/tools/execute-code.d.ts.map +1 -0
- package/dist/tools/execute-code.js +92 -0
- package/dist/tools/execute-code.js.map +1 -0
- package/dist/tools/hooks.d.ts +47 -0
- package/dist/tools/hooks.d.ts.map +1 -0
- package/dist/tools/hooks.js +69 -0
- package/dist/tools/hooks.js.map +1 -0
- package/dist/tools/index.d.ts +9 -0
- package/dist/tools/index.d.ts.map +1 -0
- package/dist/tools/index.js +16 -0
- package/dist/tools/index.js.map +1 -0
- package/dist/tools/permission.d.ts +20 -0
- package/dist/tools/permission.d.ts.map +1 -0
- package/dist/tools/permission.js +35 -0
- package/dist/tools/permission.js.map +1 -0
- package/dist/tools/registry.d.ts +25 -0
- package/dist/tools/registry.d.ts.map +1 -0
- package/dist/tools/registry.js +42 -0
- package/dist/tools/registry.js.map +1 -0
- package/package.json +1 -1
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.BUILTIN_DEFINITIONS = exports.shellCommandTool = exports.webSearchTool = exports.writeFileTool = exports.readFileTool = void 0;
|
|
4
|
+
exports.readFileTool = {
|
|
5
|
+
name: 'read_file',
|
|
6
|
+
description: 'Read the contents of a file at a given path',
|
|
7
|
+
parameters: {
|
|
8
|
+
type: 'object',
|
|
9
|
+
properties: {
|
|
10
|
+
path: { type: 'string', description: 'Relative or absolute path to the file' },
|
|
11
|
+
encoding: { type: 'string', enum: ['utf-8', 'base64'], default: 'utf-8' },
|
|
12
|
+
},
|
|
13
|
+
required: ['path'],
|
|
14
|
+
},
|
|
15
|
+
};
|
|
16
|
+
exports.writeFileTool = {
|
|
17
|
+
name: 'write_file',
|
|
18
|
+
description: 'Write or overwrite content to a file at a given path',
|
|
19
|
+
parameters: {
|
|
20
|
+
type: 'object',
|
|
21
|
+
properties: {
|
|
22
|
+
path: { type: 'string', description: 'Relative or absolute path to the file' },
|
|
23
|
+
content: { type: 'string', description: 'Content to write' },
|
|
24
|
+
encoding: { type: 'string', enum: ['utf-8', 'base64'], default: 'utf-8' },
|
|
25
|
+
},
|
|
26
|
+
required: ['path', 'content'],
|
|
27
|
+
},
|
|
28
|
+
};
|
|
29
|
+
exports.webSearchTool = {
|
|
30
|
+
name: 'web_search',
|
|
31
|
+
description: 'Search the web and return a list of results with titles, URLs, and snippets',
|
|
32
|
+
parameters: {
|
|
33
|
+
type: 'object',
|
|
34
|
+
properties: {
|
|
35
|
+
query: { type: 'string', description: 'The search query' },
|
|
36
|
+
numResults: { type: 'number', description: 'Max results to return (default 5)', default: 5 },
|
|
37
|
+
},
|
|
38
|
+
required: ['query'],
|
|
39
|
+
},
|
|
40
|
+
};
|
|
41
|
+
exports.shellCommandTool = {
|
|
42
|
+
name: 'shell_command',
|
|
43
|
+
description: 'Run a shell command and return stdout/stderr (requires explicit permission)',
|
|
44
|
+
parameters: {
|
|
45
|
+
type: 'object',
|
|
46
|
+
properties: {
|
|
47
|
+
command: { type: 'string', description: 'Shell command to execute' },
|
|
48
|
+
cwd: { type: 'string', description: 'Working directory for the command' },
|
|
49
|
+
timeoutMs: { type: 'number', description: 'Timeout in milliseconds (default 30000)', default: 30000 },
|
|
50
|
+
},
|
|
51
|
+
required: ['command'],
|
|
52
|
+
},
|
|
53
|
+
};
|
|
54
|
+
exports.BUILTIN_DEFINITIONS = [
|
|
55
|
+
exports.readFileTool,
|
|
56
|
+
exports.writeFileTool,
|
|
57
|
+
exports.webSearchTool,
|
|
58
|
+
exports.shellCommandTool,
|
|
59
|
+
];
|
|
60
|
+
//# sourceMappingURL=definitions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"definitions.js","sourceRoot":"","sources":["../../../src/tools/builtin/definitions.ts"],"names":[],"mappings":";;;AAEa,QAAA,YAAY,GAAmB;IAC1C,IAAI,EAAE,WAAW;IACjB,WAAW,EAAE,6CAA6C;IAC1D,UAAU,EAAE;QACV,IAAI,EAAE,QAAQ;QACd,UAAU,EAAE;YACV,IAAI,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,uCAAuC,EAAE;YAC9E,QAAQ,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,OAAO,EAAE,QAAQ,CAAC,EAAE,OAAO,EAAE,OAAO,EAAE;SAC1E;QACD,QAAQ,EAAE,CAAC,MAAM,CAAC;KACnB;CACF,CAAC;AAEW,QAAA,aAAa,GAAmB;IAC3C,IAAI,EAAE,YAAY;IAClB,WAAW,EAAE,sDAAsD;IACnE,UAAU,EAAE;QACV,IAAI,EAAE,QAAQ;QACd,UAAU,EAAE;YACV,IAAI,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,uCAAuC,EAAE;YAC9E,OAAO,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,kBAAkB,EAAE;YAC5D,QAAQ,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,OAAO,EAAE,QAAQ,CAAC,EAAE,OAAO,EAAE,OAAO,EAAE;SAC1E;QACD,QAAQ,EAAE,CAAC,MAAM,EAAE,SAAS,CAAC;KAC9B;CACF,CAAC;AAEW,QAAA,aAAa,GAAmB;IAC3C,IAAI,EAAE,YAAY;IAClB,WAAW,EAAE,6EAA6E;IAC1F,UAAU,EAAE;QACV,IAAI,EAAE,QAAQ;QACd,UAAU,EAAE;YACV,KAAK,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,kBAAkB,EAAE;YAC1D,UAAU,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,mCAAmC,EAAE,OAAO,EAAE,CAAC,EAAE;SAC7F;QACD,QAAQ,EAAE,CAAC,OAAO,CAAC;KACpB;CACF,CAAC;AAEW,QAAA,gBAAgB,GAAmB;IAC9C,IAAI,EAAE,eAAe;IACrB,WAAW,EAAE,6EAA6E;IAC1F,UAAU,EAAE;QACV,IAAI,EAAE,QAAQ;QACd,UAAU,EAAE;YACV,OAAO,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,0BAA0B,EAAE;YACpE,GAAG,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,mCAAmC,EAAE;YACzE,SAAS,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,yCAAyC,EAAE,OAAO,EAAE,KAAK,EAAE;SACtG;QACD,QAAQ,EAAE,CAAC,SAAS,CAAC;KACtB;CACF,CAAC;AAEW,QAAA,mBAAmB,GAAqB;IACnD,oBAAY;IACZ,qBAAa;IACb,qBAAa;IACb,wBAAgB;CACjB,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
export interface CodeExecutionRequest {
|
|
2
|
+
code: string;
|
|
3
|
+
language: 'javascript' | 'typescript' | 'python' | 'bash';
|
|
4
|
+
timeoutMs?: number;
|
|
5
|
+
env?: Record<string, string>;
|
|
6
|
+
}
|
|
7
|
+
export interface CodeExecutionResult {
|
|
8
|
+
stdout: string;
|
|
9
|
+
stderr: string;
|
|
10
|
+
exitCode: number;
|
|
11
|
+
timedOut: boolean;
|
|
12
|
+
elapsedMs: number;
|
|
13
|
+
}
|
|
14
|
+
export declare function executeCode(code: string, lang: 'js' | 'ts' | 'python' | 'shell', timeout?: number): Promise<{
|
|
15
|
+
stdout: string;
|
|
16
|
+
stderr: string;
|
|
17
|
+
exitCode: number;
|
|
18
|
+
}>;
|
|
19
|
+
export declare function executeCodeRequest(req: CodeExecutionRequest): Promise<CodeExecutionResult>;
|
|
20
|
+
//# sourceMappingURL=execute-code.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"execute-code.d.ts","sourceRoot":"","sources":["../../src/tools/execute-code.ts"],"names":[],"mappings":"AAIA,MAAM,WAAW,oBAAoB;IACnC,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,YAAY,GAAG,YAAY,GAAG,QAAQ,GAAG,MAAM,CAAC;IAC1D,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,GAAG,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CAC9B;AAED,MAAM,WAAW,mBAAmB;IAClC,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,OAAO,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;CACnB;AAGD,wBAAsB,WAAW,CAC/B,IAAI,EAAE,MAAM,EACZ,IAAI,EAAE,IAAI,GAAG,IAAI,GAAG,QAAQ,GAAG,OAAO,EACtC,OAAO,SAAS,GACf,OAAO,CAAC;IAAE,MAAM,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,CAAC;IAAC,QAAQ,EAAE,MAAM,CAAA;CAAE,CAAC,CAG/D;AAGD,wBAAsB,kBAAkB,CAAC,GAAG,EAAE,oBAAoB,GAAG,OAAO,CAAC,mBAAmB,CAAC,CAGhG"}
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.executeCode = executeCode;
|
|
37
|
+
exports.executeCodeRequest = executeCodeRequest;
|
|
38
|
+
// v2 execute-code tool — runs code snippets in a sandboxed subprocess
|
|
39
|
+
const child_process_1 = require("child_process");
|
|
40
|
+
const os = __importStar(require("os"));
|
|
41
|
+
// Simple API: executeCode(code, lang, timeout)
|
|
42
|
+
async function executeCode(code, lang, timeout = 30_000) {
|
|
43
|
+
const result = await runSubprocess(buildArgs(lang, code), {}, timeout);
|
|
44
|
+
return { stdout: result.stdout, stderr: result.stderr, exitCode: result.exitCode };
|
|
45
|
+
}
|
|
46
|
+
// Full API: executeCodeRequest(req) — supports env vars, timedOut flag
|
|
47
|
+
async function executeCodeRequest(req) {
|
|
48
|
+
const lang = mapLanguage(req.language);
|
|
49
|
+
return runSubprocess(buildArgs(lang, req.code), req.env ?? {}, req.timeoutMs ?? 10_000);
|
|
50
|
+
}
|
|
51
|
+
function mapLanguage(lang) {
|
|
52
|
+
switch (lang) {
|
|
53
|
+
case 'javascript': return 'js';
|
|
54
|
+
case 'typescript': return 'ts';
|
|
55
|
+
case 'python': return 'python';
|
|
56
|
+
case 'bash': return 'shell';
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
function buildArgs(lang, code) {
|
|
60
|
+
switch (lang) {
|
|
61
|
+
case 'js': return ['node', '-e', code];
|
|
62
|
+
case 'ts': return ['npx', 'ts-node', '-e', code];
|
|
63
|
+
case 'python': return ['python3', '-c', code];
|
|
64
|
+
case 'shell':
|
|
65
|
+
return os.platform() === 'win32'
|
|
66
|
+
? ['powershell', '-Command', code]
|
|
67
|
+
: ['sh', '-c', code];
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
function runSubprocess(args, env, timeout) {
|
|
71
|
+
const start = Date.now();
|
|
72
|
+
return new Promise((resolve) => {
|
|
73
|
+
const proc = (0, child_process_1.spawn)(args[0], args.slice(1), {
|
|
74
|
+
env: { ...process.env, ...env },
|
|
75
|
+
shell: false,
|
|
76
|
+
});
|
|
77
|
+
let stdout = '';
|
|
78
|
+
let stderr = '';
|
|
79
|
+
let timedOut = false;
|
|
80
|
+
const timer = setTimeout(() => {
|
|
81
|
+
timedOut = true;
|
|
82
|
+
proc.kill('SIGKILL');
|
|
83
|
+
}, timeout);
|
|
84
|
+
proc.stdout.on('data', (d) => { stdout += d.toString(); });
|
|
85
|
+
proc.stderr.on('data', (d) => { stderr += d.toString(); });
|
|
86
|
+
proc.on('close', (exitCode) => {
|
|
87
|
+
clearTimeout(timer);
|
|
88
|
+
resolve({ stdout, stderr, exitCode: exitCode ?? 1, timedOut, elapsedMs: Date.now() - start });
|
|
89
|
+
});
|
|
90
|
+
});
|
|
91
|
+
}
|
|
92
|
+
//# sourceMappingURL=execute-code.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"execute-code.js","sourceRoot":"","sources":["../../src/tools/execute-code.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import type { ToolCall } from '../core/types';
|
|
2
|
+
export interface SimpleHookContext {
|
|
3
|
+
toolName: string;
|
|
4
|
+
args: Record<string, unknown>;
|
|
5
|
+
}
|
|
6
|
+
export type BeforeHook = (ctx: SimpleHookContext) => {
|
|
7
|
+
allow: boolean;
|
|
8
|
+
reason?: string;
|
|
9
|
+
modifiedArgs?: Record<string, unknown>;
|
|
10
|
+
};
|
|
11
|
+
export type AfterHook = (ctx: SimpleHookContext, result: string) => string;
|
|
12
|
+
export declare class ToolHooks {
|
|
13
|
+
private beforeHooks;
|
|
14
|
+
private afterHooks;
|
|
15
|
+
addBefore(hook: BeforeHook): void;
|
|
16
|
+
addAfter(hook: AfterHook): void;
|
|
17
|
+
runBefore(ctx: SimpleHookContext): {
|
|
18
|
+
allow: boolean;
|
|
19
|
+
reason?: string;
|
|
20
|
+
modifiedArgs?: Record<string, unknown>;
|
|
21
|
+
};
|
|
22
|
+
runAfter(ctx: SimpleHookContext, result: string): string;
|
|
23
|
+
}
|
|
24
|
+
export declare const dangerousCommandBlocker: BeforeHook;
|
|
25
|
+
export type HookPhase = 'before' | 'after' | 'error';
|
|
26
|
+
export interface ToolHook {
|
|
27
|
+
id: string;
|
|
28
|
+
phase: HookPhase;
|
|
29
|
+
tools?: string[];
|
|
30
|
+
fn: (ctx: ToolHookContext) => Promise<void>;
|
|
31
|
+
}
|
|
32
|
+
export interface ToolHookContext {
|
|
33
|
+
call: ToolCall;
|
|
34
|
+
args: Record<string, unknown>;
|
|
35
|
+
result?: unknown;
|
|
36
|
+
error?: Error;
|
|
37
|
+
startedAt: number;
|
|
38
|
+
}
|
|
39
|
+
export declare class ToolHookRunner {
|
|
40
|
+
private hooks;
|
|
41
|
+
add(hook: ToolHook): void;
|
|
42
|
+
remove(id: string): void;
|
|
43
|
+
runBefore(ctx: ToolHookContext): Promise<void>;
|
|
44
|
+
runAfter(ctx: ToolHookContext): Promise<void>;
|
|
45
|
+
runError(ctx: ToolHookContext): Promise<void>;
|
|
46
|
+
}
|
|
47
|
+
//# sourceMappingURL=hooks.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hooks.d.ts","sourceRoot":"","sources":["../../src/tools/hooks.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AAI9C,MAAM,WAAW,iBAAiB;IAChC,QAAQ,EAAE,MAAM,CAAC;IACjB,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CAC/B;AAED,MAAM,MAAM,UAAU,GAAG,CAAC,GAAG,EAAE,iBAAiB,KAAK;IACnD,KAAK,EAAE,OAAO,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,YAAY,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACxC,CAAC;AAEF,MAAM,MAAM,SAAS,GAAG,CAAC,GAAG,EAAE,iBAAiB,EAAE,MAAM,EAAE,MAAM,KAAK,MAAM,CAAC;AAE3E,qBAAa,SAAS;IACpB,OAAO,CAAC,WAAW,CAAoB;IACvC,OAAO,CAAC,UAAU,CAAmB;IAErC,SAAS,CAAC,IAAI,EAAE,UAAU,GAAG,IAAI;IACjC,QAAQ,CAAC,IAAI,EAAE,SAAS,GAAG,IAAI;IAE/B,SAAS,CAAC,GAAG,EAAE,iBAAiB,GAAG;QAAE,KAAK,EAAE,OAAO,CAAC;QAAC,MAAM,CAAC,EAAE,MAAM,CAAC;QAAC,YAAY,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;KAAE;IAU9G,QAAQ,CAAC,GAAG,EAAE,iBAAiB,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM;CAOzD;AAGD,eAAO,MAAM,uBAAuB,EAAE,UAQrC,CAAC;AAIF,MAAM,MAAM,SAAS,GAAG,QAAQ,GAAG,OAAO,GAAG,OAAO,CAAC;AAErD,MAAM,WAAW,QAAQ;IACvB,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,SAAS,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,EAAE,CAAC;IACjB,EAAE,EAAE,CAAC,GAAG,EAAE,eAAe,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;CAC7C;AAED,MAAM,WAAW,eAAe;IAC9B,IAAI,EAAE,QAAQ,CAAC;IACf,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC9B,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,KAAK,CAAC,EAAE,KAAK,CAAC;IACd,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,qBAAa,cAAc;IACzB,OAAO,CAAC,KAAK,CAAkB;IAE/B,GAAG,CAAC,IAAI,EAAE,QAAQ,GAAG,IAAI;IAIzB,MAAM,CAAC,EAAE,EAAE,MAAM,GAAG,IAAI;IAIlB,SAAS,CAAC,GAAG,EAAE,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC;IAQ9C,QAAQ,CAAC,GAAG,EAAE,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC;IAQ7C,QAAQ,CAAC,GAAG,EAAE,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC;CAOpD"}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ToolHookRunner = exports.dangerousCommandBlocker = exports.ToolHooks = void 0;
|
|
4
|
+
class ToolHooks {
|
|
5
|
+
beforeHooks = [];
|
|
6
|
+
afterHooks = [];
|
|
7
|
+
addBefore(hook) { this.beforeHooks.push(hook); }
|
|
8
|
+
addAfter(hook) { this.afterHooks.push(hook); }
|
|
9
|
+
runBefore(ctx) {
|
|
10
|
+
let modifiedArgs = ctx.args;
|
|
11
|
+
for (const hook of this.beforeHooks) {
|
|
12
|
+
const result = hook({ ...ctx, args: modifiedArgs });
|
|
13
|
+
if (!result.allow)
|
|
14
|
+
return result;
|
|
15
|
+
if (result.modifiedArgs)
|
|
16
|
+
modifiedArgs = result.modifiedArgs;
|
|
17
|
+
}
|
|
18
|
+
return { allow: true, modifiedArgs };
|
|
19
|
+
}
|
|
20
|
+
runAfter(ctx, result) {
|
|
21
|
+
let out = result;
|
|
22
|
+
for (const hook of this.afterHooks) {
|
|
23
|
+
out = hook(ctx, out);
|
|
24
|
+
}
|
|
25
|
+
return out;
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
exports.ToolHooks = ToolHooks;
|
|
29
|
+
// Built-in guard: block destructive shell commands before execution
|
|
30
|
+
const dangerousCommandBlocker = (ctx) => {
|
|
31
|
+
if (ctx.toolName === 'shell' &&
|
|
32
|
+
/rm\s+-rf|format\s+[c-z]:|DROP\s+TABLE/i.test(ctx.args['command'] ?? '')) {
|
|
33
|
+
return { allow: false, reason: 'Dangerous command blocked' };
|
|
34
|
+
}
|
|
35
|
+
return { allow: true };
|
|
36
|
+
};
|
|
37
|
+
exports.dangerousCommandBlocker = dangerousCommandBlocker;
|
|
38
|
+
class ToolHookRunner {
|
|
39
|
+
hooks = [];
|
|
40
|
+
add(hook) {
|
|
41
|
+
this.hooks.push(hook);
|
|
42
|
+
}
|
|
43
|
+
remove(id) {
|
|
44
|
+
this.hooks = this.hooks.filter((h) => h.id !== id);
|
|
45
|
+
}
|
|
46
|
+
async runBefore(ctx) {
|
|
47
|
+
for (const hook of this.hooks.filter((h) => h.phase === 'before')) {
|
|
48
|
+
if (!hook.tools || hook.tools.includes(ctx.call.name)) {
|
|
49
|
+
await hook.fn(ctx);
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
async runAfter(ctx) {
|
|
54
|
+
for (const hook of this.hooks.filter((h) => h.phase === 'after')) {
|
|
55
|
+
if (!hook.tools || hook.tools.includes(ctx.call.name)) {
|
|
56
|
+
await hook.fn(ctx);
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
async runError(ctx) {
|
|
61
|
+
for (const hook of this.hooks.filter((h) => h.phase === 'error')) {
|
|
62
|
+
if (!hook.tools || hook.tools.includes(ctx.call.name)) {
|
|
63
|
+
await hook.fn(ctx);
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
exports.ToolHookRunner = ToolHookRunner;
|
|
69
|
+
//# sourceMappingURL=hooks.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hooks.js","sourceRoot":"","sources":["../../src/tools/hooks.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export { ToolRegistry } from './registry';
|
|
2
|
+
export type { RegisteredTool } from './registry';
|
|
3
|
+
export { ToolHookRunner, ToolHooks, dangerousCommandBlocker } from './hooks';
|
|
4
|
+
export type { ToolHook, ToolHookContext, HookPhase, SimpleHookContext, BeforeHook, AfterHook } from './hooks';
|
|
5
|
+
export { PermissionResolver, checkPermission } from './permission';
|
|
6
|
+
export type { PermissionRequest, PermissionDecision } from './permission';
|
|
7
|
+
export { executeCode, executeCodeRequest } from './execute-code';
|
|
8
|
+
export type { CodeExecutionRequest, CodeExecutionResult } from './execute-code';
|
|
9
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/tools/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAC1C,YAAY,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAEjD,OAAO,EAAE,cAAc,EAAE,SAAS,EAAE,uBAAuB,EAAE,MAAM,SAAS,CAAC;AAC7E,YAAY,EAAE,QAAQ,EAAE,eAAe,EAAE,SAAS,EAAE,iBAAiB,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AAE9G,OAAO,EAAE,kBAAkB,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AACnE,YAAY,EAAE,iBAAiB,EAAE,kBAAkB,EAAE,MAAM,cAAc,CAAC;AAE1E,OAAO,EAAE,WAAW,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AACjE,YAAY,EAAE,oBAAoB,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.executeCodeRequest = exports.executeCode = exports.checkPermission = exports.PermissionResolver = exports.dangerousCommandBlocker = exports.ToolHooks = exports.ToolHookRunner = exports.ToolRegistry = void 0;
|
|
4
|
+
var registry_1 = require("./registry");
|
|
5
|
+
Object.defineProperty(exports, "ToolRegistry", { enumerable: true, get: function () { return registry_1.ToolRegistry; } });
|
|
6
|
+
var hooks_1 = require("./hooks");
|
|
7
|
+
Object.defineProperty(exports, "ToolHookRunner", { enumerable: true, get: function () { return hooks_1.ToolHookRunner; } });
|
|
8
|
+
Object.defineProperty(exports, "ToolHooks", { enumerable: true, get: function () { return hooks_1.ToolHooks; } });
|
|
9
|
+
Object.defineProperty(exports, "dangerousCommandBlocker", { enumerable: true, get: function () { return hooks_1.dangerousCommandBlocker; } });
|
|
10
|
+
var permission_1 = require("./permission");
|
|
11
|
+
Object.defineProperty(exports, "PermissionResolver", { enumerable: true, get: function () { return permission_1.PermissionResolver; } });
|
|
12
|
+
Object.defineProperty(exports, "checkPermission", { enumerable: true, get: function () { return permission_1.checkPermission; } });
|
|
13
|
+
var execute_code_1 = require("./execute-code");
|
|
14
|
+
Object.defineProperty(exports, "executeCode", { enumerable: true, get: function () { return execute_code_1.executeCode; } });
|
|
15
|
+
Object.defineProperty(exports, "executeCodeRequest", { enumerable: true, get: function () { return execute_code_1.executeCodeRequest; } });
|
|
16
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/tools/index.ts"],"names":[],"mappings":";;;AAAA,uCAA0C;AAAjC,wGAAA,YAAY,OAAA;AAGrB,iCAA6E;AAApE,uGAAA,cAAc,OAAA;AAAE,kGAAA,SAAS,OAAA;AAAE,gHAAA,uBAAuB,OAAA;AAG3D,2CAAmE;AAA1D,gHAAA,kBAAkB,OAAA;AAAE,6GAAA,eAAe,OAAA;AAG5C,+CAAiE;AAAxD,2GAAA,WAAW,OAAA;AAAE,kHAAA,kBAAkB,OAAA"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import type { PermissionLevel, ToolConfig } from '../core/types';
|
|
2
|
+
type PermissionConfig = Record<string, PermissionLevel>;
|
|
3
|
+
export declare function checkPermission(toolName: string, config?: PermissionConfig): PermissionLevel;
|
|
4
|
+
export interface PermissionRequest {
|
|
5
|
+
tool: string;
|
|
6
|
+
args: Record<string, unknown>;
|
|
7
|
+
sessionId?: string;
|
|
8
|
+
}
|
|
9
|
+
export interface PermissionDecision {
|
|
10
|
+
level: PermissionLevel;
|
|
11
|
+
reason?: string;
|
|
12
|
+
}
|
|
13
|
+
export declare class PermissionResolver {
|
|
14
|
+
private config;
|
|
15
|
+
constructor(config: ToolConfig);
|
|
16
|
+
resolve(req: PermissionRequest): PermissionDecision;
|
|
17
|
+
isAllowed(req: PermissionRequest): boolean;
|
|
18
|
+
}
|
|
19
|
+
export {};
|
|
20
|
+
//# sourceMappingURL=permission.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"permission.d.ts","sourceRoot":"","sources":["../../src/tools/permission.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,eAAe,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAIjE,KAAK,gBAAgB,GAAG,MAAM,CAAC,MAAM,EAAE,eAAe,CAAC,CAAC;AAWxD,wBAAgB,eAAe,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,gBAAgB,GAAG,eAAe,CAE5F;AAID,MAAM,WAAW,iBAAiB;IAChC,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC9B,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,kBAAkB;IACjC,KAAK,EAAE,eAAe,CAAC;IACvB,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED,qBAAa,kBAAkB;IACjB,OAAO,CAAC,MAAM;gBAAN,MAAM,EAAE,UAAU;IAEtC,OAAO,CAAC,GAAG,EAAE,iBAAiB,GAAG,kBAAkB;IAWnD,SAAS,CAAC,GAAG,EAAE,iBAAiB,GAAG,OAAO;CAG3C"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.PermissionResolver = void 0;
|
|
4
|
+
exports.checkPermission = checkPermission;
|
|
5
|
+
const DEFAULTS = {
|
|
6
|
+
read_file: 'allow',
|
|
7
|
+
write_file: 'allow',
|
|
8
|
+
web_search: 'allow',
|
|
9
|
+
execute_code: 'ask',
|
|
10
|
+
shell_command: 'ask',
|
|
11
|
+
delete_file: 'ask',
|
|
12
|
+
};
|
|
13
|
+
function checkPermission(toolName, config) {
|
|
14
|
+
return config?.[toolName] ?? DEFAULTS[toolName] ?? 'ask';
|
|
15
|
+
}
|
|
16
|
+
class PermissionResolver {
|
|
17
|
+
config;
|
|
18
|
+
constructor(config) {
|
|
19
|
+
this.config = config;
|
|
20
|
+
}
|
|
21
|
+
resolve(req) {
|
|
22
|
+
const explicit = this.config.permissions[req.tool];
|
|
23
|
+
if (explicit)
|
|
24
|
+
return { level: explicit };
|
|
25
|
+
if (this.config.builtin.includes(req.tool)) {
|
|
26
|
+
return { level: 'allow', reason: 'builtin_tool' };
|
|
27
|
+
}
|
|
28
|
+
return { level: 'ask', reason: 'default_policy' };
|
|
29
|
+
}
|
|
30
|
+
isAllowed(req) {
|
|
31
|
+
return this.resolve(req).level === 'allow';
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
exports.PermissionResolver = PermissionResolver;
|
|
35
|
+
//# sourceMappingURL=permission.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"permission.js","sourceRoot":"","sources":["../../src/tools/permission.ts"],"names":[],"mappings":";;;AAgBA,0CAEC;AAXD,MAAM,QAAQ,GAAqB;IACjC,SAAS,EAAE,OAAO;IAClB,UAAU,EAAE,OAAO;IACnB,UAAU,EAAE,OAAO;IACnB,YAAY,EAAE,KAAK;IACnB,aAAa,EAAE,KAAK;IACpB,WAAW,EAAE,KAAK;CACnB,CAAC;AAEF,SAAgB,eAAe,CAAC,QAAgB,EAAE,MAAyB;IACzE,OAAO,MAAM,EAAE,CAAC,QAAQ,CAAC,IAAI,QAAQ,CAAC,QAAQ,CAAC,IAAI,KAAK,CAAC;AAC3D,CAAC;AAeD,MAAa,kBAAkB;IACT;IAApB,YAAoB,MAAkB;QAAlB,WAAM,GAAN,MAAM,CAAY;IAAG,CAAC;IAE1C,OAAO,CAAC,GAAsB;QAC5B,MAAM,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACnD,IAAI,QAAQ;YAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC;QAEzC,IAAI,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC;YAC3C,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,EAAE,cAAc,EAAE,CAAC;QACpD,CAAC;QAED,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,gBAAgB,EAAE,CAAC;IACpD,CAAC;IAED,SAAS,CAAC,GAAsB;QAC9B,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,KAAK,KAAK,OAAO,CAAC;IAC7C,CAAC;CACF;AAjBD,gDAiBC"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import type { ToolDefinition } from '../core/types';
|
|
2
|
+
export interface RegisteredTool {
|
|
3
|
+
definition: ToolDefinition;
|
|
4
|
+
handler: (args: Record<string, unknown>) => Promise<unknown>;
|
|
5
|
+
category?: string;
|
|
6
|
+
enabled: boolean;
|
|
7
|
+
}
|
|
8
|
+
export declare class ToolRegistry {
|
|
9
|
+
private tools;
|
|
10
|
+
register(tool: RegisteredTool): void;
|
|
11
|
+
unregister(name: string): void;
|
|
12
|
+
get(name: string): RegisteredTool | undefined;
|
|
13
|
+
list(enabled?: boolean): RegisteredTool[];
|
|
14
|
+
definitions(): ToolDefinition[];
|
|
15
|
+
execute(name: string, args: Record<string, unknown>): Promise<unknown>;
|
|
16
|
+
toOpenAIFormat(): {
|
|
17
|
+
type: string;
|
|
18
|
+
function: {
|
|
19
|
+
name: string;
|
|
20
|
+
description: string;
|
|
21
|
+
parameters: Record<string, unknown>;
|
|
22
|
+
};
|
|
23
|
+
}[];
|
|
24
|
+
}
|
|
25
|
+
//# sourceMappingURL=registry.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"registry.d.ts","sourceRoot":"","sources":["../../src/tools/registry.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAEpD,MAAM,WAAW,cAAc;IAC7B,UAAU,EAAE,cAAc,CAAC;IAC3B,OAAO,EAAE,CAAC,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,KAAK,OAAO,CAAC,OAAO,CAAC,CAAC;IAC7D,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,OAAO,CAAC;CAClB;AAED,qBAAa,YAAY;IACvB,OAAO,CAAC,KAAK,CAAqC;IAElD,QAAQ,CAAC,IAAI,EAAE,cAAc,GAAG,IAAI;IAIpC,UAAU,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI;IAI9B,GAAG,CAAC,IAAI,EAAE,MAAM,GAAG,cAAc,GAAG,SAAS;IAI7C,IAAI,CAAC,OAAO,CAAC,EAAE,OAAO,GAAG,cAAc,EAAE;IAKzC,WAAW,IAAI,cAAc,EAAE;IAIzB,OAAO,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,OAAO,CAAC,OAAO,CAAC;IAO5E,cAAc,IAAI;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,QAAQ,EAAE;YAAE,IAAI,EAAE,MAAM,CAAC;YAAC,WAAW,EAAE,MAAM,CAAC;YAAC,UAAU,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;SAAE,CAAA;KAAE,EAAE;CAU3H"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ToolRegistry = void 0;
|
|
4
|
+
class ToolRegistry {
|
|
5
|
+
tools = new Map();
|
|
6
|
+
register(tool) {
|
|
7
|
+
this.tools.set(tool.definition.name, tool);
|
|
8
|
+
}
|
|
9
|
+
unregister(name) {
|
|
10
|
+
this.tools.delete(name);
|
|
11
|
+
}
|
|
12
|
+
get(name) {
|
|
13
|
+
return this.tools.get(name);
|
|
14
|
+
}
|
|
15
|
+
list(enabled) {
|
|
16
|
+
const all = Array.from(this.tools.values());
|
|
17
|
+
return enabled !== undefined ? all.filter((t) => t.enabled === enabled) : all;
|
|
18
|
+
}
|
|
19
|
+
definitions() {
|
|
20
|
+
return this.list(true).map((t) => t.definition);
|
|
21
|
+
}
|
|
22
|
+
async execute(name, args) {
|
|
23
|
+
const tool = this.tools.get(name);
|
|
24
|
+
if (!tool)
|
|
25
|
+
throw new Error(`unknown tool: ${name}`);
|
|
26
|
+
if (!tool.enabled)
|
|
27
|
+
throw new Error(`tool disabled: ${name}`);
|
|
28
|
+
return tool.handler(args);
|
|
29
|
+
}
|
|
30
|
+
toOpenAIFormat() {
|
|
31
|
+
return this.list(true).map((t) => ({
|
|
32
|
+
type: 'function',
|
|
33
|
+
function: {
|
|
34
|
+
name: t.definition.name,
|
|
35
|
+
description: t.definition.description,
|
|
36
|
+
parameters: t.definition.parameters,
|
|
37
|
+
},
|
|
38
|
+
}));
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
exports.ToolRegistry = ToolRegistry;
|
|
42
|
+
//# sourceMappingURL=registry.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"registry.js","sourceRoot":"","sources":["../../src/tools/registry.ts"],"names":[],"mappings":";;;AAUA,MAAa,YAAY;IACf,KAAK,GAAG,IAAI,GAAG,EAA0B,CAAC;IAElD,QAAQ,CAAC,IAAoB;QAC3B,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IAC7C,CAAC;IAED,UAAU,CAAC,IAAY;QACrB,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAC1B,CAAC;IAED,GAAG,CAAC,IAAY;QACd,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IAC9B,CAAC;IAED,IAAI,CAAC,OAAiB;QACpB,MAAM,GAAG,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,CAAC;QAC5C,OAAO,OAAO,KAAK,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;IAChF,CAAC;IAED,WAAW;QACT,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC;IAClD,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,IAAY,EAAE,IAA6B;QACvD,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAClC,IAAI,CAAC,IAAI;YAAE,MAAM,IAAI,KAAK,CAAC,iBAAiB,IAAI,EAAE,CAAC,CAAC;QACpD,IAAI,CAAC,IAAI,CAAC,OAAO;YAAE,MAAM,IAAI,KAAK,CAAC,kBAAkB,IAAI,EAAE,CAAC,CAAC;QAC7D,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IAC5B,CAAC;IAED,cAAc;QACZ,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;YACjC,IAAI,EAAE,UAAU;YAChB,QAAQ,EAAE;gBACR,IAAI,EAAE,CAAC,CAAC,UAAU,CAAC,IAAI;gBACvB,WAAW,EAAE,CAAC,CAAC,UAAU,CAAC,WAAW;gBACrC,UAAU,EAAE,CAAC,CAAC,UAAU,CAAC,UAAqC;aAC/D;SACF,CAAC,CAAC,CAAC;IACN,CAAC;CACF;AAzCD,oCAyCC"}
|