npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

@harrison99/gitlab-mcp

v1.0.0

Published

MCP server for using the GitLab API

Downloads

5

Readme

Better GitLab MCP Server

@harrison99/gitlab-mcp

GitLab MCP(Model Context Protocol) Server. Includes bug fixes and improvements over the original GitLab MCP server.

Usage

Using with Claude App, Cline, Roo Code, Cursor

When using with the Claude App, you need to set up your API key and URLs directly.

npx

{
  "mcpServers": {
    "GitLab communication server": {
      "command": "npx",
      "args": ["-y", "@harrison99/gitlab-mcp"],
      "env": {
        "GITLAB_PERSONAL_ACCESS_TOKEN": "your_gitlab_token",
        "GITLAB_API_URL": "your_gitlab_api_url",
        "GITLAB_READ_ONLY_MODE": "false",
        "USE_GITLAB_WIKI": "false", // use wiki api?
        "USE_MILESTONE": "false", // use milestone api?
        "USE_PIPELINE": "false" // use pipeline api?
      }
    }
  }
}

vscode .vscode/mcp.json

{
  "inputs": [
    {
      "type": "promptString",
      "id": "gitlab-token",
      "description": "Gitlab Token to read API",
      "password": true
    }
  ],
  "servers": {
    "GitLab-MCP": {
      "type": "stdio",
      "command": "npx",
      "args": ["-y", "@harrison99/gitlab-mcp"],
      "env": {
        "GITLAB_PERSONAL_ACCESS_TOKEN": "${input:gitlab-token}",
        "GITLAB_API_URL": "your-fancy-gitlab-url",
        "GITLAB_READ_ONLY_MODE": "true",
        ...
      }
    }
  }
}

Docker

  • 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"
    }
  }
}

Docker Image Push

$ sh scripts/image_push.sh docker_user_name

Environment Variables

  • 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_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.

Tools 🛠️

+

  1. create_or_update_file - Create or update a single file in a GitLab project
  2. search_repositories - Search for GitLab projects
  3. create_repository - Create a new GitLab project
  4. edit_repository - Edit an existing GitLab project
  5. add_member_repository - Add a member to a GitLab project
  6. remove_member_repository - Remove a member from a GitLab project
  7. invite_member_repository_by_email - Invite a member to a GitLab project by email
  8. get_file_contents - Get the contents of a file or directory from a GitLab project
  9. push_files - Push multiple files to a GitLab project in a single commit
  10. create_issue - Create a new issue in a GitLab project
  11. create_merge_request - Create a new merge request in a GitLab project
  12. fork_repository - Fork a GitLab project to your account or specified namespace
  13. create_branch - Create a new branch in a GitLab project
  14. get_merge_request - Get details of a merge request (Either mergeRequestIid or branchName must be provided)
  15. get_merge_request_diffs - Get the changes/diffs of a merge request (Either mergeRequestIid or branchName must be provided)
  16. list_merge_request_diffs - List merge request diffs with pagination support (Either mergeRequestIid or branchName must be provided)
  17. get_branch_diffs - Get the changes/diffs between two branches or commits in a GitLab project
  18. update_merge_request - Update a merge request (Either mergeRequestIid or branchName must be provided)
  19. create_note - Create a new note (comment) to an issue or merge request
  20. create_merge_request_thread - Create a new thread on a merge request
  21. mr_discussions - List discussion items for a merge request
  22. update_merge_request_note - Modify an existing merge request thread note
  23. create_merge_request_note - Add a new note to an existing merge request thread
  24. update_issue_note - Modify an existing issue thread note
  25. create_issue_note - Add a new note to an existing issue thread
  26. list_issues - List issues in a GitLab project with filtering options
  27. get_issue - Get details of a specific issue in a GitLab project
  28. update_issue - Update an issue in a GitLab project
  29. delete_issue - Delete an issue from a GitLab project
  30. list_issue_links - List all issue links for a specific issue
  31. list_issue_discussions - List discussions for an issue in a GitLab project
  32. get_issue_link - Get a specific issue link
  33. create_issue_link - Create an issue link between two issues
  34. delete_issue_link - Delete an issue link
  35. list_namespaces - List all namespaces available to the current user
  36. get_namespace - Get details of a namespace by ID or path
  37. verify_namespace - Verify if a namespace path exists
  38. get_project - Get details of a specific project
  39. list_projects - List projects accessible by the current user
  40. list_labels - List labels for a project
  41. get_label - Get a single label from a project
  42. create_label - Create a new label in a project
  43. update_label - Update an existing label in a project
  44. delete_label - Delete a label from a project
  45. list_group_projects - List projects in a GitLab group with filtering options
  46. list_wiki_pages - List wiki pages in a GitLab project
  47. get_wiki_page - Get details of a specific wiki page
  48. create_wiki_page - Create a new wiki page in a GitLab project
  49. update_wiki_page - Update an existing wiki page in a GitLab project
  50. delete_wiki_page - Delete a wiki page from a GitLab project
  51. get_repository_tree - Get the repository tree for a GitLab project (list files and directories)
  52. list_pipelines - List pipelines in a GitLab project with filtering options
  53. get_pipeline - Get details of a specific pipeline in a GitLab project
  54. list_pipeline_jobs - List all jobs in a specific pipeline
  55. get_pipeline_job - Get details of a GitLab pipeline job number
  56. get_pipeline_job_output - Get the output/trace of a GitLab pipeline job number
  57. create_pipeline - Create a new pipeline for a branch or tag
  58. retry_pipeline - Retry a failed or canceled pipeline
  59. cancel_pipeline - Cancel a running pipeline
  60. list_merge_requests - List merge requests in a GitLab project with filtering options
  61. list_milestones - List milestones in a GitLab project with filtering options
  62. get_milestone - Get details of a specific milestone
  63. create_milestone - Create a new milestone in a GitLab project
  64. edit_milestone - Edit an existing milestone in a GitLab project
  65. delete_milestone - Delete a milestone from a GitLab project
  66. get_milestone_issue - Get issues associated with a specific milestone
  67. get_milestone_merge_requests - Get merge requests associated with a specific milestone
  68. promote_milestone - Promote a milestone to the next stage
  69. get_milestone_burndown_events - Get burndown events for a specific milestone
  70. get_users - Get GitLab user details by usernames

Fork from

https://github.com/zereight/gitlab-mcp