@robota-sdk/agent-core 3.0.0-beta.14 → 3.0.0-beta.16

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 (486) hide show
  1. package/README.md +2 -0
  2. package/dist/abstracts/abstract-agent.d.ts.map +1 -1
  3. package/dist/abstracts/abstract-agent.js.map +1 -1
  4. package/dist/abstracts/abstract-ai-provider.d.ts +8 -7
  5. package/dist/abstracts/abstract-ai-provider.d.ts.map +1 -1
  6. package/dist/abstracts/abstract-ai-provider.js +21 -15
  7. package/dist/abstracts/abstract-ai-provider.js.map +1 -1
  8. package/dist/abstracts/abstract-executor.d.ts.map +1 -1
  9. package/dist/abstracts/abstract-executor.js +20 -12
  10. package/dist/abstracts/abstract-executor.js.map +1 -1
  11. package/dist/abstracts/abstract-manager.d.ts.map +1 -1
  12. package/dist/abstracts/abstract-manager.js.map +1 -1
  13. package/dist/abstracts/abstract-module-events.d.ts +77 -0
  14. package/dist/abstracts/abstract-module-events.d.ts.map +1 -0
  15. package/dist/abstracts/abstract-module-events.js +8 -0
  16. package/dist/abstracts/abstract-module-events.js.map +1 -0
  17. package/dist/abstracts/abstract-module-types.d.ts +110 -0
  18. package/dist/abstracts/abstract-module-types.d.ts.map +1 -0
  19. package/dist/abstracts/abstract-module-types.js +20 -0
  20. package/dist/abstracts/abstract-module-types.js.map +1 -0
  21. package/dist/abstracts/abstract-module.d.ts +13 -312
  22. package/dist/abstracts/abstract-module.d.ts.map +1 -1
  23. package/dist/abstracts/abstract-module.js +137 -302
  24. package/dist/abstracts/abstract-module.js.map +1 -1
  25. package/dist/abstracts/abstract-module.test.d.ts +2 -0
  26. package/dist/abstracts/abstract-module.test.d.ts.map +1 -0
  27. package/dist/abstracts/abstract-module.test.js +150 -0
  28. package/dist/abstracts/abstract-module.test.js.map +1 -0
  29. package/dist/abstracts/abstract-plugin-types.d.ts +152 -0
  30. package/dist/abstracts/abstract-plugin-types.d.ts.map +1 -0
  31. package/dist/abstracts/abstract-plugin-types.js +29 -0
  32. package/dist/abstracts/abstract-plugin-types.js.map +1 -0
  33. package/dist/abstracts/abstract-plugin.d.ts +15 -304
  34. package/dist/abstracts/abstract-plugin.d.ts.map +1 -1
  35. package/dist/abstracts/abstract-plugin.js +28 -144
  36. package/dist/abstracts/abstract-plugin.js.map +1 -1
  37. package/dist/abstracts/abstract-tool.d.ts +1 -1
  38. package/dist/abstracts/abstract-tool.d.ts.map +1 -1
  39. package/dist/abstracts/abstract-tool.js +2 -2
  40. package/dist/abstracts/abstract-tool.js.map +1 -1
  41. package/dist/abstracts/abstract-workflow-converter.d.ts.map +1 -1
  42. package/dist/abstracts/abstract-workflow-converter.js +29 -20
  43. package/dist/abstracts/abstract-workflow-converter.js.map +1 -1
  44. package/dist/abstracts/abstract-workflow-converter.test.d.ts +2 -0
  45. package/dist/abstracts/abstract-workflow-converter.test.d.ts.map +1 -0
  46. package/dist/abstracts/abstract-workflow-converter.test.js +144 -0
  47. package/dist/abstracts/abstract-workflow-converter.test.js.map +1 -0
  48. package/dist/abstracts/abstract-workflow-validator-helpers.d.ts +37 -0
  49. package/dist/abstracts/abstract-workflow-validator-helpers.d.ts.map +1 -0
  50. package/dist/abstracts/abstract-workflow-validator-helpers.js +147 -0
  51. package/dist/abstracts/abstract-workflow-validator-helpers.js.map +1 -0
  52. package/dist/abstracts/abstract-workflow-validator-helpers.test.d.ts +2 -0
  53. package/dist/abstracts/abstract-workflow-validator-helpers.test.d.ts.map +1 -0
  54. package/dist/abstracts/abstract-workflow-validator-helpers.test.js +157 -0
  55. package/dist/abstracts/abstract-workflow-validator-helpers.test.js.map +1 -0
  56. package/dist/abstracts/abstract-workflow-validator.d.ts +18 -130
  57. package/dist/abstracts/abstract-workflow-validator.d.ts.map +1 -1
  58. package/dist/abstracts/abstract-workflow-validator.js +58 -326
  59. package/dist/abstracts/abstract-workflow-validator.js.map +1 -1
  60. package/dist/abstracts/abstract-workflow-validator.test.d.ts +2 -0
  61. package/dist/abstracts/abstract-workflow-validator.test.d.ts.map +1 -0
  62. package/dist/abstracts/abstract-workflow-validator.test.js +142 -0
  63. package/dist/abstracts/abstract-workflow-validator.test.js.map +1 -0
  64. package/dist/abstracts/index.d.ts +1 -0
  65. package/dist/abstracts/index.d.ts.map +1 -1
  66. package/dist/abstracts/index.js +3 -2
  67. package/dist/abstracts/index.js.map +1 -1
  68. package/dist/agents/constants.d.ts +1 -1
  69. package/dist/agents/constants.d.ts.map +1 -1
  70. package/dist/agents/constants.js +1 -1
  71. package/dist/agents/constants.js.map +1 -1
  72. package/dist/agents/index.js +1 -1
  73. package/dist/agents/index.js.map +1 -1
  74. package/dist/agents/robota.test.js +36 -36
  75. package/dist/agents/robota.test.js.map +1 -1
  76. package/dist/browser/index.d.ts +28 -1
  77. package/dist/browser/index.js +5 -5
  78. package/dist/context/index.d.ts +4 -0
  79. package/dist/context/index.d.ts.map +1 -0
  80. package/dist/context/index.js +2 -0
  81. package/dist/context/index.js.map +1 -0
  82. package/dist/context/models.d.ts +27 -0
  83. package/dist/context/models.d.ts.map +1 -0
  84. package/dist/context/models.js +76 -0
  85. package/dist/context/models.js.map +1 -0
  86. package/dist/context/models.test.d.ts +2 -0
  87. package/dist/context/models.test.d.ts.map +1 -0
  88. package/dist/context/models.test.js +51 -0
  89. package/dist/context/models.test.js.map +1 -0
  90. package/dist/context/types.d.ts +25 -0
  91. package/dist/context/types.d.ts.map +1 -0
  92. package/dist/context/types.js +8 -0
  93. package/dist/context/types.js.map +1 -0
  94. package/dist/core/robota-config-manager.d.ts +78 -0
  95. package/dist/core/robota-config-manager.d.ts.map +1 -0
  96. package/dist/core/robota-config-manager.js +216 -0
  97. package/dist/core/robota-config-manager.js.map +1 -0
  98. package/dist/core/robota-execution.d.ts +23 -0
  99. package/dist/core/robota-execution.d.ts.map +1 -0
  100. package/dist/core/robota-execution.js +81 -0
  101. package/dist/core/robota-execution.js.map +1 -0
  102. package/dist/core/robota-initializer.d.ts +37 -0
  103. package/dist/core/robota-initializer.d.ts.map +1 -0
  104. package/dist/core/robota-initializer.js +77 -0
  105. package/dist/core/robota-initializer.js.map +1 -0
  106. package/dist/core/robota-lifecycle.d.ts +53 -0
  107. package/dist/core/robota-lifecycle.d.ts.map +1 -0
  108. package/dist/core/robota-lifecycle.js +73 -0
  109. package/dist/core/robota-lifecycle.js.map +1 -0
  110. package/dist/core/robota-module-manager.d.ts +78 -0
  111. package/dist/core/robota-module-manager.d.ts.map +1 -0
  112. package/dist/core/robota-module-manager.js +114 -0
  113. package/dist/core/robota-module-manager.js.map +1 -0
  114. package/dist/core/robota-plugin-manager.d.ts +40 -0
  115. package/dist/core/robota-plugin-manager.d.ts.map +1 -0
  116. package/dist/core/robota-plugin-manager.js +71 -0
  117. package/dist/core/robota-plugin-manager.js.map +1 -0
  118. package/dist/core/robota.d.ts +56 -606
  119. package/dist/core/robota.d.ts.map +1 -1
  120. package/dist/core/robota.js +210 -1152
  121. package/dist/core/robota.js.map +1 -1
  122. package/dist/core/robota.test.d.ts +2 -0
  123. package/dist/core/robota.test.d.ts.map +1 -0
  124. package/dist/core/robota.test.js +353 -0
  125. package/dist/core/robota.test.js.map +1 -0
  126. package/dist/event-service/event-service.d.ts +61 -0
  127. package/dist/event-service/event-service.d.ts.map +1 -0
  128. package/dist/event-service/event-service.js +120 -0
  129. package/dist/event-service/event-service.js.map +1 -0
  130. package/dist/event-service/index.d.ts +6 -0
  131. package/dist/event-service/index.d.ts.map +1 -0
  132. package/dist/event-service/index.js +4 -0
  133. package/dist/event-service/index.js.map +1 -0
  134. package/dist/event-service/interfaces.d.ts +98 -0
  135. package/dist/event-service/interfaces.d.ts.map +1 -0
  136. package/dist/event-service/interfaces.js +8 -0
  137. package/dist/event-service/interfaces.js.map +1 -0
  138. package/dist/event-service/task-events.d.ts +6 -0
  139. package/dist/event-service/task-events.d.ts.map +1 -0
  140. package/dist/event-service/task-events.js +6 -0
  141. package/dist/event-service/task-events.js.map +1 -0
  142. package/dist/event-service/user-events.d.ts +7 -0
  143. package/dist/event-service/user-events.d.ts.map +1 -0
  144. package/dist/event-service/user-events.js +6 -0
  145. package/dist/event-service/user-events.js.map +1 -0
  146. package/dist/executors/local-executor.d.ts +2 -2
  147. package/dist/executors/local-executor.d.ts.map +1 -1
  148. package/dist/executors/local-executor.js +7 -7
  149. package/dist/executors/local-executor.js.map +1 -1
  150. package/dist/executors/local-executor.test.js +16 -16
  151. package/dist/executors/local-executor.test.js.map +1 -1
  152. package/dist/hooks/hook-runner.d.ts +20 -0
  153. package/dist/hooks/hook-runner.d.ts.map +1 -0
  154. package/dist/hooks/hook-runner.js +95 -0
  155. package/dist/hooks/hook-runner.js.map +1 -0
  156. package/dist/hooks/index.d.ts +3 -0
  157. package/dist/hooks/index.d.ts.map +1 -0
  158. package/dist/hooks/index.js +3 -0
  159. package/dist/hooks/index.js.map +1 -0
  160. package/dist/hooks/types.d.ts +40 -0
  161. package/dist/hooks/types.d.ts.map +1 -0
  162. package/dist/hooks/types.js +5 -0
  163. package/dist/hooks/types.js.map +1 -0
  164. package/dist/index.d.ts +49 -75
  165. package/dist/index.d.ts.map +1 -1
  166. package/dist/index.js +26 -71
  167. package/dist/index.js.map +1 -1
  168. package/dist/interfaces/agent.d.ts +3 -2
  169. package/dist/interfaces/agent.d.ts.map +1 -1
  170. package/dist/interfaces/cache.d.ts +64 -0
  171. package/dist/interfaces/cache.d.ts.map +1 -0
  172. package/dist/interfaces/cache.js +2 -0
  173. package/dist/interfaces/cache.js.map +1 -0
  174. package/dist/interfaces/event-service.d.ts +4 -75
  175. package/dist/interfaces/event-service.d.ts.map +1 -1
  176. package/dist/interfaces/executor.d.ts.map +1 -1
  177. package/dist/interfaces/history-module.d.ts.map +1 -1
  178. package/dist/interfaces/index.d.ts +12 -9
  179. package/dist/interfaces/index.d.ts.map +1 -1
  180. package/dist/interfaces/index.js +2 -1
  181. package/dist/interfaces/index.js.map +1 -1
  182. package/dist/interfaces/manager.d.ts.map +1 -1
  183. package/dist/interfaces/media-provider.d.ts +86 -0
  184. package/dist/interfaces/media-provider.d.ts.map +1 -0
  185. package/dist/interfaces/media-provider.js +13 -0
  186. package/dist/interfaces/media-provider.js.map +1 -0
  187. package/dist/interfaces/messages.d.ts +23 -1
  188. package/dist/interfaces/messages.d.ts.map +1 -1
  189. package/dist/interfaces/messages.js.map +1 -1
  190. package/dist/interfaces/progress-reporting.d.ts.map +1 -1
  191. package/dist/interfaces/progress-reporting.js +1 -3
  192. package/dist/interfaces/progress-reporting.js.map +1 -1
  193. package/dist/interfaces/provider.d.ts +12 -1
  194. package/dist/interfaces/provider.d.ts.map +1 -1
  195. package/dist/interfaces/service.d.ts.map +1 -1
  196. package/dist/interfaces/tool.d.ts +1 -0
  197. package/dist/interfaces/tool.d.ts.map +1 -1
  198. package/dist/interfaces/types.d.ts.map +1 -1
  199. package/dist/interfaces/types.js +6 -6
  200. package/dist/interfaces/types.js.map +1 -1
  201. package/dist/interfaces/workflow-converter.d.ts.map +1 -1
  202. package/dist/interfaces/workflow-validator.d.ts.map +1 -1
  203. package/dist/interfaces/workflow-validator.js.map +1 -1
  204. package/dist/managers/agent-factory.d.ts.map +1 -1
  205. package/dist/managers/agent-factory.js +24 -16
  206. package/dist/managers/agent-factory.js.map +1 -1
  207. package/dist/managers/agent-factory.test.js +35 -25
  208. package/dist/managers/agent-factory.test.js.map +1 -1
  209. package/dist/managers/agent-templates.d.ts.map +1 -1
  210. package/dist/managers/agent-templates.js +22 -10
  211. package/dist/managers/agent-templates.js.map +1 -1
  212. package/dist/managers/agent-templates.test.d.ts +2 -0
  213. package/dist/managers/agent-templates.test.d.ts.map +1 -0
  214. package/dist/managers/agent-templates.test.js +175 -0
  215. package/dist/managers/agent-templates.test.js.map +1 -0
  216. package/dist/managers/ai-provider-manager.d.ts.map +1 -1
  217. package/dist/managers/ai-provider-manager.js +8 -10
  218. package/dist/managers/ai-provider-manager.js.map +1 -1
  219. package/dist/managers/ai-provider-manager.test.d.ts +2 -0
  220. package/dist/managers/ai-provider-manager.test.d.ts.map +1 -0
  221. package/dist/managers/ai-provider-manager.test.js +327 -0
  222. package/dist/managers/ai-provider-manager.test.js.map +1 -0
  223. package/dist/managers/conversation-history-manager.d.ts +13 -425
  224. package/dist/managers/conversation-history-manager.d.ts.map +1 -1
  225. package/dist/managers/conversation-history-manager.js +21 -537
  226. package/dist/managers/conversation-history-manager.js.map +1 -1
  227. package/dist/managers/conversation-history-manager.test.js +82 -43
  228. package/dist/managers/conversation-history-manager.test.js.map +1 -1
  229. package/dist/managers/conversation-message-factory.d.ts +40 -0
  230. package/dist/managers/conversation-message-factory.d.ts.map +1 -0
  231. package/dist/managers/conversation-message-factory.js +66 -0
  232. package/dist/managers/conversation-message-factory.js.map +1 -0
  233. package/dist/managers/conversation-message-factory.test.d.ts +2 -0
  234. package/dist/managers/conversation-message-factory.test.d.ts.map +1 -0
  235. package/dist/managers/conversation-message-factory.test.js +95 -0
  236. package/dist/managers/conversation-message-factory.test.js.map +1 -0
  237. package/dist/managers/conversation-session.d.ts +90 -0
  238. package/dist/managers/conversation-session.d.ts.map +1 -0
  239. package/dist/managers/conversation-session.js +177 -0
  240. package/dist/managers/conversation-session.js.map +1 -0
  241. package/dist/managers/index.d.ts +2 -2
  242. package/dist/managers/index.d.ts.map +1 -1
  243. package/dist/managers/index.js +1 -1
  244. package/dist/managers/index.js.map +1 -1
  245. package/dist/managers/module-registry-validation.d.ts +38 -0
  246. package/dist/managers/module-registry-validation.d.ts.map +1 -0
  247. package/dist/managers/module-registry-validation.js +100 -0
  248. package/dist/managers/module-registry-validation.js.map +1 -0
  249. package/dist/managers/module-registry-validation.test.d.ts +2 -0
  250. package/dist/managers/module-registry-validation.test.d.ts.map +1 -0
  251. package/dist/managers/module-registry-validation.test.js +144 -0
  252. package/dist/managers/module-registry-validation.test.js.map +1 -0
  253. package/dist/managers/module-registry.d.ts +13 -111
  254. package/dist/managers/module-registry.d.ts.map +1 -1
  255. package/dist/managers/module-registry.js +74 -344
  256. package/dist/managers/module-registry.js.map +1 -1
  257. package/dist/managers/module-type-registry-helpers.d.ts +34 -0
  258. package/dist/managers/module-type-registry-helpers.d.ts.map +1 -0
  259. package/dist/managers/module-type-registry-helpers.js +255 -0
  260. package/dist/managers/module-type-registry-helpers.js.map +1 -0
  261. package/dist/managers/module-type-registry.d.ts +10 -64
  262. package/dist/managers/module-type-registry.d.ts.map +1 -1
  263. package/dist/managers/module-type-registry.js +25 -373
  264. package/dist/managers/module-type-registry.js.map +1 -1
  265. package/dist/managers/plugins-helpers.d.ts +18 -0
  266. package/dist/managers/plugins-helpers.d.ts.map +1 -0
  267. package/dist/managers/plugins-helpers.js +118 -0
  268. package/dist/managers/plugins-helpers.js.map +1 -0
  269. package/dist/managers/plugins-helpers.test.d.ts +2 -0
  270. package/dist/managers/plugins-helpers.test.d.ts.map +1 -0
  271. package/dist/managers/plugins-helpers.test.js +68 -0
  272. package/dist/managers/plugins-helpers.test.js.map +1 -0
  273. package/dist/managers/plugins.d.ts +16 -109
  274. package/dist/managers/plugins.d.ts.map +1 -1
  275. package/dist/managers/plugins.js +29 -220
  276. package/dist/managers/plugins.js.map +1 -1
  277. package/dist/managers/plugins.test.d.ts +2 -0
  278. package/dist/managers/plugins.test.d.ts.map +1 -0
  279. package/dist/managers/plugins.test.js +160 -0
  280. package/dist/managers/plugins.test.js.map +1 -0
  281. package/dist/managers/tool-manager.d.ts +1 -1
  282. package/dist/managers/tool-manager.d.ts.map +1 -1
  283. package/dist/managers/tool-manager.js +15 -5
  284. package/dist/managers/tool-manager.js.map +1 -1
  285. package/dist/managers/tool-manager.test.js +32 -16
  286. package/dist/managers/tool-manager.test.js.map +1 -1
  287. package/dist/node/index.cjs +5 -5
  288. package/dist/node/index.d.cts +28 -1
  289. package/dist/node/index.d.ts +28 -1
  290. package/dist/node/index.js +5 -5
  291. package/dist/permissions/index.d.ts +7 -0
  292. package/dist/permissions/index.d.ts.map +1 -0
  293. package/dist/permissions/index.js +4 -0
  294. package/dist/permissions/index.js.map +1 -0
  295. package/dist/permissions/permission-gate.d.ts +38 -0
  296. package/dist/permissions/permission-gate.d.ts.map +1 -0
  297. package/dist/permissions/permission-gate.js +119 -0
  298. package/dist/permissions/permission-gate.js.map +1 -0
  299. package/dist/permissions/permission-mode.d.ts +25 -0
  300. package/dist/permissions/permission-mode.d.ts.map +1 -0
  301. package/dist/permissions/permission-mode.js +58 -0
  302. package/dist/permissions/permission-mode.js.map +1 -0
  303. package/dist/permissions/types.d.ts +27 -0
  304. package/dist/permissions/types.d.ts.map +1 -0
  305. package/dist/permissions/types.js +9 -0
  306. package/dist/permissions/types.js.map +1 -0
  307. package/dist/plugins/event-emitter/metrics.d.ts.map +1 -1
  308. package/dist/plugins/event-emitter/metrics.js +1 -1
  309. package/dist/plugins/event-emitter/metrics.js.map +1 -1
  310. package/dist/plugins/event-emitter/plugin-types.d.ts +88 -0
  311. package/dist/plugins/event-emitter/plugin-types.d.ts.map +1 -0
  312. package/dist/plugins/event-emitter/plugin-types.js +2 -0
  313. package/dist/plugins/event-emitter/plugin-types.js.map +1 -0
  314. package/dist/plugins/event-emitter/types.d.ts +3 -3
  315. package/dist/plugins/event-emitter/types.d.ts.map +1 -1
  316. package/dist/plugins/event-emitter/types.js +4 -4
  317. package/dist/plugins/event-emitter/types.js.map +1 -1
  318. package/dist/plugins/event-emitter-plugin.d.ts +9 -184
  319. package/dist/plugins/event-emitter-plugin.d.ts.map +1 -1
  320. package/dist/plugins/event-emitter-plugin.js +91 -235
  321. package/dist/plugins/event-emitter-plugin.js.map +1 -1
  322. package/dist/schemas/agent-template-schema.d.ts +12 -12
  323. package/dist/schemas/agent-template-schema.d.ts.map +1 -1
  324. package/dist/schemas/agent-template-schema.js +35 -33
  325. package/dist/schemas/agent-template-schema.js.map +1 -1
  326. package/dist/services/cache/cache-key-builder.d.ts +13 -0
  327. package/dist/services/cache/cache-key-builder.d.ts.map +1 -0
  328. package/dist/services/cache/cache-key-builder.js +30 -0
  329. package/dist/services/cache/cache-key-builder.js.map +1 -0
  330. package/dist/services/cache/cache-key-builder.test.d.ts +2 -0
  331. package/dist/services/cache/cache-key-builder.test.d.ts.map +1 -0
  332. package/dist/services/cache/cache-key-builder.test.js +56 -0
  333. package/dist/services/cache/cache-key-builder.test.js.map +1 -0
  334. package/dist/services/cache/execution-cache-service.d.ts +18 -0
  335. package/dist/services/cache/execution-cache-service.d.ts.map +1 -0
  336. package/dist/services/cache/execution-cache-service.js +26 -0
  337. package/dist/services/cache/execution-cache-service.js.map +1 -0
  338. package/dist/services/cache/execution-cache-service.test.d.ts +2 -0
  339. package/dist/services/cache/execution-cache-service.test.d.ts.map +1 -0
  340. package/dist/services/cache/execution-cache-service.test.js +59 -0
  341. package/dist/services/cache/execution-cache-service.test.js.map +1 -0
  342. package/dist/services/cache/index.d.ts +4 -0
  343. package/dist/services/cache/index.d.ts.map +1 -0
  344. package/dist/services/cache/index.js +4 -0
  345. package/dist/services/cache/index.js.map +1 -0
  346. package/dist/services/cache/memory-cache-storage.d.ts +25 -0
  347. package/dist/services/cache/memory-cache-storage.d.ts.map +1 -0
  348. package/dist/services/cache/memory-cache-storage.js +89 -0
  349. package/dist/services/cache/memory-cache-storage.js.map +1 -0
  350. package/dist/services/cache/memory-cache-storage.test.d.ts +2 -0
  351. package/dist/services/cache/memory-cache-storage.test.d.ts.map +1 -0
  352. package/dist/services/cache/memory-cache-storage.test.js +94 -0
  353. package/dist/services/cache/memory-cache-storage.test.js.map +1 -0
  354. package/dist/services/conversation-service/conversation-service.test.d.ts +2 -0
  355. package/dist/services/conversation-service/conversation-service.test.d.ts.map +1 -0
  356. package/dist/services/conversation-service/conversation-service.test.js +248 -0
  357. package/dist/services/conversation-service/conversation-service.test.js.map +1 -0
  358. package/dist/services/conversation-service/index.d.ts +10 -71
  359. package/dist/services/conversation-service/index.d.ts.map +1 -1
  360. package/dist/services/conversation-service/index.js +58 -355
  361. package/dist/services/conversation-service/index.js.map +1 -1
  362. package/dist/services/conversation-service/message-helpers.d.ts +47 -0
  363. package/dist/services/conversation-service/message-helpers.d.ts.map +1 -0
  364. package/dist/services/conversation-service/message-helpers.js +150 -0
  365. package/dist/services/conversation-service/message-helpers.js.map +1 -0
  366. package/dist/services/conversation-service/types.d.ts.map +1 -1
  367. package/dist/services/execution-constants.d.ts +16 -0
  368. package/dist/services/execution-constants.d.ts.map +1 -0
  369. package/dist/services/execution-constants.js +16 -0
  370. package/dist/services/execution-constants.js.map +1 -0
  371. package/dist/services/execution-event-emitter.d.ts +60 -0
  372. package/dist/services/execution-event-emitter.d.ts.map +1 -0
  373. package/dist/services/execution-event-emitter.js +323 -0
  374. package/dist/services/execution-event-emitter.js.map +1 -0
  375. package/dist/services/execution-round.d.ts +58 -0
  376. package/dist/services/execution-round.d.ts.map +1 -0
  377. package/dist/services/execution-round.js +323 -0
  378. package/dist/services/execution-round.js.map +1 -0
  379. package/dist/services/execution-round.test.d.ts +2 -0
  380. package/dist/services/execution-round.test.d.ts.map +1 -0
  381. package/dist/services/execution-round.test.js +188 -0
  382. package/dist/services/execution-round.test.js.map +1 -0
  383. package/dist/services/execution-service.d.ts +28 -125
  384. package/dist/services/execution-service.d.ts.map +1 -1
  385. package/dist/services/execution-service.js +222 -1134
  386. package/dist/services/execution-service.js.map +1 -1
  387. package/dist/services/execution-service.test.js +115 -72
  388. package/dist/services/execution-service.test.js.map +1 -1
  389. package/dist/services/execution-stream.d.ts +32 -0
  390. package/dist/services/execution-stream.d.ts.map +1 -0
  391. package/dist/services/execution-stream.js +268 -0
  392. package/dist/services/execution-stream.js.map +1 -0
  393. package/dist/services/execution-types.d.ts +122 -0
  394. package/dist/services/execution-types.d.ts.map +1 -0
  395. package/dist/services/execution-types.js +48 -0
  396. package/dist/services/execution-types.js.map +1 -0
  397. package/dist/services/history-module.d.ts.map +1 -1
  398. package/dist/services/history-module.js +1 -1
  399. package/dist/services/history-module.js.map +1 -1
  400. package/dist/services/history-module.test.d.ts +2 -0
  401. package/dist/services/history-module.test.d.ts.map +1 -0
  402. package/dist/services/history-module.test.js +137 -0
  403. package/dist/services/history-module.test.js.map +1 -0
  404. package/dist/services/in-memory-history-store.d.ts.map +1 -1
  405. package/dist/services/in-memory-history-store.js +1 -1
  406. package/dist/services/in-memory-history-store.js.map +1 -1
  407. package/dist/services/index.d.ts +0 -1
  408. package/dist/services/index.d.ts.map +1 -1
  409. package/dist/services/index.js +2 -3
  410. package/dist/services/index.js.map +1 -1
  411. package/dist/services/plugin-hook-dispatcher.d.ts +11 -0
  412. package/dist/services/plugin-hook-dispatcher.d.ts.map +1 -0
  413. package/dist/services/plugin-hook-dispatcher.js +68 -0
  414. package/dist/services/plugin-hook-dispatcher.js.map +1 -0
  415. package/dist/services/plugin-hook-dispatcher.test.d.ts +2 -0
  416. package/dist/services/plugin-hook-dispatcher.test.d.ts.map +1 -0
  417. package/dist/services/plugin-hook-dispatcher.test.js +93 -0
  418. package/dist/services/plugin-hook-dispatcher.test.js.map +1 -0
  419. package/dist/services/plugin-priority.test.d.ts +2 -0
  420. package/dist/services/plugin-priority.test.d.ts.map +1 -0
  421. package/dist/services/plugin-priority.test.js +119 -0
  422. package/dist/services/plugin-priority.test.js.map +1 -0
  423. package/dist/services/tool-execution-service.d.ts +1 -0
  424. package/dist/services/tool-execution-service.d.ts.map +1 -1
  425. package/dist/services/tool-execution-service.js +89 -46
  426. package/dist/services/tool-execution-service.js.map +1 -1
  427. package/dist/services/tool-execution-service.test.d.ts +2 -0
  428. package/dist/services/tool-execution-service.test.d.ts.map +1 -0
  429. package/dist/services/tool-execution-service.test.js +358 -0
  430. package/dist/services/tool-execution-service.test.js.map +1 -0
  431. package/dist/tool-registry/function-tool.d.ts +54 -0
  432. package/dist/tool-registry/function-tool.d.ts.map +1 -0
  433. package/dist/tool-registry/function-tool.js +190 -0
  434. package/dist/tool-registry/function-tool.js.map +1 -0
  435. package/dist/tool-registry/index.d.ts +3 -0
  436. package/dist/tool-registry/index.d.ts.map +1 -0
  437. package/dist/tool-registry/index.js +3 -0
  438. package/dist/tool-registry/index.js.map +1 -0
  439. package/dist/tool-registry/tool-registry.d.ts +54 -0
  440. package/dist/tool-registry/tool-registry.d.ts.map +1 -0
  441. package/dist/tool-registry/tool-registry.js +148 -0
  442. package/dist/tool-registry/tool-registry.js.map +1 -0
  443. package/dist/utils/errors.d.ts +11 -2
  444. package/dist/utils/errors.d.ts.map +1 -1
  445. package/dist/utils/errors.js +13 -2
  446. package/dist/utils/errors.js.map +1 -1
  447. package/dist/utils/errors.test.d.ts +2 -0
  448. package/dist/utils/errors.test.d.ts.map +1 -0
  449. package/dist/utils/errors.test.js +361 -0
  450. package/dist/utils/errors.test.js.map +1 -0
  451. package/dist/utils/execution-proxy.d.ts +7 -3
  452. package/dist/utils/execution-proxy.d.ts.map +1 -1
  453. package/dist/utils/execution-proxy.js +64 -42
  454. package/dist/utils/execution-proxy.js.map +1 -1
  455. package/dist/utils/execution-proxy.test.d.ts +2 -0
  456. package/dist/utils/execution-proxy.test.d.ts.map +1 -0
  457. package/dist/utils/execution-proxy.test.js +179 -0
  458. package/dist/utils/execution-proxy.test.js.map +1 -0
  459. package/dist/utils/logger.d.ts +3 -3
  460. package/dist/utils/logger.d.ts.map +1 -1
  461. package/dist/utils/logger.js +9 -5
  462. package/dist/utils/logger.js.map +1 -1
  463. package/dist/utils/message-converter.d.ts +1 -4
  464. package/dist/utils/message-converter.d.ts.map +1 -1
  465. package/dist/utils/message-converter.js +13 -12
  466. package/dist/utils/message-converter.js.map +1 -1
  467. package/dist/utils/message-converter.test.d.ts +2 -0
  468. package/dist/utils/message-converter.test.d.ts.map +1 -0
  469. package/dist/utils/message-converter.test.js +164 -0
  470. package/dist/utils/message-converter.test.js.map +1 -0
  471. package/dist/utils/periodic-task.d.ts +1 -1
  472. package/dist/utils/periodic-task.d.ts.map +1 -1
  473. package/dist/utils/periodic-task.js +1 -1
  474. package/dist/utils/periodic-task.js.map +1 -1
  475. package/dist/utils/periodic-task.test.d.ts +2 -0
  476. package/dist/utils/periodic-task.test.d.ts.map +1 -0
  477. package/dist/utils/periodic-task.test.js +87 -0
  478. package/dist/utils/periodic-task.test.js.map +1 -0
  479. package/dist/utils/validation.d.ts.map +1 -1
  480. package/dist/utils/validation.js +17 -11
  481. package/dist/utils/validation.js.map +1 -1
  482. package/dist/utils/validation.test.d.ts +2 -0
  483. package/dist/utils/validation.test.d.ts.map +1 -0
  484. package/dist/utils/validation.test.js +249 -0
  485. package/dist/utils/validation.test.js.map +1 -0
  486. package/package.json +1 -1
@@ -0,0 +1,58 @@
1
+ import type { IAgentConfig, IAssistantMessage } from '../interfaces/agent';
2
+ import type { IToolCall, TUniversalMessage } from '../interfaces/messages';
3
+ import type { ToolExecutionService } from './tool-execution-service';
4
+ import type { ILogger } from '../utils/logger';
5
+ import type { ExecutionEventEmitter } from './execution-event-emitter';
6
+ import type { ExecutionCacheService } from './cache/execution-cache-service';
7
+ import type { ConversationSession } from '../managers/conversation-history-manager';
8
+ import type { TPluginWithHooks } from './plugin-hook-dispatcher';
9
+ import { type IResolvedProviderInfo, type IExecutionRoundState, type IExecutionContext } from './execution-types';
10
+ /** Dependencies required by the round executor */
11
+ export interface IRoundDependencies {
12
+ toolExecutionService: ToolExecutionService;
13
+ plugins: ReadonlyArray<TPluginWithHooks>;
14
+ logger: ILogger;
15
+ eventEmitter: ExecutionEventEmitter;
16
+ cacheService?: ExecutionCacheService;
17
+ }
18
+ /**
19
+ * Compute thinking node ID and previous thinking node ID for the current round
20
+ */
21
+ export declare function computeRoundThinkingContext(conversationId: string, roundState: IExecutionRoundState): {
22
+ thinkingNodeId: string;
23
+ previousThinkingNodeId: string | undefined;
24
+ };
25
+ /**
26
+ * Call the AI provider with optional cache lookup/store
27
+ */
28
+ export declare function callProviderWithCache(conversationMessages: TUniversalMessage[], config: IAgentConfig, resolved: IResolvedProviderInfo, cacheService?: ExecutionCacheService): Promise<TUniversalMessage>;
29
+ /**
30
+ * Validate and normalize the provider response
31
+ */
32
+ export declare function validateAndExtractResponse(response: TUniversalMessage, executionId: string, conversationId: string | undefined, currentRound: number, logger: ILogger): {
33
+ assistantResponse: IAssistantMessage;
34
+ assistantToolCalls: IToolCall[];
35
+ };
36
+ /**
37
+ * Execute tools from assistant tool calls and add results to conversation history
38
+ */
39
+ export declare function executeAndRecordToolCalls(assistantToolCalls: IToolCall[], conversationSession: ConversationSession, conversationId: string, executionId: string, currentRound: number, thinkingNodeId: string, previousThinkingNodeId: string | undefined, roundState: IExecutionRoundState, deps: IRoundDependencies): Promise<void>;
40
+ /**
41
+ * Add tool execution results to conversation history in call order
42
+ */
43
+ export declare function addToolResultsToHistory(assistantToolCalls: IToolCall[], toolSummary: {
44
+ results: Array<{
45
+ executionId?: string;
46
+ toolName?: string;
47
+ success: boolean;
48
+ result?: unknown;
49
+ error?: string;
50
+ }>;
51
+ errors: Error[];
52
+ }, conversationSession: ConversationSession, currentRound: number, logger: ILogger): void;
53
+ /**
54
+ * Execute a single round of the conversation loop.
55
+ * Returns true if the loop should break (no more tool calls).
56
+ */
57
+ export declare function executeRound(roundState: IExecutionRoundState, maxRounds: number, conversationSession: ConversationSession, conversationId: string, executionId: string, fullContext: IExecutionContext, config: IAgentConfig, resolved: IResolvedProviderInfo, deps: IRoundDependencies): Promise<boolean>;
58
+ //# sourceMappingURL=execution-round.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"execution-round.d.ts","sourceRoot":"","sources":["../../src/services/execution-round.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,323 @@
1
+ import { callPluginHook } from './plugin-hook-dispatcher';
2
+ import { bindWithOwnerPath } from '../event-service/index';
3
+ import { getModelContextWindow } from '../context/models';
4
+ import { EXECUTION_EVENTS } from './execution-constants';
5
+ import { isExecutionError, PREVIEW_LENGTH, SHORT_PREVIEW_LENGTH, LAST_MESSAGES_SLICE, } from './execution-types';
6
+ /**
7
+ * Compute thinking node ID and previous thinking node ID for the current round
8
+ */
9
+ export function computeRoundThinkingContext(conversationId, roundState) {
10
+ const shouldChainFromPreviousToolResult = Array.isArray(roundState.lastTrackedAssistantMessage?.toolCalls) &&
11
+ roundState.lastTrackedAssistantMessage.toolCalls.length > 0;
12
+ const thinkingNodeId = `thinking_${conversationId}_round${roundState.runningAssistantCount + 1}`;
13
+ const previousThinkingNodeId = shouldChainFromPreviousToolResult
14
+ ? `thinking_${conversationId}_round${roundState.runningAssistantCount}`
15
+ : undefined;
16
+ return { thinkingNodeId, previousThinkingNodeId };
17
+ }
18
+ /**
19
+ * Call the AI provider with optional cache lookup/store
20
+ */
21
+ export async function callProviderWithCache(conversationMessages, config, resolved, cacheService) {
22
+ if (!config.defaultModel?.model) {
23
+ throw new Error('Model is required in defaultModel configuration. Please specify a model.');
24
+ }
25
+ if (typeof config.defaultModel.model !== 'string' || config.defaultModel.model.trim() === '') {
26
+ throw new Error('Model must be a non-empty string in defaultModel configuration.');
27
+ }
28
+ const chatOptions = {
29
+ model: config.defaultModel.model,
30
+ ...(config.defaultModel.maxTokens !== undefined && {
31
+ maxTokens: config.defaultModel.maxTokens,
32
+ }),
33
+ ...(config.defaultModel.temperature !== undefined && {
34
+ temperature: config.defaultModel.temperature,
35
+ }),
36
+ ...(resolved.availableTools.length > 0 && { tools: resolved.availableTools }),
37
+ };
38
+ if (cacheService) {
39
+ const cachedResponse = cacheService.lookup(conversationMessages, config.defaultModel.model, config.defaultModel.provider, { temperature: config.defaultModel.temperature, maxTokens: config.defaultModel.maxTokens });
40
+ if (cachedResponse) {
41
+ return { role: 'assistant', content: cachedResponse, timestamp: new Date() };
42
+ }
43
+ const response = await resolved.provider.chat(conversationMessages, chatOptions);
44
+ if (typeof response.content === 'string') {
45
+ cacheService.store(conversationMessages, config.defaultModel.model, config.defaultModel.provider, response.content, { temperature: config.defaultModel.temperature, maxTokens: config.defaultModel.maxTokens });
46
+ }
47
+ return response;
48
+ }
49
+ return resolved.provider.chat(conversationMessages, chatOptions);
50
+ }
51
+ /**
52
+ * Validate and normalize the provider response
53
+ */
54
+ export function validateAndExtractResponse(response, executionId, conversationId, currentRound, logger) {
55
+ const assistantToolCallsFromResponse = response.role === 'assistant' ? response.toolCalls : undefined;
56
+ const hasToolCalls = Array.isArray(assistantToolCallsFromResponse) && assistantToolCallsFromResponse.length > 0;
57
+ if (typeof response.content !== 'string' && !hasToolCalls) {
58
+ throw new Error('[EXECUTION] Provider response must have content or tool calls');
59
+ }
60
+ if (assistantToolCallsFromResponse && !Array.isArray(assistantToolCallsFromResponse)) {
61
+ throw new Error('[EXECUTION] assistant toolCalls must be an array');
62
+ }
63
+ const responseContent = response.content ?? '';
64
+ logger.debug(`[ROUND-${currentRound}] Provider response completed`, {
65
+ executionId,
66
+ conversationId,
67
+ round: currentRound,
68
+ responseLength: responseContent.length,
69
+ hasToolCalls: Array.isArray(assistantToolCallsFromResponse) && assistantToolCallsFromResponse.length > 0,
70
+ toolCallsCount: Array.isArray(assistantToolCallsFromResponse)
71
+ ? assistantToolCallsFromResponse.length
72
+ : 0,
73
+ });
74
+ if (response.role !== 'assistant') {
75
+ throw new Error(`Unexpected response role: ${response.role}`);
76
+ }
77
+ const assistantResponse = response;
78
+ const assistantToolCalls = assistantResponse.toolCalls ?? [];
79
+ if (!Array.isArray(assistantToolCalls)) {
80
+ throw new Error('[EXECUTION] assistantResponse.toolCalls must be an array');
81
+ }
82
+ return { assistantResponse, assistantToolCalls };
83
+ }
84
+ /**
85
+ * Execute tools from assistant tool calls and add results to conversation history
86
+ */
87
+ export async function executeAndRecordToolCalls(assistantToolCalls, conversationSession, conversationId, executionId, currentRound, thinkingNodeId, previousThinkingNodeId, roundState, deps) {
88
+ const { toolExecutionService, logger, eventEmitter } = deps;
89
+ logger.debug('Tool calls detected, executing tools', {
90
+ toolCallCount: assistantToolCalls.length,
91
+ round: currentRound,
92
+ toolCalls: assistantToolCalls.map((tc) => ({ id: tc.id, name: tc.function?.name })),
93
+ });
94
+ const toolOwnerPathBase = eventEmitter.buildThinkingOwnerContext(conversationId, executionId, thinkingNodeId, previousThinkingNodeId).ownerPath;
95
+ const expectedCountForBatch = assistantToolCalls.length;
96
+ const batchId = `${thinkingNodeId}`;
97
+ const toolRequestsBase = toolExecutionService.createExecutionRequestsWithContext(assistantToolCalls, {
98
+ ownerPathBase: toolOwnerPathBase,
99
+ metadataFactory: (toolCall) => ({
100
+ conversationId,
101
+ round: currentRound,
102
+ directParentId: thinkingNodeId,
103
+ batchId,
104
+ expectedCount: expectedCountForBatch,
105
+ toolCallId: toolCall.id,
106
+ }),
107
+ });
108
+ const toolRequests = toolRequestsBase.map((request) => {
109
+ if (!request.ownerId) {
110
+ throw new Error('[EXECUTION] Tool request missing ownerId');
111
+ }
112
+ return {
113
+ ...request,
114
+ eventService: eventEmitter.ensureToolEventService(request.ownerId, request.ownerPath),
115
+ baseEventService: eventEmitter.getBaseEventService(),
116
+ };
117
+ });
118
+ const toolContext = {
119
+ requests: toolRequests,
120
+ mode: 'parallel',
121
+ maxConcurrency: 5,
122
+ continueOnError: true,
123
+ };
124
+ const toolSummary = await toolExecutionService.executeTools(toolContext);
125
+ roundState.toolsExecuted.push(...toolSummary.results.map((r) => {
126
+ if (!r.toolName || r.toolName.length === 0) {
127
+ throw new Error('[EXECUTION] Tool result missing toolName');
128
+ }
129
+ return r.toolName;
130
+ }));
131
+ addToolResultsToHistory(assistantToolCalls, toolSummary, conversationSession, currentRound, logger);
132
+ eventEmitter.emitToolResultsEvents(assistantToolCalls, toolSummary, roundState.toolsExecuted, conversationId, executionId, currentRound, thinkingNodeId, previousThinkingNodeId);
133
+ eventEmitter.clearToolEventServices();
134
+ }
135
+ /**
136
+ * Add tool execution results to conversation history in call order
137
+ */
138
+ export function addToolResultsToHistory(assistantToolCalls, toolSummary, conversationSession, currentRound, logger) {
139
+ for (const toolCall of assistantToolCalls) {
140
+ if (!toolCall.id) {
141
+ throw new Error(`Tool call missing ID: ${JSON.stringify(toolCall)}`);
142
+ }
143
+ const toolCallName = toolCall.function?.name;
144
+ if (!toolCallName || toolCallName.length === 0) {
145
+ throw new Error(`[EXECUTION] Tool call "${toolCall.id}" missing function name`);
146
+ }
147
+ const result = toolSummary.results.find((r) => r.executionId === toolCall.id);
148
+ const error = toolSummary.errors.find((e) => isExecutionError(e) && e.executionId === toolCall.id);
149
+ let content;
150
+ let metadata = { round: currentRound };
151
+ if (result && result.success) {
152
+ if (typeof result.result === 'undefined') {
153
+ throw new Error('[EXECUTION] Tool result missing result payload');
154
+ }
155
+ content = typeof result.result === 'string' ? result.result : JSON.stringify(result.result);
156
+ metadata['success'] = true;
157
+ if (result.toolName)
158
+ metadata['toolName'] = result.toolName;
159
+ }
160
+ else if (result && !result.success) {
161
+ if (!result.error || result.error.length === 0) {
162
+ throw new Error('[EXECUTION] Tool result missing error message');
163
+ }
164
+ content = `Error: ${result.error}`;
165
+ metadata['success'] = false;
166
+ metadata['error'] = result.error;
167
+ if (result.toolName)
168
+ metadata['toolName'] = result.toolName;
169
+ }
170
+ else if (error) {
171
+ const execError = error;
172
+ const execMessage = (() => {
173
+ if (execError.error?.message)
174
+ return execError.error.message;
175
+ if (execError.message)
176
+ return execError.message;
177
+ return '';
178
+ })();
179
+ if (!execMessage || execMessage.length === 0) {
180
+ throw new Error('[EXECUTION] Tool execution error missing message');
181
+ }
182
+ content = `Error: ${execMessage}`;
183
+ metadata['success'] = false;
184
+ metadata['error'] = execMessage;
185
+ if (execError.toolName)
186
+ metadata['toolName'] = execError.toolName;
187
+ }
188
+ else {
189
+ throw new Error(`No execution result found for tool call ID: ${toolCall.id}`);
190
+ }
191
+ logger.debug('Adding tool result to conversation', {
192
+ toolCallId: toolCall.id,
193
+ toolName: toolCallName,
194
+ content: content.substring(0, PREVIEW_LENGTH),
195
+ round: currentRound,
196
+ currentHistoryLength: conversationSession.getMessages().length,
197
+ });
198
+ conversationSession.addToolMessageWithId(content, toolCall.id, toolCallName, metadata);
199
+ logger.debug('Tool result added to history', {
200
+ toolCallId: toolCall.id,
201
+ newHistoryLength: conversationSession.getMessages().length,
202
+ round: currentRound,
203
+ });
204
+ }
205
+ }
206
+ /**
207
+ * Execute a single round of the conversation loop.
208
+ * Returns true if the loop should break (no more tool calls).
209
+ */
210
+ export async function executeRound(roundState, maxRounds, conversationSession, conversationId, executionId, fullContext, config, resolved, deps) {
211
+ const { plugins, logger, eventEmitter, cacheService } = deps;
212
+ const currentRound = roundState.currentRound;
213
+ logger.debug(`[ROUND-${currentRound}] Starting execution round ${currentRound}`, {
214
+ executionId,
215
+ conversationId: fullContext.conversationId,
216
+ round: currentRound,
217
+ maxRounds,
218
+ });
219
+ const historyMessages = conversationSession.getMessages();
220
+ if (!Array.isArray(historyMessages)) {
221
+ throw new Error('[EXECUTION] Conversation messages must be an array');
222
+ }
223
+ const { thinkingNodeId, previousThinkingNodeId } = computeRoundThinkingContext(conversationId, roundState);
224
+ const conversationMessages = historyMessages;
225
+ logger.debug('Current conversation messages', {
226
+ round: currentRound,
227
+ messageCount: conversationMessages.length,
228
+ fullHistory: conversationMessages.map((m, index) => ({
229
+ index,
230
+ role: m.role,
231
+ content: m.content?.substring(0, PREVIEW_LENGTH),
232
+ hasToolCalls: 'toolCalls' in m ? !!m.toolCalls?.length : false,
233
+ toolCallId: 'toolCallId' in m ? m.toolCallId : undefined,
234
+ toolCallsCount: 'toolCalls' in m ? m.toolCalls?.length : 0,
235
+ })),
236
+ });
237
+ await callPluginHook(plugins, 'beforeProviderCall', { messages: conversationMessages }, logger);
238
+ logger.debug('Sending messages to AI provider', {
239
+ round: currentRound,
240
+ messageCount: conversationMessages.length,
241
+ lastFewMessages: conversationMessages.slice(LAST_MESSAGES_SLICE).map((m) => ({
242
+ role: m.role,
243
+ content: m.content?.substring(0, SHORT_PREVIEW_LENGTH),
244
+ hasToolCalls: 'toolCalls' in m ? !!m.toolCalls?.length : false,
245
+ toolCallId: 'toolCallId' in m ? m.toolCallId : undefined,
246
+ })),
247
+ });
248
+ eventEmitter.emitWithContext(EXECUTION_EVENTS.ASSISTANT_MESSAGE_START, {
249
+ parameters: { round: currentRound, messageCount: conversationMessages.length },
250
+ metadata: { round: currentRound, thinkingNodeId },
251
+ }, () => eventEmitter.buildThinkingOwnerContext(conversationId, executionId, thinkingNodeId, previousThinkingNodeId), (ctx) => {
252
+ if (!ctx.ownerType || !ctx.ownerId) {
253
+ throw new Error('[EXECUTION] Missing owner context for thinking event');
254
+ }
255
+ return bindWithOwnerPath(eventEmitter.getBaseEventService(), {
256
+ ownerType: ctx.ownerType,
257
+ ownerId: ctx.ownerId,
258
+ ownerPath: ctx.ownerPath,
259
+ });
260
+ });
261
+ // Pre-send context check: use API-reported token count when available,
262
+ // fall back to chars/3 estimation for the first round.
263
+ // Threshold at 83.5% matching Claude Code's approach (accurate tokens assumed).
264
+ // NOTE: When parallel tool execution is implemented, this check must account for
265
+ // partial results — only count completed tool results, not pending ones.
266
+ const CHARS_PER_TOKEN = 3;
267
+ const CONTEXT_OVERFLOW_THRESHOLD = 0.835;
268
+ const estimatedTokens = roundState.cumulativeInputTokens > 0
269
+ ? roundState.cumulativeInputTokens
270
+ : Math.ceil(JSON.stringify(conversationMessages).length / CHARS_PER_TOKEN);
271
+ const contextLimit = getModelContextWindow(config.defaultModel.model);
272
+ if (estimatedTokens > contextLimit * CONTEXT_OVERFLOW_THRESHOLD) {
273
+ logger.warn('[ROUND] Context overflow prevention — tokens exceed 83.5% of context window', {
274
+ estimatedTokens,
275
+ contextLimit,
276
+ round: currentRound,
277
+ });
278
+ return true; // Break the execution loop
279
+ }
280
+ // Emit round separator for streaming UI — when round > 1, text from previous
281
+ // round and this round would otherwise concatenate without any line break.
282
+ if (currentRound > 1 && 'onTextDelta' in resolved.provider) {
283
+ const cb = resolved.provider.onTextDelta;
284
+ if (cb)
285
+ cb('\n\n');
286
+ }
287
+ const response = await callProviderWithCache(conversationMessages, config, resolved, cacheService);
288
+ const { assistantResponse, assistantToolCalls } = validateAndExtractResponse(response, executionId, fullContext.conversationId, currentRound, logger);
289
+ await callPluginHook(plugins, 'afterProviderCall', {
290
+ messages: conversationMessages,
291
+ responseMessage: response,
292
+ }, logger);
293
+ const inputTokens = typeof assistantResponse.metadata?.['inputTokens'] === 'number'
294
+ ? assistantResponse.metadata['inputTokens']
295
+ : 0;
296
+ const outputTokens = typeof assistantResponse.metadata?.['outputTokens'] === 'number'
297
+ ? assistantResponse.metadata['outputTokens']
298
+ : 0;
299
+ // Accumulate authoritative token count from API response
300
+ if (inputTokens > 0) {
301
+ roundState.cumulativeInputTokens = inputTokens; // input_tokens already includes full context
302
+ }
303
+ conversationSession.addAssistantMessage(assistantResponse.content ?? '', assistantToolCalls, {
304
+ round: currentRound,
305
+ ...(inputTokens > 0 && { inputTokens }),
306
+ ...(outputTokens > 0 && { outputTokens }),
307
+ // Preserve usage.totalTokens for execution-service token accounting
308
+ ...((inputTokens > 0 || outputTokens > 0) && {
309
+ usage: { totalTokens: inputTokens + outputTokens, inputTokens, outputTokens },
310
+ }),
311
+ });
312
+ roundState.runningAssistantCount++;
313
+ roundState.lastTrackedAssistantMessage = assistantResponse;
314
+ if (assistantToolCalls.length === 0) {
315
+ logger.debug(`[AGENT-FLOW-CONTROL] Round ${currentRound} completed - no tool calls, execution finished for agent ${fullContext.conversationId}`);
316
+ eventEmitter.emitAssistantMessageComplete(assistantResponse, executionId, currentRound, conversationId, thinkingNodeId, previousThinkingNodeId);
317
+ return true;
318
+ }
319
+ await executeAndRecordToolCalls(assistantToolCalls, conversationSession, conversationId, executionId, currentRound, thinkingNodeId, previousThinkingNodeId, roundState, deps);
320
+ logger.debug(`Round ${currentRound} completed - continuing to next round for agent ${fullContext.conversationId}`);
321
+ return false;
322
+ }
323
+ //# sourceMappingURL=execution-round.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"execution-round.js","sourceRoot":"","sources":["../../src/services/execution-round.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=execution-round.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"execution-round.test.d.ts","sourceRoot":"","sources":["../../src/services/execution-round.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,188 @@
1
+ import { describe, it, expect } from 'vitest';
2
+ import { computeRoundThinkingContext, validateAndExtractResponse, callProviderWithCache, addToolResultsToHistory, } from './execution-round';
3
+ import { vi } from 'vitest';
4
+ function mockLogger() {
5
+ return { debug: vi.fn(), info: vi.fn(), warn: vi.fn(), error: vi.fn(), log: vi.fn() };
6
+ }
7
+ function createResolvedProviderInfo(overrides = {}) {
8
+ return {
9
+ provider: { chat: vi.fn() },
10
+ currentInfo: { provider: 'openai' },
11
+ aiProviderInfo: {
12
+ providerName: 'openai',
13
+ model: 'gpt-4',
14
+ temperature: undefined,
15
+ maxTokens: undefined,
16
+ },
17
+ toolsInfo: [],
18
+ availableTools: [],
19
+ ...overrides,
20
+ };
21
+ }
22
+ describe('execution-round helpers', () => {
23
+ describe('computeRoundThinkingContext', () => {
24
+ it('generates thinkingNodeId based on conversationId and count', () => {
25
+ const result = computeRoundThinkingContext('conv-1', {
26
+ currentRound: 1,
27
+ runningAssistantCount: 0,
28
+ toolsExecuted: [],
29
+ lastTrackedAssistantMessage: undefined,
30
+ });
31
+ expect(result.thinkingNodeId).toBe('thinking_conv-1_round1');
32
+ expect(result.previousThinkingNodeId).toBeUndefined();
33
+ });
34
+ it('chains from previous tool result when assistant had tool calls', () => {
35
+ const result = computeRoundThinkingContext('conv-1', {
36
+ currentRound: 2,
37
+ runningAssistantCount: 1,
38
+ toolsExecuted: ['search'],
39
+ lastTrackedAssistantMessage: {
40
+ role: 'assistant',
41
+ content: '',
42
+ timestamp: new Date(),
43
+ toolCalls: [
44
+ { id: 'tc-1', type: 'function', function: { name: 'search', arguments: '{}' } },
45
+ ],
46
+ },
47
+ });
48
+ expect(result.thinkingNodeId).toBe('thinking_conv-1_round2');
49
+ expect(result.previousThinkingNodeId).toBe('thinking_conv-1_round1');
50
+ });
51
+ });
52
+ describe('validateAndExtractResponse', () => {
53
+ const logger = mockLogger();
54
+ it('extracts assistant response with content', () => {
55
+ const response = {
56
+ role: 'assistant',
57
+ content: 'hello',
58
+ timestamp: new Date(),
59
+ };
60
+ const result = validateAndExtractResponse(response, 'exec-1', 'conv-1', 1, logger);
61
+ expect(result.assistantResponse.content).toBe('hello');
62
+ expect(result.assistantToolCalls).toEqual([]);
63
+ });
64
+ it('extracts tool calls from response', () => {
65
+ const toolCalls = [
66
+ { id: 'tc-1', type: 'function', function: { name: 'fn', arguments: '{}' } },
67
+ ];
68
+ const response = {
69
+ role: 'assistant',
70
+ content: null,
71
+ timestamp: new Date(),
72
+ toolCalls,
73
+ };
74
+ const result = validateAndExtractResponse(response, 'exec-1', 'conv-1', 1, logger);
75
+ expect(result.assistantToolCalls).toHaveLength(1);
76
+ });
77
+ it('throws for non-assistant response', () => {
78
+ const response = {
79
+ role: 'user',
80
+ content: 'hello',
81
+ timestamp: new Date(),
82
+ };
83
+ expect(() => validateAndExtractResponse(response, 'exec-1', 'conv-1', 1, logger)).toThrow('Unexpected response role: user');
84
+ });
85
+ it('throws when response has no content and no tool calls', () => {
86
+ const response = {
87
+ role: 'assistant',
88
+ content: undefined,
89
+ timestamp: new Date(),
90
+ };
91
+ expect(() => validateAndExtractResponse(response, 'exec-1', 'conv-1', 1, logger)).toThrow('Provider response must have content or tool calls');
92
+ });
93
+ });
94
+ describe('callProviderWithCache', () => {
95
+ it('throws when model is empty string', async () => {
96
+ const config = { name: 'test', defaultModel: { provider: 'openai', model: '' } };
97
+ const resolved = createResolvedProviderInfo();
98
+ // Empty string is falsy, hits the first guard
99
+ await expect(callProviderWithCache([], config, resolved)).rejects.toThrow('Model is required');
100
+ });
101
+ it('throws when model is whitespace only', async () => {
102
+ const config = { name: 'test', defaultModel: { provider: 'openai', model: ' ' } };
103
+ const resolved = createResolvedProviderInfo();
104
+ await expect(callProviderWithCache([], config, resolved)).rejects.toThrow('Model must be a non-empty string');
105
+ });
106
+ it('throws when model is missing', async () => {
107
+ const config = { name: 'test', defaultModel: { provider: 'openai' } };
108
+ const resolved = createResolvedProviderInfo();
109
+ await expect(callProviderWithCache([], config, resolved)).rejects.toThrow('Model is required');
110
+ });
111
+ it('calls provider without cache', async () => {
112
+ const mockResponse = { role: 'assistant', content: 'hi', timestamp: new Date() };
113
+ const resolved = createResolvedProviderInfo({
114
+ provider: { chat: vi.fn().mockResolvedValue(mockResponse) },
115
+ });
116
+ const config = { name: 'test', defaultModel: { provider: 'openai', model: 'gpt-4' } };
117
+ const result = await callProviderWithCache([{ role: 'user', content: 'hello', timestamp: new Date() }], config, resolved);
118
+ expect(result).toBe(mockResponse);
119
+ expect(resolved.provider.chat).toHaveBeenCalled();
120
+ });
121
+ it('uses cached response when available', async () => {
122
+ const config = { name: 'test', defaultModel: { provider: 'openai', model: 'gpt-4' } };
123
+ const resolved = createResolvedProviderInfo();
124
+ const cacheService = {
125
+ lookup: vi.fn().mockReturnValue('cached response'),
126
+ store: vi.fn(),
127
+ };
128
+ const result = await callProviderWithCache([], config, resolved, cacheService);
129
+ expect(result.content).toBe('cached response');
130
+ expect(resolved.provider.chat).not.toHaveBeenCalled();
131
+ });
132
+ it('stores response in cache on miss', async () => {
133
+ const mockResponse = { role: 'assistant', content: 'fresh', timestamp: new Date() };
134
+ const config = { name: 'test', defaultModel: { provider: 'openai', model: 'gpt-4' } };
135
+ const resolved = createResolvedProviderInfo({
136
+ provider: { chat: vi.fn().mockResolvedValue(mockResponse) },
137
+ });
138
+ const cacheService = {
139
+ lookup: vi.fn().mockReturnValue(undefined),
140
+ store: vi.fn(),
141
+ };
142
+ await callProviderWithCache([], config, resolved, cacheService);
143
+ expect(cacheService.store).toHaveBeenCalled();
144
+ });
145
+ });
146
+ describe('addToolResultsToHistory', () => {
147
+ const logger = mockLogger();
148
+ it('adds successful tool results to session', () => {
149
+ const toolCalls = [
150
+ { id: 'tc-1', type: 'function', function: { name: 'search', arguments: '{}' } },
151
+ ];
152
+ const toolSummary = {
153
+ results: [{ executionId: 'tc-1', toolName: 'search', success: true, result: 'found it' }],
154
+ errors: [],
155
+ };
156
+ const session = { getMessages: () => [], addToolMessageWithId: vi.fn() };
157
+ addToolResultsToHistory(toolCalls, toolSummary, session, 1, logger);
158
+ expect(session.addToolMessageWithId).toHaveBeenCalledWith('found it', 'tc-1', 'search', expect.objectContaining({ success: true }));
159
+ });
160
+ it('adds failed tool results to session', () => {
161
+ const toolCalls = [
162
+ { id: 'tc-1', type: 'function', function: { name: 'search', arguments: '{}' } },
163
+ ];
164
+ const toolSummary = {
165
+ results: [{ executionId: 'tc-1', toolName: 'search', success: false, error: 'not found' }],
166
+ errors: [],
167
+ };
168
+ const session = { getMessages: () => [], addToolMessageWithId: vi.fn() };
169
+ addToolResultsToHistory(toolCalls, toolSummary, session, 1, logger);
170
+ expect(session.addToolMessageWithId).toHaveBeenCalledWith('Error: not found', 'tc-1', 'search', expect.objectContaining({ success: false }));
171
+ });
172
+ it('throws when tool call has no ID', () => {
173
+ const toolCalls = [
174
+ { type: 'function', function: { name: 'search', arguments: '{}' } },
175
+ ];
176
+ const session = { getMessages: () => [], addToolMessageWithId: vi.fn() };
177
+ expect(() => addToolResultsToHistory(toolCalls, { results: [], errors: [] }, session, 1, logger)).toThrow('Tool call missing ID');
178
+ });
179
+ it('throws when no result found for tool call', () => {
180
+ const toolCalls = [
181
+ { id: 'tc-1', type: 'function', function: { name: 'search', arguments: '{}' } },
182
+ ];
183
+ const session = { getMessages: () => [], addToolMessageWithId: vi.fn() };
184
+ expect(() => addToolResultsToHistory(toolCalls, { results: [], errors: [] }, session, 1, logger)).toThrow('No execution result found for tool call ID: tc-1');
185
+ });
186
+ });
187
+ });
188
+ //# sourceMappingURL=execution-round.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"execution-round.test.js","sourceRoot":"","sources":["../../src/services/execution-round.test.ts"],"names":[],"mappings":"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"}