Skip to main content

A Model Context Protocol (MCP) server for BitBucket Cloud operations

Project description

BitBucket MCP Server

A Model Context Protocol (MCP) server for BitBucket Cloud operations. This server enables AI coding agents like Claude Code CLI and Codex CLI to interact with BitBucket repositories, branches, and pull requests.

Features

  • Repository Management: Create, delete, update, and list repositories
  • Branch Management: Create, delete, and list branches
  • Pull Request Operations: Create, review, approve, comment on pull requests
  • Code Search: Search repositories and browse file contents
  • Memory System: Store and retrieve workspace standards and learnings from PR reviews
  • Auto-detection: Automatically detects current BitBucket repository from git remote

Installation

Using uvx (Recommended)

uvx bitbucket-mcp

Using pip

pip install bitbucket-mcp

From Source

git clone https://github.com/yourusername/bitbucket-python-mcp.git
cd bitbucket-python-mcp
uv sync

Configuration

The server requires the following environment variables:

Variable Required Description
BITBUCKET_USERNAME Yes Your BitBucket username (not email)
BITBUCKET_API_TOKEN Yes App password/API token from BitBucket settings
BITBUCKET_WORKSPACE Yes Default workspace slug
BITBUCKET_MCP_DEBUG No Enable debug logging (1/true/yes)

Creating an App Password

  1. Go to BitBucket App Passwords
  2. Click "Create app password"
  3. Give it a descriptive name (e.g., "MCP Server")
  4. Select the required permissions:
    • Repositories: Read, Write, Admin (for create/delete)
    • Pull requests: Read, Write
  5. Click "Create" and copy the generated password

Usage with AI Agents

Claude Code CLI

Add to your ~/.claude/claude_desktop_config.json:

{
  "mcpServers": {
    "bitbucket": {
      "command": "uvx",
      "args": ["bitbucket-mcp"],
      "env": {
        "BITBUCKET_USERNAME": "your-username",
        "BITBUCKET_API_TOKEN": "your-api-token",
        "BITBUCKET_WORKSPACE": "your-workspace"
      }
    }
  }
}

OpenAI Codex CLI

Add to your ~/.codex/config.toml:

[mcp_servers.bitbucket]
command = "uvx"
args = ["bitbucket-mcp"]

[mcp_servers.bitbucket.env]
BITBUCKET_USERNAME = "your-username"
BITBUCKET_API_TOKEN = "your-api-token"
BITBUCKET_WORKSPACE = "your-workspace"

Alternatively, use the Codex CLI to add the server:

codex mcp add bitbucket \
  --env BITBUCKET_USERNAME=your-username \
  --env BITBUCKET_API_TOKEN=your-api-token \
  --env BITBUCKET_WORKSPACE=your-workspace \
  -- uvx bitbucket-mcp

Verify the server is configured:

codex mcp list

Running Locally

# Set environment variables
export BITBUCKET_USERNAME="your-username"
export BITBUCKET_API_TOKEN="your-api-token"
export BITBUCKET_WORKSPACE="your-workspace"

# Run the server
uvx bitbucket-mcp
# or
uv run bitbucket-mcp

Available Tools

Repository Tools

Tool Description
list_repositories List all repositories in a workspace
get_repository Get detailed repository information
create_repository Create a new repository
delete_repository Delete a repository (requires confirmation)
update_repository Update repository settings

Branch Tools

Tool Description
list_branches List all branches in a repository
get_branch Get branch details
create_branch Create a new branch
delete_branch Delete a branch (requires confirmation)

Pull Request Tools

Tool Description
list_pull_requests List pull requests (open/merged/declined)
get_pull_request Get PR details (defaults to newest)
get_pull_request_diff Get the diff for a PR
get_pull_request_comments Get all comments on a PR
add_pull_request_comment Add a comment (general or inline)
approve_pull_request Approve a PR
request_changes Request changes on a PR
create_pull_request Create a new PR

Search Tools

Tool Description
search_repositories Search for repositories by name
get_repository_contents Browse repository files/directories
search_code Search for code patterns
get_file_content Get raw file content

Memory Tools

Tool Description
add_memory Store a new learning/standard for future reference
list_memories List stored memories filtered by workspace/category
search_memories Search memories by keyword
get_relevant_memories Get memories relevant to current context
delete_memory Delete a stored memory
remember_from_pr_comment Extract and store learning from a PR comment

Memories are stored in ~/.bitbucket-python-mcp/memory/ and persist across sessions.

Examples

Create a Repository

User: Create a new private repository named "my-new-project" with description "My awesome project"

Create a Branch

User: Create a new branch named "feature-login" from development

Review a Pull Request

User: Show me the details of the newest pull request
User: What are the comments on PR #42?
User: Approve PR #42

Search Code

User: Search for "authentication" in the project-api repository
User: Show me the contents of src/main.py

Store and Retrieve Memories

User: Remember that we should use shared-pipeline for SonarQube scans
User: What standards should I follow for this workspace?
User: Search memories for "pipeline"

Development

Setup

# Clone the repository
git clone https://github.com/yourusername/bitbucket-python-mcp.git
cd bitbucket-python-mcp

# Install dependencies
uv sync --all-extras

# or using just
just install-dev

Running Tests

uv run pytest

# or using just
just test

Linting

uv run ruff check src tests
uv run ruff format src tests

# or using just
just fmt
just lint

Building

uv build

# or using just
just build

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

  1. Fork the repository
  2. Create your feature branch (git checkout -b feature/amazing-feature)
  3. Commit your changes (git commit -m 'Add some amazing feature')
  4. Push to the branch (git push origin feature/amazing-feature)
  5. Open a Pull Request

License

This project is licensed under the MIT License - see the LICENSE file for details.

Acknowledgments

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

bitbucket_python_mcp-0.1.2.tar.gz (96.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

bitbucket_python_mcp-0.1.2-py3-none-any.whl (26.2 kB view details)

Uploaded Python 3

File details

Details for the file bitbucket_python_mcp-0.1.2.tar.gz.

File metadata

  • Download URL: bitbucket_python_mcp-0.1.2.tar.gz
  • Upload date:
  • Size: 96.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.25 {"installer":{"name":"uv","version":"0.9.25","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":null,"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for bitbucket_python_mcp-0.1.2.tar.gz
Algorithm Hash digest
SHA256 dcbdb0c51372b870d3c39f0e82379ec8fe419565c799d7c76aada2584c84b4cf
MD5 047dd4059b87b432ebaaaeaa86afc136
BLAKE2b-256 907f27cb1b8d92024738a8214d50843df98ebc065ecfb46165b790886703ed7e

See more details on using hashes here.

File details

Details for the file bitbucket_python_mcp-0.1.2-py3-none-any.whl.

File metadata

  • Download URL: bitbucket_python_mcp-0.1.2-py3-none-any.whl
  • Upload date:
  • Size: 26.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.25 {"installer":{"name":"uv","version":"0.9.25","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":null,"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for bitbucket_python_mcp-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 ff2f1bd10d9b7cd6397e2f30d188885549632708beb5b23804d7ffe13a2c88ea
MD5 2aec181da32f6f5cbb2b356e7a51d727
BLAKE2b-256 4b8810740eaf6cab1f7753e495f7e47dacdf39cf839ef48a21673da5bf315bc6

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page