@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,68 @@
1
+ /**
2
+ * Agent instruction 组装工具。
3
+ *
4
+ * 关键点(中文)
5
+ * - 这里只处理静态 instruction 与默认 core prompt。
6
+ * - 不读取 session、plugin 或 runtime 状态,保持为纯函数。
7
+ */
8
+
9
+ import type { DowncityConfig } from "@/types/config/DowncityConfig.js";
10
+ import type { AgentSessionSystemBlock } from "@/types/agent/AgentTypes.js";
11
+ import { DEFAULT_SHIP_PROMPTS } from "@executor/composer/system/default/SystemDomain.js";
12
+
13
+ /**
14
+ * 创建 SDK 场景的最小 fallback 配置。
15
+ */
16
+ export function createFallbackSdkConfig(agent_id: string): DowncityConfig {
17
+ return {
18
+ id: agent_id,
19
+ version: "0.0.0",
20
+ } as DowncityConfig;
21
+ }
22
+
23
+ /**
24
+ * 归一化调用方传入的静态 instruction。
25
+ */
26
+ export function normalizeInstructionInput(
27
+ input: string | string[] | undefined,
28
+ ): string[] {
29
+ const items = Array.isArray(input)
30
+ ? input
31
+ : typeof input === "string"
32
+ ? [input]
33
+ : [];
34
+ return items
35
+ .map((item) => String(item || "").trim())
36
+ .filter((item) => item.length > 0);
37
+ }
38
+
39
+ function createCoreInstructionContent(project_root: string): string {
40
+ const current_year = String(new Date().getFullYear());
41
+ return DEFAULT_SHIP_PROMPTS
42
+ .replaceAll("{{project_path}}", project_root)
43
+ .replaceAll("{{project_root}}", project_root)
44
+ .replaceAll("{{current_year}}", current_year);
45
+ }
46
+
47
+ /**
48
+ * 构造进入 session system prompt 的 instruction block。
49
+ */
50
+ export function createInstructionSystemBlocks(
51
+ instruction: string[],
52
+ project_root: string,
53
+ ): AgentSessionSystemBlock[] {
54
+ if (instruction.length === 0) {
55
+ return [
56
+ {
57
+ source: "core",
58
+ name: "default",
59
+ content: createCoreInstructionContent(project_root),
60
+ },
61
+ ];
62
+ }
63
+ return instruction.map((content, index) => ({
64
+ source: "instruction" as const,
65
+ name: instruction.length === 1 ? "agent" : `agent:${index + 1}`,
66
+ content,
67
+ }));
68
+ }
@@ -0,0 +1,83 @@
1
+ /**
2
+ * Agent plugin 装配工厂。
3
+ *
4
+ * 关键点(中文)
5
+ * - 这里只负责把 plugin 实例装配成 registry 与对外 port。
6
+ * - Agent 仍然持有长期状态;这里不创建新的运行时层级。
7
+ */
8
+
9
+ import type { BasePlugin } from "@/plugin/core/BasePlugin.js";
10
+ import type { AgentContext } from "@/types/runtime/agent/AgentContext.js";
11
+ import type {
12
+ PluginAvailability,
13
+ PluginPort,
14
+ PluginView,
15
+ } from "@/plugin/types/Plugin.js";
16
+ import { HookRegistry } from "@/plugin/core/HookRegistry.js";
17
+ import { PluginRegistry } from "@/plugin/core/PluginRegistry.js";
18
+ import { isPluginEnabled } from "@/plugin/core/Activation.js";
19
+
20
+ /**
21
+ * 创建 plugin registry 的参数。
22
+ */
23
+ export interface CreateAgentPluginRegistryOptions {
24
+ /** 当前 agent 显式注册的 plugin 实例。 */
25
+ plugins: BasePlugin[];
26
+ /** 延迟读取当前 AgentContext。 */
27
+ get_context: () => AgentContext;
28
+ }
29
+
30
+ /**
31
+ * 创建 plugin 注册表。
32
+ */
33
+ export function createAgentPluginRegistry(
34
+ options: CreateAgentPluginRegistryOptions,
35
+ ): PluginRegistry {
36
+ let plugin_registry_ref: PluginRegistry | null = null;
37
+ const hook_registry = new HookRegistry({
38
+ contextResolver: options.get_context,
39
+ pluginEnabledChecker: (plugin_name) => {
40
+ const plugin = plugin_registry_ref?.get(plugin_name);
41
+ return plugin
42
+ ? isPluginEnabled({ plugin, context: options.get_context() })
43
+ : false;
44
+ },
45
+ });
46
+ const registry = new PluginRegistry({
47
+ contextResolver: options.get_context,
48
+ hookRegistry: hook_registry,
49
+ });
50
+ plugin_registry_ref = registry;
51
+
52
+ for (const plugin of options.plugins) {
53
+ registry.register(plugin);
54
+ }
55
+ return registry;
56
+ }
57
+
58
+ /**
59
+ * 创建对外暴露的 plugin 调用门面。
60
+ */
61
+ export function createAgentPluginPort(
62
+ plugin_registry: PluginRegistry,
63
+ ): PluginPort {
64
+ return {
65
+ list: (): PluginView[] => plugin_registry.list(),
66
+ availability: async (plugin_name: string): Promise<PluginAvailability> =>
67
+ await plugin_registry.availability(plugin_name),
68
+ runAction: async (params) => await plugin_registry.runAction(params),
69
+ pipeline: async <T>(point_name: string, value: T): Promise<T> =>
70
+ await plugin_registry.pipeline(point_name, value),
71
+ guard: async <T>(point_name: string, value: T): Promise<void> => {
72
+ await plugin_registry.guard(point_name, value);
73
+ },
74
+ effect: async <T>(point_name: string, value: T): Promise<void> => {
75
+ await plugin_registry.effect(point_name, value);
76
+ },
77
+ resolve: async <TInput, TOutput>(
78
+ point_name: string,
79
+ value: TInput,
80
+ ): Promise<TOutput> =>
81
+ await plugin_registry.resolve<TInput, TOutput>(point_name, value),
82
+ };
83
+ }
@@ -1,5 +1,5 @@
1
1
  /**
2
- * AgentHostRuntime:装配 AgentRuntime 宿主能力。
2
+ * AgentRuntimeAssembly:装配本地 AgentRuntime 能力。
3
3
  *
4
4
  * 关键点(中文)
5
5
  * - agent runtime 负责创建这些宿主能力对象,再注入到 AgentRuntime。
@@ -22,7 +22,7 @@ import { persistProjectPluginConfig } from "@/plugin/core/ProjectConfigStore.js"
22
22
  import type {
23
23
  AgentPathRuntime,
24
24
  AgentPluginConfigRuntime,
25
- } from "@/types/runtime/host/AgentHost.js";
25
+ } from "@/types/agent/AgentRuntimeAssembly.js";
26
26
  import type { DowncityConfig } from "@/types/config/DowncityConfig.js";
27
27
 
28
28
  /**
@@ -0,0 +1,152 @@
1
+ /**
2
+ * Agent runtime / context 装配工厂。
3
+ *
4
+ * 关键点(中文)
5
+ * - 这里只创建长期 runtime 视图与执行期 context 视图。
6
+ * - Agent 仍然持有 session/plugin 状态;这里通过函数参数读取状态。
7
+ */
8
+
9
+ import type { BasePlugin } from "@/plugin/core/BasePlugin.js";
10
+ import type { Logger } from "@/utils/logger/Logger.js";
11
+ import type { DowncityConfig } from "@/types/config/DowncityConfig.js";
12
+ import type { LanguageModel } from "ai";
13
+ import type { JsonValue } from "@/types/common/Json.js";
14
+ import type {
15
+ AgentContext,
16
+ SessionPort,
17
+ } from "@/types/runtime/agent/AgentContext.js";
18
+ import type { AgentRuntime } from "@/types/runtime/agent/AgentRuntime.js";
19
+ import type { PluginPort } from "@/plugin/types/Plugin.js";
20
+ import type { AgentManagedSession } from "@/types/agent/AgentTypes.js";
21
+ import {
22
+ createAgentPathRuntime,
23
+ createAgentPluginConfigRuntime,
24
+ } from "@/agent/local/AgentRuntimeAssembly.js";
25
+
26
+ /**
27
+ * 创建 AgentRuntime 的参数。
28
+ */
29
+ export interface CreateAgentRuntimeOptions {
30
+ /** 当前 agent id。 */
31
+ agent_id: string;
32
+ /** 当前项目根目录。 */
33
+ project_root: string;
34
+ /** 统一日志器。 */
35
+ logger: Logger;
36
+ /** 当前解析后的配置。 */
37
+ config: DowncityConfig;
38
+ /** 当前环境变量快照。 */
39
+ env: Record<string, string>;
40
+ /** 当前静态 system 文本集合。 */
41
+ systems: string[];
42
+ /** 当前 plugin 实例集合。 */
43
+ plugin_instances: Map<string, BasePlugin>;
44
+ /** 获取或创建 session runtime port。 */
45
+ get_session_port: (session_id: string) => SessionPort;
46
+ /** 读取当前已缓存的 session 实例。 */
47
+ list_cached_sessions: () => AgentManagedSession[];
48
+ }
49
+
50
+ /**
51
+ * 创建 AgentContext 的参数。
52
+ */
53
+ export interface CreateAgentContextOptions {
54
+ /** 当前 AgentRuntime。 */
55
+ runtime: AgentRuntime;
56
+ /** 当前项目根目录。 */
57
+ project_root: string;
58
+ /** 统一日志器。 */
59
+ logger: Logger;
60
+ /** 当前解析后的配置。 */
61
+ config: DowncityConfig;
62
+ /** 当前环境变量快照。 */
63
+ env: Record<string, string>;
64
+ /** 当前静态 system 文本集合。 */
65
+ systems: string[];
66
+ /** 当前 plugin 实例集合。 */
67
+ plugin_instances: Map<string, BasePlugin>;
68
+ /** 对外 plugin 调用端口。 */
69
+ plugins: PluginPort;
70
+ /** 获取或创建 session runtime port。 */
71
+ get_session_port: (session_id: string) => SessionPort;
72
+ /** 解析 session 当前绑定的模型实例。 */
73
+ resolve_session_model: (session_id: string) => Promise<LanguageModel | undefined>;
74
+ }
75
+
76
+ /**
77
+ * 创建实例级 runtime 视图。
78
+ */
79
+ export function createAgentRuntime(
80
+ options: CreateAgentRuntimeOptions,
81
+ ): AgentRuntime {
82
+ return {
83
+ cwd: options.project_root,
84
+ rootPath: options.project_root,
85
+ logger: options.logger,
86
+ config: options.config,
87
+ env: options.env,
88
+ systems: options.systems,
89
+ paths: createAgentPathRuntime(options.project_root, options.agent_id),
90
+ pluginConfig: createAgentPluginConfigRuntime(options.project_root),
91
+ getSession: (session_id: string): SessionPort =>
92
+ options.get_session_port(session_id),
93
+ listExecutingSessionIds: () =>
94
+ options
95
+ .list_cached_sessions()
96
+ .filter((session) => session.isExecuting())
97
+ .map((session) => session.id),
98
+ getExecutingSessionCount: () =>
99
+ options
100
+ .list_cached_sessions()
101
+ .filter((session) => session.isExecuting()).length,
102
+ pluginInstances: options.plugin_instances,
103
+ };
104
+ }
105
+
106
+ /**
107
+ * 创建统一执行上下文。
108
+ */
109
+ export function createAgentContext(
110
+ options: CreateAgentContextOptions,
111
+ ): AgentContext {
112
+ let context!: AgentContext;
113
+ context = {
114
+ agent: options.runtime,
115
+ cwd: options.project_root,
116
+ rootPath: options.project_root,
117
+ logger: options.logger,
118
+ config: options.config,
119
+ env: options.env,
120
+ systems: options.systems,
121
+ paths: options.runtime.paths,
122
+ pluginConfig: options.runtime.pluginConfig,
123
+ session: {
124
+ get: (session_id) => options.get_session_port(session_id),
125
+ listExecutingSessionIds: () => options.runtime.listExecutingSessionIds(),
126
+ getExecutingSessionCount: () => options.runtime.getExecutingSessionCount(),
127
+ resolveModel: async (session_id) =>
128
+ await options.resolve_session_model(session_id),
129
+ },
130
+ invoke: {
131
+ invoke: async (params: {
132
+ plugin: string;
133
+ action: string;
134
+ payload?: JsonValue;
135
+ }) => {
136
+ const result = await options.plugins.runAction(params);
137
+ if (!result.success) {
138
+ return {
139
+ success: false,
140
+ error: result.error || result.message || "plugin action failed",
141
+ };
142
+ }
143
+ return {
144
+ success: true,
145
+ ...(result.data !== undefined ? { data: result.data } : {}),
146
+ };
147
+ },
148
+ },
149
+ plugins: options.plugins,
150
+ };
151
+ return context;
152
+ }
@@ -1,5 +1,5 @@
1
1
  /**
2
- * ProjectSetup:runtime 启动前项目结构准备模块。
2
+ * ProjectSetup:本地 Agent 启动前项目结构准备模块。
3
3
  *
4
4
  * 关键点(中文)
5
5
  * - 统一校验初始化必要文件(PROFILE.md / downcity.json)。
@@ -0,0 +1,268 @@
1
+ /**
2
+ * AgentAssemblyService:本地 Agent 装配服务。
3
+ *
4
+ * 关键点(中文)
5
+ * - 统一装配 logger、config、env、runtime、context、plugin registry 与 plugin port。
6
+ * - 该服务只负责一次性长期对象装配,不负责 session 缓存和生命周期启动。
7
+ * - session/lifecycle service 通过它暴露的长期对象协作,避免在 facade 中重复拼装。
8
+ */
9
+
10
+ import type { LanguageModel, Tool } from "ai";
11
+ import type { BasePlugin } from "@/plugin/core/BasePlugin.js";
12
+ import type { AgentContext } from "@/types/runtime/agent/AgentContext.js";
13
+ import type { AgentRuntime } from "@/types/runtime/agent/AgentRuntime.js";
14
+ import type { DowncityConfig } from "@/types/config/DowncityConfig.js";
15
+ import type { PluginPort } from "@/plugin/types/Plugin.js";
16
+ import type { AgentOptions } from "@/types/agent/AgentTypes.js";
17
+ import { Logger } from "@/utils/logger/Logger.js";
18
+ import { loadDowncityConfig, resolveAgentEnv } from "@/config/Config.js";
19
+ import { PluginRegistry } from "@/plugin/core/PluginRegistry.js";
20
+ import {
21
+ createFallbackSdkConfig,
22
+ normalizeInstructionInput,
23
+ } from "@/agent/local/AgentInstructions.js";
24
+ import {
25
+ createAgentPluginPort,
26
+ createAgentPluginRegistry,
27
+ } from "@/agent/local/AgentPluginFactory.js";
28
+ import {
29
+ createAgentContext,
30
+ createAgentRuntime,
31
+ } from "@/agent/local/AgentRuntimeFactory.js";
32
+ import { setShellToolRuntime } from "@executor/tools/shell/ShellToolDefinition.js";
33
+ import {
34
+ plugin_tools,
35
+ setPluginToolRuntime,
36
+ } from "@executor/tools/plugin/PluginToolDefinition.js";
37
+ import type { AgentManagedSession } from "@/types/agent/AgentTypes.js";
38
+ import type { SessionPort } from "@/types/runtime/agent/AgentContext.js";
39
+
40
+ type AgentAssemblyServiceOptions = {
41
+ /**
42
+ * 当前 agent 构造参数。
43
+ */
44
+ options: AgentOptions;
45
+
46
+ /**
47
+ * 读取当前已缓存的 session 实例。
48
+ */
49
+ list_cached_sessions: () => AgentManagedSession[];
50
+
51
+ /**
52
+ * 获取或创建 session runtime port。
53
+ */
54
+ get_session_port: (session_id: string) => SessionPort;
55
+
56
+ /**
57
+ * 解析指定 session 当前绑定的模型实例。
58
+ */
59
+ resolve_session_model: (
60
+ session_id: string,
61
+ ) => Promise<LanguageModel | undefined>;
62
+ };
63
+
64
+ /**
65
+ * 本地 Agent 装配结果。
66
+ */
67
+ export interface AgentAssemblyResult {
68
+ /**
69
+ * 当前 agent 稳定标识。
70
+ */
71
+ id: string;
72
+
73
+ /**
74
+ * 当前项目根目录。
75
+ */
76
+ path: string;
77
+
78
+ /**
79
+ * 当前 agent 默认工具集合。
80
+ */
81
+ tools: Record<string, Tool>;
82
+
83
+ /**
84
+ * 当前 agent 统一日志器。
85
+ */
86
+ logger: Logger;
87
+
88
+ /**
89
+ * 当前 agent 环境变量快照。
90
+ */
91
+ env: Record<string, string>;
92
+
93
+ /**
94
+ * 当前 agent 静态 instruction。
95
+ */
96
+ instruction: string[];
97
+
98
+ /**
99
+ * 当前解析后的项目配置。
100
+ */
101
+ config: DowncityConfig;
102
+
103
+ /**
104
+ * 当前 plugin 实例集合。
105
+ */
106
+ plugin_instances: Map<string, BasePlugin>;
107
+
108
+ /**
109
+ * 当前 plugin 注册表。
110
+ */
111
+ plugin_registry: PluginRegistry;
112
+
113
+ /**
114
+ * 当前对外 plugin 调用端口。
115
+ */
116
+ plugins: PluginPort;
117
+
118
+ /**
119
+ * 当前 agent runtime。
120
+ */
121
+ runtime: AgentRuntime;
122
+
123
+ /**
124
+ * 当前 agent context。
125
+ */
126
+ agent_context: AgentContext;
127
+ }
128
+
129
+ /**
130
+ * 本地 Agent 装配服务。
131
+ */
132
+ export class AgentAssemblyService {
133
+ private readonly options: AgentOptions;
134
+ private readonly list_cached_sessions: AgentAssemblyServiceOptions["list_cached_sessions"];
135
+ private readonly get_session_port: AgentAssemblyServiceOptions["get_session_port"];
136
+ private readonly resolve_session_model: AgentAssemblyServiceOptions["resolve_session_model"];
137
+
138
+ constructor(options: AgentAssemblyServiceOptions) {
139
+ this.options = options.options;
140
+ this.list_cached_sessions = options.list_cached_sessions;
141
+ this.get_session_port = options.get_session_port;
142
+ this.resolve_session_model = options.resolve_session_model;
143
+ }
144
+
145
+ /**
146
+ * 执行一次性长期对象装配。
147
+ */
148
+ assemble(): AgentAssemblyResult {
149
+ const id = String(this.options.id || "").trim();
150
+ const path = String(this.options.path || "").trim();
151
+ const tools =
152
+ this.options.tools && typeof this.options.tools === "object"
153
+ ? { ...this.options.tools }
154
+ : {};
155
+ if (!id) {
156
+ throw new Error("Agent requires a non-empty id");
157
+ }
158
+ if (!path) {
159
+ throw new Error("Agent requires a non-empty path");
160
+ }
161
+
162
+ const logger = new Logger();
163
+ logger.bindProjectRoot(path);
164
+ const env = resolveAgentEnv(path, this.options.env);
165
+ const instruction = normalizeInstructionInput(this.options.instruction);
166
+ const config = this.load_config(id, path);
167
+ const plugin_instances = new Map<string, BasePlugin>();
168
+
169
+ const runtime = createAgentRuntime({
170
+ agent_id: id,
171
+ project_root: path,
172
+ logger,
173
+ config,
174
+ env,
175
+ systems: instruction,
176
+ plugin_instances,
177
+ get_session_port: this.get_session_port,
178
+ list_cached_sessions: this.list_cached_sessions,
179
+ });
180
+
181
+ this.register_plugins(plugin_instances, runtime, this.options.plugins || []);
182
+
183
+ let agent_context!: AgentContext;
184
+ const plugin_registry = createAgentPluginRegistry({
185
+ plugins: [...plugin_instances.values()],
186
+ get_context: () => agent_context,
187
+ });
188
+ const plugins = createAgentPluginPort(plugin_registry);
189
+ if (this.should_register_plugin_call_tool(plugin_instances)) {
190
+ tools.plugin_call = tools.plugin_call || plugin_tools.plugin_call;
191
+ }
192
+ agent_context = createAgentContext({
193
+ runtime,
194
+ project_root: path,
195
+ logger,
196
+ config,
197
+ env,
198
+ systems: instruction,
199
+ plugin_instances,
200
+ plugins,
201
+ get_session_port: this.get_session_port,
202
+ resolve_session_model: async (session_id) =>
203
+ await this.resolve_session_model(session_id),
204
+ });
205
+ setShellToolRuntime(agent_context.invoke);
206
+ setPluginToolRuntime(plugins);
207
+
208
+ return {
209
+ id,
210
+ path,
211
+ tools,
212
+ logger,
213
+ env,
214
+ instruction,
215
+ config,
216
+ plugin_instances,
217
+ plugin_registry,
218
+ plugins,
219
+ runtime,
220
+ agent_context,
221
+ };
222
+ }
223
+
224
+ private load_config(agent_id: string, project_root: string): DowncityConfig {
225
+ try {
226
+ return loadDowncityConfig(project_root);
227
+ } catch {
228
+ return createFallbackSdkConfig(agent_id);
229
+ }
230
+ }
231
+
232
+ private register_plugins(
233
+ plugin_instances: Map<string, BasePlugin>,
234
+ runtime: AgentRuntime,
235
+ plugins: BasePlugin[],
236
+ ): void {
237
+ for (const plugin of plugins) {
238
+ const name = String(plugin?.name || "").trim();
239
+ if (!name) {
240
+ throw new Error("Agent received a plugin without a valid name");
241
+ }
242
+ if (plugin_instances.has(name)) {
243
+ throw new Error(`Duplicate plugin registration: ${name}`);
244
+ }
245
+ plugin.bindAgent(runtime);
246
+ plugin_instances.set(name, plugin);
247
+ }
248
+ }
249
+
250
+ /**
251
+ * 判断是否需要自动注册 plugin_call tool。
252
+ */
253
+ private should_register_plugin_call_tool(
254
+ plugin_instances: Map<string, BasePlugin>,
255
+ ): boolean {
256
+ for (const plugin of plugin_instances.values()) {
257
+ if (
258
+ plugin.actions &&
259
+ Object.keys(plugin.actions).some((action_name) =>
260
+ Boolean(String(action_name || "").trim()),
261
+ )
262
+ ) {
263
+ return true;
264
+ }
265
+ }
266
+ return false;
267
+ }
268
+ }