@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.
- package/README.md +15 -18
- package/bin/agent/local/Agent.d.ts +82 -0
- package/bin/agent/local/Agent.d.ts.map +1 -0
- package/bin/agent/local/Agent.js +154 -0
- package/bin/agent/local/Agent.js.map +1 -0
- package/bin/agent/local/AgentInstructions.d.ts +22 -0
- package/bin/agent/local/AgentInstructions.d.ts.map +1 -0
- package/bin/agent/local/AgentInstructions.js +57 -0
- package/bin/agent/local/AgentInstructions.js.map +1 -0
- package/bin/agent/local/AgentPluginFactory.d.ts +29 -0
- package/bin/agent/local/AgentPluginFactory.d.ts.map +1 -0
- package/bin/agent/local/AgentPluginFactory.js +53 -0
- package/bin/agent/local/AgentPluginFactory.js.map +1 -0
- package/bin/{runtime/host/AgentHostRuntime.d.ts → agent/local/AgentRuntimeAssembly.d.ts} +2 -2
- package/bin/agent/local/AgentRuntimeAssembly.d.ts.map +1 -0
- package/bin/{runtime/host/AgentHostRuntime.js → agent/local/AgentRuntimeAssembly.js} +2 -2
- package/bin/agent/local/AgentRuntimeAssembly.js.map +1 -0
- package/bin/agent/local/AgentRuntimeFactory.d.ts +72 -0
- package/bin/agent/local/AgentRuntimeFactory.d.ts.map +1 -0
- package/bin/agent/local/AgentRuntimeFactory.js +73 -0
- package/bin/agent/local/AgentRuntimeFactory.js.map +1 -0
- package/bin/{runtime/host → agent/local}/ProjectSetup.d.ts +1 -1
- package/bin/agent/local/ProjectSetup.d.ts.map +1 -0
- package/bin/{runtime/host → agent/local}/ProjectSetup.js +1 -1
- package/bin/agent/local/ProjectSetup.js.map +1 -0
- package/bin/agent/local/services/AgentAssemblyService.d.ts +112 -0
- package/bin/agent/local/services/AgentAssemblyService.d.ts.map +1 -0
- package/bin/agent/local/services/AgentAssemblyService.js +135 -0
- package/bin/agent/local/services/AgentAssemblyService.js.map +1 -0
- package/bin/agent/local/services/AgentLifecycleService.d.ts +59 -0
- package/bin/agent/local/services/AgentLifecycleService.d.ts.map +1 -0
- package/bin/agent/local/services/AgentLifecycleService.js +136 -0
- package/bin/agent/local/services/AgentLifecycleService.js.map +1 -0
- package/bin/agent/local/services/AgentSessionManager.d.ts +106 -0
- package/bin/agent/local/services/AgentSessionManager.d.ts.map +1 -0
- package/bin/agent/local/services/AgentSessionManager.js +182 -0
- package/bin/agent/local/services/AgentSessionManager.js.map +1 -0
- package/bin/agent/{RemoteAgent.d.ts → remote/RemoteAgent.d.ts} +3 -3
- package/bin/agent/remote/RemoteAgent.d.ts.map +1 -0
- package/bin/agent/remote/RemoteAgent.js +58 -0
- package/bin/agent/remote/RemoteAgent.js.map +1 -0
- package/bin/agent/remote/RemoteSession.d.ts +62 -0
- package/bin/agent/remote/RemoteSession.d.ts.map +1 -0
- package/bin/agent/remote/RemoteSession.js +225 -0
- package/bin/agent/remote/RemoteSession.js.map +1 -0
- package/bin/agent/remote/RemoteTransport.d.ts +52 -0
- package/bin/agent/remote/RemoteTransport.d.ts.map +1 -0
- package/bin/agent/remote/RemoteTransport.js +9 -0
- package/bin/agent/remote/RemoteTransport.js.map +1 -0
- package/bin/agent/remote/TransportFactory.d.ts +13 -0
- package/bin/agent/remote/TransportFactory.d.ts.map +1 -0
- package/bin/agent/remote/TransportFactory.js +22 -0
- package/bin/agent/remote/TransportFactory.js.map +1 -0
- package/bin/agent/remote/transports/HttpRemoteAgentTransport.d.ts +35 -0
- package/bin/agent/remote/transports/HttpRemoteAgentTransport.d.ts.map +1 -0
- package/bin/agent/remote/transports/HttpRemoteAgentTransport.js +259 -0
- package/bin/agent/remote/transports/HttpRemoteAgentTransport.js.map +1 -0
- package/bin/agent/remote/transports/RpcRemoteAgentTransport.d.ts +34 -0
- package/bin/agent/remote/transports/RpcRemoteAgentTransport.d.ts.map +1 -0
- package/bin/agent/remote/transports/RpcRemoteAgentTransport.js +66 -0
- package/bin/agent/remote/transports/RpcRemoteAgentTransport.js.map +1 -0
- package/bin/executor/Executor.d.ts +7 -20
- package/bin/executor/Executor.d.ts.map +1 -1
- package/bin/executor/Executor.js +77 -348
- package/bin/executor/Executor.js.map +1 -1
- package/bin/executor/SessionRunScope.d.ts +18 -34
- package/bin/executor/SessionRunScope.d.ts.map +1 -1
- package/bin/executor/SessionRunScope.js +42 -28
- package/bin/executor/SessionRunScope.js.map +1 -1
- package/bin/executor/composer/context/LocalSessionContextComposer.d.ts +5 -3
- package/bin/executor/composer/context/LocalSessionContextComposer.d.ts.map +1 -1
- package/bin/executor/composer/context/LocalSessionContextComposer.js +11 -18
- package/bin/executor/composer/context/LocalSessionContextComposer.js.map +1 -1
- package/bin/executor/composer/context/SessionContextComposer.d.ts +8 -3
- package/bin/executor/composer/context/SessionContextComposer.d.ts.map +1 -1
- package/bin/executor/composer/history/SessionHistoryWriter.js +2 -2
- package/bin/executor/composer/history/SessionHistoryWriter.js.map +1 -1
- package/bin/executor/composer/system/SessionSystemComposer.d.ts +2 -1
- package/bin/executor/composer/system/SessionSystemComposer.d.ts.map +1 -1
- package/bin/executor/composer/system/default/DefaultSessionSystemComposer.d.ts +2 -1
- package/bin/executor/composer/system/default/DefaultSessionSystemComposer.d.ts.map +1 -1
- package/bin/executor/composer/system/default/DefaultSessionSystemComposer.js +2 -4
- package/bin/executor/composer/system/default/DefaultSessionSystemComposer.js.map +1 -1
- package/bin/executor/core-engine/CoreEngineRunner.d.ts +62 -0
- package/bin/executor/core-engine/CoreEngineRunner.d.ts.map +1 -0
- package/bin/executor/core-engine/CoreEngineRunner.js +309 -0
- package/bin/executor/core-engine/CoreEngineRunner.js.map +1 -0
- package/bin/executor/core-engine/CoreEngineUiStreamCollector.d.ts +5 -0
- package/bin/executor/core-engine/CoreEngineUiStreamCollector.d.ts.map +1 -1
- package/bin/executor/core-engine/CoreEngineUiStreamCollector.js +2 -4
- package/bin/executor/core-engine/CoreEngineUiStreamCollector.js.map +1 -1
- package/bin/executor/messages/AssistantResultPersistence.d.ts +3 -3
- package/bin/executor/messages/AssistantResultPersistence.d.ts.map +1 -1
- package/bin/executor/messages/AssistantResultPersistence.js +2 -6
- package/bin/executor/messages/AssistantResultPersistence.js.map +1 -1
- package/bin/executor/messages/SessionStepEventMapper.d.ts +7 -8
- package/bin/executor/messages/SessionStepEventMapper.d.ts.map +1 -1
- package/bin/executor/messages/SessionStepEventMapper.js +55 -86
- package/bin/executor/messages/SessionStepEventMapper.js.map +1 -1
- package/bin/executor/messages/UserVisibleText.d.ts +2 -10
- package/bin/executor/messages/UserVisibleText.d.ts.map +1 -1
- package/bin/executor/messages/UserVisibleText.js +3 -16
- package/bin/executor/messages/UserVisibleText.js.map +1 -1
- package/bin/executor/services/ExecutorInflightService.d.ts +39 -0
- package/bin/executor/services/ExecutorInflightService.d.ts.map +1 -0
- package/bin/executor/services/ExecutorInflightService.js +75 -0
- package/bin/executor/services/ExecutorInflightService.js.map +1 -0
- package/bin/executor/services/ExecutorRecoveryPolicy.d.ts +103 -0
- package/bin/executor/services/ExecutorRecoveryPolicy.d.ts.map +1 -0
- package/bin/executor/services/ExecutorRecoveryPolicy.js +87 -0
- package/bin/executor/services/ExecutorRecoveryPolicy.js.map +1 -0
- package/bin/executor/store/history/SessionHistoryStore.d.ts +12 -0
- package/bin/executor/store/history/SessionHistoryStore.d.ts.map +1 -1
- package/bin/executor/store/history/jsonl/JsonlSessionHistoryStore.d.ts +12 -0
- package/bin/executor/store/history/jsonl/JsonlSessionHistoryStore.d.ts.map +1 -1
- package/bin/executor/store/history/jsonl/JsonlSessionHistoryStore.js +145 -8
- package/bin/executor/store/history/jsonl/JsonlSessionHistoryStore.js.map +1 -1
- package/bin/executor/tools/plugin/PluginToolBridge.d.ts +19 -0
- package/bin/executor/tools/plugin/PluginToolBridge.d.ts.map +1 -0
- package/bin/executor/tools/plugin/PluginToolBridge.js +143 -0
- package/bin/executor/tools/plugin/PluginToolBridge.js.map +1 -0
- package/bin/executor/tools/plugin/PluginToolDefinition.d.ts +32 -0
- package/bin/executor/tools/plugin/PluginToolDefinition.d.ts.map +1 -0
- package/bin/executor/tools/plugin/PluginToolDefinition.js +27 -0
- package/bin/executor/tools/plugin/PluginToolDefinition.js.map +1 -0
- package/bin/executor/tools/plugin/PluginToolSchemas.d.ts +14 -0
- package/bin/executor/tools/plugin/PluginToolSchemas.d.ts.map +1 -0
- package/bin/executor/tools/plugin/PluginToolSchemas.js +19 -0
- package/bin/executor/tools/plugin/PluginToolSchemas.js.map +1 -0
- package/bin/executor/tools/plugin/types/PluginTool.d.ts +39 -0
- package/bin/executor/tools/plugin/types/PluginTool.d.ts.map +1 -0
- package/bin/executor/tools/plugin/types/PluginTool.js +9 -0
- package/bin/executor/tools/plugin/types/PluginTool.js.map +1 -0
- package/bin/executor/tools/shell/ShellToolBridge.js +3 -3
- package/bin/executor/tools/shell/ShellToolBridge.js.map +1 -1
- package/bin/executor/tools/shell/ShellToolFormatting.d.ts +1 -10
- package/bin/executor/tools/shell/ShellToolFormatting.d.ts.map +1 -1
- package/bin/executor/tools/shell/ShellToolFormatting.js +1 -39
- package/bin/executor/tools/shell/ShellToolFormatting.js.map +1 -1
- package/bin/executor/types/SessionHistoryPaths.d.ts +4 -0
- package/bin/executor/types/SessionHistoryPaths.d.ts.map +1 -1
- package/bin/executor/types/SessionRun.d.ts +18 -0
- package/bin/executor/types/SessionRun.d.ts.map +1 -1
- package/bin/index.d.ts +15 -6
- package/bin/index.d.ts.map +1 -1
- package/bin/index.js +6 -3
- package/bin/index.js.map +1 -1
- package/bin/plugin/core/BasePlugin.d.ts +2 -2
- package/bin/plugin/core/BasePlugin.d.ts.map +1 -1
- package/bin/plugin/core/BasePlugin.js.map +1 -1
- package/bin/plugin/core/ImagePlugin.d.ts +56 -0
- package/bin/plugin/core/ImagePlugin.d.ts.map +1 -0
- package/bin/plugin/core/ImagePlugin.js +109 -0
- package/bin/plugin/core/ImagePlugin.js.map +1 -0
- package/bin/plugin/core/PluginCommandRequest.d.ts +1 -1
- package/bin/plugin/core/PluginCommandRequest.js +1 -1
- package/bin/plugin/core/PluginLocalExecution.js +1 -1
- package/bin/plugin/core/PluginLocalExecution.js.map +1 -1
- package/bin/plugin/core/ProjectConfigStore.d.ts +3 -2
- package/bin/plugin/core/ProjectConfigStore.d.ts.map +1 -1
- package/bin/plugin/core/ProjectConfigStore.js +3 -4
- package/bin/plugin/core/ProjectConfigStore.js.map +1 -1
- package/bin/plugin/types/Plugin.d.ts +10 -842
- package/bin/plugin/types/Plugin.d.ts.map +1 -1
- package/bin/plugin/types/Plugin.js +3 -4
- package/bin/plugin/types/Plugin.js.map +1 -1
- package/bin/plugin/types/PluginState.d.ts +1 -1
- package/bin/plugin/types/PluginState.d.ts.map +1 -1
- package/bin/rpc/Client.d.ts +2 -99
- package/bin/rpc/Client.d.ts.map +1 -1
- package/bin/rpc/Client.js +0 -46
- package/bin/rpc/Client.js.map +1 -1
- package/bin/rpc/Server.d.ts +5 -21
- package/bin/rpc/Server.d.ts.map +1 -1
- package/bin/rpc/Server.js +30 -315
- package/bin/rpc/Server.js.map +1 -1
- package/bin/rpc/server/InternalHandlers.d.ts +21 -0
- package/bin/rpc/server/InternalHandlers.d.ts.map +1 -0
- package/bin/rpc/server/InternalHandlers.js +190 -0
- package/bin/rpc/server/InternalHandlers.js.map +1 -0
- package/bin/rpc/server/RequestDispatcher.d.ts +27 -0
- package/bin/rpc/server/RequestDispatcher.d.ts.map +1 -0
- package/bin/rpc/server/RequestDispatcher.js +38 -0
- package/bin/rpc/server/RequestDispatcher.js.map +1 -0
- package/bin/rpc/server/SdkSessionHandlers.d.ts +25 -0
- package/bin/rpc/server/SdkSessionHandlers.d.ts.map +1 -0
- package/bin/rpc/server/SdkSessionHandlers.js +86 -0
- package/bin/rpc/server/SdkSessionHandlers.js.map +1 -0
- package/bin/rpc/server/ServerTypes.d.ts +59 -0
- package/bin/rpc/server/ServerTypes.d.ts.map +1 -0
- package/bin/rpc/server/ServerTypes.js +9 -0
- package/bin/rpc/server/ServerTypes.js.map +1 -0
- package/bin/{runtime/sandbox → sandbox}/MacOsSeatbeltSandbox.d.ts +1 -1
- package/bin/sandbox/MacOsSeatbeltSandbox.d.ts.map +1 -0
- package/bin/sandbox/MacOsSeatbeltSandbox.js.map +1 -0
- package/bin/{runtime/sandbox → sandbox}/SandboxConfigResolver.d.ts +2 -2
- package/bin/sandbox/SandboxConfigResolver.d.ts.map +1 -0
- package/bin/sandbox/SandboxConfigResolver.js.map +1 -0
- package/bin/{runtime/sandbox → sandbox}/SandboxRunner.d.ts +2 -2
- package/bin/sandbox/SandboxRunner.d.ts.map +1 -0
- package/bin/{runtime/sandbox → sandbox}/SandboxRunner.js +2 -2
- package/bin/sandbox/SandboxRunner.js.map +1 -0
- package/bin/sandbox/types/Sandbox.d.ts.map +1 -0
- package/bin/sandbox/types/Sandbox.js.map +1 -0
- package/bin/{runtime/sandbox → sandbox}/types/SandboxRuntime.d.ts +2 -2
- package/bin/sandbox/types/SandboxRuntime.d.ts.map +1 -0
- package/bin/sandbox/types/SandboxRuntime.js.map +1 -0
- package/bin/session/Session.d.ts +14 -83
- package/bin/session/Session.d.ts.map +1 -1
- package/bin/session/Session.js +140 -362
- package/bin/session/Session.js.map +1 -1
- package/bin/session/SessionSystemBuilder.d.ts +2 -1
- package/bin/session/SessionSystemBuilder.d.ts.map +1 -1
- package/bin/session/SessionSystemBuilder.js +2 -3
- package/bin/session/SessionSystemBuilder.js.map +1 -1
- package/bin/session/browse/Browse.d.ts +1 -1
- package/bin/session/browse/Browse.d.ts.map +1 -1
- package/bin/session/browse/Browse.js +28 -13
- package/bin/session/browse/Browse.js.map +1 -1
- package/bin/session/index.d.ts +1 -1
- package/bin/session/index.d.ts.map +1 -1
- package/bin/session/index.js +1 -1
- package/bin/session/index.js.map +1 -1
- package/bin/session/services/SessionStateService.d.ts +132 -0
- package/bin/session/services/SessionStateService.d.ts.map +1 -0
- package/bin/session/services/SessionStateService.js +242 -0
- package/bin/session/services/SessionStateService.js.map +1 -0
- package/bin/session/services/SessionTurnService.d.ts +66 -0
- package/bin/session/services/SessionTurnService.d.ts.map +1 -0
- package/bin/session/services/SessionTurnService.js +137 -0
- package/bin/session/services/SessionTurnService.js.map +1 -0
- package/bin/session/services/SessionViewService.d.ts +105 -0
- package/bin/session/services/SessionViewService.d.ts.map +1 -0
- package/bin/session/services/SessionViewService.js +184 -0
- package/bin/session/services/SessionViewService.js.map +1 -0
- package/bin/session/storage/Paths.d.ts +9 -0
- package/bin/session/storage/Paths.d.ts.map +1 -1
- package/bin/session/storage/Paths.js +11 -0
- package/bin/session/storage/Paths.js.map +1 -1
- package/bin/types/agent/AgentOptions.d.ts +152 -0
- package/bin/types/agent/AgentOptions.d.ts.map +1 -0
- package/bin/types/agent/AgentOptions.js +9 -0
- package/bin/types/agent/AgentOptions.js.map +1 -0
- package/bin/types/{runtime/host/AgentHost.d.ts → agent/AgentRuntimeAssembly.d.ts} +4 -4
- package/bin/types/agent/AgentRuntimeAssembly.d.ts.map +1 -0
- package/bin/types/{runtime/host/AgentHost.js → agent/AgentRuntimeAssembly.js} +3 -3
- package/bin/types/agent/AgentRuntimeAssembly.js.map +1 -0
- package/bin/types/agent/AgentTypes.d.ts +10 -613
- package/bin/types/agent/AgentTypes.d.ts.map +1 -1
- package/bin/types/agent/AgentTypes.js +4 -4
- package/bin/types/agent/RemoteAgentOptions.d.ts +28 -0
- package/bin/types/agent/RemoteAgentOptions.d.ts.map +1 -0
- package/bin/types/agent/RemoteAgentOptions.js +9 -0
- package/bin/types/agent/RemoteAgentOptions.js.map +1 -0
- package/bin/types/agent/SessionActor.d.ts +60 -0
- package/bin/types/agent/SessionActor.d.ts.map +1 -0
- package/bin/types/agent/SessionActor.js +9 -0
- package/bin/types/agent/SessionActor.js.map +1 -0
- package/bin/types/agent/SessionTypes.d.ts +312 -0
- package/bin/types/agent/SessionTypes.d.ts.map +1 -0
- package/bin/types/agent/SessionTypes.js +9 -0
- package/bin/types/agent/SessionTypes.js.map +1 -0
- package/bin/types/config/DowncityConfig.d.ts +1 -1
- package/bin/types/config/DowncityConfig.d.ts.map +1 -1
- package/bin/types/executor/SessionRunContext.d.ts +66 -0
- package/bin/types/executor/SessionRunContext.d.ts.map +1 -0
- package/bin/types/executor/SessionRunContext.js +10 -0
- package/bin/types/executor/SessionRunContext.js.map +1 -0
- package/bin/types/{runtime/host → platform}/Store.d.ts +1 -1
- package/bin/types/platform/Store.d.ts.map +1 -0
- package/bin/types/{runtime/host → platform}/Store.js +1 -1
- package/bin/types/platform/Store.js.map +1 -0
- package/bin/types/plugin/ImagePlugin.d.ts +94 -0
- package/bin/types/plugin/ImagePlugin.d.ts.map +1 -0
- package/bin/types/plugin/ImagePlugin.js +10 -0
- package/bin/types/plugin/ImagePlugin.js.map +1 -0
- package/bin/types/plugin/PluginAction.d.ts +119 -0
- package/bin/types/plugin/PluginAction.d.ts.map +1 -0
- package/bin/types/plugin/PluginAction.js +9 -0
- package/bin/types/plugin/PluginAction.js.map +1 -0
- package/bin/types/plugin/PluginCommand.d.ts +80 -0
- package/bin/types/plugin/PluginCommand.d.ts.map +1 -0
- package/bin/types/plugin/PluginCommand.js +9 -0
- package/bin/types/plugin/PluginCommand.js.map +1 -0
- package/bin/types/plugin/PluginDefinition.d.ts +57 -0
- package/bin/types/plugin/PluginDefinition.d.ts.map +1 -0
- package/bin/types/plugin/PluginDefinition.js +9 -0
- package/bin/types/plugin/PluginDefinition.js.map +1 -0
- package/bin/types/plugin/PluginHttp.d.ts +34 -0
- package/bin/types/plugin/PluginHttp.d.ts.map +1 -0
- package/bin/types/plugin/PluginHttp.js +9 -0
- package/bin/types/plugin/PluginHttp.js.map +1 -0
- package/bin/types/plugin/PluginRuntime.d.ts +148 -0
- package/bin/types/plugin/PluginRuntime.d.ts.map +1 -0
- package/bin/types/plugin/PluginRuntime.js +9 -0
- package/bin/types/plugin/PluginRuntime.js.map +1 -0
- package/bin/types/plugin/PluginSetup.d.ts +133 -0
- package/bin/types/plugin/PluginSetup.d.ts.map +1 -0
- package/bin/types/plugin/PluginSetup.js +9 -0
- package/bin/types/plugin/PluginSetup.js.map +1 -0
- package/bin/types/plugin/PluginState.d.ts +69 -0
- package/bin/types/plugin/PluginState.d.ts.map +1 -0
- package/bin/types/plugin/PluginState.js +9 -0
- package/bin/types/plugin/PluginState.js.map +1 -0
- package/bin/types/rpc/RpcProtocol.d.ts +323 -0
- package/bin/types/rpc/RpcProtocol.d.ts.map +1 -0
- package/bin/types/rpc/RpcProtocol.js +10 -0
- package/bin/types/rpc/RpcProtocol.js.map +1 -0
- package/bin/types/runtime/agent/AgentContext.d.ts +1 -1
- package/bin/types/runtime/agent/AgentContext.d.ts.map +1 -1
- package/bin/types/runtime/agent/AgentRuntime.d.ts +1 -1
- package/bin/types/runtime/agent/AgentRuntime.d.ts.map +1 -1
- package/bin/types/session/SessionComposerOptions.d.ts +90 -0
- package/bin/types/session/SessionComposerOptions.d.ts.map +1 -0
- package/bin/types/session/SessionComposerOptions.js +10 -0
- package/bin/types/session/SessionComposerOptions.js.map +1 -0
- package/bin/types/session/SessionLocalState.d.ts +35 -0
- package/bin/types/session/SessionLocalState.d.ts.map +1 -0
- package/bin/types/session/SessionLocalState.js +10 -0
- package/bin/types/session/SessionLocalState.js.map +1 -0
- package/bin/types/session/SessionOptions.d.ts +85 -0
- package/bin/types/session/SessionOptions.d.ts.map +1 -0
- package/bin/types/session/SessionOptions.js +10 -0
- package/bin/types/session/SessionOptions.js.map +1 -0
- package/package.json +2 -2
- package/scripts/session-history-inflight.test.mjs +146 -0
- package/src/agent/local/Agent.ts +197 -0
- package/src/agent/local/AgentInstructions.ts +68 -0
- package/src/agent/local/AgentPluginFactory.ts +83 -0
- package/src/{runtime/host/AgentHostRuntime.ts → agent/local/AgentRuntimeAssembly.ts} +2 -2
- package/src/agent/local/AgentRuntimeFactory.ts +152 -0
- package/src/{runtime/host → agent/local}/ProjectSetup.ts +1 -1
- package/src/agent/local/services/AgentAssemblyService.ts +268 -0
- package/src/agent/local/services/AgentLifecycleService.ts +187 -0
- package/src/agent/local/services/AgentSessionManager.ts +291 -0
- package/src/agent/remote/RemoteAgent.ts +76 -0
- package/src/agent/remote/RemoteSession.ts +287 -0
- package/src/agent/remote/RemoteTransport.ts +71 -0
- package/src/agent/remote/TransportFactory.ts +29 -0
- package/src/agent/remote/transports/HttpRemoteAgentTransport.ts +347 -0
- package/src/agent/remote/transports/RpcRemoteAgentTransport.ts +107 -0
- package/src/executor/Executor.ts +107 -426
- package/src/executor/README.md +4 -4
- package/src/executor/SessionRunScope.ts +47 -71
- package/src/executor/composer/context/LocalSessionContextComposer.ts +24 -20
- package/src/executor/composer/context/SessionContextComposer.ts +13 -3
- package/src/executor/composer/history/SessionHistoryWriter.ts +2 -2
- package/src/executor/composer/system/SessionSystemComposer.ts +2 -1
- package/src/executor/composer/system/default/DefaultSessionSystemComposer.ts +3 -4
- package/src/executor/core-engine/CoreEngineRunner.ts +433 -0
- package/src/executor/core-engine/CoreEngineUiStreamCollector.ts +7 -5
- package/src/executor/messages/AssistantResultPersistence.ts +4 -12
- package/src/executor/messages/SessionStepEventMapper.ts +59 -101
- package/src/executor/messages/UserVisibleText.ts +3 -18
- package/src/executor/services/ExecutorInflightService.ts +101 -0
- package/src/executor/services/ExecutorRecoveryPolicy.ts +213 -0
- package/src/executor/store/history/SessionHistoryStore.ts +15 -0
- package/src/executor/store/history/jsonl/JsonlSessionHistoryStore.ts +164 -11
- package/src/executor/tools/plugin/PluginToolBridge.ts +161 -0
- package/src/executor/tools/plugin/PluginToolDefinition.ts +32 -0
- package/src/executor/tools/plugin/PluginToolSchemas.ts +20 -0
- package/src/executor/tools/plugin/types/PluginTool.ts +41 -0
- package/src/executor/tools/shell/ShellToolBridge.ts +3 -3
- package/src/executor/tools/shell/ShellToolFormatting.ts +1 -50
- package/src/executor/types/SessionHistoryPaths.ts +5 -0
- package/src/executor/types/SessionRun.ts +20 -0
- package/src/index.ts +38 -5
- package/src/plugin/core/BasePlugin.ts +2 -2
- package/src/plugin/core/ImagePlugin.ts +128 -0
- package/src/plugin/core/PluginCommandRequest.ts +1 -1
- package/src/plugin/core/PluginLocalExecution.ts +1 -1
- package/src/plugin/core/ProjectConfigStore.ts +4 -4
- package/src/plugin/types/Plugin.ts +54 -913
- package/src/plugin/types/PluginState.ts +1 -1
- package/src/rpc/Client.ts +16 -322
- package/src/rpc/Server.ts +39 -565
- package/src/rpc/server/InternalHandlers.ts +230 -0
- package/src/rpc/server/RequestDispatcher.ts +67 -0
- package/src/rpc/server/SdkSessionHandlers.ts +106 -0
- package/src/rpc/server/ServerTypes.ts +65 -0
- package/src/{runtime/sandbox → sandbox}/MacOsSeatbeltSandbox.ts +1 -1
- package/src/{runtime/sandbox → sandbox}/SandboxConfigResolver.ts +1 -1
- package/src/{runtime/sandbox → sandbox}/SandboxRunner.ts +3 -3
- package/src/{runtime/sandbox → sandbox}/types/SandboxRuntime.ts +2 -2
- package/src/session/Session.ts +184 -485
- package/src/session/SessionSystemBuilder.ts +3 -3
- package/src/session/browse/Browse.ts +29 -10
- package/src/session/index.ts +1 -0
- package/src/session/services/SessionStateService.ts +341 -0
- package/src/session/services/SessionTurnService.ts +202 -0
- package/src/session/services/SessionViewService.ts +301 -0
- package/src/session/storage/Paths.ts +19 -0
- package/src/types/agent/AgentOptions.ts +172 -0
- package/src/types/{runtime/host/AgentHost.ts → agent/AgentRuntimeAssembly.ts} +2 -2
- package/src/types/agent/AgentTypes.ts +47 -709
- package/src/types/agent/RemoteAgentOptions.ts +29 -0
- package/src/types/agent/SessionActor.ts +88 -0
- package/src/types/agent/SessionTypes.ts +335 -0
- package/src/types/config/DowncityConfig.ts +1 -1
- package/src/types/executor/SessionRunContext.ts +76 -0
- package/src/types/{runtime/host → platform}/Store.ts +1 -1
- package/src/types/plugin/ImagePlugin.ts +103 -0
- package/src/types/plugin/PluginAction.ts +133 -0
- package/src/types/plugin/PluginCommand.ts +89 -0
- package/src/types/plugin/PluginDefinition.ts +74 -0
- package/src/types/plugin/PluginHttp.ts +36 -0
- package/src/types/plugin/PluginRuntime.ts +169 -0
- package/src/types/plugin/PluginSetup.ts +138 -0
- package/src/types/plugin/PluginState.ts +82 -0
- package/src/types/rpc/RpcProtocol.ts +361 -0
- package/src/types/runtime/agent/AgentContext.ts +1 -1
- package/src/types/runtime/agent/AgentRuntime.ts +1 -1
- package/src/types/session/SessionComposerOptions.ts +107 -0
- package/src/types/session/SessionLocalState.ts +40 -0
- package/src/types/session/SessionOptions.ts +99 -0
- package/tsconfig.tsbuildinfo +1 -1
- package/bin/agent/Agent.d.ts +0 -223
- package/bin/agent/Agent.d.ts.map +0 -1
- package/bin/agent/Agent.js +0 -627
- package/bin/agent/Agent.js.map +0 -1
- package/bin/agent/RemoteAgent.d.ts.map +0 -1
- package/bin/agent/RemoteAgent.js +0 -585
- package/bin/agent/RemoteAgent.js.map +0 -1
- package/bin/runtime/auth/AuthEnv.d.ts +0 -36
- package/bin/runtime/auth/AuthEnv.d.ts.map +0 -1
- package/bin/runtime/auth/AuthEnv.js +0 -54
- package/bin/runtime/auth/AuthEnv.js.map +0 -1
- package/bin/runtime/auth/CliAuthStateStore.d.ts +0 -29
- package/bin/runtime/auth/CliAuthStateStore.d.ts.map +0 -1
- package/bin/runtime/auth/CliAuthStateStore.js +0 -26
- package/bin/runtime/auth/CliAuthStateStore.js.map +0 -1
- package/bin/runtime/control/AuthControlService.d.ts +0 -34
- package/bin/runtime/control/AuthControlService.d.ts.map +0 -1
- package/bin/runtime/control/AuthControlService.js +0 -129
- package/bin/runtime/control/AuthControlService.js.map +0 -1
- package/bin/runtime/control/CommonHelpers.d.ts +0 -36
- package/bin/runtime/control/CommonHelpers.d.ts.map +0 -1
- package/bin/runtime/control/CommonHelpers.js +0 -63
- package/bin/runtime/control/CommonHelpers.js.map +0 -1
- package/bin/runtime/control/ExecuteBySession.d.ts +0 -30
- package/bin/runtime/control/ExecuteBySession.d.ts.map +0 -1
- package/bin/runtime/control/ExecuteBySession.js +0 -41
- package/bin/runtime/control/ExecuteBySession.js.map +0 -1
- package/bin/runtime/control/ExecuteInput.d.ts +0 -18
- package/bin/runtime/control/ExecuteInput.d.ts.map +0 -1
- package/bin/runtime/control/ExecuteInput.js +0 -201
- package/bin/runtime/control/ExecuteInput.js.map +0 -1
- package/bin/runtime/control/Helpers.d.ts +0 -13
- package/bin/runtime/control/Helpers.d.ts.map +0 -1
- package/bin/runtime/control/Helpers.js +0 -13
- package/bin/runtime/control/Helpers.js.map +0 -1
- package/bin/runtime/control/MessageTimeline.d.ts +0 -22
- package/bin/runtime/control/MessageTimeline.d.ts.map +0 -1
- package/bin/runtime/control/MessageTimeline.js +0 -226
- package/bin/runtime/control/MessageTimeline.js.map +0 -1
- package/bin/runtime/control/SessionSummaryStore.d.ts +0 -20
- package/bin/runtime/control/SessionSummaryStore.d.ts.map +0 -1
- package/bin/runtime/control/SessionSummaryStore.js +0 -50
- package/bin/runtime/control/SessionSummaryStore.js.map +0 -1
- package/bin/runtime/control/TaskStore.d.ts +0 -33
- package/bin/runtime/control/TaskStore.d.ts.map +0 -1
- package/bin/runtime/control/TaskStore.js +0 -175
- package/bin/runtime/control/TaskStore.js.map +0 -1
- package/bin/runtime/control/types/AuthControl.d.ts +0 -30
- package/bin/runtime/control/types/AuthControl.d.ts.map +0 -1
- package/bin/runtime/control/types/AuthControl.js +0 -9
- package/bin/runtime/control/types/AuthControl.js.map +0 -1
- package/bin/runtime/control/types/ControlSessionExecute.d.ts +0 -85
- package/bin/runtime/control/types/ControlSessionExecute.d.ts.map +0 -1
- package/bin/runtime/control/types/ControlSessionExecute.js +0 -9
- package/bin/runtime/control/types/ControlSessionExecute.js.map +0 -1
- package/bin/runtime/control/types/ControlViewData.d.ts +0 -320
- package/bin/runtime/control/types/ControlViewData.d.ts.map +0 -1
- package/bin/runtime/control/types/ControlViewData.js +0 -9
- package/bin/runtime/control/types/ControlViewData.js.map +0 -1
- package/bin/runtime/host/AgentHostRuntime.d.ts.map +0 -1
- package/bin/runtime/host/AgentHostRuntime.js.map +0 -1
- package/bin/runtime/host/ProjectSetup.d.ts.map +0 -1
- package/bin/runtime/host/ProjectSetup.js.map +0 -1
- package/bin/runtime/sandbox/MacOsSeatbeltSandbox.d.ts.map +0 -1
- package/bin/runtime/sandbox/MacOsSeatbeltSandbox.js.map +0 -1
- package/bin/runtime/sandbox/SandboxConfigResolver.d.ts.map +0 -1
- package/bin/runtime/sandbox/SandboxConfigResolver.js.map +0 -1
- package/bin/runtime/sandbox/SandboxRunner.d.ts.map +0 -1
- package/bin/runtime/sandbox/SandboxRunner.js.map +0 -1
- package/bin/runtime/sandbox/types/Sandbox.d.ts.map +0 -1
- package/bin/runtime/sandbox/types/Sandbox.js.map +0 -1
- package/bin/runtime/sandbox/types/SandboxRuntime.d.ts.map +0 -1
- package/bin/runtime/sandbox/types/SandboxRuntime.js.map +0 -1
- package/bin/types/runtime/host/AgentHost.d.ts.map +0 -1
- package/bin/types/runtime/host/AgentHost.js.map +0 -1
- package/bin/types/runtime/host/Store.d.ts.map +0 -1
- package/bin/types/runtime/host/Store.js.map +0 -1
- package/src/agent/Agent.ts +0 -734
- package/src/agent/RemoteAgent.ts +0 -834
- package/src/runtime/auth/AuthEnv.ts +0 -62
- package/src/runtime/auth/CliAuthStateStore.ts +0 -46
- package/src/runtime/control/AuthControlService.ts +0 -169
- package/src/runtime/control/CommonHelpers.ts +0 -69
- package/src/runtime/control/ExecuteBySession.ts +0 -52
- package/src/runtime/control/ExecuteInput.ts +0 -236
- package/src/runtime/control/Helpers.ts +0 -22
- package/src/runtime/control/MessageTimeline.ts +0 -269
- package/src/runtime/control/SessionSummaryStore.ts +0 -72
- package/src/runtime/control/TaskStore.ts +0 -242
- package/src/runtime/control/types/AuthControl.ts +0 -34
- package/src/runtime/control/types/ControlSessionExecute.ts +0 -99
- package/src/runtime/control/types/ControlViewData.ts +0 -392
- /package/bin/{runtime/sandbox → sandbox}/MacOsSeatbeltSandbox.js +0 -0
- /package/bin/{runtime/sandbox → sandbox}/SandboxConfigResolver.js +0 -0
- /package/bin/{runtime/sandbox → sandbox}/types/Sandbox.d.ts +0 -0
- /package/bin/{runtime/sandbox → sandbox}/types/Sandbox.js +0 -0
- /package/bin/{runtime/sandbox → sandbox}/types/SandboxRuntime.js +0 -0
- /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
|
-
*
|
|
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/
|
|
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
|
+
}
|
|
@@ -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
|
+
}
|