loading…
Search for a command to run...
loading…
Model Context Protocol (MCP) server for Bitbucket Cloud and Server API integration
Model Context Protocol (MCP) server for Bitbucket Cloud and Server API integration
A Model Context Protocol (MCP) server for integrating with Bitbucket Cloud and Server APIs. This MCP server enables AI assistants like Cursor to interact with your Bitbucket repositories, pull requests, and other resources.
This is a safe and responsible package — no DELETE operations are used, so there's no risk of data loss. Every pull request is analyzed with CodeQL to ensure the code remains secure.
CodeQL GitHub Repository License: MIT npm version
Checkout out the official npm package This server implements the Model Context Protocol standard to provide AI assistants with access to Bitbucket data and operations. It includes tools for:
-- Since it has been asked, in many cases we have seen - "BITBUCKET_USERNAME" is usually your email
The easiest way to use this MCP server is via NPX, which allows you to run it without installing it globally:
# Option A (recommended): API URL + explicit workspace
BITBUCKET_URL="https://api.bitbucket.org/2.0" \
BITBUCKET_WORKSPACE="your-workspace" \
BITBUCKET_USERNAME="your-username" \
BITBUCKET_PASSWORD="your-app-password" \
npx -y bitbucket-mcp@latest
# Option B (legacy-compatible): web URL only; workspace is auto-extracted
BITBUCKET_URL="https://bitbucket.org/your-workspace" \
BITBUCKET_USERNAME="your-username" \
BITBUCKET_PASSWORD="your-app-password" \
npx -y bitbucket-mcp@latest
Alternatively, you can install it globally or as part of your project:
# Install globally
npm install -g bitbucket-mcp
# Or install in your project
npm install bitbucket-mcp
Then run it with:
# If installed globally (Option A)
BITBUCKET_URL="https://api.bitbucket.org/2.0" \
BITBUCKET_WORKSPACE="your-workspace" \
BITBUCKET_USERNAME="your-username" \
BITBUCKET_PASSWORD="your-app-password" \
bitbucket-mcp
# If installed globally (Option B - legacy-compatible)
BITBUCKET_URL="https://bitbucket.org/your-workspace" \
BITBUCKET_USERNAME="your-username" \
BITBUCKET_PASSWORD="your-app-password" \
bitbucket-mcp
# If installed in your project (Option A)
BITBUCKET_URL="https://api.bitbucket.org/2.0" \
BITBUCKET_WORKSPACE="your-workspace" \
BITBUCKET_USERNAME="your-username" \
BITBUCKET_PASSWORD="your-app-password" \
npx bitbucket-mcp
# If installed in your project (Option B - legacy-compatible)
BITBUCKET_URL="https://bitbucket.org/your-workspace" \
BITBUCKET_USERNAME="your-username" \
BITBUCKET_PASSWORD="your-app-password" \
npx bitbucket-mcp
Configure the server using the following environment variables:
| Variable | Description | Required |
|---|---|---|
BITBUCKET_URL |
Bitbucket API base URL. Defaults to https://api.bitbucket.org/2.0 |
No |
BITBUCKET_USERNAME |
Your Bitbucket username | Yes* |
BITBUCKET_PASSWORD |
Your Bitbucket app password | Yes* |
BITBUCKET_TOKEN |
Your Bitbucket access token (alternative to username/password) | No |
BITBUCKET_WORKSPACE |
Default workspace to use. If omitted and BITBUCKET_URL contains it, auto-set |
No |
BITBUCKET_ENABLE_DANGEROUS |
Set to true to enable dangerous tools (e.g., deletions). Default: disabled |
No |
BITBUCKET_LOG_DISABLE |
Disable file logging when set to true/1 |
No |
BITBUCKET_LOG_FILE |
Absolute path to a specific log file | No |
BITBUCKET_LOG_DIR |
Directory to store logs (defaults to OS-specific app log dir) | No |
BITBUCKET_LOG_PER_CWD |
When true, nest logs under a per-working-directory subfolder |
No |
Either BITBUCKET_TOKEN or both BITBUCKET_USERNAME and BITBUCKET_PASSWORD must be provided.
BITBUCKET_PASSWORD environment variableIf you're getting 401 authentication errors, check the following:
BITBUCKET_URL="https://api.bitbucket.org/2.0"
# Test with curl (replace with your actual values)
curl -u "your-username:your-app-password" \
"https://api.bitbucket.org/2.0/repositories/your-workspace"
BITBUCKET_PASSWORD variable, not BITBUCKET_TOKENBITBUCKET_USERNAME instead of your regular usernameFor reference you can check the API token documentation
If you encounter issues:
To integrate this MCP server with Cursor:
"bitbucket": {
"command": "npx",
"env": {
"BITBUCKET_URL": "https://api.bitbucket.org/2.0",
"BITBUCKET_WORKSPACE": "your-workspace",
"BITBUCKET_USERNAME": "your-username",
"BITBUCKET_PASSWORD": "your-app-password"
},
"args": ["-y", "bitbucket-mcp@latest"]
}
If you're developing locally and want to test your changes:
"bitbucket-local": {
"command": "node",
"env": {
"BITBUCKET_URL": "https://api.bitbucket.org/2.0",
"BITBUCKET_WORKSPACE": "your-workspace",
"BITBUCKET_USERNAME": "your-username",
"BITBUCKET_PASSWORD": "your-app-password"
},
"args": ["/path/to/your/local/bitbucket-mcp/dist/index.js"]
}
This MCP server provides tools for interacting with Bitbucket repositories and pull requests. Below is a comprehensive list of the available operations:
Unless noted otherwise, listing tools accept the following optional parameters:
pagelen: Number of items per page (Bitbucket pagelen). Defaults to 10 and is capped at 100.page: 1-based Bitbucket page number to fetch. When omitted, the first page is returned.all: When true (and page is not provided), the server automatically follows Bitbucket next links until all items are fetched or a safety cap of 1,000 entries is reached.limit: Deprecated alias for pagelen kept for backward compatibility.Use these knobs to page through large collections without hitting CLI truncation.
listRepositoriesLists repositories in a workspace.
Parameters:
workspace (optional): Bitbucket workspace namename (optional): Filter repositories by partial name matchgetRepositoryGets details for a specific repository.
Parameters:
workspace: Bitbucket workspace namerepo_slug: Repository sluggetPullRequestsGets pull requests for a repository.
Parameters:
workspace: Bitbucket workspace namerepo_slug: Repository slugstate (optional): Pull request state (OPEN, MERGED, DECLINED, SUPERSEDED)createPullRequestCreates a new pull request.
Parameters:
workspace: Bitbucket workspace namerepo_slug: Repository slugtitle: Pull request titledescription: Pull request descriptionsourceBranch: Source branch nametargetBranch: Target branch namereviewers (optional): List of reviewer usernamesdraft (optional): Whether to create the pull request as a draftgetPullRequestGets details for a specific pull request.
Parameters:
workspace: Bitbucket workspace namerepo_slug: Repository slugpull_request_id: Pull request IDupdatePullRequestUpdates a pull request.
Parameters:
workspace: Bitbucket workspace namerepo_slug: Repository slugpull_request_id: Pull request IDgetPullRequestActivityGets the activity log for a pull request.
Parameters:
workspace: Bitbucket workspace namerepo_slug: Repository slugpull_request_id: Pull request IDapprovePullRequestApproves a pull request.
Parameters:
workspace: Bitbucket workspace namerepo_slug: Repository slugpull_request_id: Pull request IDunapprovePullRequestRemoves an approval from a pull request.
Parameters:
workspace: Bitbucket workspace namerepo_slug: Repository slugpull_request_id: Pull request IDdeclinePullRequestDeclines a pull request.
Parameters:
workspace: Bitbucket workspace namerepo_slug: Repository slugpull_request_id: Pull request IDmessage (optional): Reason for decliningmergePullRequestMerges a pull request.
Parameters:
workspace: Bitbucket workspace namerepo_slug: Repository slugpull_request_id: Pull request IDmessage (optional): Merge commit messagestrategy (optional): Merge strategy (merge-commit, squash, fast-forward)requestChangesRequests changes on a pull request.
Parameters:
workspace: Bitbucket workspace namerepo_slug: Repository slugpull_request_id: Pull request IDremoveChangeRequestRemoves a change request from a pull request.
Parameters:
workspace: Bitbucket workspace namerepo_slug: Repository slugpull_request_id: Pull request IDcreateDraftPullRequestCreates a new draft pull request.
Parameters:
workspace: Bitbucket workspace namerepo_slug: Repository slugtitle: Pull request titledescription: Pull request descriptionsourceBranch: Source branch nametargetBranch: Target branch namereviewers (optional): List of reviewer usernamesNote: This is equivalent to calling createPullRequest with draft: true.
publishDraftPullRequestPublishes a draft pull request to make it ready for review.
Parameters:
workspace: Bitbucket workspace namerepo_slug: Repository slugpull_request_id: Pull request IDconvertTodraftConverts a regular pull request to draft status.
Parameters:
workspace: Bitbucket workspace namerepo_slug: Repository slugpull_request_id: Pull request IDgetPullRequestCommentsLists comments on a pull request.
Parameters:
workspace: Bitbucket workspace namerepo_slug: Repository slugpull_request_id: Pull request IDaddPullRequestCommentCreates a comment on a pull request (general or inline).
Parameters:
workspace: Bitbucket workspace namerepo_slug: Repository slugpull_request_id: Pull request IDcontent: Comment content in markdown formatinline (optional): Inline comment information for commenting on specific linesInline Comment Format:
The inline parameter allows you to create comments on specific lines of code in the pull request diff:
{
"path": "src/file.ts",
"to": 15, // Line number in NEW version (for added/modified lines)
"from": 10 // Line number in OLD version (for deleted/modified lines)
}
Examples:
inline parameter for a general pull request commentto parameterfrom parameterfrom and to parametersUsage:
// General comment
addPullRequestComment(workspace, repo, pr_id, "Great work!");
// Inline comment on new line 25
addPullRequestComment(workspace, repo, pr_id, "Consider error handling here", {
path: "src/service.ts",
to: 25,
});
getPullRequestCommentGets a specific comment on a pull request.
Parameters:
workspace: Bitbucket workspace namerepo_slug: Repository slugpull_request_id: Pull request IDcomment_id: Comment IDupdatePullRequestCommentUpdates a comment on a pull request.
Parameters:
workspace: Bitbucket workspace namerepo_slug: Repository slugpull_request_id: Pull request IDcomment_id: Comment IDcontent: Updated comment contentdeletePullRequestCommentDeletes a comment on a pull request.
Parameters:
workspace: Bitbucket workspace namerepo_slug: Repository slugpull_request_id: Pull request IDcomment_id: Comment IDresolveCommentResolves a comment thread on a pull request.
Parameters:
workspace: Bitbucket workspace namerepo_slug: Repository slugpull_request_id: Pull request IDcomment_id: Comment IDreopenCommentReopens a resolved comment thread on a pull request.
Parameters:
workspace: Bitbucket workspace namerepo_slug: Repository slugpull_request_id: Pull request IDcomment_id: Comment IDgetPullRequestDiffGets the diff for a pull request.
Parameters:
workspace: Bitbucket workspace namerepo_slug: Repository slugpull_request_id: Pull request IDgetPullRequestDiffStatGets the diff statistics for a pull request.
Parameters:
workspace: Bitbucket workspace namerepo_slug: Repository slugpull_request_id: Pull request IDgetPullRequestPatchGets the patch for a pull request.
Parameters:
workspace: Bitbucket workspace namerepo_slug: Repository slugpull_request_id: Pull request IDgetPullRequestTasksLists tasks on a pull request.
Parameters:
workspace: Bitbucket workspace namerepo_slug: Repository slugpull_request_id: Pull request IDcreatePullRequestTaskCreates a task on a pull request.
Parameters:
workspace: Bitbucket workspace namerepo_slug: Repository slugpull_request_id: Pull request IDcontent: Task contentcomment (optional): Comment ID to associate with the taskpending (optional): Whether the task is pendinggetPullRequestTaskGets a specific task on a pull request.
Parameters:
workspace: Bitbucket workspace namerepo_slug: Repository slugpull_request_id: Pull request IDtask_id: Task IDupdatePullRequestTaskUpdates a task on a pull request.
Parameters:
workspace: Bitbucket workspace namerepo_slug: Repository slugpull_request_id: Pull request IDtask_id: Task IDcontent (optional): Updated task contentstate (optional): Updated task statedeletePullRequestTaskDeletes a task on a pull request.
Parameters:
workspace: Bitbucket workspace namerepo_slug: Repository slugpull_request_id: Pull request IDtask_id: Task IDgetPullRequestCommitsLists commits on a pull request.
Parameters:
workspace: Bitbucket workspace namerepo_slug: Repository slugpull_request_id: Pull request IDgetPullRequestStatusesLists commit statuses for a pull request.
Parameters:
workspace: Bitbucket workspace namerepo_slug: Repository slugpull_request_id: Pull request IDlistPipelineRunsLists pipeline runs for a repository.
Parameters:
workspace: Bitbucket workspace namerepo_slug: Repository slugstatus (optional): Filter pipelines by status (PENDING, IN_PROGRESS, SUCCESSFUL, FAILED, ERROR, STOPPED)target_branch (optional): Filter pipelines by target branchtrigger_type (optional): Filter pipelines by trigger type (manual, push, pullrequest, schedule)getPipelineRunGets details for a specific pipeline run.
Parameters:
workspace: Bitbucket workspace namerepo_slug: Repository slugpipeline_uuid: Pipeline UUIDrunPipelineTriggers a new pipeline run.
Parameters:
workspace: Bitbucket workspace namerepo_slug: Repository slugtarget: Pipeline target configuration (object with ref_type, ref_name, and optional commit_hash, selector_type, selector_pattern)variables (optional): Array of pipeline variables (objects with key, value, and optional secured fields)stopPipelineStops a running pipeline.
Parameters:
workspace: Bitbucket workspace namerepo_slug: Repository slugpipeline_uuid: Pipeline UUIDgetPipelineStepsLists steps for a pipeline run.
Parameters:
workspace: Bitbucket workspace namerepo_slug: Repository slugpipeline_uuid: Pipeline UUIDgetPipelineStepGets details for a specific pipeline step.
Parameters:
workspace: Bitbucket workspace namerepo_slug: Repository slugpipeline_uuid: Pipeline UUIDstep_uuid: Step UUIDgetPipelineStepLogsGets logs for a specific pipeline step.
Parameters:
workspace: Bitbucket workspace namerepo_slug: Repository slugpipeline_uuid: Pipeline UUIDstep_uuid: Step UUID# Clone the repository
git clone https://github.com/MatanYemini/bitbucket-mcp.git
cd bitbucket-mcp
# Install dependencies
npm install
# Build the project
npm run build
# Run in development mode
npm run dev
Use the official Model Context Protocol publishing guide when you are ready to make a new server release. The repository includes everything that guide expects:
dist/index.js is up to date:npm run build
package.json and emits registry/bitbucket-mcp.manifest.json):npm run registry:manifest
smithery publish or the recommended workflow from the guide.The generated manifest captures the CLI command (node dist/index.js), all documented configuration options, and pointers back to
this README for setup instructions, so it can be submitted directly to the MCP registry.
This project is licensed under the MIT License - see the LICENSE file for details.
Добавь это в claude_desktop_config.json и перезапусти Claude Desktop.
{
"mcpServers": {
"bitbucket-mcp": {
"command": "npx",
"args": [
"-y",
"bitbucket-mcp"
]
}
}
}