@namzu/sdk 0.1.1 → 0.1.3

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 (783) hide show
  1. package/README.md +6 -0
  2. package/dist/agents/AbstractAgent.d.ts +5 -5
  3. package/dist/agents/AbstractAgent.d.ts.map +1 -1
  4. package/dist/agents/AbstractAgent.js +7 -7
  5. package/dist/agents/AbstractAgent.js.map +1 -1
  6. package/dist/agents/PipelineAgent.d.ts +1 -1
  7. package/dist/agents/PipelineAgent.d.ts.map +1 -1
  8. package/dist/agents/PipelineAgent.js +3 -1
  9. package/dist/agents/PipelineAgent.js.map +1 -1
  10. package/dist/agents/ReactiveAgent.d.ts +1 -1
  11. package/dist/agents/ReactiveAgent.d.ts.map +1 -1
  12. package/dist/agents/ReactiveAgent.js +4 -1
  13. package/dist/agents/ReactiveAgent.js.map +1 -1
  14. package/dist/agents/RouterAgent.d.ts +1 -1
  15. package/dist/agents/RouterAgent.d.ts.map +1 -1
  16. package/dist/agents/RouterAgent.js +5 -9
  17. package/dist/agents/RouterAgent.js.map +1 -1
  18. package/dist/agents/SupervisorAgent.d.ts +4 -4
  19. package/dist/agents/SupervisorAgent.d.ts.map +1 -1
  20. package/dist/agents/SupervisorAgent.js +16 -14
  21. package/dist/agents/SupervisorAgent.js.map +1 -1
  22. package/dist/agents/defineAgent.d.ts +1 -1
  23. package/dist/agents/defineAgent.d.ts.map +1 -1
  24. package/dist/agents/defineAgent.js +1 -6
  25. package/dist/agents/defineAgent.js.map +1 -1
  26. package/dist/bridge/a2a/agent-card.d.ts.map +1 -1
  27. package/dist/bridge/a2a/agent-card.js +1 -1
  28. package/dist/bridge/a2a/agent-card.js.map +1 -1
  29. package/dist/bridge/a2a/index.d.ts.map +1 -1
  30. package/dist/bridge/a2a/index.js.map +1 -1
  31. package/dist/bridge/a2a/mapper.d.ts +2 -2
  32. package/dist/bridge/a2a/mapper.d.ts.map +1 -1
  33. package/dist/bridge/a2a/mapper.js +28 -28
  34. package/dist/bridge/a2a/mapper.js.map +1 -1
  35. package/dist/bridge/a2a/message.d.ts +1 -1
  36. package/dist/bridge/a2a/message.d.ts.map +1 -1
  37. package/dist/bridge/a2a/message.js.map +1 -1
  38. package/dist/bridge/a2a/task.d.ts +2 -2
  39. package/dist/bridge/a2a/task.d.ts.map +1 -1
  40. package/dist/bridge/a2a/task.js +8 -18
  41. package/dist/bridge/a2a/task.js.map +1 -1
  42. package/dist/bridge/mcp/connector/adapter.d.ts +2 -2
  43. package/dist/bridge/mcp/connector/adapter.d.ts.map +1 -1
  44. package/dist/bridge/mcp/connector/adapter.js +1 -3
  45. package/dist/bridge/mcp/connector/adapter.js.map +1 -1
  46. package/dist/bridge/sse/index.d.ts +2 -2
  47. package/dist/bridge/sse/index.d.ts.map +1 -1
  48. package/dist/bridge/sse/index.js +1 -1
  49. package/dist/bridge/sse/index.js.map +1 -1
  50. package/dist/bridge/sse/mapper.d.ts +3 -3
  51. package/dist/bridge/sse/mapper.d.ts.map +1 -1
  52. package/dist/bridge/sse/mapper.js +26 -26
  53. package/dist/bridge/sse/mapper.js.map +1 -1
  54. package/dist/bridge/tools/connector/adapter.d.ts +2 -2
  55. package/dist/bridge/tools/connector/adapter.d.ts.map +1 -1
  56. package/dist/bridge/tools/connector/adapter.js +2 -6
  57. package/dist/bridge/tools/connector/adapter.js.map +1 -1
  58. package/dist/bridge/tools/connector/definitions.d.ts +1 -1
  59. package/dist/bridge/tools/connector/definitions.d.ts.map +1 -1
  60. package/dist/bridge/tools/connector/definitions.js +5 -16
  61. package/dist/bridge/tools/connector/definitions.js.map +1 -1
  62. package/dist/bridge/tools/connector/index.d.ts.map +1 -1
  63. package/dist/bridge/tools/connector/index.js.map +1 -1
  64. package/dist/bridge/tools/connector/router.d.ts +1 -1
  65. package/dist/bridge/tools/connector/router.d.ts.map +1 -1
  66. package/dist/bridge/tools/connector/router.js +2 -2
  67. package/dist/bridge/tools/connector/router.js.map +1 -1
  68. package/dist/config/runtime.d.ts +4 -4
  69. package/dist/config/runtime.js.map +1 -1
  70. package/dist/connector/BaseConnector.d.ts +1 -1
  71. package/dist/connector/BaseConnector.d.ts.map +1 -1
  72. package/dist/connector/BaseConnector.js +1 -3
  73. package/dist/connector/BaseConnector.js.map +1 -1
  74. package/dist/connector/builtins/http.d.ts +1 -1
  75. package/dist/connector/builtins/http.d.ts.map +1 -1
  76. package/dist/connector/builtins/http.js +6 -6
  77. package/dist/connector/builtins/http.js.map +1 -1
  78. package/dist/connector/builtins/webhook.d.ts +2 -2
  79. package/dist/connector/builtins/webhook.d.ts.map +1 -1
  80. package/dist/connector/builtins/webhook.js +4 -6
  81. package/dist/connector/builtins/webhook.js.map +1 -1
  82. package/dist/connector/execution/factory.d.ts +4 -4
  83. package/dist/connector/execution/factory.d.ts.map +1 -1
  84. package/dist/connector/execution/factory.js +1 -1
  85. package/dist/connector/execution/factory.js.map +1 -1
  86. package/dist/connector/execution/hybrid.d.ts +1 -1
  87. package/dist/connector/execution/hybrid.d.ts.map +1 -1
  88. package/dist/connector/execution/hybrid.js +4 -2
  89. package/dist/connector/execution/hybrid.js.map +1 -1
  90. package/dist/connector/execution/remote.d.ts +1 -1
  91. package/dist/connector/execution/remote.d.ts.map +1 -1
  92. package/dist/connector/execution/remote.js +1 -2
  93. package/dist/connector/execution/remote.js.map +1 -1
  94. package/dist/connector/index.d.ts.map +1 -1
  95. package/dist/connector/index.js.map +1 -1
  96. package/dist/connector/mcp/adapter.d.ts +1 -1
  97. package/dist/connector/mcp/adapter.d.ts.map +1 -1
  98. package/dist/connector/mcp/adapter.js +1 -1
  99. package/dist/connector/mcp/adapter.js.map +1 -1
  100. package/dist/connector/mcp/client.d.ts +1 -1
  101. package/dist/connector/mcp/client.d.ts.map +1 -1
  102. package/dist/connector/mcp/client.js +13 -12
  103. package/dist/connector/mcp/client.js.map +1 -1
  104. package/dist/connector/mcp/discovery.d.ts +1 -1
  105. package/dist/connector/mcp/discovery.d.ts.map +1 -1
  106. package/dist/connector/mcp/discovery.js +1 -1
  107. package/dist/connector/mcp/discovery.js.map +1 -1
  108. package/dist/connector/mcp/http-sse.d.ts +1 -1
  109. package/dist/connector/mcp/http-sse.d.ts.map +1 -1
  110. package/dist/connector/mcp/http-sse.js.map +1 -1
  111. package/dist/connector/mcp/index.d.ts.map +1 -1
  112. package/dist/connector/mcp/index.js.map +1 -1
  113. package/dist/connector/mcp/server.d.ts +1 -1
  114. package/dist/connector/mcp/server.d.ts.map +1 -1
  115. package/dist/connector/mcp/server.js +4 -4
  116. package/dist/connector/mcp/server.js.map +1 -1
  117. package/dist/connector/mcp/stdio.d.ts +1 -1
  118. package/dist/connector/mcp/stdio.d.ts.map +1 -1
  119. package/dist/connector/mcp/stdio.js +3 -3
  120. package/dist/connector/mcp/stdio.js.map +1 -1
  121. package/dist/constants/a2a/index.d.ts +6 -0
  122. package/dist/constants/a2a/index.d.ts.map +1 -0
  123. package/dist/constants/a2a/index.js +17 -0
  124. package/dist/constants/a2a/index.js.map +1 -0
  125. package/dist/constants/agent/index.d.ts +6 -0
  126. package/dist/constants/agent/index.d.ts.map +1 -0
  127. package/dist/constants/agent/index.js +13 -0
  128. package/dist/constants/agent/index.js.map +1 -0
  129. package/dist/constants/index.d.ts +9 -0
  130. package/dist/constants/index.d.ts.map +1 -0
  131. package/dist/constants/index.js +9 -0
  132. package/dist/constants/index.js.map +1 -0
  133. package/dist/constants/limits.d.ts +4 -0
  134. package/dist/constants/limits.d.ts.map +1 -0
  135. package/dist/constants/limits.js +14 -0
  136. package/dist/constants/limits.js.map +1 -0
  137. package/dist/constants/mcp/index.d.ts +2 -0
  138. package/dist/constants/mcp/index.d.ts.map +1 -0
  139. package/dist/constants/mcp/index.js +2 -0
  140. package/dist/constants/mcp/index.js.map +1 -0
  141. package/dist/constants/provider/index.d.ts +5 -0
  142. package/dist/constants/provider/index.d.ts.map +1 -0
  143. package/dist/constants/provider/index.js +20 -0
  144. package/dist/constants/provider/index.js.map +1 -0
  145. package/dist/constants/rag/index.d.ts +6 -0
  146. package/dist/constants/rag/index.d.ts.map +1 -0
  147. package/dist/constants/rag/index.js +24 -0
  148. package/dist/constants/rag/index.js.map +1 -0
  149. package/dist/constants/telemetry/index.d.ts +29 -0
  150. package/dist/constants/telemetry/index.d.ts.map +1 -0
  151. package/dist/constants/telemetry/index.js +29 -0
  152. package/dist/constants/telemetry/index.js.map +1 -0
  153. package/dist/constants/tools/index.d.ts +3 -0
  154. package/dist/constants/tools/index.d.ts.map +1 -0
  155. package/dist/constants/tools/index.js +3 -0
  156. package/dist/constants/tools/index.js.map +1 -0
  157. package/dist/contracts/a2a.d.ts +116 -116
  158. package/dist/contracts/a2a.d.ts.map +1 -1
  159. package/dist/contracts/a2a.js +44 -22
  160. package/dist/contracts/a2a.js.map +1 -1
  161. package/dist/contracts/api.d.ts +2 -2
  162. package/dist/contracts/api.d.ts.map +1 -1
  163. package/dist/contracts/index.d.ts +1 -1
  164. package/dist/contracts/index.d.ts.map +1 -1
  165. package/dist/contracts/index.js.map +1 -1
  166. package/dist/contracts/schemas.d.ts +2 -2
  167. package/dist/contracts/schemas.d.ts.map +1 -1
  168. package/dist/contracts/schemas.js +20 -10
  169. package/dist/contracts/schemas.js.map +1 -1
  170. package/dist/execution/base.d.ts +1 -1
  171. package/dist/execution/base.d.ts.map +1 -1
  172. package/dist/execution/base.js +1 -1
  173. package/dist/execution/base.js.map +1 -1
  174. package/dist/execution/local.d.ts +1 -1
  175. package/dist/execution/local.d.ts.map +1 -1
  176. package/dist/execution/local.js +2 -3
  177. package/dist/execution/local.js.map +1 -1
  178. package/dist/gateway/local.d.ts +3 -3
  179. package/dist/gateway/local.d.ts.map +1 -1
  180. package/dist/gateway/local.js +8 -4
  181. package/dist/gateway/local.js.map +1 -1
  182. package/dist/index.d.ts +92 -91
  183. package/dist/index.d.ts.map +1 -1
  184. package/dist/index.js +74 -73
  185. package/dist/index.js.map +1 -1
  186. package/dist/manager/agent/index.d.ts +1 -1
  187. package/dist/manager/agent/index.d.ts.map +1 -1
  188. package/dist/manager/agent/index.js +1 -1
  189. package/dist/manager/agent/index.js.map +1 -1
  190. package/dist/manager/agent/lifecycle.d.ts +6 -6
  191. package/dist/manager/agent/lifecycle.d.ts.map +1 -1
  192. package/dist/manager/agent/lifecycle.js +32 -34
  193. package/dist/manager/agent/lifecycle.js.map +1 -1
  194. package/dist/manager/connector/environment.d.ts +5 -5
  195. package/dist/manager/connector/environment.d.ts.map +1 -1
  196. package/dist/manager/connector/environment.js +2 -2
  197. package/dist/manager/connector/environment.js.map +1 -1
  198. package/dist/manager/connector/index.d.ts.map +1 -1
  199. package/dist/manager/connector/lifecycle.d.ts +3 -3
  200. package/dist/manager/connector/lifecycle.d.ts.map +1 -1
  201. package/dist/manager/connector/lifecycle.js +19 -4
  202. package/dist/manager/connector/lifecycle.js.map +1 -1
  203. package/dist/manager/connector/tenant.d.ts +3 -3
  204. package/dist/manager/connector/tenant.d.ts.map +1 -1
  205. package/dist/manager/connector/tenant.js +6 -5
  206. package/dist/manager/connector/tenant.js.map +1 -1
  207. package/dist/manager/index.d.ts.map +1 -1
  208. package/dist/manager/plan/lifecycle.d.ts +2 -2
  209. package/dist/manager/plan/lifecycle.d.ts.map +1 -1
  210. package/dist/manager/plan/lifecycle.js +3 -4
  211. package/dist/manager/plan/lifecycle.js.map +1 -1
  212. package/dist/manager/run/persistence.d.ts +3 -3
  213. package/dist/manager/run/persistence.d.ts.map +1 -1
  214. package/dist/manager/run/persistence.js +2 -2
  215. package/dist/manager/run/persistence.js.map +1 -1
  216. package/dist/persona/assembler.d.ts.map +1 -1
  217. package/dist/persona/assembler.js +1 -4
  218. package/dist/persona/assembler.js.map +1 -1
  219. package/dist/provider/bedrock/client.d.ts +2 -2
  220. package/dist/provider/bedrock/client.d.ts.map +1 -1
  221. package/dist/provider/bedrock/client.js +75 -79
  222. package/dist/provider/bedrock/client.js.map +1 -1
  223. package/dist/provider/factory.d.ts +1 -1
  224. package/dist/provider/factory.d.ts.map +1 -1
  225. package/dist/provider/factory.js +4 -21
  226. package/dist/provider/factory.js.map +1 -1
  227. package/dist/provider/openrouter/client.d.ts.map +1 -1
  228. package/dist/provider/openrouter/client.js +12 -6
  229. package/dist/provider/openrouter/client.js.map +1 -1
  230. package/dist/provider/telemetry/setup.d.ts +1 -1
  231. package/dist/provider/telemetry/setup.d.ts.map +1 -1
  232. package/dist/provider/telemetry/setup.js +9 -13
  233. package/dist/provider/telemetry/setup.js.map +1 -1
  234. package/dist/rag/chunking.d.ts +3 -2
  235. package/dist/rag/chunking.d.ts.map +1 -1
  236. package/dist/rag/chunking.js +6 -15
  237. package/dist/rag/chunking.js.map +1 -1
  238. package/dist/rag/context-assembler.d.ts +2 -1
  239. package/dist/rag/context-assembler.d.ts.map +1 -1
  240. package/dist/rag/context-assembler.js +2 -6
  241. package/dist/rag/context-assembler.js.map +1 -1
  242. package/dist/rag/embedding.d.ts.map +1 -1
  243. package/dist/rag/embedding.js +5 -4
  244. package/dist/rag/embedding.js.map +1 -1
  245. package/dist/rag/index.d.ts.map +1 -1
  246. package/dist/rag/ingestion.d.ts.map +1 -1
  247. package/dist/rag/ingestion.js +3 -3
  248. package/dist/rag/ingestion.js.map +1 -1
  249. package/dist/rag/knowledge-base.d.ts.map +1 -1
  250. package/dist/rag/knowledge-base.js +2 -2
  251. package/dist/rag/knowledge-base.js.map +1 -1
  252. package/dist/rag/rag-tool.d.ts.map +1 -1
  253. package/dist/rag/rag-tool.js +3 -1
  254. package/dist/rag/rag-tool.js.map +1 -1
  255. package/dist/rag/retriever.d.ts +2 -1
  256. package/dist/rag/retriever.d.ts.map +1 -1
  257. package/dist/rag/retriever.js +6 -12
  258. package/dist/rag/retriever.js.map +1 -1
  259. package/dist/rag/vector-store.d.ts +1 -1
  260. package/dist/rag/vector-store.d.ts.map +1 -1
  261. package/dist/rag/vector-store.js +7 -3
  262. package/dist/rag/vector-store.js.map +1 -1
  263. package/dist/registry/ManagedRegistry.d.ts +2 -2
  264. package/dist/registry/ManagedRegistry.d.ts.map +1 -1
  265. package/dist/registry/ManagedRegistry.js +21 -5
  266. package/dist/registry/ManagedRegistry.js.map +1 -1
  267. package/dist/registry/Registry.d.ts.map +1 -1
  268. package/dist/registry/Registry.js.map +1 -1
  269. package/dist/registry/agent/definitions.d.ts +3 -3
  270. package/dist/registry/agent/definitions.d.ts.map +1 -1
  271. package/dist/registry/agent/definitions.js +19 -6
  272. package/dist/registry/agent/definitions.js.map +1 -1
  273. package/dist/registry/agent/index.d.ts +1 -1
  274. package/dist/registry/agent/index.d.ts.map +1 -1
  275. package/dist/registry/agent/index.js +1 -1
  276. package/dist/registry/agent/index.js.map +1 -1
  277. package/dist/registry/connector/definitions.d.ts +3 -3
  278. package/dist/registry/connector/definitions.d.ts.map +1 -1
  279. package/dist/registry/connector/definitions.js +19 -6
  280. package/dist/registry/connector/definitions.js.map +1 -1
  281. package/dist/registry/connector/scoped.d.ts +1 -1
  282. package/dist/registry/connector/scoped.d.ts.map +1 -1
  283. package/dist/registry/connector/scoped.js.map +1 -1
  284. package/dist/registry/tool/execute.d.ts +2 -2
  285. package/dist/registry/tool/execute.d.ts.map +1 -1
  286. package/dist/registry/tool/execute.js +50 -50
  287. package/dist/registry/tool/execute.js.map +1 -1
  288. package/dist/run/LimitChecker.d.ts +1 -1
  289. package/dist/run/LimitChecker.d.ts.map +1 -1
  290. package/dist/run/LimitChecker.js.map +1 -1
  291. package/dist/run/reporter.d.ts +2 -2
  292. package/dist/run/reporter.d.ts.map +1 -1
  293. package/dist/run/reporter.js +40 -40
  294. package/dist/run/reporter.js.map +1 -1
  295. package/dist/runtime/decision/fallback.d.ts +1 -1
  296. package/dist/runtime/decision/fallback.d.ts.map +1 -1
  297. package/dist/runtime/decision/fallback.js +2 -2
  298. package/dist/runtime/decision/fallback.js.map +1 -1
  299. package/dist/runtime/decision/parser.d.ts +1 -1
  300. package/dist/runtime/decision/parser.d.ts.map +1 -1
  301. package/dist/runtime/decision/parser.js +2 -2
  302. package/dist/runtime/decision/parser.js.map +1 -1
  303. package/dist/runtime/query/checkpoint.d.ts +1 -1
  304. package/dist/runtime/query/checkpoint.d.ts.map +1 -1
  305. package/dist/runtime/query/checkpoint.js +2 -4
  306. package/dist/runtime/query/checkpoint.js.map +1 -1
  307. package/dist/runtime/query/context-cache.d.ts +1 -1
  308. package/dist/runtime/query/context-cache.d.ts.map +1 -1
  309. package/dist/runtime/query/context-cache.js +3 -6
  310. package/dist/runtime/query/context-cache.js.map +1 -1
  311. package/dist/runtime/query/context.d.ts +8 -8
  312. package/dist/runtime/query/context.d.ts.map +1 -1
  313. package/dist/runtime/query/context.js +4 -4
  314. package/dist/runtime/query/context.js.map +1 -1
  315. package/dist/runtime/query/events.d.ts +4 -4
  316. package/dist/runtime/query/events.d.ts.map +1 -1
  317. package/dist/runtime/query/events.js +4 -2
  318. package/dist/runtime/query/events.js.map +1 -1
  319. package/dist/runtime/query/executor.d.ts +8 -8
  320. package/dist/runtime/query/executor.d.ts.map +1 -1
  321. package/dist/runtime/query/executor.js +6 -6
  322. package/dist/runtime/query/executor.js.map +1 -1
  323. package/dist/runtime/query/guard.d.ts +1 -1
  324. package/dist/runtime/query/guard.d.ts.map +1 -1
  325. package/dist/runtime/query/guard.js +1 -1
  326. package/dist/runtime/query/guard.js.map +1 -1
  327. package/dist/runtime/query/index.d.ts +9 -9
  328. package/dist/runtime/query/index.d.ts.map +1 -1
  329. package/dist/runtime/query/index.js +15 -9
  330. package/dist/runtime/query/index.js.map +1 -1
  331. package/dist/runtime/query/iteration/index.d.ts +15 -15
  332. package/dist/runtime/query/iteration/index.d.ts.map +1 -1
  333. package/dist/runtime/query/iteration/index.js +47 -49
  334. package/dist/runtime/query/iteration/index.js.map +1 -1
  335. package/dist/runtime/query/iteration/phases/checkpoint.d.ts +2 -2
  336. package/dist/runtime/query/iteration/phases/checkpoint.d.ts.map +1 -1
  337. package/dist/runtime/query/iteration/phases/checkpoint.js +5 -5
  338. package/dist/runtime/query/iteration/phases/checkpoint.js.map +1 -1
  339. package/dist/runtime/query/iteration/phases/context.d.ts +16 -16
  340. package/dist/runtime/query/iteration/phases/context.d.ts.map +1 -1
  341. package/dist/runtime/query/iteration/phases/context.js +19 -19
  342. package/dist/runtime/query/iteration/phases/context.js.map +1 -1
  343. package/dist/runtime/query/iteration/phases/index.d.ts +6 -6
  344. package/dist/runtime/query/iteration/phases/index.d.ts.map +1 -1
  345. package/dist/runtime/query/iteration/phases/index.js +4 -4
  346. package/dist/runtime/query/iteration/phases/index.js.map +1 -1
  347. package/dist/runtime/query/iteration/phases/plan.d.ts +2 -2
  348. package/dist/runtime/query/iteration/phases/plan.d.ts.map +1 -1
  349. package/dist/runtime/query/iteration/phases/plan.js +6 -6
  350. package/dist/runtime/query/iteration/phases/plan.js.map +1 -1
  351. package/dist/runtime/query/iteration/phases/tool-review.d.ts +4 -4
  352. package/dist/runtime/query/iteration/phases/tool-review.d.ts.map +1 -1
  353. package/dist/runtime/query/iteration/phases/tool-review.js +40 -41
  354. package/dist/runtime/query/iteration/phases/tool-review.js.map +1 -1
  355. package/dist/runtime/query/prompt.d.ts +2 -2
  356. package/dist/runtime/query/prompt.d.ts.map +1 -1
  357. package/dist/runtime/query/prompt.js +2 -2
  358. package/dist/runtime/query/prompt.js.map +1 -1
  359. package/dist/runtime/query/result.d.ts +3 -3
  360. package/dist/runtime/query/result.d.ts.map +1 -1
  361. package/dist/runtime/query/result.js +1 -1
  362. package/dist/runtime/query/result.js.map +1 -1
  363. package/dist/runtime/query/tooling.d.ts +3 -3
  364. package/dist/runtime/query/tooling.d.ts.map +1 -1
  365. package/dist/runtime/query/tooling.js.map +1 -1
  366. package/dist/skills/loader.d.ts.map +1 -1
  367. package/dist/skills/loader.js +11 -12
  368. package/dist/skills/loader.js.map +1 -1
  369. package/dist/skills/registry.d.ts.map +1 -1
  370. package/dist/skills/registry.js +2 -4
  371. package/dist/skills/registry.js.map +1 -1
  372. package/dist/store/InMemoryStore.d.ts +1 -1
  373. package/dist/store/InMemoryStore.d.ts.map +1 -1
  374. package/dist/store/InMemoryStore.js.map +1 -1
  375. package/dist/store/activity/memory.d.ts +1 -1
  376. package/dist/store/activity/memory.d.ts.map +1 -1
  377. package/dist/store/activity/memory.js +1 -2
  378. package/dist/store/activity/memory.js.map +1 -1
  379. package/dist/store/conversation/memory.d.ts +2 -2
  380. package/dist/store/conversation/memory.d.ts.map +1 -1
  381. package/dist/store/conversation/memory.js +4 -6
  382. package/dist/store/conversation/memory.js.map +1 -1
  383. package/dist/store/run/disk.d.ts +1 -1
  384. package/dist/store/run/disk.d.ts.map +1 -1
  385. package/dist/store/run/disk.js +7 -6
  386. package/dist/store/run/disk.js.map +1 -1
  387. package/dist/store/task/disk.d.ts +2 -2
  388. package/dist/store/task/disk.d.ts.map +1 -1
  389. package/dist/store/task/disk.js +8 -6
  390. package/dist/store/task/disk.js.map +1 -1
  391. package/dist/store/task/memory.d.ts +2 -2
  392. package/dist/store/task/memory.d.ts.map +1 -1
  393. package/dist/store/task/memory.js +4 -4
  394. package/dist/store/task/memory.js.map +1 -1
  395. package/dist/telemetry/attributes.d.ts +1 -28
  396. package/dist/telemetry/attributes.d.ts.map +1 -1
  397. package/dist/telemetry/attributes.js +1 -28
  398. package/dist/telemetry/attributes.js.map +1 -1
  399. package/dist/telemetry/index.d.ts.map +1 -1
  400. package/dist/telemetry/index.js.map +1 -1
  401. package/dist/telemetry/metrics.d.ts.map +1 -1
  402. package/dist/telemetry/metrics.js.map +1 -1
  403. package/dist/tools/builtins/bash.d.ts +2 -2
  404. package/dist/tools/builtins/bash.d.ts.map +1 -1
  405. package/dist/tools/builtins/bash.js +7 -13
  406. package/dist/tools/builtins/bash.js.map +1 -1
  407. package/dist/tools/builtins/glob.d.ts.map +1 -1
  408. package/dist/tools/builtins/glob.js +3 -3
  409. package/dist/tools/builtins/glob.js.map +1 -1
  410. package/dist/tools/builtins/index.d.ts +6 -6
  411. package/dist/tools/builtins/index.d.ts.map +1 -1
  412. package/dist/tools/builtins/index.js +10 -10
  413. package/dist/tools/builtins/index.js.map +1 -1
  414. package/dist/tools/builtins/read-file.d.ts +1 -1
  415. package/dist/tools/builtins/read-file.d.ts.map +1 -1
  416. package/dist/tools/builtins/read-file.js +6 -11
  417. package/dist/tools/builtins/read-file.js.map +1 -1
  418. package/dist/tools/builtins/search-tools.d.ts.map +1 -1
  419. package/dist/tools/builtins/search-tools.js +10 -12
  420. package/dist/tools/builtins/search-tools.js.map +1 -1
  421. package/dist/tools/builtins/write-file.js +2 -2
  422. package/dist/tools/builtins/write-file.js.map +1 -1
  423. package/dist/tools/coordinator/index.d.ts +1 -1
  424. package/dist/tools/coordinator/index.d.ts.map +1 -1
  425. package/dist/tools/coordinator/index.js +36 -13
  426. package/dist/tools/coordinator/index.js.map +1 -1
  427. package/dist/tools/defineTool.d.ts +1 -1
  428. package/dist/tools/defineTool.d.ts.map +1 -1
  429. package/dist/tools/defineTool.js.map +1 -1
  430. package/dist/tools/task/create.d.ts +1 -1
  431. package/dist/tools/task/create.d.ts.map +1 -1
  432. package/dist/tools/task/create.js +12 -3
  433. package/dist/tools/task/create.js.map +1 -1
  434. package/dist/tools/task/index.d.ts +1 -1
  435. package/dist/tools/task/index.d.ts.map +1 -1
  436. package/dist/tools/task/index.js +1 -1
  437. package/dist/tools/task/index.js.map +1 -1
  438. package/dist/tools/task/list.d.ts +1 -1
  439. package/dist/tools/task/list.d.ts.map +1 -1
  440. package/dist/tools/task/list.js +1 -3
  441. package/dist/tools/task/list.js.map +1 -1
  442. package/dist/tools/task/update.d.ts.map +1 -1
  443. package/dist/tools/task/update.js +13 -4
  444. package/dist/tools/task/update.js.map +1 -1
  445. package/dist/types/a2a/index.d.ts.map +1 -1
  446. package/dist/types/a2a/index.js.map +1 -1
  447. package/dist/types/activity/index.d.ts.map +1 -1
  448. package/dist/types/activity/index.js +1 -1
  449. package/dist/types/activity/index.js.map +1 -1
  450. package/dist/types/agent/base.d.ts +2 -2
  451. package/dist/types/agent/base.d.ts.map +1 -1
  452. package/dist/types/agent/core.d.ts +1 -1
  453. package/dist/types/agent/core.d.ts.map +1 -1
  454. package/dist/types/agent/factory.d.ts +1 -1
  455. package/dist/types/agent/factory.d.ts.map +1 -1
  456. package/dist/types/agent/gateway.d.ts +1 -1
  457. package/dist/types/agent/gateway.d.ts.map +1 -1
  458. package/dist/types/agent/lifecycle-event.d.ts +9 -9
  459. package/dist/types/agent/lifecycle-event.d.ts.map +1 -1
  460. package/dist/types/agent/pipeline.d.ts.map +1 -1
  461. package/dist/types/agent/reactive.d.ts +2 -2
  462. package/dist/types/agent/reactive.d.ts.map +1 -1
  463. package/dist/types/agent/router.d.ts.map +1 -1
  464. package/dist/types/agent/supervisor.d.ts +1 -1
  465. package/dist/types/agent/supervisor.d.ts.map +1 -1
  466. package/dist/types/agent/task.d.ts +10 -10
  467. package/dist/types/agent/task.d.ts.map +1 -1
  468. package/dist/types/agent/task.js +3 -10
  469. package/dist/types/agent/task.js.map +1 -1
  470. package/dist/types/common/index.d.ts +1 -1
  471. package/dist/types/common/index.d.ts.map +1 -1
  472. package/dist/types/common/index.js +1 -7
  473. package/dist/types/common/index.js.map +1 -1
  474. package/dist/types/connector/core.d.ts.map +1 -1
  475. package/dist/types/connector/core.js.map +1 -1
  476. package/dist/types/connector/definition.d.ts +1 -1
  477. package/dist/types/connector/definition.d.ts.map +1 -1
  478. package/dist/types/connector/execution-context.d.ts +3 -3
  479. package/dist/types/connector/execution-context.d.ts.map +1 -1
  480. package/dist/types/connector/http.d.ts.map +1 -1
  481. package/dist/types/connector/mcp.d.ts +2 -2
  482. package/dist/types/connector/mcp.d.ts.map +1 -1
  483. package/dist/types/connector/scope.d.ts.map +1 -1
  484. package/dist/types/connector/scope.js.map +1 -1
  485. package/dist/types/connector/tenant.d.ts +2 -2
  486. package/dist/types/connector/tenant.d.ts.map +1 -1
  487. package/dist/types/connector/webhook.d.ts.map +1 -1
  488. package/dist/types/conversation/index.d.ts +1 -1
  489. package/dist/types/conversation/index.d.ts.map +1 -1
  490. package/dist/types/decision/index.d.ts.map +1 -1
  491. package/dist/types/decision/index.js +4 -2
  492. package/dist/types/decision/index.js.map +1 -1
  493. package/dist/types/execution/index.d.ts.map +1 -1
  494. package/dist/types/hitl/index.d.ts +3 -3
  495. package/dist/types/hitl/index.d.ts.map +1 -1
  496. package/dist/types/hitl/index.js.map +1 -1
  497. package/dist/types/message/index.d.ts.map +1 -1
  498. package/dist/types/message/index.js.map +1 -1
  499. package/dist/types/persona/index.d.ts.map +1 -1
  500. package/dist/types/plan/index.d.ts.map +1 -1
  501. package/dist/types/plan/index.js.map +1 -1
  502. package/dist/types/provider/chat.d.ts +1 -1
  503. package/dist/types/provider/chat.d.ts.map +1 -1
  504. package/dist/types/provider/config.d.ts.map +1 -1
  505. package/dist/types/provider/index.d.ts +1 -1
  506. package/dist/types/provider/index.d.ts.map +1 -1
  507. package/dist/types/provider/interface.d.ts +1 -1
  508. package/dist/types/provider/interface.d.ts.map +1 -1
  509. package/dist/types/provider/model.d.ts.map +1 -1
  510. package/dist/types/provider/stream.d.ts.map +1 -1
  511. package/dist/types/rag/chunking.d.ts.map +1 -1
  512. package/dist/types/rag/context.d.ts.map +1 -1
  513. package/dist/types/rag/embedding.d.ts.map +1 -1
  514. package/dist/types/rag/ingestion.d.ts.map +1 -1
  515. package/dist/types/rag/knowledge-base.d.ts +2 -2
  516. package/dist/types/rag/knowledge-base.d.ts.map +1 -1
  517. package/dist/types/rag/retrieval.d.ts +1 -1
  518. package/dist/types/rag/retrieval.d.ts.map +1 -1
  519. package/dist/types/rag/scope.d.ts.map +1 -1
  520. package/dist/types/rag/storage.d.ts +1 -1
  521. package/dist/types/rag/storage.d.ts.map +1 -1
  522. package/dist/types/rag/vector.d.ts.map +1 -1
  523. package/dist/types/run/config.d.ts +2 -2
  524. package/dist/types/run/config.d.ts.map +1 -1
  525. package/dist/types/run/events.d.ts +36 -36
  526. package/dist/types/run/events.d.ts.map +1 -1
  527. package/dist/types/run/metadata.d.ts +2 -2
  528. package/dist/types/run/metadata.d.ts.map +1 -1
  529. package/dist/types/run/state.d.ts +2 -2
  530. package/dist/types/run/state.d.ts.map +1 -1
  531. package/dist/types/skills/index.d.ts.map +1 -1
  532. package/dist/types/task/index.d.ts +1 -1
  533. package/dist/types/task/index.d.ts.map +1 -1
  534. package/dist/types/task/index.js.map +1 -1
  535. package/dist/types/telemetry/index.d.ts.map +1 -1
  536. package/dist/types/tool/index.d.ts +9 -9
  537. package/dist/types/tool/index.d.ts.map +1 -1
  538. package/dist/utils/abort.d.ts.map +1 -1
  539. package/dist/utils/abort.js +3 -3
  540. package/dist/utils/abort.js.map +1 -1
  541. package/dist/utils/conversation.d.ts +1 -1
  542. package/dist/utils/conversation.d.ts.map +1 -1
  543. package/dist/utils/conversation.js +2 -0
  544. package/dist/utils/conversation.js.map +1 -1
  545. package/dist/utils/cost.d.ts +3 -2
  546. package/dist/utils/cost.d.ts.map +1 -1
  547. package/dist/utils/cost.js +2 -6
  548. package/dist/utils/cost.js.map +1 -1
  549. package/dist/utils/error.js.map +1 -1
  550. package/dist/utils/hash.d.ts.map +1 -1
  551. package/dist/utils/hash.js.map +1 -1
  552. package/dist/utils/id.d.ts +1 -1
  553. package/dist/utils/id.d.ts.map +1 -1
  554. package/dist/utils/id.js +14 -6
  555. package/dist/utils/id.js.map +1 -1
  556. package/dist/utils/logger.d.ts.map +1 -1
  557. package/dist/utils/logger.js +6 -3
  558. package/dist/utils/logger.js.map +1 -1
  559. package/dist/utils/memoize.d.ts.map +1 -1
  560. package/dist/utils/memoize.js.map +1 -1
  561. package/dist/vault/InMemoryCredentialVault.d.ts +2 -2
  562. package/dist/vault/InMemoryCredentialVault.d.ts.map +1 -1
  563. package/dist/vault/InMemoryCredentialVault.js.map +1 -1
  564. package/package.json +21 -6
  565. package/src/agents/AbstractAgent.ts +31 -44
  566. package/src/agents/PipelineAgent.ts +152 -157
  567. package/src/agents/ReactiveAgent.ts +89 -85
  568. package/src/agents/RouterAgent.ts +216 -228
  569. package/src/agents/SupervisorAgent.ts +43 -48
  570. package/src/agents/defineAgent.ts +53 -63
  571. package/src/bridge/a2a/agent-card.ts +57 -62
  572. package/src/bridge/a2a/index.ts +9 -9
  573. package/src/bridge/a2a/mapper.ts +53 -61
  574. package/src/bridge/a2a/message.ts +66 -71
  575. package/src/bridge/a2a/task.ts +77 -97
  576. package/src/bridge/mcp/connector/adapter.ts +116 -117
  577. package/src/bridge/sse/index.ts +2 -2
  578. package/src/bridge/sse/mapper.ts +52 -60
  579. package/src/bridge/tools/connector/adapter.ts +111 -116
  580. package/src/bridge/tools/connector/definitions.ts +105 -125
  581. package/src/bridge/tools/connector/index.ts +7 -7
  582. package/src/bridge/tools/connector/router.ts +51 -54
  583. package/src/config/runtime.ts +6 -6
  584. package/src/connector/BaseConnector.ts +65 -69
  585. package/src/connector/builtins/http.ts +175 -177
  586. package/src/connector/builtins/webhook.ts +134 -141
  587. package/src/connector/execution/factory.ts +43 -43
  588. package/src/connector/execution/hybrid.ts +193 -192
  589. package/src/connector/execution/remote.ts +121 -123
  590. package/src/connector/index.ts +13 -13
  591. package/src/connector/mcp/adapter.ts +100 -100
  592. package/src/connector/mcp/client.ts +229 -217
  593. package/src/connector/mcp/discovery.ts +53 -53
  594. package/src/connector/mcp/http-sse.ts +133 -132
  595. package/src/connector/mcp/index.ts +6 -6
  596. package/src/connector/mcp/server.ts +193 -191
  597. package/src/connector/mcp/stdio.ts +99 -97
  598. package/src/constants/a2a/index.ts +21 -0
  599. package/src/constants/agent/index.ts +17 -0
  600. package/src/constants/index.ts +8 -0
  601. package/src/constants/limits.ts +16 -0
  602. package/src/constants/mcp/index.ts +1 -0
  603. package/src/constants/provider/index.ts +23 -0
  604. package/src/constants/rag/index.ts +34 -0
  605. package/src/constants/telemetry/index.ts +34 -0
  606. package/src/constants/tools/index.ts +3 -0
  607. package/src/contracts/a2a.ts +111 -89
  608. package/src/contracts/api.ts +147 -147
  609. package/src/contracts/index.ts +34 -34
  610. package/src/contracts/schemas.ts +57 -47
  611. package/src/execution/base.ts +59 -62
  612. package/src/execution/local.ts +147 -148
  613. package/src/gateway/local.ts +89 -89
  614. package/src/index.ts +107 -100
  615. package/src/manager/agent/index.ts +1 -1
  616. package/src/manager/agent/lifecycle.ts +159 -184
  617. package/src/manager/connector/environment.ts +242 -234
  618. package/src/manager/connector/index.ts +2 -2
  619. package/src/manager/connector/lifecycle.ts +243 -230
  620. package/src/manager/connector/tenant.ts +279 -283
  621. package/src/manager/index.ts +2 -2
  622. package/src/manager/plan/lifecycle.ts +226 -223
  623. package/src/manager/run/persistence.ts +166 -165
  624. package/src/persona/assembler.ts +52 -64
  625. package/src/provider/bedrock/client.ts +203 -234
  626. package/src/provider/factory.ts +139 -158
  627. package/src/provider/openrouter/client.ts +368 -374
  628. package/src/provider/telemetry/setup.ts +100 -110
  629. package/src/rag/chunking.ts +131 -141
  630. package/src/rag/context-assembler.ts +39 -43
  631. package/src/rag/embedding.ts +57 -56
  632. package/src/rag/index.ts +25 -25
  633. package/src/rag/ingestion.ts +60 -60
  634. package/src/rag/knowledge-base.ts +54 -54
  635. package/src/rag/rag-tool.ts +54 -51
  636. package/src/rag/retriever.ts +170 -177
  637. package/src/rag/vector-store.ts +66 -63
  638. package/src/registry/ManagedRegistry.ts +41 -30
  639. package/src/registry/Registry.ts +25 -25
  640. package/src/registry/agent/definitions.ts +42 -34
  641. package/src/registry/agent/index.ts +1 -1
  642. package/src/registry/connector/definitions.ts +36 -26
  643. package/src/registry/connector/scoped.ts +120 -120
  644. package/src/registry/tool/execute.ts +130 -151
  645. package/src/run/LimitChecker.ts +61 -61
  646. package/src/run/reporter.ts +90 -96
  647. package/src/runtime/decision/fallback.ts +78 -81
  648. package/src/runtime/decision/parser.ts +150 -146
  649. package/src/runtime/query/checkpoint.ts +70 -66
  650. package/src/runtime/query/context-cache.ts +58 -62
  651. package/src/runtime/query/context.ts +82 -82
  652. package/src/runtime/query/events.ts +129 -127
  653. package/src/runtime/query/executor.ts +59 -67
  654. package/src/runtime/query/guard.ts +52 -55
  655. package/src/runtime/query/index.ts +290 -292
  656. package/src/runtime/query/iteration/index.ts +284 -310
  657. package/src/runtime/query/iteration/phases/checkpoint.ts +12 -20
  658. package/src/runtime/query/iteration/phases/context.ts +64 -73
  659. package/src/runtime/query/iteration/phases/index.ts +6 -6
  660. package/src/runtime/query/iteration/phases/plan.ts +14 -21
  661. package/src/runtime/query/iteration/phases/tool-review.ts +82 -91
  662. package/src/runtime/query/prompt.ts +49 -50
  663. package/src/runtime/query/result.ts +72 -72
  664. package/src/runtime/query/tooling.ts +29 -29
  665. package/src/skills/loader.ts +127 -123
  666. package/src/skills/registry.ts +91 -85
  667. package/src/store/InMemoryStore.ts +48 -51
  668. package/src/store/activity/memory.ts +217 -209
  669. package/src/store/conversation/memory.ts +88 -90
  670. package/src/store/run/disk.ts +204 -205
  671. package/src/store/task/disk.ts +311 -307
  672. package/src/store/task/memory.ts +173 -171
  673. package/src/telemetry/attributes.ts +5 -38
  674. package/src/telemetry/index.ts +5 -5
  675. package/src/telemetry/metrics.ts +53 -54
  676. package/src/tools/builtins/bash.ts +44 -55
  677. package/src/tools/builtins/glob.ts +75 -79
  678. package/src/tools/builtins/index.ts +12 -12
  679. package/src/tools/builtins/read-file.ts +37 -42
  680. package/src/tools/builtins/search-tools.ts +17 -19
  681. package/src/tools/builtins/write-file.ts +23 -23
  682. package/src/tools/coordinator/index.ts +227 -189
  683. package/src/tools/defineTool.ts +42 -36
  684. package/src/tools/task/create.ts +45 -38
  685. package/src/tools/task/index.ts +8 -11
  686. package/src/tools/task/list.ts +45 -48
  687. package/src/tools/task/update.ts +78 -60
  688. package/src/types/a2a/index.ts +143 -143
  689. package/src/types/activity/index.ts +40 -32
  690. package/src/types/agent/base.ts +41 -41
  691. package/src/types/agent/core.ts +13 -17
  692. package/src/types/agent/factory.ts +27 -27
  693. package/src/types/agent/gateway.ts +18 -18
  694. package/src/types/agent/lifecycle-event.ts +14 -16
  695. package/src/types/agent/pipeline.ts +23 -23
  696. package/src/types/agent/reactive.ts +9 -9
  697. package/src/types/agent/router.ts +17 -17
  698. package/src/types/agent/supervisor.ts +14 -14
  699. package/src/types/agent/task.ts +54 -63
  700. package/src/types/common/index.ts +24 -39
  701. package/src/types/connector/core.ts +22 -22
  702. package/src/types/connector/definition.ts +59 -45
  703. package/src/types/connector/execution-context.ts +37 -30
  704. package/src/types/connector/http.ts +12 -12
  705. package/src/types/connector/mcp.ts +123 -115
  706. package/src/types/connector/scope.ts +19 -19
  707. package/src/types/connector/tenant.ts +28 -23
  708. package/src/types/connector/webhook.ts +10 -10
  709. package/src/types/conversation/index.ts +3 -3
  710. package/src/types/decision/index.ts +18 -16
  711. package/src/types/execution/index.ts +21 -21
  712. package/src/types/hitl/index.ts +80 -69
  713. package/src/types/message/index.ts +26 -29
  714. package/src/types/persona/index.ts +31 -31
  715. package/src/types/plan/index.ts +38 -38
  716. package/src/types/provider/chat.ts +47 -44
  717. package/src/types/provider/config.ts +26 -23
  718. package/src/types/provider/index.ts +16 -10
  719. package/src/types/provider/interface.ts +7 -7
  720. package/src/types/provider/model.ts +8 -8
  721. package/src/types/provider/stream.ts +16 -16
  722. package/src/types/rag/chunking.ts +7 -7
  723. package/src/types/rag/context.ts +14 -14
  724. package/src/types/rag/embedding.ts +10 -10
  725. package/src/types/rag/ingestion.ts +11 -11
  726. package/src/types/rag/knowledge-base.ts +16 -16
  727. package/src/types/rag/retrieval.ts +19 -19
  728. package/src/types/rag/scope.ts +8 -8
  729. package/src/types/rag/storage.ts +18 -18
  730. package/src/types/rag/vector.ts +13 -13
  731. package/src/types/run/config.ts +30 -30
  732. package/src/types/run/events.ts +113 -115
  733. package/src/types/run/metadata.ts +29 -29
  734. package/src/types/run/state.ts +20 -20
  735. package/src/types/skills/index.ts +13 -13
  736. package/src/types/task/index.ts +55 -59
  737. package/src/types/telemetry/index.ts +6 -6
  738. package/src/types/tool/index.ts +43 -43
  739. package/src/utils/abort.ts +13 -15
  740. package/src/utils/conversation.ts +14 -13
  741. package/src/utils/cost.ts +31 -35
  742. package/src/utils/error.ts +1 -1
  743. package/src/utils/hash.ts +8 -8
  744. package/src/utils/id.ts +70 -41
  745. package/src/utils/logger.ts +41 -50
  746. package/src/utils/memoize.ts +14 -12
  747. package/src/vault/InMemoryCredentialVault.ts +50 -54
  748. package/dist/manager/session/lifecycle.d.ts +0 -3
  749. package/dist/manager/session/lifecycle.d.ts.map +0 -1
  750. package/dist/manager/session/lifecycle.js +0 -3
  751. package/dist/manager/session/lifecycle.js.map +0 -1
  752. package/dist/session/LimitChecker.d.ts +0 -3
  753. package/dist/session/LimitChecker.d.ts.map +0 -1
  754. package/dist/session/LimitChecker.js +0 -3
  755. package/dist/session/LimitChecker.js.map +0 -1
  756. package/dist/session/index.d.ts +0 -3
  757. package/dist/session/index.d.ts.map +0 -1
  758. package/dist/session/index.js +0 -3
  759. package/dist/session/index.js.map +0 -1
  760. package/dist/session/reporter.d.ts +0 -3
  761. package/dist/session/reporter.d.ts.map +0 -1
  762. package/dist/session/reporter.js +0 -3
  763. package/dist/session/reporter.js.map +0 -1
  764. package/dist/store/session/disk.d.ts +0 -3
  765. package/dist/store/session/disk.d.ts.map +0 -1
  766. package/dist/store/session/disk.js +0 -3
  767. package/dist/store/session/disk.js.map +0 -1
  768. package/dist/types/session/config.d.ts +0 -2
  769. package/dist/types/session/config.d.ts.map +0 -1
  770. package/dist/types/session/config.js +0 -2
  771. package/dist/types/session/config.js.map +0 -1
  772. package/dist/types/session/events.d.ts +0 -2
  773. package/dist/types/session/events.d.ts.map +0 -1
  774. package/dist/types/session/events.js +0 -2
  775. package/dist/types/session/events.js.map +0 -1
  776. package/dist/types/session/index.d.ts +0 -4
  777. package/dist/types/session/index.d.ts.map +0 -1
  778. package/dist/types/session/index.js +0 -4
  779. package/dist/types/session/index.js.map +0 -1
  780. package/dist/types/session/state.d.ts +0 -2
  781. package/dist/types/session/state.d.ts.map +0 -1
  782. package/dist/types/session/state.js +0 -2
  783. package/dist/types/session/state.js.map +0 -1
