utensils/mcp-nixos
{ "createdAt": "2025-03-20T05:05:00Z", "defaultBranch": "main", "description": "MCP-NixOS - Model Context Protocol Server for NixOS resources", "fullName": "utensils/mcp-nixos", "homepage": "https://mcp-nixos.io/", "language": "Python", "name": "mcp-nixos", "pushedAt": "2026-03-11T18:46:52Z", "stargazersCount": 487, "topics": [ "ai-assistant", "ai-integration", "ai-tools", "anthropic", "claude", "developer-tools", "devops-tools", "fastmcp", "llm-tools", "mcp", "model-context-protocol", "nix", "nix-options", "nix-packages", "nix-search", "nixos", "package-search", "python", "sre-tools" ], "updatedAt": "2026-03-20T14:42:56Z", "url": "https://github.com/utensils/mcp-nixos"}MCP-NixOS - Because Your AI Shouldn’t Hallucinate Package Names
Section titled “MCP-NixOS - Because Your AI Shouldn’t Hallucinate Package Names”Quick Start
Section titled “Quick Start”🚨 No Nix/NixOS Required! Works on any system - Windows, macOS, Linux. You’re just querying APIs.
Option 1: uvx (Recommended)
Section titled “Option 1: uvx (Recommended)”{ "mcpServers": { "nixos": { "command": "uvx", "args": ["mcp-nixos"] } }}Option 2: Nix
Section titled “Option 2: Nix”{ "mcpServers": { "nixos": { "command": "nix", "args": ["run", "github:utensils/mcp-nixos", "--"] } }}Option 3: Docker
Section titled “Option 3: Docker”{ "mcpServers": { "nixos": { "command": "docker", "args": ["run", "--rm", "-i", "ghcr.io/utensils/mcp-nixos"] } }}Your AI now has access to real NixOS data instead of making things up. You’re welcome.
Option 4: HTTP (Remote MCP)
Section titled “Option 4: HTTP (Remote MCP)”FastMCP supports running this server over HTTP at a URL (the MCP endpoint defaults to /mcp).
MCP_NIXOS_TRANSPORT=http MCP_NIXOS_HOST=127.0.0.1 MCP_NIXOS_PORT=8000 mcp-nixosSTDIO (default):
MCP_NIXOS_TRANSPORT=stdio mcp-nixosCustom path:
MCP_NIXOS_TRANSPORT=http MCP_NIXOS_PATH=/api/mcp mcp-nixosStateless HTTP (disables per-client session state):
MCP_NIXOS_TRANSPORT=http MCP_NIXOS_STATELESS_HTTP=1 mcp-nixosWhat Is This?
Section titled “What Is This?”An MCP server providing accurate, real-time information about:
- NixOS packages - 130K+ packages that actually exist
- NixOS options - 23K+ ways to configure your system
- Home Manager - 5K+ options for dotfile enthusiasts
- nix-darwin - 1K+ macOS settings Apple doesn’t document
- Nixvim - 5K+ options for Neovim configuration via NuschtOS search
- FlakeHub - 600+ flakes from FlakeHub.com registry
- Noogle - 2K+ Nix functions with type signatures via noogle.dev
- NixOS Wiki - Community documentation and guides from wiki.nixos.org
- nix.dev - Official Nix tutorials and guides from nix.dev
- Package versions - Historical versions with commit hashes via NixHub.io
- Binary cache status - Check if packages are cached on cache.nixos.org with download sizes
- Local flake inputs - Explore your pinned flake dependencies directly from the Nix store (requires Nix)
The Tools
Section titled “The Tools”Just two. We consolidated 17 tools into 2 because your AI’s context window isn’t infinite.
~1,030 tokens total. That’s it. While other MCP servers are hogging your context like it’s Black Friday, we’re sipping minimalist tea in the corner. Your AI gets NixOS superpowers without the bloat.
nix - Unified Query Tool
Section titled “nix - Unified Query Tool”One tool to rule them all:
nix(action, query, source, type, channel, limit)| Action | What it does |
|---|---|
search | Search packages, options, programs, or flakes |
info | Get detailed info about a package or option |
stats | Get counts and categories |
options | Browse Home Manager/Darwin options by prefix |
channels | List available NixOS channels |
flake-inputs | Explore local flake inputs from Nix store |
cache | Check binary cache status for packages |
| Source | What it queries |
|---|---|
nixos | Packages, options, programs |
home-manager | Home Manager options |
darwin | nix-darwin options |
flakes | Community flakes (search.nixos.org) |
flakehub | FlakeHub registry (flakehub.com) |
nixvim | Nixvim Neovim configuration options |
noogle | Nix function signatures and docs (noogle.dev) |
wiki | NixOS Wiki articles (wiki.nixos.org) |
nix-dev | Official Nix documentation (nix.dev) |
nixhub | Package metadata and store paths (nixhub.io) |
Examples:
# Search NixOS packagesnix(action="search", query="firefox", source="nixos", type="packages")
# Get package infonix(action="info", query="firefox", source="nixos", type="package")
# Search Home Manager optionsnix(action="search", query="git", source="home-manager")
# Browse darwin optionsnix(action="options", source="darwin", query="system.defaults")
# Search Nixvim optionsnix(action="search", query="telescope", source="nixvim")
# Get Nixvim option infonix(action="info", query="plugins.telescope.enable", source="nixvim")
# Search FlakeHubnix(action="search", query="nixpkgs", source="flakehub")
# Get FlakeHub flake infonix(action="info", query="NixOS/nixpkgs", source="flakehub")
# Search Noogle for Nix functionsnix(action="search", query="mapAttrs", source="noogle")
# Get Noogle function infonix(action="info", query="lib.attrsets.mapAttrs", source="noogle")
# Browse Noogle function categoriesnix(action="options", source="noogle", query="lib.strings")
# Search NixOS Wikinix(action="search", query="nvidia", source="wiki")
# Get Wiki page infonix(action="info", query="Flakes", source="wiki")
# Search nix.dev documentationnix(action="search", query="packaging tutorial", source="nix-dev")
# Search NixHub for package metadatanix(action="search", query="nodejs", source="nixhub")
# Get detailed package info from NixHub (license, homepage, store paths)nix(action="info", query="python", source="nixhub")
# Check binary cache statusnix(action="cache", query="hello")
# Check cache for specific versionnix(action="cache", query="python", version="3.12.0")
# Check cache for specific systemnix(action="cache", query="firefox", system="x86_64-linux")
# Get statsnix(action="stats", source="nixos", channel="stable")
# List local flake inputs (requires Nix)nix(action="flake-inputs", type="list")
# Browse files in a flake inputnix(action="flake-inputs", type="ls", query="nixpkgs:pkgs/by-name")
# Read a file from a flake inputnix(action="flake-inputs", type="read", query="nixpkgs:flake.nix")nix_versions - Package Version History
Section titled “nix_versions - Package Version History”Find historical versions with nixpkgs commit hashes. Output includes:
- Package metadata (license, homepage, programs) when available
- Platform availability per version (Linux/macOS)
- Nixpkgs commit hash for reproducible builds
- Attribute path for Nix expressions
nix_versions(package, version, limit)Examples:
# List recent versions with metadatanix_versions(package="python", limit=5)
# Find specific versionnix_versions(package="nodejs", version="20.0.0")Installation
Section titled “Installation”You DON’T need Nix installed. This runs anywhere Python runs.
# Run directly (no install)uvx mcp-nixos
# Or installpip install mcp-nixosFor Nix users:
nix run github:utensils/mcp-nixosnix profile install github:utensils/mcp-nixosDeclarative Installation (NixOS / Home Manager / nix-darwin)
Section titled “Declarative Installation (NixOS / Home Manager / nix-darwin)”mcp-nixos is available in nixpkgs:
# NixOS (configuration.nix)environment.systemPackages = [ pkgs.mcp-nixos ];
# Home Manager (home.nix)home.packages = [ pkgs.mcp-nixos ];
# nix-darwin (darwin-configuration.nix)environment.systemPackages = [ pkgs.mcp-nixos ];Or use the flake directly with the provided overlay:
{ inputs = { nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable"; mcp-nixos.url = "github:utensils/mcp-nixos"; };
outputs = { self, nixpkgs, mcp-nixos, ... }: { # Example: NixOS configuration nixosConfigurations.myhost = nixpkgs.lib.nixosSystem { system = "x86_64-linux"; modules = [{ nixpkgs.overlays = [ mcp-nixos.overlays.default ]; environment.systemPackages = [ pkgs.mcp-nixos ]; }]; };
# Example: Home Manager standalone homeConfigurations.myuser = home-manager.lib.homeManagerConfiguration { pkgs = import nixpkgs { system = "x86_64-linux"; overlays = [ mcp-nixos.overlays.default ]; }; modules = [{ home.packages = [ pkgs.mcp-nixos ]; }]; }; };}Development
Section titled “Development”nix develop # Enter dev shellnix build # Build packagepytest tests/ # Run testsruff check . # Lintruff format . # Formatmypy mcp_nixos/ # Type checkAcknowledgments
Section titled “Acknowledgments”- NixHub.io - Package version history
- search.nixos.org - Official NixOS search
- FlakeHub - Flake registry by Determinate Systems
- Jetify - Creators of Devbox and NixHub
- Noogle - Nix function search engine
- NuschtOS - Static option search infrastructure powering Nixvim support
- Nixvim - Neovim configuration framework for Nix
License
Section titled “License”MIT - Because sharing is caring.
Created by James Brink. Maintained by mass̶o̶c̶h̶i̶s̶t̶s̶ enthusiasts who enjoy Nix.