Skip to main content
Glama
Kustode-ce

Medical Billing MCP

by Kustode-ce

🏥 Medical Billing MCP

Open-source billing knowledge for AI assistants

License: MIT MCP Docker PRs Welcome


The Problem: A billing staff member gets a denial code. They Google it, read 5 articles, call the payer, wait on hold for 45 minutes, and maybe get an answer. Cost: 30-60 minutes per denial.

The Solution: Ask an AI assistant. Get instant answers with resolution steps. Cost: 2 minutes.


What Is This?

An MCP (Model Context Protocol) server that gives AI assistants like Claude access to medical billing knowledge:

Tool

What It Does

lookup_icd10

Look up diagnosis codes

lookup_cpt

Look up procedure codes

lookup_modifier

Understand when to use modifiers (25, 59, etc.)

lookup_denial

Understand denial codes + how to fix them

lookup_payer

Get payer-specific rules (timely filing, etc.)

lookup_bundling

Check if codes are bundled together

This is a knowledge layer. You bring your own payer connectivity (Stedi, Availity, Change Healthcare, etc.).


Related MCP server: Verity MCP Server

Quick Start

# Clone the repo
git clone https://github.com/Kustode-ce/medical-billing-mcp.git
cd medical-billing-mcp

# Run with Docker
docker compose up -d

# Test it
docker compose exec mcp python -m medical_billing_mcp --test

Option 2: Local Install

# Clone and install
git clone https://github.com/Kustode-ce/medical-billing-mcp.git
cd medical-billing-mcp
pip install -e .

# Run the server
python -m medical_billing_mcp

Configure Claude Desktop

Add to your claude_desktop_config.json:

{
  "mcpServers": {
    "medical-billing": {
      "command": "python",
      "args": ["-m", "medical_billing_mcp"]
    }
  }
}

Config locations:

  • macOS: ~/Library/Application Support/Claude/claude_desktop_config.json

  • Windows: %APPDATA%\Claude\claude_desktop_config.json

  • Linux: ~/.config/Claude/claude_desktop_config.json

Restart Claude Desktop.


Usage Examples

Once installed, ask Claude questions like:

Understanding Codes

"What does ICD-10 code E11.9 mean?"

"What's CPT code 99214 and what documentation do I need?"

"When should I use modifier 25?"

Resolving Denials

"I got denial code CO-50. What does it mean and how do I fix it?"

"My claim was denied for 'not medically necessary'. What are the resolution steps?"

Payer Rules

"What's Medicare's timely filing limit?"

"What are Blue Cross MA's known billing issues?"

Bundling

"Are CPT codes 99213 and 36415 bundled?"

See docs/examples/ for sample conversations.


Architecture

┌─────────────────────────────────────────────────────────────────┐
│                    AI ASSISTANT (Claude)                         │
└─────────────────────────────────────────────────────────────────┘
                              │
                              │ MCP Protocol
                              ▼
┌─────────────────────────────────────────────────────────────────┐
│                    MEDICAL BILLING MCP                           │
│                                                                  │
│  ┌──────────────────────────────────────────────────────────┐  │
│  │                      server.py                            │  │
│  │            (Tool definitions + routing)                   │  │
│  └──────────────────────────────────────────────────────────┘  │
│                              │                                   │
│  ┌──────────────────────────────────────────────────────────┐  │
│  │                     handlers.py                           │  │
│  │              (Lookup functions)                           │  │
│  └──────────────────────────────────────────────────────────┘  │
│                              │                                   │
│  ┌──────────────────────────────────────────────────────────┐  │
│  │                       data/                               │  │
│  │                                                           │  │
│  │   icd10.json   cpt.json   modifiers.json                 │  │
│  │   denials.json   payers.json   bundling.json             │  │
│  │                                                           │  │
│  │            [Community contributes here]                   │  │
│  └──────────────────────────────────────────────────────────┘  │
└─────────────────────────────────────────────────────────────────┘

See ARCHITECTURE.md for detailed design documentation.


What This Is NOT

Not In Scope

Why

You Already Have

Claim submission

Not our job

Stedi, Availity

Eligibility checks

Real-time payer data

Stedi, payer portals

Prior auth submission

Payer integration

Cohere, eviCore

EOB/ERA parsing

Clearinghouse function

Stedi, clearinghouse

PHI storage

Security/compliance

Your EHR/PMS

We provide knowledge. You provide connectivity.


Data Sources

All data is from public sources:

Data

Source

ICD-10 codes

CMS

CPT descriptions

AMA (limited - full requires license)

HCPCS codes

CMS

Denial codes (CARC/RARC)

X12 / Washington Publishing

Payer rules

Public payer manuals


Contributing

We welcome contributions! The easiest way to help:

Add Payer Rules

Know a payer's quirks? Edit data/payers.json:

{
  "bcbs_tx": {
    "name": "Blue Cross Blue Shield Texas",
    "timely_filing_days": 95,
    "known_issues": ["Requires modifier 25 documentation"]
  }
}

Add Denial Resolution Steps

Fixed a tricky denial? Share how in data/denials.json:

{
  "CO-151": {
    "description": "Service not covered",
    "resolution_steps": [
      "Check if service requires prior auth",
      "Verify correct place of service code",
      "Appeal with medical necessity documentation"
    ]
  }
}

See CONTRIBUTING.md for full guidelines.


Project Structure

medical-billing-mcp/
├── src/medical_billing_mcp/
│   ├── __init__.py
│   ├── __main__.py
│   ├── server.py          # MCP server
│   ├── handlers.py        # Lookup functions
│   └── data/              # JSON knowledge base
│       ├── icd10.json
│       ├── cpt.json
│       ├── modifiers.json
│       ├── denials.json
│       ├── payers.json
│       └── bundling.json
├── tests/
├── docs/
│   ├── diagrams/          # Architecture diagrams
│   ├── api/               # API documentation
│   └── examples/          # Usage examples
├── docker/
│   ├── Dockerfile
│   └── docker-compose.yml
├── ARCHITECTURE.md
├── CONTRIBUTING.md
├── LICENSE
└── README.md

License

MIT License - see LICENSE

Note: CPT codes are copyrighted by the AMA. This tool provides limited descriptions for educational purposes. For full CPT data, obtain an AMA license.


Support


Made for the healthcare community ❤️

Because providers should spend time with patients, not fighting insurance companies.

Install Server
A
license - permissive license
A
quality
C
maintenance

Maintenance

Maintainers
Response time
Release cycle
1Releases (12mo)
Commit activity

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/Kustode-ce/medical-billing-mcp'

If you have feedback or need assistance with the MCP directory API, please join our Discord server