Jira MCP Server

Jira MCP Server

A production-ready server that automatically exposes your entire Jira instance through the Model Context Protocol, allowing seamless interaction with Jira's API features including issue management, project administration, and user management.

Category
Visit Server

README

Jira MCP Server

A production-ready Jira MCP server using FastMCP 2.0's OpenAPI integration. Automatically exposes your entire Jira instance through the Model Context Protocol (MCP) with zero configuration overhead.

Features

  • 🚀 Zero-maintenance OpenAPI integration - Automatically generates MCP tools from Jira's official API specification
  • 🔐 Secure authentication - Uses Jira API tokens with environment variable support
  • 🌐 Multiple transports - Support for stdio, HTTP, and SSE protocols
  • Fast and lightweight - Minimal overhead with async HTTP client
  • 🔧 Production-ready - Type-safe, well-tested, and follows security best practices
  • 📝 Self-documenting - All Jira API endpoints automatically become available as MCP tools

Quick Start

1. Installation

# Clone and install
git clone <repository-url>
cd jira_mcp
uv sync

2. Setup Jira API Token

  1. Go to Atlassian Account Settings
  2. Create an API token
  3. Note your Jira instance URL (e.g., https://yourcompany.atlassian.net)

3. Set Environment Variables

export JIRA_BASE_URL="https://yourcompany.atlassian.net"
export JIRA_API_USER="your-email@company.com"
export JIRA_API_TOKEN="your-api-token"

4. Run the Server

# Default configuration (stdio transport)
jira-mcp

# Or with custom transport
jira-mcp --transport http --port 8080

How It Works

The server automatically:

  1. Downloads Jira's official OpenAPI specification
  2. Generates MCP tools for every Jira API endpoint
  3. Authenticates requests using your API token
  4. Exposes your entire Jira instance through MCP

This means you get instant access to:

  • Issue management (create, update, search, transition)
  • Project administration
  • User and permission management
  • Dashboards and filters
  • Webhooks and automation
  • And every other Jira Cloud API feature!

Configuration

Environment Variables

Variable Required Default Description
JIRA_BASE_URL - Your Jira instance URL (e.g., https://company.atlassian.net)
JIRA_API_USER - Your Jira username/email address
JIRA_API_TOKEN - Your Jira API token
JIRA_TIMEOUT 30 HTTP timeout in seconds
MCP_TRANSPORT stdio Transport method (stdio, http, sse)
MCP_PORT 8000 Port for HTTP/SSE transports
MCP_LOG_LEVEL INFO Logging level (DEBUG, INFO, WARNING, ERROR)

Command Line Options

jira-mcp [OPTIONS]

Options:
  --transport {stdio,http,sse} Transport method (overrides MCP_TRANSPORT env var)
  --port PORT                  Port for HTTP/SSE transport (overrides MCP_PORT env var)
  --version                    Show version and exit
  --help                       Show help message

Integration with MCP Clients

Claude Desktop (Docker - Recommended)

Option 1: Using pre-built Docker image (easiest)

{
  "mcpServers": {
    "jira": {
      "command": "docker",
      "args": [
        "run", "--rm", "-i",
        "--env", "JIRA_BASE_URL=https://yourcompany.atlassian.net",
        "--env", "JIRA_API_USER=your-email@company.com", 
        "--env", "JIRA_API_TOKEN=your-api-token",
        "ghcr.io/brukhabtu/jira-mcp:latest"
      ]
    }
  }
}

Option 2: Using environment variables (more secure)

Set your credentials in your shell profile (.bashrc, .zshrc, etc.):

export JIRA_BASE_URL="https://yourcompany.atlassian.net"
export JIRA_API_USER="your-email@company.com"
export JIRA_API_TOKEN="your-api-token"

Then use this config:

{
  "mcpServers": {
    "jira": {
      "command": "docker",
      "args": [
        "run", "--rm", "-i",
        "--env", "JIRA_BASE_URL",
        "--env", "JIRA_API_USER",
        "--env", "JIRA_API_TOKEN", 
        "ghcr.io/brukhabtu/jira-mcp:latest"
      ]
    }
  }
}

Option 3: Local installation (if you prefer)

# Install with uv
git clone https://github.com/brukhabtu/jira-mcp.git
cd jira-mcp
uv sync
uv pip install -e .
{
  "mcpServers": {
    "jira": {
      "command": "jira-mcp",
      "env": {
        "JIRA_BASE_URL": "https://yourcompany.atlassian.net",
        "JIRA_API_USER": "your-email@company.com",
        "JIRA_API_TOKEN": "your-api-token"
      }
    }
  }
}

Advanced Docker Usage

Running as HTTP Service (for multiple clients)

# Run as background service
docker run -d --name jira-mcp \
  -p 8000:8000 \
  -e JIRA_BASE_URL=https://yourcompany.atlassian.net \
  -e JIRA_API_USER=your-email@company.com \
  -e JIRA_API_TOKEN=your-api-token \
  -e MCP_TRANSPORT=http \
  --restart unless-stopped \
  ghcr.io/brukhabtu/jira-mcp:latest

# Connect via HTTP from any MCP client
# Server will be available at http://localhost:8000

Other MCP Clients

The Docker image supports all MCP transport protocols:

  • stdio: For local desktop applications (Claude Desktop, etc.)
  • HTTP: For web applications and remote clients
  • SSE: For real-time web applications

Example HTTP usage:

# Start HTTP server
docker run -p 8000:8000 \
  -e MCP_TRANSPORT=http \
  -e JIRA_BASE_URL=https://yourcompany.atlassian.net \
  -e JIRA_API_USER=your-email@company.com \
  -e JIRA_API_TOKEN=your-api-token \
  ghcr.io/brukhabtu/jira-mcp:latest

# Connect from any HTTP MCP client to http://localhost:8000

Docker

Build and run with Docker:

# Build the image
docker build -t jira-mcp .

# Run with stdio transport (default)
docker run -e JIRA_BASE_URL=https://your-domain.atlassian.net \
           -e JIRA_API_USER=your-email@example.com \
           -e JIRA_API_TOKEN=your-api-token \
           jira-mcp

# Run with HTTP transport
docker run -p 8000:8000 \
           -e JIRA_BASE_URL=https://your-domain.atlassian.net \
           -e JIRA_API_USER=your-email@example.com \
           -e JIRA_API_TOKEN=your-api-token \
           -e MCP_TRANSPORT=http \
           jira-mcp

# Use pre-built image from GitHub Container Registry
docker run ghcr.io/brukhabtu/jira-mcp:latest

Development

Setup

# Install dependencies
uv sync

# Run all tests (55 unit and integration tests)
uv run pytest

# Run only unit tests
uv run pytest tests/unit/

# Run only integration tests  
uv run pytest tests/integration/

# Type checking (mypy strict mode)
uv run mypy jira_mcp/

# Code formatting and linting
uv run ruff check .
uv run ruff format .

Architecture

  • jira_mcp/config.py: Pydantic models with environment variable loading
  • jira_mcp/auth.py: HTTP client with Jira Basic Auth
  • jira_mcp/server.py: FastMCP integration with OpenAPI spec fetching
  • jira_mcp/__main__.py: CLI interface with environment-based configuration

Testing

The project includes 41 unit tests organized in tests/unit/ covering:

  • Configuration validation and edge cases
  • Authentication and HTTP client behavior
  • Server initialization and error handling
  • Environment variable parsing and type conversion

Troubleshooting

Common Issues

"Configuration error" on startup: Check that all required environment variables (JIRA_BASE_URL, JIRA_API_USER, JIRA_API_TOKEN) are set.

Authentication errors: Verify your API token is correct and your email matches your Jira account.

Connection timeout: Check your JIRA_BASE_URL is correct and accessible. Increase JIRA_TIMEOUT if needed.

Claude Desktop not finding server: Ensure environment variables are available to GUI applications (may require restart or launchctl setenv on macOS).

Getting Help

  • Check the CLAUDE.md file for development guidance
  • Review test files for usage examples
  • Run jira-mcp --help for command line options

Security

  • API tokens are stored in environment variables, never in code or config files
  • All HTTP requests use TLS encryption
  • No sensitive data is logged or exposed
  • Follows OAuth 2.0 and Atlassian security best practices

License

MIT

Recommended Servers

playwright-mcp

playwright-mcp

A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.

Official
Featured
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

graphlit-mcp-server

The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.

Official
Featured
TypeScript
Kagi MCP Server

Kagi MCP Server

An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

Exa Search

A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured