Indian Railways MCP Server
Overview
The Indian Railways MCP Server provides live station status and train information using the Model Context Protocol (MCP). This server is designed to handle requests for live data from Indian Railways.
Features
- Fetch live station status
- Retrieve train information
- Get train details between stations
- Get train details on a specific date
- Retrieve train route information
- Check PNR status
Demo
https://github.com/user-attachments/assets/3f751174-cb0e-43b0-86a5-5493ab3da1e5
Installation
-
Clone the repository:
git clone https://github.com/yourusername/indian-railways-mcp.git cd indian-railways-mcp -
Install dependencies:
npm install
Usage
-
Build the project:
npm run build -
Start the server:
npm start -
Test the functions:
node --loader ts-node/esm src/testFunctions.ts
API
Get Station Live Status
- Endpoint:
tools/call - Method:
get-station-live-status - Parameters:
stationCode: The code of the station to get live status for.
Get Train Details Between Stations
- Endpoint:
tools/call - Method:
get-trains-between-stations - Parameters:
from: Source station code.to: Destination station code.
Get Train Details on a Specific Date
- Endpoint:
tools/call - Method:
get-trains-on-date - Parameters:
from: Source station code.to: Destination station code.date: Date inYYYY-MM-DDformat.
Retrieve Train Route Information
- Endpoint:
tools/call - Method:
get-train-route - Parameters:
trainNo: Train number.
Check PNR Status
- Endpoint:
tools/call - Method:
get-pnr-status - Parameters:
pnr: PNR number.
Sample Queries
Here are some example queries you can use with the API:
-
Get live railway station status for NDLS:
{ "method": "get-station-live-status", "params": { "stationCode": "NDLS" } } -
Get all details of train number 12059:
{ "method": "get-train-details", "params": { "trainNo": "12059" } } -
Fetch complete route of train number 12059:
{ "method": "get-train-route", "params": { "trainNo": "12059" } } -
Get all trains running between GODA and NDLS:
{ "method": "get-trains-between-stations", "params": { "from": "GODA", "to": "NDLS" } }
Development
- Build:
npm run build - Start:
npm start - Test:
npx ts-node src/testFunctions.ts
Using with Claude
To integrate this server with Claude, follow these steps:
-
Configure Claude Desktop: Add the following configuration to your Claude Desktop config file:
- Windows:
%APPDATA%\\Claude\\claude_desktop_config.json
{ "mcpServers": { "indian-railways-mcp": { "command": "node", "args": [ "F:\\\\railways-mcp\\\\indian-railways-mcp\\\\build\\\\index.js" ] } } } - Windows:
-
Restart Claude Desktop: After updating the configuration file, restart Claude Desktop to apply the changes.
This setup will allow Claude to connect to the Indian Railways MCP Server and handle requests seamlessly.
Contributing
Contributions are welcome! Please open an issue or submit a pull request for any changes.
License
This project is licensed under the MIT License.
Recommend MCP Servers 💡
MCP-searxng
MCP server for connecting agentic systems to search systems via searXNG
mcp-jira-server
Comprehensive MCP server for Jira integration with Claude Code
@gentoro/mcp-nodejs-server
MCP Server for Gentoro services enabling Claude to interact with Gentoro bridges and tools
jobspy-mcp-server
An MCP server enabling AI assistants to search jobs across platforms like Indeed and LinkedIn using JobSpy
mcp_plexus
A secure, multi-tenant MCP server framework for building AI backend systems with external service integration
@Badhansen/notion-mcp
A simple Model Context Protocol (MCP) server that integrates with Notion's API to manage my personal todo list.