@@ -1,52 +1,44 @@
1
- import { SpanStatusCode } from "@opentelemetry/api";
2
- import type { PlanManager } from "../../../manager/plan/lifecycle.js";
3
- import type { RunPersistence } from "../../../manager/run/persistence.js";
4
- import { getTracer } from "../../../provider/telemetry/setup.js";
5
- import type { ToolRegistry } from "../../../registry/tool/execute.js";
6
- import type { ActivityStore } from "../../../store/activity/memory.js";
7
- import {
8
- GENAI,
9
- NAMZU,
10
- agentIterationSpanName,
11
- } from "../../../telemetry/attributes.js";
12
- import type { ResumeHandler } from "../../../types/hitl/index.js";
13
- import {
14
- createAssistantMessage,
15
- createUserMessage,
16
- } from "../../../types/message/index.js";
17
- import type { LLMProvider } from "../../../types/provider/index.js";
18
- import type {
19
- AgentRunConfig,
20
- RunEvent,
21
- StopReason,
22
- } from "../../../types/run/index.js";
23
- import { toErrorMessage } from "../../../utils/error.js";
24
- import type { Logger } from "../../../utils/logger.js";
25
- import type { CheckpointManager } from "../checkpoint.js";
26
- import type { EmitEvent } from "../events.js";
27
- import type { ToolExecutor } from "../executor.js";
28
- import type { GuardCoordinator } from "../guard.js";
29
- import { runIterationCheckpoint } from "./phases/checkpoint.js";
30
- import type { IterationContext } from "./phases/index.js";
31
- import { runPlanGate } from "./phases/plan.js";
32
- import { runToolReview } from "./phases/tool-review.js";
33
-
34
- export type { IterationContext } from "./phases/index.js";
35
- export type { PhaseSignal } from "./phases/index.js";
36
- export type { ToolReviewOutcome } from "./phases/index.js";
1
+ import { SpanStatusCode } from '@opentelemetry/api'
2
+ import type { PlanManager } from '../../../manager/plan/lifecycle.js'
3
+ import type { RunPersistence } from '../../../manager/run/persistence.js'
4
+ import { getTracer } from '../../../provider/telemetry/setup.js'
5
+ import type { ToolRegistry } from '../../../registry/tool/execute.js'
6
+ import type { ActivityStore } from '../../../store/activity/memory.js'
7
+ import { GENAI, NAMZU, agentIterationSpanName } from '../../../telemetry/attributes.js'
8
+ import type { ResumeHandler } from '../../../types/hitl/index.js'
9
+ import { createAssistantMessage, createUserMessage } from '../../../types/message/index.js'
10
+ import type { LLMProvider } from '../../../types/provider/index.js'
11
+ import type { AgentRunConfig, RunEvent, StopReason } from '../../../types/run/index.js'
12
+ import { toErrorMessage } from '../../../utils/error.js'
13
+ import type { Logger } from '../../../utils/logger.js'
14
+ import type { CheckpointManager } from '../checkpoint.js'
15
+ import type { EmitEvent } from '../events.js'
16
+ import type { ToolExecutor } from '../executor.js'
17
+ import type { GuardCoordinator } from '../guard.js'
18
+ import { runIterationCheckpoint } from './phases/checkpoint.js'
19
+ import type { IterationContext } from './phases/index.js'
20
+ import { runPlanGate } from './phases/plan.js'
21
+ import { runToolReview } from './phases/tool-review.js'
22
+
23
+ export type { IterationContext } from './phases/index.js'
24
+ export type { PhaseSignal } from './phases/index.js'
25
+ export type { ToolReviewOutcome } from './phases/index.js'
37
26
 
38
27
  export interface IterationConfig {
39
- provider: LLMProvider;
40
- sessionConfig: AgentRunConfig;
41
- tools: ToolRegistry;
42
- allowedTools?: string[];
43
- taskGateway?: import('../../../types/agent/gateway.js').TaskGateway;
44
- taskStore?: import('../../../types/task/index.js').TaskStore;
45
- launchedTasks?: Map<import('../../../types/ids/index.js').TaskId, import('./phases/context.js').LaunchedTaskMeta>;
28
+ provider: LLMProvider
29
+ sessionConfig: AgentRunConfig
30
+ tools: ToolRegistry
31
+ allowedTools?: string[]
32
+ taskGateway?: import('../../../types/agent/gateway.js').TaskGateway
33
+ taskStore?: import('../../../types/task/index.js').TaskStore
34
+ launchedTasks?: Map<
35
+ import('../../../types/ids/index.js').TaskId,
36
+ import('./phases/context.js').LaunchedTaskMeta
37
+ >
46
38
  }
47
39
 
48
40
  export class IterationOrchestrator {
49
- private ctx: IterationContext;
41
+ private ctx: IterationContext
50
42
 
51
43
  constructor(
52
44
  config: IterationConfig,
@@ -82,320 +74,305 @@ export class IterationOrchestrator {
82
74
  taskStore: config.taskStore,
83
75
  pendingNotifications: [],
84
76
  launchedTasks: config.launchedTasks ?? new Map(),
85
- };
77
+ }
86
78
  }
