Skip to main content

ADIF MCP core engine with plugin support (LoTW, eQSL, QRZ, Clublog)

Project description

adif-mcp

Core Model Context Protocol (MCP) service for Amateur Radio Logging, per ADIF 3.1.5 specification

Pretty Code • Pretty Output • Iterative Docs - A simple mantra: keep the code clean, the output clear, and the docs evolving.


Resources

Made with Python License: MIT

Core Project Health

ADIF GitHub release GitHub tag CI Docs pre-commit Conventional Commits SSL Certificate Expiry Check

MCP / API Readiness

MCP API Docs JSON Schema Manifest Valid

Compliance and Program Registry

ADIF 3.1.5 Program ID


Project Ethos

ADIF-MCP is a community-driven effort. It is not intended to replace or compete with existing ADIF libraries, utilities, or logging applications. Instead, it provides a common foundation that others can build upon.

  • Interoperability — a schema-driven, spec-compliant core that makes it easier for tools, logs, and services to talk to each other.
  • Extensibility — a plugin and integration framework for services like LoTW, eQSL, QRZ, and future platforms.
  • Collaboration — designed to complement, not fragment, the ecosystem of ADIF tools already enjoyed by the ham community.
  • Future-facing — introduces safe, typed access to ADIF data in contexts such as AI agents and MCP integrations, opening doors for innovation while preserving compatibility.

Our goal is simple: support and enhance the Amateur Radio logging ecosystem while keeping the project open, transparent, and aligned with the spirit of the hobby.


ADIF-MCP Engines

This package defines the ADIF MCP core engine, with plugins for:

  • LoTW (adif-mcp-lotw)
  • eQSL (adif-mcp-eqsl)
  • qrz (adif-mcp-qrz)
  • clublog (adif-mcp-clublog)

Performs these tasks

  • Validation & normalization of ADIF records
  • Unified schema for consistent QSO storage and exchange
  • MCP-ready tools for safe AI-agent access
  • Foundation for service adapters (e.g., LoTW, eQSL, Qrx, Clublog)

🔑 Takeaway: MCP doesn’t replace LoTW, eQSL, Clublog, Qrz, or award / logging program(s). Instead, it gives operators visibility and accessibility into their award progress, across sponsors, without them needing to export, filter, or code.


Why ADIF-MCP Matters

Unlike existing ADIF editors and one-off utilities, ADIF-MCP is a shared protocol engine for the Amateur Radio community:

  • Spec-compliant & typed — ADIF fields are validated against the official standard.
  • Extensible — integrations (LoTW, eQSL, QRZ, Clublog, and other logging apps) plug into a common base.
  • AI-ready — exposes safe, typed tools to AI agents via the Model Context Protocol.
  • Foundation, not silo — one engine many apps can trust, instead of everyone re-implementing ADIF parsing.

👉 ADIF-MCP turns ADIF from a static file format into a living protocol interface.


Next Steps

  • Build adif-mcp-lotw and adif-mcp-eqsl adapters
  • Expose MCP tools for validation, award tracking, and service sync
  • Support cross-logger interoperability with AI-driven agents

Compliance & Provenance

ADIF-MCP and its plugins follow the ADIF Specification (currently 3.1.5) and use registered Program IDs to identify all exports:

  • ADIF-MCP — Core engine
  • ADIF-MCP-LOTW — Plugin for ARRL Logbook of The World
  • ADIF-MCP-EQSL — Plugin for eQSL.cc
  • ADIF-MCP-QRZ — Plugin for Qrz.com
  • ADIF-MCP-CLUBLOG — Plugin for Clublog.com
  • ADIF-MCP-NEXT — Whatever else operators want integrated

To ensure transparency and auditability, the project also uses APP_ fields for provenance when augmenting records. Examples include:

  • APP_ADIF-MCP_OP → operation performed (normalize, validate, merge)
  • APP_ADIF-MCP-LOTW_ACTION → LoTW plugin operation
  • APP_ADIF-MCP-EQSL_TIME → timestamp of eQSL merge

See the Program ID & APP_ Field Policy for full details.

License

MIT — open and free for amateur radio use.

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

adif_mcp-0.3.12.tar.gz (54.2 kB view details)

Uploaded Source

Built Distribution

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

adif_mcp-0.3.12-py3-none-any.whl (68.2 kB view details)

Uploaded Python 3

File details

Details for the file adif_mcp-0.3.12.tar.gz.

File metadata

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

File hashes

Hashes for adif_mcp-0.3.12.tar.gz
Algorithm Hash digest
SHA256 b24a44c40d18edd5f37557cb18ce557855a2bd5e1b34ba671e60b8b0801db077
MD5 a301044a1b60dabcfb9af5b3912d6af9
BLAKE2b-256 70c6253a16040fb2ff372d0c39f3a41ca41815fc4d1df81d02af098b540a6190

See more details on using hashes here.

Provenance

The following attestation bundles were made for adif_mcp-0.3.12.tar.gz:

Publisher: release.yml on KI7MT/adif-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 adif_mcp-0.3.12-py3-none-any.whl.

File metadata

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

File hashes

Hashes for adif_mcp-0.3.12-py3-none-any.whl
Algorithm Hash digest
SHA256 fa31dd56628ad8a25d20925b7eb3b1a1444e39c49d0d743a7fa4428dabed4f3d
MD5 3c1be042d25e122a55ad957d87cce1bf
BLAKE2b-256 df71f00a40441bcc3f99f9232e304e1da955e5abcd61656ab1680220c7e6c67d

See more details on using hashes here.

Provenance

The following attestation bundles were made for adif_mcp-0.3.12-py3-none-any.whl:

Publisher: release.yml on KI7MT/adif-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