Skip to main content

SpaceBridge MCP Server for issue tracker automation.

Project description

SpaceBridge-MCP

A Model Context Protocol (MCP) server that integrates with the SpaceBridge REST API (https://spacebridge.io/docs) to automate issue management across connected issue trackers.

SpaceBridge-MCP Overview

Overview

SpaceBridge-MCP is a Model Context Protocol (MCP) server designed to integrate AI development tools (like Claude code, Windsurf, Cursor) with the SpaceBridge issue aggregation platform. It allows developers to interact with their issue trackers directly from their coding environment via their AI assistant.

Core Benefits:

  • Reduced Context Switching: Manage issues (search, create, view) without leaving the development environment.
  • Automated Issue Tracking: Facilitates workflows where AI assistants can automatically find or create relevant issues associated with code changes (e.g., for commit messages).
  • Enhanced AI Context: Provides AI assistants with access to issue details (via get_issue_by_id), enabling more context-aware code generation and analysis.
  • Centralized Interaction: Leverages SpaceBridge to interact with multiple underlying issue trackers (Jira, GitHub Issues, etc.) through a single interface.

Functionality:

The server exposes MCP tools and resources that translate natural language requests from an AI assistant into SpaceBridge API calls. Key features include intelligent duplicate checking (using similarity search and LLM comparison) before issue creation and flexible handling of organization/project context.

Features

  • Resource: get_issue_by_id: Retrieves details for a specific issue using its SpaceBridge ID.
  • Tool: search_issues: Searches for issues based on a query string using either full-text or similarity search.
  • Tool: create_issue: Creates a new issue. Before creation, it performs a similarity search for potentially duplicate issues and uses an LLM to compare the top results against the new issue's content. If a likely duplicate is found, it returns the existing issue's ID; otherwise, it creates the new issue.
  • Tool: update_issue: Updates an existing issue.

Getting Started

Prerequisites

  • Python 3.9+
  • pip (Python package installer)
  • Access to a SpaceBridge instance and API key.
  • OpenAI API Key (for the create_issue tool's duplicate check).

Installation using pip

  1. Install the package:
    pip install spacebridge-mcp
    

Installation from source

  1. Clone the repository:
    git clone <repository-url>
    cd spacebridge-mcp
    
  2. Create and activate a virtual environment (recommended):
    # Use .venv as requested by user
    python -m venv .venv
    source .venv/bin/activate  # On Windows use `.venv\Scripts\activate`
    
  3. Install the package in editable mode, including development dependencies (for testing):
    # Use the specific python from your virtual env if 'pip' isn't found directly
    .venv/bin/python -m pip install -e ".[dev]"
    # Or if 'pip' is correctly on PATH for the venv:
    # pip install -e ".[dev]"
    
    Note: This installs the package such that changes to the source code are immediately reflected without reinstalling. Including [dev] installs packages needed for running tests, like pytest and respx.

Configuration

The server requires the following configuration values:

  • SpaceBridge API URL: The base URL for your SpaceBridge API instance (e.g., https://your-spacebridge.com/api/v1).
  • SpaceBridge API Key: Your API key for authenticating with SpaceBridge.
  • OpenAI API Key: Your API key for OpenAI, used by the create_issue tool for duplicate checking.

These values, along with organization/project context, can be provided in multiple ways. The server determines the final values based on the following order of precedence (highest first):

  1. Command-line Arguments: Pass arguments when running the server. These override all other methods.

    spacebridge-mcp-server \
      --spacebridge-api-url "YOUR_URL" \
      --spacebridge-api-key "YOUR_SB_KEY" \
      --openai-api-key "YOUR_OPENAI_KEY" \
      --org-name "YOUR_ORG" \        # Explicit Org Name
      --project-name "YOUR_PROJECT"  # Explicit Project Name
      # --project-dir "/path/to/your/project" # Optional: Specify dir for Git detection
    

    (Use spacebridge-mcp-server --help to see all available arguments.)

  2. Environment Variables: Set standard environment variables. These override .env files and Git detection.

    export SPACEBRIDGE_API_URL="YOUR_URL"
    export SPACEBRIDGE_API_KEY="YOUR_SB_KEY"
    export OPENAI_API_KEY="YOUR_OPENAI_KEY"
    export SPACEBRIDGE_ORG_NAME="YOUR_ORG"        # Explicit Org Name
    export SPACEBRIDGE_PROJECT_NAME="YOUR_PROJECT"  # Explicit Project Name
    # Then run:
    spacebridge-mcp-server
    
  3. .env File: Create a file named .env in the directory where you run the server. Environment variables and command-line arguments override values in this file.

    # .env file content
    SPACEBRIDGE_API_URL="YOUR_URL"
    SPACEBRIDGE_API_KEY="YOUR_SB_KEY"
    OPENAI_API_KEY="YOUR_OPENAI_KEY"
    SPACEBRIDGE_ORG_NAME="YOUR_ORG"
    SPACEBRIDGE_PROJECT_NAME="YOUR_PROJECT"
    

    The server automatically loads values from this file if it exists.

  4. Git Configuration Detection: If organization and project are not set via arguments or environment variables, the server attempts to detect them from the .git/config file.

    • It first checks in the directory specified by the --project-dir argument (if provided).
    • If --project-dir is not used, it checks the current working directory where the server was started.

Context Handling Priority:

The organization and project context used for API calls is determined as follows:

  1. Startup Context: The context determined during server startup (using the precedence above: Args > Env Vars > Git Detection) is used by default.
  2. Tool Parameter Fallback: If (and only if) the server could not determine the context during startup (e.g., no explicit config provided and not running in a Git repository), the optional org_name and project_name parameters provided in a tool call (search_issues, create_issue, update_issue) will be used as a fallback.

Note on Client Configuration: When configuring MCP clients like Claude code (see "Connecting MCP Clients" section), passing credentials or context via the client's --env flags effectively sets them as environment variables for the server process (Priority 2). This is the recommended way to provide explicit context in environments where Git detection might fail (like Windsurf or Cursor).

Running the Server

Once installed and configured, you can run the server using the command defined in pyproject.toml:

spacebridge-mcp-server

The server will start listening for MCP connections via standard input/output (stdio) by default.

Connecting MCP Clients

This server uses standard input/output (stdio) for communication. You need to configure your MCP client (e.g., Claude code, Windsurf, Cursor) to launch the spacebridge-mcp-server command and pass the required environment variables.

Configuration Steps:

  1. Install: Ensure spacebridge-mcp is installed (see Installation section). The spacebridge-mcp-server command should be available in your environment's path (e.g., inside your virtual environment's bin directory if installed from source, or globally if installed via pip install spacebridge-mcp).
  2. Find Server Path: Determine the full path to the spacebridge-mcp-server executable. If you installed in a virtual environment .venv, it might be /path/to/your/project/.venv/bin/spacebridge-mcp-server. If installed globally, you can often find it with which spacebridge-mcp-server (Linux/macOS) or where spacebridge-mcp-server (Windows).
  3. Add Server to Client: Use your MCP client's command for adding a new server.

Example using claude mcp add (Claude code):

claude mcp add spacebridge \
  /full/path/to/your/spacebridge-mcp-server \
  --scope user \
  --env SPACEBRIDGE_API_URL="https://your-spacebridge.com/api" \
  --env SPACEBRIDGE_API_KEY="your-spacebridge-api-key" \
  --env OPENAI_API_KEY="your-openai-api-key" \
  --env SPACEBRIDGE_ORG_NAME="your-explicit-org" \      # Add this if needed
  --env SPACEBRIDGE_PROJECT_NAME="your-explicit-project" # Add this if needed
  • Replace /full/path/to/your/spacebridge-mcp-server with the actual path found in step 2.
  • Replace the placeholder API URL and keys with your actual credentials.
  • --scope user makes the server available across all your projects in Claude code. Use --scope project to limit it to the current project.

Other Clients (Windsurf, Cursor, etc.):

Refer to the specific documentation for your client. The general principle is the same: provide a name for the server and the command to execute it, ensuring the necessary environment variables (SPACEBRIDGE_API_URL, SPACEBRIDGE_API_KEY, OPENAI_API_KEY, and optionally SPACEBRIDGE_ORG_NAME, SPACEBRIDGE_PROJECT_NAME) are passed to the command's environment. Some clients might have dedicated fields for environment variables, while others might require a wrapper script. Passing SPACEBRIDGE_ORG_NAME and SPACEBRIDGE_PROJECT_NAME is recommended for clients where the server's working directory might not match the actual project directory (e.g., Windsurf, Cursor).

Usage Tips & Agentic Workflows

  • Automated Commit Messages: Configure your AI tool (e.g., via custom instructions or rules in Claude code, Windsurf, Cursor) to automatically reference relevant issue IDs when generating commit messages.
    • Example Rule/Instruction: "When generating a commit message, always ask the SpaceBridge-MCP tool to find or create an issue related to the changes and include the resulting issue ID (e.g., SB-123) in the commit message footer."
    • The AI can then use the search_issues or create_issue tool via this MCP server. If an issue exists, it gets the ID; if not, create_issue makes one and returns the new ID.
  • Context Augmentation: When asking your AI assistant to work on a feature or bug, provide the SpaceBridge issue ID. The assistant can then use the get_issue_by_id resource via this MCP server to fetch the full context (description, comments, status) directly from your tracker, leading to more informed code generation or analysis.
  • Quick Issue Creation: Simply ask your assistant "Create an issue about [brief description]" while coding. The create_issue tool will handle the similarity search and creation process.

Development

Running Tests

  1. Ensure you have installed the development dependencies:
    .venv/bin/python -m pip install -e ".[dev]"
    
  2. Run pytest from the project root directory:
    .venv/bin/python -m pytest -vvv
    

Contributing

(Contribution guidelines - TODO)

License

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

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

spacebridge_mcp-0.2.2.tar.gz (30.5 kB view details)

Uploaded Source

Built Distribution

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

spacebridge_mcp-0.2.2-py3-none-any.whl (19.7 kB view details)

Uploaded Python 3

File details

Details for the file spacebridge_mcp-0.2.2.tar.gz.

File metadata

  • Download URL: spacebridge_mcp-0.2.2.tar.gz
  • Upload date:
  • Size: 30.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.2

File hashes

Hashes for spacebridge_mcp-0.2.2.tar.gz
Algorithm Hash digest
SHA256 436f43e6f15bbeddcb62322089eb081044946491edd6b2df41438c6b317a2bc8
MD5 196866313d754fd01de66f750244b70c
BLAKE2b-256 2632c8090350b71d8c1551705c75eee0503006fcda9ab6da0b717e3c6738a0c7

See more details on using hashes here.

File details

Details for the file spacebridge_mcp-0.2.2-py3-none-any.whl.

File metadata

File hashes

Hashes for spacebridge_mcp-0.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 cbe6a88399eaf80424b3c6aa54ec1382dce7621a423c4be68a8248db069bb99c
MD5 1511f8f8eea56b838cc4c4204146acaf
BLAKE2b-256 29f573bc9b3c13b4cb899235278fb320262bbaa97a84fb2a7e6777cfcbe61892

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