Skip to main content

Full SSH terminal for Linux servers with AI/user control and dual-stream visibility

Project description

Remote Terminal

AI-Powered Remote Linux Server Management via MCP

Remote Terminal lets Claude (the AI assistant) execute commands on your remote Linux servers through a natural chat interface. Watch full output in your browser in real-time while Claude receives smart-filtered summaries optimized for token efficiency.


๐ŸŽฏ What Is This?

Imagine telling Claude:

"Install nginx on my server and configure it with SSL"
"Run complete system diagnostics and tell me if anything looks wrong"
"Find all log errors from the last hour and summarize them"
"Save this batch script and run it again next week"

And Claude does it - executing commands, analyzing output, saving useful scripts, and taking action on your behalf.

That's Remote Terminal.


โœจ Key Features

Core Capabilities

  • ๐Ÿ–ฅ๏ธ Remote Command Execution - Run any bash command on Linux servers
  • ๐ŸŒ Multi-Server Management - Switch between multiple servers easily
  • ๐Ÿ“ File Transfer (SFTP) - Upload/download files and directories with compression
  • ๐Ÿ“œ Batch Script Execution - Run multi-command scripts 10-50x faster
  • ๐Ÿ“š Batch Script Library - Save, browse, and reuse batch scripts (NEW in 3.1)
  • ๐Ÿ’ฌ Conversation Tracking - Group commands by goal with rollback support
  • ๐ŸŽฏ Recipe System - Save successful workflows for reuse
  • ๐Ÿ—„๏ธ Database Integration - Full audit trail with SQLite
  • ๐ŸŒ Interactive Web Terminal - Full-featured terminal in browser (type, paste, scroll history)
  • ๐Ÿ”„ Multi-Terminal Sync - Open multiple terminals, all perfectly synchronized
  • โœจ Bash Syntax Highlighting - VS Code-style colors in standalone UI (NEW in 3.1)

The Interactive Web Terminal

Remote Terminal provides a fully interactive terminal window in your browser at http://localhost:8080 - it looks and feels just like WSL, PuTTY, or any standard terminal:

You can:

  • Type commands directly (just like any terminal)
  • Copy/paste text (Ctrl+C, Ctrl+V)
  • Scroll through command history
  • Use arrow keys for history navigation
  • View real-time command output with colors preserved

Claude can:

  • Execute commands that appear in your terminal
  • See command results instantly
  • Continue working while you watch

The key advantage: You maintain complete visibility and control. Every command Claude runs appears in your terminal window in real-time. You're never in the dark about what's happening on your server - it's like sitting side-by-side with an assistant who types commands for you while you watch the screen.

Multi-Terminal Support: Open multiple browser windows at http://localhost:8080 - they all stay perfectly synchronized via WebSocket broadcast. Type in one terminal, see it in all terminals instantly. Perfect for multi-monitor setups or sharing your view with others.

โš ๏ธ Best Practice: Close unused terminal tabs when done. While the system handles multiple connections efficiently, keeping many old tabs open can consume unnecessary resources and may cause connection issues.

๐ŸŽฌ See It In Action

Your browser does not support the video tag.

https://github.com/user-attachments/assets/98a6fa41-ec4f-410b-8d4a-a2422d8ac7c9

Watch the interactive web terminal in action - see Claude execute commands while you maintain full visibility and control

The Dual-Stream Architecture

Behind the scenes, Remote Terminal uses a smart two-stream approach:

           SSH Output from Remote Server
                      โ†“
                  [Raw Output]
                      โ†“
                 โ”Œโ”€โ”€โ”€โ”€โ”ดโ”€โ”€โ”€โ”€โ”
                 โ”‚         โ”‚
                 โ†“         โ†“
             [FULL]    [FILTERED]
                 โ”‚         โ”‚
                 โ†“         โ†“
            Web Terminal    Claude
         (You see all)  (Smart summary)

Result:

  • You: Full visibility and control in interactive terminal
  • Claude: Efficient work with 95% token savings
  • Both: Shared SSH session, synchronized state
  • Best of both worlds!

๐Ÿš€ Quick Start

Installation

Step 1: Create Installation Directory

# Choose a location for your installation (example: C:\RemoteTerminal)
mkdir C:\RemoteTerminal
cd C:\RemoteTerminal

Step 2: Install Package

# Create dedicated virtual environment
python -m venv remote-terminal-env
remote-terminal-env\Scripts\activate
pip install remote-terminal-mcp

Step 3: Configure Claude Desktop

Edit %APPDATA%\Claude\claude_desktop_config.json:

{
    "mcpServers": {
        "remote-terminal": {
            "command": "C:\\RemoteTerminal\\remote-terminal-env\\Scripts\\remote-terminal-mcp.exe",
            "env": {
                "REMOTE_TERMINAL_ROOT": "C:\\RemoteTerminal"
            }
        }
    }
}

Important: Replace C:\RemoteTerminal with your actual installation path from Step 1.

Step 4: First Run - Auto Setup

Restart Claude Desktop. On first use, configuration files will automatically copy to C:\RemoteTerminal:

  • config.yaml - Default settings (auto-created from package defaults)
  • hosts.yaml - Server list (auto-created from template)

Step 5: Configure Your Servers

You have two options to configure your servers:

Option A: Manual Configuration (Recommended for first server)

Edit C:\RemoteTerminal\hosts.yaml:

servers:
  - name: My Server
    host: 192.168.1.100
    user: username
    password: your_password
    port: 22
    description: My development server
    tags:
      - development
# Optional: Set default server for auto-connect
# Use list_servers to see which server is marked as [DEFAULT]
default_server: My Server

Option B: AI-Assisted Configuration

Ask Claude to help you add a new server:

Claude, add a new server to my configuration:
- Name: Production Server
- Host: 192.168.1.100
- User: admin
- Password: mypassword
- Port: 22

Claude will use the add_server tool to update your hosts.yaml file automatically.

Restart Claude Desktop and test:

List my configured servers

Step 6: (Optional) Run Standalone Web Interface

cd C:\RemoteTerminal
remote-terminal-env\Scripts\activate
remote-terminal-standalone

Access at:


๐Ÿ“– Documentation

Complete guides for every use case:


๐Ÿ’ก Usage Examples

System Administration

"Check disk space and memory usage"
"What processes are using the most CPU?"
"Is nginx running? If not, start it"
"Show me the last 50 lines of the system log"

Software Management

"Install htop and verify it works"
"Update all packages"
"Check if docker is installed and what version"

Troubleshooting

"Run complete network diagnostics"
"Find all errors in the last hour of logs"
"Check why nginx won't start"
"Analyze disk usage by directory"

File Operations

"Upload my local config.json to /etc/app/"
"Download all log files from /var/log/myapp/"
"List files in /var/log modified today"
"Find all files larger than 100MB"

Automation & Script Management

"Create a recipe from our successful nginx installation"
"Execute the network diagnostics recipe"
"Start a conversation to configure WiFi"
"List my saved batch scripts"
"Execute script 5"
"Load script 3 for editing"

๐ŸŽจ Example Session

You:

Install nginx on my production server

Claude:

I'll install nginx. This will create a package installation...

Interactive terminal opens automatically at http://localhost:8080

Web Terminal shows (real-time):

$ sudo apt install nginx
Reading package lists... Done
Building dependency tree... Done
[... 500+ lines of installation output ...]
Setting up nginx (1.18.0-0ubuntu1) ...
Created symlink /etc/systemd/system/multi-user.target.wants/nginx.service
Processing triggers for systemd (245.4-4ubuntu3.23) ...

Claude receives (filtered summary):

nginx installed successfully in 45s
12 packages installed
Service: nginx.service is active

Claude responds:

nginx has been successfully installed and is now running. The service is active. Would you like me to configure it or show you the default page?

Token savings: 96% (15,000 tokens โ†’ 600 tokens)


๐Ÿ—๏ธ Architecture

Project Structure

remote_terminal/
โ”œโ”€โ”€ config/                    # Default configuration templates
โ”‚   โ”œโ”€โ”€ config.yaml            # Default settings (packaged)
โ”‚   โ””โ”€โ”€ hosts.yaml.example     # Server template (packaged)
โ”œโ”€โ”€ data/                      # SQLite database (user directory)
โ”‚   โ””โ”€โ”€ remote_terminal.db     # Command history, conversations, recipes, scripts
โ”œโ”€โ”€ docs/                      # Documentation
โ”‚   โ”œโ”€โ”€ QUICK_START.md
โ”‚   โ”œโ”€โ”€ INSTALLATION.md
โ”‚   โ”œโ”€โ”€ USER_GUIDE.md
โ”‚   โ”œโ”€โ”€ FEATURE_REFERENCE.md
โ”‚   โ”œโ”€โ”€ TROUBLESHOOTING.md
โ”‚   โ”œโ”€โ”€ WEBSOCKET_BROADCAST.md
โ”‚   โ””โ”€โ”€ RELEASE_NOTES_v3.1.md
โ”œโ”€โ”€ recipes/                   # Example automation recipes
โ”œโ”€โ”€ src/                       # Source code
โ”‚   โ”œโ”€โ”€ tools/                 # MCP tool modules
โ”‚   โ”‚   โ”œโ”€โ”€ tools_hosts.py     # Server management
โ”‚   โ”‚   โ”œโ”€โ”€ tools_commands.py  # Command execution
โ”‚   โ”‚   โ”œโ”€โ”€ tools_sftp.py      # File transfer
โ”‚   โ”‚   โ”œโ”€โ”€ tools_batch.py     # Batch execution & script management
โ”‚   โ”‚   โ”œโ”€โ”€ tools_conversations.py
โ”‚   โ”‚   โ””โ”€โ”€ tools_recipes.py
โ”‚   โ”œโ”€โ”€ config_init.py         # First-run config setup
โ”‚   โ”œโ”€โ”€ mcp_server.py          # MCP server entry point
โ”‚   โ”œโ”€โ”€ ssh_manager.py         # SSH connection handling
โ”‚   โ”œโ”€โ”€ command_state.py       # Command tracking
โ”‚   โ”œโ”€โ”€ database_manager.py    # SQLite integration
โ”‚   โ”œโ”€โ”€ database_batch.py      # Batch script database
โ”‚   โ”œโ”€โ”€ output_filter.py       # Smart filtering
โ”‚   โ”œโ”€โ”€ prompt_detector.py     # Command completion detection
โ”‚   โ””โ”€โ”€ web_terminal.py        # WebSocket-enabled web interface
โ””โ”€โ”€ standalone/                # Standalone web UI
    โ”œโ”€โ”€ static/
    โ”‚   โ”œโ”€โ”€ css/
    โ”‚   โ”‚   โ””โ”€โ”€ control-styles.css  # Bash syntax highlighting
    โ”‚   โ”œโ”€โ”€ js/
    โ”‚   โ”‚   โ”œโ”€โ”€ control-main.js     # Script loading
    โ”‚   โ”‚   โ””โ”€โ”€ control-forms.js    # Script selectors & highlighting
    โ”‚   โ””โ”€โ”€ tool-schemas/
    โ”‚       โ””โ”€โ”€ batch.json          # Batch tool definitions
    โ”œโ”€โ”€ mcp_control.html
    โ””โ”€โ”€ standalone_mcp.py

Technology Stack

  • Python 3.9+ - Core language
  • MCP Protocol - Claude integration
  • Paramiko - SSH/SFTP library
  • NiceGUI + WebSockets - Web terminal with multi-terminal sync
  • SQLite - Database for history/recipes/scripts
  • FastAPI - Web framework

๐Ÿ”ง Configuration

