hephaestus/docs
Erich Blume b04a71421e
All checks were successful
Build / validate (pull_request) Successful in 8m7s
fix(hephd): reconnect the socket client across daemon restarts
`Client` connected to the unix socket once and never reconnected, so after an
opt-in self-update or `heph daemon restart` dropped the socket, every later
`call()` failed — `heph-tui` would sit on errors until relaunched (and the work
we just shipped makes restarts more frequent).

`Client` now stores the socket path and reconnects on a dropped connection,
classifying the failure to stay safe:
- write-side failure (request never reached the daemon) → reconnect + retry once;
- reply lost after sending (daemon closed mid-request) → reconnect for next time
  but surface this one, so a mutation is never silently double-applied;
- genuine RPC errors are passed through untouched.

heph-tui and the CLI use `Client` unchanged, so the TUI self-heals on its next
refresh tick. Adds an integration test driving a mock daemon that drops the
connection after each request.

Closes the "heph-tui: reconnect on a dropped daemon socket" backlog task.

Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
2026-06-08 15:19:10 -07:00
..
changelog.d fix(hephd): reconnect the socket client across daemon restarts 2026-06-08 15:19:10 -07:00
explanation doc(explanation): hub+spoke data-evolution / migration rules 2026-06-05 17:31:11 -07:00
how-to fix(hephd): reconnect the socket client across daemon restarts 2026-06-08 15:19:10 -07:00
reference docs: release bumps Cargo.toml/lock on a tag-only commit; --version reports X.Y.Z (sha) 2026-06-04 09:37:14 -07:00
tutorials Set up hephaestus from template and add design + tech spec 2026-05-31 09:37:28 -07:00
index.md Initial commit 2026-05-31 06:13:36 -07:00
quartz.config.ts Set up hephaestus from template and add design + tech spec 2026-05-31 09:37:28 -07:00
quartz.layout.ts Initial commit 2026-05-31 06:13:36 -07:00