A Model Context Protocol (MCP) server implementation in Python that integrates with Jira API. This allows AI models to interact with Jira through a standardized protocol.
This MCP server exposes Jira API operations as tools that can be used by AI models supporting the Model Context Protocol. The server implements the stdio transport mechanism to communicate with clients like Cursor.
- JQL Search Tool: Search for Jira issues using JQL queries
- Get Issue Tool: Retrieve detailed information about a specific Jira issue
- MCP SDK Integration: Compatible with the official MCP Python SDK
- Fallback Mode: Minimal implementation when the SDK is not available
- Environment Configuration: Load Jira credentials from environment variables
- Python 3.8+
- Jira API access (API token, email, and domain)
- Required Python packages:
mcp(Model Context Protocol Python SDK)aiohttp(for HTTP requests)pydantic(for validation)python-dotenv(for environment variables)
-
Clone this repository:
git clone https://github.com/yourusername/python-jira-mcp.git cd python-jira-mcp -
Install the dependencies:
pip install -r requirements.txt
-
Set up your Jira credentials:
cp .env.example .env # Edit .env with your Jira credentials
To start the MCP server, run:
python main.pyOr use the executable directly:
./main.pyThe server will start and listen for MCP messages on standard input (stdin) and respond on standard output (stdout).
To use this MCP server with Cursor:
- Start the server (as above)
- In Cursor, configure the MCP server path to point to
main.py - Use Jira tools directly within Cursor
Search for Jira issues using JQL (Jira Query Language).
Example:
{
"type": "tool_call",
"id": "123",
"name": "jql_search",
"parameters": {
"jql": "project = XYZ AND status = 'In Progress'",
"max_results": 10,
"fields": ["summary", "description", "status"]
}
}Retrieve details about a specific Jira issue by its ID or key.
Example:
{
"type": "tool_call",
"id": "456",
"name": "get_issue",
"parameters": {
"issue_id_or_key": "XYZ-123",
"fields": ["summary", "description", "status", "assignee"],
"expand": "changelog"
}
}main.py: Entry point for the MCP serversrc/server.py: Main MCP server implementationsrc/tools/jira_tools.py: Jira API tool implementationssrc/tool_schemas.py: Tool schemas definition
To add a new Jira-related tool:
- Implement the tool function in
src/tools/jira_tools.py - Add the tool schema in
src/tool_schemas.py - Register the tool in
src/server.py
This project is licensed under the MIT License - see the LICENSE file for details.