|
|
297660 |
From b84a1e6d246bbb758f0530038612bd18eff71767 Mon Sep 17 00:00:00 2001
|
|
|
297660 |
From: Eduardo Otubo <otubo@redhat.com>
|
|
|
297660 |
Date: Tue, 8 Dec 2020 13:27:22 +0100
|
|
|
297660 |
Subject: [PATCH 4/4] ssh_util: handle non-default AuthorizedKeysFile config
|
|
|
297660 |
(#586)
|
|
|
297660 |
|
|
|
297660 |
RH-Author: Eduardo Terrell Ferrari Otubo (eterrell)
|
|
|
297660 |
RH-MergeRequest: 28: ssh_util: handle non-default AuthorizedKeysFile config (#586)
|
|
|
297660 |
RH-Commit: [1/1] f7ce396e3002c53a3504e653b58810efb956aa26 (eterrell/cloud-init)
|
|
|
297660 |
RH-Bugzilla: 1862967
|
|
|
297660 |
|
|
|
297660 |
commit b0e73814db4027dba0b7dc0282e295b7f653325c
|
|
|
297660 |
Author: Eduardo Otubo <otubo@redhat.com>
|
|
|
297660 |
Date: Tue Oct 20 18:04:59 2020 +0200
|
|
|
297660 |
|
|
|
297660 |
ssh_util: handle non-default AuthorizedKeysFile config (#586)
|
|
|
297660 |
|
|
|
297660 |
The following commit merged all ssh keys into a default user file
|
|
|
297660 |
`~/.ssh/authorized_keys` in sshd_config had multiple files configured for
|
|
|
297660 |
AuthorizedKeysFile:
|
|
|
297660 |
|
|
|
297660 |
commit f1094b1a539044c0193165a41501480de0f8df14
|
|
|
297660 |
Author: Eduardo Otubo <otubo@redhat.com>
|
|
|
297660 |
Date: Thu Dec 5 17:37:35 2019 +0100
|
|
|
297660 |
|
|
|
297660 |
Multiple file fix for AuthorizedKeysFile config (#60)
|
|
|
297660 |
|
|
|
297660 |
This commit ignored the case when sshd_config would have a single file for
|
|
|
297660 |
AuthorizedKeysFile, but a non default configuration, for example
|
|
|
297660 |
`~/.ssh/authorized_keys_foobar`. In this case cloud-init would grab all keys
|
|
|
297660 |
from this file and write a new one, the default `~/.ssh/authorized_keys`
|
|
|
297660 |
causing the bug.
|
|
|
297660 |
|
|
|
297660 |
rhbz: #1862967
|
|
|
297660 |
|
|
|
297660 |
Signed-off-by: Eduardo Otubo <otubo@redhat.com>
|
|
|
297660 |
|
|
|
297660 |
Signed-off-by: Eduardo Otubo <otubo@redhat.com>
|
|
|
297660 |
---
|
|
|
297660 |
cloudinit/ssh_util.py | 6 +++---
|
|
|
297660 |
tests/unittests/test_sshutil.py | 6 +++---
|
|
|
297660 |
2 files changed, 6 insertions(+), 6 deletions(-)
|
|
|
297660 |
|
|
|
297660 |
diff --git a/cloudinit/ssh_util.py b/cloudinit/ssh_util.py
|
|
|
297660 |
index c08042d6..d5113996 100644
|
|
|
297660 |
--- a/cloudinit/ssh_util.py
|
|
|
297660 |
+++ b/cloudinit/ssh_util.py
|
|
|
297660 |
@@ -262,13 +262,13 @@ def extract_authorized_keys(username, sshd_cfg_file=DEF_SSHD_CFG):
|
|
|
297660 |
|
|
|
297660 |
except (IOError, OSError):
|
|
|
297660 |
# Give up and use a default key filename
|
|
|
297660 |
- auth_key_fns[0] = default_authorizedkeys_file
|
|
|
297660 |
+ auth_key_fns.append(default_authorizedkeys_file)
|
|
|
297660 |
util.logexc(LOG, "Failed extracting 'AuthorizedKeysFile' in SSH "
|
|
|
297660 |
"config from %r, using 'AuthorizedKeysFile' file "
|
|
|
297660 |
"%r instead", DEF_SSHD_CFG, auth_key_fns[0])
|
|
|
297660 |
|
|
|
297660 |
- # always store all the keys in the user's private file
|
|
|
297660 |
- return (default_authorizedkeys_file, parse_authorized_keys(auth_key_fns))
|
|
|
297660 |
+ # always store all the keys in the first file configured on sshd_config
|
|
|
297660 |
+ return (auth_key_fns[0], parse_authorized_keys(auth_key_fns))
|
|
|
297660 |
|
|
|
297660 |
|
|
|
297660 |
def setup_user_keys(keys, username, options=None):
|
|
|
297660 |
diff --git a/tests/unittests/test_sshutil.py b/tests/unittests/test_sshutil.py
|
|
|
297660 |
index fd1d1bac..88a111e3 100644
|
|
|
297660 |
--- a/tests/unittests/test_sshutil.py
|
|
|
297660 |
+++ b/tests/unittests/test_sshutil.py
|
|
|
297660 |
@@ -593,7 +593,7 @@ class TestMultipleSshAuthorizedKeysFile(test_helpers.CiTestCase):
|
|
|
297660 |
fpw.pw_name, sshd_config)
|
|
|
297660 |
content = ssh_util.update_authorized_keys(auth_key_entries, [])
|
|
|
297660 |
|
|
|
297660 |
- self.assertEqual("%s/.ssh/authorized_keys" % fpw.pw_dir, auth_key_fn)
|
|
|
297660 |
+ self.assertEqual(authorized_keys, auth_key_fn)
|
|
|
297660 |
self.assertTrue(VALID_CONTENT['rsa'] in content)
|
|
|
297660 |
self.assertTrue(VALID_CONTENT['dsa'] in content)
|
|
|
297660 |
|
|
|
297660 |
@@ -610,7 +610,7 @@ class TestMultipleSshAuthorizedKeysFile(test_helpers.CiTestCase):
|
|
|
297660 |
sshd_config = self.tmp_path('sshd_config')
|
|
|
297660 |
util.write_file(
|
|
|
297660 |
sshd_config,
|
|
|
297660 |
- "AuthorizedKeysFile %s %s" % (authorized_keys, user_keys)
|
|
|
297660 |
+ "AuthorizedKeysFile %s %s" % (user_keys, authorized_keys)
|
|
|
297660 |
)
|
|
|
297660 |
|
|
|
297660 |
(auth_key_fn, auth_key_entries) = ssh_util.extract_authorized_keys(
|
|
|
297660 |
@@ -618,7 +618,7 @@ class TestMultipleSshAuthorizedKeysFile(test_helpers.CiTestCase):
|
|
|
297660 |
)
|
|
|
297660 |
content = ssh_util.update_authorized_keys(auth_key_entries, [])
|
|
|
297660 |
|
|
|
297660 |
- self.assertEqual("%s/.ssh/authorized_keys" % fpw.pw_dir, auth_key_fn)
|
|
|
297660 |
+ self.assertEqual(user_keys, auth_key_fn)
|
|
|
297660 |
self.assertTrue(VALID_CONTENT['rsa'] in content)
|
|
|
297660 |
self.assertTrue(VALID_CONTENT['dsa'] in content)
|
|
|
297660 |
|
|
|
297660 |
--
|
|
|
297660 |
2.18.4
|
|
|
297660 |
|