Configuration Files Location

Configuration files are automatically copied to your working directory on first run:

For PyPI users:

  • Set REMOTE_TERMINAL_ROOT in Claude Desktop config
  • Files auto-copy to that directory on first run
  • Location: %REMOTE_TERMINAL_ROOT%\config.yaml and hosts.yaml
  • User data preserved when reinstalling/upgrading

Default template files packaged with installation:

  • config/config.yaml - Default settings template
  • config/hosts.yaml.example - Server configuration template

hosts.yaml

Define your servers:

servers:
  - name: production
    host: 192.168.1.100
    user: admin
    password: secure_pass
    port: 22
    description: Production server
    tags: production, critical
    
  - name: development
    host: 192.168.1.101
    user: dev
    password: dev_pass
    tags: development

default_server: production

๐Ÿ›ก๏ธ Security Considerations

Current Status

  • Passwords stored in plain text in hosts.yaml
  • Web terminal bound to localhost only (not network-exposed)
  • Full command audit trail in database
  • SSH uses standard security (password authentication)
  • User config files stored outside package (preserved on reinstall)

๐Ÿ“Š Performance

Token Efficiency

Average token savings on verbose commands:

Command Type Full Output Filtered Savings
apt install ~15,000 ~600 96%
ls -la /var ~8,000 ~400 95%
Log search ~12,000 ~500 96%
find / ~30,000 ~800 97%

Average: 95-98% token reduction on verbose commands

Speed Improvements

Batch execution vs sequential:

  • 10 commands sequential: 5 minutes (10 round-trips)
  • 10 commands batch: 30 seconds (1 round-trip)
  • Speed improvement: 10x faster!

๐Ÿ” Advanced Features

Batch Script Library

Save batch scripts for reuse:

1. Run diagnostics โ†’ Script auto-saved with deduplication
2. Browse library โ†’ "List my batch scripts"
3. Execute saved script โ†’ "Execute script 5"
4. Edit existing โ†’ "Load script 3 for editing"
5. Track usage โ†’ times_used, last_used_at

Features:

  • Automatic deduplication via SHA256 hash
  • Usage statistics tracking
  • Edit mode for modifications
  • Search and sort capabilities
  • Two-step deletion with confirmation

Conversation Tracking

Group related commands by goal:

Start conversation: "Configure nginx with SSL"
โ†’ [Execute multiple commands]
โ†’ End conversation: success
โ†’ Create recipe from conversation

Benefits:

  • Organized command history
  • Rollback capability
  • Context for AI
  • Recipe generation

Recipe System

Save successful workflows:

# Recipe: wifi_diagnostics
1. lspci | grep -i network
2. iwconfig
3. ip link show
4. dmesg | grep -i wifi
5. systemctl status NetworkManager

Reuse on any compatible server:

Execute wifi_diagnostics recipe on my new server

Machine Identity

Each server tracked by unique machine_id (hardware + OS fingerprint):

  • Commands tracked per physical machine
  • Recipes execute on compatible systems
  • Audit trail maintains integrity
  • Handles server IP changes

๐Ÿ› Known Issues & Limitations

Current Limitations

  1. Designed for Windows local machine

    • Currently optimized for Windows 10/11
    • Linux/Mac support possible with modifications
  2. SSH Key Support not implemented

    • Password authentication only
    • SSH keys work with manual SSH but not integrated with MCP tools
  3. Works with only one remote server at a time

    • Can configure multiple servers
    • Can only actively work with one server per session
    • Switch between servers as needed

๐Ÿค Contributing

This is Tim's personal project. If you'd like to contribute:

  1. Test thoroughly on your setup
  2. Document any issues found
  3. Suggest improvements
  4. Share recipes and scripts you create

๐Ÿ“œ Version History

Version 1.1.3 (Current - December 20, 2024)

