Skip to main content

MCP server for QRZ.com — callsign lookup, DXCC resolution, logbook queries

Project description

qrz-mcp

MCP server for QRZ.com — callsign lookups, DXCC entity resolution, and logbook queries through any MCP-compatible AI assistant.

Part of the qso-graph project. Uses qso-graph-auth for credential management.

Install

pip install qrz-mcp

Tools

Tool API Auth Description
qrz_lookup XML Session key Callsign lookup (name, grid, DXCC, license class, QSL info, image)
qrz_dxcc XML Session key DXCC entity resolution from callsign or entity code
qrz_logbook_status Logbook API key Logbook stats (QSO count, DXCC total, date range)
qrz_logbook_fetch Logbook API key Query QSOs with filters and transparent pagination
qrz_download Logbook API key Download full logbook as ADIF
get_version_info None Service version + upstream QRZ API version (fleet identity attestation)

Quick Start

1. Set up credentials

qrz-mcp uses qso-graph-auth personas for credential management. QRZ has two separate auth mechanisms — set up whichever you need:

# Install qso-graph-auth if you haven't
pip install qso-graph-auth

# Create a persona
qso-auth persona create ki7mt --callsign KI7MT

# Enable QRZ provider
qso-auth persona provider ki7mt qrz --username KI7MT

# Set password (for XML API: qrz_lookup, qrz_dxcc)
qso-auth persona secret ki7mt qrz

# Set API key (for Logbook API: qrz_logbook_status, qrz_logbook_fetch)
qso-auth creds set --persona ki7mt --provider qrz --api-key YOUR_API_KEY

XML API (callsign lookup, DXCC) requires a QRZ XML Subscription ($35.95/yr). Free tier returns name and address only.

Logbook API requires an API key from QRZ Settings > API.

2. Configure your MCP client

qrz-mcp works with any MCP-compatible client. Add the server config and restart — tools appear automatically.

Claude Desktop

Add to claude_desktop_config.json (~/Library/Application Support/Claude/ on macOS, %APPDATA%\Claude\ on Windows):

{
  "mcpServers": {
    "qrz": {
      "command": "qrz-mcp"
    }
  }
}

Claude Code

Add to .claude/settings.json:

{
  "mcpServers": {
    "qrz": {
      "command": "qrz-mcp"
    }
  }
}

ChatGPT Desktop

ChatGPT supports MCP via the OpenAI Agents SDK. Add under Settings > Apps & Connectors, or configure in your agent definition:

{
  "mcpServers": {
    "qrz": {
      "command": "qrz-mcp"
    }
  }
}

Cursor

Add to .cursor/mcp.json (project-level) or ~/.cursor/mcp.json (global):

{
  "mcpServers": {
    "qrz": {
      "command": "qrz-mcp"
    }
  }
}

VS Code / GitHub Copilot

Add to .vscode/mcp.json in your workspace:

{
  "servers": {
    "qrz": {
      "command": "qrz-mcp"
    }
  }
}

Gemini CLI

Add to ~/.gemini/settings.json (global) or .gemini/settings.json (project):

{
  "mcpServers": {
    "qrz": {
      "command": "qrz-mcp"
    }
  }
}

3. Ask questions

"Look up W1AW on QRZ — what's their grid and license class?"

"What DXCC entity is VP8PJ?"

"How many QSOs do I have in my QRZ logbook?"

"Show me all 20m FT8 QSOs from my QRZ logbook this year"

Rate Limiting

QRZ enforces undocumented rate limits that can trigger 24-hour IP bans. qrz-mcp protects you:

  • 500ms minimum delay between all API calls
  • Token bucket: 35 requests/minute
  • 60s freeze on authentication failures
  • 3600s freeze on connection refused (IP ban detection)
  • In-memory response cache (5 min for callsigns, 1 hour for DXCC)

Testing Without Credentials

Set the mock environment variable to test all 4 tools without QRZ credentials:

QRZ_MCP_MOCK=1 qrz-mcp

MCP Inspector

qrz-mcp --transport streamable-http --port 8002

Then open the MCP Inspector at http://localhost:8002.

Development

git clone https://github.com/qso-graph/qrz-mcp.git
cd qrz-mcp
pip install -e .

QRZ Subscription Tiers

Feature Free XML Data ($35.95/yr)
Callsign lookups/day 100 Unlimited
Fields returned Name + address only All (grid, lat/lon, DXCC, class, QSL, image)
Logbook API No Yes
DXCC lookup No Yes

License

GPL-3.0-or-later

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

qrz_mcp-0.3.3.tar.gz (16.7 kB view details)

Uploaded Source

Built Distribution

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

qrz_mcp-0.3.3-py3-none-any.whl (15.3 kB view details)

Uploaded Python 3

File details

Details for the file qrz_mcp-0.3.3.tar.gz.

File metadata

  • Download URL: qrz_mcp-0.3.3.tar.gz
  • Upload date:
  • Size: 16.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for qrz_mcp-0.3.3.tar.gz
Algorithm Hash digest
SHA256 bb23df83a0f63048f96b7d11cc3b3035e415c938020a8430aa7eac0cf4994090
MD5 d373d79dbea974aaa084fadcbcc1c9ea
BLAKE2b-256 8718aeb1c11a1ca8dd95e716b9b1161e9c392ce8681a7f5c9400983cdda5bf9d

See more details on using hashes here.

Provenance

The following attestation bundles were made for qrz_mcp-0.3.3.tar.gz:

Publisher: publish.yml on qso-graph/qrz-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file qrz_mcp-0.3.3-py3-none-any.whl.

File metadata

  • Download URL: qrz_mcp-0.3.3-py3-none-any.whl
  • Upload date:
  • Size: 15.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for qrz_mcp-0.3.3-py3-none-any.whl
Algorithm Hash digest
SHA256 d9fae54135c8acde06d829a097cc533e41ed059680d0f4d7cb539c5f522b80a5
MD5 c155078daf27a971cd80bd1d84f16908
BLAKE2b-256 68aa6d46b1d21a075931906e101421bf66e8a4f69008a849cff3ce0c1519b87a

See more details on using hashes here.

Provenance

The following attestation bundles were made for qrz_mcp-0.3.3-py3-none-any.whl:

Publisher: publish.yml on qso-graph/qrz-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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