Fire in da houseTop Tip:Paying $100+ per month for Perplexity, MidJourney, Runway, ChatGPT and other tools is crazy - get all your AI tools in one site starting at $15 per month with Galaxy AI Fire in da houseCheck it out free

mcp-server-ssh-rails-runner

MCP.Pizza Chef: tadasant

The mcp-server-ssh-rails-runner is an MCP server enabling secure SSH connections to deployed Rails applications for executing Rails console commands remotely. It supports safe read-only queries, dry-run mutation previews, and controlled execution of database mutations, streamlining data management without complex admin interfaces. Ideal for integrating with tools like Cursor Composer, it facilitates real-time Rails model context usage and efficient remote data operations.

Use This MCP server To

Run Rails console commands remotely over SSH Perform safe read-only queries on deployed Rails apps Execute dry-run mutations to preview database changes Apply approved database mutations securely via SSH Integrate Rails model context with Cursor Composer Manage deployed Rails app data without admin UI Automate remote Rails data wrangling and analysis Control resource usage for remote code execution

README

MCP Server: SSH Rails Runner

An MCP server that enables secure remote execution of Rails console commands via SSH. This server provides tools for both read-only operations and carefully managed mutations in a deployed Rails environment.

This works great with Cursor. You can use Cursor Composer to pull in your Rails model files as context and then use the execute_read_only, dry_run_mutate, and execute_mutate tools to make changes to the database. No need to trudge through complicated Admin UI's to get your data wrangling and analysis done.

Example

Example

Features

  • Remote Rails console execution over SSH
  • Safe read-only operations
  • Dry-run capability for mutations
  • Execution of approved mutations
  • Resource management for code snippets

Installation

npm install
npm run build

Configuration

Set the following environment variables:

SSH_HOST=your.remote.host
SSH_USER=your_ssh_user
SSH_PRIVATE_KEY_PATH=your_SSH_PRIVATE_KEY_PATH
RAILS_WORKING_DIR=/path/to/rails/app

Usage with Claude Desktop

Add to your Claude Desktop configuration:

{
  "mcpServers": {
    "ssh-rails-runner": {
      "command": "npx",
      "args": ["mcp-server-ssh-rails-runner"],
      "env": {
        "SSH_HOST": "your.remote.host",
        "SSH_USER": "your_ssh_user",
        "SSH_PRIVATE_KEY_PATH": "your_SSH_PRIVATE_KEY_PATH",
        "RAILS_WORKING_DIR": "/path/to/rails/app/root",
        "PROJECT_NAME_AS_CONTEXT": "Name that shows up in tool descriptions to help the LLM describe what kind of Rails project we're working with.",
        "CODE_SNIPPET_FILE_DIRECTORY": "/path/to/store/code/snippets/locally"
      }
    }
  }
}

If CODE_SNIPPET_FILE_DIRECTORY is not provided, snippets will be stored in a temporary directory (e.g., /tmp/mcp-ssh-rails-runner-code-snippets). PROJECT_NAME_AS_CONTEXT is optional and helps identify the project context in tool descriptions.

Available Tools

The server now uses a Prepare -> Execute workflow:

mcp_ssh_rails_runner_prepare_code_snippet

  • Arguments: name (string, for filename), type (enum: "readOnly" | "mutate"), code (string, Ruby code), description (string, optional).
  • Function: Saves the provided Ruby code to a local file named code_snippet_<name>.json, marks it as read-only or mutate, and opens the file for review.
  • Returns: The file:// URI of the created snippet.

mcp_ssh_rails_runner_execute_code_snippet_read_only

  • Arguments: uri (string, file:// URI from prepareCodeSnippet).
  • Function: Reads the code snippet from the URI, verifies it's marked as readOnly, performs a safety check on the code, and executes it.
  • Returns: The output of the Rails command.

mcp_ssh_rails_runner_execute_code_snippet_mutate

  • Arguments: uri (string, file:// URI from prepareCodeSnippet).
  • Function: DANGER ZONE! Reads the code snippet, verifies it's marked as mutate, and executes it directly. There is no dry run or further safety check within this tool.
  • Returns: The output of the Rails command.
  • Usage: ONLY CALL THIS AFTER THE USER HAS REVIEWED the prepared code (via the opened file from prepareCodeSnippet) AND EXPLICITLY CONFIRMED they want to execute the mutation.

Security Considerations

  • Only use with trusted SSH endpoints from your own local machine that is (temporarily) provided access to the remote environment.
  • Crucially, always review the code saved by prepareCodeSnippet before executing any mutation with executeCodeSnippetMutate. The responsibility for confirming mutations lies with the user and the calling AI.

License

MIT

mcp-server-ssh-rails-runner FAQ

How do I configure SSH access for this MCP server?
Set environment variables SSH_HOST, SSH_USER, and SSH_PRIVATE_KEY_PATH with your remote host, user, and private key path respectively.
Can I run commands that modify the database?
Yes, but mutations require dry-run approval and explicit execution to ensure safety.
Is this server compatible with Rails model files?
Yes, it works well with tools like Cursor Composer to pull Rails model context for command execution.
What safety features are included?
It supports read-only operations, dry-run mutation previews, and controlled mutation execution to prevent accidental data loss.
How does this server handle resource management?
It manages code snippet execution resources to maintain performance and security during remote operations.
Can this server be used with multiple Rails environments?
Yes, by configuring SSH access to different hosts or environments, you can manage multiple deployments.
What dependencies are required to install this server?
Installation requires Node.js with npm; run 'npm install' and 'npm run build' to set up.
How does this server integrate with MCP clients?
It exposes structured Rails console command execution tools accessible by MCP clients for seamless remote interaction.