mcp-server-redmine
Enables AI assistants to create, update, and query Redmine issues and projects directly from conversations.
README
MCP Server for Redmine
Model Context Protocol (MCP) server for Redmine project management integration. Allows AI assistants to create, update, and query Redmine issues directly from conversations.
Features
- ✅ Create issues with full metadata (priority, estimates, parent tasks)
- ✅ Update existing issues (status, description, comments)
- ✅ List and filter issues by project and status
- ✅ Get detailed issue information
- ✅ List all accessible projects
Installation
cd mcp-server-redmine
npm install
npm run build
Configuration
Set environment variables for your Redmine instance:
export REDMINE_URL="https://your-redmine.com"
export REDMINE_API_KEY="your-api-key-here"
Getting Your Redmine API Key
IMPORTANT: You need the REST API key, not the Atom feed key!
If REST API is Enabled:
- Log into Redmine
- Go to "My account" (top right)
- Look for "API access key" section (right sidebar)
- Click "Show" to reveal the key
- Copy the 40-character key
If You Only See "Atom Access Key":
The Atom key is for RSS feeds only. You need REST API enabled:
-
Admin must enable it:
- Administration → Settings → API
- Check "Enable REST web service"
- Save
-
Then get your key:
- Refresh "My account" page
- "API access key" section should now appear
- Click "Show" and copy
-
Alternative: Try using Atom key
- Some Redmine versions accept it
- Test with
npm test - If 401 error, you need proper API key
Usage with Amazon Q
Add to your Amazon Q configuration file (~/.aws/amazonq/mcp.json or IDE settings):
{
"mcpServers": {
"redmine": {
"command": "node",
"args": ["/absolute/path/to/mcp-server-redmine/build/index.js"],
"env": {
"REDMINE_URL": "https://your-redmine.com",
"REDMINE_API_KEY": "your-api-key-here"
}
}
}
}
Available Tools
create_issue
Create a new Redmine issue/task.
Parameters:
project_id(required): Project ID numbertracker_id: Tracker type (1=Bug, 2=Feature, 3=Support) - defaults to 2 (Feature)subject(required): Issue titledescription: Issue description (markdown supported)priority_id: Priority level (1=Low, 2=Normal, 3=High, 4=Urgent, 5=Immediate)estimated_hours: Time estimate in hoursparent_issue_id: Parent issue ID for creating subtasks
Example:
Create a Redmine issue in project 1 titled "Implement ServingsService"
with description "Add quantity scaling logic" and estimate 8 hours
update_issue
Update an existing issue.
Parameters:
issue_id(required): Issue ID to updatetracker_id: Change tracker type (1=Bug, 2=Feature, 3=Support)subject: New titledescription: New descriptionstatus_id: Status (1=New, 2=In Progress, 3=Resolved, 5=Closed)priority_id: Priority levelnotes: Add a comment
Example:
Update Redmine issue #123 status to 3 (Resolved) and add note "Implementation complete"
list_issues
List issues from a project.
Parameters:
project_id(required): Project IDstatus_id: Filter by status ("open", "closed", or specific ID)limit: Max results (default 25)
Example:
List all open issues in Redmine project 1
get_issue
Get detailed information about a specific issue.
Parameters:
issue_id(required): Issue ID
Example:
Get details of Redmine issue #123
list_projects
List all accessible Redmine projects.
Example:
List all my Redmine projects
Example Workflows
1. Convert Documentation to Tasks
You: "Read PRODUCT_ROADMAP.md and create Redmine issues for all Phase 1 tasks in project 1"
AI:
- Reads PRODUCT_ROADMAP.md
- Extracts Phase 1 tasks
- Creates issues with:
- Subject from task name
- Description from details
- Priority based on roadmap priority
- Estimated hours from effort estimates
2. Update Task Status
You: "Mark Redmine issue #45 as resolved since ServingsService is complete"
AI: Updates issue #45 with status_id=3 and adds completion note
3. Create Subtasks
You: "Create subtasks for Redmine issue #50 to implement Categories feature:
- Database migration
- Service layer
- Controller updates
- UI components"
AI: Creates 4 subtasks with parent_issue_id=50
4. Sprint Planning
You: "List all open issues in project 1 and create a sprint plan"
AI:
- Lists issues
- Analyzes priorities and estimates
- Suggests grouping and ordering
Common Redmine Status IDs
- 1 = New
- 2 = In Progress
- 3 = Resolved
- 4 = Feedback
- 5 = Closed
- 6 = Rejected
(Your Redmine instance may have different IDs - check your Redmine settings)
Common Redmine Priority IDs
- 1 = Low
- 2 = Normal
- 3 = High
- 4 = Urgent
- 5 = Immediate
Troubleshooting
"I only see Atom Access Key, not API Access Key"
See TROUBLESHOOTING_API_KEY.md for complete solutions.
Quick fix: Ask your admin to enable REST API:
- Administration → Settings → API → "Enable REST web service"
"REDMINE_URL and REDMINE_API_KEY environment variables are required"
Make sure environment variables are set in your MCP configuration.
"401 Unauthorized"
Check that your API key is correct and has not expired.
"403 Forbidden"
Your API key doesn't have permission for the requested operation.
"404 Not Found"
Project or issue ID doesn't exist or you don't have access.
Development
# Watch mode for development
npm run watch
# Build for production
npm run build
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.