@downcity/agent 1.1.74 → 1.1.81

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 (514) hide show
  1. package/README.md +15 -18
  2. package/bin/agent/local/Agent.d.ts +82 -0
  3. package/bin/agent/local/Agent.d.ts.map +1 -0
  4. package/bin/agent/local/Agent.js +154 -0
  5. package/bin/agent/local/Agent.js.map +1 -0
  6. package/bin/agent/local/AgentInstructions.d.ts +22 -0
  7. package/bin/agent/local/AgentInstructions.d.ts.map +1 -0
  8. package/bin/agent/local/AgentInstructions.js +57 -0
  9. package/bin/agent/local/AgentInstructions.js.map +1 -0
  10. package/bin/agent/local/AgentPluginFactory.d.ts +29 -0
  11. package/bin/agent/local/AgentPluginFactory.d.ts.map +1 -0
  12. package/bin/agent/local/AgentPluginFactory.js +53 -0
  13. package/bin/agent/local/AgentPluginFactory.js.map +1 -0
  14. package/bin/{runtime/host/AgentHostRuntime.d.ts → agent/local/AgentRuntimeAssembly.d.ts} +2 -2
  15. package/bin/agent/local/AgentRuntimeAssembly.d.ts.map +1 -0
  16. package/bin/{runtime/host/AgentHostRuntime.js → agent/local/AgentRuntimeAssembly.js} +2 -2
  17. package/bin/agent/local/AgentRuntimeAssembly.js.map +1 -0
  18. package/bin/agent/local/AgentRuntimeFactory.d.ts +72 -0
  19. package/bin/agent/local/AgentRuntimeFactory.d.ts.map +1 -0
  20. package/bin/agent/local/AgentRuntimeFactory.js +73 -0
  21. package/bin/agent/local/AgentRuntimeFactory.js.map +1 -0
  22. package/bin/{runtime/host → agent/local}/ProjectSetup.d.ts +1 -1
  23. package/bin/agent/local/ProjectSetup.d.ts.map +1 -0
  24. package/bin/{runtime/host → agent/local}/ProjectSetup.js +1 -1
  25. package/bin/agent/local/ProjectSetup.js.map +1 -0
  26. package/bin/agent/local/services/AgentAssemblyService.d.ts +112 -0
  27. package/bin/agent/local/services/AgentAssemblyService.d.ts.map +1 -0
  28. package/bin/agent/local/services/AgentAssemblyService.js +135 -0
  29. package/bin/agent/local/services/AgentAssemblyService.js.map +1 -0
  30. package/bin/agent/local/services/AgentLifecycleService.d.ts +59 -0
  31. package/bin/agent/local/services/AgentLifecycleService.d.ts.map +1 -0
  32. package/bin/agent/local/services/AgentLifecycleService.js +136 -0
  33. package/bin/agent/local/services/AgentLifecycleService.js.map +1 -0
  34. package/bin/agent/local/services/AgentSessionManager.d.ts +106 -0
  35. package/bin/agent/local/services/AgentSessionManager.d.ts.map +1 -0
  36. package/bin/agent/local/services/AgentSessionManager.js +182 -0
  37. package/bin/agent/local/services/AgentSessionManager.js.map +1 -0
  38. package/bin/agent/{RemoteAgent.d.ts → remote/RemoteAgent.d.ts} +3 -3
  39. package/bin/agent/remote/RemoteAgent.d.ts.map +1 -0
  40. package/bin/agent/remote/RemoteAgent.js +58 -0
  41. package/bin/agent/remote/RemoteAgent.js.map +1 -0
  42. package/bin/agent/remote/RemoteSession.d.ts +62 -0
  43. package/bin/agent/remote/RemoteSession.d.ts.map +1 -0
  44. package/bin/agent/remote/RemoteSession.js +225 -0
  45. package/bin/agent/remote/RemoteSession.js.map +1 -0
  46. package/bin/agent/remote/RemoteTransport.d.ts +52 -0
  47. package/bin/agent/remote/RemoteTransport.d.ts.map +1 -0
  48. package/bin/agent/remote/RemoteTransport.js +9 -0
  49. package/bin/agent/remote/RemoteTransport.js.map +1 -0
  50. package/bin/agent/remote/TransportFactory.d.ts +13 -0
  51. package/bin/agent/remote/TransportFactory.d.ts.map +1 -0
  52. package/bin/agent/remote/TransportFactory.js +22 -0
  53. package/bin/agent/remote/TransportFactory.js.map +1 -0
  54. package/bin/agent/remote/transports/HttpRemoteAgentTransport.d.ts +35 -0
  55. package/bin/agent/remote/transports/HttpRemoteAgentTransport.d.ts.map +1 -0
  56. package/bin/agent/remote/transports/HttpRemoteAgentTransport.js +259 -0
  57. package/bin/agent/remote/transports/HttpRemoteAgentTransport.js.map +1 -0
  58. package/bin/agent/remote/transports/RpcRemoteAgentTransport.d.ts +34 -0
  59. package/bin/agent/remote/transports/RpcRemoteAgentTransport.d.ts.map +1 -0
  60. package/bin/agent/remote/transports/RpcRemoteAgentTransport.js +66 -0
  61. package/bin/agent/remote/transports/RpcRemoteAgentTransport.js.map +1 -0
  62. package/bin/executor/Executor.d.ts +7 -20
  63. package/bin/executor/Executor.d.ts.map +1 -1
  64. package/bin/executor/Executor.js +77 -348
  65. package/bin/executor/Executor.js.map +1 -1
  66. package/bin/executor/SessionRunScope.d.ts +18 -34
  67. package/bin/executor/SessionRunScope.d.ts.map +1 -1
  68. package/bin/executor/SessionRunScope.js +42 -28
  69. package/bin/executor/SessionRunScope.js.map +1 -1
  70. package/bin/executor/composer/context/LocalSessionContextComposer.d.ts +5 -3
  71. package/bin/executor/composer/context/LocalSessionContextComposer.d.ts.map +1 -1
  72. package/bin/executor/composer/context/LocalSessionContextComposer.js +11 -18
  73. package/bin/executor/composer/context/LocalSessionContextComposer.js.map +1 -1
  74. package/bin/executor/composer/context/SessionContextComposer.d.ts +8 -3
  75. package/bin/executor/composer/context/SessionContextComposer.d.ts.map +1 -1
  76. package/bin/executor/composer/history/SessionHistoryWriter.js +2 -2
  77. package/bin/executor/composer/history/SessionHistoryWriter.js.map +1 -1
  78. package/bin/executor/composer/system/SessionSystemComposer.d.ts +2 -1
  79. package/bin/executor/composer/system/SessionSystemComposer.d.ts.map +1 -1
  80. package/bin/executor/composer/system/default/DefaultSessionSystemComposer.d.ts +2 -1
  81. package/bin/executor/composer/system/default/DefaultSessionSystemComposer.d.ts.map +1 -1
  82. package/bin/executor/composer/system/default/DefaultSessionSystemComposer.js +2 -4
  83. package/bin/executor/composer/system/default/DefaultSessionSystemComposer.js.map +1 -1
  84. package/bin/executor/core-engine/CoreEngineRunner.d.ts +62 -0
  85. package/bin/executor/core-engine/CoreEngineRunner.d.ts.map +1 -0
  86. package/bin/executor/core-engine/CoreEngineRunner.js +309 -0
  87. package/bin/executor/core-engine/CoreEngineRunner.js.map +1 -0
  88. package/bin/executor/core-engine/CoreEngineUiStreamCollector.d.ts +5 -0
  89. package/bin/executor/core-engine/CoreEngineUiStreamCollector.d.ts.map +1 -1
  90. package/bin/executor/core-engine/CoreEngineUiStreamCollector.js +2 -4
  91. package/bin/executor/core-engine/CoreEngineUiStreamCollector.js.map +1 -1
  92. package/bin/executor/messages/AssistantResultPersistence.d.ts +3 -3
  93. package/bin/executor/messages/AssistantResultPersistence.d.ts.map +1 -1
  94. package/bin/executor/messages/AssistantResultPersistence.js +2 -6
  95. package/bin/executor/messages/AssistantResultPersistence.js.map +1 -1
  96. package/bin/executor/messages/SessionStepEventMapper.d.ts +7 -8
  97. package/bin/executor/messages/SessionStepEventMapper.d.ts.map +1 -1
  98. package/bin/executor/messages/SessionStepEventMapper.js +55 -86
  99. package/bin/executor/messages/SessionStepEventMapper.js.map +1 -1
  100. package/bin/executor/messages/UserVisibleText.d.ts +2 -10
  101. package/bin/executor/messages/UserVisibleText.d.ts.map +1 -1
  102. package/bin/executor/messages/UserVisibleText.js +3 -16
  103. package/bin/executor/messages/UserVisibleText.js.map +1 -1
  104. package/bin/executor/services/ExecutorInflightService.d.ts +39 -0
  105. package/bin/executor/services/ExecutorInflightService.d.ts.map +1 -0
  106. package/bin/executor/services/ExecutorInflightService.js +75 -0
  107. package/bin/executor/services/ExecutorInflightService.js.map +1 -0
  108. package/bin/executor/services/ExecutorRecoveryPolicy.d.ts +103 -0
  109. package/bin/executor/services/ExecutorRecoveryPolicy.d.ts.map +1 -0
  110. package/bin/executor/services/ExecutorRecoveryPolicy.js +87 -0
  111. package/bin/executor/services/ExecutorRecoveryPolicy.js.map +1 -0
  112. package/bin/executor/store/history/SessionHistoryStore.d.ts +12 -0
  113. package/bin/executor/store/history/SessionHistoryStore.d.ts.map +1 -1
  114. package/bin/executor/store/history/jsonl/JsonlSessionHistoryStore.d.ts +12 -0
  115. package/bin/executor/store/history/jsonl/JsonlSessionHistoryStore.d.ts.map +1 -1
  116. package/bin/executor/store/history/jsonl/JsonlSessionHistoryStore.js +145 -8
  117. package/bin/executor/store/history/jsonl/JsonlSessionHistoryStore.js.map +1 -1
  118. package/bin/executor/tools/plugin/PluginToolBridge.d.ts +19 -0
  119. package/bin/executor/tools/plugin/PluginToolBridge.d.ts.map +1 -0
  120. package/bin/executor/tools/plugin/PluginToolBridge.js +143 -0
  121. package/bin/executor/tools/plugin/PluginToolBridge.js.map +1 -0
  122. package/bin/executor/tools/plugin/PluginToolDefinition.d.ts +32 -0
  123. package/bin/executor/tools/plugin/PluginToolDefinition.d.ts.map +1 -0
  124. package/bin/executor/tools/plugin/PluginToolDefinition.js +27 -0
  125. package/bin/executor/tools/plugin/PluginToolDefinition.js.map +1 -0
  126. package/bin/executor/tools/plugin/PluginToolSchemas.d.ts +14 -0
  127. package/bin/executor/tools/plugin/PluginToolSchemas.d.ts.map +1 -0
  128. package/bin/executor/tools/plugin/PluginToolSchemas.js +19 -0
  129. package/bin/executor/tools/plugin/PluginToolSchemas.js.map +1 -0
  130. package/bin/executor/tools/plugin/types/PluginTool.d.ts +39 -0
  131. package/bin/executor/tools/plugin/types/PluginTool.d.ts.map +1 -0
  132. package/bin/executor/tools/plugin/types/PluginTool.js +9 -0
  133. package/bin/executor/tools/plugin/types/PluginTool.js.map +1 -0
  134. package/bin/executor/tools/shell/ShellToolBridge.js +3 -3
  135. package/bin/executor/tools/shell/ShellToolBridge.js.map +1 -1
  136. package/bin/executor/tools/shell/ShellToolFormatting.d.ts +1 -10
  137. package/bin/executor/tools/shell/ShellToolFormatting.d.ts.map +1 -1
  138. package/bin/executor/tools/shell/ShellToolFormatting.js +1 -39
  139. package/bin/executor/tools/shell/ShellToolFormatting.js.map +1 -1
  140. package/bin/executor/types/SessionHistoryPaths.d.ts +4 -0
  141. package/bin/executor/types/SessionHistoryPaths.d.ts.map +1 -1
  142. package/bin/executor/types/SessionRun.d.ts +18 -0
  143. package/bin/executor/types/SessionRun.d.ts.map +1 -1
  144. package/bin/index.d.ts +15 -6
  145. package/bin/index.d.ts.map +1 -1
  146. package/bin/index.js +6 -3
  147. package/bin/index.js.map +1 -1
  148. package/bin/plugin/core/BasePlugin.d.ts +2 -2
  149. package/bin/plugin/core/BasePlugin.d.ts.map +1 -1
  150. package/bin/plugin/core/BasePlugin.js.map +1 -1
  151. package/bin/plugin/core/ImagePlugin.d.ts +56 -0
  152. package/bin/plugin/core/ImagePlugin.d.ts.map +1 -0
  153. package/bin/plugin/core/ImagePlugin.js +109 -0
  154. package/bin/plugin/core/ImagePlugin.js.map +1 -0
  155. package/bin/plugin/core/PluginCommandRequest.d.ts +1 -1
  156. package/bin/plugin/core/PluginCommandRequest.js +1 -1
  157. package/bin/plugin/core/PluginLocalExecution.js +1 -1
  158. package/bin/plugin/core/PluginLocalExecution.js.map +1 -1
  159. package/bin/plugin/core/ProjectConfigStore.d.ts +3 -2
  160. package/bin/plugin/core/ProjectConfigStore.d.ts.map +1 -1
  161. package/bin/plugin/core/ProjectConfigStore.js +3 -4
  162. package/bin/plugin/core/ProjectConfigStore.js.map +1 -1
  163. package/bin/plugin/types/Plugin.d.ts +10 -842
  164. package/bin/plugin/types/Plugin.d.ts.map +1 -1
  165. package/bin/plugin/types/Plugin.js +3 -4
  166. package/bin/plugin/types/Plugin.js.map +1 -1
  167. package/bin/plugin/types/PluginState.d.ts +1 -1
  168. package/bin/plugin/types/PluginState.d.ts.map +1 -1
  169. package/bin/rpc/Client.d.ts +2 -99
  170. package/bin/rpc/Client.d.ts.map +1 -1
  171. package/bin/rpc/Client.js +0 -46
  172. package/bin/rpc/Client.js.map +1 -1
  173. package/bin/rpc/Server.d.ts +5 -21
  174. package/bin/rpc/Server.d.ts.map +1 -1
  175. package/bin/rpc/Server.js +30 -315
  176. package/bin/rpc/Server.js.map +1 -1
  177. package/bin/rpc/server/InternalHandlers.d.ts +21 -0
  178. package/bin/rpc/server/InternalHandlers.d.ts.map +1 -0
  179. package/bin/rpc/server/InternalHandlers.js +190 -0
  180. package/bin/rpc/server/InternalHandlers.js.map +1 -0
  181. package/bin/rpc/server/RequestDispatcher.d.ts +27 -0
  182. package/bin/rpc/server/RequestDispatcher.d.ts.map +1 -0
  183. package/bin/rpc/server/RequestDispatcher.js +38 -0
  184. package/bin/rpc/server/RequestDispatcher.js.map +1 -0
  185. package/bin/rpc/server/SdkSessionHandlers.d.ts +25 -0
  186. package/bin/rpc/server/SdkSessionHandlers.d.ts.map +1 -0
  187. package/bin/rpc/server/SdkSessionHandlers.js +86 -0
  188. package/bin/rpc/server/SdkSessionHandlers.js.map +1 -0
  189. package/bin/rpc/server/ServerTypes.d.ts +59 -0
  190. package/bin/rpc/server/ServerTypes.d.ts.map +1 -0
  191. package/bin/rpc/server/ServerTypes.js +9 -0
  192. package/bin/rpc/server/ServerTypes.js.map +1 -0
  193. package/bin/{runtime/sandbox → sandbox}/MacOsSeatbeltSandbox.d.ts +1 -1
  194. package/bin/sandbox/MacOsSeatbeltSandbox.d.ts.map +1 -0
  195. package/bin/sandbox/MacOsSeatbeltSandbox.js.map +1 -0
  196. package/bin/{runtime/sandbox → sandbox}/SandboxConfigResolver.d.ts +2 -2
  197. package/bin/sandbox/SandboxConfigResolver.d.ts.map +1 -0
  198. package/bin/sandbox/SandboxConfigResolver.js.map +1 -0
  199. package/bin/{runtime/sandbox → sandbox}/SandboxRunner.d.ts +2 -2
  200. package/bin/sandbox/SandboxRunner.d.ts.map +1 -0
  201. package/bin/{runtime/sandbox → sandbox}/SandboxRunner.js +2 -2
  202. package/bin/sandbox/SandboxRunner.js.map +1 -0
  203. package/bin/sandbox/types/Sandbox.d.ts.map +1 -0
  204. package/bin/sandbox/types/Sandbox.js.map +1 -0
  205. package/bin/{runtime/sandbox → sandbox}/types/SandboxRuntime.d.ts +2 -2
  206. package/bin/sandbox/types/SandboxRuntime.d.ts.map +1 -0
  207. package/bin/sandbox/types/SandboxRuntime.js.map +1 -0
  208. package/bin/session/Session.d.ts +14 -83
  209. package/bin/session/Session.d.ts.map +1 -1
  210. package/bin/session/Session.js +140 -362
  211. package/bin/session/Session.js.map +1 -1
  212. package/bin/session/SessionSystemBuilder.d.ts +2 -1
  213. package/bin/session/SessionSystemBuilder.d.ts.map +1 -1
  214. package/bin/session/SessionSystemBuilder.js +2 -3
  215. package/bin/session/SessionSystemBuilder.js.map +1 -1
  216. package/bin/session/browse/Browse.d.ts +1 -1
  217. package/bin/session/browse/Browse.d.ts.map +1 -1
  218. package/bin/session/browse/Browse.js +28 -13
  219. package/bin/session/browse/Browse.js.map +1 -1
  220. package/bin/session/index.d.ts +1 -1
  221. package/bin/session/index.d.ts.map +1 -1
  222. package/bin/session/index.js +1 -1
  223. package/bin/session/index.js.map +1 -1
  224. package/bin/session/services/SessionStateService.d.ts +132 -0
  225. package/bin/session/services/SessionStateService.d.ts.map +1 -0
  226. package/bin/session/services/SessionStateService.js +242 -0
  227. package/bin/session/services/SessionStateService.js.map +1 -0
  228. package/bin/session/services/SessionTurnService.d.ts +66 -0
  229. package/bin/session/services/SessionTurnService.d.ts.map +1 -0
  230. package/bin/session/services/SessionTurnService.js +137 -0
  231. package/bin/session/services/SessionTurnService.js.map +1 -0
  232. package/bin/session/services/SessionViewService.d.ts +105 -0
  233. package/bin/session/services/SessionViewService.d.ts.map +1 -0
  234. package/bin/session/services/SessionViewService.js +184 -0
  235. package/bin/session/services/SessionViewService.js.map +1 -0
  236. package/bin/session/storage/Paths.d.ts +9 -0
  237. package/bin/session/storage/Paths.d.ts.map +1 -1
  238. package/bin/session/storage/Paths.js +11 -0
  239. package/bin/session/storage/Paths.js.map +1 -1
  240. package/bin/types/agent/AgentOptions.d.ts +152 -0
  241. package/bin/types/agent/AgentOptions.d.ts.map +1 -0
  242. package/bin/types/agent/AgentOptions.js +9 -0
  243. package/bin/types/agent/AgentOptions.js.map +1 -0
  244. package/bin/types/{runtime/host/AgentHost.d.ts → agent/AgentRuntimeAssembly.d.ts} +4 -4
  245. package/bin/types/agent/AgentRuntimeAssembly.d.ts.map +1 -0
  246. package/bin/types/{runtime/host/AgentHost.js → agent/AgentRuntimeAssembly.js} +3 -3
  247. package/bin/types/agent/AgentRuntimeAssembly.js.map +1 -0
  248. package/bin/types/agent/AgentTypes.d.ts +10 -613
  249. package/bin/types/agent/AgentTypes.d.ts.map +1 -1
  250. package/bin/types/agent/AgentTypes.js +4 -4
  251. package/bin/types/agent/RemoteAgentOptions.d.ts +28 -0
  252. package/bin/types/agent/RemoteAgentOptions.d.ts.map +1 -0
  253. package/bin/types/agent/RemoteAgentOptions.js +9 -0
  254. package/bin/types/agent/RemoteAgentOptions.js.map +1 -0
  255. package/bin/types/agent/SessionActor.d.ts +60 -0
  256. package/bin/types/agent/SessionActor.d.ts.map +1 -0
  257. package/bin/types/agent/SessionActor.js +9 -0
  258. package/bin/types/agent/SessionActor.js.map +1 -0
  259. package/bin/types/agent/SessionTypes.d.ts +312 -0
  260. package/bin/types/agent/SessionTypes.d.ts.map +1 -0
  261. package/bin/types/agent/SessionTypes.js +9 -0
  262. package/bin/types/agent/SessionTypes.js.map +1 -0
  263. package/bin/types/config/DowncityConfig.d.ts +1 -1
  264. package/bin/types/config/DowncityConfig.d.ts.map +1 -1
  265. package/bin/types/executor/SessionRunContext.d.ts +66 -0
  266. package/bin/types/executor/SessionRunContext.d.ts.map +1 -0
  267. package/bin/types/executor/SessionRunContext.js +10 -0
  268. package/bin/types/executor/SessionRunContext.js.map +1 -0
  269. package/bin/types/{runtime/host → platform}/Store.d.ts +1 -1
  270. package/bin/types/platform/Store.d.ts.map +1 -0
  271. package/bin/types/{runtime/host → platform}/Store.js +1 -1
  272. package/bin/types/platform/Store.js.map +1 -0
  273. package/bin/types/plugin/ImagePlugin.d.ts +94 -0
  274. package/bin/types/plugin/ImagePlugin.d.ts.map +1 -0
  275. package/bin/types/plugin/ImagePlugin.js +10 -0
  276. package/bin/types/plugin/ImagePlugin.js.map +1 -0
  277. package/bin/types/plugin/PluginAction.d.ts +119 -0
  278. package/bin/types/plugin/PluginAction.d.ts.map +1 -0
  279. package/bin/types/plugin/PluginAction.js +9 -0
  280. package/bin/types/plugin/PluginAction.js.map +1 -0
  281. package/bin/types/plugin/PluginCommand.d.ts +80 -0
  282. package/bin/types/plugin/PluginCommand.d.ts.map +1 -0
  283. package/bin/types/plugin/PluginCommand.js +9 -0
  284. package/bin/types/plugin/PluginCommand.js.map +1 -0
  285. package/bin/types/plugin/PluginDefinition.d.ts +57 -0
  286. package/bin/types/plugin/PluginDefinition.d.ts.map +1 -0
  287. package/bin/types/plugin/PluginDefinition.js +9 -0
  288. package/bin/types/plugin/PluginDefinition.js.map +1 -0
  289. package/bin/types/plugin/PluginHttp.d.ts +34 -0
  290. package/bin/types/plugin/PluginHttp.d.ts.map +1 -0
  291. package/bin/types/plugin/PluginHttp.js +9 -0
  292. package/bin/types/plugin/PluginHttp.js.map +1 -0
  293. package/bin/types/plugin/PluginRuntime.d.ts +148 -0
  294. package/bin/types/plugin/PluginRuntime.d.ts.map +1 -0
  295. package/bin/types/plugin/PluginRuntime.js +9 -0
  296. package/bin/types/plugin/PluginRuntime.js.map +1 -0
  297. package/bin/types/plugin/PluginSetup.d.ts +133 -0
  298. package/bin/types/plugin/PluginSetup.d.ts.map +1 -0
  299. package/bin/types/plugin/PluginSetup.js +9 -0
  300. package/bin/types/plugin/PluginSetup.js.map +1 -0
  301. package/bin/types/plugin/PluginState.d.ts +69 -0
  302. package/bin/types/plugin/PluginState.d.ts.map +1 -0
  303. package/bin/types/plugin/PluginState.js +9 -0
  304. package/bin/types/plugin/PluginState.js.map +1 -0
  305. package/bin/types/rpc/RpcProtocol.d.ts +323 -0
  306. package/bin/types/rpc/RpcProtocol.d.ts.map +1 -0
  307. package/bin/types/rpc/RpcProtocol.js +10 -0
  308. package/bin/types/rpc/RpcProtocol.js.map +1 -0
  309. package/bin/types/runtime/agent/AgentContext.d.ts +1 -1
  310. package/bin/types/runtime/agent/AgentContext.d.ts.map +1 -1
  311. package/bin/types/runtime/agent/AgentRuntime.d.ts +1 -1
  312. package/bin/types/runtime/agent/AgentRuntime.d.ts.map +1 -1
  313. package/bin/types/session/SessionComposerOptions.d.ts +90 -0
  314. package/bin/types/session/SessionComposerOptions.d.ts.map +1 -0
  315. package/bin/types/session/SessionComposerOptions.js +10 -0
  316. package/bin/types/session/SessionComposerOptions.js.map +1 -0
  317. package/bin/types/session/SessionLocalState.d.ts +35 -0
  318. package/bin/types/session/SessionLocalState.d.ts.map +1 -0
  319. package/bin/types/session/SessionLocalState.js +10 -0
  320. package/bin/types/session/SessionLocalState.js.map +1 -0
  321. package/bin/types/session/SessionOptions.d.ts +85 -0
  322. package/bin/types/session/SessionOptions.d.ts.map +1 -0
  323. package/bin/types/session/SessionOptions.js +10 -0
  324. package/bin/types/session/SessionOptions.js.map +1 -0
  325. package/package.json +2 -2
  326. package/scripts/session-history-inflight.test.mjs +146 -0
  327. package/src/agent/local/Agent.ts +197 -0
  328. package/src/agent/local/AgentInstructions.ts +68 -0
  329. package/src/agent/local/AgentPluginFactory.ts +83 -0
  330. package/src/{runtime/host/AgentHostRuntime.ts → agent/local/AgentRuntimeAssembly.ts} +2 -2
  331. package/src/agent/local/AgentRuntimeFactory.ts +152 -0
  332. package/src/{runtime/host → agent/local}/ProjectSetup.ts +1 -1
  333. package/src/agent/local/services/AgentAssemblyService.ts +268 -0
  334. package/src/agent/local/services/AgentLifecycleService.ts +187 -0
  335. package/src/agent/local/services/AgentSessionManager.ts +291 -0
  336. package/src/agent/remote/RemoteAgent.ts +76 -0
  337. package/src/agent/remote/RemoteSession.ts +287 -0
  338. package/src/agent/remote/RemoteTransport.ts +71 -0
  339. package/src/agent/remote/TransportFactory.ts +29 -0
  340. package/src/agent/remote/transports/HttpRemoteAgentTransport.ts +347 -0
  341. package/src/agent/remote/transports/RpcRemoteAgentTransport.ts +107 -0
  342. package/src/executor/Executor.ts +107 -426
  343. package/src/executor/README.md +4 -4
  344. package/src/executor/SessionRunScope.ts +47 -71
  345. package/src/executor/composer/context/LocalSessionContextComposer.ts +24 -20
  346. package/src/executor/composer/context/SessionContextComposer.ts +13 -3
  347. package/src/executor/composer/history/SessionHistoryWriter.ts +2 -2
  348. package/src/executor/composer/system/SessionSystemComposer.ts +2 -1
  349. package/src/executor/composer/system/default/DefaultSessionSystemComposer.ts +3 -4
  350. package/src/executor/core-engine/CoreEngineRunner.ts +433 -0
  351. package/src/executor/core-engine/CoreEngineUiStreamCollector.ts +7 -5
  352. package/src/executor/messages/AssistantResultPersistence.ts +4 -12
  353. package/src/executor/messages/SessionStepEventMapper.ts +59 -101
  354. package/src/executor/messages/UserVisibleText.ts +3 -18
  355. package/src/executor/services/ExecutorInflightService.ts +101 -0
  356. package/src/executor/services/ExecutorRecoveryPolicy.ts +213 -0
  357. package/src/executor/store/history/SessionHistoryStore.ts +15 -0
  358. package/src/executor/store/history/jsonl/JsonlSessionHistoryStore.ts +164 -11
  359. package/src/executor/tools/plugin/PluginToolBridge.ts +161 -0
  360. package/src/executor/tools/plugin/PluginToolDefinition.ts +32 -0
  361. package/src/executor/tools/plugin/PluginToolSchemas.ts +20 -0
  362. package/src/executor/tools/plugin/types/PluginTool.ts +41 -0
  363. package/src/executor/tools/shell/ShellToolBridge.ts +3 -3
  364. package/src/executor/tools/shell/ShellToolFormatting.ts +1 -50
  365. package/src/executor/types/SessionHistoryPaths.ts +5 -0
  366. package/src/executor/types/SessionRun.ts +20 -0
  367. package/src/index.ts +38 -5
  368. package/src/plugin/core/BasePlugin.ts +2 -2
  369. package/src/plugin/core/ImagePlugin.ts +128 -0
  370. package/src/plugin/core/PluginCommandRequest.ts +1 -1
  371. package/src/plugin/core/PluginLocalExecution.ts +1 -1
  372. package/src/plugin/core/ProjectConfigStore.ts +4 -4
  373. package/src/plugin/types/Plugin.ts +54 -913
  374. package/src/plugin/types/PluginState.ts +1 -1
  375. package/src/rpc/Client.ts +16 -322
  376. package/src/rpc/Server.ts +39 -565
  377. package/src/rpc/server/InternalHandlers.ts +230 -0
  378. package/src/rpc/server/RequestDispatcher.ts +67 -0
  379. package/src/rpc/server/SdkSessionHandlers.ts +106 -0
  380. package/src/rpc/server/ServerTypes.ts +65 -0
  381. package/src/{runtime/sandbox → sandbox}/MacOsSeatbeltSandbox.ts +1 -1
  382. package/src/{runtime/sandbox → sandbox}/SandboxConfigResolver.ts +1 -1
  383. package/src/{runtime/sandbox → sandbox}/SandboxRunner.ts +3 -3
  384. package/src/{runtime/sandbox → sandbox}/types/SandboxRuntime.ts +2 -2
  385. package/src/session/Session.ts +184 -485
  386. package/src/session/SessionSystemBuilder.ts +3 -3
  387. package/src/session/browse/Browse.ts +29 -10
  388. package/src/session/index.ts +1 -0
  389. package/src/session/services/SessionStateService.ts +341 -0
  390. package/src/session/services/SessionTurnService.ts +202 -0
  391. package/src/session/services/SessionViewService.ts +301 -0
  392. package/src/session/storage/Paths.ts +19 -0
  393. package/src/types/agent/AgentOptions.ts +172 -0
  394. package/src/types/{runtime/host/AgentHost.ts → agent/AgentRuntimeAssembly.ts} +2 -2
  395. package/src/types/agent/AgentTypes.ts +47 -709
  396. package/src/types/agent/RemoteAgentOptions.ts +29 -0
  397. package/src/types/agent/SessionActor.ts +88 -0
  398. package/src/types/agent/SessionTypes.ts +335 -0
  399. package/src/types/config/DowncityConfig.ts +1 -1
  400. package/src/types/executor/SessionRunContext.ts +76 -0
  401. package/src/types/{runtime/host → platform}/Store.ts +1 -1
  402. package/src/types/plugin/ImagePlugin.ts +103 -0
  403. package/src/types/plugin/PluginAction.ts +133 -0
  404. package/src/types/plugin/PluginCommand.ts +89 -0
  405. package/src/types/plugin/PluginDefinition.ts +74 -0
  406. package/src/types/plugin/PluginHttp.ts +36 -0
  407. package/src/types/plugin/PluginRuntime.ts +169 -0
  408. package/src/types/plugin/PluginSetup.ts +138 -0
  409. package/src/types/plugin/PluginState.ts +82 -0
  410. package/src/types/rpc/RpcProtocol.ts +361 -0
  411. package/src/types/runtime/agent/AgentContext.ts +1 -1
  412. package/src/types/runtime/agent/AgentRuntime.ts +1 -1
  413. package/src/types/session/SessionComposerOptions.ts +107 -0
  414. package/src/types/session/SessionLocalState.ts +40 -0
  415. package/src/types/session/SessionOptions.ts +99 -0
  416. package/tsconfig.tsbuildinfo +1 -1
  417. package/bin/agent/Agent.d.ts +0 -223
  418. package/bin/agent/Agent.d.ts.map +0 -1
  419. package/bin/agent/Agent.js +0 -627
  420. package/bin/agent/Agent.js.map +0 -1
  421. package/bin/agent/RemoteAgent.d.ts.map +0 -1
  422. package/bin/agent/RemoteAgent.js +0 -585
  423. package/bin/agent/RemoteAgent.js.map +0 -1
  424. package/bin/runtime/auth/AuthEnv.d.ts +0 -36
  425. package/bin/runtime/auth/AuthEnv.d.ts.map +0 -1
  426. package/bin/runtime/auth/AuthEnv.js +0 -54
  427. package/bin/runtime/auth/AuthEnv.js.map +0 -1
  428. package/bin/runtime/auth/CliAuthStateStore.d.ts +0 -29
  429. package/bin/runtime/auth/CliAuthStateStore.d.ts.map +0 -1
  430. package/bin/runtime/auth/CliAuthStateStore.js +0 -26
  431. package/bin/runtime/auth/CliAuthStateStore.js.map +0 -1
  432. package/bin/runtime/control/AuthControlService.d.ts +0 -34
  433. package/bin/runtime/control/AuthControlService.d.ts.map +0 -1
  434. package/bin/runtime/control/AuthControlService.js +0 -129
  435. package/bin/runtime/control/AuthControlService.js.map +0 -1
  436. package/bin/runtime/control/CommonHelpers.d.ts +0 -36
  437. package/bin/runtime/control/CommonHelpers.d.ts.map +0 -1
  438. package/bin/runtime/control/CommonHelpers.js +0 -63
  439. package/bin/runtime/control/CommonHelpers.js.map +0 -1
  440. package/bin/runtime/control/ExecuteBySession.d.ts +0 -30
  441. package/bin/runtime/control/ExecuteBySession.d.ts.map +0 -1
  442. package/bin/runtime/control/ExecuteBySession.js +0 -41
  443. package/bin/runtime/control/ExecuteBySession.js.map +0 -1
  444. package/bin/runtime/control/ExecuteInput.d.ts +0 -18
  445. package/bin/runtime/control/ExecuteInput.d.ts.map +0 -1
  446. package/bin/runtime/control/ExecuteInput.js +0 -201
  447. package/bin/runtime/control/ExecuteInput.js.map +0 -1
  448. package/bin/runtime/control/Helpers.d.ts +0 -13
  449. package/bin/runtime/control/Helpers.d.ts.map +0 -1
  450. package/bin/runtime/control/Helpers.js +0 -13
  451. package/bin/runtime/control/Helpers.js.map +0 -1
  452. package/bin/runtime/control/MessageTimeline.d.ts +0 -22
  453. package/bin/runtime/control/MessageTimeline.d.ts.map +0 -1
  454. package/bin/runtime/control/MessageTimeline.js +0 -226
  455. package/bin/runtime/control/MessageTimeline.js.map +0 -1
  456. package/bin/runtime/control/SessionSummaryStore.d.ts +0 -20
  457. package/bin/runtime/control/SessionSummaryStore.d.ts.map +0 -1
  458. package/bin/runtime/control/SessionSummaryStore.js +0 -50
  459. package/bin/runtime/control/SessionSummaryStore.js.map +0 -1
  460. package/bin/runtime/control/TaskStore.d.ts +0 -33
  461. package/bin/runtime/control/TaskStore.d.ts.map +0 -1
  462. package/bin/runtime/control/TaskStore.js +0 -175
  463. package/bin/runtime/control/TaskStore.js.map +0 -1
  464. package/bin/runtime/control/types/AuthControl.d.ts +0 -30
  465. package/bin/runtime/control/types/AuthControl.d.ts.map +0 -1
  466. package/bin/runtime/control/types/AuthControl.js +0 -9
  467. package/bin/runtime/control/types/AuthControl.js.map +0 -1
  468. package/bin/runtime/control/types/ControlSessionExecute.d.ts +0 -85
  469. package/bin/runtime/control/types/ControlSessionExecute.d.ts.map +0 -1
  470. package/bin/runtime/control/types/ControlSessionExecute.js +0 -9
  471. package/bin/runtime/control/types/ControlSessionExecute.js.map +0 -1
  472. package/bin/runtime/control/types/ControlViewData.d.ts +0 -320
  473. package/bin/runtime/control/types/ControlViewData.d.ts.map +0 -1
  474. package/bin/runtime/control/types/ControlViewData.js +0 -9
  475. package/bin/runtime/control/types/ControlViewData.js.map +0 -1
  476. package/bin/runtime/host/AgentHostRuntime.d.ts.map +0 -1
  477. package/bin/runtime/host/AgentHostRuntime.js.map +0 -1
  478. package/bin/runtime/host/ProjectSetup.d.ts.map +0 -1
  479. package/bin/runtime/host/ProjectSetup.js.map +0 -1
  480. package/bin/runtime/sandbox/MacOsSeatbeltSandbox.d.ts.map +0 -1
  481. package/bin/runtime/sandbox/MacOsSeatbeltSandbox.js.map +0 -1
  482. package/bin/runtime/sandbox/SandboxConfigResolver.d.ts.map +0 -1
  483. package/bin/runtime/sandbox/SandboxConfigResolver.js.map +0 -1
  484. package/bin/runtime/sandbox/SandboxRunner.d.ts.map +0 -1
  485. package/bin/runtime/sandbox/SandboxRunner.js.map +0 -1
  486. package/bin/runtime/sandbox/types/Sandbox.d.ts.map +0 -1
  487. package/bin/runtime/sandbox/types/Sandbox.js.map +0 -1
  488. package/bin/runtime/sandbox/types/SandboxRuntime.d.ts.map +0 -1
  489. package/bin/runtime/sandbox/types/SandboxRuntime.js.map +0 -1
  490. package/bin/types/runtime/host/AgentHost.d.ts.map +0 -1
  491. package/bin/types/runtime/host/AgentHost.js.map +0 -1
  492. package/bin/types/runtime/host/Store.d.ts.map +0 -1
  493. package/bin/types/runtime/host/Store.js.map +0 -1
  494. package/src/agent/Agent.ts +0 -734
  495. package/src/agent/RemoteAgent.ts +0 -834
  496. package/src/runtime/auth/AuthEnv.ts +0 -62
  497. package/src/runtime/auth/CliAuthStateStore.ts +0 -46
  498. package/src/runtime/control/AuthControlService.ts +0 -169
  499. package/src/runtime/control/CommonHelpers.ts +0 -69
  500. package/src/runtime/control/ExecuteBySession.ts +0 -52
  501. package/src/runtime/control/ExecuteInput.ts +0 -236
  502. package/src/runtime/control/Helpers.ts +0 -22
  503. package/src/runtime/control/MessageTimeline.ts +0 -269
  504. package/src/runtime/control/SessionSummaryStore.ts +0 -72
  505. package/src/runtime/control/TaskStore.ts +0 -242
  506. package/src/runtime/control/types/AuthControl.ts +0 -34
  507. package/src/runtime/control/types/ControlSessionExecute.ts +0 -99
  508. package/src/runtime/control/types/ControlViewData.ts +0 -392
  509. /package/bin/{runtime/sandbox → sandbox}/MacOsSeatbeltSandbox.js +0 -0
  510. /package/bin/{runtime/sandbox → sandbox}/SandboxConfigResolver.js +0 -0
  511. /package/bin/{runtime/sandbox → sandbox}/types/Sandbox.d.ts +0 -0
  512. /package/bin/{runtime/sandbox → sandbox}/types/Sandbox.js +0 -0
  513. /package/bin/{runtime/sandbox → sandbox}/types/SandboxRuntime.js +0 -0
  514. /package/src/{runtime/sandbox → sandbox}/types/Sandbox.ts +0 -0
@@ -0,0 +1,433 @@
1
+ /**
2
+ * CoreEngineRunner:模型与 tool-loop 主循环执行器。
3
+ *
4
+ * 关键点(中文)
5
+ * - 只负责单次已装配输入的执行,不负责 run scope、外层重试与历史准备。
6
+ * - 把 step 循环、续写恢复、最终 assistant 汇总等细节从 Executor 中剥离。
7
+ * - 保持失败返回结构稳定,避免对外 Session 行为变化。
8
+ */
9
+
10
+ import { streamText, type FileUIPart, type LanguageModel } from "ai";
11
+ import { buildOpenAIResponsesProviderOptions } from "@executor/messages/SessionMessageCodec.js";
12
+ import { logAssistantMessageNow } from "@executor/messages/SessionMessageLog.js";
13
+ import {
14
+ MAX_INCOMPLETE_RESPONSE_RECOVERIES,
15
+ MAX_TEXT_ONLY_CONTINUATIONS,
16
+ MAX_TOOL_LOOP_STEPS,
17
+ buildIncompleteResponseRecoveryNudge,
18
+ buildTextOnlyContinuationNudge,
19
+ detectIncompleteResponse,
20
+ detectTextOnlyContinuationReason,
21
+ mergeAssistantUiMessages,
22
+ summarizeStepForDebug,
23
+ summarizeUiMessageForDebug,
24
+ toInlinePreview,
25
+ } from "@executor/core-engine/CoreEngineSignals.js";
26
+ import {
27
+ evaluateCoreEngineLoopDecision,
28
+ shouldContinueForTailMergedUserMessages,
29
+ } from "@executor/core-engine/CoreEngineLoopDecision.js";
30
+ import {
31
+ resolveEffectiveCoreEngineError,
32
+ summarizeStreamError,
33
+ } from "@executor/core-engine/CoreEngineError.js";
34
+ import { collectFinalAssistantMessageFromUiStream } from "@executor/core-engine/CoreEngineUiStreamCollector.js";
35
+ import { CoreEngineMessageState } from "@executor/core-engine/CoreEngineMessageState.js";
36
+ import type { Logger } from "@/utils/logger/Logger.js";
37
+ import type { SessionHistoryStore } from "@/executor/store/history/SessionHistoryStore.js";
38
+ import type { SessionContextComposer } from "@executor/composer/context/SessionContextComposer.js";
39
+ import type { SessionRunContext } from "@/types/executor/SessionRunContext.js";
40
+ import type {
41
+ SessionExecuteInput,
42
+ SessionRunResult,
43
+ } from "@/executor/types/SessionRun.js";
44
+ import type { SessionMessageV1 } from "@/executor/types/SessionMessages.js";
45
+
46
+ /**
47
+ * 生成 file part 去重 key。
48
+ */
49
+ function build_file_part_key(part: FileUIPart): string {
50
+ return [
51
+ String(part.type || ""),
52
+ String(part.mediaType || ""),
53
+ String(part.filename || ""),
54
+ String(part.url || ""),
55
+ ].join("\n");
56
+ }
57
+
58
+ /**
59
+ * 把 tool/plugin 运行期产生的 file parts 并入最终 assistant UIMessage。
60
+ */
61
+ function mergePendingAssistantFileParts(
62
+ message: SessionMessageV1,
63
+ parts: FileUIPart[],
64
+ ): SessionMessageV1 {
65
+ if (!Array.isArray(parts) || parts.length === 0) return message;
66
+ const current_parts = Array.isArray(message.parts) ? message.parts : [];
67
+ const seen = new Set<string>();
68
+ for (const part of current_parts) {
69
+ const candidate = part as FileUIPart;
70
+ if (candidate?.type !== "file") continue;
71
+ seen.add(build_file_part_key(candidate));
72
+ }
73
+ const next_file_parts = parts.filter((part) => {
74
+ const key = build_file_part_key(part);
75
+ if (seen.has(key)) return false;
76
+ seen.add(key);
77
+ return true;
78
+ });
79
+ if (next_file_parts.length === 0) return message;
80
+ return {
81
+ ...message,
82
+ parts: [...current_parts, ...next_file_parts],
83
+ };
84
+ }
85
+
86
+ interface CoreEngineRunnerOptions {
87
+ /**
88
+ * 当前 session 对应的 history 事实源。
89
+ */
90
+ history_store: SessionHistoryStore;
91
+
92
+ /**
93
+ * 当前 session 对应的 context Composer。
94
+ */
95
+ context_composer: SessionContextComposer;
96
+
97
+ /**
98
+ * 当前 session 统一日志器。
99
+ */
100
+ logger: Logger;
101
+
102
+ /**
103
+ * 判断某次执行错误是否应该上抛给外层压缩重试。
104
+ */
105
+ should_compact_on_error: (error: unknown) => boolean;
106
+ }
107
+
108
+ interface CoreEngineRunInput {
109
+ /**
110
+ * 已装配好的执行输入。
111
+ */
112
+ execute_input: SessionExecuteInput;
113
+
114
+ /**
115
+ * 当前轮模型实例。
116
+ */
117
+ model: LanguageModel;
118
+
119
+ /**
120
+ * 当前显式运行上下文。
121
+ */
122
+ run_context: SessionRunContext;
123
+ }
124
+
125
+ /**
126
+ * 模型与 tool-loop 主循环执行器。
127
+ */
128
+ export class CoreEngineRunner {
129
+ private readonly history_store: SessionHistoryStore;
130
+ private readonly context_composer: SessionContextComposer;
131
+ private readonly logger: Logger;
132
+ private readonly should_compact_on_error: CoreEngineRunnerOptions["should_compact_on_error"];
133
+
134
+ constructor(options: CoreEngineRunnerOptions) {
135
+ this.history_store = options.history_store;
136
+ this.context_composer = options.context_composer;
137
+ this.logger = options.logger;
138
+ this.should_compact_on_error = options.should_compact_on_error;
139
+ }
140
+
141
+ /**
142
+ * 执行一次已装配完成的模型/tool-loop 运行。
143
+ */
144
+ async run(input: CoreEngineRunInput): Promise<SessionRunResult> {
145
+ const start_time = Date.now();
146
+ const session_id = String(this.history_store.sessionId || "").trim();
147
+ const system = Array.isArray(input.execute_input.system)
148
+ ? input.execute_input.system
149
+ : [];
150
+ const tools = input.execute_input.tools;
151
+ let last_observed_stream_error: unknown = undefined;
152
+
153
+ try {
154
+ const message_state = await CoreEngineMessageState.create({
155
+ messages: input.execute_input.messages,
156
+ tools,
157
+ });
158
+
159
+ const append_merged_user_messages = (messages: SessionMessageV1[]) =>
160
+ message_state.appendMergedUserMessages(messages);
161
+
162
+ const context_composer_on_step_finish =
163
+ this.context_composer.createOnStepFinishHandler(input.run_context);
164
+ let step_count = 0;
165
+ let total_tool_call_count = 0;
166
+ let total_tool_result_count = 0;
167
+ const on_step_finish = async (step_result: unknown): Promise<void> => {
168
+ step_count += 1;
169
+ const summary = summarizeStepForDebug(step_result);
170
+ total_tool_call_count +=
171
+ typeof summary.toolCallCount === "number" ? summary.toolCallCount : 0;
172
+ total_tool_result_count +=
173
+ typeof summary.toolResultCount === "number"
174
+ ? summary.toolResultCount
175
+ : 0;
176
+ await this.logger.log("info", "[agent] step.finish", {
177
+ sessionId: session_id,
178
+ stepIndex: step_count,
179
+ ...summary,
180
+ });
181
+ await context_composer_on_step_finish(step_result);
182
+ };
183
+
184
+ const prepare_step = this.context_composer.createPrepareStepHandler({
185
+ system,
186
+ appendMergedUserMessages: append_merged_user_messages,
187
+ runContext: input.run_context,
188
+ });
189
+
190
+ let final_assistant_ui_message: SessionMessageV1 | null = null;
191
+ let text_only_continuation_count = 0;
192
+ let incomplete_response_recovery_count = 0;
193
+
194
+ while (step_count < MAX_TOOL_LOOP_STEPS) {
195
+ const result = streamText({
196
+ model: input.model,
197
+ system,
198
+ onStepFinish: on_step_finish,
199
+ prepareStep: prepare_step,
200
+ messages: message_state.modelMessages,
201
+ tools,
202
+ providerOptions: buildOpenAIResponsesProviderOptions(),
203
+ onError: async ({ error }) => {
204
+ last_observed_stream_error = error;
205
+ await this.logger.log("error", "[agent] stream.error", {
206
+ sessionId: session_id,
207
+ ...summarizeStreamError(error),
208
+ });
209
+ },
210
+ });
211
+
212
+ const step_assistant_ui_message =
213
+ await collectFinalAssistantMessageFromUiStream({
214
+ result,
215
+ sessionId: session_id,
216
+ logger: this.logger,
217
+ buildFallbackAssistantMessage: (text) =>
218
+ this.context_composer.buildFallbackAssistantMessage(
219
+ text,
220
+ input.run_context,
221
+ ),
222
+ onUiMessageChunkCallback: input.run_context.onUiMessageChunkCallback,
223
+ });
224
+
225
+ const executed_steps = await result.steps;
226
+ const last_step = executed_steps[executed_steps.length - 1];
227
+ if (!last_step) break;
228
+
229
+ const incomplete_response = detectIncompleteResponse({
230
+ stepResult: last_step,
231
+ assistantMessage: step_assistant_ui_message,
232
+ });
233
+ const text_only_continuation_reason =
234
+ detectTextOnlyContinuationReason(last_step);
235
+ const loop_decision = evaluateCoreEngineLoopDecision({
236
+ hasIncompleteResponse: incomplete_response !== null,
237
+ incompleteRecoveryCount: incomplete_response_recovery_count,
238
+ maxIncompleteRecoveries: MAX_INCOMPLETE_RESPONSE_RECOVERIES,
239
+ textOnlyContinuationReason: text_only_continuation_reason,
240
+ textOnlyContinuationCount: text_only_continuation_count,
241
+ maxTextOnlyContinuations: MAX_TEXT_ONLY_CONTINUATIONS,
242
+ hasTools: Object.keys(tools).length > 0,
243
+ toolCallCount: last_step.toolCalls.length,
244
+ });
245
+
246
+ await this.logger.log("info", "[agent] loop.decision", {
247
+ sessionId: session_id,
248
+ stepIndex: step_count,
249
+ continueForToolCalls: loop_decision.continueForToolCalls,
250
+ continueForTextOnly: loop_decision.continueForTextOnly,
251
+ continueForIncompleteRecovery:
252
+ loop_decision.continueForIncompleteRecovery,
253
+ decisionKind: loop_decision.kind,
254
+ textOnlyContinuationReason: text_only_continuation_reason,
255
+ textOnlyContinuationCount: text_only_continuation_count,
256
+ incompleteResponseReason: incomplete_response?.reason ?? null,
257
+ incompleteResponseRecoveryCount: incomplete_response_recovery_count,
258
+ toolCallCount: last_step.toolCalls.length,
259
+ toolResultCount: last_step.toolResults.length,
260
+ finishReason: last_step.finishReason,
261
+ textPreview: toInlinePreview(last_step.text),
262
+ });
263
+
264
+ if (
265
+ loop_decision.continueForIncompleteRecovery &&
266
+ incomplete_response
267
+ ) {
268
+ incomplete_response_recovery_count += 1;
269
+ await this.logger.log("warn", "[agent] incomplete_response.recover", {
270
+ sessionId: session_id,
271
+ stepIndex: step_count,
272
+ recoveryCount: incomplete_response_recovery_count,
273
+ reason: incomplete_response.reason,
274
+ ...incomplete_response.details,
275
+ });
276
+ const recovery_message = this.history_store.userText({
277
+ text: buildIncompleteResponseRecoveryNudge(
278
+ incomplete_response_recovery_count,
279
+ ),
280
+ metadata: {
281
+ sessionId: session_id,
282
+ extra: {
283
+ internal: "agent_incomplete_response_recover",
284
+ reason: incomplete_response.reason,
285
+ stepIndex: step_count,
286
+ },
287
+ },
288
+ });
289
+ await message_state.appendUserTextMessage(recovery_message);
290
+ continue;
291
+ }
292
+
293
+ if (incomplete_response) {
294
+ await this.logger.log("error", "[agent] incomplete_response", {
295
+ sessionId: session_id,
296
+ stepIndex: step_count,
297
+ reason: incomplete_response.reason,
298
+ recoveryCount: incomplete_response_recovery_count,
299
+ ...incomplete_response.details,
300
+ });
301
+ throw new Error(
302
+ `Agent received incomplete response (${incomplete_response.reason})`,
303
+ );
304
+ }
305
+
306
+ const response_messages = Array.isArray(last_step.response?.messages)
307
+ ? last_step.response.messages
308
+ : [];
309
+ message_state.appendModelMessages(response_messages);
310
+
311
+ final_assistant_ui_message = mergeAssistantUiMessages(
312
+ final_assistant_ui_message,
313
+ step_assistant_ui_message,
314
+ );
315
+
316
+ // 关键点(中文):把本 step 的 assistant UI 消息并入运行时上下文,保证后续全量重算不丢历史。
317
+ message_state.appendRuntimeSessionMessage(step_assistant_ui_message);
318
+
319
+ if (loop_decision.continueForToolCalls) {
320
+ text_only_continuation_count = 0;
321
+ incomplete_response_recovery_count = 0;
322
+ continue;
323
+ }
324
+
325
+ if (loop_decision.continueForTextOnly) {
326
+ text_only_continuation_count += 1;
327
+ incomplete_response_recovery_count = 0;
328
+ const continuation_message = this.history_store.userText({
329
+ text: buildTextOnlyContinuationNudge(text_only_continuation_count),
330
+ metadata: {
331
+ sessionId: session_id,
332
+ extra: {
333
+ internal: "agent_loop_auto_continue",
334
+ reason: text_only_continuation_reason,
335
+ stepIndex: step_count,
336
+ },
337
+ },
338
+ });
339
+ await message_state.appendUserTextMessage(continuation_message);
340
+ continue;
341
+ }
342
+
343
+ // 关键点(中文):stop 前做 tail merge,覆盖最后一个 step 后才入队的新 user 消息。
344
+ const tail_prepared = await prepare_step({ messages: [] });
345
+ const tail_merged_message_count = Array.isArray(tail_prepared.messages)
346
+ ? tail_prepared.messages.length
347
+ : 0;
348
+ if (
349
+ shouldContinueForTailMergedUserMessages({
350
+ mergedUserMessageCount: tail_merged_message_count,
351
+ })
352
+ ) {
353
+ text_only_continuation_count = 0;
354
+ incomplete_response_recovery_count = 0;
355
+ await this.logger.log("info", "[agent] loop.tail_merge_continue", {
356
+ sessionId: session_id,
357
+ stepIndex: step_count,
358
+ mergedUserMessageCount: tail_merged_message_count,
359
+ });
360
+ continue;
361
+ }
362
+
363
+ break;
364
+ }
365
+
366
+ if (step_count >= MAX_TOOL_LOOP_STEPS) {
367
+ await this.logger.log("warn", "[agent] loop.max_steps_reached", {
368
+ sessionId: session_id,
369
+ stepCount: step_count,
370
+ totalToolCallCount: total_tool_call_count,
371
+ totalToolResultCount: total_tool_result_count,
372
+ });
373
+ }
374
+
375
+ const final_message = mergePendingAssistantFileParts(
376
+ final_assistant_ui_message ||
377
+ this.context_composer.buildFallbackAssistantMessage(
378
+ "Execution completed",
379
+ input.run_context,
380
+ ),
381
+ input.run_context.pendingAssistantFileParts,
382
+ );
383
+
384
+ await this.logger.log("info", "[agent] final.message", {
385
+ sessionId: session_id,
386
+ ...summarizeUiMessageForDebug(final_message),
387
+ });
388
+ await logAssistantMessageNow(this.logger, final_message);
389
+
390
+ const duration = Date.now() - start_time;
391
+ await this.logger.log("info", "[agent] finish", {
392
+ sessionId: session_id,
393
+ duration,
394
+ stepCount: step_count,
395
+ totalToolCallCount: total_tool_call_count,
396
+ totalToolResultCount: total_tool_result_count,
397
+ });
398
+
399
+ return {
400
+ success: true,
401
+ assistantMessage: final_message,
402
+ deferredPersistedUserMessages: [
403
+ ...input.run_context.deferredPersistedUserMessages,
404
+ ],
405
+ };
406
+ } catch (error) {
407
+ if (this.should_compact_on_error(error)) {
408
+ throw error;
409
+ }
410
+
411
+ const error_text = resolveEffectiveCoreEngineError({
412
+ error,
413
+ streamError: last_observed_stream_error,
414
+ });
415
+
416
+ await this.logger.log("error", "CoreEngine execution failed", {
417
+ error: error_text,
418
+ });
419
+
420
+ return {
421
+ success: false,
422
+ error: error_text,
423
+ assistantMessage: this.context_composer.buildFallbackAssistantMessage(
424
+ `Execution failed: ${error_text}`,
425
+ input.run_context,
426
+ ),
427
+ deferredPersistedUserMessages: [
428
+ ...input.run_context.deferredPersistedUserMessages,
429
+ ],
430
+ };
431
+ }
432
+ }
433
+ }
@@ -11,7 +11,7 @@ import type { streamText } from "ai";
11
11
  import type { Logger } from "@/utils/logger/Logger.js";
