loading…
Search for a command to run...
loading…
Stateless Redmine MCP server. Credentials are passed per-request via HTTP headers and never stored on the server. Supports listing/creating/updating issues, ful
Stateless Redmine MCP server. Credentials are passed per-request via HTTP headers and never stored on the server. Supports listing/creating/updating issues, full-text search across subjects, descriptions and comments, and editing journals (Redmine 5.0+). Deployable on RHEL (systemd) or Docker.
An MCP (Model Context Protocol) server that lets Claude Code operate Redmine directly. Runs as an HTTP server on RHEL or Docker. Credentials are never stored on the server — they are passed per-request via HTTP headers from the Claude Code configuration file.
Context-First Design Returns journals (comments) alongside issues so the AI can reason about history, generate accurate follow-up proposals, and summarize progress.
Stateless Design API keys are passed per-request from the client and never stored on the server. This brings three practical benefits:
Powerful Full-Text Search
search_issues_full searches across subject, description, and all comments, returning results in an AI-friendly format.
update_journal)Client PC (Claude Code / Mac or Windows)
↓ HTTP :8000 + headers (X-Redmine-URL / X-Redmine-API-Key)
Server (RHEL or Docker)
↓ REST API
Redmine
1. Transfer files to the server
ssh root@<server> "mkdir -p /tmp/redmine-mcp-stateless"
scp redmine_mcp_interface.py redmine_mcp_server.py requirements.txt \
redmine-mcp-stateless.service install.sh uninstall.sh \
root@<server>:/tmp/redmine-mcp-stateless/
2. Run the installer
cd /tmp/redmine-mcp-stateless
chmod +x install.sh
./install.sh
install.sh performs the following:
redmine-mcp-stateless system user/opt/redmine-mcp-stateless/ and creates a Python virtual environmenthttp_port_t)3. Verify
systemctl status redmine-mcp-stateless
journalctl -u redmine-mcp-stateless -f
To uninstall
bash uninstall.sh
Runs the MCP server as a container. Requires an existing Redmine instance accessible from the host.
1. Build and start
docker compose up -d --build
2. Verify
docker compose ps
docker compose logs -f redmine-mcp-stateless
Stop
docker compose down
Add the following to ~/.claude.json:
RHEL
{
"mcpServers": {
"redmine-mcp-stateless": {
"type": "sse",
"url": "http://<server-IP>:8000/sse",
"headers": {
"X-Redmine-URL": "https://<your-redmine>",
"X-Redmine-API-Key": "<your-api-key>"
}
}
}
}
Docker
{
"mcpServers": {
"redmine-mcp-stateless": {
"type": "sse",
"url": "http://localhost:8000/sse",
"headers": {
"X-Redmine-URL": "https://<your-redmine>",
"X-Redmine-API-Key": "<your-api-key>"
}
}
}
}
| Tool | Description |
|---|---|
list_issues |
List issues with optional filters (project, status, assignee) |
get_issue |
Issue details including all comments and attachments |
create_issue |
Create a new issue |
update_issue |
Update an issue or add a comment |
update_journal |
Edit an existing comment (requires Redmine 5.0+) |
list_issues_with_journals |
List issues with all comments — useful for per-assignee progress review |
search_issues_full |
Full-text search across subject, description, and comments |
| Tool | Description |
|---|---|
list_projects |
List all projects |
get_project |
Project details |
| Tool | Description |
|---|---|
list_statuses |
Available issue statuses |
list_trackers |
Available trackers |
list_priorities |
Available priorities |
list_users |
User list (may require admin privileges) |
| Category | Fields |
|---|---|
| Project | ID, identifier, name, description, status |
| Issue | ID, subject, description, status, project, tracker, priority, assignee, created/updated date |
| Journal (comment) | comment ID, body, created date, author |
| Attachment | file ID, filename, file size, MIME type, description, author, created date |
| Status / Tracker / Priority | ID, name |
| User | ID, login, first name, last name, full name |
| File | Description |
|---|---|
redmine_mcp_interface.py |
MCP server entry point |
redmine_mcp_server.py |
Redmine REST API client |
requirements.txt |
Python dependencies |
Dockerfile |
Container image (python:3.12-slim) |
compose.yml |
Docker Compose configuration |
redmine-mcp-stateless.service |
systemd unit file |
install.sh |
RHEL installation script |
uninstall.sh |
Uninstallation script |
example-claude-code-config.json |
Example Claude Code configuration |
X-Redmine-URL and X-Redmine-API-Key headersContextVar and discarded after each request completesredmine-mcp-stateless)MIT
Добавь это в claude_desktop_config.json и перезапусти Claude Desktop.
{
"mcpServers": {
"daiji-sshr-redmine-mcp-stateless": {
"command": "npx",
"args": []
}
}
}PRs, issues, code search, CI status
Database, auth and storage
Reference / test server with prompts, resources, and tools.
Secure file operations with configurable access controls.