> ## Documentation Index
> Fetch the complete documentation index at: https://docs.equa.cc/llms.txt
> Use this file to discover all available pages before exploring further.

# Updating

# Updating

Equabot is moving fast (pre “1.0”). Treat updates like shipping infra: update → run checks → restart (or use `equabot update`, which restarts) → verify.

## 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 `equabot doctor` when
needed.

```bash theme={null}
curl -fsSL https://equabot.com/install.sh | bash
```

Notes:

* Add `--no-onboard` if you don’t want the onboarding wizard to run again.
* For **source installs**, use:
  ```bash theme={null}
  curl -fsSL https://equabot.com/install.sh | bash -s -- --install-method git --no-onboard
  ```
  The installer will `git pull --rebase` **only** if the repo is clean.
* For **global installs**, the script uses `npm install -g equabot@latest` under the hood.

## 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: `~/.equabot/equabot.json`
  * Credentials: `~/.equabot/credentials/`
  * Workspace: `~/equa`

## Update (global install)

Global install (pick one):

```bash theme={null}
npm i -g equabot@latest
```

```bash theme={null}
pnpm add -g equabot@latest
```

We do **not** recommend Bun for the Gateway runtime (WhatsApp/Telegram bugs).

To switch update channels (git + npm installs):

```bash theme={null}
equabot update --channel beta
equabot update --channel dev
equabot update --channel stable
```

Use `--tag <dist-tag|version>` for a one-off install tag/version.

See [Development channels](/install/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:

```bash theme={null}
equabot doctor
equabot gateway restart
equabot health
```

Notes:

* If your Gateway runs as a service, `equabot gateway restart` is preferred over killing PIDs.
* If you’re pinned to a specific version, see “Rollback / pinning” below.

## Update (`equabot update`)

For **source installs** (git checkout), prefer:

```bash theme={null}
equabot update
```

It 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 `equabot doctor`.
* Restarts the gateway by default (use `--no-restart` to skip).

If you installed via **npm/pnpm** (no git metadata), `equabot 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)

The Control UI has **Update & Restart** (RPC: `update.run`). It:

1. Runs the same source-update flow as `equabot update` (git checkout only).
2. Writes a restart sentinel with a structured report (stdout/stderr tail).
3. 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)

From the repo checkout:

Preferred:

```bash theme={null}
equabot update
```

Manual (equivalent-ish):

```bash theme={null}
git pull
pnpm install
pnpm build
pnpm ui:build # auto-installs UI deps on first run
equabot doctor
equabot health
```

Notes:

* `pnpm build` matters when you run the packaged `equabot` binary ([`dist/entry.js`](https://github.com/equabot/equabot/blob/main/dist/entry.js)) or use Node to run `dist/`.
* If you run from a repo checkout without a global install, use `pnpm equabot ...` for CLI commands.
* If you run directly from TypeScript (`pnpm equabot ...`), 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 `equabot doctor` so the gateway service entrypoint is rewritten to the current install.

## Always run: `equabot doctor`

Doctor is the “safe update” command. It’s intentionally boring: repair + migrate + warn.

Note: if you’re on a **source install** (git checkout), `equabot doctor` will offer to run `equabot 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 Equabot services.
* On Linux, ensure systemd user lingering (so the Gateway survives logout).

Details: [Doctor](/gateway/doctor)

## Start / stop / restart the Gateway

CLI (works regardless of OS):

```bash theme={null}
equabot gateway status
equabot gateway stop
equabot gateway restart
equabot gateway --port 18789
equabot logs --follow
```

If you’re supervised:

* macOS launchd (app-bundled LaunchAgent): `launchctl kickstart -k gui/$UID/com.equabot.gateway` (use `com.equabot.<profile>` if set)
* Linux systemd user service: `systemctl --user restart equabot-gateway[-<profile>].service`
* Windows (WSL2): `systemctl --user restart equabot-gateway[-<profile>].service`
  * `launchctl`/`systemctl` only work if the service is installed; otherwise run `equabot gateway install`.

Runbook + exact service labels: [Gateway runbook](/gateway)

## Rollback / pinning (when something breaks)

### Pin (global install)

Install a known-good version (replace `<version>` with the last working one):

```bash theme={null}
npm i -g equabot@<version>
```

```bash theme={null}
pnpm add -g equabot@<version>
```

Tip: to see the current published version, run `npm view equabot version`.

Then restart + re-run doctor:

```bash theme={null}
equabot doctor
equabot gateway restart
```

### Pin (source) by date

Pick a commit from a date (example: “state of main as of 2026-01-01”):

```bash theme={null}
git fetch origin
git checkout "$(git rev-list -n 1 --before=\"2026-01-01\" origin/main)"
```

Then reinstall deps + restart:

```bash theme={null}
pnpm install
pnpm build
equabot gateway restart
```

If you want to go back to latest later:

```bash theme={null}
git checkout main
git pull
```

## If you’re stuck

* Run `equabot doctor` again and read the output carefully (it often tells you the fix).
* Check: [Troubleshooting](/gateway/troubleshooting)
* Ask in Discord: [https://channels.discord.gg/equabot](https://channels.discord.gg/equabot)
