Server data from the Official MCP Registry
Control fldigi (amateur-radio digital modes) over XML-RPC: modem, frequency, rig, log, transmit.
Control fldigi (amateur-radio digital modes) over XML-RPC: modem, frequency, rig, log, transmit.
Valid MCP server (1 strong, 3 medium validity signals). No known CVEs in dependencies. Package registry verified. Imported from the Official MCP Registry.
7 files analyzed · 1 issue found
Security scores are indicators to help you make informed decisions, not guarantees. Always review permissions before connecting any MCP server.
This plugin requests these system permissions. Most are normal for its category.
Set these up before or after installing:
Environment variable: FLDIGI_CALLSIGN
Environment variable: FLDIGI_HOST
Environment variable: FLDIGI_PORT
Environment variable: FLDIGI_BAND_GUIDANCE
Environment variable: FLDIGI_REGION
Add this to your MCP configuration file:
{
"mcpServers": {
"io-github-sbrunner-atx-fldigi-mcp": {
"env": {
"FLDIGI_HOST": "your-fldigi-host-here",
"FLDIGI_PORT": "your-fldigi-port-here",
"FLDIGI_REGION": "your-fldigi-region-here",
"FLDIGI_CALLSIGN": "your-fldigi-callsign-here",
"FLDIGI_BAND_GUIDANCE": "your-fldigi-band-guidance-here"
},
"args": [
"fldigi-mcp"
],
"command": "uvx"
}
}
}From the project's GitHub README.
An MCP server for controlling fldigi, the popular amateur-radio digital-modem application, from MCP-aware clients such as Claude Desktop.
fldigi ships a built-in XML-RPC control interface. fldigi-mcp connects to it
and exposes the whole API as a small set of logically-grouped MCP tools, so an
assistant can read the radio's state and drive the modem, rig, log, and
transmitter through plain language.
Status: beta. Full API coverage, callsign-gated transmit, and an optional experimental Band Guidance feature. Tested against fldigi 4.2.x.
fldigi_call escape hatch for the
long tail and future methods.xmlrpc.client. The only third-party runtime deps are the MCP SDK and PyYAML
(for the optional band-plan data).fldigi's XML-RPC interface is its official, OS-independent control API. This project talks to it directly rather than through an unmaintained wrapper, keeping the moving parts to Python's standard library and fldigi's own API.
To install the desktop extension (.mcpb) all you need is:
127.0.0.1:7362).Claude Desktop's uv runtime supplies Python and the dependencies, so end users
do not install Python or uv themselves. (That runtime is currently marked
experimental, so a recent Claude Desktop is recommended.)
For development from source you additionally need Python 3.10+ and uv (and Node.js, only for the MCP Inspector).
Download fldigi-mcp.mcpb from the latest
release, then in Claude
Desktop go to Settings → Extensions → Advanced settings → Install Extension…
and choose the file.
A short settings form asks for your callsign (everything else has a default).
No terminal, no Python, no uv to install.
👉 New to this? Follow the simple step-by-step install guide. Also see the install & safety model.
git clone https://github.com/sbrunner-atx/fldigi-mcp.git
cd fldigi-mcp
uv sync
Then add it to Claude Desktop's config
(~/Library/Application Support/Claude/claude_desktop_config.json on macOS):
{
"mcpServers": {
"fldigi": {
"command": "uv",
"args": ["--directory", "/absolute/path/to/fldigi-mcp", "run", "fldigi-mcp"],
"env": { "FLDIGI_CALLSIGN": "AE5VG" }
}
}
}
Restart Claude Desktop and ask "What's fldigi's status?". Omit the env block
to run receive-only.
uv run mcp dev src/fldigi_mcp/server.py
Each tool is one permission and takes an operation argument, so e.g. "change
the mode" is a single permission regardless of which underlying method runs.
| Tool | Controls (fldigi area) |
|---|---|
status | quick snapshot: version, mode, frequency, T/R, callsign, band |
application | program info + launch/stop the fldigi process (fldigi.*) |
modem | Op Mode / modem select, carrier, bandwidth, AFC range, Olivia |
frequency | dial frequency and waterfall sideband |
controls | AFC, SQL, Rev, Lock, RxID, TxID, status fields |
transmit | T/R, Tune, abort, disable/enable Tx, macros, send — callsign-gated |
rig | CAT control: mode, frequency, bandwidth, notch, QSY, take/release |
log | Logbook / contest fields; ADIF last/all records |
text | RX/TX text and data streams |
spot | spotting / PSK Reporter |
wefax | WEFAX (weather fax) mode |
navtex | NAVTEX / SitorB mode |
band_guidance | advisory band/watering-hole help (experimental) |
fldigi_call | escape hatch — call any method by name, incl. future ones |
Use application → list_methods to enumerate every method the running build
supports; anything not surfaced in a group is reachable via fldigi_call.
| Variable | Default | Purpose |
|---|---|---|
FLDIGI_HOST | 127.0.0.1 | fldigi XML-RPC host |
FLDIGI_PORT | 7362 | fldigi XML-RPC port |
FLDIGI_CALLSIGN | (empty) | Operator callsign. The single transmit gate — set it to enable transmit; blank keeps the station receive-only |
FLDIGI_BAND_GUIDANCE | off | Experimental advisory band guidance. on to enable |
FLDIGI_REGION | 2 | IARU region for band guidance: 1, 2, or 3 |
FLDIGI_PATH | (auto) | Explicit path to the fldigi executable (for application launch) |
In the packaged desktop extension these appear as a settings form — most users only ever fill in the callsign.
The callsign is the single transmit gate. Keying operations (transmit
tx/tune/run_macro/send, and the wefax/navtex send operations, and any keying
method via fldigi_call) refuse unless FLDIGI_CALLSIGN is set. With it blank,
the station is receive-only. rx, abort, and disable_tx are always allowed
because they take the station off the air. Any non-blank value is accepted
(club, event, vanity, portable, and international calls all work). See
docs/install-and-safety.md.
An optional, advisory feature that suggests a mode's customary "watering hole"
and warns when a frequency falls outside the digital band segment — guidance and
defaults, never hard locks. Region-aware (IARU R1/R2/R3), covering 160 m – 70 cm.
Enable with FLDIGI_BAND_GUIDANCE=on. It adds the band_guidance tool and
enriches modem/frequency set operations with an advisory guidance field.
Because band-plan data is hard to get exactly right, it ships experimental and
disabled by default. Design and data: docs/band-guidance.md.
fldigi need not run on the same machine. Point the server at it with
FLDIGI_HOST/FLDIGI_PORT. The fldigi machine must be launched with
--xmlrpc-server-address 0.0.0.0 to accept LAN connections, and the link should
be kept on a trusted LAN or tunneled over SSH (the XML-RPC interface is
unauthenticated).
uv sync
uv run ruff check . # lint
uv run pytest # tests (no running fldigi required)
The test suite covers the band-plan logic and the operation maps / type coercion; it does not require a running fldigi.
MIT © 2026 Stefan Brunner (AE5VG)
Be the first to review this server!
by Modelcontextprotocol · Developer Tools
Web content fetching and conversion for efficient LLM usage
by Toleno · Developer Tools
Toleno Network MCP Server — Manage your Toleno mining account with Claude AI using natural language.
by mcp-marketplace · Developer Tools
Create, build, and publish Python MCP servers to PyPI — conversationally.