Fortinet MCP Server
A complete Model Context Protocol (MCP) server for Fortinet FortiOS 7.6.6
FortiOS 7.6.6 MCP Server
A complete Model Context Protocol (MCP) server for Fortinet FortiOS 7.6.6, exposing the entire REST API (1536 endpoints) as typed MCP tools usable from Claude Desktop, Cursor, or any MCP-compatible client.
Features
- 150+ specific typed tools organized by functional area
- 5 generic pass-through tools that cover all 1536 FortiOS API endpoints
- Async HTTP client with Bearer-token authentication
- Full support for CMDB, Monitor, Log, and Service API sections
- Safe against self-signed certificates (configurable)
- Compatible with multi-VDOM environments
Tool Categories
| Module | Tools | Description |
|---|---|---|
| Generic | 5 | cmdb_list/get/create/update/delete, monitor_get/action, log_get, service_call — cover ALL endpoints |
| System | 27 | Interfaces, DNS, NTP, admins, DHCP, SNMP, certificates, VDOMs, syslog |
| Firewall | 32 | Policies (IPv4/IPv6), addresses, address groups, services, VIPs, IP pools, schedules, sessions |
| VPN | 22 | IPsec Phase 1/2, SSL VPN portals/settings, tunnel up/down, VPN certificates |
| Router | 17 | Static routes, OSPF, BGP, RIP, prefix lists, route maps, SD-WAN health |
| User | 18 | Local users, groups, RADIUS, LDAP, TACACS+, SAML, authenticated sessions |
| Monitor | 18 | ARP, FortiView top talkers, endpoint control, IPS stats, switch controller, config backup |
| Log | 18 | Traffic, event, VPN, user, virus, webfilter, IPS, app-ctrl, DNS logs + log config |
| Security | 29 | IPS, AV, webfilter, app control, DLP, email filter, DNS filter, WAF, ICAP, ssh-filter, ZTNA |
| Wireless | 18 | AP profiles, WTPs, SSIDs (VAPs), Hotspot 2.0, connected clients, rogue APs |
Total: 204+ tools
Requirements
- Python 3.11+
uvpackage manager (orpip)- Fortinet FortiGate with FortiOS 7.6.x
- A REST API admin account on the FortiGate
Setup
1. Create API Token on FortiGate
- Go to System > Administrators
- Create a new REST API Admin
- Set appropriate admin profile (e.g.
super_adminfor full access or restrict as needed) - Copy the generated API token
2. Install dependencies
cd fortinet/mcp-server
# Using uv (recommended)
uv sync
# Or using pip
pip install -e .
3. Configure environment
cp .env.example .env
# Edit .env with your FortiGate details:
# FORTIOS_HOST=https://192.168.1.1
# FORTIOS_API_TOKEN=your-token-here
# FORTIOS_VDOM=root
# FORTIOS_VERIFY_SSL=false
4. Test with MCP Inspector
uv run mcp dev server.py
5. Install in Claude Desktop
uv run mcp install server.py --name "FortiOS 7.6.6"
Or manually add to claude_desktop_config.json:
{
"mcpServers": {
"fortios": {
"command": "uv",
"args": ["run", "--directory", "/path/to/fortinet/mcp-server", "python", "server.py"],
"env": {
"FORTIOS_HOST": "https://192.168.1.1",
"FORTIOS_API_TOKEN": "your-api-token",
"FORTIOS_VDOM": "root",
"FORTIOS_VERIFY_SSL": "false"
}
}
}
}
HTTP Mode (optional)
To run as a remote HTTP server instead of stdio:
MCP_TRANSPORT=streamable-http MCP_PORT=8000 uv run server.py
Connect via http://localhost:8000/mcp.
Usage Examples
Via Claude Desktop
Once installed, ask Claude:
- "Show me all firewall policies that deny traffic"
- "What IPsec tunnels are currently down?"
- "List interfaces with their IPs"
- "Look up which route would be used to reach 8.8.8.8"
- "Show top 20 traffic sources in FortiView"
- "Are there any failed admin login attempts in the logs?"
Direct Tool Invocations
# List firewall policies
firewall_policy_list(filter_action="deny")
# Get system status
system_status()
# Check VPN tunnels
monitor_vpn_ipsec()
# Query forward traffic logs for a specific IP
log_traffic_forward(srcip="10.10.1.100", rows=50)
# Generic: list any resource
cmdb_list("casb/profile")
cmdb_list("wireless-controller.hotspot20/hs-profile")
# Generic: get any monitor data
monitor_get("registration/forticloud")
Project Structure
├── server.py # FastMCP entry point, lifespan, tool registration
├── fortios_client.py # Async HTTP client (CMDB/Monitor/Log/Service)
├── pyproject.toml # Project metadata and dependencies
├── .env.example # Environment variable template
├── README.md # This file
└── tools/
├── __init__.py
├── generic.py # Generic pass-through tools (all 1536 endpoints)
├── system.py # System config + monitoring
├── firewall.py # Firewall policies, addresses, VIPs, sessions
├── vpn.py # IPsec + SSL VPN config and monitoring
├── router.py # Static routes, OSPF, BGP, SD-WAN
├── user.py # Local users, groups, RADIUS, LDAP, sessions
├── monitor.py # Network monitoring, FortiView, endpoint control
├── log.py # Log retrieval and configuration
├── security.py # IPS, AV, webfilter, DLP, WAF, ZTNA profiles
└── wireless.py # WiFi APs, SSIDs, clients, rogue APs
Security Notes
- The API token provides the same level of access as the admin profile it was assigned to. Use the principle of least privilege.
- Set
FORTIOS_VERIFY_SSL=truein production and install a valid certificate on your FortiGate. - This server runs locally on stdio by default — it is not exposed over the network unless you use HTTP mode.
- Never commit your
.envfile or expose your API token.
FortiOS API Reference
The full FortiOS 7.6.6 REST API is documented in the official Fortinet documentation.
You can explore any available path at runtime using the generic cmdb_list tool:
# Discover resources using generic tools
cmdb_list("casb/profile")
cmdb_list("wireless-controller.hotspot20/hs-profile")
monitor_get("registration/forticloud")
संबंधित सर्वर
Spotify
Connects your Spotify account to AI tools, allowing access to your music library, playlists, and playback controls.
NBA MCP Server
Provides NBA statistics and live game data using the Model Context Protocol (MCP).
Meridian Edge
Real-time prediction market consensus data aggregated from multiple regulated prediction markets. 5 MCP tools for consensus probabilities, divergence opportunities, market signals, active markets, and settlements. Free tier: 100 calls/day, no credit card.
APsystems MCP Server
A Model Context Protocol (MCP) server written in Go that wraps the APsystems OpenAPI, giving AI assistants like Claude direct access to your solar monitoring data. Includes an optional web dashboard for visual monitoring.
mcp-dice
Rolls dice using standard notation (e.g., 1d20) and returns individual rolls and their sum.
Map Traveler
A virtual travel environment for an avatar on Google Maps, utilizing various Google Maps and optional AI image generation APIs.
Microsoft Learn MCP Server
The Microsoft Learn MCP Server enables clients like GitHub Copilot and other AI agents to bring trusted and up-to-date information directly from Microsoft's official documentation. It is a remote MCP server that uses streamable http. It allows to search through documentation, fetch a complete article, and search through code samples.
Immigration & Travel MCP
US visa bulletin data and CBP border wait times. 3 MCP tools for immigration and travel planning.
Ultra MCP SS
An MCP server for programmatic control of smartscreen.tv displays via HTTP and MCP commands, with YouTube integration.
Actiongate
Pre-execution safety layer for autonomous agent wallets — risk scoring, simulation, and policy enforcement via MCP, with free tier and pay-per-call pricing over x402