87
79
 
88
80
  async *runLoop(): AsyncGenerator<RunEvent> {
89
- const { sessionConfig, sessionMgr } = this.ctx;
90
- const { model } = sessionConfig;
91
- const tracer = getTracer();
81
+ const { sessionConfig, sessionMgr } = this.ctx
82
+ const { model } = sessionConfig
83
+ const tracer = getTracer()
92
84
 
93
- let unsubscribeTaskListener: (() => void) | undefined;
85
+ let unsubscribeTaskListener: (() => void) | undefined
94
86
  if (this.ctx.taskGateway) {
95
87
  unsubscribeTaskListener = this.ctx.taskGateway.onTaskCompleted((handle) => {
96
- this.ctx.pendingNotifications.push(handle);
88
+ this.ctx.pendingNotifications.push(handle)
97
89
  this.ctx.log.debug('Task completion queued for notification', {
98
90
  taskId: handle.taskId,
99
91
  agentId: handle.agentId,
100
92
  state: handle.state,
101
- });
102
- });
93
+ })
94
+ })
103
95
  }
104
96
 
105
97
  try {
106
- const planSignal = yield* runPlanGate(this.ctx);
107
- if (planSignal === "stop") return;
108
-
109
- while (true) {
110
- const guardResult = this.ctx.guard.beforeIteration(
111
- sessionMgr,
112
- this.ctx.abortController.signal,
113
- );
114
-
115
- if (guardResult.shouldStop) {
116
- if (guardResult.isCancelled) {
117
- this.ctx.log.info('Run cancelled by signal', { runId: sessionMgr.id });
118
- sessionMgr.setStopReason("cancelled");
119
- sessionMgr.markCancelled();
120
- break;
121
- }
122
-
123
- this.ctx.log.info('Guard enforcing stop', {
124
- runId: sessionMgr.id,
125
- stopReason: guardResult.stopReason,
126
- iteration: sessionMgr.currentIteration,
127
- inputTokens: sessionMgr.tokenUsage.promptTokens,
128
- outputTokens: sessionMgr.tokenUsage.completionTokens,
129
- });
130
- await this.requestFinalResponse(model, guardResult.stopReason!);
131
- yield* this.ctx.drainPending();
132
- sessionMgr.setStopReason(guardResult.stopReason!);
133
- break;
134
- }
135
-
136
- const forceFinalize = guardResult.forceFinalize;
137
- const iterationNum = sessionMgr.incrementIteration();
138
- this.ctx.log.debug('Iteration started', {
139
- runId: sessionMgr.id,
140
- iteration: iterationNum,
141
- model,
142
- forceFinalize,
143
- messageCount: sessionMgr.messages.length,
144
- });
145
-
146
- const iterationActivity = this.ctx.activityStore.create({
147
- type: "llm_turn",
148
- description: `LLM iteration ${iterationNum}`,
149
- });
150
- if (iterationActivity) {
151
- this.ctx.activityStore.start(iterationActivity.id);
152
- }
153
-
154
- const iterSpan = tracer.startSpan(agentIterationSpanName(iterationNum));
155
- iterSpan.setAttributes({
156
- [NAMZU.ITERATION]: iterationNum,
157
- [NAMZU.SESSION_ID]: sessionMgr.id,
158
- [GENAI.REQUEST_MODEL]: model,
159
- });
98
+ const planSignal = yield* runPlanGate(this.ctx)
99
+ if (planSignal === 'stop') return
100
+
101
+ while (true) {
102
+ const guardResult = this.ctx.guard.beforeIteration(
103
+ sessionMgr,
104
+ this.ctx.abortController.signal,
105
+ )
106
+
107
+ if (guardResult.shouldStop) {
108
+ if (guardResult.isCancelled) {
109
+ this.ctx.log.info('Run cancelled by signal', { runId: sessionMgr.id })
110
+ sessionMgr.setStopReason('cancelled')
111
+ sessionMgr.markCancelled()
112
+ break
113
+ }
160
114
 
161
- await this.ctx.emitEvent({
162
- type: "iteration_started",
163
- runId: sessionMgr.id,
164
- iteration: iterationNum,
165
- });
166
- yield* this.ctx.drainPending();
167
-
168
- try {
169
- if (this.ctx.pendingNotifications.length > 0) {
170
- yield* this.injectOneTaskNotification();
115
+ const stopReason = guardResult.stopReason ?? 'end_turn'
116
+ this.ctx.log.info('Guard enforcing stop', {
117
+ runId: sessionMgr.id,
118
+ stopReason,
119
+ iteration: sessionMgr.currentIteration,
120
+ inputTokens: sessionMgr.tokenUsage.promptTokens,
121
+ outputTokens: sessionMgr.tokenUsage.completionTokens,
122
+ })
123
+ await this.requestFinalResponse(model, stopReason)
124
+ yield* this.ctx.drainPending()
125
+ sessionMgr.setStopReason(stopReason)
126
+ break
171
127
  }
172
128
 
173
- const openAITools = forceFinalize
174
- ? undefined
175
- : this.ctx.tools.toLLMTools(this.ctx.allowedTools);
176
-
177
- const messages = forceFinalize
178
- ? [
179
- ...sessionMgr.messages,
180
- createUserMessage(
181
- "[SYSTEM] You are approaching your resource limits. Provide your final, comprehensive response now based on everything you have gathered so far. Do not request any more tool calls.",
182
- ),
183
- ]
184
- : sessionMgr.messages;
185
-
186
- const response = await this.ctx.provider.chat({
187
- model,
188
- messages,
189
- tools:
190
- openAITools && openAITools.length > 0 ? openAITools : undefined,
191
- temperature: sessionConfig.temperature,
192
- maxTokens: sessionConfig.maxResponseTokens,
193
- });
194
-
195
- sessionMgr.accumulateUsage(response.usage);
196
-
197
- this.ctx.log.debug('LLM response received', {
129
+ const forceFinalize = guardResult.forceFinalize
130
+ const iterationNum = sessionMgr.incrementIteration()
131
+ this.ctx.log.debug('Iteration started', {
198
132
  runId: sessionMgr.id,
199
133
  iteration: iterationNum,
200
- finishReason: response.finishReason,
201
- hasContent: response.message.content !== null && response.message.content.length > 0,
202
- toolCallCount: response.message.toolCalls?.length ?? 0,
203
- promptTokens: response.usage.promptTokens,
204
- completionTokens: response.usage.completionTokens,
205
- totalTokens: sessionMgr.tokenUsage.totalTokens,
206
- totalCost: sessionMgr.costInfo.totalCost,
207
- });
134
+ model,
135
+ forceFinalize,
136
+ messageCount: sessionMgr.messages.length,
137
+ })
138
+
139
+ const iterationActivity = this.ctx.activityStore.create({
140
+ type: 'llm_turn',
141
+ description: `LLM iteration ${iterationNum}`,
142
+ })
143
+ if (iterationActivity) {
144
+ this.ctx.activityStore.start(iterationActivity.id)
145
+ }
146
+
147
+ const iterSpan = tracer.startSpan(agentIterationSpanName(iterationNum))
148
+ iterSpan.setAttributes({
149
+ [NAMZU.ITERATION]: iterationNum,
150
+ [NAMZU.SESSION_ID]: sessionMgr.id,
151
+ [GENAI.REQUEST_MODEL]: model,
152
+ })
208
153
 
209
154
  await this.ctx.emitEvent({
210
- type: "token_usage_updated",
155
+ type: 'iteration_started',
211
156
  runId: sessionMgr.id,
212
- usage: sessionMgr.tokenUsage,
213
- cost: sessionMgr.costInfo,
214
- });
157
+ iteration: iterationNum,
158
+ })
159
+ yield* this.ctx.drainPending()
215
160
 
216
- const assistantMsg = createAssistantMessage(
217
- response.message.content,
218
- forceFinalize ? undefined : response.message.toolCalls,
219
- );
220
- sessionMgr.pushMessage(assistantMsg);
161
+ try {
162
+ if (this.ctx.pendingNotifications.length > 0) {
163
+ await this.injectOneTaskNotification()
164
+ }
221
165
 
222
- await this.ctx.emitEvent({
223
- type: "llm_response",
224
- runId: sessionMgr.id,
225
- content: response.message.content,
226
- hasToolCalls: forceFinalize
227
- ? false
228
- : !!response.message.toolCalls?.length,
229
- });
166
+ const openAITools = forceFinalize
167
+ ? undefined
168
+ : this.ctx.tools.toLLMTools(this.ctx.allowedTools)
169
+
170
+ const messages = forceFinalize
171
+ ? [
172
+ ...sessionMgr.messages,
173
+ createUserMessage(
174
+ '[SYSTEM] You are approaching your resource limits. Provide your final, comprehensive response now based on everything you have gathered so far. Do not request any more tool calls.',
175
+ ),
176
+ ]
177
+ : sessionMgr.messages
178
+
179
+ const response = await this.ctx.provider.chat({
180
+ model,
181
+ messages,
182
+ tools: openAITools && openAITools.length > 0 ? openAITools : undefined,
183
+ temperature: sessionConfig.temperature,
184
+ maxTokens: sessionConfig.maxResponseTokens,
185
+ })
186
+
187
+ sessionMgr.accumulateUsage(response.usage)
188
+
189
+ this.ctx.log.debug('LLM response received', {
190
+ runId: sessionMgr.id,
191
+ iteration: iterationNum,
192
+ finishReason: response.finishReason,
193
+ hasContent: response.message.content !== null && response.message.content.length > 0,
194
+ toolCallCount: response.message.toolCalls?.length ?? 0,
195
+ promptTokens: response.usage.promptTokens,
196
+ completionTokens: response.usage.completionTokens,
197
+ totalTokens: sessionMgr.tokenUsage.totalTokens,
198
+ totalCost: sessionMgr.costInfo.totalCost,
199
+ })
230
200
 
231
- yield* this.ctx.drainPending();
201
+ await this.ctx.emitEvent({
202
+ type: 'token_usage_updated',
203
+ runId: sessionMgr.id,
204
+ usage: sessionMgr.tokenUsage,
205
+ cost: sessionMgr.costInfo,
206
+ })
232
207
 
233
- iterSpan.setAttributes({
234
- [GENAI.USAGE_INPUT_TOKENS]: response.usage.promptTokens,
235
- [GENAI.USAGE_OUTPUT_TOKENS]: response.usage.completionTokens,
236
- });
237
- iterSpan.setStatus({ code: SpanStatusCode.OK });
208
+ const assistantMsg = createAssistantMessage(
209
+ response.message.content,
210
+ forceFinalize ? undefined : response.message.toolCalls,
211
+ )
212
+ sessionMgr.pushMessage(assistantMsg)
238
213
 
239
- if (iterationActivity) {
240
- this.ctx.activityStore.complete(iterationActivity.id, {
214
+ await this.ctx.emitEvent({
215
+ type: 'llm_response',
216
+ runId: sessionMgr.id,
241
217
  content: response.message.content,
242
- hasToolCalls: forceFinalize
243
- ? false
244
- : !!response.message.toolCalls?.length,
245
- });
246
- }
218
+ hasToolCalls: forceFinalize ? false : !!response.message.toolCalls?.length,
219
+ })
220
+
221
+ yield* this.ctx.drainPending()
222
+
223
+ iterSpan.setAttributes({
224
+ [GENAI.USAGE_INPUT_TOKENS]: response.usage.promptTokens,
225
+ [GENAI.USAGE_OUTPUT_TOKENS]: response.usage.completionTokens,
226
+ })
227
+ iterSpan.setStatus({ code: SpanStatusCode.OK })
228
+
229
+ if (iterationActivity) {
230
+ this.ctx.activityStore.complete(iterationActivity.id, {
231
+ content: response.message.content,
232
+ hasToolCalls: forceFinalize ? false : !!response.message.toolCalls?.length,
233
+ })
234
+ }
247
235
 
248
- if (
249
- forceFinalize ||
250
- response.finishReason === "stop" ||
251
- !response.message.toolCalls ||
252
- response.message.toolCalls.length === 0
253
- ) {
254
- const hasRunningTasks = this.hasRunningAgentTasks();
255
- const hasPendingNotifications = this.ctx.pendingNotifications.length > 0;
256
-
257
- if (!forceFinalize && (hasRunningTasks || hasPendingNotifications)) {
258
- this.ctx.log.info('LLM ended turn but agent tasks still running — waiting for notifications', {
259
- runId: sessionMgr.id,
260
- runningTasks: hasRunningTasks,
261
- pendingNotifications: hasPendingNotifications,
262
- });
236
+ if (
237
+ forceFinalize ||
238
+ response.finishReason === 'stop' ||
239
+ !response.message.toolCalls ||
240
+ response.message.toolCalls.length === 0
241
+ ) {
242
+ const hasRunningTasks = this.hasRunningAgentTasks()
243
+ const hasPendingNotifications = this.ctx.pendingNotifications.length > 0
244
+
245
+ if (!forceFinalize && (hasRunningTasks || hasPendingNotifications)) {
246
+ this.ctx.log.info(
247
+ 'LLM ended turn but agent tasks still running — waiting for notifications',
248
+ {
249
+ runId: sessionMgr.id,
250
+ runningTasks: hasRunningTasks,
251
+ pendingNotifications: hasPendingNotifications,
252
+ },
253
+ )
254
+
255
+ await this.ctx.emitEvent({
256
+ type: 'iteration_completed',
257
+ runId: sessionMgr.id,
258
+ iteration: iterationNum,
259
+ hasToolCalls: false,
260
+ })
261
+ yield* this.ctx.drainPending()
262
+ iterSpan.end()
263
+
264
+ yield* this.waitAndInjectNotifications()
265
+ continue
266
+ }
267
+
268
+ const hasContent =
269
+ response.message.content !== null && response.message.content.length > 0
270
+
271
+ if (!hasContent && !forceFinalize) {
272
+ this.ctx.log.warn('Empty completion detected — requesting final summary', {
273
+ iteration: iterationNum,
274
+ finishReason: response.finishReason,
275
+ })
276
+ await this.requestFinalResponse(model, 'end_turn')
277
+ yield* this.ctx.drainPending()
278
+ }
263
279
 
264
280
  await this.ctx.emitEvent({
265
- type: "iteration_completed",
281
+ type: 'iteration_completed',
266
282
  runId: sessionMgr.id,
267
283
  iteration: iterationNum,
268
284
  hasToolCalls: false,
269
- });
270
- yield* this.ctx.drainPending();
271
- iterSpan.end();
285
+ })
286
+ yield* this.ctx.drainPending()
287
+ sessionMgr.setStopReason('end_turn')
288
+ iterSpan.end()
289
+ break
290
+ }
291
+
292
+ const reviewOutcome = yield* runToolReview(this.ctx, response, iterationNum)
272
293
 
273
- yield* this.waitAndInjectNotifications();
274
- continue;
294
+ if (reviewOutcome === 'stop') {
295
+ iterSpan.end()
296
+ return
275
297
  }
276
298
 
277
- const hasContent =
278
- response.message.content !== null &&
279
- response.message.content.length > 0;
299
+ if (reviewOutcome === 'rejected') {
300
+ iterSpan.end()
301
+ continue
302
+ }
280
303
 
281
- if (!hasContent && !forceFinalize) {
282
- this.ctx.log.warn(
283
- "Empty completion detected — requesting final summary",
284
- {
285
- iteration: iterationNum,
286
- finishReason: response.finishReason,
287
- },
288
- );
289
- await this.requestFinalResponse(model, "end_turn");
290
- yield* this.ctx.drainPending();
304
+ const checkpointSignal = yield* runIterationCheckpoint(this.ctx, iterationNum)
305
+ if (checkpointSignal === 'stop') {
306
+ iterSpan.end()
307
+ return
291
308
  }
292
309
 
293
310
  await this.ctx.emitEvent({
294
- type: "iteration_completed",
311
+ type: 'iteration_completed',
295
312
  runId: sessionMgr.id,
296
313
  iteration: iterationNum,
297
- hasToolCalls: false,
298
- });
299
- yield* this.ctx.drainPending();
300
- sessionMgr.setStopReason("end_turn");
301
- iterSpan.end();
302
- break;
303
- }
304
-
305
- const reviewOutcome = yield* runToolReview(
306
- this.ctx,
307
- response,
308
- iterationNum,
309
- );
310
-
311
- if (reviewOutcome === "stop") {
312
- iterSpan.end();
313
- return;
314
- }
315
-
316
- if (reviewOutcome === "rejected") {
317
- iterSpan.end();
318
- continue;
319
- }
320
-
321
- const checkpointSignal = yield* runIterationCheckpoint(
322
- this.ctx,
323
- iterationNum,
324
- );
325
- if (checkpointSignal === "stop") {
326
- iterSpan.end();
327
- return;
328
- }
314
+ hasToolCalls: true,
315
+ })
316
+ yield* this.ctx.drainPending()
317
+ iterSpan.end()
318
+ } catch (err) {
319
+ if (iterationActivity) {
320
+ this.ctx.activityStore.fail(iterationActivity.id, toErrorMessage(err))
321
+ }
329
322
 
330
- await this.ctx.emitEvent({
331
- type: "iteration_completed",
332
- runId: sessionMgr.id,
333
- iteration: iterationNum,
334
- hasToolCalls: true,
335
- });
336
- yield* this.ctx.drainPending();
337
- iterSpan.end();
338
- } catch (err) {
339
- if (iterationActivity) {
340
- this.ctx.activityStore.fail(iterationActivity.id, toErrorMessage(err));
323
+ iterSpan.setStatus({
324
+ code: SpanStatusCode.ERROR,
325
+ message: toErrorMessage(err),
326
+ })
327
+ iterSpan.recordException(err instanceof Error ? err : new Error(String(err)))
328
+ iterSpan.end()
329
+ throw err
341
330
  }
342
-
343
- iterSpan.setStatus({
344
- code: SpanStatusCode.ERROR,
345
- message: toErrorMessage(err),
346
- });
347
- iterSpan.recordException(
348
- err instanceof Error ? err : new Error(String(err)),
349
- );
350
- iterSpan.end();
351
- throw err;
352
331
  }
353
- }
354
-
355
332
  } finally {
356
- unsubscribeTaskListener?.();
333
+ unsubscribeTaskListener?.()
357
334
  }
