Local GitHub Copilot API proxy โ use GPT-4o, Claude, Gemini via OpenAI/Anthropic compatible APIs
Project description
๐ CopilotX
Local GitHub Copilot API proxy โ use GPT-4o, Claude, Gemini and more via OpenAI/Anthropic compatible APIs.
Turn your GitHub Copilot subscription into a local AI API server. Use any model available through Copilot with any tool that supports OpenAI or Anthropic SDKs.
โจ Features
- ๐ GitHub OAuth โ One-command login via Device Flow, or use existing token
- ๐ Auto Token Refresh โ Copilot JWT refreshed transparently before expiry
- ๐ Dual API Format โ OpenAI
/v1/chat/completions+ Anthropic/v1/messages - ๐ SSE Streaming โ Real-time streaming responses for both formats
- ๐ Model Discovery โ Auto-fetch available models from Copilot
- โก Zero Config โ
pip installโauth loginโserveโ done
๐ 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 v0.1.0
โ
Copilot Token valid (28m remaining, auto-refresh)
๐ Models: gpt-4o, gpt-4o-mini, o3-mini, claude-sonnet-4, gemini-2.0-flash
๐ OpenAI API: http://127.0.0.1:8080/v1/chat/completions
๐ Anthropic API: http://127.0.0.1:8080/v1/messages
๐ Models: http://127.0.0.1:8080/v1/models
Press Ctrl+C to stop
4. Use It
Python (OpenAI SDK):
from openai import OpenAI
client = OpenAI(base_url="http://localhost:8080/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:8080", 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:8080
export ANTHROPIC_API_KEY=copilotx
claude
Codex:
export OPENAI_BASE_URL=http://localhost:8080/v1
export OPENAI_API_KEY=copilotx
codex
cURL:
curl http://localhost:8080/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/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:8080)
copilotx serve --port 9090 # Custom port
copilotx --version # Show version
๐๏ธ How It Works
Your Tool (Claude Code / Codex / Python script)
โ
โ OpenAI or Anthropic format
โผ
โโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโโ
โ CopilotX (localhost:8080) โ
โ โ
โ โข Anthropic โ OpenAI โ
โ format translation โ
โ โข Token auto-refresh โ
โ โข SSE stream forwarding โ
โโโโโโโโโโโโโโโโฌโโโโโโโโโโโโโโโโ
โ OpenAI format
โผ
api.githubcopilot.com/chat/completions
(GPT-4o, Claude, Gemini, o3-mini, ...)
CopilotX uses your GitHub Copilot subscription to access models. The Copilot backend natively speaks OpenAI format, so OpenAI requests are direct passthrough. Anthropic requests are translated on-the-fly.
โ ๏ธ 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
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file copilotx-0.1.0.tar.gz.
File metadata
- Download URL: copilotx-0.1.0.tar.gz
- Upload date:
- Size: 14.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.10.11
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b977530d8ba422bbbe26f3e6bd475fab7e63f397976037998aa20995e065d8d4
|
|
| MD5 |
f90259d6eed44ebf680332e292bf4858
|
|
| BLAKE2b-256 |
9f33969d8e93a48cf1a83f1441ea181ca0c07e31c5ab1840f763de8238551310
|
File details
Details for the file copilotx-0.1.0-py3-none-any.whl.
File metadata
- Download URL: copilotx-0.1.0-py3-none-any.whl
- Upload date:
- Size: 20.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.10.11
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b5c89c556c242cbd122051cf4cfc873e55bb0c84e02b0d205dada540b0a8213f
|
|
| MD5 |
22228ecfb5dcef5e484f8565089b4e34
|
|
| BLAKE2b-256 |
892bec4d113dc011c13d06d2fee507cb0cbaf9eccddf26bad741fe4ed9d9c9d9
|