Configuration System Improvements:

  • โœ… Auto-copy config files on first run
  • โœ… User data preserved outside package directory
  • โœ… REMOTE_TERMINAL_ROOT environment variable support
  • โœ… Simplified installation process
  • โœ… Config templates packaged in config/ folder

Version 3.1 (December 16, 2024)

NEW - Batch Script Management:

  • โœ… 5 new MCP tools for batch script library management
  • โœ… Automatic deduplication via SHA256 content hash
  • โœ… Usage statistics tracking (times_used, last_used_at)
  • โœ… Edit mode for modifying saved scripts
  • โœ… Two-step deletion with confirmation
  • โœ… Standalone UI with bash syntax highlighting (VS Code colors)
  • โœ… Script dropdown selectors with auto-population

Tool Renaming (for clarity):

  • โœ… create_diagnostic_script โ†’ build_script_from_commands
  • โœ… execute_batch_script โ†’ execute_script_content

Version 3.0 (December 2024)

  • โœ… Converted from PostgreSQL to SQLite
  • โœ… Eliminated Docker dependency
  • โœ… Multi-server support with server selection
  • โœ… Machine identity tracking (hardware fingerprints)
  • โœ… Conversation management (pause/resume)
  • โœ… Recipe system for automation
  • โœ… Batch script execution with progress tracking
  • โœ… SFTP directory transfer with compression
  • โœ… Comprehensive database integration
  • โœ… Full audit trail
  • โœ… WebSocket-based multi-terminal synchronization

Version 2.0 (October 2024)

  • โœ… Dual-stream architecture
  • โœ… Smart output filtering
  • โœ… Web terminal auto-open
  • โœ… MCP integration with Claude

Version 1.0 (Initial Release)

  • โœ… Basic SSH command execution
  • โœ… Simple web terminal
  • โœ… PostgreSQL backend

๐Ÿ“ž Support

For issues or questions:

  1. Check Documentation

  2. Review Logs

    • Claude Desktop logs (Help โ†’ Show Logs)
  3. Test Components

    • Use standalone mode (start_standalone.ps1)
    • Test SSH manually
    • Verify database (view_db.py)

๐Ÿ“„ License

This project is for personal use by Tim. Not currently open source.


๐Ÿ™ Acknowledgments

  • Anthropic - Claude and MCP protocol
  • Paramiko - SSH library
  • FastAPI - Web framework
  • NiceGUI - UI components with WebSocket support

Ready to let Claude manage your servers? Check out QUICK_START.md to get started in 5 minutes!


Version: 1.2.0 (Auto-config, user data preservation)
Last Updated: December 23, 2024
Maintainer: Tim

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

remote_terminal_mcp-1.2.0.tar.gz (231.0 kB view details)

Uploaded Source

Built Distribution

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

remote_terminal_mcp-1.2.0-py3-none-any.whl (247.6 kB view details)

Uploaded Python 3

File details

Details for the file remote_terminal_mcp-1.2.0.tar.gz.

File metadata

  • Download URL: remote_terminal_mcp-1.2.0.tar.gz
  • Upload date:
  • Size: 231.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.7

File hashes

Hashes for remote_terminal_mcp-1.2.0.tar.gz
Algorithm Hash digest
SHA256 a6cee0a97aa3d0705ce1e7f668592b6c54f9330e44bcb710cae8cfcae9cb9cda
MD5 6f4056a7f6585f82b386c79f7a46e633
BLAKE2b-256 dd23868637a1d4e9e0e4c27e54f17c0855336112fa1f3e24eaabab1cb43ee889

See more details on using hashes here.

File details

Details for the file remote_terminal_mcp-1.2.0-py3-none-any.whl.

File metadata

File hashes

Hashes for remote_terminal_mcp-1.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 1578e86d824a9aac15477e0e38f1cba6e136b869d3ee6350fe78a5a81c0e2504
MD5 73c9ae4f6e6d81264c7f6a214e5570b8
BLAKE2b-256 063e46046afbd7189a8de351cdafd670efe773bc8bf0fa6a3b81b01b76b35447

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