A Model Context Protocol (MCP) server that provides AI agents with access to the Ticket Generator APIs for managing tickets and events.
This MCP server acts as a bridge between AI agents and the Ticket Generator APIs, allowing AI assistants to:
- Generate ticket IDs with QR code images (base64 PNG)
- Get hosted ticket URLs with optional variable field overrides
- Send tickets via email, SMS, or WhatsApp
- Retrieve event details for all active events on your account
- Node.js 18.0.0 or higher
- A Ticket Generator API key (obtain from https://apis.ticket-generator.com/client/api-docs/)
- (For local development) ngrok for exposing local server
-
Install dependencies:
npm install
-
Start the server (HTTP mode):
npm run dev:http
-
Expose locally with ngrok:
ngrok http 3000
-
Configure your MCP client with the ngrok URL and your API key:
{ "mcpServers": { "ticket-generator": { "url": "https://your-ngrok-url.ngrok-free.app/mcp", "headers": { "Authorization": "your_ticket_generator_api_key" } } } }
Important: In HTTP transport mode, the API key is passed securely via the Authorization header from your MCP client configuration. It is:
- Session-specific — each client session has its own API key stored in memory
- Transmitted securely over HTTPS (production) or ngrok tunnel (development)
In stdio transport mode, the API key is read from the TG_API_KEY environment variable.
This MCP server supports two transport modes: HTTP (for development and production deployments) and stdio (for local CLI usage). In HTTP mode the API key is securely passed from your MCP client configuration via the Authorization header. In stdio mode the key is read from the TG_API_KEY environment variable.
-
Start the MCP server in HTTP mode:
npm run dev:http
This will start the server on
http://localhost:3000 -
In a separate terminal, expose your local server using ngrok:
ngrok http 3000
-
Copy the ngrok forwarding URL (e.g.,
https://abc123.ngrok-free.app) -
Configure your MCP client (Claude Desktop, Cursor, etc.) with the ngrok URL and your API key:
{ "mcpServers": { "ticket-generator": { "url": "https://abc123.ngrok-free.app/mcp", "headers": { "Authorization": "your_ticket_generator_api_key" } } } }
For production deployment, follow these steps:
-
Deploy the server to your hosting platform (AWS, DigitalOcean, etc.)
-
Set the required environment variable:
export MCP_TRANSPORT=httpNote: The server listens on
0.0.0.0:3000(hardcoded inserver.js). -
Optional environment variables for production:
CORS_ORIGINS— comma-separated allowed origins (e.g.,https://yourapp.com)RATE_WINDOW_MS— rate-limit window in ms (default: 60000)RATE_MAX— max requests per IP per window (default: 60)JSON_LIMIT— JSON body limit (default: 200kb)LOG_FORMAT— morgan log format (default: combined)
-
Start the server:
npm start
-
Configure your MCP client with your production URL:
{ "mcpServers": { "ticket-generator": { "url": "https://your-production-domain.com/mcp", "headers": { "Authorization": "your_ticket_generator_api_key" } } } }
GET /health— Health check endpointPOST /mcp— MCP initialization and tool call handlingGET /mcp— Server-to-client notifications via streamingDELETE /mcp— Session termination
The MCP server provides the following tools for AI agents:
Generates a ticket ID and its QR Code image (base64 PNG) for a given event. Optionally pass a ticket category and image width.
Parameters:
eventId(required): The Ticket Generator Event ID for which the ticket should be createdwidth(required): QR image width/height in pixels (square). Allowed range: 300–1500. Default: 300ticketCategoryId(optional): Ticket Category ID. If the event has only one category, this can be omitted
Returns a URL to the rendered QR Code ticket for the specified event (and optional category). You can optionally override up to 5 variable fields on the ticket design.
Parameters:
eventId(required): Ticket Generator Event IDticketCategoryId(optional): Ticket Category ID. Omit if the event has a single categoryvariables(optional): Array of up to 5 variable field overrides, each with:value(required): Value for this variable (e.g.,"Mark","A2")header(optional): Header/label for this variable (e.g.,"Name","Seat"). Leave empty to use the default label defined in the design
Sends a generated ticket to a recipient via Email, SMS, or WhatsApp. You can include subject, body, and sender details, along with up to 5 custom variable fields.
Parameters:
eventId(required): Ticket Generator Event IDticketCategoryId(optional): Ticket Category ID. Omit if the event has a single categoryemail(optional): Email address of the recipient (ticket will be sent here)phoneNumber(optional): Recipient's phone number for SMS deliverywhatsApp(optional): Settrueto send ticket via WhatsApp (requiresphoneNumber)whatsAppConsent(optional): Whether the recipient has consented to receive WhatsApp messages (required ifwhatsAppistrue)subject(optional): Subject line of the email (ifemailis provided)body(optional): Message body (HTML or plain text) for the email/SMS/WhatsApp messagefromName(optional): The sender name shown to the recipientvariables(optional): Array of up to 5 variable fields to personalize the ticket, each with:value(required): Value corresponding to the header (e.g.,"A12","Mark")header(optional): Variable header label (e.g.,"Seat","Name"). Optional if default is set in design
Returns the details (name, description, start date, end date, location, ticket categories, etc.) of all active events associated with your account.
Parameters:
- None — this tool takes no parameters and returns all active events for your API key
Add this server to your Claude Desktop configuration file (claude_desktop_config.json):
{
"mcpServers": {
"ticket-generator": {
"url": "https://your-server-url.com/mcp",
"headers": {
"Authorization": "your_ticket_generator_api_key"
}
}
}
}For local development with ngrok:
{
"mcpServers": {
"ticket-generator": {
"url": "https://abc123.ngrok-free.app/mcp",
"headers": {
"Authorization": "your_ticket_generator_api_key"
}
}
}
}Add the server to your Cursor MCP configuration:
{
"mcpServers": {
"ticket-generator": {
"url": "https://your-server-url.com/mcp",
"headers": {
"Authorization": "your_ticket_generator_api_key"
}
}
}
}Any MCP-compatible client can connect to this server using HTTP transport. Configure it with:
- URL: Your server endpoint (e.g.,
https://your-domain.com/mcp) - Authorization Header: Your Ticket Generator API key
This MCP server integrates with the following Ticket Generator API endpoints (base URL: https://apis.ticket-generator.com/client/v1):
POST /ticket/data— Generate a ticket ID and QR code imagePOST /ticket/url— Get a hosted URL for a rendered ticketPOST /ticket/send— Send a ticket via email, SMS, or WhatsAppGET /event/details— Retrieve details for all active events
For detailed information about the Ticket Generator APIs, visit: https://apis.ticket-generator.com/client/api-docs/
The MCP server includes comprehensive error handling:
- Invalid API keys are caught and reported
- Network errors are handled gracefully
- Invalid parameters are validated and error messages are provided
- All errors are returned in a structured format for AI agents to understand
ticket-generator-mcp/
├── server.js # Main MCP server implementation
├── package.json # Node.js dependencies and scripts
├── ecosystem.config.cjs # PM2 configuration for production
├── Dockerfile # Docker container configuration
├── deploy.sh # ECR build/push + ECS deployment script
├── task-definition.json # AWS ECS Fargate task definition template
├── nginx.conf # Nginx reverse proxy configuration
├── DEPLOYMENT.md # AWS Fargate/ECS deployment guide
├── NGINX-SETUP.md # Nginx setup options
├── PM2-GUIDE.md # PM2 usage guide
└── README.md # This file
To add new tools to the MCP server:
- Add the tool definition to the
getToolDefinitions()function - Add the corresponding case in the
handleToolCall()function - Implement the API call using the
makeTGRequesthelper function
-
Install dependencies:
npm install
-
Start the server in development mode:
npm run dev:http
-
In a separate terminal, start ngrok:
ngrok http 3000
-
Use the ngrok URL to configure your MCP client with your API key in the Authorization header
ISC
For issues related to:
- This MCP server: Create an issue in this repository
- Ticket Generator APIs: Contact Ticket Generator support
- MCP protocol: Refer to the MCP documentation