From: Michael Olbrich <mol@pengutronix.de>
To: ptxdist@pengutronix.de
Cc: Christian Hermann <christian.hermann@hytera.de>
Subject: Re: [ptxdist] [APPLIED] openssh/rc-once: iterate over configured hostkeys
Date: Tue, 06 Oct 2020 10:18:20 +0200 [thread overview]
Message-ID: <E1kPiAu-0004g2-FK@dude02.hi.pengutronix.de> (raw)
In-Reply-To: <20200821112902.17281-2-christian.hermann@hytera.de>
Thanks, applied as cf2b6aa24e21431186e255312b7c4f6691ad367a.
Michael
[sent from post-receive hook]
On Tue, 06 Oct 2020 10:18:20 +0200, Christian Hermann <christian.hermann@hytera.de> wrote:
> ...instead of relying on a hardcoded list of keytypes.
>
> Some cleanup was performed as well:
> * merge key gathering functions
> * absence of sshd_config was tested but properly progagated and
> therefore not properly handled.
>
> Tested with sed implementations of busybox-1.31.1, toybox-0.8.3 and GNU.
>
> Signed-off-by: Christian Hermann <christian.hermann@hytera.de>
> Message-Id: <20200821112902.17281-2-christian.hermann@hytera.de>
> Signed-off-by: Michael Olbrich <m.olbrich@pengutronix.de>
>
> diff --git a/projectroot/etc/rc.once.d/openssh b/projectroot/etc/rc.once.d/openssh
> index fe8b00691122..545586f07629 100644
> --- a/projectroot/etc/rc.once.d/openssh
> +++ b/projectroot/etc/rc.once.d/openssh
> @@ -3,43 +3,32 @@
> PATH=/sbin:/bin:/usr/sbin:/usr/bin
>
> get_hostkeys() {
> - [ -f /etc/ssh/sshd_config ] || return
> - sed -n 's/^HostKey[ \t][ \t]*\(.*\)/\1/p' /etc/ssh/sshd_config
> -}
> -
> -host_keys_required() {
> - hostkeys="$(get_hostkeys)"
> - if [ "$hostkeys" ]; then
> - echo "$hostkeys"
> - else
> - # No HostKey directives found, so we pick secure defaults
> - echo /etc/ssh/ssh_host_ed25519_key
> - fi
> + hostkeys="$(sed -E -n -e 's/^HostKey[[:space:]]+(.*)/\1/p' /etc/ssh/sshd_config)" || return
> + # pick secure defaults if no HostKey directives are found
> + echo "${hostkeys:-/etc/ssh/ssh_host_ed25519_key}"
> }
>
> create_key() {
> - keytype="$1"
> - shift
> - hostkeys="$1"
> - shift
> -
> - file="/etc/ssh/ssh_host_${keytype}_key"
> -
> - if echo "$hostkeys" | grep -x -F "$file" >/dev/null; then
> - echo "Create $keytype key; this may take some time ..."
> - rm -f $file &&
> - ssh-keygen -q -f "$file" -N '' -t "$keytype" "$@" || return
> - echo "Created $keytype key."
> - fi
> + keyfile="$1"
> + keytype="$(echo "$keyfile" | sed -E -e 's/.*ssh_host_(.*)_key$/\1/')"
> +
> + keygen_args=
> + case "$keytype" in
> + rsa) keygen_args="-b 4096" ;;
> + esac
> +
> + echo "Create $keytype key; this may take some time ..."
> + rm -f "$keyfile" &&
> + ssh-keygen -q -f "$keyfile" -N '' -t "$keytype" $keygen_args || return
> + echo "Created $keytype key."
> }
>
> create_keys() {
> - hostkeys="$(host_keys_required)"
> + hostkeys="$(get_hostkeys)" || return
>
> - create_key "dsa" "$hostkeys" &&
> - create_key "ecdsa" "$hostkeys" &&
> - create_key "ed25519" "$hostkeys" &&
> - create_key "rsa" "$hostkeys" -b 4096
> + for keyfile in $hostkeys; do
> + create_key "$keyfile" || return
> + done
> }
>
> if ! create_keys; then
_______________________________________________
ptxdist mailing list
ptxdist@pengutronix.de
To unsubscribe, send a mail with subject "unsubscribe" to ptxdist-request@pengutronix.de
prev parent reply other threads:[~2020-10-06 8:18 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2020-08-21 11:29 [ptxdist] [PATCH 0/1] " Christian Hermann
2020-08-21 11:29 ` [ptxdist] [PATCH 1/1] " Christian Hermann
2020-10-06 8:18 ` Michael Olbrich [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=E1kPiAu-0004g2-FK@dude02.hi.pengutronix.de \
--to=mol@pengutronix.de \
--cc=christian.hermann@hytera.de \
--cc=ptxdist@pengutronix.de \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox