A proxy server that enables Cursor IDE to use GitHub Copilot's API instead of Cursor's default AI services. This allows you to use your GitHub Copilot subscription with Cursor IDE, maximizing your resources by switching between services as needed.
- OpenAI API Compatibility: Implements the OpenAI API format that Cursor IDE can use
- GitHub Copilot Integration: Connects to GitHub Copilot's backend services
- Seamless Authentication: Handles GitHub OAuth device flow authentication
- Token Management: Automatically refreshes Copilot tokens
- Streaming Support: Supports both streaming and non-streaming completions
- Easy Configuration: Simple setup with Cursor IDE
- Node.js 18.0 or higher
- GitHub Copilot subscription
- Cursor IDE
- 
Clone the repository: git clone https://github.com/bjornmelin/github-copilot-proxy.git cd github-copilot-proxy
- 
Install dependencies: npm install 
- 
Create a .envfile:cp .env.example .env 
- 
Build the project: npm run build 
- 
Start the proxy server: npm start 
- Open Cursor IDE
- Go to Settings > API Keys
- In the "Override OpenAI Base URL" section, enter:
http://localhost:3000
- Go to http://localhost:3000 in your browser
- Follow the authentication steps to connect to GitHub
Once configured, you can use Cursor IDE as normal. All AI-powered features will now use your GitHub Copilot subscription instead of Cursor's API.
To switch back to Cursor's API:
- Go to Settings > API Keys
- Remove the Override OpenAI Base URL
- The proxy authenticates with GitHub using the OAuth device flow
- GitHub provides a token that the proxy uses to obtain a Copilot token
- Cursor sends requests to the proxy in OpenAI format
- The proxy converts these requests to GitHub Copilot's format
- The proxy forwards responses back to Cursor in OpenAI format
npm run devnpm testnpm run lintThis project is licensed under the MIT License - see the LICENSE file for details.
Contributions are welcome! Please feel free to submit a Pull Request.
- Fork the repository
- Create a feature branch (git checkout -b feature/amazing-feature)
- Commit your changes using conventional commits (git commit -m 'feat: add amazing feature')
- Push to the branch (git push origin feature/amazing-feature)
- Open a Pull Request