
Omnigit GitHub & Local Git MCP Server
The Omnigit GitHub & Local Git MCP Server connects AI tools directly to GitHub's platform. This gives AI agents, assistants, and chatbots the ability to read repositories and code files, manage issues and PRs, analyze code, and automate workflows. All through natural language interactions.
Use Cases
- Repository Management: Browse and query code, search files, analyze commits, and understand project structure across any repository you have access to.
- Issue & PR Automation: Create, update, and manage issues and pull requests. Let AI help triage bugs, review code changes, and maintain project boards.
- CI/CD & Workflow Intelligence: Monitor GitHub Actions workflow runs, analyze build failures, manage releases, and get insights into your development pipeline.
- Code Analysis: Examine security findings, review Dependabot alerts, understand code patterns, and get comprehensive insights into your codebase.
- Team Collaboration: Access discussions, manage notifications, analyze team activity, and streamline processes for your team.
Built for developers who want to connect their AI tools to GitHub context and capabilities, from simple natural language queries to complex multi-step agent workflows.
---
Fork differences from upstream
This is a fork of github/github-mcp-server with the following additions and improvements.
Improved review comment ID resolution
get_review_comments now returns a CommentID field (which is the databaseId from GraphQL) alongside the GraphQL NodeID and DatabaseID for every comment node. This CommentID is the numeric ID that should be used when calling add_reply_to_pull_request_comment or pull_request_comment_write. Previously, only the opaque base64 GraphQL node ID was returned, forcing the model to decode it or scrape the numeric ID from comment URLs. The commentId / comment_id parameter descriptions in those tools now explicitly say to use the CommentID field.
Issue comment management (issue_comment_write)
A new issue_comment_write tool lets AI agents update or delete existing issue comments. Previously only add_issue_comment (create) was available.
PR review comment management (pull_request_comment_write)
A new pull_request_comment_write tool lets AI agents update or delete existing pull request review comments.
Body filtering (filter_patterns)
Issue bodies, PR bodies, and local git commit messages are filtered before being sent to GitHub. By default, Co-Authored-By: trailers and generic AI-generated PR footers are stripped. The filter list is fully configurable via filter_patterns in omnigit-mcp-config.json. See i18n / Overriding Descriptions for details.
Local Git toolset (local_git)
A full set of git_* tools for operating on local repositories without going through the GitHub API: git_add, git_apply_patch_file, git_apply_patch_string, git_checkout, git_commit, git_create_branch, git_diff, git_diff_staged, git_diff_unstaged, git_init, git_list_repositories, git_log, git_pull, git_push, git_reset, git_show, and git_status.
---
Remote GitHub MCP Server
 
The remote GitHub MCP Server is hosted by GitHub and provides the easiest method for getting up and running. If your MCP host does not support remote MCP servers, don't worry! You can use the local version of the GitHub MCP Server instead.
Prerequisites
- A compatible MCP host with remote server support (VS Code 1.101+, Claude Desktop, Cursor, Windsurf, etc.)
- Any applicable policies enabled
Install in VS Code
For quick installation, use one of the one-click install buttons above. Once you complete that flow, toggle Agent mode (located by the Copilot Chat text input) and the server will start. Make sure you're using VS Code 1.101 or later for remote MCP and OAuth support.
Alternatively, to manually configure VS Code, choose the appropriate JSON block from the examples below and add it to your host configuration:
<table> <tr><th>Using OAuth</th><th>Using a GitHub PAT</th></tr> <tr><th align=left colspan=2>VS Code (version 1.101 or greater)</th></tr> <tr valign=top> <td>
{
"servers": {
"github": {
"type": "http",
"url": "https://api.githubcopilot.com/mcp/"
}
}
}
</td> <td>
{
"servers": {
"github": {
"type": "http",
"url": "https://api.githubcopilot.com/mcp/",
"headers": {
"Authorization": "Bearer ${input:github_mcp_pat}"
}
}
},
"inputs": [
{
"type": "promptString",
"id": "github_mcp_pat",
"description": "GitHub Personal Access Token",
"password": true
}
]
}
</td> </tr> </table>
Install in other MCP hosts
- Copilot CLI - Installation guide for GitHub Copilot CLI
- GitHub Copilot in other IDEs - Installation for JetBrains, Visual Studio, Eclipse, and Xcode with GitHub Copilot
- Claude Applications - Installation guide for Claude Desktop and Claude Code CLI
- Codex - Installation guide for OpenAI Codex
- Cursor - Installation guide for Cursor IDE
- Windsurf - Installation guide for Windsurf IDE
- Rovo Dev CLI - Installation guide for Rovo Dev CLI
Note: Each MCP host application needs to configure a GitHub App or OAuth App to support remote access via OAuth. Any host application that supports remote MCP servers should support the remote GitHub server with PAT authentication. Configuration details and support levels vary by host. Make sure to refer to the host application's documentation for more info.
Configuration
Toolset configuration
See Remote Server Documentation for full details on remote server configuration, toolsets, headers, and advanced usage. This file provides comprehensive instructions and examples for connecting, customizing, and installing the remote GitHub MCP Server in VS Code and other MCP hosts.
When no toolsets are specified, default toolsets are used.
Insiders Mode
Try new features early! The remote server offers an insiders version with early access to new features and experimental tools.
<table> <tr><th>Using URL Path</th><th>Using Header</th></tr> <tr valign=top> <td>
{
"servers": {
"github": {
"type": "http",
"url": "https://api.githubcopilot.com/mcp/insiders"
}
}
}
</td> <td>
{
"servers": {
"github": {
"type": "http",
"url": "https://api.githubcopilot.com/mcp/",
"headers": {
"X-MCP-Insiders": "true"
}
}
}
}
</td> </tr> </table>
See Remote Server Documentation for more details and examples.
GitHub Enterprise
GitHub Enterprise Cloud with data residency (ghe.com)
GitHub Enterprise Cloud can also make use of the remote server.
Example for https://octocorp.ghe.com with GitHub PAT token:
{
...
"proxima-github": {
"type": "http",
"url": "https://copilot-api.octocorp.ghe.com/mcp",
"headers": {
"Authorization": "Bearer ${input:github_mcp_pat}"
}
},
...
}
Note: When using OAuth with GitHub Enterprise with VS Code and GitHub Copilot, you also need to configure your VS Code settings to point to your GitHub Enterprise instance - see Authenticate from VS Code
GitHub Enterprise Server
GitHub Enterprise Server does not support remote server hosting. Please refer to GitHub Enterprise Server and Enterprise Cloud with data residency (ghe.com) from the local server configuration.
---
Local GitHub MCP Server
 
