Skip to main content
Glama
onozaty

Redmine MCP Server

by onozaty

Redmine MCP Server

Model Context Protocol (MCP) server for Redmine that provides comprehensive access to the Redmine REST API.

Overview

This project is an MCP server that comprehensively covers Redmine's REST API. It allows you to operate Redmine from MCP clients (such as Claude Desktop).

Related MCP server: Redmine MCP Server

Demonstration

Here are example videos showing how to use the Redmine MCP server with Claude Desktop:

Creating an Issue

https://github.com/user-attachments/assets/075fb079-104c-404d-91f5-755b3882853b

This demonstration also uses the Playwright MCP for browser automation alongside the Redmine MCP server.

Getting Issue Information

https://github.com/user-attachments/assets/8f551082-6982-4513-8fe7-b0f111be982d

Features

  • 📋 Comprehensive API Coverage: Supports all functions available in Redmine's REST API

  • 🔒 Read-Only Mode: Supports safe data reference mode

  • 🔧 Tool Filtering: Control which tools are available using regex patterns

Prerequisites

Getting Redmine API Key

  1. Log in to Redmine with administrator privileges

  2. Go to "Administration" → "Settings" → "API" tab

  3. Check "Enable REST web service"

  4. Generate "API access key" in personal settings

For details, refer to Redmine REST API documentation.

Configuration

Environment Variables

The following environment variables are required (specified in MCP client configuration files):

  • REDMINE_URL (Required): Base URL of the Redmine instance

    • Example: https://redmine.example.com

  • REDMINE_API_KEY (Required): API key generated in Redmine

    • Set the API key obtained in prerequisites

  • REDMINE_MCP_READ_ONLY (Optional): Enable read-only mode

    • true: Read-only mode (disables data modification operations)

    • false or unset: Allow all operations (default)

  • REDMINE_MCP_TOOLS_ALLOW_PATTERN (Optional): Regex pattern to allow only matching tools

    • Example: ^get (enable only tools starting with "get")

    • If unset, all tools are allowed (subject to other settings)

  • REDMINE_MCP_TOOLS_DENY_PATTERN (Optional): Regex pattern to disable matching tools

    • Example: ^delete (disable all tools starting with "delete")

    • If unset, no tools are denied (subject to other settings)

    • Deny pattern takes priority over allow pattern

MCP Client Configuration

Add the following as MCP configuration for your AI agent:

{
  "mcpServers": {
    "redmine": {
      "command": "npx",
      "args": ["-y", "@onozaty/redmine-mcp-server"],
      "env": {
        "REDMINE_URL": "https://your-redmine.example.com",
        "REDMINE_API_KEY": "your-api-key-here",
        "REDMINE_MCP_READ_ONLY": "true"
      }
    }
  }
}

Using Docker (Alternative)

If you prefer using Docker:

{
  "mcpServers": {
    "redmine": {
      "command": "docker",
      "args": [
        "run", "--rm", "-i",
        "-e", "REDMINE_URL=https://your-redmine.example.com",
        "-e", "REDMINE_API_KEY=your-api-key-here",
        "-e", "REDMINE_MCP_READ_ONLY=true",
        "ghcr.io/onozaty/redmine-mcp-server:latest"
      ]
    }
  }
}

When to use Docker:

  • Enterprise environments requiring container isolation

  • Reproducible deployments across different systems

  • Environments where Node.js installation is restricted

Below are specific configuration methods for several MCP clients:

Claude Desktop

Add the following to claude_desktop_config.json:

{
  "mcpServers": {
    "redmine": {
      "command": "npx",
      "args": ["-y", "@onozaty/redmine-mcp-server"],
      "env": {
        "REDMINE_URL": "https://your-redmine.example.com",
        "REDMINE_API_KEY": "your-api-key-here",
        "REDMINE_MCP_READ_ONLY": "true"
      }
    }
  }
}

Claude Code

In Claude Code, you can add MCP servers using the following commands:

Local configuration:

claude mcp add redmine -e REDMINE_URL=https://your-redmine.example.com -e REDMINE_API_KEY=your-api-key-here -e REDMINE_MCP_READ_ONLY=true -- npx -y @onozaty/redmine-mcp-server

Project configuration:

claude mcp add -s project redmine -e REDMINE_URL=https://your-redmine.example.com -e REDMINE_API_KEY=your-api-key-here -e REDMINE_MCP_READ_ONLY=true -- npx -y @onozaty/redmine-mcp-server

User configuration (global):

claude mcp add -s user redmine -e REDMINE_URL=https://your-redmine.example.com -e REDMINE_API_KEY=your-api-key-here -e REDMINE_MCP_READ_ONLY=true -- npx -y @onozaty/redmine-mcp-server

Visual Studio Code

Project configuration (.vscode/mcp.json):

