Skip to main content

MCP server for managing Juniper Mist networks with AI assistants

Project description

Juniper Mist MCP Server

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-mcp

Option 2: Install with pipx (isolated environment)

pipx install juniper-mist-mcp

Verify installation

juniper-mist-mcp --help

Setup

1. Get a Mist API Token

  1. Log in to the Mist portal at https://admin.mist.com
  2. Navigate to OrganizationSettingsAPI Tokens
  3. 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.com

Each org needs a MIST_TOKEN_<ORGNAME> variable. Region is optional — defaults to US (api.mist.com).

Supported Regions

Region Endpoint
US (default) api.mist.com
EU api.eu.mist.com
Government Cloud 1 api.gc1.mist.com
Government Cloud 2 api.gc2.mist.com
Asia Pacific api.ac2.mist.com

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-tools

Run 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-tools

Configure 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
mist_list_orgs List configured customer orgs and regions
mist_get_device_stats AP, switch, and gateway statistics
mist_get_sle_summary Service Level Experience metrics (throughput, latency, coverage)
mist_get_client_stats Wireless client connection and bandwidth data
mist_get_alarms Infrastructure, security, and Marvis AI alarms
mist_get_site_events Config changes, user activities, system alerts
mist_list_wlans WLAN/SSID profiles and security settings
mist_get_rf_templates Radio frequency templates (channel, power, band)
mist_get_inventory Device inventory with type/status/site filters
mist_get_device_config_cmd Generated CLI config commands for a device

Write Tools (opt-in with --enable-write-tools)

Tool What it does
mist_update_wlan Modify WLAN/SSID configurations
mist_manage_nac_rules Create, update, or delete 802.1X NAC rules
mist_manage_wxlan Manage WXLAN microsegmentation policies
mist_manage_security_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:

  1. Read-only by default — write tools aren't registered unless you opt in
  2. CLI flag — must explicitly pass --enable-write-tools
  3. MCP annotations — read tools tagged readOnlyHint, write tools tagged destructiveHint so the AI asks for confirmation
  4. Pre-flight validation — UUID format checks and required field validation before any API call

CLI Reference

Flag Description Default
--enable-write-tools Enable 4 write tools for network modification Disabled
--transport Transport protocol: stdio or http stdio
--host Host for HTTP transport 0.0.0.0
--port Port for HTTP transport 8000
--env-file Path to .env file .env

Troubleshooting

Error Fix
Configuration file not found: .env Create a .env file from .env.example
Organization 'X' is not configured Check MIST_TOKEN_<ORGNAME> in your .env (case-sensitive)
Unknown region 'X' Use a supported region endpoint (see table above)
Failed to fetch orgs: 401 Token is invalid or expired — regenerate in Mist portal
Write tools not appearing Start server with --enable-write-tools flag

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 --help

Run tests

pytest tests/ -v
pytest tests/ -v --tb=short
pytest tests/test_config.py -v

Project 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 management

Architecture

  • 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 org parameter; the server maintains separate authenticated sessions per org
  • Conditional tool registration — write tools are only registered when --enable-write-tools is passed, using mcp.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.0

The CI pipeline builds the distribution, runs tests, publishes to TestPyPI on every push, and publishes to PyPI on tags matching v*.


License

Apache License 2.0

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

juniper_mist_mcp-0.1.0.tar.gz (30.3 kB view details)

Uploaded Source

Built Distribution

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

juniper_mist_mcp-0.1.0-py3-none-any.whl (20.6 kB view details)

Uploaded Python 3

File details

Details for the file juniper_mist_mcp-0.1.0.tar.gz.

File metadata

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

File hashes

Hashes for juniper_mist_mcp-0.1.0.tar.gz
Algorithm Hash digest
SHA256 e490ef284efac79d89236a0e884774869d030c87a6f089025f69ad89e40c4a56
MD5 62439249475016b2dca2908feba2087c
BLAKE2b-256 c84ac460bc7475c19698ae4aa8cce16aa6d1ce8e054da86583fb2aadc1c1a294

See more details on using hashes here.

Provenance

The following attestation bundles were made for juniper_mist_mcp-0.1.0.tar.gz:

Publisher: pypi-publish.yml on vahagn-madatyan/juniper-mist-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 juniper_mist_mcp-0.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for juniper_mist_mcp-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 230444ced535d40c62dbe4984540e4303cf90f17366dee2807bb12db6c5836ed
MD5 0bf417951efd2f217e919a56985f405c
BLAKE2b-256 270d92b30ffbb97674685077f0fe0288ea386de369ed184a31a770c088ced92f

See more details on using hashes here.

Provenance

The following attestation bundles were made for juniper_mist_mcp-0.1.0-py3-none-any.whl:

Publisher: pypi-publish.yml on vahagn-madatyan/juniper-mist-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