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.2.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.2-py3-none-any.whl (8.4 kB view details)

Uploaded Python 3

File details

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

File metadata

File hashes

Hashes for mcp_atlassian_attachments-0.1.2.tar.gz
Algorithm Hash digest
SHA256 177f285d51f5ac790b532517ab6cdf6c4acae948ba4e5684f796cc4fe9ad78df
MD5 0a100d402f99ce31bdfbd877163cf88d
BLAKE2b-256 606311751bc9a2d16f7d1f32a1941796ac18a233ad19455eca809f82d2470828

See more details on using hashes here.

Provenance

The following attestation bundles were made for mcp_atlassian_attachments-0.1.2.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.2-py3-none-any.whl.

File metadata

File hashes

Hashes for mcp_atlassian_attachments-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 bc42541c3726d2d6ec79a226db4cc921945e8cc5037e5fc3d2162ab6b591a33c
MD5 bdc4c162803195d36700cd4cf5bac83b
BLAKE2b-256 770539d4ece65a27adfd89ca8f23a2c95da9f3912e1e1ee9a5d03cc906cf2e04

See more details on using hashes here.

Provenance

The following attestation bundles were made for mcp_atlassian_attachments-0.1.2-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