MCP server for Parks on the Air — park lookup, activator/hunter stats, spots
Project description
pota-mcp
MCP server for Parks on the Air (POTA) — live activator spots, park info, activator/hunter stats, and scheduled activations through any MCP-compatible AI assistant.
Part of the qso-graph project. No authentication required — all POTA endpoints are public.
Install
pip install pota-mcp
Tools
| Tool | Description |
|---|---|
pota_spots |
Current activator spots with park/grid enrichment and optional filters |
pota_park_info |
Park details by reference code (name, grid, type, agencies, website) |
pota_park_stats |
Activation and QSO counts for a park |
pota_user_stats |
Activator/hunter stats by callsign |
pota_scheduled |
Upcoming scheduled activations |
pota_location_parks |
All parks in a state/province/country |
Quick Start
No credentials needed — just install and configure your MCP client.
Configure your MCP client
pota-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": {
"pota": {
"command": "pota-mcp"
}
}
}
Claude Code
Add to .claude/settings.json:
{
"mcpServers": {
"pota": {
"command": "pota-mcp"
}
}
}
ChatGPT Desktop
{
"mcpServers": {
"pota": {
"command": "pota-mcp"
}
}
}
Cursor
Add to .cursor/mcp.json (project-level) or ~/.cursor/mcp.json (global):
{
"mcpServers": {
"pota": {
"command": "pota-mcp"
}
}
}
VS Code / GitHub Copilot
Add to .vscode/mcp.json in your workspace:
{
"servers": {
"pota": {
"command": "pota-mcp"
}
}
}
Gemini CLI
Add to ~/.gemini/settings.json (global) or .gemini/settings.json (project):
{
"mcpServers": {
"pota": {
"command": "pota-mcp"
}
}
}
Ask questions
"What POTA activations are happening right now?"
"Tell me about park US-0001 — how many activations has it had?"
"What are K4SWL's POTA stats?"
"Show me all parks in Idaho"
"Are there any CW activators on 20m right now?"
"What activations are scheduled for tomorrow?"
Testing Without Network
For testing all tools without hitting the POTA API:
POTA_MCP_MOCK=1 pota-mcp
MCP Inspector
pota-mcp --transport streamable-http --port 8006
Then open the MCP Inspector at http://localhost:8006.
Development
git clone https://github.com/qso-graph/pota-mcp.git
cd pota-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
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 pota_mcp-0.2.0.tar.gz.
File metadata
- Download URL: pota_mcp-0.2.0.tar.gz
- Upload date:
- Size: 9.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f0bef6b13443698dfb284dd18a5b5c53c2f4fd7c370d66bdc136a5c082cebbf1
|
|
| MD5 |
18a3b8163768e7c292c7f6285ac4d4b5
|
|
| BLAKE2b-256 |
9401ef19254c0327a24b7821b2e955417aaea8102623ab193d6d6edb17291858
|
Provenance
The following attestation bundles were made for pota_mcp-0.2.0.tar.gz:
Publisher:
publish.yml on qso-graph/pota-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
pota_mcp-0.2.0.tar.gz -
Subject digest:
f0bef6b13443698dfb284dd18a5b5c53c2f4fd7c370d66bdc136a5c082cebbf1 - Sigstore transparency entry: 1093287144
- Sigstore integration time:
-
Permalink:
qso-graph/pota-mcp@b35722da5f22006f2bdd66031919fc504097484a -
Branch / Tag:
refs/tags/v0.2.0 - Owner: https://github.com/qso-graph
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@b35722da5f22006f2bdd66031919fc504097484a -
Trigger Event:
push
-
Statement type:
File details
Details for the file pota_mcp-0.2.0-py3-none-any.whl.
File metadata
- Download URL: pota_mcp-0.2.0-py3-none-any.whl
- Upload date:
- Size: 9.3 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 |
0c81d2df27a25a29822661bf7efbbc15d3b1489ad311254e0b1b6ff3131fa973
|
|
| MD5 |
ac24586fbead9842808ae1adcffdeb66
|
|
| BLAKE2b-256 |
70b4cfe99c87292b83d4782adc70a45578d4635259f011a5297376c1fdbf9145
|
Provenance
The following attestation bundles were made for pota_mcp-0.2.0-py3-none-any.whl:
Publisher:
publish.yml on qso-graph/pota-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
pota_mcp-0.2.0-py3-none-any.whl -
Subject digest:
0c81d2df27a25a29822661bf7efbbc15d3b1489ad311254e0b1b6ff3131fa973 - Sigstore transparency entry: 1093287196
- Sigstore integration time:
-
Permalink:
qso-graph/pota-mcp@b35722da5f22006f2bdd66031919fc504097484a -
Branch / Tag:
refs/tags/v0.2.0 - Owner: https://github.com/qso-graph
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@b35722da5f22006f2bdd66031919fc504097484a -
Trigger Event:
push
-
Statement type: