ccc is a CLI tool that provides seamless provider switching for Claude Code. Switch between Kimi, GLM, MiniMax, and other providers with one command.
OS=$(uname -s | tr '[:upper:]' '[:lower:]'); ARCH=$(uname -m | sed -e 's/x86_64/amd64/' -e 's/aarch64/arm64/'); curl -LO "https://github.com/guyskk/claude-code-config-switcher/releases/latest/download/ccc-${OS}-${ARCH}" && sudo install -m 755 "ccc-${OS}-${ARCH}" /usr/local/bin/ccc && rm "ccc-${OS}-${ARCH}" && ccc --versionOption B: Download from Releases
Download the binary for your platform (ccc-darwin-arm64, ccc-linux-amd64, etc.) and install to /usr/local/bin/.
If you already have ~/.claude/settings.json, the first time you run ccc it will prompt to migrate and automatically generate the ccc config at ~/.claude/ccc.json.
You can also create the config file manually:
{
"settings": {
"permissions": {
"defaultMode": "bypassPermissions"
}
},
"providers": {
"glm": {
"env": {
"ANTHROPIC_BASE_URL": "https://open.bigmodel.cn/api/anthropic",
"ANTHROPIC_AUTH_TOKEN": "YOUR_API_KEY_HERE",
"ANTHROPIC_MODEL": "glm-4.7"
}
},
"kimi": {
"env": {
"ANTHROPIC_BASE_URL": "https://api.moonshot.cn/anthropic",
"ANTHROPIC_AUTH_TOKEN": "YOUR_API_KEY_HERE",
"ANTHROPIC_MODEL": "kimi-k2-thinking"
}
}
}
}Security Warning:
bypassPermissionsallows Claude Code to execute tools without confirmation. Only use this in trusted environments.
# Show help
ccc --help
# Switch to a provider and run Claude Code
ccc glm
# Run with current provider
ccc
# Pass any Claude Code arguments
ccc glm -pVerify your provider configuration:
# Validate current provider
ccc validate
# Validate all providers
ccc validate --allMake ccc your default Claude Code by replacing the system claude command.
# Replace claude command with ccc (requires sudo)
sudo ccc patch
# After patching, `claude` command now uses ccc
claude --help # Shows ccc help
# Restore original claude command
sudo ccc patch --resetConfig file location, default: ~/.claude/ccc.json
When you run ccc, your existing settings.json is read and deep-merged with ccc.json. Priority: user settings.json > provider > base settings. Your manual edits, plugins, and hooks are preserved; provider env is passed via command line and never written into settings.json.
Claude Code's settings.json env field overrides environment variables passed by ccc when launching claude. If settings.json shadows provider env, switching silently fails (wrong base_url / token / model).
ccc refuses to start claude — and refuses to run ccc validate — when it detects such conflicts. It prints the offending keys (without values, to avoid leaking secrets) and never modifies your settings.json env field.
A key is considered conflicting if it:
- starts with
ANTHROPIC_orCLAUDE_, or - collides with any key defined in ccc.json's base / provider
env.
How to fix: remove those keys from ~/.claude/settings.json's env and move provider-related configuration into providers.<name>.env in ~/.claude/ccc.json.
{
"settings": {
"permissions": {
"defaultMode": "bypassPermissions"
},
"alwaysThinkingEnabled": true
},
"claude_args": ["--verbose"],
"current_provider": "glm",
"providers": {
"glm": {
"env": {
"ANTHROPIC_BASE_URL": "https://open.bigmodel.cn/api/anthropic",
"ANTHROPIC_AUTH_TOKEN": "YOUR_API_KEY_HERE",
"ANTHROPIC_MODEL": "glm-4.7"
}
},
"kimi": {
"env": {
"ANTHROPIC_BASE_URL": "https://api.moonshot.cn/anthropic",
"ANTHROPIC_AUTH_TOKEN": "YOUR_API_KEY_HERE",
"ANTHROPIC_MODEL": "kimi-k2-thinking",
"ANTHROPIC_SMALL_FAST_MODEL": "kimi-k2-0905-preview"
}
}
}
}| Field | Description |
|---|---|
settings |
Shared Claude Code config template for all providers |
claude_args |
Fixed arguments to pass to Claude Code (optional) |
current_provider |
Currently used provider (auto-managed by ccc) |
providers.{name} |
Provider-specific Claude Code configuration |
Each provider only needs to specify the fields it wants to override. Common fields:
| Field | Description |
|---|---|
env.ANTHROPIC_BASE_URL |
API endpoint URL |
env.ANTHROPIC_AUTH_TOKEN |
API key/token |
env.ANTHROPIC_MODEL |
Main model to use |
env.ANTHROPIC_SMALL_FAST_MODEL |
Fast model for quick tasks |
How merging works: Provider settings are deep-merged with the base template. Provider env takes precedence over settings.env.
| Variable | Description |
|---|---|
CCC_CONFIG_DIR |
Override config directory (default: ~/.claude/) |
# Debug with custom config directory
CCC_CONFIG_DIR=./tmp ccc glm# Build for all platforms
./build.sh --all
# Build for specific platforms
./build.sh -p darwin-arm64,linux-amd64
# Custom output directory
./build.sh -o ./binSupported platforms: darwin-amd64, darwin-arm64, linux-amd64, linux-arm64
MIT License - see LICENSE file for details.