2009-01-15 20:56:45 +00:00
|
|
|
diff --exclude-from=exclude -N -u -r nsalibsemanage/src/genhomedircon.c libsemanage-2.0.31/src/genhomedircon.c
|
2008-09-10 14:37:31 +00:00
|
|
|
--- nsalibsemanage/src/genhomedircon.c 2008-08-28 09:34:24.000000000 -0400
|
2009-03-11 19:38:20 +00:00
|
|
|
+++ libsemanage-2.0.31/src/genhomedircon.c 2009-03-11 15:36:08.000000000 -0400
|
2009-01-15 20:56:45 +00:00
|
|
|
@@ -794,6 +794,12 @@
|
2008-12-04 20:19:01 +00:00
|
|
|
* /root */
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
+ if (strcmp(pwent->pw_dir, "/root") == 0) {
|
|
|
|
+ /* don't relabel / genhomdircon checked to see if root
|
|
|
|
+ * was the user and if so, set his home directory to
|
|
|
|
+ * /root */
|
|
|
|
+ continue;
|
|
|
|
+ }
|
|
|
|
if (push_user_entry(&head, name, seuname,
|
|
|
|
prefix, pwent->pw_dir) != STATUS_SUCCESS) {
|
|
|
|
*errors = STATUS_ERR;
|
2009-03-11 19:38:20 +00:00
|
|
|
diff --exclude-from=exclude -N -u -r nsalibsemanage/src/handle.c libsemanage-2.0.31/src/handle.c
|
|
|
|
--- nsalibsemanage/src/handle.c 2008-11-14 17:10:15.000000000 -0500
|
|
|
|
+++ libsemanage-2.0.31/src/handle.c 2009-03-11 15:36:26.000000000 -0400
|
|
|
|
@@ -264,7 +264,7 @@
|
|
|
|
assert(sh != NULL && sh->funcs != NULL && sh->funcs->commit != NULL);
|
|
|
|
if (!sh->is_in_transaction) {
|
|
|
|
ERR(sh,
|
|
|
|
- "Will not commit because caller does not have a tranaction lock yet.");
|
|
|
|
+ "Will not commit because caller does not have a transaction lock yet.");
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
retval = sh->funcs->commit(sh);
|
2009-01-15 20:56:45 +00:00
|
|
|
diff --exclude-from=exclude -N -u -r nsalibsemanage/src/semanage.conf libsemanage-2.0.31/src/semanage.conf
|
2008-09-10 14:37:31 +00:00
|
|
|
--- nsalibsemanage/src/semanage.conf 2008-08-28 09:34:24.000000000 -0400
|
2009-03-11 19:38:20 +00:00
|
|
|
+++ libsemanage-2.0.31/src/semanage.conf 2009-03-11 15:36:08.000000000 -0400
|
2007-12-07 01:18:18 +00:00
|
|
|
@@ -35,4 +35,4 @@
|
|
|
|
# given in <sepol/policydb.h>. Change this setting if a different
|
|
|
|
# version is necessary.
|
|
|
|
#policy-version = 19
|
|
|
|
-
|
|
|
|
+expand-check=0
|
2009-01-15 20:56:45 +00:00
|
|
|
diff --exclude-from=exclude -N -u -r nsalibsemanage/src/semanage_store.c libsemanage-2.0.31/src/semanage_store.c
|
|
|
|
--- nsalibsemanage/src/semanage_store.c 2009-01-13 08:45:35.000000000 -0500
|
2009-03-11 19:38:20 +00:00
|
|
|
+++ libsemanage-2.0.31/src/semanage_store.c 2009-03-11 15:36:08.000000000 -0400
|
2009-01-15 20:56:45 +00:00
|
|
|
@@ -440,8 +440,6 @@
|
|
|
|
char tmp[PATH_MAX];
|
|
|
|
char buf[4192];
|
|
|
|
|
|
|
|
- if (link(src,dst) == 0) return 0;
|
|
|
|
-
|
|
|
|
n = snprintf(tmp, PATH_MAX, "%s.tmp", dst);
|
|
|
|
if (n < 0 || n >= PATH_MAX)
|
|
|
|
return -1;
|
|
|
|
@@ -509,7 +507,8 @@
|
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
} else if (S_ISREG(sb.st_mode)) {
|
|
|
|
- if (semanage_copy_file(path, path2, sb.st_mode) == -1) {
|
|
|
|
+ if ((link(path,path2) == -1) &&
|
|
|
|
+ (semanage_copy_file(path, path2, sb.st_mode) == -1)) {
|
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
}
|