@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.
Files changed (313) hide show
  1. package/.github/workflows/ci.yml +46 -0
  2. package/.github/workflows/release.yml +79 -0
  3. package/README.md +71 -0
  4. package/config/examples/memory.yaml +39 -0
  5. package/config/examples/model.yaml +21 -0
  6. package/config/examples/runtime.yaml +44 -0
  7. package/config/examples/skills.yaml +8 -0
  8. package/config/examples/tool.yaml +16 -0
  9. package/dist/config/index.d.ts +7 -0
  10. package/dist/config/index.d.ts.map +1 -0
  11. package/dist/config/index.js +4 -0
  12. package/dist/config/index.js.map +1 -0
  13. package/dist/config/loader.d.ts +41 -0
  14. package/dist/config/loader.d.ts.map +1 -0
  15. package/dist/config/loader.js +140 -0
  16. package/dist/config/loader.js.map +1 -0
  17. package/dist/config/resolveRuntimeConfig.d.ts +83 -0
  18. package/dist/config/resolveRuntimeConfig.d.ts.map +1 -0
  19. package/dist/config/resolveRuntimeConfig.js +85 -0
  20. package/dist/config/resolveRuntimeConfig.js.map +1 -0
  21. package/dist/config/resources.d.ts +112 -0
  22. package/dist/config/resources.d.ts.map +1 -0
  23. package/dist/config/resources.js +20 -0
  24. package/dist/config/resources.js.map +1 -0
  25. package/dist/config/runtimeConfigLoader.d.ts +28 -0
  26. package/dist/config/runtimeConfigLoader.d.ts.map +1 -0
  27. package/dist/config/runtimeConfigLoader.js +38 -0
  28. package/dist/config/runtimeConfigLoader.js.map +1 -0
  29. package/dist/index.d.ts +9 -0
  30. package/dist/index.d.ts.map +1 -0
  31. package/dist/index.js +5 -0
  32. package/dist/index.js.map +1 -0
  33. package/dist/runtime/agentMiddleware.d.ts +3 -0
  34. package/dist/runtime/agentMiddleware.d.ts.map +1 -0
  35. package/dist/runtime/agentMiddleware.js +2 -0
  36. package/dist/runtime/agentMiddleware.js.map +1 -0
  37. package/dist/runtime/bootstrap/runtimeFactory.d.ts +7 -0
  38. package/dist/runtime/bootstrap/runtimeFactory.d.ts.map +1 -0
  39. package/dist/runtime/bootstrap/runtimeFactory.js +139 -0
  40. package/dist/runtime/bootstrap/runtimeFactory.js.map +1 -0
  41. package/dist/runtime/bootstrap/runtimeModuleInitializer.d.ts +5 -0
  42. package/dist/runtime/bootstrap/runtimeModuleInitializer.d.ts.map +1 -0
  43. package/dist/runtime/bootstrap/runtimeModuleInitializer.js +32 -0
  44. package/dist/runtime/bootstrap/runtimeModuleInitializer.js.map +1 -0
  45. package/dist/runtime/context/agentContext.d.ts +5 -0
  46. package/dist/runtime/context/agentContext.d.ts.map +1 -0
  47. package/dist/runtime/context/agentContext.js +19 -0
  48. package/dist/runtime/context/agentContext.js.map +1 -0
  49. package/dist/runtime/context/globalContext.d.ts +19 -0
  50. package/dist/runtime/context/globalContext.d.ts.map +1 -0
  51. package/dist/runtime/context/globalContext.js +47 -0
  52. package/dist/runtime/context/globalContext.js.map +1 -0
  53. package/dist/runtime/events/eventPublisher.d.ts +15 -0
  54. package/dist/runtime/events/eventPublisher.d.ts.map +1 -0
  55. package/dist/runtime/events/eventPublisher.js +23 -0
  56. package/dist/runtime/events/eventPublisher.js.map +1 -0
  57. package/dist/runtime/execution/agentRunExecutor.d.ts +38 -0
  58. package/dist/runtime/execution/agentRunExecutor.d.ts.map +1 -0
  59. package/dist/runtime/execution/agentRunExecutor.js +378 -0
  60. package/dist/runtime/execution/agentRunExecutor.js.map +1 -0
  61. package/dist/runtime/execution/agentRunExecutor.types.d.ts +37 -0
  62. package/dist/runtime/execution/agentRunExecutor.types.d.ts.map +1 -0
  63. package/dist/runtime/execution/agentRunExecutor.types.js +2 -0
  64. package/dist/runtime/execution/agentRunExecutor.types.js.map +1 -0
  65. package/dist/runtime/execution/agentRunProgress.d.ts +8 -0
  66. package/dist/runtime/execution/agentRunProgress.d.ts.map +1 -0
  67. package/dist/runtime/execution/agentRunProgress.js +46 -0
  68. package/dist/runtime/execution/agentRunProgress.js.map +1 -0
  69. package/dist/runtime/execution/agentRunState.d.ts +44 -0
  70. package/dist/runtime/execution/agentRunState.d.ts.map +1 -0
  71. package/dist/runtime/execution/agentRunState.js +17 -0
  72. package/dist/runtime/execution/agentRunState.js.map +1 -0
  73. package/dist/runtime/execution/policies/runCompletionPolicy.d.ts +5 -0
  74. package/dist/runtime/execution/policies/runCompletionPolicy.d.ts.map +1 -0
  75. package/dist/runtime/execution/policies/runCompletionPolicy.js +30 -0
  76. package/dist/runtime/execution/policies/runCompletionPolicy.js.map +1 -0
  77. package/dist/runtime/execution/policies/runErrorPolicy.d.ts +7 -0
  78. package/dist/runtime/execution/policies/runErrorPolicy.d.ts.map +1 -0
  79. package/dist/runtime/execution/policies/runErrorPolicy.js +40 -0
  80. package/dist/runtime/execution/policies/runErrorPolicy.js.map +1 -0
  81. package/dist/runtime/execution/policies/runPromptBuilder.d.ts +10 -0
  82. package/dist/runtime/execution/policies/runPromptBuilder.d.ts.map +1 -0
  83. package/dist/runtime/execution/policies/runPromptBuilder.js +34 -0
  84. package/dist/runtime/execution/policies/runPromptBuilder.js.map +1 -0
  85. package/dist/runtime/execution/policies/runSummaryFormatter.d.ts +6 -0
  86. package/dist/runtime/execution/policies/runSummaryFormatter.d.ts.map +1 -0
  87. package/dist/runtime/execution/policies/runSummaryFormatter.js +47 -0
  88. package/dist/runtime/execution/policies/runSummaryFormatter.js.map +1 -0
  89. package/dist/runtime/execution/policies/runtimeDelay.d.ts +4 -0
  90. package/dist/runtime/execution/policies/runtimeDelay.d.ts.map +1 -0
  91. package/dist/runtime/execution/policies/runtimeDelay.js +6 -0
  92. package/dist/runtime/execution/policies/runtimeDelay.js.map +1 -0
  93. package/dist/runtime/execution/policies/toolConfigReader.d.ts +8 -0
  94. package/dist/runtime/execution/policies/toolConfigReader.d.ts.map +1 -0
  95. package/dist/runtime/execution/policies/toolConfigReader.js +91 -0
  96. package/dist/runtime/execution/policies/toolConfigReader.js.map +1 -0
  97. package/dist/runtime/human-loop/consoleHumanLoop.d.ts +21 -0
  98. package/dist/runtime/human-loop/consoleHumanLoop.d.ts.map +1 -0
  99. package/dist/runtime/human-loop/consoleHumanLoop.js +102 -0
  100. package/dist/runtime/human-loop/consoleHumanLoop.js.map +1 -0
  101. package/dist/runtime/human-loop/humanLoop.d.ts +44 -0
  102. package/dist/runtime/human-loop/humanLoop.d.ts.map +1 -0
  103. package/dist/runtime/human-loop/humanLoop.js +36 -0
  104. package/dist/runtime/human-loop/humanLoop.js.map +1 -0
  105. package/dist/runtime/index.d.ts +10 -0
  106. package/dist/runtime/index.d.ts.map +1 -0
  107. package/dist/runtime/index.js +6 -0
  108. package/dist/runtime/index.js.map +1 -0
  109. package/dist/runtime/middleware/agentToolMiddleware.d.ts +30 -0
  110. package/dist/runtime/middleware/agentToolMiddleware.d.ts.map +1 -0
  111. package/dist/runtime/middleware/agentToolMiddleware.js +259 -0
  112. package/dist/runtime/middleware/agentToolMiddleware.js.map +1 -0
  113. package/dist/runtime/middleware/commandPolicy.d.ts +8 -0
  114. package/dist/runtime/middleware/commandPolicy.d.ts.map +1 -0
  115. package/dist/runtime/middleware/commandPolicy.js +55 -0
  116. package/dist/runtime/middleware/commandPolicy.js.map +1 -0
  117. package/dist/runtime/middleware/frameworkPrompt.d.ts +4 -0
  118. package/dist/runtime/middleware/frameworkPrompt.d.ts.map +1 -0
  119. package/dist/runtime/middleware/frameworkPrompt.js +44 -0
  120. package/dist/runtime/middleware/frameworkPrompt.js.map +1 -0
  121. package/dist/runtime/middleware/index.d.ts +4 -0
  122. package/dist/runtime/middleware/index.d.ts.map +1 -0
  123. package/dist/runtime/middleware/index.js +3 -0
  124. package/dist/runtime/middleware/index.js.map +1 -0
  125. package/dist/runtime/middleware/skillPathMap.d.ts +3 -0
  126. package/dist/runtime/middleware/skillPathMap.d.ts.map +1 -0
  127. package/dist/runtime/middleware/skillPathMap.js +44 -0
  128. package/dist/runtime/middleware/skillPathMap.js.map +1 -0
  129. package/dist/runtime/middleware/toolArgsNormalizer.d.ts +21 -0
  130. package/dist/runtime/middleware/toolArgsNormalizer.d.ts.map +1 -0
  131. package/dist/runtime/middleware/toolArgsNormalizer.js +227 -0
  132. package/dist/runtime/middleware/toolArgsNormalizer.js.map +1 -0
  133. package/dist/runtime/middleware/toolCallGuard.d.ts +8 -0
  134. package/dist/runtime/middleware/toolCallGuard.d.ts.map +1 -0
  135. package/dist/runtime/middleware/toolCallGuard.js +60 -0
  136. package/dist/runtime/middleware/toolCallGuard.js.map +1 -0
  137. package/dist/runtime/middleware/toolFsHandlers.d.ts +12 -0
  138. package/dist/runtime/middleware/toolFsHandlers.d.ts.map +1 -0
  139. package/dist/runtime/middleware/toolFsHandlers.js +79 -0
  140. package/dist/runtime/middleware/toolFsHandlers.js.map +1 -0
  141. package/dist/runtime/middleware/toolRequestParser.d.ts +14 -0
  142. package/dist/runtime/middleware/toolRequestParser.d.ts.map +1 -0
  143. package/dist/runtime/middleware/toolRequestParser.js +72 -0
  144. package/dist/runtime/middleware/toolRequestParser.js.map +1 -0
  145. package/dist/runtime/middleware/types.d.ts +87 -0
  146. package/dist/runtime/middleware/types.d.ts.map +1 -0
  147. package/dist/runtime/middleware/types.js +3 -0
  148. package/dist/runtime/middleware/types.js.map +1 -0
  149. package/dist/runtime/providers/backendResolver.d.ts +26 -0
  150. package/dist/runtime/providers/backendResolver.d.ts.map +1 -0
  151. package/dist/runtime/providers/backendResolver.js +73 -0
  152. package/dist/runtime/providers/backendResolver.js.map +1 -0
  153. package/dist/runtime/providers/index.d.ts +14 -0
  154. package/dist/runtime/providers/index.d.ts.map +1 -0
  155. package/dist/runtime/providers/index.js +10 -0
  156. package/dist/runtime/providers/index.js.map +1 -0
  157. package/dist/runtime/providers/langchainRuntime.d.ts +11 -0
  158. package/dist/runtime/providers/langchainRuntime.d.ts.map +1 -0
  159. package/dist/runtime/providers/langchainRuntime.js +45 -0
  160. package/dist/runtime/providers/langchainRuntime.js.map +1 -0
  161. package/dist/runtime/providers/localShellBackend.d.ts +10 -0
  162. package/dist/runtime/providers/localShellBackend.d.ts.map +1 -0
  163. package/dist/runtime/providers/localShellBackend.js +23 -0
  164. package/dist/runtime/providers/localShellBackend.js.map +1 -0
  165. package/dist/runtime/providers/openaiDeepAgent.d.ts +9 -0
  166. package/dist/runtime/providers/openaiDeepAgent.d.ts.map +1 -0
  167. package/dist/runtime/providers/openaiDeepAgent.js +7 -0
  168. package/dist/runtime/providers/openaiDeepAgent.js.map +1 -0
  169. package/dist/runtime/providers/openaiLocalAgent.d.ts +17 -0
  170. package/dist/runtime/providers/openaiLocalAgent.d.ts.map +1 -0
  171. package/dist/runtime/providers/openaiLocalAgent.js +26 -0
  172. package/dist/runtime/providers/openaiLocalAgent.js.map +1 -0
  173. package/dist/runtime/providers/openaiLocalAgentFactory.d.ts +36 -0
  174. package/dist/runtime/providers/openaiLocalAgentFactory.d.ts.map +1 -0
  175. package/dist/runtime/providers/openaiLocalAgentFactory.js +139 -0
  176. package/dist/runtime/providers/openaiLocalAgentFactory.js.map +1 -0
  177. package/dist/runtime/providers/shared/agentProbe.d.ts +4 -0
  178. package/dist/runtime/providers/shared/agentProbe.d.ts.map +1 -0
  179. package/dist/runtime/providers/shared/agentProbe.js +17 -0
  180. package/dist/runtime/providers/shared/agentProbe.js.map +1 -0
  181. package/dist/runtime/providers/shared/moduleFallback.d.ts +2 -0
  182. package/dist/runtime/providers/shared/moduleFallback.d.ts.map +1 -0
  183. package/dist/runtime/providers/shared/moduleFallback.js +34 -0
  184. package/dist/runtime/providers/shared/moduleFallback.js.map +1 -0
  185. package/dist/runtime/providers/shared/resourceCloser.d.ts +6 -0
  186. package/dist/runtime/providers/shared/resourceCloser.d.ts.map +1 -0
  187. package/dist/runtime/providers/shared/resourceCloser.js +30 -0
  188. package/dist/runtime/providers/shared/resourceCloser.js.map +1 -0
  189. package/dist/runtime/runtimeService.d.ts +109 -0
  190. package/dist/runtime/runtimeService.d.ts.map +1 -0
  191. package/dist/runtime/runtimeService.js +90 -0
  192. package/dist/runtime/runtimeService.js.map +1 -0
  193. package/dist/runtime/stream/agentMessages.d.ts +40 -0
  194. package/dist/runtime/stream/agentMessages.d.ts.map +1 -0
  195. package/dist/runtime/stream/agentMessages.js +44 -0
  196. package/dist/runtime/stream/agentMessages.js.map +1 -0
  197. package/dist/runtime/stream/agentStream.d.ts +31 -0
  198. package/dist/runtime/stream/agentStream.d.ts.map +1 -0
  199. package/dist/runtime/stream/agentStream.js +106 -0
  200. package/dist/runtime/stream/agentStream.js.map +1 -0
  201. package/dist/runtime/stream/messageSummary.d.ts +20 -0
  202. package/dist/runtime/stream/messageSummary.d.ts.map +1 -0
  203. package/dist/runtime/stream/messageSummary.js +150 -0
  204. package/dist/runtime/stream/messageSummary.js.map +1 -0
  205. package/dist/runtime/stream/runArtifacts.d.ts +9 -0
  206. package/dist/runtime/stream/runArtifacts.d.ts.map +1 -0
  207. package/dist/runtime/stream/runArtifacts.js +48 -0
  208. package/dist/runtime/stream/runArtifacts.js.map +1 -0
  209. package/dist/state/index.d.ts +7 -0
  210. package/dist/state/index.d.ts.map +1 -0
  211. package/dist/state/index.js +4 -0
  212. package/dist/state/index.js.map +1 -0
  213. package/dist/state/runState.d.ts +36 -0
  214. package/dist/state/runState.d.ts.map +1 -0
  215. package/dist/state/runState.js +51 -0
  216. package/dist/state/runState.js.map +1 -0
  217. package/dist/state/todos.d.ts +19 -0
  218. package/dist/state/todos.d.ts.map +1 -0
  219. package/dist/state/todos.js +45 -0
  220. package/dist/state/todos.js.map +1 -0
  221. package/dist/state/workspaceRunSession.d.ts +32 -0
  222. package/dist/state/workspaceRunSession.d.ts.map +1 -0
  223. package/dist/state/workspaceRunSession.js +67 -0
  224. package/dist/state/workspaceRunSession.js.map +1 -0
  225. package/dist/state/workspaceState.d.ts +94 -0
  226. package/dist/state/workspaceState.d.ts.map +1 -0
  227. package/dist/state/workspaceState.js +119 -0
  228. package/dist/state/workspaceState.js.map +1 -0
  229. package/dist/types.d.ts +2 -0
  230. package/dist/types.d.ts.map +1 -0
  231. package/dist/types.js +2 -0
  232. package/dist/types.js.map +1 -0
  233. package/example/.tsbuildinfo +1 -0
  234. package/example/build/.tsbuildinfo +1 -0
  235. package/example/config/memory.yaml +35 -0
  236. package/example/config/model.yaml +14 -0
  237. package/example/config/runtime.yaml +46 -0
  238. package/example/config/tool.yaml +24 -0
  239. package/example/index.ts +159 -0
  240. package/example/package-lock.json +1396 -0
  241. package/example/package.json +26 -0
  242. package/example/serve-output.mjs +52 -0
  243. package/example/tsconfig.json +19 -0
  244. package/package.json +73 -0
  245. package/scripts/resolve-deps.js +40 -0
  246. package/src/config/index.ts +29 -0
  247. package/src/config/loader.ts +174 -0
  248. package/src/config/resolveRuntimeConfig.ts +160 -0
  249. package/src/config/resources.ts +152 -0
  250. package/src/config/runtimeConfigLoader.ts +68 -0
  251. package/src/external-modules.d.ts +20 -0
  252. package/src/index.ts +36 -0
  253. package/src/runtime/agentMiddleware.ts +6 -0
  254. package/src/runtime/bootstrap/runtimeFactory.ts +212 -0
  255. package/src/runtime/bootstrap/runtimeModuleInitializer.ts +34 -0
  256. package/src/runtime/context/agentContext.ts +24 -0
  257. package/src/runtime/context/globalContext.ts +70 -0
  258. package/src/runtime/events/eventPublisher.ts +45 -0
  259. package/src/runtime/execution/agentRunExecutor.ts +499 -0
  260. package/src/runtime/execution/agentRunExecutor.types.ts +39 -0
  261. package/src/runtime/execution/agentRunProgress.ts +67 -0
  262. package/src/runtime/execution/agentRunState.ts +66 -0
  263. package/src/runtime/execution/policies/runCompletionPolicy.ts +30 -0
  264. package/src/runtime/execution/policies/runErrorPolicy.ts +50 -0
  265. package/src/runtime/execution/policies/runPromptBuilder.ts +39 -0
  266. package/src/runtime/execution/policies/runSummaryFormatter.ts +57 -0
  267. package/src/runtime/execution/policies/runtimeDelay.ts +5 -0
  268. package/src/runtime/execution/policies/toolConfigReader.ts +107 -0
  269. package/src/runtime/human-loop/consoleHumanLoop.ts +113 -0
  270. package/src/runtime/human-loop/humanLoop.ts +90 -0
  271. package/src/runtime/index.ts +36 -0
  272. package/src/runtime/middleware/agentToolMiddleware.ts +329 -0
  273. package/src/runtime/middleware/commandPolicy.ts +65 -0
  274. package/src/runtime/middleware/frameworkPrompt.ts +51 -0
  275. package/src/runtime/middleware/index.ts +7 -0
  276. package/src/runtime/middleware/skillPathMap.ts +49 -0
  277. package/src/runtime/middleware/toolArgsNormalizer.ts +277 -0
  278. package/src/runtime/middleware/toolCallGuard.ts +73 -0
  279. package/src/runtime/middleware/toolFsHandlers.ts +94 -0
  280. package/src/runtime/middleware/toolRequestParser.ts +84 -0
  281. package/src/runtime/middleware/types.ts +91 -0
  282. package/src/runtime/providers/backendResolver.ts +127 -0
  283. package/src/runtime/providers/index.ts +19 -0
  284. package/src/runtime/providers/langchainRuntime.ts +67 -0
  285. package/src/runtime/providers/localShellBackend.ts +54 -0
  286. package/src/runtime/providers/openaiDeepAgent.ts +17 -0
  287. package/src/runtime/providers/openaiLocalAgent.ts +35 -0
  288. package/src/runtime/providers/openaiLocalAgentFactory.ts +185 -0
  289. package/src/runtime/providers/shared/agentProbe.ts +24 -0
  290. package/src/runtime/providers/shared/moduleFallback.ts +41 -0
  291. package/src/runtime/providers/shared/resourceCloser.ts +30 -0
  292. package/src/runtime/runtimeService.ts +205 -0
  293. package/src/runtime/stream/agentMessages.ts +72 -0
  294. package/src/runtime/stream/agentStream.ts +168 -0
  295. package/src/runtime/stream/messageSummary.ts +164 -0
  296. package/src/runtime/stream/runArtifacts.ts +72 -0
  297. package/src/state/index.ts +19 -0
  298. package/src/state/runState.ts +84 -0
  299. package/src/state/todos.ts +59 -0
  300. package/src/state/workspaceRunSession.ts +96 -0
  301. package/src/state/workspaceState.ts +199 -0
  302. package/src/types/easynet-agent-common.d.ts +62 -0
  303. package/src/types.ts +1 -0
  304. package/test/integration/runtime-live.integration.test.ts +30 -0
  305. package/test/unit/config/loader.test.ts +429 -0
  306. package/test/unit/runtime/agentContext.test.ts +23 -0
  307. package/test/unit/runtime/agentRuntime.test.ts +99 -0
  308. package/test/unit/runtime/consoleHumanLoop.test.ts +52 -0
  309. package/test/unit/runtime/events.test.ts +11 -0
  310. package/test/unit/runtime/globalContext.test.ts +34 -0
  311. package/test/unit/runtime/humanLoop.test.ts +104 -0
  312. package/test/unit/runtime/toolArgsNormalizer.test.ts +136 -0
  313. package/tsconfig.json +18 -0
@@ -0,0 +1,44 @@
1
+ import type { ToolArgs } from "../middleware/types.js";
2
+ export type HumanLoopRequestKind = "tool_approval";
3
+ export type HumanLoopDecisionAction = "approve" | "reject" | "revise";
4
+ export type HumanLoopRiskLevel = "low" | "medium" | "high";
5
+ export interface HumanLoopToolCallContext {
6
+ threadId?: string;
7
+ toolCallId?: string;
8
+ toolName: string;
9
+ args: ToolArgs;
10
+ rootDir: string;
11
+ }
12
+ export interface HumanLoopRequest {
13
+ id: string;
14
+ kind: HumanLoopRequestKind;
15
+ threadId?: string;
16
+ toolCallId?: string;
17
+ toolName: string;
18
+ title: string;
19
+ description: string;
20
+ args: ToolArgs;
21
+ rootDir: string;
22
+ createdAt: string;
23
+ riskLevel?: HumanLoopRiskLevel;
24
+ metadata?: Record<string, unknown>;
25
+ }
26
+ export interface HumanLoopDecision {
27
+ action: HumanLoopDecisionAction;
28
+ message?: string;
29
+ revisedArgs?: ToolArgs;
30
+ actor?: string;
31
+ decidedAt?: string;
32
+ }
33
+ export interface HumanLoopService {
34
+ request(request: HumanLoopRequest): Promise<HumanLoopDecision>;
35
+ }
36
+ export interface HumanLoopToolPolicy {
37
+ buildRequest(context: HumanLoopToolCallContext): HumanLoopRequest | null | undefined;
38
+ }
39
+ export interface CreateDefaultHumanLoopToolPolicyOptions {
40
+ toolNames?: string[];
41
+ riskLevel?: HumanLoopRiskLevel;
42
+ }
43
+ export declare function createDefaultHumanLoopToolPolicy(options?: CreateDefaultHumanLoopToolPolicyOptions): HumanLoopToolPolicy;
44
+ //# sourceMappingURL=humanLoop.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"humanLoop.d.ts","sourceRoot":"","sources":["../../../src/runtime/human-loop/humanLoop.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,wBAAwB,CAAC;AAEvD,MAAM,MAAM,oBAAoB,GAAG,eAAe,CAAC;AACnD,MAAM,MAAM,uBAAuB,GAAG,SAAS,GAAG,QAAQ,GAAG,QAAQ,CAAC;AACtE,MAAM,MAAM,kBAAkB,GAAG,KAAK,GAAG,QAAQ,GAAG,MAAM,CAAC;AAE3D,MAAM,WAAW,wBAAwB;IACvC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,QAAQ,EAAE,MAAM,CAAC;IACjB,IAAI,EAAE,QAAQ,CAAC;IACf,OAAO,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,WAAW,gBAAgB;IAC/B,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,oBAAoB,CAAC;IAC3B,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,EAAE,MAAM,CAAC;IACpB,IAAI,EAAE,QAAQ,CAAC;IACf,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,CAAC,EAAE,kBAAkB,CAAC;IAC/B,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACpC;AAED,MAAM,WAAW,iBAAiB;IAChC,MAAM,EAAE,uBAAuB,CAAC;IAChC,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,WAAW,CAAC,EAAE,QAAQ,CAAC;IACvB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,gBAAgB;IAC/B,OAAO,CAAC,OAAO,EAAE,gBAAgB,GAAG,OAAO,CAAC,iBAAiB,CAAC,CAAC;CAChE;AAED,MAAM,WAAW,mBAAmB;IAClC,YAAY,CAAC,OAAO,EAAE,wBAAwB,GAAG,gBAAgB,GAAG,IAAI,GAAG,SAAS,CAAC;CACtF;AAED,MAAM,WAAW,uCAAuC;IACtD,SAAS,CAAC,EAAE,MAAM,EAAE,CAAC;IACrB,SAAS,CAAC,EAAE,kBAAkB,CAAC;CAChC;AAED,wBAAgB,gCAAgC,CAC9C,OAAO,GAAE,uCAA4C,GACpD,mBAAmB,CAyBrB"}
@@ -0,0 +1,36 @@
1
+ import { randomUUID } from "node:crypto";
2
+ export function createDefaultHumanLoopToolPolicy(options = {}) {
3
+ const riskyToolNames = new Set(options.toolNames ?? ["execute", "write_file", "edit_file"]);
4
+ const riskLevel = options.riskLevel ?? "high";
5
+ return {
6
+ buildRequest(context) {
7
+ if (!riskyToolNames.has(context.toolName)) {
8
+ return null;
9
+ }
10
+ return {
11
+ id: randomUUID(),
12
+ kind: "tool_approval",
13
+ threadId: context.threadId,
14
+ toolCallId: context.toolCallId,
15
+ toolName: context.toolName,
16
+ title: `Approval required for ${context.toolName}`,
17
+ description: buildDefaultDescription(context.toolName, context.args),
18
+ args: context.args,
19
+ rootDir: context.rootDir,
20
+ createdAt: new Date().toISOString(),
21
+ riskLevel,
22
+ };
23
+ },
24
+ };
25
+ }
26
+ function buildDefaultDescription(toolName, args) {
27
+ if (toolName === "execute" && typeof args.command === "string") {
28
+ return `Command: ${args.command}`;
29
+ }
30
+ if ((toolName === "write_file" || toolName === "edit_file") &&
31
+ typeof (args.file_path ?? args.path) === "string") {
32
+ return `File: ${String(args.file_path ?? args.path)}`;
33
+ }
34
+ return `Tool args: ${JSON.stringify(args)}`;
35
+ }
36
+ //# sourceMappingURL=humanLoop.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"humanLoop.js","sourceRoot":"","sources":["../../../src/runtime/human-loop/humanLoop.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAmDzC,MAAM,UAAU,gCAAgC,CAC9C,UAAmD,EAAE;IAErD,MAAM,cAAc,GAAG,IAAI,GAAG,CAAC,OAAO,CAAC,SAAS,IAAI,CAAC,SAAS,EAAE,YAAY,EAAE,WAAW,CAAC,CAAC,CAAC;IAC5F,MAAM,SAAS,GAAG,OAAO,CAAC,SAAS,IAAI,MAAM,CAAC;IAE9C,OAAO;QACL,YAAY,CAAC,OAAO;YAClB,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC;gBAC1C,OAAO,IAAI,CAAC;YACd,CAAC;YAED,OAAO;gBACL,EAAE,EAAE,UAAU,EAAE;gBAChB,IAAI,EAAE,eAAe;gBACrB,QAAQ,EAAE,OAAO,CAAC,QAAQ;gBAC1B,UAAU,EAAE,OAAO,CAAC,UAAU;gBAC9B,QAAQ,EAAE,OAAO,CAAC,QAAQ;gBAC1B,KAAK,EAAE,yBAAyB,OAAO,CAAC,QAAQ,EAAE;gBAClD,WAAW,EAAE,uBAAuB,CAAC,OAAO,CAAC,QAAQ,EAAE,OAAO,CAAC,IAAI,CAAC;gBACpE,IAAI,EAAE,OAAO,CAAC,IAAI;gBAClB,OAAO,EAAE,OAAO,CAAC,OAAO;gBACxB,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;gBACnC,SAAS;aACV,CAAC;QACJ,CAAC;KACF,CAAC;AACJ,CAAC;AAED,SAAS,uBAAuB,CAAC,QAAgB,EAAE,IAAc;IAC/D,IAAI,QAAQ,KAAK,SAAS,IAAI,OAAO,IAAI,CAAC,OAAO,KAAK,QAAQ,EAAE,CAAC;QAC/D,OAAO,YAAY,IAAI,CAAC,OAAO,EAAE,CAAC;IACpC,CAAC;IACD,IAAI,CAAC,QAAQ,KAAK,YAAY,IAAI,QAAQ,KAAK,WAAW,CAAC;QACzD,OAAO,CAAC,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK,QAAQ,EAAE,CAAC;QACpD,OAAO,SAAS,MAAM,CAAC,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;IACxD,CAAC;IACD,OAAO,cAAc,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC;AAC9C,CAAC"}
@@ -0,0 +1,10 @@
1
+ export { AgentRuntimeService, createAgentRuntime2, initializeAgentRuntimeModules, } from "./runtimeService.js";
2
+ export { ConsoleHumanLoopService } from "./human-loop/consoleHumanLoop.js";
3
+ export type { CreateAgentRuntimeFrameworkOptions } from "./runtimeService.js";
4
+ export { createDefaultHumanLoopToolPolicy, } from "./human-loop/humanLoop.js";
5
+ export type { HumanLoopDecision, HumanLoopRequest, HumanLoopService, HumanLoopToolCallContext, HumanLoopToolPolicy, } from "./human-loop/humanLoop.js";
6
+ export type { AgentEvent, AgentEventBus, AgentEventListener, } from "./events/eventPublisher.js";
7
+ export { clearAgentRuntimeGlobalContext, getAgentRuntimeGlobal, getAgentRuntimeGlobalContext, getOrRegisterAgentRuntimeGlobal, registerAgentRuntimeGlobal, } from "./context/globalContext.js";
8
+ export type { AgentRuntimeGlobalContext } from "./context/globalContext.js";
9
+ export { requireAgentRuntimeChatModel, requireAgentRuntimeContextValue, requireAgentRuntimeMemory, requireAgentRuntimeTools, } from "./context/agentContext.js";
10
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/runtime/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,mBAAmB,EACnB,mBAAmB,EACnB,6BAA6B,GAC9B,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,uBAAuB,EAAE,MAAM,kCAAkC,CAAC;AAC3E,YAAY,EAAE,kCAAkC,EAAE,MAAM,qBAAqB,CAAC;AAC9E,OAAO,EACL,gCAAgC,GACjC,MAAM,2BAA2B,CAAC;AACnC,YAAY,EACV,iBAAiB,EACjB,gBAAgB,EAChB,gBAAgB,EAChB,wBAAwB,EACxB,mBAAmB,GACpB,MAAM,2BAA2B,CAAC;AACnC,YAAY,EACV,UAAU,EACV,aAAa,EACb,kBAAkB,GACnB,MAAM,4BAA4B,CAAC;AACpC,OAAO,EACL,8BAA8B,EAC9B,qBAAqB,EACrB,4BAA4B,EAC5B,+BAA+B,EAC/B,0BAA0B,GAC3B,MAAM,4BAA4B,CAAC;AACpC,YAAY,EAAE,yBAAyB,EAAE,MAAM,4BAA4B,CAAC;AAC5E,OAAO,EACL,4BAA4B,EAC5B,+BAA+B,EAC/B,yBAAyB,EACzB,wBAAwB,GACzB,MAAM,2BAA2B,CAAC"}
@@ -0,0 +1,6 @@
1
+ export { AgentRuntimeService, createAgentRuntime2, initializeAgentRuntimeModules, } from "./runtimeService.js";
2
+ export { ConsoleHumanLoopService } from "./human-loop/consoleHumanLoop.js";
3
+ export { createDefaultHumanLoopToolPolicy, } from "./human-loop/humanLoop.js";
4
+ export { clearAgentRuntimeGlobalContext, getAgentRuntimeGlobal, getAgentRuntimeGlobalContext, getOrRegisterAgentRuntimeGlobal, registerAgentRuntimeGlobal, } from "./context/globalContext.js";
5
+ export { requireAgentRuntimeChatModel, requireAgentRuntimeContextValue, requireAgentRuntimeMemory, requireAgentRuntimeTools, } from "./context/agentContext.js";
6
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/runtime/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,mBAAmB,EACnB,mBAAmB,EACnB,6BAA6B,GAC9B,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,uBAAuB,EAAE,MAAM,kCAAkC,CAAC;AAE3E,OAAO,EACL,gCAAgC,GACjC,MAAM,2BAA2B,CAAC;AAanC,OAAO,EACL,8BAA8B,EAC9B,qBAAqB,EACrB,4BAA4B,EAC5B,+BAA+B,EAC/B,0BAA0B,GAC3B,MAAM,4BAA4B,CAAC;AAEpC,OAAO,EACL,4BAA4B,EAC5B,+BAA+B,EAC/B,yBAAyB,EACzB,wBAAwB,GACzB,MAAM,2BAA2B,CAAC"}
@@ -0,0 +1,30 @@
1
+ import type { AgentMiddlewareLike, CreateAgentToolMiddlewareOptions } from "./types.js";
2
+ export declare class AgentToolMiddlewareFactory {
3
+ private readonly rootDir;
4
+ private readonly skillRoots;
5
+ private readonly skillPathMap;
6
+ private readonly createMiddleware;
7
+ private readonly ToolMessage;
8
+ private readonly events?;
9
+ private readonly executeTimeoutMs;
10
+ private readonly blockTaskTool;
11
+ private readonly allowedToolNames?;
12
+ private readonly logger;
13
+ private readonly persistTodos?;
14
+ private readonly humanLoop?;
15
+ private readonly humanLoopToolPolicy?;
16
+ private readonly beforeToolCall?;
17
+ private readonly afterToolCall?;
18
+ constructor(options: CreateAgentToolMiddlewareOptions);
19
+ create(): AgentMiddlewareLike;
20
+ private wrapModelCall;
21
+ private wrapToolCall;
22
+ private expandSyntheticFileEdits;
23
+ private handleSyntheticToolResponse;
24
+ private invokeToolHandler;
25
+ private requestHumanApprovalIfNeeded;
26
+ private resolveHumanLoopDecision;
27
+ private runTool;
28
+ private logToolStart;
29
+ }
30
+ //# sourceMappingURL=agentToolMiddleware.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"agentToolMiddleware.d.ts","sourceRoot":"","sources":["../../../src/runtime/middleware/agentToolMiddleware.ts"],"names":[],"mappings":"AAQA,OAAO,KAAK,EACV,mBAAmB,EACnB,gCAAgC,EAEjC,MAAM,YAAY,CAAC;AAEpB,qBAAa,0BAA0B;IACrC,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAS;IACjC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAW;IACtC,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAyB;IACtD,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAuD;IACxF,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAkD;IAC9E,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,CAA6B;IACrD,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAS;IAC1C,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAU;IACxC,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAC,CAAW;IAC7C,OAAO,CAAC,QAAQ,CAAC,MAAM,CAA4B;IACnD,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAC,CAA6C;IAC3E,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAgD;IAC3E,OAAO,CAAC,QAAQ,CAAC,mBAAmB,CAAC,CAA0D;IAC/F,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAC,CAAqD;IACrF,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAoD;gBAEhE,OAAO,EAAE,gCAAgC;IAkBrD,MAAM,IAAI,mBAAmB;YAQtB,aAAa;YAab,YAAY;YA8EZ,wBAAwB;YAOxB,2BAA2B;YAsB3B,iBAAiB;YAqDjB,4BAA4B;IAoC1C,OAAO,CAAC,wBAAwB;YA2BlB,OAAO;IAqBrB,OAAO,CAAC,YAAY;CAcrB"}
@@ -0,0 +1,259 @@
1
+ import { FrameworkPrompt } from "./frameworkPrompt.js";
2
+ import { ToolArgsNormalizer } from "./toolArgsNormalizer.js";
3
+ import { ToolCallGuard } from "./toolCallGuard.js";
4
+ import { ToolFsHandlers } from "./toolFsHandlers.js";
5
+ import { ToolRequestParser } from "./toolRequestParser.js";
6
+ import { buildSkillPathMap, expandSkillRoots } from "./skillPathMap.js";
7
+ export class AgentToolMiddlewareFactory {
8
+ rootDir;
9
+ skillRoots;
10
+ skillPathMap;
11
+ createMiddleware;
12
+ ToolMessage;
13
+ events;
14
+ executeTimeoutMs;
15
+ blockTaskTool;
16
+ allowedToolNames;
17
+ logger;
18
+ persistTodos;
19
+ humanLoop;
20
+ humanLoopToolPolicy;
21
+ beforeToolCall;
22
+ afterToolCall;
23
+ constructor(options) {
24
+ this.rootDir = options.rootDir;
25
+ this.skillRoots = expandSkillRoots(options.skillRoots ?? []);
26
+ this.skillPathMap = options.skillPathMap ?? buildSkillPathMap(this.skillRoots);
27
+ this.createMiddleware = options.createMiddleware;
28
+ this.ToolMessage = options.ToolMessage;
29
+ this.events = options.events;
30
+ this.executeTimeoutMs = options.executeTimeoutMs ?? 60_000;
31
+ this.blockTaskTool = options.blockTaskTool ?? false;
32
+ this.allowedToolNames = options.allowedToolNames?.filter((name) => typeof name === "string" && name.trim().length > 0);
33
+ this.logger = options.logger ?? (() => { });
34
+ this.persistTodos = options.persistTodos;
35
+ this.humanLoop = options.humanLoop;
36
+ this.humanLoopToolPolicy = options.humanLoopToolPolicy;
37
+ this.beforeToolCall = options.beforeToolCall;
38
+ this.afterToolCall = options.afterToolCall;
39
+ }
40
+ create() {
41
+ return this.createMiddleware({
42
+ name: "AgentToolMiddleware",
43
+ wrapModelCall: async (request, handler) => this.wrapModelCall(request, handler),
44
+ wrapToolCall: async (request, handler) => this.wrapToolCall(request, handler),
45
+ });
46
+ }
47
+ async wrapModelCall(request, handler) {
48
+ const modelRequest = ToolRequestParser.toModelRequest(request);
49
+ return handler({
50
+ ...modelRequest,
51
+ systemPrompt: FrameworkPrompt.build(modelRequest.systemPrompt, this.blockTaskTool, this.allowedToolNames, this.skillPathMap),
52
+ });
53
+ }
54
+ async wrapToolCall(request, handler) {
55
+ const toolRequest = ToolRequestParser.toMiddlewareRequest(request);
56
+ const name = toolRequest.toolCall.name;
57
+ const toolCallId = toolRequest.toolCall.id;
58
+ if (this.blockTaskTool && name === "task") {
59
+ this.events?.emit({
60
+ name: "agent.runtime2.tool.call.blocked",
61
+ from: "agent-runtime2.middleware",
62
+ to: name,
63
+ payload: { toolCallId, reason: "task_tool_disabled" },
64
+ });
65
+ return new this.ToolMessage({
66
+ content: "Error: Do not use the task tool. Use execute(), write_file(), and read_file() directly.",
67
+ tool_call_id: toolCallId ?? "blocked",
68
+ });
69
+ }
70
+ const args = ToolRequestParser.toToolArgs(toolRequest.toolCall.args);
71
+ const blocked = ToolCallGuard.maybeBlock(name, args, toolCallId, this.ToolMessage, this.rootDir, this.allowedToolNames, Object.values(this.skillPathMap));
72
+ if (blocked) {
73
+ this.events?.emit({
74
+ name: "agent.runtime2.tool.call.blocked",
75
+ from: "agent-runtime2.middleware",
76
+ to: name,
77
+ payload: { toolCallId, args, reason: "policy_violation" },
78
+ });
79
+ return blocked;
80
+ }
81
+ let nextArgs = ToolArgsNormalizer.normalizeToolArgs(this.rootDir, this.skillRoots, name, args, this.skillPathMap);
82
+ nextArgs = await this.expandSyntheticFileEdits(name, nextArgs);
83
+ const syntheticResult = await this.handleSyntheticToolResponse(name, toolRequest.toolCall.id, nextArgs);
84
+ if (syntheticResult) {
85
+ return syntheticResult;
86
+ }
87
+ const humanLoopResult = await this.requestHumanApprovalIfNeeded(toolRequest, name, nextArgs);
88
+ if (humanLoopResult?.result) {
89
+ return humanLoopResult.result;
90
+ }
91
+ if (humanLoopResult?.args) {
92
+ nextArgs = humanLoopResult.args;
93
+ }
94
+ const override = await this.beforeToolCall?.({
95
+ threadId: toolRequest.threadId,
96
+ name,
97
+ args,
98
+ nextArgs,
99
+ request: ToolRequestParser.toHookRequest(toolRequest),
100
+ rootDir: this.rootDir,
101
+ });
102
+ if (override?.result) {
103
+ return override.result;
104
+ }
105
+ if (override?.args) {
106
+ nextArgs = override.args;
107
+ }
108
+ return this.invokeToolHandler(toolRequest, name, nextArgs, handler);
109
+ }
110
+ async expandSyntheticFileEdits(name, args) {
111
+ if (name !== "edit_file") {
112
+ return args;
113
+ }
114
+ return ToolFsHandlers.expandEditFileContent(this.rootDir, args);
115
+ }
116
+ async handleSyntheticToolResponse(name, toolCallId, args) {
117
+ if (name === "write_file" && typeof args.content === "string") {
118
+ const result = await ToolFsHandlers.handleWriteFile(this.rootDir, args, this.logger);
119
+ if (result) {
120
+ return new this.ToolMessage({ content: result.content, tool_call_id: toolCallId ?? "write_file" });
121
+ }
122
+ }
123
+ if (name === "ls" || name === "inspect_files") {
124
+ const result = await ToolFsHandlers.handleListFiles(this.rootDir, args);
125
+ if (result) {
126
+ this.logger(`[tool] ${name}: ${String(args.path ?? ".")}`);
127
+ this.logger(`[tool] ${name} done in 0ms`);
128
+ return new this.ToolMessage({ content: result.content, tool_call_id: toolCallId ?? name });
129
+ }
130
+ }
131
+ return null;
132
+ }
133
+ async invokeToolHandler(toolRequest, name, nextArgs, handler) {
134
+ this.events?.emit({
135
+ name: "agent.runtime2.tool.call.start",
136
+ from: "agent-runtime2.middleware",
137
+ to: name,
138
+ payload: { toolCallId: toolRequest.toolCall.id, args: nextArgs },
139
+ });
140
+ this.logToolStart(name, nextArgs);
141
+ const startedAt = Date.now();
142
+ try {
143
+ const result = await this.runTool(name, nextArgs, toolRequest, handler);
144
+ const durationMs = Date.now() - startedAt;
145
+ this.logger(`[tool] ${name} done in ${durationMs}ms`);
146
+ if (name === "write_todos" && Array.isArray(nextArgs.todos)) {
147
+ await this.persistTodos?.(nextArgs.todos);
148
+ }
149
+ await this.afterToolCall?.({
150
+ threadId: toolRequest.threadId,
151
+ name,
152
+ args: nextArgs,
153
+ result,
154
+ request: ToolRequestParser.toAfterHookRequest(toolRequest),
155
+ rootDir: this.rootDir,
156
+ });
157
+ this.events?.emit({
158
+ name: "agent.runtime2.tool.call.done",
159
+ from: name,
160
+ to: "agent-runtime2.middleware",
161
+ payload: { toolCallId: toolRequest.toolCall.id, args: nextArgs, durationMs, result },
162
+ });
163
+ return result;
164
+ }
165
+ catch (error) {
166
+ this.events?.emit({
167
+ name: "agent.runtime2.tool.call.error",
168
+ from: name,
169
+ to: "agent-runtime2.middleware",
170
+ payload: {
171
+ toolCallId: toolRequest.toolCall.id,
172
+ args: nextArgs,
173
+ durationMs: Date.now() - startedAt,
174
+ error: error instanceof Error ? error.message : String(error),
175
+ },
176
+ });
177
+ throw error;
178
+ }
179
+ }
180
+ async requestHumanApprovalIfNeeded(toolRequest, name, args) {
181
+ const request = this.humanLoopToolPolicy?.buildRequest({
182
+ threadId: toolRequest.threadId,
183
+ toolCallId: toolRequest.toolCall.id,
184
+ toolName: name,
185
+ args,
186
+ rootDir: this.rootDir,
187
+ });
188
+ if (!request || !this.humanLoop) {
189
+ return;
190
+ }
191
+ this.events?.emit({
192
+ name: "agent.runtime2.human_loop.requested",
193
+ from: "agent-runtime2.middleware",
194
+ to: "human",
195
+ payload: request,
196
+ });
197
+ const decision = await this.humanLoop.request(request);
198
+ this.events?.emit({
199
+ name: "agent.runtime2.human_loop.resolved",
200
+ from: "human",
201
+ to: "agent-runtime2.middleware",
202
+ payload: {
203
+ request,
204
+ decision,
205
+ },
206
+ });
207
+ return this.resolveHumanLoopDecision(toolRequest.toolCall.id, request, decision);
208
+ }
209
+ resolveHumanLoopDecision(toolCallId, request, decision) {
210
+ if (decision.action === "approve") {
211
+ return decision.revisedArgs ? { args: decision.revisedArgs } : {};
212
+ }
213
+ if (decision.action === "revise") {
214
+ if (decision.revisedArgs) {
215
+ return { args: decision.revisedArgs };
216
+ }
217
+ return {
218
+ result: new this.ToolMessage({
219
+ content: decision.message ?? "Error: human review requested revised args but none were provided.",
220
+ tool_call_id: toolCallId ?? request.id,
221
+ }),
222
+ };
223
+ }
224
+ return {
225
+ result: new this.ToolMessage({
226
+ content: decision.message ?? `Rejected by human reviewer for tool ${request.toolName}.`,
227
+ tool_call_id: toolCallId ?? request.id,
228
+ }),
229
+ };
230
+ }
231
+ async runTool(name, nextArgs, toolRequest, handler) {
232
+ const runPromise = Promise.resolve(handler({
233
+ ...toolRequest,
234
+ toolCall: { ...toolRequest.toolCall, args: nextArgs },
235
+ }));
236
+ if (name !== "execute") {
237
+ return runPromise;
238
+ }
239
+ return Promise.race([
240
+ runPromise,
241
+ new Promise((_, reject) => setTimeout(() => reject(new Error(`execute timeout after ${this.executeTimeoutMs / 1000}s`)), this.executeTimeoutMs)),
242
+ ]);
243
+ }
244
+ logToolStart(name, args) {
245
+ if (name === "execute" && typeof args.command === "string") {
246
+ const command = args.command.length > 120 ? `${args.command.slice(0, 117)}…` : args.command;
247
+ this.logger(`[tool] execute: ${command}`);
248
+ return;
249
+ }
250
+ if (name === "write_file") {
251
+ const filePath = String(args.file_path ?? args.path ?? "");
252
+ const length = typeof args.content === "string" ? args.content.length : 0;
253
+ this.logger(`[tool] write_file: ${filePath} (${length} chars)`);
254
+ return;
255
+ }
256
+ this.logger(`[tool] ${name}`);
257
+ }
258
+ }
259
+ //# sourceMappingURL=agentToolMiddleware.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"agentToolMiddleware.js","sourceRoot":"","sources":["../../../src/runtime/middleware/agentToolMiddleware.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,8 @@
1
+ import type { ToolMessageConstructorLike, ToolMessageLike } from "./types.js";
2
+ export declare class CommandPolicy {
3
+ static maybeBlockExecuteCommand(command: string, toolCallId: string | undefined, ToolMessage: ToolMessageConstructorLike, rootDir: string, allowedPathPrefixes?: string[]): ToolMessageLike | null;
4
+ private static getViolationMessage;
5
+ private static containsAbsolutePathOutsideWorkspace;
6
+ private static isSystemPath;
7
+ }
8
+ //# sourceMappingURL=commandPolicy.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"commandPolicy.d.ts","sourceRoot":"","sources":["../../../src/runtime/middleware/commandPolicy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,0BAA0B,EAAE,eAAe,EAAE,MAAM,YAAY,CAAC;AAE9E,qBAAa,aAAa;WACV,wBAAwB,CACpC,OAAO,EAAE,MAAM,EACf,UAAU,EAAE,MAAM,GAAG,SAAS,EAC9B,WAAW,EAAE,0BAA0B,EACvC,OAAO,EAAE,MAAM,EACf,mBAAmB,GAAE,MAAM,EAAO,GACjC,eAAe,GAAG,IAAI;IAKzB,OAAO,CAAC,MAAM,CAAC,mBAAmB;IA2BlC,OAAO,CAAC,MAAM,CAAC,oCAAoC;IAmBnD,OAAO,CAAC,MAAM,CAAC,YAAY;CAI5B"}
@@ -0,0 +1,55 @@
1
+ export class CommandPolicy {
2
+ static maybeBlockExecuteCommand(command, toolCallId, ToolMessage, rootDir, allowedPathPrefixes = []) {
3
+ const message = this.getViolationMessage(command, rootDir, allowedPathPrefixes);
4
+ return message ? new ToolMessage({ content: message, tool_call_id: toolCallId ?? "execute" }) : null;
5
+ }
6
+ static getViolationMessage(command, rootDir, allowedPathPrefixes) {
7
+ if (/\bls\b/.test(command) && command.includes("?")) {
8
+ return "Error: Do not run fuzzy ls probes with unknown paths. Continue with known workflow commands.";
9
+ }
10
+ if ((/\bbash\b/i.test(command) || /\/bin\/bash\b/i.test(command) || /\bzsh\b/i.test(command)) && command.includes("/scripts/")) {
11
+ return "Error: Do not wrap skill scripts with `bash`. Execute the script path directly.";
12
+ }
13
+ if (/\bchmod\s+\+x\b/i.test(command)) {
14
+ return "Error: Do not run chmod +x. Use direct execution of the target command or script.";
15
+ }
16
+ if (/\b(?:ba)?sh\s+-lc\b/i.test(command)) {
17
+ return "Error: Do not wrap command execution with shell -lc. Execute the target command directly.";
18
+ }
19
+ if (/\b(curl|wget)\b/i.test(command)) {
20
+ return "Error: Do not execute direct network fetch commands. Use provided scripts/tools and then write results with write_file/edit_file.";
21
+ }
22
+ if (/\|\s*reportgen\b/i.test(command)) {
23
+ return "Error: Do not pipe output to ad-hoc generators. Use write_file/edit_file for artifact generation.";
24
+ }
25
+ if (/(^|[\s;|&])(?:echo|cat|printf)[^|&;]*>\s*[^\s]+/i.test(command)) {
26
+ return "Error: Do not write files via shell redirection in execute. Use write_file/edit_file tools.";
27
+ }
28
+ return this.containsAbsolutePathOutsideWorkspace(command, rootDir, allowedPathPrefixes)
29
+ ? "Error: Do not execute commands with absolute paths outside workspace root. Use workspace-relative paths only."
30
+ : null;
31
+ }
32
+ static containsAbsolutePathOutsideWorkspace(command, rootDir, allowedPathPrefixes) {
33
+ const normalizedRoot = rootDir.replace(/\\/g, "/");
34
+ const normalizedAllowed = allowedPathPrefixes.map((entry) => entry.replace(/\\/g, "/"));
35
+ const pathLikeMatches = [...command.matchAll(/(?:^|[\s=>(;|&])(["']?)(\/[^\s"'`<>|&;]+)\1/g)];
36
+ for (const match of pathLikeMatches) {
37
+ const pathToken = match[2];
38
+ if (!pathToken || pathToken.startsWith("//"))
39
+ continue;
40
+ if (this.isSystemPath(pathToken))
41
+ continue;
42
+ if (pathToken === normalizedRoot || pathToken.startsWith(`${normalizedRoot}/`))
43
+ continue;
44
+ if (normalizedAllowed.some((prefix) => pathToken === prefix || pathToken.startsWith(`${prefix}/`)))
45
+ continue;
46
+ return true;
47
+ }
48
+ return false;
49
+ }
50
+ static isSystemPath(pathToken) {
51
+ return ["/usr/", "/bin/", "/etc/", "/var/", "/dev/", "/proc/", "/System/", "/opt/"]
52
+ .some((prefix) => pathToken.startsWith(prefix));
53
+ }
54
+ }
55
+ //# sourceMappingURL=commandPolicy.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"commandPolicy.js","sourceRoot":"","sources":["../../../src/runtime/middleware/commandPolicy.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ export declare class FrameworkPrompt {
2
+ static build(currentPrompt: string | undefined, blockTaskTool: boolean, allowedToolNames?: string[], skillPathMap?: Record<string, string>): string;
3
+ }
4
+ //# sourceMappingURL=frameworkPrompt.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"frameworkPrompt.d.ts","sourceRoot":"","sources":["../../../src/runtime/middleware/frameworkPrompt.ts"],"names":[],"mappings":"AAAA,qBAAa,eAAe;WACZ,KAAK,CACjB,aAAa,EAAE,MAAM,GAAG,SAAS,EACjC,aAAa,EAAE,OAAO,EACtB,gBAAgB,CAAC,EAAE,MAAM,EAAE,EAC3B,YAAY,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GACpC,MAAM;CA4CV"}
@@ -0,0 +1,44 @@
1
+ export class FrameworkPrompt {
2
+ static build(currentPrompt, blockTaskTool, allowedToolNames, skillPathMap) {
3
+ const baseRules = [
4
+ "Framework execution rules:",
5
+ "- Follow SKILL instructions exactly as the source of truth.",
6
+ "- Execute required workflow steps in order; do not skip required steps.",
7
+ "- Do not add extra exploratory or redundant operations outside the SKILL workflow.",
8
+ "- Support both tool calls and script commands: use whichever the SKILL explicitly allows for each step.",
9
+ "- If a SKILL allows both tool and script for the same step, prefer the safer/more structured tool path.",
10
+ "- For independent operations with no data dependency, prefer parallel tool calls to reduce latency.",
11
+ "- Do not stop after intermediate reads/planning. Continue autonomously until required outputs are produced.",
12
+ '- Return strict JSON for tool arguments (example: {"offset":0}, never "offset=0").',
13
+ "- Use workspace-relative paths only; do not invent absolute filesystem paths unless provided by runtime placeholders.",
14
+ "- Do not inspect script source files unless explicitly requested.",
15
+ "- Runtime path variable `${WORKSPACE}` expands to the workspace root.",
16
+ ];
17
+ if (blockTaskTool) {
18
+ baseRules.push("- The task tool is disabled. Never call task; complete work using available file and execute tools.");
19
+ }
20
+ if (allowedToolNames?.length) {
21
+ baseRules.push(`- Tool allowlist is enforced by config. Only call these tools: ${allowedToolNames.join(", ")}.`);
22
+ }
23
+ const skillEntries = Object.entries(skillPathMap ?? {});
24
+ if (skillEntries.length > 0) {
25
+ baseRules.push("- Active skills for this run:");
26
+ for (const [skillId, skillPath] of skillEntries) {
27
+ baseRules.push(` - ${skillId} => ${skillPath}`);
28
+ }
29
+ baseRules.push("- Use `${SKILL_PATH:<skill-id>}` to reference a specific skill directory from the active skill mapping above.");
30
+ if (skillEntries.length === 1) {
31
+ baseRules.push("- Because only one skill is active, `${SKILL_PATH}` also resolves to that skill directory.");
32
+ }
33
+ baseRules.push("- `${SKILL_PATH...}` is only for skill-owned assets such as scripts/, references/, templates, and static inputs explicitly required by the SKILL.");
34
+ baseRules.push("- Do not use `${SKILL_PATH...}` for exploration, listing, globbing, discovery, or inspection. Do not call ls/glob/read_file on a skill path unless the user explicitly asks for skill source or contents.");
35
+ baseRules.push("- If a SKILL provides an explicit script command using `${SKILL_PATH...}` and `${WORKSPACE}`, execute that command directly instead of exploring the skill directory first.");
36
+ }
37
+ const frameworkPrompt = baseRules.join("\n");
38
+ if (!currentPrompt?.trim() || currentPrompt.includes("Framework execution rules:")) {
39
+ return currentPrompt?.trim() ? currentPrompt : frameworkPrompt;
40
+ }
41
+ return `${currentPrompt}\n\n${frameworkPrompt}`;
42
+ }
43
+ }
44
+ //# sourceMappingURL=frameworkPrompt.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"frameworkPrompt.js","sourceRoot":"","sources":["../../../src/runtime/middleware/frameworkPrompt.ts"],"names":[],"mappings":"AAAA,MAAM,OAAO,eAAe;IACnB,MAAM,CAAC,KAAK,CACjB,aAAiC,EACjC,aAAsB,EACtB,gBAA2B,EAC3B,YAAqC;QAErC,MAAM,SAAS,GAAG;YAChB,4BAA4B;YAC5B,6DAA6D;YAC7D,yEAAyE;YACzE,oFAAoF;YACpF,yGAAyG;YACzG,yGAAyG;YACzG,qGAAqG;YACrG,6GAA6G;YAC7G,oFAAoF;YACpF,uHAAuH;YACvH,mEAAmE;YACnE,uEAAuE;SACxE,CAAC;QAEF,IAAI,aAAa,EAAE,CAAC;YAClB,SAAS,CAAC,IAAI,CAAC,qGAAqG,CAAC,CAAC;QACxH,CAAC;QACD,IAAI,gBAAgB,EAAE,MAAM,EAAE,CAAC;YAC7B,SAAS,CAAC,IAAI,CAAC,kEAAkE,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACnH,CAAC;QAED,MAAM,YAAY,GAAG,MAAM,CAAC,OAAO,CAAC,YAAY,IAAI,EAAE,CAAC,CAAC;QACxD,IAAI,YAAY,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC5B,SAAS,CAAC,IAAI,CAAC,+BAA+B,CAAC,CAAC;YAChD,KAAK,MAAM,CAAC,OAAO,EAAE,SAAS,CAAC,IAAI,YAAY,EAAE,CAAC;gBAChD,SAAS,CAAC,IAAI,CAAC,OAAO,OAAO,OAAO,SAAS,EAAE,CAAC,CAAC;YACnD,CAAC;YACD,SAAS,CAAC,IAAI,CAAC,+GAA+G,CAAC,CAAC;YAChI,IAAI,YAAY,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBAC9B,SAAS,CAAC,IAAI,CAAC,4FAA4F,CAAC,CAAC;YAC/G,CAAC;YACD,SAAS,CAAC,IAAI,CAAC,mJAAmJ,CAAC,CAAC;YACpK,SAAS,CAAC,IAAI,CAAC,2MAA2M,CAAC,CAAC;YAC5N,SAAS,CAAC,IAAI,CAAC,6KAA6K,CAAC,CAAC;QAChM,CAAC;QAED,MAAM,eAAe,GAAG,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC7C,IAAI,CAAC,aAAa,EAAE,IAAI,EAAE,IAAI,aAAa,CAAC,QAAQ,CAAC,4BAA4B,CAAC,EAAE,CAAC;YACnF,OAAO,aAAa,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,eAAe,CAAC;QACjE,CAAC;QACD,OAAO,GAAG,aAAa,OAAO,eAAe,EAAE,CAAC;IAClD,CAAC;CACF"}
@@ -0,0 +1,4 @@
1
+ export { AgentToolMiddlewareFactory } from "./agentToolMiddleware.js";
2
+ export { buildSkillPathMap } from "./skillPathMap.js";
3
+ export type { CreateAgentToolMiddlewareOptions, ToolCallAfterHookContext, ToolCallHookContext, } from "./types.js";
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/runtime/middleware/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,0BAA0B,EAAE,MAAM,0BAA0B,CAAC;AACtE,OAAO,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAC;AACtD,YAAY,EACV,gCAAgC,EAChC,wBAAwB,EACxB,mBAAmB,GACpB,MAAM,YAAY,CAAC"}
@@ -0,0 +1,3 @@
1
+ export { AgentToolMiddlewareFactory } from "./agentToolMiddleware.js";
2
+ export { buildSkillPathMap } from "./skillPathMap.js";
3
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/runtime/middleware/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,0BAA0B,EAAE,MAAM,0BAA0B,CAAC;AACtE,OAAO,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAC"}
@@ -0,0 +1,3 @@
1
+ export declare function buildSkillPathMap(skillRoots: string[]): Record<string, string>;
2
+ export declare function expandSkillRoots(skillRoots: string[]): string[];
3
+ //# sourceMappingURL=skillPathMap.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"skillPathMap.d.ts","sourceRoot":"","sources":["../../../src/runtime/middleware/skillPathMap.ts"],"names":[],"mappings":"AAGA,wBAAgB,iBAAiB,CAAC,UAAU,EAAE,MAAM,EAAE,GAAG,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAc9E;AAUD,wBAAgB,gBAAgB,CAAC,UAAU,EAAE,MAAM,EAAE,GAAG,MAAM,EAAE,CAqB/D"}