Uninstall Zirkabot completely (CLI, service, state, workspace)

Read when…
  • You want to remove Zirkabot from a machine
  • The gateway service is still running after uninstall

Uninstall

Two paths:

  • Easy path if zirkabot is still installed.
  • Manual service removal if the CLI is gone but the service is still running.

Easy path (CLI still installed)

Recommended: use the built-in uninstaller:

zirkabot uninstall

Non-interactive (automation / npx):

zirkabot uninstall --all --yes --non-interactive
npx -y zirkabot uninstall --all --yes --non-interactive

Manual steps (same result):

  1. Stop the gateway service:
zirkabot gateway stop
  1. Uninstall the gateway service (launchd/systemd/schtasks):
zirkabot gateway uninstall
  1. Delete state + config:
rm -rf "${ZIRKABOT_STATE_DIR:-$HOME/.zirkabot}"

If you set ZIRKABOT_CONFIG_PATH to a custom location outside the state dir, delete that file too.

  1. Delete your workspace (optional, removes agent files):
rm -rf ~/zirka
  1. Remove the CLI install (pick the one you used):
npm rm -g zirkabot
pnpm remove -g zirkabot
bun remove -g zirkabot
  1. If you installed the macOS app:
rm -rf /Applications/Zirkabot.app

Notes:

  • If you used profiles (--profile / ZIRKABOT_PROFILE), repeat step 3 for each state dir (defaults are ~/.zirkabot-<profile>).
  • In remote mode, the state dir lives on the gateway host, so run steps 1-4 there too.

Manual service removal (CLI not installed)

Use this if the gateway service keeps running but zirkabot is missing.

macOS (launchd)

Default label is com.zirkabot.gateway (or com.zirkabot.<profile>):

launchctl bootout gui/$UID/com.zirkabot.gateway
rm -f ~/Library/LaunchAgents/com.zirkabot.gateway.plist

If you used a profile, replace the label and plist name with com.zirkabot.<profile>.

Linux (systemd user unit)

Default unit name is zirkabot-gateway.service (or zirkabot-gateway-<profile>.service):

systemctl --user disable --now zirkabot-gateway.service
rm -f ~/.config/systemd/user/zirkabot-gateway.service
systemctl --user daemon-reload

Windows (Scheduled Task)

Default task name is Zirkabot Gateway (or Zirkabot Gateway (<profile>)). The task script lives under your state dir.

schtasks /Delete /F /TN "Zirkabot Gateway"
Remove-Item -Force "$env:USERPROFILE\.zirkabot\gateway.cmd"

If you used a profile, delete the matching task name and ~\.zirkabot-<profile>\gateway.cmd.

Normal install vs source checkout

Normal install (install.sh / npm / pnpm / bun)

If you used https://zirka.bot/install.sh or install.ps1, the CLI was installed with npm install -g zirkabot@latest. Remove it with npm rm -g zirkabot (or pnpm remove -g / bun remove -g if you installed that way).

Source checkout (git clone)

If you run from a repo checkout (git clone + zirkabot ... / bun run zirkabot ...):

  1. Uninstall the gateway service before deleting the repo (use the easy path above or manual service removal).
  2. Delete the repo directory.
  3. Remove state + workspace as shown above.