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

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.2.tar.gz (15.0 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.2-py3-none-any.whl (14.6 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for qrz_mcp-0.3.2.tar.gz
Algorithm Hash digest
SHA256 ed6bc5a8b2b8dad48af97a3b660e289648e981155d9c80927ed276d51133fa7f
MD5 358a1e7fb140239c564f35d960b95cd1
BLAKE2b-256 5dde1ed67dc129730ca77edb2d5bbb6692a9783959ce8e00dd9e6e0d54c56c23

See more details on using hashes here.

Provenance

The following attestation bundles were made for qrz_mcp-0.3.2.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.2-py3-none-any.whl.

File metadata

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

File hashes

Hashes for qrz_mcp-0.3.2-py3-none-any.whl
Algorithm Hash digest
SHA256 7269f034bc27f81db8773f4eef3d364b57b944b7f674579b2bfe33cbb5d42b47
MD5 32c6c111f3fc9dfd6c08d47b8042e79e
BLAKE2b-256 22f5372ef16e74ddc74901f62298056facb72fdcc2f3902384404295bd93911d

See more details on using hashes here.

Provenance

The following attestation bundles were made for qrz_mcp-0.3.2-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