fix(cli): 1.31.2 — daemon paths no longer follow per-session CLAUDEMESH_CONFIG_DIR
Real production bug observed in 1.31.0 / 1.31.1: every CLI verb from inside a claudemesh launch-spawned session printed [claudemesh] warn service-managed daemon not responding within 8000ms even when the launchd-managed daemon was healthy and answering direct UDS probes in 10ms. Root cause: claudemesh launch exports CLAUDEMESH_CONFIG_DIR to a per-session tmpdir so joined-mesh state and the IPC session token stay isolated. DAEMON_PATHS read from the same env, so inside a launched session the CLI looked for daemon.sock at /var/folders/.../claudemesh-XXXX/daemon/daemon.sock — which never exists. The CLI declared the daemon down, fell into the service- managed wait branch, and timed out. The daemon is a per-machine singleton serving every session; its files live at ~/.claudemesh/daemon/ regardless of overlays. Pin DAEMON_PATHS.DAEMON_DIR to that location. New CLAUDEMESH_DAEMON_DIR override is preserved for tests and multi-daemon dev setups. Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
This commit is contained in:
@@ -1,5 +1,36 @@
|
||||
# Changelog
|
||||
|
||||
## 1.31.2 (2026-05-04) — daemon paths no longer follow per-session CLAUDEMESH_CONFIG_DIR
|
||||
|
||||
**Production bug observed in real installs:** every CLI verb invoked from
|
||||
inside a `claudemesh launch`-spawned session printed
|
||||
|
||||
```
|
||||
[claudemesh] warn service-managed daemon not responding within 8000ms
|
||||
```
|
||||
|
||||
even when the launchd-managed daemon was healthy and responding to
|
||||
direct probes in ~10 ms.
|
||||
|
||||
Root cause: `claudemesh launch` exports `CLAUDEMESH_CONFIG_DIR` to a
|
||||
per-session tmpdir so that joined-mesh state and the session IPC
|
||||
token stay isolated from the host's shared config. `DAEMON_PATHS`
|
||||
read its base directory from the same env var, so inside a launched
|
||||
session the CLI looked for `daemon.sock` at e.g.
|
||||
`/var/folders/.../claudemesh-XXXX/daemon/daemon.sock` — which never
|
||||
exists. The CLI declared the daemon down, fell into the
|
||||
service-managed wait branch, and timed out.
|
||||
|
||||
The daemon is a per-machine singleton serving every session; its
|
||||
files belong at `~/.claudemesh/daemon/` regardless of any per-session
|
||||
overlay. Fix: pin `DAEMON_PATHS.DAEMON_DIR` to `~/.claudemesh/daemon/`
|
||||
and ignore `CLAUDEMESH_CONFIG_DIR`. A new `CLAUDEMESH_DAEMON_DIR`
|
||||
override is preserved for tests / multi-daemon dev setups; production
|
||||
callers should never set it.
|
||||
|
||||
After this fix, all CLI verbs from within a launched session take the
|
||||
warm-path (~10 ms IPC) again instead of the cold path (~600-1200 ms).
|
||||
|
||||
## 1.31.1 (2026-05-04) — hotfix: reaper stops blocking the daemon event loop
|
||||
|
||||
1.31.0 shipped a session reaper that called `execFileSync("ps")`
|
||||
|
||||
Reference in New Issue
Block a user