|
|
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 |
/*
|