osTicket MCP Server
Enables AI-driven management of osTicket helpdesks through natural language, allowing users to reply to, assign, and transfer tickets without requiring API keys. It reverse-engineers the osTicket staff panel to provide full access to ticket operations using session-based authentication.
README
osTicket MCP Server
<div align="center">
Manage your osTicket helpdesk with AI — from Claude Code, Cursor, Windsurf, or any MCP client.
</div>
Talk to your helpdesk in natural language. Reply to tickets, add internal notes, assign agents, transfer departments, close tickets — all without leaving your editor.
> show me the open tickets
> reply to ticket 32 saying we're investigating the issue
> assign it to Sarah
> close all the automated notification tickets
Why?
osTicket doesn't have a public API. This MCP server reverse-engineers the staff panel to give AI tools full access to your helpdesk — using the same session-based auth as the web UI. No API keys, no plugins, no osTicket modifications needed.
Quick Start
1. Install
npm install -g mcp-osticket
Or clone and build from source:
git clone https://github.com/tecnologicachile/mcp-osticket.git
cd mcp-osticket
npm install && npm run build
2. Configure
Add to your MCP client config:
<details> <summary><strong>Claude Desktop</strong> — <code>claude_desktop_config.json</code></summary>
macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
Windows: %APPDATA%\Claude\claude_desktop_config.json
{
"mcpServers": {
"osticket": {
"command": "npx",
"args": ["-y", "mcp-osticket"],
"env": {
"OSTICKET_URL": "https://helpdesk.example.com",
"OSTICKET_EMAIL": "agent@example.com",
"OSTICKET_PASSWORD": "your-password"
}
}
}
}
</details>
<details> <summary><strong>Claude Code</strong> — <code>~/.claude/settings.json</code></summary>
{
"mcpServers": {
"osticket": {
"command": "mcp-osticket",
"env": {
"OSTICKET_URL": "https://helpdesk.example.com",
"OSTICKET_EMAIL": "agent@example.com",
"OSTICKET_PASSWORD": "your-password"
}
}
}
}
If installed from source, use "command": "node" with "args": ["/path/to/mcp-osticket/dist/mcp-server.js"].
</details>
<details> <summary><strong>Cursor</strong> — <code>.cursor/mcp.json</code></summary>
{
"mcpServers": {
"osticket": {
"command": "mcp-osticket",
"env": {
"OSTICKET_URL": "https://helpdesk.example.com",
"OSTICKET_EMAIL": "agent@example.com",
"OSTICKET_PASSWORD": "your-password"
}
}
}
}
</details>
<details> <summary><strong>Windsurf</strong> — <code>~/.codeium/windsurf/mcp_config.json</code></summary>
{
"mcpServers": {
"osticket": {
"command": "mcp-osticket",
"env": {
"OSTICKET_URL": "https://helpdesk.example.com",
"OSTICKET_EMAIL": "agent@example.com",
"OSTICKET_PASSWORD": "your-password"
}
}
}
}
</details>
3. Use
Restart your editor. The tools are available immediately — just ask in natural language.
Tools
| Tool | Description |
|---|---|
list_tickets |
List tickets by queue — open, my, or closed |
get_ticket |
Full ticket detail with conversation thread |
reply_ticket |
Reply to a ticket with email control (all, user, or none) |
add_note |
Add an internal note (not visible to the end user) |
change_ticket_status |
Change status to open, resolved, or closed |
assign_ticket |
Assign a ticket to a staff member |
transfer_ticket |
Transfer a ticket to another department |
list_agents |
List available staff for assignment |
list_departments |
List available departments for transfer |
search_users |
Search users by name or email |
get_queue_counts |
Get ticket counts per queue |
Reply Control
When replying, you control who gets the email:
reply_to |
Behavior |
|---|---|
all |
Email all active recipients (default) |
user |
Email only the ticket owner |
none |
No email — just post the reply in the thread |
Examples
Triage your inbox:
> list open tickets and summarize them by priority
Bulk operations:
> close all the automated notification tickets (ZohoMail, BaseAPI, etc.)
Reply without email:
> reply to ticket 15 with "Fixed in latest deploy" but don't send an email
Assign and transfer:
> assign ticket 8 to Sarah and transfer it to the Sales department
Search users:
> find all users with @example.com emails
Environment Variables
| Variable | Required | Description |
|---|---|---|
OSTICKET_URL |
Yes | Base URL of your osTicket instance (e.g. https://helpdesk.example.com) |
OSTICKET_EMAIL |
Yes | Staff agent email for login |
OSTICKET_PASSWORD |
Yes | Staff agent password |
How It Works
This server authenticates as a staff agent through osTicket's web panel and operates using the same internal endpoints the browser uses:
- Session auth — logs in via
/scp/login.php, maintains session cookie - CSRF handling — automatically extracts and refreshes CSRF tokens
- Ticket locking — acquires and releases locks for write operations (reply, note)
- AJAX endpoints — uses
/scp/ajax.php/*for assign, transfer, and status changes - HTML scraping — parses ticket data from the staff panel using Cheerio
No osTicket plugins, API keys, or server modifications required.
Compatibility
| osTicket Version | Status |
|---|---|
| v1.18.x | Tested |
| v1.17.x | Should work (not verified) |
| v1.15–1.16 | May work with minor differences |
The server adapts to dynamic form field names that osTicket generates per-session, so it should be resilient across minor versions.
Integration Tests
Run the test suite against a live osTicket instance:
OSTICKET_URL=http://localhost:8082 \
OSTICKET_EMAIL=agent@example.com \
OSTICKET_PASSWORD=secret \
npx tsx src/test-integration.ts
Contributing
PRs welcome. The main files:
src/mcp-server.ts— MCP tool definitionssrc/osticket-client.ts— osTicket HTTP client (session, scraping, AJAX)src/test-integration.ts— integration tests against a live instance
License
MIT
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.