MCP server for eQSL.cc — inbox download, QSO verification, AG status checks
Project description
eqsl-mcp
MCP server for eQSL.cc — download incoming eQSLs, verify QSOs, check AG status, and query upload history through any MCP-compatible AI assistant.
Part of the qso-graph project. Depends on adif-mcp for persona and credential management.
Install
pip install eqsl-mcp
Tools
| Tool | Auth | Description |
|---|---|---|
eqsl_inbox |
Yes | Download incoming eQSLs with date/confirmation filters |
eqsl_verify |
No | Check if a specific QSO exists in eQSL |
eqsl_ag_check |
No | Check if a callsign has AG (Authenticity Guaranteed) status |
eqsl_last_upload |
No | When did a persona last upload to eQSL |
Quick Start
1. Set up credentials
eqsl-mcp uses adif-mcp personas for credential management:
# Install adif-mcp if you haven't
pip install adif-mcp
# Create a persona and add eQSL credentials
adif-mcp persona create ki7mt --callsign KI7MT
adif-mcp persona provider ki7mt eqsl --username KI7MT
adif-mcp persona secret ki7mt eqsl
2. Configure your MCP client
eqsl-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": {
"eqsl": {
"command": "eqsl-mcp"
}
}
}
Claude Code
Add to .claude/settings.json:
{
"mcpServers": {
"eqsl": {
"command": "eqsl-mcp"
}
}
}
ChatGPT Desktop
ChatGPT supports MCP via the OpenAI Agents SDK. Add under Settings > Apps & Connectors, or configure in your agent definition:
{
"mcpServers": {
"eqsl": {
"command": "eqsl-mcp"
}
}
}
Cursor
Add to .cursor/mcp.json (project-level) or ~/.cursor/mcp.json (global):
{
"mcpServers": {
"eqsl": {
"command": "eqsl-mcp"
}
}
}
VS Code / GitHub Copilot
Add to .vscode/mcp.json in your workspace:
{
"servers": {
"eqsl": {
"command": "eqsl-mcp"
}
}
}
Gemini CLI
Add to ~/.gemini/settings.json (global) or .gemini/settings.json (project):
{
"mcpServers": {
"eqsl": {
"command": "eqsl-mcp"
}
}
}
3. Ask questions
"Show me all eQSLs received this week"
"How many unconfirmed eQSLs do I have on 20m FT8?"
"Does W1AW have AG status on eQSL?"
"Verify my QSO with KI7MT on 20m on March 1, 2026"
Testing Without Credentials
The two public tools (eqsl_verify and eqsl_ag_check) work without any credentials.
For eqsl_inbox testing, set the mock environment variable:
EQSL_MCP_MOCK=1 eqsl-mcp
Or point to a local ADIF file:
EQSL_MCP_MOCK=1 EQSL_MCP_ADIF=/path/to/test.adi eqsl-mcp
MCP Inspector
eqsl-mcp --transport streamable-http --port 8001
Then open the MCP Inspector at http://localhost:8001.
Development
git clone https://github.com/qso-graph/eqsl-mcp.git
cd eqsl-mcp
pip install -e .
Date Formats
eQSL uses different date formats across endpoints. eqsl-mcp normalizes everything — you always use YYYY-MM-DD:
| You provide | eqsl-mcp sends | Endpoint |
|---|---|---|
2026-03-01 |
202603010000 |
DownloadInBox (RcvdSince) |
2026-03-01 |
03/01/2026 |
VerifyQSO (QSODate) |
Mode Matching
eQSL requires exact mode matching. SSB won't match USB/LSB. PSK won't match PSK31. Use the exact mode logged by the other station.
License
GPL-3.0-or-later
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file eqsl_mcp-0.2.1.tar.gz.
File metadata
- Download URL: eqsl_mcp-0.2.1.tar.gz
- Upload date:
- Size: 10.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
01223d405330bd5e11a2cac2766fe764b441758089d660c56f94431722cdab5a
|
|
| MD5 |
0b010ca3b5c9498221982cce88917a72
|
|
| BLAKE2b-256 |
65a1d98f4fa0a0f3fe8c2dea42e4a895b9f8799e8dc11f58d0086c1644e10776
|
Provenance
The following attestation bundles were made for eqsl_mcp-0.2.1.tar.gz:
Publisher:
publish.yml on qso-graph/eqsl-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
eqsl_mcp-0.2.1.tar.gz -
Subject digest:
01223d405330bd5e11a2cac2766fe764b441758089d660c56f94431722cdab5a - Sigstore transparency entry: 1052718026
- Sigstore integration time:
-
Permalink:
qso-graph/eqsl-mcp@b5a4c349021ddbf75a8743dba3c91f2ac14769b3 -
Branch / Tag:
refs/tags/v0.2.1 - Owner: https://github.com/qso-graph
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@b5a4c349021ddbf75a8743dba3c91f2ac14769b3 -
Trigger Event:
push
-
Statement type:
File details
Details for the file eqsl_mcp-0.2.1-py3-none-any.whl.
File metadata
- Download URL: eqsl_mcp-0.2.1-py3-none-any.whl
- Upload date:
- Size: 11.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6525a7a3f959c72abf28b9c5b0a68b2788ae5bb95442b927df171af31f6476f4
|
|
| MD5 |
b272f9e3fe4ef2f53bd2b3651d34536c
|
|
| BLAKE2b-256 |
042c6a0bcb7f91c311df23c2e55ee572ab23f5f368d334095812fcd25c51265a
|
Provenance
The following attestation bundles were made for eqsl_mcp-0.2.1-py3-none-any.whl:
Publisher:
publish.yml on qso-graph/eqsl-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
eqsl_mcp-0.2.1-py3-none-any.whl -
Subject digest:
6525a7a3f959c72abf28b9c5b0a68b2788ae5bb95442b927df171af31f6476f4 - Sigstore transparency entry: 1052718201
- Sigstore integration time:
-
Permalink:
qso-graph/eqsl-mcp@b5a4c349021ddbf75a8743dba3c91f2ac14769b3 -
Branch / Tag:
refs/tags/v0.2.1 - Owner: https://github.com/qso-graph
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@b5a4c349021ddbf75a8743dba3c91f2ac14769b3 -
Trigger Event:
push
-
Statement type: