Piotr1215/vcluster-yaml-mcp
If you are the rightful owner of vcluster-yaml-mcp and would like to certify it and/or have it hosted online, please leave a comment on the right or send an email to dayong@mcphub.com.
A Model Context Protocol (MCP) server that allows AI assistants to query and validate vCluster YAML configurations directly from GitHub.
vCluster YAML MCP Server
A Model Context Protocol (MCP) server that lets AI assistants query and validate vCluster YAML configurations directly from GitHub.
What Does It Do?
This MCP server provides AI assistants with tools to:
- Query vCluster configuration options and schemas
- Validate YAML configurations
- Search for specific settings using natural language
- Query any version with explicit version parameters (stateless)
- Extract validation rules from comments
Key feature: No local files needed. All data is fetched live from the vCluster GitHub repository.
How It Works
The server uses the GitHub API to fetch vCluster YAML configurations, schemas, and documentation directly from the source:
- GitHub as Source of Truth: Queries
github.com/loft-sh/vclusterrepository - Stateless Version Queries: Every tool accepts an optional
versionparameter (e.g.,v0.19.0,main) - Parallel Version Support: Query multiple versions simultaneously without state conflicts
- Live Data: Always fetches the latest configuration for the requested version
- Smart Caching: 15-minute in-memory cache to avoid overloading GitHub API
graph LR
A[Claude/AI] --> B[MCP Server]
B --> C[GitHub API]
C --> D[vCluster Repository]
B --> E[Parse YAML/JSON]
E --> F[Return Structured Data]
F --> A
Installation
Option 1: Local (stdio)
Run the server locally via npx:
{
"mcpServers": {
"vcluster-yaml": {
"command": "npx",
"args": ["-y", "vcluster-yaml-mcp-server@latest"]
}
}
}
Option 2: Remote (HTTP)
Use the public instance (always running latest version):
{
"mcpServers": {
"vcluster-yaml": {
"type": "http",
"url": "https://vcluster-yaml.cloudrumble.net/mcp"
}
}
}
Command-Line Interface
The package also provides a standalone CLI for quick queries and validation without MCP setup:
# Quick start with npx (no installation)
npx vcluster-yaml-mcp-server query sync
# Or install globally
npm install -g vcluster-yaml-mcp-server
vcluster-yaml query sync
# Validate configurations with ease
vcluster-yaml validate my-config.yaml
cat my-config.yaml | vcluster-yaml validate -
vcluster-yaml validate my-config.yaml --schema-version v0.24.0
# Shell completion (bash/zsh)
vcluster-yaml completion bash 2>/dev/null > ~/.vcluster-yaml-completion.bash
vcluster-yaml completion zsh 2>/dev/null > ~/.zsh/completion/_vcluster-yaml
📖
Available Tools
Version Discovery
list-versions - Browse all available vCluster versions
// Returns tags (releases) and branches
// Example output: v0.19.0, v0.20.0, main, etc.
Configuration Queries
All query tools accept an optional version parameter (defaults to "main"):
smart-query - Universal search using dot notation or natural language
smart-query --query="controlPlane.ingress.enabled" --version="v0.19.0"
smart-query --query="namespace syncing" --version="main"
smart-query --query="etcd" // Defaults to "main"
Output Format (kubectl-style):
Found 4 matches for "replicas" in chart/values.yaml (v0.24.0)
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
MATCH: controlPlane.statefulSet.highAvailability.replicas
TYPE: integer
VALUE: 1
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
MATCH: controlPlane.coredns.deployment.replicas
TYPE: integer
VALUE: 1
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
MATCH: controlPlane.statefulSet.highAvailability
TYPE: object
FIELDS:
replicas <integer>
value: 1
leaseDuration <integer>
value: 60
renewDeadline <integer>
value: 40
retryPeriod <integer>
value: 15
RELATED CONFIGS:
• controlPlane.statefulSet.resources - Resource limits for HA mode
• controlPlane.backingStore.etcd.deploy.statefulSet.highAvailability
Features:
- ✅ Structured output - kubectl-style format
- ✅ Type information - Every value shows its type (integer, string, boolean, array, object)
- ✅ Relevance ranking - Exact matches appear first, results sorted by relevance
- ✅ Related configs - Suggests commonly configured fields together
- ✅ Smart formatting - Objects show structure, not full content dumps
- ✅ LLM-friendly - Easy to parse and understand for AI assistants
Config Creation & Validation
All validation tools accept an optional version parameter (defaults to "main"):
create-vcluster-config - Create and validate configs in one step (PRIMARY TOOL)
// Claude uses this when generating configs for you
// Ensures every generated config is validated before you see it
create-vcluster-config --yaml_content="<generated-yaml>" --description="Node sync config" --version="v0.24.0"
// Returns:
// ✅ Configuration validated successfully!
// Version: v0.24.0
// Section: sync
// Validation time: 45ms
//
// ### Configuration:
// [your YAML here]
validate-config - Validate existing YAML configs
// Validate user-provided configs against specific version
validate-config --content="<your-yaml>" --version="v0.24.0"
// Validate files from GitHub
validate-config --file="chart/values.yaml" --version="main"
// Works with full configs or partial snippets (auto-detects section)
// Returns: { valid: true/false, errors: [...], section: "...", version: "...", elapsed_ms: <100 }
extract-validation-rules - Get validation rules from YAML comments
extract-validation-rules --section="controlPlane" --version="v0.24.0"
// Returns: { rules, enums, dependencies, defaults }
// Extracts constraints like "Valid values: a, b, c"
Usage Examples
Interactive Config Creation (Primary Workflow)
Ask Claude:
"Create a vCluster config with node sync enabled and etcd embedded"
Claude will:
- Use
smart-queryorextract-validation-rulesto research options - Generate the YAML configuration
- Automatically call
create-vcluster-configto validate - Return validated, ready-to-use configuration
Why this works: The create-vcluster-config tool forces Claude to validate every config it generates. You'll always get validated configs.
Validate User-Provided Configuration
Ask Claude:
"Is this ingress configuration valid for vCluster v0.24?"
ingress: enabled: true host: "my-vcluster.example.com"
Claude will:
- Use
validate-configwith--version="v0.24.0"parameter - Report any validation errors with specific paths
- Suggest fixes if needed
Explore vCluster Options
Ask Claude:
"What high availability options are available in vCluster v0.19.0?"
Claude will use:
smart-querywith--version="v0.19.0"to find HA-related settings- No need to "switch" versions - query directly with version parameter
Compare Versions
Ask Claude:
"How did the sync.fromHost configuration change between v0.19.0 and v0.20.0?"
Claude will use:
smart-querywith--version="v0.19.0"for first versionsmart-querywith--version="v0.20.0"for second version- Can query both versions in parallel (stateless design)
Token Optimization
This server is designed for efficient token usage with the new kubectl-style format:
| Tool | Tokens | Strategy | Performance |
|---|---|---|---|
| create-vcluster-config | ~300-600 | Validation + formatted response with emoji indicators | <100ms |
| validate-config | ~200-500 | Fast validation, precise errors only | <100ms |
| smart-query | ~800-1.5K | Structured output (was ~2K with JSON dumps), limits to 50 matches | <100ms |
| extract-validation-rules | ~2-5K | Section-specific filtering, cache for knowledge base | <100ms |
Development
# Install dependencies
npm install
# Run locally (stdio)
node src/index.js
# Test with MCP Inspector
npx @modelcontextprotocol/inspector node src/index.js
# Open http://localhost:5173
# Run tests
npm test
# Run HTTP server locally
npm run start:http
# Server runs on http://localhost:3000
Technical Details
- SDK:
@modelcontextprotocol/sdkv1.20.1 (Streamable HTTP transport) - Node: >=18
- Transport: Both stdio (local) and HTTP/SSE (remote)
- Dependencies:
js-yamlfor parsing,node-jqfor querying,node-fetchfor GitHub API
Release Process
This project uses automated CI/CD workflows for releases to npm, Docker Hub, and GitHub Releases.
📖
Links
License
MIT