Supports local Git operations including staging changes, committing with messages, pushing to branches, and creating branches based on issue keys.
Provides tools for creating and managing branches, creating and merging pull requests, and integrating GitHub workflows with issue tracking systems.
Enables retrieval, searching, and filtering of Jira issues using JQL queries, transitioning issues across workflow statuses, and managing issue assignments and tracking.
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., "@Jira - GitHub MCP Servercreate a branch for issue KAN-42 and start working on it"
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.
Jira - GitHub MCP Server
A modular and extensible Model Context Protocol (MCP) server for Jira and GitHub integration, enabling end-to-end automation of developer workflows - from issue tracking to code changes and pull request management - via AI agents inside the IDE.
Overview
Jira integration: fetch issues by filters, search via JQL, and transition issues across workflows
GitHub integration: create branches, open and merge PRs
Local Git operations: stage, commit, and push changes locally
IDE-native: works with any MCP-compatible agent (e.g., GitHub Copilot) over stdio
End-to-end workflow: Jira issue → branch → code → commit → PR → merge → Jira status update
Why
Developers constantly context-switch between Jira, GitHub, and their IDE, breaking focus and slowing down delivery. This project transforms that workflow into a seamless, IDE-native, conversational experience, allowing developers to move from Jira issue to merged pull request using natural language and AI-assisted automation.
Features
Retrieve, filter, and search Jira issues using fields and JQL
Transition Jira issues across workflow statuses
Automate branch creation as part of the Jira-driven workflow
Commit and push changes from the local Git repository
Create and merge GitHub pull requests
MCP resources providing workflow guidance and current issue context
Available Tools
Tool | Description |
| Retrieve a Jira issue by key (e.g., KAN-1) with configurable fields |
| Search Jira using JQL; paginate and filter results |
| List issues assigned to the current user, optionally filtered by status/type... |
| Move an issue to another status with optional comment |
| Create a new Git branch (e.g., |
| Create a PR on GitHub from a branch |
| Stage all changes, commit with a message, and push to a branch |
| Merge a PR using squash, merge, or rebase; optionally check CI status |
Project Structure
src/— Application source codeserver/— MCP server entry point and tool registrationconfig/— Configuration loading for Jira and GitHubproviders/— Jira/GitHub API clients and local Git operationstools/— MCP tool definitions and implementationsresources/— MCP resources (workflow guidance, issue context)prompts/— AI-facing prompts used internally by the server to guide agent behavior
tests/— Integration and unit testspyproject.toml— Project metadata and dependenciesuv.lock— Dependency lockfile
Architecture Overview
High-level overview of the system design and main components.
See full architecture documentation: docs/architecture.md
Installation & Setup
Requirements
Python 3.10+
Git (available on PATH)
Jira instance (Cloud or self-hosted) with REST API v3 access
GitHub repository with token-based API access
1. Clone the Repository
2. Create & Activate a Virtual Environment
Using uv (recommended)
Or with python
3. Install Dependencies
Using uv (recommended):
Or with pip:
The project depends on:
fastmcp: MCP protocol and server utilities
4. Configure Environment Variables
Create a .env file in the repository root:
Notes:
JIRA_BASE_URLshould not end with/Grant the GitHub PAT only the minimal permissions required (branches, pull requests, etc.)
5. Run the MCP Server
Run the server as a Python module:
If you defined an entrypoint, you can also run:
6. Connect from an MCP Client
To use this server with an MCP client (e.g., VS Code / GitHub Copilot), configure the client to run the server from the project root.
Example MCP configuration:
Note: Replace
/absolute/path/to/mcp-serverwith the actual path to the repository.
Connecting to GitHub Copilot
Here's how to connect and start using the server with Copilot:
Open VS Code and ensure GitHub Copilot is installed
Sign in with your GitHub account (if not already signed in)
Add the MCP server configuration to your VS Code settings (see JSON above)
Reload VS Code
Start asking Copilot natural language questions—it will invoke the tools automatically
How It Works
Example Workflow
This example demonstrates a complete issue-to-merge flow using GitHub Copilot with this MCP server.
Discover the next task
Ask Copilot:
"What is the most urgent task assigned to me?"
Call Tools:
jira_get_my_issues— list issues assigned to the userjira_search_issues— prioritize by status or urgency
Selected issue:
Start working on the issue
Ask Copilot:
"Start work on KAN-42"
Call Tools:
jira_get_issue(issue_key="KAN-42")create_branch_for_issue(issue_key="KAN-42")jira_transition_issue(issue_key="KAN-42", to_status="In Progress")
Make changes in your editor.
Commit changes
Ask Copilot:
"Commit my changes with message 'Implement KAN-42'"
Call Tools:
git_commit_and_push(message="Implement KAN-42", branch="feature/KAN-42")
Create a pull request
Ask Copilot:
"Create a PR for KAN-42"
Call Tools:
create_pull_request(issue_key="KAN-42", branch_name="feature/KAN-42")jira_transition_issue(issue_key="KAN-42", to_status="In Review")
Code review and CI checks run on GitHub.
Merge and close the issue
Ask Copilot:
"Merge the PR and move KAN-42 to Done"
Call Tools:
merge_pull_request(pr_number=123)jira_transition_issue(issue_key="KAN-42", to_status="Done")
Issue closed, code merged, workflow complete.
Use Cases
Day-to-day development workflows across Jira issues, branches, and pull requests
Code review processes with clear pull request status tracking
Sprint execution and task progress visibility
Rapid bug fixes and hotfix workflows
End-to-end feature development from issue to merge
Team collaboration with consistent status and ownership tracking
Future Enhancements
Multi-platform support: Extend integrations beyond GitHub to additional platforms (e.g. GitLab)
Smarter workflows: Multi-repo support, reusable JQL templates, and configurable automation rules
Deeper automation: AI-assisted PR/commit drafting, webhook-driven synchronization, and CI/CD feedback
Summary
This MCP server provides a clear and traceable development workflow by connecting Jira and GitHub through a single conversational interface.
By reducing manual coordination and keeping issues, branches, and pull requests in sync, it helps teams focus on development rather than process.
Designed with a focus on clarity, extensibility, and developer experience.