{
  "servers": {
    "redmine": {
      "type": "stdio",
      "command": "npx",
      "args": ["-y", "@onozaty/redmine-mcp-server"],
      "env": {
        "REDMINE_URL": "https://your-redmine.example.com",
        "REDMINE_API_KEY": "your-api-key-here",
        "REDMINE_MCP_READ_ONLY": "true"
      }
    }
  }
}

User configuration (settings.json):

{
  "mcp": {
    "servers": {
      "redmine": {
        "type": "stdio",
        "command": "npx",
        "args": ["-y", "@onozaty/redmine-mcp-server"],
        "env": {
          "REDMINE_URL": "https://your-redmine.example.com",
          "REDMINE_API_KEY": "your-api-key-here",
          "REDMINE_MCP_READ_ONLY": "true"
        }
      }
    }
  }
}

Available Features

This MCP server comprehensively supports the functions provided by Redmine's REST API:

Main Features

  • Issues: Create, update, delete, search, and manage related issues

  • Projects: Create, update, delete, archive, and manage memberships

  • Users: Create, update, delete, and manage groups

  • Time Entries: Record, update, and delete time entries

  • Wiki: Create, update, delete pages, and manage versions

  • News: Create, update, and delete news

  • Files: Upload and download files

  • Attachments: Upload, download files, and get thumbnails

  • Queries: Execute saved queries

  • Custom Fields: Get and manage custom fields

  • Roles: Get and manage roles

  • Trackers: Get and manage trackers

  • Issue Statuses: Get and manage issue statuses

  • Search: Cross-search functionality

Read-Only Mode

By setting REDMINE_MCP_READ_ONLY=true, you can disable data modification operations. This allows safe data reference.

Tool Filtering

You can control which tools are available using the following environment variables:

  • REDMINE_MCP_TOOLS_ALLOW_PATTERN: Only tools whose names match this regex are enabled.

    • Example: ^get enables only read-oriented tools like getIssues, getProjects, etc.

  • REDMINE_MCP_TOOLS_DENY_PATTERN: Tools whose names match this regex are disabled.

    • Example: ^delete disables all delete operations.

When both are set, deny takes priority. These can also be combined with REDMINE_MCP_READ_ONLY.

Example: Allow only issue-related tools

"env": {
  "REDMINE_MCP_TOOLS_ALLOW_PATTERN": "Issue"
}

Example: Disable all delete and archive operations

"env": {
  "REDMINE_MCP_TOOLS_DENY_PATTERN": "^(delete|archive)"
}

Available Tools

The following tools are available (based on Redmine REST API categories):

Category

Tools

Issues

getIssues, getIssue, createIssue, updateIssue, deleteIssue, addWatcher, removeWatcher, addRelatedIssue, removeRelatedIssue

Projects

getProjects, getProject, createProject, updateProject, deleteProject, archiveProject, unarchiveProject, closeProject, reopenProject

Project Memberships

getMemberships, getMembership, createMembership, updateMembership, deleteMembership

Users

getUsers, getUser, createUser, updateUser, deleteUser, getCurrentUser

Time Entries

getTimeEntries, getTimeEntry, createTimeEntry, updateTimeEntry, deleteTimeEntry

News

getNewsList, getNewsListByProject, getNews, createNews, updateNews, deleteNews

Issue Relations

getIssueRelations, getIssueRelation, createIssueRelation, deleteIssueRelation

Versions

getVersionsByProject, getVersions, createVersion, updateVersion, deleteVersion

Wiki Pages

getWikiPages, getWikiPage, getWikiPageByVersion, updateWikiPage, deleteWikiPage

Queries

getQueries

Attachments

getAttachment, updateAttachment, deleteAttachment, uploadAttachmentFromLocalFile, uploadAttachmentFromBase64Content, downloadAttachmentToLocalFile, downloadAttachmentAsBase64Content, downloadThumbnailToLocalFile, downloadThumbnailAsBase64Content

Issue Statuses

getIssueStatuses

Trackers

getTrackers

Enumerations

getIssuePriorities, getTimeEntryActivities, getDocumentCategories

Issue Categories

getIssueCategories, getIssueCategory, createIssueCategory, updateIssueCategory, deleteIssueCategory

Roles

getRoles, getRole

Groups

getGroups, getGroup, createGroup, updateGroup, deleteGroup, addUserToGroup, removeUserFromGroup

Custom Fields

getCustomFields

Search

search

Files

getFiles, createFile

My Account

getMyAccount, updateMyAccount

Journals

updateJournal

License

MIT License

Author

onozaty

Acknowledgments

Install Server
A
license - permissive license
C
quality
A
maintenance

Maintenance

–Maintainers
9hResponse time
2moRelease cycle
5Releases (12mo)
Commit activity
Issues opened vs closed

Resources

Unclaimed servers have limited discoverability.

Looking for Admin?

If you are the server author, to access and configure the admin panel.

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/onozaty/redmine-mcp-server'

If you have feedback or need assistance with the MCP directory API, please join our Discord server