358
335
  }
359
336
 
360
337
  private hasRunningAgentTasks(): boolean {
361
- if (!this.ctx.taskGateway) return false;
362
- return this.ctx.taskGateway.listTasks().some(
363
- (t) => t.state !== 'completed' && t.state !== 'failed' && t.state !== 'canceled',
364
- );
338
+ if (!this.ctx.taskGateway) return false
339
+ return this.ctx.taskGateway
340
+ .listTasks()
341
+ .some((t) => t.state !== 'completed' && t.state !== 'failed' && t.state !== 'canceled')
365
342
  }
366
343
 
367
344
  private async *waitAndInjectNotifications(): AsyncGenerator<RunEvent> {
368
- const deadline = Date.now() + (this.ctx.sessionConfig.timeoutMs ?? 120_000);
345
+ const deadline = Date.now() + (this.ctx.sessionConfig.timeoutMs ?? 120_000)
369
346
  while (
370
347
  this.ctx.pendingNotifications.length === 0 &&
371
348
  Date.now() < deadline &&
372
349
  !this.ctx.abortController.signal.aborted
373
350
  ) {
374
- await new Promise((r) => setTimeout(r, 250));
351
+ await new Promise((r) => setTimeout(r, 250))
375
352
  }
376
353
 
377
- yield* this.injectOneTaskNotification();
354
+ await this.injectOneTaskNotification()
378
355
  }
