This server provides an MCP interface to interact with GitHub Enterprise API (also compatible with GitHub.com and GitHub Enterprise Cloud with some limitations) for AI tools like Cursor.
Capabilities include:
Repository Management: Retrieve repository lists and details, list branches, get file/directory contents, create/update/delete repositories
Pull Requests & Issues: List, create, get details, merge PRs, manage issues, and retrieve/add comments
GitHub Actions: List workflows and workflow runs, trigger workflows
User Management: List, create, update, suspend/unsuspend users (Enterprise only)
Enterprise Features: Access license information and system statistics (requires site admin permissions)
Provides access to GitHub Enterprise and GitHub.com repositories, enabling repository management, branch listing, file content retrieval, and issue/PR handling through the GitHub API.
Offers tools for listing, viewing, and triggering GitHub Actions workflows, with capabilities for managing workflow runs and filtering by branch or status.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@GitHub Enterprise MCP Serverlist open pull requests in the backend repository"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
GitHub Enterprise MCP Server
An MCP (Model Context Protocol) server for integration with GitHub Enterprise API. This server provides an MCP interface to easily access repository information, issues, PRs, and more from GitHub Enterprise in Cursor.
Compatibility
This project is primarily designed for GitHub Enterprise Server environments, but it also works with:
GitHub.com
GitHub Enterprise Cloud
Note: Some enterprise-specific features (like license information and enterprise statistics) will not work with GitHub.com or GitHub Enterprise Cloud.
Related MCP server: GitHub MCP Server Plus
Key Features
Retrieve repository list from GitHub Enterprise instances
Get detailed repository information
List repository branches
View file and directory contents
Manage issues and pull requests
Repository management (create, update, delete)
GitHub Actions workflows management
User management (list, create, update, delete, suspend/unsuspend users)
Access enterprise statistics
Enhanced error handling and user-friendly response formatting
Getting Started
Prerequisites
Node.js 18 or higher
Access to a GitHub Enterprise instance
Personal Access Token (PAT)
Docker Installation and Setup
Option 1: Running with Docker
Build the Docker image:
docker build -t github-enterprise-mcp .Run the Docker container with environment variables:
docker run -p 3000:3000 \ -e GITHUB_TOKEN="your_github_token" \ -e GITHUB_ENTERPRISE_URL="https://github.your-company.com/api/v3" \ -e DEBUG=true \ github-enterprise-mcp
Note: The Dockerfile is configured to run with
--transport httpby default. If you need to change this, you can override the command:
docker run -p 3000:3000 \
-e GITHUB_TOKEN="your_github_token" \
-e GITHUB_ENTERPRISE_URL="https://github.your-company.com/api/v3" \
-e DEBUG=true \
github-enterprise-mcp node dist/index.js --transport http --debugOption 2: Using Docker Compose
Create a
.envfile in the project root with the required environment variables:GITHUB_ENTERPRISE_URL=https://github.your-company.com/api/v3 GITHUB_TOKEN=your_github_token DEBUG=trueStart the container with Docker Compose:
docker-compose up -dCheck the logs:
docker-compose logs -fStop the container:
docker-compose down
Installation and Setup
Local Development (Using Concurrent Mode)
This method is recommended for active development with automatic recompilation and server restarts:
Clone the repository and install required packages:
git clone https://github.com/ddukbg/github-enterprise-mcp.git cd github-enterprise-mcp npm installRun the development server:
export GITHUB_TOKEN="your_github_token" export GITHUB_ENTERPRISE_URL="https://github.your-company.com/api/v3" npm run devThis will:
Compile TypeScript code automatically when files change
Restart the server when compiled files are updated
Run the server in HTTP mode for URL-based connections
Connect to Cursor using URL mode as described below
Installation and Setup for Production
Option 1: Using URL Mode (Recommended for Local Development)
This method is the most stable and recommended for local development or testing:
Clone the repository and install required packages:
git clone https://github.com/ddukbg/github-enterprise-mcp.git cd github-enterprise-mcp npm installBuild the project:
npm run build chmod +x dist/index.jsRun the server:
export GITHUB_TOKEN="your_github_token" export GITHUB_ENTERPRISE_URL="https://github.your-company.com/api/v3" node dist/index.js --transport http --debugConnect to Cursor using URL mode:
Add the following to your Cursor's
.cursor/mcp.jsonfile:
{ "mcpServers": { "github-enterprise": { "url": "http://localhost:3000/sse" } } }
Option 2: Install as a Global Command (npm link)
This method is useful for local development:
# After cloning the repository
git clone https://github.com/ddukbg/github-enterprise-mcp.git
cd github-enterprise-mcp
# Install required packages
npm install
# Build
npm run build
chmod +x dist/index.js
# Link globally
npm link
# Run as a global command
export GITHUB_TOKEN="your_github_token"
export GITHUB_ENTERPRISE_URL="https://github.your-company.com/api/v3"
github-enterprise-mcp --transport=http --debugOption 3: Using npx (When Package is Published)
If the package is published to the public npm registry:
npx @ddukbg/github-enterprise-mcp --token=your_github_token --github-enterprise-url=https://github.your-company.com/api/v3Integration with AI Tools
Claude Desktop
Add the following to your claude_desktop_config.json:
{
"mcpServers": {
"github-enterprise": {
"command": "npx",
"args": ["-y", "@ddukbg/github-enterprise-mcp", "--token=YOUR_GITHUB_TOKEN", "--github-enterprise-url=YOUR_GITHUB_ENTERPRISE_URL"]
}
}
}Replace YOUR_GITHUB_TOKEN and YOUR_GITHUB_ENTERPRISE_URL with your actual values.
Cursor
Recommended: URL Mode (Most Stable)
For the most reliable operation in Cursor, using URL mode is recommended:
Start the server in a separate terminal window:
cd /path/to/github-enterprise-mcp GITHUB_ENTERPRISE_URL="https://github.your-company.com/api/v3" GITHUB_TOKEN="your_github_token" node dist/index.js --transport httpConfigure Cursor's MCP settings:
Open Cursor and go to Settings
Navigate to AI > MCP Servers
Edit your
.cursor/mcp.jsonfile:
{ "mcpServers": { "github-enterprise": { "url": "http://localhost:3000/sse" } } }Restart Cursor to apply the changes
Alternative: Command Mode
Alternatively, you can configure Cursor to use the command mode, although URL mode is more reliable:
Open Cursor and go to Settings
Navigate to AI > MCP Servers
Click Add MCP Server
Enter the following details:
Name: GitHub Enterprise
Command:
npxArguments:
@ddukbg/github-enterprise-mcpEnvironment Variables:
GITHUB_ENTERPRISE_URL: Your GitHub Enterprise API URLGITHUB_TOKEN: Your GitHub personal access token
Alternatively, you can manually edit your .cursor/mcp.json file to include:
{
"mcpServers": {
"github-enterprise": {
"command": "npx",
"args": [
"@ddukbg/github-enterprise-mcp"
],
"env": {
"GITHUB_ENTERPRISE_URL": "https://github.your-company.com/api/v3",
"GITHUB_TOKEN": "your_github_token"
}
}
}
}Language Configuration
This MCP server supports both English and Korean languages. You can configure the language using:
Environment Variables
# Set language to Korean
export LANGUAGE=ko
# Or in .env file
LANGUAGE=koCommand-line Arguments
# Set language to Korean
node dist/index.js --language koThe default language is English if not specified.
Additional Options in HTTP Mode
--debug: Enable debug logging--github-enterprise-url <URL>: Set GitHub Enterprise API URL--token <TOKEN>: Set GitHub Personal Access Token--language <LANG>: Set language (en or ko, default: en)
Available MCP Tools
This MCP server provides the following tools:
Tool Name | Description | Parameters | Required PAT Permissions |
| Retrieve repository list for a user or organization |
|
|
| Get detailed repository information |
|
|
| List branches of a repository |
|
|
| Retrieve file or directory contents |
|
|
| List pull requests in a repository |
|
|
| Get pull request details |
|
|
| Create a new pull request |
|
|
| Merge a pull request |
|
|
| List issues in a repository |
|
|
| Get issue details |
|
|
| List comments on an issue or pull request |
|
|
| Create a new issue |
|
|
| Create a new repository |
|
|
| Update repository settings |
|
|
| Delete a repository |
|
|
| List GitHub Actions workflows |
|
|
| List workflow runs |
|
|
| Trigger a workflow |
|
|
| Get GitHub Enterprise license information | - | Requires site_admin (Administrator) account |
| Get GitHub Enterprise system statistics | - | Requires site_admin (Administrator) account |
Note: For Enterprise-specific tools (
get-license-infoandget-enterprise-stats), a user with site administrator privileges is required. A Classic Personal Access Token is recommended, as Fine-grained tokens may not support these Enterprise-level permissions.
Using the Tools in Cursor
Once you have set up the MCP server and configured Cursor to connect to it, you can use the GitHub Enterprise tools directly in Cursor's AI chat. Here are some examples:
Listing Repositories
mcp_github_enterprise_list_repositories(owner="octocat")Getting Repository Information
mcp_github_enterprise_get_repository(owner="octocat", repo="hello-world")Listing Pull Requests
mcp_github_enterprise_list_pull_requests(owner="octocat", repo="hello-world", state="open")Managing Issues
# List issues
mcp_github_enterprise_list_issues(owner="octocat", repo="hello-world", state="all")
# Get issue details
mcp_github_enterprise_get_issue(owner="octocat", repo="hello-world", issue_number=1)
# Get issue/PR comments
mcp_github_enterprise_list_issue_comments(owner="octocat", repo="hello-world", issue_number=1)
# Create a new issue
mcp_github_enterprise_create_issue(
owner="octocat",
repo="hello-world",
title="Found a bug",
body="Here is a description of the bug",
labels=["bug", "important"]
)Working with Repository Content
mcp_github_enterprise_get_content(owner="octocat", repo="hello-world", path="README.md")Repository Management
# Create a new repository
mcp_github_enterprise_create_repository(
name="new-project",
description="This is a new project",
private=true,
auto_init=true
)
# Update repository settings
mcp_github_enterprise_update_repository(
owner="octocat",
repo="hello-world",
description="Updated description",
has_issues=true
)User Management (Enterprise Only)
These features are specifically designed for GitHub Enterprise Server environments and require administrative permissions:
# List all users in the GitHub Enterprise instance
mcp_github_enterprise_list_users(filter="active", per_page=100)
# Get a specific user's details
mcp_github_enterprise_get_user(username="octocat")
# Create a new user (Enterprise only)
mcp_github_enterprise_create_user(
login="newuser",
email="newuser@example.com",
name="New User",
company="ACME Inc."
)
# Update a user's information (Enterprise only)
mcp_github_enterprise_update_user(
username="octocat",
email="updated-email@example.com",
location="San Francisco"
)
# Suspend a user (Enterprise only)
mcp_github_enterprise_suspend_user(
username="octocat",
reason="Violation of terms of service"
)
# Unsuspend a user (Enterprise only)
mcp_github_enterprise_unsuspend_user(username="octocat")
# List organizations a user belongs to
mcp_github_enterprise_list_user_orgs(username="octocat")API Improvements
Flexible API URL configuration (supports various environment variables and command-line arguments)
Enhanced error handling and timeout management
User-friendly response formatting and messages
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
License
ISC