juniper-mist-mcp
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@juniper-mist-mcpshow alarms for acme_corp"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Juniper Mist MCP Server
⚠️ Juniper now offers an official MCP server for Mist.
Juniper has released their own MCP server at https://mcp.ai.juniper.net/mcp/mist with native integration for Claude Desktop.
We recommend using the official upstream server instead of this project. See the Juniper Mist MCP documentation for setup instructions.
This community project remains available for use cases that require multi-org MSP routing, write tools, or HTTP transport — features not yet covered by the upstream server. However, for standard single-org monitoring and troubleshooting, the official server is the better choice going forward.
MCP server for managing Juniper Mist networks with AI assistants. Monitor, troubleshoot, and configure customer networks through natural language — built for MSPs managing multiple organizations across regions.
Input: Natural language via Claude Desktop (or any MCP client) Output: Device stats, client data, alarms, WLAN configs, inventory, and more
AI Assistant ──▶ MCP Server ──▶ Juniper Mist API
(Claude, etc.) (multi-org (US, EU, GC1, GC2,
routing) APAC regions)Installation
Option 1: Install from PyPI (recommended)
pip install juniper-mist-mcpOption 2: Install with pipx (isolated environment)
pipx install juniper-mist-mcpVerify installation
juniper-mist-mcp --helpRelated MCP server: io.github.shigechika/junos-mcp
Setup
1. Get a Mist API Token
Log in to the Mist portal at https://admin.mist.com
Navigate to Organization → Settings → API Tokens
Create a new API token with appropriate scope
2. Configure Organizations
Create a .env file with your organization credentials:
# US-based org (default region)
MIST_TOKEN_acme_corp=your_token_here
# EU-based org
MIST_TOKEN_euro_client=your_token_here
MIST_REGION_euro_client=api.eu.mist.com
# Government org
MIST_TOKEN_gov_agency=your_token_here
MIST_REGION_gov_agency=api.gc1.mist.comEach org needs a MIST_TOKEN_<ORGNAME> variable. Region is optional — defaults to US (api.mist.com).
Supported Regions
Region | Endpoint |
US (default) |
|
EU |
|
Government Cloud 1 |
|
Government Cloud 2 |
|
Asia Pacific |
|
Usage
Run in stdio mode (Claude Desktop)
# Read-only mode (default — 10 tools)
juniper-mist-mcp
# With write tools enabled (14 tools)
juniper-mist-mcp --enable-write-toolsRun in HTTP mode (centralized deployment)
# Default port 8000
juniper-mist-mcp --transport=http
# Custom host and port
juniper-mist-mcp --transport=http --host=0.0.0.0 --port=8080
# HTTP + write tools
juniper-mist-mcp --transport=http --port=8080 --enable-write-toolsConfigure Claude Desktop
Add to ~/Library/Application Support/Claude/claude_desktop_config.json (macOS):
{
"mcpServers": {
"juniper-mist": {
"command": "juniper-mist-mcp",
"env": {
"MIST_TOKEN_acme_corp": "your_token_here",
"MIST_REGION_acme_corp": "api.mist.com"
}
}
}
}Or if using a .env file alongside the install:
{
"mcpServers": {
"juniper-mist": {
"command": "juniper-mist-mcp",
"args": ["--env-file", "/path/to/your/.env"]
}
}
}Verify it works
In your AI assistant, ask it to list organizations. The mist_list_orgs tool should return your configured orgs:
[
{"name": "acme_corp", "region": "api.mist.com", "has_token": true},
{"name": "euro_client", "region": "api.eu.mist.com", "has_token": true}
]Available Tools
Read Tools (always available)
Tool | What it does |
| List configured customer orgs and regions |
| AP, switch, and gateway statistics |
| Service Level Experience metrics (throughput, latency, coverage) |
| Wireless client connection and bandwidth data |
| Infrastructure, security, and Marvis AI alarms |
| Config changes, user activities, system alerts |
| WLAN/SSID profiles and security settings |
| Radio frequency templates (channel, power, band) |
| Device inventory with type/status/site filters |
| Generated CLI config commands for a device |
Write Tools (opt-in with --enable-write-tools)
Tool | What it does |
| Modify WLAN/SSID configurations |
| Create, update, or delete 802.1X NAC rules |
| Manage WXLAN microsegmentation policies |
| Create, update, or delete security policies |
Every tool takes an org parameter to route to the right customer org and region.
Safety Model
Four layers prevent accidental network changes:
Read-only by default — write tools aren't registered unless you opt in
CLI flag — must explicitly pass
--enable-write-toolsMCP annotations — read tools tagged
readOnlyHint, write tools taggeddestructiveHintso the AI asks for confirmationPre-flight validation — UUID format checks and required field validation before any API call
CLI Reference
Flag | Description | Default |
| Enable 4 write tools for network modification | Disabled |
| Transport protocol: |
|
| Host for HTTP transport |
|
| Port for HTTP transport |
|
| Path to |
|
Troubleshooting
Error | Fix |
| Create a |
| Check |
| Use a supported region endpoint (see table above) |
| Token is invalid or expired — regenerate in Mist portal |
Write tools not appearing | Start server with |
Contributing
Build from source
git clone https://github.com/vahagn-madatyan/juniper-mist-mcp.git
cd juniper-mist-mcp
# Create virtual environment
python -m venv .venv
source .venv/bin/activate # or .venv\Scripts\activate on Windows
# Install with dev dependencies
pip install -e ".[dev]"
# Run from source
python -m mist_mcp.server --helpRun tests
pytest tests/ -v
pytest tests/ -v --tb=short
pytest tests/test_config.py -vProject structure
mist_mcp/
├── __init__.py # Package version
├── __main__.py # Module entry point
├── server.py # MCP server, tool definitions, CLI
├── config.py # .env loader, org routing, region validation
└── session.py # Mist API session managementArchitecture
FastMCP — MCP server framework handling tool registration, lifespan, and transport
mistapi SDK — Juniper Mist Python SDK for all API calls
Multi-tenant routing — each tool call includes an
orgparameter; the server maintains separate authenticated sessions per orgConditional tool registration — write tools are only registered when
--enable-write-toolsis passed, usingmcp.add_tool()with MCP annotations
Making a release
Releases are published to PyPI automatically via GitHub Actions when a version tag is pushed:
# Update version in pyproject.toml and mist_mcp/__init__.py
# Commit the version bump
git tag v0.2.0
git push origin v0.2.0The CI pipeline builds the distribution, runs tests, publishes to TestPyPI on every push, and publishes to PyPI on tags matching v*.
License
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/vahagn-madatyan/juniper-mist-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server