SSH config generator based on Ansible hosts yaml file
Project description
sshgen
[!IMPORTANT] This repository contains software that is currently in the Beta stage.
SSH configuration generator based on your Ansible hosts YAML file.
Current version: v0.8.0
Table of Contents
Features
- Generates a
config
file to merge with your existing SSH configuration or include as a separate.conf
file (since v0.6.0). - Custom configuration for ssh-agent.
- Custom SSH aliases for quick connections.
- Skip selected hosts from results file.
Installation
Using pip
pip install --user git+https://github.com/pythoninja/sshgen@v0.8.0
Or
pip install --user sshgen
Using pipx
pipx install git+https://github.com/pythoninja/sshgen@v0.8.0
Or just run without installing:
pipx run sshgen
Usage
Before using this tool, make sure you have an Ansible hosts.yml
in your current working directory.
Consider the following example hosts.yml
file, which defines 2 host groups with a total of 4 hosts:
group1: # host_group
hosts:
host1: # host
ansible_host: 127.0.0.1
ansible_user: root
_meta:
_auth_type: IdentityAgent
_auth_path: ~/.1password/agent.sock
_aliases: [ "base", "another-alias" ]
_skip: false
host2:
ansible_host: 127.0.0.2
ansible_user: manager
ansible_password:
ansible_port: 19020
_meta:
_skip: true
group2:
hosts:
host3:
ansible_host: 172.19.0.1
ansible_user: postgres
ansible_password:
ansible_port: 19222
host4:
ansible_host: 172.99.99.99
ansible_user: postgres
_meta:
_auth_type: IdentityAgent
_auth_path: ~/.1password/agent.sock
_aliases: [ "base", "another-alias" ]
_skip: false
To use sshgen
, you can either invoke it as a Python module using python -m sshgen --help
or directly use the
command sshgen --help
.
By default, sshgen
looks for the hosts.yml
file in your current working directory. To generate the SSH
configuration, run the following command:
sshgen generate
To display addition logs (verbose mode), add --verbose
flag:
sshgen --verbose generate
Or use SSHGEN_DEBUG=1
(SSHGEN_VERBOSE=1
) environment variable (since v0.5.0):
SSHGEN_DEBUG=1 sshgen generate
After executing the command, you will see the following output:
[2024-03-10 10:00:00] [INFO] - Generated SSH config file was saved to /my_dir/config
[2024-03-10 10:00:00] [INFO] - Total processed hosts: 3, total skipped hosts: 1
Check the file contents cat /my_dir/config
:
Host host1 base another-alias # group1
HostName 127.0.0.1
User root
Port 22
IdentityAgent ~/.1password/agent.sock
Host host3 # group2
HostName 172.19.0.1
User postgres
Port 19222
IdentityFile ~/.ssh/ssh_key
IdentitiesOnly yes
Host host4 postgres-server # group2
HostName 172.99.99.99
User postgres
Port 22
IdentityAgent ~/.1password/agent.sock
If you run using verbose mode, you should see additional information:
Verbose output example
[2024-03-10 10:00:00] [DEBUG] - Loading ansible hosts file: /home/user/code/python/sshgen/examples/hosts.yml
[2024-03-10 10:00:00] [DEBUG] - Total hosts found (include skipped): 4
[2024-03-10 10:00:00] [DEBUG] - Using template file /home/user/code/python/sshgen/sshgen/templates/ssh_config.template to generate ssh config
[2024-03-10 10:00:00] [DEBUG] - Filtering hosts where _skip metafield was defined
[2024-03-10 10:00:00] [DEBUG] - Host host1 should be skipped: False
[2024-03-10 10:00:00] [DEBUG] - Host host2 should be skipped: True
[2024-03-10 10:00:00] [DEBUG] - Host host3 should be skipped: False
[2024-03-10 10:00:00] [DEBUG] - Host host4 should be skipped: False
[2024-03-10 10:00:00] [DEBUG] - Processing host1 from group group1
[2024-03-10 10:00:00] [DEBUG] - Adding SSH port 22 for host host1
[2024-03-10 10:00:00] [DEBUG] - Adding aliases ['base', 'another-alias'] for host host1
[2024-03-10 10:00:00] [DEBUG] - Adding custom auth methods for host host1
[2024-03-10 10:00:00] [DEBUG] - Processing host3 from group group2
[2024-03-10 10:00:00] [DEBUG] - Adding SSH port 19222 for host host3
[2024-03-10 10:00:00] [DEBUG] - Processing host4 from group group2
[2024-03-10 10:00:00] [DEBUG] - Adding SSH port 22 for host host4
[2024-03-10 10:00:00] [DEBUG] - Adding aliases ['base', 'another-alias'] for host host4
[2024-03-10 10:00:00] [DEBUG] - Adding custom auth methods for host host4
[2024-03-10 10:00:00] [INFO] - Generated SSH config file was saved to /home/user/code/python/sshgen/config
[2024-03-10 10:00:00] [DEBUG] - Skipped hosts list: 127.0.0.2
[2024-03-10 10:00:00] [INFO] - Total processed hosts: 3, total skipped hosts: 1
There are two ways to use the generated file:
- Copy and insert the output into your
~/.ssh/config
file. - Copy file to the conf directory, e.g.
~/.ssh/config.d/00-custom.conf
(if it's not exist, create one). Edit your~/.ssh/config
and addInclude
directive to the top:
#### Custom configuration
Include ~/.ssh/config.d/*.conf
#### End of custom configuration
After that, you can use any of the defined aliases to SSH
into the corresponding hosts. For example, running ssh base
will connect you to the host with the IP address 127.0.0.1
as the root user and utilizing 1password as your SSH agent.
For more examples, please refer to the examples directory.
License
There are no specific requirements for usage and distribution. For more information, refer to the LICENSE.
Changelog
For the changelog, please see CHANGELOG.md.
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
Built Distribution
File details
Details for the file sshgen-0.8.0.tar.gz
.
File metadata
- Download URL: sshgen-0.8.0.tar.gz
- Upload date:
- Size: 10.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.3 CPython/3.10.12 Linux/6.5.0-1025-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 7b1c5d3a1917bd87e8730aaf64ec80d50afe8f5fbf0a7863e7bb3877a1389895 |
|
MD5 | bf30b7c85b2fd2c09e5e85a8bc8472d9 |
|
BLAKE2b-256 | fae5492a31a9444b0807b69451ed38140ef065727d6bca24713f6fd946651eea |
File details
Details for the file sshgen-0.8.0-py3-none-any.whl
.
File metadata
- Download URL: sshgen-0.8.0-py3-none-any.whl
- Upload date:
- Size: 12.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.3 CPython/3.10.12 Linux/6.5.0-1025-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 9b17080a6ba1ae590c4989134571ce71caeb40dfe5cc93c895c8f8b74bb87437 |
|
MD5 | dd0c74fc03b18fc1b1652a049c26099c |
|
BLAKE2b-256 | d9b4ce7bf4c1d187d5ba6ef8319fe919503e56f440309169348e1cbc828f8f00 |