summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPanu Matilainen <pmatilai@redhat.com>2008-05-08 13:06:34 +0300
committerPanu Matilainen <pmatilai@redhat.com>2008-05-08 13:06:34 +0300
commit485ee9bbb4ff3e9c3b4cb65052055d4e8d47e78f (patch)
tree81cdeb8c02de6ce9f01f9cbd34cdf915aefc4e11
parent461fd000d22d76d97ad0ac76263477d364691d32 (diff)
downloadrpm-485ee9bbb4ff3e9c3b4cb65052055d4e8d47e78f.tar.gz
rpm-485ee9bbb4ff3e9c3b4cb65052055d4e8d47e78f.tar.bz2
rpm-485ee9bbb4ff3e9c3b4cb65052055d4e8d47e78f.zip
Restore rpmdb selinux contexts to default after rebuild (rhbz#442149)
-rw-r--r--rpmdb/rpmdb.c17
1 files changed, 15 insertions, 2 deletions
diff --git a/rpmdb/rpmdb.c b/rpmdb/rpmdb.c
index 3bdb503cc..670d2cf14 100644
--- a/rpmdb/rpmdb.c
+++ b/rpmdb/rpmdb.c
@@ -3256,7 +3256,8 @@ static int rpmdbMoveDatabase(const char * prefix,
struct stat st;
int rc = 0;
int xx;
-
+ int selinux = is_selinux_enabled() && (matchpathcon_init(NULL) != -1);
+
switch (_olddbapi) {
case 4:
/* Fall through */
@@ -3279,7 +3280,7 @@ static int rpmdbMoveDatabase(const char * prefix,
goto cont;
/*
- * Restore uid/gid/mode/mtime if possible.
+ * Restore uid/gid/mode/mtime/security context if possible.
*/
if (stat(dest, &st) < 0)
if (stat(src, &st) < 0)
@@ -3296,6 +3297,15 @@ static int rpmdbMoveDatabase(const char * prefix,
stamp.modtime = st.st_mtime;
xx = utime(dest, &stamp);
}
+
+ if (selinux) {
+ security_context_t scon = NULL;
+ if (matchpathcon(dest, &st, &scon) != -1) {
+ (void) setfilecon(dest, scon);
+ freecon(scon);
+ }
+ }
+
cont:
free(src);
free(dest);
@@ -3316,6 +3326,9 @@ cont:
rc = rpmdbRemoveDatabase(prefix, newdbpath, _newdbapi);
#endif
+ if (selinux) {
+ (void) matchpathcon_fini();
+ }
return rc;
}