Skip to main content

Local GitHub Copilot API proxy โ€” use GPT-4o, Claude, Gemini via OpenAI/Anthropic compatible APIs

Project description

๐Ÿš€ CopilotX

Local & Remote GitHub Copilot API proxy โ€” use GPT-4o, Claude, Gemini and more via OpenAI/Anthropic compatible APIs.

Turn your GitHub Copilot subscription into an AI API server. Use any model available through Copilot with any tool that supports OpenAI or Anthropic SDKs โ€” locally or on a remote VM.

โœจ Features

  • ๐Ÿ” GitHub OAuth โ€” One-command login via Device Flow, or use existing token
  • ๐Ÿ”„ Auto Token Refresh โ€” Copilot JWT refreshed transparently before expiry
  • ๐Ÿ”Œ Triple API Format โ€” OpenAI /v1/chat/completions + /v1/responses + Anthropic /v1/messages
  • ๐ŸŒŠ SSE Streaming โ€” Real-time streaming responses for all formats
  • ๐Ÿ‘๏ธ Vision Support โ€” Pass images through Responses API (auto-detected)
  • ๐ŸŽฏ Dynamic API URL โ€” Auto-discovers correct Copilot API endpoint per account type
  • ๐Ÿ“‹ Model Discovery โ€” Auto-fetch available models from Copilot
  • โšก Zero Config โ€” pip install โ†’ auth login โ†’ serve โ†’ done
  • ๐ŸŒ Remote Deploy โ€” Serve on 0.0.0.0 with API key protection, deploy behind Caddy for auto-HTTPS

๐Ÿš€ Quick Start

1. Install

pip install copilotx
# or
uv pip install copilotx

2. Authenticate

# Option A: OAuth Device Flow (recommended)
copilotx auth login
# โ†’ Opens browser for GitHub authorization

# Option B: Use existing GitHub token
copilotx auth login --token ghp_xxxxx
# or
export GITHUB_TOKEN=ghp_xxxxx && copilotx auth login

3. Start Server

copilotx serve

Output:

๐Ÿš€ CopilotX v2.2.1
โœ… Copilot Token valid (28m remaining, auto-refresh)
๏ฟฝ Local mode (localhost only)
๐ŸŽฏ API: api.enterprise.githubcopilot.com (auto-detected)
๐Ÿ“‹ Models: claude-opus-4.6, gpt-5-mini, gpt-5, gemini-2.5-pro, ...
๐Ÿ“ Port info: ~/.copilotx/server.json

๐Ÿ”— OpenAI Chat:   http://127.0.0.1:24680/v1/chat/completions
๐Ÿ”— Responses:     http://127.0.0.1:24680/v1/responses
๐Ÿ”— Anthropic API: http://127.0.0.1:24680/v1/messages
๐Ÿ”— Models:        http://127.0.0.1:24680/v1/models

Press Ctrl+C to stop

4. Use It

Python (OpenAI SDK):

from openai import OpenAI

client = OpenAI(base_url="http://localhost:24680/v1", api_key="copilotx")

response = client.chat.completions.create(
    model="gpt-4o",
    messages=[{"role": "user", "content": "Hello!"}],
    stream=True,
)

for chunk in response:
    print(chunk.choices[0].delta.content or "", end="")

Python (Anthropic SDK):

from anthropic import Anthropic

client = Anthropic(base_url="http://localhost:24680", api_key="copilotx")

message = client.messages.create(
    model="claude-sonnet-4",
    max_tokens=1024,
    messages=[{"role": "user", "content": "Hello!"}],
)
print(message.content[0].text)

Claude Code:

# Set environment variables
export ANTHROPIC_BASE_URL=http://localhost:24680
export ANTHROPIC_API_KEY=copilotx
claude

Codex CLI (uses Responses API):

export OPENAI_BASE_URL=http://localhost:24680/v1
export OPENAI_API_KEY=copilotx
codex

Codex CLI uses the /v1/responses endpoint natively. CopilotX v2.1.0+ supports this including streaming, vision input, and apply_patch tool invocation.

Python (OpenAI Responses API):

from openai import OpenAI

client = OpenAI(base_url="http://localhost:24680/v1", api_key="copilotx")

response = client.responses.create(
    model="gpt-5-mini",
    input="Explain quicksort in 3 sentences.",
)
print(response.output_text)

cURL:

curl http://localhost:24680/v1/chat/completions \
  -H "Content-Type: application/json" \
  -d '{
    "model": "gpt-4o",
    "messages": [{"role": "user", "content": "Hello!"}]
  }'

๐Ÿ“ก API Endpoints

Endpoint Method Description
/v1/chat/completions POST OpenAI-compatible chat completions
/v1/responses POST OpenAI Responses API (streaming, vision, tools)
/v1/messages POST Anthropic-compatible messages
/v1/models GET List available models
/health GET Server health + token status

๐Ÿ”ง CLI Commands

copilotx auth login              # OAuth Device Flow login
copilotx auth login --token XXX  # Quick login with existing token
copilotx auth status             # Show auth status
copilotx auth logout             # Clear credentials

copilotx models                  # List available models
copilotx serve                   # Start server (default: 127.0.0.1:24680)
copilotx serve --host 0.0.0.0   # Remote mode (bind all interfaces)
copilotx serve --port 9090       # Custom port (strict โ€” fails if in use)

copilotx config claude-code      # Configure for local CopilotX
copilotx config claude-code -u https://...  # Configure for remote server

copilotx --version               # Show version

Client Configuration

The config command auto-generates Claude Code configuration with smart defaults:

# Local mode โ€” one command, zero prompts
copilotx config claude-code
# โ†’ Uses localhost:24680, auto-selects best models

# Remote mode โ€” auto-reads API key from ~/.copilotx/.env
copilotx config claude-code -u https://api.polly.wang

# Custom models (optional)
copilotx config claude-code -m claude-opus-4.6 -s gpt-5-mini

Creates ~/.claude/settings.json using ANTHROPIC_AUTH_TOKEN (bypasses Claude Code's API key format validation).

๐Ÿ—๏ธ How It Works

Your Tool (Claude Code / Codex / Python script)
    โ”‚
    โ”‚  OpenAI Chat / Responses / Anthropic format
    โ–ผ
โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚  CopilotX (localhost:24680)       โ”‚
โ”‚                                   โ”‚
โ”‚  โ€ข /v1/chat/completions (pass)    โ”‚
โ”‚  โ€ข /v1/responses (pass + fix IDs) โ”‚
โ”‚  โ€ข /v1/messages (Anthropicโ†’OpenAI)โ”‚
โ”‚  โ€ข Vision auto-detection          โ”‚
โ”‚  โ€ข apply_patch tool patching      โ”‚
โ”‚  โ€ข Token auto-refresh             โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ฌโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜
                โ”‚  OpenAI format
                โ–ผ
  api.{individual|enterprise}.githubcopilot.com
  โ”œโ”€โ”€ /chat/completions
  โ””โ”€โ”€ /responses
  (GPT-5, Claude Opus 4.6, Gemini 2.5, ...)

CopilotX uses your GitHub Copilot subscription to access models. The correct API endpoint is auto-detected from the Copilot token (endpoints.api field) โ€” no hardcoded URLs. OpenAI requests are direct passthrough, Anthropic requests are translated on-the-fly, and Responses API streams get ID synchronization for consistent event tracking.

๐Ÿ” Port Discovery

When CopilotX starts, it writes ~/.copilotx/server.json:

{
  "host": "127.0.0.1",
  "port": 24680,
  "pid": 12345,
  "started_at": "2026-02-09T12:00:00+00:00",
  "base_url": "http://127.0.0.1:24680"
}

Other scripts can read this to discover the actual port:

# Bash/Zsh
PORT=$(python -c "import json; print(json.load(open('$HOME/.copilotx/server.json'))['port'])")
curl http://localhost:$PORT/health

# PowerShell
$info = Get-Content "$HOME\.copilotx\server.json" | ConvertFrom-Json
curl http://localhost:$($info.port)/health

The file is automatically cleaned up when the server stops.

๐ŸŒ Remote Deployment

Deploy CopilotX on a cloud VM to access your Copilot models from anywhere.

Quick Setup (Azure VM / any Linux server)

# 1. Install
pip install copilotx

# 2. Authenticate
copilotx auth login

# 3. Set API key for remote protection
export COPILOTX_API_KEY=$(openssl rand -hex 32)
echo "Save this key: $COPILOTX_API_KEY"

# 4. Start in remote mode
copilotx serve --host 0.0.0.0

Production Setup with Nginx + systemd

For production deployments with HTTPS, we recommend using Nginx as the reverse proxy.

1. Install and configure systemd service:

# Copy and customize the systemd service template
sudo cp deploy/copilotx.service /etc/systemd/system/

# Create environment file with your API key
mkdir -p ~/.copilotx
echo "COPILOTX_API_KEY=$(openssl rand -hex 32)" > ~/.copilotx/.env

# Enable and start service
sudo systemctl daemon-reload
sudo systemctl enable --now copilotx

2. Configure Nginx reverse proxy:

# Copy the Nginx config template
sudo cp deploy/nginx-copilotx.conf /etc/nginx/sites-available/copilotx
sudo ln -s /etc/nginx/sites-available/copilotx /etc/nginx/sites-enabled/

# Get SSL certificate with Let's Encrypt
sudo certbot --nginx -d your-domain.com

# Reload Nginx
sudo nginx -t && sudo systemctl reload nginx

The deploy/ directory includes ready-to-use templates:

  • copilotx.service โ€” systemd service unit (generic)
  • copilotx-azureuser.service โ€” systemd service unit (Azure VM with virtualenv)
  • nginx-copilotx.conf โ€” Nginx reverse proxy with SSL, rate limiting, and SSE support
  • nginx-copilotx-http.conf โ€” Temporary HTTP-only config for initial Let's Encrypt setup
  • Caddyfile โ€” Alternative Caddy config (simpler setup with auto-HTTPS)
  • .env.example โ€” Environment variables template

Security Model

Mode Host API Key Behavior
Local 127.0.0.1 (default) Not needed Fully open, localhost only
Remote (protected) 0.0.0.0 COPILOTX_API_KEY set Localhost exempt, remote needs Bearer token
Remote (open) 0.0.0.0 Not set โš ๏ธ Warning shown, fully open

Accessing from remote:

# Use Bearer token
curl https://your-domain.com/v1/models \
  -H "Authorization: Bearer YOUR_API_KEY"

# Or x-api-key header
curl https://your-domain.com/v1/models \
  -H "x-api-key: YOUR_API_KEY"

With OpenAI SDK:

client = OpenAI(
    base_url="https://your-domain.com/v1",
    api_key="YOUR_COPILOTX_API_KEY",
)

๐Ÿ“‹ Version Roadmap

Version Codename Features
v1.0.0 Local OAuth, dual API, streaming, model discovery
v2.0.0 Remote API key auth, remote deploy, Nginx/Caddy + systemd templates
v2.1.0 Codex Responses API, vision support, dynamic API URL, stream ID sync
v2.2.0 Config copilotx config command for client setup (Claude Code)
v2.3.x Polish Error passthrough, stream error handling, test suite
v3.0.0 Multi-User Token pool, user database, OpenRouter mode

โš ๏ธ Disclaimer

This tool is for personal local use only. Please comply with GitHub Copilot Terms of Service. The author is not responsible for any account restrictions resulting from misuse.

๐Ÿ“„ License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

copilotx-2.3.2.tar.gz (29.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

copilotx-2.3.2-py3-none-any.whl (35.6 kB view details)

Uploaded Python 3

File details

Details for the file copilotx-2.3.2.tar.gz.

File metadata

  • Download URL: copilotx-2.3.2.tar.gz
  • Upload date:
  • Size: 29.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.5

File hashes

Hashes for copilotx-2.3.2.tar.gz
Algorithm Hash digest
SHA256 a512ac806c45a8fff4739357df80f4613c4a84658d02f1707ad670efe4b14015
MD5 20f5c46f0a10b0dcb7ba60a3921b490d
BLAKE2b-256 5ea847f102c61c3a2c07a899206d3c04f846d8278ccc8e54808db21bd5a15b1c

See more details on using hashes here.

File details

Details for the file copilotx-2.3.2-py3-none-any.whl.

File metadata

  • Download URL: copilotx-2.3.2-py3-none-any.whl
  • Upload date:
  • Size: 35.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.5

File hashes

Hashes for copilotx-2.3.2-py3-none-any.whl
Algorithm Hash digest
SHA256 3d8c79143476cf8ebba5b63fca0e52c2e75ff71e782364b3b13198ce67a8b14e
MD5 0367a3dce2367c56557ba5170caeb7ea
BLAKE2b-256 f5c122245b445894d7bae4db71ddde2e7c3f61fc9b54fe6583c9e589fdcea298

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page