GitLab MCP(Model Context Protocol) Server. Includes bug fixes and improvements over the original GitLab MCP server.
When using with the Claude App, you need to set up your API key and URLs directly.
{
"mcpServers": {
"GitLab communication server": {
"command": "npx",
"args": ["-y", "@zereight/mcp-gitlab"],
"env": {
"GITLAB_PERSONAL_ACCESS_TOKEN": "your_gitlab_token",
"GITLAB_API_URL": "your_gitlab_api_url",
"GITLAB_PROJECT_ID": "your_project_id", // Optional: default project
"GITLAB_ALLOWED_PROJECT_IDS": "", // Optional: comma-separated list of allowed project IDs
"GITLAB_READ_ONLY_MODE": "false",
"USE_GITLAB_WIKI": "false", // use wiki api?
"USE_MILESTONE": "false", // use milestone api?
"USE_PIPELINE": "false" // use pipeline api?
}
}
}
}
{
"inputs": [
{
"type": "promptString",
"id": "gitlab-token",
"description": "Gitlab Token to read API",
"password": true
}
],
"servers": {
"GitLab-MCP": {
"type": "stdio",
"command": "npx",
"args": ["-y", "@zereight/mcp-gitlab"],
"env": {
"GITLAB_PERSONAL_ACCESS_TOKEN": "${input:gitlab-token}",
"GITLAB_API_URL": "your-fancy-gitlab-url",
"GITLAB_READ_ONLY_MODE": "true",
...
}
}
}
}
- stdio mcp.json
{
"mcpServers": {
"GitLab communication server": {
"command": "docker",
"args": [
"run",
"-i",
"--rm",
"-e",
"GITLAB_PERSONAL_ACCESS_TOKEN",
"-e",
"GITLAB_API_URL",
"-e",
"GITLAB_READ_ONLY_MODE",
"-e",
"USE_GITLAB_WIKI",
"-e",
"USE_MILESTONE",
"-e",
"USE_PIPELINE",
"iwakitakuma/gitlab-mcp"
],
"env": {
"GITLAB_PERSONAL_ACCESS_TOKEN": "your_gitlab_token",
"GITLAB_API_URL": "https://gitlab.com/api/v4", // Optional, for self-hosted GitLab
"GITLAB_READ_ONLY_MODE": "false",
"USE_GITLAB_WIKI": "true",
"USE_MILESTONE": "true",
"USE_PIPELINE": "true"
}
}
}
}
- sse
docker run -i --rm \
-e GITLAB_PERSONAL_ACCESS_TOKEN=your_gitlab_token \
-e GITLAB_API_URL= "https://gitlab.com/api/v4"\
-e GITLAB_READ_ONLY_MODE=true \
-e USE_GITLAB_WIKI=true \
-e USE_MILESTONE=true \
-e USE_PIPELINE=true \
-e SSE=true \
-p 3333:3002 \
iwakitakuma/gitlab-mcp
{
"mcpServers": {
"GitLab communication server": {
"type": "sse",
"url": "http://localhost:3333/sse"
}
}
}
- streamable-http
docker run -i --rm \
-e GITLAB_PERSONAL_ACCESS_TOKEN=your_gitlab_token \
-e GITLAB_API_URL="https://gitlab.com/api/v4" \
-e GITLAB_READ_ONLY_MODE=true \
-e USE_GITLAB_WIKI=true \
-e USE_MILESTONE=true \
-e USE_PIPELINE=true \
-e STREAMABLE_HTTP=true \
-p 3333:3002 \
iwakitakuma/gitlab-mcp
{
"mcpServers": {
"GitLab communication server": {
"url": "http://localhost:3333/mcp"
}
}
}
$ sh scripts/image_push.sh docker_user_name
GITLAB_PERSONAL_ACCESS_TOKEN
: Your GitLab personal access token.GITLAB_API_URL
: Your GitLab API URL. (Default:https://gitlab.com/api/v4
)GITLAB_PROJECT_ID
: Default project ID. If set, Overwrite this value when making an API request.GITLAB_ALLOWED_PROJECT_IDS
: Optional comma-separated list of allowed project IDs. When set with a single value, acts as a default project (like the old "lock" mode). When set with multiple values, restricts access to only those projects. Examples:- Single value
123
: MCP server can only access project 123 and uses it as default - Multiple values
123,456,789
: MCP server can access projects 123, 456, and 789 but requires explicit project ID in requests
- Single value
GITLAB_READ_ONLY_MODE
: When set to 'true', restricts the server to only expose read-only operations. Useful for enhanced security or when write access is not needed. Also useful for using with Cursor and it's 40 tool limit.USE_GITLAB_WIKI
: When set to 'true', enables the wiki-related tools (list_wiki_pages, get_wiki_page, create_wiki_page, update_wiki_page, delete_wiki_page). By default, wiki features are disabled.USE_MILESTONE
: When set to 'true', enables the milestone-related tools (list_milestones, get_milestone, create_milestone, edit_milestone, delete_milestone, get_milestone_issue, get_milestone_merge_requests, promote_milestone, get_milestone_burndown_events). By default, milestone features are disabled.USE_PIPELINE
: When set to 'true', enables the pipeline-related tools (list_pipelines, get_pipeline, list_pipeline_jobs, get_pipeline_job, get_pipeline_job_output, create_pipeline, retry_pipeline, cancel_pipeline). By default, pipeline features are disabled.GITLAB_AUTH_COOKIE_PATH
: Path to an authentication cookie file for GitLab instances that require cookie-based authentication. When provided, the cookie will be included in all GitLab API requests.SSE
: When set to 'true', enables the Server-Sent Events transport.STREAMABLE_HTTP
: When set to 'true', enables the Streamable HTTP transport. If both SSE and STREAMABLE_HTTP are set to 'true', the server will prioritize Streamable HTTP over SSE transport.
+
verify_namespace
- Verify if a namespace path exists
update_wiki_page
- Update an existing wiki page in a GitLab project
update_merge_request
- Update a merge request (Either mergeRequestIid or branchName must be provided)
update_merge_request_note
- Modify an existing merge request thread note
update_label
- Update an existing label in a project
update_issue
- Update an issue in a GitLab project
update_issue_note
- Modify an existing issue thread note
update_draft_note
- Update an existing draft note
search_repositories
- Search for GitLab projects
retry_pipeline
- Retry a failed or canceled pipeline
push_files
- Push multiple files to a GitLab project in a single commit
publish_draft_note
- Publish a single draft note
promote_milestone
- Promote a milestone to the next stage
my_issues
- List issues assigned to the authenticated user
mr_discussions
- List discussion items for a merge request
list_wiki_pages
- List wiki pages in a GitLab project
list_projects
- List projects accessible by the current user
list_project_members
- List members of a GitLab project
list_pipelines
- List pipelines in a GitLab project with filtering options
list_pipeline_trigger_jobs
- List all trigger jobs (bridges) in a specific pipeline that trigger downstream pipelines
list_pipeline_jobs
- List all jobs in a specific pipeline
list_namespaces
- List all namespaces available to the current user
list_milestones
- List milestones in a GitLab project with filtering options
list_merge_requests
- List merge requests in a GitLab project with filtering options
list_merge_request_diffs
- List merge request diffs with pagination support (Either mergeRequestIid or branchName must be provided)
list_labels
- List labels for a project
list_issues
- List issues in a GitLab project with filtering options
list_issue_links
- List all issue links for a specific issue
list_issue_discussions
- List discussions for an issue in a GitLab project
list_group_projects
- List projects in a GitLab group with filtering options
list_draft_notes
- List draft notes for a merge request
get_wiki_page
- Get details of a specific wiki page
get_users
- Get GitLab user details by usernames
get_repository_tree
- Get the repository tree for a GitLab project (list files and directories)
get_project
- Get details of a specific project
get_pipeline
- Get details of a specific pipeline in a GitLab project
get_pipeline_job
- Get details of a GitLab pipeline job number
get_pipeline_job_output
- Get the output/trace of a GitLab pipeline job number
get_namespace
- Get details of a namespace by ID or path
get_milestone
- Get details of a specific milestone
get_milestone_merge_requests
- Get merge requests associated with a specific milestone
get_milestone_issue
- Get issues associated with a specific milestone
get_milestone_burndown_events
- Get burndown events for a specific milestone
get_merge_request
- Get details of a merge request (Either mergeRequestIid or branchName must be provided)
get_merge_request_diffs
- Get the changes/diffs of a merge request (Either mergeRequestIid or branchName must be provided)
get_label
- Get a single label from a project
get_issue
- Get details of a specific issue in a GitLab project
get_issue_link
- Get a specific issue link
get_file_contents
- Get the contents of a file or directory from a GitLab project
get_branch_diffs
- Get the changes/diffs between two branches or commits in a GitLab project
fork_repository
- Fork a GitLab project to your account or specified namespace
edit_milestone
- Edit an existing milestone in a GitLab project
delete_wiki_page
- Delete a wiki page from a GitLab project
delete_milestone
- Delete a milestone from a GitLab project
delete_label
- Delete a label from a project
delete_issue
- Delete an issue from a GitLab project
delete_issue_link
- Delete an issue link
delete_draft_note
- Delete a draft note
download_attachment
- Download an uploaded file from a GitLab project by secret and filename
create_wiki_page
- Create a new wiki page in a GitLab project
create_repository
- Create a new GitLab project
create_pipeline
- Create a new pipeline for a branch or tag
create_or_update_file
- Create or update a single file in a GitLab project
create_note
- Create a new note (comment) to an issue or merge request
create_milestone
- Create a new milestone in a GitLab project
create_merge_request
- Create a new merge request in a GitLab project
create_merge_request_thread
- Create a new thread on a merge request
create_merge_request_note
- Add a new note to an existing merge request thread
create_label
- Create a new label in a project
create_issue
- Create a new issue in a GitLab project
create_issue_note
- Add a new note to an existing issue thread
create_issue_link
- Create an issue link between two issues
create_draft_note
- Create a draft note for a merge request
create_branch
- Create a new branch in a GitLab project
cancel_pipeline
- Cancel a running pipeline
bulk_publish_draft_notes
- Publish all draft notes for a merge request