SSH password log-in and command automator
Project description
ocsh - SSH password log-in and command automator
ocsh automates SSH password login and command execution through annotations on ssh_config(5)
Hosts:
- password authentication, reading password from pass[1]:
- config:
# ocsh pass <pass-name>
- command:
$ ocsh host
- config:
- post-login command execution:
- config:
# ocsh post <action> "<cmd>"
- command:
$ ocsh host[action]
- config:
- post-login command execution, reading additional password from pass[1]:
- config:
# ocsh postpass <action> "<cmd>" <pass-name>
- command:
$ ocsh host[action]
- config:
- use different ssh command or prefix by other command:
- config:
# ocsh cmd "<ssh-command>"
- config:
# ocsh pre "<pre-command>"
- command:
$ ocsh host
- config:
[1] https://www.passwordstore.org/
Compatibility with OpenSSH is kept as much as possible:
- support usual SSH aliases, keys and command-line options
- compatible with rsync, scp and other tools using SSH for transport, see example commands
- autocompletion can be set-up with --ocsh-install-autocompletion
Usage
usage: ocsh.py [-h] [--ocsh-verbose] [--ocsh-pretend] [--ocsh-examples]
[--ocsh-install-autocompletion]
[destination] ...
ocsh - SSH password log-in and command automator
positional arguments:
destination host[action]
args any OpenSSH options or remote command
options:
-h, --help show this help message and exit
--ocsh-verbose enable debug messages
--ocsh-pretend do not actually perform the connection
--ocsh-examples show example ocsh configuration and commands
--ocsh-install-autocompletion
install bash autocompletion for the current user
Installation
pip install ocsh
Examples of usage
# connect to SSH alias 'host1' with automated password login
# ssh_config(5)
Host host1
Hostname 10.0.0.1
User minou
# ocsh pass pass-location # location in password-store
# command
ocsh host1
# equivalent ssh command
sshpass -p "$(pass pass-location)" ssh host1
# connect to SSH alias 'host2' with automated password login, going through the above 'host1', and become root
# ssh_config(5)
Host host2
Host 10.9.0.1
User root
# ocsh pass pass-location2 # location in password-store
# ocsh postpass su "su -l" pass-location3
# ocsh post nsep "ip netns exec nsep" # post-login command to enter a network namespace
# command
ocsh host2[root]
# equivalent ssh command
sshpass -p "$(pass pass-location2)" ssh -oProxyCommand="sshpass -p "$(pass pass-location1)" ssh host1" host2 su -l
<now enter root password (from pass-location3) manually>
# run ssh connection from a different namespace
# ssh_config(5)
Host host1
Hostname 10.0.0.1
User minou
# ocsh pre "ip netns exec toto"
# command
ocsh host1
# equivalent command
ip netns exec ssh host1
# run rsync through ocsh from host1 with automated password login
rsync -e "ocsh" -avP host1:/etc/hosts /tmp/
# run scp through ocsh from host1 with automated password login
scp -S "ocsh" host1:/etc/hosts /tmp/
See also
- netmiko - python library to SSH to various network devices https://github.com/ktbyers/netmiko
- sshpass - automate SSH password-based log-in https://github.com/kevinburke/sshpass
- passh - sshpass alternative to automate SSH password-based log-in https://github.com/clarkwang/passh
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
ocsh-20230812.tar.gz
(6.2 kB
view details)
Built Distribution
File details
Details for the file ocsh-20230812.tar.gz
.
File metadata
- Download URL: ocsh-20230812.tar.gz
- Upload date:
- Size: 6.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 747bef8df9b73a6d2e8910f8ab4edfc02b3ff34a163984eebd04bb4343ff83cc |
|
MD5 | 2c37b9d17d441dd93e33b68939e1c2bb |
|
BLAKE2b-256 | 489168870a92831d573c8a12c69f07e47a2619e4b45c30eede1987dbc9dece7c |
File details
Details for the file ocsh-20230812-py3-none-any.whl
.
File metadata
- Download URL: ocsh-20230812-py3-none-any.whl
- Upload date:
- Size: 7.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | ca61972f2db07389d4d283980733295bdeeb2bd78a88d2c0aa94a457d4e710ea |
|
MD5 | 74b478bf1f36833759e7bd4e2fd78137 |
|
BLAKE2b-256 | 02f79498569252c0d6217b350492e17cb3fb6702b5ac27ad2d0e9bcd5dc5e245 |