From mboxrd@z Thu Jan 1 00:00:00 1970 From: Peter =?utf-8?q?M=C3=BCller?= To: development@lists.ipfire.org Subject: Re: [PATCH 3/3] OpenSSH: use safer cryptography defaults Date: Wed, 16 May 2018 17:39:46 +0200 Message-ID: <02ce9d57-066a-4b26-00d9-f69e1ce5aecb@link38.eu> In-Reply-To: <60141712-0583-e014-ad5d-d423587566a3@link38.eu> MIME-Version: 1.0 Content-Type: multipart/mixed; boundary="===============8083109455041262837==" List-Id: --===============8083109455041262837== Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: quoted-printable Hello *, could somebody have a look at this sometimes? If possible, I'd like to add this to the upcoming Core 121, too - in case we are not becoming too big with the new kernel already. Thanks, and best regards, Peter M=C3=BCller > By default, OpenSSH uses crypto algorithms such as SHA1, which are > considered insecure and should not be used anymore. This patch > updates the used ciphers, message-digest algorithms and key exchange > algorithms according https://stribika.github.io/2015/01/04/secure-secure-sh= ell.html . >=20 > For the kex algo "diffie-hellman-group-exchange-sha256", an intact > SSH moduli file is required. To make sure we are not falling back > to insecure crypto here, its presence is checked at SSH startup. >=20 > On my machines, this file was already there, but it makes sense to > me to double-check this. This patch should not make problems except > for very outdated OpenSSH clients (older than 6.x) or PuTTY versions. >=20 > This partially addresses #11538 and requires patch 2/3. >=20 > Signed-off-by: Peter M=C3=BCller > --- > config/rootfiles/core/121/update.sh | 6 +++++- > lfs/openssh | 4 ++++ > src/initscripts/system/sshd | 12 ++++++++++++ > 3 files changed, 21 insertions(+), 1 deletion(-) >=20 > diff --git a/config/rootfiles/core/121/update.sh b/config/rootfiles/core/12= 1/update.sh > index 3ec251292..99c174156 100644 > --- a/config/rootfiles/core/121/update.sh > +++ b/config/rootfiles/core/121/update.sh > @@ -60,7 +60,11 @@ rm -rvf \ > sed -i /etc/ssh/sshd_config \ > -e 's/^#SyslogFacility AUTH$/SyslogFacility AUTH/' \ > -e 's/^#LogLevel INFO$/LogLevel INFO/' \ > - -e 's/^#StrictModes .*$/StrictModes yes/' > + -e 's/^#StrictModes .*$/StrictModes yes/' \ > + -e 's/^#RekeyLimit default none$/Ciphers chacha20-poly1305(a)openssh.com,= aes256-gcm(a)openssh.com,aes128-gcm(a)openssh.com,aes256-ctr,aes192-ctr,aes12= 8-ctr\ > + MACs hmac-sha2-512-etm(a)openssh.com,hmac-sha2-256-etm(a)openssh.com,um= ac-128-etm(a)openssh.com,hmac-sha2-512,hmac-sha2-256,umac-128(a)openssh.com\ > + KexAlgorithms curve25519-sha256(a)libssh.org,diffie-hellman-group-excha= nge-sha256\ > + #RekeyLimit default none/' > =20 > # Start services > /etc/init.d/sshd restart > diff --git a/lfs/openssh b/lfs/openssh > index 7e8468ac9..3043501a2 100644 > --- a/lfs/openssh > +++ b/lfs/openssh > @@ -96,6 +96,10 @@ $(TARGET) : $(patsubst %,$(DIR_DL)/%,$(objects)) > -e 's/^#\?AllowTcpForwarding .*$$/AllowTcpForwarding no/' \ > -e 's/^#\?PermitRootLogin .*$$/PermitRootLogin yes/' \ > -e 's/^#StrictModes .*$/StrictModes yes/' \ > + -e 's/^#RekeyLimit default none$/Ciphers chacha20-poly1305(a)openssh.com= ,aes256-gcm(a)openssh.com,aes128-gcm(a)openssh.com,aes256-ctr,aes192-ctr,aes1= 28-ctr\ > + MACs hmac-sha2-512-etm(a)openssh.com,hmac-sha2-256-etm(a)openssh.com,um= ac-128-etm(a)openssh.com,hmac-sha2-512,hmac-sha2-256,umac-128(a)openssh.com\ > + KexAlgorithms curve25519-sha256(a)libssh.org,diffie-hellman-group-excha= nge-sha256\ > + #RekeyLimit default none/' \ > -e 's|^#\?HostKey /etc/ssh/ssh_host_dsa_key$$||' \ > -e 's|^#\?HostKey /etc/ssh/ssh_host_ecdsa_key$$||' \ > -e 's|^#\?HostKey /etc/ssh/ssh_host_ed25519_key$$||' \ > diff --git a/src/initscripts/system/sshd b/src/initscripts/system/sshd > index 7b4092d38..d7958e800 100644 > --- a/src/initscripts/system/sshd > +++ b/src/initscripts/system/sshd > @@ -23,6 +23,18 @@ case "$1" in > evaluate_retval > done > =20 > + # Make sure moduli file is properly present > + # (https://stribika.github.io/2015/01/04/secure-secure-shell.html) > + modulifile=3D"/etc/ssh/moduli" > + if [ ! -e "${modulifile}" ]; then > + boot_mesg "Generating SSH moduli file (this may take a while)..." > + > + ssh-keygen -G /etc/ssh/moduli.all -b 4096 > + ssh-keygen -T /etc/ssh/moduli.safe -f /etc/ssh/moduli.all > + mv /etc/ssh/moduli.safe /etc/ssh/moduli > + rm -f /etc/ssh/moduli.all > + fi > + > [ -e "/var/ipfire/remote/enablessh" ] || exit 0 # SSH is not enabl= ed > boot_mesg "Starting SSH Server..." > loadproc /usr/sbin/sshd=20 >=20 --===============8083109455041262837== Content-Type: application/pgp-signature Content-Transfer-Encoding: base64 Content-Disposition: attachment; filename="signature.asc" MIME-Version: 1.0 LS0tLS1CRUdJTiBQR1AgU0lHTkFUVVJFLS0tLS0KVmVyc2lvbjogR251UEcgdjIKCmlRSWNCQUVC Q2dBR0JRSmEvRkRZQUFvSkVObEk4Zzk5ZTU5b3RBY1AvaVhUNW5WL2tWVlo1MHZzanN3SDI4MCsK Zmd2eGpMWE43NzE2MXRiRGNSclhrNURUamFldnJzL0RkSjBYb2FROFJBb1M4blBsUzVHR2ZlbHlK azF1bDRTbwpZaGd1V01SeTROYjRRUXlkNjRMcyt0aXV4ZTkwdmVTalhrcVRKWmJlYWpBN2pNSys1 ZEpZNE9xYXdGWldVTjdsClVFY0lHZzZlbGp4ZCs2bm1QclpBaENXVmRkRkFuVXNNaFZEV1BKSHRG RUVWSGFqZzBkL01jR3kzSGY2WGVGZHMKbEJKMk5LRThNRUpHNkdESy9iL1VsQS9sSTBFZERiVzZG ODhhT1NOcCtIM2t2YmZ6ZlNkbm5UWHdGTFRFWXYyMwpvSlF6Y2E2YXczZ0sxdFVibE1iU2dSUnFI L3V2Mk1FdGRQOTYyQXozM1YrcU81TkN5L3h4SXlKSlZTQXloNjIxCis5WEk0VmNjdUNKdDdPZ2hX V0pwQlNIc25YcUQzTXpidU4vS1JNT251d2Y2L3hEdEEzQWIxV2F2Q0Zlb052VzgKSWpxaVZtWU1J YWhiTXlicm9sZlFZbHBRa0NkVWxxd3didHMyR3ZUTTVTRHNWWGY3RVZ2NmlVeitHOHd1bTNGUgpr VXpEV2U1R0R3Wnh5c0U5OUxFcllVVlFURzU4cDlPVjBMUVVUZUJNSkg2UDJGMm0yellyU3FKeENC Q1pEbUFnCjdOb3piOVZXSzRQYXQzY3lmclRZK0FRN1lBalNuNFl0SkVBRm5vR1MrQitESk80SUIx OWorL0JoeWt5UEhQd0sKVXppMzZ5WDFYMUpiWlg4Sm81dG92a0xId3JsMnhHcnpXUTkyNGU5eC8r YXNJUUJjbkp6Q0t5amZ0alFEZWdmNgovRmU1SXhGbzdlL1ptWFp2UVF4RQo9UVdzaQotLS0tLUVO RCBQR1AgU0lHTkFUVVJFLS0tLS0K --===============8083109455041262837==--