Atlassian Trello MCP
Comprehensive Trello integration: 46 tools covering boards, cards, lists, labels, checklists, attachments, members, custom fields, and search. Read-only mode, image attachment auto-download. Active fork of kocakli/Trello-Desktop-MCP integrating contributions from across the Trello MCP fork ecosystem
Trello MCP Server
🔀 Active fork. This is a maintained fork of kocakli/Trello-Desktop-MCP integrating contributions from across the fork ecosystem (kevinhillinger, zonca, dbz-max, maks244, jantman, ThatIanMcShane, josh-argyle). PRs welcome — see Credits for what each contributor brought in. Published on npm as
atlassian-trello-mcp.
A Model Context Protocol (MCP) server for Trello that works with any MCP-compatible client -- Claude Desktop, Claude Code, Gemini CLI, and more.
Provides 46 tools covering boards, cards, lists, labels, checklists, attachments, members, custom fields, and search.
Quick Start
1. Get Trello API credentials
Trello no longer hands out API keys directly — each user must create their own Power-Up, then mint a token against that Power-Up's key.
- Visit https://trello.com/power-ups/admin and click New.
- Fill out the New Power-Up or Integration form:
- New Power-Up or Integration name:
Claude MCP. If you have multiple team members, each developer must create their own Power-Up so the API key is tied to their user — name it with your own name too, e.g.Trello MCP Steve. - Workspace: the workspace you want to interact with.
- Iframe connector URL:
https://localhost(required field, not actually used by this MCP server). - Email: your email.
- Support contact and Author: can be company-level or personal.
- New Power-Up or Integration name:
- Once the Power-Up is created, click API key in the sidebar, then Generate a new API key, then Generate API key in the confirmation modal. Trello displays both an API key and a Secret — save them somewhere safe.
- In a browser, visit:
Replacehttps://trello.com/1/authorize?expiration=never&scope=read,write,account&response_type=token&name={NAME}&key={APIKEY}{NAME}with the Power-Up name you chose and{APIKEY}with the key from the previous step. This is an auth prompt — confirm access and click Allow. Trello returns an API token; copy it. - Put the API key and token into your MCP client config (e.g.
.claude.json) — see the next section.
2. Install
The easiest path is npx — no clone, no build, just run:
npx atlassian-trello-mcp
Or install from source:
git clone https://github.com/agrath/Trello-Desktop-MCP.git
cd Trello-Desktop-MCP
npm install
npm run build
3. Configure your MCP client
Claude Desktop
Edit your config file:
- macOS:
~/Library/Application Support/Claude/claude_desktop_config.json - Windows:
%APPDATA%\Claude\claude_desktop_config.json - Linux:
~/.config/Claude/claude_desktop_config.json
{
"mcpServers": {
"trello": {
"command": "npx",
"args": ["-y", "atlassian-trello-mcp"],
"env": {
"TRELLO_API_KEY": "your-api-key",
"TRELLO_TOKEN": "your-token"
}
}
}
}
Claude Code
claude mcp add trello -- npx -y atlassian-trello-mcp
Set environment variables TRELLO_API_KEY and TRELLO_TOKEN, or pass credentials per-request.
Gemini CLI
Edit ~/.gemini/settings.json:
{
"mcpServers": {
"trello": {
"command": "npx",
"args": ["-y", "atlassian-trello-mcp"],
"env": {
"TRELLO_API_KEY": "your-api-key",
"TRELLO_TOKEN": "your-token"
}
}
}
}
Generic MCP client / source install
The server uses stdio transport. Run with environment variables set:
TRELLO_API_KEY=your-key TRELLO_TOKEN=your-token npx atlassian-trello-mcp
# or, from a source clone:
TRELLO_API_KEY=your-key TRELLO_TOKEN=your-token node dist/index.js
Credentials
Credentials can be provided two ways:
- Environment variables (recommended): Set
TRELLO_API_KEYandTRELLO_TOKEN - Per-request: Pass
apiKeyandtokenas tool parameters (overrides env vars)
Available Tools (46)
Boards & Lists
| Tool | Description |
|---|---|
list_boards | List all accessible boards |
trello_get_user_boards | Get boards with user profile info |
get_board_details | Board metadata, lists, and optionally cards |
get_lists | Get all lists on a board |
trello_filter_lists | Filter lists by name (case-insensitive substring match) |
trello_create_list | Create a new list on a board |
trello_get_board_members | Get all members on a board |
trello_get_board_labels | Get all labels on a board |
trello_get_board_cards | Get all cards on a board (compact or full) |
trello_get_board_custom_fields | Get custom field definitions |
Cards
| Tool | Description |
|---|---|
create_card | Create a card with name, description, due date, labels, members |
get_card | Get card details |
update_card | Update card properties |
move_card | Move a card to a different list |
trello_archive_card | Archive or unarchive a card |
trello_get_list_cards | Get cards in a list (compact or full mode) |
Comments & Activity
| Tool | Description |
|---|---|
trello_add_comment | Add a comment to a card |
trello_get_card_actions | Get card activity history and comments |
Labels
| Tool | Description |
|---|---|
trello_create_label | Create a label on a board |
trello_update_label | Update label name or color |
trello_delete_label | Delete a label |
trello_add_label_to_card | Assign a label to a card |
trello_remove_label_from_card | Remove a label from a card |
Members on Cards
| Tool | Description |
|---|---|
trello_get_member | Get member profile details |
trello_add_member_to_card | Assign a member to a card |
trello_remove_member_from_card | Remove a member from a card |
Attachments
| Tool | Description |
|---|---|
trello_get_card_attachments | List all attachments on a card |
trello_get_card_attachment | Get a specific attachment |
trello_create_card_attachment | Attach a URL or upload a local file |
trello_delete_card_attachment | Delete an attachment |
Checklists
| Tool | Description |
|---|---|
trello_create_checklist | Create a checklist on a card |
trello_get_checklist | Get a checklist with items |
trello_update_checklist | Update checklist name or position |
trello_delete_checklist | Delete a checklist |
trello_get_checklist_field | Get a specific checklist field |
trello_update_checklist_field | Update a specific checklist field |
trello_get_board_for_checklist | Get the board a checklist belongs to |
trello_get_card_for_checklist | Get the card a checklist belongs to |
trello_get_card_checklists | Get all checklists on a card |
Check Items
| Tool | Description |
|---|---|
trello_create_check_item | Add an item to a checklist |
trello_get_check_items | Get all items on a checklist |
trello_get_check_item | Get a specific check item |
trello_update_check_item | Update item (name, state, due date, assignee) |
trello_delete_check_item | Delete a check item |
Search
| Tool | Description |
|---|---|
trello_search | Search across boards, cards, members, organizations |
Configuration
Read-only mode
Set TRELLO_READ_ONLY=true to disable all write operations. Only read/query tools will be available.
{
"env": {
"TRELLO_API_KEY": "your-key",
"TRELLO_TOKEN": "your-token",
"TRELLO_READ_ONLY": "true"
}
}
Compact mode
Several tools support a compact parameter (default: true) that returns minimal fields to reduce response size. Set compact: false for full details including descriptions, labels, members, and custom fields.
Tools with compact mode: get_board_details, trello_get_board_cards, trello_get_list_cards, trello_search.
Image attachment download
When get_card is called and the card has image attachments, the server downloads them and returns them as inline MCP image content blocks alongside the JSON — letting the client see card images directly. Downloads are restricted to Trello-hosted URLs (*.trello.com, trello-attachments.s3.amazonaws.com) and capped at 5 MB per image to mitigate SSRF and payload-bloat risks.
Set TRELLO_DOWNLOAD_IMAGES=false (or 0/no/off) to disable entirely — the server will skip the extra getCardAttachments call and return text only. Default is enabled.
Logging
Set TRELLO_MCP_LOGGING=true to enable file-based logging via Pino. Logs are written to dist/logs/app.log.
Development
Project structure
src/
index.ts Entry point (credential injection, tool routing)
server.ts MCP server factory (read-only mode support)
tools/
boards.ts Board tools (list, details, lists, filter)
cards.ts Card tools (CRUD, archive)
lists.ts List tools (cards, create list, comments)
members.ts Member tools (user boards, member details)
search.ts Search tool
advanced.ts Labels, attachments, members on cards, custom fields
checklists.ts Checklist and check item tools (13 tools)
trello/
client.ts TrelloClient (API calls, retry, rate limiting)
types/
trello.ts TypeScript interfaces
utils/
validation.ts Zod schemas, extractCredentials, extractTrelloId
logger.ts Pino file logger
health.ts Health check utility
appInsights.ts Telemetry (no-op)
tests/
validation.test.ts Validation and credential extraction tests
trelloClient.test.ts API client tests (mocked fetch)
tools.test.ts Tool handler tests (mocked client)
Build & test
npm install
npm run build
npm test
npm run type-check
Key patterns
- ID resolution: All tools accept Trello URLs, short IDs, or full 24-char hex IDs via
extractTrelloId() - Credential fallback:
extractCredentials()checks args first, then env vars - Retry with backoff: TrelloClient retries on 500/network errors (3 attempts, exponential backoff)
- Rate limiting: Extracts and returns
x-rate-limit-*headers from every response - Validation: Zod schemas validate all inputs before API calls
Contributing
Pull requests are welcome and actively reviewed. This fork is maintained by an extensive Trello user, so features get real-world testing.
If you've forked the original project and built something useful, please submit a PR here rather than maintaining a separate fork -- it's easier for everyone to benefit from a single well-maintained project.
To contribute:
- Fork this repo
- Create a feature branch
- Add tests for new functionality
- Run
npm testandnpm run build - Submit a pull request with a clear description of what and why
Credits
This project is a fork of kocakli/Trello-Desktop-MCP. Features and ideas were incorporated from across the fork ecosystem:
- kocakli -- Original project, MCP client-agnostic rebranding, stderr logging fix
- kevinhillinger -- Credential injection architecture, label deletion, card member management, card archiving, expanded TypeScript types, resources layer
- zonca -- Centralized credential handling with env var fallback, label management tools, comprehensive unit tests, improved TypeScript types replacing
any - dbz-max -- Custom fields support (board custom fields + card custom field items)
- maks244 -- Read-only mode concept, list filtering by name, credential stripping from telemetry logs
- jantman -- Fix for numeric
posvalues rejected when sent as strings by MCP clients - ThatIanMcShane -- Bumped
@modelcontextprotocol/sdk1.0.4 → 1.29.0 to fix connection timeouts with current Claude Code releases - josh-argyle -- Auto-download image attachments in
get_cardresponses as inline MCP image content blocks (with allowlist + size cap added during port)
License
MIT
相關伺服器
Kone.vc
贊助Monetize your AI agent with contextual product recommendations
healthcare-billing-codes
Standard MCP Server for looking up CPT, ICD-10, and denial codes.
Outline MCP Server
MCP server for the Outline knowledge base and document management tool.
Obsidian MCP Server
Manage notes and files in an Obsidian vault. Requires the Obsidian Local REST API plugin.
Mimic AI
Transforms HTML into Figma using only your design system, enforcing correct component usage and falling back safely when needed, while improving accuracy with every build.
CalmBoard.ai
MCP - Multi-purpose endpoint for AI agents to access CalmBoard's features and data. This MCP provides a comprehensive interface for AI agents to interact with CalmBoard's project/scrum/kanban board management functionalities and retrieve relevant data to provide insights and recommendations to users.
Lindo AI
MCP (Model Context Protocol) server for Lindo AI — create websites, pages, and blog posts with AI directly from Claude, Cursor, Kiro, Windsurf, and other MCP-compatible tools.
Claudesidian MCP
Integrates Model Context Protocol (MCP) with Obsidian, allowing AI assistants to interact with your notes and vault.
Paperless-MCP
An MCP server for interacting with a Paperless-NGX API server. This server provides tools for managing documents, tags, correspondents, and document types in your Paperless-NGX instance.
Eventbrite
Manage events, reporting, and analytics on Eventbrite.
Excel MCP Server
Interact with Microsoft Excel to read data, edit cells, execute VBA code, and manage worksheets.