Skip to main content

MCP server for downloading Jira and Confluence Cloud attachments

Project description

MCP Atlassian Attachments

A Model Context Protocol (MCP) server for downloading Jira Cloud attachments by attachment ID, using Atlassian Cloud granular API token authentication.

Supplement to the official Atlassian MCP server. The official Atlassian MCP server covers search, issue management, and content operations but does not support downloading attachment files to disk. This server fills that gap.

Requirements: Python 3.13+, an Atlassian Cloud account, and a granular API token with the read:attachment:jira scope.

Authentication

This server uses granular API tokens — scoped tokens that limit access to exactly the permissions needed.

Create a granular API token

  1. Go to id.atlassian.com/manage-profile/security/api-tokens
  2. Click Create API token and choose "Create API token with scopes"
  3. Select the scope: read:attachment:jira
  4. Copy the generated token

Why granular tokens?

Granular tokens route through api.atlassian.com instead of your org's domain, which requires Atlassian to verify your token's scope. This follows the least-privilege principle — the token can only read attachments, nothing else.

The server automatically resolves your Cloud ID from your site URL at startup (via /_edge/tenant_info), so you never need to look it up manually.

Quick start

The fastest way to try the server is with the MCP Inspector. Set the three required environment variables and run:

From the published package (no clone needed):

ATLASSIAN_SITE_URL=https://yourorg.atlassian.net \
ATLASSIAN_EMAIL=your.email@example.com \
ATLASSIAN_API_TOKEN=your-api-token \
npx -y @modelcontextprotocol/inspector uvx mcp-atlassian-attachments

From a local clone:

ATLASSIAN_SITE_URL=https://yourorg.atlassian.net \
ATLASSIAN_EMAIL=your.email@example.com \
ATLASSIAN_API_TOKEN=your-api-token \
npx -y @modelcontextprotocol/inspector uv run mcp-atlassian-attachments

Configuration

Set environment variables or create a config file. Environment variables take priority.

Environment variables:

export ATLASSIAN_SITE_URL="https://yourorg.atlassian.net"
export ATLASSIAN_EMAIL="your.email@example.com"
export ATLASSIAN_API_TOKEN="your-api-token"

Config file (~/.config/mcp-atlassian-attachments/config.json):

{
  "site_url": "https://yourorg.atlassian.net",
  "email": "your.email@example.com",
  "api_token": "your-api-token"
}

The server resolves your Atlassian Cloud ID automatically from the site URL — no manual lookup required.

Tools

Tool Description Required params
download_jira_attachment_tool Download a Jira attachment by ID. attachment_id, output_dir

Common parameters

Parameter Type Description
attachment_id string Jira attachment ID
output_dir string Local directory for the saved file. Created automatically if it does not exist.
filename string (optional) Override filename. Uses metadata filename when omitted.
overwrite bool (optional) Replace an existing file. Defaults to false.

Output

The tool returns a JSON object:

{
  "product": "jira",
  "attachmentId": "439535",
  "filename": "screenshot.png",
  "mimeType": "image/png",
  "size": 496724,
  "path": "/your/output/dir/screenshot.png",
  "sourceUrl": "https://api.atlassian.com/ex/jira/<cloud-id>/rest/api/3/attachment/content/439535"
}

MCP host configuration

Add the following to your MCP host's config file. The JSON is the same for Cursor (.cursor/mcp.json), Claude Desktop (claude_desktop_config.json), and Claude Code (.claude.json).

{
  "mcpServers": {
    "atlassian": {
      "command": "uvx",
      "args": ["mcp-atlassian-attachments"],
      "env": {
        "ATLASSIAN_SITE_URL": "https://yourorg.atlassian.net",
        "ATLASSIAN_EMAIL": "your.email@example.com",
        "ATLASSIAN_API_TOKEN": "your-api-token"
      }
    }
  }
}

Security

  • ATLASSIAN_API_TOKEN is never logged or included in error messages.
  • The computed Authorization header is never exposed in tool output or errors.
  • File writes are confined to the provided output_dir.
  • Filenames are sanitized to prevent path traversal.

Tests

uv run pytest tests/ -v

Roadmap

  • download_confluence_attachment_tool — Confluence Cloud uses a different API (/wiki/api/v2/) and a different identifier model. Planned for a future release.

License

MIT. See LICENSE.

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

mcp_atlassian_attachments-0.1.0.tar.gz (48.0 kB view details)

Uploaded Source

Built Distribution

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

mcp_atlassian_attachments-0.1.0-py3-none-any.whl (8.4 kB view details)

Uploaded Python 3

File details

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

File metadata

File hashes

Hashes for mcp_atlassian_attachments-0.1.0.tar.gz
Algorithm Hash digest
SHA256 99a707b090a1efeba2c9bfd5f55cee064845b0f7aad0de33ffcd35636f476ea9
MD5 bc086e86baa9215c946bad87c0048afc
BLAKE2b-256 a804ecbe713fd4a7a351d642b5107625db89cdae2c18182e1b374a90f03233f4

See more details on using hashes here.

Provenance

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

Publisher: ci.yml on alyiox/mcp-atlassian-attachments

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

File details

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

File metadata

File hashes

Hashes for mcp_atlassian_attachments-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 f0a86f43d16590d46d54f827a2be65c9e8837b4d31c9b1ccbe49788f3cad0531
MD5 de3471fcd485c02459f0cc188506a72d
BLAKE2b-256 d2d6b3ca5ddc6d1dbead51be7077fc79e9f37405e349da1bce41865680dc7b82

See more details on using hashes here.

Provenance

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

Publisher: ci.yml on alyiox/mcp-atlassian-attachments

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