MCP server for N1MM Logger+ — live contest state via UDP broadcast
Project description
n1mm-mcp
MCP server for N1MM Logger+ — live contest state via UDP broadcast.
Part of the qso-graph amateur radio MCP ecosystem.
Install
pip install n1mm-mcp
Tools (Phase 1 — 8 Composite State Views)
| Tool | Description |
|---|---|
n1mm_current_state |
Station snapshot — connection, contest, operator, radios |
n1mm_lookup |
Pre-log callsign (Contest-Copilot trigger) + current band/mode |
n1mm_contacts |
QSO log — recent contacts, edits, deletes |
n1mm_bandmap |
Live spots, mult targets, band activity |
n1mm_performance |
Score, rate, bands, run/S&P, hourly timeline |
n1mm_multipliers |
Mult grid, needs, value analysis |
n1mm_clock |
Contest timing, off-time, pacing |
n1mm_diagnostics |
Server health, parse errors, memory |
Quick Start
- In N1MM: Config → Configure Ports → Broadcast Data — enable all message types
- N1MM broadcasts to
255.255.255.255:12060by default
Claude Desktop
{
"mcpServers": {
"n1mm": {
"command": "n1mm-mcp"
}
}
}
Or with uvx (no install needed):
{
"mcpServers": {
"n1mm": {
"command": "uvx",
"args": ["n1mm-mcp"]
}
}
}
Claude Code
claude mcp add n1mm-mcp -- n1mm-mcp
Architecture
N1MM Logger+ (Windows)
│ UDP broadcast (port 12060, XML)
▼
n1mm-mcp (Python, any OS on same LAN)
├── UDP Listener Thread (background)
├── State Engine (in-memory, partitioned by StationName)
│ MCP protocol (stdio)
▼
AI Assistant (Claude, qsp-mcp, etc.)
- Passive listener — N1MM doesn't know we exist
- Stream-to-state — UDP packets → in-memory state → tool queries
- Multi-station — state partitioned by StationName (SO2R, multi-op)
- Zero auth — no credentials needed
CLI Options
| Option | Default | Description |
|---|---|---|
--port |
12060 |
UDP listen port |
--transport |
stdio |
MCP transport (stdio or streamable-http) |
--heartbeat-timeout |
60 |
Seconds before connection goes stale |
--stale-timeout |
900 |
Seconds before connection goes disconnected |
--max-spots |
2000 |
Maximum spots in bandmap buffer |
--spot-ttl |
30 |
Spot time-to-live in minutes |
Testing
# Mock mode (no N1MM needed)
N1MM_MCP_MOCK=1 n1mm-mcp
# MCP Inspector
n1mm-mcp --transport streamable-http
Development
git clone https://github.com/qso-graph/n1mm-mcp.git
cd n1mm-mcp
pip install -e .
N1MM_MCP_MOCK=1 n1mm-mcp
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
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 n1mm_mcp-0.1.3.tar.gz.
File metadata
- Download URL: n1mm_mcp-0.1.3.tar.gz
- Upload date:
- Size: 31.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
08ce4697c5e481ac3edec6cfb38e23809cc1819671ef5a5f629cdb9a467f428d
|
|
| MD5 |
aee4822437731d1e58d65e1f2bb5dafa
|
|
| BLAKE2b-256 |
7d7aa58e847a09b6d773f11c02666bfa2ba2efdb017516ca5ee19c46dcb9de77
|
Provenance
The following attestation bundles were made for n1mm_mcp-0.1.3.tar.gz:
Publisher:
publish.yml on qso-graph/n1mm-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
n1mm_mcp-0.1.3.tar.gz -
Subject digest:
08ce4697c5e481ac3edec6cfb38e23809cc1819671ef5a5f629cdb9a467f428d - Sigstore transparency entry: 1086804807
- Sigstore integration time:
-
Permalink:
qso-graph/n1mm-mcp@70c0c7a3e82f8ec9c525ec3a86292bb259f89b43 -
Branch / Tag:
refs/tags/v0.1.3 - Owner: https://github.com/qso-graph
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@70c0c7a3e82f8ec9c525ec3a86292bb259f89b43 -
Trigger Event:
push
-
Statement type:
File details
Details for the file n1mm_mcp-0.1.3-py3-none-any.whl.
File metadata
- Download URL: n1mm_mcp-0.1.3-py3-none-any.whl
- Upload date:
- Size: 32.6 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 |
413691dfeeedd6538b276295af9c909ba3d7bf6167d073dc10c5b2bc2875157b
|
|
| MD5 |
ddc3d0f11fe81797ed8b6c480a31fff3
|
|
| BLAKE2b-256 |
4af90a87d052c8c6ecede7b2261ed1488004937c4f5a46e8f9a2522dae165e5b
|
Provenance
The following attestation bundles were made for n1mm_mcp-0.1.3-py3-none-any.whl:
Publisher:
publish.yml on qso-graph/n1mm-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
n1mm_mcp-0.1.3-py3-none-any.whl -
Subject digest:
413691dfeeedd6538b276295af9c909ba3d7bf6167d073dc10c5b2bc2875157b - Sigstore transparency entry: 1086804879
- Sigstore integration time:
-
Permalink:
qso-graph/n1mm-mcp@70c0c7a3e82f8ec9c525ec3a86292bb259f89b43 -
Branch / Tag:
refs/tags/v0.1.3 - Owner: https://github.com/qso-graph
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@70c0c7a3e82f8ec9c525ec3a86292bb259f89b43 -
Trigger Event:
push
-
Statement type: