A Model Context Protocol (MCP) server implementation
Project description
Gitlab Review MCP
A Model Context Protocol (MCP) server for GitLab code review and project management. Provides comprehensive tools for interacting with GitLab projects, merge requests, issues, and code reviews through Claude AI.
Features
- GitLab Integration - Complete GitLab API integration using python-gitlab
- Code Review Tools - List projects, MRs, view diffs, and add comments
- Merge Request Management - Create, update, and review merge requests
- Suggestion Support - View and apply code change suggestions
- Issue Tracking - Fetch and manage GitLab issues
- Line Comments - Add precise code review comments to specific lines
- Comment Management - Update existing comments and reply to discussions
- Singleton Pattern - Efficient connection reuse across all tools
- Type Safety - Full Pydantic validation with structured models
- Error Handling - Comprehensive error reporting and graceful failure modes
- Logging - Centralized logging configuration with optional console output
Installation
Using uvx (Recommended)
uvx gitlab-review-mcp
Using uv
uv add gitlab-review-mcp
uv run gitlab-review-mcp
Configuration
Environment Variables
Required:
GITLAB_URL- GitLab instance URL (default:https://gitlab.com)GITLAB_PRIVATE_TOKEN- Your GitLab personal access token
Optional:
GITLAB_REVIEW_MCP_SHOW_LOGS- Set to"true"to enable detailed logging (default:false)
Getting Your GitLab Token
- Go to your GitLab instance (e.g., https://gitlab.com)
- Navigate to Settings โ Access Tokens
- Create a new token with the following scopes:
api- Full API accessread_api- Read API (if you only need read operations)
- Copy the token and add it to your environment configuration
Transport Types
stdio(default) - Standard input/output, client launches server automaticallyhttp(recommended for remote) - Modern HTTP transport (aliases:streamable-http,streamable_http)sse(legacy) - Server-Sent Events transport (deprecated)
๐ Quick Start (uvx)
Stdio Transport
{
"mcpServers": {
"gitlab-review-mcp": {
"command": "uvx",
"args": ["--no-progress", "gitlab-review-mcp"],
"env": {
"GITLAB_URL": "https://gitlab.com",
"GITLAB_PRIVATE_TOKEN": "your-token-here",
"GITLAB_REVIEW_MCP_SHOW_LOGS": "false"
}
}
}
}
HTTP Transport
Start server:
uvx --no-progress gitlab-review-mcp --transport http --port 8000 --host 0.0.0.0
Client config:
{
"mcpServers": {
"gitlab-review-mcp": {
"url": "http://localhost:8000/mcp",
"transport": "http"
}
}
}
SSE Transport
Start server:
uvx --no-progress gitlab-review-mcp --transport sse --port 8000 --host 0.0.0.0
Client config:
{
"mcpServers": {
"gitlab-review-mcp": {
"url": "http://localhost:8000/sse",
"transport": "sse"
}
}
}
๐ง Alternative Commands
Stdio with uv run --with
{
"mcpServers": {
"gitlab-review-mcp": {
"command": "uv",
"args": ["run", "--with", "gitlab-review-mcp", "gitlab-review-mcp"],
"env": {
"GITLAB_REVIEW_MCP_SHOW_LOGS": "false"
}
}
}
}
Stdio with uv run --directory (Local Development)
{
"mcpServers": {
"gitlab-review-mcp": {
"command": "uv",
"args": ["run", "--directory", "/path/to/gitlab-review-mcp", "gitlab-review-mcp"],
"env": {
"GITLAB_REVIEW_MCP_SHOW_LOGS": "true"
}
}
}
}
HTTP/SSE Alternative Commands
All transport types can use these alternative commands:
# Using uv run --with
uv run --with gitlab-review-mcp gitlab-review-mcp --transport http --port 8000
# Using uv run --directory (local development)
cd /path/to/gitlab-review-mcp
uv run gitlab-review-mcp --transport http --port 8000
Available Tools
Project Management
search_projects
Search for GitLab projects by keyword with pagination support.
Search Capabilities:
-
Performs substring matching across project name, path, namespace, and description
-
Note: Does not support regex or exact matching - simple keyword search only
-
Parameters:
search(required) - Search keyword for substring matchingowned(optional) - Only show owned projects (default:false)membership(optional) - Only show projects you're a member of (default:true)page(optional) - Page number for pagination (default:1)per_page(optional) - Results per page (default:20, max:100)order_by(optional) - Sort by:id,name,created_at,star_count,last_activity_at(default)sort(optional) - Sort order:ascordesc(default)
-
Returns: Formatted list of projects with ID, name, description, URL, default branch, and pagination info
Merge Request Operations
list_merge_requests
List merge requests for a specific project with pagination support.
- Parameters:
project_id(required) - GitLab project IDstate(optional) - Filter by state:opened,closed,merged,allauthor_id(optional) - Filter by author user IDassignee_id(optional) - Filter by assignee user IDlabels(optional) - Filter by label names (comma-separated)page(optional) - Page number for pagination (default:1)per_page(optional) - Results per page (default:20, max:100)
- Returns: Formatted list of MRs with IID, title, state, author, branches, URLs, and pagination info
get_merge_request
Fetch detailed merge request information.
- Parameters:
project_id(required) - GitLab project IDmr_iid(required) - Merge request IID (e.g., !123)
- Returns: MR details including title, description, state, branches, author, and timestamps
get_merge_request_diffs
Get code changes (diffs) for a merge request with pagination support.
- Parameters:
project_id(required) - GitLab project IDmr_iid(required) - Merge request IIDpage(optional) - Page number for pagination (default:1)per_page(optional) - Results per page (default:20, max:100)
- Returns: Complete diff information including file paths, commit SHAs, code changes, and pagination info
add_merge_request_comment
Add a general comment to a merge request.
- Parameters:
project_id(required) - GitLab project IDmr_iid(required) - Merge request IIDcomment(required) - Comment text
- Returns: Confirmation with comment ID and details
add_merge_request_line_comment
Add a line-specific comment to merge request code.
- Parameters:
project_id(required) - GitLab project IDmr_iid(required) - Merge request IIDfile_path(required) - File path in repositoryline_number(required) - Line number in new versioncomment(required) - Comment textbase_sha(required) - Base commit SHA (from diff)head_sha(required) - Head commit SHA (from diff)start_sha(required) - Start commit SHA (from diff)old_line(optional) - Line number in old version
- Returns: Confirmation with discussion ID and comment details
get_merge_request_comments
Get all comments and discussions from a merge request, including suggestions, with pagination support.
- Parameters:
project_id(required) - GitLab project IDmr_iid(required) - Merge request IIDpage(optional) - Page number for pagination (default:1)per_page(optional) - Results per page (default:20, max:100)
- Returns: All comments with note IDs, discussion IDs, authors, timestamps, embedded suggestions, and pagination info
get_merge_request_commits
Get all commits in a merge request with pagination support.
- Parameters:
project_id(required) - GitLab project IDmr_iid(required) - Merge request IIDpage(optional) - Page number for pagination (default:1)per_page(optional) - Results per page (default:20, max:100)
- Returns: List of commits with SHA, title, message, author, timestamps, and pagination info
update_merge_request_comment
Update an existing merge request comment.
- Parameters:
project_id(required) - GitLab project IDmr_iid(required) - Merge request IIDnote_id(required) - Note ID to updatecomment(required) - Updated comment text
- Returns: Confirmation with updated comment details
reply_to_merge_request_comment
Reply to an existing discussion thread.
- Parameters:
project_id(required) - GitLab project IDmr_iid(required) - Merge request IIDdiscussion_id(required) - Discussion ID to reply tocomment(required) - Reply comment text
- Returns: Confirmation with reply details
update_merge_request
Update merge request title and/or description.
- Parameters:
project_id(required) - GitLab project IDmr_iid(required) - Merge request IIDtitle(optional) - New titledescription(optional) - New description
- Returns: Updated MR details
Suggestion Management
apply_suggestion
Apply a single code change suggestion.
- Parameters:
suggestion_id(required) - Suggestion ID to apply
- Returns: Confirmation with commit ID
apply_suggestions
Apply multiple code change suggestions in batch.
- Parameters:
suggestion_ids(required) - List of suggestion IDs to apply
- Returns: Confirmation with commit ID and applied suggestion IDs
Issue Management
get_issue
Fetch detailed issue information.
- Parameters:
project_id(required) - GitLab project IDissue_iid(required) - Issue IID (e.g., #123)
- Returns: Issue details including title, description, state, assignees, labels, and timestamps
Testing
The project includes comprehensive tests:
# Run all tests
make test
# Run with coverage
make test-cov
Development
Setup Development Environment
# Clone the repository
git clone https://github.com/midodimori/gitlab-review-mcp.git
cd gitlab-review-mcp
# Install with development dependencies
make install-dev
# Run tests
make test
# Format and lint code
make format
# Check code style and types
make lint
# Run the server locally
make run
# See all available commands
make help
Project Structure
gitlab-review-mcp/
โโโ src/gitlab_review_mcp/
โ โโโ __init__.py
โ โโโ server.py # MCP server implementation
โ โโโ config.py # Configuration settings
โ โโโ services/ # Business logic layer
โ โ โโโ __init__.py
โ โ โโโ gitlab_service.py # GitLab API service
โ โโโ tools/ # MCP tool implementations
โ โ โโโ __init__.py
โ โ โโโ gitlab_tools.py # GitLab tools (14 tools)
โ โโโ utils/ # Utility modules
โ โโโ __init__.py
โ โโโ logging.py # Logging configuration
โโโ tests/
โ โโโ __init__.py
โ โโโ test_server.py # Tool function tests with mocks
โ โโโ test_pagination.py # Pagination-specific tests
โ โโโ test_mcp_integration.py # MCP integration tests
โโโ LICENSE
โโโ Makefile
โโโ PUBLISHING.md # Publishing guide
โโโ pyproject.toml # Project configuration
โโโ pytest.ini
โโโ README.md
Contributing
- Fork the repository
- Create a feature branch (
git checkout -b feature/amazing-feature) - Commit your changes (
git commit -m 'Add amazing feature') - Push to the branch (
git push origin feature/amazing-feature) - Open a Pull Request
License
This project is licensed under the MIT License - see the LICENSE file for details.
Links
Support
For questions, issues, or contributions:
- Open an issue on GitHub
- Check the comprehensive test suite for usage examples
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file gitlab_review_mcp-0.2.0.tar.gz.
File metadata
- Download URL: gitlab_review_mcp-0.2.0.tar.gz
- Upload date:
- Size: 82.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3fb96905f2d60e4c8f3fba71eaa270cdcb2683549881b0b69e3d0c05a38f7ba3
|
|
| MD5 |
bef0f2a4f879fa403259ca3a3aa7ffbf
|
|
| BLAKE2b-256 |
aea4437da2bc029df86b3fee95d17b1ad43f5e71c1e42981a38da2e884f23739
|
Provenance
The following attestation bundles were made for gitlab_review_mcp-0.2.0.tar.gz:
Publisher:
publish.yml on midodimori/gitlab-review-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
gitlab_review_mcp-0.2.0.tar.gz -
Subject digest:
3fb96905f2d60e4c8f3fba71eaa270cdcb2683549881b0b69e3d0c05a38f7ba3 - Sigstore transparency entry: 611636046
- Sigstore integration time:
-
Permalink:
midodimori/gitlab-review-mcp@40dd6b72e897bb9227a658934a829d19334fb0ce -
Branch / Tag:
refs/tags/v0.2.0 - Owner: https://github.com/midodimori
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@40dd6b72e897bb9227a658934a829d19334fb0ce -
Trigger Event:
release
-
Statement type:
File details
Details for the file gitlab_review_mcp-0.2.0-py3-none-any.whl.
File metadata
- Download URL: gitlab_review_mcp-0.2.0-py3-none-any.whl
- Upload date:
- Size: 19.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6720b84962b51a2d5e5e18a40bfe1fdc19bcdcdbed17997d5765a90b7ca24b68
|
|
| MD5 |
46051613dcb64cc4eeab070bbf31909e
|
|
| BLAKE2b-256 |
92f70400ee9dad877589f17bb9b5226608591fd81bfa974e261ae2d788af39b0
|
Provenance
The following attestation bundles were made for gitlab_review_mcp-0.2.0-py3-none-any.whl:
Publisher:
publish.yml on midodimori/gitlab-review-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
gitlab_review_mcp-0.2.0-py3-none-any.whl -
Subject digest:
6720b84962b51a2d5e5e18a40bfe1fdc19bcdcdbed17997d5765a90b7ca24b68 - Sigstore transparency entry: 611636053
- Sigstore integration time:
-
Permalink:
midodimori/gitlab-review-mcp@40dd6b72e897bb9227a658934a829d19334fb0ce -
Branch / Tag:
refs/tags/v0.2.0 - Owner: https://github.com/midodimori
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@40dd6b72e897bb9227a658934a829d19334fb0ce -
Trigger Event:
release
-
Statement type: