martijndormans/mcp-gitlab
If you are the rightful owner of mcp-gitlab and would like to certify it and/or have it hosted online, please leave a comment on the right or send an email to henry@mcphub.com.
The GitLab MCP Server is designed to facilitate seamless interaction with the GitLab API, offering tools for project management, file operations, and more.
create_or_update_file
Create or update a single file in a project.
push_files
Push multiple files in a single commit.
search_repositories
Search for GitLab projects.
create_repository
Create a new GitLab project.
get_file_contents
Get contents of a file or directory.
create_issue
Create a new issue.
create_merge_request
Create a new merge request.
get_merge_request_raw_diff
Get a merge request information of the difference in a raw format.
fork_repository
Fork a project.
create_branch
Create a new branch.
get_job_logs
Retrieve the logs from a job.
🦊 GitLab MCP Server
🚀 MCP Server for the GitLab API, enabling project management, file operations, and more.
✨ Features
- 🌿 Automatic Branch Creation: When creating/updating files or pushing changes, branches are automatically created if they don't exist
- 🛡️ Comprehensive Error Handling: Clear error messages for common issues
- 📚 Git History Preservation: Operations maintain proper Git history without force pushing
- 📦 Batch Operations: Support for both single-file and multi-file operations
🔧 Tools
-
create_or_update_file
- Create or update a single file in a project
- Inputs:
project_id
(string): Project ID or URL-encoded pathfile_path
(string): Path where to create/update the filecontent
(string): Content of the filecommit_message
(string): Commit messagebranch
(string): Branch to create/update the file inprevious_path
(optional string): Path of the file to move/rename
- Returns: File content and commit details
-
push_files
- Push multiple files in a single commit
- Inputs:
project_id
(string): Project ID or URL-encoded pathbranch
(string): Branch to push tofiles
(array): Files to push, each withfile_path
andcontent
commit_message
(string): Commit message
- Returns: Updated branch reference
-
search_repositories
- Search for GitLab projects
- Inputs:
search
(string): Search querypage
(optional number): Page number for paginationper_page
(optional number): Results per page (default 20)
- Returns: Project search results
-
create_repository
- Create a new GitLab project
- Inputs:
name
(string): Project namedescription
(optional string): Project descriptionvisibility
(optional string): 'private', 'internal', or 'public'initialize_with_readme
(optional boolean): Initialize with README
- Returns: Created project details
-
get_file_contents
- Get contents of a file or directory
- Inputs:
project_id
(string): Project ID or URL-encoded pathfile_path
(string): Path to file/directoryref
(optional string): Branch/tag/commit to get contents from
- Returns: File/directory contents
-
create_issue
- Create a new issue
- Inputs:
project_id
(string): Project ID or URL-encoded pathtitle
(string): Issue titledescription
(optional string): Issue descriptionassignee_ids
(optional number[]): User IDs to assignlabels
(optional string[]): Labels to addmilestone_id
(optional number): Milestone ID
- Returns: Created issue details
-
create_merge_request
- Create a new merge request
- Inputs:
project_id
(string): Project ID or URL-encoded pathtitle
(string): MR titledescription
(optional string): MR descriptionsource_branch
(string): Branch containing changestarget_branch
(string): Branch to merge intodraft
(optional boolean): Create as draft MRallow_collaboration
(optional boolean): Allow commits from upstream members
- Returns: Created merge request details
-
get_merge_request_raw_diff
- Get a merge request information of the difference in a raw format
- Inputs:
project_id
(string): Project ID or URL-encoded pathmerge_request_id
(string): ID of the merge request
- Returns: The difference of the merge request in a raw format
-
fork_repository
- Fork a project
- Inputs:
project_id
(string): Project ID or URL-encoded pathnamespace
(optional string): Namespace to fork to
- Returns: Forked project details
-
create_branch
- Create a new branch
- Inputs:
project_id
(string): Project ID or URL-encoded pathbranch
(string): Name for new branchref
(optional string): Source branch/commit for new branch
- Returns: Created branch reference
get_job_logs
- Retrieve the logs from a job
- Inputs:
project_id
(string): Project ID or URL-encoded pathjob_id
(string): ID of the job
- Returns: The logs of the job
⚙️ Setup
🔑 Personal Access Token
Create a GitLab Personal Access Token with appropriate permissions:
- Go to User Settings > Access Tokens in GitLab
- Select the required scopes:
api
for full API accessread_api
for read-only accessread_repository
andwrite_repository
for repository operations
- Create the token and save it securely
💻 Usage with Claude Desktop
Add the following to your claude_desktop_config.json
:
🐳 Docker
{
"mcpServers": {
"gitlab": {
"command": "docker",
"args": [
"run",
"--rm",
"-i",
"-e",
"GITLAB_PERSONAL_ACCESS_TOKEN",
"-e",
"GITLAB_API_URL",
"mcp/gitlab"
],
"env": {
"GITLAB_PERSONAL_ACCESS_TOKEN": "<YOUR_TOKEN>",
"GITLAB_API_URL": "https://gitlab.com/api/v4" // Optional, for self-hosted instances
}
}
}
}
📦 NPX
{
"mcpServers": {
"gitlab": {
"command": "npx",
"args": ["-y", "@modelcontextprotocol/server-gitlab"],
"env": {
"GITLAB_PERSONAL_ACCESS_TOKEN": "<YOUR_TOKEN>",
"GITLAB_API_URL": "https://gitlab.com/api/v4" // Optional, for self-hosted instances
}
}
}
}
🏗️ Build
Docker build:
docker build -t vonwig/gitlab:mcp -f src/gitlab/Dockerfile .
🌍 Environment Variables
GITLAB_PERSONAL_ACCESS_TOKEN
: Your GitLab personal access token (required)GITLAB_API_URL
: Base URL for GitLab API (optional, defaults tohttps://gitlab.com/api/v4
)