Prerequisites
- To run the server in a container, you will need to have Docker installed.
- Once Docker is installed, you will also need to ensure Docker is running. The Docker image is available at
ghcr.io/aifity/omnigit-mcp. The image is public; if you get errors on pull, you may have an expired token and need todocker logout ghcr.io. - Lastly you will need to Create a GitHub Personal Access Token.
The MCP server can use many of the GitHub APIs, so enable the permissions that you feel comfortable granting your AI tools (to learn more about access tokens, please check out the documentation).
<details><summary><b>Handling PATs Securely</b></summary>
Environment Variables (Recommended)
To keep your GitHub PAT secure and reusable across different MCP hosts:
- Store your PAT in environment variables
export GITHUB_PAT=your_token_here
Or create a .env file:
GITHUB_PAT=your_token_here
- Protect your
.envfile
# Add to .gitignore to prevent accidental commits
echo ".env" >> .gitignore
- Reference the token in configurations
# CLI usage
claude mcp update github -e GITHUB_PERSONAL_ACCESS_TOKEN=$GITHUB_PAT
# In config files (where supported)
"env": {
"GITHUB_PERSONAL_ACCESS_TOKEN": "$GITHUB_PAT"
}
Note: Environment variable support varies by host app and IDE. Some applications (like Windsurf) require hardcoded tokens in config files.
Token Security Best Practices
- Minimum scopes: Only grant necessary permissions
repo- Repository operationsread:packages- Docker image accessread:org- Organization team access- Separate tokens: Use different PATs for different projects/environments
- Regular rotation: Update tokens periodically
- Never commit: Keep tokens out of version control
- File permissions: Restrict access to config files containing tokens
chmod 600 ~/.your-app/config.json
</details>
GitHub Enterprise Server and Enterprise Cloud with data residency (ghe.com)
The flag --gh-host and the environment variable GITHUB_HOST can be used to set the hostname for GitHub Enterprise Server or GitHub Enterprise Cloud with data residency.
- For GitHub Enterprise Server, prefix the hostname with the
https://URI scheme, as it otherwise defaults tohttp://, which GitHub Enterprise Server does not support. - For GitHub Enterprise Cloud with data residency, use
https://YOURSUBDOMAIN.ghe.comas the hostname.
"github": {
"command": "docker",
"args": [
"run",
"-i",
"--rm",
"-e",
"GITHUB_PERSONAL_ACCESS_TOKEN",
"-e",
"GITHUB_HOST",
"ghcr.io/aifity/omnigit-mcp"
],
"env": {
"GITHUB_PERSONAL_ACCESS_TOKEN": "${input:github_token}",
"GITHUB_HOST": "https://<your GHES or ghe.com domain name>"
}
}
Installation
Install in GitHub Copilot on VS Code
For quick installation, use one of the one-click install buttons above. Once you complete that flow, toggle Agent mode (located by the Copilot Chat text input) and the server will start.
More about using MCP server tools in VS Code's agent mode documentation.
Install in GitHub Copilot on other IDEs (JetBrains, Visual Studio, Eclipse, etc.)
Add the following JSON block to your IDE's MCP settings.
{
"mcp": {
"inputs": [
{
"type": "promptString",
"id": "github_token",
"description": "GitHub Personal Access Token",
"password": true
}
],
"servers": {
"github": {
"command": "docker",
"args": [
"run",
"-i",
"--rm",
"-e",
"GITHUB_PERSONAL_ACCESS_TOKEN",
"ghcr.io/aifity/omnigit-mcp"
],
"env": {
"GITHUB_PERSONAL_ACCESS_TOKEN": "${input:github_token}"
}
}
}
}
}
Optionally, you can add a similar example (i.e. without the mcp key) to a file called .vscode/mcp.json in your workspace. This will allow you to share the configuration with other host applications that accept the same format.
<details> <summary><b>Example JSON block without the MCP key included</b></summary> <br>
{
"inputs": [
{
"type": "promptString",
"id": "github_token",
"description": "GitHub Personal Access Token",
"password": true
}
],
"servers": {
"github": {
"command": "docker",
"args": [
"run",
"-i",
"--rm",
"-e",
"GITHUB_PERSONAL_ACCESS_TOKEN",
"ghcr.io/aifity/omnigit-mcp"
],
"env": {
"GITHUB_PERSONAL_ACCESS_TOKEN": "${input:github_token}"
}
}
}
}
</details>
Install in Other MCP Hosts
For other MCP host applications, please refer to our installation guides:
- Copilot CLI - Installation guide for GitHub Copilot CLI
- GitHub Copilot in other IDEs - Installation for JetBrains, Visual Studio, Eclipse, and Xcode with GitHub Copilot
- Claude Code & Claude Desktop - Installation guide for Claude Code and Claude Desktop
- Cursor - Installation guide for Cursor IDE
- Google Gemini CLI - Installation guide for Google Gemini CLI
- Windsurf - Installation guide for Windsurf IDE
For a complete overview of all installation options, see our Installation Guides Index.
Note: Any host application that supports local MCP servers should be able to access the local GitHub MCP server. However, the specific configuration process, syntax and stability of the integration will vary by host application. While many may follow a similar format to the examples above, this is not guaranteed. Please refer to your host application's documentation for the correct MCP configuration syntax and setup process.
Build from source
If you don't have Docker, you can use go build to build the binary in the cmd/omnigit-mcp directory, and use the omnigit-mcp stdio command with the GITHUB_PERSONAL_ACCESS_TOKEN environment variable set to your token. To specify the output location of the build, use the -o flag. You should configure your server to use the built executable as its command. For example:
{
"mcp": {
"servers": {
"github": {
"command": "/path/to/omnigit-mcp",
"args": ["stdio"],
"env": {
"GITHUB_PERSONAL_ACCESS_TOKEN": "<YOUR_TOKEN>"
}
}
}
}
}
CLI utilities
The omnigit-mcp binary includes a few CLI subcommands that are helpful for debugging and exploring the server.
omnigit-mcp tool-search "<query>"searches tools by name, description, and input parameter names. Use--max-resultsto return more matches.
Example (color output requires a TTY; use docker run -t (or -it) when running in Docker): ``bash docker run -it --rm ghcr.io/aifity/omnigit-mcp tool-search "issue" --max-results 5 omnigit-mcp tool-search "issue" --max-results 5 ``
Tool Configuration
The GitHub MCP Server supports enabling or disabling specific groups of functionalities via the --toolsets flag. This allows you to control which GitHub API capabilities are available to your AI tools. Enabling only the toolsets that you need can help the LLM with tool choice and reduce the context size.
_Toolsets are not limited to Tools. Relevant MCP Resources and Prompts are also included where applicable._
When no toolsets are specified, default toolsets are used.
Looking for examples? See the Server Configuration Guide for common recipes like minimal setups, read-only mode, and combining tools with toolsets.
Specifying Toolsets
To specify toolsets you want available to the LLM, you can pass an allow-list in two ways:
- Using Command Line Argument:
omnigit-mcp --toolsets repos,issues,pull_requests,actions,code_security
- Using Environment Variable:
GITHUB_TOOLSETS="repos,issues,pull_requests,actions,code_security" ./omnigit-mcp
The environment variable GITHUB_TOOLSETS takes precedence over the command line argument if both are provided.
Specifying Individual Tools
You can also configure specific tools using the --tools flag. Tools can be used independently or combined with toolsets and dynamic toolsets discovery for fine-grained control.
- Using Command Line Argument:
omnigit-mcp --tools get_file_contents,issue_read,create_pull_request
- Using Environment Variable:
GITHUB_TOOLS="get_file_contents,issue_read,create_pull_request" ./omnigit-mcp
- Combining with Toolsets (additive):
omnigit-mcp --toolsets repos,issues --tools get_gist
This registers all tools from repos and issues toolsets, plus get_gist.
- Combining with Dynamic Toolsets (additive):
omnigit-mcp --tools get_file_contents --dynamic-toolsets
This registers get_file_contents plus the dynamic toolset tools (enable_toolset, list_available_toolsets, get_toolset_tools).
Important Notes:
- Tools, toolsets, and dynamic toolsets can all be used together
- Read-only mode takes priority: write tools are skipped if
--read-onlyis set, even if explicitly requested via--tools - Tool names must match exactly (e.g.,
get_file_contents, notgetFileContents). Invalid tool names will cause the server to fail at startup with an error message - When tools are renamed, old names are preserved as aliases for backward compatibility. See Deprecated Tool Aliases for details.
Using Toolsets With Docker
When using Docker, you can pass the toolsets as environment variables:
docker run -i --rm \
-e GITHUB_PERSONAL_ACCESS_TOKEN=<your-token> \
-e GITHUB_TOOLSETS="repos,issues,pull_requests,actions,code_security" \
ghcr.io/aifity/omnigit-mcp
Using Tools With Docker
When using Docker, you can pass specific tools as environment variables. You can also combine tools with toolsets:
# Tools only
docker run -i --rm \
-e GITHUB_PERSONAL_ACCESS_TOKEN=<your-token> \
-e GITHUB_TOOLS="get_file_contents,issue_read,create_pull_request" \
ghcr.io/aifity/omnigit-mcp
# Tools combined with toolsets (additive)
docker run -i --rm \
-e GITHUB_PERSONAL_ACCESS_TOKEN=<your-token> \
-e GITHUB_TOOLSETS="repos,issues" \
-e GITHUB_TOOLS="get_gist" \
ghcr.io/aifity/omnigit-mcp
Special toolsets
"all" toolset
The special toolset all can be provided to enable all available toolsets regardless of any other configuration:
./omnigit-mcp --toolsets all
Or using the environment variable:
GITHUB_TOOLSETS="all" ./omnigit-mcp
"default" toolset
The default toolset default is the configuration that gets passed to the server if no toolsets are specified.
The default configuration is:
- context
- repos
- issues
- pull_requests
- users
To keep the default configuration and add additional toolsets:
GITHUB_TOOLSETS="default,stargazers" ./omnigit-mcp
Insiders Mode
The local GitHub MCP Server offers an insiders version with early access to new features and experimental tools.
- Using Command Line Argument:
./omnigit-mcp --insiders
- Using Environment Variable:
GITHUB_INSIDERS=true ./omnigit-mcp
When using Docker:
docker run -i --rm \
-e GITHUB_PERSONAL_ACCESS_TOKEN=<your-token> \
-e GITHUB_INSIDERS=true \
ghcr.io/aifity/omnigit-mcp
Available Toolsets
The following sets of tools are available:
<!-- START AUTOMATED TOOLSETS --> | | Toolset | Description | | --- | ----------------------- | ------------------------------------------------------------- | | <picture><source media="(prefers-color-scheme: dark)" srcset="pkg/octicons/icons/person-dark.png"><source media="(prefers-color-scheme: light)" srcset="pkg/octicons/icons/person-light.png"><img src="pkg/octicons/icons/person-light.png" width="20" height="20" alt="person"></picture> | context | Strongly recommended: Tools that provide context about the current user and GitHub context you are operating in | | <picture><source media="(prefers-color-scheme: dark)" srcset="pkg/octicons/icons/workflow-dark.png"><source media="(prefers-color-scheme: light)" srcset="pkg/octicons/icons/workflow-light.png"><img src="pkg/octicons/icons/workflow-light.png" width="20" height="20" alt="workflow"></picture> | actions | GitHub Actions workflows and CI/CD operations | | <picture><source media="(prefers-color-scheme: dark)" srcset="pkg/octicons/icons/codescan-dark.png"><source media="(prefers-color-scheme: light)" srcset="pkg/octicons/icons/codescan-light.png"><img src="pkg/octicons/icons/codescan-light.png" width="20" height="20" alt="codescan"></picture> | code_security | Code security related tools, such as GitHub Code Scanning | | <picture><source media="(prefers-color-scheme: dark)" srcset="pkg/octicons/icons/dependabot-dark.png"><source media="(prefers-color-scheme: light)" srcset="pkg/octicons/icons/dependabot-light.png"><img src="pkg/octicons/icons/dependabot-light.png" width="20" height="20" alt="dependabot"></picture> | dependabot | Dependabot tools | | <picture><source media="(prefers-color-scheme: dark)" srcset="pkg/octicons/icons/comment-discussion-dark.png"><source media="(prefers-color-scheme: light)" srcset="pkg/octicons/icons/comment-discussion-light.png"><img src="pkg/octicons/icons/comment-discussion-light.png" width="20" height="20" alt="comment-discussion"></picture> | discussions | GitHub Discussions related tools | | <picture><source media="(prefers-color-scheme: dark)" srcset="pkg/octicons/icons/logo-gist-dark.png"><source media="(prefers-color-scheme: light)" srcset="pkg/octicons/icons/logo-gist-light.png"><img src="pkg/octicons/icons/logo-gist-light.png" width="20" height="20" alt="logo-gist"></picture> | gists | GitHub Gist related tools | | <picture><source media="(prefers-color-scheme: dark)" srcset="pkg/octicons/icons/git-branch-dark.png"><source media="(prefers-color-scheme: light)" srcset="pkg/octicons/icons/git-branch-light.png"><img src="pkg/octicons/icons/git-branch-light.png" width="20" height="20" alt="git-branch"></picture> | git | GitHub Git API related tools for low-level Git operations | | <picture><source media="(prefers-color-scheme: dark)" srcset="pkg/octicons/icons/issue-opened-dark.png"><source media="(prefers-color-scheme: light)" srcset="pkg/octicons/icons/issue-opened-light.png"><img src="pkg/octicons/icons/issue-opened-light.png" width="20" height="20" alt="issue-opened"></picture> | issues | GitHub Issues related tools | | <picture><source media="(prefers-color-scheme: dark)" srcset="pkg/octicons/icons/tag-dark.png"><source media="(prefers-color-scheme: light)" srcset="pkg/octicons/icons/tag-light.png"><img src="pkg/octicons/icons/tag-light.png" width="20" height="20" alt="tag"></picture> | labels | GitHub Labels related tools | | <picture><source media="(prefers-color-scheme: dark)" srcset="pkg/octicons/icons/git-branch-dark.png"><source media="(prefers-color-scheme: light)" srcset="pkg/octicons/icons/git-branch-light.png"><img src="pkg/octicons/icons/git-branch-light.png" width="20" height="20" alt="git-branch"></picture> | local_git | Local Git repository operations - work with git repositories on your local machine (status, diff, commit, push, pull, branches, etc.) | | <picture><source media="(prefers-color-scheme: dark)" srcset="pkg/octicons/icons/bell-dark.png"><source media="(prefers-color-scheme: light)" srcset="pkg/octicons/icons/bell-light.png"><img src="pkg/octicons/icons/bell-light.png" width="20" height="20" alt="bell"></picture> | notifications | GitHub Notifications related tools | | <picture><source media="(prefers-color-scheme: dark)" srcset="pkg/octicons/icons/organization-dark.png"><source media="(prefers-color-scheme: light)" srcset="pkg/octicons/icons/organization-light.png"><img src="pkg/octicons/icons/organization-light.png" width="20" height="20" alt="organization"></picture> | orgs | GitHub Organization related tools | | <picture><source media="(prefers-color-scheme: dark)" srcset="pkg/octicons/icons/project-dark.png"><source media="(prefers-color-scheme: light)" srcset="pkg/octicons/icons/project-light.png"><img src="pkg/octicons/icons/project-light.png" width="20" height="20" alt="project"></picture> | projects | GitHub Projects related tools | | <picture><source media="(prefers-color-scheme: dark)" srcset="pkg/octicons/icons/git-pull-request-dark.png"><source media="(prefers-color-scheme: light)" srcset="pkg/octicons/icons/git-pull-request-light.png"><img src="pkg/octicons/icons/git-pull-request-light.png" width="20" height="20" alt="git-pull-request"></picture> | pull_requests | GitHub Pull Request related tools | | <picture><source media="(prefers-color-scheme: dark)" srcset="pkg/octicons/icons/repo-dark.png"><source media="(prefers-color-scheme: light)" srcset="pkg/octicons/icons/repo-light.png"><img src="pkg/octicons/icons/repo-light.png" width="20" height="20" alt="repo"></picture> | repos | GitHub Repository related tools | | <picture><source media="(prefers-color-scheme: dark)" srcset="pkg/octicons/icons/shield-lock-dark.png"><source media="(prefers-color-scheme: light)" srcset="pkg/octicons/icons/shield-lock-light.png"><img src="pkg/octicons/icons/shield-lock-light.png" width="20" height="20" alt="shield-lock"></picture> | secret_protection | Secret protection related tools, such as GitHub Secret Scanning | | <picture><source media="(prefers-color-scheme: dark)" srcset="pkg/octicons/icons/shield-dark.png"><source media="(prefers-color-scheme: light)" srcset="pkg/octicons/icons/shield-light.png"><img src="pkg/octicons/icons/shield-light.png" width="20" height="20" alt="shield"></picture> | security_advisories | Security advisories related tools | | <picture><source media="(prefers-color-scheme: dark)" srcset="pkg/octicons/icons/star-dark.png"><source media="(prefers-color-scheme: light)" srcset="pkg/octicons/icons/star-light.png"><img src="pkg/octicons/icons/star-light.png" width="20" height="20" alt="star"></picture> | stargazers | GitHub Stargazers related tools | | <picture><source media="(prefers-color-scheme: dark)" srcset="pkg/octicons/icons/people-dark.png"><source media="(prefers-color-scheme: light)" srcset="pkg/octicons/icons/people-light.png"><img src="pkg/octicons/icons/people-light.png" width="20" height="20" alt="people"></picture> | users | GitHub User related tools | <!-- END AUTOMATED TOOLSETS -->
Additional Toolsets in Remote GitHub MCP Server
| Toolset | Description | | ----------------------- | ------------------------------------------------------------- | | copilot | Copilot related tools (e.g. Copilot Coding Agent) | | copilot_spaces | Copilot Spaces related tools | | github_support_docs_search | Search docs to answer GitHub product and support questions |
Tools
<!-- START AUTOMATED TOOLS --> <details>
<summary><picture><source media="(prefers-color-scheme: dark)" srcset="pkg/octicons/icons/workflow-dark.png"><source media="(prefers-color-scheme: light)" srcset="pkg/octicons/icons/workflow-light.png"><img src="pkg/octicons/icons/workflow-light.png" width="20" height="20" alt="workflow"></picture> Actions</summary>
- actions_get - Get details of GitHub Actions resources (workflows, workflow runs, jobs, and artifacts)
- Required OAuth Scopes:
repo method: The method to execute (string, required)owner: Repository owner (string, required)repo: Repository name (string, required)resource_id: The unique identifier of the resource. This will vary based on the "method" provided, so ensure you provide the correct ID:- Provide a workflow ID or workflow file name (e.g. ci.yaml) for 'get_workflow' method.
- Provide a workflow run ID for 'get_workflow_run', 'get_workflow_run_usage', and 'get_workflow_run_logs_url' methods.
- Provide an artifact ID for 'download_workflow_run_artifact' method.
- Provide a job ID for 'get_workflow_job' method.
(string, required)
- actions_list - List GitHub Actions workflows in a repository
- Required OAuth Scopes:
repo method: The action to perform (string, required)owner: Repository owner (string, required)page: Page number for pagination (default: 1) (number, optional)per_page: Results per page for pagination (default: 30, max: 100) (number, optional)repo: Repository name (string, required)resource_id: The unique identifier of the resource. This will vary based on the "method" provided, so ensure you provide the correct ID:- Do not provide any resource ID for 'list_workflows' method.
- Provide a workflow ID or workflow file name (e.g. ci.yaml) for 'list_workflow_runs' method, or omit to list all workflow runs in the repository.
- Provide a workflow run ID for 'list_workflow_jobs' and 'list_workflow_run_artifacts' methods.
(string, optional)
workflow_jobs_filter: Filters for workflow jobs. ONLY used when method is 'list_workflow_jobs' (object, optional)workflow_runs_filter: Filters for workflow runs. ONLY used when method is 'list_workflow_runs' (object, optional)
- actions_run_trigger - Trigger GitHub Actions workflow actions
- Required OAuth Scopes:
repo inputs: Inputs the workflow accepts. Only used for 'run_workflow' method. (object, optional)method: The method to execute (string, required)owner: Repository owner (string, required)ref: The git reference for the workflow. The reference can be a branch or tag name. Required for 'run_workflow' method. (string, optional)repo: Repository name (string, required)run_id: The ID of the workflow run. Required for all methods except 'run_workflow'. (number, optional)workflow_id: The workflow ID (numeric) or workflow file name (e.g., main.yml, ci.yaml). Required for 'run_workflow' method. (string, optional)
- get_job_logs - Get GitHub Actions workflow job logs
- Required OAuth Scopes:
repo failed_only: When true, gets logs for all failed jobs in the workflow run specified by run_id. Requires run_id to be provided. (boolean, optional)job_id: The unique identifier of the workflow job. Required when getting logs for a single job. (number, optional)owner: Repository owner (string, required)repo: Repository name (string, required)return_content: Returns actual log content instead of URLs (boolean, optional)run_id: The unique identifier of the workflow run. Required when failed_only is true to get logs for all failed jobs in the run. (number, optional)tail_lines: Number of lines to return from the end of the log (number, optional)
</details>
<details>
<summary><picture><source media="(prefers-color-scheme: dark)" srcset="pkg/octicons/icons/codescan-dark.png"><source media="(prefers-color-scheme: light)" srcset="pkg/octicons/icons/codescan-light.png"><img src="pkg/octicons/icons/codescan-light.png" width="20" height="20" alt="codescan"></picture> Code Security</summary>
- get_code_scanning_alert - Get code scanning alert
- Required OAuth Scopes:
security_events - Accepted OAuth Scopes:
repo,security_events alertNumber: The number of the alert. (number, required)owner: The owner of the repository. (string, required)repo: The name of the repository. (string, required)
- list_code_scanning_alerts - List code scanning alerts
- Required OAuth Scopes:
security_events - Accepted OAuth Scopes:
repo,security_events owner: The owner of the repository. (string, required)ref: The Git reference for the results you want to list. (string, optional)repo: The name of the repository. (string, required)severity: Filter code scanning alerts by severity (string, optional)state: Filter code scanning alerts by state. Defaults to open (string, optional)tool_name: The name of the tool used for code scanning. (string, optional)
</details>
<details>
<summary><picture><source media="(prefers-color-scheme: dark)" srcset="pkg/octicons/icons/person-dark.png"><source media="(prefers-color-scheme: light)" srcset="pkg/octicons/icons/person-light.png"><img src="pkg/octicons/icons/person-light.png" width="20" height="20" alt="person"></picture> Context</summary>
- get_me - Get my user profile
- No parameters required
- get_team_members - Get team members
- Required OAuth Scopes:
read:org - Accepted OAuth Scopes:
admin:org,read:org,write:org org: Organization login (owner) that contains the team. (string, required)team_slug: Team slug (string, required)
- get_teams - Get teams
- Required OAuth Scopes:
read:org - Accepted OAuth Scopes:
admin:org,read:org,write:org user: Username to get teams for. If not provided, uses the authenticated user. (string, optional)
</details>
<details>
<summary><picture><source media="(prefers-color-scheme: dark)" srcset="pkg/octicons/icons/dependabot-dark.png"><source media="(prefers-color-scheme: light)" srcset="pkg/octicons/icons/dependabot-light.png"><img src="pkg/octicons/icons/dependabot-light.png" width="20" height="20" alt="dependabot"></picture> Dependabot</summary>
- get_dependabot_alert - Get dependabot alert
- Required OAuth Scopes:
security_events - Accepted OAuth Scopes:
repo,security_events alertNumber: The number of the alert. (number, required)owner: The owner of the repository. (string, required)repo: The name of the repository. (string, required)
- list_dependabot_alerts - List dependabot alerts
- Required OAuth Scopes:
security_events - Accepted OAuth Scopes:
repo,security_events owner: The owner of the repository. (string, required)repo: The name of the repository. (string, required)severity: Filter dependabot alerts by severity (string, optional)state: Filter dependabot alerts by state. Defaults to open (string, optional)
</details>
<details>
<summary><picture><source media="(prefers-color-scheme: dark)" srcset="pkg/octicons/icons/comment-discussion-dark.png"><source media="(prefers-color-scheme: light)" srcset="pkg/octicons/icons/comment-discussion-light.png"><img src="pkg/octicons/icons/comment-discussion-light.png" width="20" height="20" alt="comment-discussion"></picture> Discussions</summary>
- get_discussion - Get discussion
- Required OAuth Scopes:
repo discussionNumber: Discussion Number (number, required)owner: Repository owner (string, required)repo: Repository name (string, required)
- get_discussion_comments - Get discussion comments
- Required OAuth Scopes:
repo after: Cursor for pagination. Use the endCursor from the previous page's PageInfo for GraphQL APIs. (string, optional)discussionNumber: Discussion Number (number, required)owner: Repository owner (string, required)perPage: Results per page for pagination (min 1, max 100) (number, optional)repo: Repository name (string, required)
- list_discussion_categories - List discussion categories
- Required OAuth Scopes:
repo owner: Repository owner (string, required)repo: Repository name. If not provided, discussion categories will be queried at the organisation level. (string, optional)
- list_discussions - List discussions
- Required OAuth Scopes:
repo after: Cursor for pagination. Use the endCursor from the previous page's PageInfo for GraphQL APIs. (string, optional)category: Optional filter by discussion category ID. If provided, only discussions with this category are listed. (string, optional)direction: Order direction. (string, optional)orderBy: Order discussions by field. If provided, the 'direction' also needs to be provided. (string, optional)owner: Repository owner (string, required)perPage: Results per page for pagination (min 1, max 100) (number, optional)repo: Repository name. If not provided, discussions will be queried at the organisation level. (string, optional)
</details>
<details>
<summary><picture><source media="(prefers-color-scheme: dark)" srcset="pkg/octicons/icons/logo-gist-dark.png"><source media="(prefers-color-scheme: light)" srcset="pkg/octicons/icons/logo-gist-light.png"><img src="pkg/octicons/icons/logo-gist-light.png" width="20" height="20" alt="logo-gist"></picture> Gists</summary>
- create_gist - Create Gist
- Required OAuth Scopes:
gist content: Content for simple single-file gist creation (string, required)description: Description of the gist (string, optional)filename: Filename for simple single-file gist creation (string, required)public: Whether the gist is public (boolean, optional)
- get_gist - Get Gist Content
gist_id: The ID of the gist (string, required)
- list_gists - List Gists
page: Page number for pagination (min 1) (number, optional)perPage: Results per page for pagination (min 1, max 100) (number, optional)since: Only gists updated after this time (ISO 8601 timestamp) (string, optional)username: GitHub username (omit for authenticated user's gists) (string, optional)
- update_gist - Update Gist
- Required OAuth Scopes:
gist content: Content for the file (string, required)description: Updated description of the gist (string, optional)filename: Filename to update or create (string, required)gist_id: ID of the gist to update (string, required)
</details>
<details>
<summary><picture><source media="(prefers-color-scheme: dark)" srcset="pkg/octicons/icons/git-branch-dark.png"><source media="(prefers-color-scheme: light)" srcset="pkg/octicons/icons/git-branch-light.png"><img src="pkg/octicons/icons/git-branch-light.png" width="20" height="20" alt="git-branch"></picture> Git</summary>
- get_repository_tree - Get repository tree
- Required OAuth Scopes:
repo owner: Repository owner (username or organization) (string, required)path_filter: Optional path prefix to filter the tree results (e.g., 'src/' to only show files in the src directory) (string, optional)recursive: Setting this parameter to true returns the objects or subtrees referenced by the tree. Default is false (boolean, optional)repo: Repository name (string, required)tree_sha: The SHA1 value or ref (branch or tag) name of the tree. Defaults to the repository's default branch (string, optional)
</details>
<details>
<summary><picture><source media="(prefers-color-scheme: dark)" srcset="pkg/octicons/icons/issue-opened-dark.png"><source media="(prefers-color-scheme: light)" srcset="pkg/octicons/icons/issue-opened-light.png"><img src="pkg/octicons/icons/issue-opened-light.png" width="20" height="20" alt="issue-opened"></picture> Issues</summary>
- add_issue_comment - Add comment to issue
- Required OAuth Scopes:
repo body: Comment content (string, required)issue_number: Issue number to comment on (number, required)owner: Repository owner (string, required)repo: Repository name (string, required)
- assign_copilot_to_issue - Assign Copilot to issue
- Required OAuth Scopes:
repo base_ref: Git reference (e.g., branch) that the agent will start its work from. If not specified, defaults to the repository's default branch (string, optional)custom_instructions: Optional custom instructions to guide the agent beyond the issue body. Use this to provide additional context, constraints, or guidance that is not captured in the issue description (string, optional)issue_number: Issue number (number, required)owner: Repository owner (string, required)repo: Repository name (string, required)
- get_label - Get a specific label from a repository.
- Required OAuth Scopes:
repo name: Label name. (string, required)owner: Repository owner (username or organization name) (string, required)repo: Repository name (string, required)
- issue_comment_write - Update or delete issue comment
- Required OAuth Scopes:
repo body: New comment content (required for update method) (string, optional)comment_id: Comment ID to update or delete (number, required)method: The write operation to perform on a comment.
Options are:
- 'update' - updates an existing comment.
- 'delete' - deletes an existing comment.
(string, required)
owner: Repository owner (string, required)repo: Repository name (string, required)
- issue_read - Get issue details
- Required OAuth Scopes:
repo issue_number: The number of the issue (number, required)method: The read operation to perform on a single issue.
Options are:
- get - Get details of a specific issue.
- get_comments - Get issue comments.
- get_sub_issues - Get sub-issues of the issue.
- get_labels - Get labels assigned to the issue.
(string, required)
owner: The owner of the repository (string, required)page: Page number for pagination (min 1) (number, optional)perPage: Results per page for pagination (min 1, max 100) (number, optional)repo: The name of the repository (string, required)
- issue_write - Create or update issue.
- Required OAuth Scopes:
repo assignees: Usernames to assign to this issue (string[], optional)body: Issue body content (string, optional)duplicate_of: Issue number that this issue is a duplicate of. Only used when state_reason is 'duplicate'. (number, optional)issue_number: Issue number to update (number, optional)labels: Labels to apply to this issue (string[], optional)method: Write operation to perform on a single issue.
Options are:
- 'create' - creates a new issue.
- 'update' - updates an existing issue.
(string, required)
milestone: Milestone number (number, optional)owner: Repository owner (string, required)repo: Repository name (string, required)state: New state (string, optional)state_reason: Reason for the state change. Ignored unless state is changed. (string, optional)title: Issue title (string, optional)type: Type of this issue. Only use if the repository has issue types configured. Use list_issue_types tool to get valid type values for the organization. If the repository doesn't support issue types, omit this parameter. (string, optional)
- list_issue_types - List available issue types
- Required OAuth Scopes:
read:org - Accepted OAuth Scopes:
admin:org,read:org,write:org owner: The organization owner of the repository (string, required)
- list_issues - List issues
- Required OAuth Scopes:
repo after: Cursor for pagination. Use the endCursor from the previous page's PageInfo for GraphQL APIs. (string, optional)direction: Order direction. If provided, the 'orderBy' also needs to be provided. (string, optional)labels: Filter by labels (string[], optional)orderBy: Order issues by field. If provided, the 'direction' also needs to be provided. (string, optional)owner: Repository owner (string, required)perPage: Results per page for pagination (min 1, max 100) (number, optional)repo: Repository name (string, required)since: Filter by date (ISO 8601 timestamp) (string, optional)state: Filter by state, by default both open and closed issues are returned when not provided (string, optional)
- search_issues - Search issues
- Required OAuth Scopes:
repo order: Sort order (string, optional)owner: Optional repository owner. If provided with repo, only issues for this repository are listed. (string, optional)page: Page number for pagination (min 1) (number, optional)perPage: Results per page for pagination (min 1, max 100) (number, optional)query: Search query using GitHub issues search syntax (string, required)repo: Optional repository name. If provided with owner, only issues for this repository are listed. (string, optional)sort: Sort field by number of matches of categories, defaults to best match (string, optional)
- sub_issue_write - Change sub-issue
- Required OAuth Scopes:
repo after_id: The ID of the sub-issue to be prioritized after (either after_id OR before_id should be specified) (number, optional)before_id: The ID of the sub-issue to be prioritized before (either after_id OR before_id should be specified) (number, optional)issue_number: The number of the parent issue (number, required)method: The action to perform on a single sub-issue
Options are:
- 'add' - add a sub-issue to a parent issue in a GitHub repository.
- 'remove' - remove a sub-issue from a parent issue in a GitHub repository.
- 'reprioritize' - change the order of sub-issues within a parent issue in a GitHub repository. Use either 'after_id' or 'before_id' to specify the new position.
(string, required)
owner: Repository owner (string, required)replace_parent: When true, replaces the sub-issue's current parent issue. Use with 'add' method only. (boolean, optional)repo: Repository name (string, required)sub_issue_id: The ID of the sub-issue to add. ID is not the same as issue number (number, required)
</details>
<details>
<summary><picture><source media="(prefers-color-scheme: dark)" srcset="pkg/octicons/icons/tag-dark.png"><source media="(prefers-color-scheme: light)" srcset="pkg/octicons/icons/tag-light.png"><img src="pkg/octicons/icons/tag-light.png" width="20" height="20" alt="tag"></picture> Labels</summary>
- get_label - Get a specific label from a repository.
- Required OAuth Scopes:
repo name: Label name. (string, required)owner: Repository owner (username or organization name) (string, required)repo: Repository name (string, required)
- label_write - Write operations on repository labels.
- Required OAuth Scopes:
repo color: Label color as 6-character hex code without '#' prefix (e.g., 'f29513'). Required for 'create', optional for 'update'. (string, optional)description: Label description text. Optional for 'create' and 'update'. (string, optional)method: Operation to perform: 'create', 'update', or 'delete' (string, required)name: Label name - required for all operations (string, required)new_name: New name for the label (used only with 'update' method to rename) (string, optional)owner: Repository owner (username or organization name) (string, required)repo: Repository name (string, required)
- list_label - List labels from a repository
- Required OAuth Scopes:
repo owner: Repository owner (username or organization name) - required for all operations (string, required)repo: Repository name - required for all operations (string, required)
</details>
<details>
<summary><picture><source media="(prefers-color-scheme: dark)" srcset="pkg/octicons/icons/git-branch-dark.png"><source media="(prefers-color-scheme: light)" srcset="pkg/octicons/icons/git-branch-light.png"><img src="pkg/octicons/icons/git-branch-light.png" width="20" height="20" alt="git-branch"></picture> Local Git</summary>
- git_add - Git add
files: Comma-separated list of file paths to stage (string, required)repo_path: Path to Git repository (optional if default repository is configured) (string, optional)
- git_add - Git add
files: Comma-separated list of file paths to stage (string, required)repo_path: Path to Git repository (optional if default repository is configured) (string, optional)
- git_apply_patch_file - Git apply patch file
patch_file: Path to the patch file (string, required)repo_path: Path to Git repository (optional if default repository is configured) (string, optional)
- git_apply_patch_file - Git apply patch file
patch_file: Path to the patch file (string, required)repo_path: Path to Git repository (optional if default repository is configured) (string, optional)
- git_apply_patch_string - Git apply patch string
patch_string: Patch string to apply (string, required)repo_path: Path to Git repository (optional if default repository is configured) (string, optional)
- git_apply_patch_string - Git apply patch string
patch_string: Patch string to apply (string, required)repo_path: Path to Git repository (optional if default repository is configured) (string, optional)
- git_checkout - Git checkout
branch_name: Name of branch to checkout (string, required)repo_path: Path to Git repository (optional if default repository is configured) (string, optional)
- git_checkout - Git checkout
branch_name: Name of branch to checkout (string, required)repo_path: Path to Git repository (optional if default repository is configured) (string, optional)
- git_commit - Git commit
message: Commit message (string, required)repo_path: Path to Git repository (optional if default repository is configured) (string, optional)
- git_commit - Git commit
message: Commit message (string, required)repo_path: Path to Git repository (optional if default repository is configured) (string, optional)
- git_create_branch - Git create branch
base_branch: Starting point for the new branch (optional) (string, optional)branch_name: Name of the new branch (string, required)repo_path: Path to Git repository (optional if default repository is configured) (string, optional)
- git_create_branch - Git create branch
base_branch: Starting point for the new branch (optional) (string, optional)branch_name: Name of the new branch (string, required)repo_path: Path to Git repository (optional if default repository is configured) (string, optional)
- git_diff - Git diff
repo_path: Path to Git repository (optional if default repository is configured) (string, optional)target: Target branch or commit to compare with (string, required)
- git_diff - Git diff
repo_path: Path to Git repository (optional if default repository is configured) (string, optional)target: Target branch or commit to compare with (string, required)
- git_diff_staged - Git diff staged
repo_path: Path to Git repository (optional if default repository is configured) (string, optional)
- git_diff_staged - Git diff staged
repo_path: Path to Git repository (optional if default repository is configured) (string, optional)
- git_diff_unstaged - Git diff unstaged
repo_path: Path to Git repository (optional if default repository is configured) (string, optional)
- git_diff_unstaged - Git diff unstaged
repo_path: Path to Git repository (optional if default repository is configured) (string, optional)
- git_init - Git init
repo_path: Path to directory to initialize git repo (string, required)
- git_init - Git init
repo_path: Path to directory to initialize git repo (string, required)
- git_list_repositories - Git list repositories
- No parameters required
- git_list_repositories - Git list repositories
- No parameters required
- git_log - Git log
max_count: Maximum number of commits to show (default: 10) (number, optional)repo_path: Path to Git repository (optional if default repository is configured) (string, optional)
- git_log - Git log
max_count: Maximum number of commits to show (default: 10) (number, optional)repo_path: Path to Git repository (optional if default repository is configured) (string, optional)
- git_pull - Git pull
branch: Branch name to pull (default: current branch's upstream) (string, optional)remote: Remote name (default: origin) (string, optional)repo_path: Path to Git repository (optional if default repository is configured) (string, optional)
- git_pull - Git pull
branch: Branch name to pull (default: current branch's upstream) (string, optional)remote: Remote name (default: origin) (string, optional)repo_path: Path to Git repository (optional if default repository is configured) (string, optional)
- git_push - Git push
branch: Branch name to push (default: current branch) (string, optional)remote: Remote name (default: origin) (string, optional)repo_path: Path to Git repository (optional if default repository is configured) (string, optional)
- git_push - Git push
branch: Branch name to push (default: current branch) (string, optional)remote: Remote name (default: origin) (string, optional)repo_path: Path to Git repository (optional if default repository is configured) (string, optional)
- git_reset - Git reset
repo_path: Path to Git repository (optional if default repository is configured) (string, optional)
- git_reset - Git reset
repo_path: Path to Git repository (optional if default repository is configured) (string, optional)
- git_show - Git show
repo_path: Path to Git repository (optional if default repository is configured) (string, optional)revision: The revision (commit hash, branch name, tag) to show (string, required)
- git_show - Git show
repo_path: Path to Git repository (optional if default repository is configured) (string, optional)revision: The revision (commit hash, branch name, tag) to show (string, required)
- git_status - Git status
repo_path: Path to Git repository (optional if default repository is configured) (string, optional)
- git_status - Git status
repo_path: Path to Git repository (optional if default repository is configured) (string, optional)
- git_worktree_add - Git worktree add
commitish: Branch name, tag, or commit SHA to checkout in the new worktree (optional) (string, optional)detach: Create a detached HEAD worktree (optional, default: false) (boolean, optional)force: Force creation even if worktree path already exists (optional, default: false) (boolean, optional)new_branch: Create a new branch with this name in the worktree (optional) (string, optional)repo_path: Path to Git repository (optional if default repository is configured) (string, optional)worktree_path: Path where the new worktree should be created (string, required)
- git_worktree_add - Git worktree add
commitish: Branch name, tag, or commit SHA to checkout in the new worktree (optional) (string, optional)detach: Create a detached HEAD worktree (optional, default: false) (boolean, optional)force: Force creation even if worktree path already exists (optional, default: false) (boolean, optional)new_branch: Create a new branch with this name in the worktree (optional) (string, optional)repo_path: Path to Git repository (optional if default repository is configured) (string, optional)worktree_path: Path where the new worktree should be created (string, required)
- git_worktree_list - Git worktree list
repo_path: Path to Git repository (optional if default repository is configured) (string, optional)
- git_worktree_list - Git worktree list
repo_path: Path to Git repository (optional if default repository is configured) (string, optional)
- git_worktree_lock - Git worktree lock
reason: Reason for locking the worktree (optional) (string, optional)repo_path: Path to Git repository (optional if default repository is configured) (string, optional)worktree: Path to the worktree directory to lock (string, required)
- git_worktree_lock - Git worktree lock
reason: Reason for locking the worktree (optional) (string, optional)repo_path: Path to Git repository (optional if default repository is c






