nextdns-mcp
Enables AI assistants to manage NextDNS profiles, settings, logs, analytics, and security configurations through 70+ operations via the Model Context Protocol.
README
NextDNS MCP Server
A Model Context Protocol (MCP) server for the NextDNS API, built with FastMCP and generated from OpenAPI specifications.
Overview
This project provides an MCP server that exposes NextDNS API operations as tools that can be used by AI assistants and other MCP clients. The server is automatically generated from a comprehensive OpenAPI specification using the FastMCP library.
Features
- 70+ NextDNS operations exposed as MCP tools
- Profile Management: Full CRUD operations - create, read, update, and delete profiles
- Profile Access Control: Fine-grained read/write restrictions per profile, with read-only mode support
- DNS-over-HTTPS Testing: Perform DoH lookups to test DNS resolution through profiles
- Settings Configuration: Comprehensive settings management including logs, block page, and performance
- Logs: Query log retrieval and clearing
- Analytics: Comprehensive DNS query analytics and statistics (11 endpoints)
- Content Lists: Manage denylist, allowlist, and parental control
- Security: Complete security settings and TLD blocking configuration
- Privacy: Privacy settings, blocklists, and native tracking protection management
- Parental Control: Settings management with safe search and YouTube restrictions
- OpenAPI-Generated: Server automatically generated from nextdns-openapi.yaml
- Docker MCP Gateway: Full integration with Docker's MCP Gateway for secure, isolated deployment
- Docker Support: Containerized deployment with proper OCI labels
- Safety Mechanisms: Write operation protections and validation
Documentation
Complete documentation can be found in docs/index.md.
Quick Start
Prerequisites
- Python 3.12+
- uv (for development)
- Docker (for containerized deployment)
- NextDNS API key (get one here)
Configuration
-
Copy the
.env.examplefile to.env:cp .env.example .env -
Edit
.envand set your NextDNS API key:NEXTDNS_API_KEY=your_api_key_here NEXTDNS_DEFAULT_PROFILE=your_profile_id # Optional NEXTDNS_TEST_PROFILE=test_profile_id # For write operation tests # Optional: Profile access control (see Profile Access Control section) # NEXTDNS_READABLE_PROFILES=profile1,profile2 # NEXTDNS_WRITABLE_PROFILES=test_profile # NEXTDNS_READ_ONLY=false
Running with Docker
-
Build the Docker image:
docker build -t nextdns-mcp:latest . -
Run the container with environment variables:
Option A: Direct environment variables (simple)
docker run -i --rm \ -e NEXTDNS_API_KEY=your_api_key_here \ -e NEXTDNS_DEFAULT_PROFILE=your_profile_id \ nextdns-mcp:latestOption B: Docker secrets (recommended for production)
# Create secret echo "your_api_key_here" | docker secret create nextdns_api_key - # Run with Docker Swarm docker service create \ --name nextdns-mcp \ --secret nextdns_api_key \ -e NEXTDNS_API_KEY_FILE=/run/secrets/nextdns_api_key \ nextdns-mcp:latestOr for non-swarm (using mounted file):
# Create a secret file echo "your_api_key_here" > /tmp/api_key.txt chmod 600 /tmp/api_key.txt # Run with mounted secret docker run -i --rm \ -v /tmp/api_key.txt:/run/secrets/nextdns_api_key:ro \ -e NEXTDNS_API_KEY_FILE=/run/secrets/nextdns_api_key \ nextdns-mcp:latestOption C: Environment file (development)
docker run -i --rm \ --env-file .env \ nextdns-mcp:latestNote: MCP servers use stdio (standard input/output) for communication, not HTTP ports.
Running Locally (Development)
-
Install dependencies:
uv sync -
Run the server:
uv run python -m nextdns_mcp.server
Architecture
This server uses a modern, declarative approach:
- OpenAPI Specification (nextdns-openapi.yaml): Complete NextDNS API documentation
- FastMCP Generation: Server automatically generated using
FastMCP.from_openapi() - HTTP Client: Authenticated
httpx.AsyncClientfor NextDNS API calls - MCP Protocol: Tools, resources, and prompts exposed via Model Context Protocol
Key Components
src/nextdns_mcp/nextdns-openapi.yaml: OpenAPI 3.0 specification for NextDNS APIsrc/nextdns_mcp/server.py: FastMCP server implementationcatalog.yaml: Docker MCP Gateway catalog entry with server metadataDockerfile: Container definition with OCI labels for MCP GatewayAGENT.md: Development guidelines and safety rules
Docker Tags
This project publishes official Docker images with a standardized tagging policy:
:latest: Floating tag that tracks the most recent successful build from themainbranch. This tag is rebuilt on changes tomainand via scheduled rebuilds.:<major>: Floating tag for the most recent build in a given major series (e.g.,:2). This tag is updated whenever a new image for that major line is published and may include unreleased changes if the corresponding build comes from a branch head.:<major>.<minor>: Floating tag for the most recent build in a given minor series (e.g.,:2.0). Like:<major>, it is updated when new images are built for that series and may include unreleased changes.:<major>.<minor>.<patch>: Tags for specific application releases (e.g.,:2.0.3). These are intended to be immutable once published via the release workflow.
All floating tags (:latest, :<major>, :<major>.<minor>) are rebuilt regularly to include the latest OS security updates and any application changes present in the source commit used for that build. Consumers who require strict version pinning should use the full :<major>.<minor>.<patch> tags.
License
This project is released under the MIT License.
Contributing
- See
AGENT.mdfor guidelines and architecture - Note that NextDNS does not provide an OpenAPI specification. This is based on their documentation and may not reflect the current state of the API.
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.