install.fairie/docs/scripts/after/run_onchange_after_07-ensure-private-key.sh.tmpl.md
2023-08-08 03:06:49 -04:00

1.8 KiB

title description sidebar_label slug githubLocation scriptLocation repoLocation
Default SSH Key Create a default `id_rsa` SSH key if one is not present in the repository / fork of Install Doctor 07 Default SSH Key /scripts/after/run_onchange_after_07-ensure-private-key.sh.tmpl https://github.com/megabyte-labs/install.doctor/blob/master/home/.chezmoiscripts/universal/run_onchange_after_07-ensure-private-key.sh.tmpl https://github.com/megabyte-labs/install.doctor/raw/master/home/.chezmoiscripts/universal/run_onchange_after_07-ensure-private-key.sh.tmpl home/.chezmoiscripts/universal/run_onchange_after_07-ensure-private-key.sh.tmpl

Default SSH Key

Create a default id_rsa SSH key if one is not present in the repository / fork of Install Doctor

Overview

This script generates a pair of default id_rsa and id_rsa.pub keys if one is not already present on the system after the Install Doctor provisioning process completes. It also ensures the private key is only readable and writable the provisioning user.

Source Code

#!/usr/bin/env bash
# @file Default SSH Key
# @brief Create a default `id_rsa` SSH key if one is not present in the repository / fork of Install Doctor
# @description
#     This script generates a pair of default `id_rsa` and `id_rsa.pub` keys if one is not already present
#     on the system after the Install Doctor provisioning process completes. It also ensures the private
#     key is only readable and writable the provisioning user.

{{ includeTemplate "universal/profile" }}
{{ includeTemplate "universal/logg" }}

### Ensure id_rsa is present and create one if it does not exist
if [ ! -f "$HOME/.ssh/id_rsa" ]; then
  logg 'Generating missing default private key / public key (`~/.ssh/id_rsa`)'
  ssh-keygen -b 4096 -t rsa -f "$HOME/.ssh/id_rsa" -q -N ""
  chmod 600 "$HOME/.ssh/id_rsa"
fi