chore(agent): start rpc worker at launch, fail if not running

This commit is contained in:
Peter Steinberger
2025-12-07 05:24:54 +01:00
parent fb106967bc
commit 2f44046622
2 changed files with 8 additions and 8 deletions

View File

@@ -14,8 +14,10 @@ actor AgentRPC {
private struct RpcError: Error { let message: String }
func send(text: String, thinking: String?, session: String) async -> (ok: Bool, text: String?, error: String?) {
guard process?.isRunning == true else {
return (false, nil, "rpc worker not running")
}
do {
try await ensureRunning()
let payload: [String: Any] = [
"type": "send",
"text": text,
@@ -54,8 +56,10 @@ actor AgentRPC {
}
func status() async -> (ok: Bool, error: String?) {
guard process?.isRunning == true else {
return (false, "rpc worker not running")
}
do {
try await ensureRunning()
let payload: [String: Any] = ["type": "status"]
let data = try JSONSerialization.data(withJSONObject: payload)
guard let stdinHandle else { throw RpcError(message: "stdin missing") }
@@ -75,12 +79,7 @@ actor AgentRPC {
// MARK: - Process lifecycle
private func ensureRunning() async throws {
if let process, process.isRunning { return }
try await start()
}
private func start() async throws {
func start() async throws {
let process = Process()
process.executableURL = URL(fileURLWithPath: "/usr/bin/env")
process.arguments = ["pnpm", "clawdis", "rpc"]

View File

@@ -426,6 +426,7 @@ final class AppDelegate: NSObject, NSApplicationDelegate, NSXPCListenerDelegate
if let state {
RelayProcessManager.shared.setActive(!state.isPaused)
}
Task { try? await AgentRPC.shared.start() }
self.startListener()
self.scheduleFirstRunOnboardingIfNeeded()