Redmine
An MCP server for interacting with the Redmine project management system.
Redmine MCP Server
A Model Context Protocol (MCP) server for Redmine integration, built with TypeScript following TDD methodology. This server allows AI assistants to interact with Redmine instances to manage issues, projects, and users with comprehensive security and monitoring features.
Features
- Issue Management: Create, read, update, and list issues
- Project Management: List and view project details
- User Management: List and view user information
- Error Handling: Comprehensive error handling with meaningful error messages
- Type Safety: Full TypeScript implementation with proper type definitions
Installation
npm install
npm run build
Configuration
The server requires two environment variables:
REDMINE_BASE_URL: The base URL of your Redmine instance (e.g.,https://redmine.example.com)REDMINE_API_KEY: Your Redmine API key (found in your account settings)
Usage
Running the Server
export REDMINE_BASE_URL="https://your-redmine-instance.com"
export REDMINE_API_KEY="your-api-key-here"
npm run dev
Building and Running
npm run build
export REDMINE_BASE_URL="https://your-redmine-instance.com"
export REDMINE_API_KEY="your-api-key-here"
npm start
Production Deployment
# Build the project
npm run build
# Set production environment variables
export REDMINE_BASE_URL="https://your-redmine-instance.com"
export REDMINE_API_KEY="your-api-key-here"
export LOG_LEVEL="info"
# Start the server
npm start
Available Tools
Issue Tools
-
list-issues: List issues with optional filtering
- Parameters:
project_id,status_id,assigned_to_id,limit,offset
- Parameters:
-
create-issue: Create a new issue
- Required:
project_id,subject - Optional:
description,tracker_id,status_id,priority_id,assigned_to_id
- Required:
-
get-issue: Get details of a specific issue
- Required:
id
- Required:
-
update-issue: Update an existing issue
- Required:
id - Optional:
subject,description,status_id,priority_id,assigned_to_id,done_ratio
- Required:
Project Tools
-
list-projects: List all projects
-
get-project: Get details of a specific project
- Required:
id(can be numeric ID or string identifier)
- Required:
User Tools
-
list-users: List all users
-
get-user: Get details of a specific user
- Required:
id
- Required:
Development
Running Tests
npm test
Running Tests with Coverage
npm run test:coverage
Running in Watch Mode
npm run test:watch
Linting
npm run lint
Type Checking
npm run typecheck
Clean Build Directory
npm run clean
API Reference
RedmineClient
The core client for interacting with Redmine's REST API.
const client = new RedmineClient({
baseUrl: 'https://redmine.example.com',
apiKey: 'your-api-key'
});
RedmineMcpServer
The MCP server that exposes Redmine functionality as MCP tools.
const server = new RedmineMcpServer({
baseUrl: 'https://redmine.example.com',
apiKey: 'your-api-key'
});
await server.start();
Error Handling
The server provides comprehensive error handling for common scenarios:
- Authentication errors (401): Invalid API key
- Authorization errors (403): Insufficient permissions
- Not found errors (404): Resource doesn't exist
- Validation errors (422): Invalid data provided
- Server errors (500): Internal server issues
- Network errors: Connection timeouts and network issues
- Input validation: Client-side validation with detailed error messages
Logging
The server includes structured logging with configurable levels:
- DEBUG: Detailed execution information and request/response data
- INFO: General operational information (default)
- WARN: Warning conditions that don't affect operation
- ERROR: Error conditions that require attention
Configure the log level using the LOG_LEVEL environment variable:
export LOG_LEVEL="debug" # For development
export LOG_LEVEL="info" # For production (default)
export LOG_LEVEL="error" # For minimal logging
Contributing
- Fork the repository
- Create a feature branch
- Make your changes
- Add tests for new functionality
- Run the test suite
- Submit a pull request
License
MIT License
Servidores relacionados
Kone.vc
patrocinadorMonetize your AI agent with contextual product recommendations
Anytype
Interact with your Anytype data through its API, enabling AI assistants to access your information.
Ookcite MCP
Validate DOIs against a real citation database, format references in 2900+ CSL styles (APA, IEEE, Chicago, Nature, etc.), and catch hallucinated academic references before they reach your paper or documentation or pitch deck. Manage citation collections, import/export BibTeX, and batch-process references. 29 tools.
GitHub Project Manager MCP
A GitHub-integrated project management server for Claude Desktop, requiring a personal access token.
Umami MCP Server
Integrate Umami Analytics with any MCP client like Claude Desktop, VS Code, and more.
mdshare
Free markdown sharing with collaboration. Upload, get a link, share. No login needed.
MCP Sharepoint (aisuru)
A Model Context Protocol (MCP) server that exposes core Microsoft SharePoint / Microsoft Graph API functionalities as tools usable by LLM agents (e.g. Claude Desktop).
Hilanet MCP
Provides HR-related tools for a corporate dystopia.
Todoist
Manage tasks and projects on Todoist using natural language.
Clio MCP Server
An MCP server for integrating with Clio practice management software, tailored for Australian legal professionals.
freee
Interact with the freee accounting API to manage financial data and business operations.