summaryrefslogtreecommitdiffstats
path: root/ipaplatform/redhat
diff options
context:
space:
mode:
authorMartin Babinsky <mbabinsk@redhat.com>2015-09-25 18:00:30 +0200
committerMartin Basti <mbasti@redhat.com>2015-10-02 12:45:26 +0200
commit14977b5d84796c02a2c2a41f78919810cce83732 (patch)
treeac911d27e1d0da68d5b27bec65f990dfd1d25091 /ipaplatform/redhat
parent7ab52384be3109a572564797b3d186234144414b (diff)
downloadfreeipa-14977b5d84796c02a2c2a41f78919810cce83732.tar.gz
freeipa-14977b5d84796c02a2c2a41f78919810cce83732.tar.xz
freeipa-14977b5d84796c02a2c2a41f78919810cce83732.zip
do not overwrite files with local users/groups when restoring authconfig
the patch fixes regression in ipa-restore caused by overwriting /etc/passwd, /etc/shadow and fiends during restore of authconfig configuration files. These files are now excluded from authconfig backup dir. https://fedorahosted.org/freeipa/ticket/5328 Reviewed-By: David Kupka <dkupka@redhat.com>
Diffstat (limited to 'ipaplatform/redhat')
-rw-r--r--ipaplatform/redhat/authconfig.py12
1 files changed, 12 insertions, 0 deletions
diff --git a/ipaplatform/redhat/authconfig.py b/ipaplatform/redhat/authconfig.py
index edefee8b2..7b06d583d 100644
--- a/ipaplatform/redhat/authconfig.py
+++ b/ipaplatform/redhat/authconfig.py
@@ -19,7 +19,9 @@
# along with this program. If not, see <http://www.gnu.org/licenses/>.
from ipapython import ipautil
+import os
+FILES_TO_NOT_BACKUP = ['passwd', 'group', 'shadow', 'gshadow']
class RedHatAuthConfig(object):
"""
@@ -88,5 +90,15 @@ class RedHatAuthConfig(object):
def backup(self, path):
ipautil.run(["/usr/sbin/authconfig", "--savebackup", path])
+ # do not backup these files since we don't want to mess with
+ # users/groups during restore. Authconfig doesn't seem to mind about
+ # having them deleted from backup dir
+ files_to_remove = [os.path.join(path, f) for f in FILES_TO_NOT_BACKUP]
+ for filename in files_to_remove:
+ try:
+ os.remove(filename)
+ except OSError:
+ pass
+
def restore(self, path):
ipautil.run(["/usr/sbin/authconfig", "--restorebackup", path])