Blame SOURCES/nfs-utils-2.3.3-gssd-k5identity.patch

4cb8ad
diff -up nfs-utils-2.3.3/nfs.conf.orig nfs-utils-2.3.3/nfs.conf
4cb8ad
--- nfs-utils-2.3.3/nfs.conf.orig	2021-04-17 10:49:23.660184527 -0400
4cb8ad
+++ nfs-utils-2.3.3/nfs.conf	2021-04-17 11:14:41.482108562 -0400
4cb8ad
@@ -21,6 +21,7 @@ use-gss-proxy=1
4cb8ad
 # keytab-file=/etc/krb5.keytab
4cb8ad
 # cred-cache-directory=
4cb8ad
 # preferred-realm=
4cb8ad
+# set-home=1
4cb8ad
 #
4cb8ad
 [lockd]
4cb8ad
 # port=0
4cb8ad
diff -up nfs-utils-2.3.3/systemd/nfs.conf.man.orig nfs-utils-2.3.3/systemd/nfs.conf.man
4cb8ad
--- nfs-utils-2.3.3/systemd/nfs.conf.man.orig	2021-04-17 10:49:23.696185472 -0400
4cb8ad
+++ nfs-utils-2.3.3/systemd/nfs.conf.man	2021-04-17 11:14:41.483108588 -0400
4cb8ad
@@ -222,7 +222,8 @@ Recognized values:
4cb8ad
 .BR rpc-timeout ,
4cb8ad
 .BR keytab-file ,
4cb8ad
 .BR cred-cache-directory ,
4cb8ad
-.BR preferred-realm .
4cb8ad
+.BR preferred-realm ,
4cb8ad
+.BR set-home .
4cb8ad
 
4cb8ad
 See
4cb8ad
 .BR rpc.gssd (8)
4cb8ad
diff -up nfs-utils-2.3.3/utils/gssd/gssd.c.orig nfs-utils-2.3.3/utils/gssd/gssd.c
4cb8ad
--- nfs-utils-2.3.3/utils/gssd/gssd.c.orig	2021-04-17 10:49:23.684185157 -0400
4cb8ad
+++ nfs-utils-2.3.3/utils/gssd/gssd.c	2021-04-17 11:14:41.483108588 -0400
4cb8ad
@@ -87,6 +87,8 @@ unsigned int  context_timeout = 0;
4cb8ad
 unsigned int  rpc_timeout = 5;
4cb8ad
 char *preferred_realm = NULL;
4cb8ad
 char *ccachedir = NULL;
4cb8ad
+/* set $HOME to "/" by default */
4cb8ad
+static bool set_home = true;
4cb8ad
 /* Avoid DNS reverse lookups on server names */
4cb8ad
 static bool avoid_dns = true;
4cb8ad
 static bool use_gssproxy = false;
4cb8ad
@@ -885,7 +887,7 @@ sig_die(int signal)
4cb8ad
 static void
4cb8ad
 usage(char *progname)
4cb8ad
 {
4cb8ad
-	fprintf(stderr, "usage: %s [-f] [-l] [-M] [-n] [-v] [-r] [-p pipefsdir] [-k keytab] [-d ccachedir] [-t timeout] [-R preferred realm] [-D]\n",
4cb8ad
+	fprintf(stderr, "usage: %s [-f] [-l] [-M] [-n] [-v] [-r] [-p pipefsdir] [-k keytab] [-d ccachedir] [-t timeout] [-R preferred realm] [-D] [-H]\n",
4cb8ad
 		progname);
4cb8ad
 	exit(1);
4cb8ad
 }
4cb8ad
@@ -926,6 +928,7 @@ read_gss_conf(void)
4cb8ad
 		preferred_realm = s;
4cb8ad
 
4cb8ad
 	use_gssproxy = conf_get_bool("gssd", "use-gss-proxy", use_gssproxy);
4cb8ad
+	set_home = conf_get_bool("gssd", "set-home", set_home);
4cb8ad
 }
4cb8ad
 
4cb8ad
 int
4cb8ad
@@ -946,7 +949,7 @@ main(int argc, char *argv[])
4cb8ad
 	verbosity = conf_get_num("gssd", "verbosity", verbosity);
4cb8ad
 	rpc_verbosity = conf_get_num("gssd", "rpc-verbosity", rpc_verbosity);
4cb8ad
 
