Skip to main content

An open source, MIT-licensed command line tool for managing per-project ssh configs.

Project description

Clove Hitch Logo

Lassh

An open source, MIT-licensed command line tool for managing per-project ssh configs.

Using a ssh config

ssh allows the use of a config plaintext file, usually located in ~/.ssh/config, that allows you to customize ssh in a whole host (heh) of ways. One primary use is the creation of aliases for hosts.

However, a single global config file for ssh can quickly become unwieldy and messy (motivating stack exchange).

Introducing Lassh

A CLI to manage your global ssh config and to allow for per-project configurations.

Installation

Lassh requires Python 3. Run pip install lassh. If you haven't already, check out pyenv for python version management and pipenv for dependency management, though they aren't neccesary for using Lassh.

Getting Started

  1. cd into your project (or lab or class or secret government R&D group) directory that you want to configure ssh for.

Initializing Lassh

  1. lassh init will create a global config and a project lassh.config (if they don't already exist). Note: lassh.config files are valid plaintext .ssh/config files. Lassh will then link your new or existing lassh.config to the global config! But you don't have any new hosts to connect to...

Adding Hosts

  1. lassh addhost beepboop computer.dartmouth.edu stevenchun adds a host now called beepboop that points to stevenchun@computer.dartmouth.edu. You can also specify a path to identity keys using the --key option and a port with the --port option. If you leave the user out, it will default to root.

It's important to remember that while Lassh allows you to distribute your config files, the ssh alias namespace is global so you can't have the same alias in two different lassh.config files.

Deleting Hosts

  1. lassh deletehost beepboop deletes the host we just made from our local lassh.config. (It does not remove the link from our project lassh.config to the global config)

Teardown

  1. lassh teardown unlinks and deletes the lassh.config in the current directory from the global config. Warning: this deletes all aliases you have in the project's lassh.config

Other Operations

Since each lassh.config is a valid ssh config file, if you want to add an option like LocalForward, simply add the host and manually edit the lassh.config file to add more options (or contribute to add the relevant feature to Lassh!!).

Testing

Tests can be run using python -m unittest test.test_lassh while in the lassh python package directory.

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

lassh-0.1.1.tar.gz (6.4 kB view hashes)

Uploaded Source

Built Distribution

lassh-0.1.1-py3-none-any.whl (7.7 kB view hashes)

Uploaded Python 3

Supported by

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