379
356
 
380
- private async *injectOneTaskNotification(): AsyncGenerator<RunEvent> {
381
- if (this.ctx.pendingNotifications.length === 0) return;
382
-
383
- const handle = this.ctx.pendingNotifications.shift()!;
384
- const meta = this.ctx.launchedTasks.get(handle.taskId);
385
- const resultText = handle.result?.result
386
- ?? handle.result?.lastError
387
- ?? `Task finished with state: ${handle.state}`;
357
+ private async injectOneTaskNotification(): Promise<void> {
358
+ const handle = this.ctx.pendingNotifications.shift()
359
+ if (!handle) return
360
+ const meta = this.ctx.launchedTasks.get(handle.taskId)
361
+ const resultText =
362
+ handle.result?.result ??
363
+ handle.result?.lastError ??
364
+ `Task finished with state: ${handle.state}`
388
365
 
389
366
  if (meta?.planTaskId && this.ctx.taskStore) {
390
- const success = handle.state === 'completed';
367
+ const success = handle.state === 'completed'
391
368
  await this.ctx.taskStore.update(meta.planTaskId as `task_${string}`, {
392
369
  status: 'completed',
393
370
  description: success ? undefined : `Failed: ${resultText.substring(0, 200)}`,
394
- });
371
+ })
395
372
  }
