fix(uninstall): wildcard env cleanup + AUTH_TOKEN + npm + claude README (Item 18)

User asked: do per-tool READMEs document uninstall? Sub-agent audit
(gpt-5.5 sh + glm-5.1 ps1) found multiple BLOCKERs in uninstall scripts.

Fixes:

1. claude/README.md — added Uninstall section (was missing — other tools'
   READMEs already documented theirs).

2. All 4 ps1 uninstallers (claude/codex/gemini/qwen) — wildcard env-var
   cleanup by prefix. Was: hardcoded list missed *_AUTH_TOKEN, leaving
   stale token after uninstall → Auth conflict warning on reinstall
   (root cause user reported on Windows).
   Prefixes:
     claude → ANTHROPIC_*, CLAUDE_*, DISABLE_TELEMETRY, ...
     codex  → OPENAI_*
     gemini → GEMINI_*, GOOGLE_API_KEY, GOOGLE_CLOUD_PROJECT
     qwen   → QWEN_*, DASHSCOPE_*

3. codex/ucodex_uninstall.ps1 — added `npm uninstall -g @openai/codex`
   step (was missing — npm package would survive uninstall).

4. codex/ucodex_uninstall.ps1 — also clears npm registry override
   `@openai:registry`.

Audit also flagged (NOT applied — defer to next iteration):
- sh: overly broad `sed '/PATTERN/d'` deletes unrelated user lines
  (could damage user's .bashrc — use marker comments instead)
- sh: missing /var/root scan (macOS root user)
- sh: missing systemd/LaunchAgent cleanup
- sh: backup restore not implemented
- All: should preserve some user data (history, projects) — current
  behavior is destructive

Tests: tests/test_uninstall_completeness.py — 10 GREEN regression guards
(prefix wildcard works, README has section, sh uses portable sed,
codex npm uninstall present).

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
This commit is contained in:
delta-cloud-208e
2026-04-25 18:03:41 +00:00
parent 06057f864b
commit 134606839a
5 changed files with 101 additions and 5 deletions

View File

@@ -9,6 +9,15 @@ Write-Host " | Codex CLI -- Windows Uninstaller |" -ForegroundColor Cyan
Write-Host " +--------------------------------------+" -ForegroundColor Cyan
Write-Host ""
# ---- Optionally remove npm package (if codex was installed via @openai/codex) ----
if (Get-Command npm -ErrorAction SilentlyContinue) {
Write-Host " Removing @openai/codex npm package (if present)..." -ForegroundColor Cyan
npm uninstall -g @openai/codex 2>$null | Out-Null
npm config delete "@openai:registry" 2>$null | Out-Null
Write-Host " npm cleanup done (no-op if not installed via npm)" -ForegroundColor Green
}
# ---- Remove binary ----
$installDir = "$env:LOCALAPPDATA\Programs\codex"
@@ -23,7 +32,22 @@ if (Test-Path "$installDir\codex.exe") {
$userPath = [System.Environment]::GetEnvironmentVariable("Path", "User")
if ($userPath -like "*$installDir*") {
$newPath = ($userPath -split ";" | Where-Object { $_ -ne $installDir }) -join ";"
[System.Environment]::SetEnvironmentVariable("Path", $newPath, "User")
# >>> wildcard env cleanup (Item 18 audit) <<<
$prefixesToRemove = @("OPENAI_")
$userVars = [System.Environment]::GetEnvironmentVariables("User")
foreach ($name in @($userVars.Keys)) {
foreach ($p in $prefixesToRemove) {
if ($name -like "${p}*" -or $name -eq $p) {
[System.Environment]::SetEnvironmentVariable($name, $null, "User")
Remove-Item -Path "Env:\$name" -ErrorAction SilentlyContinue
Write-Host " Removed env: $name" -ForegroundColor Cyan
break
}
}
}
# <<< end wildcard cleanup >>>
[System.Environment]::SetEnvironmentVariable("Path", $newPath, "User")
Write-Host " Removed from PATH" -ForegroundColor Green
}
} else {