4cb8ad
-	while ((opt = getopt(argc, argv, "DfvrlmnMp:k:d:t:T:R:")) != -1) {
4cb8ad
+	while ((opt = getopt(argc, argv, "HDfvrlmnMp:k:d:t:T:R:")) != -1) {
4cb8ad
 		switch (opt) {
4cb8ad
 			case 'f':
4cb8ad
 				fg = 1;
4cb8ad
@@ -994,6 +997,9 @@ main(int argc, char *argv[])
4cb8ad
 			case 'D':
4cb8ad
 				avoid_dns = false;
4cb8ad
 				break;
4cb8ad
+			case 'H':
4cb8ad
+				set_home = false;
4cb8ad
+				break;
4cb8ad
 			default:
4cb8ad
 				usage(argv[0]);
4cb8ad
 				break;
4cb8ad
@@ -1003,13 +1009,19 @@ main(int argc, char *argv[])
4cb8ad
 	/*
4cb8ad
 	 * Some krb5 routines try to scrape info out of files in the user's
4cb8ad
 	 * home directory. This can easily deadlock when that homedir is on a
4cb8ad
-	 * kerberized NFS mount. By setting $HOME unconditionally to "/", we
4cb8ad
-	 * prevent this behavior in routines that use $HOME in preference to
4cb8ad
-	 * the results of getpw*.
4cb8ad
+	 * kerberized NFS mount. By setting $HOME to "/" by default, we prevent
4cb8ad
+	 * this behavior in routines that use $HOME in preference to the results
4cb8ad
+	 * of getpw*.
4cb8ad
+	 *
4cb8ad
+	 * Some users do not use Kerberized home dirs and need $HOME to remain
4cb8ad
+	 * unchanged. Those users can leave $HOME unchanged by setting set_home
4cb8ad
+	 * to false.
4cb8ad
 	 */
4cb8ad
-	if (setenv("HOME", "/", 1)) {
4cb8ad
-		printerr(0, "gssd: Unable to set $HOME: %s\n", strerror(errno));
4cb8ad
-		exit(1);
4cb8ad
+	if (set_home) {
4cb8ad
+		if (setenv("HOME", "/", 1)) {
4cb8ad
+			printerr(0, "gssd: Unable to set $HOME: %s\n", strerror(errno));
4cb8ad
+			exit(1);
4cb8ad
+		}
4cb8ad
 	}
4cb8ad
 
4cb8ad
 	if (use_gssproxy) {
4cb8ad
diff -up nfs-utils-2.3.3/utils/gssd/gssd.man.orig nfs-utils-2.3.3/utils/gssd/gssd.man
4cb8ad
--- nfs-utils-2.3.3/utils/gssd/gssd.man.orig	2021-04-17 10:49:23.650184264 -0400
4cb8ad
+++ nfs-utils-2.3.3/utils/gssd/gssd.man	2021-04-17 11:14:41.484108615 -0400
4cb8ad
@@ -8,7 +8,7 @@
4cb8ad
 rpc.gssd \- RPCSEC_GSS daemon
4cb8ad
 .SH SYNOPSIS
4cb8ad
 .B rpc.gssd
4cb8ad
-.RB [ \-DfMnlvr ]
4cb8ad
+.RB [ \-DfMnlvrH ]
4cb8ad
 .RB [ \-k
4cb8ad
 .IR keytab ]
4cb8ad
 .RB [ \-p
4cb8ad
@@ -297,6 +297,16 @@ The default timeout is set to 5 seconds.
4cb8ad
 If you get messages like "WARNING: can't create tcp rpc_clnt to server
4cb8ad
 %servername% for user with uid %uid%: RPC: Remote system error -
4cb8ad
 Connection timed out", you should consider an increase of this timeout.
4cb8ad
+.TP
4cb8ad
+.B -H
4cb8ad
+Avoids setting $HOME to "/". This allows rpc.gssd to read per user k5identity
4cb8ad
+files versus trying to read /.k5identity for each user.
4cb8ad
+
4cb8ad
+If
4cb8ad
+.B \-H
4cb8ad
+is not set, rpc.gssd will use the first match found in
4cb8ad
+/var/kerberos/krb5/user/$EUID/client.keytab and will not use a principal based on
4cb8ad
+host and/or service parameters listed in $HOME/.k5identity.
4cb8ad
 .SH CONFIGURATION FILE
4cb8ad
 Many of the options that can be set on the command line can also be
4cb8ad
 controlled through values set in the
4cb8ad
@@ -354,6 +364,13 @@ Equivalent to
4cb8ad
 .B preferred-realm
4cb8ad
 Equivalent to
4cb8ad
 .BR -R .
4cb8ad
+.TP
4cb8ad
+.B set-home
4cb8ad
+Setting to
4cb8ad
+.B false
4cb8ad
+is equivalent to providing the
4cb8ad
+.B -H
4cb8ad
+flag.
4cb8ad
 .P
4cb8ad
 In addtion, the following value is recognized from the
4cb8ad
 .B [general]