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:
[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 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-20230811.tar.gz
(5.6 kB
view details)
Built Distribution
File details
Details for the file ocsh-20230811.tar.gz
.
File metadata
- Download URL: ocsh-20230811.tar.gz
- Upload date:
- Size: 5.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 307889f6a1d0697d3622e086833596354629eadc89a776cc54f43c9f2fe70e1a |
|
MD5 | 1052297627b811e3fb80bd8af3eaa3bf |
|
BLAKE2b-256 | eb0cea52a33b66c013f47bee40072ad891f338dfd26b671eae8e470ccd10aead |
File details
Details for the file ocsh-20230811-py3-none-any.whl
.
File metadata
- Download URL: ocsh-20230811-py3-none-any.whl
- Upload date:
- Size: 6.5 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 | 6b386cf2f59365556c2402599fd97c5b8b7a52914acfed2e6fba856742a07acf |
|
MD5 | 1f36a31ed09cd07121c399f8c2f55000 |
|
BLAKE2b-256 | 750cf5259ee268c6d41489742b884c239b18dd3fef5619550b4fb7cba2281459 |