Zendesk MCP server for Claude Code and other MCP clients
Project description
zendesk-mcp
A Model Context Protocol server that exposes Zendesk ticket read and write tools to Claude Code and other MCP clients.
What it does
- Search, list (paginated), and fetch Zendesk tickets, comments, and attachments
- Create new tickets and update existing ticket fields (including group, custom status, and tags)
- Post public replies and internal notes
- Set ticket status and assign tickets to agents
- Browse and apply views and macros
- Look up users, groups, organizations, and custom statuses
- Read and write time-tracking entries
- Format a ticket as a Markdown issue draft for handoff to a tracker (GitLab, GitHub, Jira)
- Two MCP prompts (
analyze-ticket,draft-ticket-response) for ticket analysis and response drafting - (Optional) Expose Zendesk Help Center articles as an MCP resource
- (Optional) Read linked GitLab issues / MRs / commits via the Git-Zen Zendesk app
Prerequisites
- Python 3.10 or newer
- A Zendesk OAuth client. A Zendesk admin can create one at:
https://<your-subdomain>.zendesk.com/admin/apps-integrations/apis/zendesk-api/oauth_clientsSet the redirect URL tohttp://localhost:8787/callbackand request scopesread write.
Install
Install into a project-local virtualenv. Using a venv keeps zendesk-mcp and its dependencies isolated from your system Python and from other projects, and is the recommended path for everything below.
From a clone of this repository:
python3 -m venv .venv
.venv/bin/pip install --upgrade pip
.venv/bin/pip install -e .
For development (also installs pytest):
.venv/bin/pip install -e ".[dev]"
Throughout this README, commands use the venv's binaries via
.venv/bin/.... You can insteadsource .venv/bin/activateonce per shell and drop the prefix — the result is the same.
OAuth setup
Run the interactive setup using the venv's Python:
.venv/bin/python -m zendesk_mcp setup
You will be prompted for:
- Your Zendesk subdomain (e.g.
acmeforacme.zendesk.com) - The OAuth client ID created by your admin
- The OAuth client secret
- (Optional) A Git-Zen integration field ID — see Optional: Git-Zen integration
- (Optional) Whether to enable the Help Center knowledge base resource — see Optional: Help Center knowledge base
The setup opens a browser for the OAuth authorization step, then writes a token to ~/.config/zendesk-mcp/config.json (mode 0600).
If you have no browser, the URL is printed to the terminal — open it on any device, click Allow, and paste the resulting redirect URL back into the prompt.
Register with Claude Code
Register the MCP server using the venv's Python by absolute path. Claude Code launches the server in a fresh shell that does not inherit your activated venv, so the absolute path is required — pointing at a bare python here will fail to import zendesk_mcp.
ZENDESK_MCP_DIR="$(pwd)" # run this from the repo root, after install
claude mcp add --scope user zendesk -- "$ZENDESK_MCP_DIR/.venv/bin/python" -m zendesk_mcp
Or just inline the absolute path you want:
claude mcp add --scope user zendesk -- /absolute/path/to/zendesk-mcp/.venv/bin/python -m zendesk_mcp
Then add the read tools to permissions.allow in ~/.claude/settings.json to avoid per-call prompts:
{
"permissions": {
"allow": [
"mcp__zendesk__zendesk_get_ticket",
"mcp__zendesk__zendesk_get_tickets",
"mcp__zendesk__zendesk_get_comments",
"mcp__zendesk__zendesk_list_attachments",
"mcp__zendesk__zendesk_download_attachment",
"mcp__zendesk__zendesk_search_tickets",
"mcp__zendesk__zendesk_ticket_to_gitlab_context",
"mcp__zendesk__zendesk_list_views",
"mcp__zendesk__zendesk_get_view",
"mcp__zendesk__zendesk_get_view_tickets",
"mcp__zendesk__zendesk_list_macros",
"mcp__zendesk__zendesk_preview_macro",
"mcp__zendesk__zendesk_search_users",
"mcp__zendesk__zendesk_get_groups",
"mcp__zendesk__zendesk_get_group_users",
"mcp__zendesk__zendesk_get_organization",
"mcp__zendesk__zendesk_list_custom_statuses"
]
}
}
Write tools (zendesk_post_comment, zendesk_post_internal_note, zendesk_set_ticket_status, zendesk_assign_ticket, zendesk_create_ticket, zendesk_update_ticket, zendesk_log_time, zendesk_add_tag, zendesk_remove_tag, zendesk_apply_macro) are intentionally not in the default allow-list — Claude will prompt you per call.
Tools
Tickets
| Tool | What it does |
|---|---|
zendesk_search_tickets |
Search tickets by status, priority, type, assignee, requester, tags, or keyword |
zendesk_get_tickets |
List tickets with pagination and sorting (page, per_page, sort_by, sort_order) |
zendesk_get_ticket |
Get one ticket's metadata |
zendesk_create_ticket |
Create a new ticket (subject, description, optional priority/type/assignee_id/requester_id/tags/custom_fields) |
zendesk_update_ticket |
Update one or more fields on an existing ticket (status, priority, subject, type, assignee_id, requester_id, group_id, custom_status_id, tags, custom_fields, due_at) |
zendesk_get_comments |
Get the conversation thread on a ticket |
zendesk_list_attachments |
List attachments on a ticket |
zendesk_download_attachment |
Download an attachment to a local cache directory |
zendesk_ticket_to_gitlab_context |
Format a ticket and its conversation as a Markdown issue draft |
zendesk_post_comment |
Post a public reply on a ticket |
zendesk_post_internal_note |
Post an agent-only internal note on a ticket |
zendesk_set_ticket_status |
Set ticket status (new, open, pending, hold, solved, closed) |
zendesk_assign_ticket |
Assign a ticket to an agent by email or me |
Tags
| Tool | What it does |
|---|---|
zendesk_add_tag |
Add a tag to a ticket (idempotent) |
zendesk_remove_tag |
Remove a tag from a ticket (idempotent) |
Views & Macros
| Tool | What it does |
|---|---|
zendesk_list_views |
List all active views |
zendesk_get_view |
Get a view's filter conditions and execution settings |
zendesk_get_view_tickets |
Fetch tickets currently matching a view |
zendesk_list_macros |
List active macros with their actions |
zendesk_preview_macro |
Preview what changes a macro would make |
zendesk_apply_macro |
Apply a macro to a ticket (applies field changes and posts any comment) |
Users, Groups & Organizations
| Tool | What it does |
|---|---|
zendesk_search_users |
Find users by name or email |
zendesk_get_groups |
List all active groups |
zendesk_get_group_users |
List the members of a group |
zendesk_get_organization |
Fetch an organization including custom fields |
zendesk_list_custom_statuses |
List all custom ticket statuses and their IDs |
Time tracking
| Tool | What it does |
|---|---|
zendesk_get_time_tracking |
Read time-tracking entries for a ticket |
zendesk_log_time |
Log a time entry against a ticket |
Git-Zen integration
| Tool | What it does |
|---|---|
zendesk_get_git_zen_links |
(Git-Zen only) Get linked GitLab issues / MRs / commits for a ticket |
Prompts
The server exposes two MCP prompts that some clients (e.g. Claude Desktop) surface as slash commands:
| Prompt | Argument | What it does |
|---|---|---|
analyze-ticket |
ticket_id |
Asks the model to fetch the ticket and produce a summary, status/timeline, and key interaction points |
draft-ticket-response |
ticket_id |
Asks the model to fetch the ticket and draft a customer-facing response (with a confirmation step before posting) |
Optional: Git-Zen integration
If your Zendesk instance uses the Git-Zen app, the zendesk_get_git_zen_links tool can read its custom-field payload. Find your instance's Git-Zen custom field ID under Admin → Tickets → Fields (it is a numeric ID), then either set it during .venv/bin/python -m zendesk_mcp setup or edit ~/.config/zendesk-mcp/config.json to add:
{
"git_zen_field_id": 12345678901234
}
Without this configured, zendesk_get_git_zen_links returns a "not configured" message.
Optional: Help Center knowledge base
If your Zendesk instance has a published Help Center, you can expose its sections and articles as the zendesk://knowledge-base MCP resource. The resource returns a single JSON document covering all sections and articles, cached for one hour.
This is opt-in. Enable it by either answering "y" to the prompt during .venv/bin/python -m zendesk_mcp setup, or by adding the following to ~/.config/zendesk-mcp/config.json:
{
"knowledge_base_enabled": true
}
When the flag is absent or false, the resource is not registered, keeping the server's resource list empty for instances without a Help Center.
Development
python3 -m venv .venv
.venv/bin/pip install -e ".[dev]"
.venv/bin/pytest
Tests run on Python 3.10, 3.11, and 3.12 in CI (see .github/workflows/test.yml).
License
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file zendesk_mcp-0.1.0.tar.gz.
File metadata
- Download URL: zendesk_mcp-0.1.0.tar.gz
- Upload date:
- Size: 34.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
832786eb2b0d019b022157b0d845e51257038b424d6ffc8e807ea0f82fd351b5
|
|
| MD5 |
62625b717ab3c8cd7e398fc3edf9e45b
|
|
| BLAKE2b-256 |
b5a52f17164b6336cbac95f53b726de579a6b1feb4d3d8d610c4adcfd6b1496a
|
Provenance
The following attestation bundles were made for zendesk_mcp-0.1.0.tar.gz:
Publisher:
release.yml on michaelrice/zendesk-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
zendesk_mcp-0.1.0.tar.gz -
Subject digest:
832786eb2b0d019b022157b0d845e51257038b424d6ffc8e807ea0f82fd351b5 - Sigstore transparency entry: 1462216986
- Sigstore integration time:
-
Permalink:
michaelrice/zendesk-mcp@3cf9507cdc53f19bcdc029019fe5c59da8392ce3 -
Branch / Tag:
refs/tags/v0.1.0 - Owner: https://github.com/michaelrice
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@3cf9507cdc53f19bcdc029019fe5c59da8392ce3 -
Trigger Event:
push
-
Statement type:
File details
Details for the file zendesk_mcp-0.1.0-py3-none-any.whl.
File metadata
- Download URL: zendesk_mcp-0.1.0-py3-none-any.whl
- Upload date:
- Size: 34.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5239f95c221c82505e1b70bccd994396bfeee89530104d4220fe66c931d11b0f
|
|
| MD5 |
7344211f070ec80460a2dc3e5ef23ef5
|
|
| BLAKE2b-256 |
bdc17f5fdb19b1889a3424e10f8386d3cc2268199468fbd2904e721eb9cc9cf9
|
Provenance
The following attestation bundles were made for zendesk_mcp-0.1.0-py3-none-any.whl:
Publisher:
release.yml on michaelrice/zendesk-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
zendesk_mcp-0.1.0-py3-none-any.whl -
Subject digest:
5239f95c221c82505e1b70bccd994396bfeee89530104d4220fe66c931d11b0f - Sigstore transparency entry: 1462217016
- Sigstore integration time:
-
Permalink:
michaelrice/zendesk-mcp@3cf9507cdc53f19bcdc029019fe5c59da8392ce3 -
Branch / Tag:
refs/tags/v0.1.0 - Owner: https://github.com/michaelrice
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@3cf9507cdc53f19bcdc029019fe5c59da8392ce3 -
Trigger Event:
push
-
Statement type: