DCI MCP Server
MCP server for DCI API enabling AI models to extract and analyze DCI jobs, components, and topics, with integrations for Google Drive, Jira, GitHub, and Red Hat support cases.
README
DCI MCP Server
This project provides a Model Context Protocol (MCP) server adapted for the DCI API. It allows AI models to interact with DCI for comprehensive data extraction about DCI jobs, components, topics and files.
Features
- š FastAPI: Built on a modern, fast web framework
- š¤ MCP: Implements the Model Context Protocol for AI integration
- š Comprehensive DCI API: Full access to DCI components, jobs, files, pipelines, products, teams, and topics
- š§ Smart PR Detection: Advanced PR build finder that analyzes job URLs and metadata
- š DCI Integration: Native DCI API support with authentication
- š Easy Configuration: Support for .env files for simple setup
- ā Code Quality: Comprehensive pre-commit checks and linting
- š Google Drive Integration: Convert DCI reports to Google Docs with rich formatting
- š« Jira Integration: Collect comprehensive ticket data from Jira with comments and changelog
- š GitHub Integration: Search issues and pull requests using GitHub's powerful search API
- š“ Red Hat Support Case Integration: Access Red Hat support case data from the Customer Portal
Installation
# Clone the repository
git clone https://github.com/redhat-community-ai-tools/dci-mcp-server
cd dci-mcp-server
# Install dependencies
uv sync
# Activate virtual environment
source .venv/bin/activate
Configuration
The server supports multiple ways to configure DCI authentication:
Copy the example file and customize it:
cp env.example .env
# Edit .env with your DCI credentials
Example .env file:
# Method 1: API Key Authentication
DCI_CLIENT_ID=<client_type>/<client_id>
DCI_API_SECRET=<api_secret>
# Method 2: User ID/Password (alternative to API key)
# DCI_LOGIN=foo
# DCI_PASSWORD=bar
# Google Drive Integration (optional)
# GOOGLE_CREDENTIALS_PATH=credentials.json
# GOOGLE_TOKEN_PATH=token.json
MCP Configuration
Cursor IDE (stdio transport)
Add to your ~/.cursor/mcp.json:
{
"mcpServers": {
"dci": {
"command": "uv",
"args": ["run", "/path/to/dci-mcp-server/.venv/bin/python", "/path/to/dci-mcp-server/main.py"],
"description": "MCP server for DCI integration"
}
}
}
Claude Desktop (~/.claude.json)
{
"mcpServers": {
"dci": {
"command": "uv",
"args": ["run", "--directory", "/path/to/dci-mcp-server", "main.py"],
"env": {
"DCI_CLIENT_ID": "your-client-id",
"DCI_API_SECRET": "your-secret",
"DCI_CS_URL": "https://api.distributed-ci.io"
}
}
}
}
Claude CLI (~/.claude.json)
- close the claude cli
- include the block above in the ~/.claude.json file
- start a claude session from the /path/to/dci-mcp-server/ directory
- verify MCP is connected with /mcp
Web-based Integration (SSE transport)
For web applications or services that need HTTP-based communication:
{
"mcpServers": {
"dci": {
"url": "http://0.0.0.0:8000/sse/",
"description": "MCP server for DCI integration with direct SSE",
"env": {
"MCP_TRANSPORT": "sse"
}
}
}
}
SSE Endpoint: http://0.0.0.0:8000/sse/
Note: Make sure to start the SSE server separately with
MCP_TRANSPORT=sse uv run main.pybefore using this configuration.
Prompts
You can then use prompts to explore the DCI data.
There are also parameterized prompts defined in the MCP server:
/dci/rca <job id>conducts a Root Cause Analysis of the problem in the job. Storing the downloaded files under/tmp/dci/<job id>and generating a report at/tmp/dci/rca-<job id>.md./dci/weekly <team name/id or remoteci name/id>conducts a report for the last 7 days stored at/tmp/dci./dci/biweekly <team name/id or remoteci name/id>conducts a report for the last 14 days stored at/tmp/dci./dci/quarterly <remoteci name/id>conducts a comprehensive quarterly analysis (last 3 months) with statistics about pipelines, topics, failure rates, trends, and component usage. Uses pagination and caching to handle large datasets. Report stored at/tmp/dci/<remoteci>/quarterly/<date-range>/report.md.
Google Drive Integration
The server includes Google Drive integration to convert DCI reports and markdown content to Google Docs with rich formatting support.
Features
- š Markdown to Google Docs: Convert markdown content to properly formatted Google Docs
- š DCI Report Conversion: Specialized tools for converting DCI weekly/biweekly reports
- šØ Rich Formatting: Support for tables, code blocks, headers, lists, and links
- š OAuth2 Authentication: Secure authentication with Google Drive API
- š Folder Organization: Option to organize documents in specific Google Drive folders
Setup
To use Google Drive features, follow the Google Drive Setup Guide for detailed configuration instructions.
Quick Setup:
- Set up Google Cloud Project and enable Google Drive API
- Download OAuth2 credentials and save as
credentials.json - Initialize the service:
uv run python -c "from mcp_server.services.google_drive_service import GoogleDriveService; GoogleDriveService()" - Complete browser authentication when prompted
Usage Examples
# Convert a DCI report to Google Doc in a specific folder by name
result = await convert_dci_report_to_google_doc(
report_path="/tmp/dci/the_weekly_report_2025-09-09.md",
doc_title="The Weekly Report - September 2025",
folder_name="DCI Reports"
)
# Create a Google Doc from markdown content in a folder by ID
result = await create_google_doc_from_markdown(
markdown_content="# My Report\n\nThis is a **test** document.",
doc_title="My Custom Report",
folder_id="1BxiMVs0XRA5nFMdKvBdBZjgmUUqptlbs74OgvE2upms"
)
# Create a Google Doc from a file in a folder by name
result = await create_google_doc_from_file(
file_path="/path/to/report.md",
doc_title="My Report",
folder_name="Project Documents"
)
Jira Integration
The server includes Jira integration to collect comprehensive ticket data from Red Hat Jira, including comments and changelog information.
Features
- š« Ticket Data Collection: Retrieve comprehensive ticket information including summary, description, status, and dates
- š¬ Comments Analysis: Get up to 50 recent comments with author and timestamp information
- š Changelog Tracking: Access complete ticket history and field changes
- š JQL Search: Search tickets using Jira Query Language (JQL)
- š Project Information: Get project details and metadata
- š DCI Integration: Seamlessly extract Jira tickets from DCI job comments
- āļø Write Operations (opt-in): Create tickets, update fields, add comments, and transition status
Setup
To use Jira features, follow the Jira Setup Guide for detailed configuration instructions.
Quick Setup:
- Get your Jira API token from https://id.atlassian.com/manage-profile/security/api-tokens
- Set environment variables in your
.envfile:JIRA_API_TOKEN=your_jira_api_token_here JIRA_EMAIL=you@redhat.com JIRA_URL=https://redhat.atlassian.net # Optional: enable write operations (create/update tickets, add comments) JIRA_WRITE_ENABLED=true
Usage Examples
# Get comprehensive ticket data with comments
ticket_data = await get_jira_ticket("CILAB-1234", max_comments=10)
# Search for tickets using JQL
open_tickets = await search_jira_tickets("project = CILAB AND status = Open")
# Get project information
project_info = await get_jira_project_info("CILAB")
# Extract Jira tickets from DCI job comments
jobs_with_tickets = await search_dci_jobs("comment=~'.*CILAB.*'")
for job in jobs_with_tickets:
if job.get('comment'):
ticket_data = await get_jira_ticket(job['comment'])
GitHub Integration
The server includes GitHub integration to search for issues and pull requests and retrieve detailed information about them.
Features
- š Issue & PR Search: Search using GitHub's powerful query syntax
- š Comprehensive Data: Get detailed information including comments, labels, assignees, and more
- š Pull Request Metadata: Access PR-specific data like merge status, branch info, and file changes
- š Repository Information: Retrieve repository metadata and statistics
- š Token Authentication: Secure authentication with GitHub personal access tokens
Setup
Quick Setup:
- Get your GitHub personal access token from https://github.com/settings/tokens
- Create a new token (classic) with
reposcope (for private repos) orpublic_repo(for public repos only) - Set environment variable in your
.envfile:GITHUB_TOKEN=your_github_token_here
Red Hat Support Case Integration
The server includes Red Hat Support Case integration to retrieve case data from the Red Hat Customer Portal.
Features
- š Case Data Retrieval: Get comprehensive case information including summary, status, severity, and product details
- š¬ Comments: Access case comments and communication history
- š Linked Bugs: View Bugzilla bugs linked to the case
- š¢ Errata/Advisory Details: Retrieve errata information including CVEs, affected products, and references
- š Offline Token Authentication: Secure authentication using Red Hat API offline tokens
Setup
Quick Setup:
- Get your offline token from https://access.redhat.com/management/api
- Set environment variable in your
.envfile:OFFLINE_TOKEN=your_offline_token_here
Available Tools exposed by the MCP server
The server provides tools for interacting with DCI API components:
Component Tools
query_dci_components(query, limit, offset, sort, fields): Query components with advanced query language and pagination
Date Tools
Enabled by default. Set DATE_TOOLS_ENABLED=false to disable.
today(): Returns today's date in YYYY-MM-DD format.now(): Returns current date and time in DCI compatible format (GMT).
Job Tools
search_dci_jobs(query, sort, limit, offset, fields): Search jobs with advanced query language and pagination
File Tools
download_dci_file(job_id, file_id, output_path): Download a file to local path
Google Drive Tools
create_google_doc_from_markdown(markdown_content, doc_title, folder_id, folder_name): Create a Google Doc from markdown contentcreate_google_doc_from_file(file_path, doc_title, folder_id, folder_name): Create a Google Doc from a markdown fileconvert_dci_report_to_google_doc(report_path, doc_title, folder_id, folder_name): Convert a DCI report to Google Doclist_google_docs(query, max_results): List Google Docs in your Drive
Note: For folder placement, you can use either folder_id (exact folder ID) or folder_name (searches for folder by name). Do not use both parameters together.
Jira Tools
get_jira_ticket(ticket_key, max_comments): Get comprehensive ticket data including comments and changelogsearch_jira_tickets(jql, max_results): Search tickets using JQL (Jira Query Language)get_jira_project_info(project_key): Get project information and metadatasearch_jira_child_tickets(parent_jql, child_jql, ...): Traverse a 2-level Jira hierarchy (e.g. TELCOSTRAT ā Epics ā Stories) in a single call, returning leaf tickets with full ancestry info
Note: Jira tools require JIRA_API_TOKEN environment variable to be set.
Jira Write Tools
create_jira_ticket(project_key, summary, ...): Create a new Jira ticket with optional description, issue type, priority, labels, components, and assigneeupdate_jira_ticket(ticket_key, ...): Update ticket fields (summary, description, priority, labels, components, assignee) or transition statusadd_jira_comment(ticket_key, body): Add a comment to a ticketlist_jira_transitions(ticket_key): List available workflow transitions for a ticket
Note: Jira write tools require both JIRA_API_TOKEN and JIRA_WRITE_ENABLED=true environment variables.
GitHub Tools
search_github_issues(query, max_results): Search issues and pull requests using GitHub search query syntaxget_github_issue(repo, issue_number, max_comments): Get comprehensive issue/PR data including comments and PR-specific informationget_github_repository_info(repo): Get repository information and statisticsget_github_pr_diff(repo, pull_number, max_files): Get the diff/patch for a pull request with per-file unified diffsget_github_pr_checks(repo, pull_number): Get CI check runs and commit statuses for a pull request, including status, conclusion, and links to each CI job
Note: GitHub tools require GITHUB_TOKEN environment variable to be set.
Support Case Tools
get_support_case(case_number): Get Red Hat support case data including comments and linked Bugzilla bugsget_support_case_comments(case_number, start_date?, end_date?): Get comments for a case with optional date filteringlist_support_case_attachments(case_number): List attachment metadata for a caseget_errata(advisory_id): Get Red Hat errata/advisory details (RHSA, RHBA, RHEA)
Note: Support Case tools require OFFLINE_TOKEN environment variable to be set.
Code Quality Checks
The project includes comprehensive code quality checks:
Manual Checks
# Run all checks
bash scripts/run-checks.sh
# Or run individual checks
./.venv/bin/python -m black --check .
./.venv/bin/python -m isort --check-only .
./.venv/bin/python -m ruff check .
./.venv/bin/python -m mypy mcp_server/
./.venv/bin/python -m bandit -r mcp_server/ -c pyproject.toml
Pre-commit Hooks (Optional)
# Install pre-commit hooks
./.venv/bin/python -m pre_commit install
# Run pre-commit on all files
./.venv/bin/python -m pre_commit run --all-files
Development
Project Structure
mcp_server/
āāā config.py # Configuration and authentication
āāā main.py # Server entry point
āāā services/ # DCI API services
ā āāā dci_base_service.py
ā āāā dci_component_service.py
ā āāā dci_job_service.py
ā āāā dci_file_service.py
ā āāā dci_log_service.py
ā āāā dci_pipeline_service.py
ā āāā dci_product_service.py
ā āāā dci_team_service.py
ā āāā dci_remoteci_service.py
ā āāā dci_topic_service.py
ā āāā google_drive_service.py
ā āāā jira_service.py
ā āāā github_service.py
ā āāā support_case_service.py
āāā promps/ # Templatized prompts
ā āāā prompts.py
āāā tools/ # MCP tools
ā āāā component_tools.py
ā āāā date_tools.py
ā āāā job_tools.py
ā āāā file_tools.py
ā āāā google_drive_tools.py
ā āāā jira_tools.py
ā āāā jira_write_tools.py
ā āāā github_tools.py
ā āāā support_case_tools.py
ā āāā log_tools.py
āāā utils/ # Utility functions
āāā http_client.py
Testing
# Run all checks (format, lint, tests + evals)
bash scripts/run-checks.sh
# Run evals only
uv run pytest -m eval -v
# Run evals with a different model
EVAL_MODEL=haiku uv run pytest -m eval -v
Eval tests use claude -p to verify that Claude selects the correct MCP tools for natural language prompts. Each eval case is automatically skipped if its required credentials (DCI, Jira, GitHub, etc.) are not configured in .env.
Adding New Tools
- Create a new service in
mcp_server/services/if needed - Create a new tool file in
mcp_server/tools/ - Register the tools in
mcp_server/main.py - Update this README with documentation
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
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.
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.