bitbucket-python-mcp
Allows AI agents to manage Bitbucket Cloud repositories, branches, pull requests, search code, and store/retrieve workspace memories through the Bitbucket API.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@bitbucket-python-mcplist my open pull requests"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
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-mcpUsing pip
pip install bitbucket-python-mcpFrom Source
git clone https://github.com/yourusername/bitbucket-python-mcp.git
cd bitbucket-python-mcp
uv syncConfiguration
The server requires the following environment variables:
Variable | Required | Description |
| Yes | Your BitBucket username (not email) |
| Yes | App password/API token from BitBucket settings |
| Yes | Default workspace slug |
| 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-mcpVerify the server is configured:
codex mcp listRunning 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-mcpAvailable Tools
Repository Tools
Tool | Description |
| List all repositories in a workspace |
| Get detailed repository information |
| Create a new repository |
| Delete a repository (requires confirmation) |
| Update repository settings |
Branch Tools
Tool | Description |
| List all branches in a repository |
| Get branch details |
| Create a new branch |
| Delete a branch (requires confirmation) |
Pull Request Tools
Tool | Description |
| List pull requests (open/merged/declined) |
| Get PR details (defaults to newest) |
| Get the diff for a PR |
| Get all comments on a PR |
| Add a comment (general or inline) |
| Approve a PR |
| Request changes on a PR |
| Create a new PR |
Search Tools
Tool | Description |
| Search for repositories by name |
| Browse repository files/directories |
| Search for code patterns |
| Get raw file content |
Memory Tools
Tool | Description |
| Store a new learning/standard for future reference |
| List stored memories filtered by workspace/category |
| Search memories by keyword |
| Get memories relevant to current context |
| Delete a stored memory |
| 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 developmentReview a Pull Request
User: Show me the details of the newest pull request
User: What are the comments on PR #42?
User: Approve PR #42Search Code
User: Search for "authentication" in the project-api repository
User: Show me the contents of src/main.pyStore 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-devRunning Tests
uv run pytest
# or using just
just testLinting
uv run ruff check src tests
uv run ruff format src tests
# or using just
just fmt
just lintBuilding
uv build
# or using just
just buildContributing
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
This server cannot be installed
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/clikader/bitbucket-python-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server