Skip to main content

MCP server for ARRL Logbook of The World — QSO query, QSL status, DXCC credit

Project description

lotw-mcp

MCP server for ARRL Logbook of The World (LoTW) — query confirmations, uploaded QSOs, DXCC credits, and user activity through any MCP-compatible AI assistant.

Part of the qso-graph project. Read-only — uploads require TQSL digital signatures and are out of scope.

Install

pip install lotw-mcp

Tools

Tool Auth Description
lotw_confirmations Yes Query confirmed QSLs with band/mode/call/date filters
lotw_qsos Yes Query all uploaded QSOs (confirmed and unconfirmed)
lotw_dxcc_credits Yes DXCC award credits from LoTW confirmations
lotw_user_activity No Check if a callsign uses LoTW and when they last uploaded

Quick Start

1. Set up credentials

lotw-mcp uses adif-mcp personas for credential management:

pip install adif-mcp

adif-mcp persona create ki7mt --callsign KI7MT
adif-mcp persona provider ki7mt lotw --username KI7MT
adif-mcp persona secret ki7mt lotw

Note: The LoTW login is usually your callsign but not always. Pre-Sept 2019 accounts may require lowercase passwords. Avoid special characters in passwords.

2. Configure your MCP client

Claude Desktop

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

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

Claude Code

Add to .claude/settings.json:

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

ChatGPT Desktop

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

Cursor

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

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

VS Code / GitHub Copilot

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

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

Gemini CLI

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

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

3. Ask questions

"How many LoTW confirmations did I get this month?"

"Show me all unconfirmed 20m FT8 QSOs uploaded to LoTW in the last 90 days"

"What DXCC credits do I have on 40m CW?"

"Does JA1ABC use LoTW? When did they last upload?"

Public Tool

lotw_user_activity works without any credentials. It uses the public LoTW user activity CSV, cached locally for 7 days.

Testing Without Credentials

Set the mock environment variable:

LOTW_MCP_MOCK=1 lotw-mcp

Performance Notes

LoTW can be slow (30-60s for large queries). lotw-mcp uses 120s timeouts. Use date filters (since, start_date) to limit result sets.

MCP Inspector

lotw-mcp --transport streamable-http --port 8004

Development

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

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

lotw_mcp-0.1.0.tar.gz (7.8 kB view details)

Uploaded Source

Built Distribution

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

lotw_mcp-0.1.0-py3-none-any.whl (10.1 kB view details)

Uploaded Python 3

File details

Details for the file lotw_mcp-0.1.0.tar.gz.

File metadata

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

File hashes

Hashes for lotw_mcp-0.1.0.tar.gz
Algorithm Hash digest
SHA256 4a151a8a420626fa095c6b60397d3ecece1e1998a590f311e6f97a66ac92aab3
MD5 bbf446a0c248a563ffb037d29f904f73
BLAKE2b-256 10ff63ee6d40e503f7419561ff6803e9073451c5a0abb2184b62e2403e5ddbad

See more details on using hashes here.

Provenance

The following attestation bundles were made for lotw_mcp-0.1.0.tar.gz:

Publisher: publish.yml on qso-graph/lotw-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 lotw_mcp-0.1.0-py3-none-any.whl.

File metadata

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

File hashes

Hashes for lotw_mcp-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 6c89dfe1b9d84737ec1023268f66091aeb46babe6cc8c37b0fedfb78ffd79662
MD5 0c16c759eac5e7920087680152ee271c
BLAKE2b-256 db24f57c9ea3b31459af440058d278ff3f77aa6d27e12ff78f94e35a1e4ae008

See more details on using hashes here.

Provenance

The following attestation bundles were made for lotw_mcp-0.1.0-py3-none-any.whl:

Publisher: publish.yml on qso-graph/lotw-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