Skip to main content

MCP server for Jira Service Management — connect Claude Code, Claude Desktop, Cursor and other AI assistants to JSM

Project description

jira-service-desk-mcp

PyPI Python License: MIT

MCP (Model Context Protocol) server for Jira Service Management (formerly Jira Service Desk).
Connects AI assistants — Claude Code, Claude Desktop, Cursor, and others — to your JSM instance via Anthropic's MCP.

Built on top of atlassian-python-api and inspired by mcp-atlassian.

Features

Category Tools
Service Desks List desks, get desk by ID, app info
Request Types List types, get type details, get required fields
Customer Requests Create, get, list my requests, get status
Comments Add public/internal comments, list, get by ID
Customers Create customer, list, add/remove from desk
Participants List, add, remove request participants
Transitions List available transitions, perform transition
Organizations CRUD organizations, manage users, link to desks
Queues List queues, list issues in queue
SLA Get SLA info per request, by metric ID
Approvals List approvals, get by ID, approve/decline
Attachments Upload temp file, attach to request

40 tools total. Write operations are gated by READ_ONLY_MODE.

Quick Start

Install from PyPI

pip install jira-service-desk-mcp

Or with uv:

uv pip install jira-service-desk-mcp

Or install from source:

pip install -e .

Configure

Copy .env.example to .env and fill in your credentials:

cp .env.example .env

Recommended shared format (same env shape as mcp-atlassian):

JIRA_URL=https://jira.your-company.com
JIRA_PERSONAL_TOKEN=<base64-encoded username:token>

Use a base64-encoded username:token string when you want one MCP config style that works across both mcp-atlassian and jira-service-desk-mcp for Atlassian Cloud. On non-Cloud/self-hosted Jira instances, JIRA_PERSONAL_TOKEN now defaults to Bearer/PAT handling to avoid misclassifying base64-looking PATs. If you intentionally need basic auth there, set JIRA_PERSONAL_TOKEN_MODE=basic.

Alternative: Atlassian Cloud (username + API token):

JIRA_URL=https://your-instance.atlassian.net
JIRA_USERNAME=your-email@example.com
JIRA_API_TOKEN=your-api-token

Generate an API token at https://id.atlassian.com/manage-profile/security/api-tokens.

Alternative: Server / Data Center (raw Personal Access Token):

JIRA_URL=https://jira.your-company.com
JIRA_PERSONAL_TOKEN=your-personal-access-token

The token can be either a raw PAT (bearer token), the full Bearer <token> header value, or a base64-encoded username:api_token string. The server strips Bearer automatically when present.

For non-Cloud/self-hosted Jira, JIRA_PERSONAL_TOKEN is treated as Bearer/PAT by default, even if it looks like base64. This avoids accidental fallback to Basic auth for PATs that happen to decode cleanly. If you need to force Basic auth from JIRA_PERSONAL_TOKEN, set:

JIRA_PERSONAL_TOKEN_MODE=basic

Note: JIRA_IS_CLOUD is auto-detected from the URL (.atlassian.net → Cloud). Set it explicitly only if the heuristic is wrong for your instance.

Run

stdio (default — for Claude Code, Claude Desktop, Cursor, etc.):

jira-service-desk-mcp

SSE (for remote/web clients):

jira-service-desk-mcp --transport sse --port 8000

Claude Code Integration

The fastest way to connect JSM to Claude Code:

claude mcp add jira-service-desk -- jira-service-desk-mcp

With environment variables inline:

claude mcp add jira-service-desk \
  -e JIRA_URL=https://jira.your-company.com \
  -e JIRA_PERSONAL_TOKEN=<base64-encoded username:token> \
  -- uvx jira-service-desk-mcp

To scope the server to your project only:

claude mcp add --scope project jira-service-desk \
  -e JIRA_URL=https://jira.your-company.com \
  -e JIRA_PERSONAL_TOKEN=<base64-encoded username:token> \
  -- uvx jira-service-desk-mcp

Verify it works:

claude mcp list

Shared MCP Config

Add the same shape to ~/.claude.json, project-level .mcp.json, claude_desktop_config.json, or .cursor/mcp.json:

{
  "mcpServers": {
    "mcp-atlassian": {
      "type": "stdio",
      "command": "uvx",
      "args": ["mcp-atlassian"],
      "env": {
        "JIRA_URL": "https://jira.your-company.com",
        "JIRA_PERSONAL_TOKEN": "<base64-encoded username:token>"
      }
    },
    "jira-service-desk": {
      "type": "stdio",
      "command": "uvx",
      "args": ["jira-service-desk-mcp"],
      "env": {
        "JIRA_URL": "https://jira.your-company.com",
        "JIRA_PERSONAL_TOKEN": "<base64-encoded username:token>"
      }
    }
  }
}

This mirrors the mcp-atlassian configuration style for Atlassian Cloud while still allowing jira-service-desk-mcp to distinguish Cloud basic-auth tokens from non-Cloud Bearer/PAT tokens.


Environment Variables

Variable Required Description
JIRA_URL Yes Jira instance URL
JIRA_USERNAME Cloud Email for Atlassian Cloud
JIRA_API_TOKEN Cloud API token for Cloud auth
JIRA_PERSONAL_TOKEN Recommended Raw PAT or base64-encoded username:token
JIRA_PERSONAL_TOKEN_MODE No auto (default), pat, or basic override for JIRA_PERSONAL_TOKEN
JIRA_PASSWORD Basic auth password (not recommended)
JIRA_IS_CLOUD No Auto-detected from URL; set explicitly to override
JIRA_SSL_VERIFY No true (default) or false
READ_ONLY_MODE No true to disable all write operations

Available Tools

Service Desks

  • get_service_desk_info — Application info
  • list_service_desks — All accessible service desks
  • get_service_desk — Service desk by ID

Request Types

  • list_request_types — Request types for a desk
  • get_request_type — Specific request type
  • get_request_type_fields — Fields required for a request type

Customer Requests

  • create_customer_request — Create a new request
  • get_customer_request — Get request by key
  • list_my_customer_requests — Your requests
  • get_customer_request_status — Request status

Comments

  • add_request_comment — Add public or internal comment
  • list_request_comments — List comments on a request
  • get_request_comment — Get comment by ID

Customers

  • create_customer — Create customer account
  • list_customers — List customers of a desk
  • add_customers_to_service_desk — Add customers
  • remove_customers_from_service_desk — Remove customers

Participants

  • list_request_participants — List participants
  • add_request_participants — Add participants
  • remove_request_participants — Remove participants

Transitions

  • list_customer_transitions — Available transitions
  • perform_transition — Execute a transition

Organizations

  • list_organizations — List organizations
  • get_organization — Organization by ID
  • create_organization — Create organization
  • delete_organization — Delete organization
  • add_organization_to_service_desk — Link org to desk
  • remove_organization_from_service_desk — Unlink org
  • list_users_in_organization — Users in org
  • add_users_to_organization — Add users to org
  • remove_users_from_organization — Remove users from org

Queues

  • list_queues — Queues in a service desk
  • list_issues_in_queue — Issues in a queue

SLA

  • get_request_sla — SLA info for a request
  • get_request_sla_by_id — Specific SLA metric

Approvals

  • list_approvals — Approvals for a request
  • get_approval — Approval by ID
  • answer_approval — Approve or decline

Attachments

  • upload_temporary_attachment — Upload temp file
  • attach_file_to_request — Attach to request

Architecture

src/mcp_jira_service_desk/
├── __init__.py      # CLI entry point (click)
├── __main__.py      # python -m support
├── config.py        # Environment-based configuration
├── client.py        # ServiceDeskClient — wraps atlassian-python-api
├── formatting.py    # Human-readable formatting for API responses
└── server.py        # FastMCP server with all tool definitions
  • config.py — reads JIRA_* env vars, determines auth type
  • client.py — thin typed wrapper around atlassian.ServiceDesk, normalizes paginated responses
  • formatting.py — converts raw API dicts into markdown for LLM consumption
  • server.pyFastMCP instance with @mcp.tool() decorators for each operation

Development

git clone https://github.com/CzSadykov/jira-service-desk-mcp.git
cd jira-service-desk-mcp
pip install -e ".[dev]"
pytest

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

jira_service_desk_mcp-0.1.0.tar.gz (28.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

jira_service_desk_mcp-0.1.0-py3-none-any.whl (18.3 kB view details)

Uploaded Python 3

File details

Details for the file jira_service_desk_mcp-0.1.0.tar.gz.

File metadata

  • Download URL: jira_service_desk_mcp-0.1.0.tar.gz
  • Upload date:
  • Size: 28.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for jira_service_desk_mcp-0.1.0.tar.gz
Algorithm Hash digest
SHA256 5c4bcd4214c7c08a131b548594686c7f59a5cbe4118db3e87cae67a5e7f081c1
MD5 c20e3f9628be8a2c19bddc4ff480a3eb
BLAKE2b-256 8117ea9734945151bb35dd13fb9162cf18994ac540a43e0c0a581c7098811d4d

See more details on using hashes here.

Provenance

The following attestation bundles were made for jira_service_desk_mcp-0.1.0.tar.gz:

Publisher: publish.yml on CzSadykov/jira-service-desk-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file jira_service_desk_mcp-0.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for jira_service_desk_mcp-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 48ffb6a829dc7e4a8ba1ecfeeb187101f8f5ad10e7e4ee3e8961b67bf49708fa
MD5 f94baa02ee4e1c66c622d73e228b2726
BLAKE2b-256 2b7146afc83c8f7226a1a918e8220f95b8ab1fe6264bfaa44200d9f35c607d66

See more details on using hashes here.

Provenance

The following attestation bundles were made for jira_service_desk_mcp-0.1.0-py3-none-any.whl:

Publisher: publish.yml on CzSadykov/jira-service-desk-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page