A Model Context Protocol (MCP) server that integrates with GitHub Copilot to provide AI-powered code assistance directly to Claude Code and other MCP-compatible tools.
- Chat with Copilot: Get general programming assistance using GitHub Copilot's AI models
- Code Explanation: Detailed explanations of code snippets
- Code Suggestions: Generate code based on natural language descriptions
- Code Review: Get feedback and improvement suggestions for your code
- Multiple AI Models: Support for GPT-4o, Claude 3.5 Sonnet, and Gemini 2.0 Flash
- Rate Limiting: Built-in rate limiting to respect API limits
- Automatic Authentication: Works with your existing GitHub Copilot CLI setup
npx @willianpaiva/copilot-mcp-server- Clone this repository:
git clone https://github.com/WillianPaiva/copilot-mcp.git
cd copilot-mcp- Install dependencies:
npm install- Build the project:
npm run buildThe server works out of the box with your existing GitHub Copilot authentication.
Only needed for special use cases. Create a .env file:
cp .env.example .envOptional settings:
# Only if you want to override the detected organization
GITHUB_ORG=your_organization_name
# Optional debugging
LOG_LEVEL=info
DEBUG=false
MAX_REQUESTS_PER_MINUTE=60Prerequisites:
- GitHub Copilot Subscription: You need an active GitHub Copilot subscription
- GitHub Copilot CLI Installed: Install and authenticate GitHub Copilot CLI:
# Install GitHub CLI first brew install gh # or your preferred method # Install GitHub Copilot CLI extension gh extension install github/gh-copilot # Authenticate (this will save tokens to ~/.config/github-copilot/) gh auth login
Automatic Authentication (Recommended)
The MCP server automatically detects your GitHub Copilot authentication from:
~/.config/github-copilot/hosts.json~/.config/github-copilot/apps.json
No manual configuration needed if you have GitHub Copilot CLI installed and authenticated!
Troubleshooting Authentication
If automatic detection fails, ensure you have GitHub Copilot CLI properly installed and authenticated:
gh extension install github/gh-copilot
gh auth loginAdd the following to your Claude Code MCP configuration:
Option 1: Using npx (Recommended)
{
"mcpServers": {
"copilot": {
"command": "npx",
"args": ["-y", "@willianpaiva/copilot-mcp-server"]
}
}
}Option 2: Manual Installation
{
"mcpServers": {
"copilot": {
"command": "node",
"args": ["/path/to/your/copilot-mcp/build/index.js"]
}
}
}That's it! No tokens or environment variables needed - the server automatically uses your existing GitHub Copilot authentication.
General programming assistance and questions.
// Example usage in Claude Code
copilot_chat({
message: "How do I implement a binary search algorithm?",
model: "gpt-4o",
context: "I'm working on a JavaScript project"
})Get detailed explanations of code.
copilot_explain({
code: "function fibonacci(n) { return n <= 1 ? n : fibonacci(n-1) + fibonacci(n-2); }",
language: "javascript"
})Generate code from natural language descriptions.
copilot_suggest({
prompt: "Create a React component for a user profile card",
language: "javascript",
maxSuggestions: 3
})Get code review and improvement suggestions.
copilot_review({
code: "your code here",
language: "python",
reviewType: "security"
})List of available AI models and their capabilities.
Current usage statistics and rate limiting information.
npm run devnpm run buildnpm run lintnpm testThe server implements rate limiting to respect GitHub's API limits:
- Default: 60 requests per minute
- Configurable via
MAX_REQUESTS_PER_MINUTEenvironment variable - Automatic reset every minute
The server includes comprehensive error handling for:
- Authentication failures
- Rate limit exceeded
- Network issues
- Invalid requests
- API unavailability
-
Authentication Failed
- Ensure GitHub Copilot CLI is installed:
gh extension install github/gh-copilot - Make sure you're authenticated:
gh auth login - Verify you have access to GitHub Copilot
- Ensure GitHub Copilot CLI is installed:
-
Rate Limit Exceeded
- Wait for the rate limit to reset (1 minute)
- Consider reducing the frequency of requests
-
API Not Available
- Verify you have access to GitHub Copilot
- Check GitHub's status page for outages
Enable debug mode for verbose logging:
DEBUG=true
LOG_LEVEL=debug- Fork the repository
- Create a feature branch
- Make your changes
- Add tests if applicable
- Submit a pull request
MIT License - see LICENSE file for details.
- The server uses your existing GitHub Copilot authentication
- No tokens are stored or transmitted by this application
- Authentication files are read-only from GitHub CLI's standard locations
- Follow GitHub's security best practices for your main GitHub authentication
For issues and questions:
- Check the troubleshooting section
- Search existing GitHub issues
- Create a new issue with detailed information