e7076c
diff -up rpcbind-0.2.0/configure.ac.orig rpcbind-0.2.0/configure.ac
e7076c
--- rpcbind-0.2.0/configure.ac.orig	2015-05-04 08:09:47.390954657 -0400
e7076c
+++ rpcbind-0.2.0/configure.ac	2015-05-04 08:10:23.707550057 -0400
e7076c
@@ -27,6 +27,13 @@ AC_ARG_WITH([rpcuser],
e7076c
   ,, [with_rpcuser=root])
e7076c
 AC_SUBST([rpcuser], [$with_rpcuser])
e7076c
  
e7076c
+AC_ARG_WITH([nss_modules],
e7076c
+  AS_HELP_STRING([--with-nss-modules=NSS_MODULES]
e7076c
+  , [Sets the nss module search list to the given space-delimited string.
e7076c
+     For example --with-nss-modules="files altfiles" @<:@default=files@:>@])
e7076c
+  ,, [with_nss_modules=files])
e7076c
+AC_SUBST([nss_modules], [$with_nss_modules])
e7076c
+
e7076c
 PKG_CHECK_MODULES([TIRPC], [libtirpc])
e7076c
 
e7076c
 AS_IF([test x$enable_libwrap = xyes], [
e7076c
diff -up rpcbind-0.2.0/Makefile.am.orig rpcbind-0.2.0/Makefile.am
e7076c
--- rpcbind-0.2.0/Makefile.am.orig	2015-05-04 08:09:47.386954591 -0400
e7076c
+++ rpcbind-0.2.0/Makefile.am	2015-05-04 08:10:23.707550057 -0400
e7076c
@@ -6,6 +6,7 @@ AM_CPPFLAGS = \
e7076c
 	-DINET6 \
e7076c
 	-DRPCBIND_STATEDIR="\"$(statedir)\"" \
e7076c
 	-DRPCBIND_USER="\"$(rpcuser)\"" \
e7076c
+	-DNSS_MODULES="\"$(nss_modules)\"" \
e7076c
 	-D_GNU_SOURCE \
e7076c
 	$(TIRPC_CFLAGS)
e7076c
 
e7076c
diff -up rpcbind-0.2.0/src/rpcbind.c.orig rpcbind-0.2.0/src/rpcbind.c
e7076c
--- rpcbind-0.2.0/src/rpcbind.c.orig	2015-05-04 08:09:47.387954608 -0400
e7076c
+++ rpcbind-0.2.0/src/rpcbind.c	2015-05-04 08:10:23.707550057 -0400
e7076c
@@ -86,6 +86,12 @@ char *rpcbinduser = RPCBIND_USER;
e7076c
 char *rpcbinduser = NULL;
e7076c
 #endif
e7076c
 
e7076c
+#ifdef NSS_MODULES
e7076c
+char *nss_modules = NSS_MODULES;
e7076c
+#else
e7076c
+char *nss_modules = "files";
e7076c
+#endif
e7076c
+
e7076c
 /* who to suid to if -s is given */
e7076c
 #define RUN_AS  "daemon"
e7076c
 
e7076c
@@ -160,7 +166,7 @@ main(int argc, char *argv[])
e7076c
 	 * Make sure we use the local service file 
e7076c
 	 * for service lookkups
e7076c
 	 */
e7076c
-	__nss_configure_lookup("services", "files");
e7076c
+	__nss_configure_lookup("services", nss_modules);
e7076c
 
e7076c
 	nc_handle = setnetconfig(); 	/* open netconfig file */
e7076c
 	if (nc_handle == NULL) {
e7076c
@@ -226,7 +232,7 @@ main(int argc, char *argv[])
e7076c
 		 * Make sure we use the local password file
e7076c
 		 * for these lookups.
e7076c
 		 */
e7076c
-		__nss_configure_lookup("passwd", "files");
e7076c
+		__nss_configure_lookup("passwd", nss_modules);
e7076c
 
e7076c
 		if((p = getpwnam(id)) == NULL) {
e7076c
 			syslog(LOG_ERR, "cannot get uid of '%s': %m", id);