lazyssh

module
v0.1.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Aug 30, 2025 License: Apache-2.0

README ΒΆ

lazyssh logo

Lazyssh is a terminal-based, interactive SSH manager inspired by tools like lazydocker and k9s β€” but built for managing your fleet of servers directly from your terminal.
With lazyssh, you can quickly navigate, connect, manage, and transfer files between your local machine and any server defined in your ~/.ssh/config. No more remembering IP addresses or running long scp commands β€” just a clean, keyboard-driven UI.


✨ Features

Server Management

  • πŸ“œ Read & display servers from your ~/.ssh/config in a scrollable list.
  • βž• Add a new server from the UI by specifying alias, host/IP, username, port, identity file.
  • ✏ Edit existing server entries directly from the UI.
  • πŸ—‘ Delete server entries safely.
  • πŸ“Œ Pin / unpin servers to keep favorites at the top.
  • πŸ“ Ping server to check status.

Quick Server Navigation

  • πŸ” Fuzzy search by alias, IP, or tags.
  • πŸ–₯ One‑keypress SSH into the selected server (Enter).
  • 🏷 Tag servers (e.g., prod, dev, test) for quick filtering.
  • ↕️ Sort by alias or last SSH (toggle + reverse).

Upcoming

  • πŸ“ Copy files between local and servers with an easy picker UI.
  • πŸ“‘ Port forwarding (local↔remote) from the UI.
  • πŸ”‘ Enhanced Key Management:
    • Use default local public key (~/.ssh/id_ed25519.pub or ~/.ssh/id_rsa.pub)
    • Paste custom public keys manually
    • Generate new keypairs and deploy them
    • Automatically append keys to ~/.ssh/authorized_keys with correct permissions

πŸ“· Screenshots

πŸš€ Startup

App starting splash/loader

Clean loading screen when launching the app


πŸ“‹ Server Management Dashboard

Server list view

Main dashboard displaying all configured servers with status indicators, pinned favorites at the top, and easy navigation


Fuzzy search servers

Fuzzy search functionality to quickly find servers by name, IP address, or tags


βž• Add Server

Add a new server

User-friendly form interface for adding new SSH connections.


πŸ” Connect to server

SSH connection details

SSH into the selected server


πŸ“¦ Installation

Option 1: Download Binary from Release

Download the latest release from GitHub Releases:

# Download and extract (example)
curl -JLO https://github.com/Adembc/lazyssh/releases/download/v0.1.0/lazyssh-darwin-arm64.tar.gz
tar -xzf lazyssh-darwin-arm64.tar.gz

# Make it executable and move to PATH
chmod +x  lazyssh-darwin-arm64
sudo mv lazyssh-darwin-arm64 /usr/local/bin/lazyssh

# run it
lazyssh

Option 2: Build from Source

Requires Go 1.22+

# Clone the repository
git clone https://github.com/Adembc/lazyssh.git
cd lazyssh

# Build for macOS
make build
./bin/lazyssh

# Or Run it directly
make run

⌨️ Key Bindings

Key Action
/ Toggle search bar
↑/↓ Navigate servers
Enter SSH into selected server
c Copy SSH command to clipboard
g Ping selected server
r Refresh background data
a Add server
e Edit server
t Edit tags
d Delete server
p Pin/Unpin server
s Toggle sort field
S Reverse sort order
q Quit

Tip: The hint bar at the top of the list shows the most useful shortcuts.


🀝 Contributing

Contributions are welcome!

  • If you spot a bug or have a feature request, please open an issue.
  • If you'd like to contribute, fork the repo and submit a pull request ❀️.

We love seeing the community make Lazyssh better πŸš€


⭐ Support

If you find Lazyssh useful, please consider giving the repo a star ⭐️ and join stargazers.

β˜• You can also support me by buying me a coffee ❀️


πŸ™ Acknowledgments

Directories ΒΆ

Path Synopsis
internal

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL