Updating
Updating
Section titled “Updating”CoderClaw is moving fast (pre “1.0”). Treat updates like shipping infra: update → run checks → restart (or use coderclaw update, which restarts) → verify.
Recommended: re-run the website installer (upgrade in place)
Section titled “Recommended: re-run the website installer (upgrade in place)”The preferred update path is to re-run the installer from the website. It
detects existing installs, upgrades in place, and runs coderclaw doctor when
needed.
curl -fsSL https://coderclaw.ai/install.sh | bashNotes:
-
Add
--no-onboardif you don’t want the onboarding wizard to run again. -
For source installs, use:
Terminal window curl -fsSL https://coderclaw.ai/install.sh | bash -s -- --install-method git --no-onboardThe installer will
git pull --rebaseonly if the repo is clean. -
For global installs, the script uses
npm install -g coderclaw@latestunder the hood. -
Legacy note:
coderclawremains available as a compatibility shim.
Before you update
Section titled “Before you update”- Know how you installed: global (npm/pnpm) vs from source (git clone).
- Know how your Gateway is running: foreground terminal vs supervised service (launchd/systemd).
- Snapshot your tailoring:
- Config:
~/.coderclaw/coderclaw.json - Credentials:
~/.coderclaw/credentials/ - Workspace:
~/.coderclaw/workspace
- Config:
Update (global install)
Section titled “Update (global install)”Global install (pick one):
npm i -g coderclaw@latestpnpm add -g coderclaw@latestWe do not recommend Bun for the Gateway runtime (WhatsApp/Telegram bugs).
To switch update channels (git + npm installs):
coderclaw update --channel betacoderclaw update --channel devcoderclaw update --channel stableUse --tag <dist-tag|version> for a one-off install tag/version.
See Development channels for channel semantics and release notes.
Note: on npm installs, the gateway logs an update hint on startup (checks the current channel tag). Disable via update.checkOnStart: false.
Then:
coderclaw doctorcoderclaw gateway restartcoderclaw healthNotes:
- If your Gateway runs as a service,
coderclaw gateway restartis preferred over killing PIDs. - If you’re pinned to a specific version, see “Rollback / pinning” below.
Update (coderclaw update)
Section titled “Update (coderclaw update)”For source installs (git checkout), prefer:
coderclaw updateIt runs a safe-ish update flow:
- Requires a clean worktree.
- Switches to the selected channel (tag or branch).
- Fetches + rebases against the configured upstream (dev channel).
- Installs deps, builds, builds the Control UI, and runs
coderclaw doctor. - Restarts the gateway by default (use
--no-restartto skip).
If you installed via npm/pnpm (no git metadata), coderclaw update will try to update via your package manager. If it can’t detect the install, use “Update (global install)” instead.
Update (Control UI / RPC)
Section titled “Update (Control UI / RPC)”The Control UI has Update & Restart (RPC: update.run). It:
- Runs the same source-update flow as
coderclaw update(git checkout only). - Writes a restart sentinel with a structured report (stdout/stderr tail).
- Restarts the gateway and pings the last active session with the report.
If the rebase fails, the gateway aborts and restarts without applying the update.
Update (from source)
Section titled “Update (from source)”From the repo checkout:
Preferred:
coderclaw updateManual (equivalent-ish):
git pullpnpm installpnpm buildpnpm ui:build # auto-installs UI deps on first runcoderclaw doctorcoderclaw healthNotes:
pnpm buildmatters when you run the packagedcoderclawbinary (coderclaw.mjs) or use Node to rundist/.- If you run from a repo checkout without a global install, use
pnpm coderclaw ...for CLI commands. - If you run directly from TypeScript (
pnpm coderclaw ...), a rebuild is usually unnecessary, but config migrations still apply → run doctor. - Switching between global and git installs is easy: install the other flavor, then run
coderclaw doctorso the gateway service entrypoint is rewritten to the current install.
Always Run: coderclaw doctor
Section titled “Always Run: coderclaw doctor”Doctor is the “safe update” command. It’s intentionally boring: repair + migrate + warn.
Note: if you’re on a source install (git checkout), coderclaw doctor will offer to run coderclaw update first.
Typical things it does:
- Migrate deprecated config keys / legacy config file locations.
- Audit DM policies and warn on risky “open” settings.
- Check Gateway health and can offer to restart.
- Detect and migrate older gateway services (launchd/systemd; legacy schtasks) to current CoderClaw services.
- On Linux, ensure systemd user lingering (so the Gateway survives logout).
Details: Doctor
Start / stop / restart the Gateway
Section titled “Start / stop / restart the Gateway”CLI (works regardless of OS):
coderclaw gateway statuscoderclaw gateway stopcoderclaw gateway restartcoderclaw gateway --port 18789coderclaw logs --followIf you’re supervised:
- macOS launchd (app-bundled LaunchAgent):
launchctl kickstart -k gui/$UID/bot.molt.gateway(usebot.molt.<profile>; legacycom.coderclaw.*still works) - Linux systemd user service:
systemctl --user restart coderclaw-gateway[-<profile>].service - Windows (WSL2):
systemctl --user restart coderclaw-gateway[-<profile>].servicelaunchctl/systemctlonly work if the service is installed; otherwise runcoderclaw gateway install.
Runbook + exact service labels: Gateway runbook
Rollback / pinning (when something breaks)
Section titled “Rollback / pinning (when something breaks)”Pin (global install)
Section titled “Pin (global install)”Install a known-good version (replace <version> with the last working one):
npm i -g coderclaw@<version>pnpm add -g coderclaw@<version>Tip: to see the current published version, run npm view coderclaw version.
Then restart + re-run doctor:
coderclaw doctorcoderclaw gateway restartPin (source) by date
Section titled “Pin (source) by date”Pick a commit from a date (example: “state of main as of 2026-01-01”):
git fetch origingit checkout "$(git rev-list -n 1 --before=\"2026-01-01\" origin/main)"Then reinstall deps + restart:
pnpm installpnpm buildcoderclaw gateway restartIf you want to go back to latest later:
git checkout maingit pullIf you’re stuck
Section titled “If you’re stuck”- Run
coderclaw doctoragain and read the output carefully (it often tells you the fix). - Check: Troubleshooting
- Ask in Discord: https://discord.gg/9gUsc2sNG6