A Model Context Protocol (MCP) server for interacting with Bloom Growth's GraphQL API.
Bloomy MCP is a server that connects to Bloom Growth's GraphQL API and exposes it through the Model Context Protocol, enabling AI assistants to perform operations against the Bloom Growth platform.
- Query Bloom Growth GraphQL API through MCP
- Retrieve query and mutation details
- Execute GraphQL queries and mutations via MCP tools
- Get authenticated user information
- Automatic schema introspection
- Python 3.12 or higher
- Access to Bloom Growth API
- uv (recommended) or pip for package management
This project recommends using uv
, a fast Python package installer and resolver that serves as a drop-in replacement for pip/pip-tools. It's significantly faster than traditional package managers.
curl -sSf https://astral.sh/uv/install.sh | sh
For other installation methods, see the uv documentation.
-
Clone this repository
-
Set up a Python virtual environment:
python -m venv .venv source .venv/bin/activate # On Windows: .venv\Scripts\activate
-
Install the package in development mode:
Using pip:
pip install -e .
Using uv (recommended):
uv pip install -e .
For development dependencies:
uv pip install -e ".[dev]"
Create a .env
file with the following variables:
BLOOM_API_URL=<Your Bloom API URL>
BLOOM_API_TOKEN=<Your Bloom API Token>
To use this MCP server with Cursor (AI-powered IDE):
-
Go to Cursor > Cursor Settings > MCP
-
Click on "Add new MCP server"
-
Configure the server with the following details:
- Name: "Bloom Growth" (or "BG" or any name you prefer)
- Type: Command
- Command:
uv run --project /path/to/your/repo/ --env-file /path/to/your/repo/.env bloomy-server
Important: Replace
/path/to/your/repo/
with the actual path to your bloomy-mcp repository (e.g.,/Users/username/workspace/bloomy-mcp/
).
Start the Bloomy MCP server:
bloomy-server
For development and debugging purposes, you can use the MCP inspector tool:
npx @modelcontextprotocol/inspector bloomy-server
This allows you to inspect the MCP server's behavior and responses during development.
For optimal development workflow:
- direnv: Use for managing environment variables and automatically loading them when entering the project directory
- uv: Use for fast and reliable package management
Setting up direnv:
- Install direnv (e.g.,
brew install direnv
on macOS) - Create a
.envrc
file in your project root:export BLOOM_API_URL=your_api_url export BLOOM_API_TOKEN=your_api_token
- Run
direnv allow
to authorize the environment variables
This combination of tools (direnv + uv) provides an efficient environment for both secrets management and package management.
The following MCP tools are available for AI assistants:
get_query_details
- Get detailed information about specific GraphQL queriesget_mutation_details
- Get detailed information about specific GraphQL mutationsexecute_query
- Execute a GraphQL query or mutation with variablesget_authenticated_user_id
- Get the ID of the currently authenticated user
bloom://queries
- Get a list of all available queriesbloom://mutations
- Get a list of all available mutations
src/
└── bloomy_mcp/
├── __init__.py # Package initialization
├── client.py # GraphQL client implementation
├── formatters.py # Data formatting utilities
├── introspection.py # GraphQL schema introspection
├── operations.py # GraphQL operation utilities
└── server.py # MCP server implementation
mcp[cli]
- Model Context Protocol servergql
- GraphQL client libraryhttpx
- HTTP clientpyyaml
- YAML processing