A comprehensive Redmine integration that wraps nearly 100% of the Redmine REST API, letting Claude create issues, manage projects, upload attachments, and track time entries directly from your chat. Built with httpx and the full Redmine OpenAPI spec, it handles authentication via API keys and includes security controls for file operations through directory allowlists. The server supports both uv and Docker deployment, with configurable response formats and custom headers for proxy setups. Reach for this when you need Claude to act as your Redmine assistant for project management workflows, issue triage, or bulk operations across tickets and time tracking.
Status: Works great and is in daily use without any known bugs.
Status2: I just added the package to PyPI and updated the usage instructions. Please report any issues :)
Let Claude be your Redmine assistant! MCP Redmine connects Claude Desktop to your Redmine instance, allowing it to:
Uses httpx for API requests and integrates with the Redmine OpenAPI specification for comprehensive API coverage.

uvEnsure you have uv installed.
uv --version
Install uv if you haven't already.
Linux
curl -LsSf https://astral.sh/uv/install.sh | sh
macOS
brew install uv
windows
powershell -ExecutionPolicy ByPass -c "irm https://astral.sh/uv/install.ps1 | iex"
Add to your claude_desktop_config.json:
{
"mcpServers": {
"redmine": {
"command": "uvx",
"args": ["--from", "mcp-redmine==2026.01.13.152335",
"--refresh-package", "mcp-redmine", "mcp-redmine"],
"env": {
"REDMINE_URL": "https://your-redmine-instance.example.com",
"REDMINE_API_KEY": "your-api-key",
"REDMINE_REQUEST_INSTRUCTIONS": "/path/to/instructions.md",
"REDMINE_ALLOWED_DIRECTORIES": "/tmp,/home/user/uploads"
}
}
}
}
dockerEnsure you have docker installed.
docker --version
Build docker image:
git clone git@github.com:runekaagaard/mcp-redmine.git
cd mcp-redmine
docker build -t mcp-redmine .
Add to your claude_desktop_config.json:
{
"mcpServers": {
"redmine": {
"command": "docker",
"args": [
"run",
"-i",
"--rm",
"-e", "REDMINE_URL",
"-e", "REDMINE_API_KEY",
"-e", "REDMINE_REQUEST_INSTRUCTIONS",
"-e", "REDMINE_ALLOWED_DIRECTORIES",
"-v", "/path/to/instructions.md:/app/INSTRUCTIONS.md",
"-v", "/path/to/uploads:/app/uploads",
"mcp-redmine"
],
"env": {
"REDMINE_URL": "https://your-redmine-instance.example.com",
"REDMINE_API_KEY": "your-api-key",
"REDMINE_REQUEST_INSTRUCTIONS": "/app/INSTRUCTIONS.md",
"REDMINE_ALLOWED_DIRECTORIES": "/app/uploads"
}
}
}
}
| Variable | Required | Default | Description |
|---|---|---|---|
REDMINE_URL | Yes | - | URL of your Redmine instance. Subpaths are supported (e.g., http://localhost/redmine/) |
REDMINE_API_KEY | Yes | - | Your Redmine API key (see below for how to get it) |
REDMINE_REQUEST_INSTRUCTIONS | No | - | Path to a file containing additional instructions for the redmine_request tool. I've found it works great to have the LLM generate that file after a session. (example1 example2) |
REDMINE_HEADERS | No | (empty) | Custom HTTP headers to include in all requests. Format: "Header1: Value1, Header2: Value2". Useful for proxies that require additional authentication (e.g., X-Redmine-Username) |
REDMINE_RESPONSE_FORMAT | No | yaml | Response format: yaml or json. Controls how API responses are formatted |
REDMINE_ALLOWED_DIRECTORIES | For upload/download | (disabled) | Required for file operations. Comma-separated list of directories where upload/download are allowed (e.g., /tmp,/home/user/uploads). Upload/download are disabled if not set for security |
REDMINE_DANGEROUSLY_ACCEPT_INVALID_CERTS | No | (disabled) | Set to 1 to disable SSL certificate verification. Use only for self-signed certs in trusted environments |
Note: When running via Docker, the
REDMINE_REQUEST_INSTRUCTIONSenvironment variable must point to a path inside the container, not a path on the host machine. Therefore, if you want to use a local file, you need to mount it into the container at the correct location.
Security Note: The
REDMINE_ALLOWED_DIRECTORIESsetting protects against path traversal attacks. Paths containing../are resolved before validation, ensuring files can only be accessed within the allowed directories.
redmine_paths_list
- /issues.json
- /projects.json
- /time_entries.json
...
redmine_paths_info
path_templates (list of strings)/issues.json:
get:
operationId: getIssues
parameters:
- $ref: '#/components/parameters/format'
...
redmine_request
path (string): API endpoint path (e.g. '/issues.json')method (string, optional): HTTP method to use (default: 'get')data (object, optional): Dictionary for request body (for POST/PUT)params (object, optional): Dictionary for query parametersstatus_code: 200
body:
issues:
- id: 1
subject: "Fix login page"
...
error: ""
redmine_upload
REDMINE_ALLOWED_DIRECTORIES to be setfile_path (string): Fully qualified path to the file to upload (must be within allowed directories)description (string, optional): Optional description for the filestatus_code: 201
body:
upload:
id: 7
token: "7.ed32257a2ab0f7526c0d72c32994c58b131bb2c0775f7aa84aae01ea8397ea54"
error: ""
redmine_download
REDMINE_ALLOWED_DIRECTORIES to be setattachment_id (integer): The ID of the attachment to downloadsave_path (string): Fully qualified path where the file should be saved (must be within allowed directories)filename (string, optional): Optional filename to use (determined automatically if not provided)status_code: 200
body:
saved_to: "/path/to/downloaded/file.pdf"
filename: "file.pdf"
error: ""
Let's create a new bug report in the "Website" project:
1. Title: "Homepage not loading on mobile devices"
2. Description: "When accessing the homepage from iOS or Android devices, the loading spinner appears but the content never loads. This issue started after the last deployment."
3. Priority: High
4. Assign to: John Smith
Can you find all high priority issues in the "Website" project that are currently unassigned?
Please mark issue #123 as "In Progress" and add a comment: "I've started working on this issue. Expect it to be completed by Friday."
Log 3.5 hours against issue #456 for "Implementing user authentication" done today.
MCP Redmine is listed in the following MCP directory sites and repositories:
First clone the github repository and install the dependencies:
git clone git@github.com:runekaagaard/mcp-redmine.git
cd mcp-redmine
uv sync
Then set this in claude_desktop_config.json:
...
"command": "uv",
"args": ["run", "--directory", "/path/to/mcp-redmine", "-m", "mcp_redmine.server", "main"],
...
Contributions are warmly welcomed! Whether it's bug reports, feature requests, documentation improvements, or code contributions - all input is valuable. Feel free to:
The goal is to make Redmine project management with Claude even better, and your insights and contributions help achieve that.
This project builds on the excellent work of others:
Mozilla Public License Version 2.0