RT MCP Server
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@RT MCP ServerFind tickets related to network issues"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
RT MCP Server
A TypeScript MCP server that provides read-only access to RT (Request Tracker) via the REST2 API. This Model Context Protocol (MCP) server allows Large Language Models to search for tickets, query ticket information, retrieve correspondence, download attachments, and explore ticket hierarchies.
Features
Read-only access to RT tickets, correspondence, and attachments
Token-based authentication via RT REST2 API
Command-line & environment variable configuration
Five main tools:
search_tickets- Search for tickets using simple query syntaxget_ticket- Retrieve complete ticket informationget_ticket_correspondence- Get ticket correspondence grouped by transaction with inline text and file metadataget_attachment- Download any attachment by ID with base64-encoded contentget_ticket_hierarchy- Build ticket parent/child relationship trees
STDIO transport for seamless integration with MCP clients
TypeScript for type safety and better developer experience
Easy deployment with npm/npx
Installation
Requirements
Node.js ≥ v18.0.0
RT authentication token (create via Settings > Auth Tokens in RT web interface)
MCP Clients
Using Command Line (Recommended)
macOS/Linux:
claude mcp add rt -- npx -y rt-mcp-server --api-token YOUR_RT_TOKEN --url https://rt.example.com/REST/2.0Windows:
claude mcp add rt -- cmd /c npx -y rt-mcp-server --api-token YOUR_RT_TOKEN --url https://rt.example.com/REST/2.0Manual Configuration
Edit your Claude Code MCP configuration file and add:
{
"mcpServers": {
"rt": {
"command": "npx",
"args": [
"-y",
"rt-mcp-server",
"--api-token",
"YOUR_RT_TOKEN",
"--url",
"https://rt.example.com/REST/2.0"
]
}
}
}Option 1: UI Method
Open Claude Desktop
Navigate to Settings → Developer → Edit Config
Add the RT MCP server configuration
Option 2: Configuration File
Edit claude_desktop_config.json (location varies by OS):
macOS:
~/Library/Application Support/Claude/claude_desktop_config.jsonWindows:
%APPDATA%\Claude\claude_desktop_config.jsonLinux:
~/.config/Claude/claude_desktop_config.json
macOS/Linux configuration:
{
"mcpServers": {
"rt": {
"command": "npx",
"args": [
"-y",
"rt-mcp-server",
"--api-token",
"YOUR_RT_TOKEN",
"--url",
"https://rt.example.com/REST/2.0"
]
}
}
}Windows configuration:
{
"mcpServers": {
"rt": {
"command": "cmd",
"args": [
"/c",
"npx",
"-y",
"rt-mcp-server",
"--api-token",
"YOUR_RT_TOKEN",
"--url",
"https://rt.example.com/REST/2.0"
]
}
}
}Restart Claude Desktop after saving.
Using Command Line (Recommended)
gemini mcp add rt npx -y rt-mcp-server --api-token YOUR_RT_TOKEN --url https://rt.example.com/REST/2.0Manual Configuration
Edit the Gemini settings file at ~/.gemini/settings.json and add the RT MCP server to the mcpServers object:
{
"mcpServers": {
"rt": {
"command": "npx",
"args": [
"-y",
"rt-mcp-server",
"--api-token",
"YOUR_RT_TOKEN",
"--url",
"https://rt.example.com/REST/2.0"
]
}
}
}Using Command Line (Recommended)
codex mcp add rt npx -y rt-mcp-server --api-token YOUR_RT_TOKEN --url https://rt.example.com/REST/2.0Manual Configuration
Add the RT MCP server to your OpenAI Codex configuration using TOML format:
[mcp_servers.rt]
command = "npx"
args = [
"-y",
"rt-mcp-server",
"--api-token",
"YOUR_RT_TOKEN",
"--url",
"https://rt.example.com/REST/2.0"
]Use the MCP toolkit to integrate RT:
from langchain_mcp import MCPToolkit
rt_toolkit = MCPToolkit(
server_params={
"command": "npx",
"args": [
"-y",
"rt-mcp-server",
"--api-token",
"YOUR_RT_TOKEN",
"--url",
"https://rt.example.com/REST/2.0"
]
}
)
tools = rt_toolkit.get_tools()Local Development Installation
If you want to develop or modify the server:
# Clone the repository
git clone <repository-url>
cd rt-mcp
# Install dependencies
npm install
# Build the project
npm run build
# Test it
node dist/index.js --api-token "YOUR_RT_TOKEN" --url "https://rt.example.com/REST/2.0"Configuration
The server supports configuration via command-line arguments or environment variables.
Command-Line Arguments (Recommended)
--api-token- Your RT authentication token--url- RT server base URL (required)
Environment Variables (Alternative)
RT_TOKEN- Your RT authentication tokenRT_BASE_URL- RT server base URL
Priority: Command-line arguments override environment variables.
Usage with MCP Clients
After installing the RT MCP server in your preferred MCP client (see Installation section above), you can interact with RT tickets using natural language.
Usage Examples
Example 1: Searching for Tickets
Ask your MCP-enabled LLM:
"Find all tickets about database errors"
The LLM will use search_tickets(query="database errors") to find matching tickets and display a summary of results.
Example 2: Checking Ticket Status
Ask your MCP-enabled LLM:
"What is the status of RT ticket 12345?"
The LLM will use get_ticket(12345) to fetch the ticket details and report the status, owner, priority, and other relevant information.
Example 3: Reading Ticket Correspondence
Ask your MCP-enabled LLM:
"Show me all the comments and correspondence from RT ticket 67890"
The LLM will use get_ticket_correspondence(67890) to retrieve all correspondence grouped by transaction, including inline text messages and file attachment metadata.
Example 4: Downloading Attachments
Ask your MCP-enabled LLM:
"Download the PDF receipt from RT ticket 67890"
The LLM will use get_ticket_correspondence(67890) to find attachment IDs, then get_attachment(attachment_id) to download the specific file with base64-encoded content.
Example 5: Exploring Ticket Hierarchies
Ask your MCP-enabled LLM:
"Show me the parent and child tickets for RT ticket 54321"
The LLM will use get_ticket_hierarchy(54321, recursive=True) to build the complete relationship tree showing all related tickets.
Available Tools
search_tickets(query: string, limit?: number)
Searches for tickets using simple query syntax that matches across ticket subject, content, and other fields.
Parameters:
query- Simple search query text (e.g., "bug in login", "database error")limit- Maximum number of results to return (default 20, max 100)
Example:
{
"query": "database error",
"limit": 10
}Returns:
{
"total": 45,
"count": 10,
"limit": 10,
"tickets": [
{
"id": 12345,
"subject": "Database connection error on production",
"status": "open",
"queue": "Engineering",
"owner": "john.doe",
"created": "2024-01-15T10:30:00Z"
}
]
}get_ticket(ticket_id: number)
Retrieves complete ticket information including:
Basic info: ID, type, subject, status, queue
People: owner, creator, requestors, CC, AdminCC
Dates: created, started, resolved, last updated
Time tracking: worked, estimated, left
Example:
{
"ticket_id": 12345
}Returns:
{
"id": 12345,
"subject": "Example ticket",
"status": "open",
"queue": "General",
"owner": "username",
"creator": "requester@example.com",
"created": "2024-01-15T10:30:00Z"
}get_ticket_correspondence(ticket_id: number)
Retrieves all correspondence from a ticket, grouped by transaction. Each transaction may contain:
Inline text messages (user's typed message)
File attachments (with metadata only)
Example:
{
"ticket_id": 12345
}Returns:
{
"ticket_id": 12345,
"total_attachments": 5,
"correspondence": [
{
"transaction_id": "100",
"creator": "user@example.com",
"created": "2024-01-15T10:35:00Z",
"message": "This is the user's typed message...",
"attachments": [
{
"id": 67890,
"filename": "document.pdf",
"content_type": "application/pdf",
"size": "42.0 KB"
}
]
}
]
}get_attachment(attachment_id: number)
Downloads a specific attachment by ID, returning base64-encoded content for any file type.
Example:
{
"attachment_id": 67890
}Returns:
{
"attachment_id": 67890,
"filename": "document.pdf",
"content_type": "application/pdf",
"size": "42.0 KB",
"content_base64": "JVBERi0xLjQK...",
"created": "2024-01-15T10:35:00Z",
"creator": "user@example.com"
}get_ticket_hierarchy(ticket_id: number, recursive?: boolean)
Retrieves the parent/child relationship tree for a ticket.
Parameters:
ticket_id- The RT ticket IDrecursive- If true, fetches complete tree; if false, only immediate relationships (default: true)
Example:
{
"ticket_id": 12345,
"recursive": true
}Returns:
{
"ticket_id": 12345,
"recursive": true,
"tickets_fetched": 10,
"hierarchy": {
"id": 12345,
"subject": "Main ticket",
"status": "open",
"parents": {
"12340": {
"id": 12340,
"subject": "Parent ticket"
}
},
"children": {
"12350": {
"id": 12350,
"subject": "Child ticket"
}
}
}
}How It Works
Configuration: Parses command-line arguments (or reads environment variables) for RT URL and authentication token
Authentication: Uses token-based auth with RT REST2 API for all requests
HTTP Client: Uses native
fetchAPI for async HTTP requests to RT REST2 APIError Handling: Returns error information as objects rather than throwing exceptions
MCP Protocol: Implements MCP server using
@modelcontextprotocol/sdkwith STDIO transportType Safety: Full TypeScript type checking for reliability
API Endpoints Used
The server interacts with these RT REST2 endpoints:
GET /tickets?simple=1;query={query};per_page={limit}- Search tickets using simple query syntaxGET /ticket/{id}- Retrieve ticket informationGET /ticket/{id}/attachments- List all attachments for a ticketGET /attachment/{id}- Retrieve individual attachment content (base64-encoded)
Documentation
RT REST2 API Documentation - Official RT REST2 API reference
Model Context Protocol - MCP specification
Development
Building
# Install dependencies
npm install
# Build TypeScript to JavaScript
npm run build
# Watch mode (auto-rebuild on changes)
npm run devProject Structure
rt-mcp/
├── src/
│ └── index.ts # Main MCP server implementation
├── dist/ # Compiled JavaScript (generated)
├── package.json # Node.js dependencies and scripts
├── tsconfig.json # TypeScript configuration
├── .gitignore # Git ignore rules
├── README.md # This file
└── CLAUDE.md # Guide for Claude CodeRunning Tests
# Run the built server with test credentials
node dist/index.js --api-token "test-token" --url "https://rt.example.com/REST/2.0"Common Workflows
Reading Ticket Information
Simply ask Claude in natural language:
"What's the status of RT ticket 12345?"
"Who is assigned to ticket 67890?"
"When was ticket 11111 created and last updated?"
"Show me the custom fields for ticket 22222"
Analyzing Ticket Discussions
Ask Claude to summarize or analyze:
"Read all comments from RT ticket 33333 and summarize the issue"
"What are the main discussion points in ticket 44444?"
"Extract action items from the conversation in ticket 55555"
"Translate the technical discussion in ticket 66666 to non-technical language"
Batch Operations
Ask Claude to process multiple tickets:
"Compare the status of tickets 100, 101, and 102"
"Show me a table of ticket 200, 201, 202 with status, owner, and priority"
"Check if any of tickets 300-305 mention the word 'urgent' in their attachments"
Limitations
Read-only: No ticket creation, updates, or deletion capabilities
Simple search only: Uses RT's simple search syntax (not full TicketSQL query language)
No transaction history: Does not expose complete ticket history/transactions (only correspondence)
Single ticket at a time: Each tool call fetches one ticket (LLM can call multiple times for batch operations)
File size: Large attachments may take time to download depending on RT server performance
Search result limit: Maximum 100 tickets per search query (RT API limitation)
Troubleshooting
Module Not Found Error
If you see module errors during build:
# Make sure dependencies are installed
npm install
# Rebuild the project
npm run buildAuthentication Errors
If you see HTTP 401 or 403 errors:
Verify your RT token is correct
Check the token hasn't expired
Ensure your RT user has permissions to access tickets
Verify the RT server URL is correct
Connection Errors
If you see connection timeout or refused errors:
Check the RT server URL (should include
/REST/2.0)Verify the server is accessible from your network
Ensure HTTPS is being used
TypeScript Build Errors
If you encounter TypeScript compilation errors:
Check that you're using Node.js ≥18.0.0
Ensure all dependencies are installed:
npm installTry cleaning and rebuilding:
npm run clean && npm run build
Security Notes
Store
RT_TOKENsecurely (environment variables, secrets manager, etc.)Never commit tokens to version control (
.gitignoreexcludestoken.txtand.envfiles)The server will fail fast if
RT_TOKENis not providedAll communication with RT should use HTTPS
Command-line tokens may be visible in process lists - prefer environment variables in production
Contributing
When extending this server:
Follow TypeScript best practices
Use async/await pattern consistently
Return error objects instead of throwing exceptions
Update tool schemas for new functionality
Test with actual RT instance before committing
Run
npm run buildafter making changes
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/msekoranja/rt-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server