Files
incus-mcp/README.md
kappa 31d0e9b97f Fix npm package deployment and usage documentation
🔧 Resolve npmjs deployment issue:
- Add npm global installation guide (npm install -g @ironclads/incus-mcp)
- Update Claude Desktop configuration with two options
- Fix mcp-config-example.json to use global binary
- Update CLAUDE.md with correct remote server list (removed lambda)

 npm package now works correctly with global installation
📚 Documentation updated with clear installation options

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-08-10 21:53:37 +09:00

340 lines
8.5 KiB
Markdown

# Incus MCP Server
A comprehensive Model Context Protocol (MCP) server for managing Incus containers and virtual machines. This server provides a complete set of tools and resources to interact with Incus instances locally and across remote servers through the MCP protocol.
## ⭐ Key Features
### 🛠 Tools (10 Available)
- **incus_list_instances**: List all instances with their current status (supports remote servers)
- **incus_show_instance**: Show detailed information about a specific instance
- **incus_start_instance**: Start stopped instances
- **incus_stop_instance**: Stop running instances (with optional force flag)
- **incus_restart_instance**: Restart instances (with optional force flag)
- **incus_create_instance**: Create new instances from images with custom configuration
- **incus_delete_instance**: Delete instances (with optional force flag)
- **incus_exec_command**: Execute commands inside running instances
- **incus_list_remotes**: List all configured remote servers
- **incus_info**: Show comprehensive Incus system information
### 📚 Resources (2 Available)
- **incus://instances/list**: JSON list of all instances across all remotes
- **incus://remotes/list**: JSON list of all configured remote servers with connection details
### 🌐 Multi-Remote Support
Seamlessly works with all your configured Incus remotes:
- **Local instances**: Direct access to local Incus daemon
- **Remote servers**: Full support for TLS-authenticated remote Incus servers
- **Image sources**: Integration with LinuxContainers.org, Docker Hub, GitHub Container Registry
- **Automatic discovery**: Automatically detects and works with existing remote configurations
## 📋 Prerequisites
- **Node.js 18+**: Required for running the TypeScript/JavaScript server
- **Incus installed**: Working Incus installation with daemon running
- **Proper permissions**: User must be in `incus` group or have appropriate file access
- **Remote configuration**: Pre-configured remote servers (optional but recommended)
## 🚀 Quick Start
### Installation from NPM (Recommended)
```bash
# Global installation (recommended for Claude Desktop)
npm install -g @ironclads/incus-mcp
# Verify installation
incus-mcp --version
which incus-mcp
```
### Installation from Source
```bash
# Clone the repository
git clone https://github.com/your-username/incus-mcp.git
cd incus-mcp
# Install dependencies
npm install
# Build the project
npm run build
# Test the installation
npm test
```
### Verify Incus Setup
```bash
# Check Incus is working
incus version
incus list
incus remote list
```
## 💻 Usage
### Standalone MCP Server
```bash
# Run the server directly
node build/index.js
# Development mode with auto-reload
npm run dev
# Production mode
npm start
```
### Integration with Claude Desktop
Add to your Claude Desktop MCP configuration (`~/.config/claude-desktop/config.json`):
#### Option 1: Using Global NPM Installation (Recommended)
```json
{
"mcpServers": {
"incus": {
"command": "incus-mcp",
"env": {
"PATH": "/usr/local/bin:/opt/homebrew/bin:/usr/bin:/bin"
}
}
}
}
```
#### Option 2: Using Local Installation
```json
{
"mcpServers": {
"incus": {
"command": "node",
"args": ["/absolute/path/to/incus-mcp/build/index.js"],
"env": {
"PATH": "/usr/local/bin:/opt/homebrew/bin:/usr/bin:/bin"
}
}
}
}
```
### Integration with Claude Code
The repository includes `.mcp.json` for local development:
```json
{
"mcpServers": {
"incus": {
"command": "node",
"args": ["/Users/kaffa/mcp-servers/incus-mcp/build/index.js"]
}
}
}
```
## 🔧 Development
### Development Workflow
```bash
# Install dependencies
npm install
# Development mode with auto-reload
npm run dev
# Build TypeScript to JavaScript
npm run build
# Run comprehensive tests
node test/simple-test.js
node test/resource-test.js
# Code quality
npm run lint
npm run format
```
### Project Structure
```
incus-mcp/
├── src/
│ ├── index.ts # Main MCP server implementation
│ ├── incus.ts # Incus command execution utilities
│ └── schemas.ts # MCP tool/resource schema definitions
├── test/
│ ├── simple-test.js # Basic functionality tests
│ └── resource-test.js # Resource reading tests
├── build/ # Compiled JavaScript output
├── .mcp.json # Local MCP server configuration
└── mcp-config-example.json # Claude Desktop config template
```
## ⚙️ Configuration
### System Requirements
The server automatically uses your existing Incus configuration:
1. **Incus daemon running**: `systemctl status incus` (Linux) or check process list
2. **User permissions**: Member of `incus` group or appropriate file access
3. **Remote servers**: Pre-configured remotes work automatically
### Setting up Remote Servers
```bash
# Add a remote Incus server
incus remote add myserver https://server.example.com:8443
# Add with custom certificate
incus remote add myserver https://server.example.com:8443 --password
# List all configured remotes
incus remote list
# Test remote connection
incus list myserver:
```
### Environment Variables
```bash
# Optional: Custom PATH for incus binary
export PATH="/opt/incus/bin:$PATH"
# Optional: Debug MCP communication
export MCP_DEBUG=1
```
## 📖 Usage Examples
### Basic Instance Management
```bash
# Via MCP tools (conceptual - actual usage through MCP client)
incus_list_instances: {}
# Returns: List of all instances across all remotes
incus_create_instance: {
"name": "webserver",
"image": "ubuntu:22.04",
"config": {"limits.cpu": "2", "limits.memory": "2GB"}
}
incus_start_instance: {"name": "webserver"}
```
### Remote Operations
```bash
incus_list_instances: {"remote": "remote1"}
# Lists instances only from the remote1 server
incus_show_instance: {"name": "myapp", "remote": "remote2"}
# Shows details for 'myapp' instance on remote2 server
```
### Command Execution
```bash
incus_exec_command: {
"instance": "webserver",
"command": "apt update && apt install -y nginx",
"remote": "remote1"
}
```
### Resource Access
- `incus://instances/list` → JSON array of all instances with full metadata
- `incus://remotes/list` → JSON object with remote server configurations
## 🛡️ Security & Error Handling
### Security Features
- **Input validation**: All arguments validated with Zod schemas
- **Command sanitization**: No shell injection vulnerabilities
- **Permission isolation**: Uses existing Incus user permissions
- **Remote auth**: Leverages configured TLS certificates
- **Audit trail**: All commands logged through Incus
### Error Handling
- **Graceful failures**: Comprehensive error messages without exposing internals
- **Network timeouts**: Proper handling of remote server connectivity issues
- **Permission errors**: Clear guidance for permission-related problems
- **Invalid arguments**: Detailed validation error messages
## 🐛 Troubleshooting
### Common Issues & Solutions
#### 1. Permission Denied
```bash
# Add user to incus group
sudo usermod -a -G incus $USER
newgrp incus
# Verify permissions
id | grep incus
incus list # Should work without sudo
```
#### 2. Incus Not Found
```bash
# Check installation
which incus
incus version
# Install on Ubuntu/Debian
curl -fsSL https://packagecloud.io/install/repositories/candid/incus/script.deb.sh | sudo bash
sudo apt install incus
# Install on macOS
brew install incus
```
#### 3. Remote Connection Issues
```bash
# Verify remote configuration
incus remote list
# Test connectivity
incus info remote-name:
# Re-add problematic remote
incus remote remove old-remote
incus remote add old-remote https://server:8443
```
#### 4. MCP Server Issues
```bash
# Test MCP server directly
node build/index.js
# Should show: "Incus MCP server running on stdio"
# Check build output
npm run build
ls -la build/
# Run test suite
node test/simple-test.js
```
### Debug Mode
```bash
# Enable verbose logging
DEBUG=mcp* node build/index.js
# Test individual tools
echo '{"jsonrpc":"2.0","id":1,"method":"tools/list"}' | node build/index.js
```
## 🤝 Contributing
1. Fork the repository
2. Create a feature branch: `git checkout -b feature-name`
3. Make your changes and add tests
4. Run the test suite: `node test/*.js`
5. Submit a pull request
## 📄 License
MIT License - see LICENSE file for details.
---
**Built with ❤️ for the Incus and MCP communities**
For support, please open an issue on GitHub or check the [MCP documentation](https://modelcontextprotocol.io/).