Blob Blame History Raw
diff -up ecryptfs-utils-99/src/pam_ecryptfs/pam_ecryptfs.c.fixexecgid ecryptfs-utils-99/src/pam_ecryptfs/pam_ecryptfs.c
--- ecryptfs-utils-99/src/pam_ecryptfs/pam_ecryptfs.c.fixexecgid	2012-07-24 13:20:58.456297563 +0200
+++ ecryptfs-utils-99/src/pam_ecryptfs/pam_ecryptfs.c	2012-07-24 13:21:53.250786224 +0200
@@ -337,8 +337,10 @@ static int private_dir(pam_handle_t *pam
 				_exit(0);
 			}
 			clearenv();
-			if (setgroups(1, &pwd->pw_gid) < 0 || setgid(pwd->pw_gid) < 0)
+			if (initgroups(pwd->pw_name, pwd->pw_gid) != 0) {
+				syslog(LOG_ERR, "Unable to set user's groups : %m");
 				_exit(255);
+			}
 			/* run mount.ecryptfs_private as the user */
 			if (setresuid(pwd->pw_uid, pwd->pw_uid, pwd->pw_uid) < 0)
 				_exit(255);
@@ -352,8 +354,10 @@ static int private_dir(pam_handle_t *pam
 				_exit(0);
 			}
 			clearenv();
-			if (setgroups(1, &pwd->pw_gid) < 0 || setgid(pwd->pw_gid) < 0)
+			if (initgroups(pwd->pw_name, pwd->pw_gid) != 0) {
+				syslog(LOG_ERR, "Unable to set user's groups : %m");
 				_exit(255);
+			}
 			/* run umount.ecryptfs_private as the user */
 			if (setresuid(pwd->pw_uid, pwd->pw_uid, pwd->pw_uid) < 0)
 				_exit(255);