A production-ready Model Context Protocol (MCP) server for TrueNAS Core systems. Control and manage your TrueNAS storage through natural language with Claude or other MCP-compatible clients.
- User Management - Create, update, delete users and manage permissions
- Storage Management - Manage pools, datasets, volumes with full ZFS support
- File Sharing - Configure SMB, NFS, and iSCSI shares
- Snapshot Management - Create, delete, rollback snapshots with automation
- System Monitoring - Check system health, pool status, and resource usage
- Type-Safe Operations - Full Pydantic models for request/response validation
- Comprehensive Error Handling - Detailed error messages and recovery guidance
- Production Logging - Structured logging with configurable levels
- Connection Pooling - Efficient HTTP connection management with retry logic
- Rate Limiting - Built-in rate limiting to prevent API abuse
- Environment-Based Config - Flexible configuration via environment variables
The easiest way to run TrueNAS MCP Server is with uvx:
# Run directly without installation
uvx truenas-mcp-server
# Or install globally with uv
uv tool install truenas-mcp-server
# With pip
pip install truenas-mcp-server
# Or with pipx for isolated environment
pipx install truenas-mcp-server
git clone https://github.com/vespo92/TrueNasCoreMCP.git
cd TrueNasCoreMCP
pip install -e .
Create a .env
file or set environment variables:
# Required
TRUENAS_URL=https://your-truenas-server.local
TRUENAS_API_KEY=your-api-key-here
# Optional
TRUENAS_VERIFY_SSL=true # Verify SSL certificates
TRUENAS_LOG_LEVEL=INFO # Logging level
TRUENAS_ENV=production # Environment (development/staging/production)
TRUENAS_HTTP_TIMEOUT=30 # HTTP timeout in seconds
TRUENAS_ENABLE_DESTRUCTIVE_OPS=false # Enable delete operations
TRUENAS_ENABLE_DEBUG_TOOLS=false # Enable debug tools
- Log into TrueNAS Web UI
- Go to Settings β API Keys
- Click Add and create a new API key
- Copy the key immediately (it won't be shown again)
Add to your Claude Desktop config (claude_desktop_config.json
):
{
"mcpServers": {
"truenas": {
"command": "uvx",
"args": ["truenas-mcp-server"],
"env": {
"TRUENAS_URL": "https://your-truenas-server.local",
"TRUENAS_API_KEY": "your-api-key-here",
"TRUENAS_VERIFY_SSL": "false"
}
}
}
}
Note: This uses uvx
to automatically manage the Python environment. Make sure you have uv installed:
# Install uv if you haven't already
curl -LsSf https://astral.sh/uv/install.sh | sh
# or
brew install uv
Once configured, you can interact with TrueNAS using natural language:
"List all storage pools and their health status"
"Create a new dataset called 'backups' in the tank pool with compression"
"Set up an SMB share for the documents dataset"
"Create a snapshot of all datasets in the tank pool"
"Show me users who have sudo privileges"
from truenas_mcp_server import TrueNASMCPServer
# Create server instance
server = TrueNASMCPServer()
# Run the server
server.run()
import asyncio
from truenas_mcp_server.client import TrueNASClient
from truenas_mcp_server.config import Settings
async def main():
# Initialize client
settings = Settings(
truenas_url="https://truenas.local",
truenas_api_key="your-api-key"
)
async with TrueNASClient(settings) as client:
# List pools
pools = await client.get("/pool")
print(f"Found {len(pools)} pools")
# Create a dataset
dataset = await client.post("/pool/dataset", {
"name": "tank/mydata",
"compression": "lz4"
})
print(f"Created dataset: {dataset['name']}")
asyncio.run(main())
list_users
- List all users with detailsget_user
- Get specific user informationcreate_user
- Create new user accountupdate_user
- Modify user propertiesdelete_user
- Remove user account
list_pools
- Show all storage poolsget_pool_status
- Detailed pool health and statisticslist_datasets
- List all datasetscreate_dataset
- Create new dataset with optionsupdate_dataset
- Modify dataset propertiesdelete_dataset
- Remove dataset
list_smb_shares
- Show SMB/CIFS sharescreate_smb_share
- Create Windows sharelist_nfs_exports
- Show NFS exportscreate_nfs_export
- Create NFS exportlist_iscsi_targets
- Show iSCSI targetscreate_iscsi_target
- Create iSCSI target
list_snapshots
- Show snapshotscreate_snapshot
- Create manual snapshotdelete_snapshot
- Remove snapshotrollback_snapshot
- Revert to snapshotclone_snapshot
- Clone to new datasetcreate_snapshot_task
- Setup automated snapshots
debug_connection
- Check connection settingstest_connection
- Verify API connectivityget_server_stats
- Server statistics
truenas_mcp_server/
βββ __init__.py # Package initialization
βββ server.py # Main MCP server
βββ config/ # Configuration management
β βββ __init__.py
β βββ settings.py # Pydantic settings
βββ client/ # HTTP client
β βββ __init__.py
β βββ http_client.py # Async HTTP with retry
βββ models/ # Data models
β βββ __init__.py
β βββ base.py # Base models
β βββ user.py # User models
β βββ storage.py # Storage models
β βββ sharing.py # Share models
βββ tools/ # MCP tools
β βββ __init__.py
β βββ base.py # Base tool class
β βββ users.py # User tools
β βββ storage.py # Storage tools
β βββ sharing.py # Share tools
β βββ snapshots.py # Snapshot tools
βββ exceptions.py # Custom exceptions
# Clone repository
git clone https://github.com/vespo92/TrueNasCoreMCP.git
cd TrueNasCoreMCP
# Create virtual environment
python -m venv venv
source venv/bin/activate # On Windows: venv\Scripts\activate
# Install in development mode
pip install -e ".[dev]"
# Run all tests
pytest
# With coverage
pytest --cov=truenas_mcp_server
# Specific test file
pytest tests/test_client.py
# Format code
black truenas_mcp_server
# Lint
flake8 truenas_mcp_server
# Type checking
mypy truenas_mcp_server
- Installation Guide - Detailed installation instructions
- Quick Start - Get up and running quickly
- Quick Reference - Command reference
- Features Overview - Detailed feature documentation
- API Documentation - Coming soon
Contributions are welcome! Please see CONTRIBUTING.md for guidelines.
- Fork the repository
- Create a feature branch (
git checkout -b feature/amazing-feature
) - Commit your changes (
git commit -m 'Add amazing feature'
) - Push to the branch (
git push origin feature/amazing-feature
) - Open a Pull Request
This project is licensed under the MIT License - see the LICENSE file for details.
- Never commit API keys or credentials
- Use environment variables for sensitive data
- Enable SSL verification in production
- Restrict destructive operations by default
- Report security issues via GitHub Issues
- Issues: GitHub Issues
- Discussions: GitHub Discussions
- Anthropic for the MCP specification
- TrueNAS for the excellent storage platform
- MCP Python SDK contributors
Made with β€οΈ for the TrueNAS community