12
12
  import type { JsonObject } from "@/types/common/Json.js";
13
13
  import type { SessionMessageV1 } from "@/executor/types/SessionMessages.js";
14
- import { getSessionRunScope } from "@executor/SessionRunScope.js";
14
+ import type { SessionUiMessageChunkCallback } from "@/executor/types/SessionRun.js";
15
15
  import {
16
16
  summarizeUiMessageForDebug,
17
17
  toInlinePreview,
@@ -37,6 +37,10 @@ export async function collectFinalAssistantMessageFromUiStream(params: {
37
37
  * 构造 fallback assistant 消息的工厂函数。
38
38
  */
39
39
  buildFallbackAssistantMessage: (text: string) => SessionMessageV1;
40
+ /**
41
+ * UI stream chunk 回调。
42
+ */
43
+ onUiMessageChunkCallback?: SessionUiMessageChunkCallback;
40
44
  }): Promise<SessionMessageV1> {
41
45
  let streamedAssistantMessage: SessionMessageV1 | null = null;
42
46
  let uiFinishSummary: JsonObject | null = null;
@@ -57,12 +61,10 @@ export async function collectFinalAssistantMessageFromUiStream(params: {
57
61
  },
58
62
  });
59
63
 
60
- const onUiMessageChunkCallback =
61
- getSessionRunScope()?.onUiMessageChunkCallback;
62
64
  for await (const chunk of uiStream) {
63
- if (typeof onUiMessageChunkCallback !== "function") continue;
65
+ if (typeof params.onUiMessageChunkCallback !== "function") continue;
64
66
  try {
65
- await onUiMessageChunkCallback(chunk);
67
+ await params.onUiMessageChunkCallback(chunk);
66
68
  } catch {
67
69
  // ignore UI stream callback failures
68
70
  }
@@ -4,14 +4,11 @@
4
4
  * 关键点(中文)
5
5
  * - 负责收敛“写完整 assistant message / 写 fallback 文本 / 完全跳过”三种分支。
6
6
  * - 避免 SDK、HTTP execute、control execute、chat queue 各自复制一套判断。
7
- * - 一旦 step 消息已经单独持久化,最终 merged assistant 必须跳过,不能再补一条 fallback。
7
+ * - 运行中 step/tool 的持久化由 inflight 快照承担;run 结束时只关心最终 assistant 如何收口。
8
8
  */
9
9
 
10
10
  import type { SessionMessageV1 } from "@/executor/types/SessionMessages.js";
11
- import {
12
- hasPersistedAssistantSteps,
13
- resolveAssistantMessageForPersistence,
14
- } from "@/executor/messages/UserVisibleText.js";
11
+ import { resolveAssistantMessageForPersistence } from "@/executor/messages/UserVisibleText.js";
15
12
 
16
13
  /**
17
14
  * assistant 写入端口。
@@ -48,8 +45,8 @@ export interface PersistAssistantResultParams {
48
45
  * 可选兜底文本。
49
46
  *
50
47
  * 关键点(中文)
51
- * - 仅在没有完整 assistant message 且未发生 step 持久化时才允许写入。
52
- * - step 已单独落盘,这里必须被忽略,避免重复 assistant。
48
+ * - 仅在没有完整 assistant message 时才允许写入。
49
+ * - inflight 快照的正式收口由 history store 负责,这里不再处理旧的 step 独立落盘分支。
53
50
  */
54
51
  fallbackText?: string;
55
52
  }
@@ -83,11 +80,6 @@ export function buildAssistantResultPersistencePayload(
83
80
  };
84
81
  }
85
82
 
86
- // 关键点(中文):step 已经单独落盘时,最终 merged assistant 必须完全跳过。
87
- if (hasPersistedAssistantSteps(params.assistantMessage)) {
88
- return null;
89
- }
90
-
91
83
  const fallbackText = normalizeFallbackText(params.fallbackText);
92
84
  if (!fallbackText) return null;
93
85
  return {