bitbucket-python-mcp
An MCP server for BitBucket Cloud operations that enables AI agents to manage repositories, branches, pull requests, and search code.
README
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-python-mcp
Using pip
pip install bitbucket-python-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
- Go to BitBucket App Passwords
- Click "Create app password"
- Give it a descriptive name (e.g., "MCP Server")
- Select the required permissions:
- Repositories: Read, Write, Admin (for create/delete)
- Pull requests: Read, Write
- 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-python-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-python-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-python-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-python-mcp
# or
uv run bitbucket-python-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.
- Fork the repository
- Create your feature branch (
git checkout -b feature/amazing-feature) - Commit your changes (
git commit -m 'Add some amazing feature') - Push to the branch (
git push origin feature/amazing-feature) - Open a Pull Request
License
This project is licensed under the MIT License - see the LICENSE file for details.
Acknowledgments
- Model Context Protocol - The protocol specification
- atlassian-python-api - BitBucket API client
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.