|
|
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);
|