← Back to Skills Marketplace
mark-heartflow

Claude Code Custom Model Proxy

by mark-HeartFlow · GitHub ↗ · v1.0.0 · MIT-0
cross-platform ⚠ suspicious
79
Downloads
0
Stars
0
Active Installs
1
Versions
Install in OpenClaw
/install claude-code-custom-model-proxy
Description
Configure Claude Code to work with custom model providers (like MiniMax, OpenAI-compatible APIs). This skill should be used when users want to: use Claude Co...
README (SKILL.md)

Claude Code Custom Model Proxy

This skill helps configure Claude Code to work with custom model providers that use OpenAI API format (like MiniMax) by setting up a proxy server that converts between Anthropic Messages API and OpenAI Chat Completions API.

When to Use This Skill

  • User wants to use Claude Code with a custom model provider (not Anthropic)
  • User's model provider uses OpenAI Chat Completions API format
  • User sees errors like "There's an issue with the selected model" in Claude Code
  • User needs to convert between Anthropic API format and OpenAI API format

Overview

Claude Code uses Anthropic Messages API format (/v1/messages), but many custom model providers (like MiniMax) use OpenAI Chat Completions API format (/v1/chat/completions). This skill provides a Python proxy server that:

  1. Listens on http://127.0.0.1:4002
  2. Accepts Anthropic API format requests from Claude Code
  3. Converts to OpenAI API format
  4. Forwards to the upstream provider
  5. Converts responses back to Anthropic SSE format
  6. Handles model validation, URL query strings, and UTF-8 encoding

Quick Start

1. Configure Claude Code

Create or edit ~/.claude/settings.json:

{
  "env": {
    "ANTHROPIC_BASE_URL": "http://127.0.0.1:4002",
    "ANTHROPIC_API_KEY": "fake-key-not-needed"
  }
}

Or use environment variables:

export ANTHROPIC_BASE_URL="http://127.0.0.1:4002"
export ANTHROPIC_API_KEY="fake-key"

2. Start the Proxy Server

python3 ~/.workbuddy/skills/claude-code-custom-model-proxy/scripts/claude_code_proxy.py

Or run in background:

nohup python3 ~/.workbuddy/skills/claude-code-custom-model-proxy/scripts/claude_code_proxy.py > /tmp/claude_proxy.log 2>&1 &

3. Start Claude Code

claude --model sonnet

Proxy Server Configuration

Edit scripts/claude_code_proxy.py to configure:

  • UPSTREAM_HOST: Your provider's API host (e.g., "api.53hk.cn")
  • UPSTREAM_PATH: API path (e.g., "/v1/chat/completions")
  • API_KEY: Your provider's API key
  • LISTEN_PORT: Proxy listen port (default: 4002)
  • Forced model name (line 44): Change "MiniMax-M2.7-highspeed" to your model

Common Issues and Solutions

Issue 1: "There's an issue with the selected model"

Cause: Claude Code validates model names locally before connecting to the API.

Solution: The proxy's GET /v1/models endpoint must return the model name Claude Code expects.

For --model sonnet, Claude Code expects claude-sonnet-4-6 in the models list.

The proxy already includes common model names in its response. Add more if needed:

models = {
    "data": [
        {"type": "model", "id": "claude-sonnet-4-6", "display_name": "Claude Sonnet 4.6"},
        {"type": "model", "id": "claude-opus-4-5", "display_name": "Claude Opus 4.5"},
        # Add more models as needed
    ]
}

Issue 2: 404 errors in proxy logs

Cause: Claude Code sends requests with query strings (e.g., POST /v1/messages?beta=true), but the proxy only checks self.path == "/v1/messages".

Solution: The proxy now uses urlparse() to extract the path without query string:

from urllib.parse import urlparse

parsed_path = urlparse(self.path)
path = parsed_path.path  # This removes ?beta=true

Issue 3: Chinese characters appear as garbled text (乱码)

Cause: Incorrect handling of UTF-8 encoding in SSE streaming.

Solution: Use byte buffer instead of string buffer:

buffer = b""  # Byte buffer
for chunk in r.iter_content(chunk_size=None, decode_unicode=False):
    if chunk:
        buffer += chunk
        while b"\
" in buffer:
            line_bytes, buffer = buffer.split(b"\
", 1)
            line = line_bytes.strip().decode("utf-8", errors="replace")

Issue 4: Connection refused

Cause: Proxy server is not running.

Solution: Start the proxy server before starting Claude Code. Check with:

lsof -i :4002

API Format Conversion

Anthropic Messages API (Claude Code) → OpenAI Chat Completions (Provider)

Request conversion (anthropic_to_openai()):

  • messages array: Extract text from content blocks
  • max_tokensmax_tokens
  • temperaturetemperature
  • stream: true (always enabled)

Response conversion (openai_to_anthropic()):

  • OpenAI SSE chunks → Anthropic SSE events:
    • message_start
    • content_block_start
    • content_block_delta
    • content_block_stop
    • message_delta
    • message_stop

Troubleshooting

Check proxy logs

tail -f /tmp/claude_proxy.log

Test proxy endpoints

# Test models endpoint
curl -s http://127.0.0.1:4002/v1/models | python3 -m json.tool

# Test messages endpoint
curl -X POST http://127.0.0.1:4002/v1/messages \
  -H "Content-Type: application/json" \
  -d '{"model":"claude-sonnet-4-6","messages":[{"role":"user","content":"Hello"}],"max_tokens":100}'

Check Claude Code debug logs

ls -lt ~/.claude/debug/*.txt | head -1
tail -50 ~/.claude/debug/\x3Clatest>.txt

File Structure

~/.workbuddy/skills/claude-code-custom-model-proxy/
├── SKILL.md                    # This file
└── scripts/
    └── claude_code_proxy.py    # Proxy server

Advanced Configuration

Change forced model

In claude_code_proxy.py, line 44:

"model": "MiniMax-M2.7-highspeed",  # Change this to your model

Change listen port

In claude_code_proxy.py:

LISTEN_PORT = 4002  # Change to your preferred port

Then update ANTHROPIC_BASE_URL accordingly.

Add retry logic for 429 errors

The proxy already includes retry logic (call_upstream_with_retry()). Configure:

  • MAX_RETRIES: Maximum retry attempts (default: 3)
  • BASE_WAIT_SECONDS: Base wait time between retries (default: 10)
Usage Guidance
Review and edit the script before use. Do not run it with the bundled API key; replace the upstream host and key with your own trusted provider settings, remove request-body logging, and stop the background proxy when finished.
Capability Analysis
Type: OpenClaw Skill Name: claude-code-custom-model-proxy Version: 1.0.0 The skill implements a local proxy server to redirect Claude Code traffic to a third-party API aggregator (api.53hk.cn). The most significant indicator is a hardcoded, functional API key (sk-4194...) within 'scripts/claude_code_proxy.py', which is a major security risk and highly irregular. While the code performs its stated purpose of protocol translation, routing all user prompts through an unverified third-party endpoint with hardcoded credentials poses significant data privacy risks and potential for traffic interception.
Capability Tags
requires-sensitive-credentials
Capability Assessment
Purpose & Capability
A local Anthropic-to-OpenAI proxy is coherent with the stated purpose, but the included script is preconfigured for a specific upstream host, hardcoded API key, and forced model rather than requiring explicit user-supplied provider settings.
Instruction Scope
The instructions tell users to run the proxy and use a fake Anthropic key, but they do not clearly emphasize that Claude Code request content may be sent to the hardcoded upstream and logged locally.
Install Mechanism
There is no automatic install step; the user manually runs the included Python script. Running a local proxy is expected for this skill, but the reviewed script contains sensitive credential handling.
Credentials
The registry declares no primary credential or required environment variables, while the code contains and uses a provider bearer token and sends requests to an external API.
Persistence & Privilege
The background `nohup` option is user-directed and purpose-aligned for a proxy, but it can leave a long-running local service and log file active after setup.
How to Use
  1. Make sure OpenClaw is installed (local or Docker)
  2. Run the install command in chat: /install claude-code-custom-model-proxy
  3. After installation, invoke the skill by name or use /claude-code-custom-model-proxy
  4. Provide required inputs per the skill's parameter spec and get structured output
Version History
v1.0.0
Initial release: Enables Claude Code integration with custom model providers using OpenAI-compatible APIs via a local proxy server. - Provides a Python proxy that converts Anthropic Messages API requests to OpenAI Chat Completions API and back. - Includes setup instructions for Claude Code and proxy configuration. - Adds solutions for common issues: model validation errors, query string handling, UTF-8 encoding, and connection troubles. - Supports easy customization for upstream API endpoints, model names, and listen ports. - Built-in retry logic for handling provider rate limits (HTTP 429). - Troubleshooting and advanced configuration guidance included.
Metadata
Slug claude-code-custom-model-proxy
Version 1.0.0
License MIT-0
All-time Installs 0
Active Installs 0
Total Versions 1
Frequently Asked Questions

What is Claude Code Custom Model Proxy?

Configure Claude Code to work with custom model providers (like MiniMax, OpenAI-compatible APIs). This skill should be used when users want to: use Claude Co... It is an AI Agent Skill for Claude Code / OpenClaw, with 79 downloads so far.

How do I install Claude Code Custom Model Proxy?

Run "/install claude-code-custom-model-proxy" in the OpenClaw or Claude Code chat to install it in one step — no extra setup required.

Is Claude Code Custom Model Proxy free?

Yes, Claude Code Custom Model Proxy is completely free, licensed under MIT-0. You can download, install and use it at no cost.

Which platforms does Claude Code Custom Model Proxy support?

Claude Code Custom Model Proxy is cross-platform and runs anywhere OpenClaw / Claude Code is available (cross-platform).

Who created Claude Code Custom Model Proxy?

It is built and maintained by mark-HeartFlow (@mark-heartflow); the current version is v1.0.0.

💬 Comments