Feature flags let you opt into experimental tool behavior on top of the default GitHub MCP Server surface. Insiders Mode turns on a curated subset of these flags automatically — see Insiders Features for that specific set.
For background on how flags resolve at request time, see the resolution section in the Insiders docs.
| Method | Remote Server | Local Server |
|---|---|---|
| Header | X-MCP-Features: <flag>,<flag> |
N/A |
| CLI flag | N/A | --features=<flag>,<flag> |
| Environment variable | N/A | GITHUB_FEATURES=<flag>,<flag> |
Only flags listed in
AllowedFeatureFlags can be enabled by
end users. Insiders-only flags are not user-toggleable.
The list below is regenerated from the Go source. For each user-controllable feature flag, it lists every tool whose inventory or input schema differs from the default — either because the flag introduces a new tool, or because it selects a flag-aware variant of an existing tool. Flags that only affect runtime behavior (such as output formatting) won't appear here.
-
create_pull_request - Open new pull request
- Required OAuth Scopes:
repo - MCP App UI:
ui://github-mcp-server/pr-write base: Branch to merge into (string, required)body: PR description (string, optional)draft: Create as draft PR (boolean, optional)head: Branch containing changes (string, required)maintainer_can_modify: Allow maintainer edits (boolean, optional)owner: Repository owner (string, required)repo: Repository name (string, required)reviewers: GitHub usernames or ORG/team-slug team reviewers to request reviews from (string[], optional)title: PR title (string, required)
- Required OAuth Scopes:
-
get_me - Get my user profile
- MCP App UI:
ui://github-mcp-server/get-me - No parameters required
- MCP App UI:
-
issue_write - Create or update issue/pull request
- Required OAuth Scopes:
repo - MCP App UI:
ui://github-mcp-server/issue-write 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_fields: Issue field values to set or clear. Each item requires 'field_name' and exactly one of 'value', 'field_option_name', or 'delete: true'. (object[], 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 issue types are enabled for this repository. Use list_issue_types tool to get valid type values for this repository or its owner organization. If the repository doesn't support issue types, omit this parameter. (string, optional)
- Required OAuth Scopes:
-
ui_get - Get UI data
- Required OAuth Scopes (any of):
repo,read:org - Accepted OAuth Scopes:
admin:org,read:org,repo,write:org method: The type of data to fetch (string, required)owner: Repository owner (required for all methods) (string, required)repo: Repository name (required for labels, assignees, milestones, branches, issue fields, reviewers) (string, optional)
- Required OAuth Scopes (any of):
-
update_pull_request - Edit pull request
- Required OAuth Scopes:
repo - MCP App UI:
ui://github-mcp-server/pr-edit base: New base branch name (string, optional)body: New description (string, optional)draft: Mark pull request as draft (true) or ready for review (false) (boolean, optional)maintainer_can_modify: Allow maintainer edits (boolean, optional)owner: Repository owner (string, required)pullNumber: Pull request number to update (number, required)repo: Repository name (string, required)reviewers: GitHub usernames or ORG/team-slug team reviewers to request reviews from (string[], optional)state: New state (string, optional)title: New title (string, optional)
- Required OAuth Scopes:
-
add_issue_comment_reaction - Add Reaction to Issue or Pull Request Comment
- Required OAuth Scopes:
repo comment_id: The issue or pull request comment ID (number, required)content: The emoji reaction type (string, required)owner: Repository owner (username or organization) (string, required)repo: Repository name (string, required)
- Required OAuth Scopes:
-
add_issue_reaction - Add Reaction to Issue or Pull Request
- Required OAuth Scopes:
repo content: The emoji reaction type (string, required)issue_number: The issue number (number, required)owner: Repository owner (username or organization) (string, required)repo: Repository name (string, required)
- Required OAuth Scopes:
-
add_sub_issue - Add Sub-Issue
- Required OAuth Scopes:
repo issue_number: The parent issue number (number, required)owner: Repository owner (username or organization) (string, required)replace_parent: If true, reparent the sub-issue if it already has a parent (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)
- Required OAuth Scopes:
-
create_issue - Create Issue
- Required OAuth Scopes:
repo body: Issue body content (optional) (string, optional)owner: Repository owner (username or organization) (string, required)repo: Repository name (string, required)title: Issue title (string, required)
- Required OAuth Scopes:
-
remove_sub_issue - Remove Sub-Issue
- Required OAuth Scopes:
repo issue_number: The parent issue number (number, required)owner: Repository owner (username or organization) (string, required)repo: Repository name (string, required)sub_issue_id: The ID of the sub-issue to remove. ID is not the same as issue number (number, required)
- Required OAuth Scopes:
-
reprioritize_sub_issue - Reprioritize Sub-Issue
- Required OAuth Scopes:
repo after_id: The ID of the sub-issue to place this after (either after_id OR before_id should be specified) (number, optional)before_id: The ID of the sub-issue to place this before (either after_id OR before_id should be specified) (number, optional)issue_number: The parent issue number (number, required)owner: Repository owner (username or organization) (string, required)repo: Repository name (string, required)sub_issue_id: The ID of the sub-issue to reorder. ID is not the same as issue number (number, required)
- Required OAuth Scopes:
-
set_issue_fields - Set Issue Fields
- Required OAuth Scopes:
repo fields: Array of issue field values to set. Each element must have a 'field_id' (string, the GraphQL node ID of the field) and exactly one value field: 'text_value' for text fields, 'number_value' for number fields, 'date_value' (ISO 8601 date string) for date fields, or 'single_select_option_id' (the GraphQL node ID of the option) for single select fields. Set 'delete' to true to remove a field value. (object[], required)issue_number: The issue number to update (number, required)owner: Repository owner (username or organization) (string, required)repo: Repository name (string, required)
- Required OAuth Scopes:
-
update_issue_assignees - Update Issue Assignees
- Required OAuth Scopes:
repo assignees: GitHub usernames to assign to this issue (string[], required)issue_number: The issue number to update (number, required)owner: Repository owner (username or organization) (string, required)repo: Repository name (string, required)
- Required OAuth Scopes:
-
update_issue_body - Update Issue Body
- Required OAuth Scopes:
repo body: The new body content for the issue (string, required)issue_number: The issue number to update (number, required)owner: Repository owner (username or organization) (string, required)repo: Repository name (string, required)
- Required OAuth Scopes:
-
update_issue_labels - Update Issue Labels
- Required OAuth Scopes:
repo issue_number: The issue number to update (number, required)labels: Labels to apply to this issue. ([], required)owner: Repository owner (username or organization) (string, required)repo: Repository name (string, required)
- Required OAuth Scopes:
-
update_issue_milestone - Update Issue Milestone
- Required OAuth Scopes:
repo issue_number: The issue number to update (number, required)milestone: The milestone number to set on the issue (integer, required)owner: Repository owner (username or organization) (string, required)repo: Repository name (string, required)
- Required OAuth Scopes:
-
update_issue_state - Update Issue State
- Required OAuth Scopes:
repo issue_number: The issue number to update (number, required)owner: Repository owner (username or organization) (string, required)repo: Repository name (string, required)state: The new state for the issue (string, required)state_reason: The reason for the state change (only for closed state) (string, optional)
- Required OAuth Scopes:
-
update_issue_title - Update Issue Title
- Required OAuth Scopes:
repo issue_number: The issue number to update (number, required)owner: Repository owner (username or organization) (string, required)repo: Repository name (string, required)title: The new title for the issue (string, required)
- Required OAuth Scopes:
-
update_issue_type - Update Issue Type
- Required OAuth Scopes:
repo confidence: How confident you are in this choice. Use 'HIGH' for clear signal or explicit user request, 'MEDIUM' for reasonable inference with some ambiguity, 'LOW' for best guess with limited signal. (string, optional)is_suggestion: If true, this issue type change is sent to the API as a suggestion (suggest:true) rather than an applied value. Whether the type is applied or recorded as a proposal is determined by the API. (boolean, optional)issue_number: The issue number to update (number, required)issue_type: The issue type to set (string, required)owner: Repository owner (username or organization) (string, required)rationale: One concise sentence explaining what specifically about the issue led you to choose this type. State the concrete signal (e.g. 'Reports a crash when saving' → bug, 'Asks for dark mode support' → feature). (string, optional)repo: Repository name (string, required)
- Required OAuth Scopes:
-
add_pull_request_review_comment - Add Pull Request Review Comment
- Required OAuth Scopes:
repo body: The comment body (string, required)line: The line number in the diff to comment on (optional) (number, optional)owner: Repository owner (username or organization) (string, required)path: The relative path of the file to comment on (string, required)pullNumber: The pull request number (number, required)repo: Repository name (string, required)side: The side of the diff to comment on (optional) (string, optional)startLine: The start line of a multi-line comment (optional) (number, optional)startSide: The start side of a multi-line comment (optional) (string, optional)subjectType: The subject type of the comment (string, required)
- Required OAuth Scopes:
-
add_pull_request_review_comment_reaction - Add Pull Request Review Comment Reaction
- Required OAuth Scopes:
repo comment_id: The numeric pull request review comment ID. Use the number from a #discussion_r... anchor, not the GraphQL thread node ID (PRRT_...). (number, required)content: The emoji reaction type (string, required)owner: Repository owner (username or organization) (string, required)repo: Repository name (string, required)
- Required OAuth Scopes:
-
create_pull_request_review - Create Pull Request Review
- Required OAuth Scopes:
repo body: The review body text (optional) (string, optional)commitID: The SHA of the commit to review (optional, defaults to latest) (string, optional)event: The review action to perform. If omitted, creates a pending review. (string, optional)owner: Repository owner (username or organization) (string, required)pullNumber: The pull request number (number, required)repo: Repository name (string, required)
- Required OAuth Scopes:
-
delete_pending_pull_request_review - Delete Pending Pull Request Review
- Required OAuth Scopes:
repo owner: Repository owner (username or organization) (string, required)pullNumber: The pull request number (number, required)repo: Repository name (string, required)
- Required OAuth Scopes:
-
request_pull_request_reviewers - Request Pull Request Reviewers
- Required OAuth Scopes:
repo owner: Repository owner (username or organization) (string, required)pullNumber: The pull request number (number, required)repo: Repository name (string, required)reviewers: GitHub usernames or ORG/team-slug team reviewers to request reviews from (string[], required)
- Required OAuth Scopes:
-
resolve_review_thread - Resolve Review Thread
- Required OAuth Scopes:
repo threadID: The node ID of the review thread to resolve (e.g., PRRT_kwDOxxx) (string, required)
- Required OAuth Scopes:
-
submit_pending_pull_request_review - Submit Pending Pull Request Review
- Required OAuth Scopes:
repo body: The review body text (optional) (string, optional)event: The review action to perform (string, required)owner: Repository owner (username or organization) (string, required)pullNumber: The pull request number (number, required)repo: Repository name (string, required)
- Required OAuth Scopes:
-
unresolve_review_thread - Unresolve Review Thread
- Required OAuth Scopes:
repo threadID: The node ID of the review thread to unresolve (e.g., PRRT_kwDOxxx) (string, required)
- Required OAuth Scopes:
-
update_pull_request_body - Update Pull Request Body
- Required OAuth Scopes:
repo body: The new body content for the pull request (string, required)owner: Repository owner (username or organization) (string, required)pullNumber: The pull request number (number, required)repo: Repository name (string, required)
- Required OAuth Scopes:
-
update_pull_request_draft_state - Update Pull Request Draft State
- Required OAuth Scopes:
repo draft: Set to true to convert to draft, false to mark as ready for review (boolean, required)owner: Repository owner (username or organization) (string, required)pullNumber: The pull request number (number, required)repo: Repository name (string, required)
- Required OAuth Scopes:
-
update_pull_request_state - Update Pull Request State
- Required OAuth Scopes:
repo owner: Repository owner (username or organization) (string, required)pullNumber: The pull request number (number, required)repo: Repository name (string, required)state: The new state for the pull request (string, required)
- Required OAuth Scopes:
-
update_pull_request_title - Update Pull Request Title
- Required OAuth Scopes:
repo owner: Repository owner (username or organization) (string, required)pullNumber: The pull request number (number, required)repo: Repository name (string, required)title: The new title for the pull request (string, required)
- Required OAuth Scopes:
- get_file_blame - Get file blame information
- Required OAuth Scopes:
repo after: Cursor for pagination. Use the cursor from the previous response. (string, optional)end_line: Optional 1-based ending line of the window of interest. Must be >= start_line when both are provided. (number, optional)owner: Repository owner (username or organization) (string, required)path: Path to the file in the repository, relative to the repository root (string, required)perPage: Results per page for pagination (min 1, max 100) (number, optional)ref: Git reference (branch, tag, or commit SHA). Defaults to the repository's default branch (HEAD). (string, optional)repo: Repository name (string, required)start_line: Optional 1-based starting line of the window of interest. Only ranges overlapping [start_line, end_line] are returned, clamped to the window. (number, optional)
- Required OAuth Scopes:
-
issue_dependency_read - Read issue dependencies
- Required OAuth Scopes:
repo after: Cursor for pagination. Use the cursor from the previous response. (string, optional)issue_number: The number of the issue (number, required)method: The read operation to perform on a single issue's dependencies. Options are:- get_blocked_by - List the issues that block this issue (this issue is blocked by them).
- get_blocking - List the issues that this issue blocks. (string, required)
owner: The owner of the repository (string, required)perPage: Results per page for pagination (min 1, max 100) (number, optional)repo: The name of the repository (string, required)
- Required OAuth Scopes:
-
issue_dependency_write - Change issue dependency
- Required OAuth Scopes:
repo issue_number: The number of the subject issue (number, required)method: The action to perform. Options are:- 'add' - create the dependency relationship.
- 'remove' - delete the dependency relationship. (string, required)
owner: The owner of the subject issue's repository (string, required)related_issue_number: The number of the related issue to link or unlink (number, required)related_owner: The owner of the related issue's repository. Defaults to 'owner' when omitted. (string, optional)related_repo: The name of the related issue's repository. Defaults to 'repo' when omitted. (string, optional)repo: The name of the subject issue's repository (string, required)type: The relationship direction relative to the subject issue. Options are:- 'blocked_by' - the subject issue is blocked by the related issue.
- 'blocking' - the subject issue blocks the related issue. (string, required)
- Required OAuth Scopes: