@botbotgo/runtime 1.0.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/.github/workflows/ci.yml +46 -0
- package/.github/workflows/release.yml +79 -0
- package/README.md +71 -0
- package/config/examples/memory.yaml +39 -0
- package/config/examples/model.yaml +21 -0
- package/config/examples/runtime.yaml +44 -0
- package/config/examples/skills.yaml +8 -0
- package/config/examples/tool.yaml +16 -0
- package/dist/config/index.d.ts +7 -0
- package/dist/config/index.d.ts.map +1 -0
- package/dist/config/index.js +4 -0
- package/dist/config/index.js.map +1 -0
- package/dist/config/loader.d.ts +41 -0
- package/dist/config/loader.d.ts.map +1 -0
- package/dist/config/loader.js +140 -0
- package/dist/config/loader.js.map +1 -0
- package/dist/config/resolveRuntimeConfig.d.ts +83 -0
- package/dist/config/resolveRuntimeConfig.d.ts.map +1 -0
- package/dist/config/resolveRuntimeConfig.js +85 -0
- package/dist/config/resolveRuntimeConfig.js.map +1 -0
- package/dist/config/resources.d.ts +112 -0
- package/dist/config/resources.d.ts.map +1 -0
- package/dist/config/resources.js +20 -0
- package/dist/config/resources.js.map +1 -0
- package/dist/config/runtimeConfigLoader.d.ts +28 -0
- package/dist/config/runtimeConfigLoader.d.ts.map +1 -0
- package/dist/config/runtimeConfigLoader.js +38 -0
- package/dist/config/runtimeConfigLoader.js.map +1 -0
- package/dist/index.d.ts +9 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +5 -0
- package/dist/index.js.map +1 -0
- package/dist/runtime/agentMiddleware.d.ts +3 -0
- package/dist/runtime/agentMiddleware.d.ts.map +1 -0
- package/dist/runtime/agentMiddleware.js +2 -0
- package/dist/runtime/agentMiddleware.js.map +1 -0
- package/dist/runtime/bootstrap/runtimeFactory.d.ts +7 -0
- package/dist/runtime/bootstrap/runtimeFactory.d.ts.map +1 -0
- package/dist/runtime/bootstrap/runtimeFactory.js +139 -0
- package/dist/runtime/bootstrap/runtimeFactory.js.map +1 -0
- package/dist/runtime/bootstrap/runtimeModuleInitializer.d.ts +5 -0
- package/dist/runtime/bootstrap/runtimeModuleInitializer.d.ts.map +1 -0
- package/dist/runtime/bootstrap/runtimeModuleInitializer.js +32 -0
- package/dist/runtime/bootstrap/runtimeModuleInitializer.js.map +1 -0
- package/dist/runtime/context/agentContext.d.ts +5 -0
- package/dist/runtime/context/agentContext.d.ts.map +1 -0
- package/dist/runtime/context/agentContext.js +19 -0
- package/dist/runtime/context/agentContext.js.map +1 -0
- package/dist/runtime/context/globalContext.d.ts +19 -0
- package/dist/runtime/context/globalContext.d.ts.map +1 -0
- package/dist/runtime/context/globalContext.js +47 -0
- package/dist/runtime/context/globalContext.js.map +1 -0
- package/dist/runtime/events/eventPublisher.d.ts +15 -0
- package/dist/runtime/events/eventPublisher.d.ts.map +1 -0
- package/dist/runtime/events/eventPublisher.js +23 -0
- package/dist/runtime/events/eventPublisher.js.map +1 -0
- package/dist/runtime/execution/agentRunExecutor.d.ts +38 -0
- package/dist/runtime/execution/agentRunExecutor.d.ts.map +1 -0
- package/dist/runtime/execution/agentRunExecutor.js +378 -0
- package/dist/runtime/execution/agentRunExecutor.js.map +1 -0
- package/dist/runtime/execution/agentRunExecutor.types.d.ts +37 -0
- package/dist/runtime/execution/agentRunExecutor.types.d.ts.map +1 -0
- package/dist/runtime/execution/agentRunExecutor.types.js +2 -0
- package/dist/runtime/execution/agentRunExecutor.types.js.map +1 -0
- package/dist/runtime/execution/agentRunProgress.d.ts +8 -0
- package/dist/runtime/execution/agentRunProgress.d.ts.map +1 -0
- package/dist/runtime/execution/agentRunProgress.js +46 -0
- package/dist/runtime/execution/agentRunProgress.js.map +1 -0
- package/dist/runtime/execution/agentRunState.d.ts +44 -0
- package/dist/runtime/execution/agentRunState.d.ts.map +1 -0
- package/dist/runtime/execution/agentRunState.js +17 -0
- package/dist/runtime/execution/agentRunState.js.map +1 -0
- package/dist/runtime/execution/policies/runCompletionPolicy.d.ts +5 -0
- package/dist/runtime/execution/policies/runCompletionPolicy.d.ts.map +1 -0
- package/dist/runtime/execution/policies/runCompletionPolicy.js +30 -0
- package/dist/runtime/execution/policies/runCompletionPolicy.js.map +1 -0
- package/dist/runtime/execution/policies/runErrorPolicy.d.ts +7 -0
- package/dist/runtime/execution/policies/runErrorPolicy.d.ts.map +1 -0
- package/dist/runtime/execution/policies/runErrorPolicy.js +40 -0
- package/dist/runtime/execution/policies/runErrorPolicy.js.map +1 -0
- package/dist/runtime/execution/policies/runPromptBuilder.d.ts +10 -0
- package/dist/runtime/execution/policies/runPromptBuilder.d.ts.map +1 -0
- package/dist/runtime/execution/policies/runPromptBuilder.js +34 -0
- package/dist/runtime/execution/policies/runPromptBuilder.js.map +1 -0
- package/dist/runtime/execution/policies/runSummaryFormatter.d.ts +6 -0
- package/dist/runtime/execution/policies/runSummaryFormatter.d.ts.map +1 -0
- package/dist/runtime/execution/policies/runSummaryFormatter.js +47 -0
- package/dist/runtime/execution/policies/runSummaryFormatter.js.map +1 -0
- package/dist/runtime/execution/policies/runtimeDelay.d.ts +4 -0
- package/dist/runtime/execution/policies/runtimeDelay.d.ts.map +1 -0
- package/dist/runtime/execution/policies/runtimeDelay.js +6 -0
- package/dist/runtime/execution/policies/runtimeDelay.js.map +1 -0
- package/dist/runtime/execution/policies/toolConfigReader.d.ts +8 -0
- package/dist/runtime/execution/policies/toolConfigReader.d.ts.map +1 -0
- package/dist/runtime/execution/policies/toolConfigReader.js +91 -0
- package/dist/runtime/execution/policies/toolConfigReader.js.map +1 -0
- package/dist/runtime/human-loop/consoleHumanLoop.d.ts +21 -0
- package/dist/runtime/human-loop/consoleHumanLoop.d.ts.map +1 -0
- package/dist/runtime/human-loop/consoleHumanLoop.js +102 -0
- package/dist/runtime/human-loop/consoleHumanLoop.js.map +1 -0
- package/dist/runtime/human-loop/humanLoop.d.ts +44 -0
- package/dist/runtime/human-loop/humanLoop.d.ts.map +1 -0
- package/dist/runtime/human-loop/humanLoop.js +36 -0
- package/dist/runtime/human-loop/humanLoop.js.map +1 -0
- package/dist/runtime/index.d.ts +10 -0
- package/dist/runtime/index.d.ts.map +1 -0
- package/dist/runtime/index.js +6 -0
- package/dist/runtime/index.js.map +1 -0
- package/dist/runtime/middleware/agentToolMiddleware.d.ts +30 -0
- package/dist/runtime/middleware/agentToolMiddleware.d.ts.map +1 -0
- package/dist/runtime/middleware/agentToolMiddleware.js +259 -0
- package/dist/runtime/middleware/agentToolMiddleware.js.map +1 -0
- package/dist/runtime/middleware/commandPolicy.d.ts +8 -0
- package/dist/runtime/middleware/commandPolicy.d.ts.map +1 -0
- package/dist/runtime/middleware/commandPolicy.js +55 -0
- package/dist/runtime/middleware/commandPolicy.js.map +1 -0
- package/dist/runtime/middleware/frameworkPrompt.d.ts +4 -0
- package/dist/runtime/middleware/frameworkPrompt.d.ts.map +1 -0
- package/dist/runtime/middleware/frameworkPrompt.js +44 -0
- package/dist/runtime/middleware/frameworkPrompt.js.map +1 -0
- package/dist/runtime/middleware/index.d.ts +4 -0
- package/dist/runtime/middleware/index.d.ts.map +1 -0
- package/dist/runtime/middleware/index.js +3 -0
- package/dist/runtime/middleware/index.js.map +1 -0
- package/dist/runtime/middleware/skillPathMap.d.ts +3 -0
- package/dist/runtime/middleware/skillPathMap.d.ts.map +1 -0
- package/dist/runtime/middleware/skillPathMap.js +44 -0
- package/dist/runtime/middleware/skillPathMap.js.map +1 -0
- package/dist/runtime/middleware/toolArgsNormalizer.d.ts +21 -0
- package/dist/runtime/middleware/toolArgsNormalizer.d.ts.map +1 -0
- package/dist/runtime/middleware/toolArgsNormalizer.js +227 -0
- package/dist/runtime/middleware/toolArgsNormalizer.js.map +1 -0
- package/dist/runtime/middleware/toolCallGuard.d.ts +8 -0
- package/dist/runtime/middleware/toolCallGuard.d.ts.map +1 -0
- package/dist/runtime/middleware/toolCallGuard.js +60 -0
- package/dist/runtime/middleware/toolCallGuard.js.map +1 -0
- package/dist/runtime/middleware/toolFsHandlers.d.ts +12 -0
- package/dist/runtime/middleware/toolFsHandlers.d.ts.map +1 -0
- package/dist/runtime/middleware/toolFsHandlers.js +79 -0
- package/dist/runtime/middleware/toolFsHandlers.js.map +1 -0
- package/dist/runtime/middleware/toolRequestParser.d.ts +14 -0
- package/dist/runtime/middleware/toolRequestParser.d.ts.map +1 -0
- package/dist/runtime/middleware/toolRequestParser.js +72 -0
- package/dist/runtime/middleware/toolRequestParser.js.map +1 -0
- package/dist/runtime/middleware/types.d.ts +87 -0
- package/dist/runtime/middleware/types.d.ts.map +1 -0
- package/dist/runtime/middleware/types.js +3 -0
- package/dist/runtime/middleware/types.js.map +1 -0
- package/dist/runtime/providers/backendResolver.d.ts +26 -0
- package/dist/runtime/providers/backendResolver.d.ts.map +1 -0
- package/dist/runtime/providers/backendResolver.js +73 -0
- package/dist/runtime/providers/backendResolver.js.map +1 -0
- package/dist/runtime/providers/index.d.ts +14 -0
- package/dist/runtime/providers/index.d.ts.map +1 -0
- package/dist/runtime/providers/index.js +10 -0
- package/dist/runtime/providers/index.js.map +1 -0
- package/dist/runtime/providers/langchainRuntime.d.ts +11 -0
- package/dist/runtime/providers/langchainRuntime.d.ts.map +1 -0
- package/dist/runtime/providers/langchainRuntime.js +45 -0
- package/dist/runtime/providers/langchainRuntime.js.map +1 -0
- package/dist/runtime/providers/localShellBackend.d.ts +10 -0
- package/dist/runtime/providers/localShellBackend.d.ts.map +1 -0
- package/dist/runtime/providers/localShellBackend.js +23 -0
- package/dist/runtime/providers/localShellBackend.js.map +1 -0
- package/dist/runtime/providers/openaiDeepAgent.d.ts +9 -0
- package/dist/runtime/providers/openaiDeepAgent.d.ts.map +1 -0
- package/dist/runtime/providers/openaiDeepAgent.js +7 -0
- package/dist/runtime/providers/openaiDeepAgent.js.map +1 -0
- package/dist/runtime/providers/openaiLocalAgent.d.ts +17 -0
- package/dist/runtime/providers/openaiLocalAgent.d.ts.map +1 -0
- package/dist/runtime/providers/openaiLocalAgent.js +26 -0
- package/dist/runtime/providers/openaiLocalAgent.js.map +1 -0
- package/dist/runtime/providers/openaiLocalAgentFactory.d.ts +36 -0
- package/dist/runtime/providers/openaiLocalAgentFactory.d.ts.map +1 -0
- package/dist/runtime/providers/openaiLocalAgentFactory.js +139 -0
- package/dist/runtime/providers/openaiLocalAgentFactory.js.map +1 -0
- package/dist/runtime/providers/shared/agentProbe.d.ts +4 -0
- package/dist/runtime/providers/shared/agentProbe.d.ts.map +1 -0
- package/dist/runtime/providers/shared/agentProbe.js +17 -0
- package/dist/runtime/providers/shared/agentProbe.js.map +1 -0
- package/dist/runtime/providers/shared/moduleFallback.d.ts +2 -0
- package/dist/runtime/providers/shared/moduleFallback.d.ts.map +1 -0
- package/dist/runtime/providers/shared/moduleFallback.js +34 -0
- package/dist/runtime/providers/shared/moduleFallback.js.map +1 -0
- package/dist/runtime/providers/shared/resourceCloser.d.ts +6 -0
- package/dist/runtime/providers/shared/resourceCloser.d.ts.map +1 -0
- package/dist/runtime/providers/shared/resourceCloser.js +30 -0
- package/dist/runtime/providers/shared/resourceCloser.js.map +1 -0
- package/dist/runtime/runtimeService.d.ts +109 -0
- package/dist/runtime/runtimeService.d.ts.map +1 -0
- package/dist/runtime/runtimeService.js +90 -0
- package/dist/runtime/runtimeService.js.map +1 -0
- package/dist/runtime/stream/agentMessages.d.ts +40 -0
- package/dist/runtime/stream/agentMessages.d.ts.map +1 -0
- package/dist/runtime/stream/agentMessages.js +44 -0
- package/dist/runtime/stream/agentMessages.js.map +1 -0
- package/dist/runtime/stream/agentStream.d.ts +31 -0
- package/dist/runtime/stream/agentStream.d.ts.map +1 -0
- package/dist/runtime/stream/agentStream.js +106 -0
- package/dist/runtime/stream/agentStream.js.map +1 -0
- package/dist/runtime/stream/messageSummary.d.ts +20 -0
- package/dist/runtime/stream/messageSummary.d.ts.map +1 -0
- package/dist/runtime/stream/messageSummary.js +150 -0
- package/dist/runtime/stream/messageSummary.js.map +1 -0
- package/dist/runtime/stream/runArtifacts.d.ts +9 -0
- package/dist/runtime/stream/runArtifacts.d.ts.map +1 -0
- package/dist/runtime/stream/runArtifacts.js +48 -0
- package/dist/runtime/stream/runArtifacts.js.map +1 -0
- package/dist/state/index.d.ts +7 -0
- package/dist/state/index.d.ts.map +1 -0
- package/dist/state/index.js +4 -0
- package/dist/state/index.js.map +1 -0
- package/dist/state/runState.d.ts +36 -0
- package/dist/state/runState.d.ts.map +1 -0
- package/dist/state/runState.js +51 -0
- package/dist/state/runState.js.map +1 -0
- package/dist/state/todos.d.ts +19 -0
- package/dist/state/todos.d.ts.map +1 -0
- package/dist/state/todos.js +45 -0
- package/dist/state/todos.js.map +1 -0
- package/dist/state/workspaceRunSession.d.ts +32 -0
- package/dist/state/workspaceRunSession.d.ts.map +1 -0
- package/dist/state/workspaceRunSession.js +67 -0
- package/dist/state/workspaceRunSession.js.map +1 -0
- package/dist/state/workspaceState.d.ts +94 -0
- package/dist/state/workspaceState.d.ts.map +1 -0
- package/dist/state/workspaceState.js +119 -0
- package/dist/state/workspaceState.js.map +1 -0
- package/dist/types.d.ts +2 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +2 -0
- package/dist/types.js.map +1 -0
- package/example/.tsbuildinfo +1 -0
- package/example/build/.tsbuildinfo +1 -0
- package/example/config/memory.yaml +35 -0
- package/example/config/model.yaml +14 -0
- package/example/config/runtime.yaml +46 -0
- package/example/config/tool.yaml +24 -0
- package/example/index.ts +159 -0
- package/example/package-lock.json +1396 -0
- package/example/package.json +26 -0
- package/example/serve-output.mjs +52 -0
- package/example/tsconfig.json +19 -0
- package/package.json +73 -0
- package/scripts/resolve-deps.js +40 -0
- package/src/config/index.ts +29 -0
- package/src/config/loader.ts +174 -0
- package/src/config/resolveRuntimeConfig.ts +160 -0
- package/src/config/resources.ts +152 -0
- package/src/config/runtimeConfigLoader.ts +68 -0
- package/src/external-modules.d.ts +20 -0
- package/src/index.ts +36 -0
- package/src/runtime/agentMiddleware.ts +6 -0
- package/src/runtime/bootstrap/runtimeFactory.ts +212 -0
- package/src/runtime/bootstrap/runtimeModuleInitializer.ts +34 -0
- package/src/runtime/context/agentContext.ts +24 -0
- package/src/runtime/context/globalContext.ts +70 -0
- package/src/runtime/events/eventPublisher.ts +45 -0
- package/src/runtime/execution/agentRunExecutor.ts +499 -0
- package/src/runtime/execution/agentRunExecutor.types.ts +39 -0
- package/src/runtime/execution/agentRunProgress.ts +67 -0
- package/src/runtime/execution/agentRunState.ts +66 -0
- package/src/runtime/execution/policies/runCompletionPolicy.ts +30 -0
- package/src/runtime/execution/policies/runErrorPolicy.ts +50 -0
- package/src/runtime/execution/policies/runPromptBuilder.ts +39 -0
- package/src/runtime/execution/policies/runSummaryFormatter.ts +57 -0
- package/src/runtime/execution/policies/runtimeDelay.ts +5 -0
- package/src/runtime/execution/policies/toolConfigReader.ts +107 -0
- package/src/runtime/human-loop/consoleHumanLoop.ts +113 -0
- package/src/runtime/human-loop/humanLoop.ts +90 -0
- package/src/runtime/index.ts +36 -0
- package/src/runtime/middleware/agentToolMiddleware.ts +329 -0
- package/src/runtime/middleware/commandPolicy.ts +65 -0
- package/src/runtime/middleware/frameworkPrompt.ts +51 -0
- package/src/runtime/middleware/index.ts +7 -0
- package/src/runtime/middleware/skillPathMap.ts +49 -0
- package/src/runtime/middleware/toolArgsNormalizer.ts +277 -0
- package/src/runtime/middleware/toolCallGuard.ts +73 -0
- package/src/runtime/middleware/toolFsHandlers.ts +94 -0
- package/src/runtime/middleware/toolRequestParser.ts +84 -0
- package/src/runtime/middleware/types.ts +91 -0
- package/src/runtime/providers/backendResolver.ts +127 -0
- package/src/runtime/providers/index.ts +19 -0
- package/src/runtime/providers/langchainRuntime.ts +67 -0
- package/src/runtime/providers/localShellBackend.ts +54 -0
- package/src/runtime/providers/openaiDeepAgent.ts +17 -0
- package/src/runtime/providers/openaiLocalAgent.ts +35 -0
- package/src/runtime/providers/openaiLocalAgentFactory.ts +185 -0
- package/src/runtime/providers/shared/agentProbe.ts +24 -0
- package/src/runtime/providers/shared/moduleFallback.ts +41 -0
- package/src/runtime/providers/shared/resourceCloser.ts +30 -0
- package/src/runtime/runtimeService.ts +205 -0
- package/src/runtime/stream/agentMessages.ts +72 -0
- package/src/runtime/stream/agentStream.ts +168 -0
- package/src/runtime/stream/messageSummary.ts +164 -0
- package/src/runtime/stream/runArtifacts.ts +72 -0
- package/src/state/index.ts +19 -0
- package/src/state/runState.ts +84 -0
- package/src/state/todos.ts +59 -0
- package/src/state/workspaceRunSession.ts +96 -0
- package/src/state/workspaceState.ts +199 -0
- package/src/types/easynet-agent-common.d.ts +62 -0
- package/src/types.ts +1 -0
- package/test/integration/runtime-live.integration.test.ts +30 -0
- package/test/unit/config/loader.test.ts +429 -0
- package/test/unit/runtime/agentContext.test.ts +23 -0
- package/test/unit/runtime/agentRuntime.test.ts +99 -0
- package/test/unit/runtime/consoleHumanLoop.test.ts +52 -0
- package/test/unit/runtime/events.test.ts +11 -0
- package/test/unit/runtime/globalContext.test.ts +34 -0
- package/test/unit/runtime/humanLoop.test.ts +104 -0
- package/test/unit/runtime/toolArgsNormalizer.test.ts +136 -0
- package/tsconfig.json +18 -0
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { existsSync, readdirSync, statSync } from "node:fs";
|
|
2
|
+
import { basename, join } from "node:path";
|
|
3
|
+
export function buildSkillPathMap(skillRoots) {
|
|
4
|
+
const counts = new Map();
|
|
5
|
+
const result = {};
|
|
6
|
+
for (const skillRoot of expandSkillRoots(skillRoots)) {
|
|
7
|
+
const normalizedRoot = skillRoot.replace(/\\/g, "/");
|
|
8
|
+
const baseName = sanitizeSkillId(basename(normalizedRoot) || "skill");
|
|
9
|
+
const seen = counts.get(baseName) ?? 0;
|
|
10
|
+
counts.set(baseName, seen + 1);
|
|
11
|
+
const id = seen === 0 ? baseName : `${baseName}_${seen + 1}`;
|
|
12
|
+
result[id] = normalizedRoot;
|
|
13
|
+
}
|
|
14
|
+
return result;
|
|
15
|
+
}
|
|
16
|
+
function sanitizeSkillId(value) {
|
|
17
|
+
return value
|
|
18
|
+
.trim()
|
|
19
|
+
.replace(/[^A-Za-z0-9._-]+/g, "-")
|
|
20
|
+
.replace(/^-+|-+$/g, "")
|
|
21
|
+
.toLowerCase() || "skill";
|
|
22
|
+
}
|
|
23
|
+
export function expandSkillRoots(skillRoots) {
|
|
24
|
+
const expanded = skillRoots.flatMap((skillRoot) => {
|
|
25
|
+
const directSkill = join(skillRoot, "SKILL.md");
|
|
26
|
+
if (existsSync(directSkill)) {
|
|
27
|
+
return [skillRoot];
|
|
28
|
+
}
|
|
29
|
+
try {
|
|
30
|
+
return readdirSync(skillRoot, { withFileTypes: true })
|
|
31
|
+
.filter((entry) => entry.isDirectory())
|
|
32
|
+
.map((entry) => join(skillRoot, entry.name))
|
|
33
|
+
.filter((entryPath) => {
|
|
34
|
+
const skillFile = join(entryPath, "SKILL.md");
|
|
35
|
+
return existsSync(skillFile) && statSync(entryPath).isDirectory();
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
catch {
|
|
39
|
+
return [skillRoot];
|
|
40
|
+
}
|
|
41
|
+
});
|
|
42
|
+
return expanded.length > 0 ? expanded : skillRoots;
|
|
43
|
+
}
|
|
44
|
+
//# sourceMappingURL=skillPathMap.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"skillPathMap.js","sourceRoot":"","sources":["../../../src/runtime/middleware/skillPathMap.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,WAAW,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAC5D,OAAO,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAE3C,MAAM,UAAU,iBAAiB,CAAC,UAAoB;IACpD,MAAM,MAAM,GAAG,IAAI,GAAG,EAAkB,CAAC;IACzC,MAAM,MAAM,GAA2B,EAAE,CAAC;IAE1C,KAAK,MAAM,SAAS,IAAI,gBAAgB,CAAC,UAAU,CAAC,EAAE,CAAC;QACrD,MAAM,cAAc,GAAG,SAAS,CAAC,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;QACrD,MAAM,QAAQ,GAAG,eAAe,CAAC,QAAQ,CAAC,cAAc,CAAC,IAAI,OAAO,CAAC,CAAC;QACtE,MAAM,IAAI,GAAG,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QACvC,MAAM,CAAC,GAAG,CAAC,QAAQ,EAAE,IAAI,GAAG,CAAC,CAAC,CAAC;QAC/B,MAAM,EAAE,GAAG,IAAI,KAAK,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,QAAQ,IAAI,IAAI,GAAG,CAAC,EAAE,CAAC;QAC7D,MAAM,CAAC,EAAE,CAAC,GAAG,cAAc,CAAC;IAC9B,CAAC;IAED,OAAO,MAAM,CAAC;AAChB,CAAC;AAED,SAAS,eAAe,CAAC,KAAa;IACpC,OAAO,KAAK;SACT,IAAI,EAAE;SACN,OAAO,CAAC,mBAAmB,EAAE,GAAG,CAAC;SACjC,OAAO,CAAC,UAAU,EAAE,EAAE,CAAC;SACvB,WAAW,EAAE,IAAI,OAAO,CAAC;AAC9B,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,UAAoB;IACnD,MAAM,QAAQ,GAAG,UAAU,CAAC,OAAO,CAAC,CAAC,SAAS,EAAE,EAAE;QAChD,MAAM,WAAW,GAAG,IAAI,CAAC,SAAS,EAAE,UAAU,CAAC,CAAC;QAChD,IAAI,UAAU,CAAC,WAAW,CAAC,EAAE,CAAC;YAC5B,OAAO,CAAC,SAAS,CAAC,CAAC;QACrB,CAAC;QAED,IAAI,CAAC;YACH,OAAO,WAAW,CAAC,SAAS,EAAE,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC;iBACnD,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC;iBACtC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,SAAS,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;iBAC3C,MAAM,CAAC,CAAC,SAAS,EAAE,EAAE;gBACpB,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,EAAE,UAAU,CAAC,CAAC;gBAC9C,OAAO,UAAU,CAAC,SAAS,CAAC,IAAI,QAAQ,CAAC,SAAS,CAAC,CAAC,WAAW,EAAE,CAAC;YACpE,CAAC,CAAC,CAAC;QACP,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,CAAC,SAAS,CAAC,CAAC;QACrB,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,OAAO,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,UAAU,CAAC;AACrD,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { type ToolArgs } from "./types.js";
|
|
2
|
+
export declare class ToolArgsNormalizer {
|
|
3
|
+
static normalizeToolArgs(rootDir: string, skillRoots: string[], name: string, args: ToolArgs, skillPathMap?: Record<string, string>): ToolArgs;
|
|
4
|
+
private static usesFilePathAlias;
|
|
5
|
+
private static normalizeExecuteCommand;
|
|
6
|
+
private static normalizePathArgs;
|
|
7
|
+
private static expandPlaceholders;
|
|
8
|
+
private static expandStringPlaceholders;
|
|
9
|
+
private static resolveSkillPathPlaceholder;
|
|
10
|
+
private static shouldNormalizePath;
|
|
11
|
+
private static isResolvableAbsolutePath;
|
|
12
|
+
private static tokenizeCommand;
|
|
13
|
+
private static resolveSkillRelativeCommandArg;
|
|
14
|
+
private static looksLikeRelativePath;
|
|
15
|
+
private static quoteCommandPart;
|
|
16
|
+
private static normalizeWriteTodosArgs;
|
|
17
|
+
private static extractTodoText;
|
|
18
|
+
private static normalizeTodo;
|
|
19
|
+
static resolveScriptSourcePath(rootDir: string, value: string): string;
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=toolArgsNormalizer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"toolArgsNormalizer.d.ts","sourceRoot":"","sources":["../../../src/runtime/middleware/toolArgsNormalizer.ts"],"names":[],"mappings":"AAEA,OAAO,EAAsB,KAAK,QAAQ,EAAE,MAAM,YAAY,CAAC;AAE/D,qBAAa,kBAAkB;WACf,iBAAiB,CAC7B,OAAO,EAAE,MAAM,EACf,UAAU,EAAE,MAAM,EAAE,EACpB,IAAI,EAAE,MAAM,EACZ,IAAI,EAAE,QAAQ,EACd,YAAY,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GACpC,QAAQ;IAoBX,OAAO,CAAC,MAAM,CAAC,iBAAiB;IAMhC,OAAO,CAAC,MAAM,CAAC,uBAAuB;IAgCtC,OAAO,CAAC,MAAM,CAAC,iBAAiB;IAkBhC,OAAO,CAAC,MAAM,CAAC,kBAAkB;IAkBjC,OAAO,CAAC,MAAM,CAAC,wBAAwB;IAcvC,OAAO,CAAC,MAAM,CAAC,2BAA2B;IAgB1C,OAAO,CAAC,MAAM,CAAC,mBAAmB;IAIlC,OAAO,CAAC,MAAM,CAAC,wBAAwB;IAOvC,OAAO,CAAC,MAAM,CAAC,eAAe;IA4C9B,OAAO,CAAC,MAAM,CAAC,8BAA8B;IAmB7C,OAAO,CAAC,MAAM,CAAC,qBAAqB;IAIpC,OAAO,CAAC,MAAM,CAAC,gBAAgB;IAM/B,OAAO,CAAC,MAAM,CAAC,uBAAuB;IAqBtC,OAAO,CAAC,MAAM,CAAC,eAAe;IAU9B,OAAO,CAAC,MAAM,CAAC,aAAa;WAoBd,uBAAuB,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,MAAM;CAM9E"}
|
|
@@ -0,0 +1,227 @@
|
|
|
1
|
+
import { existsSync } from "node:fs";
|
|
2
|
+
import { basename, dirname, relative, resolve } from "node:path";
|
|
3
|
+
import { TOOL_PATH_ARG_KEYS } from "./types.js";
|
|
4
|
+
export class ToolArgsNormalizer {
|
|
5
|
+
static normalizeToolArgs(rootDir, skillRoots, name, args, skillPathMap) {
|
|
6
|
+
let nextArgs = this.expandPlaceholders(rootDir, skillRoots, args, skillPathMap);
|
|
7
|
+
nextArgs = this.normalizePathArgs(rootDir, nextArgs);
|
|
8
|
+
if (name === "execute" && typeof nextArgs.command === "string") {
|
|
9
|
+
nextArgs = {
|
|
10
|
+
...nextArgs,
|
|
11
|
+
command: this.normalizeExecuteCommand(rootDir, skillRoots, nextArgs.command, skillPathMap),
|
|
12
|
+
};
|
|
13
|
+
}
|
|
14
|
+
if (this.usesFilePathAlias(name, args)) {
|
|
15
|
+
nextArgs = { ...nextArgs, file_path: args.path };
|
|
16
|
+
}
|
|
17
|
+
if (name === "write_todos") {
|
|
18
|
+
nextArgs = this.normalizeWriteTodosArgs(args, nextArgs);
|
|
19
|
+
}
|
|
20
|
+
return nextArgs;
|
|
21
|
+
}
|
|
22
|
+
static usesFilePathAlias(name, args) {
|
|
23
|
+
return (name === "read_file" || name === "write_file" || name === "edit_file") &&
|
|
24
|
+
typeof args.path === "string" &&
|
|
25
|
+
!("file_path" in args);
|
|
26
|
+
}
|
|
27
|
+
static normalizeExecuteCommand(rootDir, skillRoots, command, skillPathMap) {
|
|
28
|
+
const trimmed = this.expandStringPlaceholders(rootDir, skillRoots, command, skillPathMap).trim();
|
|
29
|
+
const normalized = /^\.\/(Users|home|usr|opt)\//.test(trimmed)
|
|
30
|
+
? `/${trimmed.slice(2)}`
|
|
31
|
+
: trimmed;
|
|
32
|
+
if (skillRoots.length === 0) {
|
|
33
|
+
return normalized;
|
|
34
|
+
}
|
|
35
|
+
const parts = this.tokenizeCommand(normalized);
|
|
36
|
+
if (parts.length < 2) {
|
|
37
|
+
return normalized;
|
|
38
|
+
}
|
|
39
|
+
let changed = false;
|
|
40
|
+
const rewritten = parts.map((part, index) => {
|
|
41
|
+
if (index === 0)
|
|
42
|
+
return part;
|
|
43
|
+
const nextPart = this.resolveSkillRelativeCommandArg(rootDir, skillRoots, part);
|
|
44
|
+
if (nextPart !== part) {
|
|
45
|
+
changed = true;
|
|
46
|
+
}
|
|
47
|
+
return nextPart;
|
|
48
|
+
});
|
|
49
|
+
return changed ? rewritten.map((part) => this.quoteCommandPart(part)).join(" ") : normalized;
|
|
50
|
+
}
|
|
51
|
+
static normalizePathArgs(rootDir, args) {
|
|
52
|
+
let nextArgs = { ...args };
|
|
53
|
+
for (const key of TOOL_PATH_ARG_KEYS) {
|
|
54
|
+
const value = nextArgs[key];
|
|
55
|
+
if (!this.shouldNormalizePath(value)) {
|
|
56
|
+
continue;
|
|
57
|
+
}
|
|
58
|
+
if (this.isResolvableAbsolutePath(rootDir, value)) {
|
|
59
|
+
continue;
|
|
60
|
+
}
|
|
61
|
+
const stripped = value.replace(/^\/+/, "");
|
|
62
|
+
if (!stripped.startsWith("usr/") && !stripped.startsWith("etc/") && !stripped.startsWith("var/")) {
|
|
63
|
+
nextArgs = { ...nextArgs, [key]: stripped };
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
return nextArgs;
|
|
67
|
+
}
|
|
68
|
+
static expandPlaceholders(rootDir, skillRoots, args, skillPathMap) {
|
|
69
|
+
let nextArgs = { ...args };
|
|
70
|
+
for (const [key, value] of Object.entries(nextArgs)) {
|
|
71
|
+
if (typeof value === "string") {
|
|
72
|
+
nextArgs = {
|
|
73
|
+
...nextArgs,
|
|
74
|
+
[key]: this.expandStringPlaceholders(rootDir, skillRoots, value, skillPathMap),
|
|
75
|
+
};
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
return nextArgs;
|
|
79
|
+
}
|
|
80
|
+
static expandStringPlaceholders(rootDir, skillRoots, value, skillPathMap) {
|
|
81
|
+
let nextValue = value.replaceAll("${WORKSPACE}", rootDir.replace(/\\/g, "/"));
|
|
82
|
+
nextValue = nextValue.replace(/\$\{SKILL_PATH(?::([^}]+))?\}/g, (_match, skillName) => {
|
|
83
|
+
const resolved = this.resolveSkillPathPlaceholder(skillRoots, skillName, skillPathMap);
|
|
84
|
+
return resolved ?? _match;
|
|
85
|
+
});
|
|
86
|
+
return nextValue;
|
|
87
|
+
}
|
|
88
|
+
static resolveSkillPathPlaceholder(skillRoots, skillName, skillPathMap) {
|
|
89
|
+
if (skillName && skillPathMap?.[skillName]) {
|
|
90
|
+
return skillPathMap[skillName];
|
|
91
|
+
}
|
|
92
|
+
const normalizedRoots = skillRoots.map((root) => root.replace(/\\/g, "/"));
|
|
93
|
+
if (skillName) {
|
|
94
|
+
const matches = normalizedRoots.filter((root) => basename(root) === skillName);
|
|
95
|
+
return matches.length === 1 ? matches[0] : null;
|
|
96
|
+
}
|
|
97
|
+
return normalizedRoots.length === 1 ? normalizedRoots[0] : null;
|
|
98
|
+
}
|
|
99
|
+
static shouldNormalizePath(value) {
|
|
100
|
+
return typeof value === "string" && value.startsWith("/") && !value.startsWith("//");
|
|
101
|
+
}
|
|
102
|
+
static isResolvableAbsolutePath(rootDir, value) {
|
|
103
|
+
return value === rootDir ||
|
|
104
|
+
value.startsWith(`${rootDir}/`) ||
|
|
105
|
+
existsSync(value) ||
|
|
106
|
+
existsSync(dirname(value));
|
|
107
|
+
}
|
|
108
|
+
static tokenizeCommand(command) {
|
|
109
|
+
const parts = [];
|
|
110
|
+
let current = "";
|
|
111
|
+
let quote = null;
|
|
112
|
+
let escaped = false;
|
|
113
|
+
for (const char of command) {
|
|
114
|
+
if (escaped) {
|
|
115
|
+
current += char;
|
|
116
|
+
escaped = false;
|
|
117
|
+
continue;
|
|
118
|
+
}
|
|
119
|
+
if (char === "\\") {
|
|
120
|
+
escaped = true;
|
|
121
|
+
continue;
|
|
122
|
+
}
|
|
123
|
+
if (quote) {
|
|
124
|
+
if (char === quote) {
|
|
125
|
+
quote = null;
|
|
126
|
+
}
|
|
127
|
+
else {
|
|
128
|
+
current += char;
|
|
129
|
+
}
|
|
130
|
+
continue;
|
|
131
|
+
}
|
|
132
|
+
if (char === "'" || char === "\"") {
|
|
133
|
+
quote = char;
|
|
134
|
+
continue;
|
|
135
|
+
}
|
|
136
|
+
if (/\s/.test(char)) {
|
|
137
|
+
if (current) {
|
|
138
|
+
parts.push(current);
|
|
139
|
+
current = "";
|
|
140
|
+
}
|
|
141
|
+
continue;
|
|
142
|
+
}
|
|
143
|
+
current += char;
|
|
144
|
+
}
|
|
145
|
+
if (current) {
|
|
146
|
+
parts.push(current);
|
|
147
|
+
}
|
|
148
|
+
return parts;
|
|
149
|
+
}
|
|
150
|
+
static resolveSkillRelativeCommandArg(rootDir, skillRoots, value) {
|
|
151
|
+
if (!this.looksLikeRelativePath(value) || value.startsWith("./") || value.startsWith("../")) {
|
|
152
|
+
return value;
|
|
153
|
+
}
|
|
154
|
+
if (existsSync(resolve(rootDir, value))) {
|
|
155
|
+
return value;
|
|
156
|
+
}
|
|
157
|
+
const matches = skillRoots
|
|
158
|
+
.map((skillRoot) => resolve(skillRoot, value))
|
|
159
|
+
.filter((candidate) => existsSync(candidate));
|
|
160
|
+
if (matches.length !== 1) {
|
|
161
|
+
return value;
|
|
162
|
+
}
|
|
163
|
+
const rel = relative(rootDir, matches[0]).replace(/\\/g, "/");
|
|
164
|
+
return rel && !rel.startsWith("..") ? rel : matches[0].replace(/\\/g, "/");
|
|
165
|
+
}
|
|
166
|
+
static looksLikeRelativePath(value) {
|
|
167
|
+
return value.includes("/") && !value.startsWith("/") && !value.startsWith("~") && !value.startsWith("-");
|
|
168
|
+
}
|
|
169
|
+
static quoteCommandPart(value) {
|
|
170
|
+
return /^[A-Za-z0-9_./:@=-]+$/.test(value)
|
|
171
|
+
? value
|
|
172
|
+
: `'${value.replace(/'/g, `'\\''`)}'`;
|
|
173
|
+
}
|
|
174
|
+
static normalizeWriteTodosArgs(args, nextArgs) {
|
|
175
|
+
if (!Array.isArray(args.todos)) {
|
|
176
|
+
const text = this.extractTodoText(args);
|
|
177
|
+
if (!text) {
|
|
178
|
+
return nextArgs;
|
|
179
|
+
}
|
|
180
|
+
return {
|
|
181
|
+
...nextArgs,
|
|
182
|
+
todos: [{
|
|
183
|
+
content: text,
|
|
184
|
+
status: args.status === "in_progress" || args.status === "completed" ? args.status : "pending",
|
|
185
|
+
}],
|
|
186
|
+
};
|
|
187
|
+
}
|
|
188
|
+
return {
|
|
189
|
+
...nextArgs,
|
|
190
|
+
todos: args.todos.map((todo) => this.normalizeTodo(todo)),
|
|
191
|
+
};
|
|
192
|
+
}
|
|
193
|
+
static extractTodoText(args) {
|
|
194
|
+
if (typeof args.description === "string") {
|
|
195
|
+
return args.description;
|
|
196
|
+
}
|
|
197
|
+
if (typeof args.content === "string") {
|
|
198
|
+
return args.content;
|
|
199
|
+
}
|
|
200
|
+
return null;
|
|
201
|
+
}
|
|
202
|
+
static normalizeTodo(todo) {
|
|
203
|
+
if (typeof todo === "string") {
|
|
204
|
+
return { content: todo, status: "pending" };
|
|
205
|
+
}
|
|
206
|
+
if (!todo || typeof todo !== "object") {
|
|
207
|
+
return { content: JSON.stringify(todo), status: "pending" };
|
|
208
|
+
}
|
|
209
|
+
const candidate = todo;
|
|
210
|
+
const content = typeof candidate.content === "string"
|
|
211
|
+
? candidate.content
|
|
212
|
+
: typeof candidate.description === "string"
|
|
213
|
+
? candidate.description
|
|
214
|
+
: JSON.stringify(todo);
|
|
215
|
+
const status = candidate.status === "in_progress" || candidate.status === "completed"
|
|
216
|
+
? candidate.status
|
|
217
|
+
: "pending";
|
|
218
|
+
return { content, status };
|
|
219
|
+
}
|
|
220
|
+
static resolveScriptSourcePath(rootDir, value) {
|
|
221
|
+
const normalized = value.replace(/\\/g, "/");
|
|
222
|
+
return normalized.startsWith("/")
|
|
223
|
+
? normalized
|
|
224
|
+
: resolve(rootDir, normalized).replace(/\\/g, "/");
|
|
225
|
+
}
|
|
226
|
+
}
|
|
227
|
+
//# sourceMappingURL=toolArgsNormalizer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"toolArgsNormalizer.js","sourceRoot":"","sources":["../../../src/runtime/middleware/toolArgsNormalizer.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { type ToolArgs, type ToolMessageConstructorLike, type ToolMessageLike } from "./types.js";
|
|
2
|
+
export declare class ToolCallGuard {
|
|
3
|
+
static maybeBlock(name: string, args: ToolArgs, toolCallId: string | undefined, ToolMessage: ToolMessageConstructorLike, rootDir: string, allowedToolNames?: string[], allowedPathPrefixes?: string[]): ToolMessageLike | null;
|
|
4
|
+
private static isToolAllowed;
|
|
5
|
+
private static hasAbsolutePathArgOutsideWorkspace;
|
|
6
|
+
private static isScriptSourcePath;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=toolCallGuard.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"toolCallGuard.d.ts","sourceRoot":"","sources":["../../../src/runtime/middleware/toolCallGuard.ts"],"names":[],"mappings":"AAEA,OAAO,EAAsB,KAAK,QAAQ,EAAE,KAAK,0BAA0B,EAAE,KAAK,eAAe,EAAE,MAAM,YAAY,CAAC;AAEtH,qBAAa,aAAa;WACV,UAAU,CACtB,IAAI,EAAE,MAAM,EACZ,IAAI,EAAE,QAAQ,EACd,UAAU,EAAE,MAAM,GAAG,SAAS,EAC9B,WAAW,EAAE,0BAA0B,EACvC,OAAO,EAAE,MAAM,EACf,gBAAgB,CAAC,EAAE,MAAM,EAAE,EAC3B,mBAAmB,GAAE,MAAM,EAAO,GACjC,eAAe,GAAG,IAAI;IAyBzB,OAAO,CAAC,MAAM,CAAC,aAAa;IAQ5B,OAAO,CAAC,MAAM,CAAC,kCAAkC;IAmBjD,OAAO,CAAC,MAAM,CAAC,kBAAkB;CAOlC"}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import { CommandPolicy } from "./commandPolicy.js";
|
|
2
|
+
import { ToolArgsNormalizer } from "./toolArgsNormalizer.js";
|
|
3
|
+
import { TOOL_PATH_ARG_KEYS } from "./types.js";
|
|
4
|
+
export class ToolCallGuard {
|
|
5
|
+
static maybeBlock(name, args, toolCallId, ToolMessage, rootDir, allowedToolNames, allowedPathPrefixes = []) {
|
|
6
|
+
if (allowedToolNames?.length && !this.isToolAllowed(name, allowedToolNames)) {
|
|
7
|
+
return new ToolMessage({
|
|
8
|
+
content: `Error: Tool "${name}" is not allowed by tool config allowlist.`,
|
|
9
|
+
tool_call_id: toolCallId ?? name,
|
|
10
|
+
});
|
|
11
|
+
}
|
|
12
|
+
if ((name === "read_file" || name === "edit_file") && this.isScriptSourcePath(args, rootDir)) {
|
|
13
|
+
return new ToolMessage({
|
|
14
|
+
content: "Error: Do not inspect script source files unless the user explicitly asks for script code.",
|
|
15
|
+
tool_call_id: toolCallId ?? name,
|
|
16
|
+
});
|
|
17
|
+
}
|
|
18
|
+
if (this.hasAbsolutePathArgOutsideWorkspace(args, rootDir, allowedPathPrefixes)) {
|
|
19
|
+
return new ToolMessage({
|
|
20
|
+
content: "Error: Do not use absolute filesystem paths outside workspace root. Use workspace-relative paths only.",
|
|
21
|
+
tool_call_id: toolCallId ?? name,
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
if (name === "execute" && typeof args.command === "string") {
|
|
25
|
+
return CommandPolicy.maybeBlockExecuteCommand(args.command, toolCallId, ToolMessage, rootDir, allowedPathPrefixes);
|
|
26
|
+
}
|
|
27
|
+
return null;
|
|
28
|
+
}
|
|
29
|
+
static isToolAllowed(name, allowedToolNames) {
|
|
30
|
+
if (allowedToolNames.includes(name))
|
|
31
|
+
return true;
|
|
32
|
+
return allowedToolNames.some((allowed) => {
|
|
33
|
+
const normalized = allowed.trim();
|
|
34
|
+
return Boolean(normalized && !normalized.includes(".") && name.endsWith(`.${normalized}`));
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
static hasAbsolutePathArgOutsideWorkspace(args, rootDir, allowedPathPrefixes) {
|
|
38
|
+
const normalizedRoot = rootDir.replace(/\\/g, "/");
|
|
39
|
+
const normalizedAllowed = allowedPathPrefixes.map((entry) => entry.replace(/\\/g, "/"));
|
|
40
|
+
return TOOL_PATH_ARG_KEYS.some((key) => {
|
|
41
|
+
const value = args[key];
|
|
42
|
+
if (typeof value !== "string")
|
|
43
|
+
return false;
|
|
44
|
+
const path = value.replace(/\\/g, "/");
|
|
45
|
+
return path.startsWith("/") &&
|
|
46
|
+
!path.startsWith("//") &&
|
|
47
|
+
path !== normalizedRoot &&
|
|
48
|
+
!path.startsWith(`${normalizedRoot}/`) &&
|
|
49
|
+
!normalizedAllowed.some((prefix) => path === prefix || path.startsWith(`${prefix}/`));
|
|
50
|
+
});
|
|
51
|
+
}
|
|
52
|
+
static isScriptSourcePath(args, rootDir) {
|
|
53
|
+
return TOOL_PATH_ARG_KEYS.some((key) => {
|
|
54
|
+
const value = args[key];
|
|
55
|
+
return typeof value === "string" &&
|
|
56
|
+
ToolArgsNormalizer.resolveScriptSourcePath(rootDir, value).includes("/scripts/");
|
|
57
|
+
});
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
//# sourceMappingURL=toolCallGuard.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"toolCallGuard.js","sourceRoot":"","sources":["../../../src/runtime/middleware/toolCallGuard.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { type ToolArgs } from "./types.js";
|
|
2
|
+
export declare class ToolFsHandlers {
|
|
3
|
+
static expandEditFileContent(rootDir: string, args: ToolArgs): Promise<ToolArgs>;
|
|
4
|
+
static handleWriteFile(rootDir: string, args: ToolArgs, logger: (message: string) => void): Promise<{
|
|
5
|
+
content: string;
|
|
6
|
+
} | null>;
|
|
7
|
+
static handleListFiles(rootDir: string, args: ToolArgs): Promise<{
|
|
8
|
+
content: string;
|
|
9
|
+
} | null>;
|
|
10
|
+
private static compareEntries;
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=toolFsHandlers.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"toolFsHandlers.d.ts","sourceRoot":"","sources":["../../../src/runtime/middleware/toolFsHandlers.ts"],"names":[],"mappings":"AAEA,OAAO,EAAkB,KAAK,QAAQ,EAAE,MAAM,YAAY,CAAC;AAE3D,qBAAa,cAAc;WACL,qBAAqB,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAC;WAezE,eAAe,CACjC,OAAO,EAAE,MAAM,EACf,IAAI,EAAE,QAAQ,EACd,MAAM,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,IAAI,GAChC,OAAO,CAAC;QAAE,OAAO,EAAE,MAAM,CAAA;KAAE,GAAG,IAAI,CAAC;WA4BlB,eAAe,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,QAAQ,GAAG,OAAO,CAAC;QAAE,OAAO,EAAE,MAAM,CAAA;KAAE,GAAG,IAAI,CAAC;IAiCzG,OAAO,CAAC,MAAM,CAAC,cAAc;CAQ9B"}
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
import { lstat, mkdir, readdir, readFile, writeFile } from "node:fs/promises";
|
|
2
|
+
import { dirname, resolve } from "node:path";
|
|
3
|
+
import { MAX_LS_ENTRIES } from "./types.js";
|
|
4
|
+
export class ToolFsHandlers {
|
|
5
|
+
static async expandEditFileContent(rootDir, args) {
|
|
6
|
+
if (typeof args.content !== "string" ||
|
|
7
|
+
!(args.file_path ?? args.path) ||
|
|
8
|
+
"old_string" in args) {
|
|
9
|
+
return args;
|
|
10
|
+
}
|
|
11
|
+
const relPath = String(args.file_path ?? args.path);
|
|
12
|
+
const absPath = resolve(rootDir, relPath);
|
|
13
|
+
const oldContent = await readFile(absPath, "utf8").catch(() => "");
|
|
14
|
+
return { ...args, file_path: relPath, old_string: oldContent, new_string: args.content };
|
|
15
|
+
}
|
|
16
|
+
static async handleWriteFile(rootDir, args, logger) {
|
|
17
|
+
const targetPath = args.file_path ?? args.path;
|
|
18
|
+
if (typeof targetPath !== "string") {
|
|
19
|
+
return null;
|
|
20
|
+
}
|
|
21
|
+
const absPath = targetPath.startsWith("/") ? targetPath : resolve(rootDir, targetPath);
|
|
22
|
+
if (absPath !== rootDir && !absPath.startsWith(`${rootDir}/`)) {
|
|
23
|
+
return null;
|
|
24
|
+
}
|
|
25
|
+
const content = String(args.content);
|
|
26
|
+
if (/\.json$/i.test(absPath)) {
|
|
27
|
+
try {
|
|
28
|
+
JSON.parse(content);
|
|
29
|
+
}
|
|
30
|
+
catch (error) {
|
|
31
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
32
|
+
return { content: `Error: invalid JSON for '${targetPath}': ${message}` };
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
await mkdir(dirname(absPath), { recursive: true });
|
|
36
|
+
await writeFile(absPath, content, "utf8");
|
|
37
|
+
logger(`[tool] write_file: ${targetPath} (${content.length} chars)`);
|
|
38
|
+
logger("[tool] write_file done in 0ms");
|
|
39
|
+
return { content: `Successfully wrote to '${targetPath}'` };
|
|
40
|
+
}
|
|
41
|
+
static async handleListFiles(rootDir, args) {
|
|
42
|
+
const requestedPath = typeof args.path === "string" && args.path.trim() ? args.path.trim() : ".";
|
|
43
|
+
const absPath = requestedPath.startsWith("/") ? requestedPath : resolve(rootDir, requestedPath);
|
|
44
|
+
if (absPath !== rootDir && !absPath.startsWith(`${rootDir}/`)) {
|
|
45
|
+
return { content: `Error: path '${requestedPath}' is outside workspace root` };
|
|
46
|
+
}
|
|
47
|
+
const info = await lstat(absPath).catch(() => null);
|
|
48
|
+
if (!info) {
|
|
49
|
+
return { content: `Error: path '${requestedPath}' does not exist` };
|
|
50
|
+
}
|
|
51
|
+
if (!info.isDirectory()) {
|
|
52
|
+
const size = typeof info.size === "number" ? `${info.size} bytes` : "unknown size";
|
|
53
|
+
return { content: `${requestedPath === "." ? "." : requestedPath}\n[file] ${size}` };
|
|
54
|
+
}
|
|
55
|
+
const entries = await readdir(absPath, { withFileTypes: true }).catch(() => null);
|
|
56
|
+
if (!entries) {
|
|
57
|
+
return { content: `Error: unable to list '${requestedPath}'` };
|
|
58
|
+
}
|
|
59
|
+
const lines = entries
|
|
60
|
+
.sort((a, b) => this.compareEntries(a.isDirectory(), b.isDirectory(), a.name, b.name))
|
|
61
|
+
.slice(0, MAX_LS_ENTRIES)
|
|
62
|
+
.map((entry) => `${entry.name}${entry.isDirectory() ? "/" : entry.isSymbolicLink() ? "@" : ""}`);
|
|
63
|
+
const truncated = entries.length > MAX_LS_ENTRIES
|
|
64
|
+
? `\n... truncated ${entries.length - MAX_LS_ENTRIES} more entries`
|
|
65
|
+
: "";
|
|
66
|
+
return {
|
|
67
|
+
content: `${requestedPath === "." ? "." : requestedPath}\n${lines.join("\n")}${truncated}`,
|
|
68
|
+
};
|
|
69
|
+
}
|
|
70
|
+
static compareEntries(aIsDirectory, bIsDirectory, aName, bName) {
|
|
71
|
+
const aRank = aIsDirectory ? 0 : 1;
|
|
72
|
+
const bRank = bIsDirectory ? 0 : 1;
|
|
73
|
+
if (aRank !== bRank) {
|
|
74
|
+
return aRank - bRank;
|
|
75
|
+
}
|
|
76
|
+
return aName.localeCompare(bName);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
//# sourceMappingURL=toolFsHandlers.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"toolFsHandlers.js","sourceRoot":"","sources":["../../../src/runtime/middleware/toolFsHandlers.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { MiddlewareRequest, ToolArgs, ToolCallAfterHookContext, ToolCallHookContext } from "./types.js";
|
|
2
|
+
export declare class ToolRequestParser {
|
|
3
|
+
static toMiddlewareRequest(request: unknown): MiddlewareRequest;
|
|
4
|
+
static toToolArgs(args: unknown): ToolArgs;
|
|
5
|
+
static toHookRequest(request: MiddlewareRequest): ToolCallHookContext["request"];
|
|
6
|
+
static toAfterHookRequest(request: MiddlewareRequest): ToolCallAfterHookContext["request"];
|
|
7
|
+
static toModelRequest(request: unknown): Record<string, unknown> & {
|
|
8
|
+
systemPrompt?: string;
|
|
9
|
+
threadId?: string;
|
|
10
|
+
};
|
|
11
|
+
private static extractThreadId;
|
|
12
|
+
private static readThreadId;
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=toolRequestParser.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"toolRequestParser.d.ts","sourceRoot":"","sources":["../../../src/runtime/middleware/toolRequestParser.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,iBAAiB,EACjB,QAAQ,EACR,wBAAwB,EACxB,mBAAmB,EACpB,MAAM,YAAY,CAAC;AAEpB,qBAAa,iBAAiB;WACd,mBAAmB,CAAC,OAAO,EAAE,OAAO,GAAG,iBAAiB;WAoBxD,UAAU,CAAC,IAAI,EAAE,OAAO,GAAG,QAAQ;WAOnC,aAAa,CAAC,OAAO,EAAE,iBAAiB,GAAG,mBAAmB,CAAC,SAAS,CAAC;WAUzE,kBAAkB,CAAC,OAAO,EAAE,iBAAiB,GAAG,wBAAwB,CAAC,SAAS,CAAC;WAUnF,cAAc,CAAC,OAAO,EAAE,OAAO,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG;QAAE,YAAY,CAAC,EAAE,MAAM,CAAC;QAAC,QAAQ,CAAC,EAAE,MAAM,CAAA;KAAE;IAatH,OAAO,CAAC,MAAM,CAAC,eAAe;IAU9B,OAAO,CAAC,MAAM,CAAC,YAAY;CAK5B"}
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
export class ToolRequestParser {
|
|
2
|
+
static toMiddlewareRequest(request) {
|
|
3
|
+
if (!request || typeof request !== "object") {
|
|
4
|
+
throw new Error("Invalid tool call request");
|
|
5
|
+
}
|
|
6
|
+
const candidate = request;
|
|
7
|
+
if (!candidate.toolCall || typeof candidate.toolCall.name !== "string") {
|
|
8
|
+
throw new Error("Invalid tool call request");
|
|
9
|
+
}
|
|
10
|
+
return {
|
|
11
|
+
...candidate,
|
|
12
|
+
threadId: this.extractThreadId(candidate),
|
|
13
|
+
toolCall: {
|
|
14
|
+
id: candidate.toolCall.id,
|
|
15
|
+
name: candidate.toolCall.name,
|
|
16
|
+
args: candidate.toolCall.args,
|
|
17
|
+
},
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
static toToolArgs(args) {
|
|
21
|
+
if (!args || typeof args !== "object") {
|
|
22
|
+
return {};
|
|
23
|
+
}
|
|
24
|
+
return args;
|
|
25
|
+
}
|
|
26
|
+
static toHookRequest(request) {
|
|
27
|
+
return {
|
|
28
|
+
toolCall: {
|
|
29
|
+
id: request.toolCall.id,
|
|
30
|
+
name: request.toolCall.name,
|
|
31
|
+
args: request.toolCall.args,
|
|
32
|
+
},
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
static toAfterHookRequest(request) {
|
|
36
|
+
return {
|
|
37
|
+
toolCall: {
|
|
38
|
+
id: request.toolCall.id,
|
|
39
|
+
name: request.toolCall.name,
|
|
40
|
+
args: request.toolCall.args,
|
|
41
|
+
},
|
|
42
|
+
};
|
|
43
|
+
}
|
|
44
|
+
static toModelRequest(request) {
|
|
45
|
+
if (!request || typeof request !== "object") {
|
|
46
|
+
throw new Error("Invalid model request");
|
|
47
|
+
}
|
|
48
|
+
const candidate = request;
|
|
49
|
+
return {
|
|
50
|
+
...candidate,
|
|
51
|
+
systemPrompt: typeof candidate.systemPrompt === "string" ? candidate.systemPrompt : undefined,
|
|
52
|
+
threadId: this.extractThreadId(candidate),
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
static extractThreadId(candidate) {
|
|
56
|
+
const direct = this.readThreadId(candidate.configurable);
|
|
57
|
+
if (direct)
|
|
58
|
+
return direct;
|
|
59
|
+
const config = candidate.config;
|
|
60
|
+
if (config && typeof config === "object") {
|
|
61
|
+
return this.readThreadId(config.configurable);
|
|
62
|
+
}
|
|
63
|
+
return undefined;
|
|
64
|
+
}
|
|
65
|
+
static readThreadId(value) {
|
|
66
|
+
if (!value || typeof value !== "object")
|
|
67
|
+
return undefined;
|
|
68
|
+
const threadId = value.thread_id;
|
|
69
|
+
return typeof threadId === "string" && threadId.trim().length > 0 ? threadId : undefined;
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
//# sourceMappingURL=toolRequestParser.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"toolRequestParser.js","sourceRoot":"","sources":["../../../src/runtime/middleware/toolRequestParser.ts"],"names":[],"mappings":"AAOA,MAAM,OAAO,iBAAiB;IACrB,MAAM,CAAC,mBAAmB,CAAC,OAAgB;QAChD,IAAI,CAAC,OAAO,IAAI,OAAO,OAAO,KAAK,QAAQ,EAAE,CAAC;YAC5C,MAAM,IAAI,KAAK,CAAC,2BAA2B,CAAC,CAAC;QAC/C,CAAC;QACD,MAAM,SAAS,GAAG,OAAqC,CAAC;QACxD,IAAI,CAAC,SAAS,CAAC,QAAQ,IAAI,OAAO,SAAS,CAAC,QAAQ,CAAC,IAAI,KAAK,QAAQ,EAAE,CAAC;YACvE,MAAM,IAAI,KAAK,CAAC,2BAA2B,CAAC,CAAC;QAC/C,CAAC;QAED,OAAO;YACL,GAAG,SAAS;YACZ,QAAQ,EAAE,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC;YACzC,QAAQ,EAAE;gBACR,EAAE,EAAE,SAAS,CAAC,QAAQ,CAAC,EAAE;gBACzB,IAAI,EAAE,SAAS,CAAC,QAAQ,CAAC,IAAI;gBAC7B,IAAI,EAAE,SAAS,CAAC,QAAQ,CAAC,IAAI;aAC9B;SACF,CAAC;IACJ,CAAC;IAEM,MAAM,CAAC,UAAU,CAAC,IAAa;QACpC,IAAI,CAAC,IAAI,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE,CAAC;YACtC,OAAO,EAAE,CAAC;QACZ,CAAC;QACD,OAAO,IAAgB,CAAC;IAC1B,CAAC;IAEM,MAAM,CAAC,aAAa,CAAC,OAA0B;QACpD,OAAO;YACL,QAAQ,EAAE;gBACR,EAAE,EAAE,OAAO,CAAC,QAAQ,CAAC,EAAE;gBACvB,IAAI,EAAE,OAAO,CAAC,QAAQ,CAAC,IAAI;gBAC3B,IAAI,EAAE,OAAO,CAAC,QAAQ,CAAC,IAAI;aAC5B;SACF,CAAC;IACJ,CAAC;IAEM,MAAM,CAAC,kBAAkB,CAAC,OAA0B;QACzD,OAAO;YACL,QAAQ,EAAE;gBACR,EAAE,EAAE,OAAO,CAAC,QAAQ,CAAC,EAAE;gBACvB,IAAI,EAAE,OAAO,CAAC,QAAQ,CAAC,IAAI;gBAC3B,IAAI,EAAE,OAAO,CAAC,QAAQ,CAAC,IAAI;aAC5B;SACF,CAAC;IACJ,CAAC;IAEM,MAAM,CAAC,cAAc,CAAC,OAAgB;QAC3C,IAAI,CAAC,OAAO,IAAI,OAAO,OAAO,KAAK,QAAQ,EAAE,CAAC;YAC5C,MAAM,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAC;QAC3C,CAAC;QAED,MAAM,SAAS,GAAG,OAAkC,CAAC;QACrD,OAAO;YACL,GAAG,SAAS;YACZ,YAAY,EAAE,OAAO,SAAS,CAAC,YAAY,KAAK,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC,CAAC,SAAS;YAC7F,QAAQ,EAAE,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC;SAC1C,CAAC;IACJ,CAAC;IAEO,MAAM,CAAC,eAAe,CAAC,SAAkC;QAC/D,MAAM,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC;QACzD,IAAI,MAAM;YAAE,OAAO,MAAM,CAAC;QAC1B,MAAM,MAAM,GAAG,SAAS,CAAC,MAAM,CAAC;QAChC,IAAI,MAAM,IAAI,OAAO,MAAM,KAAK,QAAQ,EAAE,CAAC;YACzC,OAAO,IAAI,CAAC,YAAY,CAAE,MAAqC,CAAC,YAAY,CAAC,CAAC;QAChF,CAAC;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;IAEO,MAAM,CAAC,YAAY,CAAC,KAAc;QACxC,IAAI,CAAC,KAAK,IAAI,OAAO,KAAK,KAAK,QAAQ;YAAE,OAAO,SAAS,CAAC;QAC1D,MAAM,QAAQ,GAAI,KAAiC,CAAC,SAAS,CAAC;QAC9D,OAAO,OAAO,QAAQ,KAAK,QAAQ,IAAI,QAAQ,CAAC,IAAI,EAAE,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC;IAC3F,CAAC;CACF"}
|