396
373
 
397
- this.ctx.launchedTasks.delete(handle.taskId);
398
- const remainingTasks = this.ctx.launchedTasks.size;
374
+ this.ctx.launchedTasks.delete(handle.taskId)
375
+ const remainingTasks = this.ctx.launchedTasks.size
399
376
 
400
377
  const notification = [
401
378
  '<task-notification>',
@@ -406,9 +383,9 @@ export class IterationOrchestrator {
406
383
  ` <result>${resultText}</result>`,
407
384
  ` <remaining-tasks>${remainingTasks}</remaining-tasks>`,
408
385
  '</task-notification>',
409
- ].join('\n');
386
+ ].join('\n')
410
387
 
411
- this.ctx.sessionMgr.pushMessage(createUserMessage(notification));
388
+ this.ctx.sessionMgr.pushMessage(createUserMessage(notification))
412
389
 
413
390
  this.ctx.log.info('Task notification injected', {
414
391
  taskId: handle.taskId,
@@ -417,27 +394,24 @@ export class IterationOrchestrator {
417
394
  planTaskId: meta?.planTaskId,
418
395
  remainingTasks,
419
396
  remainingNotifications: this.ctx.pendingNotifications.length,
420
- });
397
+ })
421
398
  }
422
399
 
423
- private async requestFinalResponse(
424
- model: string,
425
- reason: StopReason,
426
- ): Promise<void> {
400
+ private async requestFinalResponse(model: string, reason: StopReason): Promise<void> {
427
401
  const lastAssistant = [...this.ctx.sessionMgr.messages]
428
402
  .reverse()
429
- .find((m) => m.role === "assistant");
403
+ .find((m) => m.role === 'assistant')
430
404
 
431
405
  const hasResult =
432
406
  lastAssistant?.content !== null &&
433
407
  lastAssistant?.content !== undefined &&
434
- lastAssistant.content.length > 0;
408
+ lastAssistant.content.length > 0
435
409
 
436
- if (hasResult) return;
410
+ if (hasResult) return
437
411
 
438
- this.ctx.log.info("Requesting final response before limit enforcement", {
412
+ this.ctx.log.info('Requesting final response before limit enforcement', {
439
413
  reason,
440
- });
414
+ })
441
415
 
442
416
  try {
443
417
  const finalMessages = [
@@ -445,30 +419,30 @@ export class IterationOrchestrator {
445
419
  createUserMessage(
446
420
  `[SYSTEM] Session is ending due to ${reason}. You MUST provide a final response now summarizing all your findings and work so far. Do not use any tools.`,
447
421
  ),
448
- ];
422
+ ]
449
423
 
450
424
  const response = await this.ctx.provider.chat({
451
425
  model,
452
426
  messages: finalMessages,
453
427
  temperature: this.ctx.sessionConfig.temperature,
454
428
  maxTokens: this.ctx.sessionConfig.maxResponseTokens,
455
- });
429
+ })
456
430
 
457
- this.ctx.sessionMgr.accumulateUsage(response.usage);
431
+ this.ctx.sessionMgr.accumulateUsage(response.usage)
458
432
 
459
- const assistantMsg = createAssistantMessage(response.message.content);
460
- this.ctx.sessionMgr.pushMessage(assistantMsg);
433
+ const assistantMsg = createAssistantMessage(response.message.content)
434
+ this.ctx.sessionMgr.pushMessage(assistantMsg)
461
435
 
462
436
  await this.ctx.emitEvent({
463
- type: "llm_response",
437
+ type: 'llm_response',
464
438
  runId: this.ctx.sessionMgr.id,
465
439
  content: response.message.content,
466
440
  hasToolCalls: false,
467
- });
441
+ })
468
442
  } catch (err) {
469
- this.ctx.log.error("Failed to get final response", {
443
+ this.ctx.log.error('Failed to get final response', {
470
444
  error: toErrorMessage(err),
471
- });
445
+ })
472
446
  }
473
447
  }
474
448
  }