Blame SOURCES/rpcbind-0.2.0-systemd-socket.patch

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:15:10.394432254 -0400
e7076c
+++ rpcbind-0.2.0/configure.ac	2015-05-04 08:48:36.463258254 -0400
e7076c
@@ -36,6 +36,18 @@ AC_SUBST([nss_modules], [$with_nss_modul
e7076c
 
e7076c
 PKG_CHECK_MODULES([TIRPC], [libtirpc])
e7076c
 
e7076c
+PKG_PROG_PKG_CONFIG
e7076c
+AC_ARG_WITH([systemdsystemunitdir],
e7076c
+  AS_HELP_STRING([--with-systemdsystemunitdir=DIR], [Directory for systemd service files]),
e7076c
+  [], [with_systemdsystemunitdir=$($PKG_CONFIG --variable=systemdsystemunitdir systemd)])
e7076c
+  if test "x$with_systemdsystemunitdir" != xno; then
e7076c
+    AC_SUBST([systemdsystemunitdir], [$with_systemdsystemunitdir])
e7076c
+     PKG_CHECK_MODULES([SYSTEMD], [libsystemd], [],
e7076c
+	   [PKG_CHECK_MODULES([SYSTEMD], [libsystemd-daemon], [],
e7076c
+	   AC_MSG_ERROR([libsystemd support requested but found]))])
e7076c
+  fi
e7076c
+AM_CONDITIONAL(SYSTEMD, [test -n "$with_systemdsystemunitdir" -a "x$with_systemdsystemunitdir" != xno ])
e7076c
+
e7076c
 AS_IF([test x$enable_libwrap = xyes], [
e7076c
 	AC_CHECK_LIB([wrap], [hosts_access], ,
e7076c
 		AC_MSG_ERROR([libwrap support requested but unable to find libwrap]))
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:15:10.394432254 -0400
e7076c
+++ rpcbind-0.2.0/Makefile.am	2015-05-04 08:48:36.463258254 -0400
e7076c
@@ -39,6 +39,12 @@ rpcbind_SOURCES = \
e7076c
 	src/warmstart.c
e7076c
 rpcbind_LDADD = $(TIRPC_LIBS)
e7076c
 
e7076c
+if SYSTEMD
e7076c
+AM_CPPFLAGS += $(SYSTEMD_CFLAGS) -DSYSTEMD
e7076c
+
e7076c
+rpcbind_LDADD += $(SYSTEMD_LIBS)
e7076c
+endif
e7076c
+
e7076c
 rpcinfo_SOURCES =       src/rpcinfo.c
e7076c
 rpcinfo_LDADD   =       $(TIRPC_LIBS)
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:15:10.394432254 -0400
e7076c
+++ rpcbind-0.2.0/src/rpcbind.c	2015-05-04 08:48:36.463258254 -0400
e7076c
@@ -56,6 +56,9 @@
e7076c
 #include <netinet/in.h>
e7076c
 #endif
e7076c
 #include <arpa/inet.h>
e7076c
+#ifdef SYSTEMD
e7076c
+#include <systemd/sd-daemon.h>
e7076c
+#endif
e7076c
 #include <fcntl.h>
e7076c
 #include <netdb.h>
e7076c
 #include <stdio.h>
e7076c
@@ -291,6 +294,7 @@ init_transport(struct netconfig *nconf)
e7076c
 	u_int32_t host_addr[4];  /* IPv4 or IPv6 */
e7076c
 	struct sockaddr_un sun;
e7076c
 	mode_t oldmask;
e7076c
+	int n;
e7076c
         res = NULL;
e7076c
 
e7076c
 	if ((nconf->nc_semantics != NC_TPI_CLTS) &&
e7076c
@@ -309,6 +313,76 @@ init_transport(struct netconfig *nconf)
e7076c
 			fprintf(stderr, "[%d] - %s\n", i, *s);
e7076c
 	}
e7076c
 #endif
e7076c
+	if (!__rpc_nconf2sockinfo(nconf, &si)) {
e7076c
+		syslog(LOG_ERR, "cannot get information for %s",
e7076c
+		    nconf->nc_netid);
e7076c
+		return (1);
e7076c
+	}
e7076c
+
e7076c
+#ifdef SYSTEMD
e7076c
+	n = sd_listen_fds(0);
e7076c
+	if (n < 0) {
e7076c
+		syslog(LOG_ERR, "failed to acquire systemd sockets: %s", strerror(-n));
e7076c
+		return 1;
e7076c
+	}
e7076c
+
e7076c
+	/* Try to find if one of the systemd sockets we were given match
e7076c
+	 * our netconfig structure. */
e7076c
+
e7076c
+	for (fd = SD_LISTEN_FDS_START; fd < SD_LISTEN_FDS_START + n; fd++) {
e7076c
+		struct __rpc_sockinfo si_other;
e7076c
+		union {
e7076c
+			struct sockaddr sa;
e7076c
+			struct sockaddr_un un;
e7076c
+			struct sockaddr_in in4;
e7076c
+			struct sockaddr_in6 in6;
e7076c
+			struct sockaddr_storage storage;
e7076c
+		} sa;
e7076c
+		socklen_t addrlen = sizeof(sa);
e7076c
+
e7076c
+		if (!__rpc_fd2sockinfo(fd, &si_other)) {
e7076c
+			syslog(LOG_ERR, "cannot get information for fd %i", fd);
e7076c
+			return 1;
e7076c
+		}
e7076c
+
e7076c
+		if (si.si_af != si_other.si_af ||
e7076c
+                    si.si_socktype != si_other.si_socktype ||
e7076c
+                    si.si_proto != si_other.si_proto)
e7076c
+			continue;
e7076c
+
e7076c
+		if (getsockname(fd, &sa.sa, &addrlen) < 0) {
e7076c
+			syslog(LOG_ERR, "failed to query socket name: %s",
e7076c
+                               strerror(errno));
e7076c
+			goto error;
e7076c
+		}
e7076c
+
e7076c
+		/* Copy the address */
e7076c
+		taddr.addr.maxlen = taddr.addr.len = addrlen;
e7076c
+		taddr.addr.buf = malloc(addrlen);
e7076c
+		if (taddr.addr.buf == NULL) {
e7076c
+			syslog(LOG_ERR,
e7076c
+                               "cannot allocate memory for %s address",
e7076c
+                               nconf->nc_netid);
e7076c
+			goto error;
e7076c
+		}
e7076c
+		memcpy(taddr.addr.buf, &sa, addrlen);
e7076c
+
e7076c
+		my_xprt = (SVCXPRT *)svc_tli_create(fd, nconf, &taddr,
e7076c
+                          RPC_MAXDATASIZE, RPC_MAXDATASIZE);
e7076c
+		if (my_xprt == (SVCXPRT *)NULL) {
e7076c
+			syslog(LOG_ERR, "%s: could not create service",
e7076c
+                               nconf->nc_netid);
e7076c
+			goto error;
e7076c
+		}
e7076c
+	}
e7076c
+
e7076c
+	/*
e7076c
+	 * If none of the systemd sockets matched, we set up the socket in
e7076c
+	 * the normal way:
e7076c
+	 */
e7076c
+#endif
e7076c
+	if (my_xprt != NULL)
e7076c
+		goto got_socket;
e7076c
 
e7076c
 	/*
e7076c
 	 * XXX - using RPC library internal functions. For NC_TPI_CLTS
e7076c
@@ -322,12 +396,6 @@ init_transport(struct netconfig *nconf)
e7076c
 		}
e7076c
 	}
e7076c
 
e7076c
-	if (!__rpc_nconf2sockinfo(nconf, &si)) {
e7076c
-		syslog(LOG_ERR, "cannot get information for %s",
e7076c
-		    nconf->nc_netid);
e7076c
-		return (1);
e7076c
-	}
e7076c
-
e7076c
 	if ((strcmp(nconf->nc_netid, "local") == 0) ||
e7076c
 	    (strcmp(nconf->nc_netid, "unix") == 0)) {
e7076c
 		memset(&sun, 0, sizeof sun);
e7076c
@@ -564,6 +632,7 @@ init_transport(struct netconfig *nconf)
e7076c
 			goto error;
e7076c
 		}
e7076c
 	}
e7076c
+got_socket:
e7076c
 
e7076c
 #ifdef PORTMAP
e7076c
 	/*