Skip to main content

Model Context Protocol (MCP) server for Dell PowerScale (Isilon) OneFS 9.7 REST API integration - enables AI assistants to interact with PowerScale storage clusters

Project description

Isilon MCP Server

PyPI version Python 3.10+ Tests codecov License: MIT

A professional-grade Model Context Protocol (MCP) server for Dell PowerScale (Isilon) OneFS API integration. This server enables AI assistants like Claude to interact with PowerScale storage clusters through a comprehensive set of tools generated from the OneFS 9.7 REST API specification.

Features

  • ๐Ÿš€ Complete API Coverage: 2,434 operations across 46 categories
  • ๐Ÿ” Secure Authentication: Basic Auth with TLS support
  • ๐Ÿ“ฆ Dynamic Tool Generation: Auto-generates MCP tools from OpenAPI spec
  • ๐Ÿ”„ Multiple Transports: stdio (Claude Desktop) and HTTP/SSE (n8n)
  • ๐Ÿ“ Comprehensive Logging: Structured JSON and colored console output
  • โšก Async/Await: Built on httpx for high-performance async operations
  • ๐Ÿ›ก๏ธ Credential-Free Mode: Explore available tools without credentials

Supported API Categories

Category Operations Description
Auth 373 Authentication, users, groups, roles, providers
Protocols 351 SMB, NFS, HDFS, S3, HTTP, FTP, Swift
Sync 185 SyncIQ replication policies, reports, jobs
Cluster 167 Cluster management, nodes, configuration
Network 153 Networking, subnets, pools, interfaces
Datamover 151 Data migration, accounts, policies
Cloud 136 CloudPools, tiering, accounts
Snapshot 117 Snapshot schedules, aliases, locks
Upgrade 85 Cluster upgrade management
Event 83 Event channels, alerts, settings
Quota 78 SmartQuotas management
Job 72 Job engine, policies, reports
... ... And 34 more categories!

Quick Start

Prerequisites

  • Python 3.10 or higher
  • Access to a Dell PowerScale cluster with REST API enabled
  • API credentials with appropriate permissions

Installation

From PyPI (Recommended)

# Install the package
pip install isilon-mcp-server

# Or install with HTTP server support for n8n
pip install "isilon-mcp-server[http]"

From Source

# Clone the repository
git clone https://github.com/sachdev27/isilon-mcp-server.git
cd isilon-mcp-server

# Create virtual environment
python -m venv venv
source venv/bin/activate  # On Windows: venv\Scripts\activate

# Install the package
pip install -e .

# Or install with HTTP server support for n8n
pip install -e ".[http]"

Configuration

  1. Copy the example environment file:
cp .env.example .env
  1. Edit .env with your PowerScale credentials:
ISILON_HOST=your-powerscale-host
ISILON_USERNAME=admin
ISILON_PASSWORD=your-secure-password
ISILON_PORT=8080
ISILON_TLS_VERIFY=true

Running the Server

stdio Transport (for Claude Desktop)

# Using the CLI
isilon-mcp

# Or using Python module
python -m isilon_mcp.main

HTTP/SSE Transport (for n8n or web clients)

# Start HTTP server
python -m isilon_mcp.http_server

# With custom host/port
python -m isilon_mcp.http_server --host 0.0.0.0 --port 8000

Claude Desktop Integration

Add to your Claude Desktop configuration (~/Library/Application Support/Claude/claude_desktop_config.json on macOS):

{
  "mcpServers": {
    "isilon": {
      "command": "/path/to/venv/bin/python",
      "args": ["-m", "isilon_mcp.main"],
      "cwd": "/path/to/isilon-mcp-server",
      "env": {
        "ISILON_HOST": "your-powerscale-host",
        "ISILON_USERNAME": "admin",
        "ISILON_PASSWORD": "your-password"
      }
    }
  }
}

n8n Integration

  1. Start the HTTP server:
python -m isilon_mcp.http_server --host 0.0.0.0 --port 8000
  1. In n8n, add an MCP Client node pointing to:
http://localhost:8000/sse

Example Usage

Once connected, you can ask Claude to:

  • "List all SMB shares on the cluster"
  • "Show me the cluster health status"
  • "Create a new NFS export for /ifs/data/project1"
  • "Get all snapshots older than 30 days"
  • "Show active SyncIQ policies"
  • "List users in the local provider"

Project Structure

isilon-mcp-server/
โ”œโ”€โ”€ isilon_mcp/
โ”‚   โ”œโ”€โ”€ __init__.py          # Package exports
โ”‚   โ”œโ”€โ”€ api_client.py        # Async HTTP client with Basic Auth
โ”‚   โ”œโ”€โ”€ config.py            # Pydantic configuration models
โ”‚   โ”œโ”€โ”€ exceptions.py        # Exception hierarchy
โ”‚   โ”œโ”€โ”€ http_server.py       # HTTP/SSE transport for n8n
โ”‚   โ”œโ”€โ”€ logging_config.py    # Structured logging
โ”‚   โ”œโ”€โ”€ main.py              # CLI entry point (stdio)
โ”‚   โ”œโ”€โ”€ server.py            # Core MCP server
โ”‚   โ””โ”€โ”€ tool_generator.py    # OpenAPI to MCP tool generator
โ”œโ”€โ”€ powerscale_9.7_comprehensive_openapi.json  # Full API spec
โ”œโ”€โ”€ pyproject.toml           # Package configuration
โ”œโ”€โ”€ requirements-mcp.txt     # Dependencies
โ”œโ”€โ”€ .env.example             # Configuration template
โ””โ”€โ”€ README.md                # This file

Development

Running Tests

# Install dev dependencies
pip install -e ".[dev]"

# Run tests
pytest

# With coverage
pytest --cov=isilon_mcp --cov-report=html

Code Quality

# Format code
black isilon_mcp/
isort isilon_mcp/

# Lint
ruff check isilon_mcp/

# Type checking
mypy isilon_mcp/

API Reference

Tool Naming Convention

Tools are named using the pattern:

{category}_{operationId}

Examples:

  • auth_list_providers - List authentication providers
  • protocols_list_smb_shares - List SMB shares
  • snapshot_create_snapshot - Create a new snapshot
  • cluster_get_cluster_config - Get cluster configuration

Authentication

The server uses HTTP Basic Authentication with your PowerScale credentials. All requests are made over HTTPS by default.

Error Handling

The server provides detailed error messages for:

  • Authentication failures
  • Connection errors
  • Rate limiting
  • API validation errors

Security Considerations

  1. Never commit .env files - They contain sensitive credentials
  2. Use TLS verification - Set ISILON_TLS_VERIFY=true in production
  3. Principle of least privilege - Use API users with minimal required permissions
  4. Read-only mode - Set READ_ONLY_MODE=true for monitoring-only access

Troubleshooting

Connection Issues

# Test connection manually
curl -k -u username:password https://your-host:8080/platform/18/cluster/config

Certificate Errors

If using self-signed certificates:

ISILON_TLS_VERIFY=false  # Only for testing!

Debug Mode

Enable detailed logging:

LOG_LEVEL=DEBUG
DEBUG_HTTP=true

License

MIT License - see LICENSE for details.

Contributing

Contributions are welcome! Please read our contributing guidelines and submit pull requests.

Acknowledgments

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

isilon_mcp_server-1.0.0.tar.gz (58.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

isilon_mcp_server-1.0.0-py3-none-any.whl (31.9 kB view details)

Uploaded Python 3

File details

Details for the file isilon_mcp_server-1.0.0.tar.gz.

File metadata

  • Download URL: isilon_mcp_server-1.0.0.tar.gz
  • Upload date:
  • Size: 58.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.7

File hashes

Hashes for isilon_mcp_server-1.0.0.tar.gz
Algorithm Hash digest
SHA256 7352e20380ae4bbe28ec024a145626621c107648e4a96e8de72a4f3714b7c059
MD5 c6af5b1639268c5e18c6a9759f8b05da
BLAKE2b-256 3b7e20da2bf08370e9afe9bfad4028c86c8704c410223b4cc9584bef569c56a1

See more details on using hashes here.

File details

Details for the file isilon_mcp_server-1.0.0-py3-none-any.whl.

File metadata

File hashes

Hashes for isilon_mcp_server-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 f17fb52e952f110188e9f921ce7044cba1af7453a4b9128579f6ae91143e5a97
MD5 35b9e4174dcc5b356826c4dd35acb676
BLAKE2b-256 332dc1fcba8330168801c28f4526d623b40d2dc2f819f503bb1d076030e57175

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page