mcp-swarmia

mcp-swarmia

Exposes the Swarmia Export API as tools for AI assistants to query engineering metrics through natural language. It enables retrieval of DORA metrics, pull request cycle times, investment balances, and FTE effort reports.

Category
Visit Server

README

mcp-swarmia

A local Model Context Protocol (MCP) server that exposes the Swarmia Export API as tools for AI assistants such as Claude.

Once connected, Claude (or any MCP-compatible client) can query your engineering metrics—pull request cycle times, DORA metrics, investment balance, CapEx reports, and FTE effort—in natural language without you having to write a single API call.


Requirements

  • Python 3.11+
  • A Swarmia account with an API token (Settings → API tokens)
  • mcp Python package (only external dependency)

Installation

# 1. Clone or copy this directory
cd mcp-swarmia

# 2. Create and activate a virtual environment (recommended)
python -m venv .venv
source .venv/bin/activate   # Windows: .venv\Scripts\activate

# 3. Install dependencies
pip install -r requirements.txt

Configuration

Export your Swarmia API token as an environment variable:

export SWARMIA_API_TOKEN="your-token-here"

Alternatively, add it to a .env file and source it, or configure it in your MCP client settings (see below).


Running the server

python server.py

The server communicates over stdio (standard input/output), which is the transport expected by Claude Desktop and most other MCP clients. You do not need to expose any network ports.


Connecting to Claude Desktop

Add the following block to your Claude Desktop configuration file:

macOS: ~/Library/Application Support/Claude/claude_desktop_config.json Windows: %APPDATA%\Claude\claude_desktop_config.json

{
  "mcpServers": {
    "swarmia": {
      "command": "/absolute/path/to/.venv/bin/python",
      "args": ["/absolute/path/to/mcp-swarmia/server.py"],
      "env": {
        "SWARMIA_API_TOKEN": "your-token-here"
      }
    }
  }
}

Replace the paths and token with your actual values, then restart Claude Desktop.


Available tools

Tool Description Required params
get_pull_requests Team-level PR metrics (cycle time, review time, size, …)
get_dora_metrics Organisation DORA metrics (deployment frequency, lead time, CFR, MTTR)
get_investment_balance Monthly FTE investment balance by category startDate, endDate
get_capex Software capitalisation report startDate, endDate
get_capex_employees Per-employee CapEx breakdown year
get_fte Monthly engineering effort (FTE) by author month

Shared optional parameters

All time-series endpoints accept:

Parameter Description Example
timeframe Preset window last_30_days
startDate Custom start (YYYY-MM-DD) 2024-01-01
endDate Custom end (YYYY-MM-DD) 2024-03-31
timezone tz database identifier America/New_York

timeframe and startDate/endDate are mutually exclusive. Defaults to last_7_days when neither is provided.

DORA-specific parameters

Parameter Description
app Filter by deployment application name
environment Filter by deployment environment

FTE-specific parameters

Parameter Description Values
groupBy How to group effort highestLevelIssue (default), lowestLevelIssue, customField
customField Jira field ID Required when groupBy=customField

Response format

All tools return CSV text with a header row and comma delimiters, exactly as returned by the Swarmia API. No summary aggregations are added.


Example prompts

After connecting the server to Claude, try:

  • "Show me our DORA metrics for the last 30 days."
  • "What does our pull request cycle time look like for Q1 2024?"
  • "Fetch the investment balance for January 2024."
  • "Get the CapEx report for 2024."
  • "Show FTE effort for March 2024, grouped by highest-level issue."

Security note

Swarmia recommends passing tokens via the Authorization header rather than query parameters, as some proxies log query strings. This server always uses the header approach.


Troubleshooting

Problem Solution
SWARMIA_API_TOKEN is not set Export the env var or add it to your MCP client config
HTTP 401 Token is invalid or expired — regenerate it in Swarmia
HTTP 400 Check that required parameters (e.g. startDate/endDate) are provided and in the correct format
Server not appearing in Claude Verify the absolute paths in claude_desktop_config.json and restart Claude Desktop

Recommended Servers

playwright-mcp

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

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.

Official
Featured
TypeScript
Kagi MCP Server

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.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

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.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured