Vast Storage MCP Server
An MCP (Model Context Protocol) server that enables LLMs to interact with VAST Data storage APIs. This server exposes VAST Data management endpoints as tools for comprehensive storage infrastructure management and automation.
VAST MCP Server
An MCP (Model Context Protocol) server that enables LLMs to interact with VAST Data storage APIs. This server exposes VAST Data management endpoints as tools for comprehensive storage infrastructure management and automation.
Overview
This project implements a Model Context Protocol (MCP) server for the VAST Data storage API, allowing LLMs like GitHub Copilot and Claude to interact with VAST storage infrastructure through natural language commands.
Architecture
- TypeScript for type-safe implementation
- @modelcontextprotocol/sdk for MCP protocol handling
- Axios for HTTP/REST API communication
- Winston for logging (to stderr to avoid protocol corruption)
- OpenAPI 3.0 specification for automatic tool generation
Features
Storage Management
- Views (4 tools): NFS, SMB, and S3 file system views
- Quotas (4 tools): Directory and user quotas with hard/soft limits
Network & Infrastructure
- VIP Pools (4 tools): Virtual IP pool management
- Clusters (2 tools): Cluster monitoring and status
- Nodes (2 tools): Cluster node information and health
Data Protection
- Protected Paths (3 tools): Data protection and replication setup
- Snapshots (4 tools): Snapshot creation and lifecycle management
Access Management
- Users (4 tools): User account management
- Tenants (4 tools): Multi-tenancy configuration
Monitoring & Observability
- Alarms (4 tools): Alarm monitoring, acknowledgement, and management
- Events (2 tools): Event log querying and filtering
- Analytics (2 tools): Performance and capacity analytics with time-series data
Prerequisites
- Node.js 18+ installed
- VSCode with GitHub Copilot or Claude Desktop
- VAST Data cluster with API access
- VAST API credentials (username and password)
Installation
Step 1: Build
npm install
npm run build
Step 2: Configure Environment
Option A: Interactive Setup (Recommended)
node setup.js
Option B: Manual Setup
cp .env.example .env
# Edit .env with your VAST cluster details
Required environment variables:
VAST_API_BASE_URL=https://your-vast-cluster.example.com
VAST_API_USERNAME=your-username
VAST_API_PASSWORD=your-password
VAST_SSL_VERIFY=false
LOG_LEVEL=info
Step 3: Configure LLM Client
For VSCode with GitHub Copilot
-
Open VSCode Settings:
Cmd+Shift+P→ "Preferences: Open User Settings (JSON)" -
Add this configuration to your
settings.json:
{
"github.copilot.chat.mcp.servers": {
"vast": {
"command": "node",
"args": ["/path/to/vast_MCP/dist/main.js"],
"env": {
"VAST_API_BASE_URL": "https://your-vast-cluster.example.com",
"VAST_API_USERNAME": "your-username",
"VAST_API_PASSWORD": "your-password",
"LOG_LEVEL": "info"
}
}
}
}
- Reload VS Code:
Cmd+Shift+P→ "Developer: Reload Window"
For Claude Desktop
-
Locate your Claude Desktop configuration file:
- macOS:
~/Library/Application Support/Claude/claude_desktop_config.json - Windows:
%APPDATA%\Claude\claude_desktop_config.json - Linux:
~/.config/Claude/claude_desktop_config.json
- macOS:
-
Add this configuration to
claude_desktop_config.json:
{
"mcpServers": {
"vast": {
"command": "node",
"args": ["/path/to/vast_MCP/dist/main.js"],
"env": {
"VAST_API_BASE_URL": "https://your-vast-cluster.example.com",
"VAST_API_USERNAME": "your-username",
"VAST_API_PASSWORD": "your-password",
"LOG_LEVEL": "info"
}
}
}
}
- Restart Claude Desktop application
Available Tools
The MCP server automatically generates tools from the VAST API specification:
📁 Views Management (4 tools)
- viewsGetAll - List all file system views
- viewsGetById - Get specific view details
- viewsCreate - Create new file system views (NFS, SMB, S3)
- viewsUpdate - Update view configuration
- viewsDelete - Delete a view
📊 Quotas Management (4 tools)
- quotasGetAll - List all quotas
- quotasGetById - Get specific quota details
- quotasCreate - Create new quotas with hard/soft limits
- quotasUpdate - Update quota configuration
- quotasDelete - Delete a quota
🌐 Network Management (4 tools)
- vippoolsGetAll - List all VIP pools
- vippoolsGetById - Get specific VIP pool details
- vippoolsCreate - Create new VIP pools
- vippoolsUpdate - Update VIP pool configuration
- vippoolsDelete - Delete a VIP pool
🖥️ Cluster Management (4 tools)
- clustersGetAll - List all clusters
- clustersGetById - Get cluster details
- cnodesGetAll - List all cluster nodes
- cnodesGetById - Get node details and status
🛡️ Data Protection (4 tools)
- protectedPathsGetAll - List all protected paths
- protectedPathsGetById - Get protected path details
- protectedPathsCreate - Create new protected paths
- protectedPathsDelete - Delete protected path
📸 Snapshots (4 tools)
- snapshotsGetAll - List all snapshots
- snapshotsGetById - Get snapshot details
- snapshotsCreate - Create new snapshots
- snapshotsDelete - Delete a snapshot
👥 User Management (4 tools)
- usersGetAll - List all users
- usersGetById - Get user details
- usersCreate - Create new users
- usersUpdate - Update user configuration
- usersDelete - Delete a user
🏢 Tenant Management (4 tools)
- tenantsGetAll - List all tenants
- tenantsGetById - Get tenant details
- tenantsCreate - Create new tenants
- tenantsUpdate - Update tenant configuration
- tenantsDelete - Delete a tenant
🚨 Alarms Management (4 tools)
- alarmsGetAll - List all alarms with filtering by severity, state, and category
- alarmsGetById - Get specific alarm details
- alarmsUpdate - Update alarm state (acknowledge or clear alarms)
- alarmsDelete - Delete an alarm
📋 Events Management (2 tools)
- eventsGetAll - List all events with filtering by type, severity, time range, and category
- eventsGetById - Get specific event details
📊 Analytics (2 tools)
- analyticsGetAll - List analytics metrics with filtering by metric type, time range, and interval
- analyticsGetById - Get specific analytics data by ID
## Advanced Configuration
### Using with Multiple VAST Clusters
Configure multiple server instances in your LLM client:
```json
{
"mcpServers": {
"vast-prod": {
"command": "node",
"args": ["/path/to/vast_MCP/dist/main.js"],
"env": {
"VAST_API_BASE_URL": "https://prod-cluster.example.com",
...
}
},
"vast-dev": {
"command": "node",
"args": ["/path/to/vast_MCP/dist/main.js"],
"env": {
"VAST_API_BASE_URL": "https://dev-cluster.example.com",
...
}
}
}
}
Custom OpenAPI Specification
To use a custom or extended VAST API specification:
# In .env or client config
OPENAPI_SPEC_PATH=/path/to/custom_vast_spec.json
References
Server Terkait
Meta Marketing API MCP Server
Interact with Facebook and Instagram advertising data using the Meta Marketing API.
Lido
An MCP server for interacting with the Lido liquid staking protocol.
MCP Bybit API Interface
An interface for interacting with the Bybit cryptocurrency exchange API.
MCP SSH Server
Provides SSH access to remote servers, allowing AI tools to securely connect to your VPS for management.
Weather MCP Tool
Provides real-time weather information for any city, with paywalled access to forecasts.
CISA M365 MCP Server
Implements CISA Binding Operational Directive 25-01 security controls for Microsoft 365 and Azure AD/Entra ID.
AWS MCP
Interact with your AWS environment using natural language to query and manage resources. Requires local AWS credentials.
Google Analytics MCP Server
A structured interface for interacting with Google Analytics APIs, simplifying tasks like querying reports and managing properties.
MCP Gemini CLI
An MCP server for Google's Gemini CLI, allowing AI assistants to leverage Gemini's capabilities.
Remote MCP Server on Cloudflare
An MCP server deployed on Cloudflare Workers, featuring OAuth login and data storage via Cloudflare KV.